import { radians } from "./angle"; import { ellipse, ellipseSegmentInterceptPoints, ellipseIncludesPoint, ellipseTouchesPoint, } from "./ellipse"; import { point } from "./point"; import { segment } from "./segment"; import type { Ellipse, GlobalPoint } from "./types"; describe("point and ellipse", () => { const target: Ellipse = ellipse(point(0, 0), radians(0), 2, 1); it("point on ellipse", () => { [point(0, 1), point(0, -1), point(2, 0), point(-2, 0)].forEach((p) => { expect(ellipseTouchesPoint(p, target)).toBe(true); }); expect(ellipseTouchesPoint(point(-1.4, 0.7), target, 0.1)).toBe(true); expect(ellipseTouchesPoint(point(-1.4, 0.71), target, 0.01)).toBe(true); expect(ellipseTouchesPoint(point(1.4, 0.7), target, 0.1)).toBe(true); expect(ellipseTouchesPoint(point(1.4, 0.71), target, 0.01)).toBe(true); expect(ellipseTouchesPoint(point(1, -0.86), target, 0.1)).toBe(true); expect(ellipseTouchesPoint(point(1, -0.86), target, 0.01)).toBe(true); expect(ellipseTouchesPoint(point(-1, -0.86), target, 0.1)).toBe(true); expect(ellipseTouchesPoint(point(-1, -0.86), target, 0.01)).toBe(true); expect(ellipseTouchesPoint(point(-1, 0.8), target)).toBe(false); expect(ellipseTouchesPoint(point(1, -0.8), target)).toBe(false); }); it("point in ellipse", () => { [point(0, 1), point(0, -1), point(2, 0), point(-2, 0)].forEach((p) => { expect(ellipseIncludesPoint(p, target)).toBe(true); }); expect(ellipseIncludesPoint(point(-1, 0.8), target)).toBe(true); expect(ellipseIncludesPoint(point(1, -0.8), target)).toBe(true); // Point on outline expect(ellipseIncludesPoint(point(2, 0), target)).toBe(true); expect(ellipseIncludesPoint(point(-1, 1), target)).toBe(false); expect(ellipseIncludesPoint(point(-1.4, 0.8), target)).toBe(false); }); }); describe("line and ellipse", () => { it("detects outside segment", () => { const l = segment(point(-100, 0), point(-10, 0)); const e = ellipse(point(0, 0), radians(0), 2, 2); expect(ellipseSegmentInterceptPoints(e, l).length).toBe(0); }); });