From f0b29e0e4d70d8bf40f63c45f199d7b1678d978d Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?J=C3=BCrg=20Lehni?= Date: Mon, 16 May 2011 11:19:19 +0100 Subject: [PATCH] Make Item#position a LinkedPoint and change the way it's transformed in #transform(). --- src/item/Item.js | 15 ++++++++++----- 1 file changed, 10 insertions(+), 5 deletions(-) diff --git a/src/item/Item.js b/src/item/Item.js index af755ff8..fb931e49 100644 --- a/src/item/Item.js +++ b/src/item/Item.js @@ -512,9 +512,13 @@ var Item = this.Item = Base.extend({ */ getPosition: function() { // Cache position value - if (!this._position) - this._position = this.getBounds().getCenter(); - return this._position.clone(); + if (!this._position) { + // Center is a LinkedPoint as well, so we can use _x and _y + var center = this.getBounds().getCenter(); + this._position = LinkedPoint.create(this, 'setPosition', + center._x, center._y); + } + return this._position; }, setPosition: function(point) { @@ -534,9 +538,10 @@ var Item = this.Item = Base.extend({ // TODO: Call transform on chidren only if 'children' flag is provided if (this._transform) this._transform(matrix, flags); - // Transform position as well + // Transform position as well. Do not modify _position directly, + // since it's a LinkedPoint and would cause recursion! if (this._position) - this._position = matrix._transformPoint(this._position); + matrix._transformPoint(this._position, this._position, true); if (this._children) { for (var i = 0, l = this._children.length; i < l; i++) { var child = this._children[i];