get-line-intersect.js 1.0 KB

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