@loaders.gl/gltf 4.0.0-alpha.9 → 4.0.0-beta.2

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 (152) hide show
  1. package/dist/dist.min.js +3777 -3105
  2. package/dist/es5/glb-loader.js +1 -3
  3. package/dist/es5/glb-loader.js.map +1 -1
  4. package/dist/es5/index.js +33 -0
  5. package/dist/es5/index.js.map +1 -1
  6. package/dist/es5/lib/api/gltf-extensions.js +3 -1
  7. package/dist/es5/lib/api/gltf-extensions.js.map +1 -1
  8. package/dist/es5/lib/extensions/EXT_mesh_features.js +99 -0
  9. package/dist/es5/lib/extensions/EXT_mesh_features.js.map +1 -0
  10. package/dist/es5/lib/extensions/EXT_meshopt_compression.js +2 -2
  11. package/dist/es5/lib/extensions/EXT_meshopt_compression.js.map +1 -1
  12. package/dist/es5/lib/extensions/EXT_structural_metadata.js +375 -0
  13. package/dist/es5/lib/extensions/EXT_structural_metadata.js.map +1 -0
  14. package/dist/es5/lib/extensions/KHR_draco_mesh_compression.js +6 -7
  15. package/dist/es5/lib/extensions/KHR_draco_mesh_compression.js.map +1 -1
  16. package/dist/es5/lib/extensions/KHR_texture_transform.js +2 -1
  17. package/dist/es5/lib/extensions/KHR_texture_transform.js.map +1 -1
  18. package/dist/es5/lib/extensions/deprecated/EXT_feature_metadata.js +162 -183
  19. package/dist/es5/lib/extensions/deprecated/EXT_feature_metadata.js.map +1 -1
  20. package/dist/es5/lib/extensions/utils/3d-tiles-utils.js +254 -0
  21. package/dist/es5/lib/extensions/utils/3d-tiles-utils.js.map +1 -0
  22. package/dist/es5/lib/gltf-utils/gltf-utils.js +29 -0
  23. package/dist/es5/lib/gltf-utils/gltf-utils.js.map +1 -1
  24. package/dist/es5/lib/parsers/parse-gltf.js +7 -4
  25. package/dist/es5/lib/parsers/parse-gltf.js.map +1 -1
  26. package/dist/es5/lib/types/gltf-ext-feature-metadata-schema.js +2 -0
  27. package/dist/es5/lib/types/gltf-ext-feature-metadata-schema.js.map +1 -0
  28. package/dist/es5/lib/types/gltf-ext-mesh-features-schema.js +2 -0
  29. package/dist/es5/lib/types/gltf-ext-mesh-features-schema.js.map +1 -0
  30. package/dist/es5/lib/types/gltf-ext-structural-metadata-schema.js +2 -0
  31. package/dist/es5/lib/types/gltf-ext-structural-metadata-schema.js.map +1 -0
  32. package/dist/es5/lib/types/gltf-json-schema.js.map +1 -1
  33. package/dist/es5/lib/types/gltf-types.js.map +1 -1
  34. package/dist/es5/lib/utils/version.js +1 -1
  35. package/dist/es5/lib/utils/version.js.map +1 -1
  36. package/dist/esm/glb-loader.js +0 -1
  37. package/dist/esm/glb-loader.js.map +1 -1
  38. package/dist/esm/index.js +5 -0
  39. package/dist/esm/index.js.map +1 -1
  40. package/dist/esm/lib/api/gltf-extensions.js +3 -1
  41. package/dist/esm/lib/api/gltf-extensions.js.map +1 -1
  42. package/dist/esm/lib/extensions/EXT_mesh_features.js +43 -0
  43. package/dist/esm/lib/extensions/EXT_mesh_features.js.map +1 -0
  44. package/dist/esm/lib/extensions/EXT_meshopt_compression.js +2 -2
  45. package/dist/esm/lib/extensions/EXT_meshopt_compression.js.map +1 -1
  46. package/dist/esm/lib/extensions/EXT_structural_metadata.js +302 -0
  47. package/dist/esm/lib/extensions/EXT_structural_metadata.js.map +1 -0
  48. package/dist/esm/lib/extensions/KHR_draco_mesh_compression.js +2 -5
  49. package/dist/esm/lib/extensions/KHR_draco_mesh_compression.js.map +1 -1
  50. package/dist/esm/lib/extensions/KHR_texture_transform.js +2 -1
  51. package/dist/esm/lib/extensions/KHR_texture_transform.js.map +1 -1
  52. package/dist/esm/lib/extensions/deprecated/EXT_feature_metadata.js +156 -167
  53. package/dist/esm/lib/extensions/deprecated/EXT_feature_metadata.js.map +1 -1
  54. package/dist/esm/lib/extensions/utils/3d-tiles-utils.js +215 -0
  55. package/dist/esm/lib/extensions/utils/3d-tiles-utils.js.map +1 -0
  56. package/dist/esm/lib/gltf-utils/gltf-utils.js +30 -0
  57. package/dist/esm/lib/gltf-utils/gltf-utils.js.map +1 -1
  58. package/dist/esm/lib/parsers/parse-gltf.js +6 -6
  59. package/dist/esm/lib/parsers/parse-gltf.js.map +1 -1
  60. package/dist/esm/lib/types/gltf-ext-feature-metadata-schema.js +2 -0
  61. package/dist/esm/lib/types/gltf-ext-feature-metadata-schema.js.map +1 -0
  62. package/dist/esm/lib/types/gltf-ext-mesh-features-schema.js +2 -0
  63. package/dist/esm/lib/types/gltf-ext-mesh-features-schema.js.map +1 -0
  64. package/dist/esm/lib/types/gltf-ext-structural-metadata-schema.js +2 -0
  65. package/dist/esm/lib/types/gltf-ext-structural-metadata-schema.js.map +1 -0
  66. package/dist/esm/lib/types/gltf-json-schema.js.map +1 -1
  67. package/dist/esm/lib/types/gltf-types.js.map +1 -1
  68. package/dist/esm/lib/utils/version.js +1 -1
  69. package/dist/esm/lib/utils/version.js.map +1 -1
  70. package/dist/glb-loader.d.ts +3 -1
  71. package/dist/glb-loader.d.ts.map +1 -1
  72. package/dist/index.d.ts +10 -2
  73. package/dist/index.d.ts.map +1 -1
  74. package/dist/lib/api/gltf-extensions.d.ts.map +1 -1
  75. package/dist/lib/extensions/EXT_mesh_features.d.ts +7 -0
  76. package/dist/lib/extensions/EXT_mesh_features.d.ts.map +1 -0
  77. package/dist/lib/extensions/EXT_structural_metadata.d.ts +16 -0
  78. package/dist/lib/extensions/EXT_structural_metadata.d.ts.map +1 -0
  79. package/dist/lib/extensions/KHR_draco_mesh_compression.d.ts +1 -1
  80. package/dist/lib/extensions/KHR_draco_mesh_compression.d.ts.map +1 -1
  81. package/dist/lib/extensions/deprecated/EXT_feature_metadata.d.ts +9 -0
  82. package/dist/lib/extensions/deprecated/EXT_feature_metadata.d.ts.map +1 -1
  83. package/dist/lib/extensions/utils/3d-tiles-utils.d.ts +82 -0
  84. package/dist/lib/extensions/utils/3d-tiles-utils.d.ts.map +1 -0
  85. package/dist/lib/gltf-utils/gltf-utils.d.ts +2 -0
  86. package/dist/lib/gltf-utils/gltf-utils.d.ts.map +1 -1
  87. package/dist/lib/parsers/parse-gltf.d.ts.map +1 -1
  88. package/dist/lib/types/gltf-ext-feature-metadata-schema.d.ts +421 -0
  89. package/dist/lib/types/gltf-ext-feature-metadata-schema.d.ts.map +1 -0
  90. package/dist/lib/types/gltf-ext-mesh-features-schema.d.ts +43 -0
  91. package/dist/lib/types/gltf-ext-mesh-features-schema.d.ts.map +1 -0
  92. package/dist/lib/types/gltf-ext-structural-metadata-schema.d.ts +329 -0
  93. package/dist/lib/types/gltf-ext-structural-metadata-schema.d.ts.map +1 -0
  94. package/dist/lib/types/gltf-json-schema.d.ts +12 -404
  95. package/dist/lib/types/gltf-json-schema.d.ts.map +1 -1
  96. package/dist/lib/types/gltf-types.d.ts +4 -1
  97. package/dist/lib/types/gltf-types.d.ts.map +1 -1
  98. package/package.json +6 -6
  99. package/src/glb-loader.ts +3 -3
  100. package/src/index.ts +37 -6
  101. package/src/lib/api/gltf-extensions.ts +6 -2
  102. package/src/lib/extensions/EXT_mesh_features.ts +91 -0
  103. package/src/lib/extensions/EXT_meshopt_compression.ts +1 -1
  104. package/src/lib/extensions/EXT_structural_metadata.ts +750 -0
  105. package/src/lib/extensions/KHR_draco_mesh_compression.ts +7 -7
  106. package/src/lib/extensions/KHR_texture_transform.ts +1 -1
  107. package/src/lib/extensions/deprecated/EXT_feature_metadata.ts +407 -281
  108. package/src/lib/extensions/utils/3d-tiles-utils.ts +430 -0
  109. package/src/lib/gltf-utils/gltf-utils.ts +38 -0
  110. package/src/lib/parsers/parse-gltf.ts +14 -6
  111. package/src/lib/types/gltf-ext-feature-metadata-schema.ts +470 -0
  112. package/src/lib/types/gltf-ext-mesh-features-schema.ts +46 -0
  113. package/src/lib/types/gltf-ext-structural-metadata-schema.ts +378 -0
  114. package/src/lib/types/gltf-json-schema.ts +26 -465
  115. package/src/lib/types/gltf-types.ts +5 -3
  116. package/dist/bundle.js +0 -5
  117. package/dist/glb-loader.js +0 -36
  118. package/dist/glb-writer.js +0 -35
  119. package/dist/gltf-loader.js +0 -50
  120. package/dist/gltf-writer.js +0 -32
  121. package/dist/index.js +0 -28
  122. package/dist/lib/api/gltf-extensions.js +0 -83
  123. package/dist/lib/api/gltf-scenegraph.js +0 -580
  124. package/dist/lib/api/normalize-gltf-v1.js +0 -299
  125. package/dist/lib/api/post-process-gltf.js +0 -433
  126. package/dist/lib/encoders/encode-glb.js +0 -72
  127. package/dist/lib/encoders/encode-gltf.js +0 -32
  128. package/dist/lib/extensions/EXT_meshopt_compression.js +0 -41
  129. package/dist/lib/extensions/EXT_texture_webp.js +0 -36
  130. package/dist/lib/extensions/KHR_binary_gltf.js +0 -39
  131. package/dist/lib/extensions/KHR_draco_mesh_compression.js +0 -138
  132. package/dist/lib/extensions/KHR_texture_basisu.js +0 -29
  133. package/dist/lib/extensions/KHR_texture_transform.js +0 -227
  134. package/dist/lib/extensions/deprecated/EXT_feature_metadata.js +0 -290
  135. package/dist/lib/extensions/deprecated/KHR_lights_punctual.js +0 -59
  136. package/dist/lib/extensions/deprecated/KHR_materials_unlit.js +0 -44
  137. package/dist/lib/extensions/deprecated/KHR_techniques_webgl.js +0 -79
  138. package/dist/lib/gltf-utils/get-typed-array.js +0 -41
  139. package/dist/lib/gltf-utils/gltf-attribute-utils.js +0 -73
  140. package/dist/lib/gltf-utils/gltf-constants.js +0 -43
  141. package/dist/lib/gltf-utils/gltf-utils.js +0 -90
  142. package/dist/lib/gltf-utils/resolve-url.js +0 -18
  143. package/dist/lib/parsers/parse-glb.js +0 -166
  144. package/dist/lib/parsers/parse-gltf.js +0 -179
  145. package/dist/lib/types/glb-types.js +0 -2
  146. package/dist/lib/types/gltf-json-schema.js +0 -4
  147. package/dist/lib/types/gltf-postprocessed-schema.js +0 -4
  148. package/dist/lib/types/gltf-types.js +0 -3
  149. package/dist/lib/utils/assert.js +0 -12
  150. package/dist/lib/utils/version.js +0 -7
  151. package/dist/meshopt/meshopt-decoder.js +0 -118
  152. package/dist/webp/webp.js +0 -38
