Clean up code from #856 a bit.

This commit is contained in:
Jürg Lehni 2015-12-27 20:21:02 +01:00
parent d67796f655
commit f34afbc19a
3 changed files with 13 additions and 9 deletions

View file

@ -3940,6 +3940,7 @@ var Item = Base.extend(Emitter, /** @lends Item# */{
// Get the transformation matrix for non-scaling strokes. // Get the transformation matrix for non-scaling strokes.
var strokeMatrix = parentStrokeMatrix var strokeMatrix = parentStrokeMatrix
? parentStrokeMatrix.chain(matrix) ? parentStrokeMatrix.chain(matrix)
// pass `true` for dontMerge
: !this.getStrokeScaling(true) && getViewMatrix(globalMatrix), : !this.getStrokeScaling(true) && getViewMatrix(globalMatrix),
// If we're drawing into a separate canvas and a clipItem is defined // If we're drawing into a separate canvas and a clipItem is defined
// for the current rendering loop, we need to draw the clip item // for the current rendering loop, we need to draw the clip item

View file

@ -272,14 +272,17 @@ var Shape = Item.extend(/** @lends Shape# */{
_getBounds: function(getter, matrix) { _getBounds: function(getter, matrix) {
var rect = new Rectangle(this._size).setCenter(0, 0), var rect = new Rectangle(this._size).setCenter(0, 0),
expandStrokeWidth = getter !== 'getBounds' && this.hasStroke() strokeWidth = getter === 'getStrokeBounds' && this.hasStroke()
&& this.getStrokeWidth(); && this.getStrokeWidth(),
if (expandStrokeWidth && this.getStrokeScaling(true)) scaling = strokeWidth && this.getStrokeScaling();
rect = rect.expand(expandStrokeWidth); // If we're getting the strokeBounds, include the stroke width before
// or after transforming the rect, based on strokeScaling.
if (strokeWidth && scaling)
rect = rect.expand(strokeWidth);
if (matrix) if (matrix)
rect = matrix._transformBounds(rect); rect = matrix._transformBounds(rect);
if (expandStrokeWidth && !this.getStrokeScaling(true)) if (strokeWidth && !scaling)
rect = rect.expand(expandStrokeWidth); rect = rect.expand(strokeWidth);
return rect; return rect;
} }
}, },

View file

@ -77,7 +77,7 @@ test('path.bounds when contained in a transformed group', function() {
equals(path.bounds, new Rectangle(110, 110, 50, 50), 'path.bounds after group translation'); equals(path.bounds, new Rectangle(110, 110, 50, 50), 'path.bounds after group translation');
}); });
test('shape.strokeBounds when scale with strokeScaling is false', function(){ test('shape.strokeBounds when scaled with strokeScaling set to false', function(){
var shape = new Shape.Rectangle({ var shape = new Shape.Rectangle({
point: [5, 5], point: [5, 5],
size: [20, 20], size: [20, 20],
@ -85,9 +85,9 @@ test('shape.strokeBounds when scale with strokeScaling is false', function(){
strokeColor: 'black', strokeColor: 'black',
strokeWidth: 10 strokeWidth: 10
}); });
equals(shape.getStrokeBounds(), new Rectangle(0, 0, 30, 30), 'shape.strokeBounds before scaling'); equals(shape.strokeBounds, new Rectangle(0, 0, 30, 30), 'shape.strokeBounds before scaling');
shape.scale(2, 2, [5, 5]); shape.scale(2, 2, [5, 5]);
equals(shape.getStrokeBounds(), new Rectangle(0, 0, 50, 50), 'shape.strokeBounds after scaling'); equals(shape.strokeBounds, new Rectangle(0, 0, 50, 50), 'shape.strokeBounds after scaling');
}); });
test('text.bounds', function() { test('text.bounds', function() {