mirror of
https://github.com/piskelapp/piskel.git
synced 2023-08-10 21:12:52 +03:00
deploy dev version
This commit is contained in:
96
dev/js/rendering/layer/LayersRenderer.js
Normal file
96
dev/js/rendering/layer/LayersRenderer.js
Normal file
@@ -0,0 +1,96 @@
|
||||
(function () {
|
||||
var ns = $.namespace('pskl.rendering.layer');
|
||||
|
||||
ns.LayersRenderer = function (container, renderingOptions, piskelController) {
|
||||
pskl.rendering.CompositeRenderer.call(this);
|
||||
|
||||
this.piskelController = piskelController;
|
||||
|
||||
// Do not use CachedFrameRenderers here, since the caching will be performed in the render method of LayersRenderer
|
||||
this.belowRenderer = new pskl.rendering.frame.FrameRenderer(container, renderingOptions,
|
||||
['layers-canvas', 'layers-below-canvas']);
|
||||
|
||||
this.aboveRenderer = new pskl.rendering.frame.FrameRenderer(container, renderingOptions,
|
||||
['layers-canvas', 'layers-above-canvas']);
|
||||
|
||||
this.add(this.belowRenderer);
|
||||
this.add(this.aboveRenderer);
|
||||
|
||||
this.serializedRendering = '';
|
||||
|
||||
this.stylesheet_ = document.createElement('style');
|
||||
document.head.appendChild(this.stylesheet_);
|
||||
this.updateLayersCanvasOpacity_(pskl.UserSettings.get(pskl.UserSettings.LAYER_OPACITY));
|
||||
|
||||
$.subscribe(Events.PISKEL_RESET, this.flush.bind(this));
|
||||
$.subscribe(Events.USER_SETTINGS_CHANGED, $.proxy(this.onUserSettingsChange_, this));
|
||||
};
|
||||
|
||||
pskl.utils.inherit(pskl.rendering.layer.LayersRenderer, pskl.rendering.CompositeRenderer);
|
||||
|
||||
ns.LayersRenderer.prototype.render = function () {
|
||||
var offset = this.getOffset();
|
||||
var size = this.getDisplaySize();
|
||||
var layers = this.piskelController.getLayers();
|
||||
var frameIndex = this.piskelController.getCurrentFrameIndex();
|
||||
var layerIndex = this.piskelController.getCurrentLayerIndex();
|
||||
|
||||
var belowLayers = layers.slice(0, layerIndex);
|
||||
var aboveLayers = layers.slice(layerIndex + 1, layers.length);
|
||||
|
||||
var serializedRendering = [
|
||||
this.getZoom(),
|
||||
this.getGridWidth(),
|
||||
offset.x,
|
||||
offset.y,
|
||||
size.width,
|
||||
size.height,
|
||||
pskl.utils.LayerUtils.getFrameHashAt(belowLayers, frameIndex),
|
||||
pskl.utils.LayerUtils.getFrameHashAt(aboveLayers, frameIndex),
|
||||
layers.length
|
||||
].join('-');
|
||||
|
||||
if (this.serializedRendering != serializedRendering) {
|
||||
this.serializedRendering = serializedRendering;
|
||||
|
||||
this.clear();
|
||||
|
||||
if (belowLayers.length > 0) {
|
||||
var belowFrame = pskl.utils.LayerUtils.mergeFrameAt(belowLayers, frameIndex);
|
||||
this.belowRenderer.render(belowFrame);
|
||||
}
|
||||
|
||||
if (aboveLayers.length > 0) {
|
||||
var aboveFrame = pskl.utils.LayerUtils.mergeFrameAt(aboveLayers, frameIndex);
|
||||
this.aboveRenderer.render(aboveFrame);
|
||||
}
|
||||
}
|
||||
};
|
||||
|
||||
/**
|
||||
* See @pskl.rendering.frame.CachedFrameRenderer
|
||||
* Same issue : FrameRenderer setDisplaySize destroys the canvas
|
||||
* @param {Number} width
|
||||
* @param {Number} height
|
||||
*/
|
||||
ns.LayersRenderer.prototype.setDisplaySize = function (width, height) {
|
||||
var size = this.getDisplaySize();
|
||||
if (size.width !== width || size.height !== height) {
|
||||
this.superclass.setDisplaySize.call(this, width, height);
|
||||
}
|
||||
};
|
||||
|
||||
ns.LayersRenderer.prototype.onUserSettingsChange_ = function (evt, settingsName, settingsValue) {
|
||||
if (settingsName == pskl.UserSettings.LAYER_OPACITY) {
|
||||
this.updateLayersCanvasOpacity_(settingsValue);
|
||||
}
|
||||
};
|
||||
|
||||
ns.LayersRenderer.prototype.updateLayersCanvasOpacity_ = function (opacity) {
|
||||
this.stylesheet_.innerHTML = '.layers-canvas { opacity : ' + opacity + '}';
|
||||
};
|
||||
|
||||
ns.LayersRenderer.prototype.flush = function () {
|
||||
this.serializedRendering = '';
|
||||
};
|
||||
})();
|
||||
Reference in New Issue
Block a user