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

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 (86) hide show
  1. package/dist/dist.min.js +3587 -3026
  2. package/dist/es5/index.js +21 -0
  3. package/dist/es5/index.js.map +1 -1
  4. package/dist/es5/lib/api/gltf-extensions.js +3 -1
  5. package/dist/es5/lib/api/gltf-extensions.js.map +1 -1
  6. package/dist/es5/lib/extensions/EXT_mesh_features.js +111 -0
  7. package/dist/es5/lib/extensions/EXT_mesh_features.js.map +1 -0
  8. package/dist/es5/lib/extensions/EXT_structural_metadata.js +386 -0
  9. package/dist/es5/lib/extensions/EXT_structural_metadata.js.map +1 -0
  10. package/dist/es5/lib/extensions/KHR_draco_mesh_compression.js +6 -7
  11. package/dist/es5/lib/extensions/KHR_draco_mesh_compression.js.map +1 -1
  12. package/dist/es5/lib/extensions/data-processing.js +181 -0
  13. package/dist/es5/lib/extensions/data-processing.js.map +1 -0
  14. package/dist/es5/lib/extensions/deprecated/EXT_feature_metadata.js +6 -9
  15. package/dist/es5/lib/extensions/deprecated/EXT_feature_metadata.js.map +1 -1
  16. package/dist/es5/lib/parsers/parse-gltf.js +3 -3
  17. package/dist/es5/lib/parsers/parse-gltf.js.map +1 -1
  18. package/dist/es5/lib/types/gltf-ext-mesh-features-schema.js +2 -0
  19. package/dist/es5/lib/types/gltf-ext-mesh-features-schema.js.map +1 -0
  20. package/dist/es5/lib/types/gltf-ext-structural-metadata-schema.js +2 -0
  21. package/dist/es5/lib/types/gltf-ext-structural-metadata-schema.js.map +1 -0
  22. package/dist/es5/lib/types/gltf-json-schema.js.map +1 -1
  23. package/dist/es5/lib/utils/version.js +1 -1
  24. package/dist/esm/index.js +3 -0
  25. package/dist/esm/index.js.map +1 -1
  26. package/dist/esm/lib/api/gltf-extensions.js +3 -1
  27. package/dist/esm/lib/api/gltf-extensions.js.map +1 -1
  28. package/dist/esm/lib/extensions/EXT_mesh_features.js +55 -0
  29. package/dist/esm/lib/extensions/EXT_mesh_features.js.map +1 -0
  30. package/dist/esm/lib/extensions/EXT_structural_metadata.js +320 -0
  31. package/dist/esm/lib/extensions/EXT_structural_metadata.js.map +1 -0
  32. package/dist/esm/lib/extensions/KHR_draco_mesh_compression.js +2 -5
  33. package/dist/esm/lib/extensions/KHR_draco_mesh_compression.js.map +1 -1
  34. package/dist/esm/lib/extensions/data-processing.js +146 -0
  35. package/dist/esm/lib/extensions/data-processing.js.map +1 -0
  36. package/dist/esm/lib/extensions/deprecated/EXT_feature_metadata.js +4 -7
  37. package/dist/esm/lib/extensions/deprecated/EXT_feature_metadata.js.map +1 -1
  38. package/dist/esm/lib/parsers/parse-gltf.js +5 -6
  39. package/dist/esm/lib/parsers/parse-gltf.js.map +1 -1
  40. package/dist/esm/lib/types/gltf-ext-mesh-features-schema.js +2 -0
  41. package/dist/esm/lib/types/gltf-ext-mesh-features-schema.js.map +1 -0
  42. package/dist/esm/lib/types/gltf-ext-structural-metadata-schema.js +2 -0
  43. package/dist/esm/lib/types/gltf-ext-structural-metadata-schema.js.map +1 -0
  44. package/dist/esm/lib/types/gltf-json-schema.js.map +1 -1
  45. package/dist/esm/lib/utils/version.js +1 -1
  46. package/dist/index.d.ts +6 -1
  47. package/dist/index.d.ts.map +1 -1
  48. package/dist/index.js +7 -1
  49. package/dist/lib/api/gltf-extensions.d.ts.map +1 -1
  50. package/dist/lib/api/gltf-extensions.js +5 -0
  51. package/dist/lib/extensions/EXT_mesh_features.d.ts +7 -0
  52. package/dist/lib/extensions/EXT_mesh_features.d.ts.map +1 -0
  53. package/dist/lib/extensions/EXT_mesh_features.js +89 -0
  54. package/dist/lib/extensions/EXT_structural_metadata.d.ts +17 -0
  55. package/dist/lib/extensions/EXT_structural_metadata.d.ts.map +1 -0
  56. package/dist/lib/extensions/EXT_structural_metadata.js +504 -0
  57. package/dist/lib/extensions/KHR_draco_mesh_compression.d.ts +1 -1
  58. package/dist/lib/extensions/KHR_draco_mesh_compression.d.ts.map +1 -1
  59. package/dist/lib/extensions/KHR_draco_mesh_compression.js +2 -3
  60. package/dist/lib/extensions/data-processing.d.ts +34 -0
  61. package/dist/lib/extensions/data-processing.d.ts.map +1 -0
  62. package/dist/lib/extensions/data-processing.js +212 -0
  63. package/dist/lib/extensions/deprecated/EXT_feature_metadata.d.ts.map +1 -1
  64. package/dist/lib/extensions/deprecated/EXT_feature_metadata.js +8 -17
  65. package/dist/lib/parsers/parse-gltf.d.ts.map +1 -1
  66. package/dist/lib/parsers/parse-gltf.js +5 -3
  67. package/dist/lib/types/gltf-ext-mesh-features-schema.d.ts +45 -0
  68. package/dist/lib/types/gltf-ext-mesh-features-schema.d.ts.map +1 -0
  69. package/dist/lib/types/gltf-ext-mesh-features-schema.js +2 -0
  70. package/dist/lib/types/gltf-ext-structural-metadata-schema.d.ts +310 -0
  71. package/dist/lib/types/gltf-ext-structural-metadata-schema.d.ts.map +1 -0
  72. package/dist/lib/types/gltf-ext-structural-metadata-schema.js +2 -0
  73. package/dist/lib/types/gltf-json-schema.d.ts +11 -57
  74. package/dist/lib/types/gltf-json-schema.d.ts.map +1 -1
  75. package/package.json +6 -6
  76. package/src/index.ts +11 -3
  77. package/src/lib/api/gltf-extensions.ts +6 -2
  78. package/src/lib/extensions/EXT_mesh_features.ts +117 -0
  79. package/src/lib/extensions/EXT_structural_metadata.ts +730 -0
  80. package/src/lib/extensions/KHR_draco_mesh_compression.ts +7 -7
  81. package/src/lib/extensions/data-processing.ts +264 -0
  82. package/src/lib/extensions/deprecated/EXT_feature_metadata.ts +6 -17
  83. package/src/lib/parsers/parse-gltf.ts +9 -5
  84. package/src/lib/types/gltf-ext-mesh-features-schema.ts +48 -0
  85. package/src/lib/types/gltf-ext-structural-metadata-schema.ts +357 -0
  86. package/src/lib/types/gltf-json-schema.ts +12 -60
