mirror of
https://github.com/piskelapp/piskel.git
synced 2023-08-10 21:12:52 +03:00
125 lines
4.2 KiB
JavaScript
125 lines
4.2 KiB
JavaScript
(function () {
|
|
var ns = $.namespace("pskl.controller");
|
|
|
|
// Preview is a square of PREVIEW_SIZE x PREVIEW_SIZE
|
|
var PREVIEW_SIZE = 200;
|
|
|
|
ns.AnimatedPreviewController = function (piskelController, container) {
|
|
this.piskelController = piskelController;
|
|
this.container = container;
|
|
|
|
this.elapsedTime = 0;
|
|
this.currentIndex = 0;
|
|
|
|
this.setFPS(Constants.DEFAULT.FPS);
|
|
|
|
var frame = this.piskelController.getCurrentFrame();
|
|
|
|
this.renderer = new pskl.rendering.frame.TiledFrameRenderer(this.container);
|
|
this.updateZoom_();
|
|
$.subscribe(Events.FRAME_SIZE_CHANGED, this.onFrameSizeChange_.bind(this));
|
|
$.subscribe(Events.USER_SETTINGS_CHANGED, $.proxy(this.onUserSettingsChange_, this));
|
|
};
|
|
|
|
ns.AnimatedPreviewController.prototype.onUserSettingsChange_ = function () {
|
|
this.updateZoom_();
|
|
this.updateContainerDimensions_();
|
|
};
|
|
|
|
ns.AnimatedPreviewController.prototype.updateZoom_ = function () {
|
|
var isTiled = pskl.UserSettings.get(pskl.UserSettings.TILED_PREVIEW);
|
|
var zoom = isTiled ? 1 : this.calculateZoom_();
|
|
this.renderer.setZoom(zoom);
|
|
};
|
|
|
|
ns.AnimatedPreviewController.prototype.getZoom = function () {
|
|
return this.calculateZoom_();
|
|
};
|
|
|
|
ns.AnimatedPreviewController.prototype.getCoordinates = function(x, y) {
|
|
var containerOffset = this.container.offset();
|
|
x = x - containerOffset.left;
|
|
y = y - containerOffset.top;
|
|
var zoom = this.getZoom();
|
|
return {
|
|
x : Math.floor(x / zoom),
|
|
y : Math.floor(y / zoom)
|
|
};
|
|
};
|
|
|
|
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));
|
|
document.querySelector(".right-column").style.width = Constants.ANIMATED_PREVIEW_WIDTH + 'px';
|
|
};
|
|
|
|
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;
|
|
}
|
|
var frame = this.piskelController.getFrameAt(this.currentIndex);
|
|
this.renderer.render(frame);
|
|
}
|
|
};
|
|
|
|
/**
|
|
* Calculate the preview zoom depending on the framesheet size
|
|
*/
|
|
ns.AnimatedPreviewController.prototype.calculateZoom_ = function () {
|
|
var frame = this.piskelController.getCurrentFrame();
|
|
var previewSize = 200,
|
|
hZoom = previewSize / frame.getHeight(),
|
|
wZoom = previewSize / frame.getWidth();
|
|
|
|
return Math.min(hZoom, wZoom);
|
|
};
|
|
|
|
ns.AnimatedPreviewController.prototype.onFrameSizeChange_ = function () {
|
|
this.updateZoom_();
|
|
this.updateContainerDimensions_();
|
|
};
|
|
|
|
ns.AnimatedPreviewController.prototype.updateContainerDimensions_ = function () {
|
|
var containerEl = this.container.get(0);
|
|
var isTiled = pskl.UserSettings.get(pskl.UserSettings.TILED_PREVIEW);
|
|
var height, width;
|
|
|
|
if (isTiled) {
|
|
height = PREVIEW_SIZE;
|
|
width = PREVIEW_SIZE;
|
|
} else {
|
|
var zoom = this.getZoom();
|
|
var frame = this.piskelController.getCurrentFrame();
|
|
height = frame.getHeight() * zoom;
|
|
width = frame.getWidth() * zoom;
|
|
}
|
|
|
|
containerEl.style.height = height + "px";
|
|
containerEl.style.width = width + "px";
|
|
containerEl.style.marginTop = ((PREVIEW_SIZE - height) / 2) + "px";
|
|
containerEl.style.marginBottom = ((PREVIEW_SIZE - height) / 2) + "px";
|
|
containerEl.style.marginLeft = ((PREVIEW_SIZE - width) / 2) + "px";
|
|
containerEl.style.marginRight = ((PREVIEW_SIZE - width) / 2) + "px";
|
|
};
|
|
})(); |