@babylonjs/core 7.50.0 → 7.51.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 (60) hide show
  1. package/Behaviors/Meshes/pointerDragBehavior.js +4 -1
  2. package/Behaviors/Meshes/pointerDragBehavior.js.map +1 -1
  3. package/Engines/AbstractEngine/abstractEngine.cubeTexture.js +2 -3
  4. package/Engines/AbstractEngine/abstractEngine.cubeTexture.js.map +1 -1
  5. package/Engines/abstractEngine.js +2 -2
  6. package/Engines/abstractEngine.js.map +1 -1
  7. package/Engines/thinEngine.functions.js +5 -3
  8. package/Engines/thinEngine.functions.js.map +1 -1
  9. package/Loading/loadingScreen.js +4 -1
  10. package/Loading/loadingScreen.js.map +1 -1
  11. package/Meshes/Node/Blocks/Sources/boxBlock.js +4 -4
  12. package/Meshes/Node/Blocks/Sources/boxBlock.js.map +1 -1
  13. package/Meshes/Node/Blocks/Sources/gridBlock.js +3 -3
  14. package/Meshes/Node/Blocks/Sources/gridBlock.js.map +1 -1
  15. package/Meshes/Node/Blocks/Sources/planeBlock.js +3 -3
  16. package/Meshes/Node/Blocks/Sources/planeBlock.js.map +1 -1
  17. package/Meshes/Node/Blocks/subdivideBlock.d.ts +45 -0
  18. package/Meshes/Node/Blocks/subdivideBlock.js +98 -0
  19. package/Meshes/Node/Blocks/subdivideBlock.js.map +1 -0
  20. package/Meshes/Node/index.d.ts +1 -0
  21. package/Meshes/Node/index.js +1 -0
  22. package/Meshes/Node/index.js.map +1 -1
  23. package/Meshes/csg2.js +4 -0
  24. package/Meshes/csg2.js.map +1 -1
  25. package/Meshes/geometry.js +1 -0
  26. package/Meshes/geometry.js.map +1 -1
  27. package/Meshes/index.d.ts +1 -0
  28. package/Meshes/index.js +1 -0
  29. package/Meshes/index.js.map +1 -1
  30. package/Meshes/mesh.vertexData.js +1 -1
  31. package/Meshes/mesh.vertexData.js.map +1 -1
  32. package/Meshes/mesh.vertexData.subdivide.d.ts +28 -0
  33. package/Meshes/mesh.vertexData.subdivide.js +400 -0
  34. package/Meshes/mesh.vertexData.subdivide.js.map +1 -0
  35. package/Misc/index.d.ts +1 -0
  36. package/Misc/index.js +1 -0
  37. package/Misc/index.js.map +1 -1
  38. package/Misc/urlTools.d.ts +6 -0
  39. package/Misc/urlTools.js +12 -0
  40. package/Misc/urlTools.js.map +1 -0
  41. package/Rendering/IBLShadows/iblShadowsVoxelRenderer.js +5 -3
  42. package/Rendering/IBLShadows/iblShadowsVoxelRenderer.js.map +1 -1
  43. package/Shaders/ShadersInclude/lightFragment.js +1 -1
  44. package/Shaders/ShadersInclude/lightFragment.js.map +1 -1
  45. package/Shaders/ShadersInclude/pbrBlockFinalUnlitComponents.js +5 -1
  46. package/Shaders/ShadersInclude/pbrBlockFinalUnlitComponents.js.map +1 -1
  47. package/Shaders/ShadersInclude/pbrDirectLightingFunctions.js +2 -1
  48. package/Shaders/ShadersInclude/pbrDirectLightingFunctions.js.map +1 -1
  49. package/ShadersWGSL/ShadersInclude/lightFragment.js +1 -1
  50. package/ShadersWGSL/ShadersInclude/lightFragment.js.map +1 -1
  51. package/ShadersWGSL/ShadersInclude/pbrBlockFinalUnlitComponents.js +5 -1
  52. package/ShadersWGSL/ShadersInclude/pbrBlockFinalUnlitComponents.js.map +1 -1
  53. package/ShadersWGSL/ShadersInclude/pbrDirectLightingFunctions.js +2 -1
  54. package/ShadersWGSL/ShadersInclude/pbrDirectLightingFunctions.js.map +1 -1
  55. package/ShadersWGSL/pbr.fragment.js +1 -1
  56. package/ShadersWGSL/pbr.fragment.js.map +1 -1
  57. package/XR/features/WebXRAnchorSystem.d.ts +4 -0
  58. package/XR/features/WebXRAnchorSystem.js +8 -5
  59. package/XR/features/WebXRAnchorSystem.js.map +1 -1
  60. package/package.json +1 -1
