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.

166 lines
5.9 KiB
JavaScript

import { Cartesian3 } from "../../Source/Cesium.js";
import { JulianDate } from "../../Source/Cesium.js";
import { Quaternion } from "../../Source/Cesium.js";
import { TimeInterval } from "../../Source/Cesium.js";
import { ConstantProperty } from "../../Source/Cesium.js";
import { NodeTransformationProperty } from "../../Source/Cesium.js";
import { TimeIntervalCollectionProperty } from "../../Source/Cesium.js";
import testDefinitionChanged from "../testDefinitionChanged.js";
describe("DataSources/NodeTransformationProperty", function () {
it("default constructor sets expected values", function () {
var property = new NodeTransformationProperty();
expect(property.isConstant).toBe(true);
expect(property.translation).toBeUndefined();
expect(property.rotation).toBeUndefined();
expect(property.scale).toBeUndefined();
var result = property.getValue();
expect(result.translation).toEqual(Cartesian3.ZERO);
expect(result.rotation).toEqual(Quaternion.IDENTITY);
expect(result.scale).toEqual(new Cartesian3(1.0, 1.0, 1.0));
});
it("constructor sets options and allows raw assignment", function () {
var options = {
translation: Cartesian3.UNIT_Y,
rotation: new Quaternion(0.5, 0.5, 0.5, 0.5),
scale: Cartesian3.UNIT_X,
};
var property = new NodeTransformationProperty(options);
expect(property.translation).toBeInstanceOf(ConstantProperty);
expect(property.rotation).toBeInstanceOf(ConstantProperty);
expect(property.scale).toBeInstanceOf(ConstantProperty);
expect(property.translation.getValue()).toEqual(options.translation);
expect(property.rotation.getValue()).toEqual(options.rotation);
expect(property.scale.getValue()).toEqual(options.scale);
});
it("works with constant values", function () {
var property = new NodeTransformationProperty();
property.translation = new ConstantProperty(Cartesian3.UNIT_Y);
property.rotation = new ConstantProperty(
new Quaternion(0.5, 0.5, 0.5, 0.5)
);
property.scale = new ConstantProperty(Cartesian3.UNIT_X);
var result = property.getValue(JulianDate.now());
expect(result.translation).toEqual(Cartesian3.UNIT_Y);
expect(result.rotation).toEqual(new Quaternion(0.5, 0.5, 0.5, 0.5));
expect(result.scale).toEqual(Cartesian3.UNIT_X);
});
it("works with dynamic values", function () {
var property = new NodeTransformationProperty();
property.translation = new TimeIntervalCollectionProperty();
property.rotation = new TimeIntervalCollectionProperty();
property.scale = new TimeIntervalCollectionProperty();
var start = new JulianDate(1, 0);
var stop = new JulianDate(2, 0);
property.translation.intervals.addInterval(
new TimeInterval({
start: start,
stop: stop,
data: Cartesian3.UNIT_Y,
})
);
property.rotation.intervals.addInterval(
new TimeInterval({
start: start,
stop: stop,
data: new Quaternion(0.5, 0.5, 0.5, 0.5),
})
);
property.scale.intervals.addInterval(
new TimeInterval({
start: start,
stop: stop,
data: Cartesian3.UNIT_X,
})
);
expect(property.isConstant).toBe(false);
var result = property.getValue(start);
expect(result.translation).toEqual(Cartesian3.UNIT_Y);
expect(result.rotation).toEqual(new Quaternion(0.5, 0.5, 0.5, 0.5));
expect(result.scale).toEqual(Cartesian3.UNIT_X);
});
it("works with a result parameter", function () {
var property = new NodeTransformationProperty();
property.translation = new ConstantProperty(Cartesian3.UNIT_Y);
property.rotation = new ConstantProperty(
new Quaternion(0.5, 0.5, 0.5, 0.5)
);
property.scale = new ConstantProperty(Cartesian3.UNIT_X);
var translation = new Cartesian3();
var rotation = new Quaternion();
var scale = new Cartesian3();
var result = {
translation: translation,
rotation: rotation,
scale: scale,
};
var returnedResult = property.getValue(JulianDate.now(), result);
expect(returnedResult).toBe(result);
expect(returnedResult.translation).toBe(translation);
expect(returnedResult.translation).toEqual(Cartesian3.UNIT_Y);
expect(returnedResult.rotation).toBe(rotation);
expect(returnedResult.rotation).toEqual(new Quaternion(0.5, 0.5, 0.5, 0.5));
expect(returnedResult.scale).toBe(scale);
expect(returnedResult.scale).toEqual(Cartesian3.UNIT_X);
});
it("equals works", function () {
var left = new NodeTransformationProperty();
left.translation = new ConstantProperty(Cartesian3.UNIT_Y);
left.rotation = new ConstantProperty(new Quaternion(0.5, 0.5, 0.5, 0.5));
left.scale = new ConstantProperty(Cartesian3.UNIT_X);
var right = new NodeTransformationProperty();
right.translation = new ConstantProperty(Cartesian3.UNIT_Y);
right.rotation = new ConstantProperty(new Quaternion(0.5, 0.5, 0.5, 0.5));
right.scale = new ConstantProperty(Cartesian3.UNIT_X);
expect(left.equals(right)).toEqual(true);
right.scale = new ConstantProperty(Cartesian3.ZERO);
expect(left.equals(right)).toEqual(false);
right.scale = new ConstantProperty(Cartesian3.UNIT_X);
right.translation = new ConstantProperty(Cartesian3.ZERO);
expect(left.equals(right)).toEqual(false);
right.translation = new ConstantProperty(Cartesian3.UNIT_Y);
right.rotation = new ConstantProperty(Quaternion.ZERO);
expect(left.equals(right)).toEqual(false);
});
it("raises definitionChanged when a property is assigned or modified", function () {
var property = new NodeTransformationProperty();
testDefinitionChanged(
property,
"rotation",
Cartesian3.UNIT_X,
Cartesian3.ZERO
);
testDefinitionChanged(
property,
"translation",
new Quaternion(0.5, 0.5, 0.5, 0.5),
Quaternion.ZERO
);
testDefinitionChanged(
property,
"scale",
Cartesian3.UNIT_X,
Cartesian3.ZERO
);
});
});