mirror of
https://github.com/scratchfoundation/paper.js.git
synced 2025-01-20 22:39:50 -05:00
Clean up Item#hitTest() code.
This commit is contained in:
parent
58f697abfc
commit
9f7167a47f
1 changed files with 21 additions and 18 deletions
|
@ -1372,14 +1372,6 @@ var Item = Base.extend(Callback, /** @lends Item# */{
|
||||||
* hit.
|
* hit.
|
||||||
*/
|
*/
|
||||||
hitTest: function(point, options) {
|
hitTest: function(point, options) {
|
||||||
function checkBounds(type, part) {
|
|
||||||
var pt = bounds['get' + part]();
|
|
||||||
// TODO: We need to transform the point back to the coordinate
|
|
||||||
// system of the DOM level on which the inquiry was started!
|
|
||||||
if (point.getDistance(pt) < options.tolerance)
|
|
||||||
return new HitResult(type, that,
|
|
||||||
{ name: Base.hyphenate(part), point: pt });
|
|
||||||
}
|
|
||||||
point = Point.read(arguments);
|
point = Point.read(arguments);
|
||||||
options = HitResult.getOptions(Base.read(arguments));
|
options = HitResult.getOptions(Base.read(arguments));
|
||||||
|
|
||||||
|
@ -1395,20 +1387,32 @@ var Item = Base.extend(Callback, /** @lends Item# */{
|
||||||
// Transform point to local coordinates but use untransformed point
|
// Transform point to local coordinates but use untransformed point
|
||||||
// for bounds check above.
|
// for bounds check above.
|
||||||
point = this._matrix._inverseTransform(point);
|
point = this._matrix._inverseTransform(point);
|
||||||
|
|
||||||
|
var that = this,
|
||||||
|
res;
|
||||||
|
function checkBounds(type, part) {
|
||||||
|
var pt = bounds['get' + part]();
|
||||||
|
// TODO: We need to transform the point back to the coordinate
|
||||||
|
// system of the DOM level on which the inquiry was started!
|
||||||
|
if (point.getDistance(pt) < options.tolerance)
|
||||||
|
return new HitResult(type, that,
|
||||||
|
{ name: Base.hyphenate(part), point: pt });
|
||||||
|
}
|
||||||
|
|
||||||
if ((options.center || options.bounds) &&
|
if ((options.center || options.bounds) &&
|
||||||
// Ignore top level layers:
|
// Ignore top level layers:
|
||||||
!(this instanceof Layer && !this._parent)) {
|
!(this instanceof Layer && !this._parent)) {
|
||||||
// Don't get the transformed bounds, check against transformed
|
// Don't get the transformed bounds, check against transformed
|
||||||
// points instead
|
// points instead
|
||||||
var bounds = this.getBounds(),
|
var bounds = this.getBounds();
|
||||||
that = this,
|
|
||||||
// TODO: Move these into a private scope
|
|
||||||
points = ['TopLeft', 'TopRight', 'BottomLeft', 'BottomRight',
|
|
||||||
'LeftCenter', 'TopCenter', 'RightCenter', 'BottomCenter'],
|
|
||||||
res;
|
|
||||||
if (options.center && (res = checkBounds('center', 'Center')))
|
if (options.center && (res = checkBounds('center', 'Center')))
|
||||||
return res;
|
return res;
|
||||||
if (options.bounds) {
|
if (options.bounds) {
|
||||||
|
// TODO: Move these into a private scope
|
||||||
|
var points = [
|
||||||
|
'TopLeft', 'TopRight', 'BottomLeft', 'BottomRight',
|
||||||
|
'LeftCenter', 'TopCenter', 'RightCenter', 'BottomCenter'
|
||||||
|
];
|
||||||
for (var i = 0; i < 8; i++)
|
for (var i = 0; i < 8; i++)
|
||||||
if (res = checkBounds('bounds', points[i]))
|
if (res = checkBounds('bounds', points[i]))
|
||||||
return res;
|
return res;
|
||||||
|
@ -1427,10 +1431,9 @@ var Item = Base.extend(Callback, /** @lends Item# */{
|
||||||
_hitTest: function(point, options) {
|
_hitTest: function(point, options) {
|
||||||
if (this._children) {
|
if (this._children) {
|
||||||
// Loop backwards, so items that get drawn last are tested first
|
// Loop backwards, so items that get drawn last are tested first
|
||||||
for (var i = this._children.length - 1; i >= 0; i--) {
|
for (var i = this._children.length - 1; i >= 0; i--)
|
||||||
var res = this._children[i].hitTest(point, options);
|
if (res = this._children[i].hitTest(point, options))
|
||||||
if (res) return res;
|
return res;
|
||||||
}
|
|
||||||
} else if (this.hasFill() && this._contains(point)) {
|
} else if (this.hasFill() && this._contains(point)) {
|
||||||
return new HitResult('fill', this);
|
return new HitResult('fill', this);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue