Move PlacedItem#_hitTest() to PlacedSymbol#_hitTest() since it was written for symbols, and remove PlacedItem as it's an empty class now.

This commit is contained in:
Jürg Lehni 2013-04-19 16:40:30 -07:00
parent 8fc2a69136
commit 9cc0822477
6 changed files with 20 additions and 44 deletions

View file

@ -854,7 +854,7 @@ var Item = this.Item = Base.extend(Callback, {
_getBounds: function(getter, matrix, cacheItem) { _getBounds: function(getter, matrix, cacheItem) {
// Note: We cannot cache these results here, since we do not get // Note: We cannot cache these results here, since we do not get
// _changed() notifications here for changing geometry in children. // _changed() notifications here for changing geometry in children.
// But cacheName is used in sub-classes such as PlacedItem. // But cacheName is used in sub-classes such as PlacedSymbol and Raster.
var children = this._children; var children = this._children;
// TODO: What to return if nothing is defined, e.g. empty Groups? // TODO: What to return if nothing is defined, e.g. empty Groups?
// Scriptographer behaves weirdly then too. // Scriptographer behaves weirdly then too.

View file

@ -1,34 +0,0 @@
/*
* Paper.js - The Swiss Army Knife of Vector Graphics Scripting.
* http://paperjs.org/
*
* Copyright (c) 2011 - 2013, Juerg Lehni & Jonathan Puckey
* http://lehni.org/ & http://jonathanpuckey.com/
*
* Distributed under the MIT license. See LICENSE file for details.
*
* All rights reserved.
*/
/**
* @name PlacedItem
*
* @class The PlacedItem class is the base for any items that have a matrix
* associated with them, describing their placement in the project, such as
* {@link Raster} and {@link PlacedSymbol}.
*
* @extends Item
*/
var PlacedItem = this.PlacedItem = Item.extend(/** @lends PlacedItem# */{
// PlacedItem uses strokeBounds for bounds
_boundsGetter: { getBounds: 'getStrokeBounds' },
_hitTest: function(point, options, matrix) {
var result = this._symbol._definition._hitTest(point, options, matrix);
// TODO: When the symbol's definition is a path, should hitResult
// contain information like HitResult#curve?
if (result)
result.item = this;
return result;
}
});

View file

@ -16,10 +16,12 @@
* @class A PlacedSymbol represents an instance of a symbol which has been * @class A PlacedSymbol represents an instance of a symbol which has been
* placed in a Paper.js project. * placed in a Paper.js project.
* *
* @extends PlacedItem * @extends Item
*/ */
var PlacedSymbol = this.PlacedSymbol = PlacedItem.extend(/** @lends PlacedSymbol# */{ var PlacedSymbol = this.PlacedSymbol = Item.extend(/** @lends PlacedSymbol# */{
_class: 'PlacedSymbol', _class: 'PlacedSymbol',
// PlacedSymbol uses strokeBounds for bounds
_boundsGetter: { getBounds: 'getStrokeBounds' },
_boundsSelected: true, _boundsSelected: true,
_serializeFields: { _serializeFields: {
symbol: null symbol: null
@ -110,6 +112,15 @@ var PlacedSymbol = this.PlacedSymbol = PlacedItem.extend(/** @lends PlacedSymbol
return this.symbol._definition._getCachedBounds(getter, matrix); return this.symbol._definition._getCachedBounds(getter, matrix);
}, },
_hitTest: function(point, options, matrix) {
var result = this._symbol._definition._hitTest(point, options, matrix);
// TODO: When the symbol's definition is a path, should hitResult
// contain information like HitResult#curve?
if (result)
result.item = this;
return result;
},
_draw: function(ctx, param) { _draw: function(ctx, param) {
this.symbol._definition.draw(ctx, param); this.symbol._definition.draw(ctx, param);
} }

View file

@ -15,17 +15,17 @@
* *
* @class The Raster item represents an image in a Paper.js project. * @class The Raster item represents an image in a Paper.js project.
* *
* @extends PlacedItem * @extends Item
*/ */
var Raster = this.Raster = PlacedItem.extend(/** @lends Raster# */{ var Raster = this.Raster = Item.extend(/** @lends Raster# */{
_class: 'Raster', _class: 'Raster',
// Raster doesn't make the distinction between the different bounds,
// so use the same name for all of them
_boundsGetter: 'getBounds',
_boundsSelected: true, _boundsSelected: true,
_serializeFields: { _serializeFields: {
source: null source: null
}, },
// Raster doesn't make the distinction between the different bounds,
// so use the same name for all of them
_boundsGetter: 'getBounds',
// TODO: Implement type, width, height. // TODO: Implement type, width, height.
// TODO: Have PlacedSymbol & Raster inherit from a shared class? // TODO: Have PlacedSymbol & Raster inherit from a shared class?

View file

@ -62,7 +62,6 @@ var paper = new function() {
/*#*/ include('item/Item.js'); /*#*/ include('item/Item.js');
/*#*/ include('item/Group.js'); /*#*/ include('item/Group.js');
/*#*/ include('item/Layer.js'); /*#*/ include('item/Layer.js');
/*#*/ include('item/PlacedItem.js');
/*#*/ include('item/Raster.js'); /*#*/ include('item/Raster.js');
/*#*/ include('item/PlacedSymbol.js'); /*#*/ include('item/PlacedSymbol.js');
/*#*/ include('item/HitResult.js'); /*#*/ include('item/HitResult.js');

View file

@ -95,7 +95,7 @@ var Symbol = this.Symbol = Base.extend(/** @lends Symbol# */{
* @param {ChangeFlag} flags describes what exactly has changed. * @param {ChangeFlag} flags describes what exactly has changed.
*/ */
_changed: function(flags) { _changed: function(flags) {
// Notify all PlacedItems of the change in our definition, so they // Notify all PlacedSymbols of the change in our definition, so they
// can clear cached bounds. // can clear cached bounds.
Base.each(this._instances, function(item) { Base.each(this._instances, function(item) {
item._changed(flags); item._changed(flags);