@@ -0,0 +1,181 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.convertRawBufferToMetadataArray = convertRawBufferToMetadataArray;
7
+ exports.getArrayElementByteSize = getArrayElementByteSize;
8
+ exports.getPrimitiveTextureData = getPrimitiveTextureData;
9
+ exports.primitivePropertyDataToAttributes = primitivePropertyDataToAttributes;
10
+ var _gltfUtils = require("../gltf-utils/gltf-utils");
11
+ var _images = require("@loaders.gl/images");
12
+ var _math = require("@loaders.gl/math");
13
+ 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; } } }; }
14
+ 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); }
15
+ 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; }
16
+ var ATTRIBUTE_TYPE_TO_COMPONENTS = {
17
+ SCALAR: 1,
18
+ VEC2: 2,
19
+ VEC3: 3,
20
+ VEC4: 4,
21
+ MAT2: 4,
22
+ MAT3: 9,
23
+ MAT4: 16,
24
+ BOOLEAN: 1,
25
+ STRING: 1,
26
+ ENUM: 1
27
+ };
28
+ var ATTRIBUTE_COMPONENT_TYPE_TO_ARRAY = {
29
+ INT8: Int8Array,
30
+ UINT8: Uint8Array,
31
+ INT16: Int16Array,
32
+ UINT16: Uint16Array,
33
+ INT32: Int32Array,
34
+ UINT32: Uint32Array,
35
+ INT64: BigInt64Array,
36
+ UINT64: BigUint64Array,
37
+ FLOAT32: Float32Array,
38
+ FLOAT64: Float64Array
39
+ };
40
+ var ATTRIBUTE_COMPONENT_TYPE_TO_BYTE_SIZE = {
41
+ INT8: 1,
42
+ UINT8: 1,
43
+ INT16: 2,
44
+ UINT16: 2,
45
+ INT32: 4,
46
+ UINT32: 4,
47
+ INT64: 8,
48
+ UINT64: 8,
49
+ FLOAT32: 4,
50
+ FLOAT64: 8
51
+ };
52
+ function getArrayElementByteSize(attributeType, componentType) {
53
+ return ATTRIBUTE_COMPONENT_TYPE_TO_BYTE_SIZE[componentType] * ATTRIBUTE_TYPE_TO_COMPONENTS[attributeType];
54
+ }
55
+ function convertRawBufferToMetadataArray(typedArray, attributeType, componentType) {
56
+ var elementCount = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : 1;
57
+ var numberOfComponents = ATTRIBUTE_TYPE_TO_COMPONENTS[attributeType];
58
+ var ArrayType = ATTRIBUTE_COMPONENT_TYPE_TO_ARRAY[componentType];
59
+ var length = elementCount * numberOfComponents;
60
+ var size = ATTRIBUTE_COMPONENT_TYPE_TO_BYTE_SIZE[componentType];
61
+ var offset = typedArray.byteOffset % size ? Math.ceil(typedArray.byteOffset / size) * size : typedArray.byteOffset;
62
+ return new ArrayType(typedArray.buffer, offset, length);
63
+ }
64
+ function getPrimitiveTextureData(scenegraph, textureInfo, primitive) {
65
+ var _json$textures, _json$textures$textur;
66
+ var json = scenegraph.gltf.json;
67
+ var texCoordAccessorKey = "TEXCOORD_".concat(textureInfo.texCoord || 0);
68
+ var texCoordAccessorIndex = primitive.attributes[texCoordAccessorKey];
69
+ var texCoordBufferView = scenegraph.getBufferView(texCoordAccessorIndex);
70
+ var texCoordArray = scenegraph.getTypedArrayForBufferView(texCoordBufferView);
71
+ var textureCoordinates = new Float32Array(texCoordArray.buffer, texCoordArray.byteOffset, texCoordArray.length / 4);
72
+ var textureIndex = textureInfo.index;
73
+ var imageIndex = (_json$textures = json.textures) === null || _json$textures === void 0 ? void 0 : (_json$textures$textur = _json$textures[textureIndex]) === null || _json$textures$textur === void 0 ? void 0 : _json$textures$textur.source;
74
+ if (typeof imageIndex !== 'undefined') {
75
+ var _json$images, _json$images$imageInd, _scenegraph$gltf$imag;
76
+ var mimeType = (_json$images = json.images) === null || _json$images === void 0 ? void 0 : (_json$images$imageInd = _json$images[imageIndex]) === null || _json$images$imageInd === void 0 ? void 0 : _json$images$imageInd.mimeType;
77
+ var parsedImage = (_scenegraph$gltf$imag = scenegraph.gltf.images) === null || _scenegraph$gltf$imag === void 0 ? void 0 : _scenegraph$gltf$imag[imageIndex];
78
+ if (parsedImage && typeof parsedImage.width !== 'undefined') {
79
+ var textureData = [];
80
+ for (var index = 0; index < textureCoordinates.length; index += 2) {
81
+ var value = getImageValueByCoordinates(parsedImage, mimeType, textureCoordinates, index, textureInfo.channels);
82
+ textureData.push(value);
83
+ }
84
+ return textureData;
85
+ }
86
+ }
87
+ return null;
88
+ }
89
+ function primitivePropertyDataToAttributes(scenegraph, attributeName, propertyData, featureTable, primitive) {
90
+ if (propertyData === null) return;
91
+ var featureIndices = [];
92
+ var _iterator = _createForOfIteratorHelper(propertyData),
93
+ _step;
94
+ try {
95
+ var _loop = function _loop() {
96
+ var texelData = _step.value;
97
+ var index = featureTable.findIndex(function (item) {
98
+ return item === texelData;
99
+ });
100
+ if (index === -1) {
101
+ index = featureTable.push(texelData) - 1;
102
+ }
103
+ featureIndices.push(index);
104
+ };
105
+ for (_iterator.s(); !(_step = _iterator.n()).done;) {
106
+ _loop();
107
+ }
108
+ } catch (err) {
109
+ _iterator.e(err);
110
+ } finally {
111
+ _iterator.f();
112
+ }
113
+ var typedArray = new Uint32Array(featureIndices);
114
+ var bufferIndex = scenegraph.gltf.buffers.push({
115
+ arrayBuffer: typedArray.buffer,
116
+ byteOffset: typedArray.byteOffset,
117
+ byteLength: typedArray.byteLength
118
+ }) - 1;
119
+ var bufferViewIndex = scenegraph.addBufferView(typedArray, bufferIndex, 0);
120
+ var accessorIndex = scenegraph.addAccessor(bufferViewIndex, {
121
+ size: 1,
122
+ componentType: (0, _gltfUtils.getComponentTypeFromArray)(typedArray),
123
+ count: typedArray.length
124
+ });
125
+ primitive.attributes[attributeName] = accessorIndex;
126
+ }
127
+ function getImageValueByCoordinates(parsedImage, mimeType, textureCoordinates, index) {
128
+ var channels = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : [0];
129
+ var CHANNELS_MAP = [{
130
+ offset: 0,
131
+ shift: 0
132
+ }, {
133
+ offset: 1,
134
+ shift: 8
135
+ }, {
136
+ offset: 2,
137
+ shift: 16
138
+ }, {
139
+ offset: 3,
140
+ shift: 24
141
+ }];
142
+ var u = textureCoordinates[index];
143
+ var v = textureCoordinates[index + 1];
144
+ var components = 1;
145
+ if (mimeType && (mimeType.indexOf('image/jpeg') !== -1 || mimeType.indexOf('image/png') !== -1)) components = 4;
146
+ var offset = coordinatesToOffset(u, v, parsedImage, components);
147
+ var value = 0;
148
+ var _iterator2 = _createForOfIteratorHelper(channels),
149
+ _step2;
150
+ try {
151
+ for (_iterator2.s(); !(_step2 = _iterator2.n()).done;) {
152
+ var c = _step2.value;
153
+ var map = CHANNELS_MAP[c];
154
+ var imageOffset = offset + map.offset;
155
+ var imageData = (0, _images.getImageData)(parsedImage);
156
+ if (imageData.data.length <= imageOffset) {
157
+ throw new Error("".concat(imageData.data.length, " <= ").concat(imageOffset));
158
+ }
159
+ var imageValue = imageData.data[imageOffset];
160
+ value |= imageValue << map.shift;
161
+ }
162
+ } catch (err) {
163
+ _iterator2.e(err);
164
+ } finally {
165
+ _iterator2.f();
166
+ }
167
+ return value;
168
+ }
169
+ function coordinatesToOffset(u, v, parsedImage) {
170
+ var componentsCount = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : 1;
171
+ var w = parsedImage.width;
172
+ var iX = (0, _math.emod)(u) * (w - 1);
173
+ var indX = Math.round(iX);
174
+ var h = parsedImage.height;
175
+ var iY = (0, _math.emod)(v) * (h - 1);
176
+ var indY = Math.round(iY);
177
+ var components = parsedImage.components ? parsedImage.components : componentsCount;
178
+ var offset = (indY * w + indX) * components;
179
+ return offset;
180
+ }
181
+ //# sourceMappingURL=data-processing.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"data-processing.js","names":["_gltfUtils","require","_images","_math","_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","ATTRIBUTE_TYPE_TO_COMPONENTS","SCALAR","VEC2","VEC3","VEC4","MAT2","MAT3","MAT4","BOOLEAN","STRING","ENUM","ATTRIBUTE_COMPONENT_TYPE_TO_ARRAY","INT8","Int8Array","UINT8","Uint8Array","INT16","Int16Array","UINT16","Uint16Array","INT32","Int32Array","UINT32","Uint32Array","INT64","BigInt64Array","UINT64","BigUint64Array","FLOAT32","Float32Array","FLOAT64","Float64Array","ATTRIBUTE_COMPONENT_TYPE_TO_BYTE_SIZE","getArrayElementByteSize","attributeType","componentType","convertRawBufferToMetadataArray","typedArray","elementCount","arguments","undefined","numberOfComponents","ArrayType","size","offset","byteOffset","Math","ceil","buffer","getPrimitiveTextureData","scenegraph","textureInfo","primitive","_json$textures","_json$textures$textur","json","gltf","texCoordAccessorKey","concat","texCoord","texCoordAccessorIndex","attributes","texCoordBufferView","getBufferView","texCoordArray","getTypedArrayForBufferView","textureCoordinates","textureIndex","index","imageIndex","textures","source","_json$images","_json$images$imageInd","_scenegraph$gltf$imag","mimeType","images","parsedImage","width","textureData","getImageValueByCoordinates","channels","push","primitivePropertyDataToAttributes","attributeName","propertyData","featureTable","featureIndices","_iterator","_step","_loop","texelData","findIndex","item","bufferIndex","buffers","arrayBuffer","byteLength","bufferViewIndex","addBufferView","accessorIndex","addAccessor","getComponentTypeFromArray","count","CHANNELS_MAP","shift","u","v","components","indexOf","coordinatesToOffset","_iterator2","_step2","c","map","imageOffset","imageData","getImageData","data","Error","imageValue","componentsCount","w","iX","emod","indX","round","h","height","iY","indY"],"sources":["../../../../src/lib/extensions/data-processing.ts"],"sourcesContent":["import type {GLTFTextureInfoMetadata, GLTFMeshPrimitive} from '../types/gltf-json-schema';\nimport type {TypedArray} from '@loaders.gl/schema';\nimport type {ImageType} from '@loaders.gl/images';\n\nimport {GLTFScenegraph} from '../api/gltf-scenegraph';\nimport {getComponentTypeFromArray} from '../gltf-utils/gltf-utils';\nimport {getImageData} from '@loaders.gl/images';\nimport {emod} from '@loaders.gl/math';\n\nconst ATTRIBUTE_TYPE_TO_COMPONENTS = {\n SCALAR: 1,\n VEC2: 2,\n VEC3: 3,\n VEC4: 4,\n MAT2: 4,\n MAT3: 9,\n MAT4: 16,\n BOOLEAN: 1,\n STRING: 1,\n ENUM: 1\n};\n\nconst ATTRIBUTE_COMPONENT_TYPE_TO_ARRAY = {\n INT8: Int8Array,\n UINT8: Uint8Array,\n INT16: Int16Array,\n UINT16: Uint16Array,\n INT32: Int32Array,\n UINT32: Uint32Array,\n INT64: BigInt64Array,\n UINT64: BigUint64Array,\n FLOAT32: Float32Array,\n FLOAT64: Float64Array\n};\n\nconst ATTRIBUTE_COMPONENT_TYPE_TO_BYTE_SIZE = {\n INT8: 1,\n UINT8: 1,\n INT16: 2,\n UINT16: 2,\n INT32: 4,\n UINT32: 4,\n INT64: 8,\n UINT64: 8,\n FLOAT32: 4,\n FLOAT64: 8\n};\n\nexport function getArrayElementByteSize(attributeType, componentType): number {\n return (\n ATTRIBUTE_COMPONENT_TYPE_TO_BYTE_SIZE[componentType] *\n ATTRIBUTE_TYPE_TO_COMPONENTS[attributeType]\n );\n}\n\n/**\n * Converts raw bytes that are in the buffer to an array of the type defined by the schema.\n * @param {Uint8Array} typedArray - raw bytes in the buffer\n * @param {string} attributeType - SCALAR, VECN, MATN\n * @param {string} componentType - type of the component in elements, e.g. 'UINT8' or 'FLOAT32'\n * @param {number} elementCount - number of elements in the array. Default value is 1.\n * @returns {TypedArray} Data array\n */\nexport function convertRawBufferToMetadataArray(\n typedArray: Uint8Array,\n attributeType: string,\n componentType: string,\n elementCount: number = 1\n): TypedArray {\n const numberOfComponents = ATTRIBUTE_TYPE_TO_COMPONENTS[attributeType];\n const ArrayType = ATTRIBUTE_COMPONENT_TYPE_TO_ARRAY[componentType];\n const length = elementCount * numberOfComponents;\n const size = ATTRIBUTE_COMPONENT_TYPE_TO_BYTE_SIZE[componentType];\n // the buffer view `byteOffset` must be aligned to a multiple of the `componentType` size.\n const offset =\n typedArray.byteOffset % size\n ? Math.ceil(typedArray.byteOffset / size) * size\n : typedArray.byteOffset;\n return new ArrayType(typedArray.buffer, offset, length);\n}\n\n/**\n * Processes data encoded in the texture associated with the primitive.\n * If Ext_mesh_featues is combined with the Ext_structural_metadata, propertyTable will also be processed.\n * @param {GLTFScenegraph} scenegraph - Instance of the class for structured access to GLTF data.\n * @param {GLTFTextureInfoMetadata} textureInfo - reference to the texture where extension data are stored.\n * @param {GLTFMeshPrimitive} primitive - primitive object in the mesh\n * @returns {number[] | null} Array of data taken. Null if data can't be taken from the texture.\n */\nexport function getPrimitiveTextureData(\n scenegraph: GLTFScenegraph,\n textureInfo: GLTFTextureInfoMetadata,\n primitive: GLTFMeshPrimitive\n): number[] | null {\n /*\n texture.index is an index for the \"textures\" array.\n The texture object referenced by this index looks like this:\n {\n \"sampler\": 0,\n \"source\": 0\n }\n \"sampler\" is an index for the \"samplers\" array\n \"source\" is an index for the \"images\" array that contains data. These data are stored in rgba channels of the image.\n\n texture.texCoord is a number-suffix (like 1) for an attribute like \"TEXCOORD_1\" in meshes.primitives\n The value of \"TEXCOORD_1\" is an accessor that is used to get coordinates. These coordinates are being used to get data from the image.\n */\n const json = scenegraph.gltf.json;\n\n const texCoordAccessorKey = `TEXCOORD_${textureInfo.texCoord || 0}`;\n const texCoordAccessorIndex = primitive.attributes[texCoordAccessorKey];\n const texCoordBufferView = scenegraph.getBufferView(texCoordAccessorIndex);\n const texCoordArray: Uint8Array = scenegraph.getTypedArrayForBufferView(texCoordBufferView);\n\n // textureCoordinates array contains UV coordinates of the actual data stored in the texture\n const textureCoordinates: Float32Array = new Float32Array(\n texCoordArray.buffer,\n texCoordArray.byteOffset,\n texCoordArray.length / 4\n );\n\n const textureIndex: number = textureInfo.index;\n const imageIndex = json.textures?.[textureIndex]?.source;\n if (typeof imageIndex !== 'undefined') {\n const mimeType = json.images?.[imageIndex]?.mimeType;\n const parsedImage = scenegraph.gltf.images?.[imageIndex];\n // Checking for width is to prevent handling Un-processed images (e.g. [analyze] stage, where loadImages option is set to false)\n if (parsedImage && typeof parsedImage.width !== 'undefined') {\n const textureData: number[] = [];\n for (let index = 0; index < textureCoordinates.length; index += 2) {\n const value = getImageValueByCoordinates(\n parsedImage,\n mimeType,\n textureCoordinates,\n index,\n textureInfo.channels\n );\n textureData.push(value);\n }\n return textureData;\n }\n }\n return null;\n}\n\n/**\n * Puts property data to attributes.\n * It creates corresponding buffer, bufferView and accessor\n * so the data can be accessed like regular data stored in buffers.\n * @param {GLTFScenegraph} scenegraph - scenegraph object\n * @param {string} attributeName - name of the attribute\n * @param {number[]} propertyData - property data to store\n * @param {number[]} featureTable - an array where unique data from the property data are being stored\n * @param {GLTFMeshPrimitive} primitive - primitive object\n */\nexport function primitivePropertyDataToAttributes(\n scenegraph: GLTFScenegraph,\n attributeName: string,\n propertyData: number[],\n featureTable: number[],\n primitive: GLTFMeshPrimitive\n): void {\n if (propertyData === null) return;\n /*\n featureTable will contain unique values, e.g.\n propertyData = [24, 35, 28, 24]\n featureTable = [24, 35, 28]\n featureIndices will contain indices that refer featureTextureTable, e.g.\n featureIndices = [0, 1, 2, 0]\n */\n const featureIndices: number[] = [];\n for (const texelData of propertyData) {\n let index = featureTable.findIndex((item) => item === texelData);\n if (index === -1) {\n index = featureTable.push(texelData) - 1;\n }\n featureIndices.push(index);\n }\n const typedArray = new Uint32Array(featureIndices);\n const bufferIndex =\n scenegraph.gltf.buffers.push({\n arrayBuffer: typedArray.buffer,\n byteOffset: typedArray.byteOffset,\n byteLength: typedArray.byteLength\n }) - 1;\n const bufferViewIndex = scenegraph.addBufferView(typedArray, bufferIndex, 0);\n const accessorIndex = scenegraph.addAccessor(bufferViewIndex, {\n size: 1,\n componentType: getComponentTypeFromArray(typedArray),\n count: typedArray.length\n });\n primitive.attributes[attributeName] = accessorIndex;\n}\n\n/**\n * Gets the value from the texture by coordinates provided.\n * @param {ImageType} parsedImage - image where the data are stored.\n * @param {string | undefined} mimeType - MIME type\n * @param {Float32Array} textureCoordinates - uv coordinates to access data in the image.\n * @param {number} index - index of uv coordinates in the array textureCoordinates\n * @param {channels} channels - image channels where data are stored. Channels of an RGBA texture are numbered 0..3 respectively.\n * @returns {number} Value taken from the image.\n */\nfunction getImageValueByCoordinates(\n parsedImage: ImageType,\n mimeType: string | undefined,\n textureCoordinates: Float32Array,\n index: number,\n channels: number[] = [0]\n) {\n const CHANNELS_MAP = [\n {offset: 0, shift: 0},\n {offset: 1, shift: 8},\n {offset: 2, shift: 16},\n {offset: 3, shift: 24}\n ];\n\n const u = textureCoordinates[index];\n const v = textureCoordinates[index + 1];\n\n let components = 1;\n if (mimeType && (mimeType.indexOf('image/jpeg') !== -1 || mimeType.indexOf('image/png') !== -1))\n components = 4;\n const offset = coordinatesToOffset(u, v, parsedImage, components);\n let value: number = 0;\n for (const c of channels) {\n const map = CHANNELS_MAP[c];\n const imageOffset = offset + map.offset;\n const imageData = getImageData(parsedImage);\n if (imageData.data.length <= imageOffset) {\n throw new Error(`${imageData.data.length} <= ${imageOffset}`);\n }\n const imageValue = imageData.data[imageOffset];\n value |= imageValue << map.shift;\n }\n return value;\n}\n\n/**\n * Retrieves the offset in the image where the data are stored\n * @param u - u-coordinate\n * @param v - v-coordinate\n * @param parsedImage - image where the data are stored\n * @param componentsCount - number of components the data consists of.\n * @returns offset in the image where the data are stored\n */\nfunction coordinatesToOffset(\n u: number,\n v: number,\n parsedImage: any,\n componentsCount: number = 1\n): number {\n const w = parsedImage.width;\n const iX = emod(u) * (w - 1);\n const indX = Math.round(iX);\n\n const h = parsedImage.height;\n const iY = emod(v) * (h - 1);\n const indY = Math.round(iY);\n const components = parsedImage.components ? parsedImage.components : componentsCount;\n // components is a number of channels in the image\n const offset = (indY * w + indX) * components;\n return offset;\n}\n"],"mappings":"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"}
@@ -11,11 +11,12 @@ var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/
11
11
  var _gltfScenegraph = require("../../api/gltf-scenegraph");
12
12
  var _images = require("@loaders.gl/images");
13
13
  var _gltfUtils = require("../../gltf-utils/gltf-utils");
14
+ var _math = require("@loaders.gl/math");
14
15
  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
16
  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
17
  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; }
17
- var EXT_FEATURE_METADATA = 'EXT_feature_metadata';
18
- var name = EXT_FEATURE_METADATA;
18
+ var EXT_FEATURE_METADATA_NAME = 'EXT_feature_metadata';
19
+ var name = EXT_FEATURE_METADATA_NAME;
19
20
  exports.name = name;
