mirror of
https://github.com/scratchfoundation/paper.js.git
synced 2025-01-09 22:32:48 -05:00
114 lines
3.1 KiB
JavaScript
114 lines
3.1 KiB
JavaScript
/*
|
|
* 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/
|
|
*
|
|
* Distributed under the MIT license. See LICENSE file for details.
|
|
*
|
|
* Copyright (c) 2011, Juerg Lehni & Jonathan Puckey
|
|
* http://lehni.org/ & http://jonathanpuckey.com/
|
|
*
|
|
* All rights reserved.
|
|
*/
|
|
|
|
var PlacedSymbol = this.PlacedSymbol = Item.extend({
|
|
/** @lends PlacedSymbol# */
|
|
|
|
beans: true,
|
|
|
|
/**
|
|
* Creates a new PlacedSymbol Item.
|
|
*
|
|
* @example
|
|
* var path = new Path.Star(new Point(0, 0), 6, 5, 13);
|
|
* path.style = {
|
|
* fillColor: 'white',
|
|
* strokeColor: 'black'
|
|
* };
|
|
*
|
|
* // Create a symbol from the path:
|
|
* // (the original path is removed from the project)
|
|
* var symbol = new Symbol(path);
|
|
*
|
|
* // 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);
|
|
*
|
|
* // Move the instance to a random position within the view:
|
|
* instance.position = Point.random() * view.size;
|
|
*
|
|
* // Rotate the instance by a random amount between
|
|
* // 0 and 360 degrees:
|
|
* instance.rotate(Math.random() * 360);
|
|
*
|
|
* // Scale the instance between 0.25 and 1:
|
|
* instance.scale(0.25 + Math.random() * 0.75);
|
|
* }
|
|
*
|
|
* @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.
|
|
*
|
|
* @class A PlacedSymbol represents a symbol which has been placed in a
|
|
* Paper.js project.
|
|
*
|
|
* @extends Item
|
|
* @constructs PlacedSymbol
|
|
*/
|
|
initialize: function(symbol, matrixOrOffset) {
|
|
this.base();
|
|
this.symbol = symbol instanceof Symbol ? symbol : new Symbol(symbol);
|
|
this.matrix = matrixOrOffset !== undefined
|
|
? matrixOrOffset instanceof Matrix
|
|
? matrixOrOffset
|
|
: new Matrix().translate(Point.read(arguments, 1))
|
|
: new Matrix();
|
|
},
|
|
|
|
/**
|
|
* The symbol contained within the placed symbol.
|
|
*
|
|
* @name PlacedSymbol#symbol
|
|
* @type Symbol
|
|
*/
|
|
|
|
clone: function() {
|
|
return this._clone(new PlacedSymbol(this.symbol, this.matrix.clone()));
|
|
},
|
|
|
|
_transform: function(matrix, flags) {
|
|
// In order to set the right context transformation when drawing the
|
|
// raster, simply preconcatenate the internal matrix with the provided
|
|
// one.
|
|
this.matrix.preConcatenate(matrix);
|
|
},
|
|
|
|
getBounds: function() {
|
|
var bounds = this.symbol._definition.getStrokeBounds(this.matrix);
|
|
return LinkedRectangle.create(this, 'setBounds',
|
|
bounds.x, bounds.y, bounds.width, bounds.height);
|
|
},
|
|
|
|
getStrokeBounds: function() {
|
|
return this.getBounds();
|
|
},
|
|
|
|
draw: function(ctx, param) {
|
|
if (param.selection) {
|
|
Item.drawSelectedBounds(this.symbol._definition.getStrokeBounds(),
|
|
ctx, this.matrix);
|
|
} else {
|
|
ctx.save();
|
|
this.matrix.applyToContext(ctx);
|
|
Item.draw(this.symbol.getDefinition(), ctx, param);
|
|
ctx.restore();
|
|
}
|
|
}
|
|
|
|
// TODO: PlacedSymbol#embed()
|
|
});
|