Symbol documentation & move Symbol#clone below Symbol#setDefinition.

This commit is contained in:
Jonathan Puckey 2011-05-23 18:28:48 +02:00
parent 14c693aa7c
commit 5bd935be75

View file

@ -15,20 +15,59 @@
*/ */
var Symbol = this.Symbol = Base.extend({ var Symbol = this.Symbol = Base.extend({
/** @lends Symbol# */
beans: true, beans: true,
/**
* Creates a Symbol item.
*
* Sample code:
* @example
* var circlePath = new Path.Circle(new Point(100, 100), 50);
* circlePath.fillColor = 'red';
*
* var circleSymbol = new Symbol(circlePath);
* circleSymbol.name = 'Circle';
*
* // The original item is still contained in the document:
* circlePath.remove();
*
* // The symbol can now also be accessed
* // through project.symbols:
* console.log(project.symbols['Circle']);
*
* // To place instances of the symbol in the document:
* var placedCircle = new PlacedSymbol(circleSymbol);
* placedCircle.position = new Point(150, 150);
*
* @param {Item} item the source item which is copied as the definition of
* the symbol
*
* @name Symbol
* @constructor
*
* @class Symbols allow you to place multiple instances of an item in your
* project. This can save memory, since all instances of a symbol
* simply refer to the original item and it can speed up moving
* around complex objects, since internal properties such as segment
* lists and gradient positions don't need to be updated with every
* transformation.
*/
initialize: function(item) { initialize: function(item) {
this.project = paper.project; this.project = paper.project;
this.project.symbols.push(this); this.project.symbols.push(this);
this.setDefinition(item); this.setDefinition(item);
}, },
clone: function() {
return new Symbol(this._definition.clone());
},
// TODO: remove() // TODO: remove()
/**
* The symbol definition.
*
* @type Item
* @bean
*/
getDefinition: function() { getDefinition: function() {
return this._definition; return this._definition;
}, },
@ -40,5 +79,14 @@ var Symbol = this.Symbol = Base.extend({
item._removeFromParent(); item._removeFromParent();
// Move position to 0, 0. TODO: Why? // Move position to 0, 0. TODO: Why?
item.setPosition(new Point()); item.setPosition(new Point());
},
/**
* Returns a copy of the symbol.
*
* @return {Symbol}
*/
clone: function() {
return new Symbol(this._definition.clone());
} }
}); });