paper.js/src/item/PlacedSymbol.js

116 lines
3.1 KiB
JavaScript
Raw Normal View History

2011-03-06 19:50:44 -05:00
/*
* Paper.js
*
2011-03-06 19:50:44 -05:00
* This file is part of Paper.js, a JavaScript Vector Graphics Library,
* based on Scriptographer.org and designed to be largely API compatible.
2011-03-07 20:41:50 -05:00
* http://paperjs.org/
2011-03-06 19:50:44 -05:00
* http://scriptographer.org/
*
2011-03-06 19:50:44 -05:00
* 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.
*
2011-03-07 20:41:50 -05:00
* All rights reserved.
2011-03-06 19:50:44 -05:00
*/
/**
* @name PlacedSymbol
*
* @class A PlacedSymbol represents an instance of a symbol which has been
* placed in a Paper.js project.
*
* @extends PlacedItem
*/
var PlacedSymbol = this.PlacedSymbol = PlacedItem.extend(/** @lends PlacedSymbol# */{
2011-05-23 13:48:03 -04:00
/**
* Creates a new PlacedSymbol Item.
*
* @param {Symbol} symbol the symbol to place
* @param {Point|Matrix} [matrixOrOffset] the center point of the placed
* symbol or a {@link Matrix} transformation to transform the placed symbol
* with.
*
2011-06-03 16:25:37 -04:00
* @example {@paperscript split=true height=240}
* // Placing 100 instances of a symbol:
2011-05-23 13:48:03 -04:00
* var path = new Path.Star(new Point(0, 0), 6, 5, 13);
* path.style = {
* fillColor: 'white',
* strokeColor: 'black'
* };
*
2011-05-23 13:48:03 -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-05-23 13:48:03 -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 = new PlacedSymbol(symbol);
*
2011-05-23 13:48:03 -04:00
* // Move the instance to a random position within the view:
* instance.position = Point.random() * view.size;
*
2011-05-23 13:48:03 -04:00
* // Rotate the instance by a random amount between
* // 0 and 360 degrees:
* instance.rotate(Math.random() * 360);
*
2011-05-23 13:48:03 -04:00
* // Scale the instance between 0.25 and 1:
* instance.scale(0.25 + Math.random() * 0.75);
* }
*/
initialize: function(symbol, matrixOrOffset) {
this.base();
this.setSymbol(symbol instanceof Symbol ? symbol : new Symbol(symbol));
this._matrix = matrixOrOffset !== undefined
2011-05-07 08:12:46 -04:00
? matrixOrOffset instanceof Matrix
? matrixOrOffset
: new Matrix().translate(Point.read(arguments, 1))
: new Matrix();
},
2011-05-23 13:48:03 -04:00
/**
2011-07-09 03:28:49 -04:00
* The symbol that the placed symbol refers to.
*
2011-05-23 13:48:03 -04:00
* @type Symbol
* @bean
2011-05-23 13:48:03 -04:00
*/
getSymbol: function() {
return this._symbol;
},
setSymbol: function(symbol) {
// Remove from previous symbol's instances
if (this._symbol)
delete this._symbol._instances[this._id];
this._symbol = symbol;
// Add to the new one's
symbol._instances[this._id] = this;
},
2011-05-23 13:48:03 -04:00
clone: function() {
return this._clone(new PlacedSymbol(this.symbol, this._matrix.clone()));
},
_getBounds: function(baseItem, type, matrix) {
// Redirect the call to the symbol definition to calculate the bounds
return this.symbol._definition._getBounds(baseItem, type, matrix);
},
draw: function(ctx, param) {
2011-04-21 09:48:21 -04:00
if (param.selection) {
Item.drawSelectedBounds(this._getBounds(this, 'bounds'), ctx,
this._matrix);
2011-04-21 09:48:21 -04:00
} else {
ctx.save();
this._matrix.applyToContext(ctx);
2011-04-21 09:48:21 -04:00
Item.draw(this.symbol.getDefinition(), ctx, param);
ctx.restore();
}
}
2011-05-23 13:48:03 -04:00
// TODO: PlacedSymbol#embed()
2011-03-03 11:32:55 -05:00
});