@loaders.gl/gltf 4.0.0-alpha.23 → 4.0.0-alpha.24

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 (85) hide show
  1. package/dist/dist.min.js +148 -102
  2. package/dist/es5/lib/extensions/EXT_mesh_features.js +3 -3
  3. package/dist/es5/lib/extensions/EXT_mesh_features.js.map +1 -1
  4. package/dist/es5/lib/extensions/EXT_structural_metadata.js +88 -86
  5. package/dist/es5/lib/extensions/EXT_structural_metadata.js.map +1 -1
  6. package/dist/es5/lib/extensions/deprecated/EXT_feature_metadata.js +26 -13
  7. package/dist/es5/lib/extensions/deprecated/EXT_feature_metadata.js.map +1 -1
  8. package/dist/es5/lib/extensions/{data-processing.js → utils/3d-tiles-utils.js} +25 -6
  9. package/dist/es5/lib/extensions/utils/3d-tiles-utils.js.map +1 -0
  10. package/dist/es5/lib/types/gltf-ext-structural-metadata-schema.js.map +1 -1
  11. package/dist/es5/lib/types/gltf-json-schema.js.map +1 -1
  12. package/dist/es5/lib/utils/version.js +1 -1
  13. package/dist/esm/lib/extensions/EXT_mesh_features.js +1 -1
  14. package/dist/esm/lib/extensions/EXT_mesh_features.js.map +1 -1
  15. package/dist/esm/lib/extensions/EXT_structural_metadata.js +85 -81
  16. package/dist/esm/lib/extensions/EXT_structural_metadata.js.map +1 -1
  17. package/dist/esm/lib/extensions/deprecated/EXT_feature_metadata.js +26 -13
  18. package/dist/esm/lib/extensions/deprecated/EXT_feature_metadata.js.map +1 -1
  19. package/dist/esm/lib/extensions/{data-processing.js → utils/3d-tiles-utils.js} +24 -6
  20. package/dist/esm/lib/extensions/utils/3d-tiles-utils.js.map +1 -0
  21. package/dist/esm/lib/types/gltf-ext-structural-metadata-schema.js.map +1 -1
  22. package/dist/esm/lib/types/gltf-json-schema.js.map +1 -1
  23. package/dist/esm/lib/utils/version.js +1 -1
  24. package/dist/lib/extensions/EXT_structural_metadata.d.ts +3 -3
  25. package/dist/lib/extensions/EXT_structural_metadata.d.ts.map +1 -1
  26. package/dist/lib/extensions/deprecated/EXT_feature_metadata.d.ts.map +1 -1
  27. package/dist/lib/extensions/utils/3d-tiles-utils.d.ts +52 -0
  28. package/dist/lib/extensions/utils/3d-tiles-utils.d.ts.map +1 -0
  29. package/dist/lib/types/gltf-ext-structural-metadata-schema.d.ts +4 -4
  30. package/dist/lib/types/gltf-ext-structural-metadata-schema.d.ts.map +1 -1
  31. package/dist/lib/types/gltf-json-schema.d.ts +1 -1
  32. package/dist/lib/types/gltf-json-schema.d.ts.map +1 -1
  33. package/package.json +6 -6
  34. package/src/lib/extensions/EXT_mesh_features.ts +1 -1
  35. package/src/lib/extensions/EXT_structural_metadata.ts +267 -200
  36. package/src/lib/extensions/deprecated/EXT_feature_metadata.ts +123 -19
  37. package/src/lib/extensions/{data-processing.ts → utils/3d-tiles-utils.ts} +95 -34
  38. package/src/lib/types/gltf-ext-structural-metadata-schema.ts +6 -4
  39. package/src/lib/types/gltf-json-schema.ts +1 -1
  40. package/dist/bundle.js +0 -5
  41. package/dist/es5/lib/extensions/data-processing.js.map +0 -1
  42. package/dist/esm/lib/extensions/data-processing.js.map +0 -1
  43. package/dist/glb-loader.js +0 -34
  44. package/dist/glb-writer.js +0 -35
  45. package/dist/gltf-loader.js +0 -50
  46. package/dist/gltf-writer.js +0 -32
  47. package/dist/index.js +0 -34
  48. package/dist/lib/api/gltf-extensions.js +0 -88
  49. package/dist/lib/api/gltf-scenegraph.js +0 -580
  50. package/dist/lib/api/normalize-gltf-v1.js +0 -299
  51. package/dist/lib/api/post-process-gltf.js +0 -433
  52. package/dist/lib/encoders/encode-glb.js +0 -72
  53. package/dist/lib/encoders/encode-gltf.js +0 -32
  54. package/dist/lib/extensions/EXT_mesh_features.js +0 -89
  55. package/dist/lib/extensions/EXT_meshopt_compression.js +0 -41
  56. package/dist/lib/extensions/EXT_structural_metadata.js +0 -504
  57. package/dist/lib/extensions/EXT_texture_webp.js +0 -36
  58. package/dist/lib/extensions/KHR_binary_gltf.js +0 -39
  59. package/dist/lib/extensions/KHR_draco_mesh_compression.js +0 -137
  60. package/dist/lib/extensions/KHR_texture_basisu.js +0 -29
  61. package/dist/lib/extensions/KHR_texture_transform.js +0 -227
  62. package/dist/lib/extensions/data-processing.d.ts +0 -34
  63. package/dist/lib/extensions/data-processing.d.ts.map +0 -1
  64. package/dist/lib/extensions/data-processing.js +0 -212
  65. package/dist/lib/extensions/deprecated/EXT_feature_metadata.js +0 -282
  66. package/dist/lib/extensions/deprecated/KHR_lights_punctual.js +0 -59
  67. package/dist/lib/extensions/deprecated/KHR_materials_unlit.js +0 -44
  68. package/dist/lib/extensions/deprecated/KHR_techniques_webgl.js +0 -79
  69. package/dist/lib/gltf-utils/get-typed-array.js +0 -41
  70. package/dist/lib/gltf-utils/gltf-attribute-utils.js +0 -73
  71. package/dist/lib/gltf-utils/gltf-constants.js +0 -43
  72. package/dist/lib/gltf-utils/gltf-utils.js +0 -90
  73. package/dist/lib/gltf-utils/resolve-url.js +0 -18
  74. package/dist/lib/parsers/parse-glb.js +0 -166
  75. package/dist/lib/parsers/parse-gltf.js +0 -185
  76. package/dist/lib/types/glb-types.js +0 -2
  77. package/dist/lib/types/gltf-ext-mesh-features-schema.js +0 -2
  78. package/dist/lib/types/gltf-ext-structural-metadata-schema.js +0 -2
  79. package/dist/lib/types/gltf-json-schema.js +0 -4
  80. package/dist/lib/types/gltf-postprocessed-schema.js +0 -4
  81. package/dist/lib/types/gltf-types.js +0 -3
  82. package/dist/lib/utils/assert.js +0 -12
  83. package/dist/lib/utils/version.js +0 -7
  84. package/dist/meshopt/meshopt-decoder.js +0 -118
  85. package/dist/webp/webp.js +0 -38
@@ -10,7 +10,7 @@ exports.name = void 0;
10
10
  var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
11
11
  var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
12
12
  var _gltfScenegraph = require("../api/gltf-scenegraph");
13
- var _dataProcessing = require("./data-processing");
13
+ var _dTilesUtils = require("./utils/3d-tiles-utils");
14
14
  function _createForOfIteratorHelper(o, allowArrayLike) { var it = typeof Symbol !== "undefined" && o[Symbol.iterator] || o["@@iterator"]; if (!it) { if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === "number") { if (it) o = it; var i = 0; var F = function F() {}; return { s: F, n: function n() { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }, e: function e(_e) { throw _e; }, f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var normalCompletion = true, didErr = false, err; return { s: function s() { it = it.call(o); }, n: function n() { var step = it.next(); normalCompletion = step.done; return step; }, e: function e(_e2) { didErr = true; err = _e2; }, f: function f() { try { if (!normalCompletion && it.return != null) it.return(); } finally { if (didErr) throw err; } } }; }
15
15
  function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
16
16
  function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }
@@ -90,6 +90,15 @@ function decodeExtStructuralMetadata(scenegraph, options) {
90
90
  }
91
91
  }
92
92
  }