@@ -1 +1 @@
1
- {"version":3,"file":"KHR_texture_transform.js","names":["_core","require","_gltfUtils","_gltfConstants","_gltfScenegraph","_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","hasExtension","materials","wrap","_callee$","_context","prev","GLTFScenegraph","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","translationMatrix","rotationMatrix","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 {GLTFWithBuffers} from '../types/gltf-types';\nimport type {\n GLTFMeshPrimitive,\n GLTFAccessor,\n GLTFBufferView,\n GLTFMaterialNormalTextureInfo,\n GLTFMaterialOcclusionTextureInfo,\n GLTFTextureInfo\n} from '../types/gltf-json-schema';\nimport type {GLTFLoaderOptions} from '../../gltf-loader';\n\nimport {getAccessorArrayTypeAndLength} from '../gltf-utils/gltf-utils';\nimport {BYTES, COMPONENTS} from '../gltf-utils/gltf-constants';\nimport {} 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 GLTFMaterialNormalTextureInfo &\n GLTFMaterialOcclusionTextureInfo;\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 hasExtension = gltfScenegraph.hasExtension(EXT_MESHOPT_TRANSFORM);\n if (!hasExtension) {\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: GLTFAccessor,\n bufferView: GLTFBufferView,\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: GLTFAccessor,\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 translationMatrix = new Matrix3().set(1, 0, 0, 0, 1, 0, offset[0], offset[1], 1);\n const rotationMatrix = 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 translationMatrix.multiplyRight(rotationMatrix).multiplyRight(scaleMatrix);\n}\n"],"mappings":"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"}
1
+ {"version":3,"file":"KHR_texture_transform.js","names":["_core","require","_gltfUtils","_gltfConstants","_gltfScenegraph","_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","_options$gltf","gltfScenegraph","hasExtension","materials","wrap","_callee$","_context","prev","GLTFScenegraph","gltf","loadBuffers","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","translationMatrix","rotationMatrix","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 {GLTFWithBuffers} from '../types/gltf-types';\nimport type {\n GLTFMeshPrimitive,\n GLTFAccessor,\n GLTFBufferView,\n GLTFMaterialNormalTextureInfo,\n GLTFMaterialOcclusionTextureInfo,\n GLTFTextureInfo\n} from '../types/gltf-json-schema';\nimport type {GLTFLoaderOptions} from '../../gltf-loader';\n\nimport {getAccessorArrayTypeAndLength} from '../gltf-utils/gltf-utils';\nimport {BYTES, COMPONENTS} from '../gltf-utils/gltf-constants';\nimport {} 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 GLTFMaterialNormalTextureInfo &\n GLTFMaterialOcclusionTextureInfo;\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 hasExtension = gltfScenegraph.hasExtension(EXT_MESHOPT_TRANSFORM);\n if (!hasExtension || !options.gltf?.loadBuffers) {\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: GLTFAccessor,\n bufferView: GLTFBufferView,\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: GLTFAccessor,\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 translationMatrix = new Matrix3().set(1, 0, 0, 0, 1, 0, offset[0], offset[1], 1);\n const rotationMatrix = 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 translationMatrix.multiplyRight(rotationMatrix).multiplyRight(scaleMatrix);\n}\n"],"mappings":"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"}
@@ -5,17 +5,20 @@ Object.defineProperty(exports, "__esModule", {
5
5
  value: true
6
6
  });
