piskel/zoom/js/controller/AnimatedPreviewController.js

72 lines
2.5 KiB
JavaScript
Raw Normal View History

2013-10-30 01:21:57 +04:00
(function () {
var ns = $.namespace("pskl.controller");
ns.AnimatedPreviewController = function (piskelController, container, dpi) {
this.piskelController = piskelController;
this.container = container;
this.elapsedTime = 0;
this.currentIndex = 0;
this.setFPS(Constants.DEFAULT.FPS);
2013-11-02 02:16:38 +04:00
var zoom = this.calculateZoom_();
2013-10-30 01:21:57 +04:00
var renderingOptions = {
2013-11-02 02:16:38 +04:00
"zoom": zoom,
"height" : this.piskelController.getCurrentFrame().getHeight() * zoom,
"width" : this.piskelController.getCurrentFrame().getWidth() * zoom
2013-10-30 01:21:57 +04:00
};
2013-11-02 02:16:38 +04:00
this.renderer = new pskl.rendering.frame.FrameRenderer(this.container, renderingOptions);
2013-10-30 01:21:57 +04:00
2013-11-02 02:16:38 +04:00
$.subscribe(Events.FRAME_SIZE_CHANGED, this.updateZoom_.bind(this));
2013-10-30 01:21:57 +04:00
};
ns.AnimatedPreviewController.prototype.init = function () {
// the oninput event won't work on IE10 unfortunately, but at least will provide a
// consistent behavior across all other browsers that support the input type range
// see https://bugzilla.mozilla.org/show_bug.cgi?id=853670
$("#preview-fps")[0].addEventListener('change', this.onFPSSliderChange.bind(this));
};
ns.AnimatedPreviewController.prototype.onFPSSliderChange = function (evt) {
this.setFPS(parseInt($("#preview-fps")[0].value, 10));
};
ns.AnimatedPreviewController.prototype.setFPS = function (fps) {
this.fps = fps;
$("#preview-fps").val(this.fps);
$("#display-fps").html(this.fps + " FPS");
};
ns.AnimatedPreviewController.prototype.getFPS = function () {
return this.fps;
};
ns.AnimatedPreviewController.prototype.render = function (delta) {
this.elapsedTime += delta;
var index = Math.floor(this.elapsedTime / (1000/this.fps));
if (index != this.currentIndex) {
this.currentIndex = index;
if (!this.piskelController.hasFrameAt(this.currentIndex)) {
this.currentIndex = 0;
this.elapsedTime = 0;
}
this.renderer.render(this.piskelController.getFrameAt(this.currentIndex));
}
};
/**
* Calculate the preview DPI depending on the framesheet size
*/
ns.AnimatedPreviewController.prototype.calculateZoom_ = function () {
var previewSize = 200,
2013-11-02 02:16:38 +04:00
hZoom = previewSize / this.piskelController.getCurrentFrame().getHeight(),
wZoom = previewSize / this.piskelController.getCurrentFrame().getWidth();
2013-10-30 01:21:57 +04:00
2013-11-02 02:16:38 +04:00
return Math.min(hZoom, wZoom);
2013-10-30 01:21:57 +04:00
};
2013-11-02 02:16:38 +04:00
ns.AnimatedPreviewController.prototype.updateZoom_ = function () {
var zoom = this.calculateZoom_();
this.renderer.setZoom(zoom);
2013-10-30 01:21:57 +04:00
};
})();