mirror of
https://github.com/scratchfoundation/paper.js.git
synced 2025-01-22 07:19:57 -05:00
Introduce faster versions of Rectangle#contains() that do not perform checks.
This commit is contained in:
parent
833d4968ce
commit
ebd3bfc092
3 changed files with 21 additions and 12 deletions
|
@ -456,16 +456,25 @@ var Rectangle = this.Rectangle = Base.extend(/** @lends Rectangle# */{
|
||||||
*/
|
*/
|
||||||
contains: function(rect) {
|
contains: function(rect) {
|
||||||
// TODO: improve handling of passed Rectangle or Point
|
// TODO: improve handling of passed Rectangle or Point
|
||||||
if (rect.width !== undefined) {
|
return rect.width !== undefined
|
||||||
return rect.x >= this.x && rect.y >= this.y
|
? this._containsRectangle(rect)
|
||||||
&& rect.x + rect.width <= this.x + this.width
|
: this._containsPoint(Point.read(arguments));
|
||||||
&& rect.y + rect.height <= this.y + this.height;
|
},
|
||||||
} else {
|
|
||||||
var point = Point.read(arguments);
|
_containsPoint: function(point) {
|
||||||
return point.x >= this.x && point.y >= this.y
|
var x = point.x,
|
||||||
&& point.x <= this.x + this.width
|
y = point.y;
|
||||||
&& point.y <= this.y + this.height;
|
return x >= this.x && y >= this.y
|
||||||
}
|
&& x <= this.x + this.width
|
||||||
|
&& y <= this.y + this.height;
|
||||||
|
},
|
||||||
|
|
||||||
|
_containsRectangle: function(rect) {
|
||||||
|
var x = rect.x,
|
||||||
|
y = rect.y;
|
||||||
|
return x >= this.x && y >= this.y
|
||||||
|
&& x + rect.width <= this.x + this.width
|
||||||
|
&& y + rect.height <= this.y + this.height;
|
||||||
},
|
},
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -675,7 +675,7 @@ var Item = this.Item = Base.extend(/** @lends Item# */{
|
||||||
// this item does not have children, since we'd have to travel up the
|
// this item does not have children, since we'd have to travel up the
|
||||||
// chain already to determine the rough bounds.
|
// chain already to determine the rough bounds.
|
||||||
if (!this._children && !this.getRoughBounds(matrix)
|
if (!this._children && !this.getRoughBounds(matrix)
|
||||||
.expand(options.tolerance).contains(point))
|
.expand(options.tolerance)._containsPoint(point))
|
||||||
return null;
|
return null;
|
||||||
if (options.center || options.bounds) {
|
if (options.center || options.bounds) {
|
||||||
// Don't get the transformed bounds, check against transformed
|
// Don't get the transformed bounds, check against transformed
|
||||||
|
|
|
@ -1184,7 +1184,7 @@ var Path = this.Path = PathItem.extend(/** @lends Path# */{
|
||||||
|
|
||||||
contains: function(point, matrix) {
|
contains: function(point, matrix) {
|
||||||
point = Point.read(arguments);
|
point = Point.read(arguments);
|
||||||
if (!this._closed || !this.getRoughBounds(matrix).contains(point))
|
if (!this._closed || !this.getRoughBounds(matrix)._containsPoint(point))
|
||||||
return false;
|
return false;
|
||||||
// Use the crossing number algorithm, by counting the crossings of the
|
// Use the crossing number algorithm, by counting the crossings of the
|
||||||
// beam in right y-direction with the shape, and see if it's an odd
|
// beam in right y-direction with the shape, and see if it's an odd
|
||||||
|
|
Loading…
Reference in a new issue