@cognite/reveal 4.5.1 → 4.6.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/api-entry-points/core.d.ts +1 -1
- package/dist/index.js +146 -146
- package/dist/index.js.map +1 -1
- package/dist/packages/cad-geometry-loaders/src/CadManager.d.ts +11 -0
- package/dist/packages/cad-model/src/wrappers/CogniteCadModel.d.ts +13 -2
- package/dist/packages/camera-manager/index.d.ts +1 -1
- package/dist/packages/camera-manager/src/ComboControls.d.ts +12 -1
- package/dist/packages/rendering/index.d.ts +0 -1
- package/dist/packages/rendering/src/rendering/materials.d.ts +0 -2
- package/dist/packages/rendering/src/rendering/shaders.d.ts +0 -11
- package/dist/packages/rendering/src/transform/NodeTransformProvider.d.ts +8 -3
- package/dist/packages/utilities/src/constants.d.ts +1 -0
- package/package.json +13 -13
|
@@ -43,6 +43,17 @@ export declare class CadManager {
|
|
|
43
43
|
addModel(modelIdentifier: ModelIdentifier, geometryFilter?: GeometryFilter): Promise<CadNode>;
|
|
44
44
|
removeModel(model: CadNode): void;
|
|
45
45
|
getLoadingStateObserver(): Observable<LoadingState>;
|
|
46
|
+
/**
|
|
47
|
+
* Sets the Memory Cache size for all loaded models to the current budget
|
|
48
|
+
* @param budget The budget to calculate cache size by
|
|
49
|
+
*/
|
|
50
|
+
private updateCacheSizeForAllLoadedModels;
|
|
51
|
+
/**
|
|
52
|
+
* Sets the Memory Cache size the model to the current budget
|
|
53
|
+
* @param model The model to update
|
|
54
|
+
* @param budget The budget to calculate cache size by
|
|
55
|
+
*/
|
|
56
|
+
private setCacheSizeForModel;
|
|
46
57
|
private markNeedsRedraw;
|
|
47
58
|
private handleMaterialsChanged;
|
|
48
59
|
private updateTreeIndexToSectorsMap;
|
|
@@ -119,15 +119,17 @@ export declare class CogniteCadModel implements CdfModelNodeCollectionDataProvid
|
|
|
119
119
|
* @param treeIndices Tree indices of nodes to apply the transformation to.
|
|
120
120
|
* @param transformMatrix Transformation to apply.
|
|
121
121
|
* @param boundingBox Optional bounding box for the nodes before any transformation is applied. If given, it is assumed that all the nodes' geometry fit inside.
|
|
122
|
+
* @param space Space to apply the transformation in. Defaults to 'world'.
|
|
122
123
|
*/
|
|
123
|
-
setNodeTransform(treeIndices: NumericRange, transformMatrix: THREE.Matrix4, boundingBox?: THREE.Box3): void;
|
|
124
|
+
setNodeTransform(treeIndices: NumericRange, transformMatrix: THREE.Matrix4, boundingBox?: THREE.Box3, space?: 'model' | 'world'): void;
|
|
124
125
|
/**
|
|
125
126
|
* Set override transform of the node by tree index.
|
|
126
127
|
* @param treeIndex
|
|
127
128
|
* @param transform
|
|
128
129
|
* @param applyToChildren
|
|
130
|
+
* @param space
|
|
129
131
|
*/
|
|
130
|
-
setNodeTransformByTreeIndex(treeIndex: number, transform: THREE.Matrix4, applyToChildren?: boolean): Promise<number>;
|
|
132
|
+
setNodeTransformByTreeIndex(treeIndex: number, transform: THREE.Matrix4, applyToChildren?: boolean, space?: 'model' | 'world'): Promise<number>;
|
|
131
133
|
/**
|
|
132
134
|
* Resets the transformation for the nodes given.
|
|
133
135
|
* @param treeIndices Tree indices of the nodes to reset transforms for.
|
|
@@ -242,6 +244,15 @@ export declare class CogniteCadModel implements CdfModelNodeCollectionDataProvid
|
|
|
242
244
|
* ```
|
|
243
245
|
*/
|
|
244
246
|
getBoundingBoxByNodeId(nodeId: number, box?: THREE.Box3): Promise<THREE.Box3>;
|
|
247
|
+
/**
|
|
248
|
+
* Fetches a bounding box from the CDF by a list of nodeIds.
|
|
249
|
+
* @param nodeIds
|
|
250
|
+
* @example
|
|
251
|
+
* ```js
|
|
252
|
+
* const box = await model.getBoundingBoxByNodeIds([158239, 192837]);
|
|
253
|
+
* ```
|
|
254
|
+
*/
|
|
255
|
+
getBoundingBoxesByNodeIds(nodeIds: number[]): Promise<THREE.Box3[]>;
|
|
245
256
|
/**
|
|
246
257
|
* Determine the bounding box of the node identified by the tree index provided. Note that this
|
|
247
258
|
* function uses the CDF API to look up the bounding box.
|
|
@@ -6,6 +6,6 @@ export { ProxyCameraManager } from './src/ProxyCameraManager';
|
|
|
6
6
|
export { StationaryCameraManager } from './src/StationaryCameraManager';
|
|
7
7
|
export { CameraManagerHelper } from './src/CameraManagerHelper';
|
|
8
8
|
export { CameraManager } from './src/CameraManager';
|
|
9
|
-
export { ComboControls, ComboControlsOptions } from './src/ComboControls';
|
|
9
|
+
export { ComboControls, ComboControlsOptions, ComboControlsEventType } from './src/ComboControls';
|
|
10
10
|
export { DebouncedCameraStopEventTrigger } from './src/utils/DebouncedCameraStopEventTrigger';
|
|
11
11
|
export * from './src/types';
|
|
@@ -62,7 +62,18 @@ export type ComboControlsOptions = {
|
|
|
62
62
|
minDeltaDownscaleCoefficient: number;
|
|
63
63
|
maxDeltaDownscaleCoefficient: number;
|
|
64
64
|
};
|
|
65
|
-
|
|
65
|
+
/**
|
|
66
|
+
* The event type for events emitted by {@link ComboControls}.
|
|
67
|
+
*/
|
|
68
|
+
export type ComboControlsEventType = {
|
|
69
|
+
cameraChange: {
|
|
70
|
+
camera: {
|
|
71
|
+
position: Vector3;
|
|
72
|
+
target: Vector3;
|
|
73
|
+
};
|
|
74
|
+
};
|
|
75
|
+
};
|
|
76
|
+
export declare class ComboControls extends EventDispatcher<ComboControlsEventType> {
|
|
66
77
|
dispose: () => void;
|
|
67
78
|
private _temporarilyDisableDamping;
|
|
68
79
|
private readonly _camera;
|
|
@@ -13,7 +13,6 @@ export { DEFAULT_CLASSIFICATION } from './src/pointcloud-rendering/classificatio
|
|
|
13
13
|
export { RenderMode } from './src/rendering/RenderMode';
|
|
14
14
|
export { RenderLayer, setModelRenderLayers } from './src/utilities/renderUtilities';
|
|
15
15
|
export { StyledTreeIndexSets } from './src/utilities/types';
|
|
16
|
-
export { coverageShaders } from './src/rendering/shaders';
|
|
17
16
|
export { Materials } from './src/rendering/materials';
|
|
18
17
|
export { PointCloudMaterial, OctreeMaterialParams } from './src/pointcloud-rendering';
|
|
19
18
|
export { DefaultRenderPipelineProvider } from './src/render-pipeline-providers/DefaultRenderPipelineProvider';
|
|
@@ -11,14 +11,12 @@ export interface Materials {
|
|
|
11
11
|
quad: THREE.RawShaderMaterial;
|
|
12
12
|
cone: THREE.RawShaderMaterial;
|
|
13
13
|
eccentricCone: THREE.RawShaderMaterial;
|
|
14
|
-
sphericalSegment: THREE.RawShaderMaterial;
|
|
15
14
|
torusSegment: THREE.RawShaderMaterial;
|
|
16
15
|
generalCylinder: THREE.RawShaderMaterial;
|
|
17
16
|
trapezium: THREE.RawShaderMaterial;
|
|
18
17
|
ellipsoidSegment: THREE.RawShaderMaterial;
|
|
19
18
|
instancedMesh: THREE.RawShaderMaterial;
|
|
20
19
|
triangleMesh: THREE.RawShaderMaterial;
|
|
21
|
-
simple: THREE.RawShaderMaterial;
|
|
22
20
|
texturedMaterials: {
|
|
23
21
|
[key: string]: THREE.RawShaderMaterial;
|
|
24
22
|
};
|
|
@@ -2,10 +2,6 @@
|
|
|
2
2
|
* Copyright 2021 Cognite AS
|
|
3
3
|
*/
|
|
4
4
|
export declare const sectorShaders: {
|
|
5
|
-
simpleMesh: {
|
|
6
|
-
fragment: string;
|
|
7
|
-
vertex: string;
|
|
8
|
-
};
|
|
9
5
|
detailedMesh: {
|
|
10
6
|
fragment: string;
|
|
11
7
|
vertex: string;
|
|
@@ -87,10 +83,3 @@ export declare const depthBlendBlitShaders: {
|
|
|
87
83
|
fragment: string;
|
|
88
84
|
vertex: string;
|
|
89
85
|
};
|
|
90
|
-
/**
|
|
91
|
-
* Shaders use to estimate how many pixels a sector covers on screen.
|
|
92
|
-
*/
|
|
93
|
-
export declare const coverageShaders: {
|
|
94
|
-
fragment: string;
|
|
95
|
-
vertex: string;
|
|
96
|
-
};
|
|
@@ -1,13 +1,18 @@
|
|
|
1
1
|
/*!
|
|
2
2
|
* Copyright 2021 Cognite AS
|
|
3
3
|
*/
|
|
4
|
-
import * as THREE from 'three';
|
|
5
4
|
import { NumericRange } from '../../../utilities';
|
|
6
|
-
|
|
5
|
+
import { Matrix4 } from 'three';
|
|
6
|
+
export type NodeTransformChangeEventDelegate = (change: 'set' | 'reset', treeIndices: NumericRange, transform: Matrix4) => void;
|
|
7
7
|
export declare class NodeTransformProvider {
|
|
8
8
|
private readonly _events;
|
|
9
|
+
private readonly _treeIndexSetToWorldTransformMap;
|
|
10
|
+
private _cdfToWorldTransform;
|
|
11
|
+
private _worldToCdfTransform;
|
|
12
|
+
constructor();
|
|
9
13
|
on(event: 'changed', listener: NodeTransformChangeEventDelegate): void;
|
|
10
14
|
off(event: 'changed', listener: NodeTransformChangeEventDelegate): void;
|
|
11
|
-
|
|
15
|
+
setCdfToWorldTransform(cdfToModelTransformation: Matrix4): void;
|
|
16
|
+
setNodeTransform(treeIndices: NumericRange, transform: Matrix4, space?: 'model' | 'world'): void;
|
|
12
17
|
resetNodeTransform(treeIndices: NumericRange): void;
|
|
13
18
|
}
|
|
@@ -3,6 +3,7 @@
|
|
|
3
3
|
*/
|
|
4
4
|
import { Matrix4 } from 'three';
|
|
5
5
|
export declare const cadFromCdfToThreeMatrix: Matrix4;
|
|
6
|
+
export declare const cadFromThreeToCdfMatrix: Matrix4;
|
|
6
7
|
/**
|
|
7
8
|
* The transformation matrix from CDF coordinates to ThreeJS/Reveal.
|
|
8
9
|
* Note that this is already applied to Reveal models.
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@cognite/reveal",
|
|
3
|
-
"version": "4.
|
|
3
|
+
"version": "4.6.0",
|
|
4
4
|
"description": "WebGL based 3D viewer for CAD and point clouds processed in Cognite Data Fusion.",
|
|
5
5
|
"homepage": "https://github.com/cognitedata/reveal/tree/master/viewer",
|
|
6
6
|
"repository": {
|
|
@@ -78,30 +78,30 @@
|
|
|
78
78
|
"sparse-octree": "7.1.8"
|
|
79
79
|
},
|
|
80
80
|
"devDependencies": {
|
|
81
|
-
"@azure/msal-browser": "2.38.
|
|
81
|
+
"@azure/msal-browser": "2.38.3",
|
|
82
82
|
"@cognite/sdk": "8.3.0",
|
|
83
|
-
"@microsoft/api-extractor": "
|
|
83
|
+
"@microsoft/api-extractor": "7.38.2",
|
|
84
84
|
"@types/dat.gui": "0.7.11",
|
|
85
85
|
"@types/gl": "^6.0.2",
|
|
86
86
|
"@types/glob": "8.1.0",
|
|
87
|
-
"@types/jest": "29.5.
|
|
87
|
+
"@types/jest": "29.5.7",
|
|
88
88
|
"@types/jest-environment-puppeteer": "5.0.5",
|
|
89
89
|
"@types/jest-image-snapshot": "6.2.2",
|
|
90
90
|
"@types/jsdom": "21.1.4",
|
|
91
91
|
"@types/lodash": "4.14.200",
|
|
92
92
|
"@types/mixpanel-browser": "2.47.4",
|
|
93
|
-
"@types/node": "18.18.
|
|
93
|
+
"@types/node": "18.18.7",
|
|
94
94
|
"@types/random-seed": "0.3.4",
|
|
95
|
-
"@types/skmeans": "0.11.
|
|
95
|
+
"@types/skmeans": "0.11.6",
|
|
96
96
|
"@types/stats": "0.16.30",
|
|
97
|
-
"@types/three": "0.
|
|
97
|
+
"@types/three": "0.158.1",
|
|
98
98
|
"@types/tween.js": "18.5.1",
|
|
99
99
|
"@typescript-eslint/eslint-plugin": "6.7.0",
|
|
100
100
|
"@typescript-eslint/parser": "6.7.0",
|
|
101
|
-
"concurrently": "8.2.
|
|
101
|
+
"concurrently": "8.2.2",
|
|
102
102
|
"cross-env": "7.0.3",
|
|
103
103
|
"dat.gui": "0.7.9",
|
|
104
|
-
"eslint": "8.
|
|
104
|
+
"eslint": "8.52.0",
|
|
105
105
|
"eslint-config-prettier": "9.0.0",
|
|
106
106
|
"eslint-plugin-header": "3.1.1",
|
|
107
107
|
"eslint-plugin-jsdoc": "46.8.2",
|
|
@@ -121,17 +121,17 @@
|
|
|
121
121
|
"jest-puppeteer": "9.0.1",
|
|
122
122
|
"jsdom": "22.1.0",
|
|
123
123
|
"moq.ts": "10.0.8",
|
|
124
|
-
"nock": "13.3.
|
|
124
|
+
"nock": "13.3.6",
|
|
125
125
|
"prettier": "3.0.3",
|
|
126
126
|
"process": "0.11.10",
|
|
127
|
-
"puppeteer": "21.
|
|
127
|
+
"puppeteer": "21.4.1",
|
|
128
128
|
"random-seed": "0.3.0",
|
|
129
129
|
"raw-loader": "4.0.2",
|
|
130
130
|
"remove-files-webpack-plugin": "1.5.0",
|
|
131
131
|
"resize-observer-polyfill": "1.5.1",
|
|
132
132
|
"shx": "0.3.4",
|
|
133
133
|
"stats.js": "0.17.0",
|
|
134
|
-
"three": "0.
|
|
134
|
+
"three": "0.158.0",
|
|
135
135
|
"ts-jest": "29.1.1",
|
|
136
136
|
"ts-loader": "9.5.0",
|
|
137
137
|
"tsc-alias": "1.8.8",
|
|
@@ -146,7 +146,7 @@
|
|
|
146
146
|
},
|
|
147
147
|
"peerDependencies": {
|
|
148
148
|
"@cognite/sdk": "^7.16.0 || ^8.0.0",
|
|
149
|
-
"three": "0.
|
|
149
|
+
"three": "0.158.0"
|
|
150
150
|
},
|
|
151
151
|
"glslify": {
|
|
152
152
|
"transform": [
|