7
7
  exports.decode = decode;
8
+ exports.getPropertyTableFromExtFeatureMetadata = getPropertyTableFromExtFeatureMetadata;
8
9
  exports.name = void 0;
9
10
  var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
11
+ var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
10
12
  var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
11
13
  var _gltfScenegraph = require("../../api/gltf-scenegraph");
12
- var _images = require("@loaders.gl/images");
13
- var _gltfUtils = require("../../gltf-utils/gltf-utils");
14
+ var _dTilesUtils = require("../utils/3d-tiles-utils");
15
+ function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
16
+ function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { (0, _defineProperty2.default)(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
14
17
  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
18
  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
19
  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;
20
+ var EXT_FEATURE_METADATA_NAME = 'EXT_feature_metadata';
21
+ var name = EXT_FEATURE_METADATA_NAME;
19
22
  exports.name = name;
20
23
  function decode(_x, _x2) {
21
24
  return _decode.apply(this, arguments);
@@ -36,41 +39,121 @@ function _decode() {
36
39
  }));
37
40
  return _decode.apply(this, arguments);
38
41
  }
42
+ function getPropertyTableFromExtFeatureMetadata(extension, metadataClass) {
43
+ if (extension.featureTables) {
44
+ var _Object$keys;
45
+ var firstFeatureTableName = (_Object$keys = Object.keys(extension.featureTables)) === null || _Object$keys === void 0 ? void 0 : _Object$keys[0];
46
+ if (firstFeatureTableName) {
47
+ var featureTable = extension.featureTables[firstFeatureTableName];
48
+ var propertyTable = {};
49
+ for (var propertyName in featureTable.properties) {
50
+ propertyTable[propertyName] = featureTable.properties[propertyName].data;
51
+ }
52
+ return propertyTable;
53
+ }
54
+ }
55
+ if (extension.featureTextures) {
56
+ var featureTexture;
57
+ for (var textureKey in extension.featureTextures) {
58
+ var texture = extension.featureTextures[textureKey];
59
+ if (texture.class === metadataClass) {
60
+ featureTexture = textureKey;
61
+ }
62
+ }
63
+ if (typeof featureTexture === 'string') {
64
+ var _featureTable = extension.featureTextures[featureTexture];
65
+ var _propertyTable = {};
66
+ for (var _propertyName in _featureTable.properties) {
67
+ _propertyTable[_propertyName] = _featureTable.properties[_propertyName].data;
68
+ }
69
+ return _propertyTable;
70
+ }
71
+ }
72
+ console.warn('Cannot get property table from EXT_feature_metadata extension. There is neither featureTables, nor featureTextures in the extension.');
73
+ return null;
74
+ }
39
75
  function decodeExtFeatureMetadata(scenegraph, options) {
40
- var _extension$schema, _options$gltf;
41
- var extension = scenegraph.getExtension(EXT_FEATURE_METADATA);
42
- if (!extension) return;
43
- var schemaClasses = (_extension$schema = extension.schema) === null || _extension$schema === void 0 ? void 0 : _extension$schema.classes;
44
- var featureTables = extension.featureTables;
45
- if (schemaClasses && featureTables) {
76
+ var _options$gltf, _options$gltf2;
77
+ if (!((_options$gltf = options.gltf) !== null && _options$gltf !== void 0 && _options$gltf.loadBuffers)) {
78
+ return;
79
+ }
80
+ var extension = scenegraph.getExtension(EXT_FEATURE_METADATA_NAME);
81
+ if (!extension) {
82
+ return;
83
+ }
84
+ if ((_options$gltf2 = options.gltf) !== null && _options$gltf2 !== void 0 && _options$gltf2.loadImages) {
85
+ decodePropertyTextures(scenegraph, extension);
86
+ }
87
+ decodePropertyTables(scenegraph, extension);
88
+ }
89
+ function decodePropertyTextures(scenegraph, extension) {
90
+ var schema = extension.schema;
91
+ if (!schema) {
92
+ return;
93
+ }
94
+ var schemaClasses = schema.classes;
95
+ var featureTextures = extension.featureTextures;
96
+ if (schemaClasses && featureTextures) {
46
97
  for (var schemaName in schemaClasses) {
47
98
  var schemaClass = schemaClasses[schemaName];
48
- var featureTable = findFeatureTableByName(featureTables, schemaName);
49
- if (featureTable) {
50
- handleFeatureTableProperties(scenegraph, featureTable, schemaClass);
99
+ var featureTexture = findFeatureTextureByClass(featureTextures, schemaName);
100
+ if (featureTexture) {
101
+ handleFeatureTextureProperties(scenegraph, featureTexture, schemaClass);
51
102
  }
52
103
  }
53
104
  }
54
- var featureTextures = extension.featureTextures;
55
- if (schemaClasses && featureTextures && (_options$gltf = options.gltf) !== null && _options$gltf !== void 0 && _options$gltf.loadImages) {
56
- for (var _schemaName in schemaClasses) {
57
- var _schemaClass = schemaClasses[_schemaName];
58
- var featureTexture = findFeatureTextureByName(featureTextures, _schemaName);
59
- if (featureTexture) {
60
- handleFeatureTextureProperties(scenegraph, featureTexture, _schemaClass);
105
+ }
106
+ function decodePropertyTables(scenegraph, extension) {
107
+ var schema = extension.schema;
108
+ if (!schema) {
109
+ return;
110
+ }
111
+ var schemaClasses = schema.classes;
112
+ var propertyTables = extension.featureTables;
113
+ if (schemaClasses && propertyTables) {
114
+ for (var schemaName in schemaClasses) {
115
+ var propertyTable = findPropertyTableByClass(propertyTables, schemaName);
116
+ if (propertyTable) {
117
+ processPropertyTable(scenegraph, schema, propertyTable);
61
118
  }
62
119
  }
63
120
  }
64
121
  }
65
- function handleFeatureTableProperties(scenegraph, featureTable, schemaClass) {
122
+ function findPropertyTableByClass(propertyTables, schemaClassName) {
123
+ for (var propertyTableName in propertyTables) {
124
+ var propertyTable = propertyTables[propertyTableName];
125
+ if (propertyTable.class === schemaClassName) {
126
+ return propertyTable;
127
+ }
128
+ }
129
+ return null;
130
+ }
131
+ function findFeatureTextureByClass(featureTextures, schemaClassName) {
132
+ for (var featureTexturesName in featureTextures) {
133
+ var featureTable = featureTextures[featureTexturesName];
134
+ if (featureTable.class === schemaClassName) {
135
+ return featureTable;
136
+ }
137
+ }
138
+ return null;
139
+ }
140
+ function processPropertyTable(scenegraph, schema, propertyTable) {
141
+ var _schema$classes;
142
+ if (!propertyTable.class) {
143
+ return;
144
+ }
145
+ var schemaClass = (_schema$classes = schema.classes) === null || _schema$classes === void 0 ? void 0 : _schema$classes[propertyTable.class];
146
+ if (!schemaClass) {
147
+ throw new Error("Incorrect data in the EXT_structural_metadata extension: no schema class with name ".concat(propertyTable.class));
148
+ }
149
+ var numberOfElements = propertyTable.count;
66
150
  for (var propertyName in schemaClass.properties) {
67
- var _featureTable$propert;
68
- var schemaProperty = schemaClass.properties[propertyName];
69
- var featureTableProperty = featureTable === null || featureTable === void 0 ? void 0 : (_featureTable$propert = featureTable.properties) === null || _featureTable$propert === void 0 ? void 0 : _featureTable$propert[propertyName];
70
- var numberOfFeatures = featureTable.count;
71
- if (featureTableProperty) {
72
- var data = getPropertyDataFromBinarySource(scenegraph, schemaProperty, numberOfFeatures, featureTableProperty);
73
- featureTableProperty.data = data;
151
+ var _propertyTable$proper;
152
+ var classProperty = schemaClass.properties[propertyName];
153
+ var propertyTableProperty = (_propertyTable$proper = propertyTable.properties) === null || _propertyTable$proper === void 0 ? void 0 : _propertyTable$proper[propertyName];
154
+ if (propertyTableProperty) {
155
+ var data = getPropertyDataFromBinarySource(scenegraph, schema, classProperty, numberOfElements, propertyTableProperty);
156
+ propertyTableProperty.data = data;
74
157
  }
75
158
  }
76
159
  }
@@ -85,19 +168,53 @@ function handleFeatureTextureProperties(scenegraph, featureTexture, schemaClass)
85
168
  }
86
169
  }
87
170
  }
88
- function getPropertyDataFromBinarySource(scenegraph, schemaProperty, numberOfFeatures, featureTableProperty) {
171
+ function getPropertyDataFromBinarySource(scenegraph, schema, classProperty, numberOfFeatures, featureTableProperty) {
172
+ var data = [];
89
173
  var bufferView = featureTableProperty.bufferView;
90
174
  var dataArray = scenegraph.getTypedArrayForBufferView(bufferView);
91
- switch (schemaProperty.type) {
92
- case 'STRING':
93
- {
94
- var stringOffsetBufferView = featureTableProperty.stringOffsetBufferView;
95
- var offsetsData = scenegraph.getTypedArrayForBufferView(stringOffsetBufferView);
96
- return getStringAttributes(dataArray, offsetsData, numberOfFeatures);
97
- }
98
- default:
175
+ var arrayOffsets = getArrayOffsetsForProperty(scenegraph, classProperty, featureTableProperty, numberOfFeatures);
176
+ var stringOffsets = getStringOffsetsForProperty(scenegraph, classProperty, featureTableProperty, numberOfFeatures);
177
+ if (classProperty.type === 'STRING' || classProperty.componentType === 'STRING') {
178
+ data = (0, _dTilesUtils.getPropertyDataString)(numberOfFeatures, dataArray, arrayOffsets, stringOffsets);
179
+ } else if (isNumericProperty(classProperty)) {
180
+ data = getPropertyDataNumeric(classProperty, numberOfFeatures, dataArray, arrayOffsets);
99
181
  }
100
- return dataArray;
182
+ return data;
183
+ }
184
+ function getArrayOffsetsForProperty(scenegraph, classProperty, propertyTableProperty, numberOfElements) {
185
+ if (classProperty.type === 'ARRAY' && typeof classProperty.componentCount === 'undefined' && typeof propertyTableProperty.arrayOffsetBufferView !== 'undefined') {
186
+ return (0, _dTilesUtils.getOffsetsForProperty)(scenegraph, propertyTableProperty.arrayOffsetBufferView, propertyTableProperty.offsetType || 'UINT32', numberOfElements);
187
+ }
188
+ return null;
189
+ }
190
+ function getStringOffsetsForProperty(scenegraph, classProperty, propertyTableProperty, numberOfElements) {
191
+ if (typeof propertyTableProperty.stringOffsetBufferView !== 'undefined') {
192
+ return (0, _dTilesUtils.getOffsetsForProperty)(scenegraph, propertyTableProperty.stringOffsetBufferView, propertyTableProperty.offsetType || 'UINT32', numberOfElements);
193
+ }
194
+ return null;
195
+ }
196
+ function isNumericProperty(schemaProperty) {
197
+ var types = ['UINT8', 'INT16', 'UINT16', 'INT32', 'UINT32', 'INT64', 'UINT64', 'FLOAT32', 'FLOAT64'];
198
+ return types.includes(schemaProperty.type) || typeof schemaProperty.componentType !== 'undefined' && types.includes(schemaProperty.componentType);
199
+ }
200
+ function getPropertyDataNumeric(classProperty, numberOfElements, valuesDataBytes, arrayOffsets) {
201
+ var isArray = classProperty.type === 'ARRAY';
202
+ var arrayCount = classProperty.componentCount;
203
+ var attributeType = 'SCALAR';
204
+ var componentType = classProperty.componentType || classProperty.type;
205
+ var elementSize = (0, _dTilesUtils.getArrayElementByteSize)(attributeType, componentType);
206
+ var elementCount = valuesDataBytes.byteLength / elementSize;
207
+ var valuesData = (0, _dTilesUtils.convertRawBufferToMetadataArray)(valuesDataBytes, attributeType, componentType, elementCount);
208
+ if (isArray) {
209
+ if (arrayOffsets) {
210
+ return (0, _dTilesUtils.parseVariableLengthArrayNumeric)(valuesData, numberOfElements, arrayOffsets, valuesDataBytes.length, elementSize);
211
+ }
212
+ if (arrayCount) {
213
+ return (0, _dTilesUtils.parseFixedLengthArrayNumeric)(valuesData, numberOfElements, arrayCount);
214
+ }
215
+ return [];
216
+ }
217
+ return valuesData;
101
218
  }
102
219
  function getPropertyDataFromTexture(scenegraph, featureTextureProperty, attributeName) {
103
220
  var json = scenegraph.gltf.json;
@@ -131,151 +248,13 @@ function getPropertyDataFromTexture(scenegraph, featureTextureProperty, attribut
131
248
  return featureTextureTable;
132
249
  }
133
250
  function processPrimitiveTextures(scenegraph, attributeName, featureTextureProperty, featureTextureTable, primitive) {
134
- var _json$textures;
135
- var json = scenegraph.gltf.json;
136
- var textureData = [];
137
- var texCoordAccessorKey = "TEXCOORD_".concat(featureTextureProperty.texture.texCoord);
138
- var texCoordAccessorIndex = primitive.attributes[texCoordAccessorKey];
139
- var texCoordBufferView = scenegraph.getBufferView(texCoordAccessorIndex);
140
- var texCoordArray = scenegraph.getTypedArrayForBufferView(texCoordBufferView);
141
- var textureCoordinates = new Float32Array(texCoordArray.buffer, texCoordArray.byteOffset, texCoordArray.length / 4);
142
- var textureIndex = featureTextureProperty.texture.index;
143
- var texture = (_json$textures = json.textures) === null || _json$textures === void 0 ? void 0 : _json$textures[textureIndex];
144
- var imageIndex = texture === null || texture === void 0 ? void 0 : texture.source;
145
- if (typeof imageIndex !== 'undefined') {
146
- var _json$images, _scenegraph$gltf$imag;
147
- var image = (_json$images = json.images) === null || _json$images === void 0 ? void 0 : _json$images[imageIndex];
148
- var mimeType = image === null || image === void 0 ? void 0 : image.mimeType;
149
- var parsedImage = (_scenegraph$gltf$imag = scenegraph.gltf.images) === null || _scenegraph$gltf$imag === void 0 ? void 0 : _scenegraph$gltf$imag[imageIndex];
150
- if (parsedImage) {
151
- for (var index = 0; index < textureCoordinates.length; index += 2) {
152
- var value = getImageValueByCoordinates(parsedImage, mimeType, textureCoordinates, index, featureTextureProperty.channels);
153
- textureData.push(value);
154
- }
155
- }
156
- }
157
- var featureIndices = [];
158
- var _loop = function _loop() {
159
- var texelData = _textureData[_i];
160
- var index = featureTextureTable.findIndex(function (item) {
161
- return item === texelData;
162
- });
163
- if (index === -1) {
164
- index = featureTextureTable.push(texelData) - 1;
165
- }
166
- featureIndices.push(index);
167
- };
168
- for (var _i = 0, _textureData = textureData; _i < _textureData.length; _i++) {
169
- _loop();
170
- }
171
- var typedArray = new Uint32Array(featureIndices);
172
- var bufferIndex = scenegraph.gltf.buffers.push({
173
- arrayBuffer: typedArray.buffer,
174
- byteOffset: 0,
175
- byteLength: typedArray.byteLength
176
- }) - 1;
177
- var bufferViewIndex = scenegraph.addBufferView(typedArray, bufferIndex, 0);
178
- var accessorIndex = scenegraph.addAccessor(bufferViewIndex, {
179
- size: 1,
180
- componentType: (0, _gltfUtils.getComponentTypeFromArray)(typedArray),
181
- count: typedArray.length
182
- });
183
- primitive.attributes[attributeName] = accessorIndex;
184
- }
185
- function getImageValueByCoordinates(parsedImage, mimeType, textureCoordinates, index, channels) {
186
- var CHANNELS_MAP = {
187
- r: {
188
- offset: 0,
189
- shift: 0
190
- },
191
- g: {
192
- offset: 1,
193
- shift: 8
194
- },
195
- b: {
196
- offset: 2,
197
- shift: 16
198
- },
199
- a: {
200
- offset: 3,
201
- shift: 24
202
- }
203
- };
204
- var u = textureCoordinates[index];
205
- var v = textureCoordinates[index + 1];
206
- var components = 1;
207
- if (mimeType && (mimeType.indexOf('image/jpeg') !== -1 || mimeType.indexOf('image/png') !== -1)) components = 4;
208
- var offset = coordinatesToOffset(u, v, parsedImage, components);
209
- var value = 0;
210
- var _iterator3 = _createForOfIteratorHelper(channels),
211
- _step3;
212
- try {
213
- for (_iterator3.s(); !(_step3 = _iterator3.n()).done;) {
214
- var c = _step3.value;
215
- var map = CHANNELS_MAP[c];
216
- var val = getVal(parsedImage, offset + map.offset);
217
- value |= val << map.shift;
218
- }
219
- } catch (err) {
220
- _iterator3.e(err);
221
- } finally {
222
- _iterator3.f();
223
- }
224
- return value;
225
- }
226
- function getVal(parsedImage, offset) {
227
- var imageData = (0, _images.getImageData)(parsedImage);
228
- if (imageData.data.length <= offset) {
229
- throw new Error("".concat(imageData.data.length, " <= ").concat(offset));
230
- }
231
- return imageData.data[offset];
232
- }
233
- function coordinatesToOffset(u, v, parsedImage) {
234
- var componentsCount = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : 1;
235
- var w = parsedImage.width;
236
- var iX = emod(u) * (w - 1);
237
- var indX = Math.round(iX);
238
- var h = parsedImage.height;
239
- var iY = emod(v) * (h - 1);
240
- var indY = Math.round(iY);
241
- var components = parsedImage.components ? parsedImage.components : componentsCount;
242
- var offset = (indY * w + indX) * components;
243
- return offset;
244
- }
245
- function emod(n) {
246
- var a = (n % 1 + 1) % 1;
247
- return a;
248
- }
249
- function findFeatureTableByName(featureTables, schemaClassName) {
250
- for (var featureTableName in featureTables) {
251
- var featureTable = featureTables[featureTableName];
252
- if (featureTable.class === schemaClassName) {
253
- return featureTable;
254
- }
255
- }
256
- return null;
257
- }
258
- function findFeatureTextureByName(featureTextures, schemaClassName) {
259
- for (var featureTexturesName in featureTextures) {
260
- var featureTable = featureTextures[featureTexturesName];
261
- if (featureTable.class === schemaClassName) {
262
- return featureTable;
263
- }
264
- }
265
- return null;
266
- }
267
- function getStringAttributes(data, offsetsData, stringsCount) {
268
- var stringsArray = [];
269
- var textDecoder = new TextDecoder('utf8');
270
- var stringOffset = 0;
271
- var bytesPerStringSize = 4;
272
- for (var index = 0; index < stringsCount; index++) {
273
- var stringByteSize = offsetsData[(index + 1) * bytesPerStringSize] - offsetsData[index * bytesPerStringSize];
274
- var stringData = data.subarray(stringOffset, stringByteSize + stringOffset);
275
- var stringAttribute = textDecoder.decode(stringData);
276
- stringsArray.push(stringAttribute);
277
- stringOffset += stringByteSize;
251
+ var textureInfoTopLevel = _objectSpread({
252
+ channels: featureTextureProperty.channels
253
+ }, featureTextureProperty.texture);
254
+ var propertyData = (0, _dTilesUtils.getPrimitiveTextureData)(scenegraph, textureInfoTopLevel, primitive);
255
+ if (!propertyData) {
256
+ return;
278
257
  }
279
- return stringsArray;
258
+ (0, _dTilesUtils.primitivePropertyDataToAttributes)(scenegraph, attributeName, propertyData, featureTextureTable, primitive);
280
259
  }
281
260
  //# sourceMappingURL=EXT_feature_metadata.js.map