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.
298 lines
10 KiB
JavaScript
298 lines
10 KiB
JavaScript
import { BoundingRectangle } from "../../Source/Cesium.js";
|
|
import { Cartesian2 } from "../../Source/Cesium.js";
|
|
import { Ellipsoid } from "../../Source/Cesium.js";
|
|
import { GeographicProjection } from "../../Source/Cesium.js";
|
|
import { Intersect } from "../../Source/Cesium.js";
|
|
import { Rectangle } from "../../Source/Cesium.js";
|
|
import createPackableSpecs from "../createPackableSpecs.js";
|
|
|
|
describe("Core/BoundingRectangle", function () {
|
|
it("default constructor sets expected values", function () {
|
|
var rectangle = new BoundingRectangle();
|
|
expect(rectangle.x).toEqual(0.0);
|
|
expect(rectangle.y).toEqual(0.0);
|
|
expect(rectangle.width).toEqual(0.0);
|
|
expect(rectangle.height).toEqual(0.0);
|
|
});
|
|
|
|
it("constructor sets expected parameters", function () {
|
|
var rectangle = new BoundingRectangle(1.0, 2.0, 3.0, 4.0);
|
|
expect(rectangle.x).toEqual(1.0);
|
|
expect(rectangle.y).toEqual(2.0);
|
|
expect(rectangle.width).toEqual(3.0);
|
|
expect(rectangle.height).toEqual(4.0);
|
|
});
|
|
|
|
it("clone without a result parameter", function () {
|
|
var rectangle = new BoundingRectangle(1.0, 2.0, 3.0, 4.0);
|
|
var result = rectangle.clone();
|
|
expect(rectangle).not.toBe(result);
|
|
expect(rectangle).toEqual(result);
|
|
});
|
|
|
|
it("clone with a result parameter", function () {
|
|
var rectangle = new BoundingRectangle(1.0, 2.0, 3.0, 4.0);
|
|
var result = new BoundingRectangle(6.0, 7.0, 8.0, 9.0);
|
|
var returnedResult = rectangle.clone(result);
|
|
expect(result).not.toBe(rectangle);
|
|
expect(result).toEqual(rectangle);
|
|
expect(result).toBe(returnedResult);
|
|
});
|
|
|
|
it('clone works with "this" result parameter', function () {
|
|
var rectangle = new BoundingRectangle(1.0, 2.0, 3.0, 4.0);
|
|
var returnedResult = rectangle.clone(rectangle);
|
|
expect(rectangle.x).toEqual(1.0);
|
|
expect(rectangle.y).toEqual(2.0);
|
|
expect(rectangle.width).toEqual(3.0);
|
|
expect(rectangle.height).toEqual(4.0);
|
|
expect(rectangle).toBe(returnedResult);
|
|
});
|
|
|
|
it("equals", function () {
|
|
var rectangle = new BoundingRectangle(1.0, 2.0, 3.0, 4.0);
|
|
expect(rectangle.equals(new BoundingRectangle(1.0, 2.0, 3.0, 4.0))).toEqual(
|
|
true
|
|
);
|
|
expect(rectangle.equals(new BoundingRectangle(5.0, 2.0, 3.0, 4.0))).toEqual(
|
|
false
|
|
);
|
|
expect(rectangle.equals(new BoundingRectangle(1.0, 6.0, 3.0, 4.0))).toEqual(
|
|
false
|
|
);
|
|
expect(rectangle.equals(new BoundingRectangle(1.0, 2.0, 7.0, 4.0))).toEqual(
|
|
false
|
|
);
|
|
expect(rectangle.equals(new BoundingRectangle(1.0, 2.0, 3.0, 8.0))).toEqual(
|
|
false
|
|
);
|
|
expect(rectangle.equals(undefined)).toEqual(false);
|
|
});
|
|
|
|
var positions = [
|
|
new Cartesian2(3, -1),
|
|
new Cartesian2(2, -2),
|
|
new Cartesian2(1, -3),
|
|
new Cartesian2(0, 0),
|
|
new Cartesian2(-1, 1),
|
|
new Cartesian2(-2, 2),
|
|
new Cartesian2(-3, 3),
|
|
];
|
|
|
|
it("create axis aligned bounding rectangle", function () {
|
|
var rectangle = BoundingRectangle.fromPoints(positions);
|
|
expect(rectangle.x).toEqual(-3);
|
|
expect(rectangle.y).toEqual(-3);
|
|
expect(rectangle.width).toEqual(6);
|
|
expect(rectangle.height).toEqual(6);
|
|
});
|
|
|
|
it("fromPoints works with a result parameter", function () {
|
|
var result = new BoundingRectangle();
|
|
var rectangle = BoundingRectangle.fromPoints(positions, result);
|
|
expect(rectangle).toBe(result);
|
|
expect(rectangle.x).toEqual(-3);
|
|
expect(rectangle.y).toEqual(-3);
|
|
expect(rectangle.width).toEqual(6);
|
|
expect(rectangle.height).toEqual(6);
|
|
});
|
|
|
|
it("fromPoints creates an empty rectangle with no positions", function () {
|
|
var rectangle = BoundingRectangle.fromPoints();
|
|
expect(rectangle.x).toEqual(0.0);
|
|
expect(rectangle.y).toEqual(0.0);
|
|
expect(rectangle.width).toEqual(0.0);
|
|
expect(rectangle.height).toEqual(0.0);
|
|
});
|
|
|
|
it("fromRectangle creates an empty rectangle with no rectangle", function () {
|
|
var rectangle = BoundingRectangle.fromRectangle();
|
|
expect(rectangle.x).toEqual(0.0);
|
|
expect(rectangle.y).toEqual(0.0);
|
|
expect(rectangle.width).toEqual(0.0);
|
|
expect(rectangle.height).toEqual(0.0);
|
|
});
|
|
|
|
it("create a bounding rectangle from a rectangle", function () {
|
|
var rectangle = Rectangle.MAX_VALUE;
|
|
var projection = new GeographicProjection(Ellipsoid.UNIT_SPHERE);
|
|
var expected = new BoundingRectangle(
|
|
rectangle.west,
|
|
rectangle.south,
|
|
rectangle.east - rectangle.west,
|
|
rectangle.north - rectangle.south
|
|
);
|
|
expect(BoundingRectangle.fromRectangle(rectangle, projection)).toEqual(
|
|
expected
|
|
);
|
|
});
|
|
|
|
it("fromRectangle works with a result parameter", function () {
|
|
var rectangle = Rectangle.MAX_VALUE;
|
|
var expected = new BoundingRectangle(
|
|
rectangle.west,
|
|
rectangle.south,
|
|
rectangle.east - rectangle.west,
|
|
rectangle.north - rectangle.south
|
|
);
|
|
var projection = new GeographicProjection(Ellipsoid.UNIT_SPHERE);
|
|
|
|
var result = new BoundingRectangle();
|
|
var returnedResult = BoundingRectangle.fromRectangle(
|
|
rectangle,
|
|
projection,
|
|
result
|
|
);
|
|
expect(result).toBe(returnedResult);
|
|
expect(returnedResult).toEqual(expected);
|
|
});
|
|
it("intersect works", function () {
|
|
var rectangle1 = new BoundingRectangle(0, 0, 4, 4);
|
|
var rectangle2 = new BoundingRectangle(2, 2, 4, 4);
|
|
var rectangle3 = new BoundingRectangle(-6, 2, 4, 4);
|
|
var rectangle4 = new BoundingRectangle(8, 2, 4, 4);
|
|
var rectangle5 = new BoundingRectangle(2, -6, 4, 4);
|
|
var rectangle6 = new BoundingRectangle(2, 8, 4, 4);
|
|
expect(BoundingRectangle.intersect(rectangle1, rectangle2)).toEqual(
|
|
Intersect.INTERSECTING
|
|
);
|
|
expect(BoundingRectangle.intersect(rectangle1, rectangle3)).toEqual(
|
|
Intersect.OUTSIDE
|
|
);
|
|
expect(BoundingRectangle.intersect(rectangle1, rectangle4)).toEqual(
|
|
Intersect.OUTSIDE
|
|
);
|
|
expect(BoundingRectangle.intersect(rectangle1, rectangle5)).toEqual(
|
|
Intersect.OUTSIDE
|
|
);
|
|
expect(BoundingRectangle.intersect(rectangle1, rectangle6)).toEqual(
|
|
Intersect.OUTSIDE
|
|
);
|
|
});
|
|
|
|
it("union works without a result parameter", function () {
|
|
var rectangle1 = new BoundingRectangle(2.0, 0.0, 1.0, 1.0);
|
|
var rectangle2 = new BoundingRectangle(-2.0, 0.0, 1.0, 2.0);
|
|
var expected = new BoundingRectangle(-2.0, 0.0, 5.0, 2.0);
|
|
var returnedResult = BoundingRectangle.union(rectangle1, rectangle2);
|
|
expect(returnedResult).toEqual(expected);
|
|
});
|
|
|
|
it("union works with a result parameter", function () {
|
|
var rectangle1 = new BoundingRectangle(2.0, 0.0, 1.0, 1.0);
|
|
var rectangle2 = new BoundingRectangle(-2.0, 0.0, 1.0, 2.0);
|
|
var expected = new BoundingRectangle(-2.0, 0.0, 5.0, 2.0);
|
|
var result = new BoundingRectangle(-1.0, -1.0, 10.0, 10.0);
|
|
var returnedResult = BoundingRectangle.union(
|
|
rectangle1,
|
|
rectangle2,
|
|
result
|
|
);
|
|
expect(result).toBe(returnedResult);
|
|
expect(returnedResult).toEqual(expected);
|
|
});
|
|
|
|
it("expand works if rectangle needs to grow right", function () {
|
|
var rectangle = new BoundingRectangle(2.0, 0.0, 1.0, 1.0);
|
|
var point = new Cartesian2(4.0, 0.0);
|
|
var expected = new BoundingRectangle(2.0, 0.0, 2.0, 1.0);
|
|
var result = BoundingRectangle.expand(rectangle, point);
|
|
expect(result).toEqual(expected);
|
|
});
|
|
|
|
it("expand works if rectangle needs x to grow left", function () {
|
|
var rectangle = new BoundingRectangle(2.0, 0.0, 1.0, 1.0);
|
|
var point = new Cartesian2(0.0, 0.0);
|
|
var expected = new BoundingRectangle(0.0, 0.0, 3.0, 1.0);
|
|
var result = BoundingRectangle.expand(rectangle, point);
|
|
expect(result).toEqual(expected);
|
|
});
|
|
|
|
it("expand works if rectangle needs to grow up", function () {
|
|
var rectangle = new BoundingRectangle(2.0, 0.0, 1.0, 1.0);
|
|
var point = new Cartesian2(2.0, 2.0);
|
|
var expected = new BoundingRectangle(2.0, 0.0, 1.0, 2.0);
|
|
var result = BoundingRectangle.expand(rectangle, point);
|
|
expect(result).toEqual(expected);
|
|
});
|
|
|
|
it("expand works if rectangle needs x to grow down", function () {
|
|
var rectangle = new BoundingRectangle(2.0, 0.0, 1.0, 1.0);
|
|
var point = new Cartesian2(2.0, -1.0);
|
|
var expected = new BoundingRectangle(2.0, -1.0, 1.0, 2.0);
|
|
var result = BoundingRectangle.expand(rectangle, point);
|
|
expect(result).toEqual(expected);
|
|
});
|
|
|
|
it("expand works if rectangle does not need to grow", function () {
|
|
var rectangle = new BoundingRectangle(2.0, 0.0, 1.0, 1.0);
|
|
var point = new Cartesian2(2.5, 0.6);
|
|
var expected = new BoundingRectangle(2.0, 0.0, 1.0, 1.0);
|
|
var result = BoundingRectangle.expand(rectangle, point);
|
|
expect(result).toEqual(expected);
|
|
});
|
|
|
|
it("expand works with a result parameter", function () {
|
|
var rectangle = new BoundingRectangle(2.0, 0.0, 1.0, 1.0);
|
|
var point = new Cartesian2(2.0, -1.0);
|
|
var expected = new BoundingRectangle(2.0, -1.0, 1.0, 2.0);
|
|
var result = new BoundingRectangle();
|
|
var returnedResult = BoundingRectangle.expand(rectangle, point, result);
|
|
expect(returnedResult).toBe(returnedResult);
|
|
expect(result).toEqual(expected);
|
|
});
|
|
|
|
it("clone returns undefined with no parameter", function () {
|
|
expect(BoundingRectangle.clone()).toBeUndefined();
|
|
});
|
|
|
|
it("union throws with no left parameter", function () {
|
|
var right = new BoundingRectangle(1.0, 2.0, 3.0, 4.0);
|
|
expect(function () {
|
|
BoundingRectangle.union(undefined, right);
|
|
}).toThrowDeveloperError();
|
|
});
|
|
|
|
it("union throws with no right parameter", function () {
|
|
var left = new BoundingRectangle(1.0, 2.0, 3.0, 4.0);
|
|
expect(function () {
|
|
BoundingRectangle.union(left, undefined);
|
|
}).toThrowDeveloperError();
|
|
});
|
|
|
|
it("expand throws with no rectangle parameter", function () {
|
|
var point = new Cartesian2();
|
|
expect(function () {
|
|
BoundingRectangle.expand(undefined, point);
|
|
}).toThrowDeveloperError();
|
|
});
|
|
|
|
it("expand throws with no point parameter", function () {
|
|
var rectangle = new BoundingRectangle(1.0, 2.0, 3.0, 4.0);
|
|
expect(function () {
|
|
BoundingRectangle.expand(rectangle, undefined);
|
|
}).toThrowDeveloperError();
|
|
});
|
|
|
|
it("intersect throws with no left parameter", function () {
|
|
var right = new BoundingRectangle(1.0, 2.0, 3.0, 4.0);
|
|
expect(function () {
|
|
BoundingRectangle.intersect(undefined, right);
|
|
}).toThrowDeveloperError();
|
|
});
|
|
|
|
it("intersect throws with no right parameter", function () {
|
|
var left = new BoundingRectangle(1.0, 2.0, 3.0, 4.0);
|
|
expect(function () {
|
|
BoundingRectangle.intersect(left, undefined);
|
|
}).toThrowDeveloperError();
|
|
});
|
|
|
|
createPackableSpecs(BoundingRectangle, new BoundingRectangle(1, 2, 3, 4), [
|
|
1,
|
|
2,
|
|
3,
|
|
4,
|
|
]);
|
|
});
|