2011-03-06 19:50:44 -05:00
|
|
|
/*
|
2013-01-28 21:03:27 -05:00
|
|
|
* Paper.js - The Swiss Army Knife of Vector Graphics Scripting.
|
2011-03-07 20:41:50 -05:00
|
|
|
* http://paperjs.org/
|
2011-06-30 06:01:51 -04:00
|
|
|
*
|
2015-12-27 12:09:25 -05:00
|
|
|
* Copyright (c) 2011 - 2016, Juerg Lehni & Jonathan Puckey
|
2014-01-03 19:47:16 -05:00
|
|
|
* http://scratchdisk.com/ & http://jonathanpuckey.com/
|
2011-06-30 06:01:51 -04:00
|
|
|
*
|
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
|
|
|
*/
|
|
|
|
|
2011-06-22 18:56:05 -04:00
|
|
|
/**
|
2016-01-31 10:52:51 -05:00
|
|
|
* @name SymbolItem
|
2011-06-30 06:01:51 -04:00
|
|
|
*
|
2016-01-31 10:52:51 -05:00
|
|
|
* @class A symbol item represents an instance of a symbol which has been
|
2011-06-22 18:56:05 -04:00
|
|
|
* placed in a Paper.js project.
|
2011-06-30 06:01:51 -04:00
|
|
|
*
|
2013-04-19 19:40:30 -04:00
|
|
|
* @extends Item
|
2011-06-22 18:56:05 -04:00
|
|
|
*/
|
2016-01-31 10:52:51 -05:00
|
|
|
var SymbolItem = Item.extend(/** @lends SymbolItem# */{
|
|
|
|
_class: 'SymbolItem',
|
2014-08-16 13:24:54 -04:00
|
|
|
_applyMatrix: false,
|
|
|
|
_canApplyMatrix: false,
|
2016-01-31 10:52:51 -05:00
|
|
|
// SymbolItem uses strokeBounds for bounds
|
2014-08-16 13:24:54 -04:00
|
|
|
_boundsGetter: { getBounds: 'getStrokeBounds' },
|
|
|
|
_boundsSelected: true,
|
|
|
|
_serializeFields: {
|
|
|
|
symbol: null
|
|
|
|
},
|
2013-03-01 13:08:17 -05:00
|
|
|
|
2014-08-16 13:24:54 -04:00
|
|
|
/**
|
2016-01-31 10:52:51 -05:00
|
|
|
* Creates a new symbol item.
|
2014-08-16 13:24:54 -04:00
|
|
|
*
|
2016-01-31 10:52:51 -05:00
|
|
|
* @param {Symbol} definition the symbol definition to place
|
2014-08-16 13:24:54 -04:00
|
|
|
* @param {Point} [point] the center point of the placed symbol
|
|
|
|
*
|
|
|
|
* @example {@paperscript split=true height=240}
|
|
|
|
* // Placing 100 instances of a symbol:
|
|
|
|
* // Create a star shaped path at {x: 0, y: 0}:
|
|
|
|
* var path = new Path.Star({
|
|
|
|
* center: new Point(0, 0),
|
|
|
|
* points: 6,
|
|
|
|
* radius1: 5,
|
|
|
|
* radius2: 13,
|
|
|
|
* fillColor: 'white',
|
|
|
|
* strokeColor: 'black'
|
|
|
|
* });
|
|
|
|
*
|
2016-01-31 10:52:51 -05:00
|
|
|
* // Create a symbol definition from the path:
|
|
|
|
* var definition = new SymbolDefinition(path);
|
2014-08-16 13:24:54 -04:00
|
|
|
*
|
|
|
|
* // Place 100 instances of the symbol:
|
|
|
|
* for (var i = 0; i < 100; i++) {
|
|
|
|
* // Place an instance of the symbol in the project:
|
2016-01-31 10:52:51 -05:00
|
|
|
* var instance = new SymbolItem(definition);
|
2014-08-16 13:24:54 -04:00
|
|
|
*
|
|
|
|
* // 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);
|
|
|
|
* }
|
|
|
|
*/
|
2016-01-31 10:52:51 -05:00
|
|
|
initialize: function SymbolItem(arg0, arg1) {
|
2014-08-16 13:24:54 -04:00
|
|
|
// Support two forms of item initialization: Passing one object literal
|
|
|
|
// describing all the different properties to be set, or a symbol (arg0)
|
|
|
|
// and a point where it should be placed (arg1).
|
|
|
|
// If _initialize can set properties through object literal, we're done.
|
|
|
|
// Otherwise we need to set symbol from arg0.
|
|
|
|
if (!this._initialize(arg0,
|
|
|
|
arg1 !== undefined && Point.read(arguments, 1)))
|
2016-01-31 10:52:51 -05:00
|
|
|
this.setDefinition(arg0 instanceof SymbolDefinition ?
|
|
|
|
arg0 : new SymbolDefinition(arg0));
|
2014-08-16 13:24:54 -04:00
|
|
|
},
|
2011-03-03 17:45:17 -05:00
|
|
|
|
2014-08-16 13:24:54 -04:00
|
|
|
_equals: function(item) {
|
2016-01-31 10:52:51 -05:00
|
|
|
// TODO: Compare position too!
|
|
|
|
return this._definition === item._definition;
|
2014-08-16 13:24:54 -04:00
|
|
|
},
|
2013-10-17 07:08:54 -04:00
|
|
|
|
2015-12-26 15:46:36 -05:00
|
|
|
copyContent: function(source) {
|
2016-01-31 10:52:51 -05:00
|
|
|
this.setDefinition(source._definition);
|
2015-12-26 15:46:36 -05:00
|
|
|
},
|
|
|
|
|
2014-08-16 13:24:54 -04:00
|
|
|
/**
|
2016-01-31 10:52:51 -05:00
|
|
|
* The symbol definition that the placed symbol refers to.
|
2014-08-16 13:24:54 -04:00
|
|
|
*
|
|
|
|
* @bean
|
2016-01-31 10:52:51 -05:00
|
|
|
* @type SymbolDefinition
|
2014-08-16 13:24:54 -04:00
|
|
|
*/
|
2016-01-31 10:52:51 -05:00
|
|
|
getDefinition: function() {
|
|
|
|
return this._definition;
|
2014-08-16 13:24:54 -04:00
|
|
|
},
|
2011-07-04 15:27:42 -04:00
|
|
|
|
2016-01-31 10:52:51 -05:00
|
|
|
setDefinition: function(definition) {
|
|
|
|
this._definition = definition;
|
2014-08-16 13:24:54 -04:00
|
|
|
this._changed(/*#=*/Change.GEOMETRY);
|
|
|
|
},
|
2011-05-23 13:48:03 -04:00
|
|
|
|
2016-01-31 10:52:51 -05:00
|
|
|
/**
|
|
|
|
* @bean
|
|
|
|
* @deprecated use {@link #getDefinition()} instead.
|
|
|
|
*/
|
|
|
|
getSymbol: '#getDefinition',
|
|
|
|
setSymbol: '#setDefinition',
|
|
|
|
|
2014-08-16 13:24:54 -04:00
|
|
|
isEmpty: function() {
|
2016-01-31 10:52:51 -05:00
|
|
|
return this._definition._item.isEmpty();
|
2014-08-16 13:24:54 -04:00
|
|
|
},
|
2013-03-03 19:56:48 -05:00
|
|
|
|
2015-12-26 15:46:36 -05:00
|
|
|
|
2016-01-17 17:57:56 -05:00
|
|
|
_getBounds: function(getter, matrix, cacheItem, internal) {
|
2016-01-31 10:52:51 -05:00
|
|
|
var item = this._definition._item;
|
|
|
|
// Redirect the call to the definition item to calculate the bounds.
|
|
|
|
return item._getCachedBounds(getter,
|
|
|
|
matrix && matrix.appended(item._matrix),
|
2016-01-17 17:57:56 -05:00
|
|
|
cacheItem, internal);
|
2014-08-16 13:24:54 -04:00
|
|
|
},
|
2011-03-06 16:26:38 -05:00
|
|
|
|
2014-08-16 13:24:54 -04:00
|
|
|
_hitTestSelf: function(point, options) {
|
2016-01-31 10:52:51 -05:00
|
|
|
var res = this._definition._item._hitTest(point, options);
|
2014-08-16 13:24:54 -04:00
|
|
|
// TODO: When the symbol's definition is a path, should hitResult
|
|
|
|
// contain information like HitResult#curve?
|
|
|
|
if (res)
|
|
|
|
res.item = this;
|
|
|
|
return res;
|
|
|
|
},
|
2013-04-19 19:40:30 -04:00
|
|
|
|
2014-08-16 13:24:54 -04:00
|
|
|
_draw: function(ctx, param) {
|
2016-01-31 10:52:51 -05:00
|
|
|
this._definition._item.draw(ctx, param);
|
2014-08-16 13:24:54 -04:00
|
|
|
}
|
2013-03-01 18:55:19 -05:00
|
|
|
|
2016-01-31 10:52:51 -05:00
|
|
|
// TODO: SymbolItem#embed()
|
2011-03-03 11:32:55 -05:00
|
|
|
});
|