2011-07-01 05:26:51 -04:00
|
|
|
/*
|
|
|
|
* Paper.js
|
2011-07-01 06:01:32 -04:00
|
|
|
*
|
2011-07-01 05:26:51 -04:00
|
|
|
* 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/
|
2011-07-01 06:01:32 -04:00
|
|
|
*
|
2011-07-01 05:26:51 -04:00
|
|
|
* Copyright (c) 2011, Juerg Lehni & Jonathan Puckey
|
|
|
|
* http://lehni.org/ & http://jonathanpuckey.com/
|
2011-07-01 06:01:32 -04:00
|
|
|
*
|
2011-07-01 06:17:45 -04:00
|
|
|
* Distributed under the MIT license. See LICENSE file for details.
|
|
|
|
*
|
2011-07-01 05:26:51 -04:00
|
|
|
* All rights reserved.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @name PlacedItem
|
2011-07-01 06:01:32 -04:00
|
|
|
*
|
2011-07-01 05:26:51 -04:00
|
|
|
* @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}.
|
2011-07-01 06:01:32 -04:00
|
|
|
*
|
2011-07-01 05:26:51 -04:00
|
|
|
* @extends Item
|
|
|
|
*/
|
|
|
|
var PlacedItem = this.PlacedItem = Item.extend(/** @lends PlacedItem# */{
|
|
|
|
|
|
|
|
_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.
|
2011-07-01 05:32:09 -04:00
|
|
|
this._matrix.preConcatenate(matrix);
|
|
|
|
},
|
|
|
|
|
2011-07-04 13:45:53 -04:00
|
|
|
_changed: function(flags) {
|
|
|
|
// Don't use base() for reasons of performance.
|
|
|
|
Item.prototype._changed.call(this, flags);
|
|
|
|
if (flags & ChangeFlag.GEOMETRY) {
|
|
|
|
delete this._strokeBounds;
|
|
|
|
// TODO: These are not used in Raster. Do we mind?
|
|
|
|
delete this._handleBounds;
|
|
|
|
delete this._roughBounds;
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
2011-07-01 05:32:09 -04:00
|
|
|
/**
|
|
|
|
* The item's transformation matrix, defining position and dimensions in the
|
|
|
|
* document.
|
|
|
|
*
|
|
|
|
* @type Matrix
|
|
|
|
* @bean
|
|
|
|
*/
|
|
|
|
getMatrix: function() {
|
|
|
|
return this._matrix;
|
|
|
|
},
|
|
|
|
|
|
|
|
setMatrix: function(matrix) {
|
|
|
|
this._matrix = matrix.clone();
|
|
|
|
this._changed(Change.GEOMETRY);
|
2011-07-01 05:26:51 -04:00
|
|
|
},
|
|
|
|
|
2011-07-04 13:45:53 -04:00
|
|
|
getBounds: function(/* matrix */) {
|
|
|
|
var useCache = arguments[0] === undefined;
|
|
|
|
if (useCache && this._bounds)
|
|
|
|
return this._bounds;
|
2011-07-04 17:28:28 -04:00
|
|
|
// The bounds of PlacedItems are the same as the strokeBounds, but are
|
|
|
|
// wrapped in a LinkedRectangle that catch changes for us.
|
2011-07-04 13:45:53 -04:00
|
|
|
var bounds = this.getStrokeBounds(arguments[0]);
|
|
|
|
if (useCache)
|
|
|
|
bounds = this._bounds = this._createBounds(bounds);
|
|
|
|
return bounds;
|
|
|
|
},
|
|
|
|
|
2011-11-20 12:51:34 -05:00
|
|
|
_getBounds: function(getter, cacheName, matrix) {
|
|
|
|
var useCache = matrix === undefined;
|
2011-07-04 13:45:53 -04:00
|
|
|
if (useCache && this[cacheName])
|
|
|
|
return this[cacheName];
|
2011-07-04 17:28:28 -04:00
|
|
|
// Concatenate the passed matrix with the internal one
|
2011-07-04 13:45:53 -04:00
|
|
|
matrix = matrix ? matrix.clone().concatenate(this._matrix)
|
|
|
|
: this._matrix;
|
|
|
|
// Call _calculateBounds, which needs to be defined in the subclasses:
|
|
|
|
var bounds = this._calculateBounds(getter, matrix);
|
|
|
|
if (useCache)
|
|
|
|
this[cacheName] = bounds;
|
|
|
|
return bounds;
|
2011-07-01 05:26:51 -04:00
|
|
|
}
|
|
|
|
});
|