@@ -0,0 +1,28 @@
1
+ import { VertexData } from "./mesh.vertexData";
2
+ /**
3
+ * Inspired by https://github.com/stevinz/three-subdivide
4
+ * Thanks a lot to https://github.com/stevinz
5
+ */
6
+ /**
7
+ * Interface used to configure the subdivision process
8
+ */
9
+ export interface ISubdivideOptions {
10
+ /** Apply only flat subdivision - false by default */
11
+ flatOnly?: boolean;
12
+ /** Split all triangles at edges shared by coplanar triangles - true by default*/
13
+ split?: boolean;
14
+ /** Should UV values be averaged during subdivision - false by default */
15
+ uvSmooth?: boolean;
16
+ /** Should edges / breaks in geometry be ignored during subdivision? - false by default */
17
+ preserveEdges?: boolean;
18
+ /** How much to weigh favoring heavy corners vs favoring Loop's formula - 1 by default*/
19
+ weight?: number;
20
+ }
21
+ /**
22
+ * Subdivide a vertexData using Loop algorithm
23
+ * @param vertexData The vertexData to subdivide
24
+ * @param level The number of times to subdivide
25
+ * @param options The options to use when subdividing
26
+ * @returns The subdivided vertexData
27
+ */
28
+ export declare function Subdivide(vertexData: VertexData, level: number, options?: Partial<ISubdivideOptions>): VertexData;
@@ -0,0 +1,400 @@
1
+ import { Vector3 } from "../Maths/math.vector.js";
2
+ import { VertexData } from "./mesh.vertexData.js";
3
+ import { Scalar } from "../Maths/math.scalar.js";
4
+ const _positionShift = Math.pow(10, 4);
5
+ /**
6
+ * Rounds a number (simulate integer rounding)
7
+ * @internal
8
+ */
9
+ function round(x) {
10
+ return (x + (x > 0 ? 0.5 : -0.5)) << 0;
11
+ }
12
+ /**
13
+ * Generates a hash string from a number
14
+ * @internal
15
+ */
16
+ function hashFromNumber(num, shift = _positionShift) {
17
+ let roundedNumber = round(num * shift);
18
+ if (roundedNumber === 0) {
19
+ roundedNumber = 0; // prevent -0
20
+ }
21
+ return `${roundedNumber}`;
22
+ }
23
+ /**
24
+ * Generates a hash string from a Vector3
25
+ * @internal
26
+ */
27
+ function hashFromVector(v, shift = _positionShift) {
28
+ return `${hashFromNumber(v.x, shift)},${hashFromNumber(v.y, shift)},${hashFromNumber(v.z, shift)}`;
29
+ }
30
+ /**
31
+ * Gathers attribute names from a VertexData object
32
+ * @internal
33
+ */
34
+ function gatherAttributes(vertexData) {
35
+ const desired = ["positions", "normals", "uvs"];
36
+ const available = Object.keys(vertexData).filter((k) => Array.isArray(vertexData[k]));
37
+ return Array.from(new Set([...desired, ...available]));
38
+ }
39
+ /**
40
+ * Sets triangle data into an attribute array
41
+ * @internal
42
+ */
43
+ function setTriangle(arr, index, itemSize, vec0, vec1, vec2) {
44
+ for (let i = 0; i < itemSize; i++) {
45
+ arr[index + i] = vec0[i];
46
+ arr[index + itemSize + i] = vec1[i];
47
+ arr[index + 2 * itemSize + i] = vec2[i];
48
+ }
49
+ }
50
+ /**
51
+ * Converts indexed VertexData to a non-indexed form
52
+ * @internal
53
+ */
54
+ function toNonIndexed(vertexData) {
55
+ if (!vertexData.indices || vertexData.indices.length === 0) {
56
+ return vertexData; // already non-indexed
57
+ }
58
+ const newPositions = [];
59
+ const newNormals = [];
60
+ const newUVs = [];
61
+ const indices = vertexData.indices;
62
+ const pos = vertexData.positions;
63
+ const norm = vertexData.normals;
64
+ const uv = vertexData.uvs;
65
+ for (let i = 0; i < indices.length; i++) {
66
+ const idx = indices[i];
67
+ newPositions.push(pos[3 * idx], pos[3 * idx + 1], pos[3 * idx + 2]);
68
+ if (norm) {
69
+ newNormals.push(norm[3 * idx], norm[3 * idx + 1], norm[3 * idx + 2]);
70
+ }
71
+ if (uv) {
72
+ newUVs.push(uv[2 * idx], uv[2 * idx + 1]);
73
+ }
74
+ }
75
+ const newVertexData = new VertexData();
76
+ newVertexData.positions = newPositions;
77
+ if (newNormals.length) {
78
+ newVertexData.normals = newNormals;
79
+ }
80
+ if (newUVs.length) {
81
+ newVertexData.uvs = newUVs;
82
+ }
83
+ return newVertexData;
84
+ }
85
+ /** Helper to read a Vector3 from an attribute array
86
+ * @internal
87
+ */
88
+ function readVector(destination, attribute, index, itemSize) {
89
+ if (itemSize === 3) {
90
+ destination.fromArray(attribute, index * 3);
91
+ return;
92
+ }
93
+ // For uvs (itemSize 2), return a Vector3 with z = 0.
94
+ destination.set(attribute[index * 2], attribute[index * 2 + 1], 0);
95
+ }
96
+ function processFlatAttribute(source, vertexCount, output) {
97
+ const v0 = new Vector3();
98
+ const v1 = new Vector3();
99
+ const v2 = new Vector3();
100
+ const m01 = new Vector3();
101
+ const m12 = new Vector3();
102
+ const m20 = new Vector3();
103
+ for (let i = 0; i < vertexCount; i += 3) {
104
+ const j = i * 3;
105
+ v0.set(source[j], source[j + 1], source[j + 2]);
106
+ v1.set(source[j + 3], source[j + 4], source[j + 5]);
107
+ v2.set(source[j + 6], source[j + 7], source[j + 8]);
108
+ v0.addToRef(v1, m01);
109
+ m01.scaleInPlace(0.5);
110
+ v1.addToRef(v2, m12);
111
+ m12.scaleInPlace(0.5);
112
+ v2.addToRef(v0, m20);
113
+ m20.scaleInPlace(0.5);
114
+ // Positions
115
+ output.push(v0.x, v0.y, v0.z, m01.x, m01.y, m01.z, m20.x, m20.y, m20.z);
116
+ output.push(v1.x, v1.y, v1.z, m12.x, m12.y, m12.z, m01.x, m01.y, m01.z);
117
+ output.push(v2.x, v2.y, v2.z, m20.x, m20.y, m20.z, m12.x, m12.y, m12.z);
118
+ output.push(m01.x, m01.y, m01.z, m12.x, m12.y, m12.z, m20.x, m20.y, m20.z);
119
+ }
120
+ }
121
+ /**
122
+ * Applies one iteration of flat subdivision (each triangle becomes 4).
123
+ * @internal
124
+ */
125
+ function flat(vertexData) {
126
+ const data = toNonIndexed(vertexData);
127
+ const positions = data.positions;
128
+ const normals = data.normals;
129
+ const uvs = data.uvs;
130
+ const vertexCount = positions.length / 3;
131
+ const newPositions = [];
132
+ const newNormals = [];
133
+ const newUVs = [];
134
+ processFlatAttribute(positions, vertexCount, newPositions);
135
+ if (normals && normals.length) {
136
+ processFlatAttribute(normals, vertexCount, newNormals);
137
+ }
138
+ if (uvs && uvs.length) {
139
+ for (let i = 0; i < vertexCount; i += 3) {
140
+ const j = i * 2;
141
+ const uv0 = [uvs[j], uvs[j + 1]];
142
+ const uv1 = [uvs[j + 2], uvs[j + 3]];
143
+ const uv2 = [uvs[j + 4], uvs[j + 5]];
144
+ const uv01 = [(uv0[0] + uv1[0]) / 2, (uv0[1] + uv1[1]) / 2];
145
+ const uv12 = [(uv1[0] + uv2[0]) / 2, (uv1[1] + uv2[1]) / 2];
146
+ const uv20 = [(uv2[0] + uv0[0]) / 2, (uv2[1] + uv0[1]) / 2];
147
+ newUVs.push(...uv0, ...uv01, ...uv20);
148
+ newUVs.push(...uv1, ...uv12, ...uv01);
149
+ newUVs.push(...uv2, ...uv20, ...uv12);
150
+ newUVs.push(...uv01, ...uv12, ...uv20);
151
+ }
152
+ }
153
+ const newVertexCount = newPositions.length / 3;
154
+ const newIndices = [];
155
+ for (let i = 0; i < newVertexCount; i++) {
156
+ newIndices.push(i);
157
+ }
158
+ const newVertexData = new VertexData();
159
+ newVertexData.positions = newPositions;
160
+ if (newNormals.length) {
161
+ newVertexData.normals = newNormals;
162
+ }
163
+ if (newUVs.length) {
164
+ newVertexData.uvs = newUVs;
165
+ }
166
+ newVertexData.indices = newIndices;
167
+ return newVertexData;
168
+ }
169
+ /**
170
+ * Applies one iteration of smooth subdivision with vertex averaging.
171
+ * This function uses the subdivideAttribute routine to adjust vertex data.
172
+ * @internal
173
+ */
174
+ function smooth(vertexData, options) {
175
+ // Convert to non-indexed and apply flat subdivision first.
176
+ const sourceData = toNonIndexed(vertexData);
177
+ const flatData = flat(sourceData);
178
+ const attributeList = gatherAttributes(sourceData);
179
+ const origPositions = sourceData.positions;
180
+ const flatPositions = flatData.positions;
181
+ const vertexCount = origPositions.length / 3;
182
+ // Build connectivity maps from the original geometry.
183
+ const hashToIndex = {};
184
+ const existingNeighbors = {};
185
+ const flatOpposites = {};
186
+ const existingEdges = {};
187
+ function addNeighbor(posHash, neighborHash, index) {
188
+ if (!existingNeighbors[posHash]) {
189
+ existingNeighbors[posHash] = {};
190
+ }
191
+ if (!existingNeighbors[posHash][neighborHash]) {
192
+ existingNeighbors[posHash][neighborHash] = [];
193
+ }
194
+ existingNeighbors[posHash][neighborHash].push(index);
195
+ }
196
+ function addOpposite(posHash, index) {
197
+ if (!flatOpposites[posHash]) {
198
+ flatOpposites[posHash] = [];
199
+ }
200
+ flatOpposites[posHash].push(index);
201
+ }
202
+ function addEdgePoint(posHash, edgeHash) {
203
+ if (!existingEdges[posHash]) {
204
+ existingEdges[posHash] = new Set();
205
+ }
206
+ existingEdges[posHash].add(edgeHash);
207
+ }
208
+ const temp = new Vector3();
209
+ const v0 = new Vector3();
210
+ const v1 = new Vector3();
211
+ const v2 = new Vector3();
212
+ const m01 = new Vector3();
213
+ const m12 = new Vector3();
214
+ const m20 = new Vector3();
215
+ // Process original positions
216
+ for (let i = 0; i < vertexCount; i += 3) {
217
+ readVector(v0, origPositions, i, 3);
218
+ readVector(v1, origPositions, i + 1, 3);
219
+ readVector(v2, origPositions, i + 2, 3);
220
+ const h0 = hashFromVector(v0);
221
+ const h1 = hashFromVector(v1);
222
+ const h2 = hashFromVector(v2);
223
+ addNeighbor(h0, h1, i + 1);
224
+ addNeighbor(h0, h2, i + 2);
225
+ addNeighbor(h1, h0, i);
226
+ addNeighbor(h1, h2, i + 2);
227
+ addNeighbor(h2, h0, i);
228
+ addNeighbor(h2, h1, i + 1);
229
+ // Opposites from flat subdivision: calculate midpoints.
230
+ v0.addToRef(v1, m01);
231
+ m01.scaleInPlace(0.5);
232
+ v1.addToRef(v2, m12);
233
+ m12.scaleInPlace(0.5);
234
+ v2.addToRef(v0, m20);
235
+ m20.scaleInPlace(0.5);
236
+ addOpposite(hashFromVector(m01), i + 2);
237
+ addOpposite(hashFromVector(m12), i);
238
+ addOpposite(hashFromVector(m20), i + 1);
239
+ // Track edges for preserveEdges.
240
+ addEdgePoint(h0, hashFromVector(m01));
241
+ addEdgePoint(h0, hashFromVector(m20));
242
+ addEdgePoint(h1, hashFromVector(m01));
243
+ addEdgePoint(h1, hashFromVector(m12));
244
+ addEdgePoint(h2, hashFromVector(m12));
245
+ addEdgePoint(h2, hashFromVector(m20));
246
+ }
247
+ // Build map from flat positions to indices.
248
+ for (let i = 0; i < flatPositions.length / 3; i++) {
249
+ readVector(temp, flatPositions, i, 3);
250
+ const h = hashFromVector(temp);
251
+ if (!hashToIndex[h]) {
252
+ hashToIndex[h] = [];
253
+ }
254
+ hashToIndex[h].push(i);
255
+ }
256
+ // Prepare temporary vectors for subdivideAttribute.
257
+ const _vertex = [new Vector3(), new Vector3(), new Vector3()];
258
+ const _position = [new Vector3(), new Vector3(), new Vector3()];
259
+ const _average = new Vector3();
260
+ const _temp = new Vector3();
261
+ // subdivideAttribute: adjusts vertex attributes using Loop’s averaging rules.
262
+ function subdivideAttribute(attributeName, existingAttribute, flattenedAttribute) {
263
+ const itemSize = attributeName === "uvs" ? 2 : 3;
264
+ const flatVertexCount = flatPositions.length / 3;
265
+ const floatArray = new Array(flatVertexCount * itemSize);
266
+ let index = 0;
267
+ for (let i = 0; i < flatVertexCount; i += 3) {
268
+ for (let v = 0; v < 3; v++) {
269
+ if (attributeName === "uvs" && !options.uvSmooth) {
270
+ // Simply copy UVs.
271
+ readVector(_vertex[v], flattenedAttribute, i + v, 2);
272
+ }
273
+ else if (attributeName === "normals") {
274
+ readVector(_position[v], flatPositions, i + v, 3);
275
+ const positionHash = hashFromVector(_position[v]);
276
+ const positionsArr = hashToIndex[positionHash] || [];
277
+ const k = positionsArr.length;
278
+ const beta = 0.75 / k;
279
+ const startWeight = 1.0 - beta * k;
280
+ readVector(_vertex[v], flattenedAttribute, i + v, 3);
281
+ _vertex[v].scaleInPlace(startWeight);
282
+ positionsArr.forEach((positionIndex) => {
283
+ readVector(_average, flattenedAttribute, positionIndex, 3);
284
+ _average.scaleInPlace(beta);
285
+ _vertex[v].addInPlace(_average);
286
+ });
287
+ }
288
+ else {
289
+ // 'positions', 'colors', etc.
290
+ readVector(_vertex[v], flattenedAttribute, i + v, itemSize);
291
+ readVector(_position[v], flatPositions, i + v, 3);
292
+ const positionHash = hashFromVector(_position[v]);
293
+ const neighbors = existingNeighbors[positionHash];
294
+ const opposites = flatOpposites[positionHash];
295
+ if (neighbors) {
296
+ if (options.preserveEdges) {
297
+ const edgeSet = existingEdges[positionHash];
298
+ let hasPair = true;
299
+ edgeSet.forEach((edgeHash) => {
300
+ if (flatOpposites[edgeHash] && flatOpposites[edgeHash].length % 2 !== 0) {
301
+ hasPair = false;
302
+ }
303
+ });
304
+ if (!hasPair) {
305
+ // If edges aren't paired, skip adjustment.
306
+ continue;
307
+ }
308
+ }
309
+ const neighborKeys = Object.keys(neighbors);
310
+ const k = neighborKeys.length;
311
+ const beta = (1 / k) * (5 / 8 - Math.pow(3 / 8 + (1 / 4) * Math.cos((2 * Math.PI) / k), 2));
312
+ const heavy = 1 / k / k;
313
+ const weight = Scalar.Lerp(heavy, beta, options.weight);
314
+ const startWeight = 1.0 - weight * k;
315
+ _vertex[v].scaleInPlace(startWeight);
316
+ for (const neighborHash in neighbors) {
317
+ const neighborIndices = neighbors[neighborHash];
318
+ _average.set(0, 0, 0);
319
+ neighborIndices.forEach((neighborIndex) => {
320
+ readVector(_temp, existingAttribute, neighborIndex, itemSize);
321
+ _average.addInPlace(_temp);
322
+ });
323
+ _average.scaleInPlace(1 / neighborIndices.length);
324
+ _average.scaleInPlace(weight);
325
+ _vertex[v].addInPlace(_average);
326
+ }
327
+ }
328
+ else if (opposites && opposites.length === 2) {
329
+ const k = opposites.length;
330
+ const beta = 0.125; // 1/8
331
+ const startWeight = 1.0 - beta * k;
332
+ _vertex[v].scaleInPlace(startWeight);
333
+ opposites.forEach((oppositeIndex) => {
334
+ readVector(_average, existingAttribute, oppositeIndex, itemSize);
335
+ _average.scaleInPlace(beta);
336
+ _vertex[v].addInPlace(_average);
337
+ });
338
+ }
339
+ }
340
+ }
341
+ // Write out new triangle vertices.
342
+ setTriangle(floatArray, index, itemSize, _vertex[0].asArray(), _vertex[1].asArray(), _vertex[2].asArray());
343
+ index += itemSize * 3;
344
+ }
345
+ return floatArray;
346
+ }
347
+ // Build new attributes for the smoothed geometry.
348
+ const smoothData = new VertexData();
349
+ attributeList.forEach((attributeName) => {
350
+ if (attributeName === "indices") {
351
+ return;
352
+ }
353
+ const existingAttribute = sourceData[attributeName];
354
+ const flattenedAttribute = flatData[attributeName];
355
+ if (!existingAttribute || !flattenedAttribute) {
356
+ return;
357
+ }
358
+ const newArray = subdivideAttribute(attributeName, existingAttribute, flattenedAttribute);
359
+ smoothData[attributeName] = newArray;
360
+ });
361
+ // Rebuild indices sequentially.
362
+ const newPositions = smoothData.positions;
363
+ const newIndices = [];
364
+ for (let i = 0; i < newPositions.length / 3; i++) {
365
+ newIndices.push(i);
366
+ }
367
+ smoothData.indices = newIndices;
368
+ return smoothData;
369
+ }
370
+ /**
371
+ * Subdivide a vertexData using Loop algorithm
372
+ * @param vertexData The vertexData to subdivide
373
+ * @param level The number of times to subdivide
374
+ * @param options The options to use when subdividing
375
+ * @returns The subdivided vertexData
376
+ */
377
+ export function Subdivide(vertexData, level, options) {
378
+ options = {
379
+ flatOnly: false,
380
+ uvSmooth: false,
381
+ preserveEdges: false,
382
+ weight: 1,
383
+ ...options,
384
+ };
385
+ if (!vertexData.positions || vertexData.positions.length === 0 || level <= 0) {
386
+ return vertexData;
387
+ }
388
+ // Clone the input
389
+ let modified = vertexData.clone();
390
+ for (let i = 0; i < level; i++) {
391
+ if (options.flatOnly) {
392
+ modified = flat(modified);
393
+ }
394
+ else {
395
+ modified = smooth(modified, options);
396
+ }
397
+ }
398
+ return modified;
399
+ }
400
+ //# sourceMappingURL=mesh.vertexData.subdivide.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"mesh.vertexData.subdivide.js","sourceRoot":"","sources":["../../../../dev/core/src/Meshes/mesh.vertexData.subdivide.ts"],"names":[],"mappings":"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","sourcesContent":["import { Vector3 } from \"core/Maths/math.vector\";\r\nimport { VertexData } from \"./mesh.vertexData\";\r\nimport { Scalar } from \"core/Maths/math.scalar\";\r\nimport type { FloatArray } from \"core/types\";\r\n\r\n/**\r\n * Inspired by https://github.com/stevinz/three-subdivide\r\n * Thanks a lot to https://github.com/stevinz\r\n */\r\n\r\n/**\r\n * Interface used to configure the subdivision process\r\n */\r\nexport interface ISubdivideOptions {\r\n /** Apply only flat subdivision - false by default */\r\n flatOnly?: boolean;\r\n /** Split all triangles at edges shared by coplanar triangles - true by default*/\r\n split?: boolean;\r\n /** Should UV values be averaged during subdivision - false by default */\r\n uvSmooth?: boolean;\r\n /** Should edges / breaks in geometry be ignored during subdivision? - false by default */\r\n preserveEdges?: boolean;\r\n /** How much to weigh favoring heavy corners vs favoring Loop's formula - 1 by default*/\r\n weight?: number;\r\n}\r\n\r\nconst _positionShift = Math.pow(10, 4);\r\n\r\n/**\r\n * Rounds a number (simulate integer rounding)\r\n * @internal\r\n */\r\nfunction round(x: number): number {\r\n return (x + (x > 0 ? 0.5 : -0.5)) << 0;\r\n}\r\n\r\n/**\r\n * Generates a hash string from a number\r\n * @internal\r\n */\r\nfunction hashFromNumber(num: number, shift = _positionShift): string {\r\n let roundedNumber = round(num * shift);\r\n if (roundedNumber === 0) {\r\n roundedNumber = 0; // prevent -0\r\n }\r\n return `${roundedNumber}`;\r\n}\r\n\r\n/**\r\n * Generates a hash string from a Vector3\r\n * @internal\r\n */\r\nfunction hashFromVector(v: Vector3, shift = _positionShift): string {\r\n return `${hashFromNumber(v.x, shift)},${hashFromNumber(v.y, shift)},${hashFromNumber(v.z, shift)}`;\r\n}\r\n\r\n/**\r\n * Gathers attribute names from a VertexData object\r\n * @internal\r\n */\r\nfunction gatherAttributes(vertexData: VertexData): string[] {\r\n const desired = [\"positions\", \"normals\", \"uvs\"];\r\n const available = Object.keys(vertexData).filter((k) => Array.isArray((vertexData as any)[k]));\r\n return Array.from(new Set([...desired, ...available]));\r\n}\r\n\r\n/**\r\n * Sets triangle data into an attribute array\r\n * @internal\r\n */\r\nfunction setTriangle(arr: number[], index: number, itemSize: number, vec0: number[], vec1: number[], vec2: number[]): void {\r\n for (let i = 0; i < itemSize; i++) {\r\n arr[index + i] = vec0[i];\r\n arr[index + itemSize + i] = vec1[i];\r\n arr[index + 2 * itemSize + i] = vec2[i];\r\n }\r\n}\r\n\r\n/**\r\n * Converts indexed VertexData to a non-indexed form\r\n * @internal\r\n */\r\nfunction toNonIndexed(vertexData: VertexData): VertexData {\r\n if (!vertexData.indices || vertexData.indices.length === 0) {\r\n return vertexData; // already non-indexed\r\n }\r\n const newPositions: number[] = [];\r\n const newNormals: number[] = [];\r\n const newUVs: number[] = [];\r\n const indices = vertexData.indices;\r\n const pos = vertexData.positions!;\r\n const norm = vertexData.normals;\r\n const uv = vertexData.uvs;\r\n\r\n for (let i = 0; i < indices.length; i++) {\r\n const idx = indices[i];\r\n newPositions.push(pos[3 * idx], pos[3 * idx + 1], pos[3 * idx + 2]);\r\n if (norm) {\r\n newNormals.push(norm[3 * idx], norm[3 * idx + 1], norm[3 * idx + 2]);\r\n }\r\n if (uv) {\r\n newUVs.push(uv[2 * idx], uv[2 * idx + 1]);\r\n }\r\n }\r\n\r\n const newVertexData = new VertexData();\r\n newVertexData.positions = newPositions;\r\n if (newNormals.length) {\r\n newVertexData.normals = newNormals;\r\n }\r\n if (newUVs.length) {\r\n newVertexData.uvs = newUVs;\r\n }\r\n return newVertexData;\r\n}\r\n\r\n/** Helper to read a Vector3 from an attribute array\r\n * @internal\r\n */\r\nfunction readVector(destination: Vector3, attribute: FloatArray, index: number, itemSize: number) {\r\n if (itemSize === 3) {\r\n destination.fromArray(attribute, index * 3);\r\n return;\r\n }\r\n // For uvs (itemSize 2), return a Vector3 with z = 0.\r\n destination.set(attribute[index * 2], attribute[index * 2 + 1], 0);\r\n}\r\n\r\nfunction processFlatAttribute(source: FloatArray, vertexCount: number, output: number[]) {\r\n const v0 = new Vector3();\r\n const v1 = new Vector3();\r\n const v2 = new Vector3();\r\n const m01 = new Vector3();\r\n const m12 = new Vector3();\r\n const m20 = new Vector3();\r\n\r\n for (let i = 0; i < vertexCount; i += 3) {\r\n const j = i * 3;\r\n v0.set(source[j], source[j + 1], source[j + 2]);\r\n v1.set(source[j + 3], source[j + 4], source[j + 5]);\r\n v2.set(source[j + 6], source[j + 7], source[j + 8]);\r\n v0.addToRef(v1, m01);\r\n m01.scaleInPlace(0.5);\r\n v1.addToRef(v2, m12);\r\n m12.scaleInPlace(0.5);\r\n v2.addToRef(v0, m20);\r\n m20.scaleInPlace(0.5);\r\n\r\n // Positions\r\n output.push(v0.x, v0.y, v0.z, m01.x, m01.y, m01.z, m20.x, m20.y, m20.z);\r\n output.push(v1.x, v1.y, v1.z, m12.x, m12.y, m12.z, m01.x, m01.y, m01.z);\r\n output.push(v2.x, v2.y, v2.z, m20.x, m20.y, m20.z, m12.x, m12.y, m12.z);\r\n output.push(m01.x, m01.y, m01.z, m12.x, m12.y, m12.z, m20.x, m20.y, m20.z);\r\n }\r\n}\r\n\r\n/**\r\n * Applies one iteration of flat subdivision (each triangle becomes 4).\r\n * @internal\r\n */\r\nfunction flat(vertexData: VertexData): VertexData {\r\n const data = toNonIndexed(vertexData);\r\n const positions = data.positions!;\r\n const normals = data.normals;\r\n const uvs = data.uvs;\r\n const vertexCount = positions.length / 3;\r\n\r\n const newPositions: number[] = [];\r\n const newNormals: number[] = [];\r\n const newUVs: number[] = [];\r\n processFlatAttribute(positions, vertexCount, newPositions);\r\n\r\n if (normals && normals.length) {\r\n processFlatAttribute(normals, vertexCount, newNormals);\r\n }\r\n\r\n if (uvs && uvs.length) {\r\n for (let i = 0; i < vertexCount; i += 3) {\r\n const j = i * 2;\r\n const uv0 = [uvs[j], uvs[j + 1]];\r\n const uv1 = [uvs[j + 2], uvs[j + 3]];\r\n const uv2 = [uvs[j + 4], uvs[j + 5]];\r\n\r\n const uv01 = [(uv0[0] + uv1[0]) / 2, (uv0[1] + uv1[1]) / 2];\r\n const uv12 = [(uv1[0] + uv2[0]) / 2, (uv1[1] + uv2[1]) / 2];\r\n const uv20 = [(uv2[0] + uv0[0]) / 2, (uv2[1] + uv0[1]) / 2];\r\n\r\n newUVs.push(...uv0, ...uv01, ...uv20);\r\n newUVs.push(...uv1, ...uv12, ...uv01);\r\n newUVs.push(...uv2, ...uv20, ...uv12);\r\n newUVs.push(...uv01, ...uv12, ...uv20);\r\n }\r\n }\r\n\r\n const newVertexCount = newPositions.length / 3;\r\n const newIndices: number[] = [];\r\n for (let i = 0; i < newVertexCount; i++) {\r\n newIndices.push(i);\r\n }\r\n\r\n const newVertexData = new VertexData();\r\n newVertexData.positions = newPositions;\r\n if (newNormals.length) {\r\n newVertexData.normals = newNormals;\r\n }\r\n if (newUVs.length) {\r\n newVertexData.uvs = newUVs;\r\n }\r\n newVertexData.indices = newIndices;\r\n return newVertexData;\r\n}\r\n\r\n/**\r\n * Applies one iteration of smooth subdivision with vertex averaging.\r\n * This function uses the subdivideAttribute routine to adjust vertex data.\r\n * @internal\r\n */\r\nfunction smooth(vertexData: VertexData, options: ISubdivideOptions): VertexData {\r\n // Convert to non-indexed and apply flat subdivision first.\r\n const sourceData = toNonIndexed(vertexData);\r\n const flatData = flat(sourceData);\r\n\r\n const attributeList = gatherAttributes(sourceData);\r\n const origPositions = sourceData.positions!;\r\n const flatPositions = flatData.positions!;\r\n const vertexCount = origPositions.length / 3;\r\n\r\n // Build connectivity maps from the original geometry.\r\n const hashToIndex: { [hash: string]: number[] } = {};\r\n const existingNeighbors: { [hash: string]: { [neighborHash: string]: number[] } } = {};\r\n const flatOpposites: { [hash: string]: number[] } = {};\r\n const existingEdges: { [hash: string]: Set<string> } = {};\r\n\r\n function addNeighbor(posHash: string, neighborHash: string, index: number): void {\r\n if (!existingNeighbors[posHash]) {\r\n existingNeighbors[posHash] = {};\r\n }\r\n if (!existingNeighbors[posHash][neighborHash]) {\r\n existingNeighbors[posHash][neighborHash] = [];\r\n }\r\n existingNeighbors[posHash][neighborHash].push(index);\r\n }\r\n function addOpposite(posHash: string, index: number): void {\r\n if (!flatOpposites[posHash]) {\r\n flatOpposites[posHash] = [];\r\n }\r\n flatOpposites[posHash].push(index);\r\n }\r\n function addEdgePoint(posHash: string, edgeHash: string): void {\r\n if (!existingEdges[posHash]) {\r\n existingEdges[posHash] = new Set<string>();\r\n }\r\n existingEdges[posHash].add(edgeHash);\r\n }\r\n\r\n const temp = new Vector3();\r\n const v0 = new Vector3();\r\n const v1 = new Vector3();\r\n const v2 = new Vector3();\r\n const m01 = new Vector3();\r\n const m12 = new Vector3();\r\n const m20 = new Vector3();\r\n\r\n // Process original positions\r\n for (let i = 0; i < vertexCount; i += 3) {\r\n readVector(v0, origPositions, i, 3);\r\n readVector(v1, origPositions, i + 1, 3);\r\n readVector(v2, origPositions, i + 2, 3);\r\n const h0 = hashFromVector(v0);\r\n const h1 = hashFromVector(v1);\r\n const h2 = hashFromVector(v2);\r\n addNeighbor(h0, h1, i + 1);\r\n addNeighbor(h0, h2, i + 2);\r\n addNeighbor(h1, h0, i);\r\n addNeighbor(h1, h2, i + 2);\r\n addNeighbor(h2, h0, i);\r\n addNeighbor(h2, h1, i + 1);\r\n\r\n // Opposites from flat subdivision: calculate midpoints.\r\n v0.addToRef(v1, m01);\r\n m01.scaleInPlace(0.5);\r\n v1.addToRef(v2, m12);\r\n m12.scaleInPlace(0.5);\r\n v2.addToRef(v0, m20);\r\n m20.scaleInPlace(0.5);\r\n\r\n addOpposite(hashFromVector(m01), i + 2);\r\n addOpposite(hashFromVector(m12), i);\r\n addOpposite(hashFromVector(m20), i + 1);\r\n\r\n // Track edges for preserveEdges.\r\n addEdgePoint(h0, hashFromVector(m01));\r\n addEdgePoint(h0, hashFromVector(m20));\r\n addEdgePoint(h1, hashFromVector(m01));\r\n addEdgePoint(h1, hashFromVector(m12));\r\n addEdgePoint(h2, hashFromVector(m12));\r\n addEdgePoint(h2, hashFromVector(m20));\r\n }\r\n\r\n // Build map from flat positions to indices.\r\n for (let i = 0; i < flatPositions.length / 3; i++) {\r\n readVector(temp, flatPositions, i, 3);\r\n const h = hashFromVector(temp);\r\n if (!hashToIndex[h]) {\r\n hashToIndex[h] = [];\r\n }\r\n hashToIndex[h].push(i);\r\n }\r\n\r\n // Prepare temporary vectors for subdivideAttribute.\r\n const _vertex: Vector3[] = [new Vector3(), new Vector3(), new Vector3()];\r\n const _position: Vector3[] = [new Vector3(), new Vector3(), new Vector3()];\r\n const _average = new Vector3();\r\n const _temp = new Vector3();\r\n\r\n // subdivideAttribute: adjusts vertex attributes using Loop’s averaging rules.\r\n function subdivideAttribute(attributeName: string, existingAttribute: number[], flattenedAttribute: number[]): number[] {\r\n const itemSize = attributeName === \"uvs\" ? 2 : 3;\r\n const flatVertexCount = flatPositions.length / 3;\r\n const floatArray = new Array(flatVertexCount * itemSize);\r\n let index = 0;\r\n for (let i = 0; i < flatVertexCount; i += 3) {\r\n for (let v = 0; v < 3; v++) {\r\n if (attributeName === \"uvs\" && !options.uvSmooth) {\r\n // Simply copy UVs.\r\n readVector(_vertex[v], flattenedAttribute, i + v, 2);\r\n } else if (attributeName === \"normals\") {\r\n readVector(_position[v], flatPositions, i + v, 3);\r\n const positionHash = hashFromVector(_position[v]);\r\n const positionsArr = hashToIndex[positionHash] || [];\r\n const k = positionsArr.length;\r\n const beta = 0.75 / k;\r\n const startWeight = 1.0 - beta * k;\r\n readVector(_vertex[v], flattenedAttribute, i + v, 3);\r\n _vertex[v].scaleInPlace(startWeight);\r\n positionsArr.forEach((positionIndex) => {\r\n readVector(_average, flattenedAttribute, positionIndex, 3);\r\n _average.scaleInPlace(beta);\r\n _vertex[v].addInPlace(_average);\r\n });\r\n } else {\r\n // 'positions', 'colors', etc.\r\n readVector(_vertex[v], flattenedAttribute, i + v, itemSize);\r\n readVector(_position[v], flatPositions, i + v, 3);\r\n const positionHash = hashFromVector(_position[v]);\r\n const neighbors = existingNeighbors[positionHash];\r\n const opposites = flatOpposites[positionHash];\r\n if (neighbors) {\r\n if (options.preserveEdges) {\r\n const edgeSet = existingEdges[positionHash];\r\n let hasPair = true;\r\n edgeSet.forEach((edgeHash) => {\r\n if (flatOpposites[edgeHash] && flatOpposites[edgeHash].length % 2 !== 0) {\r\n hasPair = false;\r\n }\r\n });\r\n if (!hasPair) {\r\n // If edges aren't paired, skip adjustment.\r\n continue;\r\n }\r\n }\r\n const neighborKeys = Object.keys(neighbors);\r\n const k = neighborKeys.length;\r\n const beta = (1 / k) * (5 / 8 - Math.pow(3 / 8 + (1 / 4) * Math.cos((2 * Math.PI) / k), 2));\r\n const heavy = 1 / k / k;\r\n const weight = Scalar.Lerp(heavy, beta, options.weight!);\r\n const startWeight = 1.0 - weight * k;\r\n _vertex[v].scaleInPlace(startWeight);\r\n for (const neighborHash in neighbors) {\r\n const neighborIndices = neighbors[neighborHash];\r\n _average.set(0, 0, 0);\r\n neighborIndices.forEach((neighborIndex) => {\r\n readVector(_temp, existingAttribute, neighborIndex, itemSize);\r\n _average.addInPlace(_temp);\r\n });\r\n _average.scaleInPlace(1 / neighborIndices.length);\r\n _average.scaleInPlace(weight);\r\n _vertex[v].addInPlace(_average);\r\n }\r\n } else if (opposites && opposites.length === 2) {\r\n const k = opposites.length;\r\n const beta = 0.125; // 1/8\r\n const startWeight = 1.0 - beta * k;\r\n _vertex[v].scaleInPlace(startWeight);\r\n opposites.forEach((oppositeIndex) => {\r\n readVector(_average, existingAttribute, oppositeIndex, itemSize);\r\n _average.scaleInPlace(beta);\r\n _vertex[v].addInPlace(_average);\r\n });\r\n }\r\n }\r\n }\r\n // Write out new triangle vertices.\r\n setTriangle(floatArray, index, itemSize, _vertex[0].asArray(), _vertex[1].asArray(), _vertex[2].asArray());\r\n index += itemSize * 3;\r\n }\r\n return floatArray;\r\n }\r\n\r\n // Build new attributes for the smoothed geometry.\r\n const smoothData = new VertexData();\r\n attributeList.forEach((attributeName) => {\r\n if (attributeName === \"indices\") {\r\n return;\r\n }\r\n const existingAttribute = (sourceData as any)[attributeName] as number[];\r\n const flattenedAttribute = (flatData as any)[attributeName] as number[];\r\n if (!existingAttribute || !flattenedAttribute) {\r\n return;\r\n }\r\n const newArray = subdivideAttribute(attributeName, existingAttribute, flattenedAttribute);\r\n (smoothData as any)[attributeName] = newArray;\r\n });\r\n\r\n // Rebuild indices sequentially.\r\n const newPositions = smoothData.positions!;\r\n const newIndices: number[] = [];\r\n for (let i = 0; i < newPositions.length / 3; i++) {\r\n newIndices.push(i);\r\n }\r\n smoothData.indices = newIndices;\r\n return smoothData;\r\n}\r\n\r\n/**\r\n * Subdivide a vertexData using Loop algorithm\r\n * @param vertexData The vertexData to subdivide\r\n * @param level The number of times to subdivide\r\n * @param options The options to use when subdividing\r\n * @returns The subdivided vertexData\r\n */\r\nexport function Subdivide(vertexData: VertexData, level: number, options?: Partial<ISubdivideOptions>): VertexData {\r\n options = {\r\n flatOnly: false,\r\n uvSmooth: false,\r\n preserveEdges: false,\r\n weight: 1,\r\n ...options,\r\n };\r\n\r\n if (!vertexData.positions || vertexData.positions.length === 0 || level <= 0) {\r\n return vertexData;\r\n }\r\n\r\n // Clone the input\r\n let modified = vertexData.clone();\r\n\r\n for (let i = 0; i < level; i++) {\r\n if (options.flatOnly) {\r\n modified = flat(modified);\r\n } else {\r\n modified = smooth(modified, options);\r\n }\r\n }\r\n\r\n return modified;\r\n}\r\n"]}
package/Misc/index.d.ts CHANGED
@@ -74,6 +74,7 @@ export * from "./equirectangularCapture";
74
74
  export * from "./decorators.serialization";
