174a4d6566aaf3bb3fcc5e0b5e5b586849bd0b5d89fcb15931e1d139e97cfe9bc1739f25292e00eda63b2067936357155532df212343db596b7423c78899cc 981 B

12345678910111213141516171819202122232425262728293031323334353637383940414243
  1. /**
  2. * 线段包含判断
  3. * @param {number} x0
  4. * @param {number} y0
  5. * @param {number} x1
  6. * @param {number} y1
  7. * @param {number} lineWidth
  8. * @param {number} x
  9. * @param {number} y
  10. * @return {boolean}
  11. */
  12. export function containStroke(
  13. x0: number, y0: number, x1: number, y1: number,
  14. lineWidth: number, x: number, y: number
  15. ): boolean {
  16. if (lineWidth === 0) {
  17. return false;
  18. }
  19. const _l = lineWidth;
  20. let _a = 0;
  21. let _b = x0;
  22. // Quick reject
  23. if (
  24. (y > y0 + _l && y > y1 + _l)
  25. || (y < y0 - _l && y < y1 - _l)
  26. || (x > x0 + _l && x > x1 + _l)
  27. || (x < x0 - _l && x < x1 - _l)
  28. ) {
  29. return false;
  30. }
  31. if (x0 !== x1) {
  32. _a = (y0 - y1) / (x0 - x1);
  33. _b = (x0 * y1 - x1 * y0) / (x0 - x1);
  34. }
  35. else {
  36. return Math.abs(x - x0) <= _l / 2;
  37. }
  38. const tmp = _a * x - y + _b;
  39. const _s = tmp * tmp / (_a * _a + 1);
  40. return _s <= _l / 2 * _l / 2;
  41. }