@combeenation/3d-viewer 13.0.1 → 14.0.1-rc1

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 (72) 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 +62 -63
  5. package/dist/lib-cjs/index.js +94 -95
  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 -51
  22. package/dist/lib-cjs/manager/camera-manager.js +206 -153
  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 +84 -75
  29. package/dist/lib-cjs/manager/gltf-export-manager.js +290 -278
  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 -117
  44. package/dist/lib-cjs/viewer.js +217 -221
  45. package/dist/lib-cjs/viewer.js.map +1 -1
  46. package/package.json +91 -91
  47. package/src/buildinfo.json +3 -3
  48. package/src/dev.ts +47 -47
  49. package/src/global-types.d.ts +39 -39
  50. package/src/index.ts +81 -82
  51. package/src/internal/cbn-custom-babylon-loader-plugin.ts +159 -159
  52. package/src/internal/cloning-helper.ts +225 -225
  53. package/src/internal/device-helper.ts +25 -25
  54. package/src/internal/geometry-helper.ts +181 -181
  55. package/src/internal/metadata-helper.ts +63 -63
  56. package/src/internal/paintable-helper.ts +310 -310
  57. package/src/internal/tags-helper.ts +41 -41
  58. package/src/manager/camera-manager.ts +365 -236
  59. package/src/manager/debug-manager.ts +245 -245
  60. package/src/manager/event-manager.ts +72 -72
  61. package/src/manager/gltf-export-manager.ts +357 -341
  62. package/src/manager/material-manager.ts +135 -135
  63. package/src/manager/model-manager.ts +458 -458
  64. package/src/manager/parameter-manager.ts +652 -652
  65. package/src/manager/scene-manager.ts +101 -101
  66. package/src/manager/texture-manager.ts +32 -32
  67. package/src/viewer-error.ts +68 -68
  68. package/src/viewer.ts +290 -296
  69. package/dist/lib-cjs/manager/screenshot-manager.d.ts +0 -36
  70. package/dist/lib-cjs/manager/screenshot-manager.js +0 -40
  71. package/dist/lib-cjs/manager/screenshot-manager.js.map +0 -1
  72. package/src/manager/screenshot-manager.ts +0 -59
@@ -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 {};