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.

302 lines
11 KiB
JavaScript

import { ApproximateTerrainHeights } from "../../Source/Cesium.js";
import { Cartesian3 } from "../../Source/Cesium.js";
import { CornerType } from "../../Source/Cesium.js";
import { JulianDate } from "../../Source/Cesium.js";
import { Math as CesiumMath } from "../../Source/Cesium.js";
import { TimeInterval } from "../../Source/Cesium.js";
import { TimeIntervalCollection } from "../../Source/Cesium.js";
import { ConstantProperty } from "../../Source/Cesium.js";
import { CorridorGeometryUpdater } from "../../Source/Cesium.js";
import { CorridorGraphics } from "../../Source/Cesium.js";
import { Entity } from "../../Source/Cesium.js";
import { PropertyArray } from "../../Source/Cesium.js";
import { SampledPositionProperty } from "../../Source/Cesium.js";
import { SampledProperty } from "../../Source/Cesium.js";
import { TimeIntervalCollectionProperty } from "../../Source/Cesium.js";
import { PrimitiveCollection } from "../../Source/Cesium.js";
import createDynamicGeometryUpdaterSpecs from "../createDynamicGeometryUpdaterSpecs.js";
import createDynamicProperty from "../createDynamicProperty.js";
import createGeometryUpdaterGroundGeometrySpecs from "../createGeometryUpdaterGroundGeometrySpecs.js";
import createGeometryUpdaterSpecs from "../createGeometryUpdaterSpecs.js";
import createScene from "../createScene.js";
describe(
"DataSources/CorridorGeometryUpdater",
function () {
var scene;
var time;
beforeAll(function () {
scene = createScene();
time = JulianDate.now();
return ApproximateTerrainHeights.initialize();
});
afterAll(function () {
scene.destroyForSpecs();
ApproximateTerrainHeights._initPromise = undefined;
ApproximateTerrainHeights._terrainHeights = undefined;
});
function createBasicCorridor() {
var corridor = new CorridorGraphics();
corridor.positions = new ConstantProperty(
Cartesian3.fromDegreesArray([0, 0, 1, 0, 1, 1, 0, 1])
);
corridor.width = new ConstantProperty(1);
corridor.height = new ConstantProperty(0);
var entity = new Entity();
entity.corridor = corridor;
return entity;
}
function createDynamicCorridor() {
var entity = createBasicCorridor();
entity.corridor.positions = createDynamicProperty(
Cartesian3.fromDegreesArray([0, 0, 1, 0, 1, 1, 0, 1])
);
return entity;
}
function createBasicCorridorWithoutHeight() {
var corridor = new CorridorGraphics();
corridor.positions = new ConstantProperty(
Cartesian3.fromDegreesArray([0, 0, 1, 0, 1, 1, 0, 1])
);
corridor.width = new ConstantProperty(1);
var entity = new Entity();
entity.corridor = corridor;
return entity;
}
function createDynamicCorridorWithoutHeight() {
var entity = createBasicCorridorWithoutHeight();
entity.corridor.positions = createDynamicProperty(
Cartesian3.fromDegreesArray([0, 0, 1, 0, 1, 1, 0, 1])
);
return entity;
}
it("A time-varying positions causes geometry to be dynamic", function () {
var entity = createBasicCorridor();
var updater = new CorridorGeometryUpdater(entity, scene);
var point1 = new SampledPositionProperty();
point1.addSample(time, new Cartesian3());
var point2 = new SampledPositionProperty();
point2.addSample(time, new Cartesian3());
var point3 = new SampledPositionProperty();
point3.addSample(time, new Cartesian3());
entity.corridor.positions = new PropertyArray();
entity.corridor.positions.setValue([point1, point2, point3]);
updater._onEntityPropertyChanged(entity, "corridor");
expect(updater.isDynamic).toBe(true);
});
it("A time-varying height causes geometry to be dynamic", function () {
var entity = createBasicCorridor();
var updater = new CorridorGeometryUpdater(entity, scene);
entity.corridor.height = new SampledProperty(Number);
entity.corridor.height.addSample(time, 1);
updater._onEntityPropertyChanged(entity, "corridor");
expect(updater.isDynamic).toBe(true);
});
it("A time-varying extrudedHeight causes geometry to be dynamic", function () {
var entity = createBasicCorridor();
var updater = new CorridorGeometryUpdater(entity, scene);
entity.corridor.extrudedHeight = new SampledProperty(Number);
entity.corridor.extrudedHeight.addSample(time, 1);
updater._onEntityPropertyChanged(entity, "corridor");
expect(updater.isDynamic).toBe(true);
});
it("A time-varying granularity causes geometry to be dynamic", function () {
var entity = createBasicCorridor();
var updater = new CorridorGeometryUpdater(entity, scene);
entity.corridor.granularity = new SampledProperty(Number);
entity.corridor.granularity.addSample(time, 1);
updater._onEntityPropertyChanged(entity, "corridor");
expect(updater.isDynamic).toBe(true);
});
it("A time-varying width causes geometry to be dynamic", function () {
var entity = createBasicCorridor();
var updater = new CorridorGeometryUpdater(entity, scene);
entity.corridor.width = new SampledProperty(Number);
entity.corridor.width.addSample(time, 1);
updater._onEntityPropertyChanged(entity, "corridor");
expect(updater.isDynamic).toBe(true);
});
it("A time-varying cornerType causes geometry to be dynamic", function () {
var entity = createBasicCorridor();
var updater = new CorridorGeometryUpdater(entity, scene);
entity.corridor.cornerType = new TimeIntervalCollectionProperty();
entity.corridor.cornerType.intervals.addInterval(
new TimeInterval({
start: JulianDate.now(),
stop: JulianDate.now(),
data: CornerType.ROUNDED,
})
);
updater._onEntityPropertyChanged(entity, "corridor");
expect(updater.isDynamic).toBe(true);
});
it("Creates geometry with expected properties", function () {
var options = {
height: 431,
extrudedHeight: 123,
granularity: 0.97,
width: 12,
cornerType: CornerType.MITERED,
};
var entity = createBasicCorridor();
var corridor = entity.corridor;
corridor.outline = true;
corridor.cornerType = new ConstantProperty(options.cornerType);
corridor.width = new ConstantProperty(options.width);
corridor.height = new ConstantProperty(options.height);
corridor.extrudedHeight = new ConstantProperty(options.extrudedHeight);
corridor.granularity = new ConstantProperty(options.granularity);
var updater = new CorridorGeometryUpdater(entity, scene);
var instance;
var geometry;
instance = updater.createFillGeometryInstance(time);
geometry = instance.geometry;
expect(geometry._width).toEqual(options.width);
expect(geometry._height).toEqual(options.height);
expect(geometry._granularity).toEqual(options.granularity);
expect(geometry._extrudedHeight).toEqual(options.extrudedHeight);
expect(geometry._cornerType).toEqual(options.cornerType);
expect(geometry._offsetAttribute).toBeUndefined();
instance = updater.createOutlineGeometryInstance(time);
geometry = instance.geometry;
expect(geometry._width).toEqual(options.width);
expect(geometry._height).toEqual(options.height);
expect(geometry._granularity).toEqual(options.granularity);
expect(geometry._extrudedHeight).toEqual(options.extrudedHeight);
expect(geometry._cornerType).toEqual(options.cornerType);
expect(geometry._offsetAttribute).toBeUndefined();
});
it("dynamic updater sets properties", function () {
var corridor = new CorridorGraphics();
corridor.positions = createDynamicProperty(
Cartesian3.fromDegreesArray([0, 0, 1, 0, 1, 1, 0, 1])
);
corridor.show = createDynamicProperty(true);
corridor.height = createDynamicProperty(3);
corridor.extrudedHeight = createDynamicProperty(2);
corridor.outline = createDynamicProperty(true);
corridor.fill = createDynamicProperty(true);
corridor.width = createDynamicProperty(6);
corridor.granularity = createDynamicProperty(2);
corridor.cornerType = createDynamicProperty(CornerType.MITERED);
var entity = new Entity();
entity.corridor = corridor;
var updater = new CorridorGeometryUpdater(entity, scene);
var dynamicUpdater = updater.createDynamicUpdater(
new PrimitiveCollection(),
new PrimitiveCollection()
);
dynamicUpdater.update(time);
var options = dynamicUpdater._options;
expect(options.positions).toEqual(corridor.positions.getValue());
expect(options.height).toEqual(corridor.height.getValue());
expect(options.extrudedHeight).toEqual(
corridor.extrudedHeight.getValue()
);
expect(options.width).toEqual(corridor.width.getValue());
expect(options.granularity).toEqual(corridor.granularity.getValue());
expect(options.cornerType).toEqual(corridor.cornerType.getValue());
expect(options.offsetAttribute).toBeUndefined();
});
it("geometryChanged event is raised when expected", function () {
var entity = createBasicCorridor();
var updater = new CorridorGeometryUpdater(entity, scene);
var listener = jasmine.createSpy("listener");
updater.geometryChanged.addEventListener(listener);
entity.corridor.positions = new ConstantProperty([]);
updater._onEntityPropertyChanged(entity, "corridor");
expect(listener.calls.count()).toEqual(1);
entity.corridor.height = new ConstantProperty(82);
updater._onEntityPropertyChanged(entity, "corridor");
expect(listener.calls.count()).toEqual(2);
entity.availability = new TimeIntervalCollection();
updater._onEntityPropertyChanged(entity, "availability");
expect(listener.calls.count()).toEqual(3);
entity.corridor.positions = undefined;
updater._onEntityPropertyChanged(entity, "corridor");
expect(listener.calls.count()).toEqual(4);
//Since there's no valid geometry, changing another property should not raise the event.
entity.corridor.height = undefined;
updater._onEntityPropertyChanged(entity, "corridor");
//Modifying an unrelated property should not have any effect.
entity.viewFrom = new ConstantProperty(Cartesian3.UNIT_X);
updater._onEntityPropertyChanged(entity, "viewFrom");
expect(listener.calls.count()).toEqual(4);
});
it("computes center", function () {
var entity = createBasicCorridor();
var updater = new CorridorGeometryUpdater(entity, scene);
expect(updater._computeCenter(time)).toEqualEpsilon(
Cartesian3.fromDegrees(1.0, 1.0),
CesiumMath.EPSILON10
);
});
function getScene() {
return scene;
}
createGeometryUpdaterSpecs(
CorridorGeometryUpdater,
"corridor",
createBasicCorridor,
getScene
);
createDynamicGeometryUpdaterSpecs(
CorridorGeometryUpdater,
"corridor",
createDynamicCorridor,
getScene
);
createGeometryUpdaterGroundGeometrySpecs(
CorridorGeometryUpdater,
"corridor",
createBasicCorridorWithoutHeight,
createDynamicCorridorWithoutHeight,
getScene
);
},
"WebGL"
);