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.

312 lines
12 KiB
JavaScript

import { Cartesian3 } from "../../Source/Cesium.js";
import { Color } from "../../Source/Cesium.js";
import { GeometryOffsetAttribute } from "../../Source/Cesium.js";
import { JulianDate } from "../../Source/Cesium.js";
import { Quaternion } from "../../Source/Cesium.js";
import { TimeIntervalCollection } from "../../Source/Cesium.js";
import { ConstantPositionProperty } from "../../Source/Cesium.js";
import { ConstantProperty } from "../../Source/Cesium.js";
import { CylinderGeometryUpdater } from "../../Source/Cesium.js";
import { CylinderGraphics } from "../../Source/Cesium.js";
import { Entity } from "../../Source/Cesium.js";
import { SampledPositionProperty } from "../../Source/Cesium.js";
import { SampledProperty } from "../../Source/Cesium.js";
import { HeightReference } from "../../Source/Cesium.js";
import { PrimitiveCollection } from "../../Source/Cesium.js";
import createDynamicGeometryUpdaterSpecs from "../createDynamicGeometryUpdaterSpecs.js";
import createDynamicProperty from "../createDynamicProperty.js";
import createGeometryUpdaterSpecs from "../createGeometryUpdaterSpecs.js";
import createScene from "../createScene.js";
describe(
"DataSources/CylinderGeometryUpdater",
function () {
var scene;
var time;
beforeAll(function () {
scene = createScene();
time = JulianDate.now();
});
afterAll(function () {
scene.destroyForSpecs();
});
function createBasicCylinder() {
var cylinder = new CylinderGraphics();
cylinder.length = new ConstantProperty(1000);
cylinder.topRadius = new ConstantProperty(1000);
cylinder.bottomRadius = new ConstantProperty(1000);
var entity = new Entity();
entity.position = new ConstantPositionProperty(
Cartesian3.fromDegrees(0, 0, 0)
);
entity.cylinder = cylinder;
return entity;
}
function createDynamicCylinder() {
var entity = createBasicCylinder();
entity.cylinder.topRadius = createDynamicProperty(4);
return entity;
}
it("No geometry available when topRadius is undefined", function () {
var entity = createBasicCylinder();
var updater = new CylinderGeometryUpdater(entity, scene);
entity.cylinder.topRadius = undefined;
updater._onEntityPropertyChanged(entity, "cylinder");
expect(updater.fillEnabled).toBe(false);
expect(updater.outlineEnabled).toBe(false);
expect(updater.isDynamic).toBe(false);
});
it("No geometry available when bottomRadius is undefined", function () {
var entity = createBasicCylinder();
var updater = new CylinderGeometryUpdater(entity, scene);
entity.cylinder.bottomRadius = undefined;
updater._onEntityPropertyChanged(entity, "cylinder");
expect(updater.fillEnabled).toBe(false);
expect(updater.outlineEnabled).toBe(false);
expect(updater.isDynamic).toBe(false);
});
it("A time-varying position causes geometry to be dynamic", function () {
var entity = createBasicCylinder();
var updater = new CylinderGeometryUpdater(entity, scene);
entity.position = new SampledPositionProperty();
entity.position.addSample(time, Cartesian3.ZERO);
updater._onEntityPropertyChanged(entity, "position");
expect(updater.isDynamic).toBe(true);
});
it("A time-varying bottomRadius causes geometry to be dynamic", function () {
var entity = createBasicCylinder();
var updater = new CylinderGeometryUpdater(entity, scene);
entity.cylinder.bottomRadius = new SampledProperty(Number);
entity.cylinder.bottomRadius.addSample(time, 1);
updater._onEntityPropertyChanged(entity, "cylinder");
expect(updater.isDynamic).toBe(true);
});
it("A time-varying topRadius causes geometry to be dynamic", function () {
var entity = createBasicCylinder();
var updater = new CylinderGeometryUpdater(entity, scene);
entity.cylinder.topRadius = new SampledProperty(Number);
entity.cylinder.topRadius.addSample(time, 1);
updater._onEntityPropertyChanged(entity, "cylinder");
expect(updater.isDynamic).toBe(true);
});
it("A time-varying length causes geometry to be dynamic", function () {
var entity = createBasicCylinder();
var updater = new CylinderGeometryUpdater(entity, scene);
entity.cylinder.length = new SampledProperty(Number);
entity.cylinder.length.addSample(time, 1);
updater._onEntityPropertyChanged(entity, "cylinder");
expect(updater.isDynamic).toBe(true);
});
it("A time-varying numberOfVerticalLines causes geometry to be dynamic", function () {
var entity = createBasicCylinder();
var updater = new CylinderGeometryUpdater(entity, scene);
entity.cylinder.numberOfVerticalLines = new SampledProperty(Number);
entity.cylinder.numberOfVerticalLines.addSample(time, 1);
updater._onEntityPropertyChanged(entity, "cylinder");
expect(updater.isDynamic).toBe(true);
});
it("Creates geometry with expected properties", function () {
var options = {
length: 1,
topRadius: 3,
bottomRadius: 2,
numberOfVerticalLines: 15,
};
var entity = new Entity();
entity.position = new ConstantPositionProperty(new Cartesian3(4, 5, 6));
entity.orientation = new ConstantProperty(Quaternion.IDENTITY);
var cylinder = new CylinderGraphics();
cylinder.outline = true;
cylinder.numberOfVerticalLines = new ConstantProperty(
options.numberOfVerticalLines
);
cylinder.length = new ConstantProperty(options.length);
cylinder.topRadius = new ConstantProperty(options.topRadius);
cylinder.bottomRadius = new ConstantProperty(options.bottomRadius);
entity.cylinder = cylinder;
var updater = new CylinderGeometryUpdater(entity, scene);
var instance;
var geometry;
instance = updater.createFillGeometryInstance(time);
geometry = instance.geometry;
expect(geometry._topRadius).toEqual(options.topRadius);
expect(geometry._bottomRadius).toEqual(options.bottomRadius);
expect(geometry._length).toEqual(options.length);
expect(geometry._offsetAttribute).toBeUndefined();
instance = updater.createOutlineGeometryInstance(time);
geometry = instance.geometry;
expect(geometry._topRadius).toEqual(options.topRadius);
expect(geometry._bottomRadius).toEqual(options.bottomRadius);
expect(geometry._length).toEqual(options.length);
expect(geometry._numberOfVerticalLines).toEqual(
options.numberOfVerticalLines
);
expect(geometry._offsetAttribute).toBeUndefined();
});
it("Creates geometry with expected offsetAttribute", function () {
var entity = createBasicCylinder();
var graphics = entity.cylinder;
graphics.outline = true;
graphics.outlineColor = Color.BLACK;
graphics.height = new ConstantProperty(20.0);
graphics.extrudedHeight = new ConstantProperty(0.0);
var updater = new CylinderGeometryUpdater(entity, getScene());
var instance;
updater._onEntityPropertyChanged(entity, "cylinder");
instance = updater.createFillGeometryInstance(time);
expect(instance.geometry._offsetAttribute).toBeUndefined();
instance = updater.createOutlineGeometryInstance(time);
expect(instance.geometry._offsetAttribute).toBeUndefined();
graphics.heightReference = new ConstantProperty(HeightReference.NONE);
updater._onEntityPropertyChanged(entity, "cylinder");
instance = updater.createFillGeometryInstance(time);
expect(instance.geometry._offsetAttribute).toBeUndefined();
instance = updater.createOutlineGeometryInstance(time);
expect(instance.geometry._offsetAttribute).toBeUndefined();
graphics.heightReference = new ConstantProperty(
HeightReference.CLAMP_TO_GROUND
);
updater._onEntityPropertyChanged(entity, "cylinder");
instance = updater.createFillGeometryInstance(time);
expect(instance.geometry._offsetAttribute).toEqual(
GeometryOffsetAttribute.ALL
);
instance = updater.createOutlineGeometryInstance(time);
expect(instance.geometry._offsetAttribute).toEqual(
GeometryOffsetAttribute.ALL
);
graphics.heightReference = new ConstantProperty(
HeightReference.RELATIVE_TO_GROUND
);
updater._onEntityPropertyChanged(entity, "cylinder");
instance = updater.createFillGeometryInstance(time);
expect(instance.geometry._offsetAttribute).toEqual(
GeometryOffsetAttribute.ALL
);
instance = updater.createOutlineGeometryInstance(time);
expect(instance.geometry._offsetAttribute).toEqual(
GeometryOffsetAttribute.ALL
);
});
it("dynamic updater sets properties", function () {
var cylinder = new CylinderGraphics();
cylinder.topRadius = createDynamicProperty(2);
cylinder.bottomRadius = createDynamicProperty(1);
cylinder.length = createDynamicProperty(3);
var entity = new Entity();
entity.position = createDynamicProperty(Cartesian3.UNIT_Z);
entity.orientation = createDynamicProperty(Quaternion.IDENTITY);
entity.cylinder = cylinder;
var updater = new CylinderGeometryUpdater(entity, scene);
var dynamicUpdater = updater.createDynamicUpdater(
new PrimitiveCollection(),
new PrimitiveCollection()
);
dynamicUpdater.update(JulianDate.now());
var options = dynamicUpdater._options;
expect(options.topRadius).toEqual(cylinder.topRadius.getValue());
expect(options.bottomRadius).toEqual(cylinder.bottomRadius.getValue());
expect(options.length).toEqual(cylinder.length.getValue());
expect(options.offsetAttribute).toBeUndefined();
});
it("geometryChanged event is raised when expected", function () {
var entity = createBasicCylinder();
var updater = new CylinderGeometryUpdater(entity, scene);
var listener = jasmine.createSpy("listener");
updater.geometryChanged.addEventListener(listener);
entity.position = new ConstantPositionProperty(Cartesian3.UNIT_Z);
updater._onEntityPropertyChanged(entity, "position");
expect(listener.calls.count()).toEqual(1);
entity.cylinder.topRadius = new ConstantProperty(82);
updater._onEntityPropertyChanged(entity, "cylinder");
expect(listener.calls.count()).toEqual(2);
entity.availability = new TimeIntervalCollection();
updater._onEntityPropertyChanged(entity, "availability");
expect(listener.calls.count()).toEqual(3);
entity.cylinder.topRadius = undefined;
updater._onEntityPropertyChanged(entity, "cylinder");
expect(listener.calls.count()).toEqual(4);
//Since there's no valid geometry, changing another property should not raise the event.
entity.cylinder.bottomRadius = undefined;
updater._onEntityPropertyChanged(entity, "cylinder");
//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);
entity.cylinder.topRadius = new SampledProperty(Number);
entity.cylinder.bottomRadius = new SampledProperty(Number);
updater._onEntityPropertyChanged(entity, "cylinder");
expect(listener.calls.count()).toEqual(5);
});
it("computes center", function () {
var entity = createBasicCylinder();
var updater = new CylinderGeometryUpdater(entity, scene);
expect(updater._computeCenter(time)).toEqual(
entity.position.getValue(time)
);
});
function getScene() {
return scene;
}
createGeometryUpdaterSpecs(
CylinderGeometryUpdater,
"cylinder",
createBasicCylinder,
getScene
);
createDynamicGeometryUpdaterSpecs(
CylinderGeometryUpdater,
"cylinder",
createDynamicCylinder,
getScene
);
},
"WebGL"
);