1 | "use strict";
|
2 | Object.defineProperty(exports, "__esModule", { value: true });
|
3 | exports.getLineIntersect = void 0;
|
4 | var isBetween = function (value, min, max) { return value >= min && value <= max; };
|
5 | function 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 | }
|
36 | exports.getLineIntersect = getLineIntersect;
|
37 |
|
\ | No newline at end of file |