@loaders.gl/gltf 3.3.0-alpha.5 → 3.3.0-alpha.6
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.
- package/dist/dist.min.js +104 -124
- package/dist/es5/bundle.js +0 -1
- package/dist/es5/bundle.js.map +1 -1
- package/dist/es5/glb-loader.js +2 -13
- package/dist/es5/glb-loader.js.map +1 -1
- package/dist/es5/glb-writer.js +3 -6
- package/dist/es5/glb-writer.js.map +1 -1
- package/dist/es5/gltf-loader.js +11 -23
- package/dist/es5/gltf-loader.js.map +1 -1
- package/dist/es5/gltf-writer.js +2 -5
- package/dist/es5/gltf-writer.js.map +1 -1
- package/dist/es5/index.js +10 -17
- package/dist/es5/index.js.map +1 -1
- package/dist/es5/lib/api/gltf-extensions.js +14 -48
- package/dist/es5/lib/api/gltf-extensions.js.map +1 -1
- package/dist/es5/lib/api/gltf-scenegraph.js +113 -96
- package/dist/es5/lib/api/gltf-scenegraph.js.map +1 -1
- package/dist/es5/lib/api/normalize-gltf-v1.js +32 -70
- package/dist/es5/lib/api/normalize-gltf-v1.js.map +1 -1
- package/dist/es5/lib/api/post-process-gltf.js +26 -89
- package/dist/es5/lib/api/post-process-gltf.js.map +1 -1
- package/dist/es5/lib/encoders/encode-glb.js +10 -8
- package/dist/es5/lib/encoders/encode-glb.js.map +1 -1
- package/dist/es5/lib/encoders/encode-gltf.js +3 -6
- package/dist/es5/lib/encoders/encode-gltf.js.map +1 -1
- package/dist/es5/lib/extensions/EXT_meshopt_compression.js +2 -28
- package/dist/es5/lib/extensions/EXT_meshopt_compression.js.map +1 -1
- package/dist/es5/lib/extensions/EXT_texture_webp.js +5 -18
- package/dist/es5/lib/extensions/EXT_texture_webp.js.map +1 -1
- package/dist/es5/lib/extensions/KHR_binary_gltf.js +5 -12
- package/dist/es5/lib/extensions/KHR_binary_gltf.js.map +1 -1
- package/dist/es5/lib/extensions/KHR_draco_mesh_compression.js +11 -79
- package/dist/es5/lib/extensions/KHR_draco_mesh_compression.js.map +1 -1
- package/dist/es5/lib/extensions/KHR_texture_basisu.js +5 -14
- package/dist/es5/lib/extensions/KHR_texture_basisu.js.map +1 -1
- package/dist/es5/lib/extensions/KHR_texture_transform.js +17 -72
- package/dist/es5/lib/extensions/KHR_texture_transform.js.map +1 -1
- package/dist/es5/lib/extensions/deprecated/EXT_feature_metadata.js +0 -21
- package/dist/es5/lib/extensions/deprecated/EXT_feature_metadata.js.map +1 -1
- package/dist/es5/lib/extensions/deprecated/KHR_lights_punctual.js +0 -24
- package/dist/es5/lib/extensions/deprecated/KHR_lights_punctual.js.map +1 -1
- package/dist/es5/lib/extensions/deprecated/KHR_materials_unlit.js +2 -19
- package/dist/es5/lib/extensions/deprecated/KHR_materials_unlit.js.map +1 -1
- package/dist/es5/lib/extensions/deprecated/KHR_techniques_webgl.js +11 -29
- package/dist/es5/lib/extensions/deprecated/KHR_techniques_webgl.js.map +1 -1
- package/dist/es5/lib/gltf-utils/get-typed-array.js +1 -1
- package/dist/es5/lib/gltf-utils/get-typed-array.js.map +1 -1
- package/dist/es5/lib/gltf-utils/gltf-attribute-utils.js +5 -17
- package/dist/es5/lib/gltf-utils/gltf-attribute-utils.js.map +1 -1
- package/dist/es5/lib/gltf-utils/gltf-constants.js +3 -4
- package/dist/es5/lib/gltf-utils/gltf-constants.js.map +1 -1
- package/dist/es5/lib/gltf-utils/gltf-utils.js +1 -8
- package/dist/es5/lib/gltf-utils/gltf-utils.js.map +1 -1
- package/dist/es5/lib/gltf-utils/resolve-url.js +0 -5
- package/dist/es5/lib/gltf-utils/resolve-url.js.map +1 -1
- package/dist/es5/lib/parsers/parse-glb.js +11 -17
- package/dist/es5/lib/parsers/parse-glb.js.map +1 -1
- package/dist/es5/lib/parsers/parse-gltf.js +12 -73
- package/dist/es5/lib/parsers/parse-gltf.js.map +1 -1
- package/dist/es5/lib/types/glb-types.js.map +1 -1
- package/dist/es5/lib/types/gltf-json-schema.js.map +1 -1
- package/dist/es5/lib/types/gltf-postprocessed-schema.js.map +1 -1
- package/dist/es5/lib/types/gltf-types.js.map +1 -1
- package/dist/es5/lib/utils/assert.js +0 -1
- package/dist/es5/lib/utils/assert.js.map +1 -1
- package/dist/es5/lib/utils/version.js +1 -1
- package/dist/es5/lib/utils/version.js.map +1 -1
- package/dist/es5/meshopt/meshopt-decoder.js +10 -47
- package/dist/es5/meshopt/meshopt-decoder.js.map +1 -1
- package/dist/es5/webp/webp.js +3 -19
- package/dist/es5/webp/webp.js.map +1 -1
- package/dist/esm/bundle.js +1 -1
- package/dist/esm/bundle.js.map +1 -1
- package/dist/esm/glb-loader.js +0 -1
- package/dist/esm/glb-loader.js.map +1 -1
- package/dist/esm/glb-writer.js +3 -1
- package/dist/esm/glb-writer.js.map +1 -1
- package/dist/esm/gltf-loader.js +9 -3
- package/dist/esm/gltf-loader.js.map +1 -1
- package/dist/esm/gltf-writer.js +3 -2
- package/dist/esm/gltf-writer.js.map +1 -1
- package/dist/esm/index.js +4 -0
- package/dist/esm/index.js.map +1 -1
- package/dist/esm/lib/api/gltf-extensions.js +16 -9
- package/dist/esm/lib/api/gltf-extensions.js.map +1 -1
- package/dist/esm/lib/api/gltf-scenegraph.js +27 -68
- package/dist/esm/lib/api/gltf-scenegraph.js.map +1 -1
- package/dist/esm/lib/api/normalize-gltf-v1.js +3 -34
- package/dist/esm/lib/api/normalize-gltf-v1.js.map +1 -1
- package/dist/esm/lib/api/post-process-gltf.js +26 -93
- package/dist/esm/lib/api/post-process-gltf.js.map +1 -1
- package/dist/esm/lib/encoders/encode-glb.js +9 -2
- package/dist/esm/lib/encoders/encode-glb.js.map +1 -1
- package/dist/esm/lib/encoders/encode-gltf.js +6 -4
- package/dist/esm/lib/encoders/encode-gltf.js.map +1 -1
- package/dist/esm/lib/extensions/EXT_meshopt_compression.js +5 -6
- package/dist/esm/lib/extensions/EXT_meshopt_compression.js.map +1 -1
- package/dist/esm/lib/extensions/EXT_texture_webp.js +4 -6
- package/dist/esm/lib/extensions/EXT_texture_webp.js.map +1 -1
- package/dist/esm/lib/extensions/KHR_binary_gltf.js +3 -2
- package/dist/esm/lib/extensions/KHR_binary_gltf.js.map +1 -1
- package/dist/esm/lib/extensions/KHR_draco_mesh_compression.js +18 -17
- package/dist/esm/lib/extensions/KHR_draco_mesh_compression.js.map +1 -1
- package/dist/esm/lib/extensions/KHR_texture_basisu.js +4 -3
- package/dist/esm/lib/extensions/KHR_texture_basisu.js.map +1 -1
- package/dist/esm/lib/extensions/KHR_texture_transform.js +8 -34
- package/dist/esm/lib/extensions/KHR_texture_transform.js.map +1 -1
- package/dist/esm/lib/extensions/deprecated/EXT_feature_metadata.js +2 -13
- package/dist/esm/lib/extensions/deprecated/EXT_feature_metadata.js.map +1 -1
- package/dist/esm/lib/extensions/deprecated/KHR_lights_punctual.js +4 -4
- package/dist/esm/lib/extensions/deprecated/KHR_lights_punctual.js.map +1 -1
- package/dist/esm/lib/extensions/deprecated/KHR_materials_unlit.js +3 -2
- package/dist/esm/lib/extensions/deprecated/KHR_materials_unlit.js.map +1 -1
- package/dist/esm/lib/extensions/deprecated/KHR_techniques_webgl.js +10 -10
- package/dist/esm/lib/extensions/deprecated/KHR_techniques_webgl.js.map +1 -1
- package/dist/esm/lib/gltf-utils/get-typed-array.js +4 -0
- package/dist/esm/lib/gltf-utils/get-typed-array.js.map +1 -1
- package/dist/esm/lib/gltf-utils/gltf-attribute-utils.js +7 -11
- package/dist/esm/lib/gltf-utils/gltf-attribute-utils.js.map +1 -1
- package/dist/esm/lib/gltf-utils/gltf-constants.js +1 -0
- package/dist/esm/lib/gltf-utils/gltf-constants.js.map +1 -1
- package/dist/esm/lib/gltf-utils/gltf-utils.js +0 -2
- package/dist/esm/lib/gltf-utils/gltf-utils.js.map +1 -1
- package/dist/esm/lib/gltf-utils/resolve-url.js +1 -4
- package/dist/esm/lib/gltf-utils/resolve-url.js.map +1 -1
- package/dist/esm/lib/parsers/parse-glb.js +19 -16
- package/dist/esm/lib/parsers/parse-glb.js.map +1 -1
- package/dist/esm/lib/parsers/parse-gltf.js +11 -16
- package/dist/esm/lib/parsers/parse-gltf.js.map +1 -1
- package/dist/esm/lib/types/glb-types.js.map +1 -1
- package/dist/esm/lib/types/gltf-json-schema.js.map +1 -1
- package/dist/esm/lib/types/gltf-postprocessed-schema.js.map +1 -1
- package/dist/esm/lib/types/gltf-types.js.map +1 -1
- package/dist/esm/lib/utils/assert.js +1 -0
- package/dist/esm/lib/utils/assert.js.map +1 -1
- package/dist/esm/lib/utils/version.js +2 -1
- package/dist/esm/lib/utils/version.js.map +1 -1
- package/dist/esm/meshopt/meshopt-decoder.js +11 -15
- package/dist/esm/meshopt/meshopt-decoder.js.map +1 -1
- package/dist/esm/webp/webp.js +3 -5
- package/dist/esm/webp/webp.js.map +1 -1
- package/dist/lib/api/gltf-extensions.js +5 -1
- package/dist/lib/api/normalize-gltf-v1.js +5 -1
- package/dist/lib/parsers/parse-gltf.js +5 -1
- package/package.json +6 -6
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../../src/lib/extensions/KHR_draco_mesh_compression.ts"],"names":["makeMeshPrimitiveIterator","KHR_DRACO_MESH_COMPRESSION","name","preprocess","gltfData","options","context","scenegraph","Scenegraph","primitive","getObjectExtension","decode","gltf","decompressMeshes","promises","push","decompressPrimitive","Promise","all","removeExtension","encode","json","meshes","mesh","compressMesh","addRequiredExtension","dracoExtension","buffer","getTypedArrayForBufferView","bufferView","bufferCopy","byteOffset","parse","dracoOptions","DracoLoader","decodedData","decodedAttributes","attributes","Object","entries","attributeName","decodedAttribute","accessorIndex","accessor","getAccessor","min","max","indices","checkPrimitive","mode","DracoWriter","Error","compressedData","encodeSync","parseSync","fauxAccessors","_addFauxAttributes","bufferViewIndex","addBufferView","glTFMesh","primitives","extensions","keys","length"],"mappings":"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","sourcesContent":["// https://github.com/KhronosGroup/glTF/tree/master/extensions/2.0/Khronos/KHR_draco_mesh_compression\n// Only TRIANGLES: 0x0004 and TRIANGLE_STRIP: 0x0005 are supported\n/* eslint-disable camelcase */\n\n/* eslint-disable camelcase */\nimport type {\n GLTF,\n GLTFAccessor,\n GLTFMeshPrimitive,\n GLTF_KHR_draco_mesh_compression\n} from '../types/gltf-types';\nimport type {GLTFLoaderOptions} from '../../gltf-loader';\n\nimport type {LoaderContext} from '@loaders.gl/loader-utils';\nimport {DracoLoader} from '@loaders.gl/draco';\nimport {DracoLoaderOptions, DracoMesh} from '@loaders.gl/draco';\nimport {sliceArrayBuffer} from '@loaders.gl/loader-utils';\nimport {default as Scenegraph} from '../api/gltf-scenegraph';\nimport {getGLTFAccessors, getGLTFAccessor} from '../gltf-utils/gltf-attribute-utils';\n\nconst KHR_DRACO_MESH_COMPRESSION = 'KHR_draco_mesh_compression';\n\n/** Extension name */\nexport const name = KHR_DRACO_MESH_COMPRESSION;\n\nexport function preprocess(\n gltfData: {json: GLTF},\n options: GLTFLoaderOptions,\n context: LoaderContext\n): void {\n const scenegraph = new Scenegraph(gltfData);\n for (const primitive of makeMeshPrimitiveIterator(scenegraph)) {\n if (scenegraph.getObjectExtension(primitive, KHR_DRACO_MESH_COMPRESSION)) {\n // TODO - Remove fallback accessors to make sure we don't load unnecessary buffers\n }\n }\n}\n\nexport async function decode(\n gltfData: {json: GLTF},\n options: GLTFLoaderOptions,\n context: LoaderContext\n): Promise<void> {\n if (!options?.gltf?.decompressMeshes) {\n return;\n }\n\n const scenegraph = new Scenegraph(gltfData);\n const promises: Promise<void>[] = [];\n for (const primitive of makeMeshPrimitiveIterator(scenegraph)) {\n if (scenegraph.getObjectExtension(primitive, KHR_DRACO_MESH_COMPRESSION)) {\n promises.push(decompressPrimitive(scenegraph, primitive, options, context));\n }\n }\n\n // Decompress meshes in parallel\n await Promise.all(promises);\n\n // We have now decompressed all primitives, so remove the top-level extensions\n scenegraph.removeExtension(KHR_DRACO_MESH_COMPRESSION);\n}\n\nexport function encode(gltfData, options: GLTFLoaderOptions = {}): void {\n const scenegraph = new Scenegraph(gltfData);\n\n for (const mesh of scenegraph.json.meshes || []) {\n // eslint-disable-next-line camelcase\n // @ts-ignore\n compressMesh(mesh, options);\n // NOTE: Only add the extension if something was actually compressed\n scenegraph.addRequiredExtension(KHR_DRACO_MESH_COMPRESSION);\n }\n}\n\n// DECODE\n\n// Unpacks one mesh primitive and removes the extension from the primitive\n// DracoDecoder needs to be imported and registered by app\n// Returns: Promise that resolves when all pending draco decoder jobs for this mesh complete\n\n// TODO - Implement fallback behavior per KHR_DRACO_MESH_COMPRESSION spec\n\nasync function decompressPrimitive(\n scenegraph: Scenegraph,\n primitive: GLTFMeshPrimitive,\n options: GLTFLoaderOptions,\n context: LoaderContext\n): Promise<void> {\n const dracoExtension = scenegraph.getObjectExtension<GLTF_KHR_draco_mesh_compression>(\n primitive,\n KHR_DRACO_MESH_COMPRESSION\n );\n if (!dracoExtension) {\n return;\n }\n\n const buffer = scenegraph.getTypedArrayForBufferView(dracoExtension.bufferView);\n // TODO - parse does not yet deal well with byte offsets embedded in typed arrays. Copy buffer\n // TODO - remove when `parse` is fixed to handle `byteOffset`s\n const bufferCopy = sliceArrayBuffer(buffer.buffer, buffer.byteOffset); // , buffer.byteLength);\n\n const {parse} = context;\n const dracoOptions: DracoLoaderOptions = {...options};\n\n // TODO - remove hack: The entire tileset might be included, too expensive to serialize\n delete dracoOptions['3d-tiles'];\n const decodedData = (await parse(bufferCopy, DracoLoader, dracoOptions, context)) as DracoMesh;\n\n const decodedAttributes: {[key: string]: GLTFAccessor} = getGLTFAccessors(decodedData.attributes);\n\n // Restore min/max values\n for (const [attributeName, decodedAttribute] of Object.entries(decodedAttributes)) {\n if (attributeName in primitive.attributes) {\n const accessorIndex: number = primitive.attributes[attributeName];\n const accessor = scenegraph.getAccessor(accessorIndex);\n if (accessor?.min && accessor?.max) {\n decodedAttribute.min = accessor.min;\n decodedAttribute.max = accessor.max;\n }\n }\n }\n\n // @ts-ignore\n primitive.attributes = decodedAttributes;\n if (decodedData.indices) {\n // @ts-ignore\n primitive.indices = getGLTFAccessor(decodedData.indices);\n }\n\n // Extension has been processed, delete it\n // delete primitive.extensions[KHR_DRACO_MESH_COMPRESSION];\n\n checkPrimitive(primitive);\n}\n\n// ENCODE\n\n// eslint-disable-next-line max-len\n// Only TRIANGLES: 0x0004 and TRIANGLE_STRIP: 0x0005 are supported\nfunction compressMesh(attributes, indices, mode: number = 4, options, context: LoaderContext) {\n if (!options.DracoWriter) {\n throw new Error('options.gltf.DracoWriter not provided');\n }\n\n // TODO - use DracoWriter using encode w/ registered DracoWriter...\n const compressedData = options.DracoWriter.encodeSync({attributes});\n\n // Draco compression may change the order and number of vertices in a mesh.\n // To satisfy the requirement that accessors properties be correct for both\n // compressed and uncompressed data, generators should create uncompressed\n // attributes and indices using data that has been decompressed from the Draco buffer,\n // rather than the original source data.\n // @ts-ignore TODO this needs to be fixed\n const decodedData = context?.parseSync?.({attributes});\n const fauxAccessors = options._addFauxAttributes(decodedData.attributes);\n\n const bufferViewIndex = options.addBufferView(compressedData);\n\n const glTFMesh = {\n primitives: [\n {\n attributes: fauxAccessors, // TODO - verify with spec\n mode, // GL.POINTS\n extensions: {\n [KHR_DRACO_MESH_COMPRESSION]: {\n bufferView: bufferViewIndex,\n attributes: fauxAccessors // TODO - verify with spec\n }\n }\n }\n ]\n };\n\n return glTFMesh;\n}\n\n// UTILS\n\nfunction checkPrimitive(primitive: GLTFMeshPrimitive) {\n if (!primitive.attributes && Object.keys(primitive.attributes).length > 0) {\n throw new Error('glTF: Empty primitive detected: Draco decompression failure?');\n }\n}\n\nfunction* makeMeshPrimitiveIterator(scenegraph) {\n for (const mesh of scenegraph.json.meshes || []) {\n for (const primitive of mesh.primitives) {\n yield primitive;\n }\n }\n}\n"],"file":"KHR_draco_mesh_compression.js"}
|
|
1
|
+
{"version":3,"file":"KHR_draco_mesh_compression.js","names":["makeMeshPrimitiveIterator","KHR_DRACO_MESH_COMPRESSION","name","preprocess","gltfData","options","context","scenegraph","Scenegraph","primitive","getObjectExtension","decode","gltf","decompressMeshes","promises","push","decompressPrimitive","Promise","all","removeExtension","encode","json","meshes","mesh","compressMesh","addRequiredExtension","dracoExtension","buffer","getTypedArrayForBufferView","bufferView","bufferCopy","sliceArrayBuffer","byteOffset","parse","dracoOptions","DracoLoader","decodedData","decodedAttributes","getGLTFAccessors","attributes","Object","entries","attributeName","decodedAttribute","accessorIndex","accessor","getAccessor","min","max","indices","getGLTFAccessor","checkPrimitive","mode","DracoWriter","Error","compressedData","encodeSync","parseSync","fauxAccessors","_addFauxAttributes","bufferViewIndex","addBufferView","glTFMesh","primitives","extensions","keys","length"],"sources":["../../../../src/lib/extensions/KHR_draco_mesh_compression.ts"],"sourcesContent":["// https://github.com/KhronosGroup/glTF/tree/master/extensions/2.0/Khronos/KHR_draco_mesh_compression\n// Only TRIANGLES: 0x0004 and TRIANGLE_STRIP: 0x0005 are supported\n/* eslint-disable camelcase */\n\n/* eslint-disable camelcase */\nimport type {\n GLTF,\n GLTFAccessor,\n GLTFMeshPrimitive,\n GLTF_KHR_draco_mesh_compression\n} from '../types/gltf-types';\nimport type {GLTFLoaderOptions} from '../../gltf-loader';\n\nimport type {LoaderContext} from '@loaders.gl/loader-utils';\nimport {DracoLoader} from '@loaders.gl/draco';\nimport {DracoLoaderOptions, DracoMesh} from '@loaders.gl/draco';\nimport {sliceArrayBuffer} from '@loaders.gl/loader-utils';\nimport {default as Scenegraph} from '../api/gltf-scenegraph';\nimport {getGLTFAccessors, getGLTFAccessor} from '../gltf-utils/gltf-attribute-utils';\n\nconst KHR_DRACO_MESH_COMPRESSION = 'KHR_draco_mesh_compression';\n\n/** Extension name */\nexport const name = KHR_DRACO_MESH_COMPRESSION;\n\nexport function preprocess(\n gltfData: {json: GLTF},\n options: GLTFLoaderOptions,\n context: LoaderContext\n): void {\n const scenegraph = new Scenegraph(gltfData);\n for (const primitive of makeMeshPrimitiveIterator(scenegraph)) {\n if (scenegraph.getObjectExtension(primitive, KHR_DRACO_MESH_COMPRESSION)) {\n // TODO - Remove fallback accessors to make sure we don't load unnecessary buffers\n }\n }\n}\n\nexport async function decode(\n gltfData: {json: GLTF},\n options: GLTFLoaderOptions,\n context: LoaderContext\n): Promise<void> {\n if (!options?.gltf?.decompressMeshes) {\n return;\n }\n\n const scenegraph = new Scenegraph(gltfData);\n const promises: Promise<void>[] = [];\n for (const primitive of makeMeshPrimitiveIterator(scenegraph)) {\n if (scenegraph.getObjectExtension(primitive, KHR_DRACO_MESH_COMPRESSION)) {\n promises.push(decompressPrimitive(scenegraph, primitive, options, context));\n }\n }\n\n // Decompress meshes in parallel\n await Promise.all(promises);\n\n // We have now decompressed all primitives, so remove the top-level extensions\n scenegraph.removeExtension(KHR_DRACO_MESH_COMPRESSION);\n}\n\nexport function encode(gltfData, options: GLTFLoaderOptions = {}): void {\n const scenegraph = new Scenegraph(gltfData);\n\n for (const mesh of scenegraph.json.meshes || []) {\n // eslint-disable-next-line camelcase\n // @ts-ignore\n compressMesh(mesh, options);\n // NOTE: Only add the extension if something was actually compressed\n scenegraph.addRequiredExtension(KHR_DRACO_MESH_COMPRESSION);\n }\n}\n\n// DECODE\n\n// Unpacks one mesh primitive and removes the extension from the primitive\n// DracoDecoder needs to be imported and registered by app\n// Returns: Promise that resolves when all pending draco decoder jobs for this mesh complete\n\n// TODO - Implement fallback behavior per KHR_DRACO_MESH_COMPRESSION spec\n\nasync function decompressPrimitive(\n scenegraph: Scenegraph,\n primitive: GLTFMeshPrimitive,\n options: GLTFLoaderOptions,\n context: LoaderContext\n): Promise<void> {\n const dracoExtension = scenegraph.getObjectExtension<GLTF_KHR_draco_mesh_compression>(\n primitive,\n KHR_DRACO_MESH_COMPRESSION\n );\n if (!dracoExtension) {\n return;\n }\n\n const buffer = scenegraph.getTypedArrayForBufferView(dracoExtension.bufferView);\n // TODO - parse does not yet deal well with byte offsets embedded in typed arrays. Copy buffer\n // TODO - remove when `parse` is fixed to handle `byteOffset`s\n const bufferCopy = sliceArrayBuffer(buffer.buffer, buffer.byteOffset); // , buffer.byteLength);\n\n const {parse} = context;\n const dracoOptions: DracoLoaderOptions = {...options};\n\n // TODO - remove hack: The entire tileset might be included, too expensive to serialize\n delete dracoOptions['3d-tiles'];\n const decodedData = (await parse(bufferCopy, DracoLoader, dracoOptions, context)) as DracoMesh;\n\n const decodedAttributes: {[key: string]: GLTFAccessor} = getGLTFAccessors(decodedData.attributes);\n\n // Restore min/max values\n for (const [attributeName, decodedAttribute] of Object.entries(decodedAttributes)) {\n if (attributeName in primitive.attributes) {\n const accessorIndex: number = primitive.attributes[attributeName];\n const accessor = scenegraph.getAccessor(accessorIndex);\n if (accessor?.min && accessor?.max) {\n decodedAttribute.min = accessor.min;\n decodedAttribute.max = accessor.max;\n }\n }\n }\n\n // @ts-ignore\n primitive.attributes = decodedAttributes;\n if (decodedData.indices) {\n // @ts-ignore\n primitive.indices = getGLTFAccessor(decodedData.indices);\n }\n\n // Extension has been processed, delete it\n // delete primitive.extensions[KHR_DRACO_MESH_COMPRESSION];\n\n checkPrimitive(primitive);\n}\n\n// ENCODE\n\n// eslint-disable-next-line max-len\n// Only TRIANGLES: 0x0004 and TRIANGLE_STRIP: 0x0005 are supported\nfunction compressMesh(attributes, indices, mode: number = 4, options, context: LoaderContext) {\n if (!options.DracoWriter) {\n throw new Error('options.gltf.DracoWriter not provided');\n }\n\n // TODO - use DracoWriter using encode w/ registered DracoWriter...\n const compressedData = options.DracoWriter.encodeSync({attributes});\n\n // Draco compression may change the order and number of vertices in a mesh.\n // To satisfy the requirement that accessors properties be correct for both\n // compressed and uncompressed data, generators should create uncompressed\n // attributes and indices using data that has been decompressed from the Draco buffer,\n // rather than the original source data.\n // @ts-ignore TODO this needs to be fixed\n const decodedData = context?.parseSync?.({attributes});\n const fauxAccessors = options._addFauxAttributes(decodedData.attributes);\n\n const bufferViewIndex = options.addBufferView(compressedData);\n\n const glTFMesh = {\n primitives: [\n {\n attributes: fauxAccessors, // TODO - verify with spec\n mode, // GL.POINTS\n extensions: {\n [KHR_DRACO_MESH_COMPRESSION]: {\n bufferView: bufferViewIndex,\n attributes: fauxAccessors // TODO - verify with spec\n }\n }\n }\n ]\n };\n\n return glTFMesh;\n}\n\n// UTILS\n\nfunction checkPrimitive(primitive: GLTFMeshPrimitive) {\n if (!primitive.attributes && Object.keys(primitive.attributes).length > 0) {\n throw new Error('glTF: Empty primitive detected: Draco decompression failure?');\n }\n}\n\nfunction* makeMeshPrimitiveIterator(scenegraph) {\n for (const mesh of scenegraph.json.meshes || []) {\n for (const primitive of mesh.primitives) {\n yield primitive;\n }\n }\n}\n"],"mappings":"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"}
|
|
@@ -1,49 +1,40 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
3
|
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
-
|
|
5
4
|
Object.defineProperty(exports, "__esModule", {
|
|
6
5
|
value: true
|
|
7
6
|
});
|
|
8
|
-
exports.preprocess = preprocess;
|
|
9
7
|
exports.name = void 0;
|
|
10
|
-
|
|
8
|
+
exports.preprocess = preprocess;
|
|
11
9
|
var _gltfScenegraph = _interopRequireDefault(require("../api/gltf-scenegraph"));
|
|
12
|
-
|
|
13
10
|
function _createForOfIteratorHelper(o, allowArrayLike) { var it = typeof Symbol !== "undefined" && o[Symbol.iterator] || o["@@iterator"]; if (!it) { if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === "number") { if (it) o = it; var i = 0; var F = function F() {}; return { s: F, n: function n() { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }, e: function e(_e) { throw _e; }, f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var normalCompletion = true, didErr = false, err; return { s: function s() { it = it.call(o); }, n: function n() { var step = it.next(); normalCompletion = step.done; return step; }, e: function e(_e2) { didErr = true; err = _e2; }, f: function f() { try { if (!normalCompletion && it.return != null) it.return(); } finally { if (didErr) throw err; } } }; }
|
|
14
|
-
|
|
15
11
|
function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
|
|
16
|
-
|
|
17
12
|
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; }
|
|
18
|
-
|
|
19
13
|
var KHR_TEXTURE_BASISU = 'KHR_texture_basisu';
|
|
14
|
+
|
|
20
15
|
var name = KHR_TEXTURE_BASISU;
|
|
21
|
-
exports.name = name;
|
|
22
16
|
|
|
17
|
+
exports.name = name;
|
|
23
18
|
function preprocess(gltfData, options) {
|
|
24
19
|
var scene = new _gltfScenegraph.default(gltfData);
|
|
25
20
|
var json = scene.json;
|
|
26
|
-
|
|
27
21
|
var _iterator = _createForOfIteratorHelper(json.textures || []),
|
|
28
|
-
|
|
29
|
-
|
|
22
|
+
_step;
|
|
30
23
|
try {
|
|
31
24
|
for (_iterator.s(); !(_step = _iterator.n()).done;) {
|
|
32
25
|
var texture = _step.value;
|
|
33
26
|
var extension = scene.getObjectExtension(texture, KHR_TEXTURE_BASISU);
|
|
34
|
-
|
|
35
27
|
if (extension) {
|
|
36
28
|
texture.source = extension.source;
|
|
37
29
|
}
|
|
38
|
-
|
|
39
30
|
scene.removeObjectExtension(texture, KHR_TEXTURE_BASISU);
|
|
40
31
|
}
|
|
32
|
+
|
|
41
33
|
} catch (err) {
|
|
42
34
|
_iterator.e(err);
|
|
43
35
|
} finally {
|
|
44
36
|
_iterator.f();
|
|
45
37
|
}
|
|
46
|
-
|
|
47
38
|
scene.removeExtension(KHR_TEXTURE_BASISU);
|
|
48
39
|
}
|
|
49
40
|
//# sourceMappingURL=KHR_texture_basisu.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"
|
|
1
|
+
{"version":3,"file":"KHR_texture_basisu.js","names":["KHR_TEXTURE_BASISU","name","preprocess","gltfData","options","scene","GLTFScenegraph","json","textures","texture","extension","getObjectExtension","source","removeObjectExtension","removeExtension"],"sources":["../../../../src/lib/extensions/KHR_texture_basisu.ts"],"sourcesContent":["// GLTF EXTENSION: KHR_texture_basisu\n// https://github.com/KhronosGroup/glTF/tree/main/extensions/2.0/Khronos/KHR_texture_basisu\n/* eslint-disable camelcase */\n\nimport type {GLTF, GLTF_KHR_texture_basisu} from '../types/gltf-types';\nimport type {GLTFLoaderOptions} from '../../gltf-loader';\n\nimport GLTFScenegraph from '../api/gltf-scenegraph';\n\nconst KHR_TEXTURE_BASISU = 'KHR_texture_basisu';\n\n/** Extension name */\nexport const name = KHR_TEXTURE_BASISU;\n\n/**\n * Replaces a texture source reference with the extension texture\n * Done in preprocess() to prevent load of default image\n */\nexport function preprocess(gltfData: {json: GLTF}, options: GLTFLoaderOptions): void {\n const scene = new GLTFScenegraph(gltfData);\n const {json} = scene;\n\n for (const texture of json.textures || []) {\n const extension = scene.getObjectExtension<GLTF_KHR_texture_basisu>(\n texture,\n KHR_TEXTURE_BASISU\n );\n if (extension) {\n texture.source = extension.source;\n }\n scene.removeObjectExtension(texture, KHR_TEXTURE_BASISU);\n }\n\n // Remove the top-level extension\n scene.removeExtension(KHR_TEXTURE_BASISU);\n}\n"],"mappings":";;;;;;;;AAOA;AAAoD;AAAA;AAAA;AAEpD,IAAMA,kBAAkB,GAAG,oBAAoB;;AAGxC,IAAMC,IAAI,GAAGD,kBAAkB;;AAAC;AAMhC,SAASE,UAAU,CAACC,QAAsB,EAAEC,OAA0B,EAAQ;EACnF,IAAMC,KAAK,GAAG,IAAIC,uBAAc,CAACH,QAAQ,CAAC;EAC1C,IAAOI,IAAI,GAAIF,KAAK,CAAbE,IAAI;EAAU,2CAECA,IAAI,CAACC,QAAQ,IAAI,EAAE;IAAA;EAAA;IAAzC,oDAA2C;MAAA,IAAhCC,OAAO;MAChB,IAAMC,SAAS,GAAGL,KAAK,CAACM,kBAAkB,CACxCF,OAAO,EACPT,kBAAkB,CACnB;MACD,IAAIU,SAAS,EAAE;QACbD,OAAO,CAACG,MAAM,GAAGF,SAAS,CAACE,MAAM;MACnC;MACAP,KAAK,CAACQ,qBAAqB,CAACJ,OAAO,EAAET,kBAAkB,CAAC;IAC1D;;EAAC;IAAA;EAAA;IAAA;EAAA;EAGDK,KAAK,CAACS,eAAe,CAACd,kBAAkB,CAAC;AAC3C"}
|
|
@@ -1,33 +1,21 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
3
|
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
-
|
|
5
4
|
Object.defineProperty(exports, "__esModule", {
|
|
6
5
|
value: true
|
|
7
6
|
});
|
|
8
7
|
exports.decode = decode;
|
|
9
8
|
exports.name = void 0;
|
|
10
|
-
|
|
11
9
|
var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
|
|
12
|
-
|
|
13
10
|
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
|
|
14
|
-
|
|
15
11
|
var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
|
|
16
|
-
|
|
17
12
|
var _core = require("@math.gl/core");
|
|
18
|
-
|
|
19
13
|
var _gltfUtils = require("../gltf-utils/gltf-utils");
|
|
20
|
-
|
|
21
14
|
var _gltfConstants = require("../gltf-utils/gltf-constants");
|
|
22
|
-
|
|
23
15
|
var _gltfScenegraph = _interopRequireDefault(require("../api/gltf-scenegraph"));
|
|
24
|
-
|
|
25
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; } } }; }
|
|
26
|
-
|
|
27
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); }
|
|
28
|
-
|
|
29
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; }
|
|
30
|
-
|
|
31
19
|
var EXT_MESHOPT_TRANSFORM = 'KHR_texture_transform';
|
|
32
20
|
var name = EXT_MESHOPT_TRANSFORM;
|
|
33
21
|
exports.name = name;
|
|
@@ -38,7 +26,6 @@ var scratchScaleMatrix = new _core.Matrix3();
|
|
|
38
26
|
function decode(_x, _x2) {
|
|
39
27
|
return _decode.apply(this, arguments);
|
|
40
28
|
}
|
|
41
|
-
|
|
42
29
|
function _decode() {
|
|
43
30
|
_decode = (0, _asyncToGenerator2.default)(_regenerator.default.mark(function _callee(gltfData, options) {
|
|
44
31
|
var gltfScenegraph, extension, materials, i;
|
|
@@ -48,21 +35,16 @@ function _decode() {
|
|
|
48
35
|
case 0:
|
|
49
36
|
gltfScenegraph = new _gltfScenegraph.default(gltfData);
|
|
50
37
|
extension = gltfScenegraph.getExtension(EXT_MESHOPT_TRANSFORM);
|
|
51
|
-
|
|
52
38
|
if (extension) {
|
|
53
39
|
_context.next = 4;
|
|
54
40
|
break;
|
|
55
41
|
}
|
|
56
|
-
|
|
57
42
|
return _context.abrupt("return");
|
|
58
|
-
|
|
59
43
|
case 4:
|
|
60
44
|
materials = gltfData.json.materials || [];
|
|
61
|
-
|
|
62
45
|
for (i = 0; i < materials.length; i++) {
|
|
63
46
|
transformTexCoords(i, gltfData);
|
|
64
47
|
}
|
|
65
|
-
|
|
66
48
|
case 6:
|
|
67
49
|
case "end":
|
|
68
50
|
return _context.stop();
|
|
@@ -72,38 +54,27 @@ function _decode() {
|
|
|
72
54
|
}));
|
|
73
55
|
return _decode.apply(this, arguments);
|
|
74
56
|
}
|
|
75
|
-
|
|
76
57
|
function transformTexCoords(materialIndex, gltfData) {
|
|
77
58
|
var _gltfData$json$materi, _material$pbrMetallic, _material$pbrMetallic2;
|
|
78
|
-
|
|
79
59
|
var processedTexCoords = [];
|
|
80
60
|
var material = (_gltfData$json$materi = gltfData.json.materials) === null || _gltfData$json$materi === void 0 ? void 0 : _gltfData$json$materi[materialIndex];
|
|
81
61
|
var baseColorTexture = material === null || material === void 0 ? void 0 : (_material$pbrMetallic = material.pbrMetallicRoughness) === null || _material$pbrMetallic === void 0 ? void 0 : _material$pbrMetallic.baseColorTexture;
|
|
82
|
-
|
|
83
62
|
if (baseColorTexture) {
|
|
84
63
|
transformPrimitives(gltfData, materialIndex, baseColorTexture, processedTexCoords);
|
|
85
64
|
}
|
|
86
|
-
|
|
87
65
|
var emisiveTexture = material === null || material === void 0 ? void 0 : material.emissiveTexture;
|
|
88
|
-
|
|
89
66
|
if (emisiveTexture) {
|
|
90
67
|
transformPrimitives(gltfData, materialIndex, emisiveTexture, processedTexCoords);
|
|
91
68
|
}
|
|
92
|
-
|
|
93
69
|
var normalTexture = material === null || material === void 0 ? void 0 : material.normalTexture;
|
|
94
|
-
|
|
95
70
|
if (normalTexture) {
|
|
96
71
|
transformPrimitives(gltfData, materialIndex, normalTexture, processedTexCoords);
|
|
97
72
|
}
|
|
98
|
-
|
|
99
73
|
var occlusionTexture = material === null || material === void 0 ? void 0 : material.occlusionTexture;
|
|
100
|
-
|
|
101
74
|
if (occlusionTexture) {
|
|
102
75
|
transformPrimitives(gltfData, materialIndex, occlusionTexture, processedTexCoords);
|
|
103
76
|
}
|
|
104
|
-
|
|
105
77
|
var metallicRoughnessTexture = material === null || material === void 0 ? void 0 : (_material$pbrMetallic2 = material.pbrMetallicRoughness) === null || _material$pbrMetallic2 === void 0 ? void 0 : _material$pbrMetallic2.metallicRoughnessTexture;
|
|
106
|
-
|
|
107
78
|
if (metallicRoughnessTexture) {
|
|
108
79
|
transformPrimitives(gltfData, materialIndex, metallicRoughnessTexture, processedTexCoords);
|
|
109
80
|
}
|
|
@@ -111,28 +82,21 @@ function transformTexCoords(materialIndex, gltfData) {
|
|
|
111
82
|
|
|
112
83
|
function transformPrimitives(gltfData, materialIndex, texture, processedTexCoords) {
|
|
113
84
|
var transformParameters = getTransformParameters(texture, processedTexCoords);
|
|
114
|
-
|
|
115
85
|
if (!transformParameters) {
|
|
116
86
|
return;
|
|
117
87
|
}
|
|
118
|
-
|
|
119
88
|
var meshes = gltfData.json.meshes || [];
|
|
120
|
-
|
|
121
89
|
var _iterator = _createForOfIteratorHelper(meshes),
|
|
122
|
-
|
|
123
|
-
|
|
90
|
+
_step;
|
|
124
91
|
try {
|
|
125
92
|
for (_iterator.s(); !(_step = _iterator.n()).done;) {
|
|
126
93
|
var mesh = _step.value;
|
|
127
|
-
|
|
128
94
|
var _iterator2 = _createForOfIteratorHelper(mesh.primitives),
|
|
129
|
-
|
|
130
|
-
|
|
95
|
+
_step2;
|
|
131
96
|
try {
|
|
132
97
|
for (_iterator2.s(); !(_step2 = _iterator2.n()).done;) {
|
|
133
98
|
var primitive = _step2.value;
|
|
134
99
|
var material = primitive.material;
|
|
135
|
-
|
|
136
100
|
if (Number.isFinite(material) && materialIndex === material) {
|
|
137
101
|
transformPrimitive(gltfData, primitive, transformParameters);
|
|
138
102
|
}
|
|
@@ -152,27 +116,22 @@ function transformPrimitives(gltfData, materialIndex, texture, processedTexCoord
|
|
|
152
116
|
|
|
153
117
|
function getTransformParameters(texture, processedTexCoords) {
|
|
154
118
|
var _texture$extensions;
|
|
155
|
-
|
|
156
119
|
var textureInfo = (_texture$extensions = texture.extensions) === null || _texture$extensions === void 0 ? void 0 : _texture$extensions[EXT_MESHOPT_TRANSFORM];
|
|
157
120
|
var _texture$texCoord = texture.texCoord,
|
|
158
|
-
|
|
121
|
+
originalTexCoord = _texture$texCoord === void 0 ? 0 : _texture$texCoord;
|
|
159
122
|
var _textureInfo$texCoord = textureInfo.texCoord,
|
|
160
|
-
|
|
123
|
+
texCoord = _textureInfo$texCoord === void 0 ? originalTexCoord : _textureInfo$texCoord;
|
|
161
124
|
var isProcessed = processedTexCoords.findIndex(function (_ref) {
|
|
162
125
|
var _ref2 = (0, _slicedToArray2.default)(_ref, 2),
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
126
|
+
original = _ref2[0],
|
|
127
|
+
newTexCoord = _ref2[1];
|
|
166
128
|
return original === originalTexCoord && newTexCoord === texCoord;
|
|
167
129
|
}) !== -1;
|
|
168
|
-
|
|
169
130
|
if (!isProcessed) {
|
|
170
131
|
var matrix = makeTransformationMatrix(textureInfo);
|
|
171
|
-
|
|
172
132
|
if (originalTexCoord !== texCoord) {
|
|
173
133
|
texture.texCoord = texCoord;
|
|
174
134
|
}
|
|
175
|
-
|
|
176
135
|
processedTexCoords.push([originalTexCoord, texCoord]);
|
|
177
136
|
return {
|
|
178
137
|
originalTexCoord: originalTexCoord,
|
|
@@ -180,48 +139,38 @@ function getTransformParameters(texture, processedTexCoords) {
|
|
|
180
139
|
matrix: matrix
|
|
181
140
|
};
|
|
182
141
|
}
|
|
183
|
-
|
|
184
142
|
return null;
|
|
185
143
|
}
|
|
186
144
|
|
|
187
145
|
function transformPrimitive(gltfData, primitive, transformParameters) {
|
|
188
146
|
var originalTexCoord = transformParameters.originalTexCoord,
|
|
189
|
-
|
|
190
|
-
|
|
147
|
+
texCoord = transformParameters.texCoord,
|
|
148
|
+
matrix = transformParameters.matrix;
|
|
191
149
|
var texCoordAccessor = primitive.attributes["TEXCOORD_".concat(originalTexCoord)];
|
|
192
|
-
|
|
193
150
|
if (Number.isFinite(texCoordAccessor)) {
|
|
194
151
|
var _gltfData$json$access;
|
|
195
|
-
|
|
196
152
|
var accessor = (_gltfData$json$access = gltfData.json.accessors) === null || _gltfData$json$access === void 0 ? void 0 : _gltfData$json$access[texCoordAccessor];
|
|
197
|
-
|
|
198
153
|
if (accessor && accessor.bufferView) {
|
|
199
154
|
var _gltfData$json$buffer;
|
|
200
|
-
|
|
201
155
|
var bufferView = (_gltfData$json$buffer = gltfData.json.bufferViews) === null || _gltfData$json$buffer === void 0 ? void 0 : _gltfData$json$buffer[accessor.bufferView];
|
|
202
|
-
|
|
203
156
|
if (bufferView) {
|
|
204
157
|
var _gltfData$buffers$buf = gltfData.buffers[bufferView.buffer],
|
|
205
|
-
|
|
206
|
-
|
|
158
|
+
arrayBuffer = _gltfData$buffers$buf.arrayBuffer,
|
|
159
|
+
bufferByteOffset = _gltfData$buffers$buf.byteOffset;
|
|
207
160
|
var byteOffset = (bufferByteOffset || 0) + (accessor.byteOffset || 0) + (bufferView.byteOffset || 0);
|
|
208
|
-
|
|
209
161
|
var _getAccessorArrayType = (0, _gltfUtils.getAccessorArrayTypeAndLength)(accessor, bufferView),
|
|
210
|
-
|
|
211
|
-
|
|
212
|
-
|
|
162
|
+
ArrayType = _getAccessorArrayType.ArrayType,
|
|
163
|
+
length = _getAccessorArrayType.length;
|
|
213
164
|
var bytes = _gltfConstants.BYTES[accessor.componentType];
|
|
214
165
|
var components = _gltfConstants.COMPONENTS[accessor.type];
|
|
215
166
|
var elementAddressScale = bufferView.byteStride || bytes * components;
|
|
216
167
|
var result = new Float32Array(length);
|
|
217
|
-
|
|
218
168
|
for (var i = 0; i < accessor.count; i++) {
|
|
219
169
|
var uv = new ArrayType(arrayBuffer, byteOffset + i * elementAddressScale, 2);
|
|
220
170
|
scratchVector.set(uv[0], uv[1], 1);
|
|
221
171
|
scratchVector.transformByMatrix3(matrix);
|
|
222
172
|
result.set([scratchVector[0], scratchVector[1]], i * components);
|
|
223
173
|
}
|
|
224
|
-
|
|
225
174
|
if (originalTexCoord === texCoord) {
|
|
226
175
|
updateGltf(accessor, bufferView, gltfData.buffers, result);
|
|
227
176
|
} else {
|
|
@@ -252,22 +201,18 @@ function createAttribute(newTexCoord, originalAccessor, primitive, gltfData, new
|
|
|
252
201
|
byteLength: newTexCoordArray.buffer.byteLength
|
|
253
202
|
});
|
|
254
203
|
var bufferViews = gltfData.json.bufferViews;
|
|
255
|
-
|
|
256
204
|
if (!bufferViews) {
|
|
257
205
|
return;
|
|
258
206
|
}
|
|
259
|
-
|
|
260
207
|
bufferViews.push({
|
|
261
208
|
buffer: gltfData.buffers.length - 1,
|
|
262
209
|
byteLength: newTexCoordArray.buffer.byteLength,
|
|
263
210
|
byteOffset: 0
|
|
264
211
|
});
|
|
265
212
|
var accessors = gltfData.json.accessors;
|
|
266
|
-
|
|
267
213
|
if (!accessors) {
|
|
268
214
|
return;
|
|
269
215
|
}
|
|
270
|
-
|
|
271
216
|
accessors.push({
|
|
272
217
|
bufferView: (bufferViews === null || bufferViews === void 0 ? void 0 : bufferViews.length) - 1,
|
|
273
218
|
byteOffset: 0,
|
|
@@ -280,11 +225,11 @@ function createAttribute(newTexCoord, originalAccessor, primitive, gltfData, new
|
|
|
280
225
|
|
|
281
226
|
function makeTransformationMatrix(extensionData) {
|
|
282
227
|
var _extensionData$offset = extensionData.offset,
|
|
283
|
-
|
|
284
|
-
|
|
285
|
-
|
|
286
|
-
|
|
287
|
-
|
|
228
|
+
offset = _extensionData$offset === void 0 ? [0, 0] : _extensionData$offset,
|
|
229
|
+
_extensionData$rotati = extensionData.rotation,
|
|
230
|
+
rotation = _extensionData$rotati === void 0 ? 0 : _extensionData$rotati,
|
|
231
|
+
_extensionData$scale = extensionData.scale,
|
|
232
|
+
scale = _extensionData$scale === void 0 ? [1, 1] : _extensionData$scale;
|
|
288
233
|
var translationMatirx = new _core.Matrix3().set(1, 0, 0, 0, 1, 0, offset[0], offset[1], 1);
|
|
289
234
|
var rotationMatirx = scratchRotationMatrix.set(Math.cos(rotation), Math.sin(rotation), 0, -Math.sin(rotation), Math.cos(rotation), 0, 0, 0, 1);
|
|
290
235
|
var scaleMatrix = scratchScaleMatrix.set(scale[0], 0, 0, 0, scale[1], 0, 0, 0, 1);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../../src/lib/extensions/KHR_texture_transform.ts"],"names":["EXT_MESHOPT_TRANSFORM","name","scratchVector","Vector3","scratchRotationMatrix","Matrix3","scratchScaleMatrix","decode","gltfData","options","gltfScenegraph","GLTFScenegraph","extension","getExtension","materials","json","i","length","transformTexCoords","materialIndex","processedTexCoords","material","baseColorTexture","pbrMetallicRoughness","transformPrimitives","emisiveTexture","emissiveTexture","normalTexture","occlusionTexture","metallicRoughnessTexture","texture","transformParameters","getTransformParameters","meshes","mesh","primitives","primitive","Number","isFinite","transformPrimitive","textureInfo","extensions","texCoord","originalTexCoord","isProcessed","findIndex","original","newTexCoord","matrix","makeTransformationMatrix","push","texCoordAccessor","attributes","accessor","accessors","bufferView","bufferViews","buffers","buffer","arrayBuffer","bufferByteOffset","byteOffset","ArrayType","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"],"mappings":"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","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"],"file":"KHR_texture_transform.js"}
|
|
1
|
+
{"version":3,"file":"KHR_texture_transform.js","names":["EXT_MESHOPT_TRANSFORM","name","scratchVector","Vector3","scratchRotationMatrix","Matrix3","scratchScaleMatrix","decode","gltfData","options","gltfScenegraph","GLTFScenegraph","extension","getExtension","materials","json","i","length","transformTexCoords","materialIndex","processedTexCoords","material","baseColorTexture","pbrMetallicRoughness","transformPrimitives","emisiveTexture","emissiveTexture","normalTexture","occlusionTexture","metallicRoughnessTexture","texture","transformParameters","getTransformParameters","meshes","mesh","primitives","primitive","Number","isFinite","transformPrimitive","textureInfo","extensions","texCoord","originalTexCoord","isProcessed","findIndex","original","newTexCoord","matrix","makeTransformationMatrix","push","texCoordAccessor","attributes","accessor","accessors","bufferView","bufferViews","buffers","buffer","arrayBuffer","bufferByteOffset","byteOffset","getAccessorArrayTypeAndLength","ArrayType","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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"}
|
|
@@ -1,27 +1,21 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
3
|
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
-
|
|
5
4
|
Object.defineProperty(exports, "__esModule", {
|
|
6
5
|
value: true
|
|
7
6
|
});
|
|
8
7
|
exports.decode = decode;
|
|
9
8
|
exports.name = void 0;
|
|
10
|
-
|
|
11
9
|
var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
|
|
12
|
-
|
|
13
10
|
var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
|
|
14
|
-
|
|
15
11
|
var _gltfScenegraph = _interopRequireDefault(require("../../api/gltf-scenegraph"));
|
|
16
12
|
|
|
17
13
|
var EXT_FEATURE_METADATA = 'EXT_feature_metadata';
|
|
18
14
|
var name = EXT_FEATURE_METADATA;
|
|
19
15
|
exports.name = name;
|
|
20
|
-
|
|
21
16
|
function decode(_x) {
|
|
22
17
|
return _decode.apply(this, arguments);
|
|
23
18
|
}
|
|
24
|
-
|
|
25
19
|
function _decode() {
|
|
26
20
|
_decode = (0, _asyncToGenerator2.default)(_regenerator.default.mark(function _callee(gltfData) {
|
|
27
21
|
var scenegraph;
|
|
@@ -31,7 +25,6 @@ function _decode() {
|
|
|
31
25
|
case 0:
|
|
32
26
|
scenegraph = new _gltfScenegraph.default(gltfData);
|
|
33
27
|
decodeExtFeatureMetadata(scenegraph);
|
|
34
|
-
|
|
35
28
|
case 2:
|
|
36
29
|
case "end":
|
|
37
30
|
return _context.stop();
|
|
@@ -41,24 +34,19 @@ function _decode() {
|
|
|
41
34
|
}));
|
|
42
35
|
return _decode.apply(this, arguments);
|
|
43
36
|
}
|
|
44
|
-
|
|
45
37
|
function decodeExtFeatureMetadata(scenegraph) {
|
|
46
38
|
var _extension$schema;
|
|
47
|
-
|
|
48
39
|
var extension = scenegraph.getExtension(EXT_FEATURE_METADATA);
|
|
49
40
|
var schemaClasses = extension === null || extension === void 0 ? void 0 : (_extension$schema = extension.schema) === null || _extension$schema === void 0 ? void 0 : _extension$schema.classes;
|
|
50
41
|
var featureTables = extension === null || extension === void 0 ? void 0 : extension.featureTables;
|
|
51
42
|
var featureTextures = extension === null || extension === void 0 ? void 0 : extension.featureTextures;
|
|
52
|
-
|
|
53
43
|
if (featureTextures) {
|
|
54
44
|
console.warn('featureTextures is not yet supported in the "EXT_feature_metadata" extension.');
|
|
55
45
|
}
|
|
56
|
-
|
|
57
46
|
if (schemaClasses && featureTables) {
|
|
58
47
|
for (var schemaName in schemaClasses) {
|
|
59
48
|
var schemaClass = schemaClasses[schemaName];
|
|
60
49
|
var featureTable = findFeatureTableByName(featureTables, schemaName);
|
|
61
|
-
|
|
62
50
|
if (featureTable) {
|
|
63
51
|
handleFeatureTableProperties(scenegraph, featureTable, schemaClass);
|
|
64
52
|
}
|
|
@@ -69,11 +57,9 @@ function decodeExtFeatureMetadata(scenegraph) {
|
|
|
69
57
|
function handleFeatureTableProperties(scenegraph, featureTable, schemaClass) {
|
|
70
58
|
for (var propertyName in schemaClass.properties) {
|
|
71
59
|
var _featureTable$propert;
|
|
72
|
-
|
|
73
60
|
var schemaProperty = schemaClass.properties[propertyName];
|
|
74
61
|
var featureTableProperty = featureTable === null || featureTable === void 0 ? void 0 : (_featureTable$propert = featureTable.properties) === null || _featureTable$propert === void 0 ? void 0 : _featureTable$propert[propertyName];
|
|
75
62
|
var numberOfFeatures = featureTable.count;
|
|
76
|
-
|
|
77
63
|
if (featureTableProperty) {
|
|
78
64
|
var data = getPropertyDataFromBinarySource(scenegraph, schemaProperty, numberOfFeatures, featureTableProperty);
|
|
79
65
|
featureTableProperty.data = data;
|
|
@@ -84,7 +70,6 @@ function handleFeatureTableProperties(scenegraph, featureTable, schemaClass) {
|
|
|
84
70
|
function getPropertyDataFromBinarySource(scenegraph, schemaProperty, numberOfFeatures, featureTableProperty) {
|
|
85
71
|
var bufferView = featureTableProperty.bufferView;
|
|
86
72
|
var data = scenegraph.getTypedArrayForBufferView(bufferView);
|
|
87
|
-
|
|
88
73
|
switch (schemaProperty.type) {
|
|
89
74
|
case 'STRING':
|
|
90
75
|
{
|
|
@@ -93,22 +78,18 @@ function getPropertyDataFromBinarySource(scenegraph, schemaProperty, numberOfFea
|
|
|
93
78
|
data = getStringAttributes(data, offsetsData, numberOfFeatures);
|
|
94
79
|
break;
|
|
95
80
|
}
|
|
96
|
-
|
|
97
81
|
default:
|
|
98
82
|
}
|
|
99
|
-
|
|
100
83
|
return data;
|
|
101
84
|
}
|
|
102
85
|
|
|
103
86
|
function findFeatureTableByName(featureTables, schemaClassName) {
|
|
104
87
|
for (var featureTableName in featureTables) {
|
|
105
88
|
var featureTable = featureTables[featureTableName];
|
|
106
|
-
|
|
107
89
|
if (featureTable.class === schemaClassName) {
|
|
108
90
|
return featureTable;
|
|
109
91
|
}
|
|
110
92
|
}
|
|
111
|
-
|
|
112
93
|
return null;
|
|
113
94
|
}
|
|
114
95
|
|
|
@@ -117,7 +98,6 @@ function getStringAttributes(data, offsetsData, stringsCount) {
|
|
|
117
98
|
var textDecoder = new TextDecoder('utf8');
|
|
118
99
|
var stringOffset = 0;
|
|
119
100
|
var bytesPerStringSize = 4;
|
|
120
|
-
|
|
121
101
|
for (var index = 0; index < stringsCount; index++) {
|
|
122
102
|
var stringByteSize = offsetsData[(index + 1) * bytesPerStringSize] - offsetsData[index * bytesPerStringSize];
|
|
123
103
|
var stringData = data.subarray(stringOffset, stringByteSize + stringOffset);
|
|
@@ -125,7 +105,6 @@ function getStringAttributes(data, offsetsData, stringsCount) {
|
|
|
125
105
|
stringsArray.push(stringAttribute);
|
|
126
106
|
stringOffset += stringByteSize;
|
|
127
107
|
}
|
|
128
|
-
|
|
129
108
|
return stringsArray;
|
|
130
109
|
}
|
|
131
110
|
//# sourceMappingURL=EXT_feature_metadata.js.map
|