Introduce GEOMETRIC_EPSILON, for isOrthogonal(), isCollinear() and overlap checks.

Relates to #777
This commit is contained in:
Jürg Lehni 2015-09-12 10:35:47 +02:00
parent cdd0cee623
commit fb5f8c0115
5 changed files with 6 additions and 14 deletions

View file

@ -113,10 +113,8 @@ var Line = Base.extend(/** @lends Line# */{
}, },
isCollinear: function(line) { isCollinear: function(line) {
// TODO: Tests showed that 1e-10 might work well here, but we want to
// keep it in sync with Point#isCollinear()
return this._vx * line._vy - this._vy * line._vx return this._vx * line._vy - this._vy * line._vx
< /*#=*/Numerical.TOLERANCE; < /*#=*/Numerical.GEOMETRIC_EPSILON;
}, },
statics: /** @lends Line */{ statics: /** @lends Line */{

View file

@ -702,10 +702,7 @@ var Point = Base.extend(/** @lends Point# */{
* @return {Boolean} {@true it is collinear} * @return {Boolean} {@true it is collinear}
*/ */
isCollinear: function(point) { isCollinear: function(point) {
// NOTE: Numerical.EPSILON is too small, breaking shape-path-shape return Math.abs(this.cross(point)) < /*#=*/Numerical.GEOMETRIC_EPSILON;
// conversion test. But tolerance is probably too large?
// TODO: Tests showed that 1e-10 might work well here.
return Math.abs(this.cross(point)) < /*#=*/Numerical.TOLERANCE;
}, },
// TODO: Remove version with typo after a while (deprecated June 2015) // TODO: Remove version with typo after a while (deprecated June 2015)
@ -719,10 +716,7 @@ var Point = Base.extend(/** @lends Point# */{
* @return {Boolean} {@true it is orthogonal} * @return {Boolean} {@true it is orthogonal}
*/ */
isOrthogonal: function(point) { isOrthogonal: function(point) {
// NOTE: Numerical.EPSILON is too small, breaking shape-path-shape return Math.abs(this.dot(point)) < /*#=*/Numerical.GEOMETRIC_EPSILON;
// conversion test.
// TODO: Test if 1e-10 works here too? See #isCollinear()
return Math.abs(this.dot(point)) < /*#=*/Numerical.TOLERANCE;
}, },
/** /**

View file

@ -1614,7 +1614,7 @@ new function() { // Scope for intersection using bezier fat-line clipping
var line1 = new Line(v1[0], v1[1], v1[6], v1[7]), var line1 = new Line(v1[0], v1[1], v1[6], v1[7]),
line2 = new Line(v2[0], v2[1], v2[6], v2[7]); line2 = new Line(v2[0], v2[1], v2[6], v2[7]);
if (!line1.isCollinear(line2) || line1.getDistance(line2.getPoint()) if (!line1.isCollinear(line2) || line1.getDistance(line2.getPoint())
> /*#=*/Numerical.GEOMETRY_TOLERANCE) > /*#=*/Numerical.GEOMETRIC_EPSILON)
return false; return false;
} else if (straight1 ^ straight2) { } else if (straight1 ^ straight2) {
// If one curve is straight, the other curve must be straight, too, // If one curve is straight, the other curve must be straight, too,

View file

@ -2502,7 +2502,6 @@ new function() { // PostScript-style drawing commands
x = pt.x, x = pt.x,
y = pt.y, y = pt.y,
abs = Math.abs, abs = Math.abs,
epsilon = /*#=*/Numerical.EPSILON,
rx = abs(radius.width), rx = abs(radius.width),
ry = abs(radius.height), ry = abs(radius.height),
rxSq = rx * rx, rxSq = rx * rx,
@ -2519,7 +2518,7 @@ new function() { // PostScript-style drawing commands
} }
factor = (rxSq * rySq - rxSq * ySq - rySq * xSq) / factor = (rxSq * rySq - rxSq * ySq - rySq * xSq) /
(rxSq * ySq + rySq * xSq); (rxSq * ySq + rySq * xSq);
if (abs(factor) < epsilon) if (abs(factor) < /*#=*/Numerical.EPSILON)
factor = 0; factor = 0;
if (factor < 0) if (factor < 0)
throw new Error( throw new Error(

View file

@ -81,6 +81,7 @@ var Numerical = new function() {
* range (see MACHINE_EPSILON). * range (see MACHINE_EPSILON).
*/ */
EPSILON: EPSILON, EPSILON: EPSILON,
GEOMETRIC_EPSILON: 1e-9,
/** /**
* MACHINE_EPSILON for a double precision (Javascript Number) is * MACHINE_EPSILON for a double precision (Javascript Number) is
* 2.220446049250313e-16. (try this in the js console) * 2.220446049250313e-16. (try this in the js console)