@loaders.gl/gltf 3.4.14 → 3.4.15

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 (65) hide show
  1. package/dist/es5/bundle.js +1 -1
  2. package/dist/es5/bundle.js.map +1 -1
  3. package/dist/es5/glb-loader.js +10 -26
  4. package/dist/es5/glb-loader.js.map +1 -1
  5. package/dist/es5/glb-writer.js +9 -8
  6. package/dist/es5/glb-writer.js.map +1 -1
  7. package/dist/es5/gltf-loader.js +18 -40
  8. package/dist/es5/gltf-loader.js.map +1 -1
  9. package/dist/es5/gltf-writer.js +10 -9
  10. package/dist/es5/gltf-writer.js.map +1 -1
  11. package/dist/es5/index.js +7 -7
  12. package/dist/es5/lib/api/gltf-extensions.js +19 -82
  13. package/dist/es5/lib/api/gltf-extensions.js.map +1 -1
  14. package/dist/es5/lib/api/gltf-scenegraph.js +395 -524
  15. package/dist/es5/lib/api/gltf-scenegraph.js.map +1 -1
  16. package/dist/es5/lib/api/normalize-gltf-v1.js +141 -259
  17. package/dist/es5/lib/api/normalize-gltf-v1.js.map +1 -1
  18. package/dist/es5/lib/api/post-process-gltf.js +263 -337
  19. package/dist/es5/lib/api/post-process-gltf.js.map +1 -1
  20. package/dist/es5/lib/encoders/encode-glb.js +20 -21
  21. package/dist/es5/lib/encoders/encode-glb.js.map +1 -1
  22. package/dist/es5/lib/encoders/encode-gltf.js +3 -3
  23. package/dist/es5/lib/encoders/encode-gltf.js.map +1 -1
  24. package/dist/es5/lib/extensions/EXT_meshopt_compression.js +34 -79
  25. package/dist/es5/lib/extensions/EXT_meshopt_compression.js.map +1 -1
  26. package/dist/es5/lib/extensions/EXT_texture_webp.js +11 -21
  27. package/dist/es5/lib/extensions/EXT_texture_webp.js.map +1 -1
  28. package/dist/es5/lib/extensions/KHR_binary_gltf.js +11 -21
  29. package/dist/es5/lib/extensions/KHR_binary_gltf.js.map +1 -1
  30. package/dist/es5/lib/extensions/KHR_draco_mesh_compression.js +76 -201
  31. package/dist/es5/lib/extensions/KHR_draco_mesh_compression.js.map +1 -1
  32. package/dist/es5/lib/extensions/KHR_texture_basisu.js +11 -21
  33. package/dist/es5/lib/extensions/KHR_texture_basisu.js.map +1 -1
  34. package/dist/es5/lib/extensions/KHR_texture_transform.js +75 -114
  35. package/dist/es5/lib/extensions/KHR_texture_transform.js.map +1 -1
  36. package/dist/es5/lib/extensions/deprecated/EXT_feature_metadata.js +31 -48
  37. package/dist/es5/lib/extensions/deprecated/EXT_feature_metadata.js.map +1 -1
  38. package/dist/es5/lib/extensions/deprecated/KHR_lights_punctual.js +37 -84
  39. package/dist/es5/lib/extensions/deprecated/KHR_lights_punctual.js.map +1 -1
  40. package/dist/es5/lib/extensions/deprecated/KHR_materials_unlit.js +24 -57
  41. package/dist/es5/lib/extensions/deprecated/KHR_materials_unlit.js.map +1 -1
  42. package/dist/es5/lib/extensions/deprecated/KHR_techniques_webgl.js +33 -75
  43. package/dist/es5/lib/extensions/deprecated/KHR_techniques_webgl.js.map +1 -1
  44. package/dist/es5/lib/gltf-utils/get-typed-array.js +6 -6
  45. package/dist/es5/lib/gltf-utils/get-typed-array.js.map +1 -1
  46. package/dist/es5/lib/gltf-utils/gltf-attribute-utils.js +19 -18
  47. package/dist/es5/lib/gltf-utils/gltf-attribute-utils.js.map +1 -1
  48. package/dist/es5/lib/gltf-utils/gltf-constants.js +7 -7
  49. package/dist/es5/lib/gltf-utils/gltf-constants.js.map +1 -1
  50. package/dist/es5/lib/gltf-utils/gltf-utils.js +28 -31
  51. package/dist/es5/lib/gltf-utils/gltf-utils.js.map +1 -1
  52. package/dist/es5/lib/gltf-utils/resolve-url.js +2 -2
  53. package/dist/es5/lib/gltf-utils/resolve-url.js.map +1 -1
  54. package/dist/es5/lib/parsers/parse-glb.js +35 -34
  55. package/dist/es5/lib/parsers/parse-glb.js.map +1 -1
  56. package/dist/es5/lib/parsers/parse-gltf.js +108 -230
  57. package/dist/es5/lib/parsers/parse-gltf.js.map +1 -1
  58. package/dist/es5/lib/utils/version.js +1 -1
  59. package/dist/es5/lib/utils/version.js.map +1 -1
  60. package/dist/es5/meshopt/meshopt-decoder.js +48 -162
  61. package/dist/es5/meshopt/meshopt-decoder.js.map +1 -1
  62. package/dist/es5/webp/webp.js +17 -69
  63. package/dist/es5/webp/webp.js.map +1 -1
  64. package/dist/esm/lib/utils/version.js +1 -1
  65. package/package.json +6 -6
@@ -6,161 +6,123 @@ Object.defineProperty(exports, "__esModule", {
6
6
  });
7
7
  exports.decode = decode;
8
8
  exports.name = void 0;
9
- var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
10
- var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
11
- var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
12
9
  var _core = require("@math.gl/core");
13
10
  var _gltfUtils = require("../gltf-utils/gltf-utils");
14
11
  var _gltfConstants = require("../gltf-utils/gltf-constants");
15
12
  var _gltfScenegraph = _interopRequireDefault(require("../api/gltf-scenegraph"));
