@combeenation/3d-viewer 14.0.1-rc1 → 14.1.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.
Files changed (67) hide show
  1. package/README.md +9 -9
  2. package/dist/lib-cjs/buildinfo.json +3 -3
  3. package/dist/lib-cjs/commonjs.tsconfig.tsbuildinfo +1 -1
  4. package/dist/lib-cjs/index.d.ts +51 -62
  5. package/dist/lib-cjs/index.js +84 -94
  6. package/dist/lib-cjs/index.js.map +1 -1
  7. package/dist/lib-cjs/internal/cbn-custom-babylon-loader-plugin.d.ts +10 -10
  8. package/dist/lib-cjs/internal/cbn-custom-babylon-loader-plugin.js +131 -131
  9. package/dist/lib-cjs/internal/cloning-helper.d.ts +19 -19
  10. package/dist/lib-cjs/internal/cloning-helper.js +163 -163
  11. package/dist/lib-cjs/internal/device-helper.d.ts +9 -9
  12. package/dist/lib-cjs/internal/device-helper.js +24 -24
  13. package/dist/lib-cjs/internal/geometry-helper.d.ts +21 -21
  14. package/dist/lib-cjs/internal/geometry-helper.js +145 -145
  15. package/dist/lib-cjs/internal/metadata-helper.d.ts +26 -26
  16. package/dist/lib-cjs/internal/metadata-helper.js +50 -50
  17. package/dist/lib-cjs/internal/paintable-helper.d.ts +40 -40
  18. package/dist/lib-cjs/internal/paintable-helper.js +286 -286
  19. package/dist/lib-cjs/internal/tags-helper.d.ts +12 -12
  20. package/dist/lib-cjs/internal/tags-helper.js +37 -37
  21. package/dist/lib-cjs/manager/camera-manager.d.ts +110 -110
  22. package/dist/lib-cjs/manager/camera-manager.js +209 -206
  23. package/dist/lib-cjs/manager/camera-manager.js.map +1 -1
  24. package/dist/lib-cjs/manager/debug-manager.d.ts +60 -60
  25. package/dist/lib-cjs/manager/debug-manager.js +217 -217
  26. package/dist/lib-cjs/manager/event-manager.d.ts +52 -52
  27. package/dist/lib-cjs/manager/event-manager.js +71 -71
  28. package/dist/lib-cjs/manager/gltf-export-manager.d.ts +75 -84
  29. package/dist/lib-cjs/manager/gltf-export-manager.js +286 -290
  30. package/dist/lib-cjs/manager/gltf-export-manager.js.map +1 -1
  31. package/dist/lib-cjs/manager/material-manager.d.ts +35 -35
  32. package/dist/lib-cjs/manager/material-manager.js +125 -125
  33. package/dist/lib-cjs/manager/model-manager.d.ts +145 -145
  34. package/dist/lib-cjs/manager/model-manager.js +382 -382
  35. package/dist/lib-cjs/manager/parameter-manager.d.ts +210 -210
  36. package/dist/lib-cjs/manager/parameter-manager.js +514 -514
  37. package/dist/lib-cjs/manager/scene-manager.d.ts +45 -45
  38. package/dist/lib-cjs/manager/scene-manager.js +64 -64
  39. package/dist/lib-cjs/manager/texture-manager.d.ts +12 -12
  40. package/dist/lib-cjs/manager/texture-manager.js +43 -43
  41. package/dist/lib-cjs/viewer-error.d.ts +48 -48
  42. package/dist/lib-cjs/viewer-error.js +60 -60
  43. package/dist/lib-cjs/viewer.d.ts +115 -115
  44. package/dist/lib-cjs/viewer.js +217 -217
  45. package/package.json +91 -91
  46. package/src/buildinfo.json +3 -3
  47. package/src/dev.ts +47 -47
  48. package/src/global-types.d.ts +39 -39
  49. package/src/index.ts +71 -81
  50. package/src/internal/cbn-custom-babylon-loader-plugin.ts +159 -159
  51. package/src/internal/cloning-helper.ts +225 -225
  52. package/src/internal/device-helper.ts +25 -25
  53. package/src/internal/geometry-helper.ts +181 -181
  54. package/src/internal/metadata-helper.ts +63 -63
  55. package/src/internal/paintable-helper.ts +310 -310
  56. package/src/internal/tags-helper.ts +41 -41
  57. package/src/manager/camera-manager.ts +368 -365
  58. package/src/manager/debug-manager.ts +245 -245
  59. package/src/manager/event-manager.ts +72 -72
  60. package/src/manager/gltf-export-manager.ts +356 -357
  61. package/src/manager/material-manager.ts +135 -135
  62. package/src/manager/model-manager.ts +458 -458
  63. package/src/manager/parameter-manager.ts +652 -652
  64. package/src/manager/scene-manager.ts +101 -101
  65. package/src/manager/texture-manager.ts +32 -32
  66. package/src/viewer-error.ts +68 -68
  67. package/src/viewer.ts +290 -290
