From 4081afb635e85ce6ed7fbf9e9ffd8e174f197da2 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?J=C3=BCrg=20Lehni?= Date: Tue, 16 Feb 2016 00:28:04 +0100 Subject: [PATCH] Fix #977: Apply hit-testing tolerance to fills in Shape. --- src/item/Shape.js | 14 +++++++++----- src/path/Path.js | 2 +- 2 files changed, 10 insertions(+), 6 deletions(-) diff --git a/src/item/Shape.js b/src/item/Shape.js index 64315920..6b73e486 100644 --- a/src/item/Shape.js +++ b/src/item/Shape.js @@ -344,13 +344,17 @@ new function() { // Scope for _contains() and _hitTestSelf() code. _hitTestSelf: function _hitTestSelf(point, options, viewMatrix, strokeMatrix) { var hit = false, - style = this._style; - if (options.stroke && style.hasStroke()) { + style = this._style, + hitStroke = options.stroke && style.hasStroke(), + hitFill = options.fill && style.hasFill(); + // Just like in Path, use stroke-hit-tests also for hitting fill + // with tolerance: + if (hitStroke || hitFill) { var type = this._type, radius = this._radius, - strokeWidth = style.getStrokeWidth(), + strokeRadius = hitStroke ? style.getStrokeWidth() / 2 : 0; strokePadding = options._tolerancePadding.add( - Path._getStrokePadding(strokeWidth / 2, + Path._getStrokePadding(strokeRadius, !style.getStrokeScaling() && strokeMatrix)); if (type === 'rectangle') { var padding = strokePadding.multiply(2), @@ -370,7 +374,7 @@ new function() { // Scope for _contains() and _hitTestSelf() code. hit = isOnEllipseStroke(point, radius, strokePadding); } } - return hit ? new HitResult('stroke', this) + return hit ? new HitResult(hitStroke ? 'stroke' : 'fill', this) : _hitTestSelf.base.apply(this, arguments); } }; diff --git a/src/path/Path.js b/src/path/Path.js index 74225b50..054bd8fd 100644 --- a/src/path/Path.js +++ b/src/path/Path.js @@ -1577,7 +1577,7 @@ var Path = PathItem.extend(/** @lends Path# */{ miterLimit = strokeRadius * style.getMiterLimit(); // Add the stroke radius to tolerance padding, taking // #strokeScaling into account through _getStrokeMatrix(). - strokePadding = tolerancePadding.add( + strokePadding = strokePadding.add( Path._getStrokePadding(strokeRadius, !style.getStrokeScaling() && strokeMatrix)); } else {