UNPKG

1.11 kBJavaScriptView Raw
1"use strict";
2Object.defineProperty(exports, "__esModule", { value: true });
3exports.getLineIntersect = void 0;
4var isBetween = function (value, min, max) { return value >= min && value <= max; };
5function getLineIntersect(p0, p1, p2, p3) {
6 var tolerance = 0.001;
7 var E = {
8 x: p2.x - p0.x,
9 y: p2.y - p0.y,
10 };
11 var D0 = {
12 x: p1.x - p0.x,
13 y: p1.y - p0.y,
14 };
15 var D1 = {
16 x: p3.x - p2.x,
17 y: p3.y - p2.y,
18 };
19 var kross = D0.x * D1.y - D0.y * D1.x;
20 var sqrKross = kross * kross;
21 var sqrLen0 = D0.x * D0.x + D0.y * D0.y;
22 var sqrLen1 = D1.x * D1.x + D1.y * D1.y;
23 var point = null;
24 if (sqrKross > tolerance * sqrLen0 * sqrLen1) {
25 var s = (E.x * D1.y - E.y * D1.x) / kross;
26 var t = (E.x * D0.y - E.y * D0.x) / kross;
27 if (isBetween(s, 0, 1) && isBetween(t, 0, 1)) {
28 point = {
29 x: p0.x + s * D0.x,
30 y: p0.y + s * D0.y,
31 };
32 }
33 }
34 return point;
35}
36exports.getLineIntersect = getLineIntersect;
37//# sourceMappingURL=get-line-intersect.js.map
\No newline at end of file