@loaders.gl/gltf 4.0.0-alpha.4 → 4.0.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/bundle.d.ts +2 -0
- package/dist/bundle.d.ts.map +1 -0
- package/dist/bundle.js +2 -2
- package/dist/dist.min.js +5565 -0
- package/dist/es5/bundle.js +6 -0
- package/dist/es5/bundle.js.map +1 -0
- package/dist/es5/glb-loader.js +56 -0
- package/dist/es5/glb-loader.js.map +1 -0
- package/dist/es5/glb-writer.js +35 -0
- package/dist/es5/glb-writer.js.map +1 -0
- package/dist/es5/gltf-loader.js +81 -0
- package/dist/es5/gltf-loader.js.map +1 -0
- package/dist/es5/gltf-writer.js +35 -0
- package/dist/es5/gltf-writer.js.map +1 -0
- package/dist/es5/index.js +49 -0
- package/dist/es5/index.js.map +1 -0
- package/dist/es5/lib/api/gltf-extensions.js +109 -0
- package/dist/es5/lib/api/gltf-extensions.js.map +1 -0
- package/dist/es5/lib/api/gltf-scenegraph.js +578 -0
- package/dist/es5/lib/api/gltf-scenegraph.js.map +1 -0
- package/dist/es5/lib/api/normalize-gltf-v1.js +331 -0
- package/dist/es5/lib/api/normalize-gltf-v1.js.map +1 -0
- package/dist/es5/lib/api/post-process-gltf.js +422 -0
- package/dist/es5/lib/api/post-process-gltf.js.map +1 -0
- package/dist/es5/lib/encoders/encode-glb.js +61 -0
- package/dist/es5/lib/encoders/encode-glb.js.map +1 -0
- package/dist/es5/lib/encoders/encode-gltf.js +21 -0
- package/dist/es5/lib/encoders/encode-gltf.js.map +1 -0
- package/dist/es5/lib/extensions/EXT_meshopt_compression.js +96 -0
- package/dist/es5/lib/extensions/EXT_meshopt_compression.js.map +1 -0
- package/dist/es5/lib/extensions/EXT_texture_webp.js +44 -0
- package/dist/es5/lib/extensions/EXT_texture_webp.js.map +1 -0
- package/dist/es5/lib/extensions/KHR_binary_gltf.js +40 -0
- package/dist/es5/lib/extensions/KHR_binary_gltf.js.map +1 -0
- package/dist/es5/lib/extensions/KHR_draco_mesh_compression.js +246 -0
- package/dist/es5/lib/extensions/KHR_draco_mesh_compression.js.map +1 -0
- package/dist/es5/lib/extensions/KHR_texture_basisu.js +37 -0
- package/dist/es5/lib/extensions/KHR_texture_basisu.js.map +1 -0
- package/dist/es5/lib/extensions/KHR_texture_transform.js +229 -0
- package/dist/es5/lib/extensions/KHR_texture_transform.js.map +1 -0
- package/dist/es5/lib/extensions/deprecated/EXT_feature_metadata.js +103 -0
- package/dist/es5/lib/extensions/deprecated/EXT_feature_metadata.js.map +1 -0
- package/dist/es5/lib/extensions/deprecated/KHR_lights_punctual.js +99 -0
- package/dist/es5/lib/extensions/deprecated/KHR_lights_punctual.js.map +1 -0
- package/dist/es5/lib/extensions/deprecated/KHR_materials_unlit.js +76 -0
- package/dist/es5/lib/extensions/deprecated/KHR_materials_unlit.js.map +1 -0
- package/dist/es5/lib/extensions/deprecated/KHR_techniques_webgl.js +113 -0
- package/dist/es5/lib/extensions/deprecated/KHR_techniques_webgl.js.map +1 -0
- package/dist/es5/lib/gltf-utils/get-typed-array.js +23 -0
- package/dist/es5/lib/gltf-utils/get-typed-array.js.map +1 -0
- package/dist/es5/lib/gltf-utils/gltf-attribute-utils.js +68 -0
- package/dist/es5/lib/gltf-utils/gltf-attribute-utils.js.map +1 -0
- package/dist/es5/lib/gltf-utils/gltf-constants.js +48 -0
- package/dist/es5/lib/gltf-utils/gltf-constants.js.map +1 -0
- package/dist/es5/lib/gltf-utils/gltf-utils.js +62 -0
- package/dist/es5/lib/gltf-utils/gltf-utils.js.map +1 -0
- package/dist/es5/lib/gltf-utils/resolve-url.js +18 -0
- package/dist/es5/lib/gltf-utils/resolve-url.js.map +1 -0
- package/dist/es5/lib/parsers/parse-glb.js +120 -0
- package/dist/es5/lib/parsers/parse-glb.js.map +1 -0
- package/dist/es5/lib/parsers/parse-gltf.js +287 -0
- package/dist/es5/lib/parsers/parse-gltf.js.map +1 -0
- package/dist/es5/lib/types/glb-types.js +2 -0
- package/dist/es5/lib/types/glb-types.js.map +1 -0
- package/dist/es5/lib/types/gltf-json-schema.js +2 -0
- package/dist/es5/lib/types/gltf-json-schema.js.map +1 -0
- package/dist/es5/lib/types/gltf-postprocessed-schema.js +2 -0
- package/dist/es5/lib/types/gltf-postprocessed-schema.js.map +1 -0
- package/dist/es5/lib/types/gltf-types.js +2 -0
- package/dist/es5/lib/types/gltf-types.js.map +1 -0
- package/dist/es5/lib/utils/assert.js +12 -0
- package/dist/es5/lib/utils/assert.js.map +1 -0
- package/dist/es5/lib/utils/version.js +9 -0
- package/dist/es5/lib/utils/version.js.map +1 -0
- package/dist/es5/meshopt/meshopt-decoder.js +215 -0
- package/dist/es5/meshopt/meshopt-decoder.js.map +1 -0
- package/dist/es5/webp/webp.js +83 -0
- package/dist/es5/webp/webp.js.map +1 -0
- package/dist/esm/bundle.js +4 -0
- package/dist/esm/bundle.js.map +1 -0
- package/dist/esm/glb-loader.js +31 -0
- package/dist/esm/glb-loader.js.map +1 -0
- package/dist/esm/glb-writer.js +27 -0
- package/dist/esm/glb-writer.js.map +1 -0
- package/dist/esm/gltf-loader.js +51 -0
- package/dist/esm/gltf-loader.js.map +1 -0
- package/dist/esm/gltf-writer.js +28 -0
- package/dist/esm/gltf-writer.js.map +1 -0
- package/dist/esm/index.js +7 -0
- package/dist/esm/index.js.map +1 -0
- package/dist/esm/lib/api/gltf-extensions.js +35 -0
- package/dist/esm/lib/api/gltf-extensions.js.map +1 -0
- package/dist/esm/lib/api/gltf-scenegraph.js +441 -0
- package/dist/esm/lib/api/gltf-scenegraph.js.map +1 -0
- package/dist/esm/lib/api/normalize-gltf-v1.js +204 -0
- package/dist/esm/lib/api/normalize-gltf-v1.js.map +1 -0
- package/dist/esm/lib/api/post-process-gltf.js +341 -0
- package/dist/esm/lib/api/post-process-gltf.js.map +1 -0
- package/dist/esm/lib/encoders/encode-glb.js +54 -0
- package/dist/esm/lib/encoders/encode-glb.js.map +1 -0
- package/dist/esm/lib/encoders/encode-gltf.js +14 -0
- package/dist/esm/lib/encoders/encode-gltf.js.map +1 -0
- package/dist/esm/lib/extensions/EXT_meshopt_compression.js +42 -0
- package/dist/esm/lib/extensions/EXT_meshopt_compression.js.map +1 -0
- package/dist/esm/lib/extensions/EXT_texture_webp.js +25 -0
- package/dist/esm/lib/extensions/EXT_texture_webp.js.map +1 -0
- package/dist/esm/lib/extensions/KHR_binary_gltf.js +21 -0
- package/dist/esm/lib/extensions/KHR_binary_gltf.js.map +1 -0
- package/dist/esm/lib/extensions/KHR_draco_mesh_compression.js +110 -0
- package/dist/esm/lib/extensions/KHR_draco_mesh_compression.js.map +1 -0
- package/dist/esm/lib/extensions/KHR_texture_basisu.js +18 -0
- package/dist/esm/lib/extensions/KHR_texture_basisu.js.map +1 -0
- package/dist/esm/lib/extensions/KHR_texture_transform.js +181 -0
- package/dist/esm/lib/extensions/KHR_texture_transform.js.map +1 -0
- package/dist/esm/lib/extensions/deprecated/EXT_feature_metadata.js +77 -0
- package/dist/esm/lib/extensions/deprecated/EXT_feature_metadata.js.map +1 -0
- package/dist/esm/lib/extensions/deprecated/KHR_lights_punctual.js +42 -0
- package/dist/esm/lib/extensions/deprecated/KHR_lights_punctual.js.map +1 -0
- package/dist/esm/lib/extensions/deprecated/KHR_materials_unlit.js +33 -0
- package/dist/esm/lib/extensions/deprecated/KHR_materials_unlit.js.map +1 -0
- package/dist/esm/lib/extensions/deprecated/KHR_techniques_webgl.js +61 -0
- package/dist/esm/lib/extensions/deprecated/KHR_techniques_webgl.js.map +1 -0
- package/dist/esm/lib/gltf-utils/get-typed-array.js +16 -0
- package/dist/esm/lib/gltf-utils/get-typed-array.js.map +1 -0
- package/dist/esm/lib/gltf-utils/gltf-attribute-utils.js +62 -0
- package/dist/esm/lib/gltf-utils/gltf-attribute-utils.js.map +1 -0
- package/dist/esm/lib/gltf-utils/gltf-constants.js +37 -0
- package/dist/esm/lib/gltf-utils/gltf-constants.js.map +1 -0
- package/dist/esm/lib/gltf-utils/gltf-utils.js +54 -0
- package/dist/esm/lib/gltf-utils/gltf-utils.js.map +1 -0
- package/dist/esm/lib/gltf-utils/resolve-url.js +12 -0
- package/dist/esm/lib/gltf-utils/resolve-url.js.map +1 -0
- package/dist/esm/lib/parsers/parse-glb.js +114 -0
- package/dist/esm/lib/parsers/parse-glb.js.map +1 -0
- package/dist/esm/lib/parsers/parse-gltf.js +156 -0
- package/dist/esm/lib/parsers/parse-gltf.js.map +1 -0
- package/dist/esm/lib/types/glb-types.js +2 -0
- package/dist/esm/lib/types/glb-types.js.map +1 -0
- package/dist/esm/lib/types/gltf-json-schema.js +2 -0
- package/dist/esm/lib/types/gltf-json-schema.js.map +1 -0
- package/dist/esm/lib/types/gltf-postprocessed-schema.js +2 -0
- package/dist/esm/lib/types/gltf-postprocessed-schema.js.map +1 -0
- package/dist/esm/lib/types/gltf-types.js +2 -0
- package/dist/esm/lib/types/gltf-types.js.map +1 -0
- package/dist/esm/lib/utils/assert.js +6 -0
- package/dist/esm/lib/utils/assert.js.map +1 -0
- package/dist/esm/lib/utils/version.js +2 -0
- package/dist/esm/lib/utils/version.js.map +1 -0
- package/dist/esm/meshopt/meshopt-decoder.js +91 -0
- package/dist/esm/meshopt/meshopt-decoder.js.map +1 -0
- package/dist/esm/meshopt/meshopt-encoder.ts.disabled +409 -0
- package/dist/esm/webp/webp.js +25 -0
- package/dist/esm/webp/webp.js.map +1 -0
- package/dist/glb-loader.d.ts +14 -0
- package/dist/glb-loader.d.ts.map +1 -0
- package/dist/glb-loader.js +33 -28
- package/dist/glb-writer.d.ts +13 -0
- package/dist/glb-writer.d.ts.map +1 -0
- package/dist/glb-writer.js +34 -26
- package/dist/gltf-loader.d.ts +19 -0
- package/dist/gltf-loader.d.ts.map +1 -0
- package/dist/gltf-loader.js +46 -43
- package/dist/gltf-writer.d.ts +25 -0
- package/dist/gltf-writer.d.ts.map +1 -0
- package/dist/gltf-writer.js +29 -26
- package/dist/index.d.ts +12 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +21 -7
- package/dist/lib/api/gltf-extensions.d.ts +31 -0
- package/dist/lib/api/gltf-extensions.d.ts.map +1 -0
- package/dist/lib/api/gltf-extensions.js +79 -31
- package/dist/lib/api/gltf-scenegraph.d.ts +177 -0
- package/dist/lib/api/gltf-scenegraph.d.ts.map +1 -0
- package/dist/lib/api/gltf-scenegraph.js +563 -512
- package/dist/lib/api/normalize-gltf-v1.d.ts +2 -0
- package/dist/lib/api/normalize-gltf-v1.d.ts.map +1 -0
- package/dist/lib/api/normalize-gltf-v1.js +278 -226
- package/dist/lib/api/post-process-gltf.d.ts +2 -0
- package/dist/lib/api/post-process-gltf.d.ts.map +1 -0
- package/dist/lib/api/post-process-gltf.js +324 -346
- package/dist/lib/encoders/encode-glb.d.ts +3 -0
- package/dist/lib/encoders/encode-glb.d.ts.map +1 -0
- package/dist/lib/encoders/encode-glb.js +56 -58
- package/dist/lib/encoders/encode-gltf.d.ts +20 -0
- package/dist/lib/encoders/encode-gltf.d.ts.map +1 -0
- package/dist/lib/encoders/encode-gltf.js +33 -12
- package/dist/lib/extensions/EXT_meshopt_compression.d.ts +7 -0
- package/dist/lib/extensions/EXT_meshopt_compression.d.ts.map +1 -0
- package/dist/lib/extensions/EXT_meshopt_compression.js +39 -50
- package/dist/lib/extensions/EXT_texture_webp.d.ts +12 -0
- package/dist/lib/extensions/EXT_texture_webp.d.ts.map +1 -0
- package/dist/lib/extensions/EXT_texture_webp.js +35 -28
- package/dist/lib/extensions/KHR_binary_gltf.d.ts +7 -0
- package/dist/lib/extensions/KHR_binary_gltf.d.ts.map +1 -0
- package/dist/lib/extensions/KHR_binary_gltf.js +39 -23
- package/dist/lib/extensions/KHR_draco_mesh_compression.d.ts +13 -0
- package/dist/lib/extensions/KHR_draco_mesh_compression.d.ts.map +1 -0
- package/dist/lib/extensions/KHR_draco_mesh_compression.js +126 -111
- package/dist/lib/extensions/KHR_texture_basisu.d.ts +12 -0
- package/dist/lib/extensions/KHR_texture_basisu.d.ts.map +1 -0
- package/dist/lib/extensions/KHR_texture_basisu.js +29 -19
- package/dist/lib/extensions/KHR_texture_transform.d.ts +13 -0
- package/dist/lib/extensions/KHR_texture_transform.d.ts.map +1 -0
- package/dist/lib/extensions/KHR_texture_transform.js +230 -0
- package/dist/lib/extensions/deprecated/EXT_feature_metadata.d.ts +6 -0
- package/dist/lib/extensions/deprecated/EXT_feature_metadata.d.ts.map +1 -0
- package/dist/lib/extensions/deprecated/EXT_feature_metadata.js +118 -0
- package/dist/lib/extensions/deprecated/KHR_lights_punctual.d.ts +7 -0
- package/dist/lib/extensions/deprecated/KHR_lights_punctual.d.ts.map +1 -0
- package/dist/lib/extensions/deprecated/KHR_lights_punctual.js +57 -44
- package/dist/lib/extensions/deprecated/KHR_materials_unlit.d.ts +7 -0
- package/dist/lib/extensions/deprecated/KHR_materials_unlit.d.ts.map +1 -0
- package/dist/lib/extensions/deprecated/KHR_materials_unlit.js +42 -32
- package/dist/lib/extensions/deprecated/KHR_techniques_webgl.d.ts +7 -0
- package/dist/lib/extensions/deprecated/KHR_techniques_webgl.d.ts.map +1 -0
- package/dist/lib/extensions/deprecated/KHR_techniques_webgl.js +76 -62
- package/dist/lib/gltf-utils/get-typed-array.d.ts +3 -0
- package/dist/lib/gltf-utils/get-typed-array.d.ts.map +1 -0
- package/dist/lib/gltf-utils/get-typed-array.js +39 -14
- package/dist/lib/gltf-utils/gltf-attribute-utils.d.ts +6 -0
- package/dist/lib/gltf-utils/gltf-attribute-utils.d.ts.map +1 -0
- package/dist/lib/gltf-utils/gltf-attribute-utils.js +65 -65
- package/dist/lib/gltf-utils/gltf-constants.d.ts +21 -0
- package/dist/lib/gltf-utils/gltf-constants.d.ts.map +1 -0
- package/dist/lib/gltf-utils/gltf-constants.js +38 -32
- package/dist/lib/gltf-utils/gltf-utils.d.ts +8 -0
- package/dist/lib/gltf-utils/gltf-utils.d.ts.map +1 -0
- package/dist/lib/gltf-utils/gltf-utils.js +52 -45
- package/dist/lib/gltf-utils/resolve-url.d.ts +2 -0
- package/dist/lib/gltf-utils/resolve-url.d.ts.map +1 -0
- package/dist/lib/gltf-utils/resolve-url.js +17 -15
- package/dist/lib/parsers/parse-glb.d.ts +8 -0
- package/dist/lib/parsers/parse-glb.d.ts.map +1 -0
- package/dist/lib/parsers/parse-glb.js +120 -107
- package/dist/lib/parsers/parse-gltf.d.ts +14 -0
- package/dist/lib/parsers/parse-gltf.d.ts.map +1 -0
- package/dist/lib/parsers/parse-gltf.js +187 -154
- package/dist/lib/types/glb-types.d.ts +17 -0
- package/dist/lib/types/glb-types.d.ts.map +1 -0
- package/dist/lib/types/glb-types.js +2 -2
- package/dist/lib/types/gltf-json-schema.d.ts +1105 -0
- package/dist/lib/types/gltf-json-schema.d.ts.map +1 -0
- package/dist/lib/types/gltf-json-schema.js +4 -2
- package/dist/lib/types/gltf-postprocessed-schema.d.ts +686 -0
- package/dist/lib/types/gltf-postprocessed-schema.d.ts.map +1 -0
- package/dist/lib/types/gltf-postprocessed-schema.js +4 -2
- package/dist/lib/types/gltf-types.d.ts +14 -0
- package/dist/lib/types/gltf-types.d.ts.map +1 -0
- package/dist/lib/types/gltf-types.js +3 -2
- package/dist/lib/utils/assert.d.ts +2 -0
- package/dist/lib/utils/assert.d.ts.map +1 -0
- package/dist/lib/utils/assert.js +11 -5
- package/dist/lib/utils/version.d.ts +2 -0
- package/dist/lib/utils/version.d.ts.map +1 -0
- package/dist/lib/utils/version.js +7 -2
- package/dist/meshopt/meshopt-decoder.d.ts +6 -0
- package/dist/meshopt/meshopt-decoder.d.ts.map +1 -0
- package/dist/meshopt/meshopt-decoder.js +97 -82
- package/dist/webp/webp.d.ts +7 -0
- package/dist/webp/webp.d.ts.map +1 -0
- package/dist/webp/webp.js +32 -23
- package/package.json +11 -13
- package/src/glb-loader.ts +1 -1
- package/src/glb-writer.ts +9 -3
- package/src/gltf-writer.ts +2 -2
- package/src/index.ts +11 -1
- package/src/lib/api/gltf-extensions.ts +13 -2
- package/src/lib/api/gltf-scenegraph.ts +23 -14
- package/src/lib/api/{normalize-gltf-v1.js → normalize-gltf-v1.ts} +20 -17
- package/src/lib/api/{post-process-gltf.js → post-process-gltf.ts} +52 -9
- package/src/lib/encoders/{encode-glb.js → encode-glb.ts} +8 -1
- package/src/lib/encoders/encode-gltf.ts +34 -0
- package/src/lib/extensions/EXT_meshopt_compression.ts +12 -19
- package/src/lib/extensions/EXT_texture_webp.ts +3 -2
- package/src/lib/extensions/KHR_binary_gltf.ts +1 -1
- package/src/lib/extensions/KHR_draco_mesh_compression.ts +1 -1
- package/src/lib/extensions/KHR_texture_basisu.ts +3 -2
- package/src/lib/extensions/KHR_texture_transform.ts +305 -0
- package/src/lib/extensions/deprecated/EXT_feature_metadata.ts +163 -0
- package/src/lib/extensions/deprecated/KHR_materials_unlit.ts +3 -3
- package/src/lib/extensions/deprecated/KHR_techniques_webgl.ts +1 -0
- package/src/lib/gltf-utils/gltf-constants.ts +2 -2
- package/src/lib/parsers/parse-gltf.ts +12 -3
- package/src/lib/types/glb-types.ts +1 -1
- package/src/lib/types/gltf-json-schema.ts +434 -5
- package/src/lib/types/gltf-postprocessed-schema.ts +12 -11
- package/src/lib/types/gltf-types.ts +26 -2
- package/src/lib/utils/{assert.js → assert.ts} +1 -1
- package/dist/bundle.js.map +0 -1
- package/dist/glb-loader.js.map +0 -1
- package/dist/glb-writer.js.map +0 -1
- package/dist/gltf-loader.js.map +0 -1
- package/dist/gltf-writer.js.map +0 -1
- package/dist/index.js.map +0 -1
- package/dist/lib/api/gltf-extensions.js.map +0 -1
- package/dist/lib/api/gltf-scenegraph.js.map +0 -1
- package/dist/lib/api/normalize-gltf-v1.js.map +0 -1
- package/dist/lib/api/post-process-gltf.js.map +0 -1
- package/dist/lib/encoders/encode-glb.js.map +0 -1
- package/dist/lib/encoders/encode-gltf.js.map +0 -1
- package/dist/lib/extensions/EXT_meshopt_compression.js.map +0 -1
- package/dist/lib/extensions/EXT_texture_webp.js.map +0 -1
- package/dist/lib/extensions/KHR_binary_gltf.js.map +0 -1
- package/dist/lib/extensions/KHR_draco_mesh_compression.js.map +0 -1
- package/dist/lib/extensions/KHR_texture_basisu.js.map +0 -1
- package/dist/lib/extensions/deprecated/KHR_lights_punctual.js.map +0 -1
- package/dist/lib/extensions/deprecated/KHR_materials_unlit.js.map +0 -1
- package/dist/lib/extensions/deprecated/KHR_techniques_webgl.js.map +0 -1
- package/dist/lib/gltf-utils/get-typed-array.js.map +0 -1
- package/dist/lib/gltf-utils/gltf-attribute-utils.js.map +0 -1
- package/dist/lib/gltf-utils/gltf-constants.js.map +0 -1
- package/dist/lib/gltf-utils/gltf-utils.js.map +0 -1
- package/dist/lib/gltf-utils/resolve-url.js.map +0 -1
- package/dist/lib/parsers/parse-glb.js.map +0 -1
- package/dist/lib/parsers/parse-gltf.js.map +0 -1
- package/dist/lib/types/glb-types.js.map +0 -1
- package/dist/lib/types/gltf-json-schema.js.map +0 -1
- package/dist/lib/types/gltf-postprocessed-schema.js.map +0 -1
- package/dist/lib/types/gltf-types.js.map +0 -1
- package/dist/lib/utils/assert.js.map +0 -1
- package/dist/lib/utils/version.js.map +0 -1
- package/dist/meshopt/meshopt-decoder.js.map +0 -1
- package/dist/webp/webp.js.map +0 -1
- package/src/lib/encoders/encode-gltf.js +0 -25
- /package/dist/{meshopt → es5/meshopt}/meshopt-encoder.ts.disabled +0 -0
- /package/src/lib/utils/{version.js → version.ts} +0 -0
|
@@ -0,0 +1,305 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* https://github.com/KhronosGroup/glTF/blob/main/extensions/2.0/Khronos/KHR_texture_transform/README.md
|
|
3
|
+
*/
|
|
4
|
+
|
|
5
|
+
import {Vector3, Matrix3} from '@math.gl/core';
|
|
6
|
+
import type {GLTFMeshPrimitive, GLTFWithBuffers} from '../types/gltf-types';
|
|
7
|
+
import type {GLTFLoaderOptions} from '../../gltf-loader';
|
|
8
|
+
import {getAccessorArrayTypeAndLength} from '../gltf-utils/gltf-utils';
|
|
9
|
+
import {BYTES, COMPONENTS} from '../gltf-utils/gltf-constants';
|
|
10
|
+
import {
|
|
11
|
+
Accessor,
|
|
12
|
+
BufferView,
|
|
13
|
+
MaterialNormalTextureInfo,
|
|
14
|
+
MaterialOcclusionTextureInfo,
|
|
15
|
+
TextureInfo as GLTFTextureInfo
|
|
16
|
+
} from '../types/gltf-json-schema';
|
|
17
|
+
import GLTFScenegraph from '../api/gltf-scenegraph';
|
|
18
|
+
|
|
19
|
+
/** Extension name */
|
|
20
|
+
const EXT_MESHOPT_TRANSFORM = 'KHR_texture_transform';
|
|
21
|
+
|
|
22
|
+
export const name = EXT_MESHOPT_TRANSFORM;
|
|
23
|
+
|
|
24
|
+
const scratchVector = new Vector3();
|
|
25
|
+
const scratchRotationMatrix = new Matrix3();
|
|
26
|
+
const scratchScaleMatrix = new Matrix3();
|
|
27
|
+
|
|
28
|
+
/** Extension textureInfo https://github.com/KhronosGroup/glTF/tree/main/extensions/2.0/Khronos/KHR_texture_transform#gltf-schema-updates */
|
|
29
|
+
type TextureInfo = {
|
|
30
|
+
/** The offset of the UV coordinate origin as a factor of the texture dimensions. */
|
|
31
|
+
offset?: [number, number];
|
|
32
|
+
/** Rotate the UVs by this many radians counter-clockwise around the origin. This is equivalent to a similar rotation of the image clockwise. */
|
|
33
|
+
rotation?: number;
|
|
34
|
+
/** The scale factor applied to the components of the UV coordinates. */
|
|
35
|
+
scale?: [number, number];
|
|
36
|
+
/** Overrides the textureInfo texCoord value if supplied, and if this extension is supported. */
|
|
37
|
+
texCoord?: number;
|
|
38
|
+
};
|
|
39
|
+
/** Intersection of all GLTF textures */
|
|
40
|
+
type CompoundGLTFTextureInfo = GLTFTextureInfo &
|
|
41
|
+
MaterialNormalTextureInfo &
|
|
42
|
+
MaterialOcclusionTextureInfo;
|
|
43
|
+
/** Parameters for TEXCOORD transformation */
|
|
44
|
+
type TransformParameters = {
|
|
45
|
+
/** Original texCoord value https://www.khronos.org/registry/glTF/specs/2.0/glTF-2.0.html#_textureinfo_texcoord */
|
|
46
|
+
originalTexCoord: number;
|
|
47
|
+
/** New texCoord value from extension https://github.com/KhronosGroup/glTF/tree/main/extensions/2.0/Khronos/KHR_texture_transform#gltf-schema-updates */
|
|
48
|
+
texCoord: number;
|
|
49
|
+
/** Transformation matrix */
|
|
50
|
+
matrix: Matrix3;
|
|
51
|
+
};
|
|
52
|
+
|
|
53
|
+
/**
|
|
54
|
+
* The extension entry to process the transformation
|
|
55
|
+
* @param gltfData gltf buffers and json
|
|
56
|
+
* @param options GLTFLoader options
|
|
57
|
+
*/
|
|
58
|
+
export async function decode(gltfData: GLTFWithBuffers, options: GLTFLoaderOptions) {
|
|
59
|
+
const gltfScenegraph = new GLTFScenegraph(gltfData);
|
|
60
|
+
const extension = gltfScenegraph.getExtension(EXT_MESHOPT_TRANSFORM);
|
|
61
|
+
if (!extension) {
|
|
62
|
+
return;
|
|
63
|
+
}
|
|
64
|
+
const materials = gltfData.json.materials || [];
|
|
65
|
+
for (let i = 0; i < materials.length; i++) {
|
|
66
|
+
transformTexCoords(i, gltfData);
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
|
|
70
|
+
/**
|
|
71
|
+
* Transform TEXCOORD by material
|
|
72
|
+
* @param materialIndex processing material index
|
|
73
|
+
* @param gltfData gltf buffers and json
|
|
74
|
+
*/
|
|
75
|
+
function transformTexCoords(materialIndex: number, gltfData: GLTFWithBuffers): void {
|
|
76
|
+
// Save processed texCoords in order no to process the same twice
|
|
77
|
+
const processedTexCoords: [number, number][] = [];
|
|
78
|
+
const material = gltfData.json.materials?.[materialIndex];
|
|
79
|
+
const baseColorTexture = material?.pbrMetallicRoughness?.baseColorTexture;
|
|
80
|
+
if (baseColorTexture) {
|
|
81
|
+
transformPrimitives(gltfData, materialIndex, baseColorTexture, processedTexCoords);
|
|
82
|
+
}
|
|
83
|
+
const emisiveTexture = material?.emissiveTexture;
|
|
84
|
+
if (emisiveTexture) {
|
|
85
|
+
transformPrimitives(gltfData, materialIndex, emisiveTexture, processedTexCoords);
|
|
86
|
+
}
|
|
87
|
+
const normalTexture = material?.normalTexture;
|
|
88
|
+
if (normalTexture) {
|
|
89
|
+
transformPrimitives(gltfData, materialIndex, normalTexture, processedTexCoords);
|
|
90
|
+
}
|
|
91
|
+
const occlusionTexture = material?.occlusionTexture;
|
|
92
|
+
if (occlusionTexture) {
|
|
93
|
+
transformPrimitives(gltfData, materialIndex, occlusionTexture, processedTexCoords);
|
|
94
|
+
}
|
|
95
|
+
const metallicRoughnessTexture = material?.pbrMetallicRoughness?.metallicRoughnessTexture;
|
|
96
|
+
if (metallicRoughnessTexture) {
|
|
97
|
+
transformPrimitives(gltfData, materialIndex, metallicRoughnessTexture, processedTexCoords);
|
|
98
|
+
}
|
|
99
|
+
}
|
|
100
|
+
|
|
101
|
+
/**
|
|
102
|
+
* Transform primitives of the particular material
|
|
103
|
+
* @param gltfData gltf data
|
|
104
|
+
* @param materialIndex primitives with this material will be transformed
|
|
105
|
+
* @param texture texture object
|
|
106
|
+
* @param processedTexCoords storage to save already processed texCoords
|
|
107
|
+
*/
|
|
108
|
+
function transformPrimitives(
|
|
109
|
+
gltfData: GLTFWithBuffers,
|
|
110
|
+
materialIndex: number,
|
|
111
|
+
texture: CompoundGLTFTextureInfo,
|
|
112
|
+
processedTexCoords: [number, number][]
|
|
113
|
+
) {
|
|
114
|
+
const transformParameters = getTransformParameters(texture, processedTexCoords);
|
|
115
|
+
if (!transformParameters) {
|
|
116
|
+
return;
|
|
117
|
+
}
|
|
118
|
+
const meshes = gltfData.json.meshes || [];
|
|
119
|
+
for (const mesh of meshes) {
|
|
120
|
+
for (const primitive of mesh.primitives) {
|
|
121
|
+
const material = primitive.material;
|
|
122
|
+
if (Number.isFinite(material) && materialIndex === material) {
|
|
123
|
+
transformPrimitive(gltfData, primitive, transformParameters);
|
|
124
|
+
}
|
|
125
|
+
}
|
|
126
|
+
}
|
|
127
|
+
}
|
|
128
|
+
|
|
129
|
+
/**
|
|
130
|
+
* Get parameters for TEXCOORD transformation
|
|
131
|
+
* @param texture texture object
|
|
132
|
+
* @param processedTexCoords storage to save already processed texCoords
|
|
133
|
+
* @returns texCoord couple and transformation matrix
|
|
134
|
+
*/
|
|
135
|
+
function getTransformParameters(
|
|
136
|
+
texture: CompoundGLTFTextureInfo,
|
|
137
|
+
processedTexCoords: [number, number][]
|
|
138
|
+
): TransformParameters | null {
|
|
139
|
+
const textureInfo = texture.extensions?.[EXT_MESHOPT_TRANSFORM];
|
|
140
|
+
const {texCoord: originalTexCoord = 0} = texture;
|
|
141
|
+
// If texCoord is not set in the extension, original attribute data will be replaced
|
|
142
|
+
const {texCoord = originalTexCoord} = textureInfo;
|
|
143
|
+
// Make sure that couple [originalTexCoord, extensionTexCoord] is not processed twice
|
|
144
|
+
const isProcessed =
|
|
145
|
+
processedTexCoords.findIndex(
|
|
146
|
+
([original, newTexCoord]) => original === originalTexCoord && newTexCoord === texCoord
|
|
147
|
+
) !== -1;
|
|
148
|
+
if (!isProcessed) {
|
|
149
|
+
const matrix = makeTransformationMatrix(textureInfo);
|
|
150
|
+
if (originalTexCoord !== texCoord) {
|
|
151
|
+
texture.texCoord = texCoord;
|
|
152
|
+
}
|
|
153
|
+
processedTexCoords.push([originalTexCoord, texCoord]);
|
|
154
|
+
return {originalTexCoord, texCoord, matrix};
|
|
155
|
+
}
|
|
156
|
+
return null;
|
|
157
|
+
}
|
|
158
|
+
|
|
159
|
+
/**
|
|
160
|
+
* Transform `TEXCOORD_0` attribute in the primitive
|
|
161
|
+
* @param gltfData gltf data
|
|
162
|
+
* @param primitive primitive object
|
|
163
|
+
* @param transformParameters texCoord couple and transformation matrix
|
|
164
|
+
*/
|
|
165
|
+
function transformPrimitive(
|
|
166
|
+
gltfData: GLTFWithBuffers,
|
|
167
|
+
primitive: GLTFMeshPrimitive,
|
|
168
|
+
transformParameters: TransformParameters
|
|
169
|
+
) {
|
|
170
|
+
const {originalTexCoord, texCoord, matrix} = transformParameters;
|
|
171
|
+
const texCoordAccessor = primitive.attributes[`TEXCOORD_${originalTexCoord}`];
|
|
172
|
+
if (Number.isFinite(texCoordAccessor)) {
|
|
173
|
+
// Get accessor of the `TEXCOORD_0` attribute
|
|
174
|
+
const accessor = gltfData.json.accessors?.[texCoordAccessor];
|
|
175
|
+
if (accessor && accessor.bufferView) {
|
|
176
|
+
// Get `bufferView` of the `accessor`
|
|
177
|
+
const bufferView = gltfData.json.bufferViews?.[accessor.bufferView];
|
|
178
|
+
if (bufferView) {
|
|
179
|
+
// Get `arrayBuffer` the `bufferView` look at
|
|
180
|
+
const {arrayBuffer, byteOffset: bufferByteOffset} = gltfData.buffers[bufferView.buffer];
|
|
181
|
+
// Resulting byteOffset is sum of the buffer, accessor and bufferView byte offsets
|
|
182
|
+
const byteOffset =
|
|
183
|
+
(bufferByteOffset || 0) + (accessor.byteOffset || 0) + (bufferView.byteOffset || 0);
|
|
184
|
+
// Deduce TypedArray type and its length from `accessor` and `bufferView` data
|
|
185
|
+
const {ArrayType, length} = getAccessorArrayTypeAndLength(accessor, bufferView);
|
|
186
|
+
// Number of bytes each component occupies
|
|
187
|
+
const bytes = BYTES[accessor.componentType];
|
|
188
|
+
// Number of components. For the `TEXCOORD_0` with `VEC2` type, it must return 2
|
|
189
|
+
const components = COMPONENTS[accessor.type];
|
|
190
|
+
// Multiplier to calculate the address of the `TEXCOORD_0` element in the arrayBuffer
|
|
191
|
+
const elementAddressScale = bufferView.byteStride || bytes * components;
|
|
192
|
+
// Data transform to Float32Array
|
|
193
|
+
const result = new Float32Array(length);
|
|
194
|
+
for (let i = 0; i < accessor.count; i++) {
|
|
195
|
+
// Take [u, v] couple from the arrayBuffer
|
|
196
|
+
const uv = new ArrayType(arrayBuffer, byteOffset + i * elementAddressScale, 2);
|
|
197
|
+
// Set and transform Vector3 per https://github.com/KhronosGroup/glTF/tree/main/extensions/2.0/Khronos/KHR_texture_transform#overview
|
|
198
|
+
scratchVector.set(uv[0], uv[1], 1);
|
|
199
|
+
scratchVector.transformByMatrix3(matrix);
|
|
200
|
+
// Save result in Float32Array
|
|
201
|
+
result.set([scratchVector[0], scratchVector[1]], i * components);
|
|
202
|
+
}
|
|
203
|
+
// If texCoord the same, replace gltf structural data
|
|
204
|
+
if (originalTexCoord === texCoord) {
|
|
205
|
+
updateGltf(accessor, bufferView, gltfData.buffers, result);
|
|
206
|
+
} else {
|
|
207
|
+
// If texCoord change, create new attribute
|
|
208
|
+
createAttribute(texCoord, accessor, primitive, gltfData, result);
|
|
209
|
+
}
|
|
210
|
+
}
|
|
211
|
+
}
|
|
212
|
+
}
|
|
213
|
+
}
|
|
214
|
+
|
|
215
|
+
/**
|
|
216
|
+
* Update GLTF structural objects with new data as we create new `Float32Array` for `TEXCOORD_0`.
|
|
217
|
+
* @param accessor accessor to change
|
|
218
|
+
* @param bufferView bufferView to change
|
|
219
|
+
* @param buffers binary buffers
|
|
220
|
+
* @param newTexcoordArray typed array with data after transformation
|
|
221
|
+
*/
|
|
222
|
+
function updateGltf(
|
|
223
|
+
accessor: Accessor,
|
|
224
|
+
bufferView: BufferView,
|
|
225
|
+
buffers: {arrayBuffer: ArrayBuffer; byteOffset: number; byteLength: number}[],
|
|
226
|
+
newTexCoordArray: Float32Array
|
|
227
|
+
): void {
|
|
228
|
+
accessor.componentType = 5126;
|
|
229
|
+
buffers.push({
|
|
230
|
+
arrayBuffer: newTexCoordArray.buffer,
|
|
231
|
+
byteOffset: 0,
|
|
232
|
+
byteLength: newTexCoordArray.buffer.byteLength
|
|
233
|
+
});
|
|
234
|
+
bufferView.buffer = buffers.length - 1;
|
|
235
|
+
bufferView.byteLength = newTexCoordArray.buffer.byteLength;
|
|
236
|
+
bufferView.byteOffset = 0;
|
|
237
|
+
delete bufferView.byteStride;
|
|
238
|
+
}
|
|
239
|
+
|
|
240
|
+
/**
|
|
241
|
+
*
|
|
242
|
+
* @param newTexCoord new `texCoord` value
|
|
243
|
+
* @param originalAccessor original accessor object, that store data before transformation
|
|
244
|
+
* @param primitive primitive object
|
|
245
|
+
* @param gltfData gltf data
|
|
246
|
+
* @param newTexCoordArray typed array with data after transformation
|
|
247
|
+
* @returns
|
|
248
|
+
*/
|
|
249
|
+
function createAttribute(
|
|
250
|
+
newTexCoord: number,
|
|
251
|
+
originalAccessor: Accessor,
|
|
252
|
+
primitive: GLTFMeshPrimitive,
|
|
253
|
+
gltfData: GLTFWithBuffers,
|
|
254
|
+
newTexCoordArray: Float32Array
|
|
255
|
+
) {
|
|
256
|
+
gltfData.buffers.push({
|
|
257
|
+
arrayBuffer: newTexCoordArray.buffer,
|
|
258
|
+
byteOffset: 0,
|
|
259
|
+
byteLength: newTexCoordArray.buffer.byteLength
|
|
260
|
+
});
|
|
261
|
+
const bufferViews = gltfData.json.bufferViews;
|
|
262
|
+
if (!bufferViews) {
|
|
263
|
+
return;
|
|
264
|
+
}
|
|
265
|
+
bufferViews.push({
|
|
266
|
+
buffer: gltfData.buffers.length - 1,
|
|
267
|
+
byteLength: newTexCoordArray.buffer.byteLength,
|
|
268
|
+
byteOffset: 0
|
|
269
|
+
});
|
|
270
|
+
const accessors = gltfData.json.accessors;
|
|
271
|
+
if (!accessors) {
|
|
272
|
+
return;
|
|
273
|
+
}
|
|
274
|
+
accessors.push({
|
|
275
|
+
bufferView: bufferViews?.length - 1,
|
|
276
|
+
byteOffset: 0,
|
|
277
|
+
componentType: 5126,
|
|
278
|
+
count: originalAccessor.count,
|
|
279
|
+
type: 'VEC2'
|
|
280
|
+
});
|
|
281
|
+
primitive.attributes[`TEXCOORD_${newTexCoord}`] = accessors.length - 1;
|
|
282
|
+
}
|
|
283
|
+
|
|
284
|
+
/**
|
|
285
|
+
* Construct transformation matrix from the extension data (transition, rotation, scale)
|
|
286
|
+
* @param extensionData extension data
|
|
287
|
+
* @returns transformation matrix
|
|
288
|
+
*/
|
|
289
|
+
function makeTransformationMatrix(extensionData: TextureInfo): Matrix3 {
|
|
290
|
+
const {offset = [0, 0], rotation = 0, scale = [1, 1]} = extensionData;
|
|
291
|
+
const translationMatirx = new Matrix3().set(1, 0, 0, 0, 1, 0, offset[0], offset[1], 1);
|
|
292
|
+
const rotationMatirx = scratchRotationMatrix.set(
|
|
293
|
+
Math.cos(rotation),
|
|
294
|
+
Math.sin(rotation),
|
|
295
|
+
0,
|
|
296
|
+
-Math.sin(rotation),
|
|
297
|
+
Math.cos(rotation),
|
|
298
|
+
0,
|
|
299
|
+
0,
|
|
300
|
+
0,
|
|
301
|
+
1
|
|
302
|
+
);
|
|
303
|
+
const scaleMatrix = scratchScaleMatrix.set(scale[0], 0, 0, 0, scale[1], 0, 0, 0, 1);
|
|
304
|
+
return translationMatirx.multiplyRight(rotationMatirx).multiplyRight(scaleMatrix);
|
|
305
|
+
}
|
|
@@ -0,0 +1,163 @@
|
|
|
1
|
+
/* eslint-disable camelcase */
|
|
2
|
+
import type {GLTF} from '../../types/gltf-types';
|
|
3
|
+
|
|
4
|
+
import GLTFScenegraph from '../../api/gltf-scenegraph';
|
|
5
|
+
import {
|
|
6
|
+
ClassProperty,
|
|
7
|
+
EXT_feature_metadata_class_object,
|
|
8
|
+
EXT_feature_metadata_feature_table,
|
|
9
|
+
FeatureTableProperty,
|
|
10
|
+
GLTF_EXT_feature_metadata
|
|
11
|
+
} from '../../types/gltf-json-schema';
|
|
12
|
+
|
|
13
|
+
/** Extension name */
|
|
14
|
+
const EXT_FEATURE_METADATA = 'EXT_feature_metadata';
|
|
15
|
+
|
|
16
|
+
export const name = EXT_FEATURE_METADATA;
|
|
17
|
+
|
|
18
|
+
export async function decode(gltfData: {json: GLTF}): Promise<void> {
|
|
19
|
+
const scenegraph = new GLTFScenegraph(gltfData);
|
|
20
|
+
decodeExtFeatureMetadata(scenegraph);
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
/**
|
|
24
|
+
* Decodes feature metadata from extension
|
|
25
|
+
* @param scenegraph
|
|
26
|
+
*/
|
|
27
|
+
function decodeExtFeatureMetadata(scenegraph: GLTFScenegraph): void {
|
|
28
|
+
const extension: GLTF_EXT_feature_metadata | null = scenegraph.getExtension(EXT_FEATURE_METADATA);
|
|
29
|
+
const schemaClasses = extension?.schema?.classes;
|
|
30
|
+
const featureTables = extension?.featureTables;
|
|
31
|
+
const featureTextures = extension?.featureTextures;
|
|
32
|
+
|
|
33
|
+
if (featureTextures) {
|
|
34
|
+
/*
|
|
35
|
+
* TODO add support for featureTextures
|
|
36
|
+
* Spec - https://github.com/CesiumGS/glTF/tree/3d-tiles-next/extensions/2.0/Vendor/EXT_feature_metadata#feature-textures
|
|
37
|
+
*/
|
|
38
|
+
// eslint-disable-next-line no-console
|
|
39
|
+
console.warn('featureTextures is not yet supported in the "EXT_feature_metadata" extension.');
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
if (schemaClasses && featureTables) {
|
|
43
|
+
for (const schemaName in schemaClasses) {
|
|
44
|
+
const schemaClass = schemaClasses[schemaName];
|
|
45
|
+
const featureTable = findFeatureTableByName(featureTables, schemaName);
|
|
46
|
+
|
|
47
|
+
if (featureTable) {
|
|
48
|
+
handleFeatureTableProperties(scenegraph, featureTable, schemaClass);
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
/**
|
|
55
|
+
* Navigate throw all properies in feature table and gets properties data.
|
|
56
|
+
* @param scenegraph
|
|
57
|
+
* @param featureTable
|
|
58
|
+
* @param schemaClass
|
|
59
|
+
*/
|
|
60
|
+
function handleFeatureTableProperties(
|
|
61
|
+
scenegraph: GLTFScenegraph,
|
|
62
|
+
featureTable: EXT_feature_metadata_feature_table,
|
|
63
|
+
schemaClass: EXT_feature_metadata_class_object
|
|
64
|
+
): void {
|
|
65
|
+
for (const propertyName in schemaClass.properties) {
|
|
66
|
+
const schemaProperty = schemaClass.properties[propertyName];
|
|
67
|
+
const featureTableProperty = featureTable?.properties?.[propertyName];
|
|
68
|
+
const numberOfFeatures = featureTable.count;
|
|
69
|
+
|
|
70
|
+
if (featureTableProperty) {
|
|
71
|
+
const data = getPropertyDataFromBinarySource(
|
|
72
|
+
scenegraph,
|
|
73
|
+
schemaProperty,
|
|
74
|
+
numberOfFeatures,
|
|
75
|
+
featureTableProperty
|
|
76
|
+
);
|
|
77
|
+
featureTableProperty.data = data;
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
|
|
82
|
+
/**
|
|
83
|
+
* Decode properties from binary sourse based on property type.
|
|
84
|
+
* @param scenegraph
|
|
85
|
+
* @param schemaProperty
|
|
86
|
+
* @param numberOfFeatures
|
|
87
|
+
* @param featureTableProperty
|
|
88
|
+
*/
|
|
89
|
+
function getPropertyDataFromBinarySource(
|
|
90
|
+
scenegraph: GLTFScenegraph,
|
|
91
|
+
schemaProperty: ClassProperty,
|
|
92
|
+
numberOfFeatures: number,
|
|
93
|
+
featureTableProperty: FeatureTableProperty
|
|
94
|
+
): Uint8Array | string[] {
|
|
95
|
+
const bufferView = featureTableProperty.bufferView;
|
|
96
|
+
// TODO think maybe we shouldn't get data only in Uint8Array format.
|
|
97
|
+
let data: Uint8Array | string[] = scenegraph.getTypedArrayForBufferView(bufferView);
|
|
98
|
+
|
|
99
|
+
switch (schemaProperty.type) {
|
|
100
|
+
case 'STRING': {
|
|
101
|
+
// stringOffsetBufferView should be available for string type.
|
|
102
|
+
const stringOffsetBufferView = featureTableProperty.stringOffsetBufferView!;
|
|
103
|
+
const offsetsData = scenegraph.getTypedArrayForBufferView(stringOffsetBufferView);
|
|
104
|
+
data = getStringAttributes(data, offsetsData, numberOfFeatures);
|
|
105
|
+
break;
|
|
106
|
+
}
|
|
107
|
+
default:
|
|
108
|
+
}
|
|
109
|
+
|
|
110
|
+
return data;
|
|
111
|
+
}
|
|
112
|
+
|
|
113
|
+
/**
|
|
114
|
+
* Find the feature table by class name.
|
|
115
|
+
* @param featureTables
|
|
116
|
+
* @param schemaClassName
|
|
117
|
+
*/
|
|
118
|
+
function findFeatureTableByName(
|
|
119
|
+
featureTables: {[key: string]: EXT_feature_metadata_feature_table},
|
|
120
|
+
schemaClassName: string
|
|
121
|
+
): EXT_feature_metadata_feature_table | null {
|
|
122
|
+
for (const featureTableName in featureTables) {
|
|
123
|
+
const featureTable = featureTables[featureTableName];
|
|
124
|
+
|
|
125
|
+
if (featureTable.class === schemaClassName) {
|
|
126
|
+
return featureTable;
|
|
127
|
+
}
|
|
128
|
+
}
|
|
129
|
+
|
|
130
|
+
return null;
|
|
131
|
+
}
|
|
132
|
+
|
|
133
|
+
/**
|
|
134
|
+
* Getting string attributes from binary data.
|
|
135
|
+
* Spec - https://github.com/CesiumGS/3d-tiles/tree/main/specification/Metadata#strings
|
|
136
|
+
* @param data
|
|
137
|
+
* @param offsetsData
|
|
138
|
+
* @param stringsCount
|
|
139
|
+
*/
|
|
140
|
+
function getStringAttributes(
|
|
141
|
+
data: Uint8Array,
|
|
142
|
+
offsetsData: Uint8Array,
|
|
143
|
+
stringsCount: number
|
|
144
|
+
): string[] {
|
|
145
|
+
const stringsArray: string[] = [];
|
|
146
|
+
const textDecoder = new TextDecoder('utf8');
|
|
147
|
+
|
|
148
|
+
let stringOffset = 0;
|
|
149
|
+
const bytesPerStringSize = 4;
|
|
150
|
+
|
|
151
|
+
for (let index = 0; index < stringsCount; index++) {
|
|
152
|
+
// TODO check if it is multiplication on bytesPerStringSize is valid operation?
|
|
153
|
+
const stringByteSize =
|
|
154
|
+
offsetsData[(index + 1) * bytesPerStringSize] - offsetsData[index * bytesPerStringSize];
|
|
155
|
+
const stringData = data.subarray(stringOffset, stringByteSize + stringOffset);
|
|
156
|
+
const stringAttribute = textDecoder.decode(stringData);
|
|
157
|
+
|
|
158
|
+
stringsArray.push(stringAttribute);
|
|
159
|
+
stringOffset += stringByteSize;
|
|
160
|
+
}
|
|
161
|
+
|
|
162
|
+
return stringsArray;
|
|
163
|
+
}
|
|
@@ -13,9 +13,6 @@ export async function decode(gltfData: {json: GLTF}): Promise<void> {
|
|
|
13
13
|
const gltfScenegraph = new GLTFScenegraph(gltfData);
|
|
14
14
|
const {json} = gltfScenegraph;
|
|
15
15
|
|
|
16
|
-
// Remove the top-level extension
|
|
17
|
-
gltfScenegraph.removeExtension(KHR_MATERIALS_UNLIT);
|
|
18
|
-
|
|
19
16
|
// Any nodes that have the extension, add lights field pointing to light object
|
|
20
17
|
// and remove the extension
|
|
21
18
|
for (const material of json.materials || []) {
|
|
@@ -26,6 +23,9 @@ export async function decode(gltfData: {json: GLTF}): Promise<void> {
|
|
|
26
23
|
}
|
|
27
24
|
gltfScenegraph.removeObjectExtension(material, KHR_MATERIALS_UNLIT);
|
|
28
25
|
}
|
|
26
|
+
|
|
27
|
+
// Remove the top-level extension
|
|
28
|
+
gltfScenegraph.removeExtension(KHR_MATERIALS_UNLIT);
|
|
29
29
|
}
|
|
30
30
|
|
|
31
31
|
export function encode(gltfData) {
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
const COMPONENTS = {
|
|
1
|
+
export const COMPONENTS = {
|
|
2
2
|
SCALAR: 1,
|
|
3
3
|
VEC2: 2,
|
|
4
4
|
VEC3: 3,
|
|
@@ -8,7 +8,7 @@ const COMPONENTS = {
|
|
|
8
8
|
MAT4: 16
|
|
9
9
|
};
|
|
10
10
|
|
|
11
|
-
const BYTES = {
|
|
11
|
+
export const BYTES = {
|
|
12
12
|
5120: 1, // BYTE
|
|
13
13
|
5121: 1, // UNSIGNED_BYTE
|
|
14
14
|
5122: 2, // SHORT
|
|
@@ -144,6 +144,12 @@ async function loadBuffers(gltf: GLTFWithBuffers, options, context: LoaderContex
|
|
|
144
144
|
};
|
|
145
145
|
|
|
146
146
|
delete buffer.uri;
|
|
147
|
+
} else if (gltf.buffers[i] === null) {
|
|
148
|
+
gltf.buffers[i] = {
|
|
149
|
+
arrayBuffer: new ArrayBuffer(buffer.byteLength),
|
|
150
|
+
byteOffset: 0,
|
|
151
|
+
byteLength: buffer.byteLength
|
|
152
|
+
};
|
|
147
153
|
}
|
|
148
154
|
}
|
|
149
155
|
}
|
|
@@ -195,10 +201,13 @@ async function loadImage(
|
|
|
195
201
|
|
|
196
202
|
let arrayBuffer;
|
|
197
203
|
|
|
198
|
-
if (image.uri) {
|
|
204
|
+
if (image.uri && !image.hasOwnProperty('bufferView')) {
|
|
199
205
|
const uri = resolveUrl(image.uri, options);
|
|
200
206
|
const response = await fetch(uri);
|
|
201
207
|
arrayBuffer = await response.arrayBuffer();
|
|
208
|
+
image.bufferView = {
|
|
209
|
+
data: arrayBuffer
|
|
210
|
+
};
|
|
202
211
|
}
|
|
203
212
|
|
|
204
213
|
if (Number.isFinite(image.bufferView)) {
|
|
@@ -212,7 +221,7 @@ async function loadImage(
|
|
|
212
221
|
let parsedImage = await parse(
|
|
213
222
|
arrayBuffer,
|
|
214
223
|
[ImageLoader, BasisLoader],
|
|
215
|
-
{mimeType: image.mimeType, basis: {format: selectSupportedBasisFormat()}},
|
|
224
|
+
{mimeType: image.mimeType, basis: options.basis || {format: selectSupportedBasisFormat()}},
|
|
216
225
|
context
|
|
217
226
|
);
|
|
218
227
|
|
|
@@ -222,7 +231,7 @@ async function loadImage(
|
|
|
222
231
|
mipmaps: false,
|
|
223
232
|
width: parsedImage[0].width,
|
|
224
233
|
height: parsedImage[0].height,
|
|
225
|
-
data: parsedImage
|
|
234
|
+
data: parsedImage[0]
|
|
226
235
|
};
|
|
227
236
|
}
|
|
228
237
|
// TODO making sure ImageLoader is overridable by using array of loaders
|