15832144755
2022-01-06 7b4c8991dca9cf2a809a95e239d144697d3afb56
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
import { Cartesian3 } from "../../Source/Cesium.js";
import { EllipsoidGeometry } from "../../Source/Cesium.js";
import { Matrix4 } from "../../Source/Cesium.js";
import { PrimitiveType } from "../../Source/Cesium.js";
import { VertexFormat } from "../../Source/Cesium.js";
import { createTangentSpaceDebugPrimitive } from "../../Source/Cesium.js";
 
describe("Scene/createTangentSpaceDebugPrimitive", function () {
  it("computes all attributes", function () {
    var geometry = new EllipsoidGeometry({
      vertexFormat: VertexFormat.ALL,
      radii: new Cartesian3(500000.0, 500000.0, 1000000.0),
    });
    var modelMatrix = Matrix4.multiplyByTranslation(
      Matrix4.IDENTITY,
      new Cartesian3(0.0, 0.0, 11000000.0),
      new Matrix4()
    );
 
    var primitive = createTangentSpaceDebugPrimitive({
      geometry: geometry,
      modelMatrix: modelMatrix,
      length: 1000.0,
    });
 
    expect(primitive.geometryInstances).toBeDefined();
    expect(primitive.appearance).toBeDefined();
    expect(primitive.asynchronous).toBe(false);
 
    var instances = primitive.geometryInstances;
    expect(instances.length).toEqual(3);
 
    expect(instances[0].modelMatrix).toEqual(modelMatrix);
    expect(instances[1].modelMatrix).toEqual(modelMatrix);
    expect(instances[2].modelMatrix).toEqual(modelMatrix);
 
    expect(instances[0].attributes).toBeDefined();
    expect(instances[0].attributes.color).toBeDefined();
    expect(instances[1].attributes).toBeDefined();
    expect(instances[1].attributes.color).toBeDefined();
    expect(instances[2].attributes).toBeDefined();
    expect(instances[2].attributes.color).toBeDefined();
 
    expect(instances[0].geometry.primitiveType).toEqual(PrimitiveType.LINES);
    expect(instances[1].geometry.primitiveType).toEqual(PrimitiveType.LINES);
    expect(instances[2].geometry.primitiveType).toEqual(PrimitiveType.LINES);
  });
 
  it("throws without geometry", function () {
    expect(function () {
      createTangentSpaceDebugPrimitive();
    }).toThrowDeveloperError();
  });
});