mirror of
https://github.com/excalidraw/excalidraw.git
synced 2025-05-03 10:00:07 -04:00
57 lines
2.1 KiB
TypeScript
57 lines
2.1 KiB
TypeScript
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<GlobalPoint> = 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<GlobalPoint>(point(-100, 0), point(-10, 0));
|
|
const e = ellipse(point(0, 0), radians(0), 2, 2);
|
|
expect(ellipseSegmentInterceptPoints(e, l).length).toBe(0);
|
|
});
|
|
});
|