You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
625 lines
16 KiB
JavaScript
625 lines
16 KiB
JavaScript
import { Intersections2D } from "../../Source/Cesium.js";
|
|
|
|
describe("Core/Intersections2D", function () {
|
|
describe("clipTriangleAtAxisAlignedThreshold", function () {
|
|
it("eliminates a triangle that is entirely on the wrong side of the threshold", function () {
|
|
var result = Intersections2D.clipTriangleAtAxisAlignedThreshold(
|
|
0.1,
|
|
false,
|
|
0.2,
|
|
0.3,
|
|
0.4
|
|
);
|
|
expect(result.length).toBe(0);
|
|
});
|
|
|
|
it("keeps a triangle that is entirely on the correct side of the threshold", function () {
|
|
var result = Intersections2D.clipTriangleAtAxisAlignedThreshold(
|
|
0.1,
|
|
true,
|
|
0.2,
|
|
0.3,
|
|
0.4
|
|
);
|
|
expect(result.length).toBe(3);
|
|
expect(result[0]).toBe(0);
|
|
expect(result[1]).toBe(1);
|
|
expect(result[2]).toBe(2);
|
|
});
|
|
|
|
it("adds two vertices on threshold when point 0 is on the wrong side and above", function () {
|
|
var result = Intersections2D.clipTriangleAtAxisAlignedThreshold(
|
|
0.5,
|
|
false,
|
|
0.6,
|
|
0.4,
|
|
0.2
|
|
);
|
|
expect(result.length).toBe(10);
|
|
|
|
expect(result[0]).toBe(1);
|
|
expect(result[1]).toBe(2);
|
|
|
|
expect(result[2]).toBe(-1);
|
|
expect(result[3]).toBe(0);
|
|
expect(result[4]).toBe(2);
|
|
expect(result[5]).toEqualEpsilon(0.25, 1e-14);
|
|
|
|
expect(result[6]).toBe(-1);
|
|
expect(result[7]).toBe(0);
|
|
expect(result[8]).toBe(1);
|
|
expect(result[9]).toEqualEpsilon(0.5, 1e-14);
|
|
});
|
|
|
|
it("adds two vertices on threshold when point 0 is on the wrong side and below", function () {
|
|
var result = Intersections2D.clipTriangleAtAxisAlignedThreshold(
|
|
0.5,
|
|
true,
|
|
0.4,
|
|
0.6,
|
|
0.8
|
|
);
|
|
expect(result.length).toBe(10);
|
|
|
|
expect(result[0]).toBe(1);
|
|
expect(result[1]).toBe(2);
|
|
|
|
expect(result[2]).toBe(-1);
|
|
expect(result[3]).toBe(0);
|
|
expect(result[4]).toBe(2);
|
|
expect(result[5]).toEqualEpsilon(0.25, 1e-14);
|
|
|
|
expect(result[6]).toBe(-1);
|
|
expect(result[7]).toBe(0);
|
|
expect(result[8]).toBe(1);
|
|
expect(result[9]).toEqualEpsilon(0.5, 1e-14);
|
|
});
|
|
|
|
it("adds two vertices on threshold when point 1 is on the wrong side and above", function () {
|
|
var result = Intersections2D.clipTriangleAtAxisAlignedThreshold(
|
|
0.5,
|
|
false,
|
|
0.2,
|
|
0.6,
|
|
0.4
|
|
);
|
|
expect(result.length).toBe(10);
|
|
|
|
expect(result[0]).toBe(2);
|
|
expect(result[1]).toBe(0);
|
|
|
|
expect(result[2]).toBe(-1);
|
|
expect(result[3]).toBe(1);
|
|
expect(result[4]).toBe(0);
|
|
expect(result[5]).toEqualEpsilon(0.25, 1e-14);
|
|
|
|
expect(result[6]).toBe(-1);
|
|
expect(result[7]).toBe(1);
|
|
expect(result[8]).toBe(2);
|
|
expect(result[9]).toEqualEpsilon(0.5, 1e-14);
|
|
});
|
|
|
|
it("adds two vertices on threshold when point 1 is on the wrong side and below", function () {
|
|
var result = Intersections2D.clipTriangleAtAxisAlignedThreshold(
|
|
0.5,
|
|
true,
|
|
0.8,
|
|
0.4,
|
|
0.6
|
|
);
|
|
expect(result.length).toBe(10);
|
|
|
|
expect(result[0]).toBe(2);
|
|
expect(result[1]).toBe(0);
|
|
|
|
expect(result[2]).toBe(-1);
|
|
expect(result[3]).toBe(1);
|
|
expect(result[4]).toBe(0);
|
|
expect(result[5]).toEqualEpsilon(0.25, 1e-14);
|
|
|
|
expect(result[6]).toBe(-1);
|
|
expect(result[7]).toBe(1);
|
|
expect(result[8]).toBe(2);
|
|
expect(result[9]).toEqualEpsilon(0.5, 1e-14);
|
|
});
|
|
|
|
it("adds two vertices on threshold when point 2 is on the wrong side and above", function () {
|
|
var result = Intersections2D.clipTriangleAtAxisAlignedThreshold(
|
|
0.5,
|
|
false,
|
|
0.4,
|
|
0.2,
|
|
0.6
|
|
);
|
|
expect(result.length).toBe(10);
|
|
|
|
expect(result[0]).toBe(0);
|
|
expect(result[1]).toBe(1);
|
|
|
|
expect(result[2]).toBe(-1);
|
|
expect(result[3]).toBe(2);
|
|
expect(result[4]).toBe(1);
|
|
expect(result[5]).toEqualEpsilon(0.25, 1e-14);
|
|
|
|
expect(result[6]).toBe(-1);
|
|
expect(result[7]).toBe(2);
|
|
expect(result[8]).toBe(0);
|
|
expect(result[9]).toEqualEpsilon(0.5, 1e-14);
|
|
});
|
|
|
|
it("adds two vertices on threshold when point 2 is on the wrong side and below", function () {
|
|
var result = Intersections2D.clipTriangleAtAxisAlignedThreshold(
|
|
0.5,
|
|
true,
|
|
0.6,
|
|
0.8,
|
|
0.4
|
|
);
|
|
expect(result.length).toBe(10);
|
|
|
|
expect(result[0]).toBe(0);
|
|
expect(result[1]).toBe(1);
|
|
|
|
expect(result[2]).toBe(-1);
|
|
expect(result[3]).toBe(2);
|
|
expect(result[4]).toBe(1);
|
|
expect(result[5]).toEqualEpsilon(0.25, 1e-14);
|
|
|
|
expect(result[6]).toBe(-1);
|
|
expect(result[7]).toBe(2);
|
|
expect(result[8]).toBe(0);
|
|
expect(result[9]).toEqualEpsilon(0.5, 1e-14);
|
|
});
|
|
|
|
it("adds two vertices on threshold when only point 0 is on the right side and below", function () {
|
|
var result = Intersections2D.clipTriangleAtAxisAlignedThreshold(
|
|
0.5,
|
|
false,
|
|
0.4,
|
|
0.6,
|
|
0.8
|
|
);
|
|
expect(result.length).toBe(9);
|
|
|
|
expect(result[0]).toBe(0);
|
|
|
|
expect(result[1]).toBe(-1);
|
|
expect(result[2]).toBe(1);
|
|
expect(result[3]).toBe(0);
|
|
expect(result[4]).toEqualEpsilon(0.5, 1e-14);
|
|
|
|
expect(result[5]).toBe(-1);
|
|
expect(result[6]).toBe(2);
|
|
expect(result[7]).toBe(0);
|
|
expect(result[8]).toEqualEpsilon(0.75, 1e-14);
|
|
});
|
|
|
|
it("adds two vertices on threshold when only point 0 is on the right side and above", function () {
|
|
var result = Intersections2D.clipTriangleAtAxisAlignedThreshold(
|
|
0.5,
|
|
true,
|
|
0.6,
|
|
0.4,
|
|
0.2
|
|
);
|
|
expect(result.length).toBe(9);
|
|
|
|
expect(result[0]).toBe(0);
|
|
|
|
expect(result[1]).toBe(-1);
|
|
expect(result[2]).toBe(1);
|
|
expect(result[3]).toBe(0);
|
|
expect(result[4]).toEqualEpsilon(0.5, 1e-14);
|
|
|
|
expect(result[5]).toBe(-1);
|
|
expect(result[6]).toBe(2);
|
|
expect(result[7]).toBe(0);
|
|
expect(result[8]).toEqualEpsilon(0.75, 1e-14);
|
|
});
|
|
|
|
it("adds two vertices on threshold when only point 1 is on the right side and below", function () {
|
|
var result = Intersections2D.clipTriangleAtAxisAlignedThreshold(
|
|
0.5,
|
|
false,
|
|
0.8,
|
|
0.4,
|
|
0.6
|
|
);
|
|
expect(result.length).toBe(9);
|
|
|
|
expect(result[0]).toBe(1);
|
|
|
|
expect(result[1]).toBe(-1);
|
|
expect(result[2]).toBe(2);
|
|
expect(result[3]).toBe(1);
|
|
expect(result[4]).toEqualEpsilon(0.5, 1e-14);
|
|
|
|
expect(result[5]).toBe(-1);
|
|
expect(result[6]).toBe(0);
|
|
expect(result[7]).toBe(1);
|
|
expect(result[8]).toEqualEpsilon(0.75, 1e-14);
|
|
});
|
|
|
|
it("adds two vertices on threshold when only point 1 is on the right side and above", function () {
|
|
var result = Intersections2D.clipTriangleAtAxisAlignedThreshold(
|
|
0.5,
|
|
true,
|
|
0.2,
|
|
0.6,
|
|
0.4
|
|
);
|
|
expect(result.length).toBe(9);
|
|
|
|
expect(result[0]).toBe(1);
|
|
|
|
expect(result[1]).toBe(-1);
|
|
expect(result[2]).toBe(2);
|
|
expect(result[3]).toBe(1);
|
|
expect(result[4]).toEqualEpsilon(0.5, 1e-14);
|
|
|
|
expect(result[5]).toBe(-1);
|
|
expect(result[6]).toBe(0);
|
|
expect(result[7]).toBe(1);
|
|
expect(result[8]).toEqualEpsilon(0.75, 1e-14);
|
|
});
|
|
|
|
it("adds two vertices on threshold when only point 2 is on the right side and below", function () {
|
|
var result = Intersections2D.clipTriangleAtAxisAlignedThreshold(
|
|
0.5,
|
|
false,
|
|
0.6,
|
|
0.8,
|
|
0.4
|
|
);
|
|
expect(result.length).toBe(9);
|
|
|
|
expect(result[0]).toBe(2);
|
|
|
|
expect(result[1]).toBe(-1);
|
|
expect(result[2]).toBe(0);
|
|
expect(result[3]).toBe(2);
|
|
expect(result[4]).toEqualEpsilon(0.5, 1e-14);
|
|
|
|
expect(result[5]).toBe(-1);
|
|
expect(result[6]).toBe(1);
|
|
expect(result[7]).toBe(2);
|
|
expect(result[8]).toEqualEpsilon(0.75, 1e-14);
|
|
});
|
|
|
|
it("adds two vertices on threshold when only point 2 is on the right side and above", function () {
|
|
var result = Intersections2D.clipTriangleAtAxisAlignedThreshold(
|
|
0.5,
|
|
true,
|
|
0.4,
|
|
0.2,
|
|
0.6
|
|
);
|
|
expect(result.length).toBe(9);
|
|
|
|
expect(result[0]).toBe(2);
|
|
|
|
expect(result[1]).toBe(-1);
|
|
expect(result[2]).toBe(0);
|
|
expect(result[3]).toBe(2);
|
|
expect(result[4]).toEqualEpsilon(0.5, 1e-14);
|
|
|
|
expect(result[5]).toBe(-1);
|
|
expect(result[6]).toBe(1);
|
|
expect(result[7]).toBe(2);
|
|
expect(result[8]).toEqualEpsilon(0.75, 1e-14);
|
|
});
|
|
});
|
|
|
|
describe("computeBarycentricCoordinates", function () {
|
|
it("returns the correct result for positions on a triangle vertex", function () {
|
|
var ll = Intersections2D.computeBarycentricCoordinates(
|
|
0.0,
|
|
0.0,
|
|
0.0,
|
|
0.0,
|
|
1.0,
|
|
0.0,
|
|
0.0,
|
|
1.0
|
|
);
|
|
expect(ll.x).toEqualEpsilon(1.0, 1e-15);
|
|
expect(ll.y).toEqualEpsilon(0.0, 1e-15);
|
|
expect(ll.z).toEqualEpsilon(0.0, 1e-15);
|
|
|
|
var lr = Intersections2D.computeBarycentricCoordinates(
|
|
1.0,
|
|
0.0,
|
|
0.0,
|
|
0.0,
|
|
1.0,
|
|
0.0,
|
|
0.0,
|
|
1.0
|
|
);
|
|
expect(lr.x).toEqualEpsilon(0.0, 1e-15);
|
|
expect(lr.y).toEqualEpsilon(1.0, 1e-15);
|
|
expect(lr.z).toEqualEpsilon(0.0, 1e-15);
|
|
|
|
var ul = Intersections2D.computeBarycentricCoordinates(
|
|
0.0,
|
|
1.0,
|
|
0.0,
|
|
0.0,
|
|
1.0,
|
|
0.0,
|
|
0.0,
|
|
1.0
|
|
);
|
|
expect(ul.x).toEqualEpsilon(0.0, 1e-15);
|
|
expect(ul.y).toEqualEpsilon(0.0, 1e-15);
|
|
expect(ul.z).toEqualEpsilon(1.0, 1e-15);
|
|
});
|
|
|
|
it("returns the correct result for a position in the barycenter of a triangle", function () {
|
|
var result = Intersections2D.computeBarycentricCoordinates(
|
|
0.0,
|
|
0.0,
|
|
0.0,
|
|
1.0,
|
|
-1,
|
|
-0.5,
|
|
1,
|
|
-0.5
|
|
);
|
|
expect(result.x).toEqualEpsilon(1.0 / 3.0, 1e-15);
|
|
expect(result.y).toEqualEpsilon(1.0 / 3.0, 1e-15);
|
|
expect(result.z).toEqualEpsilon(1.0 / 3.0, 1e-15);
|
|
});
|
|
|
|
it("returns the correct result for a position on an edge between two vertices", function () {
|
|
var e12 = Intersections2D.computeBarycentricCoordinates(
|
|
1.5,
|
|
1.0,
|
|
1.0,
|
|
1.0,
|
|
2.0,
|
|
1.0,
|
|
1.0,
|
|
2.0
|
|
);
|
|
expect(e12.x).toEqualEpsilon(0.5, 1e-15);
|
|
expect(e12.y).toEqualEpsilon(0.5, 1e-15);
|
|
expect(e12.z).toEqualEpsilon(0.0, 1e-15);
|
|
|
|
var e23 = Intersections2D.computeBarycentricCoordinates(
|
|
1.5,
|
|
1.5,
|
|
1.0,
|
|
1.0,
|
|
2.0,
|
|
1.0,
|
|
1.0,
|
|
2.0
|
|
);
|
|
expect(e23.x).toEqualEpsilon(0.0, 1e-15);
|
|
expect(e23.y).toEqualEpsilon(0.5, 1e-15);
|
|
expect(e23.z).toEqualEpsilon(0.5, 1e-15);
|
|
|
|
var e31 = Intersections2D.computeBarycentricCoordinates(
|
|
1.0,
|
|
1.5,
|
|
1.0,
|
|
1.0,
|
|
2.0,
|
|
1.0,
|
|
1.0,
|
|
2.0
|
|
);
|
|
expect(e31.x).toEqualEpsilon(0.5, 1e-15);
|
|
expect(e31.y).toEqualEpsilon(0.0, 1e-15);
|
|
expect(e31.z).toEqualEpsilon(0.5, 1e-15);
|
|
});
|
|
|
|
it("returns the correct result for a position outside a triangle", function () {
|
|
var result1 = Intersections2D.computeBarycentricCoordinates(
|
|
0.5,
|
|
0.5,
|
|
1.0,
|
|
1.0,
|
|
2.0,
|
|
1.0,
|
|
1.0,
|
|
2.0
|
|
);
|
|
expect(result1.x).toBeGreaterThan(0.0);
|
|
expect(result1.y).toBeLessThan(0.0);
|
|
expect(result1.z).toBeLessThan(0.0);
|
|
|
|
var result2 = Intersections2D.computeBarycentricCoordinates(
|
|
2.1,
|
|
0.99,
|
|
1.0,
|
|
1.0,
|
|
2.0,
|
|
1.0,
|
|
1.0,
|
|
2.0
|
|
);
|
|
expect(result2.x).toBeLessThan(0.0);
|
|
expect(result2.y).toBeGreaterThan(0.0);
|
|
expect(result2.z).toBeLessThan(0.0);
|
|
|
|
var result3 = Intersections2D.computeBarycentricCoordinates(
|
|
0.99,
|
|
2.1,
|
|
1.0,
|
|
1.0,
|
|
2.0,
|
|
1.0,
|
|
1.0,
|
|
2.0
|
|
);
|
|
expect(result3.x).toBeLessThan(0.0);
|
|
expect(result3.y).toBeLessThan(0.0);
|
|
expect(result3.z).toBeGreaterThan(0.0);
|
|
});
|
|
});
|
|
|
|
describe("computeLineSegmentLineSegmentIntersection", function () {
|
|
it("returns the correct result for intersection point", function () {
|
|
var intersection0 = Intersections2D.computeLineSegmentLineSegmentIntersection(
|
|
0.0,
|
|
0.0,
|
|
0.0,
|
|
2.0,
|
|
-1.0,
|
|
1.0,
|
|
1.0,
|
|
1.0
|
|
);
|
|
expect(intersection0.x).toEqualEpsilon(0.0, 1e-15);
|
|
expect(intersection0.y).toEqualEpsilon(1.0, 1e-15);
|
|
|
|
var intersection1 = Intersections2D.computeLineSegmentLineSegmentIntersection(
|
|
0.0,
|
|
0.0,
|
|
10.0,
|
|
5.0,
|
|
0.0,
|
|
5.0,
|
|
10.0,
|
|
0.0
|
|
);
|
|
expect(intersection1.x).toEqualEpsilon(5.0, 1e-15);
|
|
expect(intersection1.y).toEqualEpsilon(2.5, 1e-15);
|
|
|
|
var intersection2 = Intersections2D.computeLineSegmentLineSegmentIntersection(
|
|
0.0,
|
|
-5.0,
|
|
4.0,
|
|
3.0,
|
|
-2.0,
|
|
1.0,
|
|
4.0,
|
|
-2.0
|
|
);
|
|
expect(intersection2.x).toEqualEpsilon(2.0, 1e-15);
|
|
expect(intersection2.y).toEqualEpsilon(-1.0, 1e-15);
|
|
});
|
|
|
|
it("returns the correct result for intersection point on a vertex", function () {
|
|
var intersection0 = Intersections2D.computeLineSegmentLineSegmentIntersection(
|
|
0.0,
|
|
0.0,
|
|
0.0,
|
|
2.0,
|
|
-1.0,
|
|
0.0,
|
|
1.0,
|
|
0.0
|
|
);
|
|
expect(intersection0.x).toEqualEpsilon(0.0, 1e-15);
|
|
expect(intersection0.y).toEqualEpsilon(0.0, 1e-15);
|
|
|
|
var intersection1 = Intersections2D.computeLineSegmentLineSegmentIntersection(
|
|
0.0,
|
|
0.0,
|
|
1.0,
|
|
1.0,
|
|
1.0,
|
|
1.0,
|
|
2.0,
|
|
0.0
|
|
);
|
|
expect(intersection1.x).toEqualEpsilon(1.0, 1e-15);
|
|
expect(intersection1.y).toEqualEpsilon(1.0, 1e-15);
|
|
|
|
var intersection2 = Intersections2D.computeLineSegmentLineSegmentIntersection(
|
|
0.0,
|
|
0.0,
|
|
4.0,
|
|
3.0,
|
|
5.0,
|
|
0.0,
|
|
4.0,
|
|
3.0
|
|
);
|
|
expect(intersection2.x).toEqualEpsilon(4.0, 1e-15);
|
|
expect(intersection2.y).toEqualEpsilon(3.0, 1e-15);
|
|
});
|
|
|
|
it("returns undefined for non-intersecting lines", function () {
|
|
var intersection0 = Intersections2D.computeLineSegmentLineSegmentIntersection(
|
|
0.0,
|
|
0.0,
|
|
0.0,
|
|
5.0,
|
|
0.1,
|
|
4.8,
|
|
5.0,
|
|
0.0
|
|
);
|
|
expect(intersection0).toBeUndefined();
|
|
|
|
var intersection1 = Intersections2D.computeLineSegmentLineSegmentIntersection(
|
|
10.0,
|
|
0.0,
|
|
0.0,
|
|
-10.0,
|
|
0.0,
|
|
0.0,
|
|
-8.0,
|
|
-8.0
|
|
);
|
|
expect(intersection1).toBeUndefined();
|
|
});
|
|
|
|
it("returns undefined for parallel lines", function () {
|
|
var intersection0 = Intersections2D.computeLineSegmentLineSegmentIntersection(
|
|
0.0,
|
|
0.0,
|
|
0.0,
|
|
2.0,
|
|
1.0,
|
|
1.0,
|
|
1.0,
|
|
4.0
|
|
);
|
|
expect(intersection0).toBeUndefined();
|
|
|
|
var intersection1 = Intersections2D.computeLineSegmentLineSegmentIntersection(
|
|
1.0,
|
|
1.0,
|
|
4.0,
|
|
4.0,
|
|
0.0,
|
|
0.0,
|
|
3.0,
|
|
3.0
|
|
);
|
|
expect(intersection1).toBeUndefined();
|
|
});
|
|
|
|
it("returns undefined for coincident lines", function () {
|
|
var intersection0 = Intersections2D.computeLineSegmentLineSegmentIntersection(
|
|
0.0,
|
|
0.0,
|
|
0.0,
|
|
2.0,
|
|
0.0,
|
|
1.0,
|
|
0.0,
|
|
4.0
|
|
);
|
|
expect(intersection0).toBeUndefined();
|
|
|
|
var intersection1 = Intersections2D.computeLineSegmentLineSegmentIntersection(
|
|
0.0,
|
|
0.0,
|
|
0.0,
|
|
2.0,
|
|
0.0,
|
|
0.0,
|
|
0.0,
|
|
2.0
|
|
);
|
|
expect(intersection1).toBeUndefined();
|
|
});
|
|
});
|
|
});
|