2013-11-25 22:00:19 +04:00
|
|
|
(function () {
|
|
|
|
var ns = $.namespace('pskl.model');
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @constructor
|
|
|
|
* @param {Number} width
|
|
|
|
* @param {Number} height
|
2014-03-30 05:12:56 +04:00
|
|
|
* @param {String} name
|
|
|
|
* @param {String} description
|
2013-11-25 22:00:19 +04:00
|
|
|
*/
|
2014-03-30 05:12:56 +04:00
|
|
|
ns.Piskel = function (width, height, descriptor) {
|
|
|
|
if (width && height && descriptor) {
|
2013-11-25 22:00:19 +04:00
|
|
|
/** @type {Array} */
|
|
|
|
this.layers = [];
|
|
|
|
|
|
|
|
/** @type {Number} */
|
|
|
|
this.width = width;
|
|
|
|
|
|
|
|
/** @type {Number} */
|
|
|
|
this.height = height;
|
2014-03-30 05:12:56 +04:00
|
|
|
|
|
|
|
this.descriptor = descriptor;
|
2013-11-25 22:00:19 +04:00
|
|
|
} else {
|
|
|
|
throw 'Missing arguments in Piskel constructor : ' + Array.prototype.join.call(arguments, ",");
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Create a piskel instance from an existing set of (non empty) layers
|
|
|
|
* Layers should all be synchronized : same number of frames, same dimensions
|
|
|
|
* @param {Array<pskl.model.Layer>} layers
|
|
|
|
* @return {pskl.model.Piskel}
|
|
|
|
*/
|
2014-03-30 05:12:56 +04:00
|
|
|
ns.Piskel.fromLayers = function (layers, descriptor) {
|
2013-11-25 22:00:19 +04:00
|
|
|
var piskel = null;
|
|
|
|
if (layers.length > 0 && layers[0].length() > 0) {
|
|
|
|
var sampleFrame = layers[0].getFrameAt(0);
|
2014-03-30 05:12:56 +04:00
|
|
|
piskel = new pskl.model.Piskel(sampleFrame.getWidth(), sampleFrame.getHeight(), descriptor);
|
2013-11-25 22:00:19 +04:00
|
|
|
layers.forEach(piskel.addLayer.bind(piskel));
|
|
|
|
} else {
|
|
|
|
throw 'Piskel.fromLayers expects array of non empty pskl.model.Layer as first argument';
|
|
|
|
}
|
|
|
|
return piskel;
|
|
|
|
};
|
|
|
|
|
|
|
|
ns.Piskel.prototype.getLayers = function () {
|
|
|
|
return this.layers;
|
|
|
|
};
|
|
|
|
|
|
|
|
ns.Piskel.prototype.getHeight = function () {
|
|
|
|
return this.height;
|
|
|
|
};
|
|
|
|
|
|
|
|
ns.Piskel.prototype.getWidth = function () {
|
|
|
|
return this.width;
|
|
|
|
};
|
|
|
|
|
|
|
|
ns.Piskel.prototype.getLayers = function () {
|
|
|
|
return this.layers;
|
|
|
|
};
|
|
|
|
|
|
|
|
ns.Piskel.prototype.getLayerAt = function (index) {
|
|
|
|
return this.layers[index];
|
|
|
|
};
|
|
|
|
|
|
|
|
ns.Piskel.prototype.getLayersByName = function (name) {
|
|
|
|
return this.layers.filter(function (l) {
|
|
|
|
return l.getName() == name;
|
|
|
|
});
|
|
|
|
};
|
|
|
|
|
|
|
|
ns.Piskel.prototype.addLayer = function (layer) {
|
|
|
|
this.layers.push(layer);
|
|
|
|
};
|
|
|
|
|
|
|
|
ns.Piskel.prototype.moveLayerUp = function (layer) {
|
|
|
|
var index = this.layers.indexOf(layer);
|
|
|
|
if (index > -1 && index < this.layers.length-1) {
|
|
|
|
this.layers[index] = this.layers[index+1];
|
|
|
|
this.layers[index+1] = layer;
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
ns.Piskel.prototype.moveLayerDown = function (layer) {
|
|
|
|
var index = this.layers.indexOf(layer);
|
|
|
|
if (index > 0) {
|
|
|
|
this.layers[index] = this.layers[index-1];
|
|
|
|
this.layers[index-1] = layer;
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
ns.Piskel.prototype.removeLayer = function (layer) {
|
|
|
|
var index = this.layers.indexOf(layer);
|
|
|
|
if (index != -1) {
|
|
|
|
this.layers.splice(index, 1);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
ns.Piskel.prototype.removeLayerAt = function (index) {
|
|
|
|
this.layers.splice(index, 1);
|
|
|
|
};
|
|
|
|
|
2014-03-30 05:12:56 +04:00
|
|
|
ns.Piskel.prototype.getDescriptor = function () {
|
|
|
|
return this.descriptor;
|
|
|
|
};
|
|
|
|
|
|
|
|
ns.Piskel.prototype.setDescriptor = function (descriptor) {
|
|
|
|
this.descriptor = descriptor;
|
|
|
|
var appEngineEditorHeader = $('.piskel-name').html(this.descriptor.name);
|
|
|
|
};
|
|
|
|
|
2013-11-25 22:00:19 +04:00
|
|
|
})();
|