20
21
  function decode(_x, _x2) {
21
22
  return _decode.apply(this, arguments);
@@ -38,7 +39,7 @@ function _decode() {
38
39
  }
39
40
  function decodeExtFeatureMetadata(scenegraph, options) {
40
41
  var _extension$schema, _options$gltf;
41
- var extension = scenegraph.getExtension(EXT_FEATURE_METADATA);
42
+ var extension = scenegraph.getExtension(EXT_FEATURE_METADATA_NAME);
42
43
  if (!extension) return;
43
44
  var schemaClasses = (_extension$schema = extension.schema) === null || _extension$schema === void 0 ? void 0 : _extension$schema.classes;
44
45
  var featureTables = extension.featureTables;
@@ -233,19 +234,15 @@ function getVal(parsedImage, offset) {
233
234
  function coordinatesToOffset(u, v, parsedImage) {
234
235
  var componentsCount = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : 1;
235
236
  var w = parsedImage.width;
236
- var iX = emod(u) * (w - 1);
237
+ var iX = (0, _math.emod)(u) * (w - 1);
237
238
  var indX = Math.round(iX);
238
239
  var h = parsedImage.height;
239
- var iY = emod(v) * (h - 1);
240
+ var iY = (0, _math.emod)(v) * (h - 1);
240
241
  var indY = Math.round(iY);
241
242
  var components = parsedImage.components ? parsedImage.components : componentsCount;
242
243
  var offset = (indY * w + indX) * components;
243
244
  return offset;
244
245
  }
245
- function emod(n) {
246
- var a = (n % 1 + 1) % 1;
247
- return a;
248
- }
249
246
  function findFeatureTableByName(featureTables, schemaClassName) {
250
247
  for (var featureTableName in featureTables) {
251
248
  var featureTable = featureTables[featureTableName];
@@ -1 +1 @@
1
- {"version":3,"file":"EXT_feature_metadata.js","names":["_gltfScenegraph","require","_images","_gltfUtils","_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_FEATURE_METADATA","exports","decode","_x","_x2","_decode","apply","arguments","_asyncToGenerator2","default","_regenerator","mark","_callee","gltfData","options","scenegraph","wrap","_callee$","_context","prev","GLTFScenegraph","decodeExtFeatureMetadata","stop","_extension$schema","_options$gltf","extension","getExtension","schemaClasses","schema","classes","featureTables","schemaName","schemaClass","featureTable","findFeatureTableByName","handleFeatureTableProperties","featureTextures","gltf","loadImages","featureTexture","findFeatureTextureByName","handleFeatureTextureProperties","propertyName","properties","_featureTable$propert","schemaProperty","featureTableProperty","numberOfFeatures","count","data","getPropertyDataFromBinarySource","attributeName","class","_featureTexture$prope","featureTextureProperty","getPropertyDataFromTexture","bufferView","dataArray","getTypedArrayForBufferView","type","stringOffsetBufferView","offsetsData","getStringAttributes","json","meshes","featureTextureTable","_iterator","_step","mesh","_iterator2","primitives","_step2","primitive","processPrimitiveTextures","_json$textures","textureData","texCoordAccessorKey","concat","texture","texCoord","texCoordAccessorIndex","attributes","texCoordBufferView","getBufferView","texCoordArray","textureCoordinates","Float32Array","buffer","byteOffset","textureIndex","index","textures","imageIndex","source","_json$images","_scenegraph$gltf$imag","image","images","mimeType","parsedImage","getImageValueByCoordinates","channels","push","featureIndices","_loop","texelData","_textureData","_i","findIndex","item","typedArray","Uint32Array","bufferIndex","buffers","arrayBuffer","byteLength","bufferViewIndex","addBufferView","accessorIndex","addAccessor","size","componentType","getComponentTypeFromArray","CHANNELS_MAP","r","offset","shift","g","b","a","u","v","components","indexOf","coordinatesToOffset","_iterator3","_step3","c","map","val","getVal","imageData","getImageData","Error","componentsCount","undefined","w","width","iX","emod","indX","Math","round","h","height","iY","indY","schemaClassName","featureTableName","featureTexturesName","stringsCount","stringsArray","textDecoder","TextDecoder","stringOffset","bytesPerStringSize","stringByteSize","stringData","subarray","stringAttribute"],"sources":["../../../../../src/lib/extensions/deprecated/EXT_feature_metadata.ts"],"sourcesContent":["/* eslint-disable camelcase */\nimport type {\n GLTF,\n GLTF_EXT_feature_metadata_Class,\n GLTF_EXT_feature_metadata_ClassProperty,\n GLTF_EXT_feature_metadata_FeatureTable,\n GLTF_EXT_feature_metadata_FeatureTableProperty,\n GLTF_EXT_feature_metadata_FeatureTexture,\n GLTF_EXT_feature_metadata_GLTF,\n GLTF_EXT_feature_metadata_TextureAccessor\n} from '../../types/gltf-json-schema';\nimport {GLTFScenegraph} from '../../api/gltf-scenegraph';\nimport {getImageData} from '@loaders.gl/images';\nimport {GLTFMeshPrimitive} from '../../types/gltf-json-schema';\nimport {getComponentTypeFromArray} from '../../gltf-utils/gltf-utils';\nimport {GLTFLoaderOptions} from '../../../gltf-loader';\n\n/** Extension name */\nconst EXT_FEATURE_METADATA = 'EXT_feature_metadata';\n\nexport const name = EXT_FEATURE_METADATA;\n\nexport async function decode(gltfData: {json: GLTF}, options: GLTFLoaderOptions): Promise<void> {\n const scenegraph = new GLTFScenegraph(gltfData);\n decodeExtFeatureMetadata(scenegraph, options);\n}\n\n/**\n * Decodes feature metadata from extension\n * @param scenegraph\n */\nfunction decodeExtFeatureMetadata(scenegraph: GLTFScenegraph, options: GLTFLoaderOptions): void {\n const extension: GLTF_EXT_feature_metadata_GLTF | null =\n scenegraph.getExtension(EXT_FEATURE_METADATA);\n if (!extension) return;\n\n const schemaClasses = extension.schema?.classes;\n\n const {featureTables} = extension;\n if (schemaClasses && featureTables) {\n for (const schemaName in schemaClasses) {\n const schemaClass = schemaClasses[schemaName];\n const featureTable = findFeatureTableByName(featureTables, schemaName);\n\n if (featureTable) {\n handleFeatureTableProperties(scenegraph, featureTable, schemaClass);\n }\n }\n }\n\n const {featureTextures} = extension;\n if (schemaClasses && featureTextures && options.gltf?.loadImages) {\n for (const schemaName in schemaClasses) {\n const schemaClass = schemaClasses[schemaName];\n const featureTexture = findFeatureTextureByName(featureTextures, schemaName);\n\n if (featureTexture) {\n handleFeatureTextureProperties(scenegraph, featureTexture, schemaClass);\n }\n }\n }\n}\n\n/**\n * Navigate throw all properies in feature table and gets properties data.\n * @param scenegraph\n * @param featureTable\n * @param schemaClass\n */\nfunction handleFeatureTableProperties(\n scenegraph: GLTFScenegraph,\n featureTable: GLTF_EXT_feature_metadata_FeatureTable,\n schemaClass: GLTF_EXT_feature_metadata_Class\n): void {\n for (const propertyName in schemaClass.properties) {\n const schemaProperty = schemaClass.properties[propertyName];\n const featureTableProperty = featureTable?.properties?.[propertyName];\n const numberOfFeatures = featureTable.count;\n\n if (featureTableProperty) {\n const data = getPropertyDataFromBinarySource(\n scenegraph,\n schemaProperty,\n numberOfFeatures,\n featureTableProperty\n );\n featureTableProperty.data = data;\n }\n }\n}\n\n/**\n * Navigate throw all properies in feature texture and gets properties data.\n * Data will be stored in featureTexture.properties[propertyName].data\n * @param scenegraph\n * @param featureTexture\n * @param schemaClass\n */\nfunction handleFeatureTextureProperties(\n scenegraph: GLTFScenegraph,\n featureTexture: GLTF_EXT_feature_metadata_FeatureTexture,\n schemaClass: GLTF_EXT_feature_metadata_Class\n): void {\n const attributeName = featureTexture.class;\n\n for (const propertyName in schemaClass.properties) {\n const featureTextureProperty = featureTexture?.properties?.[propertyName];\n\n if (featureTextureProperty) {\n const data = getPropertyDataFromTexture(scenegraph, featureTextureProperty, attributeName);\n featureTextureProperty.data = data;\n }\n }\n}\n\n/**\n * Decode properties from binary sourse based on property type.\n * @param scenegraph\n * @param schemaProperty\n * @param numberOfFeatures\n * @param featureTableProperty\n */\nfunction getPropertyDataFromBinarySource(\n scenegraph: GLTFScenegraph,\n schemaProperty: GLTF_EXT_feature_metadata_ClassProperty,\n numberOfFeatures: number,\n featureTableProperty: GLTF_EXT_feature_metadata_FeatureTableProperty\n): Uint8Array | string[] {\n const bufferView = featureTableProperty.bufferView;\n // TODO think maybe we shouldn't get data only in Uint8Array format.\n const dataArray: Uint8Array = scenegraph.getTypedArrayForBufferView(bufferView);\n\n switch (schemaProperty.type) {\n case 'STRING': {\n // stringOffsetBufferView should be available for string type.\n const stringOffsetBufferView = featureTableProperty.stringOffsetBufferView!;\n const offsetsData = scenegraph.getTypedArrayForBufferView(stringOffsetBufferView);\n return getStringAttributes(dataArray, offsetsData, numberOfFeatures);\n }\n default:\n }\n\n return dataArray;\n}\n\n/**\n * Get properties from texture associated with all mesh primitives.\n * @param scenegraph\n * @param featureTextureProperty\n * @param attributeName\n * @returns Feature texture data\n */\nfunction getPropertyDataFromTexture(\n scenegraph: GLTFScenegraph,\n featureTextureProperty: GLTF_EXT_feature_metadata_TextureAccessor,\n attributeName: string\n): number[] {\n const json = scenegraph.gltf.json;\n if (!json.meshes) {\n return [];\n }\n const featureTextureTable: number[] = [];\n for (const mesh of json.meshes) {\n for (const primitive of mesh.primitives) {\n processPrimitiveTextures(\n scenegraph,\n attributeName,\n featureTextureProperty,\n featureTextureTable,\n primitive\n );\n }\n }\n return featureTextureTable;\n}\n\n// eslint-disable-next-line max-statements\n/**\n * Processes data encoded in the texture associated with the primitive. This data will be accessible through the attributes.\n * @param scenegraph\n * @param attributeName\n * @param featureTextureProperty\n * @param featureTextureTable\n * @param primitive\n */\n// eslint-disable-next-line max-statements\nfunction processPrimitiveTextures(\n scenegraph: GLTFScenegraph,\n attributeName: string,\n featureTextureProperty: GLTF_EXT_feature_metadata_TextureAccessor,\n featureTextureTable: number[],\n primitive: GLTFMeshPrimitive\n): void {\n /*\n texture.index is an index for the \"textures\" array.\n The texture object referenced by this index looks like this:\n {\n \"sampler\": 0,\n \"source\": 0\n }\n \"sampler\" is an index for the \"samplers\" array\n \"source\" is an index for the \"images\" array that contains data. These data are stored in rgba channels of the image.\n\n texture.texCoord is a number-suffix (like 1) for an attribute like \"TEXCOORD_1\" in meshes.primitives\n The value of \"TEXCOORD_1\" is an accessor that is used to get coordinates. These coordinates ared used to get data from the image.\n */\n const json = scenegraph.gltf.json;\n const textureData: number[] = [];\n const texCoordAccessorKey = `TEXCOORD_${featureTextureProperty.texture.texCoord}`;\n const texCoordAccessorIndex = primitive.attributes[texCoordAccessorKey];\n const texCoordBufferView = scenegraph.getBufferView(texCoordAccessorIndex);\n const texCoordArray: Uint8Array = scenegraph.getTypedArrayForBufferView(texCoordBufferView);\n\n const textureCoordinates: Float32Array = new Float32Array(\n texCoordArray.buffer,\n texCoordArray.byteOffset,\n texCoordArray.length / 4\n );\n // textureCoordinates contains UV coordinates of the actual data stored in the texture\n // accessor.count is a number of UV pairs (they are stored as VEC2)\n\n const textureIndex = featureTextureProperty.texture.index;\n const texture = json.textures?.[textureIndex];\n const imageIndex = texture?.source;\n if (typeof imageIndex !== 'undefined') {\n const image = json.images?.[imageIndex];\n const mimeType = image?.mimeType;\n const parsedImage = scenegraph.gltf.images?.[imageIndex];\n if (parsedImage) {\n for (let index = 0; index < textureCoordinates.length; index += 2) {\n const value = getImageValueByCoordinates(\n parsedImage,\n mimeType,\n textureCoordinates,\n index,\n featureTextureProperty.channels\n );\n textureData.push(value);\n }\n }\n }\n /*\n featureTextureTable will contain unique values, e.g.\n textureData = [24, 35, 28, 24]\n featureTextureTable = [24, 35, 28]\n featureIndices will contain indices hat refer featureTextureTable, e.g.\n featureIndices = [0, 1, 2, 0]\n */\n const featureIndices: number[] = [];\n for (const texelData of textureData) {\n let index = featureTextureTable.findIndex((item) => item === texelData);\n if (index === -1) {\n index = featureTextureTable.push(texelData) - 1;\n }\n featureIndices.push(index);\n }\n const typedArray = new Uint32Array(featureIndices);\n const bufferIndex =\n scenegraph.gltf.buffers.push({\n arrayBuffer: typedArray.buffer,\n byteOffset: 0,\n byteLength: typedArray.byteLength\n }) - 1;\n const bufferViewIndex = scenegraph.addBufferView(typedArray, bufferIndex, 0);\n const accessorIndex = scenegraph.addAccessor(bufferViewIndex, {\n size: 1,\n componentType: getComponentTypeFromArray(typedArray),\n count: typedArray.length\n });\n primitive.attributes[attributeName] = accessorIndex;\n}\n\nfunction getImageValueByCoordinates(\n parsedImage: any,\n mimeType: string | undefined,\n textureCoordinates: Float32Array,\n index: number,\n channels: string\n) {\n const CHANNELS_MAP = {\n r: {offset: 0, shift: 0},\n g: {offset: 1, shift: 8},\n b: {offset: 2, shift: 16},\n a: {offset: 3, shift: 24}\n };\n\n const u = textureCoordinates[index];\n const v = textureCoordinates[index + 1];\n\n let components = 1;\n if (mimeType && (mimeType.indexOf('image/jpeg') !== -1 || mimeType.indexOf('image/png') !== -1))\n components = 4;\n const offset = coordinatesToOffset(u, v, parsedImage, components);\n let value = 0;\n for (const c of channels) {\n const map = CHANNELS_MAP[c];\n const val = getVal(parsedImage, offset + map.offset);\n value |= val << map.shift;\n }\n return value;\n}\n\nfunction getVal(parsedImage: any, offset: number): number {\n const imageData = getImageData(parsedImage);\n if (imageData.data.length <= offset) {\n throw new Error(`${imageData.data.length} <= ${offset}`);\n }\n return imageData.data[offset];\n}\n\nfunction coordinatesToOffset(\n u: number,\n v: number,\n parsedImage: any,\n componentsCount: number = 1\n): number {\n const w = parsedImage.width;\n const iX = emod(u) * (w - 1);\n const indX = Math.round(iX);\n\n const h = parsedImage.height;\n const iY = emod(v) * (h - 1);\n const indY = Math.round(iY);\n const components = parsedImage.components ? parsedImage.components : componentsCount;\n // components is a number of channels in the image\n const offset = (indY * w + indX) * components;\n return offset;\n}\n\n// The following is taken from tile-converter\\src\\i3s-converter\\helpers\\batch-ids-extensions.ts\n/**\n * Handle UVs if they are out of range [0,1].\n * @param n\n * @param m\n */\nfunction emod(n: number): number {\n const a = ((n % 1) + 1) % 1;\n return a;\n}\n\n/**\n * Find the feature table by class name.\n * @param featureTables\n * @param schemaClassName\n */\nfunction findFeatureTableByName(\n featureTables: {[key: string]: GLTF_EXT_feature_metadata_FeatureTable},\n schemaClassName: string\n): GLTF_EXT_feature_metadata_FeatureTable | null {\n for (const featureTableName in featureTables) {\n const featureTable = featureTables[featureTableName];\n\n if (featureTable.class === schemaClassName) {\n return featureTable;\n }\n }\n\n return null;\n}\n\nfunction findFeatureTextureByName(\n featureTextures: {[key: string]: GLTF_EXT_feature_metadata_FeatureTexture},\n schemaClassName: string\n): GLTF_EXT_feature_metadata_FeatureTexture | null {\n for (const featureTexturesName in featureTextures) {\n const featureTable = featureTextures[featureTexturesName];\n\n if (featureTable.class === schemaClassName) {\n return featureTable;\n }\n }\n\n return null;\n}\n\n/**\n * Getting string attributes from binary data.\n * Spec - https://github.com/CesiumGS/3d-tiles/tree/main/specification/Metadata#strings\n * @param data\n * @param offsetsData\n * @param stringsCount\n */\nfunction getStringAttributes(\n data: Uint8Array,\n offsetsData: Uint8Array,\n stringsCount: number\n): string[] {\n const stringsArray: string[] = [];\n const textDecoder = new TextDecoder('utf8');\n\n let stringOffset = 0;\n const bytesPerStringSize = 4;\n\n for (let index = 0; index < stringsCount; index++) {\n // TODO check if it is multiplication on bytesPerStringSize is valid operation?\n const stringByteSize =\n offsetsData[(index + 1) * bytesPerStringSize] - offsetsData[index * bytesPerStringSize];\n const stringData = data.subarray(stringOffset, stringByteSize + stringOffset);\n const stringAttribute = textDecoder.decode(stringData);\n\n stringsArray.push(stringAttribute);\n stringOffset += stringByteSize;\n }\n\n return stringsArray;\n}\n"],"mappings":"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"}
1
+ {"version":3,"file":"EXT_feature_metadata.js","names":["_gltfScenegraph","require","_images","_gltfUtils","_math","_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_FEATURE_METADATA_NAME","exports","decode","_x","_x2","_decode","apply","arguments","_asyncToGenerator2","default","_regenerator","mark","_callee","gltfData","options","scenegraph","wrap","_callee$","_context","prev","GLTFScenegraph","decodeExtFeatureMetadata","stop","_extension$schema","_options$gltf","extension","getExtension","schemaClasses","schema","classes","featureTables","schemaName","schemaClass","featureTable","findFeatureTableByName","handleFeatureTableProperties","featureTextures","gltf","loadImages","featureTexture","findFeatureTextureByName","handleFeatureTextureProperties","propertyName","properties","_featureTable$propert","schemaProperty","featureTableProperty","numberOfFeatures","count","data","getPropertyDataFromBinarySource","attributeName","class","_featureTexture$prope","featureTextureProperty","getPropertyDataFromTexture","bufferView","dataArray","getTypedArrayForBufferView","type","stringOffsetBufferView","offsetsData","getStringAttributes","json","meshes","featureTextureTable","_iterator","_step","mesh","_iterator2","primitives","_step2","primitive","processPrimitiveTextures","_json$textures","textureData","texCoordAccessorKey","concat","texture","texCoord","texCoordAccessorIndex","attributes","texCoordBufferView","getBufferView","texCoordArray","textureCoordinates","Float32Array","buffer","byteOffset","textureIndex","index","textures","imageIndex","source","_json$images","_scenegraph$gltf$imag","image","images","mimeType","parsedImage","getImageValueByCoordinates","channels","push","featureIndices","_loop","texelData","_textureData","_i","findIndex","item","typedArray","Uint32Array","bufferIndex","buffers","arrayBuffer","byteLength","bufferViewIndex","addBufferView","accessorIndex","addAccessor","size","componentType","getComponentTypeFromArray","CHANNELS_MAP","r","offset","shift","g","b","a","u","v","components","indexOf","coordinatesToOffset","_iterator3","_step3","c","map","val","getVal","imageData","getImageData","Error","componentsCount","undefined","w","width","iX","emod","indX","Math","round","h","height","iY","indY","schemaClassName","featureTableName","featureTexturesName","stringsCount","stringsArray","textDecoder","TextDecoder","stringOffset","bytesPerStringSize","stringByteSize","stringData","subarray","stringAttribute"],"sources":["../../../../../src/lib/extensions/deprecated/EXT_feature_metadata.ts"],"sourcesContent":["/* eslint-disable camelcase */\nimport type {\n GLTF,\n GLTF_EXT_feature_metadata_Class,\n GLTF_EXT_feature_metadata_ClassProperty,\n GLTF_EXT_feature_metadata_FeatureTable,\n GLTF_EXT_feature_metadata_FeatureTableProperty,\n GLTF_EXT_feature_metadata_FeatureTexture,\n GLTF_EXT_feature_metadata_GLTF,\n GLTF_EXT_feature_metadata_TextureAccessor\n} from '../../types/gltf-json-schema';\nimport {GLTFScenegraph} from '../../api/gltf-scenegraph';\nimport {getImageData} from '@loaders.gl/images';\nimport {GLTFMeshPrimitive} from '../../types/gltf-json-schema';\nimport {getComponentTypeFromArray} from '../../gltf-utils/gltf-utils';\nimport {GLTFLoaderOptions} from '../../../gltf-loader';\nimport {emod} from '@loaders.gl/math';\n\n/** Extension name */\nconst EXT_FEATURE_METADATA_NAME = 'EXT_feature_metadata';\nexport const name = EXT_FEATURE_METADATA_NAME;\n\nexport async function decode(gltfData: {json: GLTF}, options: GLTFLoaderOptions): Promise<void> {\n const scenegraph = new GLTFScenegraph(gltfData);\n decodeExtFeatureMetadata(scenegraph, options);\n}\n\n/**\n * Decodes feature metadata from extension\n * @param scenegraph\n */\nfunction decodeExtFeatureMetadata(scenegraph: GLTFScenegraph, options: GLTFLoaderOptions): void {\n const extension: GLTF_EXT_feature_metadata_GLTF | null =\n scenegraph.getExtension(EXT_FEATURE_METADATA_NAME);\n if (!extension) return;\n\n const schemaClasses = extension.schema?.classes;\n\n const {featureTables} = extension;\n if (schemaClasses && featureTables) {\n for (const schemaName in schemaClasses) {\n const schemaClass = schemaClasses[schemaName];\n const featureTable = findFeatureTableByName(featureTables, schemaName);\n\n if (featureTable) {\n handleFeatureTableProperties(scenegraph, featureTable, schemaClass);\n }\n }\n }\n\n const {featureTextures} = extension;\n if (schemaClasses && featureTextures && options.gltf?.loadImages) {\n for (const schemaName in schemaClasses) {\n const schemaClass = schemaClasses[schemaName];\n const featureTexture = findFeatureTextureByName(featureTextures, schemaName);\n\n if (featureTexture) {\n handleFeatureTextureProperties(scenegraph, featureTexture, schemaClass);\n }\n }\n }\n}\n\n/**\n * Navigates through all properies in feature table and gets properties data.\n * @param scenegraph\n * @param featureTable\n * @param schemaClass\n */\nfunction handleFeatureTableProperties(\n scenegraph: GLTFScenegraph,\n featureTable: GLTF_EXT_feature_metadata_FeatureTable,\n schemaClass: GLTF_EXT_feature_metadata_Class\n): void {\n for (const propertyName in schemaClass.properties) {\n const schemaProperty = schemaClass.properties[propertyName];\n const featureTableProperty = featureTable?.properties?.[propertyName];\n const numberOfFeatures = featureTable.count;\n\n if (featureTableProperty) {\n const data = getPropertyDataFromBinarySource(\n scenegraph,\n schemaProperty,\n numberOfFeatures,\n featureTableProperty\n );\n featureTableProperty.data = data;\n }\n }\n}\n\n/**\n * Navigates through all properies in feature texture and gets properties data.\n * Data will be stored in featureTexture.properties[propertyName].data\n * @param scenegraph\n * @param featureTexture\n * @param schemaClass\n */\nfunction handleFeatureTextureProperties(\n scenegraph: GLTFScenegraph,\n featureTexture: GLTF_EXT_feature_metadata_FeatureTexture,\n schemaClass: GLTF_EXT_feature_metadata_Class\n): void {\n const attributeName = featureTexture.class;\n\n for (const propertyName in schemaClass.properties) {\n const featureTextureProperty = featureTexture?.properties?.[propertyName];\n\n if (featureTextureProperty) {\n const data = getPropertyDataFromTexture(scenegraph, featureTextureProperty, attributeName);\n featureTextureProperty.data = data;\n }\n }\n}\n\n/**\n * Decode properties from binary sourse based on property type.\n * @param scenegraph\n * @param schemaProperty\n * @param numberOfFeatures\n * @param featureTableProperty\n */\nfunction getPropertyDataFromBinarySource(\n scenegraph: GLTFScenegraph,\n schemaProperty: GLTF_EXT_feature_metadata_ClassProperty,\n numberOfFeatures: number,\n featureTableProperty: GLTF_EXT_feature_metadata_FeatureTableProperty\n): Uint8Array | string[] {\n const bufferView = featureTableProperty.bufferView;\n // TODO think maybe we shouldn't get data only in Uint8Array format.\n const dataArray: Uint8Array = scenegraph.getTypedArrayForBufferView(bufferView);\n\n switch (schemaProperty.type) {\n case 'STRING': {\n // stringOffsetBufferView should be available for string type.\n const stringOffsetBufferView = featureTableProperty.stringOffsetBufferView!;\n const offsetsData = scenegraph.getTypedArrayForBufferView(stringOffsetBufferView);\n return getStringAttributes(dataArray, offsetsData, numberOfFeatures);\n }\n default:\n }\n\n return dataArray;\n}\n\n/**\n * Get properties from texture associated with all mesh primitives.\n * @param scenegraph\n * @param featureTextureProperty\n * @param attributeName\n * @returns Feature texture data\n */\nfunction getPropertyDataFromTexture(\n scenegraph: GLTFScenegraph,\n featureTextureProperty: GLTF_EXT_feature_metadata_TextureAccessor,\n attributeName: string\n): number[] {\n const json = scenegraph.gltf.json;\n if (!json.meshes) {\n return [];\n }\n const featureTextureTable: number[] = [];\n for (const mesh of json.meshes) {\n for (const primitive of mesh.primitives) {\n processPrimitiveTextures(\n scenegraph,\n attributeName,\n featureTextureProperty,\n featureTextureTable,\n primitive\n );\n }\n }\n return featureTextureTable;\n}\n\n// eslint-disable-next-line max-statements\n/**\n * Processes data encoded in the texture associated with the primitive. This data will be accessible through the attributes.\n * @param scenegraph\n * @param attributeName\n * @param featureTextureProperty\n * @param featureTextureTable\n * @param primitive\n */\n// eslint-disable-next-line max-statements\nfunction processPrimitiveTextures(\n scenegraph: GLTFScenegraph,\n attributeName: string,\n featureTextureProperty: GLTF_EXT_feature_metadata_TextureAccessor,\n featureTextureTable: number[],\n primitive: GLTFMeshPrimitive\n): void {\n /*\n texture.index is an index for the \"textures\" array.\n The texture object referenced by this index looks like this:\n {\n \"sampler\": 0,\n \"source\": 0\n }\n \"sampler\" is an index for the \"samplers\" array\n \"source\" is an index for the \"images\" array that contains data. These data are stored in rgba channels of the image.\n\n texture.texCoord is a number-suffix (like 1) for an attribute like \"TEXCOORD_1\" in meshes.primitives\n The value of \"TEXCOORD_1\" is an accessor that is used to get coordinates. These coordinates ared used to get data from the image.\n */\n const json = scenegraph.gltf.json;\n const textureData: number[] = [];\n const texCoordAccessorKey = `TEXCOORD_${featureTextureProperty.texture.texCoord}`;\n const texCoordAccessorIndex = primitive.attributes[texCoordAccessorKey];\n const texCoordBufferView = scenegraph.getBufferView(texCoordAccessorIndex);\n const texCoordArray: Uint8Array = scenegraph.getTypedArrayForBufferView(texCoordBufferView);\n\n const textureCoordinates: Float32Array = new Float32Array(\n texCoordArray.buffer,\n texCoordArray.byteOffset,\n texCoordArray.length / 4\n );\n // textureCoordinates contains UV coordinates of the actual data stored in the texture\n // accessor.count is a number of UV pairs (they are stored as VEC2)\n\n const textureIndex = featureTextureProperty.texture.index;\n const texture = json.textures?.[textureIndex];\n const imageIndex = texture?.source;\n if (typeof imageIndex !== 'undefined') {\n const image = json.images?.[imageIndex];\n const mimeType = image?.mimeType;\n const parsedImage = scenegraph.gltf.images?.[imageIndex];\n if (parsedImage) {\n for (let index = 0; index < textureCoordinates.length; index += 2) {\n const value = getImageValueByCoordinates(\n parsedImage,\n mimeType,\n textureCoordinates,\n index,\n featureTextureProperty.channels\n );\n textureData.push(value);\n }\n }\n }\n /*\n featureTextureTable will contain unique values, e.g.\n textureData = [24, 35, 28, 24]\n featureTextureTable = [24, 35, 28]\n featureIndices will contain indices hat refer featureTextureTable, e.g.\n featureIndices = [0, 1, 2, 0]\n */\n const featureIndices: number[] = [];\n for (const texelData of textureData) {\n let index = featureTextureTable.findIndex((item) => item === texelData);\n if (index === -1) {\n index = featureTextureTable.push(texelData) - 1;\n }\n featureIndices.push(index);\n }\n const typedArray = new Uint32Array(featureIndices);\n const bufferIndex =\n scenegraph.gltf.buffers.push({\n arrayBuffer: typedArray.buffer,\n byteOffset: 0,\n byteLength: typedArray.byteLength\n }) - 1;\n const bufferViewIndex = scenegraph.addBufferView(typedArray, bufferIndex, 0);\n const accessorIndex = scenegraph.addAccessor(bufferViewIndex, {\n size: 1,\n componentType: getComponentTypeFromArray(typedArray),\n count: typedArray.length\n });\n primitive.attributes[attributeName] = accessorIndex;\n}\n\nfunction getImageValueByCoordinates(\n parsedImage: any,\n mimeType: string | undefined,\n textureCoordinates: Float32Array,\n index: number,\n channels: string\n) {\n const CHANNELS_MAP = {\n r: {offset: 0, shift: 0},\n g: {offset: 1, shift: 8},\n b: {offset: 2, shift: 16},\n a: {offset: 3, shift: 24}\n };\n\n const u = textureCoordinates[index];\n const v = textureCoordinates[index + 1];\n\n let components = 1;\n if (mimeType && (mimeType.indexOf('image/jpeg') !== -1 || mimeType.indexOf('image/png') !== -1))\n components = 4;\n const offset = coordinatesToOffset(u, v, parsedImage, components);\n let value = 0;\n for (const c of channels) {\n const map = CHANNELS_MAP[c];\n const val = getVal(parsedImage, offset + map.offset);\n value |= val << map.shift;\n }\n return value;\n}\n\nfunction getVal(parsedImage: any, offset: number): number {\n const imageData = getImageData(parsedImage);\n if (imageData.data.length <= offset) {\n throw new Error(`${imageData.data.length} <= ${offset}`);\n }\n return imageData.data[offset];\n}\n\nfunction coordinatesToOffset(\n u: number,\n v: number,\n parsedImage: any,\n componentsCount: number = 1\n): number {\n const w = parsedImage.width;\n const iX = emod(u) * (w - 1);\n const indX = Math.round(iX);\n\n const h = parsedImage.height;\n const iY = emod(v) * (h - 1);\n const indY = Math.round(iY);\n const components = parsedImage.components ? parsedImage.components : componentsCount;\n // components is a number of channels in the image\n const offset = (indY * w + indX) * components;\n return offset;\n}\n\n/**\n * Find the feature table by class name.\n * @param featureTables\n * @param schemaClassName\n */\nfunction findFeatureTableByName(\n featureTables: {[key: string]: GLTF_EXT_feature_metadata_FeatureTable},\n schemaClassName: string\n): GLTF_EXT_feature_metadata_FeatureTable | null {\n for (const featureTableName in featureTables) {\n const featureTable = featureTables[featureTableName];\n\n if (featureTable.class === schemaClassName) {\n return featureTable;\n }\n }\n\n return null;\n}\n\nfunction findFeatureTextureByName(\n featureTextures: {[key: string]: GLTF_EXT_feature_metadata_FeatureTexture},\n schemaClassName: string\n): GLTF_EXT_feature_metadata_FeatureTexture | null {\n for (const featureTexturesName in featureTextures) {\n const featureTable = featureTextures[featureTexturesName];\n\n if (featureTable.class === schemaClassName) {\n return featureTable;\n }\n }\n\n return null;\n}\n\n/**\n * Getting string attributes from binary data.\n * Spec - https://github.com/CesiumGS/3d-tiles/tree/main/specification/Metadata#strings\n * @param data\n * @param offsetsData\n * @param stringsCount\n */\nfunction getStringAttributes(\n data: Uint8Array,\n offsetsData: Uint8Array,\n stringsCount: number\n): string[] {\n const stringsArray: string[] = [];\n const textDecoder = new TextDecoder('utf8');\n\n let stringOffset = 0;\n const bytesPerStringSize = 4;\n\n for (let index = 0; index < stringsCount; index++) {\n // TODO check if it is multiplication on bytesPerStringSize is valid operation?\n const stringByteSize =\n offsetsData[(index + 1) * bytesPerStringSize] - offsetsData[index * bytesPerStringSize];\n const stringData = data.subarray(stringOffset, stringByteSize + stringOffset);\n const stringAttribute = textDecoder.decode(stringData);\n\n stringsArray.push(stringAttribute);\n stringOffset += stringByteSize;\n }\n\n return stringsArray;\n}\n"],"mappings":";;;;;;;;;;AAWA,IAAAA,eAAA,GAAAC,OAAA;AACA,IAAAC,OAAA,GAAAD,OAAA;AAEA,IAAAE,UAAA,GAAAF,OAAA;AAEA,IAAAG,KAAA,GAAAH,OAAA;AAAsC,SAAAI,2BAAAC,CAAA,EAAAC,cAAA,QAAAC,EAAA,UAAAC,MAAA,oBAAAH,CAAA,CAAAG,MAAA,CAAAC,QAAA,KAAAJ,CAAA,qBAAAE,EAAA,QAAAG,KAAA,CAAAC,OAAA,CAAAN,CAAA,MAAAE,EAAA,GAAAK,2BAAA,CAAAP,CAAA,MAAAC,cAAA,IAAAD,CAAA,WAAAA,CAAA,CAAAQ,MAAA,qBAAAN,EAAA,EAAAF,CAAA,GAAAE,EAAA,MAAAO,CAAA,UAAAC,CAAA,YAAAA,EAAA,eAAAC,CAAA,EAAAD,CAAA,EAAAE,CAAA,WAAAA,EAAA,QAAAH,CAAA,IAAAT,CAAA,CAAAQ,MAAA,WAAAK,IAAA,mBAAAA,IAAA,SAAAC,KAAA,EAAAd,CAAA,CAAAS,CAAA,UAAAM,CAAA,WAAAA,EAAAC,EAAA,UAAAA,EAAA,KAAAC,CAAA,EAAAP,CAAA,gBAAAQ,SAAA,iJAAAC,gBAAA,SAAAC,MAAA,UAAAC,GAAA,WAAAV,CAAA,WAAAA,EAAA,IAAAT,EAAA,GAAAA,EAAA,CAAAoB,IAAA,CAAAtB,CAAA,MAAAY,CAAA,WAAAA,EAAA,QAAAW,IAAA,GAAArB,EAAA,CAAAsB,IAAA,IAAAL,gBAAA,GAAAI,IAAA,CAAAV,IAAA,SAAAU,IAAA,KAAAR,CAAA,WAAAA,EAAAU,GAAA,IAAAL,MAAA,SAAAC,GAAA,GAAAI,GAAA,KAAAR,CAAA,WAAAA,EAAA,eAAAE,gBAAA,IAAAjB,EAAA,CAAAwB,MAAA,UAAAxB,EAAA,CAAAwB,MAAA,oBAAAN,MAAA,QAAAC,GAAA;AAAA,SAAAd,4BAAAP,CAAA,EAAA2B,MAAA,SAAA3B,CAAA,qBAAAA,CAAA,sBAAA4B,iBAAA,CAAA5B,CAAA,EAAA2B,MAAA,OAAAf,CAAA,GAAAiB,MAAA,CAAAC,SAAA,CAAAC,QAAA,CAAAT,IAAA,CAAAtB,CAAA,EAAAgC,KAAA,aAAApB,CAAA,iBAAAZ,CAAA,CAAAiC,WAAA,EAAArB,CAAA,GAAAZ,CAAA,CAAAiC,WAAA,CAAAC,IAAA,MAAAtB,CAAA,cAAAA,CAAA,mBAAAP,KAAA,CAAA8B,IAAA,CAAAnC,CAAA,OAAAY,CAAA,+DAAAwB,IAAA,CAAAxB,CAAA,UAAAgB,iBAAA,CAAA5B,CAAA,EAAA2B,MAAA;AAAA,SAAAC,kBAAAS,GAAA,EAAAC,GAAA,QAAAA,GAAA,YAAAA,GAAA,GAAAD,GAAA,CAAA7B,MAAA,EAAA8B,GAAA,GAAAD,GAAA,CAAA7B,MAAA,WAAAC,CAAA,MAAA8B,IAAA,OAAAlC,KAAA,CAAAiC,GAAA,GAAA7B,CAAA,GAAA6B,GAAA,EAAA7B,CAAA,IAAA8B,IAAA,CAAA9B,CAAA,IAAA4B,GAAA,CAAA5B,CAAA,UAAA8B,IAAA;AAGtC,IAAMC,yBAAyB,GAAG,sBAAsB;AACjD,IAAMN,IAAI,GAAGM,yBAAyB;AAACC,OAAA,CAAAP,IAAA,GAAAA,IAAA;AAAA,SAExBQ,MAAMA,CAAAC,EAAA,EAAAC,GAAA;EAAA,OAAAC,OAAA,CAAAC,KAAA,OAAAC,SAAA;AAAA;AAAA,SAAAF,QAAA;EAAAA,OAAA,OAAAG,kBAAA,CAAAC,OAAA,EAAAC,YAAA,CAAAD,OAAA,CAAAE,IAAA,CAArB,SAAAC,QAAsBC,QAAsB,EAAEC,OAA0B;IAAA,IAAAC,UAAA;IAAA,OAAAL,YAAA,CAAAD,OAAA,CAAAO,IAAA,UAAAC,SAAAC,QAAA;MAAA,kBAAAA,QAAA,CAAAC,IAAA,GAAAD,QAAA,CAAAlC,IAAA;QAAA;UACvE+B,UAAU,GAAG,IAAIK,8BAAc,CAACP,QAAQ,CAAC;UAC/CQ,wBAAwB,CAACN,UAAU,EAAED,OAAO,CAAC;QAAC;QAAA;UAAA,OAAAI,QAAA,CAAAI,IAAA;MAAA;IAAA,GAAAV,OAAA;EAAA,CAC/C;EAAA,OAAAP,OAAA,CAAAC,KAAA,OAAAC,SAAA;AAAA;AAMD,SAASc,wBAAwBA,CAACN,UAA0B,EAAED,OAA0B,EAAQ;EAAA,IAAAS,iBAAA,EAAAC,aAAA;EAC9F,IAAMC,SAAgD,GACpDV,UAAU,CAACW,YAAY,CAAC1B,yBAAyB,CAAC;EACpD,IAAI,CAACyB,SAAS,EAAE;EAEhB,IAAME,aAAa,IAAAJ,iBAAA,GAAGE,SAAS,CAACG,MAAM,cAAAL,iBAAA,uBAAhBA,iBAAA,CAAkBM,OAAO;EAE/C,IAAOC,aAAa,GAAIL,SAAS,CAA1BK,aAAa;EACpB,IAAIH,aAAa,IAAIG,aAAa,EAAE;IAClC,KAAK,IAAMC,UAAU,IAAIJ,aAAa,EAAE;MACtC,IAAMK,WAAW,GAAGL,aAAa,CAACI,UAAU,CAAC;MAC7C,IAAME,YAAY,GAAGC,sBAAsB,CAACJ,aAAa,EAAEC,UAAU,CAAC;MAEtE,IAAIE,YAAY,EAAE;QAChBE,4BAA4B,CAACpB,UAAU,EAAEkB,YAAY,EAAED,WAAW,CAAC;MACrE;IACF;EACF;EAEA,IAAOI,eAAe,GAAIX,SAAS,CAA5BW,eAAe;EACtB,IAAIT,aAAa,IAAIS,eAAe,KAAAZ,aAAA,GAAIV,OAAO,CAACuB,IAAI,cAAAb,aAAA,eAAZA,aAAA,CAAcc,UAAU,EAAE;IAChE,KAAK,IAAMP,WAAU,IAAIJ,aAAa,EAAE;MACtC,IAAMK,YAAW,GAAGL,aAAa,CAACI,WAAU,CAAC;MAC7C,IAAMQ,cAAc,GAAGC,wBAAwB,CAACJ,eAAe,EAAEL,WAAU,CAAC;MAE5E,IAAIQ,cAAc,EAAE;QAClBE,8BAA8B,CAAC1B,UAAU,EAAEwB,cAAc,EAAEP,YAAW,CAAC;MACzE;IACF;EACF;AACF;AAQA,SAASG,4BAA4BA,CACnCpB,UAA0B,EAC1BkB,YAAoD,EACpDD,WAA4C,EACtC;EACN,KAAK,IAAMU,YAAY,IAAIV,WAAW,CAACW,UAAU,EAAE;IAAA,IAAAC,qBAAA;IACjD,IAAMC,cAAc,GAAGb,WAAW,CAACW,UAAU,CAACD,YAAY,CAAC;IAC3D,IAAMI,oBAAoB,GAAGb,YAAY,aAAZA,YAAY,wBAAAW,qBAAA,GAAZX,YAAY,CAAEU,UAAU,cAAAC,qBAAA,uBAAxBA,qBAAA,CAA2BF,YAAY,CAAC;IACrE,IAAMK,gBAAgB,GAAGd,YAAY,CAACe,KAAK;IAE3C,IAAIF,oBAAoB,EAAE;MACxB,IAAMG,IAAI,GAAGC,+BAA+B,CAC1CnC,UAAU,EACV8B,cAAc,EACdE,gBAAgB,EAChBD,oBACF,CAAC;MACDA,oBAAoB,CAACG,IAAI,GAAGA,IAAI;IAClC;EACF;AACF;AASA,SAASR,8BAA8BA,CACrC1B,UAA0B,EAC1BwB,cAAwD,EACxDP,WAA4C,EACtC;EACN,IAAMmB,aAAa,GAAGZ,cAAc,CAACa,KAAK;EAE1C,KAAK,IAAMV,YAAY,IAAIV,WAAW,CAACW,UAAU,EAAE;IAAA,IAAAU,qBAAA;IACjD,IAAMC,sBAAsB,GAAGf,cAAc,aAAdA,cAAc,wBAAAc,qBAAA,GAAdd,cAAc,CAAEI,UAAU,cAAAU,qBAAA,uBAA1BA,qBAAA,CAA6BX,YAAY,CAAC;IAEzE,IAAIY,sBAAsB,EAAE;MAC1B,IAAML,IAAI,GAAGM,0BAA0B,CAACxC,UAAU,EAAEuC,sBAAsB,EAAEH,aAAa,CAAC;MAC1FG,sBAAsB,CAACL,IAAI,GAAGA,IAAI;IACpC;EACF;AACF;AASA,SAASC,+BAA+BA,CACtCnC,UAA0B,EAC1B8B,cAAuD,EACvDE,gBAAwB,EACxBD,oBAAoE,EAC7C;EACvB,IAAMU,UAAU,GAAGV,oBAAoB,CAACU,UAAU;EAElD,IAAMC,SAAqB,GAAG1C,UAAU,CAAC2C,0BAA0B,CAACF,UAAU,CAAC;EAE/E,QAAQX,cAAc,CAACc,IAAI;IACzB,KAAK,QAAQ;MAAE;QAEb,IAAMC,sBAAsB,GAAGd,oBAAoB,CAACc,sBAAuB;QAC3E,IAAMC,WAAW,GAAG9C,UAAU,CAAC2C,0BAA0B,CAACE,sBAAsB,CAAC;QACjF,OAAOE,mBAAmB,CAACL,SAAS,EAAEI,WAAW,EAAEd,gBAAgB,CAAC;MACtE;IACA;EACF;EAEA,OAAOU,SAAS;AAClB;AASA,SAASF,0BAA0BA,CACjCxC,UAA0B,EAC1BuC,sBAAiE,EACjEH,aAAqB,EACX;EACV,IAAMY,IAAI,GAAGhD,UAAU,CAACsB,IAAI,CAAC0B,IAAI;EACjC,IAAI,CAACA,IAAI,CAACC,MAAM,EAAE;IAChB,OAAO,EAAE;EACX;EACA,IAAMC,mBAA6B,GAAG,EAAE;EAAC,IAAAC,SAAA,GAAA3G,0BAAA,CACtBwG,IAAI,CAACC,MAAM;IAAAG,KAAA;EAAA;IAA9B,KAAAD,SAAA,CAAA/F,CAAA,MAAAgG,KAAA,GAAAD,SAAA,CAAA9F,CAAA,IAAAC,IAAA,GAAgC;MAAA,IAArB+F,IAAI,GAAAD,KAAA,CAAA7F,KAAA;MAAA,IAAA+F,UAAA,GAAA9G,0BAAA,CACW6G,IAAI,CAACE,UAAU;QAAAC,MAAA;MAAA;QAAvC,KAAAF,UAAA,CAAAlG,CAAA,MAAAoG,MAAA,GAAAF,UAAA,CAAAjG,CAAA,IAAAC,IAAA,GAAyC;UAAA,IAA9BmG,SAAS,GAAAD,MAAA,CAAAjG,KAAA;UAClBmG,wBAAwB,CACtB1D,UAAU,EACVoC,aAAa,EACbG,sBAAsB,EACtBW,mBAAmB,EACnBO,SACF,CAAC;QACH;MAAC,SAAA3F,GAAA;QAAAwF,UAAA,CAAA9F,CAAA,CAAAM,GAAA;MAAA;QAAAwF,UAAA,CAAA5F,CAAA;MAAA;IACH;EAAC,SAAAI,GAAA;IAAAqF,SAAA,CAAA3F,CAAA,CAAAM,GAAA;EAAA;IAAAqF,SAAA,CAAAzF,CAAA;EAAA;EACD,OAAOwF,mBAAmB;AAC5B;AAYA,SAASQ,wBAAwBA,CAC/B1D,UAA0B,EAC1BoC,aAAqB,EACrBG,sBAAiE,EACjEW,mBAA6B,EAC7BO,SAA4B,EACtB;EAAA,IAAAE,cAAA;EAcN,IAAMX,IAAI,GAAGhD,UAAU,CAACsB,IAAI,CAAC0B,IAAI;EACjC,IAAMY,WAAqB,GAAG,EAAE;EAChC,IAAMC,mBAAmB,eAAAC,MAAA,CAAevB,sBAAsB,CAACwB,OAAO,CAACC,QAAQ,CAAE;EACjF,IAAMC,qBAAqB,GAAGR,SAAS,CAACS,UAAU,CAACL,mBAAmB,CAAC;EACvE,IAAMM,kBAAkB,GAAGnE,UAAU,CAACoE,aAAa,CAACH,qBAAqB,CAAC;EAC1E,IAAMI,aAAyB,GAAGrE,UAAU,CAAC2C,0BAA0B,CAACwB,kBAAkB,CAAC;EAE3F,IAAMG,kBAAgC,GAAG,IAAIC,YAAY,CACvDF,aAAa,CAACG,MAAM,EACpBH,aAAa,CAACI,UAAU,EACxBJ,aAAa,CAACpH,MAAM,GAAG,CACzB,CAAC;EAID,IAAMyH,YAAY,GAAGnC,sBAAsB,CAACwB,OAAO,CAACY,KAAK;EACzD,IAAMZ,OAAO,IAAAJ,cAAA,GAAGX,IAAI,CAAC4B,QAAQ,cAAAjB,cAAA,uBAAbA,cAAA,CAAgBe,YAAY,CAAC;EAC7C,IAAMG,UAAU,GAAGd,OAAO,aAAPA,OAAO,uBAAPA,OAAO,CAAEe,MAAM;EAClC,IAAI,OAAOD,UAAU,KAAK,WAAW,EAAE;IAAA,IAAAE,YAAA,EAAAC,qBAAA;IACrC,IAAMC,KAAK,IAAAF,YAAA,GAAG/B,IAAI,CAACkC,MAAM,cAAAH,YAAA,uBAAXA,YAAA,CAAcF,UAAU,CAAC;IACvC,IAAMM,QAAQ,GAAGF,KAAK,aAALA,KAAK,uBAALA,KAAK,CAAEE,QAAQ;IAChC,IAAMC,WAAW,IAAAJ,qBAAA,GAAGhF,UAAU,CAACsB,IAAI,CAAC4D,MAAM,cAAAF,qBAAA,uBAAtBA,qBAAA,CAAyBH,UAAU,CAAC;IACxD,IAAIO,WAAW,EAAE;MACf,KAAK,IAAIT,KAAK,GAAG,CAAC,EAAEA,KAAK,GAAGL,kBAAkB,CAACrH,MAAM,EAAE0H,KAAK,IAAI,CAAC,EAAE;QACjE,IAAMpH,KAAK,GAAG8H,0BAA0B,CACtCD,WAAW,EACXD,QAAQ,EACRb,kBAAkB,EAClBK,KAAK,EACLpC,sBAAsB,CAAC+C,QACzB,CAAC;QACD1B,WAAW,CAAC2B,IAAI,CAAChI,KAAK,CAAC;MACzB;IACF;EACF;EAQA,IAAMiI,cAAwB,GAAG,EAAE;EAAC,IAAAC,KAAA,YAAAA,MAAA,EACC;IAAhC,IAAMC,SAAS,GAAAC,YAAA,CAAAC,EAAA;IAClB,IAAIjB,KAAK,GAAGzB,mBAAmB,CAAC2C,SAAS,CAAC,UAACC,IAAI;MAAA,OAAKA,IAAI,KAAKJ,SAAS;IAAA,EAAC;IACvE,IAAIf,KAAK,KAAK,CAAC,CAAC,EAAE;MAChBA,KAAK,GAAGzB,mBAAmB,CAACqC,IAAI,CAACG,SAAS,CAAC,GAAG,CAAC;IACjD;IACAF,cAAc,CAACD,IAAI,CAACZ,KAAK,CAAC;EAC5B,CAAC;EAND,SAAAiB,EAAA,MAAAD,YAAA,GAAwB/B,WAAW,EAAAgC,EAAA,GAAAD,YAAA,CAAA1I,MAAA,EAAA2I,EAAA;IAAAH,KAAA;EAAA;EAOnC,IAAMM,UAAU,GAAG,IAAIC,WAAW,CAACR,cAAc,CAAC;EAClD,IAAMS,WAAW,GACfjG,UAAU,CAACsB,IAAI,CAAC4E,OAAO,CAACX,IAAI,CAAC;IAC3BY,WAAW,EAAEJ,UAAU,CAACvB,MAAM;IAC9BC,UAAU,EAAE,CAAC;IACb2B,UAAU,EAAEL,UAAU,CAACK;EACzB,CAAC,CAAC,GAAG,CAAC;EACR,IAAMC,eAAe,GAAGrG,UAAU,CAACsG,aAAa,CAACP,UAAU,EAAEE,WAAW,EAAE,CAAC,CAAC;EAC5E,IAAMM,aAAa,GAAGvG,UAAU,CAACwG,WAAW,CAACH,eAAe,EAAE;IAC5DI,IAAI,EAAE,CAAC;IACPC,aAAa,EAAE,IAAAC,oCAAyB,EAACZ,UAAU,CAAC;IACpD9D,KAAK,EAAE8D,UAAU,CAAC9I;EACpB,CAAC,CAAC;EACFwG,SAAS,CAACS,UAAU,CAAC9B,aAAa,CAAC,GAAGmE,aAAa;AACrD;AAEA,SAASlB,0BAA0BA,CACjCD,WAAgB,EAChBD,QAA4B,EAC5Bb,kBAAgC,EAChCK,KAAa,EACbW,QAAgB,EAChB;EACA,IAAMsB,YAAY,GAAG;IACnBC,CAAC,EAAE;MAACC,MAAM,EAAE,CAAC;MAAEC,KAAK,EAAE;IAAC,CAAC;IACxBC,CAAC,EAAE;MAACF,MAAM,EAAE,CAAC;MAAEC,KAAK,EAAE;IAAC,CAAC;IACxBE,CAAC,EAAE;MAACH,MAAM,EAAE,CAAC;MAAEC,KAAK,EAAE;IAAE,CAAC;IACzBG,CAAC,EAAE;MAACJ,MAAM,EAAE,CAAC;MAAEC,KAAK,EAAE;IAAE;EAC1B,CAAC;EAED,IAAMI,CAAC,GAAG7C,kBAAkB,CAACK,KAAK,CAAC;EACnC,IAAMyC,CAAC,GAAG9C,kBAAkB,CAACK,KAAK,GAAG,CAAC,CAAC;EAEvC,IAAI0C,UAAU,GAAG,CAAC;EAClB,IAAIlC,QAAQ,KAAKA,QAAQ,CAACmC,OAAO,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC,IAAInC,QAAQ,CAACmC,OAAO,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC,CAAC,EAC7FD,UAAU,GAAG,CAAC;EAChB,IAAMP,MAAM,GAAGS,mBAAmB,CAACJ,CAAC,EAAEC,CAAC,EAAEhC,WAAW,EAAEiC,UAAU,CAAC;EACjE,IAAI9J,KAAK,GAAG,CAAC;EAAC,IAAAiK,UAAA,GAAAhL,0BAAA,CACE8I,QAAQ;IAAAmC,MAAA;EAAA;IAAxB,KAAAD,UAAA,CAAApK,CAAA,MAAAqK,MAAA,GAAAD,UAAA,CAAAnK,CAAA,IAAAC,IAAA,GAA0B;MAAA,IAAfoK,CAAC,GAAAD,MAAA,CAAAlK,KAAA;MACV,IAAMoK,GAAG,GAAGf,YAAY,CAACc,CAAC,CAAC;MAC3B,IAAME,GAAG,GAAGC,MAAM,CAACzC,WAAW,EAAE0B,MAAM,GAAGa,GAAG,CAACb,MAAM,CAAC;MACpDvJ,KAAK,IAAIqK,GAAG,IAAID,GAAG,CAACZ,KAAK;IAC3B;EAAC,SAAAjJ,GAAA;IAAA0J,UAAA,CAAAhK,CAAA,CAAAM,GAAA;EAAA;IAAA0J,UAAA,CAAA9J,CAAA;EAAA;EACD,OAAOH,KAAK;AACd;AAEA,SAASsK,MAAMA,CAACzC,WAAgB,EAAE0B,MAAc,EAAU;EACxD,IAAMgB,SAAS,GAAG,IAAAC,oBAAY,EAAC3C,WAAW,CAAC;EAC3C,IAAI0C,SAAS,CAAC5F,IAAI,CAACjF,MAAM,IAAI6J,MAAM,EAAE;IACnC,MAAM,IAAIkB,KAAK,IAAAlE,MAAA,CAAIgE,SAAS,CAAC5F,IAAI,CAACjF,MAAM,UAAA6G,MAAA,CAAOgD,MAAM,CAAE,CAAC;EAC1D;EACA,OAAOgB,SAAS,CAAC5F,IAAI,CAAC4E,MAAM,CAAC;AAC/B;AAEA,SAASS,mBAAmBA,CAC1BJ,CAAS,EACTC,CAAS,EACThC,WAAgB,EAER;EAAA,IADR6C,eAAuB,GAAAzI,SAAA,CAAAvC,MAAA,QAAAuC,SAAA,QAAA0I,SAAA,GAAA1I,SAAA,MAAG,CAAC;EAE3B,IAAM2I,CAAC,GAAG/C,WAAW,CAACgD,KAAK;EAC3B,IAAMC,EAAE,GAAG,IAAAC,UAAI,EAACnB,CAAC,CAAC,IAAIgB,CAAC,GAAG,CAAC,CAAC;EAC5B,IAAMI,IAAI,GAAGC,IAAI,CAACC,KAAK,CAACJ,EAAE,CAAC;EAE3B,IAAMK,CAAC,GAAGtD,WAAW,CAACuD,MAAM;EAC5B,IAAMC,EAAE,GAAG,IAAAN,UAAI,EAAClB,CAAC,CAAC,IAAIsB,CAAC,GAAG,CAAC,CAAC;EAC5B,IAAMG,IAAI,GAAGL,IAAI,CAACC,KAAK,CAACG,EAAE,CAAC;EAC3B,IAAMvB,UAAU,GAAGjC,WAAW,CAACiC,UAAU,GAAGjC,WAAW,CAACiC,UAAU,GAAGY,eAAe;EAEpF,IAAMnB,MAAM,GAAG,CAAC+B,IAAI,GAAGV,CAAC,GAAGI,IAAI,IAAIlB,UAAU;EAC7C,OAAOP,MAAM;AACf;AAOA,SAAS3F,sBAAsBA,CAC7BJ,aAAsE,EACtE+H,eAAuB,EACwB;EAC/C,KAAK,IAAMC,gBAAgB,IAAIhI,aAAa,EAAE;IAC5C,IAAMG,YAAY,GAAGH,aAAa,CAACgI,gBAAgB,CAAC;IAEpD,IAAI7H,YAAY,CAACmB,KAAK,KAAKyG,eAAe,EAAE;MAC1C,OAAO5H,YAAY;IACrB;EACF;EAEA,OAAO,IAAI;AACb;AAEA,SAASO,wBAAwBA,CAC/BJ,eAA0E,EAC1EyH,eAAuB,EAC0B;EACjD,KAAK,IAAME,mBAAmB,IAAI3H,eAAe,EAAE;IACjD,IAAMH,YAAY,GAAGG,eAAe,CAAC2H,mBAAmB,CAAC;IAEzD,IAAI9H,YAAY,CAACmB,KAAK,KAAKyG,eAAe,EAAE;MAC1C,OAAO5H,YAAY;IACrB;EACF;EAEA,OAAO,IAAI;AACb;AASA,SAAS6B,mBAAmBA,CAC1Bb,IAAgB,EAChBY,WAAuB,EACvBmG,YAAoB,EACV;EACV,IAAMC,YAAsB,GAAG,EAAE;EACjC,IAAMC,WAAW,GAAG,IAAIC,WAAW,CAAC,MAAM,CAAC;EAE3C,IAAIC,YAAY,GAAG,CAAC;EACpB,IAAMC,kBAAkB,GAAG,CAAC;EAE5B,KAAK,IAAI3E,KAAK,GAAG,CAAC,EAAEA,KAAK,GAAGsE,YAAY,EAAEtE,KAAK,EAAE,EAAE;IAEjD,IAAM4E,cAAc,GAClBzG,WAAW,CAAC,CAAC6B,KAAK,GAAG,CAAC,IAAI2E,kBAAkB,CAAC,GAAGxG,WAAW,CAAC6B,KAAK,GAAG2E,kBAAkB,CAAC;IACzF,IAAME,UAAU,GAAGtH,IAAI,CAACuH,QAAQ,CAACJ,YAAY,EAAEE,cAAc,GAAGF,YAAY,CAAC;IAC7E,IAAMK,eAAe,GAAGP,WAAW,CAAChK,MAAM,CAACqK,UAAU,CAAC;IAEtDN,YAAY,CAAC3D,IAAI,CAACmE,eAAe,CAAC;IAClCL,YAAY,IAAIE,cAAc;EAChC;EAEA,OAAOL,YAAY;AACrB"}
@@ -225,16 +225,16 @@ function loadImage(_x9, _x10, _x11, _x12, _x13) {
225
225
  }
226
226
  function _loadImage() {
227
227
  _loadImage = (0, _asyncToGenerator2.default)(_regenerator.default.mark(function _callee4(gltf, image, index, options, context) {
228
- var fetch, parse, arrayBuffer, uri, response, array, parsedImage;
228
+ var arrayBuffer, uri, fetch, response, array, parsedImage;
229
229
  return _regenerator.default.wrap(function _callee4$(_context4) {
230
230
  while (1) switch (_context4.prev = _context4.next) {
231
231
  case 0:
232
- fetch = context.fetch, parse = context.parse;
233
232
  if (!(image.uri && !image.hasOwnProperty('bufferView'))) {
234
233
  _context4.next = 10;
235
234
  break;
236
235
  }
237
236
  uri = (0, _resolveUrl.resolveUrl)(image.uri, options);
237
+ fetch = context.fetch;
238
238
  _context4.next = 5;
239
239
  return fetch(uri);
240
240
  case 5:
@@ -253,7 +253,7 @@ function _loadImage() {
253
253
  }
254
254
  (0, _assert.assert)(arrayBuffer, 'glTF image has no data');
255
255
  _context4.next = 14;
256
- return parse(arrayBuffer, [_images.ImageLoader, _textures.BasisLoader], _objectSpread(_objectSpread({}, options), {}, {
256
+ return (0, _loaderUtils.parseFromContext)(arrayBuffer, [_images.ImageLoader, _textures.BasisLoader], _objectSpread(_objectSpread({}, options), {}, {
257
257
  mimeType: image.mimeType,
258
258
  basis: options.basis || {
259
259
  format: (0, _textures.selectSupportedBasisFormat)()
@@ -1 +1 @@
1
- {"version":3,"file":"parse-gltf.js","names":["_loaderUtils","require","_images","_textures","_assert","_parseGlb","_resolveUrl","_getTypedArray","_gltfExtensions","_normalizeGltfV","ownKeys","object","enumerableOnly","keys","Object","getOwnPropertySymbols","symbols","filter","sym","getOwnPropertyDescriptor","enumerable","push","apply","_objectSpread","target","i","arguments","length","source","forEach","key","_defineProperty2","default","getOwnPropertyDescriptors","defineProperties","defineProperty","_createForOfIteratorHelper","o","allowArrayLike","it","Symbol","iterator","Array","isArray","_unsupportedIterableToArray","F","s","n","done","value","e","_e","f","TypeError","normalCompletion","didErr","err","call","step","next","_e2","return","minLen","_arrayLikeToArray","prototype","toString","slice","constructor","name","from","test","arr","len","arr2","isGLTF","arrayBuffer","options","byteOffset","isGLB","parseGLTF","_x","_x2","_parseGLTF","_asyncToGenerator2","_regenerator","mark","_callee","gltf","arrayBufferOrString","_options$gltf","_options$gltf2","_options$gltf3","context","_args","wrap","_callee$","_context","prev","undefined","parseGLTFContainerSync","normalizeGLTFV1","normalize","preprocessExtensions","loadBuffers","json","buffers","loadImages","decodeExtensions","abrupt","stop","data","uri","baseUri","ArrayBuffer","textDecoder","TextDecoder","decode","parseJSON","glb","parseGLBSync","assert","type","concat","_glb","fill","header","hasBinChunk","binChunks","byteLength","images","_x3","_x4","_x5","_loadBuffers","_callee2","buffer","_context$fetch","_response$arrayBuffer","fetch","response","_callee2$","_context2","resolveUrl","sent","_x6","_x7","_x8","_loadImages","_callee3","imageIndices","promises","_iterator2","_step2","imageIndex","_callee3$","_context3","getReferencesImageIndices","loadImage","Promise","all","Set","textures","_iterator","_step","texture","add","sort","_x9","_x10","_x11","_x12","_x13","_loadImage","_callee4","image","index","parse","array","parsedImage","_callee4$","_context4","hasOwnProperty","bufferView","Number","isFinite","getTypedArrayForBufferView","sliceArrayBuffer","ImageLoader","BasisLoader","mimeType","basis","format","selectSupportedBasisFormat","compressed","mipmaps","width","height"],"sources":["../../../../src/lib/parsers/parse-gltf.ts"],"sourcesContent":["/* eslint-disable camelcase, max-statements, no-restricted-globals */\nimport type {LoaderContext} from '@loaders.gl/loader-utils';\nimport type {GLTFLoaderOptions} from '../../gltf-loader';\nimport type {GLTFWithBuffers} from '../types/gltf-types';\nimport type {GLB} from '../types/glb-types';\nimport type {ParseGLBOptions} from './parse-glb';\n\nimport {parseJSON, sliceArrayBuffer} from '@loaders.gl/loader-utils';\nimport {ImageLoader} from '@loaders.gl/images';\nimport {BasisLoader, selectSupportedBasisFormat} from '@loaders.gl/textures';\n\nimport {assert} from '../utils/assert';\nimport {isGLB, parseGLBSync} from './parse-glb';\nimport {resolveUrl} from '../gltf-utils/resolve-url';\nimport {getTypedArrayForBufferView} from '../gltf-utils/get-typed-array';\nimport {preprocessExtensions, decodeExtensions} from '../api/gltf-extensions';\nimport {normalizeGLTFV1} from '../api/normalize-gltf-v1';\n\n/** */\nexport type ParseGLTFOptions = ParseGLBOptions & {\n normalize?: boolean;\n loadImages?: boolean;\n loadBuffers?: boolean;\n decompressMeshes?: boolean;\n excludeExtensions?: string[];\n\n /** @deprecated not supported in v4. `postProcessGLTF()` must be called by the application */\n postProcess?: false;\n};\n\n/** Check if an array buffer appears to contain GLTF data */\nexport function isGLTF(arrayBuffer: ArrayBuffer, options?: ParseGLTFOptions): boolean {\n const byteOffset = 0;\n return isGLB(arrayBuffer, byteOffset, options);\n}\n\nexport async function parseGLTF(\n gltf: GLTFWithBuffers,\n arrayBufferOrString,\n byteOffset = 0,\n options: GLTFLoaderOptions,\n context: LoaderContext\n): Promise<GLTFWithBuffers> {\n parseGLTFContainerSync(gltf, arrayBufferOrString, byteOffset, options);\n\n normalizeGLTFV1(gltf, {normalize: options?.gltf?.normalize});\n\n preprocessExtensions(gltf, options, context);\n\n // Load linked buffers asynchronously and decodes base64 buffers in parallel\n if (options?.gltf?.loadBuffers && gltf.json.buffers) {\n await loadBuffers(gltf, options, context);\n }\n\n // loadImages and decodeExtensions should not be running in parallel, because\n // decodeExtensions uses data from images taken during the loadImages call.\n if (options?.gltf?.loadImages) {\n await loadImages(gltf, options, context);\n }\n\n await decodeExtensions(gltf, options, context);\n\n return gltf;\n}\n\n/**\n *\n * @param gltf\n * @param data - can be ArrayBuffer (GLB), ArrayBuffer (Binary JSON), String (JSON), or Object (parsed JSON)\n * @param byteOffset\n * @param options\n */\nfunction parseGLTFContainerSync(gltf, data, byteOffset, options) {\n // Initialize gltf container\n if (options.uri) {\n gltf.baseUri = options.uri;\n }\n\n // If data is binary and starting with magic bytes, assume binary JSON text, convert to string\n if (data instanceof ArrayBuffer && !isGLB(data, byteOffset, options)) {\n const textDecoder = new TextDecoder();\n data = textDecoder.decode(data);\n }\n\n if (typeof data === 'string') {\n // If string, try to parse as JSON\n gltf.json = parseJSON(data);\n } else if (data instanceof ArrayBuffer) {\n // If still ArrayBuffer, parse as GLB container\n const glb: GLB = {} as GLB;\n byteOffset = parseGLBSync(glb, data, byteOffset, options.glb);\n\n assert(glb.type === 'glTF', `Invalid GLB magic string ${glb.type}`);\n\n gltf._glb = glb;\n gltf.json = glb.json;\n } else {\n assert(false, 'GLTF: must be ArrayBuffer or string');\n }\n\n // Populate buffers\n // Create an external buffers array to hold binary data\n const buffers = gltf.json.buffers || [];\n gltf.buffers = new Array(buffers.length).fill(null);\n\n // Populates JSON and some bin chunk info\n if (gltf._glb && gltf._glb.header.hasBinChunk) {\n const {binChunks} = gltf._glb;\n gltf.buffers[0] = {\n arrayBuffer: binChunks[0].arrayBuffer,\n byteOffset: binChunks[0].byteOffset,\n byteLength: binChunks[0].byteLength\n };\n\n // TODO - this modifies JSON and is a post processing thing\n // gltf.json.buffers[0].data = gltf.buffers[0].arrayBuffer;\n // gltf.json.buffers[0].byteOffset = gltf.buffers[0].byteOffset;\n }\n\n // Populate images\n const images = gltf.json.images || [];\n gltf.images = new Array(images.length).fill({});\n}\n\n/** Asynchronously fetch and parse buffers, store in buffers array outside of json\n * TODO - traverse gltf and determine which buffers are actually needed\n */\nasync function loadBuffers(gltf: GLTFWithBuffers, options, context: LoaderContext) {\n // TODO\n const buffers = gltf.json.buffers || [];\n for (let i = 0; i < buffers.length; ++i) {\n const buffer = buffers[i];\n if (buffer.uri) {\n const {fetch} = context;\n assert(fetch);\n\n const uri = resolveUrl(buffer.uri, options);\n const response = await context?.fetch?.(uri);\n const arrayBuffer = await response?.arrayBuffer?.();\n\n gltf.buffers[i] = {\n arrayBuffer,\n byteOffset: 0,\n byteLength: arrayBuffer.byteLength\n };\n\n delete buffer.uri;\n } else if (gltf.buffers[i] === null) {\n gltf.buffers[i] = {\n arrayBuffer: new ArrayBuffer(buffer.byteLength),\n byteOffset: 0,\n byteLength: buffer.byteLength\n };\n }\n }\n}\n\n/**\n * Loads all images\n * TODO - traverse gltf and determine which images are actually needed\n * @param gltf\n * @param options\n * @param context\n * @returns\n */\nasync function loadImages(gltf: GLTFWithBuffers, options, context: LoaderContext) {\n const imageIndices = getReferencesImageIndices(gltf);\n\n const images = gltf.json.images || [];\n\n const promises: Promise<any>[] = [];\n for (const imageIndex of imageIndices) {\n promises.push(loadImage(gltf, images[imageIndex], imageIndex, options, context));\n }\n\n return await Promise.all(promises);\n}\n\n/** Make sure we only load images that are actually referenced by textures */\nfunction getReferencesImageIndices(gltf: GLTFWithBuffers): number[] {\n const imageIndices = new Set<number>();\n\n const textures = gltf.json.textures || [];\n for (const texture of textures) {\n if (texture.source !== undefined) {\n imageIndices.add(texture.source);\n }\n }\n\n return Array.from(imageIndices).sort();\n}\n\n/** Asynchronously fetches and parses one image, store in images array outside of json */\nasync function loadImage(\n gltf: GLTFWithBuffers,\n image,\n index: number,\n options,\n context: LoaderContext\n) {\n const {fetch, parse} = context;\n\n let arrayBuffer;\n\n if (image.uri && !image.hasOwnProperty('bufferView')) {\n const uri = resolveUrl(image.uri, options);\n const response = await fetch(uri);\n arrayBuffer = await response.arrayBuffer();\n image.bufferView = {\n data: arrayBuffer\n };\n }\n\n if (Number.isFinite(image.bufferView)) {\n const array = getTypedArrayForBufferView(gltf.json, gltf.buffers, image.bufferView);\n arrayBuffer = sliceArrayBuffer(array.buffer, array.byteOffset, array.byteLength);\n }\n\n assert(arrayBuffer, 'glTF image has no data');\n\n // Call `parse`\n let parsedImage = await parse(\n arrayBuffer,\n [ImageLoader, BasisLoader],\n {\n ...options,\n mimeType: image.mimeType,\n basis: options.basis || {format: selectSupportedBasisFormat()}\n },\n context\n );\n\n if (parsedImage && parsedImage[0]) {\n parsedImage = {\n compressed: true,\n mipmaps: false,\n width: parsedImage[0].width,\n height: parsedImage[0].height,\n data: parsedImage[0]\n };\n }\n // TODO making sure ImageLoader is overridable by using array of loaders\n // const parsedImage = await parse(arrayBuffer, [ImageLoader]);\n\n // Store the loaded image\n gltf.images = gltf.images || [];\n gltf.images[index] = parsedImage;\n}\n"],"mappings":"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"}
1
+ {"version":3,"file":"parse-gltf.js","names":["_loaderUtils","require","_images","_textures","_assert","_parseGlb","_resolveUrl","_getTypedArray","_gltfExtensions","_normalizeGltfV","ownKeys","object","enumerableOnly","keys","Object","getOwnPropertySymbols","symbols","filter","sym","getOwnPropertyDescriptor","enumerable","push","apply","_objectSpread","target","i","arguments","length","source","forEach","key","_defineProperty2","default","getOwnPropertyDescriptors","defineProperties","defineProperty","_createForOfIteratorHelper","o","allowArrayLike","it","Symbol","iterator","Array","isArray","_unsupportedIterableToArray","F","s","n","done","value","e","_e","f","TypeError","normalCompletion","didErr","err","call","step","next","_e2","return","minLen","_arrayLikeToArray","prototype","toString","slice","constructor","name","from","test","arr","len","arr2","isGLTF","arrayBuffer","options","byteOffset","isGLB","parseGLTF","_x","_x2","_parseGLTF","_asyncToGenerator2","_regenerator","mark","_callee","gltf","arrayBufferOrString","_options$gltf","_options$gltf2","_options$gltf3","context","_args","wrap","_callee$","_context","prev","undefined","parseGLTFContainerSync","normalizeGLTFV1","normalize","preprocessExtensions","loadBuffers","json","buffers","loadImages","decodeExtensions","abrupt","stop","data","uri","baseUri","ArrayBuffer","textDecoder","TextDecoder","decode","parseJSON","glb","parseGLBSync","assert","type","concat","_glb","fill","header","hasBinChunk","binChunks","byteLength","images","_x3","_x4","_x5","_loadBuffers","_callee2","buffer","_context$fetch","_response$arrayBuffer","fetch","response","_callee2$","_context2","resolveUrl","sent","_x6","_x7","_x8","_loadImages","_callee3","imageIndices","promises","_iterator2","_step2","imageIndex","_callee3$","_context3","getReferencesImageIndices","loadImage","Promise","all","Set","textures","_iterator","_step","texture","add","sort","_x9","_x10","_x11","_x12","_x13","_loadImage","_callee4","image","index","array","parsedImage","_callee4$","_context4","hasOwnProperty","bufferView","Number","isFinite","getTypedArrayForBufferView","sliceArrayBuffer","parseFromContext","ImageLoader","BasisLoader","mimeType","basis","format","selectSupportedBasisFormat","compressed","mipmaps","width","height"],"sources":["../../../../src/lib/parsers/parse-gltf.ts"],"sourcesContent":["/* eslint-disable camelcase, max-statements, no-restricted-globals */\nimport type {LoaderContext} from '@loaders.gl/loader-utils';\nimport type {GLTFLoaderOptions} from '../../gltf-loader';\nimport type {GLTFWithBuffers} from '../types/gltf-types';\nimport type {GLB} from '../types/glb-types';\nimport type {ParseGLBOptions} from './parse-glb';\n\nimport type {ImageType, TextureLevel} from '@loaders.gl/schema';\nimport {parseJSON, sliceArrayBuffer, parseFromContext} from '@loaders.gl/loader-utils';\nimport {ImageLoader} from '@loaders.gl/images';\nimport {BasisLoader, selectSupportedBasisFormat} from '@loaders.gl/textures';\n\nimport {assert} from '../utils/assert';\nimport {isGLB, parseGLBSync} from './parse-glb';\nimport {resolveUrl} from '../gltf-utils/resolve-url';\nimport {getTypedArrayForBufferView} from '../gltf-utils/get-typed-array';\nimport {preprocessExtensions, decodeExtensions} from '../api/gltf-extensions';\nimport {normalizeGLTFV1} from '../api/normalize-gltf-v1';\n\n/** */\nexport type ParseGLTFOptions = ParseGLBOptions & {\n normalize?: boolean;\n loadImages?: boolean;\n loadBuffers?: boolean;\n decompressMeshes?: boolean;\n excludeExtensions?: string[];\n\n /** @deprecated not supported in v4. `postProcessGLTF()` must be called by the application */\n postProcess?: false;\n};\n\n/** Check if an array buffer appears to contain GLTF data */\nexport function isGLTF(arrayBuffer: ArrayBuffer, options?: ParseGLTFOptions): boolean {\n const byteOffset = 0;\n return isGLB(arrayBuffer, byteOffset, options);\n}\n\nexport async function parseGLTF(\n gltf: GLTFWithBuffers,\n arrayBufferOrString,\n byteOffset = 0,\n options: GLTFLoaderOptions,\n context: LoaderContext\n): Promise<GLTFWithBuffers> {\n parseGLTFContainerSync(gltf, arrayBufferOrString, byteOffset, options);\n\n normalizeGLTFV1(gltf, {normalize: options?.gltf?.normalize});\n\n preprocessExtensions(gltf, options, context);\n\n // Load linked buffers asynchronously and decodes base64 buffers in parallel\n if (options?.gltf?.loadBuffers && gltf.json.buffers) {\n await loadBuffers(gltf, options, context);\n }\n\n // loadImages and decodeExtensions should not be running in parallel, because\n // decodeExtensions uses data from images taken during the loadImages call.\n if (options?.gltf?.loadImages) {\n await loadImages(gltf, options, context);\n }\n\n await decodeExtensions(gltf, options, context);\n\n return gltf;\n}\n\n/**\n *\n * @param gltf\n * @param data - can be ArrayBuffer (GLB), ArrayBuffer (Binary JSON), String (JSON), or Object (parsed JSON)\n * @param byteOffset\n * @param options\n */\nfunction parseGLTFContainerSync(gltf, data, byteOffset, options) {\n // Initialize gltf container\n if (options.uri) {\n gltf.baseUri = options.uri;\n }\n\n // If data is binary and starting with magic bytes, assume binary JSON text, convert to string\n if (data instanceof ArrayBuffer && !isGLB(data, byteOffset, options)) {\n const textDecoder = new TextDecoder();\n data = textDecoder.decode(data);\n }\n\n if (typeof data === 'string') {\n // If string, try to parse as JSON\n gltf.json = parseJSON(data);\n } else if (data instanceof ArrayBuffer) {\n // If still ArrayBuffer, parse as GLB container\n const glb: GLB = {} as GLB;\n byteOffset = parseGLBSync(glb, data, byteOffset, options.glb);\n\n assert(glb.type === 'glTF', `Invalid GLB magic string ${glb.type}`);\n\n gltf._glb = glb;\n gltf.json = glb.json;\n } else {\n assert(false, 'GLTF: must be ArrayBuffer or string');\n }\n\n // Populate buffers\n // Create an external buffers array to hold binary data\n const buffers = gltf.json.buffers || [];\n gltf.buffers = new Array(buffers.length).fill(null);\n\n // Populates JSON and some bin chunk info\n if (gltf._glb && gltf._glb.header.hasBinChunk) {\n const {binChunks} = gltf._glb;\n gltf.buffers[0] = {\n arrayBuffer: binChunks[0].arrayBuffer,\n byteOffset: binChunks[0].byteOffset,\n byteLength: binChunks[0].byteLength\n };\n\n // TODO - this modifies JSON and is a post processing thing\n // gltf.json.buffers[0].data = gltf.buffers[0].arrayBuffer;\n // gltf.json.buffers[0].byteOffset = gltf.buffers[0].byteOffset;\n }\n\n // Populate images\n const images = gltf.json.images || [];\n gltf.images = new Array(images.length).fill({});\n}\n\n/** Asynchronously fetch and parse buffers, store in buffers array outside of json\n * TODO - traverse gltf and determine which buffers are actually needed\n */\nasync function loadBuffers(gltf: GLTFWithBuffers, options, context: LoaderContext) {\n // TODO\n const buffers = gltf.json.buffers || [];\n for (let i = 0; i < buffers.length; ++i) {\n const buffer = buffers[i];\n if (buffer.uri) {\n const {fetch} = context;\n assert(fetch);\n\n const uri = resolveUrl(buffer.uri, options);\n const response = await context?.fetch?.(uri);\n const arrayBuffer = await response?.arrayBuffer?.();\n\n gltf.buffers[i] = {\n arrayBuffer,\n byteOffset: 0,\n byteLength: arrayBuffer.byteLength\n };\n\n delete buffer.uri;\n } else if (gltf.buffers[i] === null) {\n gltf.buffers[i] = {\n arrayBuffer: new ArrayBuffer(buffer.byteLength),\n byteOffset: 0,\n byteLength: buffer.byteLength\n };\n }\n }\n}\n\n/**\n * Loads all images\n * TODO - traverse gltf and determine which images are actually needed\n * @param gltf\n * @param options\n * @param context\n * @returns\n */\nasync function loadImages(gltf: GLTFWithBuffers, options, context: LoaderContext) {\n const imageIndices = getReferencesImageIndices(gltf);\n\n const images = gltf.json.images || [];\n\n const promises: Promise<any>[] = [];\n for (const imageIndex of imageIndices) {\n promises.push(loadImage(gltf, images[imageIndex], imageIndex, options, context));\n }\n\n return await Promise.all(promises);\n}\n\n/** Make sure we only load images that are actually referenced by textures */\nfunction getReferencesImageIndices(gltf: GLTFWithBuffers): number[] {\n const imageIndices = new Set<number>();\n\n const textures = gltf.json.textures || [];\n for (const texture of textures) {\n if (texture.source !== undefined) {\n imageIndices.add(texture.source);\n }\n }\n\n return Array.from(imageIndices).sort();\n}\n\n/** Asynchronously fetches and parses one image, store in images array outside of json */\nasync function loadImage(\n gltf: GLTFWithBuffers,\n image,\n index: number,\n options,\n context: LoaderContext\n) {\n let arrayBuffer;\n\n if (image.uri && !image.hasOwnProperty('bufferView')) {\n const uri = resolveUrl(image.uri, options);\n\n const {fetch} = context;\n const response = await fetch(uri);\n\n arrayBuffer = await response.arrayBuffer();\n image.bufferView = {\n data: arrayBuffer\n };\n }\n\n if (Number.isFinite(image.bufferView)) {\n const array = getTypedArrayForBufferView(gltf.json, gltf.buffers, image.bufferView);\n arrayBuffer = sliceArrayBuffer(array.buffer, array.byteOffset, array.byteLength);\n }\n\n assert(arrayBuffer, 'glTF image has no data');\n\n // Call `parse`\n let parsedImage = (await parseFromContext(\n arrayBuffer,\n [ImageLoader, BasisLoader],\n {\n ...options,\n mimeType: image.mimeType,\n basis: options.basis || {format: selectSupportedBasisFormat()}\n },\n context\n )) as ImageType | TextureLevel[][];\n\n if (parsedImage && parsedImage[0]) {\n parsedImage = {\n compressed: true,\n // @ts-expect-error\n mipmaps: false,\n width: parsedImage[0].width,\n height: parsedImage[0].height,\n data: parsedImage[0]\n };\n }\n // TODO making sure ImageLoader is overridable by using array of loaders\n // const parsedImage = await parse(arrayBuffer, [ImageLoader]);\n\n // Store the loaded image\n gltf.images = gltf.images || [];\n // @ts-expect-error TODO - sort out image typing asap\n gltf.images[index] = parsedImage;\n}\n"],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ "use strict";
2
+ //# sourceMappingURL=gltf-ext-mesh-features-schema.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"gltf-ext-mesh-features-schema.js","names":[],"sources":["../../../../src/lib/types/gltf-ext-mesh-features-schema.ts"],"sourcesContent":["import {GLTFTextureInfoMetadata} from './gltf-json-schema';\n/* eslint-disable camelcase */\n\n/**\n * EXT_mesh_features extension types\n * This is a primitive-level extension\n * @see https://github.com/CesiumGS/glTF/tree/3d-tiles-next/extensions/2.0/Vendor/EXT_mesh_features\n * or https://github.com/CesiumGS/glTF/blob/c38f7f37e894004353c15cd0481bc5b7381ce841/extensions/2.0/Vendor/EXT_mesh_features/schema/mesh.primitive.EXT_mesh_features.schema.json\n * An object describing feature IDs for a mesh primitive.\n */\nexport type GLTF_EXT_mesh_features = {\n /** An array of feature ID sets. */\n featureIds: GLTF_EXT_mesh_features_featureId[];\n extensions?: Record<string, unknown>;\n extras?: unknown;\n /** For internal usage */\n dataAttributeNames?: string[];\n};\n\n/**\n * @see https://github.com/CesiumGS/glTF/blob/c38f7f37e894004353c15cd0481bc5b7381ce841/extensions/2.0/Vendor/EXT_mesh_features/schema/featureId.schema.json\n * Feature IDs stored in an attribute or texture.\n */\nexport type GLTF_EXT_mesh_features_featureId = {\n /** The number of unique features in the attribute or texture. */\n featureCount: number;\n /** A value that indicates that no feature is associated with this vertex or texel. */\n nullFeatureId?: number;\n /** A label assigned to this feature ID set. Labels must be alphanumeric identifiers matching the regular expression `^[a-zA-Z_][a-zA-Z0-9_]*$`. */\n label?: string;\n /**\n * An attribute containing feature IDs.\n * When `attribute` and `texture` are omitted the feature IDs are assigned to vertices by their index.\n * @see https://github.com/CesiumGS/glTF/blob/3d-tiles-next/extensions/2.0/Vendor/EXT_mesh_features/schema/featureIdAttribute.schema.json\n * An integer value used to construct a string in the format `_FEATURE_ID_<set index>` which is a reference to a key in `mesh.primitives.attributes`\n * (e.g. a value of `0` corresponds to `_FEATURE_ID_0`).\n */\n attribute?: number;\n /** A texture containing feature IDs. */\n texture?: GLTFTextureInfoMetadata;\n /** The index of the property table containing per-feature property values. Only applicable when using the `EXT_structural_metadata` extension. */\n propertyTable?: number;\n extensions?: Record<string, unknown>;\n extras?: unknown;\n\n /** For internal usage */\n data?: unknown;\n};\n"],"mappings":""}
@@ -0,0 +1,2 @@
1
+ "use strict";
2
+ //# sourceMappingURL=gltf-ext-structural-metadata-schema.js.map