From ee6d59362033009658db0db3701fcc6e109739a4 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?J=C3=BCrg=20Lehni?= Date: Thu, 5 May 2011 11:21:09 +0100 Subject: [PATCH] Cache strokeBounds and bounds only if no transformation matrix is passed. --- src/path/Path.js | 11 +++++++++-- 1 file changed, 9 insertions(+), 2 deletions(-) diff --git a/src/path/Path.js b/src/path/Path.js index 1241d47b..41ee46c2 100644 --- a/src/path/Path.js +++ b/src/path/Path.js @@ -1011,10 +1011,13 @@ var Path = this.Path = PathItem.extend({ * @param matrix optional */ getBounds: function(/* matrix */) { + var useCache = arguments.length == 0; // Pass the matrix hidden from Bootstrap, so it still inject // getBounds as bean too. - if (!this._bounds) { + if (!useCache || !this._bounds) { var bounds = getBounds(this, arguments[0]); + if (!useCache) + return bounds; this._bounds = LinkedRectangle.create(this, 'setBounds', bounds.x, bounds.y, bounds.width, bounds.height); } @@ -1025,6 +1028,9 @@ var Path = this.Path = PathItem.extend({ * The bounding rectangle of the item including stroke width. */ getStrokeBounds: function(/* matrix */) { + var useCache = arguments.length == 0; + if (this._strokeBounds && useCache) + return this._strokeBounds; var matrix = arguments[0], // set #getBounds() width = this.getStrokeWidth(), radius = width / 2, @@ -1124,7 +1130,8 @@ var Path = this.Path = PathItem.extend({ addCap(segments[0], cap, 0); addCap(segments[length - 1], cap, 1); } - + if (useCache) + this._strokeBounds = bounds; return bounds; },