paper.js/src/item/Layer.js

75 lines
1.6 KiB
JavaScript
Raw Normal View History

var Layer = Group.extend({
beans: true,
2011-02-11 12:37:36 -05:00
initialize: function() {
this.children = [];
this.document = Paper.document;
this.document.layers.push(this);
this.activate();
},
getIndex: function() {
return !this.parent ? this.document.layers.indexOf(this) : this.base();
},
/**
* Removes the layer from its document's layers list
* or its parent's children list.
*/
removeFromParent: function() {
2011-02-20 21:32:39 -05:00
if (!this.parent) {
this.document.layers.splice(this.index, 1);
} else {
this.base();
}
},
moveAbove: function(item) {
// if the item is a layer and contained within Document#layers
2011-02-20 21:32:39 -05:00
if (item instanceof Layer && !item.parent) {
this.removeFromParent();
item.document.layers.splice(item.index + 1, 0, this);
this.document = item.document;
return true;
} else {
this.base(item);
}
},
moveBelow: function(item) {
// if the item is a layer and contained within Document#layers
2011-02-20 21:32:39 -05:00
if (item instanceof Layer && !item.parent) {
this.removeFromParent();
item.document.layers.splice(item.index - 1, 0, this);
this.document = item.document;
return true;
} else {
this.base(item);
}
},
getNextSibling: function() {
2011-02-20 21:32:39 -05:00
if (!this.parent) {
var index = this.index + 1;
if (index < this.document.layers.length)
return this.document.layers[index];
} else {
return this.base();
}
},
getPreviousSibling: function() {
2011-02-20 21:32:39 -05:00
if (!this.parent) {
var index = this.index - 1;
if (index <= 0)
return this.document.layers[index];
} else {
return this.base();
}
},
activate: function() {
this.document.activeLayer = this;
2011-02-11 12:37:36 -05:00
}
});