tangram-core 0.2.0__cp313-cp313-win_amd64.whl
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.
- tangram_core/App.vue +335 -0
- tangram_core/__init__.py +5 -0
- tangram_core/__main__.py +141 -0
- tangram_core/_core.cp313-win_amd64.pyd +0 -0
- tangram_core/_core.pyi +38 -0
- tangram_core/api.ts +456 -0
- tangram_core/backend.py +335 -0
- tangram_core/colour.ts +71 -0
- tangram_core/config.py +122 -0
- tangram_core/dist-frontend/aggregation-layers.js +521 -0
- tangram_core/dist-frontend/aggregation-layers.js.map +1 -0
- tangram_core/dist-frontend/assets/_commonjsHelpers-CqkleIqs.js +2 -0
- tangram_core/dist-frontend/assets/_commonjsHelpers-CqkleIqs.js.map +1 -0
- tangram_core/dist-frontend/assets/array-utils-flat-wyE8tIYR.js +11 -0
- tangram_core/dist-frontend/assets/array-utils-flat-wyE8tIYR.js.map +1 -0
- tangram_core/dist-frontend/assets/assert-hrfsarFU.js +3 -0
- tangram_core/dist-frontend/assets/assert-hrfsarFU.js.map +1 -0
- tangram_core/dist-frontend/assets/b612-latin-400-italic-DePNXA0a.woff +0 -0
- tangram_core/dist-frontend/assets/b612-latin-400-italic-a-4GLPtl.woff2 +0 -0
- tangram_core/dist-frontend/assets/b612-latin-400-normal-CC98FVm_.woff2 +0 -0
- tangram_core/dist-frontend/assets/b612-latin-400-normal-JbZ7xwUX.woff +0 -0
- tangram_core/dist-frontend/assets/b612-latin-700-normal-B_Snq1wd.woff +0 -0
- tangram_core/dist-frontend/assets/b612-latin-700-normal-BinQrnoB.woff2 +0 -0
- tangram_core/dist-frontend/assets/clip-extension-DTCP51Ak.js +26 -0
- tangram_core/dist-frontend/assets/clip-extension-DTCP51Ak.js.map +1 -0
- tangram_core/dist-frontend/assets/color-CUNNsFV-.js +17 -0
- tangram_core/dist-frontend/assets/color-CUNNsFV-.js.map +1 -0
- tangram_core/dist-frontend/assets/cube-geometry-CzJ_uBWa.js +2 -0
- tangram_core/dist-frontend/assets/cube-geometry-CzJ_uBWa.js.map +1 -0
- tangram_core/dist-frontend/assets/deep-equal-uriyKJca.js +2 -0
- tangram_core/dist-frontend/assets/deep-equal-uriyKJca.js.map +1 -0
- tangram_core/dist-frontend/assets/fly-to-interpolator-DlKiy9_S.js +2 -0
- tangram_core/dist-frontend/assets/fly-to-interpolator-DlKiy9_S.js.map +1 -0
- tangram_core/dist-frontend/assets/geojson-layer-CLhXLxdI.js +1010 -0
- tangram_core/dist-frontend/assets/geojson-layer-CLhXLxdI.js.map +1 -0
- tangram_core/dist-frontend/assets/globe-view-DKhftlA1.js +94 -0
- tangram_core/dist-frontend/assets/globe-view-DKhftlA1.js.map +1 -0
- tangram_core/dist-frontend/assets/globe-viewport-CPES4D4P.js +2 -0
- tangram_core/dist-frontend/assets/globe-viewport-CPES4D4P.js.map +1 -0
- tangram_core/dist-frontend/assets/image-loader-ClbNCMXW.js +2 -0
- tangram_core/dist-frontend/assets/image-loader-ClbNCMXW.js.map +1 -0
- tangram_core/dist-frontend/assets/inconsolata-latin-400-normal-DTZQ6lD6.woff2 +0 -0
- tangram_core/dist-frontend/assets/inconsolata-latin-400-normal-HYADljCo.woff +0 -0
- tangram_core/dist-frontend/assets/inconsolata-latin-700-normal-ByjKuJjN.woff2 +0 -0
- tangram_core/dist-frontend/assets/inconsolata-latin-700-normal-DzgUY3Rl.woff +0 -0
- tangram_core/dist-frontend/assets/inconsolata-latin-ext-400-normal-BaHVOdFB.woff2 +0 -0
- tangram_core/dist-frontend/assets/inconsolata-latin-ext-400-normal-yvPjCxxx.woff +0 -0
- tangram_core/dist-frontend/assets/inconsolata-latin-ext-700-normal-D0Kpgs_9.woff2 +0 -0
- tangram_core/dist-frontend/assets/inconsolata-latin-ext-700-normal-Dlt-daqV.woff +0 -0
- tangram_core/dist-frontend/assets/inconsolata-vietnamese-400-normal-ByiM2lek.woff +0 -0
- tangram_core/dist-frontend/assets/inconsolata-vietnamese-400-normal-DfC_iMic.woff2 +0 -0
- tangram_core/dist-frontend/assets/inconsolata-vietnamese-700-normal-DLCFFAUf.woff +0 -0
- tangram_core/dist-frontend/assets/inconsolata-vietnamese-700-normal-DuasYmn8.woff2 +0 -0
- tangram_core/dist-frontend/assets/index-UPPakSLR.css +1 -0
- tangram_core/dist-frontend/assets/index-r8T0kY2p.js +821 -0
- tangram_core/dist-frontend/assets/index-r8T0kY2p.js.map +1 -0
- tangram_core/dist-frontend/assets/layer-DO63TrsS.js +555 -0
- tangram_core/dist-frontend/assets/layer-DO63TrsS.js.map +1 -0
- tangram_core/dist-frontend/assets/layer-extension-CZ3zsHuN.js +2 -0
- tangram_core/dist-frontend/assets/layer-extension-CZ3zsHuN.js.map +1 -0
- tangram_core/dist-frontend/assets/mesh-layers-BSECKarm.js +1123 -0
- tangram_core/dist-frontend/assets/mesh-layers-BSECKarm.js.map +1 -0
- tangram_core/dist-frontend/assets/orthographic-viewport-CzZmHDEZ.js +2 -0
- tangram_core/dist-frontend/assets/orthographic-viewport-CzZmHDEZ.js.map +1 -0
- tangram_core/dist-frontend/assets/pick-layers-pass-xhWsgZtf.js +2 -0
- tangram_core/dist-frontend/assets/pick-layers-pass-xhWsgZtf.js.map +1 -0
- tangram_core/dist-frontend/assets/project-CrvReKGW.js +760 -0
- tangram_core/dist-frontend/assets/project-CrvReKGW.js.map +1 -0
- tangram_core/dist-frontend/assets/roboto-condensed-cyrillic-400-italic-4qS3_zkX.woff2 +0 -0
- tangram_core/dist-frontend/assets/roboto-condensed-cyrillic-400-italic-CDK-EZBY.woff +0 -0
- tangram_core/dist-frontend/assets/roboto-condensed-cyrillic-400-normal-Bgns473E.woff +0 -0
- tangram_core/dist-frontend/assets/roboto-condensed-cyrillic-400-normal-_T2aQlWs.woff2 +0 -0
- tangram_core/dist-frontend/assets/roboto-condensed-cyrillic-500-normal-CvEVpWxD.woff +0 -0
- tangram_core/dist-frontend/assets/roboto-condensed-cyrillic-500-normal-s4PklZE0.woff2 +0 -0
- tangram_core/dist-frontend/assets/roboto-condensed-cyrillic-700-normal-9RN-Z7cI.woff2 +0 -0
- tangram_core/dist-frontend/assets/roboto-condensed-cyrillic-700-normal-BGMkBBYx.woff +0 -0
- tangram_core/dist-frontend/assets/roboto-condensed-cyrillic-ext-400-italic-C7erd-g8.woff +0 -0
- tangram_core/dist-frontend/assets/roboto-condensed-cyrillic-ext-400-italic-DR5R5TWx.woff2 +0 -0
- tangram_core/dist-frontend/assets/roboto-condensed-cyrillic-ext-400-normal-DGo1Ayjq.woff2 +0 -0
- tangram_core/dist-frontend/assets/roboto-condensed-cyrillic-ext-400-normal-WtM1l1qc.woff +0 -0
- tangram_core/dist-frontend/assets/roboto-condensed-cyrillic-ext-500-normal-C8FNIdXm.woff2 +0 -0
- tangram_core/dist-frontend/assets/roboto-condensed-cyrillic-ext-500-normal-TLDmfi3Q.woff +0 -0
- tangram_core/dist-frontend/assets/roboto-condensed-cyrillic-ext-700-normal-CTXjXnze.woff2 +0 -0
- tangram_core/dist-frontend/assets/roboto-condensed-cyrillic-ext-700-normal-CWPRiRXS.woff +0 -0
- tangram_core/dist-frontend/assets/roboto-condensed-greek-400-italic-CR6qj4Z4.woff2 +0 -0
- tangram_core/dist-frontend/assets/roboto-condensed-greek-400-italic-DHRaIs10.woff +0 -0
- tangram_core/dist-frontend/assets/roboto-condensed-greek-400-normal-D5vBSIyg.woff2 +0 -0
- tangram_core/dist-frontend/assets/roboto-condensed-greek-400-normal-FabMgVmk.woff +0 -0
- tangram_core/dist-frontend/assets/roboto-condensed-greek-500-normal-BIN62cw9.woff +0 -0
- tangram_core/dist-frontend/assets/roboto-condensed-greek-500-normal-Hsn-wDIp.woff2 +0 -0
- tangram_core/dist-frontend/assets/roboto-condensed-greek-700-normal-89Up2Xly.woff +0 -0
- tangram_core/dist-frontend/assets/roboto-condensed-greek-700-normal-DWMOA2VK.woff2 +0 -0
- tangram_core/dist-frontend/assets/roboto-condensed-latin-400-italic-D_BR-3LG.woff2 +0 -0
- tangram_core/dist-frontend/assets/roboto-condensed-latin-400-italic-om57GXsO.woff +0 -0
- tangram_core/dist-frontend/assets/roboto-condensed-latin-400-normal-BICmKrXV.woff2 +0 -0
- tangram_core/dist-frontend/assets/roboto-condensed-latin-400-normal-D2e7XwB1.woff +0 -0
- tangram_core/dist-frontend/assets/roboto-condensed-latin-500-normal-3p2daRJW.woff2 +0 -0
- tangram_core/dist-frontend/assets/roboto-condensed-latin-500-normal-Dc9bsamC.woff +0 -0
- tangram_core/dist-frontend/assets/roboto-condensed-latin-700-normal-BOl6B_hI.woff +0 -0
- tangram_core/dist-frontend/assets/roboto-condensed-latin-700-normal-DRbp0YnP.woff2 +0 -0
- tangram_core/dist-frontend/assets/roboto-condensed-latin-ext-400-italic-BXrkWnoY.woff +0 -0
- tangram_core/dist-frontend/assets/roboto-condensed-latin-ext-400-italic-Bhem1d5z.woff2 +0 -0
- tangram_core/dist-frontend/assets/roboto-condensed-latin-ext-400-normal-DT8nEsYA.woff +0 -0
- tangram_core/dist-frontend/assets/roboto-condensed-latin-ext-400-normal-OHaX69iP.woff2 +0 -0
- tangram_core/dist-frontend/assets/roboto-condensed-latin-ext-500-normal-CcSTXKtO.woff2 +0 -0
- tangram_core/dist-frontend/assets/roboto-condensed-latin-ext-500-normal-JgPl2bDS.woff +0 -0
- tangram_core/dist-frontend/assets/roboto-condensed-latin-ext-700-normal-B004qtqu.woff2 +0 -0
- tangram_core/dist-frontend/assets/roboto-condensed-latin-ext-700-normal-O6H_RRvN.woff +0 -0
- tangram_core/dist-frontend/assets/roboto-condensed-vietnamese-400-italic-BwUYFJ2t.woff2 +0 -0
- tangram_core/dist-frontend/assets/roboto-condensed-vietnamese-400-italic-DV8QogUk.woff +0 -0
- tangram_core/dist-frontend/assets/roboto-condensed-vietnamese-400-normal-0o1laQ-g.woff2 +0 -0
- tangram_core/dist-frontend/assets/roboto-condensed-vietnamese-400-normal-CPsdS8_S.woff +0 -0
- tangram_core/dist-frontend/assets/roboto-condensed-vietnamese-500-normal-G9shSJ2z.woff +0 -0
- tangram_core/dist-frontend/assets/roboto-condensed-vietnamese-500-normal-TFWhjk13.woff2 +0 -0
- tangram_core/dist-frontend/assets/roboto-condensed-vietnamese-700-normal-BtNeb9D6.woff +0 -0
- tangram_core/dist-frontend/assets/roboto-condensed-vietnamese-700-normal-D35V1G0s.woff2 +0 -0
- tangram_core/dist-frontend/assets/shader-BJmsOfPx.js +843 -0
- tangram_core/dist-frontend/assets/shader-BJmsOfPx.js.map +1 -0
- tangram_core/dist-frontend/assets/solid-polygon-layer-DiarVGxh.js +392 -0
- tangram_core/dist-frontend/assets/solid-polygon-layer-DiarVGxh.js.map +1 -0
- tangram_core/dist-frontend/assets/tesselator-49Dw9L5A.js +2 -0
- tangram_core/dist-frontend/assets/tesselator-49Dw9L5A.js.map +1 -0
- tangram_core/dist-frontend/assets/webgl-developer-tools-CZl8qVFg.js +7 -0
- tangram_core/dist-frontend/assets/webgl-developer-tools-CZl8qVFg.js.map +1 -0
- tangram_core/dist-frontend/assets/webgl-device-BY0-CUP6.js +3 -0
- tangram_core/dist-frontend/assets/webgl-device-BY0-CUP6.js.map +1 -0
- tangram_core/dist-frontend/assets/widget-BbOeHGj0.js +2 -0
- tangram_core/dist-frontend/assets/widget-BbOeHGj0.js.map +1 -0
- tangram_core/dist-frontend/core.js +60 -0
- tangram_core/dist-frontend/core.js.map +1 -0
- tangram_core/dist-frontend/extensions.js +609 -0
- tangram_core/dist-frontend/extensions.js.map +1 -0
- tangram_core/dist-frontend/favicon.ico +0 -0
- tangram_core/dist-frontend/favicon.png +0 -0
- tangram_core/dist-frontend/font-awesome.min.css +4 -0
- tangram_core/dist-frontend/fonts/FontAwesome.otf +0 -0
- tangram_core/dist-frontend/fonts/fontawesome-webfont.eot +0 -0
- tangram_core/dist-frontend/fonts/fontawesome-webfont.svg +2671 -0
- tangram_core/dist-frontend/fonts/fontawesome-webfont.ttf +0 -0
- tangram_core/dist-frontend/fonts/fontawesome-webfont.woff +0 -0
- tangram_core/dist-frontend/fonts/fontawesome-webfont.woff2 +0 -0
- tangram_core/dist-frontend/geo-layers.js +115 -0
- tangram_core/dist-frontend/geo-layers.js.map +1 -0
- tangram_core/dist-frontend/index.html +38 -0
- tangram_core/dist-frontend/json.js +3 -0
- tangram_core/dist-frontend/json.js.map +1 -0
- tangram_core/dist-frontend/layers.js +268 -0
- tangram_core/dist-frontend/layers.js.map +1 -0
- tangram_core/dist-frontend/lit-html.js +7 -0
- tangram_core/dist-frontend/lit-html.js.map +1 -0
- tangram_core/dist-frontend/mapbox.js +2 -0
- tangram_core/dist-frontend/mapbox.js.map +1 -0
- tangram_core/dist-frontend/maplibre-gl.js +59 -0
- tangram_core/dist-frontend/maplibre-gl.js.map +1 -0
- tangram_core/dist-frontend/mesh-layers.js +2 -0
- tangram_core/dist-frontend/mesh-layers.js.map +1 -0
- tangram_core/dist-frontend/rs1090_wasm.js +813 -0
- tangram_core/dist-frontend/rs1090_wasm_bg.wasm +0 -0
- tangram_core/dist-frontend/vue.esm-browser.prod.js +13 -0
- tangram_core/dist-frontend/widgets.js +3 -0
- tangram_core/dist-frontend/widgets.js.map +1 -0
- tangram_core/main.ts +16 -0
- tangram_core/plugin.py +70 -0
- tangram_core/plugin.ts +41 -0
- tangram_core/redis.py +89 -0
- tangram_core/user.css +114 -0
- tangram_core/vite-plugin-tangram.mjs +88 -0
- tangram_core-0.2.0.dist-info/METADATA +37 -0
- tangram_core-0.2.0.dist-info/RECORD +171 -0
- tangram_core-0.2.0.dist-info/WHEEL +4 -0
- tangram_core-0.2.0.dist-info/entry_points.txt +2 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"mesh-layers-BSECKarm.js","sources":["../../../../../../node_modules/.pnpm/@loaders.gl+loader-utils@4.3.4_@loaders.gl+core@4.3.4/node_modules/@loaders.gl/loader-utils/dist/loader-types.js","../../../../../../node_modules/.pnpm/@loaders.gl+loader-utils@4.3.4_@loaders.gl+core@4.3.4/node_modules/@loaders.gl/loader-utils/dist/lib/module-utils/js-module-utils.js","../../../../../../node_modules/.pnpm/@loaders.gl+worker-utils@4.3.4_@loaders.gl+core@4.3.4/node_modules/@loaders.gl/worker-utils/dist/lib/library-utils/library-utils.js","../../../../../../node_modules/.pnpm/@loaders.gl+loader-utils@4.3.4_@loaders.gl+core@4.3.4/node_modules/@loaders.gl/loader-utils/dist/lib/binary-utils/get-first-characters.js","../../../../../../node_modules/.pnpm/@loaders.gl+loader-utils@4.3.4_@loaders.gl+core@4.3.4/node_modules/@loaders.gl/loader-utils/dist/lib/parser-utils/parse-json.js","../../../../../../node_modules/.pnpm/@loaders.gl+loader-utils@4.3.4_@loaders.gl+core@4.3.4/node_modules/@loaders.gl/loader-utils/dist/lib/binary-utils/memory-copy-utils.js","../../../../../../node_modules/.pnpm/@loaders.gl+schema@4.3.4_@loaders.gl+core@4.3.4/node_modules/@loaders.gl/schema/dist/lib/table/simple-table/data-type.js","../../../../../../node_modules/.pnpm/@loaders.gl+schema@4.3.4_@loaders.gl+core@4.3.4/node_modules/@loaders.gl/schema/dist/lib/mesh/mesh-utils.js","../../../../../../node_modules/.pnpm/@loaders.gl+schema@4.3.4_@loaders.gl+core@4.3.4/node_modules/@loaders.gl/schema/dist/lib/mesh/deduce-mesh-schema.js","../../../../../../node_modules/.pnpm/@loaders.gl+images@4.3.4_@loaders.gl+core@4.3.4/node_modules/@loaders.gl/images/dist/lib/category-api/image-format.js","../../../../../../node_modules/.pnpm/@math.gl+core@4.1.0/node_modules/@math.gl/core/dist/classes/vector4.js","../../../../../../node_modules/.pnpm/@math.gl+core@4.1.0/node_modules/@math.gl/core/dist/gl-matrix/mat3.js","../../../../../../node_modules/.pnpm/@math.gl+core@4.1.0/node_modules/@math.gl/core/dist/classes/matrix3.js","../../../../../../node_modules/.pnpm/@math.gl+core@4.1.0/node_modules/@math.gl/core/dist/gl-matrix/quat.js","../../../../../../node_modules/.pnpm/@math.gl+core@4.1.0/node_modules/@math.gl/core/dist/classes/quaternion.js","../../../../../../node_modules/.pnpm/@luma.gl+shadertools@9.2.4_@luma.gl+core@9.2.4/node_modules/@luma.gl/shadertools/dist/modules/lighting/pbr-material/pbr-material-glsl.js","../../../../../../node_modules/.pnpm/@luma.gl+shadertools@9.2.4_@luma.gl+core@9.2.4/node_modules/@luma.gl/shadertools/dist/modules/lighting/pbr-material/pbr-material-wgsl.js","../../../../../../node_modules/.pnpm/@luma.gl+shadertools@9.2.4_@luma.gl+core@9.2.4/node_modules/@luma.gl/shadertools/dist/modules/lighting/pbr-material/pbr-projection.js","../../../../../../node_modules/.pnpm/@luma.gl+shadertools@9.2.4_@luma.gl+core@9.2.4/node_modules/@luma.gl/shadertools/dist/modules/lighting/pbr-material/pbr-material.js","../../../../../../node_modules/.pnpm/@luma.gl+engine@9.2.4_@luma.gl+core@9.2.4_@luma.gl+shadertools@9.2.4_@luma.gl+core@9.2.4_/node_modules/@luma.gl/engine/dist/scenegraph/scenegraph-node.js","../../../../../../node_modules/.pnpm/@luma.gl+engine@9.2.4_@luma.gl+core@9.2.4_@luma.gl+shadertools@9.2.4_@luma.gl+core@9.2.4_/node_modules/@luma.gl/engine/dist/scenegraph/group-node.js","../../../../../../node_modules/.pnpm/@luma.gl+engine@9.2.4_@luma.gl+core@9.2.4_@luma.gl+shadertools@9.2.4_@luma.gl+core@9.2.4_/node_modules/@luma.gl/engine/dist/scenegraph/model-node.js","../../../../../../node_modules/.pnpm/@deck.gl+mesh-layers@9.2.2_@deck.gl+core@9.2.2_@loaders.gl+core@4.3.4_@luma.gl+core@9.2_0ff936c4a97c04ca2c286d691dfddb68/node_modules/@deck.gl/mesh-layers/dist/utils/matrix.js","../../../../../../node_modules/.pnpm/@deck.gl+mesh-layers@9.2.2_@deck.gl+core@9.2.2_@loaders.gl+core@4.3.4_@luma.gl+core@9.2_0ff936c4a97c04ca2c286d691dfddb68/node_modules/@deck.gl/mesh-layers/dist/simple-mesh-layer/simple-mesh-layer-uniforms.js","../../../../../../node_modules/.pnpm/@deck.gl+mesh-layers@9.2.2_@deck.gl+core@9.2.2_@loaders.gl+core@4.3.4_@luma.gl+core@9.2_0ff936c4a97c04ca2c286d691dfddb68/node_modules/@deck.gl/mesh-layers/dist/simple-mesh-layer/simple-mesh-layer-vertex.glsl.js","../../../../../../node_modules/.pnpm/@deck.gl+mesh-layers@9.2.2_@deck.gl+core@9.2.2_@loaders.gl+core@4.3.4_@luma.gl+core@9.2_0ff936c4a97c04ca2c286d691dfddb68/node_modules/@deck.gl/mesh-layers/dist/simple-mesh-layer/simple-mesh-layer-fragment.glsl.js","../../../../../../node_modules/.pnpm/@deck.gl+mesh-layers@9.2.2_@deck.gl+core@9.2.2_@loaders.gl+core@4.3.4_@luma.gl+core@9.2_0ff936c4a97c04ca2c286d691dfddb68/node_modules/@deck.gl/mesh-layers/dist/simple-mesh-layer/simple-mesh-layer.js","../../../../../../node_modules/.pnpm/@loaders.gl+textures@4.3.4_@loaders.gl+core@4.3.4/node_modules/@loaders.gl/textures/dist/lib/utils/version.js","../../../../../../node_modules/.pnpm/@loaders.gl+textures@4.3.4_@loaders.gl+core@4.3.4/node_modules/@loaders.gl/textures/dist/lib/parsers/basis-module-loader.js","../../../../../../node_modules/.pnpm/@loaders.gl+textures@4.3.4_@loaders.gl+core@4.3.4/node_modules/@loaders.gl/textures/dist/lib/gl-extensions.js","../../../../../../node_modules/.pnpm/@loaders.gl+textures@4.3.4_@loaders.gl+core@4.3.4/node_modules/@loaders.gl/textures/dist/lib/utils/texture-formats.js","../../../../../../node_modules/.pnpm/@loaders.gl+textures@4.3.4_@loaders.gl+core@4.3.4/node_modules/@loaders.gl/textures/dist/lib/parsers/parse-ktx.js","../../../../../../node_modules/.pnpm/@loaders.gl+textures@4.3.4_@loaders.gl+core@4.3.4/node_modules/@loaders.gl/textures/dist/lib/parsers/parse-basis.js","../../../../../../node_modules/.pnpm/@loaders.gl+textures@4.3.4_@loaders.gl+core@4.3.4/node_modules/@loaders.gl/textures/dist/basis-loader.js","../../../../../../node_modules/.pnpm/@luma.gl+gltf@9.2.4_@luma.gl+constants@9.2.4_@luma.gl+core@9.2.4_@luma.gl+engine@9.2.4__9b8012f70b84b144036e672059766688/node_modules/@luma.gl/gltf/dist/webgl-to-webgpu/convert-webgl-sampler.js","../../../../../../node_modules/.pnpm/@luma.gl+gltf@9.2.4_@luma.gl+constants@9.2.4_@luma.gl+core@9.2.4_@luma.gl+engine@9.2.4__9b8012f70b84b144036e672059766688/node_modules/@luma.gl/gltf/dist/parsers/parse-pbr-material.js","../../../../../../node_modules/.pnpm/@luma.gl+gltf@9.2.4_@luma.gl+constants@9.2.4_@luma.gl+core@9.2.4_@luma.gl+engine@9.2.4__9b8012f70b84b144036e672059766688/node_modules/@luma.gl/gltf/dist/webgl-to-webgpu/convert-webgl-topology.js","../../../../../../node_modules/.pnpm/@luma.gl+gltf@9.2.4_@luma.gl+constants@9.2.4_@luma.gl+core@9.2.4_@luma.gl+engine@9.2.4__9b8012f70b84b144036e672059766688/node_modules/@luma.gl/gltf/dist/gltf/create-gltf-model.js","../../../../../../node_modules/.pnpm/@luma.gl+gltf@9.2.4_@luma.gl+constants@9.2.4_@luma.gl+core@9.2.4_@luma.gl+engine@9.2.4__9b8012f70b84b144036e672059766688/node_modules/@luma.gl/gltf/dist/parsers/parse-gltf.js","../../../../../../node_modules/.pnpm/@luma.gl+gltf@9.2.4_@luma.gl+constants@9.2.4_@luma.gl+core@9.2.4_@luma.gl+engine@9.2.4__9b8012f70b84b144036e672059766688/node_modules/@luma.gl/gltf/dist/gltf/animations/interpolate.js","../../../../../../node_modules/.pnpm/@luma.gl+gltf@9.2.4_@luma.gl+constants@9.2.4_@luma.gl+core@9.2.4_@luma.gl+engine@9.2.4__9b8012f70b84b144036e672059766688/node_modules/@luma.gl/gltf/dist/gltf/gltf-animator.js","../../../../../../node_modules/.pnpm/@luma.gl+gltf@9.2.4_@luma.gl+constants@9.2.4_@luma.gl+core@9.2.4_@luma.gl+engine@9.2.4__9b8012f70b84b144036e672059766688/node_modules/@luma.gl/gltf/dist/webgl-to-webgpu/convert-webgl-attribute.js","../../../../../../node_modules/.pnpm/@luma.gl+gltf@9.2.4_@luma.gl+constants@9.2.4_@luma.gl+core@9.2.4_@luma.gl+engine@9.2.4__9b8012f70b84b144036e672059766688/node_modules/@luma.gl/gltf/dist/parsers/parse-gltf-animations.js","../../../../../../node_modules/.pnpm/@luma.gl+gltf@9.2.4_@luma.gl+constants@9.2.4_@luma.gl+core@9.2.4_@luma.gl+engine@9.2.4__9b8012f70b84b144036e672059766688/node_modules/@luma.gl/gltf/dist/utils/deep-copy.js","../../../../../../node_modules/.pnpm/@luma.gl+gltf@9.2.4_@luma.gl+constants@9.2.4_@luma.gl+core@9.2.4_@luma.gl+engine@9.2.4__9b8012f70b84b144036e672059766688/node_modules/@luma.gl/gltf/dist/gltf/create-scenegraph-from-gltf.js","../../../../../../node_modules/.pnpm/@loaders.gl+gltf@4.3.4_@loaders.gl+core@4.3.4/node_modules/@loaders.gl/gltf/dist/lib/utils/assert.js","../../../../../../node_modules/.pnpm/@loaders.gl+gltf@4.3.4_@loaders.gl+core@4.3.4/node_modules/@loaders.gl/gltf/dist/lib/gltf-utils/gltf-constants.js","../../../../../../node_modules/.pnpm/@loaders.gl+gltf@4.3.4_@loaders.gl+core@4.3.4/node_modules/@loaders.gl/gltf/dist/lib/gltf-utils/gltf-utils.js","../../../../../../node_modules/.pnpm/@loaders.gl+gltf@4.3.4_@loaders.gl+core@4.3.4/node_modules/@loaders.gl/gltf/dist/lib/gltf-utils/get-typed-array.js","../../../../../../node_modules/.pnpm/@loaders.gl+gltf@4.3.4_@loaders.gl+core@4.3.4/node_modules/@loaders.gl/gltf/dist/lib/api/gltf-scenegraph.js","../../../../../../node_modules/.pnpm/@loaders.gl+gltf@4.3.4_@loaders.gl+core@4.3.4/node_modules/@loaders.gl/gltf/dist/lib/extensions/utils/3d-tiles-utils.js","../../../../../../node_modules/.pnpm/@loaders.gl+gltf@4.3.4_@loaders.gl+core@4.3.4/node_modules/@loaders.gl/gltf/dist/lib/extensions/EXT_mesh_features.js","../../../../../../node_modules/.pnpm/@loaders.gl+gltf@4.3.4_@loaders.gl+core@4.3.4/node_modules/@loaders.gl/gltf/dist/lib/extensions/EXT_structural_metadata.js","../../../../../../node_modules/.pnpm/@loaders.gl+gltf@4.3.4_@loaders.gl+core@4.3.4/node_modules/@loaders.gl/gltf/dist/lib/extensions/deprecated/EXT_feature_metadata.js","../../../../../../node_modules/.pnpm/@loaders.gl+gltf@4.3.4_@loaders.gl+core@4.3.4/node_modules/@loaders.gl/gltf/dist/lib/utils/version.js","../../../../../../node_modules/.pnpm/@loaders.gl+gltf@4.3.4_@loaders.gl+core@4.3.4/node_modules/@loaders.gl/gltf/dist/lib/parsers/parse-glb.js","../../../../../../node_modules/.pnpm/@loaders.gl+gltf@4.3.4_@loaders.gl+core@4.3.4/node_modules/@loaders.gl/gltf/dist/lib/gltf-utils/resolve-url.js","../../../../../../node_modules/.pnpm/@loaders.gl+gltf@4.3.4_@loaders.gl+core@4.3.4/node_modules/@loaders.gl/gltf/dist/meshopt/meshopt-decoder.js","../../../../../../node_modules/.pnpm/@loaders.gl+gltf@4.3.4_@loaders.gl+core@4.3.4/node_modules/@loaders.gl/gltf/dist/lib/extensions/EXT_meshopt_compression.js","../../../../../../node_modules/.pnpm/@loaders.gl+gltf@4.3.4_@loaders.gl+core@4.3.4/node_modules/@loaders.gl/gltf/dist/lib/extensions/EXT_texture_webp.js","../../../../../../node_modules/.pnpm/@loaders.gl+gltf@4.3.4_@loaders.gl+core@4.3.4/node_modules/@loaders.gl/gltf/dist/lib/extensions/KHR_texture_basisu.js","../../../../../../node_modules/.pnpm/@loaders.gl+draco@4.3.4_@loaders.gl+core@4.3.4/node_modules/@loaders.gl/draco/dist/lib/utils/version.js","../../../../../../node_modules/.pnpm/@loaders.gl+draco@4.3.4_@loaders.gl+core@4.3.4/node_modules/@loaders.gl/draco/dist/draco-loader.js","../../../../../../node_modules/.pnpm/@loaders.gl+draco@4.3.4_@loaders.gl+core@4.3.4/node_modules/@loaders.gl/draco/dist/lib/utils/get-draco-schema.js","../../../../../../node_modules/.pnpm/@loaders.gl+draco@4.3.4_@loaders.gl+core@4.3.4/node_modules/@loaders.gl/draco/dist/lib/draco-parser.js","../../../../../../node_modules/.pnpm/@loaders.gl+draco@4.3.4_@loaders.gl+core@4.3.4/node_modules/@loaders.gl/draco/dist/lib/draco-module-loader.js","../../../../../../node_modules/.pnpm/@loaders.gl+draco@4.3.4_@loaders.gl+core@4.3.4/node_modules/@loaders.gl/draco/dist/index.js","../../../../../../node_modules/.pnpm/@loaders.gl+gltf@4.3.4_@loaders.gl+core@4.3.4/node_modules/@loaders.gl/gltf/dist/lib/gltf-utils/gltf-attribute-utils.js","../../../../../../node_modules/.pnpm/@loaders.gl+gltf@4.3.4_@loaders.gl+core@4.3.4/node_modules/@loaders.gl/gltf/dist/lib/extensions/KHR_draco_mesh_compression.js","../../../../../../node_modules/.pnpm/@loaders.gl+gltf@4.3.4_@loaders.gl+core@4.3.4/node_modules/@loaders.gl/gltf/dist/lib/extensions/KHR_texture_transform.js","../../../../../../node_modules/.pnpm/@loaders.gl+gltf@4.3.4_@loaders.gl+core@4.3.4/node_modules/@loaders.gl/gltf/dist/lib/extensions/deprecated/KHR_lights_punctual.js","../../../../../../node_modules/.pnpm/@loaders.gl+gltf@4.3.4_@loaders.gl+core@4.3.4/node_modules/@loaders.gl/gltf/dist/lib/extensions/deprecated/KHR_materials_unlit.js","../../../../../../node_modules/.pnpm/@loaders.gl+gltf@4.3.4_@loaders.gl+core@4.3.4/node_modules/@loaders.gl/gltf/dist/lib/extensions/deprecated/KHR_techniques_webgl.js","../../../../../../node_modules/.pnpm/@loaders.gl+gltf@4.3.4_@loaders.gl+core@4.3.4/node_modules/@loaders.gl/gltf/dist/lib/api/gltf-extensions.js","../../../../../../node_modules/.pnpm/@loaders.gl+gltf@4.3.4_@loaders.gl+core@4.3.4/node_modules/@loaders.gl/gltf/dist/lib/extensions/KHR_binary_gltf.js","../../../../../../node_modules/.pnpm/@loaders.gl+gltf@4.3.4_@loaders.gl+core@4.3.4/node_modules/@loaders.gl/gltf/dist/lib/api/normalize-gltf-v1.js","../../../../../../node_modules/.pnpm/@loaders.gl+gltf@4.3.4_@loaders.gl+core@4.3.4/node_modules/@loaders.gl/gltf/dist/lib/parsers/parse-gltf.js","../../../../../../node_modules/.pnpm/@loaders.gl+gltf@4.3.4_@loaders.gl+core@4.3.4/node_modules/@loaders.gl/gltf/dist/gltf-loader.js","../../../../../../node_modules/.pnpm/@loaders.gl+gltf@4.3.4_@loaders.gl+core@4.3.4/node_modules/@loaders.gl/gltf/dist/lib/api/post-process-gltf.js","../../../../../../node_modules/.pnpm/@deck.gl+mesh-layers@9.2.2_@deck.gl+core@9.2.2_@loaders.gl+core@4.3.4_@luma.gl+core@9.2_0ff936c4a97c04ca2c286d691dfddb68/node_modules/@deck.gl/mesh-layers/dist/scenegraph-layer/gltf-utils.js","../../../../../../node_modules/.pnpm/@deck.gl+mesh-layers@9.2.2_@deck.gl+core@9.2.2_@loaders.gl+core@4.3.4_@luma.gl+core@9.2_0ff936c4a97c04ca2c286d691dfddb68/node_modules/@deck.gl/mesh-layers/dist/scenegraph-layer/scenegraph-layer-uniforms.js","../../../../../../node_modules/.pnpm/@deck.gl+mesh-layers@9.2.2_@deck.gl+core@9.2.2_@loaders.gl+core@4.3.4_@luma.gl+core@9.2_0ff936c4a97c04ca2c286d691dfddb68/node_modules/@deck.gl/mesh-layers/dist/scenegraph-layer/scenegraph-layer-vertex.glsl.js","../../../../../../node_modules/.pnpm/@deck.gl+mesh-layers@9.2.2_@deck.gl+core@9.2.2_@loaders.gl+core@4.3.4_@luma.gl+core@9.2_0ff936c4a97c04ca2c286d691dfddb68/node_modules/@deck.gl/mesh-layers/dist/scenegraph-layer/scenegraph-layer-fragment.glsl.js","../../../../../../node_modules/.pnpm/@deck.gl+mesh-layers@9.2.2_@deck.gl+core@9.2.2_@loaders.gl+core@4.3.4_@luma.gl+core@9.2_0ff936c4a97c04ca2c286d691dfddb68/node_modules/@deck.gl/mesh-layers/dist/scenegraph-layer/scenegraph-layer.js"],"sourcesContent":["// loaders.gl\n// SPDX-License-Identifier: MIT\n// Copyright (c) vis.gl contributors\n/**\n * Parses `data` using a specified loader\n * @param data\n * @param loaders\n * @param options\n * @param context\n */\n// implementation signature\nexport async function parseFromContext(data, loaders, options, context) {\n return context._parse(data, loaders, options, context);\n}\n/**\n * Parses `data` synchronously using the specified loader, parse function provided via the loader context\n */\nexport function parseSyncFromContext(data, loader, options, context) {\n if (!context._parseSync) {\n throw new Error('parseSync');\n }\n return context._parseSync(data, loader, options, context);\n}\n/**\n * Parses `data` synchronously using a specified loader, parse function provided via the loader context\n */\nexport async function parseInBatchesFromContext(data, loader, options, context) {\n if (!context._parseInBatches) {\n throw new Error('parseInBatches');\n }\n return context._parseInBatches(data, loader, options, context);\n}\n","// loaders.gl\n// SPDX-License-Identifier: MIT\n// Copyright (c) vis.gl contributors\nimport { log } from \"../log-utils/log.js\";\n/**\n * Register application-imported modules\n * These modules are typically to big to bundle, or may have issues on some bundlers/environments\n */\nexport function registerJSModules(modules) {\n globalThis.loaders ||= {};\n globalThis.loaders.modules ||= {};\n Object.assign(globalThis.loaders.modules, modules);\n}\n/**\n * Get a pre-registered application-imported module, warn if not present\n */\nexport function checkJSModule(name, caller) {\n const module = globalThis.loaders?.modules?.[name];\n if (!module) {\n log.warn(`${caller}: ${name} library not installed`)();\n }\n}\n/**\n * Get a pre-registered application-imported module, throw if not present\n */\nexport function getJSModule(name, caller) {\n const module = globalThis.loaders?.modules?.[name];\n if (!module) {\n throw new Error(`${caller}: ${name} library not installed`);\n }\n return module;\n}\n/**\n * Get a pre-registered application-imported module, return null if not present\n */\nexport function getJSModuleOrNull(name) {\n const module = globalThis.loaders?.modules?.[name];\n return module || null;\n}\n","// loaders.gl\n// SPDX-License-Identifier: MIT\n// Copyright (c) vis.gl contributors\n/* global importScripts */\nimport { isBrowser, isWorker } from \"../env-utils/globals.js\";\nimport { assert } from \"../env-utils/assert.js\";\nimport { VERSION } from \"../env-utils/version.js\";\nconst loadLibraryPromises = {}; // promises\n/**\n * Dynamically loads a library (\"module\")\n *\n * - wasm library: Array buffer is returned\n * - js library: Parse JS is returned\n *\n * Method depends on environment\n * - browser - script element is created and installed on document\n * - worker - eval is called on global context\n * - node - file is required\n *\n * @param libraryUrl\n * @param moduleName\n * @param options\n */\nexport async function loadLibrary(libraryUrl, moduleName = null, options = {}, libraryName = null) {\n if (moduleName) {\n libraryUrl = getLibraryUrl(libraryUrl, moduleName, options, libraryName);\n }\n // Ensure libraries are only loaded once\n loadLibraryPromises[libraryUrl] =\n // eslint-disable-next-line @typescript-eslint/no-misused-promises\n loadLibraryPromises[libraryUrl] || loadLibraryFromFile(libraryUrl);\n return await loadLibraryPromises[libraryUrl];\n}\n// TODO - sort out how to resolve paths for main/worker and dev/prod\nexport function getLibraryUrl(library, moduleName, options = {}, libraryName = null) {\n // Check if already a URL\n if (!options.useLocalLibraries && library.startsWith('http')) {\n return library;\n }\n libraryName = libraryName || library;\n // Allow application to import and supply libraries through `options.modules`\n // TODO - See js-module-utils in loader-utils\n const modules = options.modules || {};\n if (modules[libraryName]) {\n return modules[libraryName];\n }\n // Load from local files, not from CDN scripts in Node.js\n // TODO - needs to locate the modules directory when installed!\n if (!isBrowser) {\n return `modules/${moduleName}/dist/libs/${libraryName}`;\n }\n // In browser, load from external scripts\n if (options.CDN) {\n assert(options.CDN.startsWith('http'));\n return `${options.CDN}/${moduleName}@${VERSION}/dist/libs/${libraryName}`;\n }\n // TODO - loading inside workers requires paths relative to worker script location...\n if (isWorker) {\n return `../src/libs/${libraryName}`;\n }\n return `modules/${moduleName}/src/libs/${libraryName}`;\n}\nasync function loadLibraryFromFile(libraryUrl) {\n if (libraryUrl.endsWith('wasm')) {\n return await loadAsArrayBuffer(libraryUrl);\n }\n if (!isBrowser) {\n // TODO - Node doesn't yet support dynamic import from https URLs\n // try {\n // return await import(libraryUrl);\n // } catch (error) {\n // console.error(error);\n // }\n try {\n const { requireFromFile } = globalThis.loaders || {};\n return await requireFromFile?.(libraryUrl);\n }\n catch (error) {\n console.error(error); // eslint-disable-line no-console\n return null;\n }\n }\n if (isWorker) {\n return importScripts(libraryUrl);\n }\n // TODO - fix - should be more secure than string parsing since observes CORS\n // if (isBrowser) {\n // return await loadScriptFromFile(libraryUrl);\n // }\n const scriptSource = await loadAsText(libraryUrl);\n return loadLibraryFromString(scriptSource, libraryUrl);\n}\n/*\nasync function loadScriptFromFile(libraryUrl) {\n const script = document.createElement('script');\n script.src = libraryUrl;\n return await new Promise((resolve, reject) => {\n script.onload = data => {\n resolve(data);\n };\n script.onerror = reject;\n });\n}\n*/\n// TODO - Needs security audit...\n// - Raw eval call\n// - Potentially bypasses CORS\n// Upside is that this separates fetching and parsing\n// we could create a`LibraryLoader` or`ModuleLoader`\nfunction loadLibraryFromString(scriptSource, id) {\n if (!isBrowser) {\n const { requireFromString } = globalThis.loaders || {};\n return requireFromString?.(scriptSource, id);\n }\n if (isWorker) {\n // Use lvalue trick to make eval run in global scope\n eval.call(globalThis, scriptSource); // eslint-disable-line no-eval\n // https://stackoverflow.com/questions/9107240/1-evalthis-vs-evalthis-in-javascript\n // http://perfectionkills.com/global-eval-what-are-the-options/\n return null;\n }\n const script = document.createElement('script');\n script.id = id;\n // most browsers like a separate text node but some throw an error. The second method covers those.\n try {\n script.appendChild(document.createTextNode(scriptSource));\n }\n catch (e) {\n script.text = scriptSource;\n }\n document.body.appendChild(script);\n return null;\n}\n// TODO - technique for module injection into worker, from THREE.DracoLoader...\n/*\nfunction combineWorkerWithLibrary(worker, jsContent) {\n var fn = wWorker.toString();\n var body = [\n '// injected',\n jsContent,\n '',\n '// worker',\n fn.substring(fn.indexOf('{') + 1, fn.lastIndexOf('}'))\n ].join('\\n');\n this.workerSourceURL = URL.createObjectURL(new Blob([body]));\n}\n*/\nasync function loadAsArrayBuffer(url) {\n const { readFileAsArrayBuffer } = globalThis.loaders || {};\n if (isBrowser || !readFileAsArrayBuffer || url.startsWith('http')) {\n const response = await fetch(url);\n return await response.arrayBuffer();\n }\n return await readFileAsArrayBuffer(url);\n}\n/**\n * Load a file from local file system\n * @param filename\n * @returns\n */\nasync function loadAsText(url) {\n const { readFileAsText } = globalThis.loaders || {};\n if (isBrowser || !readFileAsText || url.startsWith('http')) {\n const response = await fetch(url);\n return await response.text();\n }\n return await readFileAsText(url);\n}\n","// loaders.gl\n// SPDX-License-Identifier: MIT\n// Copyright (c) vis.gl contributors\n/**\n * Get the first characters from a binary file (interpret the first bytes as an ASCII string)\n * @param data\n * @param length\n * @returns\n */\nexport function getFirstCharacters(data, length = 5) {\n if (typeof data === 'string') {\n return data.slice(0, length);\n }\n else if (ArrayBuffer.isView(data)) {\n // Typed Arrays can have offsets into underlying buffer\n return getMagicString(data.buffer, data.byteOffset, length);\n }\n else if (data instanceof ArrayBuffer) {\n const byteOffset = 0;\n return getMagicString(data, byteOffset, length);\n }\n return '';\n}\n/**\n * Gets a magic string from a \"file\"\n * Typically used to check or detect file format\n * @param arrayBuffer\n * @param byteOffset\n * @param length\n * @returns\n */\nexport function getMagicString(arrayBuffer, byteOffset, length) {\n if (arrayBuffer.byteLength <= byteOffset + length) {\n return '';\n }\n const dataView = new DataView(arrayBuffer);\n let magic = '';\n for (let i = 0; i < length; i++) {\n magic += String.fromCharCode(dataView.getUint8(byteOffset + i));\n }\n return magic;\n}\n","import { getFirstCharacters } from \"../binary-utils/get-first-characters.js\";\n/**\n * Minimal JSON parser that throws more meaningful error messages\n */\nexport function parseJSON(string) {\n try {\n return JSON.parse(string);\n }\n catch (_) {\n throw new Error(`Failed to parse JSON from data starting with \"${getFirstCharacters(string)}\"`);\n }\n}\n","import { assert } from \"../env-utils/assert.js\";\n/**\n * Calculate new size of an arrayBuffer to be aligned to an n-byte boundary\n * This function increases `byteLength` by the minimum delta,\n * allowing the total length to be divided by `padding`\n * @param byteLength\n * @param padding\n */\nexport function padToNBytes(byteLength, padding) {\n assert(byteLength >= 0); // `Incorrect 'byteLength' value: ${byteLength}`\n assert(padding > 0); // `Incorrect 'padding' value: ${padding}`\n return (byteLength + (padding - 1)) & ~(padding - 1);\n}\n/**\n * Creates a new Uint8Array based on two different ArrayBuffers\n * @param targetBuffer The first buffer.\n * @param sourceBuffer The second buffer.\n * @return The new ArrayBuffer created out of the two.\n */\nexport function copyArrayBuffer(targetBuffer, sourceBuffer, byteOffset, byteLength = sourceBuffer.byteLength) {\n const targetArray = new Uint8Array(targetBuffer, byteOffset, byteLength);\n const sourceArray = new Uint8Array(sourceBuffer);\n targetArray.set(sourceArray);\n return targetBuffer;\n}\n/**\n * Copy from source to target at the targetOffset\n *\n * @param source - The data to copy\n * @param target - The destination to copy data into\n * @param targetOffset - The start offset into target to place the copied data\n * @returns the new offset taking into account proper padding\n */\nexport function copyToArray(source, target, targetOffset) {\n let sourceArray;\n if (source instanceof ArrayBuffer) {\n sourceArray = new Uint8Array(source);\n }\n else {\n // Pack buffer onto the big target array\n //\n // 'source.data.buffer' could be a view onto a larger buffer.\n // We MUST use this constructor to ensure the byteOffset and byteLength is\n // set to correct values from 'source.data' and not the underlying\n // buffer for target.set() to work properly.\n const srcByteOffset = source.byteOffset;\n const srcByteLength = source.byteLength;\n // In gltf parser it is set as \"arrayBuffer\" instead of \"buffer\"\n // https://github.com/visgl/loaders.gl/blob/1e3a82a0a65d7b6a67b1e60633453e5edda2960a/modules/gltf/src/lib/parse-gltf.js#L85\n sourceArray = new Uint8Array(source.buffer || source.arrayBuffer, srcByteOffset, srcByteLength);\n }\n // Pack buffer onto the big target array\n target.set(sourceArray, targetOffset);\n return targetOffset + padToNBytes(sourceArray.byteLength, 4);\n}\n","// loaders.gl\n// SPDX-License-Identifier: MIT\n// Copyright (c) vis.gl contributors\n/** Deduce column types from values */\nexport function getDataTypeFromValue(value, defaultNumberType = 'float32') {\n if (value instanceof Date) {\n return 'date-millisecond';\n }\n if (value instanceof Number) {\n return defaultNumberType;\n }\n if (typeof value === 'string') {\n return 'utf8';\n }\n if (value === null || value === 'undefined') {\n return 'null';\n }\n return 'null';\n}\n/**\n * Deduces a simple data type \"descriptor from a typed array instance\n */\nexport function getDataTypeFromArray(array) {\n let type = getDataTypeFromTypedArray(array);\n if (type !== 'null') {\n return { type, nullable: false };\n }\n if (array.length > 0) {\n type = getDataTypeFromValue(array[0]);\n return { type, nullable: true };\n }\n return { type: 'null', nullable: true };\n}\n/**\n * Deduces a simple data type \"descriptor from a typed array instance\n */\nexport function getDataTypeFromTypedArray(array) {\n switch (array.constructor) {\n case Int8Array:\n return 'int8';\n case Uint8Array:\n case Uint8ClampedArray:\n return 'uint8';\n case Int16Array:\n return 'int16';\n case Uint16Array:\n return 'uint16';\n case Int32Array:\n return 'int32';\n case Uint32Array:\n return 'uint32';\n case Float32Array:\n return 'float32';\n case Float64Array:\n return 'float64';\n default:\n return 'null';\n }\n}\nexport function getArrayTypeFromDataType(type, nullable) {\n if (!nullable) {\n switch (type) {\n case 'int8':\n return Int8Array;\n case 'uint8':\n return Uint8Array;\n case 'int16':\n return Int16Array;\n case 'uint16':\n return Uint16Array;\n case 'int32':\n return Int32Array;\n case 'uint32':\n return Uint32Array;\n case 'float32':\n return Float32Array;\n case 'float64':\n return Float64Array;\n default:\n break;\n }\n }\n // if (typeof BigInt64Array !== 'undefined') {\n // TYPED_ARRAY_TO_TYPE.BigInt64Array = new Int64();\n // TYPED_ARRAY_TO_TYPE.BigUint64Array = new Uint64();\n // }\n return Array;\n}\n","/**\n * Get number of vertices in mesh\n * @param attributes\n */\nexport function getMeshSize(attributes) {\n let size = 0;\n for (const attributeName in attributes) {\n const attribute = attributes[attributeName];\n if (ArrayBuffer.isView(attribute)) {\n // @ts-ignore DataView doesn't have BYTES_PER_ELEMENT\n size += attribute.byteLength * attribute.BYTES_PER_ELEMENT;\n }\n }\n return size;\n}\n/**\n * Get the (axis aligned) bounding box of a mesh\n * @param attributes\n * @returns array of two vectors representing the axis aligned bounding box\n */\n// eslint-disable-next-line complexity\nexport function getMeshBoundingBox(attributes) {\n let minX = Infinity;\n let minY = Infinity;\n let minZ = Infinity;\n let maxX = -Infinity;\n let maxY = -Infinity;\n let maxZ = -Infinity;\n const positions = attributes.POSITION ? attributes.POSITION.value : [];\n const len = positions && positions.length;\n for (let i = 0; i < len; i += 3) {\n const x = positions[i];\n const y = positions[i + 1];\n const z = positions[i + 2];\n minX = x < minX ? x : minX;\n minY = y < minY ? y : minY;\n minZ = z < minZ ? z : minZ;\n maxX = x > maxX ? x : maxX;\n maxY = y > maxY ? y : maxY;\n maxZ = z > maxZ ? z : maxZ;\n }\n return [\n [minX, minY, minZ],\n [maxX, maxY, maxZ]\n ];\n}\n","// loaders.gl\n// SPDX-License-Identifier: MIT\n// Copyright (c) vis.gl contributors\nimport { getDataTypeFromTypedArray } from \"../table/simple-table/data-type.js\";\n/**\n * Create a schema for mesh attributes data\n * @param attributes\n * @param metadata\n * @returns\n */\nexport function deduceMeshSchema(attributes, metadata = {}) {\n const fields = deduceMeshFields(attributes);\n return { fields, metadata };\n}\n/**\n * Create arrow-like schema field for mesh attribute\n * @param attributeName\n * @param attribute\n * @param optionalMetadata\n * @returns\n */\nexport function deduceMeshField(name, attribute, optionalMetadata) {\n const type = getDataTypeFromTypedArray(attribute.value);\n const metadata = optionalMetadata ? optionalMetadata : makeMeshAttributeMetadata(attribute);\n return {\n name,\n type: { type: 'fixed-size-list', listSize: attribute.size, children: [{ name: 'value', type }] },\n nullable: false,\n metadata\n };\n}\n/**\n * Create fields array for mesh attributes\n * @param attributes\n * @returns\n */\nfunction deduceMeshFields(attributes) {\n const fields = [];\n for (const attributeName in attributes) {\n const attribute = attributes[attributeName];\n fields.push(deduceMeshField(attributeName, attribute));\n }\n return fields;\n}\n/**\n * Make metadata by mesh attribute properties\n * @param attribute\n * @returns\n */\nexport function makeMeshAttributeMetadata(attribute) {\n const result = {};\n if ('byteOffset' in attribute) {\n result.byteOffset = attribute.byteOffset.toString(10);\n }\n if ('byteStride' in attribute) {\n result.byteStride = attribute.byteStride.toString(10);\n }\n if ('normalized' in attribute) {\n result.normalized = attribute.normalized.toString();\n }\n return result;\n}\n","// loaders.gl\n// SPDX-License-Identifier: MIT\n// Copyright (c) vis.gl contributors\nimport { isBrowser } from '@loaders.gl/loader-utils';\nconst MIME_TYPES = [\n 'image/png',\n 'image/jpeg',\n 'image/gif',\n 'image/webp',\n 'image/avif',\n 'image/tiff',\n // TODO - what is the correct type for SVG\n 'image/svg',\n 'image/svg+xml',\n 'image/bmp',\n 'image/vnd.microsoft.icon'\n];\n/** Only one round of tests is performed */\nconst mimeTypeSupportedPromise = null;\n/** Run-time browser detection of file formats requires async tests for most precise results */\nexport async function getSupportedImageFormats() {\n if (mimeTypeSupportedPromise) {\n return await mimeTypeSupportedPromise;\n }\n const supportedMimeTypes = new Set();\n for (const mimeType of MIME_TYPES) {\n const supported = isBrowser\n ? await checkBrowserImageFormatSupportAsync(mimeType)\n : checkNodeImageFormatSupport(mimeType);\n if (supported) {\n supportedMimeTypes.add(mimeType);\n }\n }\n return supportedMimeTypes;\n}\n/** Cache sync values for speed */\nconst mimeTypeSupportedSync = {};\n/**\n * Check if image MIME type is supported. Result is cached to avoid repeated tests.\n */\nexport function isImageFormatSupported(mimeType) {\n if (mimeTypeSupportedSync[mimeType] === undefined) {\n const supported = isBrowser\n ? checkBrowserImageFormatSupport(mimeType)\n : checkNodeImageFormatSupport(mimeType);\n mimeTypeSupportedSync[mimeType] = supported;\n }\n return mimeTypeSupportedSync[mimeType];\n}\n/**\n * Checks that polyfills are installed and that mimeType is supported by polyfills\n * @todo Ideally polyfills should declare what formats they support, instead of storing that data here.\n */\nfunction checkNodeImageFormatSupport(mimeType) {\n const NODE_FORMAT_SUPPORT = ['image/png', 'image/jpeg', 'image/gif'];\n const imageFormatsNode = globalThis.loaders?.imageFormatsNode || NODE_FORMAT_SUPPORT;\n const parseImageNode = globalThis.loaders?.parseImageNode;\n return Boolean(parseImageNode) && imageFormatsNode.includes(mimeType);\n}\n/** Checks image format support synchronously.\n * @note Unreliable, fails on AVIF\n */\nfunction checkBrowserImageFormatSupport(mimeType) {\n switch (mimeType) {\n case 'image/avif': // Will fail\n case 'image/webp':\n return testBrowserImageFormatSupport(mimeType);\n default:\n return true;\n }\n}\nconst TEST_IMAGE = {\n 'image/avif': '',\n // Lossy test image. Support for lossy images doesn't guarantee support for all WebP images.\n 'image/webp': ''\n};\n/** Checks WebP and AVIF support asynchronously */\nasync function checkBrowserImageFormatSupportAsync(mimeType) {\n const dataURL = TEST_IMAGE[mimeType];\n return dataURL ? await testBrowserImageFormatSupportAsync(dataURL) : true;\n}\n/**\n * Checks browser synchronously\n * Checks if toDataURL supports the mimeType.\n * @note Imperfect testOn Chrome this is true for WebP but not for AVIF\n */\nfunction testBrowserImageFormatSupport(mimeType) {\n try {\n const element = document.createElement('canvas');\n const dataURL = element.toDataURL(mimeType);\n return dataURL.indexOf(`data:${mimeType}`) === 0;\n }\n catch {\n // Probably Safari...\n return false;\n }\n}\n// Check WebPSupport asynchronously\nasync function testBrowserImageFormatSupportAsync(testImageDataURL) {\n return new Promise((resolve) => {\n const image = new Image();\n image.src = testImageDataURL;\n image.onload = () => resolve(image.height > 0);\n image.onerror = () => resolve(false);\n });\n}\n","// math.gl\n// SPDX-License-Identifier: MIT\n// Copyright (c) vis.gl contributors\n// Copyright (c) 2017 Uber Technologies, Inc.\n/* eslint-disable camelcase */\nimport { transformMat4 as vec4_transformMat4, transformQuat as vec4_transformQuat } from \"../gl-matrix/vec3.js\";\nimport { vec4_transformMat2, vec4_transformMat3 } from \"../lib/gl-matrix-extras.js\";\nimport { Vector } from \"./base/vector.js\";\nimport { config, isArray } from \"../lib/common.js\";\nimport { checkNumber } from \"../lib/validators.js\";\nlet ZERO;\n/**\n * Four-element vector class with common linear algebra operations.\n * Subclass of Array<number> meaning that it is highly compatible with other libraries\n */\nexport class Vector4 extends Vector {\n static get ZERO() {\n if (!ZERO) {\n ZERO = new Vector4(0, 0, 0, 0);\n Object.freeze(ZERO);\n }\n return ZERO;\n }\n constructor(x = 0, y = 0, z = 0, w = 0) {\n // PERF NOTE: initialize elements as double precision numbers\n super(-0, -0, -0, -0);\n if (isArray(x) && arguments.length === 1) {\n this.copy(x);\n }\n else {\n // this.set(x, y, z, w);\n if (config.debug) {\n checkNumber(x);\n checkNumber(y);\n checkNumber(z);\n checkNumber(w);\n }\n this[0] = x;\n this[1] = y;\n this[2] = z;\n this[3] = w;\n }\n }\n set(x, y, z, w) {\n this[0] = x;\n this[1] = y;\n this[2] = z;\n this[3] = w;\n return this.check();\n }\n copy(array) {\n this[0] = array[0];\n this[1] = array[1];\n this[2] = array[2];\n this[3] = array[3];\n return this.check();\n }\n fromObject(object) {\n if (config.debug) {\n checkNumber(object.x);\n checkNumber(object.y);\n checkNumber(object.z);\n checkNumber(object.w);\n }\n this[0] = object.x;\n this[1] = object.y;\n this[2] = object.z;\n this[3] = object.w;\n return this;\n }\n toObject(object) {\n object.x = this[0];\n object.y = this[1];\n object.z = this[2];\n object.w = this[3];\n return object;\n }\n // Getters/setters\n /* eslint-disable no-multi-spaces, brace-style, no-return-assign */\n get ELEMENTS() {\n return 4;\n }\n get z() {\n return this[2];\n }\n set z(value) {\n this[2] = checkNumber(value);\n }\n get w() {\n return this[3];\n }\n set w(value) {\n this[3] = checkNumber(value);\n }\n transform(matrix4) {\n vec4_transformMat4(this, this, matrix4);\n return this.check();\n }\n transformByMatrix3(matrix3) {\n vec4_transformMat3(this, this, matrix3);\n return this.check();\n }\n transformByMatrix2(matrix2) {\n vec4_transformMat2(this, this, matrix2);\n return this.check();\n }\n transformByQuaternion(quaternion) {\n vec4_transformQuat(this, this, quaternion);\n return this.check();\n }\n // three.js compatibility\n applyMatrix4(m) {\n m.transform(this, this);\n return this;\n }\n}\n//# sourceMappingURL=vector4.js.map","import * as glMatrix from './common.js';\n/**\n * 3x3 Matrix\n * @module mat3\n */\n/**\n * Creates a new identity mat3\n *\n * @returns {mat3} a new 3x3 matrix\n */\nexport function create() {\n const out = new glMatrix.ARRAY_TYPE(9);\n if (glMatrix.ARRAY_TYPE != Float32Array) {\n out[1] = 0;\n out[2] = 0;\n out[3] = 0;\n out[5] = 0;\n out[6] = 0;\n out[7] = 0;\n }\n out[0] = 1;\n out[4] = 1;\n out[8] = 1;\n return out;\n}\n/**\n * Copies the upper-left 3x3 values into the given mat3.\n *\n * @param {mat3} out the receiving 3x3 matrix\n * @param {ReadonlyMat4} a the source 4x4 matrix\n * @returns {mat3} out\n */\nexport function fromMat4(out, a) {\n out[0] = a[0];\n out[1] = a[1];\n out[2] = a[2];\n out[3] = a[4];\n out[4] = a[5];\n out[5] = a[6];\n out[6] = a[8];\n out[7] = a[9];\n out[8] = a[10];\n return out;\n}\n/**\n * Creates a new mat3 initialized with values from an existing matrix\n *\n * @param {ReadonlyMat3} a matrix to clone\n * @returns {mat3} a new 3x3 matrix\n */\nexport function clone(a) {\n const out = new glMatrix.ARRAY_TYPE(9);\n out[0] = a[0];\n out[1] = a[1];\n out[2] = a[2];\n out[3] = a[3];\n out[4] = a[4];\n out[5] = a[5];\n out[6] = a[6];\n out[7] = a[7];\n out[8] = a[8];\n return out;\n}\n/**\n * Copy the values from one mat3 to another\n *\n * @param {mat3} out the receiving matrix\n * @param {ReadonlyMat3} a the source matrix\n * @returns {mat3} out\n */\nexport function copy(out, a) {\n out[0] = a[0];\n out[1] = a[1];\n out[2] = a[2];\n out[3] = a[3];\n out[4] = a[4];\n out[5] = a[5];\n out[6] = a[6];\n out[7] = a[7];\n out[8] = a[8];\n return out;\n}\n/**\n * Create a new mat3 with the given values\n *\n * @param {Number} m00 Component in column 0, row 0 position (index 0)\n * @param {Number} m01 Component in column 0, row 1 position (index 1)\n * @param {Number} m02 Component in column 0, row 2 position (index 2)\n * @param {Number} m10 Component in column 1, row 0 position (index 3)\n * @param {Number} m11 Component in column 1, row 1 position (index 4)\n * @param {Number} m12 Component in column 1, row 2 position (index 5)\n * @param {Number} m20 Component in column 2, row 0 position (index 6)\n * @param {Number} m21 Component in column 2, row 1 position (index 7)\n * @param {Number} m22 Component in column 2, row 2 position (index 8)\n * @returns {mat3} A new mat3\n */\nexport function fromValues(m00, m01, m02, m10, m11, m12, m20, m21, m22) {\n const out = new glMatrix.ARRAY_TYPE(9);\n out[0] = m00;\n out[1] = m01;\n out[2] = m02;\n out[3] = m10;\n out[4] = m11;\n out[5] = m12;\n out[6] = m20;\n out[7] = m21;\n out[8] = m22;\n return out;\n}\n/**\n * Set the components of a mat3 to the given values\n *\n * @param {mat3} out the receiving matrix\n * @param {Number} m00 Component in column 0, row 0 position (index 0)\n * @param {Number} m01 Component in column 0, row 1 position (index 1)\n * @param {Number} m02 Component in column 0, row 2 position (index 2)\n * @param {Number} m10 Component in column 1, row 0 position (index 3)\n * @param {Number} m11 Component in column 1, row 1 position (index 4)\n * @param {Number} m12 Component in column 1, row 2 position (index 5)\n * @param {Number} m20 Component in column 2, row 0 position (index 6)\n * @param {Number} m21 Component in column 2, row 1 position (index 7)\n * @param {Number} m22 Component in column 2, row 2 position (index 8)\n * @returns {mat3} out\n */\nexport function set(out, m00, m01, m02, m10, m11, m12, m20, m21, m22) {\n out[0] = m00;\n out[1] = m01;\n out[2] = m02;\n out[3] = m10;\n out[4] = m11;\n out[5] = m12;\n out[6] = m20;\n out[7] = m21;\n out[8] = m22;\n return out;\n}\n/**\n * Set a mat3 to the identity matrix\n *\n * @param {mat3} out the receiving matrix\n * @returns {mat3} out\n */\nexport function identity(out) {\n out[0] = 1;\n out[1] = 0;\n out[2] = 0;\n out[3] = 0;\n out[4] = 1;\n out[5] = 0;\n out[6] = 0;\n out[7] = 0;\n out[8] = 1;\n return out;\n}\n/**\n * Transpose the values of a mat3\n *\n * @param {mat3} out the receiving matrix\n * @param {ReadonlyMat3} a the source matrix\n * @returns {mat3} out\n */\nexport function transpose(out, a) {\n // If we are transposing ourselves we can skip a few steps but have to cache some values\n if (out === a) {\n const a01 = a[1];\n const a02 = a[2];\n const a12 = a[5];\n out[1] = a[3];\n out[2] = a[6];\n out[3] = a01;\n out[5] = a[7];\n out[6] = a02;\n out[7] = a12;\n }\n else {\n out[0] = a[0];\n out[1] = a[3];\n out[2] = a[6];\n out[3] = a[1];\n out[4] = a[4];\n out[5] = a[7];\n out[6] = a[2];\n out[7] = a[5];\n out[8] = a[8];\n }\n return out;\n}\n/**\n * Inverts a mat3\n *\n * @param {mat3} out the receiving matrix\n * @param {ReadonlyMat3} a the source matrix\n * @returns {mat3} out\n */\nexport function invert(out, a) {\n const a00 = a[0];\n const a01 = a[1];\n const a02 = a[2];\n const a10 = a[3];\n const a11 = a[4];\n const a12 = a[5];\n const a20 = a[6];\n const a21 = a[7];\n const a22 = a[8];\n const b01 = a22 * a11 - a12 * a21;\n const b11 = -a22 * a10 + a12 * a20;\n const b21 = a21 * a10 - a11 * a20;\n // Calculate the determinant\n let det = a00 * b01 + a01 * b11 + a02 * b21;\n if (!det) {\n return null;\n }\n det = 1.0 / det;\n out[0] = b01 * det;\n out[1] = (-a22 * a01 + a02 * a21) * det;\n out[2] = (a12 * a01 - a02 * a11) * det;\n out[3] = b11 * det;\n out[4] = (a22 * a00 - a02 * a20) * det;\n out[5] = (-a12 * a00 + a02 * a10) * det;\n out[6] = b21 * det;\n out[7] = (-a21 * a00 + a01 * a20) * det;\n out[8] = (a11 * a00 - a01 * a10) * det;\n return out;\n}\n/**\n * Calculates the adjugate of a mat3\n *\n * @param {mat3} out the receiving matrix\n * @param {ReadonlyMat3} a the source matrix\n * @returns {mat3} out\n */\nexport function adjoint(out, a) {\n const a00 = a[0];\n const a01 = a[1];\n const a02 = a[2];\n const a10 = a[3];\n const a11 = a[4];\n const a12 = a[5];\n const a20 = a[6];\n const a21 = a[7];\n const a22 = a[8];\n out[0] = a11 * a22 - a12 * a21;\n out[1] = a02 * a21 - a01 * a22;\n out[2] = a01 * a12 - a02 * a11;\n out[3] = a12 * a20 - a10 * a22;\n out[4] = a00 * a22 - a02 * a20;\n out[5] = a02 * a10 - a00 * a12;\n out[6] = a10 * a21 - a11 * a20;\n out[7] = a01 * a20 - a00 * a21;\n out[8] = a00 * a11 - a01 * a10;\n return out;\n}\n/**\n * Calculates the determinant of a mat3\n *\n * @param {ReadonlyMat3} a the source matrix\n * @returns {Number} determinant of a\n */\nexport function determinant(a) {\n const a00 = a[0];\n const a01 = a[1];\n const a02 = a[2];\n const a10 = a[3];\n const a11 = a[4];\n const a12 = a[5];\n const a20 = a[6];\n const a21 = a[7];\n const a22 = a[8];\n return (a00 * (a22 * a11 - a12 * a21) + a01 * (-a22 * a10 + a12 * a20) + a02 * (a21 * a10 - a11 * a20));\n}\n/**\n * Multiplies two mat3's\n *\n * @param {mat3} out the receiving matrix\n * @param {ReadonlyMat3} a the first operand\n * @param {ReadonlyMat3} b the second operand\n * @returns {mat3} out\n */\nexport function multiply(out, a, b) {\n const a00 = a[0];\n const a01 = a[1];\n const a02 = a[2];\n const a10 = a[3];\n const a11 = a[4];\n const a12 = a[5];\n const a20 = a[6];\n const a21 = a[7];\n const a22 = a[8];\n const b00 = b[0];\n const b01 = b[1];\n const b02 = b[2];\n const b10 = b[3];\n const b11 = b[4];\n const b12 = b[5];\n const b20 = b[6];\n const b21 = b[7];\n const b22 = b[8];\n out[0] = b00 * a00 + b01 * a10 + b02 * a20;\n out[1] = b00 * a01 + b01 * a11 + b02 * a21;\n out[2] = b00 * a02 + b01 * a12 + b02 * a22;\n out[3] = b10 * a00 + b11 * a10 + b12 * a20;\n out[4] = b10 * a01 + b11 * a11 + b12 * a21;\n out[5] = b10 * a02 + b11 * a12 + b12 * a22;\n out[6] = b20 * a00 + b21 * a10 + b22 * a20;\n out[7] = b20 * a01 + b21 * a11 + b22 * a21;\n out[8] = b20 * a02 + b21 * a12 + b22 * a22;\n return out;\n}\n/**\n * Translate a mat3 by the given vector\n *\n * @param {mat3} out the receiving matrix\n * @param {ReadonlyMat3} a the matrix to translate\n * @param {ReadonlyVec2} v vector to translate by\n * @returns {mat3} out\n */\nexport function translate(out, a, v) {\n const a00 = a[0];\n const a01 = a[1];\n const a02 = a[2];\n const a10 = a[3];\n const a11 = a[4];\n const a12 = a[5];\n const a20 = a[6];\n const a21 = a[7];\n const a22 = a[8];\n const x = v[0];\n const y = v[1];\n out[0] = a00;\n out[1] = a01;\n out[2] = a02;\n out[3] = a10;\n out[4] = a11;\n out[5] = a12;\n out[6] = x * a00 + y * a10 + a20;\n out[7] = x * a01 + y * a11 + a21;\n out[8] = x * a02 + y * a12 + a22;\n return out;\n}\n/**\n * Rotates a mat3 by the given angle\n *\n * @param {mat3} out the receiving matrix\n * @param {ReadonlyMat3} a the matrix to rotate\n * @param {Number} rad the angle to rotate the matrix by\n * @returns {mat3} out\n */\nexport function rotate(out, a, rad) {\n const a00 = a[0];\n const a01 = a[1];\n const a02 = a[2];\n const a10 = a[3];\n const a11 = a[4];\n const a12 = a[5];\n const a20 = a[6];\n const a21 = a[7];\n const a22 = a[8];\n const s = Math.sin(rad);\n const c = Math.cos(rad);\n out[0] = c * a00 + s * a10;\n out[1] = c * a01 + s * a11;\n out[2] = c * a02 + s * a12;\n out[3] = c * a10 - s * a00;\n out[4] = c * a11 - s * a01;\n out[5] = c * a12 - s * a02;\n out[6] = a20;\n out[7] = a21;\n out[8] = a22;\n return out;\n}\n/**\n * Scales the mat3 by the dimensions in the given vec2\n *\n * @param {mat3} out the receiving matrix\n * @param {ReadonlyMat3} a the matrix to scale\n * @param {ReadonlyVec2} v the vec2 to scale the matrix by\n * @returns {mat3} out\n **/\nexport function scale(out, a, v) {\n const x = v[0];\n const y = v[1];\n out[0] = x * a[0];\n out[1] = x * a[1];\n out[2] = x * a[2];\n out[3] = y * a[3];\n out[4] = y * a[4];\n out[5] = y * a[5];\n out[6] = a[6];\n out[7] = a[7];\n out[8] = a[8];\n return out;\n}\n/**\n * Creates a matrix from a vector translation\n * This is equivalent to (but much faster than):\n *\n * mat3.identity(dest);\n * mat3.translate(dest, dest, vec);\n *\n * @param {mat3} out mat3 receiving operation result\n * @param {ReadonlyVec2} v Translation vector\n * @returns {mat3} out\n */\nexport function fromTranslation(out, v) {\n out[0] = 1;\n out[1] = 0;\n out[2] = 0;\n out[3] = 0;\n out[4] = 1;\n out[5] = 0;\n out[6] = v[0];\n out[7] = v[1];\n out[8] = 1;\n return out;\n}\n/**\n * Creates a matrix from a given angle\n * This is equivalent to (but much faster than):\n *\n * mat3.identity(dest);\n * mat3.rotate(dest, dest, rad);\n *\n * @param {mat3} out mat3 receiving operation result\n * @param {Number} rad the angle to rotate the matrix by\n * @returns {mat3} out\n */\nexport function fromRotation(out, rad) {\n const s = Math.sin(rad);\n const c = Math.cos(rad);\n out[0] = c;\n out[1] = s;\n out[2] = 0;\n out[3] = -s;\n out[4] = c;\n out[5] = 0;\n out[6] = 0;\n out[7] = 0;\n out[8] = 1;\n return out;\n}\n/**\n * Creates a matrix from a vector scaling\n * This is equivalent to (but much faster than):\n *\n * mat3.identity(dest);\n * mat3.scale(dest, dest, vec);\n *\n * @param {mat3} out mat3 receiving operation result\n * @param {ReadonlyVec2} v Scaling vector\n * @returns {mat3} out\n */\nexport function fromScaling(out, v) {\n out[0] = v[0];\n out[1] = 0;\n out[2] = 0;\n out[3] = 0;\n out[4] = v[1];\n out[5] = 0;\n out[6] = 0;\n out[7] = 0;\n out[8] = 1;\n return out;\n}\n/**\n * Copies the values from a mat2d into a mat3\n *\n * @param {mat3} out the receiving matrix\n * @param {ReadonlyMat2d} a the matrix to copy\n * @returns {mat3} out\n **/\nexport function fromMat2d(out, a) {\n out[0] = a[0];\n out[1] = a[1];\n out[2] = 0;\n out[3] = a[2];\n out[4] = a[3];\n out[5] = 0;\n out[6] = a[4];\n out[7] = a[5];\n out[8] = 1;\n return out;\n}\n/**\n * Calculates a 3x3 matrix from the given quaternion\n *\n * @param {mat3} out mat3 receiving operation result\n * @param {ReadonlyQuat} q Quaternion to create matrix from\n *\n * @returns {mat3} out\n */\nexport function fromQuat(out, q) {\n const x = q[0];\n const y = q[1];\n const z = q[2];\n const w = q[3];\n const x2 = x + x;\n const y2 = y + y;\n const z2 = z + z;\n const xx = x * x2;\n const yx = y * x2;\n const yy = y * y2;\n const zx = z * x2;\n const zy = z * y2;\n const zz = z * z2;\n const wx = w * x2;\n const wy = w * y2;\n const wz = w * z2;\n out[0] = 1 - yy - zz;\n out[3] = yx - wz;\n out[6] = zx + wy;\n out[1] = yx + wz;\n out[4] = 1 - xx - zz;\n out[7] = zy - wx;\n out[2] = zx - wy;\n out[5] = zy + wx;\n out[8] = 1 - xx - yy;\n return out;\n}\n/**\n * Calculates a 3x3 normal matrix (transpose inverse) from the 4x4 matrix\n *\n * @param {mat3} out mat3 receiving operation result\n * @param {ReadonlyMat4} a Mat4 to derive the normal matrix from\n *\n * @returns {mat3} out\n */\nexport function normalFromMat4(out, a) {\n const a00 = a[0];\n const a01 = a[1];\n const a02 = a[2];\n const a03 = a[3];\n const a10 = a[4];\n const a11 = a[5];\n const a12 = a[6];\n const a13 = a[7];\n const a20 = a[8];\n const a21 = a[9];\n const a22 = a[10];\n const a23 = a[11];\n const a30 = a[12];\n const a31 = a[13];\n const a32 = a[14];\n const a33 = a[15];\n const b00 = a00 * a11 - a01 * a10;\n const b01 = a00 * a12 - a02 * a10;\n const b02 = a00 * a13 - a03 * a10;\n const b03 = a01 * a12 - a02 * a11;\n const b04 = a01 * a13 - a03 * a11;\n const b05 = a02 * a13 - a03 * a12;\n const b06 = a20 * a31 - a21 * a30;\n const b07 = a20 * a32 - a22 * a30;\n const b08 = a20 * a33 - a23 * a30;\n const b09 = a21 * a32 - a22 * a31;\n const b10 = a21 * a33 - a23 * a31;\n const b11 = a22 * a33 - a23 * a32;\n // Calculate the determinant\n let det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n if (!det) {\n return null;\n }\n det = 1.0 / det;\n out[0] = (a11 * b11 - a12 * b10 + a13 * b09) * det;\n out[1] = (a12 * b08 - a10 * b11 - a13 * b07) * det;\n out[2] = (a10 * b10 - a11 * b08 + a13 * b06) * det;\n out[3] = (a02 * b10 - a01 * b11 - a03 * b09) * det;\n out[4] = (a00 * b11 - a02 * b08 + a03 * b07) * det;\n out[5] = (a01 * b08 - a00 * b10 - a03 * b06) * det;\n out[6] = (a31 * b05 - a32 * b04 + a33 * b03) * det;\n out[7] = (a32 * b02 - a30 * b05 - a33 * b01) * det;\n out[8] = (a30 * b04 - a31 * b02 + a33 * b00) * det;\n return out;\n}\n/**\n * Generates a 2D projection matrix with the given bounds\n *\n * @param {mat3} out mat3 frustum matrix will be written into\n * @param {number} width Width of your gl context\n * @param {number} height Height of gl context\n * @returns {mat3} out\n */\nexport function projection(out, width, height) {\n out[0] = 2 / width;\n out[1] = 0;\n out[2] = 0;\n out[3] = 0;\n out[4] = -2 / height;\n out[5] = 0;\n out[6] = -1;\n out[7] = 1;\n out[8] = 1;\n return out;\n}\n/**\n * Returns a string representation of a mat3\n *\n * @param {ReadonlyMat3} a matrix to represent as a string\n * @returns {String} string representation of the matrix\n */\nexport function str(a) {\n return `mat3(${a[0]}, ${a[1]}, ${a[2]}, ${a[3]}, ${a[4]}, ${a[5]}, ${a[6]}, ${a[7]}, ${a[8]})`;\n}\n/**\n * Returns Frobenius norm of a mat3\n *\n * @param {ReadonlyMat3} a the matrix to calculate Frobenius norm of\n * @returns {Number} Frobenius norm\n */\nexport function frob(a) {\n return Math.sqrt(a[0] * a[0] +\n a[1] * a[1] +\n a[2] * a[2] +\n a[3] * a[3] +\n a[4] * a[4] +\n a[5] * a[5] +\n a[6] * a[6] +\n a[7] * a[7] +\n a[8] * a[8]);\n}\n/**\n * Adds two mat3's\n *\n * @param {mat3} out the receiving matrix\n * @param {ReadonlyMat3} a the first operand\n * @param {ReadonlyMat3} b the second operand\n * @returns {mat3} out\n */\nexport function add(out, a, b) {\n out[0] = a[0] + b[0];\n out[1] = a[1] + b[1];\n out[2] = a[2] + b[2];\n out[3] = a[3] + b[3];\n out[4] = a[4] + b[4];\n out[5] = a[5] + b[5];\n out[6] = a[6] + b[6];\n out[7] = a[7] + b[7];\n out[8] = a[8] + b[8];\n return out;\n}\n/**\n * Subtracts matrix b from matrix a\n *\n * @param {mat3} out the receiving matrix\n * @param {ReadonlyMat3} a the first operand\n * @param {ReadonlyMat3} b the second operand\n * @returns {mat3} out\n */\nexport function subtract(out, a, b) {\n out[0] = a[0] - b[0];\n out[1] = a[1] - b[1];\n out[2] = a[2] - b[2];\n out[3] = a[3] - b[3];\n out[4] = a[4] - b[4];\n out[5] = a[5] - b[5];\n out[6] = a[6] - b[6];\n out[7] = a[7] - b[7];\n out[8] = a[8] - b[8];\n return out;\n}\n/**\n * Multiply each element of the matrix by a scalar.\n *\n * @param {mat3} out the receiving matrix\n * @param {ReadonlyMat3} a the matrix to scale\n * @param {Number} b amount to scale the matrix's elements by\n * @returns {mat3} out\n */\nexport function multiplyScalar(out, a, b) {\n out[0] = a[0] * b;\n out[1] = a[1] * b;\n out[2] = a[2] * b;\n out[3] = a[3] * b;\n out[4] = a[4] * b;\n out[5] = a[5] * b;\n out[6] = a[6] * b;\n out[7] = a[7] * b;\n out[8] = a[8] * b;\n return out;\n}\n/**\n * Adds two mat3's after multiplying each element of the second operand by a scalar value.\n *\n * @param {mat3} out the receiving vector\n * @param {ReadonlyMat3} a the first operand\n * @param {ReadonlyMat3} b the second operand\n * @param {Number} scale the amount to scale b's elements by before adding\n * @returns {mat3} out\n */\nexport function multiplyScalarAndAdd(out, a, b, scale) {\n out[0] = a[0] + b[0] * scale;\n out[1] = a[1] + b[1] * scale;\n out[2] = a[2] + b[2] * scale;\n out[3] = a[3] + b[3] * scale;\n out[4] = a[4] + b[4] * scale;\n out[5] = a[5] + b[5] * scale;\n out[6] = a[6] + b[6] * scale;\n out[7] = a[7] + b[7] * scale;\n out[8] = a[8] + b[8] * scale;\n return out;\n}\n/**\n * Returns whether or not the matrices have exactly the same elements in the same position (when compared with ===)\n *\n * @param {ReadonlyMat3} a The first matrix.\n * @param {ReadonlyMat3} b The second matrix.\n * @returns {Boolean} True if the matrices are equal, false otherwise.\n */\nexport function exactEquals(a, b) {\n return (a[0] === b[0] &&\n a[1] === b[1] &&\n a[2] === b[2] &&\n a[3] === b[3] &&\n a[4] === b[4] &&\n a[5] === b[5] &&\n a[6] === b[6] &&\n a[7] === b[7] &&\n a[8] === b[8]);\n}\n/**\n * Returns whether or not the matrices have approximately the same elements in the same position.\n *\n * @param {ReadonlyMat3} a The first matrix.\n * @param {ReadonlyMat3} b The second matrix.\n * @returns {Boolean} True if the matrices are equal, false otherwise.\n */\nexport function equals(a, b) {\n const a0 = a[0];\n const a1 = a[1];\n const a2 = a[2];\n const a3 = a[3];\n const a4 = a[4];\n const a5 = a[5];\n const a6 = a[6];\n const a7 = a[7];\n const a8 = a[8];\n const b0 = b[0];\n const b1 = b[1];\n const b2 = b[2];\n const b3 = b[3];\n const b4 = b[4];\n const b5 = b[5];\n const b6 = b[6];\n const b7 = b[7];\n const b8 = b[8];\n return (Math.abs(a0 - b0) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a0), Math.abs(b0)) &&\n Math.abs(a1 - b1) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a1), Math.abs(b1)) &&\n Math.abs(a2 - b2) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a2), Math.abs(b2)) &&\n Math.abs(a3 - b3) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a3), Math.abs(b3)) &&\n Math.abs(a4 - b4) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a4), Math.abs(b4)) &&\n Math.abs(a5 - b5) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a5), Math.abs(b5)) &&\n Math.abs(a6 - b6) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a6), Math.abs(b6)) &&\n Math.abs(a7 - b7) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a7), Math.abs(b7)) &&\n Math.abs(a8 - b8) <= glMatrix.EPSILON * Math.max(1.0, Math.abs(a8), Math.abs(b8)));\n}\n/**\n * Alias for {@link mat3.multiply}\n * @function\n */\nexport const mul = multiply;\n/**\n * Alias for {@link mat3.subtract}\n * @function\n */\nexport const sub = subtract;\n//# sourceMappingURL=mat3.js.map","// math.gl\n// SPDX-License-Identifier: MIT\n// Copyright (c) vis.gl contributors\n// Copyright (c) 2017 Uber Technologies, Inc.\nimport { Matrix } from \"./base/matrix.js\";\nimport { checkVector } from \"../lib/validators.js\";\nimport { vec4_transformMat3 } from \"../lib/gl-matrix-extras.js\";\nimport { fromQuat as mat3_fromQuat, determinant as mat3_determinant, transpose as mat3_transpose, invert as mat3_invert, multiply as mat3_multiply, rotate as mat3_rotate, scale as mat3_scale, translate as mat3_translate } from \"../gl-matrix/mat3.js\";\nimport { transformMat3 as vec2_transformMat3 } from \"../gl-matrix/vec2.js\";\nimport { transformMat3 as vec3_transformMat3 } from \"../gl-matrix/vec3.js\";\n// eslint-disable-next-line no-shadow\nvar INDICES;\n(function (INDICES) {\n INDICES[INDICES[\"COL0ROW0\"] = 0] = \"COL0ROW0\";\n INDICES[INDICES[\"COL0ROW1\"] = 1] = \"COL0ROW1\";\n INDICES[INDICES[\"COL0ROW2\"] = 2] = \"COL0ROW2\";\n INDICES[INDICES[\"COL1ROW0\"] = 3] = \"COL1ROW0\";\n INDICES[INDICES[\"COL1ROW1\"] = 4] = \"COL1ROW1\";\n INDICES[INDICES[\"COL1ROW2\"] = 5] = \"COL1ROW2\";\n INDICES[INDICES[\"COL2ROW0\"] = 6] = \"COL2ROW0\";\n INDICES[INDICES[\"COL2ROW1\"] = 7] = \"COL2ROW1\";\n INDICES[INDICES[\"COL2ROW2\"] = 8] = \"COL2ROW2\";\n})(INDICES || (INDICES = {}));\nconst IDENTITY_MATRIX = Object.freeze([1, 0, 0, 0, 1, 0, 0, 0, 1]);\n/**\n * A 3x3 matrix with common linear algebra operations\n * Subclass of Array<number> meaning that it is highly compatible with other libraries\n */\nexport class Matrix3 extends Matrix {\n static get IDENTITY() {\n return getIdentityMatrix();\n }\n static get ZERO() {\n return getZeroMatrix();\n }\n get ELEMENTS() {\n return 9;\n }\n get RANK() {\n return 3;\n }\n get INDICES() {\n return INDICES;\n }\n constructor(array, ...args) {\n // PERF NOTE: initialize elements as double precision numbers\n super(-0, -0, -0, -0, -0, -0, -0, -0, -0);\n if (arguments.length === 1 && Array.isArray(array)) {\n this.copy(array);\n }\n else if (args.length > 0) {\n this.copy([array, ...args]);\n }\n else {\n this.identity();\n }\n }\n copy(array) {\n // Element wise copy for performance\n this[0] = array[0];\n this[1] = array[1];\n this[2] = array[2];\n this[3] = array[3];\n this[4] = array[4];\n this[5] = array[5];\n this[6] = array[6];\n this[7] = array[7];\n this[8] = array[8];\n return this.check();\n }\n // Constructors\n identity() {\n return this.copy(IDENTITY_MATRIX);\n }\n /**\n *\n * @param object\n * @returns self\n */\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n fromObject(object) {\n return this.check();\n }\n /** Calculates a 3x3 matrix from the given quaternion\n * q quat Quaternion to create matrix from\n */\n fromQuaternion(q) {\n mat3_fromQuat(this, q);\n return this.check();\n }\n /**\n * accepts column major order, stores in column major order\n */\n // eslint-disable-next-line max-params\n set(m00, m10, m20, m01, m11, m21, m02, m12, m22) {\n this[0] = m00;\n this[1] = m10;\n this[2] = m20;\n this[3] = m01;\n this[4] = m11;\n this[5] = m21;\n this[6] = m02;\n this[7] = m12;\n this[8] = m22;\n return this.check();\n }\n /**\n * accepts row major order, stores as column major\n */\n // eslint-disable-next-line max-params\n setRowMajor(m00, m01, m02, m10, m11, m12, m20, m21, m22) {\n this[0] = m00;\n this[1] = m10;\n this[2] = m20;\n this[3] = m01;\n this[4] = m11;\n this[5] = m21;\n this[6] = m02;\n this[7] = m12;\n this[8] = m22;\n return this.check();\n }\n // Accessors\n determinant() {\n return mat3_determinant(this);\n }\n // Modifiers\n transpose() {\n mat3_transpose(this, this);\n return this.check();\n }\n /** Invert a matrix. Note that this can fail if the matrix is not invertible */\n invert() {\n mat3_invert(this, this);\n return this.check();\n }\n // Operations\n multiplyLeft(a) {\n mat3_multiply(this, a, this);\n return this.check();\n }\n multiplyRight(a) {\n mat3_multiply(this, this, a);\n return this.check();\n }\n rotate(radians) {\n mat3_rotate(this, this, radians);\n return this.check();\n }\n scale(factor) {\n if (Array.isArray(factor)) {\n mat3_scale(this, this, factor);\n }\n else {\n mat3_scale(this, this, [factor, factor]);\n }\n return this.check();\n }\n translate(vec) {\n mat3_translate(this, this, vec);\n return this.check();\n }\n // Transforms\n transform(vector, result) {\n let out;\n switch (vector.length) {\n case 2:\n out = vec2_transformMat3(result || [-0, -0], vector, this);\n break;\n case 3:\n out = vec3_transformMat3(result || [-0, -0, -0], vector, this);\n break;\n case 4:\n out = vec4_transformMat3(result || [-0, -0, -0, -0], vector, this);\n break;\n default:\n throw new Error('Illegal vector');\n }\n checkVector(out, vector.length);\n return out;\n }\n /** @deprecated */\n transformVector(vector, result) {\n return this.transform(vector, result);\n }\n /** @deprecated */\n transformVector2(vector, result) {\n return this.transform(vector, result);\n }\n /** @deprecated */\n transformVector3(vector, result) {\n return this.transform(vector, result);\n }\n}\nlet ZERO_MATRIX3;\nlet IDENTITY_MATRIX3 = null;\nfunction getZeroMatrix() {\n if (!ZERO_MATRIX3) {\n ZERO_MATRIX3 = new Matrix3([0, 0, 0, 0, 0, 0, 0, 0, 0]);\n Object.freeze(ZERO_MATRIX3);\n }\n return ZERO_MATRIX3;\n}\nfunction getIdentityMatrix() {\n if (!IDENTITY_MATRIX3) {\n IDENTITY_MATRIX3 = new Matrix3();\n Object.freeze(IDENTITY_MATRIX3);\n }\n return IDENTITY_MATRIX3;\n}\n//# sourceMappingURL=matrix3.js.map","// @eslint-disable\n// @ts-nocheck\nimport * as glMatrix from './common.js';\nimport * as mat3 from './mat3.js';\nimport * as vec3 from './vec3.js';\nimport * as vec4 from './vec4.js';\n// const glMatrix: {EPSILON = 0.000001};\n/**\n * Quaternion in the format XYZW\n * @module quat\n */\n/**\n * Creates a new identity quat\n *\n * @returns {quat} a new quaternion\n */\nexport function create() {\n const out = new glMatrix.ARRAY_TYPE(4);\n if (glMatrix.ARRAY_TYPE != Float32Array) {\n out[0] = 0;\n out[1] = 0;\n out[2] = 0;\n }\n out[3] = 1;\n return out;\n}\n/**\n * Set a quat to the identity quaternion\n *\n * @param {quat} out the receiving quaternion\n * @returns {quat} out\n */\nexport function identity(out) {\n out[0] = 0;\n out[1] = 0;\n out[2] = 0;\n out[3] = 1;\n return out;\n}\n/**\n * Sets a quat from the given angle and rotation axis,\n * then returns it.\n *\n * @param {quat} out the receiving quaternion\n * @param {ReadonlyVec3} axis the axis around which to rotate\n * @param {Number} rad the angle in radians\n * @returns {quat} out\n **/\nexport function setAxisAngle(out, axis, rad) {\n rad = rad * 0.5;\n const s = Math.sin(rad);\n out[0] = s * axis[0];\n out[1] = s * axis[1];\n out[2] = s * axis[2];\n out[3] = Math.cos(rad);\n return out;\n}\n/**\n * Gets the rotation axis and angle for a given\n * quaternion. If a quaternion is created with\n * setAxisAngle, this method will return the same\n * values as providied in the original parameter list\n * OR functionally equivalent values.\n * Example: The quaternion formed by axis [0, 0, 1] and\n * angle -90 is the same as the quaternion formed by\n * [0, 0, 1] and 270. This method favors the latter.\n * @param {vec3} out_axis Vector receiving the axis of rotation\n * @param {ReadonlyQuat} q Quaternion to be decomposed\n * @return {Number} Angle, in radians, of the rotation\n */\nexport function getAxisAngle(out_axis, q) {\n const rad = Math.acos(q[3]) * 2.0;\n const s = Math.sin(rad / 2.0);\n if (s > glMatrix.EPSILON) {\n out_axis[0] = q[0] / s;\n out_axis[1] = q[1] / s;\n out_axis[2] = q[2] / s;\n }\n else {\n // If s is zero, return any axis (no rotation - axis does not matter)\n out_axis[0] = 1;\n out_axis[1] = 0;\n out_axis[2] = 0;\n }\n return rad;\n}\n/**\n * Gets the angular distance between two unit quaternions\n *\n * @param {ReadonlyQuat} a Origin unit quaternion\n * @param {ReadonlyQuat} b Destination unit quaternion\n * @return {Number} Angle, in radians, between the two quaternions\n */\nexport function getAngle(a, b) {\n const dotproduct = dot(a, b);\n return Math.acos(2 * dotproduct * dotproduct - 1);\n}\n/**\n * Multiplies two quat's\n *\n * @param {quat} out the receiving quaternion\n * @param {ReadonlyQuat} a the first operand\n * @param {ReadonlyQuat} b the second operand\n * @returns {quat} out\n */\nexport function multiply(out, a, b) {\n const ax = a[0];\n const ay = a[1];\n const az = a[2];\n const aw = a[3];\n const bx = b[0];\n const by = b[1];\n const bz = b[2];\n const bw = b[3];\n out[0] = ax * bw + aw * bx + ay * bz - az * by;\n out[1] = ay * bw + aw * by + az * bx - ax * bz;\n out[2] = az * bw + aw * bz + ax * by - ay * bx;\n out[3] = aw * bw - ax * bx - ay * by - az * bz;\n return out;\n}\n/**\n * Rotates a quaternion by the given angle about the X axis\n *\n * @param {quat} out quat receiving operation result\n * @param {ReadonlyQuat} a quat to rotate\n * @param {number} rad angle (in radians) to rotate\n * @returns {quat} out\n */\nexport function rotateX(out, a, rad) {\n rad *= 0.5;\n const ax = a[0];\n const ay = a[1];\n const az = a[2];\n const aw = a[3];\n const bx = Math.sin(rad);\n const bw = Math.cos(rad);\n out[0] = ax * bw + aw * bx;\n out[1] = ay * bw + az * bx;\n out[2] = az * bw - ay * bx;\n out[3] = aw * bw - ax * bx;\n return out;\n}\n/**\n * Rotates a quaternion by the given angle about the Y axis\n *\n * @param {quat} out quat receiving operation result\n * @param {ReadonlyQuat} a quat to rotate\n * @param {number} rad angle (in radians) to rotate\n * @returns {quat} out\n */\nexport function rotateY(out, a, rad) {\n rad *= 0.5;\n const ax = a[0];\n const ay = a[1];\n const az = a[2];\n const aw = a[3];\n const by = Math.sin(rad);\n const bw = Math.cos(rad);\n out[0] = ax * bw - az * by;\n out[1] = ay * bw + aw * by;\n out[2] = az * bw + ax * by;\n out[3] = aw * bw - ay * by;\n return out;\n}\n/**\n * Rotates a quaternion by the given angle about the Z axis\n *\n * @param {quat} out quat receiving operation result\n * @param {ReadonlyQuat} a quat to rotate\n * @param {number} rad angle (in radians) to rotate\n * @returns {quat} out\n */\nexport function rotateZ(out, a, rad) {\n rad *= 0.5;\n const ax = a[0];\n const ay = a[1];\n const az = a[2];\n const aw = a[3];\n const bz = Math.sin(rad);\n const bw = Math.cos(rad);\n out[0] = ax * bw + ay * bz;\n out[1] = ay * bw - ax * bz;\n out[2] = az * bw + aw * bz;\n out[3] = aw * bw - az * bz;\n return out;\n}\n/**\n * Calculates the W component of a quat from the X, Y, and Z components.\n * Assumes that quaternion is 1 unit in length.\n * Any existing W component will be ignored.\n *\n * @param {quat} out the receiving quaternion\n * @param {ReadonlyQuat} a quat to calculate W component of\n * @returns {quat} out\n */\nexport function calculateW(out, a) {\n const x = a[0];\n const y = a[1];\n const z = a[2];\n out[0] = x;\n out[1] = y;\n out[2] = z;\n out[3] = Math.sqrt(Math.abs(1.0 - x * x - y * y - z * z));\n return out;\n}\n/**\n * Calculate the exponential of a unit quaternion.\n *\n * @param {quat} out the receiving quaternion\n * @param {ReadonlyQuat} a quat to calculate the exponential of\n * @returns {quat} out\n */\nexport function exp(out, a) {\n const x = a[0];\n const y = a[1];\n const z = a[2];\n const w = a[3];\n const r = Math.sqrt(x * x + y * y + z * z);\n const et = Math.exp(w);\n const s = r > 0 ? (et * Math.sin(r)) / r : 0;\n out[0] = x * s;\n out[1] = y * s;\n out[2] = z * s;\n out[3] = et * Math.cos(r);\n return out;\n}\n/**\n * Calculate the natural logarithm of a unit quaternion.\n *\n * @param {quat} out the receiving quaternion\n * @param {ReadonlyQuat} a quat to calculate the exponential of\n * @returns {quat} out\n */\nexport function ln(out, a) {\n const x = a[0];\n const y = a[1];\n const z = a[2];\n const w = a[3];\n const r = Math.sqrt(x * x + y * y + z * z);\n const t = r > 0 ? Math.atan2(r, w) / r : 0;\n out[0] = x * t;\n out[1] = y * t;\n out[2] = z * t;\n out[3] = 0.5 * Math.log(x * x + y * y + z * z + w * w);\n return out;\n}\n/**\n * Calculate the scalar power of a unit quaternion.\n *\n * @param {quat} out the receiving quaternion\n * @param {ReadonlyQuat} a quat to calculate the exponential of\n * @param {Number} b amount to scale the quaternion by\n * @returns {quat} out\n */\nexport function pow(out, a, b) {\n ln(out, a);\n scale(out, out, b);\n exp(out, out);\n return out;\n}\n/**\n * Performs a spherical linear interpolation between two quat\n *\n * @param {quat} out the receiving quaternion\n * @param {ReadonlyQuat} a the first operand\n * @param {ReadonlyQuat} b the second operand\n * @param {Number} t interpolation amount, in the range [0-1], between the two inputs\n * @returns {quat} out\n */\nexport function slerp(out, a, b, t) {\n // benchmarks:\n // http://jsperf.com/quaternion-slerp-implementations\n const ax = a[0];\n const ay = a[1];\n const az = a[2];\n const aw = a[3];\n let bx = b[0];\n let by = b[1];\n let bz = b[2];\n let bw = b[3];\n let cosom;\n let omega;\n let scale0;\n let scale1;\n let sinom;\n // calc cosine\n cosom = ax * bx + ay * by + az * bz + aw * bw;\n // adjust signs (if necessary)\n if (cosom < 0.0) {\n cosom = -cosom;\n bx = -bx;\n by = -by;\n bz = -bz;\n bw = -bw;\n }\n // calculate coefficients\n if (1.0 - cosom > glMatrix.EPSILON) {\n // standard case (slerp)\n omega = Math.acos(cosom);\n sinom = Math.sin(omega);\n scale0 = Math.sin((1.0 - t) * omega) / sinom;\n scale1 = Math.sin(t * omega) / sinom;\n }\n else {\n // \"from\" and \"to\" quaternions are very close\n // ... so we can do a linear interpolation\n scale0 = 1.0 - t;\n scale1 = t;\n }\n // calculate final values\n out[0] = scale0 * ax + scale1 * bx;\n out[1] = scale0 * ay + scale1 * by;\n out[2] = scale0 * az + scale1 * bz;\n out[3] = scale0 * aw + scale1 * bw;\n return out;\n}\n/**\n * Generates a random unit quaternion\n *\n * @param {quat} out the receiving quaternion\n * @returns {quat} out\n */\n// export function random(out) {\n// // Implementation of http://planning.cs.uiuc.edu/node198.html\n// // TODO: Calling random 3 times is probably not the fastest solution\n// let u1 = glMatrix.RANDOM();\n// let u2 = glMatrix.RANDOM();\n// let u3 = glMatrix.RANDOM();\n// let sqrt1MinusU1 = Math.sqrt(1 - u1);\n// let sqrtU1 = Math.sqrt(u1);\n// out[0] = sqrt1MinusU1 * Math.sin(2.0 * Math.PI * u2);\n// out[1] = sqrt1MinusU1 * Math.cos(2.0 * Math.PI * u2);\n// out[2] = sqrtU1 * Math.sin(2.0 * Math.PI * u3);\n// out[3] = sqrtU1 * Math.cos(2.0 * Math.PI * u3);\n// return out;\n// }\n/**\n * Calculates the inverse of a quat\n *\n * @param {quat} out the receiving quaternion\n * @param {ReadonlyQuat} a quat to calculate inverse of\n * @returns {quat} out\n */\nexport function invert(out, a) {\n const a0 = a[0];\n const a1 = a[1];\n const a2 = a[2];\n const a3 = a[3];\n const dot = a0 * a0 + a1 * a1 + a2 * a2 + a3 * a3;\n const invDot = dot ? 1.0 / dot : 0;\n // TODO: Would be faster to return [0,0,0,0] immediately if dot == 0\n out[0] = -a0 * invDot;\n out[1] = -a1 * invDot;\n out[2] = -a2 * invDot;\n out[3] = a3 * invDot;\n return out;\n}\n/**\n * Calculates the conjugate of a quat\n * If the quaternion is normalized, this function is faster than quat.inverse and produces the same result.\n *\n * @param {quat} out the receiving quaternion\n * @param {ReadonlyQuat} a quat to calculate conjugate of\n * @returns {quat} out\n */\nexport function conjugate(out, a) {\n out[0] = -a[0];\n out[1] = -a[1];\n out[2] = -a[2];\n out[3] = a[3];\n return out;\n}\n/**\n * Creates a quaternion from the given 3x3 rotation matrix.\n *\n * NOTE: The resultant quaternion is not normalized, so you should be sure\n * to renormalize the quaternion yourself where necessary.\n *\n * @param {quat} out the receiving quaternion\n * @param {ReadonlyMat3} m rotation matrix\n * @returns {quat} out\n * @function\n */\nexport function fromMat3(out, m) {\n // Algorithm in Ken Shoemake's article in 1987 SIGGRAPH course notes\n // article \"Quaternion Calculus and Fast Animation\".\n const fTrace = m[0] + m[4] + m[8];\n let fRoot;\n if (fTrace > 0.0) {\n // |w| > 1/2, may as well choose w > 1/2\n fRoot = Math.sqrt(fTrace + 1.0); // 2w\n out[3] = 0.5 * fRoot;\n fRoot = 0.5 / fRoot; // 1/(4w)\n out[0] = (m[5] - m[7]) * fRoot;\n out[1] = (m[6] - m[2]) * fRoot;\n out[2] = (m[1] - m[3]) * fRoot;\n }\n else {\n // |w| <= 1/2\n let i = 0;\n if (m[4] > m[0])\n i = 1;\n if (m[8] > m[i * 3 + i])\n i = 2;\n const j = (i + 1) % 3;\n const k = (i + 2) % 3;\n fRoot = Math.sqrt(m[i * 3 + i] - m[j * 3 + j] - m[k * 3 + k] + 1.0);\n out[i] = 0.5 * fRoot;\n fRoot = 0.5 / fRoot;\n out[3] = (m[j * 3 + k] - m[k * 3 + j]) * fRoot;\n out[j] = (m[j * 3 + i] + m[i * 3 + j]) * fRoot;\n out[k] = (m[k * 3 + i] + m[i * 3 + k]) * fRoot;\n }\n return out;\n}\n/**\n * Creates a quaternion from the given euler angle x, y, z using the provided intrinsic order for the conversion.\n *\n * @param {quat} out the receiving quaternion\n * @param {Number} x Angle to rotate around X axis in degrees.\n * @param {Number} y Angle to rotate around Y axis in degrees.\n * @param {Number} z Angle to rotate around Z axis in degrees.\n * @param {'zyx'|'xyz'|'yxz'|'yzx'|'zxy'|'zyx'} order Intrinsic order for conversion, default is zyx.\n * @returns {quat} out\n * @function\n */\n// export function fromEuler(out, x, y, z, order = glMatrix.ANGLE_ORDER) {\n// let halfToRad = Math.PI / 360;\n// x *= halfToRad;\n// z *= halfToRad;\n// y *= halfToRad;\n// let sx = Math.sin(x);\n// let cx = Math.cos(x);\n// let sy = Math.sin(y);\n// let cy = Math.cos(y);\n// let sz = Math.sin(z);\n// let cz = Math.cos(z);\n// switch (order) {\n// case \"xyz\":\n// out[0] = sx * cy * cz + cx * sy * sz;\n// out[1] = cx * sy * cz - sx * cy * sz;\n// out[2] = cx * cy * sz + sx * sy * cz;\n// out[3] = cx * cy * cz - sx * sy * sz;\n// break;\n// case \"xzy\":\n// out[0] = sx * cy * cz - cx * sy * sz;\n// out[1] = cx * sy * cz - sx * cy * sz;\n// out[2] = cx * cy * sz + sx * sy * cz;\n// out[3] = cx * cy * cz + sx * sy * sz;\n// break;\n// case \"yxz\":\n// out[0] = sx * cy * cz + cx * sy * sz;\n// out[1] = cx * sy * cz - sx * cy * sz;\n// out[2] = cx * cy * sz - sx * sy * cz;\n// out[3] = cx * cy * cz + sx * sy * sz;\n// break;\n// case \"yzx\":\n// out[0] = sx * cy * cz + cx * sy * sz;\n// out[1] = cx * sy * cz + sx * cy * sz;\n// out[2] = cx * cy * sz - sx * sy * cz;\n// out[3] = cx * cy * cz - sx * sy * sz;\n// break;\n// case \"zxy\":\n// out[0] = sx * cy * cz - cx * sy * sz;\n// out[1] = cx * sy * cz + sx * cy * sz;\n// out[2] = cx * cy * sz + sx * sy * cz;\n// out[3] = cx * cy * cz - sx * sy * sz;\n// break;\n// case \"zyx\":\n// out[0] = sx * cy * cz - cx * sy * sz;\n// out[1] = cx * sy * cz + sx * cy * sz;\n// out[2] = cx * cy * sz - sx * sy * cz;\n// out[3] = cx * cy * cz + sx * sy * sz;\n// break;\n// default:\n// throw new Error('Unknown angle order ' + order);\n// }\n// return out;\n// }\n/**\n * Returns a string representation of a quaternion\n *\n * @param {ReadonlyQuat} a vector to represent as a string\n * @returns {String} string representation of the vector\n */\nexport function str(a) {\n return `quat(${a[0]}, ${a[1]}, ${a[2]}, ${a[3]})`;\n}\n/**\n * Creates a new quat initialized with values from an existing quaternion\n *\n * @param {ReadonlyQuat} a quaternion to clone\n * @returns {quat} a new quaternion\n * @function\n */\nexport const clone = vec4.clone;\n/**\n * Creates a new quat initialized with the given values\n *\n * @param {Number} x X component\n * @param {Number} y Y component\n * @param {Number} z Z component\n * @param {Number} w W component\n * @returns {quat} a new quaternion\n * @function\n */\nexport const fromValues = vec4.fromValues;\n/**\n * Copy the values from one quat to another\n *\n * @param {quat} out the receiving quaternion\n * @param {ReadonlyQuat} a the source quaternion\n * @returns {quat} out\n * @function\n */\nexport const copy = vec4.copy;\n/**\n * Set the components of a quat to the given values\n *\n * @param {quat} out the receiving quaternion\n * @param {Number} x X component\n * @param {Number} y Y component\n * @param {Number} z Z component\n * @param {Number} w W component\n * @returns {quat} out\n * @function\n */\nexport const set = vec4.set;\n/**\n * Adds two quat's\n *\n * @param {quat} out the receiving quaternion\n * @param {ReadonlyQuat} a the first operand\n * @param {ReadonlyQuat} b the second operand\n * @returns {quat} out\n * @function\n */\nexport const add = vec4.add;\n/**\n * Alias for {@link quat.multiply}\n * @function\n */\nexport const mul = multiply;\n/**\n * Scales a quat by a scalar number\n *\n * @param {quat} out the receiving vector\n * @param {ReadonlyQuat} a the vector to scale\n * @param {Number} b amount to scale the vector by\n * @returns {quat} out\n * @function\n */\nexport const scale = vec4.scale;\n/**\n * Calculates the dot product of two quat's\n *\n * @param {ReadonlyQuat} a the first operand\n * @param {ReadonlyQuat} b the second operand\n * @returns {Number} dot product of a and b\n * @function\n */\nexport const dot = vec4.dot;\n/**\n * Performs a linear interpolation between two quat's\n *\n * @param {quat} out the receiving quaternion\n * @param {ReadonlyQuat} a the first operand\n * @param {ReadonlyQuat} b the second operand\n * @param {Number} t interpolation amount, in the range [0-1], between the two inputs\n * @returns {quat} out\n * @function\n */\nexport const lerp = vec4.lerp;\n/**\n * Calculates the length of a quat\n *\n * @param {ReadonlyQuat} a vector to calculate length of\n * @returns {Number} length of a\n */\nexport const length = vec4.length;\n/**\n * Alias for {@link quat.length}\n * @function\n */\nexport const len = length;\n/**\n * Calculates the squared length of a quat\n *\n * @param {ReadonlyQuat} a vector to calculate squared length of\n * @returns {Number} squared length of a\n * @function\n */\nexport const squaredLength = vec4.squaredLength;\n/**\n * Alias for {@link quat.squaredLength}\n * @function\n */\nexport const sqrLen = squaredLength;\n/**\n * Normalize a quat\n *\n * @param {quat} out the receiving quaternion\n * @param {ReadonlyQuat} a quaternion to normalize\n * @returns {quat} out\n * @function\n */\nexport const normalize = vec4.normalize;\n/**\n * Returns whether or not the quaternions have exactly the same elements in the same position (when compared with ===)\n *\n * @param {ReadonlyQuat} a The first quaternion.\n * @param {ReadonlyQuat} b The second quaternion.\n * @returns {Boolean} True if the vectors are equal, false otherwise.\n */\nexport const exactEquals = vec4.exactEquals;\n/**\n * Returns whether or not the quaternions point approximately to the same direction.\n *\n * Both quaternions are assumed to be unit length.\n *\n * @param {ReadonlyQuat} a The first unit quaternion.\n * @param {ReadonlyQuat} b The second unit quaternion.\n * @returns {Boolean} True if the quaternions are equal, false otherwise.\n */\nexport function equals(a, b) {\n return Math.abs(vec4.dot(a, b)) >= 1 - glMatrix.EPSILON;\n}\n/**\n * Sets a quaternion to represent the shortest rotation from one\n * vector to another.\n *\n * Both vectors are assumed to be unit length.\n *\n * @param {quat} out the receiving quaternion.\n * @param {ReadonlyVec3} a the initial vector\n * @param {ReadonlyVec3} b the destination vector\n * @returns {quat} out\n */\nexport const rotationTo = (function () {\n const tmpvec3 = vec3.create();\n const xUnitVec3 = vec3.fromValues(1, 0, 0);\n const yUnitVec3 = vec3.fromValues(0, 1, 0);\n return function (out, a, b) {\n const dot = vec3.dot(a, b);\n if (dot < -0.999999) {\n vec3.cross(tmpvec3, xUnitVec3, a);\n if (vec3.len(tmpvec3) < 0.000001)\n vec3.cross(tmpvec3, yUnitVec3, a);\n vec3.normalize(tmpvec3, tmpvec3);\n setAxisAngle(out, tmpvec3, Math.PI);\n return out;\n }\n else if (dot > 0.999999) {\n out[0] = 0;\n out[1] = 0;\n out[2] = 0;\n out[3] = 1;\n return out;\n }\n vec3.cross(tmpvec3, a, b);\n out[0] = tmpvec3[0];\n out[1] = tmpvec3[1];\n out[2] = tmpvec3[2];\n out[3] = 1 + dot;\n return normalize(out, out);\n };\n})();\n/**\n * Performs a spherical linear interpolation with two control points\n *\n * @param {quat} out the receiving quaternion\n * @param {ReadonlyQuat} a the first operand\n * @param {ReadonlyQuat} b the second operand\n * @param {ReadonlyQuat} c the third operand\n * @param {ReadonlyQuat} d the fourth operand\n * @param {Number} t interpolation amount, in the range [0-1], between the two inputs\n * @returns {quat} out\n */\nexport const sqlerp = (function () {\n const temp1 = create();\n const temp2 = create();\n return function (out, a, b, c, d, t) {\n slerp(temp1, a, d, t);\n slerp(temp2, b, c, t);\n slerp(out, temp1, temp2, 2 * t * (1 - t));\n return out;\n };\n})();\n/**\n * Sets the specified quaternion with values corresponding to the given\n * axes. Each axis is a vec3 and is expected to be unit length and\n * perpendicular to all other specified axes.\n *\n * @param {ReadonlyVec3} view the vector representing the viewing direction\n * @param {ReadonlyVec3} right the vector representing the local \"right\" direction\n * @param {ReadonlyVec3} up the vector representing the local \"up\" direction\n * @returns {quat} out\n */\nexport const setAxes = (function () {\n const matr = mat3.create();\n return function (out, view, right, up) {\n matr[0] = right[0];\n matr[3] = right[1];\n matr[6] = right[2];\n matr[1] = up[0];\n matr[4] = up[1];\n matr[7] = up[2];\n matr[2] = -view[0];\n matr[5] = -view[1];\n matr[8] = -view[2];\n return normalize(out, fromMat3(out, matr));\n };\n})();\n//# sourceMappingURL=quat.js.map","// math.gl\n// SPDX-License-Identifier: MIT\n// Copyright (c) vis.gl contributors\n// Copyright (c) 2017 Uber Technologies, Inc.\nimport { MathArray } from \"./base/math-array.js\";\nimport { checkNumber, checkVector } from \"../lib/validators.js\";\nimport { Vector4 } from \"./vector4.js\";\n// @ts-ignore gl-matrix types...\nimport { fromMat3 as quat_fromMat3, setAxisAngle as quat_setAxisAngle, identity as quat_identity, length as quat_length, squaredLength as quat_squaredLength, dot as quat_dot, \n// getAxisAngle as quat_getAxisAngle,\nrotationTo as quat_rotationTo, add as quat_add, calculateW as quat_calculateW, conjugate as quat_conjugate, invert as quat_invert, lerp as quat_lerp, multiply as quat_multiply, rotateX as quat_rotateX, rotateY as quat_rotateY, rotateZ as quat_rotateZ, scale as quat_scale, slerp as quat_slerp } from \"../gl-matrix/quat.js\";\n// @ts-ignore gl-matrix types...\nimport { transformQuat as vec4_transformQuat } from \"../gl-matrix/vec4.js\";\nconst IDENTITY_QUATERNION = [0, 0, 0, 1];\nexport class Quaternion extends MathArray {\n constructor(x = 0, y = 0, z = 0, w = 1) {\n // PERF NOTE: initialize elements as double precision numbers\n super(-0, -0, -0, -0);\n // eslint-disable-next-line prefer-rest-params\n if (Array.isArray(x) && arguments.length === 1) {\n this.copy(x);\n }\n else {\n this.set(x, y, z, w);\n }\n }\n copy(array) {\n this[0] = array[0];\n this[1] = array[1];\n this[2] = array[2];\n this[3] = array[3];\n return this.check();\n }\n set(x, y, z, w) {\n this[0] = x;\n this[1] = y;\n this[2] = z;\n this[3] = w;\n return this.check();\n }\n fromObject(object) {\n this[0] = object.x;\n this[1] = object.y;\n this[2] = object.z;\n this[3] = object.w;\n return this.check();\n }\n /**\n * Creates a quaternion from the given 3x3 rotation matrix.\n * NOTE: The resultant quaternion is not normalized, so you should\n * be sure to renormalize the quaternion yourself where necessary.\n * @param m\n * @returns\n */\n fromMatrix3(m) {\n quat_fromMat3(this, m);\n return this.check();\n }\n fromAxisRotation(axis, rad) {\n quat_setAxisAngle(this, axis, rad);\n return this.check();\n }\n /** Set a quat to the identity quaternion */\n identity() {\n quat_identity(this);\n return this.check();\n }\n // Set the components of a quat to the given values\n // set(i, j, k, l) {\n // quat_set(this, i, j, k, l);\n // return this.check();\n // }\n // Sets a quat from the given angle and rotation axis, then returns it.\n setAxisAngle(axis, rad) {\n return this.fromAxisRotation(axis, rad);\n }\n // Getters/setters\n get ELEMENTS() {\n return 4;\n }\n get x() {\n return this[0];\n }\n set x(value) {\n this[0] = checkNumber(value);\n }\n get y() {\n return this[1];\n }\n set y(value) {\n this[1] = checkNumber(value);\n }\n get z() {\n return this[2];\n }\n set z(value) {\n this[2] = checkNumber(value);\n }\n get w() {\n return this[3];\n }\n set w(value) {\n this[3] = checkNumber(value);\n }\n // Calculates the length of a quat\n len() {\n return quat_length(this);\n }\n // Calculates the squared length of a quat\n lengthSquared() {\n return quat_squaredLength(this);\n }\n // Calculates the dot product of two quat's\n // @return {Number}\n dot(a) {\n return quat_dot(this, a);\n }\n // Gets the rotation axis and angle for a given quaternion.\n // If a quaternion is created with setAxisAngle, this method will\n // return the same values as providied in the original parameter\n // list OR functionally equivalent values.\n // Example: The quaternion formed by axis [0, 0, 1] and angle -90\n // is the same as the quaternion formed by [0, 0, 1] and 270.\n // This method favors the latter.\n // @return {{[x,y,z], Number}}\n // getAxisAngle() {\n // const axis = [];\n // // const angle = quat_getAxisAngle(axis, this);\n // return {axis, angle};\n // }\n // MODIFIERS\n // Sets a quaternion to represent the shortest rotation from one vector\n // to another. Both vectors are assumed to be unit length.\n rotationTo(vectorA, vectorB) {\n quat_rotationTo(this, vectorA, vectorB);\n return this.check();\n }\n // Sets the specified quaternion with values corresponding to the given axes.\n // Each axis is a vec3 and is expected to be unit length and perpendicular\n // to all other specified axes.\n // setAxes() {\n // Number\n // }\n // Performs a spherical linear interpolation with two control points\n // sqlerp() {\n // Number;\n // }\n // Adds two quat's\n add(a) {\n quat_add(this, this, a);\n return this.check();\n }\n // Calculates the W component of a quat from the X, Y, and Z components.\n // Any existing W component will be ignored.\n calculateW() {\n quat_calculateW(this, this);\n return this.check();\n }\n // Calculates the conjugate of a quat If the quaternion is normalized,\n // this function is faster than quat_invert and produces the same result.\n conjugate() {\n quat_conjugate(this, this);\n return this.check();\n }\n // Calculates the inverse of a quat\n invert() {\n quat_invert(this, this);\n return this.check();\n }\n // Performs a linear interpolation between two quat's\n lerp(a, b, t) {\n if (t === undefined) {\n return this.lerp(this, a, b);\n }\n quat_lerp(this, a, b, t);\n return this.check();\n }\n // Multiplies two quat's\n multiplyRight(a) {\n quat_multiply(this, this, a);\n return this.check();\n }\n multiplyLeft(a) {\n quat_multiply(this, a, this);\n return this.check();\n }\n // Normalize a quat\n normalize() {\n // Handle 0 case\n const length = this.len();\n const l = length > 0 ? 1 / length : 0;\n this[0] = this[0] * l;\n this[1] = this[1] * l;\n this[2] = this[2] * l;\n this[3] = this[3] * l;\n // Set to [0, 0, 0, 1] if length is 0\n if (length === 0) {\n this[3] = 1;\n }\n return this.check();\n }\n // Rotates a quaternion by the given angle about the X axis\n rotateX(rad) {\n quat_rotateX(this, this, rad);\n return this.check();\n }\n // Rotates a quaternion by the given angle about the Y axis\n rotateY(rad) {\n quat_rotateY(this, this, rad);\n return this.check();\n }\n // Rotates a quaternion by the given angle about the Z axis\n rotateZ(rad) {\n quat_rotateZ(this, this, rad);\n return this.check();\n }\n // Scales a quat by a scalar number\n scale(b) {\n quat_scale(this, this, b);\n return this.check();\n }\n // Performs a spherical linear interpolation between two quat\n slerp(arg0, arg1, arg2) {\n let start;\n let target;\n let ratio;\n // eslint-disable-next-line prefer-rest-params\n switch (arguments.length) {\n case 1: // Deprecated signature ({start, target, ratio})\n // eslint-disable-next-line prefer-rest-params\n ({\n start = IDENTITY_QUATERNION,\n target,\n ratio\n } = arg0);\n break;\n case 2: // THREE.js compatibility signature (target, ration)\n start = this; // eslint-disable-line\n target = arg0;\n ratio = arg1;\n break;\n default:\n // Default signature: (start, target, ratio)\n start = arg0;\n target = arg1;\n ratio = arg2;\n }\n quat_slerp(this, start, target, ratio);\n return this.check();\n }\n transformVector4(vector, result = new Vector4()) {\n vec4_transformQuat(result, vector, this);\n return checkVector(result, 4);\n }\n // THREE.js Math API compatibility\n lengthSq() {\n return this.lengthSquared();\n }\n setFromAxisAngle(axis, rad) {\n return this.setAxisAngle(axis, rad);\n }\n premultiply(a) {\n return this.multiplyLeft(a);\n }\n multiply(a) {\n return this.multiplyRight(a);\n }\n}\n//# sourceMappingURL=quaternion.js.map","// luma.gl\n// SPDX-License-Identifier: MIT\n// Copyright (c) vis.gl contributors\n// Attribution:\n// MIT license, Copyright (c) 2016-2017 Mohamad Moneimne and Contributors\n// This fragment shader defines a reference implementation for Physically Based Shading of\n// a microfacet surface material defined by a glTF model.\n// TODO - better do the checks outside of shader\nexport const vs = /* glsl */ `\\\nout vec3 pbr_vPosition;\nout vec2 pbr_vUV;\n\n#ifdef HAS_NORMALS\n# ifdef HAS_TANGENTS\nout mat3 pbr_vTBN;\n# else\nout vec3 pbr_vNormal;\n# endif\n#endif\n\nvoid pbr_setPositionNormalTangentUV(vec4 position, vec4 normal, vec4 tangent, vec2 uv)\n{\n vec4 pos = pbrProjection.modelMatrix * position;\n pbr_vPosition = vec3(pos.xyz) / pos.w;\n\n#ifdef HAS_NORMALS\n#ifdef HAS_TANGENTS\n vec3 normalW = normalize(vec3(pbrProjection.normalMatrix * vec4(normal.xyz, 0.0)));\n vec3 tangentW = normalize(vec3(pbrProjection.modelMatrix * vec4(tangent.xyz, 0.0)));\n vec3 bitangentW = cross(normalW, tangentW) * tangent.w;\n pbr_vTBN = mat3(tangentW, bitangentW, normalW);\n#else // HAS_TANGENTS != 1\n pbr_vNormal = normalize(vec3(pbrProjection.modelMatrix * vec4(normal.xyz, 0.0)));\n#endif\n#endif\n\n#ifdef HAS_UV\n pbr_vUV = uv;\n#else\n pbr_vUV = vec2(0.,0.);\n#endif\n}\n`;\nexport const fs = /* glsl */ `\\\nprecision highp float;\n\nuniform pbrMaterialUniforms {\n // Material is unlit\n bool unlit;\n\n // Base color map\n bool baseColorMapEnabled;\n vec4 baseColorFactor;\n\n bool normalMapEnabled; \n float normalScale; // #ifdef HAS_NORMALMAP\n\n bool emissiveMapEnabled;\n vec3 emissiveFactor; // #ifdef HAS_EMISSIVEMAP\n\n vec2 metallicRoughnessValues;\n bool metallicRoughnessMapEnabled;\n\n bool occlusionMapEnabled;\n float occlusionStrength; // #ifdef HAS_OCCLUSIONMAP\n \n bool alphaCutoffEnabled;\n float alphaCutoff; // #ifdef ALPHA_CUTOFF\n \n // IBL\n bool IBLenabled;\n vec2 scaleIBLAmbient; // #ifdef USE_IBL\n \n // debugging flags used for shader output of intermediate PBR variables\n // #ifdef PBR_DEBUG\n vec4 scaleDiffBaseMR;\n vec4 scaleFGDSpec;\n // #endif\n} pbrMaterial;\n\n// Samplers\n#ifdef HAS_BASECOLORMAP\nuniform sampler2D pbr_baseColorSampler;\n#endif\n#ifdef HAS_NORMALMAP\nuniform sampler2D pbr_normalSampler;\n#endif\n#ifdef HAS_EMISSIVEMAP\nuniform sampler2D pbr_emissiveSampler;\n#endif\n#ifdef HAS_METALROUGHNESSMAP\nuniform sampler2D pbr_metallicRoughnessSampler;\n#endif\n#ifdef HAS_OCCLUSIONMAP\nuniform sampler2D pbr_occlusionSampler;\n#endif\n#ifdef USE_IBL\nuniform samplerCube pbr_diffuseEnvSampler;\nuniform samplerCube pbr_specularEnvSampler;\nuniform sampler2D pbr_brdfLUT;\n#endif\n\n// Inputs from vertex shader\n\nin vec3 pbr_vPosition;\nin vec2 pbr_vUV;\n\n#ifdef HAS_NORMALS\n#ifdef HAS_TANGENTS\nin mat3 pbr_vTBN;\n#else\nin vec3 pbr_vNormal;\n#endif\n#endif\n\n// Encapsulate the various inputs used by the various functions in the shading equation\n// We store values in this struct to simplify the integration of alternative implementations\n// of the shading terms, outlined in the Readme.MD Appendix.\nstruct PBRInfo {\n float NdotL; // cos angle between normal and light direction\n float NdotV; // cos angle between normal and view direction\n float NdotH; // cos angle between normal and half vector\n float LdotH; // cos angle between light direction and half vector\n float VdotH; // cos angle between view direction and half vector\n float perceptualRoughness; // roughness value, as authored by the model creator (input to shader)\n float metalness; // metallic value at the surface\n vec3 reflectance0; // full reflectance color (normal incidence angle)\n vec3 reflectance90; // reflectance color at grazing angle\n float alphaRoughness; // roughness mapped to a more linear change in the roughness (proposed by [2])\n vec3 diffuseColor; // color contribution from diffuse lighting\n vec3 specularColor; // color contribution from specular lighting\n vec3 n; // normal at surface point\n vec3 v; // vector from surface point to camera\n};\n\nconst float M_PI = 3.141592653589793;\nconst float c_MinRoughness = 0.04;\n\nvec4 SRGBtoLINEAR(vec4 srgbIn)\n{\n#ifdef MANUAL_SRGB\n#ifdef SRGB_FAST_APPROXIMATION\n vec3 linOut = pow(srgbIn.xyz,vec3(2.2));\n#else // SRGB_FAST_APPROXIMATION\n vec3 bLess = step(vec3(0.04045),srgbIn.xyz);\n vec3 linOut = mix( srgbIn.xyz/vec3(12.92), pow((srgbIn.xyz+vec3(0.055))/vec3(1.055),vec3(2.4)), bLess );\n#endif //SRGB_FAST_APPROXIMATION\n return vec4(linOut,srgbIn.w);;\n#else //MANUAL_SRGB\n return srgbIn;\n#endif //MANUAL_SRGB\n}\n\n// Find the normal for this fragment, pulling either from a predefined normal map\n// or from the interpolated mesh normal and tangent attributes.\nvec3 getNormal()\n{\n // Retrieve the tangent space matrix\n#ifndef HAS_TANGENTS\n vec3 pos_dx = dFdx(pbr_vPosition);\n vec3 pos_dy = dFdy(pbr_vPosition);\n vec3 tex_dx = dFdx(vec3(pbr_vUV, 0.0));\n vec3 tex_dy = dFdy(vec3(pbr_vUV, 0.0));\n vec3 t = (tex_dy.t * pos_dx - tex_dx.t * pos_dy) / (tex_dx.s * tex_dy.t - tex_dy.s * tex_dx.t);\n\n#ifdef HAS_NORMALS\n vec3 ng = normalize(pbr_vNormal);\n#else\n vec3 ng = cross(pos_dx, pos_dy);\n#endif\n\n t = normalize(t - ng * dot(ng, t));\n vec3 b = normalize(cross(ng, t));\n mat3 tbn = mat3(t, b, ng);\n#else // HAS_TANGENTS\n mat3 tbn = pbr_vTBN;\n#endif\n\n#ifdef HAS_NORMALMAP\n vec3 n = texture(pbr_normalSampler, pbr_vUV).rgb;\n n = normalize(tbn * ((2.0 * n - 1.0) * vec3(pbrMaterial.normalScale, pbrMaterial.normalScale, 1.0)));\n#else\n // The tbn matrix is linearly interpolated, so we need to re-normalize\n vec3 n = normalize(tbn[2].xyz);\n#endif\n\n return n;\n}\n\n// Calculation of the lighting contribution from an optional Image Based Light source.\n// Precomputed Environment Maps are required uniform inputs and are computed as outlined in [1].\n// See our README.md on Environment Maps [3] for additional discussion.\n#ifdef USE_IBL\nvec3 getIBLContribution(PBRInfo pbrInfo, vec3 n, vec3 reflection)\n{\n float mipCount = 9.0; // resolution of 512x512\n float lod = (pbrInfo.perceptualRoughness * mipCount);\n // retrieve a scale and bias to F0. See [1], Figure 3\n vec3 brdf = SRGBtoLINEAR(texture(pbr_brdfLUT,\n vec2(pbrInfo.NdotV, 1.0 - pbrInfo.perceptualRoughness))).rgb;\n vec3 diffuseLight = SRGBtoLINEAR(texture(pbr_diffuseEnvSampler, n)).rgb;\n\n#ifdef USE_TEX_LOD\n vec3 specularLight = SRGBtoLINEAR(texture(pbr_specularEnvSampler, reflection, lod)).rgb;\n#else\n vec3 specularLight = SRGBtoLINEAR(texture(pbr_specularEnvSampler, reflection)).rgb;\n#endif\n\n vec3 diffuse = diffuseLight * pbrInfo.diffuseColor;\n vec3 specular = specularLight * (pbrInfo.specularColor * brdf.x + brdf.y);\n\n // For presentation, this allows us to disable IBL terms\n diffuse *= pbrMaterial.scaleIBLAmbient.x;\n specular *= pbrMaterial.scaleIBLAmbient.y;\n\n return diffuse + specular;\n}\n#endif\n\n// Basic Lambertian diffuse\n// Implementation from Lambert's Photometria https://archive.org/details/lambertsphotome00lambgoog\n// See also [1], Equation 1\nvec3 diffuse(PBRInfo pbrInfo)\n{\n return pbrInfo.diffuseColor / M_PI;\n}\n\n// The following equation models the Fresnel reflectance term of the spec equation (aka F())\n// Implementation of fresnel from [4], Equation 15\nvec3 specularReflection(PBRInfo pbrInfo)\n{\n return pbrInfo.reflectance0 +\n (pbrInfo.reflectance90 - pbrInfo.reflectance0) *\n pow(clamp(1.0 - pbrInfo.VdotH, 0.0, 1.0), 5.0);\n}\n\n// This calculates the specular geometric attenuation (aka G()),\n// where rougher material will reflect less light back to the viewer.\n// This implementation is based on [1] Equation 4, and we adopt their modifications to\n// alphaRoughness as input as originally proposed in [2].\nfloat geometricOcclusion(PBRInfo pbrInfo)\n{\n float NdotL = pbrInfo.NdotL;\n float NdotV = pbrInfo.NdotV;\n float r = pbrInfo.alphaRoughness;\n\n float attenuationL = 2.0 * NdotL / (NdotL + sqrt(r * r + (1.0 - r * r) * (NdotL * NdotL)));\n float attenuationV = 2.0 * NdotV / (NdotV + sqrt(r * r + (1.0 - r * r) * (NdotV * NdotV)));\n return attenuationL * attenuationV;\n}\n\n// The following equation(s) model the distribution of microfacet normals across\n// the area being drawn (aka D())\n// Implementation from \"Average Irregularity Representation of a Roughened Surface\n// for Ray Reflection\" by T. S. Trowbridge, and K. P. Reitz\n// Follows the distribution function recommended in the SIGGRAPH 2013 course notes\n// from EPIC Games [1], Equation 3.\nfloat microfacetDistribution(PBRInfo pbrInfo)\n{\n float roughnessSq = pbrInfo.alphaRoughness * pbrInfo.alphaRoughness;\n float f = (pbrInfo.NdotH * roughnessSq - pbrInfo.NdotH) * pbrInfo.NdotH + 1.0;\n return roughnessSq / (M_PI * f * f);\n}\n\nvoid PBRInfo_setAmbientLight(inout PBRInfo pbrInfo) {\n pbrInfo.NdotL = 1.0;\n pbrInfo.NdotH = 0.0;\n pbrInfo.LdotH = 0.0;\n pbrInfo.VdotH = 1.0;\n}\n\nvoid PBRInfo_setDirectionalLight(inout PBRInfo pbrInfo, vec3 lightDirection) {\n vec3 n = pbrInfo.n;\n vec3 v = pbrInfo.v;\n vec3 l = normalize(lightDirection); // Vector from surface point to light\n vec3 h = normalize(l+v); // Half vector between both l and v\n\n pbrInfo.NdotL = clamp(dot(n, l), 0.001, 1.0);\n pbrInfo.NdotH = clamp(dot(n, h), 0.0, 1.0);\n pbrInfo.LdotH = clamp(dot(l, h), 0.0, 1.0);\n pbrInfo.VdotH = clamp(dot(v, h), 0.0, 1.0);\n}\n\nvoid PBRInfo_setPointLight(inout PBRInfo pbrInfo, PointLight pointLight) {\n vec3 light_direction = normalize(pointLight.position - pbr_vPosition);\n PBRInfo_setDirectionalLight(pbrInfo, light_direction);\n}\n\nvec3 calculateFinalColor(PBRInfo pbrInfo, vec3 lightColor) {\n // Calculate the shading terms for the microfacet specular shading model\n vec3 F = specularReflection(pbrInfo);\n float G = geometricOcclusion(pbrInfo);\n float D = microfacetDistribution(pbrInfo);\n\n // Calculation of analytical lighting contribution\n vec3 diffuseContrib = (1.0 - F) * diffuse(pbrInfo);\n vec3 specContrib = F * G * D / (4.0 * pbrInfo.NdotL * pbrInfo.NdotV);\n // Obtain final intensity as reflectance (BRDF) scaled by the energy of the light (cosine law)\n return pbrInfo.NdotL * lightColor * (diffuseContrib + specContrib);\n}\n\nvec4 pbr_filterColor(vec4 colorUnused)\n{\n // The albedo may be defined from a base texture or a flat color\n#ifdef HAS_BASECOLORMAP\n vec4 baseColor = SRGBtoLINEAR(texture(pbr_baseColorSampler, pbr_vUV)) * pbrMaterial.baseColorFactor;\n#else\n vec4 baseColor = pbrMaterial.baseColorFactor;\n#endif\n\n#ifdef ALPHA_CUTOFF\n if (baseColor.a < pbrMaterial.alphaCutoff) {\n discard;\n }\n#endif\n\n vec3 color = vec3(0, 0, 0);\n\n if(pbrMaterial.unlit){\n color.rgb = baseColor.rgb;\n }\n else{\n // Metallic and Roughness material properties are packed together\n // In glTF, these factors can be specified by fixed scalar values\n // or from a metallic-roughness map\n float perceptualRoughness = pbrMaterial.metallicRoughnessValues.y;\n float metallic = pbrMaterial.metallicRoughnessValues.x;\n#ifdef HAS_METALROUGHNESSMAP\n // Roughness is stored in the 'g' channel, metallic is stored in the 'b' channel.\n // This layout intentionally reserves the 'r' channel for (optional) occlusion map data\n vec4 mrSample = texture(pbr_metallicRoughnessSampler, pbr_vUV);\n perceptualRoughness = mrSample.g * perceptualRoughness;\n metallic = mrSample.b * metallic;\n#endif\n perceptualRoughness = clamp(perceptualRoughness, c_MinRoughness, 1.0);\n metallic = clamp(metallic, 0.0, 1.0);\n // Roughness is authored as perceptual roughness; as is convention,\n // convert to material roughness by squaring the perceptual roughness [2].\n float alphaRoughness = perceptualRoughness * perceptualRoughness;\n\n vec3 f0 = vec3(0.04);\n vec3 diffuseColor = baseColor.rgb * (vec3(1.0) - f0);\n diffuseColor *= 1.0 - metallic;\n vec3 specularColor = mix(f0, baseColor.rgb, metallic);\n\n // Compute reflectance.\n float reflectance = max(max(specularColor.r, specularColor.g), specularColor.b);\n\n // For typical incident reflectance range (between 4% to 100%) set the grazing\n // reflectance to 100% for typical fresnel effect.\n // For very low reflectance range on highly diffuse objects (below 4%),\n // incrementally reduce grazing reflecance to 0%.\n float reflectance90 = clamp(reflectance * 25.0, 0.0, 1.0);\n vec3 specularEnvironmentR0 = specularColor.rgb;\n vec3 specularEnvironmentR90 = vec3(1.0, 1.0, 1.0) * reflectance90;\n\n vec3 n = getNormal(); // normal at surface point\n vec3 v = normalize(pbrProjection.camera - pbr_vPosition); // Vector from surface point to camera\n\n float NdotV = clamp(abs(dot(n, v)), 0.001, 1.0);\n vec3 reflection = -normalize(reflect(v, n));\n\n PBRInfo pbrInfo = PBRInfo(\n 0.0, // NdotL\n NdotV,\n 0.0, // NdotH\n 0.0, // LdotH\n 0.0, // VdotH\n perceptualRoughness,\n metallic,\n specularEnvironmentR0,\n specularEnvironmentR90,\n alphaRoughness,\n diffuseColor,\n specularColor,\n n,\n v\n );\n\n\n#ifdef USE_LIGHTS\n // Apply ambient light\n PBRInfo_setAmbientLight(pbrInfo);\n color += calculateFinalColor(pbrInfo, lighting.ambientColor);\n\n // Apply directional light\n for(int i = 0; i < lighting.directionalLightCount; i++) {\n if (i < lighting.directionalLightCount) {\n PBRInfo_setDirectionalLight(pbrInfo, lighting_getDirectionalLight(i).direction);\n color += calculateFinalColor(pbrInfo, lighting_getDirectionalLight(i).color);\n }\n }\n\n // Apply point light\n for(int i = 0; i < lighting.pointLightCount; i++) {\n if (i < lighting.pointLightCount) {\n PBRInfo_setPointLight(pbrInfo, lighting_getPointLight(i));\n float attenuation = getPointLightAttenuation(lighting_getPointLight(i), distance(lighting_getPointLight(i).position, pbr_vPosition));\n color += calculateFinalColor(pbrInfo, lighting_getPointLight(i).color / attenuation);\n }\n }\n#endif\n\n // Calculate lighting contribution from image based lighting source (IBL)\n#ifdef USE_IBL\n if (pbrMaterial.IBLenabled) {\n color += getIBLContribution(pbrInfo, n, reflection);\n }\n#endif\n\n // Apply optional PBR terms for additional (optional) shading\n#ifdef HAS_OCCLUSIONMAP\n if (pbrMaterial.occlusionMapEnabled) {\n float ao = texture(pbr_occlusionSampler, pbr_vUV).r;\n color = mix(color, color * ao, pbrMaterial.occlusionStrength);\n }\n#endif\n\n#ifdef HAS_EMISSIVEMAP\n if (pbrMaterial.emissiveMapEnabled) {\n vec3 emissive = SRGBtoLINEAR(texture(pbr_emissiveSampler, pbr_vUV)).rgb * pbrMaterial.emissiveFactor;\n color += emissive;\n }\n#endif\n\n // This section uses mix to override final color for reference app visualization\n // of various parameters in the lighting equation.\n#ifdef PBR_DEBUG\n // TODO: Figure out how to debug multiple lights\n\n // color = mix(color, F, pbr_scaleFGDSpec.x);\n // color = mix(color, vec3(G), pbr_scaleFGDSpec.y);\n // color = mix(color, vec3(D), pbr_scaleFGDSpec.z);\n // color = mix(color, specContrib, pbr_scaleFGDSpec.w);\n\n // color = mix(color, diffuseContrib, pbr_scaleDiffBaseMR.x);\n color = mix(color, baseColor.rgb, pbrMaterial.scaleDiffBaseMR.y);\n color = mix(color, vec3(metallic), pbrMaterial.scaleDiffBaseMR.z);\n color = mix(color, vec3(perceptualRoughness), pbrMaterial.scaleDiffBaseMR.w);\n#endif\n\n }\n\n return vec4(pow(color,vec3(1.0/2.2)), baseColor.a);\n}\n`;\n//# sourceMappingURL=pbr-material-glsl.js.map","// luma.gl\n// SPDX-License-Identifier: MIT\n// Copyright (c) vis.gl contributors\n// Attribution:\n// MIT license, Copyright (c) 2016-2017 Mohamad Moneimne and Contributors\n// This fragment shader defines a reference implementation for Physically Based Shading of\n// a microfacet surface material defined by a glTF model.\n// TODO - better do the checks outside of shader\nexport const pbrMaterialUniforms = /* wgsl */ `\\\nuniform Projection {\n // Projection\n vec3 u_Camera;\n};\n\nuniform pbrMaterialUniforms {\n // Material is unlit\n bool unlit;\n\n // Base color map\n bool baseColorMapEnabled;\n vec4 baseColorFactor;\n\n bool normalMapEnabled; \n float normalScale; // #ifdef HAS_NORMALMAP\n\n bool emissiveMapEnabled;\n vec3 emissiveFactor; // #ifdef HAS_EMISSIVEMAP\n\n vec2 metallicRoughnessValues;\n bool metallicRoughnessMapEnabled;\n\n bool occlusionMapEnabled;\n float occlusionStrength; // #ifdef HAS_OCCLUSIONMAP\n \n bool alphaCutoffEnabled;\n float alphaCutoff; // #ifdef ALPHA_CUTOFF\n \n // IBL\n bool IBLenabled;\n vec2 scaleIBLAmbient; // #ifdef USE_IBL\n \n // debugging flags used for shader output of intermediate PBR variables\n // #ifdef PBR_DEBUG\n vec4 scaleDiffBaseMR;\n vec4 scaleFGDSpec;\n // #endif\n};\n\n// Samplers\n#ifdef HAS_BASECOLORMAP\nuniform sampler2D u_BaseColorSampler;\n#endif\n#ifdef HAS_NORMALMAP\nuniform sampler2D u_NormalSampler;\n#endif\n#ifdef HAS_EMISSIVEMAP\nuniform sampler2D u_EmissiveSampler;\n#endif\n#ifdef HAS_METALROUGHNESSMAP\nuniform sampler2D u_MetallicRoughnessSampler;\n#endif\n#ifdef HAS_OCCLUSIONMAP\nuniform sampler2D u_OcclusionSampler;\n#endif\n#ifdef USE_IBL\nuniform samplerCube u_DiffuseEnvSampler;\nuniform samplerCube u_SpecularEnvSampler;\nuniform sampler2D u_brdfLUT;\n#endif\n\n`;\nexport const source = /* wgsl */ `\\\nstruct PBRFragmentInputs {\n pbr_vPosition: vec3f,\n pbr_vUV: vec2f,\n pbr_vTBN: mat3f,\n pbr_vNormal: vec3f\n};\n\nvar fragmentInputs: PBRFragmentInputs;\n\nfn pbr_setPositionNormalTangentUV(position: vec4f, normal: vec4f, tangent: vec4f, uv: vec2f)\n{\n var pos: vec4f = pbrProjection.modelMatrix * position;\n pbr_vPosition = vec3(pos.xyz) / pos.w;\n\n#ifdef HAS_NORMALS\n#ifdef HAS_TANGENTS\n let normalW: vec3f = normalize(vec3(pbrProjection.normalMatrix * vec4(normal.xyz, 0.0)));\n let tangentW: vec3f = normalize(vec3(pbrProjection.modelMatrix * vec4(tangent.xyz, 0.0)));\n let bitangentW: vec3f = cross(normalW, tangentW) * tangent.w;\n fragmentInputs,pbr_vTBN = mat3(tangentW, bitangentW, normalW);\n#else // HAS_TANGENTS != 1\n fragmentInputs.pbr_vNormal = normalize(vec3(pbrProjection.modelMatrix * vec4(normal.xyz, 0.0)));\n#endif\n#endif\n\n#ifdef HAS_UV\n pbr_vUV = uv;\n#else\n pbr_vUV = vec2(0.,0.);\n#endif\n}\n\nstruct pbrMaterialUniforms {\n // Material is unlit\n unlit: uint32,\n\n // Base color map\n baseColorMapEnabled: uint32,\n baseColorFactor: vec4f,\n\n normalMapEnabled : uint32,\n normalScale: f32, // #ifdef HAS_NORMALMAP\n\n emissiveMapEnabled: uint32,\n emissiveFactor: vec3f, // #ifdef HAS_EMISSIVEMAP\n\n metallicRoughnessValues: vec2f,\n metallicRoughnessMapEnabled: uint32,\n\n occlusionMapEnabled: i32,\n occlusionStrength: f32, // #ifdef HAS_OCCLUSIONMAP\n \n alphaCutoffEnabled: i32,\n alphaCutoff: f32, // #ifdef ALPHA_CUTOFF\n \n // IBL\n IBLenabled: i32,\n scaleIBLAmbient: vec2f, // #ifdef USE_IBL\n \n // debugging flags used for shader output of intermediate PBR variables\n // #ifdef PBR_DEBUG\n scaleDiffBaseMR: vec4f,\n scaleFGDSpec: vec4f\n // #endif\n} \n \n@binding(2) @group(0) var<uniform> material : pbrMaterialUniforms;\n\n// Samplers\n#ifdef HAS_BASECOLORMAP\nuniform sampler2D pbr_baseColorSampler;\n#endif\n#ifdef HAS_NORMALMAP\nuniform sampler2D pbr_normalSampler;\n#endif\n#ifdef HAS_EMISSIVEMAP\nuniform sampler2D pbr_emissiveSampler;\n#endif\n#ifdef HAS_METALROUGHNESSMAP\nuniform sampler2D pbr_metallicRoughnessSampler;\n#endif\n#ifdef HAS_OCCLUSIONMAP\nuniform sampler2D pbr_occlusionSampler;\n#endif\n#ifdef USE_IBL\nuniform samplerCube pbr_diffuseEnvSampler;\nuniform samplerCube pbr_specularEnvSampler;\nuniform sampler2D pbr_brdfLUT;\n#endif\n\n// Encapsulate the various inputs used by the various functions in the shading equation\n// We store values in this struct to simplify the integration of alternative implementations\n// of the shading terms, outlined in the Readme.MD Appendix.\nstruct PBRInfo {\n NdotL: f32, // cos angle between normal and light direction\n NdotV: f32, // cos angle between normal and view direction\n NdotH: f32, // cos angle between normal and half vector\n LdotH: f32, // cos angle between light direction and half vector\n VdotH: f32, // cos angle between view direction and half vector\n perceptualRoughness: f32, // roughness value, as authored by the model creator (input to shader)\n metalness: f32, // metallic value at the surface\n reflectance0: vec3f, // full reflectance color (normal incidence angle)\n reflectance90: vec3f, // reflectance color at grazing angle\n alphaRoughness: f32, // roughness mapped to a more linear change in the roughness (proposed by [2])\n diffuseColor: vec3f, // color contribution from diffuse lighting\n specularColor: vec3f, // color contribution from specular lighting\n n: vec3f, // normal at surface point\n v: vec3f, // vector from surface point to camera\n};\n\nconst M_PI = 3.141592653589793;\nconst c_MinRoughness = 0.04;\n\nfn SRGBtoLINEAR(srgbIn: vec4f ) -> vec4f\n{\n#ifdef MANUAL_SRGB\n#ifdef SRGB_FAST_APPROXIMATION\n var linOut: vec3f = pow(srgbIn.xyz,vec3(2.2));\n#else // SRGB_FAST_APPROXIMATION\n var bLess: vec3f = step(vec3(0.04045),srgbIn.xyz);\n var linOut: vec3f = mix( srgbIn.xyz/vec3(12.92), pow((srgbIn.xyz+vec3(0.055))/vec3(1.055),vec3(2.4)), bLess );\n#endif //SRGB_FAST_APPROXIMATION\n return vec4f(linOut,srgbIn.w);;\n#else //MANUAL_SRGB\n return srgbIn;\n#endif //MANUAL_SRGB\n}\n\n// Find the normal for this fragment, pulling either from a predefined normal map\n// or from the interpolated mesh normal and tangent attributes.\nfn getNormal() -> vec3f\n{\n // Retrieve the tangent space matrix\n#ifndef HAS_TANGENTS\n var pos_dx: vec3f = dFdx(pbr_vPosition);\n var pos_dy: vec3f = dFdy(pbr_vPosition);\n var tex_dx: vec3f = dFdx(vec3(pbr_vUV, 0.0));\n var tex_dy: vec3f = dFdy(vec3(pbr_vUV, 0.0));\n var t: vec3f = (tex_dy.t * pos_dx - tex_dx.t * pos_dy) / (tex_dx.s * tex_dy.t - tex_dy.s * tex_dx.t);\n\n#ifdef HAS_NORMALS\n var ng: vec3f = normalize(pbr_vNormal);\n#else\n var ng: vec3f = cross(pos_dx, pos_dy);\n#endif\n\n t = normalize(t - ng * dot(ng, t));\n var b: vec3f = normalize(cross(ng, t));\n var tbn: mat3f = mat3f(t, b, ng);\n#else // HAS_TANGENTS\n var tbn: mat3f = pbr_vTBN;\n#endif\n\n#ifdef HAS_NORMALMAP\n vec3 n = texture(pbr_normalSampler, pbr_vUV).rgb;\n n = normalize(tbn * ((2.0 * n - 1.0) * vec3(pbrMaterial.normalScale, pbrMaterial.normalScale, 1.0)));\n#else\n // The tbn matrix is linearly interpolated, so we need to re-normalize\n vec3 n = normalize(tbn[2].xyz);\n#endif\n\n return n;\n}\n\n// Calculation of the lighting contribution from an optional Image Based Light source.\n// Precomputed Environment Maps are required uniform inputs and are computed as outlined in [1].\n// See our README.md on Environment Maps [3] for additional discussion.\n#ifdef USE_IBL\nfn getIBLContribution(PBRInfo pbrInfo, vec3 n, vec3 reflection) -> vec3f\n{\n float mipCount = 9.0; // resolution of 512x512\n float lod = (pbrInfo.perceptualRoughness * mipCount);\n // retrieve a scale and bias to F0. See [1], Figure 3\n vec3 brdf = SRGBtoLINEAR(texture(pbr_brdfLUT,\n vec2(pbrInfo.NdotV, 1.0 - pbrInfo.perceptualRoughness))).rgb;\n vec3 diffuseLight = SRGBtoLINEAR(texture(pbr_diffuseEnvSampler, n)).rgb;\n\n#ifdef USE_TEX_LOD\n vec3 specularLight = SRGBtoLINEAR(texture(pbr_specularEnvSampler, reflection, lod)).rgb;\n#else\n vec3 specularLight = SRGBtoLINEAR(texture(pbr_specularEnvSampler, reflection)).rgb;\n#endif\n\n vec3 diffuse = diffuseLight * pbrInfo.diffuseColor;\n vec3 specular = specularLight * (pbrInfo.specularColor * brdf.x + brdf.y);\n\n // For presentation, this allows us to disable IBL terms\n diffuse *= pbrMaterial.scaleIBLAmbient.x;\n specular *= pbrMaterial.scaleIBLAmbient.y;\n\n return diffuse + specular;\n}\n#endif\n\n// Basic Lambertian diffuse\n// Implementation from Lambert's Photometria https://archive.org/details/lambertsphotome00lambgoog\n// See also [1], Equation 1\nfn diffuse(pbrInfo: PBRInfo) -> vec3<f32> {\n return pbrInfo.diffuseColor / PI;\n}\n\n// The following equation models the Fresnel reflectance term of the spec equation (aka F())\n// Implementation of fresnel from [4], Equation 15\nfn specularReflection(pbrInfo: PBRInfo) -> vec3<f32> {\n return pbrInfo.reflectance0 +\n (pbrInfo.reflectance90 - pbrInfo.reflectance0) *\n pow(clamp(1.0 - pbrInfo.VdotH, 0.0, 1.0), 5.0);\n}\n\n// This calculates the specular geometric attenuation (aka G()),\n// where rougher material will reflect less light back to the viewer.\n// This implementation is based on [1] Equation 4, and we adopt their modifications to\n// alphaRoughness as input as originally proposed in [2].\nfn geometricOcclusion(pbrInfo: PBRInfo) -> f32 {\n let NdotL: f32 = pbrInfo.NdotL;\n let NdotV: f32 = pbrInfo.NdotV;\n let r: f32 = pbrInfo.alphaRoughness;\n\n let attenuationL = 2.0 * NdotL / (NdotL + sqrt(r * r + (1.0 - r * r) * (NdotL * NdotL)));\n let attenuationV = 2.0 * NdotV / (NdotV + sqrt(r * r + (1.0 - r * r) * (NdotV * NdotV)));\n return attenuationL * attenuationV;\n}\n\n// The following equation(s) model the distribution of microfacet normals across\n// the area being drawn (aka D())\n// Implementation from \"Average Irregularity Representation of a Roughened Surface\n// for Ray Reflection\" by T. S. Trowbridge, and K. P. Reitz\n// Follows the distribution function recommended in the SIGGRAPH 2013 course notes\n// from EPIC Games [1], Equation 3.\nfn microfacetDistribution(pbrInfo: PBRInfo) -> f32 {\n let roughnessSq = pbrInfo.alphaRoughness * pbrInfo.alphaRoughness;\n let f = (pbrInfo.NdotH * roughnessSq - pbrInfo.NdotH) * pbrInfo.NdotH + 1.0;\n return roughnessSq / (PI * f * f);\n}\n\nfn PBRInfo_setAmbientLight(pbrInfo: ptr<function, PBRInfo>) {\n (*pbrInfo).NdotL = 1.0;\n (*pbrInfo).NdotH = 0.0;\n (*pbrInfo).LdotH = 0.0;\n (*pbrInfo).VdotH = 1.0;\n}\n\nfn PBRInfo_setDirectionalLight(pbrInfo: ptr<function, PBRInfo>, lightDirection: vec3<f32>) {\n let n = (*pbrInfo).n;\n let v = (*pbrInfo).v;\n let l = normalize(lightDirection); // Vector from surface point to light\n let h = normalize(l + v); // Half vector between both l and v\n\n (*pbrInfo).NdotL = clamp(dot(n, l), 0.001, 1.0);\n (*pbrInfo).NdotH = clamp(dot(n, h), 0.0, 1.0);\n (*pbrInfo).LdotH = clamp(dot(l, h), 0.0, 1.0);\n (*pbrInfo).VdotH = clamp(dot(v, h), 0.0, 1.0);\n}\n\nfn PBRInfo_setPointLight(pbrInfo: ptr<function, PBRInfo>, pointLight: PointLight) {\n let light_direction = normalize(pointLight.position - pbr_vPosition);\n PBRInfo_setDirectionalLight(pbrInfo, light_direction);\n}\n\nfn calculateFinalColor(pbrInfo: PBRInfo, lightColor: vec3<f32>) -> vec3<f32> {\n // Calculate the shading terms for the microfacet specular shading model\n let F = specularReflection(pbrInfo);\n let G = geometricOcclusion(pbrInfo);\n let D = microfacetDistribution(pbrInfo);\n\n // Calculation of analytical lighting contribution\n let diffuseContrib = (1.0 - F) * diffuse(pbrInfo);\n let specContrib = F * G * D / (4.0 * pbrInfo.NdotL * pbrInfo.NdotV);\n // Obtain final intensity as reflectance (BRDF) scaled by the energy of the light (cosine law)\n return pbrInfo.NdotL * lightColor * (diffuseContrib + specContrib);\n}\n\nfn pbr_filterColor(colorUnused: vec4<f32>) -> vec4<f32> {\n // The albedo may be defined from a base texture or a flat color\n var baseColor: vec4<f32>;\n #ifdef HAS_BASECOLORMAP\n baseColor = SRGBtoLINEAR(textureSample(pbr_baseColorSampler, pbr_baseColorSampler, pbr_vUV)) * pbrMaterial.baseColorFactor;\n #else\n baseColor = pbrMaterial.baseColorFactor;\n #endif\n\n #ifdef ALPHA_CUTOFF\n if (baseColor.a < pbrMaterial.alphaCutoff) {\n discard;\n }\n #endif\n\n var color = vec3<f32>(0.0, 0.0, 0.0);\n\n if (pbrMaterial.unlit) {\n color = baseColor.rgb;\n } else {\n // Metallic and Roughness material properties are packed together\n // In glTF, these factors can be specified by fixed scalar values\n // or from a metallic-roughness map\n var perceptualRoughness = pbrMaterial.metallicRoughnessValues.y;\n var metallic = pbrMaterial.metallicRoughnessValues.x;\n #ifdef HAS_METALROUGHNESSMAP\n // Roughness is stored in the 'g' channel, metallic is stored in the 'b' channel.\n // This layout intentionally reserves the 'r' channel for (optional) occlusion map data\n let mrSample = textureSample(pbr_metallicRoughnessSampler, pbr_metallicRoughnessSampler, pbr_vUV);\n perceptualRoughness = mrSample.g * perceptualRoughness;\n metallic = mrSample.b * metallic;\n #endif\n perceptualRoughness = clamp(perceptualRoughness, c_MinRoughness, 1.0);\n metallic = clamp(metallic, 0.0, 1.0);\n // Roughness is authored as perceptual roughness; as is convention,\n // convert to material roughness by squaring the perceptual roughness [2].\n let alphaRoughness = perceptualRoughness * perceptualRoughness;\n\n let f0 = vec3<f32>(0.04);\n var diffuseColor = baseColor.rgb * (vec3<f32>(1.0) - f0);\n diffuseColor *= 1.0 - metallic;\n let specularColor = mix(f0, baseColor.rgb, metallic);\n\n // Compute reflectance.\n let reflectance = max(max(specularColor.r, specularColor.g), specularColor.b);\n\n // For typical incident reflectance range (between 4% to 100%) set the grazing\n // reflectance to 100% for typical fresnel effect.\n // For very low reflectance range on highly diffuse objects (below 4%),\n // incrementally reduce grazing reflectance to 0%.\n let reflectance90 = clamp(reflectance * 25.0, 0.0, 1.0);\n let specularEnvironmentR0 = specularColor;\n let specularEnvironmentR90 = vec3<f32>(1.0, 1.0, 1.0) * reflectance90;\n\n let n = getNormal(); // normal at surface point\n let v = normalize(pbrProjection.camera - pbr_vPosition); // Vector from surface point to camera\n\n let NdotV = clamp(abs(dot(n, v)), 0.001, 1.0);\n let reflection = -normalize(reflect(v, n));\n\n var pbrInfo = PBRInfo(\n 0.0, // NdotL\n NdotV,\n 0.0, // NdotH\n 0.0, // LdotH\n 0.0, // VdotH\n perceptualRoughness,\n metallic,\n specularEnvironmentR0,\n specularEnvironmentR90,\n alphaRoughness,\n diffuseColor,\n specularColor,\n n,\n v\n );\n\n #ifdef USE_LIGHTS\n // Apply ambient light\n PBRInfo_setAmbientLight(&pbrInfo);\n color += calculateFinalColor(pbrInfo, lighting.ambientColor);\n\n // Apply directional light\n for (var i = 0; i < lighting.directionalLightCount; i++) {\n if (i < lighting.directionalLightCount) {\n PBRInfo_setDirectionalLight(&pbrInfo, lighting_getDirectionalLight(i).direction);\n color += calculateFinalColor(pbrInfo, lighting_getDirectionalLight(i).color);\n }\n }\n\n // Apply point light\n for (var i = 0; i < lighting.pointLightCount; i++) {\n if (i < lighting.pointLightCount) {\n PBRInfo_setPointLight(&pbrInfo, lighting_getPointLight(i));\n let attenuation = getPointLightAttenuation(lighting_getPointLight(i), distance(lighting_getPointLight(i).position, pbr_vPosition));\n color += calculateFinalColor(pbrInfo, lighting_getPointLight(i).color / attenuation);\n }\n }\n #endif\n\n // Calculate lighting contribution from image based lighting source (IBL)\n #ifdef USE_IBL\n if (pbrMaterial.IBLenabled) {\n color += getIBLContribution(pbrInfo, n, reflection);\n }\n #endif\n\n // Apply optional PBR terms for additional (optional) shading\n #ifdef HAS_OCCLUSIONMAP\n if (pbrMaterial.occlusionMapEnabled) {\n let ao = textureSample(pbr_occlusionSampler, pbr_occlusionSampler, pbr_vUV).r;\n color = mix(color, color * ao, pbrMaterial.occlusionStrength);\n }\n #endif\n\n #ifdef HAS_EMISSIVEMAP\n if (pbrMaterial.emissiveMapEnabled) {\n let emissive = SRGBtoLINEAR(textureSample(pbr_emissiveSampler, pbr_emissiveSampler, pbr_vUV)).rgb * pbrMaterial.emissiveFactor;\n color += emissive;\n }\n #endif\n\n // This section uses mix to override final color for reference app visualization\n // of various parameters in the lighting equation.\n #ifdef PBR_DEBUG\n // TODO: Figure out how to debug multiple lights\n\n // color = mix(color, F, pbr_scaleFGDSpec.x);\n // color = mix(color, vec3(G), pbr_scaleFGDSpec.y);\n // color = mix(color, vec3(D), pbr_scaleFGDSpec.z);\n // color = mix(color, specContrib, pbr_scaleFGDSpec.w);\n\n // color = mix(color, diffuseContrib, pbr_scaleDiffBaseMR.x);\n color = mix(color, baseColor.rgb, pbrMaterial.scaleDiffBaseMR.y);\n color = mix(color, vec3<f32>(metallic), pbrMaterial.scaleDiffBaseMR.z);\n color = mix(color, vec3<f32>(perceptualRoughness), pbrMaterial.scaleDiffBaseMR.w);\n #endif\n }\n\n return vec4<f32>(pow(color, vec3<f32>(1.0 / 2.2)), baseColor.a);\n}\n`;\n//# sourceMappingURL=pbr-material-wgsl.js.map","// luma.gl\n// SPDX-License-Identifier: MIT\n// Copyright (c) vis.gl contributors\nconst uniformBlock = /* glsl */ `\\\nuniform pbrProjectionUniforms {\n mat4 modelViewProjectionMatrix;\n mat4 modelMatrix;\n mat4 normalMatrix;\n vec3 camera;\n} pbrProjection;\n`;\nexport const pbrProjection = {\n name: 'pbrProjection',\n vs: uniformBlock,\n fs: uniformBlock,\n // TODO why is this needed?\n getUniforms: props => props,\n uniformTypes: {\n modelViewProjectionMatrix: 'mat4x4<f32>',\n modelMatrix: 'mat4x4<f32>',\n normalMatrix: 'mat4x4<f32>',\n camera: 'vec3<i32>'\n }\n};\n//# sourceMappingURL=pbr-projection.js.map","// luma.gl\n// SPDX-License-Identifier: MIT\n// Copyright (c) vis.gl contributors\nimport { lighting } from \"../lights/lighting.js\";\nimport { vs, fs } from \"./pbr-material-glsl.js\";\nimport { source } from \"./pbr-material-wgsl.js\";\nimport { pbrProjection } from \"./pbr-projection.js\";\n/**\n * An implementation of PBR (Physically-Based Rendering).\n * Physically Based Shading of a microfacet surface defined by a glTF material.\n */\nexport const pbrMaterial = {\n props: {},\n uniforms: {},\n name: 'pbrMaterial',\n dependencies: [lighting, pbrProjection],\n source,\n vs,\n fs,\n defines: {\n LIGHTING_FRAGMENT: true,\n HAS_NORMALMAP: false,\n HAS_EMISSIVEMAP: false,\n HAS_OCCLUSIONMAP: false,\n HAS_BASECOLORMAP: false,\n HAS_METALROUGHNESSMAP: false,\n ALPHA_CUTOFF: false,\n USE_IBL: false,\n PBR_DEBUG: false\n },\n getUniforms: props => props,\n uniformTypes: {\n // Material is unlit\n unlit: 'i32',\n // Base color map\n baseColorMapEnabled: 'i32',\n baseColorFactor: 'vec4<f32>',\n normalMapEnabled: 'i32',\n normalScale: 'f32', // #ifdef HAS_NORMALMAP\n emissiveMapEnabled: 'i32',\n emissiveFactor: 'vec3<f32>', // #ifdef HAS_EMISSIVEMAP\n metallicRoughnessValues: 'vec2<f32>',\n metallicRoughnessMapEnabled: 'i32',\n occlusionMapEnabled: 'i32',\n occlusionStrength: 'f32', // #ifdef HAS_OCCLUSIONMAP\n alphaCutoffEnabled: 'i32',\n alphaCutoff: 'f32', // #ifdef ALPHA_CUTOFF\n // IBL\n IBLenabled: 'i32',\n scaleIBLAmbient: 'vec2<f32>', // #ifdef USE_IBL\n // debugging flags used for shader output of intermediate PBR variables\n // #ifdef PBR_DEBUG\n scaleDiffBaseMR: 'vec4<f32>',\n scaleFGDSpec: 'vec4<f32>'\n }\n};\n//# sourceMappingURL=pbr-material.js.map","// luma.gl\n// SPDX-License-Identifier: MIT\n// Copyright (c) vis.gl contributors\nimport { Vector3, Matrix4 } from '@math.gl/core';\nimport { uid } from \"../utils/uid.js\";\nexport class ScenegraphNode {\n id;\n matrix = new Matrix4();\n display = true;\n position = new Vector3();\n rotation = new Vector3();\n scale = new Vector3(1, 1, 1);\n userData = {};\n props = {};\n constructor(props = {}) {\n const { id } = props;\n this.id = id || uid(this.constructor.name);\n this._setScenegraphNodeProps(props);\n }\n getBounds() {\n return null;\n }\n destroy() { }\n /** @deprecated use .destroy() */\n delete() {\n this.destroy();\n }\n setProps(props) {\n this._setScenegraphNodeProps(props);\n return this;\n }\n toString() {\n return `{type: ScenegraphNode, id: ${this.id})}`;\n }\n setPosition(position) {\n // assert(position.length === 3, 'setPosition requires vector argument');\n this.position = position;\n return this;\n }\n setRotation(rotation) {\n // assert(rotation.length === 3, 'setRotation requires vector argument');\n this.rotation = rotation;\n return this;\n }\n setScale(scale) {\n // assert(scale.length === 3, 'setScale requires vector argument');\n this.scale = scale;\n return this;\n }\n setMatrix(matrix, copyMatrix = true) {\n if (copyMatrix) {\n this.matrix.copy(matrix);\n }\n else {\n this.matrix = matrix;\n }\n }\n setMatrixComponents(components) {\n const { position, rotation, scale, update = true } = components;\n if (position) {\n this.setPosition(position);\n }\n if (rotation) {\n this.setRotation(rotation);\n }\n if (scale) {\n this.setScale(scale);\n }\n if (update) {\n this.updateMatrix();\n }\n return this;\n }\n updateMatrix() {\n const pos = this.position;\n const rot = this.rotation;\n const scale = this.scale;\n this.matrix.identity();\n this.matrix.translate(pos);\n this.matrix.rotateXYZ(rot);\n this.matrix.scale(scale);\n return this;\n }\n update(options = {}) {\n const { position, rotation, scale } = options;\n if (position) {\n this.setPosition(position);\n }\n if (rotation) {\n this.setRotation(rotation);\n }\n if (scale) {\n this.setScale(scale);\n }\n this.updateMatrix();\n return this;\n }\n getCoordinateUniforms(viewMatrix, modelMatrix) {\n // TODO - solve multiple class problem\n // assert(viewMatrix instanceof Matrix4);\n // assert(viewMatrix);\n modelMatrix = modelMatrix || this.matrix;\n const worldMatrix = new Matrix4(viewMatrix).multiplyRight(modelMatrix);\n const worldInverse = worldMatrix.invert();\n const worldInverseTranspose = worldInverse.transpose();\n return {\n viewMatrix,\n modelMatrix,\n objectMatrix: modelMatrix,\n worldMatrix,\n worldInverseMatrix: worldInverse,\n worldInverseTransposeMatrix: worldInverseTranspose\n };\n }\n // TODO - copied code, not yet vetted\n /*\n transform() {\n if (!this.parent) {\n this.endPosition.set(this.position);\n this.endRotation.set(this.rotation);\n this.endScale.set(this.scale);\n } else {\n const parent = this.parent;\n this.endPosition.set(this.position.add(parent.endPosition));\n this.endRotation.set(this.rotation.add(parent.endRotation));\n this.endScale.set(this.scale.add(parent.endScale));\n }\n \n const ch = this.children;\n for (let i = 0; i < ch.length; ++i) {\n ch[i].transform();\n }\n \n return this;\n }\n */\n _setScenegraphNodeProps(props) {\n // if ('display' in props) {\n // this.display = props.display;\n // }\n if ('position' in props) {\n this.setPosition(props.position);\n }\n if ('rotation' in props) {\n this.setRotation(props.rotation);\n }\n if ('scale' in props) {\n this.setScale(props.scale);\n }\n // Matrix overwrites other props\n if ('matrix' in props) {\n this.setMatrix(props.matrix);\n }\n Object.assign(this.props, props);\n }\n}\n//# sourceMappingURL=scenegraph-node.js.map","// luma.gl\n// SPDX-License-Identifier: MIT\n// Copyright (c) vis.gl contributors\nimport { Matrix4, Vector3 } from '@math.gl/core';\nimport { log } from '@luma.gl/core';\nimport { ScenegraphNode } from \"./scenegraph-node.js\";\nexport class GroupNode extends ScenegraphNode {\n children;\n constructor(props = {}) {\n props = Array.isArray(props) ? { children: props } : props;\n const { children = [] } = props;\n log.assert(children.every(child => child instanceof ScenegraphNode), 'every child must an instance of ScenegraphNode');\n super(props);\n this.children = children;\n }\n getBounds() {\n const result = [\n [Infinity, Infinity, Infinity],\n [-Infinity, -Infinity, -Infinity]\n ];\n this.traverse((node, { worldMatrix }) => {\n const bounds = node.getBounds();\n if (!bounds) {\n return;\n }\n const [min, max] = bounds;\n const center = new Vector3(min).add(max).divide([2, 2, 2]);\n worldMatrix.transformAsPoint(center, center);\n const halfSize = new Vector3(max).subtract(min).divide([2, 2, 2]);\n worldMatrix.transformAsVector(halfSize, halfSize);\n for (let v = 0; v < 8; v++) {\n // Test all 8 corners of the box\n const position = new Vector3(v & 0b001 ? -1 : 1, v & 0b010 ? -1 : 1, v & 0b100 ? -1 : 1)\n .multiply(halfSize)\n .add(center);\n for (let i = 0; i < 3; i++) {\n result[0][i] = Math.min(result[0][i], position[i]);\n result[1][i] = Math.max(result[1][i], position[i]);\n }\n }\n });\n if (!Number.isFinite(result[0][0])) {\n return null;\n }\n return result;\n }\n destroy() {\n this.children.forEach(child => child.destroy());\n this.removeAll();\n super.destroy();\n }\n // Unpacks arrays and nested arrays of children\n add(...children) {\n for (const child of children) {\n if (Array.isArray(child)) {\n this.add(...child);\n }\n else {\n this.children.push(child);\n }\n }\n return this;\n }\n remove(child) {\n const children = this.children;\n const indexOf = children.indexOf(child);\n if (indexOf > -1) {\n children.splice(indexOf, 1);\n }\n return this;\n }\n removeAll() {\n this.children = [];\n return this;\n }\n traverse(visitor, { worldMatrix = new Matrix4() } = {}) {\n const modelMatrix = new Matrix4(worldMatrix).multiplyRight(this.matrix);\n for (const child of this.children) {\n if (child instanceof GroupNode) {\n child.traverse(visitor, { worldMatrix: modelMatrix });\n }\n else {\n visitor(child, { worldMatrix: modelMatrix });\n }\n }\n }\n}\n//# sourceMappingURL=group-node.js.map","// luma.gl\n// SPDX-License-Identifier: MIT\n// Copyright (c) vis.gl contributors\nimport { ScenegraphNode } from \"./scenegraph-node.js\";\nexport class ModelNode extends ScenegraphNode {\n model;\n bounds = null;\n managedResources;\n // TODO - is this used? override callbacks to make sure we call them with this\n // onBeforeRender = null;\n // onAfterRender = null;\n // AfterRender = null;\n constructor(props) {\n super(props);\n // Create new Model or used supplied Model\n this.model = props.model;\n this.managedResources = props.managedResources || [];\n this.bounds = props.bounds || null;\n this.setProps(props);\n }\n destroy() {\n if (this.model) {\n this.model.destroy();\n // @ts-expect-error\n this.model = null;\n }\n this.managedResources.forEach(resource => resource.destroy());\n this.managedResources = [];\n }\n getBounds() {\n return this.bounds;\n }\n // Expose model methods\n draw(renderPass) {\n // Return value indicates if something was actually drawn\n return this.model.draw(renderPass);\n }\n}\n//# sourceMappingURL=model-node.js.map","// deck.gl\n// SPDX-License-Identifier: MIT\n// Copyright (c) vis.gl contributors\nimport { COORDINATE_SYSTEM, createIterable } from '@deck.gl/core';\n/* eslint-disable max-statements, complexity, camelcase */\nconst RADIAN_PER_DEGREE = Math.PI / 180;\nconst modelMatrix = new Float32Array(16);\nconst valueArray = new Float32Array(12);\nfunction calculateTransformMatrix(targetMatrix, orientation, scale) {\n const pitch = orientation[0] * RADIAN_PER_DEGREE;\n const yaw = orientation[1] * RADIAN_PER_DEGREE;\n const roll = orientation[2] * RADIAN_PER_DEGREE;\n const sr = Math.sin(roll);\n const sp = Math.sin(pitch);\n const sw = Math.sin(yaw);\n const cr = Math.cos(roll);\n const cp = Math.cos(pitch);\n const cw = Math.cos(yaw);\n const scx = scale[0];\n const scy = scale[1];\n const scz = scale[2];\n targetMatrix[0] = scx * cw * cp; // 0,0\n targetMatrix[1] = scx * sw * cp; // 1,0\n targetMatrix[2] = scx * -sp; // 2,0\n targetMatrix[3] = scy * (-sw * cr + cw * sp * sr); // 0,1\n targetMatrix[4] = scy * (cw * cr + sw * sp * sr); // 1,1\n targetMatrix[5] = scy * cp * sr; // 2,1\n targetMatrix[6] = scz * (sw * sr + cw * sp * cr); // 0,2\n targetMatrix[7] = scz * (-cw * sr + sw * sp * cr); // 1,2\n targetMatrix[8] = scz * cp * cr; // 2,2\n}\nfunction getExtendedMat3FromMat4(mat4) {\n mat4[0] = mat4[0];\n mat4[1] = mat4[1];\n mat4[2] = mat4[2];\n mat4[3] = mat4[4];\n mat4[4] = mat4[5];\n mat4[5] = mat4[6];\n mat4[6] = mat4[8];\n mat4[7] = mat4[9];\n mat4[8] = mat4[10];\n mat4[9] = mat4[12];\n mat4[10] = mat4[13];\n mat4[11] = mat4[14];\n return mat4.subarray(0, 12);\n}\nexport const MATRIX_ATTRIBUTES = {\n size: 12,\n accessor: ['getOrientation', 'getScale', 'getTranslation', 'getTransformMatrix'],\n shaderAttributes: {\n instanceModelMatrixCol0: {\n size: 3,\n elementOffset: 0\n },\n instanceModelMatrixCol1: {\n size: 3,\n elementOffset: 3\n },\n instanceModelMatrixCol2: {\n size: 3,\n elementOffset: 6\n },\n instanceTranslation: {\n size: 3,\n elementOffset: 9\n }\n },\n update(attribute, { startRow, endRow }) {\n // @ts-expect-error: \"this\" will be bound to a layer when this function is called\n const { data, getOrientation, getScale, getTranslation, getTransformMatrix } = this.props;\n const arrayMatrix = Array.isArray(getTransformMatrix);\n const constantMatrix = arrayMatrix && getTransformMatrix.length === 16;\n const constantScale = Array.isArray(getScale);\n const constantOrientation = Array.isArray(getOrientation);\n const constantTranslation = Array.isArray(getTranslation);\n const hasMatrix = constantMatrix || (!arrayMatrix && Boolean(getTransformMatrix(data[0])));\n if (hasMatrix) {\n attribute.constant = constantMatrix;\n }\n else {\n attribute.constant = constantOrientation && constantScale && constantTranslation;\n }\n const instanceModelMatrixData = attribute.value;\n if (attribute.constant) {\n let matrix;\n if (hasMatrix) {\n modelMatrix.set(getTransformMatrix);\n matrix = getExtendedMat3FromMat4(modelMatrix);\n }\n else {\n matrix = valueArray;\n const orientation = getOrientation;\n const scale = getScale;\n calculateTransformMatrix(matrix, orientation, scale);\n matrix.set(getTranslation, 9);\n }\n attribute.value = new Float32Array(matrix);\n }\n else {\n let i = startRow * attribute.size;\n const { iterable, objectInfo } = createIterable(data, startRow, endRow);\n for (const object of iterable) {\n objectInfo.index++;\n let matrix;\n if (hasMatrix) {\n modelMatrix.set(constantMatrix ? getTransformMatrix : getTransformMatrix(object, objectInfo));\n matrix = getExtendedMat3FromMat4(modelMatrix);\n }\n else {\n matrix = valueArray;\n const orientation = constantOrientation\n ? getOrientation\n : getOrientation(object, objectInfo);\n const scale = constantScale ? getScale : getScale(object, objectInfo);\n calculateTransformMatrix(matrix, orientation, scale);\n matrix.set(constantTranslation ? getTranslation : getTranslation(object, objectInfo), 9);\n }\n instanceModelMatrixData[i++] = matrix[0];\n instanceModelMatrixData[i++] = matrix[1];\n instanceModelMatrixData[i++] = matrix[2];\n instanceModelMatrixData[i++] = matrix[3];\n instanceModelMatrixData[i++] = matrix[4];\n instanceModelMatrixData[i++] = matrix[5];\n instanceModelMatrixData[i++] = matrix[6];\n instanceModelMatrixData[i++] = matrix[7];\n instanceModelMatrixData[i++] = matrix[8];\n instanceModelMatrixData[i++] = matrix[9];\n instanceModelMatrixData[i++] = matrix[10];\n instanceModelMatrixData[i++] = matrix[11];\n }\n }\n }\n};\n// only apply composeModelMatrix when in cartesian or meter_offsets coordinate system\n// with `composeModelMatrix` enabled, the rotation part of the layer's modelMatrix will be composed to instance's transformations\n// since rotating latitude and longitude can not provide meaningful results, hence `composeModelMatrix` is disabled\n// when in LNGLAT and LNGLAT_OFFSET coordinates.\nexport function shouldComposeModelMatrix(viewport, coordinateSystem) {\n return (coordinateSystem === COORDINATE_SYSTEM.CARTESIAN ||\n coordinateSystem === COORDINATE_SYSTEM.METER_OFFSETS ||\n (coordinateSystem === COORDINATE_SYSTEM.DEFAULT && !viewport.isGeospatial));\n}\n//# sourceMappingURL=matrix.js.map","// deck.gl\n// SPDX-License-Identifier: MIT\n// Copyright (c) vis.gl contributors\nconst uniformBlock = `\\\nuniform simpleMeshUniforms {\n float sizeScale;\n bool composeModelMatrix;\n bool hasTexture;\n bool flatShading;\n} simpleMesh;\n`;\nexport const simpleMeshUniforms = {\n name: 'simpleMesh',\n vs: uniformBlock,\n fs: uniformBlock,\n uniformTypes: {\n sizeScale: 'f32',\n composeModelMatrix: 'f32',\n hasTexture: 'f32',\n flatShading: 'f32'\n }\n};\n//# sourceMappingURL=simple-mesh-layer-uniforms.js.map","// deck.gl\n// SPDX-License-Identifier: MIT\n// Copyright (c) vis.gl contributors\nexport default `#version 300 es\n#define SHADER_NAME simple-mesh-layer-vs\nin vec3 positions;\nin vec3 normals;\nin vec3 colors;\nin vec2 texCoords;\nin vec3 instancePositions;\nin vec3 instancePositions64Low;\nin vec4 instanceColors;\nin vec3 instancePickingColors;\nin vec3 instanceModelMatrixCol0;\nin vec3 instanceModelMatrixCol1;\nin vec3 instanceModelMatrixCol2;\nin vec3 instanceTranslation;\nout vec2 vTexCoord;\nout vec3 cameraPosition;\nout vec3 normals_commonspace;\nout vec4 position_commonspace;\nout vec4 vColor;\nvoid main(void) {\ngeometry.worldPosition = instancePositions;\ngeometry.uv = texCoords;\ngeometry.pickingColor = instancePickingColors;\nvTexCoord = texCoords;\ncameraPosition = project.cameraPosition;\nvColor = vec4(colors * instanceColors.rgb, instanceColors.a);\nmat3 instanceModelMatrix = mat3(instanceModelMatrixCol0, instanceModelMatrixCol1, instanceModelMatrixCol2);\nvec3 pos = (instanceModelMatrix * positions) * simpleMesh.sizeScale + instanceTranslation;\nif (simpleMesh.composeModelMatrix) {\nDECKGL_FILTER_SIZE(pos, geometry);\nnormals_commonspace = project_normal(instanceModelMatrix * normals);\ngeometry.worldPosition += pos;\ngl_Position = project_position_to_clipspace(pos + instancePositions, instancePositions64Low, vec3(0.0), position_commonspace);\ngeometry.position = position_commonspace;\n}\nelse {\npos = project_size(pos);\nDECKGL_FILTER_SIZE(pos, geometry);\ngl_Position = project_position_to_clipspace(instancePositions, instancePositions64Low, pos, position_commonspace);\ngeometry.position = position_commonspace;\nnormals_commonspace = project_normal(instanceModelMatrix * normals);\n}\ngeometry.normal = normals_commonspace;\nDECKGL_FILTER_GL_POSITION(gl_Position, geometry);\nDECKGL_FILTER_COLOR(vColor, geometry);\n}\n`;\n//# sourceMappingURL=simple-mesh-layer-vertex.glsl.js.map","// deck.gl\n// SPDX-License-Identifier: MIT\n// Copyright (c) vis.gl contributors\nexport default `#version 300 es\n#define SHADER_NAME simple-mesh-layer-fs\nprecision highp float;\nuniform sampler2D sampler;\nin vec2 vTexCoord;\nin vec3 cameraPosition;\nin vec3 normals_commonspace;\nin vec4 position_commonspace;\nin vec4 vColor;\nout vec4 fragColor;\nvoid main(void) {\ngeometry.uv = vTexCoord;\nvec3 normal;\nif (simpleMesh.flatShading) {\nnormal = normalize(cross(dFdx(position_commonspace.xyz), dFdy(position_commonspace.xyz)));\n} else {\nnormal = normals_commonspace;\n}\nvec4 color = simpleMesh.hasTexture ? texture(sampler, vTexCoord) : vColor;\nDECKGL_FILTER_COLOR(color, geometry);\nvec3 lightColor = lighting_getLightColor(color.rgb, cameraPosition, position_commonspace.xyz, normal);\nfragColor = vec4(lightColor, color.a * layer.opacity);\n}\n`;\n//# sourceMappingURL=simple-mesh-layer-fragment.glsl.js.map","// Note: This file will either be moved back to deck.gl or reformatted to web-monorepo standards\n// Disabling lint temporarily to facilitate copying code in and out of this repo\n/* eslint-disable */\n// deck.gl\n// SPDX-License-Identifier: MIT\n// Copyright (c) vis.gl contributors\nimport { Layer, project32, picking, log } from '@deck.gl/core';\nimport { Texture } from '@luma.gl/core';\nimport { Model, Geometry } from '@luma.gl/engine';\nimport { phongMaterial } from '@luma.gl/shadertools';\nimport { MATRIX_ATTRIBUTES, shouldComposeModelMatrix } from \"../utils/matrix.js\";\nimport { simpleMeshUniforms } from \"./simple-mesh-layer-uniforms.js\";\nimport vs from \"./simple-mesh-layer-vertex.glsl.js\";\nimport fs from \"./simple-mesh-layer-fragment.glsl.js\";\nimport { getMeshBoundingBox } from '@loaders.gl/schema';\nfunction normalizeGeometryAttributes(attributes) {\n const positionAttribute = attributes.positions || attributes.POSITION;\n log.assert(positionAttribute, 'no \"postions\" or \"POSITION\" attribute in mesh');\n const vertexCount = positionAttribute.value.length / positionAttribute.size;\n let colorAttribute = attributes.COLOR_0 || attributes.colors;\n if (!colorAttribute) {\n colorAttribute = { size: 3, value: new Float32Array(vertexCount * 3).fill(1) };\n }\n let normalAttribute = attributes.NORMAL || attributes.normals;\n if (!normalAttribute) {\n normalAttribute = { size: 3, value: new Float32Array(vertexCount * 3).fill(0) };\n }\n let texCoordAttribute = attributes.TEXCOORD_0 || attributes.texCoords;\n if (!texCoordAttribute) {\n texCoordAttribute = { size: 2, value: new Float32Array(vertexCount * 2).fill(0) };\n }\n return {\n positions: positionAttribute,\n colors: colorAttribute,\n normals: normalAttribute,\n texCoords: texCoordAttribute\n };\n}\n/*\n * Convert mesh data into geometry\n * @returns {Geometry} geometry\n */\nfunction getGeometry(data) {\n if (data instanceof Geometry) {\n // @ts-expect-error data.attributes is readonly\n data.attributes = normalizeGeometryAttributes(data.attributes);\n return data;\n }\n else if (data.attributes) {\n return new Geometry({\n ...data,\n topology: 'triangle-list',\n attributes: normalizeGeometryAttributes(data.attributes)\n });\n }\n else {\n return new Geometry({\n topology: 'triangle-list',\n attributes: normalizeGeometryAttributes(data)\n });\n }\n}\nconst DEFAULT_COLOR = [0, 0, 0, 255];\nconst defaultProps = {\n mesh: { type: 'object', value: null, async: true },\n texture: { type: 'image', value: null, async: true },\n sizeScale: { type: 'number', value: 1, min: 0 },\n // _instanced is a hack to use world position instead of meter offsets in mesh\n // TODO - formalize API\n _instanced: true,\n // NOTE(Tarek): Quick and dirty wireframe. Just draws\n // the same mesh with LINE_STRIPS. Won't follow edges\n // of the original mesh.\n wireframe: false,\n // Optional material for 'lighting' shader module\n material: true,\n getPosition: { type: 'accessor', value: (x) => x.position },\n getColor: { type: 'accessor', value: DEFAULT_COLOR },\n // yaw, pitch and roll are in degrees\n // https://en.wikipedia.org/wiki/Euler_angles\n // [pitch, yaw, roll]\n getOrientation: { type: 'accessor', value: [0, 0, 0] },\n getScale: { type: 'accessor', value: [1, 1, 1] },\n getTranslation: { type: 'accessor', value: [0, 0, 0] },\n // 4x4 matrix\n getTransformMatrix: { type: 'accessor', value: [] },\n textureParameters: { type: 'object', ignore: true, value: null }\n};\n/** Render a number of instances of an arbitrary 3D geometry. */\nclass SimpleMeshLayer extends Layer {\n getShaders() {\n return super.getShaders({\n vs,\n fs,\n modules: [project32, phongMaterial, picking, simpleMeshUniforms]\n });\n }\n getBounds() {\n if (this.props._instanced) {\n return super.getBounds();\n }\n let result = this.state.positionBounds;\n if (result) {\n return result;\n }\n const { mesh } = this.props;\n if (!mesh) {\n return null;\n }\n // @ts-ignore Detect if mesh is generated by loaders.gl\n result = mesh.header?.boundingBox;\n if (!result) {\n // Otherwise, calculate bounding box from positions\n const { attributes } = getGeometry(mesh);\n attributes.POSITION = attributes.POSITION || attributes.positions;\n //@ts-expect-error\n result = getMeshBoundingBox(attributes);\n }\n this.state.positionBounds = result;\n return result;\n }\n initializeState() {\n const attributeManager = this.getAttributeManager();\n // attributeManager is always defined in a primitive layer\n attributeManager.addInstanced({\n instancePositions: {\n transition: true,\n type: 'float64',\n fp64: this.use64bitPositions(),\n size: 3,\n accessor: 'getPosition'\n },\n instanceColors: {\n type: 'unorm8',\n transition: true,\n size: this.props.colorFormat.length,\n accessor: 'getColor',\n defaultValue: [0, 0, 0, 255]\n },\n instanceModelMatrix: MATRIX_ATTRIBUTES\n });\n this.setState({\n // Avoid luma.gl's missing uniform warning\n // TODO - add feature to luma.gl to specify ignored uniforms?\n emptyTexture: this.context.device.createTexture({\n data: new Uint8Array(4),\n width: 1,\n height: 1\n })\n });\n }\n updateState(params) {\n super.updateState(params);\n const { props, oldProps, changeFlags } = params;\n if (props.mesh !== oldProps.mesh || changeFlags.extensionsChanged) {\n this.state.positionBounds = null;\n this.state.model?.destroy();\n if (props.mesh) {\n this.state.model = this.getModel(props.mesh);\n const attributes = props.mesh.attributes || props.mesh;\n this.setState({\n hasNormals: Boolean(attributes.NORMAL || attributes.normals)\n });\n }\n // attributeManager is always defined in a primitive layer\n this.getAttributeManager().invalidateAll();\n }\n if (props.texture !== oldProps.texture && props.texture instanceof Texture) {\n this.setTexture(props.texture);\n }\n if (this.state.model) {\n this.state.model.setTopology(this.props.wireframe ? 'line-strip' : 'triangle-list');\n }\n }\n finalizeState(context) {\n super.finalizeState(context);\n this.state.emptyTexture.delete();\n }\n draw({ uniforms }) {\n const { model } = this.state;\n if (!model) {\n return;\n }\n const { viewport, renderPass } = this.context;\n const { sizeScale, coordinateSystem, _instanced } = this.props;\n const simpleMeshProps = {\n sizeScale,\n composeModelMatrix: !_instanced || shouldComposeModelMatrix(viewport, coordinateSystem),\n flatShading: !this.state.hasNormals\n };\n model.shaderInputs.setProps({ simpleMesh: simpleMeshProps });\n model.draw(renderPass);\n }\n get isLoaded() {\n return Boolean(this.state?.model && super.isLoaded);\n }\n getModel(mesh) {\n const model = new Model(this.context.device, {\n ...this.getShaders(),\n id: this.props.id,\n bufferLayout: this.getAttributeManager().getBufferLayouts(),\n geometry: getGeometry(mesh),\n isInstanced: true\n });\n const { texture } = this.props;\n const { emptyTexture } = this.state;\n const simpleMeshProps = {\n sampler: texture || emptyTexture,\n hasTexture: Boolean(texture)\n };\n model.shaderInputs.setProps({ simpleMesh: simpleMeshProps });\n return model;\n }\n setTexture(texture) {\n const { emptyTexture, model } = this.state;\n // props.mesh may not be ready at this time.\n // The sampler will be set when `getModel` is called\n if (model) {\n const simpleMeshProps = {\n sampler: texture || emptyTexture,\n hasTexture: Boolean(texture)\n };\n model.shaderInputs.setProps({ simpleMesh: simpleMeshProps });\n }\n }\n}\nSimpleMeshLayer.defaultProps = defaultProps;\nSimpleMeshLayer.layerName = 'SimpleMeshLayer';\nexport default SimpleMeshLayer;\n//# sourceMappingURL=simple-mesh-layer.js.map","// loaders.gl\n// SPDX-License-Identifier: MIT\n// Copyright (c) vis.gl contributors\n// Version constant cannot be imported, it needs to correspond to the build version of **this** module.\n// __VERSION__ is injected by babel-plugin-version-inline\n// @ts-ignore TS2304: Cannot find name '__VERSION__'.\nexport const VERSION = typeof \"4.3.3\" !== 'undefined' ? \"4.3.3\" : 'latest';\n","// loaders.gl\n// SPDX-License-Identifier: MIT\n// Copyright (c) vis.gl contributors\nimport { registerJSModules, getJSModuleOrNull } from '@loaders.gl/loader-utils';\nimport { loadLibrary } from '@loaders.gl/worker-utils';\nexport const BASIS_EXTERNAL_LIBRARIES = {\n /** Basis transcoder, javascript wrapper part */\n TRANSCODER: 'basis_transcoder.js',\n /** Basis transcoder, compiled web assembly part */\n TRANSCODER_WASM: 'basis_transcoder.wasm',\n /** Basis encoder, javascript wrapper part */\n ENCODER: 'basis_encoder.js',\n /** Basis encoder, compiled web assembly part */\n ENCODER_WASM: 'basis_encoder.wasm'\n};\nlet loadBasisTranscoderPromise;\n/**\n * Loads wasm transcoder module\n * @param options\n * @returns {BasisFile} promise\n */\nexport async function loadBasisTranscoderModule(options) {\n registerJSModules(options.modules);\n const basis = getJSModuleOrNull('basis');\n if (basis) {\n return basis;\n }\n loadBasisTranscoderPromise ||= loadBasisTranscoder(options);\n return await loadBasisTranscoderPromise;\n}\n/**\n * Loads wasm transcoder module\n * @param options\n * @returns {BasisFile} promise\n */\nasync function loadBasisTranscoder(options) {\n let BASIS = null;\n let wasmBinary = null;\n [BASIS, wasmBinary] = await Promise.all([\n await loadLibrary(BASIS_EXTERNAL_LIBRARIES.TRANSCODER, 'textures', options),\n await loadLibrary(BASIS_EXTERNAL_LIBRARIES.TRANSCODER_WASM, 'textures', options)\n ]);\n // Depends on how import happened...\n // @ts-ignore TS2339: Property does not exist on type\n BASIS = BASIS || globalThis.BASIS;\n return await initializeBasisTranscoderModule(BASIS, wasmBinary);\n}\n/**\n * Initialize wasm transcoder module\n * @param BasisModule - js part of the module\n * @param wasmBinary - wasm part of the module\n * @returns {BasisFile} promise\n */\nfunction initializeBasisTranscoderModule(BasisModule, wasmBinary) {\n const options = {};\n if (wasmBinary) {\n options.wasmBinary = wasmBinary;\n }\n return new Promise((resolve) => {\n // if you try to return BasisModule the browser crashes!\n BasisModule(options).then((module) => {\n const { BasisFile, initializeBasis } = module;\n initializeBasis();\n resolve({ BasisFile });\n });\n });\n}\nlet loadBasisEncoderPromise;\n/**\n * Loads wasm encoder module\n * @param options\n * @returns {BasisFile, KTX2File} promise\n */\nexport async function loadBasisEncoderModule(options) {\n const modules = options.modules || {};\n if (modules.basisEncoder) {\n return modules.basisEncoder;\n }\n loadBasisEncoderPromise = loadBasisEncoderPromise || loadBasisEncoder(options);\n return await loadBasisEncoderPromise;\n}\n/**\n * Loads wasm encoder module\n * @param options\n * @returns {BasisFile, KTX2File} promise\n */\nasync function loadBasisEncoder(options) {\n let BASIS_ENCODER = null;\n let wasmBinary = null;\n [BASIS_ENCODER, wasmBinary] = await Promise.all([\n await loadLibrary(BASIS_EXTERNAL_LIBRARIES.ENCODER, 'textures', options),\n await loadLibrary(BASIS_EXTERNAL_LIBRARIES.ENCODER_WASM, 'textures', options)\n ]);\n // Depends on how import happened...\n // @ts-ignore TS2339: Property does not exist on type\n BASIS_ENCODER = BASIS_ENCODER || globalThis.BASIS;\n return await initializeBasisEncoderModule(BASIS_ENCODER, wasmBinary);\n}\n/**\n * Initialize wasm transcoder module\n * @param BasisEncoderModule - js part of the module\n * @param wasmBinary - wasm part of the module\n * @returns {BasisFile, KTX2File} promise\n */\nfunction initializeBasisEncoderModule(BasisEncoderModule, wasmBinary) {\n const options = {};\n if (wasmBinary) {\n options.wasmBinary = wasmBinary;\n }\n return new Promise((resolve) => {\n // if you try to return BasisModule the browser crashes!\n BasisEncoderModule(options).then((module) => {\n const { BasisFile, KTX2File, initializeBasis, BasisEncoder } = module;\n initializeBasis();\n resolve({ BasisFile, KTX2File, BasisEncoder });\n });\n });\n}\n","// loaders.gl\n// SPDX-License-Identifier: MIT\n// Copyright (c) vis.gl contributors\n/* eslint-disable camelcase */\nexport const GL_EXTENSIONS_CONSTANTS = {\n // WEBGL_compressed_texture_s3tc\n COMPRESSED_RGB_S3TC_DXT1_EXT: 0x83f0,\n COMPRESSED_RGBA_S3TC_DXT1_EXT: 0x83f1,\n COMPRESSED_RGBA_S3TC_DXT3_EXT: 0x83f2,\n COMPRESSED_RGBA_S3TC_DXT5_EXT: 0x83f3,\n // WEBGL_compressed_texture_es3\n COMPRESSED_R11_EAC: 0x9270,\n COMPRESSED_SIGNED_R11_EAC: 0x9271,\n COMPRESSED_RG11_EAC: 0x9272,\n COMPRESSED_SIGNED_RG11_EAC: 0x9273,\n COMPRESSED_RGB8_ETC2: 0x9274,\n COMPRESSED_RGBA8_ETC2_EAC: 0x9275,\n COMPRESSED_SRGB8_ETC2: 0x9276,\n COMPRESSED_SRGB8_ALPHA8_ETC2_EAC: 0x9277,\n COMPRESSED_RGB8_PUNCHTHROUGH_ALPHA1_ETC2: 0x9278,\n COMPRESSED_SRGB8_PUNCHTHROUGH_ALPHA1_ETC2: 0x9279,\n // WEBGL_compressed_texture_pvrtc\n COMPRESSED_RGB_PVRTC_4BPPV1_IMG: 0x8c00,\n COMPRESSED_RGBA_PVRTC_4BPPV1_IMG: 0x8c02,\n COMPRESSED_RGB_PVRTC_2BPPV1_IMG: 0x8c01,\n COMPRESSED_RGBA_PVRTC_2BPPV1_IMG: 0x8c03,\n // WEBGL_compressed_texture_etc1\n COMPRESSED_RGB_ETC1_WEBGL: 0x8d64,\n // WEBGL_compressed_texture_atc\n COMPRESSED_RGB_ATC_WEBGL: 0x8c92,\n COMPRESSED_RGBA_ATC_EXPLICIT_ALPHA_WEBGL: 0x8c93,\n COMPRESSED_RGBA_ATC_INTERPOLATED_ALPHA_WEBGL: 0x87ee,\n // WEBGL_compressed_texture_astc\n COMPRESSED_RGBA_ASTC_4X4_KHR: 0x93b0,\n COMPRESSED_RGBA_ASTC_5X4_KHR: 0x93b1,\n COMPRESSED_RGBA_ASTC_5X5_KHR: 0x93b2,\n COMPRESSED_RGBA_ASTC_6X5_KHR: 0x93b3,\n COMPRESSED_RGBA_ASTC_6X6_KHR: 0x93b4,\n COMPRESSED_RGBA_ASTC_8X5_KHR: 0x93b5,\n COMPRESSED_RGBA_ASTC_8X6_KHR: 0x93b6,\n COMPRESSED_RGBA_ASTC_8X8_KHR: 0x93b7,\n COMPRESSED_RGBA_ASTC_10X5_KHR: 0x93b8,\n COMPRESSED_RGBA_ASTC_10X6_KHR: 0x93b9,\n COMPRESSED_RGBA_ASTC_10X8_KHR: 0x93ba,\n COMPRESSED_RGBA_ASTC_10X10_KHR: 0x93bb,\n COMPRESSED_RGBA_ASTC_12X10_KHR: 0x93bc,\n COMPRESSED_RGBA_ASTC_12X12_KHR: 0x93bd,\n COMPRESSED_SRGB8_ALPHA8_ASTC_4X4_KHR: 0x93d0,\n COMPRESSED_SRGB8_ALPHA8_ASTC_5X4_KHR: 0x93d1,\n COMPRESSED_SRGB8_ALPHA8_ASTC_5X5_KHR: 0x93d2,\n COMPRESSED_SRGB8_ALPHA8_ASTC_6X5_KHR: 0x93d3,\n COMPRESSED_SRGB8_ALPHA8_ASTC_6X6_KHR: 0x93d4,\n COMPRESSED_SRGB8_ALPHA8_ASTC_8X5_KHR: 0x93d5,\n COMPRESSED_SRGB8_ALPHA8_ASTC_8X6_KHR: 0x93d6,\n COMPRESSED_SRGB8_ALPHA8_ASTC_8X8_KHR: 0x93d7,\n COMPRESSED_SRGB8_ALPHA8_ASTC_10X5_KHR: 0x93d8,\n COMPRESSED_SRGB8_ALPHA8_ASTC_10X6_KHR: 0x93d9,\n COMPRESSED_SRGB8_ALPHA8_ASTC_10X8_KHR: 0x93da,\n COMPRESSED_SRGB8_ALPHA8_ASTC_10X10_KHR: 0x93db,\n COMPRESSED_SRGB8_ALPHA8_ASTC_12X10_KHR: 0x93dc,\n COMPRESSED_SRGB8_ALPHA8_ASTC_12X12_KHR: 0x93dd,\n // EXT_texture_compression_rgtc\n COMPRESSED_RED_RGTC1_EXT: 0x8dbb,\n COMPRESSED_SIGNED_RED_RGTC1_EXT: 0x8dbc,\n COMPRESSED_RED_GREEN_RGTC2_EXT: 0x8dbd,\n COMPRESSED_SIGNED_RED_GREEN_RGTC2_EXT: 0x8dbe,\n // WEBGL_compressed_texture_s3tc_srgb\n COMPRESSED_SRGB_S3TC_DXT1_EXT: 0x8c4c,\n COMPRESSED_SRGB_ALPHA_S3TC_DXT1_EXT: 0x8c4d,\n COMPRESSED_SRGB_ALPHA_S3TC_DXT3_EXT: 0x8c4e,\n COMPRESSED_SRGB_ALPHA_S3TC_DXT5_EXT: 0x8c4f\n};\n","// loaders.gl\n// SPDX-License-Identifier: MIT\n// Copyright (c) vis.gl contributors\nconst BROWSER_PREFIXES = ['', 'WEBKIT_', 'MOZ_'];\nconst WEBGL_EXTENSIONS = {\n /* eslint-disable camelcase */\n WEBGL_compressed_texture_s3tc: 'dxt',\n WEBGL_compressed_texture_s3tc_srgb: 'dxt-srgb',\n WEBGL_compressed_texture_etc1: 'etc1',\n WEBGL_compressed_texture_etc: 'etc2',\n WEBGL_compressed_texture_pvrtc: 'pvrtc',\n WEBGL_compressed_texture_atc: 'atc',\n WEBGL_compressed_texture_astc: 'astc',\n EXT_texture_compression_rgtc: 'rgtc'\n /* eslint-enable camelcase */\n};\nlet formats = null;\n/**\n * Returns a list of formats.\n * Creates a temporary WebGLRenderingContext if none is provided.\n *\n * @param gl - Optional context.\n */\nexport function getSupportedGPUTextureFormats(gl) {\n if (!formats) {\n gl = gl || getWebGLContext() || undefined;\n formats = new Set();\n for (const prefix of BROWSER_PREFIXES) {\n for (const extension in WEBGL_EXTENSIONS) {\n if (gl && gl.getExtension(`${prefix}${extension}`)) {\n const gpuTextureFormat = WEBGL_EXTENSIONS[extension];\n formats.add(gpuTextureFormat);\n }\n }\n }\n }\n return formats;\n}\n/**\n * @returns {WebGLRenderingContext?}\n */\nfunction getWebGLContext() {\n try {\n const canvas = document.createElement('canvas');\n return canvas.getContext('webgl');\n }\n catch (error) {\n return null;\n }\n}\n","// loaders.gl\n// SPDX-License-Identifier: MIT\n// Copyright (c) vis.gl contributors\nimport { read } from 'ktx-parse';\nimport { extractMipmapImages } from \"../utils/extract-mipmap-images.js\";\nimport { mapVkFormatToWebGL } from \"../utils/ktx-format-helper.js\";\nconst KTX2_ID = [\n // '´', 'K', 'T', 'X', '2', '0', 'ª', '\\r', '\\n', '\\x1A', '\\n'\n 0xab, 0x4b, 0x54, 0x58, 0x20, 0x32, 0x30, 0xbb, 0x0d, 0x0a, 0x1a, 0x0a\n];\n// eslint-disable-next-line complexity\nexport function isKTX(data) {\n // const id = new Uint8Array(data.buffer, data.byteOffset, data.byteLength);\n const id = new Uint8Array(data);\n const notKTX = id.byteLength < KTX2_ID.length ||\n id[0] !== KTX2_ID[0] || // '´'\n id[1] !== KTX2_ID[1] || // 'K'\n id[2] !== KTX2_ID[2] || // 'T'\n id[3] !== KTX2_ID[3] || // 'X'\n id[4] !== KTX2_ID[4] || // ' '\n id[5] !== KTX2_ID[5] || // '2'\n id[6] !== KTX2_ID[6] || // '0'\n id[7] !== KTX2_ID[7] || // 'ª'\n id[8] !== KTX2_ID[8] || // '\\r'\n id[9] !== KTX2_ID[9] || // '\\n'\n id[10] !== KTX2_ID[10] || // '\\x1A'\n id[11] !== KTX2_ID[11]; // '\\n'\n return !notKTX;\n}\nexport function parseKTX(arrayBuffer) {\n const uint8Array = new Uint8Array(arrayBuffer);\n const ktx = read(uint8Array);\n const mipMapLevels = Math.max(1, ktx.levels.length);\n const width = ktx.pixelWidth;\n const height = ktx.pixelHeight;\n const internalFormat = mapVkFormatToWebGL(ktx.vkFormat);\n return extractMipmapImages(ktx.levels, {\n mipMapLevels,\n width,\n height,\n sizeFunction: (level) => level.uncompressedByteLength,\n internalFormat\n });\n}\n","// loaders.gl\n// SPDX-License-Identifier: MIT\n// Copyright (c) vis.gl contributors\nimport { loadBasisEncoderModule, loadBasisTranscoderModule } from \"./basis-module-loader.js\";\nimport { GL_EXTENSIONS_CONSTANTS } from \"../gl-extensions.js\";\nimport { getSupportedGPUTextureFormats } from \"../utils/texture-formats.js\";\nimport { isKTX } from \"./parse-ktx.js\";\nconst OutputFormat = {\n etc1: {\n basisFormat: 0,\n compressed: true,\n format: GL_EXTENSIONS_CONSTANTS.COMPRESSED_RGB_ETC1_WEBGL\n },\n etc2: { basisFormat: 1, compressed: true },\n bc1: {\n basisFormat: 2,\n compressed: true,\n format: GL_EXTENSIONS_CONSTANTS.COMPRESSED_RGB_S3TC_DXT1_EXT\n },\n bc3: {\n basisFormat: 3,\n compressed: true,\n format: GL_EXTENSIONS_CONSTANTS.COMPRESSED_RGBA_S3TC_DXT5_EXT\n },\n bc4: { basisFormat: 4, compressed: true },\n bc5: { basisFormat: 5, compressed: true },\n 'bc7-m6-opaque-only': { basisFormat: 6, compressed: true },\n 'bc7-m5': { basisFormat: 7, compressed: true },\n 'pvrtc1-4-rgb': {\n basisFormat: 8,\n compressed: true,\n format: GL_EXTENSIONS_CONSTANTS.COMPRESSED_RGB_PVRTC_4BPPV1_IMG\n },\n 'pvrtc1-4-rgba': {\n basisFormat: 9,\n compressed: true,\n format: GL_EXTENSIONS_CONSTANTS.COMPRESSED_RGBA_PVRTC_4BPPV1_IMG\n },\n 'astc-4x4': {\n basisFormat: 10,\n compressed: true,\n format: GL_EXTENSIONS_CONSTANTS.COMPRESSED_RGBA_ASTC_4X4_KHR\n },\n 'atc-rgb': { basisFormat: 11, compressed: true },\n 'atc-rgba-interpolated-alpha': { basisFormat: 12, compressed: true },\n rgba32: { basisFormat: 13, compressed: false },\n rgb565: { basisFormat: 14, compressed: false },\n bgr565: { basisFormat: 15, compressed: false },\n rgba4444: { basisFormat: 16, compressed: false }\n};\n/**\n * parse data with a Binomial Basis_Universal module\n * @param data\n * @param options\n * @returns compressed texture data\n */\nexport async function parseBasis(data, options) {\n if (options.basis.containerFormat === 'auto') {\n if (isKTX(data)) {\n const fileConstructors = await loadBasisEncoderModule(options);\n return parseKTX2File(fileConstructors.KTX2File, data, options);\n }\n const { BasisFile } = await loadBasisTranscoderModule(options);\n return parseBasisFile(BasisFile, data, options);\n }\n switch (options.basis.module) {\n case 'encoder':\n const fileConstructors = await loadBasisEncoderModule(options);\n switch (options.basis.containerFormat) {\n case 'ktx2':\n return parseKTX2File(fileConstructors.KTX2File, data, options);\n case 'basis':\n default:\n return parseBasisFile(fileConstructors.BasisFile, data, options);\n }\n case 'transcoder':\n default:\n const { BasisFile } = await loadBasisTranscoderModule(options);\n return parseBasisFile(BasisFile, data, options);\n }\n}\n/**\n * Parse *.basis file data\n * @param BasisFile - initialized transcoder module\n * @param data\n * @param options\n * @returns compressed texture data\n */\nfunction parseBasisFile(BasisFile, data, options) {\n const basisFile = new BasisFile(new Uint8Array(data));\n try {\n if (!basisFile.startTranscoding()) {\n throw new Error('Failed to start basis transcoding');\n }\n const imageCount = basisFile.getNumImages();\n const images = [];\n for (let imageIndex = 0; imageIndex < imageCount; imageIndex++) {\n const levelsCount = basisFile.getNumLevels(imageIndex);\n const levels = [];\n for (let levelIndex = 0; levelIndex < levelsCount; levelIndex++) {\n levels.push(transcodeImage(basisFile, imageIndex, levelIndex, options));\n }\n images.push(levels);\n }\n return images;\n }\n finally {\n basisFile.close();\n basisFile.delete();\n }\n}\n/**\n * Parse the particular level image of a basis file\n * @param basisFile\n * @param imageIndex\n * @param levelIndex\n * @param options\n * @returns compressed texture data\n */\nfunction transcodeImage(basisFile, imageIndex, levelIndex, options) {\n const width = basisFile.getImageWidth(imageIndex, levelIndex);\n const height = basisFile.getImageHeight(imageIndex, levelIndex);\n // See https://github.com/BinomialLLC/basis_universal/pull/83\n const hasAlpha = basisFile.getHasAlpha( /* imageIndex, levelIndex */);\n // Check options for output format etc\n const { compressed, format, basisFormat } = getBasisOptions(options, hasAlpha);\n const decodedSize = basisFile.getImageTranscodedSizeInBytes(imageIndex, levelIndex, basisFormat);\n const decodedData = new Uint8Array(decodedSize);\n if (!basisFile.transcodeImage(decodedData, imageIndex, levelIndex, basisFormat, 0, 0)) {\n throw new Error('failed to start Basis transcoding');\n }\n return {\n // standard loaders.gl image category payload\n width,\n height,\n data: decodedData,\n compressed,\n format,\n // Additional fields\n // Add levelSize field.\n hasAlpha\n };\n}\n/**\n * Parse *.ktx2 file data\n * @param KTX2File\n * @param data\n * @param options\n * @returns compressed texture data\n */\nfunction parseKTX2File(KTX2File, data, options) {\n const ktx2File = new KTX2File(new Uint8Array(data));\n try {\n if (!ktx2File.startTranscoding()) {\n throw new Error('failed to start KTX2 transcoding');\n }\n const levelsCount = ktx2File.getLevels();\n const levels = [];\n for (let levelIndex = 0; levelIndex < levelsCount; levelIndex++) {\n levels.push(transcodeKTX2Image(ktx2File, levelIndex, options));\n }\n return [levels];\n }\n finally {\n ktx2File.close();\n ktx2File.delete();\n }\n}\n/**\n * Parse the particular level image of a ktx2 file\n * @param ktx2File\n * @param levelIndex\n * @param options\n * @returns\n */\nfunction transcodeKTX2Image(ktx2File, levelIndex, options) {\n const { alphaFlag, height, width } = ktx2File.getImageLevelInfo(levelIndex, 0, 0);\n // Check options for output format etc\n const { compressed, format, basisFormat } = getBasisOptions(options, alphaFlag);\n const decodedSize = ktx2File.getImageTranscodedSizeInBytes(levelIndex, 0 /* layerIndex */, 0 /* faceIndex */, basisFormat);\n const decodedData = new Uint8Array(decodedSize);\n if (!ktx2File.transcodeImage(decodedData, levelIndex, 0 /* layerIndex */, 0 /* faceIndex */, basisFormat, 0, -1 /* channel0 */, -1 /* channel1 */)) {\n throw new Error('Failed to transcode KTX2 image');\n }\n return {\n // standard loaders.gl image category payload\n width,\n height,\n data: decodedData,\n compressed,\n // Additional fields\n levelSize: decodedSize,\n hasAlpha: alphaFlag,\n format\n };\n}\n/**\n * Get BasisFormat by loader format option\n * @param options\n * @param hasAlpha\n * @returns BasisFormat data\n */\nfunction getBasisOptions(options, hasAlpha) {\n let format = options && options.basis && options.basis.format;\n if (format === 'auto') {\n format = selectSupportedBasisFormat();\n }\n if (typeof format === 'object') {\n format = hasAlpha ? format.alpha : format.noAlpha;\n }\n format = format.toLowerCase();\n return OutputFormat[format];\n}\n/**\n * Select transcode format from the list of supported formats\n * @returns key for OutputFormat map\n */\nexport function selectSupportedBasisFormat() {\n const supportedFormats = getSupportedGPUTextureFormats();\n if (supportedFormats.has('astc')) {\n return 'astc-4x4';\n }\n else if (supportedFormats.has('dxt')) {\n return {\n alpha: 'bc3',\n noAlpha: 'bc1'\n };\n }\n else if (supportedFormats.has('pvrtc')) {\n return {\n alpha: 'pvrtc1-4-rgba',\n noAlpha: 'pvrtc1-4-rgb'\n };\n }\n else if (supportedFormats.has('etc1')) {\n return 'etc1';\n }\n else if (supportedFormats.has('etc2')) {\n return 'etc2';\n }\n return 'rgb565';\n}\n","// loaders.gl\n// SPDX-License-Identifier: MIT\n// Copyright (c) vis.gl contributors\nimport { VERSION } from \"./lib/utils/version.js\";\nimport { parseBasis } from \"./lib/parsers/parse-basis.js\";\n/**\n * Worker loader for Basis super compressed textures\n */\nexport const BasisWorkerLoader = {\n dataType: null,\n batchType: null,\n name: 'Basis',\n id: 'basis',\n module: 'textures',\n version: VERSION,\n worker: true,\n extensions: ['basis', 'ktx2'],\n mimeTypes: ['application/octet-stream', 'image/ktx2'],\n tests: ['sB'],\n binary: true,\n options: {\n basis: {\n format: 'auto',\n libraryPath: 'libs/',\n containerFormat: 'auto',\n module: 'transcoder'\n }\n }\n};\n/**\n * Loader for Basis super compressed textures\n */\nexport const BasisLoader = {\n ...BasisWorkerLoader,\n parse: parseBasis\n};\n","// luma.gl\n// SPDX-License-Identifier: MIT\n// Copyright (c) vis.gl contributors\nimport { GL } from '@luma.gl/constants';\nexport function convertSampler(gltfSampler) {\n return {\n addressModeU: convertSamplerWrapMode(gltfSampler.wrapS),\n addressModeV: convertSamplerWrapMode(gltfSampler.wrapT),\n magFilter: convertSamplerMagFilter(gltfSampler.magFilter),\n ...convertSamplerMinFilter(gltfSampler.minFilter)\n };\n}\nfunction convertSamplerWrapMode(mode) {\n switch (mode) {\n case 33071:\n return 'clamp-to-edge';\n case 10497:\n return 'repeat';\n case 33648:\n return 'mirror-repeat';\n default:\n return undefined;\n }\n}\nfunction convertSamplerMagFilter(mode) {\n switch (mode) {\n case 9728:\n return 'nearest';\n case 9729:\n return 'linear';\n default:\n return undefined;\n }\n}\nfunction convertSamplerMinFilter(mode) {\n switch (mode) {\n case 9728:\n return { minFilter: 'nearest' };\n case 9729:\n return { minFilter: 'linear' };\n case 9984:\n return { minFilter: 'nearest', mipmapFilter: 'nearest' };\n case 9985:\n return { minFilter: 'linear', mipmapFilter: 'nearest' };\n case 9986:\n return { minFilter: 'nearest', mipmapFilter: 'linear' };\n case 9987:\n return { minFilter: 'linear', mipmapFilter: 'linear' };\n default:\n return {};\n }\n}\n//# sourceMappingURL=convert-webgl-sampler.js.map","// luma.gl\n// SPDX-License-Identifier: MIT\n// Copyright (c) vis.gl contributors\nimport { GL } from '@luma.gl/constants';\nimport { log } from '@luma.gl/core';\nimport { convertSampler } from \"../webgl-to-webgpu/convert-webgl-sampler.js\";\n/**\n * Parses a GLTF material definition into uniforms and parameters for the PBR shader module\n */\nexport function parsePBRMaterial(device, material, attributes, options) {\n const parsedMaterial = {\n defines: {\n // TODO: Use EXT_sRGB if available (Standard in WebGL 2.0)\n MANUAL_SRGB: true,\n SRGB_FAST_APPROXIMATION: true\n },\n bindings: {},\n uniforms: {\n // TODO: find better values?\n camera: [0, 0, 0], // Model should override\n metallicRoughnessValues: [1, 1] // Default is 1 and 1\n },\n parameters: {},\n glParameters: {},\n generatedTextures: []\n };\n // TODO - always available\n parsedMaterial.defines['USE_TEX_LOD'] = true;\n const { imageBasedLightingEnvironment } = options;\n if (imageBasedLightingEnvironment) {\n parsedMaterial.bindings.pbr_diffuseEnvSampler =\n imageBasedLightingEnvironment.diffuseEnvSampler.texture;\n parsedMaterial.bindings.pbr_specularEnvSampler =\n imageBasedLightingEnvironment.specularEnvSampler.texture;\n parsedMaterial.bindings.pbr_BrdfLUT = imageBasedLightingEnvironment.brdfLutTexture.texture;\n parsedMaterial.uniforms.scaleIBLAmbient = [1, 1];\n }\n if (options?.pbrDebug) {\n parsedMaterial.defines['PBR_DEBUG'] = true;\n // Override final color for reference app visualization of various parameters in the lighting equation.\n parsedMaterial.uniforms.scaleDiffBaseMR = [0, 0, 0, 0];\n parsedMaterial.uniforms.scaleFGDSpec = [0, 0, 0, 0];\n }\n if (attributes['NORMAL'])\n parsedMaterial.defines['HAS_NORMALS'] = true;\n if (attributes['TANGENT'] && options?.useTangents)\n parsedMaterial.defines['HAS_TANGENTS'] = true;\n if (attributes['TEXCOORD_0'])\n parsedMaterial.defines['HAS_UV'] = true;\n if (options?.imageBasedLightingEnvironment)\n parsedMaterial.defines['USE_IBL'] = true;\n if (options?.lights)\n parsedMaterial.defines['USE_LIGHTS'] = true;\n if (material) {\n parseMaterial(device, material, parsedMaterial);\n }\n return parsedMaterial;\n}\n/** Parse GLTF material record */\nfunction parseMaterial(device, material, parsedMaterial) {\n parsedMaterial.uniforms.unlit = Boolean(material.unlit);\n if (material.pbrMetallicRoughness) {\n parsePbrMetallicRoughness(device, material.pbrMetallicRoughness, parsedMaterial);\n }\n if (material.normalTexture) {\n addTexture(device, material.normalTexture, 'pbr_normalSampler', 'HAS_NORMALMAP', parsedMaterial);\n const { scale = 1 } = material.normalTexture;\n parsedMaterial.uniforms.normalScale = scale;\n }\n if (material.occlusionTexture) {\n addTexture(device, material.occlusionTexture, 'pbr_occlusionSampler', 'HAS_OCCLUSIONMAP', parsedMaterial);\n const { strength = 1 } = material.occlusionTexture;\n parsedMaterial.uniforms.occlusionStrength = strength;\n }\n if (material.emissiveTexture) {\n addTexture(device, material.emissiveTexture, 'pbr_emissiveSampler', 'HAS_EMISSIVEMAP', parsedMaterial);\n parsedMaterial.uniforms.emissiveFactor = material.emissiveFactor || [0, 0, 0];\n }\n switch (material.alphaMode || 'MASK') {\n case 'MASK':\n const { alphaCutoff = 0.5 } = material;\n parsedMaterial.defines['ALPHA_CUTOFF'] = true;\n parsedMaterial.uniforms.alphaCutoff = alphaCutoff;\n break;\n case 'BLEND':\n log.warn('glTF BLEND alphaMode might not work well because it requires mesh sorting')();\n // WebGPU style parameters\n parsedMaterial.parameters.blend = true;\n parsedMaterial.parameters.blendColorOperation = 'add';\n parsedMaterial.parameters.blendColorSrcFactor = 'src-alpha';\n parsedMaterial.parameters.blendColorDstFactor = 'one-minus-src-alpha';\n parsedMaterial.parameters.blendAlphaOperation = 'add';\n parsedMaterial.parameters.blendAlphaSrcFactor = 'one';\n parsedMaterial.parameters.blendAlphaDstFactor = 'one-minus-src-alpha';\n // GL parameters\n // TODO - remove in favor of parameters\n parsedMaterial.glParameters['blend'] = true;\n parsedMaterial.glParameters['blendEquation'] = 32774;\n parsedMaterial.glParameters['blendFunc'] = [\n 770,\n 771,\n 1,\n 771\n ];\n break;\n }\n}\n/** Parse GLTF material sub record */\nfunction parsePbrMetallicRoughness(device, pbrMetallicRoughness, parsedMaterial) {\n if (pbrMetallicRoughness.baseColorTexture) {\n addTexture(device, pbrMetallicRoughness.baseColorTexture, 'pbr_baseColorSampler', 'HAS_BASECOLORMAP', parsedMaterial);\n }\n parsedMaterial.uniforms.baseColorFactor = pbrMetallicRoughness.baseColorFactor || [1, 1, 1, 1];\n if (pbrMetallicRoughness.metallicRoughnessTexture) {\n addTexture(device, pbrMetallicRoughness.metallicRoughnessTexture, 'pbr_metallicRoughnessSampler', 'HAS_METALROUGHNESSMAP', parsedMaterial);\n }\n const { metallicFactor = 1, roughnessFactor = 1 } = pbrMetallicRoughness;\n parsedMaterial.uniforms.metallicRoughnessValues = [metallicFactor, roughnessFactor];\n}\n/** Create a texture from a glTF texture/sampler/image combo and add it to bindings */\nfunction addTexture(device, gltfTexture, uniformName, define, parsedMaterial) {\n const image = gltfTexture.texture.source.image;\n let textureOptions;\n if (image.compressed) {\n textureOptions = image;\n }\n else {\n // Texture2D accepts a promise that returns an image as data (Async Textures)\n textureOptions = { data: image };\n }\n const gltfSampler = {\n wrapS: 10497, // default REPEAT S (U) wrapping mode.\n wrapT: 10497, // default REPEAT T (V) wrapping mode.\n ...gltfTexture?.texture?.sampler\n };\n const texture = device.createTexture({\n id: gltfTexture.uniformName || gltfTexture.id,\n sampler: convertSampler(gltfSampler),\n ...textureOptions\n });\n parsedMaterial.bindings[uniformName] = texture;\n if (define)\n parsedMaterial.defines[define] = true;\n parsedMaterial.generatedTextures.push(texture);\n}\n/*\n/**\n * Parses a GLTF material definition into uniforms and parameters for the PBR shader module\n *\nexport class PBRMaterialParser {\n readonly device: Device;\n\n readonly defines: Record<string, boolean>;\n readonly bindings: Record<string, Binding>;\n readonly uniforms: Record<string, any>;\n readonly parameters: Record<string, any>;\n\n /** Hold on to generated textures, we destroy them in the destroy method *\n readonly generatedTextures: Texture[];\n\n constructor(device: Device, props: PBRMaterialParserProps) {\n const {attributes, material, pbrDebug, imageBasedLightingEnvironment, lights, useTangents} =\n props;\n this.device = device;\n\n this.defines = {\n // TODO: Use EXT_sRGB if available (Standard in WebGL 2.0)\n MANUAL_SRGB: true,\n SRGB_FAST_APPROXIMATION: true\n };\n\n if (this.device.features.has('glsl-texture-lod')) {\n this.defines.USE_TEX_LOD = true;\n }\n\n this.uniforms = {\n // TODO: find better values?\n camera: [0, 0, 0], // Model should override\n\n metallicRoughnessValues: [1, 1] // Default is 1 and 1\n };\n\n this.bindings = {};\n\n this.parameters = {};\n this.generatedTextures = [];\n\n if (imageBasedLightingEnvironment) {\n this.bindings.pbr_diffuseEnvSampler = imageBasedLightingEnvironment.getDiffuseEnvSampler();\n this.bindings.pbr_specularEnvSampler = imageBasedLightingEnvironment.getSpecularEnvSampler();\n this.bindings.pbr_BrdfLUT = imageBasedLightingEnvironment.getBrdfTexture();\n this.uniforms.scaleIBLAmbient = [1, 1];\n }\n\n if (pbrDebug) {\n // Override final color for reference app visualization\n // of various parameters in the lighting equation.\n this.uniforms.scaleDiffBaseMR = [0, 0, 0, 0];\n this.uniforms.scaleFGDSpec = [0, 0, 0, 0];\n }\n\n this.defineIfPresent(attributes.NORMAL, 'HAS_NORMALS');\n this.defineIfPresent(attributes.TANGENT && useTangents, 'HAS_TANGENTS');\n this.defineIfPresent(attributes.TEXCOORD_0, 'HAS_UV');\n\n this.defineIfPresent(imageBasedLightingEnvironment, 'USE_IBL');\n this.defineIfPresent(lights, 'USE_LIGHTS');\n this.defineIfPresent(pbrDebug, 'PBR_DEBUG');\n\n if (material) {\n this.parseMaterial(material);\n }\n }\n\n /**\n * Destroy all generated resources to release memory.\n *\n destroy(): void {\n this.generatedTextures.forEach(texture => texture.destroy());\n }\n\n /** Add a define if the the value is non-nullish *\n defineIfPresent(value: unknown, name: string): void {\n if (value) {\n this.defines[name] = 1;\n }\n }\n\n /** Parse GLTF material record *\n parseMaterial(material) {\n this.uniforms.unlit = Boolean(material.unlit);\n\n if (material.pbrMetallicRoughness) {\n this.parsePbrMetallicRoughness(material.pbrMetallicRoughness);\n }\n if (material.normalTexture) {\n this.addTexture(material.normalTexture, 'pbr_normalSampler', 'HAS_NORMALMAP');\n\n const {scale = 1} = material.normalTexture;\n this.uniforms.normalScale = scale;\n }\n if (material.occlusionTexture) {\n this.addTexture(material.occlusionTexture, 'pbr_occlusionSampler', 'HAS_OCCLUSIONMAP');\n\n const {strength = 1} = material.occlusionTexture;\n this.uniforms.occlusionStrength = strength;\n }\n if (material.emissiveTexture) {\n this.addTexture(material.emissiveTexture, 'pbr_emissiveSampler', 'HAS_EMISSIVEMAP');\n this.uniforms.emissiveFactor = material.emissiveFactor || [0, 0, 0];\n }\n if (material.alphaMode === 'MASK') {\n const {alphaCutoff = 0.5} = material;\n this.defines.ALPHA_CUTOFF = true;\n this.uniforms.u_AlphaCutoff = alphaCutoff;\n } else if (material.alphaMode === 'BLEND') {\n log.warn('BLEND alphaMode might not work well because it requires mesh sorting')();\n Object.assign(this.parameters, {\n blend: true,\n blendEquation: GL.FUNC_ADD,\n blendFunc: [GL.SRC_ALPHA, GL.ONE_MINUS_SRC_ALPHA, GL.ONE, GL.ONE_MINUS_SRC_ALPHA]\n });\n }\n }\n\n /** Parse GLTF material sub record *\n parsePbrMetallicRoughness(pbrMetallicRoughness) {\n if (pbrMetallicRoughness.baseColorTexture) {\n this.addTexture(\n pbrMetallicRoughness.baseColorTexture,\n 'pbr_baseColorSampler',\n 'HAS_BASECOLORMAP'\n );\n }\n this.uniforms.baseColorFactor = pbrMetallicRoughness.baseColorFactor || [1, 1, 1, 1];\n\n if (pbrMetallicRoughness.metallicRoughnessTexture) {\n this.addTexture(\n pbrMetallicRoughness.metallicRoughnessTexture,\n 'pbr_metallicRoughnessSampler',\n 'HAS_METALROUGHNESSMAP'\n );\n }\n const {metallicFactor = 1, roughnessFactor = 1} = pbrMetallicRoughness;\n this.uniforms.metallicRoughnessValues = [metallicFactor, roughnessFactor];\n }\n\n /** Create a texture from a glTF texture/sampler/image combo and add it to bindings *\n addTexture(gltfTexture, name, define = null) {\n const parameters = gltfTexture?.texture?.sampler?.parameters || {};\n\n const image = gltfTexture.texture.source.image;\n let textureOptions;\n let specialTextureParameters = {};\n if (image.compressed) {\n textureOptions = image;\n specialTextureParameters = {\n [GL.TEXTURE_MIN_FILTER]: image.data.length > 1 ? GL.LINEAR_MIPMAP_NEAREST : GL.LINEAR\n };\n } else {\n // Texture2D accepts a promise that returns an image as data (Async Textures)\n textureOptions = {data: image};\n }\n\n const texture: Texture = this.device.createTexture({\n id: gltfTexture.name || gltfTexture.id,\n parameters: {\n ...parameters,\n ...specialTextureParameters\n },\n pixelStore: {\n [GL.UNPACK_FLIP_Y_WEBGL]: false\n },\n ...textureOptions\n });\n this.bindings[name] = texture;\n this.defineIfPresent(define, define);\n this.generatedTextures.push(texture);\n }\n}\n*/\n//# sourceMappingURL=parse-pbr-material.js.map","// luma.gl\n// SPDX-License-Identifier: MIT\n// Copyright (c) vis.gl contributors\n// NOTE: Modules other than `@luma.gl/webgl` should not import `GL` from\n// `@luma.gl/constants`. Locally we use `GLEnum` instead of `GL` to avoid\n// conflicts with the `babel-plugin-inline-webgl-constants` plugin.\n// eslint-disable-next-line no-shadow\nexport var GLEnum;\n(function (GLEnum) {\n GLEnum[GLEnum[\"POINTS\"] = 0] = \"POINTS\";\n GLEnum[GLEnum[\"LINES\"] = 1] = \"LINES\";\n GLEnum[GLEnum[\"LINE_LOOP\"] = 2] = \"LINE_LOOP\";\n GLEnum[GLEnum[\"LINE_STRIP\"] = 3] = \"LINE_STRIP\";\n GLEnum[GLEnum[\"TRIANGLES\"] = 4] = \"TRIANGLES\";\n GLEnum[GLEnum[\"TRIANGLE_STRIP\"] = 5] = \"TRIANGLE_STRIP\";\n GLEnum[GLEnum[\"TRIANGLE_FAN\"] = 6] = \"TRIANGLE_FAN\";\n})(GLEnum || (GLEnum = {}));\nexport function convertGLDrawModeToTopology(drawMode) {\n // prettier-ignore\n switch (drawMode) {\n case GLEnum.POINTS: return 'point-list';\n case GLEnum.LINES: return 'line-list';\n case GLEnum.LINE_STRIP: return 'line-strip';\n case GLEnum.TRIANGLES: return 'triangle-list';\n case GLEnum.TRIANGLE_STRIP: return 'triangle-strip';\n default: throw new Error(String(drawMode));\n }\n}\n//# sourceMappingURL=convert-webgl-topology.js.map","// luma.gl\n// SPDX-License-Identifier: MIT\n// Copyright (c) vis.gl contributors\nimport { log } from '@luma.gl/core';\nimport { pbrMaterial } from '@luma.gl/shadertools';\nimport { Model, ModelNode } from '@luma.gl/engine';\nconst SHADER = /* WGSL */ `\nlayout(0) positions: vec4; // in vec4 POSITION;\n\n #ifdef HAS_NORMALS\n in vec4 normals; // in vec4 NORMAL;\n #endif\n\n #ifdef HAS_TANGENTS\n in vec4 TANGENT;\n #endif\n\n #ifdef HAS_UV\n // in vec2 TEXCOORD_0;\n in vec2 texCoords;\n #endif\n\n@vertex\n void main(void) {\n vec4 _NORMAL = vec4(0.);\n vec4 _TANGENT = vec4(0.);\n vec2 _TEXCOORD_0 = vec2(0.);\n\n #ifdef HAS_NORMALS\n _NORMAL = normals;\n #endif\n\n #ifdef HAS_TANGENTS\n _TANGENT = TANGENT;\n #endif\n\n #ifdef HAS_UV\n _TEXCOORD_0 = texCoords;\n #endif\n\n pbr_setPositionNormalTangentUV(positions, _NORMAL, _TANGENT, _TEXCOORD_0);\n gl_Position = u_MVPMatrix * positions;\n }\n\n@fragment\n out vec4 fragmentColor;\n\n void main(void) {\n vec3 pos = pbr_vPosition;\n fragmentColor = pbr_filterColor(vec4(1.0));\n }\n`;\n// TODO rename attributes to POSITION/NORMAL etc\n// See gpu-geometry.ts: getAttributeBuffersFromGeometry()\nconst vs = /* glsl */ `\\\n#version 300 es\n\n // in vec4 POSITION;\n in vec4 positions;\n\n #ifdef HAS_NORMALS\n // in vec4 NORMAL;\n in vec4 normals;\n #endif\n\n #ifdef HAS_TANGENTS\n in vec4 TANGENT;\n #endif\n\n #ifdef HAS_UV\n // in vec2 TEXCOORD_0;\n in vec2 texCoords;\n #endif\n\n void main(void) {\n vec4 _NORMAL = vec4(0.);\n vec4 _TANGENT = vec4(0.);\n vec2 _TEXCOORD_0 = vec2(0.);\n\n #ifdef HAS_NORMALS\n _NORMAL = normals;\n #endif\n\n #ifdef HAS_TANGENTS\n _TANGENT = TANGENT;\n #endif\n\n #ifdef HAS_UV\n _TEXCOORD_0 = texCoords;\n #endif\n\n pbr_setPositionNormalTangentUV(positions, _NORMAL, _TANGENT, _TEXCOORD_0);\n gl_Position = pbrProjection.modelViewProjectionMatrix * positions;\n }\n`;\nconst fs = /* glsl */ `\\\n#version 300 es\n out vec4 fragmentColor;\n\n void main(void) {\n vec3 pos = pbr_vPosition;\n fragmentColor = pbr_filterColor(vec4(1.0));\n }\n`;\n/** Creates a luma.gl Model from GLTF data*/\nexport function createGLTFModel(device, options) {\n const { id, geometry, parsedPPBRMaterial, vertexCount, modelOptions = {} } = options;\n log.info(4, 'createGLTFModel defines: ', parsedPPBRMaterial.defines)();\n // Calculate managedResources\n // TODO: Implement resource management logic that will\n // not deallocate resources/textures/buffers that are shared\n const managedResources = [];\n // managedResources.push(...parsedMaterial.generatedTextures);\n // managedResources.push(...Object.values(attributes).map((attribute) => attribute.buffer));\n const parameters = {\n depthWriteEnabled: true,\n depthCompare: 'less',\n depthFormat: 'depth24plus',\n cullMode: 'back'\n };\n const modelProps = {\n id,\n source: SHADER,\n vs,\n fs,\n geometry,\n topology: geometry.topology,\n vertexCount,\n modules: [pbrMaterial],\n ...modelOptions,\n defines: { ...parsedPPBRMaterial.defines, ...modelOptions.defines },\n parameters: { ...parameters, ...parsedPPBRMaterial.parameters, ...modelOptions.parameters }\n };\n const model = new Model(device, modelProps);\n const { camera, ...pbrMaterialProps } = {\n ...parsedPPBRMaterial.uniforms,\n ...modelOptions.uniforms,\n ...parsedPPBRMaterial.bindings,\n ...modelOptions.bindings\n };\n model.shaderInputs.setProps({ pbrMaterial: pbrMaterialProps, pbrProjection: { camera } });\n return new ModelNode({ managedResources, model });\n}\n//# sourceMappingURL=create-gltf-model.js.map","// luma.gl\n// SPDX-License-Identifier: MIT\n// Copyright (c) vis.gl contributors\nimport { Geometry, GroupNode } from '@luma.gl/engine';\nimport { Matrix4 } from '@math.gl/core';\nimport { convertGLDrawModeToTopology } from \"../webgl-to-webgpu/convert-webgl-topology.js\";\nimport { createGLTFModel } from \"../gltf/create-gltf-model.js\";\nimport { parsePBRMaterial } from \"./parse-pbr-material.js\";\nconst defaultOptions = {\n modelOptions: {},\n pbrDebug: false,\n imageBasedLightingEnvironment: undefined,\n lights: true,\n useTangents: false\n};\n/**\n * GLTF instantiator for luma.gl\n * Walks the parsed and resolved glTF structure and builds a luma.gl scenegraph\n */\nexport function parseGLTF(device, gltf, options_ = {}) {\n const options = { ...defaultOptions, ...options_ };\n const sceneNodes = gltf.scenes.map(gltfScene => createScene(device, gltfScene, gltf.nodes, options));\n return sceneNodes;\n}\nfunction createScene(device, gltfScene, gltfNodes, options) {\n const gltfSceneNodes = gltfScene.nodes || [];\n const nodes = gltfSceneNodes.map(node => createNode(device, node, gltfNodes, options));\n const sceneNode = new GroupNode({\n id: gltfScene.name || gltfScene.id,\n children: nodes\n });\n return sceneNode;\n}\nfunction createNode(device, gltfNode, gltfNodes, options) {\n if (!gltfNode._node) {\n const gltfChildren = gltfNode.children || [];\n const children = gltfChildren.map(child => createNode(device, child, gltfNodes, options));\n // Node can have children nodes and meshes at the same time\n if (gltfNode.mesh) {\n children.push(createMesh(device, gltfNode.mesh, options));\n }\n const node = new GroupNode({\n id: gltfNode.name || gltfNode.id,\n children\n });\n if (gltfNode.matrix) {\n node.setMatrix(gltfNode.matrix);\n }\n else {\n node.matrix.identity();\n if (gltfNode.translation) {\n node.matrix.translate(gltfNode.translation);\n }\n if (gltfNode.rotation) {\n const rotationMatrix = new Matrix4().fromQuaternion(gltfNode.rotation);\n node.matrix.multiplyRight(rotationMatrix);\n }\n if (gltfNode.scale) {\n node.matrix.scale(gltfNode.scale);\n }\n }\n gltfNode._node = node;\n }\n // Copy _node so that gltf-animator can access\n const topLevelNode = gltfNodes.find(node => node.id === gltfNode.id);\n topLevelNode._node = gltfNode._node;\n return gltfNode._node;\n}\nfunction createMesh(device, gltfMesh, options) {\n // TODO: avoid changing the gltf\n if (!gltfMesh._mesh) {\n const gltfPrimitives = gltfMesh.primitives || [];\n const primitives = gltfPrimitives.map((gltfPrimitive, i) => createPrimitive(device, gltfPrimitive, i, gltfMesh, options));\n const mesh = new GroupNode({\n id: gltfMesh.name || gltfMesh.id,\n children: primitives\n });\n gltfMesh._mesh = mesh;\n }\n return gltfMesh._mesh;\n}\nfunction createPrimitive(device, gltfPrimitive, i, gltfMesh, options) {\n const id = gltfPrimitive.name || `${gltfMesh.name || gltfMesh.id}-primitive-${i}`;\n const topology = convertGLDrawModeToTopology(gltfPrimitive.mode || 4);\n const vertexCount = gltfPrimitive.indices\n ? gltfPrimitive.indices.count\n : getVertexCount(gltfPrimitive.attributes);\n const geometry = createGeometry(id, gltfPrimitive, topology);\n const parsedPPBRMaterial = parsePBRMaterial(device, gltfPrimitive.material, geometry.attributes, options);\n const modelNode = createGLTFModel(device, {\n id,\n geometry: createGeometry(id, gltfPrimitive, topology),\n parsedPPBRMaterial,\n modelOptions: options.modelOptions,\n vertexCount\n });\n modelNode.bounds = [gltfPrimitive.attributes.POSITION.min, gltfPrimitive.attributes.POSITION.max];\n // TODO this holds on to all the CPU side texture and attribute data\n // modelNode.material = gltfPrimitive.material;\n return modelNode;\n}\nfunction getVertexCount(attributes) {\n throw new Error('getVertexCount not implemented');\n}\nfunction createGeometry(id, gltfPrimitive, topology) {\n const attributes = {};\n for (const [attributeName, attribute] of Object.entries(gltfPrimitive.attributes)) {\n const { components, size, value } = attribute;\n attributes[attributeName] = { size: size ?? components, value };\n }\n return new Geometry({\n id,\n topology,\n indices: gltfPrimitive.indices.value,\n attributes\n });\n}\n//# sourceMappingURL=parse-gltf.js.map","import { log } from '@luma.gl/core';\nimport { Quaternion } from '@math.gl/core';\nconst scratchQuaternion = new Quaternion();\nexport function interpolate(time, { input, interpolation, output }, target, path) {\n const maxTime = input[input.length - 1];\n const animationTime = time % maxTime;\n const nextIndex = input.findIndex(t => t >= animationTime);\n const previousIndex = Math.max(0, nextIndex - 1);\n if (!Array.isArray(target[path])) {\n switch (path) {\n case 'translation':\n target[path] = [0, 0, 0];\n break;\n case 'rotation':\n target[path] = [0, 0, 0, 1];\n break;\n case 'scale':\n target[path] = [1, 1, 1];\n break;\n default:\n log.warn(`Bad animation path ${path}`)();\n }\n }\n // assert(target[path].length === output[previousIndex].length);\n const previousTime = input[previousIndex];\n const nextTime = input[nextIndex];\n switch (interpolation) {\n case 'STEP':\n stepInterpolate(target, path, output[previousIndex]);\n break;\n case 'LINEAR':\n if (nextTime > previousTime) {\n const ratio = (animationTime - previousTime) / (nextTime - previousTime);\n linearInterpolate(target, path, output[previousIndex], output[nextIndex], ratio);\n }\n break;\n case 'CUBICSPLINE':\n if (nextTime > previousTime) {\n const ratio = (animationTime - previousTime) / (nextTime - previousTime);\n const tDiff = nextTime - previousTime;\n const p0 = output[3 * previousIndex + 1];\n const outTangent0 = output[3 * previousIndex + 2];\n const inTangent1 = output[3 * nextIndex + 0];\n const p1 = output[3 * nextIndex + 1];\n cubicsplineInterpolate(target, path, { p0, outTangent0, inTangent1, p1, tDiff, ratio });\n }\n break;\n default:\n log.warn(`Interpolation ${interpolation} not supported`)();\n break;\n }\n}\nfunction linearInterpolate(target, path, start, stop, ratio) {\n if (!target[path]) {\n throw new Error();\n }\n if (path === 'rotation') {\n // SLERP when path is rotation\n scratchQuaternion.slerp({ start, target: stop, ratio });\n for (let i = 0; i < scratchQuaternion.length; i++) {\n target[path][i] = scratchQuaternion[i];\n }\n }\n else {\n // regular interpolation\n for (let i = 0; i < start.length; i++) {\n target[path][i] = ratio * stop[i] + (1 - ratio) * start[i];\n }\n }\n}\nfunction cubicsplineInterpolate(target, path, { p0, outTangent0, inTangent1, p1, tDiff, ratio: t }) {\n if (!target[path]) {\n throw new Error();\n }\n // TODO: Quaternion might need normalization\n for (let i = 0; i < target[path].length; i++) {\n const m0 = outTangent0[i] * tDiff;\n const m1 = inTangent1[i] * tDiff;\n target[path][i] =\n (2 * Math.pow(t, 3) - 3 * Math.pow(t, 2) + 1) * p0[i] +\n (Math.pow(t, 3) - 2 * Math.pow(t, 2) + t) * m0 +\n (-2 * Math.pow(t, 3) + 3 * Math.pow(t, 2)) * p1[i] +\n (Math.pow(t, 3) - Math.pow(t, 2)) * m1;\n }\n}\nfunction stepInterpolate(target, path, value) {\n if (!target[path]) {\n throw new Error();\n }\n for (let i = 0; i < value.length; i++) {\n target[path][i] = value[i];\n }\n}\n//# sourceMappingURL=interpolate.js.map","// luma.gl\n// SPDX-License-Identifier: MIT\n// Copyright (c) vis.gl contributors\nimport { log } from '@luma.gl/core';\nimport { Matrix4 } from '@math.gl/core';\nimport { interpolate } from \"./animations/interpolate.js\";\nclass GLTFSingleAnimator {\n animation;\n startTime = 0;\n playing = true;\n speed = 1;\n constructor(props) {\n this.animation = props.animation;\n this.animation.name ||= 'unnamed';\n Object.assign(this, props);\n }\n setTime(timeMs) {\n if (!this.playing) {\n return;\n }\n const absTime = timeMs / 1000;\n const time = (absTime - this.startTime) * this.speed;\n this.animation.channels.forEach(({ sampler, target, path }) => {\n interpolate(time, sampler, target, path);\n applyTranslationRotationScale(target, target._node);\n });\n }\n}\nexport class GLTFAnimator {\n animations;\n constructor(props) {\n this.animations = props.animations.map((animation, index) => {\n const name = animation.name || `Animation-${index}`;\n return new GLTFSingleAnimator({\n animation: { name, channels: animation.channels }\n });\n });\n }\n /** @deprecated Use .setTime(). Will be removed (deck.gl is using this) */\n animate(time) {\n log.warn('GLTFAnimator#animate is deprecated. Use GLTFAnimator#setTime instead')();\n this.setTime(time);\n }\n setTime(time) {\n this.animations.forEach(animation => animation.setTime(time));\n }\n getAnimations() {\n return this.animations;\n }\n}\n// TODO: share with GLTFInstantiator\nconst scratchMatrix = new Matrix4();\nfunction applyTranslationRotationScale(gltfNode, node) {\n node.matrix.identity();\n if (gltfNode.translation) {\n node.matrix.translate(gltfNode.translation);\n }\n if (gltfNode.rotation) {\n const rotationMatrix = scratchMatrix.fromQuaternion(gltfNode.rotation);\n node.matrix.multiplyRight(rotationMatrix);\n }\n if (gltfNode.scale) {\n node.matrix.scale(gltfNode.scale);\n }\n}\n//# sourceMappingURL=gltf-animator.js.map","// luma.gl\n// SPDX-License-Identifier: MIT\n// Copyright (c) vis.gl contributors\nexport const ATTRIBUTE_TYPE_TO_COMPONENTS = {\n SCALAR: 1,\n VEC2: 2,\n VEC3: 3,\n VEC4: 4,\n MAT2: 4,\n MAT3: 9,\n MAT4: 16\n};\nexport const ATTRIBUTE_COMPONENT_TYPE_TO_ARRAY = {\n 5120: Int8Array,\n 5121: Uint8Array,\n 5122: Int16Array,\n 5123: Uint16Array,\n 5125: Uint32Array,\n 5126: Float32Array\n};\nexport function accessorToTypedArray(accessor) {\n const ArrayType = ATTRIBUTE_COMPONENT_TYPE_TO_ARRAY[accessor.componentType];\n const components = ATTRIBUTE_TYPE_TO_COMPONENTS[accessor.type];\n const length = components * accessor.count;\n const { buffer, byteOffset = 0 } = accessor.bufferView?.data ?? {};\n const typedArray = new ArrayType(buffer, byteOffset + (accessor.byteOffset || 0), length);\n return { typedArray, components };\n}\n//# sourceMappingURL=convert-webgl-attribute.js.map","// luma.gl\n// SPDX-License-Identifier: MIT\n// Copyright (c) vis.gl contributors\nimport { accessorToTypedArray } from \"..//webgl-to-webgpu/convert-webgl-attribute.js\";\nexport function parseGLTFAnimations(gltf) {\n const gltfAnimations = gltf.animations || [];\n return gltfAnimations.map((animation, index) => {\n const name = animation.name || `Animation-${index}`;\n const samplers = animation.samplers.map(({ input, interpolation = 'LINEAR', output }) => ({\n input: accessorToJsArray(gltf.accessors[input]),\n interpolation,\n output: accessorToJsArray(gltf.accessors[output])\n }));\n const channels = animation.channels.map(({ sampler, target }) => ({\n sampler: samplers[sampler],\n target: gltf.nodes[target.node ?? 0],\n path: target.path\n }));\n return { name, channels };\n });\n}\n//\nfunction accessorToJsArray(accessor) {\n if (!accessor._animation) {\n const { typedArray: array, components } = accessorToTypedArray(accessor);\n if (components === 1) {\n accessor._animation = Array.from(array);\n }\n else {\n // Slice array\n const slicedArray = [];\n for (let i = 0; i < array.length; i += components) {\n slicedArray.push(Array.from(array.slice(i, i + components)));\n }\n accessor._animation = slicedArray;\n }\n }\n return accessor._animation;\n}\n//# sourceMappingURL=parse-gltf-animations.js.map","/** Deeply copies a JS data structure */\nexport function deepCopy(object) {\n // don't copy binary data\n if (ArrayBuffer.isView(object) ||\n object instanceof ArrayBuffer ||\n object instanceof ImageBitmap) {\n return object;\n }\n if (Array.isArray(object)) {\n return object.map(deepCopy);\n }\n if (object && typeof object === 'object') {\n const result = {};\n for (const key in object) {\n result[key] = deepCopy(object[key]);\n }\n return result;\n }\n return object;\n}\n//# sourceMappingURL=deep-copy.js.map","// luma.gl\n// SPDX-License-Identifier: MIT\n// Copyright (c) vis.gl contributors\nimport { parseGLTF } from \"../parsers/parse-gltf.js\";\nimport { GLTFAnimator } from \"./gltf-animator.js\";\nimport { parseGLTFAnimations } from \"../parsers/parse-gltf-animations.js\";\nimport { deepCopy } from \"../utils/deep-copy.js\";\nexport function createScenegraphsFromGLTF(device, gltf, options) {\n gltf = deepCopy(gltf);\n const scenes = parseGLTF(device, gltf, options);\n // Note: There is a nasty dependency on injected nodes in the glTF\n const animations = parseGLTFAnimations(gltf);\n const animator = new GLTFAnimator({ animations });\n return { scenes, animator };\n}\n//# sourceMappingURL=create-scenegraph-from-gltf.js.map","// Replacement for the external assert method to reduce bundle size\n// Note: We don't use the second \"message\" argument in calling code,\n// so no need to support it here\nexport function assert(condition, message) {\n if (!condition) {\n throw new Error(message || 'assert failed: gltf');\n }\n}\n","export const COMPONENTS = {\n SCALAR: 1,\n VEC2: 2,\n VEC3: 3,\n VEC4: 4,\n MAT2: 4,\n MAT3: 9,\n MAT4: 16\n};\nexport const BYTES = {\n 5120: 1, // BYTE\n 5121: 1, // UNSIGNED_BYTE\n 5122: 2, // SHORT\n 5123: 2, // UNSIGNED_SHORT\n 5125: 4, // UNSIGNED_INT\n 5126: 4 // FLOAT\n};\n// ENUM LOOKUP\nexport function getBytesFromComponentType(componentType) {\n return BYTES[componentType];\n}\nexport function getSizeFromAccessorType(type) {\n return COMPONENTS[type];\n}\nexport function getGLEnumFromSamplerParameter(parameter) {\n const GL_TEXTURE_MAG_FILTER = 0x2800;\n const GL_TEXTURE_MIN_FILTER = 0x2801;\n const GL_TEXTURE_WRAP_S = 0x2802;\n const GL_TEXTURE_WRAP_T = 0x2803;\n const PARAMETER_MAP = {\n magFilter: GL_TEXTURE_MAG_FILTER,\n minFilter: GL_TEXTURE_MIN_FILTER,\n wrapS: GL_TEXTURE_WRAP_S,\n wrapT: GL_TEXTURE_WRAP_T\n };\n return PARAMETER_MAP[parameter];\n}\n","import { assert } from \"../utils/assert.js\";\nimport { BYTES, COMPONENTS } from \"../gltf-utils/gltf-constants.js\";\n/**\n * Memory needed to store texture and all mipmap levels 1 + 1/4 + 1/16 + 1/64 + ...\n * Minimum 1.33, but due to GPU layout may be 1.5\n */\nconst MIPMAP_FACTOR = 1.33;\nconst TYPES = ['SCALAR', 'VEC2', 'VEC3', 'VEC4'];\nconst ARRAY_CONSTRUCTOR_TO_WEBGL_CONSTANT = [\n [Int8Array, 5120],\n [Uint8Array, 5121],\n [Int16Array, 5122],\n [Uint16Array, 5123],\n [Uint32Array, 5125],\n [Float32Array, 5126],\n [Float64Array, 5130]\n];\nconst ARRAY_TO_COMPONENT_TYPE = new Map(ARRAY_CONSTRUCTOR_TO_WEBGL_CONSTANT);\nconst ATTRIBUTE_TYPE_TO_COMPONENTS = {\n SCALAR: 1,\n VEC2: 2,\n VEC3: 3,\n VEC4: 4,\n MAT2: 4,\n MAT3: 9,\n MAT4: 16\n};\nconst ATTRIBUTE_COMPONENT_TYPE_TO_BYTE_SIZE = {\n 5120: 1,\n 5121: 1,\n 5122: 2,\n 5123: 2,\n 5125: 4,\n 5126: 4\n};\nconst ATTRIBUTE_COMPONENT_TYPE_TO_ARRAY = {\n 5120: Int8Array,\n 5121: Uint8Array,\n 5122: Int16Array,\n 5123: Uint16Array,\n 5125: Uint32Array,\n 5126: Float32Array\n};\nexport function getAccessorTypeFromSize(size) {\n const type = TYPES[size - 1];\n return type || TYPES[0];\n}\nexport function getComponentTypeFromArray(typedArray) {\n const componentType = ARRAY_TO_COMPONENT_TYPE.get(typedArray.constructor);\n if (!componentType) {\n throw new Error('Illegal typed array');\n }\n return componentType;\n}\nexport function getAccessorArrayTypeAndLength(accessor, bufferView) {\n const ArrayType = ATTRIBUTE_COMPONENT_TYPE_TO_ARRAY[accessor.componentType];\n const components = ATTRIBUTE_TYPE_TO_COMPONENTS[accessor.type];\n const bytesPerComponent = ATTRIBUTE_COMPONENT_TYPE_TO_BYTE_SIZE[accessor.componentType];\n const length = accessor.count * components;\n const byteLength = accessor.count * components * bytesPerComponent;\n assert(byteLength >= 0 && byteLength <= bufferView.byteLength);\n const componentByteSize = BYTES[accessor.componentType];\n const numberOfComponentsInElement = COMPONENTS[accessor.type];\n return { ArrayType, length, byteLength, componentByteSize, numberOfComponentsInElement };\n}\n/**\n * Calculate the GPU memory used by a GLTF tile, for both buffer and texture memory\n * @param gltf - the gltf content of a GLTF tile\n * @returns - total memory usage in bytes\n */\nexport function getMemoryUsageGLTF(gltf) {\n let { images, bufferViews } = gltf;\n images = images || [];\n bufferViews = bufferViews || [];\n const imageBufferViews = images.map((i) => i.bufferView);\n bufferViews = bufferViews.filter((view) => !imageBufferViews.includes(view));\n const bufferMemory = bufferViews.reduce((acc, view) => acc + view.byteLength, 0);\n // Assume each pixel of the texture is 4 channel with mimmaps (which add 33%)\n // TODO correctly handle compressed textures\n const pixelCount = images.reduce((acc, image) => {\n // @ts-ignore\n const { width, height } = image.image;\n return acc + width * height;\n }, 0);\n return bufferMemory + Math.ceil(4 * pixelCount * MIPMAP_FACTOR);\n}\n","// TODO - GLTFScenegraph should use these\nimport { assert } from \"../utils/assert.js\";\nimport { getAccessorArrayTypeAndLength } from \"./gltf-utils.js\";\n// accepts buffer view index or buffer view object\n// returns a `Uint8Array`\nexport function getTypedArrayForBufferView(json, buffers, bufferViewIndex) {\n const bufferView = json.bufferViews[bufferViewIndex];\n assert(bufferView);\n // Get hold of the arrayBuffer\n const bufferIndex = bufferView.buffer;\n const binChunk = buffers[bufferIndex];\n assert(binChunk);\n const byteOffset = (bufferView.byteOffset || 0) + binChunk.byteOffset;\n return new Uint8Array(binChunk.arrayBuffer, byteOffset, bufferView.byteLength);\n}\n// accepts accessor index or accessor object\n// returns a `Uint8Array`\nexport function getTypedArrayForImageData(json, buffers, imageIndex) {\n const image = json.images[imageIndex];\n const bufferViewIndex = json.bufferViews[image.bufferView];\n return getTypedArrayForBufferView(json, buffers, bufferViewIndex);\n}\n/**\n * Gets data pointed by the accessor.\n * @param json - json part of gltf content of a GLTF tile.\n * @param buffers - Array containing buffers of data.\n * @param accessor - accepts accessor index or accessor object.\n * @returns {TypedArray} Typed array with type matching the type of data poited by the accessor.\n */\n// eslint-disable-next-line complexity\nexport function getTypedArrayForAccessor(json, buffers, accessor) {\n const gltfAccessor = typeof accessor === 'number' ? json.accessors?.[accessor] : accessor;\n if (!gltfAccessor) {\n throw new Error(`No gltf accessor ${JSON.stringify(accessor)}`);\n }\n const bufferView = json.bufferViews?.[gltfAccessor.bufferView || 0];\n if (!bufferView) {\n throw new Error(`No gltf buffer view for accessor ${bufferView}`);\n }\n // Get `arrayBuffer` the `bufferView` looks at\n const { arrayBuffer, byteOffset: bufferByteOffset } = buffers[bufferView.buffer];\n // Resulting byteOffset is sum of the buffer, accessor and bufferView byte offsets\n const byteOffset = (bufferByteOffset || 0) + (gltfAccessor.byteOffset || 0) + (bufferView.byteOffset || 0);\n // Deduce TypedArray type and its length from `accessor` and `bufferView` data\n const { ArrayType, length, componentByteSize, numberOfComponentsInElement } = getAccessorArrayTypeAndLength(gltfAccessor, bufferView);\n // 'length' is a whole number of components of all elements in the buffer pointed by the accessor\n // Multiplier to calculate the address of the element in the arrayBuffer\n const elementByteSize = componentByteSize * numberOfComponentsInElement;\n const elementAddressScale = bufferView.byteStride || elementByteSize;\n // Creare an array of component's type where all components (not just elements) will reside\n if (typeof bufferView.byteStride === 'undefined' || bufferView.byteStride === elementByteSize) {\n // No iterleaving\n const result = new ArrayType(arrayBuffer, byteOffset, length);\n return result;\n }\n // Iterleaving\n const result = new ArrayType(length);\n for (let i = 0; i < gltfAccessor.count; i++) {\n const values = new ArrayType(arrayBuffer, byteOffset + i * elementAddressScale, numberOfComponentsInElement);\n result.set(values, i * numberOfComponentsInElement);\n }\n return result;\n}\n","// loaders.gl\n// SPDX-License-Identifier: MIT\n// Copyright (c) vis.gl contributors\nimport { getBinaryImageMetadata } from '@loaders.gl/images';\nimport { padToNBytes, copyToArray } from '@loaders.gl/loader-utils';\nimport { assert } from \"../utils/assert.js\";\nimport { getAccessorTypeFromSize, getComponentTypeFromArray } from \"../gltf-utils/gltf-utils.js\";\nimport { getTypedArrayForAccessor as _getTypedArrayForAccessor } from \"../gltf-utils/get-typed-array.js\";\nfunction makeDefaultGLTFJson() {\n return {\n asset: {\n version: '2.0',\n generator: 'loaders.gl'\n },\n buffers: [],\n extensions: {},\n extensionsRequired: [],\n extensionsUsed: []\n };\n}\n/**\n * Class for structured access to GLTF data\n */\nexport class GLTFScenegraph {\n // internal\n gltf;\n sourceBuffers;\n byteLength;\n // TODO - why is this not GLTFWithBuffers - what happens to images?\n constructor(gltf) {\n // Declare locally so\n this.gltf = {\n json: gltf?.json || makeDefaultGLTFJson(),\n buffers: gltf?.buffers || [],\n images: gltf?.images || []\n };\n this.sourceBuffers = [];\n this.byteLength = 0;\n // Initialize buffers\n if (this.gltf.buffers && this.gltf.buffers[0]) {\n this.byteLength = this.gltf.buffers[0].byteLength;\n this.sourceBuffers = [this.gltf.buffers[0]];\n }\n }\n // Accessors\n get json() {\n return this.gltf.json;\n }\n getApplicationData(key) {\n // TODO - Data is already unpacked by GLBParser\n const data = this.json[key];\n return data;\n }\n getExtraData(key) {\n // TODO - Data is already unpacked by GLBParser\n const extras = (this.json.extras || {});\n return extras[key];\n }\n hasExtension(extensionName) {\n const isUsedExtension = this.getUsedExtensions().find((name) => name === extensionName);\n const isRequiredExtension = this.getRequiredExtensions().find((name) => name === extensionName);\n return typeof isUsedExtension === 'string' || typeof isRequiredExtension === 'string';\n }\n getExtension(extensionName) {\n const isExtension = this.getUsedExtensions().find((name) => name === extensionName);\n const extensions = this.json.extensions || {};\n return isExtension ? extensions[extensionName] : null;\n }\n getRequiredExtension(extensionName) {\n const isRequired = this.getRequiredExtensions().find((name) => name === extensionName);\n return isRequired ? this.getExtension(extensionName) : null;\n }\n getRequiredExtensions() {\n return this.json.extensionsRequired || [];\n }\n getUsedExtensions() {\n return this.json.extensionsUsed || [];\n }\n getRemovedExtensions() {\n return (this.json.extensionsRemoved || []);\n }\n getObjectExtension(object, extensionName) {\n const extensions = object.extensions || {};\n return extensions[extensionName];\n }\n getScene(index) {\n return this.getObject('scenes', index);\n }\n getNode(index) {\n return this.getObject('nodes', index);\n }\n getSkin(index) {\n return this.getObject('skins', index);\n }\n getMesh(index) {\n return this.getObject('meshes', index);\n }\n getMaterial(index) {\n return this.getObject('materials', index);\n }\n getAccessor(index) {\n return this.getObject('accessors', index);\n }\n // getCamera(index: number): object | null {\n // return null; // TODO: fix thi: object as null;\n // }\n getTexture(index) {\n return this.getObject('textures', index);\n }\n getSampler(index) {\n return this.getObject('samplers', index);\n }\n getImage(index) {\n return this.getObject('images', index);\n }\n getBufferView(index) {\n return this.getObject('bufferViews', index);\n }\n getBuffer(index) {\n return this.getObject('buffers', index);\n }\n getObject(array, index) {\n // check if already resolved\n if (typeof index === 'object') {\n return index;\n }\n const object = this.json[array] && this.json[array][index];\n if (!object) {\n throw new Error(`glTF file error: Could not find ${array}[${index}]`); // eslint-disable-line\n }\n return object;\n }\n /**\n * Accepts buffer view index or buffer view object\n * @returns a `Uint8Array`\n */\n getTypedArrayForBufferView(bufferView) {\n bufferView = this.getBufferView(bufferView);\n // @ts-ignore\n const bufferIndex = bufferView.buffer;\n // Get hold of the arrayBuffer\n // const buffer = this.getBuffer(bufferIndex);\n const binChunk = this.gltf.buffers[bufferIndex];\n assert(binChunk);\n // @ts-ignore\n const byteOffset = (bufferView.byteOffset || 0) + binChunk.byteOffset;\n // @ts-ignore\n return new Uint8Array(binChunk.arrayBuffer, byteOffset, bufferView.byteLength);\n }\n /** Accepts accessor index or accessor object\n * @returns a typed array with type that matches the types\n */\n getTypedArrayForAccessor(accessor) {\n // @ts-ignore\n const gltfAccessor = this.getAccessor(accessor);\n return _getTypedArrayForAccessor(this.gltf.json, this.gltf.buffers, gltfAccessor);\n }\n /** accepts accessor index or accessor object\n * returns a `Uint8Array`\n */\n getTypedArrayForImageData(image) {\n // @ts-ignore\n image = this.getAccessor(image);\n // @ts-ignore\n const bufferView = this.getBufferView(image.bufferView);\n const buffer = this.getBuffer(bufferView.buffer);\n // @ts-ignore\n const arrayBuffer = buffer.data;\n const byteOffset = bufferView.byteOffset || 0;\n return new Uint8Array(arrayBuffer, byteOffset, bufferView.byteLength);\n }\n // MODIFERS\n /**\n * Add an extra application-defined key to the top-level data structure\n */\n addApplicationData(key, data) {\n this.json[key] = data;\n return this;\n }\n /**\n * `extras` - Standard GLTF field for storing application specific data\n */\n addExtraData(key, data) {\n this.json.extras = this.json.extras || {};\n this.json.extras[key] = data;\n return this;\n }\n addObjectExtension(object, extensionName, data) {\n // @ts-ignore\n object.extensions = object.extensions || {};\n // TODO - clobber or merge?\n // @ts-ignore\n object.extensions[extensionName] = data;\n this.registerUsedExtension(extensionName);\n return this;\n }\n setObjectExtension(object, extensionName, data) {\n const extensions = object.extensions || {};\n extensions[extensionName] = data;\n // TODO - add to usedExtensions...\n }\n removeObjectExtension(object, extensionName) {\n const extensions = object?.extensions || {};\n if (extensions[extensionName]) {\n this.json.extensionsRemoved = this.json.extensionsRemoved || [];\n const extensionsRemoved = this.json.extensionsRemoved;\n if (!extensionsRemoved.includes(extensionName)) {\n extensionsRemoved.push(extensionName);\n }\n }\n delete extensions[extensionName];\n }\n /**\n * Add to standard GLTF top level extension object, mark as used\n */\n addExtension(extensionName, extensionData = {}) {\n assert(extensionData);\n this.json.extensions = this.json.extensions || {};\n this.json.extensions[extensionName] = extensionData;\n this.registerUsedExtension(extensionName);\n return extensionData;\n }\n /**\n * Standard GLTF top level extension object, mark as used and required\n */\n addRequiredExtension(extensionName, extensionData = {}) {\n assert(extensionData);\n this.addExtension(extensionName, extensionData);\n this.registerRequiredExtension(extensionName);\n return extensionData;\n }\n /**\n * Add extensionName to list of used extensions\n */\n registerUsedExtension(extensionName) {\n this.json.extensionsUsed = this.json.extensionsUsed || [];\n if (!this.json.extensionsUsed.find((ext) => ext === extensionName)) {\n this.json.extensionsUsed.push(extensionName);\n }\n }\n /**\n * Add extensionName to list of required extensions\n */\n registerRequiredExtension(extensionName) {\n this.registerUsedExtension(extensionName);\n this.json.extensionsRequired = this.json.extensionsRequired || [];\n if (!this.json.extensionsRequired.find((ext) => ext === extensionName)) {\n this.json.extensionsRequired.push(extensionName);\n }\n }\n /**\n * Removes an extension from the top-level list\n */\n removeExtension(extensionName) {\n if (this.json.extensions?.[extensionName]) {\n this.json.extensionsRemoved = this.json.extensionsRemoved || [];\n const extensionsRemoved = this.json.extensionsRemoved;\n if (!extensionsRemoved.includes(extensionName)) {\n extensionsRemoved.push(extensionName);\n }\n }\n if (this.json.extensions) {\n delete this.json.extensions[extensionName];\n }\n if (this.json.extensionsRequired) {\n this._removeStringFromArray(this.json.extensionsRequired, extensionName);\n }\n if (this.json.extensionsUsed) {\n this._removeStringFromArray(this.json.extensionsUsed, extensionName);\n }\n }\n /**\n * Set default scene which is to be displayed at load time\n */\n setDefaultScene(sceneIndex) {\n this.json.scene = sceneIndex;\n }\n /**\n * @todo: add more properties for scene initialization:\n * name`, `extensions`, `extras`\n * https://github.com/KhronosGroup/glTF/tree/master/specification/2.0#reference-scene\n */\n addScene(scene) {\n const { nodeIndices } = scene;\n this.json.scenes = this.json.scenes || [];\n this.json.scenes.push({ nodes: nodeIndices });\n return this.json.scenes.length - 1;\n }\n /**\n * @todo: add more properties for node initialization:\n * `name`, `extensions`, `extras`, `camera`, `children`, `skin`, `rotation`, `scale`, `translation`, `weights`\n * https://github.com/KhronosGroup/glTF/tree/master/specification/2.0#node\n */\n addNode(node) {\n const { meshIndex, matrix } = node;\n this.json.nodes = this.json.nodes || [];\n const nodeData = { mesh: meshIndex };\n if (matrix) {\n // @ts-ignore\n nodeData.matrix = matrix;\n }\n this.json.nodes.push(nodeData);\n return this.json.nodes.length - 1;\n }\n /** Adds a mesh to the json part */\n addMesh(mesh) {\n const { attributes, indices, material, mode = 4 } = mesh;\n const accessors = this._addAttributes(attributes);\n const glTFMesh = {\n primitives: [\n {\n attributes: accessors,\n mode\n }\n ]\n };\n if (indices) {\n const indicesAccessor = this._addIndices(indices);\n // @ts-ignore\n glTFMesh.primitives[0].indices = indicesAccessor;\n }\n if (Number.isFinite(material)) {\n // @ts-ignore\n glTFMesh.primitives[0].material = material;\n }\n this.json.meshes = this.json.meshes || [];\n this.json.meshes.push(glTFMesh);\n return this.json.meshes.length - 1;\n }\n addPointCloud(attributes) {\n // @ts-ignore\n const accessorIndices = this._addAttributes(attributes);\n const glTFMesh = {\n primitives: [\n {\n attributes: accessorIndices,\n mode: 0 // GL.POINTS\n }\n ]\n };\n this.json.meshes = this.json.meshes || [];\n this.json.meshes.push(glTFMesh);\n return this.json.meshes.length - 1;\n }\n /**\n * Adds a binary image. Builds glTF \"JSON metadata\" and saves buffer reference\n * Buffer will be copied into BIN chunk during \"pack\"\n * Currently encodes as glTF image\n * @param imageData\n * @param mimeType\n */\n addImage(imageData, mimeTypeOpt) {\n // If image is referencing a bufferView instead of URI, mimeType must be defined:\n // https://github.com/KhronosGroup/glTF/tree/master/specification/2.0#images\n // \"a reference to a bufferView; in that case mimeType must be defined.\"\n const metadata = getBinaryImageMetadata(imageData);\n const mimeType = mimeTypeOpt || metadata?.mimeType;\n const bufferViewIndex = this.addBufferView(imageData);\n const glTFImage = {\n bufferView: bufferViewIndex,\n mimeType\n };\n this.json.images = this.json.images || [];\n this.json.images.push(glTFImage);\n return this.json.images.length - 1;\n }\n /**\n * Add one untyped source buffer, create a matching glTF `bufferView`, and return its index\n * @param buffer\n */\n addBufferView(buffer, bufferIndex = 0, byteOffset = this.byteLength) {\n const byteLength = buffer.byteLength;\n assert(Number.isFinite(byteLength));\n // Add this buffer to the list of buffers to be written to the body.\n this.sourceBuffers = this.sourceBuffers || [];\n this.sourceBuffers.push(buffer);\n const glTFBufferView = {\n buffer: bufferIndex,\n // Write offset from the start of the binary body\n byteOffset,\n byteLength\n };\n // We've now added the contents to the body, so update the total length\n // Every sub-chunk needs to be 4-byte align ed\n this.byteLength += padToNBytes(byteLength, 4);\n // Add a bufferView indicating start and length of this binary sub-chunk\n this.json.bufferViews = this.json.bufferViews || [];\n this.json.bufferViews.push(glTFBufferView);\n return this.json.bufferViews.length - 1;\n }\n /**\n * Adds an accessor to a bufferView\n * @param bufferViewIndex\n * @param accessor\n */\n addAccessor(bufferViewIndex, accessor) {\n const glTFAccessor = {\n bufferView: bufferViewIndex,\n // @ts-ignore\n type: getAccessorTypeFromSize(accessor.size),\n // @ts-ignore\n componentType: accessor.componentType,\n // @ts-ignore\n count: accessor.count,\n // @ts-ignore\n max: accessor.max,\n // @ts-ignore\n min: accessor.min\n };\n this.json.accessors = this.json.accessors || [];\n this.json.accessors.push(glTFAccessor);\n return this.json.accessors.length - 1;\n }\n /**\n * Add a binary buffer. Builds glTF \"JSON metadata\" and saves buffer reference\n * Buffer will be copied into BIN chunk during \"pack\"\n * Currently encodes buffers as glTF accessors, but this could be optimized\n * @param sourceBuffer\n * @param accessor\n */\n addBinaryBuffer(sourceBuffer, accessor = { size: 3 }) {\n const bufferViewIndex = this.addBufferView(sourceBuffer);\n // @ts-ignore\n let minMax = { min: accessor.min, max: accessor.max };\n if (!minMax.min || !minMax.max) {\n // @ts-ignore\n minMax = this._getAccessorMinMax(sourceBuffer, accessor.size);\n }\n const accessorDefaults = {\n // @ts-ignore\n size: accessor.size,\n componentType: getComponentTypeFromArray(sourceBuffer),\n // @ts-ignore\n count: Math.round(sourceBuffer.length / accessor.size),\n min: minMax.min,\n max: minMax.max\n };\n return this.addAccessor(bufferViewIndex, Object.assign(accessorDefaults, accessor));\n }\n /**\n * Adds a texture to the json part\n * @todo: add more properties for texture initialization\n * `sampler`, `name`, `extensions`, `extras`\n * https://github.com/KhronosGroup/glTF/tree/master/specification/2.0#texture\n */\n addTexture(texture) {\n const { imageIndex } = texture;\n const glTFTexture = {\n source: imageIndex\n };\n this.json.textures = this.json.textures || [];\n this.json.textures.push(glTFTexture);\n return this.json.textures.length - 1;\n }\n /** Adds a material to the json part */\n addMaterial(pbrMaterialInfo) {\n this.json.materials = this.json.materials || [];\n this.json.materials.push(pbrMaterialInfo);\n return this.json.materials.length - 1;\n }\n /** Pack the binary chunk */\n createBinaryChunk() {\n // Allocate total array\n const totalByteLength = this.byteLength;\n const arrayBuffer = new ArrayBuffer(totalByteLength);\n const targetArray = new Uint8Array(arrayBuffer);\n // Copy each array into\n let dstByteOffset = 0;\n for (const sourceBuffer of this.sourceBuffers || []) {\n dstByteOffset = copyToArray(sourceBuffer, targetArray, dstByteOffset);\n }\n // Update the glTF BIN CHUNK byte length\n if (this.json?.buffers?.[0]) {\n this.json.buffers[0].byteLength = totalByteLength;\n }\n else {\n this.json.buffers = [{ byteLength: totalByteLength }];\n }\n // Save generated arrayBuffer\n this.gltf.binary = arrayBuffer;\n // Put arrayBuffer to sourceBuffers for possible additional writing data in the chunk\n this.sourceBuffers = [arrayBuffer];\n this.gltf.buffers = [{ arrayBuffer, byteOffset: 0, byteLength: arrayBuffer.byteLength }];\n }\n // PRIVATE\n _removeStringFromArray(array, string) {\n let found = true;\n while (found) {\n const index = array.indexOf(string);\n if (index > -1) {\n array.splice(index, 1);\n }\n else {\n found = false;\n }\n }\n }\n /**\n * Add attributes to buffers and create `attributes` object which is part of `mesh`\n */\n _addAttributes(attributes = {}) {\n const result = {};\n for (const attributeKey in attributes) {\n const attributeData = attributes[attributeKey];\n const attrName = this._getGltfAttributeName(attributeKey);\n const accessor = this.addBinaryBuffer(attributeData.value, attributeData);\n result[attrName] = accessor;\n }\n return result;\n }\n /**\n * Add indices to buffers\n */\n _addIndices(indices) {\n return this.addBinaryBuffer(indices, { size: 1 });\n }\n /**\n * Deduce gltf specific attribue name from input attribute name\n */\n _getGltfAttributeName(attributeName) {\n switch (attributeName.toLowerCase()) {\n case 'position':\n case 'positions':\n case 'vertices':\n return 'POSITION';\n case 'normal':\n case 'normals':\n return 'NORMAL';\n case 'color':\n case 'colors':\n return 'COLOR_0';\n case 'texcoord':\n case 'texcoords':\n return 'TEXCOORD_0';\n default:\n return attributeName;\n }\n }\n /**\n * Calculate `min` and `max` arrays of accessor according to spec:\n * https://github.com/KhronosGroup/glTF/tree/master/specification/2.0#reference-accessor\n */\n _getAccessorMinMax(buffer, size) {\n const result = { min: null, max: null };\n if (buffer.length < size) {\n return result;\n }\n // @ts-ignore\n result.min = [];\n // @ts-ignore\n result.max = [];\n const initValues = buffer.subarray(0, size);\n for (const value of initValues) {\n // @ts-ignore\n result.min.push(value);\n // @ts-ignore\n result.max.push(value);\n }\n for (let index = size; index < buffer.length; index += size) {\n for (let componentIndex = 0; componentIndex < size; componentIndex++) {\n // @ts-ignore\n result.min[0 + componentIndex] = Math.min(\n // @ts-ignore\n result.min[0 + componentIndex], buffer[index + componentIndex]);\n // @ts-ignore\n result.max[0 + componentIndex] = Math.max(\n // @ts-ignore\n result.max[0 + componentIndex], buffer[index + componentIndex]);\n }\n }\n return result;\n }\n}\n","/**\n * loaders.gl, MIT license\n *\n * Shared code for 3DTiles extensions:\n * * EXT_feature_metadata\n * * EXT_mesh_features\n * * EXT_structural_metadata\n */\nimport { getComponentTypeFromArray } from \"../../gltf-utils/gltf-utils.js\";\nimport { getImageData } from '@loaders.gl/images';\nfunction emod(n) {\n return ((n % 1) + 1) % 1;\n}\nconst ATTRIBUTE_TYPE_TO_COMPONENTS = {\n SCALAR: 1,\n VEC2: 2,\n VEC3: 3,\n VEC4: 4,\n MAT2: 4,\n MAT3: 9,\n MAT4: 16,\n BOOLEAN: 1,\n STRING: 1,\n ENUM: 1\n};\nconst ATTRIBUTE_COMPONENT_TYPE_TO_ARRAY = {\n INT8: Int8Array,\n UINT8: Uint8Array,\n INT16: Int16Array,\n UINT16: Uint16Array,\n INT32: Int32Array,\n UINT32: Uint32Array,\n INT64: BigInt64Array,\n UINT64: BigUint64Array,\n FLOAT32: Float32Array,\n FLOAT64: Float64Array\n};\nconst ATTRIBUTE_COMPONENT_TYPE_TO_BYTE_SIZE = {\n INT8: 1,\n UINT8: 1,\n INT16: 2,\n UINT16: 2,\n INT32: 4,\n UINT32: 4,\n INT64: 8,\n UINT64: 8,\n FLOAT32: 4,\n FLOAT64: 8\n};\nexport function getArrayElementByteSize(attributeType, componentType) {\n return (ATTRIBUTE_COMPONENT_TYPE_TO_BYTE_SIZE[componentType] *\n ATTRIBUTE_TYPE_TO_COMPONENTS[attributeType]);\n}\n/**\n * Gets offset array from `arrayOffsets` or `stringOffsets`.\n * @param scenegraph - Instance of the class for structured access to GLTF data.\n * @param bufferViewIndex - Buffer view index\n * @param offsetType - The type of values in `arrayOffsets` or `stringOffsets`.\n * @param numberOfElements - The number of elements in each property array.\n * @returns Array of values offsets. The number of offsets in the array is equal to `numberOfElements` plus one.\n */\nexport function getOffsetsForProperty(scenegraph, bufferViewIndex, offsetType, numberOfElements) {\n if (offsetType !== 'UINT8' &&\n offsetType !== 'UINT16' &&\n offsetType !== 'UINT32' &&\n offsetType !== 'UINT64') {\n return null;\n }\n const arrayOffsetsBytes = scenegraph.getTypedArrayForBufferView(bufferViewIndex);\n const arrayOffsets = convertRawBufferToMetadataArray(arrayOffsetsBytes, 'SCALAR', // offsets consist of ONE component\n offsetType, numberOfElements + 1 // The number of offsets is equal to the property table `count` plus one.\n );\n // We don't support BigInt offsets at the moment. It requires additional logic and potential issues in Safari\n if (arrayOffsets instanceof BigInt64Array || arrayOffsets instanceof BigUint64Array) {\n return null;\n }\n return arrayOffsets;\n}\n/**\n * Converts raw bytes that are in the buffer to an array of the type defined by the schema.\n * @param data - Raw bytes in the buffer.\n * @param attributeType - SCALAR, VECN, MATN.\n * @param componentType - Type of the component in elements, e.g. 'UINT8' or 'FLOAT32'.\n * @param elementCount - Number of elements in the array. Default value is 1.\n * @returns Data array\n */\nexport function convertRawBufferToMetadataArray(data, attributeType, componentType, elementCount = 1) {\n const numberOfComponents = ATTRIBUTE_TYPE_TO_COMPONENTS[attributeType];\n const ArrayType = ATTRIBUTE_COMPONENT_TYPE_TO_ARRAY[componentType];\n const size = ATTRIBUTE_COMPONENT_TYPE_TO_BYTE_SIZE[componentType];\n const length = elementCount * numberOfComponents;\n const byteLength = length * size;\n let buffer = data.buffer;\n let offset = data.byteOffset;\n if (offset % size !== 0) {\n const bufferArray = new Uint8Array(buffer);\n buffer = bufferArray.slice(offset, offset + byteLength).buffer;\n offset = 0;\n }\n return new ArrayType(buffer, offset, length);\n}\n/**\n * Processes data encoded in the texture associated with the primitive.\n * @param scenegraph - Instance of the class for structured access to GLTF data.\n * @param textureInfo - Reference to the texture where extension data are stored.\n * @param primitive - Primitive object in the mesh.\n * @returns Array of data taken. Null if data can't be taken from the texture.\n */\nexport function getPrimitiveTextureData(scenegraph, textureInfo, primitive) {\n /*\n texture.index is an index for the \"textures\" array.\n The texture object referenced by this index looks like this:\n {\n \"sampler\": 0,\n \"source\": 0\n }\n \"sampler\" is an index for the \"samplers\" array\n \"source\" is an index for the \"images\" array that contains data stored in rgba channels of the image.\n \n texture.texCoord is a number-suffix (like 1) for an attribute like \"TEXCOORD_1\" in meshes.primitives\n The value of \"TEXCOORD_1\" is an accessor that is used to get coordinates.\n These coordinates are being used to get data from the image.\n \n Default for texture.texCoord is 0\n @see https://github.com/CesiumGS/glTF/blob/3d-tiles-next/specification/2.0/schema/textureInfo.schema.json\n */\n const texCoordAccessorKey = `TEXCOORD_${textureInfo.texCoord || 0}`;\n const texCoordAccessorIndex = primitive.attributes[texCoordAccessorKey];\n const textureCoordinates = scenegraph.getTypedArrayForAccessor(texCoordAccessorIndex);\n const json = scenegraph.gltf.json;\n const textureIndex = textureInfo.index;\n const imageIndex = json.textures?.[textureIndex]?.source;\n if (typeof imageIndex !== 'undefined') {\n const mimeType = json.images?.[imageIndex]?.mimeType;\n const parsedImage = scenegraph.gltf.images?.[imageIndex];\n // Checking for width is to prevent handling Un-processed images (e.g. [analyze] stage, where loadImages option is set to false)\n if (parsedImage && typeof parsedImage.width !== 'undefined') {\n const textureData = [];\n for (let index = 0; index < textureCoordinates.length; index += 2) {\n const value = getImageValueByCoordinates(parsedImage, mimeType, textureCoordinates, index, textureInfo.channels);\n textureData.push(value);\n }\n return textureData;\n }\n }\n return [];\n}\n/**\n * Puts property data to attributes.\n * It creates corresponding buffer, bufferView and accessor\n * so the data can be accessed like regular data stored in buffers.\n * @param scenegraph - Scenegraph object.\n * @param attributeName - Name of the attribute.\n * @param propertyData - Property data to store.\n * @param featureTable - Array where unique data from the property data are being stored.\n * @param primitive - Primitive object.\n */\nexport function primitivePropertyDataToAttributes(scenegraph, attributeName, propertyData, featureTable, primitive) {\n // No reason to create an empty buffer if there is no property data to store.\n if (!propertyData?.length) {\n return;\n }\n /*\n featureTable will contain unique values, e.g.\n propertyData = [24, 35, 28, 24]\n featureTable = [24, 35, 28]\n featureIndices will contain indices that refer featureTextureTable, e.g.\n featureIndices = [0, 1, 2, 0]\n */\n const featureIndices = [];\n for (const texelData of propertyData) {\n let index = featureTable.findIndex((item) => item === texelData);\n if (index === -1) {\n index = featureTable.push(texelData) - 1;\n }\n featureIndices.push(index);\n }\n const typedArray = new Uint32Array(featureIndices);\n const bufferIndex = scenegraph.gltf.buffers.push({\n arrayBuffer: typedArray.buffer,\n byteOffset: typedArray.byteOffset,\n byteLength: typedArray.byteLength\n }) - 1;\n const bufferViewIndex = scenegraph.addBufferView(typedArray, bufferIndex, 0);\n const accessorIndex = scenegraph.addAccessor(bufferViewIndex, {\n size: 1,\n componentType: getComponentTypeFromArray(typedArray),\n count: typedArray.length\n });\n primitive.attributes[attributeName] = accessorIndex;\n}\n/**\n * Gets the value from the texture by coordinates provided.\n * @param parsedImage - Image where the data are stored.\n * @param mimeType - MIME type.\n * @param textureCoordinates - uv coordinates to access data in the image.\n * @param index - Index of uv coordinates in the array textureCoordinates.\n * @param channels - Image channels where data are stored.\n * Channels of an RGBA texture are numbered 0..3 respectively.\n * For Ext_mesh_features and EXT_strucural_metadata the channels default is [0]\n * @see https://github.com/CesiumGS/glTF/blob/3d-tiles-next/extensions/2.0/Vendor/EXT_mesh_features/schema/featureIdTexture.schema.json\n * @see https://github.com/CesiumGS/glTF/blob/3d-tiles-next/extensions/2.0/Vendor/EXT_structural_metadata/schema/propertyTexture.property.schema.json\n * @returns Value taken from the image.\n */\nfunction getImageValueByCoordinates(parsedImage, mimeType, textureCoordinates, index, channels = [0]) {\n const CHANNELS_MAP = {\n r: { offset: 0, shift: 0 },\n g: { offset: 1, shift: 8 },\n b: { offset: 2, shift: 16 },\n a: { offset: 3, shift: 24 }\n };\n const u = textureCoordinates[index];\n const v = textureCoordinates[index + 1];\n let components = 1;\n if (mimeType && (mimeType.indexOf('image/jpeg') !== -1 || mimeType.indexOf('image/png') !== -1))\n components = 4;\n const offset = coordinatesToOffset(u, v, parsedImage, components);\n let value = 0;\n for (const c of channels) {\n /*\n According to the EXT_feature_metadata extension specification:\n Channels are labeled by rgba and are swizzled with a string of 1-4 characters.\n According to the EXT_mesh_features extension specification:\n The channels array contains non-negative integer values corresponding to channels of the source texture that the feature ID consists of.\n Channels of an RGBA texture are numbered 0–3 respectively.\n Function getImageValueByCoordinates is used to process both extensions.\n So, there should be possible to get the element of CHANNELS_MAP by either index (0, 1, 2, 3) or key (r, g, b, a).\n */\n const map = typeof c === 'number' ? Object.values(CHANNELS_MAP)[c] : CHANNELS_MAP[c];\n const imageOffset = offset + map.offset;\n const imageData = getImageData(parsedImage);\n if (imageData.data.length <= imageOffset) {\n throw new Error(`${imageData.data.length} <= ${imageOffset}`);\n }\n const imageValue = imageData.data[imageOffset];\n value |= imageValue << map.shift;\n }\n return value;\n}\n/**\n * Retrieves the offset in the image where the data are stored.\n * @param u - u-coordinate.\n * @param v - v-coordinate.\n * @param parsedImage - Image where the data are stored.\n * @param componentsCount - Number of components the data consists of.\n * @returns Offset in the image where the data are stored.\n */\nfunction coordinatesToOffset(u, v, parsedImage, componentsCount = 1) {\n const w = parsedImage.width;\n const iX = emod(u) * (w - 1);\n const indX = Math.round(iX);\n const h = parsedImage.height;\n const iY = emod(v) * (h - 1);\n const indY = Math.round(iY);\n const components = parsedImage.components ? parsedImage.components : componentsCount;\n // components is a number of channels in the image\n const offset = (indY * w + indX) * components;\n return offset;\n}\n/**\n * Parses variable-length array data.\n * In this case every value of the property in the table will be an array\n * of arbitrary length.\n * @param valuesData - Values in a flat typed array.\n * @param numberOfElements - Number of rows in the property table.\n * @param arrayOffsets - Offsets of nested arrays in the flat values array.\n * @param valuesDataBytesLength - Data byte length.\n * @param valueSize - Value size in bytes.\n * @returns Array of typed arrays.\n */\nexport function parseVariableLengthArrayNumeric(valuesData, numberOfElements, arrayOffsets, valuesDataBytesLength, valueSize) {\n const attributeValueArray = [];\n for (let index = 0; index < numberOfElements; index++) {\n const arrayOffset = arrayOffsets[index];\n const arrayByteSize = arrayOffsets[index + 1] - arrayOffsets[index];\n if (arrayByteSize + arrayOffset > valuesDataBytesLength) {\n break;\n }\n const typedArrayOffset = arrayOffset / valueSize;\n const elementCount = arrayByteSize / valueSize;\n attributeValueArray.push(valuesData.slice(typedArrayOffset, typedArrayOffset + elementCount));\n }\n return attributeValueArray;\n}\n/**\n * Parses fixed-length array data.\n * In this case every value of the property in the table will be an array\n * of constant length equal to `arrayCount`.\n * @param valuesData - Values in a flat typed array.\n * @param numberOfElements - Number of rows in the property table.\n * @param arrayCount - Nested arrays length.\n * @returns Array of typed arrays.\n */\nexport function parseFixedLengthArrayNumeric(valuesData, numberOfElements, arrayCount) {\n const attributeValueArray = [];\n for (let index = 0; index < numberOfElements; index++) {\n const elementOffset = index * arrayCount;\n attributeValueArray.push(valuesData.slice(elementOffset, elementOffset + arrayCount));\n }\n return attributeValueArray;\n}\n/**\n * Decodes properties of string type from binary source.\n * @param numberOfElements - The number of elements in each property array that propertyTableProperty contains. It's a number of rows in the table.\n * @param valuesDataBytes - Data taken from values property of the property table property.\n * @param arrayOffsets - Offsets for variable-length arrays. It's null for fixed-length arrays or scalar types.\n * @param stringOffsets - Index of the buffer view containing offsets for strings. It should be available for string type.\n * @returns String property values\n */\nexport function getPropertyDataString(numberOfElements, valuesDataBytes, arrayOffsets, stringOffsets) {\n if (arrayOffsets) {\n // TODO: implement it as soon as we have the corresponding tileset\n throw new Error('Not implemented - arrayOffsets for strings is specified');\n }\n if (stringOffsets) {\n const stringsArray = [];\n const textDecoder = new TextDecoder('utf8');\n let stringOffset = 0;\n for (let index = 0; index < numberOfElements; index++) {\n const stringByteSize = stringOffsets[index + 1] - stringOffsets[index];\n if (stringByteSize + stringOffset <= valuesDataBytes.length) {\n const stringData = valuesDataBytes.subarray(stringOffset, stringByteSize + stringOffset);\n const stringAttribute = textDecoder.decode(stringData);\n stringsArray.push(stringAttribute);\n stringOffset += stringByteSize;\n }\n }\n return stringsArray;\n }\n return [];\n}\n","import { GLTFScenegraph } from \"../api/gltf-scenegraph.js\";\nimport { getPrimitiveTextureData } from \"./utils/3d-tiles-utils.js\";\nimport { getComponentTypeFromArray } from \"../gltf-utils/gltf-utils.js\";\nconst EXT_MESH_FEATURES_NAME = 'EXT_mesh_features';\nexport const name = EXT_MESH_FEATURES_NAME;\nexport async function decode(gltfData, options) {\n const scenegraph = new GLTFScenegraph(gltfData);\n decodeExtMeshFeatures(scenegraph, options);\n}\nexport function encode(gltfData, options) {\n const scenegraph = new GLTFScenegraph(gltfData);\n encodeExtMeshFeatures(scenegraph, options);\n scenegraph.createBinaryChunk();\n return scenegraph.gltf;\n}\n/**\n * Decodes feature metadata from extension.\n * @param {GLTFScenegraph} scenegraph - Instance of the class for structured access to GLTF data.\n * @param {GLTFLoaderOptions} options - GLTFLoader options.\n */\nfunction decodeExtMeshFeatures(scenegraph, options) {\n const json = scenegraph.gltf.json;\n if (!json.meshes) {\n return;\n }\n // Iterate through all meshes/primitives.\n for (const mesh of json.meshes) {\n for (const primitive of mesh.primitives) {\n processMeshPrimitiveFeatures(scenegraph, primitive, options);\n }\n }\n}\n/**\n * Takes data from EXT_mesh_features and store it in 'data' property of featureIds.\n * If combined with EXT_structural_metadata, corresponding data are taken from the property tables of that extension.\n * @param {GLTFScenegraph} scenegraph - Instance of the class for structured access to GLTF data.\n * @param {GLTFMeshPrimitive} primitive - Primitive that contains extensions.\n * @param {GLTFLoaderOptions} options - GLTFLoader options.\n */\nfunction processMeshPrimitiveFeatures(scenegraph, primitive, options) {\n // Processing of mesh primitive features requires buffers to be loaded.\n if (!options?.gltf?.loadBuffers) {\n return;\n }\n const extension = primitive.extensions?.[EXT_MESH_FEATURES_NAME];\n const featureIds = extension?.featureIds;\n if (!featureIds) {\n return;\n }\n for (const featureId of featureIds) {\n let featureIdData;\n // Process \"Feature ID by Vertex\"\n if (typeof featureId.attribute !== 'undefined') {\n const accessorKey = `_FEATURE_ID_${featureId.attribute}`;\n const accessorIndex = primitive.attributes[accessorKey];\n featureIdData = scenegraph.getTypedArrayForAccessor(accessorIndex);\n }\n // Process \"Feature ID by Texture Coordinates\"\n else if (typeof featureId.texture !== 'undefined' && options?.gltf?.loadImages) {\n featureIdData = getPrimitiveTextureData(scenegraph, featureId.texture, primitive);\n }\n // Process \"Feature ID by Index\"\n else {\n /*\n When both featureId.attribute and featureId.texture are undefined,\n then the feature ID value for each vertex is given implicitly, via the index of the vertex.\n In this case, the featureCount must match the number of vertices of the mesh primitive.\n */\n // TODO: At the moment of writing we don't have a tileset with the data of that kind. Implement it later.\n featureIdData = [];\n }\n featureId.data = featureIdData;\n }\n}\n/*\n Encoding data\n*/\nfunction encodeExtMeshFeatures(scenegraph, options) {\n const meshes = scenegraph.gltf.json.meshes;\n if (!meshes) {\n return;\n }\n // Iterate through all meshes/primitives.\n for (const mesh of meshes) {\n for (const primitive of mesh.primitives) {\n encodeExtMeshFeaturesForPrimitive(scenegraph, primitive);\n }\n }\n}\n/**\n * Creates ExtMeshFeatures, creates a featureId containing feature ids provided.\n * @param scenegraph - Instance of the class for structured access to GLTF data.\n * @param primitive - target primitive instance that will contain the extension\n * @param featureIdArray - Array of feature id\n * @param propertyTableIndex - index of the property table created by the ExtStructuralMetadata (optional).\n */\nexport function createExtMeshFeatures(scenegraph, primitive, featureIdArray, propertyTableIndex) {\n if (!primitive.extensions) {\n primitive.extensions = {};\n }\n let extension = primitive.extensions[EXT_MESH_FEATURES_NAME];\n if (!extension) {\n extension = { featureIds: [] };\n primitive.extensions[EXT_MESH_FEATURES_NAME] = extension;\n }\n const { featureIds } = extension;\n const featureId = {\n featureCount: featureIdArray.length,\n propertyTable: propertyTableIndex,\n data: featureIdArray\n };\n featureIds.push(featureId);\n scenegraph.addObjectExtension(primitive, EXT_MESH_FEATURES_NAME, extension);\n}\n/**\n * Encodes a feature ID set to extension.\n * @param scenegraph - Instance of the class for structured access to GLTF data.\n * @param primitive - Primitive that the data encoded belongs to.\n * @see https://github.com/CesiumGS/glTF/tree/3d-tiles-next/extensions/2.0/Vendor/EXT_mesh_features\n */\nfunction encodeExtMeshFeaturesForPrimitive(scenegraph, primitive) {\n const extension = primitive.extensions?.[EXT_MESH_FEATURES_NAME];\n if (!extension) {\n return;\n }\n const featureIds = extension.featureIds;\n featureIds.forEach((featureId, elementIndex) => {\n if (featureId.data) {\n const { accessorKey, index } = createAccessorKey(primitive.attributes);\n const typedArray = new Uint32Array(featureId.data);\n // Clean up featureId object.\n // Everything that could come from the original extension in case of round-trip decode/encode operations should be deleted.\n // We need make sure the featureId object is clean.\n featureIds[elementIndex] = {\n featureCount: typedArray.length,\n propertyTable: featureId.propertyTable,\n attribute: index\n };\n scenegraph.gltf.buffers.push({\n arrayBuffer: typedArray.buffer,\n byteOffset: typedArray.byteOffset,\n byteLength: typedArray.byteLength\n });\n const bufferViewIndex = scenegraph.addBufferView(typedArray);\n const accessorIndex = scenegraph.addAccessor(bufferViewIndex, {\n size: 1,\n componentType: getComponentTypeFromArray(typedArray),\n count: typedArray.length\n });\n primitive.attributes[accessorKey] = accessorIndex;\n }\n });\n}\n/**\n * Creates an accessor key for the attribute array provided.\n * The generated key has a suffix (number) that is the next consequtive in the list of existing accessors.\n * @param attributes - attribute array\n * @returns accessor key and the key suffix (number) used in the key.\n */\nfunction createAccessorKey(attributes) {\n const prefix = '_FEATURE_ID_';\n // Search for all \"_FEATURE_ID_n\" attribures in the primitive provided if any.\n // If there are some, e.g. \"_FEATURE_ID_0\", \"_FEATURE_ID_1\",\n // we will add a new one with the name \"_FEATURE_ID_2\"\n const attrs = Object.keys(attributes).filter((item) => item.indexOf(prefix) === 0);\n let max = -1;\n for (const a of attrs) {\n const n = Number(a.substring(prefix.length));\n if (n > max) {\n max = n;\n }\n }\n max++;\n const accessorKey = `${prefix}${max}`;\n return { accessorKey, index: max };\n}\n","import { GLTFScenegraph } from \"../api/gltf-scenegraph.js\";\nimport { convertRawBufferToMetadataArray, getPrimitiveTextureData, primitivePropertyDataToAttributes, getArrayElementByteSize, getOffsetsForProperty, parseVariableLengthArrayNumeric, parseFixedLengthArrayNumeric, getPropertyDataString } from \"./utils/3d-tiles-utils.js\";\nconst EXT_STRUCTURAL_METADATA_NAME = 'EXT_structural_metadata';\nexport const name = EXT_STRUCTURAL_METADATA_NAME;\nexport async function decode(gltfData, options) {\n const scenegraph = new GLTFScenegraph(gltfData);\n decodeExtStructuralMetadata(scenegraph, options);\n}\nexport function encode(gltfData, options) {\n const scenegraph = new GLTFScenegraph(gltfData);\n encodeExtStructuralMetadata(scenegraph, options);\n scenegraph.createBinaryChunk();\n return scenegraph.gltf;\n}\n/*\n// Example of the extension.\n// See more info at https://github.com/CesiumGS/glTF/tree/3d-tiles-next/extensions/2.0/Vendor/EXT_structural_metadata\nconst extensions = {\n \"extensions\": {\n \"EXT_structural_metadata\": {\n \"schema\": {\n \"classes\": {\n \"tree\": {\n \"name\": \"Tree\",\n \"description\": \"Woody, perennial plant.\",\n \"properties\": {\n \"species\": {\n \"description\": \"Type of tree.\",\n \"type\": \"ENUM\",\n \"enumType\": \"speciesEnum\",\n \"required\": true\n },\n \"age\": {\n \"description\": \"The age of the tree, in years\",\n \"type\": \"SCALAR\",\n \"componentType\": \"UINT8\",\n \"required\": true\n }\n }\n }\n },\n \"enums\": {\n \"speciesEnum\": {\n \"name\": \"Species\",\n \"description\": \"An example enum for tree species.\",\n // valueType is not defined here. Default is \"UINT16\"\n \"values\": [\n { \"name\": \"Unspecified\", \"value\": 0 },\n { \"name\": \"Oak\", \"value\": 1 }\n ]\n }\n }\n },\n \"propertyTables\": [{\n \"name\": \"tree_survey_2021-09-29\",\n \"class\": \"tree\",\n \"count\": 10, // The number of elements in each property array (in `species`, in `age`).\n \"properties\": {\n \"species\": {\n \"values\": 0, // It's an index of the buffer view containing property values.\n },\n \"age\": {\n \"values\": 1\n }\n }\n }]\n }\n }\n}\n*/\n/**\n * Decodes feature metadata from extension.\n * @param scenegraph - Instance of the class for structured access to GLTF data.\n * @param options - GLTFLoader options.\n */\nfunction decodeExtStructuralMetadata(scenegraph, options) {\n // Decoding metadata involves buffers processing.\n // So, if buffers have not been loaded, there is no reason to process metadata.\n if (!options.gltf?.loadBuffers) {\n return;\n }\n const extension = scenegraph.getExtension(EXT_STRUCTURAL_METADATA_NAME);\n if (!extension) {\n return;\n }\n if (options.gltf?.loadImages) {\n decodePropertyTextures(scenegraph, extension);\n }\n decodePropertyTables(scenegraph, extension);\n}\n/**\n * Processes the data stored in the textures\n * @param scenegraph - Instance of the class for structured access to GLTF data.\n * @param extension - Top-level extension.\n */\nfunction decodePropertyTextures(scenegraph, extension) {\n const propertyTextures = extension.propertyTextures;\n const json = scenegraph.gltf.json;\n if (propertyTextures && json.meshes) {\n // Iterate through all meshes/primitives.\n for (const mesh of json.meshes) {\n for (const primitive of mesh.primitives) {\n processPrimitivePropertyTextures(scenegraph, propertyTextures, primitive, extension);\n }\n }\n }\n}\n/**\n * Processes the data stored in the property tables.\n * @param scenegraph - Instance of the class for structured access to GLTF data.\n * @param extension - Top-level extension.\n */\nfunction decodePropertyTables(scenegraph, extension) {\n const schema = extension.schema;\n if (!schema) {\n return;\n }\n const schemaClasses = schema.classes;\n const propertyTables = extension.propertyTables;\n if (schemaClasses && propertyTables) {\n for (const schemaName in schemaClasses) {\n const propertyTable = findPropertyTableByClass(propertyTables, schemaName);\n if (propertyTable) {\n processPropertyTable(scenegraph, schema, propertyTable);\n }\n }\n }\n}\n/**\n * Finds the property table by class name.\n * @param propertyTables - propertyTable definition taken from the top-level extension.\n * @param schemaClassName - class name in the extension schema.\n */\nfunction findPropertyTableByClass(propertyTables, schemaClassName) {\n for (const propertyTable of propertyTables) {\n if (propertyTable.class === schemaClassName) {\n return propertyTable;\n }\n }\n return null;\n}\n/**\n * Takes data from property textures reffered by the primitive.\n * @param scenegraph - Instance of the class for structured access to GLTF data.\n * @param propertyTextures - propertyTexture definition taken from the top-level extention.\n * @param primitive - Primitive object.\n * @param extension - Top-level extension.\n */\nfunction processPrimitivePropertyTextures(scenegraph, propertyTextures, primitive, extension) {\n if (!propertyTextures) {\n return;\n }\n const primitiveExtension = primitive.extensions?.[EXT_STRUCTURAL_METADATA_NAME];\n const primitivePropertyTextureIndices = primitiveExtension?.propertyTextures;\n if (!primitivePropertyTextureIndices) {\n return;\n }\n for (const primitivePropertyTextureIndex of primitivePropertyTextureIndices) {\n const propertyTexture = propertyTextures[primitivePropertyTextureIndex];\n processPrimitivePropertyTexture(scenegraph, propertyTexture, primitive, extension);\n }\n}\n/**\n * Takes property data from the texture pointed by the primitive and appends them to `exension.data`.\n * @param scenegraph - Instance of the class for structured access to GLTF data.\n * @param propertyTexture - propertyTexture definition taken from the top-level extension.\n * @param primitive - Primitive object.\n * @param extension - Top-level extension.\n */\nfunction processPrimitivePropertyTexture(scenegraph, propertyTexture, primitive, extension) {\n if (!propertyTexture.properties) {\n return;\n }\n if (!extension.dataAttributeNames) {\n extension.dataAttributeNames = [];\n }\n /* Iterate through all properties defined in propertyTexture, e.g. \"speed\" and \"direction\":\n {\n \"class\": \"wind\",\n \"properties\": {\n \"speed\": {\n \"index\": 0,\n \"texCoord\": 0,\n \"channels\": [0]\n },\n \"direction\": {\n \"index\": 0,\n \"texCoord\": 0,\n \"channels\": [1, 2]\n }\n }\n }\n */\n const className = propertyTexture.class;\n for (const propertyName in propertyTexture.properties) {\n // propertyName has values like \"speed\", \"direction\"\n // Make attributeName as a combination of the class name and the propertyName like \"wind_speed\" or \"wind_direction\"\n const attributeName = `${className}_${propertyName}`;\n const textureInfoTopLevel = propertyTexture.properties?.[propertyName];\n if (!textureInfoTopLevel) {\n // eslint-disable-next-line no-continue\n continue;\n }\n // The data taken from all meshes/primitives (the same property, e.g. \"speed\" or \"direction\") will be combined into one array and saved in textureInfoTopLevel.data\n // Initially textureInfoTopLevel.data will be initialized with an empty array.\n if (!textureInfoTopLevel.data) {\n textureInfoTopLevel.data = [];\n }\n const featureTextureTable = textureInfoTopLevel.data;\n const propertyData = getPrimitiveTextureData(scenegraph, textureInfoTopLevel, primitive);\n if (propertyData === null) {\n // eslint-disable-next-line no-continue\n continue;\n }\n primitivePropertyDataToAttributes(scenegraph, attributeName, propertyData, featureTextureTable, primitive);\n textureInfoTopLevel.data = featureTextureTable;\n extension.dataAttributeNames.push(attributeName);\n }\n}\n/**\n * Navigates through all properies in the property table, gets properties data,\n * and put the data to `propertyTable.data` as an array.\n * @param scenegraph - Instance of the class for structured access to GLTF data.\n * @param schema - schema object.\n * @param propertyTable - propertyTable definition taken from the top-level extension.\n */\nfunction processPropertyTable(scenegraph, schema, propertyTable) {\n const schemaClass = schema.classes?.[propertyTable.class];\n if (!schemaClass) {\n throw new Error(`Incorrect data in the EXT_structural_metadata extension: no schema class with name ${propertyTable.class}`);\n }\n const numberOfElements = propertyTable.count; // `propertyTable.count` is a number of elements in each property array.\n for (const propertyName in schemaClass.properties) {\n const classProperty = schemaClass.properties[propertyName];\n const propertyTableProperty = propertyTable.properties?.[propertyName];\n if (propertyTableProperty) {\n // Getting all elements (`numberOfElements`) of the array in the `propertyTableProperty`\n const data = getPropertyDataFromBinarySource(scenegraph, schema, classProperty, numberOfElements, propertyTableProperty);\n propertyTableProperty.data = data;\n }\n }\n}\n/**\n * Decodes a propertyTable column from binary source based on property type.\n * @param scenegraph - Instance of the class for structured access to GLTF data.\n * @param schema - Schema object.\n * @param classProperty - class property object.\n * @param numberOfElements - The number of elements in each property array that propertyTableProperty contains. It's a number of rows in the table.\n * @param propertyTableProperty - propertyTable's property metadata.\n * @returns {string[] | number[] | string[][] | number[][]}\n */\nfunction getPropertyDataFromBinarySource(scenegraph, schema, classProperty, numberOfElements, propertyTableProperty) {\n let data = [];\n const valuesBufferView = propertyTableProperty.values;\n const valuesDataBytes = scenegraph.getTypedArrayForBufferView(valuesBufferView);\n const arrayOffsets = getArrayOffsetsForProperty(scenegraph, classProperty, propertyTableProperty, numberOfElements);\n const stringOffsets = getStringOffsetsForProperty(scenegraph, propertyTableProperty, numberOfElements);\n switch (classProperty.type) {\n case 'SCALAR':\n case 'VEC2':\n case 'VEC3':\n case 'VEC4':\n case 'MAT2':\n case 'MAT3':\n case 'MAT4': {\n data = getPropertyDataNumeric(classProperty, numberOfElements, valuesDataBytes, arrayOffsets);\n break;\n }\n case 'BOOLEAN': {\n // TODO: implement it as soon as we have the corresponding tileset\n throw new Error(`Not implemented - classProperty.type=${classProperty.type}`);\n }\n case 'STRING': {\n data = getPropertyDataString(numberOfElements, valuesDataBytes, arrayOffsets, stringOffsets);\n break;\n }\n case 'ENUM': {\n data = getPropertyDataENUM(schema, classProperty, numberOfElements, valuesDataBytes, arrayOffsets);\n break;\n }\n default:\n throw new Error(`Unknown classProperty type ${classProperty.type}`);\n }\n return data;\n}\n/**\n * Parses propertyTable.property.arrayOffsets that are offsets of sub-arrays in a flatten array of values.\n * @param scenegraph - Instance of the class for structured access to GLTF data.\n * @param classProperty - class property object.\n * @param propertyTableProperty - propertyTable's property metadata.\n * @param numberOfElements - The number of elements in each property array that propertyTableProperty contains. It's a number of rows in the table.\n * @returns Typed array with offset values.\n * @see https://github.com/CesiumGS/glTF/blob/2976f1183343a47a29e4059a70961371cd2fcee8/extensions/2.0/Vendor/EXT_structural_metadata/schema/propertyTable.property.schema.json#L21\n */\nfunction getArrayOffsetsForProperty(scenegraph, classProperty, propertyTableProperty, numberOfElements) {\n if (classProperty.array &&\n // `count` is a number of array elements. May only be defined when `array` is true.\n // If `count` is NOT defined, it's a VARIABLE-length array\n typeof classProperty.count === 'undefined' &&\n // `arrayOffsets` is an index of the buffer view containing offsets for variable-length arrays.\n typeof propertyTableProperty.arrayOffsets !== 'undefined') {\n // Data are in a VARIABLE-length array\n return getOffsetsForProperty(scenegraph, propertyTableProperty.arrayOffsets, propertyTableProperty.arrayOffsetType || 'UINT32', numberOfElements);\n }\n return null;\n}\n/**\n * Parses propertyTable.property.stringOffsets.\n * @param scenegraph - Instance of the class for structured access to GLTF data.\n * @param propertyTableProperty - propertyTable's property metadata.\n * @param numberOfElements - The number of elements in each property array that propertyTableProperty contains. It's a number of rows in the table.\n * @returns Typed array with offset values.\n * @see https://github.com/CesiumGS/glTF/blob/2976f1183343a47a29e4059a70961371cd2fcee8/extensions/2.0/Vendor/EXT_structural_metadata/schema/propertyTable.property.schema.json#L29C10-L29C23\n */\nfunction getStringOffsetsForProperty(scenegraph, propertyTableProperty, numberOfElements) {\n if (typeof propertyTableProperty.stringOffsets !== 'undefined' // `stringOffsets` is an index of the buffer view containing offsets for strings.\n ) {\n // Data are in a FIXED-length array\n return getOffsetsForProperty(scenegraph, propertyTableProperty.stringOffsets, propertyTableProperty.stringOffsetType || 'UINT32', numberOfElements);\n }\n return null;\n}\n/**\n * Decodes properties of SCALAR, VEC-N, MAT-N types from binary sourse.\n * @param classProperty - class property object.\n * @param numberOfElements - The number of elements in each property array that propertyTableProperty contains. It's a number of rows in the table.\n * @param valuesDataBytes - Data taken from values property of the property table property.\n * @param arrayOffsets - Offsets for variable-length arrays. It's null for fixed-length arrays or scalar types.\n * @returns Property values in a typed array or in an array of typed arrays.\n */\nfunction getPropertyDataNumeric(classProperty, numberOfElements, valuesDataBytes, arrayOffsets) {\n const isArray = classProperty.array;\n const arrayCount = classProperty.count;\n const elementSize = getArrayElementByteSize(classProperty.type, classProperty.componentType);\n const elementCount = valuesDataBytes.byteLength / elementSize;\n let valuesData;\n if (classProperty.componentType) {\n valuesData = convertRawBufferToMetadataArray(valuesDataBytes, classProperty.type, \n // The datatype of the element's components. Only applicable to `SCALAR`, `VECN`, and `MATN` types.\n classProperty.componentType, elementCount);\n }\n else {\n // The spec doesn't provide any info what to do if componentType is not set.\n valuesData = valuesDataBytes;\n }\n if (isArray) {\n if (arrayOffsets) {\n // VARIABLE-length array\n return parseVariableLengthArrayNumeric(valuesData, numberOfElements, arrayOffsets, valuesDataBytes.length, elementSize);\n }\n if (arrayCount) {\n // FIXED-length array\n return parseFixedLengthArrayNumeric(valuesData, numberOfElements, arrayCount);\n }\n return [];\n }\n return valuesData;\n}\n/**\n * Decodes properties of enum type from binary source.\n * @param schema - Schema object.\n * @param classProperty - Class property object.\n * @param numberOfElements - The number of elements in each property array that propertyTableProperty contains. It's a number of rows in the table.\n * @param valuesDataBytes - Data taken from values property of the property table property.\n * @param arrayOffsets - Offsets for variable-length arrays. It's null for fixed-length arrays or scalar types.\n * @returns Strings array of nested strings array.\n */\nfunction getPropertyDataENUM(schema, classProperty, numberOfElements, valuesDataBytes, arrayOffsets) {\n const enumType = classProperty.enumType;\n // Enum ID as declared in the `enums` dictionary. Required when `type` is `ENUM`.\n if (!enumType) {\n throw new Error('Incorrect data in the EXT_structural_metadata extension: classProperty.enumType is not set for type ENUM');\n }\n const enumEntry = schema.enums?.[enumType];\n if (!enumEntry) {\n throw new Error(`Incorrect data in the EXT_structural_metadata extension: schema.enums does't contain ${enumType}`);\n }\n const enumValueType = enumEntry.valueType || 'UINT16';\n const elementSize = getArrayElementByteSize(classProperty.type, enumValueType);\n const elementCount = valuesDataBytes.byteLength / elementSize;\n let valuesData = convertRawBufferToMetadataArray(valuesDataBytes, classProperty.type, enumValueType, elementCount);\n if (!valuesData) {\n valuesData = valuesDataBytes;\n }\n if (classProperty.array) {\n if (arrayOffsets) {\n // VARIABLE-length array\n return parseVariableLengthArrayENUM({\n valuesData,\n numberOfElements,\n arrayOffsets,\n valuesDataBytesLength: valuesDataBytes.length,\n elementSize,\n enumEntry\n });\n }\n const arrayCount = classProperty.count;\n if (arrayCount) {\n // FIXED-length array\n return parseFixedLengthArrayENUM(valuesData, numberOfElements, arrayCount, enumEntry);\n }\n return [];\n }\n // Single value (not an array)\n return getEnumsArray(valuesData, 0, numberOfElements, enumEntry);\n}\n/**\n * Parses variable length nested ENUM arrays.\n * @param params.valuesData - Values in a flat typed array.\n * @param params.numberOfElements - The number of elements in each property array that propertyTableProperty contains. It's a number of rows in the table.\n * @param params.arrayOffsets - Offsets for variable-length arrays. It's null for fixed-length arrays or scalar types.\n * @param params.valuesDataBytesLength - Byte length of values array.\n * @param params.elementSize - Single element byte size.\n * @param params.enumEntry - Enums dictionary.\n * @returns Nested strings array.\n */\nfunction parseVariableLengthArrayENUM(params) {\n const { valuesData, numberOfElements, arrayOffsets, valuesDataBytesLength, elementSize, enumEntry } = params;\n const attributeValueArray = [];\n for (let index = 0; index < numberOfElements; index++) {\n const arrayOffset = arrayOffsets[index];\n const arrayByteSize = arrayOffsets[index + 1] - arrayOffsets[index];\n if (arrayByteSize + arrayOffset > valuesDataBytesLength) {\n break;\n }\n const typedArrayOffset = arrayOffset / elementSize;\n const elementCount = arrayByteSize / elementSize;\n const array = getEnumsArray(valuesData, typedArrayOffset, elementCount, enumEntry);\n attributeValueArray.push(array);\n }\n return attributeValueArray;\n}\n/**\n * Parses fixed length ENUM arrays.\n * @param valuesData - Values in a flat typed array.\n * @param numberOfElements - The number of elements in each property array that propertyTableProperty contains. It's a number of rows in the table.\n * @param arrayCount - Nested arrays length.\n * @param enumEntry - Enums dictionary.\n * @returns Nested strings array.\n */\nfunction parseFixedLengthArrayENUM(valuesData, numberOfElements, arrayCount, enumEntry) {\n const attributeValueArray = [];\n for (let index = 0; index < numberOfElements; index++) {\n const elementOffset = arrayCount * index;\n const array = getEnumsArray(valuesData, elementOffset, arrayCount, enumEntry);\n attributeValueArray.push(array);\n }\n return attributeValueArray;\n}\n/**\n * Parses ENUM values into a string array.\n * @param valuesData - Values in a flat typed array.\n * @param offset - Offset to start parse from.\n * @param count - Values length to parse.\n * @param enumEntry - Enums dictionary.\n * @returns Array of strings with parsed ENUM names.\n */\nfunction getEnumsArray(valuesData, offset, count, enumEntry) {\n const array = [];\n for (let i = 0; i < count; i++) {\n // At the moment we don't support BigInt. It requires additional calculations logic\n // and might be an issue in Safari\n if (valuesData instanceof BigInt64Array || valuesData instanceof BigUint64Array) {\n array.push('');\n }\n else {\n const value = valuesData[offset + i];\n const enumObject = getEnumByValue(enumEntry, value);\n if (enumObject) {\n array.push(enumObject.name);\n }\n else {\n array.push('');\n }\n }\n }\n return array;\n}\n/**\n * Looks up ENUM whose `value` property matches the specified number in the parameter `value`.\n * @param {GLTF_EXT_structural_metadata_Enum} enumEntry - ENUM entry containing the array of possible enums.\n * @param {number} value - The value of the ENUM to locate.\n * @returns {GLTF_EXT_structural_metadata_EnumValue | null} ENUM matcihng the specified value or null of no ENUM object was found.\n */\nfunction getEnumByValue(enumEntry, value) {\n for (const enumValue of enumEntry.values) {\n if (enumValue.value === value) {\n return enumValue;\n }\n }\n return null;\n}\nconst SCHEMA_CLASS_ID_DEFAULT = 'schemaClassId';\nfunction encodeExtStructuralMetadata(scenegraph, options) {\n const extension = scenegraph.getExtension(EXT_STRUCTURAL_METADATA_NAME);\n if (!extension) {\n return;\n }\n if (extension.propertyTables) {\n for (const table of extension.propertyTables) {\n const classId = table.class;\n const schemaClass = extension.schema?.classes?.[classId];\n if (table.properties && schemaClass) {\n encodeProperties(table, schemaClass, scenegraph);\n }\n }\n }\n}\nfunction encodeProperties(table, schemaClass, scenegraph) {\n for (const propertyName in table.properties) {\n const data = table.properties[propertyName].data;\n if (data) {\n const classProperty = schemaClass.properties[propertyName];\n if (classProperty) {\n const tableProperty = createPropertyTableProperty(data, classProperty, scenegraph);\n // Override table property that came with \"data\"\n table.properties[propertyName] = tableProperty;\n }\n }\n }\n}\n/**\n * Creates ExtStructuralMetadata, creates the schema and creates a property table containing feature data provided.\n * @param scenegraph - Instance of the class for structured access to GLTF data.\n * @param propertyAttributes - property attributes\n * @param classId - classId to use for encoding metadata.\n * @returns Index of the table created.\n */\nexport function createExtStructuralMetadata(scenegraph, propertyAttributes, classId = SCHEMA_CLASS_ID_DEFAULT) {\n let extension = scenegraph.getExtension(EXT_STRUCTURAL_METADATA_NAME);\n if (!extension) {\n extension = scenegraph.addExtension(EXT_STRUCTURAL_METADATA_NAME);\n }\n extension.schema = createSchema(propertyAttributes, classId, extension.schema);\n const table = createPropertyTable(propertyAttributes, classId, extension.schema);\n if (!extension.propertyTables) {\n extension.propertyTables = [];\n }\n return extension.propertyTables.push(table) - 1; // index of the table\n}\nfunction createSchema(propertyAttributes, classId, schemaToUpdate) {\n const schema = schemaToUpdate ?? {\n id: 'schema_id'\n };\n const schemaClass = {\n properties: {}\n };\n for (const attribute of propertyAttributes) {\n const classProperty = {\n type: attribute.elementType,\n componentType: attribute.componentType\n };\n schemaClass.properties[attribute.name] = classProperty;\n }\n schema.classes = {};\n schema.classes[classId] = schemaClass;\n return schema;\n}\nfunction createPropertyTable(propertyAttributes, classId, schema) {\n const table = {\n class: classId,\n count: 0\n };\n // count is a number of rows in the table\n let count = 0;\n const schemaClass = schema.classes?.[classId];\n for (const attribute of propertyAttributes) {\n if (count === 0) {\n count = attribute.values.length;\n }\n // The number of elements in all propertyAttributes must be the same\n if (count !== attribute.values.length && attribute.values.length) {\n throw new Error('Illegal values in attributes');\n }\n const classProperty = schemaClass?.properties[attribute.name];\n if (classProperty) {\n // const tableProperty = createPropertyTableProperty(attribute, classProperty, scenegraph);\n if (!table.properties) {\n table.properties = {};\n }\n // values is a required field. Its real value will be set while encoding data\n table.properties[attribute.name] = { values: 0, data: attribute.values };\n }\n }\n table.count = count;\n return table;\n}\nfunction createPropertyTableProperty(\n// attribute: PropertyAttribute,\nvalues, classProperty, scenegraph) {\n const prop = { values: 0 };\n if (classProperty.type === 'STRING') {\n const { stringData, stringOffsets } = createPropertyDataString(values);\n prop.stringOffsets = createBufferView(stringOffsets, scenegraph);\n prop.values = createBufferView(stringData, scenegraph);\n }\n else if (classProperty.type === 'SCALAR' && classProperty.componentType) {\n const data = createPropertyDataScalar(values, classProperty.componentType);\n prop.values = createBufferView(data, scenegraph);\n }\n return prop;\n}\nconst COMPONENT_TYPE_TO_ARRAY_CONSTRUCTOR = {\n INT8: Int8Array,\n UINT8: Uint8Array,\n INT16: Int16Array,\n UINT16: Uint16Array,\n INT32: Int32Array,\n UINT32: Uint32Array,\n INT64: Int32Array,\n UINT64: Uint32Array,\n FLOAT32: Float32Array,\n FLOAT64: Float64Array\n};\nfunction createPropertyDataScalar(array, componentType) {\n const numberArray = [];\n for (const value of array) {\n numberArray.push(Number(value));\n }\n const Construct = COMPONENT_TYPE_TO_ARRAY_CONSTRUCTOR[componentType];\n if (!Construct) {\n throw new Error('Illegal component type');\n }\n return new Construct(numberArray);\n}\nfunction createPropertyDataString(strings) {\n const utf8Encode = new TextEncoder();\n const arr = [];\n let len = 0;\n for (const str of strings) {\n const uint8Array = utf8Encode.encode(str);\n len += uint8Array.length;\n arr.push(uint8Array);\n }\n const strArray = new Uint8Array(len);\n const strOffsets = [];\n let offset = 0;\n for (const str of arr) {\n strArray.set(str, offset);\n strOffsets.push(offset);\n offset += str.length;\n }\n strOffsets.push(offset); // The last offset represents the byte offset after the last string.\n const stringOffsetsTypedArray = new Uint32Array(strOffsets); // Its length = len+1\n return { stringData: strArray, stringOffsets: stringOffsetsTypedArray };\n}\nfunction createBufferView(typedArray, scenegraph) {\n scenegraph.gltf.buffers.push({\n arrayBuffer: typedArray.buffer,\n byteOffset: typedArray.byteOffset,\n byteLength: typedArray.byteLength\n });\n return scenegraph.addBufferView(typedArray);\n}\n","import { GLTFScenegraph } from \"../../api/gltf-scenegraph.js\";\nimport { convertRawBufferToMetadataArray, getPrimitiveTextureData, primitivePropertyDataToAttributes, getArrayElementByteSize, getOffsetsForProperty, parseVariableLengthArrayNumeric, parseFixedLengthArrayNumeric, getPropertyDataString } from \"../utils/3d-tiles-utils.js\";\n/** Extension name */\nconst EXT_FEATURE_METADATA_NAME = 'EXT_feature_metadata';\nexport const name = EXT_FEATURE_METADATA_NAME;\nexport async function decode(gltfData, options) {\n const scenegraph = new GLTFScenegraph(gltfData);\n decodeExtFeatureMetadata(scenegraph, options);\n}\n/**\n * Decodes feature metadata from extension.\n * @param scenegraph - Instance of the class for structured access to GLTF data.\n * @param options - GLTFLoader options.\n */\nfunction decodeExtFeatureMetadata(scenegraph, options) {\n // Decoding metadata involves buffers processing.\n // So, if buffers have not been loaded, there is no reason to process metadata.\n if (!options.gltf?.loadBuffers) {\n return;\n }\n const extension = scenegraph.getExtension(EXT_FEATURE_METADATA_NAME);\n if (!extension) {\n return;\n }\n if (options.gltf?.loadImages) {\n decodePropertyTextures(scenegraph, extension);\n }\n decodePropertyTables(scenegraph, extension);\n}\n/**\n * Processes the data stored in the textures\n * @param scenegraph - Instance of the class for structured access to GLTF data.\n * @param extension - Top-level extension.\n */\nfunction decodePropertyTextures(scenegraph, extension) {\n const schema = extension.schema;\n if (!schema) {\n return;\n }\n const schemaClasses = schema.classes;\n const { featureTextures } = extension;\n if (schemaClasses && featureTextures) {\n for (const schemaName in schemaClasses) {\n const schemaClass = schemaClasses[schemaName];\n const featureTexture = findFeatureTextureByClass(featureTextures, schemaName);\n if (featureTexture) {\n handleFeatureTextureProperties(scenegraph, featureTexture, schemaClass);\n }\n }\n }\n}\n/**\n * Processes the data stored in the property tables.\n * @param scenegraph - Instance of the class for structured access to GLTF data.\n * @param extension - Top-level extension.\n */\nfunction decodePropertyTables(scenegraph, extension) {\n const schema = extension.schema;\n if (!schema) {\n return;\n }\n const schemaClasses = schema.classes;\n const propertyTables = extension.featureTables;\n if (schemaClasses && propertyTables) {\n for (const schemaName in schemaClasses) {\n const propertyTable = findPropertyTableByClass(propertyTables, schemaName);\n if (propertyTable) {\n processPropertyTable(scenegraph, schema, propertyTable);\n }\n }\n }\n}\n/**\n * Finds the property table by class name.\n * @param propertyTables - propertyTable definition taken from the top-level extension.\n * @param schemaClassName - class name in the extension schema.\n */\nfunction findPropertyTableByClass(propertyTables, schemaClassName) {\n for (const propertyTableName in propertyTables) {\n const propertyTable = propertyTables[propertyTableName];\n if (propertyTable.class === schemaClassName) {\n return propertyTable;\n }\n }\n return null;\n}\nfunction findFeatureTextureByClass(featureTextures, schemaClassName) {\n for (const featureTexturesName in featureTextures) {\n const featureTable = featureTextures[featureTexturesName];\n if (featureTable.class === schemaClassName) {\n return featureTable;\n }\n }\n return null;\n}\n/**\n * Navigates through all properies in the property table, gets properties data,\n * and put the data to `propertyTable.data` as an array.\n * @param scenegraph - Instance of the class for structured access to GLTF data.\n * @param schema - schema object.\n * @param propertyTable - propertyTable definition taken from the top-level extension.\n */\nfunction processPropertyTable(scenegraph, schema, propertyTable) {\n // Though 'class' is not required by spec, it doesn't make any scence when it's not provided.\n // So, bale out here.\n if (!propertyTable.class) {\n return;\n }\n const schemaClass = schema.classes?.[propertyTable.class];\n if (!schemaClass) {\n throw new Error(`Incorrect data in the EXT_structural_metadata extension: no schema class with name ${propertyTable.class}`);\n }\n const numberOfElements = propertyTable.count; // `propertyTable.count` is a number of elements in each property array.\n for (const propertyName in schemaClass.properties) {\n const classProperty = schemaClass.properties[propertyName];\n const propertyTableProperty = propertyTable.properties?.[propertyName];\n if (propertyTableProperty) {\n // Getting all elements (`numberOfElements`) of the array in the `propertyTableProperty`\n const data = getPropertyDataFromBinarySource(scenegraph, schema, classProperty, numberOfElements, propertyTableProperty);\n propertyTableProperty.data = data;\n }\n }\n}\n/**\n * Navigates through all properies in feature texture and gets properties data.\n * Data will be stored in featureTexture.properties[propertyName].data.\n * @param scenegraph - Instance of the class for structured access to GLTF data.\n * @param featureTexture\n * @param schemaClass\n */\nfunction handleFeatureTextureProperties(scenegraph, featureTexture, schemaClass) {\n const attributeName = featureTexture.class;\n for (const propertyName in schemaClass.properties) {\n const featureTextureProperty = featureTexture?.properties?.[propertyName];\n if (featureTextureProperty) {\n const data = getPropertyDataFromTexture(scenegraph, featureTextureProperty, attributeName);\n featureTextureProperty.data = data;\n }\n }\n}\n/**\n * Decodes properties from binary sourse based on property type.\n * @param scenegraph - Instance of the class for structured access to GLTF data.\n * @param schemaProperty\n * @param numberOfFeatures\n * @param featureTableProperty\n */\nfunction getPropertyDataFromBinarySource(scenegraph, schema, classProperty, numberOfFeatures, featureTableProperty) {\n let data = [];\n const bufferView = featureTableProperty.bufferView;\n const dataArray = scenegraph.getTypedArrayForBufferView(bufferView);\n const arrayOffsets = getArrayOffsetsForProperty(scenegraph, classProperty, featureTableProperty, numberOfFeatures);\n const stringOffsets = getStringOffsetsForProperty(scenegraph, classProperty, featureTableProperty, numberOfFeatures);\n if (classProperty.type === 'STRING' || classProperty.componentType === 'STRING') {\n data = getPropertyDataString(numberOfFeatures, dataArray, arrayOffsets, stringOffsets);\n }\n else if (isNumericProperty(classProperty)) {\n data = getPropertyDataNumeric(classProperty, numberOfFeatures, dataArray, arrayOffsets);\n }\n return data;\n}\n/**\n * Parses propertyTable.property.arrayOffsets that are offsets of sub-arrays in a flatten array of values.\n * @param scenegraph - Instance of the class for structured access to GLTF data.\n * @param classProperty - class property object.\n * @param propertyTableProperty - propertyTable's property metadata.\n * @param numberOfElements - The number of elements in each property array that propertyTableProperty contains. It's a number of rows in the table.\n * @returns Typed array with offset values.\n * @see https://github.com/CesiumGS/glTF/blob/2976f1183343a47a29e4059a70961371cd2fcee8/extensions/2.0/Vendor/EXT_structural_metadata/schema/propertyTable.property.schema.json#L21\n */\nfunction getArrayOffsetsForProperty(scenegraph, classProperty, propertyTableProperty, numberOfElements) {\n /*\n If ARRAY is used, then componentType must also be specified.\n ARRAY is a fixed-length array when componentCount is defined, and variable-length otherwise.\n */\n if (classProperty.type === 'ARRAY' &&\n // `componentCount` is a number of fixed-length array elements.\n // If `componentCount` is NOT defined, it's a VARIABLE-length array\n typeof classProperty.componentCount === 'undefined' &&\n // `arrayOffsetBufferView` is an index of the buffer view containing offsets for variable-length arrays.\n typeof propertyTableProperty.arrayOffsetBufferView !== 'undefined') {\n // Data are in a VARIABLE-length array\n return getOffsetsForProperty(scenegraph, propertyTableProperty.arrayOffsetBufferView, propertyTableProperty.offsetType || 'UINT32', // offsetType is used both for stringOffsetBufferView and arrayOffsetBufferView\n numberOfElements);\n }\n return null;\n}\n/**\n * Parses featureTable.property.stringOffsetBufferView.\n * String offsets is an array of offsets of strings in the united array of characters.\n * @param scenegraph - Instance of the class for structured access to GLTF data.\n * @param propertyTableProperty - propertyTable's property metadata.\n * @param numberOfElements - The number of elements in each property array that propertyTableProperty contains. It's a number of rows in the table.\n * @returns Typed array of offset values. The number of offsets in the array is equal to `numberOfElements` plus one.\n * @see https://github.com/CesiumGS/glTF/blob/c38f7f37e894004353c15cd0481bc5b7381ce841/extensions/2.0/Vendor/EXT_feature_metadata/schema/featureTable.property.schema.json#L50C10-L50C32\n */\nfunction getStringOffsetsForProperty(scenegraph, classProperty, propertyTableProperty, numberOfElements) {\n if (typeof propertyTableProperty.stringOffsetBufferView !== 'undefined' // `stringOffsetBufferView` is an index of the buffer view containing offsets for strings.\n ) {\n // Data are in a FIXED-length array\n return getOffsetsForProperty(scenegraph, propertyTableProperty.stringOffsetBufferView, propertyTableProperty.offsetType || 'UINT32', // offsetType is used both for stringOffsetBufferView and arrayOffsetBufferView\n numberOfElements);\n }\n return null;\n}\n/**\n * Checks if the feature table property is of numeric type.\n * @param schemaPropertyType - feature table property\n * @returns true if property is numeric, else - false\n */\nfunction isNumericProperty(schemaProperty) {\n const types = [\n 'UINT8',\n 'INT16',\n 'UINT16',\n 'INT32',\n 'UINT32',\n 'INT64',\n 'UINT64',\n 'FLOAT32',\n 'FLOAT64'\n ];\n return (types.includes(schemaProperty.type) ||\n (typeof schemaProperty.componentType !== 'undefined' &&\n types.includes(schemaProperty.componentType)));\n}\n/**\n * Decodes properties of numeric types from binary sourse.\n * @param classProperty - class property object.\n * @param numberOfElements - The number of elements in each property array that propertyTableProperty contains. It's a number of rows in the table.\n * @param valuesDataBytes - Data taken from values property of the property table property.\n * @param arrayOffsets - Offsets for variable-length arrays. It's null for fixed-length arrays or scalar types.\n * @returns Property values in a typed array or in an array of typed arrays.\n */\nfunction getPropertyDataNumeric(classProperty, numberOfElements, valuesDataBytes, arrayOffsets) {\n const isArray = classProperty.type === 'ARRAY';\n const arrayCount = classProperty.componentCount;\n /*\n We are getting Numeric data. So,\n the component type can be one of NumericComponentType,\n the attribute type should be 'SCALAR'\n */\n const attributeType = 'SCALAR';\n const componentType = classProperty.componentType || classProperty.type;\n const elementSize = getArrayElementByteSize(attributeType, componentType);\n const elementCount = valuesDataBytes.byteLength / elementSize;\n const valuesData = convertRawBufferToMetadataArray(valuesDataBytes, attributeType, componentType, elementCount);\n if (isArray) {\n if (arrayOffsets) {\n // VARIABLE-length array\n return parseVariableLengthArrayNumeric(valuesData, numberOfElements, arrayOffsets, valuesDataBytes.length, elementSize);\n }\n if (arrayCount) {\n // FIXED-length array\n return parseFixedLengthArrayNumeric(valuesData, numberOfElements, arrayCount);\n }\n return [];\n }\n return valuesData;\n}\n/**\n * Gets properties from texture associated with all mesh primitives.\n * @param scenegraph - Instance of the class for structured access to GLTF data.\n * @param featureTextureProperty\n * @param attributeName\n * @returns Feature texture data\n */\nfunction getPropertyDataFromTexture(scenegraph, featureTextureProperty, attributeName) {\n const json = scenegraph.gltf.json;\n if (!json.meshes) {\n return [];\n }\n const featureTextureTable = [];\n for (const mesh of json.meshes) {\n for (const primitive of mesh.primitives) {\n processPrimitiveTextures(scenegraph, attributeName, featureTextureProperty, featureTextureTable, primitive);\n }\n }\n return featureTextureTable;\n}\n/**\n * Processes data encoded in the texture associated with the primitive. This data will be accessible through the attributes.\n * @param scenegraph - Instance of the class for structured access to GLTF data.\n * @param attributeName\n * @param featureTextureProperty\n * @param featureTextureTable\n * @param primitive\n */\nfunction processPrimitiveTextures(scenegraph, attributeName, featureTextureProperty, featureTextureTable, primitive) {\n const textureInfoTopLevel = {\n channels: featureTextureProperty.channels,\n ...featureTextureProperty.texture\n };\n const propertyData = getPrimitiveTextureData(scenegraph, textureInfoTopLevel, primitive);\n if (!propertyData) {\n return;\n }\n primitivePropertyDataToAttributes(scenegraph, attributeName, propertyData, featureTextureTable, primitive);\n}\n","// Version constant cannot be imported, it needs to correspond to the build version of **this** module.\n// __VERSION__ is injected by babel-plugin-version-inline\n// @ts-ignore TS2304: Cannot find name '__VERSION__'.\nexport const VERSION = typeof \"4.3.3\" !== 'undefined' ? \"4.3.3\" : 'latest';\n","import { padToNBytes, assert } from '@loaders.gl/loader-utils';\n/** Binary GLTF is little endian. */\nconst LITTLE_ENDIAN = true;\n/** 'glTF' in Big-Endian ASCII */\nconst MAGIC_glTF = 0x676c5446;\nconst GLB_FILE_HEADER_SIZE = 12;\nconst GLB_CHUNK_HEADER_SIZE = 8;\nconst GLB_CHUNK_TYPE_JSON = 0x4e4f534a;\nconst GLB_CHUNK_TYPE_BIN = 0x004e4942;\nconst GLB_V1_CONTENT_FORMAT_JSON = 0x0;\n/** @deprecated - Backward compatibility for old xviz files */\nconst GLB_CHUNK_TYPE_JSON_XVIZ_DEPRECATED = 0;\n/** @deprecated - Backward compatibility for old xviz files */\nconst GLB_CHUNK_TYPE_BIX_XVIZ_DEPRECATED = 1;\nfunction getMagicString(dataView, byteOffset = 0) {\n return `\\\n${String.fromCharCode(dataView.getUint8(byteOffset + 0))}\\\n${String.fromCharCode(dataView.getUint8(byteOffset + 1))}\\\n${String.fromCharCode(dataView.getUint8(byteOffset + 2))}\\\n${String.fromCharCode(dataView.getUint8(byteOffset + 3))}`;\n}\n/** Check if the contents of an array buffer contains GLB byte markers */\nexport function isGLB(arrayBuffer, byteOffset = 0, options = {}) {\n const dataView = new DataView(arrayBuffer);\n // Check that GLB Header starts with the magic number\n const { magic = MAGIC_glTF } = options;\n const magic1 = dataView.getUint32(byteOffset, false);\n return magic1 === magic || magic1 === MAGIC_glTF;\n}\n/**\n * Synchronously parse a GLB\n * @param glb - Target, Output is stored there\n * @param arrayBuffer - Input data\n * @param byteOffset - Offset into arrayBuffer to start parsing from (for \"embedded\" GLBs, e.g. in 3D tiles)\n * @param options\n * @returns\n */\nexport function parseGLBSync(glb, arrayBuffer, byteOffset = 0, options = {}) {\n // Check that GLB Header starts with the magic number\n const dataView = new DataView(arrayBuffer);\n // Compare format with GLBLoader documentation\n const type = getMagicString(dataView, byteOffset + 0);\n const version = dataView.getUint32(byteOffset + 4, LITTLE_ENDIAN); // Version 2 of binary glTF container format\n const byteLength = dataView.getUint32(byteOffset + 8, LITTLE_ENDIAN); // Total byte length of binary file\n Object.assign(glb, {\n // Put less important stuff in a header, to avoid clutter\n header: {\n byteOffset, // Byte offset into the initial arrayBuffer\n byteLength,\n hasBinChunk: false\n },\n type,\n version,\n json: {},\n binChunks: []\n });\n byteOffset += GLB_FILE_HEADER_SIZE;\n switch (glb.version) {\n case 1:\n return parseGLBV1(glb, dataView, byteOffset);\n case 2:\n return parseGLBV2(glb, dataView, byteOffset, (options = {}));\n default:\n throw new Error(`Invalid GLB version ${glb.version}. Only supports version 1 and 2.`);\n }\n}\n/**\n * Parse a V1 GLB\n * @param glb - target, output is stored in this object\n * @param dataView - Input, memory to be parsed\n * @param byteOffset - Offset of first byte of GLB data in the data view\n * @returns Number of bytes parsed (there could be additional non-GLB data after the GLB)\n */\nfunction parseGLBV1(glb, dataView, byteOffset) {\n // Sanity: ensure file is big enough to hold at least the headers\n assert(glb.header.byteLength > GLB_FILE_HEADER_SIZE + GLB_CHUNK_HEADER_SIZE);\n // Explanation of GLB structure:\n // https://cloud.githubusercontent.com/assets/3479527/22600725/36b87122-ea55-11e6-9d40-6fd42819fcab.png\n const contentLength = dataView.getUint32(byteOffset + 0, LITTLE_ENDIAN); // Byte length of chunk\n const contentFormat = dataView.getUint32(byteOffset + 4, LITTLE_ENDIAN); // Chunk format as uint32\n byteOffset += GLB_CHUNK_HEADER_SIZE;\n // GLB v1 only supports a single chunk type\n assert(contentFormat === GLB_V1_CONTENT_FORMAT_JSON);\n parseJSONChunk(glb, dataView, byteOffset, contentLength);\n // No need to call the function padToBytes() from parseJSONChunk()\n byteOffset += contentLength;\n byteOffset += parseBINChunk(glb, dataView, byteOffset, glb.header.byteLength);\n return byteOffset;\n}\n/**\n * Parse a V2 GLB\n * @param glb - target, output is stored in this object\n * @param dataView - Input, memory to be parsed\n * @param byteOffset - Offset of first byte of GLB data in the data view\n * @returns Number of bytes parsed (there could be additional non-GLB data after the GLB)\n */\nfunction parseGLBV2(glb, dataView, byteOffset, options) {\n // Sanity: ensure file is big enough to hold at least the first chunk header\n assert(glb.header.byteLength > GLB_FILE_HEADER_SIZE + GLB_CHUNK_HEADER_SIZE);\n parseGLBChunksSync(glb, dataView, byteOffset, options);\n return byteOffset + glb.header.byteLength;\n}\n/** Iterate over GLB chunks and parse them */\nfunction parseGLBChunksSync(glb, dataView, byteOffset, options) {\n // Per spec we must iterate over chunks, ignoring all except JSON and BIN\n // Iterate as long as there is space left for another chunk header\n while (byteOffset + 8 <= glb.header.byteLength) {\n const chunkLength = dataView.getUint32(byteOffset + 0, LITTLE_ENDIAN); // Byte length of chunk\n const chunkFormat = dataView.getUint32(byteOffset + 4, LITTLE_ENDIAN); // Chunk format as uint32\n byteOffset += GLB_CHUNK_HEADER_SIZE;\n // Per spec we must iterate over chunks, ignoring all except JSON and BIN\n switch (chunkFormat) {\n case GLB_CHUNK_TYPE_JSON:\n parseJSONChunk(glb, dataView, byteOffset, chunkLength);\n break;\n case GLB_CHUNK_TYPE_BIN:\n parseBINChunk(glb, dataView, byteOffset, chunkLength);\n break;\n // Backward compatibility for very old xviz files\n case GLB_CHUNK_TYPE_JSON_XVIZ_DEPRECATED:\n if (!options.strict) {\n parseJSONChunk(glb, dataView, byteOffset, chunkLength);\n }\n break;\n case GLB_CHUNK_TYPE_BIX_XVIZ_DEPRECATED:\n if (!options.strict) {\n parseBINChunk(glb, dataView, byteOffset, chunkLength);\n }\n break;\n default:\n // Ignore, per spec\n // console.warn(`Unknown GLB chunk type`); // eslint-disable-line\n break;\n }\n byteOffset += padToNBytes(chunkLength, 4);\n }\n return byteOffset;\n}\n/* Parse a GLB JSON chunk */\nfunction parseJSONChunk(glb, dataView, byteOffset, chunkLength) {\n // 1. Create a \"view\" of the binary encoded JSON data inside the GLB\n const jsonChunk = new Uint8Array(dataView.buffer, byteOffset, chunkLength);\n // 2. Decode the JSON binary array into clear text\n const textDecoder = new TextDecoder('utf8');\n const jsonText = textDecoder.decode(jsonChunk);\n // 3. Parse the JSON text into a JavaScript data structure\n glb.json = JSON.parse(jsonText);\n return padToNBytes(chunkLength, 4);\n}\n/** Parse a GLB BIN chunk */\nfunction parseBINChunk(glb, dataView, byteOffset, chunkLength) {\n // Note: BIN chunk can be optional\n glb.header.hasBinChunk = true;\n glb.binChunks.push({\n byteOffset,\n byteLength: chunkLength,\n arrayBuffer: dataView.buffer\n // TODO - copy, or create typed array view?\n });\n return padToNBytes(chunkLength, 4);\n}\n","// Resolves a relative url against a baseUrl\n// If url is absolute, return it unchanged\nexport function resolveUrl(url, options) {\n // TODO: Use better logic to handle all protocols plus not delay on data\n const absolute = url.startsWith('data:') || url.startsWith('http:') || url.startsWith('https:');\n if (absolute) {\n return url;\n }\n const baseUrl = options.baseUri || options.uri;\n if (!baseUrl) {\n throw new Error(`'baseUri' must be provided to resolve relative url ${url}`);\n }\n return baseUrl.substr(0, baseUrl.lastIndexOf('/') + 1) + url;\n}\n","// This file is part of meshoptimizer library and is distributed under the terms of MIT License.\n// Copyright (C) 2016-2021, by Arseny Kapoulkine (arseny.kapoulkine@gmail.com)\n/* eslint-disable camelcase */\nconst isWebAssemblySupported = typeof WebAssembly !== 'object';\n// Built with clang version 11.0.0 (https://github.com/llvm/llvm-project.git 0160ad802e899c2922bc9b29564080c22eb0908c)\n// Built from meshoptimizer 0.16\nconst wasm_base = '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';\nconst wasm_simd = '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';\n// Uses bulk-memory and simd extensions\nconst detector = new Uint8Array([\n 0, 97, 115, 109, 1, 0, 0, 0, 1, 4, 1, 96, 0, 0, 3, 3, 2, 0, 0, 5, 3, 1, 0, 1, 12, 1, 0, 10, 22, 2,\n 12, 0, 65, 0, 65, 0, 65, 0, 252, 10, 0, 0, 11, 7, 0, 65, 0, 253, 15, 26, 11\n]);\n// Used to unpack wasm\nconst wasmpack = new Uint8Array([\n 32, 0, 65, 253, 3, 1, 2, 34, 4, 106, 6, 5, 11, 8, 7, 20, 13, 33, 12, 16, 128, 9, 116, 64, 19, 113,\n 127, 15, 10, 21, 22, 14, 255, 66, 24, 54, 136, 107, 18, 23, 192, 26, 114, 118, 132, 17, 77, 101,\n 130, 144, 27, 87, 131, 44, 45, 74, 156, 154, 70, 167\n]);\nconst FILTERS = {\n // legacy index-based enums for glTF\n 0: '',\n 1: 'meshopt_decodeFilterOct',\n 2: 'meshopt_decodeFilterQuat',\n 3: 'meshopt_decodeFilterExp',\n // string-based enums for glTF\n NONE: '',\n OCTAHEDRAL: 'meshopt_decodeFilterOct',\n QUATERNION: 'meshopt_decodeFilterQuat',\n EXPONENTIAL: 'meshopt_decodeFilterExp'\n};\nconst DECODERS = {\n // legacy index-based enums for glTF\n 0: 'meshopt_decodeVertexBuffer',\n 1: 'meshopt_decodeIndexBuffer',\n 2: 'meshopt_decodeIndexSequence',\n // string-based enums for glTF\n ATTRIBUTES: 'meshopt_decodeVertexBuffer',\n TRIANGLES: 'meshopt_decodeIndexBuffer',\n INDICES: 'meshopt_decodeIndexSequence'\n};\nexport function isMeshoptSupported() {\n return isWebAssemblySupported;\n}\nexport async function meshoptDecodeVertexBuffer(target, count, size, source, filter = 'NONE') {\n const instance = await loadWasmInstance();\n decode(instance, instance.exports.meshopt_decodeVertexBuffer, target, count, size, source, instance.exports[FILTERS[filter]]);\n}\nexport async function meshoptDecodeIndexBuffer(target, count, size, source) {\n const instance = await loadWasmInstance();\n decode(instance, instance.exports.meshopt_decodeIndexBuffer, target, count, size, source);\n}\nexport async function meshoptDecodeIndexSequence(target, count, size, source) {\n const instance = await loadWasmInstance();\n decode(instance, instance.exports.meshopt_decodeIndexSequence, target, count, size, source);\n}\n// eslint-disable-next-line max-params\nexport async function meshoptDecodeGltfBuffer(target, count, size, source, mode, filter = 'NONE') {\n const instance = await loadWasmInstance();\n decode(instance, instance.exports[DECODERS[mode]], target, count, size, source, instance.exports[FILTERS[filter || 'NONE']]);\n}\nlet wasmPromise;\nasync function loadWasmInstance() {\n // eslint-disable-next-line\n if (!wasmPromise) {\n wasmPromise = loadWasmModule();\n }\n return wasmPromise;\n}\nasync function loadWasmModule() {\n let wasm = wasm_base;\n if (WebAssembly.validate(detector)) {\n wasm = wasm_simd;\n // eslint-disable-next-line no-console\n console.log('Warning: meshopt_decoder is using experimental SIMD support');\n }\n const result = await WebAssembly.instantiate(unpack(wasm), {});\n await result.instance.exports.__wasm_call_ctors();\n return result.instance;\n}\nfunction unpack(data) {\n const result = new Uint8Array(data.length);\n for (let i = 0; i < data.length; ++i) {\n const ch = data.charCodeAt(i);\n result[i] = ch > 96 ? ch - 71 : ch > 64 ? ch - 65 : ch > 47 ? ch + 4 : ch > 46 ? 63 : 62;\n }\n let write = 0;\n for (let i = 0; i < data.length; ++i) {\n result[write++] = result[i] < 60 ? wasmpack[result[i]] : (result[i] - 60) * 64 + result[++i];\n }\n return result.buffer.slice(0, write);\n}\n// eslint-disable-next-line max-params\nfunction decode(instance, fun, target, count, size, source, filter) {\n const sbrk = instance.exports.sbrk;\n const count4 = (count + 3) & ~3; // pad for SIMD filter\n const tp = sbrk(count4 * size);\n const sp = sbrk(source.length);\n const heap = new Uint8Array(instance.exports.memory.buffer);\n heap.set(source, sp);\n const res = fun(tp, count, size, sp, source.length);\n if (res === 0 && filter) {\n filter(tp, count4, size);\n }\n target.set(heap.subarray(tp, tp + count * size));\n sbrk(tp - sbrk(0));\n if (res !== 0) {\n throw new Error(`Malformed buffer data: ${res}`);\n }\n}\n","import { GLTFScenegraph } from \"../api/gltf-scenegraph.js\";\nimport { meshoptDecodeGltfBuffer } from \"../../meshopt/meshopt-decoder.js\";\n// @ts-ignore\n// eslint-disable-next-line\nconst DEFAULT_MESHOPT_OPTIONS = {\n byteOffset: 0,\n filter: 'NONE'\n};\n/** Extension name */\nconst EXT_MESHOPT_COMPRESSION = 'EXT_meshopt_compression';\nexport const name = EXT_MESHOPT_COMPRESSION;\nexport async function decode(gltfData, options) {\n const scenegraph = new GLTFScenegraph(gltfData);\n if (!options?.gltf?.decompressMeshes || !options.gltf?.loadBuffers) {\n return;\n }\n const promises = [];\n for (const bufferViewIndex of gltfData.json.bufferViews || []) {\n promises.push(decodeMeshoptBufferView(scenegraph, bufferViewIndex));\n }\n // Decompress meshes in parallel\n await Promise.all(promises);\n // We have now decompressed all primitives, so remove the top-level extension\n scenegraph.removeExtension(EXT_MESHOPT_COMPRESSION);\n}\n/** Decode one meshopt buffer view */\nasync function decodeMeshoptBufferView(scenegraph, bufferView) {\n const meshoptExtension = scenegraph.getObjectExtension(bufferView, EXT_MESHOPT_COMPRESSION);\n if (meshoptExtension) {\n const { byteOffset = 0, byteLength = 0, byteStride, count, mode, filter = 'NONE', buffer: bufferIndex } = meshoptExtension;\n const buffer = scenegraph.gltf.buffers[bufferIndex];\n const source = new Uint8Array(buffer.arrayBuffer, buffer.byteOffset + byteOffset, byteLength);\n const result = new Uint8Array(scenegraph.gltf.buffers[bufferView.buffer].arrayBuffer, bufferView.byteOffset, bufferView.byteLength);\n await meshoptDecodeGltfBuffer(result, count, byteStride, source, mode, filter);\n scenegraph.removeObjectExtension(bufferView, EXT_MESHOPT_COMPRESSION);\n }\n}\n","// GLTF EXTENSION: EXT_TEXTURE_WEBP\n// https://github.com/KhronosGroup/glTF/tree/master/extensions/2.0/Khronos/EXT_TEXTURE_WEBP\n/* eslint-disable camelcase */\nimport { isImageFormatSupported } from '@loaders.gl/images';\nimport { GLTFScenegraph } from \"../api/gltf-scenegraph.js\";\nconst EXT_TEXTURE_WEBP = 'EXT_texture_webp';\n/** Extension name */\nexport const name = EXT_TEXTURE_WEBP;\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, options) {\n const scenegraph = new GLTFScenegraph(gltfData);\n if (!isImageFormatSupported('image/webp')) {\n if (scenegraph.getRequiredExtensions().includes(EXT_TEXTURE_WEBP)) {\n throw new Error(`gltf: Required extension ${EXT_TEXTURE_WEBP} not supported by browser`);\n }\n return;\n }\n const { json } = scenegraph;\n for (const texture of json.textures || []) {\n const extension = scenegraph.getObjectExtension(texture, EXT_TEXTURE_WEBP);\n if (extension) {\n // TODO - if multiple texture extensions are present which one wins?\n texture.source = extension.source;\n }\n scenegraph.removeObjectExtension(texture, EXT_TEXTURE_WEBP);\n }\n // Remove the top-level extension\n scenegraph.removeExtension(EXT_TEXTURE_WEBP);\n}\n","// GLTF EXTENSION: KHR_texture_basisu\n// https://github.com/KhronosGroup/glTF/tree/main/extensions/2.0/Khronos/KHR_texture_basisu\n/* eslint-disable camelcase */\nimport { GLTFScenegraph } from \"../api/gltf-scenegraph.js\";\nconst KHR_TEXTURE_BASISU = 'KHR_texture_basisu';\n/** Extension name */\nexport const name = KHR_TEXTURE_BASISU;\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, options) {\n const scene = new GLTFScenegraph(gltfData);\n const { json } = scene;\n for (const texture of json.textures || []) {\n const extension = scene.getObjectExtension(texture, KHR_TEXTURE_BASISU);\n if (extension) {\n // TODO - if multiple texture extensions are present which one wins?\n texture.source = extension.source;\n scene.removeObjectExtension(texture, KHR_TEXTURE_BASISU);\n }\n }\n // Remove the top-level extension\n scene.removeExtension(KHR_TEXTURE_BASISU);\n}\n","// Version constant cannot be imported, it needs to correspond to the build version of **this** module.\n// __VERSION__ is injected by babel-plugin-version-inline\n// @ts-ignore TS2304: Cannot find name '__VERSION__'.\nexport const VERSION = typeof \"4.3.3\" !== 'undefined' ? \"4.3.3\" : 'latest';\n","// loaders.gl\n// SPDX-License-Identifier: MIT\n// Copyright (c) vis.gl contributors\nimport { VERSION } from \"./lib/utils/version.js\";\n/**\n * Worker loader for Draco3D compressed geometries\n */\nexport const DracoLoader = {\n dataType: null,\n batchType: null,\n name: 'Draco',\n id: 'draco',\n module: 'draco',\n // shapes: ['mesh'],\n version: VERSION,\n worker: true,\n extensions: ['drc'],\n mimeTypes: ['application/octet-stream'],\n binary: true,\n tests: ['DRACO'],\n options: {\n draco: {\n decoderType: typeof WebAssembly === 'object' ? 'wasm' : 'js', // 'js' for IE11\n libraryPath: 'libs/',\n extraAttributes: {},\n attributeNameEntry: undefined\n }\n }\n};\n","import { deduceMeshField } from '@loaders.gl/schema';\n/** Extract an arrow-like schema from a Draco mesh */\nexport function getDracoSchema(attributes, loaderData, indices) {\n const metadata = makeMetadata(loaderData.metadata);\n const fields = [];\n const namedLoaderDataAttributes = transformAttributesLoaderData(loaderData.attributes);\n for (const attributeName in attributes) {\n const attribute = attributes[attributeName];\n const field = getArrowFieldFromAttribute(attributeName, attribute, namedLoaderDataAttributes[attributeName]);\n fields.push(field);\n }\n if (indices) {\n const indicesField = getArrowFieldFromAttribute('indices', indices);\n fields.push(indicesField);\n }\n return { fields, metadata };\n}\nfunction transformAttributesLoaderData(loaderData) {\n const result = {};\n for (const key in loaderData) {\n const dracoAttribute = loaderData[key];\n result[dracoAttribute.name || 'undefined'] = dracoAttribute;\n }\n return result;\n}\nfunction getArrowFieldFromAttribute(attributeName, attribute, loaderData) {\n const metadataMap = loaderData ? makeMetadata(loaderData.metadata) : undefined;\n const field = deduceMeshField(attributeName, attribute, metadataMap);\n return field;\n}\nfunction makeMetadata(metadata) {\n Object.entries(metadata);\n const serializedMetadata = {};\n for (const key in metadata) {\n serializedMetadata[`${key}.string`] = JSON.stringify(metadata[key]);\n }\n return serializedMetadata;\n}\n","/* eslint-disable camelcase */\nimport { getMeshBoundingBox } from '@loaders.gl/schema';\nimport { getDracoSchema } from \"./utils/get-draco-schema.js\";\n// @ts-ignore\n// eslint-disable-next-line @typescript-eslint/no-unused-vars\nconst GEOMETRY_TYPE = {\n TRIANGULAR_MESH: 0,\n POINT_CLOUD: 1\n};\n// Native Draco attribute names to GLTF attribute names.\nconst DRACO_TO_GLTF_ATTRIBUTE_NAME_MAP = {\n POSITION: 'POSITION',\n NORMAL: 'NORMAL',\n COLOR: 'COLOR_0',\n TEX_COORD: 'TEXCOORD_0'\n};\nconst DRACO_DATA_TYPE_TO_TYPED_ARRAY_MAP = {\n 1: Int8Array,\n 2: Uint8Array,\n 3: Int16Array,\n 4: Uint16Array,\n 5: Int32Array,\n 6: Uint32Array,\n // 7: BigInt64Array,\n // 8: BigUint64Array,\n 9: Float32Array\n // 10: Float64Array\n // 11: BOOL - What array type do we use for this?\n};\nconst INDEX_ITEM_SIZE = 4;\nexport default class DracoParser {\n draco;\n decoder;\n metadataQuerier;\n // draco - the draco decoder, either import `draco3d` or load dynamically\n constructor(draco) {\n this.draco = draco;\n this.decoder = new this.draco.Decoder();\n this.metadataQuerier = new this.draco.MetadataQuerier();\n }\n /**\n * Destroy draco resources\n */\n destroy() {\n this.draco.destroy(this.decoder);\n this.draco.destroy(this.metadataQuerier);\n }\n /**\n * NOTE: caller must call `destroyGeometry` on the return value after using it\n * @param arrayBuffer\n * @param options\n */\n parseSync(arrayBuffer, options = {}) {\n const buffer = new this.draco.DecoderBuffer();\n buffer.Init(new Int8Array(arrayBuffer), arrayBuffer.byteLength);\n this._disableAttributeTransforms(options);\n const geometry_type = this.decoder.GetEncodedGeometryType(buffer);\n const dracoGeometry = geometry_type === this.draco.TRIANGULAR_MESH\n ? new this.draco.Mesh()\n : new this.draco.PointCloud();\n try {\n let dracoStatus;\n switch (geometry_type) {\n case this.draco.TRIANGULAR_MESH:\n dracoStatus = this.decoder.DecodeBufferToMesh(buffer, dracoGeometry);\n break;\n case this.draco.POINT_CLOUD:\n dracoStatus = this.decoder.DecodeBufferToPointCloud(buffer, dracoGeometry);\n break;\n default:\n throw new Error('DRACO: Unknown geometry type.');\n }\n if (!dracoStatus.ok() || !dracoGeometry.ptr) {\n const message = `DRACO decompression failed: ${dracoStatus.error_msg()}`;\n // console.error(message);\n throw new Error(message);\n }\n const loaderData = this._getDracoLoaderData(dracoGeometry, geometry_type, options);\n const geometry = this._getMeshData(dracoGeometry, loaderData, options);\n const boundingBox = getMeshBoundingBox(geometry.attributes);\n const schema = getDracoSchema(geometry.attributes, loaderData, geometry.indices);\n const data = {\n loader: 'draco',\n loaderData,\n header: {\n vertexCount: dracoGeometry.num_points(),\n boundingBox\n },\n ...geometry,\n schema\n };\n return data;\n }\n finally {\n this.draco.destroy(buffer);\n if (dracoGeometry) {\n this.draco.destroy(dracoGeometry);\n }\n }\n }\n // Draco specific \"loader data\"\n /**\n * Extract\n * @param dracoGeometry\n * @param geometry_type\n * @param options\n * @returns\n */\n _getDracoLoaderData(dracoGeometry, geometry_type, options) {\n const metadata = this._getTopLevelMetadata(dracoGeometry);\n const attributes = this._getDracoAttributes(dracoGeometry, options);\n return {\n geometry_type,\n num_attributes: dracoGeometry.num_attributes(),\n num_points: dracoGeometry.num_points(),\n num_faces: dracoGeometry instanceof this.draco.Mesh ? dracoGeometry.num_faces() : 0,\n metadata,\n attributes\n };\n }\n /**\n * Extract all draco provided information and metadata for each attribute\n * @param dracoGeometry\n * @param options\n * @returns\n */\n _getDracoAttributes(dracoGeometry, options) {\n const dracoAttributes = {};\n for (let attributeId = 0; attributeId < dracoGeometry.num_attributes(); attributeId++) {\n // Note: Draco docs do not seem clear on `GetAttribute` ids just being a zero-based index,\n // but it does seems to work this way\n const dracoAttribute = this.decoder.GetAttribute(dracoGeometry, attributeId);\n const metadata = this._getAttributeMetadata(dracoGeometry, attributeId);\n dracoAttributes[dracoAttribute.unique_id()] = {\n unique_id: dracoAttribute.unique_id(),\n attribute_type: dracoAttribute.attribute_type(),\n data_type: dracoAttribute.data_type(),\n num_components: dracoAttribute.num_components(),\n byte_offset: dracoAttribute.byte_offset(),\n byte_stride: dracoAttribute.byte_stride(),\n normalized: dracoAttribute.normalized(),\n attribute_index: attributeId,\n metadata\n };\n // Add transformation parameters for any attributes app wants untransformed\n const quantization = this._getQuantizationTransform(dracoAttribute, options);\n if (quantization) {\n dracoAttributes[dracoAttribute.unique_id()].quantization_transform = quantization;\n }\n const octahedron = this._getOctahedronTransform(dracoAttribute, options);\n if (octahedron) {\n dracoAttributes[dracoAttribute.unique_id()].octahedron_transform = octahedron;\n }\n }\n return dracoAttributes;\n }\n /**\n * Get standard loaders.gl mesh category data\n * Extracts the geometry from draco\n * @param dracoGeometry\n * @param options\n */\n _getMeshData(dracoGeometry, loaderData, options) {\n const attributes = this._getMeshAttributes(loaderData, dracoGeometry, options);\n const positionAttribute = attributes.POSITION;\n if (!positionAttribute) {\n throw new Error('DRACO: No position attribute found.');\n }\n // For meshes, we need indices to define the faces.\n if (dracoGeometry instanceof this.draco.Mesh) {\n switch (options.topology) {\n case 'triangle-strip':\n return {\n topology: 'triangle-strip',\n mode: 4, // GL.TRIANGLES\n attributes,\n indices: {\n value: this._getTriangleStripIndices(dracoGeometry),\n size: 1\n }\n };\n case 'triangle-list':\n default:\n return {\n topology: 'triangle-list',\n mode: 5, // GL.TRIANGLE_STRIP\n attributes,\n indices: {\n value: this._getTriangleListIndices(dracoGeometry),\n size: 1\n }\n };\n }\n }\n // PointCloud - must come last as Mesh inherits from PointCloud\n return {\n topology: 'point-list',\n mode: 0, // GL.POINTS\n attributes\n };\n }\n _getMeshAttributes(loaderData, dracoGeometry, options) {\n const attributes = {};\n for (const loaderAttribute of Object.values(loaderData.attributes)) {\n const attributeName = this._deduceAttributeName(loaderAttribute, options);\n loaderAttribute.name = attributeName;\n const values = this._getAttributeValues(dracoGeometry, loaderAttribute);\n if (values) {\n const { value, size } = values;\n attributes[attributeName] = {\n value,\n size,\n byteOffset: loaderAttribute.byte_offset,\n byteStride: loaderAttribute.byte_stride,\n normalized: loaderAttribute.normalized\n };\n }\n }\n return attributes;\n }\n // MESH INDICES EXTRACTION\n /**\n * For meshes, we need indices to define the faces.\n * @param dracoGeometry\n */\n _getTriangleListIndices(dracoGeometry) {\n // Example on how to retrieve mesh and attributes.\n const numFaces = dracoGeometry.num_faces();\n const numIndices = numFaces * 3;\n const byteLength = numIndices * INDEX_ITEM_SIZE;\n const ptr = this.draco._malloc(byteLength);\n try {\n this.decoder.GetTrianglesUInt32Array(dracoGeometry, byteLength, ptr);\n return new Uint32Array(this.draco.HEAPF32.buffer, ptr, numIndices).slice();\n }\n finally {\n this.draco._free(ptr);\n }\n }\n /**\n * For meshes, we need indices to define the faces.\n * @param dracoGeometry\n */\n _getTriangleStripIndices(dracoGeometry) {\n const dracoArray = new this.draco.DracoInt32Array();\n try {\n /* const numStrips = */ this.decoder.GetTriangleStripsFromMesh(dracoGeometry, dracoArray);\n return getUint32Array(dracoArray);\n }\n finally {\n this.draco.destroy(dracoArray);\n }\n }\n /**\n *\n * @param dracoGeometry\n * @param dracoAttribute\n * @param attributeName\n */\n _getAttributeValues(dracoGeometry, attribute) {\n const TypedArrayCtor = DRACO_DATA_TYPE_TO_TYPED_ARRAY_MAP[attribute.data_type];\n if (!TypedArrayCtor) {\n // eslint-disable-next-line no-console\n console.warn(`DRACO: Unsupported attribute type ${attribute.data_type}`);\n return null;\n }\n const numComponents = attribute.num_components;\n const numPoints = dracoGeometry.num_points();\n const numValues = numPoints * numComponents;\n const byteLength = numValues * TypedArrayCtor.BYTES_PER_ELEMENT;\n const dataType = getDracoDataType(this.draco, TypedArrayCtor);\n let value;\n const ptr = this.draco._malloc(byteLength);\n try {\n const dracoAttribute = this.decoder.GetAttribute(dracoGeometry, attribute.attribute_index);\n this.decoder.GetAttributeDataArrayForAllPoints(dracoGeometry, dracoAttribute, dataType, byteLength, ptr);\n value = new TypedArrayCtor(this.draco.HEAPF32.buffer, ptr, numValues).slice();\n }\n finally {\n this.draco._free(ptr);\n }\n return { value, size: numComponents };\n }\n // Attribute names\n /**\n * DRACO does not store attribute names - We need to deduce an attribute name\n * for each attribute\n _getAttributeNames(\n dracoGeometry: Mesh | PointCloud,\n options: DracoParseOptions\n ): {[unique_id: number]: string} {\n const attributeNames: {[unique_id: number]: string} = {};\n for (let attributeId = 0; attributeId < dracoGeometry.num_attributes(); attributeId++) {\n const dracoAttribute = this.decoder.GetAttribute(dracoGeometry, attributeId);\n const attributeName = this._deduceAttributeName(dracoAttribute, options);\n attributeNames[attributeName] = attributeName;\n }\n return attributeNames;\n }\n */\n /**\n * Deduce an attribute name.\n * @note DRACO does not save attribute names, just general type (POSITION, COLOR)\n * to help optimize compression. We generate GLTF compatible names for the Draco-recognized\n * types\n * @param attributeData\n */\n _deduceAttributeName(attribute, options) {\n // Deduce name based on application provided map\n const uniqueId = attribute.unique_id;\n for (const [attributeName, attributeUniqueId] of Object.entries(options.extraAttributes || {})) {\n if (attributeUniqueId === uniqueId) {\n return attributeName;\n }\n }\n // Deduce name based on attribute type\n const thisAttributeType = attribute.attribute_type;\n for (const dracoAttributeConstant in DRACO_TO_GLTF_ATTRIBUTE_NAME_MAP) {\n const attributeType = this.draco[dracoAttributeConstant];\n if (attributeType === thisAttributeType) {\n // TODO - Return unique names if there multiple attributes per type\n // (e.g. multiple TEX_COORDS or COLORS)\n return DRACO_TO_GLTF_ATTRIBUTE_NAME_MAP[dracoAttributeConstant];\n }\n }\n // Look up in metadata\n // TODO - shouldn't this have priority?\n const entryName = options.attributeNameEntry || 'name';\n if (attribute.metadata[entryName]) {\n return attribute.metadata[entryName].string;\n }\n // Attribute of \"GENERIC\" type, we need to assign some name\n return `CUSTOM_ATTRIBUTE_${uniqueId}`;\n }\n // METADATA EXTRACTION\n /** Get top level metadata */\n _getTopLevelMetadata(dracoGeometry) {\n const dracoMetadata = this.decoder.GetMetadata(dracoGeometry);\n return this._getDracoMetadata(dracoMetadata);\n }\n /** Get per attribute metadata */\n _getAttributeMetadata(dracoGeometry, attributeId) {\n const dracoMetadata = this.decoder.GetAttributeMetadata(dracoGeometry, attributeId);\n return this._getDracoMetadata(dracoMetadata);\n }\n /**\n * Extract metadata field values\n * @param dracoMetadata\n * @returns\n */\n _getDracoMetadata(dracoMetadata) {\n // The not so wonderful world of undocumented Draco APIs :(\n if (!dracoMetadata || !dracoMetadata.ptr) {\n return {};\n }\n const result = {};\n const numEntries = this.metadataQuerier.NumEntries(dracoMetadata);\n for (let entryIndex = 0; entryIndex < numEntries; entryIndex++) {\n const entryName = this.metadataQuerier.GetEntryName(dracoMetadata, entryIndex);\n result[entryName] = this._getDracoMetadataField(dracoMetadata, entryName);\n }\n return result;\n }\n /**\n * Extracts possible values for one metadata entry by name\n * @param dracoMetadata\n * @param entryName\n */\n _getDracoMetadataField(dracoMetadata, entryName) {\n const dracoArray = new this.draco.DracoInt32Array();\n try {\n // Draco metadata fields can hold int32 arrays\n this.metadataQuerier.GetIntEntryArray(dracoMetadata, entryName, dracoArray);\n const intArray = getInt32Array(dracoArray);\n return {\n int: this.metadataQuerier.GetIntEntry(dracoMetadata, entryName),\n string: this.metadataQuerier.GetStringEntry(dracoMetadata, entryName),\n double: this.metadataQuerier.GetDoubleEntry(dracoMetadata, entryName),\n intArray\n };\n }\n finally {\n this.draco.destroy(dracoArray);\n }\n }\n // QUANTIZED ATTRIBUTE SUPPORT (NO DECOMPRESSION)\n /** Skip transforms for specific attribute types */\n _disableAttributeTransforms(options) {\n const { quantizedAttributes = [], octahedronAttributes = [] } = options;\n const skipAttributes = [...quantizedAttributes, ...octahedronAttributes];\n for (const dracoAttributeName of skipAttributes) {\n this.decoder.SkipAttributeTransform(this.draco[dracoAttributeName]);\n }\n }\n /**\n * Extract (and apply?) Position Transform\n * @todo not used\n */\n _getQuantizationTransform(dracoAttribute, options) {\n const { quantizedAttributes = [] } = options;\n const attribute_type = dracoAttribute.attribute_type();\n const skip = quantizedAttributes.map((type) => this.decoder[type]).includes(attribute_type);\n if (skip) {\n const transform = new this.draco.AttributeQuantizationTransform();\n try {\n if (transform.InitFromAttribute(dracoAttribute)) {\n return {\n quantization_bits: transform.quantization_bits(),\n range: transform.range(),\n min_values: new Float32Array([1, 2, 3]).map((i) => transform.min_value(i))\n };\n }\n }\n finally {\n this.draco.destroy(transform);\n }\n }\n return null;\n }\n _getOctahedronTransform(dracoAttribute, options) {\n const { octahedronAttributes = [] } = options;\n const attribute_type = dracoAttribute.attribute_type();\n const octahedron = octahedronAttributes\n .map((type) => this.decoder[type])\n .includes(attribute_type);\n if (octahedron) {\n const transform = new this.draco.AttributeQuantizationTransform();\n try {\n if (transform.InitFromAttribute(dracoAttribute)) {\n return {\n quantization_bits: transform.quantization_bits()\n };\n }\n }\n finally {\n this.draco.destroy(transform);\n }\n }\n return null;\n }\n}\n/**\n * Get draco specific data type by TypedArray constructor type\n * @param attributeType\n * @returns draco specific data type\n */\nfunction getDracoDataType(draco, attributeType) {\n switch (attributeType) {\n case Float32Array:\n return draco.DT_FLOAT32;\n case Int8Array:\n return draco.DT_INT8;\n case Int16Array:\n return draco.DT_INT16;\n case Int32Array:\n return draco.DT_INT32;\n case Uint8Array:\n return draco.DT_UINT8;\n case Uint16Array:\n return draco.DT_UINT16;\n case Uint32Array:\n return draco.DT_UINT32;\n default:\n return draco.DT_INVALID;\n }\n}\n/**\n * Copy a Draco int32 array into a JS typed array\n */\nfunction getInt32Array(dracoArray) {\n const numValues = dracoArray.size();\n const intArray = new Int32Array(numValues);\n for (let i = 0; i < numValues; i++) {\n intArray[i] = dracoArray.GetValue(i);\n }\n return intArray;\n}\n/**\n * Copy a Draco int32 array into a JS typed array\n */\nfunction getUint32Array(dracoArray) {\n const numValues = dracoArray.size();\n const intArray = new Int32Array(numValues);\n for (let i = 0; i < numValues; i++) {\n intArray[i] = dracoArray.GetValue(i);\n }\n return intArray;\n}\n","// Dynamic DRACO module loading inspired by THREE.DRACOLoader\n// https://github.com/mrdoob/three.js/blob/398c4f39ebdb8b23eefd4a7a5ec49ec0c96c7462/examples/jsm/loaders/DRACOLoader.js\n// by Don McCurdy / https://www.donmccurdy.com / MIT license\nimport { loadLibrary } from '@loaders.gl/worker-utils';\nconst DRACO_DECODER_VERSION = '1.5.6';\nconst DRACO_ENCODER_VERSION = '1.4.1';\nconst STATIC_DECODER_URL = `https://www.gstatic.com/draco/versioned/decoders/${DRACO_DECODER_VERSION}`;\nexport const DRACO_EXTERNAL_LIBRARIES = {\n /** The primary Draco3D encoder, javascript wrapper part */\n DECODER: 'draco_wasm_wrapper.js',\n /** The primary draco decoder, compiled web assembly part */\n DECODER_WASM: 'draco_decoder.wasm',\n /** Fallback decoder for non-webassebly environments. Very big bundle, lower performance */\n FALLBACK_DECODER: 'draco_decoder.js',\n /** Draco encoder */\n ENCODER: 'draco_encoder.js'\n};\nexport const DRACO_EXTERNAL_LIBRARY_URLS = {\n [DRACO_EXTERNAL_LIBRARIES.DECODER]: `${STATIC_DECODER_URL}/${DRACO_EXTERNAL_LIBRARIES.DECODER}`,\n [DRACO_EXTERNAL_LIBRARIES.DECODER_WASM]: `${STATIC_DECODER_URL}/${DRACO_EXTERNAL_LIBRARIES.DECODER_WASM}`,\n [DRACO_EXTERNAL_LIBRARIES.FALLBACK_DECODER]: `${STATIC_DECODER_URL}/${DRACO_EXTERNAL_LIBRARIES.FALLBACK_DECODER}`,\n [DRACO_EXTERNAL_LIBRARIES.ENCODER]: `https://raw.githubusercontent.com/google/draco/${DRACO_ENCODER_VERSION}/javascript/${DRACO_EXTERNAL_LIBRARIES.ENCODER}`\n};\nlet loadDecoderPromise;\nlet loadEncoderPromise;\nexport async function loadDracoDecoderModule(options) {\n const modules = options.modules || {};\n // Check if a bundled draco3d library has been supplied by application\n if (modules.draco3d) {\n loadDecoderPromise ||= modules.draco3d.createDecoderModule({}).then((draco) => {\n return { draco };\n });\n }\n else {\n // If not, dynamically load the WASM script from our CDN\n loadDecoderPromise ||= loadDracoDecoder(options);\n }\n return await loadDecoderPromise;\n}\nexport async function loadDracoEncoderModule(options) {\n const modules = options.modules || {};\n // Check if a bundled draco3d library has been supplied by application\n if (modules.draco3d) {\n loadEncoderPromise ||= modules.draco3d.createEncoderModule({}).then((draco) => {\n return { draco };\n });\n }\n else {\n // If not, dynamically load the WASM script from our CDN\n loadEncoderPromise ||= loadDracoEncoder(options);\n }\n return await loadEncoderPromise;\n}\n// DRACO DECODER LOADING\nasync function loadDracoDecoder(options) {\n let DracoDecoderModule;\n let wasmBinary;\n switch (options.draco && options.draco.decoderType) {\n case 'js':\n DracoDecoderModule = await loadLibrary(DRACO_EXTERNAL_LIBRARY_URLS[DRACO_EXTERNAL_LIBRARIES.FALLBACK_DECODER], 'draco', options, DRACO_EXTERNAL_LIBRARIES.FALLBACK_DECODER);\n break;\n case 'wasm':\n default:\n [DracoDecoderModule, wasmBinary] = await Promise.all([\n await loadLibrary(DRACO_EXTERNAL_LIBRARY_URLS[DRACO_EXTERNAL_LIBRARIES.DECODER], 'draco', options, DRACO_EXTERNAL_LIBRARIES.DECODER),\n await loadLibrary(DRACO_EXTERNAL_LIBRARY_URLS[DRACO_EXTERNAL_LIBRARIES.DECODER_WASM], 'draco', options, DRACO_EXTERNAL_LIBRARIES.DECODER_WASM)\n ]);\n }\n // Depends on how import happened...\n // @ts-ignore\n DracoDecoderModule = DracoDecoderModule || globalThis.DracoDecoderModule;\n return await initializeDracoDecoder(DracoDecoderModule, wasmBinary);\n}\nfunction initializeDracoDecoder(DracoDecoderModule, wasmBinary) {\n const options = {};\n if (wasmBinary) {\n options.wasmBinary = wasmBinary;\n }\n return new Promise((resolve) => {\n DracoDecoderModule({\n ...options,\n onModuleLoaded: (draco) => resolve({ draco }) // Module is Promise-like. Wrap in object to avoid loop.\n });\n });\n}\n// ENCODER\nasync function loadDracoEncoder(options) {\n let DracoEncoderModule = await loadLibrary(DRACO_EXTERNAL_LIBRARY_URLS[DRACO_EXTERNAL_LIBRARIES.ENCODER], 'draco', options, DRACO_EXTERNAL_LIBRARIES.ENCODER);\n // @ts-ignore\n DracoEncoderModule = DracoEncoderModule || globalThis.DracoEncoderModule;\n return new Promise((resolve) => {\n DracoEncoderModule({\n onModuleLoaded: (draco) => resolve({ draco }) // Module is Promise-like. Wrap in object to avoid loop.\n });\n });\n}\n","import { DracoLoader as DracoWorkerLoader } from \"./draco-loader.js\";\nimport DracoParser from \"./lib/draco-parser.js\";\nimport { loadDracoDecoderModule } from \"./lib/draco-module-loader.js\";\nimport { VERSION } from \"./lib/utils/version.js\";\n// Module constants\nexport { DRACO_EXTERNAL_LIBRARIES, DRACO_EXTERNAL_LIBRARY_URLS } from \"./lib/draco-module-loader.js\";\nexport { DracoWriter } from \"./draco-writer.js\";\n/**\n * Browser worker doesn't work because of issue during \"draco_encoder.js\" loading.\n * Refused to execute script from 'https://raw.githubusercontent.com/google/draco/1.4.1/javascript/draco_encoder.js' because its MIME type ('') is not executable.\n */\nexport const DracoWriterWorker = {\n id: 'draco-writer',\n name: 'Draco compressed geometry writer',\n module: 'draco',\n version: VERSION,\n worker: true,\n options: {\n draco: {},\n source: null\n }\n};\nexport { DracoWorkerLoader };\n/**\n * Loader for Draco3D compressed geometries\n */\nexport const DracoLoader = {\n ...DracoWorkerLoader,\n parse\n};\nasync function parse(arrayBuffer, options) {\n const { draco } = await loadDracoDecoderModule(options);\n const dracoParser = new DracoParser(draco);\n try {\n return dracoParser.parseSync(arrayBuffer, options?.draco);\n }\n finally {\n dracoParser.destroy();\n }\n}\n","// TODO - remove\nimport { getAccessorTypeFromSize, getComponentTypeFromArray } from \"./gltf-utils.js\";\n// Returns a fresh attributes object with glTF-standardized attributes names\n// Attributes that cannot be identified will not be included\n// Removes `indices` if present, as it should be stored separately from the attributes\nexport function getGLTFAccessors(attributes) {\n const accessors = {};\n for (const name in attributes) {\n const attribute = attributes[name];\n if (name !== 'indices') {\n const glTFAccessor = getGLTFAccessor(attribute);\n accessors[name] = glTFAccessor;\n }\n }\n return accessors;\n}\n// Fix up a single accessor.\n// Input: typed array or a partial accessor object\n// Return: accessor object\nexport function getGLTFAccessor(attribute) {\n const { buffer, size, count } = getAccessorData(attribute);\n const glTFAccessor = {\n // glTF Accessor values\n // TODO: Instead of a bufferView index we could have an actual buffer (typed array)\n // bufferView: null,\n // TODO: Deprecate `value` in favor of bufferView?\n // @ts-ignore\n value: buffer,\n size, // Decoded `type` (e.g. SCALAR)\n byteOffset: 0,\n count,\n type: getAccessorTypeFromSize(size),\n componentType: getComponentTypeFromArray(buffer)\n };\n return glTFAccessor;\n}\n// export function getGLTFAttribute(data, gltfAttributeName): GLTFAccessor {\n// return data.attributes[data.glTFAttributeMap[gltfAttributeName]];\n// }\nfunction getAccessorData(attribute) {\n let buffer = attribute;\n let size = 1;\n let count = 0;\n if (attribute && attribute.value) {\n buffer = attribute.value;\n size = attribute.size || 1;\n }\n if (buffer) {\n if (!ArrayBuffer.isView(buffer)) {\n buffer = toTypedArray(buffer, Float32Array);\n }\n count = buffer.length / size;\n }\n return { buffer, size, count };\n}\n// Convert non-typed arrays to arrays of specified format\nfunction toTypedArray(array, ArrayType, convertTypedArrays = false) {\n if (!array) {\n return null;\n }\n if (Array.isArray(array)) {\n return new ArrayType(array);\n }\n if (convertTypedArrays && !(array instanceof ArrayType)) {\n return new ArrayType(array);\n }\n return array;\n}\n","// 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 */\nimport { sliceArrayBuffer, parseFromContext } from '@loaders.gl/loader-utils';\nimport { DracoLoader } from '@loaders.gl/draco';\nimport { GLTFScenegraph } from \"../api/gltf-scenegraph.js\";\nimport { getGLTFAccessors, getGLTFAccessor } from \"../gltf-utils/gltf-attribute-utils.js\";\nconst KHR_DRACO_MESH_COMPRESSION = 'KHR_draco_mesh_compression';\n/** Extension name */\nexport const name = KHR_DRACO_MESH_COMPRESSION;\nexport function preprocess(gltfData, options, context) {\n const scenegraph = new GLTFScenegraph(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}\nexport async function decode(gltfData, options, context) {\n if (!options?.gltf?.decompressMeshes) {\n return;\n }\n const scenegraph = new GLTFScenegraph(gltfData);\n const promises = [];\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 // Decompress meshes in parallel\n await Promise.all(promises);\n // We have now decompressed all primitives, so remove the top-level extension\n scenegraph.removeExtension(KHR_DRACO_MESH_COMPRESSION);\n}\nexport function encode(gltfData, options = {}) {\n const scenegraph = new GLTFScenegraph(gltfData);\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// DECODE\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// TODO - Implement fallback behavior per KHR_DRACO_MESH_COMPRESSION spec\nasync function decompressPrimitive(scenegraph, primitive, options, context) {\n const dracoExtension = scenegraph.getObjectExtension(primitive, KHR_DRACO_MESH_COMPRESSION);\n if (!dracoExtension) {\n return;\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 const dracoOptions = { ...options };\n // TODO - remove hack: The entire tileset might be included, too expensive to serialize\n delete dracoOptions['3d-tiles'];\n const decodedData = await parseFromContext(bufferCopy, DracoLoader, dracoOptions, context);\n const decodedAttributes = getGLTFAccessors(decodedData.attributes);\n // Restore min/max values\n for (const [attributeName, decodedAttribute] of Object.entries(decodedAttributes)) {\n if (attributeName in primitive.attributes) {\n const accessorIndex = 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 // @ts-ignore\n primitive.attributes = decodedAttributes;\n if (decodedData.indices) {\n // @ts-ignore\n primitive.indices = getGLTFAccessor(decodedData.indices);\n }\n // Extension has been processed, delete it\n scenegraph.removeObjectExtension(primitive, KHR_DRACO_MESH_COMPRESSION);\n checkPrimitive(primitive);\n}\n// ENCODE\n// eslint-disable-next-line max-len\n// Only TRIANGLES: 0x0004 and TRIANGLE_STRIP: 0x0005 are supported\nfunction compressMesh(attributes, indices, mode = 4, options, context) {\n if (!options.DracoWriter) {\n throw new Error('options.gltf.DracoWriter not provided');\n }\n // TODO - use DracoWriter using encode w/ registered DracoWriter...\n const compressedData = options.DracoWriter.encodeSync({ attributes });\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 const bufferViewIndex = options.addBufferView(compressedData);\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 return glTFMesh;\n}\n// UTILS\nfunction checkPrimitive(primitive) {\n if (!primitive.attributes && Object.keys(primitive.attributes).length > 0) {\n throw new Error('glTF: Empty primitive detected: Draco decompression failure?');\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","/**\n * https://github.com/KhronosGroup/glTF/blob/main/extensions/2.0/Khronos/KHR_texture_transform/README.md\n */\nimport { Vector3, Matrix3 } from '@math.gl/core';\nimport { getAccessorArrayTypeAndLength } from \"../gltf-utils/gltf-utils.js\";\nimport { BYTES, COMPONENTS } from \"../gltf-utils/gltf-constants.js\";\nimport { GLTFScenegraph } from \"../api/gltf-scenegraph.js\";\n/** Extension name */\nconst KHR_TEXTURE_TRANSFORM = 'KHR_texture_transform';\nexport const name = KHR_TEXTURE_TRANSFORM;\nconst scratchVector = new Vector3();\nconst scratchRotationMatrix = new Matrix3();\nconst scratchScaleMatrix = new Matrix3();\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, options) {\n const gltfScenegraph = new GLTFScenegraph(gltfData);\n const hasExtension = gltfScenegraph.hasExtension(KHR_TEXTURE_TRANSFORM);\n if (!hasExtension || !options.gltf?.loadBuffers) {\n return;\n }\n const materials = gltfData.json.materials || [];\n for (let i = 0; i < materials.length; i++) {\n transformTexCoords(i, gltfData);\n }\n}\n/**\n * Transform TEXCOORD by material\n * @param materialIndex processing material index\n * @param gltfData gltf buffers and json\n */\nfunction transformTexCoords(materialIndex, gltfData) {\n const material = gltfData.json.materials?.[materialIndex];\n const materialTextures = [\n material?.pbrMetallicRoughness?.baseColorTexture,\n material?.emissiveTexture,\n material?.normalTexture,\n material?.occlusionTexture,\n material?.pbrMetallicRoughness?.metallicRoughnessTexture\n ];\n // Save processed texCoords in order no to process the same twice\n const processedTexCoords = [];\n for (const textureInfo of materialTextures) {\n if (textureInfo && textureInfo?.extensions?.[KHR_TEXTURE_TRANSFORM]) {\n transformPrimitives(gltfData, materialIndex, textureInfo, 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(gltfData, materialIndex, texture, processedTexCoords) {\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 * 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(texture, processedTexCoords) {\n const textureInfo = texture.extensions?.[KHR_TEXTURE_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 = processedTexCoords.findIndex(([original, newTexCoord]) => original === originalTexCoord && newTexCoord === texCoord) !== -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 * 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(gltfData, primitive, transformParameters) {\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 = (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 }\n else {\n // If texCoord change, create new attribute\n createAttribute(texCoord, accessor, primitive, gltfData, result);\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(accessor, bufferView, buffers, newTexCoordArray) {\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 * @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(newTexCoord, originalAccessor, primitive, gltfData, newTexCoordArray) {\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 * Construct transformation matrix from the extension data (transition, rotation, scale)\n * @param extensionData extension data\n * @returns transformation matrix\n */\nfunction makeTransformationMatrix(extensionData) {\n const { offset = [0, 0], rotation = 0, scale = [1, 1] } = extensionData;\n const translationMatrix = new Matrix3().set(1, 0, 0, 0, 1, 0, offset[0], offset[1], 1);\n const rotationMatrix = scratchRotationMatrix.set(Math.cos(rotation), Math.sin(rotation), 0, -Math.sin(rotation), Math.cos(rotation), 0, 0, 0, 1);\n const scaleMatrix = scratchScaleMatrix.set(scale[0], 0, 0, 0, scale[1], 0, 0, 0, 1);\n return translationMatrix.multiplyRight(rotationMatrix).multiplyRight(scaleMatrix);\n}\n","// GLTF EXTENSION: KHR_lights_punctual\n// https://github.com/KhronosGroup/glTF/tree/master/extensions/2.0/Khronos/KHR_lights_punctual\nimport { assert } from \"../../utils/assert.js\";\nimport { GLTFScenegraph } from \"../../api/gltf-scenegraph.js\";\nconst KHR_LIGHTS_PUNCTUAL = 'KHR_lights_punctual';\nexport const name = KHR_LIGHTS_PUNCTUAL;\nexport async function decode(gltfData) {\n const gltfScenegraph = new GLTFScenegraph(gltfData);\n const { json } = gltfScenegraph;\n // Move the light array out of the extension and remove the extension\n const extension = gltfScenegraph.getExtension(KHR_LIGHTS_PUNCTUAL);\n if (extension) {\n // @ts-ignore\n gltfScenegraph.json.lights = extension.lights;\n gltfScenegraph.removeExtension(KHR_LIGHTS_PUNCTUAL);\n }\n // Any nodes that have the extension, add lights field pointing to light object\n // and remove the extension\n for (const node of json.nodes || []) {\n const nodeExtension = gltfScenegraph.getObjectExtension(node, KHR_LIGHTS_PUNCTUAL);\n if (nodeExtension) {\n // @ts-ignore\n node.light = nodeExtension.light;\n }\n gltfScenegraph.removeObjectExtension(node, KHR_LIGHTS_PUNCTUAL);\n }\n}\n// Move the light ar ray out of the extension and remove the extension\nexport async function encode(gltfData) {\n const gltfScenegraph = new GLTFScenegraph(gltfData);\n const { json } = gltfScenegraph;\n // @ts-ignore\n if (json.lights) {\n const extension = gltfScenegraph.addExtension(KHR_LIGHTS_PUNCTUAL);\n // @ts-ignore\n assert(!extension.lights);\n // @ts-ignore\n extension.lights = json.lights;\n // @ts-ignore\n delete json.lights;\n }\n // Any nodes that have lights field pointing to light object\n // add the extension\n // @ts-ignore\n if (gltfScenegraph.json.lights) {\n // @ts-ignore\n for (const light of gltfScenegraph.json.lights) {\n const node = light.node;\n gltfScenegraph.addObjectExtension(node, KHR_LIGHTS_PUNCTUAL, light);\n }\n // @ts-ignore\n delete gltfScenegraph.json.lights;\n }\n}\n","// GLTF EXTENSION: KHR_materials_unlit\n// https://github.com/KhronosGroup/glTF/tree/master/extensions/2.0/Khronos/KHR_materials_unlit\nimport { GLTFScenegraph } from \"../../api/gltf-scenegraph.js\";\nconst KHR_MATERIALS_UNLIT = 'KHR_materials_unlit';\nexport const name = KHR_MATERIALS_UNLIT;\nexport async function decode(gltfData) {\n const gltfScenegraph = new GLTFScenegraph(gltfData);\n const { json } = gltfScenegraph;\n // Any nodes that have the extension, add lights field pointing to light object\n // and remove the extension\n for (const material of json.materials || []) {\n const extension = material.extensions && material.extensions.KHR_materials_unlit;\n if (extension) {\n // @ts-ignore TODO\n material.unlit = true;\n }\n gltfScenegraph.removeObjectExtension(material, KHR_MATERIALS_UNLIT);\n }\n // Remove the top-level extension\n gltfScenegraph.removeExtension(KHR_MATERIALS_UNLIT);\n}\nexport function encode(gltfData) {\n const gltfScenegraph = new GLTFScenegraph(gltfData);\n const { json } = gltfScenegraph;\n // Any nodes that have lights field pointing to light object\n // add the extension\n // @ts-ignore\n if (gltfScenegraph.materials) {\n for (const material of json.materials || []) {\n // @ts-ignore\n if (material.unlit) {\n // @ts-ignore\n delete material.unlit;\n gltfScenegraph.addObjectExtension(material, KHR_MATERIALS_UNLIT, {});\n gltfScenegraph.addExtension(KHR_MATERIALS_UNLIT);\n }\n }\n }\n}\n","// GLTF EXTENSION: KHR_techniques_webgl\n// https://github.com/KhronosGroup/glTF/tree/master/extensions/2.0/Khronos/KHR_techniques_webgl\nimport { GLTFScenegraph } from \"../../api/gltf-scenegraph.js\";\nconst KHR_TECHNIQUES_WEBGL = 'KHR_techniques_webgl';\nexport const name = KHR_TECHNIQUES_WEBGL;\nexport async function decode(gltfData) {\n const gltfScenegraph = new GLTFScenegraph(gltfData);\n const { json } = gltfScenegraph;\n const extension = gltfScenegraph.getExtension(KHR_TECHNIQUES_WEBGL);\n if (extension) {\n const techniques = resolveTechniques(extension, gltfScenegraph);\n for (const material of json.materials || []) {\n const materialExtension = gltfScenegraph.getObjectExtension(material, KHR_TECHNIQUES_WEBGL);\n if (materialExtension) {\n // @ts-ignore TODO\n material.technique = Object.assign({}, materialExtension, \n // @ts-ignore\n techniques[materialExtension.technique]);\n // @ts-ignore TODO\n material.technique.values = resolveValues(material.technique, gltfScenegraph);\n }\n gltfScenegraph.removeObjectExtension(material, KHR_TECHNIQUES_WEBGL);\n }\n // Remove the top-level extension\n gltfScenegraph.removeExtension(KHR_TECHNIQUES_WEBGL);\n }\n}\n// eslint-disable-next-line\nexport async function encode(gltfData, options) {\n // TODO\n}\nfunction resolveTechniques(techniquesExtension, \n// programs: {[key: string]: any}[],\n// shaders: {[key: string]: any}[],\n// techniques: {[key: string]: any}[]\ngltfScenegraph) {\n const { programs = [], shaders = [], techniques = [] } = techniquesExtension;\n const textDecoder = new TextDecoder();\n shaders.forEach((shader) => {\n if (Number.isFinite(shader.bufferView)) {\n shader.code = textDecoder.decode(gltfScenegraph.getTypedArrayForBufferView(shader.bufferView));\n }\n else {\n // TODO: handle URI shader\n throw new Error('KHR_techniques_webgl: no shader code');\n }\n });\n programs.forEach((program) => {\n program.fragmentShader = shaders[program.fragmentShader];\n program.vertexShader = shaders[program.vertexShader];\n });\n techniques.forEach((technique) => {\n technique.program = programs[technique.program];\n });\n return techniques;\n}\nfunction resolveValues(technique, gltfScenegraph) {\n const values = Object.assign({}, technique.values);\n // merge values from uniforms\n Object.keys(technique.uniforms || {}).forEach((uniform) => {\n if (technique.uniforms[uniform].value && !(uniform in values)) {\n values[uniform] = technique.uniforms[uniform].value;\n }\n });\n // resolve textures\n Object.keys(values).forEach((uniform) => {\n if (typeof values[uniform] === 'object' && values[uniform].index !== undefined) {\n // Assume this is a texture\n // TODO: find if there are any other types that can be referenced\n values[uniform].texture = gltfScenegraph.getTexture(values[uniform].index);\n }\n });\n return values;\n}\n","// GLTF 1.0 extensions (decode only)\n// import * as KHR_binary_gltf from './KHR_draco_mesh_compression';\n// GLTF 2.0 Vendor extensions\nimport * as EXT_mesh_features from \"../extensions/EXT_mesh_features.js\";\nimport * as EXT_structural_metadata from \"../extensions/EXT_structural_metadata.js\";\n// GLTF 2.0 Khronos extensions (decode/encode)\nimport * as EXT_meshopt_compression from \"../extensions/EXT_meshopt_compression.js\";\nimport * as EXT_texture_webp from \"../extensions/EXT_texture_webp.js\";\nimport * as KHR_texture_basisu from \"../extensions/KHR_texture_basisu.js\";\nimport * as KHR_draco_mesh_compression from \"../extensions/KHR_draco_mesh_compression.js\";\nimport * as KHR_texture_transform from \"../extensions/KHR_texture_transform.js\";\n// Deprecated. These should be handled by rendering library (e.g. luma.gl), not the loader.\nimport * as KHR_lights_punctual from \"../extensions/deprecated/KHR_lights_punctual.js\";\nimport * as KHR_materials_unlit from \"../extensions/deprecated/KHR_materials_unlit.js\";\nimport * as KHR_techniques_webgl from \"../extensions/deprecated/KHR_techniques_webgl.js\";\nimport * as EXT_feature_metadata from \"../extensions/deprecated/EXT_feature_metadata.js\";\n/**\n * List of extensions processed by the GLTFLoader\n * Note that may extensions can only be handled on the rendering stage and are left out here\n * These are just extensions that can be handled fully or partially during loading.\n */\nexport const EXTENSIONS = [\n // 1.0\n // KHR_binary_gltf is handled separately - must be processed before other parsing starts\n // KHR_binary_gltf,\n // 2.0\n EXT_structural_metadata,\n EXT_mesh_features,\n EXT_meshopt_compression,\n EXT_texture_webp,\n // Basisu should come after webp, we want basisu to be preferred if both are provided\n KHR_texture_basisu,\n KHR_draco_mesh_compression,\n KHR_lights_punctual,\n KHR_materials_unlit,\n KHR_techniques_webgl,\n KHR_texture_transform,\n EXT_feature_metadata\n];\n/**\n * List of extensions processed by the GLTFWriter\n */\nconst EXTENSIONS_ENCODING = [EXT_structural_metadata, EXT_mesh_features];\n/** Call before any resource loading starts */\nexport function preprocessExtensions(gltf, options = {}, context) {\n const extensions = EXTENSIONS.filter((extension) => useExtension(extension.name, options));\n for (const extension of extensions) {\n extension.preprocess?.(gltf, options, context);\n }\n}\n/** Call after resource loading */\nexport async function decodeExtensions(gltf, options = {}, context) {\n const extensions = EXTENSIONS.filter((extension) => useExtension(extension.name, options));\n for (const extension of extensions) {\n // Note: We decode async extensions sequentially, this might not be necessary\n // Currently we only have Draco, but when we add Basis we may revisit\n await extension.decode?.(gltf, options, context);\n }\n}\n/** Call before resource writing */\nexport function encodeExtensions(gltf, options = {}) {\n for (const extension of EXTENSIONS_ENCODING) {\n gltf = extension.encode?.(gltf, options) ?? gltf;\n }\n return gltf;\n}\nfunction useExtension(extensionName, options) {\n const excludes = options?.gltf?.excludeExtensions || {};\n const exclude = extensionName in excludes && !excludes[extensionName];\n return !exclude;\n}\n","// GLTF 1.0 EXTENSION: KHR_binary_glTF\n// https://github.com/KhronosGroup/glTF/tree/master/extensions/1.0/Khronos/KHR_binary_glTF\n/* eslint-disable camelcase */\nimport { GLTFScenegraph } from \"../api/gltf-scenegraph.js\";\nconst KHR_BINARY_GLTF = 'KHR_binary_glTF';\n/** Extension name */\nexport const name = KHR_BINARY_GLTF;\nexport function preprocess(gltfData) {\n const gltfScenegraph = new GLTFScenegraph(gltfData);\n const { json } = gltfScenegraph;\n // Note: json.buffers.binary_glTF also needs to be replaced\n // This is currently done during gltf normalization\n // Image and shader nodes can have the extension\n // https://github.com/KhronosGroup/glTF/blob/master/extensions/1.0/Khronos/KHR_binary_glTF/schema/image.KHR_binary_glTF.schema.json\n for (const image of json.images || []) {\n const extension = gltfScenegraph.getObjectExtension(image, KHR_BINARY_GLTF);\n // The data in the extension is valid as glTF 2.0 data inside the object, so just copy it in\n if (extension) {\n Object.assign(image, extension);\n }\n gltfScenegraph.removeObjectExtension(image, KHR_BINARY_GLTF);\n }\n // TODO shaders - At least traverse and throw error if used?\n // https://github.com/KhronosGroup/glTF/blob/master/extensions/1.0/Khronos/KHR_binary_glTF/schema/shader.KHR_binary_glTF.schema.json\n // glTF v1 one files have a partially formed URI field that is not expected in (and causes problems in) 2.0\n if (json.buffers && json.buffers[0]) {\n delete json.buffers[0].uri;\n }\n // Remove the top-level extension as it has now been processed\n gltfScenegraph.removeExtension(KHR_BINARY_GLTF);\n}\n// KHR_binary_gltf is a 1.0 extension that is supported natively by 2.0\n// export function encode() {\n// throw new Error(KHR_BINARY_GLTF);\n// }\n","/* eslint-disable camelcase */\nimport * as KHR_binary_glTF from \"../extensions/KHR_binary_gltf.js\";\n// Binary format changes (mainly implemented by GLBLoader)\n// https://github.com/KhronosGroup/glTF/tree/master/extensions/1.0/Khronos/KHR_binary_glTF\n// JSON format changes:\n// https://github.com/khronosgroup/gltf/issues/605\n// - [x] Top-level JSON objects are arrays now\n// - [ ] Removed indirection from animation: sampler now refers directly to accessors, #712\n// - [ ] material.parameter.value and technique.parameter.value must be an array, #690\n// - [ ] Node can have only one mesh #821\n// - [ ] Added reqs on JSON encoding\n// - [ ] Added reqs on binary data alignment #802 (comment)\n// Additions:\n// - [ ] Added accessor.normalized, #691, #706\n// - [ ] Added glExtensionsUsed property and 5125 (UNSIGNED_INT) accessor.componentType value, #619\n// - [ ] Added extensionsRequired property, #720, #721\n// - [ ] Added \"STEP\" as valid animation.sampler.interpolation value, #712\n// Removals:\n// - [x] Removed buffer.type, #786, #629\n// - [ ] Removed revision number from profile.version, #709\n// - [ ] Removed technique.functions.scissor and removed 3089 (SCISSOR_TEST) as a valid value for technique.states.enable, #681\n// - [ ] Techniques, programs, and shaders were moved out to KHR_technique_webgl extension.\n// Other edits:\n// - [x] asset is now required, #642\n// - [ ] buffer.byteLength and bufferView.byteLength are now required, #560.\n// - [ ] accessor.min and accessor.max are now required, #593, and clarified that the JSON value and binary data must be the same, #628.\n// - [ ] Clarified animation.sampler and animation.channel restrictions, #712\n// - [ ] skin.inverseBindMatrices is now optional, #461.\n// - [ ] Attribute parameters can't have a value defined in the technique or parameter, #563 (comment).\n// - [ ] Only TEXCOORD and COLOR attribute semantics can be written in the form [semantic]_[set_index], #563 (comment).\n// - [ ] TEXCOORD and COLOR attribute semantics must be written in the form [semantic]_[set_index], e.g., just TEXCOORD should be TEXCOORD_0, and just COLOR should be COLOR_0, #649\n// - [ ] camera.perspective.aspectRatio and camera.perspective.yfov must now be > 0, not >= 0, #563 (comment).\n// - [ ] Application-specific parameter semantics must start with an underscore, e.g., _TEMPERATURE and _SIMULATION_TIME, #563 (comment).\n// - [ ] Properties in technique.parameters must be defined in technique.uniforms or technique.attributes,\n// #563 (comment).\n// - [ ] technique.parameter.count can only be defined when the semantic is JOINTMATRIX or an application-specific semantic is used. It can never be defined for attribute parameters; only uniforms, d2f6945\n// - [ ] technique.parameter.semantic is required when the parameter is an attribute, 28e113d\n// - [ ] Mesh-only models are allowed, e.g., without materials, #642\n// - [ ] Skeleton hierarchies (nodes containing jointName) must be separated from non-skeleton hierarchies., #647\n// - [ ] technique.states.functions.blendColor and technique.states.functions.depthRange parameters now must match WebGL function min/max, #707\nconst GLTF_ARRAYS = {\n accessors: 'accessor',\n animations: 'animation',\n buffers: 'buffer',\n bufferViews: 'bufferView',\n images: 'image',\n materials: 'material',\n meshes: 'mesh',\n nodes: 'node',\n samplers: 'sampler',\n scenes: 'scene',\n skins: 'skin',\n textures: 'texture'\n};\nconst GLTF_KEYS = {\n accessor: 'accessors',\n animations: 'animation',\n buffer: 'buffers',\n bufferView: 'bufferViews',\n image: 'images',\n material: 'materials',\n mesh: 'meshes',\n node: 'nodes',\n sampler: 'samplers',\n scene: 'scenes',\n skin: 'skins',\n texture: 'textures'\n};\n/**\n * Converts (normalizes) glTF v1 to v2\n */\nclass GLTFV1Normalizer {\n idToIndexMap = {\n animations: {},\n accessors: {},\n buffers: {},\n bufferViews: {},\n images: {},\n materials: {},\n meshes: {},\n nodes: {},\n samplers: {},\n scenes: {},\n skins: {},\n textures: {}\n };\n json;\n // constructor() {}\n /**\n * Convert (normalize) glTF < 2.0 to glTF 2.0\n * @param gltf - object with json and binChunks\n * @param options\n * @param options normalize Whether to actually normalize\n */\n normalize(gltf, options) {\n this.json = gltf.json;\n const json = gltf.json;\n // Check version\n switch (json.asset && json.asset.version) {\n // We are converting to v2 format. Return if there is nothing to do\n case '2.0':\n return;\n // This class is written to convert 1.0\n case undefined:\n case '1.0':\n break;\n default:\n // eslint-disable-next-line no-undef, no-console\n console.warn(`glTF: Unknown version ${json.asset.version}`);\n return;\n }\n if (!options.normalize) {\n // We are still missing a few conversion tricks, remove once addressed\n throw new Error('glTF v1 is not supported.');\n }\n // eslint-disable-next-line no-undef, no-console\n console.warn('Converting glTF v1 to glTF v2 format. This is experimental and may fail.');\n this._addAsset(json);\n // In glTF2 top-level fields are Arrays not Object maps\n this._convertTopLevelObjectsToArrays(json);\n // Extract bufferView indices for images\n // (this extension needs to be invoked early in the normalization process)\n // TODO can this be handled by standard extension processing instead of called explicitly?\n KHR_binary_glTF.preprocess(gltf);\n // Convert object references from ids to indices\n this._convertObjectIdsToArrayIndices(json);\n this._updateObjects(json);\n this._updateMaterial(json);\n }\n // asset is now required, #642 https://github.com/KhronosGroup/glTF/issues/639\n _addAsset(json) {\n json.asset = json.asset || {};\n // We are normalizing to glTF v2, so change version to \"2.0\"\n json.asset.version = '2.0';\n json.asset.generator = json.asset.generator || 'Normalized to glTF 2.0 by loaders.gl';\n }\n _convertTopLevelObjectsToArrays(json) {\n // TODO check that all arrays are covered\n for (const arrayName in GLTF_ARRAYS) {\n this._convertTopLevelObjectToArray(json, arrayName);\n }\n }\n /** Convert one top level object to array */\n _convertTopLevelObjectToArray(json, mapName) {\n const objectMap = json[mapName];\n if (!objectMap || Array.isArray(objectMap)) {\n return;\n }\n // Rewrite the top-level field as an array\n json[mapName] = [];\n // Copy the map key into object.id\n for (const id in objectMap) {\n const object = objectMap[id];\n object.id = object.id || id; // Mutates the loaded object\n const index = json[mapName].length;\n json[mapName].push(object);\n this.idToIndexMap[mapName][id] = index;\n }\n }\n /** Go through all objects in all top-level arrays and replace ids with indices */\n _convertObjectIdsToArrayIndices(json) {\n for (const arrayName in GLTF_ARRAYS) {\n this._convertIdsToIndices(json, arrayName);\n }\n if ('scene' in json) {\n json.scene = this._convertIdToIndex(json.scene, 'scene');\n }\n // Convert any index references that are not using array names\n // texture.source (image)\n for (const texture of json.textures) {\n this._convertTextureIds(texture);\n }\n for (const mesh of json.meshes) {\n this._convertMeshIds(mesh);\n }\n for (const node of json.nodes) {\n this._convertNodeIds(node);\n }\n for (const node of json.scenes) {\n this._convertSceneIds(node);\n }\n }\n _convertTextureIds(texture) {\n if (texture.source) {\n texture.source = this._convertIdToIndex(texture.source, 'image');\n }\n }\n _convertMeshIds(mesh) {\n for (const primitive of mesh.primitives) {\n const { attributes, indices, material } = primitive;\n for (const attributeName in attributes) {\n attributes[attributeName] = this._convertIdToIndex(attributes[attributeName], 'accessor');\n }\n if (indices) {\n primitive.indices = this._convertIdToIndex(indices, 'accessor');\n }\n if (material) {\n primitive.material = this._convertIdToIndex(material, 'material');\n }\n }\n }\n _convertNodeIds(node) {\n if (node.children) {\n node.children = node.children.map((child) => this._convertIdToIndex(child, 'node'));\n }\n if (node.meshes) {\n node.meshes = node.meshes.map((mesh) => this._convertIdToIndex(mesh, 'mesh'));\n }\n }\n _convertSceneIds(scene) {\n if (scene.nodes) {\n scene.nodes = scene.nodes.map((node) => this._convertIdToIndex(node, 'node'));\n }\n }\n /** Go through all objects in a top-level array and replace ids with indices */\n _convertIdsToIndices(json, topLevelArrayName) {\n if (!json[topLevelArrayName]) {\n console.warn(`gltf v1: json doesn't contain attribute ${topLevelArrayName}`); // eslint-disable-line no-console, no-undef\n json[topLevelArrayName] = [];\n }\n for (const object of json[topLevelArrayName]) {\n for (const key in object) {\n const id = object[key];\n const index = this._convertIdToIndex(id, key);\n object[key] = index;\n }\n }\n }\n _convertIdToIndex(id, key) {\n const arrayName = GLTF_KEYS[key];\n if (arrayName in this.idToIndexMap) {\n const index = this.idToIndexMap[arrayName][id];\n if (!Number.isFinite(index)) {\n throw new Error(`gltf v1: failed to resolve ${key} with id ${id}`);\n }\n return index;\n }\n return id;\n }\n /**\n *\n * @param {*} json\n */\n _updateObjects(json) {\n for (const buffer of this.json.buffers) {\n // - [x] Removed buffer.type, #786, #629\n delete buffer.type;\n }\n }\n /**\n * Update material (set pbrMetallicRoughness)\n * @param {*} json\n */\n _updateMaterial(json) {\n for (const material of json.materials) {\n material.pbrMetallicRoughness = {\n baseColorFactor: [1, 1, 1, 1],\n metallicFactor: 1,\n roughnessFactor: 1\n };\n const textureId = material.values?.tex || material.values?.texture2d_0 || material.values?.diffuseTex;\n const textureIndex = json.textures.findIndex((texture) => texture.id === textureId);\n if (textureIndex !== -1) {\n material.pbrMetallicRoughness.baseColorTexture = { index: textureIndex };\n }\n }\n }\n}\nexport function normalizeGLTFV1(gltf, options = {}) {\n return new GLTFV1Normalizer().normalize(gltf, options);\n}\n","import { parseJSON, sliceArrayBuffer, parseFromContext } from '@loaders.gl/loader-utils';\nimport { ImageLoader } from '@loaders.gl/images';\nimport { BasisLoader, selectSupportedBasisFormat } from '@loaders.gl/textures';\nimport { assert } from \"../utils/assert.js\";\nimport { isGLB, parseGLBSync } from \"./parse-glb.js\";\nimport { resolveUrl } from \"../gltf-utils/resolve-url.js\";\nimport { getTypedArrayForBufferView } from \"../gltf-utils/get-typed-array.js\";\nimport { preprocessExtensions, decodeExtensions } from \"../api/gltf-extensions.js\";\nimport { normalizeGLTFV1 } from \"../api/normalize-gltf-v1.js\";\n/** Check if an array buffer appears to contain GLTF data */\nexport function isGLTF(arrayBuffer, options) {\n const byteOffset = 0;\n return isGLB(arrayBuffer, byteOffset, options);\n}\nexport async function parseGLTF(gltf, arrayBufferOrString, byteOffset = 0, options, context) {\n parseGLTFContainerSync(gltf, arrayBufferOrString, byteOffset, options);\n normalizeGLTFV1(gltf, { normalize: options?.gltf?.normalize });\n preprocessExtensions(gltf, options, context);\n // Load linked buffers asynchronously and decodes base64 buffers in parallel\n if (options?.gltf?.loadBuffers && gltf.json.buffers) {\n await loadBuffers(gltf, options, context);\n }\n // loadImages and decodeExtensions should not be running in parallel, because\n // decodeExtensions uses data from images taken during the loadImages call.\n if (options?.gltf?.loadImages) {\n await loadImages(gltf, options, context);\n }\n await decodeExtensions(gltf, options, context);\n return gltf;\n}\n/**\n *\n * @param gltf\n * @param data - can be ArrayBuffer (GLB), ArrayBuffer (Binary JSON), String (JSON), or Object (parsed JSON)\n * @param byteOffset\n * @param options\n */\nfunction parseGLTFContainerSync(gltf, data, byteOffset, options) {\n // Initialize gltf container\n if (options.uri) {\n gltf.baseUri = options.uri;\n }\n // If data is binary and starting with magic bytes, assume binary JSON text, convert to string\n if (data instanceof ArrayBuffer && !isGLB(data, byteOffset, options)) {\n const textDecoder = new TextDecoder();\n data = textDecoder.decode(data);\n }\n if (typeof data === 'string') {\n // If string, try to parse as JSON\n gltf.json = parseJSON(data);\n }\n else if (data instanceof ArrayBuffer) {\n // If still ArrayBuffer, parse as GLB container\n const glb = {};\n byteOffset = parseGLBSync(glb, data, byteOffset, options.glb);\n assert(glb.type === 'glTF', `Invalid GLB magic string ${glb.type}`);\n gltf._glb = glb;\n gltf.json = glb.json;\n }\n else {\n assert(false, 'GLTF: must be ArrayBuffer or string');\n }\n // Populate buffers\n // Create an external buffers array to hold binary data\n const buffers = gltf.json.buffers || [];\n gltf.buffers = new Array(buffers.length).fill(null);\n // Populates JSON and some bin chunk info\n if (gltf._glb && gltf._glb.header.hasBinChunk) {\n const { binChunks } = gltf._glb;\n gltf.buffers[0] = {\n arrayBuffer: binChunks[0].arrayBuffer,\n byteOffset: binChunks[0].byteOffset,\n byteLength: binChunks[0].byteLength\n };\n // TODO - this modifies JSON and is a post processing thing\n // gltf.json.buffers[0].data = gltf.buffers[0].arrayBuffer;\n // gltf.json.buffers[0].byteOffset = gltf.buffers[0].byteOffset;\n }\n // Populate images\n const images = gltf.json.images || [];\n gltf.images = new Array(images.length).fill({});\n}\n/** Asynchronously fetch and parse buffers, store in buffers array outside of json\n * TODO - traverse gltf and determine which buffers are actually needed\n */\nasync function loadBuffers(gltf, options, context) {\n // TODO\n const buffers = gltf.json.buffers || [];\n for (let i = 0; i < buffers.length; ++i) {\n const buffer = buffers[i];\n if (buffer.uri) {\n const { fetch } = context;\n assert(fetch);\n const uri = resolveUrl(buffer.uri, options);\n const response = await context?.fetch?.(uri);\n const arrayBuffer = await response?.arrayBuffer?.();\n gltf.buffers[i] = {\n arrayBuffer,\n byteOffset: 0,\n byteLength: arrayBuffer.byteLength\n };\n delete buffer.uri;\n }\n else if (gltf.buffers[i] === null) {\n gltf.buffers[i] = {\n arrayBuffer: new ArrayBuffer(buffer.byteLength),\n byteOffset: 0,\n byteLength: buffer.byteLength\n };\n }\n }\n}\n/**\n * Loads all images\n * TODO - traverse gltf and determine which images are actually needed\n * @param gltf\n * @param options\n * @param context\n * @returns\n */\nasync function loadImages(gltf, options, context) {\n const imageIndices = getReferencesImageIndices(gltf);\n const images = gltf.json.images || [];\n const promises = [];\n for (const imageIndex of imageIndices) {\n promises.push(loadImage(gltf, images[imageIndex], imageIndex, options, context));\n }\n return await Promise.all(promises);\n}\n/** Make sure we only load images that are actually referenced by textures */\nfunction getReferencesImageIndices(gltf) {\n const imageIndices = new Set();\n const textures = gltf.json.textures || [];\n for (const texture of textures) {\n if (texture.source !== undefined) {\n imageIndices.add(texture.source);\n }\n }\n return Array.from(imageIndices).sort();\n}\n/** Asynchronously fetches and parses one image, store in images array outside of json */\nasync function loadImage(gltf, image, index, options, context) {\n let arrayBuffer;\n if (image.uri && !image.hasOwnProperty('bufferView')) {\n const uri = resolveUrl(image.uri, options);\n const { fetch } = context;\n const response = await fetch(uri);\n arrayBuffer = await response.arrayBuffer();\n image.bufferView = {\n data: arrayBuffer\n };\n }\n if (Number.isFinite(image.bufferView)) {\n const array = getTypedArrayForBufferView(gltf.json, gltf.buffers, image.bufferView);\n arrayBuffer = sliceArrayBuffer(array.buffer, array.byteOffset, array.byteLength);\n }\n assert(arrayBuffer, 'glTF image has no data');\n // Call `parse`\n let parsedImage = (await parseFromContext(arrayBuffer, [ImageLoader, BasisLoader], {\n ...options,\n mimeType: image.mimeType,\n basis: options.basis || { format: selectSupportedBasisFormat() }\n }, context));\n if (parsedImage && parsedImage[0]) {\n parsedImage = {\n compressed: true,\n // @ts-expect-error\n mipmaps: false,\n width: parsedImage[0].width,\n height: parsedImage[0].height,\n data: parsedImage[0]\n };\n }\n // TODO making sure ImageLoader is overridable by using array of loaders\n // const parsedImage = await parse(arrayBuffer, [ImageLoader]);\n // Store the loaded image\n gltf.images = gltf.images || [];\n // @ts-expect-error TODO - sort out image typing asap\n gltf.images[index] = parsedImage;\n}\n","import { VERSION } from \"./lib/utils/version.js\";\nimport { parseGLTF } from \"./lib/parsers/parse-gltf.js\";\n/**\n * GLTF loader\n */\nexport const GLTFLoader = {\n dataType: null,\n batchType: null,\n name: 'glTF',\n id: 'gltf',\n module: 'gltf',\n version: VERSION,\n extensions: ['gltf', 'glb'],\n mimeTypes: ['model/gltf+json', 'model/gltf-binary'],\n text: true,\n binary: true,\n tests: ['glTF'],\n parse,\n options: {\n gltf: {\n normalize: true, // Normalize glTF v1 to glTF v2 format (not yet stable)\n loadBuffers: true, // Fetch any linked .BIN buffers, decode base64\n loadImages: true, // Create image objects\n decompressMeshes: true // Decompress Draco encoded meshes\n },\n // common?\n log: console // eslint-disable-line\n }\n};\nexport async function parse(arrayBuffer, options = {}, context) {\n // Apps can call the parse method directly, we so apply default options here\n options = { ...GLTFLoader.options, ...options };\n // @ts-ignore\n options.gltf = { ...GLTFLoader.options.gltf, ...options.gltf };\n const { byteOffset = 0 } = options;\n const gltf = {};\n return await parseGLTF(gltf, arrayBuffer, byteOffset, options, context);\n}\n","// loaders.gl\n// SPDX-License-Identifier: MIT\n// Copyright (c) vis.gl contributors\nimport { assert } from \"../utils/assert.js\";\nimport { getAccessorArrayTypeAndLength } from \"../gltf-utils/gltf-utils.js\";\n// This is a post processor for loaded glTF files\n// The goal is to make the loaded data easier to use in WebGL applications\n//\n// Functions:\n// * Resolve indexed arrays structure of glTF into a linked tree.\n// * Translate stringified enum keys and values into WebGL constants.\n// * Load images (optional)\n// ENUM LOOKUP\nconst COMPONENTS = {\n SCALAR: 1,\n VEC2: 2,\n VEC3: 3,\n VEC4: 4,\n MAT2: 4,\n MAT3: 9,\n MAT4: 16\n};\nconst BYTES = {\n 5120: 1, // BYTE\n 5121: 1, // UNSIGNED_BYTE\n 5122: 2, // SHORT\n 5123: 2, // UNSIGNED_SHORT\n 5125: 4, // UNSIGNED_INT\n 5126: 4 // FLOAT\n};\nconst GL_SAMPLER = {\n // Sampler parameters\n TEXTURE_MAG_FILTER: 0x2800,\n TEXTURE_MIN_FILTER: 0x2801,\n TEXTURE_WRAP_S: 0x2802,\n TEXTURE_WRAP_T: 0x2803,\n // Sampler default values\n REPEAT: 0x2901,\n LINEAR: 0x2601,\n NEAREST_MIPMAP_LINEAR: 0x2702\n};\nconst SAMPLER_PARAMETER_GLTF_TO_GL = {\n magFilter: GL_SAMPLER.TEXTURE_MAG_FILTER,\n minFilter: GL_SAMPLER.TEXTURE_MIN_FILTER,\n wrapS: GL_SAMPLER.TEXTURE_WRAP_S,\n wrapT: GL_SAMPLER.TEXTURE_WRAP_T\n};\n// When undefined, a sampler with repeat wrapping and auto filtering should be used.\n// https://github.com/KhronosGroup/glTF/tree/master/specification/2.0#texture\nconst DEFAULT_SAMPLER_PARAMETERS = {\n [GL_SAMPLER.TEXTURE_MAG_FILTER]: GL_SAMPLER.LINEAR,\n [GL_SAMPLER.TEXTURE_MIN_FILTER]: GL_SAMPLER.NEAREST_MIPMAP_LINEAR,\n [GL_SAMPLER.TEXTURE_WRAP_S]: GL_SAMPLER.REPEAT,\n [GL_SAMPLER.TEXTURE_WRAP_T]: GL_SAMPLER.REPEAT\n};\nfunction makeDefaultSampler() {\n return {\n id: 'default-sampler',\n parameters: DEFAULT_SAMPLER_PARAMETERS\n };\n}\nfunction getBytesFromComponentType(componentType) {\n return BYTES[componentType];\n}\nfunction getSizeFromAccessorType(type) {\n return COMPONENTS[type];\n}\nclass GLTFPostProcessor {\n baseUri = '';\n // @ts-expect-error\n jsonUnprocessed;\n // @ts-expect-error\n json;\n buffers = [];\n images = [];\n postProcess(gltf, options = {}) {\n const { json, buffers = [], images = [] } = gltf;\n // @ts-expect-error\n const { baseUri = '' } = gltf;\n assert(json);\n this.baseUri = baseUri;\n this.buffers = buffers;\n this.images = images;\n this.jsonUnprocessed = json;\n this.json = this._resolveTree(gltf.json, options);\n return this.json;\n }\n // Convert indexed glTF structure into tree structure\n // cross-link index resolution, enum lookup, convenience calculations\n // eslint-disable-next-line complexity, max-statements\n _resolveTree(gltf, options = {}) {\n // @ts-expect-error\n const json = { ...gltf };\n this.json = json;\n if (gltf.bufferViews) {\n json.bufferViews = gltf.bufferViews.map((bufView, i) => this._resolveBufferView(bufView, i));\n }\n if (gltf.images) {\n json.images = gltf.images.map((image, i) => this._resolveImage(image, i));\n }\n if (gltf.samplers) {\n json.samplers = gltf.samplers.map((sampler, i) => this._resolveSampler(sampler, i));\n }\n if (gltf.textures) {\n json.textures = gltf.textures.map((texture, i) => this._resolveTexture(texture, i));\n }\n if (gltf.accessors) {\n json.accessors = gltf.accessors.map((accessor, i) => this._resolveAccessor(accessor, i));\n }\n if (gltf.materials) {\n json.materials = gltf.materials.map((material, i) => this._resolveMaterial(material, i));\n }\n if (gltf.meshes) {\n json.meshes = gltf.meshes.map((mesh, i) => this._resolveMesh(mesh, i));\n }\n if (gltf.nodes) {\n json.nodes = gltf.nodes.map((node, i) => this._resolveNode(node, i));\n json.nodes = json.nodes.map((node, i) => this._resolveNodeChildren(node));\n }\n if (gltf.skins) {\n json.skins = gltf.skins.map((skin, i) => this._resolveSkin(skin, i));\n }\n if (gltf.scenes) {\n json.scenes = gltf.scenes.map((scene, i) => this._resolveScene(scene, i));\n }\n if (typeof this.json.scene === 'number' && json.scenes) {\n json.scene = json.scenes[this.json.scene];\n }\n return json;\n }\n getScene(index) {\n return this._get(this.json.scenes, index);\n }\n getNode(index) {\n return this._get(this.json.nodes, index);\n }\n getSkin(index) {\n return this._get(this.json.skins, index);\n }\n getMesh(index) {\n return this._get(this.json.meshes, index);\n }\n getMaterial(index) {\n return this._get(this.json.materials, index);\n }\n getAccessor(index) {\n return this._get(this.json.accessors, index);\n }\n getCamera(index) {\n return this._get(this.json.cameras, index);\n }\n getTexture(index) {\n return this._get(this.json.textures, index);\n }\n getSampler(index) {\n return this._get(this.json.samplers, index);\n }\n getImage(index) {\n return this._get(this.json.images, index);\n }\n getBufferView(index) {\n return this._get(this.json.bufferViews, index);\n }\n getBuffer(index) {\n return this._get(this.json.buffers, index);\n }\n _get(array, index) {\n // check if already resolved\n if (typeof index === 'object') {\n return index;\n }\n const object = array && array[index];\n if (!object) {\n console.warn(`glTF file error: Could not find ${array}[${index}]`); // eslint-disable-line\n }\n return object;\n }\n // PARSING HELPERS\n _resolveScene(scene, index) {\n return {\n ...scene,\n // @ts-ignore\n id: scene.id || `scene-${index}`,\n nodes: (scene.nodes || []).map((node) => this.getNode(node))\n };\n }\n _resolveNode(gltfNode, index) {\n // @ts-expect-error\n const node = {\n ...gltfNode,\n // @ts-expect-error id could already be present, glTF standard does not prevent it\n id: gltfNode?.id || `node-${index}`\n };\n if (gltfNode.mesh !== undefined) {\n node.mesh = this.getMesh(gltfNode.mesh);\n }\n if (gltfNode.camera !== undefined) {\n node.camera = this.getCamera(gltfNode.camera);\n }\n if (gltfNode.skin !== undefined) {\n node.skin = this.getSkin(gltfNode.skin);\n }\n // TODO deprecated - Delete in v4.0?\n // @ts-expect-error node.meshes does not seem to be part of the GLTF standard\n if (gltfNode.meshes !== undefined && gltfNode.meshes.length) {\n // @ts-expect-error\n node.mesh = gltfNode.meshes.reduce((accum, meshIndex) => {\n const mesh = this.getMesh(meshIndex);\n accum.id = mesh.id;\n accum.primitives = accum.primitives.concat(mesh.primitives);\n return accum;\n }, { primitives: [] });\n }\n return node;\n }\n _resolveNodeChildren(node) {\n if (node.children) {\n // @ts-expect-error node.children are numbers at this stage\n node.children = node.children.map((child) => this.getNode(child));\n }\n return node;\n }\n _resolveSkin(gltfSkin, index) {\n const inverseBindMatrices = typeof gltfSkin.inverseBindMatrices === 'number'\n ? this.getAccessor(gltfSkin.inverseBindMatrices)\n : undefined;\n return {\n ...gltfSkin,\n id: gltfSkin.id || `skin-${index}`,\n inverseBindMatrices\n };\n }\n _resolveMesh(gltfMesh, index) {\n const mesh = {\n ...gltfMesh,\n id: gltfMesh.id || `mesh-${index}`,\n primitives: []\n };\n if (gltfMesh.primitives) {\n mesh.primitives = gltfMesh.primitives.map((gltfPrimitive) => {\n const primitive = {\n ...gltfPrimitive,\n attributes: {},\n indices: undefined,\n material: undefined\n };\n const attributes = gltfPrimitive.attributes;\n for (const attribute in attributes) {\n primitive.attributes[attribute] = this.getAccessor(attributes[attribute]);\n }\n if (gltfPrimitive.indices !== undefined) {\n primitive.indices = this.getAccessor(gltfPrimitive.indices);\n }\n if (gltfPrimitive.material !== undefined) {\n primitive.material = this.getMaterial(gltfPrimitive.material);\n }\n return primitive;\n });\n }\n return mesh;\n }\n _resolveMaterial(gltfMaterial, index) {\n // @ts-expect-error\n const material = {\n ...gltfMaterial,\n // @ts-expect-error\n id: gltfMaterial.id || `material-${index}`\n };\n if (material.normalTexture) {\n material.normalTexture = { ...material.normalTexture };\n material.normalTexture.texture = this.getTexture(material.normalTexture.index);\n }\n if (material.occlusionTexture) {\n material.occlusionTexture = { ...material.occlusionTexture };\n material.occlusionTexture.texture = this.getTexture(material.occlusionTexture.index);\n }\n if (material.emissiveTexture) {\n material.emissiveTexture = { ...material.emissiveTexture };\n material.emissiveTexture.texture = this.getTexture(material.emissiveTexture.index);\n }\n if (!material.emissiveFactor) {\n material.emissiveFactor = material.emissiveTexture ? [1, 1, 1] : [0, 0, 0];\n }\n if (material.pbrMetallicRoughness) {\n material.pbrMetallicRoughness = { ...material.pbrMetallicRoughness };\n const mr = material.pbrMetallicRoughness;\n if (mr.baseColorTexture) {\n mr.baseColorTexture = { ...mr.baseColorTexture };\n mr.baseColorTexture.texture = this.getTexture(mr.baseColorTexture.index);\n }\n if (mr.metallicRoughnessTexture) {\n mr.metallicRoughnessTexture = { ...mr.metallicRoughnessTexture };\n mr.metallicRoughnessTexture.texture = this.getTexture(mr.metallicRoughnessTexture.index);\n }\n }\n return material;\n }\n _resolveAccessor(gltfAccessor, index) {\n // Look up enums\n const bytesPerComponent = getBytesFromComponentType(gltfAccessor.componentType);\n const components = getSizeFromAccessorType(gltfAccessor.type);\n const bytesPerElement = bytesPerComponent * components;\n const accessor = {\n ...gltfAccessor,\n // @ts-expect-error\n id: gltfAccessor.id || `accessor-${index}`,\n bytesPerComponent,\n components,\n bytesPerElement,\n value: undefined,\n bufferView: undefined,\n sparse: undefined\n };\n if (gltfAccessor.bufferView !== undefined) {\n // Draco encoded meshes don't have bufferView\n accessor.bufferView = this.getBufferView(gltfAccessor.bufferView);\n }\n // Create TypedArray for the accessor\n // Note: The canonical way to instantiate is to ignore this array and create\n // WebGLBuffer's using the bufferViews.\n if (accessor.bufferView) {\n const buffer = accessor.bufferView.buffer;\n const { ArrayType, byteLength } = getAccessorArrayTypeAndLength(accessor, accessor.bufferView);\n const byteOffset = (accessor.bufferView.byteOffset || 0) + (accessor.byteOffset || 0) + buffer.byteOffset;\n let cutBuffer = buffer.arrayBuffer.slice(byteOffset, byteOffset + byteLength);\n if (accessor.bufferView.byteStride) {\n cutBuffer = this._getValueFromInterleavedBuffer(buffer, byteOffset, accessor.bufferView.byteStride, accessor.bytesPerElement, accessor.count);\n }\n accessor.value = new ArrayType(cutBuffer);\n }\n return accessor;\n }\n /**\n * Take values of particular accessor from interleaved buffer\n * various parts of the buffer\n * @param buffer\n * @param byteOffset\n * @param byteStride\n * @param bytesPerElement\n * @param count\n * @returns\n */\n _getValueFromInterleavedBuffer(buffer, byteOffset, byteStride, bytesPerElement, count) {\n const result = new Uint8Array(count * bytesPerElement);\n for (let i = 0; i < count; i++) {\n const elementOffset = byteOffset + i * byteStride;\n result.set(new Uint8Array(buffer.arrayBuffer.slice(elementOffset, elementOffset + bytesPerElement)), i * bytesPerElement);\n }\n return result.buffer;\n }\n _resolveTexture(gltfTexture, index) {\n return {\n ...gltfTexture,\n // @ts-expect-error id could already be present, glTF standard does not prevent it\n id: gltfTexture.id || `texture-${index}`,\n sampler: typeof gltfTexture.sampler === 'number'\n ? this.getSampler(gltfTexture.sampler)\n : makeDefaultSampler(),\n source: typeof gltfTexture.source === 'number' ? this.getImage(gltfTexture.source) : undefined\n };\n }\n _resolveSampler(gltfSampler, index) {\n const sampler = {\n // @ts-expect-error id could already be present, glTF standard does not prevent it\n id: gltfSampler.id || `sampler-${index}`,\n ...gltfSampler,\n parameters: {}\n };\n // Map textual parameters to GL parameter values\n for (const key in sampler) {\n const glEnum = this._enumSamplerParameter(key);\n if (glEnum !== undefined) {\n sampler.parameters[glEnum] = sampler[key];\n }\n }\n return sampler;\n }\n _enumSamplerParameter(key) {\n return SAMPLER_PARAMETER_GLTF_TO_GL[key];\n }\n _resolveImage(gltfImage, index) {\n const image = {\n ...gltfImage,\n // @ts-expect-error id could already be present, glTF standard does not prevent it\n id: gltfImage.id || `image-${index}`,\n image: null,\n bufferView: gltfImage.bufferView !== undefined ? this.getBufferView(gltfImage.bufferView) : undefined\n };\n // Check if image has been preloaded by the GLTFLoader\n // If so, link it into the JSON and drop the URI\n const preloadedImage = this.images[index];\n if (preloadedImage) {\n image.image = preloadedImage;\n }\n return image;\n }\n _resolveBufferView(gltfBufferView, index) {\n const bufferIndex = gltfBufferView.buffer;\n const arrayBuffer = this.buffers[bufferIndex].arrayBuffer;\n // Add offset of buffer, then offset of buffer view\n let byteOffset = this.buffers[bufferIndex].byteOffset || 0;\n if (gltfBufferView.byteOffset) {\n byteOffset += gltfBufferView.byteOffset;\n }\n const bufferView = {\n // // @ts-expect-error id could already be present, glTF standard does not prevent it\n id: `bufferView-${index}`,\n ...gltfBufferView,\n // ...this.buffers[bufferIndex],\n buffer: this.buffers[bufferIndex],\n data: new Uint8Array(arrayBuffer, byteOffset, gltfBufferView.byteLength)\n };\n return bufferView;\n }\n _resolveCamera(gltfCamera, index) {\n const camera = {\n ...gltfCamera,\n // @ts-expect-error id could already be present, glTF standard does not prevent it\n id: gltfCamera.id || `camera-${index}`\n };\n // TODO - create 4x4 matrices\n if (camera.perspective) {\n // camera.matrix = createPerspectiveMatrix(camera.perspective);\n }\n if (camera.orthographic) {\n // camera.matrix = createOrthographicMatrix(camera.orthographic);\n }\n return camera;\n }\n}\nexport function postProcessGLTF(gltf, options) {\n return new GLTFPostProcessor().postProcess(gltf, options);\n}\n","// deck.gl\n// SPDX-License-Identifier: MIT\n// Copyright (c) vis.gl contributors\nexport async function waitForGLTFAssets(gltfObjects) {\n const remaining = [];\n gltfObjects.scenes.forEach(scene => {\n scene.traverse((modelNode) => {\n // Not really clear how we can access the uniforms?\n // TODO v9 getUnforms() was removed, hack it with props.uniforms\n // Object.values((modelNode as ModelNode).model.uniforms).forEach((uniform: any) => {\n // if (uniform.loaded === false) {\n // remaining.push(uniform);\n // }\n // });\n });\n });\n return await waitWhileCondition(() => remaining.some(uniform => !uniform.loaded));\n}\nasync function waitWhileCondition(condition) {\n while (condition()) {\n await new Promise(resolve => requestAnimationFrame(resolve));\n }\n}\n//# sourceMappingURL=gltf-utils.js.map","// deck.gl\n// SPDX-License-Identifier: MIT\n// Copyright (c) vis.gl contributors\nconst uniformBlock = `\\\nuniform scenegraphUniforms {\n float sizeScale;\n float sizeMinPixels;\n float sizeMaxPixels;\n mat4 sceneModelMatrix;\n bool composeModelMatrix;\n} scenegraph;\n`;\nexport const scenegraphUniforms = {\n name: 'scenegraph',\n vs: uniformBlock,\n fs: uniformBlock,\n uniformTypes: {\n sizeScale: 'f32',\n sizeMinPixels: 'f32',\n sizeMaxPixels: 'f32',\n sceneModelMatrix: 'mat4x4<f32>',\n composeModelMatrix: 'f32'\n }\n};\n//# sourceMappingURL=scenegraph-layer-uniforms.js.map","// deck.gl\n// SPDX-License-Identifier: MIT\n// Copyright (c) vis.gl contributors\nexport default `\\\n#version 300 es\n#define SHADER_NAME scenegraph-layer-vertex-shader\nin vec3 instancePositions;\nin vec3 instancePositions64Low;\nin vec4 instanceColors;\nin vec3 instancePickingColors;\nin vec3 instanceModelMatrixCol0;\nin vec3 instanceModelMatrixCol1;\nin vec3 instanceModelMatrixCol2;\nin vec3 instanceTranslation;\nin vec3 positions;\n#ifdef HAS_UV\nin vec2 texCoords;\n#endif\n#ifdef LIGHTING_PBR\n#ifdef HAS_NORMALS\nin vec3 normals;\n#endif\n#endif\nout vec4 vColor;\n#ifndef LIGHTING_PBR\n#ifdef HAS_UV\nout vec2 vTEXCOORD_0;\n#endif\n#endif\nvoid main(void) {\n#if defined(HAS_UV) && !defined(LIGHTING_PBR)\nvTEXCOORD_0 = texCoords;\ngeometry.uv = texCoords;\n#endif\ngeometry.worldPosition = instancePositions;\ngeometry.pickingColor = instancePickingColors;\nmat3 instanceModelMatrix = mat3(instanceModelMatrixCol0, instanceModelMatrixCol1, instanceModelMatrixCol2);\nvec3 normal = vec3(0.0, 0.0, 1.0);\n#ifdef LIGHTING_PBR\n#ifdef HAS_NORMALS\nnormal = instanceModelMatrix * (scenegraph.sceneModelMatrix * vec4(normals, 0.0)).xyz;\n#endif\n#endif\nfloat originalSize = project_size_to_pixel(scenegraph.sizeScale);\nfloat clampedSize = clamp(originalSize, scenegraph.sizeMinPixels, scenegraph.sizeMaxPixels);\nvec3 pos = (instanceModelMatrix * (scenegraph.sceneModelMatrix * vec4(positions, 1.0)).xyz) * scenegraph.sizeScale * (clampedSize / originalSize) + instanceTranslation;\nif(scenegraph.composeModelMatrix) {\nDECKGL_FILTER_SIZE(pos, geometry);\ngeometry.normal = project_normal(normal);\ngeometry.worldPosition += pos;\ngl_Position = project_position_to_clipspace(pos + instancePositions, instancePositions64Low, vec3(0.0), geometry.position);\n}\nelse {\npos = project_size(pos);\nDECKGL_FILTER_SIZE(pos, geometry);\ngl_Position = project_position_to_clipspace(instancePositions, instancePositions64Low, pos, geometry.position);\ngeometry.normal = project_normal(normal);\n}\nDECKGL_FILTER_GL_POSITION(gl_Position, geometry);\n#ifdef LIGHTING_PBR\npbr_vPosition = geometry.position.xyz;\n#ifdef HAS_NORMALS\npbr_vNormal = geometry.normal;\n#endif\n#ifdef HAS_UV\npbr_vUV = texCoords;\n#else\npbr_vUV = vec2(0., 0.);\n#endif\ngeometry.uv = pbr_vUV;\n#endif\nvColor = instanceColors;\nDECKGL_FILTER_COLOR(vColor, geometry);\n}\n`;\n//# sourceMappingURL=scenegraph-layer-vertex.glsl.js.map","// deck.gl\n// SPDX-License-Identifier: MIT\n// Copyright (c) vis.gl contributors\nexport default `\\\n#version 300 es\n#define SHADER_NAME scenegraph-layer-fragment-shader\nin vec4 vColor;\nout vec4 fragColor;\n#ifndef LIGHTING_PBR\n#if defined(HAS_UV) && defined(HAS_BASECOLORMAP)\nin vec2 vTEXCOORD_0;\nuniform sampler2D pbr_baseColorSampler;\n#endif\n#endif\nvoid main(void) {\n#ifdef LIGHTING_PBR\nfragColor = vColor * pbr_filterColor(vec4(0));\ngeometry.uv = pbr_vUV;\n#else\n#if defined(HAS_UV) && defined(HAS_BASECOLORMAP)\nfragColor = vColor * texture(pbr_baseColorSampler, vTEXCOORD_0);\ngeometry.uv = vTEXCOORD_0;\n#else\nfragColor = vColor;\n#endif\n#endif\nfragColor.a *= layer.opacity;\nDECKGL_FILTER_COLOR(fragColor, geometry);\n}\n`;\n//# sourceMappingURL=scenegraph-layer-fragment.glsl.js.map","// deck.gl\n// SPDX-License-Identifier: MIT\n// Copyright (c) vis.gl contributors\nimport { Layer, project32, picking, log } from '@deck.gl/core';\nimport { pbrMaterial } from '@luma.gl/shadertools';\nimport { ScenegraphNode, GroupNode, ModelNode } from '@luma.gl/engine';\nimport { createScenegraphsFromGLTF } from '@luma.gl/gltf';\nimport { GLTFLoader, postProcessGLTF } from '@loaders.gl/gltf';\nimport { waitForGLTFAssets } from \"./gltf-utils.js\";\nimport { MATRIX_ATTRIBUTES, shouldComposeModelMatrix } from \"../utils/matrix.js\";\nimport { scenegraphUniforms } from \"./scenegraph-layer-uniforms.js\";\nimport vs from \"./scenegraph-layer-vertex.glsl.js\";\nimport fs from \"./scenegraph-layer-fragment.glsl.js\";\nconst DEFAULT_COLOR = [255, 255, 255, 255];\nconst defaultProps = {\n scenegraph: { type: 'object', value: null, async: true },\n getScene: gltf => {\n if (gltf && gltf.scenes) {\n // gltf post processor replaces `gltf.scene` number with the scene `object`\n return typeof gltf.scene === 'object' ? gltf.scene : gltf.scenes[gltf.scene || 0];\n }\n return gltf;\n },\n getAnimator: scenegraph => scenegraph && scenegraph.animator,\n _animations: null,\n sizeScale: { type: 'number', value: 1, min: 0 },\n sizeMinPixels: { type: 'number', min: 0, value: 0 },\n sizeMaxPixels: { type: 'number', min: 0, value: Number.MAX_SAFE_INTEGER },\n getPosition: { type: 'accessor', value: (x) => x.position },\n getColor: { type: 'accessor', value: DEFAULT_COLOR },\n // flat or pbr\n _lighting: 'flat',\n // _lighting must be pbr for this to work\n _imageBasedLightingEnvironment: undefined,\n // yaw, pitch and roll are in degrees\n // https://en.wikipedia.org/wiki/Euler_angles\n // [pitch, yaw, roll]\n getOrientation: { type: 'accessor', value: [0, 0, 0] },\n getScale: { type: 'accessor', value: [1, 1, 1] },\n getTranslation: { type: 'accessor', value: [0, 0, 0] },\n // 4x4 matrix\n getTransformMatrix: { type: 'accessor', value: [] },\n loaders: [GLTFLoader]\n};\n/** Render a number of instances of a complete glTF scenegraph. */\nclass ScenegraphLayer extends Layer {\n getShaders() {\n const defines = {};\n let pbr;\n if (this.props._lighting === 'pbr') {\n pbr = pbrMaterial;\n defines.LIGHTING_PBR = 1;\n }\n else {\n // Dummy shader module needed to handle\n // pbrMaterial.pbr_baseColorSampler binding\n pbr = { name: 'pbrMaterial' };\n }\n const modules = [project32, picking, scenegraphUniforms, pbr];\n return super.getShaders({ defines, vs, fs, modules });\n }\n initializeState() {\n const attributeManager = this.getAttributeManager();\n // attributeManager is always defined for primitive layers\n attributeManager.addInstanced({\n instancePositions: {\n size: 3,\n type: 'float64',\n fp64: this.use64bitPositions(),\n accessor: 'getPosition',\n transition: true\n },\n instanceColors: {\n type: 'unorm8',\n size: this.props.colorFormat.length,\n accessor: 'getColor',\n defaultValue: DEFAULT_COLOR,\n transition: true\n },\n instanceModelMatrix: MATRIX_ATTRIBUTES\n });\n }\n updateState(params) {\n super.updateState(params);\n const { props, oldProps } = params;\n if (props.scenegraph !== oldProps.scenegraph) {\n this._updateScenegraph();\n }\n else if (props._animations !== oldProps._animations) {\n this._applyAnimationsProp(this.state.animator, props._animations);\n }\n }\n finalizeState(context) {\n super.finalizeState(context);\n this.state.scenegraph?.destroy();\n }\n get isLoaded() {\n return Boolean(this.state?.scenegraph && super.isLoaded);\n }\n _updateScenegraph() {\n const props = this.props;\n const { device } = this.context;\n let scenegraphData = null;\n if (props.scenegraph instanceof ScenegraphNode) {\n // Signature 1: props.scenegraph is a proper luma.gl Scenegraph\n scenegraphData = { scenes: [props.scenegraph] };\n }\n else if (props.scenegraph && typeof props.scenegraph === 'object') {\n // Converts loaders.gl gltf to luma.gl scenegraph using the undocumented @luma.gl/experimental function\n const gltf = props.scenegraph;\n // Tiles3DLoader already processes GLTF\n const processedGLTF = gltf.json ? postProcessGLTF(gltf) : gltf;\n const gltfObjects = createScenegraphsFromGLTF(device, processedGLTF, this._getModelOptions());\n scenegraphData = { gltf: processedGLTF, ...gltfObjects };\n waitForGLTFAssets(gltfObjects)\n .then(() => {\n this.setNeedsRedraw();\n })\n .catch(ex => {\n this.raiseError(ex, 'loading glTF');\n });\n }\n const options = { layer: this, device: this.context.device };\n const scenegraph = props.getScene(scenegraphData, options);\n const animator = props.getAnimator(scenegraphData, options);\n if (scenegraph instanceof GroupNode) {\n this.state.scenegraph?.destroy();\n this._applyAnimationsProp(animator, props._animations);\n const models = [];\n scenegraph.traverse(node => {\n if (node instanceof ModelNode) {\n models.push(node.model);\n }\n });\n this.setState({ scenegraph, animator, models });\n this.getAttributeManager().invalidateAll();\n }\n else if (scenegraph !== null) {\n log.warn('invalid scenegraph:', scenegraph)();\n }\n }\n _applyAnimationsProp(animator, animationsProp) {\n if (!animator || !animationsProp) {\n return;\n }\n const animations = animator.getAnimations();\n // sort() to ensure '*' comes first so that other values can override\n Object.keys(animationsProp)\n .sort()\n .forEach(key => {\n // Key can be:\n // - number for index number\n // - name for animation name\n // - * to affect all animations\n const value = animationsProp[key];\n if (key === '*') {\n animations.forEach(animation => {\n Object.assign(animation, value);\n });\n }\n else if (Number.isFinite(Number(key))) {\n const number = Number(key);\n if (number >= 0 && number < animations.length) {\n Object.assign(animations[number], value);\n }\n else {\n log.warn(`animation ${key} not found`)();\n }\n }\n else {\n const findResult = animations.find(({ animation }) => animation.name === key);\n if (findResult) {\n Object.assign(findResult, value);\n }\n else {\n log.warn(`animation ${key} not found`)();\n }\n }\n });\n }\n _getModelOptions() {\n const { _imageBasedLightingEnvironment } = this.props;\n let env;\n if (_imageBasedLightingEnvironment) {\n if (typeof _imageBasedLightingEnvironment === 'function') {\n env = _imageBasedLightingEnvironment({ gl: this.context.gl, layer: this });\n }\n else {\n env = _imageBasedLightingEnvironment;\n }\n }\n return {\n imageBasedLightingEnvironment: env,\n modelOptions: {\n id: this.props.id,\n isInstanced: true,\n bufferLayout: this.getAttributeManager().getBufferLayouts(),\n ...this.getShaders()\n },\n // tangents are not supported\n useTangents: false\n };\n }\n draw({ context }) {\n if (!this.state.scenegraph)\n return;\n if (this.props._animations && this.state.animator) {\n this.state.animator.animate(context.timeline.getTime());\n this.setNeedsRedraw();\n }\n const { viewport, renderPass } = this.context;\n const { sizeScale, sizeMinPixels, sizeMaxPixels, coordinateSystem } = this.props;\n const pbrProjectionProps = {\n camera: viewport.cameraPosition\n };\n const numInstances = this.getNumInstances();\n this.state.scenegraph.traverse((node, { worldMatrix }) => {\n if (node instanceof ModelNode) {\n const { model } = node;\n model.setInstanceCount(numInstances);\n const scenegraphProps = {\n sizeScale,\n sizeMinPixels,\n sizeMaxPixels,\n composeModelMatrix: shouldComposeModelMatrix(viewport, coordinateSystem),\n sceneModelMatrix: worldMatrix\n };\n model.shaderInputs.setProps({\n pbrProjection: pbrProjectionProps,\n scenegraph: scenegraphProps\n });\n model.draw(renderPass);\n }\n });\n }\n}\nScenegraphLayer.defaultProps = defaultProps;\nScenegraphLayer.layerName = 'ScenegraphLayer';\nexport default ScenegraphLayer;\n//# sourceMappingURL=scenegraph-layer.js.map"],"names":["parseFromContext","data","loaders","options","context","registerJSModules","modules","getJSModuleOrNull","name","loadLibraryPromises","loadLibrary","libraryUrl","moduleName","libraryName","getLibraryUrl","loadLibraryFromFile","library","isBrowser","assert","VERSION","isWorker","loadAsArrayBuffer","requireFromFile","error","scriptSource","loadAsText","loadLibraryFromString","id","requireFromString","script","url","readFileAsArrayBuffer","readFileAsText","getFirstCharacters","length","getMagicString","arrayBuffer","byteOffset","dataView","magic","i","parseJSON","string","padToNBytes","byteLength","padding","copyToArray","source","target","targetOffset","sourceArray","srcByteOffset","srcByteLength","getDataTypeFromTypedArray","array","getMeshBoundingBox","attributes","minX","minY","minZ","maxX","maxY","maxZ","positions","len","x","y","z","deduceMeshField","attribute","optionalMetadata","type","metadata","makeMeshAttributeMetadata","result","mimeTypeSupportedSync","isImageFormatSupported","mimeType","supported","checkBrowserImageFormatSupport","checkNodeImageFormatSupport","NODE_FORMAT_SUPPORT","imageFormatsNode","testBrowserImageFormatSupport","ZERO","Vector4","Vector","w","isArray","config","checkNumber","object","value","matrix4","vec4_transformMat4","matrix3","vec4_transformMat3","matrix2","vec4_transformMat2","quaternion","vec4_transformQuat","m","create","out","glMatrix.ARRAY_TYPE","transpose","a","a01","a02","a12","invert","a00","a10","a11","a20","a21","a22","b01","b11","b21","det","determinant","multiply","b","b00","b02","b10","b12","b20","b22","translate","v","rotate","rad","s","c","scale","fromQuat","q","x2","y2","z2","xx","yx","yy","zx","zy","zz","wx","wy","wz","INDICES","IDENTITY_MATRIX","Matrix3","Matrix","getIdentityMatrix","getZeroMatrix","args","mat3_fromQuat","m00","m10","m20","m01","m11","m21","m02","m12","m22","mat3_determinant","mat3_transpose","mat3_invert","mat3_multiply","radians","mat3_rotate","factor","mat3_scale","vec","mat3_translate","vector","vec2_transformMat3","vec3_transformMat3","checkVector","ZERO_MATRIX3","IDENTITY_MATRIX3","identity","setAxisAngle","axis","ax","ay","az","aw","bx","by","bz","bw","rotateX","rotateY","rotateZ","calculateW","slerp","t","cosom","omega","scale0","scale1","sinom","glMatrix.EPSILON","a0","a1","a2","a3","dot","invDot","conjugate","fromMat3","fTrace","fRoot","j","k","add","vec4.add","vec4.scale","vec4.dot","lerp","vec4.lerp","vec4.length","squaredLength","vec4.squaredLength","normalize","vec4.normalize","rotationTo","tmpvec3","vec3.create","xUnitVec3","vec3.fromValues","yUnitVec3","vec3.dot","vec3.cross","vec3.len","vec3.normalize","temp1","temp2","d","matr","mat3.create","view","right","up","IDENTITY_QUATERNION","Quaternion","MathArray","quat_fromMat3","quat_setAxisAngle","quat_identity","quat_length","quat_squaredLength","quat_dot","vectorA","vectorB","quat_rotationTo","quat_add","quat_calculateW","quat_conjugate","quat_invert","quat_lerp","quat_multiply","l","quat_rotateX","quat_rotateY","quat_rotateZ","quat_scale","arg0","arg1","arg2","start","ratio","quat_slerp","vs","fs","uniformBlock","pbrProjection","props","pbrMaterial","lighting","ScenegraphNode","Matrix4","Vector3","uid","position","rotation","matrix","copyMatrix","components","update","pos","rot","viewMatrix","modelMatrix","worldMatrix","worldInverse","worldInverseTranspose","GroupNode","children","log","child","node","bounds","min","max","center","halfSize","indexOf","visitor","ModelNode","resource","renderPass","RADIAN_PER_DEGREE","valueArray","calculateTransformMatrix","targetMatrix","orientation","pitch","yaw","roll","sr","sp","sw","cr","cp","cw","scx","scy","scz","getExtendedMat3FromMat4","mat4","MATRIX_ATTRIBUTES","startRow","endRow","getOrientation","getScale","getTranslation","getTransformMatrix","arrayMatrix","constantMatrix","constantScale","constantOrientation","constantTranslation","hasMatrix","instanceModelMatrixData","iterable","objectInfo","createIterable","shouldComposeModelMatrix","viewport","coordinateSystem","COORDINATE_SYSTEM","simpleMeshUniforms","vs$2","fs$2","normalizeGeometryAttributes","positionAttribute","vertexCount","colorAttribute","normalAttribute","texCoordAttribute","getGeometry","Geometry","DEFAULT_COLOR","defaultProps","SimpleMeshLayer","Layer","project32","phongMaterial","picking","mesh","params","oldProps","changeFlags","Texture","uniforms","model","sizeScale","_instanced","simpleMeshProps","Model","texture","emptyTexture","BASIS_EXTERNAL_LIBRARIES","loadBasisTranscoderPromise","loadBasisTranscoderModule","basis","loadBasisTranscoder","BASIS","wasmBinary","initializeBasisTranscoderModule","BasisModule","resolve","module","BasisFile","initializeBasis","loadBasisEncoderPromise","loadBasisEncoderModule","loadBasisEncoder","BASIS_ENCODER","initializeBasisEncoderModule","BasisEncoderModule","KTX2File","BasisEncoder","GL_EXTENSIONS_CONSTANTS","BROWSER_PREFIXES","WEBGL_EXTENSIONS","formats","getSupportedGPUTextureFormats","gl","getWebGLContext","prefix","extension","gpuTextureFormat","KTX2_ID","isKTX","OutputFormat","parseBasis","fileConstructors","parseKTX2File","parseBasisFile","basisFile","imageCount","images","imageIndex","levelsCount","levels","levelIndex","transcodeImage","width","height","hasAlpha","compressed","format","basisFormat","getBasisOptions","decodedSize","decodedData","ktx2File","transcodeKTX2Image","alphaFlag","selectSupportedBasisFormat","supportedFormats","BasisWorkerLoader","BasisLoader","convertSampler","gltfSampler","convertSamplerWrapMode","convertSamplerMagFilter","convertSamplerMinFilter","mode","parsePBRMaterial","device","material","parsedMaterial","imageBasedLightingEnvironment","parseMaterial","parsePbrMetallicRoughness","addTexture","strength","alphaCutoff","pbrMetallicRoughness","metallicFactor","roughnessFactor","gltfTexture","uniformName","define","image","textureOptions","GLEnum","convertGLDrawModeToTopology","drawMode","SHADER","createGLTFModel","geometry","parsedPPBRMaterial","modelOptions","managedResources","parameters","modelProps","camera","pbrMaterialProps","defaultOptions","parseGLTF","gltf","options_","gltfScene","createScene","gltfNodes","nodes","createNode","gltfNode","createMesh","rotationMatrix","topLevelNode","gltfMesh","primitives","gltfPrimitive","createPrimitive","topology","getVertexCount","createGeometry","modelNode","attributeName","size","scratchQuaternion","interpolate","time","input","interpolation","output","path","maxTime","animationTime","nextIndex","previousIndex","previousTime","nextTime","stepInterpolate","linearInterpolate","tDiff","p0","outTangent0","inTangent1","p1","cubicsplineInterpolate","stop","m0","m1","GLTFSingleAnimator","timeMs","sampler","applyTranslationRotationScale","GLTFAnimator","animation","index","scratchMatrix","ATTRIBUTE_TYPE_TO_COMPONENTS","ATTRIBUTE_COMPONENT_TYPE_TO_ARRAY","accessorToTypedArray","accessor","ArrayType","buffer","parseGLTFAnimations","samplers","accessorToJsArray","channels","slicedArray","deepCopy","key","createScenegraphsFromGLTF","scenes","animations","animator","condition","message","COMPONENTS","BYTES","MIPMAP_FACTOR","TYPES","ARRAY_CONSTRUCTOR_TO_WEBGL_CONSTANT","ARRAY_TO_COMPONENT_TYPE","ATTRIBUTE_COMPONENT_TYPE_TO_BYTE_SIZE","getAccessorTypeFromSize","getComponentTypeFromArray","typedArray","componentType","getAccessorArrayTypeAndLength","bufferView","bytesPerComponent","componentByteSize","numberOfComponentsInElement","getMemoryUsageGLTF","bufferViews","imageBufferViews","bufferMemory","acc","pixelCount","getTypedArrayForBufferView","json","buffers","bufferViewIndex","bufferIndex","binChunk","getTypedArrayForAccessor","gltfAccessor","bufferByteOffset","elementByteSize","elementAddressScale","values","makeDefaultGLTFJson","GLTFScenegraph","extensionName","isUsedExtension","isRequiredExtension","isExtension","extensions","_getTypedArrayForAccessor","extensionsRemoved","extensionData","ext","sceneIndex","scene","nodeIndices","meshIndex","nodeData","indices","glTFMesh","indicesAccessor","imageData","mimeTypeOpt","getBinaryImageMetadata","glTFImage","glTFBufferView","glTFAccessor","sourceBuffer","minMax","accessorDefaults","glTFTexture","pbrMaterialInfo","totalByteLength","targetArray","dstByteOffset","found","attributeKey","attributeData","attrName","initValues","componentIndex","emod","n","getArrayElementByteSize","attributeType","getOffsetsForProperty","scenegraph","offsetType","numberOfElements","arrayOffsetsBytes","arrayOffsets","convertRawBufferToMetadataArray","elementCount","numberOfComponents","offset","getPrimitiveTextureData","textureInfo","primitive","texCoordAccessorKey","texCoordAccessorIndex","textureCoordinates","textureIndex","parsedImage","textureData","getImageValueByCoordinates","primitivePropertyDataToAttributes","propertyData","featureTable","featureIndices","texelData","item","accessorIndex","CHANNELS_MAP","u","coordinatesToOffset","map","imageOffset","getImageData","imageValue","componentsCount","iX","indX","h","iY","indY","parseVariableLengthArrayNumeric","valuesData","valuesDataBytesLength","valueSize","attributeValueArray","arrayOffset","arrayByteSize","typedArrayOffset","parseFixedLengthArrayNumeric","arrayCount","elementOffset","getPropertyDataString","valuesDataBytes","stringOffsets","stringsArray","textDecoder","stringOffset","stringByteSize","stringData","stringAttribute","EXT_MESH_FEATURES_NAME","decode","gltfData","decodeExtMeshFeatures","encode","encodeExtMeshFeatures","processMeshPrimitiveFeatures","featureIds","featureId","featureIdData","accessorKey","meshes","encodeExtMeshFeaturesForPrimitive","createExtMeshFeatures","featureIdArray","propertyTableIndex","elementIndex","createAccessorKey","attrs","EXT_STRUCTURAL_METADATA_NAME","decodeExtStructuralMetadata","encodeExtStructuralMetadata","decodePropertyTextures","decodePropertyTables","propertyTextures","processPrimitivePropertyTextures","schema","schemaClasses","propertyTables","schemaName","propertyTable","findPropertyTableByClass","processPropertyTable","schemaClassName","primitivePropertyTextureIndices","primitivePropertyTextureIndex","propertyTexture","processPrimitivePropertyTexture","className","propertyName","textureInfoTopLevel","featureTextureTable","schemaClass","classProperty","propertyTableProperty","getPropertyDataFromBinarySource","valuesBufferView","getArrayOffsetsForProperty","getStringOffsetsForProperty","getPropertyDataNumeric","getPropertyDataENUM","elementSize","enumType","enumEntry","enumValueType","parseVariableLengthArrayENUM","parseFixedLengthArrayENUM","getEnumsArray","count","enumObject","getEnumByValue","enumValue","SCHEMA_CLASS_ID_DEFAULT","table","classId","encodeProperties","tableProperty","createPropertyTableProperty","createExtStructuralMetadata","propertyAttributes","createSchema","createPropertyTable","schemaToUpdate","prop","createPropertyDataString","createBufferView","createPropertyDataScalar","COMPONENT_TYPE_TO_ARRAY_CONSTRUCTOR","numberArray","Construct","strings","utf8Encode","arr","str","uint8Array","strArray","strOffsets","stringOffsetsTypedArray","EXT_FEATURE_METADATA_NAME","decodeExtFeatureMetadata","featureTextures","featureTexture","findFeatureTextureByClass","handleFeatureTextureProperties","propertyTableName","featureTexturesName","featureTextureProperty","getPropertyDataFromTexture","numberOfFeatures","featureTableProperty","dataArray","isNumericProperty","schemaProperty","types","processPrimitiveTextures","LITTLE_ENDIAN","MAGIC_glTF","GLB_FILE_HEADER_SIZE","GLB_CHUNK_HEADER_SIZE","GLB_CHUNK_TYPE_JSON","GLB_CHUNK_TYPE_BIN","GLB_V1_CONTENT_FORMAT_JSON","GLB_CHUNK_TYPE_JSON_XVIZ_DEPRECATED","GLB_CHUNK_TYPE_BIX_XVIZ_DEPRECATED","isGLB","magic1","parseGLBSync","glb","version","parseGLBV1","parseGLBV2","contentLength","contentFormat","parseJSONChunk","parseBINChunk","parseGLBChunksSync","chunkLength","chunkFormat","jsonChunk","jsonText","resolveUrl","baseUrl","wasm_base","wasm_simd","detector","wasmpack","FILTERS","DECODERS","meshoptDecodeGltfBuffer","filter","instance","loadWasmInstance","wasmPromise","loadWasmModule","wasm","unpack","ch","write","fun","sbrk","count4","tp","heap","res","EXT_MESHOPT_COMPRESSION","promises","decodeMeshoptBufferView","meshoptExtension","byteStride","EXT_TEXTURE_WEBP","preprocess","KHR_TEXTURE_BASISU","DracoLoader","getDracoSchema","loaderData","makeMetadata","fields","namedLoaderDataAttributes","transformAttributesLoaderData","field","getArrowFieldFromAttribute","indicesField","dracoAttribute","metadataMap","serializedMetadata","DRACO_TO_GLTF_ATTRIBUTE_NAME_MAP","DRACO_DATA_TYPE_TO_TYPED_ARRAY_MAP","INDEX_ITEM_SIZE","DracoParser","draco","geometry_type","dracoGeometry","dracoStatus","boundingBox","dracoAttributes","attributeId","quantization","octahedron","loaderAttribute","numIndices","ptr","dracoArray","getUint32Array","TypedArrayCtor","numComponents","numValues","dataType","getDracoDataType","uniqueId","attributeUniqueId","thisAttributeType","dracoAttributeConstant","entryName","dracoMetadata","numEntries","entryIndex","intArray","getInt32Array","quantizedAttributes","octahedronAttributes","skipAttributes","dracoAttributeName","attribute_type","transform","DRACO_DECODER_VERSION","DRACO_ENCODER_VERSION","STATIC_DECODER_URL","DRACO_EXTERNAL_LIBRARIES","DRACO_EXTERNAL_LIBRARY_URLS","loadDecoderPromise","loadDracoDecoderModule","loadDracoDecoder","DracoDecoderModule","initializeDracoDecoder","DracoWorkerLoader","parse","dracoParser","getGLTFAccessors","accessors","getGLTFAccessor","getAccessorData","toTypedArray","convertTypedArrays","KHR_DRACO_MESH_COMPRESSION","makeMeshPrimitiveIterator","decompressPrimitive","compressMesh","dracoExtension","bufferCopy","sliceArrayBuffer","dracoOptions","decodedAttributes","decodedAttribute","checkPrimitive","compressedData","fauxAccessors","KHR_TEXTURE_TRANSFORM","scratchVector","scratchRotationMatrix","scratchScaleMatrix","materials","transformTexCoords","materialIndex","materialTextures","processedTexCoords","transformPrimitives","transformParameters","getTransformParameters","transformPrimitive","originalTexCoord","texCoord","original","newTexCoord","makeTransformationMatrix","texCoordAccessor","bytes","uv","updateGltf","createAttribute","newTexCoordArray","originalAccessor","translationMatrix","scaleMatrix","KHR_LIGHTS_PUNCTUAL","gltfScenegraph","nodeExtension","light","KHR_MATERIALS_UNLIT","KHR_TECHNIQUES_WEBGL","techniques","resolveTechniques","materialExtension","resolveValues","techniquesExtension","programs","shaders","shader","program","technique","uniform","EXTENSIONS","EXT_structural_metadata","EXT_mesh_features","EXT_meshopt_compression","EXT_texture_webp","KHR_texture_basisu","KHR_draco_mesh_compression","KHR_lights_punctual","KHR_materials_unlit","KHR_techniques_webgl","KHR_texture_transform","EXT_feature_metadata","preprocessExtensions","useExtension","decodeExtensions","excludes","KHR_BINARY_GLTF","GLTF_ARRAYS","GLTF_KEYS","GLTFV1Normalizer","KHR_binary_glTF.preprocess","arrayName","mapName","objectMap","topLevelArrayName","textureId","normalizeGLTFV1","arrayBufferOrString","parseGLTFContainerSync","loadBuffers","loadImages","binChunks","fetch","uri","imageIndices","getReferencesImageIndices","loadImage","textures","ImageLoader","GLTFLoader","GL_SAMPLER","SAMPLER_PARAMETER_GLTF_TO_GL","DEFAULT_SAMPLER_PARAMETERS","makeDefaultSampler","getBytesFromComponentType","getSizeFromAccessorType","GLTFPostProcessor","baseUri","bufView","skin","accum","gltfSkin","inverseBindMatrices","gltfMaterial","mr","bytesPerElement","cutBuffer","glEnum","gltfImage","preloadedImage","gltfBufferView","gltfCamera","postProcessGLTF","waitForGLTFAssets","gltfObjects","remaining","waitWhileCondition","scenegraphUniforms","ScenegraphLayer","defines","pbr","scenegraphData","processedGLTF","ex","models","animationsProp","number","findResult","_imageBasedLightingEnvironment","env","sizeMinPixels","sizeMaxPixels","pbrProjectionProps","numInstances","scenegraphProps"],"mappings":"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AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EC4BhBvO,GAAoB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;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","x_google_ignoreList":[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29,30,31,32,33,34,35,36,37,38,39,40,41,42,43,44,45,46,47,48,49,50,51,52,53,54,55,56,57,58,59,60,61,62,63,64,65,66,67,68,69,70,71,72,73,74,75,76,77,78,79,80,81,82,83]}
|