paper.js/src/project/Symbol.js

117 lines
2.9 KiB
JavaScript
Raw Normal View History

/*
* Paper.js
*
* This file is part of Paper.js, a JavaScript Vector Graphics Library,
* based on Scriptographer.org and designed to be largely API compatible.
* http://paperjs.org/
* http://scriptographer.org/
*
* Copyright (c) 2011, Juerg Lehni & Jonathan Puckey
* http://lehni.org/ & http://jonathanpuckey.com/
*
2011-07-01 06:17:45 -04:00
* Distributed under the MIT license. See LICENSE file for details.
*
* All rights reserved.
*/
/**
* @name Symbol
*
* @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.
*/
var Symbol = this.Symbol = Base.extend(/** @lends Symbol# */{
/**
* Creates a Symbol item.
*
* @param {Item} item the source item which is copied as the definition of
* the symbol
*
2011-06-03 16:25:37 -04:00
* @example {@paperscript split=true height=240}
* // Placing 100 instances of a symbol:
* var path = new Path.Star(new Point(0, 0), 6, 5, 13);
* path.style = {
* fillColor: 'white',
* strokeColor: 'black'
* };
*
2011-06-03 16:25:37 -04:00
* // Create a symbol from the path:
* var symbol = new Symbol(path);
*
2011-06-03 16:25:37 -04:00
* // Remove the path:
* path.remove();
*
2011-06-03 16:25:37 -04:00
* // Place 100 instances of the symbol:
* for (var i = 0; i < 100; i++) {
* // Place an instance of the symbol in the project:
* var instance = symbol.place();
*
2011-06-03 16:25:37 -04:00
* // Move the instance to a random position within the view:
* instance.position = Point.random() * view.size;
*
2011-06-03 16:25:37 -04:00
* // Rotate the instance by a random amount between
* // 0 and 360 degrees:
* instance.rotate(Math.random() * 360);
*
2011-06-03 16:25:37 -04:00
* // Scale the instance between 0.25 and 1:
* instance.scale(0.25 + Math.random() * 0.75);
* }
*/
initialize: function(item) {
this.project = paper.project;
this.project.symbols.push(this);
this.setDefinition(item);
},
// TODO: Symbol#remove()
2011-06-01 05:49:43 -04:00
// TODO: Symbol#name (accessible by name through project#symbols)
/**
* The project that this symbol belongs to.
*
* @type Project
* @readonly
* @name Symbol#project
*/
2011-05-20 03:55:44 -04:00
/**
* The symbol definition.
*
* @type Item
* @bean
*/
getDefinition: function() {
return this._definition;
},
setDefinition: function(item) {
this._definition = item;
// Remove item from DOM, as it's embedded in Symbol now.
item.remove();
2011-05-20 03:55:44 -04:00
// Move position to 0, 0. TODO: Why?
item.setPosition(new Point());
},
2011-06-03 16:25:37 -04:00
/**
* Places in instance of the symbol in the project.
*
2011-06-03 16:25:37 -04:00
* @param [position] The position of the placed symbol.
* @return {PlacedSymbol}
*/
place: function(position) {
return new PlacedSymbol(this, position);
},
/**
* Returns a copy of the symbol.
*
* @return {Symbol}
*/
clone: function() {
return new Symbol(this._definition.clone());
}
});