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.

49 lines
1.4 KiB
JavaScript

import { Cartesian3 } from "../../Source/Cesium.js";
import { Math as CesiumMath } from "../../Source/Cesium.js";
import { ConeEmitter } from "../../Source/Cesium.js";
import { Particle } from "../../Source/Cesium.js";
describe("Scene/ConeEmitter", function () {
it("default constructor", function () {
var emitter = new ConeEmitter();
expect(emitter.angle).toEqual(CesiumMath.toRadians(30.0));
});
it("constructor", function () {
var emitter = new ConeEmitter(CesiumMath.PI_OVER_SIX);
expect(emitter.angle).toEqual(CesiumMath.PI_OVER_SIX);
});
it("angle setter", function () {
var emitter = new ConeEmitter();
emitter.angle = CesiumMath.PI_OVER_SIX;
expect(emitter.angle).toEqual(CesiumMath.PI_OVER_SIX);
});
it("angle setter throws with invalid value", function () {
var emitter = new ConeEmitter();
expect(function () {
emitter.angle = undefined;
}).toThrowDeveloperError();
});
it("emits", function () {
var emitter = new ConeEmitter(CesiumMath.PI_OVER_SIX);
var particle = new Particle();
for (var i = 0; i < 1000; ++i) {
emitter.emit(particle);
expect(particle.position).toEqual(Cartesian3.ZERO);
expect(Cartesian3.magnitude(particle.velocity)).toEqualEpsilon(
1.0,
CesiumMath.EPSILON14
);
// acos(dot(unit v, unit z)) <= angle
expect(Math.acos(particle.velocity.z)).toBeLessThanOrEqualTo(
emitter.angle
);
}
});
});