From 217870292025f806c95ce2d00f426117a91beadf Mon Sep 17 00:00:00 2001 From: wuyuxiang Date: Wed, 19 Apr 2023 14:33:50 +0800 Subject: [PATCH] fix: add epsilon check, try fix #155 --- src/segment_intersection.js | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/src/segment_intersection.js b/src/segment_intersection.js index 1bcc718..9ab9a05 100644 --- a/src/segment_intersection.js +++ b/src/segment_intersection.js @@ -1,4 +1,4 @@ -//const EPS = 1e-9; +const EPS = 1e-9; /** * Finds the magnitude of the cross product of two vectors (if we pretend @@ -71,14 +71,14 @@ export default function (a1, a2, b1, b2, noEndpointTouch) { let kross = crossProduct(va, vb); let sqrKross = kross * kross; const sqrLenA = dotProduct(va, va); - //const sqrLenB = dotProduct(vb, vb); + const sqrLenB = dotProduct(vb, vb); // Check for line intersection. This works because of the properties of the // cross product -- specifically, two vectors are parallel if and only if the // cross product is the 0 vector. The full calculation involves relative error // to account for possible very small line segments. See Schneider & Eberly // for details. - if (sqrKross > 0/* EPS * sqrLenB * sqLenA */) { + if (sqrKross > EPS * sqrLenB * sqrLenA) { // If they're not parallel, then (because these are line segments) they // still might not actually intersect. This code checks that the // intersection point of the lines is actually on both line segments. @@ -109,11 +109,11 @@ export default function (a1, a2, b1, b2, noEndpointTouch) { // the (vector) difference between the two initial points. If this is parallel // with the line itself, then the two lines are the same line, and there will // be overlap. - //const sqrLenE = dotProduct(e, e); + const sqrLenE = dotProduct(e, e); kross = crossProduct(e, va); sqrKross = kross * kross; - if (sqrKross > 0 /* EPS * sqLenB * sqLenE */) { + if (sqrKross > EPS * sqrLenB * sqrLenE ) { // Lines are just parallel, not the same. No overlap. return null; }