mirror of
https://github.com/scratchfoundation/paper.js.git
synced 2025-01-22 07:19:57 -05:00
Fix hit-test for compound paths again.
This commit is contained in:
parent
ddeacb1763
commit
e6ef5e7e17
1 changed files with 11 additions and 6 deletions
|
@ -221,17 +221,22 @@ var CompoundPath = PathItem.extend(/** @lends CompoundPath# */{
|
|||
/*#*/ } // !options.nativeContains
|
||||
},
|
||||
|
||||
_hitTest: function _hitTest(point, options) {
|
||||
_hitTest : function _hitTest(point, options) {
|
||||
// Do not test children for fill, since a compound path forms one shape.
|
||||
// options.compoundChildren allows to specifically do so, see below.
|
||||
var res = _hitTest.base.call(this, point,
|
||||
Base.merge(options, { fill: false }));
|
||||
// If asked to query all children seperately, perform the same loop as
|
||||
// Item#hitTest() now on the compound children.
|
||||
if (!res && options.compoundChildren) {
|
||||
var children = this._children;
|
||||
for (var i = children.length - 1; i >= 0 && !res; i--)
|
||||
res = children[i]._hitTest(point, options);
|
||||
if (!res) {
|
||||
if (options.compoundChildren) {
|
||||
var children = this._children;
|
||||
for (var i = children.length - 1; i >= 0 && !res; i--)
|
||||
res = children[i]._hitTest(point, options);
|
||||
} else if (options.fill && this.hasFill()
|
||||
&& this._contains(point)) {
|
||||
res = new HitResult('fill', this);
|
||||
}
|
||||
}
|
||||
return res;
|
||||
},
|
||||
|
|
Loading…
Reference in a new issue