16
- function _createForOfIteratorHelper(o, allowArrayLike) { var it = typeof Symbol !== "undefined" && o[Symbol.iterator] || o["@@iterator"]; if (!it) { if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === "number") { if (it) o = it; var i = 0; var F = function F() {}; return { s: F, n: function n() { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }, e: function e(_e) { throw _e; }, f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var normalCompletion = true, didErr = false, err; return { s: function s() { it = it.call(o); }, n: function n() { var step = it.next(); normalCompletion = step.done; return step; }, e: function e(_e2) { didErr = true; err = _e2; }, f: function f() { try { if (!normalCompletion && it.return != null) it.return(); } finally { if (didErr) throw err; } } }; }
17
- function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
18
- function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }
19
- var EXT_MESHOPT_TRANSFORM = 'KHR_texture_transform';
20
- var name = EXT_MESHOPT_TRANSFORM;
13
+ const EXT_MESHOPT_TRANSFORM = 'KHR_texture_transform';
14
+ const name = EXT_MESHOPT_TRANSFORM;
21
15
  exports.name = name;
22
- var scratchVector = new _core.Vector3();
23
- var scratchRotationMatrix = new _core.Matrix3();
24
- var scratchScaleMatrix = new _core.Matrix3();
25
- function decode(_x, _x2) {
26
- return _decode.apply(this, arguments);
27
- }
28
- function _decode() {
29
- _decode = (0, _asyncToGenerator2.default)(_regenerator.default.mark(function _callee(gltfData, options) {
30
- var gltfScenegraph, extension, materials, i;
31
- return _regenerator.default.wrap(function _callee$(_context) {
32
- while (1) switch (_context.prev = _context.next) {
33
- case 0:
34
- gltfScenegraph = new _gltfScenegraph.default(gltfData);
35
- extension = gltfScenegraph.getExtension(EXT_MESHOPT_TRANSFORM);
36
- if (extension) {
37
- _context.next = 4;
38
- break;
39
- }
40
- return _context.abrupt("return");
41
- case 4:
42
- materials = gltfData.json.materials || [];
43
- for (i = 0; i < materials.length; i++) {
44
- transformTexCoords(i, gltfData);
45
- }
46
- case 6:
47
- case "end":
48
- return _context.stop();
49
- }
50
- }, _callee);
51
- }));
52
- return _decode.apply(this, arguments);
16
+ const scratchVector = new _core.Vector3();
17
+ const scratchRotationMatrix = new _core.Matrix3();
18
+ const scratchScaleMatrix = new _core.Matrix3();
19
+ async function decode(gltfData, options) {
20
+ const gltfScenegraph = new _gltfScenegraph.default(gltfData);
21
+ const extension = gltfScenegraph.getExtension(EXT_MESHOPT_TRANSFORM);
22
+ if (!extension) {
23
+ return;
24
+ }
25
+ const materials = gltfData.json.materials || [];
26
+ for (let i = 0; i < materials.length; i++) {
27
+ transformTexCoords(i, gltfData);
28
+ }
53
29
  }
54
30
  function transformTexCoords(materialIndex, gltfData) {
55
31
  var _gltfData$json$materi, _material$pbrMetallic, _material$pbrMetallic2;
56
- var processedTexCoords = [];
57
- var material = (_gltfData$json$materi = gltfData.json.materials) === null || _gltfData$json$materi === void 0 ? void 0 : _gltfData$json$materi[materialIndex];
58
- var baseColorTexture = material === null || material === void 0 ? void 0 : (_material$pbrMetallic = material.pbrMetallicRoughness) === null || _material$pbrMetallic === void 0 ? void 0 : _material$pbrMetallic.baseColorTexture;
32
+ const processedTexCoords = [];
33
+ const material = (_gltfData$json$materi = gltfData.json.materials) === null || _gltfData$json$materi === void 0 ? void 0 : _gltfData$json$materi[materialIndex];
34
+ const baseColorTexture = material === null || material === void 0 ? void 0 : (_material$pbrMetallic = material.pbrMetallicRoughness) === null || _material$pbrMetallic === void 0 ? void 0 : _material$pbrMetallic.baseColorTexture;
59
35
  if (baseColorTexture) {
60
36
  transformPrimitives(gltfData, materialIndex, baseColorTexture, processedTexCoords);
61
37
  }
62
- var emisiveTexture = material === null || material === void 0 ? void 0 : material.emissiveTexture;
38
+ const emisiveTexture = material === null || material === void 0 ? void 0 : material.emissiveTexture;
63
39
  if (emisiveTexture) {
64
40
  transformPrimitives(gltfData, materialIndex, emisiveTexture, processedTexCoords);
65
41
  }
66
- var normalTexture = material === null || material === void 0 ? void 0 : material.normalTexture;
42
+ const normalTexture = material === null || material === void 0 ? void 0 : material.normalTexture;
67
43
  if (normalTexture) {
68
44
  transformPrimitives(gltfData, materialIndex, normalTexture, processedTexCoords);
69
45
  }
70
- var occlusionTexture = material === null || material === void 0 ? void 0 : material.occlusionTexture;
46
+ const occlusionTexture = material === null || material === void 0 ? void 0 : material.occlusionTexture;
71
47
  if (occlusionTexture) {
72
48
  transformPrimitives(gltfData, materialIndex, occlusionTexture, processedTexCoords);
73
49
  }
74
- var metallicRoughnessTexture = material === null || material === void 0 ? void 0 : (_material$pbrMetallic2 = material.pbrMetallicRoughness) === null || _material$pbrMetallic2 === void 0 ? void 0 : _material$pbrMetallic2.metallicRoughnessTexture;
50
+ const metallicRoughnessTexture = material === null || material === void 0 ? void 0 : (_material$pbrMetallic2 = material.pbrMetallicRoughness) === null || _material$pbrMetallic2 === void 0 ? void 0 : _material$pbrMetallic2.metallicRoughnessTexture;
75
51
  if (metallicRoughnessTexture) {
76
52
  transformPrimitives(gltfData, materialIndex, metallicRoughnessTexture, processedTexCoords);
77
53
  }
78
54
  }
79
55
  function transformPrimitives(gltfData, materialIndex, texture, processedTexCoords) {
80
- var transformParameters = getTransformParameters(texture, processedTexCoords);
56
+ const transformParameters = getTransformParameters(texture, processedTexCoords);
81
57
  if (!transformParameters) {
82
58
  return;
83
59
  }
84
- var meshes = gltfData.json.meshes || [];
85
- var _iterator = _createForOfIteratorHelper(meshes),
86
- _step;
87
- try {
88
- for (_iterator.s(); !(_step = _iterator.n()).done;) {
89
- var mesh = _step.value;
90
- var _iterator2 = _createForOfIteratorHelper(mesh.primitives),
91
- _step2;
92
- try {
93
- for (_iterator2.s(); !(_step2 = _iterator2.n()).done;) {
94
- var primitive = _step2.value;
95
- var material = primitive.material;
96
- if (Number.isFinite(material) && materialIndex === material) {
97
- transformPrimitive(gltfData, primitive, transformParameters);
98
- }
99
- }
100
- } catch (err) {
101
- _iterator2.e(err);
102
- } finally {
103
- _iterator2.f();
60
+ const meshes = gltfData.json.meshes || [];
61
+ for (const mesh of meshes) {
62
+ for (const primitive of mesh.primitives) {
63
+ const material = primitive.material;
64
+ if (Number.isFinite(material) && materialIndex === material) {
65
+ transformPrimitive(gltfData, primitive, transformParameters);
104
66
  }
105
67
  }
106
- } catch (err) {
107
- _iterator.e(err);
108
- } finally {
109
- _iterator.f();
110
68
  }
111
69
  }
112
70
  function getTransformParameters(texture, processedTexCoords) {
113
71
  var _texture$extensions;
114
- var textureInfo = (_texture$extensions = texture.extensions) === null || _texture$extensions === void 0 ? void 0 : _texture$extensions[EXT_MESHOPT_TRANSFORM];
115
- var _texture$texCoord = texture.texCoord,
116
- originalTexCoord = _texture$texCoord === void 0 ? 0 : _texture$texCoord;
117
- var _textureInfo$texCoord = textureInfo.texCoord,
118
- texCoord = _textureInfo$texCoord === void 0 ? originalTexCoord : _textureInfo$texCoord;
119
- var isProcessed = processedTexCoords.findIndex(function (_ref) {
120
- var _ref2 = (0, _slicedToArray2.default)(_ref, 2),
121
- original = _ref2[0],
122
- newTexCoord = _ref2[1];
72
+ const textureInfo = (_texture$extensions = texture.extensions) === null || _texture$extensions === void 0 ? void 0 : _texture$extensions[EXT_MESHOPT_TRANSFORM];
73
+ const {
74
+ texCoord: originalTexCoord = 0
75
+ } = texture;
76
+ const {
77
+ texCoord = originalTexCoord
78
+ } = textureInfo;
79
+ const isProcessed = processedTexCoords.findIndex(_ref => {
80
+ let [original, newTexCoord] = _ref;
123
81
  return original === originalTexCoord && newTexCoord === texCoord;
124
82
  }) !== -1;
125
83
  if (!isProcessed) {
126
- var matrix = makeTransformationMatrix(textureInfo);
84
+ const matrix = makeTransformationMatrix(textureInfo);
127
85
  if (originalTexCoord !== texCoord) {
128
86
  texture.texCoord = texCoord;
129
87
  }
130
88
  processedTexCoords.push([originalTexCoord, texCoord]);
131
89
  return {
132
- originalTexCoord: originalTexCoord,
133
- texCoord: texCoord,
134
- matrix: matrix
90
+ originalTexCoord,
91
+ texCoord,
92
+ matrix
135
93
  };
136
94
  }
137
95
  return null;
138
96
  }
139
97
  function transformPrimitive(gltfData, primitive, transformParameters) {
140
- var originalTexCoord = transformParameters.originalTexCoord,
141
- texCoord = transformParameters.texCoord,
142
- matrix = transformParameters.matrix;
143
- var texCoordAccessor = primitive.attributes["TEXCOORD_".concat(originalTexCoord)];
98
+ const {
99
+ originalTexCoord,
100
+ texCoord,
101
+ matrix
102
+ } = transformParameters;
103
+ const texCoordAccessor = primitive.attributes["TEXCOORD_".concat(originalTexCoord)];
144
104
  if (Number.isFinite(texCoordAccessor)) {
145
105
  var _gltfData$json$access;
146
- var accessor = (_gltfData$json$access = gltfData.json.accessors) === null || _gltfData$json$access === void 0 ? void 0 : _gltfData$json$access[texCoordAccessor];
106
+ const accessor = (_gltfData$json$access = gltfData.json.accessors) === null || _gltfData$json$access === void 0 ? void 0 : _gltfData$json$access[texCoordAccessor];
147
107
  if (accessor && accessor.bufferView) {
148
108
  var _gltfData$json$buffer;
149
- var bufferView = (_gltfData$json$buffer = gltfData.json.bufferViews) === null || _gltfData$json$buffer === void 0 ? void 0 : _gltfData$json$buffer[accessor.bufferView];
109
+ const bufferView = (_gltfData$json$buffer = gltfData.json.bufferViews) === null || _gltfData$json$buffer === void 0 ? void 0 : _gltfData$json$buffer[accessor.bufferView];
150
110
  if (bufferView) {
151
- var _gltfData$buffers$buf = gltfData.buffers[bufferView.buffer],
152
- arrayBuffer = _gltfData$buffers$buf.arrayBuffer,
153
- bufferByteOffset = _gltfData$buffers$buf.byteOffset;
154
- var byteOffset = (bufferByteOffset || 0) + (accessor.byteOffset || 0) + (bufferView.byteOffset || 0);
155
- var _getAccessorArrayType = (0, _gltfUtils.getAccessorArrayTypeAndLength)(accessor, bufferView),
156
- ArrayType = _getAccessorArrayType.ArrayType,
157
- length = _getAccessorArrayType.length;
158
- var bytes = _gltfConstants.BYTES[accessor.componentType];
159
- var components = _gltfConstants.COMPONENTS[accessor.type];
160
- var elementAddressScale = bufferView.byteStride || bytes * components;
161
- var result = new Float32Array(length);
162
- for (var i = 0; i < accessor.count; i++) {
163
- var uv = new ArrayType(arrayBuffer, byteOffset + i * elementAddressScale, 2);
111
+ const {
112
+ arrayBuffer,
113
+ byteOffset: bufferByteOffset
114
+ } = gltfData.buffers[bufferView.buffer];
115
+ const byteOffset = (bufferByteOffset || 0) + (accessor.byteOffset || 0) + (bufferView.byteOffset || 0);
116
+ const {
117
+ ArrayType,
118
+ length
119
+ } = (0, _gltfUtils.getAccessorArrayTypeAndLength)(accessor, bufferView);
120
+ const bytes = _gltfConstants.BYTES[accessor.componentType];
121
+ const components = _gltfConstants.COMPONENTS[accessor.type];
122
+ const elementAddressScale = bufferView.byteStride || bytes * components;
123
+ const result = new Float32Array(length);
124
+ for (let i = 0; i < accessor.count; i++) {
125
+ const uv = new ArrayType(arrayBuffer, byteOffset + i * elementAddressScale, 2);
164
126
  scratchVector.set(uv[0], uv[1], 1);
165
127
  scratchVector.transformByMatrix3(matrix);
166
128
  result.set([scratchVector[0], scratchVector[1]], i * components);
@@ -192,7 +154,7 @@ function createAttribute(newTexCoord, originalAccessor, primitive, gltfData, new
192
154
  byteOffset: 0,
193
155
  byteLength: newTexCoordArray.buffer.byteLength
194
156
  });
195
- var bufferViews = gltfData.json.bufferViews;
157
+ const bufferViews = gltfData.json.bufferViews;
196
158
  if (!bufferViews) {
197
159
  return;
198
160
  }
@@ -201,7 +163,7 @@ function createAttribute(newTexCoord, originalAccessor, primitive, gltfData, new
201
163
  byteLength: newTexCoordArray.buffer.byteLength,
202
164
  byteOffset: 0
203
165
  });
204
- var accessors = gltfData.json.accessors;
166
+ const accessors = gltfData.json.accessors;
205
167
  if (!accessors) {
206
168
  return;
207
169
  }
@@ -215,15 +177,14 @@ function createAttribute(newTexCoord, originalAccessor, primitive, gltfData, new
215
177
  primitive.attributes["TEXCOORD_".concat(newTexCoord)] = accessors.length - 1;
216
178
  }
217
179
  function makeTransformationMatrix(extensionData) {
218
- var _extensionData$offset = extensionData.offset,
219
- offset = _extensionData$offset === void 0 ? [0, 0] : _extensionData$offset,
220
- _extensionData$rotati = extensionData.rotation,
221
- rotation = _extensionData$rotati === void 0 ? 0 : _extensionData$rotati,
222
- _extensionData$scale = extensionData.scale,
223
- scale = _extensionData$scale === void 0 ? [1, 1] : _extensionData$scale;
224
- var translationMatirx = new _core.Matrix3().set(1, 0, 0, 0, 1, 0, offset[0], offset[1], 1);
225
- var rotationMatirx = scratchRotationMatrix.set(Math.cos(rotation), Math.sin(rotation), 0, -Math.sin(rotation), Math.cos(rotation), 0, 0, 0, 1);
226
- var scaleMatrix = scratchScaleMatrix.set(scale[0], 0, 0, 0, scale[1], 0, 0, 0, 1);
180
+ const {
181
+ offset = [0, 0],
182
+ rotation = 0,
183
+ scale = [1, 1]
184
+ } = extensionData;
185
+ const translationMatirx = new _core.Matrix3().set(1, 0, 0, 0, 1, 0, offset[0], offset[1], 1);
186
+ const rotationMatirx = scratchRotationMatrix.set(Math.cos(rotation), Math.sin(rotation), 0, -Math.sin(rotation), Math.cos(rotation), 0, 0, 0, 1);
187
+ const scaleMatrix = scratchScaleMatrix.set(scale[0], 0, 0, 0, scale[1], 0, 0, 0, 1);
227
188
  return translationMatirx.multiplyRight(rotationMatirx).multiplyRight(scaleMatrix);
228
189
  }
229
190
  //# sourceMappingURL=KHR_texture_transform.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"KHR_texture_transform.js","names":["_core","require","_gltfUtils","_gltfConstants","_gltfScenegraph","_interopRequireDefault","_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_MESHOPT_TRANSFORM","exports","scratchVector","Vector3","scratchRotationMatrix","Matrix3","scratchScaleMatrix","decode","_x","_x2","_decode","apply","arguments","_asyncToGenerator2","default","_regenerator","mark","_callee","gltfData","options","gltfScenegraph","extension","materials","wrap","_callee$","_context","prev","GLTFScenegraph","getExtension","abrupt","json","transformTexCoords","stop","materialIndex","_gltfData$json$materi","_material$pbrMetallic","_material$pbrMetallic2","processedTexCoords","material","baseColorTexture","pbrMetallicRoughness","transformPrimitives","emisiveTexture","emissiveTexture","normalTexture","occlusionTexture","metallicRoughnessTexture","texture","transformParameters","getTransformParameters","meshes","_iterator","_step","mesh","_iterator2","primitives","_step2","primitive","Number","isFinite","transformPrimitive","_texture$extensions","textureInfo","extensions","_texture$texCoord","texCoord","originalTexCoord","_textureInfo$texCoord","isProcessed","findIndex","_ref","_ref2","_slicedToArray2","original","newTexCoord","matrix","makeTransformationMatrix","push","texCoordAccessor","attributes","concat","_gltfData$json$access","accessor","accessors","bufferView","_gltfData$json$buffer","bufferViews","_gltfData$buffers$buf","buffers","buffer","arrayBuffer","bufferByteOffset","byteOffset","_getAccessorArrayType","getAccessorArrayTypeAndLength","ArrayType","bytes","BYTES","componentType","components","COMPONENTS","type","elementAddressScale","byteStride","result","Float32Array","count","uv","set","transformByMatrix3","updateGltf","createAttribute","newTexCoordArray","byteLength","originalAccessor","extensionData","_extensionData$offset","offset","_extensionData$rotati","rotation","_extensionData$scale","scale","translationMatirx","rotationMatirx","Math","cos","sin","scaleMatrix","multiplyRight"],"sources":["../../../../src/lib/extensions/KHR_texture_transform.ts"],"sourcesContent":["/**\n * https://github.com/KhronosGroup/glTF/blob/main/extensions/2.0/Khronos/KHR_texture_transform/README.md\n */\n\nimport {Vector3, Matrix3} from '@math.gl/core';\nimport type {GLTFMeshPrimitive, GLTFWithBuffers} from '../types/gltf-types';\nimport type {GLTFLoaderOptions} from '../../gltf-loader';\nimport {getAccessorArrayTypeAndLength} from '../gltf-utils/gltf-utils';\nimport {BYTES, COMPONENTS} from '../gltf-utils/gltf-constants';\nimport {\n Accessor,\n BufferView,\n MaterialNormalTextureInfo,\n MaterialOcclusionTextureInfo,\n TextureInfo as GLTFTextureInfo\n} from '../types/gltf-json-schema';\nimport GLTFScenegraph from '../api/gltf-scenegraph';\n\n/** Extension name */\nconst EXT_MESHOPT_TRANSFORM = 'KHR_texture_transform';\n\nexport const name = EXT_MESHOPT_TRANSFORM;\n\nconst scratchVector = new Vector3();\nconst scratchRotationMatrix = new Matrix3();\nconst scratchScaleMatrix = new Matrix3();\n\n/** Extension textureInfo https://github.com/KhronosGroup/glTF/tree/main/extensions/2.0/Khronos/KHR_texture_transform#gltf-schema-updates */\ntype TextureInfo = {\n /** The offset of the UV coordinate origin as a factor of the texture dimensions. */\n offset?: [number, number];\n /** Rotate the UVs by this many radians counter-clockwise around the origin. This is equivalent to a similar rotation of the image clockwise. */\n rotation?: number;\n /** The scale factor applied to the components of the UV coordinates. */\n scale?: [number, number];\n /** Overrides the textureInfo texCoord value if supplied, and if this extension is supported. */\n texCoord?: number;\n};\n/** Intersection of all GLTF textures */\ntype CompoundGLTFTextureInfo = GLTFTextureInfo &\n MaterialNormalTextureInfo &\n MaterialOcclusionTextureInfo;\n/** Parameters for TEXCOORD transformation */\ntype TransformParameters = {\n /** Original texCoord value https://www.khronos.org/registry/glTF/specs/2.0/glTF-2.0.html#_textureinfo_texcoord */\n originalTexCoord: number;\n /** New texCoord value from extension https://github.com/KhronosGroup/glTF/tree/main/extensions/2.0/Khronos/KHR_texture_transform#gltf-schema-updates */\n texCoord: number;\n /** Transformation matrix */\n matrix: Matrix3;\n};\n\n/**\n * The extension entry to process the transformation\n * @param gltfData gltf buffers and json\n * @param options GLTFLoader options\n */\nexport async function decode(gltfData: GLTFWithBuffers, options: GLTFLoaderOptions) {\n const gltfScenegraph = new GLTFScenegraph(gltfData);\n const extension = gltfScenegraph.getExtension(EXT_MESHOPT_TRANSFORM);\n if (!extension) {\n return;\n }\n const materials = gltfData.json.materials || [];\n for (let i = 0; i < materials.length; i++) {\n transformTexCoords(i, gltfData);\n }\n}\n\n/**\n * Transform TEXCOORD by material\n * @param materialIndex processing material index\n * @param gltfData gltf buffers and json\n */\nfunction transformTexCoords(materialIndex: number, gltfData: GLTFWithBuffers): void {\n // Save processed texCoords in order no to process the same twice\n const processedTexCoords: [number, number][] = [];\n const material = gltfData.json.materials?.[materialIndex];\n const baseColorTexture = material?.pbrMetallicRoughness?.baseColorTexture;\n if (baseColorTexture) {\n transformPrimitives(gltfData, materialIndex, baseColorTexture, processedTexCoords);\n }\n const emisiveTexture = material?.emissiveTexture;\n if (emisiveTexture) {\n transformPrimitives(gltfData, materialIndex, emisiveTexture, processedTexCoords);\n }\n const normalTexture = material?.normalTexture;\n if (normalTexture) {\n transformPrimitives(gltfData, materialIndex, normalTexture, processedTexCoords);\n }\n const occlusionTexture = material?.occlusionTexture;\n if (occlusionTexture) {\n transformPrimitives(gltfData, materialIndex, occlusionTexture, processedTexCoords);\n }\n const metallicRoughnessTexture = material?.pbrMetallicRoughness?.metallicRoughnessTexture;\n if (metallicRoughnessTexture) {\n transformPrimitives(gltfData, materialIndex, metallicRoughnessTexture, processedTexCoords);\n }\n}\n\n/**\n * Transform primitives of the particular material\n * @param gltfData gltf data\n * @param materialIndex primitives with this material will be transformed\n * @param texture texture object\n * @param processedTexCoords storage to save already processed texCoords\n */\nfunction transformPrimitives(\n gltfData: GLTFWithBuffers,\n materialIndex: number,\n texture: CompoundGLTFTextureInfo,\n processedTexCoords: [number, number][]\n) {\n const transformParameters = getTransformParameters(texture, processedTexCoords);\n if (!transformParameters) {\n return;\n }\n const meshes = gltfData.json.meshes || [];\n for (const mesh of meshes) {\n for (const primitive of mesh.primitives) {\n const material = primitive.material;\n if (Number.isFinite(material) && materialIndex === material) {\n transformPrimitive(gltfData, primitive, transformParameters);\n }\n }\n }\n}\n\n/**\n * Get parameters for TEXCOORD transformation\n * @param texture texture object\n * @param processedTexCoords storage to save already processed texCoords\n * @returns texCoord couple and transformation matrix\n */\nfunction getTransformParameters(\n texture: CompoundGLTFTextureInfo,\n processedTexCoords: [number, number][]\n): TransformParameters | null {\n const textureInfo = texture.extensions?.[EXT_MESHOPT_TRANSFORM];\n const {texCoord: originalTexCoord = 0} = texture;\n // If texCoord is not set in the extension, original attribute data will be replaced\n const {texCoord = originalTexCoord} = textureInfo;\n // Make sure that couple [originalTexCoord, extensionTexCoord] is not processed twice\n const isProcessed =\n processedTexCoords.findIndex(\n ([original, newTexCoord]) => original === originalTexCoord && newTexCoord === texCoord\n ) !== -1;\n if (!isProcessed) {\n const matrix = makeTransformationMatrix(textureInfo);\n if (originalTexCoord !== texCoord) {\n texture.texCoord = texCoord;\n }\n processedTexCoords.push([originalTexCoord, texCoord]);\n return {originalTexCoord, texCoord, matrix};\n }\n return null;\n}\n\n/**\n * Transform `TEXCOORD_0` attribute in the primitive\n * @param gltfData gltf data\n * @param primitive primitive object\n * @param transformParameters texCoord couple and transformation matrix\n */\nfunction transformPrimitive(\n gltfData: GLTFWithBuffers,\n primitive: GLTFMeshPrimitive,\n transformParameters: TransformParameters\n) {\n const {originalTexCoord, texCoord, matrix} = transformParameters;\n const texCoordAccessor = primitive.attributes[`TEXCOORD_${originalTexCoord}`];\n if (Number.isFinite(texCoordAccessor)) {\n // Get accessor of the `TEXCOORD_0` attribute\n const accessor = gltfData.json.accessors?.[texCoordAccessor];\n if (accessor && accessor.bufferView) {\n // Get `bufferView` of the `accessor`\n const bufferView = gltfData.json.bufferViews?.[accessor.bufferView];\n if (bufferView) {\n // Get `arrayBuffer` the `bufferView` look at\n const {arrayBuffer, byteOffset: bufferByteOffset} = gltfData.buffers[bufferView.buffer];\n // Resulting byteOffset is sum of the buffer, accessor and bufferView byte offsets\n const byteOffset =\n (bufferByteOffset || 0) + (accessor.byteOffset || 0) + (bufferView.byteOffset || 0);\n // Deduce TypedArray type and its length from `accessor` and `bufferView` data\n const {ArrayType, length} = getAccessorArrayTypeAndLength(accessor, bufferView);\n // Number of bytes each component occupies\n const bytes = BYTES[accessor.componentType];\n // Number of components. For the `TEXCOORD_0` with `VEC2` type, it must return 2\n const components = COMPONENTS[accessor.type];\n // Multiplier to calculate the address of the `TEXCOORD_0` element in the arrayBuffer\n const elementAddressScale = bufferView.byteStride || bytes * components;\n // Data transform to Float32Array\n const result = new Float32Array(length);\n for (let i = 0; i < accessor.count; i++) {\n // Take [u, v] couple from the arrayBuffer\n const uv = new ArrayType(arrayBuffer, byteOffset + i * elementAddressScale, 2);\n // Set and transform Vector3 per https://github.com/KhronosGroup/glTF/tree/main/extensions/2.0/Khronos/KHR_texture_transform#overview\n scratchVector.set(uv[0], uv[1], 1);\n scratchVector.transformByMatrix3(matrix);\n // Save result in Float32Array\n result.set([scratchVector[0], scratchVector[1]], i * components);\n }\n // If texCoord the same, replace gltf structural data\n if (originalTexCoord === texCoord) {\n updateGltf(accessor, bufferView, gltfData.buffers, result);\n } else {\n // If texCoord change, create new attribute\n createAttribute(texCoord, accessor, primitive, gltfData, result);\n }\n }\n }\n }\n}\n\n/**\n * Update GLTF structural objects with new data as we create new `Float32Array` for `TEXCOORD_0`.\n * @param accessor accessor to change\n * @param bufferView bufferView to change\n * @param buffers binary buffers\n * @param newTexcoordArray typed array with data after transformation\n */\nfunction updateGltf(\n accessor: Accessor,\n bufferView: BufferView,\n buffers: {arrayBuffer: ArrayBuffer; byteOffset: number; byteLength: number}[],\n newTexCoordArray: Float32Array\n): void {\n accessor.componentType = 5126;\n buffers.push({\n arrayBuffer: newTexCoordArray.buffer,\n byteOffset: 0,\n byteLength: newTexCoordArray.buffer.byteLength\n });\n bufferView.buffer = buffers.length - 1;\n bufferView.byteLength = newTexCoordArray.buffer.byteLength;\n bufferView.byteOffset = 0;\n delete bufferView.byteStride;\n}\n\n/**\n *\n * @param newTexCoord new `texCoord` value\n * @param originalAccessor original accessor object, that store data before transformation\n * @param primitive primitive object\n * @param gltfData gltf data\n * @param newTexCoordArray typed array with data after transformation\n * @returns\n */\nfunction createAttribute(\n newTexCoord: number,\n originalAccessor: Accessor,\n primitive: GLTFMeshPrimitive,\n gltfData: GLTFWithBuffers,\n newTexCoordArray: Float32Array\n) {\n gltfData.buffers.push({\n arrayBuffer: newTexCoordArray.buffer,\n byteOffset: 0,\n byteLength: newTexCoordArray.buffer.byteLength\n });\n const bufferViews = gltfData.json.bufferViews;\n if (!bufferViews) {\n return;\n }\n bufferViews.push({\n buffer: gltfData.buffers.length - 1,\n byteLength: newTexCoordArray.buffer.byteLength,\n byteOffset: 0\n });\n const accessors = gltfData.json.accessors;\n if (!accessors) {\n return;\n }\n accessors.push({\n bufferView: bufferViews?.length - 1,\n byteOffset: 0,\n componentType: 5126,\n count: originalAccessor.count,\n type: 'VEC2'\n });\n primitive.attributes[`TEXCOORD_${newTexCoord}`] = accessors.length - 1;\n}\n\n/**\n * Construct transformation matrix from the extension data (transition, rotation, scale)\n * @param extensionData extension data\n * @returns transformation matrix\n */\nfunction makeTransformationMatrix(extensionData: TextureInfo): Matrix3 {\n const {offset = [0, 0], rotation = 0, scale = [1, 1]} = extensionData;\n const translationMatirx = new Matrix3().set(1, 0, 0, 0, 1, 0, offset[0], offset[1], 1);\n const rotationMatirx = scratchRotationMatrix.set(\n Math.cos(rotation),\n Math.sin(rotation),\n 0,\n -Math.sin(rotation),\n Math.cos(rotation),\n 0,\n 0,\n 0,\n 1\n );\n const scaleMatrix = scratchScaleMatrix.set(scale[0], 0, 0, 0, scale[1], 0, 0, 0, 1);\n return translationMatirx.multiplyRight(rotationMatirx).multiplyRight(scaleMatrix);\n}\n"],"mappings":"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"}
1
+ {"version":3,"file":"KHR_texture_transform.js","names":["_core","require","_gltfUtils","_gltfConstants","_gltfScenegraph","_interopRequireDefault","EXT_MESHOPT_TRANSFORM","name","exports","scratchVector","Vector3","scratchRotationMatrix","Matrix3","scratchScaleMatrix","decode","gltfData","options","gltfScenegraph","GLTFScenegraph","extension","getExtension","materials","json","i","length","transformTexCoords","materialIndex","_gltfData$json$materi","_material$pbrMetallic","_material$pbrMetallic2","processedTexCoords","material","baseColorTexture","pbrMetallicRoughness","transformPrimitives","emisiveTexture","emissiveTexture","normalTexture","occlusionTexture","metallicRoughnessTexture","texture","transformParameters","getTransformParameters","meshes","mesh","primitive","primitives","Number","isFinite","transformPrimitive","_texture$extensions","textureInfo","extensions","texCoord","originalTexCoord","isProcessed","findIndex","_ref","original","newTexCoord","matrix","makeTransformationMatrix","push","texCoordAccessor","attributes","concat","_gltfData$json$access","accessor","accessors","bufferView","_gltfData$json$buffer","bufferViews","arrayBuffer","byteOffset","bufferByteOffset","buffers","buffer","ArrayType","getAccessorArrayTypeAndLength","bytes","BYTES","componentType","components","COMPONENTS","type","elementAddressScale","byteStride","result","Float32Array","count","uv","set","transformByMatrix3","updateGltf","createAttribute","newTexCoordArray","byteLength","originalAccessor","extensionData","offset","rotation","scale","translationMatirx","rotationMatirx","Math","cos","sin","scaleMatrix","multiplyRight"],"sources":["../../../../src/lib/extensions/KHR_texture_transform.ts"],"sourcesContent":["/**\n * https://github.com/KhronosGroup/glTF/blob/main/extensions/2.0/Khronos/KHR_texture_transform/README.md\n */\n\nimport {Vector3, Matrix3} from '@math.gl/core';\nimport type {GLTFMeshPrimitive, GLTFWithBuffers} from '../types/gltf-types';\nimport type {GLTFLoaderOptions} from '../../gltf-loader';\nimport {getAccessorArrayTypeAndLength} from '../gltf-utils/gltf-utils';\nimport {BYTES, COMPONENTS} from '../gltf-utils/gltf-constants';\nimport {\n Accessor,\n BufferView,\n MaterialNormalTextureInfo,\n MaterialOcclusionTextureInfo,\n TextureInfo as GLTFTextureInfo\n} from '../types/gltf-json-schema';\nimport GLTFScenegraph from '../api/gltf-scenegraph';\n\n/** Extension name */\nconst EXT_MESHOPT_TRANSFORM = 'KHR_texture_transform';\n\nexport const name = EXT_MESHOPT_TRANSFORM;\n\nconst scratchVector = new Vector3();\nconst scratchRotationMatrix = new Matrix3();\nconst scratchScaleMatrix = new Matrix3();\n\n/** Extension textureInfo https://github.com/KhronosGroup/glTF/tree/main/extensions/2.0/Khronos/KHR_texture_transform#gltf-schema-updates */\ntype TextureInfo = {\n /** The offset of the UV coordinate origin as a factor of the texture dimensions. */\n offset?: [number, number];\n /** Rotate the UVs by this many radians counter-clockwise around the origin. This is equivalent to a similar rotation of the image clockwise. */\n rotation?: number;\n /** The scale factor applied to the components of the UV coordinates. */\n scale?: [number, number];\n /** Overrides the textureInfo texCoord value if supplied, and if this extension is supported. */\n texCoord?: number;\n};\n/** Intersection of all GLTF textures */\ntype CompoundGLTFTextureInfo = GLTFTextureInfo &\n MaterialNormalTextureInfo &\n MaterialOcclusionTextureInfo;\n/** Parameters for TEXCOORD transformation */\ntype TransformParameters = {\n /** Original texCoord value https://www.khronos.org/registry/glTF/specs/2.0/glTF-2.0.html#_textureinfo_texcoord */\n originalTexCoord: number;\n /** New texCoord value from extension https://github.com/KhronosGroup/glTF/tree/main/extensions/2.0/Khronos/KHR_texture_transform#gltf-schema-updates */\n texCoord: number;\n /** Transformation matrix */\n matrix: Matrix3;\n};\n\n/**\n * The extension entry to process the transformation\n * @param gltfData gltf buffers and json\n * @param options GLTFLoader options\n */\nexport async function decode(gltfData: GLTFWithBuffers, options: GLTFLoaderOptions) {\n const gltfScenegraph = new GLTFScenegraph(gltfData);\n const extension = gltfScenegraph.getExtension(EXT_MESHOPT_TRANSFORM);\n if (!extension) {\n return;\n }\n const materials = gltfData.json.materials || [];\n for (let i = 0; i < materials.length; i++) {\n transformTexCoords(i, gltfData);\n }\n}\n\n/**\n * Transform TEXCOORD by material\n * @param materialIndex processing material index\n * @param gltfData gltf buffers and json\n */\nfunction transformTexCoords(materialIndex: number, gltfData: GLTFWithBuffers): void {\n // Save processed texCoords in order no to process the same twice\n const processedTexCoords: [number, number][] = [];\n const material = gltfData.json.materials?.[materialIndex];\n const baseColorTexture = material?.pbrMetallicRoughness?.baseColorTexture;\n if (baseColorTexture) {\n transformPrimitives(gltfData, materialIndex, baseColorTexture, processedTexCoords);\n }\n const emisiveTexture = material?.emissiveTexture;\n if (emisiveTexture) {\n transformPrimitives(gltfData, materialIndex, emisiveTexture, processedTexCoords);\n }\n const normalTexture = material?.normalTexture;\n if (normalTexture) {\n transformPrimitives(gltfData, materialIndex, normalTexture, processedTexCoords);\n }\n const occlusionTexture = material?.occlusionTexture;\n if (occlusionTexture) {\n transformPrimitives(gltfData, materialIndex, occlusionTexture, processedTexCoords);\n }\n const metallicRoughnessTexture = material?.pbrMetallicRoughness?.metallicRoughnessTexture;\n if (metallicRoughnessTexture) {\n transformPrimitives(gltfData, materialIndex, metallicRoughnessTexture, processedTexCoords);\n }\n}\n\n/**\n * Transform primitives of the particular material\n * @param gltfData gltf data\n * @param materialIndex primitives with this material will be transformed\n * @param texture texture object\n * @param processedTexCoords storage to save already processed texCoords\n */\nfunction transformPrimitives(\n gltfData: GLTFWithBuffers,\n materialIndex: number,\n texture: CompoundGLTFTextureInfo,\n processedTexCoords: [number, number][]\n) {\n const transformParameters = getTransformParameters(texture, processedTexCoords);\n if (!transformParameters) {\n return;\n }\n const meshes = gltfData.json.meshes || [];\n for (const mesh of meshes) {\n for (const primitive of mesh.primitives) {\n const material = primitive.material;\n if (Number.isFinite(material) && materialIndex === material) {\n transformPrimitive(gltfData, primitive, transformParameters);\n }\n }\n }\n}\n\n/**\n * Get parameters for TEXCOORD transformation\n * @param texture texture object\n * @param processedTexCoords storage to save already processed texCoords\n * @returns texCoord couple and transformation matrix\n */\nfunction getTransformParameters(\n texture: CompoundGLTFTextureInfo,\n processedTexCoords: [number, number][]\n): TransformParameters | null {\n const textureInfo = texture.extensions?.[EXT_MESHOPT_TRANSFORM];\n const {texCoord: originalTexCoord = 0} = texture;\n // If texCoord is not set in the extension, original attribute data will be replaced\n const {texCoord = originalTexCoord} = textureInfo;\n // Make sure that couple [originalTexCoord, extensionTexCoord] is not processed twice\n const isProcessed =\n processedTexCoords.findIndex(\n ([original, newTexCoord]) => original === originalTexCoord && newTexCoord === texCoord\n ) !== -1;\n if (!isProcessed) {\n const matrix = makeTransformationMatrix(textureInfo);\n if (originalTexCoord !== texCoord) {\n texture.texCoord = texCoord;\n }\n processedTexCoords.push([originalTexCoord, texCoord]);\n return {originalTexCoord, texCoord, matrix};\n }\n return null;\n}\n\n/**\n * Transform `TEXCOORD_0` attribute in the primitive\n * @param gltfData gltf data\n * @param primitive primitive object\n * @param transformParameters texCoord couple and transformation matrix\n */\nfunction transformPrimitive(\n gltfData: GLTFWithBuffers,\n primitive: GLTFMeshPrimitive,\n transformParameters: TransformParameters\n) {\n const {originalTexCoord, texCoord, matrix} = transformParameters;\n const texCoordAccessor = primitive.attributes[`TEXCOORD_${originalTexCoord}`];\n if (Number.isFinite(texCoordAccessor)) {\n // Get accessor of the `TEXCOORD_0` attribute\n const accessor = gltfData.json.accessors?.[texCoordAccessor];\n if (accessor && accessor.bufferView) {\n // Get `bufferView` of the `accessor`\n const bufferView = gltfData.json.bufferViews?.[accessor.bufferView];\n if (bufferView) {\n // Get `arrayBuffer` the `bufferView` look at\n const {arrayBuffer, byteOffset: bufferByteOffset} = gltfData.buffers[bufferView.buffer];\n // Resulting byteOffset is sum of the buffer, accessor and bufferView byte offsets\n const byteOffset =\n (bufferByteOffset || 0) + (accessor.byteOffset || 0) + (bufferView.byteOffset || 0);\n // Deduce TypedArray type and its length from `accessor` and `bufferView` data\n const {ArrayType, length} = getAccessorArrayTypeAndLength(accessor, bufferView);\n // Number of bytes each component occupies\n const bytes = BYTES[accessor.componentType];\n // Number of components. For the `TEXCOORD_0` with `VEC2` type, it must return 2\n const components = COMPONENTS[accessor.type];\n // Multiplier to calculate the address of the `TEXCOORD_0` element in the arrayBuffer\n const elementAddressScale = bufferView.byteStride || bytes * components;\n // Data transform to Float32Array\n const result = new Float32Array(length);\n for (let i = 0; i < accessor.count; i++) {\n // Take [u, v] couple from the arrayBuffer\n const uv = new ArrayType(arrayBuffer, byteOffset + i * elementAddressScale, 2);\n // Set and transform Vector3 per https://github.com/KhronosGroup/glTF/tree/main/extensions/2.0/Khronos/KHR_texture_transform#overview\n scratchVector.set(uv[0], uv[1], 1);\n scratchVector.transformByMatrix3(matrix);\n // Save result in Float32Array\n result.set([scratchVector[0], scratchVector[1]], i * components);\n }\n // If texCoord the same, replace gltf structural data\n if (originalTexCoord === texCoord) {\n updateGltf(accessor, bufferView, gltfData.buffers, result);\n } else {\n // If texCoord change, create new attribute\n createAttribute(texCoord, accessor, primitive, gltfData, result);\n }\n }\n }\n }\n}\n\n/**\n * Update GLTF structural objects with new data as we create new `Float32Array` for `TEXCOORD_0`.\n * @param accessor accessor to change\n * @param bufferView bufferView to change\n * @param buffers binary buffers\n * @param newTexcoordArray typed array with data after transformation\n */\nfunction updateGltf(\n accessor: Accessor,\n bufferView: BufferView,\n buffers: {arrayBuffer: ArrayBuffer; byteOffset: number; byteLength: number}[],\n newTexCoordArray: Float32Array\n): void {\n accessor.componentType = 5126;\n buffers.push({\n arrayBuffer: newTexCoordArray.buffer,\n byteOffset: 0,\n byteLength: newTexCoordArray.buffer.byteLength\n });\n bufferView.buffer = buffers.length - 1;\n bufferView.byteLength = newTexCoordArray.buffer.byteLength;\n bufferView.byteOffset = 0;\n delete bufferView.byteStride;\n}\n\n/**\n *\n * @param newTexCoord new `texCoord` value\n * @param originalAccessor original accessor object, that store data before transformation\n * @param primitive primitive object\n * @param gltfData gltf data\n * @param newTexCoordArray typed array with data after transformation\n * @returns\n */\nfunction createAttribute(\n newTexCoord: number,\n originalAccessor: Accessor,\n primitive: GLTFMeshPrimitive,\n gltfData: GLTFWithBuffers,\n newTexCoordArray: Float32Array\n) {\n gltfData.buffers.push({\n arrayBuffer: newTexCoordArray.buffer,\n byteOffset: 0,\n byteLength: newTexCoordArray.buffer.byteLength\n });\n const bufferViews = gltfData.json.bufferViews;\n if (!bufferViews) {\n return;\n }\n bufferViews.push({\n buffer: gltfData.buffers.length - 1,\n byteLength: newTexCoordArray.buffer.byteLength,\n byteOffset: 0\n });\n const accessors = gltfData.json.accessors;\n if (!accessors) {\n return;\n }\n accessors.push({\n bufferView: bufferViews?.length - 1,\n byteOffset: 0,\n componentType: 5126,\n count: originalAccessor.count,\n type: 'VEC2'\n });\n primitive.attributes[`TEXCOORD_${newTexCoord}`] = accessors.length - 1;\n}\n\n/**\n * Construct transformation matrix from the extension data (transition, rotation, scale)\n * @param extensionData extension data\n * @returns transformation matrix\n */\nfunction makeTransformationMatrix(extensionData: TextureInfo): Matrix3 {\n const {offset = [0, 0], rotation = 0, scale = [1, 1]} = extensionData;\n const translationMatirx = new Matrix3().set(1, 0, 0, 0, 1, 0, offset[0], offset[1], 1);\n const rotationMatirx = scratchRotationMatrix.set(\n Math.cos(rotation),\n Math.sin(rotation),\n 0,\n -Math.sin(rotation),\n Math.cos(rotation),\n 0,\n 0,\n 0,\n 1\n );\n const scaleMatrix = scratchScaleMatrix.set(scale[0], 0, 0, 0, scale[1], 0, 0, 0, 1);\n return translationMatirx.multiplyRight(rotationMatirx).multiplyRight(scaleMatrix);\n}\n"],"mappings":"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"}
@@ -6,44 +6,27 @@ Object.defineProperty(exports, "__esModule", {
6
6
  });
7
7
  exports.decode = decode;
8
8
  exports.name = void 0;
9
- var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
10
- var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
11
9
  var _gltfScenegraph = _interopRequireDefault(require("../../api/gltf-scenegraph"));
12
- var EXT_FEATURE_METADATA = 'EXT_feature_metadata';
13
- var name = EXT_FEATURE_METADATA;
10
+ const EXT_FEATURE_METADATA = 'EXT_feature_metadata';
11
+ const name = EXT_FEATURE_METADATA;
14
12
  exports.name = name;
15
- function decode(_x) {
16
- return _decode.apply(this, arguments);
17
- }
18
- function _decode() {
19
- _decode = (0, _asyncToGenerator2.default)(_regenerator.default.mark(function _callee(gltfData) {
20
- var scenegraph;
21
- return _regenerator.default.wrap(function _callee$(_context) {
22
- while (1) switch (_context.prev = _context.next) {
23
- case 0:
24
- scenegraph = new _gltfScenegraph.default(gltfData);
25
- decodeExtFeatureMetadata(scenegraph);
26
- case 2:
27
- case "end":
28
- return _context.stop();
29
- }
30
- }, _callee);
31
- }));
32
- return _decode.apply(this, arguments);
13
+ async function decode(gltfData) {
14
+ const scenegraph = new _gltfScenegraph.default(gltfData);
15
+ decodeExtFeatureMetadata(scenegraph);
33
16
  }
34
17
  function decodeExtFeatureMetadata(scenegraph) {
35
18
  var _extension$schema;
36
- var extension = scenegraph.getExtension(EXT_FEATURE_METADATA);
37
- var schemaClasses = extension === null || extension === void 0 ? void 0 : (_extension$schema = extension.schema) === null || _extension$schema === void 0 ? void 0 : _extension$schema.classes;
38
- var featureTables = extension === null || extension === void 0 ? void 0 : extension.featureTables;
39
- var featureTextures = extension === null || extension === void 0 ? void 0 : extension.featureTextures;
19
+ const extension = scenegraph.getExtension(EXT_FEATURE_METADATA);
20
+ const schemaClasses = extension === null || extension === void 0 ? void 0 : (_extension$schema = extension.schema) === null || _extension$schema === void 0 ? void 0 : _extension$schema.classes;
21
+ const featureTables = extension === null || extension === void 0 ? void 0 : extension.featureTables;
22
+ const featureTextures = extension === null || extension === void 0 ? void 0 : extension.featureTextures;
40
23
  if (featureTextures) {
41
24
  console.warn('featureTextures is not yet supported in the "EXT_feature_metadata" extension.');
42
25
  }
43
26
  if (schemaClasses && featureTables) {
44
- for (var schemaName in schemaClasses) {
45
- var schemaClass = schemaClasses[schemaName];
46
- var featureTable = findFeatureTableByName(featureTables, schemaName);
27
+ for (const schemaName in schemaClasses) {
28
+ const schemaClass = schemaClasses[schemaName];
29
+ const featureTable = findFeatureTableByName(featureTables, schemaName);
47
30
  if (featureTable) {
48
31
  handleFeatureTableProperties(scenegraph, featureTable, schemaClass);
49
32
  }
@@ -51,25 +34,25 @@ function decodeExtFeatureMetadata(scenegraph) {
51
34
  }
52
35
  }
53
36
  function handleFeatureTableProperties(scenegraph, featureTable, schemaClass) {
54
- for (var propertyName in schemaClass.properties) {
37
+ for (const propertyName in schemaClass.properties) {
55
38
  var _featureTable$propert;
56
- var schemaProperty = schemaClass.properties[propertyName];
57
- var featureTableProperty = featureTable === null || featureTable === void 0 ? void 0 : (_featureTable$propert = featureTable.properties) === null || _featureTable$propert === void 0 ? void 0 : _featureTable$propert[propertyName];
58
- var numberOfFeatures = featureTable.count;
39
+ const schemaProperty = schemaClass.properties[propertyName];
40
+ const featureTableProperty = featureTable === null || featureTable === void 0 ? void 0 : (_featureTable$propert = featureTable.properties) === null || _featureTable$propert === void 0 ? void 0 : _featureTable$propert[propertyName];
41
+ const numberOfFeatures = featureTable.count;
59
42
  if (featureTableProperty) {
60
- var data = getPropertyDataFromBinarySource(scenegraph, schemaProperty, numberOfFeatures, featureTableProperty);
43
+ const data = getPropertyDataFromBinarySource(scenegraph, schemaProperty, numberOfFeatures, featureTableProperty);
61
44
  featureTableProperty.data = data;
62
45
  }
63
46
  }
64
47
  }
65
48
  function getPropertyDataFromBinarySource(scenegraph, schemaProperty, numberOfFeatures, featureTableProperty) {
66
- var bufferView = featureTableProperty.bufferView;
67
- var data = scenegraph.getTypedArrayForBufferView(bufferView);
49
+ const bufferView = featureTableProperty.bufferView;
50
+ let data = scenegraph.getTypedArrayForBufferView(bufferView);
68
51
  switch (schemaProperty.type) {
69
52
  case 'STRING':
70
53
  {
71
- var stringOffsetBufferView = featureTableProperty.stringOffsetBufferView;
72
- var offsetsData = scenegraph.getTypedArrayForBufferView(stringOffsetBufferView);
54
+ const stringOffsetBufferView = featureTableProperty.stringOffsetBufferView;
55
+ const offsetsData = scenegraph.getTypedArrayForBufferView(stringOffsetBufferView);
73
56
  data = getStringAttributes(data, offsetsData, numberOfFeatures);
74
57
  break;
75
58
  }
@@ -78,8 +61,8 @@ function getPropertyDataFromBinarySource(scenegraph, schemaProperty, numberOfFea
78
61
  return data;
79
62
  }
80
63
  function findFeatureTableByName(featureTables, schemaClassName) {
81
- for (var featureTableName in featureTables) {
82
- var featureTable = featureTables[featureTableName];
64
+ for (const featureTableName in featureTables) {
65
+ const featureTable = featureTables[featureTableName];
83
66
  if (featureTable.class === schemaClassName) {
84
67
  return featureTable;
85
68
  }
@@ -87,14 +70,14 @@ function findFeatureTableByName(featureTables, schemaClassName) {
87
70
  return null;
88
71
  }
89
72
  function getStringAttributes(data, offsetsData, stringsCount) {
90
- var stringsArray = [];
91
- var textDecoder = new TextDecoder('utf8');
92
- var stringOffset = 0;
93
- var bytesPerStringSize = 4;
94
- for (var index = 0; index < stringsCount; index++) {
95
- var stringByteSize = offsetsData[(index + 1) * bytesPerStringSize] - offsetsData[index * bytesPerStringSize];
96
- var stringData = data.subarray(stringOffset, stringByteSize + stringOffset);
97
- var stringAttribute = textDecoder.decode(stringData);
73
+ const stringsArray = [];
74
+ const textDecoder = new TextDecoder('utf8');
75
+ let stringOffset = 0;
76
+ const bytesPerStringSize = 4;
77
+ for (let index = 0; index < stringsCount; index++) {
78
+ const stringByteSize = offsetsData[(index + 1) * bytesPerStringSize] - offsetsData[index * bytesPerStringSize];
79
+ const stringData = data.subarray(stringOffset, stringByteSize + stringOffset);
80
+ const stringAttribute = textDecoder.decode(stringData);
98
81
  stringsArray.push(stringAttribute);
99
82
  stringOffset += stringByteSize;
100
83
  }
@@ -1 +1 @@
1
- {"version":3,"file":"EXT_feature_metadata.js","names":["_gltfScenegraph","_interopRequireDefault","require","EXT_FEATURE_METADATA","name","exports","decode","_x","_decode","apply","arguments","_asyncToGenerator2","default","_regenerator","mark","_callee","gltfData","scenegraph","wrap","_callee$","_context","prev","next","GLTFScenegraph","decodeExtFeatureMetadata","stop","_extension$schema","extension","getExtension","schemaClasses","schema","classes","featureTables","featureTextures","console","warn","schemaName","schemaClass","featureTable","findFeatureTableByName","handleFeatureTableProperties","propertyName","properties","_featureTable$propert","schemaProperty","featureTableProperty","numberOfFeatures","count","data","getPropertyDataFromBinarySource","bufferView","getTypedArrayForBufferView","type","stringOffsetBufferView","offsetsData","getStringAttributes","schemaClassName","featureTableName","class","stringsCount","stringsArray","textDecoder","TextDecoder","stringOffset","bytesPerStringSize","index","stringByteSize","stringData","subarray","stringAttribute","push"],"sources":["../../../../../src/lib/extensions/deprecated/EXT_feature_metadata.ts"],"sourcesContent":["/* eslint-disable camelcase */\nimport type {GLTF} from '../../types/gltf-types';\n\nimport GLTFScenegraph from '../../api/gltf-scenegraph';\nimport {\n ClassProperty,\n EXT_feature_metadata_class_object,\n EXT_feature_metadata_feature_table,\n FeatureTableProperty,\n GLTF_EXT_feature_metadata\n} from '../../types/gltf-json-schema';\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}): Promise<void> {\n const scenegraph = new GLTFScenegraph(gltfData);\n decodeExtFeatureMetadata(scenegraph);\n}\n\n/**\n * Decodes feature metadata from extension\n * @param scenegraph\n */\nfunction decodeExtFeatureMetadata(scenegraph: GLTFScenegraph): void {\n const extension: GLTF_EXT_feature_metadata | null = scenegraph.getExtension(EXT_FEATURE_METADATA);\n const schemaClasses = extension?.schema?.classes;\n const featureTables = extension?.featureTables;\n const featureTextures = extension?.featureTextures;\n\n if (featureTextures) {\n /*\n * TODO add support for featureTextures\n * Spec - https://github.com/CesiumGS/glTF/tree/3d-tiles-next/extensions/2.0/Vendor/EXT_feature_metadata#feature-textures\n */\n // eslint-disable-next-line no-console\n console.warn('featureTextures is not yet supported in the \"EXT_feature_metadata\" extension.');\n }\n\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\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: EXT_feature_metadata_feature_table,\n schemaClass: EXT_feature_metadata_class_object\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 * 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: ClassProperty,\n numberOfFeatures: number,\n featureTableProperty: FeatureTableProperty\n): Uint8Array | string[] {\n const bufferView = featureTableProperty.bufferView;\n // TODO think maybe we shouldn't get data only in Uint8Array format.\n let data: Uint8Array | string[] = 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 data = getStringAttributes(data, offsetsData, numberOfFeatures);\n break;\n }\n default:\n }\n\n return data;\n}\n\n/**\n * Find the feature table by class name.\n * @param featureTables\n * @param schemaClassName\n */\nfunction findFeatureTableByName(\n featureTables: {[key: string]: EXT_feature_metadata_feature_table},\n schemaClassName: string\n): EXT_feature_metadata_feature_table | 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\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","_interopRequireDefault","require","EXT_FEATURE_METADATA","name","exports","decode","gltfData","scenegraph","GLTFScenegraph","decodeExtFeatureMetadata","_extension$schema","extension","getExtension","schemaClasses","schema","classes","featureTables","featureTextures","console","warn","schemaName","schemaClass","featureTable","findFeatureTableByName","handleFeatureTableProperties","propertyName","properties","_featureTable$propert","schemaProperty","featureTableProperty","numberOfFeatures","count","data","getPropertyDataFromBinarySource","bufferView","getTypedArrayForBufferView","type","stringOffsetBufferView","offsetsData","getStringAttributes","schemaClassName","featureTableName","class","stringsCount","stringsArray","textDecoder","TextDecoder","stringOffset","bytesPerStringSize","index","stringByteSize","stringData","subarray","stringAttribute","push"],"sources":["../../../../../src/lib/extensions/deprecated/EXT_feature_metadata.ts"],"sourcesContent":["/* eslint-disable camelcase */\nimport type {GLTF} from '../../types/gltf-types';\n\nimport GLTFScenegraph from '../../api/gltf-scenegraph';\nimport {\n ClassProperty,\n EXT_feature_metadata_class_object,\n EXT_feature_metadata_feature_table,\n FeatureTableProperty,\n GLTF_EXT_feature_metadata\n} from '../../types/gltf-json-schema';\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}): Promise<void> {\n const scenegraph = new GLTFScenegraph(gltfData);\n decodeExtFeatureMetadata(scenegraph);\n}\n\n/**\n * Decodes feature metadata from extension\n * @param scenegraph\n */\nfunction decodeExtFeatureMetadata(scenegraph: GLTFScenegraph): void {\n const extension: GLTF_EXT_feature_metadata | null = scenegraph.getExtension(EXT_FEATURE_METADATA);\n const schemaClasses = extension?.schema?.classes;\n const featureTables = extension?.featureTables;\n const featureTextures = extension?.featureTextures;\n\n if (featureTextures) {\n /*\n * TODO add support for featureTextures\n * Spec - https://github.com/CesiumGS/glTF/tree/3d-tiles-next/extensions/2.0/Vendor/EXT_feature_metadata#feature-textures\n */\n // eslint-disable-next-line no-console\n console.warn('featureTextures is not yet supported in the \"EXT_feature_metadata\" extension.');\n }\n\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\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: EXT_feature_metadata_feature_table,\n schemaClass: EXT_feature_metadata_class_object\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 * 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: ClassProperty,\n numberOfFeatures: number,\n featureTableProperty: FeatureTableProperty\n): Uint8Array | string[] {\n const bufferView = featureTableProperty.bufferView;\n // TODO think maybe we shouldn't get data only in Uint8Array format.\n let data: Uint8Array | string[] = 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 data = getStringAttributes(data, offsetsData, numberOfFeatures);\n break;\n }\n default:\n }\n\n return data;\n}\n\n/**\n * Find the feature table by class name.\n * @param featureTables\n * @param schemaClassName\n */\nfunction findFeatureTableByName(\n featureTables: {[key: string]: EXT_feature_metadata_feature_table},\n schemaClassName: string\n): EXT_feature_metadata_feature_table | 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\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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"}