75
75
  export * from "./asyncLock";
76
76
  export * from "./bitArray";
77
+ export * from "./urlTools";
77
78
  export * from "../Shaders/rgbdDecode.fragment";
78
79
  export * from "../Shaders/rgbdEncode.fragment";
79
80
  export * from "../ShadersWGSL/rgbdDecode.fragment";
package/Misc/index.js CHANGED
@@ -77,6 +77,7 @@ export * from "./equirectangularCapture.js";
77
77
  export * from "./decorators.serialization.js";
78
78
  export * from "./asyncLock.js";
79
79
  export * from "./bitArray.js";
80
+ export * from "./urlTools.js";
80
81
  // RGBDTextureTools
81
82
  export * from "../Shaders/rgbdDecode.fragment.js";
82
83
  export * from "../Shaders/rgbdEncode.fragment.js";
package/Misc/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../dev/core/src/Misc/index.ts"],"names":[],"mappings":"AAAA,+CAA+C;AAC/C,cAAc,qBAAqB,CAAC;AACpC,cAAc,iBAAiB,CAAC;AAChC,cAAc,SAAS,CAAC;AACxB,cAAc,OAAO,CAAC;AACtB,cAAc,cAAc,CAAC;AAC7B,cAAc,YAAY,CAAC;AAC3B,cAAc,2BAA2B,CAAC;AAC1C,cAAc,gBAAgB,CAAC;AAC/B,cAAc,cAAc,CAAC;AAC7B,cAAc,0BAA0B,CAAC;AACzC,cAAc,2BAA2B,CAAC;AAC1C,cAAc,cAAc,CAAC;AAC7B,cAAc,yBAAyB,CAAC;AACxC,cAAc,sBAAsB,CAAC;AACrC,cAAc,kBAAkB,CAAC;AACjC,cAAc,mBAAmB,CAAC;AAClC,cAAc,cAAc,CAAC;AAC7B,cAAc,oBAAoB,CAAC;AACnC,cAAc,QAAQ,CAAC;AACvB,cAAc,gBAAgB,CAAC;AAC/B,4BAA4B;AAC5B,cAAc,6BAA6B,CAAC;AAC5C,cAAc,yBAAyB,CAAC;AACxC,cAAc,iCAAiC,CAAC;AAChD,cAAc,6BAA6B,CAAC;AAC5C,cAAc,OAAO,CAAC;AACtB,cAAc,SAAS,CAAC;AACxB,cAAc,iBAAiB,CAAC;AAChC,cAAc,mBAAmB,CAAC;AAClC,cAAc,cAAc,CAAC;AAC7B,cAAc,UAAU,CAAC;AACzB,cAAc,aAAa,CAAC;AAC5B,cAAc,mBAAmB,CAAC;AAClC,cAAc,cAAc,CAAC;AAC7B,cAAc,cAAc,CAAC;AAC7B,cAAc,cAAc,CAAC;AAC7B,cAAc,iBAAiB,CAAC;AAChC,cAAc,mBAAmB,CAAC;AAClC,cAAc,cAAc,CAAC;AAC7B,cAAc,gBAAgB,CAAC;AAC/B,cAAc,oBAAoB,CAAC;AACnC,cAAc,oBAAoB,CAAC;AACnC,cAAc,aAAa,CAAC;AAC5B,cAAc,eAAe,CAAC;AAC9B,cAAc,eAAe,CAAC;AAC9B,cAAc,iCAAiC,CAAC;AAChD,cAAc,iBAAiB,CAAC;AAChC,cAAc,6BAA6B,CAAC;AAC5C,cAAc,0BAA0B,CAAC;AACzC,cAAc,aAAa,CAAC;AAC5B,cAAc,eAAe,CAAC;AAC9B,cAAc,cAAc,CAAC;AAC7B,cAAc,iBAAiB,CAAC;AAChC,cAAc,gBAAgB,CAAC;AAC/B,cAAc,eAAe,CAAC;AAC9B,cAAc,iBAAiB,CAAC;AAChC,cAAc,4BAA4B,CAAC;AAC3C,cAAc,wBAAwB,CAAC;AACvC,cAAc,SAAS,CAAC;AACxB,cAAc,aAAa,CAAC;AAC5B,cAAc,aAAa,CAAC;AAC5B,cAAc,iBAAiB,CAAC;AAChC,cAAc,2BAA2B,CAAC;AAC1C,cAAc,2BAA2B,CAAC;AAC1C,cAAc,aAAa,CAAC;AAC5B,cAAc,QAAQ,CAAC;AACvB,cAAc,SAAS,CAAC;AACxB,cAAc,2BAA2B,CAAC;AAC1C,yCAAyC;AACzC,cAAc,uBAAuB,CAAC;AACtC,cAAc,wBAAwB,CAAC;AACvC,yCAAyC;AACzC,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AACxC,cAAc,oBAAoB,CAAC;AACnC,cAAc,0BAA0B,CAAC;AACzC,cAAc,4BAA4B,CAAC;AAC3C,cAAc,aAAa,CAAC;AAC5B,cAAc,YAAY,CAAC;AAE3B,mBAAmB;AACnB,cAAc,gCAAgC,CAAC;AAC/C,cAAc,gCAAgC,CAAC;AAC/C,cAAc,oCAAoC,CAAC;AACnD,cAAc,oCAAoC,CAAC;AAEnD,uBAAuB;AACvB,cAAc,0CAA0C,CAAC;AACzD,cAAc,8CAA8C,CAAC","sourcesContent":["/* eslint-disable import/no-internal-modules */\r\nexport * from \"./andOrNotEvaluator\";\r\nexport * from \"./assetsManager\";\r\nexport * from \"./basis\";\r\nexport * from \"./dds\";\r\nexport * from \"./decorators\";\r\nexport * from \"./deferred\";\r\nexport * from \"./environmentTextureTools\";\r\nexport * from \"./meshExploder\";\r\nexport * from \"./filesInput\";\r\nexport * from \"./HighDynamicRange/index\";\r\nexport * from \"./khronosTextureContainer\";\r\nexport * from \"./observable\";\r\nexport * from \"./observable.extensions\";\r\nexport * from \"./performanceMonitor\";\r\nexport * from \"./sceneOptimizer\";\r\nexport * from \"./sceneSerializer\";\r\nexport * from \"./smartArray\";\r\nexport * from \"./stringDictionary\";\r\nexport * from \"./tags\";\r\nexport * from \"./textureTools\";\r\n// loaded from texture tools\r\nexport * from \"../Shaders/lodCube.fragment\";\r\nexport * from \"../Shaders/lod.fragment\";\r\nexport * from \"../ShadersWGSL/lodCube.fragment\";\r\nexport * from \"../ShadersWGSL/lod.fragment\";\r\nexport * from \"./tga\";\r\nexport * from \"./tools\";\r\nexport * from \"./videoRecorder\";\r\nexport * from \"./virtualJoystick\";\r\nexport * from \"./workerPool\";\r\nexport * from \"./logger\";\r\nexport * from \"./typeStore\";\r\nexport * from \"./filesInputStore\";\r\nexport * from \"./deepCopier\";\r\nexport * from \"./deepMerger\";\r\nexport * from \"./pivotTools\";\r\nexport * from \"./precisionDate\";\r\nexport * from \"./screenshotTools\";\r\nexport * from \"./webRequest\";\r\nexport * from \"./iInspectable\";\r\nexport * from \"./brdfTextureTools\";\r\nexport * from \"./rgbdTextureTools\";\r\nexport * from \"./gradients\";\r\nexport * from \"./perfCounter\";\r\nexport * from \"./fileRequest\";\r\nexport * from \"./customAnimationFrameRequester\";\r\nexport * from \"./retryStrategy\";\r\nexport * from \"./interfaces/screenshotSize\";\r\nexport * from \"./interfaces/iPerfViewer\";\r\nexport * from \"./fileTools\";\r\nexport * from \"./stringTools\";\r\nexport * from \"./dataReader\";\r\nexport * from \"./minMaxReducer\";\r\nexport * from \"./depthReducer\";\r\nexport * from \"./dataStorage\";\r\nexport * from \"./sceneRecorder\";\r\nexport * from \"./khronosTextureContainer2\";\r\nexport * from \"./trajectoryClassifier\";\r\nexport * from \"./timer\";\r\nexport * from \"./copyTools\";\r\nexport * from \"./reflector\";\r\nexport * from \"./domManagement\";\r\nexport * from \"./pressureObserverWrapper\";\r\nexport * from \"./PerformanceViewer/index\";\r\nexport * from \"./coroutine\";\r\nexport * from \"./guid\";\r\nexport * from \"./error\";\r\nexport * from \"./snapshotRenderingHelper\";\r\n// eslint-disable-next-line import/export\r\nexport * from \"./observableCoroutine\";\r\nexport * from \"./copyTextureToTexture\";\r\n/** @deprecated Use individual exports */\r\nexport { DumpTools } from \"./dumpTools\";\r\nexport * from \"./greasedLineTools\";\r\nexport * from \"./equirectangularCapture\";\r\nexport * from \"./decorators.serialization\";\r\nexport * from \"./asyncLock\";\r\nexport * from \"./bitArray\";\r\n\r\n// RGBDTextureTools\r\nexport * from \"../Shaders/rgbdDecode.fragment\";\r\nexport * from \"../Shaders/rgbdEncode.fragment\";\r\nexport * from \"../ShadersWGSL/rgbdDecode.fragment\";\r\nexport * from \"../ShadersWGSL/rgbdEncode.fragment\";\r\n\r\n// CopyTextureToTexture\r\nexport * from \"../Shaders/copyTextureToTexture.fragment\";\r\nexport * from \"../ShadersWGSL/copyTextureToTexture.fragment\";\r\n"]}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../dev/core/src/Misc/index.ts"],"names":[],"mappings":"AAAA,+CAA+C;AAC/C,cAAc,qBAAqB,CAAC;AACpC,cAAc,iBAAiB,CAAC;AAChC,cAAc,SAAS,CAAC;AACxB,cAAc,OAAO,CAAC;AACtB,cAAc,cAAc,CAAC;AAC7B,cAAc,YAAY,CAAC;AAC3B,cAAc,2BAA2B,CAAC;AAC1C,cAAc,gBAAgB,CAAC;AAC/B,cAAc,cAAc,CAAC;AAC7B,cAAc,0BAA0B,CAAC;AACzC,cAAc,2BAA2B,CAAC;AAC1C,cAAc,cAAc,CAAC;AAC7B,cAAc,yBAAyB,CAAC;AACxC,cAAc,sBAAsB,CAAC;AACrC,cAAc,kBAAkB,CAAC;AACjC,cAAc,mBAAmB,CAAC;AAClC,cAAc,cAAc,CAAC;AAC7B,cAAc,oBAAoB,CAAC;AACnC,cAAc,QAAQ,CAAC;AACvB,cAAc,gBAAgB,CAAC;AAC/B,4BAA4B;AAC5B,cAAc,6BAA6B,CAAC;AAC5C,cAAc,yBAAyB,CAAC;AACxC,cAAc,iCAAiC,CAAC;AAChD,cAAc,6BAA6B,CAAC;AAC5C,cAAc,OAAO,CAAC;AACtB,cAAc,SAAS,CAAC;AACxB,cAAc,iBAAiB,CAAC;AAChC,cAAc,mBAAmB,CAAC;AAClC,cAAc,cAAc,CAAC;AAC7B,cAAc,UAAU,CAAC;AACzB,cAAc,aAAa,CAAC;AAC5B,cAAc,mBAAmB,CAAC;AAClC,cAAc,cAAc,CAAC;AAC7B,cAAc,cAAc,CAAC;AAC7B,cAAc,cAAc,CAAC;AAC7B,cAAc,iBAAiB,CAAC;AAChC,cAAc,mBAAmB,CAAC;AAClC,cAAc,cAAc,CAAC;AAC7B,cAAc,gBAAgB,CAAC;AAC/B,cAAc,oBAAoB,CAAC;AACnC,cAAc,oBAAoB,CAAC;AACnC,cAAc,aAAa,CAAC;AAC5B,cAAc,eAAe,CAAC;AAC9B,cAAc,eAAe,CAAC;AAC9B,cAAc,iCAAiC,CAAC;AAChD,cAAc,iBAAiB,CAAC;AAChC,cAAc,6BAA6B,CAAC;AAC5C,cAAc,0BAA0B,CAAC;AACzC,cAAc,aAAa,CAAC;AAC5B,cAAc,eAAe,CAAC;AAC9B,cAAc,cAAc,CAAC;AAC7B,cAAc,iBAAiB,CAAC;AAChC,cAAc,gBAAgB,CAAC;AAC/B,cAAc,eAAe,CAAC;AAC9B,cAAc,iBAAiB,CAAC;AAChC,cAAc,4BAA4B,CAAC;AAC3C,cAAc,wBAAwB,CAAC;AACvC,cAAc,SAAS,CAAC;AACxB,cAAc,aAAa,CAAC;AAC5B,cAAc,aAAa,CAAC;AAC5B,cAAc,iBAAiB,CAAC;AAChC,cAAc,2BAA2B,CAAC;AAC1C,cAAc,2BAA2B,CAAC;AAC1C,cAAc,aAAa,CAAC;AAC5B,cAAc,QAAQ,CAAC;AACvB,cAAc,SAAS,CAAC;AACxB,cAAc,2BAA2B,CAAC;AAC1C,yCAAyC;AACzC,cAAc,uBAAuB,CAAC;AACtC,cAAc,wBAAwB,CAAC;AACvC,yCAAyC;AACzC,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AACxC,cAAc,oBAAoB,CAAC;AACnC,cAAc,0BAA0B,CAAC;AACzC,cAAc,4BAA4B,CAAC;AAC3C,cAAc,aAAa,CAAC;AAC5B,cAAc,YAAY,CAAC;AAC3B,cAAc,YAAY,CAAC;AAE3B,mBAAmB;AACnB,cAAc,gCAAgC,CAAC;AAC/C,cAAc,gCAAgC,CAAC;AAC/C,cAAc,oCAAoC,CAAC;AACnD,cAAc,oCAAoC,CAAC;AAEnD,uBAAuB;AACvB,cAAc,0CAA0C,CAAC;AACzD,cAAc,8CAA8C,CAAC","sourcesContent":["/* eslint-disable import/no-internal-modules */\r\nexport * from \"./andOrNotEvaluator\";\r\nexport * from \"./assetsManager\";\r\nexport * from \"./basis\";\r\nexport * from \"./dds\";\r\nexport * from \"./decorators\";\r\nexport * from \"./deferred\";\r\nexport * from \"./environmentTextureTools\";\r\nexport * from \"./meshExploder\";\r\nexport * from \"./filesInput\";\r\nexport * from \"./HighDynamicRange/index\";\r\nexport * from \"./khronosTextureContainer\";\r\nexport * from \"./observable\";\r\nexport * from \"./observable.extensions\";\r\nexport * from \"./performanceMonitor\";\r\nexport * from \"./sceneOptimizer\";\r\nexport * from \"./sceneSerializer\";\r\nexport * from \"./smartArray\";\r\nexport * from \"./stringDictionary\";\r\nexport * from \"./tags\";\r\nexport * from \"./textureTools\";\r\n// loaded from texture tools\r\nexport * from \"../Shaders/lodCube.fragment\";\r\nexport * from \"../Shaders/lod.fragment\";\r\nexport * from \"../ShadersWGSL/lodCube.fragment\";\r\nexport * from \"../ShadersWGSL/lod.fragment\";\r\nexport * from \"./tga\";\r\nexport * from \"./tools\";\r\nexport * from \"./videoRecorder\";\r\nexport * from \"./virtualJoystick\";\r\nexport * from \"./workerPool\";\r\nexport * from \"./logger\";\r\nexport * from \"./typeStore\";\r\nexport * from \"./filesInputStore\";\r\nexport * from \"./deepCopier\";\r\nexport * from \"./deepMerger\";\r\nexport * from \"./pivotTools\";\r\nexport * from \"./precisionDate\";\r\nexport * from \"./screenshotTools\";\r\nexport * from \"./webRequest\";\r\nexport * from \"./iInspectable\";\r\nexport * from \"./brdfTextureTools\";\r\nexport * from \"./rgbdTextureTools\";\r\nexport * from \"./gradients\";\r\nexport * from \"./perfCounter\";\r\nexport * from \"./fileRequest\";\r\nexport * from \"./customAnimationFrameRequester\";\r\nexport * from \"./retryStrategy\";\r\nexport * from \"./interfaces/screenshotSize\";\r\nexport * from \"./interfaces/iPerfViewer\";\r\nexport * from \"./fileTools\";\r\nexport * from \"./stringTools\";\r\nexport * from \"./dataReader\";\r\nexport * from \"./minMaxReducer\";\r\nexport * from \"./depthReducer\";\r\nexport * from \"./dataStorage\";\r\nexport * from \"./sceneRecorder\";\r\nexport * from \"./khronosTextureContainer2\";\r\nexport * from \"./trajectoryClassifier\";\r\nexport * from \"./timer\";\r\nexport * from \"./copyTools\";\r\nexport * from \"./reflector\";\r\nexport * from \"./domManagement\";\r\nexport * from \"./pressureObserverWrapper\";\r\nexport * from \"./PerformanceViewer/index\";\r\nexport * from \"./coroutine\";\r\nexport * from \"./guid\";\r\nexport * from \"./error\";\r\nexport * from \"./snapshotRenderingHelper\";\r\n// eslint-disable-next-line import/export\r\nexport * from \"./observableCoroutine\";\r\nexport * from \"./copyTextureToTexture\";\r\n/** @deprecated Use individual exports */\r\nexport { DumpTools } from \"./dumpTools\";\r\nexport * from \"./greasedLineTools\";\r\nexport * from \"./equirectangularCapture\";\r\nexport * from \"./decorators.serialization\";\r\nexport * from \"./asyncLock\";\r\nexport * from \"./bitArray\";\r\nexport * from \"./urlTools\";\r\n\r\n// RGBDTextureTools\r\nexport * from \"../Shaders/rgbdDecode.fragment\";\r\nexport * from \"../Shaders/rgbdEncode.fragment\";\r\nexport * from \"../ShadersWGSL/rgbdDecode.fragment\";\r\nexport * from \"../ShadersWGSL/rgbdEncode.fragment\";\r\n\r\n// CopyTextureToTexture\r\nexport * from \"../Shaders/copyTextureToTexture.fragment\";\r\nexport * from \"../ShadersWGSL/copyTextureToTexture.fragment\";\r\n"]}
@@ -0,0 +1,6 @@
1
+ /**
2
+ * Gets the file extension from a URL.
3
+ * @param url The URL to get the file extension from.
4
+ * @returns The file extension, or an empty string if no extension is found.
5
+ */
6
+ export declare function GetExtensionFromUrl(url: string): string;
@@ -0,0 +1,12 @@
1
+ /**
2
+ * Gets the file extension from a URL.
3
+ * @param url The URL to get the file extension from.
4
+ * @returns The file extension, or an empty string if no extension is found.
5
+ */
6
+ export function GetExtensionFromUrl(url) {
7
+ const urlWithoutUriParams = url.split("?")[0];
8
+ const lastDot = urlWithoutUriParams.lastIndexOf(".");
9
+ const extension = lastDot > -1 ? urlWithoutUriParams.substring(lastDot).toLowerCase() : "";
10
+ return extension;
11
+ }
12
+ //# sourceMappingURL=urlTools.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"urlTools.js","sourceRoot":"","sources":["../../../../dev/core/src/Misc/urlTools.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AACH,MAAM,UAAU,mBAAmB,CAAC,GAAW;IAC3C,MAAM,mBAAmB,GAAG,GAAG,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;IAC9C,MAAM,OAAO,GAAG,mBAAmB,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC;IACrD,MAAM,SAAS,GAAG,OAAO,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,mBAAmB,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;IAC3F,OAAO,SAAS,CAAC;AACrB,CAAC","sourcesContent":["/**\r\n * Gets the file extension from a URL.\r\n * @param url The URL to get the file extension from.\r\n * @returns The file extension, or an empty string if no extension is found.\r\n */\r\nexport function GetExtensionFromUrl(url: string) {\r\n const urlWithoutUriParams = url.split(\"?\")[0];\r\n const lastDot = urlWithoutUriParams.lastIndexOf(\".\");\r\n const extension = lastDot > -1 ? urlWithoutUriParams.substring(lastDot).toLowerCase() : \"\";\r\n return extension;\r\n}\r\n"]}
@@ -587,9 +587,11 @@ export class _IblShadowsVoxelRenderer {
587
587
  this._voxelGridRT.render();
588
588
  }
589
589
  this._generateMipMaps();
590
- this._copyMipMaps();
591
- this._scene.onAfterRenderObservable.removeCallback(this._renderVoxelGridBound);
592
- this._voxelizationInProgress = false;
590
+ this._copyMipEffectWrapper.effect.whenCompiledAsync().then(() => {
591
+ this._copyMipMaps();
592
+ this._scene.onAfterRenderObservable.removeCallback(this._renderVoxelGridBound);
593
+ this._voxelizationInProgress = false;
594
+ });
593
595
  }
594
596
  }
595
597
  }