93
+ function findPropertyTableByClass(propertyTables, schemaClassName) {
94
+ for (var i = 0, len = propertyTables.length; i < len; i++) {
95
+ var propertyTable = propertyTables[i];
96
+ if (propertyTable.class === schemaClassName) {
97
+ return propertyTable;
98
+ }
99
+ }
100
+ return null;
101
+ }
93
102
  function processPrimitivePropertyTextures(scenegraph, propertyTextures, primitive, extension) {
94
103
  var _primitive$extensions;
95
104
  if (!propertyTextures) {
@@ -133,11 +142,11 @@ function processPrimitivePropertyTexture(scenegraph, propertyTexture, primitive,
133
142
  textureInfoTopLevel.data = [];
134
143
  }
135
144
  var featureTextureTable = textureInfoTopLevel.data;
136
- var propertyData = (0, _dataProcessing.getPrimitiveTextureData)(scenegraph, textureInfoTopLevel, primitive);
145
+ var propertyData = (0, _dTilesUtils.getPrimitiveTextureData)(scenegraph, textureInfoTopLevel, primitive);
137
146
  if (propertyData === null) {
138
147
  continue;
139
148
  }
140
- (0, _dataProcessing.primitivePropertyDataToAttributes)(scenegraph, attributeName, propertyData, featureTextureTable, primitive);
149
+ (0, _dTilesUtils.primitivePropertyDataToAttributes)(scenegraph, attributeName, propertyData, featureTextureTable, primitive);
141
150
  textureInfoTopLevel.data = featureTextureTable;
142
151
  extension.dataAttributeNames.push(attributeName);
143
152
  }
@@ -163,14 +172,8 @@ function getPropertyDataFromBinarySource(scenegraph, schema, classProperty, numb
163
172
  var data = [];
164
173
  var valuesBufferView = propertyTableProperty.values;
165
174
  var valuesDataBytes = scenegraph.getTypedArrayForBufferView(valuesBufferView);
166
- var arrayOffsets = null;
167
- if (classProperty.array && typeof classProperty.count === 'undefined' && typeof propertyTableProperty.arrayOffsets !== 'undefined' && typeof propertyTableProperty.arrayOffsetType !== 'undefined') {
168
- arrayOffsets = getOffsetArray(scenegraph, propertyTableProperty.arrayOffsets, propertyTableProperty.arrayOffsetType, numberOfElements);
169
- }
170
- var stringOffsets = null;
171
- if (typeof propertyTableProperty.stringOffsets !== 'undefined' && typeof propertyTableProperty.stringOffsetType !== 'undefined') {
172
- stringOffsets = getOffsetArray(scenegraph, propertyTableProperty.stringOffsets, propertyTableProperty.stringOffsetType, numberOfElements);
173
- }
175
+ var arrayOffsets = getArrayOffsetsForProperty(scenegraph, classProperty, propertyTableProperty, numberOfElements);
176
+ var stringOffsets = getStringOffsetsForProperty(scenegraph, propertyTableProperty, numberOfElements);
174
177
  switch (classProperty.type) {
175
178
  case 'SCALAR':
176
179
  case 'VEC2':
@@ -202,66 +205,62 @@ function getPropertyDataFromBinarySource(scenegraph, schema, classProperty, numb
202
205
  }
203
206
  return data;
204
207
  }
205
- function getOffsetArray(scenegraph, offsets, offsetType, numberOfElements) {
206
- var arrayOffsetsBufferView = offsets;
207
- var arrayOffsetsBytes = scenegraph.getTypedArrayForBufferView(arrayOffsetsBufferView);
208
- var arrayOffsets = (0, _dataProcessing.convertRawBufferToMetadataArray)(arrayOffsetsBytes, 'SCALAR', offsetType, numberOfElements + 1);
209
- return arrayOffsets;
208
+ function getArrayOffsetsForProperty(scenegraph, classProperty, propertyTableProperty, numberOfElements) {
209
+ if (classProperty.array && typeof classProperty.count === 'undefined' && typeof propertyTableProperty.arrayOffsets !== 'undefined' && typeof propertyTableProperty.arrayOffsetType !== 'undefined') {
210
+ return (0, _dTilesUtils.getOffsetsForProperty)(scenegraph, propertyTableProperty.arrayOffsets, propertyTableProperty.arrayOffsetType, numberOfElements);
211
+ }
212
+ return null;
213
+ }
214
+ function getStringOffsetsForProperty(scenegraph, propertyTableProperty, numberOfElements) {
215
+ if (typeof propertyTableProperty.stringOffsets !== 'undefined' && typeof propertyTableProperty.stringOffsetType !== 'undefined') {
216
+ return (0, _dTilesUtils.getOffsetsForProperty)(scenegraph, propertyTableProperty.stringOffsets, propertyTableProperty.stringOffsetType, numberOfElements);
217
+ }
218
+ return null;
210
219
  }
211
220
  function getPropertyDataNumeric(classProperty, numberOfElements, valuesDataBytes, arrayOffsets) {
212
221
  var isArray = classProperty.array;
213
222
  var arrayCount = classProperty.count;
214
- var elementSize = (0, _dataProcessing.getArrayElementByteSize)(classProperty.type, classProperty.componentType);
223
+ var elementSize = (0, _dTilesUtils.getArrayElementByteSize)(classProperty.type, classProperty.componentType);
215
224
  var elementCount = valuesDataBytes.byteLength / elementSize;
216
225
  var valuesData;
217
226
  if (classProperty.componentType) {
218
- valuesData = (0, _dataProcessing.convertRawBufferToMetadataArray)(valuesDataBytes, classProperty.type, classProperty.componentType, elementCount);
227
+ valuesData = (0, _dTilesUtils.convertRawBufferToMetadataArray)(valuesDataBytes, classProperty.type, classProperty.componentType, elementCount);
228
+ if (!valuesData) {
229
+ valuesData = valuesDataBytes;
230
+ }
219
231
  } else {
220
232
  valuesData = valuesDataBytes;
221
233
  }
222
234
  if (isArray) {
223
235
  if (arrayOffsets) {
224
- return handleVariableLengthArrayNumeric(valuesData, numberOfElements, arrayOffsets, valuesDataBytes.length, elementSize);
236
+ return parseVariableLengthArrayNumeric(valuesData, numberOfElements, arrayOffsets, valuesDataBytes.length, elementSize);
225
237
  }
226
238
  if (arrayCount) {
227
- return handleFixedLengthArrayNumeric(valuesData, numberOfElements, arrayCount);
239
+ return parseFixedLengthArrayNumeric(valuesData, numberOfElements, arrayCount);
228
240
  }
229
241
  return [];
230
242
  }
231
- var attributeValueArray = [];
232
- for (var index = 0; index < numberOfElements; index++) {
233
- var value = valuesData[index];
234
- attributeValueArray.push(value);
235
- }
236
- return attributeValueArray;
243
+ return valuesData;
237
244
  }
238
- function handleVariableLengthArrayNumeric(valuesData, numberOfElements, arrayOffsets, valuesDataBytesLength, elementSize) {
245
+ function parseVariableLengthArrayNumeric(valuesData, numberOfElements, arrayOffsets, valuesDataBytesLength, valueSize) {
239
246
  var attributeValueArray = [];
240
247
  for (var index = 0; index < numberOfElements; index++) {
241
- var array = [];
242
248
  var arrayOffset = arrayOffsets[index];
243
249
  var arrayByteSize = arrayOffsets[index + 1] - arrayOffsets[index];
244
- if (arrayByteSize + arrayOffset <= valuesDataBytesLength) {
245
- var typedArrayOffset = arrayOffset / elementSize;
246
- var elementCount = arrayByteSize / elementSize;
247
- for (var i = 0; i < elementCount; i++) {
248
- var value = valuesData[typedArrayOffset + i];
249
- array.push(value);
250
- }
250
+ if (arrayByteSize + arrayOffset > valuesDataBytesLength) {
251
+ break;
251
252
  }
252
- attributeValueArray.push(array);
253
+ var typedArrayOffset = arrayOffset / valueSize;
254
+ var elementCount = arrayByteSize / valueSize;
255
+ attributeValueArray.push(valuesData.slice(typedArrayOffset, typedArrayOffset + elementCount));
253
256
  }
254
257
  return attributeValueArray;
255
258
  }
256
- function handleFixedLengthArrayNumeric(valuesData, numberOfElements, arrayCount) {
259
+ function parseFixedLengthArrayNumeric(valuesData, numberOfElements, arrayCount) {
257
260
  var attributeValueArray = [];
258
261
  for (var index = 0; index < numberOfElements; index++) {
259
- var array = [];
260
- for (var i = 0; i < arrayCount; i++) {
261
- var value = valuesData[i];
262
- array.push(value);
263
- }
264
- attributeValueArray.push(array);
262
+ var elementOffset = index * arrayCount;
263
+ attributeValueArray.push(valuesData.slice(elementOffset, elementOffset + arrayCount));
265
264
  }
266
265
  return attributeValueArray;
267
266
  }
@@ -288,9 +287,6 @@ function getPropertyDataString(classProperty, numberOfElements, valuesDataBytes,
288
287
  }
289
288
  function getPropertyDataENUM(schema, classProperty, numberOfElements, valuesDataBytes, arrayOffsets) {
290
289
  var _schema$enums;
291
- var data = [];
292
- var isArray = classProperty.array;
293
- var arrayCount = classProperty.count;
294
290
  var enumType = classProperty.enumType;
295
291
  if (!enumType) {
296
292
  throw new Error('Incorrect data in the EXT_structural_metadata extension: classProperty.enumType is not set for type ENUM');
@@ -300,71 +296,77 @@ function getPropertyDataENUM(schema, classProperty, numberOfElements, valuesData
300
296
  throw new Error("Incorrect data in the EXT_structural_metadata extension: schema.enums does't contain ".concat(enumType));
301
297
  }
302
298
  var enumValueType = enumEntry.valueType || 'UINT16';
303
- var elementSize = (0, _dataProcessing.getArrayElementByteSize)(classProperty.type, enumValueType);
299
+ var elementSize = (0, _dTilesUtils.getArrayElementByteSize)(classProperty.type, enumValueType);
304
300
  var elementCount = valuesDataBytes.byteLength / elementSize;
305
- var valuesData = (0, _dataProcessing.convertRawBufferToMetadataArray)(valuesDataBytes, classProperty.type, enumValueType, elementCount);
306
- if (isArray) {
301
+ var valuesData = (0, _dTilesUtils.convertRawBufferToMetadataArray)(valuesDataBytes, classProperty.type, enumValueType, elementCount);
302
+ if (!valuesData) {
303
+ valuesData = valuesDataBytes;
304
+ }
305
+ if (classProperty.array) {
307
306
  if (arrayOffsets) {
308
- return handleVariableLengthArrayENUM(valuesData, numberOfElements, arrayOffsets, valuesDataBytes.length, elementSize, enumEntry);
307
+ return parseVariableLengthArrayENUM({
308
+ valuesData: valuesData,
309
+ numberOfElements: numberOfElements,
310
+ arrayOffsets: arrayOffsets,
311
+ valuesDataBytesLength: valuesDataBytes.length,
312
+ elementSize: elementSize,
313
+ enumEntry: enumEntry
314
+ });
309
315
  }
316
+ var arrayCount = classProperty.count;
310
317
  if (arrayCount) {
311
- return handleFixedLengthArrayENUM(valuesData, numberOfElements, arrayCount, enumEntry);
318
+ return parseFixedLengthArrayENUM(valuesData, numberOfElements, arrayCount, enumEntry);
312
319
  }
313
320
  return [];
314
321
  }
315
- for (var index = 0; index < numberOfElements; index++) {
316
- var enumValue = valuesData[index];
317
- var enumObject = getEnumByValue(enumEntry, enumValue);
318
- if (enumObject) {
319
- data.push(enumObject.name);
320
- }
321
- }
322
- return data;
322
+ return getEnumsArray(valuesData, 0, numberOfElements, enumEntry);
323
323
  }
324
- function handleVariableLengthArrayENUM(valuesData, numberOfElements, arrayOffsets, valuesDataBytesLength, elementSize, enumEntry) {
324
+ function parseVariableLengthArrayENUM(params) {
325
+ var valuesData = params.valuesData,
326
+ numberOfElements = params.numberOfElements,
327
+ arrayOffsets = params.arrayOffsets,
328
+ valuesDataBytesLength = params.valuesDataBytesLength,
329
+ elementSize = params.elementSize,
330
+ enumEntry = params.enumEntry;
325
331
  var attributeValueArray = [];
326
332
  for (var index = 0; index < numberOfElements; index++) {
327
- var array = [];
328
333
  var arrayOffset = arrayOffsets[index];
329
334
  var arrayByteSize = arrayOffsets[index + 1] - arrayOffsets[index];
330
- if (arrayByteSize + arrayOffset <= valuesDataBytesLength) {
331
- var typedArrayOffset = arrayOffset / elementSize;
332
- var elementCount = arrayByteSize / elementSize;
333
- for (var i = 0; i < elementCount; i++) {
334
- var value = valuesData[typedArrayOffset + i];
335
- var enumObject = getEnumByValue(enumEntry, value);
336
- if (enumObject) {
337
- array.push(enumObject.name);
338
- }
339
- }
335
+ if (arrayByteSize + arrayOffset > valuesDataBytesLength) {
336
+ break;
340
337
  }
338
+ var typedArrayOffset = arrayOffset / elementSize;
339
+ var elementCount = arrayByteSize / elementSize;
340
+ var array = getEnumsArray(valuesData, typedArrayOffset, elementCount, enumEntry);
341
341
  attributeValueArray.push(array);
342
342
  }
343
343
  return attributeValueArray;
344
344
  }
345
- function handleFixedLengthArrayENUM(valuesData, numberOfElements, arrayCount, enumEntry) {
345
+ function parseFixedLengthArrayENUM(valuesData, numberOfElements, arrayCount, enumEntry) {
346
346
  var attributeValueArray = [];
347
347
  for (var index = 0; index < numberOfElements; index++) {
348
- var array = [];
349
- for (var i = 0; i < arrayCount; i++) {
350
- var value = valuesData[i];
351
- var enumObject = getEnumByValue(enumEntry, value);
352
- if (enumObject) {
353
- array.push(enumObject.name);
354
- }
355
- }
348
+ var elementOffset = arrayCount * index;
349
+ var array = getEnumsArray(valuesData, elementOffset, arrayCount, enumEntry);
356
350
  attributeValueArray.push(array);
357
351
  }
358
352
  return attributeValueArray;
359
353
  }
360
- function findPropertyTableByClass(propertyTables, schemaClassName) {
361
- for (var i = 0, len = propertyTables.length; i < len; i++) {
362
- var propertyTable = propertyTables[i];
363
- if (propertyTable.class === schemaClassName) {
364
- return propertyTable;
354
+ function getEnumsArray(valuesData, offset, count, enumEntry) {
355
+ var array = [];
356
+ for (var i = 0; i < count; i++) {
357
+ if (valuesData instanceof BigInt64Array || valuesData instanceof BigUint64Array) {
358
+ array.push('');
359
+ } else {
360
+ var value = valuesData[offset + i];
361
+ var enumObject = getEnumByValue(enumEntry, value);
362
+ if (enumObject) {
363
+ array.push(enumObject.name);
364
+ } else {
365
+ array.push('');
366
+ }
365
367
  }
366
368
  }
367
- return null;
369
+ return array;
368
370
  }
369
371
  function getEnumByValue(enumEntry, value) {
370
372
  var _iterator4 = _createForOfIteratorHelper(enumEntry.values),
@@ -1 +1 @@
1
- {"version":3,"file":"EXT_structural_metadata.js","names":["_gltfScenegraph","require","_dataProcessing","_createForOfIteratorHelper","o","allowArrayLike","it","Symbol","iterator","Array","isArray","_unsupportedIterableToArray","length","i","F","s","n","done","value","e","_e","f","TypeError","normalCompletion","didErr","err","call","step","next","_e2","return","minLen","_arrayLikeToArray","Object","prototype","toString","slice","constructor","name","from","test","arr","len","arr2","EXT_STRUCTURAL_METADATA_NAME","exports","decode","_x","_x2","_decode","apply","arguments","_asyncToGenerator2","default","_regenerator","mark","_callee","gltfData","options","scenegraph","wrap","_callee$","_context","prev","GLTFScenegraph","decodeExtStructuralMetadata","stop","getPropertyTablePopulated","propertyTableIndex","_extension$propertyTa","extension","getExtension","propertyTable","propertyTables","schema","processPropertyTable","Error","concat","_options$gltf","propertyTextures","json","gltf","meshes","loadImages","_iterator","_step","mesh","_iterator2","primitives","_step2","primitive","processPrimitivePropertyTextures","schemaClasses","classes","schemaName","findPropertyTableByClass","_primitive$extensions","primitiveExtension","extensions","primitivePropertyTextureIndices","_iterator3","_step3","primitivePropertyTextureIndex","propertyTexture","processPrimitivePropertyTexture","properties","dataAttributeNames","className","class","propName","_propertyTexture$prop","attributeName","textureInfoTopLevel","data","featureTextureTable","propertyData","getPrimitiveTextureData","primitivePropertyDataToAttributes","push","_schema$classes","schemaClass","numberOfElements","count","propertyName","_propertyTable$proper","classProperty","propertyTableProperty","getPropertyDataFromBinarySource","valuesBufferView","values","valuesDataBytes","getTypedArrayForBufferView","arrayOffsets","array","arrayOffsetType","getOffsetArray","stringOffsets","stringOffsetType","type","getPropertyDataNumeric","getPropertyDataString","getPropertyDataENUM","offsets","offsetType","arrayOffsetsBufferView","arrayOffsetsBytes","convertRawBufferToMetadataArray","arrayCount","elementSize","getArrayElementByteSize","componentType","elementCount","byteLength","valuesData","handleVariableLengthArrayNumeric","handleFixedLengthArrayNumeric","attributeValueArray","index","valuesDataBytesLength","arrayOffset","arrayByteSize","typedArrayOffset","stringsArray","textDecoder","TextDecoder","stringOffset","stringByteSize","stringData","subarray","stringAttribute","_schema$enums","enumType","enumEntry","enums","enumValueType","valueType","handleVariableLengthArrayENUM","handleFixedLengthArrayENUM","enumValue","enumObject","getEnumByValue","schemaClassName","_iterator4","_step4"],"sources":["../../../../src/lib/extensions/EXT_structural_metadata.ts"],"sourcesContent":["/* eslint-disable camelcase */\nimport type {GLTF, GLTFTextureInfoMetadata, GLTFMeshPrimitive} from '../types/gltf-json-schema';\nimport type {\n GLTF_EXT_structural_metadata_Schema,\n GLTF_EXT_structural_metadata_ClassProperty,\n GLTF_EXT_structural_metadata_Enum,\n GLTF_EXT_structural_metadata_EnumValue,\n GLTF_EXT_structural_metadata_PropertyTable,\n GLTF_EXT_structural_metadata,\n GLTF_EXT_structural_metadata_PropertyTexture,\n GLTF_EXT_structural_metadata_PropertyTable_Property,\n GLTF_EXT_structural_metadata_Primitive\n} from '../types/gltf-ext-structural-metadata-schema';\n\nimport type {TypedArray} from '@loaders.gl/schema';\nimport type {GLTFLoaderOptions} from '../../gltf-loader';\n\nimport {GLTFScenegraph} from '../api/gltf-scenegraph';\nimport {\n convertRawBufferToMetadataArray,\n getPrimitiveTextureData,\n primitivePropertyDataToAttributes,\n getArrayElementByteSize\n} from './data-processing';\n\nconst EXT_STRUCTURAL_METADATA_NAME = 'EXT_structural_metadata';\nexport const name = EXT_STRUCTURAL_METADATA_NAME;\n\nexport async function decode(gltfData: {json: GLTF}, options: GLTFLoaderOptions): Promise<void> {\n const scenegraph = new GLTFScenegraph(gltfData);\n decodeExtStructuralMetadata(scenegraph, options);\n}\n\n/*\n// Example of the extension.\n// See more info at https://github.com/CesiumGS/glTF/tree/3d-tiles-next/extensions/2.0/Vendor/EXT_structural_metadata\nconst extensions = {\n \"extensions\": {\n \"EXT_structural_metadata\": {\n \"schema\": {\n \"classes\": {\n \"tree\": {\n \"name\": \"Tree\",\n \"description\": \"Woody, perennial plant.\",\n \"properties\": {\n \"species\": {\n \"description\": \"Type of tree.\",\n \"type\": \"ENUM\",\n \"enumType\": \"speciesEnum\",\n \"required\": true\n },\n \"age\": {\n \"description\": \"The age of the tree, in years\",\n \"type\": \"SCALAR\",\n \"componentType\": \"UINT8\",\n \"required\": true\n }\n }\n }\n },\n \"enums\": {\n \"speciesEnum\": {\n \"name\": \"Species\",\n \"description\": \"An example enum for tree species.\",\n // valueType is not defined here. Default is \"UINT16\"\n \"values\": [\n { \"name\": \"Unspecified\", \"value\": 0 },\n { \"name\": \"Oak\", \"value\": 1 }\n ]\n }\n }\n },\n \"propertyTables\": [{\n \"name\": \"tree_survey_2021-09-29\",\n \"class\": \"tree\",\n \"count\": 10, // The number of elements in each property array (in `species`, in `age`).\n \"properties\": {\n \"species\": {\n \"values\": 0, // It's an index of the buffer view containing property values.\n },\n \"age\": {\n \"values\": 1\n }\n }\n }]\n }\n }\n}\n*/\n\n/**\n * Returns the property table populated with the data taken according to the extension schema.\n * @param {GLTFScenegraph} scenegraph - Instance of the class for structured access to GLTF data.\n * @param {number} propertyTableIndex - Index of the property table to locate.\n * @returns {GLTF_EXT_structural_metadata_PropertyTable} Property table populated with the data.\n * Throws an exception if no property table was found for propertyTableIndex provided.\n */\nexport function getPropertyTablePopulated(\n scenegraph: GLTFScenegraph,\n propertyTableIndex: number\n): GLTF_EXT_structural_metadata_PropertyTable {\n const extension: GLTF_EXT_structural_metadata | null = scenegraph.getExtension(\n EXT_STRUCTURAL_METADATA_NAME\n );\n const propertyTable = extension?.propertyTables?.[propertyTableIndex];\n if (extension?.schema && propertyTable) {\n processPropertyTable(scenegraph, extension.schema, propertyTable);\n return propertyTable;\n }\n throw new Error(\n `Incorrect data in the EXT_structural_metadata extension: no property table with index ${propertyTableIndex}`\n );\n}\n\n/**\n * Decodes feature metadata from extension\n * @param {GLTFScenegraph} scenegraph - Instance of the class for structured access to GLTF data.\n * @param {GLTFLoaderOptions} options - loader options.\n */\nfunction decodeExtStructuralMetadata(scenegraph: GLTFScenegraph, options: GLTFLoaderOptions): void {\n const extension: GLTF_EXT_structural_metadata | null = scenegraph.getExtension(\n EXT_STRUCTURAL_METADATA_NAME\n );\n if (!extension?.schema) {\n return;\n }\n\n const propertyTextures = extension.propertyTextures;\n const json = scenegraph.gltf.json;\n if (propertyTextures && json.meshes && options?.gltf?.loadImages) {\n // Iterate through all meshes/primitives.\n for (const mesh of json.meshes) {\n for (const primitive of mesh.primitives) {\n processPrimitivePropertyTextures(scenegraph, propertyTextures, primitive, extension);\n }\n }\n }\n\n const schemaClasses = extension.schema.classes;\n const propertyTables = extension.propertyTables;\n if (schemaClasses && propertyTables) {\n for (const schemaName in schemaClasses) {\n const propertyTable = findPropertyTableByClass(propertyTables, schemaName);\n if (propertyTable) {\n processPropertyTable(scenegraph, extension.schema, propertyTable);\n }\n }\n }\n}\n\n/**\n * Takes data from property textures reffered by the primitive\n * @param {GLTFScenegraph} scenegraph - Instance of the class for structured access to GLTF data.\n * @param {GLTF_EXT_structural_metadata_PropertyTexture[]} propertyTextures - propertyTexture definition taken from the top-level extention\n * @param {GLTFMeshPrimitive} primitive - Primitive object\n * @param {GLTF_EXT_structural_metadata} extension - top-level extension\n */\nfunction processPrimitivePropertyTextures(\n scenegraph: GLTFScenegraph,\n propertyTextures: GLTF_EXT_structural_metadata_PropertyTexture[],\n primitive: GLTFMeshPrimitive,\n extension: GLTF_EXT_structural_metadata\n): void {\n if (!propertyTextures) {\n return;\n }\n const primitiveExtension: GLTF_EXT_structural_metadata_Primitive = primitive.extensions?.[\n EXT_STRUCTURAL_METADATA_NAME\n ] as GLTF_EXT_structural_metadata_Primitive;\n const primitivePropertyTextureIndices = primitiveExtension?.propertyTextures;\n if (!primitivePropertyTextureIndices) {\n return;\n }\n\n for (const primitivePropertyTextureIndex of primitivePropertyTextureIndices) {\n const propertyTexture = propertyTextures[primitivePropertyTextureIndex];\n processPrimitivePropertyTexture(scenegraph, propertyTexture, primitive, extension);\n }\n}\n\n/**\n * Takes property data from the texture pointed by the primitive and appends them to `exension.data`\n * @param {GLTFScenegraph} scenegraph - Instance of the class for structured access to GLTF data.\n * @param {GLTF_EXT_structural_metadata_PropertyTexture} propertyTexture - propertyTexture definition taken from the top-level extension.\n * @param {GLTFMeshPrimitive} primitive - Primitive object\n * @param {GLTF_EXT_structural_metadata} extension - top-level extension\n */\nfunction processPrimitivePropertyTexture(\n scenegraph: GLTFScenegraph,\n propertyTexture: GLTF_EXT_structural_metadata_PropertyTexture,\n primitive: GLTFMeshPrimitive,\n extension: GLTF_EXT_structural_metadata\n): void {\n if (!propertyTexture.properties) {\n return;\n }\n\n if (!extension.dataAttributeNames) {\n extension.dataAttributeNames = [];\n }\n\n /* Iterate through all properties defined in propertyTexture, e.g. \"speed\" and \"direction\":\n {\n \"class\": \"wind\",\n \"properties\": {\n \"speed\": {\n \"index\": 0,\n \"texCoord\": 0,\n \"channels\": [0]\n },\n \"direction\": {\n \"index\": 0,\n \"texCoord\": 0,\n \"channels\": [1, 2]\n }\n }\n }\n */\n const className = propertyTexture.class;\n for (const propName in propertyTexture.properties) {\n // propName has values like \"speed\", \"direction\"\n // Make attributeName as a combination of the class name and the propertyName like \"wind_speed\" or \"wind_direction\"\n const attributeName = `${className}_${propName}`;\n const textureInfoTopLevel: GLTFTextureInfoMetadata | undefined =\n propertyTexture.properties?.[propName];\n if (!textureInfoTopLevel) {\n // eslint-disable-next-line no-continue\n continue;\n }\n\n // The data taken from all meshes/primitives (the same property, e.g. \"speed\" or \"direction\") will be combined into one array and saved in textureInfoTopLevel.data\n // Initially textureInfoTopLevel.data will be initialized with an empty array.\n if (!textureInfoTopLevel.data) {\n textureInfoTopLevel.data = [];\n }\n const featureTextureTable: number[] = textureInfoTopLevel.data as number[];\n\n const propertyData: number[] | null = getPrimitiveTextureData(\n scenegraph,\n textureInfoTopLevel,\n primitive\n );\n if (propertyData === null) {\n // eslint-disable-next-line no-continue\n continue;\n }\n primitivePropertyDataToAttributes(\n scenegraph,\n attributeName,\n propertyData,\n featureTextureTable,\n primitive\n );\n textureInfoTopLevel.data = featureTextureTable;\n extension.dataAttributeNames.push(attributeName);\n }\n}\n\n/**\n * Navigates through all properies in the property table, gets properties data,\n * and put the data to `propertyTable.data` as an array.\n * @param {GLTFScenegraph} scenegraph - Instance of the class for structured access to GLTF data.\n * @param {GLTF_EXT_structural_metadata_Schema} schema - schema object\n * @param {GLTF_EXT_structural_metadata_PropertyTable} propertyTable - propertyTable definition taken from the top-level extension\n */\nfunction processPropertyTable(\n scenegraph: GLTFScenegraph,\n schema: GLTF_EXT_structural_metadata_Schema,\n propertyTable: GLTF_EXT_structural_metadata_PropertyTable\n): void {\n const schemaClass = schema.classes?.[propertyTable.class];\n if (!schemaClass) {\n throw new Error(\n `Incorrect data in the EXT_structural_metadata extension: no schema class with name ${propertyTable.class}`\n );\n }\n\n const numberOfElements = propertyTable.count; // `propertyTable.count` is a number of elements in each property array.\n\n for (const propertyName in schemaClass.properties) {\n const classProperty = schemaClass.properties[propertyName];\n const propertyTableProperty: GLTF_EXT_structural_metadata_PropertyTable_Property | undefined =\n propertyTable.properties?.[propertyName];\n\n if (propertyTableProperty) {\n // Getting all elements (`numberOfElements`) of the array in the `propertyTableProperty`\n const data = getPropertyDataFromBinarySource(\n scenegraph,\n schema,\n classProperty,\n numberOfElements,\n propertyTableProperty\n );\n propertyTableProperty.data = data;\n }\n }\n}\n\n/**\n * Decodes properties from binary sourse based on property type.\n * @param {GLTFScenegraph} scenegraph - Instance of the class for structured access to GLTF data.\n * @param {GLTF_EXT_structural_metadata_Schema} schema - Schema object\n * @param {GLTF_EXT_structural_metadata_ClassProperty} classProperty - class property object\n * @param {GLTF_EXT_structural_metadata_PropertyTable_Property} propertyTableProperty\n * @param {number} numberOfElements - The number of elements in each property array that propertyTableProperty contains. It's a number of rows in the table.\n * @returns {string[] | number[] | string[][] | number[][]}\n */\n/* eslint complexity: [\"error\", 17]*/\nfunction getPropertyDataFromBinarySource(\n scenegraph: GLTFScenegraph,\n schema: GLTF_EXT_structural_metadata_Schema,\n classProperty: GLTF_EXT_structural_metadata_ClassProperty,\n numberOfElements: number,\n propertyTableProperty: GLTF_EXT_structural_metadata_PropertyTable_Property\n): string[] | number[] | string[][] | number[][] {\n let data: string[] | number[] | string[][] | number[][] = [];\n const valuesBufferView = propertyTableProperty.values;\n const valuesDataBytes: Uint8Array = scenegraph.getTypedArrayForBufferView(valuesBufferView);\n\n let arrayOffsets: TypedArray | null = null;\n if (\n classProperty.array &&\n // `count` is a number of array elements. May only be defined when `array` is true.\n typeof classProperty.count === 'undefined' && // If `count` is NOT defined, it's a VARIABLE-length array\n typeof propertyTableProperty.arrayOffsets !== 'undefined' && // `arrayOffsets` is an index of the buffer view containing offsets for variable-length arrays.\n typeof propertyTableProperty.arrayOffsetType !== 'undefined'\n ) {\n // Data are in a VARIABLE-length array\n arrayOffsets = getOffsetArray(\n scenegraph,\n propertyTableProperty.arrayOffsets,\n propertyTableProperty.arrayOffsetType,\n numberOfElements\n );\n }\n\n let stringOffsets: TypedArray | null = null;\n if (\n typeof propertyTableProperty.stringOffsets !== 'undefined' && // `stringOffsets` is an index of the buffer view containing offsets for strings.\n typeof propertyTableProperty.stringOffsetType !== 'undefined'\n ) {\n // Data are in a FIXED-length array\n stringOffsets = getOffsetArray(\n scenegraph,\n propertyTableProperty.stringOffsets,\n propertyTableProperty.stringOffsetType,\n numberOfElements\n );\n }\n\n switch (classProperty.type) {\n case 'SCALAR':\n case 'VEC2':\n case 'VEC3':\n case 'VEC4':\n case 'MAT2':\n case 'MAT3':\n case 'MAT4': {\n data = getPropertyDataNumeric(classProperty, numberOfElements, valuesDataBytes, arrayOffsets);\n break;\n }\n case 'BOOLEAN': {\n // TODO: implement it as soon as we have the corresponding tileset\n throw new Error(`Not implemented - classProperty.type=${classProperty.type}`);\n }\n case 'STRING': {\n data = getPropertyDataString(\n classProperty,\n numberOfElements,\n valuesDataBytes,\n arrayOffsets,\n stringOffsets\n );\n break;\n }\n case 'ENUM': {\n data = getPropertyDataENUM(\n schema,\n classProperty,\n numberOfElements,\n valuesDataBytes,\n arrayOffsets\n );\n break;\n }\n default:\n throw new Error(`Unknown classProperty type ${classProperty.type}`);\n }\n\n return data;\n}\n\n/**\n * Gets offset array from `arrayOffsets` or `stringOffsets`.\n * @param {GLTFScenegraph} scenegraph - Instance of the class for structured access to GLTF data.\n * @param {number} offsets - Buffer view index\n * @param offsetType - The type of values in `arrayOffsets` or `stringOffsets`.\n * @param {number} numberOfElements - The number of elements in each property array.\n * @returns {TypedArray}\n */\nfunction getOffsetArray(\n scenegraph: GLTFScenegraph,\n offsets: number,\n offsetType: 'UINT8' | 'UINT16' | 'UINT32' | 'UINT64',\n numberOfElements: number\n): TypedArray {\n const arrayOffsetsBufferView = offsets;\n const arrayOffsetsBytes = scenegraph.getTypedArrayForBufferView(arrayOffsetsBufferView);\n\n const arrayOffsets = convertRawBufferToMetadataArray(\n arrayOffsetsBytes,\n 'SCALAR', // offsets consist of ONE component\n offsetType,\n numberOfElements + 1 // The number of offsets is equal to the property table `count` plus one.\n );\n return arrayOffsets;\n}\n\n/**\n * Decodes properties of SCALAR, VEC-N, MAT-N types from binary sourse.\n * @param {GLTF_EXT_structural_metadata_ClassProperty} classProperty - class property object\n * @param {number} numberOfElements - The number of elements in each property array that propertyTableProperty contains. It's a number of rows in the table.\n * @param {Uint8Array} valuesDataBytes - data taken from values property of the property table property.\n * @param {TypedArray | null} arrayOffsets - offsets for variable-length arrays. It's null for fixed-length arrays or scalar types.\n * @returns {number[] | number[][]}\n */\nfunction getPropertyDataNumeric(\n classProperty: GLTF_EXT_structural_metadata_ClassProperty,\n numberOfElements: number,\n valuesDataBytes: Uint8Array,\n arrayOffsets: TypedArray | null\n): number[] | number[][] {\n const isArray = classProperty.array;\n const arrayCount = classProperty.count;\n\n const elementSize = getArrayElementByteSize(classProperty.type, classProperty.componentType);\n const elementCount = valuesDataBytes.byteLength / elementSize;\n\n let valuesData: TypedArray;\n if (classProperty.componentType) {\n valuesData = convertRawBufferToMetadataArray(\n valuesDataBytes,\n classProperty.type,\n classProperty.componentType, // The datatype of the element's components. Only applicable to `SCALAR`, `VECN`, and `MATN` types.\n elementCount\n );\n } else {\n // The spec doesn't provide any info what to do if componentType is not set.\n valuesData = valuesDataBytes;\n }\n\n if (isArray) {\n if (arrayOffsets) {\n // VARIABLE-length array\n return handleVariableLengthArrayNumeric(\n valuesData,\n numberOfElements,\n arrayOffsets,\n valuesDataBytes.length,\n elementSize\n );\n }\n if (arrayCount) {\n // FIXED-length array\n return handleFixedLengthArrayNumeric(valuesData, numberOfElements, arrayCount);\n }\n return [];\n }\n\n // Single value (not an array)\n const attributeValueArray: number[] = [];\n for (let index = 0; index < numberOfElements; index++) {\n const value = valuesData[index];\n attributeValueArray.push(value);\n }\n return attributeValueArray;\n}\n\nfunction handleVariableLengthArrayNumeric(\n valuesData: TypedArray,\n numberOfElements: number,\n arrayOffsets: TypedArray,\n valuesDataBytesLength: number,\n elementSize: number\n) {\n const attributeValueArray: number[][] = [];\n for (let index = 0; index < numberOfElements; index++) {\n const array: number[] = [];\n const arrayOffset = arrayOffsets[index];\n const arrayByteSize = arrayOffsets[index + 1] - arrayOffsets[index];\n if (arrayByteSize + arrayOffset <= valuesDataBytesLength) {\n const typedArrayOffset = arrayOffset / elementSize;\n const elementCount = arrayByteSize / elementSize;\n for (let i = 0; i < elementCount; i++) {\n const value = valuesData[typedArrayOffset + i];\n array.push(value);\n }\n }\n attributeValueArray.push(array);\n }\n return attributeValueArray;\n}\n\nfunction handleFixedLengthArrayNumeric(\n valuesData: TypedArray,\n numberOfElements: number,\n arrayCount: number\n) {\n const attributeValueArray: number[][] = [];\n for (let index = 0; index < numberOfElements; index++) {\n const array: number[] = [];\n for (let i = 0; i < arrayCount; i++) {\n const value = valuesData[i];\n array.push(value);\n }\n attributeValueArray.push(array);\n }\n return attributeValueArray;\n}\n\n/**\n * Decodes properties of string type from binary sourse.\n * @param {GLTF_EXT_structural_metadata_ClassProperty} classProperty - class property object\n * @param {number} numberOfElements - The number of elements in each property array that propertyTableProperty contains. It's a number of rows in the table.\n * @param {Uint8Array} valuesDataBytes - data taken from values property of the property table property.\n * @param {TypedArray | null} arrayOffsets - offsets for variable-length arrays. It's null for fixed-length arrays or scalar types.\n * @param {TypedArray | null} stringOffsets - index of the buffer view containing offsets for strings. It should be available for string type.\n * @returns {string[] | string[][]}\n */\nfunction getPropertyDataString(\n classProperty: GLTF_EXT_structural_metadata_ClassProperty,\n numberOfElements: number,\n valuesDataBytes: Uint8Array,\n arrayOffsets: TypedArray | null,\n stringOffsets: TypedArray | null\n): string[] | string[][] {\n if (arrayOffsets) {\n // TODO: implement it as soon as we have the corresponding tileset\n throw new Error(`Not implemented - classProperty.type=${classProperty.type}`);\n }\n\n if (stringOffsets) {\n const stringsArray: string[] = [];\n const textDecoder = new TextDecoder('utf8');\n\n let stringOffset = 0;\n for (let index = 0; index < numberOfElements; index++) {\n const stringByteSize = stringOffsets[index + 1] - stringOffsets[index];\n\n if (stringByteSize + stringOffset <= valuesDataBytes.length) {\n const stringData = valuesDataBytes.subarray(stringOffset, stringByteSize + stringOffset);\n const stringAttribute = textDecoder.decode(stringData);\n\n stringsArray.push(stringAttribute);\n stringOffset += stringByteSize;\n }\n }\n\n return stringsArray;\n }\n return [];\n}\n\n/**\n * Decodes properties of enum type from binary sourse.\n * @param {GLTF_EXT_structural_metadata_Schema} schema - schema object\n * @param {GLTF_EXT_structural_metadata_ClassProperty} classProperty - class property object\n * @param {number} numberOfElements - The number of elements in each property array that propertyTableProperty contains. It's a number of rows in the table.\n * @param {Uint8Array} valuesDataBytes - data taken from values property of the property table property.\n * @param {TypedArray | null} arrayOffsets - offsets for variable-length arrays. It's null for fixed-length arrays or scalar types.\n * @returns {string[] | string[][]}\n */\nfunction getPropertyDataENUM(\n schema: GLTF_EXT_structural_metadata_Schema,\n classProperty: GLTF_EXT_structural_metadata_ClassProperty,\n numberOfElements: number,\n valuesDataBytes: Uint8Array,\n arrayOffsets: TypedArray | null\n): string[] | string[][] {\n const data: string[] = [];\n\n const isArray = classProperty.array;\n const arrayCount = classProperty.count;\n\n const enumType = classProperty.enumType;\n // Enum ID as declared in the `enums` dictionary. Required when `type` is `ENUM`.\n if (!enumType) {\n throw new Error(\n 'Incorrect data in the EXT_structural_metadata extension: classProperty.enumType is not set for type ENUM'\n );\n }\n\n const enumEntry: GLTF_EXT_structural_metadata_Enum | undefined = schema.enums?.[enumType];\n if (!enumEntry) {\n throw new Error(\n `Incorrect data in the EXT_structural_metadata extension: schema.enums does't contain ${enumType}`\n );\n }\n\n const enumValueType = enumEntry.valueType || 'UINT16';\n const elementSize = getArrayElementByteSize(classProperty.type, enumValueType);\n const elementCount = valuesDataBytes.byteLength / elementSize;\n const valuesData: TypedArray = convertRawBufferToMetadataArray(\n valuesDataBytes,\n classProperty.type,\n enumValueType,\n elementCount\n );\n\n if (isArray) {\n if (arrayOffsets) {\n // VARIABLE-length array\n return handleVariableLengthArrayENUM(\n valuesData,\n numberOfElements,\n arrayOffsets,\n valuesDataBytes.length,\n elementSize,\n enumEntry\n );\n }\n if (arrayCount) {\n // FIXED-length array\n return handleFixedLengthArrayENUM(valuesData, numberOfElements, arrayCount, enumEntry);\n }\n return [];\n }\n\n // Single value (not an array)\n for (let index = 0; index < numberOfElements; index++) {\n const enumValue = valuesData[index];\n const enumObject = getEnumByValue(enumEntry, enumValue);\n if (enumObject) {\n data.push(enumObject.name);\n }\n }\n\n return data;\n}\n\n/* eslint max-params: [\"error\", 6]*/\nfunction handleVariableLengthArrayENUM(\n valuesData: TypedArray,\n numberOfElements: number,\n arrayOffsets: TypedArray,\n valuesDataBytesLength: number,\n elementSize: number,\n enumEntry: GLTF_EXT_structural_metadata_Enum\n) {\n const attributeValueArray: string[][] = [];\n for (let index = 0; index < numberOfElements; index++) {\n const array: string[] = [];\n const arrayOffset = arrayOffsets[index];\n const arrayByteSize = arrayOffsets[index + 1] - arrayOffsets[index];\n if (arrayByteSize + arrayOffset <= valuesDataBytesLength) {\n const typedArrayOffset = arrayOffset / elementSize;\n const elementCount = arrayByteSize / elementSize;\n for (let i = 0; i < elementCount; i++) {\n const value = valuesData[typedArrayOffset + i];\n\n const enumObject = getEnumByValue(enumEntry, value);\n if (enumObject) {\n array.push(enumObject.name);\n }\n }\n }\n attributeValueArray.push(array);\n }\n return attributeValueArray;\n}\n\nfunction handleFixedLengthArrayENUM(\n valuesData: TypedArray,\n numberOfElements: number,\n arrayCount: number,\n enumEntry: GLTF_EXT_structural_metadata_Enum\n) {\n const attributeValueArray: string[][] = [];\n for (let index = 0; index < numberOfElements; index++) {\n const array: string[] = [];\n for (let i = 0; i < arrayCount; i++) {\n const value = valuesData[i];\n\n const enumObject = getEnumByValue(enumEntry, value);\n if (enumObject) {\n array.push(enumObject.name);\n }\n }\n attributeValueArray.push(array);\n }\n return attributeValueArray;\n}\n/**\n * Find the property table by class name.\n * @param {GLTF_EXT_structural_metadata_PropertyTable[]} propertyTables\n * @param {string} schemaClassName\n */\nfunction findPropertyTableByClass(\n propertyTables: GLTF_EXT_structural_metadata_PropertyTable[],\n schemaClassName: string\n): GLTF_EXT_structural_metadata_PropertyTable | null {\n for (let i = 0, len = propertyTables.length; i < len; i++) {\n const propertyTable = propertyTables[i];\n\n if (propertyTable.class === schemaClassName) {\n return propertyTable;\n }\n }\n\n return null;\n}\n\n/**\n * Looks up ENUM whose `value` property matches the specified number in the parameter `value`.\n * @param {GLTF_EXT_structural_metadata_Enum} enumEntry - ENUM entry containing the array of possible enums.\n * @param {number} value - the value of the ENUM to locate.\n * @returns {GLTF_EXT_structural_metadata_EnumValue | null} ENUM matcihng the specified value or null of no ENUM object was found.\n */\nfunction getEnumByValue(\n enumEntry: GLTF_EXT_structural_metadata_Enum,\n value: number\n): GLTF_EXT_structural_metadata_EnumValue | null {\n for (const enumValue of enumEntry.values) {\n if (enumValue.value === value) {\n return enumValue;\n }\n }\n\n return null;\n}\n"],"mappings":"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"}
1
+ {"version":3,"file":"EXT_structural_metadata.js","names":["_gltfScenegraph","require","_dTilesUtils","_createForOfIteratorHelper","o","allowArrayLike","it","Symbol","iterator","Array","isArray","_unsupportedIterableToArray","length","i","F","s","n","done","value","e","_e","f","TypeError","normalCompletion","didErr","err","call","step","next","_e2","return","minLen","_arrayLikeToArray","Object","prototype","toString","slice","constructor","name","from","test","arr","len","arr2","EXT_STRUCTURAL_METADATA_NAME","exports","decode","_x","_x2","_decode","apply","arguments","_asyncToGenerator2","default","_regenerator","mark","_callee","gltfData","options","scenegraph","wrap","_callee$","_context","prev","GLTFScenegraph","decodeExtStructuralMetadata","stop","getPropertyTablePopulated","propertyTableIndex","_extension$propertyTa","extension","getExtension","propertyTable","propertyTables","schema","processPropertyTable","Error","concat","_options$gltf","propertyTextures","json","gltf","meshes","loadImages","_iterator","_step","mesh","_iterator2","primitives","_step2","primitive","processPrimitivePropertyTextures","schemaClasses","classes","schemaName","findPropertyTableByClass","schemaClassName","class","_primitive$extensions","primitiveExtension","extensions","primitivePropertyTextureIndices","_iterator3","_step3","primitivePropertyTextureIndex","propertyTexture","processPrimitivePropertyTexture","properties","dataAttributeNames","className","propName","_propertyTexture$prop","attributeName","textureInfoTopLevel","data","featureTextureTable","propertyData","getPrimitiveTextureData","primitivePropertyDataToAttributes","push","_schema$classes","schemaClass","numberOfElements","count","propertyName","_propertyTable$proper","classProperty","propertyTableProperty","getPropertyDataFromBinarySource","valuesBufferView","values","valuesDataBytes","getTypedArrayForBufferView","arrayOffsets","getArrayOffsetsForProperty","stringOffsets","getStringOffsetsForProperty","type","getPropertyDataNumeric","getPropertyDataString","getPropertyDataENUM","array","arrayOffsetType","getOffsetsForProperty","stringOffsetType","arrayCount","elementSize","getArrayElementByteSize","componentType","elementCount","byteLength","valuesData","convertRawBufferToMetadataArray","parseVariableLengthArrayNumeric","parseFixedLengthArrayNumeric","valuesDataBytesLength","valueSize","attributeValueArray","index","arrayOffset","arrayByteSize","typedArrayOffset","elementOffset","stringsArray","textDecoder","TextDecoder","stringOffset","stringByteSize","stringData","subarray","stringAttribute","_schema$enums","enumType","enumEntry","enums","enumValueType","valueType","parseVariableLengthArrayENUM","parseFixedLengthArrayENUM","getEnumsArray","params","offset","BigInt64Array","BigUint64Array","enumObject","getEnumByValue","_iterator4","_step4","enumValue"],"sources":["../../../../src/lib/extensions/EXT_structural_metadata.ts"],"sourcesContent":["/* eslint-disable camelcase */\nimport type {BigTypedArray, TypedArray} from '@loaders.gl/schema';\nimport type {GLTF, GLTFTextureInfoMetadata, GLTFMeshPrimitive} from '../types/gltf-json-schema';\nimport type {\n GLTF_EXT_structural_metadata_Schema,\n GLTF_EXT_structural_metadata_ClassProperty,\n GLTF_EXT_structural_metadata_Enum,\n GLTF_EXT_structural_metadata_EnumValue,\n GLTF_EXT_structural_metadata_PropertyTable,\n GLTF_EXT_structural_metadata,\n GLTF_EXT_structural_metadata_PropertyTexture,\n GLTF_EXT_structural_metadata_PropertyTable_Property,\n GLTF_EXT_structural_metadata_Primitive\n} from '../types/gltf-ext-structural-metadata-schema';\nimport type {GLTFLoaderOptions} from '../../gltf-loader';\n\nimport {GLTFScenegraph} from '../api/gltf-scenegraph';\nimport {\n convertRawBufferToMetadataArray,\n getPrimitiveTextureData,\n primitivePropertyDataToAttributes,\n getArrayElementByteSize,\n NumericComponentType,\n getOffsetsForProperty\n} from './utils/3d-tiles-utils';\n\nconst EXT_STRUCTURAL_METADATA_NAME = 'EXT_structural_metadata';\nexport const name = EXT_STRUCTURAL_METADATA_NAME;\n\nexport async function decode(gltfData: {json: GLTF}, options: GLTFLoaderOptions): Promise<void> {\n const scenegraph = new GLTFScenegraph(gltfData);\n decodeExtStructuralMetadata(scenegraph, options);\n}\n\n/*\n// Example of the extension.\n// See more info at https://github.com/CesiumGS/glTF/tree/3d-tiles-next/extensions/2.0/Vendor/EXT_structural_metadata\nconst extensions = {\n \"extensions\": {\n \"EXT_structural_metadata\": {\n \"schema\": {\n \"classes\": {\n \"tree\": {\n \"name\": \"Tree\",\n \"description\": \"Woody, perennial plant.\",\n \"properties\": {\n \"species\": {\n \"description\": \"Type of tree.\",\n \"type\": \"ENUM\",\n \"enumType\": \"speciesEnum\",\n \"required\": true\n },\n \"age\": {\n \"description\": \"The age of the tree, in years\",\n \"type\": \"SCALAR\",\n \"componentType\": \"UINT8\",\n \"required\": true\n }\n }\n }\n },\n \"enums\": {\n \"speciesEnum\": {\n \"name\": \"Species\",\n \"description\": \"An example enum for tree species.\",\n // valueType is not defined here. Default is \"UINT16\"\n \"values\": [\n { \"name\": \"Unspecified\", \"value\": 0 },\n { \"name\": \"Oak\", \"value\": 1 }\n ]\n }\n }\n },\n \"propertyTables\": [{\n \"name\": \"tree_survey_2021-09-29\",\n \"class\": \"tree\",\n \"count\": 10, // The number of elements in each property array (in `species`, in `age`).\n \"properties\": {\n \"species\": {\n \"values\": 0, // It's an index of the buffer view containing property values.\n },\n \"age\": {\n \"values\": 1\n }\n }\n }]\n }\n }\n}\n*/\n\n/**\n * Returns the property table populated with the data taken according to the extension schema.\n * @param scenegraph - Instance of the class for structured access to GLTF data.\n * @param propertyTableIndex - Index of the property table to locate.\n * @returns Property table populated with the data.\n * Throws an exception if no property table was found for propertyTableIndex provided.\n */\nexport function getPropertyTablePopulated(\n scenegraph: GLTFScenegraph,\n propertyTableIndex: number\n): GLTF_EXT_structural_metadata_PropertyTable {\n const extension: GLTF_EXT_structural_metadata | null = scenegraph.getExtension(\n EXT_STRUCTURAL_METADATA_NAME\n );\n const propertyTable = extension?.propertyTables?.[propertyTableIndex];\n if (extension?.schema && propertyTable) {\n processPropertyTable(scenegraph, extension.schema, propertyTable);\n return propertyTable;\n }\n throw new Error(\n `Incorrect data in the EXT_structural_metadata extension: no property table with index ${propertyTableIndex}`\n );\n}\n\n/**\n * Decodes feature metadata from extension\n * @param scenegraph - Instance of the class for structured access to GLTF data.\n * @param options - loader options.\n */\nfunction decodeExtStructuralMetadata(scenegraph: GLTFScenegraph, options: GLTFLoaderOptions): void {\n const extension: GLTF_EXT_structural_metadata | null = scenegraph.getExtension(\n EXT_STRUCTURAL_METADATA_NAME\n );\n if (!extension?.schema) {\n return;\n }\n\n const propertyTextures = extension.propertyTextures;\n const json = scenegraph.gltf.json;\n if (propertyTextures && json.meshes && options?.gltf?.loadImages) {\n // Iterate through all meshes/primitives.\n for (const mesh of json.meshes) {\n for (const primitive of mesh.primitives) {\n processPrimitivePropertyTextures(scenegraph, propertyTextures, primitive, extension);\n }\n }\n }\n\n const schemaClasses = extension.schema.classes;\n const propertyTables = extension.propertyTables;\n if (schemaClasses && propertyTables) {\n for (const schemaName in schemaClasses) {\n const propertyTable = findPropertyTableByClass(propertyTables, schemaName);\n if (propertyTable) {\n processPropertyTable(scenegraph, extension.schema, propertyTable);\n }\n }\n }\n}\n\n/**\n * Find the property table by class name.\n * @param propertyTables - propertyTable definition taken from the top-level extension\n * @param schemaClassName - class name in the extension schema\n */\nfunction findPropertyTableByClass(\n propertyTables: GLTF_EXT_structural_metadata_PropertyTable[],\n schemaClassName: string\n): GLTF_EXT_structural_metadata_PropertyTable | null {\n for (let i = 0, len = propertyTables.length; i < len; i++) {\n const propertyTable = propertyTables[i];\n\n if (propertyTable.class === schemaClassName) {\n return propertyTable;\n }\n }\n\n return null;\n}\n\n/**\n * Takes data from property textures reffered by the primitive\n * @param scenegraph - Instance of the class for structured access to GLTF data.\n * @param propertyTextures - propertyTexture definition taken from the top-level extention\n * @param primitive - Primitive object\n * @param extension - top-level extension\n */\nfunction processPrimitivePropertyTextures(\n scenegraph: GLTFScenegraph,\n propertyTextures: GLTF_EXT_structural_metadata_PropertyTexture[],\n primitive: GLTFMeshPrimitive,\n extension: GLTF_EXT_structural_metadata\n): void {\n if (!propertyTextures) {\n return;\n }\n const primitiveExtension: GLTF_EXT_structural_metadata_Primitive = primitive.extensions?.[\n EXT_STRUCTURAL_METADATA_NAME\n ] as GLTF_EXT_structural_metadata_Primitive;\n const primitivePropertyTextureIndices = primitiveExtension?.propertyTextures;\n if (!primitivePropertyTextureIndices) {\n return;\n }\n\n for (const primitivePropertyTextureIndex of primitivePropertyTextureIndices) {\n const propertyTexture = propertyTextures[primitivePropertyTextureIndex];\n processPrimitivePropertyTexture(scenegraph, propertyTexture, primitive, extension);\n }\n}\n\n/**\n * Takes property data from the texture pointed by the primitive and appends them to `exension.data`\n * @param scenegraph - Instance of the class for structured access to GLTF data.\n * @param propertyTexture - propertyTexture definition taken from the top-level extension.\n * @param primitive - Primitive object\n * @param extension - top-level extension\n */\nfunction processPrimitivePropertyTexture(\n scenegraph: GLTFScenegraph,\n propertyTexture: GLTF_EXT_structural_metadata_PropertyTexture,\n primitive: GLTFMeshPrimitive,\n extension: GLTF_EXT_structural_metadata\n): void {\n if (!propertyTexture.properties) {\n return;\n }\n\n if (!extension.dataAttributeNames) {\n extension.dataAttributeNames = [];\n }\n\n /* Iterate through all properties defined in propertyTexture, e.g. \"speed\" and \"direction\":\n {\n \"class\": \"wind\",\n \"properties\": {\n \"speed\": {\n \"index\": 0,\n \"texCoord\": 0,\n \"channels\": [0]\n },\n \"direction\": {\n \"index\": 0,\n \"texCoord\": 0,\n \"channels\": [1, 2]\n }\n }\n }\n */\n const className = propertyTexture.class;\n for (const propName in propertyTexture.properties) {\n // propName has values like \"speed\", \"direction\"\n // Make attributeName as a combination of the class name and the propertyName like \"wind_speed\" or \"wind_direction\"\n const attributeName = `${className}_${propName}`;\n const textureInfoTopLevel: GLTFTextureInfoMetadata | undefined =\n propertyTexture.properties?.[propName];\n if (!textureInfoTopLevel) {\n // eslint-disable-next-line no-continue\n continue;\n }\n\n // The data taken from all meshes/primitives (the same property, e.g. \"speed\" or \"direction\") will be combined into one array and saved in textureInfoTopLevel.data\n // Initially textureInfoTopLevel.data will be initialized with an empty array.\n if (!textureInfoTopLevel.data) {\n textureInfoTopLevel.data = [];\n }\n const featureTextureTable: number[] = textureInfoTopLevel.data as number[];\n\n const propertyData: number[] | null = getPrimitiveTextureData(\n scenegraph,\n textureInfoTopLevel,\n primitive\n );\n if (propertyData === null) {\n // eslint-disable-next-line no-continue\n continue;\n }\n primitivePropertyDataToAttributes(\n scenegraph,\n attributeName,\n propertyData,\n featureTextureTable,\n primitive\n );\n textureInfoTopLevel.data = featureTextureTable;\n extension.dataAttributeNames.push(attributeName);\n }\n}\n\n/**\n * Navigates through all properies in the property table, gets properties data,\n * and put the data to `propertyTable.data` as an array.\n * @param scenegraph - Instance of the class for structured access to GLTF data.\n * @param schema - schema object\n * @param propertyTable - propertyTable definition taken from the top-level extension\n */\nfunction processPropertyTable(\n scenegraph: GLTFScenegraph,\n schema: GLTF_EXT_structural_metadata_Schema,\n propertyTable: GLTF_EXT_structural_metadata_PropertyTable\n): void {\n const schemaClass = schema.classes?.[propertyTable.class];\n if (!schemaClass) {\n throw new Error(\n `Incorrect data in the EXT_structural_metadata extension: no schema class with name ${propertyTable.class}`\n );\n }\n\n const numberOfElements = propertyTable.count; // `propertyTable.count` is a number of elements in each property array.\n\n for (const propertyName in schemaClass.properties) {\n const classProperty = schemaClass.properties[propertyName];\n const propertyTableProperty: GLTF_EXT_structural_metadata_PropertyTable_Property | undefined =\n propertyTable.properties?.[propertyName];\n\n if (propertyTableProperty) {\n // Getting all elements (`numberOfElements`) of the array in the `propertyTableProperty`\n const data = getPropertyDataFromBinarySource(\n scenegraph,\n schema,\n classProperty,\n numberOfElements,\n propertyTableProperty\n );\n propertyTableProperty.data = data;\n }\n }\n}\n\n/**\n * Decodes a propertyTable column from binary source based on property type\n * @param scenegraph - Instance of the class for structured access to GLTF data.\n * @param schema - Schema object\n * @param classProperty - class property object\n * @param numberOfElements - The number of elements in each property array that propertyTableProperty contains. It's a number of rows in the table.\n * @param propertyTableProperty - propertyTable's property metadata\n * @returns {string[] | number[] | string[][] | number[][]}\n */\nfunction getPropertyDataFromBinarySource(\n scenegraph: GLTFScenegraph,\n schema: GLTF_EXT_structural_metadata_Schema,\n classProperty: GLTF_EXT_structural_metadata_ClassProperty,\n numberOfElements: number,\n propertyTableProperty: GLTF_EXT_structural_metadata_PropertyTable_Property\n): string[] | BigTypedArray | string[][] | BigTypedArray[] {\n let data: string[] | BigTypedArray | string[][] | BigTypedArray[] = [];\n const valuesBufferView = propertyTableProperty.values;\n const valuesDataBytes: Uint8Array = scenegraph.getTypedArrayForBufferView(valuesBufferView);\n\n const arrayOffsets = getArrayOffsetsForProperty(\n scenegraph,\n classProperty,\n propertyTableProperty,\n numberOfElements\n );\n const stringOffsets = getStringOffsetsForProperty(\n scenegraph,\n propertyTableProperty,\n numberOfElements\n );\n\n switch (classProperty.type) {\n case 'SCALAR':\n case 'VEC2':\n case 'VEC3':\n case 'VEC4':\n case 'MAT2':\n case 'MAT3':\n case 'MAT4': {\n data = getPropertyDataNumeric(classProperty, numberOfElements, valuesDataBytes, arrayOffsets);\n break;\n }\n case 'BOOLEAN': {\n // TODO: implement it as soon as we have the corresponding tileset\n throw new Error(`Not implemented - classProperty.type=${classProperty.type}`);\n }\n case 'STRING': {\n data = getPropertyDataString(\n classProperty,\n numberOfElements,\n valuesDataBytes,\n arrayOffsets,\n stringOffsets\n );\n break;\n }\n case 'ENUM': {\n data = getPropertyDataENUM(\n schema,\n classProperty,\n numberOfElements,\n valuesDataBytes,\n arrayOffsets\n );\n break;\n }\n default:\n throw new Error(`Unknown classProperty type ${classProperty.type}`);\n }\n\n return data;\n}\n\n/**\n * Parse propertyTable.property.arrayOffsets that are offsets of sub-arrays in a flatten array of values\n * @param scenegraph - Instance of the class for structured access to GLTF data.\n * @param classProperty - class property object\n * @param propertyTableProperty - propertyTable's property metadata\n * @param numberOfElements - The number of elements in each property array that propertyTableProperty contains. It's a number of rows in the table.\n * @returns typed array with offset values\n * @see https://github.com/CesiumGS/glTF/blob/2976f1183343a47a29e4059a70961371cd2fcee8/extensions/2.0/Vendor/EXT_structural_metadata/schema/propertyTable.property.schema.json#L21\n */\nfunction getArrayOffsetsForProperty(\n scenegraph: GLTFScenegraph,\n classProperty: GLTF_EXT_structural_metadata_ClassProperty,\n propertyTableProperty: GLTF_EXT_structural_metadata_PropertyTable_Property,\n numberOfElements: number\n): TypedArray | null {\n if (\n classProperty.array &&\n // `count` is a number of array elements. May only be defined when `array` is true.\n // If `count` is NOT defined, it's a VARIABLE-length array\n typeof classProperty.count === 'undefined' &&\n // `arrayOffsets` is an index of the buffer view containing offsets for variable-length arrays.\n typeof propertyTableProperty.arrayOffsets !== 'undefined' &&\n typeof propertyTableProperty.arrayOffsetType !== 'undefined'\n ) {\n // Data are in a VARIABLE-length array\n return getOffsetsForProperty(\n scenegraph,\n propertyTableProperty.arrayOffsets,\n propertyTableProperty.arrayOffsetType,\n numberOfElements\n );\n }\n return null;\n}\n\n/**\n * Parse propertyTable.property.stringOffsets\n * @param scenegraph - Instance of the class for structured access to GLTF data\n * @param propertyTableProperty - propertyTable's property metadata\n * @param numberOfElements - The number of elements in each property array that propertyTableProperty contains. It's a number of rows in the table\n * @returns typed array with offset values\n * @see https://github.com/CesiumGS/glTF/blob/2976f1183343a47a29e4059a70961371cd2fcee8/extensions/2.0/Vendor/EXT_structural_metadata/schema/propertyTable.property.schema.json#L29C10-L29C23\n */\nfunction getStringOffsetsForProperty(\n scenegraph: GLTFScenegraph,\n propertyTableProperty: GLTF_EXT_structural_metadata_PropertyTable_Property,\n numberOfElements: number\n): TypedArray | null {\n if (\n typeof propertyTableProperty.stringOffsets !== 'undefined' && // `stringOffsets` is an index of the buffer view containing offsets for strings.\n typeof propertyTableProperty.stringOffsetType !== 'undefined'\n ) {\n // Data are in a FIXED-length array\n return getOffsetsForProperty(\n scenegraph,\n propertyTableProperty.stringOffsets,\n propertyTableProperty.stringOffsetType,\n numberOfElements\n );\n }\n return null;\n}\n\n/**\n * Decodes properties of SCALAR, VEC-N, MAT-N types from binary sourse.\n * @param classProperty - class property object\n * @param numberOfElements - The number of elements in each property array that propertyTableProperty contains. It's a number of rows in the table.\n * @param valuesDataBytes - data taken from values property of the property table property.\n * @param arrayOffsets - offsets for variable-length arrays. It's null for fixed-length arrays or scalar types.\n * @returns property values in a typed array or in an array of typed arrays\n */\nfunction getPropertyDataNumeric(\n classProperty: GLTF_EXT_structural_metadata_ClassProperty,\n numberOfElements: number,\n valuesDataBytes: Uint8Array,\n arrayOffsets: TypedArray | null\n): BigTypedArray | BigTypedArray[] {\n const isArray = classProperty.array;\n const arrayCount = classProperty.count;\n\n const elementSize = getArrayElementByteSize(classProperty.type, classProperty.componentType);\n const elementCount = valuesDataBytes.byteLength / elementSize;\n\n let valuesData: BigTypedArray | null;\n if (classProperty.componentType) {\n valuesData = convertRawBufferToMetadataArray(\n valuesDataBytes,\n classProperty.type,\n // The datatype of the element's components. Only applicable to `SCALAR`, `VECN`, and `MATN` types.\n classProperty.componentType as NumericComponentType,\n elementCount\n );\n if (!valuesData) {\n valuesData = valuesDataBytes;\n }\n } else {\n // The spec doesn't provide any info what to do if componentType is not set.\n valuesData = valuesDataBytes;\n }\n\n if (isArray) {\n if (arrayOffsets) {\n // VARIABLE-length array\n return parseVariableLengthArrayNumeric(\n valuesData,\n numberOfElements,\n arrayOffsets,\n valuesDataBytes.length,\n elementSize\n );\n }\n if (arrayCount) {\n // FIXED-length array\n return parseFixedLengthArrayNumeric(valuesData, numberOfElements, arrayCount);\n }\n return [];\n }\n\n return valuesData;\n}\n\n/**\n * Parse variable-length array data.\n * In this case every value of the property in the table will be an array\n * of arbitrary length\n * @param valuesData - values in a flat typed array\n * @param numberOfElements - number of rows in the property table\n * @param arrayOffsets - offsets of nested arrays in the flat values array\n * @param valuesDataBytesLength - data byte length\n * @param valueSize - value size in bytes\n * @returns array of typed arrays\n */\nfunction parseVariableLengthArrayNumeric(\n valuesData: BigTypedArray,\n numberOfElements: number,\n arrayOffsets: TypedArray,\n valuesDataBytesLength: number,\n valueSize: number\n): BigTypedArray[] {\n const attributeValueArray: BigTypedArray[] = [];\n for (let index = 0; index < numberOfElements; index++) {\n const arrayOffset = arrayOffsets[index];\n const arrayByteSize = arrayOffsets[index + 1] - arrayOffsets[index];\n if (arrayByteSize + arrayOffset > valuesDataBytesLength) {\n break;\n }\n const typedArrayOffset = arrayOffset / valueSize;\n const elementCount = arrayByteSize / valueSize;\n attributeValueArray.push(valuesData.slice(typedArrayOffset, typedArrayOffset + elementCount));\n }\n return attributeValueArray;\n}\n\n/**\n * Parse fixed-length array data\n * In this case every value of the property in the table will be an array\n * of constant length equal to `arrayCount`\n * @param valuesData - values in a flat typed array\n * @param numberOfElements - number of rows in the property table\n * @param arrayCount - nested arrays length\n * @returns array of typed arrays\n */\nfunction parseFixedLengthArrayNumeric(\n valuesData: BigTypedArray,\n numberOfElements: number,\n arrayCount: number\n): BigTypedArray[] {\n const attributeValueArray: BigTypedArray[] = [];\n for (let index = 0; index < numberOfElements; index++) {\n const elementOffset = index * arrayCount;\n attributeValueArray.push(valuesData.slice(elementOffset, elementOffset + arrayCount));\n }\n return attributeValueArray;\n}\n\n/**\n * Decodes properties of string type from binary source.\n * @param classProperty - class property object\n * @param numberOfElements - The number of elements in each property array that propertyTableProperty contains. It's a number of rows in the table.\n * @param valuesDataBytes - data taken from values property of the property table property.\n * @param arrayOffsets - offsets for variable-length arrays. It's null for fixed-length arrays or scalar types.\n * @param stringOffsets - index of the buffer view containing offsets for strings. It should be available for string type.\n * @returns string property values\n */\nfunction getPropertyDataString(\n classProperty: GLTF_EXT_structural_metadata_ClassProperty,\n numberOfElements: number,\n valuesDataBytes: Uint8Array,\n arrayOffsets: TypedArray | null,\n stringOffsets: TypedArray | null\n): string[] | string[][] {\n if (arrayOffsets) {\n // TODO: implement it as soon as we have the corresponding tileset\n throw new Error(`Not implemented - classProperty.type=${classProperty.type}`);\n }\n\n if (stringOffsets) {\n const stringsArray: string[] = [];\n const textDecoder = new TextDecoder('utf8');\n\n let stringOffset = 0;\n for (let index = 0; index < numberOfElements; index++) {\n const stringByteSize = stringOffsets[index + 1] - stringOffsets[index];\n\n if (stringByteSize + stringOffset <= valuesDataBytes.length) {\n const stringData = valuesDataBytes.subarray(stringOffset, stringByteSize + stringOffset);\n const stringAttribute = textDecoder.decode(stringData);\n\n stringsArray.push(stringAttribute);\n stringOffset += stringByteSize;\n }\n }\n\n return stringsArray;\n }\n return [];\n}\n\n/**\n * Decodes properties of enum type from binary source.\n * @param schema - schema object\n * @param classProperty - class property object\n * @param numberOfElements - The number of elements in each property array that propertyTableProperty contains. It's a number of rows in the table.\n * @param valuesDataBytes - data taken from values property of the property table property.\n * @param arrayOffsets - offsets for variable-length arrays. It's null for fixed-length arrays or scalar types.\n * @returns strings array of nested strings array\n */\nfunction getPropertyDataENUM(\n schema: GLTF_EXT_structural_metadata_Schema,\n classProperty: GLTF_EXT_structural_metadata_ClassProperty,\n numberOfElements: number,\n valuesDataBytes: Uint8Array,\n arrayOffsets: TypedArray | null\n): string[] | string[][] {\n const enumType = classProperty.enumType;\n // Enum ID as declared in the `enums` dictionary. Required when `type` is `ENUM`.\n if (!enumType) {\n throw new Error(\n 'Incorrect data in the EXT_structural_metadata extension: classProperty.enumType is not set for type ENUM'\n );\n }\n\n const enumEntry: GLTF_EXT_structural_metadata_Enum | undefined = schema.enums?.[enumType];\n if (!enumEntry) {\n throw new Error(\n `Incorrect data in the EXT_structural_metadata extension: schema.enums does't contain ${enumType}`\n );\n }\n\n const enumValueType = enumEntry.valueType || 'UINT16';\n const elementSize = getArrayElementByteSize(classProperty.type, enumValueType);\n const elementCount = valuesDataBytes.byteLength / elementSize;\n let valuesData: BigTypedArray | null = convertRawBufferToMetadataArray(\n valuesDataBytes,\n classProperty.type,\n enumValueType,\n elementCount\n );\n if (!valuesData) {\n valuesData = valuesDataBytes;\n }\n\n if (classProperty.array) {\n if (arrayOffsets) {\n // VARIABLE-length array\n return parseVariableLengthArrayENUM({\n valuesData,\n numberOfElements,\n arrayOffsets,\n valuesDataBytesLength: valuesDataBytes.length,\n elementSize,\n enumEntry\n });\n }\n\n const arrayCount = classProperty.count;\n if (arrayCount) {\n // FIXED-length array\n return parseFixedLengthArrayENUM(valuesData, numberOfElements, arrayCount, enumEntry);\n }\n return [];\n }\n\n // Single value (not an array)\n return getEnumsArray(valuesData, 0, numberOfElements, enumEntry);\n}\n\n/**\n * Parse variable length nested ENUM arrays\n * @param params.valuesData - values in a flat typed array\n * @param params.numberOfElements - The number of elements in each property array that propertyTableProperty contains. It's a number of rows in the table.\n * @param params.arrayOffsets - offsets for variable-length arrays. It's null for fixed-length arrays or scalar types.\n * @param params.valuesDataBytesLength - byte length of values array\n * @param params.elementSize - single element byte size\n * @param params.enumEntry - enums dictionary\n * @returns nested strings array\n */\nfunction parseVariableLengthArrayENUM(params: {\n valuesData: BigTypedArray;\n numberOfElements: number;\n arrayOffsets: TypedArray;\n valuesDataBytesLength: number;\n elementSize: number;\n enumEntry: GLTF_EXT_structural_metadata_Enum;\n}): string[][] {\n const {\n valuesData,\n numberOfElements,\n arrayOffsets,\n valuesDataBytesLength,\n elementSize,\n enumEntry\n } = params;\n const attributeValueArray: string[][] = [];\n for (let index = 0; index < numberOfElements; index++) {\n const arrayOffset = arrayOffsets[index];\n const arrayByteSize = arrayOffsets[index + 1] - arrayOffsets[index];\n if (arrayByteSize + arrayOffset > valuesDataBytesLength) {\n break;\n }\n\n const typedArrayOffset = arrayOffset / elementSize;\n const elementCount = arrayByteSize / elementSize;\n const array: string[] = getEnumsArray(valuesData, typedArrayOffset, elementCount, enumEntry);\n attributeValueArray.push(array);\n }\n return attributeValueArray;\n}\n\n/**\n * Parse fixed length ENUM arrays\n * @param valuesData - values in a flat typed array\n * @param numberOfElements - The number of elements in each property array that propertyTableProperty contains. It's a number of rows in the table.\n * @param arrayCount - nested arrays length\n * @param enumEntry - enums dictionary\n * @returns nested strings array\n */\nfunction parseFixedLengthArrayENUM(\n valuesData: BigTypedArray,\n numberOfElements: number,\n arrayCount: number,\n enumEntry: GLTF_EXT_structural_metadata_Enum\n): string[][] {\n const attributeValueArray: string[][] = [];\n for (let index = 0; index < numberOfElements; index++) {\n const elementOffset = arrayCount * index;\n const array: string[] = getEnumsArray(valuesData, elementOffset, arrayCount, enumEntry);\n attributeValueArray.push(array);\n }\n return attributeValueArray;\n}\n\n/**\n * Parse ENUM values into a string array\n * @param valuesData - values in a flat typed array\n * @param offset - offset to start parse from\n * @param count - values length to parse\n * @param enumEntry - enums dictionary\n * @returns array of string with parsed ENUM names\n */\nfunction getEnumsArray(\n valuesData: BigTypedArray,\n offset: number,\n count: number,\n enumEntry: GLTF_EXT_structural_metadata_Enum\n): string[] {\n const array: string[] = [];\n for (let i = 0; i < count; i++) {\n // At the moment we don't support BigInt. It requires additional calculations logic\n // and might be an issue in Safari\n if (valuesData instanceof BigInt64Array || valuesData instanceof BigUint64Array) {\n array.push('');\n } else {\n const value = valuesData[offset + i];\n\n const enumObject = getEnumByValue(enumEntry, value);\n if (enumObject) {\n array.push(enumObject.name);\n } else {\n array.push('');\n }\n }\n }\n return array;\n}\n\n/**\n * Looks up ENUM whose `value` property matches the specified number in the parameter `value`.\n * @param {GLTF_EXT_structural_metadata_Enum} enumEntry - ENUM entry containing the array of possible enums.\n * @param {number} value - the value of the ENUM to locate.\n * @returns {GLTF_EXT_structural_metadata_EnumValue | null} ENUM matcihng the specified value or null of no ENUM object was found.\n */\nfunction getEnumByValue(\n enumEntry: GLTF_EXT_structural_metadata_Enum,\n value: number\n): GLTF_EXT_structural_metadata_EnumValue | null {\n for (const enumValue of enumEntry.values) {\n if (enumValue.value === value) {\n return enumValue;\n }\n }\n\n return null;\n}\n"],"mappings":"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"}
@@ -12,6 +12,7 @@ var _gltfScenegraph = require("../../api/gltf-scenegraph");
12
12
  var _images = require("@loaders.gl/images");
13
13
  var _gltfUtils = require("../../gltf-utils/gltf-utils");
14
14
  var _math = require("@loaders.gl/math");
15
+ var _dTilesUtils = require("../utils/3d-tiles-utils");
15
16
  function _createForOfIteratorHelper(o, allowArrayLike) { var it = typeof Symbol !== "undefined" && o[Symbol.iterator] || o["@@iterator"]; if (!it) { if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === "number") { if (it) o = it; var i = 0; var F = function F() {}; return { s: F, n: function n() { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }, e: function e(_e) { throw _e; }, f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var normalCompletion = true, didErr = false, err; return { s: function s() { it = it.call(o); }, n: function n() { var step = it.next(); normalCompletion = step.done; return step; }, e: function e(_e2) { didErr = true; err = _e2; }, f: function f() { try { if (!normalCompletion && it.return != null) it.return(); } finally { if (didErr) throw err; } } }; }
16
17
  function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
17
18
  function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }
@@ -89,17 +90,33 @@ function handleFeatureTextureProperties(scenegraph, featureTexture, schemaClass)
89
90
  function getPropertyDataFromBinarySource(scenegraph, schemaProperty, numberOfFeatures, featureTableProperty) {
90
91
  var bufferView = featureTableProperty.bufferView;
91
92
  var dataArray = scenegraph.getTypedArrayForBufferView(bufferView);
92
- switch (schemaProperty.type) {
93
- case 'STRING':
94
- {
95
- var stringOffsetBufferView = featureTableProperty.stringOffsetBufferView;
96
- var offsetsData = scenegraph.getTypedArrayForBufferView(stringOffsetBufferView);
97
- return getStringAttributes(dataArray, offsetsData, numberOfFeatures);
98
- }
99
- default:
93
+ if (schemaProperty.type === 'STRING') {
94
+ var offsetsData = getStringOffsets(scenegraph, featureTableProperty, numberOfFeatures);
95
+ if (!offsetsData) {
96
+ return [];
97
+ }
98
+ return getStringAttributes(dataArray, offsetsData, numberOfFeatures);
99
+ } else if (isNumericProperty(schemaProperty.type)) {
100
+ return getNumericAttributes(dataArray, schemaProperty.type, numberOfFeatures);
100
101
  }
101
102
  return dataArray;
102
103
  }
104
+ function isNumericProperty(schemaPropertyType) {
105
+ return ['UINT8', 'INT16', 'UINT16', 'INT32', 'UINT32', 'INT64', 'UINT64', 'FLOAT32', 'FLOAT64'].includes(schemaPropertyType);
106
+ }
107
+ function getStringOffsets(scenegraph, featureTableProperty, numberOfElements) {
108
+ if (typeof featureTableProperty.stringOffsetBufferView !== 'undefined') {
109
+ return (0, _dTilesUtils.getOffsetsForProperty)(scenegraph, featureTableProperty.stringOffsetBufferView, featureTableProperty.offsetType || 'UINT32', numberOfElements);
110
+ }
111
+ return null;
112
+ }
113
+ function getNumericAttributes(valuesDataBytes, propertyType, elementCount) {
114
+ var valuesData = (0, _dTilesUtils.convertRawBufferToMetadataArray)(valuesDataBytes, 'SCALAR', propertyType, elementCount);
115
+ if (!valuesData) {
116
+ valuesData = valuesDataBytes;
117
+ }
118
+ return valuesData;
119
+ }
103
120
  function getPropertyDataFromTexture(scenegraph, featureTextureProperty, attributeName) {
104
121
  var json = scenegraph.gltf.json;
105
122
  if (!json.meshes) {
@@ -264,14 +281,10 @@ function findFeatureTextureByName(featureTextures, schemaClassName) {
264
281
  function getStringAttributes(data, offsetsData, stringsCount) {
265
282
  var stringsArray = [];
266
283
  var textDecoder = new TextDecoder('utf8');
267
- var stringOffset = 0;
268
- var bytesPerStringSize = 4;
269
284
  for (var index = 0; index < stringsCount; index++) {
270
- var stringByteSize = offsetsData[(index + 1) * bytesPerStringSize] - offsetsData[index * bytesPerStringSize];
271
- var stringData = data.subarray(stringOffset, stringByteSize + stringOffset);
285
+ var stringData = data.slice(offsetsData[index], offsetsData[index + 1]);
272
286
  var stringAttribute = textDecoder.decode(stringData);
273
287
  stringsArray.push(stringAttribute);
274
- stringOffset += stringByteSize;
275
288
  }
276
289
  return stringsArray;
277
290
  }