@@ -1,210 +1,210 @@
1
- import { AbstractScene, Color3, Material, TransformNode, Vector3, Viewer } from '../index';
2
- /**
3
- * Parameters with a built in observer implementation
4
- */
5
- export declare const BuiltInParameter: {
6
- Visible: string;
7
- Material: string;
8
- Position: string;
9
- Rotation: string;
10
- Scaling: string;
11
- Color: string;
12
- Roughness: string;
13
- Metallic: string;
14
- Paintable: string;
15
- };
16
- export declare type ParameterName = string;
17
- export declare type ParameterValue = string | number | boolean;
18
- export declare type TagParameterSubject = {
19
- tagName: string;
20
- nodeName?: never;
21
- materialName?: never;
22
- };
23
- export declare type NodeParameterSubject = {
24
- tagName?: never;
25
- nodeName: string;
26
- materialName?: never;
27
- };
28
- export declare type MaterialParameterSubject = {
29
- tagName?: never;
30
- nodeName?: never;
31
- materialName: string;
32
- };
33
- /**
34
- * Defines which objects are affected by the parameter.\
35
- * This can be single nodes and materials or tags, which can be used to apply a parameter to a group of nodes or
36
- * materials.
37
- */
38
- export declare type ParameterSubject = TagParameterSubject | NodeParameterSubject | MaterialParameterSubject;
39
- /**
40
- * Bulk of targeted parameter values, mainly used as input for {@link ParameterManager.setParameterValues} function.\
41
- * E.g.
42
- * ```
43
- * [
44
- * { nodeName: 'someMesh', parameterName: BuiltInParameter.Visible, value: false },
45
- * { materialName: 'someMaterial', parameterName: BuiltInParameter.Color, value: '#DD0060' }
46
- * ]
47
- * ```
48
- * Each parameter value entry has to set exactly one of the subject keys (`nodeName`, `materialName` or `tagName`)
49
- */
50
- export declare type ParameterValues = (ParameterSubject & {
51
- parameterName: ParameterName;
52
- value: ParameterValue;
53
- })[];
54
- /**
55
- * Definition of callback function for parameter change
56
- */
57
- export declare type ParameterObserver = (payload: ParameterObserverPayload) => Promise<void>;
58
- /**
59
- * Payload of parameter observer.\
60
- * Contains current data of parameter entry, which can be usefull for implementing the dedicated observer
61
- */
62
- export declare type ParameterObserverPayload = {
63
- subject: ParameterSubject;
64
- nodes: TransformNode[];
65
- materials: Material[];
66
- newValue: ParameterValue;
67
- oldValue: ParameterValue | undefined;
68
- };
69
- declare type ParameterEntry = {
70
- subject: ParameterSubject;
71
- parameterName: ParameterName;
72
- value: ParameterValue;
73
- oldValue: ParameterValue | undefined;
74
- };
75
- export declare class ParameterManager {
76
- protected viewer: Viewer;
77
- /**
78
- * Parses and converts input to a boolean value, valid values are:
79
- * - true / false
80
- * - 1 / 0
81
- */
82
- static parseBoolean(value: ParameterValue): boolean;
83
- /**
84
- * Parses and converts input to a number value
85
- */
86
- static parseNumber(value: ParameterValue): number;
87
- /**
88
- * Parses and converts input to a string value
89
- */
90
- static parseString(value: ParameterValue): string;
91
- /**
92
- * Parses a string of format "(x,y,z)"" to a "Vector3".
93
- */
94
- static parseVector(value: ParameterValue): Vector3;
95
- /**
96
- * Parses a string of format `'(x,y,z)'` with angular degrees to a `Vector3` with rotation information in radians.
97
- */
98
- static parseRotation(value: ParameterValue): Vector3;
99
- /**
100
- * Parses a string of format `'#rrggbb'` or `'(r,g,b)'` to a `Color3`.
101
- */
102
- static parseColor(value: ParameterValue): Color3;
103
- protected _parameterEntries: ParameterEntry[];
104
- protected _parameterObserver: {
105
- [parameterName: ParameterName]: ParameterObserver;
106
- };
107
- constructor(viewer: Viewer);
108
- /**
109
- * Set parameter value for a certain node and calls the corresponding observer if the value has changed
110
- *
111
- * @returns "true" if parameter value has changed
112
- */
113
- setNodeParameterValue(nodeName: string, parameterName: ParameterName, value: ParameterValue): Promise<boolean>;
114
- /**
115
- * Set parameter value for a certain material and calls the corresponding observer if the value has changed
116
- *
117
- * @returns "true" if parameter value has changed
118
- */
119
- setMaterialParameterValue(materialName: string, parameterName: ParameterName, value: ParameterValue): Promise<boolean>;
120
- /**
121
- * Set parameter value for a certain tag and calls the corresponding observer if the value has changed.\
122
- * Setting a parameter value on a tag can affect multiple nodes and tags, depending which of these objects contains
123
- * the desired tag.
124
- *
125
- * @returns "true" if parameter value has changed
126
- */
127
- setTagParameterValue(tagName: string, parameterName: ParameterName, value: ParameterValue): Promise<boolean>;
128
- /**
129
- * Set multiple parameter values simultaniously.\
130
- * Tag parameters are applied before node and material parameters, node and materials are more specific and should
131
- * have priority.
132
- *
133
- * @returns Array of parameters, which have changed values
134
- */
135
- setParameterValues(values: ParameterValues): Promise<ParameterValues>;
136
- /**
137
- * @returns desired parameter value or "undefined" if parameter entry is not available.
138
- */
139
- getParameterValue(subject: ParameterSubject, parameterName: ParameterName): ParameterValue | undefined;
140
- /**
141
- * Define observer callback for certain parameter.\
142
- * There can only be one observer for a certain parameter name.\
143
- * Parameter observers can not be overwritten once they are defined, this also includes system observers for
144
- * {@link BuiltInParameter}.
145
- */
146
- setParameterObserver(parameterName: ParameterName, observer: ParameterObserver): void;
147
- /**
148
- * Print all parameter entries in table format into the console
149
- */
150
- printAllParameters(): void;
151
- /**
152
- * Applies all existing parameter entries to a certain "model", as defined in the {@link ModelManager}.\
153
- * This can be usefull when updating the model before showing it in the scene.
154
- *
155
- * @internal
156
- */
157
- applyAllParameterValuesToModel(model: AbstractScene): Promise<void>;
158
- /**
159
- * Applies all parameter values which are targeting a material.\
160
- * This can be usefull when updating a material definition before creating it.
161
- *
162
- * @internal
163
- */
164
- applyParameterValuesToMaterial(material: Material): Promise<void>;
165
- /**
166
- * @returns Desired parameter value of a certain node.
167
- * Tags are considered as well but have lower priority than node parameters, as these are more specific.
168
- *
169
- * @internal
170
- */
171
- getParameterValueOfNode(node: TransformNode, parameterName: string): ParameterValue | undefined;
172
- /**
173
- * @returns Desired parameter value of a certain material.
174
- * Tags are considered as well but have lower priority than material parameters, as these are more specific.
175
- * Unused ATM, but added for consistency as counter part for {@link getParameterValueOfNode}
176
- *
177
- * @internal
178
- */
179
- getParameterValueOfMaterial(material: Material, parameterName: string): ParameterValue | undefined;
180
- /**
181
- * Parameter observer implementation of default parameters
182
- */
183
- protected _addBuiltInParameterObservers(): void;
184
- /**
185
- * Change parameter value in array of existing parameter entries or create a new entry
186
- *
187
- * @returns "true" if parameter has changed or wasn't available before
188
- */
189
- protected _addParameterValue(subject: ParameterSubject, parameterName: ParameterName, value: ParameterValue): boolean;
190
- /**
191
- * Call parameter observer of desired parameter which usually apply the new values to the scene.
192
- *
193
- * @param assetContainer Asset container in which to look for the paramter entries subjects (e.g. the nodes and
194
- * materials to which the parameter values should be applied to).\
195
- * Defaults to `viewer.scene`.
196
- */
197
- protected _applyParameterValues(parameterEntries: ParameterEntry[], assetContainer?: AbstractScene): Promise<void>;
198
- /**
199
- * Call parameter observer of desired parameter
200
- *
201
- * @param assetContainer Optionally add an "asset container", which actually represents a model in the
202
- * {@link ModelManager}. Viewer scene is used if left empty.
203
- */
204
- protected _applyParameterValue(subject: ParameterSubject, parameterName: ParameterName, assetContainer?: AbstractScene): Promise<void>;
205
- protected _getAffectedMaterials(subject: ParameterSubject, assetContainer?: AbstractScene): Material[];
206
- protected _getAffectedNodes(subject: ParameterSubject, assetContainer?: AbstractScene): TransformNode[];
207
- protected _getEntry(subject: ParameterSubject, parameterName: ParameterName): ParameterEntry | undefined;
208
- protected _getEntriesOfSubject(subject: ParameterSubject): ParameterEntry[];
209
- }
210
- export {};
1
+ import { AbstractScene, Color3, Material, TransformNode, Vector3, Viewer } from '../index';
2
+ /**
3
+ * Parameters with a built in observer implementation
4
+ */
5
+ export declare const BuiltInParameter: {
6
+ Visible: string;
7
+ Material: string;
8
+ Position: string;
9
+ Rotation: string;
10
+ Scaling: string;
11
+ Color: string;
12
+ Roughness: string;
13
+ Metallic: string;
14
+ Paintable: string;
15
+ };
16
+ export declare type ParameterName = string;
17
+ export declare type ParameterValue = string | number | boolean;
18
+ export declare type TagParameterSubject = {
19
+ tagName: string;
20
+ nodeName?: never;
21
+ materialName?: never;
22
+ };
23
+ export declare type NodeParameterSubject = {
24
+ tagName?: never;
25
+ nodeName: string;
26
+ materialName?: never;
27
+ };
28
+ export declare type MaterialParameterSubject = {
29
+ tagName?: never;
30
+ nodeName?: never;
31
+ materialName: string;
32
+ };
33
+ /**
34
+ * Defines which objects are affected by the parameter.\
35
+ * This can be single nodes and materials or tags, which can be used to apply a parameter to a group of nodes or
36
+ * materials.
37
+ */
38
+ export declare type ParameterSubject = TagParameterSubject | NodeParameterSubject | MaterialParameterSubject;
39
+ /**
40
+ * Bulk of targeted parameter values, mainly used as input for {@link ParameterManager.setParameterValues} function.\
41
+ * E.g.
42
+ * ```
43
+ * [
44
+ * { nodeName: 'someMesh', parameterName: BuiltInParameter.Visible, value: false },
45
+ * { materialName: 'someMaterial', parameterName: BuiltInParameter.Color, value: '#DD0060' }
46
+ * ]
47
+ * ```
48
+ * Each parameter value entry has to set exactly one of the subject keys (`nodeName`, `materialName` or `tagName`)
49
+ */
50
+ export declare type ParameterValues = (ParameterSubject & {
51
+ parameterName: ParameterName;
52
+ value: ParameterValue;
53
+ })[];
54
+ /**
55
+ * Definition of callback function for parameter change
56
+ */
57
+ export declare type ParameterObserver = (payload: ParameterObserverPayload) => Promise<void>;
58
+ /**
59
+ * Payload of parameter observer.\
60
+ * Contains current data of parameter entry, which can be usefull for implementing the dedicated observer
61
+ */
62
+ export declare type ParameterObserverPayload = {
63
+ subject: ParameterSubject;
64
+ nodes: TransformNode[];
65
+ materials: Material[];
66
+ newValue: ParameterValue;
67
+ oldValue: ParameterValue | undefined;
68
+ };
69
+ declare type ParameterEntry = {
70
+ subject: ParameterSubject;
71
+ parameterName: ParameterName;
72
+ value: ParameterValue;
73
+ oldValue: ParameterValue | undefined;
74
+ };
75
+ export declare class ParameterManager {
76
+ protected viewer: Viewer;
77
+ /**
78
+ * Parses and converts input to a boolean value, valid values are:
79
+ * - true / false
80
+ * - 1 / 0
81
+ */
82
+ static parseBoolean(value: ParameterValue): boolean;
83
+ /**
84
+ * Parses and converts input to a number value
85
+ */
86
+ static parseNumber(value: ParameterValue): number;
87
+ /**
88
+ * Parses and converts input to a string value
89
+ */
90
+ static parseString(value: ParameterValue): string;
91
+ /**
92
+ * Parses a string of format "(x,y,z)"" to a "Vector3".
93
+ */
94
+ static parseVector(value: ParameterValue): Vector3;
95
+ /**
96
+ * Parses a string of format `'(x,y,z)'` with angular degrees to a `Vector3` with rotation information in radians.
97
+ */
98
+ static parseRotation(value: ParameterValue): Vector3;
99
+ /**
100
+ * Parses a string of format `'#rrggbb'` or `'(r,g,b)'` to a `Color3`.
101
+ */
102
+ static parseColor(value: ParameterValue): Color3;
103
+ protected _parameterEntries: ParameterEntry[];
104
+ protected _parameterObserver: {
105
+ [parameterName: ParameterName]: ParameterObserver;
106
+ };
107
+ constructor(viewer: Viewer);
108
+ /**
109
+ * Set parameter value for a certain node and calls the corresponding observer if the value has changed
110
+ *
111
+ * @returns "true" if parameter value has changed
112
+ */
113
+ setNodeParameterValue(nodeName: string, parameterName: ParameterName, value: ParameterValue): Promise<boolean>;
114
+ /**
115
+ * Set parameter value for a certain material and calls the corresponding observer if the value has changed
116
+ *
117
+ * @returns "true" if parameter value has changed
118
+ */
119
+ setMaterialParameterValue(materialName: string, parameterName: ParameterName, value: ParameterValue): Promise<boolean>;
120
+ /**
121
+ * Set parameter value for a certain tag and calls the corresponding observer if the value has changed.\
122
+ * Setting a parameter value on a tag can affect multiple nodes and tags, depending which of these objects contains
123
+ * the desired tag.
124
+ *
125
+ * @returns "true" if parameter value has changed
126
+ */
127
+ setTagParameterValue(tagName: string, parameterName: ParameterName, value: ParameterValue): Promise<boolean>;
128
+ /**
129
+ * Set multiple parameter values simultaniously.\
130
+ * Tag parameters are applied before node and material parameters, node and materials are more specific and should
131
+ * have priority.
132
+ *
133
+ * @returns Array of parameters, which have changed values
134
+ */
135
+ setParameterValues(values: ParameterValues): Promise<ParameterValues>;
136
+ /**
137
+ * @returns desired parameter value or "undefined" if parameter entry is not available.
138
+ */
139
+ getParameterValue(subject: ParameterSubject, parameterName: ParameterName): ParameterValue | undefined;
140
+ /**
141
+ * Define observer callback for certain parameter.\
142
+ * There can only be one observer for a certain parameter name.\
143
+ * Parameter observers can not be overwritten once they are defined, this also includes system observers for
144
+ * {@link BuiltInParameter}.
145
+ */
146
+ setParameterObserver(parameterName: ParameterName, observer: ParameterObserver): void;
147
+ /**
148
+ * Print all parameter entries in table format into the console
149
+ */
150
+ printAllParameters(): void;
151
+ /**
152
+ * Applies all existing parameter entries to a certain "model", as defined in the {@link ModelManager}.\
153
+ * This can be usefull when updating the model before showing it in the scene.
154
+ *
155
+ * @internal
156
+ */
157
+ applyAllParameterValuesToModel(model: AbstractScene): Promise<void>;
158
+ /**
159
+ * Applies all parameter values which are targeting a material.\
160
+ * This can be usefull when updating a material definition before creating it.
161
+ *
162
+ * @internal
163
+ */
164
+ applyParameterValuesToMaterial(material: Material): Promise<void>;
165
+ /**
166
+ * @returns Desired parameter value of a certain node.
167
+ * Tags are considered as well but have lower priority than node parameters, as these are more specific.
168
+ *
169
+ * @internal
170
+ */
171
+ getParameterValueOfNode(node: TransformNode, parameterName: string): ParameterValue | undefined;
172
+ /**
173
+ * @returns Desired parameter value of a certain material.
174
+ * Tags are considered as well but have lower priority than material parameters, as these are more specific.
175
+ * Unused ATM, but added for consistency as counter part for {@link getParameterValueOfNode}
176
+ *
177
+ * @internal
178
+ */
179
+ getParameterValueOfMaterial(material: Material, parameterName: string): ParameterValue | undefined;
180
+ /**
181
+ * Parameter observer implementation of default parameters
182
+ */
183
+ protected _addBuiltInParameterObservers(): void;
184
+ /**
185
+ * Change parameter value in array of existing parameter entries or create a new entry
186
+ *
187
+ * @returns "true" if parameter has changed or wasn't available before
188
+ */
189
+ protected _addParameterValue(subject: ParameterSubject, parameterName: ParameterName, value: ParameterValue): boolean;
190
+ /**
191
+ * Call parameter observer of desired parameter which usually apply the new values to the scene.
192
+ *
193
+ * @param assetContainer Asset container in which to look for the paramter entries subjects (e.g. the nodes and
194
+ * materials to which the parameter values should be applied to).\
195
+ * Defaults to `viewer.scene`.
196
+ */
197
+ protected _applyParameterValues(parameterEntries: ParameterEntry[], assetContainer?: AbstractScene): Promise<void>;
198
+ /**
199
+ * Call parameter observer of desired parameter
200
+ *
201
+ * @param assetContainer Optionally add an "asset container", which actually represents a model in the
202
+ * {@link ModelManager}. Viewer scene is used if left empty.
203
+ */
204
+ protected _applyParameterValue(subject: ParameterSubject, parameterName: ParameterName, assetContainer?: AbstractScene): Promise<void>;
205
+ protected _getAffectedMaterials(subject: ParameterSubject, assetContainer?: AbstractScene): Material[];
206
+ protected _getAffectedNodes(subject: ParameterSubject, assetContainer?: AbstractScene): TransformNode[];
207
+ protected _getEntry(subject: ParameterSubject, parameterName: ParameterName): ParameterEntry | undefined;
208
+ protected _getEntriesOfSubject(subject: ParameterSubject): ParameterEntry[];
209
+ }
210
+ export {};