@combeenation/3d-viewer 5.1.0-rc3 → 5.1.0-rc4
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/lib-cjs/api/classes/element.js +4 -18
- package/dist/lib-cjs/api/classes/element.js.map +1 -1
- package/dist/lib-cjs/api/classes/variant.js +37 -26
- package/dist/lib-cjs/api/classes/variant.js.map +1 -1
- package/dist/lib-cjs/api/util/babylonHelper.d.ts +2 -2
- package/dist/lib-cjs/api/util/babylonHelper.js +17 -6
- package/dist/lib-cjs/api/util/babylonHelper.js.map +1 -1
- package/dist/lib-cjs/api/util/sceneLoaderHelper.d.ts +8 -1
- package/dist/lib-cjs/api/util/sceneLoaderHelper.js +39 -2
- package/dist/lib-cjs/api/util/sceneLoaderHelper.js.map +1 -1
- package/dist/lib-cjs/buildinfo.json +1 -1
- package/dist/lib-es6/api/classes/animationInterface.d.ts +8 -0
- package/dist/lib-es6/api/classes/animationInterface.js +2 -0
- package/dist/lib-es6/api/classes/animationInterface.js.map +1 -0
- package/dist/lib-es6/api/classes/dottedPath.d.ts +79 -0
- package/dist/lib-es6/api/classes/dottedPath.js +185 -0
- package/dist/lib-es6/api/classes/dottedPath.js.map +1 -0
- package/dist/lib-es6/api/classes/element.d.ts +149 -0
- package/dist/lib-es6/api/classes/element.js +821 -0
- package/dist/lib-es6/api/classes/element.js.map +1 -0
- package/dist/lib-es6/api/classes/event.d.ts +326 -0
- package/dist/lib-es6/api/classes/event.js +369 -0
- package/dist/lib-es6/api/classes/event.js.map +1 -0
- package/dist/lib-es6/api/classes/eventBroadcaster.d.ts +26 -0
- package/dist/lib-es6/api/classes/eventBroadcaster.js +51 -0
- package/dist/lib-es6/api/classes/eventBroadcaster.js.map +1 -0
- package/dist/lib-es6/api/classes/parameter.d.ts +336 -0
- package/dist/lib-es6/api/classes/parameter.js +469 -0
- package/dist/lib-es6/api/classes/parameter.js.map +1 -0
- package/dist/lib-es6/api/classes/parameterObservable.d.ts +36 -0
- package/dist/lib-es6/api/classes/parameterObservable.js +99 -0
- package/dist/lib-es6/api/classes/parameterObservable.js.map +1 -0
- package/dist/lib-es6/api/classes/parameterizable.d.ts +15 -0
- package/dist/lib-es6/api/classes/parameterizable.js +147 -0
- package/dist/lib-es6/api/classes/parameterizable.js.map +1 -0
- package/dist/lib-es6/api/classes/placementAnimation.d.ts +44 -0
- package/dist/lib-es6/api/classes/placementAnimation.js +161 -0
- package/dist/lib-es6/api/classes/placementAnimation.js.map +1 -0
- package/dist/lib-es6/api/classes/variant.d.ts +234 -0
- package/dist/lib-es6/api/classes/variant.js +1199 -0
- package/dist/lib-es6/api/classes/variant.js.map +1 -0
- package/dist/lib-es6/api/classes/variantInstance.d.ts +45 -0
- package/dist/lib-es6/api/classes/variantInstance.js +106 -0
- package/dist/lib-es6/api/classes/variantInstance.js.map +1 -0
- package/dist/lib-es6/api/classes/variantParameterizable.d.ts +17 -0
- package/dist/lib-es6/api/classes/variantParameterizable.js +97 -0
- package/dist/lib-es6/api/classes/variantParameterizable.js.map +1 -0
- package/dist/lib-es6/api/classes/viewer.d.ts +184 -0
- package/dist/lib-es6/api/classes/viewer.js +729 -0
- package/dist/lib-es6/api/classes/viewer.js.map +1 -0
- package/dist/lib-es6/api/classes/viewerLight.d.ts +66 -0
- package/dist/lib-es6/api/classes/viewerLight.js +390 -0
- package/dist/lib-es6/api/classes/viewerLight.js.map +1 -0
- package/dist/lib-es6/api/internal/debugViewer.d.ts +13 -0
- package/dist/lib-es6/api/internal/debugViewer.js +84 -0
- package/dist/lib-es6/api/internal/debugViewer.js.map +1 -0
- package/dist/lib-es6/api/internal/lensRendering.d.ts +8 -0
- package/dist/lib-es6/api/internal/lensRendering.js +9 -0
- package/dist/lib-es6/api/internal/lensRendering.js.map +1 -0
- package/dist/lib-es6/api/internal/sceneSetup.d.ts +13 -0
- package/dist/lib-es6/api/internal/sceneSetup.js +234 -0
- package/dist/lib-es6/api/internal/sceneSetup.js.map +1 -0
- package/dist/lib-es6/api/manager/animationManager.d.ts +29 -0
- package/dist/lib-es6/api/manager/animationManager.js +128 -0
- package/dist/lib-es6/api/manager/animationManager.js.map +1 -0
- package/dist/lib-es6/api/manager/gltfExportManager.d.ts +65 -0
- package/dist/lib-es6/api/manager/gltfExportManager.js +221 -0
- package/dist/lib-es6/api/manager/gltfExportManager.js.map +1 -0
- package/dist/lib-es6/api/manager/sceneManager.d.ts +31 -0
- package/dist/lib-es6/api/manager/sceneManager.js +150 -0
- package/dist/lib-es6/api/manager/sceneManager.js.map +1 -0
- package/dist/lib-es6/api/manager/variantInstanceManager.d.ts +92 -0
- package/dist/lib-es6/api/manager/variantInstanceManager.js +333 -0
- package/dist/lib-es6/api/manager/variantInstanceManager.js.map +1 -0
- package/dist/lib-es6/api/store/specStorage.d.ts +24 -0
- package/dist/lib-es6/api/store/specStorage.js +49 -0
- package/dist/lib-es6/api/store/specStorage.js.map +1 -0
- package/dist/lib-es6/api/util/babylonHelper.d.ts +174 -0
- package/dist/lib-es6/api/util/babylonHelper.js +582 -0
- package/dist/lib-es6/api/util/babylonHelper.js.map +1 -0
- package/dist/lib-es6/api/util/globalTypes.d.ts +366 -0
- package/dist/lib-es6/api/util/globalTypes.js +2 -0
- package/dist/lib-es6/api/util/globalTypes.js.map +1 -0
- package/dist/lib-es6/api/util/resourceHelper.d.ts +58 -0
- package/dist/lib-es6/api/util/resourceHelper.js +248 -0
- package/dist/lib-es6/api/util/resourceHelper.js.map +1 -0
- package/dist/lib-es6/api/util/sceneLoaderHelper.d.ts +35 -0
- package/dist/lib-es6/api/util/sceneLoaderHelper.js +134 -0
- package/dist/lib-es6/api/util/sceneLoaderHelper.js.map +1 -0
- package/dist/lib-es6/api/util/stringHelper.d.ts +9 -0
- package/dist/lib-es6/api/util/stringHelper.js +22 -0
- package/dist/lib-es6/api/util/stringHelper.js.map +1 -0
- package/dist/lib-es6/api/util/structureHelper.d.ts +9 -0
- package/dist/lib-es6/api/util/structureHelper.js +46 -0
- package/dist/lib-es6/api/util/structureHelper.js.map +1 -0
- package/dist/lib-es6/buildinfo.json +3 -0
- package/dist/lib-es6/index.d.ts +49 -0
- package/dist/lib-es6/index.js +51 -0
- package/dist/lib-es6/index.js.map +1 -0
- package/package.json +6 -6
- package/src/api/classes/element.ts +4 -23
- package/src/api/classes/variant.ts +22 -3
- package/src/api/util/babylonHelper.ts +17 -7
- package/src/api/util/sceneLoaderHelper.ts +48 -2
|
@@ -0,0 +1,221 @@
|
|
|
1
|
+
import { __assign, __awaiter, __generator } from "tslib";
|
|
2
|
+
import { PBRMaterial } from '@babylonjs/core/Materials/PBR/pbrMaterial';
|
|
3
|
+
import { Color3 } from '@babylonjs/core/Maths/math.color';
|
|
4
|
+
import { AbstractMesh } from '@babylonjs/core/Meshes/abstractMesh';
|
|
5
|
+
import { GLTF2Export } from '@babylonjs/serializers/glTF/2.0';
|
|
6
|
+
import { isMeshIncludedInExclusionList } from '../util/structureHelper';
|
|
7
|
+
import { merge } from 'lodash-es';
|
|
8
|
+
import { Mesh } from '@babylonjs/core/Meshes/mesh';
|
|
9
|
+
var GltfExportManager = /** @class */ (function () {
|
|
10
|
+
/**
|
|
11
|
+
* Constructor.
|
|
12
|
+
*/
|
|
13
|
+
function GltfExportManager(viewer) {
|
|
14
|
+
this.viewer = viewer;
|
|
15
|
+
}
|
|
16
|
+
/**
|
|
17
|
+
* Creates an {@link GltfExportManager}.
|
|
18
|
+
*/
|
|
19
|
+
GltfExportManager.create = function (viewer) {
|
|
20
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
21
|
+
return __generator(this, function (_a) {
|
|
22
|
+
return [2 /*return*/, new GltfExportManager(viewer)];
|
|
23
|
+
});
|
|
24
|
+
});
|
|
25
|
+
};
|
|
26
|
+
/**
|
|
27
|
+
* Exports selected nodes to a file.
|
|
28
|
+
* @param filename optional name of the exported .GLB file.
|
|
29
|
+
* @param exportOptions export options to be merged with default options.
|
|
30
|
+
* @param excluded optional list of geometry (meshes, elements, variants, variantInstances) to be excluded from export.
|
|
31
|
+
*/
|
|
32
|
+
GltfExportManager.prototype.exportGlb = function (filename, exportOptions, excluded) {
|
|
33
|
+
if (filename === void 0) { filename = 'glb-export.glb'; }
|
|
34
|
+
if (exportOptions === void 0) { exportOptions = {}; }
|
|
35
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
36
|
+
var glbData, resBlob;
|
|
37
|
+
return __generator(this, function (_a) {
|
|
38
|
+
switch (_a.label) {
|
|
39
|
+
case 0:
|
|
40
|
+
this.exportPreProcess();
|
|
41
|
+
return [4 /*yield*/, GLTF2Export.GLBAsync(this.viewer.scene, 'dummy', this.gltfExportOptions(exportOptions, excluded))];
|
|
42
|
+
case 1:
|
|
43
|
+
glbData = _a.sent();
|
|
44
|
+
this.exportPostProcess();
|
|
45
|
+
resBlob = glbData.glTFFiles['dummy.glb'];
|
|
46
|
+
// check if result is valid, according to the typings this could also be a string
|
|
47
|
+
if (resBlob instanceof Blob) {
|
|
48
|
+
if (!filename.endsWith('.glb')) {
|
|
49
|
+
filename += '.glb';
|
|
50
|
+
}
|
|
51
|
+
return [2 /*return*/, new File([resBlob], filename)];
|
|
52
|
+
}
|
|
53
|
+
else {
|
|
54
|
+
// result was not a valid blob
|
|
55
|
+
return [2 /*return*/, undefined];
|
|
56
|
+
}
|
|
57
|
+
return [2 /*return*/];
|
|
58
|
+
}
|
|
59
|
+
});
|
|
60
|
+
});
|
|
61
|
+
};
|
|
62
|
+
/**
|
|
63
|
+
* Exports selected nodes to GLTF. This may result in more than one file, since textures are exported separately.
|
|
64
|
+
* @param filename name of the main (text-based) .GLTF file referring to separate texture files.
|
|
65
|
+
* @param exportOptions export options to be merged with default options.
|
|
66
|
+
* @param excluded optional list of geometry (meshes, elements, variants, variantInstances) to be excluded from export.
|
|
67
|
+
*/
|
|
68
|
+
GltfExportManager.prototype.exportGltfToFile = function (filename, exportOptions, excluded) {
|
|
69
|
+
if (exportOptions === void 0) { exportOptions = {}; }
|
|
70
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
71
|
+
return __generator(this, function (_a) {
|
|
72
|
+
switch (_a.label) {
|
|
73
|
+
case 0:
|
|
74
|
+
this.exportPreProcess();
|
|
75
|
+
return [4 /*yield*/, GLTF2Export.GLTFAsync(this.viewer.scene, filename, this.gltfExportOptions(exportOptions, excluded)).then(function (glb) {
|
|
76
|
+
glb.downloadFiles();
|
|
77
|
+
})];
|
|
78
|
+
case 1:
|
|
79
|
+
_a.sent();
|
|
80
|
+
this.exportPostProcess();
|
|
81
|
+
return [2 /*return*/];
|
|
82
|
+
}
|
|
83
|
+
});
|
|
84
|
+
});
|
|
85
|
+
};
|
|
86
|
+
/**
|
|
87
|
+
* Exports selected nodes to GLB. This results in one binary file.
|
|
88
|
+
* @param filename name of the .GLB file.
|
|
89
|
+
* @param exportOptions export options to be merged with default options.
|
|
90
|
+
* @param excluded optional list of geometry (meshes, elements, variants, variantInstances) to be excluded from export
|
|
91
|
+
*/
|
|
92
|
+
GltfExportManager.prototype.exportGlbToFile = function (filename, exportOptions, excluded) {
|
|
93
|
+
if (exportOptions === void 0) { exportOptions = {}; }
|
|
94
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
95
|
+
return __generator(this, function (_a) {
|
|
96
|
+
switch (_a.label) {
|
|
97
|
+
case 0:
|
|
98
|
+
this.exportPreProcess();
|
|
99
|
+
return [4 /*yield*/, GLTF2Export.GLBAsync(this.viewer.scene, filename, this.gltfExportOptions(exportOptions, excluded)).then(function (glb) {
|
|
100
|
+
glb.downloadFiles();
|
|
101
|
+
})];
|
|
102
|
+
case 1:
|
|
103
|
+
_a.sent();
|
|
104
|
+
this.exportPostProcess();
|
|
105
|
+
return [2 /*return*/];
|
|
106
|
+
}
|
|
107
|
+
});
|
|
108
|
+
});
|
|
109
|
+
};
|
|
110
|
+
/**
|
|
111
|
+
* Gets predefined {@link IExportOptions } merged with given ones.
|
|
112
|
+
*/
|
|
113
|
+
GltfExportManager.prototype.gltfExportOptions = function (mergeWithOptions, excluded) {
|
|
114
|
+
if (mergeWithOptions === void 0) { mergeWithOptions = {}; }
|
|
115
|
+
var defaultOptions = {
|
|
116
|
+
// includeCoordinateSystemConversionNodes: true,
|
|
117
|
+
shouldExportNode: function (node) {
|
|
118
|
+
if (!node.isEnabled()) {
|
|
119
|
+
return false;
|
|
120
|
+
}
|
|
121
|
+
if (node.isVisible === false) {
|
|
122
|
+
return false;
|
|
123
|
+
}
|
|
124
|
+
if (node.name === '__bounding_box__') {
|
|
125
|
+
return false;
|
|
126
|
+
}
|
|
127
|
+
if (excluded && node instanceof Mesh && isMeshIncludedInExclusionList(node, excluded)) {
|
|
128
|
+
return false;
|
|
129
|
+
}
|
|
130
|
+
return true;
|
|
131
|
+
},
|
|
132
|
+
};
|
|
133
|
+
return merge({}, defaultOptions, mergeWithOptions);
|
|
134
|
+
};
|
|
135
|
+
/**
|
|
136
|
+
* Stuff to be done before exporting to GLTF
|
|
137
|
+
*/
|
|
138
|
+
GltfExportManager.prototype.exportPreProcess = function () {
|
|
139
|
+
this.viewer.pauseRendering();
|
|
140
|
+
this.exchangeRefractionMaterials();
|
|
141
|
+
};
|
|
142
|
+
/**
|
|
143
|
+
* Stuff to be done after the GLTF export
|
|
144
|
+
*/
|
|
145
|
+
GltfExportManager.prototype.exportPostProcess = function () {
|
|
146
|
+
this.restoreRefractionMaterials();
|
|
147
|
+
this.viewer.resumeRendering();
|
|
148
|
+
};
|
|
149
|
+
/**
|
|
150
|
+
* Materials with refraction set are not exported properly.
|
|
151
|
+
* Exchange all such (relevant) materials with a more export-friendly version
|
|
152
|
+
*/
|
|
153
|
+
GltfExportManager.prototype.exchangeRefractionMaterials = function () {
|
|
154
|
+
for (var _i = 0, _a = this.viewer.scene.getNodes(); _i < _a.length; _i++) {
|
|
155
|
+
var n = _a[_i];
|
|
156
|
+
if (!(n instanceof AbstractMesh))
|
|
157
|
+
continue;
|
|
158
|
+
if (!(n.material instanceof PBRMaterial))
|
|
159
|
+
continue;
|
|
160
|
+
if (!n.material.subSurface.isRefractionEnabled)
|
|
161
|
+
continue;
|
|
162
|
+
if (n.material.transparencyMode !== PBRMaterial.PBRMATERIAL_OPAQUE)
|
|
163
|
+
continue;
|
|
164
|
+
// if we're here, we have a node holding a material with set refraction whose transparencyMode is set to PBRMATERIAL_OPAQUE
|
|
165
|
+
n.material = this.createRefractionMaterialReplacement(n.material);
|
|
166
|
+
}
|
|
167
|
+
};
|
|
168
|
+
/**
|
|
169
|
+
* Restore original materials with set refraction.
|
|
170
|
+
*/
|
|
171
|
+
GltfExportManager.prototype.restoreRefractionMaterials = function () {
|
|
172
|
+
for (var _i = 0, _a = this.viewer.scene.getNodes(); _i < _a.length; _i++) {
|
|
173
|
+
var n = _a[_i];
|
|
174
|
+
if (!(n instanceof AbstractMesh))
|
|
175
|
+
continue;
|
|
176
|
+
if (!(n.material instanceof PBRMaterial))
|
|
177
|
+
continue;
|
|
178
|
+
if (!this.isMaterialClonedForExport(n.material))
|
|
179
|
+
continue;
|
|
180
|
+
// at this point we have a pbrmaterial tagged as cloned in its metadata that's set on a mesh
|
|
181
|
+
// restore and dispose
|
|
182
|
+
var currMaterial = n.material;
|
|
183
|
+
var prevMaterial = this.viewer.scene.getMaterialByUniqueID(n.material.metadata.clonedFrom);
|
|
184
|
+
if (prevMaterial) {
|
|
185
|
+
n.material = prevMaterial; // restore previous material
|
|
186
|
+
currMaterial.dispose(false, true); // dispose of clone
|
|
187
|
+
}
|
|
188
|
+
}
|
|
189
|
+
};
|
|
190
|
+
/**
|
|
191
|
+
* Create an export-friendly replacement material for a material using refraction.
|
|
192
|
+
* @param mat Material to be replaced
|
|
193
|
+
*/
|
|
194
|
+
GltfExportManager.prototype.createRefractionMaterialReplacement = function (mat) {
|
|
195
|
+
// if we're dealing with a clone already, return it instead of cloning
|
|
196
|
+
if (this.isMaterialClonedForExport(mat))
|
|
197
|
+
return mat;
|
|
198
|
+
// change material according to https://www.notion.so/combeenation/Glas-materials-don-t-look-glasy-after-export-d5fda2c6515e4420a8772744d3e6b460
|
|
199
|
+
var clonedMaterial = mat.clone(mat.name); // clone material. clone uses same name
|
|
200
|
+
clonedMaterial.metadata = __assign(__assign({}, mat.metadata), { clonedFrom: mat.uniqueId }); // create shallow copy of metadata on clone. see https://forum.babylonjs.com/t/the-metadata-of-the-mesh-cloned-by-the-instantiatemodelstoscene-method-is-a-shallow-copy/21563
|
|
201
|
+
clonedMaterial.refractionTexture = null;
|
|
202
|
+
clonedMaterial.metallicReflectanceTexture = null; // is this the correct one for metallic roughness?
|
|
203
|
+
clonedMaterial.alpha = 0.7;
|
|
204
|
+
clonedMaterial.albedoColor = new Color3(0.3, 0.3, 0.3);
|
|
205
|
+
clonedMaterial.transparencyMode = PBRMaterial.PBRMATERIAL_ALPHABLEND;
|
|
206
|
+
clonedMaterial.metallic = 0.65;
|
|
207
|
+
clonedMaterial.roughness = 0.15;
|
|
208
|
+
return clonedMaterial;
|
|
209
|
+
};
|
|
210
|
+
/**
|
|
211
|
+
* Inspect if a material was temporarily cloned for GLB export
|
|
212
|
+
* @param mat Material to be inspected
|
|
213
|
+
*/
|
|
214
|
+
GltfExportManager.prototype.isMaterialClonedForExport = function (mat) {
|
|
215
|
+
var _a;
|
|
216
|
+
return !!((_a = mat.metadata) === null || _a === void 0 ? void 0 : _a.clonedFrom);
|
|
217
|
+
};
|
|
218
|
+
return GltfExportManager;
|
|
219
|
+
}());
|
|
220
|
+
export { GltfExportManager };
|
|
221
|
+
//# sourceMappingURL=gltfExportManager.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"gltfExportManager.js","sourceRoot":"","sources":["../../../../src/api/manager/gltfExportManager.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import { Camera } from '@babylonjs/core/Cameras/camera';
|
|
2
|
+
import { Scene as BabylonScene } from '@babylonjs/core/scene';
|
|
3
|
+
import { ParameterObservable } from '../classes/parameterObservable';
|
|
4
|
+
export declare class SceneManager extends ParameterObservable {
|
|
5
|
+
scene: BabylonScene;
|
|
6
|
+
protected readonly _parameterObservers: Map<string, ParameterObserver[]>;
|
|
7
|
+
/**
|
|
8
|
+
* Constructor.
|
|
9
|
+
*/
|
|
10
|
+
protected constructor(scene: BabylonScene);
|
|
11
|
+
/**
|
|
12
|
+
* Creates a {@link SceneManager} based on given BabylonJS scene.
|
|
13
|
+
*/
|
|
14
|
+
static create(scene: BabylonScene): Promise<SceneManager>;
|
|
15
|
+
/**
|
|
16
|
+
* The active `Camera`.
|
|
17
|
+
*/
|
|
18
|
+
get activeCamera(): Camera;
|
|
19
|
+
/**
|
|
20
|
+
* Places the given {@link ParameterBag} in the {@link SceneManager}'s parameters, replaces all patterns in the
|
|
21
|
+
* {@link StructureJson} and broadcasts all {@link ParameterObserver}s.
|
|
22
|
+
*
|
|
23
|
+
* @emit {@link Event.SCENE_PARAMETER_COMMITTED}
|
|
24
|
+
*/
|
|
25
|
+
commitParameters(parameters?: ParameterBag): Promise<SceneManager>;
|
|
26
|
+
protected addParameterObservers(): SceneManager;
|
|
27
|
+
/**
|
|
28
|
+
* Bootstrapping for parameters. It sets the `parametersInitialized` to true for all ancestors.
|
|
29
|
+
*/
|
|
30
|
+
protected bootstrapParameters(parameters?: ParameterBag): Promise<SceneManager>;
|
|
31
|
+
}
|
|
@@ -0,0 +1,150 @@
|
|
|
1
|
+
import { __awaiter, __extends, __generator } from "tslib";
|
|
2
|
+
import { cloneDeep, concat, merge } from 'lodash-es';
|
|
3
|
+
import { ParameterObservable } from '../classes/parameterObservable';
|
|
4
|
+
import { Event } from '../classes/event';
|
|
5
|
+
import { SpecStorage } from '../store/specStorage';
|
|
6
|
+
import { mergeMaps } from '../util/resourceHelper';
|
|
7
|
+
import { Parameter } from '../classes/parameter';
|
|
8
|
+
import { changeEnvironment } from '../util/babylonHelper';
|
|
9
|
+
var SceneManager = /** @class */ (function (_super) {
|
|
10
|
+
__extends(SceneManager, _super);
|
|
11
|
+
/**
|
|
12
|
+
* Constructor.
|
|
13
|
+
*/
|
|
14
|
+
function SceneManager(scene) {
|
|
15
|
+
var _this = _super.call(this) || this;
|
|
16
|
+
_this.scene = scene;
|
|
17
|
+
_this._parameterObservers = new Map();
|
|
18
|
+
_this.addParameterObservers();
|
|
19
|
+
return _this;
|
|
20
|
+
}
|
|
21
|
+
/**
|
|
22
|
+
* Creates a {@link SceneManager} based on given BabylonJS scene.
|
|
23
|
+
*/
|
|
24
|
+
SceneManager.create = function (scene) {
|
|
25
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
26
|
+
var sceneManager;
|
|
27
|
+
return __generator(this, function (_a) {
|
|
28
|
+
switch (_a.label) {
|
|
29
|
+
case 0:
|
|
30
|
+
sceneManager = new SceneManager(scene);
|
|
31
|
+
return [4 /*yield*/, sceneManager.bootstrapParameters(SpecStorage.get('scene.parameters'))];
|
|
32
|
+
case 1:
|
|
33
|
+
_a.sent();
|
|
34
|
+
return [2 /*return*/, sceneManager];
|
|
35
|
+
}
|
|
36
|
+
});
|
|
37
|
+
});
|
|
38
|
+
};
|
|
39
|
+
Object.defineProperty(SceneManager.prototype, "activeCamera", {
|
|
40
|
+
/**
|
|
41
|
+
* The active `Camera`.
|
|
42
|
+
*/
|
|
43
|
+
get: function () {
|
|
44
|
+
if (!this.scene.activeCamera) {
|
|
45
|
+
throw new Error('Scene has no active camera.');
|
|
46
|
+
}
|
|
47
|
+
return this.scene.activeCamera;
|
|
48
|
+
},
|
|
49
|
+
enumerable: false,
|
|
50
|
+
configurable: true
|
|
51
|
+
});
|
|
52
|
+
/**
|
|
53
|
+
* Places the given {@link ParameterBag} in the {@link SceneManager}'s parameters, replaces all patterns in the
|
|
54
|
+
* {@link StructureJson} and broadcasts all {@link ParameterObserver}s.
|
|
55
|
+
*
|
|
56
|
+
* @emit {@link Event.SCENE_PARAMETER_COMMITTED}
|
|
57
|
+
*/
|
|
58
|
+
SceneManager.prototype.commitParameters = function (parameters) {
|
|
59
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
60
|
+
var oldParameters, observerPromises, _loop_1, this_1, parameter;
|
|
61
|
+
var _this = this;
|
|
62
|
+
return __generator(this, function (_a) {
|
|
63
|
+
switch (_a.label) {
|
|
64
|
+
case 0:
|
|
65
|
+
if (!parameters) {
|
|
66
|
+
parameters = {};
|
|
67
|
+
}
|
|
68
|
+
oldParameters = cloneDeep(this.parameters);
|
|
69
|
+
merge(this.parameters, parameters);
|
|
70
|
+
observerPromises = [];
|
|
71
|
+
_loop_1 = function (parameter) {
|
|
72
|
+
var oldParameterValue = oldParameters[parameter];
|
|
73
|
+
var newParameterValue = this_1.parameters[parameter];
|
|
74
|
+
this_1.assertParameter(Parameter.declarations, parameter, newParameterValue);
|
|
75
|
+
if (oldParameterValue === newParameterValue) {
|
|
76
|
+
return "continue";
|
|
77
|
+
}
|
|
78
|
+
// parameter changed
|
|
79
|
+
var parameterObservers = mergeMaps(this_1._parameterObservers, this_1.parameterObservers);
|
|
80
|
+
if (parameterObservers.has(parameter)) {
|
|
81
|
+
var observers = parameterObservers.get(parameter);
|
|
82
|
+
observerPromises = concat(observerPromises, observers.map(function (observer) {
|
|
83
|
+
var observerResult = observer(_this, oldParameterValue, newParameterValue);
|
|
84
|
+
var observerPromise = Promise.resolve(observerResult);
|
|
85
|
+
observerPromise.then(function () {
|
|
86
|
+
_this.broadcastEvent(Event.SCENE_PARAMETER_COMMITTED, _this, parameter, oldParameterValue, newParameterValue);
|
|
87
|
+
});
|
|
88
|
+
return observerPromise;
|
|
89
|
+
}));
|
|
90
|
+
}
|
|
91
|
+
};
|
|
92
|
+
this_1 = this;
|
|
93
|
+
for (parameter in this.parameters) {
|
|
94
|
+
_loop_1(parameter);
|
|
95
|
+
}
|
|
96
|
+
return [4 /*yield*/, Promise.all(observerPromises)];
|
|
97
|
+
case 1:
|
|
98
|
+
_a.sent();
|
|
99
|
+
return [2 /*return*/, this];
|
|
100
|
+
}
|
|
101
|
+
});
|
|
102
|
+
});
|
|
103
|
+
};
|
|
104
|
+
SceneManager.prototype.addParameterObservers = function () {
|
|
105
|
+
var handleEnvParamChange = function (manager, oldValue, newValue) {
|
|
106
|
+
var params = {
|
|
107
|
+
color: manager.parameters[Parameter.ENVIRONMENT_COLOR],
|
|
108
|
+
intensity: manager.parameters[Parameter.ENVIRONMENT_INTENSITY],
|
|
109
|
+
env: manager.parameters[Parameter.ENVIRONMENT],
|
|
110
|
+
background: manager.parameters[Parameter.ENVIRONMENT_BACKGROUND],
|
|
111
|
+
rotation: manager.parameters[Parameter.ENVIRONMENT_ROTATION],
|
|
112
|
+
useDefault: manager.parameters[Parameter.ENVIRONMENT_USEDEFAULT],
|
|
113
|
+
};
|
|
114
|
+
var envDef = {
|
|
115
|
+
environmentColor: params.color ? Parameter.parseColor(params.color) : undefined,
|
|
116
|
+
environmentIntensity: params.intensity !== undefined ? Parameter.parseNumber(params.intensity) : undefined,
|
|
117
|
+
environment: params.env ? params.env : undefined,
|
|
118
|
+
environmentBackground: params.background ? params.background : undefined,
|
|
119
|
+
environmentRotation: params.rotation !== undefined ? Parameter.parseNumber(params.rotation) : undefined,
|
|
120
|
+
environmentUseDefault: params.useDefault ? Parameter.parseBoolean(params.useDefault) : undefined,
|
|
121
|
+
};
|
|
122
|
+
changeEnvironment(manager.scene, envDef);
|
|
123
|
+
};
|
|
124
|
+
this._parameterObservers.set(Parameter.ENVIRONMENT_COLOR, [handleEnvParamChange]);
|
|
125
|
+
this._parameterObservers.set(Parameter.ENVIRONMENT_ROTATION, [handleEnvParamChange]);
|
|
126
|
+
this._parameterObservers.set(Parameter.ENVIRONMENT_USEDEFAULT, [handleEnvParamChange]);
|
|
127
|
+
this._parameterObservers.set(Parameter.ENVIRONMENT, [handleEnvParamChange]);
|
|
128
|
+
this._parameterObservers.set(Parameter.ENVIRONMENT_BACKGROUND, [handleEnvParamChange]);
|
|
129
|
+
this._parameterObservers.set(Parameter.ENVIRONMENT_INTENSITY, [handleEnvParamChange]);
|
|
130
|
+
return this;
|
|
131
|
+
};
|
|
132
|
+
/**
|
|
133
|
+
* Bootstrapping for parameters. It sets the `parametersInitialized` to true for all ancestors.
|
|
134
|
+
*/
|
|
135
|
+
SceneManager.prototype.bootstrapParameters = function (parameters) {
|
|
136
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
137
|
+
return __generator(this, function (_a) {
|
|
138
|
+
switch (_a.label) {
|
|
139
|
+
case 0: return [4 /*yield*/, this.commitParameters(merge(cloneDeep(this.parameters), parameters))];
|
|
140
|
+
case 1:
|
|
141
|
+
_a.sent();
|
|
142
|
+
return [2 /*return*/, this];
|
|
143
|
+
}
|
|
144
|
+
});
|
|
145
|
+
});
|
|
146
|
+
};
|
|
147
|
+
return SceneManager;
|
|
148
|
+
}(ParameterObservable));
|
|
149
|
+
export { SceneManager };
|
|
150
|
+
//# sourceMappingURL=sceneManager.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sceneManager.js","sourceRoot":"","sources":["../../../../src/api/manager/sceneManager.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,92 @@
|
|
|
1
|
+
import { EventBroadcaster } from '../classes/eventBroadcaster';
|
|
2
|
+
import { Variant } from '../classes/variant';
|
|
3
|
+
import { VariantInstance } from '../classes/variantInstance';
|
|
4
|
+
/**
|
|
5
|
+
* There's usually no need to instantiate a {@link VariantInstanceManager} yourself as it is provided by each
|
|
6
|
+
* {@link Viewer} instance via its {@link Viewer.variantInstances}
|
|
7
|
+
*/
|
|
8
|
+
export declare class VariantInstanceManager extends EventBroadcaster {
|
|
9
|
+
protected rootVariant: Variant;
|
|
10
|
+
protected variantInstancePromises: Map<string, Promise<VariantInstance>>;
|
|
11
|
+
protected variantInstances: Map<string, VariantInstance>;
|
|
12
|
+
protected variantInstanceDefinitions: Map<string, VariantInstanceDefinition>;
|
|
13
|
+
protected parameters: ParameterBag;
|
|
14
|
+
protected queues: {
|
|
15
|
+
[name: string]: Promise<VariantInstance>[];
|
|
16
|
+
};
|
|
17
|
+
/**
|
|
18
|
+
* Constructor.
|
|
19
|
+
*/
|
|
20
|
+
protected constructor(rootVariant: Variant);
|
|
21
|
+
/**
|
|
22
|
+
* Creates a {@link VariantInstanceManager} based on given root Variant.
|
|
23
|
+
*/
|
|
24
|
+
static create(rootVariant: Variant): Promise<VariantInstanceManager>;
|
|
25
|
+
/**
|
|
26
|
+
* Gets all instances.
|
|
27
|
+
*/
|
|
28
|
+
get all(): VariantInstance[];
|
|
29
|
+
/**
|
|
30
|
+
* Gets all instance definitions.
|
|
31
|
+
*/
|
|
32
|
+
get allDefinitions(): VariantInstanceDefinition[];
|
|
33
|
+
/**
|
|
34
|
+
* Checks whether a {@link VariantInstance} is either registered or created.
|
|
35
|
+
*/
|
|
36
|
+
has(name: string): boolean;
|
|
37
|
+
/**
|
|
38
|
+
* Retrieves a {@link VariantInstance}.
|
|
39
|
+
* If the instance has been created, the created instance will be returned.
|
|
40
|
+
* If the instance is registered, the instance will be created and returned.
|
|
41
|
+
* if the instance has already been requested and is currently pending, the dedicated promise will be returned.
|
|
42
|
+
* If none of these apply, an Error is thrown.
|
|
43
|
+
*
|
|
44
|
+
* @emits {@link Event.VARIANT_INSTANCE_CREATED}
|
|
45
|
+
*/
|
|
46
|
+
get(name: string): Promise<VariantInstance>;
|
|
47
|
+
/**
|
|
48
|
+
* Creates and registers a unique {@link VariantInstance}.
|
|
49
|
+
*
|
|
50
|
+
* @emits {@link Event.VARIANT_INSTANCE_CREATED}
|
|
51
|
+
*/
|
|
52
|
+
create(dottedPath: DottedPathArgument, name?: string, parameters?: ParameterBag): Promise<VariantInstance>;
|
|
53
|
+
/**
|
|
54
|
+
* Registers a unique {@link VariantInstanceDefinition}.
|
|
55
|
+
*
|
|
56
|
+
* @emits {@link Event.VARIANT_INSTANCE_REGISTERED}
|
|
57
|
+
*/
|
|
58
|
+
register(instanceDefinition: VariantInstanceDefinition): VariantInstanceDefinition;
|
|
59
|
+
/**
|
|
60
|
+
* Commits the {@link ParameterBag} to all registered and created {@link VariantInstance}s.
|
|
61
|
+
*/
|
|
62
|
+
commitParameters(parameters?: ParameterBag, onlyVisible?: boolean): Promise<VariantInstanceManager>;
|
|
63
|
+
/**
|
|
64
|
+
* Show one {@link VariantInstance}. If `exclusive` is set to `true` it will hide all other
|
|
65
|
+
* instances handled by this {@link VariantInstanceManager}. If the function is called synchronously,
|
|
66
|
+
* the calls end up in a queue according to the FIFO principle (the last one wins).
|
|
67
|
+
*/
|
|
68
|
+
show(name: string, exclusive?: boolean): Promise<VariantInstance>;
|
|
69
|
+
/**
|
|
70
|
+
* Clones and registers a new {@link VariantInstance} with a new, unique name.
|
|
71
|
+
*
|
|
72
|
+
* @emits {@link Event.VARIANT_INSTANCE_CLONED}
|
|
73
|
+
*/
|
|
74
|
+
clone(name: string, newName: string, parameters?: ParameterBag): Promise<VariantInstance>;
|
|
75
|
+
/**
|
|
76
|
+
* Destroys the instance by removing the {@link Variant} and de-registering the instance.
|
|
77
|
+
*
|
|
78
|
+
* @emits {@link Event.VARIANT_INSTANCE_DESTROYED}
|
|
79
|
+
*/
|
|
80
|
+
destroy(name: string): VariantInstanceManager;
|
|
81
|
+
/**
|
|
82
|
+
* Creates and registers a unique {@link VariantInstance} from `definition`.
|
|
83
|
+
*
|
|
84
|
+
* @emits {@link Event.VARIANT_INSTANCE_CREATED}
|
|
85
|
+
*/
|
|
86
|
+
protected createFromDefinition(definition: VariantInstanceDefinition): Promise<VariantInstance>;
|
|
87
|
+
/**
|
|
88
|
+
* Creates a unique instance name based on already registered instance names on the {@link VariantInstanceManager}.
|
|
89
|
+
* Appends an `_i` to the name where `i = 0` and increments as long as the name is not registered.
|
|
90
|
+
*/
|
|
91
|
+
protected ensureUniqueName(name: string): string;
|
|
92
|
+
}
|