From 15a2d6014d38b5c939eafc01d13c64f69046f8a3 Mon Sep 17 00:00:00 2001 From: webseon Date: Tue, 10 Feb 2026 14:00:20 +0900 Subject: [PATCH 1/4] - --- testCase/README.md | 1 + 1 file changed, 1 insertion(+) create mode 100644 testCase/README.md diff --git a/testCase/README.md b/testCase/README.md new file mode 100644 index 000000000..9862a689d --- /dev/null +++ b/testCase/README.md @@ -0,0 +1 @@ +TestCase is currently under construction. \ No newline at end of file From 2e84a44a48b0bf46d8af90ce561d85dabefdea12 Mon Sep 17 00:00:00 2001 From: "github-actions[bot]" Date: Tue, 10 Feb 2026 05:01:02 +0000 Subject: [PATCH 2/4] chore: update build and examples --- examples/2d/blendMode/basic/index.html | 4 +-- examples/2d/blendMode/basic/index.js | 6 ++--- examples/2d/group2D/basic/index.html | 4 +-- examples/2d/group2D/basic/index.js | 6 ++--- examples/2d/helloWorld2D/index.html | 4 +-- examples/2d/helloWorld2D/index.js | 8 +++--- .../2d/interaction/keyboardEvent/index.html | 4 +-- .../2d/interaction/keyboardEvent/index.js | 6 ++--- .../mouseEvent/sprite2D/index.html | 6 ++--- .../interaction/mouseEvent/sprite2D/index.js | 6 ++--- .../mouseEvent/spriteSheet2D/index.html | 6 ++--- .../mouseEvent/spriteSheet2D/index.js | 6 ++--- .../mouseEvent/textField2D/index.html | 6 ++--- .../mouseEvent/textField2D/index.js | 6 ++--- examples/2d/line2D/linear/index.html | 4 +-- examples/2d/line2D/linear/index.js | 4 +-- examples/2d/opacity/basic/index.html | 4 +-- examples/2d/opacity/basic/index.js | 6 ++--- examples/2d/sprite2D/basic/index.html | 4 +-- examples/2d/sprite2D/basic/index.js | 6 ++--- examples/2d/sprite2D/childMethod/index.html | 4 +-- examples/2d/sprite2D/childMethod/index.js | 6 ++--- examples/2d/sprite2D/hierarchy/index.html | 4 +-- examples/2d/sprite2D/hierarchy/index.js | 6 ++--- examples/2d/sprite2D/pivot/index.html | 4 +-- examples/2d/sprite2D/pivot/index.js | 6 ++--- examples/2d/spriteSheet2D/basic/index.html | 4 +-- examples/2d/spriteSheet2D/basic/index.js | 6 ++--- examples/2d/textField2D/basic/index.html | 4 +-- examples/2d/textField2D/basic/index.js | 6 ++--- examples/2d/tint/2dObjectTint/index.html | 4 +-- examples/2d/tint/2dObjectTint/index.js | 6 ++--- examples/2d/tint/basic/index.html | 4 +-- examples/2d/tint/basic/index.js | 6 ++--- examples/2d/view/multiView/index.html | 4 +-- examples/2d/view/multiView/index.js | 6 ++--- examples/2d/view/multiViewWith3D/index.html | 4 +-- examples/2d/view/multiViewWith3D/index.js | 6 ++--- .../3d/controller/followController/index.html | 4 +-- .../3d/controller/followController/index.js | 6 ++--- .../3d/controller/freeController/index.html | 4 +-- .../3d/controller/freeController/index.js | 6 ++--- .../controller/isometricController/index.html | 4 +-- .../controller/isometricController/index.js | 6 ++--- .../3d/controller/orbitController/index.html | 4 +-- .../3d/controller/orbitController/index.js | 6 ++--- .../screenToWorld/index.html | 4 +-- .../screenToWorld/index.js | 4 +-- .../worldToLocal/index.html | 4 +-- .../worldToLocal/index.js | 4 +-- examples/3d/drawDebugger/basic/index.html | 4 +-- examples/3d/drawDebugger/basic/index.js | 6 ++--- .../frustumCulling/distanceCulling/index.html | 4 +-- .../frustumCulling/distanceCulling/index.js | 6 ++--- .../frustumCulling/frustumCulling/index.html | 4 +-- .../3d/frustumCulling/frustumCulling/index.js | 6 ++--- examples/3d/group3D/basic/index.html | 4 +-- examples/3d/group3D/basic/index.js | 6 ++--- examples/3d/helloWorld/index.html | 4 +-- examples/3d/helloWorld/index.js | 6 ++--- examples/3d/indirectDrawTest/index.html | 4 +-- examples/3d/indirectDrawTest/index.js | 6 ++--- examples/3d/instancedMesh/simple/index.html | 4 +-- examples/3d/instancedMesh/simple/index.js | 6 ++--- examples/3d/instancedMesh/sphere/index.html | 4 +-- examples/3d/instancedMesh/sphere/index.js | 6 ++--- .../3d/interaction/keyboardEvent/index.html | 4 +-- .../3d/interaction/keyboardEvent/index.js | 6 ++--- .../3d/interaction/mouseEvent/mesh/index.html | 6 ++--- .../3d/interaction/mouseEvent/mesh/index.js | 4 +-- .../mouseEvent/raycasting/index.html | 6 ++--- .../mouseEvent/raycasting/index.js | 6 ++--- .../mouseEvent/sprite3D/index.html | 6 ++--- .../interaction/mouseEvent/sprite3D/index.js | 6 ++--- .../mouseEvent/spriteSheet3D/index.html | 6 ++--- .../mouseEvent/spriteSheet3D/index.js | 6 ++--- .../mouseEvent/textField3D/index.html | 6 ++--- .../mouseEvent/textField3D/index.js | 6 ++--- examples/3d/light/directionalLight/index.html | 4 +-- examples/3d/light/directionalLight/index.js | 6 ++--- examples/3d/light/pointLight/index.html | 4 +-- examples/3d/light/pointLight/index.js | 6 ++--- .../3d/light/pointLightPerformance/index.html | 4 +-- .../3d/light/pointLightPerformance/index.js | 4 +-- examples/3d/light/spotLight/index.html | 4 +-- examples/3d/light/spotLight/index.js | 6 ++--- .../3d/light/spotLightPerformance/index.html | 4 +-- .../3d/light/spotLightPerformance/index.js | 4 +-- examples/3d/line3D/bezier/index.html | 4 +-- examples/3d/line3D/bezier/index.js | 6 ++--- examples/3d/line3D/catmullRom/index.html | 4 +-- examples/3d/line3D/catmullRom/index.js | 6 ++--- examples/3d/line3D/linear/index.html | 4 +-- examples/3d/line3D/linear/index.js | 6 ++--- examples/3d/lod/InstanceMeshGPULOD/index.html | 4 +-- examples/3d/lod/InstanceMeshGPULOD/index.js | 6 ++--- .../InstanceMeshGPULOD_material/index.html | 4 +-- .../lod/InstanceMeshGPULOD_material/index.js | 6 ++--- examples/3d/lod/MeshCPULOD/index.html | 4 +-- examples/3d/lod/MeshCPULOD/index.js | 6 ++--- .../3d/lod/MeshCPULOD_material/index.html | 4 +-- examples/3d/lod/MeshCPULOD_material/index.js | 6 ++--- .../3d/material/bitmapMaterial/index.html | 4 +-- examples/3d/material/bitmapMaterial/index.js | 6 ++--- examples/3d/material/colorMaterial/index.html | 4 +-- examples/3d/material/colorMaterial/index.js | 6 ++--- .../material/fragmentVariantTest/index.html | 4 +-- .../3d/material/fragmentVariantTest/index.js | 6 ++--- examples/3d/material/opacity/index.html | 4 +-- examples/3d/material/opacity/index.js | 6 ++--- examples/3d/material/phongMaterial/index.html | 4 +-- examples/3d/material/phongMaterial/index.js | 6 ++--- .../material/phongMaterialTextures/index.html | 4 +-- .../material/phongMaterialTextures/index.js | 4 +-- examples/3d/material/uvTransform/index.html | 4 +-- examples/3d/material/uvTransform/index.js | 6 ++--- examples/3d/mesh/basicMesh/index.html | 4 +-- examples/3d/mesh/basicMesh/index.js | 6 ++--- .../boundBox/meshAABBIntersects/index.html | 4 +-- .../mesh/boundBox/meshAABBIntersects/index.js | 4 +-- .../3d/mesh/boundBox/meshBoundBox/index.html | 4 +-- .../3d/mesh/boundBox/meshBoundBox/index.js | 4 +-- .../boundBox/meshOBBIntersects/index.html | 4 +-- .../mesh/boundBox/meshOBBIntersects/index.js | 4 +-- examples/3d/mesh/childMethod/index.html | 4 +-- examples/3d/mesh/childMethod/index.js | 6 ++--- examples/3d/mesh/hierarchy/index.html | 4 +-- examples/3d/mesh/hierarchy/index.js | 6 ++--- examples/3d/mesh/lookAt/index.html | 4 +-- examples/3d/mesh/lookAt/index.js | 4 +-- examples/3d/mesh/pivot/index.html | 4 +-- examples/3d/mesh/pivot/index.js | 6 ++--- .../3d/noiseTexture/simplex/basic/index.html | 4 +-- .../3d/noiseTexture/simplex/basic/index.js | 6 ++--- .../simplex/displacement/index.html | 4 +-- .../simplex/displacement/index.js | 6 ++--- .../3d/noiseTexture/simplex/fire/index.html | 4 +-- .../3d/noiseTexture/simplex/fire/index.js | 6 ++--- .../3d/noiseTexture/voronoi/basic/index.html | 4 +-- .../3d/noiseTexture/voronoi/basic/index.js | 6 ++--- examples/3d/particle/basic/index.html | 4 +-- examples/3d/particle/basic/index.js | 8 +++--- examples/3d/particle/performance/index.html | 4 +-- examples/3d/particle/performance/index.js | 4 +-- examples/3d/primitive/box/index.html | 4 +-- examples/3d/primitive/box/index.js | 6 ++--- examples/3d/primitive/capsule/index.html | 4 +-- examples/3d/primitive/capsule/index.js | 6 ++--- examples/3d/primitive/circle/index.html | 4 +-- examples/3d/primitive/circle/index.js | 6 ++--- examples/3d/primitive/cylinder/index.html | 4 +-- examples/3d/primitive/cylinder/index.js | 6 ++--- examples/3d/primitive/ground/index.html | 4 +-- examples/3d/primitive/ground/index.js | 6 ++--- examples/3d/primitive/plane/index.html | 4 +-- examples/3d/primitive/plane/index.js | 6 ++--- examples/3d/primitive/primitives/index.html | 4 +-- examples/3d/primitive/primitives/index.js | 4 +-- examples/3d/primitive/sphere/index.html | 4 +-- examples/3d/primitive/sphere/index.js | 6 ++--- examples/3d/primitive/torus/index.html | 4 +-- examples/3d/primitive/torus/index.js | 6 ++--- examples/3d/primitive/torusNut/index.html | 4 +-- examples/3d/primitive/torusNut/index.js | 6 ++--- examples/3d/scene/index.html | 4 +-- examples/3d/scene/index.js | 6 ++--- .../3d/shadow/directionalShadow/index.html | 4 +-- examples/3d/shadow/directionalShadow/index.js | 6 ++--- .../shadow/gltfDirectionalShadow/index.html | 4 +-- .../3d/shadow/gltfDirectionalShadow/index.js | 8 +++--- examples/3d/skybox/ibl/brdfLutTest/index.html | 4 +-- examples/3d/skybox/ibl/brdfLutTest/index.js | 2 +- examples/3d/skybox/ibl/iblTest/index.html | 4 +-- examples/3d/skybox/ibl/iblTest/index.js | 6 ++--- .../3d/skybox/ibl/iblTextureSize/index.html | 4 +-- .../3d/skybox/ibl/iblTextureSize/index.js | 8 +++--- .../3d/skybox/ibl/irradianceTest/index.html | 4 +-- .../3d/skybox/ibl/irradianceTest/index.js | 4 +-- .../3d/skybox/ibl/skyboxWithIbl/index.html | 4 +-- examples/3d/skybox/ibl/skyboxWithIbl/index.js | 6 ++--- examples/3d/skybox/skybox/index.html | 4 +-- examples/3d/skybox/skybox/index.js | 6 ++--- .../transition/skyboxTransition/index.html | 4 +-- .../transition/skyboxTransition/index.js | 6 ++--- .../index.html | 4 +-- .../skyboxTransitionWithNoiseTexture/index.js | 6 ++--- examples/3d/sprite/sprite3D/index.html | 4 +-- examples/3d/sprite/sprite3D/index.js | 6 ++--- examples/3d/sprite/sprite3DCompare/index.html | 4 +-- examples/3d/sprite/sprite3DCompare/index.js | 6 ++--- examples/3d/sprite/spriteSheet3D/index.html | 4 +-- examples/3d/sprite/spriteSheet3D/index.js | 6 ++--- .../3d/sprite/spriteSheet3DCompare/index.html | 4 +-- .../3d/sprite/spriteSheet3DCompare/index.js | 6 ++--- examples/3d/textField/textField3D/index.html | 4 +-- examples/3d/textField/textField3D/index.js | 6 ++--- .../textField/textField3DCompare/index.html | 4 +-- .../3d/textField/textField3DCompare/index.js | 6 ++--- .../texture/bitmapTextureSampler/index.html | 4 +-- .../3d/texture/bitmapTextureSampler/index.js | 6 ++--- examples/3d/texture/maxAnisotropy/index.html | 4 +-- examples/3d/texture/maxAnisotropy/index.js | 4 +-- .../3d/texture/samplerAddressMode/index.html | 4 +-- .../3d/texture/samplerAddressMode/index.js | 4 +-- .../3d/texture/samplerCombination/index.html | 4 +-- .../3d/texture/samplerCombination/index.js | 4 +-- examples/3d/tint/basic/index.html | 4 +-- examples/3d/tint/basic/index.js | 6 ++--- examples/3d/transparentSort/index.html | 4 +-- examples/3d/transparentSort/index.js | 6 ++--- examples/3d/view/multiView/index.html | 4 +-- examples/3d/view/multiView/index.js | 6 ++--- examples/3d/view/singleView/index.html | 4 +-- examples/3d/view/singleView/index.js | 6 ++--- .../createExample/loadExampleInfo/index.js | 6 ++--- .../createExample/panes/createIblHelper.js | 4 +-- .../createExample/panes/index.js | 26 +++++++++---------- .../panes/scene/setSceneListTest.js | 2 +- .../panes/view/setSingleViewTest.js | 2 +- .../panes/view/setViewListTest.js | 2 +- .../exampleList/createExampleList.js | 2 +- examples/exampleHelper/indexSample.html | 2 +- .../gltf/animation/basicAnimations/index.html | 4 +-- .../gltf/animation/basicAnimations/index.js | 8 +++--- examples/gltf/animation/brainStem/index.html | 4 +-- examples/gltf/animation/brainStem/index.js | 6 ++--- examples/gltf/animation/cesiumMan/index.html | 4 +-- examples/gltf/animation/cesiumMan/index.js | 8 +++--- .../animation/interpolationTest/index.html | 4 +-- .../gltf/animation/interpolationTest/index.js | 6 ++--- .../gltf/animation/morphStressTest/index.html | 4 +-- .../gltf/animation/morphStressTest/index.js | 6 ++--- .../performance/highMorphTarget/index.html | 4 +-- .../performance/highMorphTarget/index.js | 8 +++--- .../highVertexLoadSkinning/index.html | 4 +-- .../highVertexLoadSkinning/index.js | 8 +++--- .../performance/mediumLoadSkinning/index.html | 4 +-- .../performance/mediumLoadSkinning/index.js | 8 +++--- .../animation/recursiveSkeletons/index.html | 4 +-- .../animation/recursiveSkeletons/index.js | 6 ++--- .../gltf/animation/riggedFigure/index.html | 4 +-- examples/gltf/animation/riggedFigure/index.js | 6 ++--- .../gltf/animation/riggedSimple/index.html | 4 +-- examples/gltf/animation/riggedSimple/index.js | 6 ++--- .../gltf/animation/simpleMorph/index.html | 4 +-- examples/gltf/animation/simpleMorph/index.js | 6 ++--- examples/gltf/animation/simpleSkin/index.html | 4 +-- examples/gltf/animation/simpleSkin/index.js | 6 ++--- .../gltf/basic/alphaBlendModeTest/index.html | 4 +-- .../gltf/basic/alphaBlendModeTest/index.js | 8 +++--- .../gltf/basic/boxVertexColors/index.html | 4 +-- examples/gltf/basic/boxVertexColors/index.js | 8 +++--- .../basic/compareAlphaCoverage/index.html | 4 +-- .../gltf/basic/compareAlphaCoverage/index.js | 8 +++--- .../basic/compareAmbientOcclusion/index.html | 4 +-- .../basic/compareAmbientOcclusion/index.js | 8 +++--- .../gltf/basic/compareBaseColor/index.html | 4 +-- examples/gltf/basic/compareBaseColor/index.js | 8 +++--- .../gltf/basic/compareMetallic/index.html | 4 +-- examples/gltf/basic/compareMetallic/index.js | 8 +++--- examples/gltf/basic/compareNormal/index.html | 4 +-- examples/gltf/basic/compareNormal/index.js | 8 +++--- .../gltf/basic/compareRoughness/index.html | 4 +-- examples/gltf/basic/compareRoughness/index.js | 8 +++--- .../gltf/basic/environmentTest/index.html | 4 +-- examples/gltf/basic/environmentTest/index.js | 8 +++--- .../gltf/basic/generateNormalTest/index.html | 4 +-- .../gltf/basic/generateNormalTest/index.js | 8 +++--- .../gltf/basic/metalRoughSpheres/index.html | 4 +-- .../gltf/basic/metalRoughSpheres/index.js | 8 +++--- .../metalRoughSpheresNoTextures/index.html | 4 +-- .../metalRoughSpheresNoTextures/index.js | 8 +++--- examples/gltf/basic/multiUVTest/index.html | 4 +-- examples/gltf/basic/multiUVTest/index.js | 8 +++--- .../gltf/basic/negativeScaleTest/index.html | 4 +-- .../gltf/basic/negativeScaleTest/index.js | 8 +++--- .../basic/normalTangentMirrorTest/index.html | 4 +-- .../basic/normalTangentMirrorTest/index.js | 8 +++--- .../gltf/basic/normalTangentTest/index.html | 4 +-- .../gltf/basic/normalTangentTest/index.js | 8 +++--- .../gltf/basic/orientationTest/index.html | 4 +-- examples/gltf/basic/orientationTest/index.js | 8 +++--- .../basic/textureCoordinateTest/index.html | 4 +-- .../gltf/basic/textureCoordinateTest/index.js | 8 +++--- .../gltf/basic/textureEncodingTest/index.html | 4 +-- .../gltf/basic/textureEncodingTest/index.js | 8 +++--- .../textureLinearInterpolationTest/index.html | 4 +-- .../textureLinearInterpolationTest/index.js | 8 +++--- .../gltf/basic/textureSettingsTest/index.html | 4 +-- .../gltf/basic/textureSettingsTest/index.js | 8 +++--- .../gltf/basic/vertexColorTest/index.html | 4 +-- examples/gltf/basic/vertexColorTest/index.js | 8 +++--- examples/gltf/basic/waterBottle/index.html | 4 +-- examples/gltf/basic/waterBottle/index.js | 8 +++--- .../anisotropy/anisotropyBarnLamp/index.html | 4 +-- .../anisotropy/anisotropyBarnLamp/index.js | 8 +++--- .../anisotropy/anisotropyDiscTest/index.html | 4 +-- .../anisotropy/anisotropyDiscTest/index.js | 6 ++--- .../anisotropyRotationTest/index.html | 4 +-- .../anisotropyRotationTest/index.js | 6 ++--- .../anisotropyStrengthTest/index.html | 4 +-- .../anisotropyStrengthTest/index.js | 6 ++--- .../anisotropy/compareAnisotropy/index.html | 4 +-- .../anisotropy/compareAnisotropy/index.js | 8 +++--- .../clearcoat/clearCoatCarPaint/index.html | 4 +-- .../clearcoat/clearCoatCarPaint/index.js | 6 ++--- .../clearcoat/clearCoatTest/index.html | 4 +-- .../clearcoat/clearCoatTest/index.js | 6 ++--- .../clearcoat/clearcoatWicker/index.html | 4 +-- .../clearcoat/clearcoatWicker/index.js | 8 +++--- .../clearcoat/compareClearcoat/index.html | 4 +-- .../clearcoat/compareClearcoat/index.js | 6 ++--- .../diffuseTransmissionTeacup/index.html | 4 +-- .../diffuseTransmissionTeacup/index.js | 8 +++--- .../diffuseTransmissionTest/index.html | 4 +-- .../diffuseTransmissionTest/index.js | 6 ++--- .../dispersion/compareDispersion/index.html | 4 +-- .../dispersion/compareDispersion/index.js | 6 ++--- .../dispersion/dispersionTest/index.html | 4 +-- .../dispersion/dispersionTest/index.js | 8 +++--- .../dispersion/dragonDispersion/index.html | 4 +-- .../dispersion/dragonDispersion/index.js | 8 +++--- .../compareEmissiveStrength/index.html | 4 +-- .../compareEmissiveStrength/index.js | 6 ++--- .../emissiveStrengthTest/index.html | 4 +-- .../emissiveStrengthTest/index.js | 6 ++--- .../iridescence/compareIridescence/index.html | 4 +-- .../iridescence/compareIridescence/index.js | 6 ++--- .../iridescenceDielectricSpheres/index.html | 4 +-- .../iridescenceDielectricSpheres/index.js | 6 ++--- .../iridescence/iridescenceLamp/index.html | 4 +-- .../iridescence/iridescenceLamp/index.js | 8 +++--- .../iridescenceMetallicSpheres/index.html | 4 +-- .../iridescenceMetallicSpheres/index.js | 6 ++--- .../iridescence/iridescenceSuzanne/index.html | 4 +-- .../iridescence/iridescenceSuzanne/index.js | 6 ++--- .../iridescentDishWithOlives/index.html | 4 +-- .../iridescentDishWithOlives/index.js | 8 +++--- .../iridescence/sunglassesKhronos/index.html | 4 +-- .../iridescence/sunglassesKhronos/index.js | 6 ++--- .../sheen/chairDamaskPurplegold/index.html | 4 +-- .../sheen/chairDamaskPurplegold/index.js | 8 +++--- .../sheen/compareSheen/index.html | 4 +-- .../sheen/compareSheen/index.js | 6 ++--- .../sheen/glamVelvetSofa/index.html | 4 +-- .../sheen/glamVelvetSofa/index.js | 8 +++--- .../sheen/sheenChair/index.html | 4 +-- .../gltfExtensions/sheen/sheenChair/index.js | 8 +++--- .../sheen/sheenCloth/index.html | 4 +-- .../gltfExtensions/sheen/sheenCloth/index.js | 8 +++--- .../sheen/sheenTestGrid/index.html | 4 +-- .../sheen/sheenTestGrid/index.js | 8 +++--- .../sheen/sheenWoodLeatherSofa/index.html | 4 +-- .../sheen/sheenWoodLeatherSofa/index.js | 8 +++--- .../specular/compareSpecular/index.html | 4 +-- .../specular/compareSpecular/index.js | 8 +++--- .../specular/specularSilkPouf/index.html | 4 +-- .../specular/specularSilkPouf/index.js | 8 +++--- .../specular/specularTest/index.html | 4 +-- .../specular/specularTest/index.js | 6 ++--- .../textureTransformMultiTest/index.html | 4 +-- .../textureTransformMultiTest/index.js | 6 ++--- .../textureTransformTest/index.html | 4 +-- .../textureTransformTest/index.js | 6 ++--- .../transmission/chronographWatch/index.html | 4 +-- .../transmission/chronographWatch/index.js | 8 +++--- .../commercialRefrigerator/index.html | 4 +-- .../commercialRefrigerator/index.js | 8 +++--- .../compareTransmission/index.html | 4 +-- .../transmission/compareTransmission/index.js | 6 ++--- .../transmission/mosquitoInAmber/index.html | 4 +-- .../transmission/mosquitoInAmber/index.js | 8 +++--- .../transmission/stainedGlassLamp/index.html | 4 +-- .../transmission/stainedGlassLamp/index.js | 6 ++--- .../transmissionRoughnessTest/index.html | 4 +-- .../transmissionRoughnessTest/index.js | 6 ++--- .../transmission/transmissionTest/index.html | 4 +-- .../transmission/transmissionTest/index.js | 8 +++--- .../gltfExtensions/unlit/unlitTest/index.html | 4 +-- .../gltfExtensions/unlit/unlitTest/index.js | 6 ++--- .../volume/IORTestGrid/index.html | 4 +-- .../volume/IORTestGrid/index.js | 8 +++--- .../volume/attenuationTest/index.html | 4 +-- .../volume/attenuationTest/index.js | 6 ++--- .../volume/compareIor/index.html | 4 +-- .../gltfExtensions/volume/compareIor/index.js | 6 ++--- .../volume/compareVolume/index.html | 4 +-- .../volume/compareVolume/index.js | 6 ++--- .../volume/dragonAttenuation/index.html | 4 +-- .../volume/dragonAttenuation/index.js | 8 +++--- .../volume/glassBrokenWindow/index.html | 4 +-- .../volume/glassBrokenWindow/index.js | 8 +++--- .../glassHurricaneCandleHolder/index.html | 4 +-- .../glassHurricaneCandleHolder/index.js | 8 +++--- .../volume/glassVaseFlowers/index.html | 4 +-- .../volume/glassVaseFlowers/index.js | 8 +++--- .../transmissionThinwallTestGrid/index.html | 4 +-- .../transmissionThinwallTestGrid/index.js | 8 +++--- .../gltf/models/aBeautifulGame/index.html | 4 +-- examples/gltf/models/aBeautifulGame/index.js | 8 +++--- examples/gltf/models/corset/index.html | 4 +-- examples/gltf/models/corset/index.js | 8 +++--- examples/gltf/models/helmets/index.html | 4 +-- examples/gltf/models/helmets/index.js | 8 +++--- examples/gltf/models/sponza/index.html | 4 +-- examples/gltf/models/sponza/index.js | 8 +++--- .../gltf/models/texcooredNTest/index.html | 4 +-- examples/gltf/models/texcooredNTest/index.js | 8 +++--- examples/gltf/models/tokyo/index.html | 4 +-- examples/gltf/models/tokyo/index.js | 8 +++--- examples/index.html | 4 +-- examples/index.js | 2 +- .../advancedCharacterController/index.html | 4 +-- .../advancedCharacterController/index.js | 8 +++--- examples/physics/basic/index.html | 4 +-- examples/physics/basic/index.js | 8 +++--- examples/physics/bowling/index.html | 4 +-- examples/physics/bowling/index.js | 8 +++--- examples/physics/buoyancy/index.html | 4 +-- examples/physics/buoyancy/index.js | 8 +++--- .../physics/characterController/index.html | 4 +-- examples/physics/characterController/index.js | 8 +++--- examples/physics/collisionEvents/index.html | 4 +-- examples/physics/collisionEvents/index.js | 8 +++--- .../physics/collisionFiltering/index.html | 4 +-- examples/physics/collisionFiltering/index.js | 8 +++--- examples/physics/compound/index.html | 4 +-- examples/physics/compound/index.js | 8 +++--- examples/physics/explosion/index.html | 4 +-- examples/physics/explosion/index.js | 8 +++--- examples/physics/galton/index.html | 4 +-- examples/physics/galton/index.js | 8 +++--- examples/physics/gltfPhysics/index.html | 4 +-- examples/physics/gltfPhysics/index.js | 8 +++--- examples/physics/heightField/index.html | 4 +-- examples/physics/heightField/index.js | 8 +++--- examples/physics/joints/index.html | 4 +-- examples/physics/joints/index.js | 8 +++--- examples/physics/kinematic/index.html | 4 +-- examples/physics/kinematic/index.js | 8 +++--- examples/physics/meshCollider/index.html | 4 +-- examples/physics/meshCollider/index.js | 8 +++--- examples/physics/prismaticJoint/index.html | 4 +-- examples/physics/prismaticJoint/index.js | 8 +++--- examples/physics/ragdoll/index.html | 4 +-- examples/physics/ragdoll/index.js | 8 +++--- examples/physics/raycast/index.html | 4 +-- examples/physics/raycast/index.js | 8 +++--- examples/physics/revoluteJoint/index.html | 4 +-- examples/physics/revoluteJoint/index.js | 8 +++--- examples/physics/shapes/index.html | 4 +-- examples/physics/shapes/index.js | 8 +++--- examples/physics/softBody/index.html | 4 +-- examples/physics/softBody/index.js | 8 +++--- examples/physics/springJoint/index.html | 4 +-- examples/physics/springJoint/index.js | 6 ++--- examples/physics/stressTest/index.html | 4 +-- examples/physics/stressTest/index.js | 8 +++--- examples/physics/surfaceVelocity/index.html | 4 +-- examples/physics/surfaceVelocity/index.js | 8 +++--- examples/physics/triggers/index.html | 4 +-- examples/physics/triggers/index.js | 8 +++--- .../adjustments/brightnessContrast/index.html | 4 +-- .../adjustments/brightnessContrast/index.js | 8 +++--- .../adjustments/colorBalance/index.html | 4 +-- .../adjustments/colorBalance/index.js | 8 +++--- .../colorTemperatureTint/index.html | 4 +-- .../adjustments/colorTemperatureTint/index.js | 8 +++--- .../adjustments/grayscale/index.html | 4 +-- .../postEffect/adjustments/grayscale/index.js | 8 +++--- .../adjustments/hueSaturation/index.html | 4 +-- .../adjustments/hueSaturation/index.js | 8 +++--- .../postEffect/adjustments/invert/index.html | 4 +-- .../postEffect/adjustments/invert/index.js | 8 +++--- .../adjustments/threshold/index.html | 4 +-- .../postEffect/adjustments/threshold/index.js | 8 +++--- .../adjustments/vibrance/index.html | 4 +-- .../postEffect/adjustments/vibrance/index.js | 8 +++--- examples/postEffect/blur/blur/index.html | 4 +-- examples/postEffect/blur/blur/index.js | 8 +++--- examples/postEffect/blur/blurX/index.html | 4 +-- examples/postEffect/blur/blurX/index.js | 8 +++--- examples/postEffect/blur/blurY/index.html | 4 +-- examples/postEffect/blur/blurY/index.js | 8 +++--- .../blur/directionalBlur/index.html | 4 +-- .../postEffect/blur/directionalBlur/index.js | 8 +++--- .../postEffect/blur/gaussianBlur/index.html | 4 +-- .../postEffect/blur/gaussianBlur/index.js | 8 +++--- .../postEffect/blur/radialBlur/index.html | 4 +-- examples/postEffect/blur/radialBlur/index.js | 8 +++--- examples/postEffect/blur/zoomBlur/index.html | 4 +-- examples/postEffect/blur/zoomBlur/index.js | 8 +++--- examples/postEffect/convolution/index.html | 4 +-- examples/postEffect/convolution/index.js | 8 +++--- examples/postEffect/filmGrain/index.html | 4 +-- examples/postEffect/filmGrain/index.js | 8 +++--- examples/postEffect/fog/fog/index.html | 4 +-- examples/postEffect/fog/fog/index.js | 6 ++--- examples/postEffect/fog/heightFog/index.html | 4 +-- examples/postEffect/fog/heightFog/index.js | 6 ++--- .../lens/chromaticAberration/index.html | 4 +-- .../lens/chromaticAberration/index.js | 8 +++--- examples/postEffect/lens/dof/index.html | 4 +-- examples/postEffect/lens/dof/index.js | 8 +++--- .../postEffect/lens/lensDistortion/index.html | 4 +-- .../postEffect/lens/lensDistortion/index.js | 8 +++--- .../postEffect/lens/vignetting/index.html | 4 +-- examples/postEffect/lens/vignetting/index.js | 8 +++--- examples/postEffect/oldBloom/index.html | 4 +-- examples/postEffect/oldBloom/index.js | 8 +++--- examples/postEffect/sharpen/index.html | 4 +-- examples/postEffect/sharpen/index.js | 8 +++--- examples/postEffect/ssao/index.html | 4 +-- examples/postEffect/ssao/index.js | 6 ++--- examples/postEffect/ssr/index.html | 4 +-- examples/postEffect/ssr/index.js | 6 ++--- 516 files changed, 1391 insertions(+), 1391 deletions(-) diff --git a/examples/2d/blendMode/basic/index.html b/examples/2d/blendMode/basic/index.html index b4417a88f..77d781697 100644 --- a/examples/2d/blendMode/basic/index.html +++ b/examples/2d/blendMode/basic/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/2d/blendMode/basic/index.js b/examples/2d/blendMode/basic/index.js index 7365dd942..9bac8fe1b 100644 --- a/examples/2d/blendMode/basic/index.js +++ b/examples/2d/blendMode/basic/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; /** * [KO] Blend Mode 예제 @@ -208,11 +208,11 @@ function createSourceView(redGPUContext, scene, texture_blendTest_base, texture_ * @param {RedGPU.Display.Sprite2D} shape */ const renderTestPane = async (redGPUContext, base, shape) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { setRedGPUTest_pane, setDebugButtons - } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); setRedGPUTest_pane(pane, redGPUContext, false); diff --git a/examples/2d/group2D/basic/index.html b/examples/2d/group2D/basic/index.html index b4417a88f..77d781697 100644 --- a/examples/2d/group2D/basic/index.html +++ b/examples/2d/group2D/basic/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/2d/group2D/basic/index.js b/examples/2d/group2D/basic/index.js index a04ce24b1..a41230328 100644 --- a/examples/2d/group2D/basic/index.js +++ b/examples/2d/group2D/basic/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; /** * [KO] Group2D 예제 @@ -116,9 +116,9 @@ const createChildSprite2D = (redGPUContext, parent) => { * @param {RedGPU.Display.Sprite2D} child */ const renderTestPane = async (redGPUContext, rootGroup, parent, child) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const pane = new Pane(); - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext); const maxW = redGPUContext.screenRectObject.width; const maxH = redGPUContext.screenRectObject.height; diff --git a/examples/2d/helloWorld2D/index.html b/examples/2d/helloWorld2D/index.html index 19ffd6889..b3924120d 100644 --- a/examples/2d/helloWorld2D/index.html +++ b/examples/2d/helloWorld2D/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/2d/helloWorld2D/index.js b/examples/2d/helloWorld2D/index.js index 22ab4df3b..d992e4e9e 100644 --- a/examples/2d/helloWorld2D/index.js +++ b/examples/2d/helloWorld2D/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../dist/index.js?t=1770699661827"; /** * [KO] Hello World 2D 예제 @@ -100,9 +100,9 @@ RedGPU.init( * @param {RedGPU.RedGPUContext} redGPUContext */ const renderTestPane = async (redGPUContext) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); - const {setRedGPUTest_pane} = await import("../../exampleHelper/createExample/panes/index.js?t=1770698056099"); - const {setDebugButtons} = await import('../../exampleHelper/createExample/panes/index.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {setRedGPUTest_pane} = await import("../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const {setDebugButtons} = await import('../../exampleHelper/createExample/panes/index.js?t=1770699661827'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); setRedGPUTest_pane(pane, redGPUContext, true); diff --git a/examples/2d/interaction/keyboardEvent/index.html b/examples/2d/interaction/keyboardEvent/index.html index 8b072af74..6ca35a7e3 100644 --- a/examples/2d/interaction/keyboardEvent/index.html +++ b/examples/2d/interaction/keyboardEvent/index.html @@ -7,8 +7,8 @@ - - + + diff --git a/examples/2d/interaction/keyboardEvent/index.js b/examples/2d/interaction/keyboardEvent/index.js index bb7a2618e..2ba1d7e87 100644 --- a/examples/2d/interaction/keyboardEvent/index.js +++ b/examples/2d/interaction/keyboardEvent/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -76,8 +76,8 @@ RedGPU.init( ); const renderTestPane = async (redGPUContext, keyboardKeyBuffer) => { - const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); - const { setDebugButtons } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const { setDebugButtons } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext) const pane = new Pane(); pane.addBlade({ diff --git a/examples/2d/interaction/mouseEvent/sprite2D/index.html b/examples/2d/interaction/mouseEvent/sprite2D/index.html index 7d1ac96b0..fa98ba6d3 100644 --- a/examples/2d/interaction/mouseEvent/sprite2D/index.html +++ b/examples/2d/interaction/mouseEvent/sprite2D/index.html @@ -8,9 +8,9 @@ - - - + + + diff --git a/examples/2d/interaction/mouseEvent/sprite2D/index.js b/examples/2d/interaction/mouseEvent/sprite2D/index.js index f86887cbd..4cb3093da 100644 --- a/examples/2d/interaction/mouseEvent/sprite2D/index.js +++ b/examples/2d/interaction/mouseEvent/sprite2D/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; /** * [KO] Sprite2D Mouse Event 예제 @@ -145,7 +145,7 @@ const createSampleSprite2D = async (redGPUContext, scene, updateInfo) => { * @param {RedGPU.RedGPUContext} redGPUContext */ const renderTestPane = async (redGPUContext) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); - const {setDebugButtons} = await import("../../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {setDebugButtons} = await import("../../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext); }; \ No newline at end of file diff --git a/examples/2d/interaction/mouseEvent/spriteSheet2D/index.html b/examples/2d/interaction/mouseEvent/spriteSheet2D/index.html index 7d1ac96b0..fa98ba6d3 100644 --- a/examples/2d/interaction/mouseEvent/spriteSheet2D/index.html +++ b/examples/2d/interaction/mouseEvent/spriteSheet2D/index.html @@ -8,9 +8,9 @@ - - - + + + diff --git a/examples/2d/interaction/mouseEvent/spriteSheet2D/index.js b/examples/2d/interaction/mouseEvent/spriteSheet2D/index.js index 799d15947..3e6620184 100644 --- a/examples/2d/interaction/mouseEvent/spriteSheet2D/index.js +++ b/examples/2d/interaction/mouseEvent/spriteSheet2D/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; /** * [KO] SpriteSheet2D Mouse Event 예제 @@ -143,7 +143,7 @@ const createSampleSprite2D = async (redGPUContext, scene, updateInfo) => { * @param {RedGPU.RedGPUContext} redGPUContext */ const renderTestPane = async (redGPUContext) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); - const {setDebugButtons} = await import("../../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {setDebugButtons} = await import("../../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext); }; \ No newline at end of file diff --git a/examples/2d/interaction/mouseEvent/textField2D/index.html b/examples/2d/interaction/mouseEvent/textField2D/index.html index 7d1ac96b0..fa98ba6d3 100644 --- a/examples/2d/interaction/mouseEvent/textField2D/index.html +++ b/examples/2d/interaction/mouseEvent/textField2D/index.html @@ -8,9 +8,9 @@ - - - + + + diff --git a/examples/2d/interaction/mouseEvent/textField2D/index.js b/examples/2d/interaction/mouseEvent/textField2D/index.js index e3d354c59..87c8a514c 100644 --- a/examples/2d/interaction/mouseEvent/textField2D/index.js +++ b/examples/2d/interaction/mouseEvent/textField2D/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; /** * [KO] TextField2D Mouse Event 예제 @@ -150,7 +150,7 @@ function getRandomHexValue() { * @param {RedGPU.RedGPUContext} redGPUContext */ const renderTestPane = async (redGPUContext) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); - const {setDebugButtons} = await import("../../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {setDebugButtons} = await import("../../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext); }; \ No newline at end of file diff --git a/examples/2d/line2D/linear/index.html b/examples/2d/line2D/linear/index.html index b4417a88f..77d781697 100644 --- a/examples/2d/line2D/linear/index.html +++ b/examples/2d/line2D/linear/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/2d/line2D/linear/index.js b/examples/2d/line2D/linear/index.js index 0ba262ff7..3f1690a62 100644 --- a/examples/2d/line2D/linear/index.js +++ b/examples/2d/line2D/linear/index.js @@ -1,5 +1,5 @@ // RedGPU 사용을 위한 모듈 임포트 -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; /** * [KO] Line2D (Linear) 예제 @@ -130,7 +130,7 @@ function getRainbowColor(t) { /* 6. 디버그 UI 패널 */ async function setupDebugPanel(redGPUContext, groups, updateLinesCallback, getPointsPerLine, setPointsPerLine) { - const {Pane} = await import("https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099"); + const {Pane} = await import("https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827"); const pane = new Pane(); const debugOptions = { diff --git a/examples/2d/opacity/basic/index.html b/examples/2d/opacity/basic/index.html index b4417a88f..77d781697 100644 --- a/examples/2d/opacity/basic/index.html +++ b/examples/2d/opacity/basic/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/2d/opacity/basic/index.js b/examples/2d/opacity/basic/index.js index 53f374e9c..9e5e7d843 100644 --- a/examples/2d/opacity/basic/index.js +++ b/examples/2d/opacity/basic/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; /** * [KO] Opacity 예제 @@ -148,9 +148,9 @@ const createChildTextField2D = (redGPUContext, parent) => { * @param {Array} children */ const renderTestPane = async (redGPUContext, parent, children) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const pane = new Pane(); - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext); const maxW = redGPUContext.screenRectObject.width; const maxH = redGPUContext.screenRectObject.height; diff --git a/examples/2d/sprite2D/basic/index.html b/examples/2d/sprite2D/basic/index.html index b4417a88f..77d781697 100644 --- a/examples/2d/sprite2D/basic/index.html +++ b/examples/2d/sprite2D/basic/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/2d/sprite2D/basic/index.js b/examples/2d/sprite2D/basic/index.js index 883a4b1a5..103bb57ad 100644 --- a/examples/2d/sprite2D/basic/index.js +++ b/examples/2d/sprite2D/basic/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; /** * [KO] Sprite2D Basic 예제 @@ -63,11 +63,11 @@ RedGPU.init( * @param {RedGPU.Display.Sprite2D} sprite2D */ const renderTestPane = async (redGPUContext, sprite2D) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { setDebugButtons, setRedGPUTest_pane - } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); setRedGPUTest_pane(pane, redGPUContext, false); diff --git a/examples/2d/sprite2D/childMethod/index.html b/examples/2d/sprite2D/childMethod/index.html index b4417a88f..77d781697 100644 --- a/examples/2d/sprite2D/childMethod/index.html +++ b/examples/2d/sprite2D/childMethod/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/2d/sprite2D/childMethod/index.js b/examples/2d/sprite2D/childMethod/index.js index 600e6da39..be86cee20 100644 --- a/examples/2d/sprite2D/childMethod/index.js +++ b/examples/2d/sprite2D/childMethod/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; /** * [KO] Sprite2D Child Method 예제 @@ -79,12 +79,12 @@ const createInitialObjects = (redGPUContext, scene) => { * @param {RedGPU.Display.Scene} scene */ const createPaneUI = async (redGPUContext, scene) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const pane = new Pane(); const { setDebugButtons, setRedGPUTest_pane - } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext); pane.addButton({title: 'Add Child'}).on('click', () => { addChildObject(redGPUContext, scene); diff --git a/examples/2d/sprite2D/hierarchy/index.html b/examples/2d/sprite2D/hierarchy/index.html index b4417a88f..77d781697 100644 --- a/examples/2d/sprite2D/hierarchy/index.html +++ b/examples/2d/sprite2D/hierarchy/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/2d/sprite2D/hierarchy/index.js b/examples/2d/sprite2D/hierarchy/index.js index b748dd300..9d3e71b70 100644 --- a/examples/2d/sprite2D/hierarchy/index.js +++ b/examples/2d/sprite2D/hierarchy/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; /** * [KO] Sprite2D Hierarchy 예제 @@ -98,12 +98,12 @@ const createChildSprite2D = (redGPUContext, parent) => { * @param {RedGPU.Display.Sprite2D} child */ const renderTestPane = async (redGPUContext, parent, child) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const pane = new Pane(); const { setDebugButtons, setRedGPUTest_pane - } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext); const maxW = redGPUContext.screenRectObject.width; const maxH = redGPUContext.screenRectObject.height; diff --git a/examples/2d/sprite2D/pivot/index.html b/examples/2d/sprite2D/pivot/index.html index b4417a88f..77d781697 100644 --- a/examples/2d/sprite2D/pivot/index.html +++ b/examples/2d/sprite2D/pivot/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/2d/sprite2D/pivot/index.js b/examples/2d/sprite2D/pivot/index.js index f7465dbab..3435a53ee 100644 --- a/examples/2d/sprite2D/pivot/index.js +++ b/examples/2d/sprite2D/pivot/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; /** * [KO] Sprite2D Pivot 예제 @@ -102,12 +102,12 @@ const createChildSprite2D = (redGPUContext, parent) => { * @param {RedGPU.Display.Sprite2D} child */ const renderTestPane = async (redGPUContext, parent, child) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const pane = new Pane(); const { setDebugButtons, setRedGPUTest_pane - } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext); const maxW = redGPUContext.screenRectObject.width; const maxH = redGPUContext.screenRectObject.height; diff --git a/examples/2d/spriteSheet2D/basic/index.html b/examples/2d/spriteSheet2D/basic/index.html index b4417a88f..77d781697 100644 --- a/examples/2d/spriteSheet2D/basic/index.html +++ b/examples/2d/spriteSheet2D/basic/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/2d/spriteSheet2D/basic/index.js b/examples/2d/spriteSheet2D/basic/index.js index bf9364df3..26c2946dd 100644 --- a/examples/2d/spriteSheet2D/basic/index.js +++ b/examples/2d/spriteSheet2D/basic/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; /** * [KO] SpriteSheet2D Basic 예제 @@ -72,9 +72,9 @@ const renderTestPane = async (scene, redGPUContext) => { const { setDebugButtons, setSeparator - } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext); - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const pane = new Pane(); const controls = { diff --git a/examples/2d/textField2D/basic/index.html b/examples/2d/textField2D/basic/index.html index b4417a88f..77d781697 100644 --- a/examples/2d/textField2D/basic/index.html +++ b/examples/2d/textField2D/basic/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/2d/textField2D/basic/index.js b/examples/2d/textField2D/basic/index.js index f7bb4af82..6e5996fb1 100644 --- a/examples/2d/textField2D/basic/index.js +++ b/examples/2d/textField2D/basic/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; /** * [KO] TextField2D Basic 예제 @@ -75,9 +75,9 @@ const renderTestPane = async (scene, redGPUContext) => { const { setDebugButtons, setSeparator - } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext); - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const pane = new Pane(); const controls = {}; diff --git a/examples/2d/tint/2dObjectTint/index.html b/examples/2d/tint/2dObjectTint/index.html index b4417a88f..77d781697 100644 --- a/examples/2d/tint/2dObjectTint/index.html +++ b/examples/2d/tint/2dObjectTint/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/2d/tint/2dObjectTint/index.js b/examples/2d/tint/2dObjectTint/index.js index 6f260ec4d..acf3e6fbb 100644 --- a/examples/2d/tint/2dObjectTint/index.js +++ b/examples/2d/tint/2dObjectTint/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; /** * [KO] 2D Object Tint 예제 @@ -90,9 +90,9 @@ RedGPU.init( * @param {RedGPU.Display.Scene} scene */ const renderTestPane = async (redGPUContext, scene) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const pane = new Pane(); - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext); const firstChild = scene.children[0]; const defaultTint = firstChild ? firstChild.material.tint : {r: 255, g: 255, b: 255, a: 1}; diff --git a/examples/2d/tint/basic/index.html b/examples/2d/tint/basic/index.html index b4417a88f..77d781697 100644 --- a/examples/2d/tint/basic/index.html +++ b/examples/2d/tint/basic/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/2d/tint/basic/index.js b/examples/2d/tint/basic/index.js index a9735b679..b213fbf6f 100644 --- a/examples/2d/tint/basic/index.js +++ b/examples/2d/tint/basic/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; /** * [KO] Tint Basic 예제 @@ -75,9 +75,9 @@ RedGPU.init( * @param {RedGPU.Display.Sprite2D} sprite */ const renderTestPane = async (redGPUContext, sprite) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const pane = new Pane(); - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext); const folder = pane.addFolder({title: 'Material Tint Test'}); const targetTint = sprite.material.tint; diff --git a/examples/2d/view/multiView/index.html b/examples/2d/view/multiView/index.html index b4417a88f..77d781697 100644 --- a/examples/2d/view/multiView/index.html +++ b/examples/2d/view/multiView/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/2d/view/multiView/index.js b/examples/2d/view/multiView/index.js index 9e8d78f8a..2e4c3c6aa 100644 --- a/examples/2d/view/multiView/index.js +++ b/examples/2d/view/multiView/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; /** * [KO] Multi View 예제 @@ -85,12 +85,12 @@ RedGPU.init( * @param {RedGPU.RedGPUContext} redGPUContext */ const renderTestPane = async (redGPUContext) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { setDebugButtons, setRedGPUTest_pane, setViewListTest - } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); setRedGPUTest_pane(pane, redGPUContext, false); diff --git a/examples/2d/view/multiViewWith3D/index.html b/examples/2d/view/multiViewWith3D/index.html index b4417a88f..77d781697 100644 --- a/examples/2d/view/multiViewWith3D/index.html +++ b/examples/2d/view/multiViewWith3D/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/2d/view/multiViewWith3D/index.js b/examples/2d/view/multiViewWith3D/index.js index 63c06a590..f7b9ba5e0 100644 --- a/examples/2d/view/multiViewWith3D/index.js +++ b/examples/2d/view/multiViewWith3D/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; /** * [KO] Multi View with 3D 예제 @@ -85,12 +85,12 @@ RedGPU.init( * @param {RedGPU.RedGPUContext} redGPUContext */ const renderTestPane = async (redGPUContext) => { - const {Pane} = await import("https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099"); + const {Pane} = await import("https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827"); const { setDebugButtons, setRedGPUTest_pane, setViewListTest - } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); setRedGPUTest_pane(pane, redGPUContext, false); diff --git a/examples/3d/controller/followController/index.html b/examples/3d/controller/followController/index.html index c4bd4692f..a6887ba00 100644 --- a/examples/3d/controller/followController/index.html +++ b/examples/3d/controller/followController/index.html @@ -7,8 +7,8 @@ - - + + diff --git a/examples/3d/controller/followController/index.js b/examples/3d/controller/followController/index.js index 4b99de2c2..8ab758345 100644 --- a/examples/3d/controller/followController/index.js +++ b/examples/3d/controller/followController/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; /** * [KO] Follow Controller 예제 @@ -115,10 +115,10 @@ RedGPU.init( * @param {RedGPU.Camera.FollowController} controller */ const renderTestPane = async (redGPUContext, controller) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { setDebugButtons - } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); diff --git a/examples/3d/controller/freeController/index.html b/examples/3d/controller/freeController/index.html index c4bd4692f..a6887ba00 100644 --- a/examples/3d/controller/freeController/index.html +++ b/examples/3d/controller/freeController/index.html @@ -7,8 +7,8 @@ - - + + diff --git a/examples/3d/controller/freeController/index.js b/examples/3d/controller/freeController/index.js index 4860234fa..387917d74 100644 --- a/examples/3d/controller/freeController/index.js +++ b/examples/3d/controller/freeController/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; /** * [KO] Free Controller 예제 @@ -67,8 +67,8 @@ RedGPU.init(canvas, (redGPUContext) => { * @param {RedGPU.Camera.FreeController} controller */ const renderTestPane = async (redGPUContext, controller) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); diff --git a/examples/3d/controller/isometricController/index.html b/examples/3d/controller/isometricController/index.html index c4bd4692f..a6887ba00 100644 --- a/examples/3d/controller/isometricController/index.html +++ b/examples/3d/controller/isometricController/index.html @@ -7,8 +7,8 @@ - - + + diff --git a/examples/3d/controller/isometricController/index.js b/examples/3d/controller/isometricController/index.js index c500dbd92..9962d0e6a 100644 --- a/examples/3d/controller/isometricController/index.js +++ b/examples/3d/controller/isometricController/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; /** * [KO] Isometric Controller 예제 @@ -83,10 +83,10 @@ RedGPU.init( * @param {RedGPU.Display.Mesh} targetMesh */ const renderTestPane = async (redGPUContext, controller, targetMesh) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { setDebugButtons - } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); diff --git a/examples/3d/controller/orbitController/index.html b/examples/3d/controller/orbitController/index.html index c4bd4692f..a6887ba00 100644 --- a/examples/3d/controller/orbitController/index.html +++ b/examples/3d/controller/orbitController/index.html @@ -7,8 +7,8 @@ - - + + diff --git a/examples/3d/controller/orbitController/index.js b/examples/3d/controller/orbitController/index.js index b9280fd89..c4d2eeeb0 100644 --- a/examples/3d/controller/orbitController/index.js +++ b/examples/3d/controller/orbitController/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; /** * [KO] Orbit Controller 예제 @@ -70,10 +70,10 @@ RedGPU.init( * @param {RedGPU.Camera.OrbitController} controller */ const renderTestPane = async (redGPUContext, controller) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { setDebugButtons - } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); diff --git a/examples/3d/coordinateTransformation/screenToWorld/index.html b/examples/3d/coordinateTransformation/screenToWorld/index.html index b4417a88f..77d781697 100644 --- a/examples/3d/coordinateTransformation/screenToWorld/index.html +++ b/examples/3d/coordinateTransformation/screenToWorld/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/coordinateTransformation/screenToWorld/index.js b/examples/3d/coordinateTransformation/screenToWorld/index.js index 995bf1999..daa9e6e8e 100644 --- a/examples/3d/coordinateTransformation/screenToWorld/index.js +++ b/examples/3d/coordinateTransformation/screenToWorld/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; /** * [KO] Screen To World 예제 @@ -49,7 +49,7 @@ RedGPU.init( * @param {RedGPU.RedGPUContext} redGPUContext */ const renderTestPane = async (redGPUContext) => { - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext); }; diff --git a/examples/3d/coordinateTransformation/worldToLocal/index.html b/examples/3d/coordinateTransformation/worldToLocal/index.html index b4417a88f..77d781697 100644 --- a/examples/3d/coordinateTransformation/worldToLocal/index.html +++ b/examples/3d/coordinateTransformation/worldToLocal/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/coordinateTransformation/worldToLocal/index.js b/examples/3d/coordinateTransformation/worldToLocal/index.js index e6ae8dd9a..b8d731641 100644 --- a/examples/3d/coordinateTransformation/worldToLocal/index.js +++ b/examples/3d/coordinateTransformation/worldToLocal/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; /** * [KO] World To Local 예제 @@ -56,7 +56,7 @@ RedGPU.init( * @param {RedGPU.RedGPUContext} redGPUContext */ const renderTestPane = async (redGPUContext) => { - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext); }; diff --git a/examples/3d/drawDebugger/basic/index.html b/examples/3d/drawDebugger/basic/index.html index b4417a88f..77d781697 100644 --- a/examples/3d/drawDebugger/basic/index.html +++ b/examples/3d/drawDebugger/basic/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/drawDebugger/basic/index.js b/examples/3d/drawDebugger/basic/index.js index 13a077718..71ae93da4 100644 --- a/examples/3d/drawDebugger/basic/index.js +++ b/examples/3d/drawDebugger/basic/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; /** * [KO] Draw Debugger 예제 @@ -133,8 +133,8 @@ RedGPU.init( * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); - const {setDebugButtons} = await import( "../../../exampleHelper/createExample/panes/index.js?t=1770698056099" ); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {setDebugButtons} = await import( "../../../exampleHelper/createExample/panes/index.js?t=1770699661827" ); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); const ibl = new RedGPU.Resource.IBL(redGPUContext, '../../../assets/hdr/2k/the_sky_is_on_fire_2k.hdr'); diff --git a/examples/3d/frustumCulling/distanceCulling/index.html b/examples/3d/frustumCulling/distanceCulling/index.html index b4417a88f..77d781697 100644 --- a/examples/3d/frustumCulling/distanceCulling/index.html +++ b/examples/3d/frustumCulling/distanceCulling/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/frustumCulling/distanceCulling/index.js b/examples/3d/frustumCulling/distanceCulling/index.js index 28279ef7c..8172c695f 100644 --- a/examples/3d/frustumCulling/distanceCulling/index.js +++ b/examples/3d/frustumCulling/distanceCulling/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; /** * [KO] Distance Culling 예제 @@ -94,9 +94,9 @@ const createTestMeshes = (redGPUContext, scene) => { * @param {RedGPU.Display.View3D} view */ const renderTestPane = async (redGPUContext, meshes, view) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const pane = new Pane(); - const {setDebugButtons} = await import( "../../../exampleHelper/createExample/panes/index.js?t=1770698056099" ); + const {setDebugButtons} = await import( "../../../exampleHelper/createExample/panes/index.js?t=1770699661827" ); setDebugButtons(RedGPU, redGPUContext); const config = { cameraDistance: view.camera.distance, diff --git a/examples/3d/frustumCulling/frustumCulling/index.html b/examples/3d/frustumCulling/frustumCulling/index.html index b4417a88f..77d781697 100644 --- a/examples/3d/frustumCulling/frustumCulling/index.html +++ b/examples/3d/frustumCulling/frustumCulling/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/frustumCulling/frustumCulling/index.js b/examples/3d/frustumCulling/frustumCulling/index.js index 914ca9b28..e7b5b2141 100644 --- a/examples/3d/frustumCulling/frustumCulling/index.js +++ b/examples/3d/frustumCulling/frustumCulling/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; /** * [KO] Frustum Culling 예제 @@ -87,9 +87,9 @@ const createTestMeshes = (redGPUContext, scene) => { * @param {RedGPU.Display.View3D} view */ const renderTestPane = async (redGPUContext, meshes, view) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const pane = new Pane(); - const {setDebugButtons} = await import( "../../../exampleHelper/createExample/panes/index.js?t=1770698056099" ); + const {setDebugButtons} = await import( "../../../exampleHelper/createExample/panes/index.js?t=1770699661827" ); setDebugButtons(RedGPU, redGPUContext); const config = { cameraDistance: view.camera.distance, diff --git a/examples/3d/group3D/basic/index.html b/examples/3d/group3D/basic/index.html index b4417a88f..77d781697 100644 --- a/examples/3d/group3D/basic/index.html +++ b/examples/3d/group3D/basic/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/group3D/basic/index.js b/examples/3d/group3D/basic/index.js index a64fa20dd..35a48b71d 100644 --- a/examples/3d/group3D/basic/index.js +++ b/examples/3d/group3D/basic/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; /** * [KO] Group3D Basic 예제 @@ -108,9 +108,9 @@ const createChildMesh = (redGPUContext, parent) => { * @param {RedGPU.Display.Mesh} child */ const renderTestPane = async (redGPUContext, rootGroup, parent, child) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const pane = new Pane(); - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext); const rootConfig = { x: rootGroup.x, diff --git a/examples/3d/helloWorld/index.html b/examples/3d/helloWorld/index.html index 14f017028..9579c4497 100644 --- a/examples/3d/helloWorld/index.html +++ b/examples/3d/helloWorld/index.html @@ -7,8 +7,8 @@ - - + + diff --git a/examples/3d/helloWorld/index.js b/examples/3d/helloWorld/index.js index 5718854f4..599944c4f 100644 --- a/examples/3d/helloWorld/index.js +++ b/examples/3d/helloWorld/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../dist/index.js?t=1770699661827"; /** * [KO] Hello World 3D 예제 @@ -47,11 +47,11 @@ RedGPU.init( * @param {RedGPU.Display.View3D} view */ const renderTestPane = async (redGPUContext, view) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { setRedGPUTest_pane, setDebugButtons - } = await import("../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + } = await import("../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext) const pane = new Pane(); setRedGPUTest_pane(pane, redGPUContext, true); diff --git a/examples/3d/indirectDrawTest/index.html b/examples/3d/indirectDrawTest/index.html index 19ffd6889..b3924120d 100644 --- a/examples/3d/indirectDrawTest/index.html +++ b/examples/3d/indirectDrawTest/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/indirectDrawTest/index.js b/examples/3d/indirectDrawTest/index.js index b9b9b7470..476d783e7 100644 --- a/examples/3d/indirectDrawTest/index.js +++ b/examples/3d/indirectDrawTest/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../dist/index.js?t=1770699661827"; /** * [KO] Indirect Draw 예제 @@ -201,11 +201,11 @@ function loadGLTFGrid(view, urls, gridSize = 3, spacing = 3) { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { createIblHelper, setDebugButtons - } = await import('../../exampleHelper/createExample/panes/index.js?t=1770698056099'); + } = await import('../../exampleHelper/createExample/panes/index.js?t=1770699661827'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/3d/instancedMesh/simple/index.html b/examples/3d/instancedMesh/simple/index.html index b4417a88f..77d781697 100644 --- a/examples/3d/instancedMesh/simple/index.html +++ b/examples/3d/instancedMesh/simple/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/instancedMesh/simple/index.js b/examples/3d/instancedMesh/simple/index.js index 8bfe50955..246695b4c 100644 --- a/examples/3d/instancedMesh/simple/index.js +++ b/examples/3d/instancedMesh/simple/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; // 1. Create and append a canvas const canvas = document.createElement('canvas'); @@ -83,9 +83,9 @@ RedGPU.init( * @param {RedGPU.Material.PhongMaterial} material */ async function createTest(redGPUContext, scene, material) { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext); const maxInstanceCount = redGPUContext.detector.isMobile ? 100000 : RedGPU.Display.InstancingMesh.getLimitSize(); diff --git a/examples/3d/instancedMesh/sphere/index.html b/examples/3d/instancedMesh/sphere/index.html index b4417a88f..77d781697 100644 --- a/examples/3d/instancedMesh/sphere/index.html +++ b/examples/3d/instancedMesh/sphere/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/instancedMesh/sphere/index.js b/examples/3d/instancedMesh/sphere/index.js index d68ac4324..7c98a4534 100644 --- a/examples/3d/instancedMesh/sphere/index.js +++ b/examples/3d/instancedMesh/sphere/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; // 1. Create and append a canvas const canvas = document.createElement('canvas'); @@ -83,9 +83,9 @@ RedGPU.init( * @param {RedGPU.Material.PhongMaterial} material */ async function createTest(redGPUContext, scene, material) { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext); const maxInstanceCount = redGPUContext.detector.isMobile ? 100000 : RedGPU.Display.InstancingMesh.getLimitSize(); diff --git a/examples/3d/interaction/keyboardEvent/index.html b/examples/3d/interaction/keyboardEvent/index.html index 8b072af74..6ca35a7e3 100644 --- a/examples/3d/interaction/keyboardEvent/index.html +++ b/examples/3d/interaction/keyboardEvent/index.html @@ -7,8 +7,8 @@ - - + + diff --git a/examples/3d/interaction/keyboardEvent/index.js b/examples/3d/interaction/keyboardEvent/index.js index 9645ba401..8eed2f290 100644 --- a/examples/3d/interaction/keyboardEvent/index.js +++ b/examples/3d/interaction/keyboardEvent/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -139,8 +139,8 @@ RedGPU.init( * @param {Object} activeKeysState */ const renderTestPane = async (redGPUContext, activeKeysState) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext) const pane = new Pane(); diff --git a/examples/3d/interaction/mouseEvent/mesh/index.html b/examples/3d/interaction/mouseEvent/mesh/index.html index 7d1ac96b0..fa98ba6d3 100644 --- a/examples/3d/interaction/mouseEvent/mesh/index.html +++ b/examples/3d/interaction/mouseEvent/mesh/index.html @@ -8,9 +8,9 @@ - - - + + + diff --git a/examples/3d/interaction/mouseEvent/mesh/index.js b/examples/3d/interaction/mouseEvent/mesh/index.js index a03866703..c11e9ac71 100644 --- a/examples/3d/interaction/mouseEvent/mesh/index.js +++ b/examples/3d/interaction/mouseEvent/mesh/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; /** * [KO] Mesh Mouse Event 예제 @@ -167,6 +167,6 @@ const createSampleMesh = (redGPUContext, scene, infoBox, updateInfo) => { const renderTestPane = async (redGPUContext) => { const { setDebugButtons - } = await import("../../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + } = await import("../../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext); }; diff --git a/examples/3d/interaction/mouseEvent/raycasting/index.html b/examples/3d/interaction/mouseEvent/raycasting/index.html index 9990da068..e9152e103 100644 --- a/examples/3d/interaction/mouseEvent/raycasting/index.html +++ b/examples/3d/interaction/mouseEvent/raycasting/index.html @@ -8,9 +8,9 @@ - - - + + + diff --git a/examples/3d/interaction/mouseEvent/raycasting/index.js b/examples/3d/interaction/mouseEvent/raycasting/index.js index 1e16551cd..37dde2d55 100644 --- a/examples/3d/interaction/mouseEvent/raycasting/index.js +++ b/examples/3d/interaction/mouseEvent/raycasting/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; /** * [KO] Raycasting 예제 @@ -118,8 +118,8 @@ RedGPU.init( * @param {RedGPU.RedGPUContext} redGPUContext */ const renderTestPane = async (redGPUContext) => { - const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); - const { setDebugButtons } = await import("../../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const { setDebugButtons } = await import("../../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext); new Pane().addBlade({ view: 'text', label: 'Guide', value: 'Hover over objects to see raycasting in action!', parse: (v) => v, readonly: true }); }; \ No newline at end of file diff --git a/examples/3d/interaction/mouseEvent/sprite3D/index.html b/examples/3d/interaction/mouseEvent/sprite3D/index.html index 7d1ac96b0..fa98ba6d3 100644 --- a/examples/3d/interaction/mouseEvent/sprite3D/index.html +++ b/examples/3d/interaction/mouseEvent/sprite3D/index.html @@ -8,9 +8,9 @@ - - - + + + diff --git a/examples/3d/interaction/mouseEvent/sprite3D/index.js b/examples/3d/interaction/mouseEvent/sprite3D/index.js index 5f3aafab2..4dd940bc0 100644 --- a/examples/3d/interaction/mouseEvent/sprite3D/index.js +++ b/examples/3d/interaction/mouseEvent/sprite3D/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; /** * [KO] Sprite3D Mouse Event 예제 @@ -167,9 +167,9 @@ const createSampleSprite3D = (redGPUContext, scene, infoBox, updateInfo) => { * @param {RedGPU.Display.Scene} scene */ const renderTestPane = async (redGPUContext, scene) => { - const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const pane = new Pane(); - const { setDebugButtons } = await import("../../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const { setDebugButtons } = await import("../../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext); const folder = pane.addFolder({ title: 'Sprite3D', expanded: true }); diff --git a/examples/3d/interaction/mouseEvent/spriteSheet3D/index.html b/examples/3d/interaction/mouseEvent/spriteSheet3D/index.html index 7d1ac96b0..fa98ba6d3 100644 --- a/examples/3d/interaction/mouseEvent/spriteSheet3D/index.html +++ b/examples/3d/interaction/mouseEvent/spriteSheet3D/index.html @@ -8,9 +8,9 @@ - - - + + + diff --git a/examples/3d/interaction/mouseEvent/spriteSheet3D/index.js b/examples/3d/interaction/mouseEvent/spriteSheet3D/index.js index 1be7eaac7..7e7a03e8d 100644 --- a/examples/3d/interaction/mouseEvent/spriteSheet3D/index.js +++ b/examples/3d/interaction/mouseEvent/spriteSheet3D/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; /** * [KO] SpriteSheet3D Mouse Event 예제 @@ -172,9 +172,9 @@ const createSampleSprite3D = (redGPUContext, scene, infoBox, updateInfo) => { * @param {RedGPU.Display.Scene} scene */ const renderTestPane = async (redGPUContext, scene) => { - const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const pane = new Pane(); - const { setDebugButtons } = await import("../../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const { setDebugButtons } = await import("../../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext); const folder = pane.addFolder({ title: 'SpriteSheet3D', expanded: true }); diff --git a/examples/3d/interaction/mouseEvent/textField3D/index.html b/examples/3d/interaction/mouseEvent/textField3D/index.html index 7d1ac96b0..fa98ba6d3 100644 --- a/examples/3d/interaction/mouseEvent/textField3D/index.html +++ b/examples/3d/interaction/mouseEvent/textField3D/index.html @@ -8,9 +8,9 @@ - - - + + + diff --git a/examples/3d/interaction/mouseEvent/textField3D/index.js b/examples/3d/interaction/mouseEvent/textField3D/index.js index 84deda5c7..62b38e3dc 100644 --- a/examples/3d/interaction/mouseEvent/textField3D/index.js +++ b/examples/3d/interaction/mouseEvent/textField3D/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; /** * [KO] TextField3D Mouse Event 예제 @@ -165,9 +165,9 @@ function getRandomHexValue() { * @param {RedGPU.Display.Scene} scene */ const renderTestPane = async (redGPUContext, scene) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const pane = new Pane(); - const {setDebugButtons} = await import("../../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const {setDebugButtons} = await import("../../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext); const child = scene.children.find(c => c instanceof RedGPU.Display.TextField3D); diff --git a/examples/3d/light/directionalLight/index.html b/examples/3d/light/directionalLight/index.html index b4417a88f..77d781697 100644 --- a/examples/3d/light/directionalLight/index.html +++ b/examples/3d/light/directionalLight/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/light/directionalLight/index.js b/examples/3d/light/directionalLight/index.js index 3a45778ee..9eb7660e7 100644 --- a/examples/3d/light/directionalLight/index.js +++ b/examples/3d/light/directionalLight/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; /** * [KO] Directional Light 예제 @@ -81,9 +81,9 @@ const createSampleMesh = (redGPUContext, scene) => { * @param {RedGPU.Light.DirectionalLight} light */ const renderTestPaneWithLightControl = async (redGPUContext, mesh, light) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const pane = new Pane(); - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext); const lightConfig = { directionX: light.direction[0], diff --git a/examples/3d/light/pointLight/index.html b/examples/3d/light/pointLight/index.html index b4417a88f..77d781697 100644 --- a/examples/3d/light/pointLight/index.html +++ b/examples/3d/light/pointLight/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/light/pointLight/index.js b/examples/3d/light/pointLight/index.js index 8ca61c187..1d63450bc 100644 --- a/examples/3d/light/pointLight/index.js +++ b/examples/3d/light/pointLight/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; /** * [KO] Point Light 예제 @@ -98,9 +98,9 @@ const createSampleMeshes = (redGPUContext, scene) => { * @param {RedGPU.Light.PointLight} light */ const renderTestPaneWithLightControl = async (redGPUContext, light) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const pane = new Pane(); - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext); const lightConfig = { x: light.position[0], diff --git a/examples/3d/light/pointLightPerformance/index.html b/examples/3d/light/pointLightPerformance/index.html index b4417a88f..77d781697 100644 --- a/examples/3d/light/pointLightPerformance/index.html +++ b/examples/3d/light/pointLightPerformance/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/light/pointLightPerformance/index.js b/examples/3d/light/pointLightPerformance/index.js index f53e41b99..c2dab3955 100644 --- a/examples/3d/light/pointLightPerformance/index.js +++ b/examples/3d/light/pointLightPerformance/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; /** * [KO] Point Light Performance 예제 @@ -50,7 +50,7 @@ RedGPU.init( * @param {RedGPU.RedGPUContext} redGPUContext */ const renderTestPane = async (redGPUContext) => { - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext); }; diff --git a/examples/3d/light/spotLight/index.html b/examples/3d/light/spotLight/index.html index b4417a88f..77d781697 100644 --- a/examples/3d/light/spotLight/index.html +++ b/examples/3d/light/spotLight/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/light/spotLight/index.js b/examples/3d/light/spotLight/index.js index 9d832bbfc..c2376f227 100644 --- a/examples/3d/light/spotLight/index.js +++ b/examples/3d/light/spotLight/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; /** * [KO] Spot Light 예제 @@ -128,9 +128,9 @@ const createSampleMeshes = (redGPUContext, scene) => { * @param {RedGPU.Light.SpotLight} light */ const renderTestPaneWithLightControl = async (redGPUContext, light) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const pane = new Pane(); - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext); const lightConfig = { x: light.position[0], diff --git a/examples/3d/light/spotLightPerformance/index.html b/examples/3d/light/spotLightPerformance/index.html index b4417a88f..77d781697 100644 --- a/examples/3d/light/spotLightPerformance/index.html +++ b/examples/3d/light/spotLightPerformance/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/light/spotLightPerformance/index.js b/examples/3d/light/spotLightPerformance/index.js index 4ceacee48..2be54b6b1 100644 --- a/examples/3d/light/spotLightPerformance/index.js +++ b/examples/3d/light/spotLightPerformance/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; /** * [KO] Spot Light Performance 예제 @@ -56,7 +56,7 @@ RedGPU.init( * @param {RedGPU.RedGPUContext} redGPUContext */ const renderTestPane = async (redGPUContext) => { - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext); }; diff --git a/examples/3d/line3D/bezier/index.html b/examples/3d/line3D/bezier/index.html index b4417a88f..77d781697 100644 --- a/examples/3d/line3D/bezier/index.html +++ b/examples/3d/line3D/bezier/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/line3D/bezier/index.js b/examples/3d/line3D/bezier/index.js index 6e1da3d0d..d30ad3252 100644 --- a/examples/3d/line3D/bezier/index.js +++ b/examples/3d/line3D/bezier/index.js @@ -1,5 +1,5 @@ // RedGPU 사용을 위한 모듈 임포트 -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; /** * [KO] Line3D (Bezier) 예제 @@ -143,9 +143,9 @@ function rainbowHex(t) { } const renderTestPane = async (redGPUContext) => { - const {Pane} = await import("https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099"); + const {Pane} = await import("https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827"); const pane = new Pane(); - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext); // **** UI 동작 대상이 되는 Line3D 오브젝트 및 디버그 마커 모음 **** const debugOptions = { diff --git a/examples/3d/line3D/catmullRom/index.html b/examples/3d/line3D/catmullRom/index.html index b4417a88f..77d781697 100644 --- a/examples/3d/line3D/catmullRom/index.html +++ b/examples/3d/line3D/catmullRom/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/line3D/catmullRom/index.js b/examples/3d/line3D/catmullRom/index.js index bc5b4cc23..401f9b421 100644 --- a/examples/3d/line3D/catmullRom/index.js +++ b/examples/3d/line3D/catmullRom/index.js @@ -1,5 +1,5 @@ // RedGPU 사용을 위한 모듈 임포트 -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; /** * [KO] Line3D (Catmull-Rom) 예제 @@ -121,9 +121,9 @@ function rainbowHex(t) { } const renderTestPane = async (redGPUContext) => { - const {Pane} = await import("https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099"); + const {Pane} = await import("https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827"); const pane = new Pane(); - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext); // **** UI 동작 대상이 되는 Line3D 오브젝트 및 디버그 마커 모음 **** const debugOptions = { diff --git a/examples/3d/line3D/linear/index.html b/examples/3d/line3D/linear/index.html index b4417a88f..77d781697 100644 --- a/examples/3d/line3D/linear/index.html +++ b/examples/3d/line3D/linear/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/line3D/linear/index.js b/examples/3d/line3D/linear/index.js index e6cb5aeb0..30b90a480 100644 --- a/examples/3d/line3D/linear/index.js +++ b/examples/3d/line3D/linear/index.js @@ -1,5 +1,5 @@ // RedGPU 사용을 위한 모듈 임포트 -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; /** * [KO] Line3D (Linear) 예제 @@ -122,9 +122,9 @@ function rainbowHex(t) { } const renderTestPane = async (redGPUContext, view) => { - const {Pane} = await import("https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099"); + const {Pane} = await import("https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827"); const pane = new Pane(); - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext); // 옵션 초기화 const debugOptions = { diff --git a/examples/3d/lod/InstanceMeshGPULOD/index.html b/examples/3d/lod/InstanceMeshGPULOD/index.html index b4417a88f..77d781697 100644 --- a/examples/3d/lod/InstanceMeshGPULOD/index.html +++ b/examples/3d/lod/InstanceMeshGPULOD/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/lod/InstanceMeshGPULOD/index.js b/examples/3d/lod/InstanceMeshGPULOD/index.js index 0c0411b68..ea3556c2f 100644 --- a/examples/3d/lod/InstanceMeshGPULOD/index.js +++ b/examples/3d/lod/InstanceMeshGPULOD/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; // 1. Create and append a canvas const canvas = document.createElement('canvas'); @@ -83,9 +83,9 @@ RedGPU.init( * @param {RedGPU.Material.PhongMaterial} material */ async function createTest(redGPUContext, scene, material) { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext); const maxInstanceCount = redGPUContext.detector.isMobile ? 100000 : RedGPU.Display.InstancingMesh.getLimitSize(); diff --git a/examples/3d/lod/InstanceMeshGPULOD_material/index.html b/examples/3d/lod/InstanceMeshGPULOD_material/index.html index b4417a88f..77d781697 100644 --- a/examples/3d/lod/InstanceMeshGPULOD_material/index.html +++ b/examples/3d/lod/InstanceMeshGPULOD_material/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/lod/InstanceMeshGPULOD_material/index.js b/examples/3d/lod/InstanceMeshGPULOD_material/index.js index fc0298e2e..08d306386 100644 --- a/examples/3d/lod/InstanceMeshGPULOD_material/index.js +++ b/examples/3d/lod/InstanceMeshGPULOD_material/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -62,8 +62,8 @@ RedGPU.init( * @param {RedGPU.Material.PhongMaterial} material */ async function createTest(redGPUContext, scene, material) { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); const maxInstanceCount = 20000; const instanceCount = redGPUContext.detector.isMobile ? 5000 : 20000; diff --git a/examples/3d/lod/MeshCPULOD/index.html b/examples/3d/lod/MeshCPULOD/index.html index b4417a88f..77d781697 100644 --- a/examples/3d/lod/MeshCPULOD/index.html +++ b/examples/3d/lod/MeshCPULOD/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/lod/MeshCPULOD/index.js b/examples/3d/lod/MeshCPULOD/index.js index 8f3933e20..a087f2493 100644 --- a/examples/3d/lod/MeshCPULOD/index.js +++ b/examples/3d/lod/MeshCPULOD/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; // 1. Create and append a canvas const canvas = document.createElement('canvas'); @@ -83,9 +83,9 @@ RedGPU.init( * @param {RedGPU.Material.PhongMaterial} material */ async function createTest(redGPUContext, scene, material) { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext); const maxNum = redGPUContext.detector.isMobile ? 1000 : 5000; diff --git a/examples/3d/lod/MeshCPULOD_material/index.html b/examples/3d/lod/MeshCPULOD_material/index.html index b4417a88f..77d781697 100644 --- a/examples/3d/lod/MeshCPULOD_material/index.html +++ b/examples/3d/lod/MeshCPULOD_material/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/lod/MeshCPULOD_material/index.js b/examples/3d/lod/MeshCPULOD_material/index.js index f060b9e36..f420457f2 100644 --- a/examples/3d/lod/MeshCPULOD_material/index.js +++ b/examples/3d/lod/MeshCPULOD_material/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -54,8 +54,8 @@ RedGPU.init( * @param {RedGPU.Display.Scene} scene */ async function createTest(redGPUContext, scene) { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); const url = 'https://raw.githubusercontent.com/KhronosGroup/glTF-Sample-Assets/main/Models/Suzanne/glTF/Suzanne.gltf'; diff --git a/examples/3d/material/bitmapMaterial/index.html b/examples/3d/material/bitmapMaterial/index.html index b4417a88f..77d781697 100644 --- a/examples/3d/material/bitmapMaterial/index.html +++ b/examples/3d/material/bitmapMaterial/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/material/bitmapMaterial/index.js b/examples/3d/material/bitmapMaterial/index.js index caaf2f5d3..f50c68811 100644 --- a/examples/3d/material/bitmapMaterial/index.js +++ b/examples/3d/material/bitmapMaterial/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; /** * [KO] Bitmap Material 예제 @@ -67,11 +67,11 @@ const createSampleMesh = (redGPUContext, scene) => { * @param {RedGPU.Display.Mesh} mesh */ const renderTestPane = async (redGPUContext, mesh) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { setSeparator, setDebugButtons - } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); diff --git a/examples/3d/material/colorMaterial/index.html b/examples/3d/material/colorMaterial/index.html index b4417a88f..77d781697 100644 --- a/examples/3d/material/colorMaterial/index.html +++ b/examples/3d/material/colorMaterial/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/material/colorMaterial/index.js b/examples/3d/material/colorMaterial/index.js index db7479eac..f5ed2b4d4 100644 --- a/examples/3d/material/colorMaterial/index.js +++ b/examples/3d/material/colorMaterial/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; /** * [KO] Color Material 예제 @@ -61,11 +61,11 @@ const createSampleMesh = (redGPUContext, scene) => { * @param {RedGPU.Display.Mesh} mesh */ const renderTestPane = async (redGPUContext, mesh) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { setSeparator, setDebugButtons - } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); diff --git a/examples/3d/material/fragmentVariantTest/index.html b/examples/3d/material/fragmentVariantTest/index.html index b4417a88f..77d781697 100644 --- a/examples/3d/material/fragmentVariantTest/index.html +++ b/examples/3d/material/fragmentVariantTest/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/material/fragmentVariantTest/index.js b/examples/3d/material/fragmentVariantTest/index.js index 5e5a7905d..e2ab78756 100644 --- a/examples/3d/material/fragmentVariantTest/index.js +++ b/examples/3d/material/fragmentVariantTest/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; /** * [KO] Fragment Variant Test 예제 @@ -140,11 +140,11 @@ const createTextures = (redGPUContext) => { // ===== UI Rendering ===== const renderUI = async (redGPUContext, mesh) => { - const {Pane} = await import("https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099"); + const {Pane} = await import("https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827"); const { setSeparator, setDebugButtons - } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane({title: "Phong Shader Variants"}); diff --git a/examples/3d/material/opacity/index.html b/examples/3d/material/opacity/index.html index b4417a88f..77d781697 100644 --- a/examples/3d/material/opacity/index.html +++ b/examples/3d/material/opacity/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/material/opacity/index.js b/examples/3d/material/opacity/index.js index af3ceaeb4..807aa7bc0 100644 --- a/examples/3d/material/opacity/index.js +++ b/examples/3d/material/opacity/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; /** * [KO] Opacity 3D Material 예제 @@ -123,11 +123,11 @@ const createChildTextField3D = (redGPUContext, parent, x = 0, y = 0) => { * @param {Array} children */ const renderTestPane = async (redGPUContext, parent, children) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { setSeparator, setDebugButtons - } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); diff --git a/examples/3d/material/phongMaterial/index.html b/examples/3d/material/phongMaterial/index.html index b4417a88f..77d781697 100644 --- a/examples/3d/material/phongMaterial/index.html +++ b/examples/3d/material/phongMaterial/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/material/phongMaterial/index.js b/examples/3d/material/phongMaterial/index.js index 154022777..353ac136b 100644 --- a/examples/3d/material/phongMaterial/index.js +++ b/examples/3d/material/phongMaterial/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; /** * [KO] Phong Material 예제 @@ -83,11 +83,11 @@ const createTextures = (redGPUContext) => { }; const renderUI = async (redGPUContext, mesh) => { - const {Pane} = await import("https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099"); + const {Pane} = await import("https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827"); const { setSeparator, setDebugButtons - } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); const material = mesh.material; diff --git a/examples/3d/material/phongMaterialTextures/index.html b/examples/3d/material/phongMaterialTextures/index.html index b4417a88f..77d781697 100644 --- a/examples/3d/material/phongMaterialTextures/index.html +++ b/examples/3d/material/phongMaterialTextures/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/material/phongMaterialTextures/index.js b/examples/3d/material/phongMaterialTextures/index.js index c7a237ef3..662c790a5 100644 --- a/examples/3d/material/phongMaterialTextures/index.js +++ b/examples/3d/material/phongMaterialTextures/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; /** * [KO] Phong Material Textures 예제 @@ -71,7 +71,7 @@ const renderTestPane = async (redGPUContext) => { const { setSeparator, setDebugButtons - } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext); } diff --git a/examples/3d/material/uvTransform/index.html b/examples/3d/material/uvTransform/index.html index 93e0d44f2..3991dbc06 100644 --- a/examples/3d/material/uvTransform/index.html +++ b/examples/3d/material/uvTransform/index.html @@ -13,8 +13,8 @@ - - + + diff --git a/examples/3d/material/uvTransform/index.js b/examples/3d/material/uvTransform/index.js index 348df91f2..bfea6765e 100644 --- a/examples/3d/material/uvTransform/index.js +++ b/examples/3d/material/uvTransform/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; /** * [KO] UV Transform 예제 @@ -136,8 +136,8 @@ RedGPU.init( * [EN] Create UI panel function for test manipulation */ async function renderTestPane(redGPUContext, testTarget) { - const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); - const { setDebugButtons } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const { setDebugButtons } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext); diff --git a/examples/3d/mesh/basicMesh/index.html b/examples/3d/mesh/basicMesh/index.html index b4417a88f..77d781697 100644 --- a/examples/3d/mesh/basicMesh/index.html +++ b/examples/3d/mesh/basicMesh/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/mesh/basicMesh/index.js b/examples/3d/mesh/basicMesh/index.js index d7346d8c3..c09f648a1 100644 --- a/examples/3d/mesh/basicMesh/index.js +++ b/examples/3d/mesh/basicMesh/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; /** * [KO] Basic Mesh 예제 @@ -69,8 +69,8 @@ const createSampleMesh = (redGPUContext, scene) => { */ const renderTestPane = async (redGPUContext, mesh) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext) const pane = new Pane(); diff --git a/examples/3d/mesh/boundBox/meshAABBIntersects/index.html b/examples/3d/mesh/boundBox/meshAABBIntersects/index.html index c4cdcdf9a..c7c14d3dd 100644 --- a/examples/3d/mesh/boundBox/meshAABBIntersects/index.html +++ b/examples/3d/mesh/boundBox/meshAABBIntersects/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/3d/mesh/boundBox/meshAABBIntersects/index.js b/examples/3d/mesh/boundBox/meshAABBIntersects/index.js index 2de4162e3..01702513b 100644 --- a/examples/3d/mesh/boundBox/meshAABBIntersects/index.js +++ b/examples/3d/mesh/boundBox/meshAABBIntersects/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; /** * [KO] Mesh AABB Intersects 예제 @@ -48,7 +48,7 @@ RedGPU.init( * [EN] Sets up Tweakpane buttons for testing. */ const renderTestPane = async (redGPUContext, view) => { - const {setDebugButtons} = await import("../../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const {setDebugButtons} = await import("../../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext); }; diff --git a/examples/3d/mesh/boundBox/meshBoundBox/index.html b/examples/3d/mesh/boundBox/meshBoundBox/index.html index c4cdcdf9a..c7c14d3dd 100644 --- a/examples/3d/mesh/boundBox/meshBoundBox/index.html +++ b/examples/3d/mesh/boundBox/meshBoundBox/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/3d/mesh/boundBox/meshBoundBox/index.js b/examples/3d/mesh/boundBox/meshBoundBox/index.js index a8efe052c..47c2f3ca7 100644 --- a/examples/3d/mesh/boundBox/meshBoundBox/index.js +++ b/examples/3d/mesh/boundBox/meshBoundBox/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; /** * [KO] Mesh Bounding Box 예제 @@ -62,7 +62,7 @@ RedGPU.init( * [EN] Sets up test pane buttons. */ const renderTestPane = async (redGPUContext) => { - const {setDebugButtons} = await import("../../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const {setDebugButtons} = await import("../../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext); }; diff --git a/examples/3d/mesh/boundBox/meshOBBIntersects/index.html b/examples/3d/mesh/boundBox/meshOBBIntersects/index.html index c4cdcdf9a..c7c14d3dd 100644 --- a/examples/3d/mesh/boundBox/meshOBBIntersects/index.html +++ b/examples/3d/mesh/boundBox/meshOBBIntersects/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/3d/mesh/boundBox/meshOBBIntersects/index.js b/examples/3d/mesh/boundBox/meshOBBIntersects/index.js index c41587274..320393ecd 100644 --- a/examples/3d/mesh/boundBox/meshOBBIntersects/index.js +++ b/examples/3d/mesh/boundBox/meshOBBIntersects/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; /** * [KO] Mesh OBB Intersects 예제 @@ -48,7 +48,7 @@ RedGPU.init( * [EN] Initializes the test button pane. */ const renderTestPane = async (redGPUContext) => { - const {setDebugButtons} = await import("../../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const {setDebugButtons} = await import("../../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext); }; diff --git a/examples/3d/mesh/childMethod/index.html b/examples/3d/mesh/childMethod/index.html index b4417a88f..77d781697 100644 --- a/examples/3d/mesh/childMethod/index.html +++ b/examples/3d/mesh/childMethod/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/mesh/childMethod/index.js b/examples/3d/mesh/childMethod/index.js index 38080fd64..ada449c2a 100644 --- a/examples/3d/mesh/childMethod/index.js +++ b/examples/3d/mesh/childMethod/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; /** * [KO] Mesh Child Method 예제 @@ -70,8 +70,8 @@ const createInitialMeshes = (redGPUContext, scene) => { * @param {RedGPU.Display.Scene} scene */ const createPaneUI = async (redGPUContext, scene) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext) const pane = new Pane(); diff --git a/examples/3d/mesh/hierarchy/index.html b/examples/3d/mesh/hierarchy/index.html index b4417a88f..77d781697 100644 --- a/examples/3d/mesh/hierarchy/index.html +++ b/examples/3d/mesh/hierarchy/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/mesh/hierarchy/index.js b/examples/3d/mesh/hierarchy/index.js index c013d8835..8e0386839 100644 --- a/examples/3d/mesh/hierarchy/index.js +++ b/examples/3d/mesh/hierarchy/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; /** * [KO] Mesh Hierarchy 예제 @@ -91,8 +91,8 @@ const createChildMesh = (redGPUContext, parentMesh) => { */ const renderTestPane = async (redGPUContext, parentMesh, childMesh) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext) const pane = new Pane(); diff --git a/examples/3d/mesh/lookAt/index.html b/examples/3d/mesh/lookAt/index.html index b4417a88f..77d781697 100644 --- a/examples/3d/mesh/lookAt/index.html +++ b/examples/3d/mesh/lookAt/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/mesh/lookAt/index.js b/examples/3d/mesh/lookAt/index.js index b9be64a42..e4f77e4f3 100644 --- a/examples/3d/mesh/lookAt/index.js +++ b/examples/3d/mesh/lookAt/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; /** * [KO] Mesh LookAt 예제 @@ -59,7 +59,7 @@ RedGPU.init( * @param {RedGPU.RedGPUContext} redGPUContext */ const renderTestPane = async (redGPUContext) => { - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext); }; diff --git a/examples/3d/mesh/pivot/index.html b/examples/3d/mesh/pivot/index.html index b4417a88f..77d781697 100644 --- a/examples/3d/mesh/pivot/index.html +++ b/examples/3d/mesh/pivot/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/mesh/pivot/index.js b/examples/3d/mesh/pivot/index.js index 90c37166b..0a6483a88 100644 --- a/examples/3d/mesh/pivot/index.js +++ b/examples/3d/mesh/pivot/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; /** * [KO] Mesh Pivot 예제 @@ -138,8 +138,8 @@ const createPivotMesh = (redGPUContext, targetMesh) => { * @param {object} animationConfig */ const renderTestPane = async (redGPUContext, parentMesh, childMesh, animationConfig) => { - const {Pane} = await import("https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099"); - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const {Pane} = await import("https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext) const pane = new Pane(); diff --git a/examples/3d/noiseTexture/simplex/basic/index.html b/examples/3d/noiseTexture/simplex/basic/index.html index c4cdcdf9a..c7c14d3dd 100644 --- a/examples/3d/noiseTexture/simplex/basic/index.html +++ b/examples/3d/noiseTexture/simplex/basic/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/3d/noiseTexture/simplex/basic/index.js b/examples/3d/noiseTexture/simplex/basic/index.js index e65b42f7e..8461bd7b1 100644 --- a/examples/3d/noiseTexture/simplex/basic/index.js +++ b/examples/3d/noiseTexture/simplex/basic/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; /** * [KO] Simplex Noise (Basic) 예제 @@ -64,11 +64,11 @@ RedGPU.init( * @param {object} testData */ const renderTestPane = async (redGPUContext, targetNoiseTexture, testData) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { setSeparator, setDebugButtons - } = await import("../../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + } = await import("../../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); diff --git a/examples/3d/noiseTexture/simplex/displacement/index.html b/examples/3d/noiseTexture/simplex/displacement/index.html index c4cdcdf9a..c7c14d3dd 100644 --- a/examples/3d/noiseTexture/simplex/displacement/index.html +++ b/examples/3d/noiseTexture/simplex/displacement/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/3d/noiseTexture/simplex/displacement/index.js b/examples/3d/noiseTexture/simplex/displacement/index.js index 0b760969e..8435d8c08 100644 --- a/examples/3d/noiseTexture/simplex/displacement/index.js +++ b/examples/3d/noiseTexture/simplex/displacement/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; /** * [KO] Simplex Noise (Displacement) 예제 @@ -85,11 +85,11 @@ RedGPU.init( * @param {object} testData */ const renderTestPane = async (redGPUContext, targetNoiseTexture, testData) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { setSeparator, setDebugButtons - } = await import("../../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + } = await import("../../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); diff --git a/examples/3d/noiseTexture/simplex/fire/index.html b/examples/3d/noiseTexture/simplex/fire/index.html index c4cdcdf9a..c7c14d3dd 100644 --- a/examples/3d/noiseTexture/simplex/fire/index.html +++ b/examples/3d/noiseTexture/simplex/fire/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/3d/noiseTexture/simplex/fire/index.js b/examples/3d/noiseTexture/simplex/fire/index.js index 90b5c559a..df4756f38 100644 --- a/examples/3d/noiseTexture/simplex/fire/index.js +++ b/examples/3d/noiseTexture/simplex/fire/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; /** * [KO] Simplex Noise (Fire) 예제 @@ -120,11 +120,11 @@ RedGPU.init( * @param {object} testData */ const renderTestPane = async (redGPUContext, targetNoiseTexture, testData) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { setSeparator, setDebugButtons - } = await import("../../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + } = await import("../../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); diff --git a/examples/3d/noiseTexture/voronoi/basic/index.html b/examples/3d/noiseTexture/voronoi/basic/index.html index c4cdcdf9a..c7c14d3dd 100644 --- a/examples/3d/noiseTexture/voronoi/basic/index.html +++ b/examples/3d/noiseTexture/voronoi/basic/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/3d/noiseTexture/voronoi/basic/index.js b/examples/3d/noiseTexture/voronoi/basic/index.js index 7d77d2b41..08aa4ac63 100644 --- a/examples/3d/noiseTexture/voronoi/basic/index.js +++ b/examples/3d/noiseTexture/voronoi/basic/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; /** * [KO] Voronoi Noise (Basic) 예제 @@ -65,11 +65,11 @@ RedGPU.init( * @param {object} testData */ const renderTestPane = async (redGPUContext, targetNoiseTexture, testData) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { setSeparator, setDebugButtons - } = await import("../../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + } = await import("../../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); diff --git a/examples/3d/particle/basic/index.html b/examples/3d/particle/basic/index.html index b4417a88f..77d781697 100644 --- a/examples/3d/particle/basic/index.html +++ b/examples/3d/particle/basic/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/particle/basic/index.js b/examples/3d/particle/basic/index.js index 3f97b04c8..b481a98a9 100644 --- a/examples/3d/particle/basic/index.js +++ b/examples/3d/particle/basic/index.js @@ -1,5 +1,5 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; -import {setSeparator} from "../../../exampleHelper/createExample/panes/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import {setSeparator} from "../../../exampleHelper/createExample/panes/index.js?t=1770699661827"; // 1. Create and append a canvas // 1. 캔버스를 생성하고 문서에 추가 @@ -76,8 +76,8 @@ RedGPU.init( * @param {RedGPU.Display.ParticleEmitter} testParticle */ const renderTestPane = async (redGPUContext, testParticle) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); { diff --git a/examples/3d/particle/performance/index.html b/examples/3d/particle/performance/index.html index b4417a88f..77d781697 100644 --- a/examples/3d/particle/performance/index.html +++ b/examples/3d/particle/performance/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/particle/performance/index.js b/examples/3d/particle/performance/index.js index eb50838be..1c0c59e71 100644 --- a/examples/3d/particle/performance/index.js +++ b/examples/3d/particle/performance/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; // 1. Create and append a canvas // 1. 캔버스를 생성하고 문서에 추가 @@ -102,7 +102,7 @@ RedGPU.init( * @param {RedGPU.RedGPUContext} redGPUContext */ const renderTestPane = async (redGPUContext) => { - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext); }; \ No newline at end of file diff --git a/examples/3d/primitive/box/index.html b/examples/3d/primitive/box/index.html index b4417a88f..77d781697 100644 --- a/examples/3d/primitive/box/index.html +++ b/examples/3d/primitive/box/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/primitive/box/index.js b/examples/3d/primitive/box/index.js index 73ae36f8c..193ea8b7f 100644 --- a/examples/3d/primitive/box/index.js +++ b/examples/3d/primitive/box/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; /** * [KO] Box Primitive 예제 @@ -104,8 +104,8 @@ const createPrimitive = (redGPUContext, scene) => { * @param {RedGPU.RedGPUContext} redGPUContext - [KO] RedGPU 컨텍스트 [EN] RedGPU context */ const renderTestPane = async (redGPUContext) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext) const pane = new Pane(); diff --git a/examples/3d/primitive/capsule/index.html b/examples/3d/primitive/capsule/index.html index b4417a88f..77d781697 100644 --- a/examples/3d/primitive/capsule/index.html +++ b/examples/3d/primitive/capsule/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/primitive/capsule/index.js b/examples/3d/primitive/capsule/index.js index ec67e45da..f18c60ffd 100644 --- a/examples/3d/primitive/capsule/index.js +++ b/examples/3d/primitive/capsule/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; /** * [KO] Capsule Primitive 예제 @@ -119,8 +119,8 @@ const createPrimitive = (redGPUContext, scene) => { * @param {RedGPU.RedGPUContext} redGPUContext - [KO] RedGPU 컨텍스트 [EN] RedGPU context */ const renderTestPane = async (redGPUContext) => { - const {Pane} = await import("https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099"); - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const {Pane} = await import("https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext) const pane = new Pane(); diff --git a/examples/3d/primitive/circle/index.html b/examples/3d/primitive/circle/index.html index b4417a88f..77d781697 100644 --- a/examples/3d/primitive/circle/index.html +++ b/examples/3d/primitive/circle/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/primitive/circle/index.js b/examples/3d/primitive/circle/index.js index 41e5bfb7a..8dec66c57 100644 --- a/examples/3d/primitive/circle/index.js +++ b/examples/3d/primitive/circle/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; /** * [KO] Circle Primitive 예제 @@ -104,8 +104,8 @@ const createPrimitive = (redGPUContext, scene) => { * @param {RedGPU.RedGPUContext} redGPUContext - [KO] RedGPU 컨텍스트 [EN] RedGPU context */ const renderTestPane = async (redGPUContext) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext) const pane = new Pane(); diff --git a/examples/3d/primitive/cylinder/index.html b/examples/3d/primitive/cylinder/index.html index b4417a88f..77d781697 100644 --- a/examples/3d/primitive/cylinder/index.html +++ b/examples/3d/primitive/cylinder/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/primitive/cylinder/index.js b/examples/3d/primitive/cylinder/index.js index d13cde92f..8985b59b3 100644 --- a/examples/3d/primitive/cylinder/index.js +++ b/examples/3d/primitive/cylinder/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; /** * [KO] Cylinder Primitive 예제 @@ -125,8 +125,8 @@ const createPrimitive = (redGPUContext, scene) => { * @param {RedGPU.RedGPUContext} redGPUContext - [KO] RedGPU 컨텍스트 [EN] RedGPU context */ const renderTestPane = async (redGPUContext) => { - const {Pane} = await import("https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099"); - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const {Pane} = await import("https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext) const pane = new Pane(); diff --git a/examples/3d/primitive/ground/index.html b/examples/3d/primitive/ground/index.html index b4417a88f..77d781697 100644 --- a/examples/3d/primitive/ground/index.html +++ b/examples/3d/primitive/ground/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/primitive/ground/index.js b/examples/3d/primitive/ground/index.js index 185e929f5..db6ee97f1 100644 --- a/examples/3d/primitive/ground/index.js +++ b/examples/3d/primitive/ground/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; /** * [KO] Ground Primitive 예제 @@ -117,9 +117,9 @@ const createPrimitive = (redGPUContext, scene) => { * @param {RedGPU.RedGPUContext} redGPUContext - [KO] RedGPU 컨텍스트 [EN] RedGPU context */ const renderTestPane = async (redGPUContext) => { - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext) - const {Pane} = await import("https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099"); + const {Pane} = await import("https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827"); const pane = new Pane(); const config = { diff --git a/examples/3d/primitive/plane/index.html b/examples/3d/primitive/plane/index.html index b4417a88f..77d781697 100644 --- a/examples/3d/primitive/plane/index.html +++ b/examples/3d/primitive/plane/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/primitive/plane/index.js b/examples/3d/primitive/plane/index.js index f3cc721ba..7a24ace7d 100644 --- a/examples/3d/primitive/plane/index.js +++ b/examples/3d/primitive/plane/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; /** * [KO] Plane Primitive 예제 @@ -117,9 +117,9 @@ const createPrimitive = (redGPUContext, scene) => { * @param {RedGPU.RedGPUContext} redGPUContext - [KO] RedGPU 컨텍스트 [EN] RedGPU context */ const renderTestPane = async (redGPUContext) => { - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext) - const {Pane} = await import("https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099"); + const {Pane} = await import("https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827"); const pane = new Pane(); const config = { diff --git a/examples/3d/primitive/primitives/index.html b/examples/3d/primitive/primitives/index.html index b4417a88f..77d781697 100644 --- a/examples/3d/primitive/primitives/index.html +++ b/examples/3d/primitive/primitives/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/primitive/primitives/index.js b/examples/3d/primitive/primitives/index.js index 399ad3812..464c03d42 100644 --- a/examples/3d/primitive/primitives/index.js +++ b/examples/3d/primitive/primitives/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; /** * [KO] Primitives 예제 @@ -146,7 +146,7 @@ const createPrimitive = (redGPUContext, scene) => { const renderTestPane = async (redGPUContext) => { const { setDebugButtons - } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext) }; diff --git a/examples/3d/primitive/sphere/index.html b/examples/3d/primitive/sphere/index.html index b4417a88f..77d781697 100644 --- a/examples/3d/primitive/sphere/index.html +++ b/examples/3d/primitive/sphere/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/primitive/sphere/index.js b/examples/3d/primitive/sphere/index.js index 6d4fdb561..c2fcf9937 100644 --- a/examples/3d/primitive/sphere/index.js +++ b/examples/3d/primitive/sphere/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; /** * [KO] Sphere Primitive 예제 @@ -125,8 +125,8 @@ const createPrimitive = (redGPUContext, scene) => { * @param {RedGPU.RedGPUContext} redGPUContext - [KO] RedGPU 컨텍스트 [EN] RedGPU context */ const renderTestPane = async (redGPUContext) => { - const {Pane} = await import("https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099"); - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const {Pane} = await import("https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext) const pane = new Pane(); diff --git a/examples/3d/primitive/torus/index.html b/examples/3d/primitive/torus/index.html index b4417a88f..77d781697 100644 --- a/examples/3d/primitive/torus/index.html +++ b/examples/3d/primitive/torus/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/primitive/torus/index.js b/examples/3d/primitive/torus/index.js index fbbdd746b..ab8a737b8 100644 --- a/examples/3d/primitive/torus/index.js +++ b/examples/3d/primitive/torus/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; /** * [KO] Torus Primitive 예제 @@ -121,9 +121,9 @@ const createPrimitive = (redGPUContext, scene) => { * @param {RedGPU.RedGPUContext} redGPUContext - [KO] RedGPU 컨텍스트 [EN] RedGPU context */ const renderTestPane = async (redGPUContext) => { - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext) - const {Pane} = await import("https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099"); + const {Pane} = await import("https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827"); const pane = new Pane(); const config = { diff --git a/examples/3d/primitive/torusNut/index.html b/examples/3d/primitive/torusNut/index.html index b4417a88f..77d781697 100644 --- a/examples/3d/primitive/torusNut/index.html +++ b/examples/3d/primitive/torusNut/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/primitive/torusNut/index.js b/examples/3d/primitive/torusNut/index.js index 4bdef59aa..2837c5cc9 100644 --- a/examples/3d/primitive/torusNut/index.js +++ b/examples/3d/primitive/torusNut/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; /** * [KO] TorusKnot Primitive 예제 @@ -121,9 +121,9 @@ const createPrimitive = (redGPUContext, scene) => { * @param {RedGPU.RedGPUContext} redGPUContext - [KO] RedGPU 컨텍스트 [EN] RedGPU context */ const renderTestPane = async (redGPUContext) => { - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext) - const {Pane} = await import("https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099"); + const {Pane} = await import("https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827"); const pane = new Pane(); const config = { diff --git a/examples/3d/scene/index.html b/examples/3d/scene/index.html index 19ffd6889..b3924120d 100644 --- a/examples/3d/scene/index.html +++ b/examples/3d/scene/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/scene/index.js b/examples/3d/scene/index.js index 70ea6c25e..d8d8bb34a 100644 --- a/examples/3d/scene/index.js +++ b/examples/3d/scene/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../dist/index.js?t=1770699661827"; /** * [KO] Scene 예제 @@ -51,13 +51,13 @@ RedGPU.init( * @param {RedGPU.RedGPUContext} redGPUContext */ const renderTestPane = async (redGPUContext) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { setRedGPUTest_pane, setViewListTest, setSceneListTest, setDebugButtons - } = await import("../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + } = await import("../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext) const pane = new Pane(); setSceneListTest(pane, redGPUContext.viewList.flatMap(v => v.scene), true); diff --git a/examples/3d/shadow/directionalShadow/index.html b/examples/3d/shadow/directionalShadow/index.html index b4417a88f..77d781697 100644 --- a/examples/3d/shadow/directionalShadow/index.html +++ b/examples/3d/shadow/directionalShadow/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/shadow/directionalShadow/index.js b/examples/3d/shadow/directionalShadow/index.js index e0b98d897..5103ddb2e 100644 --- a/examples/3d/shadow/directionalShadow/index.js +++ b/examples/3d/shadow/directionalShadow/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; /** * [KO] Directional Shadow 예제 @@ -135,8 +135,8 @@ const getRandomHexValue = () => { * @param {RedGPU.Display.Scene} scene */ const renderTestPane = async (redGPUContext, scene) => { - const {Pane} = await import("https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099"); - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const {Pane} = await import("https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); const {shadowManager} = scene; diff --git a/examples/3d/shadow/gltfDirectionalShadow/index.html b/examples/3d/shadow/gltfDirectionalShadow/index.html index b4417a88f..77d781697 100644 --- a/examples/3d/shadow/gltfDirectionalShadow/index.html +++ b/examples/3d/shadow/gltfDirectionalShadow/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/shadow/gltfDirectionalShadow/index.js b/examples/3d/shadow/gltfDirectionalShadow/index.js index 807c4cd52..eb39c1670 100644 --- a/examples/3d/shadow/gltfDirectionalShadow/index.js +++ b/examples/3d/shadow/gltfDirectionalShadow/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; /** * [KO] GLTF Directional Shadow 예제 @@ -99,10 +99,10 @@ const addGround = (redGPUContext, scene) => { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import("https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099"); - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const {Pane} = await import("https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext); - const {createIblHelper} = await import('../../../exampleHelper/createExample/panes/index.js?t=1770698056099'); + const {createIblHelper} = await import('../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); const pane = new Pane(); const {shadowManager} = targetView.scene; diff --git a/examples/3d/skybox/ibl/brdfLutTest/index.html b/examples/3d/skybox/ibl/brdfLutTest/index.html index bd3eab198..beec74561 100644 --- a/examples/3d/skybox/ibl/brdfLutTest/index.html +++ b/examples/3d/skybox/ibl/brdfLutTest/index.html @@ -7,8 +7,8 @@ - - + + diff --git a/examples/3d/skybox/ibl/brdfLutTest/index.js b/examples/3d/skybox/ibl/brdfLutTest/index.js index 71a8df253..f52e1e4c2 100644 --- a/examples/3d/skybox/ibl/brdfLutTest/index.js +++ b/examples/3d/skybox/ibl/brdfLutTest/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); diff --git a/examples/3d/skybox/ibl/iblTest/index.html b/examples/3d/skybox/ibl/iblTest/index.html index 491f20df4..ea0e3b2db 100644 --- a/examples/3d/skybox/ibl/iblTest/index.html +++ b/examples/3d/skybox/ibl/iblTest/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/skybox/ibl/iblTest/index.js b/examples/3d/skybox/ibl/iblTest/index.js index 186ca0372..d56fb204a 100644 --- a/examples/3d/skybox/ibl/iblTest/index.js +++ b/examples/3d/skybox/ibl/iblTest/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; /** * [KO] IBL Test 예제 @@ -146,13 +146,13 @@ const createIBL = (view, src) => { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (targetView) => { - const {Pane} = await import( "https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099" ); + const {Pane} = await import( "https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827" ); const pane = new Pane(); const { createFieldOfView, createSkyBoxHelper, setDebugButtons - } = await import( "../../../../exampleHelper/createExample/panes/index.js?t=1770698056099" ); + } = await import( "../../../../exampleHelper/createExample/panes/index.js?t=1770699661827" ); setDebugButtons(RedGPU, targetView.redGPUContext); createFieldOfView(pane, targetView.camera) createSkyBoxHelper(pane, targetView); diff --git a/examples/3d/skybox/ibl/iblTextureSize/index.html b/examples/3d/skybox/ibl/iblTextureSize/index.html index 990701c6c..2b934b837 100644 --- a/examples/3d/skybox/ibl/iblTextureSize/index.html +++ b/examples/3d/skybox/ibl/iblTextureSize/index.html @@ -8,8 +8,8 @@ - - + +
diff --git a/examples/3d/skybox/ibl/iblTextureSize/index.js b/examples/3d/skybox/ibl/iblTextureSize/index.js index 366b03150..5073f6c7a 100644 --- a/examples/3d/skybox/ibl/iblTextureSize/index.js +++ b/examples/3d/skybox/ibl/iblTextureSize/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; // 1. Create and append a canvas // 1. 캔버스를 생성하고 문서에 추가 @@ -144,9 +144,9 @@ function loadGLTF(redGPUContext, scene, url) { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); - const {createPostEffectLabel} = await import('../../../../exampleHelper/createExample/loadExampleInfo/createPostEffectLabel.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {createPostEffectLabel} = await import('../../../../exampleHelper/createExample/loadExampleInfo/createPostEffectLabel.js?t=1770699661827'); createPostEffectLabel('Custom IBL Texture Size 16 * 16', redGPUContext.detector.isMobile, 'Basic IBL Texture Size 512 * 512') - const {setDebugButtons} = await import( "../../../../exampleHelper/createExample/panes/index.js?t=1770698056099" ); + const {setDebugButtons} = await import( "../../../../exampleHelper/createExample/panes/index.js?t=1770699661827" ); setDebugButtons(RedGPU, redGPUContext); }; \ No newline at end of file diff --git a/examples/3d/skybox/ibl/irradianceTest/index.html b/examples/3d/skybox/ibl/irradianceTest/index.html index bd3eab198..beec74561 100644 --- a/examples/3d/skybox/ibl/irradianceTest/index.html +++ b/examples/3d/skybox/ibl/irradianceTest/index.html @@ -7,8 +7,8 @@ - - + + diff --git a/examples/3d/skybox/ibl/irradianceTest/index.js b/examples/3d/skybox/ibl/irradianceTest/index.js index 99d6a75ad..fca3592f1 100644 --- a/examples/3d/skybox/ibl/irradianceTest/index.js +++ b/examples/3d/skybox/ibl/irradianceTest/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -55,6 +55,6 @@ RedGPU.init( ); const renderTestPane = async (redGPUContext, scene, hdrTexture) => { - const {setDebugButtons} = await import("../../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const {setDebugButtons} = await import("../../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext); }; \ No newline at end of file diff --git a/examples/3d/skybox/ibl/skyboxWithIbl/index.html b/examples/3d/skybox/ibl/skyboxWithIbl/index.html index 491f20df4..ea0e3b2db 100644 --- a/examples/3d/skybox/ibl/skyboxWithIbl/index.html +++ b/examples/3d/skybox/ibl/skyboxWithIbl/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/skybox/ibl/skyboxWithIbl/index.js b/examples/3d/skybox/ibl/skyboxWithIbl/index.js index 3da64fb13..1d72bcec8 100644 --- a/examples/3d/skybox/ibl/skyboxWithIbl/index.js +++ b/examples/3d/skybox/ibl/skyboxWithIbl/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; /** * [KO] Skybox With IBL 예제 @@ -42,13 +42,13 @@ RedGPU.init( * @param {RedGPU.Display.View3D} view */ const renderTestPane = async (view) => { - const {Pane} = await import( "https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099" ); + const {Pane} = await import( "https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827" ); const pane = new Pane(); const { createFieldOfView, createIblHelper, setDebugButtons - } = await import( "../../../../exampleHelper/createExample/panes/index.js?t=1770698056099" ); + } = await import( "../../../../exampleHelper/createExample/panes/index.js?t=1770699661827" ); setDebugButtons(RedGPU, view.redGPUContext); createFieldOfView(pane, view.camera); createIblHelper(pane, view, RedGPU); diff --git a/examples/3d/skybox/skybox/index.html b/examples/3d/skybox/skybox/index.html index b4417a88f..77d781697 100644 --- a/examples/3d/skybox/skybox/index.html +++ b/examples/3d/skybox/skybox/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/skybox/skybox/index.js b/examples/3d/skybox/skybox/index.js index 005b63e19..c7c2454fe 100644 --- a/examples/3d/skybox/skybox/index.js +++ b/examples/3d/skybox/skybox/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; /** * [KO] Skybox 예제 @@ -65,13 +65,13 @@ const createSkybox = (redGPUContext) => { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (targetView) => { - const {Pane} = await import( "https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099" ); + const {Pane} = await import( "https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827" ); const pane = new Pane(); const { createFieldOfView, createSkyBoxHelper, setDebugButtons - } = await import( "../../../exampleHelper/createExample/panes/index.js?t=1770698056099" ); + } = await import( "../../../exampleHelper/createExample/panes/index.js?t=1770699661827" ); setDebugButtons(RedGPU, targetView.redGPUContext); createFieldOfView(pane, targetView.camera) createSkyBoxHelper(pane, targetView) diff --git a/examples/3d/skybox/transition/skyboxTransition/index.html b/examples/3d/skybox/transition/skyboxTransition/index.html index c4cdcdf9a..c7c14d3dd 100644 --- a/examples/3d/skybox/transition/skyboxTransition/index.html +++ b/examples/3d/skybox/transition/skyboxTransition/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/3d/skybox/transition/skyboxTransition/index.js b/examples/3d/skybox/transition/skyboxTransition/index.js index 01db8e898..b176dfe03 100644 --- a/examples/3d/skybox/transition/skyboxTransition/index.js +++ b/examples/3d/skybox/transition/skyboxTransition/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -98,12 +98,12 @@ const createTexture = (redGPUContext, option) => { * @param {RedGPU.RedGPUContext} redGPUContext */ const renderTestPane = async (targetView, redGPUContext) => { - const {Pane} = await import("https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099"); + const {Pane} = await import("https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827"); const pane = new Pane(); const { createFieldOfView, createSkyBoxHelper - } = await import("../../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + } = await import("../../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); createFieldOfView(pane, targetView.camera); createSkyBoxHelper(pane, targetView); diff --git a/examples/3d/skybox/transition/skyboxTransitionWithNoiseTexture/index.html b/examples/3d/skybox/transition/skyboxTransitionWithNoiseTexture/index.html index c4cdcdf9a..c7c14d3dd 100644 --- a/examples/3d/skybox/transition/skyboxTransitionWithNoiseTexture/index.html +++ b/examples/3d/skybox/transition/skyboxTransitionWithNoiseTexture/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/3d/skybox/transition/skyboxTransitionWithNoiseTexture/index.js b/examples/3d/skybox/transition/skyboxTransitionWithNoiseTexture/index.js index a22c583c5..cbf3a549f 100644 --- a/examples/3d/skybox/transition/skyboxTransitionWithNoiseTexture/index.js +++ b/examples/3d/skybox/transition/skyboxTransitionWithNoiseTexture/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -100,13 +100,13 @@ const createTexture = (redGPUContext, option) => { * @param {RedGPU.RedGPUContext} redGPUContext */ const renderTestPane = async (targetView, redGPUContext) => { - const {Pane} = await import("https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099"); + const {Pane} = await import("https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827"); const pane = new Pane(); const { createFieldOfView, setSeparator, createSkyBoxHelper - } = await import("../../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + } = await import("../../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); createFieldOfView(pane, targetView.camera); createSkyBoxHelper(pane, targetView); diff --git a/examples/3d/sprite/sprite3D/index.html b/examples/3d/sprite/sprite3D/index.html index b4417a88f..77d781697 100644 --- a/examples/3d/sprite/sprite3D/index.html +++ b/examples/3d/sprite/sprite3D/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/sprite/sprite3D/index.js b/examples/3d/sprite/sprite3D/index.js index d6509ed53..4ee2d7106 100644 --- a/examples/3d/sprite/sprite3D/index.js +++ b/examples/3d/sprite/sprite3D/index.js @@ -6,7 +6,7 @@ * [EN] Demonstrates the usage of Sprite3D in 3D space, including features like billboard and pixel size modes. * @packageDocumentation */ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -107,11 +107,11 @@ RedGPU.init( * [EN] Scene containing the sprites to control */ const renderTestPane = async (redGPUContext, scene) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { setDebugButtons, setSeparator - } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); diff --git a/examples/3d/sprite/sprite3DCompare/index.html b/examples/3d/sprite/sprite3DCompare/index.html index 98a6aad04..3ac178d0f 100644 --- a/examples/3d/sprite/sprite3DCompare/index.html +++ b/examples/3d/sprite/sprite3DCompare/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/sprite/sprite3DCompare/index.js b/examples/3d/sprite/sprite3DCompare/index.js index 5c6187dee..17a5986ec 100644 --- a/examples/3d/sprite/sprite3DCompare/index.js +++ b/examples/3d/sprite/sprite3DCompare/index.js @@ -6,7 +6,7 @@ * [EN] Demonstrates the difference between World Size (worldSize) and fixed Pixel Size (pixelSize) modes. * @packageDocumentation */ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -79,8 +79,8 @@ RedGPU.init(canvas, (redGPUContext) => { }); const renderTestPane = async (redGPUContext, spriteWorld, spritePixel) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); diff --git a/examples/3d/sprite/spriteSheet3D/index.html b/examples/3d/sprite/spriteSheet3D/index.html index b4417a88f..77d781697 100644 --- a/examples/3d/sprite/spriteSheet3D/index.html +++ b/examples/3d/sprite/spriteSheet3D/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/sprite/spriteSheet3D/index.js b/examples/3d/sprite/spriteSheet3D/index.js index ed95d394d..118c8727a 100644 --- a/examples/3d/sprite/spriteSheet3D/index.js +++ b/examples/3d/sprite/spriteSheet3D/index.js @@ -6,7 +6,7 @@ * [EN] Demonstrates the usage of SpriteSheet3D in 3D space, including features like billboard and pixel size modes. * @packageDocumentation */ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -86,11 +86,11 @@ RedGPU.init(canvas, (redGPUContext) => { * [EN] Scene containing the sprites to control */ const renderTestPane = async (redGPUContext, scene) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { setDebugButtons, setSeparator - } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); diff --git a/examples/3d/sprite/spriteSheet3DCompare/index.html b/examples/3d/sprite/spriteSheet3DCompare/index.html index e091d381f..0f3965117 100644 --- a/examples/3d/sprite/spriteSheet3DCompare/index.html +++ b/examples/3d/sprite/spriteSheet3DCompare/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/sprite/spriteSheet3DCompare/index.js b/examples/3d/sprite/spriteSheet3DCompare/index.js index 80669d9be..01b37e207 100644 --- a/examples/3d/sprite/spriteSheet3DCompare/index.js +++ b/examples/3d/sprite/spriteSheet3DCompare/index.js @@ -6,7 +6,7 @@ * [EN] Demonstrates the difference between World Size (worldSize) and fixed Pixel Size (pixelSize) modes. * @packageDocumentation */ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -89,8 +89,8 @@ RedGPU.init(canvas, (redGPUContext) => { }); const renderTestPane = async (redGPUContext, worldSprite, pixelSprite) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); diff --git a/examples/3d/textField/textField3D/index.html b/examples/3d/textField/textField3D/index.html index e091d381f..0f3965117 100644 --- a/examples/3d/textField/textField3D/index.html +++ b/examples/3d/textField/textField3D/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/textField/textField3D/index.js b/examples/3d/textField/textField3D/index.js index 3db9f2d39..0affe66f9 100644 --- a/examples/3d/textField/textField3D/index.js +++ b/examples/3d/textField/textField3D/index.js @@ -6,7 +6,7 @@ * [EN] Demonstrates the usage of TextField3D in 3D space, including features like billboard and styling. * @packageDocumentation */ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -84,8 +84,8 @@ RedGPU.init(canvas, (redGPUContext) => { * [EN] Scene containing the text fields to control */ const renderTestPane = async (redGPUContext, scene) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); - const {setDebugButtons, setSeparator} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {setDebugButtons, setSeparator} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); diff --git a/examples/3d/textField/textField3DCompare/index.html b/examples/3d/textField/textField3DCompare/index.html index e091d381f..0f3965117 100644 --- a/examples/3d/textField/textField3DCompare/index.html +++ b/examples/3d/textField/textField3DCompare/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/textField/textField3DCompare/index.js b/examples/3d/textField/textField3DCompare/index.js index 63c4f861c..27ed5d647 100644 --- a/examples/3d/textField/textField3DCompare/index.js +++ b/examples/3d/textField/textField3DCompare/index.js @@ -6,7 +6,7 @@ * [EN] Demonstrates the difference between World Size (worldSize) and fixed Pixel Size (usePixelSize) modes for TextField3D. * @packageDocumentation */ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -56,8 +56,8 @@ RedGPU.init( ); const renderTestPane = async (redGPUContext, textWorld, textPixel) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); diff --git a/examples/3d/texture/bitmapTextureSampler/index.html b/examples/3d/texture/bitmapTextureSampler/index.html index b4417a88f..77d781697 100644 --- a/examples/3d/texture/bitmapTextureSampler/index.html +++ b/examples/3d/texture/bitmapTextureSampler/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/texture/bitmapTextureSampler/index.js b/examples/3d/texture/bitmapTextureSampler/index.js index 3f4ba0dfc..f345d899d 100644 --- a/examples/3d/texture/bitmapTextureSampler/index.js +++ b/examples/3d/texture/bitmapTextureSampler/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; /** * [KO] Bitmap Texture Sampler 예제 @@ -70,11 +70,11 @@ const addSingleMesh = (redGPUContext, scene) => { * @param {RedGPU.Display.Mesh} mesh */ const renderTestPane = async (redGPUContext, mesh) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { setSeparator, setDebugButtons - } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); diff --git a/examples/3d/texture/maxAnisotropy/index.html b/examples/3d/texture/maxAnisotropy/index.html index b4417a88f..77d781697 100644 --- a/examples/3d/texture/maxAnisotropy/index.html +++ b/examples/3d/texture/maxAnisotropy/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/texture/maxAnisotropy/index.js b/examples/3d/texture/maxAnisotropy/index.js index 2ab7becbe..9fd8eaa14 100644 --- a/examples/3d/texture/maxAnisotropy/index.js +++ b/examples/3d/texture/maxAnisotropy/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; /** * [KO] Max Anisotropy 예제 @@ -50,7 +50,7 @@ const renderTestPane = async (redGPUContext, scene) => { const { setSeparator, setDebugButtons - } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext); const maxAnisotropyValues = [1, 8, 16]; const spacing = 105; diff --git a/examples/3d/texture/samplerAddressMode/index.html b/examples/3d/texture/samplerAddressMode/index.html index b4417a88f..77d781697 100644 --- a/examples/3d/texture/samplerAddressMode/index.html +++ b/examples/3d/texture/samplerAddressMode/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/texture/samplerAddressMode/index.js b/examples/3d/texture/samplerAddressMode/index.js index 575ae0933..c2f00a240 100644 --- a/examples/3d/texture/samplerAddressMode/index.js +++ b/examples/3d/texture/samplerAddressMode/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; /** * [KO] Sampler Address Mode 예제 @@ -53,7 +53,7 @@ const renderTestPane = async (redGPUContext,) => { const { setSeparator, setDebugButtons - } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext); } diff --git a/examples/3d/texture/samplerCombination/index.html b/examples/3d/texture/samplerCombination/index.html index b4417a88f..77d781697 100644 --- a/examples/3d/texture/samplerCombination/index.html +++ b/examples/3d/texture/samplerCombination/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/texture/samplerCombination/index.js b/examples/3d/texture/samplerCombination/index.js index 13313311e..cde880f87 100644 --- a/examples/3d/texture/samplerCombination/index.js +++ b/examples/3d/texture/samplerCombination/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; /** * [KO] Sampler Combination 예제 @@ -54,7 +54,7 @@ const renderTestPane = async (redGPUContext,) => { const { setSeparator, setDebugButtons - } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext); } diff --git a/examples/3d/tint/basic/index.html b/examples/3d/tint/basic/index.html index b4417a88f..77d781697 100644 --- a/examples/3d/tint/basic/index.html +++ b/examples/3d/tint/basic/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/tint/basic/index.js b/examples/3d/tint/basic/index.js index 5e63cefa3..ba8d367c1 100644 --- a/examples/3d/tint/basic/index.js +++ b/examples/3d/tint/basic/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; /** * [KO] Tint Basic (3D) 예제 @@ -70,9 +70,9 @@ RedGPU.init( * @param {RedGPU.Display.Mesh} mesh */ const renderTestPane = async (redGPUContext, mesh) => { - const {Pane} = await import("https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099"); + const {Pane} = await import("https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827"); const pane = new Pane(); - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext); // Tint 테스트 추가 const folder = pane.addFolder({title: "Material Tint Test"}); diff --git a/examples/3d/transparentSort/index.html b/examples/3d/transparentSort/index.html index 19ffd6889..b3924120d 100644 --- a/examples/3d/transparentSort/index.html +++ b/examples/3d/transparentSort/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/transparentSort/index.js b/examples/3d/transparentSort/index.js index f87a8db14..26df92dcc 100644 --- a/examples/3d/transparentSort/index.js +++ b/examples/3d/transparentSort/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../dist/index.js?t=1770699661827"; /** * [KO] Transparent Sort 예제 @@ -131,9 +131,9 @@ const getRandomHexValue = () => { */ const renderTestPane = async (redGPUContext) => { const {Pane} = await import( - "https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099" + "https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827" ); - const {setDebugButtons} = await import( "../../exampleHelper/createExample/panes/index.js?t=1770698056099" ); + const {setDebugButtons} = await import( "../../exampleHelper/createExample/panes/index.js?t=1770699661827" ); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); const params = { diff --git a/examples/3d/view/multiView/index.html b/examples/3d/view/multiView/index.html index b4417a88f..77d781697 100644 --- a/examples/3d/view/multiView/index.html +++ b/examples/3d/view/multiView/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/view/multiView/index.js b/examples/3d/view/multiView/index.js index 16a101bfd..c35e3312d 100644 --- a/examples/3d/view/multiView/index.js +++ b/examples/3d/view/multiView/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; /** * [KO] Multi View 예제 @@ -101,11 +101,11 @@ RedGPU.init( * @param {RedGPU.RedGPUContext} redGPUContext */ const renderTestPane = async (redGPUContext) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { setViewListTest, setDebugButtons - } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext) const pane = new Pane(); setViewListTest(pane, redGPUContext.viewList, true); diff --git a/examples/3d/view/singleView/index.html b/examples/3d/view/singleView/index.html index c4bd4692f..a6887ba00 100644 --- a/examples/3d/view/singleView/index.html +++ b/examples/3d/view/singleView/index.html @@ -7,8 +7,8 @@ - - + + diff --git a/examples/3d/view/singleView/index.js b/examples/3d/view/singleView/index.js index 8c95b492d..0bbb0ec52 100644 --- a/examples/3d/view/singleView/index.js +++ b/examples/3d/view/singleView/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; /** * [KO] Single View 예제 @@ -70,11 +70,11 @@ RedGPU.init( * @param {RedGPU.RedGPUContext} redGPUContext */ const renderTestPane = async (redGPUContext) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { setViewListTest, setDebugButtons - } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext) const pane = new Pane(); setViewListTest(pane, redGPUContext.viewList, true); diff --git a/examples/exampleHelper/createExample/loadExampleInfo/index.js b/examples/exampleHelper/createExample/loadExampleInfo/index.js index 6ef7b21be..34d03d22d 100644 --- a/examples/exampleHelper/createExample/loadExampleInfo/index.js +++ b/examples/exampleHelper/createExample/loadExampleInfo/index.js @@ -1,6 +1,6 @@ -const codeSrc = 'index.js?t=1770698056099'; +const codeSrc = 'index.js?t=1770699661827'; const prismCSS = 'https://cdnjs.cloudflare.com/ajax/libs/prism/1.29.0/themes/prism-tomorrow.min.css'; -const prismJS = 'https://cdnjs.cloudflare.com/ajax/libs/prism/1.29.0/prism.min.js?t=1770698056099'; +const prismJS = 'https://cdnjs.cloudflare.com/ajax/libs/prism/1.29.0/prism.min.js?t=1770699661827'; const loadPrism = async () => { if (!document.querySelector(`link[href="${prismCSS}"]`)) { @@ -27,7 +27,7 @@ const loadDescription = async () => { const mainCategory = getCategoryFromPath(currentFullPath); - const ExampleList = await import('../../exampleList/exampleList.js?t=1770698056099'); + const ExampleList = await import('../../exampleList/exampleList.js?t=1770699661827'); const categoryData = ExampleList.default.find(category => category.name.toLowerCase() === mainCategory); if (!categoryData) { diff --git a/examples/exampleHelper/createExample/panes/createIblHelper.js b/examples/exampleHelper/createExample/panes/createIblHelper.js index 5cb50b99f..58ee730f7 100644 --- a/examples/exampleHelper/createExample/panes/createIblHelper.js +++ b/examples/exampleHelper/createExample/panes/createIblHelper.js @@ -1,5 +1,5 @@ -import {hdrImages} from './index.js?t=1770698056099'; -import createSkyBoxHelper from './createSkyBoxHelper.js?t=1770698056099'; +import {hdrImages} from './index.js?t=1770699661827'; +import createSkyBoxHelper from './createSkyBoxHelper.js?t=1770699661827'; const createIblHelper = (pane, view, RedGPU, option = {}) => { const folder = pane.addFolder({title: 'Lighting', expanded: true}); diff --git a/examples/exampleHelper/createExample/panes/index.js b/examples/exampleHelper/createExample/panes/index.js index c92a4e308..7301d66e1 100644 --- a/examples/exampleHelper/createExample/panes/index.js +++ b/examples/exampleHelper/createExample/panes/index.js @@ -1,16 +1,16 @@ -import createBitmapTextureTest from "./createBitmapTextureTest.js?t=1770698056099"; -import createCameraTest from "./createCameraTest.js?t=1770698056099"; -import createFieldOfView from "./createFieldOfView.js?t=1770698056099"; -import createGridTest from "./createGridTest.js?t=1770698056099"; -import createIblHelper from "./createIblHelper.js?t=1770698056099"; -import createSkyBoxHelper from "./createSkyBoxHelper.js?t=1770698056099"; -import setSceneListTest from "./scene/setSceneListTest.js?t=1770698056099"; -import setSingleSceneTest from "./scene/setSingleSceneTest.js?t=1770698056099"; -import setAntialiasing_pane from "./setAntialiasing_pane.js?t=1770698056099"; -import setRedGPUTest_pane from "./setRedGPUTest_pane.js?t=1770698056099"; -import setSingleViewTest from "./view/setSingleViewTest.js?t=1770698056099"; -import setViewListTest from "./view/setViewListTest.js?t=1770698056099"; -import setViewListTest_Pane from "./view/setViewListTest.js?t=1770698056099"; +import createBitmapTextureTest from "./createBitmapTextureTest.js?t=1770699661827"; +import createCameraTest from "./createCameraTest.js?t=1770699661827"; +import createFieldOfView from "./createFieldOfView.js?t=1770699661827"; +import createGridTest from "./createGridTest.js?t=1770699661827"; +import createIblHelper from "./createIblHelper.js?t=1770699661827"; +import createSkyBoxHelper from "./createSkyBoxHelper.js?t=1770699661827"; +import setSceneListTest from "./scene/setSceneListTest.js?t=1770699661827"; +import setSingleSceneTest from "./scene/setSingleSceneTest.js?t=1770699661827"; +import setAntialiasing_pane from "./setAntialiasing_pane.js?t=1770699661827"; +import setRedGPUTest_pane from "./setRedGPUTest_pane.js?t=1770699661827"; +import setSingleViewTest from "./view/setSingleViewTest.js?t=1770699661827"; +import setViewListTest from "./view/setViewListTest.js?t=1770699661827"; +import setViewListTest_Pane from "./view/setViewListTest.js?t=1770699661827"; /** * Sets a separator in the given pane. diff --git a/examples/exampleHelper/createExample/panes/scene/setSceneListTest.js b/examples/exampleHelper/createExample/panes/scene/setSceneListTest.js index d00a3e148..35e1ede4b 100644 --- a/examples/exampleHelper/createExample/panes/scene/setSceneListTest.js +++ b/examples/exampleHelper/createExample/panes/scene/setSceneListTest.js @@ -1,4 +1,4 @@ -import {setSingleSceneTest} from "../index.js?t=1770698056099"; +import {setSingleSceneTest} from "../index.js?t=1770699661827"; const setSceneListTest = (pane, sceneList, shouldExpand = false,) => { const title = sceneList.length === 1 ? sceneList[0].name : 'sceneList'; diff --git a/examples/exampleHelper/createExample/panes/view/setSingleViewTest.js b/examples/exampleHelper/createExample/panes/view/setSingleViewTest.js index ec8a28a0e..56bea0b65 100644 --- a/examples/exampleHelper/createExample/panes/view/setSingleViewTest.js +++ b/examples/exampleHelper/createExample/panes/view/setSingleViewTest.js @@ -1,4 +1,4 @@ -import setSingleSceneTest from "../scene/setSingleSceneTest.js?t=1770698056099"; +import setSingleSceneTest from "../scene/setSingleSceneTest.js?t=1770699661827"; const PERCENT_MAX = 200; const PIXEL_MAX = 2048; diff --git a/examples/exampleHelper/createExample/panes/view/setViewListTest.js b/examples/exampleHelper/createExample/panes/view/setViewListTest.js index 6220bfe11..c0ebcc362 100644 --- a/examples/exampleHelper/createExample/panes/view/setViewListTest.js +++ b/examples/exampleHelper/createExample/panes/view/setViewListTest.js @@ -1,4 +1,4 @@ -import {setSingleViewTest} from "../index.js?t=1770698056099"; +import {setSingleViewTest} from "../index.js?t=1770699661827"; const setViewListTest = (pane, viewList, shouldExpand = false, camera2DYn = false) => { const title = viewList.length === 1 ? viewList[0].name : 'ViewList'; diff --git a/examples/exampleHelper/exampleList/createExampleList.js b/examples/exampleHelper/exampleList/createExampleList.js index 47ab19517..70186dbbe 100644 --- a/examples/exampleHelper/exampleList/createExampleList.js +++ b/examples/exampleHelper/exampleList/createExampleList.js @@ -1,4 +1,4 @@ -import ExampleList from './exampleList.js?t=1770698056099'; +import ExampleList from './exampleList.js?t=1770699661827'; // 상태 관리 - sessionStorage에 저장/복원할 항목들 const STATE_KEY = 'redgpu_examples_state'; diff --git a/examples/exampleHelper/indexSample.html b/examples/exampleHelper/indexSample.html index c59dec1fd..23a4dec82 100644 --- a/examples/exampleHelper/indexSample.html +++ b/examples/exampleHelper/indexSample.html @@ -22,7 +22,7 @@ - + + diff --git a/examples/gltf/animation/basicAnimations/index.js b/examples/gltf/animation/basicAnimations/index.js index 74b504a7e..c68035eb9 100644 --- a/examples/gltf/animation/basicAnimations/index.js +++ b/examples/gltf/animation/basicAnimations/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; import { loadingProgressInfoHandler -} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770698056099' +} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' /** * [KO] Basic Animations 예제 @@ -89,11 +89,11 @@ function loadGLTFGrid(view, urls, gridSize = 5, spacing = 5) { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { createIblHelper, setDebugButtons - } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770698056099'); + } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/animation/brainStem/index.html b/examples/gltf/animation/brainStem/index.html index b4417a88f..77d781697 100644 --- a/examples/gltf/animation/brainStem/index.html +++ b/examples/gltf/animation/brainStem/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/gltf/animation/brainStem/index.js b/examples/gltf/animation/brainStem/index.js index 8ee0600d0..064a598a3 100644 --- a/examples/gltf/animation/brainStem/index.js +++ b/examples/gltf/animation/brainStem/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; /** * [KO] BrainStem 예제 @@ -62,11 +62,11 @@ function loadGLTF(view, url) { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { createIblHelper, setDebugButtons - } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770698056099'); + } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/animation/cesiumMan/index.html b/examples/gltf/animation/cesiumMan/index.html index b4417a88f..77d781697 100644 --- a/examples/gltf/animation/cesiumMan/index.html +++ b/examples/gltf/animation/cesiumMan/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/gltf/animation/cesiumMan/index.js b/examples/gltf/animation/cesiumMan/index.js index e6966eb69..be3ab60c3 100644 --- a/examples/gltf/animation/cesiumMan/index.js +++ b/examples/gltf/animation/cesiumMan/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; import { loadingProgressInfoHandler -} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770698056099' +} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' /** * [KO] CesiumMan 예제 @@ -99,11 +99,11 @@ function loadGLTFGrid(view, urls, gridSize = 3, spacing = 3) { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { createIblHelper, setDebugButtons - } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770698056099'); + } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/animation/interpolationTest/index.html b/examples/gltf/animation/interpolationTest/index.html index b4417a88f..77d781697 100644 --- a/examples/gltf/animation/interpolationTest/index.html +++ b/examples/gltf/animation/interpolationTest/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/gltf/animation/interpolationTest/index.js b/examples/gltf/animation/interpolationTest/index.js index 17db2a2bb..f87339b5a 100644 --- a/examples/gltf/animation/interpolationTest/index.js +++ b/examples/gltf/animation/interpolationTest/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; /** * [KO] Interpolation Test 예제 @@ -63,11 +63,11 @@ function loadGLTF(view, url) { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { createIblHelper, setDebugButtons - } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770698056099'); + } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/animation/morphStressTest/index.html b/examples/gltf/animation/morphStressTest/index.html index b4417a88f..77d781697 100644 --- a/examples/gltf/animation/morphStressTest/index.html +++ b/examples/gltf/animation/morphStressTest/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/gltf/animation/morphStressTest/index.js b/examples/gltf/animation/morphStressTest/index.js index 0a816b4fa..8c9ed0414 100644 --- a/examples/gltf/animation/morphStressTest/index.js +++ b/examples/gltf/animation/morphStressTest/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; /** * [KO] Morph Stress Test 예제 @@ -61,11 +61,11 @@ function loadGLTF(view, url) { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { createIblHelper, setDebugButtons - } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770698056099'); + } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/animation/performance/highMorphTarget/index.html b/examples/gltf/animation/performance/highMorphTarget/index.html index c4cdcdf9a..c7c14d3dd 100644 --- a/examples/gltf/animation/performance/highMorphTarget/index.html +++ b/examples/gltf/animation/performance/highMorphTarget/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/animation/performance/highMorphTarget/index.js b/examples/gltf/animation/performance/highMorphTarget/index.js index 7fed93004..396db72ca 100644 --- a/examples/gltf/animation/performance/highMorphTarget/index.js +++ b/examples/gltf/animation/performance/highMorphTarget/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; import { loadingProgressInfoHandler -} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770698056099' +} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' /** * [KO] High Morph Target Performance 예제 @@ -126,11 +126,11 @@ let pane * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { setDebugButtons, createIblHelper - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770698056099'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); setDebugButtons(RedGPU, redGPUContext); pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/animation/performance/highVertexLoadSkinning/index.html b/examples/gltf/animation/performance/highVertexLoadSkinning/index.html index c4cdcdf9a..c7c14d3dd 100644 --- a/examples/gltf/animation/performance/highVertexLoadSkinning/index.html +++ b/examples/gltf/animation/performance/highVertexLoadSkinning/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/animation/performance/highVertexLoadSkinning/index.js b/examples/gltf/animation/performance/highVertexLoadSkinning/index.js index f3dedc572..184f4f5c4 100644 --- a/examples/gltf/animation/performance/highVertexLoadSkinning/index.js +++ b/examples/gltf/animation/performance/highVertexLoadSkinning/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; import { loadingProgressInfoHandler -} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770698056099' +} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' /** * [KO] High Vertex Load Skinning 예제 @@ -84,11 +84,11 @@ let pane * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { setDebugButtons, createIblHelper - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770698056099'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); setDebugButtons(RedGPU, redGPUContext); pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/animation/performance/mediumLoadSkinning/index.html b/examples/gltf/animation/performance/mediumLoadSkinning/index.html index c4cdcdf9a..c7c14d3dd 100644 --- a/examples/gltf/animation/performance/mediumLoadSkinning/index.html +++ b/examples/gltf/animation/performance/mediumLoadSkinning/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/animation/performance/mediumLoadSkinning/index.js b/examples/gltf/animation/performance/mediumLoadSkinning/index.js index 50f326df2..e1a223aec 100644 --- a/examples/gltf/animation/performance/mediumLoadSkinning/index.js +++ b/examples/gltf/animation/performance/mediumLoadSkinning/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; import { loadingProgressInfoHandler -} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770698056099' +} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' /** * [KO] Medium Load Skinning 예제 @@ -88,8 +88,8 @@ let pane * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); - const {setDebugButtons} = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {setDebugButtons} = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); setDebugButtons(RedGPU, redGPUContext); pane = new Pane(); diff --git a/examples/gltf/animation/recursiveSkeletons/index.html b/examples/gltf/animation/recursiveSkeletons/index.html index b4417a88f..77d781697 100644 --- a/examples/gltf/animation/recursiveSkeletons/index.html +++ b/examples/gltf/animation/recursiveSkeletons/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/gltf/animation/recursiveSkeletons/index.js b/examples/gltf/animation/recursiveSkeletons/index.js index 621111dd4..790979782 100644 --- a/examples/gltf/animation/recursiveSkeletons/index.js +++ b/examples/gltf/animation/recursiveSkeletons/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; /** * [KO] Recursive Skeletons 예제 @@ -61,11 +61,11 @@ function loadGLTF(view, url) { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { createIblHelper, setDebugButtons - } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770698056099'); + } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/animation/riggedFigure/index.html b/examples/gltf/animation/riggedFigure/index.html index b4417a88f..77d781697 100644 --- a/examples/gltf/animation/riggedFigure/index.html +++ b/examples/gltf/animation/riggedFigure/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/gltf/animation/riggedFigure/index.js b/examples/gltf/animation/riggedFigure/index.js index 626c3de4a..868b11b75 100644 --- a/examples/gltf/animation/riggedFigure/index.js +++ b/examples/gltf/animation/riggedFigure/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; /** * [KO] Rigged Figure 예제 @@ -62,11 +62,11 @@ function loadGLTF(view, url) { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { createIblHelper, setDebugButtons - } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770698056099'); + } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/animation/riggedSimple/index.html b/examples/gltf/animation/riggedSimple/index.html index b4417a88f..77d781697 100644 --- a/examples/gltf/animation/riggedSimple/index.html +++ b/examples/gltf/animation/riggedSimple/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/gltf/animation/riggedSimple/index.js b/examples/gltf/animation/riggedSimple/index.js index 927edb4e2..28e424393 100644 --- a/examples/gltf/animation/riggedSimple/index.js +++ b/examples/gltf/animation/riggedSimple/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; /** * [KO] Rigged Simple 예제 @@ -60,11 +60,11 @@ function loadGLTF(view, url) { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { createIblHelper, setDebugButtons - } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770698056099'); + } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/animation/simpleMorph/index.html b/examples/gltf/animation/simpleMorph/index.html index b4417a88f..77d781697 100644 --- a/examples/gltf/animation/simpleMorph/index.html +++ b/examples/gltf/animation/simpleMorph/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/gltf/animation/simpleMorph/index.js b/examples/gltf/animation/simpleMorph/index.js index cbbe481d5..e69977c92 100644 --- a/examples/gltf/animation/simpleMorph/index.js +++ b/examples/gltf/animation/simpleMorph/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; /** * [KO] Simple Morph 예제 @@ -61,11 +61,11 @@ function loadGLTF(view, url) { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { createIblHelper, setDebugButtons - } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770698056099'); + } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/animation/simpleSkin/index.html b/examples/gltf/animation/simpleSkin/index.html index b4417a88f..77d781697 100644 --- a/examples/gltf/animation/simpleSkin/index.html +++ b/examples/gltf/animation/simpleSkin/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/gltf/animation/simpleSkin/index.js b/examples/gltf/animation/simpleSkin/index.js index fa5c32d0c..2f9866b08 100644 --- a/examples/gltf/animation/simpleSkin/index.js +++ b/examples/gltf/animation/simpleSkin/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; /** * [KO] Simple Skin 예제 @@ -60,11 +60,11 @@ function loadGLTF(view, url) { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { createIblHelper, setDebugButtons - } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770698056099'); + } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/basic/alphaBlendModeTest/index.html b/examples/gltf/basic/alphaBlendModeTest/index.html index b4417a88f..77d781697 100644 --- a/examples/gltf/basic/alphaBlendModeTest/index.html +++ b/examples/gltf/basic/alphaBlendModeTest/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/gltf/basic/alphaBlendModeTest/index.js b/examples/gltf/basic/alphaBlendModeTest/index.js index bc6ba3b93..d288499e3 100644 --- a/examples/gltf/basic/alphaBlendModeTest/index.js +++ b/examples/gltf/basic/alphaBlendModeTest/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; import { loadingProgressInfoHandler -} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770698056099' +} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' /** * [KO] Alpha Blend Mode Test 예제 @@ -76,11 +76,11 @@ const loadGLTF = async (view, url) => { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { createIblHelper, setDebugButtons - } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770698056099'); + } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/basic/boxVertexColors/index.html b/examples/gltf/basic/boxVertexColors/index.html index b4417a88f..77d781697 100644 --- a/examples/gltf/basic/boxVertexColors/index.html +++ b/examples/gltf/basic/boxVertexColors/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/gltf/basic/boxVertexColors/index.js b/examples/gltf/basic/boxVertexColors/index.js index f52fc0202..97daf0884 100644 --- a/examples/gltf/basic/boxVertexColors/index.js +++ b/examples/gltf/basic/boxVertexColors/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; import { loadingProgressInfoHandler -} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770698056099' +} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' /** * [KO] Box Vertex Colors 예제 @@ -76,11 +76,11 @@ const loadGLTF = async (view, url) => { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { createIblHelper, setDebugButtons - } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770698056099'); + } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/basic/compareAlphaCoverage/index.html b/examples/gltf/basic/compareAlphaCoverage/index.html index b4417a88f..77d781697 100644 --- a/examples/gltf/basic/compareAlphaCoverage/index.html +++ b/examples/gltf/basic/compareAlphaCoverage/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/gltf/basic/compareAlphaCoverage/index.js b/examples/gltf/basic/compareAlphaCoverage/index.js index 352f5d05e..e16180698 100644 --- a/examples/gltf/basic/compareAlphaCoverage/index.js +++ b/examples/gltf/basic/compareAlphaCoverage/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; import { loadingProgressInfoHandler -} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770698056099' +} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' /** * [KO] Compare Alpha Coverage 예제 @@ -77,11 +77,11 @@ const loadGLTF = async (view, url) => { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { createIblHelper, setDebugButtons - } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770698056099'); + } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/basic/compareAmbientOcclusion/index.html b/examples/gltf/basic/compareAmbientOcclusion/index.html index b4417a88f..77d781697 100644 --- a/examples/gltf/basic/compareAmbientOcclusion/index.html +++ b/examples/gltf/basic/compareAmbientOcclusion/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/gltf/basic/compareAmbientOcclusion/index.js b/examples/gltf/basic/compareAmbientOcclusion/index.js index 0965e13ca..fff6255a3 100644 --- a/examples/gltf/basic/compareAmbientOcclusion/index.js +++ b/examples/gltf/basic/compareAmbientOcclusion/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; import { loadingProgressInfoHandler -} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770698056099' +} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' /** * [KO] Compare Ambient Occlusion 예제 @@ -77,11 +77,11 @@ const loadGLTF = async (view, url) => { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { createIblHelper, setDebugButtons - } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770698056099'); + } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/basic/compareBaseColor/index.html b/examples/gltf/basic/compareBaseColor/index.html index b4417a88f..77d781697 100644 --- a/examples/gltf/basic/compareBaseColor/index.html +++ b/examples/gltf/basic/compareBaseColor/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/gltf/basic/compareBaseColor/index.js b/examples/gltf/basic/compareBaseColor/index.js index 608bb364c..73c876e59 100644 --- a/examples/gltf/basic/compareBaseColor/index.js +++ b/examples/gltf/basic/compareBaseColor/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; import { loadingProgressInfoHandler -} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770698056099' +} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' /** * [KO] Compare Base Color 예제 @@ -76,11 +76,11 @@ const loadGLTF = async (view, url) => { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { createIblHelper, setDebugButtons - } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770698056099'); + } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/basic/compareMetallic/index.html b/examples/gltf/basic/compareMetallic/index.html index b4417a88f..77d781697 100644 --- a/examples/gltf/basic/compareMetallic/index.html +++ b/examples/gltf/basic/compareMetallic/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/gltf/basic/compareMetallic/index.js b/examples/gltf/basic/compareMetallic/index.js index 239d94a38..f100c3cc1 100644 --- a/examples/gltf/basic/compareMetallic/index.js +++ b/examples/gltf/basic/compareMetallic/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; import { loadingProgressInfoHandler -} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770698056099' +} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' /** * [KO] Compare Metallic 예제 @@ -76,11 +76,11 @@ const loadGLTF = async (view, url) => { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { createIblHelper, setDebugButtons - } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770698056099'); + } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/basic/compareNormal/index.html b/examples/gltf/basic/compareNormal/index.html index b4417a88f..77d781697 100644 --- a/examples/gltf/basic/compareNormal/index.html +++ b/examples/gltf/basic/compareNormal/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/gltf/basic/compareNormal/index.js b/examples/gltf/basic/compareNormal/index.js index 0ab616087..9223b8e39 100644 --- a/examples/gltf/basic/compareNormal/index.js +++ b/examples/gltf/basic/compareNormal/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; import { loadingProgressInfoHandler -} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770698056099' +} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' /** * [KO] Compare Normal 예제 @@ -76,11 +76,11 @@ const loadGLTF = async (view, url) => { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { createIblHelper, setDebugButtons - } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770698056099'); + } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/basic/compareRoughness/index.html b/examples/gltf/basic/compareRoughness/index.html index b4417a88f..77d781697 100644 --- a/examples/gltf/basic/compareRoughness/index.html +++ b/examples/gltf/basic/compareRoughness/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/gltf/basic/compareRoughness/index.js b/examples/gltf/basic/compareRoughness/index.js index 3bcd7b7cc..7057591c6 100644 --- a/examples/gltf/basic/compareRoughness/index.js +++ b/examples/gltf/basic/compareRoughness/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; import { loadingProgressInfoHandler -} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770698056099' +} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' /** * [KO] Compare Roughness 예제 @@ -76,11 +76,11 @@ const loadGLTF = async (view, url) => { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { createIblHelper, setDebugButtons - } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770698056099'); + } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/basic/environmentTest/index.html b/examples/gltf/basic/environmentTest/index.html index b4417a88f..77d781697 100644 --- a/examples/gltf/basic/environmentTest/index.html +++ b/examples/gltf/basic/environmentTest/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/gltf/basic/environmentTest/index.js b/examples/gltf/basic/environmentTest/index.js index 41b7eeda4..5396c4425 100644 --- a/examples/gltf/basic/environmentTest/index.js +++ b/examples/gltf/basic/environmentTest/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; import { loadingProgressInfoHandler -} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770698056099' +} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' /** * [KO] Environment Test 예제 @@ -76,11 +76,11 @@ const loadGLTF = async (view, url) => { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { createIblHelper, setDebugButtons - } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770698056099'); + } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/basic/generateNormalTest/index.html b/examples/gltf/basic/generateNormalTest/index.html index b4417a88f..77d781697 100644 --- a/examples/gltf/basic/generateNormalTest/index.html +++ b/examples/gltf/basic/generateNormalTest/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/gltf/basic/generateNormalTest/index.js b/examples/gltf/basic/generateNormalTest/index.js index f659a7cc6..7f4adae3a 100644 --- a/examples/gltf/basic/generateNormalTest/index.js +++ b/examples/gltf/basic/generateNormalTest/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; import { loadingProgressInfoHandler -} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770698056099' +} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' /** * [KO] Generate Normal Test 예제 @@ -76,11 +76,11 @@ const loadGLTF = async (view, url) => { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { createIblHelper, setDebugButtons - } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770698056099'); + } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/basic/metalRoughSpheres/index.html b/examples/gltf/basic/metalRoughSpheres/index.html index b4417a88f..77d781697 100644 --- a/examples/gltf/basic/metalRoughSpheres/index.html +++ b/examples/gltf/basic/metalRoughSpheres/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/gltf/basic/metalRoughSpheres/index.js b/examples/gltf/basic/metalRoughSpheres/index.js index 1176590d0..b9bc1261f 100644 --- a/examples/gltf/basic/metalRoughSpheres/index.js +++ b/examples/gltf/basic/metalRoughSpheres/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; import { loadingProgressInfoHandler -} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770698056099' +} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' /** * [KO] Metal Rough Spheres 예제 @@ -77,11 +77,11 @@ const loadGLTF = async (view, url) => { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { createIblHelper, setDebugButtons - } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770698056099'); + } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/basic/metalRoughSpheresNoTextures/index.html b/examples/gltf/basic/metalRoughSpheresNoTextures/index.html index b4417a88f..77d781697 100644 --- a/examples/gltf/basic/metalRoughSpheresNoTextures/index.html +++ b/examples/gltf/basic/metalRoughSpheresNoTextures/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/gltf/basic/metalRoughSpheresNoTextures/index.js b/examples/gltf/basic/metalRoughSpheresNoTextures/index.js index a8c8c5f93..534294365 100644 --- a/examples/gltf/basic/metalRoughSpheresNoTextures/index.js +++ b/examples/gltf/basic/metalRoughSpheresNoTextures/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; import { loadingProgressInfoHandler -} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770698056099' +} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' /** * [KO] Metal Rough Spheres (No Textures) 예제 @@ -77,11 +77,11 @@ const loadGLTF = async (view, url) => { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { createIblHelper, setDebugButtons - } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770698056099'); + } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/basic/multiUVTest/index.html b/examples/gltf/basic/multiUVTest/index.html index b4417a88f..77d781697 100644 --- a/examples/gltf/basic/multiUVTest/index.html +++ b/examples/gltf/basic/multiUVTest/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/gltf/basic/multiUVTest/index.js b/examples/gltf/basic/multiUVTest/index.js index d2ee0896c..449d43627 100644 --- a/examples/gltf/basic/multiUVTest/index.js +++ b/examples/gltf/basic/multiUVTest/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; import { loadingProgressInfoHandler -} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770698056099' +} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' /** * [KO] Multi UV Test 예제 @@ -77,11 +77,11 @@ const loadGLTF = async (view, url) => { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { createIblHelper, setDebugButtons - } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770698056099'); + } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/basic/negativeScaleTest/index.html b/examples/gltf/basic/negativeScaleTest/index.html index b4417a88f..77d781697 100644 --- a/examples/gltf/basic/negativeScaleTest/index.html +++ b/examples/gltf/basic/negativeScaleTest/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/gltf/basic/negativeScaleTest/index.js b/examples/gltf/basic/negativeScaleTest/index.js index bda7e89f5..16efaf06a 100644 --- a/examples/gltf/basic/negativeScaleTest/index.js +++ b/examples/gltf/basic/negativeScaleTest/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; import { loadingProgressInfoHandler -} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770698056099' +} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' /** * [KO] Negative Scale Test 예제 @@ -76,11 +76,11 @@ const loadGLTF = async (view, url) => { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { createIblHelper, setDebugButtons - } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770698056099'); + } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/basic/normalTangentMirrorTest/index.html b/examples/gltf/basic/normalTangentMirrorTest/index.html index b4417a88f..77d781697 100644 --- a/examples/gltf/basic/normalTangentMirrorTest/index.html +++ b/examples/gltf/basic/normalTangentMirrorTest/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/gltf/basic/normalTangentMirrorTest/index.js b/examples/gltf/basic/normalTangentMirrorTest/index.js index 50a9ae00e..d199bea46 100644 --- a/examples/gltf/basic/normalTangentMirrorTest/index.js +++ b/examples/gltf/basic/normalTangentMirrorTest/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; import { loadingProgressInfoHandler -} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770698056099' +} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' /** * [KO] Normal Tangent Mirror Test 예제 @@ -77,11 +77,11 @@ const loadGLTF = async (view, url) => { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { createIblHelper, setDebugButtons - } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770698056099'); + } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/basic/normalTangentTest/index.html b/examples/gltf/basic/normalTangentTest/index.html index b4417a88f..77d781697 100644 --- a/examples/gltf/basic/normalTangentTest/index.html +++ b/examples/gltf/basic/normalTangentTest/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/gltf/basic/normalTangentTest/index.js b/examples/gltf/basic/normalTangentTest/index.js index 058c9f083..613dd3ad2 100644 --- a/examples/gltf/basic/normalTangentTest/index.js +++ b/examples/gltf/basic/normalTangentTest/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; import { loadingProgressInfoHandler -} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770698056099' +} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' /** * [KO] Normal Tangent Test 예제 @@ -77,11 +77,11 @@ const loadGLTF = async (view, url) => { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { createIblHelper, setDebugButtons - } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770698056099'); + } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/basic/orientationTest/index.html b/examples/gltf/basic/orientationTest/index.html index b4417a88f..77d781697 100644 --- a/examples/gltf/basic/orientationTest/index.html +++ b/examples/gltf/basic/orientationTest/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/gltf/basic/orientationTest/index.js b/examples/gltf/basic/orientationTest/index.js index 361316676..41c325743 100644 --- a/examples/gltf/basic/orientationTest/index.js +++ b/examples/gltf/basic/orientationTest/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; import { loadingProgressInfoHandler -} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770698056099' +} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' /** * [KO] Orientation Test 예제 @@ -76,11 +76,11 @@ const loadGLTF = async (view, url) => { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { createIblHelper, setDebugButtons - } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770698056099'); + } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/basic/textureCoordinateTest/index.html b/examples/gltf/basic/textureCoordinateTest/index.html index b4417a88f..77d781697 100644 --- a/examples/gltf/basic/textureCoordinateTest/index.html +++ b/examples/gltf/basic/textureCoordinateTest/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/gltf/basic/textureCoordinateTest/index.js b/examples/gltf/basic/textureCoordinateTest/index.js index f512f3c23..c1da51bb1 100644 --- a/examples/gltf/basic/textureCoordinateTest/index.js +++ b/examples/gltf/basic/textureCoordinateTest/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; import { loadingProgressInfoHandler -} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770698056099' +} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' /** * [KO] Texture Coordinate Test 예제 @@ -76,11 +76,11 @@ const loadGLTF = async (view, url) => { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { createIblHelper, setDebugButtons - } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770698056099'); + } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/basic/textureEncodingTest/index.html b/examples/gltf/basic/textureEncodingTest/index.html index b4417a88f..77d781697 100644 --- a/examples/gltf/basic/textureEncodingTest/index.html +++ b/examples/gltf/basic/textureEncodingTest/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/gltf/basic/textureEncodingTest/index.js b/examples/gltf/basic/textureEncodingTest/index.js index 78e83bace..db57f123b 100644 --- a/examples/gltf/basic/textureEncodingTest/index.js +++ b/examples/gltf/basic/textureEncodingTest/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; import { loadingProgressInfoHandler -} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770698056099' +} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' /** * [KO] Texture Encoding Test 예제 @@ -77,11 +77,11 @@ const loadGLTF = async (view, url) => { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { createIblHelper, setDebugButtons - } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770698056099'); + } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/basic/textureLinearInterpolationTest/index.html b/examples/gltf/basic/textureLinearInterpolationTest/index.html index b4417a88f..77d781697 100644 --- a/examples/gltf/basic/textureLinearInterpolationTest/index.html +++ b/examples/gltf/basic/textureLinearInterpolationTest/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/gltf/basic/textureLinearInterpolationTest/index.js b/examples/gltf/basic/textureLinearInterpolationTest/index.js index 52acdcf27..1beed5795 100644 --- a/examples/gltf/basic/textureLinearInterpolationTest/index.js +++ b/examples/gltf/basic/textureLinearInterpolationTest/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; import { loadingProgressInfoHandler -} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770698056099' +} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' /** * [KO] Texture Linear Interpolation Test 예제 @@ -76,11 +76,11 @@ const loadGLTF = async (view, url) => { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { createIblHelper, setDebugButtons - } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770698056099'); + } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/basic/textureSettingsTest/index.html b/examples/gltf/basic/textureSettingsTest/index.html index b4417a88f..77d781697 100644 --- a/examples/gltf/basic/textureSettingsTest/index.html +++ b/examples/gltf/basic/textureSettingsTest/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/gltf/basic/textureSettingsTest/index.js b/examples/gltf/basic/textureSettingsTest/index.js index 212b1983c..282a2c212 100644 --- a/examples/gltf/basic/textureSettingsTest/index.js +++ b/examples/gltf/basic/textureSettingsTest/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; import { loadingProgressInfoHandler -} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770698056099' +} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' /** * [KO] Texture Settings Test 예제 @@ -76,11 +76,11 @@ const loadGLTF = async (view, url) => { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { createIblHelper, setDebugButtons - } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770698056099'); + } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/basic/vertexColorTest/index.html b/examples/gltf/basic/vertexColorTest/index.html index b4417a88f..77d781697 100644 --- a/examples/gltf/basic/vertexColorTest/index.html +++ b/examples/gltf/basic/vertexColorTest/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/gltf/basic/vertexColorTest/index.js b/examples/gltf/basic/vertexColorTest/index.js index 86d1be844..fc94b9aa1 100644 --- a/examples/gltf/basic/vertexColorTest/index.js +++ b/examples/gltf/basic/vertexColorTest/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; import { loadingProgressInfoHandler -} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770698056099' +} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' /** * [KO] Vertex Color Test 예제 @@ -76,11 +76,11 @@ const loadGLTF = async (view, url) => { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { createIblHelper, setDebugButtons - } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770698056099'); + } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/basic/waterBottle/index.html b/examples/gltf/basic/waterBottle/index.html index b4417a88f..77d781697 100644 --- a/examples/gltf/basic/waterBottle/index.html +++ b/examples/gltf/basic/waterBottle/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/gltf/basic/waterBottle/index.js b/examples/gltf/basic/waterBottle/index.js index f0e37771c..1ec7a10ed 100644 --- a/examples/gltf/basic/waterBottle/index.js +++ b/examples/gltf/basic/waterBottle/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; import { loadingProgressInfoHandler -} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770698056099' +} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' /** * [KO] Water Bottle 예제 @@ -77,11 +77,11 @@ const loadGLTF = async (view, url) => { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { createIblHelper, setDebugButtons - } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770698056099'); + } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/gltfExtensions/anisotropy/anisotropyBarnLamp/index.html b/examples/gltf/gltfExtensions/anisotropy/anisotropyBarnLamp/index.html index c4cdcdf9a..c7c14d3dd 100644 --- a/examples/gltf/gltfExtensions/anisotropy/anisotropyBarnLamp/index.html +++ b/examples/gltf/gltfExtensions/anisotropy/anisotropyBarnLamp/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/gltfExtensions/anisotropy/anisotropyBarnLamp/index.js b/examples/gltf/gltfExtensions/anisotropy/anisotropyBarnLamp/index.js index b11c23b8e..3ecc9f470 100644 --- a/examples/gltf/gltfExtensions/anisotropy/anisotropyBarnLamp/index.js +++ b/examples/gltf/gltfExtensions/anisotropy/anisotropyBarnLamp/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; import { loadingProgressInfoHandler -} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770698056099' +} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' /** * [KO] Anisotropy Barn Lamp 예제 @@ -77,11 +77,11 @@ const loadGLTF = async (view, url) => { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { createIblHelper, setDebugButtons - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770698056099'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/gltfExtensions/anisotropy/anisotropyDiscTest/index.html b/examples/gltf/gltfExtensions/anisotropy/anisotropyDiscTest/index.html index c4cdcdf9a..c7c14d3dd 100644 --- a/examples/gltf/gltfExtensions/anisotropy/anisotropyDiscTest/index.html +++ b/examples/gltf/gltfExtensions/anisotropy/anisotropyDiscTest/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/gltfExtensions/anisotropy/anisotropyDiscTest/index.js b/examples/gltf/gltfExtensions/anisotropy/anisotropyDiscTest/index.js index fc240d0a1..cc469b6eb 100644 --- a/examples/gltf/gltfExtensions/anisotropy/anisotropyDiscTest/index.js +++ b/examples/gltf/gltfExtensions/anisotropy/anisotropyDiscTest/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; /** * [KO] Anisotropy Disc Test 예제 @@ -60,11 +60,11 @@ function loadGLTF(view, url) { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { createIblHelper, setDebugButtons - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770698056099'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/gltfExtensions/anisotropy/anisotropyRotationTest/index.html b/examples/gltf/gltfExtensions/anisotropy/anisotropyRotationTest/index.html index c4cdcdf9a..c7c14d3dd 100644 --- a/examples/gltf/gltfExtensions/anisotropy/anisotropyRotationTest/index.html +++ b/examples/gltf/gltfExtensions/anisotropy/anisotropyRotationTest/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/gltfExtensions/anisotropy/anisotropyRotationTest/index.js b/examples/gltf/gltfExtensions/anisotropy/anisotropyRotationTest/index.js index 84b5361c3..2902372d6 100644 --- a/examples/gltf/gltfExtensions/anisotropy/anisotropyRotationTest/index.js +++ b/examples/gltf/gltfExtensions/anisotropy/anisotropyRotationTest/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; /** * [KO] Anisotropy Rotation Test 예제 @@ -62,11 +62,11 @@ function loadGLTF(view, url) { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { createIblHelper, setDebugButtons - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770698056099'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/gltfExtensions/anisotropy/anisotropyStrengthTest/index.html b/examples/gltf/gltfExtensions/anisotropy/anisotropyStrengthTest/index.html index c4cdcdf9a..c7c14d3dd 100644 --- a/examples/gltf/gltfExtensions/anisotropy/anisotropyStrengthTest/index.html +++ b/examples/gltf/gltfExtensions/anisotropy/anisotropyStrengthTest/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/gltfExtensions/anisotropy/anisotropyStrengthTest/index.js b/examples/gltf/gltfExtensions/anisotropy/anisotropyStrengthTest/index.js index 955a9854c..76420ac6c 100644 --- a/examples/gltf/gltfExtensions/anisotropy/anisotropyStrengthTest/index.js +++ b/examples/gltf/gltfExtensions/anisotropy/anisotropyStrengthTest/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; /** * [KO] Anisotropy Strength Test 예제 @@ -62,11 +62,11 @@ function loadGLTF(view, url) { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { createIblHelper, setDebugButtons - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770698056099'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/gltfExtensions/anisotropy/compareAnisotropy/index.html b/examples/gltf/gltfExtensions/anisotropy/compareAnisotropy/index.html index c4cdcdf9a..c7c14d3dd 100644 --- a/examples/gltf/gltfExtensions/anisotropy/compareAnisotropy/index.html +++ b/examples/gltf/gltfExtensions/anisotropy/compareAnisotropy/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/gltfExtensions/anisotropy/compareAnisotropy/index.js b/examples/gltf/gltfExtensions/anisotropy/compareAnisotropy/index.js index 5b341dd3c..03ef71eae 100644 --- a/examples/gltf/gltfExtensions/anisotropy/compareAnisotropy/index.js +++ b/examples/gltf/gltfExtensions/anisotropy/compareAnisotropy/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; import { loadingProgressInfoHandler -} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770698056099' +} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' /** * [KO] Compare Anisotropy 예제 @@ -77,11 +77,11 @@ const loadGLTF = async (view, url) => { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { createIblHelper, setDebugButtons - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770698056099'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/gltfExtensions/clearcoat/clearCoatCarPaint/index.html b/examples/gltf/gltfExtensions/clearcoat/clearCoatCarPaint/index.html index c4cdcdf9a..c7c14d3dd 100644 --- a/examples/gltf/gltfExtensions/clearcoat/clearCoatCarPaint/index.html +++ b/examples/gltf/gltfExtensions/clearcoat/clearCoatCarPaint/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/gltfExtensions/clearcoat/clearCoatCarPaint/index.js b/examples/gltf/gltfExtensions/clearcoat/clearCoatCarPaint/index.js index bf57e820c..aee0ba850 100644 --- a/examples/gltf/gltfExtensions/clearcoat/clearCoatCarPaint/index.js +++ b/examples/gltf/gltfExtensions/clearcoat/clearCoatCarPaint/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; /** * [KO] ClearCoat Car Paint 예제 @@ -60,11 +60,11 @@ function loadGLTF(view, url) { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { createIblHelper, setDebugButtons - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770698056099'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/gltfExtensions/clearcoat/clearCoatTest/index.html b/examples/gltf/gltfExtensions/clearcoat/clearCoatTest/index.html index c4cdcdf9a..c7c14d3dd 100644 --- a/examples/gltf/gltfExtensions/clearcoat/clearCoatTest/index.html +++ b/examples/gltf/gltfExtensions/clearcoat/clearCoatTest/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/gltfExtensions/clearcoat/clearCoatTest/index.js b/examples/gltf/gltfExtensions/clearcoat/clearCoatTest/index.js index b8e75011b..8aafdc9fc 100644 --- a/examples/gltf/gltfExtensions/clearcoat/clearCoatTest/index.js +++ b/examples/gltf/gltfExtensions/clearcoat/clearCoatTest/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; /** * [KO] ClearCoat Test 예제 @@ -60,11 +60,11 @@ function loadGLTF(view, url) { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { createIblHelper, setDebugButtons - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770698056099'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/gltfExtensions/clearcoat/clearcoatWicker/index.html b/examples/gltf/gltfExtensions/clearcoat/clearcoatWicker/index.html index c4cdcdf9a..c7c14d3dd 100644 --- a/examples/gltf/gltfExtensions/clearcoat/clearcoatWicker/index.html +++ b/examples/gltf/gltfExtensions/clearcoat/clearcoatWicker/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/gltfExtensions/clearcoat/clearcoatWicker/index.js b/examples/gltf/gltfExtensions/clearcoat/clearcoatWicker/index.js index 9bfafbd64..ebf92fa7d 100644 --- a/examples/gltf/gltfExtensions/clearcoat/clearcoatWicker/index.js +++ b/examples/gltf/gltfExtensions/clearcoat/clearcoatWicker/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; import { loadingProgressInfoHandler -} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770698056099' +} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' /** * [KO] Clearcoat Wicker 예제 @@ -77,11 +77,11 @@ const loadGLTF = async (view, url) => { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { createIblHelper, setDebugButtons - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770698056099'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/gltfExtensions/clearcoat/compareClearcoat/index.html b/examples/gltf/gltfExtensions/clearcoat/compareClearcoat/index.html index c4cdcdf9a..c7c14d3dd 100644 --- a/examples/gltf/gltfExtensions/clearcoat/compareClearcoat/index.html +++ b/examples/gltf/gltfExtensions/clearcoat/compareClearcoat/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/gltfExtensions/clearcoat/compareClearcoat/index.js b/examples/gltf/gltfExtensions/clearcoat/compareClearcoat/index.js index 5f0c8a848..8891b9539 100644 --- a/examples/gltf/gltfExtensions/clearcoat/compareClearcoat/index.js +++ b/examples/gltf/gltfExtensions/clearcoat/compareClearcoat/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; /** * [KO] Compare Clearcoat 예제 @@ -60,11 +60,11 @@ function loadGLTF(view, url) { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { createIblHelper, setDebugButtons - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770698056099'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/gltfExtensions/diffuseTransmission/diffuseTransmissionTeacup/index.html b/examples/gltf/gltfExtensions/diffuseTransmission/diffuseTransmissionTeacup/index.html index c4cdcdf9a..c7c14d3dd 100644 --- a/examples/gltf/gltfExtensions/diffuseTransmission/diffuseTransmissionTeacup/index.html +++ b/examples/gltf/gltfExtensions/diffuseTransmission/diffuseTransmissionTeacup/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/gltfExtensions/diffuseTransmission/diffuseTransmissionTeacup/index.js b/examples/gltf/gltfExtensions/diffuseTransmission/diffuseTransmissionTeacup/index.js index fba09a809..8cd2a4ed1 100644 --- a/examples/gltf/gltfExtensions/diffuseTransmission/diffuseTransmissionTeacup/index.js +++ b/examples/gltf/gltfExtensions/diffuseTransmission/diffuseTransmissionTeacup/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; import { loadingProgressInfoHandler -} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770698056099' +} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' /** * [KO] Diffuse Transmission Teacup 예제 @@ -77,11 +77,11 @@ const loadGLTF = async (view, url) => { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { createIblHelper, setDebugButtons - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770698056099'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/gltfExtensions/diffuseTransmission/diffuseTransmissionTest/index.html b/examples/gltf/gltfExtensions/diffuseTransmission/diffuseTransmissionTest/index.html index c4cdcdf9a..c7c14d3dd 100644 --- a/examples/gltf/gltfExtensions/diffuseTransmission/diffuseTransmissionTest/index.html +++ b/examples/gltf/gltfExtensions/diffuseTransmission/diffuseTransmissionTest/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/gltfExtensions/diffuseTransmission/diffuseTransmissionTest/index.js b/examples/gltf/gltfExtensions/diffuseTransmission/diffuseTransmissionTest/index.js index d632af984..d49a06f29 100644 --- a/examples/gltf/gltfExtensions/diffuseTransmission/diffuseTransmissionTest/index.js +++ b/examples/gltf/gltfExtensions/diffuseTransmission/diffuseTransmissionTest/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; /** * [KO] Diffuse Transmission Test 예제 @@ -61,11 +61,11 @@ function loadGLTF(view, url) { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { createIblHelper, setDebugButtons - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770698056099'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/gltfExtensions/dispersion/compareDispersion/index.html b/examples/gltf/gltfExtensions/dispersion/compareDispersion/index.html index c4cdcdf9a..c7c14d3dd 100644 --- a/examples/gltf/gltfExtensions/dispersion/compareDispersion/index.html +++ b/examples/gltf/gltfExtensions/dispersion/compareDispersion/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/gltfExtensions/dispersion/compareDispersion/index.js b/examples/gltf/gltfExtensions/dispersion/compareDispersion/index.js index 9668deecc..c28a0a125 100644 --- a/examples/gltf/gltfExtensions/dispersion/compareDispersion/index.js +++ b/examples/gltf/gltfExtensions/dispersion/compareDispersion/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; /** * [KO] Compare Dispersion 예제 @@ -61,11 +61,11 @@ function loadGLTF(view, url) { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { createIblHelper, setDebugButtons - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770698056099'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/gltfExtensions/dispersion/dispersionTest/index.html b/examples/gltf/gltfExtensions/dispersion/dispersionTest/index.html index c4cdcdf9a..c7c14d3dd 100644 --- a/examples/gltf/gltfExtensions/dispersion/dispersionTest/index.html +++ b/examples/gltf/gltfExtensions/dispersion/dispersionTest/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/gltfExtensions/dispersion/dispersionTest/index.js b/examples/gltf/gltfExtensions/dispersion/dispersionTest/index.js index c9120824c..1d2585640 100644 --- a/examples/gltf/gltfExtensions/dispersion/dispersionTest/index.js +++ b/examples/gltf/gltfExtensions/dispersion/dispersionTest/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; import { loadingProgressInfoHandler -} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770698056099' +} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' /** * [KO] Dispersion Test 예제 @@ -77,11 +77,11 @@ const loadGLTF = async (view, url) => { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { createIblHelper, setDebugButtons - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770698056099'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/gltfExtensions/dispersion/dragonDispersion/index.html b/examples/gltf/gltfExtensions/dispersion/dragonDispersion/index.html index c4cdcdf9a..c7c14d3dd 100644 --- a/examples/gltf/gltfExtensions/dispersion/dragonDispersion/index.html +++ b/examples/gltf/gltfExtensions/dispersion/dragonDispersion/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/gltfExtensions/dispersion/dragonDispersion/index.js b/examples/gltf/gltfExtensions/dispersion/dragonDispersion/index.js index 7a4f178dd..76c5d563c 100644 --- a/examples/gltf/gltfExtensions/dispersion/dragonDispersion/index.js +++ b/examples/gltf/gltfExtensions/dispersion/dragonDispersion/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; import { loadingProgressInfoHandler -} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770698056099' +} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' /** * [KO] Dragon Dispersion 예제 @@ -77,11 +77,11 @@ const loadGLTF = async (view, url) => { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { createIblHelper, setDebugButtons - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770698056099'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/gltfExtensions/emissiveStrength/compareEmissiveStrength/index.html b/examples/gltf/gltfExtensions/emissiveStrength/compareEmissiveStrength/index.html index c4cdcdf9a..c7c14d3dd 100644 --- a/examples/gltf/gltfExtensions/emissiveStrength/compareEmissiveStrength/index.html +++ b/examples/gltf/gltfExtensions/emissiveStrength/compareEmissiveStrength/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/gltfExtensions/emissiveStrength/compareEmissiveStrength/index.js b/examples/gltf/gltfExtensions/emissiveStrength/compareEmissiveStrength/index.js index 2eaf4605d..7b250e86b 100644 --- a/examples/gltf/gltfExtensions/emissiveStrength/compareEmissiveStrength/index.js +++ b/examples/gltf/gltfExtensions/emissiveStrength/compareEmissiveStrength/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -40,11 +40,11 @@ function loadGLTF(view, url) { } const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { createIblHelper, setDebugButtons - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770698056099'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/gltfExtensions/emissiveStrength/emissiveStrengthTest/index.html b/examples/gltf/gltfExtensions/emissiveStrength/emissiveStrengthTest/index.html index c4cdcdf9a..c7c14d3dd 100644 --- a/examples/gltf/gltfExtensions/emissiveStrength/emissiveStrengthTest/index.html +++ b/examples/gltf/gltfExtensions/emissiveStrength/emissiveStrengthTest/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/gltfExtensions/emissiveStrength/emissiveStrengthTest/index.js b/examples/gltf/gltfExtensions/emissiveStrength/emissiveStrengthTest/index.js index 8d2b47ffd..f0a16c9e8 100644 --- a/examples/gltf/gltfExtensions/emissiveStrength/emissiveStrengthTest/index.js +++ b/examples/gltf/gltfExtensions/emissiveStrength/emissiveStrengthTest/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -40,11 +40,11 @@ function loadGLTF(view, url) { } const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { createIblHelper, setDebugButtons - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770698056099'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/gltfExtensions/iridescence/compareIridescence/index.html b/examples/gltf/gltfExtensions/iridescence/compareIridescence/index.html index c4cdcdf9a..c7c14d3dd 100644 --- a/examples/gltf/gltfExtensions/iridescence/compareIridescence/index.html +++ b/examples/gltf/gltfExtensions/iridescence/compareIridescence/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/gltfExtensions/iridescence/compareIridescence/index.js b/examples/gltf/gltfExtensions/iridescence/compareIridescence/index.js index 56b650724..a1508b115 100644 --- a/examples/gltf/gltfExtensions/iridescence/compareIridescence/index.js +++ b/examples/gltf/gltfExtensions/iridescence/compareIridescence/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -41,11 +41,11 @@ function loadGLTF(view, url) { } const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { createIblHelper, setDebugButtons - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770698056099'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/gltfExtensions/iridescence/iridescenceDielectricSpheres/index.html b/examples/gltf/gltfExtensions/iridescence/iridescenceDielectricSpheres/index.html index c4cdcdf9a..c7c14d3dd 100644 --- a/examples/gltf/gltfExtensions/iridescence/iridescenceDielectricSpheres/index.html +++ b/examples/gltf/gltfExtensions/iridescence/iridescenceDielectricSpheres/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/gltfExtensions/iridescence/iridescenceDielectricSpheres/index.js b/examples/gltf/gltfExtensions/iridescence/iridescenceDielectricSpheres/index.js index d561b5160..0e11db8c7 100644 --- a/examples/gltf/gltfExtensions/iridescence/iridescenceDielectricSpheres/index.js +++ b/examples/gltf/gltfExtensions/iridescence/iridescenceDielectricSpheres/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -41,11 +41,11 @@ function loadGLTF(view, url) { } const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { createIblHelper, setDebugButtons - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770698056099'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU, {useLight: false}); diff --git a/examples/gltf/gltfExtensions/iridescence/iridescenceLamp/index.html b/examples/gltf/gltfExtensions/iridescence/iridescenceLamp/index.html index c4cdcdf9a..c7c14d3dd 100644 --- a/examples/gltf/gltfExtensions/iridescence/iridescenceLamp/index.html +++ b/examples/gltf/gltfExtensions/iridescence/iridescenceLamp/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/gltfExtensions/iridescence/iridescenceLamp/index.js b/examples/gltf/gltfExtensions/iridescence/iridescenceLamp/index.js index 22d939053..757da558e 100644 --- a/examples/gltf/gltfExtensions/iridescence/iridescenceLamp/index.js +++ b/examples/gltf/gltfExtensions/iridescence/iridescenceLamp/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; import { loadingProgressInfoHandler -} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770698056099' +} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -57,11 +57,11 @@ const loadGLTF = async (view, url) => { } const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { createIblHelper, setDebugButtons - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770698056099'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/gltfExtensions/iridescence/iridescenceMetallicSpheres/index.html b/examples/gltf/gltfExtensions/iridescence/iridescenceMetallicSpheres/index.html index c4cdcdf9a..c7c14d3dd 100644 --- a/examples/gltf/gltfExtensions/iridescence/iridescenceMetallicSpheres/index.html +++ b/examples/gltf/gltfExtensions/iridescence/iridescenceMetallicSpheres/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/gltfExtensions/iridescence/iridescenceMetallicSpheres/index.js b/examples/gltf/gltfExtensions/iridescence/iridescenceMetallicSpheres/index.js index 4ef820d79..604421d31 100644 --- a/examples/gltf/gltfExtensions/iridescence/iridescenceMetallicSpheres/index.js +++ b/examples/gltf/gltfExtensions/iridescence/iridescenceMetallicSpheres/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -41,11 +41,11 @@ function loadGLTF(view, url) { } const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { createIblHelper, setDebugButtons - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770698056099'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU, {useLight: false}); diff --git a/examples/gltf/gltfExtensions/iridescence/iridescenceSuzanne/index.html b/examples/gltf/gltfExtensions/iridescence/iridescenceSuzanne/index.html index c4cdcdf9a..c7c14d3dd 100644 --- a/examples/gltf/gltfExtensions/iridescence/iridescenceSuzanne/index.html +++ b/examples/gltf/gltfExtensions/iridescence/iridescenceSuzanne/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/gltfExtensions/iridescence/iridescenceSuzanne/index.js b/examples/gltf/gltfExtensions/iridescence/iridescenceSuzanne/index.js index d10a5733b..ad637b67f 100644 --- a/examples/gltf/gltfExtensions/iridescence/iridescenceSuzanne/index.js +++ b/examples/gltf/gltfExtensions/iridescence/iridescenceSuzanne/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -41,11 +41,11 @@ function loadGLTF(view, url) { } const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { createIblHelper, setDebugButtons - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770698056099'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/gltfExtensions/iridescence/iridescentDishWithOlives/index.html b/examples/gltf/gltfExtensions/iridescence/iridescentDishWithOlives/index.html index c4cdcdf9a..c7c14d3dd 100644 --- a/examples/gltf/gltfExtensions/iridescence/iridescentDishWithOlives/index.html +++ b/examples/gltf/gltfExtensions/iridescence/iridescentDishWithOlives/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/gltfExtensions/iridescence/iridescentDishWithOlives/index.js b/examples/gltf/gltfExtensions/iridescence/iridescentDishWithOlives/index.js index 8be224f07..98e9dee24 100644 --- a/examples/gltf/gltfExtensions/iridescence/iridescentDishWithOlives/index.js +++ b/examples/gltf/gltfExtensions/iridescence/iridescentDishWithOlives/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; import { loadingProgressInfoHandler -} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770698056099' +} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -57,11 +57,11 @@ const loadGLTF = async (view, url) => { } const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { createIblHelper, setDebugButtons - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770698056099'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/gltfExtensions/iridescence/sunglassesKhronos/index.html b/examples/gltf/gltfExtensions/iridescence/sunglassesKhronos/index.html index c4cdcdf9a..c7c14d3dd 100644 --- a/examples/gltf/gltfExtensions/iridescence/sunglassesKhronos/index.html +++ b/examples/gltf/gltfExtensions/iridescence/sunglassesKhronos/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/gltfExtensions/iridescence/sunglassesKhronos/index.js b/examples/gltf/gltfExtensions/iridescence/sunglassesKhronos/index.js index b9eb35f3d..2c69f42f7 100644 --- a/examples/gltf/gltfExtensions/iridescence/sunglassesKhronos/index.js +++ b/examples/gltf/gltfExtensions/iridescence/sunglassesKhronos/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -42,11 +42,11 @@ function loadGLTF(view, url) { } const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { createIblHelper, setDebugButtons - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770698056099'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/gltfExtensions/sheen/chairDamaskPurplegold/index.html b/examples/gltf/gltfExtensions/sheen/chairDamaskPurplegold/index.html index c4cdcdf9a..c7c14d3dd 100644 --- a/examples/gltf/gltfExtensions/sheen/chairDamaskPurplegold/index.html +++ b/examples/gltf/gltfExtensions/sheen/chairDamaskPurplegold/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/gltfExtensions/sheen/chairDamaskPurplegold/index.js b/examples/gltf/gltfExtensions/sheen/chairDamaskPurplegold/index.js index e8baa7599..dc9201dc2 100644 --- a/examples/gltf/gltfExtensions/sheen/chairDamaskPurplegold/index.js +++ b/examples/gltf/gltfExtensions/sheen/chairDamaskPurplegold/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; import { loadingProgressInfoHandler -} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770698056099' +} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -57,11 +57,11 @@ const loadGLTF = async (view, url) => { } const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { createIblHelper, setDebugButtons - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770698056099'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/gltfExtensions/sheen/compareSheen/index.html b/examples/gltf/gltfExtensions/sheen/compareSheen/index.html index c4cdcdf9a..c7c14d3dd 100644 --- a/examples/gltf/gltfExtensions/sheen/compareSheen/index.html +++ b/examples/gltf/gltfExtensions/sheen/compareSheen/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/gltfExtensions/sheen/compareSheen/index.js b/examples/gltf/gltfExtensions/sheen/compareSheen/index.js index 32c5be0ec..f98f8e6ef 100644 --- a/examples/gltf/gltfExtensions/sheen/compareSheen/index.js +++ b/examples/gltf/gltfExtensions/sheen/compareSheen/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -40,11 +40,11 @@ function loadGLTF(view, url) { } const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { createIblHelper, setDebugButtons - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770698056099'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/gltfExtensions/sheen/glamVelvetSofa/index.html b/examples/gltf/gltfExtensions/sheen/glamVelvetSofa/index.html index c4cdcdf9a..c7c14d3dd 100644 --- a/examples/gltf/gltfExtensions/sheen/glamVelvetSofa/index.html +++ b/examples/gltf/gltfExtensions/sheen/glamVelvetSofa/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/gltfExtensions/sheen/glamVelvetSofa/index.js b/examples/gltf/gltfExtensions/sheen/glamVelvetSofa/index.js index 759abbeaa..bd7007ba1 100644 --- a/examples/gltf/gltfExtensions/sheen/glamVelvetSofa/index.js +++ b/examples/gltf/gltfExtensions/sheen/glamVelvetSofa/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; import { loadingProgressInfoHandler -} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770698056099' +} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -57,11 +57,11 @@ const loadGLTF = async (view, url) => { } const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { createIblHelper, setDebugButtons - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770698056099'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/gltfExtensions/sheen/sheenChair/index.html b/examples/gltf/gltfExtensions/sheen/sheenChair/index.html index c4cdcdf9a..c7c14d3dd 100644 --- a/examples/gltf/gltfExtensions/sheen/sheenChair/index.html +++ b/examples/gltf/gltfExtensions/sheen/sheenChair/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/gltfExtensions/sheen/sheenChair/index.js b/examples/gltf/gltfExtensions/sheen/sheenChair/index.js index 3b75ab17a..deafbc3e3 100644 --- a/examples/gltf/gltfExtensions/sheen/sheenChair/index.js +++ b/examples/gltf/gltfExtensions/sheen/sheenChair/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; import { loadingProgressInfoHandler -} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770698056099' +} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -57,11 +57,11 @@ const loadGLTF = async (view, url) => { } const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { createIblHelper, setDebugButtons - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770698056099'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/gltfExtensions/sheen/sheenCloth/index.html b/examples/gltf/gltfExtensions/sheen/sheenCloth/index.html index c4cdcdf9a..c7c14d3dd 100644 --- a/examples/gltf/gltfExtensions/sheen/sheenCloth/index.html +++ b/examples/gltf/gltfExtensions/sheen/sheenCloth/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/gltfExtensions/sheen/sheenCloth/index.js b/examples/gltf/gltfExtensions/sheen/sheenCloth/index.js index e70208a32..7bdd37429 100644 --- a/examples/gltf/gltfExtensions/sheen/sheenCloth/index.js +++ b/examples/gltf/gltfExtensions/sheen/sheenCloth/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; import { loadingProgressInfoHandler -} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770698056099' +} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -57,11 +57,11 @@ const loadGLTF = async (view, url) => { } const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { createIblHelper, setDebugButtons - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770698056099'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/gltfExtensions/sheen/sheenTestGrid/index.html b/examples/gltf/gltfExtensions/sheen/sheenTestGrid/index.html index c4cdcdf9a..c7c14d3dd 100644 --- a/examples/gltf/gltfExtensions/sheen/sheenTestGrid/index.html +++ b/examples/gltf/gltfExtensions/sheen/sheenTestGrid/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/gltfExtensions/sheen/sheenTestGrid/index.js b/examples/gltf/gltfExtensions/sheen/sheenTestGrid/index.js index 8ae38d337..fd30a81b4 100644 --- a/examples/gltf/gltfExtensions/sheen/sheenTestGrid/index.js +++ b/examples/gltf/gltfExtensions/sheen/sheenTestGrid/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; import { loadingProgressInfoHandler -} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770698056099' +} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -57,11 +57,11 @@ const loadGLTF = async (view, url) => { } const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { createIblHelper, setDebugButtons - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770698056099'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/gltfExtensions/sheen/sheenWoodLeatherSofa/index.html b/examples/gltf/gltfExtensions/sheen/sheenWoodLeatherSofa/index.html index c4cdcdf9a..c7c14d3dd 100644 --- a/examples/gltf/gltfExtensions/sheen/sheenWoodLeatherSofa/index.html +++ b/examples/gltf/gltfExtensions/sheen/sheenWoodLeatherSofa/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/gltfExtensions/sheen/sheenWoodLeatherSofa/index.js b/examples/gltf/gltfExtensions/sheen/sheenWoodLeatherSofa/index.js index 262a6cc5e..5e87163b0 100644 --- a/examples/gltf/gltfExtensions/sheen/sheenWoodLeatherSofa/index.js +++ b/examples/gltf/gltfExtensions/sheen/sheenWoodLeatherSofa/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; import { loadingProgressInfoHandler -} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770698056099' +} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -57,11 +57,11 @@ const loadGLTF = async (view, url) => { } const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { createIblHelper, setDebugButtons - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770698056099'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/gltfExtensions/specular/compareSpecular/index.html b/examples/gltf/gltfExtensions/specular/compareSpecular/index.html index c4cdcdf9a..c7c14d3dd 100644 --- a/examples/gltf/gltfExtensions/specular/compareSpecular/index.html +++ b/examples/gltf/gltfExtensions/specular/compareSpecular/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/gltfExtensions/specular/compareSpecular/index.js b/examples/gltf/gltfExtensions/specular/compareSpecular/index.js index 4b76e06de..ba847620d 100644 --- a/examples/gltf/gltfExtensions/specular/compareSpecular/index.js +++ b/examples/gltf/gltfExtensions/specular/compareSpecular/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; import { loadingProgressInfoHandler -} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770698056099' +} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -57,11 +57,11 @@ const loadGLTF = async (view, url) => { } const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { createIblHelper, setDebugButtons - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770698056099'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/gltfExtensions/specular/specularSilkPouf/index.html b/examples/gltf/gltfExtensions/specular/specularSilkPouf/index.html index c4cdcdf9a..c7c14d3dd 100644 --- a/examples/gltf/gltfExtensions/specular/specularSilkPouf/index.html +++ b/examples/gltf/gltfExtensions/specular/specularSilkPouf/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/gltfExtensions/specular/specularSilkPouf/index.js b/examples/gltf/gltfExtensions/specular/specularSilkPouf/index.js index 9f293e63d..5fcb1de4c 100644 --- a/examples/gltf/gltfExtensions/specular/specularSilkPouf/index.js +++ b/examples/gltf/gltfExtensions/specular/specularSilkPouf/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; import { loadingProgressInfoHandler -} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770698056099' +} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -57,11 +57,11 @@ const loadGLTF = async (view, url) => { } const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { createIblHelper, setDebugButtons - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770698056099'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/gltfExtensions/specular/specularTest/index.html b/examples/gltf/gltfExtensions/specular/specularTest/index.html index c4cdcdf9a..c7c14d3dd 100644 --- a/examples/gltf/gltfExtensions/specular/specularTest/index.html +++ b/examples/gltf/gltfExtensions/specular/specularTest/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/gltfExtensions/specular/specularTest/index.js b/examples/gltf/gltfExtensions/specular/specularTest/index.js index 196476064..5385d9797 100644 --- a/examples/gltf/gltfExtensions/specular/specularTest/index.js +++ b/examples/gltf/gltfExtensions/specular/specularTest/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -40,11 +40,11 @@ function loadGLTF(view, url) { } const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { createIblHelper, setDebugButtons - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770698056099'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/gltfExtensions/textureTransform/textureTransformMultiTest/index.html b/examples/gltf/gltfExtensions/textureTransform/textureTransformMultiTest/index.html index c4cdcdf9a..c7c14d3dd 100644 --- a/examples/gltf/gltfExtensions/textureTransform/textureTransformMultiTest/index.html +++ b/examples/gltf/gltfExtensions/textureTransform/textureTransformMultiTest/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/gltfExtensions/textureTransform/textureTransformMultiTest/index.js b/examples/gltf/gltfExtensions/textureTransform/textureTransformMultiTest/index.js index b2c946e87..c73700e55 100644 --- a/examples/gltf/gltfExtensions/textureTransform/textureTransformMultiTest/index.js +++ b/examples/gltf/gltfExtensions/textureTransform/textureTransformMultiTest/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -40,11 +40,11 @@ function loadGLTF(view, url) { } const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { createIblHelper, setDebugButtons - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770698056099'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/gltfExtensions/textureTransform/textureTransformTest/index.html b/examples/gltf/gltfExtensions/textureTransform/textureTransformTest/index.html index c4cdcdf9a..c7c14d3dd 100644 --- a/examples/gltf/gltfExtensions/textureTransform/textureTransformTest/index.html +++ b/examples/gltf/gltfExtensions/textureTransform/textureTransformTest/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/gltfExtensions/textureTransform/textureTransformTest/index.js b/examples/gltf/gltfExtensions/textureTransform/textureTransformTest/index.js index c1fa6bfa5..cac2ba455 100644 --- a/examples/gltf/gltfExtensions/textureTransform/textureTransformTest/index.js +++ b/examples/gltf/gltfExtensions/textureTransform/textureTransformTest/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -41,11 +41,11 @@ function loadGLTF(view, url) { } const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { createIblHelper, setDebugButtons - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770698056099'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/gltfExtensions/transmission/chronographWatch/index.html b/examples/gltf/gltfExtensions/transmission/chronographWatch/index.html index c4cdcdf9a..c7c14d3dd 100644 --- a/examples/gltf/gltfExtensions/transmission/chronographWatch/index.html +++ b/examples/gltf/gltfExtensions/transmission/chronographWatch/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/gltfExtensions/transmission/chronographWatch/index.js b/examples/gltf/gltfExtensions/transmission/chronographWatch/index.js index e37b7fd08..6fc29e875 100644 --- a/examples/gltf/gltfExtensions/transmission/chronographWatch/index.js +++ b/examples/gltf/gltfExtensions/transmission/chronographWatch/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; import { loadingProgressInfoHandler -} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770698056099' +} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -57,11 +57,11 @@ const loadGLTF = async (view, url) => { } const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { createIblHelper, setDebugButtons - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770698056099'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/gltfExtensions/transmission/commercialRefrigerator/index.html b/examples/gltf/gltfExtensions/transmission/commercialRefrigerator/index.html index c4cdcdf9a..c7c14d3dd 100644 --- a/examples/gltf/gltfExtensions/transmission/commercialRefrigerator/index.html +++ b/examples/gltf/gltfExtensions/transmission/commercialRefrigerator/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/gltfExtensions/transmission/commercialRefrigerator/index.js b/examples/gltf/gltfExtensions/transmission/commercialRefrigerator/index.js index 698337870..52505e301 100644 --- a/examples/gltf/gltfExtensions/transmission/commercialRefrigerator/index.js +++ b/examples/gltf/gltfExtensions/transmission/commercialRefrigerator/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; import { loadingProgressInfoHandler -} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770698056099' +} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -57,11 +57,11 @@ const loadGLTF = async (view, url) => { } const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { createIblHelper, setDebugButtons - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770698056099'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/gltfExtensions/transmission/compareTransmission/index.html b/examples/gltf/gltfExtensions/transmission/compareTransmission/index.html index c4cdcdf9a..c7c14d3dd 100644 --- a/examples/gltf/gltfExtensions/transmission/compareTransmission/index.html +++ b/examples/gltf/gltfExtensions/transmission/compareTransmission/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/gltfExtensions/transmission/compareTransmission/index.js b/examples/gltf/gltfExtensions/transmission/compareTransmission/index.js index a8d5dcb43..15a5e6972 100644 --- a/examples/gltf/gltfExtensions/transmission/compareTransmission/index.js +++ b/examples/gltf/gltfExtensions/transmission/compareTransmission/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -40,11 +40,11 @@ function loadGLTF(view, url) { } const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { createIblHelper, setDebugButtons - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770698056099'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/gltfExtensions/transmission/mosquitoInAmber/index.html b/examples/gltf/gltfExtensions/transmission/mosquitoInAmber/index.html index c4cdcdf9a..c7c14d3dd 100644 --- a/examples/gltf/gltfExtensions/transmission/mosquitoInAmber/index.html +++ b/examples/gltf/gltfExtensions/transmission/mosquitoInAmber/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/gltfExtensions/transmission/mosquitoInAmber/index.js b/examples/gltf/gltfExtensions/transmission/mosquitoInAmber/index.js index 563e95750..16dd9f29c 100644 --- a/examples/gltf/gltfExtensions/transmission/mosquitoInAmber/index.js +++ b/examples/gltf/gltfExtensions/transmission/mosquitoInAmber/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; import { loadingProgressInfoHandler -} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770698056099' +} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -57,11 +57,11 @@ const loadGLTF = async (view, url) => { } const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { createIblHelper, setDebugButtons - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770698056099'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/gltfExtensions/transmission/stainedGlassLamp/index.html b/examples/gltf/gltfExtensions/transmission/stainedGlassLamp/index.html index c4cdcdf9a..c7c14d3dd 100644 --- a/examples/gltf/gltfExtensions/transmission/stainedGlassLamp/index.html +++ b/examples/gltf/gltfExtensions/transmission/stainedGlassLamp/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/gltfExtensions/transmission/stainedGlassLamp/index.js b/examples/gltf/gltfExtensions/transmission/stainedGlassLamp/index.js index 7dc0d1144..e65b2d68c 100644 --- a/examples/gltf/gltfExtensions/transmission/stainedGlassLamp/index.js +++ b/examples/gltf/gltfExtensions/transmission/stainedGlassLamp/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -40,11 +40,11 @@ function loadGLTF(view, url) { } const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { createIblHelper, setDebugButtons - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770698056099'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/gltfExtensions/transmission/transmissionRoughnessTest/index.html b/examples/gltf/gltfExtensions/transmission/transmissionRoughnessTest/index.html index c4cdcdf9a..c7c14d3dd 100644 --- a/examples/gltf/gltfExtensions/transmission/transmissionRoughnessTest/index.html +++ b/examples/gltf/gltfExtensions/transmission/transmissionRoughnessTest/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/gltfExtensions/transmission/transmissionRoughnessTest/index.js b/examples/gltf/gltfExtensions/transmission/transmissionRoughnessTest/index.js index 84aaa4936..9d820679b 100644 --- a/examples/gltf/gltfExtensions/transmission/transmissionRoughnessTest/index.js +++ b/examples/gltf/gltfExtensions/transmission/transmissionRoughnessTest/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -40,11 +40,11 @@ function loadGLTF(view, url) { } const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { createIblHelper, setDebugButtons - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770698056099'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/gltfExtensions/transmission/transmissionTest/index.html b/examples/gltf/gltfExtensions/transmission/transmissionTest/index.html index c4cdcdf9a..c7c14d3dd 100644 --- a/examples/gltf/gltfExtensions/transmission/transmissionTest/index.html +++ b/examples/gltf/gltfExtensions/transmission/transmissionTest/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/gltfExtensions/transmission/transmissionTest/index.js b/examples/gltf/gltfExtensions/transmission/transmissionTest/index.js index 226901da0..982c1e01d 100644 --- a/examples/gltf/gltfExtensions/transmission/transmissionTest/index.js +++ b/examples/gltf/gltfExtensions/transmission/transmissionTest/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; import { loadingProgressInfoHandler -} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770698056099' +} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -57,11 +57,11 @@ const loadGLTF = async (view, url) => { } const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { createIblHelper, setDebugButtons - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770698056099'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/gltfExtensions/unlit/unlitTest/index.html b/examples/gltf/gltfExtensions/unlit/unlitTest/index.html index c4cdcdf9a..c7c14d3dd 100644 --- a/examples/gltf/gltfExtensions/unlit/unlitTest/index.html +++ b/examples/gltf/gltfExtensions/unlit/unlitTest/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/gltfExtensions/unlit/unlitTest/index.js b/examples/gltf/gltfExtensions/unlit/unlitTest/index.js index 664abb6d0..6b3bce273 100644 --- a/examples/gltf/gltfExtensions/unlit/unlitTest/index.js +++ b/examples/gltf/gltfExtensions/unlit/unlitTest/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -40,11 +40,11 @@ function loadGLTF(view, url) { } const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { createIblHelper, setDebugButtons - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770698056099'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/gltfExtensions/volume/IORTestGrid/index.html b/examples/gltf/gltfExtensions/volume/IORTestGrid/index.html index c4cdcdf9a..c7c14d3dd 100644 --- a/examples/gltf/gltfExtensions/volume/IORTestGrid/index.html +++ b/examples/gltf/gltfExtensions/volume/IORTestGrid/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/gltfExtensions/volume/IORTestGrid/index.js b/examples/gltf/gltfExtensions/volume/IORTestGrid/index.js index e588bdd0a..5c3624c5e 100644 --- a/examples/gltf/gltfExtensions/volume/IORTestGrid/index.js +++ b/examples/gltf/gltfExtensions/volume/IORTestGrid/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; import { loadingProgressInfoHandler -} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770698056099' +} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -57,11 +57,11 @@ const loadGLTF = async (view, url) => { } const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { createIblHelper, setDebugButtons - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770698056099'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/gltfExtensions/volume/attenuationTest/index.html b/examples/gltf/gltfExtensions/volume/attenuationTest/index.html index c4cdcdf9a..c7c14d3dd 100644 --- a/examples/gltf/gltfExtensions/volume/attenuationTest/index.html +++ b/examples/gltf/gltfExtensions/volume/attenuationTest/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/gltfExtensions/volume/attenuationTest/index.js b/examples/gltf/gltfExtensions/volume/attenuationTest/index.js index c84819823..4a9a0ed0e 100644 --- a/examples/gltf/gltfExtensions/volume/attenuationTest/index.js +++ b/examples/gltf/gltfExtensions/volume/attenuationTest/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -40,11 +40,11 @@ function loadGLTF(view, url) { } const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { createIblHelper, setDebugButtons - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770698056099'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU, {useLight: false}); diff --git a/examples/gltf/gltfExtensions/volume/compareIor/index.html b/examples/gltf/gltfExtensions/volume/compareIor/index.html index c4cdcdf9a..c7c14d3dd 100644 --- a/examples/gltf/gltfExtensions/volume/compareIor/index.html +++ b/examples/gltf/gltfExtensions/volume/compareIor/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/gltfExtensions/volume/compareIor/index.js b/examples/gltf/gltfExtensions/volume/compareIor/index.js index b4fdac7a6..2b48a2eb0 100644 --- a/examples/gltf/gltfExtensions/volume/compareIor/index.js +++ b/examples/gltf/gltfExtensions/volume/compareIor/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -40,11 +40,11 @@ function loadGLTF(view, url) { } const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { createIblHelper, setDebugButtons - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770698056099'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/gltfExtensions/volume/compareVolume/index.html b/examples/gltf/gltfExtensions/volume/compareVolume/index.html index c4cdcdf9a..c7c14d3dd 100644 --- a/examples/gltf/gltfExtensions/volume/compareVolume/index.html +++ b/examples/gltf/gltfExtensions/volume/compareVolume/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/gltfExtensions/volume/compareVolume/index.js b/examples/gltf/gltfExtensions/volume/compareVolume/index.js index 4cca9a840..5538a97bd 100644 --- a/examples/gltf/gltfExtensions/volume/compareVolume/index.js +++ b/examples/gltf/gltfExtensions/volume/compareVolume/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -40,11 +40,11 @@ function loadGLTF(view, url) { } const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { createIblHelper, setDebugButtons - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770698056099'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/gltfExtensions/volume/dragonAttenuation/index.html b/examples/gltf/gltfExtensions/volume/dragonAttenuation/index.html index c4cdcdf9a..c7c14d3dd 100644 --- a/examples/gltf/gltfExtensions/volume/dragonAttenuation/index.html +++ b/examples/gltf/gltfExtensions/volume/dragonAttenuation/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/gltfExtensions/volume/dragonAttenuation/index.js b/examples/gltf/gltfExtensions/volume/dragonAttenuation/index.js index 08d275493..eaa948564 100644 --- a/examples/gltf/gltfExtensions/volume/dragonAttenuation/index.js +++ b/examples/gltf/gltfExtensions/volume/dragonAttenuation/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; import { loadingProgressInfoHandler -} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770698056099' +} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -57,11 +57,11 @@ const loadGLTF = async (view, url) => { } const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { createIblHelper, setDebugButtons - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770698056099'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/gltfExtensions/volume/glassBrokenWindow/index.html b/examples/gltf/gltfExtensions/volume/glassBrokenWindow/index.html index c4cdcdf9a..c7c14d3dd 100644 --- a/examples/gltf/gltfExtensions/volume/glassBrokenWindow/index.html +++ b/examples/gltf/gltfExtensions/volume/glassBrokenWindow/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/gltfExtensions/volume/glassBrokenWindow/index.js b/examples/gltf/gltfExtensions/volume/glassBrokenWindow/index.js index 229da6287..722ab31ea 100644 --- a/examples/gltf/gltfExtensions/volume/glassBrokenWindow/index.js +++ b/examples/gltf/gltfExtensions/volume/glassBrokenWindow/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; import { loadingProgressInfoHandler -} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770698056099' +} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -57,11 +57,11 @@ const loadGLTF = async (view, url) => { } const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { createIblHelper, setDebugButtons - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770698056099'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/gltfExtensions/volume/glassHurricaneCandleHolder/index.html b/examples/gltf/gltfExtensions/volume/glassHurricaneCandleHolder/index.html index c4cdcdf9a..c7c14d3dd 100644 --- a/examples/gltf/gltfExtensions/volume/glassHurricaneCandleHolder/index.html +++ b/examples/gltf/gltfExtensions/volume/glassHurricaneCandleHolder/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/gltfExtensions/volume/glassHurricaneCandleHolder/index.js b/examples/gltf/gltfExtensions/volume/glassHurricaneCandleHolder/index.js index 9d5049737..151f15b39 100644 --- a/examples/gltf/gltfExtensions/volume/glassHurricaneCandleHolder/index.js +++ b/examples/gltf/gltfExtensions/volume/glassHurricaneCandleHolder/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; import { loadingProgressInfoHandler -} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770698056099' +} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -57,11 +57,11 @@ const loadGLTF = async (view, url) => { } const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { createIblHelper, setDebugButtons - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770698056099'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/gltfExtensions/volume/glassVaseFlowers/index.html b/examples/gltf/gltfExtensions/volume/glassVaseFlowers/index.html index c4cdcdf9a..c7c14d3dd 100644 --- a/examples/gltf/gltfExtensions/volume/glassVaseFlowers/index.html +++ b/examples/gltf/gltfExtensions/volume/glassVaseFlowers/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/gltfExtensions/volume/glassVaseFlowers/index.js b/examples/gltf/gltfExtensions/volume/glassVaseFlowers/index.js index 21bde1a81..08358598f 100644 --- a/examples/gltf/gltfExtensions/volume/glassVaseFlowers/index.js +++ b/examples/gltf/gltfExtensions/volume/glassVaseFlowers/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; import { loadingProgressInfoHandler -} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770698056099' +} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -57,11 +57,11 @@ const loadGLTF = async (view, url) => { } const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { createIblHelper, setDebugButtons - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770698056099'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/gltfExtensions/volume/transmissionThinwallTestGrid/index.html b/examples/gltf/gltfExtensions/volume/transmissionThinwallTestGrid/index.html index c4cdcdf9a..c7c14d3dd 100644 --- a/examples/gltf/gltfExtensions/volume/transmissionThinwallTestGrid/index.html +++ b/examples/gltf/gltfExtensions/volume/transmissionThinwallTestGrid/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/gltfExtensions/volume/transmissionThinwallTestGrid/index.js b/examples/gltf/gltfExtensions/volume/transmissionThinwallTestGrid/index.js index 459f2c5ea..6267449f2 100644 --- a/examples/gltf/gltfExtensions/volume/transmissionThinwallTestGrid/index.js +++ b/examples/gltf/gltfExtensions/volume/transmissionThinwallTestGrid/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; import { loadingProgressInfoHandler -} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770698056099' +} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -57,11 +57,11 @@ const loadGLTF = async (view, url) => { } const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { createIblHelper, setDebugButtons - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770698056099'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/models/aBeautifulGame/index.html b/examples/gltf/models/aBeautifulGame/index.html index b4417a88f..77d781697 100644 --- a/examples/gltf/models/aBeautifulGame/index.html +++ b/examples/gltf/models/aBeautifulGame/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/gltf/models/aBeautifulGame/index.js b/examples/gltf/models/aBeautifulGame/index.js index d35605730..e5cf346aa 100644 --- a/examples/gltf/models/aBeautifulGame/index.js +++ b/examples/gltf/models/aBeautifulGame/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; import { loadingProgressInfoHandler -} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770698056099' +} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -57,11 +57,11 @@ const loadGLTF = async (view, url) => { } const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { createIblHelper, setDebugButtons - } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770698056099'); + } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/models/corset/index.html b/examples/gltf/models/corset/index.html index b4417a88f..77d781697 100644 --- a/examples/gltf/models/corset/index.html +++ b/examples/gltf/models/corset/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/gltf/models/corset/index.js b/examples/gltf/models/corset/index.js index e98f338b3..ba6252591 100644 --- a/examples/gltf/models/corset/index.js +++ b/examples/gltf/models/corset/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; import { loadingProgressInfoHandler -} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770698056099' +} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -57,11 +57,11 @@ const loadGLTF = async (view, url) => { } const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { createIblHelper, setDebugButtons - } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770698056099'); + } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/models/helmets/index.html b/examples/gltf/models/helmets/index.html index b4417a88f..77d781697 100644 --- a/examples/gltf/models/helmets/index.html +++ b/examples/gltf/models/helmets/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/gltf/models/helmets/index.js b/examples/gltf/models/helmets/index.js index 76f2d304f..54d3a0c60 100644 --- a/examples/gltf/models/helmets/index.js +++ b/examples/gltf/models/helmets/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; import { loadingProgressInfoHandler -} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770698056099' +} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' // 1. Create and append a canvas // 1. 캔버스를 생성하고 문서에 추가 @@ -99,11 +99,11 @@ function loadGLTFGrid(view, urls, gridSize = 4, spacing = 3) { } const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { createIblHelper, setDebugButtons - } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770698056099'); + } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); diff --git a/examples/gltf/models/sponza/index.html b/examples/gltf/models/sponza/index.html index b4417a88f..77d781697 100644 --- a/examples/gltf/models/sponza/index.html +++ b/examples/gltf/models/sponza/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/gltf/models/sponza/index.js b/examples/gltf/models/sponza/index.js index 500cf41df..a3f74de2c 100644 --- a/examples/gltf/models/sponza/index.js +++ b/examples/gltf/models/sponza/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; import { loadingProgressInfoHandler -} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770698056099' +} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -60,11 +60,11 @@ const loadGLTF = async (view, url) => { } const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { createIblHelper, setDebugButtons - } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770698056099'); + } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/models/texcooredNTest/index.html b/examples/gltf/models/texcooredNTest/index.html index b4417a88f..77d781697 100644 --- a/examples/gltf/models/texcooredNTest/index.html +++ b/examples/gltf/models/texcooredNTest/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/gltf/models/texcooredNTest/index.js b/examples/gltf/models/texcooredNTest/index.js index fe2d834f6..eb3a70959 100644 --- a/examples/gltf/models/texcooredNTest/index.js +++ b/examples/gltf/models/texcooredNTest/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; import { loadingProgressInfoHandler -} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770698056099' +} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -57,11 +57,11 @@ const loadGLTF = async (view, url) => { } const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { createIblHelper, setDebugButtons - } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770698056099'); + } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/models/tokyo/index.html b/examples/gltf/models/tokyo/index.html index b4417a88f..77d781697 100644 --- a/examples/gltf/models/tokyo/index.html +++ b/examples/gltf/models/tokyo/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/gltf/models/tokyo/index.js b/examples/gltf/models/tokyo/index.js index 108a2aaeb..7011a3b2f 100644 --- a/examples/gltf/models/tokyo/index.js +++ b/examples/gltf/models/tokyo/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; import { loadingProgressInfoHandler -} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770698056099' +} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -58,11 +58,11 @@ const loadGLTF = async (view, url) => { } const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { createIblHelper, setDebugButtons - } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770698056099'); + } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/index.html b/examples/index.html index 785591597..3be700f10 100644 --- a/examples/index.html +++ b/examples/index.html @@ -7,8 +7,8 @@ - - + + RedGPU Examples diff --git a/examples/index.js b/examples/index.js index 90c2cffd7..f64837cd9 100644 --- a/examples/index.js +++ b/examples/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../dist/index.js?t=1770698056099"; +import * as RedGPU from "../dist/index.js?t=1770699661827"; const canvas = document.createElement('canvas'); canvas.setAttribute('id', 'redGPUCanvas') diff --git a/examples/physics/advancedCharacterController/index.html b/examples/physics/advancedCharacterController/index.html index 14f017028..9579c4497 100644 --- a/examples/physics/advancedCharacterController/index.html +++ b/examples/physics/advancedCharacterController/index.html @@ -7,8 +7,8 @@ - - + + diff --git a/examples/physics/advancedCharacterController/index.js b/examples/physics/advancedCharacterController/index.js index 2f9de2bc3..3c02c5b57 100644 --- a/examples/physics/advancedCharacterController/index.js +++ b/examples/physics/advancedCharacterController/index.js @@ -1,5 +1,5 @@ -import * as RedGPU from "../../../dist/index.js?t=1770698056099"; -import { RapierPhysics } from "../../../dist/plugins/physics/rapier/index.js?t=1770698056099"; +import * as RedGPU from "../../../dist/index.js?t=1770699661827"; +import { RapierPhysics } from "../../../dist/plugins/physics/rapier/index.js?t=1770699661827"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -252,8 +252,8 @@ RedGPU.init( * @param {function} resetFunc */ const renderTestPane = async (redGPUContext, resetFunc) => { - const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); - const { setDebugButtons } = await import("../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const { setDebugButtons } = await import("../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext) const pane = new Pane(); pane.addBlade({ diff --git a/examples/physics/basic/index.html b/examples/physics/basic/index.html index 14f017028..9579c4497 100644 --- a/examples/physics/basic/index.html +++ b/examples/physics/basic/index.html @@ -7,8 +7,8 @@ - - + + diff --git a/examples/physics/basic/index.js b/examples/physics/basic/index.js index 0c8e09e87..22b1ffd3b 100644 --- a/examples/physics/basic/index.js +++ b/examples/physics/basic/index.js @@ -1,5 +1,5 @@ -import * as RedGPU from "../../../dist/index.js?t=1770698056099"; -import { RapierPhysics } from "../../../dist/plugins/physics/rapier/index.js?t=1770698056099"; +import * as RedGPU from "../../../dist/index.js?t=1770699661827"; +import { RapierPhysics } from "../../../dist/plugins/physics/rapier/index.js?t=1770699661827"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -145,8 +145,8 @@ RedGPU.init( * @param {function} updateGravityY */ const renderTestPane = async (redGPUContext, physicsEngine, createBox, resetScene, updateGravityY) => { - const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); - const { setDebugButtons } = await import("../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const { setDebugButtons } = await import("../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext) const pane = new Pane(); diff --git a/examples/physics/bowling/index.html b/examples/physics/bowling/index.html index 14f017028..9579c4497 100644 --- a/examples/physics/bowling/index.html +++ b/examples/physics/bowling/index.html @@ -7,8 +7,8 @@ - - + + diff --git a/examples/physics/bowling/index.js b/examples/physics/bowling/index.js index 6794e4242..e895ebcf5 100644 --- a/examples/physics/bowling/index.js +++ b/examples/physics/bowling/index.js @@ -1,5 +1,5 @@ -import * as RedGPU from "../../../dist/index.js?t=1770698056099"; -import { RapierPhysics } from "../../../dist/plugins/physics/rapier/index.js?t=1770698056099"; +import * as RedGPU from "../../../dist/index.js?t=1770699661827"; +import { RapierPhysics } from "../../../dist/plugins/physics/rapier/index.js?t=1770699661827"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -194,8 +194,8 @@ RedGPU.init( * @param {function} resetGame */ const renderTestPane = async (redGPUContext, throwBall, resetGame) => { - const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); - const { setDebugButtons } = await import("../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const { setDebugButtons } = await import("../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext) const pane = new Pane(); diff --git a/examples/physics/buoyancy/index.html b/examples/physics/buoyancy/index.html index 9dfbcf079..7f22fb32d 100644 --- a/examples/physics/buoyancy/index.html +++ b/examples/physics/buoyancy/index.html @@ -13,8 +13,8 @@ - - + + diff --git a/examples/physics/buoyancy/index.js b/examples/physics/buoyancy/index.js index d0a90bf13..8ee424cbc 100644 --- a/examples/physics/buoyancy/index.js +++ b/examples/physics/buoyancy/index.js @@ -1,5 +1,5 @@ -import * as RedGPU from "../../../dist/index.js?t=1770698056099"; -import { RapierPhysics } from "../../../dist/plugins/physics/rapier/index.js?t=1770698056099"; +import * as RedGPU from "../../../dist/index.js?t=1770699661827"; +import { RapierPhysics } from "../../../dist/plugins/physics/rapier/index.js?t=1770699661827"; const canvas = document.body.appendChild(document.createElement('canvas')); @@ -228,8 +228,8 @@ RedGPU.init( * @param {function} resetScene */ const renderTestPane = async (redGPUContext, createObject, resetScene) => { - const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); - const { setDebugButtons } = await import("../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const { setDebugButtons } = await import("../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext) const pane = new Pane(); diff --git a/examples/physics/characterController/index.html b/examples/physics/characterController/index.html index 14f017028..9579c4497 100644 --- a/examples/physics/characterController/index.html +++ b/examples/physics/characterController/index.html @@ -7,8 +7,8 @@ - - + + diff --git a/examples/physics/characterController/index.js b/examples/physics/characterController/index.js index 894aa572d..916386996 100644 --- a/examples/physics/characterController/index.js +++ b/examples/physics/characterController/index.js @@ -1,5 +1,5 @@ -import * as RedGPU from "../../../dist/index.js?t=1770698056099"; -import { RapierPhysics } from "../../../dist/plugins/physics/rapier/index.js?t=1770698056099"; +import * as RedGPU from "../../../dist/index.js?t=1770699661827"; +import { RapierPhysics } from "../../../dist/plugins/physics/rapier/index.js?t=1770699661827"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -187,8 +187,8 @@ RedGPU.init( * @param {function} resetCharacter */ const renderTestPane = async (redGPUContext, resetCharacter) => { - const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); - const { setDebugButtons } = await import("../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const { setDebugButtons } = await import("../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext) const pane = new Pane(); pane.addBlade({ diff --git a/examples/physics/collisionEvents/index.html b/examples/physics/collisionEvents/index.html index acea321aa..52799e64c 100644 --- a/examples/physics/collisionEvents/index.html +++ b/examples/physics/collisionEvents/index.html @@ -13,8 +13,8 @@ - - + + diff --git a/examples/physics/collisionEvents/index.js b/examples/physics/collisionEvents/index.js index 2bace1e33..5fa253071 100644 --- a/examples/physics/collisionEvents/index.js +++ b/examples/physics/collisionEvents/index.js @@ -1,5 +1,5 @@ -import * as RedGPU from "../../../dist/index.js?t=1770698056099"; -import { RapierPhysics } from "../../../dist/plugins/physics/rapier/index.js?t=1770698056099"; +import * as RedGPU from "../../../dist/index.js?t=1770699661827"; +import { RapierPhysics } from "../../../dist/plugins/physics/rapier/index.js?t=1770699661827"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -142,8 +142,8 @@ RedGPU.init( * @param {function} resetScene */ const renderTestPane = async (redGPUContext, createBall, resetScene) => { - const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); - const { setDebugButtons } = await import("../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const { setDebugButtons } = await import("../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext) const pane = new Pane(); pane.addButton({ title: 'Spawn Ball' }).on('click', () => createBall((Math.random() * 2) - 1, 10, (Math.random() * 2) - 1)); diff --git a/examples/physics/collisionFiltering/index.html b/examples/physics/collisionFiltering/index.html index 14f017028..9579c4497 100644 --- a/examples/physics/collisionFiltering/index.html +++ b/examples/physics/collisionFiltering/index.html @@ -7,8 +7,8 @@ - - + + diff --git a/examples/physics/collisionFiltering/index.js b/examples/physics/collisionFiltering/index.js index 74a223297..31383639b 100644 --- a/examples/physics/collisionFiltering/index.js +++ b/examples/physics/collisionFiltering/index.js @@ -1,5 +1,5 @@ -import * as RedGPU from "../../../dist/index.js?t=1770698056099"; -import { RapierPhysics } from "../../../dist/plugins/physics/rapier/index.js?t=1770698056099"; +import * as RedGPU from "../../../dist/index.js?t=1770699661827"; +import { RapierPhysics } from "../../../dist/plugins/physics/rapier/index.js?t=1770699661827"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -170,8 +170,8 @@ RedGPU.init( * @param {function} resetScene */ const renderTestPane = async (redGPUContext, resetScene) => { - const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); - const { setDebugButtons } = await import("../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const { setDebugButtons } = await import("../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext) const pane = new Pane(); pane.addBlade({ diff --git a/examples/physics/compound/index.html b/examples/physics/compound/index.html index 022c559d8..377a8d38a 100644 --- a/examples/physics/compound/index.html +++ b/examples/physics/compound/index.html @@ -16,8 +16,8 @@ - - + + diff --git a/examples/physics/compound/index.js b/examples/physics/compound/index.js index c7a18a5b9..74d180841 100644 --- a/examples/physics/compound/index.js +++ b/examples/physics/compound/index.js @@ -1,5 +1,5 @@ -import * as RedGPU from "../../../dist/index.js?t=1770698056099"; -import { RapierPhysics } from "../../../dist/plugins/physics/rapier/index.js?t=1770698056099"; +import * as RedGPU from "../../../dist/index.js?t=1770699661827"; +import { RapierPhysics } from "../../../dist/plugins/physics/rapier/index.js?t=1770699661827"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -174,8 +174,8 @@ RedGPU.init( * @param {Array} activeDumbbells */ const renderTestPane = async (redGPUContext, createDumbbell, resetScene, activeDumbbells) => { - const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); - const { setDebugButtons } = await import("../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const { setDebugButtons } = await import("../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext) const pane = new Pane(); diff --git a/examples/physics/explosion/index.html b/examples/physics/explosion/index.html index 1e42ff42e..d3d191a6d 100644 --- a/examples/physics/explosion/index.html +++ b/examples/physics/explosion/index.html @@ -13,8 +13,8 @@ - - + + diff --git a/examples/physics/explosion/index.js b/examples/physics/explosion/index.js index fbc973a03..cb403b5f9 100644 --- a/examples/physics/explosion/index.js +++ b/examples/physics/explosion/index.js @@ -1,5 +1,5 @@ -import * as RedGPU from "../../../dist/index.js?t=1770698056099"; -import { RapierPhysics } from "../../../dist/plugins/physics/rapier/index.js?t=1770698056099"; +import * as RedGPU from "../../../dist/index.js?t=1770699661827"; +import { RapierPhysics } from "../../../dist/plugins/physics/rapier/index.js?t=1770699661827"; const canvas = document.body.appendChild(document.createElement('canvas')); @@ -97,8 +97,8 @@ RedGPU.init( * @param {Array} activeBoxes */ const renderTestPane = async (redGPUContext, activeBoxes) => { - const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); - const { setDebugButtons } = await import("../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const { setDebugButtons } = await import("../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); pane.addBlade({ view: 'text', label: 'Interaction', value: 'Click to EXPLODE & SPAWN!', parse: (v) => v, readonly: true }); diff --git a/examples/physics/galton/index.html b/examples/physics/galton/index.html index 176b77c40..22f5b4a9e 100644 --- a/examples/physics/galton/index.html +++ b/examples/physics/galton/index.html @@ -13,8 +13,8 @@ - - + + diff --git a/examples/physics/galton/index.js b/examples/physics/galton/index.js index 626d09dc5..daa329e12 100644 --- a/examples/physics/galton/index.js +++ b/examples/physics/galton/index.js @@ -1,5 +1,5 @@ -import * as RedGPU from "../../../dist/index.js?t=1770698056099"; -import { RapierPhysics } from "../../../dist/plugins/physics/rapier/index.js?t=1770698056099"; +import * as RedGPU from "../../../dist/index.js?t=1770699661827"; +import { RapierPhysics } from "../../../dist/plugins/physics/rapier/index.js?t=1770699661827"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -180,8 +180,8 @@ RedGPU.init( * @param {function} resetScene */ const renderTestPane = async (redGPUContext, intervalId, createBall, resetScene) => { - const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); - const { setDebugButtons } = await import("../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const { setDebugButtons } = await import("../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext) const pane = new Pane(); const params = { diff --git a/examples/physics/gltfPhysics/index.html b/examples/physics/gltfPhysics/index.html index 14f017028..9579c4497 100644 --- a/examples/physics/gltfPhysics/index.html +++ b/examples/physics/gltfPhysics/index.html @@ -7,8 +7,8 @@ - - + + diff --git a/examples/physics/gltfPhysics/index.js b/examples/physics/gltfPhysics/index.js index 3250bf5d1..fae351a7a 100644 --- a/examples/physics/gltfPhysics/index.js +++ b/examples/physics/gltfPhysics/index.js @@ -1,5 +1,5 @@ -import * as RedGPU from "../../../dist/index.js?t=1770698056099"; -import { RapierPhysics } from "../../../dist/plugins/physics/rapier/index.js?t=1770698056099"; +import * as RedGPU from "../../../dist/index.js?t=1770699661827"; +import { RapierPhysics } from "../../../dist/plugins/physics/rapier/index.js?t=1770699661827"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -149,8 +149,8 @@ RedGPU.init( * @param {function} resetScene */ const renderTestPane = async (redGPUContext, resetScene) => { - const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); - const { setDebugButtons } = await import("../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const { setDebugButtons } = await import("../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext) const pane = new Pane(); pane.addButton({ title: 'Reset Balls' }).on('click', () => resetScene()); diff --git a/examples/physics/heightField/index.html b/examples/physics/heightField/index.html index bd0f3fff0..c81983f64 100644 --- a/examples/physics/heightField/index.html +++ b/examples/physics/heightField/index.html @@ -7,8 +7,8 @@ - - + + diff --git a/examples/physics/heightField/index.js b/examples/physics/heightField/index.js index 5bd0c121c..af881ba95 100644 --- a/examples/physics/heightField/index.js +++ b/examples/physics/heightField/index.js @@ -1,5 +1,5 @@ -import * as RedGPU from "../../../dist/index.js?t=1770698056099"; -import { RapierPhysics } from "../../../dist/plugins/physics/rapier/index.js?t=1770698056099"; +import * as RedGPU from "../../../dist/index.js?t=1770699661827"; +import { RapierPhysics } from "../../../dist/plugins/physics/rapier/index.js?t=1770699661827"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -198,8 +198,8 @@ RedGPU.init( * @param {function} resetScene */ const renderTestPane = async (redGPUContext, physicsEngine, spawnSpheres, resetScene) => { - const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); - const { setDebugButtons } = await import("../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const { setDebugButtons } = await import("../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext) const pane = new Pane(); diff --git a/examples/physics/joints/index.html b/examples/physics/joints/index.html index e51bc95e5..19526b034 100644 --- a/examples/physics/joints/index.html +++ b/examples/physics/joints/index.html @@ -13,8 +13,8 @@ - - + + diff --git a/examples/physics/joints/index.js b/examples/physics/joints/index.js index 30f0bdb4c..727c33aa0 100644 --- a/examples/physics/joints/index.js +++ b/examples/physics/joints/index.js @@ -1,5 +1,5 @@ -import * as RedGPU from "../../../dist/index.js?t=1770698056099"; -import { RapierPhysics } from "../../../dist/plugins/physics/rapier/index.js?t=1770698056099"; +import * as RedGPU from "../../../dist/index.js?t=1770699661827"; +import { RapierPhysics } from "../../../dist/plugins/physics/rapier/index.js?t=1770699661827"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -205,8 +205,8 @@ RedGPU.init( * @param {function} resetScene */ const renderTestPane = async (redGPUContext, getBigBallBody, resetScene) => { - const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); - const { setDebugButtons } = await import("../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const { setDebugButtons } = await import("../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext) const pane = new Pane(); diff --git a/examples/physics/kinematic/index.html b/examples/physics/kinematic/index.html index 72cf9e454..fd39c2ee1 100644 --- a/examples/physics/kinematic/index.html +++ b/examples/physics/kinematic/index.html @@ -9,8 +9,8 @@ - - + + diff --git a/examples/physics/kinematic/index.js b/examples/physics/kinematic/index.js index 09dc0b39c..bdbfeffd7 100644 --- a/examples/physics/kinematic/index.js +++ b/examples/physics/kinematic/index.js @@ -1,5 +1,5 @@ -import * as RedGPU from "../../../dist/index.js?t=1770698056099"; -import { RapierPhysics } from "../../../dist/plugins/physics/rapier/index.js?t=1770698056099"; +import * as RedGPU from "../../../dist/index.js?t=1770699661827"; +import { RapierPhysics } from "../../../dist/plugins/physics/rapier/index.js?t=1770699661827"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -148,8 +148,8 @@ RedGPU.init( * @param {function} resetScene */ const renderTestPane = async (redGPUContext, resetScene) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); - const {setDebugButtons} = await import("../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {setDebugButtons} = await import("../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext) const pane = new Pane(); pane.addButton({title: 'Reset Scene'}).on('click', () => resetScene()); diff --git a/examples/physics/meshCollider/index.html b/examples/physics/meshCollider/index.html index 8d506ee90..8ccdf064c 100644 --- a/examples/physics/meshCollider/index.html +++ b/examples/physics/meshCollider/index.html @@ -13,8 +13,8 @@ - - + + diff --git a/examples/physics/meshCollider/index.js b/examples/physics/meshCollider/index.js index 88b062d67..fb1fbbdea 100644 --- a/examples/physics/meshCollider/index.js +++ b/examples/physics/meshCollider/index.js @@ -1,5 +1,5 @@ -import * as RedGPU from "../../../dist/index.js?t=1770698056099"; -import { RapierPhysics } from "../../../dist/plugins/physics/rapier/index.js?t=1770698056099"; +import * as RedGPU from "../../../dist/index.js?t=1770699661827"; +import { RapierPhysics } from "../../../dist/plugins/physics/rapier/index.js?t=1770699661827"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -191,8 +191,8 @@ RedGPU.init( * @param {function} resetScene */ const renderTestPane = async (redGPUContext, resetScene) => { - const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); - const { setDebugButtons } = await import("../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const { setDebugButtons } = await import("../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext) const pane = new Pane(); pane.addBlade({ diff --git a/examples/physics/prismaticJoint/index.html b/examples/physics/prismaticJoint/index.html index 2593d7e0a..4f357461c 100644 --- a/examples/physics/prismaticJoint/index.html +++ b/examples/physics/prismaticJoint/index.html @@ -13,8 +13,8 @@ - - + + diff --git a/examples/physics/prismaticJoint/index.js b/examples/physics/prismaticJoint/index.js index 34f5edaca..87ef8d4d1 100644 --- a/examples/physics/prismaticJoint/index.js +++ b/examples/physics/prismaticJoint/index.js @@ -1,5 +1,5 @@ -import * as RedGPU from "../../../dist/index.js?t=1770698056099"; -import { RapierPhysics } from "../../../dist/plugins/physics/rapier/index.js?t=1770698056099"; +import * as RedGPU from "../../../dist/index.js?t=1770699661827"; +import { RapierPhysics } from "../../../dist/plugins/physics/rapier/index.js?t=1770699661827"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -219,8 +219,8 @@ RedGPU.init( * @param {function} resetScene */ const renderTestPane = async (redGPUContext, platformBody, resetScene) => { - const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); - const { setDebugButtons } = await import("../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const { setDebugButtons } = await import("../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext) const pane = new Pane(); diff --git a/examples/physics/ragdoll/index.html b/examples/physics/ragdoll/index.html index 14f017028..9579c4497 100644 --- a/examples/physics/ragdoll/index.html +++ b/examples/physics/ragdoll/index.html @@ -7,8 +7,8 @@ - - + + diff --git a/examples/physics/ragdoll/index.js b/examples/physics/ragdoll/index.js index 13eef5ab8..620f5d039 100644 --- a/examples/physics/ragdoll/index.js +++ b/examples/physics/ragdoll/index.js @@ -1,5 +1,5 @@ -import * as RedGPU from "../../../dist/index.js?t=1770698056099"; -import { RapierPhysics } from "../../../dist/plugins/physics/rapier/index.js?t=1770698056099"; +import * as RedGPU from "../../../dist/index.js?t=1770699661827"; +import { RapierPhysics } from "../../../dist/plugins/physics/rapier/index.js?t=1770699661827"; const canvas = document.body.appendChild(document.createElement('canvas')); @@ -155,8 +155,8 @@ RedGPU.init( * @param {function} resetScene */ const renderTestPane = async (redGPUContext, spawnRagdoll, resetScene) => { - const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); - const { setDebugButtons } = await import("../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const { setDebugButtons } = await import("../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext) const pane = new Pane(); pane.addButton({ title: 'Spawn Ragdoll' }).on('click', () => spawnRagdoll((Math.random() * 10) - 5, (Math.random() * 10) - 5)); diff --git a/examples/physics/raycast/index.html b/examples/physics/raycast/index.html index f029b08e3..9a1ba4a65 100644 --- a/examples/physics/raycast/index.html +++ b/examples/physics/raycast/index.html @@ -13,8 +13,8 @@ - - + + diff --git a/examples/physics/raycast/index.js b/examples/physics/raycast/index.js index 8ffb31762..96a7563a5 100644 --- a/examples/physics/raycast/index.js +++ b/examples/physics/raycast/index.js @@ -1,5 +1,5 @@ -import * as RedGPU from "../../../dist/index.js?t=1770698056099"; -import { RapierPhysics } from "../../../dist/plugins/physics/rapier/index.js?t=1770698056099"; +import * as RedGPU from "../../../dist/index.js?t=1770699661827"; +import { RapierPhysics } from "../../../dist/plugins/physics/rapier/index.js?t=1770699661827"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -85,8 +85,8 @@ RedGPU.init( * @param {function} resetScene */ const renderTestPane = async (redGPUContext, resetScene) => { - const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); - const { setDebugButtons } = await import("../../../examples/exampleHelper/createExample/panes/index.js?t=1770698056099"); + const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const { setDebugButtons } = await import("../../../examples/exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); pane.addBlade({ view: 'text', label: 'Guide', value: 'Click boxes to push them!', parse: (v) => v, readonly: true }); diff --git a/examples/physics/revoluteJoint/index.html b/examples/physics/revoluteJoint/index.html index 3ac412c90..021f6e9e9 100644 --- a/examples/physics/revoluteJoint/index.html +++ b/examples/physics/revoluteJoint/index.html @@ -13,8 +13,8 @@ - - + + diff --git a/examples/physics/revoluteJoint/index.js b/examples/physics/revoluteJoint/index.js index 8967d3cc0..a65040a98 100644 --- a/examples/physics/revoluteJoint/index.js +++ b/examples/physics/revoluteJoint/index.js @@ -1,5 +1,5 @@ -import * as RedGPU from "../../../dist/index.js?t=1770698056099"; -import { RapierPhysics } from "../../../dist/plugins/physics/rapier/index.js?t=1770698056099"; +import * as RedGPU from "../../../dist/index.js?t=1770699661827"; +import { RapierPhysics } from "../../../dist/plugins/physics/rapier/index.js?t=1770699661827"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -216,8 +216,8 @@ RedGPU.init( * @param {function} resetScene */ const renderTestPane = async (redGPUContext, joint, resetScene) => { - const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); - const { setDebugButtons } = await import("../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const { setDebugButtons } = await import("../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext) const pane = new Pane(); diff --git a/examples/physics/shapes/index.html b/examples/physics/shapes/index.html index 14f017028..9579c4497 100644 --- a/examples/physics/shapes/index.html +++ b/examples/physics/shapes/index.html @@ -7,8 +7,8 @@ - - + + diff --git a/examples/physics/shapes/index.js b/examples/physics/shapes/index.js index 43b896724..568f98662 100644 --- a/examples/physics/shapes/index.js +++ b/examples/physics/shapes/index.js @@ -1,5 +1,5 @@ -import * as RedGPU from "../../../dist/index.js?t=1770698056099"; -import { RapierPhysics } from "../../../dist/plugins/physics/rapier/index.js?t=1770698056099"; +import * as RedGPU from "../../../dist/index.js?t=1770699661827"; +import { RapierPhysics } from "../../../dist/plugins/physics/rapier/index.js?t=1770699661827"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -179,8 +179,8 @@ RedGPU.init( * @param {function} createPhysicalObject */ const renderTestPane = async (redGPUContext, resetScene, createPhysicalObject) => { - const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); - const { setDebugButtons } = await import("../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const { setDebugButtons } = await import("../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext) const pane = new Pane(); const params = { diff --git a/examples/physics/softBody/index.html b/examples/physics/softBody/index.html index bd0f3fff0..c81983f64 100644 --- a/examples/physics/softBody/index.html +++ b/examples/physics/softBody/index.html @@ -7,8 +7,8 @@ - - + + diff --git a/examples/physics/softBody/index.js b/examples/physics/softBody/index.js index 93506c87a..7434540e3 100644 --- a/examples/physics/softBody/index.js +++ b/examples/physics/softBody/index.js @@ -1,5 +1,5 @@ -import * as RedGPU from "../../../dist/index.js?t=1770698056099"; -import { RapierPhysics } from "../../../dist/plugins/physics/rapier/index.js?t=1770698056099"; +import * as RedGPU from "../../../dist/index.js?t=1770699661827"; +import { RapierPhysics } from "../../../dist/plugins/physics/rapier/index.js?t=1770699661827"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -260,8 +260,8 @@ RedGPU.init( * @param {function} resetScene */ const renderTestPane = async (redGPUContext, clothMesh, spawnObject, windBlast, resetScene) => { - const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); - const { setDebugButtons } = await import("../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const { setDebugButtons } = await import("../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext) const pane = new Pane(); diff --git a/examples/physics/springJoint/index.html b/examples/physics/springJoint/index.html index 14f017028..9579c4497 100644 --- a/examples/physics/springJoint/index.html +++ b/examples/physics/springJoint/index.html @@ -7,8 +7,8 @@ - - + + diff --git a/examples/physics/springJoint/index.js b/examples/physics/springJoint/index.js index 4988ca7f8..bb07cb5b6 100644 --- a/examples/physics/springJoint/index.js +++ b/examples/physics/springJoint/index.js @@ -1,5 +1,5 @@ -import * as RedGPU from "../../../dist/index.js?t=1770698056099"; -import { RapierPhysics } from "../../../dist/plugins/physics/rapier/index.js?t=1770698056099"; +import * as RedGPU from "../../../dist/index.js?t=1770699661827"; +import { RapierPhysics } from "../../../dist/plugins/physics/rapier/index.js?t=1770699661827"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -208,7 +208,7 @@ RedGPU.init( // [KO] 8. 테스트 UI 구성: 플랫폼 충격 주기 및 오브젝트 제거 기능 // [EN] 8. Set up test UI: Platform kick and object clearing functions - const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const pane = new Pane(); const params = { diff --git a/examples/physics/stressTest/index.html b/examples/physics/stressTest/index.html index c53db1570..3cf44c062 100644 --- a/examples/physics/stressTest/index.html +++ b/examples/physics/stressTest/index.html @@ -13,8 +13,8 @@ - - + + diff --git a/examples/physics/stressTest/index.js b/examples/physics/stressTest/index.js index 59e06163a..8292cd2b6 100644 --- a/examples/physics/stressTest/index.js +++ b/examples/physics/stressTest/index.js @@ -1,5 +1,5 @@ -import * as RedGPU from "../../../dist/index.js?t=1770698056099"; -import { RapierPhysics } from "../../../dist/plugins/physics/rapier/index.js?t=1770698056099"; +import * as RedGPU from "../../../dist/index.js?t=1770699661827"; +import { RapierPhysics } from "../../../dist/plugins/physics/rapier/index.js?t=1770699661827"; const canvas = document.body.appendChild(document.createElement('canvas')); @@ -132,8 +132,8 @@ RedGPU.init( * @param {Array} activeObjects */ const renderTestPane = async (redGPUContext, createBall, resetScene, activeObjects) => { - const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); - const { setDebugButtons } = await import("../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const { setDebugButtons } = await import("../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext) const pane = new Pane(); diff --git a/examples/physics/surfaceVelocity/index.html b/examples/physics/surfaceVelocity/index.html index 14f017028..9579c4497 100644 --- a/examples/physics/surfaceVelocity/index.html +++ b/examples/physics/surfaceVelocity/index.html @@ -7,8 +7,8 @@ - - + + diff --git a/examples/physics/surfaceVelocity/index.js b/examples/physics/surfaceVelocity/index.js index b6c0ab6bb..a0ee4686b 100644 --- a/examples/physics/surfaceVelocity/index.js +++ b/examples/physics/surfaceVelocity/index.js @@ -1,5 +1,5 @@ -import * as RedGPU from "../../../dist/index.js?t=1770698056099"; -import { RapierPhysics } from "../../../dist/plugins/physics/rapier/index.js?t=1770698056099"; +import * as RedGPU from "../../../dist/index.js?t=1770699661827"; +import { RapierPhysics } from "../../../dist/plugins/physics/rapier/index.js?t=1770699661827"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -235,8 +235,8 @@ RedGPU.init( * @param {function} resetScene */ const renderTestPane = async (redGPUContext, resetScene) => { - const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); - const { setDebugButtons } = await import("../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const { setDebugButtons } = await import("../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext) const pane = new Pane(); pane.addBlade({ diff --git a/examples/physics/triggers/index.html b/examples/physics/triggers/index.html index 266382353..5b18e3aad 100644 --- a/examples/physics/triggers/index.html +++ b/examples/physics/triggers/index.html @@ -13,8 +13,8 @@ - - + + diff --git a/examples/physics/triggers/index.js b/examples/physics/triggers/index.js index 404aa2678..e8e435ab3 100644 --- a/examples/physics/triggers/index.js +++ b/examples/physics/triggers/index.js @@ -1,5 +1,5 @@ -import * as RedGPU from "../../../dist/index.js?t=1770698056099"; -import { RapierPhysics } from "../../../dist/plugins/physics/rapier/index.js?t=1770698056099"; +import * as RedGPU from "../../../dist/index.js?t=1770699661827"; +import { RapierPhysics } from "../../../dist/plugins/physics/rapier/index.js?t=1770699661827"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -189,8 +189,8 @@ RedGPU.init( * @param {function} resetScene */ const renderTestPane = async (redGPUContext, scene, triggerMesh, resetScene) => { - const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); - const { setDebugButtons } = await import("../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const { setDebugButtons } = await import("../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext) const pane = new Pane(); diff --git a/examples/postEffect/adjustments/brightnessContrast/index.html b/examples/postEffect/adjustments/brightnessContrast/index.html index 7f0605e12..112d2b5eb 100644 --- a/examples/postEffect/adjustments/brightnessContrast/index.html +++ b/examples/postEffect/adjustments/brightnessContrast/index.html @@ -8,8 +8,8 @@ - - + +
diff --git a/examples/postEffect/adjustments/brightnessContrast/index.js b/examples/postEffect/adjustments/brightnessContrast/index.js index c1e2e3d9a..c879150a7 100644 --- a/examples/postEffect/adjustments/brightnessContrast/index.js +++ b/examples/postEffect/adjustments/brightnessContrast/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; // 1. Create and append a canvas // 1. 캔버스를 생성하고 문서에 추가 @@ -126,10 +126,10 @@ function loadGLTF(redGPUContext, scene, url) { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); - const {createPostEffectLabel} = await import('../../../exampleHelper/createExample/loadExampleInfo/createPostEffectLabel.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {createPostEffectLabel} = await import('../../../exampleHelper/createExample/loadExampleInfo/createPostEffectLabel.js?t=1770699661827'); createPostEffectLabel('BrightnessContrast', redGPUContext.detector.isMobile) - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); diff --git a/examples/postEffect/adjustments/colorBalance/index.html b/examples/postEffect/adjustments/colorBalance/index.html index 7f0605e12..112d2b5eb 100644 --- a/examples/postEffect/adjustments/colorBalance/index.html +++ b/examples/postEffect/adjustments/colorBalance/index.html @@ -8,8 +8,8 @@ - - + +
diff --git a/examples/postEffect/adjustments/colorBalance/index.js b/examples/postEffect/adjustments/colorBalance/index.js index 2fc7dd377..3734e6194 100644 --- a/examples/postEffect/adjustments/colorBalance/index.js +++ b/examples/postEffect/adjustments/colorBalance/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; // 1. Create and append a canvas // 1. 캔버스를 생성하고 문서에 추가 @@ -126,10 +126,10 @@ function loadGLTF(redGPUContext, scene, url) { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); - const {createPostEffectLabel} = await import('../../../exampleHelper/createExample/loadExampleInfo/createPostEffectLabel.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {createPostEffectLabel} = await import('../../../exampleHelper/createExample/loadExampleInfo/createPostEffectLabel.js?t=1770699661827'); createPostEffectLabel('ColorBalance', redGPUContext.detector.isMobile) - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); diff --git a/examples/postEffect/adjustments/colorTemperatureTint/index.html b/examples/postEffect/adjustments/colorTemperatureTint/index.html index 7f0605e12..112d2b5eb 100644 --- a/examples/postEffect/adjustments/colorTemperatureTint/index.html +++ b/examples/postEffect/adjustments/colorTemperatureTint/index.html @@ -8,8 +8,8 @@ - - + +
diff --git a/examples/postEffect/adjustments/colorTemperatureTint/index.js b/examples/postEffect/adjustments/colorTemperatureTint/index.js index e463494af..5a6beabaf 100644 --- a/examples/postEffect/adjustments/colorTemperatureTint/index.js +++ b/examples/postEffect/adjustments/colorTemperatureTint/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; // 1. Create and append a canvas // 1. 캔버스를 생성하고 문서에 추가 @@ -127,10 +127,10 @@ function loadGLTF(redGPUContext, scene, url) { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); - const {createPostEffectLabel} = await import('../../../exampleHelper/createExample/loadExampleInfo/createPostEffectLabel.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {createPostEffectLabel} = await import('../../../exampleHelper/createExample/loadExampleInfo/createPostEffectLabel.js?t=1770699661827'); createPostEffectLabel('ColorTemperatureTint', redGPUContext.detector.isMobile) - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); const effect = targetView.postEffectManager.getEffectAt(0); diff --git a/examples/postEffect/adjustments/grayscale/index.html b/examples/postEffect/adjustments/grayscale/index.html index 7f0605e12..112d2b5eb 100644 --- a/examples/postEffect/adjustments/grayscale/index.html +++ b/examples/postEffect/adjustments/grayscale/index.html @@ -8,8 +8,8 @@ - - + +
diff --git a/examples/postEffect/adjustments/grayscale/index.js b/examples/postEffect/adjustments/grayscale/index.js index 0d1d5f0ee..e06a8d79b 100644 --- a/examples/postEffect/adjustments/grayscale/index.js +++ b/examples/postEffect/adjustments/grayscale/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; // 1. Create and append a canvas // 1. 캔버스를 생성하고 문서에 추가 @@ -126,10 +126,10 @@ function loadGLTF(redGPUContext, scene, url) { * @param {RedGPU.Display.View3D} viewEffect */ const renderTestPane = async (redGPUContext, viewEffect) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); - const {createPostEffectLabel} = await import('../../../exampleHelper/createExample/loadExampleInfo/createPostEffectLabel.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {createPostEffectLabel} = await import('../../../exampleHelper/createExample/loadExampleInfo/createPostEffectLabel.js?t=1770699661827'); createPostEffectLabel('Grayscale', redGPUContext.detector.isMobile) - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); const view = viewEffect diff --git a/examples/postEffect/adjustments/hueSaturation/index.html b/examples/postEffect/adjustments/hueSaturation/index.html index 7f0605e12..112d2b5eb 100644 --- a/examples/postEffect/adjustments/hueSaturation/index.html +++ b/examples/postEffect/adjustments/hueSaturation/index.html @@ -8,8 +8,8 @@ - - + +
diff --git a/examples/postEffect/adjustments/hueSaturation/index.js b/examples/postEffect/adjustments/hueSaturation/index.js index 1df884f74..8333b12a9 100644 --- a/examples/postEffect/adjustments/hueSaturation/index.js +++ b/examples/postEffect/adjustments/hueSaturation/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; // 1. Create and append a canvas // 1. 캔버스를 생성하고 문서에 추가 @@ -126,10 +126,10 @@ function loadGLTF(redGPUContext, scene, url) { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); - const {createPostEffectLabel} = await import('../../../exampleHelper/createExample/loadExampleInfo/createPostEffectLabel.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {createPostEffectLabel} = await import('../../../exampleHelper/createExample/loadExampleInfo/createPostEffectLabel.js?t=1770699661827'); createPostEffectLabel('HueSaturation', redGPUContext.detector.isMobile) - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); diff --git a/examples/postEffect/adjustments/invert/index.html b/examples/postEffect/adjustments/invert/index.html index 7f0605e12..112d2b5eb 100644 --- a/examples/postEffect/adjustments/invert/index.html +++ b/examples/postEffect/adjustments/invert/index.html @@ -8,8 +8,8 @@ - - + +
diff --git a/examples/postEffect/adjustments/invert/index.js b/examples/postEffect/adjustments/invert/index.js index abf0ab37c..d0516165a 100644 --- a/examples/postEffect/adjustments/invert/index.js +++ b/examples/postEffect/adjustments/invert/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; // 1. Create and append a canvas // 1. 캔버스를 생성하고 문서에 추가 @@ -126,10 +126,10 @@ function loadGLTF(redGPUContext, scene, url) { * @param {RedGPU.Display.View3D} viewEffect */ const renderTestPane = async (redGPUContext, viewEffect) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); - const {createPostEffectLabel} = await import('../../../exampleHelper/createExample/loadExampleInfo/createPostEffectLabel.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {createPostEffectLabel} = await import('../../../exampleHelper/createExample/loadExampleInfo/createPostEffectLabel.js?t=1770699661827'); createPostEffectLabel('Invert', redGPUContext.detector.isMobile) - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); const view = viewEffect diff --git a/examples/postEffect/adjustments/threshold/index.html b/examples/postEffect/adjustments/threshold/index.html index 7f0605e12..112d2b5eb 100644 --- a/examples/postEffect/adjustments/threshold/index.html +++ b/examples/postEffect/adjustments/threshold/index.html @@ -8,8 +8,8 @@ - - + +
diff --git a/examples/postEffect/adjustments/threshold/index.js b/examples/postEffect/adjustments/threshold/index.js index 5e2ede946..b3f9f56a6 100644 --- a/examples/postEffect/adjustments/threshold/index.js +++ b/examples/postEffect/adjustments/threshold/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; // 1. Create and append a canvas // 1. 캔버스를 생성하고 문서에 추가 @@ -126,10 +126,10 @@ function loadGLTF(redGPUContext, scene, url) { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); - const {createPostEffectLabel} = await import('../../../exampleHelper/createExample/loadExampleInfo/createPostEffectLabel.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {createPostEffectLabel} = await import('../../../exampleHelper/createExample/loadExampleInfo/createPostEffectLabel.js?t=1770699661827'); createPostEffectLabel('Threshold', redGPUContext.detector.isMobile) - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); diff --git a/examples/postEffect/adjustments/vibrance/index.html b/examples/postEffect/adjustments/vibrance/index.html index 7f0605e12..112d2b5eb 100644 --- a/examples/postEffect/adjustments/vibrance/index.html +++ b/examples/postEffect/adjustments/vibrance/index.html @@ -8,8 +8,8 @@ - - + +
diff --git a/examples/postEffect/adjustments/vibrance/index.js b/examples/postEffect/adjustments/vibrance/index.js index 34289daa2..53c26b3a4 100644 --- a/examples/postEffect/adjustments/vibrance/index.js +++ b/examples/postEffect/adjustments/vibrance/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; // 1. Create and append a canvas // 1. 캔버스를 생성하고 문서에 추가 @@ -126,10 +126,10 @@ function loadGLTF(redGPUContext, scene, url) { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); - const {createPostEffectLabel} = await import('../../../exampleHelper/createExample/loadExampleInfo/createPostEffectLabel.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {createPostEffectLabel} = await import('../../../exampleHelper/createExample/loadExampleInfo/createPostEffectLabel.js?t=1770699661827'); createPostEffectLabel('Vibrance', redGPUContext.detector.isMobile) - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); diff --git a/examples/postEffect/blur/blur/index.html b/examples/postEffect/blur/blur/index.html index 7f0605e12..112d2b5eb 100644 --- a/examples/postEffect/blur/blur/index.html +++ b/examples/postEffect/blur/blur/index.html @@ -8,8 +8,8 @@ - - + +
diff --git a/examples/postEffect/blur/blur/index.js b/examples/postEffect/blur/blur/index.js index 4d1bd6b0c..bd1f9f26c 100644 --- a/examples/postEffect/blur/blur/index.js +++ b/examples/postEffect/blur/blur/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; // 1. Create and append a canvas // 1. 캔버스를 생성하고 문서에 추가 @@ -127,10 +127,10 @@ function loadGLTF(redGPUContext, scene, url) { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); - const {createPostEffectLabel} = await import('../../../exampleHelper/createExample/loadExampleInfo/createPostEffectLabel.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {createPostEffectLabel} = await import('../../../exampleHelper/createExample/loadExampleInfo/createPostEffectLabel.js?t=1770699661827'); createPostEffectLabel('Blur', redGPUContext.detector.isMobile) - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); diff --git a/examples/postEffect/blur/blurX/index.html b/examples/postEffect/blur/blurX/index.html index 7f0605e12..112d2b5eb 100644 --- a/examples/postEffect/blur/blurX/index.html +++ b/examples/postEffect/blur/blurX/index.html @@ -8,8 +8,8 @@ - - + +
diff --git a/examples/postEffect/blur/blurX/index.js b/examples/postEffect/blur/blurX/index.js index 31f401a19..37a67d91c 100644 --- a/examples/postEffect/blur/blurX/index.js +++ b/examples/postEffect/blur/blurX/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; // 1. Create and append a canvas // 1. 캔버스를 생성하고 문서에 추가 @@ -126,10 +126,10 @@ function loadGLTF(redGPUContext, scene, url) { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); - const {createPostEffectLabel} = await import('../../../exampleHelper/createExample/loadExampleInfo/createPostEffectLabel.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {createPostEffectLabel} = await import('../../../exampleHelper/createExample/loadExampleInfo/createPostEffectLabel.js?t=1770699661827'); createPostEffectLabel('Blur', redGPUContext.detector.isMobile) - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); diff --git a/examples/postEffect/blur/blurY/index.html b/examples/postEffect/blur/blurY/index.html index 7f0605e12..112d2b5eb 100644 --- a/examples/postEffect/blur/blurY/index.html +++ b/examples/postEffect/blur/blurY/index.html @@ -8,8 +8,8 @@ - - + +
diff --git a/examples/postEffect/blur/blurY/index.js b/examples/postEffect/blur/blurY/index.js index 8c6824d80..520a43924 100644 --- a/examples/postEffect/blur/blurY/index.js +++ b/examples/postEffect/blur/blurY/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; // 1. Create and append a canvas // 1. 캔버스를 생성하고 문서에 추가 @@ -126,10 +126,10 @@ function loadGLTF(redGPUContext, scene, url) { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); - const {createPostEffectLabel} = await import('../../../exampleHelper/createExample/loadExampleInfo/createPostEffectLabel.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {createPostEffectLabel} = await import('../../../exampleHelper/createExample/loadExampleInfo/createPostEffectLabel.js?t=1770699661827'); createPostEffectLabel('Blur', redGPUContext.detector.isMobile) - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); diff --git a/examples/postEffect/blur/directionalBlur/index.html b/examples/postEffect/blur/directionalBlur/index.html index 7f0605e12..112d2b5eb 100644 --- a/examples/postEffect/blur/directionalBlur/index.html +++ b/examples/postEffect/blur/directionalBlur/index.html @@ -8,8 +8,8 @@ - - + +
diff --git a/examples/postEffect/blur/directionalBlur/index.js b/examples/postEffect/blur/directionalBlur/index.js index 9026fbf40..4c7eaf6c5 100644 --- a/examples/postEffect/blur/directionalBlur/index.js +++ b/examples/postEffect/blur/directionalBlur/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; // 1. Create and append a canvas // 1. 캔버스를 생성하고 문서에 추가 @@ -126,10 +126,10 @@ function loadGLTF(redGPUContext, scene, url) { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); - const {createPostEffectLabel} = await import('../../../exampleHelper/createExample/loadExampleInfo/createPostEffectLabel.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {createPostEffectLabel} = await import('../../../exampleHelper/createExample/loadExampleInfo/createPostEffectLabel.js?t=1770699661827'); createPostEffectLabel('DirectionalBlur', redGPUContext.detector.isMobile) - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); diff --git a/examples/postEffect/blur/gaussianBlur/index.html b/examples/postEffect/blur/gaussianBlur/index.html index 7f0605e12..112d2b5eb 100644 --- a/examples/postEffect/blur/gaussianBlur/index.html +++ b/examples/postEffect/blur/gaussianBlur/index.html @@ -8,8 +8,8 @@ - - + +
diff --git a/examples/postEffect/blur/gaussianBlur/index.js b/examples/postEffect/blur/gaussianBlur/index.js index a833e56c6..2b7b6edd5 100644 --- a/examples/postEffect/blur/gaussianBlur/index.js +++ b/examples/postEffect/blur/gaussianBlur/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; // 1. Create and append a canvas // 1. 캔버스를 생성하고 문서에 추가 @@ -126,10 +126,10 @@ function loadGLTF(redGPUContext, scene, url) { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); - const {createPostEffectLabel} = await import('../../../exampleHelper/createExample/loadExampleInfo/createPostEffectLabel.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {createPostEffectLabel} = await import('../../../exampleHelper/createExample/loadExampleInfo/createPostEffectLabel.js?t=1770699661827'); createPostEffectLabel('GaussianBlur', redGPUContext.detector.isMobile) - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); diff --git a/examples/postEffect/blur/radialBlur/index.html b/examples/postEffect/blur/radialBlur/index.html index 7f0605e12..112d2b5eb 100644 --- a/examples/postEffect/blur/radialBlur/index.html +++ b/examples/postEffect/blur/radialBlur/index.html @@ -8,8 +8,8 @@ - - + +
diff --git a/examples/postEffect/blur/radialBlur/index.js b/examples/postEffect/blur/radialBlur/index.js index 351319426..7913dac1c 100644 --- a/examples/postEffect/blur/radialBlur/index.js +++ b/examples/postEffect/blur/radialBlur/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; // 1. Create and append a canvas // 1. 캔버스를 생성하고 문서에 추가 @@ -126,10 +126,10 @@ function loadGLTF(redGPUContext, scene, url) { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); - const {createPostEffectLabel} = await import('../../../exampleHelper/createExample/loadExampleInfo/createPostEffectLabel.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {createPostEffectLabel} = await import('../../../exampleHelper/createExample/loadExampleInfo/createPostEffectLabel.js?t=1770699661827'); createPostEffectLabel('RadialBlur', redGPUContext.detector.isMobile) - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); diff --git a/examples/postEffect/blur/zoomBlur/index.html b/examples/postEffect/blur/zoomBlur/index.html index 7f0605e12..112d2b5eb 100644 --- a/examples/postEffect/blur/zoomBlur/index.html +++ b/examples/postEffect/blur/zoomBlur/index.html @@ -8,8 +8,8 @@ - - + +
diff --git a/examples/postEffect/blur/zoomBlur/index.js b/examples/postEffect/blur/zoomBlur/index.js index dc1489dda..fc83c9ebd 100644 --- a/examples/postEffect/blur/zoomBlur/index.js +++ b/examples/postEffect/blur/zoomBlur/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; // 1. Create and append a canvas // 1. 캔버스를 생성하고 문서에 추가 @@ -126,10 +126,10 @@ function loadGLTF(redGPUContext, scene, url) { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); - const {createPostEffectLabel} = await import('../../../exampleHelper/createExample/loadExampleInfo/createPostEffectLabel.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {createPostEffectLabel} = await import('../../../exampleHelper/createExample/loadExampleInfo/createPostEffectLabel.js?t=1770699661827'); createPostEffectLabel('ZoomBlur', redGPUContext.detector.isMobile) - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); diff --git a/examples/postEffect/convolution/index.html b/examples/postEffect/convolution/index.html index 490422bfb..470caed74 100644 --- a/examples/postEffect/convolution/index.html +++ b/examples/postEffect/convolution/index.html @@ -8,8 +8,8 @@ - - + +
diff --git a/examples/postEffect/convolution/index.js b/examples/postEffect/convolution/index.js index ffcef1b1c..624f2e38a 100644 --- a/examples/postEffect/convolution/index.js +++ b/examples/postEffect/convolution/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../dist/index.js?t=1770699661827"; // 1. Create and append a canvas // 1. 캔버스를 생성하고 문서에 추가 @@ -126,10 +126,10 @@ function loadGLTF(redGPUContext, scene, url) { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); - const {createPostEffectLabel} = await import('../../exampleHelper/createExample/loadExampleInfo/createPostEffectLabel.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {createPostEffectLabel} = await import('../../exampleHelper/createExample/loadExampleInfo/createPostEffectLabel.js?t=1770699661827'); createPostEffectLabel('Convolution', redGPUContext.detector.isMobile) - const {setDebugButtons} = await import("../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const {setDebugButtons} = await import("../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); const TEST_STATE = { diff --git a/examples/postEffect/filmGrain/index.html b/examples/postEffect/filmGrain/index.html index 490422bfb..470caed74 100644 --- a/examples/postEffect/filmGrain/index.html +++ b/examples/postEffect/filmGrain/index.html @@ -8,8 +8,8 @@ - - + +
diff --git a/examples/postEffect/filmGrain/index.js b/examples/postEffect/filmGrain/index.js index 5ee1a25f5..1eb9af1a4 100644 --- a/examples/postEffect/filmGrain/index.js +++ b/examples/postEffect/filmGrain/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../dist/index.js?t=1770699661827"; // 1. Create and append a canvas // 1. 캔버스를 생성하고 문서에 추가 @@ -126,10 +126,10 @@ function loadGLTF(redGPUContext, scene, url) { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); - const {createPostEffectLabel} = await import('../../exampleHelper/createExample/loadExampleInfo/createPostEffectLabel.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {createPostEffectLabel} = await import('../../exampleHelper/createExample/loadExampleInfo/createPostEffectLabel.js?t=1770699661827'); createPostEffectLabel('FilmGrain', redGPUContext.detector.isMobile) - const {setDebugButtons} = await import("../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const {setDebugButtons} = await import("../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); diff --git a/examples/postEffect/fog/fog/index.html b/examples/postEffect/fog/fog/index.html index 7f0605e12..112d2b5eb 100644 --- a/examples/postEffect/fog/fog/index.html +++ b/examples/postEffect/fog/fog/index.html @@ -8,8 +8,8 @@ - - + +
diff --git a/examples/postEffect/fog/fog/index.js b/examples/postEffect/fog/fog/index.js index 282385647..07a222e07 100644 --- a/examples/postEffect/fog/fog/index.js +++ b/examples/postEffect/fog/fog/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; const canvas = document.createElement('canvas'); document.querySelector('#example-container').appendChild(canvas); @@ -147,10 +147,10 @@ function createTestScene(redGPUContext, scene) { * @param {RedGPU.PostEffect.Fog} fogEffect */ async function createControlPanel(redGPUContext, view, fogEffect) { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const pane = new Pane({title: '🌫️ Fog Test'}); - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext); const PARAMS = { enabled: true, diff --git a/examples/postEffect/fog/heightFog/index.html b/examples/postEffect/fog/heightFog/index.html index 7f0605e12..112d2b5eb 100644 --- a/examples/postEffect/fog/heightFog/index.html +++ b/examples/postEffect/fog/heightFog/index.html @@ -8,8 +8,8 @@ - - + +
diff --git a/examples/postEffect/fog/heightFog/index.js b/examples/postEffect/fog/heightFog/index.js index 30657cfc0..f432e4a9e 100644 --- a/examples/postEffect/fog/heightFog/index.js +++ b/examples/postEffect/fog/heightFog/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; const canvas = document.createElement('canvas'); document.querySelector('#example-container').appendChild(canvas); @@ -290,10 +290,10 @@ function createGroundLevelScene(redGPUContext, scene) { * @param {function} toggleAutoRotate */ async function createHeightFogControlPanel(redGPUContext, view, heightFog, controller, toggleAutoRotate) { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const pane = new Pane({title: 'Height Fog Demo', expanded: true}); - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext); const PARAMS = { enabled: true, diff --git a/examples/postEffect/lens/chromaticAberration/index.html b/examples/postEffect/lens/chromaticAberration/index.html index 7f0605e12..112d2b5eb 100644 --- a/examples/postEffect/lens/chromaticAberration/index.html +++ b/examples/postEffect/lens/chromaticAberration/index.html @@ -8,8 +8,8 @@ - - + +
diff --git a/examples/postEffect/lens/chromaticAberration/index.js b/examples/postEffect/lens/chromaticAberration/index.js index 9b4a82b55..9b6fe290d 100644 --- a/examples/postEffect/lens/chromaticAberration/index.js +++ b/examples/postEffect/lens/chromaticAberration/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; // 1. Create and append a canvas // 1. 캔버스를 생성하고 문서에 추가 @@ -114,10 +114,10 @@ function loadGLTF(redGPUContext, scene, url) { } const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); - const {createPostEffectLabel} = await import('../../../exampleHelper/createExample/loadExampleInfo/createPostEffectLabel.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {createPostEffectLabel} = await import('../../../exampleHelper/createExample/loadExampleInfo/createPostEffectLabel.js?t=1770699661827'); createPostEffectLabel('ChromaticAberration', redGPUContext.detector.isMobile) - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); diff --git a/examples/postEffect/lens/dof/index.html b/examples/postEffect/lens/dof/index.html index 7f0605e12..112d2b5eb 100644 --- a/examples/postEffect/lens/dof/index.html +++ b/examples/postEffect/lens/dof/index.html @@ -8,8 +8,8 @@ - - + +
diff --git a/examples/postEffect/lens/dof/index.js b/examples/postEffect/lens/dof/index.js index 9121d2c36..9ccbda5e7 100644 --- a/examples/postEffect/lens/dof/index.js +++ b/examples/postEffect/lens/dof/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; // 1. Create and append a canvas const canvas = document.createElement('canvas'); @@ -207,11 +207,11 @@ function loadGLTF(redGPUContext, scene, url) { } const renderTestPane = async (redGPUContext, targetView) => { - const {createPostEffectLabel} = await import('../../../exampleHelper/createExample/loadExampleInfo/createPostEffectLabel.js?t=1770698056099'); + const {createPostEffectLabel} = await import('../../../exampleHelper/createExample/loadExampleInfo/createPostEffectLabel.js?t=1770699661827'); createPostEffectLabel('DOF', redGPUContext.detector.isMobile) - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext); - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const pane = new Pane(); const effect = targetView.postEffectManager.getEffectAt(0) diff --git a/examples/postEffect/lens/lensDistortion/index.html b/examples/postEffect/lens/lensDistortion/index.html index 7f0605e12..112d2b5eb 100644 --- a/examples/postEffect/lens/lensDistortion/index.html +++ b/examples/postEffect/lens/lensDistortion/index.html @@ -8,8 +8,8 @@ - - + +
diff --git a/examples/postEffect/lens/lensDistortion/index.js b/examples/postEffect/lens/lensDistortion/index.js index b9f2418d3..0b9ef6f93 100644 --- a/examples/postEffect/lens/lensDistortion/index.js +++ b/examples/postEffect/lens/lensDistortion/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; // 1. Create and append a canvas // 1. 캔버스를 생성하고 문서에 추가 @@ -113,10 +113,10 @@ function loadGLTF(redGPUContext, scene, url) { } const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); - const {createPostEffectLabel} = await import('../../../exampleHelper/createExample/loadExampleInfo/createPostEffectLabel.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {createPostEffectLabel} = await import('../../../exampleHelper/createExample/loadExampleInfo/createPostEffectLabel.js?t=1770699661827'); createPostEffectLabel('LensDistortion', redGPUContext.detector.isMobile) - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); diff --git a/examples/postEffect/lens/vignetting/index.html b/examples/postEffect/lens/vignetting/index.html index 7f0605e12..112d2b5eb 100644 --- a/examples/postEffect/lens/vignetting/index.html +++ b/examples/postEffect/lens/vignetting/index.html @@ -8,8 +8,8 @@ - - + +
diff --git a/examples/postEffect/lens/vignetting/index.js b/examples/postEffect/lens/vignetting/index.js index 3a98aa5d8..d9377a878 100644 --- a/examples/postEffect/lens/vignetting/index.js +++ b/examples/postEffect/lens/vignetting/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; // 1. Create and append a canvas // 1. 캔버스를 생성하고 문서에 추가 @@ -113,10 +113,10 @@ function loadGLTF(redGPUContext, scene, url) { } const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); - const {createPostEffectLabel} = await import('../../../exampleHelper/createExample/loadExampleInfo/createPostEffectLabel.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {createPostEffectLabel} = await import('../../../exampleHelper/createExample/loadExampleInfo/createPostEffectLabel.js?t=1770699661827'); createPostEffectLabel('Vignetting', redGPUContext.detector.isMobile) - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); diff --git a/examples/postEffect/oldBloom/index.html b/examples/postEffect/oldBloom/index.html index 490422bfb..470caed74 100644 --- a/examples/postEffect/oldBloom/index.html +++ b/examples/postEffect/oldBloom/index.html @@ -8,8 +8,8 @@ - - + +
diff --git a/examples/postEffect/oldBloom/index.js b/examples/postEffect/oldBloom/index.js index c7b4cb4c0..80aa04232 100644 --- a/examples/postEffect/oldBloom/index.js +++ b/examples/postEffect/oldBloom/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../dist/index.js?t=1770699661827"; // 1. Create and append a canvas // 1. 캔버스를 생성하고 문서에 추가 @@ -113,10 +113,10 @@ function loadGLTF(redGPUContext, scene, url) { } const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); - const {createPostEffectLabel} = await import('../../exampleHelper/createExample/loadExampleInfo/createPostEffectLabel.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {createPostEffectLabel} = await import('../../exampleHelper/createExample/loadExampleInfo/createPostEffectLabel.js?t=1770699661827'); createPostEffectLabel('OldBloom', redGPUContext.detector.isMobile) - const {setDebugButtons} = await import("../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const {setDebugButtons} = await import("../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); diff --git a/examples/postEffect/sharpen/index.html b/examples/postEffect/sharpen/index.html index 490422bfb..470caed74 100644 --- a/examples/postEffect/sharpen/index.html +++ b/examples/postEffect/sharpen/index.html @@ -8,8 +8,8 @@ - - + +
diff --git a/examples/postEffect/sharpen/index.js b/examples/postEffect/sharpen/index.js index a80f7c118..8705055c5 100644 --- a/examples/postEffect/sharpen/index.js +++ b/examples/postEffect/sharpen/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../dist/index.js?t=1770699661827"; // 1. Create and append a canvas // 1. 캔버스를 생성하고 문서에 추가 @@ -113,10 +113,10 @@ function loadGLTF(redGPUContext, scene, url) { } const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); - const {createPostEffectLabel} = await import('../../exampleHelper/createExample/loadExampleInfo/createPostEffectLabel.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {createPostEffectLabel} = await import('../../exampleHelper/createExample/loadExampleInfo/createPostEffectLabel.js?t=1770699661827'); createPostEffectLabel('Sharpen', redGPUContext.detector.isMobile) - const {setDebugButtons} = await import("../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const {setDebugButtons} = await import("../../exampleHelper/createExample/panes/index.js?t=1770699661827"); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); diff --git a/examples/postEffect/ssao/index.html b/examples/postEffect/ssao/index.html index 19ffd6889..b3924120d 100644 --- a/examples/postEffect/ssao/index.html +++ b/examples/postEffect/ssao/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/postEffect/ssao/index.js b/examples/postEffect/ssao/index.js index cc5a7400e..61c44af29 100644 --- a/examples/postEffect/ssao/index.js +++ b/examples/postEffect/ssao/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../dist/index.js?t=1770699661827"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -57,11 +57,11 @@ function loadGLTF(view, url) { } const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); const { createIblHelper, setDebugButtons - } = await import('../../exampleHelper/createExample/panes/index.js?t=1770698056099'); + } = await import('../../exampleHelper/createExample/panes/index.js?t=1770699661827'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/postEffect/ssr/index.html b/examples/postEffect/ssr/index.html index 490422bfb..470caed74 100644 --- a/examples/postEffect/ssr/index.html +++ b/examples/postEffect/ssr/index.html @@ -8,8 +8,8 @@ - - + +
diff --git a/examples/postEffect/ssr/index.js b/examples/postEffect/ssr/index.js index a56e29ba2..f0b0dae1a 100644 --- a/examples/postEffect/ssr/index.js +++ b/examples/postEffect/ssr/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../dist/index.js?t=1770698056099"; +import * as RedGPU from "../../../dist/index.js?t=1770699661827"; /** * [KO] SSR 예제 @@ -111,8 +111,8 @@ function loadGLTFModels(redGPUContext, scene) { * SSR 설정 컨트롤러 (Tweakpane) */ async function createSSRControls(redGPUContext, targetView) { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770698056099'); - const {setDebugButtons} = await import("../../exampleHelper/createExample/panes/index.js?t=1770698056099"); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {setDebugButtons} = await import("../../exampleHelper/createExample/panes/index.js?t=1770699661827"); const pane = new Pane({title: 'SSR 옵션 조절'}); setDebugButtons(RedGPU, redGPUContext); From 017b5287f587c953855f03fd368816b1899b44f3 Mon Sep 17 00:00:00 2001 From: webseon Date: Tue, 10 Feb 2026 17:58:05 +0900 Subject: [PATCH 3/4] - --- dist/index.js | 2 +- src/camera/controller/OrbitController.ts | 6 ++---- 2 files changed, 3 insertions(+), 5 deletions(-) diff --git a/dist/index.js b/dist/index.js index d81e99fee..def994d39 100644 --- a/dist/index.js +++ b/dist/index.js @@ -1 +1 @@ -const consoleAndThrowError=(...i)=>{const g=Array.prototype.slice.call(i).join(" ");throw new Error(g)},validatePositiveNumberRange=(i,g=0,x=Number.MAX_VALUE)=>("number"!=typeof i&&consoleAndThrowError("Only numbers allowed."),"number"!=typeof g&&consoleAndThrowError("Only numbers allowed."),"number"!=typeof x&&consoleAndThrowError("Only numbers allowed."),(g<0||i<0||ix)&&consoleAndThrowError(`Only numbers within the range of [${g},${x}] are allowed.`),!0),isUint=i=>Number.isInteger(i)&&i>=0,validateUintRange=(i,g=0,x=4503599627370496)=>{const _=isUint(i),v=isUint(g),b=isUint(x),y="is not Uint!/value:",S=`(check range:${g}u ~ ${x}u)`;return _||consoleAndThrowError(`value ${y}${i}/${S}`),v||consoleAndThrowError(`min ${y}${g}/${S}`),b||consoleAndThrowError(`max ${y}${x}/${S}`),g>=x&&consoleAndThrowError(`maximum value is bigger than minimum value./${S}`),g>i&&consoleAndThrowError(`value is smaller than minimum value./value:${i}/${S}`),x{const g=/^([A-Fa-f0-9]{3}){1,2}$/;return i.startsWith("#")?g.test(i.substring(1)):!!i.startsWith("0x")&&g.test(i.substring(2))},convertHexToRgb=(i,g=!1)=>{if("number"==typeof i&&(i=`#${i.toString(16)}`),isHexColor(i)){"#"===i.charAt(0)&&(i=i.substring(1)),3===i.length&&(i=i.charAt(0)+i.charAt(0)+i.charAt(1)+i.charAt(1)+i.charAt(2)+i.charAt(2));const x=parseInt("0x"+i),_=x>>16&255,v=x>>8&255,b=255&x;return g?[_,v,b]:{r:_,g:v,b:b}}throw Error(`from ${convertHexToRgb.constructor.name}:input value - ${i}/Only hex string allowed`)},convertRgbToHex=(i,g,x)=>{validateUintRange(i,0,255),validateUintRange(g,0,255),validateUintRange(x,0,255);return`#${i.toString(16).padStart(2,"0").toUpperCase()}${g.toString(16).padStart(2,"0").toUpperCase()}${x.toString(16).padStart(2,"0").toUpperCase()}`};class ColorRGB{#e;#t;#n;#r;constructor(i=255,g=255,x=255,_=void 0){this.#i(i,g,x),this.#a(i,g,x),_&&(this.#r=_)}get r(){return this.#e}set r(i){validateUintRange(i,0,255),this.#e=i,this.#r?.()}get g(){return this.#t}set g(i){validateUintRange(i,0,255),this.#t=i,this.#r?.()}get b(){return this.#n}set b(i){validateUintRange(i,0,255),this.#n=i,this.#r?.()}get rgb(){return[this.#e,this.#t,this.#n]}get rgbNormal(){return[this.#e/255,this.#t/255,this.#n/255]}get rgbNormalLinear(){return[Math.pow(this.#e/255,2.2),Math.pow(this.#t/255,2.2),Math.pow(this.#n/255,2.2)]}get hex(){return convertRgbToHex(this.#e,this.#t,this.#n)}setColorByRGB(i,g,x){this.#i(i,g,x),this.#a(i,g,x)}setColorByHEX(i){const{r:g,g:x,b:_}=convertHexToRgb(i);this.#a(g,x,_)}setColorByRGBString(i){const g=/rgb\s*\(\s*(\d+)\s*,\s*(\d+)\s*,\s*(\d+)\s*\)/.exec(i);g||consoleAndThrowError(`유효하지 않은 rgb 색상 값입니다:${i}`);const[,x,_,v]=g.map(Number);this.#i(x,_,v),this.#a(x,_,v)}#a(i,g,x){this.#e=i,this.#t=g,this.#n=x,this.#r?.()}#i(i,g,x){validateUintRange(i,0,255),validateUintRange(g,0,255),validateUintRange(x,0,255)}}Object.freeze(ColorRGB);class ColorRGBA extends ColorRGB{#s;#r;constructor(i=255,g=255,x=255,_=1,v=void 0){super(i,g,x,v),validatePositiveNumberRange(_,0,1),this.#s=_,v&&(this.#r=v)}get a(){return this.#s}set a(i){validatePositiveNumberRange(i,0,1),this.#s=i,this.#r?.()}get rgba(){return[this.r,this.g,this.b,this.#s]}get rgbaNormal(){return[this.r/255,this.g/255,this.b/255,this.#s]}get rgbaNormalLinear(){return[Math.pow(this.r/255,2.2),Math.pow(this.g/255,2.2),Math.pow(this.b/255,2.2),this.#s]}setColorByRGBA(i,g,x,_){this.#o(i,g,x,_),this.r=i,this.g=g,this.b=x,this.#s=_,this.#r?.()}setColorByRGBAString(i){const g=/rgba\s*\(\s*(\d+)\s*,\s*(\d+)\s*,\s*(\d+)\s*,\s*(\d*(?:\.\d+)?)\s*\)/.exec(i);if(!g)throw new Error(`유효하지 않은 rgba 색상 값입니다:${i}`);const[,x,_,v,b]=g.map(Number);this.#o(x,_,v,b),this.r=x,this.g=_,this.b=v,this.#s=b,this.#r?.()}#o(i,g,x,_){validateUintRange(i,0,255),validateUintRange(g,0,255),validateUintRange(x,0,255),validatePositiveNumberRange(_,0,1)}}const i={MOVE:"move",DOWN:"down",UP:"up",OVER:"over",OUT:"out",CLICK:"click"},copyGPUBuffer=(i,g,x)=>{const _=i.createCommandEncoder({label:"copyGPUBuffer_CommandEncoder"});_.copyBufferToBuffer(g,0,x,0,Math.min(g.size,x.size));const v=_.finish();i.queue.submit([v])},formatBytes=(i,g=2)=>{if(("number"!=typeof i||i<0||Number.isNaN(i)||!Number.isInteger(i))&&consoleAndThrowError("Invalid input:'bytes' must be a uint"),0===i)return"0 Bytes";const x=g<0?0:g,_=Math.floor(Math.log(i)/Math.log(1024));return parseFloat((i/Math.pow(1024,_)).toFixed(x))+" "+["Bytes","KB","MB","GB"][_]};function getAbsoluteURL(i,g){try{return new URL(g,i).href}catch(i){return g}}const getFileExtension=i=>{if(!i||0===i.trim().length)throw new Error("URL must not be empty or undefined");const g=i.split("/"),x=g[g.length-1],_=x.lastIndexOf(".");return-1===_?"":x.substring(_+1).toLowerCase()},getFileName=(i,g=!0)=>{const x=i.substring(i.lastIndexOf("/")+1);return g?x:x.split(".").slice(0,-1).join(".")},getFilePath=i=>{if(!i||0===i.trim().length)throw new Error("URL must not be empty or undefined");return i.substring(0,i.lastIndexOf("/")+1)};function calculateTextureByteSize(i){const g={size:[i.width,i.height,i.depthOrArrayLayers],format:i.format,sampleCount:i.sampleCount,usage:i.usage};return function(i){switch(i){case"r8unorm":case"r8snorm":case"r8uint":case"r8sint":return 1;case"r16uint":case"r16sint":case"r16float":case"rg8unorm":case"rg8snorm":case"rg8uint":case"rg8sint":case"depth16unorm":return 2;case"r32uint":case"r32sint":case"r32float":case"rg16uint":case"rg16sint":case"rg16float":case"rgba8unorm":case"rgba8unorm-srgb":case"rgba8snorm":case"rgba8uint":case"rgba8sint":case"bgra8unorm":case"bgra8unorm-srgb":case"depth24plus":case"depth32float":return 4;case"rg32uint":case"rg32sint":case"rg32float":case"rgba16uint":case"rgba16sint":case"rgba16float":return 8;case"rgba32uint":case"rgba32sint":case"rgba32float":return 16;default:throw new Error(`Unrecognized texture format:${i}`)}}(g.format)*(g.size[0]*g.size[1]*(g.size[2]||1))*(g.sampleCount?g.sampleCount:1)}const getMipLevelCount=(i,g)=>Math.floor(Math.log2(Math.max(i,g)))+1,imageBitmapToGPUTexture=(i,g,x,_=!0)=>{const v=i.createTexture(x);for(let b=0;b{const i="0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz".split("");let g,x=0,_=new Array(36);for(_[8]=_[13]=_[18]=_[23]="-",_[14]="4";x<36;)_[x]||(g=16*Math.random()|0,_[x]=i[19===x?3&g|8:15&g]),x++;return _.join("")};class InstanceIdGenerator{static idMaps=new Map;static getNextId(i){let g=this.idMaps.get(i)||0;return this.idMaps.set(i,g+1),g}}Object.freeze(InstanceIdGenerator);const uuidToUint=i=>{const g=i.replace(/-/g,"").substring(0,8);return parseInt(g,16)},g=console.log.bind(console);var x=Object.freeze({__proto__:null,InstanceIdGenerator:InstanceIdGenerator,calculateTextureByteSize:calculateTextureByteSize,copyGPUBuffer:copyGPUBuffer,copyToTextureArray:function(i,g,x,_){const v=i.createCommandEncoder({label:"COPY_TO_TEXTURE_ARRAY"});v.copyTextureToTexture({texture:g},{texture:x,origin:[0,0,_]},[g.width,g.height,1]),i.queue.submit([v.finish()])},createUUID:createUUID,formatBytes:formatBytes,getAbsoluteURL:getAbsoluteURL,getFileExtension:getFileExtension,getFileName:getFileName,getFilePath:getFilePath,getMipLevelCount:getMipLevelCount,imageBitmapToGPUTexture:imageBitmapToGPUTexture,keepLog:g,loadAndCreateBitmapImage:loadAndCreateBitmapImage,uuidToUint:uuidToUint});const _={CLAMP_TO_EDGE:"clamp-to-edge",REPEAT:"repeat",MIRRORED_REPEAT:"mirror-repeat"};Object.freeze(_);const v={NEAREST:"nearest",LINEAR:"linear"};Object.freeze(v);const b={NEAREST:"nearest",LINEAR:"linear"};Object.freeze(b);const validateRedGPUContext=i=>{if("RedGPUContext"!==i?.constructor?.name){return consoleAndThrowError(`from ${i?.constructor?.name}:requires a RedGPUContext instance,but received:${i}`),!1}return!0};class ResourceBase{#u=createUUID();#l;#c;#h="";#f;#d;#m=[];#p;constructor(i,g){validateRedGPUContext(i),this.#p=g,this.#l=i,this.#c=i.gpuDevice}get cacheKey(){return this.#d}set cacheKey(i){this.#d=i}get resourceManagerKey(){return this.#p}get name(){return this.#f||(this.#f=InstanceIdGenerator.getNextId(this.constructor)),this.#h||`${this.constructor.name} Instance ${this.#f}`}set name(i){this.#h=i}get uuid(){return this.#u}get gpuDevice(){return this.#c}get redGPUContext(){return this.#l}__addDirtyPipelineListener(i){this.#g(!0),this.#m.push(i)}__removeDirtyPipelineListener(i){const g=this.#m.indexOf(i);g>-1&&(this.#m.splice(g,1),this.#g(!1))}__fireListenerList(i=!1){for(const i of this.#m)i(this);i&&(this.#m.length=0)}#g(i){const{resourceManager:g}=this.#l;if("Sampler"!==this.constructor.name&&g){const x=g[this.#p];x||consoleAndThrowError("need managedStateKey",this.constructor.name);const _=x?.table.get(this.cacheKey);_&&(i?_.useNum++:_.useNum--)}}}const y=new Map,S=Object.values(v),w=Object.values(_),L=Object.values(b);class Sampler extends ResourceBase{#x;#_=v.LINEAR;#v=v.LINEAR;#b=b.LINEAR;#y=_.CLAMP_TO_EDGE;#S=_.CLAMP_TO_EDGE;#T=_.REPEAT;#M;#w;#C;#R=1;constructor(i,g){super(i),this.#P(g)}get addressModeU(){return this.#y}set addressModeU(i){this.#B(i,"addressModeU")}get addressModeV(){return this.#S}set addressModeV(i){this.#B(i,"addressModeV")}get addressModeW(){return this.#T}set addressModeW(i){this.#B(i,"addressModeW")}get mipmapFilter(){return this.#b}set mipmapFilter(i){this.#I(i,L,"mipmapFilter")}get gpuSampler(){return this.#x}get magFilter(){return this.#_}set magFilter(i){this.#I(i,S,"magFilter")}get minFilter(){return this.#v}set minFilter(i){this.#I(i,S,"minFilter")}get maxAnisotropy(){return this.#R}set maxAnisotropy(i){validateUintRange(i,1,16),this.#R=i,this.#P()}get isAnisotropyValid(){return!this.#R||"linear"===this.#_&&"linear"===this.#v&&"linear"===this.#b}#E(){this.__fireListenerList()}#B(i,g){if(w.includes(i)){switch(g){case"addressModeU":this.#y=i;break;case"addressModeV":this.#S=i;break;case"addressModeW":this.#T=i}this.#P()}else consoleAndThrowError(`Invalid ${g} value. Must be one of ${w.join(",")},but received:${i}.`)}#I(i,g,x){if(g.includes(i)||null===i){switch(x){case"mipmapFilter":this.#b=i;break;case"magFilter":this.#_=i;break;case"minFilter":this.#v=i}this.#P()}else consoleAndThrowError(`Invalid ${x} value. Must be one of ${g.join(",")},but received:${i}.`)}#D(){return`${this.#_}:${this.#v}:${this.#b}:${this.#y}:${this.#S}:${this.#T}:${this.#M}:${this.#w}:${this.#C}:${this.#R}`}#P(i){i&&(i.magFilter&&(this.#_=i.magFilter),i.minFilter&&(this.#v=i.minFilter),i.mipmapFilter&&(this.#b=i.mipmapFilter),i.addressModeU&&(this.#y=i.addressModeU),i.addressModeV&&(this.#S=i.addressModeV),i.addressModeW&&(this.#T=i.addressModeW),void 0!==i.lodMinClamp&&(this.#M=i.lodMinClamp),void 0!==i.lodMaxClamp&&(this.#w=i.lodMaxClamp),i.compare&&(this.#C=i.compare),i.maxAnisotropy&&(this.#R=i.maxAnisotropy)),this.isAnisotropyValid||1===this.#R||(console.warn(`Invalid maxAnisotropy setting (${this.#R}) detected:magFilter(${this.#_}),minFilter(${this.#v}),mipmapFilter(${this.#b}) must all be set to 'linear' for anisotropic filtering to work. Falling back to default (1).`),this.#R=1);const g=this.#D();if(!y.has(g)){let i={};this.#_&&(i.magFilter=this.#_),this.#v&&(i.minFilter=this.#v),this.#b&&(i.mipmapFilter=this.#b),this.#y&&(i.addressModeU=this.#y),this.#S&&(i.addressModeV=this.#S),this.#T&&(i.addressModeW=this.#T),void 0!==this.#M&&(i.lodMinClamp=this.#M),void 0!==this.#w&&(i.lodMaxClamp=this.#w),this.#C&&(i.compare=this.#C),this.#R&&(i.maxAnisotropy=this.#R),y.set(g,this.redGPUContext.gpuDevice.createSampler(i))}this.#x=y.get(g),this.#E()}}Object.freeze(Sampler);class ManagementResourceBase extends ResourceBase{#U;constructor(i,g){super(i,g),g||consoleAndThrowError("need managedStateKey",this.constructor.name),this.#U=i.resourceManager[g],this.#U||consoleAndThrowError(g,"is not exist in RedGPUContext.resourceManager",this.constructor.name)}get targetResourceManagedState(){return this.#U}}class ResourceStateBitmapTexture{texture;src;cacheKey;useNum=0;uuid;constructor(i){this.texture=i,this.src=i.src,this.cacheKey=i.cacheKey,this.useNum=0,this.uuid=i.uuid}}class BitmapTexture extends ManagementResourceBase{#L;#A;#G;#k;#O;#N=0;#V=!0;#F;#H;#z;constructor(i,g,x=!0,_,v,b,y=!1){if(super(i,"managedBitmapTextureState"),this.#H=_,this.#z=v,this.#V=y,this.#k=x,this.#F=b||`${navigator.gpu.getPreferredCanvasFormat()}-srgb`,g){this.#A=this.#$(g),this.cacheKey=this.#K(g);const{table:i}=this.targetResourceManagedState;let x=i.get(this.cacheKey);if(x){const i=x.texture;return this.#H?.(i),i}this.src=g,this.#X()}}get width(){return this.#O?.width||0}get height(){return this.#O?.height||0}get usePremultiplyAlpha(){return this.#V}get videoMemorySize(){return this.#N}get gpuTexture(){return this.#L}get mipLevelCount(){return this.#G}get src(){return this.#A}set src(i){this.#A=this.#$(i),this.cacheKey=this.#K(i),this.#A&&this.#j(this.#A)}get useMipmap(){return this.#k}set useMipmap(i){this.#k=i,this.#Y()}destroy(){const i=this.#L;this.#q(null),this.__fireListenerList(!0),this.#W(),this.cacheKey=null,this.#A=null,i&&i.destroy()}#K(i){return i?"string"==typeof i?getAbsoluteURL(window.location.href,i):i.cacheKey||getAbsoluteURL(window.location.href,i.src):this.uuid}#$(i){return"string"==typeof i?i:i.src}#q(i){this.#L=i,i||(this.#O=null),this.__fireListenerList()}#X(){this.redGPUContext.resourceManager.registerManagementResource(this,new ResourceStateBitmapTexture(this))}#W(){this.redGPUContext.resourceManager.unregisterManagementResource(this)}#Y(){const{gpuDevice:i,resourceManager:g}=this.redGPUContext,{mipmapGenerator:x}=g;this.#L&&(this.#L.destroy(),this.#L=null),this.targetResourceManagedState.videoMemory-=this.#N,this.#N=0;const{width:_,height:v}=this.#O;this.#G=1;const b={size:[_,v],format:this.#F,usage:GPUTextureUsage.RENDER_ATTACHMENT|GPUTextureUsage.TEXTURE_BINDING|GPUTextureUsage.COPY_DST,label:this.#A};this.#k&&(this.#G=getMipLevelCount(_,v),b.mipLevelCount=this.#G,b.usage|=GPUTextureUsage.RENDER_ATTACHMENT);const y=imageBitmapToGPUTexture(i,[this.#O],b,this.#V);this.#N=calculateTextureByteSize(y),this.targetResourceManagedState.videoMemory+=this.#N,this.#k&&x.generateMipmap(y,b),this.#q(y)}async#Z(i){return new Promise((g,x)=>{const _=new Image;_.src=i,_.onload=()=>{const i=document.createElement("canvas");i.width=_.width||512,i.height=_.height||512;const v=i.getContext("2d");v?(v.fillStyle="rgba(0,0,0,0)",v.fillRect(0,0,i.width,i.height),v.drawImage(_,0,0,i.width,i.height),createImageBitmap(i,{colorSpaceConversion:"none",premultiplyAlpha:this.#V?"premultiply":"none"}).then(g).catch(x)):x(new Error("Canvas context could not be created."))},_.onerror=i=>{x(new Error(`Failed to load SVG:${i}`))}})}async#j(i){try{i.endsWith(".svg")?this.#O=await this.#Z(i):this.#O=await loadAndCreateBitmapImage(i,"none",this.#V?"premultiply":"none"),this.#Y(),this.#H?.(this)}catch(i){console.error(i),this.#z?.(i)}}}Object.freeze(BitmapTexture);class BRDFGenerator{#l;#J;#Q;#ee;constructor(i){this.#l=i}get brdfLUTTexture(){return this.#ee||this.#te(),this.#ee}async#te(){const{gpuDevice:i,resourceManager:g}=this.#l,x="rg16float";this.#ee=g.createManagedTexture({size:[128,128],format:x,usage:GPUTextureUsage.TEXTURE_BINDING|GPUTextureUsage.COPY_DST|GPUTextureUsage.RENDER_ATTACHMENT,label:"BRDF_LUT_Texture"}),this.#J||(this.#J=g.createGPUShaderModule("BRDF_GENERATOR_SHADER_MODULE",{code:"\nconst PI=3.14159265359;\nfn radicalInverse_VdC(bits:u32) -> f32 { var b=bits; b=(b << 16u) | (b >> 16u); b=((b & 0x55555555u) << 1u) | ((b & 0xAAAAAAAAu) >> 1u); b=((b & 0x33333333u) << 2u) | ((b & 0xCCCCCCCCu) >> 2u); b=((b & 0x0F0F0F0Fu) << 4u) | ((b & 0xF0F0F0F0u) >> 4u); b=((b & 0x00FF00FFu) << 8u) | ((b & 0xFF00FF00u) >> 8u); return f32(b) * 2.3283064365386963e-10;\n}\nfn hammersley(i:u32,N:u32) -> vec2 { return vec2(f32(i)/f32(N),radicalInverse_VdC(i));\n}\nfn importanceSampleGGX(Xi:vec2,N:vec3,roughness:f32) -> vec3 { let a=roughness * roughness; let phi=2.0 * PI * Xi.x; let cosTheta=sqrt((1.0 - Xi.y)/(1.0 + (a * a - 1.0) * Xi.y)); let sinTheta=sqrt(1.0 - cosTheta * cosTheta); let H=vec3(cos(phi) * sinTheta,sin(phi) * sinTheta,cosTheta); let up=select(vec3(1.0,0.0,0.0),vec3(0.0,0.0,1.0),abs(N.z) < 0.999); let tangent=normalize(cross(up,N)); let bitangent=cross(N,tangent); return normalize(tangent * H.x + bitangent * H.y + N * H.z);\n}\nfn geometrySchlickGGX(NdotV:f32,roughness:f32) -> f32 { let a=roughness; let k=(a * a)/2.0; let nom=NdotV; let denom=NdotV * (1.0 - k) + k; return nom/denom;\n}\nfn geometrySmith(N:vec3,V:vec3,L:vec3,roughness:f32) -> f32 { let NdotV=max(dot(N,V),0.0); let NdotL=max(dot(N,L),0.0); let ggx2=geometrySchlickGGX(NdotV,roughness); let ggx1=geometrySchlickGGX(NdotL,roughness); return ggx1 * ggx2;\n}\nfn integrateBRDF(in_NdotV:f32,roughness:f32) -> vec2 { let NdotV=max(in_NdotV,0.001); var V:vec3; V.x=sqrt(1.0 - NdotV * NdotV); V.y=0.0; V.z=NdotV; var A=0.0; var B=0.0; let N=vec3(0.0,0.0,1.0); let sampleCount=1024u; for (var i=0u;i < sampleCount;i=i + 1u) { let Xi=hammersley(i,sampleCount); let H=importanceSampleGGX(Xi,N,roughness); let L=normalize(2.0 * dot(V,H) * H - V); let NdotL=max(L.z,0.0); let NdotH=max(H.z,0.0); let VdotH=max(dot(V,H),0.0); if (NdotL > 0.0) { let G=geometrySmith(N,V,L,roughness); let G_Vis=(G * VdotH)/(max(NdotH * NdotV,0.001)); let Fc=pow(1.0 - VdotH,5.0); A=A + (1.0 - Fc) * G_Vis; B=B + Fc * G_Vis; } } return vec2(A,B)/f32(sampleCount);\n}\nstruct VertexOutput { @builtin(position) position:vec4, @location(0) uv:vec2,\n};\n@vertex\nfn vs_main(@builtin(vertex_index) vertexIndex:u32) -> VertexOutput { var pos=array,3>( vec2(-1.0,-1.0), vec2(3.0,-1.0), vec2(-1.0,3.0) ); var output:VertexOutput; output.position=vec4(pos[vertexIndex],0.0,1.0); output.uv=pos[vertexIndex] * 0.5 + 0.5; return output;\n}\n@fragment\nfn fs_main(@location(0) uv:vec2) -> @location(0) vec4 { let integratedBRDF=integrateBRDF(uv.x,1.0 - uv.y); return vec4(integratedBRDF,0.0,1.0);\n}"})),this.#Q||(this.#Q=i.createRenderPipeline({label:"BRDF_GENERATOR_PIPELINE",layout:"auto",vertex:{module:this.#J,entryPoint:"vs_main"},fragment:{module:this.#J,entryPoint:"fs_main",targets:[{format:x}]},primitive:{topology:"triangle-list"}}));const _=i.createCommandEncoder({label:"BRDF_GENERATOR_COMMAND_ENCODER"}),v=_.beginRenderPass({label:"BRDF_GENERATOR_RENDER_PASS",colorAttachments:[{view:this.#ee.createView(),loadOp:"clear",clearValue:{r:0,g:0,b:0,a:1},storeOp:"store"}]});v.setPipeline(this.#Q),v.draw(3),v.end(),i.queue.submit([_.finish()]),await i.queue.onSubmittedWorkDone()}}Object.freeze(BRDFGenerator);class BRDFLUTTexture extends ManagementResourceBase{#L;constructor(i){super(i,"managedBitmapTextureState"),this.#ne()}#ne(){this.#L=this.redGPUContext.resourceManager.brdfGenerator.brdfLUTTexture,this.__fireListenerList()}get gpuTexture(){return this.#L}get videoMemorySize(){return 65536}}Object.freeze(BRDFLUTTexture);class CubeTexture extends ManagementResourceBase{static defaultViewDescriptor={dimension:"cube",aspect:"all",baseMipLevel:0,mipLevelCount:1,baseArrayLayer:0,arrayLayerCount:6};#L;#re;#G;#k;#ie;#N=0;#F;#H;#z;constructor(i,g,x=!0,_,v,b){super(i,"managedCubeTextureState"),this.#H=_,this.#z=v,this.#k=x,this.#F=b||`${navigator.gpu.getPreferredCanvasFormat()}-srgb`,this.#re=this.#$(g),this.cacheKey=this.#K(g);const{table:y}=this.targetResourceManagedState;if(g){let i=y.get(this.cacheKey);if(i){const g=i.texture;return this.#H?.(g),g}this.srcList=g,this.#X()}}get viewDescriptor(){return{...CubeTexture.defaultViewDescriptor,mipLevelCount:this.#G}}get videoMemorySize(){return this.#N}get gpuTexture(){return this.#L}get mipLevelCount(){return this.#G}get srcList(){return this.#re}set srcList(i){this.#re=this.#$(i),this.cacheKey=this.#K(i),this.#re?.length&&this.#j(this.#re)}get useMipmap(){return this.#k}set useMipmap(i){this.#k=i,this.#Y()}destroy(){const i=this.#L;this.#q(null),this.__fireListenerList(!0),this.#W(),this.#re=null,this.cacheKey=null,i&&i.destroy()}setGPUTextureDirectly(i,g,x=!0){this.#L&&(this.#L.destroy(),this.targetResourceManagedState.videoMemory-=this.#N),this.#L=i,this.#k=x,this.#G=i.mipLevelCount,this.cacheKey=g||`direct_${this.uuid}`,this.#N=calculateTextureByteSize(i),this.targetResourceManagedState.videoMemory+=this.#N,this.__fireListenerList()}#K(i){return i?i instanceof Array?i.length?i.toString():this.uuid:i.cacheKey||i.srcList.toString():this.uuid}#$(i){return i instanceof Array?i:i?.srcList}#q(i){this.#L=i,i||(this.#ie=null),this.__fireListenerList()}#X(){this.redGPUContext.resourceManager.registerManagementResource(this,new ResourceStateCubeTexture(this))}#W(){this.redGPUContext.resourceManager.unregisterManagementResource(this)}#Y(){const{gpuDevice:i,resourceManager:g}=this.redGPUContext,{mipmapGenerator:x}=g;this.#L&&(this.#L.destroy(),this.#L=null),this.#G=1;{const g=this.#ie,_=g[0],{width:v,height:b}=_,y={size:[v,b,6],format:this.#F,usage:GPUTextureUsage.RENDER_ATTACHMENT|GPUTextureUsage.TEXTURE_BINDING|GPUTextureUsage.COPY_DST,label:`cubeTexture_${this.#re?.toString()||this.uuid}`};this.#k&&(this.#G=getMipLevelCount(v,b),y.mipLevelCount=this.#G,y.usage|=GPUTextureUsage.RENDER_ATTACHMENT);const S=imageBitmapToGPUTexture(i,g,y);this.targetResourceManagedState.videoMemory-=this.#N,this.#N=calculateTextureByteSize(S),this.targetResourceManagedState.videoMemory+=this.#N,this.#k&&x.generateMipmap(S,y),this.#q(S)}}async#j(i){this.#ie=await async function(i){const g=i.map(i=>loadAndCreateBitmapImage(i));return await Promise.all(g)}(i);try{this.#Y(),this.#H?.(this)}catch(i){console.error(i),this.#z?.(i)}}}Object.freeze(CubeTexture);class ResourceStateCubeTexture{texture;srcList;cacheKey;useNum=0;uuid;constructor(i){this.texture=i,this.srcList=i instanceof CubeTexture?i.srcList:void 0,this.cacheKey=i.cacheKey,this.useNum=0,this.uuid=i.uuid}}class IBLCubeTexture extends ManagementResourceBase{#L;#G;#k=!0;#N=0;#F;constructor(i,g,x){super(i,"managedCubeTextureState"),this.cacheKey=g;const{table:_}=this.targetResourceManagedState;if(g){let i=_.get(g);if(i)return i.texture;x&&this.#q(x),this.#X()}}get viewDescriptor(){return{...CubeTexture.defaultViewDescriptor,mipLevelCount:this.#G}}get format(){return this.#F}get videoMemorySize(){return this.#N}get gpuTexture(){return this.#L}set gpuTexture(i){this.#q(i)}get mipLevelCount(){return this.#G}get useMipmap(){return this.#k}destroy(){const i=this.#L;this.#q(null),this.__fireListenerList(!0),this.#W(),this.cacheKey=null,i&&i.destroy()}#q(i){this.targetResourceManagedState.videoMemory-=this.#N,this.#L=i,i&&(this.#G=i.mipLevelCount,this.#k=i.mipLevelCount>1,this.#F=i.format,this.#N=calculateTextureByteSize(i)),this.targetResourceManagedState.videoMemory+=this.#N,this.__fireListenerList()}#X(){this.redGPUContext.resourceManager.registerManagementResource(this,new ResourceStateCubeTexture(this))}#W(){this.redGPUContext.resourceManager.unregisterManagementResource(this)}}Object.freeze(IBLCubeTexture);class IrradianceGenerator{#l;#ae;#Q;#se;constructor(i){this.#l=i,this.#ae=new Sampler(this.#l,{magFilter:v.LINEAR,minFilter:v.LINEAR,mipmapFilter:b.LINEAR,addressModeU:_.CLAMP_TO_EDGE,addressModeV:_.CLAMP_TO_EDGE,addressModeW:_.CLAMP_TO_EDGE})}async generate(i,g=32){const{gpuDevice:x,resourceManager:_}=this.#l,v=_.createManagedTexture({size:[g,g,6],format:"rgba16float",usage:GPUTextureUsage.TEXTURE_BINDING|GPUTextureUsage.STORAGE_BINDING|GPUTextureUsage.COPY_SRC|GPUTextureUsage.COPY_DST|GPUTextureUsage.RENDER_ATTACHMENT,dimension:"2d",mipLevelCount:1,label:`Irradiance_Map_Texture_${createUUID()}`});this.#se||(this.#se=_.createGPUShaderModule("IRRADIANCE_GENERATOR_SHADER_MODULE",{code:"\n@group(0) @binding(0) var environmentTexture:texture_cube;\n@group(0) @binding(1) var environmentSampler:sampler;\n@group(0) @binding(2) var outTexture:texture_storage_2d_array;\n@group(0) @binding(3) var faceMatrices:array,6>;\nconst PI=3.14159265359;\nfn radicalInverse_VdC(bits_in:u32) -> f32 { var bits=bits_in; bits=(bits << 16u) | (bits >> 16u); bits=((bits & 0x55555555u) << 1u) | ((bits & 0xAAAAAAAAu) >> 1u); bits=((bits & 0x33333333u) << 2u) | ((bits & 0xCCCCCCCCu) >> 2u); bits=((bits & 0x0F0F0F0Fu) << 4u) | ((bits & 0xF0F0F0F0u) >> 4u); bits=((bits & 0x00FF00FFu) << 8u) | ((bits & 0xFF00FF00u) >> 8u); return f32(bits) * 2.3283064365386963e-10;\n}\nfn hammersley(i:u32,n:u32) -> vec2 { return vec2(f32(i)/f32(n),radicalInverse_VdC(i));\n}\n@compute @workgroup_size(8,8,1)\nfn cs_main(@builtin(global_invocation_id) global_id:vec3) { let size_u=textureDimensions(outTexture); let size=vec2(size_u); if (global_id.x >=size_u.x || global_id.y >=size_u.y || global_id.z >=6u) { return; } let face=global_id.z; let uv=(vec2(global_id.xy) + 0.5)/size; let x=uv.x * 2.0 - 1.0; let y=uv.y * 2.0 - 1.0; let localPos=vec4(x,y,1.0,1.0); let normal=normalize((faceMatrices[face] * localPos).xyz); let s=select(1.0,-1.0,normal.z < 0.0); let a=-1.0/(s + normal.z); let b=normal.x * normal.y * a; let tangent=vec3(1.0 + s * normal.x * normal.x * a,s * b,-s * normal.x); let bitangent=vec3(b,s + normal.y * normal.y * a,-normal.y); var irradiance=vec3(0.0); var totalWeight=0.0; let totalSamples=1024u; let envSize=f32(textureDimensions(environmentTexture).x); let saTexel=4.0 * PI/(6.0 * envSize * envSize); for (var i=0u;i < totalSamples;i++) { let xi=hammersley(i,totalSamples); let phi=2.0 * PI * xi.x; let cosTheta=sqrt(1.0 - xi.y); let sinTheta=sqrt(xi.y); let sampleVec=vec3(sinTheta * cos(phi),sinTheta * sin(phi),cosTheta); let worldSample=normalize(tangent * sampleVec.x + bitangent * sampleVec.y + normal * sampleVec.z); let pdf=max(cosTheta,0.001)/PI; let saSample=1.0/(f32(totalSamples) * pdf + 0.0001); let mipLevel=max(0.5 * log2(saSample/saTexel),0.0); let sampleColor=textureSampleLevel(environmentTexture,environmentSampler,worldSample,mipLevel); irradiance +=sampleColor.rgb; totalWeight +=1.0; } irradiance=irradiance/totalWeight; textureStore(outTexture,global_id.xy,face,vec4(irradiance,1.0));\n}"})),this.#Q||(this.#Q=x.createComputePipeline({label:"IRRADIANCE_GENERATOR_PIPELINE",layout:"auto",compute:{module:this.#se,entryPoint:"cs_main"}}));const b=x.createCommandEncoder({label:"Irradiance_Generator_Command_Encoder"}),y=this.#oe(),S=x.createBuffer({size:384,usage:GPUBufferUsage.UNIFORM|GPUBufferUsage.COPY_DST,label:"Irradiance_face_matrices_uniform"}),w=new Float32Array(96);y.forEach((i,g)=>w.set(i,16*g)),x.queue.writeBuffer(S,0,w);const L=x.createBindGroup({layout:this.#Q.getBindGroupLayout(0),entries:[{binding:0,resource:i.createView({dimension:"cube"})},{binding:1,resource:this.#ae.gpuSampler},{binding:2,resource:v.createView({dimension:"2d-array"})},{binding:3,resource:{buffer:S}}]}),k=b.beginComputePass({label:"Irradiance_Generator_Compute_Pass"});return k.setPipeline(this.#Q),k.setBindGroup(0,L),k.dispatchWorkgroups(Math.ceil(g/8),Math.ceil(g/8),6),k.end(),x.queue.submit([b.finish()]),await x.queue.onSubmittedWorkDone(),S.destroy(),new IBLCubeTexture(this.#l,`Irradiance_Map_${createUUID()}`,v)}#oe(){return[new Float32Array([0,0,-1,0,0,-1,0,0,1,0,0,0,0,0,0,1]),new Float32Array([0,0,1,0,0,-1,0,0,-1,0,0,0,0,0,0,1]),new Float32Array([1,0,0,0,0,0,1,0,0,1,0,0,0,0,0,1]),new Float32Array([1,0,0,0,0,0,-1,0,0,-1,0,0,0,0,0,1]),new Float32Array([1,0,0,0,0,-1,0,0,0,0,1,0,0,0,0,1]),new Float32Array([-1,0,0,0,0,-1,0,0,0,0,-1,0,0,0,0,1])]}}Object.freeze(IrradianceGenerator);class PrefilterGenerator{#l;#ae;#Q;#se;constructor(i){this.#l=i,this.#ae=new Sampler(this.#l,{magFilter:v.LINEAR,minFilter:v.LINEAR,addressModeU:_.CLAMP_TO_EDGE,addressModeV:_.CLAMP_TO_EDGE,addressModeW:_.CLAMP_TO_EDGE})}async generate(i,g=512){const{gpuDevice:x,resourceManager:_}=this.#l,v=getMipLevelCount(g,g),b=_.createManagedTexture({size:[g,g,6],format:"rgba16float",usage:GPUTextureUsage.TEXTURE_BINDING|GPUTextureUsage.STORAGE_BINDING|GPUTextureUsage.COPY_SRC|GPUTextureUsage.COPY_DST|GPUTextureUsage.RENDER_ATTACHMENT,dimension:"2d",mipLevelCount:v,label:`Prefilter_Map_Texture_${createUUID()}`});this.#se||(this.#se=_.createGPUShaderModule("PREFILTER_GENERATOR_SHADER_MODULE",{code:"\n@group(0) @binding(0) var environmentTexture:texture_cube;\n@group(0) @binding(1) var textureSampler:sampler;\n@group(0) @binding(2) var outTexture:texture_storage_2d_array;\nstruct PrefilterUniforms { faceMatrices:array,6>, roughness:f32,\n}\n@group(0) @binding(3) var uniforms:PrefilterUniforms;\nconst PI:f32=3.14159265359;\nfn radicalInverse_VdC(bits_in:u32) -> f32 { var bits=bits_in; bits=(bits << 16u) | (bits >> 16u); bits=((bits & 0x55555555u) << 1u) | ((bits & 0xAAAAAAAAu) >> 1u); bits=((bits & 0x33333333u) << 2u) | ((bits & 0xCCCCCCCCu) >> 2u); bits=((bits & 0x0F0F0F0Fu) << 4u) | ((bits & 0xF0F0F0F0u) >> 4u); bits=((bits & 0x00FF00FFu) << 8u) | ((bits & 0xFF00FF00u) >> 8u); return f32(bits) * 2.3283064365386963e-10;\n}\nfn hammersley(i:u32,n:u32) -> vec2 { return vec2(f32(i)/f32(n),radicalInverse_VdC(i));\n}\nfn distribution_ggx(NdotH:f32,roughness:f32) -> f32 { let a=roughness * roughness; let a2=a * a; let NdotH2=NdotH * NdotH; let denom=(NdotH2 * (a2 - 1.0) + 1.0); return a2/(PI * denom * denom);\n}\nfn importanceSampleGGX(xi:vec2,N:vec3,roughness:f32) -> vec3 { let a=roughness * roughness; let phi=2.0 * PI * xi.x; let cosTheta=sqrt((1.0 - xi.y)/(1.0 + (a * a - 1.0) * xi.y)); let sinTheta=sqrt(max(0.0,1.0 - cosTheta * cosTheta)); let H=vec3(cos(phi) * sinTheta,sin(phi) * sinTheta,cosTheta); let up=select(vec3(1.0,0.0,0.0),vec3(0.0,0.0,1.0),abs(N.z) < 0.999); let tangent=normalize(cross(up,N)); let bitangent=cross(N,tangent); return normalize(tangent * H.x + bitangent * H.y + N * H.z);\n}\n@compute @workgroup_size(8,8,1)\nfn cs_main(@builtin(global_invocation_id) global_id:vec3) { let size_u=textureDimensions(outTexture); let size=vec2(size_u); if (global_id.x >=size_u.x || global_id.y >=size_u.y || global_id.z >=6u) { return; } let face=global_id.z; let roughness=uniforms.roughness; let uv=(vec2(global_id.xy) + 0.5)/size; let x=uv.x * 2.0 - 1.0; let y=uv.y * 2.0 - 1.0; let localPos=vec4(x,y,1.0,1.0); let N=normalize((uniforms.faceMatrices[face] * localPos).xyz); if (roughness <=0.0) { textureStore(outTexture,global_id.xy,face,textureSampleLevel(environmentTexture,textureSampler,N,0.0)); return; } let R=N; let V=R; var prefilteredColor=vec3(0.0); var totalWeight=0.0; let numSamples=1024u; let envSize=f32(textureDimensions(environmentTexture).x); let saTexel=4.0 * PI/(6.0 * envSize * envSize); for (var i=0u;i < numSamples;i++) { let xi=hammersley(i,numSamples); let H=importanceSampleGGX(xi,N,roughness); let L=normalize(2.0 * dot(V,H) * H - V); let NdotL=max(dot(N,L),0.0); if (NdotL > 0.0) { let NdotH=max(dot(N,H),0.001); let VdotH=max(dot(V,H),0.001); let D=distribution_ggx(NdotH,roughness); let pdf=(D * NdotH/(4.0 * VdotH)) + 0.0001; let saSample=1.0/(f32(numSamples) * pdf + 0.0001); let mipLevel=max(0.25 * log2(saSample/saTexel),0.0); prefilteredColor +=textureSampleLevel(environmentTexture,textureSampler,L,mipLevel).rgb * NdotL; totalWeight +=NdotL; } } if (totalWeight > 0.0) { textureStore(outTexture,global_id.xy,face,vec4(prefilteredColor/totalWeight,1.0)); } else { textureStore(outTexture,global_id.xy,face,textureSampleLevel(environmentTexture,textureSampler,N,0.0)); }\n}"})),this.#Q||(this.#Q=x.createComputePipeline({label:"PREFILTER_GENERATOR_PIPELINE",layout:"auto",compute:{module:this.#se,entryPoint:"cs_main"}}));const y=x.createCommandEncoder({label:"Prefilter_Generator_Command_Encoder"}),S=this.#oe(),w=[];for(let _=0;_>_),k=_/(v-1),H=new Float32Array(100);S.forEach((i,g)=>H.set(i,16*g)),H[96]=k;const z=x.createBuffer({size:H.byteLength,usage:GPUBufferUsage.UNIFORM|GPUBufferUsage.COPY_DST});x.queue.writeBuffer(z,0,H),w.push(z);const q=x.createBindGroup({layout:this.#Q.getBindGroupLayout(0),entries:[{binding:0,resource:i.createView({dimension:"cube"})},{binding:1,resource:this.#ae.gpuSampler},{binding:2,resource:b.createView({dimension:"2d-array",baseMipLevel:_,mipLevelCount:1})},{binding:3,resource:{buffer:z}}]}),W=y.beginComputePass({label:`Prefilter_mip_${_}_compute_pass`});W.setPipeline(this.#Q),W.setBindGroup(0,q),W.dispatchWorkgroups(Math.ceil(L/8),Math.ceil(L/8),6),W.end()}return x.queue.submit([y.finish()]),await x.queue.onSubmittedWorkDone(),w.forEach(i=>i.destroy()),new IBLCubeTexture(this.#l,`Prefilter_Map_${createUUID()}`,b)}#oe(){return[new Float32Array([0,0,-1,0,0,-1,0,0,1,0,0,0,0,0,0,1]),new Float32Array([0,0,1,0,0,-1,0,0,-1,0,0,0,0,0,0,1]),new Float32Array([1,0,0,0,0,0,1,0,0,1,0,0,0,0,0,1]),new Float32Array([1,0,0,0,0,0,-1,0,0,-1,0,0,0,0,0,1]),new Float32Array([1,0,0,0,0,-1,0,0,0,0,1,0,0,0,0,1]),new Float32Array([-1,0,0,0,0,-1,0,0,0,0,-1,0,0,0,0,1])]}}Object.freeze(PrefilterGenerator);class EquirectangularToCubeGenerator{#l;#se;#Q;#ae;constructor(i){this.#l=i,this.#ae=new Sampler(this.#l,{magFilter:v.LINEAR,minFilter:v.LINEAR,addressModeU:_.CLAMP_TO_EDGE,addressModeV:_.CLAMP_TO_EDGE})}async generate(i,g=512){const{gpuDevice:x,resourceManager:_}=this.#l,v=getMipLevelCount(g,g),b={size:[g,g,6],format:"rgba16float",usage:GPUTextureUsage.TEXTURE_BINDING|GPUTextureUsage.STORAGE_BINDING|GPUTextureUsage.COPY_SRC|GPUTextureUsage.COPY_DST|GPUTextureUsage.RENDER_ATTACHMENT,dimension:"2d",mipLevelCount:v,label:`EquirectangularToCube_Texture_${createUUID()}`},y=_.createManagedTexture(b);this.#se||(this.#se=_.createGPUShaderModule("EQUIRECTANGULAR_TO_CUBE_GENERATOR_SHADER_MODULE",{code:"\n@group(0) @binding(0) var equirectangularTexture:texture_2d;\n@group(0) @binding(1) var textureSampler:sampler;\n@group(0) @binding(2) var outTexture:texture_storage_2d_array;\n@group(0) @binding(3) var faceMatrices:array,6>;\nconst PI:f32=3.14159265359;\nfn directionToSphericalUV(dir:vec3) -> vec2 { let normalizedDir=normalize(dir); let theta=atan2(normalizedDir.x,normalizedDir.z); let phi=acos(clamp(normalizedDir.y,-1.0,1.0)); return vec2(0.5 - theta/(2.0 * PI),phi/PI);\n}\n@compute @workgroup_size(8,8,1)\nfn cs_main(@builtin(global_invocation_id) global_id:vec3) { let size=textureDimensions(outTexture); if (global_id.x >=size.x || global_id.y >=size.y || global_id.z >=6u) { return; } let face=global_id.z; let uv=(vec2(global_id.xy) + 0.5)/vec2(size); let x=uv.x * 2.0 - 1.0; let y=uv.y * 2.0 - 1.0; let localPos=vec4(x,y,1.0,1.0); let direction=(faceMatrices[face] * localPos).xyz; let sphericalUV=directionToSphericalUV(direction); let color=textureSampleLevel(equirectangularTexture,textureSampler,sphericalUV,0.0); textureStore(outTexture,global_id.xy,face,color);\n}\n"})),this.#Q||(this.#Q=x.createComputePipeline({label:"EQUIRECTANGULAR_TO_CUBE_GENERATOR_PIPELINE",layout:"auto",compute:{module:this.#se,entryPoint:"cs_main"}}));const S=x.createCommandEncoder({label:"EquirectangularToCube_Generator_Command_Encoder"}),w=this.#oe(),L=x.createBuffer({size:384,usage:GPUBufferUsage.UNIFORM|GPUBufferUsage.COPY_DST,label:"EquirectangularToCube_face_matrices_uniform"}),k=new Float32Array(96);w.forEach((i,g)=>k.set(i,16*g)),x.queue.writeBuffer(L,0,k);const H=x.createBindGroup({layout:this.#Q.getBindGroupLayout(0),entries:[{binding:0,resource:i.createView()},{binding:1,resource:this.#ae.gpuSampler},{binding:2,resource:y.createView({dimension:"2d-array",baseMipLevel:0,mipLevelCount:1})},{binding:3,resource:{buffer:L}}]}),z=S.beginComputePass({label:"EquirectangularToCube_Generator_Compute_Pass"});return z.setPipeline(this.#Q),z.setBindGroup(0,H),z.dispatchWorkgroups(Math.ceil(g/8),Math.ceil(g/8),6),z.end(),x.queue.submit([S.finish()]),_.mipmapGenerator.generateMipmap(y,b),await x.queue.onSubmittedWorkDone(),L.destroy(),new IBLCubeTexture(this.#l,`CubeMap_From_Equirect_${createUUID()}`,y)}#oe(){return[new Float32Array([0,0,-1,0,0,-1,0,0,1,0,0,0,0,0,0,1]),new Float32Array([0,0,1,0,0,-1,0,0,-1,0,0,0,0,0,0,1]),new Float32Array([1,0,0,0,0,0,1,0,0,1,0,0,0,0,0,1]),new Float32Array([1,0,0,0,0,0,-1,0,0,-1,0,0,0,0,0,1]),new Float32Array([1,0,0,0,0,-1,0,0,0,0,1,0,0,0,0,1]),new Float32Array([-1,0,0,0,0,-1,0,0,0,0,-1,0,0,0,0,1])]}}Object.freeze(EquirectangularToCubeGenerator);var k=Object.freeze({__proto__:null,BRDFGenerator:BRDFGenerator,BRDFLUTTexture:BRDFLUTTexture,EquirectangularToCubeGenerator:EquirectangularToCubeGenerator,IBLCubeTexture:IBLCubeTexture,IrradianceGenerator:IrradianceGenerator,PrefilterGenerator:PrefilterGenerator});class DownSampleCubeMapGenerator{#l;#ue=new Map;#le=new Map;#ce=null;#he=null;#fe=null;#de=null;#me=8;#pe=8;#ge=new Map;#xe=new Map;constructor(i){this.#l=i}createSourceTextureView(i,g){const x=`DOWN_SAMPLE_CUBE_GENERATOR_SOURCE_VIEW_${i.label}_${g}`;if(!this.#ge.has(x)){const _=i.createView({label:x,dimension:"cube",baseMipLevel:g,mipLevelCount:1});this.#ge.set(x,_)}return this.#ge.get(x)}createTargetTextureView(i,g){const x=`DOWN_SAMPLE_CUBE_GENERATOR_TARGET_VIEW_${i.label}_${g}`;if(!this.#ge.has(x)){const _=i.createView({label:x,dimension:"2d-array",baseMipLevel:g,mipLevelCount:1,arrayLayerCount:6});this.#ge.set(x,_)}return this.#ge.get(x)}createBindGroup(i,g,x){const _=`DOWN_SAMPLE_CUBE_GENERATOR_BIND_GROUP_${g.label}_${x.label}`;if(!this.#xe.has(_)){const{gpuDevice:v}=this.#l,b=v.createBindGroup({label:_,layout:i,entries:[{binding:0,resource:g},{binding:1,resource:x},{binding:2,resource:this.#de},{binding:3,resource:{buffer:this.#he}}]});this.#xe.set(_,b)}return this.#xe.get(_)}async downsampleCubemap(i,g=256,x="rgba16float"){try{this.#_e(),this.#ve();const{gpuDevice:_,resourceManager:v}=this.#l;if(!i)throw new Error("Invalid source cubemap texture");if(g<=0||!Number.isInteger(g))throw new Error("Target size must be a positive integer");const b=i.mipLevelCount,y=getMipLevelCount(g,g),S=v.createManagedTexture({size:[g,g,6],format:x,usage:GPUTextureUsage.STORAGE_BINDING|GPUTextureUsage.TEXTURE_BINDING|GPUTextureUsage.RENDER_ATTACHMENT,dimension:"2d",mipLevelCount:y,label:`DOWN_SAMPLE_CUBE_GENERATOR_TEXTURE_${g}x${g}_${y}mips_${Date.now()}`});for(let _=0;_>_),y=this.#be(i.width,g,_,b);await this.#ye(i,S,y,_,v,x)}return this.#_e(),S}catch(i){throw console.error("큐브맵 다운샘플링 실패:",i),this.#_e(),i}}destroy(){this.#_e(),this.#he&&(this.#he.destroy(),this.#he=null),this.#ue.clear(),this.#le.clear(),this.#ce=null,this.#de=null}#_e(){this.#ge.clear(),this.#xe.clear()}#ve(){if(this.#ce)return;const{gpuDevice:i,resourceManager:g}=this.#l;this.#de=new Sampler(this.#l,{minFilter:"linear",magFilter:"linear",mipmapFilter:"linear",addressModeU:"clamp-to-edge",addressModeV:"clamp-to-edge",addressModeW:"clamp-to-edge"}).gpuSampler,this.#ce=g.createGPUShaderModule("DOWN_SAMPLE_CUBE_GENERATOR_COMPUTE_SHADER",{code:"\nstruct Uniforms { targetSize:f32, sourceMipLevel:f32, targetMipLevel:f32, padding:f32,\n};\n@group(0) @binding(0) var sourceCubemap:texture_cube;\n@group(0) @binding(1) var targetCubemap:texture_storage_2d_array;\n@group(0) @binding(2) var cubemapSampler:sampler;\n@group(0) @binding(3) var uniforms:Uniforms;\nfn cubemapUVToDirection(uv:vec2,face:u32) -> vec3 { let u=uv.x * 2.0 - 1.0; let v=uv.y * 2.0 - 1.0; switch face { case 0u:{ return vec3(1.0,-v,-u); } case 1u:{ return vec3(-1.0,-v,u); } case 2u:{ return vec3(u,1.0,v); } case 3u:{ return vec3(u,-1.0,-v); } case 4u:{ return vec3(u,-v,1.0); } case 5u:{ return vec3(-u,-v,-1.0); } default:{ return vec3(0.0,0.0,1.0); } }\n}\nfn gaussianWeight(x:f32,y:f32,sigma:f32) -> f32 { let sigmaSq=sigma * sigma; return exp(-(x * x + y * y)/(2.0 * sigmaSq))/(2.0 * 3.14159265359 * sigmaSq);\n}\nfn clampCubemapUV(uv:vec2) -> vec2 { return clamp(uv,vec2(0.0),vec2(1.0));\n}\n@compute @workgroup_size(8,8,1)\nfn main(@builtin(global_invocation_id) global_id:vec3) { let face=global_id.z; let coord=vec2(global_id.xy); let targetSize=u32(uniforms.targetSize); if (coord.x >=targetSize || coord.y >=targetSize || face >=6u) { return; } let uv=(vec2(coord) + 0.5)/f32(targetSize); let direction=normalize(cubemapUVToDirection(uv,face)); let sourceMipLevel=uniforms.sourceMipLevel; let targetMipLevel=uniforms.targetMipLevel; var color=vec4(0.0); if (sourceMipLevel==0.0 && targetSize > 64u) { let sampleCount=16u; let sampleRadius=1.0/f32(targetSize); var totalWeight=0.0; for (var i=0u;i < sampleCount;i++) { let angle=2.0 * 3.14159265359 * f32(i)/f32(sampleCount); let radius=sampleRadius * (0.5 + 0.5 * f32(i % 4u)/4.0); let offsetUV=clampCubemapUV(uv + vec2( cos(angle) * radius, sin(angle) * radius )); let sampleDir=normalize(cubemapUVToDirection(offsetUV,face)); let sampleColor=textureSampleLevel(sourceCubemap,cubemapSampler,sampleDir,sourceMipLevel); let weight=gaussianWeight( cos(angle) * radius * f32(targetSize), sin(angle) * radius * f32(targetSize), 0.8 ); color +=sampleColor * weight; totalWeight +=weight; } if (totalWeight > 0.0) { color=color/totalWeight; } } else if (sourceMipLevel==0.0 && targetSize > 16u) { let sampleCount=4u; let invSampleCount=1.0/f32(sampleCount * sampleCount); let sampleOffset=0.5/f32(targetSize); for (var x=0u;x < sampleCount;x++) { for (var y=0u;y < sampleCount;y++) { let offset=vec2( (f32(x) - 1.5) * sampleOffset, (f32(y) - 1.5) * sampleOffset ); let offsetUV=clampCubemapUV(uv + offset); let sampleDir=normalize(cubemapUVToDirection(offsetUV,face)); color +=textureSampleLevel(sourceCubemap,cubemapSampler,sampleDir,sourceMipLevel); } } color *=invSampleCount; } else if (targetSize > 4u) { let sampleCount=2u; let invSampleCount=1.0/f32(sampleCount * sampleCount); let sampleOffset=0.25/f32(targetSize); for (var x=0u;x < sampleCount;x++) { for (var y=0u;y < sampleCount;y++) { let offset=vec2( (f32(x) - 0.5) * sampleOffset, (f32(y) - 0.5) * sampleOffset ); let offsetUV=clampCubemapUV(uv + offset); let sampleDir=normalize(cubemapUVToDirection(offsetUV,face)); color +=textureSampleLevel(sourceCubemap,cubemapSampler,sampleDir,sourceMipLevel); } } color *=invSampleCount; } else { color=textureSampleLevel(sourceCubemap,cubemapSampler,direction,sourceMipLevel); } if (targetMipLevel > 0.0) { let luminance=dot(color.rgb,vec3(0.299,0.587,0.114)); let saturation=0.9 + 0.1/(1.0 + targetMipLevel * 0.1); color=vec4(mix(vec3(luminance),color.rgb,saturation),color.a); } textureStore(targetCubemap,vec2(coord),i32(face),color);\n}\n"}),this.#Se()}#Te(i){if(!this.#ue.has(i)){const{gpuDevice:g,resourceManager:x}=this.#l,_=x.createBindGroupLayout(`DOWN_SAMPLE_CUBE_GENERATOR_BIND_GROUP_LAYOUT_${i}`,{entries:[{binding:0,visibility:GPUShaderStage.COMPUTE,texture:{viewDimension:"cube",sampleType:"float"}},{binding:1,visibility:GPUShaderStage.COMPUTE,storageTexture:{format:i,viewDimension:"2d-array"}},{binding:2,visibility:GPUShaderStage.COMPUTE,sampler:{type:"filtering"}},{binding:3,visibility:GPUShaderStage.COMPUTE,buffer:{type:"uniform"}}]}),v=g.createComputePipeline({label:`DOWN_SAMPLE_CUBE_GENERATOR_COMPUTE_PIPELINE_${i}`,layout:g.createPipelineLayout({label:`DOWN_SAMPLE_CUBE_GENERATOR_PIPELINE_LAYOUT_${i}`,bindGroupLayouts:[_]}),compute:{module:this.#ce,entryPoint:"main"}});this.#le.set(i,_),this.#ue.set(i,v)}return this.#ue.get(i)}#Se(){const{gpuDevice:i,resourceManager:g}=this.#l;this.#fe={arrayBufferByteLength:16,properties:{targetSize:{byteOffset:0,size:4},sourceMipLevel:{byteOffset:4,size:4},targetMipLevel:{byteOffset:8,size:4},padding:{byteOffset:12,size:4}}},this.#he=i.createBuffer({size:this.#fe.arrayBufferByteLength,usage:GPUBufferUsage.UNIFORM|GPUBufferUsage.COPY_DST,label:"DOWN_SAMPLE_CUBE_GENERATOR_UNIFORM_BUFFER"})}#be(i,g,x,_){const v=i/Math.max(1,g>>x),b=Math.max(0,Math.floor(Math.log2(v)));return Math.min(b,_-1)}async#ye(i,g,x,_,v,b){const{gpuDevice:y}=this.#l,S=this.#Te(b),w=this.#le.get(b),L=this.createSourceTextureView(i,x),k=this.createTargetTextureView(g,_),H=this.createBindGroup(w,L,k);this.#Me(x,_,v);const z=y.createCommandEncoder({label:`DOWN_SAMPLE_CUBE_GENERATOR_COMMAND_ENCODER_MIP${_}`}),q=z.beginComputePass({label:`DOWN_SAMPLE_CUBE_GENERATOR_COMPUTE_PASS_MIP${_}`});q.setPipeline(S),q.setBindGroup(0,H),q.dispatchWorkgroups(Math.ceil(v/this.#me),Math.ceil(v/this.#pe),6),q.end();const W=z.finish();y.queue.submit([W]),await y.queue.onSubmittedWorkDone()}#Me(i,g,x){const{gpuDevice:_}=this.#l,v=new Float32Array([x,i,g,0]);_.queue.writeBuffer(this.#he,0,v)}}Object.freeze(DownSampleCubeMapGenerator);const H={LOAD:"load",CLEAR:"clear"};Object.freeze(H);const z={STORE:"store",DISCARD:"discard"};Object.freeze(z);class MipmapGenerator{#l;#ae;#we;#Ce;#Re;#Pe;#ge=new Map;#xe=new Map;#Be=new WeakMap;#Ie=new WeakMap;constructor(i){this.#l=i,this.#ae=new Sampler(i,{minFilter:"linear"}).gpuSampler,this.#Ce={}}createTextureView(i,g,x,_=!1){const v=`${g}_${x}`;if(_){let _=this.#Ie.get(i);if(_||(_=new Map,this.#Ie.set(i,_)),_.has(v))return _.get(v);const b=i.createView({baseMipLevel:g,mipLevelCount:1,dimension:"2d",baseArrayLayer:x,arrayLayerCount:1,label:`MIPMAP_GENERATOR_CACHED_${i.label}_${v}`});return _.set(v,b),b}{const _=`MIPMAP_GENERATOR_${i.label}_${g}_${x}`;if(!this.#ge.has(_)){const v=i.createView({baseMipLevel:g,mipLevelCount:1,dimension:"2d",baseArrayLayer:x,arrayLayerCount:1,label:_});this.#ge.set(_,v)}return this.#ge.get(_)}}createBindGroup(i,g,x=!1){const{gpuDevice:_}=this.#l;if(x){let x=this.#Be.get(i);x||(x=new Map,this.#Be.set(i,x));const v=g.label||"unlabeled";if(x.has(v))return x.get(v);const b=_.createBindGroup({label:`MIPMAP_GENERATOR_BIND_GROUP_CACHED_${i.label}_${v}`,layout:this.#Re,entries:[{binding:0,resource:this.#ae},{binding:1,resource:g}]});return x.set(v,b),b}{const x=`${i.label}_${g.label}`;if(this.#xe.has(x))return this.#xe.get(x);const v=_.createBindGroup({label:`MIPMAP_GENERATOR_BIND_GROUP_TEMP_${x}`,layout:this.#Re,entries:[{binding:0,resource:this.#ae},{binding:1,resource:g}]});return this.#xe.set(x,v),v}}getMipmapPipeline(i){const{gpuDevice:g,resourceManager:x}=this.#l;let _=this.#Ce[i];return _||(this.#Pe||(this.#Pe=x.createGPUShaderModule("MIPMAP_GENERATOR_SHADER_MODULE",{code:"\nvar pos:array,3>=array,3>( vec2(-1.0,-1.0), vec2(-1.0,3.0), vec2(3.0,-1.0)\n);\nstruct VertexOutput { @builtin(position) position:vec4, @location(0) texCoord:vec2,\n};\n@vertex\nfn vertexMain(@builtin(vertex_index) vertexIndex:u32) -> VertexOutput { var output:VertexOutput; output.texCoord=pos[vertexIndex] * vec2(0.5,-0.5) + vec2(0.5); output.position=vec4(pos[vertexIndex],0.0,1.0); return output;\n}\n@group(0) @binding(0)\nvar imgSampler:sampler;\n@group(0) @binding(1)\nvar img:texture_2d;\n@fragment\nfn fragmentMain(@location(0) texCoord:vec2) -> @location(0) vec4 { return textureSample(img,imgSampler,texCoord);\n}\n"}),this.#Re=x.createBindGroupLayout("MIPMAP_GENERATOR_FRAGMENT_BIND_GROUP_LAYOUT",{entries:[{binding:0,visibility:GPUShaderStage.FRAGMENT,sampler:{}},{binding:1,visibility:GPUShaderStage.FRAGMENT,texture:{}}]}),this.#we=x.createGPUPipelineLayout("MIPMAP_GENERATOR_PIPELINE_LAYOUT",{bindGroupLayouts:[this.#Re]})),_=g.createRenderPipeline({label:`MIPMAP_GENERATOR_PIPELINE_${i}`,layout:this.#we,vertex:{module:this.#Pe,entryPoint:"vertexMain"},fragment:{module:this.#Pe,entryPoint:"fragmentMain",targets:[{format:i}]}}),this.#Ce[i]=_),_}generateMipmap(i,g,x=!1){x||this.#_e();const{gpuDevice:_,resourceManager:v}=this.#l,b=this.getMipmapPipeline(g.format);if("3d"==g.dimension||"1d"==g.dimension)throw new Error("Generating mipmaps for non-2d textures is currently unsupported!");let y=i;const S=g.size[0],w=g.size[1],L=g.size[2]||1,k=g.usage&GPUTextureUsage.RENDER_ATTACHMENT;if(!k){const i={size:{width:Math.max(1,S>>>1),height:Math.max(1,w>>>1),depthOrArrayLayers:L},format:g.format,usage:GPUTextureUsage.TEXTURE_BINDING|GPUTextureUsage.COPY_SRC|GPUTextureUsage.RENDER_ATTACHMENT,mipLevelCount:g.mipLevelCount-1};y=v.createManagedTexture(i)}const q=_.createCommandEncoder({});for(let _=0;_>>1),height:Math.max(1,w>>>1),depthOrArrayLayers:L};for(let _=1;_>>1),x.height=Math.max(1,x.height>>>1)}return _.queue.submit([q.finish()]),k||y.destroy(),x||this.#_e(),i}destroy(){this.#_e()}#_e(){this.#ge.clear(),this.#xe.clear()}}Object.freeze(MipmapGenerator);const q={TILE_COUNT_X:32,TILE_COUNT_Y:32,TILE_COUNT_Z:48,WORKGROUP_SIZE_X:8,WORKGROUP_SIZE_Y:4,WORKGROUP_SIZE_Z:8,MAX_LIGHTS_PER_CLUSTER:100,MAX_CLUSTER_LIGHTS:1024,getTotalTileSize:()=>q.TILE_COUNT_X*q.TILE_COUNT_Y*q.TILE_COUNT_Z,getClusterLightsBufferSize:()=>{const i=q.getTotalTileSize();return 8*i+8*q.MAX_LIGHTS_PER_CLUSTER*i+4},getDispatchSize:()=>[Math.ceil(q.TILE_COUNT_X/q.WORKGROUP_SIZE_X),Math.ceil(q.TILE_COUNT_Y/q.WORKGROUP_SIZE_Y),Math.ceil(q.TILE_COUNT_Z/q.WORKGROUP_SIZE_Z)]};Object.freeze(q);const W=Object.freeze({calcTintBlendMode:"\nfn rgbToHsl(rgb:vec3) -> vec3 { let maxVal:f32=max(max(rgb.r,rgb.g),rgb.b); let minVal:f32=min(min(rgb.r,rgb.g),rgb.b); let delta:f32=maxVal - minVal; let eps=1e-6; let lightness:f32=(maxVal + minVal) * 0.5; if (delta < eps) { return vec3(0.0,0.0,lightness); } var saturation:f32; if (lightness < 0.5) { saturation=delta/(maxVal + minVal + eps); } else { saturation=delta/(2.0 - maxVal - minVal + eps); } var hue:f32=0.0; if (abs(rgb.r - maxVal) < eps) { hue=(rgb.g - rgb.b)/delta; if (rgb.g < rgb.b) { hue +=6.0; } } else if (abs(rgb.g - maxVal) < eps) { hue=(rgb.b - rgb.r)/delta + 2.0; } else { hue=(rgb.r - rgb.g)/delta + 4.0; } hue=hue/6.0; return vec3(hue,saturation,lightness);\n}\nfn hslToRgb(hsl:vec3) -> vec3 { let h=hsl.x; let s=hsl.y; let l=hsl.z; if (s==0.0) { return vec3(l,l,l); } var q:f32; if (l < 0.5) { q=l * (1.0 + s); } else { q=l + s - l * s; } let p=2.0 * l - q; var r:f32; var g:f32; var b:f32; for (var i:i32=0;i < 3;i=i + 1) { var t:f32; if (i==0) { t=h + 1.0/3.0; } else if (i==1) { t=h; } else { t=h - 1.0/3.0; } if (t < 0.0) { t=t + 1.0; } if (t > 1.0) { t=t - 1.0; } var color:f32; if (t < 1.0/6.0) { color=p + (q - p) * 6.0 * t; } else if (t < 1.0/2.0) { color=q; } else if (t < 2.0/3.0) { color=p + (q - p) * (2.0/3.0 - t) * 6.0; } else { color=p; } if (i==0) { r=color; } else if (i==1) { g=color; } else { b=color; } } return vec3(r,g,b);\n}\nfn calcTintBlendMode(baseColor:vec4,tintBlendMode:u32,tint:vec4) -> vec4 { var tintedColor:vec3; let eps=1e-6; switch (tintBlendMode) { case 0u:{ tintedColor=mix(baseColor.rgb,tint.rgb,tint.a); } case 1u:{ tintedColor=baseColor.rgb * tint.rgb; } case 2u:{ tintedColor=max(baseColor.rgb,tint.rgb); } case 3u:{ tintedColor=1.0 - (1.0 - baseColor.rgb) * (1.0 - tint.rgb); } case 4u:{ tintedColor=clamp(baseColor.rgb + tint.rgb,vec3(0.0),vec3(1.0)); } case 5u:{ tintedColor=clamp(baseColor.rgb - tint.rgb,vec3(0.0),vec3(1.0)); } case 6u:{ tintedColor=min(baseColor.rgb,tint.rgb); } case 7u:{ tintedColor=mix( 2.0 * baseColor.rgb * tint.rgb, 1.0 - 2.0 * (1.0 - baseColor.rgb) * (1.0 - tint.rgb), step(vec3(0.5),baseColor.rgb) ); } case 8u:{ tintedColor=clamp(baseColor.rgb/(1.0 - tint.rgb + eps),vec3(0.0),vec3(1.0)); } case 9u:{ tintedColor=1.0 - clamp((1.0 - baseColor.rgb)/(tint.rgb + eps),vec3(0.0),vec3(1.0)); } case 10u:{ tintedColor=mix( 2.0 * baseColor.rgb * tint.rgb, 1.0 - 2.0 * (1.0 - baseColor.rgb) * (1.0 - tint.rgb), step(vec3(0.5),tint.rgb) ); } case 11u:{ tintedColor=mix( baseColor.rgb * (tint.rgb + tint.rgb - vec3(1.0)), baseColor.rgb + tint.rgb - baseColor.rgb * tint.rgb, step(vec3(0.5),tint.rgb) ); } case 12u:{ tintedColor=abs(baseColor.rgb - tint.rgb); } case 13u:{ tintedColor=baseColor.rgb + tint.rgb - 2.0 * baseColor.rgb * tint.rgb; } case 14u:{ tintedColor=clamp(baseColor.rgb/(tint.rgb + eps),vec3(0.0),vec3(1.0)); } case 15u:{ tintedColor=mix( clamp(baseColor.rgb/(1.0 - (tint.rgb - vec3(0.5)) * 2.0 + eps),vec3(0.0),vec3(1.0)), 1.0 - clamp((1.0 - baseColor.rgb)/(tint.rgb * 2.0 + eps),vec3(0.0),vec3(1.0)), step(vec3(0.5),tint.rgb) ); } case 16u:{ tintedColor=clamp(baseColor.rgb + tint.rgb - vec3(1.0),vec3(0.0),vec3(1.0)); } case 17u:{ tintedColor=mix( min(baseColor.rgb,2.0 * tint.rgb), max(baseColor.rgb,2.0 * tint.rgb - vec3(1.0)), step(vec3(0.5),tint.rgb) ); } case 18u:{ let baseHsl=rgbToHsl(baseColor.rgb); let tintHsl=rgbToHsl(tint.rgb); tintedColor=hslToRgb(vec3(baseHsl.x,tintHsl.y,baseHsl.z)); } case 19u:{ let baseHsl=rgbToHsl(baseColor.rgb); let tintHsl=rgbToHsl(tint.rgb); tintedColor=hslToRgb(vec3(tintHsl.x,baseHsl.y,baseHsl.z)); } case 20u:{ let baseHsl=rgbToHsl(baseColor.rgb); let tintHsl=rgbToHsl(tint.rgb); tintedColor=hslToRgb(vec3(baseHsl.x,baseHsl.y,tintHsl.z)); } case 21u:{ let baseHsl=rgbToHsl(baseColor.rgb); let tintHsl=rgbToHsl(tint.rgb); tintedColor=hslToRgb(vec3(tintHsl.x,tintHsl.y,baseHsl.z)); } case 22u:{ tintedColor=1.0 - abs(1.0 - baseColor.rgb - tint.rgb); } default:{ tintedColor=baseColor.rgb; } } return vec4(tintedColor,baseColor.a * tint.a);\n}\n",calcDirectionalShadowVisibility:"fn calcDirectionalShadowVisibility( directionalShadowMap:texture_depth_2d, directionalShadowMapSampler:sampler_comparison, shadowDepthTextureSize:u32, bias:f32, shadowPos:vec3\n) -> f32 { let oneOverShadowDepthTextureSize=1.0/f32(shadowDepthTextureSize); let shadowDepth=clamp(shadowPos.z,0.0,1.0); var visibility:f32=0.0; for (var y=-1;y <=1;y++) { for (var x=-1;x <=1;x++) { let offset=vec2f(vec2(x,y)) * oneOverShadowDepthTextureSize; let tUV=shadowPos.xy + offset; let sampleVisibility=textureSampleCompare( directionalShadowMap, directionalShadowMapSampler, tUV, shadowDepth - bias ); if (tUV.x < 0.0 || tUV.x > 1.0 || tUV.y < 0.0 || tUV.y > 1.0) { visibility +=1.0; } else { visibility +=sampleVisibility; } } } visibility/=9.0; let depthFactor=shadowDepth; let minVisibility=0.2 + depthFactor * 0.6; return max(visibility,minVisibility);\n}\n",drawDirectionalShadowDepth:"struct OutputShadowData { @builtin(position) position:vec4,\n};\n@vertex\nfn drawDirectionalShadowDepth(inputData:InputData) -> OutputShadowData { var output:OutputShadowData; let u_directionalLightProjectionViewMatrix=systemUniforms.directionalLightProjectionViewMatrix; let u_camera=systemUniforms.camera; let u_cameraMatrix=u_camera.cameraMatrix; let u_cameraPosition=u_camera.cameraPosition; let u_modelMatrix=vertexUniforms.matrixList.modelMatrix; let input_position=inputData.position; let input_vertexNormal=inputData.vertexNormal; let input_uv=inputData.uv; var position:vec4; position=u_modelMatrix * vec4(input_position,1.0); #redgpu_if useDisplacementTexture { let distance=distance(position.xyz,u_cameraPosition); let mipLevel=(distance/maxDistance) * maxMipLevel; let displacedPosition=calcDisplacementPosition( input_position, input_vertexNormal, displacementTexture, displacementTextureSampler, vertexUniforms.displacementScale, input_uv, mipLevel ); position=u_modelMatrix * vec4(displacedPosition,1.0); } #redgpu_endIf output.position=u_directionalLightProjectionViewMatrix * position; return output;\n}\n",normalFunctions:"\nfn cotangent_frame( N:vec3,p:vec3,uv:vec2) -> mat3x3{ let dp1:vec3=dpdx( p ); let dp2:vec3=dpdy( p ); let duv1:vec2=dpdx( uv ); let duv2:vec2=dpdy( uv ); let dp2perp:vec3=cross( dp2,N ); let dp1perp:vec3=cross( N,dp1 ); let T:vec3=dp2perp * duv1.x + dp1perp * duv2.x; let B:vec3=dp2perp * duv1.y + dp1perp * duv2.y; return mat3x3( normalize(T),normalize(B),N );\n}\nfn perturb_normal( N:vec3,position:vec3,texcoord:vec2,normalColor:vec3,normalPower:f32 ) -> vec3 { var map:vec3=normalColor; map=normalColor * 2.0 - 1.0; map=vec3(map.xy * -normalPower,map.z); let TBN:mat3x3=cotangent_frame(N,position,texcoord); return normalize(TBN * map);\n}\n",calcPrePathBackground:"fn calcPrePathBackground( u_useKHR_materials_volume:bool,thicknessParameter:f32,u_KHR_dispersion:f32,u_KHR_attenuationDistance:f32,u_KHR_attenuationColor:vec3, ior:f32,roughnessParameter:f32,albedo:vec3, projectionCameraMatrix:mat4x4,input_vertexPosition:vec3,input_ndcPosition:vec3, V:vec3,N:vec3, renderPath1ResultTexture:texture_2d,renderPath1ResultTextureSampler:sampler\n) -> vec3 { var prePathBackground=vec3(0.0); let maxMipLevel=f32(textureNumLevels(renderPath1ResultTexture) - 1); let transmissionMipLevel=clamp(roughnessParameter * maxMipLevel,0.0,maxMipLevel); if(u_useKHR_materials_volume){ var iorR:f32=ior; var iorG:f32=ior; var iorB:f32=ior; if(u_KHR_dispersion > 0.0){ let halfSpread:f32=(ior - 1.0) * 0.025 * u_KHR_dispersion; iorR=ior + halfSpread; iorG=ior; iorB=ior - halfSpread; } iorR=max(iorR,1.0001); iorG=max(iorG,1.0001); iorB=max(iorB,1.0001); let refractedVecR:vec3=refract(-V,N,1.0/iorR); let refractedVecG:vec3=refract(-V,N,1.0/iorG); let refractedVecB:vec3=refract(-V,N,1.0/iorB); let validR=dot(refractedVecR,refractedVecR) > 0.0; let validG=dot(refractedVecG,refractedVecG) > 0.0; let validB=dot(refractedVecB,refractedVecB) > 0.0; let finalRefractR=select(reflect(-V,N),refractedVecR,validR); let finalRefractG=select(reflect(-V,N),refractedVecG,validG); let finalRefractB=select(reflect(-V,N),refractedVecB,validB); let safeThickness=clamp(thicknessParameter,0.0,100.0); let worldPosR:vec3=input_vertexPosition + finalRefractR * safeThickness; let worldPosG:vec3=input_vertexPosition + finalRefractG * safeThickness; let worldPosB:vec3=input_vertexPosition + finalRefractB * safeThickness; let clipPosR:vec4=projectionCameraMatrix * vec4(worldPosR,1.0); let clipPosG:vec4=projectionCameraMatrix * vec4(worldPosG,1.0); let clipPosB:vec4=projectionCameraMatrix * vec4(worldPosB,1.0); let wR=max(abs(clipPosR.w),0.0001); let wG=max(abs(clipPosG.w),0.0001); let wB=max(abs(clipPosB.w),0.0001); let ndcR:vec2=clipPosR.xy/wR * 0.5 + 0.5; let ndcG:vec2=clipPosG.xy/wG * 0.5 + 0.5; let ndcB:vec2=clipPosB.xy/wB * 0.5 + 0.5; let finalUV_R:vec2=clamp(vec2(ndcR.x,1.0 - ndcR.y),vec2(0.0),vec2(1.0)); let finalUV_G:vec2=clamp(vec2(ndcG.x,1.0 - ndcG.y),vec2(0.0),vec2(1.0)); let finalUV_B:vec2=clamp(vec2(ndcB.x,1.0 - ndcB.y),vec2(0.0),vec2(1.0)); let sampledR=textureSampleLevel(renderPath1ResultTexture,renderPath1ResultTextureSampler,finalUV_R,transmissionMipLevel).r; let sampledG=textureSampleLevel(renderPath1ResultTexture,renderPath1ResultTextureSampler,finalUV_G,transmissionMipLevel).g; let sampledB=textureSampleLevel(renderPath1ResultTexture,renderPath1ResultTextureSampler,finalUV_B,transmissionMipLevel).b; prePathBackground.r=select(0.0,sampledR,isFiniteScalar(sampledR)); prePathBackground.g=select(0.0,sampledG,isFiniteScalar(sampledG)); prePathBackground.b=select(0.0,sampledB,isFiniteScalar(sampledB)); } else { let safeIor=max(ior,1.0001); let refractedVec:vec3=refract(-V,N,1.0/safeIor); let valid=dot(refractedVec,refractedVec) > 0.0; let finalRefract=select(reflect(-V,N),refractedVec,valid); let safeThickness=clamp(thicknessParameter,0.0,100.0); let worldPos:vec3=input_vertexPosition + finalRefract * safeThickness; let clipPos:vec4=projectionCameraMatrix * vec4(worldPos,1.0); let w=max(abs(clipPos.w),0.0001); let ndc:vec2=clipPos.xy/w * 0.5 + 0.5; let finalUV:vec2=clamp(vec2(ndc.x,1.0 - ndc.y),vec2(0.0),vec2(1.0)); let sampled=textureSampleLevel(renderPath1ResultTexture,renderPath1ResultTextureSampler,finalUV,transmissionMipLevel).rgb; prePathBackground=select(vec3(0.0),sampled,all(isFiniteVec3(sampled))); } let safeAlbedo=clamp(albedo,vec3(0.0),vec3(1.0)); prePathBackground *=safeAlbedo; prePathBackground=select(vec3(0.0),prePathBackground,all(isFiniteVec3(prePathBackground))); return prePathBackground;\n}\nfn isFiniteScalar(x:f32) -> bool { return x==x && abs(x) < 1e30;\n}\nfn isFiniteVec3(v:vec3) -> vec3 { return vec3( v.x==v.x && abs(v.x) < 1e30, v.y==v.y && abs(v.y) < 1e30, v.z==v.z && abs(v.z) < 1e30 );\n}",calculateMotionVector:"fn calculateMotionVector( currentClipPos:vec4, prevClipPos:vec4,\n) -> vec2 { let currentNDC=currentClipPos.xy/max(currentClipPos.w,1e-6); let prevNDC=prevClipPos.xy/max(prevClipPos.w,1e-6); var motionVector=currentNDC - prevNDC; motionVector.y=-motionVector.y; let uvMotionVector=motionVector * 0.5; return uvMotionVector;\n}\n",FragmentOutput:"struct FragmentOutput { @location(0) color:vec4, @location(1) gBufferNormal:vec4, @location(2) gBufferMotionVector:vec4,\n}\n",picking:"@vertex\nfn picking(inputData:InputData) -> OutputData { var output:OutputData; let input_position=inputData.position; let u_modelMatrix=vertexUniforms.matrixList.modelMatrix; let u_projectionMatrix=systemUniforms.projectionMatrix; let u_projectionCameraMatrix=systemUniforms.projectionCameraMatrix; let u_camera=systemUniforms.camera; let u_cameraMatrix=u_camera.cameraMatrix; var position:vec4=u_modelMatrix * vec4(input_position,1.0); output.position=u_projectionCameraMatrix * position; output.pickingId=unpack4x8unorm(vertexUniforms.pickingId); return output;\n}\n",drawPicking:"\n@fragment\nfn picking(inputData:InputData) -> @location(0) vec4 { var finalColor:vec4=inputData.pickingId; return finalColor;\n}\n"});Object.freeze(W);const be=Object.freeze({billboardPicking:"@vertex\nfn picking(inputData:InputData) -> OutputData { var output:OutputData; let u_resolution=systemUniforms.resolution; #redgpu_if disableJitter let u_projectionMatrix=systemUniforms.noneJitterProjectionMatrix; #redgpu_else let u_projectionMatrix=systemUniforms.projectionMatrix; #redgpu_endIf let u_cameraMatrix=systemUniforms.camera.cameraMatrix; let u_modelMatrix=vertexUniforms.matrixList.modelMatrix; let u_useBillboard=vertexUniforms.useBillboard; let u_usePixelSize=vertexUniforms.usePixelSize; let u_pixelSize=vertexUniforms.pixelSize; let u_renderRatioX=vertexUniforms._renderRatioX; let u_renderRatioY=vertexUniforms._renderRatioY; var ratioScaleMatrix:mat4x4=mat4x4( u_renderRatioX,0,0,0, 0,u_renderRatioY,0,0, 0,0,1,0, 0,0,0,1 ); if (u_useBillboard==1) { let billboardMatrix=getBillboardMatrix(u_cameraMatrix,u_modelMatrix); if (u_usePixelSize==1) { let viewPositionCenter=billboardMatrix * vec4(0.0,0.0,0.0,1.0); let clipCenter=u_projectionMatrix * viewPositionCenter; let scaleX=(u_pixelSize/u_resolution.x) * 2.0 * u_renderRatioX; let scaleY=(u_pixelSize/u_resolution.y) * 2.0 * u_renderRatioY; output.position=vec4( clipCenter.xy + inputData.position.xy * vec2(scaleX,scaleY) * clipCenter.w, clipCenter.zw ); } else { output.position=u_projectionMatrix * billboardMatrix * ratioScaleMatrix * vec4(inputData.position,1.0); } } else { output.position=u_projectionMatrix * u_cameraMatrix * u_modelMatrix * ratioScaleMatrix * vec4(inputData.position,1.0); } output.pickingId=unpack4x8unorm(vertexUniforms.pickingId); return output;\n}",billboardShadow:"struct OutputShadowData { @builtin(position) position:vec4,\n};\n@vertex\nfn drawDirectionalShadowDepth(inputData:InputData) -> OutputShadowData { var output:OutputShadowData; return output;\n}",calcBillboard:"struct BillboardResult { position:vec4, vertexPosition:vec3, vertexNormal:vec3,\n}\nfn calcBillboard( input_position:vec3, input_normal:vec3, modelMatrix:mat4x4, cameraMatrix:mat4x4, projectionMatrix:mat4x4, resolution:vec2, useBillboard:u32, usePixelSize:u32, pixelSize:f32, renderRatioX:f32, renderRatioY:f32\n) -> BillboardResult { var result:BillboardResult; let ratioScaleMatrix=mat4x4( renderRatioX,0,0,0, 0,renderRatioY,0,0, 0,0,1,0, 0,0,0,1 ); var viewPos:vec4; var viewNormal:vec4; if (useBillboard==1u) { let billboardMatrix=getBillboardMatrix(cameraMatrix,modelMatrix); if (usePixelSize==1u) { let viewCenter=billboardMatrix * vec4(0.0,0.0,0.0,1.0); let clipCenter=projectionMatrix * viewCenter; let scaleX=(pixelSize/resolution.x) * 2.0 * renderRatioX; let scaleY=(pixelSize/resolution.y) * 2.0 * renderRatioY; result.position=vec4( clipCenter.xy + input_position.xy * vec2(scaleX,scaleY) * clipCenter.w, clipCenter.zw ); viewPos=viewCenter; viewNormal=vec4(0.0,0.0,1.0,0.0); } else { viewPos=billboardMatrix * ratioScaleMatrix * vec4(input_position,1.0); viewNormal=vec4(0.0,0.0,1.0,0.0); result.position=projectionMatrix * viewPos; } } else { viewPos=cameraMatrix * modelMatrix * ratioScaleMatrix * vec4(input_position,1.0); viewNormal=cameraMatrix * modelMatrix * ratioScaleMatrix * vec4(input_normal,0.0); result.position=projectionMatrix * viewPos; } result.vertexPosition=viewPos.xyz; result.vertexNormal=normalize(viewNormal.xyz); return result;\n}\n",calcDisplacements:"fn calcDisplacementPosition(input_position:vec3,input_vertexNormal:vec3,displacementTexture:texture_2d,displacementTextureSampler:sampler,displacementScale:f32,input_uv:vec2,mipLevel:f32) -> vec3 { let displacementSample=textureSampleLevel(displacementTexture,displacementTextureSampler,input_uv,mipLevel).r; let scaledDisplacement=(displacementSample - 0.5) * displacementScale; let displacedPosition=input_position + input_vertexNormal * scaledDisplacement; return displacedPosition;\n}\nfn calcDisplacementNormal( input_vertexNormal:vec3, displacementTexture:texture_2d, displacementTextureSampler:sampler, displacementScale:f32, input_uv:vec2, mipLevel:f32\n) -> vec3 { let textureDimensions=vec2(textureDimensions(displacementTexture,0)); let adaptiveOffset=vec2(1.0)/textureDimensions; let actualMipLevel=mipLevel; let center=textureSampleLevel(displacementTexture,displacementTextureSampler,input_uv,actualMipLevel).r; let left=textureSampleLevel(displacementTexture,displacementTextureSampler,input_uv - vec2(adaptiveOffset.x,0.0),actualMipLevel).r; let right=textureSampleLevel(displacementTexture,displacementTextureSampler,input_uv + vec2(adaptiveOffset.x,0.0),actualMipLevel).r; let down=textureSampleLevel(displacementTexture,displacementTextureSampler,input_uv - vec2(0.0,adaptiveOffset.y),actualMipLevel).r; let up=textureSampleLevel(displacementTexture,displacementTextureSampler,input_uv + vec2(0.0,adaptiveOffset.y),actualMipLevel).r; let ddx=((right - 0.5) - (left - 0.5)) * displacementScale/(2.0 * adaptiveOffset.x); let ddy=((up - 0.5) - (down - 0.5)) * displacementScale/(2.0 * adaptiveOffset.y); let tangentSpaceNormal=normalize(vec3(-ddx,-ddy,1.0)); let worldNormal=normalize(input_vertexNormal); let normalStrength=clamp(1.0 - mipLevel * 0.1,0.2,1.0); let blendedNormal=normalize(mix(worldNormal,tangentSpaceNormal,normalStrength * 0.3)); return blendedNormal;\n}\n",getBillboardMatrix:"fn getBillboardMatrix(cameraMatrix:mat4x4,modelMatrix:mat4x4) -> mat4x4 { let scaleX=length(vec3(modelMatrix[0].xyz)); let scaleY=length(vec3(modelMatrix[1].xyz)); let scaleZ=length(vec3(modelMatrix[2].xyz)); let scaleMatrix=mat4x4( vec4(scaleX,0.0,0.0,0.0), vec4(0.0,scaleY,0.0,0.0), vec4(0.0,0.0,scaleZ,0.0), vec4(0.0,0.0,0.0,1.0) ); var resultMatrix=cameraMatrix * modelMatrix; resultMatrix[0][0]=1.0;resultMatrix[0][1]=0.0;resultMatrix[0][2]=0.0; resultMatrix[1][0]=0.0;resultMatrix[1][1]=1.0;resultMatrix[1][2]=0.0; resultMatrix[2][0]=0.0;resultMatrix[2][1]=0.0;resultMatrix[2][2]=1.0; return resultMatrix * scaleMatrix;\n}\nfn getBillboardMatrixNoScaleRatio( cameraMatrix:mat4x4,modelMatrix:mat4x4)-> mat4x4{ var resultMatrix=cameraMatrix * modelMatrix; resultMatrix[0][0]=modelMatrix[0][0];resultMatrix[0][1]=0.0;resultMatrix[0][2]=0.0; resultMatrix[1][0]=0.0;resultMatrix[1][1]=modelMatrix[1][1];resultMatrix[1][2]=0.0; resultMatrix[2][0]=0.0;resultMatrix[2][1]=0.0;resultMatrix[2][2]=modelMatrix[2][2]; return resultMatrix;\n}\n",extractScaleAndTranslation:"fn extractScaleAndTranslation(modelMatrix:mat4x4) -> mat4x4 { let scaleX=length(vec3(modelMatrix[0].xyz)); let scaleY=length(vec3(modelMatrix[1].xyz)); let scaleZ=length(vec3(modelMatrix[2].xyz)); let scaleMatrix=mat4x4( vec4(scaleX,0.0,0.0,0.0), vec4(0.0,scaleY,0.0,0.0), vec4(0.0,0.0,scaleZ,0.0), vec4(0.0,0.0,0.0,1.0) ); return mat4x4( scaleMatrix[0], scaleMatrix[1], scaleMatrix[2], modelMatrix[3] );\n}\n",meshVertexBasicUniform:"struct MatrixList{ localMatrix:mat4x4, modelMatrix:mat4x4, prevModelMatrix:mat4x4, normalModelMatrix:mat4x4,\n}\nstruct VertexUniforms { matrixList:MatrixList, pickingId:u32, receiveShadow:f32, combinedOpacity:f32, useDisplacementTexture:u32, displacementScale:f32, disableJitter:u32, uvTransform:vec4,\n};"});Object.freeze(be);const Ke=Object.freeze({SYSTEM_UNIFORM:"struct DirectionalLight { direction:vec3, color:vec3, intensity:f32,\n};\nstruct AmbientLight { color:vec3, intensity:f32\n};\nstruct Camera { cameraMatrix:mat4x4, cameraPosition:vec3, nearClipping:f32, farClipping:f32\n};\nstruct SystemUniform { projectionMatrix:mat4x4, projectionCameraMatrix:mat4x4, noneJitterProjectionMatrix:mat4x4, noneJitterProjectionCameraMatrix:mat4x4, inverseProjectionMatrix:mat4x4, prevNoneJitterProjectionCameraMatrix:mat4x4, resolution:vec2, camera:Camera, time:f32, usePrefilterTexture:u32, isView3D:u32, shadowDepthTextureSize:u32, bias:f32, directionalLightCount:u32, directionalLightProjectionViewMatrix:mat4x4, directionalLightProjectionMatrix:mat4x4, directionalLightViewMatrix:mat4x4, directionalLights:array, ambientLight:AmbientLight,\n};\n@group(0) @binding(0) var systemUniforms:SystemUniform;\n@group(0) @binding(1) var directionalShadowMapSampler:sampler_comparison;\n@group(0) @binding(2) var directionalShadowMap:texture_depth_2d;\n@group(0) @binding(3) var prefilterTextureSampler:sampler;\n@group(0) @binding(7) var renderPath1ResultTextureSampler:sampler;\n@group(0) @binding(8) var renderPath1ResultTexture:texture_2d;\n@group(0) @binding(9) var packedTextureSampler:sampler;\n@group(0) @binding(10) var ibl_environmentTexture:texture_cube;\n@group(0) @binding(11) var ibl_irradianceTexture:texture_cube;\n@group(0) @binding(12) var ibl_brdfLUTTexture:texture_2d;\nconst clusterLight_indicesLength:u32=u32(REDGPU_DEFINE_MAX_LIGHTS_PER_CLUSTERu * REDGPU_DEFINE_TOTAL_TILESu);\nconst clusterLight_tileCount=vec3(REDGPU_DEFINE_TILE_COUNT_Xu,REDGPU_DEFINE_TILE_COUNT_Yu,REDGPU_DEFINE_TILE_COUNT_Zu);\nstruct ClusterLights { offset:u32, count:u32\n};\nstruct ClusterLightsGroup { offset:atomic, lights:array, indices:array\n};\nstruct ClusterLight_ClusterCube { minAABB:vec4, maxAABB:vec4 };\nstruct ClusterLight_Clusters { cubeList:array\n};\nfn linearDepth(depthSample:f32) -> f32 { return systemUniforms.camera.farClipping*systemUniforms.camera.nearClipping/fma(depthSample,systemUniforms.camera.nearClipping-systemUniforms.camera.farClipping,systemUniforms.camera.farClipping);\n}\nfn getClusterLightClusterIndex(fragCoord:vec4) -> u32 { let tile=getClusterLightTile(fragCoord); return tile.x + tile.y * clusterLight_tileCount.x + tile.z * clusterLight_tileCount.x * clusterLight_tileCount.y;\n}\nfn getClusterLightTile(fragCoord:vec4) -> vec3 { let sliceScale=f32(clusterLight_tileCount.z)/log2(systemUniforms.camera.farClipping/systemUniforms.camera.nearClipping); let sliceBias=-(f32(clusterLight_tileCount.z) * log2(systemUniforms.camera.nearClipping)/log2(systemUniforms.camera.farClipping/systemUniforms.camera.nearClipping)); let zTile=u32(max(log2(linearDepth(fragCoord.z)) * sliceScale + sliceBias,0.0)); return vec3(u32(fragCoord.x/(systemUniforms.resolution.x/f32(clusterLight_tileCount.x))), u32(fragCoord.y/(systemUniforms.resolution.y/f32(clusterLight_tileCount.y))), zTile);\n}\nstruct ClusterLight { position:vec3,radius:f32, color:vec3,intensity:f32, isSpotLight:f32,directionX:f32,directionY:f32,directionZ:f32, outerCutoff:f32,innerCutoff:f32,\n};\nstruct ClusterLightList { count:vec4, lights:array\n};\n@group(0) @binding(5) var clusterLightList:ClusterLightList;\n@group(0) @binding(6) var clusterLightGroup:ClusterLightsGroup;\n",...be,...W});Object.freeze(Ke);class ShaderVariantGenerator{#Ee=new Map;#De;#Ue;#Le=[];#Ae=[];#Ge=new Map;#ke=new Map;constructor(i,g){this.#De=i,this.#Ue=g}setBaseInfo(i,g){this.#Le=i,this.#Ae=g}addConditionalInfo(i,g,x){this.#Ge.set(i,g),this.#ke.set(i,x)}getVariantTextures(i){const g="none"===i?[]:i.split("+"),x=[...this.#Le];return g.forEach(i=>{const g=this.#Ge.get(i);g&&g.forEach(i=>{x.find(g=>g.name===i.name)||x.push(i)})}),x}getVariantSamplers(i){const g="none"===i?[]:i.split("+"),x=[...this.#Ae];return g.forEach(i=>{const g=this.#ke.get(i);g&&g.forEach(i=>{x.find(g=>g.name===i.name)||x.push(i)})}),x}getUnionTextures(){const i=[...this.#Le];return this.#Ge.forEach(g=>{g.forEach(g=>{i.find(i=>i.name===g.name)||i.push(g)})}),i}getUnionSamplers(){const i=[...this.#Ae];return this.#ke.forEach(g=>{g.forEach(g=>{i.find(i=>i.name===g.name)||i.push(g)})}),i}getVariant(i){if(this.#Ee.has(i))return this.#Ee.get(i);const g="none"===i?[]:i.split("+"),x=this.#Oe(g);return this.#Ee.set(i,x),x}getCachedVariants(){return Array.from(this.#Ee.keys())}#Oe(i){let g=this.#De;for(let x=this.#Ue.length-1;x>=0;x--){const _=this.#Ue[x];g=i.includes(_.uniformName)?g.replace(_.fullMatch,_.ifBlock):g.replace(_.fullMatch,_.elseBlock||"")}return g}}const Xe=Object.keys(Ke).join("|"),je=new RegExp(`#redgpu_include (${Xe})`,"g"),Ye=/REDGPU_DEFINE_(?:TILE_COUNT_[XYZ]|TOTAL_TILES|WORKGROUP_SIZE_[XYZ]|MAX_LIGHTS_PER_CLUSTER)/g,Ze={REDGPU_DEFINE_TILE_COUNT_X:q.TILE_COUNT_X.toString(),REDGPU_DEFINE_TILE_COUNT_Y:q.TILE_COUNT_Y.toString(),REDGPU_DEFINE_TILE_COUNT_Z:q.TILE_COUNT_Z.toString(),REDGPU_DEFINE_TOTAL_TILES:q.getTotalTileSize().toString(),REDGPU_DEFINE_WORKGROUP_SIZE_X:q.WORKGROUP_SIZE_X.toString(),REDGPU_DEFINE_WORKGROUP_SIZE_Y:q.WORKGROUP_SIZE_Y.toString(),REDGPU_DEFINE_WORKGROUP_SIZE_Z:q.WORKGROUP_SIZE_Z.toString(),REDGPU_DEFINE_MAX_LIGHTS_PER_CLUSTER:q.MAX_LIGHTS_PER_CLUSTER.toString()},Je=new Map,preprocessWGSL=i=>{const g=(i=>{let g=0;for(let x=0;x{let g=i,x=0;for(;x<10;){const i=g;if(g=g.replace(je,(i,g)=>Ke[g]||i),g===i)break;x++}return g})(i),v=(i=>i.replace(Ye,i=>Ze[i]||i))(_),b=(i=>{const g=[],x=/#redgpu_if\s+(\w+)\b|#redgpu_else|#redgpu_endIf/g,_=[];let v,b=0;for(;null!==(v=x.exec(i));){const x=v[0];if(x.startsWith("#redgpu_if"))_.push({uniformName:v[1],startIndex:v.index,headerLength:x.length});else if("#redgpu_else"===x){const i=_[_.length-1];if(!i)throw new Error(`[preprocessWGSL] Mismatched #redgpu_else at index ${v.index}`);void 0===i.elseIndex&&(i.elseIndex=v.index)}else if("#redgpu_endIf"===x){const y=_.pop();if(!y)throw new Error(`[preprocessWGSL] Mismatched #redgpu_endIf at index ${v.index}`);{const _=i.substring(y.startIndex,v.index+x.length);let S,w;void 0!==y.elseIndex?(S=i.substring(y.startIndex+y.headerLength,y.elseIndex),w=i.substring(y.elseIndex+12,v.index)):S=i.substring(y.startIndex+y.headerLength,v.index),g.push({uniformName:y.uniformName,ifBlock:S.trim(),elseBlock:w?.trim(),fullMatch:_,blockIndex:b++})}}}if(_.length>0)throw new Error(`[preprocessWGSL] Unclosed #redgpu_if for:${_.map(i=>i.uniformName).join(",")}`);return g})(v);(i=>{if(!i.length)return;const g=new Map;i.forEach(i=>{g.set(i.uniformName,(g.get(i.uniformName)||0)+1)}),Array.from(g.entries()).filter(([i,g])=>g>1).length})(b);const y=[...new Set(b.map(i=>i.uniformName))],S=new ShaderVariantGenerator(v,b),w={cacheKey:g,defaultSource:S.getVariant("none"),shaderSourceVariant:S,conditionalBlocks:y,conditionalBlockInfos:b};return Math.pow(2,y.length),Je.set(g,w),w};class ResourceStatusInfo{table=new Map;videoMemory=0;constructor(){}}var Qe;Object.freeze(ResourceStatusInfo),function(i){i.GPUShaderModule="GPUShaderModule",i.GPUBindGroupLayout="GPUBindGroupLayout",i.GPUPipelineLayout="GPUPipelineLayout",i.GPUBuffer="GPUBuffer"}(Qe||(Qe={}));class ResourceManager{static PRESET_GPUBindGroupLayout_System="PRESET_GPUBindGroupLayout_System";static PRESET_VERTEX_GPUBindGroupLayout_Instancing="PRESET_VERTEX_GPUBindGroupLayout_Instancing";static PRESET_VERTEX_GPUBindGroupLayout="PRESET_VERTEX_GPUBindGroupLayout";static PRESET_VERTEX_GPUBindGroupLayout_SKIN="PRESET_VERTEX_GPUBindGroupLayout_SKIN";#Ne=0;#Ve=new ImmutableKeyMap([[Qe.GPUShaderModule,new Map],[Qe.GPUBindGroupLayout,new Map],[Qe.GPUPipelineLayout,new Map],[Qe.GPUBuffer,new MemoryTrackingMap]]);#Fe=new ResourceStatusInfo;#He=new ResourceStatusInfo;#ze=new ResourceStatusInfo;#$e=new ResourceStatusInfo;#Ke=new ResourceStatusInfo;#Xe=new ResourceStatusInfo;#je=new ResourceStatusInfo;#Ye={};#qe;#We;#Ze;#Je;#Qe;#et;#tt;#nt;#rt;#it=new WeakMap;#at=new WeakMap;#l;#c;constructor(i){this.#l=i,this.#c=i.gpuDevice,this.#Ze=new MipmapGenerator(i),this.#Je=new DownSampleCubeMapGenerator(i),this.#Qe=new BRDFGenerator(i),this.#et=new IrradianceGenerator(i),this.#tt=new PrefilterGenerator(i),this.#nt=new EquirectangularToCubeGenerator(i),this.#st()}get redGPUContext(){return this.#l}get gpuDevice(){return this.#c}get basicSampler(){return this.#rt}get brdfGenerator(){return this.#Qe}get irradianceGenerator(){return this.#et}get prefilterGenerator(){return this.#tt}get equirectangularToCubeGenerator(){return this.#nt}get mipmapGenerator(){return this.#Ze}get downSampleCubeMapGenerator(){return this.#Je}get cachedBufferState(){return this.#Ye}get emptyBitmapTextureView(){return this.#qe}get emptyCubeTextureView(){return this.#We}get managedBitmapTextureState(){return this.#Fe}get managedCubeTextureState(){return this.#He}get managedHDRTextureState(){return this.#ze}get managedUniformBufferState(){return this.#$e}get managedVertexBufferState(){return this.#Ke}get managedIndexBufferState(){return this.#Xe}get managedStorageBufferState(){return this.#je}get resources(){return this.#Ve}registerManagementResource(i,x){const{cacheKey:_,targetResourceManagedState:v}=i,{table:b}=v;b.get(_)?g(`Resource with cacheKey ${_} is already registered.`):(b.set(_,x),v.videoMemory+=i.videoMemorySize)}unregisterManagementResource(i){const{cacheKey:g,targetResourceManagedState:x}=i,{table:_}=x;_.get(g)&&(x.videoMemory-=i.videoMemorySize,_.delete(g))}createManagedTexture(i){const g=this.gpuDevice.createTexture(i),x=g.destroy.bind(g);return g.destroy=()=>{this.#ot(g,i),x()},g}getGPUResourceBitmapTextureView(i,g){const x=i instanceof GPUTexture?i:i?.gpuTexture;if(!x)return this.#qe;let _=this.#it.get(x);_||(_=new Map,this.#it.set(x,_));const v=this.#ut(g);let b=_.get(v);if(!b){const i=g?{...g,label:g.label||x.label}:{label:x.label};b=x.createView(i),_.set(v,b)}return b}getGPUResourceCubeTextureView(i,g){const x=i instanceof GPUTexture?i:i?.gpuTexture;if(!x)return this.#We;let _=this.#at.get(x);_||(_=new Map,this.#at.set(x,_)),i instanceof GPUTexture||g||(g=i.viewDescriptor);const v=g||CubeTexture.defaultViewDescriptor,b=this.#ut(v);let y=_.get(b);if(!y){const i={...v,label:x.label};y=x.createView(i),_.set(b,y)}return y}createGPUShaderModule(i,g){return this.#lt(i,g,g=>this.#ct(i,g),Qe.GPUShaderModule)}getGPUShaderModule(i){return this.#ht(i,Qe.GPUShaderModule)}deleteGPUShaderModule(i){this.#ft(i,Qe.GPUShaderModule)}createBindGroupLayout(i,g){return this.#lt(i,g,g=>(g.label||(g.label=i),this.redGPUContext.gpuDevice.createBindGroupLayout(g)),Qe.GPUBindGroupLayout)}getGPUBindGroupLayout(i){return this.#ht(i,Qe.GPUBindGroupLayout)}deleteGPUBindGroupLayout(i){this.#ft(i,Qe.GPUBindGroupLayout)}createGPUPipelineLayout(i,g){return this.#lt(i,g,g=>(g.label||(g.label=i),this.redGPUContext.gpuDevice.createPipelineLayout(g)),Qe.GPUPipelineLayout)}createGPUBuffer(i,g){return this.#lt(i,g,g=>(g.label||(g.label=i),this.gpuDevice.createBuffer(g)),Qe.GPUBuffer)}#ot(i,g){const x="3d"===g.dimension?this.#at:this.#it;x.get(i)?.clear(),x.delete(i)}#ut(i){return i?JSON.stringify(i):"default"}#st(){const{gpuDevice:i}=this.redGPUContext;{const g=i.createTexture({size:{width:1,height:1,depthOrArrayLayers:1},format:"rgba8unorm",usage:GPUTextureUsage.TEXTURE_BINDING|GPUTextureUsage.COPY_DST|GPUTextureUsage.STORAGE_BINDING,label:"EMPTY_BITMAP_TEXTURE"});this.#qe=g.createView({label:g.label});const x=new Uint8Array([0,0,0,0]);i.queue.writeTexture({texture:g},x,{bytesPerRow:4,rowsPerImage:1},{width:1,height:1,depthOrArrayLayers:1});const _=i.createTexture({size:{width:1,height:1,depthOrArrayLayers:6},format:"rgba8unorm",usage:GPUTextureUsage.RENDER_ATTACHMENT|GPUTextureUsage.TEXTURE_BINDING|GPUTextureUsage.COPY_DST,label:"EMPTY_CUBE_TEXTURE"});this.#We=_.createView(CubeTexture.defaultViewDescriptor);const v=new Uint8Array([0,0,0,0]);for(let g=0;g<6;g++)i.queue.writeTexture({texture:_,origin:{x:0,y:0,z:g}},v,{bytesPerRow:4,rowsPerImage:1},{width:1,height:1,depthOrArrayLayers:1});this.#rt=new Sampler(this.redGPUContext)}this.createBindGroupLayout(ResourceManager.PRESET_GPUBindGroupLayout_System,{entries:[{binding:0,visibility:GPUShaderStage.VERTEX|GPUShaderStage.FRAGMENT|GPUShaderStage.COMPUTE,buffer:{type:"uniform"}},{binding:1,visibility:GPUShaderStage.VERTEX|GPUShaderStage.FRAGMENT,sampler:{type:"comparison"}},{binding:2,visibility:GPUShaderStage.FRAGMENT,texture:{sampleType:"depth"}},{binding:3,visibility:GPUShaderStage.FRAGMENT,sampler:{type:"filtering"}},{binding:5,visibility:GPUShaderStage.FRAGMENT|GPUShaderStage.COMPUTE,buffer:{type:"read-only-storage"}},{binding:6,visibility:GPUShaderStage.FRAGMENT|GPUShaderStage.COMPUTE,buffer:{type:"storage"}},{binding:7,visibility:GPUShaderStage.FRAGMENT,sampler:{type:"filtering"}},{binding:8,visibility:GPUShaderStage.FRAGMENT,texture:{}},{binding:9,visibility:GPUShaderStage.FRAGMENT,sampler:{type:"filtering"}},{binding:10,visibility:GPUShaderStage.FRAGMENT,texture:{viewDimension:"cube"}},{binding:11,visibility:GPUShaderStage.FRAGMENT,texture:{viewDimension:"cube"}},{binding:12,visibility:GPUShaderStage.FRAGMENT,texture:{}}]}),this.createBindGroupLayout(ResourceManager.PRESET_VERTEX_GPUBindGroupLayout,{entries:[{binding:0,visibility:GPUShaderStage.VERTEX,buffer:{type:"uniform"}},{binding:1,visibility:GPUShaderStage.VERTEX,sampler:{type:"filtering"}},{binding:2,visibility:GPUShaderStage.VERTEX,texture:{}}]}),this.createBindGroupLayout(ResourceManager.PRESET_VERTEX_GPUBindGroupLayout_SKIN,{entries:[{binding:0,visibility:GPUShaderStage.VERTEX,buffer:{type:"uniform"}},{binding:1,visibility:GPUShaderStage.VERTEX,sampler:{type:"filtering"}},{binding:2,visibility:GPUShaderStage.VERTEX,texture:{}},{binding:3,visibility:GPUShaderStage.VERTEX,buffer:{type:"read-only-storage"}},{binding:4,visibility:GPUShaderStage.VERTEX,buffer:{type:"read-only-storage"}}]}),this.createBindGroupLayout(ResourceManager.PRESET_VERTEX_GPUBindGroupLayout_Instancing,{entries:[{binding:0,visibility:GPUShaderStage.VERTEX,buffer:{type:"read-only-storage"}},{binding:1,visibility:GPUShaderStage.VERTEX,sampler:{type:"filtering"}},{binding:2,visibility:GPUShaderStage.VERTEX,texture:{}},{binding:3,visibility:GPUShaderStage.VERTEX,buffer:{type:"read-only-storage"}}]})}#dt(i){return this.#Ve.get(i)}#ct(i,g){const{code:x}=g,_=preprocessWGSL(x).defaultSource,v=this.redGPUContext.gpuDevice.createShaderModule({...g,code:_});return this.#dt(Qe.GPUShaderModule).set(i,v),v}#mt(i,g){if(!i)throw new Error("Name is required");return this.#dt(g)}#lt(i,g,x,_){const v=this.#mt(i,_);if(v.has(i))return v.get(i);g.label||(g.label=i);const b=x(g);return v.set(i,b),b}#ht(i,g){return this.#mt(i,g).get(i)}#ft(i,g){const x=this.#mt(i,g);if(!x.has(i))throw new Error(`${g} with name ${i} doesn't exist.`);x.delete(i)}}Object.freeze(BitmapTexture);class ImmutableKeyMap extends Map{constructor(i=[]){super(),i?.forEach(([i,g])=>super.set(i,g))}set(i,g){if(this.has(i))throw new Error("Cannot change the value of an existing key");return super.set(i,g)}}class MemoryTrackingMap extends Map{#pt=0;constructor(){super()}get videoMemory(){return this.#pt}set(i,g){const x=g&&"videoMemorySize"in g?"videoMemorySize":g&&"size"in g?"size":void 0;if(this.has(i)){const g=this.get(i);g&&g[x]&&(this.#pt-=g[x])}g&&g&&(this.#pt+=g[x]);return super.set(i,g)}delete(i){if(this.has(i)){const g=this.get(i),x=g&&"videoMemorySize"in g?"videoMemorySize":g&&"size"in g?"size":void 0;g&&g[x]&&(this.#pt-=g[x])}return super.delete(i)}clear(){this.#pt=0,super.clear()}}class AntialiasingManager{#l;#gt;#xt=!0;#_t=!1;#vt=!1;#bt=!0;constructor(i){this.#l=i,window.devicePixelRatio>1?this.useTAA=!0:this.useMSAA=!0}get useTAA(){return this.#vt}set useTAA(i){this.#vt!==i&&(this.#yt(),this.#vt=i)}get useMSAA(){return this.#xt}set useMSAA(i){this.#xt!==i&&(this.#yt(),this.#gt=createUUID(),this.#xt=i,this.#bt=!0)}get useFXAA(){return this.#_t}set useFXAA(i){this.#_t!==i&&(this.#yt(),this.#_t=i)}get changedMSAA(){return this.#bt}set changedMSAA(i){this.#bt=i}get msaaID(){return this.#gt}#yt(){this.#xt=!1,this.#_t=!1,this.#vt=!1}}Object.freeze(AntialiasingManager);class RedGPUContextDetector{#St;#Tt;#Mt;#wt;#Ct;constructor(i){this.#ne(i.gpuAdapter)}get adapterInfo(){return this.#St}get limits(){return this.#Tt}get isFallbackAdapter(){return this.#Mt}get groupedLimits(){return this.#wt}get userAgent(){return this.#Ct}get isMobile(){return/Android|webOS|iPhone|iPad|iPod|BlackBerry|IEMobile|Opera Mini|Windows Phone|Kindle|Silk|PlayBook/i.test(navigator.userAgent)}#ne(i){this.#Ct=navigator.userAgent,this.#Rt(i),this.#Pt()}#Rt(i){if(i){const{limits:g,info:x}=i,{isFallbackAdapter:_}=x;this.#St=x,this.#Mt=_,this.#Tt=g}}#Pt(){const i={TextureLimits:["maxTextureDimension1D","maxTextureDimension2D","maxTextureDimension3D","maxTextureArrayLayers","maxSampledTexturesPerShaderStage","maxSamplersPerShaderStage"],BufferLimits:["maxBindGroups","maxBindGroupsPlusVertexBuffers","maxBindingsPerBindGroup","maxDynamicUniformBuffersPerPipelineLayout","maxDynamicStorageBuffersPerPipelineLayout","maxStorageBuffersPerShaderStage","maxStorageTexturesPerShaderStage","maxUniformBuffersPerShaderStage","maxUniformBufferBindingSize","maxStorageBufferBindingSize","minUniformBufferOffsetAlignment","minStorageBufferOffsetAlignment","maxBufferSize"],PipelineAndShaderLimits:["maxVertexBuffers","maxVertexAttributes","maxVertexBufferArrayStride","maxInterStageShaderComponents","maxInterStageShaderVariables"],ComputeLimits:["maxComputeWorkgroupStorageSize","maxComputeInvocationsPerWorkgroup","maxComputeWorkgroupSizeX","maxComputeWorkgroupSizeY","maxComputeWorkgroupSizeZ","maxComputeWorkgroupsPerDimension"],ColorLimits:["maxColorAttachments","maxColorAttachmentBytesPerSample"]},g={TextureLimits:{},BufferLimits:{},PipelineAndShaderLimits:{},ComputeLimits:{},ColorLimits:{},EtcLimit:{}};for(const x in this.#Tt){let _=!1;for(const v in i)if(i[v].includes(x)){g[v][x]=this.#Tt[x],_=!0;break}_||(g.EtcLimit[x]=this.#Tt[x])}this.#wt=g}}const validateNumber=i=>"number"==typeof i||(consoleAndThrowError("Only numbers allowed."),!1);class RedGPUContextSizeManager{#Bt;#It;#l;#Et=[0,0,0,0];#Dt;#Ut=1;constructor(i,g="100%",x="100%"){this.#l=i,this.#Dt=i.htmlCanvas,this.#Dt.style.boxSizing="border-box",this.#Bt=g,this.#It=x}get renderScale(){return this.#Ut}set renderScale(i){validateNumber(i),i<=0&&(i=.01),this.#Ut=i,this.setSize()}get width(){return this.#Bt}set width(i){this.setSize(i,this.#It)}get height(){return this.#It}set height(i){this.setSize(this.#Bt,i)}get pixelRectArray(){return this.#Et}get pixelRectObject(){return{x:this.#Et[0],y:this.#Et[1],width:this.#Et[2],height:this.#Et[3]}}get parentDomRect(){return(this.#Dt.parentNode||document.body).getBoundingClientRect()}get screenRectObject(){return{x:this.#Et[0]/devicePixelRatio,y:this.#Et[1]/devicePixelRatio,width:this.#Et[2]/devicePixelRatio,height:this.#Et[3]/devicePixelRatio}}static validateSizeValue=i=>{switch(typeof i){case"number":validatePositiveNumberRange(i);break;case"string":new RegExp(/^[+]?^[.]?(\d+)(\.\d+)?(?:px|%|$)/gm).test(i)||consoleAndThrowError(`allow positive number,%,px model/input:${i}`);break;default:consoleAndThrowError(`positive number,%,px model/input:${i}`)}};static validatePositionValue=i=>{switch(typeof i){case"number":validateNumber(i);break;case"string":new RegExp(/^-?\d+(\.\d+)?(px|%)?$/).test(i)||consoleAndThrowError(`allow number,%,px model /input:${i}`);break;default:consoleAndThrowError(`number,%,px model/input:${i}`)}};static getPixelDimension(i,g,x){return"number"==typeof x?x:RedGPUContextSizeManager.calculateSizeFromString(i,g,x)}static calculateSizeFromString(i,g,x){return x.includes("%")?Math.floor(i[g]*+x.replace("%","")/100):+x.replace("px","")}setSize(i=this.#Bt,g=this.#It){RedGPUContextSizeManager.validateSizeValue(i),RedGPUContextSizeManager.validateSizeValue(g),this.#Bt=i,this.#It=g;const x=RedGPUContextSizeManager.getPixelDimension(this.parentDomRect,"width",i),_=RedGPUContextSizeManager.getPixelDimension(this.parentDomRect,"height",g);this.#Lt(x,_),this.#At(x,_),this.#Gt()}#At(i,g){this.#Et[2]=Math.max(1,Math.floor(i*this.#Ut*window.devicePixelRatio)),this.#Et[3]=Math.max(1,Math.floor(g*this.#Ut*window.devicePixelRatio))}#Gt(){this.#l.onResize&&this.#l.onResize({target:this.#l,screenRectObject:this.screenRectObject,pixelRectObject:this.pixelRectObject}),this.#l.viewList.forEach(i=>{i.setSize(),i.setPosition()})}#Lt(i,g){const x=this.#Dt,{style:_}=x;x.width=Math.max(1,i*this.#Ut*window.devicePixelRatio),x.height=Math.max(1,g*this.#Ut*window.devicePixelRatio),_.width=`${i}px`,_.height=`${g}px`}}var et=1e-6,tt="undefined"!=typeof Float32Array?Float32Array:Array,it=Math.random;function round$3(i){return i>=0?Math.round(i):i%.5==0?Math.floor(i):Math.round(i)}function create$5(){var i=new tt(9);return tt!=Float32Array&&(i[1]=0,i[2]=0,i[3]=0,i[5]=0,i[6]=0,i[7]=0),i[0]=1,i[4]=1,i[8]=1,i}function multiply$5(i,g,x){var _=g[0],v=g[1],b=g[2],y=g[3],S=g[4],w=g[5],L=g[6],k=g[7],H=g[8],z=x[0],q=x[1],W=x[2],be=x[3],Ke=x[4],Xe=x[5],je=x[6],Ye=x[7],Ze=x[8];return i[0]=z*_+q*y+W*L,i[1]=z*v+q*S+W*k,i[2]=z*b+q*w+W*H,i[3]=be*_+Ke*y+Xe*L,i[4]=be*v+Ke*S+Xe*k,i[5]=be*b+Ke*w+Xe*H,i[6]=je*_+Ye*y+Ze*L,i[7]=je*v+Ye*S+Ze*k,i[8]=je*b+Ye*w+Ze*H,i}function subtract$4(i,g,x){return i[0]=g[0]-x[0],i[1]=g[1]-x[1],i[2]=g[2]-x[2],i[3]=g[3]-x[3],i[4]=g[4]-x[4],i[5]=g[5]-x[5],i[6]=g[6]-x[6],i[7]=g[7]-x[7],i[8]=g[8]-x[8],i}var ft=multiply$5,pt=subtract$4,xt=Object.freeze({__proto__:null,add:function(i,g,x){return i[0]=g[0]+x[0],i[1]=g[1]+x[1],i[2]=g[2]+x[2],i[3]=g[3]+x[3],i[4]=g[4]+x[4],i[5]=g[5]+x[5],i[6]=g[6]+x[6],i[7]=g[7]+x[7],i[8]=g[8]+x[8],i},adjoint:function(i,g){var x=g[0],_=g[1],v=g[2],b=g[3],y=g[4],S=g[5],w=g[6],L=g[7],k=g[8];return i[0]=y*k-S*L,i[1]=v*L-_*k,i[2]=_*S-v*y,i[3]=S*w-b*k,i[4]=x*k-v*w,i[5]=v*b-x*S,i[6]=b*L-y*w,i[7]=_*w-x*L,i[8]=x*y-_*b,i},clone:function(i){var g=new tt(9);return g[0]=i[0],g[1]=i[1],g[2]=i[2],g[3]=i[3],g[4]=i[4],g[5]=i[5],g[6]=i[6],g[7]=i[7],g[8]=i[8],g},copy:function(i,g){return i[0]=g[0],i[1]=g[1],i[2]=g[2],i[3]=g[3],i[4]=g[4],i[5]=g[5],i[6]=g[6],i[7]=g[7],i[8]=g[8],i},create:create$5,determinant:function(i){var g=i[0],x=i[1],_=i[2],v=i[3],b=i[4],y=i[5],S=i[6],w=i[7],L=i[8];return g*(L*b-y*w)+x*(-L*v+y*S)+_*(w*v-b*S)},equals:function(i,g){var x=i[0],_=i[1],v=i[2],b=i[3],y=i[4],S=i[5],w=i[6],L=i[7],k=i[8],H=g[0],z=g[1],q=g[2],W=g[3],be=g[4],Ke=g[5],Xe=g[6],je=g[7],Ye=g[8];return Math.abs(x-H)<=et*Math.max(1,Math.abs(x),Math.abs(H))&&Math.abs(_-z)<=et*Math.max(1,Math.abs(_),Math.abs(z))&&Math.abs(v-q)<=et*Math.max(1,Math.abs(v),Math.abs(q))&&Math.abs(b-W)<=et*Math.max(1,Math.abs(b),Math.abs(W))&&Math.abs(y-be)<=et*Math.max(1,Math.abs(y),Math.abs(be))&&Math.abs(S-Ke)<=et*Math.max(1,Math.abs(S),Math.abs(Ke))&&Math.abs(w-Xe)<=et*Math.max(1,Math.abs(w),Math.abs(Xe))&&Math.abs(L-je)<=et*Math.max(1,Math.abs(L),Math.abs(je))&&Math.abs(k-Ye)<=et*Math.max(1,Math.abs(k),Math.abs(Ye))},exactEquals:function(i,g){return i[0]===g[0]&&i[1]===g[1]&&i[2]===g[2]&&i[3]===g[3]&&i[4]===g[4]&&i[5]===g[5]&&i[6]===g[6]&&i[7]===g[7]&&i[8]===g[8]},frob:function(i){return Math.sqrt(i[0]*i[0]+i[1]*i[1]+i[2]*i[2]+i[3]*i[3]+i[4]*i[4]+i[5]*i[5]+i[6]*i[6]+i[7]*i[7]+i[8]*i[8])},fromMat2d:function(i,g){return i[0]=g[0],i[1]=g[1],i[2]=0,i[3]=g[2],i[4]=g[3],i[5]=0,i[6]=g[4],i[7]=g[5],i[8]=1,i},fromMat4:function(i,g){return i[0]=g[0],i[1]=g[1],i[2]=g[2],i[3]=g[4],i[4]=g[5],i[5]=g[6],i[6]=g[8],i[7]=g[9],i[8]=g[10],i},fromQuat:function(i,g){var x=g[0],_=g[1],v=g[2],b=g[3],y=x+x,S=_+_,w=v+v,L=x*y,k=_*y,H=_*S,z=v*y,q=v*S,W=v*w,be=b*y,Ke=b*S,Xe=b*w;return i[0]=1-H-W,i[3]=k-Xe,i[6]=z+Ke,i[1]=k+Xe,i[4]=1-L-W,i[7]=q-be,i[2]=z-Ke,i[5]=q+be,i[8]=1-L-H,i},fromRotation:function(i,g){var x=Math.sin(g),_=Math.cos(g);return i[0]=_,i[1]=x,i[2]=0,i[3]=-x,i[4]=_,i[5]=0,i[6]=0,i[7]=0,i[8]=1,i},fromScaling:function(i,g){return i[0]=g[0],i[1]=0,i[2]=0,i[3]=0,i[4]=g[1],i[5]=0,i[6]=0,i[7]=0,i[8]=1,i},fromTranslation:function(i,g){return i[0]=1,i[1]=0,i[2]=0,i[3]=0,i[4]=1,i[5]=0,i[6]=g[0],i[7]=g[1],i[8]=1,i},fromValues:function(i,g,x,_,v,b,y,S,w){var L=new tt(9);return L[0]=i,L[1]=g,L[2]=x,L[3]=_,L[4]=v,L[5]=b,L[6]=y,L[7]=S,L[8]=w,L},identity:function(i){return i[0]=1,i[1]=0,i[2]=0,i[3]=0,i[4]=1,i[5]=0,i[6]=0,i[7]=0,i[8]=1,i},invert:function(i,g){var x=g[0],_=g[1],v=g[2],b=g[3],y=g[4],S=g[5],w=g[6],L=g[7],k=g[8],H=k*y-S*L,z=-k*b+S*w,q=L*b-y*w,W=x*H+_*z+v*q;return W?(W=1/W,i[0]=H*W,i[1]=(-k*_+v*L)*W,i[2]=(S*_-v*y)*W,i[3]=z*W,i[4]=(k*x-v*w)*W,i[5]=(-S*x+v*b)*W,i[6]=q*W,i[7]=(-L*x+_*w)*W,i[8]=(y*x-_*b)*W,i):null},mul:ft,multiply:multiply$5,multiplyScalar:function(i,g,x){return i[0]=g[0]*x,i[1]=g[1]*x,i[2]=g[2]*x,i[3]=g[3]*x,i[4]=g[4]*x,i[5]=g[5]*x,i[6]=g[6]*x,i[7]=g[7]*x,i[8]=g[8]*x,i},multiplyScalarAndAdd:function(i,g,x,_){return i[0]=g[0]+x[0]*_,i[1]=g[1]+x[1]*_,i[2]=g[2]+x[2]*_,i[3]=g[3]+x[3]*_,i[4]=g[4]+x[4]*_,i[5]=g[5]+x[5]*_,i[6]=g[6]+x[6]*_,i[7]=g[7]+x[7]*_,i[8]=g[8]+x[8]*_,i},normalFromMat4:function(i,g){var x=g[0],_=g[1],v=g[2],b=g[3],y=g[4],S=g[5],w=g[6],L=g[7],k=g[8],H=g[9],z=g[10],q=g[11],W=g[12],be=g[13],Ke=g[14],Xe=g[15],je=x*S-_*y,Ye=x*w-v*y,Ze=x*L-b*y,Je=_*w-v*S,Qe=_*L-b*S,et=v*L-b*w,tt=k*be-H*W,it=k*Ke-z*W,ft=k*Xe-q*W,pt=H*Ke-z*be,xt=H*Xe-q*be,vt=z*Xe-q*Ke,bt=je*vt-Ye*xt+Ze*pt+Je*ft-Qe*it+et*tt;return bt?(bt=1/bt,i[0]=(S*vt-w*xt+L*pt)*bt,i[1]=(w*ft-y*vt-L*it)*bt,i[2]=(y*xt-S*ft+L*tt)*bt,i[3]=(v*xt-_*vt-b*pt)*bt,i[4]=(x*vt-v*ft+b*it)*bt,i[5]=(_*ft-x*xt-b*tt)*bt,i[6]=(be*et-Ke*Qe+Xe*Je)*bt,i[7]=(Ke*Ze-W*et-Xe*Ye)*bt,i[8]=(W*Qe-be*Ze+Xe*je)*bt,i):null},projection:function(i,g,x){return i[0]=2/g,i[1]=0,i[2]=0,i[3]=0,i[4]=-2/x,i[5]=0,i[6]=-1,i[7]=1,i[8]=1,i},rotate:function(i,g,x){var _=g[0],v=g[1],b=g[2],y=g[3],S=g[4],w=g[5],L=g[6],k=g[7],H=g[8],z=Math.sin(x),q=Math.cos(x);return i[0]=q*_+z*y,i[1]=q*v+z*S,i[2]=q*b+z*w,i[3]=q*y-z*_,i[4]=q*S-z*v,i[5]=q*w-z*b,i[6]=L,i[7]=k,i[8]=H,i},scale:function(i,g,x){var _=x[0],v=x[1];return i[0]=_*g[0],i[1]=_*g[1],i[2]=_*g[2],i[3]=v*g[3],i[4]=v*g[4],i[5]=v*g[5],i[6]=g[6],i[7]=g[7],i[8]=g[8],i},set:function(i,g,x,_,v,b,y,S,w,L){return i[0]=g,i[1]=x,i[2]=_,i[3]=v,i[4]=b,i[5]=y,i[6]=S,i[7]=w,i[8]=L,i},str:function(i){return"mat3("+i[0]+","+i[1]+","+i[2]+","+i[3]+","+i[4]+","+i[5]+","+i[6]+","+i[7]+","+i[8]+")"},sub:pt,subtract:subtract$4,translate:function(i,g,x){var _=g[0],v=g[1],b=g[2],y=g[3],S=g[4],w=g[5],L=g[6],k=g[7],H=g[8],z=x[0],q=x[1];return i[0]=_,i[1]=v,i[2]=b,i[3]=y,i[4]=S,i[5]=w,i[6]=z*_+q*y+L,i[7]=z*v+q*S+k,i[8]=z*b+q*w+H,i},transpose:function(i,g){if(i===g){var x=g[1],_=g[2],v=g[5];i[1]=g[3],i[2]=g[6],i[3]=x,i[5]=g[7],i[6]=_,i[7]=v}else i[0]=g[0],i[1]=g[3],i[2]=g[6],i[3]=g[1],i[4]=g[4],i[5]=g[7],i[6]=g[2],i[7]=g[5],i[8]=g[8];return i}});function create$4(){var i=new tt(16);return tt!=Float32Array&&(i[1]=0,i[2]=0,i[3]=0,i[4]=0,i[6]=0,i[7]=0,i[8]=0,i[9]=0,i[11]=0,i[12]=0,i[13]=0,i[14]=0),i[0]=1,i[5]=1,i[10]=1,i[15]=1,i}function clone$4(i){var g=new tt(16);return g[0]=i[0],g[1]=i[1],g[2]=i[2],g[3]=i[3],g[4]=i[4],g[5]=i[5],g[6]=i[6],g[7]=i[7],g[8]=i[8],g[9]=i[9],g[10]=i[10],g[11]=i[11],g[12]=i[12],g[13]=i[13],g[14]=i[14],g[15]=i[15],g}function copy$4(i,g){return i[0]=g[0],i[1]=g[1],i[2]=g[2],i[3]=g[3],i[4]=g[4],i[5]=g[5],i[6]=g[6],i[7]=g[7],i[8]=g[8],i[9]=g[9],i[10]=g[10],i[11]=g[11],i[12]=g[12],i[13]=g[13],i[14]=g[14],i[15]=g[15],i}function fromValues$4(i,g,x,_,v,b,y,S,w,L,k,H,z,q,W,be){var Ke=new tt(16);return Ke[0]=i,Ke[1]=g,Ke[2]=x,Ke[3]=_,Ke[4]=v,Ke[5]=b,Ke[6]=y,Ke[7]=S,Ke[8]=w,Ke[9]=L,Ke[10]=k,Ke[11]=H,Ke[12]=z,Ke[13]=q,Ke[14]=W,Ke[15]=be,Ke}function identity$1(i){return i[0]=1,i[1]=0,i[2]=0,i[3]=0,i[4]=0,i[5]=1,i[6]=0,i[7]=0,i[8]=0,i[9]=0,i[10]=1,i[11]=0,i[12]=0,i[13]=0,i[14]=0,i[15]=1,i}function invert$1(i,g){var x=g[0],_=g[1],v=g[2],b=g[3],y=g[4],S=g[5],w=g[6],L=g[7],k=g[8],H=g[9],z=g[10],q=g[11],W=g[12],be=g[13],Ke=g[14],Xe=g[15],je=x*S-_*y,Ye=x*w-v*y,Ze=x*L-b*y,Je=_*w-v*S,Qe=_*L-b*S,et=v*L-b*w,tt=k*be-H*W,it=k*Ke-z*W,ft=k*Xe-q*W,pt=H*Ke-z*be,xt=H*Xe-q*be,vt=z*Xe-q*Ke,bt=je*vt-Ye*xt+Ze*pt+Je*ft-Qe*it+et*tt;return bt?(bt=1/bt,i[0]=(S*vt-w*xt+L*pt)*bt,i[1]=(v*xt-_*vt-b*pt)*bt,i[2]=(be*et-Ke*Qe+Xe*Je)*bt,i[3]=(z*Qe-H*et-q*Je)*bt,i[4]=(w*ft-y*vt-L*it)*bt,i[5]=(x*vt-v*ft+b*it)*bt,i[6]=(Ke*Ze-W*et-Xe*Ye)*bt,i[7]=(k*et-z*Ze+q*Ye)*bt,i[8]=(y*xt-S*ft+L*tt)*bt,i[9]=(_*ft-x*xt-b*tt)*bt,i[10]=(W*Qe-be*Ze+Xe*je)*bt,i[11]=(H*Ze-k*Qe-q*je)*bt,i[12]=(S*it-y*pt-w*tt)*bt,i[13]=(x*pt-_*it+v*tt)*bt,i[14]=(be*Ye-W*Je-Ke*je)*bt,i[15]=(k*Je-H*Ye+z*je)*bt,i):null}function multiply$4(i,g,x){var _=g[0],v=g[1],b=g[2],y=g[3],S=g[4],w=g[5],L=g[6],k=g[7],H=g[8],z=g[9],q=g[10],W=g[11],be=g[12],Ke=g[13],Xe=g[14],je=g[15],Ye=x[0],Ze=x[1],Je=x[2],Qe=x[3];return i[0]=Ye*_+Ze*S+Je*H+Qe*be,i[1]=Ye*v+Ze*w+Je*z+Qe*Ke,i[2]=Ye*b+Ze*L+Je*q+Qe*Xe,i[3]=Ye*y+Ze*k+Je*W+Qe*je,Ye=x[4],Ze=x[5],Je=x[6],Qe=x[7],i[4]=Ye*_+Ze*S+Je*H+Qe*be,i[5]=Ye*v+Ze*w+Je*z+Qe*Ke,i[6]=Ye*b+Ze*L+Je*q+Qe*Xe,i[7]=Ye*y+Ze*k+Je*W+Qe*je,Ye=x[8],Ze=x[9],Je=x[10],Qe=x[11],i[8]=Ye*_+Ze*S+Je*H+Qe*be,i[9]=Ye*v+Ze*w+Je*z+Qe*Ke,i[10]=Ye*b+Ze*L+Je*q+Qe*Xe,i[11]=Ye*y+Ze*k+Je*W+Qe*je,Ye=x[12],Ze=x[13],Je=x[14],Qe=x[15],i[12]=Ye*_+Ze*S+Je*H+Qe*be,i[13]=Ye*v+Ze*w+Je*z+Qe*Ke,i[14]=Ye*b+Ze*L+Je*q+Qe*Xe,i[15]=Ye*y+Ze*k+Je*W+Qe*je,i}function translate(i,g,x){var _,v,b,y,S,w,L,k,H,z,q,W,be=x[0],Ke=x[1],Xe=x[2];return g===i?(i[12]=g[0]*be+g[4]*Ke+g[8]*Xe+g[12],i[13]=g[1]*be+g[5]*Ke+g[9]*Xe+g[13],i[14]=g[2]*be+g[6]*Ke+g[10]*Xe+g[14],i[15]=g[3]*be+g[7]*Ke+g[11]*Xe+g[15]):(_=g[0],v=g[1],b=g[2],y=g[3],S=g[4],w=g[5],L=g[6],k=g[7],H=g[8],z=g[9],q=g[10],W=g[11],i[0]=_,i[1]=v,i[2]=b,i[3]=y,i[4]=S,i[5]=w,i[6]=L,i[7]=k,i[8]=H,i[9]=z,i[10]=q,i[11]=W,i[12]=_*be+S*Ke+H*Xe+g[12],i[13]=v*be+w*Ke+z*Xe+g[13],i[14]=b*be+L*Ke+q*Xe+g[14],i[15]=y*be+k*Ke+W*Xe+g[15]),i}function scale$4(i,g,x){var _=x[0],v=x[1],b=x[2];return i[0]=g[0]*_,i[1]=g[1]*_,i[2]=g[2]*_,i[3]=g[3]*_,i[4]=g[4]*v,i[5]=g[5]*v,i[6]=g[6]*v,i[7]=g[7]*v,i[8]=g[8]*b,i[9]=g[9]*b,i[10]=g[10]*b,i[11]=g[11]*b,i[12]=g[12],i[13]=g[13],i[14]=g[14],i[15]=g[15],i}function rotateX$2(i,g,x){var _=Math.sin(x),v=Math.cos(x),b=g[4],y=g[5],S=g[6],w=g[7],L=g[8],k=g[9],H=g[10],z=g[11];return g!==i&&(i[0]=g[0],i[1]=g[1],i[2]=g[2],i[3]=g[3],i[12]=g[12],i[13]=g[13],i[14]=g[14],i[15]=g[15]),i[4]=b*v+L*_,i[5]=y*v+k*_,i[6]=S*v+H*_,i[7]=w*v+z*_,i[8]=L*v-b*_,i[9]=k*v-y*_,i[10]=H*v-S*_,i[11]=z*v-w*_,i}function rotateY$2(i,g,x){var _=Math.sin(x),v=Math.cos(x),b=g[0],y=g[1],S=g[2],w=g[3],L=g[8],k=g[9],H=g[10],z=g[11];return g!==i&&(i[4]=g[4],i[5]=g[5],i[6]=g[6],i[7]=g[7],i[12]=g[12],i[13]=g[13],i[14]=g[14],i[15]=g[15]),i[0]=b*v-L*_,i[1]=y*v-k*_,i[2]=S*v-H*_,i[3]=w*v-z*_,i[8]=b*_+L*v,i[9]=y*_+k*v,i[10]=S*_+H*v,i[11]=w*_+z*v,i}function rotateZ$2(i,g,x){var _=Math.sin(x),v=Math.cos(x),b=g[0],y=g[1],S=g[2],w=g[3],L=g[4],k=g[5],H=g[6],z=g[7];return g!==i&&(i[8]=g[8],i[9]=g[9],i[10]=g[10],i[11]=g[11],i[12]=g[12],i[13]=g[13],i[14]=g[14],i[15]=g[15]),i[0]=b*v+L*_,i[1]=y*v+k*_,i[2]=S*v+H*_,i[3]=w*v+z*_,i[4]=L*v-b*_,i[5]=k*v-y*_,i[6]=H*v-S*_,i[7]=z*v-w*_,i}function fromRotationTranslation(i,g,x){var _=g[0],v=g[1],b=g[2],y=g[3],S=_+_,w=v+v,L=b+b,k=_*S,H=_*w,z=_*L,q=v*w,W=v*L,be=b*L,Ke=y*S,Xe=y*w,je=y*L;return i[0]=1-(q+be),i[1]=H+je,i[2]=z-Xe,i[3]=0,i[4]=H-je,i[5]=1-(k+be),i[6]=W+Ke,i[7]=0,i[8]=z+Xe,i[9]=W-Ke,i[10]=1-(k+q),i[11]=0,i[12]=x[0],i[13]=x[1],i[14]=x[2],i[15]=1,i}function getScaling(i,g){var x=g[0],_=g[1],v=g[2],b=g[4],y=g[5],S=g[6],w=g[8],L=g[9],k=g[10];return i[0]=Math.sqrt(x*x+_*_+v*v),i[1]=Math.sqrt(b*b+y*y+S*S),i[2]=Math.sqrt(w*w+L*L+k*k),i}function perspectiveNO(i,g,x,_,v){var b=1/Math.tan(g/2);if(i[0]=b/x,i[1]=0,i[2]=0,i[3]=0,i[4]=0,i[5]=b,i[6]=0,i[7]=0,i[8]=0,i[9]=0,i[11]=-1,i[12]=0,i[13]=0,i[15]=0,null!=v&&v!==1/0){var y=1/(_-v);i[10]=(v+_)*y,i[14]=2*v*_*y}else i[10]=-1,i[14]=-2*_;return i}var vt=perspectiveNO;function orthoNO(i,g,x,_,v,b,y){var S=1/(g-x),w=1/(_-v),L=1/(b-y);return i[0]=-2*S,i[1]=0,i[2]=0,i[3]=0,i[4]=0,i[5]=-2*w,i[6]=0,i[7]=0,i[8]=0,i[9]=0,i[10]=2*L,i[11]=0,i[12]=(g+x)*S,i[13]=(v+_)*w,i[14]=(y+b)*L,i[15]=1,i}var bt=orthoNO;function orthoZO(i,g,x,_,v,b,y){var S=1/(g-x),w=1/(_-v),L=1/(b-y);return i[0]=-2*S,i[1]=0,i[2]=0,i[3]=0,i[4]=0,i[5]=-2*w,i[6]=0,i[7]=0,i[8]=0,i[9]=0,i[10]=L,i[11]=0,i[12]=(g+x)*S,i[13]=(v+_)*w,i[14]=b*L,i[15]=1,i}function lookAt(i,g,x,_){var v,b,y,S,w,L,k,H,z,q,W=g[0],be=g[1],Ke=g[2],Xe=_[0],je=_[1],Ye=_[2],Ze=x[0],Je=x[1],Qe=x[2];return Math.abs(W-Ze)0&&(k*=q=1/Math.sqrt(q),H*=q,z*=q);var W=w*z-L*H,be=L*k-S*z,Ke=S*H-w*k;return(q=W*W+be*be+Ke*Ke)>0&&(W*=q=1/Math.sqrt(q),be*=q,Ke*=q),i[0]=W,i[1]=be,i[2]=Ke,i[3]=0,i[4]=H*Ke-z*be,i[5]=z*W-k*Ke,i[6]=k*be-H*W,i[7]=0,i[8]=k,i[9]=H,i[10]=z,i[11]=0,i[12]=v,i[13]=b,i[14]=y,i[15]=1,i}function subtract$3(i,g,x){return i[0]=g[0]-x[0],i[1]=g[1]-x[1],i[2]=g[2]-x[2],i[3]=g[3]-x[3],i[4]=g[4]-x[4],i[5]=g[5]-x[5],i[6]=g[6]-x[6],i[7]=g[7]-x[7],i[8]=g[8]-x[8],i[9]=g[9]-x[9],i[10]=g[10]-x[10],i[11]=g[11]-x[11],i[12]=g[12]-x[12],i[13]=g[13]-x[13],i[14]=g[14]-x[14],i[15]=g[15]-x[15],i}var yt=multiply$4,St=subtract$3,Tt=Object.freeze({__proto__:null,add:function(i,g,x){return i[0]=g[0]+x[0],i[1]=g[1]+x[1],i[2]=g[2]+x[2],i[3]=g[3]+x[3],i[4]=g[4]+x[4],i[5]=g[5]+x[5],i[6]=g[6]+x[6],i[7]=g[7]+x[7],i[8]=g[8]+x[8],i[9]=g[9]+x[9],i[10]=g[10]+x[10],i[11]=g[11]+x[11],i[12]=g[12]+x[12],i[13]=g[13]+x[13],i[14]=g[14]+x[14],i[15]=g[15]+x[15],i},adjoint:function(i,g){var x=g[0],_=g[1],v=g[2],b=g[3],y=g[4],S=g[5],w=g[6],L=g[7],k=g[8],H=g[9],z=g[10],q=g[11],W=g[12],be=g[13],Ke=g[14],Xe=g[15],je=x*S-_*y,Ye=x*w-v*y,Ze=x*L-b*y,Je=_*w-v*S,Qe=_*L-b*S,et=v*L-b*w,tt=k*be-H*W,it=k*Ke-z*W,ft=k*Xe-q*W,pt=H*Ke-z*be,xt=H*Xe-q*be,vt=z*Xe-q*Ke;return i[0]=S*vt-w*xt+L*pt,i[1]=v*xt-_*vt-b*pt,i[2]=be*et-Ke*Qe+Xe*Je,i[3]=z*Qe-H*et-q*Je,i[4]=w*ft-y*vt-L*it,i[5]=x*vt-v*ft+b*it,i[6]=Ke*Ze-W*et-Xe*Ye,i[7]=k*et-z*Ze+q*Ye,i[8]=y*xt-S*ft+L*tt,i[9]=_*ft-x*xt-b*tt,i[10]=W*Qe-be*Ze+Xe*je,i[11]=H*Ze-k*Qe-q*je,i[12]=S*it-y*pt-w*tt,i[13]=x*pt-_*it+v*tt,i[14]=be*Ye-W*Je-Ke*je,i[15]=k*Je-H*Ye+z*je,i},clone:clone$4,copy:copy$4,create:create$4,decompose:function(i,g,x,_){g[0]=_[12],g[1]=_[13],g[2]=_[14];var v=_[0],b=_[1],y=_[2],S=_[4],w=_[5],L=_[6],k=_[8],H=_[9],z=_[10];x[0]=Math.sqrt(v*v+b*b+y*y),x[1]=Math.sqrt(S*S+w*w+L*L),x[2]=Math.sqrt(k*k+H*H+z*z);var q=1/x[0],W=1/x[1],be=1/x[2],Ke=v*q,Xe=b*W,je=y*be,Ye=S*q,Ze=w*W,Je=L*be,Qe=k*q,et=H*W,tt=z*be,it=Ke+Ze+tt,ft=0;return it>0?(ft=2*Math.sqrt(it+1),i[3]=.25*ft,i[0]=(Je-et)/ft,i[1]=(Qe-je)/ft,i[2]=(Xe-Ye)/ft):Ke>Ze&&Ke>tt?(ft=2*Math.sqrt(1+Ke-Ze-tt),i[3]=(Je-et)/ft,i[0]=.25*ft,i[1]=(Xe+Ye)/ft,i[2]=(Qe+je)/ft):Ze>tt?(ft=2*Math.sqrt(1+Ze-Ke-tt),i[3]=(Qe-je)/ft,i[0]=(Xe+Ye)/ft,i[1]=.25*ft,i[2]=(Je+et)/ft):(ft=2*Math.sqrt(1+tt-Ke-Ze),i[3]=(Xe-Ye)/ft,i[0]=(Qe+je)/ft,i[1]=(Je+et)/ft,i[2]=.25*ft),i},determinant:function(i){var g=i[0],x=i[1],_=i[2],v=i[3],b=i[4],y=i[5],S=i[6],w=i[7],L=i[8],k=i[9],H=i[10],z=i[11],q=i[12],W=i[13],be=i[14],Ke=g*y-x*b,Xe=g*S-_*b,je=x*S-_*y,Ye=L*W-k*q,Ze=L*be-H*q,Je=k*be-H*W;return w*(g*Je-x*Ze+_*Ye)-v*(b*Je-y*Ze+S*Ye)+i[15]*(L*je-k*Xe+H*Ke)-z*(q*je-W*Xe+be*Ke)},equals:function(i,g){var x=i[0],_=i[1],v=i[2],b=i[3],y=i[4],S=i[5],w=i[6],L=i[7],k=i[8],H=i[9],z=i[10],q=i[11],W=i[12],be=i[13],Ke=i[14],Xe=i[15],je=g[0],Ye=g[1],Ze=g[2],Je=g[3],Qe=g[4],tt=g[5],it=g[6],ft=g[7],pt=g[8],xt=g[9],vt=g[10],bt=g[11],yt=g[12],St=g[13],Tt=g[14],Mt=g[15];return Math.abs(x-je)<=et*Math.max(1,Math.abs(x),Math.abs(je))&&Math.abs(_-Ye)<=et*Math.max(1,Math.abs(_),Math.abs(Ye))&&Math.abs(v-Ze)<=et*Math.max(1,Math.abs(v),Math.abs(Ze))&&Math.abs(b-Je)<=et*Math.max(1,Math.abs(b),Math.abs(Je))&&Math.abs(y-Qe)<=et*Math.max(1,Math.abs(y),Math.abs(Qe))&&Math.abs(S-tt)<=et*Math.max(1,Math.abs(S),Math.abs(tt))&&Math.abs(w-it)<=et*Math.max(1,Math.abs(w),Math.abs(it))&&Math.abs(L-ft)<=et*Math.max(1,Math.abs(L),Math.abs(ft))&&Math.abs(k-pt)<=et*Math.max(1,Math.abs(k),Math.abs(pt))&&Math.abs(H-xt)<=et*Math.max(1,Math.abs(H),Math.abs(xt))&&Math.abs(z-vt)<=et*Math.max(1,Math.abs(z),Math.abs(vt))&&Math.abs(q-bt)<=et*Math.max(1,Math.abs(q),Math.abs(bt))&&Math.abs(W-yt)<=et*Math.max(1,Math.abs(W),Math.abs(yt))&&Math.abs(be-St)<=et*Math.max(1,Math.abs(be),Math.abs(St))&&Math.abs(Ke-Tt)<=et*Math.max(1,Math.abs(Ke),Math.abs(Tt))&&Math.abs(Xe-Mt)<=et*Math.max(1,Math.abs(Xe),Math.abs(Mt))},exactEquals:function(i,g){return i[0]===g[0]&&i[1]===g[1]&&i[2]===g[2]&&i[3]===g[3]&&i[4]===g[4]&&i[5]===g[5]&&i[6]===g[6]&&i[7]===g[7]&&i[8]===g[8]&&i[9]===g[9]&&i[10]===g[10]&&i[11]===g[11]&&i[12]===g[12]&&i[13]===g[13]&&i[14]===g[14]&&i[15]===g[15]},frob:function(i){return Math.sqrt(i[0]*i[0]+i[1]*i[1]+i[2]*i[2]+i[3]*i[3]+i[4]*i[4]+i[5]*i[5]+i[6]*i[6]+i[7]*i[7]+i[8]*i[8]+i[9]*i[9]+i[10]*i[10]+i[11]*i[11]+i[12]*i[12]+i[13]*i[13]+i[14]*i[14]+i[15]*i[15])},fromQuat:function(i,g){var x=g[0],_=g[1],v=g[2],b=g[3],y=x+x,S=_+_,w=v+v,L=x*y,k=_*y,H=_*S,z=v*y,q=v*S,W=v*w,be=b*y,Ke=b*S,Xe=b*w;return i[0]=1-H-W,i[1]=k+Xe,i[2]=z-Ke,i[3]=0,i[4]=k-Xe,i[5]=1-L-W,i[6]=q+be,i[7]=0,i[8]=z+Ke,i[9]=q-be,i[10]=1-L-H,i[11]=0,i[12]=0,i[13]=0,i[14]=0,i[15]=1,i},fromQuat2:function(i,g){var x=new tt(3),_=-g[0],v=-g[1],b=-g[2],y=g[3],S=g[4],w=g[5],L=g[6],k=g[7],H=_*_+v*v+b*b+y*y;return H>0?(x[0]=2*(S*y+k*_+w*b-L*v)/H,x[1]=2*(w*y+k*v+L*_-S*b)/H,x[2]=2*(L*y+k*b+S*v-w*_)/H):(x[0]=2*(S*y+k*_+w*b-L*v),x[1]=2*(w*y+k*v+L*_-S*b),x[2]=2*(L*y+k*b+S*v-w*_)),fromRotationTranslation(i,g,x),i},fromRotation:function(i,g,x){var _,v,b,y=x[0],S=x[1],w=x[2],L=Math.sqrt(y*y+S*S+w*w);return L0?(Ke=2*Math.sqrt(be+1),i[3]=.25*Ke,i[0]=(H-q)/Ke,i[1]=(z-w)/Ke,i[2]=(S-L)/Ke):y>k&&y>W?(Ke=2*Math.sqrt(1+y-k-W),i[3]=(H-q)/Ke,i[0]=.25*Ke,i[1]=(S+L)/Ke,i[2]=(z+w)/Ke):k>W?(Ke=2*Math.sqrt(1+k-y-W),i[3]=(z-w)/Ke,i[0]=(S+L)/Ke,i[1]=.25*Ke,i[2]=(H+q)/Ke):(Ke=2*Math.sqrt(1+W-y-k),i[3]=(S-L)/Ke,i[0]=(z+w)/Ke,i[1]=(H+q)/Ke,i[2]=.25*Ke),i},getScaling:getScaling,getTranslation:function(i,g){return i[0]=g[12],i[1]=g[13],i[2]=g[14],i},identity:identity$1,invert:invert$1,lookAt:lookAt,mul:yt,multiply:multiply$4,multiplyScalar:function(i,g,x){return i[0]=g[0]*x,i[1]=g[1]*x,i[2]=g[2]*x,i[3]=g[3]*x,i[4]=g[4]*x,i[5]=g[5]*x,i[6]=g[6]*x,i[7]=g[7]*x,i[8]=g[8]*x,i[9]=g[9]*x,i[10]=g[10]*x,i[11]=g[11]*x,i[12]=g[12]*x,i[13]=g[13]*x,i[14]=g[14]*x,i[15]=g[15]*x,i},multiplyScalarAndAdd:function(i,g,x,_){return i[0]=g[0]+x[0]*_,i[1]=g[1]+x[1]*_,i[2]=g[2]+x[2]*_,i[3]=g[3]+x[3]*_,i[4]=g[4]+x[4]*_,i[5]=g[5]+x[5]*_,i[6]=g[6]+x[6]*_,i[7]=g[7]+x[7]*_,i[8]=g[8]+x[8]*_,i[9]=g[9]+x[9]*_,i[10]=g[10]+x[10]*_,i[11]=g[11]+x[11]*_,i[12]=g[12]+x[12]*_,i[13]=g[13]+x[13]*_,i[14]=g[14]+x[14]*_,i[15]=g[15]+x[15]*_,i},ortho:bt,orthoNO:orthoNO,orthoZO:orthoZO,perspective:vt,perspectiveFromFieldOfView:function(i,g,x,_){var v=Math.tan(g.upDegrees*Math.PI/180),b=Math.tan(g.downDegrees*Math.PI/180),y=Math.tan(g.leftDegrees*Math.PI/180),S=Math.tan(g.rightDegrees*Math.PI/180),w=2/(y+S),L=2/(v+b);return i[0]=w,i[1]=0,i[2]=0,i[3]=0,i[4]=0,i[5]=L,i[6]=0,i[7]=0,i[8]=-(y-S)*w*.5,i[9]=(v-b)*L*.5,i[10]=_/(x-_),i[11]=-1,i[12]=0,i[13]=0,i[14]=_*x/(x-_),i[15]=0,i},perspectiveNO:perspectiveNO,perspectiveZO:function(i,g,x,_,v){var b=1/Math.tan(g/2);if(i[0]=b/x,i[1]=0,i[2]=0,i[3]=0,i[4]=0,i[5]=b,i[6]=0,i[7]=0,i[8]=0,i[9]=0,i[11]=-1,i[12]=0,i[13]=0,i[15]=0,null!=v&&v!==1/0){var y=1/(_-v);i[10]=v*y,i[14]=v*_*y}else i[10]=-1,i[14]=-_;return i},rotate:function(i,g,x,_){var v,b,y,S,w,L,k,H,z,q,W,be,Ke,Xe,je,Ye,Ze,Je,Qe,tt,it,ft,pt,xt,vt=_[0],bt=_[1],yt=_[2],St=Math.sqrt(vt*vt+bt*bt+yt*yt);return St0&&(b=1/Math.sqrt(b)),i[0]=g[0]*b,i[1]=g[1]*b,i[2]=g[2]*b,i}function dot$3(i,g){return i[0]*g[0]+i[1]*g[1]+i[2]*g[2]}function cross$2(i,g,x){var _=g[0],v=g[1],b=g[2],y=x[0],S=x[1],w=x[2];return i[0]=v*w-b*S,i[1]=b*y-_*w,i[2]=_*S-v*y,i}function lerp$3(i,g,x,_){var v=g[0],b=g[1],y=g[2];return i[0]=v+_*(x[0]-v),i[1]=b+_*(x[1]-b),i[2]=y+_*(x[2]-y),i}function transformMat4$2(i,g,x){var _=g[0],v=g[1],b=g[2],y=x[3]*_+x[7]*v+x[11]*b+x[15];return y=y||1,i[0]=(x[0]*_+x[4]*v+x[8]*b+x[12])/y,i[1]=(x[1]*_+x[5]*v+x[9]*b+x[13])/y,i[2]=(x[2]*_+x[6]*v+x[10]*b+x[14])/y,i}var Mt,wt=subtract$2,Ct=multiply$3,Rt=divide$2,Pt=distance$2,Bt=squaredDistance$2,It=length$3,Et=squaredLength$3,Dt=(Mt=create$3(),function(i,g,x,_,v,b){var y,S;for(g||(g=3),x||(x=0),S=_?Math.min(_*g+x,i.length):i.length,y=x;y0&&(y=1/Math.sqrt(y)),i[0]=x*y,i[1]=_*y,i[2]=v*y,i[3]=b*y,i}function dot$2(i,g){return i[0]*g[0]+i[1]*g[1]+i[2]*g[2]+i[3]*g[3]}function lerp$2(i,g,x,_){var v=g[0],b=g[1],y=g[2],S=g[3];return i[0]=v+_*(x[0]-v),i[1]=b+_*(x[1]-b),i[2]=y+_*(x[2]-y),i[3]=S+_*(x[3]-S),i}function transformMat4$1(i,g,x){var _=g[0],v=g[1],b=g[2],y=g[3];return i[0]=x[0]*_+x[4]*v+x[8]*b+x[12]*y,i[1]=x[1]*_+x[5]*v+x[9]*b+x[13]*y,i[2]=x[2]*_+x[6]*v+x[10]*b+x[14]*y,i[3]=x[3]*_+x[7]*v+x[11]*b+x[15]*y,i}function exactEquals$2(i,g){return i[0]===g[0]&&i[1]===g[1]&&i[2]===g[2]&&i[3]===g[3]}var Lt=subtract$1,At=multiply$2,Gt=divide$1,kt=distance$1,Ot=squaredDistance$1,Nt=length$2,Vt=squaredLength$2,Ft=function(){var i=create$2();return function(g,x,_,v,b,y){var S,w;for(x||(x=4),_||(_=0),w=v?Math.min(v*x+_,g.length):g.length,S=_;S0?S*Math.sin(y)/y:0;return i[0]=x*w,i[1]=_*w,i[2]=v*w,i[3]=S*Math.cos(y),i}function ln(i,g){var x=g[0],_=g[1],v=g[2],b=g[3],y=Math.sqrt(x*x+_*_+v*v),S=y>0?Math.atan2(y,b)/y:0;return i[0]=x*S,i[1]=_*S,i[2]=v*S,i[3]=.5*Math.log(x*x+_*_+v*v+b*b),i}function slerp(i,g,x,_){var v,b,y,S,w,L=g[0],k=g[1],H=g[2],z=g[3],q=x[0],W=x[1],be=x[2],Ke=x[3];return(b=L*q+k*W+H*be+z*Ke)<0&&(b=-b,q=-q,W=-W,be=-be,Ke=-Ke),1-b>et?(v=Math.acos(b),y=Math.sin(v),S=Math.sin((1-_)*v)/y,w=Math.sin(_*v)/y):(S=1-_,w=_),i[0]=S*L+w*q,i[1]=S*k+w*W,i[2]=S*H+w*be,i[3]=S*z+w*Ke,i}function fromMat3(i,g){var x,_=g[0]+g[4]+g[8];if(_>0)x=Math.sqrt(_+1),i[3]=.5*x,x=.5/x,i[0]=(g[5]-g[7])*x,i[1]=(g[6]-g[2])*x,i[2]=(g[1]-g[3])*x;else{var v=0;g[4]>g[0]&&(v=1),g[8]>g[3*v+v]&&(v=2);var b=(v+1)%3,y=(v+2)%3;x=Math.sqrt(g[3*v+v]-g[3*b+b]-g[3*y+y]+1),i[v]=.5*x,x=.5/x,i[3]=(g[3*b+y]-g[3*y+b])*x,i[b]=(g[3*b+v]+g[3*v+b])*x,i[y]=(g[3*y+v]+g[3*v+y])*x}return i}var zt=clone$2,$t=fromValues$2,Kt=copy$2,Xt=set$2,jt=add$2,Yt=multiply$1,qt=scale$2,Wt=dot$2,Zt=lerp$2,Jt=length$2,Qt=Jt,en=squaredLength$2,tn=en,nn=normalize$2,rn=exactEquals$2;var an,sn,on,un,cn=(an=create$3(),sn=fromValues$3(1,0,0),on=fromValues$3(0,1,0),function(i,g,x){var _=dot$3(g,x);return _<-.999999?(cross$2(an,sn,g),It(an)<1e-6&&cross$2(an,on,g),normalize$3(an,an),setAxisAngle(i,an,Math.PI),i):_>.999999?(i[0]=0,i[1]=0,i[2]=0,i[3]=1,i):(cross$2(an,g,x),i[0]=an[0],i[1]=an[1],i[2]=an[2],i[3]=1+_,nn(i,i))}),hn=function(){var i=create$1(),g=create$1();return function(x,_,v,b,y,S){return slerp(i,_,y,S),slerp(g,v,b,S),slerp(x,i,g,2*S*(1-S)),x}}(),fn=(un=create$5(),function(i,g,x,_){return un[0]=x[0],un[3]=x[1],un[6]=x[2],un[1]=_[0],un[4]=_[1],un[7]=_[2],un[2]=-g[0],un[5]=-g[1],un[8]=-g[2],nn(i,fromMat3(i,un))}),dn=Object.freeze({__proto__:null,add:jt,calculateW:function(i,g){var x=g[0],_=g[1],v=g[2];return i[0]=x,i[1]=_,i[2]=v,i[3]=Math.sqrt(Math.abs(1-x*x-_*_-v*v)),i},clone:zt,conjugate:function(i,g){return i[0]=-g[0],i[1]=-g[1],i[2]=-g[2],i[3]=g[3],i},copy:Kt,create:create$1,dot:Wt,equals:function(i,g){return Math.abs(dot$2(i,g))>=.999999},exactEquals:rn,exp:exp,fromEuler:function(i,g,x,_){var v=arguments.length>4&&void 0!==arguments[4]?arguments[4]:"zyx",b=Math.PI/360;g*=b,_*=b,x*=b;var y=Math.sin(g),S=Math.cos(g),w=Math.sin(x),L=Math.cos(x),k=Math.sin(_),H=Math.cos(_);switch(v){case"xyz":i[0]=y*L*H+S*w*k,i[1]=S*w*H-y*L*k,i[2]=S*L*k+y*w*H,i[3]=S*L*H-y*w*k;break;case"xzy":i[0]=y*L*H-S*w*k,i[1]=S*w*H-y*L*k,i[2]=S*L*k+y*w*H,i[3]=S*L*H+y*w*k;break;case"yxz":i[0]=y*L*H+S*w*k,i[1]=S*w*H-y*L*k,i[2]=S*L*k-y*w*H,i[3]=S*L*H+y*w*k;break;case"yzx":i[0]=y*L*H+S*w*k,i[1]=S*w*H+y*L*k,i[2]=S*L*k-y*w*H,i[3]=S*L*H-y*w*k;break;case"zxy":i[0]=y*L*H-S*w*k,i[1]=S*w*H+y*L*k,i[2]=S*L*k+y*w*H,i[3]=S*L*H-y*w*k;break;case"zyx":i[0]=y*L*H-S*w*k,i[1]=S*w*H+y*L*k,i[2]=S*L*k-y*w*H,i[3]=S*L*H+y*w*k;break;default:throw new Error("Unknown angle order "+v)}return i},fromMat3:fromMat3,fromValues:$t,getAngle:function(i,g){var x=Wt(i,g);return Math.acos(2*x*x-1)},getAxisAngle:function(i,g){var x=2*Math.acos(g[3]),_=Math.sin(x/2);return _>et?(i[0]=g[0]/_,i[1]=g[1]/_,i[2]=g[2]/_):(i[0]=1,i[1]=0,i[2]=0),x},identity:function(i){return i[0]=0,i[1]=0,i[2]=0,i[3]=1,i},invert:function(i,g){var x=g[0],_=g[1],v=g[2],b=g[3],y=x*x+_*_+v*v+b*b,S=y?1/y:0;return i[0]=-x*S,i[1]=-_*S,i[2]=-v*S,i[3]=b*S,i},len:Qt,length:Jt,lerp:Zt,ln:ln,mul:Yt,multiply:multiply$1,normalize:nn,pow:function(i,g,x){return ln(i,g),qt(i,i,x),exp(i,i),i},random:function(i){var g=it(),x=it(),_=it(),v=Math.sqrt(1-g),b=Math.sqrt(g);return i[0]=v*Math.sin(2*Math.PI*x),i[1]=v*Math.cos(2*Math.PI*x),i[2]=b*Math.sin(2*Math.PI*_),i[3]=b*Math.cos(2*Math.PI*_),i},rotateX:function(i,g,x){x*=.5;var _=g[0],v=g[1],b=g[2],y=g[3],S=Math.sin(x),w=Math.cos(x);return i[0]=_*w+y*S,i[1]=v*w+b*S,i[2]=b*w-v*S,i[3]=y*w-_*S,i},rotateY:function(i,g,x){x*=.5;var _=g[0],v=g[1],b=g[2],y=g[3],S=Math.sin(x),w=Math.cos(x);return i[0]=_*w-b*S,i[1]=v*w+y*S,i[2]=b*w+_*S,i[3]=y*w-v*S,i},rotateZ:function(i,g,x){x*=.5;var _=g[0],v=g[1],b=g[2],y=g[3],S=Math.sin(x),w=Math.cos(x);return i[0]=_*w+v*S,i[1]=v*w-_*S,i[2]=b*w+y*S,i[3]=y*w-b*S,i},rotationTo:cn,scale:qt,set:Xt,setAxes:fn,setAxisAngle:setAxisAngle,slerp:slerp,sqlerp:hn,sqrLen:tn,squaredLength:en,str:function(i){return"quat("+i[0]+","+i[1]+","+i[2]+","+i[3]+")"}});function create(){var i=new tt(2);return tt!=Float32Array&&(i[0]=0,i[1]=0),i}function fromValues(i,g){var x=new tt(2);return x[0]=i,x[1]=g,x}function set(i,g,x){return i[0]=g,i[1]=x,i}function subtract(i,g,x){return i[0]=g[0]-x[0],i[1]=g[1]-x[1],i}function multiply(i,g,x){return i[0]=g[0]*x[0],i[1]=g[1]*x[1],i}function divide(i,g,x){return i[0]=g[0]/x[0],i[1]=g[1]/x[1],i}function scaleAndAdd(i,g,x,_){return i[0]=g[0]+x[0]*_,i[1]=g[1]+x[1]*_,i}function distance(i,g){var x=g[0]-i[0],_=g[1]-i[1];return Math.sqrt(x*x+_*_)}function squaredDistance(i,g){var x=g[0]-i[0],_=g[1]-i[1];return x*x+_*_}function length(i){var g=i[0],x=i[1];return Math.sqrt(g*g+x*x)}function squaredLength(i){var g=i[0],x=i[1];return g*g+x*x}function lerp(i,g,x,_){var v=g[0],b=g[1];return i[0]=v+_*(x[0]-v),i[1]=b+_*(x[1]-b),i}var mn=length,pn=subtract,gn=multiply,xn=divide,_n=distance,vn=squaredDistance,bn=squaredLength,yn=function(){var i=create();return function(g,x,_,v,b,y){var S,w;for(x||(x=2),_||(_=0),w=v?Math.min(v*x+_,g.length):g.length,S=_;S0&&(v=1/Math.sqrt(v)),i[0]=g[0]*v,i[1]=g[1]*v,i},random:function(i,g){g=void 0===g?1:g;var x=2*it()*Math.PI;return i[0]=Math.cos(x)*g,i[1]=Math.sin(x)*g,i},rotate:function(i,g,x,_){var v=g[0]-x[0],b=g[1]-x[1],y=Math.sin(_),S=Math.cos(_);return i[0]=v*S-b*y+x[0],i[1]=v*y+b*S+x[1],i},round:function(i,g){return i[0]=round$3(g[0]),i[1]=round$3(g[1]),i},scale:function(i,g,x){return i[0]=g[0]*x,i[1]=g[1]*x,i},scaleAndAdd:scaleAndAdd,set:set,signedAngle:function(i,g){var x=i[0],_=i[1],v=g[0],b=g[1];return Math.atan2(x*b-_*v,x*v+_*b)},sqrDist:vn,sqrLen:bn,squaredDistance:squaredDistance,squaredLength:squaredLength,str:function(i){return"vec2("+i[0]+","+i[1]+")"},sub:pn,subtract:subtract,transformMat2:function(i,g,x){var _=g[0],v=g[1];return i[0]=x[0]*_+x[2]*v,i[1]=x[1]*_+x[3]*v,i},transformMat2d:function(i,g,x){var _=g[0],v=g[1];return i[0]=x[0]*_+x[2]*v+x[4],i[1]=x[1]*_+x[3]*v+x[5],i},transformMat3:function(i,g,x){var _=g[0],v=g[1];return i[0]=x[0]*_+x[3]*v+x[6],i[1]=x[1]*_+x[4]*v+x[7],i},transformMat4:function(i,g,x){var _=g[0],v=g[1];return i[0]=x[0]*_+x[4]*v+x[12],i[1]=x[1]*_+x[5]*v+x[13],i},zero:function(i){return i[0]=0,i[1]=0,i}});class Camera2D{#f;#kt=create$4();#Ot=0;#Nt=0;#Vt=0;#h;constructor(){}get name(){return this.#f||(this.#f=InstanceIdGenerator.getNextId(this.constructor)),this.#h||`${this.constructor.name} Instance ${this.#f}`}set name(i){this.#h=i}get modelMatrix(){return this.#kt}get z(){return this.#Vt}get x(){return this.#Ot}set x(i){this.#Ot=i,this.#kt[12]=i}get y(){return this.#Nt}set y(i){this.#Nt=i,this.#kt[13]=i}get position(){return[this.#Ot,this.#Nt]}setPosition(i,g){Array.isArray(i)?[this.#Ot,this.#Nt]=i:(this.#Ot=i,this.#Nt=g),[this.#kt[12],this.#kt[13],this.#kt[14]]=[this.#Ot,this.#Nt,0]}}const Tn={NEVER:"never",LESS:"less",EQUAL:"equal",LESS_EQUAL:"less-equal",GREATER:"greater",NOT_EQUAL:"not-equal",GREATER_EQUAL:"greater-equal",ALWAYS:"always"};Object.freeze(Tn);class e{constructor(i,g){this.name=i,this.attributes=g,this.size=0}get isArray(){return!1}get isStruct(){return!1}get isTemplate(){return!1}get isPointer(){return!1}getTypeName(){return this.name}}class t{constructor(i,g,x){this.name=i,this.type=g,this.attributes=x,this.offset=0,this.size=0}get isArray(){return this.type.isArray}get isStruct(){return this.type.isStruct}get isTemplate(){return this.type.isTemplate}get align(){return this.type.isStruct?this.type.align:0}get members(){return this.type.isStruct?this.type.members:null}get format(){return this.type.isArray||this.type.isTemplate?this.type.format:null}get count(){return this.type.isArray?this.type.count:0}get stride(){return this.type.isArray?this.type.stride:this.size}}class n extends e{constructor(i,g){super(i,g),this.members=[],this.align=0,this.startLine=-1,this.endLine=-1,this.inUse=!1}get isStruct(){return!0}}class s extends e{constructor(i,g){super(i,g),this.count=0,this.stride=0}get isArray(){return!0}getTypeName(){return`array<${this.format.getTypeName()},${this.count}>`}}class r extends e{constructor(i,g,x){super(i,x),this.format=g}get isPointer(){return!0}getTypeName(){return`&${this.format.getTypeName()}`}}class a extends e{constructor(i,g,x,_){super(i,x),this.format=g,this.access=_}get isTemplate(){return!0}getTypeName(){let i=this.name;if(null!==this.format){if("vec2"===i||"vec3"===i||"vec4"===i||"mat2x2"===i||"mat2x3"===i||"mat2x4"===i||"mat3x2"===i||"mat3x3"===i||"mat3x4"===i||"mat4x2"===i||"mat4x3"===i||"mat4x4"===i){if("f32"===this.format.name)return i+="f",i;if("i32"===this.format.name)return i+="i",i;if("u32"===this.format.name)return i+="u",i;if("bool"===this.format.name)return i+="b",i;if("f16"===this.format.name)return i+="h",i}i+=`<${this.format.name}>`}else if("vec2"===i||"vec3"===i||"vec4"===i)return i;return i}}var Mn;(i=>{i[i.Uniform=0]="Uniform",i[i.Storage=1]="Storage",i[i.Texture=2]="Texture",i[i.Sampler=3]="Sampler",i[i.StorageTexture=4]="StorageTexture"})(Mn||(Mn={}));class o{constructor(i,g,x,_,v,b,y){this.name=i,this.type=g,this.group=x,this.binding=_,this.attributes=v,this.resourceType=b,this.access=y}get isArray(){return this.type.isArray}get isStruct(){return this.type.isStruct}get isTemplate(){return this.type.isTemplate}get size(){return this.type.size}get align(){return this.type.isStruct?this.type.align:0}get members(){return this.type.isStruct?this.type.members:null}get format(){return this.type.isArray||this.type.isTemplate?this.type.format:null}get count(){return this.type.isArray?this.type.count:0}get stride(){return this.type.isArray?this.type.stride:this.size}}class c{constructor(i,g){this.name=i,this.type=g}}class l{constructor(i,g,x,_){this.name=i,this.type=g,this.locationType=x,this.location=_,this.interpolation=null}}class u{constructor(i,g,x,_){this.name=i,this.type=g,this.locationType=x,this.location=_}}class h{constructor(i,g,x,_){this.name=i,this.type=g,this.attributes=x,this.id=_}}class f{constructor(i,g,x){this.name=i,this.type=g,this.attributes=x}}class p{constructor(i,g=null,x){this.stage=null,this.inputs=[],this.outputs=[],this.arguments=[],this.returnType=null,this.resources=[],this.overrides=[],this.startLine=-1,this.endLine=-1,this.inUse=!1,this.calls=new Set,this.name=i,this.stage=g,this.attributes=x}}class d{constructor(){this.vertex=[],this.fragment=[],this.compute=[]}}function m(i){var g=(32768&i)>>15,x=(31744&i)>>10,_=1023&i;return 0==x?(g?-1:1)*Math.pow(2,-14)*(_/Math.pow(2,10)):31==x?_?NaN:1/0*(g?-1:1):(g?-1:1)*Math.pow(2,x-15)*(1+_/Math.pow(2,10))}const wn=new Float32Array(1),Cn=new Int32Array(wn.buffer),Rn=new Uint16Array(1);function y$1(i){wn[0]=i;const g=Cn[0],x=g>>31&1;let _=g>>23&255,v=8388607&g;if(255===_)return Rn[0]=x<<15|31744|(0!==v?512:0),Rn[0];if(0===_){if(0===v)return Rn[0]=x<<15,Rn[0];v|=8388608;let i=113;for(;!(8388608&v);)v<<=1,i--;return _=127-i,v&=8388607,_>0?(v=(v>>126-_)+(v>>127-_&1),Rn[0]=x<<15|_<<10|v>>13,Rn[0]):(Rn[0]=x<<15,Rn[0])}return _=_-127+15,_>=31?(Rn[0]=x<<15|31744,Rn[0]):_<=0?_<-10?(Rn[0]=x<<15,Rn[0]):(v=(8388608|v)>>1-_,Rn[0]=x<<15|v>>13,Rn[0]):(v>>=13,Rn[0]=x<<15|_<<10|v,Rn[0])}const Pn=new Uint32Array(1),Bn=new Float32Array(Pn.buffer,0,1);function w$1(i){const g=112+(i>>6&31)<<23|(63&i)<<17;return Pn[0]=g,Bn[0]}function I(i,g,x,_){const v=[0,0,0,0];for(let b=0;b<_;++b)switch(x){case"8unorm":v[b]=i[g]/255,g++;break;case"8snorm":v[b]=i[g]/255*2-1,g++;break;case"8uint":v[b]=i[g],g++;break;case"8sint":v[b]=i[g]-127,g++;break;case"16uint":v[b]=i[g]|i[g+1]<<8,g+=2;break;case"16sint":v[b]=(i[g]|i[g+1]<<8)-32768,g+=2;break;case"16float":v[b]=m(i[g]|i[g+1]<<8),g+=2;break;case"32uint":case"32sint":v[b]=i[g]|i[g+1]<<8|i[g+2]<<16|i[g+3]<<24,g+=4;break;case"32float":v[b]=new Float32Array(i.buffer,g,1)[0],g+=4}return v}function T(i,g,x,_,v){for(let b=0;b<_;++b)switch(x){case"8unorm":i[g]=255*v[b],g++;break;case"8snorm":i[g]=.5*(v[b]+1)*255,g++;break;case"8uint":i[g]=v[b],g++;break;case"8sint":i[g]=v[b]+127,g++;break;case"16uint":new Uint16Array(i.buffer,g,1)[0]=v[b],g+=2;break;case"16sint":new Int16Array(i.buffer,g,1)[0]=v[b],g+=2;break;case"16float":{const x=y$1(v[b]);new Uint16Array(i.buffer,g,1)[0]=x,g+=2;break}case"32uint":new Uint32Array(i.buffer,g,1)[0]=v[b],g+=4;break;case"32sint":new Int32Array(i.buffer,g,1)[0]=v[b],g+=4;break;case"32float":new Float32Array(i.buffer,g,1)[0]=v[b],g+=4}return v}const In={r8unorm:{bytesPerBlock:1,blockWidth:1,blockHeight:1,isCompressed:!1,channels:1},r8snorm:{bytesPerBlock:1,blockWidth:1,blockHeight:1,isCompressed:!1,channels:1},r8uint:{bytesPerBlock:1,blockWidth:1,blockHeight:1,isCompressed:!1,channels:1},r8sint:{bytesPerBlock:1,blockWidth:1,blockHeight:1,isCompressed:!1,channels:1},rg8unorm:{bytesPerBlock:2,blockWidth:1,blockHeight:1,isCompressed:!1,channels:2},rg8snorm:{bytesPerBlock:2,blockWidth:1,blockHeight:1,isCompressed:!1,channels:2},rg8uint:{bytesPerBlock:2,blockWidth:1,blockHeight:1,isCompressed:!1,channels:2},rg8sint:{bytesPerBlock:2,blockWidth:1,blockHeight:1,isCompressed:!1,channels:2},rgba8unorm:{bytesPerBlock:4,blockWidth:1,blockHeight:1,isCompressed:!1,channels:4},"rgba8unorm-srgb":{bytesPerBlock:4,blockWidth:1,blockHeight:1,isCompressed:!1,channels:4},rgba8snorm:{bytesPerBlock:4,blockWidth:1,blockHeight:1,isCompressed:!1,channels:4},rgba8uint:{bytesPerBlock:4,blockWidth:1,blockHeight:1,isCompressed:!1,channels:4},rgba8sint:{bytesPerBlock:4,blockWidth:1,blockHeight:1,isCompressed:!1,channels:4},bgra8unorm:{bytesPerBlock:4,blockWidth:1,blockHeight:1,isCompressed:!1,channels:4},"bgra8unorm-srgb":{bytesPerBlock:4,blockWidth:1,blockHeight:1,isCompressed:!1,channels:4},r16uint:{bytesPerBlock:2,blockWidth:1,blockHeight:1,isCompressed:!1,channels:1},r16sint:{bytesPerBlock:2,blockWidth:1,blockHeight:1,isCompressed:!1,channels:1},r16float:{bytesPerBlock:2,blockWidth:1,blockHeight:1,isCompressed:!1,channels:1},rg16uint:{bytesPerBlock:4,blockWidth:1,blockHeight:1,isCompressed:!1,channels:2},rg16sint:{bytesPerBlock:4,blockWidth:1,blockHeight:1,isCompressed:!1,channels:2},rg16float:{bytesPerBlock:4,blockWidth:1,blockHeight:1,isCompressed:!1,channels:2},rgba16uint:{bytesPerBlock:8,blockWidth:1,blockHeight:1,isCompressed:!1,channels:4},rgba16sint:{bytesPerBlock:8,blockWidth:1,blockHeight:1,isCompressed:!1,channels:4},rgba16float:{bytesPerBlock:8,blockWidth:1,blockHeight:1,isCompressed:!1,channels:4},r32uint:{bytesPerBlock:4,blockWidth:1,blockHeight:1,isCompressed:!1,channels:1},r32sint:{bytesPerBlock:4,blockWidth:1,blockHeight:1,isCompressed:!1,channels:1},r32float:{bytesPerBlock:4,blockWidth:1,blockHeight:1,isCompressed:!1,channels:1},rg32uint:{bytesPerBlock:8,blockWidth:1,blockHeight:1,isCompressed:!1,channels:2},rg32sint:{bytesPerBlock:8,blockWidth:1,blockHeight:1,isCompressed:!1,channels:2},rg32float:{bytesPerBlock:8,blockWidth:1,blockHeight:1,isCompressed:!1,channels:2},rgba32uint:{bytesPerBlock:16,blockWidth:1,blockHeight:1,isCompressed:!1,channels:4},rgba32sint:{bytesPerBlock:16,blockWidth:1,blockHeight:1,isCompressed:!1,channels:4},rgba32float:{bytesPerBlock:16,blockWidth:1,blockHeight:1,isCompressed:!1,channels:4},rgb10a2uint:{bytesPerBlock:4,blockWidth:1,blockHeight:1,isCompressed:!1,channels:4},rgb10a2unorm:{bytesPerBlock:4,blockWidth:1,blockHeight:1,isCompressed:!1,channels:4},rg11b10ufloat:{bytesPerBlock:4,blockWidth:1,blockHeight:1,isCompressed:!1,channels:4},stencil8:{bytesPerBlock:1,blockWidth:1,blockHeight:1,isCompressed:!1,isDepthStencil:!0,hasDepth:!1,hasStencil:!0,channels:1},depth16unorm:{bytesPerBlock:2,blockWidth:1,blockHeight:1,isCompressed:!1,isDepthStencil:!0,hasDepth:!0,hasStencil:!1,channels:1},depth24plus:{bytesPerBlock:4,blockWidth:1,blockHeight:1,isCompressed:!1,isDepthStencil:!0,hasDepth:!0,hasStencil:!1,depthOnlyFormat:"depth32float",channels:1},"depth24plus-stencil8":{bytesPerBlock:8,blockWidth:1,blockHeight:1,isCompressed:!1,isDepthStencil:!0,hasDepth:!0,hasStencil:!0,depthOnlyFormat:"depth32float",channels:1},depth32float:{bytesPerBlock:4,blockWidth:1,blockHeight:1,isCompressed:!1,isDepthStencil:!0,hasDepth:!0,hasStencil:!1,channels:1},"depth32float-stencil8":{bytesPerBlock:8,blockWidth:1,blockHeight:1,isCompressed:!1,isDepthStencil:!0,hasDepth:!0,hasStencil:!0,stencilOnlyFormat:"depth32float",channels:1},rgb9e5ufloat:{bytesPerBlock:4,blockWidth:1,blockHeight:1,isCompressed:!1,channels:4},"bc1-rgba-unorm":{bytesPerBlock:8,blockWidth:4,blockHeight:4,isCompressed:!0,channels:4},"bc1-rgba-unorm-srgb":{bytesPerBlock:8,blockWidth:4,blockHeight:4,isCompressed:!0,channels:4},"bc2-rgba-unorm":{bytesPerBlock:16,blockWidth:4,blockHeight:4,isCompressed:!0,channels:4},"bc2-rgba-unorm-srgb":{bytesPerBlock:16,blockWidth:4,blockHeight:4,isCompressed:!0,channels:4},"bc3-rgba-unorm":{bytesPerBlock:16,blockWidth:4,blockHeight:4,isCompressed:!0,channels:4},"bc3-rgba-unorm-srgb":{bytesPerBlock:16,blockWidth:4,blockHeight:4,isCompressed:!0,channels:4},"bc4-r-unorm":{bytesPerBlock:8,blockWidth:4,blockHeight:4,isCompressed:!0,channels:1},"bc4-r-snorm":{bytesPerBlock:8,blockWidth:4,blockHeight:4,isCompressed:!0,channels:1},"bc5-rg-unorm":{bytesPerBlock:16,blockWidth:4,blockHeight:4,isCompressed:!0,channels:2},"bc5-rg-snorm":{bytesPerBlock:16,blockWidth:4,blockHeight:4,isCompressed:!0,channels:2},"bc6h-rgb-ufloat":{bytesPerBlock:16,blockWidth:4,blockHeight:4,isCompressed:!0,channels:4},"bc6h-rgb-float":{bytesPerBlock:16,blockWidth:4,blockHeight:4,isCompressed:!0,channels:4},"bc7-rgba-unorm":{bytesPerBlock:16,blockWidth:4,blockHeight:4,isCompressed:!0,channels:4},"bc7-rgba-unorm-srgb":{bytesPerBlock:16,blockWidth:4,blockHeight:4,isCompressed:!0,channels:4},"etc2-rgb8unorm":{bytesPerBlock:8,blockWidth:4,blockHeight:4,isCompressed:!0,channels:4},"etc2-rgb8unorm-srgb":{bytesPerBlock:8,blockWidth:4,blockHeight:4,isCompressed:!0,channels:4},"etc2-rgb8a1unorm":{bytesPerBlock:8,blockWidth:4,blockHeight:4,isCompressed:!0,channels:4},"etc2-rgb8a1unorm-srgb":{bytesPerBlock:8,blockWidth:4,blockHeight:4,isCompressed:!0,channels:4},"etc2-rgba8unorm":{bytesPerBlock:16,blockWidth:4,blockHeight:4,isCompressed:!0,channels:4},"etc2-rgba8unorm-srgb":{bytesPerBlock:16,blockWidth:4,blockHeight:4,isCompressed:!0,channels:4},"eac-r11unorm":{bytesPerBlock:8,blockWidth:1,blockHeight:1,isCompressed:!0,channels:1},"eac-r11snorm":{bytesPerBlock:8,blockWidth:1,blockHeight:1,isCompressed:!0,channels:1},"eac-rg11unorm":{bytesPerBlock:16,blockWidth:1,blockHeight:1,isCompressed:!0,channels:2},"eac-rg11snorm":{bytesPerBlock:16,blockWidth:1,blockHeight:1,isCompressed:!0,channels:2},"astc-4x4-unorm":{bytesPerBlock:16,blockWidth:4,blockHeight:4,isCompressed:!0,channels:4},"astc-4x4-unorm-srgb":{bytesPerBlock:16,blockWidth:4,blockHeight:4,isCompressed:!0,channels:4},"astc-5x4-unorm":{bytesPerBlock:16,blockWidth:5,blockHeight:4,isCompressed:!0,channels:4},"astc-5x4-unorm-srgb":{bytesPerBlock:16,blockWidth:5,blockHeight:4,isCompressed:!0,channels:4},"astc-5x5-unorm":{bytesPerBlock:16,blockWidth:5,blockHeight:5,isCompressed:!0,channels:4},"astc-5x5-unorm-srgb":{bytesPerBlock:16,blockWidth:5,blockHeight:5,isCompressed:!0,channels:4},"astc-6x5-unorm":{bytesPerBlock:16,blockWidth:6,blockHeight:5,isCompressed:!0,channels:4},"astc-6x5-unorm-srgb":{bytesPerBlock:16,blockWidth:6,blockHeight:5,isCompressed:!0,channels:4},"astc-6x6-unorm":{bytesPerBlock:16,blockWidth:6,blockHeight:6,isCompressed:!0,channels:4},"astc-6x6-unorm-srgb":{bytesPerBlock:16,blockWidth:6,blockHeight:6,isCompressed:!0,channels:4},"astc-8x5-unorm":{bytesPerBlock:16,blockWidth:8,blockHeight:5,isCompressed:!0,channels:4},"astc-8x5-unorm-srgb":{bytesPerBlock:16,blockWidth:8,blockHeight:5,isCompressed:!0,channels:4},"astc-8x6-unorm":{bytesPerBlock:16,blockWidth:8,blockHeight:6,isCompressed:!0,channels:4},"astc-8x6-unorm-srgb":{bytesPerBlock:16,blockWidth:8,blockHeight:6,isCompressed:!0,channels:4},"astc-8x8-unorm":{bytesPerBlock:16,blockWidth:8,blockHeight:8,isCompressed:!0,channels:4},"astc-8x8-unorm-srgb":{bytesPerBlock:16,blockWidth:8,blockHeight:8,isCompressed:!0,channels:4},"astc-10x5-unorm":{bytesPerBlock:16,blockWidth:10,blockHeight:5,isCompressed:!0,channels:4},"astc-10x5-unorm-srgb":{bytesPerBlock:16,blockWidth:10,blockHeight:5,isCompressed:!0,channels:4},"astc-10x6-unorm":{bytesPerBlock:16,blockWidth:10,blockHeight:6,isCompressed:!0,channels:4},"astc-10x6-unorm-srgb":{bytesPerBlock:16,blockWidth:10,blockHeight:6,isCompressed:!0,channels:4},"astc-10x8-unorm":{bytesPerBlock:16,blockWidth:10,blockHeight:8,isCompressed:!0,channels:4},"astc-10x8-unorm-srgb":{bytesPerBlock:16,blockWidth:10,blockHeight:8,isCompressed:!0,channels:4},"astc-10x10-unorm":{bytesPerBlock:16,blockWidth:10,blockHeight:10,isCompressed:!0,channels:4},"astc-10x10-unorm-srgb":{bytesPerBlock:16,blockWidth:10,blockHeight:10,isCompressed:!0,channels:4},"astc-12x10-unorm":{bytesPerBlock:16,blockWidth:12,blockHeight:10,isCompressed:!0,channels:4},"astc-12x10-unorm-srgb":{bytesPerBlock:16,blockWidth:12,blockHeight:10,isCompressed:!0,channels:4},"astc-12x12-unorm":{bytesPerBlock:16,blockWidth:12,blockHeight:12,isCompressed:!0,channels:4},"astc-12x12-unorm-srgb":{bytesPerBlock:16,blockWidth:12,blockHeight:12,isCompressed:!0,channels:4}};class A{constructor(){this.id=A._id++,this.line=0}get isAstNode(){return!0}get astNodeType(){return""}search(i){i(this)}searchBlock(i,g){if(i){g(E.instance);for(const x of i)x instanceof Array?this.searchBlock(x,g):x.search(g);g($.instance)}}constEvaluate(i,g){throw new Error("Cannot evaluate node")}constEvaluateString(i){return this.constEvaluate(i).toString()}}A._id=0;class E extends A{}E.instance=new E;class $ extends A{}$.instance=new $;const En=new Set(["all","all","any","select","arrayLength","abs","acos","acosh","asin","asinh","atan","atanh","atan2","ceil","clamp","cos","cosh","countLeadingZeros","countOneBits","countTrailingZeros","cross","degrees","determinant","distance","dot","dot4U8Packed","dot4I8Packed","exp","exp2","extractBits","faceForward","firstLeadingBit","firstTrailingBit","floor","fma","fract","frexp","insertBits","inverseSqrt","ldexp","length","log","log2","max","min","mix","modf","normalize","pow","quantizeToF16","radians","reflect","refract","reverseBits","round","saturate","sign","sin","sinh","smoothStep","sqrt","step","tan","tanh","transpose","trunc","dpdx","dpdxCoarse","dpdxFine","dpdy","dpdyCoarse","dpdyFine","fwidth","fwidthCoarse","fwidthFine","textureDimensions","textureGather","textureGatherCompare","textureLoad","textureNumLayers","textureNumLevels","textureNumSamples","textureSample","textureSampleBias","textureSampleCompare","textureSampleCompareLevel","textureSampleGrad","textureSampleLevel","textureSampleBaseClampToEdge","textureStore","atomicLoad","atomicStore","atomicAdd","atomicSub","atomicMax","atomicMin","atomicAnd","atomicOr","atomicXor","atomicExchange","atomicCompareExchangeWeak","pack4x8snorm","pack4x8unorm","pack4xI8","pack4xU8","pack4x8Clamp","pack4xU8Clamp","pack2x16snorm","pack2x16unorm","pack2x16float","unpack4x8snorm","unpack4x8unorm","unpack4xI8","unpack4xU8","unpack2x16snorm","unpack2x16unorm","unpack2x16float","storageBarrier","textureBarrier","workgroupBarrier","workgroupUniformLoad","subgroupAdd","subgroupExclusiveAdd","subgroupInclusiveAdd","subgroupAll","subgroupAnd","subgroupAny","subgroupBallot","subgroupBroadcast","subgroupBroadcastFirst","subgroupElect","subgroupMax","subgroupMin","subgroupMul","subgroupExclusiveMul","subgroupInclusiveMul","subgroupOr","subgroupShuffle","subgroupShuffleDown","subgroupShuffleUp","subgroupShuffleXor","subgroupXor","quadBroadcast","quadSwapDiagonal","quadSwapX","quadSwapY"]);class C extends A{constructor(){super()}}class D extends C{constructor(i,g,x,_,v,b){super(),this.calls=new Set,this.name=i,this.args=g,this.returnType=x,this.body=_,this.startLine=v,this.endLine=b}get astNodeType(){return"function"}search(i){if(this.attributes)for(const g of this.attributes)i(g);i(this);for(const g of this.args)i(g);this.searchBlock(this.body,i)}}class N extends C{constructor(i){super(),this.expression=i}get astNodeType(){return"staticAssert"}search(i){this.expression.search(i)}}class V extends C{constructor(i,g){super(),this.condition=i,this.body=g}get astNodeType(){return"while"}search(i){this.condition.search(i),this.searchBlock(this.body,i)}}class O extends C{constructor(i,g){super(),this.body=i,this.loopId=g}get astNodeType(){return"continuing"}search(i){this.searchBlock(this.body,i)}}class B extends C{constructor(i,g,x,_){super(),this.init=i,this.condition=g,this.increment=x,this.body=_}get astNodeType(){return"for"}search(i){var g,x,_;null===(g=this.init)||void 0===g||g.search(i),null===(x=this.condition)||void 0===x||x.search(i),null===(_=this.increment)||void 0===_||_.search(i),this.searchBlock(this.body,i)}}class F extends C{constructor(i,g,x,_,v){super(),this.attributes=null,this.name=i,this.type=g,this.storage=x,this.access=_,this.value=v}get astNodeType(){return"var"}search(i){var g;i(this),null===(g=this.value)||void 0===g||g.search(i)}}class M extends C{constructor(i,g,x){super(),this.attributes=null,this.name=i,this.type=g,this.value=x}get astNodeType(){return"override"}search(i){var g;null===(g=this.value)||void 0===g||g.search(i)}}class U extends C{constructor(i,g,x,_,v){super(),this.attributes=null,this.name=i,this.type=g,this.storage=x,this.access=_,this.value=v}get astNodeType(){return"let"}search(i){var g;i(this),null===(g=this.value)||void 0===g||g.search(i)}}class P extends C{constructor(i,g,x,_,v){super(),this.attributes=null,this.name=i,this.type=g,this.storage=x,this.access=_,this.value=v}get astNodeType(){return"const"}constEvaluate(i,g){return this.value.constEvaluate(i,g)}search(i){var g;i(this),null===(g=this.value)||void 0===g||g.search(i)}}var Dn,Un,Ln,An;(i=>{i.increment="++",i.decrement="--"})(Dn||(Dn={})),(i=>{i.parse=function(g){const x=g;if("parse"==x)throw new Error("Invalid value for IncrementOperator");return i[x]}})(Dn||(Dn={}));class R extends C{constructor(i,g){super(),this.operator=i,this.variable=g}get astNodeType(){return"increment"}search(i){this.variable.search(i)}}(i=>{i.assign="=",i.addAssign="+=",i.subtractAssin="-=",i.multiplyAssign="*=",i.divideAssign="/=",i.moduloAssign="%=",i.andAssign="&=",i.orAssign="|=",i.xorAssign="^=",i.shiftLeftAssign="<<=",i.shiftRightAssign=">>="})(Un||(Un={})),(Un||(Un={})).parse=function(i){const g=i;if("parse"==g)throw new Error("Invalid value for AssignOperator");return g};class G extends C{constructor(i,g,x){super(),this.operator=i,this.variable=g,this.value=x}get astNodeType(){return"assign"}search(i){this.variable.search(i),this.value.search(i)}}class X extends C{constructor(i,g){super(),this.name=i,this.args=g}get astNodeType(){return"call"}isBuiltin(){return En.has(this.name)}search(i){for(const g of this.args)g.search(i);i(this)}}class j extends C{constructor(i,g){super(),this.body=i,this.continuing=g}get astNodeType(){return"loop"}search(i){var g;this.searchBlock(this.body,i),null===(g=this.continuing)||void 0===g||g.search(i)}}class Z extends C{constructor(i,g){super(),this.condition=i,this.cases=g}get astNodeType(){return"switch"}search(i){i(this);for(const g of this.cases)g.search(i)}}class Q extends C{constructor(i,g,x,_){super(),this.condition=i,this.body=g,this.elseif=x,this.else=_}get astNodeType(){return"if"}search(i){this.condition.search(i),this.searchBlock(this.body,i),this.searchBlock(this.elseif,i),this.searchBlock(this.else,i)}}class Y extends C{constructor(i){super(),this.value=i}get astNodeType(){return"return"}search(i){var g;null===(g=this.value)||void 0===g||g.search(i)}}class K extends C{constructor(i){super(),this.name=i}get astNodeType(){return"enable"}}class J extends C{constructor(i){super(),this.extensions=i}get astNodeType(){return"requires"}}class ee extends C{constructor(i,g){super(),this.severity=i,this.rule=g}get astNodeType(){return"diagnostic"}}class te extends C{constructor(i,g){super(),this.name=i,this.type=g}get astNodeType(){return"alias"}}class ne extends C{constructor(){super()}get astNodeType(){return"discard"}}class se extends C{constructor(){super(),this.condition=null,this.loopId=-1}get astNodeType(){return"break"}}class re extends C{constructor(){super(),this.loopId=-1}get astNodeType(){return"continue"}}class ae extends C{constructor(i){super(),this.attributes=null,this.name=i}get astNodeType(){return"type"}get isStruct(){return!1}get isArray(){return!1}static maxFormatType(i){let g=i[0];if("f32"===g.name)return g;for(let x=1;x`}else if("vec2"===i||"vec3"===i||"vec4"===i)return i;return i}}ce.vec2f=new ce("vec2",ae.f32,null),ce.vec3f=new ce("vec3",ae.f32,null),ce.vec4f=new ce("vec4",ae.f32,null),ce.vec2i=new ce("vec2",ae.i32,null),ce.vec3i=new ce("vec3",ae.i32,null),ce.vec4i=new ce("vec4",ae.i32,null),ce.vec2u=new ce("vec2",ae.u32,null),ce.vec3u=new ce("vec3",ae.u32,null),ce.vec4u=new ce("vec4",ae.u32,null),ce.vec2h=new ce("vec2",ae.f16,null),ce.vec3h=new ce("vec3",ae.f16,null),ce.vec4h=new ce("vec4",ae.f16,null),ce.vec2b=new ce("vec2",ae.bool,null),ce.vec3b=new ce("vec3",ae.bool,null),ce.vec4b=new ce("vec4",ae.bool,null),ce.mat2x2f=new ce("mat2x2",ae.f32,null),ce.mat2x3f=new ce("mat2x3",ae.f32,null),ce.mat2x4f=new ce("mat2x4",ae.f32,null),ce.mat3x2f=new ce("mat3x2",ae.f32,null),ce.mat3x3f=new ce("mat3x3",ae.f32,null),ce.mat3x4f=new ce("mat3x4",ae.f32,null),ce.mat4x2f=new ce("mat4x2",ae.f32,null),ce.mat4x3f=new ce("mat4x3",ae.f32,null),ce.mat4x4f=new ce("mat4x4",ae.f32,null),ce.mat2x2h=new ce("mat2x2",ae.f16,null),ce.mat2x3h=new ce("mat2x3",ae.f16,null),ce.mat2x4h=new ce("mat2x4",ae.f16,null),ce.mat3x2h=new ce("mat3x2",ae.f16,null),ce.mat3x3h=new ce("mat3x3",ae.f16,null),ce.mat3x4h=new ce("mat3x4",ae.f16,null),ce.mat4x2h=new ce("mat4x2",ae.f16,null),ce.mat4x3h=new ce("mat4x3",ae.f16,null),ce.mat4x4h=new ce("mat4x4",ae.f16,null),ce.mat2x2i=new ce("mat2x2",ae.i32,null),ce.mat2x3i=new ce("mat2x3",ae.i32,null),ce.mat2x4i=new ce("mat2x4",ae.i32,null),ce.mat3x2i=new ce("mat3x2",ae.i32,null),ce.mat3x3i=new ce("mat3x3",ae.i32,null),ce.mat3x4i=new ce("mat3x4",ae.i32,null),ce.mat4x2i=new ce("mat4x2",ae.i32,null),ce.mat4x3i=new ce("mat4x3",ae.i32,null),ce.mat4x4i=new ce("mat4x4",ae.i32,null),ce.mat2x2u=new ce("mat2x2",ae.u32,null),ce.mat2x3u=new ce("mat2x3",ae.u32,null),ce.mat2x4u=new ce("mat2x4",ae.u32,null),ce.mat3x2u=new ce("mat3x2",ae.u32,null),ce.mat3x3u=new ce("mat3x3",ae.u32,null),ce.mat3x4u=new ce("mat3x4",ae.u32,null),ce.mat4x2u=new ce("mat4x2",ae.u32,null),ce.mat4x3u=new ce("mat4x3",ae.u32,null),ce.mat4x4u=new ce("mat4x4",ae.u32,null);class le extends ae{constructor(i,g,x,_){super(i),this.storage=g,this.type=x,this.access=_}get astNodeType(){return"pointer"}}class ue extends ae{constructor(i,g,x,_){super(i),this.attributes=g,this.format=x,this.count=_}get astNodeType(){return"array"}get isArray(){return!0}}class he extends ae{constructor(i,g,x){super(i),this.format=g,this.access=x}get astNodeType(){return"sampler"}}class fe extends A{constructor(){super(),this.postfix=null}}class pe extends fe{constructor(i){super(),this.value=i}get astNodeType(){return"stringExpr"}toString(){return this.value}constEvaluateString(){return this.value}}class de extends fe{constructor(i,g){super(),this.type=i,this.args=g}get astNodeType(){return"createExpr"}search(i){if(i(this),this.args)for(const g of this.args)g.search(i)}constEvaluate(i,g){return g&&(g[0]=this.type),i.evalExpression(this,i.context)}}class me extends fe{constructor(i,g){super(),this.cachedReturnValue=null,this.name=i,this.args=g}get astNodeType(){return"callExpr"}setCachedReturnValue(i){this.cachedReturnValue=i}get isBuiltin(){return En.has(this.name)}constEvaluate(i,g){return i.evalExpression(this,i.context)}search(i){for(const g of this.args)g.search(i);i(this)}}class ge extends fe{constructor(i){super(),this.name=i}get astNodeType(){return"varExpr"}search(i){i(this),this.postfix&&this.postfix.search(i)}constEvaluate(i,g){return i.evalExpression(this,i.context)}}class _e extends fe{constructor(i,g){super(),this.name=i,this.initializer=g}get astNodeType(){return"constExpr"}constEvaluate(i,g){if(this.initializer){const g=i.evalExpression(this.initializer,i.context);return null!==g&&this.postfix?g.getSubData(i,this.postfix,i.context):g}return null}search(i){this.initializer.search(i)}}class xe extends fe{constructor(i,g){super(),this.value=i,this.type=g}get astNodeType(){return"literalExpr"}constEvaluate(i,g){return void 0!==g&&(g[0]=this.type),this.value}get isScalar(){return this.value instanceof Be}get isVector(){return this.value instanceof Me||this.value instanceof Ue}get scalarValue(){return this.value instanceof Be?this.value.value:(console.error("Value is not scalar."),0)}get vectorValue(){return this.value instanceof Me||this.value instanceof Ue?this.value.data:(console.error("Value is not a vector or matrix."),new Float32Array(0))}}class ye extends fe{constructor(i,g){super(),this.type=i,this.value=g}get astNodeType(){return"bitcastExpr"}search(i){this.value.search(i)}}class ve extends fe{constructor(i){super(),this.index=i}search(i){this.index.search(i)}}class we extends fe{constructor(){super()}}class ke extends we{constructor(i,g){super(),this.operator=i,this.right=g}get astNodeType(){return"unaryOp"}constEvaluate(i,g){return i.evalExpression(this,i.context)}search(i){this.right.search(i)}}class Ie extends we{constructor(i,g,x){super(),this.operator=i,this.left=g,this.right=x}get astNodeType(){return"binaryOp"}_getPromotedType(i,g){return i.name===g.name?i:"f32"===i.name||"f32"===g.name?ae.f32:"u32"===i.name||"u32"===g.name?ae.u32:ae.i32}constEvaluate(i,g){return i.evalExpression(this,i.context)}search(i){this.left.search(i),this.right.search(i)}}class Te extends A{constructor(i){super(),this.body=i}search(i){i(this),this.searchBlock(this.body,i)}}class Se extends fe{constructor(){super()}get astNodeType(){return"default"}}class Ae extends Te{constructor(i,g){super(g),this.selectors=i}get astNodeType(){return"case"}search(i){this.searchBlock(this.body,i)}}class Ee extends Te{constructor(i){super(i)}get astNodeType(){return"default"}search(i){this.searchBlock(this.body,i)}}class $e extends A{constructor(i,g,x){super(),this.name=i,this.type=g,this.attributes=x}get astNodeType(){return"argument"}}class Le extends A{constructor(i,g){super(),this.condition=i,this.body=g}get astNodeType(){return"elseif"}search(i){this.condition.search(i),this.searchBlock(this.body,i)}}class Ce extends A{constructor(i,g,x){super(),this.name=i,this.type=g,this.attributes=x}get astNodeType(){return"member"}}class De extends A{constructor(i,g){super(),this.name=i,this.value=g}get astNodeType(){return"attribute"}}class Ne{constructor(i,g){this.parent=null,this.typeInfo=i,this.parent=g,this.id=Ne._id++}clone(){throw`Clone:Not implemented for ${this.constructor.name}`}setDataValue(i,g,x,_){console.error(`SetDataValue:Not implemented for ${this.constructor.name}`)}getSubData(i,g,x){return console.error(`GetDataValue:Not implemented for ${this.constructor.name}`),null}toString(){return`<${this.typeInfo.getTypeName()}>`}}Ne._id=0;class Ve extends Ne{constructor(){super(new e("void",null),null)}toString(){return"void"}}Ve.void=new Ve;class Oe extends Ne{constructor(i){super(new r("pointer",i.typeInfo,null),null),this.reference=i}clone(){return this}setDataValue(i,g,x,_){this.reference.setDataValue(i,g,x,_)}getSubData(i,g,x){return g?this.reference.getSubData(i,g,x):this}toString(){return`&${this.reference.toString()}`}}class Be extends Ne{constructor(i,g,x=null){super(g,x),i instanceof Int32Array||i instanceof Uint32Array||i instanceof Float32Array?this.data=i:"x32"===this.typeInfo.name?i-Math.floor(i)!==0?this.data=new Float32Array([i]):this.data=i>=0?new Uint32Array([i]):new Int32Array([i]):"i32"===this.typeInfo.name||"bool"===this.typeInfo.name?this.data=new Int32Array([i]):"u32"===this.typeInfo.name?this.data=new Uint32Array([i]):"f32"===this.typeInfo.name||"f16"===this.typeInfo.name?this.data=new Float32Array([i]):console.error("ScalarData2:Invalid type",g)}clone(){if(this.data instanceof Float32Array)return new Be(new Float32Array(this.data),this.typeInfo,null);if(this.data instanceof Int32Array)return new Be(new Int32Array(this.data),this.typeInfo,null);if(this.data instanceof Uint32Array)return new Be(new Uint32Array(this.data),this.typeInfo,null);throw"ScalarData:Invalid data type"}get value(){return this.data[0]}set value(i){this.data[0]=i}setDataValue(i,g,x,_){if(x)return void console.error("SetDataValue:Scalar data does not support postfix",x);if(!(g instanceof Be))return void console.error("SetDataValue:Invalid value",g);let v=g.data[0];"i32"===this.typeInfo.name||"u32"===this.typeInfo.name?v=Math.floor(v):"bool"===this.typeInfo.name&&(v=v?1:0),this.data[0]=v}getSubData(i,g,x){return g?(console.error("getSubData:Scalar data does not support postfix",g),null):this}toString(){return`${this.value}`}}function Fe(i,g,x){const _=g.length;return 2===_?"f32"===x?new Me(new Float32Array(g),i.getTypeInfo("vec2f")):"i32"===x||"bool"===x?new Me(new Int32Array(g),i.getTypeInfo("vec2i")):"u32"===x?new Me(new Uint32Array(g),i.getTypeInfo("vec2u")):"f16"===x?new Me(new Float32Array(g),i.getTypeInfo("vec2h")):(console.error(`getSubData:Unknown format ${x}`),null):3===_?"f32"===x?new Me(new Float32Array(g),i.getTypeInfo("vec3f")):"i32"===x||"bool"===x?new Me(new Int32Array(g),i.getTypeInfo("vec3i")):"u32"===x?new Me(new Uint32Array(g),i.getTypeInfo("vec3u")):"f16"===x?new Me(new Float32Array(g),i.getTypeInfo("vec3h")):(console.error(`getSubData:Unknown format ${x}`),null):4===_?"f32"===x?new Me(new Float32Array(g),i.getTypeInfo("vec4f")):"i32"===x||"bool"===x?new Me(new Int32Array(g),i.getTypeInfo("vec4i")):"u32"===x?new Me(new Uint32Array(g),i.getTypeInfo("vec4u")):"f16"===x?new Me(new Float32Array(g),i.getTypeInfo("vec4h")):(console.error(`getSubData:Unknown format ${x}`),null):(console.error(`getSubData:Invalid vector size ${g.length}`),null)}class Me extends Ne{constructor(i,g,x=null){if(super(g,x),i instanceof Float32Array||i instanceof Uint32Array||i instanceof Int32Array)this.data=i;else{const g=this.typeInfo.name;"vec2f"===g||"vec3f"===g||"vec4f"===g?this.data=new Float32Array(i):"vec2i"===g||"vec3i"===g||"vec4i"===g?this.data=new Int32Array(i):"vec2u"===g||"vec3u"===g||"vec4u"===g?this.data=new Uint32Array(i):"vec2h"===g||"vec3h"===g||"vec4h"===g?this.data=new Float32Array(i):"vec2b"===g||"vec3b"===g||"vec4b"===g?this.data=new Int32Array(i):"vec2"===g||"vec3"===g||"vec4"===g?this.data=new Float32Array(i):console.error(`VectorData:Invalid type ${g}`)}}clone(){if(this.data instanceof Float32Array)return new Me(new Float32Array(this.data),this.typeInfo,null);if(this.data instanceof Int32Array)return new Me(new Int32Array(this.data),this.typeInfo,null);if(this.data instanceof Uint32Array)return new Me(new Uint32Array(this.data),this.typeInfo,null);throw"VectorData:Invalid data type"}setDataValue(i,g,x,_){x instanceof pe?console.error("TODO:Set vector postfix"):g instanceof Me?this.data=g.data:console.error("SetDataValue:Invalid value",g)}getSubData(i,g,x){if(null===g)return this;let _=i.getTypeInfo("f32");if(this.typeInfo instanceof a)_=this.typeInfo.format||_;else{const g=this.typeInfo.name;"vec2f"===g||"vec3f"===g||"vec4f"===g?_=i.getTypeInfo("f32"):"vec2i"===g||"vec3i"===g||"vec4i"===g?_=i.getTypeInfo("i32"):"vec2b"===g||"vec3b"===g||"vec4b"===g?_=i.getTypeInfo("bool"):"vec2u"===g||"vec3u"===g||"vec4u"===g?_=i.getTypeInfo("u32"):"vec2h"===g||"vec3h"===g||"vec4h"===g?_=i.getTypeInfo("f16"):console.error(`GetSubData:Unknown type ${g}`)}let v=this;for(;null!==g&&null!==v;){if(g instanceof ve){const b=g.index;let y=-1;if(b instanceof xe){if(!(b.value instanceof Be))return console.error(`GetSubData:Invalid array index ${b.value}`),null;y=b.value.value}else{const g=i.evalExpression(b,x);if(!(g instanceof Be))return console.error("GetSubData:Unknown index type",b),null;y=g.value}if(y<0||y>=v.data.length)return console.error("GetSubData:Index out of range",y),null;if(v.data instanceof Float32Array){const i=new Float32Array(v.data.buffer,v.data.byteOffset+4*y,1);return new Be(i,_)}if(v.data instanceof Int32Array){const i=new Int32Array(v.data.buffer,v.data.byteOffset+4*y,1);return new Be(i,_)}if(v.data instanceof Uint32Array){const i=new Uint32Array(v.data.buffer,v.data.byteOffset+4*y,1);return new Be(i,_)}throw"GetSubData:Invalid data type"}if(!(g instanceof pe))return console.error("GetSubData:Unknown postfix",g),null;{const x=g.value.toLowerCase();if(1===x.length){let i=0;if("x"===x||"r"===x)i=0;else if("y"===x||"g"===x)i=1;else if("z"===x||"b"===x)i=2;else{if("w"!==x&&"a"!==x)return console.error(`GetSubData:Unknown member ${x}`),null;i=3}if(this.data instanceof Float32Array){let g=new Float32Array(this.data.buffer,this.data.byteOffset+4*i,1);return new Be(g,_,this)}if(this.data instanceof Int32Array){let g=new Int32Array(this.data.buffer,this.data.byteOffset+4*i,1);return new Be(g,_,this)}if(this.data instanceof Uint32Array){let g=new Uint32Array(this.data.buffer,this.data.byteOffset+4*i,1);return new Be(g,_,this)}}const b=[];for(const i of x)"x"===i||"r"===i?b.push(this.data[0]):"y"===i||"g"===i?b.push(this.data[1]):"z"===i||"b"===i?b.push(this.data[2]):"w"===i||"a"===i?b.push(this.data[3]):console.error(`GetDataValue:Unknown member ${i}`);v=Fe(i,b,_.name)}g=g.postfix}return v}toString(){let i=`${this.data[0]}`;for(let g=1;g=this.data.length)return console.error("GetDataValue:Index out of range",b),null;const y=_.endsWith("h")?"h":"f";let S;if("mat2x2"===_||"mat2x2f"===_||"mat2x2h"===_||"mat3x2"===_||"mat3x2f"===_||"mat3x2h"===_||"mat4x2"===_||"mat4x2f"===_||"mat4x2h"===_)S=new Me(new Float32Array(this.data.buffer,this.data.byteOffset+2*b*4,2),i.getTypeInfo(`vec2${y}`));else if("mat2x3"===_||"mat2x3f"===_||"mat2x3h"===_||"mat3x3"===_||"mat3x3f"===_||"mat3x3h"===_||"mat4x3"===_||"mat4x3f"===_||"mat4x3h"===_)S=new Me(new Float32Array(this.data.buffer,this.data.byteOffset+3*b*4,3),i.getTypeInfo(`vec3${y}`));else{if("mat2x4"!==_&&"mat2x4f"!==_&&"mat2x4h"!==_&&"mat3x4"!==_&&"mat3x4f"!==_&&"mat3x4h"!==_&&"mat4x4"!==_&&"mat4x4f"!==_&&"mat4x4h"!==_)return console.error(`GetDataValue:Unknown type ${_}`),null;S=new Me(new Float32Array(this.data.buffer,this.data.byteOffset+4*b*4,4),i.getTypeInfo(`vec4${y}`))}return g.postfix?S.getSubData(i,g.postfix,x):S}return console.error("GetDataValue:Invalid postfix",g),null}toString(){let i=`${this.data[0]}`;for(let g=1;g"!==b&&"x32"!==b)if("u32"!==b&&"atomic"!==b)if("bool"!==b){if("vec2f"===b||"vec2h"===b){const i=new Float32Array(this.buffer,_,2);return void(g instanceof Me?(i[0]=g.data[0],i[1]=g.data[1]):(i[0]=g[0],i[1]=g[1]))}if("vec3f"===b||"vec3h"===b){const i=new Float32Array(this.buffer,_,3);return void(g instanceof Me?(i[0]=g.data[0],i[1]=g.data[1],i[2]=g.data[2]):(i[0]=g[0],i[1]=g[1],i[2]=g[2]))}if("vec4f"===b||"vec4h"===b){const i=new Float32Array(this.buffer,_,4);return void(g instanceof Me?(i[0]=g.data[0],i[1]=g.data[1],i[2]=g.data[2],i[3]=g.data[3]):(i[0]=g[0],i[1]=g[1],i[2]=g[2],i[3]=g[3]))}if("vec2i"===b){const i=new Int32Array(this.buffer,_,2);return void(g instanceof Me?(i[0]=g.data[0],i[1]=g.data[1]):(i[0]=g[0],i[1]=g[1]))}if("vec3i"===b){const i=new Int32Array(this.buffer,_,3);return void(g instanceof Me?(i[0]=g.data[0],i[1]=g.data[1],i[2]=g.data[2]):(i[0]=g[0],i[1]=g[1],i[2]=g[2]))}if("vec4i"===b){const i=new Int32Array(this.buffer,_,4);return void(g instanceof Me?(i[0]=g.data[0],i[1]=g.data[1],i[2]=g.data[2],i[3]=g.data[3]):(i[0]=g[0],i[1]=g[1],i[2]=g[2],i[3]=g[3]))}if("vec2u"===b){const i=new Uint32Array(this.buffer,_,2);return void(g instanceof Me?(i[0]=g.data[0],i[1]=g.data[1]):(i[0]=g[0],i[1]=g[1]))}if("vec3u"===b){const i=new Uint32Array(this.buffer,_,3);return void(g instanceof Me?(i[0]=g.data[0],i[1]=g.data[1],i[2]=g.data[2]):(i[0]=g[0],i[1]=g[1],i[2]=g[2]))}if("vec4u"===b){const i=new Uint32Array(this.buffer,_,4);return void(g instanceof Me?(i[0]=g.data[0],i[1]=g.data[1],i[2]=g.data[2],i[3]=g.data[3]):(i[0]=g[0],i[1]=g[1],i[2]=g[2],i[3]=g[3]))}if("vec2b"===b){const i=new Uint32Array(this.buffer,_,2);return void(g instanceof Me?(i[0]=g.data[0],i[1]=g.data[1]):(i[0]=g[0],i[1]=g[1]))}if("vec3b"===b){const i=new Uint32Array(this.buffer,_,3);return void(g instanceof Me?(i[0]=g.data[0],i[1]=g.data[1],i[2]=g.data[2]):(i[0]=g[0],i[1]=g[1],i[2]=g[2]))}if("vec4b"===b){const i=new Uint32Array(this.buffer,_,4);return void(g instanceof Me?(i[0]=g.data[0],i[1]=g.data[1],i[2]=g.data[2],i[3]=g.data[3]):(i[0]=g[0],i[1]=g[1],i[2]=g[2],i[3]=g[3]))}if("mat2x2f"===b||"mat2x2h"===b){const i=new Float32Array(this.buffer,_,4);return void(g instanceof Ue?(i[0]=g.data[0],i[1]=g.data[1],i[2]=g.data[2],i[3]=g.data[3]):(i[0]=g[0],i[1]=g[1],i[2]=g[2],i[3]=g[3]))}if("mat2x3f"===b||"mat2x3h"===b){const i=new Float32Array(this.buffer,_,6);return void(g instanceof Ue?(i[0]=g.data[0],i[1]=g.data[1],i[2]=g.data[2],i[3]=g.data[3],i[4]=g.data[4],i[5]=g.data[5]):(i[0]=g[0],i[1]=g[1],i[2]=g[2],i[3]=g[3],i[4]=g[4],i[5]=g[5]))}if("mat2x4f"===b||"mat2x4h"===b){const i=new Float32Array(this.buffer,_,8);return void(g instanceof Ue?(i[0]=g.data[0],i[1]=g.data[1],i[2]=g.data[2],i[3]=g.data[3],i[4]=g.data[4],i[5]=g.data[5],i[6]=g.data[6],i[7]=g.data[7]):(i[0]=g[0],i[1]=g[1],i[2]=g[2],i[3]=g[3],i[4]=g[4],i[5]=g[5],i[6]=g[6],i[7]=g[7]))}if("mat3x2f"===b||"mat3x2h"===b){const i=new Float32Array(this.buffer,_,6);return void(g instanceof Ue?(i[0]=g.data[0],i[1]=g.data[1],i[2]=g.data[2],i[3]=g.data[3],i[4]=g.data[4],i[5]=g.data[5]):(i[0]=g[0],i[1]=g[1],i[2]=g[2],i[3]=g[3],i[4]=g[4],i[5]=g[5]))}if("mat3x3f"===b||"mat3x3h"===b){const i=new Float32Array(this.buffer,_,9);return void(g instanceof Ue?(i[0]=g.data[0],i[1]=g.data[1],i[2]=g.data[2],i[3]=g.data[3],i[4]=g.data[4],i[5]=g.data[5],i[6]=g.data[6],i[7]=g.data[7],i[8]=g.data[8]):(i[0]=g[0],i[1]=g[1],i[2]=g[2],i[3]=g[3],i[4]=g[4],i[5]=g[5],i[6]=g[6],i[7]=g[7],i[8]=g[8]))}if("mat3x4f"===b||"mat3x4h"===b){const i=new Float32Array(this.buffer,_,12);return void(g instanceof Ue?(i[0]=g.data[0],i[1]=g.data[1],i[2]=g.data[2],i[3]=g.data[3],i[4]=g.data[4],i[5]=g.data[5],i[6]=g.data[6],i[7]=g.data[7],i[8]=g.data[8],i[9]=g.data[9],i[10]=g.data[10],i[11]=g.data[11]):(i[0]=g[0],i[1]=g[1],i[2]=g[2],i[3]=g[3],i[4]=g[4],i[5]=g[5],i[6]=g[6],i[7]=g[7],i[8]=g[8],i[9]=g[9],i[10]=g[10],i[11]=g[11]))}if("mat4x2f"===b||"mat4x2h"===b){const i=new Float32Array(this.buffer,_,8);return void(g instanceof Ue?(i[0]=g.data[0],i[1]=g.data[1],i[2]=g.data[2],i[3]=g.data[3],i[4]=g.data[4],i[5]=g.data[5],i[6]=g.data[6],i[7]=g.data[7]):(i[0]=g[0],i[1]=g[1],i[2]=g[2],i[3]=g[3],i[4]=g[4],i[5]=g[5],i[6]=g[6],i[7]=g[7]))}if("mat4x3f"===b||"mat4x3h"===b){const i=new Float32Array(this.buffer,_,12);return void(g instanceof Ue?(i[0]=g.data[0],i[1]=g.data[1],i[2]=g.data[2],i[3]=g.data[3],i[4]=g.data[4],i[5]=g.data[5],i[6]=g.data[6],i[7]=g.data[7],i[8]=g.data[8],i[9]=g.data[9],i[10]=g.data[10],i[11]=g.data[11]):(i[0]=g[0],i[1]=g[1],i[2]=g[2],i[3]=g[3],i[4]=g[4],i[5]=g[5],i[6]=g[6],i[7]=g[7],i[8]=g[8],i[9]=g[9],i[10]=g[10],i[11]=g[11]))}if("mat4x4f"===b||"mat4x4h"===b){const i=new Float32Array(this.buffer,_,16);return void(g instanceof Ue?(i[0]=g.data[0],i[1]=g.data[1],i[2]=g.data[2],i[3]=g.data[3],i[4]=g.data[4],i[5]=g.data[5],i[6]=g.data[6],i[7]=g.data[7],i[8]=g.data[8],i[9]=g.data[9],i[10]=g.data[10],i[11]=g.data[11],i[12]=g.data[12],i[13]=g.data[13],i[14]=g.data[14],i[15]=g.data[15]):(i[0]=g[0],i[1]=g[1],i[2]=g[2],i[3]=g[3],i[4]=g[4],i[5]=g[5],i[6]=g[6],i[7]=g[7],i[8]=g[8],i[9]=g[9],i[10]=g[10],i[11]=g[11],i[12]=g[12],i[13]=g[13],i[14]=g[14],i[15]=g[15]))}if(g instanceof Pe){if(x===g.typeInfo)return void new Uint8Array(this.buffer,_,g.buffer.byteLength).set(new Uint8Array(g.buffer));console.error("SetDataValue:Type mismatch",b,g.typeInfo.getTypeName())}else console.error(`SetData:Unknown type ${b}`)}else g instanceof Be&&(new Int32Array(this.buffer,_,1)[0]=g.value);else g instanceof Be&&(new Uint32Array(this.buffer,_,1)[0]=g.value);else g instanceof Be&&(new Int32Array(this.buffer,_,1)[0]=g.value);else g instanceof Be&&(new Float32Array(this.buffer,_,1)[0]=g.value)}getSubData(i,g,x){var _,v,b;if(null===g)return this;let y=this.offset,S=this.typeInfo;for(;g;){if(g instanceof ve){const _=g.index,v=_ instanceof fe?i.evalExpression(_,x):_;let b=0;if(v instanceof Be?b=v.value:"number"==typeof v?b=v:console.error("GetDataValue:Invalid index type",_),S instanceof s)y+=b*S.stride,S=S.format;else{const g=S.getTypeName();"mat4x4"===g||"mat4x4f"===g||"mat4x4h"===g?(y+=16*b,S=i.getTypeInfo("vec4f")):console.error(`getDataValue:Type ${S.getTypeName()} is not an array`)}}else{if(!(g instanceof pe))return console.error("GetDataValue:Unknown postfix type",g),null;{const x=g.value;if(S instanceof n){let i=!1;for(const g of S.members)if(g.name===x){y+=g.offset,S=g.type,i=!0;break}if(!i)return console.error(`GetDataValue:Member ${x} not found`),null}else if(S instanceof e){const g=S.getTypeName();if("vec2f"===g||"vec3f"===g||"vec4f"===g||"vec2i"===g||"vec3i"===g||"vec4i"===g||"vec2u"===g||"vec3u"===g||"vec4u"===g||"vec2b"===g||"vec3b"===g||"vec4b"===g||"vec2h"===g||"vec3h"===g||"vec4h"===g||"vec2"===g||"vec3"===g||"vec4"===g){if(x.length>0&&x.length<5){let _="f";const v=[];for(let b=0;b=this.buffer.byteLength)return console.log("Insufficient buffer data"),null;const i=new Float32Array(this.buffer,y,3);v.push(i[w])}else if("vec4f"===g)v.push(new Float32Array(this.buffer,y,4)[w]);else if("vec2i"===g)_="i",v.push(new Int32Array(this.buffer,y,2)[w]);else if("vec3i"===g)_="i",v.push(new Int32Array(this.buffer,y,3)[w]);else if("vec4i"===g)_="i",v.push(new Int32Array(this.buffer,y,4)[w]);else if("vec2u"===g){_="u";const i=new Uint32Array(this.buffer,y,2);v.push(i[w])}else"vec3u"===g?(_="u",v.push(new Uint32Array(this.buffer,y,3)[w])):"vec4u"===g&&(_="u",v.push(new Uint32Array(this.buffer,y,4)[w]))}return 2===v.length?S=i.getTypeInfo(`vec2${_}`):3===v.length?S=i.getTypeInfo(`vec3${_}`):4===v.length?S=i.getTypeInfo(`vec4${_}`):console.error(`GetDataValue:Invalid vector length ${v.length}`),new Me(v,S,null)}return console.error(`GetDataValue:Unknown member ${x}`),null}return console.error(`GetDataValue:Type ${g} is not a struct`),null}}}g=g.postfix}const w=S.getTypeName();return"f32"===w?new Be(new Float32Array(this.buffer,y,1),S,this):"i32"===w?new Be(new Int32Array(this.buffer,y,1),S,this):"u32"===w?new Be(new Uint32Array(this.buffer,y,1),S,this):"vec2f"===w?new Me(new Float32Array(this.buffer,y,2),S,this):"vec3f"===w?new Me(new Float32Array(this.buffer,y,3),S,this):"vec4f"===w?new Me(new Float32Array(this.buffer,y,4),S,this):"vec2i"===w?new Me(new Int32Array(this.buffer,y,2),S,this):"vec3i"===w?new Me(new Int32Array(this.buffer,y,3),S,this):"vec4i"===w?new Me(new Int32Array(this.buffer,y,4),S,this):"vec2u"===w?new Me(new Uint32Array(this.buffer,y,2),S,this):"vec3u"===w?new Me(new Uint32Array(this.buffer,y,3),S,this):"vec4u"===w?new Me(new Uint32Array(this.buffer,y,4),S,this):S instanceof a&&"atomic"===S.name?"u32"===(null===(_=S.format)||void 0===_?void 0:_.name)?new Be(new Uint32Array(this.buffer,y,1)[0],S.format,this):"i32"===(null===(v=S.format)||void 0===v?void 0:v.name)?new Be(new Int32Array(this.buffer,y,1)[0],S.format,this):(console.error(`GetDataValue:Invalid atomic format ${null===(b=S.format)||void 0===b?void 0:b.name}`),null):new Pe(this.buffer,S,y,this)}toString(){let i="";if(this.typeInfo instanceof s)if("f32"===this.typeInfo.format.name){const g=new Float32Array(this.buffer,this.offset);i=`[${g[0]}`;for(let x=1;x0?null!==(i=x[0])&&void 0!==i?i:0:x instanceof Object&&null!==(g=x.width)&&void 0!==g?g:0}get height(){var i,g;const x=this.descriptor.size;return x instanceof Array&&x.length>1?null!==(i=x[1])&&void 0!==i?i:0:x instanceof Object&&null!==(g=x.height)&&void 0!==g?g:0}get depthOrArrayLayers(){var i,g;const x=this.descriptor.size;return x instanceof Array&&x.length>2?null!==(i=x[2])&&void 0!==i?i:0:x instanceof Object&&null!==(g=x.depthOrArrayLayers)&&void 0!==g?g:0}get format(){var i;return this.descriptor&&null!==(i=this.descriptor.format)&&void 0!==i?i:"rgba8unorm"}get sampleCount(){var i;return this.descriptor&&null!==(i=this.descriptor.sampleCount)&&void 0!==i?i:1}get mipLevelCount(){var i;return this.descriptor&&null!==(i=this.descriptor.mipLevelCount)&&void 0!==i?i:1}get dimension(){var i;return this.descriptor&&null!==(i=this.descriptor.dimension)&&void 0!==i?i:"2d"}getMipLevelSize(i){if(i>=this.mipLevelCount)return[0,0,0];const g=[this.width,this.height,this.depthOrArrayLayers];for(let x=0;x>i);return g}get texelByteSize(){const i=this.format,g=In[i];return g?g.isDepthStencil?4:g.bytesPerBlock:0}get bytesPerRow(){return this.width*this.texelByteSize}get isDepthStencil(){const i=this.format,g=In[i];return!!g&&g.isDepthStencil}getGpuSize(){const i=this.format,g=In[i],x=this.width;if(!i||x<=0||!g)return-1;const _=this.height,v=this.depthOrArrayLayers,b=this.dimension;return x/g.blockWidth*("1d"===b?1:_/g.blockHeight)*g.bytesPerBlock*v}getPixel(i,g,x=0,_=0){const v=this.texelByteSize,b=this.bytesPerRow,y=this.height,S=this.data[_];return function(i,g,x,_,v,b,y,S,w){const L=_*(y>>=v)*(b>>=v)+x*y+g*S;switch(w){case"r8unorm":return[I(i,L,"8unorm",1)[0]];case"r8snorm":return[I(i,L,"8snorm",1)[0]];case"r8uint":return[I(i,L,"8uint",1)[0]];case"r8sint":return[I(i,L,"8sint",1)[0]];case"rg8unorm":{const g=I(i,L,"8unorm",2);return[g[0],g[1]]}case"rg8snorm":{const g=I(i,L,"8snorm",2);return[g[0],g[1]]}case"rg8uint":{const g=I(i,L,"8uint",2);return[g[0],g[1]]}case"rg8sint":{const g=I(i,L,"8sint",2);return[g[0],g[1]]}case"rgba8unorm-srgb":case"rgba8unorm":{const g=I(i,L,"8unorm",4);return[g[0],g[1],g[2],g[3]]}case"rgba8snorm":{const g=I(i,L,"8snorm",4);return[g[0],g[1],g[2],g[3]]}case"rgba8uint":{const g=I(i,L,"8uint",4);return[g[0],g[1],g[2],g[3]]}case"rgba8sint":{const g=I(i,L,"8sint",4);return[g[0],g[1],g[2],g[3]]}case"bgra8unorm-srgb":case"bgra8unorm":{const g=I(i,L,"8unorm",4);return[g[2],g[1],g[0],g[3]]}case"r16uint":return[I(i,L,"16uint",1)[0]];case"r16sint":return[I(i,L,"16sint",1)[0]];case"r16float":return[I(i,L,"16float",1)[0]];case"rg16uint":{const g=I(i,L,"16uint",2);return[g[0],g[1]]}case"rg16sint":{const g=I(i,L,"16sint",2);return[g[0],g[1]]}case"rg16float":{const g=I(i,L,"16float",2);return[g[0],g[1]]}case"rgba16uint":{const g=I(i,L,"16uint",4);return[g[0],g[1],g[2],g[3]]}case"rgba16sint":{const g=I(i,L,"16sint",4);return[g[0],g[1],g[2],g[3]]}case"rgba16float":{const g=I(i,L,"16float",4);return[g[0],g[1],g[2],g[3]]}case"r32uint":return[I(i,L,"32uint",1)[0]];case"r32sint":return[I(i,L,"32sint",1)[0]];case"depth16unorm":case"depth24plus":case"depth24plus-stencil8":case"depth32float":case"depth32float-stencil8":case"r32float":return[I(i,L,"32float",1)[0]];case"rg32uint":{const g=I(i,L,"32uint",2);return[g[0],g[1]]}case"rg32sint":{const g=I(i,L,"32sint",2);return[g[0],g[1]]}case"rg32float":{const g=I(i,L,"32float",2);return[g[0],g[1]]}case"rgba32uint":{const g=I(i,L,"32uint",4);return[g[0],g[1],g[2],g[3]]}case"rgba32sint":{const g=I(i,L,"32sint",4);return[g[0],g[1],g[2],g[3]]}case"rgba32float":{const g=I(i,L,"32float",4);return[g[0],g[1],g[2],g[3]]}case"rg11b10ufloat":{const g=new Uint32Array(i.buffer,L,1)[0],x=(4192256&g)>>11,_=(4290772992&g)>>22;return[w$1(2047&g),w$1(x),function(i){const g=112+(i>>5&31)<<23|(31&i)<<18;return Pn[0]=g,Bn[0]}(_),1]}}return null}(new Uint8Array(S),i,g,x,_,y,b,v,this.format)}setPixel(i,g,x,_,v){const b=this.texelByteSize,y=this.bytesPerRow,S=this.height,w=this.data[_];!function(i,g,x,_,v,b,y,S,w,L){const k=_*(y>>=v)*(b>>=v)+x*y+g*S;switch(w){case"r8unorm":return void T(i,k,"8unorm",1,L);case"r8snorm":return void T(i,k,"8snorm",1,L);case"r8uint":return void T(i,k,"8uint",1,L);case"r8sint":return void T(i,k,"8sint",1,L);case"rg8unorm":return void T(i,k,"8unorm",2,L);case"rg8snorm":return void T(i,k,"8snorm",2,L);case"rg8uint":return void T(i,k,"8uint",2,L);case"rg8sint":return void T(i,k,"8sint",2,L);case"rgba8unorm-srgb":case"rgba8unorm":case"bgra8unorm-srgb":case"bgra8unorm":return void T(i,k,"8unorm",4,L);case"rgba8snorm":return void T(i,k,"8snorm",4,L);case"rgba8uint":return void T(i,k,"8uint",4,L);case"rgba8sint":return void T(i,k,"8sint",4,L);case"r16uint":return void T(i,k,"16uint",1,L);case"r16sint":return void T(i,k,"16sint",1,L);case"r16float":return void T(i,k,"16float",1,L);case"rg16uint":return void T(i,k,"16uint",2,L);case"rg16sint":return void T(i,k,"16sint",2,L);case"rg16float":return void T(i,k,"16float",2,L);case"rgba16uint":return void T(i,k,"16uint",4,L);case"rgba16sint":return void T(i,k,"16sint",4,L);case"rgba16float":return void T(i,k,"16float",4,L);case"r32uint":return void T(i,k,"32uint",1,L);case"r32sint":return void T(i,k,"32sint",1,L);case"depth16unorm":case"depth24plus":case"depth24plus-stencil8":case"depth32float":case"depth32float-stencil8":case"r32float":return void T(i,k,"32float",1,L);case"rg32uint":return void T(i,k,"32uint",2,L);case"rg32sint":return void T(i,k,"32sint",2,L);case"rg32float":return void T(i,k,"32float",2,L);case"rgba32uint":return void T(i,k,"32uint",4,L);case"rgba32sint":return void T(i,k,"32sint",4,L);case"rgba32float":return void T(i,k,"32float",4,L);case"rg11b10ufloat":console.error("TODO:rg11b10ufloat not supported for writing")}}(new Uint8Array(w),i,g,x,_,S,y,b,this.format,v)}}(i=>{i[i.token=0]="token",i[i.keyword=1]="keyword",i[i.reserved=2]="reserved"})(An||(An={}));class qe{constructor(i,g,x){this.name=i,this.type=g,this.rule=x}toString(){return this.name}}class He{}Ln=He,He.none=new qe("",An.reserved,""),He.eof=new qe("EOF",An.token,""),He.reserved={asm:new qe("asm",An.reserved,"asm"),bf16:new qe("bf16",An.reserved,"bf16"),do:new qe("do",An.reserved,"do"),enum:new qe("enum",An.reserved,"enum"),f16:new qe("f16",An.reserved,"f16"),f64:new qe("f64",An.reserved,"f64"),handle:new qe("handle",An.reserved,"handle"),i8:new qe("i8",An.reserved,"i8"),i16:new qe("i16",An.reserved,"i16"),i64:new qe("i64",An.reserved,"i64"),mat:new qe("mat",An.reserved,"mat"),premerge:new qe("premerge",An.reserved,"premerge"),regardless:new qe("regardless",An.reserved,"regardless"),typedef:new qe("typedef",An.reserved,"typedef"),u8:new qe("u8",An.reserved,"u8"),u16:new qe("u16",An.reserved,"u16"),u64:new qe("u64",An.reserved,"u64"),unless:new qe("unless",An.reserved,"unless"),using:new qe("using",An.reserved,"using"),vec:new qe("vec",An.reserved,"vec"),void:new qe("void",An.reserved,"void")},He.keywords={array:new qe("array",An.keyword,"array"),atomic:new qe("atomic",An.keyword,"atomic"),bool:new qe("bool",An.keyword,"bool"),f32:new qe("f32",An.keyword,"f32"),i32:new qe("i32",An.keyword,"i32"),mat2x2:new qe("mat2x2",An.keyword,"mat2x2"),mat2x3:new qe("mat2x3",An.keyword,"mat2x3"),mat2x4:new qe("mat2x4",An.keyword,"mat2x4"),mat3x2:new qe("mat3x2",An.keyword,"mat3x2"),mat3x3:new qe("mat3x3",An.keyword,"mat3x3"),mat3x4:new qe("mat3x4",An.keyword,"mat3x4"),mat4x2:new qe("mat4x2",An.keyword,"mat4x2"),mat4x3:new qe("mat4x3",An.keyword,"mat4x3"),mat4x4:new qe("mat4x4",An.keyword,"mat4x4"),ptr:new qe("ptr",An.keyword,"ptr"),sampler:new qe("sampler",An.keyword,"sampler"),sampler_comparison:new qe("sampler_comparison",An.keyword,"sampler_comparison"),struct:new qe("struct",An.keyword,"struct"),texture_1d:new qe("texture_1d",An.keyword,"texture_1d"),texture_2d:new qe("texture_2d",An.keyword,"texture_2d"),texture_2d_array:new qe("texture_2d_array",An.keyword,"texture_2d_array"),texture_3d:new qe("texture_3d",An.keyword,"texture_3d"),texture_cube:new qe("texture_cube",An.keyword,"texture_cube"),texture_cube_array:new qe("texture_cube_array",An.keyword,"texture_cube_array"),texture_multisampled_2d:new qe("texture_multisampled_2d",An.keyword,"texture_multisampled_2d"),texture_storage_1d:new qe("texture_storage_1d",An.keyword,"texture_storage_1d"),texture_storage_2d:new qe("texture_storage_2d",An.keyword,"texture_storage_2d"),texture_storage_2d_array:new qe("texture_storage_2d_array",An.keyword,"texture_storage_2d_array"),texture_storage_3d:new qe("texture_storage_3d",An.keyword,"texture_storage_3d"),texture_depth_2d:new qe("texture_depth_2d",An.keyword,"texture_depth_2d"),texture_depth_2d_array:new qe("texture_depth_2d_array",An.keyword,"texture_depth_2d_array"),texture_depth_cube:new qe("texture_depth_cube",An.keyword,"texture_depth_cube"),texture_depth_cube_array:new qe("texture_depth_cube_array",An.keyword,"texture_depth_cube_array"),texture_depth_multisampled_2d:new qe("texture_depth_multisampled_2d",An.keyword,"texture_depth_multisampled_2d"),texture_external:new qe("texture_external",An.keyword,"texture_external"),u32:new qe("u32",An.keyword,"u32"),vec2:new qe("vec2",An.keyword,"vec2"),vec3:new qe("vec3",An.keyword,"vec3"),vec4:new qe("vec4",An.keyword,"vec4"),bitcast:new qe("bitcast",An.keyword,"bitcast"),block:new qe("block",An.keyword,"block"),break:new qe("break",An.keyword,"break"),case:new qe("case",An.keyword,"case"),continue:new qe("continue",An.keyword,"continue"),continuing:new qe("continuing",An.keyword,"continuing"),default:new qe("default",An.keyword,"default"),diagnostic:new qe("diagnostic",An.keyword,"diagnostic"),discard:new qe("discard",An.keyword,"discard"),else:new qe("else",An.keyword,"else"),enable:new qe("enable",An.keyword,"enable"),fallthrough:new qe("fallthrough",An.keyword,"fallthrough"),false:new qe("false",An.keyword,"false"),fn:new qe("fn",An.keyword,"fn"),for:new qe("for",An.keyword,"for"),function:new qe("function",An.keyword,"function"),if:new qe("if",An.keyword,"if"),let:new qe("let",An.keyword,"let"),const:new qe("const",An.keyword,"const"),loop:new qe("loop",An.keyword,"loop"),while:new qe("while",An.keyword,"while"),private:new qe("private",An.keyword,"private"),read:new qe("read",An.keyword,"read"),read_write:new qe("read_write",An.keyword,"read_write"),return:new qe("return",An.keyword,"return"),requires:new qe("requires",An.keyword,"requires"),storage:new qe("storage",An.keyword,"storage"),switch:new qe("switch",An.keyword,"switch"),true:new qe("true",An.keyword,"true"),alias:new qe("alias",An.keyword,"alias"),type:new qe("type",An.keyword,"type"),uniform:new qe("uniform",An.keyword,"uniform"),var:new qe("var",An.keyword,"var"),override:new qe("override",An.keyword,"override"),workgroup:new qe("workgroup",An.keyword,"workgroup"),write:new qe("write",An.keyword,"write"),r8unorm:new qe("r8unorm",An.keyword,"r8unorm"),r8snorm:new qe("r8snorm",An.keyword,"r8snorm"),r8uint:new qe("r8uint",An.keyword,"r8uint"),r8sint:new qe("r8sint",An.keyword,"r8sint"),r16uint:new qe("r16uint",An.keyword,"r16uint"),r16sint:new qe("r16sint",An.keyword,"r16sint"),r16float:new qe("r16float",An.keyword,"r16float"),rg8unorm:new qe("rg8unorm",An.keyword,"rg8unorm"),rg8snorm:new qe("rg8snorm",An.keyword,"rg8snorm"),rg8uint:new qe("rg8uint",An.keyword,"rg8uint"),rg8sint:new qe("rg8sint",An.keyword,"rg8sint"),r32uint:new qe("r32uint",An.keyword,"r32uint"),r32sint:new qe("r32sint",An.keyword,"r32sint"),r32float:new qe("r32float",An.keyword,"r32float"),rg16uint:new qe("rg16uint",An.keyword,"rg16uint"),rg16sint:new qe("rg16sint",An.keyword,"rg16sint"),rg16float:new qe("rg16float",An.keyword,"rg16float"),rgba8unorm:new qe("rgba8unorm",An.keyword,"rgba8unorm"),rgba8unorm_srgb:new qe("rgba8unorm_srgb",An.keyword,"rgba8unorm_srgb"),rgba8snorm:new qe("rgba8snorm",An.keyword,"rgba8snorm"),rgba8uint:new qe("rgba8uint",An.keyword,"rgba8uint"),rgba8sint:new qe("rgba8sint",An.keyword,"rgba8sint"),bgra8unorm:new qe("bgra8unorm",An.keyword,"bgra8unorm"),bgra8unorm_srgb:new qe("bgra8unorm_srgb",An.keyword,"bgra8unorm_srgb"),rgb10a2unorm:new qe("rgb10a2unorm",An.keyword,"rgb10a2unorm"),rg11b10float:new qe("rg11b10float",An.keyword,"rg11b10float"),rg32uint:new qe("rg32uint",An.keyword,"rg32uint"),rg32sint:new qe("rg32sint",An.keyword,"rg32sint"),rg32float:new qe("rg32float",An.keyword,"rg32float"),rgba16uint:new qe("rgba16uint",An.keyword,"rgba16uint"),rgba16sint:new qe("rgba16sint",An.keyword,"rgba16sint"),rgba16float:new qe("rgba16float",An.keyword,"rgba16float"),rgba32uint:new qe("rgba32uint",An.keyword,"rgba32uint"),rgba32sint:new qe("rgba32sint",An.keyword,"rgba32sint"),rgba32float:new qe("rgba32float",An.keyword,"rgba32float"),static_assert:new qe("static_assert",An.keyword,"static_assert")},He.tokens={decimal_float_literal:new qe("decimal_float_literal",An.token,/((-?[0-9]*\.[0-9]+|-?[0-9]+\.[0-9]*)((e|E)(\+|-)?[0-9]+)?[fh]?)|(-?[0-9]+(e|E)(\+|-)?[0-9]+[fh]?)|(-?[0-9]+[fh])/),hex_float_literal:new qe("hex_float_literal",An.token,/-?0x((([0-9a-fA-F]*\.[0-9a-fA-F]+|[0-9a-fA-F]+\.[0-9a-fA-F]*)((p|P)(\+|-)?[0-9]+[fh]?)?)|([0-9a-fA-F]+(p|P)(\+|-)?[0-9]+[fh]?))/),int_literal:new qe("int_literal",An.token,/-?0x[0-9a-fA-F]+|0i?|-?[1-9][0-9]*i?/),uint_literal:new qe("uint_literal",An.token,/0x[0-9a-fA-F]+u|0u|[1-9][0-9]*u/),name:new qe("name",An.token,/([_\p{XID_Start}][\p{XID_Continue}]+)|([\p{XID_Start}])/u),ident:new qe("ident",An.token,/[_a-zA-Z][0-9a-zA-Z_]*/),and:new qe("and",An.token,"&"),and_and:new qe("and_and",An.token,"&&"),arrow:new qe("arrow ",An.token,"->"),attr:new qe("attr",An.token,"@"),forward_slash:new qe("forward_slash",An.token,"/"),bang:new qe("bang",An.token,"!"),bracket_left:new qe("bracket_left",An.token,"["),bracket_right:new qe("bracket_right",An.token,"]"),brace_left:new qe("brace_left",An.token,"{"),brace_right:new qe("brace_right",An.token,"}"),colon:new qe("colon",An.token,":"),comma:new qe("comma",An.token,","),equal:new qe("equal",An.token,"="),equal_equal:new qe("equal_equal",An.token,"=="),not_equal:new qe("not_equal",An.token,"!="),greater_than:new qe("greater_than",An.token,">"),greater_than_equal:new qe("greater_than_equal",An.token,">="),shift_right:new qe("shift_right",An.token,">>"),less_than:new qe("less_than",An.token,"<"),less_than_equal:new qe("less_than_equal",An.token,"<="),shift_left:new qe("shift_left",An.token,"<<"),modulo:new qe("modulo",An.token,"%"),minus:new qe("minus",An.token,"-"),minus_minus:new qe("minus_minus",An.token,"--"),period:new qe("period",An.token,"."),plus:new qe("plus",An.token,"+"),plus_plus:new qe("plus_plus",An.token,"++"),or:new qe("or",An.token,"|"),or_or:new qe("or_or",An.token,"||"),paren_left:new qe("paren_left",An.token,"("),paren_right:new qe("paren_right",An.token,")"),semicolon:new qe("semicolon",An.token,";"),star:new qe("star",An.token,"*"),tilde:new qe("tilde",An.token,"~"),underscore:new qe("underscore",An.token,"_"),xor:new qe("xor",An.token,"^"),plus_equal:new qe("plus_equal",An.token,"+="),minus_equal:new qe("minus_equal",An.token,"-="),times_equal:new qe("times_equal",An.token,"*="),division_equal:new qe("division_equal",An.token,"/="),modulo_equal:new qe("modulo_equal",An.token,"%="),and_equal:new qe("and_equal",An.token,"&="),or_equal:new qe("or_equal",An.token,"|="),xor_equal:new qe("xor_equal",An.token,"^="),shift_right_equal:new qe("shift_right_equal",An.token,">>="),shift_left_equal:new qe("shift_left_equal",An.token,"<<=")},He.simpleTokens={"@":Ln.tokens.attr,"{":Ln.tokens.brace_left,"}":Ln.tokens.brace_right,":":Ln.tokens.colon,",":Ln.tokens.comma,"(":Ln.tokens.paren_left,")":Ln.tokens.paren_right,";":Ln.tokens.semicolon},He.literalTokens={"&":Ln.tokens.and,"&&":Ln.tokens.and_and,"->":Ln.tokens.arrow,"/":Ln.tokens.forward_slash,"!":Ln.tokens.bang,"[":Ln.tokens.bracket_left,"]":Ln.tokens.bracket_right,"=":Ln.tokens.equal,"==":Ln.tokens.equal_equal,"!=":Ln.tokens.not_equal,">":Ln.tokens.greater_than,">=":Ln.tokens.greater_than_equal,">>":Ln.tokens.shift_right,"<":Ln.tokens.less_than,"<=":Ln.tokens.less_than_equal,"<<":Ln.tokens.shift_left,"%":Ln.tokens.modulo,"-":Ln.tokens.minus,"--":Ln.tokens.minus_minus,".":Ln.tokens.period,"+":Ln.tokens.plus,"++":Ln.tokens.plus_plus,"|":Ln.tokens.or,"||":Ln.tokens.or_or,"*":Ln.tokens.star,"~":Ln.tokens.tilde,_:Ln.tokens.underscore,"^":Ln.tokens.xor,"+=":Ln.tokens.plus_equal,"-=":Ln.tokens.minus_equal,"*=":Ln.tokens.times_equal,"/=":Ln.tokens.division_equal,"%=":Ln.tokens.modulo_equal,"&=":Ln.tokens.and_equal,"|=":Ln.tokens.or_equal,"^=":Ln.tokens.xor_equal,">>=":Ln.tokens.shift_right_equal,"<<=":Ln.tokens.shift_left_equal},He.regexTokens={decimal_float_literal:Ln.tokens.decimal_float_literal,hex_float_literal:Ln.tokens.hex_float_literal,int_literal:Ln.tokens.int_literal,uint_literal:Ln.tokens.uint_literal,ident:Ln.tokens.ident},He.storage_class=[Ln.keywords.function,Ln.keywords.private,Ln.keywords.workgroup,Ln.keywords.uniform,Ln.keywords.storage],He.access_mode=[Ln.keywords.read,Ln.keywords.write,Ln.keywords.read_write],He.sampler_type=[Ln.keywords.sampler,Ln.keywords.sampler_comparison],He.sampled_texture_type=[Ln.keywords.texture_1d,Ln.keywords.texture_2d,Ln.keywords.texture_2d_array,Ln.keywords.texture_3d,Ln.keywords.texture_cube,Ln.keywords.texture_cube_array],He.multisampled_texture_type=[Ln.keywords.texture_multisampled_2d],He.storage_texture_type=[Ln.keywords.texture_storage_1d,Ln.keywords.texture_storage_2d,Ln.keywords.texture_storage_2d_array,Ln.keywords.texture_storage_3d],He.depth_texture_type=[Ln.keywords.texture_depth_2d,Ln.keywords.texture_depth_2d_array,Ln.keywords.texture_depth_cube,Ln.keywords.texture_depth_cube_array,Ln.keywords.texture_depth_multisampled_2d],He.texture_external_type=[Ln.keywords.texture_external],He.any_texture_type=[...Ln.sampled_texture_type,...Ln.multisampled_texture_type,...Ln.storage_texture_type,...Ln.depth_texture_type,...Ln.texture_external_type],He.texel_format=[Ln.keywords.r8unorm,Ln.keywords.r8snorm,Ln.keywords.r8uint,Ln.keywords.r8sint,Ln.keywords.r16uint,Ln.keywords.r16sint,Ln.keywords.r16float,Ln.keywords.rg8unorm,Ln.keywords.rg8snorm,Ln.keywords.rg8uint,Ln.keywords.rg8sint,Ln.keywords.r32uint,Ln.keywords.r32sint,Ln.keywords.r32float,Ln.keywords.rg16uint,Ln.keywords.rg16sint,Ln.keywords.rg16float,Ln.keywords.rgba8unorm,Ln.keywords.rgba8unorm_srgb,Ln.keywords.rgba8snorm,Ln.keywords.rgba8uint,Ln.keywords.rgba8sint,Ln.keywords.bgra8unorm,Ln.keywords.bgra8unorm_srgb,Ln.keywords.rgb10a2unorm,Ln.keywords.rg11b10float,Ln.keywords.rg32uint,Ln.keywords.rg32sint,Ln.keywords.rg32float,Ln.keywords.rgba16uint,Ln.keywords.rgba16sint,Ln.keywords.rgba16float,Ln.keywords.rgba32uint,Ln.keywords.rgba32sint,Ln.keywords.rgba32float],He.const_literal=[Ln.tokens.int_literal,Ln.tokens.uint_literal,Ln.tokens.decimal_float_literal,Ln.tokens.hex_float_literal,Ln.keywords.true,Ln.keywords.false],He.literal_or_ident=[Ln.tokens.ident,Ln.tokens.int_literal,Ln.tokens.uint_literal,Ln.tokens.decimal_float_literal,Ln.tokens.hex_float_literal,Ln.tokens.name],He.element_count_expression=[Ln.tokens.int_literal,Ln.tokens.uint_literal,Ln.tokens.ident],He.template_types=[Ln.keywords.vec2,Ln.keywords.vec3,Ln.keywords.vec4,Ln.keywords.mat2x2,Ln.keywords.mat2x3,Ln.keywords.mat2x4,Ln.keywords.mat3x2,Ln.keywords.mat3x3,Ln.keywords.mat3x4,Ln.keywords.mat4x2,Ln.keywords.mat4x3,Ln.keywords.mat4x4,Ln.keywords.atomic,Ln.keywords.bitcast,...Ln.any_texture_type],He.attribute_name=[Ln.tokens.ident,Ln.keywords.block,Ln.keywords.diagnostic],He.assignment_operators=[Ln.tokens.equal,Ln.tokens.plus_equal,Ln.tokens.minus_equal,Ln.tokens.times_equal,Ln.tokens.division_equal,Ln.tokens.modulo_equal,Ln.tokens.and_equal,Ln.tokens.or_equal,Ln.tokens.xor_equal,Ln.tokens.shift_right_equal,Ln.tokens.shift_left_equal],He.increment_operators=[Ln.tokens.plus_plus,Ln.tokens.minus_minus];class ze{constructor(i,g,x,_,v){this.type=i,this.lexeme=g,this.line=x,this.start=_,this.end=v}toString(){return this.lexeme}isTemplateType(){return-1!=He.template_types.indexOf(this.type)}isArrayType(){return this.type==He.keywords.array}isArrayOrTemplateType(){return this.isArrayType()||this.isTemplateType()}}class Re{constructor(i){this._tokens=[],this._start=0,this._current=0,this._line=1,this._source=null!=i?i:""}scanTokens(){for(;!this._isAtEnd();)if(this._start=this._current,!this.scanToken())throw`Invalid syntax at line ${this._line}`;return this._tokens.push(new ze(He.eof,"",this._line,this._current,this._current)),this._tokens}scanToken(){let i=this._advance();if("\n"==i)return this._line++,!0;if(this._isWhitespace(i))return!0;if("/"==i){if("/"==this._peekAhead()){for(;"\n"!=i;){if(this._isAtEnd())return!0;i=this._advance()}return this._line++,!0}if("*"==this._peekAhead()){this._advance();let g=1;for(;g>0;){if(this._isAtEnd())return!0;if(i=this._advance(),"\n"==i)this._line++;else if("*"==i){if("/"==this._peekAhead()&&(this._advance(),g--,0==g))return!0}else"/"==i&&"*"==this._peekAhead()&&(this._advance(),g++)}return!0}}const g=He.simpleTokens[i];if(g)return this._addToken(g),!0;let x=He.none;const _=this._isAlpha(i),v="_"===i;if(this._isAlphaNumeric(i)){let g=this._peekAhead();for(;this._isAlphaNumeric(g);)i+=this._advance(),g=this._peekAhead()}if(_){const g=He.keywords[i];if(g)return this._addToken(g),!0}if(_||v)return this._addToken(He.tokens.ident),!0;for(;;){let g=this._findType(i);const _=this._peekAhead();if("-"==i&&this._tokens.length>0){if("="==_)return this._current++,i+=_,this._addToken(He.tokens.minus_equal),!0;if("-"==_)return this._current++,i+=_,this._addToken(He.tokens.minus_minus),!0;const x=this._tokens.length-1;if((-1!=He.literal_or_ident.indexOf(this._tokens[x].type)||this._tokens[x].type==He.tokens.paren_right)&&">"!=_)return this._addToken(g),!0}if(">"==i&&(">"==_||"="==_)){let i=!1,x=this._tokens.length-1;for(let g=0;g<5&&x>=0&&-1===He.assignment_operators.indexOf(this._tokens[x].type);++g,--x)if(this._tokens[x].type===He.tokens.less_than){x>0&&this._tokens[x-1].isArrayOrTemplateType()&&(i=!0);break}if(i)return this._addToken(g),!0}if(g===He.none){let _=i,v=0;const b=2;for(let i=0;i=this._source.length}_isAlpha(i){return!this._isNumeric(i)&&!this._isWhitespace(i)&&"_"!==i&&"."!==i&&"("!==i&&")"!==i&&"["!==i&&"]"!==i&&"{"!==i&&"}"!==i&&","!==i&&";"!==i&&":"!==i&&"="!==i&&"!"!==i&&"<"!==i&&">"!==i&&"+"!==i&&"-"!==i&&"*"!==i&&"/"!==i&&"%"!==i&&"&"!==i&&"|"!==i&&"^"!==i&&"~"!==i&&"@"!==i&&"#"!==i&&"?"!==i&&"'"!==i&&"`"!==i&&'"'!==i&&"\\"!==i&&"\n"!==i&&"\r"!==i&&"\t"!==i&&"\0"!==i}_isNumeric(i){return i>="0"&&i<="9"}_isAlphaNumeric(i){return this._isAlpha(i)||this._isNumeric(i)||"_"===i}_isWhitespace(i){return" "==i||"\t"==i||"\r"==i}_advance(i=0){let g=this._source[this._current];return i=i||0,i++,this._current+=i,g}_peekAhead(i=0){return i=i||0,this._current+i>=this._source.length?"\0":this._source[this._current+i]}_addToken(i){const g=this._source.substring(this._start,this._current);this._tokens.push(new ze(i,g,this._line,this._start,this._current))}}function Ge(i){return Array.isArray(i)||(null==i?void 0:i.buffer)instanceof ArrayBuffer}const Gn=new Float32Array(1),kn=new Uint32Array(Gn.buffer),On=new Uint32Array(Gn.buffer),Nn=new Int32Array(1),Vn=new Float32Array(Nn.buffer),Fn=new Uint32Array(Nn.buffer),Hn=new Uint32Array(1),zn=new Float32Array(Hn.buffer),$n=new Int32Array(Hn.buffer);function nt(i,g,x){if(g===x)return i;if("f32"===g){if("i32"===x||"x32"===x)return Gn[0]=i,kn[0];if("u32"===x)return Gn[0]=i,On[0]}else if("i32"===g||"x32"===g){if("f32"===x)return Nn[0]=i,Vn[0];if("u32"===x)return Nn[0]=i,Fn[0]}else if("u32"===g){if("f32"===x)return Hn[0]=i,zn[0];if("i32"===x||"x32"===x)return Hn[0]=i,$n[0]}return console.error(`Unsupported cast from ${g} to ${x}`),i}class st{constructor(i){this.resources=null,this.inUse=!1,this.info=null,this.node=i}}class rt{constructor(i,g){this.align=i,this.size=g}}class at{constructor(){this.uniforms=[],this.storage=[],this.textures=[],this.samplers=[],this.aliases=[],this.overrides=[],this.structs=[],this.entry=new d,this.functions=[],this._types=new Map,this._functions=new Map}_isStorageTexture(i){return"texture_storage_1d"==i.name||"texture_storage_2d"==i.name||"texture_storage_2d_array"==i.name||"texture_storage_3d"==i.name}updateAST(i){for(const g of i)g instanceof D&&this._functions.set(g.name,new st(g));for(const g of i)if(g instanceof oe){const i=this.getTypeInfo(g,null);i instanceof n&&this.structs.push(i)}for(const g of i)if(g instanceof te)this.aliases.push(this._getAliasInfo(g));else{if(g instanceof M){const i=g,x=this._getAttributeNum(i.attributes,"id",0),_=null!=i.type?this.getTypeInfo(i.type,i.attributes):null;this.overrides.push(new h(i.name,_,i.attributes,x));continue}if(this._isUniformVar(g)){const i=g,x=this._getAttributeNum(i.attributes,"group",0),_=this._getAttributeNum(i.attributes,"binding",0),v=this.getTypeInfo(i.type,i.attributes),b=new o(i.name,v,x,_,i.attributes,Mn.Uniform,i.access);b.access||(b.access="read"),this.uniforms.push(b);continue}if(this._isStorageVar(g)){const i=g,x=this._getAttributeNum(i.attributes,"group",0),_=this._getAttributeNum(i.attributes,"binding",0),v=this.getTypeInfo(i.type,i.attributes),b=this._isStorageTexture(v),y=new o(i.name,v,x,_,i.attributes,b?Mn.StorageTexture:Mn.Storage,i.access);y.access||(y.access="read"),this.storage.push(y);continue}if(this._isTextureVar(g)){const i=g,x=this._getAttributeNum(i.attributes,"group",0),_=this._getAttributeNum(i.attributes,"binding",0),v=this.getTypeInfo(i.type,i.attributes),b=this._isStorageTexture(v),y=new o(i.name,v,x,_,i.attributes,b?Mn.StorageTexture:Mn.Texture,i.access);y.access||(y.access="read"),b?this.storage.push(y):this.textures.push(y);continue}if(this._isSamplerVar(g)){const i=g,x=this._getAttributeNum(i.attributes,"group",0),_=this._getAttributeNum(i.attributes,"binding",0),v=this.getTypeInfo(i.type,i.attributes),b=new o(i.name,v,x,_,i.attributes,Mn.Sampler,i.access);this.samplers.push(b);continue}}for(const g of i)if(g instanceof D){const i=this._getAttribute(g,"vertex"),x=this._getAttribute(g,"fragment"),_=this._getAttribute(g,"compute"),v=i||x||_,b=new p(g.name,null==v?void 0:v.name,g.attributes);b.attributes=g.attributes,b.startLine=g.startLine,b.endLine=g.endLine,this.functions.push(b),this._functions.get(g.name).info=b,v&&(this._functions.get(g.name).inUse=!0,b.inUse=!0,b.resources=this._findResources(g,!!v),b.inputs=this._getInputs(g.args),b.outputs=this._getOutputs(g.returnType),this.entry[v.name].push(b)),b.arguments=g.args.map(i=>new f(i.name,this.getTypeInfo(i.type,i.attributes),i.attributes)),b.returnType=g.returnType?this.getTypeInfo(g.returnType,g.attributes):null;continue}for(const i of this._functions.values())i.info&&(i.info.inUse=i.inUse,this._addCalls(i.node,i.info.calls));for(const i of this._functions.values())i.node.search(g=>{var x,_,v;if(g instanceof De){if(g.value)if(Ge(g.value))for(const _ of g.value)for(const g of this.overrides)_===g.name&&(null===(x=i.info)||void 0===x||x.overrides.push(g));else for(const x of this.overrides)g.value===x.name&&(null===(_=i.info)||void 0===_||_.overrides.push(x))}else if(g instanceof ge)for(const x of this.overrides)g.name===x.name&&(null===(v=i.info)||void 0===v||v.overrides.push(x))});for(const i of this.uniforms)this._markStructsInUse(i.type);for(const i of this.storage)this._markStructsInUse(i.type)}getFunctionInfo(i){for(const g of this.functions)if(g.name==i)return g;return null}getStructInfo(i){for(const g of this.structs)if(g.name==i)return g;return null}getOverrideInfo(i){for(const g of this.overrides)if(g.name==i)return g;return null}_markStructsInUse(i){if(i)if(i.isStruct){if(i.inUse=!0,i.members)for(const g of i.members)this._markStructsInUse(g.type)}else if(i.isArray)this._markStructsInUse(i.format);else if(i.isTemplate)i.format&&this._markStructsInUse(i.format);else{const g=this._getAlias(i.name);g&&this._markStructsInUse(g)}}_addCalls(i,g){var x;for(const _ of i.calls){const i=null===(x=this._functions.get(_.name))||void 0===x?void 0:x.info;i&&g.add(i)}}findResource(i,g,x){if(x){for(const _ of this.entry.compute)if(_.name===x)for(const x of _.resources)if(x.group==i&&x.binding==g)return x;for(const _ of this.entry.vertex)if(_.name===x)for(const x of _.resources)if(x.group==i&&x.binding==g)return x;for(const _ of this.entry.fragment)if(_.name===x)for(const x of _.resources)if(x.group==i&&x.binding==g)return x}for(const x of this.uniforms)if(x.group==i&&x.binding==g)return x;for(const x of this.storage)if(x.group==i&&x.binding==g)return x;for(const x of this.textures)if(x.group==i&&x.binding==g)return x;for(const x of this.samplers)if(x.group==i&&x.binding==g)return x;return null}_findResource(i){for(const g of this.uniforms)if(g.name==i)return g;for(const g of this.storage)if(g.name==i)return g;for(const g of this.textures)if(g.name==i)return g;for(const g of this.samplers)if(g.name==i)return g;return null}_markStructsFromAST(i){const g=this.getTypeInfo(i,null);this._markStructsInUse(g)}_findResources(i,g){const x=[],_=this,v=[];return i.search(b=>{if(b instanceof E)v.push({});else if(b instanceof $)v.pop();else if(b instanceof F){const i=b;g&&null!==i.type&&this._markStructsFromAST(i.type),v.length>0&&(v[v.length-1][i.name]=i)}else if(b instanceof de){const i=b;g&&null!==i.type&&this._markStructsFromAST(i.type)}else if(b instanceof U){const i=b;g&&null!==i.type&&this._markStructsFromAST(i.type),v.length>0&&(v[v.length-1][i.name]=i)}else if(b instanceof ge){const i=b;if(v.length>0&&v[v.length-1][i.name])return;const g=_._findResource(i.name);g&&x.push(g)}else if(b instanceof me){const v=b,y=_._functions.get(v.name);y&&(g&&(y.inUse=!0),i.calls.add(y.node),null===y.resources&&(y.resources=_._findResources(y.node,g)),x.push(...y.resources))}else if(b instanceof X){const v=b,y=_._functions.get(v.name);y&&(g&&(y.inUse=!0),i.calls.add(y.node),null===y.resources&&(y.resources=_._findResources(y.node,g)),x.push(...y.resources))}}),[...new Map(x.map(i=>[i.name,i])).values()]}getBindGroups(){const i=[];function t(g,x){g>=i.length&&(i.length=g+1),void 0===i[g]&&(i[g]=[]),x>=i[g].length&&(i[g].length=x+1)}for(const g of this.uniforms)t(g.group,g.binding),i[g.group][g.binding]=g;for(const g of this.storage)t(g.group,g.binding),i[g.group][g.binding]=g;for(const g of this.textures)t(g.group,g.binding),i[g.group][g.binding]=g;for(const g of this.samplers)t(g.group,g.binding),i[g.group][g.binding]=g;return i}_getOutputs(i,g=void 0){if(void 0===g&&(g=[]),i instanceof oe)this._getStructOutputs(i,g);else{const x=this._getOutputInfo(i);null!==x&&g.push(x)}return g}_getStructOutputs(i,g){for(const x of i.members)if(x.type instanceof oe)this._getStructOutputs(x.type,g);else{const i=this._getAttribute(x,"location")||this._getAttribute(x,"builtin");if(null!==i){const _=this.getTypeInfo(x.type,x.type.attributes),v=this._parseInt(i.value),b=new u(x.name,_,i.name,v);g.push(b)}}}_getOutputInfo(i){const g=this._getAttribute(i,"location")||this._getAttribute(i,"builtin");if(null!==g){const x=this.getTypeInfo(i,i.attributes),_=this._parseInt(g.value);return new u("",x,g.name,_)}return null}_getInputs(i,g=void 0){void 0===g&&(g=[]);for(const x of i)if(x.type instanceof oe)this._getStructInputs(x.type,g);else{const i=this._getInputInfo(x);null!==i&&g.push(i)}return g}_getStructInputs(i,g){for(const x of i.members)if(x.type instanceof oe)this._getStructInputs(x.type,g);else{const i=this._getInputInfo(x);null!==i&&g.push(i)}}_getInputInfo(i){const g=this._getAttribute(i,"location")||this._getAttribute(i,"builtin");if(null!==g){const x=this._getAttribute(i,"interpolation"),_=this.getTypeInfo(i.type,i.attributes),v=this._parseInt(g.value),b=new l(i.name,_,g.name,v);return null!==x&&(b.interpolation=this._parseString(x.value)),b}return null}_parseString(i){return i instanceof Array&&(i=i[0]),i}_parseInt(i){i instanceof Array&&(i=i[0]);const g=parseInt(i);return isNaN(g)?i:g}_getAlias(i){for(const g of this.aliases)if(g.name==i)return g.type;return null}_getAliasInfo(i){return new c(i.name,this.getTypeInfo(i.type,null))}getTypeInfoByName(i){for(const g of this.structs)if(g.name==i)return g;for(const g of this.aliases)if(g.name==i)return g.type;return null}getTypeInfo(i,g=null){if(this._types.has(i))return this._types.get(i);if(i instanceof le){const x=i.type?this.getTypeInfo(i.type,i.attributes):null,_=new r(i.name,x,g);return this._types.set(i,_),this._updateTypeInfo(_),_}if(i instanceof ue){const x=i,_=x.format?this.getTypeInfo(x.format,x.attributes):null,v=new s(x.name,g);return v.format=_,v.count=x.count,this._types.set(i,v),this._updateTypeInfo(v),v}if(i instanceof oe){const x=i,_=new n(x.name,g);_.startLine=x.startLine,_.endLine=x.endLine;for(const i of x.members){const g=this.getTypeInfo(i.type,i.attributes);_.members.push(new t(i.name,g,i.attributes))}return this._types.set(i,_),this._updateTypeInfo(_),_}if(i instanceof he){const x=i,_=x.format instanceof ae,v=x.format?_?this.getTypeInfo(x.format,null):new e(x.format,null):null,b=new a(x.name,v,g,x.access);return this._types.set(i,b),this._updateTypeInfo(b),b}if(i instanceof ce){const x=i,_=x.format?this.getTypeInfo(x.format,null):null,v=new a(x.name,_,g,x.access);return this._types.set(i,v),this._updateTypeInfo(v),v}const x=new e(i.name,g);return this._types.set(i,x),this._updateTypeInfo(x),x}_updateTypeInfo(i){var g,x,_;const v=this._getTypeSize(i);if(i.size=null!==(g=null==v?void 0:v.size)&&void 0!==g?g:0,i instanceof s&&i.format){const g=this._getTypeSize(i.format);i.stride=Math.max(null!==(x=null==g?void 0:g.size)&&void 0!==x?x:0,null!==(_=null==g?void 0:g.align)&&void 0!==_?_:0),this._updateTypeInfo(i.format)}i instanceof r&&this._updateTypeInfo(i.format),i instanceof n&&this._updateStructInfo(i)}_updateStructInfo(i){var g;let x=0,_=0,v=0,b=0;for(let y=0,S=i.members.length;yi.name),at._samplerTypes=He.sampler_type.map(i=>i.name);let Kn=0;class ot{constructor(i,g,x){this.id=Kn++,this.name=i,this.value=g,this.node=x}clone(){return new ot(this.name,this.value,this.node)}}class ct{constructor(i){this.id=Kn++,this.name=i.name,this.node=i}clone(){return new ct(this.node)}}class lt{constructor(i){this.parent=null,this.variables=new Map,this.functions=new Map,this.currentFunctionName="",this.id=Kn++,i&&(this.parent=i,this.currentFunctionName=i.currentFunctionName)}getVariable(i){var g;return this.variables.has(i)?null!==(g=this.variables.get(i))&&void 0!==g?g:null:this.parent?this.parent.getVariable(i):null}getFunction(i){var g;return this.functions.has(i)?null!==(g=this.functions.get(i))&&void 0!==g?g:null:this.parent?this.parent.getFunction(i):null}createVariable(i,g,x){this.variables.set(i,new ot(i,g,null!=x?x:null))}setVariable(i,g,x){const _=this.getVariable(i);null!==_?_.value=g:this.createVariable(i,g,x)}getVariableValue(i){var g;const x=this.getVariable(i);return null!==(g=null==x?void 0:x.value)&&void 0!==g?g:null}clone(){return new lt(this)}}class ut{evalExpression(i,g){return null}getTypeInfo(i){return null}getVariableName(i,g){return""}}class ht{constructor(i){this.exec=i}getTypeInfo(i){return this.exec.getTypeInfo(i)}All(i,g){const x=this.exec.evalExpression(i.args[0],g);let _=!0;if(x instanceof Me)return x.data.forEach(i=>{i||(_=!1)}),new Be(_?1:0,this.getTypeInfo("bool"));throw new Error(`All() expects a vector argument. Line ${i.line}`)}Any(i,g){const x=this.exec.evalExpression(i.args[0],g);if(x instanceof Me){const i=x.data.some(i=>i);return new Be(i?1:0,this.getTypeInfo("bool"))}throw new Error(`Any() expects a vector argument. Line ${i.line}`)}Select(i,g){const x=this.exec.evalExpression(i.args[2],g);if(!(x instanceof Be))throw new Error(`Select() expects a bool condition. Line ${i.line}`);return x.value?this.exec.evalExpression(i.args[1],g):this.exec.evalExpression(i.args[0],g)}ArrayLength(i,g){let x=i.args[0];x instanceof ke&&(x=x.right);const _=this.exec.evalExpression(x,g);if(_ instanceof Pe&&0===_.typeInfo.size){const i=_.typeInfo,g=_.buffer.byteLength/i.stride;return new Be(g,this.getTypeInfo("u32"))}return new Be(_.typeInfo.size,this.getTypeInfo("u32"))}Abs(i,g){const x=this.exec.evalExpression(i.args[0],g);if(x instanceof Me)return new Me(x.data.map(i=>Math.abs(i)),x.typeInfo);const _=x;return new Be(Math.abs(_.value),_.typeInfo)}Acos(i,g){const x=this.exec.evalExpression(i.args[0],g);if(x instanceof Me)return new Me(x.data.map(i=>Math.acos(i)),x.typeInfo);const _=x;return new Be(Math.acos(_.value),x.typeInfo)}Acosh(i,g){const x=this.exec.evalExpression(i.args[0],g);if(x instanceof Me)return new Me(x.data.map(i=>Math.acosh(i)),x.typeInfo);const _=x;return new Be(Math.acosh(_.value),x.typeInfo)}Asin(i,g){const x=this.exec.evalExpression(i.args[0],g);if(x instanceof Me)return new Me(x.data.map(i=>Math.asin(i)),x.typeInfo);const _=x;return new Be(Math.asin(_.value),x.typeInfo)}Asinh(i,g){const x=this.exec.evalExpression(i.args[0],g);if(x instanceof Me)return new Me(x.data.map(i=>Math.asinh(i)),x.typeInfo);const _=x;return new Be(Math.asinh(_.value),x.typeInfo)}Atan(i,g){const x=this.exec.evalExpression(i.args[0],g);if(x instanceof Me)return new Me(x.data.map(i=>Math.atan(i)),x.typeInfo);const _=x;return new Be(Math.atan(_.value),x.typeInfo)}Atanh(i,g){const x=this.exec.evalExpression(i.args[0],g);if(x instanceof Me)return new Me(x.data.map(i=>Math.atanh(i)),x.typeInfo);const _=x;return new Be(Math.atanh(_.value),x.typeInfo)}Atan2(i,g){const x=this.exec.evalExpression(i.args[0],g),_=this.exec.evalExpression(i.args[1],g);if(x instanceof Me&&_ instanceof Me)return new Me(x.data.map((i,g)=>Math.atan2(i,_.data[g])),x.typeInfo);const v=x,b=_;return new Be(Math.atan2(v.value,b.value),x.typeInfo)}Ceil(i,g){const x=this.exec.evalExpression(i.args[0],g);if(x instanceof Me)return new Me(x.data.map(i=>Math.ceil(i)),x.typeInfo);const _=x;return new Be(Math.ceil(_.value),x.typeInfo)}_clamp(i,g,x){return Math.min(Math.max(i,g),x)}Clamp(i,g){const x=this.exec.evalExpression(i.args[0],g),_=this.exec.evalExpression(i.args[1],g),v=this.exec.evalExpression(i.args[2],g);if(x instanceof Me&&_ instanceof Me&&v instanceof Me)return new Me(x.data.map((i,g)=>this._clamp(i,_.data[g],v.data[g])),x.typeInfo);const b=x,y=_,S=v;return new Be(this._clamp(b.value,y.value,S.value),x.typeInfo)}Cos(i,g){const x=this.exec.evalExpression(i.args[0],g);if(x instanceof Me)return new Me(x.data.map(i=>Math.cos(i)),x.typeInfo);const _=x;return new Be(Math.cos(_.value),x.typeInfo)}Cosh(i,g){const x=this.exec.evalExpression(i.args[0],g);if(x instanceof Me)return new Me(x.data.map(i=>Math.cosh(i)),x.typeInfo);const _=x;return new Be(Math.cos(_.value),x.typeInfo)}CountLeadingZeros(i,g){const x=this.exec.evalExpression(i.args[0],g);if(x instanceof Me)return new Me(x.data.map(i=>Math.clz32(i)),x.typeInfo);const _=x;return new Be(Math.clz32(_.value),x.typeInfo)}_countOneBits(i){let g=0;for(;0!==i;)1&i&&g++,i>>=1;return g}CountOneBits(i,g){const x=this.exec.evalExpression(i.args[0],g);if(x instanceof Me)return new Me(x.data.map(i=>this._countOneBits(i)),x.typeInfo);const _=x;return new Be(this._countOneBits(_.value),x.typeInfo)}_countTrailingZeros(i){if(0===i)return 32;let g=0;for(;!(1&i);)i>>=1,g++;return g}CountTrailingZeros(i,g){const x=this.exec.evalExpression(i.args[0],g);if(x instanceof Me)return new Me(x.data.map(i=>this._countTrailingZeros(i)),x.typeInfo);const _=x;return new Be(this._countTrailingZeros(_.value),x.typeInfo)}Cross(i,g){const x=this.exec.evalExpression(i.args[0],g),_=this.exec.evalExpression(i.args[1],g);if(x instanceof Me&&_ instanceof Me){if(3!==x.data.length||3!==_.data.length)return console.error(`Cross() expects 3D vectors. Line ${i.line}`),null;const g=x.data,v=_.data;return new Me([g[1]*v[2]-v[1]*g[2],g[2]*v[0]-v[2]*g[0],g[0]*v[1]-v[0]*g[1]],x.typeInfo)}return console.error(`Cross() expects vector arguments. Line ${i.line}`),null}Degrees(i,g){const x=this.exec.evalExpression(i.args[0],g),_=180/Math.PI;return x instanceof Me?new Me(x.data.map(i=>i*_),x.typeInfo):new Be(x.value*_,this.getTypeInfo("f32"))}Determinant(i,g){const x=this.exec.evalExpression(i.args[0],g);if(x instanceof Ue){const i=x.data,g=x.typeInfo.getTypeName(),_=g.endsWith("h")?this.getTypeInfo("f16"):this.getTypeInfo("f32");if("mat2x2"===g||"mat2x2f"===g||"mat2x2h"===g)return new Be(i[0]*i[3]-i[1]*i[2],_);if("mat2x3"===g||"mat2x3f"===g||"mat2x3h"===g)return new Be(i[0]*(i[4]*i[8]-i[5]*i[7])-i[1]*(i[3]*i[8]-i[5]*i[6])+i[2]*(i[3]*i[7]-i[4]*i[6]),_);if("mat2x4"===g||"mat2x4f"===g||"mat2x4h"===g)console.error(`TODO:Determinant for ${g}`);else if("mat3x2"===g||"mat3x2f"===g||"mat3x2h"===g)console.error(`TODO:Determinant for ${g}`);else{if("mat3x3"===g||"mat3x3f"===g||"mat3x3h"===g)return new Be(i[0]*(i[4]*i[8]-i[5]*i[7])-i[1]*(i[3]*i[8]-i[5]*i[6])+i[2]*(i[3]*i[7]-i[4]*i[6]),_);"mat3x4"===g||"mat3x4f"===g||"mat3x4h"===g||"mat4x2"===g||"mat4x2f"===g||"mat4x2h"===g||"mat4x3"===g||"mat4x3f"===g||"mat4x3h"===g?console.error(`TODO:Determinant for ${g}`):"mat4x4"!==g&&"mat4x4f"!==g&&"mat4x4h"!==g||console.error(`TODO:Determinant for ${g}`)}}return console.error(`Determinant expects a matrix argument. Line ${i.line}`),null}Distance(i,g){const x=this.exec.evalExpression(i.args[0],g),_=this.exec.evalExpression(i.args[1],g);if(x instanceof Me&&_ instanceof Me){let i=0;for(let g=0;gMath.exp(i)),x.typeInfo);const _=x;return new Be(Math.exp(_.value),x.typeInfo)}Exp2(i,g){const x=this.exec.evalExpression(i.args[0],g);if(x instanceof Me)return new Me(x.data.map(i=>Math.pow(2,i)),x.typeInfo);const _=x;return new Be(Math.pow(2,_.value),x.typeInfo)}ExtractBits(i,g){const x=this.exec.evalExpression(i.args[0],g),_=this.exec.evalExpression(i.args[1],g),v=this.exec.evalExpression(i.args[2],g);if("u32"!==_.typeInfo.name&&"x32"!==_.typeInfo.name)return console.error(`ExtractBits() expects an i32 offset argument. Line ${i.line}`),null;if("u32"!==v.typeInfo.name&&"x32"!==v.typeInfo.name)return console.error(`ExtractBits() expects an i32 count argument. Line ${i.line}`),null;const b=_.value,y=v.value;if(x instanceof Me)return new Me(x.data.map(i=>i>>b&(1<>b&(1<-i),x.typeInfo)}return console.error(`FaceForward() expects vector arguments. Line ${i.line}`),null}_firstLeadingBit(i){return 0===i?-1:31-Math.clz32(i)}FirstLeadingBit(i,g){const x=this.exec.evalExpression(i.args[0],g);if(x instanceof Me)return new Me(x.data.map(i=>this._firstLeadingBit(i)),x.typeInfo);const _=x;return new Be(this._firstLeadingBit(_.value),x.typeInfo)}_firstTrailingBit(i){return 0===i?-1:Math.log2(i&-i)}FirstTrailingBit(i,g){const x=this.exec.evalExpression(i.args[0],g);if(x instanceof Me)return new Me(x.data.map(i=>this._firstTrailingBit(i)),x.typeInfo);const _=x;return new Be(this._firstTrailingBit(_.value),x.typeInfo)}Floor(i,g){const x=this.exec.evalExpression(i.args[0],g);if(x instanceof Me)return new Me(x.data.map(i=>Math.floor(i)),x.typeInfo);const _=x;return new Be(Math.floor(_.value),x.typeInfo)}Fma(i,g){const x=this.exec.evalExpression(i.args[0],g),_=this.exec.evalExpression(i.args[1],g),v=this.exec.evalExpression(i.args[2],g);if(x instanceof Me&&_ instanceof Me&&v instanceof Me)return x.data.length!==_.data.length||x.data.length!==v.data.length?(console.error(`Fma() expects vectors of the same length. Line ${i.line}`),null):new Me(x.data.map((i,g)=>i*_.data[g]+v.data[g]),x.typeInfo);const b=x,y=_,S=v;return new Be(b.value*y.value+S.value,b.typeInfo)}Fract(i,g){const x=this.exec.evalExpression(i.args[0],g);if(x instanceof Me)return new Me(x.data.map(i=>i-Math.floor(i)),x.typeInfo);const _=x;return new Be(_.value-Math.floor(_.value),x.typeInfo)}Frexp(i,g){return console.error(`TODO:frexp. Line ${i.line}`),null}InsertBits(i,g){const x=this.exec.evalExpression(i.args[0],g),_=this.exec.evalExpression(i.args[1],g),v=this.exec.evalExpression(i.args[2],g),b=this.exec.evalExpression(i.args[3],g);if("u32"!==v.typeInfo.name&&"x32"!==v.typeInfo.name)return console.error(`InsertBits() expects an i32 offset argument. Line ${i.line}`),null;const y=v.value,S=(1<i&w|_.data[g]<1/Math.sqrt(i)),x.typeInfo);const _=x;return new Be(1/Math.sqrt(_.value),x.typeInfo)}Ldexp(i,g){return console.error(`TODO:ldexp. Line ${i.line}`),null}Length(i,g){const x=this.exec.evalExpression(i.args[0],g);if(x instanceof Me){let i=0;return x.data.forEach(g=>{i+=g*g}),new Be(Math.sqrt(i),this.getTypeInfo("f32"))}const _=x;return new Be(Math.abs(_.value),x.typeInfo)}Log(i,g){const x=this.exec.evalExpression(i.args[0],g);if(x instanceof Me)return new Me(x.data.map(i=>Math.log(i)),x.typeInfo);const _=x;return new Be(Math.log(_.value),x.typeInfo)}Log2(i,g){const x=this.exec.evalExpression(i.args[0],g);if(x instanceof Me)return new Me(x.data.map(i=>Math.log2(i)),x.typeInfo);const _=x;return new Be(Math.log2(_.value),x.typeInfo)}Max(i,g){const x=this.exec.evalExpression(i.args[0],g),_=this.exec.evalExpression(i.args[1],g);if(x instanceof Me&&_ instanceof Me)return new Me(x.data.map((i,g)=>Math.max(i,_.data[g])),x.typeInfo);const v=x,b=_;return new Be(Math.max(v.value,b.value),x.typeInfo)}Min(i,g){const x=this.exec.evalExpression(i.args[0],g),_=this.exec.evalExpression(i.args[1],g);if(x instanceof Me&&_ instanceof Me)return new Me(x.data.map((i,g)=>Math.min(i,_.data[g])),x.typeInfo);const v=x,b=_;return new Be(Math.min(v.value,b.value),x.typeInfo)}Mix(i,g){const x=this.exec.evalExpression(i.args[0],g),_=this.exec.evalExpression(i.args[1],g),v=this.exec.evalExpression(i.args[2],g);if(x instanceof Me&&_ instanceof Me&&v instanceof Me)return new Me(x.data.map((i,g)=>x.data[g]*(1-v.data[g])+_.data[g]*v.data[g]),x.typeInfo);const b=_,y=v;return new Be(x.value*(1-y.value)+b.value*y.value,x.typeInfo)}Modf(i,g){const x=this.exec.evalExpression(i.args[0],g),_=this.exec.evalExpression(i.args[1],g);if(x instanceof Me&&_ instanceof Me)return new Me(x.data.map((i,g)=>i%_.data[g]),x.typeInfo);const v=_;return new Be(x.value%v.value,x.typeInfo)}Normalize(i,g){const x=this.exec.evalExpression(i.args[0],g);if(x instanceof Me){const _=this.Length(i,g).value;return new Me(x.data.map(i=>i/_),x.typeInfo)}return console.error(`Normalize() expects a vector argument. Line ${i.line}`),null}Pow(i,g){const x=this.exec.evalExpression(i.args[0],g),_=this.exec.evalExpression(i.args[1],g);if(x instanceof Me&&_ instanceof Me)return new Me(x.data.map((i,g)=>Math.pow(i,_.data[g])),x.typeInfo);const v=x,b=_;return new Be(Math.pow(v.value,b.value),x.typeInfo)}QuantizeToF16(i,g){const x=this.exec.evalExpression(i.args[0],g);return x instanceof Me?new Me(x.data.map(i=>i),x.typeInfo):new Be(x.value,x.typeInfo)}Radians(i,g){const x=this.exec.evalExpression(i.args[0],g);return x instanceof Me?new Me(x.data.map(i=>i*Math.PI/180),x.typeInfo):new Be(x.value*Math.PI/180,this.getTypeInfo("f32"))}Reflect(i,g){let x=this.exec.evalExpression(i.args[0],g),_=this.exec.evalExpression(i.args[1],g);if(x instanceof Me&&_ instanceof Me){const i=this._dot(x.data,_.data);return new Me(x.data.map((g,x)=>g-2*i*_.data[x]),x.typeInfo)}return console.error(`Reflect() expects vector arguments. Line ${i.line}`),null}Refract(i,g){let x=this.exec.evalExpression(i.args[0],g),_=this.exec.evalExpression(i.args[1],g),v=this.exec.evalExpression(i.args[2],g);if(x instanceof Me&&_ instanceof Me&&v instanceof Be){const i=this._dot(_.data,x.data);return new Me(x.data.map((g,x)=>{const b=1-v.value*v.value*(1-i*i);if(b<0)return 0;const y=Math.sqrt(b);return v.value*g-(v.value*i+y)*_.data[x]}),x.typeInfo)}return console.error(`Refract() expects vector arguments and a scalar argument. Line ${i.line}`),null}ReverseBits(i,g){return console.error(`TODO:reverseBits. Line ${i.line}`),null}Round(i,g){const x=this.exec.evalExpression(i.args[0],g);if(x instanceof Me)return new Me(x.data.map(i=>Math.round(i)),x.typeInfo);const _=x;return new Be(Math.round(_.value),x.typeInfo)}Saturate(i,g){const x=this.exec.evalExpression(i.args[0],g);if(x instanceof Me)return new Me(x.data.map(i=>Math.min(Math.max(i,0),1)),x.typeInfo);const _=x;return new Be(Math.min(Math.max(_.value,0),1),x.typeInfo)}Sign(i,g){const x=this.exec.evalExpression(i.args[0],g);if(x instanceof Me)return new Me(x.data.map(i=>Math.sign(i)),x.typeInfo);const _=x;return new Be(Math.sign(_.value),x.typeInfo)}Sin(i,g){const x=this.exec.evalExpression(i.args[0],g);if(x instanceof Me)return new Me(x.data.map(i=>Math.sin(i)),x.typeInfo);const _=x;return new Be(Math.sin(_.value),x.typeInfo)}Sinh(i,g){const x=this.exec.evalExpression(i.args[0],g);if(x instanceof Me)return new Me(x.data.map(i=>Math.sinh(i)),x.typeInfo);const _=x;return new Be(Math.sinh(_.value),x.typeInfo)}_smoothstep(i,g,x){const _=Math.min(Math.max((x-i)/(g-i),0),1);return _*_*(3-2*_)}SmoothStep(i,g){const x=this.exec.evalExpression(i.args[0],g),_=this.exec.evalExpression(i.args[1],g),v=this.exec.evalExpression(i.args[2],g);if(v instanceof Me&&x instanceof Me&&_ instanceof Me)return new Me(v.data.map((i,g)=>this._smoothstep(x.data[g],_.data[g],i)),v.typeInfo);const b=x,y=_,S=v;return new Be(this._smoothstep(b.value,y.value,S.value),v.typeInfo)}Sqrt(i,g){const x=this.exec.evalExpression(i.args[0],g);if(x instanceof Me)return new Me(x.data.map(i=>Math.sqrt(i)),x.typeInfo);const _=x;return new Be(Math.sqrt(_.value),x.typeInfo)}Step(i,g){const x=this.exec.evalExpression(i.args[0],g),_=this.exec.evalExpression(i.args[1],g);if(_ instanceof Me&&x instanceof Me)return new Me(_.data.map((i,g)=>iMath.tan(i)),x.typeInfo);const _=x;return new Be(Math.tan(_.value),x.typeInfo)}Tanh(i,g){const x=this.exec.evalExpression(i.args[0],g);if(x instanceof Me)return new Me(x.data.map(i=>Math.tanh(i)),x.typeInfo);const _=x;return new Be(Math.tanh(_.value),x.typeInfo)}_getTransposeType(i){const g=i.getTypeName();return"mat2x2f"===g||"mat2x2h"===g?i:"mat2x3f"===g?this.getTypeInfo("mat3x2f"):"mat2x3h"===g?this.getTypeInfo("mat3x2h"):"mat2x4f"===g?this.getTypeInfo("mat4x2f"):"mat2x4h"===g?this.getTypeInfo("mat4x2h"):"mat3x2f"===g?this.getTypeInfo("mat2x3f"):"mat3x2h"===g?this.getTypeInfo("mat2x3h"):"mat3x3f"===g||"mat3x3h"===g?i:"mat3x4f"===g?this.getTypeInfo("mat4x3f"):"mat3x4h"===g?this.getTypeInfo("mat4x3h"):"mat4x2f"===g?this.getTypeInfo("mat2x4f"):"mat4x2h"===g?this.getTypeInfo("mat2x4h"):"mat4x3f"===g?this.getTypeInfo("mat3x4f"):"mat4x3h"===g?this.getTypeInfo("mat3x4h"):("mat4x4f"===g||"mat4x4h"===g||console.error(`Invalid matrix type ${g}`),i)}Transpose(i,g){const x=this.exec.evalExpression(i.args[0],g);if(!(x instanceof Ue))return console.error(`Transpose() expects a matrix argument. Line ${i.line}`),null;const _=this._getTransposeType(x.typeInfo);if("mat2x2"===x.typeInfo.name||"mat2x2f"===x.typeInfo.name||"mat2x2h"===x.typeInfo.name){const i=x.data;return new Ue([i[0],i[2],i[1],i[3]],_)}if("mat2x3"===x.typeInfo.name||"mat2x3f"===x.typeInfo.name||"mat2x3h"===x.typeInfo.name){const i=x.data;return new Ue([i[0],i[3],i[6],i[1],i[4],i[7]],_)}if("mat2x4"===x.typeInfo.name||"mat2x4f"===x.typeInfo.name||"mat2x4h"===x.typeInfo.name){const i=x.data;return new Ue([i[0],i[4],i[8],i[12],i[1],i[5],i[9],i[13]],_)}if("mat3x2"===x.typeInfo.name||"mat3x2f"===x.typeInfo.name||"mat3x2h"===x.typeInfo.name){const i=x.data;return new Ue([i[0],i[3],i[1],i[4],i[2],i[5]],_)}if("mat3x3"===x.typeInfo.name||"mat3x3f"===x.typeInfo.name||"mat3x3h"===x.typeInfo.name){const i=x.data;return new Ue([i[0],i[3],i[6],i[1],i[4],i[7],i[2],i[5],i[8]],_)}if("mat3x4"===x.typeInfo.name||"mat3x4f"===x.typeInfo.name||"mat3x4h"===x.typeInfo.name){const i=x.data;return new Ue([i[0],i[4],i[8],i[12],i[1],i[5],i[9],i[13],i[2],i[6],i[10],i[14]],_)}if("mat4x2"===x.typeInfo.name||"mat4x2f"===x.typeInfo.name||"mat4x2h"===x.typeInfo.name){const i=x.data;return new Ue([i[0],i[4],i[1],i[5],i[2],i[6]],_)}if("mat4x3"===x.typeInfo.name||"mat4x3f"===x.typeInfo.name||"mat4x3h"===x.typeInfo.name){const i=x.data;return new Ue([i[0],i[4],i[8],i[1],i[5],i[9],i[2],i[6],i[10]],_)}if("mat4x4"===x.typeInfo.name||"mat4x4f"===x.typeInfo.name||"mat4x4h"===x.typeInfo.name){const i=x.data;return new Ue([i[0],i[4],i[8],i[12],i[1],i[5],i[9],i[13],i[2],i[6],i[10],i[14],i[3],i[7],i[11],i[15]],_)}return console.error(`Invalid matrix type ${x.typeInfo.name}`),null}Trunc(i,g){const x=this.exec.evalExpression(i.args[0],g);if(x instanceof Me)return new Me(x.data.map(i=>Math.trunc(i)),x.typeInfo);const _=x;return new Be(Math.trunc(_.value),x.typeInfo)}Dpdx(i,g){return console.error(`TODO:dpdx. Line ${i.line}`),null}DpdxCoarse(i,g){return console.error(`TODO:dpdxCoarse. Line ${i.line}`),null}DpdxFine(i,g){return console.error("TODO:dpdxFine"),null}Dpdy(i,g){return console.error("TODO:dpdy"),null}DpdyCoarse(i,g){return console.error("TODO:dpdyCoarse"),null}DpdyFine(i,g){return console.error("TODO:dpdyFine"),null}Fwidth(i,g){return console.error("TODO:fwidth"),null}FwidthCoarse(i,g){return console.error("TODO:fwidthCoarse"),null}FwidthFine(i,g){return console.error("TODO:fwidthFine"),null}TextureDimensions(i,g){const x=i.args[0],_=i.args.length>1?this.exec.evalExpression(i.args[1],g).value:0;if(x instanceof ge){const v=x.name,b=g.getVariableValue(v);if(b instanceof We){if(_<0||_>=b.mipLevelCount)return console.error(`Invalid mip level for textureDimensions. Line ${i.line}`),null;const g=b.getMipLevelSize(_),x=b.dimension;return"1d"===x?new Be(g[0],this.getTypeInfo("u32")):"3d"===x?new Me(g,this.getTypeInfo("vec3u")):"2d"===x?new Me(g.slice(0,2),this.getTypeInfo("vec2u")):(console.error(`Invalid texture dimension ${x} not found. Line ${i.line}`),null)}return console.error(`Texture ${v} not found. Line ${i.line}`),null}return console.error(`Invalid texture argument for textureDimensions. Line ${i.line}`),null}TextureGather(i,g){return console.error("TODO:textureGather"),null}TextureGatherCompare(i,g){return console.error("TODO:textureGatherCompare"),null}TextureLoad(i,g){const x=i.args[0],_=this.exec.evalExpression(i.args[1],g),v=i.args.length>2?this.exec.evalExpression(i.args[2],g).value:0;if(!(_ instanceof Me)||2!==_.data.length)return console.error(`Invalid UV argument for textureLoad. Line ${i.line}`),null;if(x instanceof ge){const b=x.name,y=g.getVariableValue(b);if(y instanceof We){const g=Math.floor(_.data[0]),x=Math.floor(_.data[1]);if(g<0||g>=y.width||x<0||x>=y.height)return console.error(`Texture ${b} out of bounds. Line ${i.line}`),null;const S=y.getPixel(g,x,0,v);return null===S?(console.error(`Invalid texture format for textureLoad. Line ${i.line}`),null):new Me(S,this.getTypeInfo("vec4f"))}return console.error(`Texture ${b} not found. Line ${i.line}`),null}return console.error(`Invalid texture argument for textureLoad. Line ${i.line}`),null}TextureNumLayers(i,g){const x=i.args[0];if(x instanceof ge){const _=x.name,v=g.getVariableValue(_);return v instanceof We?new Be(v.depthOrArrayLayers,this.getTypeInfo("u32")):(console.error(`Texture ${_} not found. Line ${i.line}`),null)}return console.error(`Invalid texture argument for textureNumLayers. Line ${i.line}`),null}TextureNumLevels(i,g){const x=i.args[0];if(x instanceof ge){const _=x.name,v=g.getVariableValue(_);return v instanceof We?new Be(v.mipLevelCount,this.getTypeInfo("u32")):(console.error(`Texture ${_} not found. Line ${i.line}`),null)}return console.error(`Invalid texture argument for textureNumLevels. Line ${i.line}`),null}TextureNumSamples(i,g){const x=i.args[0];if(x instanceof ge){const _=x.name,v=g.getVariableValue(_);return v instanceof We?new Be(v.sampleCount,this.getTypeInfo("u32")):(console.error(`Texture ${_} not found. Line ${i.line}`),null)}return console.error(`Invalid texture argument for textureNumSamples. Line ${i.line}`),null}TextureSample(i,g){return console.error("TODO:textureSample"),null}TextureSampleBias(i,g){return console.error("TODO:textureSampleBias"),null}TextureSampleCompare(i,g){return console.error("TODO:textureSampleCompare"),null}TextureSampleCompareLevel(i,g){return console.error("TODO:textureSampleCompareLevel"),null}TextureSampleGrad(i,g){return console.error("TODO:textureSampleGrad"),null}TextureSampleLevel(i,g){return console.error("TODO:textureSampleLevel"),null}TextureSampleBaseClampToEdge(i,g){return console.error("TODO:textureSampleBaseClampToEdge"),null}TextureStore(i,g){const x=i.args[0],_=this.exec.evalExpression(i.args[1],g),v=4===i.args.length?this.exec.evalExpression(i.args[2],g).value:0,b=4===i.args.length?this.exec.evalExpression(i.args[3],g).data:this.exec.evalExpression(i.args[2],g).data;if(4!==b.length)return console.error(`Invalid value argument for textureStore. Line ${i.line}`),null;if(!(_ instanceof Me)||2!==_.data.length)return console.error(`Invalid UV argument for textureStore. Line ${i.line}`),null;if(x instanceof ge){const y=x.name,S=g.getVariableValue(y);if(S instanceof We){const g=S.getMipLevelSize(0),x=Math.floor(_.data[0]),w=Math.floor(_.data[1]);return x<0||x>=g[0]||w<0||w>=g[1]?(console.error(`Texture ${y} out of bounds. Line ${i.line}`),null):(S.setPixel(x,w,0,v,Array.from(b)),null)}return console.error(`Texture ${y} not found. Line ${i.line}`),null}return console.error(`Invalid texture argument for textureStore. Line ${i.line}`),null}AtomicLoad(i,g){let x=i.args[0];x instanceof ke&&(x=x.right);const _=this.exec.getVariableName(x,g);return g.getVariable(_).value.getSubData(this.exec,x.postfix,g)}AtomicStore(i,g){let x=i.args[0];x instanceof ke&&(x=x.right);const _=this.exec.getVariableName(x,g),v=g.getVariable(_);let b=i.args[1];const y=this.exec.evalExpression(b,g),S=v.value.getSubData(this.exec,x.postfix,g);return S instanceof Be&&y instanceof Be&&(S.value=y.value),v.value instanceof Pe&&v.value.setDataValue(this.exec,S,x.postfix,g),null}AtomicAdd(i,g){let x=i.args[0];x instanceof ke&&(x=x.right);const _=this.exec.getVariableName(x,g),v=g.getVariable(_);let b=i.args[1];const y=this.exec.evalExpression(b,g),S=v.value.getSubData(this.exec,x.postfix,g),w=new Be(S.value,S.typeInfo);return S instanceof Be&&y instanceof Be&&(S.value+=y.value),v.value instanceof Pe&&v.value.setDataValue(this.exec,S,x.postfix,g),w}AtomicSub(i,g){let x=i.args[0];x instanceof ke&&(x=x.right);const _=this.exec.getVariableName(x,g),v=g.getVariable(_);let b=i.args[1];const y=this.exec.evalExpression(b,g),S=v.value.getSubData(this.exec,x.postfix,g),w=new Be(S.value,S.typeInfo);return S instanceof Be&&y instanceof Be&&(S.value-=y.value),v.value instanceof Pe&&v.value.setDataValue(this.exec,S,x.postfix,g),w}AtomicMax(i,g){let x=i.args[0];x instanceof ke&&(x=x.right);const _=this.exec.getVariableName(x,g),v=g.getVariable(_);let b=i.args[1];const y=this.exec.evalExpression(b,g),S=v.value.getSubData(this.exec,x.postfix,g),w=new Be(S.value,S.typeInfo);return S instanceof Be&&y instanceof Be&&(S.value=Math.max(S.value,y.value)),v.value instanceof Pe&&v.value.setDataValue(this.exec,S,x.postfix,g),w}AtomicMin(i,g){let x=i.args[0];x instanceof ke&&(x=x.right);const _=this.exec.getVariableName(x,g),v=g.getVariable(_);let b=i.args[1];const y=this.exec.evalExpression(b,g),S=v.value.getSubData(this.exec,x.postfix,g),w=new Be(S.value,S.typeInfo);return S instanceof Be&&y instanceof Be&&(S.value=Math.min(S.value,y.value)),v.value instanceof Pe&&v.value.setDataValue(this.exec,S,x.postfix,g),w}AtomicAnd(i,g){let x=i.args[0];x instanceof ke&&(x=x.right);const _=this.exec.getVariableName(x,g),v=g.getVariable(_);let b=i.args[1];const y=this.exec.evalExpression(b,g),S=v.value.getSubData(this.exec,x.postfix,g),w=new Be(S.value,S.typeInfo);return S instanceof Be&&y instanceof Be&&(S.value=S.value&y.value),v.value instanceof Pe&&v.value.setDataValue(this.exec,S,x.postfix,g),w}AtomicOr(i,g){let x=i.args[0];x instanceof ke&&(x=x.right);const _=this.exec.getVariableName(x,g),v=g.getVariable(_);let b=i.args[1];const y=this.exec.evalExpression(b,g),S=v.value.getSubData(this.exec,x.postfix,g),w=new Be(S.value,S.typeInfo);return S instanceof Be&&y instanceof Be&&(S.value=S.value|y.value),v.value instanceof Pe&&v.value.setDataValue(this.exec,S,x.postfix,g),w}AtomicXor(i,g){let x=i.args[0];x instanceof ke&&(x=x.right);const _=this.exec.getVariableName(x,g),v=g.getVariable(_);let b=i.args[1];const y=this.exec.evalExpression(b,g),S=v.value.getSubData(this.exec,x.postfix,g),w=new Be(S.value,S.typeInfo);return S instanceof Be&&y instanceof Be&&(S.value=S.value^y.value),v.value instanceof Pe&&v.value.setDataValue(this.exec,S,x.postfix,g),w}AtomicExchange(i,g){let x=i.args[0];x instanceof ke&&(x=x.right);const _=this.exec.getVariableName(x,g),v=g.getVariable(_);let b=i.args[1];const y=this.exec.evalExpression(b,g),S=v.value.getSubData(this.exec,x.postfix,g),w=new Be(S.value,S.typeInfo);return S instanceof Be&&y instanceof Be&&(S.value=y.value),v.value instanceof Pe&&v.value.setDataValue(this.exec,S,x.postfix,g),w}AtomicCompareExchangeWeak(i,g){return console.error("TODO:atomicCompareExchangeWeak"),null}Pack4x8snorm(i,g){return console.error("TODO:pack4x8snorm"),null}Pack4x8unorm(i,g){return console.error("TODO:pack4x8unorm"),null}Pack4xI8(i,g){return console.error("TODO:pack4xI8"),null}Pack4xU8(i,g){return console.error("TODO:pack4xU8"),null}Pack4x8Clamp(i,g){return console.error("TODO:pack4x8Clamp"),null}Pack4xU8Clamp(i,g){return console.error("TODO:pack4xU8Clamp"),null}Pack2x16snorm(i,g){return console.error("TODO:pack2x16snorm"),null}Pack2x16unorm(i,g){return console.error("TODO:pack2x16unorm"),null}Pack2x16float(i,g){return console.error("TODO:pack2x16float"),null}Unpack4x8snorm(i,g){return console.error("TODO:unpack4x8snorm"),null}Unpack4x8unorm(i,g){return console.error("TODO:unpack4x8unorm"),null}Unpack4xI8(i,g){return console.error("TODO:unpack4xI8"),null}Unpack4xU8(i,g){return console.error("TODO:unpack4xU8"),null}Unpack2x16snorm(i,g){return console.error("TODO:unpack2x16snorm"),null}Unpack2x16unorm(i,g){return console.error("TODO:unpack2x16unorm"),null}Unpack2x16float(i,g){return console.error("TODO:unpack2x16float"),null}StorageBarrier(i,g){return null}TextureBarrier(i,g){return null}WorkgroupBarrier(i,g){return null}WorkgroupUniformLoad(i,g){return null}SubgroupAdd(i,g){return console.error("TODO:subgroupAdd"),null}SubgroupExclusiveAdd(i,g){return console.error("TODO:subgroupExclusiveAdd"),null}SubgroupInclusiveAdd(i,g){return console.error("TODO:subgroupInclusiveAdd"),null}SubgroupAll(i,g){return console.error("TODO:subgroupAll"),null}SubgroupAnd(i,g){return console.error("TODO:subgroupAnd"),null}SubgroupAny(i,g){return console.error("TODO:subgroupAny"),null}SubgroupBallot(i,g){return console.error("TODO:subgroupBallot"),null}SubgroupBroadcast(i,g){return console.error("TODO:subgroupBroadcast"),null}SubgroupBroadcastFirst(i,g){return console.error("TODO:subgroupBroadcastFirst"),null}SubgroupElect(i,g){return console.error("TODO:subgroupElect"),null}SubgroupMax(i,g){return console.error("TODO:subgroupMax"),null}SubgroupMin(i,g){return console.error("TODO:subgroupMin"),null}SubgroupMul(i,g){return console.error("TODO:subgroupMul"),null}SubgroupExclusiveMul(i,g){return console.error("TODO:subgroupExclusiveMul"),null}SubgroupInclusiveMul(i,g){return console.error("TODO:subgroupInclusiveMul"),null}SubgroupOr(i,g){return console.error("TODO:subgroupOr"),null}SubgroupShuffle(i,g){return console.error("TODO:subgroupShuffle"),null}SubgroupShuffleDown(i,g){return console.error("TODO:subgroupShuffleDown"),null}SubgroupShuffleUp(i,g){return console.error("TODO:subgroupShuffleUp"),null}SubgroupShuffleXor(i,g){return console.error("TODO:subgroupShuffleXor"),null}SubgroupXor(i,g){return console.error("TODO:subgroupXor"),null}QuadBroadcast(i,g){return console.error("TODO:quadBroadcast"),null}QuadSwapDiagonal(i,g){return console.error("TODO:quadSwapDiagonal"),null}QuadSwapX(i,g){return console.error("TODO:quadSwapX"),null}QuadSwapY(i,g){return console.error("TODO:quadSwapY"),null}}const Xn={vec2:2,vec2f:2,vec2i:2,vec2u:2,vec2b:2,vec2h:2,vec3:3,vec3f:3,vec3i:3,vec3u:3,vec3b:3,vec3h:3,vec4:4,vec4f:4,vec4i:4,vec4u:4,vec4b:4,vec4h:4},jn={mat2x2:[2,2,4],mat2x2f:[2,2,4],mat2x2h:[2,2,4],mat2x3:[2,3,6],mat2x3f:[2,3,6],mat2x3h:[2,3,6],mat2x4:[2,4,8],mat2x4f:[2,4,8],mat2x4h:[2,4,8],mat3x2:[3,2,6],mat3x2f:[3,2,6],mat3x2h:[3,2,6],mat3x3:[3,3,9],mat3x3f:[3,3,9],mat3x3h:[3,3,9],mat3x4:[3,4,12],mat3x4f:[3,4,12],mat3x4h:[3,4,12],mat4x2:[4,2,8],mat4x2f:[4,2,8],mat4x2h:[4,2,8],mat4x3:[4,3,12],mat4x3f:[4,3,12],mat4x3h:[4,3,12],mat4x4:[4,4,16],mat4x4f:[4,4,16],mat4x4h:[4,4,16]};class dt extends ut{constructor(i,g){var x;super(),this.ast=null!=i?i:[],this.reflection=new at,this.reflection.updateAST(this.ast),this.context=null!==(x=null==g?void 0:g.clone())&&void 0!==x?x:new lt,this.builtins=new ht(this),this.typeInfo={bool:this.getTypeInfo(ae.bool),i32:this.getTypeInfo(ae.i32),u32:this.getTypeInfo(ae.u32),f32:this.getTypeInfo(ae.f32),f16:this.getTypeInfo(ae.f16),vec2f:this.getTypeInfo(ce.vec2f),vec2u:this.getTypeInfo(ce.vec2u),vec2i:this.getTypeInfo(ce.vec2i),vec2h:this.getTypeInfo(ce.vec2h),vec3f:this.getTypeInfo(ce.vec3f),vec3u:this.getTypeInfo(ce.vec3u),vec3i:this.getTypeInfo(ce.vec3i),vec3h:this.getTypeInfo(ce.vec3h),vec4f:this.getTypeInfo(ce.vec4f),vec4u:this.getTypeInfo(ce.vec4u),vec4i:this.getTypeInfo(ce.vec4i),vec4h:this.getTypeInfo(ce.vec4h),mat2x2f:this.getTypeInfo(ce.mat2x2f),mat2x3f:this.getTypeInfo(ce.mat2x3f),mat2x4f:this.getTypeInfo(ce.mat2x4f),mat3x2f:this.getTypeInfo(ce.mat3x2f),mat3x3f:this.getTypeInfo(ce.mat3x3f),mat3x4f:this.getTypeInfo(ce.mat3x4f),mat4x2f:this.getTypeInfo(ce.mat4x2f),mat4x3f:this.getTypeInfo(ce.mat4x3f),mat4x4f:this.getTypeInfo(ce.mat4x4f)}}getVariableValue(i){var g,x;const _=null!==(x=null===(g=this.context.getVariable(i))||void 0===g?void 0:g.value)&&void 0!==x?x:null;if(null===_)return null;if(_ instanceof Be)return _.value;if(_ instanceof Me)return Array.from(_.data);if(_ instanceof Ue)return Array.from(_.data);if(_ instanceof Pe&&_.typeInfo instanceof s){if("u32"===_.typeInfo.format.name)return Array.from(new Uint32Array(_.buffer,_.offset,_.typeInfo.count));if("i32"===_.typeInfo.format.name)return Array.from(new Int32Array(_.buffer,_.offset,_.typeInfo.count));if("f32"===_.typeInfo.format.name)return Array.from(new Float32Array(_.buffer,_.offset,_.typeInfo.count))}return console.error(`Unsupported return variable type ${_.typeInfo.name}`),null}execute(i){(i=null!=i?i:{}).constants&&this._setOverrides(i.constants,this.context),this._execStatements(this.ast,this.context)}dispatchWorkgroups(i,g,x,_){const v=this.context.clone();(_=null!=_?_:{}).constants&&this._setOverrides(_.constants,v),this._execStatements(this.ast,v);const b=v.getFunction(i);if(!b)return void console.error(`Function ${i} not found`);if("number"==typeof g)g=[g,1,1];else{if(0===g.length)return void console.error("Invalid dispatch count");1===g.length?g=[g[0],1,1]:2===g.length?g=[g[0],g[1],1]:g.length>3&&(g=[g[0],g[1],g[2]])}const y=g[0],S=g[1],w=g[2],L=this.getTypeInfo("vec3u");v.setVariable("@num_workgroups",new Me(g,L));const k=this.reflection.getFunctionInfo(i);null===k&&console.error(`Function ${i} not found in reflection data`);for(const i in x)for(const g in x[i]){const _=x[i][g];v.variables.forEach(x=>{var v;const b=x.node;if(null==b?void 0:b.attributes){let y=null,S=null;for(const i of b.attributes)"binding"===i.name?y=i.value:"group"===i.name&&(S=i.value);if(g==y&&i==S){let y=!1;for(const _ of k.resources)if(_.name===x.name&&_.group===parseInt(i)&&_.binding===parseInt(g)){y=!0;break}if(y)if(void 0!==_.texture&&void 0!==_.descriptor){const i=new We(_.texture,this.getTypeInfo(b.type),_.descriptor,null!==(v=_.texture.view)&&void 0!==v?v:null);x.value=i}else void 0!==_.uniform?x.value=new Pe(_.uniform,this.getTypeInfo(b.type)):x.value=new Pe(_,this.getTypeInfo(b.type))}}})}for(let i=0;i0){const i=x.getVariableValue(g.value[0]);_[0]=i instanceof Be?i.value:parseInt(g.value[0])}if(g.value.length>1){const i=x.getVariableValue(g.value[1]);_[1]=i instanceof Be?i.value:parseInt(g.value[1])}if(g.value.length>2){const i=x.getVariableValue(g.value[2]);_[2]=i instanceof Be?i.value:parseInt(g.value[2])}}const v=this.getTypeInfo("vec3u"),b=this.getTypeInfo("u32");x.setVariable("@workgroup_size",new Me(_,v));const y=_[0],S=_[1],w=_[2];for(let L=0,k=0;L",v=null;if(i.variable instanceof ke){const x=this._getVariableData(i.variable,g),_=this.evalExpression(i.value,g),v=i.operator;if("="===v){if(x instanceof Be||x instanceof Me||x instanceof Ue){if(_ instanceof Be||_ instanceof Me||_ instanceof Ue&&x.data.length===_.data.length)return void x.data.set(_.data);console.error(`Invalid assignment. Line ${i.line}`)}else if(x instanceof Pe&&_ instanceof Pe&&x.buffer.byteLength-x.offset>=_.buffer.byteLength-_.offset)return void(x.buffer.byteLength%4==0?new Uint32Array(x.buffer,x.offset,x.typeInfo.size/4).set(new Uint32Array(_.buffer,_.offset,_.typeInfo.size/4)):new Uint8Array(x.buffer,x.offset,x.typeInfo.size).set(new Uint8Array(_.buffer,_.offset,_.typeInfo.size)));return console.error(`Invalid assignment. Line ${i.line}`),null}if("+="===v)return x instanceof Be||x instanceof Me||x instanceof Ue?_ instanceof Be||_ instanceof Me||_ instanceof Ue?void x.data.set(_.data.map((i,g)=>x.data[g]+i)):void console.error(`Invalid assignment . Line ${i.line}`):void console.error(`Invalid assignment. Line ${i.line}`);if("-="===v)return(x instanceof Be||x instanceof Me||x instanceof Ue)&&(_ instanceof Be||_ instanceof Me||_ instanceof Ue)?void x.data.set(_.data.map((i,g)=>x.data[g]-i)):void console.error(`Invalid assignment. Line ${i.line}`)}if(i.variable instanceof ke){if("*"===i.variable.operator){_=this.getVariableName(i.variable.right,g);const v=g.getVariable(_);if(!(v&&v.value instanceof Oe))return void console.error(`Variable ${_} is not a pointer. Line ${i.line}`);x=v.value.reference;let b=i.variable.postfix;if(!b){let g=i.variable.right;for(;g instanceof ke;){if(g.postfix){b=g.postfix;break}g=g.right}}b&&(x=x.getSubData(this,b,g))}}else{v=i.variable.postfix,_=this.getVariableName(i.variable,g);const b=g.getVariable(_);if(null===b)return void console.error(`Variable ${_} not found. Line ${i.line}`);x=b.value}if(x instanceof Oe&&(x=x.reference),null===x)return void console.error(`Variable ${_} not found. Line ${i.line}`);const b=this.evalExpression(i.value,g),y=i.operator;if("="!==y){const _=x.getSubData(this,v,g);if(_ instanceof Me&&b instanceof Be){const g=_.data,x=b.value;if("+="===y)for(let i=0;i>="===y)for(let i=0;i>=x;else console.error(`Invalid operator ${y}. Line ${i.line}`)}else if(_ instanceof Me&&b instanceof Me){const g=_.data,x=b.data;if(g.length!==x.length)return void console.error(`Vector length mismatch. Line ${i.line}`);if("+="===y)for(let i=0;i>="===y)for(let i=0;i>=x[i];else console.error(`Invalid operator ${y}. Line ${i.line}`)}else{if(!(_ instanceof Be&&b instanceof Be))return void console.error(`Invalid type for ${i.operator} operator. Line ${i.line}`);"+="===y?_.value+=b.value:"-="===y?_.value-=b.value:"*="===y?_.value*=b.value:"/="===y?_.value/=b.value:"%="===y?_.value%=b.value:"&="===y?_.value&=b.value:"|="===y?_.value|=b.value:"^="===y?_.value^=b.value:"<<="===y?_.value<<=b.value:">>="===y?_.value>>=b.value:console.error(`Invalid operator ${y}. Line ${i.line}`)}return void(x instanceof Pe&&x.setDataValue(this,_,v,g))}if(x instanceof Pe)x.setDataValue(this,b,v,g);else if(v){if(!(x instanceof Me||x instanceof Ue))return void console.error(`Variable ${_} is not a vector or matrix. Line ${i.line}`);if(v instanceof ve){const y=this.evalExpression(v.index,g).value;if(x instanceof Me){if(!(b instanceof Be))return void console.error(`Invalid assignment to ${_}. Line ${i.line}`);x.data[y]=b.value}else{if(!(x instanceof Ue))return void console.error(`Invalid assignment to ${_}. Line ${i.line}`);{const y=this.evalExpression(v.index,g).value;if(y<0)return void console.error(`Invalid assignment to ${_}. Line ${i.line}`);if(!(b instanceof Me))return void console.error(`Invalid assignment to ${_}. Line ${i.line}`);{const g=x.typeInfo.getTypeName();if("mat2x2"===g||"mat2x2f"===g||"mat2x2h"===g){if(!(y<2&&2===b.data.length))return void console.error(`Invalid assignment to ${_}. Line ${i.line}`);x.data[2*y]=b.data[0],x.data[2*y+1]=b.data[1]}else if("mat2x3"===g||"mat2x3f"===g||"mat2x3h"===g){if(!(y<2&&3===b.data.length))return void console.error(`Invalid assignment to ${_}. Line ${i.line}`);x.data[3*y]=b.data[0],x.data[3*y+1]=b.data[1],x.data[3*y+2]=b.data[2]}else if("mat2x4"===g||"mat2x4f"===g||"mat2x4h"===g){if(!(y<2&&4===b.data.length))return void console.error(`Invalid assignment to ${_}. Line ${i.line}`);x.data[4*y]=b.data[0],x.data[4*y+1]=b.data[1],x.data[4*y+2]=b.data[2],x.data[4*y+3]=b.data[3]}else if("mat3x2"===g||"mat3x2f"===g||"mat3x2h"===g){if(!(y<3&&2===b.data.length))return void console.error(`Invalid assignment to ${_}. Line ${i.line}`);x.data[2*y]=b.data[0],x.data[2*y+1]=b.data[1]}else if("mat3x3"===g||"mat3x3f"===g||"mat3x3h"===g){if(!(y<3&&3===b.data.length))return void console.error(`Invalid assignment to ${_}. Line ${i.line}`);x.data[3*y]=b.data[0],x.data[3*y+1]=b.data[1],x.data[3*y+2]=b.data[2]}else if("mat3x4"===g||"mat3x4f"===g||"mat3x4h"===g){if(!(y<3&&4===b.data.length))return void console.error(`Invalid assignment to ${_}. Line ${i.line}`);x.data[4*y]=b.data[0],x.data[4*y+1]=b.data[1],x.data[4*y+2]=b.data[2],x.data[4*y+3]=b.data[3]}else if("mat4x2"===g||"mat4x2f"===g||"mat4x2h"===g){if(!(y<4&&2===b.data.length))return void console.error(`Invalid assignment to ${_}. Line ${i.line}`);x.data[2*y]=b.data[0],x.data[2*y+1]=b.data[1]}else if("mat4x3"===g||"mat4x3f"===g||"mat4x3h"===g){if(!(y<4&&3===b.data.length))return void console.error(`Invalid assignment to ${_}. Line ${i.line}`);x.data[3*y]=b.data[0],x.data[3*y+1]=b.data[1],x.data[3*y+2]=b.data[2]}else{if("mat4x4"!==g&&"mat4x4f"!==g&&"mat4x4h"!==g)return void console.error(`Invalid assignment to ${_}. Line ${i.line}`);if(!(y<4&&4===b.data.length))return void console.error(`Invalid assignment to ${_}. Line ${i.line}`);x.data[4*y]=b.data[0],x.data[4*y+1]=b.data[1],x.data[4*y+2]=b.data[2],x.data[4*y+3]=b.data[3]}}}}}else if(v instanceof pe){const g=v.value;if(!(x instanceof Me))return void console.error(`Invalid assignment to ${g}. Variable ${_} is not a vector. Line ${i.line}`);if(b instanceof Be){if(g.length>1)return void console.error(`Invalid assignment to ${g} for variable ${_}. Line ${i.line}`);if("x"===g)x.data[0]=b.value;else if("y"===g){if(x.data.length<2)return void console.error(`Invalid assignment to ${g} for variable ${_}. Line ${i.line}`);x.data[1]=b.value}else if("z"===g){if(x.data.length<3)return void console.error(`Invalid assignment to ${g} for variable ${_}. Line ${i.line}`);x.data[2]=b.value}else if("w"===g){if(x.data.length<4)return void console.error(`Invalid assignment to ${g} for variable ${_}. Line ${i.line}`);x.data[3]=b.value}}else{if(!(b instanceof Me))return void console.error(`Invalid assignment to ${_}. Line ${i.line}`);if(g.length!==b.data.length)return void console.error(`Invalid assignment to ${g} for variable ${_}. Line ${i.line}`);for(let v=0;v+i);return new Me(i,x.typeInfo)}const i=_,g=this._maxFormatTypeInfo([x.typeInfo,x.typeInfo]);return new Be(+i,g)}case"-":{if(Ge(_)){const i=_.map((i,g)=>-i);return new Me(i,x.typeInfo)}const i=_,g=this._maxFormatTypeInfo([x.typeInfo,x.typeInfo]);return new Be(-i,g)}case"!":{if(Ge(_)){const i=_.map((i,g)=>i?0:1);return new Me(i,x.typeInfo)}const i=_,g=this._maxFormatTypeInfo([x.typeInfo,x.typeInfo]);return new Be(i?0:1,g)}case"~":{if(Ge(_)){const i=_.map((i,g)=>~i);return new Me(i,x.typeInfo)}const i=_,g=this._maxFormatTypeInfo([x.typeInfo,x.typeInfo]);return new Be(~i,g)}}return console.error(`Invalid unary operator ${i.operator}. Line ${i.line}`),null}_evalBinaryOp(i,g){const x=this.evalExpression(i.left,g),_=this.evalExpression(i.right,g),v=x instanceof Be?x.value:x instanceof Me||x instanceof Ue?Array.from(x.data):null,b=_ instanceof Be?_.value:_ instanceof Me||_ instanceof Ue?Array.from(_.data):null;switch(i.operator){case"+":{if(Ge(v)&&Ge(b)){const g=v,_=b;if(g.length!==_.length)return console.error(`Vector length mismatch. Line ${i.line}.`),null;const y=g.map((i,g)=>i+_[g]);return new Me(y,x.typeInfo)}if(Ge(v)){const i=b,g=v.map((g,x)=>g+i);return new Me(g,x.typeInfo)}if(Ge(b)){const i=v,g=b.map((g,x)=>i+g);return new Me(g,_.typeInfo)}const g=v,y=b,S=this._maxFormatTypeInfo([x.typeInfo,_.typeInfo]);return new Be(g+y,S)}case"-":{if(Ge(v)&&Ge(b)){const g=v,_=b;if(g.length!==_.length)return console.error(`Vector length mismatch. Line ${i.line}.`),null;const y=g.map((i,g)=>i-_[g]);return new Me(y,x.typeInfo)}if(Ge(v)){const i=b,g=v.map((g,x)=>g-i);return new Me(g,x.typeInfo)}if(Ge(b)){const i=v,g=b.map((g,x)=>i-g);return new Me(g,_.typeInfo)}const g=v,y=b,S=this._maxFormatTypeInfo([x.typeInfo,_.typeInfo]);return new Be(g-y,S)}case"*":{if(Ge(v)&&Ge(b)){const g=v,y=b;if(x instanceof Ue&&_ instanceof Ue){const v=function(i,g,x,_){if(void 0===jn[g.name]||void 0===jn[_.name])return null;const v=jn[g.name][0],b=jn[g.name][1],y=jn[_.name][0];if(v!==jn[_.name][1])return null;const S=new Array(y*b);for(let g=0;gi*y[g]);return new Me(_,x.typeInfo)}}if(Ge(v)){const i=b,g=v.map((g,x)=>g*i);return x instanceof Ue?new Ue(g,x.typeInfo):new Me(g,x.typeInfo)}if(Ge(b)){const i=v,g=b.map((g,x)=>i*g);return _ instanceof Ue?new Ue(g,_.typeInfo):new Me(g,_.typeInfo)}const g=v,y=b,S=this._maxFormatTypeInfo([x.typeInfo,_.typeInfo]);return new Be(g*y,S)}case"%":{if(Ge(v)&&Ge(b)){const g=v,_=b;if(g.length!==_.length)return console.error(`Vector length mismatch. Line ${i.line}.`),null;const y=g.map((i,g)=>i%_[g]);return new Me(y,x.typeInfo)}if(Ge(v)){const i=b,g=v.map((g,x)=>g%i);return new Me(g,x.typeInfo)}if(Ge(b)){const i=v,g=b.map((g,x)=>i%g);return new Me(g,_.typeInfo)}const g=v,y=b,S=this._maxFormatTypeInfo([x.typeInfo,_.typeInfo]);return new Be(g%y,S)}case"/":{if(Ge(v)&&Ge(b)){const g=v,_=b;if(g.length!==_.length)return console.error(`Vector length mismatch. Line ${i.line}.`),null;const y=g.map((i,g)=>i/_[g]);return new Me(y,x.typeInfo)}if(Ge(v)){const i=b,g=v.map((g,x)=>g/i);return new Me(g,x.typeInfo)}if(Ge(b)){const i=v,g=b.map((g,x)=>i/g);return new Me(g,_.typeInfo)}const g=v,y=b,S=this._maxFormatTypeInfo([x.typeInfo,_.typeInfo]);return new Be(g/y,S)}case"&":{if(Ge(v)&&Ge(b)){const g=v,_=b;if(g.length!==_.length)return console.error(`Vector length mismatch. Line ${i.line}.`),null;const y=g.map((i,g)=>i&_[g]);return new Me(y,x.typeInfo)}if(Ge(v)){const i=b,g=v.map((g,x)=>g&i);return new Me(g,x.typeInfo)}if(Ge(b)){const i=v,g=b.map((g,x)=>i&g);return new Me(g,_.typeInfo)}const g=v,y=b,S=this._maxFormatTypeInfo([x.typeInfo,_.typeInfo]);return new Be(g&y,S)}case"|":{if(Ge(v)&&Ge(b)){const g=v,_=b;if(g.length!==_.length)return console.error(`Vector length mismatch. Line ${i.line}.`),null;const y=g.map((i,g)=>i|_[g]);return new Me(y,x.typeInfo)}if(Ge(v)){const i=b,g=v.map((g,x)=>g|i);return new Me(g,x.typeInfo)}if(Ge(b)){const i=v,g=b.map((g,x)=>i|g);return new Me(g,_.typeInfo)}const g=v,y=b,S=this._maxFormatTypeInfo([x.typeInfo,_.typeInfo]);return new Be(g|y,S)}case"^":{if(Ge(v)&&Ge(b)){const g=v,_=b;if(g.length!==_.length)return console.error(`Vector length mismatch. Line ${i.line}.`),null;const y=g.map((i,g)=>i^_[g]);return new Me(y,x.typeInfo)}if(Ge(v)){const i=b,g=v.map((g,x)=>g^i);return new Me(g,x.typeInfo)}if(Ge(b)){const i=v,g=b.map((g,x)=>i^g);return new Me(g,_.typeInfo)}const g=v,y=b,S=this._maxFormatTypeInfo([x.typeInfo,_.typeInfo]);return new Be(g^y,S)}case"<<":{if(Ge(v)&&Ge(b)){const g=v,_=b;if(g.length!==_.length)return console.error(`Vector length mismatch. Line ${i.line}.`),null;const y=g.map((i,g)=>i<<_[g]);return new Me(y,x.typeInfo)}if(Ge(v)){const i=b,g=v.map((g,x)=>g<i<>":{if(Ge(v)&&Ge(b)){const g=v,_=b;if(g.length!==_.length)return console.error(`Vector length mismatch. Line ${i.line}.`),null;const y=g.map((i,g)=>i>>_[g]);return new Me(y,x.typeInfo)}if(Ge(v)){const i=b,g=v.map((g,x)=>g>>i);return new Me(g,x.typeInfo)}if(Ge(b)){const i=v,g=b.map((g,x)=>i>>g);return new Me(g,_.typeInfo)}const g=v,y=b,S=this._maxFormatTypeInfo([x.typeInfo,_.typeInfo]);return new Be(g>>y,S)}case">":if(Ge(v)&&Ge(b)){const g=v,_=b;if(g.length!==_.length)return console.error(`Vector length mismatch. Line ${i.line}.`),null;const y=g.map((i,g)=>i>_[g]?1:0);return new Me(y,x.typeInfo)}if(Ge(v)){const i=b,g=v.map((g,x)=>g>i?1:0);return new Me(g,x.typeInfo)}if(Ge(b)){const i=v,g=b.map((g,x)=>i>g?1:0);return new Me(g,_.typeInfo)}return new Be(v>b?1:0,this.getTypeInfo("bool"));case"<":if(Ge(v)&&Ge(b)){const g=v,_=b;if(g.length!==_.length)return console.error(`Vector length mismatch. Line ${i.line}.`),null;const y=g.map((i,g)=>i<_[g]?1:0);return new Me(y,x.typeInfo)}if(Ge(v)){const i=b,g=v.map((g,x)=>gii===_[g]?1:0);return new Me(y,x.typeInfo)}if(Ge(v)){const i=b,g=v.map((g,x)=>g==i?1:0);return new Me(g,x.typeInfo)}if(Ge(b)){const i=v,g=b.map((g,x)=>i==g?1:0);return new Me(g,_.typeInfo)}return new Be(v===b?1:0,this.getTypeInfo("bool"));case"!=":if(Ge(v)&&Ge(b)){const g=v,_=b;if(g.length!==_.length)return console.error(`Vector length mismatch. Line ${i.line}.`),null;const y=g.map((i,g)=>i!==_[g]?1:0);return new Me(y,x.typeInfo)}if(Ge(v)){const i=b,g=v.map((g,x)=>g!==i?1:0);return new Me(g,x.typeInfo)}if(Ge(b)){const i=v,g=b.map((g,x)=>i!==g?1:0);return new Me(g,_.typeInfo)}return new Be(v!==b?1:0,this.getTypeInfo("bool"));case">=":if(Ge(v)&&Ge(b)){const g=v,_=b;if(g.length!==_.length)return console.error(`Vector length mismatch. Line ${i.line}.`),null;const y=g.map((i,g)=>i>=_[g]?1:0);return new Me(y,x.typeInfo)}if(Ge(v)){const i=b,g=v.map((g,x)=>g>=i?1:0);return new Me(g,x.typeInfo)}if(Ge(b)){const i=v,g=b.map((g,x)=>i>=g?1:0);return new Me(g,_.typeInfo)}return new Be(v>=b?1:0,this.getTypeInfo("bool"));case"<=":if(Ge(v)&&Ge(b)){const g=v,_=b;if(g.length!==_.length)return console.error(`Vector length mismatch. Line ${i.line}.`),null;const y=g.map((i,g)=>i<=_[g]?1:0);return new Me(y,x.typeInfo)}if(Ge(v)){const i=b,g=v.map((g,x)=>g<=i?1:0);return new Me(g,x.typeInfo)}if(Ge(b)){const i=v,g=b.map((g,x)=>i<=g?1:0);return new Me(g,_.typeInfo)}return new Be(v<=b?1:0,this.getTypeInfo("bool"));case"&&":if(Ge(v)&&Ge(b)){const g=v,_=b;if(g.length!==_.length)return console.error(`Vector length mismatch. Line ${i.line}.`),null;const y=g.map((i,g)=>i&&_[g]?1:0);return new Me(y,x.typeInfo)}if(Ge(v)){const i=b,g=v.map((g,x)=>g&&i?1:0);return new Me(g,x.typeInfo)}if(Ge(b)){const i=v,g=b.map((g,x)=>i&&g?1:0);return new Me(g,_.typeInfo)}return new Be(v&&b?1:0,this.getTypeInfo("bool"));case"||":if(Ge(v)&&Ge(b)){const g=v,_=b;if(g.length!==_.length)return console.error(`Vector length mismatch. Line ${i.line}.`),null;const y=g.map((i,g)=>i||_[g]?1:0);return new Me(y,x.typeInfo)}if(Ge(v)){const i=b,g=v.map((g,x)=>g||i?1:0);return new Me(g,x.typeInfo)}if(Ge(b)){const i=v,g=b.map((g,x)=>i||g?1:0);return new Me(g,_.typeInfo)}return new Be(v||b?1:0,this.getTypeInfo("bool"))}return console.error(`Unknown operator ${i.operator}. Line ${i.line}`),null}_evalCall(i,g){if(null!==i.cachedReturnValue)return i.cachedReturnValue;const x=g.clone();x.currentFunctionName=i.name;const _=g.getFunction(i.name);if(!_)return i.isBuiltin?this._callBuiltinFunction(i,x):this.getTypeInfo(i.name)?this._evalCreate(i,g):(console.error(`Unknown function "${i.name}". Line ${i.line}`),null);for(let g=0;g<_.node.args.length;++g){const v=_.node.args[g],b=this.evalExpression(i.args[g],x);x.createVariable(v.name,b,v)}return this._execStatements(_.node.body,x)}_callBuiltinFunction(i,g){switch(i.name){case"all":return this.builtins.All(i,g);case"any":return this.builtins.Any(i,g);case"select":return this.builtins.Select(i,g);case"arrayLength":return this.builtins.ArrayLength(i,g);case"abs":return this.builtins.Abs(i,g);case"acos":return this.builtins.Acos(i,g);case"acosh":return this.builtins.Acosh(i,g);case"asin":return this.builtins.Asin(i,g);case"asinh":return this.builtins.Asinh(i,g);case"atan":return this.builtins.Atan(i,g);case"atanh":return this.builtins.Atanh(i,g);case"atan2":return this.builtins.Atan2(i,g);case"ceil":return this.builtins.Ceil(i,g);case"clamp":return this.builtins.Clamp(i,g);case"cos":return this.builtins.Cos(i,g);case"cosh":return this.builtins.Cosh(i,g);case"countLeadingZeros":return this.builtins.CountLeadingZeros(i,g);case"countOneBits":return this.builtins.CountOneBits(i,g);case"countTrailingZeros":return this.builtins.CountTrailingZeros(i,g);case"cross":return this.builtins.Cross(i,g);case"degrees":return this.builtins.Degrees(i,g);case"determinant":return this.builtins.Determinant(i,g);case"distance":return this.builtins.Distance(i,g);case"dot":return this.builtins.Dot(i,g);case"dot4U8Packed":return this.builtins.Dot4U8Packed(i,g);case"dot4I8Packed":return this.builtins.Dot4I8Packed(i,g);case"exp":return this.builtins.Exp(i,g);case"exp2":return this.builtins.Exp2(i,g);case"extractBits":return this.builtins.ExtractBits(i,g);case"faceForward":return this.builtins.FaceForward(i,g);case"firstLeadingBit":return this.builtins.FirstLeadingBit(i,g);case"firstTrailingBit":return this.builtins.FirstTrailingBit(i,g);case"floor":return this.builtins.Floor(i,g);case"fma":return this.builtins.Fma(i,g);case"fract":return this.builtins.Fract(i,g);case"frexp":return this.builtins.Frexp(i,g);case"insertBits":return this.builtins.InsertBits(i,g);case"inverseSqrt":return this.builtins.InverseSqrt(i,g);case"ldexp":return this.builtins.Ldexp(i,g);case"length":return this.builtins.Length(i,g);case"log":return this.builtins.Log(i,g);case"log2":return this.builtins.Log2(i,g);case"max":return this.builtins.Max(i,g);case"min":return this.builtins.Min(i,g);case"mix":return this.builtins.Mix(i,g);case"modf":return this.builtins.Modf(i,g);case"normalize":return this.builtins.Normalize(i,g);case"pow":return this.builtins.Pow(i,g);case"quantizeToF16":return this.builtins.QuantizeToF16(i,g);case"radians":return this.builtins.Radians(i,g);case"reflect":return this.builtins.Reflect(i,g);case"refract":return this.builtins.Refract(i,g);case"reverseBits":return this.builtins.ReverseBits(i,g);case"round":return this.builtins.Round(i,g);case"saturate":return this.builtins.Saturate(i,g);case"sign":return this.builtins.Sign(i,g);case"sin":return this.builtins.Sin(i,g);case"sinh":return this.builtins.Sinh(i,g);case"smoothstep":return this.builtins.SmoothStep(i,g);case"sqrt":return this.builtins.Sqrt(i,g);case"step":return this.builtins.Step(i,g);case"tan":return this.builtins.Tan(i,g);case"tanh":return this.builtins.Tanh(i,g);case"transpose":return this.builtins.Transpose(i,g);case"trunc":return this.builtins.Trunc(i,g);case"dpdx":return this.builtins.Dpdx(i,g);case"dpdxCoarse":return this.builtins.DpdxCoarse(i,g);case"dpdxFine":return this.builtins.DpdxFine(i,g);case"dpdy":return this.builtins.Dpdy(i,g);case"dpdyCoarse":return this.builtins.DpdyCoarse(i,g);case"dpdyFine":return this.builtins.DpdyFine(i,g);case"fwidth":return this.builtins.Fwidth(i,g);case"fwidthCoarse":return this.builtins.FwidthCoarse(i,g);case"fwidthFine":return this.builtins.FwidthFine(i,g);case"textureDimensions":return this.builtins.TextureDimensions(i,g);case"textureGather":return this.builtins.TextureGather(i,g);case"textureGatherCompare":return this.builtins.TextureGatherCompare(i,g);case"textureLoad":return this.builtins.TextureLoad(i,g);case"textureNumLayers":return this.builtins.TextureNumLayers(i,g);case"textureNumLevels":return this.builtins.TextureNumLevels(i,g);case"textureNumSamples":return this.builtins.TextureNumSamples(i,g);case"textureSample":return this.builtins.TextureSample(i,g);case"textureSampleBias":return this.builtins.TextureSampleBias(i,g);case"textureSampleCompare":return this.builtins.TextureSampleCompare(i,g);case"textureSampleCompareLevel":return this.builtins.TextureSampleCompareLevel(i,g);case"textureSampleGrad":return this.builtins.TextureSampleGrad(i,g);case"textureSampleLevel":return this.builtins.TextureSampleLevel(i,g);case"textureSampleBaseClampToEdge":return this.builtins.TextureSampleBaseClampToEdge(i,g);case"textureStore":return this.builtins.TextureStore(i,g);case"atomicLoad":return this.builtins.AtomicLoad(i,g);case"atomicStore":return this.builtins.AtomicStore(i,g);case"atomicAdd":return this.builtins.AtomicAdd(i,g);case"atomicSub":return this.builtins.AtomicSub(i,g);case"atomicMax":return this.builtins.AtomicMax(i,g);case"atomicMin":return this.builtins.AtomicMin(i,g);case"atomicAnd":return this.builtins.AtomicAnd(i,g);case"atomicOr":return this.builtins.AtomicOr(i,g);case"atomicXor":return this.builtins.AtomicXor(i,g);case"atomicExchange":return this.builtins.AtomicExchange(i,g);case"atomicCompareExchangeWeak":return this.builtins.AtomicCompareExchangeWeak(i,g);case"pack4x8snorm":return this.builtins.Pack4x8snorm(i,g);case"pack4x8unorm":return this.builtins.Pack4x8unorm(i,g);case"pack4xI8":return this.builtins.Pack4xI8(i,g);case"pack4xU8":return this.builtins.Pack4xU8(i,g);case"pack4x8Clamp":return this.builtins.Pack4x8Clamp(i,g);case"pack4xU8Clamp":return this.builtins.Pack4xU8Clamp(i,g);case"pack2x16snorm":return this.builtins.Pack2x16snorm(i,g);case"pack2x16unorm":return this.builtins.Pack2x16unorm(i,g);case"pack2x16float":return this.builtins.Pack2x16float(i,g);case"unpack4x8snorm":return this.builtins.Unpack4x8snorm(i,g);case"unpack4x8unorm":return this.builtins.Unpack4x8unorm(i,g);case"unpack4xI8":return this.builtins.Unpack4xI8(i,g);case"unpack4xU8":return this.builtins.Unpack4xU8(i,g);case"unpack2x16snorm":return this.builtins.Unpack2x16snorm(i,g);case"unpack2x16unorm":return this.builtins.Unpack2x16unorm(i,g);case"unpack2x16float":return this.builtins.Unpack2x16float(i,g);case"storageBarrier":return this.builtins.StorageBarrier(i,g);case"textureBarrier":return this.builtins.TextureBarrier(i,g);case"workgroupBarrier":return this.builtins.WorkgroupBarrier(i,g);case"workgroupUniformLoad":return this.builtins.WorkgroupUniformLoad(i,g);case"subgroupAdd":return this.builtins.SubgroupAdd(i,g);case"subgroupExclusiveAdd":return this.builtins.SubgroupExclusiveAdd(i,g);case"subgroupInclusiveAdd":return this.builtins.SubgroupInclusiveAdd(i,g);case"subgroupAll":return this.builtins.SubgroupAll(i,g);case"subgroupAnd":return this.builtins.SubgroupAnd(i,g);case"subgroupAny":return this.builtins.SubgroupAny(i,g);case"subgroupBallot":return this.builtins.SubgroupBallot(i,g);case"subgroupBroadcast":return this.builtins.SubgroupBroadcast(i,g);case"subgroupBroadcastFirst":return this.builtins.SubgroupBroadcastFirst(i,g);case"subgroupElect":return this.builtins.SubgroupElect(i,g);case"subgroupMax":return this.builtins.SubgroupMax(i,g);case"subgroupMin":return this.builtins.SubgroupMin(i,g);case"subgroupMul":return this.builtins.SubgroupMul(i,g);case"subgroupExclusiveMul":return this.builtins.SubgroupExclusiveMul(i,g);case"subgroupInclusiveMul":return this.builtins.SubgroupInclusiveMul(i,g);case"subgroupOr":return this.builtins.SubgroupOr(i,g);case"subgroupShuffle":return this.builtins.SubgroupShuffle(i,g);case"subgroupShuffleDown":return this.builtins.SubgroupShuffleDown(i,g);case"subgroupShuffleUp":return this.builtins.SubgroupShuffleUp(i,g);case"subgroupShuffleXor":return this.builtins.SubgroupShuffleXor(i,g);case"subgroupXor":return this.builtins.SubgroupXor(i,g);case"quadBroadcast":return this.builtins.QuadBroadcast(i,g);case"quadSwapDiagonal":return this.builtins.QuadSwapDiagonal(i,g);case"quadSwapX":return this.builtins.QuadSwapX(i,g);case"quadSwapY":return this.builtins.QuadSwapY(i,g)}const x=g.getFunction(i.name);if(x){const _=g.clone();for(let g=0;gv?b.slice(0,v):b,x).getSubData(this,i.postfix,g)}_callConstructorMatrix(i,g){const x=this.getTypeInfo(i.type),_=i.type.getTypeName(),v=jn[_];if(void 0===v)return console.error(`Invalid matrix constructor ${_}. Line ${i.line}`),null;const b=[];if(i instanceof xe)if(i.isVector){const g=i.vectorValue;for(const i of g)b.push(i)}else b.push(i.scalarValue);else if(i.args)for(const x of i.args){const i=this.evalExpression(x,g);i instanceof Me?b.push(...i.data):i instanceof Be?b.push(i.value):i instanceof Ue&&b.push(...i.data)}if(x instanceof a&&null===x.format&&(x.format=this.getTypeInfo("f32")),0===b.length){const _=new Array(v[2]).fill(0);return new Ue(_,x).getSubData(this,i.postfix,g)}return b.length!==v[2]?(console.error(`Invalid matrix constructor. Line ${i.line}`),null):new Ue(b,x).getSubData(this,i.postfix,g)}}dt._breakObj=new Ne(new e("BREAK",null),null),dt._continueObj=new Ne(new e("CONTINUE",null),null),dt._priority=new Map([["f32",0],["f16",1],["u32",2],["i32",3],["x32",3]]);class mt{constructor(){this.constants=new Map,this.aliases=new Map,this.structs=new Map}}class gt{constructor(){this._tokens=[],this._current=0,this._currentLine=1,this._deferArrayCountEval=[],this._currentLoop=[],this._context=new mt,this._exec=new dt,this._forwardTypeCount=0}parse(i){this._initialize(i),this._deferArrayCountEval.length=0;const g=[];for(;!this._isAtEnd();){const i=this._global_decl_or_directive();if(!i)break;g.push(i)}if(this._deferArrayCountEval.length>0){for(const g of this._deferArrayCountEval){const x=g.arrayType,_=g.countNode;if(_ instanceof ge){const g=_.name,v=this._context.constants.get(g);if(v)try{const i=v.constEvaluate(this._exec);x.count=i}catch(i){}}}this._deferArrayCountEval.length=0}if(this._forwardTypeCount>0)for(const i of g)i.search(i=>{i instanceof Ce||i instanceof le?i.type=this._forwardType(i.type):i instanceof ue?i.format=this._forwardType(i.format):i instanceof F||i instanceof U||i instanceof P?i.type=this._forwardType(i.type):i instanceof D?i.returnType=this._forwardType(i.returnType):i instanceof $e&&(i.type=this._forwardType(i.type))});return g}_forwardType(i){if(i instanceof ie){const g=this._getType(i.name);if(g)return g}else i instanceof le?i.type=this._forwardType(i.type):i instanceof ue&&(i.format=this._forwardType(i.format));return i}_initialize(i){if(i)if("string"==typeof i){const g=new Re(i);this._tokens=g.scanTokens()}else this._tokens=i;else this._tokens=[];this._current=0}_updateNode(i,g){return i.line=null!=g?g:this._currentLine,i}_error(i,g){return{token:i,message:g,toString:()=>`${g}`}}_isAtEnd(){return this._current>=this._tokens.length||this._peek().type==He.eof}_match(i){if(i instanceof qe)return!!this._check(i)&&(this._advance(),!0);for(let g=0,x=i.length;g0){const i=this._currentLoop[this._currentLoop.length-1];g.loopId=i.id}i=g,this._check(He.keywords.if)&&(this._advance(),g.condition=this._optional_paren_expression())}else if(this._match(He.keywords.continue)){const g=this._updateNode(new re);if(!(this._currentLoop.length>0))throw this._error(this._peek(),`Continue statement must be inside a loop. Line:${g.line}`);{const i=this._currentLoop[this._currentLoop.length-1];g.loopId=i.id}i=g}else i=this._increment_decrement_statement()||this._func_call_statement()||this._assignment_statement();return null!=i&&this._consume(He.tokens.semicolon,"Expected ';' after statement."),i}_static_assert_statement(){if(!this._match(He.keywords.static_assert))return null;const i=this._currentLine,g=this._optional_paren_expression();return this._updateNode(new N(g),i)}_while_statement(){if(!this._match(He.keywords.while))return null;const i=this._updateNode(new V(null,null));return this._currentLoop.push(i),i.condition=this._optional_paren_expression(),this._check(He.tokens.attr)&&this._attribute(),i.body=this._compound_statement(),this._currentLoop.pop(),i}_continuing_statement(){const i=this._currentLoop.length>0?this._currentLoop[this._currentLoop.length-1].id:-1;if(!this._match(He.keywords.continuing))return null;const g=this._currentLine,x=this._compound_statement();return this._updateNode(new O(x,i),g)}_for_statement(){if(!this._match(He.keywords.for))return null;this._consume(He.tokens.paren_left,"Expected '('.");const i=this._updateNode(new B(null,null,null,null));return this._currentLoop.push(i),i.init=this._check(He.tokens.semicolon)?null:this._for_init(),this._consume(He.tokens.semicolon,"Expected ';'."),i.condition=this._check(He.tokens.semicolon)?null:this._short_circuit_or_expression(),this._consume(He.tokens.semicolon,"Expected ';'."),i.increment=this._check(He.tokens.paren_right)?null:this._for_increment(),this._consume(He.tokens.paren_right,"Expected ')'."),this._check(He.tokens.attr)&&this._attribute(),i.body=this._compound_statement(),this._currentLoop.pop(),i}_for_init(){return this._variable_statement()||this._func_call_statement()||this._assignment_statement()}_for_increment(){return this._func_call_statement()||this._increment_decrement_statement()||this._assignment_statement()}_variable_statement(){if(this._check(He.keywords.var)){const i=this._variable_decl();if(null===i)throw this._error(this._peek(),"Variable declaration expected.");let g=null;return this._match(He.tokens.equal)&&(g=this._short_circuit_or_expression()),this._updateNode(new F(i.name,i.type,i.storage,i.access,g),i.line)}if(this._match(He.keywords.let)){const i=this._currentLine,g=this._consume(He.tokens.name,"Expected name for let.").toString();let x=null;if(this._match(He.tokens.colon)){const i=this._attribute();x=this._type_decl(),null!=x&&(x.attributes=i)}this._consume(He.tokens.equal,"Expected '=' for let.");const _=this._short_circuit_or_expression();return this._updateNode(new U(g,x,null,null,_),i)}if(this._match(He.keywords.const)){const i=this._currentLine,g=this._consume(He.tokens.name,"Expected name for const.").toString();let x=null;if(this._match(He.tokens.colon)){const i=this._attribute();x=this._type_decl(),null!=x&&(x.attributes=i)}this._consume(He.tokens.equal,"Expected '=' for const.");const _=this._short_circuit_or_expression();return null===x&&_ instanceof xe&&(x=_.type),this._updateNode(new P(g,x,null,null,_),i)}return null}_increment_decrement_statement(){const i=this._current,g=this._unary_expression();if(null==g)return null;if(!this._check(He.increment_operators))return this._current=i,null;const x=this._consume(He.increment_operators,"Expected increment operator");return this._updateNode(new R(x.type===He.tokens.plus_plus?Dn.increment:Dn.decrement,g))}_assignment_statement(){let i=null;const g=this._currentLine;if(this._check(He.tokens.brace_right))return null;let x=this._match(He.tokens.underscore);if(x||(i=this._unary_expression()),!x&&null==i)return null;const _=this._consume(He.assignment_operators,"Expected assignment operator."),v=this._short_circuit_or_expression();return this._updateNode(new G(Un.parse(_.lexeme),i,v),g)}_func_call_statement(){if(!this._check(He.tokens.ident))return null;const i=this._currentLine,g=this._current,x=this._consume(He.tokens.ident,"Expected function name."),_=this._argument_expression_list();return null===_?(this._current=g,null):this._updateNode(new X(x.lexeme,_),i)}_loop_statement(){if(!this._match(He.keywords.loop))return null;this._check(He.tokens.attr)&&this._attribute(),this._consume(He.tokens.brace_left,"Expected '{' for loop.");const i=this._updateNode(new j([],null));this._currentLoop.push(i);let g=this._statement();for(;null!==g;){if(Array.isArray(g))for(let x of g)i.body.push(x);else i.body.push(g);if(g instanceof O){i.continuing=g;break}g=this._statement()}return this._currentLoop.pop(),this._consume(He.tokens.brace_right,"Expected '}' for loop."),i}_switch_statement(){if(!this._match(He.keywords.switch))return null;const i=this._updateNode(new Z(null,[]));if(this._currentLoop.push(i),i.condition=this._optional_paren_expression(),this._check(He.tokens.attr)&&this._attribute(),this._consume(He.tokens.brace_left,"Expected '{' for switch."),i.cases=this._switch_body(),null==i.cases||0==i.cases.length)throw this._error(this._previous(),"Expected 'case' or 'default'.");return this._consume(He.tokens.brace_right,"Expected '}' for switch."),this._currentLoop.pop(),i}_switch_body(){const i=[];let g=!1;for(;this._check([He.keywords.default,He.keywords.case]);){if(this._match(He.keywords.case)){const x=this._case_selectors();for(const i of x)if(i instanceof Se){if(g)throw this._error(this._previous(),"Multiple default cases in switch statement.");g=!0;break}this._match(He.tokens.colon),this._check(He.tokens.attr)&&this._attribute(),this._consume(He.tokens.brace_left,"Exected '{' for switch case.");const _=this._case_body();this._consume(He.tokens.brace_right,"Exected '}' for switch case."),i.push(this._updateNode(new Ae(x,_)))}if(this._match(He.keywords.default)){if(g)throw this._error(this._previous(),"Multiple default cases in switch statement.");this._match(He.tokens.colon),this._check(He.tokens.attr)&&this._attribute(),this._consume(He.tokens.brace_left,"Exected '{' for switch default.");const x=this._case_body();this._consume(He.tokens.brace_right,"Exected '}' for switch default."),i.push(this._updateNode(new Ee(x)))}}return i}_case_selectors(){const i=[];for(this._match(He.keywords.default)?i.push(this._updateNode(new Se)):i.push(this._shift_expression());this._match(He.tokens.comma);)this._match(He.keywords.default)?i.push(this._updateNode(new Se)):i.push(this._shift_expression());return i}_case_body(){if(this._match(He.keywords.fallthrough))return this._consume(He.tokens.semicolon,"Expected ';'"),[];let i=this._statement();if(null==i)return[];i instanceof Array||(i=[i]);const g=this._case_body();return 0==g.length?i:[...i,g[0]]}_if_statement(){if(!this._match(He.keywords.if))return null;const i=this._currentLine,g=this._optional_paren_expression();this._check(He.tokens.attr)&&this._attribute();const x=this._compound_statement();let _=[];this._match_elseif()&&(this._check(He.tokens.attr)&&this._attribute(),_=this._elseif_statement(_));let v=null;return this._match(He.keywords.else)&&(this._check(He.tokens.attr)&&this._attribute(),v=this._compound_statement()),this._updateNode(new Q(g,x,_,v),i)}_match_elseif(){return this._tokens[this._current].type===He.keywords.else&&this._tokens[this._current+1].type===He.keywords.if&&(this._advance(),this._advance(),!0)}_elseif_statement(i=[]){const g=this._optional_paren_expression(),x=this._compound_statement();return i.push(this._updateNode(new Le(g,x))),this._match_elseif()&&(this._check(He.tokens.attr)&&this._attribute(),this._elseif_statement(i)),i}_return_statement(){if(!this._match(He.keywords.return))return null;const i=this._short_circuit_or_expression();return this._updateNode(new Y(i))}_short_circuit_or_expression(){let i=this._short_circuit_and_expr();for(;this._match(He.tokens.or_or);)i=this._updateNode(new Ie(this._previous().toString(),i,this._short_circuit_and_expr()));return i}_short_circuit_and_expr(){let i=this._inclusive_or_expression();for(;this._match(He.tokens.and_and);)i=this._updateNode(new Ie(this._previous().toString(),i,this._inclusive_or_expression()));return i}_inclusive_or_expression(){let i=this._exclusive_or_expression();for(;this._match(He.tokens.or);)i=this._updateNode(new Ie(this._previous().toString(),i,this._exclusive_or_expression()));return i}_exclusive_or_expression(){let i=this._and_expression();for(;this._match(He.tokens.xor);)i=this._updateNode(new Ie(this._previous().toString(),i,this._and_expression()));return i}_and_expression(){let i=this._equality_expression();for(;this._match(He.tokens.and);)i=this._updateNode(new Ie(this._previous().toString(),i,this._equality_expression()));return i}_equality_expression(){const i=this._relational_expression();return this._match([He.tokens.equal_equal,He.tokens.not_equal])?this._updateNode(new Ie(this._previous().toString(),i,this._relational_expression())):i}_relational_expression(){let i=this._shift_expression();for(;this._match([He.tokens.less_than,He.tokens.greater_than,He.tokens.less_than_equal,He.tokens.greater_than_equal]);)i=this._updateNode(new Ie(this._previous().toString(),i,this._shift_expression()));return i}_shift_expression(){let i=this._additive_expression();for(;this._match([He.tokens.shift_left,He.tokens.shift_right]);)i=this._updateNode(new Ie(this._previous().toString(),i,this._additive_expression()));return i}_additive_expression(){let i=this._multiplicative_expression();for(;this._match([He.tokens.plus,He.tokens.minus]);)i=this._updateNode(new Ie(this._previous().toString(),i,this._multiplicative_expression()));return i}_multiplicative_expression(){let i=this._unary_expression();for(;this._match([He.tokens.star,He.tokens.forward_slash,He.tokens.modulo]);)i=this._updateNode(new Ie(this._previous().toString(),i,this._unary_expression()));return i}_unary_expression(){return this._match([He.tokens.minus,He.tokens.bang,He.tokens.tilde,He.tokens.star,He.tokens.and])?this._updateNode(new ke(this._previous().toString(),this._unary_expression())):this._singular_expression()}_singular_expression(){const i=this._primary_expression(),g=this._postfix_expression();return g&&(i.postfix=g),i}_postfix_expression(){if(this._match(He.tokens.bracket_left)){const i=this._short_circuit_or_expression();this._consume(He.tokens.bracket_right,"Expected ']'.");const g=this._updateNode(new ve(i)),x=this._postfix_expression();return x&&(g.postfix=x),g}if(this._match(He.tokens.period)){const i=this._consume(He.tokens.name,"Expected member name."),g=this._postfix_expression(),x=this._updateNode(new pe(i.lexeme));return g&&(x.postfix=g),x}return null}_getStruct(i){return this._context.aliases.has(i)?this._context.aliases.get(i).type:this._context.structs.has(i)?this._context.structs.get(i):null}_getType(i){const g=this._getStruct(i);if(null!==g)return g;switch(i){case"void":return ae.void;case"bool":return ae.bool;case"i32":return ae.i32;case"u32":return ae.u32;case"f32":return ae.f32;case"f16":return ae.f16;case"vec2f":return ce.vec2f;case"vec3f":return ce.vec3f;case"vec4f":return ce.vec4f;case"vec2i":return ce.vec2i;case"vec3i":return ce.vec3i;case"vec4i":return ce.vec4i;case"vec2u":return ce.vec2u;case"vec3u":return ce.vec3u;case"vec4u":return ce.vec4u;case"vec2h":return ce.vec2h;case"vec3h":return ce.vec3h;case"vec4h":return ce.vec4h;case"mat2x2f":return ce.mat2x2f;case"mat2x3f":return ce.mat2x3f;case"mat2x4f":return ce.mat2x4f;case"mat3x2f":return ce.mat3x2f;case"mat3x3f":return ce.mat3x3f;case"mat3x4f":return ce.mat3x4f;case"mat4x2f":return ce.mat4x2f;case"mat4x3f":return ce.mat4x3f;case"mat4x4f":return ce.mat4x4f;case"mat2x2h":return ce.mat2x2h;case"mat2x3h":return ce.mat2x3h;case"mat2x4h":return ce.mat2x4h;case"mat3x2h":return ce.mat3x2h;case"mat3x3h":return ce.mat3x3h;case"mat3x4h":return ce.mat3x4h;case"mat4x2h":return ce.mat4x2h;case"mat4x3h":return ce.mat4x3h;case"mat4x4h":return ce.mat4x4h;case"mat2x2i":return ce.mat2x2i;case"mat2x3i":return ce.mat2x3i;case"mat2x4i":return ce.mat2x4i;case"mat3x2i":return ce.mat3x2i;case"mat3x3i":return ce.mat3x3i;case"mat3x4i":return ce.mat3x4i;case"mat4x2i":return ce.mat4x2i;case"mat4x3i":return ce.mat4x3i;case"mat4x4i":return ce.mat4x4i;case"mat2x2u":return ce.mat2x2u;case"mat2x3u":return ce.mat2x3u;case"mat2x4u":return ce.mat2x4u;case"mat3x2u":return ce.mat3x2u;case"mat3x3u":return ce.mat3x3u;case"mat3x4u":return ce.mat3x4u;case"mat4x2u":return ce.mat4x2u;case"mat4x3u":return ce.mat4x3u;case"mat4x4u":return ce.mat4x4u}return null}_validateTypeRange(i,g){if("i32"===g.name){if(i<-2147483648||i>2147483647)throw this._error(this._previous(),`Value out of range for i32:${i}. Line:${this._currentLine}.`)}else if("u32"===g.name&&(i<0||i>4294967295))throw this._error(this._previous(),`Value out of range for u32:${i}. Line:${this._currentLine}.`)}_primary_expression(){if(this._match(He.tokens.ident)){const i=this._previous().toString();if(this._check(He.tokens.paren_left)){const g=this._argument_expression_list(),x=this._getType(i);return null!==x?this._updateNode(new de(x,g)):this._updateNode(new me(i,g))}if(this._context.constants.has(i)){const g=this._context.constants.get(i);return this._updateNode(new _e(i,g.value))}return this._updateNode(new ge(i))}if(this._match(He.tokens.int_literal)){const i=this._previous().toString();let g=i.endsWith("i")||i.endsWith("i")?ae.i32:i.endsWith("u")||i.endsWith("U")?ae.u32:ae.x32;const x=parseInt(i);return this._validateTypeRange(x,g),this._updateNode(new xe(new Be(x,this._exec.getTypeInfo(g)),g))}if(this._match(He.tokens.uint_literal)){const i=parseInt(this._previous().toString());return this._validateTypeRange(i,ae.u32),this._updateNode(new xe(new Be(i,this._exec.getTypeInfo(ae.u32)),ae.u32))}if(this._match([He.tokens.decimal_float_literal,He.tokens.hex_float_literal])){let i=this._previous().toString(),g=i.endsWith("h");g&&(i=i.substring(0,i.length-1));const x=parseFloat(i);this._validateTypeRange(x,g?ae.f16:ae.f32);const _=g?ae.f16:ae.f32;return this._updateNode(new xe(new Be(x,this._exec.getTypeInfo(_)),_))}if(this._match([He.keywords.true,He.keywords.false])){let i=this._previous().toString()===He.keywords.true.rule;return this._updateNode(new xe(new Be(i?1:0,this._exec.getTypeInfo(ae.bool)),ae.bool))}if(this._check(He.tokens.paren_left))return this._paren_expression();if(this._match(He.keywords.bitcast)){this._consume(He.tokens.less_than,"Expected '<'.");const i=this._type_decl();this._consume(He.tokens.greater_than,"Expected '>'.");const g=this._paren_expression();return this._updateNode(new ye(i,g))}const i=this._type_decl(),g=this._argument_expression_list();return this._updateNode(new de(i,g))}_argument_expression_list(){if(!this._match(He.tokens.paren_left))return null;const i=[];do{if(this._check(He.tokens.paren_right))break;const g=this._short_circuit_or_expression();i.push(g)}while(this._match(He.tokens.comma));return this._consume(He.tokens.paren_right,"Expected ')' for agument list"),i}_optional_paren_expression(){this._match(He.tokens.paren_left);const i=this._short_circuit_or_expression();return this._match(He.tokens.paren_right),i}_paren_expression(){this._consume(He.tokens.paren_left,"Expected '('.");const i=this._short_circuit_or_expression();return this._consume(He.tokens.paren_right,"Expected ')'."),i}_struct_decl(){if(!this._match(He.keywords.struct))return null;const i=this._currentLine,g=this._consume(He.tokens.ident,"Expected name for struct.").toString();this._consume(He.tokens.brace_left,"Expected '{' for struct body.");const x=[];for(;!this._check(He.tokens.brace_right);){const i=this._attribute(),g=this._consume(He.tokens.name,"Expected variable name.").toString();this._consume(He.tokens.colon,"Expected ':' for struct member type.");const _=this._attribute(),v=this._type_decl();null!=v&&(v.attributes=_),this._check(He.tokens.brace_right)?this._match(He.tokens.comma):this._consume(He.tokens.comma,"Expected ',' for struct member."),x.push(this._updateNode(new Ce(g,v,i)))}this._consume(He.tokens.brace_right,"Expected '}' after struct body.");const _=this._currentLine,v=this._updateNode(new oe(g,x,i,_),i);return this._context.structs.set(g,v),v}_global_variable_decl(){const i=this._variable_decl();if(!i)return null;if(this._match(He.tokens.equal)){const g=this._const_expression();i.value=g}if(null!==i.type&&i.value instanceof xe){if("x32"!==i.value.type.name&&i.type.getTypeName()!==i.value.type.getTypeName())throw this._error(this._peek(),`Invalid cast from ${i.value.type.name} to ${i.type.name}. Line:${this._currentLine}`);i.value.isScalar&&this._validateTypeRange(i.value.scalarValue,i.type),i.value.type=i.type}else null===i.type&&i.value instanceof xe&&(i.type="x32"===i.value.type.name?ae.i32:i.value.type,i.value.isScalar&&this._validateTypeRange(i.value.scalarValue,i.type));return i}_override_variable_decl(){const i=this._override_decl();return i&&this._match(He.tokens.equal)&&(i.value=this._const_expression()),i}_global_const_decl(){var i;if(!this._match(He.keywords.const))return null;const g=this._consume(He.tokens.name,"Expected variable name"),x=this._currentLine;let _=null;if(this._match(He.tokens.colon)){const i=this._attribute();_=this._type_decl(),null!=_&&(_.attributes=i)}let v=null;this._consume(He.tokens.equal,"const declarations require an assignment");const b=this._short_circuit_or_expression();try{let i=[ae.f32],x=b.constEvaluate(this._exec,i);x instanceof Be&&this._validateTypeRange(x.value,i[0]),i[0]instanceof ce&&null===i[0].format&&x.typeInfo instanceof a&&null!==x.typeInfo.format&&("f16"===x.typeInfo.format.name?i[0].format=ae.f16:"f32"===x.typeInfo.format.name?i[0].format=ae.f32:"i32"===x.typeInfo.format.name?i[0].format=ae.i32:"u32"===x.typeInfo.format.name?i[0].format=ae.u32:"bool"===x.typeInfo.format.name?i[0].format=ae.bool:console.error(`TODO:impelement template format type ${x.typeInfo.format.name}`)),v=this._updateNode(new xe(x,i[0])),this._exec.context.setVariable(g.toString(),x)}catch(i){v=b}if(null!==_&&v instanceof xe){if("x32"!==v.type.name&&_.getTypeName()!==v.type.getTypeName())throw this._error(this._peek(),`Invalid cast from ${v.type.name} to ${_.name}. Line:${this._currentLine}`);v.type=_,v.isScalar&&this._validateTypeRange(v.scalarValue,v.type)}else null===_&&v instanceof xe&&(_=null!==(i=null==v?void 0:v.type)&&void 0!==i?i:ae.f32,_===ae.x32&&(_=ae.i32));const y=this._updateNode(new P(g.toString(),_,"","",v),x);return this._context.constants.set(y.name,y),y}_global_let_decl(){if(!this._match(He.keywords.let))return null;const i=this._currentLine,g=this._consume(He.tokens.name,"Expected variable name");let x=null;if(this._match(He.tokens.colon)){const i=this._attribute();x=this._type_decl(),null!=x&&(x.attributes=i)}let _=null;if(this._match(He.tokens.equal)&&(_=this._const_expression()),null!==x&&_ instanceof xe){if("x32"!==_.type.name&&x.getTypeName()!==_.type.getTypeName())throw this._error(this._peek(),`Invalid cast from ${_.type.name} to ${x.name}. Line:${this._currentLine}`);_.type=x}else null===x&&_ instanceof xe&&(x="x32"===_.type.name?ae.i32:_.type);return _ instanceof xe&&_.isScalar&&this._validateTypeRange(_.scalarValue,x),this._updateNode(new U(g.toString(),x,"","",_),i)}_const_expression(){return this._short_circuit_or_expression()}_variable_decl(){if(!this._match(He.keywords.var))return null;const i=this._currentLine;let g="",x="";this._match(He.tokens.less_than)&&(g=this._consume(He.storage_class,"Expected storage_class.").toString(),this._match(He.tokens.comma)&&(x=this._consume(He.access_mode,"Expected access_mode.").toString()),this._consume(He.tokens.greater_than,"Expected '>'."));const _=this._consume(He.tokens.name,"Expected variable name");let v=null;if(this._match(He.tokens.colon)){const i=this._attribute();v=this._type_decl(),null!=v&&(v.attributes=i)}return this._updateNode(new F(_.toString(),v,g,x,null),i)}_override_decl(){if(!this._match(He.keywords.override))return null;const i=this._consume(He.tokens.name,"Expected variable name");let g=null;if(this._match(He.tokens.colon)){const i=this._attribute();g=this._type_decl(),null!=g&&(g.attributes=i)}return this._updateNode(new M(i.toString(),g,null))}_diagnostic(){this._consume(He.tokens.paren_left,"Expected '('");const i=this._consume(He.tokens.ident,"Expected severity control name.");this._consume(He.tokens.comma,"Expected ','");let g=this._consume(He.tokens.ident,"Expected diagnostic rule name.").toString();return this._match(He.tokens.period)&&(g+=`.${this._consume(He.tokens.ident,"Expected diagnostic message.").toString()}`),this._consume(He.tokens.paren_right,"Expected ')'"),this._updateNode(new ee(i.toString(),g))}_enable_directive(){const i=this._consume(He.tokens.ident,"identity expected.");return this._updateNode(new K(i.toString()))}_requires_directive(){const i=[this._consume(He.tokens.ident,"identity expected.").toString()];for(;this._match(He.tokens.comma);){const g=this._consume(He.tokens.ident,"identity expected.");i.push(g.toString())}return this._updateNode(new J(i))}_type_alias(){const i=this._consume(He.tokens.ident,"identity expected.");this._consume(He.tokens.equal,"Expected '=' for type alias.");let g=this._type_decl();if(null===g)throw this._error(this._peek(),"Expected Type for Alias.");this._context.aliases.has(g.name)&&(g=this._context.aliases.get(g.name).type);const x=this._updateNode(new te(i.toString(),g));return this._context.aliases.set(x.name,x),x}_type_decl(){if(this._check([He.tokens.ident,...He.texel_format,He.keywords.bool,He.keywords.f32,He.keywords.i32,He.keywords.u32])){const i=this._advance().toString();if(this._context.structs.has(i))return this._context.structs.get(i);if(this._context.aliases.has(i))return this._context.aliases.get(i).type;if(!this._getType(i)){const g=this._updateNode(new ie(i));return this._forwardTypeCount++,g}return this._updateNode(new ae(i))}let i=this._texture_sampler_types();if(i)return i;if(this._check(He.template_types)){let i=this._advance().toString(),g=null,x=null;return this._match(He.tokens.less_than)&&(g=this._type_decl(),x=null,this._match(He.tokens.comma)&&(x=this._consume(He.access_mode,"Expected access_mode for pointer").toString()),this._consume(He.tokens.greater_than,"Expected '>' for type.")),this._updateNode(new ce(i,g,x))}if(this._match(He.keywords.ptr)){let i=this._previous().toString();this._consume(He.tokens.less_than,"Expected '<' for pointer.");const g=this._consume(He.storage_class,"Expected storage_class for pointer");this._consume(He.tokens.comma,"Expected ',' for pointer.");const x=this._type_decl();let _=null;return this._match(He.tokens.comma)&&(_=this._consume(He.access_mode,"Expected access_mode for pointer").toString()),this._consume(He.tokens.greater_than,"Expected '>' for pointer."),this._updateNode(new le(i,g.toString(),x,_))}const g=this._attribute();if(this._match(He.keywords.array)){let x=null,_=-1;const v=this._previous();let b=null;if(this._match(He.tokens.less_than)){x=this._type_decl(),this._context.aliases.has(x.name)&&(x=this._context.aliases.get(x.name).type);let g="";if(this._match(He.tokens.comma)){b=this._shift_expression();try{g=b.constEvaluate(this._exec).toString(),b=null}catch(i){g="1"}}this._consume(He.tokens.greater_than,"Expected '>' for array."),_=g?parseInt(g):0}const y=this._updateNode(new ue(v.toString(),g,x,_));return b&&this._deferArrayCountEval.push({arrayType:y,countNode:b}),y}return null}_texture_sampler_types(){if(this._match(He.sampler_type))return this._updateNode(new he(this._previous().toString(),null,null));if(this._match(He.depth_texture_type))return this._updateNode(new he(this._previous().toString(),null,null));if(this._match(He.sampled_texture_type)||this._match(He.multisampled_texture_type)){const i=this._previous();this._consume(He.tokens.less_than,"Expected '<' for sampler type.");const g=this._type_decl();return this._consume(He.tokens.greater_than,"Expected '>' for sampler type."),this._updateNode(new he(i.toString(),g,null))}if(this._match(He.storage_texture_type)){const i=this._previous();this._consume(He.tokens.less_than,"Expected '<' for sampler type.");const g=this._consume(He.texel_format,"Invalid texel format.").toString();this._consume(He.tokens.comma,"Expected ',' after texel format.");const x=this._consume(He.access_mode,"Expected access mode for storage texture type.").toString();return this._consume(He.tokens.greater_than,"Expected '>' for sampler type."),this._updateNode(new he(i.toString(),g,x))}return null}_attribute(){let i=[];for(;this._match(He.tokens.attr);){const g=this._consume(He.attribute_name,"Expected attribute name"),x=this._updateNode(new De(g.toString(),null));if(this._match(He.tokens.paren_left)){if(x.value=this._consume(He.literal_or_ident,"Expected attribute value").toString(),this._check(He.tokens.comma)){this._advance();do{const i=this._consume(He.literal_or_ident,"Expected attribute value").toString();x.value instanceof Array||(x.value=[x.value]),x.value.push(i)}while(this._match(He.tokens.comma))}this._consume(He.tokens.paren_right,"Expected ')'")}i.push(x)}return 0==i.length?null:i}}class _t extends at{constructor(i){super(),i&&this.update(i)}update(i){const g=(new gt).parse(i);this.updateAST(g)}}function ensureVertexIndexBuiltin(i){if(/@builtin\s*\(\s*vertex_index\s*\)/.test(i))return i;return i.replace(/(@vertex\s+fn\s+)([a-zA-Z_][a-zA-Z0-9_]*)\s*\(([^)]*)(\))/,(i,g,x,_,v)=>{const b=_.trim(),y="@builtin(vertex_index) redgpu_auto_builtin_vertex_index:u32";return`${g}${x}(${0===b.length?y:`${b},${y}`}${v}`})}class WGSLUniformTypes{static get i32(){return{numElements:1,align:4,size:4,type:"i32",wgslType:"i32",View:Int32Array}}static get u32(){return{numElements:1,align:4,size:4,type:"u32",wgslType:"u32",View:Uint32Array}}static get f32(){return{numElements:1,align:4,size:4,type:"f32",wgslType:"f32",View:Float32Array}}static get f16(){return{numElements:1,align:2,size:2,type:"f16",wgslType:"f16",View:Uint16Array}}static get vec2f32(){return{numElements:2,align:8,size:8,type:"f32",wgslType:"vec2",View:Float32Array}}static get vec2i32(){return{numElements:2,align:8,size:8,type:"i32",wgslType:"vec2",View:Int32Array}}static get vec2u32(){return{numElements:2,align:8,size:8,type:"u32",wgslType:"vec2",View:Uint32Array}}static get vec2u16(){return{numElements:2,align:4,size:4,type:"u16",wgslType:"vec2",View:Uint16Array}}static get vec3i32(){return{numElements:3,align:16,size:12,type:"i32",wgslType:"vec3",View:Int32Array}}static get vec3u32(){return{numElements:3,align:16,size:12,type:"u32",wgslType:"vec3",View:Uint32Array}}static get vec3f32(){return{numElements:3,align:16,size:12,type:"f32",wgslType:"vec3",View:Float32Array}}static get vec3u16(){return{numElements:3,align:8,size:6,type:"u16",wgslType:"vec3",View:Uint16Array}}static get vec4i32(){return{numElements:4,align:16,size:16,type:"i32",wgslType:"vec4",View:Int32Array}}static get vec4u32(){return{numElements:4,align:16,size:16,type:"u32",wgslType:"vec4",View:Uint32Array}}static get vec4f32(){return{numElements:4,align:16,size:16,type:"f32",wgslType:"vec4",View:Float32Array}}static get vec4u16(){return{numElements:4,align:8,size:8,type:"u16",wgslType:"vec4",View:Uint16Array}}static get mat2x2f32(){return{numElements:4,align:8,size:16,type:"f32",wgslType:"mat2x2",View:Float32Array}}static get mat2x2u16(){return{numElements:4,align:4,size:8,type:"u16",wgslType:"mat2x2",View:Uint16Array}}static get mat3x2f32(){return{numElements:6,align:8,size:24,type:"f32",wgslType:"mat3x2",View:Float32Array}}static get mat3x2u16(){return{numElements:6,align:4,size:12,type:"u16",wgslType:"mat3x2",View:Uint16Array}}static get mat3x3f32(){return{numElements:16,align:16,size:64,type:"f32",wgslType:"mat3x3",View:Float32Array}}static get mat4x2f32(){return{numElements:8,align:8,size:32,type:"f32",wgslType:"mat4x2",View:Float32Array}}static get mat4x2u16(){return{numElements:8,align:4,size:16,type:"u16",wgslType:"mat4x2",View:Uint16Array}}static get mat2x3f32(){return{numElements:8,align:16,size:32,type:"f32",wgslType:"mat2x3",View:Float32Array}}static get mat2x3u16(){return{numElements:8,align:8,size:16,type:"u16",wgslType:"mat2x3",View:Uint16Array}}static get mat4x4f32(){return{numElements:16,align:16,size:64,type:"f32",wgslType:"mat4x4",View:Float32Array}}static get mat4x4u16(){return{numElements:16,align:8,size:32,type:"u16",wgslType:"mat4x4",View:Uint16Array}}}Object.freeze(WGSLUniformTypes);const processMembers=(i,g=0,x=0)=>{let _=0,v=x;const b=i?.reduce((i,x,b)=>{const{type:y,offset:S,size:w,stride:L,count:k,isArray:H}=x,{format:z}=y,q="array"===y.name?`${z.name}${z.format?`${z.format.name}`:""}`:`${y.name}${z?`${z.name}`:""}`;if(_=g,v=S+w,i[x.name]=((i,g,x)=>{const _=WGSLUniformTypes[x];return{uniformOffset:i.offset+g,uniformOffsetForData:i.offset,stride:i.stride,isArray:i.isArray,typeInfo:_,View:_?.View}})(x,g,q),H&&z.members){const g=processMembers(z.members).members;i[x.name].memberList=Array.from({length:k},(i,x)=>{const _={};for(const i in g){const v=_[i]={...g[i]};v.uniformOffset=v.uniformOffset+S+L*x}return _})}else y.members&&(i[x.name]=processMembers(y.members,S+g,v));return i},{});return{members:b,startOffset:_,endOffset:v}},Yn=new Map,parseWGSL=i=>{i=ensureVertexIndexBuiltin(i);const{defaultSource:g,shaderSourceVariant:x,conditionalBlocks:_,cacheKey:v}=preprocessWGSL(i),b=Yn.get(v);let y;if(b)y=b;else{const i=new _t(g);y={uniforms:{...(w=i.uniforms,w.reduce((i,g)=>(i[g.name]={name:g.name,...processMembers(g.members),arrayBufferByteLength:g.size,stride:g.stride},g.attributes?.forEach(x=>i[g.name][x.name]=+x.value),i),{}))},storage:{...(S=i.storage,S.reduce((i,g)=>(i[g.name]={name:g.name,...processMembers(g.members),arrayBufferByteLength:g.size,stride:g.stride,acccess:g.access,type:g.type},g.attributes?.forEach(x=>i[g.name][x.name]=+x.value),i),{}))},samplers:i.samplers,textures:i.textures,vertexEntries:i.entry.vertex.map(i=>i.name),fragmentEntries:i.entry.fragment.map(i=>i.name),computeEntries:i.entry.compute.map(i=>i.name)},x.setBaseInfo(y.textures,y.samplers),_.forEach(i=>{const g=x.getVariant(i),_=new _t(g),v=_.textures.filter(i=>!y.textures.find(g=>g.name===i.name)),b=_.samplers.filter(i=>!y.samplers.find(g=>g.name===i.name));x.addConditionalInfo(i,v,b)}),y.textures=x.getUnionTextures(),y.samplers=x.getUnionSamplers(),Yn.set(v,y)}var S,w;return{...y,defaultSource:g,shaderSourceVariant:x,conditionalBlocks:_}};class PassClusterLightBound{#Ft;#Ht;#zt;#$t;#Kt;#l;constructor(i,g){validateRedGPUContext(i),this.#l=i,this.#Ft=g,this.#Xt()}get clusterBoundBuffer(){return this.#Ht}render(){const i=this.#Ft.systemUniform_Vertex_UniformBindGroup;if(i){const{gpuDevice:g}=this.#l,x=g.createCommandEncoder(),_=x.beginComputePass({label:"Bound cluster"}),v=q.getDispatchSize();_.setPipeline(this.#Kt),_.setBindGroup(0,i),_.setBindGroup(1,this.#$t),_.dispatchWorkgroups(v[0],v[1],v[2]),_.end(),g.queue.submit([x.finish()])}}#Xt(){const{gpuDevice:i,resourceManager:g}=this.#l,x=parseWGSL("#redgpu_include SYSTEM_UNIFORM;\n@group(1) @binding(0) var clusterLight_Clusters:ClusterLight_Clusters;\nfn lineIntersectionToZPlane(a:vec3,b:vec3,zDistance:f32) -> vec3 { let normal=vec3(0.0,0.0,0.5); let ab=b - a; let t=(zDistance - dot(normal,a))/dot(normal,ab); return a + t * ab;\n}\nfn clipToView(clip:vec4) -> vec4 { let view=systemUniforms.inverseProjectionMatrix * clip; return view/vec4(view.w,view.w,view.w,view.w);\n}\nfn screen2View(screen:vec4) -> vec4 { let texCoord=screen.xy/systemUniforms.resolution.xy; let clip=vec4(vec2(texCoord.x,1.0 - texCoord.y) * 2.0 - vec2(1.0,1.0),screen.z,screen.w ); return clipToView(clip);\n}\nconst eyePos=vec3(0.0);\n@compute @workgroup_size(REDGPU_DEFINE_WORKGROUP_SIZE_X,REDGPU_DEFINE_WORKGROUP_SIZE_Y,REDGPU_DEFINE_WORKGROUP_SIZE_Z)\nfn main(@builtin(global_invocation_id) global_id:vec3) { let tileIndex=global_id.x + global_id.y * clusterLight_tileCount.x + global_id.z * clusterLight_tileCount.x * clusterLight_tileCount.y; let tileSize=vec2( systemUniforms.resolution.x/f32(clusterLight_tileCount.x), systemUniforms.resolution.y/f32(clusterLight_tileCount.y) ); let global_id_x_pos_one=vec2(f32(global_id.x + 1u),f32(global_id.y + 1u)) * tileSize; let global_id_x_y=vec2(f32(global_id.x),f32(global_id.y)) * tileSize; let maxPoint_sS=vec4(global_id_x_pos_one,0.0,1.0); let minPoint_sS=vec4(global_id_x_y,0.0,1.0); let maxPoint_vS=screen2View(maxPoint_sS).xyz; let minPoint_vS=screen2View(minPoint_sS).xyz; let nearFarX=systemUniforms.camera.nearClipping; let nearFarY=systemUniforms.camera.farClipping; let tileZ=f32(global_id.z)/f32(clusterLight_tileCount.z); let tileZ_plus_one=f32(global_id.z + 1u)/f32(clusterLight_tileCount.z); let tileNear=-nearFarX * pow(nearFarY/nearFarX,tileZ); let tileFar=-nearFarX * pow(nearFarY/nearFarX,tileZ_plus_one); let minPointNear=lineIntersectionToZPlane(eyePos,minPoint_vS,tileNear); let minPointFar=lineIntersectionToZPlane(eyePos,minPoint_vS,tileFar); let maxPointNear=lineIntersectionToZPlane(eyePos,maxPoint_vS,tileNear); let maxPointFar=lineIntersectionToZPlane(eyePos,maxPoint_vS,tileFar); let minAABB=min(min(minPointNear,minPointFar),min(maxPointNear,maxPointFar)); let maxAABB=max(max(minPointNear,minPointFar),max(maxPointNear,maxPointFar)); clusterLight_Clusters.cubeList[tileIndex].minAABB=vec4(minAABB,0.0); clusterLight_Clusters.cubeList[tileIndex].maxAABB=vec4(maxAABB,0.0);\n}\n").defaultSource;this.#Ht=g.createGPUBuffer("PASS_CLUSTER_BOUND_BUFFER",{size:32*q.getTotalTileSize(),usage:GPUBufferUsage.STORAGE|GPUBufferUsage.COPY_DST}),this.#zt=i.createBindGroupLayout({entries:[{binding:0,visibility:GPUShaderStage.COMPUTE,buffer:{type:"storage"}}]}),this.#$t=i.createBindGroup({label:"CLUSTER_BOUND_BIND_GROUP",layout:this.#zt,entries:[{binding:0,resource:{buffer:this.#Ht}}]}),this.#Kt=i.createComputePipeline({label:"CLUSTER_BOUND_PIPELINE",layout:i.createPipelineLayout({bindGroupLayouts:[g.getGPUBindGroupLayout(ResourceManager.PRESET_GPUBindGroupLayout_System),this.#zt]}),compute:{module:g.createGPUShaderModule("CLUSTER_BOUND_SHADER",{code:x}),entryPoint:"main"}})}}const qn=new Uint32Array([0,0,0,0]);class PassClustersLight{#Ft;#jt;#Yt;#qt;#l;constructor(i,g){validateRedGPUContext(i),this.#l=i,this.#Ft=g,this.#Xt()}get clusterLightsBuffer(){return this.#qt}render(){const{gpuDevice:i}=this.#l,g=this.#Ft.systemUniform_Vertex_UniformBindGroup;if(g){const x=i.createCommandEncoder(),_=x.beginComputePass({label:"ClusterLight cluster"}),v=q.getDispatchSize();this.#l.gpuDevice.queue.writeBuffer(this.clusterLightsBuffer,0,qn),_.setPipeline(this.#Yt),_.setBindGroup(0,g),_.setBindGroup(1,this.#jt),_.dispatchWorkgroups(v[0],v[1],v[2]),_.end(),i.queue.submit([x.finish()])}}#Xt(){const{gpuDevice:i,resourceManager:g}=this.#l,x=parseWGSL("#redgpu_include SYSTEM_UNIFORM;\n@group(1) @binding(0) var clusterLight_Clusters:ClusterLight_Clusters;\nfn pointLight_testSphereAABB(light:u32,tile:u32) -> bool { let targetLight=clusterLightList.lights[light]; let targetTile=clusterLight_Clusters.cubeList[tile]; let radius:f32=targetLight.radius; let position:vec3=targetLight.position; let center:vec3=(systemUniforms.camera.cameraMatrix * vec4(position,1.0)).xyz; let squaredDistance:f32=pointLight_sqDistPointAABB(center,tile,targetTile.minAABB.xyz,targetTile.maxAABB.xyz); return squaredDistance <=(radius * radius);\n}\nfn pointLight_sqDistPointAABB(targetPoint:vec3,tile:u32,minAABB:vec3,maxAABB:vec3) -> f32 { var sqDist=0.0; for(var i=0u;i < 3u;i=i + 1u) { let v=targetPoint[i]; let _minAABB=minAABB[i]; let _maxAABB=maxAABB[i]; if(v < _minAABB){ sqDist +=(_minAABB - v) * (_minAABB - v); } if(v > _maxAABB){ sqDist +=(v - _maxAABB) * (v - _maxAABB); } } return sqDist;\n}\nfn spotLight_testSphereAABB(light:u32,tile:u32) -> bool { let targetLight=clusterLightList.lights[light]; let targetTile=clusterLight_Clusters.cubeList[tile]; let radius:f32=targetLight.radius; let position:vec3=targetLight.position; let center:vec3=(systemUniforms.camera.cameraMatrix * vec4(position,1.0)).xyz; let squaredDistance:f32=pointLight_sqDistPointAABB(center,tile,targetTile.minAABB.xyz,targetTile.maxAABB.xyz); return squaredDistance <=(radius * radius);\n}\n@compute @workgroup_size(REDGPU_DEFINE_WORKGROUP_SIZE_X,REDGPU_DEFINE_WORKGROUP_SIZE_Y,REDGPU_DEFINE_WORKGROUP_SIZE_Z)\nfn main(@builtin(global_invocation_id) global_id:vec3) { let tileIndex=global_id.x + global_id.y * clusterLight_tileCount.x + global_id.z * clusterLight_tileCount.x * clusterLight_tileCount.y; var clusterLightCount=0u; var clusterLightIndices:array; for (var i=0u;i < u32(clusterLightList.count[0]);i=i + 1u) { let lightInCluster=pointLight_testSphereAABB(i,tileIndex); if (lightInCluster) { clusterLightIndices[clusterLightCount]=i; clusterLightCount=clusterLightCount + 1u; } if (clusterLightCount==REDGPU_DEFINE_MAX_LIGHTS_PER_CLUSTERu) { break; } } let spotLightStartIndex=u32(clusterLightList.count[0]); for (var i=0u;i < u32(clusterLightList.count[1]);i=i + 1u) { let actualLightIndex=spotLightStartIndex + i; let sphereTest=spotLight_testSphereAABB(actualLightIndex,tileIndex); if (sphereTest) { clusterLightIndices[clusterLightCount]=actualLightIndex; clusterLightCount=clusterLightCount + 1u; } if (clusterLightCount==REDGPU_DEFINE_MAX_LIGHTS_PER_CLUSTERu) { break; } } var offset=atomicAdd(&clusterLightGroup.offset,clusterLightCount); for(var i=0u;i < clusterLightCount;i=i + 1u) { clusterLightGroup.indices[offset + i]=clusterLightIndices[i]; } clusterLightGroup.lights[tileIndex].offset=offset; clusterLightGroup.lights[tileIndex].count=clusterLightCount;\n}\n").defaultSource;this.#qt=g.createGPUBuffer("PASS_CLUSTER_LIGHTS_BUFFER",{size:q.getClusterLightsBufferSize(),usage:GPUBufferUsage.STORAGE|GPUBufferUsage.COPY_DST});const _=i.createBindGroupLayout({entries:[{binding:0,visibility:GPUShaderStage.COMPUTE,buffer:{type:"read-only-storage"}}]});this.#jt=i.createBindGroup({label:"CLUSTER_LIGHT_BIND_GROUP",layout:_,entries:[{binding:0,resource:{buffer:this.#Ft.passLightClustersBound.clusterBoundBuffer}}]}),this.#Yt=i.createComputePipeline({label:"CLUSTER_LIGHT_PIPELINE",layout:i.createPipelineLayout({label:"CLUSTER_LIGHT_PIPELINE_LAYOUT",bindGroupLayouts:[g.getGPUBindGroupLayout(ResourceManager.PRESET_GPUBindGroupLayout_System),_]}),compute:{module:g.createGPUShaderModule("CLUSTER_LIGHTS_SHADER",{code:x}),entryPoint:"main"}})}}class ResourceStateUniformBuffer{static dirtyList=[];buffer;uuid;#Wt=0;constructor(i){this.buffer=i,this.uuid=i.uuid}get useNum(){return this.#Wt}set useNum(i){this.#Wt=i,ResourceStateUniformBuffer.dirtyList.push(this)}}const Wn=Symbol("gpuBuffer"),Zn=Symbol("gpuBufferData"),Jn=Symbol("gpuBufferDataViewF32"),Qn=Symbol("gpuBufferDataViewU32"),er=Symbol("gpuBufferCacheKey");class ABaseBuffer extends ManagementResourceBase{[Wn];[er];#Zt;constructor(i,g,x){super(i,g),this.#Zt=x}get cacheKey(){return this[er]||this.uuid}get gpuBuffer(){return this[Wn]}get usage(){return this.#Zt}get size(){return this[Zn]?.byteLength||0}get videoMemorySize(){return this.size}destroy(){const i=this[Wn];i&&(this[Wn]=null,this.__fireListenerList(!0),this.redGPUContext.resourceManager.unregisterManagementResource(this),i&&i.destroy())}}class AUniformBaseBuffer extends ABaseBuffer{[Zn];#Jt;#Qt;constructor(i,g,x,_,v=""){super(i,g,x),this.#Qt=_.byteLength,this.#Jt={size:this.#Qt,usage:this.usage,label:v};try{this[Wn]=i.gpuDevice.createBuffer(this.#Jt)}catch(i){console.error("GPU 버퍼 생성에 실패했습니다:",i)}i.gpuDevice.queue.writeBuffer(this[Wn],0,_),this[Zn]=_,this[Jn]=new Float32Array(_),this[Qn]=new Uint32Array(_)}get data(){return this[Zn]}get dataViewF32(){return this[Jn]}get dataViewU32(){return this[Qn]}get size(){return this.#Qt}get uniformBufferDescriptor(){return this.#Jt}writeOnlyBuffer(i,g){this.redGPUContext.gpuDevice.queue.writeBuffer(this.gpuBuffer,i.uniformOffset,new i.View("number"==typeof g?[g]:g))}}class UniformBuffer extends AUniformBaseBuffer{constructor(i,g,x="",_=""){super(i,"managedUniformBufferState",GPUBufferUsage.UNIFORM|GPUBufferUsage.COPY_DST,g,x);const{table:v}=this.targetResourceManagedState,b=v.get(_);if(b)return b.buffer;_&&(this.name=_,this[er]=_),this.redGPUContext.resourceManager.registerManagementResource(this,new ResourceStateUniformBuffer(this))}}Object.freeze(UniformBuffer);var tr="struct Camera { cameraMatrix:mat4x4, inverseCameraMatrix:mat4x4, cameraPosition:vec3, nearClipping:f32, farClipping:f32, fieldOfView:f32\n};\nstruct SystemUniform { projectionMatrix:mat4x4, inverseProjectionMatrix:mat4x4, projectionCameraMatrix:mat4x4, inverseProjectionCameraMatrix:mat4x4, camera:Camera,\n};\n@group(1) @binding(1) var systemUniforms:SystemUniform;\n";const defineProperty=(i,g,x,_,...v)=>{Object.defineProperty(i.prototype,g,x(g,_,...v))},defineProperties=i=>(g,x)=>{x.forEach(x=>{if(Array.isArray(x)){const[_,v,...b]=x;defineProperty(g,_,i,v,...b)}else defineProperty(g,x,i)})},createDefineByPreset=i=>{const g={};return Object.keys(i).forEach(x=>{const[_,v]=i[x];Object.assign(g,(i=>g=>g.reduce((g,x)=>({...g,[x]:i}),{}))(_)(Object.values(v)))}),{defineByPreset:(i,x)=>((i,g,x)=>{g.forEach(g=>{if(Array.isArray(g)){const[_,v,...b]=g,y=x[_];y||consoleAndThrowError(_,"is a key not defined in Define Preset."),defineProperty(i,_,y,v,...b)}else{const _=x[g];_||consoleAndThrowError(g,"is a key not defined in Define Preset."),defineProperty(i,g,_)}})})(i,x,g)}},nr={enumerable:!0,configurable:!1};function createSetter$5(i,g,x){return function(_){this[g]=_;const{gpuRenderInfo:v}=this;if(x){const{fragmentUniformInfo:g,fragmentUniformBuffer:x}=v;x.writeOnlyBuffer(g.members[i],_?1:0),this.dirtyPipeline=!0}else if(v){const{vertexUniformInfo:g,vertexUniformBuffer:x}=v;g.members[i]&&(x.writeOnlyBuffer(g.members[i],_?1:0),this.dirtyPipeline=!0)}}}function defineBoolean(i,g=!1,x=!0){const _=Symbol(i);return{get:function(){return void 0===this[_]&&(this[_]=g),this[_]},set:createSetter$5(i,_,x),...nr}}function defineColorRGB(i,g="#fff",x=!0){const _=Symbol(i);return{get:function(){if(void 0===this[_]){let v=255,b=255,y=255;if(isHexColor(g)){const i=convertHexToRgb(g);v=i.r,b=i.g,y=i.b}this[_]=new ColorRGB(v,b,y,()=>{const{gpuRenderInfo:g}=this;if(g)if(x){const{fragmentUniformInfo:x,fragmentUniformBuffer:v}=g;v.writeOnlyBuffer(x.members[i],this[_].rgbNormalLinear)}else{const{vertexUniformInfo:x,vertexUniformBuffer:v}=g;v.writeOnlyBuffer(x.members[i],this[_].rgbNormalLinear)}})}return this[_]},...nr}}function defineColorRGBA(i,g="#fff",x=!0){const _=Symbol(i);return{get:function(){if(void 0===this[_]){let v=255,b=255,y=255,S=1;if(isHexColor(g)){const i=convertHexToRgb(g);v=i.r,b=i.g,y=i.b}this[_]=new ColorRGBA(v,b,y,S,()=>{const{gpuRenderInfo:g}=this;if(g)if(x){const{fragmentUniformInfo:x,fragmentUniformBuffer:v}=g;v.writeOnlyBuffer(x.members[i],this[_].rgbaNormalLinear)}else{const{vertexUniformInfo:x,vertexUniformBuffer:v}=g;v.writeOnlyBuffer(x.members[i],this[_].rgbaNormalLinear)}})}return this[_]},...nr}}function createSetter$4(i,g,x){const _=`use${i.charAt(0).toUpperCase()}${i.substring(1)}`;return function(i){const v=this[g];this[g]=i,this.updateTexture(v,i);const{gpuRenderInfo:b}=this;if(x){const{fragmentUniformInfo:g,fragmentUniformBuffer:x}=b;_ in this?this[_]=!!i:g.members[_]&&x.writeOnlyBuffer(g.members[_],i?1:0)}else if(b){const{vertexUniformInfo:g,vertexUniformBuffer:x}=b;g.members[_]&&x.writeOnlyBuffer(x.members[_],i?1:0)}}}function defineCubeTexture(i,g=!0){const x=Symbol(i);return{get:function(){return this[x]},set:createSetter$4(i,x,g),...nr}}function createSetter$3(i,g,x,_=0,v){return function(b){void 0!==_&&b<_&&(console.warn(`Value for ${i} is below the minimum (${_}). Received:${b}. Adjusted to ${_}.`),b=_),void 0!==v&&b>v&&(console.warn(`Value for ${i} exceeds the maximum (${v}). Received:${b}. Adjusted to ${v}.`),b=v),validatePositiveNumberRange(b),this[g]=b;const{gpuRenderInfo:y}=this;if(x){const{fragmentUniformInfo:x,fragmentUniformBuffer:_}=y;_.writeOnlyBuffer(x.members[i],this[g])}else if(y){const{vertexUniformInfo:x,vertexUniformBuffer:_}=y;_.writeOnlyBuffer(x.members[i],this[g])}}}function definePositiveNumberRange(i,g=1,x=!0,_=0,v){const b=Symbol(i);return{get:function(){return void 0===this[b]&&(this[b]=g),this[b]},set:createSetter$3(i,b,x,_,v),...nr}}function defineSampler(i){const g=Symbol(i);return{get:function(){return this[g]},set:function(i){const x=this[g];this[g]=i,this.updateSampler(x,i)},...nr}}function createSetter$2(i,g,x){const _=`use${i.charAt(0).toUpperCase()}${i.substring(1)}`;return function(i){const v=this[g];this[g]=i,this.updateTexture(v,i);const{gpuRenderInfo:b}=this;if(x){const{fragmentUniformInfo:g,fragmentUniformBuffer:x}=b;_ in this?this[_]=!!i:g.members[_]&&x.writeOnlyBuffer(g.members[_],i?1:0)}else if(b){const{vertexUniformInfo:g,vertexUniformBuffer:x}=b;g.members[_]&&x.writeOnlyBuffer(x.members[_],i?1:0)}}}function defineTexture$1(i,g=!0){const x=Symbol(i);return{get:function(){return this[x]},set:createSetter$2(i,x,g),...nr}}function createSetter$1(i,g,x,_=0,v){return function(b){validateUintRange(b),void 0!==_&&b<_&&(console.warn(`Value for ${i} is below the minimum (${_}). Received:${b}. Adjusted to ${_}.`),b=_),void 0!==v&&b>v&&(console.warn(`Value for ${i} exceeds the maximum (${v}). Received:${b}. Adjusted to ${v}.`),b=v),this[g]=b;const{gpuRenderInfo:y}=this;if(x){const{fragmentUniformInfo:x,fragmentUniformBuffer:_}=y;_.writeOnlyBuffer(x.members[i],this[g])}else if(y){const{vertexUniformInfo:x,vertexUniformBuffer:_}=y;_.writeOnlyBuffer(x.members[i],this[g])}}}function defineUintRange(i,g=0,x=!0,_=0,v){const b=Symbol(i);return{get:function(){return void 0===this[b]&&(this[b]=g),this[b]},set:createSetter$1(i,b,x,_,v),...nr}}function createSetter(i,g,x){return function(_){this[g]=_;const{gpuRenderInfo:v}=this;if(x){const{fragmentUniformInfo:g,fragmentUniformBuffer:x}=v;x.writeOnlyBuffer(g.members[i],_)}else if(v){const{vertexUniformInfo:g,vertexUniformBuffer:x}=v;x.writeOnlyBuffer(g.members[i],_)}}}function defineVector(i,g,x=!0){const _=Symbol(i);return{get:function(){return void 0===this[_]&&(this[_]=g),this[_]},set:createSetter(i,_,x),...nr}}function defineProperty_vec4$1(i,g=[0,0,0,0]){return defineVector(i,g)}function defineProperty_vec3$1(i,g=[0,0,0]){return defineVector(i,g)}function defineProperty_vec2$1(i,g=[0,0]){return defineVector(i,g)}function defineProperty_PositiveNumberRange$1(i,g=1,x,_){return definePositiveNumberRange(i,g,!0,x,_)}Object.freeze(nr),Object.freeze(defineBoolean),Object.freeze(defineColorRGB),Object.freeze(defineColorRGBA),Object.freeze(defineCubeTexture),Object.freeze(definePositiveNumberRange),Object.freeze(defineSampler),Object.freeze(defineTexture$1),Object.freeze(defineUintRange),Object.freeze(defineVector);const rr={},ir={AO_STRENGTH:"aoStrength",SPECULAR_STRENGTH:"specularStrength",EMISSIVE_STRENGTH:"emissiveStrength",OPACITY:"opacity",SHININESS:"shininess",NORMAL_SCALE:"normalScale"},ar={},sr={ALPHA_TEXTURE_SAMPLER:"alphaTextureSampler",AO_TEXTURE_SAMPLER:"aoTextureSampler",DIFFUSE_TEXTURE_SAMPLER:"diffuseTextureSampler",EMISSIVE_TEXTURE_SAMPLER:"emissiveTextureSampler",ENVIRONMENT_TEXTURE_SAMPLER:"environmentTextureSampler",NORMAL_TEXTURE_SAMPLER:"normalTextureSampler",SPECULAR_TEXTURE_SAMPLER:"specularTextureSampler"},or={ENVIRONMENT_TEXTURE:"environmentTexture"},ur={},lr={},cr={},hr={ALPHA_TEXTURE:"alphaTexture",AO_TEXTURE:"aoTexture",DIFFUSE_TEXTURE:"diffuseTexture",EMISSIVE_TEXTURE:"emissiveTexture",NORMAL_TEXTURE:"normalTexture",SPECULAR_TEXTURE:"specularTexture"},fr={COLOR:"color",EMISSIVE_COLOR:"emissiveColor",SPECULAR_COLOR:"specularColor"},dr={...createDefineByPreset({defineBoolean:[defineBoolean,rr],definePositiveNumber:[defineProperty_PositiveNumberRange$1,ir],defineUint:[defineUintRange,ar],defineVec2:[defineProperty_vec2$1,ur],defineVec3:[defineProperty_vec3$1,lr],defineVec4:[defineProperty_vec4$1,cr],defineColorRGB:[defineColorRGB,fr],defineSampler:[defineSampler,sr],defineTexture:[defineTexture$1,hr],defineCubeTexture:[defineCubeTexture,or]}),defineBoolean:defineProperties(defineBoolean),definePositiveNumber:defineProperties(defineProperty_PositiveNumberRange$1),defineUint:defineProperties(defineUintRange),defineVec2:defineProperties(defineProperty_vec2$1),defineVec3:defineProperties(defineProperty_vec3$1),defineVec4:defineProperties(defineProperty_vec4$1),defineColorRGB:defineProperties(defineColorRGB),defineColorRGBA:defineProperties(defineColorRGBA),defineSampler:defineProperties(defineSampler),defineTexture:defineProperties(defineTexture$1),defineCubeTexture:defineProperties(defineCubeTexture),PRESET_BOOLEAN:rr,PRESET_POSITIVE_NUMBER:ir,PRESET_UINT:ar,PRESET_SAMPLER:sr,PRESET_TEXTURE:hr,PRESET_CUBE_TEXTURE:or,PRESET_VEC2:ur,PRESET_VEC3:lr,PRESET_VEC4:cr,PRESET_COLOR_RGB:fr};Object.freeze(dr);const mr={ZERO:"zero",ONE:"one",SRC:"src",ONE_MINUS_SRC:"one-minus-src",SRC_ALPHA:"src-alpha",ONE_MINUS_SRC_ALPHA:"one-minus-src-alpha",DST:"dst",ONE_MINUS_DST:"one-minus-dst",DST_ALPHA:"dst-alpha",ONE_MINUS_DST_ALPHA:"one-minus-dst-alpha",SRC_ALPHA_SATURATED:"src-alpha-saturated",CONSTANT:"constant",ONE_MINUS_CONSTANT:"one-minus-constant",SRC1:"src1",ONE_MINUS_SRC1:"one-minus-src1",SRC1_ALPHA:"src1-alpha",ONE_MINUS_SRC1_ALPHA:"one-minus-src1-alpha"};Object.freeze(mr);const pr={ADD:"add",SUBTRACT:"subtract",REVERSE_SUBTRACT:"reverse-subtract",MIN:"min",MAX:"max"};Object.freeze(pr);const gr=Object.values(mr),xr=Object.values(pr);class BlendState{state;#en;#tn;#nn;#rn;constructor(i,g,x,_){this.#rn=i,this.srcFactor=g,this.dstFactor=x,this.operation=_}get operation(){return this.#nn}set operation(i){xr.includes(i)||consoleAndThrowError(`Invalid GPUBlendOperation:${i}. Valid operations are ${xr.join(",")}`),this.#nn=i,this.#in()}get srcFactor(){return this.#en}set srcFactor(i){gr.includes(i)||consoleAndThrowError(`Invalid GPUBlendFactor:${i}. Valid srcFactor factors are ${gr.join(",")}`),this.#en=i,this.#in()}get dstFactor(){return this.#tn}set dstFactor(i){gr.includes(i)||consoleAndThrowError(`Invalid GPUBlendFactor:${i}. Valid dstFactor factors are ${gr.join(",")}`),this.#tn=i,this.#in()}#in(){const i=this.#nn?{operation:this.#nn}:{},g=this.#en?{srcFactor:this.#en}:{},x=this.#tn?{dstFactor:this.#tn}:{};this.state={...i,...g,...x},this.#rn.dirtyPipeline=!0}}const _r=new Map,vr=new WeakMap;let br,yr,Sr;class PackedTexture{#u=createUUID();#l;#ae;#L;#c;#an;#xe=new Map;constructor(i){this.#l=i,this.#c=i.gpuDevice,this.#sn(),this.#ae=this.#on()}get uuid(){return this.#u}get gpuTexture(){return this.#L}static getCacheMap(){return _r}async packing(i,g,x,_,v){const b={r:"r",g:"g",b:"b",a:"a",...v},y=`${i.r?.label||""}_${i.g?.label||""}_${i.b?.label||""}_${i.a?.label||""}`,S=`${JSON.stringify(b)}_${y}`;if(!(i.r||i.g||i.b||i.a))return;this.#un(S);_r.get(S)||await this.#ln(i,g,x,_,b,S)}destroy(){const i=vr.get(this);if(i){const g=_r.get(i);g&&(g.useNum--,0===g.useNum&&(g.gpuTexture?.destroy(),_r.delete(i))),vr.delete(this)}}#sn(){Sr=this.#l.resourceManager.createGPUBuffer("PACK_TEXTURE_MAPPING_BUFFER",{size:16,usage:GPUBufferUsage.UNIFORM|GPUBufferUsage.COPY_DST}),yr||(yr=this.#l.resourceManager.createBindGroupLayout("PACK_TEXTURE_BIND_GROUP_LAYOUT",{entries:[{binding:0,visibility:GPUShaderStage.FRAGMENT,texture:{}},{binding:1,visibility:GPUShaderStage.FRAGMENT,texture:{}},{binding:2,visibility:GPUShaderStage.FRAGMENT,texture:{}},{binding:3,visibility:GPUShaderStage.FRAGMENT,texture:{}},{binding:4,visibility:GPUShaderStage.FRAGMENT,sampler:{}},{binding:5,visibility:GPUShaderStage.FRAGMENT,buffer:{type:"uniform"}}]})),br||(br=this.#cn())}#hn(i){const g=`${i.r?.label||"empty"}_${i.g?.label||"empty"}_${i.b?.label||"empty"}_${i.a?.label||"empty"}`,{resourceManager:x}=this.#l;if(!this.#xe.has(g)){const _=[{binding:0,resource:x.getGPUResourceBitmapTextureView(i.r)},{binding:1,resource:x.getGPUResourceBitmapTextureView(i.g)},{binding:2,resource:x.getGPUResourceBitmapTextureView(i.b)},{binding:3,resource:x.getGPUResourceBitmapTextureView(i.a)},{binding:4,resource:this.#ae},{binding:5,resource:{buffer:Sr}}],v=this.#c.createBindGroup({label:`PACK_TEXTURE_BIND_GROUP_${g}`,layout:yr,entries:_});this.#xe.set(g,v)}this.#an=this.#xe.get(g)}#un(i){const g=vr.get(this);if(g&&g!==i){const i=_r.get(g);i&&(i.useNum--,0===i.useNum&&(i.gpuTexture?.destroy(),_r.delete(g)))}const x=_r.get(i);x&&(this.#L=x.gpuTexture,x.useNum++),vr.set(this,i)}async#ln(i,g,x,_,v,b){const y={size:[g,x,1],format:"rgba8unorm",usage:GPUTextureUsage.RENDER_ATTACHMENT|GPUTextureUsage.TEXTURE_BINDING|GPUTextureUsage.COPY_SRC,label:_||`PACK_TEXTURE_${createUUID()}`,mipLevelCount:getMipLevelCount(g,x)};this.#L&&(this.#L=null);const S=this.#l.resourceManager.createManagedTexture(y),w=new Uint32Array([["r","g","b","a"].indexOf(v.r),["r","g","b","a"].indexOf(v.g),["r","g","b","a"].indexOf(v.b),["r","g","b","a"].indexOf(v.a)]);this.#c.queue.writeBuffer(Sr,0,w),this.#hn(i),this.#fn(S),this.#L=y.mipLevelCount>1?this.#l.resourceManager.mipmapGenerator.generateMipmap(S,y):S,_r.set(b,{gpuTexture:this.#L,useNum:1,mappingKey:b,uuid:this.#u}),this.#an=null}#fn(i){const{resourceManager:g}=this.#l,x=this.#c.createCommandEncoder({label:"PackedTexture_CommandEncoder"}),_=x.beginRenderPass({colorAttachments:[{view:g.getGPUResourceBitmapTextureView(i,{baseMipLevel:0,mipLevelCount:1,dimension:"2d",label:`${i.label}_RENDER_TARGET`}),loadOp:"clear",storeOp:"store",clearValue:[0,0,0,0]}]});_.setPipeline(br),_.setBindGroup(0,this.#an),_.draw(6,1,0,0),_.end(),this.#c.queue.submit([x.finish()])}#cn(){const i="struct VertexOut { @builtin(position) position:vec4, @location(0) uv:vec2,\n};\n@vertex\nfn vertexMain(@builtin(vertex_index) VertexIndex:u32) -> VertexOut { var pos=array,6>( vec2(-1.0,-1.0), vec2( 1.0,-1.0), vec2(-1.0,1.0), vec2(-1.0,1.0), vec2( 1.0,-1.0), vec2( 1.0,1.0) ); var uv=array,6>( vec2(0.0,1.0), vec2(1.0,1.0), vec2(0.0,0.0), vec2(0.0,0.0), vec2(1.0,1.0), vec2(1.0,0.0) ); var output:VertexOut; output.position=vec4(pos[VertexIndex],0.0,1.0); output.uv=uv[VertexIndex]; return output;\n}\nstruct ComponentMapping { r_component:u32, g_component:u32, b_component:u32, a_component:u32,\n};\n@group(0) @binding(0) var textureR:texture_2d;\n@group(0) @binding(1) var textureG:texture_2d;\n@group(0) @binding(2) var textureB:texture_2d;\n@group(0) @binding(3) var textureA:texture_2d;\n@group(0) @binding(4) var sampler0:sampler;\n@group(0) @binding(5) var mapping:ComponentMapping;\nfn getComponent(color:vec4,componentIndex:u32) -> f32 { switch componentIndex { case 0u:{ return color.r;} case 1u:{ return color.g;} case 2u:{ return color.b;} case 3u:{ return color.a;} default:{ return 0.0;} }\n}\n@fragment\nfn fragmentMain(input:VertexOut) -> @location(0) vec4 { let colorR=textureSample(textureR,sampler0,input.uv); let colorG=textureSample(textureG,sampler0,input.uv); let colorB=textureSample(textureB,sampler0,input.uv); let colorA=textureSample(textureA,sampler0,input.uv); let r=getComponent(colorR,mapping.r_component); let g=getComponent(colorG,mapping.g_component); let b=getComponent(colorB,mapping.b_component); let a=getComponent(colorA,mapping.a_component); return vec4(r,g,b,a);\n}\n",{resourceManager:g}=this.#l,x=this.#c.createPipelineLayout({label:"PACK_TEXTURE_PIPELINE_LAYOUT",bindGroupLayouts:[yr]});return this.#c.createRenderPipeline({label:"PACK_TEXTURE_PIPELINE",layout:x,vertex:{module:g.createGPUShaderModule("PACK_TEXTURE_SHADER_MODULE",{code:i}),entryPoint:"vertexMain"},fragment:{module:g.createGPUShaderModule("PACK_TEXTURE_SHADER_MODULE",{code:i}),entryPoint:"fragmentMain",targets:[{format:"rgba8unorm"}]},primitive:{topology:"triangle-list"}})}#on(){return new Sampler(this.#l).gpuSampler}}const Tr={NORMAL:0,MULTIPLY:1,LIGHTEN:2,SCREEN:3,LINEAR_DODGE:4,SUBTRACT:5,DARKEN:6,OVERLAY:7,COLOR_DODGE:8,COLOR_BURN:9,HARD_LIGHT:10,SOFT_LIGHT:11,DIFFERENCE:12,EXCLUSION:13,DIVIDE:14,VIVID_LIGHT:15,LINEAR_BURN:16,PIN_LIGHT:17,SATURATION:18,HUE:19,LUMINOSITY:20,COLOR:21,NEGATION:22};class FragmentGPURenderInfo{fragmentShaderModule;fragmentShaderSourceVariant;fragmentShaderVariantConditionalBlocks;fragmentUniformInfo;fragmentBindGroupLayout;fragmentUniformBuffer;fragmentUniformBindGroup;fragmentState;constructor(i,g,x,_,v,b,y,S){this.fragmentShaderModule=i,this.fragmentShaderSourceVariant=g,this.fragmentShaderVariantConditionalBlocks=x,this.fragmentUniformInfo=_,this.fragmentBindGroupLayout=v,this.fragmentUniformBuffer=b,this.fragmentUniformBindGroup=y,this.fragmentState=S}}Object.freeze(FragmentGPURenderInfo);const getBindGroupLayoutDescriptorFromShaderInfo=(i,g,x,_=!0)=>{const{textures:v,samplers:b,uniforms:y,storage:S}=i,w=[];for(const i in S){const _=S[i],{binding:v,name:b,group:y,type:L}=_;if(_.access){const i={write:"write-only-storage",read:"read-only-storage",read_write:"read-write-storage"}[_.access];g===y&&w.push({binding:v,visibility:x,buffer:{type:i}})}else if(g===y){const{access:i,format:g}=L,_={write:"write-only",read:"read-only",read_write:"read-write"}[i],b=g.name;w.push({binding:v,visibility:x,storageTexture:{access:_,format:b}})}}for(const i in v){const b=v[i],{binding:y,name:S,group:L,type:k}=b,{name:H}=k;g===L&&w.push({binding:y,visibility:x,texture:"texture_depth_2d"===H||"texture_depth_multisampled_2d"===H?{viewDimension:"2d",sampleType:"depth",multisampled:_}:"texture_cube"===H?{viewDimension:"cube"}:"texture_2d_array"===H?{viewDimension:"2d-array",sampleType:"float",multisampled:!1}:{}})}for(const i in b){const _=b[i],{binding:v,name:y,group:S}=_;g===S&&w.push({binding:v,visibility:x,sampler:{type:"filtering"}})}for(const i in y){const _=y[i],{binding:v,name:b,group:S}=_;g===S&&w.push({binding:v,visibility:x,buffer:{type:"uniform"}})}return{entries:w}},getFragmentBindGroupLayoutDescriptorFromShaderInfo=(i,g)=>getBindGroupLayoutDescriptorFromShaderInfo(i,g,GPUShaderStage.FRAGMENT),getVertexBindGroupLayoutDescriptorFromShaderInfo=(i,g)=>getBindGroupLayoutDescriptorFromShaderInfo(i,g,GPUShaderStage.VERTEX),getComputeBindGroupLayoutDescriptorFromShaderInfo=(i,g,x)=>getBindGroupLayoutDescriptorFromShaderInfo(i,g,GPUShaderStage.COMPUTE,x);class ABaseMaterial extends ResourceBase{use2PathRender;gpuRenderInfo;dirtyPipeline=!1;transparent=!1;#dn;#mn;#pn=GPUColorWrite.ALL;#gn;#xn;#_n;#We;#vn;#bn;#yn;#Sn;#Tn;#Mn;#wn;#Cn;#Rn;#Re;#Pn;#Bn=Tr.MULTIPLY;constructor(i,g,x,_){super(i),this.#Rn=g,this.#vn=`FRAGMENT_MODULE_${this.#Rn}`,this.#bn=`FRAGMENT_BIND_GROUP_DESCRIPTOR_${g}`,this.#yn=`FRAGMENT_BIND_GROUP_LAYOUT_${g}`,this.#Sn=x,this.#Tn=x?.storage,this.#Mn=x?.uniforms.uniforms,this.#Pn=_,this.#wn=x.shaderSourceVariant.getUnionTextures(),this.#Cn=x.shaderSourceVariant.getUnionSamplers(),this.#Re=i.resourceManager.getGPUBindGroupLayout(this.#yn)||i.resourceManager.createBindGroupLayout(this.#yn,getFragmentBindGroupLayoutDescriptorFromShaderInfo(x,_)),this.#dn=new BlendState(this,mr.SRC_ALPHA,mr.ONE_MINUS_SRC_ALPHA,pr.ADD),this.#mn=new BlendState(this,mr.SRC_ALPHA,mr.ONE_MINUS_SRC_ALPHA,pr.ADD),this.#gn=i.resourceManager,this.#xn=this.#gn.basicSampler.gpuSampler,this.#_n=this.#gn.emptyBitmapTextureView,this.#We=this.#gn.emptyCubeTextureView}get tintBlendMode(){const i=Object.entries(Tr).find(([,i])=>i===this.#Bn);if(!i)throw new Error(`Invalid tint mode value:${this.#Bn}`);return i[0]}set tintBlendMode(i){const{fragmentUniformInfo:g,fragmentUniformBuffer:x}=this.gpuRenderInfo;let _;if("string"==typeof i){if(!(i in Tr))throw new Error(`Invalid tint mode key:${i}`);_=Tr[i]}else{if("number"!=typeof i||!Object.values(Tr).includes(i))throw new Error(`Invalid tint mode:${i}`);_=i}x.writeOnlyBuffer(g.members.tintBlendMode,_),this.#Bn=_}get MODULE_NAME(){return this.#Rn}get FRAGMENT_SHADER_MODULE_NAME(){return this.#vn}get FRAGMENT_BIND_GROUP_DESCRIPTOR_NAME(){return this.#bn}get STORAGE_STRUCT(){return this.#Tn}get UNIFORM_STRUCT(){return this.#Mn}get blendColorState(){return this.#dn}get blendAlphaState(){return this.#mn}get writeMaskState(){return this.#pn}set writeMaskState(i){this.#pn=i}initGPURenderInfos(){const{redGPUContext:i}=this,{resourceManager:g}=i,x=g.createGPUShaderModule(this.#vn,{code:this.#Sn.defaultSource}),_=new ArrayBuffer(Math.max(this.#Mn.arrayBufferByteLength,16)),v=new UniformBuffer(i,_,`UniformBuffer_${this.#Rn}_${this.uuid}`);this.gpuRenderInfo=new FragmentGPURenderInfo(x,this.#Sn.shaderSourceVariant,this.#Sn.conditionalBlocks,this.#Mn,this.#Re,v,null,null),this._updateBaseProperty(),this._updateFragmentState()}_updateFragmentState(){const{gpuDevice:i,resourceManager:g}=this.redGPUContext;this.#In();const x=[];for(const i in this.#wn){const _=this.#wn[i],{binding:v,name:b,group:y,type:S}=_,{name:w}=S;let L;L="texture_cube"===w?g.getGPUResourceCubeTextureView(this[b]):this[b]instanceof PackedTexture?g.getGPUResourceBitmapTextureView(this[b]):g.getGPUResourceBitmapTextureView(this[b])||this.#_n,2===y&&x.push({binding:v,resource:L})}for(const i in this.#Cn){const g=this.#Cn[i],{binding:_,name:v,group:b}=g;2===b&&x.push({binding:_,resource:this.getGPUResourceSampler(this[v])})}this.#Mn&&x.push({binding:this.#Mn.binding,resource:{buffer:this.gpuRenderInfo.fragmentUniformBuffer.gpuBuffer,offset:0,size:this.gpuRenderInfo.fragmentUniformBuffer.size}});const _={layout:this.gpuRenderInfo.fragmentBindGroupLayout,label:this.#bn,entries:x},v=i.createBindGroup(_);this.gpuRenderInfo.fragmentState=this.getFragmentRenderState(),this.gpuRenderInfo.fragmentUniformBindGroup=v}getFragmentRenderState(i="main"){return{module:this.gpuRenderInfo.fragmentShaderModule,entryPoint:i,targets:[{format:"rgba16float",blend:{color:this.blendColorState.state,alpha:this.blendAlphaState.state},writeMask:this.writeMaskState},{format:navigator.gpu.getPreferredCanvasFormat(),blend:void 0,writeMask:this.writeMaskState},{format:"rgba16float",blend:void 0,writeMask:this.writeMaskState}]}}_updateBaseProperty(){const{fragmentUniformInfo:i,fragmentUniformBuffer:g}=this.gpuRenderInfo,{members:x}=i;for(const _ in x){const x=this[_];x instanceof ColorRGBA?g.writeOnlyBuffer(i.members[_],x.rgbaNormalLinear):x instanceof ColorRGB?g.writeOnlyBuffer(i.members[_],x.rgbNormalLinear):Mr.test(_)||(this[_]=x)}}getGPUResourceSampler(i){return i?.gpuSampler||this.#xn}#In(){const{gpuDevice:i,resourceManager:g}=this.redGPUContext,x=this.#En(),_=`${this.#vn}_${x}`;let v=g.getGPUShaderModule(_);if(!v){const i=this.gpuRenderInfo.fragmentShaderSourceVariant.getVariant(x);v=i?g.createGPUShaderModule(_,{code:i}):this.gpuRenderInfo.fragmentShaderModule}this.gpuRenderInfo.fragmentShaderModule=v,this.#wn=this.gpuRenderInfo.fragmentShaderSourceVariant.getVariantTextures(x),this.#Cn=this.gpuRenderInfo.fragmentShaderSourceVariant.getVariantSamplers(x);const b=`${this.#yn}_${x}`;let y=g.getGPUBindGroupLayout(b);if(!y){const i={...this.#Sn,textures:this.#wn,samplers:this.#Cn};y=g.createBindGroupLayout(b,getFragmentBindGroupLayoutDescriptorFromShaderInfo(i,this.#Pn))}this.gpuRenderInfo.fragmentBindGroupLayout=y}#En(){const{fragmentShaderVariantConditionalBlocks:i}=this.gpuRenderInfo,g=new Set;for(const x of i)this[x]&&g.add(x);const x=g.size>0?Array.from(g).sort().join("+"):"none";return g.size,x}}const Mr=/^use\w+Texture$/;dr.defineByPreset(ABaseMaterial,[dr.PRESET_POSITIVE_NUMBER.OPACITY]),dr.defineBoolean(ABaseMaterial,[["useTint",!1]]),dr.defineColorRGBA(ABaseMaterial,["tint","#ff0000"]),Object.freeze(ABaseMaterial);class ABitmapBaseMaterial extends ABaseMaterial{__packingList;constructor(i,g,x,_){super(i,g,x,_)}updateTexture(i,g){i&&i.__removeDirtyPipelineListener(this.#Dn),g&&g.__addDirtyPipelineListener(this.#Dn),this.#Dn()}updateSampler(i,g){i&&i.__removeDirtyPipelineListener(this.#Dn),g&&g.__addDirtyPipelineListener(this.#Dn),this.#Dn()}#Dn=()=>{this.dirtyPipeline=!0;{let i=(this.__packingList||[]).length;for(;i--;)this.__packingList[i]()}this.gpuRenderInfo?.fragmentShaderModule?this._updateFragmentState():this.initGPURenderInfos()}}Object.freeze(ABitmapBaseMaterial);class AUVTransformBaseMaterial extends ABitmapBaseMaterial{dirtyTextureTransform=!1;#Un=[0,0];#Ln=[1,1];get textureOffset(){return this.#Un}set textureOffset(i){this.dirtyTextureTransform=!0,this.#Un=i}get textureScale(){return this.#Ln}set textureScale(i){this.dirtyTextureTransform=!0,this.#Ln=i}constructor(i,g,x,_){super(i,g,x,_)}}Object.freeze(AUVTransformBaseMaterial);var wr=Object.freeze({__proto__:null,ABaseMaterial:ABaseMaterial,ABitmapBaseMaterial:ABitmapBaseMaterial,AUVTransformBaseMaterial:AUVTransformBaseMaterial,FragmentGPURenderInfo:FragmentGPURenderInfo,getComputeBindGroupLayoutDescriptorFromShaderInfo:getComputeBindGroupLayoutDescriptorFromShaderInfo,getFragmentBindGroupLayoutDescriptorFromShaderInfo:getFragmentBindGroupLayoutDescriptorFromShaderInfo,getVertexBindGroupLayoutDescriptorFromShaderInfo:getVertexBindGroupLayoutDescriptorFromShaderInfo});class ASinglePassPostEffect{#An;#Gn;#kn;#On;#Nn;#Vn;#Fn;#Hn;#zn;#$n;#Kn;#Xn;#jn;#Yn;#qn;#h;#Wn;#Zn;#Jn;#Qn;#er;#tr=16;#nr=16;#rr=1;#ir=!1;#ar=!1;#l;#sr;#or=[];#N=0;#ur;#lr;constructor(i){this.#l=i,this.#sr=i.antialiasingManager}get useGBufferNormalTexture(){return this.#ar}set useGBufferNormalTexture(i){this.#ar=i}get videoMemorySize(){return this.#N}get useDepthTexture(){return this.#ir}set useDepthTexture(i){this.#ir=i}get redGPUContext(){return this.#l}get storageInfo(){return this.#qn}get shaderInfo(){return this.#sr.useMSAA?this.#Wn:this.#Zn}get uniformBuffer(){return this.#Xn}get uniformsInfo(){return this.#jn}get systemUuniformsInfo(){return this.#Yn}get WORK_SIZE_X(){return this.#tr}set WORK_SIZE_X(i){this.#tr=i}get WORK_SIZE_Y(){return this.#nr}set WORK_SIZE_Y(i){this.#nr=i}get WORK_SIZE_Z(){return this.#rr}set WORK_SIZE_Z(i){this.#rr=i}get outputTextureView(){return this.#er}clear(){this.#Qn&&(this.#Qn.destroy(),this.#Qn=null,this.#er=null)}init(i,g,x,_){this.#h=g;const{resourceManager:v}=i;this.#An=v.createGPUShaderModule(`${g}_MSAA`,{code:x.msaa}),this.#Gn=v.createGPUShaderModule(`${g}_NonMSAA`,{code:x.nonMsaa}),this.#Wn=parseWGSL(x.msaa),this.#Zn=parseWGSL(x.nonMsaa);const b=this.#Wn.storage,y=this.#Wn.uniforms;if(this.#qn=b,this.#jn=y.uniforms,this.#Yn=y.systemUniforms,this.#jn){const g=new ArrayBuffer(this.#jn.arrayBufferByteLength);this.#Xn=new UniformBuffer(i,g,`${this.constructor.name}_UniformBuffer`)}}execute(i,g,x,_){const v=g.createCommandEncoder({label:"ASinglePassPostEffect_Execute_CommandEncoder"}),b=v.beginComputePass();b.setPipeline(this.#Kn),b.setBindGroup(0,i.renderViewStateData.swapBufferIndex?this.#Vn:this.#Nn),b.setBindGroup(1,this.#Fn),b.dispatchWorkgroups(Math.ceil(x/this.WORK_SIZE_X),Math.ceil(_/this.WORK_SIZE_Y)),b.end(),g.queue.submit([v.finish()])}render(i,g,x,..._){const{gpuDevice:v,antialiasingManager:b}=this.#l,{useMSAA:y,msaaID:S}=b,w=this.#cr(i),L=this.#ur!==y||this.#lr!==S,k=this.#hr(_),H=this.outputTextureView,{redGPUContext:z}=i;return(w||L||k)&&this.#fr(i,_,H,y,z,v),this.update(performance.now()),this.execute(i,v,g,x),this.#ur=y,this.#lr=S,{texture:this.#Qn,textureView:H}}update(i){}updateUniform(i,g){this.uniformBuffer.writeOnlyBuffer(this.uniformsInfo.members[i],g)}#fr(i,g,x,_,v,b){const y=this.storageInfo,S=this.uniformsInfo,w=this.systemUuniformsInfo;this.#Hn=[],this.#zn=[],this.#$n=[];for(const i in y){const x=y[i],{binding:_,name:v}=x;"outputTexture"!==v&&(this.#Hn.push({binding:_,resource:g[_].textureView}),this.#zn.push({binding:_,resource:g[_].textureView}))}this.#$n.push({binding:0,resource:x}),this.shaderInfo.textures.forEach(g=>{const{name:x,binding:_}=g;"depthTexture"===x&&(this.#Hn.push({binding:_,resource:i.viewRenderTextureManager.depthTextureView}),this.#zn.push({binding:_,resource:i.viewRenderTextureManager.prevDepthTextureView})),"gBufferNormalTexture"===x&&(this.#Hn.push({binding:_,resource:i.redGPUContext.antialiasingManager.useMSAA?i.viewRenderTextureManager.gBufferNormalResolveTextureView:i.viewRenderTextureManager.gBufferNormalTextureView}),this.#zn.push({binding:_,resource:i.redGPUContext.antialiasingManager.useMSAA?i.viewRenderTextureManager.gBufferNormalResolveTextureView:i.viewRenderTextureManager.gBufferNormalTextureView}))}),w&&this.#$n.push({binding:w.binding,resource:{buffer:i.postEffectManager.postEffectSystemUniformBuffer.gpuBuffer,offset:0,size:i.postEffectManager.postEffectSystemUniformBuffer.size}}),this.#Xn&&S&&this.#$n.push({binding:S.binding,resource:{buffer:this.#Xn.gpuBuffer,offset:0,size:this.#Xn.size}});const L=_?this.#Wn:this.#Zn,k=_?this.#An:this.#Gn;this.#kn=v.resourceManager.getGPUBindGroupLayout(`${this.#h}_BIND_GROUP_LAYOUT_0_USE_MSAA_${_}`)||v.resourceManager.createBindGroupLayout(`${this.#h}_BIND_GROUP_LAYOUT_0_USE_MSAA_${_}`,getComputeBindGroupLayoutDescriptorFromShaderInfo(L,0,_)),this.#On=v.resourceManager.getGPUBindGroupLayout(`${this.#h}_BIND_GROUP_LAYOUT_1_USE_MSAA_${_}`)||v.resourceManager.createBindGroupLayout(`${this.#h}_BIND_GROUP_LAYOUT_1_USE_MSAA_${_}`,getComputeBindGroupLayoutDescriptorFromShaderInfo(L,1,_)),this.#Nn=b.createBindGroup({label:`${this.#h}_BIND_GROUP_0_USE_MSAA_${_}_SWAP0`,layout:this.#kn,entries:this.#Hn}),this.#Vn=b.createBindGroup({label:`${this.#h}_BIND_GROUP_0_USE_MSAA_${_}_SWAP0`,layout:this.#kn,entries:this.#zn}),this.#Fn=b.createBindGroup({label:`${this.#h}_BIND_GROUP_1_USE_MSAA_${_}`,layout:this.#On,entries:this.#$n}),this.#Kn=b.createComputePipeline({label:`${this.#h}_COMPUTE_PIPELINE_USE_MSAA_${_}`,layout:b.createPipelineLayout({bindGroupLayouts:[this.#kn,this.#On]}),compute:{module:k,entryPoint:"main"}}),this.#dr(g)}#mr(){this.#N=0,this.#Qn&&(this.#N=calculateTextureByteSize(this.#Qn))}#hr(i){if(!this.#or||this.#or.length!==i.length)return!0;for(let g=0;gi.clear())}render(i,g,x,_){let v;return this.#pr.forEach((b,y)=>{y&&(_=v),v=b.render(i,g,x,_)}),v}#mr(){this.#N=0,this.#pr.forEach(i=>{this.#N+=i.videoMemorySize})}}Object.freeze(AMultiPassPostEffect);const validateNumberRange=(i,g=-Number.MAX_VALUE,x=Number.MAX_VALUE)=>("number"!=typeof i&&consoleAndThrowError("Only numbers allowed."),"number"!=typeof g&&consoleAndThrowError("Only numbers allowed."),"number"!=typeof x&&consoleAndThrowError("Only numbers allowed."),(ix)&&consoleAndThrowError(`Only numbers within the range of [${g},${x}] are allowed. input:${i}`),!0),createCode=(i,g,x="",_=!1)=>{const{WORK_SIZE_X:v,WORK_SIZE_Y:b,WORK_SIZE_Z:y}=i,S=_?"texture_depth_multisampled_2d":"texture_depth_2d";return`\n ${x} @group(0) @binding(0) var sourceTexture:texture_storage_2d; ${i.useDepthTexture?`@group(0) @binding(1) var depthTexture:${S}`:""}; ${i.useGBufferNormalTexture?`@group(0) @binding(${i.useDepthTexture?2:1}) var gBufferNormalTexture:texture_2d`:""}; @group(1) @binding(0) var outputTexture:texture_storage_2d; ${tr} ${x?"@group(1) @binding(2) var uniforms:Uniforms;":""} @compute @workgroup_size(${v},${b},${y}) fn main ( @builtin(global_invocation_id) global_id:vec3, ){ ${g} } `},createBasicPostEffectCode=(i,g,x="")=>({msaa:createCode(i,g,x,!0),nonMsaa:createCode(i,g,x,!1)});Object.freeze(createBasicPostEffectCode);class BlurX extends ASinglePassPostEffect{#Qt=32;constructor(i){super(i),this.init(i,"POST_EFFECT_BLUR_X",createBasicPostEffectCode(this,"let index=vec2(global_id.xy);\nlet dimensions=textureDimensions(sourceTexture);\nlet dimW=f32(dimensions.x);\nlet size_value:f32=uniforms.size;\nvar sum:vec4=vec4(0.0,0.0,0.0,0.0);\nvar offset=random(global_id,0.0);\nvar total=0.0;\nlet loopSize=10.0;\nfor (var t=-loopSize;t <=loopSize;t=t + 1.0) { var percent=(t + offset - 0.5)/loopSize; var weight=1.0 - abs(percent); var ix=clamp((f32(global_id.x) + f32(size_value * percent)),0.0,dimW - 1.0); let delta=vec2(i32(ix),i32(global_id.y)); sum +=textureLoad(sourceTexture,delta).xyzw * weight; total +=weight;\n}\nsum/=total;\ntextureStore(outputTexture,vec2(global_id.xy),sum);\n","struct Uniforms { size:f32,\n};\nfn random(id:vec3,delta:f32) -> f32 { let seed:u32=((id.x << 16) | (id.y & 0xFFFF)) ^ (id.z * 0x63641362); let t:vec3=vec3(f32(seed & 0xFF),f32((seed >> 8) & 0xFF),f32(seed >> 16)); return delta + fract(sin(dot(t,vec3(12.9898,78.233,12.9898))) * 43758.5453);\n}\n")),this.size=this.#Qt}get size(){return this.#Qt}set size(i){validateNumberRange(i,0),this.#Qt=i,this.updateUniform("size",i)}}Object.freeze(BlurX);class BlurY extends ASinglePassPostEffect{#Qt=32;constructor(i){super(i),this.init(i,"POST_EFFECT_BLUR_Y",createBasicPostEffectCode(this,"let index=vec2(global_id.xy);\nlet dimensions=textureDimensions(sourceTexture);\nlet dimH=f32(dimensions.y);\nlet size_value:f32=uniforms.size;\nvar sum:vec4=vec4(0.0,0.0,0.0,0.0);\nvar offset=random(global_id,0.0);\nvar total=0.0;\nlet loopSize=10.0;\nfor (var t=-loopSize;t <=loopSize;t=t + 1.0) { var percent=(t + offset - 0.5)/loopSize; var weight=1.0 - abs(percent); var iy=clamp((f32(global_id.y) + f32(size_value * percent)),0.0,dimH - 1.0); let delta=vec2(i32(global_id.x),i32(iy)); sum +=textureLoad(sourceTexture,delta).xyzw * weight; total +=weight;\n}\nsum/=total;\ntextureStore(outputTexture,vec2(global_id.xy),sum);\n","struct Uniforms { size:f32,\n};\nfn random(id:vec3,delta:f32) -> f32 { let seed:u32=((id.x << 16) | (id.y & 0xFFFF)) ^ (id.z * 0x63641362); let t:vec3=vec3(f32(seed & 0xFF),f32((seed >> 8) & 0xFF),f32(seed >> 16)); return delta + fract(sin(dot(t,vec3(12.9898,78.233,12.9898))) * 43758.5453);\n}\n")),this.size=this.#Qt}get size(){return this.#Qt}set size(i){validateNumberRange(i,0),this.#Qt=i,this.updateUniform("size",i)}}Object.freeze(BlurY);class GaussianBlur extends AMultiPassPostEffect{#Qt=32;constructor(i){super(i,[new BlurX(i),new BlurY(i)])}get size(){return this.#Qt}set size(i){this.#Qt=i,this.passList.forEach(g=>g.size=i)}}Object.freeze(GaussianBlur);class SSAO_AO extends ASinglePassPostEffect{#gr=.253;#xr=1;#_r=.02;#vr=.02;#br=30;#yr=20;#Sr=1.5;#Tr=!0;constructor(i){super(i),this.useDepthTexture=!0,this.useGBufferNormalTexture=!0,this.init(i,"POST_EFFECT_SSAO",createBasicPostEffectCode(this,"{ let screenCoord=vec2(global_id.xy); let texSize=vec2(textureDimensions(sourceTexture)); if (screenCoord.x >=texSize.x || screenCoord.y >=texSize.y) { return;} let originalColor=textureLoad(sourceTexture,screenCoord); let depth=textureLoad(depthTexture,screenCoord,0); var failColor=vec4(select(originalColor.rgb,vec3(1.0),uniforms.useBlur > 0.0),originalColor.a); if (depth < 0.001) { textureStore(outputTexture,screenCoord,failColor); return; } let normalData=textureLoad(gBufferNormalTexture,screenCoord,0); if (length(normalData.rgb)<0.001) { textureStore(outputTexture,screenCoord,failColor); return; } let viewPos=reconstructViewPosition(screenCoord,depth); let viewNormal=reconstructViewNormal(textureLoad(gBufferNormalTexture,screenCoord,0)); let distToCamera=-viewPos.z; let depthScale=distToCamera * 0.1; let adaptiveRadius=uniforms.radius * (1.0 + depthScale); let noiseVec=getNoiseVec(vec2(screenCoord)); let tangent=normalize(noiseVec - viewNormal * dot(noiseVec,viewNormal)); let bitangent=cross(viewNormal,tangent); let tbn=mat3x3(tangent,bitangent,viewNormal); let samples=array,8>( vec3(0.04,0.03,0.08),vec3(-0.04,0.04,0.08), vec3(0.10,-0.08,0.18),vec3(-0.09,-0.10,0.18), vec3(0.18,0.15,0.30),vec3(-0.17,0.18,0.30), vec3(0.28,-0.25,0.45),vec3(-0.27,-0.28,0.45) ); var totalOcclusion=0.0; for (var i=0u;i < 8u;i++) { let sampleOffset=tbn * samples[i]; let sampleDir=normalize(sampleOffset); let sampleViewPos=viewPos + sampleOffset * adaptiveRadius; let clipPos=systemUniforms.projectionMatrix * vec4(sampleViewPos,1.0); let sampleUV=(clipPos.xy/clipPos.w) * vec2(0.5,-0.5) + 0.5; if (sampleUV.x < 0.0 || sampleUV.x > 1.0 || sampleUV.y < 0.0 || sampleUV.y > 1.0) { continue; } let sampleCoord=vec2(sampleUV * vec2(texSize)); let realDepth=textureLoad(depthTexture,sampleCoord,0); if (realDepth < 0.001) { continue;} let realViewPos=reconstructViewPosition(sampleCoord,realDepth); let adaptiveBias=uniforms.bias * (1.0 + distToCamera * uniforms.biasDistanceScale); let deltaZ=realViewPos.z - sampleViewPos.z; if (deltaZ > adaptiveBias && deltaZ < adaptiveRadius * 1.5) { let sampleDist=length(viewPos - realViewPos); if (sampleDist < adaptiveRadius * 1.5) { let angleWeight=pow(max(0.0,dot(viewNormal,sampleDir)),2.0); let distFalloff=1.0 - smoothstep(0.0,adaptiveRadius * 1.5,sampleDist); totalOcclusion +=angleWeight * distFalloff; } } } let ao=(totalOcclusion/8.0) * uniforms.intensity; let distanceFade=smoothstep( uniforms.fadeDistanceStart + uniforms.fadeDistanceRange, uniforms.fadeDistanceStart, distToCamera ); var finalAO=saturate(1.0 - (ao * distanceFade)); finalAO=pow(finalAO,uniforms.contrast); let finalColor=vec4( select(originalColor.rgb * vec3(finalAO),vec3(finalAO),uniforms.useBlur > 0.0), originalColor.a ); textureStore(outputTexture,screenCoord,finalColor);\n}\n","struct Uniforms { radius:f32, intensity:f32, bias:f32, biasDistanceScale:f32, fadeDistanceStart:f32, fadeDistanceRange:f32, contrast:f32, useBlur:f32,\n}\nfn getTextureSize() -> vec2 { return vec2(textureDimensions(sourceTexture));\n}\nfn reconstructViewPosition(screenCoord:vec2,depth:f32) -> vec3 { let texSize=getTextureSize(); let uv=(vec2(screenCoord) + 0.5)/texSize; let ndc=vec3(uv.x * 2.0 - 1.0,(1.0 - uv.y) * 2.0 - 1.0,depth); let clipPos=vec4(ndc,1.0); let viewPos4=systemUniforms.inverseProjectionMatrix * clipPos; return viewPos4.xyz/viewPos4.w;\n}\nfn reconstructViewNormal(gBufferNormalData:vec4) -> vec3 { let worldNormal=normalize(gBufferNormalData.rgb * 2.0 - 1.0); let viewNormal=(systemUniforms.camera.cameraMatrix * vec4(worldNormal,0.0)).xyz; return normalize(viewNormal);\n}\nfn getNoiseVec(p:vec2) -> vec3 { let noise=fract(52.9829189 * fract(dot(p,vec2(0.06711056,0.00583715)))); let angle=noise * 6.28318530718; return vec3(cos(angle),sin(angle),0.0);\n}\n")),this.radius=this.#gr,this.intensity=this.#xr,this.bias=this.#_r,this.biasDistanceScale=this.#vr,this.fadeDistanceStart=this.#br,this.fadeDistanceRange=this.#yr,this.contrast=this.#Sr,this.useBlur=!0}get useBlur(){return this.#Tr}set useBlur(i){this.#Tr=i,this.updateUniform("useBlur",i?1:0)}get radius(){return this.#gr}set radius(i){validatePositiveNumberRange(i,.01,5),this.#gr=i,this.updateUniform("radius",i)}get intensity(){return this.#xr}set intensity(i){validateNumberRange(i,0,10),this.#xr=i,this.updateUniform("intensity",i)}get bias(){return this.#_r}set bias(i){validateNumberRange(i,0,.1),this.#_r=i,this.updateUniform("bias",i)}get biasDistanceScale(){return this.#vr}set biasDistanceScale(i){validateNumberRange(i,0,.5),this.#vr=i,this.updateUniform("biasDistanceScale",i)}get fadeDistanceStart(){return this.#br}set fadeDistanceStart(i){validatePositiveNumberRange(i,1,200),this.#br=i,this.updateUniform("fadeDistanceStart",i)}get fadeDistanceRange(){return this.#yr}set fadeDistanceRange(i){validatePositiveNumberRange(i,1,100),this.#yr=i,this.updateUniform("fadeDistanceRange",i)}get contrast(){return this.#Sr}set contrast(i){validateNumberRange(i,.5,4),this.#Sr=i,this.updateUniform("contrast",i)}}Object.freeze(SSAO_AO);class SSAOBlend extends ASinglePassPostEffect{constructor(i){super(i);const{WORK_SIZE_X:g,WORK_SIZE_Y:x,WORK_SIZE_Z:_}=this,v=`\n @group(0) @binding(0) var sourceTexture0:texture_storage_2d; @group(0) @binding(1) var sourceTexture1:texture_storage_2d; @group(1) @binding(0) var outputTexture:texture_storage_2d;\n @compute @workgroup_size(${g},${x},${_}) fn main ( @builtin(global_invocation_id) global_id:vec3, ){ let index=vec2(global_id.xy ); let dimensions:vec2=textureDimensions(sourceTexture0); let dimW=f32(dimensions.x); let dimH=f32(dimensions.y); let uv=\tvec2(f32(index.x)/dimW,f32(index.y)/dimH); var diffuse:vec4=textureLoad( sourceTexture0, index, ); var blur:vec4=textureLoad( sourceTexture1, index, ); let finalColor=vec4((diffuse.rgb * blur.rgb ) ,diffuse.a); textureStore(outputTexture,index,finalColor ); }; `;this.init(i,"POST_EFFECT_OLD_BLOOM",{msaa:v,nonMsaa:v})}render(i,g,x,_,v){return super.render(i,g,x,_,v)}}Object.freeze(SSAOBlend);class SSAO extends AMultiPassPostEffect{#Mr;#wr;#Cr;constructor(i){super(i,[new SSAO_AO(i),new GaussianBlur(i),new SSAOBlend(i)]),this.#Mr=this.passList[0],this.#wr=this.passList[1],this.#wr.size=3,this.#Cr=this.passList[2]}get useBlur(){return this.#Mr.useBlur}set useBlur(i){this.#Mr.useBlur=i}get radius(){return this.#Mr.radius}set radius(i){this.#Mr.radius=i}get intensity(){return this.#Mr.intensity}set intensity(i){this.#Mr.intensity=i}get bias(){return this.#Mr.bias}set bias(i){this.#Mr.bias=i}get biasDistanceScale(){return this.#Mr.biasDistanceScale}set biasDistanceScale(i){this.#Mr.biasDistanceScale=i}get fadeDistanceStart(){return this.#Mr.fadeDistanceStart}set fadeDistanceStart(i){this.#Mr.fadeDistanceStart=i}get fadeDistanceRange(){return this.#Mr.fadeDistanceRange}set fadeDistanceRange(i){this.#Mr.fadeDistanceRange=i}get contrast(){return this.#Mr.contrast}set contrast(i){this.#Mr.contrast=i}render(i,g,x,_){const v=this.#Mr.render(i,g,x,_);if(this.useBlur){const b=this.#wr.render(i,g,x,v);return this.#Cr.render(i,g,x,_,b)}return v}}Object.freeze(SSAO);class SSR extends ASinglePassPostEffect{#Rr=64;#Pr=15;#Br=.02;#Ir=1;#Er=12;#Dr=.15;constructor(i){super(i),this.WORK_SIZE_X=8,this.WORK_SIZE_Y=8,this.WORK_SIZE_Z=1,this.useDepthTexture=!0,this.useGBufferNormalTexture=!0,this.init(i,"POST_EFFECT_SSR",createBasicPostEffectCode(this,"let screenCoord=vec2(global_id.xy);\nlet texDims=textureDimensions(sourceTexture);\nlet texSize=vec2(texDims);\nif (screenCoord.x >=texSize.x || screenCoord.y >=texSize.y) { return;\n}\nlet originalColor=textureLoad(sourceTexture,screenCoord);\nlet depth=textureLoad(depthTexture,screenCoord,0);\nif (depth >=0.999) { textureStore(outputTexture,screenCoord,originalColor); return;\n}\nlet gBufferNormalData=textureLoad(gBufferNormalTexture,screenCoord,0);\nlet precomputedReflectionStrength=gBufferNormalData.a;\nif (precomputedReflectionStrength < 0.05) { textureStore(outputTexture,screenCoord,originalColor); return;\n}\nlet worldPos=reconstructWorldPosition(screenCoord,depth);\nlet worldNormal=reconstructWorldNormal(gBufferNormalData);\nif (length(worldNormal) < 0.01) { textureStore(outputTexture,screenCoord,originalColor); return;\n}\nlet normal=normalize(worldNormal);\nlet cameraWorldPos=systemUniforms.camera.inverseCameraMatrix[3].xyz;\nlet reflectionDir=calculateWorldReflectionRay(worldPos,normal,cameraWorldPos);\nlet reflection=performWorldRayMarching(worldPos,reflectionDir);\nif (reflection.a > 0.001) { let finalReflectionStrength=reflection.a * uniforms.reflectionIntensity * precomputedReflectionStrength; let reflectionColor=reflection.rgb * finalReflectionStrength; let diffuseColor=originalColor.rgb * (1.0 - finalReflectionStrength); let finalColor=diffuseColor + reflectionColor; textureStore(outputTexture,screenCoord,vec4(finalColor,originalColor.a));\n} else { textureStore(outputTexture,screenCoord,originalColor);\n}\n","struct Uniforms { maxSteps:u32, maxDistance:f32, stepSize:f32, reflectionIntensity:f32, fadeDistance:f32, edgeFade:f32, _padding:f32, _padding2:f32, } fn getTextureDimensions() -> vec2 { return textureDimensions(depthTexture); } fn reconstructWorldPosition(screenCoord:vec2,depth:f32) -> vec3 { let texDims=getTextureDimensions(); let invTexDims=1.0/vec2(texDims); let uv=(vec2(screenCoord) + 0.5) * invTexDims; let ndc=vec3( uv.x * 2.0 - 1.0, -(uv.y * 2.0 - 1.0), depth * 2.0 - 1.0 ); let clipPos=vec4(ndc,1.0); let viewPos4=systemUniforms.inverseProjectionMatrix * clipPos; if (abs(viewPos4.w) < 1e-6) { return vec3(0.0); } let viewPos=viewPos4.xyz/viewPos4.w; let worldPos4=systemUniforms.camera.inverseCameraMatrix * vec4(viewPos,1.0); return worldPos4.xyz; } fn reconstructWorldNormal(gBufferNormalData:vec4) -> vec3 { return normalize(gBufferNormalData.rgb * 2.0 - 1.0); } fn worldToScreen(worldPos:vec3) -> vec2 { let clipPos4=systemUniforms.projectionCameraMatrix * vec4(worldPos,1.0); if (abs(clipPos4.w) < 1e-6) { return vec2(-1.0); } let ndc=clipPos4.xyz/clipPos4.w; return vec2(ndc.x * 0.5 + 0.5,-ndc.y * 0.5 + 0.5); } fn calculateEdgeFade(screenUV:vec2) -> f32 { let edge=min(screenUV,1.0 - screenUV); let edgeDist=min(edge.x,edge.y); return smoothstep(0.0,uniforms.edgeFade,edgeDist); } fn calculateWorldReflectionRay(worldPos:vec3,worldNormal:vec3,cameraWorldPos:vec3) -> vec3 { let viewDir=normalize(cameraWorldPos - worldPos); return reflect(-viewDir,worldNormal); }\nfn performWorldRayMarching(startWorldPos:vec3,rayDir:vec3) -> vec4 { let cameraWorldPos=systemUniforms.camera.inverseCameraMatrix[3].xyz; let cameraDistance=length(startWorldPos - cameraWorldPos); let distanceScale=1.0 + cameraDistance * 0.1; let adaptiveStepSize=uniforms.stepSize * min(distanceScale,4.0); let stepScale=1.0 + cameraDistance * 0.067; let adaptiveMaxSteps=u32(f32(uniforms.maxSteps) * min(stepScale,2.0)); let maxDistanceSq=uniforms.maxDistance * uniforms.maxDistance; let texDims=getTextureDimensions(); let texSizeF=vec2(texDims); let maxRefinementLevels=4u; let invMaxSteps=1.0/f32(adaptiveMaxSteps); var currentWorldPos=startWorldPos + rayDir * 0.01; var currentStepSize=adaptiveStepSize; var refinementLevel=0u; for (var i=0u;i < adaptiveMaxSteps;i++) { currentWorldPos +=rayDir * currentStepSize; let travelVec=currentWorldPos - startWorldPos; let travelDistanceSq=dot(travelVec,travelVec); if (travelDistanceSq > maxDistanceSq) { break; } let currentScreenUV=worldToScreen(currentWorldPos); if (any(currentScreenUV < vec2(0.0)) || any(currentScreenUV > vec2(1.0))) { break; } let screenCoord=vec2(currentScreenUV * texSizeF); let sampledDepth=textureLoad(depthTexture,screenCoord,0); if (sampledDepth >=0.999) { continue; } let sampledWorldPos=reconstructWorldPosition(screenCoord,sampledDepth); let rayDistanceFromCamera=length(currentWorldPos - cameraWorldPos); let surfaceDistanceFromCamera=length(sampledWorldPos - cameraWorldPos); let distanceDiff=rayDistanceFromCamera - surfaceDistanceFromCamera; let intersectionThreshold=currentStepSize * (4.0 + cameraDistance * 0.033); if (distanceDiff > 0.0 && distanceDiff < intersectionThreshold) { if (refinementLevel < maxRefinementLevels) { currentWorldPos -=rayDir * currentStepSize; currentStepSize *=0.6; refinementLevel++; continue; } let reflectionColor=textureLoad(sourceTexture,screenCoord); let travelDistance=sqrt(travelDistanceSq); let distanceFade=1.0 - smoothstep(0.0,uniforms.fadeDistance,travelDistance); let edgeFade=calculateEdgeFade(currentScreenUV); let stepFade=1.0 - f32(i) * invMaxSteps; let distanceCompensation=min(1.5,1.0 + cameraDistance * 0.04); let totalFade=distanceFade * edgeFade * stepFade * distanceCompensation; return vec4(reflectionColor.rgb,totalFade); } } return vec4(0.0);\n}\n")),this.maxSteps=this.#Rr,this.maxDistance=this.#Pr,this.stepSize=this.#Br,this.reflectionIntensity=this.#Ir,this.fadeDistance=this.#Er,this.edgeFade=this.#Dr}get maxSteps(){return this.#Rr}set maxSteps(i){validateNumberRange(i,1,512),this.#Rr=i,this.updateUniform("maxSteps",i)}get maxDistance(){return this.#Pr}set maxDistance(i){validatePositiveNumberRange(i,1,200),this.#Pr=i,this.updateUniform("maxDistance",i)}get stepSize(){return this.#Br}set stepSize(i){validatePositiveNumberRange(i,.001,5),this.#Br=i,this.updateUniform("stepSize",i)}get reflectionIntensity(){return this.#Ir}set reflectionIntensity(i){validateNumberRange(i,0,5),this.#Ir=i,this.updateUniform("reflectionIntensity",i)}get fadeDistance(){return this.#Er}set fadeDistance(i){validatePositiveNumberRange(i,1,100),this.#Er=i,this.updateUniform("fadeDistance",i)}get edgeFade(){return this.#Dr}set edgeFade(i){validateNumberRange(i,0,.5),this.#Dr=i,this.updateUniform("edgeFade",i)}}Object.freeze(SSR);class TAASharpen extends ASinglePassPostEffect{#Ur=.5;constructor(i){super(i),this.init(i,"POST_EFFECT_TAA_SHARPEN",createBasicPostEffectCode(this,"let index=vec2(global_id.xy);\nlet dimensions:vec2=textureDimensions(sourceTexture);\nif (any(index >=dimensions)) { return;\n}\nlet centerRGBA=textureLoad(sourceTexture,index);\nlet leftRGBA=textureLoad(sourceTexture,index - vec2(select(0u,1u,index.x > 0u),0u));\nlet rightRGBA=textureLoad(sourceTexture,min(index + vec2(1u,0u),dimensions - 1u));\nlet upRGBA=textureLoad(sourceTexture,index - vec2(0u,select(0u,1u,index.y > 0u)));\nlet downRGBA=textureLoad(sourceTexture,min(index + vec2(0u,1u),dimensions - 1u));\nlet lumaWeight=vec3(0.299,0.587,0.114);\nlet lCenter=dot(centerRGBA.rgb,lumaWeight);\nlet lLeft=dot(leftRGBA.rgb,lumaWeight);\nlet lRight=dot(rightRGBA.rgb,lumaWeight);\nlet lUp=dot(upRGBA.rgb,lumaWeight);\nlet lDown=dot(downRGBA.rgb,lumaWeight);\nlet minL=min(lCenter,min(min(lLeft,lRight),min(lUp,lDown)));\nlet maxL=max(lCenter,max(max(lLeft,lRight),max(lUp,lDown)));\nlet contrast=maxL - minL;\nvar finalRGBA:vec4;\nlet k=uniforms.sharpness * 0.2;\nif (contrast > 0.001) { let edgeRGB=4.0 * centerRGBA.rgb - (leftRGBA.rgb + rightRGBA.rgb + upRGBA.rgb + downRGBA.rgb); let sharpRGB=centerRGBA.rgb + edgeRGB * k; let edgeAlpha=4.0 * centerRGBA.a - (leftRGBA.a + rightRGBA.a + upRGBA.a + downRGBA.a); let sharpAlpha=centerRGBA.a + edgeAlpha * k; finalRGBA=vec4(sharpRGB,sharpAlpha);\n} else { finalRGBA=centerRGBA;\n}\ntextureStore(outputTexture,index,saturate(finalRGBA));","struct Uniforms { sharpness:f32\n};")),this.sharpness=.5}get sharpness(){return this.#Ur}set sharpness(i){validateNumberRange(i,0,1),this.#Ur=i,this.updateUniform("sharpness",i)}}Object.freeze(TAASharpen);class PostEffectManager{#Ft;#Lr=[];#Ar;#Gr;#kr;#me=16;#pe=4;#Or=1;#Nr;#Vr;#Fr;#Hr;#zr;#$r;#Kr;#N=0;#Xr;#jr;#Yr;#qr;#Wr;#Zr=!1;#Jr;#Qr=!1;constructor(i){this.#Ft=i,this.#ne()}get useSSAO(){return this.#Zr}set useSSAO(i){this.#Zr=i,this.#ei()}get ssao(){return this.#Wr||(this.#Wr=new SSAO(this.#Ft.redGPUContext)),this.#Wr}get useSSR(){return this.#Qr}set useSSR(i){this.#Qr=i,this.#ti()}get ssr(){return this.#Jr||(this.#Jr=new SSR(this.#Ft.redGPUContext)),this.#Jr}get postEffectSystemUniformBuffer(){return this.#$r}get view(){return this.#Ft}get effectList(){return this.#Lr}get videoMemorySize(){return this.#mr(),this.#N}addEffect(i){this.#Lr.push(i)}getEffectAt(i){return this.#Lr[i]}removeAllEffect(){this.#Lr.forEach(i=>{i.clear()}),this.#Lr.length=0}render(){const{viewRenderTextureManager:i,redGPUContext:g,taa:x,fxaa:_,toneMappingManager:v}=this.#Ft,{antialiasingManager:b}=g,{useMSAA:y,useFXAA:S,useTAA:w}=b,{gBufferColorTextureView:L,gBufferColorResolveTextureView:k,gBufferColorTexture:H}=i,{width:z,height:q}=H,W=y?k:L;this.#ni(),this.#Gr=this.#ri(this.#Ft,W);let be={texture:this.#Ar,textureView:this.#Gr};return be=v.render(z,q,be),this.#Lr.forEach(i=>{be=i.render(this.#Ft,z,q,be)}),S&&(be=_.render(this.#Ft,z,q,be)),this.#Zr&&(be=this.ssao.render(this.#Ft,z,q,be)),this.#Qr&&(be=this.ssr.render(this.#Ft,z,q,be)),w&&("View3D"===this.#Ft.constructor.name?(be=x.render(this.#Ft,z,q,be),this.#qr||(this.#qr=new TAASharpen(g)),be=this.#qr.render(this.#Ft,z,q,be)):be=_.render(this.#Ft,z,q,be)),be}clear(){this.#Lr.forEach(i=>{i.clear()})}#ei(){!this.#Wr&&this.#Zr&&(this.#Wr=new SSAO(this.#Ft.redGPUContext))}#ti(){!this.#Jr&&this.#Qr&&(this.#Jr=new SSR(this.#Ft.redGPUContext))}#ii(i){i.forEach(({key:i,value:g,dataView:x,targetMembers:_})=>{const v=_[i];x.set("number"==typeof g?[g]:g,v.uniformOffset/v.View.BYTES_PER_ELEMENT)})}#ni(){const{inverseProjectionMatrix:i,projectionMatrix:g,rawCamera:x,redGPUContext:_,scene:v}=this.#Ft,{gpuDevice:b}=_,{modelMatrix:y,position:S}=x,w=this.#Kr,L=this.#$r.gpuBuffer,k=x instanceof Camera2D,H=multiply$4(Cr,g,y);{const{members:_}=w,v=_.camera.members;this.#ii([{key:"projectionMatrix",value:g,dataView:this.#jr,targetMembers:_},{key:"inverseProjectionMatrix",value:i,dataView:this.#jr,targetMembers:_},{key:"projectionCameraMatrix",value:H,dataView:this.#jr,targetMembers:_},{key:"inverseProjectionCameraMatrix",value:invert$1(Rr,H),dataView:this.#jr,targetMembers:_},{key:"cameraMatrix",value:y,dataView:this.#jr,targetMembers:v},{key:"inverseCameraMatrix",value:invert$1(Rr,y),dataView:this.#jr,targetMembers:v},{key:"cameraPosition",value:S,dataView:this.#jr,targetMembers:v},{key:"nearClipping",value:k?0:x.nearClipping,dataView:this.#jr,targetMembers:v},{key:"farClipping",value:k?0:x.farClipping,dataView:this.#jr,targetMembers:v},{key:"fieldOfView",value:x.fieldOfView*Math.PI/180,dataView:this.#jr,targetMembers:v}])}b.queue.writeBuffer(L,0,this.#Xr)}#ne(){const{redGPUContext:i}=this.#Ft,{gpuDevice:g,resourceManager:x}=i,_=this.#ai();this.#Nr=x.createGPUShaderModule("POST_EFFECT_TEXTURE_COPY_COMPUTE_SHADER",{code:_}),this.#Fr=this.#si(i),this.#Hr=this.#oi(g,this.#Nr,this.#Fr);const v=parseWGSL(tr).uniforms.systemUniforms,b=new ArrayBuffer(v.arrayBufferByteLength);this.#Kr=v,this.#$r=new UniformBuffer(i,b,`${this.#Ft.name}_POST_EFFECT_SYSTEM_UNIFORM_BUFFER`),this.#Xr=new ArrayBuffer(this.#Kr.endOffset),this.#jr=new Float32Array(this.#Xr),this.#Yr=new Uint32Array(this.#Xr)}#mr(){const i=this.#Ar;if(!i)return 0;this.#N=calculateTextureByteSize(i),this.#Lr.forEach(i=>{this.#N+=i.videoMemorySize})}#ri(i,g){const{redGPUContext:x,viewRenderTextureManager:_}=i,{gBufferColorTexture:v}=_,{gpuDevice:b,antialiasingManager:y,resourceManager:S}=x,{useMSAA:w,changedMSAA:L}=y,{width:k,height:H}=v,z=k!==this.#zr?.width||H!==this.#zr?.height;return z&&(this.#Ar&&(this.#Ar.destroy(),this.#Ar=null),this.#Ar=this.#ui(b,k,H),this.#kr=S.getGPUResourceBitmapTextureView(this.#Ar)),(z||L)&&(this.#Vr=this.#li(x,this.#Fr,g,this.#kr)),this.#zr={width:k,height:H},this.#ci(b,this.#Hr,this.#Vr,k,H),this.#kr}#ai(){return`\n\t @group(0) @binding(0) var sourceTextureSampler:sampler; @group(0) @binding(1) var sourceTexture:texture_2d; @group(0) @binding(2) var outputTexture:texture_storage_2d; @compute @workgroup_size(${this.#me},${this.#pe},${this.#Or}) fn main ( @builtin(global_invocation_id) global_id:vec3, ){ let index=vec2(global_id.xy ); let dimensions:vec2=textureDimensions(sourceTexture); let dimW=f32(dimensions.x); let dimH=f32(dimensions.y); let uv=\tvec2((f32(index.x)+0.5)/dimW,(f32(index.y)+0.5)/dimH); var color:vec4=textureSampleLevel( sourceTexture, sourceTextureSampler, uv, 0 ); textureStore(outputTexture,index,color ); }; `}#si(i){return i.resourceManager.createBindGroupLayout(`${this.#Ft.name}_POST_EFFECT_TEXTURE_COPY_BIND_GROUP_LAYOUT`,{entries:[{binding:0,visibility:GPUShaderStage.COMPUTE,sampler:{type:"filtering"}},{binding:1,visibility:GPUShaderStage.COMPUTE,texture:{}},{binding:2,visibility:GPUShaderStage.COMPUTE,storageTexture:{format:"rgba16float"}}]})}#ui(i,g,x){return this.#Ft.redGPUContext.resourceManager.createManagedTexture({size:{width:g,height:x},format:"rgba16float",usage:GPUTextureUsage.TEXTURE_BINDING|GPUTextureUsage.STORAGE_BINDING|GPUTextureUsage.COPY_SRC,label:`${this.#Ft.name}_POST_EFFECT_STORAGE_TEXTURE_${g}x${x}`})}#li(i,g,x,_){const v=Date.now();return i.gpuDevice.createBindGroup({label:`${this.#Ft.name}_POST_EFFECT_TEXTURE_COPY_BIND_GROUP_${v}`,layout:g,entries:[{binding:0,resource:new Sampler(i).gpuSampler},{binding:1,resource:x},{binding:2,resource:_}]})}#oi(i,g,x){return i.createComputePipeline({label:"POST_EFFECT_TEXTURE_COPY_COMPUTE_PIPELINE",layout:i.createPipelineLayout({label:"POST_EFFECT_TEXTURE_COPY_PIPELINE_LAYOUT",bindGroupLayouts:[x]}),compute:{module:g,entryPoint:"main"}})}#ci(i,g,x,_,v){const b=i.createCommandEncoder({label:"POST_EFFECT_TEXTURE_COPY_COMMAND_ENCODER"}),y=b.beginComputePass({label:"POST_EFFECT_TEXTURE_COPY_COMPUTE_PASS"});y.setPipeline(g),y.setBindGroup(0,x),y.dispatchWorkgroups(Math.ceil(_/this.#me),Math.ceil(v/this.#pe)),y.end(),i.queue.submit([b.finish()])}}let Cr=create$4(),Rr=create$4();function defineProperty_boolean(i,g=!1){return defineBoolean(i,g,!1)}function defineProperty_uintRange(i,g=0,x,_){return defineUintRange(i,g,!1,x,_)}function defineProperty_PositiveNumberRange(i,g=1,x,_){return definePositiveNumberRange(i,g,!1,x,_)}Object.freeze(PostEffectManager);const Pr={USE_BILLBOARD:"useBillboard",RECEIVE_SHADOW:"receiveShadow"},Br={},Ir={},Er={...createDefineByPreset({defineBoolean:[defineProperty_boolean,Pr],defineUint:[defineProperty_uintRange,Ir],definePositiveNumber:[defineProperty_PositiveNumberRange,Br]}),defineBoolean:defineProperties(defineProperty_boolean),defineUint:defineProperties(defineProperty_uintRange),definePositiveNumber:defineProperties(defineProperty_PositiveNumberRange),defineVec4:defineProperties(function(i,g=[0,0,0,0]){return defineVector(i,g,!1)}),defineVec3:defineProperties(function(i,g=[0,0,0]){return defineVector(i,g,!1)}),defineVec2:defineProperties(function(i,g=[0,0]){return defineVector(i,g,!1)}),PRESET_BOOLEAN:Pr,PRESET_POSITIVE_NUMBER:Br,PRESET_UINT:Ir,PRESET_SAMPLER:{},PRESET_TEXTURE:{},PRESET_CUBE_TEXTURE:{},PRESET_VEC2:{},PRESET_VEC3:{},PRESET_VEC4:{},PRESET_COLOR_RGB:{}};Object.freeze(Er);class GeometryGPURenderInfo{buffers;constructor(i){this.buffers=i}}Object.freeze(GeometryGPURenderInfo);class AABB{minX;maxX;minY;maxY;minZ;maxZ;centerX;centerY;centerZ;xSize;ySize;zSize;geometryRadius;constructor(i,g,x,_,v,b){this.minX=i,this.maxX=g,this.minY=x,this.maxY=_,this.minZ=v,this.maxZ=b,this.centerX=(g+i)/2,this.centerY=(_+x)/2,this.centerZ=(b+v)/2,this.xSize=g-i,this.ySize=_-x,this.zSize=b-v,this.geometryRadius=Math.sqrt((this.xSize/2)**2+(this.ySize/2)**2+(this.zSize/2)**2)}intersects(i){return i instanceof AABB||consoleAndThrowError("allow only AABB instance"),this.minX<=i.maxX&&this.maxX>=i.minX&&this.minY<=i.maxY&&this.maxY>=i.minY&&this.minZ<=i.maxZ&&this.maxZ>=i.minZ}contains(i,g,x){if(Array.isArray(i)){const[g,x,_]=i;return g>=this.minX&&g<=this.maxX&&x>=this.minY&&x<=this.maxY&&_>=this.minZ&&_<=this.maxZ}return i>=this.minX&&i<=this.maxX&&g>=this.minY&&g<=this.maxY&&x>=this.minZ&&x<=this.maxZ}clone(){return new AABB(this.minX,this.maxX,this.minY,this.maxY,this.minZ,this.maxZ)}}const calculateGeometryAABB=i=>{if(!i||!i.data||0===i.vertexCount)return new AABB(0,0,0,0,0,0);const g=i.stride,x=i.data,_=i.vertexCount;let v=1/0,b=1/0,y=1/0,S=-1/0,w=-1/0,L=-1/0,k=0;for(;k<=_-4;k+=4){let i=k*g;const _=x[i],H=x[i+1],z=x[i+2];i=(k+1)*g;const q=x[i],W=x[i+1],be=x[i+2];i=(k+2)*g;const Ke=x[i],Xe=x[i+1],je=x[i+2];i=(k+3)*g;const Ye=x[i],Ze=x[i+1],Je=x[i+2];_S&&(S=_),q>S&&(S=q),Ke>S&&(S=Ke),Ye>S&&(S=Ye),Hw&&(w=H),W>w&&(w=W),Xe>w&&(w=Xe),Ze>w&&(w=Ze),zL&&(L=z),be>L&&(L=be),je>L&&(L=je),Je>L&&(L=Je)}for(;k<_;k++){const i=k*g,_=x[i],H=x[i+1],z=x[i+2];_S&&(S=_),H>w&&(w=H),z>L&&(L=z)}return new AABB(v,S,b,w,y,L)};class Geometry extends ResourceBase{gpuRenderInfo;#hi;#fi;#di;constructor(i,g,x){super(i),this.#mi(g),this.#pi(x);const{interleavedStruct:_}=this.#hi;this.gpuRenderInfo=new GeometryGPURenderInfo([{arrayStride:_.arrayStride,attributes:_.attributes}])}get vertexBuffer(){return this.#hi}get indexBuffer(){return this.#fi}get volume(){return this.#di||(this.#di=calculateGeometryAABB(this.#hi)),this.#di}#mi(i){const g=this.#hi;this.#hi=i,g&&g.__removeDirtyPipelineListener(this.#gi),i&&i.__addDirtyPipelineListener(this.#gi),this.#di=null}#pi(i){const g=this.#fi;this.#fi=i,g&&g.__removeDirtyPipelineListener(this.#xi),i&&i.__addDirtyPipelineListener(this.#xi)}#gi(){this.__fireListenerList()}#xi(){this.__fireListenerList()}}Object.freeze(Geometry);const Dr={UINT16:"uint16",UINT32:"uint32"};Object.freeze(Dr);class ResourceStateIndexBuffer{static dirtyList=[];buffer;label;uuid;#Wt=0;constructor(i){this.buffer=i,this.label=i.name,this.uuid=i.uuid}get useNum(){return this.#Wt}set useNum(i){this.#Wt=i,ResourceStateIndexBuffer.dirtyList.push(this)}}class IndexBuffer extends ABaseBuffer{[Zn];#_i=0;#vi=0;#F=Dr.UINT32;constructor(i,g,x=GPUBufferUsage.INDEX|GPUBufferUsage.COPY_DST,_=""){super(i,"managedIndexBufferState",x);const{table:v}=this.targetResourceManagedState,b=v.get(_);if(b)return b.buffer;_&&(this.name=_,this[er]=_),this.changeData(g),this.redGPUContext.resourceManager.registerManagementResource(this,new ResourceStateIndexBuffer(this))}get format(){return this.#F}get triangleCount(){return this.#vi}get indexCount(){return this.#_i}get data(){return this[Zn]}changeData(i){const{gpuDevice:g}=this;if(Array.isArray(i)&&(i=new Uint32Array(i)),this[Wn]){this.targetResourceManagedState.videoMemory-=this[Zn].byteLength||0;let i=this[Wn];requestAnimationFrame(()=>{i.destroy()}),this[Wn]=null}this[Zn]=i,this.#_i=i.length;const x={size:this[Zn].byteLength,usage:this.usage,label:this.name};this[Wn]=g.createBuffer(x),this.targetResourceManagedState.videoMemory+=this[Zn].byteLength||0,this.#vi=this.#_i/3,g.queue.writeBuffer(this[Wn],0,this[Zn])}}Object.freeze(IndexBuffer);class ResourceStateVertexBuffer{static dirtyList=[];buffer;label;uuid;#Wt=0;constructor(i){this.buffer=i,this.label=i.name,this.uuid=i.uuid}get useNum(){return this.#Wt}set useNum(i){this.#Wt=i,ResourceStateVertexBuffer.dirtyList.push(this)}}class VertexBuffer extends ABaseBuffer{[Zn];#bi=0;#yi=0;#Si;#vi=0;constructor(i,g,x,_=GPUBufferUsage.VERTEX|GPUBufferUsage.COPY_DST|GPUBufferUsage.STORAGE,v=""){super(i,"managedVertexBufferState",_);const{table:b}=this.targetResourceManagedState,y=b.get(v);if(y)return y.buffer;this.#Si=x,v&&(this.name=v,this[er]=v),this.changeData(g,this.#Si),this.redGPUContext.resourceManager.registerManagementResource(this,new ResourceStateVertexBuffer(this))}get data(){return this[Zn]}get stride(){return this.#yi}get interleavedStruct(){return this.#Si}get vertexCount(){return this.#bi}get triangleCount(){return this.#vi}changeData(i,g){const{gpuDevice:x}=this;if(Array.isArray(i)&&(i=new Float32Array(i)),this[Zn]=i,g&&this.#Ti(g),this[Wn]){this.targetResourceManagedState.videoMemory-=this[Zn].byteLength||0;let i=this[Wn];requestAnimationFrame(()=>{i.destroy()}),this[Wn]=null}const _={size:this[Zn].byteLength,usage:this.usage,label:this.name};this[Wn]=x.createBuffer(_),this.targetResourceManagedState.videoMemory+=this[Zn].byteLength||0,this.#vi=this[Zn].length/this.#yi,x.queue.writeBuffer(this[Wn],0,this[Zn])}updateData(i,g=0){i instanceof Array&&(i=new Float32Array(i));const{gpuDevice:x}=this;x.queue.writeBuffer(this[Wn],g,i)}updateAllData(i){const{gpuDevice:g}=this;g.queue.writeBuffer(this[Wn],0,this[Zn])}#Ti(i){this.#Si=i,this.#bi=0,this.#yi=0;for(const i in this.#Si.define){const g=this.#Si.define[i].attributeStride/Float32Array.BYTES_PER_ELEMENT;this.#bi+=g,this.#yi+=g}this.#bi=this[Zn].length/this.#bi}}Object.freeze(VertexBuffer);class VertexInterleavedStructElement{attributeName;attributeStride;interleaveType;constructor(i,g,x){this.attributeName=i,this.attributeStride=g,this.interleaveType=x}}class VertexInterleavedStruct{#Mi;#h="";#wi=[];#Ci=0;constructor(i,g=""){this.#h=g,this.#Ri(i),this.#Pi()}get label(){return this.#h}get attributes(){return this.#wi}get arrayStride(){return this.#Ci}get define(){return{...this.#Mi}}#Ri(i){let g={};for(const x in i){const _=i[x],v=_.stride;g[x]=new VertexInterleavedStructElement(x,v,_),v%4!=0&&consoleAndThrowError(`Invalid attribute stride:${v}`)}this.#Mi=g}#Pi(){this.#Ci=0,this.#wi=[];for(const[i,{attributeStride:g,interleaveType:x}]of Object.entries(this.#Mi))this.#wi.push({attributeName:i,shaderLocation:this.#wi.length,offset:this.#Ci,format:x.gpuVertexFormat}),this.#Ci+=g}}class VertexInterleaveType{static get float32(){return{numElements:1,stride:Float32Array.BYTES_PER_ELEMENT,gpuVertexFormat:"float32",offset:0}}static get float32x2(){return{numElements:2,stride:2*Float32Array.BYTES_PER_ELEMENT,gpuVertexFormat:"float32x2",offset:0}}static get float32x3(){return{numElements:3,stride:3*Float32Array.BYTES_PER_ELEMENT,gpuVertexFormat:"float32x3",offset:0}}static get float32x4(){return{numElements:4,stride:4*Float32Array.BYTES_PER_ELEMENT,gpuVertexFormat:"float32x4",offset:0}}}Object.freeze(VertexInterleaveType);class Primitive{#Bi;#hi;#fi;#di;constructor(i){validateRedGPUContext(i)}static get primitiveInterleaveStruct(){return new VertexInterleavedStruct({vertexPosition:VertexInterleaveType.float32x3,vertexNormal:VertexInterleaveType.float32x3,texcoord:VertexInterleaveType.float32x2},"primitiveInterleaveStruct")}get gpuRenderInfo(){return this.#Bi}get vertexBuffer(){return this.#hi}get indexBuffer(){return this.#fi}get volume(){return this.#di||(this.#di=calculateGeometryAABB(this.#hi)),this.#di}_setData(i){if(this.#hi=i.vertexBuffer,this.#fi=i.indexBuffer,this.#hi){const{interleavedStruct:i}=this.#hi;this.#Bi=new GeometryGPURenderInfo([{arrayStride:i.arrayStride,attributes:i.attributes}])}}}Object.freeze(Primitive);const createPrimitiveGeometry=(i,g,x,_)=>new Geometry(i,new VertexBuffer(i,new Float32Array(g),Primitive.primitiveInterleaveStruct,void 0,`VertexBuffer_${_}`),new IndexBuffer(i,new Uint32Array(x),void 0,`IndexBuffer_${_}`));class Plane extends Primitive{#Ii=function(){const i=[],g=[];return function(x,_,v,b,y,S,w,L){const k=v/2,H=b/2,z=Math.floor(y)||1,q=Math.floor(S)||1,W=z+1,be=q+1,Ke=v/z,Xe=b/q;i.length=0,g.length=0;for(let x=0;x0?1:-1,b[0]=0,b[1]=0),lookAt(this.#kt,_,v,b)}}class OrthographicCamera extends PerspectiveCamera{#f;#h;#Oi=1;#Ni=-1;#Vi=-1;#Fi=1;#Hi=1;#zi=.1;#$i=10;constructor(){super(),this.nearClipping=.01,this.farClipping=1e4}get top(){return this.#Oi}set top(i){validateNumber(i),this.#Oi=i}get bottom(){return this.#Ni}set bottom(i){validateNumber(i),this.#Ni=i}get left(){return this.#Vi}set left(i){validateNumber(i),this.#Vi=i}get right(){return this.#Fi}set right(i){validateNumber(i),this.#Fi=i}get zoom(){return this.#Hi}set zoom(i){validateNumberRange(i,this.#zi,this.#$i),this.#Hi=i}get minZoom(){return this.#zi}set minZoom(i){validateNumberRange(i,.01),this.#zi=i}get maxZoom(){return this.#$i}set maxZoom(i){validateNumberRange(i,.01),this.#$i=i}get name(){return this.#f||(this.#f=InstanceIdGenerator.getNextId(this.constructor)),this.#h||`${this.constructor.name} Instance ${this.#f}`}set name(i){this.#h=i}setZoom(i){this.zoom=i}}class AController{static#Ki=null;static#Xi=null;#f;#h;#l;#ji;#Yi;#qi=-1;#Wi=0;#Zi=new Set;#Ji=!1;#Qi=null;#ea=!1;#ta;#na=0;#ra=0;#ia=0;#aa=!1;constructor(i,g){this.#l=i,this.#Yi=g||{},this.#ji=g.camera||new PerspectiveCamera;const x=this.#l.detector.isMobile;this.#ta={moveKey:x?"touchmove":"mousemove",upKey:x?"touchend":"mouseup",downKey:x?"touchstart":"mousedown"},this.#sa()}get name(){return this.#f||(this.#f=InstanceIdGenerator.getNextId(this.constructor)),this.#h||`${this.constructor.name} Instance ${this.#f}`}set name(i){this.#h=i}get redGPUContext(){return this.#l}get camera(){return this.#ji}get x(){return this.camera.x}get y(){return this.camera.y}get z(){return this.camera.z}get hoveredView(){return this.#Qi}get keyboardActiveView(){return AController.#Ki}set keyboardActiveView(i){AController.#Ki=i,AController.#Xi=null===i?null:this}get isKeyboardActiveController(){return AController.#Xi===this}get keyboardProcessedThisFrame(){return this.#Ji}set keyboardProcessedThisFrame(i){this.#Ji=i}destroy(){const{moveKey:i,upKey:g,downKey:x}=this.#ta,{htmlCanvas:_}=this.redGPUContext;_.removeEventListener(x,this.#oa),_.removeEventListener(i,this.#ua),_.removeEventListener(i,this.#la),window.removeEventListener(g,this.#ca),this.#Yi.HD_Wheel&&_.removeEventListener("wheel",this.#ha)}update(i,g,x){this.#qi!==g&&(this.#Wi=-1===this.#qi?0:(g-this.#qi)/1e3,this.#qi=g,this.#Zi.clear(),this.#Ji=!1),this.#Zi.has(i)||(this.#Zi.add(i),this.#Yi.useKeyboard&&this.keyboardActiveView&&this.keyboardActiveView!==i||x?.(this.#Wi))}checkKeyboardInput(i,g){if(this.keyboardProcessedThisFrame)return!1;const{keyboardKeyBuffer:x}=i.redGPUContext;let _=!1;for(const i in g)if(x[g[i]]){_=!0;break}if(!_)return this.keyboardActiveView=null,!1;if(!this.keyboardActiveView){if(this.hoveredView!==i)return!1;this.keyboardActiveView=i}return this.keyboardActiveView===i&&(this.keyboardProcessedThisFrame=!0,!0)}getCanvasEventPoint=(i,g)=>{g.htmlCanvas;const x=g.detector.isMobile,_=g.boundingClientRect,v="clientX",b="clientY";let y,S;if(x){const g=i instanceof WheelEvent?i:i.changedTouches[0];y=g[v],S=g[b]}else{const g=i;y=g[v],S=g[b]}return{x:y-_.left,y:S-_.top}};findTargetViewByInputEvent=i=>{const g=this.#l;g.detector.isMobile;const{x:x,y:_}=this.getCanvasEventPoint(i,g),v=window.devicePixelRatio*g.renderScale,b=x*v,y=_*v;let S=null;for(const i of this.redGPUContext.viewList){const g=i.pixelRectObject;g.x{if(i.length<2)return 0;const g=i[0].clientX-i[1].clientX,x=i[0].clientY-i[1].clientY;return Math.sqrt(g*g+x*x)};#sa(){const{redGPUContext:i}=this,{htmlCanvas:g}=i,{downKey:x,moveKey:_}=this.#ta;g.addEventListener(x,this.#oa),g.addEventListener(_,this.#ua),this.#Yi.HD_Wheel&&g.addEventListener("wheel",this.#ha,{passive:!1}),this.#Yi.HD_TouchPinch&&g.addEventListener("touchmove",this.#da,{passive:!1})}#ua=i=>{AController.#Ki||this.#ea||(this.#Qi=this.findTargetViewByInputEvent(i))};#oa=i=>{const g=this.findTargetViewByInputEvent(i);if(!g)return;AController.#Ki||this.#ea||(this.#Qi=g);const{redGPUContext:x}=this,{moveKey:_,upKey:v}=this.#ta,{x:b,y:y}=this.getCanvasEventPoint(i,x);this.#na=b,this.#ra=y,i instanceof TouchEvent&&(i.touches.length>=2?(this.#aa=!0,this.#ia=this.#fa(i.touches)):(this.#aa=!1,this.#ia=0)),this.#Zi.has(g)&&(this.#ea=!0,AController.#Ki=g,x.htmlCanvas.addEventListener(_,this.#la),window.addEventListener(v,this.#ca))};#la=i=>{if(i instanceof TouchEvent&&i.touches.length>=2)return void(this.#aa=!0);this.#aa=!1;const{x:g,y:x}=this.getCanvasEventPoint(i,this.#l),_=g-this.#na,v=x-this.#ra;this.#na=g,this.#ra=x,this.#Yi.HD_Move?.(_,v)};#da=i=>{if(i.touches.length<2||!this.#Yi.HD_TouchPinch)return;if(!this.#aa)return;i.preventDefault();const g=this.#fa(i.touches);if(0===this.#ia)return void(this.#ia=g);if(this.findTargetViewByInputEvent(i).rawCamera!==this.#ji)return;const x=g/this.#ia;this.#Yi.HD_TouchPinch?.(x),this.#ia=g};#ca=()=>{const{htmlCanvas:i}=this.#l,{moveKey:g,upKey:x}=this.#ta;this.#aa=!1,this.#ia=0,this.#ea=!1,i.removeEventListener(g,this.#la),window.removeEventListener(x,this.#ca)};#ha=i=>{const g=this.findTargetViewByInputEvent(i);g&&g.rawCamera===this.#ji&&(i.stopPropagation(),i.preventDefault(),this.#Yi.HD_Wheel?.(i))}}const Ur=Math.PI/180;class IsometricController extends AController{#ma=45;#pa=1;#ga=1;#xa=.1;#_a=.1;#zi=.5;#$i=3;#va=15;#ba=15;#ya=.1;#Sa=null;#Ta=0;#Ma=0;#wa=50;#Ca=.1;#Ra={moveUp:"w",moveDown:"s",moveLeft:"a",moveRight:"d"};#Pa=1;#Ba=.1;constructor(i){super(i,{camera:new OrthographicCamera,HD_Wheel:i=>{this.#ga-=i.deltaY/100*this.#_a,this.#ga=Math.max(this.#zi,Math.min(this.#$i,this.#ga))},HD_Move:(g,x)=>{if(!this.#Sa)return;const _=this.#ma*Ur,v=Math.cos(_),b=Math.sin(_),y=this.#va/this.#pa/i.boundingClientRect.height,S=g*y,w=x*y,L=-S*v-w*b,k=-S*-b-w*v;this.#Ta+=L,this.#Ma+=k},HD_TouchPinch:i=>{this.#ga/=i,this.#ga=Math.max(this.#zi,Math.min(this.#$i,this.#ga))},useKeyboard:!0}),this.#Sa=new Mesh(i),this.#Sa.setIgnoreFrustumCullingRecursively(!0)}get zoom(){return this.#ga}set zoom(i){validateNumberRange(i),this.#ga=Math.max(this.#zi,Math.min(this.#$i,i))}get zoomInterpolation(){return this.#xa}set zoomInterpolation(i){validateNumberRange(i,1e-4,1),this.#xa=i}get speedZoom(){return this.#_a}set speedZoom(i){validateNumberRange(i,.01),this.#_a=i}get minZoom(){return this.#zi}set minZoom(i){validateNumberRange(i,.01),this.#zi=i,this.zoom=this.#ga}get maxZoom(){return this.#$i}set maxZoom(i){validateNumberRange(i,.01),this.#$i=i,this.zoom=this.#ga}get viewHeight(){return this.#ba}set viewHeight(i){validateNumberRange(i,.1),this.#ba=i}get viewHeightInterpolation(){return this.#ya}set viewHeightInterpolation(i){validateNumberRange(i,1e-4,1),this.#ya=i}get moveSpeed(){return this.#wa}set moveSpeed(i){validateNumberRange(i,.01),this.#wa=i}get moveSpeedInterpolation(){return this.#Ca}set moveSpeedInterpolation(i){validateNumberRange(i,1e-4,1),this.#Ca=i}get mouseMoveSpeed(){return this.#Pa}set mouseMoveSpeed(i){validateNumberRange(i,.01),this.#Pa=i}get mouseMoveSpeedInterpolation(){return this.#Ba}set mouseMoveSpeedInterpolation(i){validateNumberRange(i,1e-4,1),this.#Ba=i}get keyNameMapper(){return{...this.#Ra}}get targetX(){return this.#Sa.x}get targetY(){return this.#Sa.y}get targetZ(){return this.#Sa.z}setMoveUpKey(i){this.#Ra.moveUp=i}setMoveDownKey(i){this.#Ra.moveDown=i}setMoveLeftKey(i){this.#Ra.moveLeft=i}setMoveRightKey(i){this.#Ra.moveRight=i}update(i,g){super.update(i,g,g=>{this.#Ia(i,g)})}#Ia(i,g){if(this.#Ea(i,g),this.#pa=this.#ga+(this.#pa-this.#ga)*Math.pow(this.#xa,g),this.#va=this.#ba+(this.#va-this.#ba)*Math.pow(this.#ya,g),!this.#Sa)return;const x=Math.pow(this.#Ca,g);this.#Sa.x=this.#Ta+(this.#Sa.x-this.#Ta)*x,this.#Sa.z=this.#Ma+(this.#Sa.z-this.#Ma)*x;const _=this.#Sa.position,v=this.#ma*Ur,{width:b,height:y}=i.pixelRectObject,S=b/y,w=this.#va/this.#pa,L=w*S,k=this.#va/15,H=15*k/this.#pa,z=12*k/this.#pa,q=_[0]+Math.cos(v)*H,W=_[1]+z,be=_[2]+Math.sin(v)*H;this.camera.setPosition(q,W,be),this.camera.lookAt(_[0],_[1],_[2]);const Ke=this.camera;Ke.left=-L/2,Ke.right=L/2,Ke.top=w/2,Ke.bottom=-w/2}#Ea(i,g){if(!this.checkKeyboardInput(i,this.#Ra))return!1;if(!this.#Sa)return!1;const{keyboardKeyBuffer:x}=i.redGPUContext,_=this.#Ra,v=this.#wa*g;let b=0,y=0,S=0,w=0;x[_.moveUp]&&(b=v),x[_.moveDown]&&(y=v),x[_.moveLeft]&&(S=v),x[_.moveRight]&&(w=v);const L=this.#ma*Ur,k=Math.cos(L),H=Math.sin(L),z=(y-b)*k+(w-S)*k,q=(y-b)*H+(w-S)*-H;return this.#Ta+=z,this.#Ma+=q,!0}}class DrawBufferManager{static#Da;static#Ua=5;#l;#La=[];#Aa=[];#Ga;#ka=0;#Oa=0;#Na;#Va=new Set;constructor(i){this.#l=i,this.#Fa()}static getInstance(i){return DrawBufferManager.#Da||(DrawBufferManager.#Da=new DrawBufferManager(i)),DrawBufferManager.#Da}allocateDrawCommand(i){this.#Oa>=this.#Ga&&(this.#ka=this.#Ha(),this.#Oa=0),this.#Va.add(this.#ka);const g={bufferIndex:this.#ka,commandOffset:this.#Oa*DrawBufferManager.#Ua,buffer:this.#La[this.#ka],dataArray:this.#Aa[this.#ka]};return this.#Oa++,g}setIndexedIndirectCommand(i,g,x=1,_=0,v=0,b=0){const y=i.commandOffset,S=i.dataArray;S[y]=g,S[y+1]=x,S[y+2]=_,S[y+3]=v,S[y+4]=b}setInstanceNum(i,g=0){const x=i.commandOffset;i.dataArray[x+1]=g}setIndirectCommand(i,g,x=1,_=0,v=0){const b=i.commandOffset,y=i.dataArray;y[b]=g,y[b+1]=x,y[b+2]=_,y[b+3]=v}updateSingleCommand(i){const g=this.#La[i.bufferIndex],x=this.#Aa[i.bufferIndex],_=DrawBufferManager.#Ua,v=4*i.commandOffset,b=_;this.#l.gpuDevice.queue.writeBuffer(g,v,x,i.commandOffset,b)}getTotalCommandCount(){let i=0;for(const g of this.#Va)g===this.#ka?i+=this.#Oa:i+=this.#Ga;return i}getMemoryUsage(){const i=this.#La.length,g=this.#Va.size,x=i*this.#Na,_=g*this.#Na;return{totalBuffers:i,usedBuffers:g,maxCommandsPerBuffer:this.#Ga,totalMemory:formatBytes(x),usedMemory:formatBytes(_),totalCommands:this.getTotalCommandCount()}}flushAllCommands(i){performance.now();for(const i of this.#Va){const g=this.#La[i],x=this.#Aa[i],_=(i===this.#ka?this.#Oa:this.#Ga)*DrawBufferManager.#Ua*4;this.#l.gpuDevice.queue.writeBuffer(g,0,x,0,_/4)}performance.now()}#Fa(){this.#za(),this.#$a()}#za(){this.#l.gpuDevice.limits,this.#Na=Math.floor(.9*Math.min(268435456,134217728)),this.#Ga=Math.floor(this.#Na/(4*DrawBufferManager.#Ua))}#$a(){this.#Ha()}#Ha(){const i=this.#Ga*DrawBufferManager.#Ua*4,g=this.#l.gpuDevice.createBuffer({size:i,usage:GPUBufferUsage.INDIRECT|GPUBufferUsage.COPY_DST,label:`DrawBuffer_${this.#La.length}`}),x=new Uint32Array(this.#Ga*DrawBufferManager.#Ua);return this.#La.push(g),this.#Aa.push(x),this.#La.length-1}}create$3(),create$3();const calculateMeshAABB=i=>{if(!i||!i._geometry){const g=i.modelMatrix;return g[12],g[13],g[14],new AABB(0,0,0,0,0,0)}const g=i._geometry.volume,{minX:x,maxX:_,minY:v,maxY:b,minZ:y,maxZ:S}=g;let w=1/0,L=1/0,k=1/0,H=-1/0,z=-1/0,q=-1/0;const W=i.modelMatrix;for(let i=0;i<8;i++){const g=1&i?_:x,be=2&i?b:v,Ke=4&i?S:y,Xe=W[0]*g+W[4]*be+W[8]*Ke+W[12],je=W[1]*g+W[5]*be+W[9]*Ke+W[13],Ye=W[2]*g+W[6]*be+W[10]*Ke+W[14];XeH&&(H=Xe),je>z&&(z=je),Ye>q&&(q=Ye)}return new AABB(w,H,L,z,k,q)},calculateMeshCombinedAABB=i=>{const g=[];return collectRecursive(i,g),0===g.length?new AABB(0,0,0,0,0,0):calculateCombinedAABBFromAABBs(g)},collectRecursive=(i,g)=>{if(i._geometry){const x=i.boundingAABB;g.push(x)}if(i.children)for(let x=0;x{if(0===i.length)return new AABB(0,0,0,0,0,0);if(1===i.length)return i[0];let g=1/0,x=1/0,_=1/0,v=-1/0,b=-1/0,y=-1/0;for(let S=0;Sv&&(v=w.maxX),w.maxY>b&&(b=w.maxY),w.maxZ>y&&(y=w.maxZ)}return new AABB(g,v,x,b,_,y)};class OBB{centerX;centerY;centerZ;halfExtentX;halfExtentY;halfExtentZ;orientation;center;halfExtents;geometryRadius;constructor(i,g,x){this.centerX=i[0],this.centerY=i[1],this.centerZ=i[2],this.halfExtentX=g[0],this.halfExtentY=g[1],this.halfExtentZ=g[2],this.center=[this.centerX,this.centerY,this.centerZ],this.halfExtents=[this.halfExtentX,this.halfExtentY,this.halfExtentZ],this.orientation=clone$4(x),this.geometryRadius=Math.sqrt(this.halfExtentX**2+this.halfExtentY**2+this.halfExtentZ**2)}intersects(i){i instanceof OBB||consoleAndThrowError("allow only OBB instance");const g=subtract$2(create$3(),this.center,i.center);if(length$3(g)>this.geometryRadius+i.geometryRadius)return!1;const x=[...this.#Ka(),...i.#Ka()];for(const _ of x){const x=this.#Xa(_),v=i.#Xa(_);if(Math.abs(dot$3(g,_))>x+v)return!1}return!0}contains(i,g,x){let _;_=Array.isArray(i)?fromValues$3(i[0],i[1],i[2]):fromValues$3(i,g,x);const v=subtract$2(create$3(),_,this.center),b=this.#Ka();for(let i=0;i<3;i++){const g=dot$3(v,b[i]);if(Math.abs(g)>this.halfExtents[i])return!1}return!0}clone(){return new OBB([this.centerX,this.centerY,this.centerZ],[this.halfExtentX,this.halfExtentY,this.halfExtentZ],this.orientation)}#Ka(){return[fromValues$3(this.orientation[0],this.orientation[1],this.orientation[2]),fromValues$3(this.orientation[4],this.orientation[5],this.orientation[6]),fromValues$3(this.orientation[8],this.orientation[9],this.orientation[10])]}#Xa(i){const g=this.#Ka();return Math.abs(dot$3(g[0],i))*this.halfExtentX+Math.abs(dot$3(g[1],i))*this.halfExtentY+Math.abs(dot$3(g[2],i))*this.halfExtentZ}}const calculateMeshOBB=i=>{if(!i||!i._geometry){const i=create$4();return new OBB([0,0,0],[0,0,0],i)}const g=i._geometry.volume;if(0===g.minX&&0===g.maxX&&0===g.minY&&0===g.maxY&&0===g.minZ&&0===g.maxZ){const i=create$4();return new OBB([0,0,0],[0,0,0],i)}const x=[g.centerX,g.centerY,g.centerZ],_=[(g.maxX-g.minX)/2,(g.maxY-g.minY)/2,(g.maxZ-g.minZ)/2],v=create$3();transformMat4$2(v,x,i.modelMatrix);const b=create$4();copy$4(b,i.modelMatrix),b[12]=0,b[13]=0,b[14]=0;const y=[create$3(),create$3(),create$3()],S=[0,0,0];for(let i=0;i<3;i++){const g=[0,0,0];g[i]=_[i],transformMat4$2(y[i],g,b),S[i]=length$3(y[i]),normalize$3(y[i],y[i])}const w=create$4();return w[0]=y[0][0],w[1]=y[0][1],w[2]=y[0][2],w[3]=0,w[4]=y[1][0],w[5]=y[1][1],w[6]=y[1][2],w[7]=0,w[8]=y[2][0],w[9]=y[2][1],w[10]=y[2][2],w[11]=0,w[12]=0,w[13]=0,w[14]=0,w[15]=1,new OBB([v[0],v[1],v[2]],S,w)},mat4ToEuler=(i,g,x)=>{g=g||[0,0,0],x=x||"XYZ";let _=i[0],v=i[4],b=i[8],y=i[1],S=i[5],w=i[9],L=i[2],k=i[6],H=i[10];return"XYZ"===x?(g[1]=Math.asin(clamp(b,-1,1)),Math.abs(b)<.99999?(g[0]=Math.atan2(-w,H),g[2]=Math.atan2(-v,_)):(g[0]=Math.atan2(k,S),g[2]=0)):"YXZ"===x?(g[0]=Math.asin(-clamp(w,-1,1)),Math.abs(w)<.99999?(g[1]=Math.atan2(b,H),g[2]=Math.atan2(y,S)):(g[1]=Math.atan2(-L,_),g[2]=0)):"ZXY"===x?(g[0]=Math.asin(clamp(k,-1,1)),Math.abs(k)<.99999?(g[1]=Math.atan2(-L,H),g[2]=Math.atan2(-v,S)):(g[1]=0,g[2]=Math.atan2(y,_))):"ZYX"===x?(g[1]=Math.asin(-clamp(L,-1,1)),Math.abs(L)<.99999?(g[0]=Math.atan2(k,H),g[2]=Math.atan2(y,_)):(g[0]=0,g[2]=Math.atan2(-v,S))):"YZX"===x?(g[2]=Math.asin(clamp(y,-1,1)),Math.abs(y)<.99999?(g[0]=Math.atan2(-w,S),g[1]=Math.atan2(-L,_)):(g[0]=0,g[1]=Math.atan2(b,H))):"XZY"===x&&(g[2]=Math.asin(-clamp(v,-1,1)),Math.abs(v)<.99999?(g[0]=Math.atan2(k,S),g[1]=Math.atan2(b,_)):(g[0]=Math.atan2(-w,H),g[1]=0)),g};let clamp=function(i,g,x){return Math.max(g,Math.min(x,i))};const Lr={POINT_LIST:"point-list",LINE_LIST:"line-list",LINE_STRIP:"line-strip",TRIANGLE_LIST:"triangle-list",TRIANGLE_STRIP:"triangle-strip"};Object.freeze(Lr);const Ar=parseWGSL("#redgpu_include drawPicking;\n#redgpu_include calcTintBlendMode;\n#redgpu_include FragmentOutput;\n#redgpu_include calculateMotionVector;\nstruct Uniforms { color:vec3, opacity:f32, useTint:u32, tint:vec4, tintBlendMode:u32,\n};\nstruct InputData { @builtin(position) position:vec4, @location(7) currentClipPos:vec4, @location(8) prevClipPos:vec4, @location(11) combinedOpacity:f32, @location(12) motionVector:vec3, @location(15) @interpolate(flat) pickingId:vec4,\n}\n@group(2) @binding(0) var uniforms:Uniforms;\n@fragment\nfn main(inputData:InputData) -> FragmentOutput { var output:FragmentOutput; var finalColor=vec4( uniforms.color.r,uniforms.color.g,uniforms.color.b,uniforms.opacity * inputData.combinedOpacity); #redgpu_if useTint finalColor=calcTintBlendMode(finalColor,uniforms.tintBlendMode,uniforms.tint); #redgpu_endIf if (finalColor.a==0.0) { discard; } output.color=finalColor; output.gBufferMotionVector=vec4(calculateMotionVector(inputData.currentClipPos,inputData.prevClipPos),0.0,1.0 ); return output;\n}\n");class ColorMaterial extends ABaseMaterial{constructor(i,g="#fff"){super(i,"COLOR_MATERIAL",Ar,2),this.initGPURenderInfos(),this.color.setColorByHEX(g)}}dr.defineByPreset(ColorMaterial,[dr.PRESET_COLOR_RGB.COLOR]),Object.freeze(ColorMaterial);class DrawDebuggerMesh{#l;#ja;#hi;#Ya;#qa;#Wa="AABB";#Za;#Ja;#Qa=null;#es=null;constructor(i,g){this.#l=i,this.#ja=g;const x=this.#ts(i);this.#hi=x.vertexBuffer,this.#Ya=new ColorMaterial(i),this.#Ya.color.setColorByRGB(255,0,0),this.#qa=new Mesh(i,x,this.#Ya),this.#qa.primitiveState.cullMode="none",this.#qa.primitiveState.topology=Lr.LINE_LIST;const _=this.#ts(i);this.#Za=new ColorMaterial(i),this.#Za.color.setColorByRGB(0,255,0),this.#Ja=new Mesh(i,_,this.#Za),this.#Ja.primitiveState.cullMode="none",this.#Ja.primitiveState.topology=Lr.LINE_LIST}get debugMode(){return this.#Wa}set debugMode(i){this.#Wa=i,"OBB"===i?this.#Ya.color.setColorByRGB(255,0,0):"AABB"===i||"COMBINED_AABB"===i?this.#Ya.color.setColorByRGB(0,255,0):"BOTH"===i&&(this.#Ya.color.setColorByRGB(255,0,0),this.#Za.color.setColorByRGB(0,255,0)),this.#Qa=null,this.#es=null}render(i){if(!this.#ja.enableDebugger)return;if("OBB"===this.#Wa){const i=this.#ja.boundingOBB;this.#ns(i)&&(this.#rs(i,this.#hi),this.#is(i)),this.#qa.setPosition(0,0,0),this.#qa.setRotation(0,0,0),this.#qa.setScale(1,1,1)}else if("AABB"===this.#Wa||"COMBINED_AABB"===this.#Wa){const i="COMBINED_AABB"===this.#Wa?this.#ja.combinedBoundingAABB:this.#ja.boundingAABB;this.#as(i)&&(this.#ss(i,this.#hi),this.#os(i)),this.#qa.setPosition(0,0,0),this.#qa.setRotation(0,0,0),this.#qa.setScale(1,1,1)}else if("BOTH"===this.#Wa){const i=this.#ja.boundingOBB,g=this.#ja.boundingAABB;this.#ns(i)&&(this.#rs(i,this.#hi),this.#is(i)),this.#qa.setPosition(0,0,0),this.#qa.setRotation(0,0,0),this.#qa.setScale(1,1,1),this.#as(g)&&(this.#ss(g,this.#Ja.geometry.vertexBuffer),this.#os(g)),this.#Ja.setPosition(0,0,0),this.#Ja.setRotation(0,0,0),this.#Ja.setScale(1,1,1)}let g=!0,x=!0;{const{frustumPlanes:_}=i,v=_[0],b=_[1],y=_[2],S=_[3],w=_[4],L=_[5];{const i=this.#ja.boundingAABB,x=i.centerX,_=i.centerY,k=i.centerZ,H=i.geometryRadius;(v[0]*x+v[1]*_+v[2]*k+v[3]<=-H||b[0]*x+b[1]*_+b[2]*k+b[3]<=-H||y[0]*x+y[1]*_+y[2]*k+y[3]<=-H||S[0]*x+S[1]*_+S[2]*k+S[3]<=-H||w[0]*x+w[1]*_+w[2]*k+w[3]<=-H||L[0]*x+L[1]*_+L[2]*k+L[3]<=-H)&&(g=!1)}{const i=this.#ja.boundingOBB,g=i.centerX,_=i.centerY,k=i.centerZ,H=i.geometryRadius;(v[0]*g+v[1]*_+v[2]*k+v[3]<=-H||b[0]*g+b[1]*_+b[2]*k+b[3]<=-H||y[0]*g+y[1]*_+y[2]*k+y[3]<=-H||S[0]*g+S[1]*_+S[2]*k+S[3]<=-H||w[0]*g+w[1]*_+w[2]*k+w[3]<=-H||L[0]*g+L[1]*_+L[2]*k+L[3]<=-H)&&(x=!1)}}"OBB"===this.#Wa?x&&this.#qa.render(i):"AABB"===this.#Wa||"COMBINED_AABB"===this.#Wa?g&&this.#qa.render(i):"BOTH"===this.#Wa&&(x&&this.#qa.render(i),g&&this.#Ja.render(i))}#ts(i){const g=new Float32Array(192),x=new VertexInterleavedStruct({vertexPosition:VertexInterleaveType.float32x3,vertexNormal:VertexInterleaveType.float32x3,texcoord:VertexInterleaveType.float32x2},`wireframeBoxStruct_${Math.random()}`),_=new VertexBuffer(i,g,x);return new Geometry(i,_)}#ns(i){if(!this.#Qa)return!0;const g=this.#Qa;return g.center[0]!==i.center[0]||g.center[1]!==i.center[1]||g.center[2]!==i.center[2]||g.halfExtents[0]!==i.halfExtents[0]||g.halfExtents[1]!==i.halfExtents[1]||g.halfExtents[2]!==i.halfExtents[2]||!this.#us(g.orientation,i.orientation)}#as(i){if(!this.#es)return!0;const g=this.#es;return g.minX!==i.minX||g.maxX!==i.maxX||g.minY!==i.minY||g.maxY!==i.maxY||g.minZ!==i.minZ||g.maxZ!==i.maxZ}#us(i,g){if(i.length!==g.length)return!1;for(let x=0;x1e-4)return!1;return!0}#is(i){this.#Qa=new OBB(i.center,i.halfExtents,i.orientation)}#os(i){this.#es=i.clone()}#rs(i,g){const{center:x,halfExtents:_,orientation:v}=i,b=[[-1,-1,-1],[1,-1,-1],[1,1,-1],[-1,1,-1],[-1,-1,1],[1,-1,1],[1,1,1],[-1,1,1]].map(i=>{const g=[i[0]*_[0],i[1]*_[1],i[2]*_[2]],b=[v[0]*g[0]+v[4]*g[1]+v[8]*g[2],v[1]*g[0]+v[5]*g[1]+v[9]*g[2],v[2]*g[0]+v[6]*g[1]+v[10]*g[2]];return[b[0]+x[0],b[1]+x[1],b[2]+x[2]]});this.#mi(b,g)}#ss(i,g){const{minX:x,maxX:_,minY:v,maxY:b,minZ:y,maxZ:S}=i,w=[[x,v,y],[_,v,y],[_,b,y],[x,b,y],[x,v,S],[_,v,S],[_,b,S],[x,b,S]];this.#mi(w,g)}#mi(i,g){const x=g.data;let _=0;[[0,1],[1,2],[2,3],[3,0],[4,5],[5,6],[6,7],[7,4],[0,4],[1,5],[2,6],[3,7]].forEach(([g,v])=>{x[_++]=i[g][0],x[_++]=i[g][1],x[_++]=i[g][2],x[_++]=0,x[_++]=0,x[_++]=1,x[_++]=0,x[_++]=0,x[_++]=i[v][0],x[_++]=i[v][1],x[_++]=i[v][2],x[_++]=0,x[_++]=0,x[_++]=1,x[_++]=0,x[_++]=0}),g.updateAllData(x)}}Object.freeze(DrawDebuggerMesh);const Gr={MESH:"mesh",PARTICLE:"particle",INSTANCED_MESH:"instancedMesh"};Object.freeze(Gr);const createMeshVertexUniformBuffers=(i,g=!1)=>{const{gpuRenderInfo:x,redGPUContext:_}=i,{resourceManager:v}=_,b=v.getGPUBindGroupLayout(g?ResourceManager.PRESET_VERTEX_GPUBindGroupLayout_SKIN:ResourceManager.PRESET_VERTEX_GPUBindGroupLayout),y=new ArrayBuffer(x.vertexUniformInfo.arrayBufferByteLength),S=new UniformBuffer(_,y,i.name);x.vertexBindGroupLayout=b,x.vertexUniformBuffer=S};const kr=[{textureList:["baseColorTexture"],vec4List:[["baseColorFactor",[1,1,1,1]]]},{textureList:["normalTexture"]},{textureList:["metallicRoughnessTexture"],positiveNumberList:["metallicFactor","roughnessFactor"]},{textureList:["emissiveTexture"],vec3List:["emissiveFactor"]},{textureList:["occlusionTexture"],positiveNumberList:["occlusionStrength"]},{extensionName:"KHR_materials_clearcoat",textureList:["KHR_clearcoatTexture","KHR_clearcoatNormalTexture","KHR_clearcoatRoughnessTexture"],positiveNumberList:[["KHR_clearcoatFactor",0],["KHR_clearcoatRoughnessFactor",0],"KHR_clearcoatNormalScale"]},{extensionName:"KHR_materials_sheen",textureList:["KHR_sheenColorTexture","KHR_sheenRoughnessTexture"],positiveNumberList:[["KHR_sheenRoughnessFactor",0]],vec3List:[["KHR_sheenColorFactor",[0,0,0]]]},{extensionName:"KHR_materials_specular",textureList:["KHR_specularTexture","KHR_specularColorTexture"],positiveNumberList:["KHR_specularFactor"],vec3List:[["KHR_specularColorFactor",[1,1,1]]]},{extensionName:"KHR_materials_transmission",textureList:["KHR_transmissionTexture"],positiveNumberList:[["KHR_transmissionFactor",0]]},{extensionName:"KHR_materials_volume",textureList:["KHR_thicknessTexture"],positiveNumberList:[["KHR_thicknessFactor",0],["KHR_attenuationDistance",1]],vec3List:[["KHR_attenuationColor",[1,1,1]]]},{extensionName:"KHR_materials_diffuse_transmission",textureList:["KHR_diffuseTransmissionTexture","KHR_diffuseTransmissionColorTexture"],positiveNumberList:[["KHR_diffuseTransmissionFactor",0]],vec3List:[["KHR_diffuseTransmissionColorFactor",[1,1,1]]]},{extensionName:"KHR_materials_anisotropy",textureList:["KHR_anisotropyTexture"],positiveNumberList:[["KHR_anisotropyStrength",0],["KHR_anisotropyRotation",0]]},{extensionName:"KHR_materials_iridescence",textureList:["KHR_iridescenceTexture","KHR_iridescenceThicknessTexture"],positiveNumberList:[["KHR_iridescenceFactor",0],["KHR_iridescenceIor",1.3],["KHR_iridescenceThicknessMinimum",100],["KHR_iridescenceThicknessMaximum",400]]}],Or=parseWGSL((i=>{const g=kr.map(i=>{const{textureList:g,positiveNumberList:x}=i,_=g?.map(i=>` use${i.charAt(0).toUpperCase()}${i.substring(1)}:u32, ${i}_texCoord_index:u32, use_${i}_KHR_texture_transform:u32, ${i}_KHR_texture_transform_offset:vec2, ${i}_KHR_texture_transform_scale:vec2, ${i}_KHR_texture_transform_rotation:f32,`).join("");return[_].join("\n")}).join("");return i.replace(/#redgpu_include KHR_texture_transform/g,g)})("#redgpu_include SYSTEM_UNIFORM;\n#redgpu_include calcDirectionalShadowVisibility;\n#redgpu_include calcTintBlendMode;\n#redgpu_include normalFunctions;\n#redgpu_include drawPicking;\n#redgpu_include calcPrePathBackground\n#redgpu_include FragmentOutput\n#redgpu_include calculateMotionVector;\nstruct Uniforms { useVertexColor:u32, useCutOff:u32, cutOff:f32, alphaBlend:u32, doubleSided:u32, useVertexTangent:u32, opacity:f32, useTint:u32, tint:vec4, tintBlendMode:u32, baseColorFactor:vec4, emissiveFactor:vec3, emissiveStrength:f32, occlusionStrength:f32, metallicFactor:f32, roughnessFactor:f32, normalScale:f32, useKHR_materials_unlit:u32, KHR_materials_ior:f32, useKHR_materials_transmission:u32, KHR_transmissionFactor:f32, useKHR_materials_diffuse_transmission:u32, KHR_diffuseTransmissionFactor:f32, KHR_diffuseTransmissionColorFactor:vec3, KHR_dispersion:f32, useKHR_materials_volume:u32, KHR_thicknessFactor:f32, KHR_attenuationDistance:f32, KHR_attenuationColor:vec3, useKHR_materials_specular:u32, KHR_specularFactor:f32, KHR_specularColorFactor:vec3, useKHR_materials_anisotropy:u32, KHR_anisotropyStrength:f32, KHR_anisotropyRotation:f32, useKHR_materials_iridescence:u32, KHR_iridescenceFactor:f32, KHR_iridescenceIor:f32, KHR_iridescenceThicknessMinimum:f32, KHR_iridescenceThicknessMaximum:f32, useKHR_materials_sheen:u32, KHR_sheenColorFactor:vec3, KHR_sheenRoughnessFactor:f32, useKHR_materials_clearcoat:u32, KHR_clearcoatFactor:f32, KHR_clearcoatRoughnessFactor:f32, KHR_clearcoatNormalScale:f32, #redgpu_include KHR_texture_transform\n};\n@group(2) @binding(0) var uniforms:Uniforms;\n@group(2) @binding(1) var baseColorTextureSampler:sampler;\n#redgpu_if baseColorTexture\n@group(2) @binding(2) var baseColorTexture:texture_2d;\n#redgpu_endIf\n#redgpu_if emissiveTexture\n@group(2) @binding(3) var emissiveTextureSampler:sampler;\n@group(2) @binding(4) var emissiveTexture:texture_2d;\n#redgpu_endIf\n#redgpu_if normalTexture\n@group(2) @binding(5) var normalTextureSampler:sampler;\n@group(2) @binding(6) var normalTexture:texture_2d;\n#redgpu_endIf\n#redgpu_if packedORMTexture\n@group(2) @binding(7) var packedORMTexture:texture_2d;\n#redgpu_endIf\n#redgpu_if useKHR_materials_specular\n@group(2) @binding(8) var KHR_specularTextureSampler:sampler;\n@group(2) @binding(9) var KHR_specularTexture:texture_2d;\n@group(2) @binding(10) var KHR_specularColorTextureSampler:sampler;\n@group(2) @binding(11) var KHR_specularColorTexture:texture_2d;\n#redgpu_endIf\n@group(2) @binding(12) var KHR_clearcoatNormalTexture:texture_2d;\n@group(2) @binding(13) var packedKHR_clearcoatTexture_transmission:texture_2d;\n#redgpu_if useKHR_materials_diffuse_transmission\n@group(2) @binding(14) var packedKHR_diffuse_transmission:texture_2d;\n#redgpu_endIf\n#redgpu_if useKHR_materials_sheen\n@group(2) @binding(15) var packedKHR_sheen:texture_2d;\n#redgpu_endIf\n#redgpu_if useKHR_materials_anisotropy\n@group(2) @binding(16) var KHR_anisotropyTexture:texture_2d;\n#redgpu_endIf\n#redgpu_if useKHR_materials_iridescence\n@group(2) @binding(17) var packedKHR_iridescence:texture_2d;\n#redgpu_endIf\nstruct InputData { @builtin(position) position:vec4, @location(0) vertexPosition:vec3, @location(1) vertexNormal:vec3, @location(2) uv:vec2, @location(3) uv1:vec2, @location(4) vertexColor_0:vec4, @location(5) vertexTangent:vec4, @location(7) currentClipPos:vec4, @location(8) prevClipPos:vec4, @location(10) localNodeScale_volumeScale:vec2, @location(11) combinedOpacity:f32, @location(12) motionVector:vec3, @location(13) shadowPos:vec3, @location(14) @interpolate(flat) receiveShadow:f32, @location(15) @interpolate(flat) pickingId:vec4,\n}\n@fragment\nfn main(inputData:InputData) -> FragmentOutput { var output:FragmentOutput; let input_vertexNormal=(inputData.vertexNormal.xyz); let input_vertexPosition=inputData.vertexPosition.xyz; let input_vertexColor_0=inputData.vertexColor_0; let input_vertexTangent=inputData.vertexTangent; let input_ndcPosition=inputData.position.xyz/inputData.position.w; let input_uv=inputData.uv; let input_uv1=inputData.uv1; let u_ambientLight=systemUniforms.ambientLight; let u_ambientLightColor=u_ambientLight.color; let u_ambientLightIntensity=u_ambientLight.intensity; let u_directionalLightCount=systemUniforms.directionalLightCount; let u_directionalLights=systemUniforms.directionalLights; let u_shadowDepthTextureSize=systemUniforms.shadowDepthTextureSize; let u_bias=systemUniforms.bias; let u_usePrefilterTexture=systemUniforms.usePrefilterTexture==1u; let receiveShadowYn=inputData.receiveShadow !=.0; let u_camera=systemUniforms.camera; let u_cameraMatrix=u_camera.cameraMatrix; let u_cameraPosition=u_camera.cameraPosition; let u_opacity=uniforms.opacity; let u_cutOff=uniforms.cutOff; let u_useVertexColor=uniforms.useVertexColor==1u; let u_useVertexTangent=uniforms.useVertexTangent==1u; let u_baseColorFactor=uniforms.baseColorFactor; let u_metallicFactor=uniforms.metallicFactor; let u_roughnessFactor=uniforms.roughnessFactor; let u_normalScale=uniforms.normalScale; let u_occlusionStrength=uniforms.occlusionStrength; let u_emissiveFactor=uniforms.emissiveFactor; let u_emissiveStrength=uniforms.emissiveStrength; let u_useKHR_materials_unlit=uniforms.useKHR_materials_unlit==1u; let u_KHR_materials_ior=uniforms.KHR_materials_ior; let u_KHR_dispersion=uniforms.KHR_dispersion; let u_KHR_transmissionFactor=uniforms.KHR_transmissionFactor; var u_useKHR_materials_volume=uniforms.useKHR_materials_volume==1u; var u_KHR_thicknessFactor=uniforms.KHR_thicknessFactor; var u_KHR_attenuationColor=uniforms.KHR_attenuationColor; var u_KHR_attenuationDistance=uniforms.KHR_attenuationDistance; let u_useKHR_materials_diffuse_transmission=uniforms.useKHR_materials_diffuse_transmission==1u; let u_KHR_diffuseTransmissionFactor=uniforms.KHR_diffuseTransmissionFactor; let u_KHR_diffuseTransmissionColorFactor=uniforms.KHR_diffuseTransmissionColorFactor; let u_KHR_specularFactor=uniforms.KHR_specularFactor; let u_KHR_specularColorFactor=uniforms.KHR_specularColorFactor; let u_KHR_anisotropyStrength=uniforms.KHR_anisotropyStrength; let u_KHR_anisotropyRotation=uniforms.KHR_anisotropyRotation; let u_useKHR_anisotropyTexture=uniforms.useKHR_anisotropyTexture==1u; let u_KHR_sheenColorFactor=uniforms.KHR_sheenColorFactor; let u_KHR_sheenRoughnessFactor=uniforms.KHR_sheenRoughnessFactor; let u_useKHR_materials_iridescence=uniforms.useKHR_materials_iridescence==1u; let u_KHR_iridescenceFactor=uniforms.KHR_iridescenceFactor; let u_KHR_iridescenceIor=uniforms.KHR_iridescenceIor; let u_KHR_iridescenceThicknessMinimum=uniforms.KHR_iridescenceThicknessMinimum; let u_KHR_iridescenceThicknessMaximum=uniforms.KHR_iridescenceThicknessMaximum; let u_KHR_clearcoatFactor=uniforms.KHR_clearcoatFactor; let u_KHR_clearcoatRoughnessFactor=uniforms.KHR_clearcoatRoughnessFactor; let u_KHR_clearcoatNormalScale=uniforms.KHR_clearcoatNormalScale; let diffuseUV=get_transformed_uv( input_uv,input_uv1, uniforms.baseColorTexture_texCoord_index, uniforms.use_baseColorTexture_KHR_texture_transform, uniforms.baseColorTexture_KHR_texture_transform_offset, uniforms.baseColorTexture_KHR_texture_transform_rotation, uniforms.baseColorTexture_KHR_texture_transform_scale ); let emissiveUV=get_transformed_uv( input_uv,input_uv1, uniforms.emissiveTexture_texCoord_index, uniforms.use_emissiveTexture_KHR_texture_transform, uniforms.emissiveTexture_KHR_texture_transform_offset, uniforms.emissiveTexture_KHR_texture_transform_rotation, uniforms.emissiveTexture_KHR_texture_transform_scale ); let occlusionUV=get_transformed_uv( input_uv,input_uv1, uniforms.occlusionTexture_texCoord_index, uniforms.use_occlusionTexture_KHR_texture_transform, uniforms.occlusionTexture_KHR_texture_transform_offset, uniforms.occlusionTexture_KHR_texture_transform_rotation, uniforms.occlusionTexture_KHR_texture_transform_scale ); let metallicRoughnessUV=get_transformed_uv( input_uv,input_uv1, uniforms.metallicRoughnessTexture_texCoord_index, uniforms.use_metallicRoughnessTexture_KHR_texture_transform, uniforms.metallicRoughnessTexture_KHR_texture_transform_offset, uniforms.metallicRoughnessTexture_KHR_texture_transform_rotation, uniforms.metallicRoughnessTexture_KHR_texture_transform_scale ); let normalUV=get_transformed_uv( input_uv,input_uv1, uniforms.normalTexture_texCoord_index, uniforms.use_normalTexture_KHR_texture_transform, uniforms.normalTexture_KHR_texture_transform_offset, uniforms.normalTexture_KHR_texture_transform_rotation, uniforms.normalTexture_KHR_texture_transform_scale ); let KHR_clearcoatUV=get_transformed_uv( input_uv,input_uv1, uniforms.KHR_clearcoatTexture_texCoord_index, uniforms.use_KHR_clearcoatTexture_KHR_texture_transform, uniforms.KHR_clearcoatTexture_KHR_texture_transform_offset, uniforms.KHR_clearcoatTexture_KHR_texture_transform_rotation, uniforms.KHR_clearcoatTexture_KHR_texture_transform_scale ); #redgpu_if useKHR_materials_clearcoat let KHR_clearcoatNormalUV=get_transformed_uv( input_uv,input_uv1, uniforms.KHR_clearcoatNormalTexture_texCoord_index, uniforms.use_KHR_clearcoatNormalTexture_KHR_texture_transform, uniforms.KHR_clearcoatNormalTexture_KHR_texture_transform_offset, uniforms.KHR_clearcoatNormalTexture_KHR_texture_transform_rotation, uniforms.KHR_clearcoatNormalTexture_KHR_texture_transform_scale ); #redgpu_endIf let KHR_clearcoatRoughnessUV=get_transformed_uv( input_uv,input_uv1, uniforms.KHR_clearcoatRoughnessTexture_texCoord_index, uniforms.use_KHR_clearcoatRoughnessTexture_KHR_texture_transform, uniforms.KHR_clearcoatRoughnessTexture_KHR_texture_transform_offset, uniforms.KHR_clearcoatRoughnessTexture_KHR_texture_transform_rotation, uniforms.KHR_clearcoatRoughnessTexture_KHR_texture_transform_scale ); let KHR_sheenColorUV=get_transformed_uv( input_uv,input_uv1, uniforms.KHR_sheenColorTexture_texCoord_index, uniforms.use_KHR_sheenColorTexture_KHR_texture_transform, uniforms.KHR_sheenColorTexture_KHR_texture_transform_offset, uniforms.KHR_sheenColorTexture_KHR_texture_transform_rotation, uniforms.KHR_sheenColorTexture_KHR_texture_transform_scale ); let KHR_sheenRoughnessUV=get_transformed_uv( input_uv,input_uv1, uniforms.KHR_sheenRoughnessTexture_texCoord_index, uniforms.use_KHR_sheenRoughnessTexture_KHR_texture_transform, uniforms.KHR_sheenRoughnessTexture_KHR_texture_transform_offset, uniforms.KHR_sheenRoughnessTexture_KHR_texture_transform_rotation, uniforms.KHR_sheenRoughnessTexture_KHR_texture_transform_scale ); let KHR_specularTextureUV=get_transformed_uv( input_uv,input_uv1, uniforms.KHR_specularTexture_texCoord_index, uniforms.use_KHR_specularTexture_KHR_texture_transform, uniforms.KHR_specularTexture_KHR_texture_transform_offset, uniforms.KHR_specularTexture_KHR_texture_transform_rotation, uniforms.KHR_specularTexture_KHR_texture_transform_scale ); let KHR_specularColorTextureUV=get_transformed_uv( input_uv,input_uv1, uniforms.KHR_specularColorTexture_texCoord_index, uniforms.use_KHR_specularColorTexture_KHR_texture_transform, uniforms.KHR_specularColorTexture_KHR_texture_transform_offset, uniforms.KHR_specularColorTexture_KHR_texture_transform_rotation, uniforms.KHR_specularColorTexture_KHR_texture_transform_scale ); let KHR_iridescenceTextureUV=get_transformed_uv( input_uv,input_uv1, uniforms.KHR_iridescenceTexture_texCoord_index, uniforms.use_KHR_iridescenceTexture_KHR_texture_transform, uniforms.KHR_iridescenceTexture_KHR_texture_transform_offset, uniforms.KHR_iridescenceTexture_KHR_texture_transform_rotation, uniforms.KHR_iridescenceTexture_KHR_texture_transform_scale ); let KHR_iridescenceThicknessTextureUV=get_transformed_uv( input_uv,input_uv1, uniforms.KHR_iridescenceThicknessTexture_texCoord_index, uniforms.use_KHR_iridescenceThicknessTexture_KHR_texture_transform, uniforms.KHR_iridescenceThicknessTexture_KHR_texture_transform_offset, uniforms.KHR_iridescenceThicknessTexture_KHR_texture_transform_rotation, uniforms.KHR_iridescenceThicknessTexture_KHR_texture_transform_scale ); let KHR_transmissionUV=get_transformed_uv( input_uv,input_uv1, uniforms.KHR_transmissionTexture_texCoord_index, uniforms.use_KHR_transmissionTexture_KHR_texture_transform, uniforms.KHR_transmissionTexture_KHR_texture_transform_offset, uniforms.KHR_transmissionTexture_KHR_texture_transform_rotation, uniforms.KHR_transmissionTexture_KHR_texture_transform_scale ); let KHR_diffuseTransmissionUV=get_transformed_uv( input_uv,input_uv1, uniforms.KHR_diffuseTransmissionTexture_texCoord_index, uniforms.use_KHR_diffuseTransmissionTexture_KHR_texture_transform, uniforms.KHR_diffuseTransmissionTexture_KHR_texture_transform_offset, uniforms.KHR_diffuseTransmissionTexture_KHR_texture_transform_rotation, uniforms.KHR_diffuseTransmissionTexture_KHR_texture_transform_scale ); let KHR_diffuseTransmissionColorUV=get_transformed_uv( input_uv,input_uv1, uniforms.KHR_diffuseTransmissionColorTexture_texCoord_index, uniforms.use_KHR_diffuseTransmissionColorTexture_KHR_texture_transform, uniforms.KHR_diffuseTransmissionColorTexture_KHR_texture_transform_offset, uniforms.KHR_diffuseTransmissionColorTexture_KHR_texture_transform_rotation, uniforms.KHR_diffuseTransmissionColorTexture_KHR_texture_transform_scale ); let KHR_anisotropyUV=get_transformed_uv( input_uv,input_uv1, uniforms.KHR_anisotropyTexture_texCoord_index, uniforms.use_KHR_anisotropyTexture_KHR_texture_transform, uniforms.KHR_anisotropyTexture_KHR_texture_transform_offset, uniforms.KHR_anisotropyTexture_KHR_texture_transform_rotation, uniforms.KHR_anisotropyTexture_KHR_texture_transform_scale ); var N:vec3=normalize(input_vertexNormal.xyz); var backFaceYn:bool=false; #redgpu_if doubleSided { var fdx:vec3=dpdx(input_vertexPosition); var fdy:vec3=dpdy(input_vertexPosition); var faceNormal:vec3=normalize(cross(fdy,fdx)); if (dot(N,faceNormal) < 0.0) { N=-N; backFaceYn=true; }; } #redgpu_endIf #redgpu_if normalTexture { var targetUv=select(normalUV,1.0 - normalUV,backFaceYn); let normalSamplerColor=textureSample(normalTexture,normalTextureSampler,normalUV).rgb; N=perturb_normal( N, input_vertexPosition, targetUv, vec3(normalSamplerColor.r,1.0 - normalSamplerColor.g,normalSamplerColor.b), u_normalScale ); N=select(N,select(N,-N,backFaceYn),u_useVertexTangent); } #redgpu_else { N=N * u_normalScale; } #redgpu_endIf let V:vec3=normalize(u_cameraPosition - input_vertexPosition); let NdotV=max(dot(N,V),0.04); let VdotN=max(dot(V,N),0.0); var visibility:f32=1.0; visibility=calcDirectionalShadowVisibility( directionalShadowMap, directionalShadowMapSampler, u_shadowDepthTextureSize, u_bias, inputData.shadowPos ); if(!receiveShadowYn){ visibility=1.0; } var finalColor:vec4; var ior:f32=u_KHR_materials_ior; var baseColor=u_baseColorFactor; var resultAlpha:f32=u_opacity * baseColor.a; baseColor *=select(vec4(1.0),input_vertexColor_0,u_useVertexColor); #redgpu_if baseColorTexture let diffuseSampleColor=(textureSample(baseColorTexture,baseColorTextureSampler,diffuseUV)); baseColor *=diffuseSampleColor; resultAlpha *=diffuseSampleColor.a; #redgpu_endIf let albedo:vec3=baseColor.rgb; #redgpu_if useKHR_materials_unlit if(u_useKHR_materials_unlit){ output.color=baseColor; return output; } #redgpu_endIf var occlusionParameter:f32=1; #redgpu_if useOcclusionTexture occlusionParameter=textureSample(packedORMTexture,packedTextureSampler,occlusionUV).r * u_occlusionStrength; #redgpu_endIf var metallicParameter:f32=u_metallicFactor; var roughnessParameter:f32=u_roughnessFactor; #redgpu_if useMetallicRoughnessTexture let metallicRoughnessSample=(textureSample(packedORMTexture,packedTextureSampler,metallicRoughnessUV)); metallicParameter=metallicRoughnessSample.b * metallicParameter; roughnessParameter=metallicRoughnessSample.g * roughnessParameter; #redgpu_endIf roughnessParameter=max(roughnessParameter,0.045); if (abs(ior - 1.0) < 0.0001) { roughnessParameter=0;} var clearcoatParameter=u_KHR_clearcoatFactor; var clearcoatRoughnessParameter=u_KHR_clearcoatRoughnessFactor; var clearcoatNormal:vec3=N; #redgpu_if useKHR_materials_clearcoat { if(clearcoatParameter !=0.0){ #redgpu_if useKHR_clearcoatTexture let clearcoatSample=textureSample(packedKHR_clearcoatTexture_transmission,packedTextureSampler,KHR_clearcoatUV); clearcoatParameter *=clearcoatSample.r; #redgpu_endIf #redgpu_if useKHR_clearcoatRoughnessTexture let clearcoatRoughnesstSample=textureSample(packedKHR_clearcoatTexture_transmission,packedTextureSampler,KHR_clearcoatRoughnessUV); clearcoatRoughnessParameter *=clearcoatRoughnesstSample.g; #redgpu_endIf var clearcoatNormalSampler=textureSample(KHR_clearcoatNormalTexture,baseColorTextureSampler,KHR_clearcoatNormalUV); #redgpu_if useKHR_clearcoatNormalTexture { var targetUv=KHR_clearcoatNormalUV; if(backFaceYn){ targetUv=1.0 - targetUv; } clearcoatNormal=clearcoatNormalSampler.rgb; clearcoatNormal=perturb_normal( N, input_vertexPosition, targetUv, clearcoatNormal, u_normalScale ); if(u_useVertexTangent){ if(backFaceYn ){ clearcoatNormal=-clearcoatNormal;} } clearcoatNormal=normalize(clearcoatNormal); } #redgpu_endIf } } #redgpu_endIf var specularParameter=u_KHR_specularFactor; var specularColor=u_KHR_specularColorFactor; #redgpu_if useKHR_materials_specular #redgpu_if KHR_specularColorTexture let specularColorTextureSample=textureSample( KHR_specularColorTexture, KHR_specularColorTextureSampler, KHR_specularColorTextureUV ); specularColor *=specularColorTextureSample.rgb; #redgpu_endIf #redgpu_if KHR_specularTexture let specularTextureSample=textureSample( KHR_specularTexture, KHR_specularTextureSampler, KHR_specularTextureUV ); specularParameter *=specularTextureSample.a; #redgpu_endIf #redgpu_endIf var transmissionParameter:f32=u_KHR_transmissionFactor; var thicknessParameter:f32=u_KHR_thicknessFactor; #redgpu_if useKHR_materials_transmission #redgpu_if useKHR_transmissionTexture let transmissionSample:vec4=textureSample( packedKHR_clearcoatTexture_transmission, packedTextureSampler, KHR_transmissionUV ); transmissionParameter *=transmissionSample.b; #redgpu_endIf #redgpu_if useKHR_thicknessTexture let thicknessSample:vec4=textureSample( packedKHR_clearcoatTexture_transmission, packedTextureSampler, KHR_transmissionUV ); thicknessParameter *=thicknessSample.a; #redgpu_endIf #redgpu_endIf var diffuseTransmissionColor:vec3=u_KHR_diffuseTransmissionColorFactor; var diffuseTransmissionParameter:f32=u_KHR_diffuseTransmissionFactor; #redgpu_if useKHR_materials_diffuse_transmission #redgpu_if useKHR_diffuseTransmissionTexture let diffuseTransmissionTextureSample=textureSample( packedKHR_diffuse_transmission, packedTextureSampler, KHR_diffuseTransmissionUV ); diffuseTransmissionParameter *=diffuseTransmissionTextureSample.a; #redgpu_endIf #redgpu_if useKHR_diffuseTransmissionColorTexture let diffuseTransmissionColorTextureSample=textureSample( packedKHR_diffuse_transmission, packedTextureSampler, KHR_diffuseTransmissionColorUV ); diffuseTransmissionColor *=diffuseTransmissionColorTextureSample.rgb; #redgpu_endIf #redgpu_endIf var sheenColor=u_KHR_sheenColorFactor; var sheenRoughnessParameter=u_KHR_sheenRoughnessFactor; #redgpu_if useKHR_materials_sheen #redgpu_if useKHR_sheenColorTexture let sheenColorSample=(textureSample(packedKHR_sheen,packedTextureSampler,KHR_sheenColorUV)); sheenColor *=sheenColorSample.rgb; #redgpu_endIf #redgpu_if useKHR_sheenRoughnessTexture let sheenRoughnessSample=(textureSample(packedKHR_sheen,packedTextureSampler,KHR_sheenRoughnessUV)); sheenRoughnessParameter *=sheenRoughnessSample.a; #redgpu_endIf #redgpu_endIf var iridescenceParameter=u_KHR_iridescenceFactor; var iridescenceThickness=u_KHR_iridescenceThicknessMaximum; #redgpu_if useKHR_materials_iridescence #redgpu_if useKHR_iridescenceTexture let iridescenceTextureSample:vec4=textureSample( packedKHR_iridescence, packedTextureSampler, KHR_iridescenceTextureUV ); iridescenceParameter *=iridescenceTextureSample.r; #redgpu_endIf #redgpu_if useKHR_iridescenceThicknessTexture let iridescenceThicknessTextureSample:vec4=textureSample( packedKHR_iridescence, packedTextureSampler, KHR_iridescenceThicknessTextureUV ); iridescenceThickness=mix(u_KHR_iridescenceThicknessMinimum,u_KHR_iridescenceThicknessMaximum,iridescenceThicknessTextureSample.g); #redgpu_endIf #redgpu_endIf var anisotropy:f32=u_KHR_anisotropyStrength; var anisotropicT:vec3=vec3(1.0); var anisotropicB:vec3=vec3(1.0); #redgpu_if useKHR_materials_anisotropy { var T:vec3; var B:vec3; if (u_useVertexTangent && length(input_vertexTangent.xyz) > 0.0) { T=normalize(input_vertexTangent.xyz); B=normalize(cross(N,T) * input_vertexTangent.w); } else { T=normalize(select(vec3(1.0,0.0,0.0),vec3(0.0,1.0,0.0),abs(N.x) > 0.9)); T=normalize(T - N * dot(T,N)); B=normalize(cross(N,T)); } var anisotropicDirection:vec2=vec2(1.0,0.0); if(u_useKHR_anisotropyTexture){ let anisotropyTex=textureSample(KHR_anisotropyTexture,baseColorTextureSampler,KHR_anisotropyUV).rgb; anisotropicDirection=anisotropyTex.rg * 2.0 - vec2(1.0,1.0); anisotropy *=anisotropyTex.b; } var cosR=cos(u_KHR_anisotropyRotation); var sinR=sin(u_KHR_anisotropyRotation); let rotationMtx:mat2x2=mat2x2( cosR,sinR, -sinR,cosR ); anisotropicDirection=rotationMtx * anisotropicDirection; anisotropicT=normalize(T * anisotropicDirection.x + B * anisotropicDirection.y); anisotropicB=normalize(cross(N,anisotropicT)); } #redgpu_endIf var prePathBackground=vec3(0.0); #redgpu_if useKHR_materials_transmission prePathBackground=calcPrePathBackground( u_useKHR_materials_volume,thicknessParameter * inputData.localNodeScale_volumeScale[1],u_KHR_dispersion,u_KHR_attenuationDistance,u_KHR_attenuationColor, ior,roughnessParameter,albedo, systemUniforms.projectionCameraMatrix,input_vertexPosition,input_ndcPosition, V,N, renderPath1ResultTexture,renderPath1ResultTextureSampler ); #redgpu_endIf let F0_dielectric_base=vec3(pow((1.0 - ior)/(1.0 + ior),2.0)); var F0_dielectric=F0_dielectric_base * specularColor; var F0_metal=baseColor.rgb; #redgpu_if useKHR_materials_iridescence if (iridescenceParameter > 0.0) { F0_dielectric=iridescent_fresnel(1.0,u_KHR_iridescenceIor,F0_dielectric,iridescenceThickness,iridescenceParameter,NdotV); F0_metal=iridescent_fresnel(1.0,u_KHR_iridescenceIor,baseColor.rgb,iridescenceThickness,iridescenceParameter,NdotV); } #redgpu_endIf let F0=mix(F0_dielectric,F0_metal,metallicParameter); var totalDirectLighting=vec3(0.0); for (var i=0u;i < u_directionalLightCount;i++) { totalDirectLighting +=calcLight( u_directionalLights[i].color,u_directionalLights[i].intensity * visibility, N,V,-normalize(u_directionalLights[i].direction), VdotN, roughnessParameter,metallicParameter,albedo, F0,ior, prePathBackground, specularColor,specularParameter, u_useKHR_materials_diffuse_transmission,diffuseTransmissionParameter,diffuseTransmissionColor, transmissionParameter, sheenColor,sheenRoughnessParameter, anisotropy,anisotropicT,anisotropicB, clearcoatParameter,clearcoatRoughnessParameter,clearcoatNormal ); } { let clusterIndex=getClusterLightClusterIndex(inputData.position); let lightOffset=clusterLightGroup.lights[clusterIndex].offset; let lightCount:u32=clusterLightGroup.lights[clusterIndex].count; for (var lightIndex=0u;lightIndex < lightCount;lightIndex=lightIndex + 1u) { let i=clusterLightGroup.indices[lightOffset + lightIndex]; let targetLight=clusterLightList.lights[i]; let u_clusterLightPosition=targetLight.position; let u_clusterLightRadius=targetLight.radius; let u_isSpotLight=targetLight.isSpotLight; let lightDistance=length(u_clusterLightPosition - input_vertexPosition); if (lightDistance > u_clusterLightRadius) { continue; } let lightDir=normalize(u_clusterLightPosition - input_vertexPosition);\nlet Lvec=u_clusterLightPosition - input_vertexPosition;\nlet dist2=max(dot(Lvec,Lvec),0.0001);\nlet d=sqrt(dist2);\nlet rangePart=pow(clamp(1.0 - d/u_clusterLightRadius,0.0,1.0),2.0);\nlet invSquare=(u_clusterLightRadius * u_clusterLightRadius)/dist2;\nlet attenuation=rangePart * invSquare; var finalAttenuation=attenuation; if (u_isSpotLight > 0.0) { let u_clusterLightDirection=normalize(vec3( targetLight.directionX, targetLight.directionY, targetLight.directionZ )); let u_clusterLightInnerAngle=targetLight.innerCutoff; let u_clusterLightOuterCutoff=targetLight.outerCutoff; let lightToVertex=normalize(-lightDir); let cosTheta=dot(lightToVertex,u_clusterLightDirection); let cosOuter=cos(radians(u_clusterLightOuterCutoff)); let cosInner=cos(radians(u_clusterLightInnerAngle)); if (cosTheta < cosOuter) { continue; } let epsilon=cosInner - cosOuter; let spotIntensity=clamp((cosTheta - cosOuter)/epsilon,0.0,1.0); finalAttenuation *=spotIntensity; } totalDirectLighting +=calcLight( targetLight.color,targetLight.intensity * finalAttenuation, N,V,lightDir, VdotN, roughnessParameter,metallicParameter,albedo, F0,ior, prePathBackground, specularColor,specularParameter, u_useKHR_materials_diffuse_transmission,diffuseTransmissionParameter,diffuseTransmissionColor, transmissionParameter, sheenColor,sheenRoughnessParameter, anisotropy,anisotropicT,anisotropicB, clearcoatParameter,clearcoatRoughnessParameter,clearcoatNormal ); } } if (u_usePrefilterTexture) { var R=(reflect(-V,N)); let NdotV=max(dot(N,V),1e-4); #redgpu_if useKHR_materials_anisotropy { var bentNormal=cross(anisotropicB,V); bentNormal=normalize(cross(bentNormal,anisotropicB)); let temp=1.0 - anisotropy * (1.0 - roughnessParameter); let tempSquared=temp * temp; var a=tempSquared * tempSquared; bentNormal=normalize(mix(bentNormal,N,a)); var reflectVec=reflect(-V,bentNormal); reflectVec=normalize(mix(reflectVec,bentNormal,roughnessParameter * roughnessParameter)); let roughnessT=roughnessParameter * (1.0 + anisotropy); let roughnessB=roughnessParameter * (1.0 - anisotropy); let TdotR=dot(anisotropicT,reflectVec); let BdotR=dot(anisotropicB,reflectVec); let TdotV=dot(anisotropicT,V); let BdotV=dot(anisotropicB,V); R=normalize(reflectVec - anisotropy * (TdotR * anisotropicT - BdotR * anisotropicB)); let VdotN=max(1e-4,dot(V,N)); let oneMinusVdotN=1.0 - VdotN; let directionFactor=oneMinusVdotN * oneMinusVdotN * oneMinusVdotN; let VdotT_abs=abs(TdotV); let VdotB_abs=abs(BdotV); let totalWeight=max(1e-4,VdotT_abs + VdotB_abs); let weightedRoughness=(roughnessT * VdotT_abs + roughnessB * VdotB_abs)/totalWeight; roughnessParameter=weightedRoughness; } #redgpu_endIf let iblMipmapCount:f32=f32(textureNumLevels(ibl_environmentTexture) - 1); var mipLevel=roughnessParameter * iblMipmapCount; var reflectedColor=textureSampleLevel( ibl_environmentTexture,prefilterTextureSampler,R,mipLevel ).rgb; let envBRDF=textureSampleLevel(ibl_brdfLUTTexture,prefilterTextureSampler,vec2(NdotV,roughnessParameter),0.0).rg; var F_IBL_dielectric=F0_dielectric * envBRDF.x + envBRDF.y; var F_IBL_metal=F0_metal * envBRDF.x + envBRDF.y; var F_IBL=F0 * envBRDF.x + envBRDF.y; let a2=roughnessParameter * roughnessParameter; let G_smith=NdotV/(NdotV * (1.0 - a2) + a2); let effectiveTransmission=transmissionParameter * (1.0 - metallicParameter); let iblDiffuseColor=textureSampleLevel(ibl_irradianceTexture,prefilterTextureSampler,N,0).rgb; var envIBL_DIFFUSE:vec3=albedo * iblDiffuseColor* (vec3(1.0) - F_IBL_dielectric); #redgpu_if useKHR_materials_diffuse_transmission { var backScatteringColor=textureSampleLevel(ibl_environmentTexture,prefilterTextureSampler,-N,mipLevel).rgb; let transmittedIBL=backScatteringColor * diffuseTransmissionColor * (vec3(1.0) - F_IBL_dielectric); envIBL_DIFFUSE=mix(envIBL_DIFFUSE,transmittedIBL,diffuseTransmissionParameter); } #redgpu_endIf var envIBL_SPECULAR:vec3; envIBL_SPECULAR=reflectedColor * F_IBL * specularParameter; var envIBL_SPECULAR_BTDF=vec3(0.0); #redgpu_if useKHR_materials_transmission var refractedDir:vec3; let eta=1.0/ior; if (abs(ior - 1.0) < 0.0001) { refractedDir=V;} else { refractedDir=refract(-V,-N,eta);} if(length(refractedDir) > 0.0001) { let NdotT=abs(dot(N,normalize(refractedDir))); let F_transmission=vec3(1.0) - mix(F_IBL_dielectric,F_IBL_metal,metallicParameter); var attenuatedBackground=prePathBackground; if (u_useKHR_materials_volume) { let localNodeScale=inputData.localNodeScale_volumeScale[0]; let volumeScale=inputData.localNodeScale_volumeScale[1]; let scaledThickness=thicknessParameter * localNodeScale; let safeAttenuationColor=clamp(u_KHR_attenuationColor,vec3(0.0001),vec3(1.0)); let safeAttenuationDistance=max(u_KHR_attenuationDistance,0.0001); let attenuationCoefficient=-log(safeAttenuationColor)/safeAttenuationDistance; let cosTheta=max(NdotT,0.001); let pathLength=scaledThickness/cosTheta; let transmittance=exp(-attenuationCoefficient * pathLength); attenuatedBackground *=transmittance; }else{ attenuatedBackground *=albedo; } envIBL_SPECULAR_BTDF=attenuatedBackground * F_transmission * transmissionParameter + reflectedColor * G_smith * mix(F_IBL_dielectric,F_IBL_metal,metallicParameter) * NdotT; } #redgpu_endIf let envIBL_DIELECTRIC=mix(envIBL_DIFFUSE,envIBL_SPECULAR_BTDF,transmissionParameter) + envIBL_SPECULAR; var envIBL_SHEEN=vec3(0.0); var sheen_albedo_scaling:f32=1.0; let maxSheenColor=max(sheenColor.x,max(sheenColor.y,sheenColor.z)); #redgpu_if useKHR_materials_sheen let sheenResult=calcIBLSheen( N, V, sheenColor, maxSheenColor, sheenRoughnessParameter, iblMipmapCount ); envIBL_SHEEN=sheenResult.envIBL_SHEEN; sheen_albedo_scaling=sheenResult.sheen_albedo_scaling; #redgpu_endIf let envIBL_METAL=reflectedColor * F_IBL_metal; let metallicPart=envIBL_METAL * metallicParameter; let dielectricPart=envIBL_DIELECTRIC * (1.0 - metallicParameter); var indirectLighting=(metallicPart + dielectricPart) * sheen_albedo_scaling + envIBL_SHEEN; #redgpu_if useKHR_materials_clearcoat if (clearcoatParameter > 0.0) { let clearcoatR=reflect(-V,clearcoatNormal); let clearcoatNdotV=max(dot(clearcoatNormal,V),0.04); let clearcoatMipLevel=clearcoatRoughnessParameter * iblMipmapCount; let clearcoatPrefilteredColor=textureSampleLevel(ibl_environmentTexture,prefilterTextureSampler,clearcoatR,clearcoatMipLevel).rgb; let clearcoatEnvBRDF=textureSampleLevel(ibl_brdfLUTTexture,prefilterTextureSampler,vec2(clearcoatNdotV,clearcoatRoughnessParameter),0.0).rg; let clearcoatF0=vec3(0.04); let clearcoatF=clearcoatF0 * clearcoatEnvBRDF.x + clearcoatEnvBRDF.y; let clearcoatSpecularIBL=clearcoatPrefilteredColor * clearcoatF * clearcoatParameter; indirectLighting=clearcoatSpecularIBL + (1.0 - max(clearcoatF.x,max(clearcoatF.y,clearcoatF.z)) * clearcoatParameter) * indirectLighting; } #redgpu_endIf let environmentIntensity=1.0; let surfaceColor=totalDirectLighting + indirectLighting * environmentIntensity * occlusionParameter; finalColor=vec4(surfaceColor,resultAlpha); } else { let ambientContribution=albedo * u_ambientLightColor * u_ambientLightIntensity * occlusionParameter; finalColor=vec4(totalDirectLighting + ambientContribution,resultAlpha); } var emissiveSamplerColor=vec3(1.0); #redgpu_if emissiveTexture emissiveSamplerColor=textureSample(emissiveTexture,emissiveTextureSampler,emissiveUV).rgb; #redgpu_endIf finalColor +=vec4( emissiveSamplerColor.rgb * u_emissiveFactor * u_emissiveStrength,0); #redgpu_if useCutOff if (resultAlpha <=u_cutOff) { discard;} #redgpu_endIf output.color=finalColor; { let smoothness=1.0 - roughnessParameter; let smoothnessCurved=smoothness * smoothness * (3.0 - 2.0 * smoothness); let metallicWeight=metallicParameter * metallicParameter; let baseReflection=0.04 + 0.96 * metallicWeight; let baseReflectionStrength=smoothnessCurved * baseReflection; output.gBufferNormal=vec4(N * 0.5 + 0.5,baseReflectionStrength); } output.gBufferMotionVector=vec4(calculateMotionVector(inputData.currentClipPos,inputData.prevClipPos),0.0,1.0 ); return output;\n};\nstruct SheenResult { envIBL_SHEEN:vec3, sheen_albedo_scaling:f32\n}\nfn calcIBLSheen( N:vec3, V:vec3, sheenColor:vec3, maxSheenColor:f32, sheenRoughness:f32, iblMipmapCount:f32,\n) -> SheenResult { let NdotV=clamp(dot(N,V),0.0001,1.0); let R=reflect(-V,N); let mipLevel=sheenRoughness * iblMipmapCount; let sheenRadiance=textureSampleLevel( ibl_irradianceTexture,prefilterTextureSampler,R,mipLevel ).rgb; let sheenDFG=charlieSheenDFG(NdotV,sheenRoughness); let envIBL_SHEEN=sheenRadiance * sheenColor * sheenDFG; let E=charlieSheenE(NdotV,sheenRoughness); let sheen_albedo_scaling=1.0 - maxSheenColor * E; return SheenResult(envIBL_SHEEN,sheen_albedo_scaling);\n}\nfn charlieSheenDFG(NdotV:f32,roughness:f32) -> f32 { if (roughness < 0.01) { return 0.0; } let r=clamp(roughness,0.01,1.0); let grazingFactor=1.0 - NdotV; let roughnessExp=1.0/max(r,0.1); let distribution=pow(grazingFactor,roughnessExp); let intensity=pow(roughnessExp,0.5); return distribution * intensity * 0.5;\n}\nfn charlieSheenE(NdotV:f32,roughness:f32) -> f32 { if (roughness < 0.01) { return 0.0; } let r=clamp(roughness,0.01,1.0); let grazingFactor=1.0 - NdotV; let roughnessExp=1.0/max(r,0.1); return pow(grazingFactor,roughnessExp) * pow(r,0.5);\n}\nfn calcLight( lightColor:vec3,lightIntensity:f32, N:vec3,V:vec3,L:vec3, VdotN:f32, roughnessParameter:f32,metallicParameter:f32,albedo:vec3, F0:vec3,ior:f32, prePathBackground:vec3, specularColor:vec3,specularParameter:f32, u_useKHR_materials_diffuse_transmission:bool,diffuseTransmissionParameter:f32,diffuseTransmissionColor:vec3, transmissionParameter:f32, sheenColor:vec3,sheenRoughnessParameter:f32, anisotropy:f32,anisotropicT:vec3,anisotropicB:vec3, clearcoatParameter:f32,clearcoatRoughnessParameter:f32,clearcoatNormal:vec3\n) -> vec3{ let dLight=lightColor * lightIntensity; let NdotL=max(dot(N,L),0.04); let NdotV=max(dot(N,V),0.04); let H=normalize(L + V); let LdotH=max(dot(L,H),0.0); let NdotH=max(dot(N,H),0.0); let VdotH=max(dot(V,H),0.0); var DIFFUSE_BRDF:vec3=diffuse_brdf_disney(NdotL,NdotV,LdotH,roughnessParameter,albedo); #redgpu_if useKHR_materials_diffuse_transmission DIFFUSE_BRDF=mix(DIFFUSE_BRDF,diffuse_btdf(N,L,diffuseTransmissionColor),diffuseTransmissionParameter); #redgpu_endIf var SPECULAR_BRDF:vec3; if (anisotropy > 0.0) { #redgpu_if useKHR_materials_anisotropy var TdotL=dot(anisotropicT,L); var TdotV=dot(anisotropicT,V); var BdotL=dot(anisotropicB,L); var TdotH=dot(anisotropicT,H); var BdotH=dot(anisotropicB,H); var BdotV=dot(anisotropicB,V); SPECULAR_BRDF=BRDF_specularAnisotropicGGX( albedo, vec3(1.0), roughnessParameter * roughnessParameter, VdotH,NdotL,NdotV,NdotH,BdotV,TdotV,TdotL,BdotL,TdotH,BdotH, anisotropy ); #redgpu_endIf }else{ SPECULAR_BRDF=specular_brdf( albedo,roughnessParameter,NdotH,NdotV,NdotL,LdotH); } let METAL_BRDF=conductor_fresnel( albedo,SPECULAR_BRDF,VdotH);; var SPECULAR_BTDF=vec3(0.0); #redgpu_if useKHR_materials_transmission if(transmissionParameter > 0.0){ SPECULAR_BTDF=specular_btdf( NdotV,NdotL,NdotH,VdotH,LdotH,roughnessParameter,albedo,ior); } #redgpu_endIf let DIELECTRIC_BRDF=fresnel_mix( F0, specularParameter, mix(DIFFUSE_BRDF,SPECULAR_BTDF,transmissionParameter), SPECULAR_BRDF, VdotH ); var SHEEN_BRDF:vec3=vec3(0.0); var sheen_albedo_scaling:f32=1.0; #redgpu_if useKHR_materials_sheen let maxSheenColor=max(sheenColor.x,max(sheenColor.y,sheenColor.z)); if(sheenRoughnessParameter > 0.0 && maxSheenColor > 0.001 && dot(N,V) > 0) { let NdotV=dot(N,V); let sheenRoughnessAlpha=sheenRoughnessParameter * sheenRoughnessParameter; let invR=1/sheenRoughnessAlpha; let cos2h=NdotH * NdotH; let sin2h=1 - cos2h; let sheenDistribution=(2 + invR) * pow(sin2h,invR * 0.5)/(2 * pi); let sheen_visibility=1.0/((1.0 + lambda_sheen(NdotV,sheenRoughnessAlpha) + lambda_sheen(NdotL,sheenRoughnessAlpha)) * (4.0 * NdotV * NdotL)); let LdotN=max(dot(L,N),0.04); let E_LdotN=1.0 - pow(1.0 - LdotN,5.0); let E_VdotN=1.0 - pow(1.0 - VdotN,5.0); sheen_albedo_scaling=max(min(1.0 - maxSheenColor * E_VdotN,1.0 - maxSheenColor * E_LdotN),0.04); SHEEN_BRDF=sheenColor * sheenDistribution * sheen_visibility; } #redgpu_endIf let metallicPart=METAL_BRDF * metallicParameter * sheen_albedo_scaling; let dielectricPart=DIELECTRIC_BRDF * sheen_albedo_scaling; let sheenPart=SHEEN_BRDF; var directLighting=(metallicPart + dielectricPart + sheenPart); #redgpu_if useKHR_materials_transmission if(transmissionParameter > 0.0) { let transmissionWeight=transmissionParameter * (vec3(1.0) - F0); directLighting=mix(directLighting,prePathBackground,transmissionWeight); } #redgpu_endIf #redgpu_if useKHR_materials_clearcoat if(clearcoatParameter > 0.0){ let clearcoatNdotL=max(dot(clearcoatNormal,L),0.04); let clearcoatNdotV=max(dot(clearcoatNormal,V),0.04); let clearcoatNdotH=max(dot(clearcoatNormal,H),0.0); let CLEARCOAT_BRDF=specular_brdf( F0,clearcoatRoughnessParameter,clearcoatNdotH,clearcoatNdotV,clearcoatNdotL,LdotH); directLighting=fresnel_coat(clearcoatNdotV,ior,clearcoatParameter,directLighting,CLEARCOAT_BRDF); } #redgpu_endIf var lightDirection:f32; #redgpu_if useKHR_materials_diffuse_transmission lightDirection=mix(abs(dot(N,L)),1.0,diffuseTransmissionParameter); #redgpu_else lightDirection=NdotL; #redgpu_endIf let lightContribution=directLighting * dLight * lightDirection; return lightContribution;\n}\nconst pi:f32=3.14159265359;\nfn BRDF_specularAnisotropicGGX( f0:vec3,f90:vec3,alphaRoughness:f32,VdotH:f32,NdotL:f32,NdotV:f32,NdotH:f32,BdotV:f32,TdotV:f32,TdotL:f32,BdotL:f32,TdotH:f32,BdotH:f32,anisotropy:f32 ) -> vec3 { var at=mix(alphaRoughness,1.0,anisotropy * anisotropy); var ab=alphaRoughness; var F:vec3=fresnel_schlick(VdotH,f0); var V:f32=V_GGX_anisotropic(NdotL,NdotV,BdotV,TdotV,TdotL,BdotL,at,ab); var D:f32=D_GGX_anisotropic(NdotH,TdotH,BdotH,at,ab); return F * (V * D);\n}\nfn D_GGX_anisotropic( NdotH:f32,TdotH:f32,BdotH:f32,at:f32,ab:f32 ) -> f32 { let a2:f32=at * ab; let f:vec3=vec3(ab * TdotH,at * BdotH,a2 * NdotH); let denominator:f32=dot(f,f); let w2:f32=a2/denominator; return a2 * w2 * w2/pi;\n}\nfn V_GGX_anisotropic( NdotL:f32,NdotV:f32,BdotV:f32,TdotV:f32,TdotL:f32,BdotL:f32,at:f32,ab:f32 ) -> f32 { let GGXV=NdotL * length(vec3(at * TdotV,ab * BdotV,NdotV)); let GGXL=NdotV * length(vec3(at * TdotL,ab * BdotL,NdotL)); let v=0.5/(GGXV + GGXL); return clamp(v,0.0,1.0);\n}\nfn iridescent_fresnel(outside_ior:f32,iridescence_ior:f32,base_f0:vec3, iridescence_thickness:f32,iridescence_factor:f32,cos_theta1:f32) -> vec3 { if (iridescence_thickness <=0.0 || iridescence_factor <=0.0) { return base_f0; } let cos_theta1_abs=abs(cos_theta1); let safe_iridescence_ior=max(iridescence_ior,1.01); let sin_theta1=sqrt(max(0.0,1.0 - cos_theta1_abs * cos_theta1_abs)); let sin_theta2=(outside_ior/safe_iridescence_ior) * sin_theta1; if (sin_theta2 >=1.0) { return base_f0 + iridescence_factor * (vec3(1.0) - base_f0); } let cos_theta2=sqrt(max(0.0,1.0 - sin_theta2 * sin_theta2)); let wavelengths=vec3(650.0,510.0,475.0); let effective_thickness=max(iridescence_thickness,10.0); let ior_scale=max(1.0,1.5 - 0.5 * (safe_iridescence_ior/1.5)); let optical_thickness=2.0 * effective_thickness * safe_iridescence_ior * cos_theta2 * ior_scale; let phase=(2.0 * 3.14159265359 * optical_thickness)/wavelengths; let cos_phase=cos(phase); let sin_phase=sin(phase); let outside_cos1=outside_ior * cos_theta1_abs; let iridescence_cos2=safe_iridescence_ior * cos_theta2; let iridescence_cos1=safe_iridescence_ior * cos_theta1_abs; let outside_cos2=outside_ior * cos_theta2; let r12_s=(outside_cos1 - iridescence_cos2)/(outside_cos1 + iridescence_cos2); let r12_p=(iridescence_cos1 - outside_cos2)/(iridescence_cos1 + outside_cos2); let sqrt_f0=sqrt(clamp(base_f0,vec3(0.01),vec3(0.99))); let safe_n3=max((1.0 + sqrt_f0)/(1.0 - sqrt_f0),vec3(1.2)); let iridescence_cos2_vec=vec3(iridescence_cos2); let cos_theta1_abs_vec=vec3(cos_theta1_abs); let iridescence_cos1_vec=vec3(iridescence_cos1); let cos_theta2_vec=vec3(cos_theta2); let r23_s=(iridescence_cos2_vec - safe_n3 * cos_theta1_abs_vec)/ (iridescence_cos2_vec + safe_n3 * cos_theta1_abs_vec); let r23_p=(safe_n3 * cos_theta2_vec - iridescence_cos1_vec)/ (safe_n3 * cos_theta2_vec + iridescence_cos1_vec); let r12_s_vec=vec3(r12_s); let r12_p_vec=vec3(r12_p); let num_s_real=r12_s_vec + r23_s * cos_phase; let num_s_imag=r23_s * sin_phase; let den_s_real=vec3(1.0) + r12_s_vec * r23_s * cos_phase; let den_s_imag=r12_s_vec * r23_s * sin_phase; let num_p_real=r12_p_vec + r23_p * cos_phase; let num_p_imag=r23_p * sin_phase; let den_p_real=vec3(1.0) + r12_p_vec * r23_p * cos_phase; let den_p_imag=r12_p_vec * r23_p * sin_phase; let den_s_squared=den_s_real * den_s_real + den_s_imag * den_s_imag + vec3(0.001); let rs_real=(num_s_real * den_s_real + num_s_imag * den_s_imag)/den_s_squared; let rs_imag=(num_s_imag * den_s_real - num_s_real * den_s_imag)/den_s_squared; let Rs=rs_real * rs_real + rs_imag * rs_imag; let den_p_squared=den_p_real * den_p_real + den_p_imag * den_p_imag + vec3(0.001); let rp_real=(num_p_real * den_p_real + num_p_imag * den_p_imag)/den_p_squared; let rp_imag=(num_p_imag * den_p_real - num_p_real * den_p_imag)/den_p_squared; let Rp=rp_real * rp_real + rp_imag * rp_imag; let reflectance=0.5 * (Rs + Rp); let ior_influence=smoothstep(1.0,2.0,safe_iridescence_ior); let enhanced_reflectance=mix( pow(reflectance,vec3(0.8)) * 1.2, reflectance, ior_influence ); let clamped_reflectance=clamp(enhanced_reflectance,vec3(0.0),vec3(1.0)); return mix(base_f0,clamped_reflectance,iridescence_factor);\n}\nfn specular_btdf( NdotV:f32, NdotL:f32, NdotH:f32, VdotH:f32, LdotH:f32, roughness:f32, F0:vec3, ior:f32\n) -> vec3 { let eta:f32=1.0/ior; let D_rough:f32=distribution_ggx(NdotH,roughness * roughness); let t:f32=clamp((ior - 1.0) * 100.0,0.0,1.0); let D:f32=mix(1.0,D_rough,t); let G:f32=min(1.0,min((2.0 * NdotH * NdotV)/VdotH,(2.0 * NdotH * NdotL)/VdotH)); let F:vec3=fresnel_schlick(VdotH,F0); let denom:f32=(eta * VdotH + LdotH) * (eta * VdotH + LdotH); let btdf:vec3= (vec3(1.0) - F) * abs(VdotH * LdotH) * (eta * eta) * D * G/ (NdotV * denom + 0.001); return btdf;\n}\nfn lambda_sheen_calc_l(x:f32,alpha_g:f32) -> f32 { let one_minus_alpha_sq=(1.0 - alpha_g) * (1.0 - alpha_g); let a=mix(21.5473,25.3245,one_minus_alpha_sq); let b=mix(3.82987,3.32435,one_minus_alpha_sq); let c=mix(0.19823,0.16801,one_minus_alpha_sq); let d=mix(-1.97760,-1.27393,one_minus_alpha_sq); let e=mix(-4.32054,-4.85967,one_minus_alpha_sq); return a/(1.0 + b * pow(x,c)) + d * x + e;\n}\nfn lambda_sheen(cos_theta:f32,alpha_g:f32) -> f32 { if (abs(cos_theta) < 0.5) { return exp(lambda_sheen_calc_l(cos_theta,alpha_g)); } else { return exp(2.0 * lambda_sheen_calc_l(0.5,alpha_g) - lambda_sheen_calc_l(1.0 - cos_theta,alpha_g)); }\n}\nfn fresnel_coat(NdotV:f32,ior:f32,weight:f32,base:vec3,layer:vec3) -> vec3 { let f0:f32=pow((1.0 - ior)/(1.0 + ior),2.0); let fr:f32=f0 + (1.0 - f0) * pow(1.0 - abs(NdotV),5.0); return mix(base,layer,weight * fr);\n}\nfn conductor_fresnel(F0:vec3,bsdf:vec3,VdotH:f32) -> vec3 { let fresnel=F0 + (vec3(1.0) - F0) * pow(1.0 - abs(VdotH),5.0); return bsdf * fresnel;\n}\nfn fresnel_mix( F0:vec3, weight:f32, base:vec3, layer:vec3, VdotH:f32\n) -> vec3 { var f0=F0; f0=min(f0,vec3(1.0)); let fr=f0 + (1.0 - f0) * pow(1.0 - abs(VdotH),5.0); return (1 - weight * max(max(fr.x,fr.y),fr.z)) * base + weight * fr * layer;\n}\nfn fresnel_mix_ibl( F0:vec3, weight:f32, base:vec3, layer:vec3, NdotV:f32\n) -> vec3 { var f0=F0; f0=min(f0,vec3(1.0)); let fr=f0 + (1.0 - f0) * pow(1.0 - max(NdotV,0.0),5.0); return base * (1.0 - fr * weight) + layer * fr * weight;\n}\nfn diffuse_brdf_disney(NdotL:f32,NdotV:f32,LdotH:f32,roughness:f32,albedo:vec3) -> vec3 { if (NdotL <=0.0) { return vec3(0.0);} let energyBias=mix(0.0,0.5,roughness); let energyFactor=mix(1.0,1.0/1.51,roughness); let fd90=energyBias + 2.0 * LdotH * LdotH * roughness; let f0=1.0; let lightScatter=f0 + (fd90 - f0) * pow(1.0 - NdotL,5.0); let viewScatter=f0 + (fd90 - f0) * pow(1.0 - NdotV,5.0); return albedo * NdotL * lightScatter * viewScatter * energyFactor/pi;\n}\nfn diffuse_brdf(NdotL:f32,albedo:vec3) -> vec3 { return albedo * NdotL/pi;\n}\nfn diffuse_btdf(N:vec3,L:vec3,Albedo:vec3) -> vec3 { let cos_theta=max(-dot(N,L),0.0); return Albedo * cos_theta/pi;\n}\nfn specular_brdf( F0:vec3, roughness:f32, NdotH:f32, NdotV:f32, NdotL:f32, LdotH:f32\n) -> vec3 { let D=distribution_ggx(NdotH,roughness); let G=geometry_smith(NdotV,NdotL,roughness); let F=fresnel_schlick(LdotH,F0); let numerator=D * G * F; let denominator=4.0 * NdotV * NdotL + 0.04; return (numerator/denominator);\n}\nfn distribution_ggx(NdotH:f32,roughness:f32) -> f32 { let alpha=roughness * roughness; let alpha2=alpha * alpha; let NdotH2=NdotH * NdotH; let nom=alpha2; let denom=(NdotH2 * (alpha2 - 1.0) + 1.0); let denom_squared=denom * denom; return nom/(denom_squared * 3.14159265359);\n}\nfn geometry_smith(NdotV:f32,NdotL:f32,roughness:f32) -> f32 { let alpha=roughness * roughness; let k=alpha/2.0; let ggx1=NdotV/(NdotV * (1.0 - k) + k); let ggx2=NdotL/(NdotL * (1.0 - k) + k); return ggx1 * ggx2;\n}\nfn fresnel_schlick(cosTheta:f32,F0:vec3) -> vec3 { return F0 + (vec3(1.0) - F0) * pow(1.0 - cosTheta,5.0);\n}\nfn get_transformed_uv( input_uv:vec2, input_uv1:vec2, texCoord_index:u32, use_transform:u32, transform_offset:vec2, transform_rotation:f32, transform_scale:vec2\n) -> vec2 { var result_uv=select(input_uv,input_uv1,texCoord_index==1); if (use_transform==1) { let translation=mat3x3( 1.0,0.0,0.0, 0.0,1.0,0.0, transform_offset.x,transform_offset.y,1.0 ); let cos_rot=cos(transform_rotation); let sin_rot=sin(transform_rotation); let rotation_matrix=mat3x3( cos_rot,-sin_rot,0.0, sin_rot,cos_rot,0.0, 0.0,0.0,1.0 ); let scale_matrix=mat3x3( transform_scale.x,0.0,0.0, 0.0,transform_scale.y,0.0, 0.0,0.0,1.0 ); let result_matrix=translation * rotation_matrix * scale_matrix; result_uv=(result_matrix * vec3(result_uv,1.0)).xy; } return result_uv;\n}\nfn linear_to_srgb(linearColor:vec4) -> vec4 { let cutoff=vec4(0.0031308); let higher=vec4(1.055) * pow(linearColor,vec4(1.0/2.4)) - vec4(0.055); let lower=linearColor * vec4(12.92); return vec4( mix(higher.r,lower.r,step(linearColor.r,cutoff.r)), mix(higher.g,lower.g,step(linearColor.g,cutoff.g)), mix(higher.b,lower.b,step(linearColor.b,cutoff.b)), linearColor.a );\n}\n"));class PBRMaterial extends ABitmapBaseMaterial{#ls;#cs;#hs;#fs;#ds;constructor(i){super(i,"PBR_MATERIAL",Or,2),this.initGPURenderInfos(),this.__packingList=[()=>{this.setupPackORMTexture(),this.setupPackedKHR_clearcoatTexture_transmission(),this.setupPackedKHR_diffuse_transmission(),this.setupPackedKHR_sheen(),this.setupPackedKHR_iridescence()}]}get packedKHR_clearcoatTexture_transmission(){return this.#ds}get packedKHR_iridescence(){return this.#fs}get packedORMTexture(){return this.#ls}get packedKHR_sheen(){return this.#hs}get packedKHR_diffuse_transmission(){return this.#cs}async setupPackORMTexture(){if(!this.occlusionTexture&&!this.metallicRoughnessTexture)return;this.#ls||(this.#ls=new PackedTexture(this.redGPUContext));const i=Math.max(this.occlusionTexture?.gpuTexture?.width||1,this.metallicRoughnessTexture?.gpuTexture?.width||1),g=Math.max(this.occlusionTexture?.gpuTexture?.height||1,this.metallicRoughnessTexture?.gpuTexture?.height||1);await this.#ls.packing({r:this.occlusionTexture?.gpuTexture,g:this.metallicRoughnessTexture?.gpuTexture,b:this.metallicRoughnessTexture?.gpuTexture},i,g,"packedORMTexture")}async setupPackedKHR_clearcoatTexture_transmission(){this.#ds||(this.#ds=new PackedTexture(this.redGPUContext));const i=Math.max(this.KHR_clearcoatTexture?.gpuTexture?.width||1,this.KHR_clearcoatRoughnessTexture?.gpuTexture?.width||1),g=Math.max(this.KHR_clearcoatTexture?.gpuTexture?.height||1,this.KHR_clearcoatRoughnessTexture?.gpuTexture?.height||1),x=Math.max(this.KHR_transmissionTexture?.gpuTexture?.width||1,this.KHR_thicknessTexture?.gpuTexture?.width||1),_=Math.max(this.KHR_transmissionTexture?.gpuTexture?.height||1,this.KHR_thicknessTexture?.gpuTexture?.height||1),v=Math.max(i,x),b=Math.max(g,_);await this.#ds.packing({r:this.KHR_clearcoatTexture?.gpuTexture,g:this.KHR_clearcoatRoughnessTexture?.gpuTexture,b:this.KHR_transmissionTexture?.gpuTexture,a:this.KHR_thicknessTexture?.gpuTexture},v,b,"packedKHR_clearcoatTexture_transmission",{b:"r",a:"g"})}async setupPackedKHR_diffuse_transmission(){if(!this.KHR_diffuseTransmissionColorTexture&&!this.KHR_diffuseTransmissionTexture)return;this.#cs||(this.#cs=new PackedTexture(this.redGPUContext));const i=Math.max(this.KHR_diffuseTransmissionColorTexture?.gpuTexture?.width||1,this.KHR_diffuseTransmissionTexture?.gpuTexture?.width||1),g=Math.max(this.KHR_diffuseTransmissionColorTexture?.gpuTexture?.height||1,this.KHR_diffuseTransmissionTexture?.gpuTexture?.height||1);await this.#cs.packing({r:this.KHR_diffuseTransmissionColorTexture?.gpuTexture,g:this.KHR_diffuseTransmissionColorTexture?.gpuTexture,b:this.KHR_diffuseTransmissionColorTexture?.gpuTexture,a:this.KHR_diffuseTransmissionTexture?.gpuTexture},i,g,"packedKHR_diffuse_transmission")}async setupPackedKHR_sheen(){if(!this.KHR_sheenColorTexture&&!this.KHR_sheenRoughnessTexture)return;this.#hs||(this.#hs=new PackedTexture(this.redGPUContext));const i=Math.max(this.KHR_sheenColorTexture?.gpuTexture?.width||1,this.KHR_sheenRoughnessTexture?.gpuTexture?.width||1),g=Math.max(this.KHR_sheenColorTexture?.gpuTexture?.height||1,this.KHR_sheenRoughnessTexture?.gpuTexture?.height||1);await this.#hs.packing({r:this.KHR_sheenColorTexture?.gpuTexture,g:this.KHR_sheenColorTexture?.gpuTexture,b:this.KHR_sheenColorTexture?.gpuTexture,a:this.KHR_sheenRoughnessTexture?.gpuTexture},i,g,"packedKHR_sheen")}async setupPackedKHR_iridescence(){if(!this.KHR_iridescenceTexture&&!this.KHR_iridescenceThicknessTexture)return;this.#fs||(this.#fs=new PackedTexture(this.redGPUContext));const i=Math.max(this.KHR_iridescenceTexture?.gpuTexture?.width||1,this.KHR_iridescenceThicknessTexture?.gpuTexture?.width||1),g=Math.max(this.KHR_iridescenceTexture?.gpuTexture?.height||1,this.KHR_iridescenceThicknessTexture?.gpuTexture?.height||1);await this.#fs.packing({r:this.KHR_iridescenceTexture?.gpuTexture,g:this.KHR_iridescenceThicknessTexture?.gpuTexture},i,g,"packedKHR_iridescence")}}dr.defineByPreset(PBRMaterial,[dr.PRESET_POSITIVE_NUMBER.EMISSIVE_STRENGTH,dr.PRESET_POSITIVE_NUMBER.NORMAL_SCALE]);kr.forEach(i=>{const{extensionName:g,textureList:x,useSampler:_}=i,{positiveNumberList:v,vec3List:b,vec4List:y}=i;g&&dr.defineBoolean(PBRMaterial,[`use${g}`]),((i,g)=>{i?.forEach(i=>{dr.defineBoolean(PBRMaterial,[`use${i.charAt(0).toUpperCase()}${i.substring(1)}`]),dr.definePositiveNumber(PBRMaterial,[[`${i}_KHR_texture_transform_rotation`,0]]),dr.defineBoolean(PBRMaterial,[`use_${i}_KHR_texture_transform`]),dr.defineVec2(PBRMaterial,[`${i}_KHR_texture_transform_offset`,[`${i}_KHR_texture_transform_scale`,[1,1]]]),dr.defineUint(PBRMaterial,[`${i}_texCoord_index`]),dr.defineTexture(PBRMaterial,[i]),g&&dr.defineSampler(PBRMaterial,[`${i}Sampler`])})})(x,!_),v?.forEach(i=>{dr.definePositiveNumber(PBRMaterial,[i])}),b?.forEach(i=>{dr.defineVec3(PBRMaterial,[i])}),y?.forEach(i=>{dr.defineVec4(PBRMaterial,[i])})}),dr.definePositiveNumber(PBRMaterial,[["cutOff",0],["KHR_materials_ior",1.5],["KHR_dispersion",0]]),dr.defineUint(PBRMaterial,["alphaBlend"]),dr.defineBoolean(PBRMaterial,["doubleSided","useCutOff","useVertexColor","useVertexTangent","useKHR_materials_unlit",["useSSR",!0]]),Object.freeze(PBRMaterial);var Nr="struct InputData { @location(0) position:vec3, @location(1) vertexNormal:vec3, @location(2) uv:vec2, @location(3) uv1:vec2, @location(4) vertexColor_0:vec4, @location(5) vertexTangent:vec4,\n};",Vr="struct OutputData { @builtin(position) position:vec4, @location(0) vertexPosition:vec3, @location(1) vertexNormal:vec3, @location(2) uv:vec2, @location(3) uv1:vec2, @location(4) vertexColor_0:vec4, @location(5) vertexTangent:vec4, @location(7) currentClipPos:vec4, @location(8) prevClipPos:vec4, @location(10) localNodeScale_volumeScale:vec2, @location(11) combinedOpacity:f32, @location(12) motionVector:vec3, @location(13) shadowPos:vec3, @location(14) @interpolate(flat) receiveShadow:f32, @location(15) @interpolate(flat) pickingId:vec4,\n};",Fr="struct InputData { @location(0) position:vec3, @location(1) vertexNormal:vec3, @location(2) uv:vec2,\n};\n",Hr="struct OutputData { @builtin(position) position:vec4, @location(0) vertexPosition:vec3, @location(1) vertexNormal:vec3, @location(2) uv:vec2, @location(7) currentClipPos:vec4, @location(8) prevClipPos:vec4, @location(11) combinedOpacity:f32, @location(12) motionVector:vec3, @location(13) shadowPos:vec3, @location(14) @interpolate(flat) receiveShadow:f32, @location(15) @interpolate(flat) pickingId:vec4,\n};",zr="#redgpu_include SYSTEM_UNIFORM;\n#redgpu_include drawDirectionalShadowDepth;\n#redgpu_include picking;\n#redgpu_include calcDisplacements;\n#redgpu_include meshVertexBasicUniform;\nconst maxDistance:f32=1000.0;\nconst maxMipLevel:f32=10.0;\n@group(1) @binding(0) var vertexUniforms:VertexUniforms;\n@group(1) @binding(1) var displacementTextureSampler:sampler;\n@group(1) @binding(2) var displacementTexture:texture_2d;\n@vertex\nfn main(inputData:InputData) -> OutputData { var output:OutputData; #redgpu_if disableJitter { let u_projectionMatrix=systemUniforms.noneJitterProjectionCameraMatrix; } #redgpu_else { let u_projectionMatrix=systemUniforms.projectionMatrix; } #redgpu_endIf let u_projectionCameraMatrix=systemUniforms.projectionCameraMatrix; let u_noneJitterProjectionCameraMatrix=systemUniforms.noneJitterProjectionCameraMatrix; let u_prevNoneJitterProjectionCameraMatrix=systemUniforms.prevNoneJitterProjectionCameraMatrix; let u_resolution=systemUniforms.resolution; let u_camera=systemUniforms.camera; let u_cameraMatrix=u_camera.cameraMatrix; let u_cameraPosition=u_camera.cameraPosition; let u_matrixList=vertexUniforms.matrixList; let u_modelMatrix=u_matrixList.modelMatrix; let u_prevModelMatrix=u_matrixList.prevModelMatrix; let u_normalModelMatrix=u_matrixList.normalModelMatrix; let u_displacementScale=vertexUniforms.displacementScale; let u_useDisplacementTexture=vertexUniforms.useDisplacementTexture==1u; let u_receiveShadow=vertexUniforms.receiveShadow; let u_directionalLightCount=systemUniforms.directionalLightCount; let u_directionalLights=systemUniforms.directionalLights; let u_directionalLightProjectionViewMatrix=systemUniforms.directionalLightProjectionViewMatrix; let input_position=inputData.position; let input_position_vec4=vec4(input_position,1.0); let input_vertexNormal=inputData.vertexNormal; let input_uv=inputData.uv; var position:vec4; var normalPosition:vec4; #redgpu_if useDisplacementTexture let tempPosition=u_modelMatrix * input_position_vec4; let distance=distance(tempPosition.xyz,u_cameraPosition); let mipLevel=(distance/maxDistance) * maxMipLevel; let displacedPosition=calcDisplacementPosition( input_position, input_vertexNormal, displacementTexture, displacementTextureSampler, u_displacementScale, input_uv, mipLevel ); position=u_modelMatrix * vec4(displacedPosition,1.0); let worldUV=input_uv; let displacedNormal=calcDisplacementNormal( normalize((u_normalModelMatrix * vec4(input_vertexNormal,0.0)).xyz), displacementTexture, displacementTextureSampler, u_displacementScale, worldUV, mipLevel ); normalPosition=vec4(displacedNormal,0.0); #redgpu_else position=u_modelMatrix * input_position_vec4; normalPosition=u_normalModelMatrix * vec4(input_vertexNormal,1.0); #redgpu_endIf output.position=u_projectionCameraMatrix * position; output.vertexPosition=position.xyz; output.vertexNormal=normalPosition.xyz; output.uv=input_uv * vertexUniforms.uvTransform.zw + vertexUniforms.uvTransform.xy; output.combinedOpacity=vertexUniforms.combinedOpacity; #redgpu_if receiveShadow { let posFromLight=u_directionalLightProjectionViewMatrix * vec4(position.xyz,1.0); output.shadowPos=vec3(posFromLight.xy * vec2(0.5,-0.5) + vec2(0.5),posFromLight.z); output.receiveShadow=vertexUniforms.receiveShadow; } #redgpu_endIf { output.currentClipPos=u_noneJitterProjectionCameraMatrix * position; output.prevClipPos=u_prevNoneJitterProjectionCameraMatrix * u_prevModelMatrix * input_position_vec4; } return output;\n}\n";const $r={SHADER_INFO_PBR:parseWGSL([Nr,Vr,"#redgpu_include SYSTEM_UNIFORM;\n#redgpu_include drawDirectionalShadowDepth;\n#redgpu_include picking;\n#redgpu_include meshVertexBasicUniform;\nconst maxDistance:f32=1000.0;\nconst maxMipLevel:f32=10.0;\n@group(1) @binding(0) var vertexUniforms:VertexUniforms;\n@group(1) @binding(1) var displacementTextureSampler:sampler;\n@group(1) @binding(2) var displacementTexture:texture_2d;\n@vertex\nfn main(inputData:InputData) -> OutputData { var output:OutputData; let input_position=inputData.position; let input_position_vec4=vec4(input_position,1.0); let input_vertexNormal=inputData.vertexNormal; let u_projectionMatrix=systemUniforms.projectionMatrix; let u_projectionCameraMatrix=systemUniforms.projectionCameraMatrix; let u_noneJitterProjectionCameraMatrix=systemUniforms.noneJitterProjectionCameraMatrix; let u_prevNoneJitterProjectionCameraMatrix=systemUniforms.prevNoneJitterProjectionCameraMatrix; let u_resolution=systemUniforms.resolution; let u_camera=systemUniforms.camera; let u_cameraMatrix=u_camera.cameraMatrix; let u_cameraPosition=u_camera.cameraPosition; let u_matrixList=vertexUniforms.matrixList; let u_localMatrix=u_matrixList.localMatrix; let u_modelMatrix=u_matrixList.modelMatrix; let u_normalModelMatrix=u_matrixList.normalModelMatrix; let u_prevModelMatrix=u_matrixList.prevModelMatrix; let u_receiveShadow=vertexUniforms.receiveShadow; let u_directionalLightCount=systemUniforms.directionalLightCount; let u_directionalLights=systemUniforms.directionalLights; let u_directionalLightProjectionViewMatrix=systemUniforms.directionalLightProjectionViewMatrix; var position:vec4; var normalPosition:vec4; position=u_modelMatrix * input_position_vec4; normalPosition=u_normalModelMatrix * vec4(input_vertexNormal,0.0); output.position=u_projectionCameraMatrix * position; output.vertexPosition=position.xyz; output.vertexNormal=normalize(normalPosition.xyz); output.uv=inputData.uv; output.uv1=inputData.uv1; output.vertexColor_0=inputData.vertexColor_0; let transformedTangentXYZ=(u_normalModelMatrix * vec4(inputData.vertexTangent.xyz,0.0)).xyz; output.vertexTangent=vec4( normalize(transformedTangentXYZ),inputData.vertexTangent.w ); #redgpu_if receiveShadow { let posFromLight=u_directionalLightProjectionViewMatrix * vec4(position.xyz,1.0); output.shadowPos=vec3(posFromLight.xy * vec2(0.5,-0.5) + vec2(0.5),posFromLight.z); output.receiveShadow=vertexUniforms.receiveShadow; } #redgpu_endIf { output.currentClipPos=u_noneJitterProjectionCameraMatrix * position; output.prevClipPos=u_prevNoneJitterProjectionCameraMatrix * u_prevModelMatrix * input_position_vec4; } let nodeScaleX=length(u_localMatrix[0].xyz); let nodeScaleY=length(u_localMatrix[1].xyz); let nodeScaleZ=length(u_localMatrix[2].xyz); let volumeScaleX=length(u_modelMatrix[0].xyz); let volumeScaleY=length(u_modelMatrix[1].xyz); let volumeScaleZ=length(u_modelMatrix[2].xyz); output.localNodeScale_volumeScale=vec2( pow(nodeScaleX * nodeScaleY * nodeScaleZ,1.0/3.0), pow(volumeScaleX * volumeScaleY * volumeScaleZ,1.0/3.0) ); return output;\n}\n"].join("\n")),SHADER_INFO_BASIC:parseWGSL([Fr,Hr,zr].join("\n")),SHADER_INFO_ONLY_FRAGMENT_PBR:parseWGSL([Fr,Vr,zr].join("\n")),SHADER_INFO_ONLY_VERTEX_PBR:parseWGSL([Nr,Hr,zr].join("\n"))};Object.freeze($r);const{SHADER_INFO_PBR:Kr,SHADER_INFO_BASIC:Xr,SHADER_INFO_ONLY_FRAGMENT_PBR:jr,SHADER_INFO_ONLY_VERTEX_PBR:Yr}=$r,qr=Kr.shaderSourceVariant.getVariant("none"),Wr=Xr.shaderSourceVariant.getVariant("none"),Zr=jr.shaderSourceVariant.getVariant("none"),Jr=Yr.shaderSourceVariant.getVariant("none");class LODManager{#ms=[];#ps;#gs=!1;constructor(i,g){"InstancingMesh"===i.constructor.name&&(this.#gs=!0),this.#ps=g}get LODList(){return[...this.#ms]}addLOD(i,g,x){if(validatePositiveNumberRange(i,1),this.#ms.length>=8)throw new Error("Maximum of 8 LOD levels allowed.");if(this.#ms.some(g=>g.distance===i))throw new Error(`LOD with distance ${i} already exists.`);const _="PBR"===g.vertexBuffer.interleavedStruct.label,v=x instanceof PBRMaterial,b={distance:i,distanceSquared:i*i,geometry:g,material:x,geometryIsPBR:_,materialIsPBR:v};this.#ms.push({...b,...this.#gs?{}:{label:`vertex_${_?"pbr":"noPbr"}_fragment_${v?"pbr":"noPbr"}`,source:this.#xs(g,x)}}),this.#ms.sort((i,g)=>i.distance-g.distance),this.#ps?.()}getLOD(i){for(const g of this.#ms)if(ig.distance!==i),this.#ps?.()}clearLOD(){this.#ms.length=0,this.#ps?.()}#xs(i,g){const x="PBR"===i.vertexBuffer.interleavedStruct.label,_=g instanceof PBRMaterial;return x&&_?qr:!x&&_?Zr:x&&!_?Jr:Wr}}const Qr=Object.values(Tn);class DepthStencilState{#_s;#F="depth32float";#vs=["r8unorm","r8snorm","r8uint","r8sint","r16uint","r16sint","r16float","rg8unorm","rg8snorm","rg8uint","rg8sint","r32uint","r32sint","r32float","rg16uint","rg16sint","rg16float","rgba8unorm","rgba8unorm-srgb","rgba8snorm","rgba8uint","rgba8sint","bgra8unorm","bgra8unorm-srgb","rgb9e5ufloat","rgb10a2uint","rgb10a2unorm","rg11b10ufloat","rg32uint","rg32sint","rg32float","rgba16uint","rgba16sint","rgba16float","rgba32uint","rgba32sint","rgba32float","stencil8","depth16unorm","depth24plus","depth24plus-stencil8","depth32float","depth32float-stencil8","bc1-rgba-unorm","bc1-rgba-unorm-srgb","bc2-rgba-unorm","bc2-rgba-unorm-srgb","bc3-rgba-unorm","bc3-rgba-unorm-srgb","bc4-r-unorm","bc4-r-snorm","bc5-rg-unorm","bc5-rg-snorm","bc6h-rgb-ufloat","bc6h-rgb-float","bc7-rgba-unorm","bc7-rgba-unorm-srgb","etc2-rgb8unorm","etc2-rgb8unorm-srgb","etc2-rgb8a1unorm","etc2-rgb8a1unorm-srgb","etc2-rgba8unorm","etc2-rgba8unorm-srgb","eac-r11unorm","eac-r11snorm","eac-rg11unorm","eac-rg11snorm","astc-4x4-unorm","astc-4x4-unorm-srgb","astc-5x4-unorm","astc-5x4-unorm-srgb","astc-5x5-unorm","astc-5x5-unorm-srgb","astc-6x5-unorm","astc-6x5-unorm-srgb","astc-6x6-unorm","astc-6x6-unorm-srgb","astc-8x5-unorm","astc-8x5-unorm-srgb","astc-8x6-unorm","astc-8x6-unorm-srgb","astc-8x8-unorm","astc-8x8-unorm-srgb","astc-10x5-unorm","astc-10x5-unorm-srgb","astc-10x6-unorm","astc-10x6-unorm-srgb","astc-10x8-unorm","astc-10x8-unorm-srgb","astc-10x10-unorm","astc-10x10-unorm-srgb","astc-12x10-unorm","astc-12x10-unorm-srgb","astc-12x12-unorm","astc-12x12-unorm-srgb"];#bs=!0;#ys=Tn.LESS_EQUAL;#Ss;#Ts;#Ms;#ws;#Cs=1;#Rs=1;#Ps=1;constructor(i){this.#_s=i}get format(){return this.#F}set format(i){this.#vs.includes(i)?(this.#F=i,this.#_s.dirtyPipeline=!0):consoleAndThrowError(`Invalid value for format. Received ${i}. Expected one of:${this.#vs.join(",")}`)}get depthWriteEnabled(){return this.#bs}set depthWriteEnabled(i){this.#bs=i,this.#_s.dirtyPipeline=!0}get depthCompare(){return this.#ys}set depthCompare(i){Qr.includes(i)?(this.#ys=i,this.#_s.dirtyPipeline=!0):consoleAndThrowError(`Invalid value for depthCompare. Received ${i}. Expected one of:${Qr.join(",")}`)}get stencilFront(){return this.#Ss}set stencilFront(i){this.#Ss=i,this.#_s.dirtyPipeline=!0}get stencilBack(){return this.#Ts}set stencilBack(i){this.#Ts=i,this.#_s.dirtyPipeline=!0}get stencilReadMask(){return this.#Ms}set stencilReadMask(i){this.#Ms=i,this.#_s.dirtyPipeline=!0}get stencilWriteMask(){return this.#ws}set stencilWriteMask(i){this.#ws=i,this.#_s.dirtyPipeline=!0}get depthBias(){return this.#Cs}set depthBias(i){this.#Cs=i,this.#_s.dirtyPipeline=!0}get depthBiasSlopeScale(){return this.#Rs}set depthBiasSlopeScale(i){this.#Rs=i,this.#_s.dirtyPipeline=!0}get depthBiasClamp(){return this.#Ps}set depthBiasClamp(i){this.#Ps=i,this.#_s.dirtyPipeline=!0}get state(){let i=!1;if(this.#_s?.primitiveState){const{topology:g}=this.#_s.primitiveState;i=g===Lr.TRIANGLE_LIST||g===Lr.TRIANGLE_STRIP}return{format:this.#F,depthWriteEnabled:this.#bs,depthCompare:this.#ys,stencilFront:this.#Ss,stencilBack:this.#Ts,stencilReadMask:this.#Ms,stencilWriteMask:this.#ws,depthBias:i?this.#Cs:null,depthBiasSlopeScale:i?this.#Rs:null,depthBiasClamp:i?this.#Ps:null}}}const ei={NONE:"none",FRONT:"front",BACK:"back"};Object.freeze(ei);const ti={CW:"cw",CCW:"ccw"};Object.freeze(ti);const ni=Object.values(Dr),ri=Object.values(ti),ii=Object.values(ei),ai=["point-list","line-list","line-strip","triangle-list","triangle-strip"];class PrimitiveState{dirtyPipeline=!1;state;#_s;#Bs=Lr.TRIANGLE_LIST;#Is;#Es=ti.CCW;#Ds=ei.BACK;#Us=!1;constructor(i){this.#_s=i,this.#in()}get topology(){return this.#Bs}set topology(i){ai.includes(i)?(this.#Bs=i,this.#in()):consoleAndThrowError(`Invalid value for topology. Received ${i}. Expected one of:${ai.join(",")}`)}get stripIndexFormat(){return this.#Is}set stripIndexFormat(i){ni.includes(i)?(this.#Is=i,this.#in()):consoleAndThrowError(`Invalid value for stripIndexFormat. Received ${i}. Expected one of:${ni.join(",")}`)}get frontFace(){return this.#Es}set frontFace(i){ri.includes(i)?(this.#Es=i,this.#in()):consoleAndThrowError(`Invalid value for frontFace. Received ${i}. Expected one of:${ri.join(",")}`)}get cullMode(){return this.#Ds}set cullMode(i){ii.includes(i)?(this.#Ds=i,this.#in()):consoleAndThrowError(`Invalid value for cullMode. Received ${i}. Expected one of:${ii.join(",")}`)}get unclippedDepth(){return this.#Us}set unclippedDepth(i){"boolean"==typeof i?(this.#Us=i,this.#in()):consoleAndThrowError(`Invalid type for unclippedDepth. Received ${typeof i}. Expected type:boolean.`)}#in(){this.state={topology:this.#Bs,stripIndexFormat:this.#Is,frontFace:this.#Es,cullMode:this.#Ds,unclippedDepth:this.#Us},this.#_s.dirtyPipeline=!0}}const si=create$4(),oi={x:0,y:0,z:0,w:0},getScreenPoint=(i,g)=>{"View3D"!==i?.constructor?.name&&consoleAndThrowError("allow only View3D instance"),identity$1(si);const{noneJitterProjectionMatrix:x,rawCamera:_,pixelRectArray:v}=i;return multiply$4(si,x,_.modelMatrix),multiply$4(si,si,g),oi.z=si[14],oi.w=si[15],oi.x=.5*si[12]/oi.w+.5,oi.y=.5*si[13]/oi.w+.5,[(v[0]+oi.x*v[2])/window.devicePixelRatio,(v[1]+(1-oi.y)*v[3])/window.devicePixelRatio]},ui=create$4(),localToWorld=(i,g,x,_)=>(validateNumber(g),validateNumber(x),validateNumber(_),identity$1(ui),translate(ui,ui,[g,x,_]),multiply$4(ui,i,ui),[ui[12],ui[13],ui[14]]),li=create$4(),ci=create$3(),worldToLocal=(i,g,x,_)=>(validateNumber(g),validateNumber(x),validateNumber(_),invert$1(li,i),set$3(ci,g,x,_),transformMat4$2(ci,ci,li),[ci[0],ci[1],ci[2]]);class Object3DContainer{modelMatrix=create$4();#Ls=[];constructor(){}get children(){return this.#Ls}get numChildren(){return this.#Ls.length}contains(i){return this.#As(i),this.#Ls.includes(i)}addChild(i){return this.#As(i),this.#Gs(i)?(this.#Ls.push(i),i.dirtyTransform=!0,i):null}addChildAt(i,g){if(validateUintRange(g),this.#Ls.lengththis.#Ls.length)&&this.#Gs(i))return this.#Ls.splice(g,0,i),i.dirtyTransform=!0,this}getChildAt(i){if(validateUintRange(i),!(i>=this.#Ls.length||i<0))return this.#Ls[i]}getChildIndex(i){this.#As(i);const g=this.#Ls.indexOf(i);return-1===g?-1:g}setChildIndex(i,g){this.#As(i),validateUintRange(g);const x=this.#Ls.length,_=g>=x,v=this.#Ls.indexOf(i);-1!==v?_?consoleAndThrowError(`Invalid index. Index ${g} is out of bounds. Index should be between 0 and ${x-1}.`):(this.#Ls.splice(v,1),this.#Ls.splice(g,0,i)):consoleAndThrowError(`The provided is not a child of the Object3DContainer.:${i}`)}swapChildren(i,g){if(this.#As(i),this.#As(g),i===g)return void consoleAndThrowError("Error:child1 and child2 are the same. Cannot swap a child with itself.");const x=this.#Ls.indexOf(i),_=this.#Ls.indexOf(g);-1!==x&&-1!==_||consoleAndThrowError(`Error:${-1===x?"child1":"child2"} is not a child of this Object3DContainer.`),this.swapChildrenAt(x,_)}swapChildrenAt(i,g){validateUintRange(i),validateUintRange(g),i===g&&consoleAndThrowError("Error:index1 and index2 are identical. Cannot swap a child with itself.");const x=this.#Ls.length;(i>=x||g>=x)&&consoleAndThrowError(`Error:Both index1 and index2 should be less than the number of children. Provided index1:${i},index2:${g},number of children:${x}`);let _=this.#Ls[i];this.#Ls[i]=this.#Ls[g],this.#Ls[g]=_}removeChild(i){this.#As(i);const g=this.#Ls.indexOf(i);if(g>-1)return i.parent=null,this.#Ls.splice(g,1)[0];consoleAndThrowError("Error:Child not found within parent.")}removeChildAt(i){validateUintRange(i);const g=this.#Ls[i];if(g)return g.parent=null,this.#Ls.splice(i,1)[0];throw new Error(`Error:No child found at provided index:${i}.`)}removeAllChildren(){let i=this.#Ls.length;for(;i--;)this.#Ls[i].parent=null;return this.#Ls.length=0,this}#As(i){i instanceof Object3DContainer||consoleAndThrowError("allow only Object3DContainer instance.")}#Gs=i=>(this.#As(i),i.parent?!!i.parent?.removeChild(i)&&(i.parent=this,!0):(i.parent=this,!0))}class MeshBase extends Object3DContainer{gpuRenderInfo;animationInfo={skinInfo:null,morphInfo:null,weightBuffer:null,jointBuffer:null,animationsList:null};gltfLoaderInfo;dirtyPipeline=!0;dirtyTransform=!0;dirtyOpacity=!0;modelMatrix=create$4();localMatrix=create$4();normalModelMatrix=create$4();#l;#c;#ks;#Os;#Ns;#m=[];#u=createUUID();constructor(i){super(),validateRedGPUContext(i),this.#l=i,this.#c=i.gpuDevice,this.#ks=new PrimitiveState(this),this.#Os=new DepthStencilState(this)}get uuid(){return this.#u}get currentShaderModuleName(){return this.#Ns}set currentShaderModuleName(i){this.#Ns=i}get primitiveState(){return this.#ks}get depthStencilState(){return this.#Os}get gpuDevice(){return this.#c}get redGPUContext(){return this.#l}worldToLocal(i,g,x){return worldToLocal(this.modelMatrix,i,g,x)}localToWorld(i,g,x){return localToWorld(this.modelMatrix,i,g,x)}getScreenPoint(i){return getScreenPoint(i,this.modelMatrix)}__fireListenerList(i=!1){for(const i of this.#m)i(this);i&&(this.#m.length=0)}}const hi="shadow",fi="picking",createBasePipeline=(i,g,x,_)=>{const{redGPUContext:v}=i,{gpuDevice:b,resourceManager:y}=v,S=i.material.gpuRenderInfo;let w,L;switch(_){case hi:w="drawDirectionalShadowDepth",L=`${g.label}_shadow_pipeline`;break;case fi:w="picking",L=`${g.label}_picking_pipeline`;break;default:w="main",L=`${g.label}_pipeline`}const k={module:g,entryPoint:w,buffers:i.vertexStateBuffers},H=[y.getGPUBindGroupLayout(ResourceManager.PRESET_GPUBindGroupLayout_System),x];_!==hi&&H.push(S.fragmentBindGroupLayout);const z={bindGroupLayouts:H,label:`${L}_${S.fragmentBindGroupLayout.label}`},q={label:L,layout:y.createGPUPipelineLayout(`${z.label}`,z),vertex:k,primitive:i.primitiveState.state};switch(_){case hi:q.depthStencil={depthWriteEnabled:!0,depthCompare:Tn.LESS_EQUAL,format:"depth32float"};break;case fi:i.material&&(q.fragment={module:i.material.gpuRenderInfo.fragmentShaderModule,entryPoint:"picking",targets:[{format:navigator.gpu.getPreferredCanvasFormat()}]},q.depthStencil=i.depthStencilState.state);break;default:q.fragment=S.fragmentState,q.depthStencil=i.depthStencilState.state,q.multisample={count:v.antialiasingManager.useMSAA?4:1}}return b.createRenderPipeline(q)};const getBasicMeshVertexBindGroupDescriptor=(i,g=!1)=>{const{redGPUContext:x,gpuRenderInfo:_,material:v}=i,{resourceManager:b}=x,{vertexUniformBuffer:y,vertexBindGroupLayout:S}=_,{basicSampler:w,emptyBitmapTextureView:L,emptyCubeTextureView:k}=b,{gpuSampler:H}=w;return{layout:S,label:g?"VERTEX_BIND_GROUP_DESCRIPTOR_MESH_SKIN":"VERTEX_BIND_GROUP_DESCRIPTOR_MESH",entries:g?[{binding:0,resource:{buffer:y.gpuBuffer,offset:0,size:y.size}},{binding:1,resource:getGPUResourceSampler(v?.displacementTextureSampler)||H},{binding:2,resource:b.getGPUResourceBitmapTextureView(v?.displacementTexture)||L},{binding:3,resource:{buffer:i.animationInfo.skinInfo.vertexStorageBuffer,offset:0,size:i.animationInfo.skinInfo.vertexStorageBuffer.size}},{binding:4,resource:{buffer:i.animationInfo.skinInfo.prevVertexStorageBuffer,offset:0,size:i.animationInfo.skinInfo.prevVertexStorageBuffer.size}}]:[{binding:0,resource:{buffer:y.gpuBuffer,offset:0,size:y.size}},{binding:1,resource:getGPUResourceSampler(v?.displacementTextureSampler)||H},{binding:2,resource:b.getGPUResourceBitmapTextureView(v?.displacementTexture)||L}]}},getGPUResourceSampler=i=>i?.gpuSampler,{SHADER_INFO_PBR:di,SHADER_INFO_BASIC:mi,SHADER_INFO_ONLY_FRAGMENT_PBR:pi,SHADER_INFO_ONLY_VERTEX_PBR:gi}=$r,xi=di.uniforms.vertexUniforms,_i=mi.uniforms.vertexUniforms,createMeshVertexShaderModule=i=>{const{material:g}=i;let x,_="basic";switch(g instanceof PBRMaterial&&i.animationInfo?.skinInfo?_="skin":i.createCustomMeshVertexShaderModule&&(_="custom"),_){case"basic":{const g=(i=>{const{geometry:g,material:x}=i,_="PBR"===g.vertexBuffer.interleavedStruct.label,v=x instanceof PBRMaterial,b=_&&!v,y=!_&&v;return _&&v?{name:"VERTEX_MODULE_MESH_PBR",shaderInfo:di,source:di.defaultSource,uniformStruct:xi}:y?{name:"VERTEX_MODULE_MESH_ONLY_FRAGMENT_PBR",shaderInfo:pi,source:pi.defaultSource,uniformStruct:_i}:b?{name:"VERTEX_MODULE_MESH_ONLY_VERTEX_PBR",shaderInfo:gi,source:gi.defaultSource,uniformStruct:_i}:{name:"VERTEX_MODULE_MESH",shaderInfo:mi,source:mi.defaultSource,uniformStruct:_i}})(i);x=i.createMeshVertexShaderModuleBASIC(g.name,g.shaderInfo,g.uniformStruct,g.source);break}case"skin":x=((i,g)=>{const{redGPUContext:x,currentShaderModuleName:_}=g,{resourceManager:v,gpuDevice:b}=x,{gpuRenderInfo:y}=g,S=`${g.animationInfo.skinInfo.joints.length}`,w=`${i}_${S}`,L="#redgpu_include SYSTEM_UNIFORM;\n#redgpu_include meshVertexBasicUniform;\nconst maxDistance:f32=1000.0;\nconst maxMipLevel:f32=10.0;\n@group(1) @binding(0) var vertexUniforms:VertexUniforms;\n@group(1) @binding(1) var displacementTextureSampler:sampler;\n@group(1) @binding(2) var displacementTexture:texture_2d;\n@group(1) @binding(3) var vertexStorages:array>;\n@group(1) @binding(4) var prevVertexStorages:array>;\nstruct InputDataSkin { @builtin(vertex_index) idx:u32, @location(0) position:vec3, @location(1) vertexNormal:vec3, @location(2) uv:vec2, @location(3) uv1:vec2, @location(4) vertexColor_0:vec4, @location(5) vertexTangent:vec4,\n};\nstruct OutputDataSkin { @builtin(position) position:vec4, @location(0) vertexPosition:vec3, @location(1) vertexNormal:vec3, @location(2) uv:vec2, @location(3) uv1:vec2, @location(4) vertexColor_0:vec4, @location(5) vertexTangent:vec4, @location(7) currentClipPos:vec4, @location(8) prevClipPos:vec4, @location(10) localNodeScale_volumeScale:vec2, @location(11) combinedOpacity:f32, @location(12) motionVector:vec3, @location(13) shadowPos:vec3, @location(14) @interpolate(flat) receiveShadow:f32, @location(15) @interpolate(flat) pickingId:vec4,\n};\nstruct OutputShadowData { @builtin(position) position:vec4,\n};\n@vertex\nfn main(inputData:InputDataSkin) -> OutputDataSkin { var output:OutputDataSkin; let input_position=inputData.position; let input_position_vec4=vec4(input_position,1.0); let input_vertexNormal=inputData.vertexNormal; let u_projectionMatrix=systemUniforms.projectionMatrix; let u_projectionCameraMatrix=systemUniforms.projectionCameraMatrix; let u_noneJitterProjectionCameraMatrix=systemUniforms.noneJitterProjectionCameraMatrix; let u_prevNoneJitterProjectionCameraMatrix=systemUniforms.prevNoneJitterProjectionCameraMatrix; let u_resolution=systemUniforms.resolution; let u_camera=systemUniforms.camera; let u_cameraMatrix=u_camera.cameraMatrix; let u_cameraPosition=u_camera.cameraPosition; let u_matrixList=vertexUniforms.matrixList; let u_localMatrix=u_matrixList.localMatrix; let u_modelMatrix=u_matrixList.modelMatrix; let u_prevModelMatrix=u_matrixList.prevModelMatrix; let u_normalModelMatrix=u_matrixList.normalModelMatrix; let u_receiveShadow=vertexUniforms.receiveShadow; let u_directionalLightCount=systemUniforms.directionalLightCount; let u_directionalLights=systemUniforms.directionalLights; let u_directionalLightProjectionViewMatrix=systemUniforms.directionalLightProjectionViewMatrix; let skinMat=vertexStorages[inputData.idx]; let prevSkinMat=prevVertexStorages[inputData.idx]; let skinnedPosition=(skinMat * vec4(inputData.position,1.0)); let position=u_modelMatrix * skinnedPosition; let skinnedNormal=(skinMat * vec4(input_vertexNormal,0.0)).xyz; let transformedNormal=normalize((u_normalModelMatrix * vec4(skinnedNormal,0.0)).xyz); output.vertexNormal=transformedNormal; let skinnedTangent=(skinMat * vec4(inputData.vertexTangent.xyz,0.0)).xyz; let transformedTangentXYZ=(u_normalModelMatrix * vec4(skinnedTangent,0.0)).xyz; output.vertexTangent=vec4(normalize(transformedTangentXYZ),inputData.vertexTangent.w); output.position=u_projectionCameraMatrix * position; output.vertexPosition=position.xyz; output.uv=inputData.uv; output.uv1=inputData.uv1; output.vertexColor_0=inputData.vertexColor_0; #redgpu_if receiveShadow { let posFromLight=u_directionalLightProjectionViewMatrix * vec4(position.xyz,1.0); output.shadowPos=vec3(posFromLight.xy * vec2(0.5,-0.5) + vec2(0.5),posFromLight.z); output.receiveShadow=vertexUniforms.receiveShadow; } #redgpu_endIf { output.currentClipPos=u_noneJitterProjectionCameraMatrix * position; output.prevClipPos=u_prevNoneJitterProjectionCameraMatrix * u_prevModelMatrix * (prevSkinMat * input_position_vec4); } let nodeScaleX=length(u_localMatrix[0].xyz); let nodeScaleY=length(u_localMatrix[1].xyz); let nodeScaleZ=length(u_localMatrix[2].xyz); let volumeScaleX=length(u_modelMatrix[0].xyz); let volumeScaleY=length(u_modelMatrix[1].xyz); let volumeScaleZ=length(u_modelMatrix[2].xyz); output.localNodeScale_volumeScale=vec2( pow(nodeScaleX * nodeScaleY * nodeScaleZ,1.0/3.0), pow(volumeScaleX * volumeScaleY * volumeScaleZ,1.0/3.0) ); return output;\n}\n@vertex\nfn drawDirectionalShadowDepth(inputData:InputDataSkin) -> OutputShadowData { var output:OutputShadowData; let u_directionalLightProjectionViewMatrix=systemUniforms.directionalLightProjectionViewMatrix; let u_modelMatrix=vertexUniforms.matrixList.modelMatrix; let input_position=inputData.position;\nlet skinMat=vertexStorages[inputData.idx]; let position=u_modelMatrix * skinMat * vec4(input_position,1.0); output.position=u_directionalLightProjectionViewMatrix * position; return output;\n}\n@vertex\nfn picking(inputData:InputDataSkin) -> OutputDataSkin { var output:OutputDataSkin; let u_projectionMatrix=systemUniforms.projectionMatrix; let u_projectionCameraMatrix=systemUniforms.projectionCameraMatrix; let u_camera=systemUniforms.camera; let u_cameraMatrix=u_camera.cameraMatrix; let u_modelMatrix=vertexUniforms.matrixList.modelMatrix;\nlet skinMat=vertexStorages[inputData.idx]; let position=u_modelMatrix * skinMat * vec4(inputData.position,1.0); output.position=u_projectionCameraMatrix * position; output.pickingId=unpack4x8unorm(vertexUniforms.pickingId); return output;\n}\n",k={code:L};if(_===w)return v.getGPUShaderModule(w);k.code=L.replaceAll("#JOINT_NUM",S),y.vertexUniformInfo=parseWGSL(k.code).uniforms.vertexUniforms,g.animationInfo.skinInfo?(createMeshVertexUniformBuffers(g,!0),g.animationInfo.skinInfo.vertexStorageInfo=parseWGSL(k.code).storage.vertexStorages,g.animationInfo.skinInfo.vertexStorageBuffer=b.createBuffer({size:16*g.geometry.vertexBuffer.vertexCount*4,usage:GPUBufferUsage.STORAGE|GPUBufferUsage.COPY_SRC|GPUBufferUsage.COPY_DST}),g.animationInfo.skinInfo.prevVertexStorageBuffer=b.createBuffer({size:16*g.geometry.vertexBuffer.vertexCount*4,usage:GPUBufferUsage.STORAGE|GPUBufferUsage.COPY_SRC|GPUBufferUsage.COPY_DST}),y.vertexUniformBindGroup=x.gpuDevice.createBindGroup(getBasicMeshVertexBindGroupDescriptor(g,!0))):(createMeshVertexUniformBuffers(g),y.vertexUniformBindGroup=x.gpuDevice.createBindGroup(getBasicMeshVertexBindGroupDescriptor(g)));const H=v.createGPUShaderModule(w,k);return g.gpuRenderInfo.vertexShaderModule=H,g.gpuRenderInfo.vertexShaderModule})("VERTEX_MODULE_MESH_PBR_SKIN",i);break;case"custom":x=i.createCustomMeshVertexShaderModule()}return i.currentShaderModuleName=x.label,x},updateMeshDirtyPipeline=(i,g)=>{const{material:x,gpuRenderInfo:_,redGPUContext:v}=i,{resourceManager:b}=v;i.dirtyTransform=!0,x.dirtyPipeline&&x._updateFragmentState();const y=createMeshVertexShaderModule(i),S=b.getGPUBindGroupLayout(i.animationInfo.skinInfo?ResourceManager.PRESET_VERTEX_GPUBindGroupLayout_SKIN:ResourceManager.PRESET_VERTEX_GPUBindGroupLayout);_.vertexShaderModule=y,_.pipeline=createBasePipeline(i,y,S),_.shadowPipeline=null,_.pickingPipeline=null;const{vertexUniformInfo:w}=i.gpuRenderInfo,{members:L}=w;for(const g in L)"pickingId"!==g&&"pixelSize"!==g&&(i[g]=i[g]);i.gpuRenderInfo.vertexUniformInfo.members.pickingId&&i.gpuRenderInfo.vertexUniformBuffer.writeOnlyBuffer(i.gpuRenderInfo.vertexUniformInfo.members.pickingId,i.pickingId),x.dirtyPipeline=!1,i.dirtyPipeline=!1,g&&g.numDirtyPipelines++};class VertexGPURenderInfo{vertexShaderModule;vertexShaderSourceVariant;vertexShaderVariantConditionalBlocks;vertexStructInfo;vertexUniformInfo;vertexBindGroupLayout;vertexUniformBindGroup;vertexUniformBuffer;pipeline;shadowPipeline;pickingPipeline;constructor(i,g,x,_,v,b,y,S,w,L){this.vertexShaderModule=i,this.vertexShaderSourceVariant=g,this.vertexShaderVariantConditionalBlocks=x,this.vertexUniformInfo=_,this.vertexBindGroupLayout=v,this.vertexUniformBindGroup=y,this.vertexUniformBuffer=b,this.pipeline=S,this.shadowPipeline=w,this.pickingPipeline=L}}Object.freeze(VertexGPURenderInfo);const vi="VERTEX_MODULE_MESH_PBR_SKIN",bi=Math.PI/180,yi=3.141592653589793,Si=6.283185307179586,Ti=.225,Mi=1.27323954,wi=.405284735,Ci=1.5707963267948966,Ri=new Float32Array(1),Pi=new Float32Array(4),Bi=new Float32Array([0,1,0]);class Mesh extends MeshBase{displacementTexture;castShadow=!1;dirtyLOD=!1;passFrustumCulling=!0;createCustomMeshVertexShaderModule;#f;#h;#Vs;#Ot=0;#Nt=0;#Vt=0;#Fs=new Float32Array([0,0,0]);#Hs=0;#zs=0;#$s=0;#Ks;#Xs=1;#js=1;#Ys=1;#qs=new Float32Array([1,1,1]);#Di=0;#Ui=0;#Li=0;#Ws=new Float32Array([0,0,0]);#Zs={};#Js=0;#Qs=!1;#eo=1;#to;#no=!1;#ro;#io;#ao;#so;#oo;#uo=[];#lo=[];#co;#ho=null;#fo=[];#do=null;#mo=!0;#po=!0;#go;#xo;#_o;#vo=[];#bo=-1;constructor(i,g,x,_){super(i),_&&(this.name=_),this._geometry=g,this._material=x,this.#Ks=uuidToUint(this.uuid),this.#do=DrawBufferManager.getInstance(i),this.#yo(),this.#_o=new LODManager(this,()=>{this.dirtyLOD=!0})}get LODManager(){return this.#_o}get enableDebugger(){return this.#no}set enableDebugger(i){this.#no=i,i&&!this.#to&&(this.#to=new DrawDebuggerMesh(this.redGPUContext,this))}get drawDebugger(){return this.#to}_material;get material(){return this._material}set material(i){this._material=i,this.dirtyPipeline=!0,"blendMode"in this&&(this.blendMode=this.blendMode)}_geometry;get geometry(){return this._geometry}set geometry(i){this._geometry=i,this.dirtyPipeline=!0,this.dirtyTransform=!0}get opacity(){return this.#eo}set opacity(i){validatePositiveNumberRange(i,0,1),this.#eo=i,this.dirtyOpacity=!0}get ignoreFrustumCulling(){return this.#Qs}set ignoreFrustumCulling(i){this.#Qs=i}get pickingId(){return this.#Ks}get events(){return this.#Zs}get name(){return this.#f||(this.#f=InstanceIdGenerator.getNextId(this.constructor)),this.#h||`${this.constructor.name} Instance ${this.#f}`}set name(i){this.#h=i}get vertexStateBuffers(){return this._geometry.gpuRenderInfo.buffers}get parent(){return this.#Vs}set parent(i){this.#Vs=i}get pivotX(){return this.#Hs}set pivotX(i){this.#Hs=i,this.dirtyTransform=!0}get pivotY(){return this.#zs}set pivotY(i){this.#zs=i,this.dirtyTransform=!0}get pivotZ(){return this.#$s}set pivotZ(i){this.#$s=i,this.dirtyTransform=!0}get x(){return this.#Ot}set x(i){this.#Ot=this.#Fs[0]=i,this.dirtyTransform=!0}get y(){return this.#Nt}set y(i){this.#Nt=this.#Fs[1]=i,this.dirtyTransform=!0}get z(){return this.#Vt}set z(i){this.#Vt=this.#Fs[2]=i,this.dirtyTransform=!0}get position(){return this.#Fs}get scaleX(){return this.#Xs}set scaleX(i){this.#Xs=this.#qs[0]=i,this.dirtyTransform=!0}get scaleY(){return this.#js}set scaleY(i){this.#js=this.#qs[1]=i,this.dirtyTransform=!0}get scaleZ(){return this.#Ys}set scaleZ(i){this.#Ys=this.#qs[2]=i,this.dirtyTransform=!0}get scale(){return this.#qs}get rotationX(){return this.#Di}set rotationX(i){this.#Di=this.#Ws[0]=i%360,this.dirtyTransform=!0}get rotationY(){return this.#Ui}set rotationY(i){this.#Ui=this.#Ws[1]=i%360,this.dirtyTransform=!0}get rotationZ(){return this.#Li}set rotationZ(i){this.#Li=this.#Ws[2]=i%360,this.dirtyTransform=!0}get rotation(){return this.#Ws}get boundingOBB(){return this.#io&&!this.dirtyTransform||(this.#io=null,this.#ro=null,this.#io=calculateMeshOBB(this)),this.#io}get boundingAABB(){return this.#ro&&!this.dirtyTransform||(this.#io=null,this.#ro=null,this.#ro=calculateMeshAABB(this)),this.#ro}get combinedBoundingAABB(){return calculateMeshCombinedAABB(this)}setEnableDebuggerRecursively(i=!1){"enableDebugger"in this&&(this.enableDebugger=i),this.children&&this.children.forEach(g=>{g.setEnableDebuggerRecursively(i)})}setCastShadowRecursively(i=!1){"castShadow"in this&&(this.castShadow=i),this.children&&this.children.forEach(g=>{g.setCastShadowRecursively(i)})}setReceiveShadowRecursively(i=!1){"receiveShadow"in this&&(this.receiveShadow=i),this.children&&this.children.forEach(g=>{g.setReceiveShadowRecursively(i)})}setIgnoreFrustumCullingRecursively(i=!1){"ignoreFrustumCulling"in this&&(this.ignoreFrustumCulling=i),this.children&&this.children.forEach(g=>{g.setIgnoreFrustumCullingRecursively(i)})}getCombinedOpacity(){if(this.is2DMeshType){const i=this.parent;return this.#eo*(i?.getCombinedOpacity?i.getCombinedOpacity():1)}return 1}addListener(i,g){this.#Zs[i]=g,this.#Js=Object.keys(this.#Zs).length}lookAt(i,g,x){var _,v=[];v[0]=i,v[1]=g,v[2]=x,identity$1(this.localMatrix),targetTo(this.localMatrix,[this.#Ot,this.#Nt,this.#Vt],v,Bi),_=mat4ToEuler(this.localMatrix,[]),this.rotationX=180*_[0]/Math.PI,this.rotationY=180*_[1]/Math.PI,this.rotationZ=180*_[2]/Math.PI}setScale(i,g,x){g=g??i,x=x??i;const _=this.#qs;this.#Xs=_[0]=i,this.#js=_[1]=g,this.#Ys=_[2]=x,this.dirtyTransform=!0}setPosition(i,g,x){g=g??i,x=x??i;const _=this.#Fs;this.#Ot=_[0]=i,this.#Nt=_[1]=g,this.#Vt=_[2]=x,this.dirtyTransform=!0}setRotation(i,g,x){g=g??i,x=x??i;const _=this.#Ws;this.#Di=_[0]=i,this.#Ui=_[1]=g,this.#Li=_[2]=x,this.dirtyTransform=!0}clone(){const i=new Mesh(this.redGPUContext,this._geometry,this._material);i.setPosition(this.#Ot,this.#Nt,this.#Vt),i.setRotation(this.#Di,this.#Ui,this.#Li),i.setScale(this.#Xs,this.#js,this.#Ys);let g=this.children.length;for(;g--;)i.addChild(this.children[g].clone());return i}render(i){const{redGPUContext:g}=this,{view:x,isScene2DMode:_,frustumPlanes:v,dirtyVertexUniformFromMaterial:b,useDistanceCulling:y,cullingDistanceSquared:S}=i,{antialiasingManager:w,gpuDevice:L}=g,{scene:k}=x,{shadowManager:H}=k,{directionalShadowManager:z}=H,{pickingManager:q}=x,{castingList:W}=z,be=this._geometry,Ke=this._material,{uuid:Xe}=Ke||{};let je,Ye,Ze=this.dirtyPipeline;const{skinInfo:Je}=this.animationInfo;if(_&&(this.#Vt=0,this.#$s=0,this.depthStencilState.depthWriteEnabled&&(this.depthStencilState.depthWriteEnabled=!1)),this.dirtyTransform){je=!0,this.#mo=!0,this.#po=!0;{const{pixelRectObject:i}=x,g=this.parent,v=this.localMatrix;let b,y,S,w,L,k,H,z,q,W,be,Ke,Xe,je,Ye,Ze,Je,Qe,et,tt,it,ft,pt,xt,vt,bt,yt,St,Tt,Mt,wt,Ct,Rt,Pt,Bt,It,Et,Dt,Ut;v[12]=this.#Ot,v[13]=this.#Nt,v[14]=this.#Vt,v[15]=1,b=this.#Di*bi,y=this.#Ui*bi,S=this.#Li*bi,pt=1,xt=0,vt=0,yt=0,St=1,Tt=0,wt=0,Ct=0,Rt=1,Ut=b%Si,Ut<-yi?Ut+=Si:Ut>yi&&(Ut-=Si),Ut=Ut<0?Mi*Ut+wi*Ut*Ut:Mi*Ut-wi*Ut*Ut,w=Ut<0?Ti*(Ut*-Ut-Ut)+Ut:Ti*(Ut*Ut-Ut)+Ut,Ut=(b+Ci)%Si,Ut<-yi?Ut+=Si:Ut>yi&&(Ut-=Si),Ut=Ut<0?Mi*Ut+wi*Ut*Ut:Mi*Ut-wi*Ut*Ut,H=Ut<0?Ti*(Ut*-Ut-Ut)+Ut:Ti*(Ut*Ut-Ut)+Ut,Ut=y%Si,Ut<-yi?Ut+=Si:Ut>yi&&(Ut-=Si),Ut=Ut<0?Mi*Ut+wi*Ut*Ut:Mi*Ut-wi*Ut*Ut,L=Ut<0?Ti*(Ut*-Ut-Ut)+Ut:Ti*(Ut*Ut-Ut)+Ut,Ut=(y+Ci)%Si,Ut<-yi?Ut+=Si:Ut>yi&&(Ut-=Si),Ut=Ut<0?Mi*Ut+wi*Ut*Ut:Mi*Ut-wi*Ut*Ut,z=Ut<0?Ti*(Ut*-Ut-Ut)+Ut:Ti*(Ut*Ut-Ut)+Ut,Ut=S%Si,Ut<-yi?Ut+=Si:Ut>yi&&(Ut-=Si),Ut=Ut<0?Mi*Ut+wi*Ut*Ut:Mi*Ut-wi*Ut*Ut,k=Ut<0?Ti*(Ut*-Ut-Ut)+Ut:Ti*(Ut*Ut-Ut)+Ut,Ut=(S+Ci)%Si,Ut<-yi?Ut+=Si:Ut>yi&&(Ut-=Si),Ut=Ut<0?Mi*Ut+wi*Ut*Ut:Mi*Ut-wi*Ut*Ut,q=Ut<0?Ti*(Ut*-Ut-Ut)+Ut:Ti*(Ut*Ut-Ut)+Ut,je=z*q,Ye=H*k+w*L*q,Ze=w*k-H*L*q,Je=-z*k,Qe=H*q-w*L*k,et=w*q+H*L*k,tt=L,it=-w*z,ft=H*z;let Lt=this.#Xs,At=this.#js,Gt=this.#Ys;if(this.renderTextureWidth&&(Lt*=this.renderTextureWidth,At*=this.renderTextureHeight),v[0]=je*Lt,v[1]=Ye*Lt,v[2]=Ze*Lt,v[3]=0,v[4]=Je*At,v[5]=Qe*At,v[6]=et*At,v[7]=0,v[8]=tt*Gt,v[9]=it*Gt,v[10]=ft*Gt,v[11]=0,(this.#Hs||this.#zs||this.#$s)&&(pt=v[0],xt=v[1],vt=v[2],bt=v[3],yt=v[4],St=v[5],Tt=v[6],Mt=v[7],wt=v[8],Ct=v[9],Rt=v[10],Pt=v[11],Bt=v[12],It=v[13],Et=v[14],Dt=v[15],W=1,be=0,Ke=0,Xe=0,v[0]=W*pt+be*yt+Ke*wt+Xe*Bt,v[1]=W*xt+be*St+Ke*Ct+Xe*It,v[2]=W*vt+be*Tt+Ke*Rt+Xe*Et,v[3]=W*bt+be*Mt+Ke*Pt+Xe*Dt,W=0,be=1,Ke=0,Xe=0,v[4]=W*pt+be*yt+Ke*wt+Xe*Bt,v[5]=W*xt+be*St+Ke*Ct+Xe*It,v[6]=W*vt+be*Tt+Ke*Rt+Xe*Et,v[7]=W*bt+be*Mt+Ke*Pt+Xe*Dt,W=0,be=0,Ke=1,Xe=0,v[8]=W*pt+be*yt+Ke*wt+Xe*Bt,v[9]=W*xt+be*St+Ke*Ct+Xe*It,v[10]=W*vt+be*Tt+Ke*Rt+Xe*Et,v[11]=W*bt+be*Mt+Ke*Pt+Xe*Dt,_?g?.modelMatrix?(W=-this.#Hs,be=-this.#zs,Ke=-this.#$s,Xe=1):(W=-this.#Hs/b,be=-this.#zs/y,Ke=-this.#$s,Xe=1):(W=-this.#Hs,be=-this.#zs,Ke=-this.#$s,Xe=1),v[12]=W*pt+be*yt+Ke*wt+Xe*Bt,v[13]=W*xt+be*St+Ke*Ct+Xe*It,v[14]=W*vt+be*Tt+Ke*Rt+Xe*Et,v[15]=W*bt+be*Mt+Ke*Pt+Xe*Dt),g?.modelMatrix){const i=g.modelMatrix,x=this.localMatrix,_=this.modelMatrix,v=i[0],b=i[1],y=i[2],S=i[3],w=i[4],L=i[5],k=i[6],H=i[7],z=i[8],q=i[9],W=i[10],be=i[11],Ke=i[12],Xe=i[13],je=i[14],Ye=i[15];let Ze=x[0],Je=x[1],Qe=x[2],et=x[3];_[0]=Ze*v+Je*w+Qe*z+et*Ke,_[1]=Ze*b+Je*L+Qe*q+et*Xe,_[2]=Ze*y+Je*k+Qe*W+et*je,_[3]=Ze*S+Je*H+Qe*be+et*Ye,Ze=x[4],Je=x[5],Qe=x[6],et=x[7],_[4]=Ze*v+Je*w+Qe*z+et*Ke,_[5]=Ze*b+Je*L+Qe*q+et*Xe,_[6]=Ze*y+Je*k+Qe*W+et*je,_[7]=Ze*S+Je*H+Qe*be+et*Ye,Ze=x[8],Je=x[9],Qe=x[10],et=x[11],_[8]=Ze*v+Je*w+Qe*z+et*Ke,_[9]=Ze*b+Je*L+Qe*q+et*Xe,_[10]=Ze*y+Je*k+Qe*W+et*je,_[11]=Ze*S+Je*H+Qe*be+et*Ye,Ze=x[12],Je=x[13],Qe=x[14],et=x[15],_[12]=Ze*v+Je*w+Qe*z+et*Ke,_[13]=Ze*b+Je*L+Qe*q+et*Xe,_[14]=Ze*y+Je*k+Qe*W+et*je,_[15]=Ze*S+Je*H+Qe*be+et*Ye}else{const{modelMatrix:i,localMatrix:g}=this;i[0]=g[0],i[1]=g[1],i[2]=g[2],i[3]=g[3],i[4]=g[4],i[5]=g[5],i[6]=g[6],i[7]=g[7],i[8]=g[8],i[9]=g[9],i[10]=g[10],i[11]=g[11],i[12]=g[12],i[13]=g[13],i[14]=g[14],i[15]=g[15]}}be||(this.#po=!1),this.dirtyTransform=!1,this.#ro=null,this.#io=null}if(w.useTAA&&this.#go){const{gpuRenderInfo:i}=this,{vertexUniformBuffer:x,vertexUniformInfo:_}=i,{members:v}=_,{members:b}=v.matrixList;this.#ao&&b.prevModelMatrix&&(this.#go.set(this.#ao,b.prevModelMatrix.uniformOffsetForData/Float32Array.BYTES_PER_ELEMENT),this.#po||g.gpuDevice.queue.writeBuffer(x.gpuBuffer,b.prevModelMatrix.uniformOffset,this.#ao));{this.#ao||(this.#ao=new Float32Array(16));const i=this.#ao,g=this.modelMatrix;i[0]=g[0],i[1]=g[1],i[2]=g[2],i[3]=g[3],i[4]=g[4],i[5]=g[5],i[6]=g[6],i[7]=g[7],i[8]=g[8],i[9]=g[9],i[10]=g[10],i[11]=g[11],i[12]=g[12],i[13]=g[13],i[14]=g[14],i[15]=g[15]}}else this.#ao=null;let Qe=this.passFrustumCulling=!0,et=0;const tt=this.#_o.LODList,it=tt.length;if(y&&be||this.#_o.LODList.length){const{rawCamera:i}=x,g=this.boundingAABB,_=i.x-g.centerX,v=i.y-g.centerY,b=i.z-g.centerZ;et=_*_+v*v+b*b}if(y&&be){const i=this.boundingAABB.geometryRadius;et>S+i*i&&(Qe=!1)}if(v&&Qe&&!this.#Qs){const{rawCamera:i}=x,g=this.boundingAABB;if(i instanceof IsometricController){const{centerX:x,centerY:_,centerZ:v,geometryRadius:b}=g,y=i,{left:S,right:w,top:L,bottom:k,nearClipping:H,farClipping:z}=y,{x:q,y:W,z:be}=y;{const i=x-q,g=_-W,y=v-be,Ke=45*(Math.PI/180),Xe=Math.cos(Ke),je=Math.sin(Ke),Ye=i*Xe+y*je,Ze=-i*je+y*Xe;(Ye+bw||g+bL||Ze+bz)&&(Qe=!1)}}else{const i=v[0],x=v[1],_=v[2],b=v[3],y=v[4],S=v[5],w=g.centerX,L=g.centerY,k=g.centerZ,H=g.geometryRadius;(i[0]*w+i[1]*L+i[2]*k+i[3]<=-H||x[0]*w+x[1]*L+x[2]*k+x[3]<=-H||_[0]*w+_[1]*L+_[2]*k+_[3]<=-H||b[0]*w+b[1]*L+b[2]*k+b[3]<=-H||y[0]*w+y[1]*L+y[2]*k+y[3]<=-H||S[0]*w+S[1]*L+S[2]*k+S[3]<=-H)&&(Qe=!1)}}Qe&&(this.gltfLoaderInfo?.activeAnimations?.length&&(i.animationList[i.animationList.length]=this.gltfLoaderInfo?.activeAnimations),Je&&(this.currentShaderModuleName.includes(vi)||(Ze=!0),this.currentShaderModuleName===`${vi}_${Je.joints?.length}`&&(i.skinList[i.skinList.length]=this,je=!1))),this.passFrustumCulling=Qe;const{displacementTexture:ft,displacementScale:pt}=Ke||{};if((Ze||Ke?.dirtyPipeline||b[Xe])&&(b[Xe]=!0),be){i.num3DObjects++,w.changedMSAA&&(Ze=!0,this.dirtyLOD=!0),this.gpuRenderInfo||this.initGPURenderInfos();const g=!!ft;this.useDisplacementTexture!==g&&(this.useDisplacementTexture=g,Ze=!0),(Ze||b[Xe])&&(updateMeshDirtyPipeline(this,i),this.#so=null,this.#oo=null);{const{gpuRenderInfo:i}=this,{vertexUniformBuffer:g,vertexUniformInfo:x}=i,{members:_}=x,{gpuBuffer:v}=g;if(this.#go||(this.#go=new Float32Array(_.matrixList.endOffset/Float32Array.BYTES_PER_ELEMENT)),_.uvTransform&&(Ke.dirtyTextureTransform||b[Xe])){const i=Ke,g=i.textureOffset,x=i.textureScale;g&&(b[Xe]=!0,Pi[0]=g[0],Pi[1]=g[1],Pi[2]=x[0],Pi[3]=x[1],L.queue.writeBuffer(v,_.uvTransform.uniformOffset,Pi),Ke.dirtyTextureTransform=!1)}}}else i.num3DGroups++;if(be&&Qe){const{gpuRenderInfo:g}=this,{vertexUniformBuffer:_,vertexUniformInfo:v}=g,{members:b}=v,{members:y}=b.matrixList,{gpuBuffer:S}=_;if(this.#go||(this.#go=new Float32Array(b.matrixList.endOffset/Float32Array.BYTES_PER_ELEMENT)),void 0!==b.displacementScale&&this.#xo!==pt&&(this.#xo=pt,Ri[0]=pt,L.queue.writeBuffer(S,b.displacementScale.uniformOffset,Ri)),this.#po){{const i=this.is2DMeshType?multiply$4(create$4(),this.modelMatrix,fromValues$4(this.width,0,0,0,0,this.height,0,0,0,0,1,0,0,0,0,1)):this.modelMatrix;this.#go.set(i,y.modelMatrix.uniformOffsetForData/Float32Array.BYTES_PER_ELEMENT)}if(this.#mo&&y.normalModelMatrix){this.#mo=!1;const i=this.modelMatrix,g=this.normalModelMatrix,x=i[0],_=i[1],v=i[2],b=i[4],y=i[5],S=i[6],w=i[8],L=i[9],k=i[10],H=x*(y*k-S*L)-_*(b*k-S*w)+v*(b*L-y*w);if(0===H)g[0]=1,g[1]=0,g[2]=0,g[3]=0,g[4]=0,g[5]=1,g[6]=0,g[7]=0,g[8]=0,g[9]=0,g[10]=1,g[11]=0,g[12]=0,g[13]=0,g[14]=0,g[15]=1;else{const i=1/H;g[0]=(y*k-S*L)*i,g[1]=(S*w-b*k)*i,g[2]=(b*L-y*w)*i,g[3]=0,g[4]=(v*L-_*k)*i,g[5]=(x*k-v*w)*i,g[6]=(_*w-x*L)*i,g[7]=0,g[8]=(_*S-v*y)*i,g[9]=(v*b-x*S)*i,g[10]=(x*y-_*b)*i,g[11]=0,g[12]=0,g[13]=0,g[14]=0,g[15]=1}}this.#go.set(this.normalModelMatrix,y.normalModelMatrix.uniformOffsetForData/Float32Array.BYTES_PER_ELEMENT),y.localMatrix&&this.#go.set(this.localMatrix,y.localMatrix.uniformOffsetForData/Float32Array.BYTES_PER_ELEMENT),je=!0,this.#po=!1,L.queue.writeBuffer(S,b.matrixList.startOffset,this.#go)}this.dirtyOpacity&&(Ye=!0,b.combinedOpacity&&(Ri[0]=this.getCombinedOpacity(),L.queue.writeBuffer(S,b.combinedOpacity.uniformOffset,Ri)),this.dirtyOpacity=!1);const{bundleListRender2PathLayer:w,bundleListParticleLayer:k,bundleListTransparentLayer:H,bundleListAlphaLayer:z,bundleListBasicList:W}=i;{const{fragmentUniformBindGroup:g}=Ke.gpuRenderInfo;if((!this.#so||Ze||this.#co!==g||this.#lo[i.viewIndex]!==x.systemUniform_Vertex_UniformBindGroup||this.dirtyLOD)&&this.#So(i),i.numDrawCalls++,be.indexBuffer){const{indexBuffer:g}=be,{indexCount:x,triangleCount:_}=g;i.numTriangles+=_,i.numPoints+=x}else{const{vertexBuffer:g}=be,{vertexCount:x,triangleCount:_}=g;i.numTriangles+=_,i.numPoints+=x}let _=this.#oo;if(it){let i=this.#bo;(i<0||i>=it)&&(i=-1);let g=!1;if(-1===i)et>=tt[0].distanceSquared&&(g=!0);else if(i===it-1)et=_)&&(g=!0)}if(g){let g=-1;for(let i=0;i=tt[i].distanceSquared;i++)g=i;g!==i&&(this.#bo=g,g>=0&&g=0&&i{const{redGPUContext:v}=this,{gpuRenderInfo:b}=this;return b.vertexUniformInfo!==x&&(b.vertexUniformInfo=x,b.vertexStructInfo=g,createMeshVertexUniformBuffers(this)),b.vertexShaderSourceVariant=g.shaderSourceVariant,b.vertexShaderVariantConditionalBlocks=g.conditionalBlocks,b.vertexUniformBindGroup=v.gpuDevice.createBindGroup(getBasicMeshVertexBindGroupDescriptor(this)),this.#In(i),this.gpuRenderInfo.vertexShaderModule};#To(i,g){let x=g-i;for(;x>180;)x-=360;for(;x<-180;)x+=360;return i+x}#Mo=()=>{const{gpuDevice:i,redGPUContext:g}=this,{resourceManager:x}=g;this.#vo.length=0;const _=x.getGPUBindGroupLayout(ResourceManager.PRESET_VERTEX_GPUBindGroupLayout);this.LODManager.LODList.forEach((i,v)=>{const b={code:i.source},y=x.createGPUShaderModule(i.label,b);this.#vo[v]={pipeline:createBasePipeline({vertexStateBuffers:i.geometry.gpuRenderInfo.buffers,primitiveState:this.primitiveState,depthStencilState:this.depthStencilState,geometry:i.geometry,material:i.material||this.material,redGPUContext:g,gpuRenderInfo:this.gpuRenderInfo},y,_),vertexUniformBindGroup:g.gpuDevice.createBindGroup(getBasicMeshVertexBindGroupDescriptor({redGPUContext:g,material:i.material||this.material,gpuRenderInfo:{vertexBindGroupLayout:_,vertexUniformBuffer:this.gpuRenderInfo.vertexUniformBuffer}}))}}),this.#bo=-1};#So(i){const{view:g}=i;this.#oo=this.#wo(g,this._geometry,this._material),this.dirtyLOD&&(this.#Mo(),this.dirtyLOD=!1),this.#uo.length=0,this.LODManager.LODList.forEach((i,x)=>{this.#uo[x]=this.#wo(g,i.geometry,i.material||this._material,x)})}#wo(i,g,x,_=null){const{gpuDevice:v}=this.redGPUContext,{renderViewStateData:b}=i,{vertexBuffer:y,indexBuffer:S}=g,{fragmentUniformBindGroup:w}=x.gpuRenderInfo;this.#Co(g,_);const L=null!==_,k=v.createRenderBundleEncoder({...i.basicRenderBundleEncoderDescriptor,label:this.uuid});L||(this.#so=k,this.#lo[b.viewIndex]=i.systemUniform_Vertex_UniformBindGroup,this.#co=w);const{gpuBuffer:H}=y,z=L?this.#vo[_].pipeline:this.gpuRenderInfo.pipeline,q=L?this.#vo[_].vertexUniformBindGroup:this.gpuRenderInfo.vertexUniformBindGroup;k.setPipeline(z),k.setVertexBuffer(0,H),this.particleBuffers?.length&&this.particleBuffers.forEach((i,g)=>{k.setVertexBuffer(g+1,i)}),k.setBindGroup(0,i.systemUniform_Vertex_UniformBindGroup),k.setBindGroup(1,q),k.setBindGroup(2,w);let W=this.#ho;if(null!==_&&(W=this.#fo[_]),S){const{gpuBuffer:i,format:g}=S;k.setIndexBuffer(i,g),k.drawIndexedIndirect(W.buffer,4*W.commandOffset)}else k.drawIndirect(W.buffer,4*W.commandOffset);const be=k.finish({label:`${this.name}_LOD${_||0}`});return be.mesh=null,be}#yo(){this.#ho||(this.#ho=this.#do.allocateDrawCommand(this.name))}#Co(i,g=null){const{vertexBuffer:x,indexBuffer:_}=i,v=this.#do;let b=this.#ho;if(null!==g&&(this.#fo[g]||(this.#fo[g]=this.#do.allocateDrawCommand(`${this.name}_LOD${g}`)),b=this.#fo[g]),this.#yo(),_){const{indexCount:i}=_;this.particleBuffers?v.setIndexedIndirectCommand(b,i,this.particleNum,0,0,0):v.setIndexedIndirectCommand(b,i,1,0,0,0)}else{const{vertexCount:i}=x;v.setIndirectCommand(b,i,1,0,0)}}#In(i){const{gpuDevice:g,resourceManager:x}=this.redGPUContext,_=this.#En(),v=`${i}_${_}`;let b=x.getGPUShaderModule(v);if(!b){let i=this.gpuRenderInfo.vertexShaderSourceVariant.getVariant(_);if(i)if(this.animationInfo?.skinInfo){const g=`${this.animationInfo.skinInfo.joints.length}`;i=i.replaceAll("#JOINT_NUM",g),this.gpuRenderInfo.vertexShaderSourceVariant.getVariant(_),b=x.createGPUShaderModule(`${v}_${g}`,{code:i})}else b=x.createGPUShaderModule(v,{code:i});else console.warn("⚠️ 버텍스 바리안트 소스를 찾을 수 없음:",_),b=this.gpuRenderInfo.vertexShaderModule}this.gpuRenderInfo.vertexShaderModule=b}#En(){const{vertexShaderVariantConditionalBlocks:i}=this.gpuRenderInfo,g=new Set;for(const x of i)this[x]&&g.add(x);const x=g.size>0?Array.from(g).sort().join("+"):"none";return g.size,x}}Object.defineProperty(Mesh.prototype,"meshType",{value:Gr.MESH,writable:!1}),Er.defineByPreset(Mesh,[Er.PRESET_BOOLEAN.RECEIVE_SHADOW]),Er.defineBoolean(Mesh,[["useDisplacementTexture",!1],["disableJitter",!1]]),Object.freeze(Mesh);const Ii=parseWGSL("#redgpu_include SYSTEM_UNIFORM;\n#redgpu_include calcTintBlendMode;\n#redgpu_include drawPicking;\n#redgpu_include FragmentOutput;\nstruct Uniforms { useDiffuseTexture:u32, opacity:f32, useTint:u32, tint:vec4, tintBlendMode:u32,\n};\n@group(2) @binding(0) var uniforms:Uniforms;\n@group(2) @binding(1) var diffuseTextureSampler:sampler;\n@group(2) @binding(2) var diffuseTexture:texture_2d;\nstruct InputData { @builtin(position) position:vec4, @location(0) vertexPosition:vec3, @location(1) vertexNormal:vec3, @location(2) uv:vec2, @location(11) combinedOpacity:f32, @location(13) shadowPos:vec3, @location(15) @interpolate(flat) pickingId:vec4,\n};\n@fragment\nfn main(inputData:InputData) -> FragmentOutput { var output:FragmentOutput; var finalColor:vec4=textureSample(diffuseTexture,diffuseTextureSampler,inputData.uv); finalColor=vec4(finalColor.rgb/finalColor.a,finalColor.a * uniforms.opacity * inputData.combinedOpacity); #redgpu_if useTint finalColor=calcTintBlendMode(finalColor,uniforms.tintBlendMode,uniforms.tint); #redgpu_endIf if (finalColor.a==0.0) { discard; } output.color=finalColor; output.gBufferMotionVector=vec4( 0.0,0.0,1.0,1.0 ); return output;\n};\n");class TextFieldMaterial extends ABitmapBaseMaterial{dirtyPipeline=!1;constructor(i,g,x){super(i,"TEXT_FILED_MATERIAL",Ii,2),x&&(this.name=x),this.diffuseTexture=g,this.diffuseTextureSampler=new Sampler(this.redGPUContext),this.initGPURenderInfos()}}dr.defineByPreset(TextFieldMaterial,[dr.PRESET_TEXTURE.DIFFUSE_TEXTURE,dr.PRESET_SAMPLER.DIFFUSE_TEXTURE_SAMPLER]),Object.freeze(TextFieldMaterial);const Ei=";box-sizing:content-box;white-space:nowrap;",Di={padding:0,background:"transparent",color:"#fff",fontFamily:"Arial",fontSize:24,fontWeight:"normal",fontStyle:"normal",letterSpacing:0,wordBreak:"keep-all",verticalAlign:"middle",textAlign:"center",borderRadius:0,lineHeight:1.4,border:"",boxShadow:"none",boxSizing:"border-box",filter:""};class ATextField extends Mesh{#Ro;#Po;#Bo;#Io;#Eo;#Do;#Uo;#Lo=!0;#l;#Ao;#Go=!1;#ko=1;#Oo=1;constructor(i,g,x=!0){super(i),this.#l=i,this.#Lo=x,this.#Uo=g,this._material=new TextFieldMaterial(i),this._material.transparent=!0,this._material.diffuseTextureSampler=new Sampler(i,x?{minFilter:v.LINEAR,magFilter:v.LINEAR,mipmapFilter:b.LINEAR}:{minFilter:v.NEAREST,magFilter:v.NEAREST,mipmapFilter:null}),this.depthStencilState.depthWriteEnabled=!1,this.#No(),this.#Vo(),this.#Fo(),this.#Ho(),this.#zo()}get text(){return this.#Do}set text(i){if(this.#Do===i)return;this.#Do=i;const g=this.#Bo.querySelector("foreignObject div"),x=this.#$o(i);this.#Io.innerHTML=x,g.innerHTML=x,this.#Go=!0}render(i){this.#Uo(this.#ko,this.#Oo),this.#Ko(),super.render(i)}#$o(i){return i.toString().replace(/\/gi,"
")}#No(){"undefined"!=typeof OffscreenCanvas?this.#Ro=new OffscreenCanvas(100,100):this.#Ro=document.createElement("canvas"),this.#Po=this.#Ro.getContext("2d")}#Xo(){const i=this.#Io.getBoundingClientRect();const g=i.width+3+3,x=i.height+3+3;return{width:-2&Math.ceil(g),height:-2&Math.ceil(x),extraTop:3,extraRight:3,extraBottom:3,extraLeft:3}}#jo(){const i=this.#Bo,g=i.querySelector("foreignObject"),{width:x,height:_,extraTop:v,extraRight:b,extraBottom:y,extraLeft:S}=this.#Xo();g.setAttribute("width",x.toString()),g.setAttribute("height",_.toString()),g.style.padding=`${v}px ${b}px ${y}px ${S}px`,i.setAttribute("width",x.toString()),i.setAttribute("height",_.toString()),this.#Eo.src="data:image/svg+xml;charset=utf-8,"+encodeURIComponent(i.outerHTML)}#Ho(){this.#Eo=new Image,this.#Eo.style.cssText="position:absolute;bottom:0px;left:0;",this.#Eo.onload=i=>{let g,x;const{width:_,height:v}=this.#Xo(),b=1===window.devicePixelRatio?2:window.devicePixelRatio;g=_*b,x=v*b,this.#Eo.width=_,this.#Eo.height=v,this.#Ro.width=g,this.#Ro.height=x,this.#Ro instanceof OffscreenCanvas||(this.#Ro.style.width=`${_}px`,this.#Ro.style.height=`${v}px`),this.#Po.imageSmoothingEnabled=!0,this.#Po.imageSmoothingQuality="high",this.#Po.clearRect(0,0,g,x),this.#Po.fillStyle="rgba(0,0,0,0)",this.#Po.fillRect(0,0,g,x),this.#Po.drawImage(this.#Eo,0,0,g,x),this.dirtyTransform=!0;const callback=i=>{if(this.material.diffuseTexture){const i=this.material.diffuseTexture.src,g="string"==typeof i&&i?.startsWith?.("blob:");this.material.diffuseTexture.destroy(),this.material.diffuseTexture=null,g&&URL.revokeObjectURL(i)}this.material.diffuseTexture=new BitmapTexture(this.#l,URL.createObjectURL(i),!0,i=>{this.#ko=_,this.#Oo=v},null,null,!0)};this.#Ro instanceof OffscreenCanvas?this.#Ro.convertToBlob({type:"image/png"}).then(callback):this.#Ro.toBlob(callback,"image/png")}}#Ko(){this.#Go&&(this.#Ao&&cancelAnimationFrame(this.#Ao),this.#Ao=requestAnimationFrame(()=>{this.#jo()})),this.#Go=!1}#Yo=(i,g)=>{const x=this.#Bo.querySelector("foreignObject > div").style,_=this.#Io.style,v=`_${i}`;this[v]=g,Object.defineProperty(this,i,{get:()=>this[v],set:g=>{const b=this[v];this[v]=g;const y=(i=>"number"==typeof i)(g)&&(i=>!["lineHeight","fontWeight"].includes(i))(i)?`${g}px`:g;x[i]=y,_[i]=y,b!==g&&(this.#Go=!0)},configurable:!0}),this[i]=g};#Vo(){this.#Io=document.createElement("div"),this.#Io.style.cssText=Ei+";position:absolute;top:200px;left:0;visibility:hidden;text-rendering:optimizeLegibility",document.body.appendChild(this.#Io)}#Fo(){const i=this.#Bo=document.createElementNS("http://www.w3.org/2000/svg","svg");i.setAttribute("xmlns","http://www.w3.org/2000/svg"),i.setAttribute("text-rendering","optimizeLegibility"),i.style.cssText="position:absolute;top:0px;left:0px;z-index:1;margin:0;padding:0;overflow:visible;background:transparent",i.innerHTML=`
`}#zo(){for(const[i,g]of Object.entries(Di))this.#Yo(i,g);this.#Go=!0}}Object.freeze(ATextField);var Ui="#redgpu_include SYSTEM_UNIFORM;\n#redgpu_include getBillboardMatrix;\n#redgpu_include calcBillboard;\n#redgpu_include billboardPicking;\n#redgpu_include billboardShadow;\nstruct MatrixList{ modelMatrix:mat4x4, normalModelMatrix:mat4x4,\n}\nstruct VertexUniforms { pickingId:u32, matrixList:MatrixList, normalModelMatrix:mat4x4, useSizeAttenuation:u32, useBillboard:u32, usePixelSize:u32, pixelSize:f32, _renderRatioX:f32, _renderRatioY:f32, combinedOpacity:f32,\n};\n@group(1) @binding(0) var vertexUniforms:VertexUniforms;\nstruct InputData { @location(0) position:vec3, @location(1) vertexNormal:vec3, @location(2) uv:vec2,\n};\nstruct OutputData { @builtin(position) position:vec4, @location(0) vertexPosition:vec3, @location(1) vertexNormal:vec3, @location(2) uv:vec2, @location(11) combinedOpacity:f32, @location(13) shadowPos:vec3, @location(15) @interpolate(flat) pickingId:vec4,\n};\n@vertex\nfn main(inputData:InputData) -> OutputData { var output:OutputData; let billboardResult=calcBillboard( inputData.position, inputData.vertexNormal, vertexUniforms.matrixList.modelMatrix, systemUniforms.camera.cameraMatrix, systemUniforms.noneJitterProjectionMatrix, systemUniforms.resolution, vertexUniforms.useBillboard, vertexUniforms.usePixelSize, vertexUniforms.pixelSize, vertexUniforms._renderRatioX, vertexUniforms._renderRatioY ); output.position=billboardResult.position; output.vertexPosition=billboardResult.vertexPosition; output.vertexNormal=billboardResult.vertexNormal; output.uv=inputData.uv; output.combinedOpacity=vertexUniforms.combinedOpacity; return output;\n}";const Li=parseWGSL(Ui),Ai=Li.uniforms.vertexUniforms;class TextField3D extends ATextField{#qo=1;#Wo=1;#Zo=1;#Jo=!1;constructor(i,g){super(i,(i,g)=>{i&&g&&(i===this.#qo&&g===this.#Wo||(this.#qo=i,this.#Wo=g,this.gpuRenderInfo&&this.redGPUContext.gpuDevice.queue.writeBuffer(this.gpuRenderInfo.vertexUniformBuffer.gpuBuffer,this.gpuRenderInfo.vertexUniformInfo.members.pixelSize.uniformOffset,new Float32Array([g*window.devicePixelRatio])),this.#Qo()))}),this._geometry=new Plane(i),this.disableJitter=!0,g&&(this.text=g)}get worldSize(){return this.#Zo}set worldSize(i){this.#Zo!==i&&(this.#Zo=i,this.#Qo())}get usePixelSize(){return this.#Jo}get pixelSize(){return this.#Wo}set usePixelSize(i){if(this.gpuRenderInfo){const{vertexUniformBuffer:g,vertexUniformInfo:x}=this.gpuRenderInfo;this.redGPUContext.gpuDevice.queue.writeBuffer(g.gpuBuffer,x.members.usePixelSize.uniformOffset,new Uint32Array([i?1:0])),this.redGPUContext.gpuDevice.queue.writeBuffer(g.gpuBuffer,x.members.pixelSize.uniformOffset,new Float32Array([this.#Wo*window.devicePixelRatio]))}this.#Jo!==i&&(this.#Jo=i,this.#Qo())}#Qo(){if(this.#Wo){const i=this._renderRatioX,g=this._renderRatioY;this.usePixelSize?(this._renderRatioY=1,this._renderRatioX=this.#qo/this.#Wo):(this._renderRatioY=this.#Zo,this._renderRatioX=this.#qo/this.#Wo*this.#Zo),i===this._renderRatioX&&g===this._renderRatioY||(this.dirtyTransform=!0)}}render(i){super.render(i)}get geometry(){return this._geometry}set geometry(i){console.error("TextField3D can not change geometry")}get material(){return this._material}set material(i){console.error("TextField3D can not change material")}createCustomMeshVertexShaderModule=()=>this.createMeshVertexShaderModuleBASIC("VERTEX_MODULE_TEXT_FIELD_3D",Li,Ai,Ui)}Er.definePositiveNumber(TextField3D,[["_renderRatioX",1],["_renderRatioY",1]]),Er.defineByPreset(TextField3D,[[Er.PRESET_BOOLEAN.USE_BILLBOARD,!0]]),Object.freeze(TextField3D);class ADrawDebuggerLight{#l;#eu;#tu;constructor(i,g,x=32){this.#l=i;const _=this.createLightDebugGeometry(i,x);this.#eu=new ColorMaterial(i),this.#eu.color.setColorByRGB(g[0],g[1],g[2]),this.#tu=new Mesh(i,_,this.#eu),this.#tu.primitiveState.cullMode="none",this.#tu.primitiveState.topology=Lr.LINE_LIST}get lightMaterial(){return this.#eu}get lightDebugMesh(){return this.#tu}updateVertexBuffer(i,g){const x=g.data;let _=0;const v=Math.min(i.length,Math.floor(x.length/16));for(let g=0;g.99&&(w=[1,0,0]);const L=[b[1]*w[2]-b[2]*w[1],b[2]*w[0]-b[0]*w[2],b[0]*w[1]-b[1]*w[0]],k=Math.sqrt(L[0]*L[0]+L[1]*L[1]+L[2]*L[2]),H=[L[0]/k,L[1]/k,L[2]/k],z=[H[1]*b[2]-H[2]*b[1],H[2]*b[0]-H[0]*b[2],H[0]*b[1]-H[1]*b[0]],q=[[x,y],[y,[y[0]+-.5*b[0]+H[0]*S,y[1]+-.5*b[1]+H[1]*S,y[2]+-.5*b[2]+H[2]*S]],[y,[y[0]+-.5*b[0]-H[0]*S,y[1]+-.5*b[1]-H[1]*S,y[2]+-.5*b[2]-H[2]*S]],[y,[y[0]+-.5*b[0]+z[0]*S,y[1]+-.5*b[1]+z[1]*S,y[2]+-.5*b[2]+z[2]*S]],[y,[y[0]+-.5*b[0]-z[0]*S,y[1]+-.5*b[1]-z[1]*S,y[2]+-.5*b[2]-z[2]*S]],[[x[0]-.3,x[1],x[2]],[x[0]+.3,x[1],x[2]]],[[x[0],x[1]-.3,x[2]],[x[0],x[1]+.3,x[2]]],[[x[0],x[1],x[2]-.3],[x[0],x[1],x[2]+.3]]];this.updateVertexBuffer(q,g)}}Object.freeze(DrawDebuggerDirectionalLight);class DrawDebuggerPointLight extends ADrawDebuggerLight{#ja;#nu;constructor(i,g){super(i,[0,255,255],51),this.#ja=g,this.#nu=new TextField3D(i),this.#nu.useBillboard=!0,this.#nu.fontSize=40,this.#nu.text="💡",this.lightDebugMesh.addChild(this.#nu)}render(i){i.view.systemUniform_Vertex_UniformBindGroup&&this.#ja.enableDebugger&&(this.#au(this.#ja,this.lightDebugMesh.geometry.vertexBuffer),this.lightDebugMesh.setPosition(0,0,0),this.lightDebugMesh.setRotation(0,0,0),this.lightDebugMesh.setScale(1,1,1),this.lightDebugMesh.render(i),this.#nu.setPosition(...this.#ja.position))}#au(i,g){const x=i.position||[0,0,0],_=i.radius||1,v=16,b=[];for(let i=0;i.99&&(q=[1,0,0]);const W=[L[1]*q[2]-L[2]*q[1],L[2]*q[0]-L[0]*q[2],L[0]*q[1]-L[1]*q[0]],be=Math.sqrt(W[0]*W[0]+W[1]*W[1]+W[2]*W[2]),Ke=[W[0]/be,W[1]/be,W[2]/be],Xe=[Ke[1]*L[2]-Ke[2]*L[1],Ke[2]*L[0]-Ke[0]*L[2],Ke[0]*L[1]-Ke[1]*L[0]],je=16;for(let i=0;iw){const i=S;S=w,w=i}g=Math.max(g,S),x=Math.min(x,w)}return x>=g&&x>=0}intersectTriangle(i,g,x,_=!0){const v=create$3(),b=create$3(),y=create$3(),S=create$3(),w=create$3();subtract$2(v,g,i),subtract$2(b,x,i),cross$2(y,this.direction,b);const L=dot$3(v,y);if(_){if(L<1e-5)return null}else if(L>-1e-5&&L<1e-5)return null;const k=1/L;subtract$2(S,this.origin,i);const H=k*dot$3(S,y);if(H<0||H>1)return null;cross$2(w,S,v);const z=k*dot$3(this.direction,w);if(z<0||H+z>1)return null;const q=k*dot$3(b,w);if(q>1e-5){const i=create$3();return scaleAndAdd$2(i,this.origin,this.direction,q),i}return null}intersectTriangleBarycentric(i,g,x,_=!0){const v=create$3(),b=create$3(),y=create$3(),S=create$3(),w=create$3();subtract$2(v,g,i),subtract$2(b,x,i),cross$2(y,this.direction,b);const L=dot$3(v,y);if(_){if(L<1e-5)return null}else if(L>-1e-5&&L<1e-5)return null;const k=1/L;subtract$2(S,this.origin,i);const H=k*dot$3(S,y);if(H<0||H>1)return null;cross$2(w,S,v);const z=k*dot$3(this.direction,w);if(z<0||H+z>1)return null;const q=k*dot$3(b,w);if(q>1e-5){const i=create$3();return scaleAndAdd$2(i,this.origin,this.direction,q),{point:i,t:q,u:H,v:z}}return null}}class Raycaster3D{ray;near=0;far=1/0;#ou=create$4();#uu=create$4();#lu=create$4();#cu=create$3();#hu=create$3();#Ft;#fu=create();constructor(){this.ray=new Ray}setFromCamera(i,g,x){const{rawCamera:_}=x,v=fromValues$3(_.x,_.y,_.z),b=x.screenToWorld(i,g),y=create$3();subtract$2(y,b,v),normalize$3(y,y),copy$3(this.ray.origin,v),copy$3(this.ray.direction,y),this.#Ft=x;const{pixelRectObject:S}=x,w=i*devicePixelRatio/S.width*2-1,L=-g*devicePixelRatio/S.height*2+1;set(this.#fu,w,L),"nearClipping"in _&&(this.near=_.nearClipping),"farClipping"in _&&(this.far=_.farClipping)}intersectObject(i,g=!0){const x=[];return this.#du(i,g,x),x.sort((i,g)=>i.distance-g.distance)}intersectObjects(i,g=!0){const x=[];for(const _ of i)this.#du(_,g,x);return x.sort((i,g)=>i.distance-g.distance)}#du(i,g,x){const _=i.useBillboard,v=i._renderRatioX||1,b=i._renderRatioY||1;if(_&&this.#Ft){i.usePixelSize?this.#mu(i,x):this.#pu(i,x)}else if(i.geometry){const g=this.#uu;if(copy$4(g,i.modelMatrix),1!==v||1!==b)scale$4(g,g,[v,b,1]),this.#gu(i,g,x,!0);else{const g=i.boundingAABB;this.ray.intersectBox(g)&&this.#gu(i,i.modelMatrix,x,!0)}}if(g&&i.children)for(const _ of i.children)this.#du(_,g,x)}#mu(i,x){const _=this.#Ft,v=i.modelMatrix,b=i.pixelSize;g(i.fontSize);const y=i._renderRatioX||1,S=i._renderRatioY||1,{rawCamera:w,projectionMatrix:L,pixelRectObject:k}=_,H=fromValues$3(v[12],v[13],v[14]),z=transformMat4$2(this.#cu,H,w.modelMatrix),q=transformMat4$1(this.#ou,fromValues$2(z[0],z[1],z[2],1),L);if(q[3]<=0)return;const W=q[0]/q[3],be=q[1]/q[3],Ke=this.#fu[0],Xe=this.#fu[1],je=b*window.devicePixelRatio,Ye=je/k.width*2*(y/S),Ze=je/k.height*2;if(Math.abs(Ke-W)<=.5*Ye&&Math.abs(Xe-be)<=.5*Ze){const g=distance$2(this.ray.origin,H);if(g>=this.near&&g<=this.far){const _=(Ke-W)/Ye+.5,v=(Xe-be)/Ze+.5;x.push({distance:g,point:H,localPoint:fromValues$3(0,0,0),object:i,faceIndex:0,uv:fromValues(_,1-v),ray:this.ray.clone()})}}}#pu(i,g){const x=this.#Ft,_=i.modelMatrix,v=i._renderRatioX||1,b=i._renderRatioY||1,y=invert$1(this.#uu,x.rawCamera.modelMatrix),S=this.#lu;copy$4(S,y),S[12]=_[12],S[13]=_[13],S[14]=_[14];scale$4(S,S,[Math.hypot(_[0],_[1],_[2])*v,Math.hypot(_[4],_[5],_[6])*b,Math.hypot(_[8],_[9],_[10])]),this.#gu(i,S,g,!1)}#gu(i,g,x,_){const v=new Ray;copy$3(v.origin,this.ray.origin),copy$3(v.direction,this.ray.direction);const b=invert$1(this.#ou,g);if(b){v.applyMatrix4(b);const y=i.geometry,S=y.vertexBuffer,w=y.indexBuffer,L=S.data,k=S.interleavedStruct.arrayStride/4;if(w){const b=w.data;for(let y=0;y=this.near&&z<=this.far){const x=fromValues(_[b*v+6],_[b*v+7]),q=fromValues(_[y*v+6],_[y*v+7]),W=fromValues(_[S*v+6],_[S*v+7]),be=create();scaleAndAdd(be,be,x,1-L-k),scaleAndAdd(be,be,q,L),scaleAndAdd(be,be,W,k),w.push({distance:z,point:H,localPoint:i,object:g,faceIndex:Math.floor(b/3),uv:be,ray:this.ray.clone()})}}}}class Raycaster2D{ray;#Ft;#_u=create$3();#ou=create$4();#uu=create$4();#cu=create$3();constructor(){this.ray=new Ray}setFromCamera(i,g,x){this.#Ft=x;const{pixelRectObject:_}=x,v=i*devicePixelRatio/_.width*2-1,b=1-g*devicePixelRatio/_.height*2;set$3(this.#_u,v,b,0);const y=x.screenToWorld(i,g);set$3(this.ray.origin,y[0],y[1],y[2]),set$3(this.ray.direction,0,0,-1)}intersectObject(i,g=!0){const x=[];return this.#du(i,g,x),x.sort((i,g)=>i.distance-g.distance)}intersectObjects(i,g=!0){const x=[];for(const _ of i)this.#du(_,g,x);return x.sort((i,g)=>i.distance-g.distance)}#du(i,g,x){if(i.geometry){const g=this.#Ft,_=g.projectionMatrix,v=g.rawCamera.modelMatrix,b=multiply$4(this.#ou,_,v);multiply$4(b,b,i.modelMatrix);const y=invert$1(this.#uu,b);if(y){const g=transformMat4$2(this.#cu,this.#_u,y);let b=!1,S=1,w=1;if(i.is2DMeshType?(S=i.width,w=i.height,g[0]>=-S/2&&g[0]<=S/2&&g[1]>=-w/2&&g[1]<=w/2&&(b=!0)):g[0]>=-.5&&g[0]<=.5&&g[1]>=-.5&&g[1]<=.5&&(b=!0),b){const b=invert$1(create$4(),multiply$4(create$4(),_,v)),y=transformMat4$2(create$3(),this.#_u,b),L=g[0]/S>g[1]/w?1:0;x.push({distance:0,point:y,localPoint:clone$3(g),object:i,uv:fromValues(g[0]/S+.5,g[1]/w+.5),ray:this.ray.clone(),faceIndex:L})}}}if(g&&i.children)for(const _ of i.children)this.#du(_,g,x)}}class PickingManager{lastMouseEvent;lastMouseClickEvent;#vu;#bu;#yu;#Su;#l;#Ft;#Tu=[];#Mu=0;#wu=0;#Cu;#Ru;#N=0;#Pu=new Raycaster3D;#Bu=new Raycaster2D;get videoMemorySize(){return this.#N}get mouseX(){return this.#Mu}set mouseX(i){this.#Mu=i}get mouseY(){return this.#wu}set mouseY(i){this.#wu=i}get castingList(){return this.#Tu}get pickingGPUTexture(){return this.#yu}get pickingGPUTextureView(){return this.#Su}get pickingDepthGPUTextureView(){return this.#bu}resetCastingList(){this.#Tu.length=0}destroy(){this.#yu&&(this.#yu.destroy(),this.#vu.destroy(),this.#yu=null,this.#Su=null,this.#vu=null,this.#bu=null)}checkTexture(i){const{redGPUContext:g}=i,{resourceManager:x}=g;this.#Ft=i,this.#l=g,this.#yu?.width===this.#Ft.pixelRectObject.width&&this.#yu?.height===this.#Ft.pixelRectObject.height||(this.destroy(),this.#yu=this.#Iu("picking",navigator.gpu.getPreferredCanvasFormat()),this.#Su=x.getGPUResourceBitmapTextureView(this.#yu),this.#vu=this.#Iu("pickingDepth","depth32float"),this.#bu=x.getGPUResourceBitmapTextureView(this.#vu),this.#mr())}checkEvents(i,g){this.castingList.length&&(this.#Eu(i,g),this.resetCastingList())}#mr(){const i=this.#yu;if(!i)return 0;this.#N=calculateTextureByteSize(i)+calculateTextureByteSize(this.#vu)}#Iu(i,g){const{resourceManager:x}=this.#l;return x.createManagedTexture({size:[this.#Ft.pixelRectObject.width,this.#Ft.pixelRectObject.height,1],usage:GPUTextureUsage.RENDER_ATTACHMENT|GPUTextureUsage.TEXTURE_BINDING|GPUTextureUsage.COPY_SRC,format:g,sampleCount:1,label:`${this.#Ft.name}_${i}_${this.#Ft.pixelRectObject.width}x${this.#Ft.pixelRectObject.height}`})}#Eu=async(i,g,x=1,_=1)=>{const{gpuDevice:v}=i.redGPUContext,{pixelRectArray:b}=i,y=this.#Mu,S=this.#wu;if(y<=0||y>=b[2]||S<=0||S>=b[3])return;const w=this.#Du();let L=this.#Uu(v,x,_,y,S);const k=await this.#Lu(L);L.destroy(),L=null,k?(this.#Au(k,y,S,g,w),this.#Gu(k,y,S,g,w)):this.#ku(),this.lastMouseEvent=null,this.lastMouseClickEvent=null};#Du=()=>this.#Tu.reduce((i,g)=>(i[g.pickingId]=g,i),{});#Uu=(i,g,x,_,v)=>{const b=i.createCommandEncoder({label:"PickingManager_ReadPixel_CommandEncoder"}),y=i.createBuffer({size:4,usage:GPUBufferUsage.COPY_DST|GPUBufferUsage.MAP_READ,label:"readPixelBuffer"}),S={texture:this.#yu,origin:{x:_,y:v,z:0}},w={buffer:y,bytesPerRow:256,rowsPerImage:1};return b.copyTextureToBuffer(S,w,{width:1,height:1,depthOrArrayLayers:1}),i.queue.submit([b.finish()]),y};#Ou(i,g,x,_,v,b,y){const S="Camera2D"===this.#Ft.rawCamera.constructor.name?this.#Bu:this.#Pu;let w;if(S.setFromCamera(this.#Mu/devicePixelRatio,this.#wu/devicePixelRatio,this.#Ft),_){w=S.intersectObject(_)[0]}const L=new PickingEvent(i,g,x,_,v,b,y,w);return L.ray||(L.ray=S.ray.clone()),L}#Au=(g,x,_,v,b)=>{const y=b[g],S=this.lastMouseClickEvent?.type;if(S===i.CLICK){const i=this.#Ou(g,x,_,y,v,S,this.lastMouseClickEvent);this.#Nu(S,i)}};#Gu=(g,x,_,v,b)=>{const y=b[g],S=this.lastMouseEvent?.type;if(S){const b=this.#Ou(g,x,_,y,v,S,this.lastMouseEvent);switch(this.#Cu&&(b.movementX=x-this.#Cu.mouseX,b.movementY=_-this.#Cu.mouseY),S){case i.DOWN:case i.UP:this.#Nu(S,b);break;case i.MOVE:this.#Vu(g,y,b)}this.#Cu=b}};#Vu=(g,x,_)=>{const v=this.#Cu?.pickingId;v!==g?(this.#Cu&&v&&v!==g&&this.#ku(),this.#Ru!==x&&(this.#Nu(i.OVER,_),document.body.style.cursor="pointer"),this.#Ru=x):this.#Nu(i.MOVE,_)};#ku=()=>{this.#Cu&&this.#Nu(i.OUT,this.#Cu),this.#Cu=null,this.#Ru=null,document.body.style.cursor="default"};async#Lu(i){await i.mapAsync(GPUMapMode.READ);const g=new DataView(i.getMappedRange()),x="rgba8unorm"==this.#yu.format?[0,1,2,3]:[2,1,0,3],_=g.getUint8(x[0]),v=g.getUint8(x[1]),b=g.getUint8(x[2]);return(g.getUint8(x[3])<<24|b<<16|v<<8|_)>>>0}#Nu(i,g){g.target&&g.target.events[i]&&g.target.events[i](g)}}Object.freeze(PickingManager);class FXAA extends ASinglePassPostEffect{#Fu=.75;#Hu=.166;#zu=.0833;constructor(i){super(i);this.init(i,"POST_EFFECT_FXAA",createBasicPostEffectCode(this,"\nlet index=vec2(global_id.xy);\nlet dims=textureDimensions(sourceTexture);\nlet i_index=vec2(index);\n\n//1. 현재 픽셀 및 주변 4방향 루마(Luma) 및 알파 샘플링\nlet colorM4=textureLoad(sourceTexture,index);\nlet colorM=colorM4.rgb;\nlet lumaM=getLuma(colorM);\n\nlet colorN4=fetchColor4(i_index + vec2(0,-1),dims);\nlet colorS4=fetchColor4(i_index + vec2(0,1),dims);\nlet colorW4=fetchColor4(i_index + vec2(-1,0),dims);\nlet colorE4=fetchColor4(i_index + vec2(1,0),dims);\n\nlet lumaN=getLuma(colorN4.rgb);\nlet lumaS=getLuma(colorS4.rgb);\nlet lumaW=getLuma(colorW4.rgb);\nlet lumaE=getLuma(colorE4.rgb);\n\n//2. 로컬 대비(Contrast) 분석을 통한 조기 종료 결정\nlet lumaMin=min(lumaM,min(min(lumaN,lumaS),min(lumaW,lumaE)));\nlet lumaMax=max(lumaM,max(max(lumaN,lumaS),max(lumaW,lumaE)));\nlet range=lumaMax - lumaMin;\n\nif (range < max(uniforms.edgeThresholdMin,lumaMax * uniforms.edgeThreshold)) { textureStore(outputTexture,index,colorM4); return;\n}\n\n//3. 대각선 루마 샘플링 (3x3 영역 완성)\nlet lumaNW=getLuma(fetchColor4(i_index + vec2(-1,-1),dims).rgb);\nlet lumaNE=getLuma(fetchColor4(i_index + vec2(1,-1),dims).rgb);\nlet lumaSW=getLuma(fetchColor4(i_index + vec2(-1,1),dims).rgb);\nlet lumaSE=getLuma(fetchColor4(i_index + vec2(1,1),dims).rgb);\n\n//4. 엣지 방향 판단 (수직 vs 수평)\nlet edgeVer=abs(lumaNW + lumaSW - 2.0 * lumaW) + abs(lumaN + lumaS - 2.0 * lumaM) * 2.0 + abs(lumaNE + lumaSE - 2.0 * lumaE);\nlet edgeHor=abs(lumaNW + lumaNE - 2.0 * lumaN) + abs(lumaW + lumaE - 2.0 * lumaM) * 2.0 + abs(lumaSW + lumaSE - 2.0 * lumaS);\nlet isHorizontal=edgeHor >=edgeVer;\n\n//5. 엣지 방향에 따른 기울기 및 오프셋 설정\nlet luma1=select(lumaW,lumaN,isHorizontal);\nlet luma2=select(lumaE,lumaS,isHorizontal);\nlet gradient1=luma1 - lumaM;\nlet gradient2=luma2 - lumaM;\nlet is1Steeper=abs(gradient1) >=abs(gradient2);\nlet gradientScaled=0.25 * max(abs(gradient1),abs(gradient2));\n\nvar lumaLocalAverage=0.0;\nvar edgeStep=vec2(0,0);\nif (is1Steeper) { edgeStep=select(vec2(-1,0),vec2(0,-1),isHorizontal); lumaLocalAverage=0.5 * (luma1 + lumaM);\n} else { edgeStep=select(vec2(1,0),vec2(0,1),isHorizontal); lumaLocalAverage=0.5 * (luma2 + lumaM);\n}\n\n//6. 언리얼급 품질을 위한 엣지 탐색 루프 (Edge Search Iteration)\nvar posP=i_index + edgeStep;\nvar posN=i_index + edgeStep;\nlet searchStep=select(vec2(1,0),vec2(0,1),isHorizontal);\n\nvar doneP=false;\nvar doneN=false;\nfor (var i=0;i < 10;i++) { if (!doneP) { if (abs(getLuma(fetchColor4(posP,dims).rgb) - lumaLocalAverage) >=gradientScaled) { doneP=true;} else { posP +=searchStep;} } if (!doneN) { if (abs(getLuma(fetchColor4(posN,dims).rgb) - lumaLocalAverage) >=gradientScaled) { doneN=true;} else { posN -=searchStep;} } if (doneP && doneN) { break;}\n}\n\n//7. 탐색된 끝점까지의 거리를 기반으로 한 엣지 블렌딩 계산\nlet distP=select(f32(posP.x - i_index.x),f32(posP.y - i_index.y),isHorizontal);\nlet distN=select(f32(i_index.x - posN.x),f32(i_index.y - posN.y),isHorizontal);\nlet distMin=min(abs(distP),abs(distN));\nlet edgeBlend=saturate(0.5 - distMin/(abs(distP) + abs(distN)));\n\n//8. 서브픽셀 필터링 (고주파 노이즈 제거용)\nlet lumaL=(lumaN + lumaS + lumaW + lumaE) * 2.0;\nlet lumaCorners=lumaNW + lumaNE + lumaSW + lumaSE;\nlet subpixFilter=saturate(abs((lumaL + lumaCorners)/12.0 - lumaM)/range);\nlet subpixBlend=smoothstep(0.0,1.0,subpixFilter) * uniforms.subpix;\n\n//9. 최종 블렌딩 및 알파 채널 보존 합성\nlet finalBlend=max(edgeBlend,subpixBlend);\nlet colorTarget4=fetchColor4(i_index + edgeStep,dims);\n\n//RGBA 전체를 보간하여 투명도 유지\nlet finalColor4=mix(colorM4,colorTarget4,finalBlend);\n\ntextureStore(outputTexture,index,finalColor4);\n","\nstruct Uniforms { subpix:f32, edgeThreshold:f32, edgeThresholdMin:f32, padding:f32\n};\n\nfn getLuma(rgb:vec3) -> f32 { return dot(rgb,vec3(0.299,0.587,0.114));\n}\n\nfn fetchColor4(pos:vec2,dims:vec2) -> vec4 { let p=vec2(clamp(vec2(pos),vec2(0),dims - 1)); return textureLoad(sourceTexture,p);\n}\n")),this.subpix=this.#Fu,this.edgeThreshold=this.#Hu,this.edgeThresholdMin=this.#zu}get subpix(){return this.#Fu}set subpix(i){validateNumberRange(i,0,1),this.#Fu=i,this.updateUniform("subpix",i)}get edgeThreshold(){return this.#Hu}set edgeThreshold(i){validateNumberRange(i,1e-4,.25),this.#Hu=i,this.updateUniform("edgeThreshold",i)}get edgeThresholdMin(){return this.#zu}set edgeThresholdMin(i){validateNumberRange(i,1e-5,.1),this.#zu=i,this.updateUniform("edgeThresholdMin",i)}}Object.freeze(FXAA);class TAA{#l;#sr;#An;#Gn;#kn;#On;#Kn;#Xn;#jn;#Yn;#qn;#h;#Wn;#Zn;#Jn;#$u=new Map;#Ku=new Map;#Xu=new Map;#ju=null;#Yu;#qu;#Wu;#Zu;#Ju;#Qu;#tr=8;#nr=8;#rr=1;#or=[];#N=0;#el=0;#tl=.5;#ur;#lr;#nl=[0,0];#rl=create$4();constructor(i){this.#l=i,this.#sr=i.antialiasingManager;const g=this.#il();this.#ne(i,"POST_EFFECT_TAA",{msaa:g.msaa,nonMsaa:g.nonMsaa}),this.jitterStrength=this.#tl}get prevNoneJitterProjectionCameraMatrix(){return this.#rl}get frameIndex(){return this.#el}get videoMemorySize(){return this.#N}get jitterStrength(){return this.#tl}set jitterStrength(i){this.#tl=i}render(i,g,x,_){const v=_.textureView;_.texture;const{gpuDevice:b,antialiasingManager:y}=this.#l,{useMSAA:S,msaaID:w}=y;this.#el++,this.#Xn&&(this.updateUniform("frameIndex",this.#el),this.updateUniform("currJitterOffset",i.jitterOffset),this.updateUniform("prevJitterOffset",this.#nl),copy$4(this.#rl,i.noneJitterProjectionCameraMatrix),this.#nl=[...i.jitterOffset]);const L=this.#cr(i),k=this.#ur!==S||this.#lr!==w,H=this.#hr([v]);(L||k||H)&&this.#al(i,[v],S,this.#l,b),this.#sl(b,g,x);{const i=b.createCommandEncoder({label:"TAA_CopyTexture_CommandEncoder_compute"});i.copyTextureToTexture({texture:this.#Yu},{texture:this.#Wu},[g,x,1]),b.queue.submit([i.finish()])}return this.#el<=20||this.#el,this.#ur=S,this.#lr=w,{texture:this.#Yu,textureView:this.#qu}}clear(){this.#Wu&&(this.#Wu.destroy(),this.#Wu=null,this.#Zu=null),this.#Yu&&(this.#Yu.destroy(),this.#Yu=null,this.#qu=null),this.#$u.clear(),this.#Ku.clear(),this.#Xu.clear(),this.#ju=null}updateUniform(i,g){this.#Xn.writeOnlyBuffer(this.#jn.members[i],g)}#il(){const createCode=i=>` \nstruct Uniforms { frameIndex:f32, currJitterOffset:vec2, prevJitterOffset:vec2,\n};\nstruct NeighborhoodStats { minColor:vec3, maxColor:vec3, mean:vec3, stdDev:vec3, minAlpha:f32, maxAlpha:f32, meanAlpha:f32,\n};\nstruct SampledColor { rgb:vec3, ycocg:vec3, alpha:f32,\n};\nfn rgb_to_ycocg(rgb:vec3) -> vec3 { let y=dot(rgb,vec3(0.25,0.5,0.25)); let co=dot(rgb,vec3(0.5,0.0,-0.5)); let cg=dot(rgb,vec3(-0.25,0.5,-0.25)); return vec3(y,co,cg);\n}\nfn ycocg_to_rgb(ycocg:vec3) -> vec3 { let y=ycocg.x; let co=ycocg.y; let cg=ycocg.z; return vec3(y + co - cg,y + cg,y - co - cg);\n}\nfn get_depth_confidence(currDepth:f32,prevDepth:f32) -> f32 { let depthDiff=abs(currDepth - prevDepth); return 1.0 - clamp((depthDiff - 0.01)/0.02,0.0,1.0);\n}\nfn fetch_depth_bilinear(tex:texture_depth_2d,uv:vec2,screenSize:vec2) -> f32 { let samplePos=uv * screenSize - 0.5; let f=fract(samplePos); let base=vec2(floor(samplePos)); let size=vec2(textureDimensions(tex)); let d00=textureLoad(tex,clamp(base + vec2(0,0),vec2(0),size - 1),0); let d10=textureLoad(tex,clamp(base + vec2(1,0),vec2(0),size - 1),0); let d01=textureLoad(tex,clamp(base + vec2(0,1),vec2(0),size - 1),0); let d11=textureLoad(tex,clamp(base + vec2(1,1),vec2(0),size - 1),0); return mix(mix(d00,d10,f.x),mix(d01,d11,f.x),f.y);\n}\nfn calculate_neighborhood_stats_ycocg(pixelCoord:vec2,screenSizeU:vec2) -> NeighborhoodStats { let screenSize=vec2(screenSizeU); var m1=vec3(0.0); var m2=vec3(0.0); var m1A=0.0; var minC=vec3(1e5); var maxC=vec3(-1e5); var minA=1e5; var maxA=-1e5; for (var y:i32=-1;y <=1;y++) { for (var x:i32=-1;x <=1;x++) { let sampleCoord=clamp(pixelCoord + vec2(x,y),vec2(0),vec2(screenSizeU) - 1); let colorRGBA=textureLoad(sourceTexture,sampleCoord,0); let colorYCoCg=rgb_to_ycocg(colorRGBA.rgb); let alpha=colorRGBA.a; m1 +=colorYCoCg; m2 +=colorYCoCg * colorYCoCg; m1A +=alpha; minC=min(minC,colorYCoCg); maxC=max(maxC,colorYCoCg); minA=min(minA,alpha); maxA=max(maxA,alpha); } } let sampleCount=9.0; var stats:NeighborhoodStats; stats.mean=m1/sampleCount; stats.stdDev=sqrt(max((m2/sampleCount) - (stats.mean * stats.mean),vec3(0.0))); stats.minColor=minC; stats.maxColor=maxC; stats.minAlpha=minA; stats.maxAlpha=maxA; stats.meanAlpha=m1A/sampleCount; return stats;\n}\nfn get_color_discrepancy_weight(stats:NeighborhoodStats,histYCoCg:vec3) -> f32 { let diff=abs(stats.mean.x - histYCoCg.x); let threshold=max(stats.stdDev.x * 0.45,0.01); return smoothstep(threshold,threshold * 2.0,diff);\n}\nfn sample_texture_catmull_rom_antiflicker(tex:texture_2d,smp:sampler,uv:vec2,texSize:vec2) -> SampledColor { let samplePos=uv * texSize; let texPos1=floor(samplePos - 0.5) + 0.5; let f=samplePos - texPos1; let w0=f * (-0.5 + f * (1.0 - 0.5 * f)); let w1=1.0 + f * f * (-2.5 + 1.5 * f); let w2=f * (0.5 + f * (2.0 - 1.5 * f)); let w3=f * f * (-0.5 + 0.5 * f); let w12=w1 + w2; let offset12=w2/w12; let invTexSize=1.0/texSize; let coords=array,5>( (texPos1 + vec2(offset12.x,-1.0)) * invTexSize, (texPos1 + vec2(-1.0,offset12.y)) * invTexSize, (texPos1 + offset12) * invTexSize, (texPos1 + vec2(2.0,offset12.y)) * invTexSize, (texPos1 + vec2(offset12.x,2.0)) * invTexSize ); let weights=array( w12.x * w0.y,w0.x * w12.y,w12.x * w12.y,w3.x * w12.y,w12.x * w3.y ); var sumRGB=vec3(0.0); var sumYCoCg=vec3(0.0); var sumAlpha=0.0; var sumW=0.0; for(var i=0;i < 5;i++) { let sampleRGBA=textureSampleLevel(tex,smp,coords[i],0.0); let sampleRGB=max(sampleRGBA.rgb,vec3(0.0)); let sampleYCoCg=rgb_to_ycocg(sampleRGB); let w=weights[i] * (1.0/(1.0 + sampleYCoCg.x)); sumRGB +=sampleRGB * w; sumYCoCg +=sampleYCoCg * w; sumAlpha +=sampleRGBA.a * w; sumW +=w; } var result:SampledColor; let invSumW=1.0/max(sumW,0.0001); result.rgb=sumRGB * invSumW; result.ycocg=sumYCoCg * invSumW; result.alpha=sumAlpha * invSumW; return result;\n}\nfn clip_history_ycocg(historyYCoCg:vec3,stats:NeighborhoodStats,motion:f32) -> vec3 { let gamma=mix(0.2,0.7,motion); let v_min=min(stats.minColor,stats.mean - stats.stdDev * gamma); let v_max=max(stats.maxColor,stats.mean + stats.stdDev * gamma); return clamp(historyYCoCg,v_min,v_max);\n}\n @group(0) @binding(0) var sourceTexture:texture_2d; @group(0) @binding(1) var historyTexture:texture_2d; @group(0) @binding(2) var motionVectorTexture:texture_2d; @group(0) @binding(3) var taaTextureSampler:sampler; @group(0) @binding(4) var depthTexture:texture_depth_2d; @group(0) @binding(5) var historyDepthTexture:texture_depth_2d; @group(1) @binding(0) var outputTexture:texture_storage_2d; ${tr} @group(1) @binding(2) var uniforms:Uniforms; @compute @workgroup_size(${this.#tr},${this.#nr},${this.#rr}) fn main(@builtin(global_invocation_id) global_id:vec3) { { let pixelCoord=vec2(global_id.xy); let screenSizeU=textureDimensions(sourceTexture); let screenSize=vec2(screenSizeU); let yFlipVec2=vec2(1.0,-1.0); if (any(pixelCoord >=vec2(screenSizeU))) { return; } let currentUV=(vec2(pixelCoord) + 0.5 - uniforms.currJitterOffset * yFlipVec2)/screenSize; let stats=calculate_neighborhood_stats_ycocg(pixelCoord,screenSizeU); let currentRGBA=textureSampleLevel(sourceTexture,taaTextureSampler,currentUV,0.0); let currentRGB=currentRGBA.rgb; let currentAlpha=currentRGBA.a; let currentYCoCg=rgb_to_ycocg(currentRGB); let currentDepth=textureLoad(depthTexture,pixelCoord,0); var closestDepth=1.0; var closestCoord=pixelCoord; for(var y:i32=-1;y <=1;y++) { for(var x:i32=-1;x <=1;x++) { let sc=clamp(pixelCoord + vec2(x,y),vec2(0),vec2(screenSizeU) - 1); let d=textureLoad(depthTexture,sc,0); if(d < closestDepth) { closestDepth=d; closestCoord=sc; } } } let motionData=textureLoad(motionVectorTexture,closestCoord,0); let velocity=motionData.xy; let jitterDisabled=motionData.z > 0.5; if (jitterDisabled) { textureStore(outputTexture,pixelCoord,vec4(currentRGB,currentAlpha)); return; } let historyUV=(vec2(pixelCoord) + 0.5 - uniforms.currJitterOffset * yFlipVec2 + uniforms.prevJitterOffset * yFlipVec2)/screenSize - velocity; var finalRGB:vec3; var finalAlpha:f32; if (any(historyUV < vec2(0.0)) || any(historyUV > vec2(1.0))) { finalRGB=currentRGB; finalAlpha=currentAlpha; } else { let prevDepth=fetch_depth_bilinear(historyDepthTexture,historyUV,screenSize); let historyData=sample_texture_catmull_rom_antiflicker(historyTexture,taaTextureSampler,historyUV,screenSize); let motionLen=length(velocity * screenSize); let motionSoft=smoothstep(0.0,1.0,motionLen); let clippedYCoCg=clip_history_ycocg(historyData.ycocg,stats,motionSoft); let clippedAlpha=clamp(historyData.alpha,stats.minAlpha,stats.maxAlpha); let clippedHistoryRGB=ycocg_to_rgb(clippedYCoCg); let lumaWeight=get_color_discrepancy_weight(stats,clippedYCoCg); var blendFactor=mix(0.08,0.4,motionSoft); let depthConfidence=get_depth_confidence(currentDepth,prevDepth); blendFactor=max(blendFactor,1.0 - depthConfidence * depthConfidence); blendFactor=max(blendFactor,lumaWeight * 0.5); let currentRGBA=vec4(currentRGB,currentAlpha); let clippedHistoryRGBA=vec4(clippedHistoryRGB,clippedAlpha); let finalRGBA=mix(clippedHistoryRGBA,currentRGBA,blendFactor); finalRGB=finalRGBA.rgb; finalAlpha=finalRGBA.a; } textureStore(outputTexture,pixelCoord,vec4(finalRGB,finalAlpha));\n} } `;return{msaa:createCode(),nonMsaa:createCode()}}#ne(i,g,x){this.#h=g;const{resourceManager:_}=i;this.#An=_.createGPUShaderModule(`${g}_MSAA`,{code:x.msaa}),this.#Gn=_.createGPUShaderModule(`${g}_NonMSAA`,{code:x.nonMsaa}),this.#Wn=parseWGSL(x.msaa),this.#Zn=parseWGSL(x.nonMsaa);const v=this.#Wn.storage,b=this.#Wn.uniforms;if(this.#qn=v,this.#jn=b.uniforms,this.#Yn=b.systemUniforms,this.#jn){const g=new ArrayBuffer(this.#jn.arrayBufferByteLength);this.#Xn=new UniformBuffer(i,g,"TAA_UniformBuffer")}}#sl(i,g,x){const _=i.createCommandEncoder({label:"TAA_Execute_CommandEncoder_compute"}),v=_.beginComputePass();v.setPipeline(this.#Kn),v.setBindGroup(0,this.#Ju),v.setBindGroup(1,this.#Qu),v.dispatchWorkgroups(Math.ceil(g/this.#tr),Math.ceil(x/this.#nr)),v.end(),i.queue.submit([_.finish()])}#al(i,g,x,_,v){const b=[],y=[];b.push({binding:0,resource:g[0]}),b.push({binding:1,resource:this.#Zu}),b.push({binding:4,resource:i.viewRenderTextureManager.depthTextureView}),b.push({binding:5,resource:i.viewRenderTextureManager.prevDepthTextureView});const S=x?i.viewRenderTextureManager.gBufferMotionVectorResolveTextureView:i.viewRenderTextureManager.gBufferMotionVectorTextureView;b.push({binding:2,resource:S}),b.push({binding:3,resource:i.redGPUContext.resourceManager.basicSampler.gpuSampler}),y.push({binding:0,resource:this.#qu}),this.#Yn&&y.push({binding:this.#Yn.binding,resource:{buffer:i.postEffectManager.postEffectSystemUniformBuffer.gpuBuffer,offset:0,size:i.postEffectManager.postEffectSystemUniformBuffer.size}}),this.#Xn&&this.#jn&&y.push({binding:this.#jn.binding,resource:{buffer:this.#Xn.gpuBuffer,offset:0,size:this.#Xn.size}}),this.#fr(b,y,x,_,v),this.#ol(x,_,v)}#fr(i,g,x,_,v){const b=x?this.#Wn:this.#Zn,y=`${this.#h}_BIND_GROUP_LAYOUT_0_USE_MSAA_${x}`,S=`${this.#h}_BIND_GROUP_LAYOUT_1_USE_MSAA_${x}`;if(!this.#$u.has(y)){const i=_.resourceManager.getGPUBindGroupLayout(y)||_.resourceManager.createBindGroupLayout(y,getComputeBindGroupLayoutDescriptorFromShaderInfo(b,0,x));this.#$u.set(y,i)}if(!this.#$u.has(S)){const i=_.resourceManager.getGPUBindGroupLayout(S)||_.resourceManager.createBindGroupLayout(S,getComputeBindGroupLayoutDescriptorFromShaderInfo(b,1,x));this.#$u.set(S,i)}this.#kn=this.#$u.get(y),this.#On=this.#$u.get(S),this.#Ju=v.createBindGroup({label:`${this.#h}_FRAME_BIND_GROUP_0_USE_MSAA_${x}`,layout:this.#kn,entries:i}),this.#Qu=v.createBindGroup({label:`${this.#h}_FRAME_BIND_GROUP_1_USE_MSAA_${x}`,layout:this.#On,entries:g})}#ol(i,g,x){const _=`${this.#h}_COMPUTE_PIPELINE_USE_MSAA_${i}`,v=`${this.#h}_PIPELINE_LAYOUT_USE_MSAA_${i}`;if(this.#ju!==i||!this.#Xu.has(_)){if(!this.#Ku.has(v)){const g=x.createPipelineLayout({label:`${this.#h}_PIPELINE_LAYOUT_USE_MSAA_${i}`,bindGroupLayouts:[this.#kn,this.#On]});this.#Ku.set(v,g)}const g=i?this.#An:this.#Gn,b=x.createComputePipeline({label:_,layout:this.#Ku.get(v),compute:{module:g,entryPoint:"main"}});this.#Xu.set(_,b),this.#ju=i}this.#Kn=this.#Xu.get(_)}#cr(i){const{redGPUContext:x,viewRenderTextureManager:_,name:v}=i,{gBufferColorTexture:b}=_,{resourceManager:y}=x,{width:S,height:w}=b,L=S!==this.#Jn?.width||w!==this.#Jn?.height||!this.#Yu||!this.#Wu||!this.#Yu;return L&&(g(`TAA 텍스처 재생성:${S}x${w},이전 프레임 히스토리 리셋`),this.#el=0,this.clear(),this.#Yu=y.createManagedTexture({size:{width:S,height:w},format:"rgba16float",usage:GPUTextureUsage.TEXTURE_BINDING|GPUTextureUsage.STORAGE_BINDING|GPUTextureUsage.COPY_SRC|GPUTextureUsage.RENDER_ATTACHMENT,label:`${v}_${this.#h}_currentFrame_${S}x${w}`}),this.#qu=y.getGPUResourceBitmapTextureView(this.#Yu,{dimension:"2d",format:"rgba16float",label:`${this.#h}_currentFrame_View`}),this.#Wu=y.createManagedTexture({size:{width:S,height:w},format:"rgba16float",usage:GPUTextureUsage.TEXTURE_BINDING|GPUTextureUsage.STORAGE_BINDING|GPUTextureUsage.COPY_DST,label:`${v}_${this.#h}_previousFrame_${S}x${w}`}),this.#Zu=y.getGPUResourceBitmapTextureView(this.#Wu,{dimension:"2d",format:"rgba16float",label:`${this.#h}_previousFrame`})),this.#Jn={width:S,height:w},this.#mr(),L}#mr(){this.#N=0,this.#Yu&&(this.#N+=calculateTextureByteSize(this.#Yu)),this.#Wu&&(this.#N+=calculateTextureByteSize(this.#Wu))}#hr(i){if(!this.#or||this.#or.length!==i.length)return this.#or=[...i],!0;for(let g=0;g{const{rawCamera:_,pixelRectArray:v}=x;return Gi=2*(i*window.devicePixelRatio+v[0])/v[2]-1,ki=-2*(g*window.devicePixelRatio+v[1])/v[3]+1,Oi=1,multiply$4($i,x.noneJitterProjectionMatrix,_.modelMatrix),Fi=clone$4($i),invert$1(Fi,Fi),Hi=fromValues$3(Gi,ki,1),identity$1(zi),translate(zi,zi,Hi),multiply$4(Fi,Fi,zi),Hi[0]=Fi[12],Hi[1]=Fi[13],Hi[2]=Fi[14],Ni=$i[12]*Gi+$i[13]*ki+$i[15],0!==Ni&&(Vi=1/Ni,Hi[0]/=Vi,Hi[1]/=Vi,Hi[2]/=Vi,Hi[0]=Hi[0]+_.x,Hi[1]=Hi[1]+_.y,Hi[2]=Hi[2]+_.z),[Hi[0],Hi[1],Hi[2]]};class Box extends Primitive{#Ii=function(){let i,g;return g=function(g,x,_,v,b,y,S,w,L,k,H,z,q){let W,be,Ke=w/H,Xe=L/z,je=w/2,Ye=L/2,Ze=k/2,Je=H+1,Qe=z+1,et=0,tt=[];for(be=0;be0?1:-1,g.push(tt.x,tt.y,tt.z),g.push(W/H*q,be/z*q),et+=1}}for(be=0;be0&&g(!0),b>0&&g(!1)),createPrimitiveGeometry(_,z,q,x)}}();constructor(i,g=1,x=1,_=1,v=8,b=8,y=!1,S=0,w=2*Math.PI){super(i);const L=`PRIMITIVE_CYLINDER_RT${g}_RB${x}_H${_}_RS${v}_HS${b}_TS${y}_TS${S}_TL${w}`,k=i.resourceManager.cachedBufferState;let H=k[L];H||(H=k[L]=this.#Ii(L,i,g,x,_,v,b,y,S,w)),this._setData(H)}}class Sphere extends Primitive{#Ii=function(){let i,g,x,_,v,b,y,S,w=[];const L=new Float32Array(3),k=new Float32Array(3);return function(H,z,q,W,be,Ke,Xe,je,Ye,Ze){i=je+Ye,_=0,w.length=0;const Je=[],Qe=[];for(x=0;x<=be;x++){const i=[],v=x/be;for(g=0;g<=W;g++){const x=g/W;L[0]=-q*Math.cos(Ke+x*Xe)*Math.sin(je+v*Ye),L[1]=q*Math.cos(je+v*Ye),L[2]=q*Math.sin(Ke+x*Xe)*Math.sin(je+v*Ye),Je.push(L[0],L[1],L[2]),k[0]=L[0],k[1]=L[1],k[2]=L[2],normalize$3(k,k),Je.push(k[0],k[1],k[2]),Je.push(x*Ze,v*Ze),i.push(_++)}w.push(i)}for(x=0;x0)&&Qe.push(v,b,S),(x!==be-1||i0&&(this.#xl=y/L,this.#_l=S/L,this.#vl=w/L)}}Object.freeze(SpotLight);class LightManager{#Sl=3;#Tl=q.MAX_CLUSTER_LIGHTS;#Ml=[];#wl=[];#Cl=[];#Rl;#Pl=create$4();get spotLights(){return this.#Cl}get spotLightCount(){return this.#Cl.length}get limitClusterLightCount(){return this.#Tl}get pointLights(){return this.#wl}get pointLightCount(){return this.#wl.length}get limitDirectionalLightCount(){return this.#Sl}get directionalLightCount(){return this.#Ml.length}get directionalLights(){return this.#Ml}get ambientLight(){return this.#Rl}set ambientLight(i){i instanceof AmbientLight||consoleAndThrowError("allow only AmbientLight instance"),this.#Rl=i}addSpotLight(i){i instanceof SpotLight||consoleAndThrowError("allow only SpotLight instance");this.#Cl.length+this.#wl.length>this.#Tl&&consoleAndThrowError("Cannot add more cluster lights. The limit has been reached."),this.#Cl.push(i)}addPointLight(i){i instanceof PointLight||consoleAndThrowError("allow only PointLight instance");this.#Cl.length+this.#wl.length>this.#Tl&&consoleAndThrowError("Cannot add more cluster lights. The limit has been reached."),this.#wl.push(i)}addDirectionalLight(i){i instanceof DirectionalLight||consoleAndThrowError("allow only DirectionalLight instance");this.#Ml.length>this.#Sl&&consoleAndThrowError("Cannot add more directional lights. The limit has been reached."),this.#Ml.push(i)}removeSpotLight(i){const g=this.#Cl.indexOf(i);-1!==g&&this.#Cl.splice(g,1)}removePointLight(i){const g=this.#wl.indexOf(i);-1!==g&&this.#wl.splice(g,1)}removeDirectionalLight(i){const g=this.#Ml.indexOf(i);-1!==g&&this.#Ml.splice(g,1)}removeAllSpotLight(){this.#Cl=[]}removeAllPointLight(){this.#wl=[]}removeAllDirectionalLight(){this.#Ml=[]}removeAllLight(){this.removeAllPointLight(),this.removeAllSpotLight(),this.removeAllDirectionalLight(),this.#Rl=null}getDirectionalLightProjectionViewMatrix(i){return multiply$4(create$4(),this.getDirectionalLightProjectionMatrix(i),this.getDirectionalLightViewMatrix(i))}getDirectionalLightProjectionMatrix(i){const g=create$4(),x=i.rawCamera instanceof Camera2D?fromValues$3(0,0,0):fromValues$3(i.rawCamera.x,i.rawCamera.y,i.rawCamera.z),_=Math.max(distance$2(x,create$3()),1);return bt(g,-_,_,-_,_,3*-_,3*_),g}getDirectionalLightViewMatrix(i){identity$1(this.#Pl);const g=i.rawCamera instanceof Camera2D?fromValues$3(0,0,0):fromValues$3(i.rawCamera.x,i.rawCamera.y,i.rawCamera.z),x=Math.max(distance$2(g,create$3()),1),_=fromValues$3(0,1,0),v=fromValues$3(0,0,0),b=i.scene.lightManager.directionalLights.length?fromValues$3(-i.scene.lightManager.directionalLights[0].direction[0]*x,-i.scene.lightManager.directionalLights[0].direction[1]*x,-i.scene.lightManager.directionalLights[0].direction[2]*x):create$3(),y=create$4();return lookAt(y,b,v,_),y}}Object.freeze(LightManager);class DirectionalShadowManager{#Bl=2048;#_r=.005;#Il;#El;#Dl;#l;#Tu=[];#N=0;get videoMemorySize(){return this.#N}get castingList(){return this.#Tu}get shadowDepthTextureView(){return this.#El}get shadowDepthTextureViewEmpty(){return this.#Dl}get bias(){return this.#_r}set bias(i){validatePositiveNumberRange(i,0,1),this.#_r=i}get shadowDepthTextureSize(){return this.#Bl}set shadowDepthTextureSize(i){validateUintRange(i,1),this.#Bl=i}reset(){this.destroy()}resetCastingList(){this.#Tu.length=0}update(i){this.#l=i,this.#Ul()}destroy(){this.#Il&&(this.#Il.destroy(),this.#Il=null,this.#El=null)}#mr(){const i=this.#Il;if(!i)return 0;this.#N=calculateTextureByteSize(i)}#Ul(){this.#Il?.width!==this.#Bl&&(this.destroy(),this.#Ll(),this.#mr())}#Al(i){const g=i.createTexture({size:[1,1,1],usage:GPUTextureUsage.RENDER_ATTACHMENT|GPUTextureUsage.TEXTURE_BINDING,format:"depth32float",label:`DirectionalShadowManager_EmptyDepthTexture_1x1_${Date.now()}`});this.#Dl=g.createView({label:g.label})}#Ll(){const{gpuDevice:i,resourceManager:g}=this.#l;this.#Il=g.createManagedTexture({size:[this.#Bl,this.#Bl,1],usage:GPUTextureUsage.RENDER_ATTACHMENT|GPUTextureUsage.TEXTURE_BINDING,format:"depth32float",label:`DirectionalShadowManager_shadowDepthTextureSize_${this.#Bl}x${this.#Bl}_${Date.now()}`}),this.#El=this.#Il.createView({label:this.#Il.label}),this.#Dl||this.#Al(i)}}Object.freeze(DirectionalShadowManager);class ShadowManager{#Gl=new DirectionalShadowManager;constructor(){}get directionalShadowManager(){return this.#Gl}update(i){this.#Gl.update(i)}}Object.freeze(ShadowManager);class Scene extends Object3DContainer{#f;#h;#kl=new ColorRGBA;#Ol=!1;#Nl=new LightManager;#Vl=new ShadowManager;#Fl;constructor(i){super(),this.#f=InstanceIdGenerator.getNextId(this.constructor),this.#h=i}get lightManager(){return this.#Nl}get shadowManager(){return this.#Vl}get physicsEngine(){return this.#Fl}set physicsEngine(i){this.#Fl=i}get name(){return this.#f||(this.#f=InstanceIdGenerator.getNextId(this.constructor)),this.#h||`${this.constructor.name} Instance ${this.#f}`}set name(i){this.#h=i}get backgroundColor(){return this.#kl}set backgroundColor(i){i instanceof ColorRGBA||consoleAndThrowError("allow only ColorRGBA instance"),this.#kl=i}get useBackgroundColor(){return this.#Ol}set useBackgroundColor(i){this.#Ol=i}}const Yi=create$4(),computeViewFrustumPlanes=(i,g)=>{multiply$4(Yi,i,g);const x=[[Yi[3]-Yi[0],Yi[7]-Yi[4],Yi[11]-Yi[8],Yi[15]-Yi[12]],[Yi[3]+Yi[0],Yi[7]+Yi[4],Yi[11]+Yi[8],Yi[15]+Yi[12]],[Yi[3]+Yi[1],Yi[7]+Yi[5],Yi[11]+Yi[9],Yi[15]+Yi[13]],[Yi[3]-Yi[1],Yi[7]-Yi[5],Yi[11]-Yi[9],Yi[15]-Yi[13]],[Yi[3]-Yi[2],Yi[7]-Yi[6],Yi[11]-Yi[10],Yi[15]-Yi[14]],[Yi[3]+Yi[2],Yi[7]+Yi[6],Yi[11]+Yi[10],Yi[15]+Yi[14]]];for(let i=0;i<6;i++){const g=x[i],_=Math.sqrt(g[0]*g[0]+g[1]*g[1]+g[2]*g[2]);g[0]/=_,g[1]/=_,g[2]/=_,g[3]/=_}return x};class ViewTransform{onResize=null;#l;#Hl=create$4();#zl=create$4();#ji;#Ot=0;#Nt=0;#Bt;#It;#Et=[0,0,0,0];#$l=0;#Kl=0;constructor(i){validateRedGPUContext(i),this.#l=i,this.setSize("100%","100%")}get redGPUContext(){return this.#l}get camera(){return this.#ji}set camera(i){i instanceof PerspectiveCamera||i instanceof Camera2D||i instanceof OrthographicCamera||i instanceof AController||consoleAndThrowError("allow PerspectiveCamera or OrthographicCamera or AController instance"),this.#ji=i}get x(){return this.#Ot}set x(i){this.setPosition(i,this.y)}get y(){return this.#Nt}set y(i){this.setPosition(this.x,i)}get width(){return this.#Bt}set width(i){this.setSize(i,this.#It)}get height(){return this.#It}set height(i){this.setSize(this.#Bt,i)}get pixelRectArray(){return this.#Et}get pixelRectObject(){return{x:this.#Et[0],y:this.#Et[1],width:this.#Et[2],height:this.#Et[3]}}get screenRectObject(){return{x:this.#Et[0]/devicePixelRatio,y:this.#Et[1]/devicePixelRatio,width:this.#Et[2]/devicePixelRatio,height:this.#Et[3]/devicePixelRatio}}get aspect(){return this.#Et[2]/this.#Et[3]}get frustumPlanes(){return this.#ji instanceof AController?computeViewFrustumPlanes(this.projectionMatrix,this.#ji.camera.modelMatrix):computeViewFrustumPlanes(this.projectionMatrix,this.#ji.modelMatrix)}get rawCamera(){return this.#ji instanceof AController?this.#ji.camera:this.#ji}get noneJitterProjectionMatrix(){const{pixelRectObject:i,redGPUContext:g}=this;if(this.rawCamera instanceof OrthographicCamera){const{nearClipping:i,farClipping:g}=this.rawCamera;orthoZO(this.#zl,this.rawCamera.left,this.rawCamera.right,this.rawCamera.bottom,this.rawCamera.top,i,g)}else if(this.rawCamera instanceof Camera2D)bt(this.#zl,-.5,.5,-.5,.5,-1e5,1e5),scale$4(this.#zl,this.#zl,[g.renderScale,g.renderScale,1]),translate(this.#zl,this.#zl,[-.5,.5,0]),scale$4(this.#zl,this.#zl,[1/i.width*window.devicePixelRatio,-1/i.height*window.devicePixelRatio,1]);else{const{fieldOfView:i,nearClipping:g,farClipping:x}=this.rawCamera;vt(this.#zl,Math.PI/180*i,this.aspect,g,x)}return this.#zl}get projectionMatrix(){const{redGPUContext:i}=this,{antialiasingManager:g}=i;this.#Hl=clone$4(this.noneJitterProjectionMatrix);if("View3D"===this.constructor.name&&!(this.camera instanceof IsometricController)&&g.useTAA&&this.rawCamera instanceof PerspectiveCamera&&(0!==this.#$l||0!==this.#Kl)){const i=this.#$l/this.pixelRectObject.width*2,g=this.#Kl/this.pixelRectObject.height*2;this.#Hl[8]+=i,this.#Hl[9]+=g}return this.#Hl}get inverseProjectionMatrix(){return invert$1(create$4(),this.#Hl)}get jitterOffset(){return[this.#$l,this.#Kl]}setJitterOffset(i,g){this.#$l=i,this.#Kl=g}clearJitterOffset(){this.#$l=0,this.#Kl=0}setPosition(i=this.#Ot,g=this.#Nt){const{sizeManager:x}=this.#l;RedGPUContextSizeManager.validatePositionValue(i),RedGPUContextSizeManager.validatePositionValue(g),this.#Ot=i,this.#Nt=g;const _=x.pixelRectObject,v=RedGPUContextSizeManager.getPixelDimension(_,"width",i),b=RedGPUContextSizeManager.getPixelDimension(_,"height",g);this.#Et[0]=Math.floor(v*(this.#Ot.toString().includes("%")?1:x.renderScale*window.devicePixelRatio)),this.#Et[1]=Math.floor(b*(this.#Nt.toString().includes("%")?1:x.renderScale*window.devicePixelRatio))}setSize(i=this.#Bt,g=this.#It){const{sizeManager:x}=this.#l;RedGPUContextSizeManager.validateSizeValue(i),RedGPUContextSizeManager.validateSizeValue(g),this.#Bt=i,this.#It=g;const _=x.pixelRectObject,v=RedGPUContextSizeManager.getPixelDimension(_,"width",i),b=RedGPUContextSizeManager.getPixelDimension(_,"height",g);this.#Et[2]=Math.max(1,Math.floor(v*(this.#Bt.toString().includes("%")?1:x.renderScale*window.devicePixelRatio))),this.#Et[3]=Math.max(1,Math.floor(b*(this.#It.toString().includes("%")?1:x.renderScale*window.devicePixelRatio))),this.onResize&&this.onResize({target:this,screenRectObject:this.screenRectObject,pixelRectObject:this.pixelRectObject})}}Object.freeze(ViewTransform);class AView extends ViewTransform{#h;#Xl;#f;#jl=new PickingManager;#Yl=!0;#ql=!1;#Wl=50;#Zl;#Jl;#Ql;#ec;constructor(i,g,x,_){super(i),this.scene=g,this.camera=x,_&&(this.name=_)}get name(){return this.#f||(this.#f=InstanceIdGenerator.getNextId(this.constructor)),this.#h||`${this.constructor.name} Instance ${this.#f}`}set name(i){this.#h=i}get scene(){return this.#Xl}set scene(i){i instanceof Scene||consoleAndThrowError("allow only Scene instance"),this.#Xl=i}get pickingManager(){return this.#jl}get useFrustumCulling(){return this.#Yl}set useFrustumCulling(i){this.#Yl=i}get useDistanceCulling(){return this.#ql}set useDistanceCulling(i){this.#ql=i}get distanceCulling(){return this.#Wl}set distanceCulling(i){this.#Wl=i}get grid(){return this.#Zl}set grid(i){if("boolean"==typeof i)i=!0===i?new DrawDebuggerGrid(this.redGPUContext):null;else if(!(i instanceof DrawDebuggerGrid)&&null!==i)throw new TypeError("grid must be of type 'DrawDebuggerGrid','boolean',or 'null'.");this.#Zl=i}get axis(){return this.#Jl}set axis(i){if("boolean"==typeof i)i=!0===i?new DrawDebuggerAxis(this.redGPUContext):null;else if(!(i instanceof DrawDebuggerAxis)&&null!==i)throw new TypeError("axis must be of type 'DrawDebuggerAxis','boolean',or 'null'.");this.#Jl=i}get fxaa(){return this.#ec||(this.#ec=new FXAA(this.redGPUContext)),this.#ec}get taa(){return this.#Ql||(this.#Ql=new TAA(this.redGPUContext)),this.#Ql}screenToWorld(i,g){return screenToWorld(i,g,this)}checkMouseInViewBounds(){const{pixelRectObject:i,pickingManager:g}=this,{mouseX:x,mouseY:_}=g;return 0i+calculateTextureByteSize(g),0)}#dc(i,x){const{antialiasingManager:_,resourceManager:v}=this.#l,{useMSAA:b}=_,y=this.#lc.get(i),S=y?.texture,{pixelRectObject:w,name:L}=this.#Ft,{width:k,height:H}=w,z=S?.width!==k||S?.height!==H,q=this.#cc[i]!==b,W=!S||z||q;if(this.#cc[i]=b,W){g(`새 텍스처 생성 중:${i}`),S&&(S?.destroy(),y.texture=null,y.textureView=null,y.resolveTexture?.destroy(),y.resolveTexture=null,y.resolveTextureView=null,this.#lc.delete(i));const _={texture:null,textureView:null,resolveTexture:null,resolveTextureView:null},w=v.createManagedTexture({size:[Math.max(k,1),Math.max(H,1),1],sampleCount:b?4:1,label:`${L}_${i}_texture_${k}x${H}`,format:x||navigator.gpu.getPreferredCanvasFormat(),usage:GPUTextureUsage.RENDER_ATTACHMENT|GPUTextureUsage.TEXTURE_BINDING|GPUTextureUsage.COPY_SRC});if(_.texture=w,_.textureView=v.getGPUResourceBitmapTextureView(w),b){const g=v.createManagedTexture({size:{width:Math.max(k,1),height:Math.max(H,1),depthOrArrayLayers:1},sampleCount:1,label:`${L}_${i}_resolveTexture_${k}x${H}`,format:x||navigator.gpu.getPreferredCanvasFormat(),usage:GPUTextureUsage.RENDER_ATTACHMENT|GPUTextureUsage.TEXTURE_BINDING|GPUTextureUsage.COPY_SRC});_.resolveTexture=g,_.resolveTextureView=v.getGPUResourceBitmapTextureView(g)}this.#lc.set(i,_),this.#mc()}}#fc(i){const{resourceManager:g}=this.#l,x=this.#nc,{pixelRectObject:_,name:v}=this.#Ft,{width:b,height:y}=_;(!x||(x?.width!==b||x?.height!==y))&&(x&&(this.#nc=null,this.#rc=null),this.#ic={size:{width:Math.max(1,b),height:Math.max(1,y),depthOrArrayLayers:1},format:i,usage:GPUTextureUsage.TEXTURE_BINDING|GPUTextureUsage.COPY_DST|GPUTextureUsage.RENDER_ATTACHMENT|GPUTextureUsage.COPY_SRC,mipLevelCount:getMipLevelCount(b,y),label:`${v}_renderPath1ResultTexture_${b}x${y}`},this.#nc=g.createManagedTexture(this.#ic),this.#rc=g.getGPUResourceBitmapTextureView(this.#nc),this.#mc(),requestAnimationFrame(()=>{x?.destroy()}))}#Ll(){const{antialiasingManager:i,resourceManager:g}=this.#l,{useMSAA:x}=i,_=this.#ac,{pixelRectObject:v,name:b}=this.#Ft,{width:y,height:S}=v,w=_?.width!==y||_?.height!==S,L=this.#cc.depth!==x,k=!_||w||L;if(this.#cc.depth=x,k){_&&(_?.destroy(),this.#sc?.destroy(),this.#ac=null,this.#sc=null,this.#oc=null,this.#uc=null);const i=g.createManagedTexture({size:[Math.max(y,1),Math.max(S,1),1],sampleCount:x?4:1,label:`${b}_depth0_${y}x${S}`,format:"depth32float",usage:GPUTextureUsage.RENDER_ATTACHMENT|GPUTextureUsage.TEXTURE_BINDING});this.#ac=i,this.#oc=g.getGPUResourceBitmapTextureView(i);{const i=g.createManagedTexture({size:[Math.max(y,1),Math.max(S,1),1],sampleCount:x?4:1,label:`${b}_depth1_${y}x${S}`,format:"depth32float",usage:GPUTextureUsage.RENDER_ATTACHMENT|GPUTextureUsage.TEXTURE_BINDING});this.#sc=i,this.#uc=g.getGPUResourceBitmapTextureView(i)}this.#mc()}}}Object.freeze(ViewRenderTextureManager);const qi={LINEAR:"linear",KHRONOS_PBR_NEUTRAL:"khronosPBRNeutral",ACES_FILMIC_HILL:"ACESFilmicHill",ACES_FILMIC_NARKOWICZ:"ACESFilmicNarkowicz"};Object.freeze(qi);var Wi="struct Uniforms { exposure:f32, contrast:f32, brightness:f32, _pad:f32,\n};\nfn linearToSRGB(linearColor:vec3) -> vec3 { let a=0.055; let cutoff=0.0031308; let gamma=2.4; var srgb:vec3; for (var i=0;i < 3;i++) { let c=linearColor[i]; if (c <=cutoff) { srgb[i]=12.92 * c; } else { srgb[i]=(1.0 + a) * pow(c,1.0/gamma) - a; } } return srgb;\n}\nfn linearToneMapping(color:vec3,exposure:f32) -> vec3 { let exposed=color * exposure; return exposed;\n}\nfn khronosPBRNeutralToneMapping(color:vec3,exposure:f32) -> vec3 { let startCompression:f32=0.8 - 0.04; let desaturation:f32=0.15; var col=color * exposure; let x=min(col.r,min(col.g,col.b)); var offset:f32; if (x < 0.08) { offset=x - 6.25 * x * x; } else { offset=0.04; } col=col - vec3(offset); let peak=max(col.r,max(col.g,col.b)); if (peak < startCompression) { return clamp(col,vec3(0.0),vec3(1.0)); } let d=1.0 - startCompression; let newPeak=1.0 - d * d/(peak + d - startCompression); col=col * (newPeak/peak); let g=1.0 - 1.0/(desaturation * (peak - newPeak) + 1.0); return clamp(mix(col,vec3(newPeak),g),vec3(0.0),vec3(1.0));\n}\nfn acesFilmicNarkowiczToneMapping(color:vec3,exposure:f32) -> vec3 { let x=color * exposure; let a=2.51; let b=0.03; let c=2.43; let d=0.59; let e=0.14; return clamp((x * (a * x + b))/(x * (c * x + d) + e),vec3(0.0),vec3(1.0));\n}\nfn acesFilmicHillToneMapping(color:vec3,exposure:f32) -> vec3 { let v=color * exposure; let a1=v.r * 0.59719 + v.g * 0.35458 + v.b * 0.04823; let a2=v.r * 0.07600 + v.g * 0.90834 + v.b * 0.01566; let a3=v.r * 0.02840 + v.g * 0.13383 + v.b * 0.83777; let a=vec3(a1,a2,a3); let b=(a * (a + 0.0245786) - 0.000090537)/(a * (0.983729 * a + 0.4329510) + 0.238081); let r=b.r * 1.60475 - b.g * 0.53108 - b.b * 0.07367; let g=b.r * -0.10208 + b.g * 1.10813 - b.b * 0.00605; let bl=b.r * -0.00327 - b.g * 0.07276 + b.b * 1.07602; return clamp(vec3(r,g,bl),vec3(0.0),vec3(1.0));\n}\nfn getFinalSRGB(toneMappedColor:vec3,contrast:f32,brightness:f32) -> vec3 { let contrastRGB=applyContrast(toneMappedColor,uniforms.contrast); let finalLinearRGB=applyBrightness(contrastRGB,uniforms.brightness); let finalSRGB=clamp(linearToSRGB(finalLinearRGB),vec3(0.0),vec3(1.0)); return finalSRGB;\n}\nfn applyContrast(color:vec3,contrast:f32) -> vec3 { return 0.5 + contrast * (color - 0.5);\n}\nfn applyBrightness(color:vec3,brightness:f32) -> vec3 { return color + brightness;\n}";class AToneMappingEffect extends ASinglePassPostEffect{#pc=1;#Sr=1;#gc=0;constructor(i){super(i)}get exposure(){return this.#pc}set exposure(i){this.#pc=Math.max(.1,Math.min(5,i)),this.updateUniform("exposure",this.#pc)}get contrast(){return this.#Sr}set contrast(i){this.#Sr=Math.max(.5,Math.min(2,i)),this.updateUniform("contrast",this.#Sr)}get brightness(){return this.#gc}set brightness(i){this.#gc=Math.max(-1,Math.min(1,i)),this.updateUniform("brightness",this.#gc)}updateUniforms(){this.updateUniform("exposure",this.#pc),this.updateUniform("contrast",this.#Sr),this.updateUniform("brightness",this.#gc)}}Object.freeze(AToneMappingEffect);class ToneLinear extends AToneMappingEffect{constructor(i){super(i),this.init(i,"POST_EFFECT_TONE_MAPPING_LINEAR",createBasicPostEffectCode(this,"{ let index=vec2(global_id.xy); let inputColor=textureLoad(sourceTexture,index); let toneMappedColor=linearToneMapping(inputColor.rgb,uniforms.exposure); let finalSRGB=getFinalSRGB( toneMappedColor,uniforms.contrast,uniforms.brightness ); textureStore(outputTexture,index,vec4(finalSRGB,inputColor.a));\n}",Wi)),this.updateUniforms()}}Object.freeze(ToneLinear);class ToneKhronosPBRNeutral extends AToneMappingEffect{constructor(i){super(i),this.init(i,"POST_EFFECT_TONE_MAPPING_KHRONOS_PBR_NEUTRAL",createBasicPostEffectCode(this,"{ let index=vec2(global_id.xy); let inputColor=textureLoad(sourceTexture,index); let toneMappedColor=khronosPBRNeutralToneMapping(inputColor.rgb,uniforms.exposure); let finalSRGB=getFinalSRGB( toneMappedColor,uniforms.contrast,uniforms.brightness ); textureStore(outputTexture,index,vec4(finalSRGB,inputColor.a));\n}",Wi)),this.updateUniforms()}}Object.freeze(ToneKhronosPBRNeutral);class ToneACESFilmicNarkowicz extends AToneMappingEffect{constructor(i){super(i),this.init(i,"POST_EFFECT_TONE_MAPPING_ACES_FILMIC_NARKOWICZ",createBasicPostEffectCode(this,"{ let index=vec2(global_id.xy); let inputColor=textureLoad(sourceTexture,index); let toneMappedColor=acesFilmicNarkowiczToneMapping(inputColor.rgb,uniforms.exposure); let finalSRGB=getFinalSRGB( toneMappedColor,uniforms.contrast,uniforms.brightness ); textureStore(outputTexture,index,vec4(finalSRGB,inputColor.a));\n}",Wi)),this.updateUniforms()}}Object.freeze(ToneACESFilmicNarkowicz);class ToneACESFilmicHill extends AToneMappingEffect{constructor(i){super(i),this.init(i,"POST_EFFECT_TONE_MAPPING_ACES_FILMIC_HILL",createBasicPostEffectCode(this,"{ let index=vec2(global_id.xy); let inputColor=textureLoad(sourceTexture,index); let toneMappedColor=acesFilmicHillToneMapping(inputColor.rgb,uniforms.exposure); let finalSRGB=getFinalSRGB( toneMappedColor,uniforms.contrast,uniforms.brightness ); textureStore(outputTexture,index,vec4(finalSRGB,inputColor.a));\n}",Wi)),this.updateUniforms()}}Object.freeze(ToneACESFilmicHill);class ToneMappingManager{#l;#Ft;#xc;#_c=qi.KHRONOS_PBR_NEUTRAL;#pc=1;#Sr=1;#gc=0;constructor(i){this.#l=i.redGPUContext,this.#Ft=i}get toneMapping(){return this.#vc(),this.#xc}get mode(){return this.#_c}set mode(i){this.#_c!==i&&(this.#_c=i,this.#xc&&(this.#xc.clear(),this.#xc=void 0))}get exposure(){return this.#pc}set exposure(i){validatePositiveNumberRange(i,0),this.#pc=i,this.#xc&&(this.#xc.exposure=i)}get contrast(){return this.#Sr}set contrast(i){validatePositiveNumberRange(i,0,2),this.#Sr=i,this.#xc&&(this.#xc.contrast=i)}get brightness(){return this.#gc}set brightness(i){validateNumberRange(i,-1,1),this.#gc=i,this.#xc&&(this.#xc.brightness=i)}render(i,g,x){const _=this.toneMapping;return _?_.render(this.#Ft,i,g,x):x}#vc(){if(!this.#xc){switch(this.#_c){case qi.LINEAR:this.#xc=new ToneLinear(this.#l);break;case qi.KHRONOS_PBR_NEUTRAL:this.#xc=new ToneKhronosPBRNeutral(this.#l);break;case qi.ACES_FILMIC_NARKOWICZ:this.#xc=new ToneACESFilmicNarkowicz(this.#l);break;case qi.ACES_FILMIC_HILL:this.#xc=new ToneACESFilmicHill(this.#l);break;default:this.#xc=new ToneKhronosPBRNeutral(this.#l)}this.#xc&&(this.#xc.exposure=this.#pc,this.#xc.contrast=this.#Sr,this.#xc.brightness=this.#gc)}}}const Zi=parseWGSL(Ke.SYSTEM_UNIFORM).uniforms.systemUniforms;let Ji=create$4(),Qi=create$4();create$4();class View3D extends AView{#bc=Zi;#yc;#Sc;#Tc;#Mc;#wc;#Cc;#Rc;#Pc;#Bc={};#Ic;#rt;#Ec;#qt;#Dc;#Uc;#Lc;#Ac=void 0;#Gc=void 0;#kc;#Oc;#Xr;#jr;#Yr;#Nc=create$4();constructor(i,g,x,_){super(i,g,x,_),this.#ne(),this.#Pc=new ViewRenderTextureManager(this),this.#wc=new RenderViewStateData(this),this.#Cc=new PostEffectManager(this),this.#Rc=new ToneMappingManager(this),this.#Xr=new ArrayBuffer(this.systemUniform_Vertex_StructInfo.endOffset),this.#jr=new Float32Array(this.#Xr),this.#Yr=new Uint32Array(this.#Xr)}get viewRenderTextureManager(){return this.#Pc}get systemUniform_Vertex_StructInfo(){return this.#bc}get systemUniform_Vertex_UniformBindGroup(){return this.#yc}get systemUniform_Vertex_UniformBuffer(){return this.#Sc}get passLightClustersBound(){return this.#Lc}get ibl(){return this.#Mc}set ibl(i){this.#Mc=i}get postEffectManager(){return this.#Cc}get toneMappingManager(){return this.#Rc}get renderViewStateData(){return this.#wc}get skybox(){return this.#Tc}set skybox(i){const{resourceManager:g}=this.redGPUContext,x=this.#Tc?.skyboxTexture,_=i?.skyboxTexture;x&&x!==_&&this.#Vc(g,x.cacheKey,!1),this.#Tc=i}get basicRenderBundleEncoderDescriptor(){const{antialiasingManager:i}=this.redGPUContext,{useMSAA:g}=i;return{colorFormats:["rgba16float",navigator.gpu.getPreferredCanvasFormat(),"rgba16float"],depthStencilFormat:"depth32float",sampleCount:g?4:1}}get noneJitterProjectionCameraMatrix(){return this.#Nc}update(i=!1,g=!1,x){const{scene:_,redGPUContext:v}=this,{shadowManager:b}=_;b.update(v);const{directionalShadowManager:y}=b,S=this.ibl,w=S?.prefilterTexture?.gpuTexture,L=S?.irradianceTexture?.gpuTexture;let k=i?y.shadowDepthTextureViewEmpty:y.shadowDepthTextureView;const H=this.redGPUContext.viewList.indexOf(this),z=`${H}_${i?"shadowRender":"basic"}_2path${!!x}`;if(H>-1){let i=!0,g=this.#Bc[z];g&&(i=g.ibl!==S||g.ibl_prefilterTexture!==w||g.ibl_irradianceTexture!==L||g.renderPath1ResultTextureView!==x||g.shadowDepthTextureView!==k||!this.#Uc),i?this.#Fc(z,k,this.ibl,x):this.#yc=this.#Bc[z].vertexUniformBindGroup,this.#Bc[z]={ibl:S,ibl_prefilterTexture:w,ibl_irradianceTexture:L,renderPath1ResultTextureView:x,shadowDepthTextureView:k,vertexUniformBindGroup:this.#yc}}this.#Hc(g),this.#zc()}#ii(i){i.forEach(({key:i,value:g,dataView:x,targetMembers:_})=>{const v=_[i];x.set("number"==typeof g?[g]:g,v.uniformOffset/v.View.BYTES_PER_ELEMENT)})}#zc(){const{inverseProjectionMatrix:i,noneJitterProjectionMatrix:g,projectionMatrix:x,rawCamera:_}=this,{redGPUContext:v,systemUniform_Vertex_UniformBuffer:b}=this,{gpuDevice:y}=v,{lightManager:S,shadowManager:w}=this.scene,{modelMatrix:L,position:k}=_,H=this.systemUniform_Vertex_StructInfo,{gpuBuffer:z}=b,q=_ instanceof Camera2D,{members:W}=H;{const{members:b}=H,y=b.camera.members;this.#Nc=multiply$4(Qi,g,L),this.#ii([{key:"projectionMatrix",value:x,dataView:this.#jr,targetMembers:b},{key:"projectionCameraMatrix",value:multiply$4(Ji,x,L),dataView:this.#jr,targetMembers:b},{key:"noneJitterProjectionMatrix",value:g,dataView:this.#jr,targetMembers:b},{key:"noneJitterProjectionCameraMatrix",value:this.#Nc,dataView:this.#jr,targetMembers:b},{key:"inverseProjectionMatrix",value:i,dataView:this.#jr,targetMembers:b},{key:"prevNoneJitterProjectionCameraMatrix",value:v.antialiasingManager.useTAA?this.taa.prevNoneJitterProjectionCameraMatrix:this.#Nc,dataView:this.#jr,targetMembers:b},{key:"resolution",value:[this.pixelRectObject.width,this.pixelRectObject.height],dataView:this.#jr,targetMembers:b},{key:"cameraMatrix",value:L,dataView:this.#jr,targetMembers:y},{key:"cameraPosition",value:k,dataView:this.#jr,targetMembers:y},{key:"nearClipping",value:q?0:_.nearClipping,dataView:this.#jr,targetMembers:y},{key:"farClipping",value:q?0:_.farClipping,dataView:this.#jr,targetMembers:y},{key:"usePrefilterTexture",value:this.ibl?.prefilterTexture?.gpuTexture?1:0,dataView:this.#Yr,targetMembers:b},{key:"time",value:this.renderViewStateData.timestamp||0,dataView:this.#jr,targetMembers:b},{key:"isView3D",value:this.constructor===View3D?1:0,dataView:this.#Yr,targetMembers:b},{key:"shadowDepthTextureSize",value:w.directionalShadowManager.shadowDepthTextureSize,dataView:this.#Yr,targetMembers:b},{key:"bias",value:w.directionalShadowManager.bias,dataView:this.#jr,targetMembers:b},{key:"directionalLightCount",value:S.directionalLightCount,dataView:this.#Yr,targetMembers:b},{key:"directionalLightProjectionViewMatrix",value:S.getDirectionalLightProjectionViewMatrix(this),dataView:this.#jr,targetMembers:b},{key:"directionalLightProjectionMatrix",value:S.getDirectionalLightProjectionMatrix(this),dataView:this.#jr,targetMembers:b},{key:"directionalLightViewMatrix",value:S.getDirectionalLightViewMatrix(this),dataView:this.#jr,targetMembers:b}])}S.directionalLights.forEach((i,g)=>{const{directionalLights:x}=W;i.enableDebugger&&(i.drawDebugger||(i.drawDebugger=new DrawDebuggerDirectionalLight(v,i)),i.drawDebugger.render(this.renderViewStateData));const _=x.memberList[g];this.#ii([{key:"direction",value:i.direction,dataView:this.#jr,targetMembers:_},{key:"color",value:i.color.rgbNormalLinear,dataView:this.#jr,targetMembers:_},{key:"intensity",value:i.intensity,dataView:this.#jr,targetMembers:_}])});{const i=S.ambientLight,{ambientLight:g}=W,x=g.members;i&&this.#ii([{key:"color",value:i.color.rgbNormalLinear,dataView:this.#jr,targetMembers:x},{key:"intensity",value:i.intensity,dataView:this.#jr,targetMembers:x}])}y.queue.writeBuffer(z,0,this.#Xr)}#Fc(i,g,x,_){this.#Hc(!0);const v=x?.prefilterTexture,b=x?.irradianceTexture,{redGPUContext:y}=this,{gpuDevice:S,resourceManager:w}=y,L={layout:w.getGPUBindGroupLayout(ResourceManager.PRESET_GPUBindGroupLayout_System),label:`SYSTEM_UNIFORM_bindGroup_${i}`,entries:[{binding:0,resource:{buffer:this.#Sc.gpuBuffer,offset:0,size:this.#Sc.size}},{binding:1,resource:this.#Ic},{binding:2,resource:g},{binding:3,resource:this.#rt},{binding:5,resource:{buffer:this.#qt,offset:0,size:this.#qt.size}},{binding:6,resource:{buffer:this.#Uc.clusterLightsBuffer,offset:0,size:this.#Uc.clusterLightsBuffer.size}},{binding:7,resource:this.#rt},{binding:8,resource:_||w.emptyBitmapTextureView},{binding:9,resource:this.#Ec},{binding:10,resource:w.getGPUResourceCubeTextureView(v,v?.viewDescriptor||CubeTexture.defaultViewDescriptor)},{binding:11,resource:w.getGPUResourceCubeTextureView(b,b?.viewDescriptor||CubeTexture.defaultViewDescriptor)},{binding:12,resource:w.brdfGenerator.brdfLUTTexture?.createView()||w.emptyBitmapTextureView}]};this.#yc=S.createBindGroup(L),this.#$c(w,v,b)}#$c(i,g,x){[[this.#kc,g],[this.#Oc,x]].forEach(([g,x])=>{g&&g!==x&&this.#Vc(i,g.cacheKey,!1),x&&g!==x&&this.#Vc(i,x.cacheKey,!0)}),this.#kc=g,this.#Oc=x}#Vc(i,g,x){const _=i.managedCubeTextureState,v=_?.table.get(g);v&&(x?v.useNum++:v.useNum--)}#ne(){const i=new ArrayBuffer(Zi.arrayBufferByteLength);this.#Sc=new UniformBuffer(this.redGPUContext,i,"SYSTEM_UNIFORM_BUFFER_VERTEX","SYSTEM_UNIFORM_BUFFER_VERTEX"),this.#Dc=new Float32Array(16*q.MAX_CLUSTER_LIGHTS+4),this.#qt=this.redGPUContext.resourceManager.createGPUBuffer("VIEW_CLUSTER_LIGHTS_BUFFER",{size:this.#Dc.byteLength,usage:GPUBufferUsage.STORAGE|GPUBufferUsage.COPY_DST|GPUBufferUsage.COPY_SRC}),this.redGPUContext.gpuDevice.queue.writeBuffer(this.#qt,0,this.#Dc),this.#Ic=new Sampler(this.redGPUContext,{addressModeU:_.CLAMP_TO_EDGE,addressModeV:_.CLAMP_TO_EDGE,addressModeW:_.CLAMP_TO_EDGE,compare:Tn.LESS_EQUAL}).gpuSampler,this.#rt=new Sampler(this.redGPUContext).gpuSampler,this.#Ec=new Sampler(this.redGPUContext,{addressModeU:_.REPEAT,addressModeV:_.REPEAT}).gpuSampler}#Hc(i=!1){if(!i)return;const{redGPUContext:g,scene:x,renderViewStateData:_}=this;if(this.#Lc||(this.#Lc=new PassClusterLightBound(g,this)),this.#Uc&&(this.#Lc.render(),this.#Ac=this.pixelRectArray[2],this.#Gc=this.pixelRectArray[3]),this.#Uc||(this.#Uc=new PassClustersLight(g,this)),x){const{pointLights:i,spotLights:v}=x.lightManager,b=i.length,y=v.length;if(b){let x=b;for(;x--;){const v=i[x],b=4+16*x;this.#Dc.set([...v.position,v.radius,...v.color.rgbNormalLinear,v.intensity,0],b),v.enableDebugger&&(v.drawDebugger||(v.drawDebugger=new DrawDebuggerPointLight(g,v)),v.drawDebugger.render(_))}}if(y){const i=16,x=b*i;let S=y;for(;S--;){const b=v[S],y=4+i*S+x;this.#Dc.set([...b.position,b.radius,...b.color.rgbNormalLinear,b.intensity,1,...b.direction,b.outerCutoff,b.innerCutoff],y),b.enableDebugger&&(b.drawDebugger||(b.drawDebugger=new DrawDebuggerSpotLight(g,b)),b.drawDebugger.render(_))}}this.#Dc.set([b,y,0,0],0),this.redGPUContext.gpuDevice.queue.writeBuffer(this.#qt,0,this.#Dc),this.#Uc.render()}}}Object.freeze(View3D);class RedGPUContextViewContainer{#Kc=[];constructor(){}get viewList(){return this.#Kc}get numViews(){return this.#Kc.length}contains(i){return this.#Kc.includes(i)}addView(i){this.#Xc(i),this.#Kc.push(i)}addViewAt(i,g){this.#Xc(i),validateUintRange(g);const x=this.#Kc.length;x=x,v=this.#Kc.indexOf(i);-1===v&&consoleAndThrowError("입력하신 View 는 RedGPUContext instance 에 등록되지 않은 View 입니다."),_&&consoleAndThrowError(`index must be smaller than the viewList length./index:${g}/this.#viewList.length:${x}`),this.#Kc.splice(v,1),this.#Kc.splice(g,0,i)}swapViews(i,g){this.#Xc(i),this.#Xc(g);const x=this.#Kc.indexOf(i),_=this.#Kc.indexOf(g);-1!==x&&-1!==_||consoleAndThrowError((-1===x?"view1":"view2")+" is not child of this RedGPUContext instance."),this.swapViewsAt(x,_)}swapViewsAt(i,g){i===g&&consoleAndThrowError("The indices to swap cannot be the same."),validateUintRange(i),validateUintRange(g);const x=this.#Kc.length;(i>=x||g>=x)&&consoleAndThrowError(`index1,index2 must be smaller than the viewList length./index1:${i}/index2:${g}/this.#viewList.length:${x}`);const _=this.#Kc[i];this.#Kc[i]=this.#Kc[g],this.#Kc[g]=_}removeView(i){this.#Xc(i);const g=this.#Kc.indexOf(i);g>-1?this.#Kc.splice(g,1):consoleAndThrowError("View3D is not found in the view list.")}removeViewAt(i){validateUintRange(i);const g=this.#Kc.length;i{i.setPosition(),i.setSize()})}destroy(){this.#c.destroy()}setSize(i=this.width,g=this.height){this.sizeManager.setSize(i,g)}#nh(){this.#rh(),this.sizeManager.setSize("100%","100%"),window?.addEventListener("resize",()=>{this.#th=this.#Dt.getBoundingClientRect(),this.sizeManager.setSize()}),this.#th=this.#Dt.getBoundingClientRect();(this.detector.isMobile?["click","touchmove","touchstart","touchend"]:["click","mousemove","mousedown","mouseup"]).forEach(g=>{const x=this.detector.isMobile?{click:i.CLICK,touchmove:i.MOVE,touchstart:i.DOWN,touchend:i.UP}:{click:i.CLICK,mousemove:i.MOVE,mousedown:i.DOWN,mouseup:i.UP};this.#Dt.addEventListener(g,g=>{const _=x[g.type];this.viewList.forEach(x=>{this.detector.isMobile&&g instanceof TouchEvent&&g.touches.length>0?(x.pickingManager.mouseX=g.touches[0].clientX*devicePixelRatio-x.pixelRectObject.x,x.pickingManager.mouseY=g.touches[0].clientY*devicePixelRatio-x.pixelRectObject.y):g instanceof MouseEvent&&(x.pickingManager.mouseX=g.offsetX*devicePixelRatio-x.pixelRectObject.x,x.pickingManager.mouseY=g.offsetY*devicePixelRatio-x.pixelRectObject.y),_===i.CLICK?x.pickingManager.lastMouseClickEvent={...g,type:_}:x.pickingManager.lastMouseEvent={...g,type:_}})})});{const HD_keyDown=i=>{this.#eh[i.key]=!0},HD_keyUp=i=>{this.#eh[i.key]=!1};window?.addEventListener("keyup",HD_keyUp),window?.addEventListener("keydown",HD_keyDown)}new ResizeObserver(i=>{}).observe(this.#Dt)}#rh(){const i=navigator.gpu.getPreferredCanvasFormat();this.#jc={device:this.#c,format:i,alphaMode:this.#qc},this.#Wc.configure(this.#jc)}}Object.freeze(RedGPUContext);const init=async(i,x,_,v,b="premultiplied",y={powerPreference:"high-performance",forceFallbackAdapter:!1})=>{if(isSearchEngineBot())return void g("🤖 Search engine bot detected - skipping WebGPU initialization");const{gpu:S}=navigator;if(!S){const i="WebGPU is not supported in this browser. Please use a modern browser with WebGPU enabled.";return void _?.(i)}const errorHandler=(i,g)=>{const x=generateErrorMessage(i,g);console.error("\n============\n",x,"\n============\n"),_?.(x)},validateAndRequestDevice=async g=>{const x=[];g?.features.has("texture-compression-astc")&&x.push("texture-compression-astc");const _={};["maxBufferSize","maxStorageBufferBindingSize","maxSampledTexturesPerShaderStage","maxSamplersPerShaderStage","maxStorageBuffersPerShaderStage","maxStorageTexturesPerShaderStage","maxUniformBuffersPerShaderStage","maxUniformBufferBindingSize","maxBindGroups","maxVertexAttributes","maxVertexBuffers","maxInterStageShaderComponents","maxComputeWorkgroupStorageSize","maxComputeInvocationsPerWorkgroup","maxComputeWorkgroupSizeX","maxComputeWorkgroupSizeY","maxComputeWorkgroupSizeZ","maxComputeWorkgroupsPerDimension"].forEach(i=>{g.limits[i]&&(_[i]=g.limits[i])});const v={requiredFeatures:x,requiredLimits:_};try{const x=await g.requestDevice(v);validateAndInitializeContext(i,g,x)}catch(i){errorHandler(null,`Failed to request device. Adapter was ${g},error message is ${i.message}`)}},validateAndInitializeContext=(i,_,y)=>{const S=i.getContext("webgpu");if(S)try{{const i=y.createShaderModule.bind(y);y.createShaderModule=function(g){g.code=ensureVertexIndexBuiltin(g.code);return i(g)}}const w=new RedGPUContext(i,_,y,S,b);x(w),y.addEventListener("uncapturederror",i=>{console.warn("TODO A WebGPU error was not captured:",i),console.warn(i.error?.message),window.cancelAnimationFrame(w.currentRequestAnimationFrame)}),y.lost.then(i=>{console.warn(i),console.warn(`Device lost occurred:${i.message}`),"destroyed"===i.reason&&v?.(i)});const clearDevice=()=>{if(w.gpuContext)try{w.gpuContext.unconfigure(),g("🧹 Canvas Context unconfigure 완료")}catch(i){g("⚠️ Canvas Context unconfigure 실패:",i)}window?.cancelAnimationFrame(w.currentRequestAnimationFrame),w.gpuDevice.destroy()};window?.addEventListener("beforeunload",()=>{w&&w.gpuDevice&&(g("🧹 페이지 종료 시 GPU 디바이스 정리"),clearDevice())}),window?.addEventListener("pageshow",i=>{i.persisted&&(g("🔄 bfcache에서 복원됨 (뒤로가기 또는 앞으로가기) - 페이지 재로드"),window.location.reload())}),window?.addEventListener("pagehide",i=>{i.persisted&&(g("💾 bfcache에 저장됨"),w&&w.gpuDevice&&clearDevice())})}catch(i){errorHandler(i,"")}else errorHandler(new Error(`Failed to get context from canvas:${i.id||i}`),"Failed to get webgpu initialize from canvas")},initializeWebGPU=async()=>{x instanceof Function?i instanceof HTMLCanvasElement?await(async i=>{i||errorHandler(null,"Cannot find navigator.gpu");try{const g=await i.requestAdapter(y);await validateAndRequestDevice(g)}catch(g){errorHandler(g,`Failed to request adapter or validate device with target GPU:${i},error message is ${g.message}`)}})(S):errorHandler(null,`Expected HTMLCanvasElement,but received:${i}`):errorHandler(null,`Expected onWebGPUInitialized,but received:${x}`)};try{await initializeWebGPU()}catch(i){errorHandler(i,`Unexpected error occurred during WebGPU initialization:${i.message}`)}},generateErrorMessage=(i,g)=>{let x=g;return i instanceof Error?(x=i.message??g,"string"==typeof i.stack&&(x+=`\nStack Trace:${i.stack}`)):console.warn("generateErrorMessage function expected an Error instance,but got:",i),x},isSearchEngineBot=()=>{if("undefined"==typeof navigator||"undefined"==typeof window)return!0;const i=navigator.userAgent.toLowerCase();return["googlebot","bingbot","slurp","duckduckbot","baiduspider","yandexbot","facebookexternalhit","twitterbot","rogerbot","linkedinbot","embedly","quora link preview","showyoubot","outbrain","pinterest/0.","developers.google.com/+/web/snippet","www.google.com/webmasters/tools/richsnippets","slackbot","vkshare","w3c_validator","redditbot","applebot","whatsapp","flipboard","tumblr","bitlybot","skypeuripreview","nuzzel","line","discordbot","telegrambot","crawler","spider","bot"].some(g=>i.includes(g))};class TextureLoaderData{src;texture;loadEnd;loadSuccess;srcInfo;idx;constructor(i,g,x){this.src=i,this.texture=null,this.loadEnd=!1,this.loadSuccess=!1,this.srcInfo=g,this.idx=x}}class TextureLoader{textures=[];#ih=0;#l;#ah;#ps;#sh;constructor(i,g=[],x,_){this.#l=i,this.#ah=g,this.#ps=x,this.#sh=_,this.#ah.length?this.#ah.forEach((i,g)=>this.#oh(i,g)):this.#uh()}getTextureByIndex(i){if(this.textures[i])return this.textures[i].texture}#oh(i,g){let x,_,v=BitmapTexture;_=i.hasOwnProperty("src")?i.src:i,_ instanceof Array&&(v=CubeTexture),x=new TextureLoaderData(_,i,g);const onLoadHandler=()=>{x.loadSuccess=!0,x.loadEnd=!0,this.#lh()},onErrorHandler=()=>{x.loadSuccess=!1,x.loadEnd=!0,this.#lh()};x.texture=v===BitmapTexture?new v(this.#l,{src:i.src,cacheKey:i.cacheKey},i.useMipmap,onLoadHandler,onErrorHandler,i.format,!1):new v(this.#l,{src:i.src,cacheKey:i.cacheKey},i.useMipmap,onLoadHandler,onErrorHandler,i.format),this.textures.push(x),this.#ch()}#ch(){const i=this.#ah.length,g=this.#ih;this.#sh&&this.#sh.call(this,{total:i,loaded:g,percent:Math.min(100,parseFloat((g/i*100).toFixed(2)))})}#lh(){this.#ih++,this.#ch(),this.#ih===this.#ah.length&&this.#uh()}#uh(){requestAnimationFrame(()=>{this.#ps&&this.#ps.call(this,this)})}}const checkProgress=(i,g,x)=>{const _=g.buffers.length;i.loadingProgressInfo.buffers={loaded:x,total:_,percent:Math.min(100,parseFloat((x/_*100).toFixed(2)))}},ea=new Map,ta=new Map,arrayBufferLoader=(i,g,x)=>{if(i=getAbsoluteURL(window.location.href,i),ea.has(i))return void g?.(ea.get(i));if(ta.has(i))return void ta.get(i).then(i=>g?.(i)).catch(i=>x?.(i));const _=fetch(i).then(i=>{if(!i.ok)throw new Error(`Network response was not ok:${i.statusText}`);return i.arrayBuffer()}).then(g=>(ea.set(i,g),g)).finally(()=>{ta.delete(i)});ta.set(i,_),_.then(i=>g?.(i)).catch(i=>x?.(i))},na={5120:Int8Array,5121:Uint8Array,5122:Int16Array,5123:Uint16Array,5125:Uint32Array,5126:Float32Array};Object.freeze(na);class AccessorInfo_GLTF{accessor;bufferView;bufferGlTfId;buffer;bufferURIDataView;componentType;componentType_BYTES_PER_ELEMENT;getMethod;accessorBufferOffset;bufferViewOffset;bufferViewByteStride;startIndex;constructor(i,g,x){switch(this.accessor=g.accessors[x],this.bufferView=g.bufferViews[this.accessor.bufferView],this.bufferGlTfId=this.bufferView.buffer,this.buffer=g.buffers[this.bufferGlTfId],this.bufferURIDataView=null,this.buffer.uri&&(this.bufferURIDataView=i.parsingResult.uris.buffers[this.bufferGlTfId]),this.componentType=na[this.accessor.componentType],this.componentType_BYTES_PER_ELEMENT=this.componentType.BYTES_PER_ELEMENT,this.componentType){case Float32Array:this.getMethod="getFloat32";break;case Uint32Array:this.getMethod="getUint32";break;case Uint16Array:this.getMethod="getUint16";break;case Int16Array:this.getMethod="getInt16";break;case Uint8Array:this.getMethod="getUint8";break;case Int8Array:this.getMethod="getInt8";break;default:consoleAndThrowError("파싱할수없는 타입",this.componentType)}this.accessorBufferOffset=this.accessor.byteOffset||0,this.bufferViewOffset=this.bufferView.byteOffset||0,this.bufferViewByteStride=this.bufferView.byteStride||0,this.startIndex=(this.bufferViewOffset+this.accessorBufferOffset)/this.componentType_BYTES_PER_ELEMENT}}class AnimationData_GLTF{gltfLoader;scenesData;accessorGlTfId;dataList;constructor(i,g,x){this.gltfLoader=i,this.scenesData=g,this.accessorGlTfId=x;const _=new AccessorInfo_GLTF(this.gltfLoader,this.scenesData,this.accessorGlTfId),{accessor:v,startIndex:b,componentType_BYTES_PER_ELEMENT:y,bufferURIDataView:S,getMethod:w}=_,{type:L,count:k}=v;let H=b,z=1;switch(L){case"SCALAR":z=1;break;case"VEC4":z=4;break;case"VEC3":z=3}const q=[];let W=0;for(;W animation_data_list:array;\n@group(0) @binding(1) var uniforms:Uniforms;\n@group(0) @binding(2) var vertices:array;\n@group(0) @binding(3) var origin_data:array;\n@group(0) @binding(4) var morph_interleave_data:array;\n@compute @workgroup_size(64)\nfn main(@builtin(global_invocation_id) global_id:vec3) { let vertex_index=global_id.x; let vertex_count=u32(uniforms.vertex_count); let stride=u32(uniforms.vertex_stride); let morph_length=u32(uniforms.morph_length); let base_vertex_index=vertex_index * stride; let base_vertex_index2=vertex_index * 3u; let prev_time_offset=u32(uniforms.prev_time_data_index) * morph_length; let next_time_offset=u32(uniforms.next_time_data_index) * morph_length; var prev_weight=origin_data[base_vertex_index]; var next_weight=origin_data[base_vertex_index]; var prev_weight1=origin_data[base_vertex_index + 1u]; var next_weight1=origin_data[base_vertex_index + 1u]; var prev_weight2=origin_data[base_vertex_index + 2u]; var next_weight2=origin_data[base_vertex_index + 2u]; for (var morph_index=0u;morph_index < morph_length;morph_index++) { let prev_animation_data=animation_data_list[prev_time_offset + morph_index]; let next_animation_data=animation_data_list[next_time_offset + morph_index]; let morph_base_offset=morph_index * vertex_count * 3u; let temp_weight_x=morph_interleave_data[morph_base_offset + base_vertex_index2]; prev_weight +=prev_animation_data * temp_weight_x; next_weight +=next_animation_data * temp_weight_x; let temp_weight_y=morph_interleave_data[morph_base_offset + base_vertex_index2 + 1u]; prev_weight1 +=prev_animation_data * temp_weight_y; next_weight1 +=next_animation_data * temp_weight_y; let temp_weight_z=morph_interleave_data[morph_base_offset + base_vertex_index2 + 2u]; prev_weight2 +=prev_animation_data * temp_weight_z; next_weight2 +=next_animation_data * temp_weight_z; } let interpolation_diff_x=next_weight - prev_weight; let interpolation_diff_y=next_weight1 - prev_weight1; let interpolation_diff_z=next_weight2 - prev_weight2; let final_x=prev_weight + uniforms.interpolation_value * interpolation_diff_x; let final_y=prev_weight1 + uniforms.interpolation_value * interpolation_diff_y; let final_z=prev_weight2 + uniforms.interpolation_value * interpolation_diff_z; vertices[base_vertex_index]=final_x; vertices[base_vertex_index + 1u]=final_y; vertices[base_vertex_index + 2u]=final_z;\n}\n"}),this.#Kn=g.createComputePipeline({layout:"auto",compute:{module:this.#hh,entryPoint:"main"}}),this.#fh=g.createBuffer({size:4*this.aniDataAnimationInfo.dataList.length,usage:GPUBufferUsage.STORAGE|GPUBufferUsage.COPY_DST}),this.#Xn=g.createBuffer({size:32,usage:GPUBufferUsage.UNIFORM|GPUBufferUsage.COPY_DST}),g.queue.writeBuffer(this.#fh,0,this.aniDataAnimationInfo.dataList)}#ph(i,g){const{gpuDevice:x}=i,_=g.animationInfo.morphInfo,v=g.geometry.vertexBuffer,b=x.createBuffer({size:4*_.origin.length,usage:GPUBufferUsage.STORAGE|GPUBufferUsage.COPY_DST}),y=_.morphInfoDataList.flatMap(i=>Array.from(i.interleaveData)),S=x.createBuffer({size:4*y.length,usage:GPUBufferUsage.STORAGE|GPUBufferUsage.COPY_DST});x.queue.writeBuffer(b,0,_.origin),x.queue.writeBuffer(S,0,new Float32Array(y));const w=x.createBindGroup({layout:this.#Kn.getBindGroupLayout(0),entries:[{binding:0,resource:{buffer:this.#fh}},{binding:1,resource:{buffer:this.#Xn}},{binding:2,resource:{buffer:v.gpuBuffer}},{binding:3,resource:{buffer:b}},{binding:4,resource:{buffer:S}}]});this.#dh.set(g,{bindGroup:w,originBuffer:b,morphInterleavedBuffer:S})}}const parseAnimations=(i,g)=>new Promise(async x=>{g.animations||(g.animations=[]);const{parsingResult:_}=i,{animations:v}=_,{animations:b}=g;if(b.length){const x=b.map(async x=>{const{samplers:_,channels:b}=x,y=[];y.minTime=1e7,y.maxTime=-1,y.name=x.name,v.push(y),await Promise.all(b.map(async x=>((i,g,x,_,v)=>{let b,y;const{nodes:S,meshes:w}=v,L=[],{sampler:k,target:H}=x,z=_[k],{node:q,path:W}=H,be=S[q];if("mesh"in be){b=be.Mesh;const{primitives:i}=w[be.mesh];let g=i.length;for(;g--;)L.push(i[g].Mesh)}else{let g;if(!i.parsingResult.groups[q])return;g=i.parsingResult.groups[q],b=g}if("scale"!=W&&"rotation"!=W&&"translation"!=W&&"weights"!=W||(y=new AniTrack_GLTF(W,new AnimationData_GLTF(i,v,z.input),new AnimationData_GLTF(i,v,z.output),z.interpolation,b,L),g.push(y)),y){const{timeAnimationInfo:i}=y,{dataList:x}=i;g.minTime>x[0]&&(g.minTime=x[0]),g.maxTimei.playAnimation(g))}x()});class ParsedSkinInfo_GLTF{joints;inverseBindMatrices;skeletonMesh;vertexStorageInfo;vertexStorageBuffer;prevVertexStorageBuffer;invertNodeGlobalTransform;usedJoints=null;WORK_SIZE=64;jointData;uniformBuffer;computeShader;computePipeline;bindGroup;constructor(){this.joints=[],this.inverseBindMatrices=null,this.skeletonMesh=null}getUsedJointIndices(i){const g=new Set,{jointBuffer:x}=i.animationInfo;if(!x.data.length)return[];const _=x.data,v=_.length;for(let i=0;i=0&&v, jointModelMatrices: array,${this.usedJoints.length}>, inverseBindMatrices: array,${this.joints.length}>, searchJointIndexTable: array,${this.joints.length}>, }; @group(0) @binding(0) var vertexWeight: array>; @group(0) @binding(1) var vertexJoint: array>; @group(0) @binding(2) var skinMatrixBuffer: array>; @group(0) @binding(3) var prevSkinMatrixBuffer: array>; @group(0) @binding(4) var uniforms: Uniforms; @compute @workgroup_size(${this.WORK_SIZE},1,1) fn main(@builtin(global_invocation_id) global_id:vec3) { let idx=global_id.x; if (idx >=arrayLength(&vertexWeight)) { return; } let weights=vertexWeight[idx]; let joints=vertexJoint[idx]; prevSkinMatrixBuffer[idx]=skinMatrixBuffer[idx]; skinMatrixBuffer[idx]=uniforms.invertNodeGlobalTransform * ( weights.x * ( \tuniforms.jointModelMatrices[uniforms.searchJointIndexTable[joints.x].x] * uniforms.inverseBindMatrices[joints.x] ) + weights.y * ( \tuniforms.jointModelMatrices[uniforms.searchJointIndexTable[joints.y].x] * uniforms.inverseBindMatrices[joints.y] ) + weights.z * ( \tuniforms.jointModelMatrices[uniforms.searchJointIndexTable[joints.z].x] * uniforms.inverseBindMatrices[joints.z] ) + weights.w * ( \tuniforms.jointModelMatrices[uniforms.searchJointIndexTable[joints.w].x] * uniforms.inverseBindMatrices[joints.w] ) ); } `;this.jointData=new Float32Array(16*(1+this.usedJoints.length)),this.computeShader=i.resourceManager.createGPUShaderModule(`calcSkinMatrix_${this.usedJoints.length}`,{code:b}),this.computePipeline=g.createComputePipeline({label:"calcSkinMatrix",layout:"auto",compute:{module:this.computeShader,entryPoint:"main"}}),this.uniformBuffer=g.createBuffer({size:this.jointData.byteLength+16*this.joints.length*4+4*this.joints.length*4,usage:GPUBufferUsage.UNIFORM|GPUBufferUsage.COPY_DST}),g.queue.writeBuffer(this.uniformBuffer,this.jointData.byteLength,new Float32Array(this.inverseBindMatrices.map(i=>Array.from(i)).flat()));const y=new Uint32Array(4*this.joints.length);y.fill(0),this.usedJoints.forEach((i,g)=>{y[4*i]=g}),g.queue.writeBuffer(this.uniformBuffer,this.jointData.byteLength+16*this.joints.length*4,y),this.bindGroup=g.createBindGroup({layout:this.computePipeline.getBindGroupLayout(0),entries:[{binding:0,resource:{buffer:_.gpuBuffer}},{binding:1,resource:{buffer:v.gpuBuffer}},{binding:2,resource:{buffer:this.vertexStorageBuffer}},{binding:3,resource:{buffer:this.prevVertexStorageBuffer}},{binding:4,resource:{buffer:this.uniformBuffer}}]})}}const parseJoint_GLTF=(i,g,x,_)=>{const{redGPUContext:v}=i,b=x[_].Mesh;b?g.joints.push(b):requestAnimationFrame(function(){parseJoint_GLTF(i,g,x,_)})},calculateNormals=(i,g)=>{let x,_,v=[],b=g;const y=i.length/3;if(!g||0===g.length){g=[];for(let i=0;i{const b=x.sparse;if(!b)return;const{values:y,indices:S,count:w}=b,L=_.bufferViews,k=L[y.bufferView],H=k.buffer,z=_.buffers,q=z[H],W=[],be=[],Ke=L[S.bufferView],Xe=Ke.buffer,je=z[Xe];let Ye;q.uri&&(Ye=i.parsingResult.uris.buffers[H]);const Ze=na[x.componentType],{BYTES_PER_ELEMENT:Je}=Ze;let Qe;switch(Ze){case Float32Array:Qe="getFloat32";break;case Uint32Array:Qe="getUint32";break;case Uint16Array:Qe="getUint16";break;case Int16Array:Qe="getInt16";break;case Uint8Array:Qe="getUint8";break;case Int8Array:Qe="getInt8"}const et=x.byteOffset||0;let tt,it,ft=((k.byteOffset||0)+et)/Je;switch(x.type){case"VEC3":for(tt=ft+Je*w/Je*3;ft{const v=new MorphInfoData_GLTF;for(let _ in x){const{vertices:b,verticesColor_0:y,normals:S,uvs:w,uvs1:L,uvs2:k,jointWeights:H,joints:z,tangents:q}=v,W=x[_],be=new AccessorInfo_GLTF(i,g,W),{accessor:Ke}=be;parseAttributeInfo_GLTF(_,be,b,w,L,0,S,H,z,y,q),Ke.sparse&&parseSparse_GLTF(i,_,Ke,g,b)}return _.length&&(v.interleaveData=new Float32Array(v.vertices)),v})),this.weights=_||[],this.origin=null}}const parseMaterialTexture=(i,g,x,_,v,b=!0)=>{const{redGPUContext:y,gltfData:S}=i,{textureRawList:w}=i.parsingResult,L=x.index,k=S.textures[L],H=k.extensions?.EXT_texture_webp?.source||k.source,z=getURL(i,S,H);if(z){const L=k.sampler,q=getSamplerInfo(i,S,L),{parsedURI:W,cacheKey:be}=z,Ke=`${_}SourceGlTfId_${H}`;if(w[Ke]?(w[Ke].materialList.push(g),w[Ke].samplerList.push(new Sampler(y,q))):w[Ke]={src:W,cacheKey:be,targetTextureKey:_,targetSamplerKey:`${_}Sampler`,materialList:[g],samplerList:[new Sampler(y,q)],format:v||navigator.gpu.getPreferredCanvasFormat(),useMipmap:b},g[`${_}_texCoord_index`]=x.texCoord||0,"extensions"in x){const{extensions:i}=x,{KHR_texture_transform:v}=i;v&&((i,g,x)=>{i[`${g}_KHR_texture_transform_offset`]=x.offset||[0,0],i[`${g}_KHR_texture_transform_scale`]=x.scale||[1,1],i[`${g}_KHR_texture_transform_rotation`]=x.rotation||0,i[`use_${g}_KHR_texture_transform`]=!0})(g,_,v)}}},getURL=function(i,g,x){if(!g.images[x])return null;const{uri:_}=g.images[x];let v;const b=`${i.url}_${x}`;return v=_.indexOf("blob:http")>-1?_:(_.indexOf(";base64,")>-1?"":i.filePath)+_,{parsedURI:v,cacheKey:b}},getSamplerInfo=function(i,g,x){const v={magFilter:b.LINEAR,minFilter:b.LINEAR,mipmapFilter:b.LINEAR,addressModeU:_.REPEAT,addressModeV:_.REPEAT,addressModeW:_.REPEAT},y={33071:_.CLAMP_TO_EDGE,33648:_.MIRRORED_REPEAT,10497:_.REPEAT},S={9728:b.NEAREST,9729:b.LINEAR},w={9728:b.NEAREST,9729:b.LINEAR};if(g.samplers){let i=g.samplers[x];i&&("magFilter"in i&&(v.magFilter=S[i.magFilter]||b.LINEAR),"minFilter"in i&&(v.minFilter=w[i.minFilter]||b.LINEAR),"wrapS"in i&&(v.addressModeU=y[i.wrapS]),"wrapT"in i&&(v.addressModeV=y[i.wrapT]))}return v.string=JSON.stringify(v),v},parseMaterialInfo_GLTF=(i,g,x)=>{const{redGPUContext:_}=i;let v,b=!1,y="OPAQUE",S=.5;if("material"in x){v=new PBRMaterial(_);const w=x.material,L=g.materials[w];b=!!L.doubleSided,y=L.alphaMode??y,S=L.alphaCutoff??S;const{pbrMetallicRoughness:k,normalTexture:H,emissiveTexture:z,occlusionTexture:q}=L;if(v.emissiveFactor=L.emissiveFactor||[0,0,0],k){const{metallicRoughnessTexture:g,baseColorTexture:x}=k;let _,b;v.baseColorFactor=k.baseColorFactor||[1,1,1,1],"metallicFactor"in k&&(_=k.metallicFactor),"roughnessFactor"in k&&(b=k.roughnessFactor),v.metallicFactor=null!=_?_:1,v.roughnessFactor=null!=b?b:1,x&&parseMaterialTexture(i,v,x,"baseColorTexture",`${navigator.gpu.getPreferredCanvasFormat()}-srgb`),g&&parseMaterialTexture(i,v,g,"metallicRoughnessTexture",null,!1)}if(H){parseMaterialTexture(i,v,H,"normalTexture");const{scale:g}=H;v.normalScale=null!=g?g:1}if(z&&parseMaterialTexture(i,v,z,"emissiveTexture",`${navigator.gpu.getPreferredCanvasFormat()}-srgb`),q&&(parseMaterialTexture(i,v,q,"occlusionTexture",null,!1),v.occlusionStrength=L.occlusionTexture.strength||1),"extensions"in L){const{extensions:g}=L,{KHR_materials_clearcoat:x,KHR_materials_emissive_strength:_,KHR_materials_transmission:b,KHR_materials_diffuse_transmission:S,KHR_materials_volume:w,KHR_materials_unlit:k,KHR_materials_ior:H,KHR_materials_sheen:z,KHR_materials_specular:q,KHR_materials_dispersion:W,KHR_materials_anisotropy:be,KHR_materials_iridescence:Ke}=g;if(Ke&&((i,g,x)=>{i.useKHR_materials_iridescence=!0,i.KHR_iridescenceFactor=g.iridescenceFactor||0,i.KHR_iridescenceIor=g.iridescenceIor||1.3,i.KHR_iridescenceThicknessMinimum=g.iridescenceThicknessMinimum||100,i.KHR_iridescenceThicknessMaximum=g.iridescenceThicknessMaximum||400,i.transparent=!0;{const{iridescenceTexture:_,iridescenceThicknessTexture:v}=g;_&&parseMaterialTexture(x,i,_,"KHR_iridescenceTexture",null,!1),v&&parseMaterialTexture(x,i,v,"KHR_iridescenceThicknessTexture",null,!1)}})(v,Ke,i),be&&((i,g,x)=>{i.useKHR_materials_anisotropy=!0,i.KHR_anisotropyStrength=g.anisotropyStrength||0,i.KHR_anisotropyRotation=g.anisotropyRotation||0;const{anisotropyTexture:_}=g;_&&parseMaterialTexture(x,i,_,"KHR_anisotropyTexture")})(v,be,i),x&&((i,g,x)=>{i.KHR_clearcoatFactor=g.clearcoatFactor||0,i.KHR_clearcoatRoughnessFactor=g.clearcoatRoughnessFactor||0,i.useKHR_materials_clearcoat=!0;const{clearcoatTexture:_,clearcoatNormalTexture:v,clearcoatRoughnessTexture:b}=g;_&&parseMaterialTexture(x,i,_,"KHR_clearcoatTexture",null,!1),v&&parseMaterialTexture(x,i,v,"KHR_clearcoatNormalTexture"),b&&parseMaterialTexture(x,i,b,"KHR_clearcoatRoughnessTexture",null,!1)})(v,x,i),_){const{emissiveStrength:i}=_;v.emissiveStrength=null!=i?i:1}if(b&&(((i,g,x)=>{i.useKHR_materials_transmission=!0,i.KHR_transmissionFactor=g.transmissionFactor||0,i.use2PathRender=!0;{const _=g.transmissionTexture;_&&parseMaterialTexture(x,i,_,"KHR_transmissionTexture",null,!1)}})(v,b,i),v.transparent="BLEND"===y),S&&((i,g,x)=>{i.useKHR_materials_diffuse_transmission=!0,i.KHR_diffuseTransmissionFactor=g.diffuseTransmissionFactor||0,i.KHR_diffuseTransmissionColorFactor=g.diffuseTransmissionColorFactor||[1,1,1],i.transparent=!0;{const _=g.diffuseTransmissionTexture;_&&parseMaterialTexture(x,i,_,"KHR_diffuseTransmissionTexture",null,!1);const v=g.diffuseTransmissionColorTexture;v&&parseMaterialTexture(x,i,v,"KHR_diffuseTransmissionColorTexture",`${navigator.gpu.getPreferredCanvasFormat()}-srgb`,!1)}})(v,S,i),w&&(((i,g,x)=>{i.useKHR_materials_volume=!0,i.KHR_thicknessFactor=g.thicknessFactor||1,i.KHR_attenuationDistance=g.attenuationDistance||1,i.KHR_attenuationColor=g.attenuationColor||[1,1,1],i.use2PathRender=!0,i.transparent=!0;{const _=g.thicknessTexture;_&&parseMaterialTexture(x,i,_,"KHR_thicknessTexture",null,!1)}})(v,w,i),y="BLEND"),k&&(v.useKHR_materials_unlit=!0),H){const{ior:i}=H;v.KHR_materials_ior=null!=i?i:1.5,v.use2PathRender=!0,v.transparent=!0}if(W){const{dispersion:i}=W;v.KHR_dispersion=i||0,v.use2PathRender=!0,v.transparent=!0}z&&((i,g,x)=>{i.KHR_sheenColorFactor=g.sheenColorFactor||[0,0,0],i.KHR_sheenRoughnessFactor=g.sheenRoughnessFactor||0,i.useKHR_materials_sheen=!0;const{sheenColorTexture:_,sheenRoughnessTexture:v}=g;_&&parseMaterialTexture(x,i,_,"KHR_sheenColorTexture",`${navigator.gpu.getPreferredCanvasFormat()}-srgb`,!1),v&&parseMaterialTexture(x,i,v,"KHR_sheenRoughnessTexture",null,!1)})(v,z,i),q&&((i,g,x)=>{i.useKHR_materials_specular=!0,i.KHR_specularFactor=g.specularFactor??1,i.KHR_specularColorFactor=g.specularColorFactor||[1,1,1];const{specularTexture:_,specularColorTexture:v}=g;_&&parseMaterialTexture(x,i,_,"KHR_specularTexture"),v&&parseMaterialTexture(x,i,v,"KHR_specularColorTexture",`${navigator.gpu.getPreferredCanvasFormat()}-srgb`)})(v,q,i)}}else v=new PBRMaterial(_);Object.hasOwn(x.attributes,"COLOR_0")&&(v.useVertexColor=!0),v.doubleSided=b,v.cutOff=S;const{blendColorState:w,blendAlphaState:L}=v;switch(y){case"BLEND":v.alphaBlend=2,w.srcFactor=mr.SRC_ALPHA,w.dstFactor=mr.ONE_MINUS_SRC_ALPHA,L.srcFactor=mr.SRC_ALPHA,L.dstFactor=mr.ONE_MINUS_SRC_ALPHA,v.transparent=!0;break;case"MASK":v.alphaBlend=1,v.useCutOff=!0,w.srcFactor=mr.ONE,w.dstFactor=mr.ZERO,L.srcFactor=mr.ONE,L.dstFactor=mr.ZERO;break;default:w.srcFactor=mr.ONE,w.dstFactor=mr.ZERO,L.srcFactor=mr.ONE,L.dstFactor=mr.ZERO,v.alphaBlend=0}return v},parseIndicesInfo_GLTF=(i,g)=>{const{accessor:x,startIndex:_,getMethod:v,bufferURIDataView:b,componentType_BYTES_PER_ELEMENT:y}=i,{type:S,count:w}=x;let L,k=_;if("SCALAR"===S)for(L=k+w;k{let z,q,W,be,Ke,Xe,je,Ye,Ze,Je=0,Qe=g.length/3,et=0;const tt=g.length,it=_.length,ft=b.length,pt=x.length,xt=S.length,vt=w.length,bt=L.length;if(z=W=Xe=0,q=be=je=1,Ke=Ye=2,Ze=3,k)for(;Je{let x=i[0],_=i[1],v=i[2],b=i[3],y=x+x,S=_+_,w=v+v,L=x*y,k=x*S,H=x*w,z=_*S,q=_*w,W=v*w,be=b*y,Ke=b*S,Xe=b*w;return g[0]=1-(z+W),g[4]=k-Xe,g[8]=H+Ke,g[1]=k+Xe,g[5]=1-(L+W),g[9]=q-be,g[2]=H-Ke,g[6]=q+be,g[10]=1-(L+z),g[3]=0,g[7]=0,g[11]=0,g[12]=0,g[13]=0,g[14]=0,g[15]=1,g},ra=180/Math.PI,setMeshRotation=(i,g)=>{g.setRotation(i[0]*ra,i[1]*ra,i[2]*ra)},parseTRSAndMATRIX_GLTF=(i,g)=>{const{matrix:x,rotation:_,translation:v,scale:b}=g;let y,S;if(y=create$4(),"matrix"in g){S=create$3(),mat4ToEuler(x,S),setMeshRotation(S,i),i.setPosition(x[12],x[13],x[14]);const g=fromValues$3(1,1,1);getScaling(g,x),i.setScale(g[0],g[1],g[2])}else"rotation"in g&&(S=create$3(),quaternionToRotationMat4(_,y),mat4ToEuler(y,S),setMeshRotation(S,i)),"translation"in g&&i.setPosition(v[0],v[1],v[2]),"scale"in g&&(i.setScale(b[0],b[1],b[2]),(b[0]<0||b[1]<0||b[2]<0)&&(i.primitiveState.frontFace=ti.CW))},parseChildrenAndSkin=(i,g,x,_,v)=>{if("children"in _){const v=_.children,b=v.length;for(let _=0;_{const v=new ParsedSkinInfo_GLTF,b=[],{nodes:y}=g,{joints:S,skeleton:w}=x;{let g=0;const x=S.length;for(;g{const{redGPUContext:v,parsingResult:b}=i,{nodes:y,meshes:S,skins:w}=g,{groups:L,cameras:k}=b,H=y[x];if("mesh"in H){const v=function(i,g,x,_){const{redGPUContext:v}=i;let b;x.name&&(b=x.name);const y=[],{primitives:S}=x;let w=0;const L=S.length;for(;w-1;if(b){const i=`TEXCOORD_${tt.size}`;tt.set(x,i)}parseAttributeInfo_GLTF(b?tt.get(x):x,v,W,Ke,Xe,0,Ye,Ze,Je,be,Qe),v.accessor.sparse&&parseSparse_GLTF(i,x,v.accessor,g,W)}if("indices"in L){let x=L.indices,_=new AccessorInfo_GLTF(i,g,x);parseIndicesInfo_GLTF(_,q)}H=parseMaterialInfo_GLTF(i,g,L),H instanceof PBRMaterial&&i.parsingResult.materials.push(H);let it,ft=!1;if("mode"in L)switch(L.mode){case 0:z=Lr.POINT_LIST;break;case 1:case 2:z=Lr.LINE_LIST;break;case 3:z=Lr.LINE_STRIP,ft=!0;break;case 4:case 6:z=Lr.TRIANGLE_LIST;break;case 5:z=Lr.TRIANGLE_STRIP,ft=!0}be.length&&(H.useVertexColor_0=!0),it=Ye.length?Ye:calculateNormals(W,q),Qe.length&&(H.useVertexTangent=!0);let pt,xt=[];parseInterleaveData_GLTF(xt,W,be,it,Ke,Xe,0,Ze,Je,Qe);let vt={};W.length&&(vt.aVertexPosition=VertexInterleaveType.float32x3),it.length&&(vt.aVertexNormal=VertexInterleaveType.float32x3),Ke.length&&(vt.aTexcoord=VertexInterleaveType.float32x2),(je.length||Xe.length||Ke.length)&&(vt.aTexcoord1=VertexInterleaveType.float32x2),vt.aVertexColor_0=VertexInterleaveType.float32x4,vt.aVertexTangent=VertexInterleaveType.float32x4;const bt=[],yt=[];parseInterleaveData_GLTF(bt,W,be,it,Ke,Xe,0,Ze,Je,Qe,!0),parseInterleaveData_GLTF(yt,W,be,it,Ke,Xe,0,Ze,Je,Qe,!1,!0);const St=new VertexBuffer(v,bt,new VertexInterleavedStruct({aVertexWeight:VertexInterleaveType.float32x4}),void 0,`Weight_${i.url}_${_}_${w}`),Tt=new IndexBuffer(v,yt,GPUBufferUsage.STORAGE|GPUBufferUsage.COPY_DST,`Joint_${i.url}_${_}_${w}`);let Mt=new MorphInfo_GLTF(i,g,L,x.weights);const wt=`Vertex_${i.url}_${_}_${w}_${Mt.weights.length?createUUID():""}`,Ct=v.resourceManager.managedVertexBufferState.table.get(wt)?.buffer;if(pt=new Geometry(v,Ct||new VertexBuffer(v,xt,new VertexInterleavedStruct(vt,"PBR"),void 0,wt),!ft&&q.length?new IndexBuffer(v,new Uint32Array(q),void 0,`Index_${i.url}_${_}_${w}`):null),H||consoleAndThrowError("재질을 파싱할수없는경우 ",L),k=new Mesh(v,pt,H),k.animationInfo.weightBuffer=St,k.animationInfo.jointBuffer=Tt,b&&(k.name=b,i.parsingOption))for(let g in i.parsingOption)b.toLowerCase().indexOf(g)>-1&&i.parsingOption[g](k);k.primitiveState.topology=z||Lr.TRIANGLE_LIST,k.material.doubleSided&&(k.primitiveState.cullMode=ei.NONE),k.material.use2PathRender&&(k.primitiveState.cullMode=ei.NONE,k.depthStencilState.depthCompare=Tn.LESS_EQUAL),2===k.material.alphaBlend&&(k.depthStencilState.depthCompare=Tn.LESS_EQUAL),k.animationInfo.morphInfo=Mt,k.animationInfo.morphInfo.origin=new Float32Array(xt);let Rt=k.geometry.vertexBuffer.data;k.gpuRenderInfo||k.initGPURenderInfos();let Pt=0;for(const i in vt)Pt+=vt[i].numElements;if(!Ct){const i=k.animationInfo.morphInfo.morphInfoDataList;let g=0;const x=i.length,_=Rt.length;for(;g{g.extensionsUsed?.includes("KHR_draco_mesh_compression")&&alert("RedGPU GLTFLoader does not support the KHR_draco_mesh_compression extension. Models using this extension may not load properly."),requestAnimationFrame(()=>{(i=>{const g=i?.asset;g||consoleAndThrowError("GLTFLoader - asset must be defined"),g.version||consoleAndThrowError("GLTFLoader - asset version must be defined");const x=parseFloat(g.version);isNaN(x)&&consoleAndThrowError("GLTFLoader - asset version must be a numerical value"),x<2&&consoleAndThrowError("GLTFLoader - asset version must be 2.0 or higher")})(g),requestAnimationFrame(()=>{((i,g,x,_)=>{const{parsingResult:v}=i,{uris:b}=v,y="buffers",S=b[y],w=g.buffers,L=w.length;let k=0;checkProgress(i,g,k),w.forEach((v,b)=>{var w;function checkLoadingStatus(){checkProgress(i,g,k),_?.(i.loadingProgressInfo),k===L&&x&&x()}v._redURIkey=y,v._redURIIndex=b,v.uri instanceof ArrayBuffer?(w=new DataView(v.uri),k++,S[b]=w,checkLoadingStatus()):function(g){const x=g.startsWith("data:")?g:i.filePath+g;arrayBufferLoader(x,function(i){k++,S[b]=new DataView(i),checkLoadingStatus()},function(i,g){})}(v.uri)})})(i,g,()=>{requestAnimationFrame(()=>{((i,g,x)=>{const{scenes:_}=g;_[0].nodes.forEach(x=>{parseNode_GLTF(i,g,x,i.resultMesh)}),x?.()})(i,g,()=>{requestAnimationFrame(()=>{((i,g)=>{const{cameras:x}=g;x&&x.forEach(function(g){let x=new PerspectiveCamera;"orthographic"==g.type||(x.fieldOfView=180*g.perspective.yfieldOfView/Math.PI,x.farClipping=g.perspective.zfar,x.nearClipping=g.perspective.znear),i.parsingResult.cameras.push(x)})})(i,g),new TextureLoader(i.redGPUContext,Object.values(i.parsingResult.textureRawList),_=>{_.textures.forEach(i=>{const{targetTextureKey:g,targetSamplerKey:x,samplerList:_}=i.srcInfo;i.srcInfo.materialList.forEach((v,b)=>{v[g]=i.texture,_[b]&&(v[x]=_[b])})}),parseAnimations(i,g).then(i=>{x&&x()})},g=>{i.loadingProgressInfo.textures=g,_?.(i.loadingProgressInfo)})})})})},_)})})},ia=new Map,aa=new Map,parseFileGLB=async(i,x,_)=>{const v=getAbsoluteURL(window.location.href,i.filePath+i.fileName),progress=()=>{if(_){const g=ia.get(v);i.loadingProgressInfo.model={loaded:g.byteLength,total:g.byteLength,lengthComputable:!0,percent:100,transferred:"Cached",totalSize:"Cached"},_(i.loadingProgressInfo)}};if(ia.has(v))return g("GLB Model parsing has cache",v),progress(),void await parseArrayBuffer(i,ia.get(v),x,_);if(aa.has(v))return await aa.get(v),progress(),void await parseArrayBuffer(i,ia.get(v),x,_);const b=new Promise((x,b)=>{(async(i,g,x=()=>{},_=()=>{})=>{try{const x=await fetch(i);if(!x.ok)throw new Error(`HTTP error! status:${x.status}`);const v=x.headers.get("content-length"),b=v?parseInt(v,10):0,y=b>0,S=y?formatBytes(b):"Unknown";if(!x.body)return void g(new ArrayBuffer(0));const w=x.body.getReader();let L=0;const k=[];for(;;){const{done:i,value:g}=await w.read();if(i)break;g&&(k.push(g),L+=g.length,_({loaded:L,total:b,lengthComputable:y,percent:y?Math.min(100,parseFloat((L/b*100).toFixed(2))):0,transferred:formatBytes(L),totalSize:S}))}if(0===L)return void g(new ArrayBuffer(0));const H=new Blob(k);g(await H.arrayBuffer())}catch(i){x?x(i):console.error("getArrayBufferFromSrc 로딩 중 오류 발생:",i)}})(v,i=>{ia.set(v,i),g("GLB Model parsing set cache",v),aa.delete(v),x(i)},i=>{g("GLB Model parsing error",i),aa.delete(v),b(i)},g=>{i.loadingProgressInfo.model=g,_?.(i.loadingProgressInfo)})});aa.set(v,b);try{const g=await b;await parseArrayBuffer(i,g,x,_)}catch(i){}},parseArrayBuffer=async(i,g,x,_)=>{const{content:v,binaryChunk:b}=parseBuffer(g);if(null===v)throw new Error("JSON content not found");const y=JSON.parse(v);processImagesIfExist(y,b),y.buffers[0].uri=b,i.gltfData=y,parseGLTF(i,y,x,_)},parseBuffer=i=>{let g=null,x=null;const _=new DataView(i,12),v=_.byteLength;for(let b=0;b{const{images:x,bufferViews:_}=i,v=["image/png","image/jpeg","image/gif","image/webp"],b=new Map;if(x)for(let i=0;i{let g="";for(let x of i)g+=String.fromCharCode(x);return g},sa=new Map,oa=new Map,getData=i=>({...i,meshes:JSON.parse(JSON.stringify(i.meshes))});class GLTFLoader{parsingResult;resultMesh;parsingOption;activeAnimations=[];#l;#gh;#xh;#_h;#vh;#bh;#H;#z;#yh;#Sh={url:"",model:{loaded:0,total:0,lengthComputable:!0,percent:0,transferred:"0",totalSize:"0"}};constructor(i,g,x,_,v){validateRedGPUContext(i),this.#l=i,this.#_h=g,this.#gh=getFilePath(g),this.#xh=getFileName(g),this.#vh=getFileExtension(g),this.#H=x,this.#yh=_,this.#z=v,this.parsingResult={groups:[],materials:[],uris:{buffers:[]},textures:{},textureRawList:[],cameras:[],animations:[]},this.resultMesh=new Mesh(this.#l),this.resultMesh.gltfLoaderInfo=this,this.resultMesh.animationInfo.animationsList=this.parsingResult.animations,this.#Sh.url=getFileName(g),this.#Th()}get loadingProgressInfo(){return this.#Sh}get redGPUContext(){return this.#l}get filePath(){return this.#gh}get gltfData(){return this.#bh}set gltfData(i){this.#bh=i}get fileName(){return this.#xh}get url(){return this.#_h}stopAnimation(){this.activeAnimations.length=0}playAnimation(i){const{activeAnimations:g}=this;g.push(new PlayAnimationInfo(performance.now(),i))}async#Th(){try{"glb"===this.#vh?parseFileGLB(this,()=>this.#H(this),this.#yh):"gltf"===this.#vh?(async(i,x,_)=>{const v=getAbsoluteURL(window.location.href,i.filePath+i.fileName),cachedProgress=()=>{if(_){const g=sa.get(v);i.loadingProgressInfo.model={loaded:g.byteLength,total:g.byteLength,lengthComputable:!0,percent:100,transferred:"Cached",totalSize:"Cached"},_(i.loadingProgressInfo)}};if(sa.has(v))return i.gltfData=getData(sa.get(v)),cachedProgress(),void requestAnimationFrame(()=>{parseGLTF(i,i.gltfData,x,_)});if(oa.has(v))return await oa.get(v),cachedProgress(),i.gltfData=getData(sa.get(v)),void requestAnimationFrame(()=>{parseGLTF(i,i.gltfData,x,_)});const b=new Promise(async(x,b)=>{try{const b=await fetch(i.url);if(!b.ok)throw new Error("GLTF 네트워크 오류:"+b.status);const y=b.headers.get("content-length"),S=y?parseInt(y,10):0;g(`전체 사이즈:${S} bytes`);const w=await b.json();sa.set(v,w),i.loadingProgressInfo.model={loaded:S,total:S,lengthComputable:!0,percent:100,transferred:formatBytes(S),totalSize:formatBytes(S)};{g(w);const x=w.buffers.length;if(x){let g=0;i.loadingProgressInfo.buffers={loaded:g,total:x,percent:Math.min(100,parseFloat((g/x*100).toFixed(2)))}}}_?.(i.loadingProgressInfo),x(w)}catch(i){b(i)}finally{oa.delete(v)}});oa.set(v,b);const y=await b;i.gltfData=getData(y),requestAnimationFrame(()=>{parseGLTF(i,i.gltfData,x,_)})})(this,()=>this.#H(this),this.#yh):consoleAndThrowError("Unknown file extension:"+this.#vh)}catch(i){this.#z?.(i)}}}Object.freeze(GLTFLoader);class PlayAnimationInfo{startTime;targetGLTFParsedSingleClip;constructor(i,g){this.startTime=i,this.targetGLTFParsedSingleClip=g}}var ua=Object.freeze({__proto__:null,AABB:AABB,OBB:OBB,calculateGeometryAABB:calculateGeometryAABB,calculateMeshAABB:calculateMeshAABB,calculateMeshCombinedAABB:calculateMeshCombinedAABB,calculateMeshOBB:calculateMeshOBB}),la=Object.freeze({__proto__:null,AController:AController});const ca=Math.PI/180,updateObject3DMatrix=(i,g)=>{const{pixelRectObject:x}=g,_=i.parent,v=i.localMatrix;identity$1(v),translate(v,v,[i.x,i.y,i.z]),rotateX$2(v,v,i.rotationX*ca),rotateY$2(v,v,i.rotationY*ca),rotateZ$2(v,v,i.rotationZ*ca);let b=[i.scaleX,i.scaleY,i.scaleZ];if(i.renderTextureWidth&&(b[0]*=i.renderTextureWidth/x.height,b[1]*=i.renderTextureHeight/x.height),scale$4(v,v,b),i.pivotX||i.pivotY||i.pivotZ){translate(v,v,[-i.pivotX,-i.pivotY,-i.pivotZ])}_?.modelMatrix?multiply$4(i.modelMatrix,_.modelMatrix,i.localMatrix):copy$4(i.modelMatrix,i.localMatrix)},ha=Math.PI/180;const fa=Math.PI/180,da=create$4(),ma=create$3();const pa=Math.PI/180,ga=1e-4,xa=create$4();var _a=Object.freeze({__proto__:null,Camera2D:Camera2D,Core:la,FollowController:class extends AController{#Mh=10;#wh=10;#Ch=.02;#Rh=5;#Ph=5;#Bh=.02;#Ih=.02;#Eh=0;#Dh=0;#Uh=.02;#Lh=20;#Ah=20;#Gh=.02;#kh=!0;#Oh=0;#Nh=0;#Vh=0;#Sa;#Fh=create$3();constructor(i,g){super(i,{HD_Wheel:i=>{this.#wh+=i.deltaY/100},HD_TouchPinch:i=>{const g=i-1;this.#wh-=g*this.#wh}}),this.targetMesh=g,this.#Sa.setIgnoreFrustumCullingRecursively(!0)}get distance(){return this.#wh}set distance(i){validateNumberRange(i,.1),this.#wh=i}get distanceInterpolation(){return this.#Ch}set distanceInterpolation(i){validateNumberRange(i,.01,1),this.#Ch=i}get height(){return this.#Ph}set height(i){validateNumber(i),this.#Ph=i}get heightInterpolation(){return this.#Bh}set heightInterpolation(i){validateNumberRange(i,.01,1),this.#Bh=i}get pan(){return this.#Dh}set pan(i){validateNumber(i),this.#Dh=i}get panInterpolation(){return this.#Uh}set panInterpolation(i){validateNumberRange(i,.01,1),this.#Uh=i}get tilt(){return this.#Ah}set tilt(i){validateNumber(i),this.#Ah=Math.max(-89,Math.min(89,i))}get tiltInterpolation(){return this.#Gh}set tiltInterpolation(i){validateNumberRange(i,.01,1),this.#Gh=i}get interpolation(){return this.#Ih}set interpolation(i){validateNumberRange(i,.01,1),this.#Ih=i}get followTargetRotation(){return this.#kh}set followTargetRotation(i){this.#kh=i}get targetOffsetX(){return this.#Oh}set targetOffsetX(i){validateNumber(i),this.#Oh=i}get targetOffsetY(){return this.#Nh}set targetOffsetY(i){validateNumber(i),this.#Nh=i}get targetOffsetZ(){return this.#Vh}set targetOffsetZ(i){validateNumber(i),this.#Vh=i}get targetMesh(){return this.#Sa}set targetMesh(i){if(!i)throw new Error("FollowController:targetMesh cannot be null or undefined");this.#Sa=i,this.#Sa.setIgnoreFrustumCullingRecursively(!0),this.#Hh()}setTargetOffset(i,g=0,x=0){validateNumber(i),validateNumber(g),validateNumber(x),this.#Oh=i,this.#Nh=g,this.#Vh=x}update(i,g){super.update(i,g,g=>{const{targetMesh:x}=this;x&&updateObject3DMatrix(x,i),this.#Mh=this.#wh+(this.#Mh-this.#wh)*Math.pow(this.#Ch,g),this.#Rh=this.#Ph+(this.#Rh-this.#Ph)*Math.pow(this.#Bh,g);let _=(this.#Dh-this.#Eh)%360;_>180&&(_-=360),_<-180&&(_+=360),this.#Eh+=_*(1-Math.pow(this.#Uh,g)),this.#Lh=this.#Ah+(this.#Lh-this.#Ah)*Math.pow(this.#Gh,g);const v=this.#zh(),b=Math.pow(this.#Ih,g);this.#Fh[0]=v[0]+(this.#Fh[0]-v[0])*b,this.#Fh[1]=v[1]+(this.#Fh[1]-v[1])*b,this.#Fh[2]=v[2]+(this.#Fh[2]-v[2])*b,this.camera.setPosition(this.#Fh[0],this.#Fh[1],this.#Fh[2]);const y=this.#$h();this.camera.lookAt(y[0],y[1],y[2])})}#zh(){const i=this.#Eh*fa,g=this.#Lh*fa,x=Math.cos(g),_=Math.sin(g),v=Math.cos(i),b=Math.sin(i),y=this.#Sa.modelMatrix,S=y[12],w=y[13],L=y[14];return this.#kh?(set$3(ma,b*this.#Mh*x,_*this.#Mh+this.#Rh,v*this.#Mh*x),copy$4(da,y),da[12]=da[13]=da[14]=0,transformMat4$2(ma,ma,da),fromValues$3(S+ma[0],w+ma[1],L+ma[2])):fromValues$3(S+this.#Mh*x*b,w+this.#Rh+this.#Mh*_,L+this.#Mh*x*v)}#$h(){set$3(ma,this.#Oh,this.#Nh,this.#Vh);const i=this.#Sa.modelMatrix,g=i[12],x=i[13],_=i[14];return!this.#kh||0===this.#Oh&&0===this.#Nh&&0===this.#Vh||(copy$4(da,i),da[12]=da[13]=da[14]=0,transformMat4$2(ma,ma,da)),fromValues$3(g+ma[0],x+ma[1],_+ma[2])}#Hh(){updateObject3DMatrix(this.#Sa,{pixelRectObject:{height:1}}),this.#Mh=this.#wh,this.#Rh=this.#Ph,this.#Eh=this.#Dh,this.#Lh=this.#Ah;const i=this.#zh();copy$3(this.#Fh,i),this.camera.setPosition(this.#Fh[0],this.#Fh[1],this.#Fh[2]);const g=this.#$h();this.camera.lookAt(g[0],g[1],g[2])}},FreeController:class extends AController{#Ra={moveForward:"w",moveBack:"s",moveLeft:"a",moveRight:"d",moveUp:"e",moveDown:"q",turnLeft:"z",turnRight:"c",turnUp:"r",turnDown:"f"};#wa=600;#Kh=.001;#Xh=1;#jh=0;#Yh=360;#qh=.001;#Wh=.15;#Zh=[0,0,0];#Jh=0;#Qh=0;#Sa;#ef=create$4();#tf=create$4();#nf=create$3();constructor(i){super(i,{HD_Move:(i,g)=>{this.#Jh-=i*this.#Wh,this.#Qh-=g*this.#Wh},useKeyboard:!0}),this.#sa()}get x(){return this.#Sa.x}set x(i){validateNumber(i),this.#Sa.x=i,this.#Zh[0]=i}get y(){return this.#Sa.y}set y(i){validateNumber(i),this.#Sa.y=i,this.#Zh[1]=i}get z(){return this.#Sa.z}set z(i){validateNumber(i),this.#Sa.z=i,this.#Zh[2]=i}get pan(){return this.#Jh}set pan(i){validateNumber(i),this.#Jh=i}get tilt(){return this.#Qh}set tilt(i){validateNumber(i),this.#Qh=Math.max(-89.9,Math.min(89.9,i))}get mouseSensitivity(){return this.#Wh}set mouseSensitivity(i){validateNumberRange(i,.01),this.#Wh=i}get moveSpeed(){return this.#wa}set moveSpeed(i){validateNumberRange(i,.01),this.#wa=i}get moveSpeedInterpolation(){return this.#Kh}set moveSpeedInterpolation(i){validateNumberRange(i,1e-4,1),this.#Kh=i}get rotationSpeed(){return this.#Yh}set rotationSpeed(i){validateNumberRange(i,.01),this.#Yh=i}get rotationSpeedInterpolation(){return this.#qh}set rotationSpeedInterpolation(i){validateNumberRange(i,1e-4,1),this.#qh=i}get maxAcceleration(){return this.#Xh}set maxAcceleration(i){this.#Xh=i}get keyNameMapper(){return{...this.#Ra}}setMoveForwardKey(i){this.#Ra.moveForward=i}setMoveBackKey(i){this.#Ra.moveBack=i}setMoveLeftKey(i){this.#Ra.moveLeft=i}setMoveRightKey(i){this.#Ra.moveRight=i}setMoveUpKey(i){this.#Ra.moveUp=i}setMoveDownKey(i){this.#Ra.moveDown=i}setTurnLeftKey(i){this.#Ra.turnLeft=i}setTurnRightKey(i){this.#Ra.turnRight=i}setTurnUpKey(i){this.#Ra.turnUp=i}setTurnDownKey(i){this.#Ra.turnDown=i}update(i,g){super.update(i,g,x=>{this.#Ia(i,g,x)})}#sa(){this.#Sa=new Mesh(this.redGPUContext)}#Ia(i,g,x){const _=this.#Sa,v=Math.pow(this.#Kh,x),b=Math.pow(this.#qh,x);let y=(this.#Jh-_.rotationY)%360;y>180&&(y-=360),y<-180&&(y+=360),_.rotationY+=y*(1-b);const S=this.#Qh-_.rotationX;_.rotationX+=S*(1-b),this.#rf(i,x)&&(updateObject3DMatrix(_,i),identity$1(this.#tf),rotateY$2(this.#tf,this.#tf,_.rotationY*ha),rotateX$2(this.#tf,this.#tf,_.rotationX*ha),translate(this.#tf,this.#tf,this.#nf),identity$1(this.#ef),translate(this.#ef,this.#ef,_.position),multiply$4(this.#ef,this.#ef,this.#tf),this.#Zh[0]=this.#ef[12],this.#Zh[1]=this.#ef[13],this.#Zh[2]=this.#ef[14]),_.x+=(this.#Zh[0]-_.x)*(1-v),_.y+=(this.#Zh[1]-_.y)*(1-v),_.z+=(this.#Zh[2]-_.z)*(1-v),identity$1(this.#ef),translate(this.#ef,this.#ef,_.position),rotateY$2(this.#ef,this.#ef,_.rotationY*ha),rotateX$2(this.#ef,this.#ef,_.rotationX*ha),this.camera.setPosition(_.x,_.y,_.z);const w=fromValues$3(0,0,-10);transformMat4$2(w,w,this.#ef),this.camera.lookAt(w[0],w[1],w[2])}#rf(i,g){if(!this.checkKeyboardInput(i,this.#Ra))return!1;const{keyboardKeyBuffer:x}=i.redGPUContext,_=this.#wa*g,v=this.#Yh*g,b=this.#Ra;let y=!1,S=!1,w=0,L=0;this.#nf[0]=0,this.#nf[1]=0,this.#nf[2]=0;const k=this.#jh*_;x[b.turnLeft]&&(S=!0,w=v),x[b.turnRight]&&(S=!0,w=-v),x[b.turnUp]&&(S=!0,L=v),x[b.turnDown]&&(S=!0,L=-v),x[b.moveForward]&&(y=!0,this.#nf[2]=-k),x[b.moveBack]&&(y=!0,this.#nf[2]=k),x[b.moveLeft]&&(y=!0,this.#nf[0]=-k),x[b.moveRight]&&(y=!0,this.#nf[0]=k),x[b.moveUp]&&(y=!0,this.#nf[1]=k),x[b.moveDown]&&(y=!0,this.#nf[1]=-k);const H=3*g;return this.#jh=S||y?Math.min(this.#Xh,this.#jh+H):Math.max(0,this.#jh-H),S&&(this.#Jh+=w,this.#Qh=Math.max(-89.9,Math.min(89.9,this.#Qh+L))),y||S}},IsometricController:IsometricController,OrbitController:class extends AController{#if=0;#af=0;#sf=0;#of=15;#uf=1.5;#Ch=.02;#lf=.1;#Pr=1/0;#Jh=0;#Qh=-35;#cf=3;#qh=.02;#hf=-90;#ff=90;#Eh=0;#Lh=0;#Mh=0;constructor(i){super(i,{HD_Move:(i,g)=>{this.#Jh-=i*this.#cf*.1,this.#Qh-=g*this.#cf*.1},HD_Wheel:i=>{this.#of+=i.deltaY/100*this.#uf,this.#ofthis.#Pr&&(this.#of=this.#Pr)},HD_TouchPinch:i=>{const g=(i-1)*this.#uf;this.#of-=g*this.#of,this.#ofthis.#Pr&&(this.#of=this.#Pr)}}),this.#Eh=this.#Jh,this.#Lh=this.#Qh,this.#Mh=this.#of}get centerX(){return this.#if}set centerX(i){this.#if=i}get centerY(){return this.#af}set centerY(i){this.#af=i}get centerZ(){return this.#sf}set centerZ(i){this.#sf=i}get distance(){return this.#of}set distance(i){validateNumberRange(i,0),this.#of=i}get speedDistance(){return this.#uf}set speedDistance(i){validateNumberRange(i,.01),this.#uf=i}get distanceInterpolation(){return this.#Ch}set distanceInterpolation(i){validateNumberRange(i,.01,1),this.#Ch=i}get minDistance(){return this.#lf}set minDistance(i){validateNumberRange(i,.1),this.#lf=i}get maxDistance(){return this.#Pr}set maxDistance(i){validateNumberRange(i,.1),this.#Pr=i}get speedRotation(){return this.#cf}set speedRotation(i){validateNumberRange(i,.01),this.#cf=i}get rotationInterpolation(){return this.#qh}set rotationInterpolation(i){validateNumberRange(i,.01,1),this.#qh=i}get pan(){return this.#Jh}set pan(i){this.#Jh=i}get tilt(){return this.#Qh}set tilt(i){validateNumberRange(i,-90,90),this.#Qh=i}get minTilt(){return this.#hf}set minTilt(i){validateNumberRange(i,-90,90),this.#hf=i}get maxTilt(){return this.#ff}set maxTilt(i){validateNumberRange(i,-90,90),this.#ff=i}#df(i,g){updateObject3DMatrix(i,g);let x=i.children.length;for(let _=0;_{this.#Ia(i)})}#Ia(i){this.#Qhthis.#ff&&(this.#Qh=this.#ff);const{camera:g}=this;let x=(this.#Jh-this.#Eh)%360;x>180&&(x-=360),x<-180&&(x+=360),Math.abs(x)>ga?this.#Eh+=x*(1-Math.pow(this.#qh,i)):this.#Eh=this.#Jh;const _=this.#Qh-this.#Lh;Math.abs(_)>ga?this.#Lh+=_*(1-Math.pow(this.#qh,i)):this.#Lh=this.#Qh,this.#ofthis.#Pr&&(this.#of=this.#Pr);const v=this.#of-this.#Mh;Math.abs(v)>1e-4?this.#Mh+=v*(1-Math.pow(this.#Ch,i)):this.#Mh=this.#of,this.#Mh uniforms:Uniforms;\n@group(2) @binding(1) var skyboxTextureSampler:sampler;\n@group(2) @binding(2) var skyboxTexture:texture_cube;\n@group(2) @binding(3) var transitionTexture:texture_cube;\n@group(2) @binding(4) var transitionAlphaTexture:texture_2d;\nstruct InputData { @location(0) vertexPosition:vec4,\n};\nfn sphericalToUV(dir:vec3) -> vec2 { let normalizedDir=normalize(dir); let phi=atan2(normalizedDir.z,normalizedDir.x); let theta=acos(clamp(normalizedDir.y,-1.0,1.0)); let u=(phi + 3.14159265359)/(2.0 * 3.14159265359); let v=theta/3.14159265359; return vec2(u,v);\n}\n@fragment\nfn main(inputData:InputData) -> FragmentOutput { var cubemapVec=(inputData.vertexPosition.xyz); let mipmapCount:f32=f32(textureNumLevels(skyboxTexture) - 1); let blurCurve=uniforms.blur * uniforms.blur; let skyboxColor=textureSampleLevel(skyboxTexture,skyboxTextureSampler,cubemapVec,mipmapCount * blurCurve); var sampleColor=skyboxColor; let u_transitionProgress=uniforms.transitionProgress; if (u_transitionProgress > 0.0) { let transitionSample=textureSampleLevel(transitionTexture,skyboxTextureSampler,cubemapVec,mipmapCount * blurCurve); #redgpu_if transitionAlphaTexture let uv=sphericalToUV(normalize(cubemapVec)); let transitionAlphaSample=textureSampleLevel(transitionAlphaTexture,skyboxTextureSampler,uv,0.0); let transitionAlphaValue=dot(transitionAlphaSample.rgb,vec3(0.299,0.587,0.114)); let threshold=u_transitionProgress; let noiseInfluence=0.3; let edgeSoftness=0.1; let maskValue=smoothstep( threshold - edgeSoftness, threshold + edgeSoftness, transitionAlphaValue + (u_transitionProgress - 0.5) * noiseInfluence ); sampleColor=mix(transitionSample,skyboxColor,maskValue * (1.0 - u_transitionProgress)); #redgpu_else sampleColor=mix(skyboxColor,transitionSample,u_transitionProgress); #redgpu_endIf } var outColor=vec4(sampleColor.rgb,sampleColor.a * uniforms.opacity); if (outColor.a==0.0) { discard; } var output:FragmentOutput; output.color=outColor; return output;\n}\n");class SkyBoxMaterial extends ABitmapBaseMaterial{dirtyPipeline=!1;constructor(i,g){super(i,"SKYBOX_MATERIAL",Sa,2),this.skyboxTexture=g,this.skyboxTextureSampler=new Sampler(this.redGPUContext,{addressModeU:"clamp-to-edge",addressModeV:"clamp-to-edge",addressModeW:"clamp-to-edge"}),this.initGPURenderInfos()}}dr.definePositiveNumber(SkyBoxMaterial,[["blur",0],["opacity",1,0,1]]),dr.definePositiveNumber(SkyBoxMaterial,[["transitionProgress",0]]),dr.defineCubeTexture(SkyBoxMaterial,["transitionTexture"]),dr.defineTexture(SkyBoxMaterial,["transitionAlphaTexture"]),dr.defineCubeTexture(SkyBoxMaterial,["skyboxTexture"]),dr.defineSampler(SkyBoxMaterial,["skyboxTextureSampler"]),Object.freeze(SkyBoxMaterial);var Ta="#redgpu_include SYSTEM_UNIFORM;\nstruct InputData { @location(0) position:vec3, @location(1) vertexNormal:vec3, @location(2) uv:vec2,\n};\nstruct OutData { @builtin(position) position:vec4, @location(0) vertexPosition:vec4,\n};\nstruct VertexUniforms { modelMatrix:mat4x4,\n};\n@group(1) @binding(0) var vertexUniforms:VertexUniforms;\n@vertex\nfn main(inputData:InputData) -> OutData { var outData:OutData; let u_projectionMatrix=systemUniforms.projectionMatrix; let u_projectionCameraMatrix=systemUniforms.projectionCameraMatrix; let u_camera=systemUniforms.camera; let u_cameraMatrix=u_camera.cameraMatrix; outData.position=u_projectionCameraMatrix * vertexUniforms.modelMatrix * vec4(inputData.position,1.0); outData.vertexPosition=vec4(inputData.position,1.0); return outData;\n}\n";const Ma=parseWGSL(Ta),wa=Ma.uniforms.vertexUniforms;class SkyBox{modelMatrix=create$4();gpuRenderInfo;#mf=!0;#oo;#pf;#Ya;#l;#ks;#Os;#gf;#xf;#_f=0;#vf=0;#bf=0;#dl;constructor(i,g){validateRedGPUContext(i),this.#l=i,this.#pf=new Box(i),this.#gf=g,this.#Ya=new SkyBoxMaterial(i,this.#gf),this.#ks=new PrimitiveState(this),this.#ks.cullMode=ei.NONE,this.#Os=new DepthStencilState(this)}get transitionDuration(){return this.#vf}get transitionElapsed(){return this.#bf}get transitionProgress(){return this.#Ya.transitionProgress}get blur(){return this.#Ya.blur}set blur(i){validatePositiveNumberRange(1,0,1),this.#Ya.blur=i}get opacity(){return this.#Ya.opacity}set opacity(i){validatePositiveNumberRange(1,0,1),this.#Ya.opacity=i}get skyboxTexture(){return this.#gf}set skyboxTexture(i){i?(this.#gf=i,this.#Ya.skyboxTexture=i):consoleAndThrowError("SkyBox requires a valid CubeTexture | IBLCubeTexture")}get transitionTexture(){return this.#xf}transition(i,g=300,x){this.#xf=i,this.#Ya.transitionTexture=i,this.#vf=g,this.#_f=performance.now(),this.#Ya.transitionAlphaTexture=x}render(i){const{currentRenderPassEncoder:g,startTime:x,view:_}=i,{indexBuffer:v}=this.#pf,{triangleCount:b,indexCount:y,format:S}=v,{gpuDevice:w,antialiasingManager:L}=this.#l,{useMSAA:k,changedMSAA:H}=L;if(this.#yf(),this.gpuRenderInfo||this.#Sf(this.#l),this.#_f)if(this.#bf=Math.max(x-this.#_f,0),this.#bf>this.#vf)this.#_f=0,this.#Ya.transitionProgress=0,this.skyboxTexture=this.#xf,this.#Ya.transitionTexture=null,this.#mf=!0;else{const i=this.#bf/this.#vf;this.#Ya.transitionProgress=i<0?0:i>1?1:i}if(this.#mf||this.#Ya.dirtyPipeline||this.#dl!==_.systemUniform_Vertex_UniformBindGroup){this.gpuRenderInfo.pipeline=this.#Tf(),this.#mf=!1,i.numDirtyPipelines++,this.#dl=_.systemUniform_Vertex_UniformBindGroup;{this.#Ya.dirtyPipeline=!1;const i=w.createRenderBundleEncoder({..._.basicRenderBundleEncoderDescriptor,label:"skybox"}),{gpuRenderInfo:g}=this,{vertexUniformBindGroup:x,pipeline:b}=g;i.setPipeline(b),i.setBindGroup(0,_.systemUniform_Vertex_UniformBindGroup),i.setVertexBuffer(0,this.#pf.vertexBuffer.gpuBuffer),i.setBindGroup(1,x),i.setBindGroup(2,this.#Ya.gpuRenderInfo.fragmentUniformBindGroup),i.setIndexBuffer(v.gpuBuffer,S),i.drawIndexed(v.indexCount,1,0,0,0),this.#oo=i.finish({label:"renderBundle skybox"})}}g.executeBundles([this.#oo]),i.num3DObjects++,i.numDrawCalls++,i.numTriangles+=b,i.numPoints+=y}#yf(){const{changedMSAA:i}=this.#l.antialiasingManager;i&&(this.#mf=!0)}#Sf(i){const{resourceManager:g}=this.#l,x=g.getGPUBindGroupLayout("SKYBOX_VERTEX_BIND_GROUP_LAYOUT")||g.createBindGroupLayout("SKYBOX_VERTEX_BIND_GROUP_LAYOUT",getVertexBindGroupLayoutDescriptorFromShaderInfo(Ma,1)),_=new ArrayBuffer(wa.arrayBufferByteLength),v=new UniformBuffer(i,_,"SKYBOX_VERTEX_UNIFORM_BUFFER","SKYBOX_VERTEX_UNIFORM_BUFFER");identity$1(this.modelMatrix),scale$4(this.modelMatrix,this.modelMatrix,[1e4,1e4,1e4]),v.writeOnlyBuffer(wa.members.modelMatrix,this.modelMatrix);const b={layout:x,label:"VERTEX_BIND_GROUP_DESCRIPTOR_SKYBOX",entries:[{binding:0,resource:{buffer:v.gpuBuffer,offset:0,size:v.size}}]},y=i.gpuDevice.createBindGroup(b);this.gpuRenderInfo=new VertexGPURenderInfo(null,Ma.shaderSourceVariant,Ma.conditionalBlocks,wa,x,v,y,this.#Tf())}#Tf(){const{resourceManager:i,gpuDevice:g,antialiasingManager:x}=this.#l,_={code:Ta},v={module:i.createGPUShaderModule("VERTEX_MODULE_SKYBOX",_),entryPoint:"main",buffers:this.#pf.gpuRenderInfo.buffers},b=i.getGPUBindGroupLayout("SKYBOX_VERTEX_BIND_GROUP_LAYOUT")||i.createBindGroupLayout("SKYBOX_VERTEX_BIND_GROUP_LAYOUT",getVertexBindGroupLayoutDescriptorFromShaderInfo(Ma,1)),y={bindGroupLayouts:[i.getGPUBindGroupLayout(ResourceManager.PRESET_GPUBindGroupLayout_System),b,this.#Ya.gpuRenderInfo.fragmentBindGroupLayout]},S={label:"PIPELINE_DESCRIPTOR_SKYBOX",layout:i.createGPUPipelineLayout("SKYBOX_PIPELINE_LAYOUT",y),vertex:v,fragment:this.#Ya.gpuRenderInfo.fragmentState,primitive:this.#ks.state,depthStencil:this.#Os.state,multisample:{count:x.useMSAA?4:1}};return g.createRenderPipeline(S)}}Object.freeze(SkyBox);var Ca=Object.freeze({__proto__:null,SkyBoxMaterial:SkyBoxMaterial});const Ra={NORMAL:0,MULTIPLY:1,LIGHTEN:2,SCREEN:3,LINEAR_DODGE:4,SUBTRACT:5,DIFFERENCE:6,EXCLUSION:7};function mixInMesh2D(i){const g=class extends i{#Mf=0;#wf=Ra.NORMAL;get blendMode(){const i=Object.entries(Ra).find(([,i])=>i===this.#wf);if(!i)throw new Error(`Invalid blendMode value:${this.#wf}`);return i[0]}set blendMode(i){let g;if("string"==typeof i){if(!(i in Ra))throw new Error(`Invalid blendMode key:${i}`);g=Ra[i]}else{if("number"!=typeof i||!Object.values(Ra).includes(i))throw new Error(`Invalid blendMode:${i}`);g=i}this.#wf=g,this.#Cf(g)}get rotation(){return this.#Mf}set rotation(i){this.#Mf=i,super.rotationZ=i}setScale(i,g){g=g??i,super.setScale(i,g,1)}setPosition(i,g){g=g??i,super.setPosition(i,g,0)}setRotation(i){this.rotation=i}#Cf(i){const{blendColorState:g,blendAlphaState:x}=this._material;switch(i){case Ra.NORMAL:g.operation=pr.ADD,g.srcFactor=mr.SRC_ALPHA,g.dstFactor=mr.ONE_MINUS_SRC_ALPHA,x.operation=pr.ADD,x.srcFactor=mr.SRC_ALPHA,x.dstFactor=mr.ONE_MINUS_SRC_ALPHA;break;case Ra.MULTIPLY:g.operation=pr.ADD,g.srcFactor=mr.ONE_MINUS_DST_ALPHA,g.dstFactor=mr.ONE_MINUS_SRC_ALPHA,x.operation=pr.ADD,x.srcFactor=mr.SRC_ALPHA,x.dstFactor=mr.ONE_MINUS_SRC_ALPHA;break;case Ra.LIGHTEN:g.operation=pr.MAX,g.srcFactor=mr.ONE,g.dstFactor=mr.ONE,x.operation=pr.ADD,x.srcFactor=mr.SRC_ALPHA,x.dstFactor=mr.ONE_MINUS_SRC_ALPHA;break;case Ra.SCREEN:g.operation=pr.ADD,g.srcFactor=mr.ONE,g.dstFactor=mr.ONE_MINUS_SRC,x.operation=pr.ADD,x.srcFactor=mr.SRC_ALPHA,x.dstFactor=mr.ONE_MINUS_SRC_ALPHA;break;case Ra.LINEAR_DODGE:g.operation=pr.ADD,g.srcFactor=mr.ONE,g.dstFactor=mr.ONE,x.operation=pr.ADD,x.srcFactor=mr.SRC_ALPHA,x.dstFactor=mr.ONE;break;case Ra.SUBTRACT:g.operation=pr.REVERSE_SUBTRACT,g.srcFactor=mr.SRC_ALPHA,g.dstFactor=mr.ONE_MINUS_SRC_ALPHA,x.operation=pr.REVERSE_SUBTRACT,x.srcFactor=mr.ONE,x.dstFactor=mr.ONE;break;case Ra.DIFFERENCE:g.operation=pr.SUBTRACT,g.srcFactor=mr.ONE,g.dstFactor=mr.ONE,x.operation=pr.SUBTRACT,x.srcFactor=mr.ONE,x.dstFactor=mr.ONE;break;case Ra.EXCLUSION:g.operation=pr.ADD,g.srcFactor=mr.ONE_MINUS_DST_ALPHA,g.dstFactor=mr.ONE_MINUS_SRC_ALPHA,x.operation=pr.ADD,x.srcFactor=mr.ONE,x.dstFactor=mr.ONE;break;default:console.warn(`Unsupported blend mode:${i}`)}}};return Object.defineProperty(g.prototype,"is2DMeshType",{value:!0,writable:!1}),g}var Pa=Object.freeze({__proto__:null,LODManager:LODManager,MeshBase:MeshBase,Object3DContainer:Object3DContainer,VertexGPURenderInfo:VertexGPURenderInfo,createMeshVertexUniformBuffers:createMeshVertexUniformBuffers,mixInMesh2D:mixInMesh2D}),Ba=Object.freeze({__proto__:null,AView:AView,RenderViewStateData:RenderViewStateData,ViewRenderTextureManager:ViewRenderTextureManager,ViewTransform:ViewTransform});class View2D extends View3D{constructor(i,g,x){super(i,g,new Camera2D,x)}}Object.freeze(View2D);class GroupBase extends Object3DContainer{modelMatrix=create$4();localMatrix=create$4();#f;#h;#Vs;#Ot=0;#Vt=0;#Nt=0;#Fs=[0,0,0];#Hs=0;#zs=0;#$s=0;#Xs=1;#js=1;#Ys=1;#qs=[1,1,1];#Di=0;#Ui=0;#Li=0;#Ws=[0,0,0];#Rf=!0;constructor(i){super(),i&&(this.name=i)}get dirtyTransform(){return this.#Rf}set dirtyTransform(i){this.#Rf=i}get name(){return this.#f||(this.#f=InstanceIdGenerator.getNextId(this.constructor)),this.#h||`${this.constructor.name} Instance ${this.#f}`}set name(i){this.#h=i}get parent(){return this.#Vs}set parent(i){this.#Vs=i}get pivotX(){return this.#Hs}set pivotX(i){this.#Hs=i,this.dirtyTransform=!0}get pivotY(){return this.#zs}set pivotY(i){this.#zs=i,this.dirtyTransform=!0}get pivotZ(){return this.#$s}set pivotZ(i){this.#$s=i,this.dirtyTransform=!0}get x(){return this.#Ot}set x(i){this.#Ot=this.#Fs[0]=i,this.dirtyTransform=!0}get y(){return this.#Nt}set y(i){this.#Nt=this.#Fs[1]=i,this.dirtyTransform=!0}get z(){return this.#Vt}set z(i){this.#Vt=this.#Fs[2]=i,this.dirtyTransform=!0}get position(){return this.#Fs}get scaleX(){return this.#Xs}set scaleX(i){this.#Xs=this.#qs[0]=i,this.dirtyTransform=!0}get scaleY(){return this.#js}set scaleY(i){this.#js=this.#qs[1]=i,this.dirtyTransform=!0}get scaleZ(){return this.#Ys}set scaleZ(i){this.#Ys=this.#qs[2]=i,this.dirtyTransform=!0}get scale(){return this.#Fs}get rotationX(){return this.#Di}set rotationX(i){this.#Di=this.#Ws[0]=i,this.dirtyTransform=!0}get rotationY(){return this.#Ui}set rotationY(i){this.#Ui=this.#Ws[1]=i,this.dirtyTransform=!0}get rotationZ(){return this.#Li}set rotationZ(i){this.#Li=this.#Ws[2]=i,this.dirtyTransform=!0}get rotation(){return this.#Ws}setScale(i,g,x){g=g??i,x=x??i;const _=this.#qs;this.#Xs=_[0]=i,this.#js=_[1]=g,this.#Ys=_[2]=x,this.dirtyTransform=!0}setPosition(i,g,x){g=g??i,x=x??i;const _=this.#Fs;this.#Ot=_[0]=i,this.#Nt=_[1]=g,this.#Vt=_[2]=x,this.dirtyTransform=!0}setRotation(i,g,x){g=g??i,x=x??i;const _=this.#Ws;this.#Di=_[0]=i,this.#Ui=_[1]=g,this.#Li=_[2]=x,this.dirtyTransform=!0}render(i){const{view:g,isScene2DMode:x}=i;let _;x&&(this.#Vt=0,this.#$s=0),this.dirtyTransform&&(_=!0,updateObject3DMatrix(this,g)),this.dirtyTransform&&(_=!0,this.dirtyTransform=!1),i.num3DGroups++;const{children:v}=this;let b=0;const y=v.length;for(;b, tintBlendMode:u32,\n};\n@group(2) @binding(0) var uniforms:Uniforms;\n@group(2) @binding(1) var diffuseTextureSampler:sampler;\n@group(2) @binding(2) var diffuseTexture:texture_2d;\nstruct InputData { @builtin(position) position:vec4, @location(0) vertexPosition:vec3, @location(1) vertexNormal:vec3, @location(2) uv:vec2, @location(7) currentClipPos:vec4, @location(8) prevClipPos:vec4, @location(11) combinedOpacity:f32, @location(12) motionVector:vec3, @location(13) shadowPos:vec3, @location(15) @interpolate(flat) pickingId:vec4,\n};\n@fragment\nfn main(inputData:InputData) -> FragmentOutput { var output:FragmentOutput; var finalColor:vec4=vec4(0.0); #redgpu_if diffuseTexture finalColor=textureSample(diffuseTexture,diffuseTextureSampler,inputData.uv); #redgpu_endIf let alpha2D=select(finalColor.a,1.0,systemUniforms.isView3D==1u); finalColor=vec4(finalColor.rgb * alpha2D,finalColor.a * uniforms.opacity * inputData.combinedOpacity); #redgpu_if useTint finalColor=calcTintBlendMode(finalColor,uniforms.tintBlendMode,uniforms.tint); #redgpu_endIf if (systemUniforms.isView3D==1 && finalColor.a==0.0) { discard; } output.color=finalColor; output.gBufferMotionVector=vec4(calculateMotionVector(inputData.currentClipPos,inputData.prevClipPos),0.0,1.0 ); return output;\n};\n");class BitmapMaterial extends AUVTransformBaseMaterial{dirtyPipeline=!1;constructor(i,g,x){super(i,"BITMAP_MATERIAL",Da,2),x&&(this.name=x),this.diffuseTexture=g,this.diffuseTextureSampler=new Sampler(this.redGPUContext),this.initGPURenderInfos()}}dr.defineByPreset(BitmapMaterial,[dr.PRESET_TEXTURE.DIFFUSE_TEXTURE,dr.PRESET_SAMPLER.DIFFUSE_TEXTURE_SAMPLER]),Object.freeze(BitmapMaterial);var Ua="#redgpu_include SYSTEM_UNIFORM;\n#redgpu_include getBillboardMatrix;\nstruct MatrixList{ modelMatrix:mat4x4, normalModelMatrix:mat4x4,\n}\nstruct VertexUniforms { matrixList:MatrixList, pickingId:u32, useBillboardPerspective:u32, useBillboard:u32, combinedOpacity:f32,\n};\n@group(1) @binding(0) var vertexUniforms:VertexUniforms;\nstruct InputData { @location(0) a_position:vec3, @location(1) a_normal:vec3, @location(2) a_uv:vec2, @location(3) position:vec3, @location(4) alpha:f32, @location(5) rotation:vec3, @location(6) scale:f32,\n};\nstruct OutputData { @builtin(position) position:vec4, @location(0) vertexPosition:vec3, @location(1) vertexNormal:vec3, @location(2) uv:vec2, @location(7) currentClipPos:vec4, @location(8) prevClipPos:vec4, @location(11) combinedOpacity:f32, @location(12) motionVector:vec3, @location(13) shadowPos:vec3, @location(14) @interpolate(flat) receiveShadow:f32, @location(15) @interpolate(flat) pickingId:vec4,\n};\nfn mat4_inverse(a:mat4x4) -> mat4x4 { var a00:f32=a[0][0]; var a01:f32=a[0][1]; var a02:f32=a[0][2]; var a03:f32=a[0][3]; var a10:f32=a[1][0]; var a11:f32=a[1][1]; var a12:f32=a[1][2]; var a13:f32=a[1][3]; var a20:f32=a[2][0]; var a21:f32=a[2][1]; var a22:f32=a[2][2]; var a23:f32=a[2][3]; var a30:f32=a[3][0]; var a31:f32=a[3][1]; var a32:f32=a[3][2]; var a33:f32=a[3][3]; var b00:f32=a00*a11 - a01*a10; var b01:f32=a00*a12 - a02*a10; var b02:f32=a00*a13 - a03*a10; var b03:f32=a01*a12 - a02*a11; var b04:f32=a01*a13 - a03*a11; var b05:f32=a02*a13 - a03*a12; var b06:f32=a20*a31 - a21*a30; var b07:f32=a20*a32 - a22*a30; var b08:f32=a20*a33 - a23*a30; var b09:f32=a21*a32 - a22*a31; var b10:f32=a21*a33 - a23*a31; var b11:f32=a22*a33 - a23*a32; var det:f32=b00*b11 - b01*b10 + b02*b09 + b03*b08 - b04*b07 + b05*b06; if (det !=0.0) { det=1.0/det; return mat4x4( (a11*b11 - a12*b10 + a13*b09) * det, (a02*b10 - a01*b11 - a03*b09) * det, (a31*b05 - a32*b04 + a33*b03) * det, (a22*b04 - a21*b05 - a23*b03) * det, (a12*b08 - a10*b11 - a13*b07) * det, (a00*b11 - a02*b08 + a03*b07) * det, (a32*b02 - a30*b05 - a33*b01) * det, (a20*b05 - a22*b02 + a23*b01) * det, (a10*b10 - a11*b08 + a13*b06) * det, (a01*b08 - a00*b10 - a03*b06) * det, (a30*b04 - a31*b02 + a33*b00) * det, (a21*b02 - a20*b04 - a23*b00) * det, (a11*b07 - a10*b09 - a12*b06) * det, (a00*b09 - a01*b07 + a02*b06) * det, (a31*b01 - a30*b03 - a32*b00) * det, (a20*b03 - a21*b01 + a22*b00) * det ); } return mat4x4( 0.0,0.0,0.0,0.0, 0.0,0.0,0.0,0.0, 0.0,0.0,0.0,0.0, 0.0,0.0,0.0,0.0 );\n}\nfn rotationMTX(t:vec3)->mat4x4\n{ var s:f32=sin(t.x); var c:f32=cos(t.x); var m1=mat4x4(1,0,0,0, 0,c,-s,0, 0,s,c,0, 0,0,0,1); s=sin(t[1]);c=cos(t[1]); var m2=mat4x4(c,0,s,0, 0,1,0,0, -s,0,c,0, 0,0,0,1); s=sin(t[2]);c=cos(t[2]); var m3=mat4x4(c,-s,0,0, s,c,0,0, 0,0,1,0, 0,0,0,1); return m1 * m2 * m3;\n}\n@vertex\nfn main( inputData:InputData) -> OutputData { var output:OutputData; let u_projectionMatrix=systemUniforms.projectionMatrix; let u_projectionCameraMatrix=systemUniforms.projectionCameraMatrix; let u_resolution=systemUniforms.resolution; let u_camera=systemUniforms.camera; let u_cameraMatrix=u_camera.cameraMatrix; let u_cameraPosition=u_camera.cameraPosition; let u_modelMatrix=vertexUniforms.matrixList.modelMatrix; let u_normalModelMatrix=vertexUniforms.matrixList.normalModelMatrix; let u_useBillboardPerspective=vertexUniforms.useBillboardPerspective==1u; let u_useBillboard=vertexUniforms.useBillboard==1u; let input_position=inputData.position; var position:vec4; var normalPosition:vec4; var scaleMTX=mat4x4( inputData.scale,0,0,0, 0,inputData.scale,0,0, 0,0,inputData.scale,0, 0,0,0,1 ); var translateTX=mat4x4( 1,0,0,0, 0,1,0,0, 0,0,1,0, inputData.position.x,inputData.position.y,inputData.position.z,1 ); var temp:mat4x4; if(u_useBillboard){ var rotateMTX2=rotationMTX( vec3(0,0,inputData.rotation.z) ); temp=translateTX * rotateMTX2; position=rotateMTX2 * vec4(inputData.a_position,1); output.position=u_projectionMatrix * getBillboardMatrixNoScaleRatio( u_cameraMatrix,temp ) * scaleMTX * position; }else{ var rotateMTX=rotationMTX( inputData.rotation ); temp=translateTX * rotateMTX * scaleMTX; position=temp * vec4(inputData.a_position,1); output.position=u_projectionCameraMatrix * position; } output.vertexPosition=position.xyz; output.vertexNormal=(transpose(mat4_inverse(temp) ) * vec4(inputData.a_normal,1.0)).xyz; output.uv=inputData.a_uv; output.combinedOpacity=inputData.alpha; return output;\n}\nstruct OutputShadowData { @builtin(position) position:vec4,\n};\n";const La=parseWGSL(Ua),Aa=La.uniforms.vertexUniforms;class ParticleEmitter extends Mesh{#Pf=1e3;#Bf=5e3;#If=0;#Ef=0;#Df=0;#Uf=0;#Lf=0;#Af=0;#Gf=-5;#kf=-5;#Of=-5;#Nf=5;#Vf=5;#Ff=5;#Hf=1;#zf=1;#$f=1;#Kf=1;#Xf=0;#jf=1;#Yf=0;#qf=0;#Wf=-360;#Zf=-360;#Jf=-360;#Qf=360;#ed=360;#td=360;#nd=-360;#rd=-360;#id=-360;#ad=360;#sd=360;#od=360;#ud=Ea.CubicOut;#ld=Ea.CubicOut;#cd=Ea.CubicOut;#hd=Ea.Linear;#fd=Ea.Linear;#dd=Ea.CubicOut;#md=Ea.CubicOut;#pd=Ea.CubicOut;#gd;#xd;#_d;#Kn;#vd;#bd=2e3;constructor(i){super(i),this.geometry=new Plane(i),this.material=new BitmapMaterial(i),this.ignoreFrustumCulling=!0,this.useBillboard=!0}get vertexStateBuffers(){return[{arrayStride:32,stepMode:"vertex",attributes:[{shaderLocation:0,offset:0,format:"float32x3"},{shaderLocation:1,offset:12,format:"float32x3"},{shaderLocation:2,offset:24,format:"float32x2"}]},{arrayStride:48,stepMode:"instance",attributes:[{shaderLocation:3,offset:16,format:"float32x3"},{shaderLocation:4,offset:28,format:"float32"},{shaderLocation:5,offset:32,format:"float32x3"},{shaderLocation:6,offset:44,format:"float32"}]}]}get particleNum(){return this.#bd}set particleNum(i){this.#bd=Math.max(Math.min(i,5e5),1),this.#gd||this.#ne(),this.#yd()}get minLife(){return this.#Pf}set minLife(i){this.#Pf=i}get maxLife(){return this.#Bf}set maxLife(i){this.#Bf=i}get minStartX(){return this.#If}set minStartX(i){this.#If=i}get minStartY(){return this.#Ef}set minStartY(i){this.#Ef=i}get minStartZ(){return this.#Df}set minStartZ(i){this.#Df=i}get maxStartX(){return this.#Uf}set maxStartX(i){this.#Uf=i}get maxStartY(){return this.#Lf}set maxStartY(i){this.#Lf=i}get maxStartZ(){return this.#Af}set maxStartZ(i){this.#Af=i}get minEndX(){return this.#Gf}set minEndX(i){this.#Gf=i}get minEndY(){return this.#kf}set minEndY(i){this.#kf=i}get minEndZ(){return this.#Of}set minEndZ(i){this.#Of=i}get maxEndX(){return this.#Nf}set maxEndX(i){this.#Nf=i}get maxEndY(){return this.#Vf}set maxEndY(i){this.#Vf=i}get maxEndZ(){return this.#Ff}set maxEndZ(i){this.#Ff=i}get minStartAlpha(){return this.#Hf}set minStartAlpha(i){this.#Hf=i}get maxStartAlpha(){return this.#zf}set maxStartAlpha(i){this.#zf=i}get minEndAlpha(){return this.#$f}set minEndAlpha(i){this.#$f=i}get maxEndAlpha(){return this.#Kf}set maxEndAlpha(i){this.#Kf=i}get minStartScale(){return this.#Xf}set minStartScale(i){this.#Xf=i}get maxStartScale(){return this.#jf}set maxStartScale(i){this.#jf=i}get minEndScale(){return this.#Yf}set minEndScale(i){this.#Yf=i}get maxEndScale(){return this.#qf}set maxEndScale(i){this.#qf=i}get minStartRotationX(){return this.#Wf}set minStartRotationX(i){this.#Wf=i}get minStartRotationY(){return this.#Zf}set minStartRotationY(i){this.#Zf=i}get minStartRotationZ(){return this.#Jf}set minStartRotationZ(i){this.#Jf=i}get maxStartRotationX(){return this.#Qf}set maxStartRotationX(i){this.#Qf=i}get maxStartRotationY(){return this.#ed}set maxStartRotationY(i){this.#ed=i}get maxStartRotationZ(){return this.#td}set maxStartRotationZ(i){this.#td=i}get minEndRotationX(){return this.#nd}set minEndRotationX(i){this.#nd=i}get minEndRotationY(){return this.#rd}set minEndRotationY(i){this.#rd=i}get minEndRotationZ(){return this.#id}set minEndRotationZ(i){this.#id=i}get maxEndRotationX(){return this.#ad}set maxEndRotationX(i){this.#ad=i}get maxEndRotationY(){return this.#sd}set maxEndRotationY(i){this.#sd=i}get maxEndRotationZ(){return this.#od}set maxEndRotationZ(i){this.#od=i}get easeX(){return this.#ud}set easeX(i){this.#ud=i}get easeY(){return this.#ld}set easeY(i){this.#ld=i}get easeZ(){return this.#cd}set easeZ(i){this.#cd=i}get easeAlpha(){return this.#hd}set easeAlpha(i){this.#hd=i}get easeScale(){return this.#fd}set easeScale(i){this.#fd=i}get easeRotationX(){return this.#dd}set easeRotationX(i){this.#dd=i}get easeRotationY(){return this.#md}set easeRotationY(i){this.#md=i}get easeRotationZ(){return this.#pd}set easeRotationZ(i){this.#pd=i}get particleBuffers(){return this.#xd}render(i){this.#gd||this.#ne(),this.#Sd(i.timestamp),super.render(i)}createCustomMeshVertexShaderModule=()=>this.createMeshVertexShaderModuleBASIC("VERTEX_MODULE_PARTICLE_EMITTER",La,Aa,Ua);#ne(){this.#_d=new Float32Array(46);let i={size:this.#_d.byteLength,usage:GPUBufferUsage.UNIFORM|GPUBufferUsage.COPY_DST};const{gpuDevice:g}=this.redGPUContext;this.#gd=g.createBuffer(i),g.queue.writeBuffer(this.#gd,0,this.#_d),this.#yd(),this.depthStencilState.depthWriteEnabled=!1}#yd(){this.dirtyPipeline=!0;let i=this.redGPUContext;const g=new Float32Array(12*this.#bd),x=new Float32Array(12*this.#bd),_=new Float32Array(12*this.#bd),v=new Float32Array(4*this.#bd),b=new Float32Array(4*this.#bd),y=performance.now(),S=this.localToWorld(this.x,this.y,this.z);for(let i=0;i{const _=i.gpuDevice.createBuffer({size:g.byteLength,usage:GPUBufferUsage.COPY_DST|GPUBufferUsage.COPY_SRC|GPUBufferUsage.VERTEX|GPUBufferUsage.STORAGE});i.gpuDevice.queue.writeBuffer(_,0,g),this.#xd.push(_),w?.length&©GPUBuffer(i.gpuDevice,w[x],_)}),w&&w.forEach(i=>i.destroy());let k={code:"\nstruct Info { startValue:f32, endValue:f32, easeType:f32, birthCenterValue:f32\n};\nstruct InfoGroup { infoX:Info, infoY:Info, infoZ:Info,\n};\nstruct Particle { startTime:f32, life:f32, valuePosition:vec3, valueAlpha:f32, valueRotation:vec3, valueScale:f32,\n};\nstruct SimParams { time:f32, currentPositionX:f32,currentPositionY:f32,currentPositionZ:f32, minLife:f32,maxLife:f32, minStartX:f32,maxStartX:f32,minEndX:f32,maxEndX:f32,easeX:f32, minStartY:f32,maxStartY:f32,minEndY:f32,maxEndY:f32,easeY:f32, minStartZ:f32,maxStartZ:f32,minEndZ:f32,maxEndZ:f32,easeZ:f32, minStartAlpha:f32,maxStartAlpha:f32,minEndAlpha:f32,maxEndAlpha:f32,easeAlpha:f32, minStartScale:f32,maxStartScale:f32,minEndScale:f32,maxEndScale:f32,easeScale:f32, minStartRotationX:f32,maxStartRotationX:f32,minEndRotationX:f32,maxEndRotationX:f32,easeRotationX:f32, minStartRotationY:f32,maxStartRotationY:f32,minEndRotationY:f32,maxEndRotationY:f32,easeRotationY:f32, minStartRotationZ:f32,maxStartRotationZ:f32,minEndRotationZ:f32,maxEndRotationZ:f32,easeRotationZ:f32,\n};\n@group(0) @binding(0) var params:SimParams;\n@group(0) @binding(1) var particles:array;\n@group(0) @binding(2) var infoPosition:array;\n@group(0) @binding(3) var infoRotation:array;\n@group(0) @binding(4) var infoScale:array;\n@group(0) @binding(5) var infoAlpha:array;\nconst PI:f32=3.141592653589793;\nconst HPI:f32=PI * 0.5;\nconst PI2:f32=PI * 2.0;\nfn calEasing(n:f32,easingType:f32) -> f32 { var m:f32=n; let easingInt:i32=i32(easingType); switch (easingInt) { case 0:{ m=m;} case 1:{ m=m * m * m * m * m;} case 2:{ m -=1.0; m=(m * m * m * m * m) + 1.0; } case 3:{ if(m * 2.0 < 1.0) { m *=2.0; m=m * m * m * m * m * 0.5; } else { m=m * 2.0 - 2.0; m=0.5 * (m * m * m * m * m + 2.0); } } case 4:{ m=m * m * (m * 1.70158 + m - 1.70158);} case 5:{ m -=1.0; m=m * m * (m * 1.70158 + m + 1.70158) + 1.0; } case 6:{ if(m * 2.0 < 1.0) { m *=2.0; m=0.5 * m * m * (m * 1.70158 + m - 1.70158); } else { m=m * 2.0 - 2.0; m=0.5 * m * m * (m * 1.70158 + m + 1.70158) + 1.0; } } case 7:{ m=-1.0 * (sqrt(1.0 - m * m) - 1.0);} case 8:{ m -=1.0; m=sqrt(1.0 - m * m); } case 9:{ if(m * 2.0 < 1.0) { m *=2.0; m=-0.5 * (sqrt(1.0 - m * m) - 1.0); } else { m=m * 2.0 - 2.0; m=0.5 * sqrt(1.0 - m * m) + 0.5; } } case 10:{ m=m * m * m;} case 11:{ m -=1.0; m=m * m * m + 1.0; } case 12:{ if(m * 2.0 < 1.0) { m *=2.0; m=m * m * m * 0.5; } else { m=m * 2.0 - 2.0; m=0.5 * (m * m * m + 2.0); } } case 13:{ if (m==0.0) { m=0.0;} else { m=pow(2.0,10.0 * (m - 1.0));} } case 14:{ if (m==1.0) { m=1.0;} else { m=-pow(2.0,-10.0 * m) + 1.0;} } case 15:{ if(m * 2.0 < 1.0) { if (m==0.0) { m=0.0;} else { m *=2.0;m=0.5 * pow(2.0,10.0 * (m - 1.0));} } else { if (m==2.0) { m=1.0;} else { m=m * 2.0 - 1.0;m=-0.5 * pow(2.0,-10.0 * m) + 1.0;} } } case 16:{ m=m * m;} case 17:{ m=(2.0 - m) * m;} case 18:{ if(m * 2.0 < 1.0) { m *=2.0; m=m * m * 0.5; } else { m=2.0 - m; m=0.5 * (m * m + 1.0); } } case 19:{ m=m * m * m * m;} case 20:{ m -=1.0; m=1.0 - (m * m * m * m); } case 21:{ if(m * 2.0 < 1.0) { m *=2.0; m=m * m * m * m * 0.5; } else { m=m * 2.0 - 2.0; m=1.0 - (m * m * m * m * 0.5); } } case 22:{ m=-cos(m * HPI) + 1.0;} case 23:{ m=sin(m * HPI);} case 24:{ m=(-cos(m * PI) + 1.0) * 0.5;} case 25:{ if (m==0.0) { m=0.0;} else if (m==1.0) { m=1.0;} else { m -=1.0;m=-1.0 * pow(2.0,10.0 * m) * sin((m - 0.075) * (PI2)/0.3);} } case 26:{ if (m==0.0) { m=0.0; } else if (m==1.0) { m=1.0; } else { m -=1.0; m=-pow(2.0,10.0 * m) * sin((m - 0.075) * PI2/0.3); } } case 27:{ if (m==0.0) { m=0.0; } else if (m==1.0) { m=1.0; } else { m=pow(2.0,-10.0 * m) * sin((m - 0.075) * PI2/0.3) + 1.0; } } default:{ m=m;} } return m;\n}\nfn rand(n:f32) -> f32 { return fract(sin(n) * 43758.5453123);\n}\nfn randomRange(min:f32,max:f32,v:f32)->f32\n{ var newValue:f32=rand(v); return (newValue * (max-min)) + min;\n}\nfn compute_value(tInfo:Info,lifeRatio:f32) -> f32 { return tInfo.startValue + ((tInfo.endValue - tInfo.startValue) * calEasing(lifeRatio,tInfo.easeType));\n}\n@compute @workgroup_size(256,1,1)\nfn main( @builtin(global_invocation_id) global_id:vec3 ) { let index:u32=(global_id.x); let age:f32=(params.time - particles[index].startTime); var lifeRatio:f32=(age/particles[index].life); if (lifeRatio >=1.0 ) { let uuid:f32=(params.time + f32(index)); particles[index].startTime=params.time; particles[index].life=randomRange( params.minLife,params.maxLife,uuid ); infoPosition[index].infoX.startValue=randomRange( params.minStartX + params.currentPositionX,params.maxStartX + params.currentPositionX,(uuid + 1.0) ); infoPosition[index].infoX.endValue=randomRange( params.minEndX + params.currentPositionX,params.maxEndX + params.currentPositionX,(uuid + 2.0) ); infoPosition[index].infoX.easeType=params.easeX; infoPosition[index].infoX.birthCenterValue=params.currentPositionX; infoPosition[index].infoY.startValue=randomRange( params.minStartY +params.currentPositionY,params.maxStartY+params.currentPositionY,(uuid + 3.0) ); infoPosition[index].infoY.endValue=randomRange( params.minEndY+params.currentPositionY,params.maxEndY+params.currentPositionY,(uuid + 4.0) ); infoPosition[index].infoY.easeType=params.easeY; infoPosition[index].infoY.birthCenterValue=params.currentPositionY; infoPosition[index].infoZ.startValue=randomRange( params.minStartZ+params.currentPositionZ,params.maxStartZ+params.currentPositionZ,(uuid + 5.0) ); infoPosition[index].infoZ.endValue=randomRange( params.minEndZ+params.currentPositionZ,params.maxEndZ+params.currentPositionZ,(uuid + 6.0) ); infoPosition[index].infoZ.easeType=params.easeZ; infoPosition[index].infoZ.birthCenterValue=params.currentPositionZ; infoAlpha[index].startValue=randomRange( params.minStartAlpha,params.maxStartAlpha,(uuid + 7.0) ); infoAlpha[index].endValue=randomRange( params.minEndAlpha,params.maxEndAlpha,(uuid + 8.0) ); infoAlpha[index].easeType=params.easeAlpha; infoScale[index].startValue=randomRange( params.minStartScale,params.maxStartScale,(uuid + 9.0) ); infoScale[index].endValue=randomRange( params.minEndScale,params.maxEndScale,(uuid + 10.0)); infoScale[index].easeType=params.easeScale; infoRotation[index].infoX.startValue=randomRange( params.minStartRotationX,params.maxStartRotationX,(uuid + 11.0)); infoRotation[index].infoX.endValue=randomRange( params.minEndRotationX,params.maxEndRotationX,(uuid + 12.0)); infoRotation[index].infoX.easeType=params.easeRotationX; infoRotation[index].infoY.startValue=randomRange( params.minStartRotationY,params.maxStartRotationY,(uuid + 13.0)); infoRotation[index].infoY.endValue=randomRange( params.minEndRotationY,params.maxEndRotationY,(uuid + 14.0)); infoRotation[index].infoY.easeType=params.easeRotationY; infoRotation[index].infoZ.startValue=randomRange( params.minStartRotationZ,params.maxStartRotationZ,(uuid + 15.0)); infoRotation[index].infoZ.endValue=randomRange( params.minEndRotationZ,params.maxEndRotationZ,(uuid + 16.0)); infoRotation[index].infoZ.easeType=params.easeRotationZ; lifeRatio=0.0; } var targetInfo:Info; let targetParticle=particles[index]; targetInfo=infoPosition[index].infoX; particles[index].valuePosition.x=compute_value(targetInfo,lifeRatio); targetInfo=infoPosition[index].infoY; particles[index].valuePosition.y=compute_value(targetInfo,lifeRatio); targetInfo=infoPosition[index].infoZ; particles[index].valuePosition.z=compute_value(targetInfo,lifeRatio); targetInfo=infoAlpha[index]; particles[index].valueAlpha=compute_value(targetInfo,lifeRatio); targetInfo=infoScale[index]; particles[index].valueScale=compute_value(targetInfo,lifeRatio); targetInfo=infoRotation[index].infoX; particles[index].valueRotation.x=compute_value(targetInfo,lifeRatio) * PI/180.0; targetInfo=infoRotation[index].infoY; particles[index].valueRotation.y=compute_value(targetInfo,lifeRatio) * PI/180.0; targetInfo=infoRotation[index].infoZ; particles[index].valueRotation.z=compute_value(targetInfo,lifeRatio) * PI/180.0;\n}\n"},H=i.resourceManager.createGPUShaderModule("PARTICLE_EMITTER_MODULE",k);const z=[{binding:0,visibility:GPUShaderStage.COMPUTE,buffer:{type:"uniform"}}],q=[{binding:0,resource:{buffer:this.#gd,offset:0,size:this.#_d.byteLength}}];L.forEach((i,g)=>{z.push({binding:g+1,visibility:GPUShaderStage.COMPUTE,buffer:{type:"storage"}}),q.push({binding:g+1,resource:{buffer:this.#xd[g],offset:0,size:i.byteLength}})});const W=i.gpuDevice.createBindGroupLayout({entries:z}),be=i.gpuDevice.createPipelineLayout({bindGroupLayouts:[W]});this.#vd=i.gpuDevice.createBindGroup({label:"PARTICLE_EMITTER_BIND_GROUP",layout:W,entries:q}),this.#Kn=i.gpuDevice.createComputePipeline({label:"PARTICLE_EMITTER_PIPELINE",layout:be,compute:{module:H,entryPoint:"main"}})}#Sd(i){const g=this.localToWorld(this.x,this.y,this.z);this.#_d.set([i,...g,this.#Pf,this.#Bf,this.#If,this.#Uf,this.#Gf,this.#Nf,this.#ud,this.#Ef,this.#Lf,this.#kf,this.#Vf,this.#ld,this.#Df,this.#Af,this.#Of,this.#Ff,this.#cd,this.#Hf,this.#zf,this.#$f,this.#Kf,this.#hd,this.#Xf,this.#jf,this.#Yf,this.#qf,this.#fd,this.#Wf,this.#Qf,this.#nd,this.#ad,this.#dd,this.#Zf,this.#ed,this.#rd,this.#sd,this.#md,this.#Jf,this.#td,this.#id,this.#od,this.#pd],0);const{gpuDevice:x}=this.redGPUContext;x.queue.writeBuffer(this.#gd,0,this.#_d);const _=x.createCommandEncoder({label:"PARTICLE_EMITTER_COMPUTE_COMMAND_ENCODER"}),v=_.beginComputePass({label:"PARTICLE_EMITTER_COMPUTE_PASS"});v.setPipeline(this.#Kn),v.setBindGroup(0,this.#vd),v.dispatchWorkgroups(Math.ceil(this.#bd/256)),v.end(),x.queue.submit([_.finish()])}}Object.defineProperty(ParticleEmitter.prototype,"meshType",{value:Gr.PARTICLE,writable:!1}),Er.defineByPreset(ParticleEmitter,[Er.PRESET_BOOLEAN.USE_BILLBOARD]),Er.definePositiveNumber(ParticleEmitter,[]),Object.freeze(ParticleEmitter);const Ga=mixInMesh2D(Mesh);class Sprite2D extends Ga{#Bt=1;#It=1;constructor(i,g){super(i,new Plane(i,1,1,1,1,1,!0),g),this.primitiveState.cullMode=ei.FRONT}get width(){return this.#Bt}set width(i){validatePositiveNumberRange(i),this.#Bt=i,this.dirtyTransform=!0}get height(){return this.#It}set height(i){validatePositiveNumberRange(i),this.#It=i,this.dirtyTransform=!0}setSize(i,g){this.width=i,this.height=void 0!==g?g:i}}Object.freeze(Sprite2D);var ka="#redgpu_include SYSTEM_UNIFORM;\n#redgpu_include getBillboardMatrix;\n#redgpu_include calcBillboard;\n#redgpu_include billboardPicking;\n#redgpu_include billboardShadow;\nstruct MatrixList{ modelMatrix:mat4x4, normalModelMatrix:mat4x4,\n}\nstruct VertexUniforms { matrixList:MatrixList, pickingId:u32, useBillboard:u32, usePixelSize:u32, pixelSize:f32, _renderRatioX:f32, _renderRatioY:f32, combinedOpacity:f32,\n};\n@group(1) @binding(0) var vertexUniforms:VertexUniforms;\nstruct InputData { @location(0) position:vec3, @location(1) vertexNormal:vec3, @location(2) uv:vec2,\n};\nstruct OutputData { @builtin(position) position:vec4, @location(0) vertexPosition:vec3, @location(1) vertexNormal:vec3, @location(2) uv:vec2, @location(7) currentClipPos:vec4, @location(8) prevClipPos:vec4, @location(11) combinedOpacity:f32, @location(12) motionVector:vec3, @location(13) shadowPos:vec3, @location(15) @interpolate(flat) pickingId:vec4,\n};\n@vertex\nfn main(inputData:InputData) -> OutputData { var output:OutputData; let billboardResult=calcBillboard( inputData.position, inputData.vertexNormal, vertexUniforms.matrixList.modelMatrix, systemUniforms.camera.cameraMatrix, systemUniforms.projectionMatrix, systemUniforms.resolution, vertexUniforms.useBillboard, vertexUniforms.usePixelSize, vertexUniforms.pixelSize, vertexUniforms._renderRatioX, vertexUniforms._renderRatioY ); output.position=billboardResult.position; output.vertexPosition=billboardResult.vertexPosition; output.vertexNormal=billboardResult.vertexNormal; output.uv=inputData.uv; output.combinedOpacity=vertexUniforms.combinedOpacity; return output;\n}\n";const Oa=parseWGSL(ka),Na=Oa.uniforms.vertexUniforms;class Sprite3D extends Mesh{#qo=1;#Wo=1;#Zo=1;#Td=0;#Jo=!1;constructor(i,g,x){super(i),this._geometry=x||new Plane(i),this._material=g,this._material&&(this._material.transparent=!0),this.dirtyPipeline=!0,this.dirtyTransform=!0,this.primitiveState.cullMode=ei.NONE}get worldSize(){return this.#Zo}set worldSize(i){this.#Zo!==i&&(this.#Zo=i,this.#Qo())}get usePixelSize(){return this.#Jo}set usePixelSize(i){if(this.gpuRenderInfo){const{vertexUniformBuffer:g,vertexUniformInfo:x}=this.gpuRenderInfo;this.redGPUContext.gpuDevice.queue.writeBuffer(g.gpuBuffer,x.members.usePixelSize.uniformOffset,new Uint32Array([i?1:0]))}this.#Jo!==i&&(this.#Jo=i,this.#Qo())}get pixelSize(){return this.#Td}set pixelSize(i){if(this.gpuRenderInfo){const{vertexUniformBuffer:g,vertexUniformInfo:x}=this.gpuRenderInfo;this.redGPUContext.gpuDevice.queue.writeBuffer(g.gpuBuffer,x.members.pixelSize.uniformOffset,new Float32Array([i*window.devicePixelRatio]))}this.#Td=i}#Qo(){if(this.#Wo){const i=this._renderRatioX,g=this._renderRatioY;this.usePixelSize?(this._renderRatioY=1,this._renderRatioX=this.#qo/this.#Wo):(this._renderRatioY=this.#Zo,this._renderRatioX=this.#qo/this.#Wo*this.#Zo),i===this._renderRatioX&&g===this._renderRatioY||(this.dirtyTransform=!0)}}render(i){if(this._material instanceof BitmapMaterial&&this._material.diffuseTexture){const{gpuTexture:i}=this._material.diffuseTexture;if(i){const g=i.width,x=i.height;if(g!==this.#qo||x!==this.#Wo){this.#qo=g,this.#Wo=x;const i=this.pixelSize;this.pixelSize=this.pixelSize||x,this.#Qo(),i!==this.pixelSize&&(this.dirtyTransform=!0)}}}super.render(i)}createCustomMeshVertexShaderModule=()=>this.createMeshVertexShaderModuleBASIC("VERTEX_MODULE_SPRITE_3D",Oa,Na,ka)}Er.definePositiveNumber(Sprite3D,[["_renderRatioX",1],["_renderRatioY",1]]),Er.defineByPreset(Sprite3D,[[Er.PRESET_BOOLEAN.USE_BILLBOARD,!0]]),Object.freeze(Sprite3D);class ASpriteSheet extends Mesh{#Md=0;#wd=0;#Cd=0;#Rd=!0;#Pd=!0;#Bd;#Id;#Ed="play";constructor(i,g,x){super(i),this.#Id=x,this._material=new BitmapMaterial(i),this._material.transparent=!0,this.dirtyPipeline=!0,this.dirtyTransform=!0,this.spriteSheetInfo=g,this._material.diffuseTextureSampler=new Sampler(i),this._material.diffuseTextureSampler.addressModeU=_.REPEAT,this._material.diffuseTextureSampler.addressModeV=_.REPEAT}get state(){return this.#Ed}get loop(){return this.#Pd}set loop(i){this.#Pd=i}get frameRate(){return this.#Md}set frameRate(i){i<0&&(i=0),0===this.#Md&&i&&(this.#wd=0),this.#Md=i,this.#Cd=1e3/this.#Md}get geometry(){return this._geometry}set geometry(i){consoleAndThrowError("ASpriteSheet can not change geometry")}get material(){return this._material}set material(i){consoleAndThrowError("ASpriteSheet can not change material")}get spriteSheetInfo(){return this.#Bd}set spriteSheetInfo(i){this.#Bd=i,this.frameRate=i.frameRate,this.segmentW=i.segmentW,this.segmentH=i.segmentH,this.totalFrame=i.totalFrame,this.currentIndex=i.startIndex,this.#Pd=!0,this.#wd=0,this._material.diffuseTexture=i.texture}play(){this.#Rd=!0,this.#Ed="play",this.#wd=0}pause(){this.#Rd=!1,this.#Ed="pause"}stop(){this.#Rd=!1,this.currentIndex=0,this.#Ed="stop"}render(i){const{diffuseTexture:g}=this._material;this.#Id(g,this.segmentW,this.segmentH);const{timestamp:x}=i;if(this.#wd||(this.#wd=this.#Cd+x),this.#Rd&&this.#wd=this.totalFrame&&(this.loop?(this.#Rd=!0,this.currentIndex=0):(this.#Rd=!1,this.currentIndex=this.totalFrame-1))}super.render(i)}}Er.definePositiveNumber(ASpriteSheet,[["segmentW",5],["segmentH",3],["totalFrame",15],["currentIndex",0]]),Object.freeze(ASpriteSheet);var Va=Object.freeze({__proto__:null,ASpriteSheet:ASpriteSheet}),Fa="#redgpu_include SYSTEM_UNIFORM;\n#redgpu_include getBillboardMatrix;\nstruct MatrixList{ modelMatrix:mat4x4, normalModelMatrix:mat4x4,\n}\nstruct VertexUniforms { matrixList:MatrixList, pickingId:u32, segmentW:f32, segmentH:f32, totalFrame:f32, currentIndex:f32, combinedOpacity:f32,\n};\n@group(1) @binding(0) var vertexUniforms:VertexUniforms;\nstruct InputData { @location(0) position:vec3, @location(1) vertexNormal:vec3, @location(2) uv:vec2,\n};\nstruct OutputData { @builtin(position) position:vec4, @location(0) vertexPosition:vec3, @location(1) vertexNormal:vec3, @location(2) uv:vec2, @location(7) currentClipPos:vec4, @location(8) prevClipPos:vec4, @location(11) combinedOpacity:f32, @location(12) motionVector:vec3, @location(13) shadowPos:vec3, @location(15) @interpolate(flat) pickingId:vec4,\n};\n@vertex\nfn main(inputData:InputData) -> OutputData { var output:OutputData; let u_projectionMatrix=systemUniforms.projectionMatrix; let u_camera=systemUniforms.camera; let u_cameraMatrix=u_camera.cameraMatrix; let u_cameraPosition=u_camera.cameraPosition; let u_modelMatrix=vertexUniforms.matrixList.modelMatrix; let u_normalModelMatrix=vertexUniforms.matrixList.normalModelMatrix; let input_position=inputData.position; let input_vertexNormal=inputData.vertexNormal; let input_uv=inputData.uv; var position:vec4; var normalPosition:vec4; position=u_cameraMatrix * u_modelMatrix * vec4(input_position,1.0); normalPosition=u_cameraMatrix * u_normalModelMatrix * vec4(input_vertexNormal,1.0); output.position=u_projectionMatrix * position; output.vertexPosition=position.xyz; output.vertexNormal=normalPosition.xyz; output.combinedOpacity=vertexUniforms.combinedOpacity; let uv=vec2( input_uv.x * 1/vertexUniforms.segmentW + ((vertexUniforms.currentIndex % vertexUniforms.segmentW)/vertexUniforms.segmentW), input_uv.y * 1/vertexUniforms.segmentH - (floor(vertexUniforms.currentIndex/vertexUniforms.segmentH)/vertexUniforms.segmentH) ); output.uv=uv; return output;\n}\n@vertex\nfn picking(inputData:InputData) -> OutputData { var output:OutputData; let u_projectionMatrix=systemUniforms.projectionMatrix; let u_camera=systemUniforms.camera; let u_cameraMatrix=u_camera.cameraMatrix; let u_cameraPosition=u_camera.cameraPosition; let u_modelMatrix=vertexUniforms.matrixList.modelMatrix; let u_normalModelMatrix=vertexUniforms.matrixList.normalModelMatrix; let input_position=inputData.position; let input_vertexNormal=inputData.vertexNormal; let input_uv=inputData.uv; var position:vec4; var normalPosition:vec4; position=u_cameraMatrix * u_modelMatrix * vec4(input_position,1.0); normalPosition=u_cameraMatrix * u_normalModelMatrix * vec4(input_vertexNormal,1.0); output.position=u_projectionMatrix * position; output.pickingId=unpack4x8unorm(vertexUniforms.pickingId); return output;\n}\n";const Ha=parseWGSL(Fa),za=Ha.uniforms.vertexUniforms,$a=mixInMesh2D(ASpriteSheet);class SpriteSheet2D extends $a{#Bt=1;#It=1;constructor(i,g){super(i,g,(i,g,x)=>{if(i){const{gpuTexture:_}=i,v=_?.width/g,b=_?.height/x;v===this.#Bt&&b===this.#It||(this.#Bt=_?.width/g,this.#It=_?.height/x,this.dirtyTransform=!0)}else this.#Bt=1,this.#It=1}),this._geometry=new Plane(i,1,1,1,1,1,!0),this.primitiveState.cullMode=ei.FRONT}get width(){return this.#Bt}get height(){return this.#It}get geometry(){return this._geometry}set geometry(i){consoleAndThrowError("SpriteSheet2D can not change geometry")}get material(){return this._material}set material(i){consoleAndThrowError("SpriteSheet2D can not change material")}createCustomMeshVertexShaderModule=()=>this.createMeshVertexShaderModuleBASIC("VERTEX_MODULE_SPRITE_SHEET_2D",Ha,za,Fa)}Object.freeze(SpriteSheet2D);var Ka="#redgpu_include SYSTEM_UNIFORM;\n#redgpu_include getBillboardMatrix;\n#redgpu_include calcBillboard;\n#redgpu_include billboardPicking;\n#redgpu_include billboardShadow;\nstruct MatrixList{ modelMatrix:mat4x4, normalModelMatrix:mat4x4,\n}\nstruct VertexUniforms { matrixList:MatrixList, pickingId:u32, useSizeAttenuation:u32, useBillboard:u32, segmentW:f32, segmentH:f32, totalFrame:f32, currentIndex:f32, usePixelSize:u32, pixelSize:f32, _renderRatioX:f32, _renderRatioY:f32, combinedOpacity:f32,\n};\n@group(1) @binding(0) var vertexUniforms:VertexUniforms;\nstruct InputData { @location(0) position:vec3, @location(1) vertexNormal:vec3, @location(2) uv:vec2,\n};\nstruct OutputData { @builtin(position) position:vec4, @location(0) vertexPosition:vec3, @location(1) vertexNormal:vec3, @location(2) uv:vec2, @location(7) currentClipPos:vec4, @location(8) prevClipPos:vec4, @location(11) combinedOpacity:f32, @location(12) motionVector:vec3, @location(13) shadowPos:vec3, @location(15) @interpolate(flat) pickingId:vec4,\n};\n@vertex\nfn main(inputData:InputData) -> OutputData { var output:OutputData; let billboardResult=calcBillboard( inputData.position, inputData.vertexNormal, vertexUniforms.matrixList.modelMatrix, systemUniforms.camera.cameraMatrix, systemUniforms.projectionMatrix, systemUniforms.resolution, vertexUniforms.useBillboard, vertexUniforms.usePixelSize, vertexUniforms.pixelSize, vertexUniforms._renderRatioX, vertexUniforms._renderRatioY ); output.position=billboardResult.position; output.vertexPosition=billboardResult.vertexPosition; output.vertexNormal=billboardResult.vertexNormal; output.uv=vec2( inputData.uv.x/vertexUniforms.segmentW + ((vertexUniforms.currentIndex % vertexUniforms.segmentW)/vertexUniforms.segmentW), inputData.uv.y/vertexUniforms.segmentH - (floor(vertexUniforms.currentIndex/vertexUniforms.segmentH)/vertexUniforms.segmentH) ); output.combinedOpacity=vertexUniforms.combinedOpacity; return output;\n}";const Xa=parseWGSL(Ka),ja=Xa.uniforms.vertexUniforms;class SpriteSheet3D extends ASpriteSheet{#qo=1;#Wo=1;#Zo=1;#Td=0;#Jo=!1;constructor(i,x){super(i,x,(i,x,_)=>{if(i){const{gpuTexture:v}=i;if(v){const i=v.width/x,b=v.height/_;i===this.#qo&&b===this.#Wo||(this.#qo=i,this.#Wo=b,this.pixelSize,this.pixelSize=this.#Td?this.#Td:b,this.#Qo(),g("오냐 ",this.pixelSize),this.dirtyTransform=!0)}}else this.#qo=1,this.#Wo=1}),this._geometry=new Plane(i)}get worldSize(){return this.#Zo}set worldSize(i){this.#Zo!==i&&(this.#Zo=i,this.#Qo())}get pixelSize(){return this.#Td}set pixelSize(i){if(this.gpuRenderInfo){const{vertexUniformBuffer:g,vertexUniformInfo:x}=this.gpuRenderInfo;this.redGPUContext.gpuDevice.queue.writeBuffer(g.gpuBuffer,x.members.pixelSize.uniformOffset,new Float32Array([i*window.devicePixelRatio]))}this.#Td=i}get usePixelSize(){return this.#Jo}set usePixelSize(i){if(this.gpuRenderInfo){const{vertexUniformBuffer:g,vertexUniformInfo:x}=this.gpuRenderInfo;this.redGPUContext.gpuDevice.queue.writeBuffer(g.gpuBuffer,x.members.usePixelSize.uniformOffset,new Uint32Array([i?1:0]))}this.#Jo!==i&&(this.#Jo=i,this.#Qo())}#Qo(){if(this.#Wo){const i=this._renderRatioX,g=this._renderRatioY;this.usePixelSize?(this._renderRatioY=1,this._renderRatioX=this.#qo/this.#Wo):(this._renderRatioY=this.#Zo,this._renderRatioX=this.#qo/this.#Wo*this.#Zo),i===this._renderRatioX&&g===this._renderRatioY||(this.dirtyTransform=!0)}}render(i){super.render(i)}get geometry(){return this._geometry}set geometry(i){consoleAndThrowError("SpriteSheet3D can not change geometry")}get material(){return this._material}set material(i){consoleAndThrowError("SpriteSheet3D can not change material")}createCustomMeshVertexShaderModule=()=>this.createMeshVertexShaderModuleBASIC("VERTEX_MODULE_SPRITE_SHEET_3D",Xa,ja,Ka)}Er.definePositiveNumber(SpriteSheet3D,[["_renderRatioX",1],["_renderRatioY",1]]),Er.defineByPreset(SpriteSheet3D,[[Er.PRESET_BOOLEAN.USE_BILLBOARD,!0]]),Object.freeze(SpriteSheet3D);class SpriteSheetInfo{#Dd=0;#Ud=0;#Ld=0;#Ad=0;#Md=0;#Pd=!0;#Gd;constructor(i,g,x,_,v,b,y=!0,S=60){validateRedGPUContext(i),validateUintRange(x),validateUintRange(_),validateUintRange(v),validateUintRange(b),validateUintRange(S),this.#Dd=x,this.#Ud=_,this.#Ld=v,this.#Ad=b,this.#Gd=new BitmapTexture(i,g),this.#Pd=y,this.#Md=S}get segmentW(){return this.#Dd}get segmentH(){return this.#Ud}get totalFrame(){return this.#Ld}get startIndex(){return this.#Ad}get texture(){return this.#Gd}get frameRate(){return this.#Md}get loop(){return this.#Pd}}Object.freeze(SpriteSheetInfo);const Ya=parseWGSL("#redgpu_include drawPicking;\n#redgpu_include FragmentOutput;\n#redgpu_include calculateMotionVector;\nstruct Uniforms { opacity:f32\n};\nstruct InputData { @builtin(position) position:vec4, @location(0) vertexPosition:vec3, @location(1) vertexColor:vec4, @location(7) currentClipPos:vec4, @location(8) prevClipPos:vec4, @location(15) @interpolate(flat) pickingId:vec4,\n}\n@group(2) @binding(0) var uniforms:Uniforms;\n@fragment\nfn main(inputData:InputData) -> FragmentOutput { var output:FragmentOutput; output.color=inputData.vertexColor; output.gBufferMotionVector=vec4(calculateMotionVector(inputData.currentClipPos,inputData.prevClipPos),0.0,1.0 ); return output;\n}\n");class LineMaterial extends ABaseMaterial{constructor(i,g){super(i,"LINE_MATERIAL",Ya,2),g&&(this.name=g),this.initGPURenderInfos()}}Object.freeze(LineMaterial);class LinePoint{position;colorRGBA;constructor(i=0,g=0,x=0,_){this.position=[i,g,x],this.colorRGBA=_}}const getPointsOnBezierCurveWithSplitting=(i,g,x,_)=>{let v=_||[];if(((i,g)=>{let x=i[g].position,_=i[g+1].position,v=i[g+2].position,b=i[g+3].position,y=3*_[0]-2*x[0]-b[0],S=3*_[1]-2*x[1]-b[1],w=3*v[0]-2*b[0]-x[0],L=3*v[1]-2*b[1]-x[1];return y*=y,S*=S,w*=w,L*=L,y{let b=v||[],y=i[g],S=i[x-1],w=0,L=1,k=g+1;for(;kw&&(w=g,L=k)}return Math.sqrt(w)>_?(lineSimplifyPoints(i,g,L+1,_,b),lineSimplifyPoints(i,L,x,_,b)):b.push(y,S),b},qa={LINEAR:"linear",CATMULL_ROM:"catmullRom",BEZIER:"bezier"};Object.freeze(qa);var Wa="#redgpu_include SYSTEM_UNIFORM;\nstruct MatrixList{ modelMatrix:mat4x4, prevModelMatrix:mat4x4, normalModelMatrix:mat4x4,\n}\nstruct VertexUniforms { matrixList:MatrixList, pickingId:u32,\n};\n@group(1) @binding(0) var vertexUniforms:VertexUniforms;\nstruct InputData { @location(0) position:vec3, @location(1) vertexColor:vec4,\n};\nstruct OutputData { @builtin(position) position:vec4, @location(0) vertexPosition:vec3, @location(1) vertexColor:vec4, @location(7) currentClipPos:vec4, @location(8) prevClipPos:vec4, @location(15) @interpolate(flat) pickingId:vec4,\n};\nstruct OutputShadowData { @builtin(position) position:vec4,\n};\n@vertex\nfn main(inputData:InputData) -> OutputData { var output:OutputData; let u_projectionCameraMatrix=systemUniforms.projectionCameraMatrix; let u_noneJitterProjectionCameraMatrix=systemUniforms.noneJitterProjectionCameraMatrix; let u_prevNoneJitterProjectionCameraMatrix=systemUniforms.prevNoneJitterProjectionCameraMatrix; let u_matrixList=vertexUniforms.matrixList; let u_modelMatrix=u_matrixList.modelMatrix; let u_prevModelMatrix=u_matrixList.prevModelMatrix; let input_position=inputData.position; let input_vertexColor=inputData.vertexColor; let input_position_vec4=vec4(input_position,1.0); var position:vec4; position=u_modelMatrix * input_position_vec4; output.position=u_projectionCameraMatrix * position; output.vertexPosition=position.xyz; output.vertexColor=input_vertexColor; { output.currentClipPos=u_noneJitterProjectionCameraMatrix * position; output.prevClipPos=u_prevNoneJitterProjectionCameraMatrix * u_prevModelMatrix * input_position_vec4; } return output;\n}\n@vertex\nfn picking(inputData:InputData) -> OutputData { var output:OutputData; return output;\n}\n";const Za=parseWGSL(Wa),Ja=Za.uniforms.vertexUniforms;class Line3D extends Mesh{baseColor;#kd;#Od=1;#Nd=.01;#of=.01;#Vd=[];#Fd=[];#Hd;constructor(i,g=qa.LINEAR,x="#fff"){super(i),this.primitiveState.topology=Lr.LINE_STRIP,this.baseColor=x,this.#kd=g,this._geometry=new Geometry(i,new VertexBuffer(i,this.#Vd,new VertexInterleavedStruct({vertexPosition:VertexInterleaveType.float32x3,vertexColor:VertexInterleaveType.float32x4}))),this._material=new LineMaterial(i)}get originalPoints(){return this.#Fd}get type(){return this.#kd}set type(i){this.#kd=i,this.#zd()}get interleaveData(){return this.#Vd}get tension(){return this.#Od}set tension(i){validatePositiveNumberRange(i),this.#Od=i,this.#zd()}get tolerance(){return this.#Nd}set tolerance(i){validatePositiveNumberRange(i),this.#Nd=i,this.#zd()}get distance(){return this.#of}set distance(i){validatePositiveNumberRange(i),this.#of=i,this.#zd()}get numPoints(){return this.#Fd.length}get geometry(){return this._geometry}set geometry(i){consoleAndThrowError("Line3D can not change geometry")}get material(){return this._material}set material(i){consoleAndThrowError("Line3D can not change material")}createCustomMeshVertexShaderModule=()=>this.createMeshVertexShaderModuleBASIC("VERTEX_MODULE_LINE_3D",Za,Ja,Wa);addPoint(i=0,g=0,x=0,_=this.baseColor,v=1,b=0,y=0,S=0,w=0,L=0,k=0){this.#Fd.push(new LinePointWithInOut(i,g,x,b,y,S,w,L,k,_,v)),this.#zd()}addPointAt(i,g=0,x=0,_=0,v=this.baseColor,b=1,y=0,S=0,w=0,L=0,k=0,H=0){this.#Fd.length1)for(this.#Hd=(i=>{let g,x=[],_=0,v=0;const b=i.length;for(;_{const x=i.length,_=x-2;for(let v=0;v{let x=[],_=(i.length-1)/3;_=Math.floor(_);let v,b=0;for(;b<_;++b)v=3*b,getPointsOnBezierCurveWithSplitting(i,v,g,x);return x})(this.#Hd,x),v=lineSimplifyPoints(v,0,v.length,_),b=0,y=v.length;b, normalModelMatrix:mat4x4,\n}\nstruct VertexUniforms { pickingId:u32, matrixList:MatrixList, combinedOpacity:f32,\n};\n@group(1) @binding(0) var vertexUniforms:VertexUniforms;\nstruct InputData { @location(0) position:vec3, @location(1) vertexNormal:vec3, @location(2) uv:vec2,\n};\nstruct OutputData { @builtin(position) position:vec4, @location(0) vertexPosition:vec3, @location(1) vertexNormal:vec3, @location(2) uv:vec2, @location(11) combinedOpacity:f32, @location(13) shadowPos:vec3, @location(15) @interpolate(flat) pickingId:vec4,\n};\nstruct OutputShadowData { @builtin(position) position:vec4,\n};\n@vertex\nfn main(inputData:InputData) -> OutputData { var output:OutputData; let u_projectionMatrix=systemUniforms.projectionMatrix; let u_camera=systemUniforms.camera; let u_cameraMatrix=u_camera.cameraMatrix; let u_cameraPosition=u_camera.cameraPosition; let u_modelMatrix=vertexUniforms.matrixList.modelMatrix; let u_normalModelMatrix=vertexUniforms.matrixList.normalModelMatrix; let input_position=inputData.position; let input_vertexNormal=inputData.vertexNormal; let input_uv=inputData.uv; var position:vec4; var normalPosition:vec4; position=u_cameraMatrix * u_modelMatrix * vec4(input_position,1.0); normalPosition=u_cameraMatrix * u_normalModelMatrix * vec4(input_vertexNormal,1.0); output.position=u_projectionMatrix * position; output.vertexPosition=position.xyz; output.vertexNormal=normalPosition.xyz; output.uv=input_uv; output.combinedOpacity=vertexUniforms.combinedOpacity; return output;\n}\n@vertex\nfn picking(inputData:InputData) -> OutputData { var output:OutputData; let u_projectionMatrix=systemUniforms.projectionMatrix; let u_camera=systemUniforms.camera; let u_cameraMatrix=u_camera.cameraMatrix; let u_cameraPosition=u_camera.cameraPosition; let u_modelMatrix=vertexUniforms.matrixList.modelMatrix; let u_normalModelMatrix=vertexUniforms.matrixList.normalModelMatrix; let input_position=inputData.position; let input_vertexNormal=inputData.vertexNormal; let input_uv=inputData.uv; var position:vec4; var normalPosition:vec4; position=u_cameraMatrix * u_modelMatrix * vec4(input_position,1.0); normalPosition=u_cameraMatrix * u_normalModelMatrix * vec4(input_vertexNormal,1.0); output.position=u_projectionMatrix * position; output.pickingId=unpack4x8unorm(vertexUniforms.pickingId); return output;\n}\n";const rs=parseWGSL(ns),is=rs.uniforms.vertexUniforms,as=mixInMesh2D(ATextField);class TextField2D extends as{#Bt=1;#It=1;#$d=!0;constructor(i,x=!0){super(i,(i,g)=>{this.#Bt===i&&this.#It===g||(this.dirtyTransform=!0),this.#Bt=i,this.#It=g},!1),this._geometry=new Plane(i,1,1,1,1,1,!0),this.useSmoothing=x,this.primitiveState.cullMode=ei.FRONT,g(this)}get useSmoothing(){return this.#$d}set useSmoothing(i){this.#$d=i,this.useSmoothing?(this._material.diffuseTextureSampler.minFilter=v.LINEAR,this._material.diffuseTextureSampler.magFilter=v.LINEAR,this._material.diffuseTextureSampler.mipmapFilter=b.LINEAR):(this._material.diffuseTextureSampler.minFilter=v.NEAREST,this._material.diffuseTextureSampler.magFilter=v.NEAREST,this._material.diffuseTextureSampler.mipmapFilter=null)}get width(){return this.#Bt}get height(){return this.#It}get geometry(){return this._geometry}set geometry(i){console.error("TextField2D can not change geometry")}get material(){return this._material}set material(i){console.error("TextField2D can not change material")}createCustomMeshVertexShaderModule=()=>this.createMeshVertexShaderModuleBASIC("VERTEX_MODULE_TEXT_FIELD_2D",rs,is,ns)}Object.freeze(TextField2D);const ss=3.141592653589793,os=6.283185307179586,us=.225,ls=1.27323954,cs=.405284735,hs=1.5707963267948966,fs=Math.PI/180;class InstancingMeshObject3D{modelMatrix=create$4();localMatrix=create$4();normalModelMatrix=create$4();#Ot=0;#Vt=0;#Nt=0;#Fs=[0,0,0];#Xs=1;#js=1;#Ys=1;#qs=[1,1,1];#Di=0;#Ui=0;#Li=0;#Ws=[0,0,0];#Kd=0;#Xd;#l;#eo=1;constructor(i,g,x){validateRedGPUContext(i),this.#l=i,this.#Xd=x,this.#Kd=g,this.#jd()}get opacity(){return this.#eo}set opacity(i){validatePositiveNumberRange(i,0,1),this.#eo=i,this.#jd()}get x(){return this.#Ot}set x(i){this.#Ot=this.#Fs[0]=i,this.#jd()}get y(){return this.#Nt}set y(i){this.#Nt=this.#Fs[1]=i,this.#jd()}get z(){return this.#Vt}set z(i){this.#Vt=this.#Fs[2]=i,this.#jd()}get position(){return this.#Fs}set position(i){this.#Ot=this.#Fs[0]=i,this.#Nt=this.#Fs[1]=i,this.#Vt=this.#Fs[2]=i,this.#jd()}get scaleX(){return this.#Xs}set scaleX(i){this.#Xs=this.#qs[0]=i,this.#jd()}get scaleY(){return this.#js}set scaleY(i){this.#js=this.#qs[1]=i,this.#jd()}get scaleZ(){return this.#Ys}set scaleZ(i){this.#Ys=this.#qs[2]=i,this.#jd()}get scale(){return this.#Fs}set scale(i){this.#Xs=this.#qs[0]=i,this.#js=this.#qs[1]=i,this.#Ys=this.#qs[2]=i,this.#jd()}get rotationX(){return this.#Di}set rotationX(i){this.#Di=this.#Ws[0]=i,this.#jd()}get rotationY(){return this.#Ui}set rotationY(i){this.#Ui=this.#Ws[1]=i,this.#jd()}get rotationZ(){return this.#Li}set rotationZ(i){this.#Li=this.#Ws[2]=i,this.#jd()}get rotation(){return this.#Ws}set rotation(i){this.#Di=this.#Ws[0]=i,this.#Ui=this.#Ws[1]=i,this.#Li=this.#Ws[2]=i,this.#jd()}setScale(i,g,x){g=g??i,x=x??i;const _=this.#qs;this.#Xs=_[0]=i,this.#js=_[1]=g,this.#Ys=_[2]=x,this.#jd()}setPosition(i,g,x){g=g??i,x=x??i;const _=this.#Fs;this.#Ot=_[0]=i,this.#Nt=_[1]=g,this.#Vt=_[2]=x,this.#jd()}setRotation(i,g,x){g=g??i,x=x??i;const _=this.#Ws;this.#Di=_[0]=i,this.#Ui=_[1]=g,this.#Li=_[2]=x,this.#jd()}#jd(){let i,g,x,_,v,b,y,S,w,L,k,H,z,q,W,be,Ke,Xe,je,Ye,Ze,Je,Qe,et,tt,it,ft,pt,xt,vt,bt,yt,St,Tt,Mt,wt,Ct,Rt;{const z=this.localMatrix;let Ke;L=1,k=0,H=0,q=0,W=1,be=0,Xe=0,je=0,Ye=1,z[12]=this.#Ot,z[13]=this.#Nt,z[14]=this.#Vt,z[15]=1,y=this.#Di*fs,S=this.#Ui*fs,w=this.#Li*fs,Ke=y%os,Ke<-ss?Ke+=os:Ke>ss&&(Ke-=os),Ke=Ke<0?ls*Ke+cs*Ke*Ke:ls*Ke-cs*Ke*Ke,i=Ke<0?us*(Ke*-Ke-Ke)+Ke:us*(Ke*Ke-Ke)+Ke,Ke=(y+hs)%os,Ke<-ss?Ke+=os:Ke>ss&&(Ke-=os),Ke=Ke<0?ls*Ke+cs*Ke*Ke:ls*Ke-cs*Ke*Ke,_=Ke<0?us*(Ke*-Ke-Ke)+Ke:us*(Ke*Ke-Ke)+Ke,Ke=S%os,Ke<-ss?Ke+=os:Ke>ss&&(Ke-=os),Ke=Ke<0?ls*Ke+cs*Ke*Ke:ls*Ke-cs*Ke*Ke,g=Ke<0?us*(Ke*-Ke-Ke)+Ke:us*(Ke*Ke-Ke)+Ke,Ke=(S+hs)%os,Ke<-ss?Ke+=os:Ke>ss&&(Ke-=os),Ke=Ke<0?ls*Ke+cs*Ke*Ke:ls*Ke-cs*Ke*Ke,v=Ke<0?us*(Ke*-Ke-Ke)+Ke:us*(Ke*Ke-Ke)+Ke,Ke=w%os,Ke<-ss?Ke+=os:Ke>ss&&(Ke-=os),Ke=Ke<0?ls*Ke+cs*Ke*Ke:ls*Ke-cs*Ke*Ke,x=Ke<0?us*(Ke*-Ke-Ke)+Ke:us*(Ke*Ke-Ke)+Ke,Ke=(w+hs)%os,Ke<-ss?Ke+=os:Ke>ss&&(Ke-=os),Ke=Ke<0?ls*Ke+cs*Ke*Ke:ls*Ke-cs*Ke*Ke,b=Ke<0?us*(Ke*-Ke-Ke)+Ke:us*(Ke*Ke-Ke)+Ke,vt=v*b,bt=_*x+i*g*b,yt=i*x-_*g*b,St=-v*x,Tt=_*b-i*g*x,Mt=i*b+_*g*x,wt=g,Ct=-i*v,Rt=_*v;let Ze=this.#Xs,Je=this.#js,Qe=this.#Ys;z[0]=vt*Ze,z[1]=bt*Ze,z[2]=yt*Ze,z[3]=0,z[4]=St*Je,z[5]=Tt*Je,z[6]=Mt*Je,z[7]=0,z[8]=wt*Qe,z[9]=Ct*Qe,z[10]=Rt*Qe,z[11]=0}this.modelMatrix=this.localMatrix;{let i=this.normalModelMatrix,g=this.modelMatrix;L=g[0],k=g[1],H=g[2],z=g[3],q=g[4],W=g[5],be=g[6],Ke=g[7],Xe=g[8],je=g[9],Ye=g[10],Ze=g[11],Qe=g[12],et=g[13],tt=g[14],it=g[15],Je=L*W-k*q,ft=L*be-H*q,pt=L*Ke-z*q,xt=k*be-H*W,vt=k*Ke-z*W,bt=H*Ke-z*be,yt=Xe*et-je*Qe,St=Xe*tt-Ye*Qe,Tt=Xe*it-Ze*Qe,wt=je*it-Ze*et,Mt=Ye*it-Ze*tt,Rt=Je*Mt-ft*wt+pt*Mt+xt*Tt-vt*St+bt*yt,Rt=1/Rt,i[0]=(W*Mt-be*wt+Ke*Mt)*Rt,i[4]=(-k*Mt+H*wt-z*Mt)*Rt,i[8]=(et*bt-tt*vt+it*xt)*Rt,i[12]=(-je*bt+Ye*vt-Ze*xt)*Rt,i[1]=(-q*Mt+be*Tt-Ke*St)*Rt,i[5]=(L*Mt-H*Tt+z*St)*Rt,i[9]=(-Qe*bt+tt*pt-it*ft)*Rt,i[13]=(Xe*bt-Ye*pt+Ze*ft)*Rt,i[2]=(q*wt-W*Tt+Ke*yt)*Rt,i[6]=(-L*wt+k*Tt-z*yt)*Rt,i[10]=(Qe*vt-et*pt+it*Je)*Rt,i[14]=(-Xe*vt+je*pt-Ze*Je)*Rt,i[3]=(-q*Mt+W*St-be*yt)*Rt,i[7]=(L*Mt-k*St+H*yt)*Rt,i[11]=(-Qe*xt+et*ft-tt*Je)*Rt,i[15]=(Xe*xt-je*ft+Ye*Je)*Rt}if(this.#Xd.gpuRenderInfo){const{vertexUniformBuffer:i,vertexUniformInfo:g}=this.#Xd.gpuRenderInfo,{dataViewF32:x}=i,{members:_}=g,v=_.instanceModelMatrixs,b=_.instanceNormalModelMatrix,y=_.instanceOpacity;x.set(this.modelMatrix,(v.uniformOffset+v.stride*this.#Kd)/4),x.set(this.normalModelMatrix,(b.uniformOffset+b.stride*this.#Kd)/4),x.set([this.opacity],(y.uniformOffset+y.stride*this.#Kd)/4),this.#Xd.dirtyInstanceMeshObject3D=!0}}}var ds=Object.freeze({__proto__:null,instancingMeshObject3D:InstancingMeshObject3D});class ResourceStateStorageBuffer{static dirtyList=[];buffer;uuid;#Wt=0;constructor(i){this.buffer=i,this.uuid=i.uuid}get useNum(){return this.#Wt}set useNum(i){this.#Wt=i,ResourceStateStorageBuffer.dirtyList.push(this)}}class StorageBuffer extends AUniformBaseBuffer{constructor(i,g,x="",_=""){super(i,"managedStorageBufferState",GPUBufferUsage.STORAGE|GPUBufferUsage.COPY_DST|GPUBufferUsage.COPY_SRC,g,x);const{table:v}=this.targetResourceManagedState,b=v.get(_);if(b)return b.buffer;_&&(this.name=_,this[er]=_),this.redGPUContext.resourceManager.registerManagementResource(this,new ResourceStateStorageBuffer(this))}}Object.freeze(StorageBuffer);var ms="struct OutputData { @builtin(position) position:vec4, @location(0) vertexPosition:vec3, @location(1) vertexNormal:vec3, @location(2) uv:vec2, @location(3) uv1:vec2, @location(4) vertexColor_0:vec4, @location(5) vertexTangent:vec4, @location(7) currentClipPos:vec4, @location(8) prevClipPos:vec4, @location(10) localNodeScale_volumeScale:vec2, @location(11) instanceOpacity:f32, @location(12) motionVector:vec3, @location(13) shadowPos:vec3, @location(14) @interpolate(flat) receiveShadow:f32, @location(15) @interpolate(flat) pickingId:vec4,\n};\n";const ps="VERTEX_MODULE_INSTANCING";class InstancingMesh extends Mesh{dirtyInstanceMeshObject3D=!0;dirtyInstanceNum=!0;#l;#Yd=1;#qd=1;#Wd=[];#xo;#Zd;#Jd;#Qd;#em;#tm;#nm=0;#rm=0;#im;#vo=[];constructor(i,g,x,_,v){super(i,_,v),this.#l=i,this.#ne(),this.maxInstanceCount=g,this.instanceCount=x}get instanceCount(){return this.#Yd}set instanceCount(i){validateUintRange(i),this.#Yd=Math.min(i,this.#qd),this.gpuRenderInfo.vertexUniformInfo=parseWGSL(this.#am(this.geometry,this.material)).storage.instanceUniforms,this.#sm(),this.#Wd.length>this.#Yd&&(this.#Wd.length=this.#Yd);let g=this.#Yd;for(;g--;)this.#Wd[g]||(this.#Wd[g]=new InstancingMeshObject3D(this.#l,g,this));this.#om(),this.#Sf(this.#l),this.dirtyInstanceNum=!0}get maxInstanceCount(){return this.#qd}set maxInstanceCount(i){validateUintRange(i);const g=InstancingMesh.getLimitSize();i=Math.min(i,g),this.#qd=i,this.#Yd>this.#qd&&(this.instanceCount=this.#qd)}get instanceChildren(){return this.#Wd}static getLimitSize(){const i=Math.floor(Math.min(268435456,134217728));return Math.floor((i-80)/132)}render(i,g=!1){if(this.dirtyLOD)return this.#om(),this.#Sf(this.#l),this.dirtyInstanceNum=!0,void(this.dirtyLOD=!1);const{view:x,currentRenderPassEncoder:_}=i,{scene:v}=x,{shadowManager:b}=v,{directionalShadowManager:y}=b,{castingList:S}=y;this.dirtyTransform&&this.#um(),this.geometry?i.num3DObjects++:i.num3DGroups++;const w=this.#l;if(this.geometry){const{antialiasingManager:x}=w;x.changedMSAA&&(this.dirtyPipeline=!0),this.gpuRenderInfo||this.#Sf(w);(this.dirtyPipeline||this.material.dirtyPipeline)&&this.#lm(i),g||this.#cm(i),this.#hm(i,g,_)}this.castShadow&&(S[S.length]=this);const{children:L}=this;let k=L.length;for(;k--;)L[k].dirtyTransform=this.dirtyTransform,L[k].render(i);this.dirtyTransform=!1}#um(){identity$1(this.localMatrix),translate(this.localMatrix,this.localMatrix,[this.x,this.y,this.z]),rotateX$2(this.localMatrix,this.localMatrix,this.rotationX),rotateY$2(this.localMatrix,this.localMatrix,this.rotationY),rotateZ$2(this.localMatrix,this.localMatrix,this.rotationZ),scale$4(this.localMatrix,this.localMatrix,[this.scaleX,this.scaleY,this.scaleZ]);const i=this.parent;i?.modelMatrix?multiply$4(this.modelMatrix,this.localMatrix,i.modelMatrix):this.modelMatrix=clone$4(this.localMatrix)}#lm(i){this.dirtyTransform=!0,this.material.dirtyPipeline&&this.material._updateFragmentState(),this.#fm(),this.material.dirtyPipeline=!1,this.dirtyPipeline=!1,i.numDirtyPipelines++}#hm(i,g,x){const{gpuRenderInfo:_}=this,{pipeline:v,shadowPipeline:b}=_;this.#dm(),this.#mm();const{fragmentUniformBindGroup:y}=this.material.gpuRenderInfo;x.setBindGroup(0,i.view.systemUniform_Vertex_UniformBindGroup),x.setBindGroup(2,y),x.setPipeline(g?b:v);this.#pm(x,this.geometry,this.gpuRenderInfo.vertexUniformBindGroup,this.material.gpuRenderInfo.fragmentUniformBindGroup,0,20),this.LODManager.LODList.forEach((i,g)=>{const _=this.#vo[g];x.setPipeline(_.pipeline),this.#pm(x,i.geometry,_.vertexUniformBindGroup,i.material?i.material.gpuRenderInfo.fragmentUniformBindGroup:this.material.gpuRenderInfo.fragmentUniformBindGroup,g+1,20)}),i.numDrawCalls++,i.numInstances++}#pm(i,g,x,_,v,b){const{vertexBuffer:y,indexBuffer:S}=g,w=b*v;if(i.setBindGroup(1,x),i.setBindGroup(2,_),i.setVertexBuffer(0,y.gpuBuffer),S){const{gpuBuffer:g,format:x}=S;i.setIndexBuffer(g,x),i.drawIndexedIndirect(this.#im,w)}else i.drawIndirect(this.#im,w)}#dm(){const{vertexUniformBuffer:i,vertexUniformInfo:g}=this.gpuRenderInfo,{displacementTexture:x,displacementScale:_}=this.material||{},{members:v}=g;void 0!==v.displacementScale&&this.#xo!==_&&(this.#xo=_,i.dataViewF32.set(new v.displacementScale.View([_]),v.displacementScale.uniformOffset/4)),void 0!==v.useDisplacementTexture&&this.#Zd!==!!x&&(this.#Zd=!!x,i.dataViewF32.set(new v.useDisplacementTexture.View([x?1:0]),v.useDisplacementTexture.uniformOffset/4))}#mm(){const{vertexUniformBuffer:i,vertexUniformInfo:g}=this.gpuRenderInfo,{gpuDevice:x}=this.#l,{members:_}=g;this.dirtyTransform&&(i.dataViewF32.set(this.modelMatrix,_.instanceGroupModelMatrix.uniformOffset/4),x.queue.writeBuffer(i.gpuBuffer,_.instanceGroupModelMatrix.uniformOffset,new _.instanceGroupModelMatrix.View(this.modelMatrix))),(this.dirtyInstanceMeshObject3D||this.dirtyInstanceNum)&&(x.queue.writeBuffer(i.gpuBuffer,0,i.data),this.dirtyInstanceMeshObject3D=!1,this.dirtyInstanceNum=!1)}#ne(){const{gpuDevice:i}=this.#l;this.gpuRenderInfo=new VertexGPURenderInfo(null,null,null,null,null,null,null,null);this.#im=i.createBuffer({size:160,usage:GPUBufferUsage.INDIRECT|GPUBufferUsage.STORAGE|GPUBufferUsage.COPY_DST,label:`IndirectDrawBuffer_${this.uuid}`});const g=new Float32Array(40);this.#em=new StorageBuffer(this.#l,g.buffer,`CullingUniformBuffer_${this.uuid}`)}#Sf(i){this.dirtyPipeline=!0;const g=new ArrayBuffer(this.#nm*(this.LODManager.LODList.length+1));this.#tm?.destroy(),this.#tm=new StorageBuffer(i,g,`VisibilityBuffer_${this.uuid}`),this.#fm(),this.#gm(this.#l)}#gm(i){const{gpuDevice:g,resourceManager:x}=i,_={code:this.#xm()},v=x.createGPUShaderModule(`CULLING_COMPUTE_MODULE_INSTANCING_${this.#qd}_${this.uuid}`,_),b=g.createBindGroupLayout({entries:[{binding:0,visibility:GPUShaderStage.COMPUTE,buffer:{type:"read-only-storage"}},{binding:1,visibility:GPUShaderStage.COMPUTE,buffer:{type:"read-only-storage"}},{binding:2,visibility:GPUShaderStage.COMPUTE,buffer:{type:"storage"}},{binding:3,visibility:GPUShaderStage.COMPUTE,buffer:{type:"storage"}}]});this.#Jd=g.createComputePipeline({layout:g.createPipelineLayout({bindGroupLayouts:[b]}),compute:{module:v,entryPoint:"main"}}),this.#Qd=g.createBindGroup({layout:b,entries:[{binding:0,resource:{buffer:this.gpuRenderInfo.vertexUniformBuffer.gpuBuffer}},{binding:1,resource:{buffer:this.#em.gpuBuffer}},{binding:2,resource:{buffer:this.#tm.gpuBuffer}},{binding:3,resource:{buffer:this.#im}}]})}#_m(i){const{view:g}=i,{gpuDevice:x}=this.#l,{data:_,dataViewU32:v,dataViewF32:b}=this.#em;v.set([this.#Yd],0),v.set([this.#rm],1),v.set([this.LODManager.LODList.length],2),b.set(g.rawCamera.position,4),b.set(g.frustumPlanes.flat(),8),b.set([...this.LODManager.LODList.map(i=>i.distance)],32),x.queue.writeBuffer(this.#em.gpuBuffer,0,_)}#cm(i){const{gpuDevice:g}=this.#l;this.#_m(i);const x=this.geometry.indexBuffer?this.geometry.indexBuffer.indexCount:this.geometry.vertexBuffer.vertexCount,_=new Uint32Array([x,0,0,0,0]);g.queue.writeBuffer(this.#im,0,_),this.LODManager.LODList.forEach((i,x)=>{const _=i.geometry.indexBuffer.indexCount,v=new Uint32Array([_,0,0,0,0]),b=20*(x+1);g.queue.writeBuffer(this.#im,b,v)});const v=g.createCommandEncoder(),b=v.beginComputePass();b.setPipeline(this.#Jd),b.setBindGroup(0,this.#Qd);const y=Math.ceil(this.#Yd/64);b.dispatchWorkgroups(y),b.end(),g.queue.submit([v.finish()])}#fm(){const{resourceManager:i,gpuDevice:g}=this.#l,x={code:this.#am(this.geometry,this.material)},_=i.createGPUShaderModule(`${ps}_${this.#qd}_${this.uuid}`,x),v=i.getGPUBindGroupLayout(ResourceManager.PRESET_VERTEX_GPUBindGroupLayout_Instancing);this.gpuRenderInfo.vertexShaderModule=_,this.gpuRenderInfo.pipeline=createBasePipeline(this,_,v),this.gpuRenderInfo.shadowPipeline=createBasePipeline(this,_,v,hi),this.gpuRenderInfo.vertexUniformBindGroup=g.createBindGroup(this.#vm()),this.#vo.length=0,this.LODManager.LODList.forEach((x,_)=>{const b={code:this.#am(x.geometry,x.material)},y=i.createGPUShaderModule(`${ps}_${this.#qd}_LOD${_}_${this.uuid}`,b);this.#vo[_]={pipeline:createBasePipeline({vertexStateBuffers:x.geometry.gpuRenderInfo.buffers,primitiveState:this.primitiveState,depthStencilState:this.depthStencilState,geometry:x.geometry,material:x.material||this.material,redGPUContext:this.#l,gpuRenderInfo:this.gpuRenderInfo},y,v),vertexUniformBindGroup:g.createBindGroup(this.#vm(_+1))}})}#vm(i=0){const{resourceManager:g}=this.#l,{vertexUniformBuffer:x}=this.gpuRenderInfo,{material:_}=this,{basicSampler:v,emptyBitmapTextureView:b}=g,{gpuSampler:y}=v,S=g.getGPUBindGroupLayout(ResourceManager.PRESET_VERTEX_GPUBindGroupLayout_Instancing),w=this.#nm,L=w*i,k=w;if(L+k>this.#tm.size)throw new Error("Binding range exceeds visibility buffer size.");return{layout:S,label:"VERTEX_BIND_GROUP_DESCRIPTOR_INSTANCING",entries:[{binding:0,resource:{buffer:x.gpuBuffer,offset:0,size:x.size}},{binding:1,resource:_?.displacementTextureSampler?.gpuSampler||y},{binding:2,resource:g.getGPUResourceBitmapTextureView(_?.displacementTexture)||b},{binding:3,resource:{buffer:this.#tm.gpuBuffer,offset:L,size:k}}]}}#om(){const i=4*this.#Yd;this.#nm=256*Math.ceil(i/256),this.#rm=this.#nm/4}#sm(){const i=this.gpuRenderInfo.vertexUniformInfo,g=new ArrayBuffer(i.arrayBufferByteLength),x=new StorageBuffer(this.#l,g,`InstanceBuffer_${this.uuid}`),_=this.gpuRenderInfo.vertexUniformBuffer;_?.gpuBuffer&&(x.dataViewF32.set(_.dataViewF32,0),x.dataViewU32.set([_.dataViewU32[0]],0),x.dataViewU32.set([_.dataViewU32[1]],4),_.destroy()),this.gpuRenderInfo.vertexUniformBuffer=x}#bm(i,g="",x="",_="",v=""){return[g,x,_,i.replaceAll(/__INSTANCE_COUNT__/g,this.#qd.toString()),v].join("\n")}#am(i,g){const x=i.vertexBuffer.interleavedStruct.label,_=g instanceof PBRMaterial,v="PBR"===x&&_,b=v?"struct InputData { @builtin(instance_index) instanceIdx:u32, @location(0) position:vec3, @location(1) vertexNormal:vec3, @location(2) uv:vec2, @location(3) uv1:vec2, @location(4) vertexColor_0:vec4, @location(5) vertexTangent:vec4,\n};\n":"struct InputData { @builtin(instance_index) instanceIdx:u32, @location(0) position:vec3, @location(1) vertexNormal:vec3, @location(2) uv:vec2,\n};",y="PBR"!==x&&_||v?ms:"struct OutputData { @builtin(position) position:vec4, @location(0) vertexPosition:vec3, @location(1) vertexNormal:vec3, @location(2) uv:vec2, @location(7) currentClipPos:vec4, @location(8) prevClipPos:vec4, @location(11) instanceOpacity:f32, @location(12) motionVector:vec3, @location(13) shadowPos:vec3, @location(14) @interpolate(flat) receiveShadow:f32, @location(15) @interpolate(flat) pickingId:vec4,\n};\n";return this.#bm("#redgpu_include SYSTEM_UNIFORM;\n#redgpu_include calcDisplacements;\nstruct InstanceUniforms { useDisplacementTexture:u32, displacementScale:f32, instanceGroupModelMatrix:mat4x4, instanceModelMatrixs:array,__INSTANCE_COUNT__>, instanceNormalModelMatrix:array,__INSTANCE_COUNT__>, instanceOpacity:array,\n};\n@group(1) @binding(0) var instanceUniforms:InstanceUniforms;\n@group(1) @binding(1) var displacementTextureSampler:sampler;\n@group(1) @binding(2) var displacementTexture:texture_2d;\n@group(1) @binding(3) var visibilityBuffer:array;\nconst maxDistance:f32=1000.0;\nconst maxMipLevel:f32=10.0;",v?"@vertex\nfn main(inputData:InputData) -> OutputData { var output:OutputData; let input_instanceIdx:u32=visibilityBuffer[inputData.instanceIdx]; let u_modelMatrix=instanceUniforms.instanceModelMatrixs[input_instanceIdx]; let u_normalModelMatrix=instanceUniforms.instanceNormalModelMatrix[input_instanceIdx]; let u_instanceGroupModelMatrix=instanceUniforms.instanceGroupModelMatrix; let u_useDisplacementTexture=instanceUniforms.useDisplacementTexture==1u; let u_displacementScale=instanceUniforms.displacementScale; let u_projectionMatrix=systemUniforms.projectionMatrix; let u_projectionCameraMatrix=systemUniforms.projectionCameraMatrix; let u_camera=systemUniforms.camera; let u_cameraMatrix=u_camera.cameraMatrix; let u_cameraPosition=u_camera.cameraPosition; let input_position=inputData.position; let input_vertexNormal=inputData.vertexNormal; let input_uv=inputData.uv; var position:vec4=u_modelMatrix * vec4(input_position,1.0); let worldPosition=position.xyz; if (u_useDisplacementTexture) { let distance=distance(position.xyz,u_cameraPosition); let mipLevel=(distance/maxDistance) * maxMipLevel; let displacedPosition=calcDisplacementPosition( input_position, input_vertexNormal, displacementTexture, displacementTextureSampler, u_displacementScale, input_uv, mipLevel ); position=u_modelMatrix * vec4(displacedPosition,1.0); } output.position=u_projectionCameraMatrix * u_instanceGroupModelMatrix * position; output.vertexPosition=position.xyz; var normalPosition:vec3=(u_instanceGroupModelMatrix * u_normalModelMatrix * vec4(input_vertexNormal,1.0)).xyz; output.vertexNormal=normalPosition; output.instanceOpacity=instanceUniforms.instanceOpacity[input_instanceIdx]; output.uv=inputData.uv; output.uv1=inputData.uv1; output.vertexColor_0=inputData.vertexColor_0; output.vertexTangent=u_normalModelMatrix * inputData.vertexTangent; return output;\n}\n":"@vertex\nfn main(inputData:InputData) -> OutputData { var output:OutputData; let input_instanceIdx:u32=visibilityBuffer[inputData.instanceIdx]; let u_modelMatrix=instanceUniforms.instanceModelMatrixs[input_instanceIdx]; let u_normalModelMatrix=instanceUniforms.instanceNormalModelMatrix[input_instanceIdx]; let u_instanceGroupModelMatrix=instanceUniforms.instanceGroupModelMatrix; let u_useDisplacementTexture=instanceUniforms.useDisplacementTexture==1u; let u_displacementScale=instanceUniforms.displacementScale; let u_projectionMatrix=systemUniforms.projectionMatrix; let u_projectionCameraMatrix=systemUniforms.projectionCameraMatrix; let u_camera=systemUniforms.camera; let u_cameraMatrix=u_camera.cameraMatrix; let u_cameraPosition=u_camera.cameraPosition; let input_position=inputData.position; let input_vertexNormal=inputData.vertexNormal; let input_uv=inputData.uv; var position:vec4=u_modelMatrix * vec4(input_position,1.0); let worldPosition=position.xyz; if (u_useDisplacementTexture) { let distance=distance(position.xyz,u_cameraPosition); let mipLevel=(distance/maxDistance) * maxMipLevel; let displacedPosition=calcDisplacementPosition( input_position, input_vertexNormal, displacementTexture, displacementTextureSampler, u_displacementScale, input_uv, mipLevel ); position=u_modelMatrix * vec4(displacedPosition,1.0); } output.position=u_projectionCameraMatrix * u_instanceGroupModelMatrix * position; output.vertexPosition=position.xyz; var normalPosition:vec3=(u_instanceGroupModelMatrix * u_normalModelMatrix * vec4(input_vertexNormal,1.0)).xyz; output.vertexNormal=normalPosition; output.uv=input_uv; output.instanceOpacity=instanceUniforms.instanceOpacity[input_instanceIdx]; return output;\n}\n",b,y,"\nstruct OutputShadowData { @builtin(position) position:vec4,\n};\n@vertex\nfn drawDirectionalShadowDepth(inputData:InputData) -> OutputShadowData { var output:OutputShadowData; let input_instanceIdx:u32=visibilityBuffer[inputData.instanceIdx]; let u_directionalLightProjectionViewMatrix=systemUniforms.directionalLightProjectionViewMatrix; let u_modelMatrix=instanceUniforms.instanceModelMatrixs[input_instanceIdx]; let u_useDisplacementTexture=instanceUniforms.useDisplacementTexture==1u; let u_displacementScale=instanceUniforms.displacementScale; let input_position=inputData.position; let input_vertexNormal=inputData.vertexNormal; let input_uv=inputData.uv; var position:vec4=u_modelMatrix * vec4(input_position,1.0); if (u_useDisplacementTexture) { let distance=distance(position.xyz,u_directionalLightProjectionViewMatrix[3].xyz); let mipLevel=(distance/maxDistance) * maxMipLevel; let displacedPosition=calcDisplacementPosition( input_position, input_vertexNormal, displacementTexture, displacementTextureSampler, u_displacementScale, input_uv, mipLevel ); position=u_modelMatrix * vec4(displacedPosition,1.0); } output.position=u_directionalLightProjectionViewMatrix * position; return output;\n}\n")}#xm(){return this.#bm("struct InstanceUniforms { useDisplacementTexture:u32, displacementScale:f32, instanceGroupModelMatrix:mat4x4, instanceModelMatrixs:array,__INSTANCE_COUNT__>, instanceNormalModelMatrix:array,__INSTANCE_COUNT__>, instanceOpacity:array,\n};\nstruct CullingUniforms { instanceCount:u32, stride:u32, lodNum:u32, padding:f32, cameraPosition:vec3, frustumPlanes:array,6>, lodDistanceList:array,\n};\nstruct IndirectDrawArgs { vertexCount:u32, instanceCount:atomic, firstVertex:u32, baseVertex:u32, firstInstance:u32,\n};\n@group(0) @binding(0) var instanceUniforms:InstanceUniforms;\n@group(0) @binding(1) var cullingUniforms:CullingUniforms;\n@group(0) @binding(2) var visibilityBuffer:array;\n@group(0) @binding(3) var indirectDrawBuffer:array;\nconst BOUNDING_RADIUS:f32=1.0;\nfn distanceToPlane(position:vec3,plane:vec4) -> f32 { return dot(vec4(position,1.0),plane);\n}\nfn isInsideFrustum(position:vec3,radius:f32) -> bool { for (var i:u32=0u;i < 6u;i=i + 1u) { let plane=cullingUniforms.frustumPlanes[i]; let distance=distanceToPlane(position,plane); if (distance < -radius) { return false; } } return true;\n}\nfn calculateLODLevel(distanceToCamera:f32) -> u32 { if (cullingUniforms.lodNum==0u) { return 0u; } for (var i:u32=0u;i < cullingUniforms.lodNum;i=i + 1u) { if (distanceToCamera < cullingUniforms.lodDistanceList[i]) { return i; } } return cullingUniforms.lodNum;\n}\n@compute @workgroup_size(64)\nfn main(@builtin(global_invocation_id) globalId:vec3) { let instanceIdx=globalId.x; if (instanceIdx >=(cullingUniforms.instanceCount)) { return; } let u_instanceGroupModelMatrix=instanceUniforms.instanceGroupModelMatrix; let modelMatrix=u_instanceGroupModelMatrix * instanceUniforms.instanceModelMatrixs[instanceIdx]; let worldPosition=vec3( modelMatrix[3][0], modelMatrix[3][1], modelMatrix[3][2] ); let scaleX=length(vec3(modelMatrix[0][0],modelMatrix[0][1],modelMatrix[0][2])); let scaleY=length(vec3(modelMatrix[1][0],modelMatrix[1][1],modelMatrix[1][2])); let scaleZ=length(vec3(modelMatrix[2][0],modelMatrix[2][1],modelMatrix[2][2])); let maxScale=max(max(scaleX,scaleY),scaleZ); let scaledRadius=BOUNDING_RADIUS * maxScale; let isVisible=isInsideFrustum(worldPosition,scaledRadius); if (isVisible) { let distanceToCamera=distance(worldPosition,cullingUniforms.cameraPosition); let lodLevel=calculateLODLevel(distanceToCamera); let visibilityStride=cullingUniforms.stride; let aliveIndex=atomicAdd(&indirectDrawBuffer[lodLevel].instanceCount,1u); visibilityBuffer[visibilityStride * lodLevel + aliveIndex]=instanceIdx; }\n}\n")}}Object.defineProperty(InstancingMesh.prototype,"meshType",{value:Gr.INSTANCED_MESH,writable:!1});var gs=Object.freeze({__proto__:null,CoreGroup:Ia,CoreInstancingMesh:ds,CoreMesh:Pa,CoreSkyBox:Ca,CoreSpriteSheet:Va,CoreTextField:ts,CoreView:Ba,Group2D:Group2D,Group3D:Group3D,InstancingMesh:InstancingMesh,LINE_TYPE:qa,Line2D:class extends Line3D{constructor(i,g=qa.LINEAR,x="#fff"){super(i,g,x),this._material=new LineMaterial(i)}get geometry(){return this._geometry}set geometry(i){consoleAndThrowError("Line2D can not change geometry")}get material(){return this._material}set material(i){consoleAndThrowError("Line2D can not change material")}createCustomMeshVertexShaderModule=()=>this.createMeshVertexShaderModuleBASIC("VERTEX_MODULE_LINE_2D",Qa,es,Wa);addPoint(i=0,g=0,x=this.baseColor,_=1,v=0,b=0,y=0,S=0){super.addPoint(i,g,0,x,_,v,b,0,y,S,0)}addPointAt(i,g=0,x=0,_=this.baseColor,v=1,b=0,y=0,S=0,w=0){super.addPointAt(i,g,x,0,_,v,b,y,0,S,w,0)}},Line3D:Line3D,Mesh:Mesh,PARTICLE_EASE:Ea,ParticleEmitter:ParticleEmitter,Scene:Scene,SkyBox:SkyBox,Sprite2D:Sprite2D,Sprite3D:Sprite3D,SpriteSheet2D:SpriteSheet2D,SpriteSheet3D:SpriteSheet3D,SpriteSheetInfo:SpriteSheetInfo,TextField2D:TextField2D,TextField3D:TextField3D,View2D:View2D,View3D:View3D}),xs=Object.freeze({__proto__:null,ABaseLight:ABaseLight}),_s=Object.freeze({__proto__:null,AmbientLight:AmbientLight,Core:xs,DirectionalLight:DirectionalLight,LightManager:LightManager,PointLight:PointLight,SpotLight:SpotLight});function sortTransparentObjects(i,g){const x={},{x:_,y:v,z:b}=i;return g.sort((i,g)=>{if(i=i.mesh,g=g.mesh,!x[i.uuid]){const g=i.x-_,y=i.y-v,S=i.z-b;x[i.uuid]=g*g+y*y+S*S}if(!x[g.uuid]){const i=g.x-_,y=g.y-v,S=g.z-b;x[g.uuid]=i*i+y*y+S*S}return x[g.uuid]-x[i.uuid]})}var vs=Object.freeze({__proto__:null,Ray:Ray,calculateNormals:calculateNormals,calculateTangents:(i,g,x,_,v)=>{const b=1e-6,y=i.length/3,S=_.length>0,w=S?_.length/3:y/3,L=new Float32Array(3*y),k=new Float32Array(3*y);for(let g=0;g=4*y;for(let i=0;ib){H.push(g,x,_,v[4*i+3]);continue}}const x=g[3*i],_=g[3*i+1],y=g[3*i+2],S=L[3*i],w=L[3*i+1],q=L[3*i+2],W=k[3*i],be=k[3*i+1],Ke=k[3*i+2],Xe=x*S+_*w+y*q;let je=S-x*Xe,Ye=w-_*Xe,Ze=q-y*Xe,Je=Math.sqrt(je*je+Ye*Ye+Ze*Ze);if(Jey+b?w-(i0&&(_=1/Math.sqrt(_||1)),W[0]=W[0]*_,W[1]=W[1]*_,W[2]=W[2]*_}{let i=Ke[0],g=Ke[1],x=Ke[2],_=i*i+g*g+x*x;_>0&&(_=1/Math.sqrt(_)),Ke[0]=Ke[0]*_,Ke[1]=Ke[1]*_,Ke[2]=Ke[2]*_}for(let g=0;g<=b;++g){const x=g/b*Math.PI*2,y=-_*Math.cos(x),S=_*Math.sin(x);k[0]=z[0]+(y*Ke[0]+S*W[0]),k[1]=z[1]+(y*Ke[1]+S*W[1]),k[2]=z[2]+(y*Ke[2]+S*W[2]),w.push(k[0],k[1],k[2]);{H[0]=k[0]-z[0],H[1]=k[1]-z[1],H[2]=k[2]-z[2];let i=H[0],g=H[1],x=H[2],_=i*i+g*g+x*x;_>0&&(_=1/Math.sqrt(_)),H[0]=H[0]*_,H[1]=H[1]*_,H[2]=H[2]*_}w.push(H[0],H[1],H[2],i/v,g/b)}}for(let i=1;i<=v;i++)for(let g=1;g<=b;g++){const x=(b+1)*(i-1)+(g-1),_=(b+1)*i+(g-1),v=(b+1)*i+g,y=(b+1)*(i-1)+g;L.push(x,_,y),L.push(_,v,y)}return createPrimitiveGeometry(g,w,L,i)}}();constructor(i,g=1,x=.4,_=64,v=8,b=2,y=3){super(i);const S=`PRIMITIVE_TORUS_NUT_R${g}_T${x}_TS${_}_RS${v}_P${b}_Q${y}`,w=i.resourceManager.cachedBufferState;let L=w[S];L||(L=w[S]=this.#Ii(S,i,g,x,_,v,b,y)),this._setData(L)}}});const Ss=parseWGSL("#redgpu_include SYSTEM_UNIFORM;\n#redgpu_include calcTintBlendMode;\n#redgpu_include calcDirectionalShadowVisibility;\n#redgpu_include normalFunctions;\n#redgpu_include drawPicking;\n#redgpu_include FragmentOutput;\n#redgpu_include calculateMotionVector;\nstruct Uniforms { color:vec3, emissiveColor:vec3, emissiveStrength:f32, specularColor:vec3, specularStrength:f32, shininess:f32, aoStrength:f32, normalScale:f32, opacity:f32, useTint:u32, tint:vec4, tintBlendMode:u32, useSSR:u32, metallic:f32, roughness:f32,\n};\nstruct InputData { @builtin(position) position:vec4, @location(0) vertexPosition:vec3, @location(1) vertexNormal:vec3, @location(2) uv:vec2, @location(7) currentClipPos:vec4, @location(8) prevClipPos:vec4, @location(11) combinedOpacity:f32, @location(12) motionVector:vec3, @location(13) shadowPos:vec3, @location(14) @interpolate(flat) receiveShadow:f32, @location(15) @interpolate(flat) pickingId:vec4,\n}\n@group(2) @binding(0) var uniforms:Uniforms;\n@group(2) @binding(1) var diffuseTextureSampler:sampler;\n@group(2) @binding(2) var diffuseTexture:texture_2d;\n@group(2) @binding(3) var alphaTextureSampler:sampler;\n@group(2) @binding(4) var alphaTexture:texture_2d;\n@group(2) @binding(5) var specularTextureSampler:sampler;\n@group(2) @binding(6) var specularTexture:texture_2d;\n@group(2) @binding(7) var emissiveTextureSampler:sampler;\n@group(2) @binding(8) var emissiveTexture:texture_2d;\n@group(2) @binding(9) var aoTextureSampler:sampler;\n@group(2) @binding(10) var aoTexture:texture_2d;\n@group(2) @binding(11) var normalTextureSampler:sampler;\n@group(2) @binding(12) var normalTexture:texture_2d;\n@fragment\nfn main(inputData:InputData) -> FragmentOutput { var output:FragmentOutput; let u_ambientLight=systemUniforms.ambientLight; let u_ambientLightColor=u_ambientLight.color; let u_ambientLightIntensity=u_ambientLight.intensity; let u_directionalLightCount=systemUniforms.directionalLightCount; let u_directionalLights=systemUniforms.directionalLights; let u_shadowDepthTextureSize=systemUniforms.shadowDepthTextureSize; let u_bias=systemUniforms.bias; let u_camera=systemUniforms.camera; let u_cameraMatrix=u_camera.cameraMatrix; let u_cameraPosition=u_camera.cameraPosition; let u_color=uniforms.color; let u_aoStrength=uniforms.aoStrength; let u_emissiveColor=uniforms.emissiveColor; let u_emissiveStrength=uniforms.emissiveStrength; let u_normalScale=uniforms.normalScale; let u_specularColor=uniforms.specularColor; let u_specularStrength=uniforms.specularStrength; let u_shininess=uniforms.shininess; let u_opacity=uniforms.opacity; let E=normalize(u_cameraPosition - inputData.vertexPosition); let receiveShadowYn=inputData.receiveShadow !=.0; var N=normalize(inputData.vertexNormal); #redgpu_if normalTexture let normalSamplerColor=textureSample(normalTexture,normalTextureSampler,inputData.uv).rgb; N=perturb_normal( N,inputData.vertexPosition,inputData.uv,normalSamplerColor,u_normalScale ); #redgpu_endIf var finalColor:vec4; var resultAlpha:f32=u_opacity * inputData.combinedOpacity; var diffuseColor:vec3=u_color; #redgpu_if diffuseTexture let diffuseSampleColor=textureSample(diffuseTexture,diffuseTextureSampler,inputData.uv); diffuseColor=diffuseSampleColor.rgb; resultAlpha=resultAlpha * diffuseSampleColor.a; #redgpu_endIf var specularSamplerValue:f32=1; #redgpu_if specularTexture specularSamplerValue=textureSample(specularTexture,specularTextureSampler,inputData.uv).r; #redgpu_endIf var mixColor:vec3; let ambientContribution=u_ambientLightColor * u_ambientLightIntensity; let ambientDiffuse=diffuseColor * ambientContribution; mixColor +=ambientDiffuse; var visibility:f32=1.0; visibility=calcDirectionalShadowVisibility( directionalShadowMap, directionalShadowMapSampler, u_shadowDepthTextureSize, u_bias, inputData.shadowPos, ); if(!receiveShadowYn){ visibility=1.0; } for (var i=0u;i < u_directionalLightCount;i=i + 1) { let u_directionalLightDirection=u_directionalLights[i].direction; let u_directionalLightColor=u_directionalLights[i].color; let u_directionalLightIntensity=u_directionalLights[i].intensity; let L=normalize(u_directionalLightDirection); let R=reflect(L,N); let lambertTerm=max(dot(N,-L),0.0); let specular=pow(max(dot(R,E),0.0),u_shininess) * specularSamplerValue; let lightContribution=u_directionalLightColor * u_directionalLightIntensity * visibility; let ld=diffuseColor * lightContribution * lambertTerm; let ls=u_specularColor * u_specularStrength * lightContribution * specular; mixColor +=ld + ls; } let clusterIndex=getClusterLightClusterIndex(inputData.position); let lightOffset=clusterLightGroup.lights[clusterIndex].offset; let lightCount:u32=clusterLightGroup.lights[clusterIndex].count; for (var lightIndex=0u;lightIndex < lightCount;lightIndex=lightIndex + 1u) { let i=clusterLightGroup.indices[lightOffset + lightIndex]; let u_clusterLightPosition=clusterLightList.lights[i].position; let u_clusterLightColor=clusterLightList.lights[i].color; let u_clusterLightIntensity=clusterLightList.lights[i].intensity; let u_clusterLightRadius=clusterLightList.lights[i].radius; let u_isSpotLight=clusterLightList.lights[i].isSpotLight; let lightDir=u_clusterLightPosition - inputData.vertexPosition; let lightDistance=length(lightDir); if (lightDistance > u_clusterLightRadius) { continue; } let L=normalize(lightDir); let dist2=max(dot(lightDir,lightDir),0.0001); let d=sqrt(dist2); let rangePart=pow(clamp(1.0 - d/u_clusterLightRadius,0.0,1.0),2.0); let invSquare=(u_clusterLightRadius * u_clusterLightRadius)/dist2; let attenuation=rangePart * invSquare; var finalAttenuation=attenuation; if (u_isSpotLight > 0.0) { let u_clusterLightDirection=normalize(vec3( clusterLightList.lights[i].directionX, clusterLightList.lights[i].directionY, clusterLightList.lights[i].directionZ )); let u_clusterLightInnerAngle=clusterLightList.lights[i].innerCutoff; let u_clusterLightOuterCutoff=clusterLightList.lights[i].outerCutoff; let lightToVertex=normalize(-lightDir); let cosTheta=dot(lightToVertex,u_clusterLightDirection); let cosOuter=cos(radians(u_clusterLightOuterCutoff)); let cosInner=cos(radians(u_clusterLightInnerAngle)); if (cosTheta < cosOuter) { continue; } let epsilon=cosInner - cosOuter; let spotIntensity=clamp((cosTheta - cosOuter)/epsilon,0.0,1.0); finalAttenuation *=spotIntensity; } let R=reflect(-L,N); let diffuse=diffuseColor * max(dot(N,L),0.0); let specular=pow(max(dot(R,E),0.0),u_shininess) * specularSamplerValue; let diffuseAttenuation=finalAttenuation; let specularAttenuation=finalAttenuation * finalAttenuation; let ld=u_clusterLightColor * diffuse * diffuseAttenuation * u_clusterLightIntensity; let ls=u_specularColor * u_specularStrength * specular * specularAttenuation * u_clusterLightIntensity; mixColor +=ld + ls; } #redgpu_if alphaTexture let alphaMapValue:f32=textureSample(alphaTexture,alphaTextureSampler,inputData.uv).r; resultAlpha=alphaMapValue * resultAlpha; if(resultAlpha==0){ discard;} #redgpu_endIf var emissiveColor=u_emissiveColor * u_emissiveStrength; #redgpu_if emissiveTexture emissiveColor=textureSample(emissiveTexture,emissiveTextureSampler,inputData.uv).rgb * u_emissiveStrength; #redgpu_endIf #redgpu_if aoTexture mixColor=mixColor * textureSample(aoTexture,aoTextureSampler,inputData.uv).rgb * u_aoStrength; #redgpu_endIf finalColor=vec4(mixColor + emissiveColor,resultAlpha); #redgpu_if useTint finalColor=calcTintBlendMode(finalColor,uniforms.tintBlendMode,uniforms.tint); #redgpu_endIf if (systemUniforms.isView3D==1 && finalColor.a==0.0) { discard; } output.color=finalColor; { let metallic=uniforms.metallic; let roughness=uniforms.roughness; let smoothness=1.0 - roughness; let smoothnessCurved=smoothness * smoothness * (3.0 - 2.0 * smoothness); let metallicWeight=metallic * metallic; let baseReflection=0.04 + 0.96 * metallicWeight; let baseReflectionStrength=smoothnessCurved * baseReflection; output.gBufferNormal=vec4(N * 0.5 + 0.5,baseReflectionStrength); } output.gBufferMotionVector=vec4(calculateMotionVector(inputData.currentClipPos,inputData.prevClipPos),0.0,1.0 ); return output;\n}\n");class PhongMaterial extends AUVTransformBaseMaterial{#ym;#xo=1;constructor(i,g="#fff",x){super(i,"PHONG_MATERIAL",Ss,2),x&&(this.name=x),this.initGPURenderInfos(),this.color.setColorByHEX(g),this.emissiveColor.setColorByHEX(this.emissiveColor.hex),this.specularColor.setColorByHEX(this.specularColor.hex)}get displacementScale(){return this.#xo}set displacementScale(i){this.#xo=i}get displacementTexture(){return this.#ym}set displacementTexture(i){const g=this.#ym;this.#ym=i,this.updateTexture(g,i),this.dirtyPipeline=!0}}dr.defineByPreset(PhongMaterial,[dr.PRESET_COLOR_RGB.COLOR,dr.PRESET_TEXTURE.ALPHA_TEXTURE,dr.PRESET_SAMPLER.ALPHA_TEXTURE_SAMPLER,dr.PRESET_TEXTURE.AO_TEXTURE,dr.PRESET_SAMPLER.AO_TEXTURE_SAMPLER,dr.PRESET_POSITIVE_NUMBER.AO_STRENGTH,dr.PRESET_TEXTURE.DIFFUSE_TEXTURE,dr.PRESET_SAMPLER.DIFFUSE_TEXTURE_SAMPLER,dr.PRESET_TEXTURE.EMISSIVE_TEXTURE,dr.PRESET_SAMPLER.EMISSIVE_TEXTURE_SAMPLER,dr.PRESET_POSITIVE_NUMBER.EMISSIVE_STRENGTH,[dr.PRESET_COLOR_RGB.EMISSIVE_COLOR,"#000000"],dr.PRESET_TEXTURE.NORMAL_TEXTURE,dr.PRESET_SAMPLER.NORMAL_TEXTURE_SAMPLER,dr.PRESET_POSITIVE_NUMBER.NORMAL_SCALE,dr.PRESET_TEXTURE.SPECULAR_TEXTURE,dr.PRESET_SAMPLER.SPECULAR_TEXTURE_SAMPLER,dr.PRESET_POSITIVE_NUMBER.SPECULAR_STRENGTH,[dr.PRESET_COLOR_RGB.SPECULAR_COLOR,"#ffffff"],[dr.PRESET_POSITIVE_NUMBER.SHININESS,32]]),dr.defineBoolean(PhongMaterial,[["useSSR",!1]]),dr.definePositiveNumber(PhongMaterial,[["metallic",0,0,1],["roughness",0,0,1]]),Object.freeze(PhongMaterial);var Ts=Object.freeze({__proto__:null,BLEND_MODE:Ra,BitmapMaterial:BitmapMaterial,COMPOSITE_MODE:{ADDITIVE:"additive",SOURCE_OVER:"source-over",SOURCE_IN:"source-in",SOURCE_OUT:"source-out",SOURCE_ATOP:"source-atop",DESTINATION_OVER:"destination-over",DESTINATION_IN:"destination-in",DESTINATION_OUT:"destination-out",DESTINATION_ATOP:"destination-atop"},ColorMaterial:ColorMaterial,Core:wr,PBRMaterial:PBRMaterial,PhongMaterial:PhongMaterial,TINT_BLEND_MODE:Tr}),Ms=Object.freeze({__proto__:null,ManagementResourceBase:ManagementResourceBase,ResourceBase:ResourceBase,ResourceManager:ResourceManager,ResourceStatusInfo:ResourceStatusInfo});var ws=Object.freeze({__proto__:null,ABaseBuffer:ABaseBuffer,AUniformBaseBuffer:AUniformBaseBuffer,getUniformOffsetByRoundUp:(i,g)=>((i+g-1)/g|0)*g}),Cs=Object.freeze({__proto__:null,VertexInterleavedStructElement:VertexInterleavedStructElement});class ResourceStateHDRTexture{texture;src;cacheKey;useNum=0;uuid;constructor(i){this.texture=i,this.src=i.src,this.cacheKey=i.cacheKey,this.useNum=0,this.uuid=i.uuid}}class HDRLoader{#Sm=!0;constructor(i=!0){this.#Sm=i}get enableDebugLogs(){return this.#Sm}set enableDebugLogs(i){this.#Sm=i}async loadHDRFile(i){this.#Sm&&g(`HDR 파일 로딩 시작:${i}`);const x=await fetch(i);if(!x.ok)throw new Error(`HTTP ${x.status}:${x.statusText}`);const _=await x.arrayBuffer(),v=new Uint8Array(_),b=this.#Tm(v,i);return g({...b}),{...b}}#Tm(i,x){const _=this.#Mm(i);if(this.#Sm&&g(`파일 형식:${_.format}`),!_.isValid)throw new Error(_.error||"지원되지 않는 파일 형식입니다");if(x.split("?")[0].toLowerCase().endsWith(".hdr")){this.#Sm&&this.#wm(i.slice(0,200));const g=this.#Cm(i);return this.#Sm&&this.#Rm(g),g}throw x.split("?")[0].toLowerCase().endsWith(".exr")?new Error("EXR format not supported yet"):new Error(`Unsupported HDR format:${x}`)}#Cm(i){let x=0,_="";const v={};for(;x0){const i=_.substring(0,g).trim(),x=_.substring(g+1).trim();v[i]=x}}for(_="";x>8&255)&&i[g+3]===(255&x)){g+=4;for(let v=0;v<4;v++){let b=v;for(;b<4*x;){const v=i[g++];if(v>128){const y=v-128,S=i[g++];for(let i=0;ii.toString(16).padStart(2,"0")).join(" "),Array.from(i.slice(g,g+16)).map(i=>i>=32&&i<=126?String.fromCharCode(i):".").join("")}}async function float32ToFloat16Linear(i,g,x){const _=performance.now(),{gpuDevice:v}=i,{width:b,height:y,workgroupSize:S=[8,8],maxValue:w=1e3}=x,L=g.length/4,k=function(i){return` struct Constants { width:u32, height:u32, }\n @group(0) @binding(0) var inputData:array; @group(0) @binding(1) var outputData:array; @group(0) @binding(2) var constants:Constants;\n fn floatToHalf(value:f32) -> u32 { let bits=bitcast(value); let sign=(bits >> 16u) & 0x8000u; var exp=(bits >> 23u) & 0xFFu; var mantissa=bits & 0x7FFFFFu;\n if (exp==0u) { return sign; }\n if (exp==255u) { return sign | 0x7C00u | select(0u,1u,mantissa !=0u); }\n let newExp=i32(exp) - 127 + 15; if (newExp <=0) { return sign; } if (newExp >=31) { return sign | 0x7C00u; }\n return sign | (u32(newExp) << 10u) | (mantissa >> 13u); }\n @compute @workgroup_size(${i[0]},${i[1]}) fn main(@builtin(global_invocation_id) global_id:vec3) { let x=global_id.x; let y=global_id.y;\n if (x >=constants.width || y >=constants.height) { return; }\n let pixelIndex=y * constants.width + x; let baseIndex=pixelIndex * 4u;\n let r=inputData[baseIndex]; let g=inputData[baseIndex + 1u]; let b=inputData[baseIndex + 2u]; let a=inputData[baseIndex + 3u];\n let r16=floatToHalf(r); let g16=floatToHalf(g); let b16=floatToHalf(b); let a16=floatToHalf(a);\n let outputIndex=pixelIndex * 2u; outputData[outputIndex]=(g16 << 16u) | r16; outputData[outputIndex + 1u]=(a16 << 16u) | b16; } `}(S);try{const i=v.createShaderModule({code:k,label:"float16_linear_conversion_shader"}),x=function(i,g,x){const _=i.createBuffer({size:g.byteLength,usage:GPUBufferUsage.STORAGE|GPUBufferUsage.COPY_DST,label:"float16_input_buffer"}),v=i.createBuffer({size:8*x,usage:GPUBufferUsage.STORAGE|GPUBufferUsage.COPY_SRC,label:"float16_output_buffer"}),b=i.createBuffer({size:16,usage:GPUBufferUsage.UNIFORM|GPUBufferUsage.COPY_DST,label:"float16_constants_buffer"}),y=i.createBuffer({size:8*x,usage:GPUBufferUsage.COPY_DST|GPUBufferUsage.MAP_READ,label:"float16_read_buffer"});return i.queue.writeBuffer(_,0,g),{inputBuffer:_,outputBuffer:v,constantsBuffer:b,readBuffer:y}}(v,g,L);!function(i,g,x,_,v){const b=new ArrayBuffer(16),y=new DataView(b);y.setUint32(0,x,!0),y.setUint32(4,_,!0),y.setFloat32(8,v,!0),i.queue.writeBuffer(g,0,b)}(v,x.constantsBuffer,b,y,w);const{computePipeline:H,bindGroup:z}=function(i,g,x){const _=i.createComputePipeline({layout:"auto",compute:{module:g,entryPoint:"main"},label:"float16_conversion_pipeline"}),v=i.createBindGroup({layout:_.getBindGroupLayout(0),entries:[{binding:0,resource:{buffer:x.inputBuffer}},{binding:1,resource:{buffer:x.outputBuffer}},{binding:2,resource:{buffer:x.constantsBuffer}}],label:"float16_conversion_bindgroup"});return{computePipeline:_,bindGroup:v}}(v,i,x),q=await async function(i,g,x,_,v,b,y,S,w){const L=Math.ceil(b/S[0]),k=Math.ceil(y/S[1]);if(L>65535||k>65535)throw new Error(`이미지 크기 초과:${L} × ${k}`);const H=i.createCommandEncoder(),z=H.beginComputePass();z.setPipeline(g),z.setBindGroup(0,x),z.dispatchWorkgroups(L,k),z.end(),H.copyBufferToBuffer(_,0,v,0,8*w),i.queue.submit([H.finish()]),await v.mapAsync(GPUMapMode.READ);const q=new Uint32Array(v.getMappedRange()),W=new Uint16Array(q.buffer.slice(q.byteOffset,q.byteOffset+q.byteLength));return v.unmap(),W}(v,H,z,x.outputBuffer,x.readBuffer,b,y,S,L);!function(i){i.inputBuffer.destroy(),i.outputBuffer.destroy(),i.constantsBuffer.destroy(),i.readBuffer.destroy()}(x);return{data:q,processedPixels:L,executionTime:performance.now()-_}}catch(i){throw console.error("Float16 변환 실패:",i),i}}class HDRTexture extends ManagementResourceBase{#L;#A;#N=0;#Bm=new HDRLoader;#F="rgba16float";#H;#z;#Bt=0;#It=0;constructor(i,g,x,_){if(super(i,"managedHDRTextureState"),this.#H=x,this.#z=_,g){const i=this.#$(g);this.#Im(i),this.#A=i,this.cacheKey=this.#K(g);const{table:x}=this.targetResourceManagedState;let _=x.get(this.cacheKey);if(_){const i=_.texture;return this.#H?.(i),i}this.src=g,this.#X()}}get width(){return this.#Bt}get height(){return this.#It}get videoMemorySize(){return this.#N}get gpuTexture(){return this.#L}get src(){return this.#A}set src(i){const g=this.#$(i);this.#Im(g),this.#A=g,this.cacheKey=this.#K(i),this.#A&&this.#Em(this.#A)}destroy(){const i=this.#L;this.#q(null),this.__fireListenerList(!0),this.#W(),this.#A=null,this.cacheKey=null,i&&i.destroy()}#K(i){let g;return i||(g=this.uuid),g="string"==typeof i?getAbsoluteURL(window.location.href,i):i.cacheKey||getAbsoluteURL(window.location.href,i.src),`HDRTexture_${g}`}#$(i){return"string"==typeof i?i:i.src}#Im(i){if(!i||"string"!=typeof i)throw new Error("HDR 파일 경로가 필요합니다");if(!i.split("?")[0].split("#")[0].toLowerCase().endsWith(".hdr"))throw new Error(`지원되지 않는 형식입니다. .hdr 형식만 지원됩니다. 입력된 파일:${i}`)}async#Em(i){try{const g=await this.#Bm.loadHDRFile(i);this.#Bt=g.width,this.#It=g.height,await this.#Y(g),this.#H?.(this),this.__fireListenerList()}catch(i){console.error("HDR loading error:",i),this.#z?.(i)}}async#Y(i){const{gpuDevice:g}=this.redGPUContext,x=this.#L,_={size:[this.#Bt,this.#It,1],format:this.#F,usage:GPUTextureUsage.TEXTURE_BINDING|GPUTextureUsage.COPY_DST,label:`HDRTexture_2D_${this.#A}`},v=g.createTexture(_),b=await float32ToFloat16Linear(this.redGPUContext,i.data,{width:this.#Bt,height:this.#It,workgroupSize:[8,8]});g.queue.writeTexture({texture:v},b.data.buffer,{bytesPerRow:8*this.#Bt,rowsPerImage:this.#It},{width:this.#Bt,height:this.#It}),this.#q(v),x&&(await g.queue.onSubmittedWorkDone(),x.destroy())}#q(i){this.targetResourceManagedState.videoMemory-=this.#N,this.#L=i,this.#N=i?calculateTextureByteSize(i):0,this.targetResourceManagedState.videoMemory+=this.#N,this.__fireListenerList()}#X(){this.redGPUContext.resourceManager.registerManagementResource(this,new ResourceStateHDRTexture(this))}#W(){this.redGPUContext.resourceManager.unregisterManagementResource(this)}}Object.freeze(HDRTexture);const Rs={MODE_1D:1,MODE_2D:2,MODE_3D:3};Object.freeze(Rs);const Ps="managedBitmapTextureState",Bs={animationSpeed:1,animationX:.1,animationY:.1};class ANoiseTexture extends ManagementResourceBase{mipLevelCount;useMipmap;src;#L;#me=8;#pe=8;#Or=1;#Nr;#Vr;#Fr;#Hr;#Xn;#Dm;#Bt;#It;#Um;#Lm=0;#Am=1;#Gm=Bs.animationX;#km=Bs.animationY;#N=0;constructor(i,g=1024,x=1024,_){super(i,Ps),validateUintRange(g,2,2048),validateUintRange(x,2,2048),this.#Bt=g,this.#It=x,this.#Um=_,this.#ne(i),this.cacheKey=`NoiseTexture_${g}x${x}_${Date.now()}`,this.#L=this.#ui(i,g,x),this.#N=calculateTextureByteSize(this.#L),this.#ci(),this.#X()}get videoMemorySize(){return this.#N}get resourceManagerKey(){return Ps}get animationSpeed(){return this.#Am}set animationSpeed(i){validatePositiveNumberRange(i),this.#Am=i,this.updateUniform("animationSpeed",i)}get animationX(){return this.#Gm}set animationX(i){validateNumber(i),this.#Gm=i,this.updateUniform("animationX",i)}get animationY(){return this.#km}set animationY(i){validateNumber(i),this.#km=i,this.updateUniform("animationY",i)}get uniformInfo(){return this.#Dm}get gpuTexture(){return this.#L}get time(){return this.#Lm}set time(i){validatePositiveNumberRange(i),this.#Lm=i,this.updateUniform("time",i/1e3)}updateUniform(i,g){this.#Dm.members[i]&&(this.#Xn.writeOnlyBuffer(this.#Dm.members[i],g),this.#Um[i]=g),this.#ci()}updateUniforms(i){Object.entries(i).forEach(([i,g])=>{this.#Dm.members[i]&&(this.#Xn.writeOnlyBuffer(this.#Dm.members[i],g),this.#Um[i]=g)}),this.#ci()}render(i){this.updateUniform("time",i),this.#ci()}destroy(){const i=this.#L;this.__fireListenerList(!0),this.#W(),i&&i.destroy(),this.src=null,this.cacheKey=null,this.#L=null}#ne(i){const{gpuDevice:g}=i,x=this.#Om();this.cacheKey=this.uuid,this.#Nr=g.createShaderModule({code:x}),this.#Fr=this.#si(i),this.#Hr=this.#oi(g,this.#Nr,this.#Fr);const _=parseWGSL(x);this.#Dm=_.uniforms.uniforms;const v=new ArrayBuffer(this.#Dm.arrayBufferByteLength);this.#Xn=new UniformBuffer(i,v,`${this.constructor.name}_UniformBuffer`),this.#Um.uniformDefaults&&this.updateUniforms({...Bs,...this.#Um.uniformDefaults})}#Om(){return` ${` struct Uniforms { time:f32, animationSpeed:f32, animationX:f32, animationY:f32, ${this.#Um.uniformStruct||""} }; `} @group(0) @binding(0) var uniforms:Uniforms; @group(0) @binding(1) var outputTexture:texture_storage_2d; ${this.#Um.helperFunctions||""} @compute @workgroup_size(${this.#me},${this.#pe},${this.#Or}) fn main ( @builtin(global_invocation_id) global_id:vec3, ){ let index=vec2(global_id.xy); let dimensions:vec2=textureDimensions(outputTexture); if (index.x >=dimensions.x || index.y >=dimensions.y) { return; } let dimW=f32(dimensions.x); let dimH=f32(dimensions.y); let base_uv=vec2((f32(index.x) + 0.5)/dimW,(f32(index.y) + 0.5)/dimH); ${this.#Um.mainLogic} textureStore(outputTexture,index,finalColor); } `}#ci(){if(!this.#Vr)return;const i=this.redGPUContext.gpuDevice.createCommandEncoder(),g=i.beginComputePass();g.setPipeline(this.#Hr),g.setBindGroup(0,this.#Vr),g.dispatchWorkgroups(Math.ceil(this.#Bt/this.#me),Math.ceil(this.#It/this.#pe)),g.end(),this.redGPUContext.gpuDevice.queue.submit([i.finish()])}#si(i){return i.resourceManager.createBindGroupLayout("NoiseTextureBindGroupLayout",{entries:[{binding:0,visibility:GPUShaderStage.COMPUTE,buffer:{type:"uniform"}},{binding:1,visibility:GPUShaderStage.COMPUTE,storageTexture:{format:"rgba8unorm"}}]})}#ui(i,g,x){const _=i.gpuDevice.createTexture({size:{width:g,height:x},format:"rgba8unorm",usage:GPUTextureUsage.TEXTURE_BINDING|GPUTextureUsage.STORAGE_BINDING,label:this.cacheKey}),v=_.createView();return this.#Vr=this.#li(i,this.#Fr,v),_}#li(i,g,x){return i.gpuDevice.createBindGroup({layout:g,entries:[{binding:0,resource:{buffer:this.#Xn.gpuBuffer,offset:0,size:this.#Xn.gpuBuffer.size}},{binding:1,resource:x}]})}#oi(i,g,x){return i.createComputePipeline({layout:i.createPipelineLayout({bindGroupLayouts:[x]}),compute:{module:g,entryPoint:"main"}})}#X(){this.redGPUContext.resourceManager.registerManagementResource(this,new ResourceStateBitmapTexture(this))}#W(){this.redGPUContext.resourceManager.unregisterManagementResource(this)}}const mergerNoiseUniformStruct=(i,g)=>[i,g].filter(Boolean).join("\n"),mergerNoiseUniformDefault=(i,g)=>({...i,...g||{}}),mergerNoiseHelperFunctions=(i,g)=>[i,g].filter(Boolean).join("\n");const Is=Object.values(Rs),Es={frequency:8,amplitude:1,octaves:1,persistence:.5,lacunarity:2,seed:0,noiseDimension:Rs.MODE_2D};const Ds={EUCLIDEAN:0,MANHATTAN:1,CHEBYSHEV:2};Object.freeze(Ds);const Us={F1:0,F2:1,F2_MINUS_F1:2,F1_PLUS_F2:3,CELL_ID:4,CELL_ID_COLOR:5};Object.freeze(Us);const Ls=Object.values(Ds),As=Object.values(Us),Gs={frequency:8,distanceScale:1,octaves:1,persistence:.5,lacunarity:2,seed:0,distanceType:Ds.EUCLIDEAN,outputType:Us.F1,jitter:1,cellIdColorIntensity:1};var ks=Object.freeze({__proto__:null,ANoiseTexture:ANoiseTexture,mergerNoiseHelperFunctions:mergerNoiseHelperFunctions,mergerNoiseUniformDefault:mergerNoiseUniformDefault,mergerNoiseUniformStruct:mergerNoiseUniformStruct});class IBL{#l;#Nm;#Vm;#Fm;#Hm;#zm;#$m;#Km;#Xm;#jm=!1;constructor(i,g,x=1024,_=512,v=64){const b=`${g}?key=${x}_${_}_${v}`;this.#Km=_,this.#$m=x,this.#Xm=v,this.#l=i,this.#Vm=new IBLCubeTexture(i,`IBL_ENV_${b}`),this.#Hm=new IBLCubeTexture(i,`IBL_SPECULAR_${b}`),this.#Fm=new IBLCubeTexture(i,`IBL_IRRADIANCE_${b}`);const onLoad=async i=>{i.__addDirtyPipelineListener(this.#Ym),i.gpuTexture&&await this.#Ym(i)};this.#zm="string"==typeof g?new HDRTexture(i,g,onLoad):new CubeTexture(i,g,!0,onLoad)}#Ym=async i=>{if((i=i||this.#zm)&&i.gpuTexture&&!this.#jm){this.#jm=!0;try{if(i instanceof HDRTexture){const{equirectangularToCubeGenerator:g}=this.#l.resourceManager,x=await g.generate(i.gpuTexture,this.#$m);this.#Nm=x.gpuTexture}else this.#Nm=i.gpuTexture;await this.#qm()}finally{this.#jm=!1}}};get environmentSize(){return this.#$m}get prefilterSize(){return this.#Km}get irradianceSize(){return this.#Xm}get irradianceTexture(){return this.#Fm}get environmentTexture(){return this.#Vm}get prefilterTexture(){return this.#Hm}async#qm(){const{resourceManager:i}=this.#l,{prefilterGenerator:g,irradianceGenerator:x}=i;if(this.#Nm){this.#Vm.gpuTexture=this.#Nm;const i=await g.generate(this.#Nm,this.#Km);this.#Hm.gpuTexture=i.gpuTexture;const _=await x.generate(this.#Nm,this.#Xm);this.#Fm.gpuTexture=_.gpuTexture}}}Object.freeze(IBL);var Os=Object.freeze({__proto__:null,ShaderVariantGenerator:ShaderVariantGenerator,WGSLUniformTypes:WGSLUniformTypes,ensureVertexIndexBuiltin:ensureVertexIndexBuiltin,preprocessWGSL:preprocessWGSL}),Ns=Object.freeze({__proto__:null,BitmapTexture:BitmapTexture,Core:Ms,CoreBuffer:ws,CoreIBL:k,CoreNoiseTexture:ks,CoreVertexBuffer:Cs,CoreWGSLParser:Os,CubeTexture:CubeTexture,HDRTexture:HDRTexture,IBL:IBL,IndexBuffer:IndexBuffer,NOISE_DIMENSION:Rs,PackedTexture:PackedTexture,Sampler:Sampler,SimplexTexture:class extends ANoiseTexture{#Wm=Es.frequency;#Zm=Es.amplitude;#Jm=Es.octaves;#Qm=Es.persistence;#ep=Es.lacunarity;#tp=Es.seed;#np=Es.noiseDimension;constructor(i,g=1024,x=1024,_){super(i,g,x,{..._,mainLogic:_?.mainLogic||" let uv=vec2( (base_uv.x + uniforms.time * ( uniforms.animationX * uniforms.animationSpeed )), (base_uv.y + uniforms.time * ( uniforms.animationY * uniforms.animationSpeed )) ); let noise=getSimplexNoiseByDimension( uv,uniforms ); let finalColor=vec4(noise,noise,noise,1.0); ",uniformStruct:mergerNoiseUniformStruct(" noiseDimension:f32, frequency:f32, amplitude:f32, octaves:i32, persistence:f32, lacunarity:f32, seed:f32, ",_?.uniformStruct),uniformDefaults:mergerNoiseUniformDefault(Es,_?.uniformDefaults),helperFunctions:mergerNoiseHelperFunctions("\nfn mod289_vec3(x:vec3) -> vec3 { return x - floor(x * (1.0/289.0)) * 289.0;\n}\nfn mod289_vec2(x:vec2) -> vec2 { return x - floor(x * (1.0/289.0)) * 289.0;\n}\nfn mod289_vec4(x:vec4) -> vec4 { return x - floor(x * (1.0/289.0)) * 289.0;\n}\nfn mod289_f32(x:f32) -> f32 { return x - floor(x * (1.0/289.0)) * 289.0;\n}\nfn permute(x:vec3) -> vec3 { return mod289_vec3(((x * 34.0) + 1.0) * x);\n}\nfn permute4(x:vec4) -> vec4 { return mod289_vec4(((x * 34.0) + 1.0) * x);\n}\nfn permute_f32(x:f32) -> f32 { return mod289_f32(((x * 34.0) + 1.0) * x);\n}\nfn taylorInvSqrt4(r:vec4) -> vec4 { return 1.79284291400159 - 0.85373472095314 * r;\n}\nfn simplex1D(x:f32) -> f32 { var i=floor(x); let f=fract(x); let g0=select(-1.0,1.0,(permute_f32(i) * 0.024390243902439) >=0.5); let g1=select(-1.0,1.0,(permute_f32(i + 1.0) * 0.024390243902439) >=0.5); let d0=f; let d1=f - 1.0; let t=f * f * f * (f * (f * 6.0 - 15.0) + 10.0); let n0=g0 * d0; let n1=g1 * d1; return mix(n0,n1,t) * 0.395;\n}\nfn simplex2D(v:vec2) -> f32 { let C=vec4(0.211324865405187,0.366025403784439,-0.577350269189626,0.024390243902439); var i=floor(v + dot(v,C.yy)); let x0=v - i + dot(i,C.xx); let i1=select(vec2(0.0,1.0),vec2(1.0,0.0),x0.x > x0.y); var x12=x0.xyxy + C.xxzz; x12.x=x12.x - i1.x; x12.y=x12.y - i1.y; i=mod289_vec2(i); let p=permute(permute(i.y + vec3(0.0,i1.y,1.0)) + i.x + vec3(0.0,i1.x,1.0)); var m=max(0.5 - vec3(dot(x0,x0),dot(x12.xy,x12.xy),dot(x12.zw,x12.zw)),vec3(0.0)); m=m * m; m=m * m; let x=2.0 * fract(p * C.www) - 1.0; let h=abs(x) - 0.5; let ox=floor(x + 0.5); let a0=x - ox; m=m * (1.79284291400159 - 0.85373472095314 * (a0 * a0 + h * h)); let g=vec3(a0.x * x0.x + h.x * x0.y,a0.y * x12.x + h.y * x12.y,a0.z * x12.z + h.z * x12.w); return 130.0 * dot(m,g);\n}\nfn simplex3D(v:vec3) -> f32 { let C=vec2(1.0/6.0,1.0/3.0); let D=vec4(0.0,0.5,1.0,2.0); var i=floor(v + dot(v,C.yyy)); let x0=v - i + dot(i,C.xxx); let g=step(x0.yzx,x0.xyz); let l=1.0 - g; let i1=min(g.xyz,l.zxy); let i2=max(g.xyz,l.zxy); let x1=x0 - i1 + C.xxx; let x2=x0 - i2 + C.yyy; let x3=x0 - D.yyy; i=mod289_vec3(i); let p=permute4(permute4(permute4( i.z + vec4(0.0,i1.z,i2.z,1.0 )) + i.y + vec4(0.0,i1.y,i2.y,1.0 )) + i.x + vec4(0.0,i1.x,i2.x,1.0 )); let n_=0.142857142857; let ns=n_ * D.wyz - D.xzx; let j=p - 49.0 * floor(p * ns.z * ns.z); let x_=floor(j * ns.z); let y_=floor(j - 7.0 * x_ ); let x=x_ *ns.x + ns.yyyy; let y=y_ *ns.x + ns.yyyy; let h=1.0 - abs(x) - abs(y); let b0=vec4( x.xy,y.xy ); let b1=vec4( x.zw,y.zw ); let s0=floor(b0)*2.0 + 1.0; let s1=floor(b1)*2.0 + 1.0; let sh=-step(h,vec4(0.0)); let a0=b0.xzyw + s0.xzyw*sh.xxyy; let a1=b1.xzyw + s1.xzyw*sh.zzww; var p0=vec3(a0.xy,h.x); var p1=vec3(a0.zw,h.y); var p2=vec3(a1.xy,h.z); var p3=vec3(a1.zw,h.w); let norm=taylorInvSqrt4(vec4(dot(p0,p0),dot(p1,p1),dot(p2,p2),dot(p3,p3))); p0 *=norm.x; p1 *=norm.y; p2 *=norm.z; p3 *=norm.w; var m=max(0.6 - vec4(dot(x0,x0),dot(x1,x1),dot(x2,x2),dot(x3,x3)),vec4(0.0)); m=m * m; return 42.0 * dot( m*m,vec4( dot(p0,x0),dot(p1,x1), dot(p2,x2),dot(p3,x3) ) );\n}\nfn fbm1D(pos:f32,octaves:i32) -> f32 { var value=0.0; var amplitude=0.5; var frequency=1.0; var max_value=0.0; for (var i=0;i < octaves;i++) { if (i >=octaves) { break;} value +=simplex1D(pos * frequency) * amplitude; max_value +=amplitude; amplitude *=0.5; frequency *=2.0; } return value/max_value;\n}\nfn fbm(pos:vec2,octaves:i32) -> f32 { var value=0.0; var amplitude=0.5; var frequency=1.0; var max_value=0.0; for (var i=0;i < octaves;i++) { if (i >=octaves) { break;} value +=simplex2D(pos * frequency) * amplitude; max_value +=amplitude; amplitude *=0.5; frequency *=2.0; } return value/max_value;\n}\nfn fbm3D(pos:vec3,octaves:i32) -> f32 { var value=0.0; var amplitude=0.5; var frequency=1.0; var max_value=0.0; for (var i=0;i < octaves;i++) { if (i >=octaves) { break;} value +=simplex3D(pos * frequency) * amplitude; max_value +=amplitude; amplitude *=0.5; frequency *=2.0; } return value/max_value;\n}\nfn getSimplexNoise1D(pos:f32,uniforms:Uniforms) -> f32 { var total_amplitude:f32=0.0; var noise_value:f32=0.0; var current_amplitude:f32=1.0; var current_frequency:f32=uniforms.frequency; for (var i:i32=0;i < uniforms.octaves;i++) { let noise_pos=(pos + uniforms.seed) * current_frequency; let octave_noise=simplex1D(noise_pos); noise_value +=octave_noise * current_amplitude; total_amplitude +=current_amplitude; current_amplitude *=uniforms.persistence; current_frequency *=uniforms.lacunarity; } noise_value/=total_amplitude; noise_value *=uniforms.amplitude; let normalized_noise=(noise_value + 1.0) * 0.5; return normalized_noise;\n}\nfn getSimplexNoise2D(uv:vec2,uniforms:Uniforms) -> f32 { var total_amplitude:f32=0.0; var noise_value:f32=0.0; var current_amplitude:f32=1.0; var current_frequency:f32=uniforms.frequency; for (var i:i32=0;i < uniforms.octaves;i++) { let noise_pos=(uv + uniforms.seed) * current_frequency; let octave_noise=simplex2D(noise_pos); noise_value +=octave_noise * current_amplitude; total_amplitude +=current_amplitude; current_amplitude *=uniforms.persistence; current_frequency *=uniforms.lacunarity; } noise_value/=total_amplitude; noise_value *=uniforms.amplitude; let normalized_noise=(noise_value + 1.0) * 0.5; return normalized_noise;\n}\nfn getSimplexNoise3D(pos:vec3,uniforms:Uniforms) -> f32 { var total_amplitude:f32=0.0; var noise_value:f32=0.0; var current_amplitude:f32=1.0; var current_frequency:f32=uniforms.frequency; for (var i:i32=0;i < uniforms.octaves;i++) { let noise_pos=(pos + vec3(uniforms.seed)) * current_frequency; let octave_noise=simplex3D(noise_pos); noise_value +=octave_noise * current_amplitude; total_amplitude +=current_amplitude; current_amplitude *=uniforms.persistence; current_frequency *=uniforms.lacunarity; } noise_value/=total_amplitude; noise_value *=uniforms.amplitude; let normalized_noise=(noise_value + 1.0) * 0.5; return normalized_noise;\n}\nfn getSimplexNoiseByDimension(uv:vec2,uniforms:Uniforms) -> f32 { if (uniforms.noiseDimension < 1.1) { return getSimplexNoise1D(uv.x,uniforms); } else if (uniforms.noiseDimension < 2.1) { return getSimplexNoise2D(uv,uniforms); } else if (uniforms.noiseDimension < 3.1) { return getSimplexNoise3D(vec3(uv.x,uv.y,uniforms.seed * 0.1),uniforms); } else { return getSimplexNoise2D(uv,uniforms); }\n}\n",_?.helperFunctions)})}get noiseDimension(){return this.#np}set noiseDimension(i){Is.includes(i)?(this.#np=i,this.updateUniform("noiseDimension",i)):consoleAndThrowError(`Invalid value for noiseDimension. Received ${i}. Expected one of:${Is.join(",")}`)}get frequency(){return this.#Wm}set frequency(i){validatePositiveNumberRange(i),this.#Wm=i,this.updateUniform("frequency",i)}get amplitude(){return this.#Zm}set amplitude(i){validatePositiveNumberRange(i),this.#Zm=i,this.updateUniform("amplitude",i)}get octaves(){return this.#Jm}set octaves(i){validateUintRange(i,1,8),this.#Jm=i,this.updateUniform("octaves",i)}get persistence(){return this.#Qm}set persistence(i){validatePositiveNumberRange(i,0,1),this.#Qm=i,this.updateUniform("persistence",i)}get lacunarity(){return this.#ep}set lacunarity(i){validatePositiveNumberRange(i),this.#ep=i,this.updateUniform("lacunarity",i)}get seed(){return this.#tp}set seed(i){this.#tp=i,this.updateUniform("seed",i)}randomizeSeed(){this.seed=1e3*Math.random()}getSettings(){return{frequency:this.#Wm,amplitude:this.#Zm,octaves:this.#Jm,persistence:this.#Qm,lacunarity:this.#ep,seed:this.#tp}}applySettings(i){void 0!==i.frequency&&(this.frequency=i.frequency),void 0!==i.amplitude&&(this.amplitude=i.amplitude),void 0!==i.octaves&&(this.octaves=i.octaves),void 0!==i.persistence&&(this.persistence=i.persistence),void 0!==i.lacunarity&&(this.lacunarity=i.lacunarity),void 0!==i.seed&&(this.seed=i.seed)}},StorageBuffer:StorageBuffer,UniformBuffer:UniformBuffer,VORONOI_DISTANCE_TYPE:Ds,VORONOI_OUTPUT_TYPE:Us,VertexBuffer:VertexBuffer,VertexInterleaveType:VertexInterleaveType,VertexInterleavedStruct:VertexInterleavedStruct,VoronoiTexture:class extends ANoiseTexture{#Wm=Gs.frequency;#rp=Gs.distanceScale;#Jm=Gs.octaves;#Qm=Gs.persistence;#ep=Gs.lacunarity;#tp=Gs.seed;#ip=Gs.distanceType;#ap=Gs.outputType;#sp=Gs.jitter;#op=Gs.cellIdColorIntensity;constructor(i,g=1024,x=1024,_){super(i,g,x,{..._,mainLogic:_?.mainLogic||" let uv=vec2( (base_uv.x + uniforms.time * (uniforms.animationX * uniforms.animationSpeed)), (base_uv.y + uniforms.time * (uniforms.animationY * uniforms.animationSpeed)) ); var finalColor:vec4; if (uniforms.outputType==5) { let colorNoise=getVoronoiColorNoise(uv,uniforms); finalColor=vec4(colorNoise,1.0); } else { let noise=getVoronoiNoise(uv,uniforms); finalColor=vec4(noise,noise,noise,1.0); } ",uniformStruct:mergerNoiseUniformStruct(" frequency:f32, distanceScale:f32, octaves:i32, persistence:f32, lacunarity:f32, seed:f32, distanceType:i32, outputType:i32, jitter:f32, cellIdColorIntensity:f32, ",_?.uniformStruct),uniformDefaults:mergerNoiseUniformDefault(Gs,_?.uniformDefaults),helperFunctions:mergerNoiseHelperFunctions("fn hash22(p:vec2) -> vec2 { var p3=fract(vec3(p.xyx) * vec3(0.1031,0.1030,0.0973)); p3 +=dot(p3,p3.yzx + 33.33); return fract((p3.xx + p3.yz) * p3.zy);\n}\nfn hash12(p:vec2) -> f32 { var p3=fract(vec3(p.xyx) * 0.1031); p3 +=dot(p3,p3.yzx + 33.33); return fract((p3.x + p3.y) * p3.z);\n}\nfn euclideanDistance(a:vec2,b:vec2) -> f32 { let d=a - b; return sqrt(d.x * d.x + d.y * d.y);\n}\nfn manhattanDistance(a:vec2,b:vec2) -> f32 { let d=abs(a - b); return d.x + d.y;\n}\nfn chebyshevDistance(a:vec2,b:vec2) -> f32 { let d=abs(a - b); return max(d.x,d.y);\n}\nfn calculateDistance(a:vec2,b:vec2,distanceType:i32) -> f32 { switch (distanceType) { case 0:{ return euclideanDistance(a,b);} case 1:{ return manhattanDistance(a,b);} case 2:{ return chebyshevDistance(a,b);} default:{ return euclideanDistance(a,b);} }\n}\nfn cellIdToColor(cellId:f32,intensity:f32) -> vec3 { let h=cellId * 6.28318; let s=0.7 + 0.3 * fract(cellId * 7.0); let v=0.6 + 0.4 * fract(cellId * 13.0); let c=v * s; let x=c * (1.0 - abs(((h/1.047198) % 2.0) - 1.0)); let m=v - c; var rgb:vec3; let sector=i32(h/1.047198) % 6; switch (sector) { case 0:{ rgb=vec3(c,x,0.0);} case 1:{ rgb=vec3(x,c,0.0);} case 2:{ rgb=vec3(0.0,c,x);} case 3:{ rgb=vec3(0.0,x,c);} case 4:{ rgb=vec3(x,0.0,c);} default:{ rgb=vec3(c,0.0,x);} } return (rgb + m) * intensity;\n}\nstruct VoronoiResult { f1:f32, f2:f32, cellId:f32,\n}\nfn voronoiSingle(pos:vec2,frequency:f32,seed:f32,jitter:f32,distanceType:i32) -> VoronoiResult { let scaledPos=pos * frequency; let gridPos=floor(scaledPos); let localPos=fract(scaledPos); var minDist1=999.0; var minDist2=999.0; var closestCellId=0.0; for (var y=-1;y <=1;y++) { for (var x=-1;x <=1;x++) { let neighborGrid=gridPos + vec2(f32(x),f32(y)); let randomOffset=hash22(neighborGrid + seed); let jitteredOffset=mix(vec2(0.5),randomOffset,jitter); let cellPoint=vec2(f32(x),f32(y)) + jitteredOffset; let dist=calculateDistance(localPos,cellPoint,distanceType); if (dist < minDist1) { minDist2=minDist1; minDist1=dist; closestCellId=hash12(neighborGrid + seed); } else if (dist < minDist2) { minDist2=dist; } } } return VoronoiResult(minDist1,minDist2,closestCellId);\n}\nfn getVoronoiNoise(uv:vec2,uniforms:Uniforms) -> f32 { var total=0.0; var frequency=uniforms.frequency; var amplitude=1.0; var maxValue=0.0; for (var i=0;i < uniforms.octaves;i++) { let voronoiResult=voronoiSingle( uv, frequency, uniforms.seed + f32(i) * 100.0, uniforms.jitter, uniforms.distanceType ); let F1=voronoiResult.f1 * uniforms.distanceScale; let F2=voronoiResult.f2 * uniforms.distanceScale; let cellId=voronoiResult.cellId; var octaveValue:f32; switch (uniforms.outputType) { case 0:{ octaveValue=F1;} case 1:{ octaveValue=F2;} case 2:{ octaveValue=F2 - F1;} case 3:{ octaveValue=(F1 + F2) * 0.5;} case 4:{ octaveValue=cellId;} case 5:{ let colorRGB=cellIdToColor(cellId,uniforms.cellIdColorIntensity); octaveValue=(colorRGB.r + colorRGB.g + colorRGB.b)/3.0; } default:{ octaveValue=F1;} } total +=octaveValue * amplitude; maxValue +=amplitude; frequency *=uniforms.lacunarity; amplitude *=uniforms.persistence; } return clamp(total/maxValue,0.0,1.0);\n}\nfn getVoronoiColorNoise(uv:vec2,uniforms:Uniforms) -> vec3 { if (uniforms.outputType==5) { let voronoiResult=voronoiSingle( uv, uniforms.frequency, uniforms.seed, uniforms.jitter, uniforms.distanceType ); return cellIdToColor(voronoiResult.cellId,uniforms.cellIdColorIntensity); } else { let grayValue=getVoronoiNoise(uv,uniforms); return vec3(grayValue,grayValue,grayValue); }\n}\n",_?.helperFunctions)})}get frequency(){return this.#Wm}set frequency(i){validatePositiveNumberRange(i),this.#Wm=i,this.updateUniform("frequency",i)}get distanceScale(){return this.#rp}set distanceScale(i){validatePositiveNumberRange(i),this.#rp=i,this.updateUniform("distanceScale",i)}get octaves(){return this.#Jm}set octaves(i){validateUintRange(i,1,8),this.#Jm=i,this.updateUniform("octaves",i)}get persistence(){return this.#Qm}set persistence(i){validatePositiveNumberRange(i,0,1),this.#Qm=i,this.updateUniform("persistence",i)}get lacunarity(){return this.#ep}set lacunarity(i){validatePositiveNumberRange(i),this.#ep=i,this.updateUniform("lacunarity",i)}get seed(){return this.#tp}set seed(i){this.#tp=i,this.updateUniform("seed",i)}get distanceType(){return this.#ip}set distanceType(i){Ls.includes(i)?(this.#ip=i,this.updateUniform("distanceType",i)):consoleAndThrowError(`Invalid value for distanceType. Received ${i}. Expected one of:${Ls.join(",")}`)}get outputType(){return this.#ap}set outputType(i){As.includes(i)?(this.#ap=i,this.updateUniform("outputType",i)):consoleAndThrowError(`Invalid value for outputType. Received ${i}. Expected one of:${As.join(",")}`)}get jitter(){return this.#sp}set jitter(i){validatePositiveNumberRange(i,0,1),this.#sp=i,this.updateUniform("jitter",i)}get cellIdColorIntensity(){return this.#op}set cellIdColorIntensity(i){validatePositiveNumberRange(i),this.#op=i,this.updateUniform("cellIdColorIntensity",i)}randomizeSeed(){this.seed=1e3*Math.random()}setEuclideanDistance(){this.distanceType=Ds.EUCLIDEAN}setManhattanDistance(){this.distanceType=Ds.MANHATTAN}setChebyshevDistance(){this.distanceType=Ds.CHEBYSHEV}setF1Output(){this.outputType=Us.F1}setF2Output(){this.outputType=Us.F2}setCrackPattern(){this.outputType=Us.F2_MINUS_F1}setSmoothBlend(){this.outputType=Us.F1_PLUS_F2}setCellIdOutput(){this.outputType=Us.CELL_ID}setCellIdColorOutput(){this.outputType=Us.CELL_ID_COLOR}setCellularPattern(){this.outputType=Us.F1,this.distanceType=Ds.EUCLIDEAN,this.jitter=1}setStonePattern(){this.outputType=Us.F2_MINUS_F1,this.distanceType=Ds.EUCLIDEAN,this.jitter=.8}setOrganicPattern(){this.distanceType=Ds.MANHATTAN,this.jitter=.6}setGridPattern(){this.jitter=0,this.distanceType=Ds.EUCLIDEAN}setCrystalPattern(){this.outputType=Us.F2_MINUS_F1,this.distanceType=Ds.CHEBYSHEV,this.jitter=.9}setStainedGlassPattern(){this.outputType=Us.CELL_ID_COLOR,this.distanceType=Ds.EUCLIDEAN,this.jitter=.7,this.cellIdColorIntensity=.8}setMosaicPattern(){this.outputType=Us.CELL_ID_COLOR,this.distanceType=Ds.MANHATTAN,this.jitter=.3,this.cellIdColorIntensity=1}setBiomeMapPattern(){this.outputType=Us.CELL_ID,this.distanceType=Ds.EUCLIDEAN,this.jitter=.8,this.frequency=4}getSettings(){return{frequency:this.#Wm,distanceScale:this.#rp,octaves:this.#Jm,persistence:this.#Qm,lacunarity:this.#ep,seed:this.#tp,distanceType:this.#ip,outputType:this.#ap,jitter:this.#sp,cellIdColorIntensity:this.#op}}applySettings(i){void 0!==i.frequency&&(this.frequency=i.frequency),void 0!==i.distanceScale&&(this.distanceScale=i.distanceScale),void 0!==i.octaves&&(this.octaves=i.octaves),void 0!==i.persistence&&(this.persistence=i.persistence),void 0!==i.lacunarity&&(this.lacunarity=i.lacunarity),void 0!==i.seed&&(this.seed=i.seed),void 0!==i.distanceType&&(this.distanceType=i.distanceType),void 0!==i.outputType&&(this.outputType=i.outputType),void 0!==i.jitter&&(this.jitter=i.jitter),void 0!==i.cellIdColorIntensity&&(this.cellIdColorIntensity=i.cellIdColorIntensity)}getDistanceTypeName(){return{[Ds.EUCLIDEAN]:"Euclidean",[Ds.MANHATTAN]:"Manhattan",[Ds.CHEBYSHEV]:"Chebyshev"}[this.#ip]||"Unknown"}getOutputTypeName(){return{[Us.F1]:"F1",[Us.F2]:"F2",[Us.F2_MINUS_F1]:"F2-F1 (Crack)",[Us.F1_PLUS_F2]:"F1+F2 (Blend)",[Us.CELL_ID]:"Cell ID",[Us.CELL_ID_COLOR]:"Cell ID Color"}[this.#ap]||"Unknown"}},parseWGSL:parseWGSL});class GltfAnimationLooperManager{#up=60;#lp=1e3/this.#up;#qi=0;#cp=0;render=(i,g,x,_)=>{const v=g;this.#qi;this.#lp,this.#qi=v,this.#cp++;const b=et,y=180/Math.PI;let S,w,L,k,H,z,q,W,be,Ke,Xe,je,Ye,Ze,Je,Qe,tt,it,ft,pt,xt,vt,bt,yt,St,Tt,Mt,wt,Ct,Rt,Pt,Bt,It,Et,Dt,Ut,Lt,At,Gt,kt,Ot,Nt,Vt,Ft,Ht,zt,$t,Kt,Xt,jt,Yt,qt,Wt,Zt,Jt,Qt,en,tn,nn,rn,an,sn,on,un,cn,hn,fn,dn,mn=_.length;for(;mn--;){an=_[mn],rn=an.targetGLTFParsedSingleClip,nn=rn.length;const v=rn.maxTime;for(;nn--;){sn=rn[nn],on=sn.cacheTable;const{animationTargetMesh:_,timeAnimationInfo:et,aniDataAnimationInfo:mn,weightMeshes:pn}=sn;_.dirtyTransform=!0,Jt=(g-an.startTime)%(1e3*v)/1e3,hn=et.dataList,fn=mn.dataList,dn=hn.length;const gn=sn.lastPrevIdx||0;if(gn=hn[dn-1])cn=dn-1,un=0;else{let i=0,g=dn-1;for(;i>1;hn[x]<=Jt?i=x:g=x}cn=i,un=g}else if(Jt<=hn[0])cn=dn-1,un=0;else if(Jt>=hn[dn-1])cn=dn-1,un=0;else{let i=0,g=dn-1;for(;i>1;hn[x]<=Jt?i=x:g=x}cn=i,un=g}let xn,_n,vn,bn,yn,Sn,Tn;sn.lastPrevIdx=cn,Qt=hn[cn],en=hn[un];const Mn=sn.interpolation;if("CUBICSPLINE"==Mn){const i=en-Qt;tn=i==i?i:0;const g=(Jt-Qt)/tn;xn=g==g?g:0,_n=xn*xn,vn=_n*xn,Sn=-2*vn+3*_n,Tn=vn-_n,bn=1-Sn,yn=Tn-_n+xn}else if("STEP"==Mn)tn=0;else{const i=(Jt-Qt)/(en-Qt);tn=i==i?i:0}switch(sn.key){case"rotation":if(cn!==dn-1){if("CUBICSPLINE"===Mn){let i,g,x,_,v,b,y,Je;Gt=12*cn,kt=12*un,S=fn[Gt+4],w=fn[Gt+5],L=fn[Gt+6],k=fn[Gt+7],H=S*S+w*w+L*L+k*k,H>0?(z=1/Math.sqrt(H),q=S*z,W=w*z,be=L*z,Ke=k*z):(q=W=be=0,Ke=1),S=fn[Gt+8],w=fn[Gt+9],L=fn[Gt+10],k=fn[Gt+11],H=S*S+w*w+L*L+k*k,H>0?(z=1/Math.sqrt(H),i=S*z,g=w*z,x=L*z,_=k*z):(i=g=x=0,_=1),S=fn[kt],w=fn[kt+1],L=fn[kt+2],k=fn[kt+3],H=S*S+w*w+L*L+k*k,H>0?(z=1/Math.sqrt(H),v=S*z,b=w*z,y=L*z,Je=k*z):(v=b=y=0,Je=1),S=fn[kt+4],w=fn[kt+5],L=fn[kt+6],k=fn[kt+7],H=S*S+w*w+L*L+k*k,H>0?(z=1/Math.sqrt(H),Xe=S*z,je=w*z,Ye=L*z,Ze=k*z):(Xe=je=Ye=0,Ze=1),S=bn*q+yn*i*tn+Sn*Xe+Tn*v*tn,w=bn*W+yn*g*tn+Sn*je+Tn*b*tn,L=bn*be+yn*x*tn+Sn*Ye+Tn*y*tn,k=bn*Ke+yn*_*tn+Sn*Ze+Tn*Je*tn}else{Gt=cn<<2,kt=un<<2;const i=Gt<<16|kt;let g=on[i];g?(Je=g[0],q=g[1],W=g[2],be=g[3],Ke=g[4],Xe=g[5],je=g[6],Ye=g[7],Ze=g[8]):(S=fn[Gt],w=fn[Gt+1],L=fn[Gt+2],k=fn[Gt+3],H=S*S+w*w+L*L+k*k,H>0?(z=1/Math.sqrt(H),q=S*z,W=w*z,be=L*z,Ke=k*z):(q=W=be=0,Ke=1),S=fn[kt],w=fn[kt+1],L=fn[kt+2],k=fn[kt+3],H=S*S+w*w+L*L+k*k,H>0?(z=1/Math.sqrt(H),Xe=S*z,je=w*z,Ye=L*z,Ze=k*z):(Xe=je=Ye=0,Ze=1),Je=q*Xe+W*je+be*Ye+Ke*Ze,Je<0&&(Je=-Je,Xe=-Xe,je=-je,Ye=-Ye,Ze=-Ze),g=new Float32Array(9),g[0]=Je,g[1]=q,g[2]=W,g[3]=be,g[4]=Ke,g[5]=Xe,g[6]=je,g[7]=Ye,g[8]=Ze,on[i]=g),1-Je>b?(Qe=Math.acos(Je),tt=Math.sin(Qe),it=Math.sin((1-tn)*Qe)/tt,ft=Math.sin(tn*Qe)/tt):(it=1-tn,ft=tn),S=it*q+ft*Xe,w=it*W+ft*je,L=it*be+ft*Ye,k=it*Ke+ft*Ze}pt=S+S,xt=w+w,vt=L+L,bt=S*pt,yt=S*xt,St=S*vt,Tt=w*xt,Mt=w*vt,wt=L*vt,Ct=k*pt,Rt=k*xt,Pt=k*vt,Et=St+Rt,Bt=1-(Tt+wt),It=yt-Pt,Ut=Mt-Ct,At=1-(bt+Tt),Lt=Mt+Ct,Dt=1-(bt+wt),w=Math.asin(Math.max(-1,Math.min(1,Et))),Math.abs(Et)<.99999?(S=Math.atan2(-Ut,At),L=Math.atan2(-It,Bt)):(S=Math.atan2(Lt,Dt),L=0),_.rotationX=S*y,_.rotationY=w*y,_.rotationZ=L*y}break;case"translation":"CUBICSPLINE"===Mn?cn!==dn-1&&(Gt=9*cn,Ot=fn[Gt+3],Nt=fn[Gt+4],Vt=fn[Gt+5],jt=fn[Gt+6],Yt=fn[Gt+7],qt=fn[Gt+8],kt=9*un,$t=fn[kt],Kt=fn[kt+1],Xt=fn[kt+2],Ft=fn[kt+3],Ht=fn[kt+4],zt=fn[kt+5],Wt=jt*tn,Zt=$t*tn,_.x=bn*Ft+yn*Wt+Sn*Ot+Tn*Zt,Wt=Yt*tn,Zt=Kt*tn,_.y=bn*Ht+yn*Wt+Sn*Nt+Tn*Zt,Wt=qt*tn,Zt=Xt*tn,_.z=bn*zt+yn*Wt+Sn*Vt+Tn*Zt):(Gt=3*un,Ot=fn[Gt],Nt=fn[Gt+1],Vt=fn[Gt+2],kt=3*cn,Ft=fn[kt],Ht=fn[kt+1],zt=fn[kt+2],_.x=Ft+tn*(Ot-Ft),_.y=Ht+tn*(Nt-Ht),_.z=zt+tn*(Vt-zt));break;case"scale":"CUBICSPLINE"===Mn?cn!==dn-1&&(Gt=9*cn,Ot=fn[Gt+3],Nt=fn[Gt+4],Vt=fn[Gt+5],jt=fn[Gt+6],Yt=fn[Gt+7],qt=fn[Gt+8],kt=9*un,$t=fn[kt],Kt=fn[kt+1],Xt=fn[kt+2],Ft=fn[kt+3],Ht=fn[kt+4],zt=fn[kt+5],Wt=jt*tn,Zt=$t*tn,_.scaleX=bn*Ft+yn*Wt+Sn*Ot+Tn*Zt,Wt=Yt*tn,Zt=Kt*tn,_.scaleY=bn*Ht+yn*Wt+Sn*Nt+Tn*Zt,Wt=qt*tn,Zt=Xt*tn,_.scaleZ=bn*zt+yn*Wt+Sn*Vt+Tn*Zt):(Gt=3*un,Ot=fn[Gt],Nt=fn[Gt+1],Vt=fn[Gt+2],kt=3*cn,Ft=fn[kt],Ht=fn[kt+1],zt=fn[kt+2],_.scaleX=Ft+tn*(Ot-Ft),_.scaleY=Ht+tn*(Nt-Ht),_.scaleZ=zt+tn*(Vt-zt));break;case"weights":{let g=pn.length;for(;g--;)sn.renderWeight(i,x,pn[g],tn,cn,un);break}}}}}}!function(i,g){void 0===g&&(g={});var x=g.insertAt;if("undefined"!=typeof document){var _=document.head||document.getElementsByTagName("head")[0],v=document.createElement("style");v.type="text/css","top"===x&&_.firstChild?_.insertBefore(v,_.firstChild):_.appendChild(v),v.styleSheet?v.styleSheet.cssText=i:v.appendChild(document.createTextNode(i))}}(".RedGPUDebugPanel{background:rgba(0,0,0,.9);bottom:0;color:#fff;font-size:11px;left:0;line-height:1;max-height:100%;min-width:250px;overflow-y:auto;position:fixed;transform:translateZ(0);width:330px;will-change:transform;z-index:2}.RedGPUDebugPanel::-webkit-scrollbar{width:6px}.RedGPUDebugPanel::-webkit-scrollbar-track{background:#000}.RedGPUDebugPanel::-webkit-scrollbar-thumb{background:#333}.RedGPUDebugPanel::-webkit-scrollbar-thumb:hover{background:#444}.debug-group{line-height:1.4;padding:10px;b{color:#fdb48d;font-weight:700}}.debug-sub-group{background:linear-gradient(90deg,hsla(0,0%,100%,.1),rgba(0,0,0,.01));border:1px solid hsla(0,0%,100%,.16);border-radius:6px;box-shadow:0 0 10px rgba(0,0,0,.16);line-height:1.4;margin:8px 0;padding:6px 10px;b{color:#fdb48d;font-weight:700}}.debug-sub-group-title{color:#e3b096}.debug-item{align-items:center;color:#ccc;display:flex;font-weight:400;gap:10px;justify-content:space-between;transform:translateZ(0);width:100%;will-change:transform;b{color:#fdb48d;font-weight:700}}.boolean-true{background:green}.boolean-false,.boolean-true{border-radius:4px;color:#fff;line-height:1;margin:2px 0;padding:2px 4px}.boolean-false{background:red}.debug-folder{background:rgba(0,0,0,.5);border-bottom:1px solid hsla(0,0%,100%,.05);display:flex;flex-direction:column;width:100%}.debug-folder-title{color:#fdb48d;font-size:15px;b{color:#fdb48d;font-size:11px;font-weight:700}}.debug-folder-small-title,.debug-folder-title{align-items:center;background:linear-gradient(0deg,rgba(0,0,0,.95),hsla(0,0%,100%,.055));cursor:pointer;display:flex;justify-content:space-between;line-height:1;padding:10px 8px;width:100%}.debug-folder-small-title{color:#fff;font-size:12px;b{color:#fdb48d;font-size:11px;font-weight:700}}.debug-folder-title .onoff{font-size:11px}.debug-item-title{color:#888;max-width:240px}.debug-item-cache-key,.debug-item-title{font-weight:500;overflow:hidden;text-overflow:ellipsis;text-shadow:1px 1px 0 rgba(0,0,0,.3)}.debug-item-cache-key{color:#fff;max-width:250px;white-space:nowrap}.div-line{background:hsla(0,0%,100%,.06);border-bottom:1px solid transparent;height:1px;margin:10px 0;width:100%}.root-padding{padding:6px;width:100%}.color-box{border:1px solid hsla(0,0%,100%,.2);border-radius:4px;margin:2px;padding:3px}");const createDebugTitle=i=>`
${i}
`,makeColorDebug=(i,g)=>`\n
\n\x3c!--\t${i} --\x3e\n\t \n\t
${g.rgba}\n\t
\n
\n`,makeBooleanDebug=(i,g)=>`${g?"TRUE":"FALSE"}`,getDebugFormatValue=i=>"boolean"==typeof i?i.toString():"number"==typeof i?i.toLocaleString():i,updateDebugItemValue=(i,g,x,_,v="")=>{const b=i.querySelector(`.${g}`);if(!b)return;const y=`${getDebugFormatValue(x)}${v}`;b.innerHTML!==y&&(b.innerHTML=y,_&&(b.style.background=x?"green":"rgba(255,255,255,0.1)"))};let Vs=class{dom;#hp;#fp=!1;constructor(i){this.#hp=i,this.dom=document.createElement("div"),this.dom.innerHTML=`
\t
${createDebugTitle(`${i} Num: ()`)}\n\x3c!--
${this.#fp?"close":"open"}
--\x3e
\n`}get openYn(){return this.#fp}set openYn(i){this.#fp=i,this.dom.querySelector(".onoff").innerHTML=this.openYn?"close":"open"}update(i,g){const{resourceManager:x}=g;if("Buffer"===this.#hp){const g=x.resources.get("GPUBuffer"),{videoMemory:_}=g;i.totalUsedVideoMemory+=_,updateDebugItemValue(this.dom,"totalCount",g.size),updateDebugItemValue(this.dom,"targetVideoMemorySize",formatBytes(_))}else{const g=x[`managed${this.#hp}State`],{table:_,videoMemory:v}=g;i.totalUsedVideoMemory+=v,updateDebugItemValue(this.dom,"totalCount",_.size),updateDebugItemValue(this.dom,"targetVideoMemorySize",formatBytes(v)),this.#hp}}#dp(i){let g=i;(i.startsWith("Vertex_")||i.startsWith("Index_"))&&(g=i.substring(i.indexOf("_")+1));try{const i=new URL(g),x=i.pathname.split("/").pop()||g;return{host:i.host,filename:x}}catch{return{host:null,filename:g}}}#mp(i){const g=this.dom.querySelector(".item-container"),x=new Set,_=this.#hp,v=new Map;g.querySelectorAll(".debug-group").forEach(i=>{const g=i.className.split(" ")[1].replace(`${_}_`,"");x.add(g),v.set(g,i)});let b=0;i.forEach((i,y)=>{const S=y,w=i.size||0,L=`${_}_${S}`;let k=v.get(S);k?x.delete(S):(k=document.createElement("div"),k.className=`debug-group ${L}`,k.innerHTML=`
${S}
`,g.appendChild(k));const{host:H,filename:z}=this.#dp(y);H?(updateDebugItemValue(k,"host",`${b} ${H}`),updateDebugItemValue(k,"name",z)):updateDebugItemValue(k,"host",`${b} ${y}`),updateDebugItemValue(k,"videoMemorySize",formatBytes(w)),b++});for(let i of x)v.get(i).remove()}#pp(i){const g=this.dom.querySelector(".item-container"),x=new Set,_=this.#hp,v=new Map;g.querySelectorAll(".debug-group").forEach(i=>{const g=i.className.split(" ")[1].replace(`${_}_`,"");x.add(g),v.set(g,i)});let b=0;const y="UniformBuffer"===this.#hp||"StorageBuffer"===this.#hp;i.forEach(i=>{const{useNum:S,buffer:w}=i,{uuid:L,size:k,name:H,gpuBuffer:z}=w,{label:q}=z,W=`${_}_${L}`;let be=v.get(L);be?x.delete(L):(be=document.createElement("div"),be.className=`debug-group ${W}`,be.innerHTML=`
${L}
`,g.appendChild(be));const{host:Ke,filename:Xe}=this.#dp(H);Ke?(updateDebugItemValue(be,"host",`${b} ${Ke}`),updateDebugItemValue(be,"name",Xe)):updateDebugItemValue(be,"host",`${b} ${q}`),y||updateDebugItemValue(be,"useNum",S,!0),updateDebugItemValue(be,"videoMemorySize",formatBytes(k)),b++});for(let i of x)v.get(i).remove()}};class DebugBufferList{debugStatisticsDomService;constructor(i){this.debugStatisticsDomService=new Vs(i)}get dom(){return this.debugStatisticsDomService.dom}update(i,g){this.debugStatisticsDomService.update(i,g)}}class ADebugItem{debugStatisticsDomService;constructor(){}get dom(){return this.debugStatisticsDomService.dom}update(i,g,x){this.debugStatisticsDomService.update(i,g)}}class ADebugStatisticsDomService{dom;#fp=!1;constructor(){}get openYn(){return this.#fp}set openYn(i){this.#fp=i,this.dom.querySelector(".onoff").innerHTML=this.openYn?"close":"open"}init(i,g=!1,x=!1){this.#fp=g,this.dom=document.createElement("div"),this.dom.innerHTML=`
\t
${i}\n\x3c!--
${this.openYn?"close":"open"}
--\x3e
\n`}update(i,g){}}const Fs=["useMSAA","useFXAA","useTAA","alphaMode","renderScale"];let Hs=class extends ADebugStatisticsDomService{constructor(){super(),this.init(`${createDebugTitle("RedGPUContext")}`,!0),this.#pp()}update(i,g){Fs.forEach(i=>this.#gp(g,i)),this.#xp(g)}#pp(){const i=this.dom.querySelector(".item-container"),g=['
',...Fs.map(i=>this.#_p(i)),this.#_p("width_height"),this.#_p("pixelRectArray"),this.#_p("backgroundColor"),"
"];i.innerHTML=g.join("")}#_p(i){return`
${i}
`}#gp(i,g){const x=["useMSAA","useFXAA","useTAA"].includes(g),_=x?i.antialiasingManager[g]:i[g];updateDebugItemValue(this.dom,`redGPUContext_${g}`,x?makeBooleanDebug(0,_):getDebugFormatValue(_))}#xp(i){const{sizeManager:g,width:x,height:_,backgroundColor:v}=i,{pixelRectArray:b}=g;updateDebugItemValue(this.dom,"redGPUContext_width_height",`${x},${_}`),updateDebugItemValue(this.dom,"redGPUContext_pixelRectArray",b),updateDebugItemValue(this.dom,"redGPUContext_backgroundColor",makeColorDebug("backgroundColor",v))}};class DebugRedGPUContext extends ADebugItem{constructor(){super(),this.debugStatisticsDomService=new Hs}}let zs=class extends ADebugStatisticsDomService{#vp;constructor(i){super(),this.#vp=i,this.init(`${createDebugTitle(`${i}Texture Num: ()`)}`,!1,!0)}update(i,g){if("Packed"===this.#vp)this.#bp(i,g);else{const{resourceManager:x}=g,{managedBitmapTextureState:_,managedCubeTextureState:v,managedHDRTextureState:b}=x,{table:y,videoMemory:S}="Bitmap"===this.#vp?_:"Cube"===this.#vp?v:b;i.totalUsedVideoMemory+=S,updateDebugItemValue(this.dom,"totalCount",y.size),updateDebugItemValue(this.dom,"targetVideoMemorySize",formatBytes(S))}}getTargetSrc(i){if("Packed"===this.#vp)return i.src||"packed texture";if(i instanceof ResourceStateCubeTexture){const{cacheKey:g}=i;return`${g}...`}{const{src:g}=i;return g?g.startsWith("data:")?"base64 texture":g:"null"}}getUpdatedTdom(i,g,x,_,v,b){return i||((i=document.createElement("div")).className=`debug-group ${x}`,i.innerHTML=`
\t
${_} ${v||""}
Place holder for host
Place holder for fileName
mipLevelCount:/useMipmap:
width:/height:
${b}
`,g.appendChild(i)),i}updateDebugItems(i,g,x,_,v,b,y,S,w){updateDebugItemValue(i,"mipLevelCount",g),updateDebugItemValue(i,"useMipmap",x),updateDebugItemValue(i,"width",_),updateDebugItemValue(i,"height",v),"HDR"!==this.#vp&&updateDebugItemValue(i,"useNum",b,!0);const{host:L,filename:k}=this.#dp(y);L?(updateDebugItemValue(i,"host",L),updateDebugItemValue(i,"fileName",k)):updateDebugItemValue(i,"fileName",y),updateDebugItemValue(i,"targetSrc","null"===S?"":S),updateDebugItemValue(i,"videoMemorySize",formatBytes(w))}#bp(i,g){const x=PackedTexture.getCacheMap(),_=this.#yp(x);let v=0;_.forEach(i=>{v+=i.texture.videoMemorySize}),i.totalUsedVideoMemory+=v,updateDebugItemValue(this.dom,"totalCount",_.size),updateDebugItemValue(this.dom,"targetVideoMemorySize",formatBytes(v))}#yp(i){const g=new Map;return i.forEach((i,x)=>{const _={gpuTexture:i.gpuTexture,uuid:i.uuid,mipLevelCount:i.gpuTexture.mipLevelCount||1,useMipmap:(i.gpuTexture.mipLevelCount||1)>1,videoMemorySize:this.#Sp(i.gpuTexture)},v={useNum:i.useNum,cacheKey:x,texture:_,src:`packed:${x.substring(0,50)}${x.length>50?"...":""}`,mappingKey:i.mappingKey};g.set(x,v)}),g}#Sp(i){const g=i.label?.match(/(\d+)x(\d+)/);if(g){const x=parseInt(g[1]),_=parseInt(g[2]),v=i.mipLevelCount||1;let b=0;for(let i=0;i>i)*Math.max(1,_>>i)*4}return b}return 4194304}#dp(i){if("Packed"===this.#vp){try{const g=i.split("}_");if(g.length>=2){const i=g[0]+"}";g[1];return{host:"packed",filename:`${i.substring(0,20)}...`}}}catch{}return{host:"packed",filename:i.length>30?i.substring(0,30)+"...":i}}try{const g=new URL(i),x=g.pathname.split("/").pop()||i;return{host:g.host,filename:x}}catch{const g=i.split("_");return{host:g[0],filename:g.pop()||i}}}#pp(i){const g=this.dom.querySelector(".item-container"),x=new Set,_="Bitmap"===this.#vp?"cube_texture":"Cube"===this.#vp?"bitmap_texture":"HDR"===this.#vp?"hdr_texture":"packed_texture";g.querySelectorAll(".debug-group").forEach(i=>{const g=i.className.split(" ")[1].replace(`${_}_`,"");x.add(g)});let v=0;for(const b of i.values()){const{useNum:i,cacheKey:y,texture:S}=b;let w=this.getTargetSrc(b);const{mipLevelCount:L,useMipmap:k,gpuTexture:H,uuid:z,videoMemorySize:q}=S,{width:W,height:be}=H||{},Ke=`${_}_${S.uuid}`;let Xe=g.querySelector(`.${Ke}`);Xe=this.getUpdatedTdom(Xe,g,Ke,v,w,z),x.delete(S.uuid),this.updateDebugItems(Xe,L,k,W,be,i,y,w,q),v++}for(let i of x)g.querySelector(`.${_}_${i}`)?.remove()}};class DebugTextureList extends ADebugItem{constructor(i="Bitmap"){super(),this.debugStatisticsDomService=new zs(i)}}const $s=["totalNum3DGroups","totalNum3DObjects","totalNumInstances","totalNumDrawCalls","totalNumTriangles","totalNumPoints","totalUsedVideoMemory"];let Ks=class{dom;constructor(){this.dom=document.createElement("div"),this.#Tp()}update(i){$s.forEach(g=>{const x=i[g],_="totalUsedVideoMemory"===g?`${formatBytes(x)}`:x;updateDebugItemValue(this.dom,g,_)})}#Tp(){const i=this.#pp();this.dom.innerHTML=`
${createDebugTitle("Total State")}
${i}
`}#pp(){return $s.map(i=>"totalUsedVideoMemory"===i?`
${i}
`:`
${i}
`).join("")}};class DebugTotalState extends ADebugItem{constructor(){super(),this.debugStatisticsDomService=new Ks}}const Xs=["usedVideoMemory","viewRenderTime","num3DGroups","num3DObjects","numInstances","numDrawCalls","numTriangles","numPoints"],js={viewRenderTime:"ms"},Ys={camera:"camera.name",scene:"scene.name",useBackgroundColor:"scene.useBackgroundColor",backgroundColor:"scene.backgroundColor",x_y:"x,y",width_height:"width,height"};let qs=class extends ADebugStatisticsDomService{#Mp=0;constructor(){super(),this.init(`${createDebugTitle("ViewList")}`,!0)}update(i,g){const{viewList:x,numViews:_}=g;this.#Mp!==_&&(this.#wp(x),this.#Mp=_),x.forEach((g,x)=>{Xs.forEach(_=>this.#gp(g,x,_,i)),this.#xp(g,x)})}#_p(i,g){return`
${Ys[g]||g}
`}#wp(i){const g=this.dom.querySelector(".item-container"),x=i.map((i,g)=>{const{name:x}=i,_=Xs.map(i=>this.#_p(g,i));return _.push('
',this.#_p(g,"x_y"),this.#_p(g,"width_height"),this.#_p(g,"pixelRectArray"),this.#_p(g,"camera"),this.#_p(g,"scene"),this.#_p(g,"useBackgroundColor"),this.#_p(g,"backgroundColor"),"
"),`${createDebugTitle(`
${x}
`)}${_.join("")}`});return g.innerHTML=`
${x.join('
')}
`}#gp(i,g,x,_){const{renderViewStateData:v}=i,b=`total${x.charAt(0).toUpperCase()}${x.substring(1)}`,y=v[x],S="usedVideoMemory"===x?`${formatBytes(y)}`:y,w=js[x];_[b]+=y,updateDebugItemValue(this.dom,`view${g}_${x}`,S,!1,w)}#xp(i,g){const{renderViewStateData:x,rawCamera:_,scene:v}=i,{backgroundColor:b,useBackgroundColor:y}=v,{viewportSize:S}=x,{pixelRectArray:w,x:L,y:k,width:H,height:z}=S;updateDebugItemValue(this.dom,`view${g}_x_y`,`${formatNumber(L)},${formatNumber(k)}`),updateDebugItemValue(this.dom,`view${g}_width_height`,`${H},${z}`),updateDebugItemValue(this.dom,`view${g}_pixelRectArray`,w),updateDebugItemValue(this.dom,`view${g}_useBackgroundColor`,makeBooleanDebug(0,y)),updateDebugItemValue(this.dom,`view${g}_backgroundColor`,makeColorDebug("backgroundColor",b)),updateDebugItemValue(this.dom,`view${g}_camera`,_.name),updateDebugItemValue(this.dom,`view${g}_scene`,v.name)}};class DebugViewList extends ADebugItem{constructor(){super(),this.debugStatisticsDomService=new qs}}const formatNumber=i=>{const g=String(i);if(g.includes("%")){const i=parseFloat(g);return isNaN(i)?g:`${i.toFixed(2)}%`}if(g.includes("px")){const i=parseFloat(g);return isNaN(i)?g:`${i.toFixed(2)}px`}const x=parseFloat(g);return isNaN(x)?g:x.toFixed(2)};class DebugStatisticsDomService{dom;constructor(i){this.dom=document.createElement("div"),this.dom.style.cssText="z-index:1;position:sticky;top:0;background:#000;border-bottom:1px solid rgba(255,255,255,0.06);box-shadow:0 10px 10px rgba(0,0,0,0.5)",this.#Tp(i)}update(i,g,x,_,v){const b={fps:i,avg:g,low1:x,low01:_,frameTime:v};Object.entries(b).forEach(([i,g])=>this.#Cp(i,g))}#Tp(i){this.dom.innerHTML='
Performance
Monitor
60 FPS
16.67ms
Avg:60
1%:60
0.1%:60
CLOSE
'}#Cp(i,g){const x=this.dom.querySelector(`.${i}`);x&&x.innerHTML!==g&&(x.innerHTML=g)}}class Fps extends ADebugItem{#Rp=0;#cp=0;#Pp=!1;#Bp=[];#Ip=1200;#Ep=[];#Dp=10;#Up=0;#Lp=60;#Ap=0;#Gp=0;#kp=0;#Op=60;constructor(i){super(),this.debugStatisticsDomService=new DebugStatisticsDomService(i)}update(i,g,x){if(0===this.#cp)return this.#Rp=x,void this.#cp++;const _=x-this.#Rp;if(this.#Rp=x,this.#cp++,!this.#Pp){const i=document.querySelector(".panel_close");i&&(i.addEventListener("click",()=>{g.useDebugPanel=!1}),this.#Pp=!0)}const v=this.#Np(_);this.#cp>this.#Op&&(this.#Bp.push(v),this.#Bp.length>this.#Ip&&this.#Bp.shift()),this.#Ep.push(v),this.#Ep.length>this.#Dp&&this.#Ep.shift();const b=this.#Vp();this.#Up++,this.#Up>=this.#Lp&&(this.#Fp(),this.#Up=0),this.debugStatisticsDomService.update(`${b} FPS`,`Avg:${this.#Ap}`,`1%:${this.#Gp}`,`0.1%:${this.#kp}`,`${v.toFixed(2)}ms`)}#Np(i){return Math.min(Math.max(i,.1),1e3)}#Vp(){if(0===this.#Ep.length)return 0;const i=this.#Ep.reduce((i,g)=>i+g,0)/this.#Ep.length;return Math.round(1e3/i)}#Fp(){if(this.#Bp.length<100)return this.#Ap=0,this.#Gp=0,void(this.#kp=0);const i=this.#Hp();this.#Ap=i.avgFps,this.#Gp=i.low1Fps,this.#kp=i.low01Fps}#Hp(){const i=this.#Bp.reduce((i,g)=>i+g,0),g=i/this.#Bp.length,x=Math.round(1e3/g),_=[...this.#Bp].sort((i,g)=>g-i),v=_.length,b=Math.max(1,Math.ceil(.01*v)),y=_.slice(0,b),S=y.reduce((i,g)=>i+g,0)/y.length,w=Math.round(1e3/S),L=Math.max(1,Math.ceil(.001*v)),k=_.slice(0,L),H=k.reduce((i,g)=>i+g,0)/k.length;return{avgFps:x,low1Fps:w,low01Fps:Math.round(1e3/H)}}}class DebugRender{fps;debugTotalState;debugViewList;debugRedGPUContext;debugBitmapTextureList;debugCubeTextureList;debugHDRTextureList;debugPackedTextureList;debugIndexBufferList;debugVertexBufferList;debugUniformBufferList;debugStorageBufferList;debugBufferList;totalNum3DGroups;totalNum3DObjects;totalNumDrawCalls;totalNumInstances;totalNumTriangles;totalNumPoints;totalUsedVideoMemory;#zp;constructor(i){this.fps=new Fps(i),this.debugTotalState=new DebugTotalState,this.debugRedGPUContext=new DebugRedGPUContext,this.debugViewList=new DebugViewList,this.debugBitmapTextureList=new DebugTextureList,this.debugCubeTextureList=new DebugTextureList("Cube"),this.debugHDRTextureList=new DebugTextureList("HDR"),this.debugPackedTextureList=new DebugTextureList("Packed"),this.debugIndexBufferList=new DebugBufferList("IndexBuffer"),this.debugVertexBufferList=new DebugBufferList("VertexBuffer"),this.debugUniformBufferList=new DebugBufferList("UniformBuffer"),this.debugStorageBufferList=new DebugBufferList("StorageBuffer"),this.debugBufferList=new DebugBufferList("Buffer"),this.#$p()}render(i,g){i.useDebugPanel?(this.#Kp(),this.fps.update(this,i,g),this.debugRedGPUContext.update(this,i,g),this.debugViewList.update(this,i,g),this.debugBitmapTextureList.update(this,i,g),this.debugCubeTextureList.update(this,i,g),this.debugHDRTextureList.update(this,i,g),this.debugPackedTextureList.update(this,i,g),this.debugIndexBufferList.update(this,i),this.debugVertexBufferList.update(this,i),this.debugUniformBufferList.update(this,i),this.debugStorageBufferList.update(this,i),this.debugBufferList.update(this,i),this.debugTotalState.update(this,i,g)):this.#Xp(),this.#$p()}#$p(){this.totalNum3DGroups=0,this.totalNum3DObjects=0,this.totalNumInstances=0,this.totalNumDrawCalls=0,this.totalNumTriangles=0,this.totalNumPoints=0,this.totalUsedVideoMemory=0}#Kp(){this.#zp||(this.#zp=document.createElement("div"),this.#zp.className="RedGPUDebugPanel",document.body.appendChild(this.#zp),[this.fps.debugStatisticsDomService,this.debugTotalState.debugStatisticsDomService,this.debugRedGPUContext.debugStatisticsDomService,this.debugViewList.debugStatisticsDomService,this.debugBufferList.debugStatisticsDomService,this.debugVertexBufferList.debugStatisticsDomService,this.debugIndexBufferList.debugStatisticsDomService,this.debugUniformBufferList.debugStatisticsDomService,this.debugStorageBufferList.debugStatisticsDomService,this.debugBitmapTextureList.debugStatisticsDomService,this.debugPackedTextureList.debugStatisticsDomService,this.debugCubeTextureList.debugStatisticsDomService,this.debugHDRTextureList.debugStatisticsDomService].forEach(i=>this.#zp.appendChild(i.dom)))}#Xp(){this.#zp&&(this.#zp.remove(),this.#zp=null)}}Object.freeze(DebugRender);var Ws="struct Uniforms{ backgroundColor:vec4\n}\n@group(1) @binding(0)\nvar _sampler:sampler;\n@group(1) @binding(1)\nvar _texture:texture_2d;\n@group(1) @binding(2)\nvar uniforms:Uniforms;\n@fragment\nfn main(@location(0) fragUV:vec2) -> @location(0) vec4 { var viewColor:vec4=textureSample(_texture,_sampler,fragUV); let backgroundColor=uniforms.backgroundColor; let blendedColor=vec4( viewColor.rgb + backgroundColor.rgb * (1.0 - viewColor.a), viewColor.a + backgroundColor.a * (1.0 - viewColor.a) ); return blendedColor;\n}\n",Zs="\nstruct VertexUniforms { modelMatrix:mat4x4,\n};\n@group(0) @binding(0)\nvar vertexUniforms:VertexUniforms;\nstruct VertexOutput { @builtin(position) Position:vec4, @location(0) fragUV:vec2,\n};\n@vertex\nfn main(@builtin(vertex_index) VertexIndex:u32) -> VertexOutput { var pos=array,6>( vec2( 1.0,1.0), vec2( 1.0,-1.0), vec2(-1.0,-1.0), vec2( 1.0,1.0), vec2(-1.0,-1.0), vec2(-1.0,1.0), ); var uv=array,6>( vec2(1.0,0.0), vec2(1.0,1.0), vec2(0.0,1.0), vec2(1.0,0.0), vec2(0.0,1.0), vec2(0.0,0.0), ); var output:VertexOutput; output.Position=vertexUniforms.modelMatrix * vec4(pos[VertexIndex],0.0,1.0); output.fragUV=uv[VertexIndex]; return output;\n}\n";const Js=parseWGSL(Zs),Qs=parseWGSL(Ws),eo=Js.uniforms.vertexUniforms;class FinalRender{#jp=[];#Yp=[];#qp;#Wp;#Zp;#Jp;#Qp;#eg=[];#Q;#tg=[];#ng=[];#ae;#rg=[];#ig=[];constructor(){}render(i,g){const{sizeManager:x,gpuDevice:_,antialiasingManager:v}=i,{changedMSAA:b,useMSAA:y}=v,{pixelRectObject:S}=x,{width:w,height:L}=S;if(0===w||0===L)return;const k=this.#ag(i),H=_.createCommandEncoder(),z=H.beginRenderPass(k);z.setViewport(0,0,w,L,0,1),z.setScissorRect(0,0,w,L),this.#qp&&!b||this.#sg(i),this.#og(i,z,g.map(i=>{const g=i.colorAttachments[0];return g.postEffectView||g.pickingView||g.resolveTarget||g.view}),w,L,y),z.end(),_.queue.submit([H.finish()])}#ug(i,g){{const{scene:x,redGPUContext:_}=i,{gpuDevice:v}=_,{backgroundColor:b,useBackgroundColor:y}=x,S=y?b.rgbaNormal:[0,0,0,0],w=_.backgroundColor.rgbaNormal;let L;const k=[S[0]*S[3],S[1]*S[3],S[2]*S[3],S[3]],H=[w[0]*w[3],w[1]*w[3],w[2]*w[3],w[3]];L=[k[0]+H[0]*(1-S[3]),k[1]+H[1]*(1-S[3]),k[2]+H[2]*(1-S[3]),S[3]+w[3]*(1-S[3])],this.#ig[g][0]=L[0],this.#ig[g][1]=L[1],this.#ig[g][2]=L[2],this.#ig[g][3]=L[3],v.queue.writeBuffer(this.#rg[g],0,this.#ig[g])}}#og(i,g,x,_,v,b){const{gpuDevice:y}=i;x.forEach((x,b)=>{const S=i.viewList[b],{x:w,y:L,width:k,height:H}=S.pixelRectObject,z=create$4();bt(z,0,1,0,1,-1e3,1e3),scale$4(z,z,[1/_,1/v,1]),translate(z,z,[k/2+w,v-H/2-L,0]),scale$4(z,z,[k/2,H/2,1]),this.#lg(i,b);const q=this.#jp[b],W=this.#Yp[b];y.queue.writeBuffer(q.gpuBuffer,eo.members.modelMatrix.uniformOffset,z);if(i.antialiasingManager.changedMSAA||!this.#tg[b]||this.#tg[b].width!==k||this.#tg[b].height!==H||this.#ng[b]!==x){this.#rg[b]||(this.#rg[b]=i.gpuDevice.createBuffer({label:`FINAL_RENDER_FRAGMENT_BUFFER_${b}`,size:16,usage:GPUBufferUsage.UNIFORM|GPUBufferUsage.COPY_DST}),this.#ig[b]=new Float32Array([1,0,0,1]));const g={layout:this.#Jp,label:"FRAGMENT_BIND_GROUP_DESCRIPTOR_FINAL_RENDER",entries:[{binding:0,resource:this.#ae.gpuSampler},{binding:1,resource:x},{binding:2,resource:{buffer:this.#rg[b],offset:0,size:this.#rg[b].size}}]};this.#eg[b]=y.createBindGroup(g),this.#tg[b]={width:k||1,height:H||1},this.#ng[b]=x}this.#ug(S,b),g.setPipeline(this.#cg(i)),g.setBindGroup(0,W),g.setBindGroup(1,this.#eg[b]),g.draw(6,1,0,0)})}#sg(i){const{resourceManager:g}=i;this.#qp=g.createBindGroupLayout("FINAL_RENDER_VERTEX_BIND_GROUP_LAYOUT",getVertexBindGroupLayoutDescriptorFromShaderInfo(Js,0)),this.#Wp=g.createGPUShaderModule("VERTEX_MODULE_FINAL_RENDER",{code:Zs}),this.#Zp={module:this.#Wp,entryPoint:"main"},this.#Qp=g.createGPUShaderModule("FRAGMENT_MODULE_FINAL_RENDER",{code:Ws}),this.#Jp=g.createBindGroupLayout("FINAL_RENDER_BIND_GROUP_LAYOUT",getFragmentBindGroupLayoutDescriptorFromShaderInfo(Qs,1)),this.#ae=new Sampler(i,{minFilter:"linear"})}#lg(i,g){const{gpuDevice:x}=i;if(!this.#jp[g]){const _=new ArrayBuffer(eo.arrayBufferByteLength),v=this.#jp[g]=new UniformBuffer(i,_,`FinalRender_View(${g})_VertexUniform`),b={layout:this.#qp,label:"VERTEX_BIND_GROUP_DESCRIPTOR_FINAL_RENDER",entries:[{binding:0,resource:{buffer:v.gpuBuffer,offset:0,size:v.size}}]};this.#Yp[g]=x.createBindGroup(b)}}#ag(i){const{backgroundColor:g,gpuContext:x}=i;return{colorAttachments:[{view:x.getCurrentTexture().createView({label:"FINAL_RENDER"}),clearValue:{r:0,g:0,b:0,a:0},loadOp:H.CLEAR,storeOp:z.STORE}]}}#cg(i){if(!this.#Q||i.antialiasingManager.changedMSAA){const{gpuDevice:g}=i,x={label:"PIPELINE_DESCRIPTOR_FINAL_RENDER",layout:g.createPipelineLayout({label:"FINAL_RENDER_PIPELINE_LAYOUT",bindGroupLayouts:[this.#qp,this.#Jp]}),vertex:this.#Zp,fragment:{module:this.#Qp,entryPoint:"main",targets:[{format:navigator.gpu.getPreferredCanvasFormat(),blend:{color:{srcFactor:mr.SRC_ALPHA,dstFactor:mr.ONE_MINUS_SRC_ALPHA,operation:pr.ADD},alpha:{srcFactor:mr.SRC_ALPHA,dstFactor:mr.ONE_MINUS_SRC_ALPHA,operation:pr.ADD}}}]}};this.#Q=g.createRenderPipeline(x)}return this.#Q}}const renderListForLayer=(i,g,x="pipeline")=>{let _=0;const v=i.length,{currentRenderPassEncoder:b}=g;for(b.setBindGroup(0,g.view.systemUniform_Vertex_UniformBindGroup);_{g?.(x),i.currentTime=x,this.renderFrame(i,x),this.#dg.render(i,x),i.currentRequestAnimationFrame=requestAnimationFrame(HD_render)};i.currentRequestAnimationFrame=requestAnimationFrame(HD_render)}stop(i){cancelAnimationFrame(i.currentRequestAnimationFrame),i.currentRequestAnimationFrame=null}renderFrame(i,g){this.#fg||(this.#fg=new FinalRender),this.#dg||(this.#dg=new DebugRender(i));const x=[];{let _=0;const v=i.viewList.length;for(;_=S){y.prevTimestamp=x-b%S;const{scene:g}=i;g.physicsEngine&&g.physicsEngine.step(S/1e3)}_.update?.(i,g)}this.#gg(i),this.#xg(i,H),this.#_g(i,H,z),this.#vg(i,H,z,w),this.#bg(i,H)}return z.colorAttachments[0].postEffectView=i.postEffectManager.render().textureView,x.gpuDevice.queue.submit([H.finish(),this.#yg(x,y)]),i.renderViewStateData.viewRenderTime=performance.now()-i.renderViewStateData.startTime,v?.checkEvents(i,g),z}#xg(i,g){const{scene:x}=i,{shadowManager:_}=x,{directionalShadowManager:v}=_,b={label:`${i.name} Shadow Render Pass`,colorAttachments:[],depthStencilAttachment:{view:v.shadowDepthTextureView,depthClearValue:1,depthLoadOp:H.CLEAR,depthStoreOp:z.STORE}},y=g.beginRenderPass(b);this.#Sg(i,y,!0),this.#Tg(i,y,!0,!1),v.castingList.length&&((i,g)=>{const{renderViewStateData:x,scene:_}=i;x.currentRenderPassEncoder=g;const{shadowManager:v}=_,{directionalShadowManager:b}=v,{castingList:y}=b;renderListForLayer(y,x,"shadowPipeline")})(i,y),y.end(),v.resetCastingList()}#_g(i,g,x){const{renderViewStateData:_,skybox:v,grid:b,axis:y}=i,S=g.beginRenderPass(x);{const g=i.viewRenderTextureManager.renderPath1ResultTextureView;this.#Sg(i,S),this.#Tg(i,S,!1,!0,g)}_.currentRenderPassEncoder=S,S.setBindGroup(0,i.systemUniform_Vertex_UniformBindGroup),v&&v.render(_),y&&y.render(_),((i,g)=>{const{renderViewStateData:x,scene:_}=i;x.currentRenderPassEncoder=g;const{children:v}=_;let b=0;const y=v.length;for(;b{const{renderViewStateData:x,rawCamera:_}=i;x.currentRenderPassEncoder=g;const{bundleListAlphaLayer:v,bundleListTransparentLayer:b,bundleListParticleLayer:y}=x;v.length&&g.executeBundles(v);const{x:S,y:w,z:L}=_;b.length&&g.executeBundles(sortTransparentObjects({x:S,y:w,z:L},b)),y.length&&g.executeBundles(y)})(i,S),S.end()}#vg(i,g,x,_){const{redGPUContext:v,renderViewStateData:b}=i,{antialiasingManager:y}=v,{useMSAA:S}=y;if(i.renderViewStateData.bundleListRender2PathLayer.length){const{mipmapGenerator:y}=v.resourceManager;let w=i.viewRenderTextureManager.renderPath1ResultTexture,L=S?i.viewRenderTextureManager.gBufferColorResolveTexture:i.viewRenderTextureManager.gBufferColorTexture;L||(S?console.error("MSAA가 활성화되어 있지만 gBufferColorResolveTexture가 정의되지 않았습니다"):console.error("gBufferColorTexture가 정의되지 않았습니다")),w||console.error("renderPath1ResultTexture가 정의되지 않았습니다"),g.copyTextureToTexture({texture:L},{texture:w},{width:i.pixelRectObject.width,height:i.pixelRectObject.height,depthOrArrayLayers:1}),y.generateMipmap(w,i.viewRenderTextureManager.renderPath1ResultTextureDescriptor,!0);const k=g.beginRenderPass({label:`${i.name} 2Path Render Pass`,colorAttachments:[...x.colorAttachments].map(i=>({...i,loadOp:H.LOAD})),depthStencilAttachment:{..._,depthLoadOp:H.LOAD}});k.executeBundles(b.bundleListRender2PathLayer),k.end()}}#bg(i,g){const{pickingManager:x}=i;if(x&&x.castingList.length){x.checkTexture(i);const _={label:`${i.name} Picking Render Pass`,colorAttachments:[{view:x.pickingGPUTextureView,clearValue:{r:0,g:0,b:0,a:0},loadOp:H.CLEAR,storeOp:z.STORE}],depthStencilAttachment:{view:x.pickingDepthGPUTextureView,depthClearValue:1,depthLoadOp:H.CLEAR,depthStoreOp:z.STORE}},v=g.beginRenderPass(_);this.#Sg(i,v),this.#Tg(i,v,!1,!1),((i,g)=>{const{renderViewStateData:x,pickingManager:_}=i;x.currentRenderPassEncoder=g;const{castingList:v}=_;renderListForLayer(v,x,"pickingPipeline")})(i,v),v.end()}}#gg(i){const{taa:g}=i,x=g.frameIndex||0,_=g.jitterStrength,v=x%16,b=this.#Mg(v+1,2),y=this.#Mg(v+1,3),S=window.devicePixelRatio||1,w=(b-.5)/S*_,L=(y-.5)/S*_;i.setJitterOffset(w,L)}#Mg(i,g){let x=0,_=1,v=i;for(;v>0;)_/=g,x+=_*(v%g),v=Math.floor(v/g);return x}#yg(i,g){const{animationList:x,skinList:_}=g,v=_.length,b=x.length,{gpuDevice:y}=i,S=y.createCommandEncoder({label:"BatchUpdateSkinMatrices_CommandEncoder"}),w=S.beginComputePass();b&&this.#mg.render(i,g.timestamp,w,x.flat());for(let g=0;g(global_id.xy );\nlet dimensions:vec2=textureDimensions(sourceTexture);\nlet dimW=f32(dimensions.x);\nlet dimH=f32(dimensions.y);\nlet uv=vec2(f32(index.x)/dimW,f32(index.y)/dimH);\nvar color:vec4=textureLoad( sourceTexture,index,);\nlet brightness_value:f32=uniforms.brightness/255.0;\nlet contrast_value:f32=uniforms.contrast/255.0;\nvar tempColor:vec3;\nif ( contrast_value > 0.0 ) { tempColor=( color.rgb - 0.5 )/( 1.0 - contrast_value ) + 0.5;\n}else { tempColor=( color.rgb - 0.5 ) * ( 1.0 + contrast_value ) + 0.5;\n}\ncolor=vec4(tempColor + brightness_value,color.a);\ntextureStore(outputTexture,index,color );\n","struct Uniforms { brightness:f32, contrast:f32\n};\n"))}get brightness(){return this.#gc}set brightness(i){validateNumberRange(i,-150,150),this.#gc=i,this.updateUniform("brightness",i)}get contrast(){return this.#Sr}set contrast(i){validateNumberRange(i,-50,100),this.#Sr=i,this.updateUniform("contrast",i)}}Object.freeze(BrightnessContrast);class ColorBalance extends ASinglePassPostEffect{#wg=0;#Cg=0;#Rg=0;#Pg=0;#Bg=0;#Ig=0;#Eg=0;#Dg=0;#Ug=0;#Lg=!0;constructor(i){super(i),this.init(i,"POST_EFFECT_COLOR_BALANCE",createBasicPostEffectCode(this,"let index=vec2(global_id.xy );\nlet dimensions:vec2=textureDimensions(sourceTexture);\nlet dimW=f32(dimensions.x);\nlet dimH=f32(dimensions.y);\nlet uv=vec2(f32(index.x)/dimW,f32(index.y)/dimH);\nvar color:vec4=textureLoad( sourceTexture,index,);\nlet original_luminance=0.299 * color.r + 0.587 * color.g + 0.114 * color.b;\nlet shadow_weight=1.0 - smoothstep(0.0,0.5,original_luminance);\nlet highlight_weight=smoothstep(0.5,1.0,original_luminance);\nlet midtone_weight=1.0 - shadow_weight - highlight_weight;\nlet cyan_red=shadow_weight * uniforms.shadowCyanRed +\nmidtone_weight * uniforms.midtoneCyanRed +\nhighlight_weight * uniforms.highlightCyanRed;\nlet magenta_green=shadow_weight * uniforms.shadowMagentaGreen +\nmidtone_weight * uniforms.midtoneMagentaGreen +\nhighlight_weight * uniforms.highlightMagentaGreen;\nlet yellow_blue=shadow_weight * uniforms.shadowYellowBlue +\nmidtone_weight * uniforms.midtoneYellowBlue +\nhighlight_weight * uniforms.highlightYellowBlue;\ncolor.r +=cyan_red * 0.01;\ncolor.g +=magenta_green * 0.01;\ncolor.b +=yellow_blue * 0.01;\nlet adjusted_luminance=0.299 * color.r + 0.587 * color.g + 0.114 * color.b;\nif (uniforms.preserveLuminosity==1 && adjusted_luminance > 0.0) { let ratio=original_luminance/adjusted_luminance; color=color * ratio;\n}\ntextureStore(outputTexture,index,color );\n","struct Uniforms { shadowCyanRed:f32, shadowMagentaGreen:f32, shadowYellowBlue:f32, midtoneCyanRed:f32, midtoneMagentaGreen:f32, midtoneYellowBlue:f32, highlightCyanRed:f32, highlightMagentaGreen:f32, highlightYellowBlue:f32, preserveLuminosity:u32\n};\n"))}get shadowCyanRed(){return this.#wg}set shadowCyanRed(i){validateNumberRange(i,-100,100),this.#wg=i,this.updateUniform("shadowCyanRed",i)}get shadowMagentaGreen(){return this.#Cg}set shadowMagentaGreen(i){validateNumberRange(i,-100,100),this.#Cg=i,this.updateUniform("shadowMagentaGreen",i)}get shadowYellowBlue(){return this.#Rg}set shadowYellowBlue(i){validateNumberRange(i,-100,100),this.#Rg=i,this.updateUniform("shadowYellowBlue",i)}get midtoneCyanRed(){return this.#Pg}set midtoneCyanRed(i){validateNumberRange(i,-100,100),this.#Pg=i,this.updateUniform("midtoneCyanRed",i)}get midtoneMagentaGreen(){return this.#Bg}set midtoneMagentaGreen(i){validateNumberRange(i,-100,100),this.#Bg=i,this.updateUniform("midtoneMagentaGreen",i)}get midtoneYellowBlue(){return this.#Ig}set midtoneYellowBlue(i){validateNumberRange(i,-100,100),this.#Ig=i,this.updateUniform("midtoneYellowBlue",i)}get highlightCyanRed(){return this.#Eg}set highlightCyanRed(i){validateNumberRange(i,-100,100),this.#Eg=i,this.updateUniform("highlightCyanRed",i)}get highlightMagentaGreen(){return this.#Dg}set highlightMagentaGreen(i){validateNumberRange(i,-100,100),this.#Dg=i,this.updateUniform("highlightMagentaGreen",i)}get highlightYellowBlue(){return this.#Ug}set highlightYellowBlue(i){validateNumberRange(i,-100,100),this.#Ug=i,this.updateUniform("highlightYellowBlue",i)}get preserveLuminosity(){return this.#Lg}set preserveLuminosity(i){this.#Lg=i,this.updateUniform("preserveLuminosity",i)}}Object.freeze(ColorBalance);class ColorTemperatureTint extends ASinglePassPostEffect{#Ag=6500;#Gg=0;#kg=100;constructor(i){super(i),this.init(i,"POST_EFFECT_COLOR_TEMPERATURE_TINT",createBasicPostEffectCode(this,"let index=vec2(global_id.xy);\nlet dimensions:vec2=textureDimensions(sourceTexture);\nlet dimW=f32(dimensions.x);\nlet dimH=f32(dimensions.y);\nlet uv=vec2(f32(index.x)/dimW,f32(index.y)/dimH);\nvar color:vec4=textureLoad(sourceTexture,index);\nlet temp=uniforms.temperature;\nvar tempRGB:vec3;\nif (temp <=6600.0) { tempRGB.r=1.0;\n} else { let t=temp - 6600.0; tempRGB.r=clamp(1.292936 * pow(t,-0.1332047),0.0,1.0);\n}\nif (temp <=6600.0) { let t=temp; tempRGB.g=clamp(0.39008157 * log(t) - 0.63184144,0.0,1.0);\n} else { let t=temp - 6600.0; tempRGB.g=clamp(1.292936 * pow(t,-0.1332047),0.0,1.0);\n}\nif (temp >=6600.0) { tempRGB.b=1.0;\n} else if (temp <=1900.0) { tempRGB.b=0.0;\n} else { let t=temp - 1000.0; tempRGB.b=clamp(0.543206789 * log(t) - 1.19625408,0.0,1.0);\n}\nlet neutralTemp:vec3=vec3(1.0,1.0,1.0);\nlet tempAdjust:vec3=tempRGB/neutralTemp;\nlet tintValue=uniforms.tint * 0.01;\nvar tintRGB:vec3;\nif (tintValue >=0.0) { tintRGB=vec3(1.0 - tintValue * 0.2,1.0,1.0 - tintValue * 0.2);\n} else { let mag=-tintValue; tintRGB=vec3(1.0,1.0 - mag * 0.2,1.0);\n}\nlet colorAdjust=tempAdjust * tintRGB;\nlet strength=uniforms.strength * 0.01;\nlet finalAdjust=mix(vec3(1.0,1.0,1.0),colorAdjust,strength);\ncolor=vec4(color.rgb * finalAdjust,color.a);\ncolor=vec4(clamp(color.rgb,vec3(0.0),vec3(1.0)),color.a);\ntextureStore(outputTexture,index,color);\n","struct Uniforms { temperature:f32, tint:f32, strength:f32\n};\n")),this.strength=this.#kg,this.tint=this.#Gg,this.temperature=this.#Ag}get temperature(){return this.#Ag}set temperature(i){validateNumberRange(i,1e3,2e4),this.#Ag=i,this.updateUniform("temperature",i)}get tint(){return this.#Gg}set tint(i){validateNumberRange(i,-100,100),this.#Gg=i,this.updateUniform("tint",i)}get strength(){return this.#kg}set strength(i){validateNumberRange(i,0,100),this.#kg=i,this.updateUniform("strength",i)}setWarmTone(){this.temperature=3200,this.tint=-10}setCoolTone(){this.temperature=8e3,this.tint=10}setNeutral(){this.temperature=6500,this.tint=0}setCandleLight(){this.temperature=1900,this.tint=-5}setDaylight(){this.temperature=5600,this.tint=0}setCloudyDay(){this.temperature=7500,this.tint=5}setNeonLight(){this.temperature=9e3,this.tint=15}}Object.freeze(ColorTemperatureTint);class Grayscale extends ASinglePassPostEffect{constructor(i){super(i);this.init(i,"POST_EFFECT_GRAYSCALE",createBasicPostEffectCode(this,"let index=vec2(global_id.xy );\nlet dimensions:vec2=textureDimensions(sourceTexture);\nlet dimW=f32(dimensions.x);\nlet dimH=f32(dimensions.y);\nlet uv=vec2(f32(index.x)/dimW,f32(index.y)/dimH);\nvar color:vec4=textureLoad( sourceTexture,index );\nlet gray=(color.r + color.g + color.b)/3.0;\ntextureStore(outputTexture,index,vec4( gray,gray,gray,color.a) );\n",""))}}Object.freeze(Grayscale);class HueSaturation extends ASinglePassPostEffect{#Og=0;#Ng=0;constructor(i){super(i),this.init(i,"POST_EFFECT_HUE_SATURATION",createBasicPostEffectCode(this,"let index=vec2(global_id.xy );\nlet dimensions:vec2=textureDimensions(sourceTexture);\nlet dimW=f32(dimensions.x);\nlet dimH=f32(dimensions.y);\nlet uv=vec2(f32(index.x)/dimW,f32(index.y)/dimH);\nvar color:vec4=textureLoad( sourceTexture,index,);\nlet hue_value:f32=uniforms.hue/180.0;\nlet saturation_value:f32=uniforms.saturation/100.0;\nlet angle:f32=hue_value * 3.1415926535897932384626433832795;\nlet s:f32=sin(angle);\nlet c:f32=cos(angle);\nvar weights:vec3=(vec3(2.0 * c,-sqrt(3.0) * s - c,sqrt(3.0) * s - c) + 1.0)/3.0;\nlet len:f32=length(color.rgb);\ncolor=vec4( vec3( dot(color.rgb,weights.xyz), dot(color.rgb,weights.zxy), dot(color.rgb,weights.yzx) ), color.a\n);\nlet average:f32=(color.r + color.g + color.b)/3.0;\nif (saturation_value > 0.0) { color=vec4( color.rgb + (average - color.rgb) * (1.0 - 1.0/(1.001 - saturation_value)), color.a );\n} else { color=vec4( color.rgb + (average - color.rgb) * (-saturation_value), color.a );\n}\ntextureStore(outputTexture,index,color );\n","struct Uniforms { hue:f32, saturation:f32\n};\n"))}get hue(){return this.#Og}set hue(i){validateNumberRange(i,-180,180),this.#Og=i,this.updateUniform("hue",i)}get saturation(){return this.#Ng}set saturation(i){validateNumberRange(i,-100,100),this.#Ng=i,this.updateUniform("saturation",i)}}Object.freeze(HueSaturation);class Invert extends ASinglePassPostEffect{constructor(i){super(i);this.init(i,"POST_EFFECT_INVERT",createBasicPostEffectCode(this,"let index=vec2(global_id.xy );\nlet dimensions:vec2=textureDimensions(sourceTexture);\nlet dimW=f32(dimensions.x);\nlet dimH=f32(dimensions.y);\nlet uv=vec2(f32(index.x)/dimW,f32(index.y)/dimH);\nvar color:vec4=textureLoad( sourceTexture,index,);\ncolor.r=1.0 - color.r;\ncolor.g=1.0 - color.g;\ncolor.b=1.0 - color.b;\ntextureStore(outputTexture,index,color );\n",""))}}Object.freeze(Invert);class Threshold extends ASinglePassPostEffect{#Vg=128;constructor(i){super(i),this.init(i,"POST_EFFECT_THRESHOLD",createBasicPostEffectCode(this,"let index=vec2(global_id.xy );\nlet dimensions:vec2=textureDimensions(sourceTexture);\nlet dimW=f32(dimensions.x);\nlet dimH=f32(dimensions.y);\nvar color:vec4=textureLoad( sourceTexture,index,);\nlet threshold_value:f32=uniforms.threshold/255.0;\nvar v=0.0;\nif( 0.2126 * color.r + 0.7152 * color.g + 0.0722 * color.b >=threshold_value) { v=1.0;\n}\ncolor=vec4(v,v,v,color.a);\ntextureStore(outputTexture,index,color );\n","struct Uniforms { threshold:f32\n};\n")),this.threshold=this.#Vg}get threshold(){return this.#Vg}set threshold(i){validateNumberRange(i,1,255),this.#Vg=i,this.updateUniform("threshold",i)}}Object.freeze(Threshold);class Vibrance extends ASinglePassPostEffect{#Fg=0;#Ng=0;constructor(i){super(i),this.init(i,"POST_EFFECT_VIBRANCE",createBasicPostEffectCode(this,"let index=vec2(global_id.xy);\nlet dimensions:vec2=textureDimensions(sourceTexture);\nlet dimW=f32(dimensions.x);\nlet dimH=f32(dimensions.y);\nlet uv=vec2(f32(index.x)/dimW,f32(index.y)/dimH);\nvar color:vec4=textureLoad(sourceTexture,index);\nlet originalColor=color;\nlet luminance=0.2126 * color.r + 0.7152 * color.g + 0.0722 * color.b;\nif (uniforms.saturation !=0.0) { let saturationFactor=1.0 + uniforms.saturation * 0.01; color=vec4( mix(luminance,color.r,saturationFactor), mix(luminance,color.g,saturationFactor), mix(luminance,color.b,saturationFactor), color.a );\n}\nif (uniforms.vibrance !=0.0) { let maxComponent=max(max(color.r,color.g),color.b); let minComponent=min(min(color.r,color.g),color.b); let currentSaturation=maxComponent - minComponent; let protectionFactor=1.0/(1.0 + exp(6.0 * (currentSaturation - 0.6))); var skinToneProtection=1.0; if (color.r > color.g && color.g > color.b) { let skinToneAmount=(color.r - color.b)/max(color.r,0.001); skinToneProtection=1.0 - smoothstep(0.3,0.8,skinToneAmount) * 0.7; } let finalProtection=protectionFactor * skinToneProtection; let vibranceStrength=uniforms.vibrance * 0.01 * finalProtection; let vibranceFactor=1.0 + vibranceStrength; color=vec4( mix(luminance,color.r,vibranceFactor), mix(luminance,color.g,vibranceFactor), mix(luminance,color.b,vibranceFactor), color.a );\n}\ncolor=clamp(color,vec4(0.0),vec4(1.0));\ntextureStore(outputTexture,index,color);\n","struct Uniforms { vibrance:f32, saturation:f32\n};\n"))}get vibrance(){return this.#Fg}set vibrance(i){validateNumberRange(i,-100,100),this.#Fg=i,this.updateUniform("vibrance",i)}get saturation(){return this.#Ng}set saturation(i){validateNumberRange(i,-100,100),this.#Ng=i,this.updateUniform("saturation",i)}}Object.freeze(Vibrance);const no=[0,0,0,0,0,1,0,0,0,0,0,0],ro=[0,-1,0,0,-1,5,-1,0,0,-1,0,0],io=[1,1,1,0,1,1,1,0,1,1,1,0],ao=[0,1,0,0,1,-4,1,0,0,1,0,0],so=[-2,-1,0,0,-1,1,1,0,0,1,2,0];class Convolution extends ASinglePassPostEffect{static NORMAL=no;static SHARPEN=ro;static BLUR=io;static EDGE=ao;static EMBOSE=so;#Hg=io;constructor(i){super(i),this.init(i,"POST_EFFECT_CONVOLUTION",createBasicPostEffectCode(this,"let index=vec2(global_id.xy );\nlet dimensions:vec2=textureDimensions(sourceTexture);\nlet dimW=f32(dimensions.x);\nlet dimH=f32(dimensions.y);\nlet perPX=vec2(1.0/dimW,1.0/dimH);\nlet uv=vec2(f32(index.x)/dimW,f32(index.y)/dimH);\nvar color:vec4=vec4(0.0);\nlet kernelWeight_value:f32=uniforms.kernelWeight;\nlet kernel_value:mat3x3=uniforms.kernel;\ncolor +=textureLoad(sourceTexture,index + vec2(-1,-1)) * kernel_value[0][0];\ncolor +=textureLoad(sourceTexture,index + vec2(0,-1)) * kernel_value[0][1];\ncolor +=textureLoad(sourceTexture,index + vec2(1,-1)) * kernel_value[0][2];\ncolor +=textureLoad(sourceTexture,index + vec2(-1,0)) * kernel_value[1][0];\ncolor +=textureLoad(sourceTexture,index + vec2(0,0)) * kernel_value[1][1];\ncolor +=textureLoad(sourceTexture,index + vec2(1,0)) * kernel_value[1][2];\ncolor +=textureLoad(sourceTexture,index + vec2(-1,1)) * kernel_value[2][0];\ncolor +=textureLoad(sourceTexture,index + vec2(0,1)) * kernel_value[2][1];\ncolor +=textureLoad(sourceTexture,index + vec2(1,1)) * kernel_value[2][2];\ntextureStore(outputTexture,index,color/kernelWeight_value );\n","struct Uniforms { kernelWeight:f32, kernel:mat3x3\n};\n")),this.kernel=this.#Hg}get kernel(){return this.#Hg}set kernel(i){this.#Hg=i;let g=0;for(const i in this.#Hg)g+=this.#Hg[i];this.updateUniform("kernelWeight",g),this.updateUniform("kernel",i)}}Object.freeze(Convolution);class Blur extends AMultiPassPostEffect{#zg;constructor(i){super(i,[new Convolution(i)]),this.#zg=this.passList[0],this.#zg.kernel=Convolution.BLUR}render(i,g,x,_){return this.#zg.render(i,g,x,_)}}Object.freeze(Blur);class DirectionalBlur extends ASinglePassPostEffect{#$g=15;#Kg=0;constructor(i){super(i),this.init(i,"POST_EFFECT_DIRECTIONAL_BLUR",createBasicPostEffectCode(this,"let dimensions=textureDimensions(sourceTexture);\nlet dimW=f32(dimensions.x);\nlet dimH=f32(dimensions.y);\nlet direction=vec2(uniforms.directionX,uniforms.directionY);\nlet dirLength=length(direction);\nlet normalizedDir=select(vec2(0.0),direction/dirLength,dirLength > 0.0);\nlet dir=normalizedDir * uniforms.amount;\nconst loopSize=30.0;\nlet offset=random(global_id,0.0);\nlet global_id_vec=vec2(f32(global_id.x),f32(global_id.y));\nvar sum=vec4(0.0,0.0,0.0,0.0);\nvar total=0.0;\nfor (var t=-loopSize;t <=loopSize;t=t + 1.0) { var percent=1.0 - (t + offset - 0.5)/loopSize; var weight=3.0 * (percent - percent * percent); let deltaPercent=dir * percent; let delta=vec2( i32(clamp(global_id_vec.x + deltaPercent.x,0.0,dimW - 1.0)), i32(clamp(global_id_vec.y + deltaPercent.y,0.0,dimH - 1.0)) ); sum +=textureLoad(sourceTexture,delta).xyzw * weight; total +=weight;\n}\ntextureStore(outputTexture,vec2(global_id.xy),sum/total);\n","struct Uniforms { amount:f32, directionX:f32, directionY:f32\n};\nfn random(id:vec3,delta:f32) -> f32 { let seed:u32=((id.x << 16) | (id.y & 0xFFFF)) ^ (id.z * 0x63641362); let t:vec3=vec3(f32(seed & 0xFF),f32((seed >> 8) & 0xFF),f32(seed >> 16)); return delta + fract(sin(dot(t,vec3(12.9898,78.233,12.9898))) * 43758.5453);\n}\n")),this.amount=this.#$g,this.angle=this.#Kg}get angle(){return this.#Kg}set angle(i){validateNumber(i),this.#Kg=i%360,this.#Xg()}get amount(){return this.#$g}set amount(i){validateNumberRange(i,0),this.#$g=i,this.updateUniform("amount",i)}#Xg(){const i=this.#Kg*Math.PI/180,g=Math.cos(i),x=Math.sin(i);this.updateUniform("directionX",g),this.updateUniform("directionY",x)}}Object.freeze(DirectionalBlur);class RadialBlur extends ASinglePassPostEffect{#$g=50;#if=0;#af=0;#jg=16;constructor(i){super(i),this.init(i,"POST_EFFECT_RADIAL_BLUR",createBasicPostEffectCode(this,"let dimensions=textureDimensions(sourceTexture);\nlet dimW=f32(dimensions.x);\nlet dimH=f32(dimensions.y);\nlet center=vec2(dimW * 0.5 + uniforms.centerX,dimH * 0.5 + uniforms.centerY);\nlet global_id_vec=vec2(f32(global_id.x),f32(global_id.y));\nlet toPixel=global_id_vec - center;\nlet distance=length(toPixel);\nlet angle=atan2(toPixel.y,toPixel.x);\nlet maxDist=min(dimW,dimH) * 0.5;\nlet normalizedDistance=distance/maxDist;\nlet rotationAngle=uniforms.amount * normalizedDistance * 0.001;\nlet sampleCount=i32(uniforms.sampleCount);\nvar sum=vec4(0.0,0.0,0.0,0.0);\nvar totalWeight=0.0;\nfor (var i=0;i < sampleCount;i=i + 1) { let t=f32(i)/f32(sampleCount - 1); let sampleAngle=angle + (t - 0.5) * rotationAngle; let samplePos=center + vec2( cos(sampleAngle) * distance, sin(sampleAngle) * distance ); var weight=1.0 - abs(t - 0.5) * 1.5; weight=max(weight,0.1); let sampleCoord=vec2( i32(clamp(samplePos.x,0.0,dimW - 1.0)), i32(clamp(samplePos.y,0.0,dimH - 1.0)) ); sum +=textureLoad(sourceTexture,sampleCoord).xyzw * weight; totalWeight +=weight;\n}\nlet centerFalloff=smoothstep(0.0,maxDist * 0.2,distance);\nlet originalColor=textureLoad(sourceTexture,vec2(global_id.xy)).xyzw;\nlet blurredColor=sum/totalWeight;\nlet finalColor=mix(originalColor,blurredColor,centerFalloff);\ntextureStore(outputTexture,vec2(global_id.xy),finalColor);\n","struct Uniforms { amount:f32, centerX:f32, centerY:f32, sampleCount:f32\n};\n")),this.amount=this.#$g,this.sampleCount=this.#jg}get centerX(){return this.#if}set centerX(i){validateNumber(i),this.#if=i,this.updateUniform("centerX",i)}get centerY(){return this.#af}set centerY(i){validateNumber(i),this.#af=i,this.updateUniform("centerY",i)}get amount(){return this.#$g}set amount(i){validateNumberRange(i,0),this.#$g=i,this.updateUniform("amount",i)}get sampleCount(){return this.#jg}set sampleCount(i){validateNumberRange(i,4),this.#jg=i,this.updateUniform("sampleCount",i)}}Object.freeze(RadialBlur);class ZoomBlur extends ASinglePassPostEffect{#$g=64;#if=0;#af=0;constructor(i){super(i),this.init(i,"POST_EFFECT_ZOOM_BLUR",createBasicPostEffectCode(this,"let dimensions=textureDimensions(sourceTexture);\nlet dimW=f32(dimensions.x);\nlet dimH=f32(dimensions.y);\nlet dimensionsVec=vec2(dimW,dimH);\nlet amount=uniforms.amount/min(dimW,dimH);\nconst loopSize=30.0;\nlet offset=random(global_id,0.0);\nlet center=vec2(dimW * 0.5 + uniforms.centerX,dimH * 0.5 + uniforms.centerY);\nlet global_id_vec=vec2(f32(global_id.x),f32(global_id.y));\nlet dir=(center - global_id_vec) * amount;\nvar sum=vec4(0.0,0.0,0.0,0.0);\nvar total=0.0;\nfor (var t=-loopSize;t <=loopSize;t=t + 1.0) { var percent=1.0 - (t + offset - 0.5)/loopSize; var weight=3.0 * (percent - percent * percent); let deltaPercent=dir * percent; let delta=vec2( i32(clamp(global_id_vec.x + deltaPercent.x,0.0,dimW - 1.0)), i32(clamp(global_id_vec.y + deltaPercent.y,0.0,dimH - 1.0)) ); sum +=textureLoad(sourceTexture,delta).xyzw * weight; total +=weight;\n}\ntextureStore(outputTexture,vec2(global_id.xy),sum/total);\n","struct Uniforms { amount:f32, centerX:f32, centerY:f32\n};\nfn random(id:vec3,delta:f32) -> f32 { let seed:u32=((id.x << 16) | (id.y & 0xFFFF)) ^ (id.z * 0x63641362); let t:vec3=vec3(f32(seed & 0xFF),f32((seed >> 8) & 0xFF),f32(seed >> 16)); return delta + fract(sin(dot(t,vec3(12.9898,78.233,12.9898))) * 43758.5453);\n}\n")),this.amount=this.#$g}get centerX(){return this.#if}set centerX(i){validateNumber(i),this.#if=i,this.updateUniform("centerX",i)}get centerY(){return this.#af}set centerY(i){validateNumber(i),this.#af=i,this.updateUniform("centerY",i)}get amount(){return this.#$g}set amount(i){validateNumberRange(i,0),this.#$g=i,this.updateUniform("amount",i)}}Object.freeze(ZoomBlur);const oo={filmGrainIntensity:.02,filmGrainResponse:.9,filmGrainScale:2.5,coloredGrain:.3,grainSaturation:.4},uo={filmGrainIntensity:.05,filmGrainResponse:.8,filmGrainScale:3,coloredGrain:.5,grainSaturation:.6},lo={filmGrainIntensity:.12,filmGrainResponse:.6,filmGrainScale:4,coloredGrain:.7,grainSaturation:.8},co={filmGrainIntensity:.08,filmGrainResponse:.7,filmGrainScale:5,coloredGrain:.9,grainSaturation:1};class FilmGrain extends ASinglePassPostEffect{static SUBTLE=oo;static MEDIUM=uo;static HEAVY=lo;static VINTAGE=co;#Yg=lo.filmGrainIntensity;#qg=lo.filmGrainResponse;#Wg=lo.filmGrainScale;#Zg=lo.coloredGrain;#Jg=lo.grainSaturation;#Lm=0;#Qg=1;constructor(i){super(i),this.#Qg=window?.devicePixelRatio||1,this.init(i,"POST_EFFECT_FILM_GRAIN",createBasicPostEffectCode(this,"let index=vec2(global_id.xy);\nlet dimensions:vec2=textureDimensions(sourceTexture);\nlet dimW=f32(dimensions.x);\nlet dimH=f32(dimensions.y);\nlet uv=vec2(f32(index.x)/dimW,f32(index.y)/dimH);\nlet originalColor=textureLoad(sourceTexture,index);\nlet filmGrainIntensity_value:f32=uniforms.filmGrainIntensity;\nlet filmGrainResponse_value:f32=uniforms.filmGrainResponse;\nlet filmGrainScale_value:f32=uniforms.filmGrainScale;\nlet coloredGrain_value:f32=uniforms.coloredGrain;\nlet grainSaturation_value:f32=uniforms.grainSaturation;\nlet time_value:f32=uniforms.time;\nlet devicePixelRatio_value:f32=uniforms.devicePixelRatio;\nif (filmGrainIntensity_value <=0.0) { textureStore(outputTexture,index,originalColor); return;\n}\nlet baseScale=max(filmGrainScale_value,0.1);\nlet scaledUV=uv * vec2(dimW,dimH) * devicePixelRatio_value/baseScale;\nlet timeOffset=vec2( fract(time_value * 0.0317) * 100.0, fract(time_value * 0.0271) * 100.0\n);\nlet grainCoord=scaledUV + timeOffset;\nlet sampleOffset=1.0/baseScale;\nlet noiseR=(filmGrainNoise(grainCoord) + filmGrainNoise(grainCoord + vec2(sampleOffset,0.0)) + filmGrainNoise(grainCoord + vec2(0.0,sampleOffset)))/3.0;\nlet noiseG=filmGrainNoise(grainCoord + vec2(127.1,311.7));\nlet noiseB=filmGrainNoise(grainCoord + vec2(269.5,183.3));\nlet monoGrain=(noiseR + noiseG + noiseB)/3.0;\nlet colorGrain=vec3(noiseR,noiseG,noiseB);\nvar grainColor=mix(vec3(monoGrain),colorGrain,coloredGrain_value);\nlet grainLuminance=dot(grainColor,vec3(0.299,0.587,0.114));\ngrainColor=mix(vec3(grainLuminance),grainColor,grainSaturation_value);\nlet luminance=dot(originalColor.rgb,vec3(0.299,0.587,0.114));\nlet luminanceWeight=pow(max(luminance,0.01),filmGrainResponse_value);\nlet grainIntensity=filmGrainIntensity_value * luminanceWeight;\nlet grain=grainColor * grainIntensity;\nlet finalColor=originalColor.rgb + grain;\nlet outputColor=vec4(clamp(finalColor,vec3(0.0),vec3(1.0)),originalColor.a);\ntextureStore(outputTexture,index,outputColor);\n","struct Uniforms { filmGrainIntensity:f32, filmGrainResponse:f32, filmGrainScale:f32, coloredGrain:f32, grainSaturation:f32, time:f32, devicePixelRatio:f32\n};\nfn filmGrainNoise(coord:vec2) -> f32 { let p=floor(coord); let f=fract(coord); let u=f * f * f * (f * (f * 6.0 - 15.0) + 10.0); let a=hash(p); let b=hash(p + vec2(1.0,0.0)); let c=hash(p + vec2(0.0,1.0)); let d=hash(p + vec2(1.0,1.0)); let noise=mix(mix(a,b,u.x),mix(c,d,u.x),u.y); return (noise - 0.5) * 2.0;\n}\nfn hash(p:vec2) -> f32 { var p3=fract(vec3(p.xyx) * 0.1031); p3 +=dot(p3,p3.yzx + 33.33); return fract((p3.x + p3.y) * p3.z);\n}\n")),this.#ex()}get filmGrainIntensity(){return this.#Yg}set filmGrainIntensity(i){this.#Yg=Math.max(0,Math.min(1,i)),this.updateUniform("filmGrainIntensity",this.#Yg)}get filmGrainResponse(){return this.#qg}set filmGrainResponse(i){this.#qg=Math.max(0,Math.min(2,i)),this.updateUniform("filmGrainResponse",this.#qg)}get filmGrainScale(){return this.#Wg}set filmGrainScale(i){this.#Wg=Math.max(.1,Math.min(20,i)),this.updateUniform("filmGrainScale",this.#Wg)}get coloredGrain(){return this.#Zg}set coloredGrain(i){this.#Zg=Math.max(0,Math.min(1,i)),this.updateUniform("coloredGrain",this.#Zg)}get grainSaturation(){return this.#Jg}set grainSaturation(i){this.#Jg=Math.max(0,Math.min(2,i)),this.updateUniform("grainSaturation",this.#Jg)}applyPreset(i){this.#Yg=i.filmGrainIntensity,this.#qg=i.filmGrainResponse,this.#Wg=i.filmGrainScale,this.#Zg=i.coloredGrain,this.#Jg=i.grainSaturation,this.#ex()}update(i){this.#Lm+=i,this.updateUniform("time",this.#Lm)}#ex(){this.updateUniform("filmGrainIntensity",this.#Yg),this.updateUniform("filmGrainResponse",this.#qg),this.updateUniform("filmGrainScale",this.#Wg),this.updateUniform("coloredGrain",this.#Zg),this.updateUniform("grainSaturation",this.#Jg),this.updateUniform("time",this.#Lm),this.updateUniform("devicePixelRatio",this.#Qg)}}Object.freeze(FilmGrain);class Fog extends ASinglePassPostEffect{static EXPONENTIAL=0;static EXPONENTIAL_SQUARED=1;#tx=Fog.EXPONENTIAL;#nx=.05;#rx=4.5;#ix=50;#ax;constructor(i){super(i),this.useDepthTexture=!0,this.init(i,"POST_EFFECT_FOG",createBasicPostEffectCode(this,"let index=vec2(global_id.xy);\nlet coord=vec2(global_id.xy);\nvar sceneColor:vec4=textureLoad(sourceTexture,coord);\nlet depth=textureLoad(depthTexture,coord,0);\nlet linearDepth=linearizeDepth(depth,systemUniforms.camera.nearClipping,systemUniforms.camera.farClipping);\nlet fogFactor=calculateFogFactor(linearDepth,systemUniforms.camera.farClipping);\nlet finalColor=mix(uniforms.fogColor.rgb,sceneColor.rgb,fogFactor);\ntextureStore(outputTexture,coord,vec4(finalColor,sceneColor.a));\n","struct Uniforms { fogType:u32, density:f32, nearDistance:f32, farDistance:f32, fogColor:vec3, padding1:f32,\n};\nfn linearizeDepth(depth:f32,cameraNear:f32,cameraFar:f32) -> f32 { let z=depth * 2.0 - 1.0; return (2.0 * cameraNear * cameraFar)/ (cameraFar + cameraNear - z * (cameraFar - cameraNear));\n}\nfn calculateFogFactor(linearDepth:f32,cameraFar:f32) -> f32 { let u_density=uniforms.density; let u_fogType=uniforms.fogType; let u_nearDistance=uniforms.nearDistance; let u_farDistance=uniforms.farDistance; let isBackground=linearDepth >=(cameraFar * 0.99); if (isBackground) { return 1.0 - u_density; } let distance=max(0.0,linearDepth - u_nearDistance); let maxDistance=u_farDistance - u_nearDistance; let normalizedDistance=clamp(distance/max(0.1,maxDistance),0.0,1.0); var fogFactor:f32; if (u_fogType==0u) { fogFactor=exp(-u_density * normalizedDistance * 10.0); } else { let expValue=u_density * normalizedDistance * 5.0; fogFactor=exp(-(expValue * expValue)); } return clamp(fogFactor,0.0,1.0);\n}\n")),this.#ax=new ColorRGB(178,178,204,()=>{this.updateUniform("fogColor",this.#ax.rgbNormalLinear)}),this.fogType=this.#tx,this.density=this.#nx,this.nearDistance=this.#rx,this.farDistance=this.#ix}get fogType(){return this.#tx}set fogType(i){validateNumberRange(i,0,1),this.#tx=Math.floor(i),this.updateUniform("fogType",this.#tx)}get density(){return this.#nx}set density(i){validateNumberRange(i,0,1),this.#nx=Math.max(0,Math.min(1,i)),this.updateUniform("density",this.#nx)}get nearDistance(){return this.#rx}set nearDistance(i){validateNumberRange(i,0),this.#rx=Math.max(.1,i),this.#ix<=this.#rx&&(this.#ix=this.#rx+.1,this.updateUniform("farDistance",this.#ix)),this.updateUniform("nearDistance",this.#rx)}get farDistance(){return this.#ix}set farDistance(i){validateNumberRange(i,0),this.#ix=Math.max(this.#rx+.1,i),this.updateUniform("farDistance",this.#ix)}get fogColor(){return this.#ax}render(i,g,x,_){return super.render(i,g,x,_)}}Object.freeze(Fog);class HeightFog extends ASinglePassPostEffect{static EXPONENTIAL=0;static EXPONENTIAL_SQUARED=1;#tx=HeightFog.EXPONENTIAL;#nx=1;#ax;#sx=0;#ox=100;#ux=.1;constructor(i){super(i),this.useDepthTexture=!0,this.init(i,"POST_EFFECT_HEIGHT_FOG",createBasicPostEffectCode(this,"let dimensions=textureDimensions(sourceTexture);\nlet dimW=f32(dimensions.x);\nlet dimH=f32(dimensions.y);\nlet global_id_vec=vec2(f32(global_id.x),f32(global_id.y));\nlet screenCoord=vec2( global_id_vec.x/dimW,global_id_vec.y/dimH );\nvar depth:f32=1.0;\nif (dimensions.x > u32(global_id.x) && dimensions.y > u32(global_id.y)) { depth=textureLoad(depthTexture,vec2(global_id.xy),0);\n}\nlet fogFactor=calculateHeightFogFactor(screenCoord,depth);\nlet originalColor=textureLoad(sourceTexture,vec2(global_id.xy)).rgb;\nlet foggedColor=mix(uniforms.fogColor,originalColor,fogFactor);\ntextureStore(outputTexture,vec2(global_id.xy),vec4(foggedColor,1.0));\n","struct Uniforms { fogType:u32, density:f32, baseHeight:f32, falloff:f32, maxHeight:f32, fogColor:vec3, padding1:f32, padding2:f32,\n};\nfn isFiniteValue(value:f32) -> bool { return value==value;\n}\nfn isFiniteVec3(v:vec3) -> bool { return isFiniteValue(v.x) && isFiniteValue(v.y) && isFiniteValue(v.z);\n}\nfn reconstructWorldPositionUltraPrecise(screenCoord:vec2,depth:f32) -> vec3 { let ndcX=fma(screenCoord.x,2.0,-1.0); let ndcY=fma(-screenCoord.y,2.0,1.0); let safeDepth=clamp(depth,1e-7,1.0 - 1e-7); let ndc=vec3(ndcX,ndcY,safeDepth); let clipPos=vec4(ndc,1.0); let worldPos4=systemUniforms.inverseProjectionCameraMatrix * clipPos; let epsilon=1e-6; let w=select(worldPos4.w,epsilon,abs(worldPos4.w) < epsilon); let worldPos=worldPos4.xyz/w; let maxCoord=1e6; let stabilizedX=clamp(worldPos.x,-maxCoord,maxCoord); let stabilizedY=clamp(worldPos.y,-maxCoord,maxCoord); let stabilizedZ=clamp(worldPos.z,-maxCoord,maxCoord); let finalPos=vec3(stabilizedX,stabilizedY,stabilizedZ); return select(vec3(0.0,0.0,0.0),finalPos,isFiniteVec3(finalPos));\n}\nfn calculateHeightFogFactor(screenCoord:vec2,depth:f32) -> f32 { let backgroundThreshold=1.0 - 1e-5; let isBackground=depth >=backgroundThreshold; var pixelWorldHeight:f32; if (isBackground) { let rayDirection=getRayDirectionMaxPrecision(screenCoord); pixelWorldHeight=getSkyboxHeightMaxPrecision(rayDirection); } else { let worldPos=reconstructWorldPositionUltraPrecise(screenCoord,depth); pixelWorldHeight=worldPos.y; } return calculateAbsoluteHeightFogMaxPrecision(pixelWorldHeight);\n}\nfn getSkyboxHeightMaxPrecision(rayDirection:vec3) -> f32 { let u_baseHeight=uniforms.baseHeight; let u_maxHeight=uniforms.maxHeight; let rayY=clamp(rayDirection.y,-0.999,0.999); let upThreshold=0.08; let downThreshold=-0.015; let transitionRange=upThreshold - downThreshold; let safeTransitionRange=max(transitionRange,1e-6); if (rayY > upThreshold) { return u_maxHeight + 25.0; } else if (rayY < downThreshold) { return fma(u_maxHeight - u_baseHeight,0.03,u_baseHeight); } else { let normalizedT=(rayY - downThreshold)/safeTransitionRange; let smoothT=smoothstep(0.0,1.0,normalizedT); let lowValue=fma(u_maxHeight - u_baseHeight,0.03,u_baseHeight); let highValue=u_maxHeight + 25.0; return fma(smoothT,highValue - lowValue,lowValue); }\n}\nfn calculateAbsoluteHeightFogMaxPrecision(worldHeight:f32) -> f32 { let u_baseHeight=uniforms.baseHeight; let u_maxHeight=uniforms.maxHeight; let u_density=uniforms.density; let u_falloff=uniforms.falloff; let u_fogType=uniforms.fogType; if (!isFiniteValue(worldHeight)) { return 1.0; } let heightRange=u_maxHeight - u_baseHeight; let safeHeightRange=max(heightRange,1e-3); let margin=fma(safeHeightRange,0.18,1.2); let extendedBaseHeight=u_baseHeight - margin; let extendedMaxHeight=u_maxHeight + margin; let extendedRange=extendedMaxHeight - extendedBaseHeight; if (worldHeight <=extendedBaseHeight || worldHeight >=extendedMaxHeight) { return 1.0; } let safeExtendedRange=max(extendedRange,1e-3); if (safeExtendedRange <=0.3) { return 1.0; } let normalizedHeight=clamp( (worldHeight - extendedBaseHeight)/safeExtendedRange, 0.0, 1.0 ); let centerOffset=normalizedHeight - 0.5; let edgeFactor=fma(-abs(centerOffset),0.25,1.0); let heightFactor=1.0 - normalizedHeight; let safeHeightFactor=max(heightFactor,1e-4); let safeFalloff=clamp(u_falloff,0.05,1.8); let expPower=fma(safeFalloff,0.73,1.05); var fogDensity:f32; if (u_fogType==0u) { fogDensity=pow(safeHeightFactor,expPower); fogDensity=smoothstep(0.0,1.0,fogDensity); } else { let expResult=pow(safeHeightFactor,expPower); fogDensity=expResult * expResult; fogDensity=smoothstep(0.0,1.0,fogDensity); } let densityWithEdge=fogDensity * edgeFactor; let safeDensity=clamp(u_density,0.0,4.0); let finalFogAmount=fma(densityWithEdge,safeDensity,0.0) * 0.42; let result=clamp(1.0 - finalFogAmount,0.0,1.0); return select(1.0,result,isFiniteValue(result));\n}\nfn getRayDirectionMaxPrecision(screenCoord:vec2) -> vec3 { let centeredX=fma(screenCoord.x,1.0,-0.5); let centeredY=fma(screenCoord.y,1.0,-0.5); let ndcX=centeredX * 2.0; let ndcY=-(centeredY * 2.0); let ndc=vec3(ndcX,ndcY,1.0); let clipPos=vec4(ndc,1.0); let worldPos4=systemUniforms.inverseProjectionCameraMatrix * clipPos; let epsilon=1e-6; let w=select(worldPos4.w,epsilon,abs(worldPos4.w) < epsilon); let worldPos=worldPos4.xyz/w; let cameraPos=systemUniforms.camera.cameraPosition; let rayDir=worldPos - cameraPos; let rayLength=length(rayDir); let minLength=1e-6; if (rayLength < minLength) { return vec3(0.0,0.0,1.0); } let normalizedRay=rayDir/rayLength; let safeRayX=clamp(normalizedRay.x,-0.999,0.999); let safeRayY=clamp(normalizedRay.y,-0.999,0.999); let safeRayZ=clamp(normalizedRay.z,-0.999,0.999); let safeRay=vec3(safeRayX,safeRayY,safeRayZ); let finalRayLength=length(safeRay); let isValidRay=finalRayLength > 1e-6 && isFiniteValue(finalRayLength); if (isValidRay) { let finalRay=safeRay/finalRayLength; return select(vec3(0.0,0.0,1.0),finalRay,isFiniteVec3(finalRay)); } return vec3(0.0,0.0,1.0);\n}\n")),this.#ax=new ColorRGB(178,178,204,()=>{this.updateUniform("fogColor",this.#ax.rgbNormal)}),this.fogType=this.#tx,this.density=this.#nx,this.baseHeight=this.#sx,this.thickness=this.#ox,this.falloff=this.#ux}get fogType(){return this.#tx}set fogType(i){validateNumberRange(i,0,1),this.#tx=Math.floor(i),this.updateUniform("fogType",this.#tx)}get density(){return this.#nx}set density(i){validateNumberRange(i,0,5),this.#nx=Math.max(0,Math.min(5,i)),this.updateUniform("density",this.#nx)}get fogColor(){return this.#ax}get baseHeight(){return this.#sx}set baseHeight(i){validateNumberRange(i),this.#sx=i,this.updateUniform("baseHeight",this.#sx),this.updateUniform("maxHeight",this.maxHeight)}get maxHeight(){return this.#sx+this.#ox}get thickness(){return this.#ox}set thickness(i){validateNumberRange(i,.1),this.#ox=Math.max(.1,i),this.updateUniform("maxHeight",this.#sx+this.#ox)}get falloff(){return this.#ux}set falloff(i){validateNumberRange(i,0,2),this.#ux=Math.max(.001,Math.min(2,i)),this.updateUniform("falloff",this.#ux)}render(i,g,x,_){return super.render(i,g,x,_)}}Object.freeze(HeightFog);class ChromaticAberration extends ASinglePassPostEffect{#kg=.015;#if=.5;#af=.5;#ux=1;constructor(i){super(i),this.init(i,"POST_EFFECT_CHROMATIC_ABERRATION",createBasicPostEffectCode(this,"let dimensions=textureDimensions(sourceTexture);\nlet dimW=f32(dimensions.x);\nlet dimH=f32(dimensions.y);\nlet uv=vec2(f32(global_id.x),f32(global_id.y))/vec2(dimW,dimH);\nlet center=vec2(uniforms.centerX,uniforms.centerY);\nlet offset=uv - center;\nlet distance=length(offset);\nlet distortion=uniforms.strength * pow(distance,uniforms.falloff);\nlet redOffset=uv + offset * distortion * vec2(-1.0,-1.0);\nlet greenOffset=uv;\nlet blueOffset=uv + offset * distortion * vec2(1.0,1.0);\nvar finalColor=vec3(0.0);\nif (redOffset.x >=0.0 && redOffset.x <=1.0 && redOffset.y >=0.0 && redOffset.y <=1.0) { let redCoord=vec2( i32(clamp(redOffset.x * dimW,0.0,dimW - 1.0)), i32(clamp(redOffset.y * dimH,0.0,dimH - 1.0)) ); finalColor.r=textureLoad(sourceTexture,redCoord).r;\n}\nlet greenCoord=vec2( i32(clamp(greenOffset.x * dimW,0.0,dimW - 1.0)), i32(clamp(greenOffset.y * dimH,0.0,dimH - 1.0))\n);\nfinalColor.g=textureLoad(sourceTexture,greenCoord).g;\nif (blueOffset.x >=0.0 && blueOffset.x <=1.0 && blueOffset.y >=0.0 && blueOffset.y <=1.0) { let blueCoord=vec2( i32(clamp(blueOffset.x * dimW,0.0,dimW - 1.0)), i32(clamp(blueOffset.y * dimH,0.0,dimH - 1.0)) ); finalColor.b=textureLoad(sourceTexture,blueCoord).b;\n}\nlet originalAlpha=textureLoad(sourceTexture,vec2(global_id.xy)).a;\ntextureStore(outputTexture,vec2(global_id.xy),vec4(finalColor,originalAlpha));\n","struct Uniforms { strength:f32, centerX:f32, centerY:f32, falloff:f32\n};\n")),this.strength=this.#kg,this.centerX=this.#if,this.centerY=this.#af,this.falloff=this.#ux}get strength(){return this.#kg}set strength(i){validateNumberRange(i,0),this.#kg=i,this.updateUniform("strength",i)}get centerX(){return this.#if}set centerX(i){validateNumberRange(i,0,1),this.#if=i,this.updateUniform("centerX",i)}get centerY(){return this.#af}set centerY(i){validateNumberRange(i,0,1),this.#af=i,this.updateUniform("centerY",i)}get falloff(){return this.#ux}set falloff(i){validateNumberRange(i,0,5),this.#ux=i,this.updateUniform("falloff",i)}}Object.freeze(ChromaticAberration);class DOFCoC extends ASinglePassPostEffect{#lx=15;#cx=1.4;#hx=32;#fx=.1;#dx=1e3;constructor(i){super(i),this.useDepthTexture=!0,this.init(i,"POST_EFFECT_DOF_COC",createBasicPostEffectCode(this,"let index=vec2(global_id.xy);\nlet coord=vec2(global_id.xy);\nlet originalColor=textureLoad(sourceTexture,coord).xyzw;\nlet depth=textureLoad(depthTexture,coord,0);\nlet linearDepth=linearizeDepth(depth);\nlet coc=calculateCoC(linearDepth);\nlet encodedCoC=encodeCoC(coc);\ntextureStore(outputTexture,coord,vec4(originalColor.rgb,encodedCoC));\n","struct Uniforms { focusDistance:f32, aperture:f32, maxCoC:f32, nearPlane:f32, farPlane:f32,\n};\nfn linearizeDepth(depth:f32) -> f32 { let z=depth * 2.0 - 1.0; return (2.0 * uniforms.nearPlane * uniforms.farPlane)/ (uniforms.farPlane + uniforms.nearPlane - z * (uniforms.farPlane - uniforms.nearPlane));\n}\nfn encodeCoC(coc:f32) -> f32 { return (coc + 1.0) * 0.5;\n}\nfn calculateCoC(linearDepth:f32) -> f32 { let subjectDistance=linearDepth; let focalLength=50.0; let focusRange=uniforms.focusDistance * 0.15; let transitionRange=uniforms.focusDistance * 0.35; let distanceFromFocus=abs(subjectDistance - uniforms.focusDistance); if (distanceFromFocus < focusRange) { let focusFactor=smoothstep(0.0,focusRange,distanceFromFocus); return mix(0.0,0.02,focusFactor); } var rawCoC:f32; var signedCoC:f32; if (subjectDistance < uniforms.focusDistance) { let nearDistance=uniforms.focusDistance - subjectDistance; let nearFactor=nearDistance/uniforms.focusDistance; rawCoC=(uniforms.aperture * focalLength * nearDistance)/ (subjectDistance * (uniforms.focusDistance - focalLength)); rawCoC=rawCoC * (1.0 + nearFactor * 1.5); signedCoC=-(rawCoC/uniforms.maxCoC); let absCoC=abs(signedCoC); if (absCoC > 0.05) { signedCoC=-min(1.0,absCoC * smoothstep(0.05,0.3,absCoC) * 1.5); } if (distanceFromFocus < transitionRange) { let transitionFactor=smoothstep(focusRange,transitionRange,distanceFromFocus); signedCoC=mix(0.0,signedCoC,transitionFactor); } return clamp(signedCoC,-1.0,0.0); } else { let farDistance=subjectDistance - uniforms.focusDistance; rawCoC=(uniforms.aperture * focalLength * farDistance)/ (subjectDistance * (uniforms.focusDistance + focalLength)); rawCoC=rawCoC * (1.0 + farDistance * 0.08); signedCoC=rawCoC/uniforms.maxCoC; let absCoC=abs(signedCoC); if (absCoC > 0.1) { signedCoC=min(1.0,absCoC * smoothstep(0.1,0.5,absCoC) * 1.2); } if (distanceFromFocus < transitionRange) { let transitionFactor=smoothstep(focusRange,transitionRange,distanceFromFocus); signedCoC=mix(0.0,signedCoC,transitionFactor); } return clamp(signedCoC,0.0,1.0); }\n}\n")),this.focusDistance=this.#lx,this.aperture=this.#cx,this.maxCoC=this.#hx,this.nearPlane=this.#fx,this.farPlane=this.#dx}get focusDistance(){return this.#lx}set focusDistance(i){validateNumberRange(i),this.#lx=i,this.updateUniform("focusDistance",i)}get aperture(){return this.#cx}set aperture(i){validateNumberRange(i),this.#cx=i,this.updateUniform("aperture",i)}get maxCoC(){return this.#hx}set maxCoC(i){validateNumberRange(i),this.#hx=i,this.updateUniform("maxCoC",i)}get nearPlane(){return this.#fx}set nearPlane(i){validateNumberRange(i),this.#fx=i,this.updateUniform("nearPlane",i)}get farPlane(){return this.#dx}set farPlane(i){validateNumberRange(i),this.#dx=i,this.updateUniform("farPlane",i)}}Object.freeze(DOFCoC);class DOFUnified extends ASinglePassPostEffect{#mx=16;#px=24;#gx=1;#xx=1;constructor(i){super(i);const{WORK_SIZE_X:g,WORK_SIZE_Y:x,WORK_SIZE_Z:_}=this,v=` struct Uniforms { nearBlurSize:f32, farBlurSize:f32, nearStrength:f32, farStrength:f32, }; @group(0) @binding(0) var sourceTexture:texture_storage_2d; @group(0) @binding(1) var cocTexture:texture_storage_2d; @group(1) @binding(0) var outputTexture:texture_storage_2d; @group(1) @binding(1) var uniforms:Uniforms; /* CoC 디코딩 함수 */ fn decodeCoC(encoded:f32) -> f32 { /* 0~1 범위를 -1~1 범위로 복원 */ return encoded * 2.0 - 1.0; } @compute @workgroup_size(${g},${x},${_}) fn main (@builtin(global_invocation_id) global_id:vec3) { let index=vec2(global_id.xy); let dimensions:vec2=textureDimensions(sourceTexture); if (index.x >=dimensions.x || index.y >=dimensions.y) { return; } let originalSample=textureLoad(sourceTexture,index); let originalColor=originalSample.rgb; let originalAlpha=originalSample.a; let encodedCoC=textureLoad(cocTexture,index).a; /* CoC 값 디코딩 */ let cocValue=decodeCoC(encodedCoC); /* CoC 임계값 체크 */ if (abs(cocValue) < 0.005) { textureStore(outputTexture,index,vec4(originalColor,originalAlpha)); return; } var finalColor=originalColor; var finalAlpha=originalAlpha; /* Near blur 처리 (CoC < 0) */ if (cocValue < 0.0) { let blurResult=calculateBlur(index,abs(cocValue),uniforms.nearBlurSize,true); let nearBlur=blurResult.rgb; let nearBlurAlpha=blurResult.a; /* Near strength 블렌딩 개선 - 더 강한 효과 */ let nearBlend=saturate(pow(abs(cocValue) * uniforms.nearStrength,0.7)); finalColor=mix(originalColor,nearBlur,nearBlend); finalAlpha=mix(originalAlpha,nearBlurAlpha,nearBlend); } /* Far blur 처리 (CoC > 0) */ else if (cocValue > 0.0) { let blurResult=calculateBlur(index,cocValue,uniforms.farBlurSize,false); let farBlur=blurResult.rgb; let farBlurAlpha=blurResult.a; let rawBlend=cocValue * uniforms.farStrength; let farBlend=saturate(smoothstep(0.0,0.8,rawBlend)); finalColor=mix(originalColor,farBlur,farBlend); finalAlpha=mix(originalAlpha,farBlurAlpha,farBlend); } textureStore(outputTexture,index,vec4(finalColor,finalAlpha)); } fn calculateBlur(center:vec2,intensity:f32,maxBlurSize:f32,isNear:bool) -> vec4 { let dimensions:vec2=textureDimensions(sourceTexture); let blurRadius=intensity * maxBlurSize; /* 최소 블러 반경 조정 */ if (blurRadius < 0.3) { return textureLoad(sourceTexture,center); } var sum:vec3=vec3(0.0); var sumAlpha:f32=0.0; var totalWeight=0.0; let maxRadius=min(blurRadius,maxBlurSize); /* Near blur에 더 많은 샘플 적용 */ let samples=select(8,16,isNear);/* near=16,far=8 */ let angleStep=6.28318530718/f32(samples); let originalSample=textureLoad(sourceTexture,center); let originalColor=originalSample.rgb; let originalAlpha=originalSample.a; /* Near blur에 더 강한 중앙 가중치 */ let centerWeight=select(0.4,0.2,isNear);/* near=0.2,far=0.4 */ sum +=originalColor * centerWeight; sumAlpha +=originalAlpha * centerWeight; totalWeight +=centerWeight; /* 방사형 샘플링 */ for (var i=0;i < samples;i=i + 1) { for (var r=1.0;r <=maxRadius;r=r + 1.0) { let angle=f32(i) * angleStep; let offset=vec2(cos(angle) * r,sin(angle) * r); let samplePos=vec2( clamp(i32(f32(center.x) + offset.x),0,i32(dimensions.x) - 1), clamp(i32(f32(center.y) + offset.y),0,i32(dimensions.y) - 1) ); let sampleData=textureLoad(sourceTexture,vec2(samplePos)); let sampleColor=sampleData.rgb; let sampleAlpha=sampleData.a; let sampleEncodedCoC=textureLoad(cocTexture,vec2(samplePos)).a; let sampleCoC=decodeCoC(sampleEncodedCoC);/* 디코딩 추가 */ /* 가우시안 가중치 */ var weight=exp(-r * r/(maxRadius * maxRadius * 0.5)); /* CoC 기반 가중치 조정 */ if (isNear) { /* Near blur:더 강한 조건으로 가중치 증가 */ if (sampleCoC < 0.0 && abs(sampleCoC) >=intensity * 0.5) { weight *=1.5; } } else { /* Far blur:기존 조건 유지 */ if (sampleCoC > 0.0 && sampleCoC >=intensity * 0.7) { weight *=1.2; } } sum +=sampleColor * weight; sumAlpha +=sampleAlpha * weight; totalWeight +=weight; } } /* 추가 근거리 샘플링 (near blur만) */ if (isNear && maxRadius > 2.0) { let additionalSamples=8; let innerRadius=maxRadius * 0.3; let innerAngleStep=6.28318530718/f32(additionalSamples); for (var i=0;i < additionalSamples;i=i + 1) { let angle=f32(i) * innerAngleStep + 0.5;/* 약간의 오프셋 */ let offset=vec2(cos(angle) * innerRadius,sin(angle) * innerRadius); let samplePos=vec2( clamp(i32(f32(center.x) + offset.x),0,i32(dimensions.x) - 1), clamp(i32(f32(center.y) + offset.y),0,i32(dimensions.y) - 1) ); let sampleData=textureLoad(sourceTexture,vec2(samplePos)); let sampleColor=sampleData.rgb; let sampleAlpha=sampleData.a; let weight=0.8; sum +=sampleColor * weight; sumAlpha +=sampleAlpha * weight; totalWeight +=weight; } } if (totalWeight > 0.0) { return vec4(sum/totalWeight,sumAlpha/totalWeight); } else { return vec4(originalColor,originalAlpha); } } `;this.init(i,"POST_EFFECT_DOF_UNIFIED",{msaa:v,nonMsaa:v}),this.nearBlurSize=this.#mx,this.farBlurSize=this.#px,this.nearStrength=this.#gx,this.farStrength=this.#xx}get nearBlurSize(){return this.#mx}set nearBlurSize(i){validateNumberRange(i),this.#mx=i,this.updateUniform("nearBlurSize",i)}get farBlurSize(){return this.#px}set farBlurSize(i){validateNumberRange(i),this.#px=i,this.updateUniform("farBlurSize",i)}get nearStrength(){return this.#gx}set nearStrength(i){validateNumberRange(i),this.#gx=i,this.updateUniform("nearStrength",i)}get farStrength(){return this.#xx}set farStrength(i){validateNumberRange(i),this.#xx=i,this.updateUniform("farStrength",i)}render(i,g,x,_,v){return super.render(i,g,x,_,v)}}Object.freeze(DOFUnified);class DOF extends AMultiPassPostEffect{#_x;#vx;#lx=15;#cx=2.8;#hx=25;#fx=.1;#dx=1e3;#mx=15;#px=15;#gx=1;#xx=1;constructor(i){super(i,[new DOFCoC(i),new DOFUnified(i)]),this.#_x=this.passList[0],this.#vx=this.passList[1],this.#_x.focusDistance=this.#lx,this.#_x.aperture=this.#cx,this.#_x.maxCoC=this.#hx,this.#_x.nearPlane=this.#fx,this.#_x.farPlane=this.#dx,this.#vx.nearBlurSize=this.#mx,this.#vx.farBlurSize=this.#px,this.#vx.nearStrength=this.#gx,this.#vx.farStrength=this.#xx}get focusDistance(){return this.#lx}set focusDistance(i){this.#lx=i,this.#_x.focusDistance=i}get aperture(){return this.#cx}set aperture(i){this.#cx=i,this.#_x.aperture=i}get maxCoC(){return this.#hx}set maxCoC(i){this.#hx=i,this.#_x.maxCoC=i}get nearPlane(){return this.#fx}set nearPlane(i){this.#fx=i,this.#_x.nearPlane=i}get farPlane(){return this.#dx}set farPlane(i){this.#dx=i,this.#_x.farPlane=i}get nearBlurSize(){return this.#mx}set nearBlurSize(i){this.#mx=i,this.#vx.nearBlurSize=i}get farBlurSize(){return this.#px}set farBlurSize(i){this.#px=i,this.#vx.farBlurSize=i}get nearStrength(){return this.#gx}set nearStrength(i){this.#gx=i,this.#vx.nearStrength=i}get farStrength(){return this.#xx}set farStrength(i){this.#xx=i,this.#vx.farStrength=i}setGameDefault(){this.focusDistance=15,this.aperture=2.8,this.maxCoC=25,this.nearBlurSize=15,this.farBlurSize=15,this.nearStrength=1,this.farStrength=1}setCinematic(){this.focusDistance=20,this.aperture=1.4,this.maxCoC=40,this.nearBlurSize=25,this.farBlurSize=30,this.nearStrength=1.2,this.farStrength=1.3}setPortrait(){this.focusDistance=8,this.aperture=1.8,this.maxCoC=35,this.nearBlurSize=12,this.farBlurSize=25,this.nearStrength=.8,this.farStrength=1.4}setLandscape(){this.focusDistance=50,this.aperture=8,this.maxCoC=20,this.nearBlurSize=20,this.farBlurSize=10,this.nearStrength=1.1,this.farStrength=.6}setMacro(){this.focusDistance=2,this.aperture=1,this.maxCoC=50,this.nearBlurSize=30,this.farBlurSize=35,this.nearStrength=1.5,this.farStrength=1.6}setSports(){this.focusDistance=25,this.aperture=4,this.maxCoC=18,this.nearBlurSize=10,this.farBlurSize=12,this.nearStrength=.8,this.farStrength=.9}setNightMode(){this.focusDistance=12,this.aperture=2,this.maxCoC=30,this.nearBlurSize=18,this.farBlurSize=20,this.nearStrength=1.1,this.farStrength=1.2}render(i,g,x,_){const v=this.#_x.render(i,g,x,_);return this.#vx.render(i,g,x,_,v)}}Object.freeze(DOF);class LensDistortion extends ASinglePassPostEffect{#bx=.1;#yx=0;#if=0;#af=0;constructor(i){super(i),this.init(i,"POST_EFFECT_LENS_DISTORTION",createBasicPostEffectCode(this,"let dimensions=textureDimensions(sourceTexture);\nlet dimW=f32(dimensions.x);\nlet dimH=f32(dimensions.y);\nlet center=vec2(dimW * 0.5 + uniforms.centerX,dimH * 0.5 + uniforms.centerY);\nlet global_id_vec=vec2(f32(global_id.x),f32(global_id.y));\nlet uv=global_id_vec/vec2(dimW,dimH);\nlet uvCenter=center/vec2(dimW,dimH);\nlet offset=uv - uvCenter;\nlet distance=length(offset);\nlet barrelFactor=1.0 + uniforms.barrelStrength * distance * distance;\nlet pincushionFactor=1.0 - uniforms.pincushionStrength * distance * distance;\nlet distortionFactor=barrelFactor * pincushionFactor;\nlet distortedUV=uvCenter + offset * distortionFactor;\nif (distortedUV.x < 0.0 || distortedUV.x > 1.0 || distortedUV.y < 0.0 || distortedUV.y > 1.0) { textureStore(outputTexture,vec2(global_id.xy),vec4(0.0,0.0,0.0,1.0));\n} else { let sampleCoord=vec2( i32(clamp(distortedUV.x * dimW,0.0,dimW - 1.0)), i32(clamp(distortedUV.y * dimH,0.0,dimH - 1.0)) ); let sampledColor=textureLoad(sourceTexture,sampleCoord).xyzw; textureStore(outputTexture,vec2(global_id.xy),sampledColor);\n}\n","struct Uniforms { barrelStrength:f32, pincushionStrength:f32, centerX:f32, centerY:f32\n};\n")),this.barrelStrength=this.#bx,this.pincushionStrength=this.#yx,this.centerX=this.#if,this.centerY=this.#af}get barrelStrength(){return this.#bx}set barrelStrength(i){validateNumberRange(i,0),this.#bx=i,this.updateUniform("barrelStrength",i)}get pincushionStrength(){return this.#yx}set pincushionStrength(i){validateNumberRange(i,0),this.#yx=i,this.updateUniform("pincushionStrength",i)}get centerX(){return this.#if}set centerX(i){validateNumber(i),this.#if=i,this.updateUniform("centerX",i)}get centerY(){return this.#af}set centerY(i){validateNumber(i),this.#af=i,this.updateUniform("centerY",i)}}Object.freeze(LensDistortion);class Vignetting extends ASinglePassPostEffect{#Sx=.2;#Qt=.5;constructor(i){super(i),this.init(i,"POST_EFFECT_VIGNETTING",createBasicPostEffectCode(this,"let dimensions=textureDimensions(sourceTexture);\nlet dimW=f32(dimensions.x);\nlet dimH=f32(dimensions.y);\nlet index=vec2(global_id.xy);\nlet uv=vec2(f32(index.x)/dimW,f32(index.y)/dimH);\nlet smoothness=uniforms.smoothness;\nlet size=uniforms.size;\nvar color:vec4=textureLoad(sourceTexture,index);\nvar diff=size - distance(uv,vec2(0.5));\nlet vignette=smoothstep(-smoothness,smoothness,diff);\ncolor.r *=vignette;\ncolor.g *=vignette;\ncolor.b *=vignette;\ntextureStore(outputTexture,index,color);\n","struct Uniforms { smoothness:f32, size:f32,\n};\n")),this.smoothness=this.#Sx,this.size=this.#Qt}get size(){return this.#Qt}set size(i){validateNumberRange(i,0),this.#Qt=i,this.updateUniform("size",i)}get smoothness(){return this.#Sx}set smoothness(i){validateNumberRange(i,0,1),this.#Sx=i,this.updateUniform("smoothness",i)}}Object.freeze(Vignetting);class OldBloomBlend extends ASinglePassPostEffect{#Tx=1;#pc=1;constructor(i){super(i);const{WORK_SIZE_X:g,WORK_SIZE_Y:x,WORK_SIZE_Z:_}=this,v=` struct Uniforms { bloomStrength:f32, exposure:f32 }; @group(0) @binding(0) var sourceTexture0:texture_storage_2d; @group(0) @binding(1) var sourceTexture1:texture_storage_2d; @group(1) @binding(0) var outputTexture:texture_storage_2d; @group(1) @binding(1) var uniforms:Uniforms; @compute @workgroup_size(${g},${x},${_}) fn main ( @builtin(global_invocation_id) global_id:vec3, ){ let index=vec2(global_id.xy ); let dimensions:vec2=textureDimensions(sourceTexture0); let dimW=f32(dimensions.x); let dimH=f32(dimensions.y); let uv=\tvec2(f32(index.x)/dimW,f32(index.y)/dimH); var diffuse:vec4=textureLoad( sourceTexture0, index, ); var blur:vec4=textureLoad( sourceTexture1, index, ); let finalColor=vec4((diffuse.rgb + blur.rgb * uniforms.bloomStrength ) * uniforms.exposure,diffuse.a); textureStore(outputTexture,index,finalColor ); }; `;this.init(i,"POST_EFFECT_OLD_BLOOM",{msaa:v,nonMsaa:v}),this.exposure=this.#pc,this.bloomStrength=this.#Tx}get bloomStrength(){return this.#Tx}set bloomStrength(i){this.#Tx=i,this.updateUniform("bloomStrength",i)}get exposure(){return this.#pc}set exposure(i){this.#pc=i,this.updateUniform("exposure",i)}render(i,g,x,_,v){return super.render(i,g,x,_,v)}}Object.freeze(OldBloomBlend);class OldBloom extends AMultiPassPostEffect{#Mx;#wx;#Cx;#Vg=156;#Rx=32;#pc=1;#Tx=1.2;constructor(i){super(i,[new Threshold(i),new GaussianBlur(i),new OldBloomBlend(i)]),this.#Mx=this.passList[0],this.#wx=this.passList[1],this.#Cx=this.passList[2],this.#Mx.threshold=this.#Vg,this.#wx.size=this.#Rx,this.#Cx.exposure=this.#pc,this.#Cx.bloomStrength=this.#Tx}get threshold(){return this.#Vg}set threshold(i){this.#Vg=i,this.#Mx.threshold=i}get gaussianBlurSize(){return this.#Rx}set gaussianBlurSize(i){this.#Rx=i,this.#wx.size=i}get exposure(){return this.#pc}set exposure(i){this.#pc=i,this.#Cx.exposure=i}get bloomStrength(){return this.#Tx}set bloomStrength(i){this.#Tx=i,this.#Cx.bloomStrength=i}render(i,g,x,_){const v=this.#Mx.render(i,g,x,_),b=this.#wx.render(i,g,x,v);return this.#Cx.render(i,g,x,_,b)}}Object.freeze(OldBloom);class Sharpen extends AMultiPassPostEffect{#zg;constructor(i){super(i,[new Convolution(i)]),this.#zg=this.passList[0],this.#zg.kernel=Convolution.SHARPEN}render(i,g,x,_){return this.#zg.render(i,g,x,_)}}Object.freeze(Sharpen);var ho=Object.freeze({__proto__:null,AMultiPassPostEffect:AMultiPassPostEffect,ASinglePassPostEffect:ASinglePassPostEffect,createBasicPostEffectCode:createBasicPostEffectCode}),fo=Object.freeze({__proto__:null,Blur:Blur,BlurX:BlurX,BlurY:BlurY,BrightnessContrast:BrightnessContrast,ChromaticAberration:ChromaticAberration,ColorBalance:ColorBalance,ColorTemperatureTint:ColorTemperatureTint,Convolution:Convolution,Core:ho,DOF:DOF,DirectionalBlur:DirectionalBlur,FilmGrain:FilmGrain,Fog:Fog,GaussianBlur:GaussianBlur,Grayscale:Grayscale,HeightFog:HeightFog,HueSaturation:HueSaturation,Invert:Invert,LensDistortion:LensDistortion,OldBloom:OldBloom,PostEffectManager:PostEffectManager,RadialBlur:RadialBlur,Sharpen:Sharpen,Threshold:Threshold,Vibrance:Vibrance,Vignetting:Vignetting,ZoomBlur:ZoomBlur}),mo=Object.freeze({__proto__:null,PICKING_EVENT_TYPE:i,PickingEvent:PickingEvent,PickingManager:PickingManager,Raycaster2D:Raycaster2D,Raycaster3D:Raycaster3D}),po=Object.freeze({__proto__:null,BlendState:BlendState,DepthStencilState:DepthStencilState,PrimitiveState:PrimitiveState}),go=Object.freeze({__proto__:null,TONE_MAPPING_MODE:qi,ToneMappingManager:ToneMappingManager}),xo=Object.freeze({__proto__:null,DirectionalShadowManager:DirectionalShadowManager,ShadowManager:ShadowManager}),_o=Object.freeze({__proto__:null,AntialiasingManager:AntialiasingManager,FXAA:FXAA,TAA:TAA,TAASharpen:TAASharpen});var vo=Object.freeze({__proto__:null,PHYSICS_BODY_TYPE:{DYNAMIC:"dynamic",STATIC:"static",KINEMATIC:"kinematic",KINEMATIC_POSITION:"kinematicPosition",KINEMATIC_VELOCITY:"kinematicVelocity"},PHYSICS_SHAPE:{BOX:"box",SPHERE:"sphere",CAPSULE:"capsule",CYLINDER:"cylinder",HEIGHTFIELD:"heightfield",MESH:"mesh"}});export{_o as Antialiasing,ua as Bound,_a as Camera,ya as Color,ba as Context,dr as DefineForFragment,Er as DefineForVertex,gs as Display,GLTFLoader,_ as GPU_ADDRESS_MODE,mr as GPU_BLEND_FACTOR,pr as GPU_BLEND_OPERATION,Tn as GPU_COMPARE_FUNCTION,ei as GPU_CULL_MODE,v as GPU_FILTER_MODE,ti as GPU_FRONT_FACE,Dr as GPU_INDEX_FORMAT,H as GPU_LOAD_OP,b as GPU_MIPMAP_FILTER_MODE,Lr as GPU_PRIMITIVE_TOPOLOGY,z as GPU_STORE_OP,Geometry,_s as Light,Ts as Material,vs as Math,vo as Physics,mo as Picking,fo as PostEffect,ys as Primitive,po as RenderState,Renderer,Ns as Resource,to as RuntimeChecker,xo as Shadow,Ke as SystemCode,go as ToneMapping,x as Util,init}; \ No newline at end of file +const consoleAndThrowError=(...i)=>{const g=Array.prototype.slice.call(i).join(" ");throw new Error(g)},validatePositiveNumberRange=(i,g=0,x=Number.MAX_VALUE)=>("number"!=typeof i&&consoleAndThrowError("Only numbers allowed."),"number"!=typeof g&&consoleAndThrowError("Only numbers allowed."),"number"!=typeof x&&consoleAndThrowError("Only numbers allowed."),(g<0||i<0||ix)&&consoleAndThrowError(`Only numbers within the range of [${g},${x}] are allowed.`),!0),isUint=i=>Number.isInteger(i)&&i>=0,validateUintRange=(i,g=0,x=4503599627370496)=>{const _=isUint(i),v=isUint(g),b=isUint(x),y="is not Uint!/value:",S=`(check range:${g}u ~ ${x}u)`;return _||consoleAndThrowError(`value ${y}${i}/${S}`),v||consoleAndThrowError(`min ${y}${g}/${S}`),b||consoleAndThrowError(`max ${y}${x}/${S}`),g>=x&&consoleAndThrowError(`maximum value is bigger than minimum value./${S}`),g>i&&consoleAndThrowError(`value is smaller than minimum value./value:${i}/${S}`),x{const g=/^([A-Fa-f0-9]{3}){1,2}$/;return i.startsWith("#")?g.test(i.substring(1)):!!i.startsWith("0x")&&g.test(i.substring(2))},convertHexToRgb=(i,g=!1)=>{if("number"==typeof i&&(i=`#${i.toString(16)}`),isHexColor(i)){"#"===i.charAt(0)&&(i=i.substring(1)),3===i.length&&(i=i.charAt(0)+i.charAt(0)+i.charAt(1)+i.charAt(1)+i.charAt(2)+i.charAt(2));const x=parseInt("0x"+i),_=x>>16&255,v=x>>8&255,b=255&x;return g?[_,v,b]:{r:_,g:v,b:b}}throw Error(`from ${convertHexToRgb.constructor.name}:input value - ${i}/Only hex string allowed`)},convertRgbToHex=(i,g,x)=>{validateUintRange(i,0,255),validateUintRange(g,0,255),validateUintRange(x,0,255);return`#${i.toString(16).padStart(2,"0").toUpperCase()}${g.toString(16).padStart(2,"0").toUpperCase()}${x.toString(16).padStart(2,"0").toUpperCase()}`};class ColorRGB{#e;#t;#n;#r;constructor(i=255,g=255,x=255,_=void 0){this.#i(i,g,x),this.#a(i,g,x),_&&(this.#r=_)}get r(){return this.#e}set r(i){validateUintRange(i,0,255),this.#e=i,this.#r?.()}get g(){return this.#t}set g(i){validateUintRange(i,0,255),this.#t=i,this.#r?.()}get b(){return this.#n}set b(i){validateUintRange(i,0,255),this.#n=i,this.#r?.()}get rgb(){return[this.#e,this.#t,this.#n]}get rgbNormal(){return[this.#e/255,this.#t/255,this.#n/255]}get rgbNormalLinear(){return[Math.pow(this.#e/255,2.2),Math.pow(this.#t/255,2.2),Math.pow(this.#n/255,2.2)]}get hex(){return convertRgbToHex(this.#e,this.#t,this.#n)}setColorByRGB(i,g,x){this.#i(i,g,x),this.#a(i,g,x)}setColorByHEX(i){const{r:g,g:x,b:_}=convertHexToRgb(i);this.#a(g,x,_)}setColorByRGBString(i){const g=/rgb\s*\(\s*(\d+)\s*,\s*(\d+)\s*,\s*(\d+)\s*\)/.exec(i);g||consoleAndThrowError(`유효하지 않은 rgb 색상 값입니다:${i}`);const[,x,_,v]=g.map(Number);this.#i(x,_,v),this.#a(x,_,v)}#a(i,g,x){this.#e=i,this.#t=g,this.#n=x,this.#r?.()}#i(i,g,x){validateUintRange(i,0,255),validateUintRange(g,0,255),validateUintRange(x,0,255)}}Object.freeze(ColorRGB);class ColorRGBA extends ColorRGB{#s;#r;constructor(i=255,g=255,x=255,_=1,v=void 0){super(i,g,x,v),validatePositiveNumberRange(_,0,1),this.#s=_,v&&(this.#r=v)}get a(){return this.#s}set a(i){validatePositiveNumberRange(i,0,1),this.#s=i,this.#r?.()}get rgba(){return[this.r,this.g,this.b,this.#s]}get rgbaNormal(){return[this.r/255,this.g/255,this.b/255,this.#s]}get rgbaNormalLinear(){return[Math.pow(this.r/255,2.2),Math.pow(this.g/255,2.2),Math.pow(this.b/255,2.2),this.#s]}setColorByRGBA(i,g,x,_){this.#o(i,g,x,_),this.r=i,this.g=g,this.b=x,this.#s=_,this.#r?.()}setColorByRGBAString(i){const g=/rgba\s*\(\s*(\d+)\s*,\s*(\d+)\s*,\s*(\d+)\s*,\s*(\d*(?:\.\d+)?)\s*\)/.exec(i);if(!g)throw new Error(`유효하지 않은 rgba 색상 값입니다:${i}`);const[,x,_,v,b]=g.map(Number);this.#o(x,_,v,b),this.r=x,this.g=_,this.b=v,this.#s=b,this.#r?.()}#o(i,g,x,_){validateUintRange(i,0,255),validateUintRange(g,0,255),validateUintRange(x,0,255),validatePositiveNumberRange(_,0,1)}}const i={MOVE:"move",DOWN:"down",UP:"up",OVER:"over",OUT:"out",CLICK:"click"},copyGPUBuffer=(i,g,x)=>{const _=i.createCommandEncoder({label:"copyGPUBuffer_CommandEncoder"});_.copyBufferToBuffer(g,0,x,0,Math.min(g.size,x.size));const v=_.finish();i.queue.submit([v])},formatBytes=(i,g=2)=>{if(("number"!=typeof i||i<0||Number.isNaN(i)||!Number.isInteger(i))&&consoleAndThrowError("Invalid input:'bytes' must be a uint"),0===i)return"0 Bytes";const x=g<0?0:g,_=Math.floor(Math.log(i)/Math.log(1024));return parseFloat((i/Math.pow(1024,_)).toFixed(x))+" "+["Bytes","KB","MB","GB"][_]};function getAbsoluteURL(i,g){try{return new URL(g,i).href}catch(i){return g}}const getFileExtension=i=>{if(!i||0===i.trim().length)throw new Error("URL must not be empty or undefined");const g=i.split("/"),x=g[g.length-1],_=x.lastIndexOf(".");return-1===_?"":x.substring(_+1).toLowerCase()},getFileName=(i,g=!0)=>{const x=i.substring(i.lastIndexOf("/")+1);return g?x:x.split(".").slice(0,-1).join(".")},getFilePath=i=>{if(!i||0===i.trim().length)throw new Error("URL must not be empty or undefined");return i.substring(0,i.lastIndexOf("/")+1)};function calculateTextureByteSize(i){const g={size:[i.width,i.height,i.depthOrArrayLayers],format:i.format,sampleCount:i.sampleCount,usage:i.usage};return function(i){switch(i){case"r8unorm":case"r8snorm":case"r8uint":case"r8sint":return 1;case"r16uint":case"r16sint":case"r16float":case"rg8unorm":case"rg8snorm":case"rg8uint":case"rg8sint":case"depth16unorm":return 2;case"r32uint":case"r32sint":case"r32float":case"rg16uint":case"rg16sint":case"rg16float":case"rgba8unorm":case"rgba8unorm-srgb":case"rgba8snorm":case"rgba8uint":case"rgba8sint":case"bgra8unorm":case"bgra8unorm-srgb":case"depth24plus":case"depth32float":return 4;case"rg32uint":case"rg32sint":case"rg32float":case"rgba16uint":case"rgba16sint":case"rgba16float":return 8;case"rgba32uint":case"rgba32sint":case"rgba32float":return 16;default:throw new Error(`Unrecognized texture format:${i}`)}}(g.format)*(g.size[0]*g.size[1]*(g.size[2]||1))*(g.sampleCount?g.sampleCount:1)}const getMipLevelCount=(i,g)=>Math.floor(Math.log2(Math.max(i,g)))+1,imageBitmapToGPUTexture=(i,g,x,_=!0)=>{const v=i.createTexture(x);for(let b=0;b{const i="0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz".split("");let g,x=0,_=new Array(36);for(_[8]=_[13]=_[18]=_[23]="-",_[14]="4";x<36;)_[x]||(g=16*Math.random()|0,_[x]=i[19===x?3&g|8:15&g]),x++;return _.join("")};class InstanceIdGenerator{static idMaps=new Map;static getNextId(i){let g=this.idMaps.get(i)||0;return this.idMaps.set(i,g+1),g}}Object.freeze(InstanceIdGenerator);const uuidToUint=i=>{const g=i.replace(/-/g,"").substring(0,8);return parseInt(g,16)},g=console.log.bind(console);var x=Object.freeze({__proto__:null,InstanceIdGenerator:InstanceIdGenerator,calculateTextureByteSize:calculateTextureByteSize,copyGPUBuffer:copyGPUBuffer,copyToTextureArray:function(i,g,x,_){const v=i.createCommandEncoder({label:"COPY_TO_TEXTURE_ARRAY"});v.copyTextureToTexture({texture:g},{texture:x,origin:[0,0,_]},[g.width,g.height,1]),i.queue.submit([v.finish()])},createUUID:createUUID,formatBytes:formatBytes,getAbsoluteURL:getAbsoluteURL,getFileExtension:getFileExtension,getFileName:getFileName,getFilePath:getFilePath,getMipLevelCount:getMipLevelCount,imageBitmapToGPUTexture:imageBitmapToGPUTexture,keepLog:g,loadAndCreateBitmapImage:loadAndCreateBitmapImage,uuidToUint:uuidToUint});const _={CLAMP_TO_EDGE:"clamp-to-edge",REPEAT:"repeat",MIRRORED_REPEAT:"mirror-repeat"};Object.freeze(_);const v={NEAREST:"nearest",LINEAR:"linear"};Object.freeze(v);const b={NEAREST:"nearest",LINEAR:"linear"};Object.freeze(b);const validateRedGPUContext=i=>{if("RedGPUContext"!==i?.constructor?.name){return consoleAndThrowError(`from ${i?.constructor?.name}:requires a RedGPUContext instance,but received:${i}`),!1}return!0};class ResourceBase{#u=createUUID();#l;#c;#h="";#f;#d;#m=[];#p;constructor(i,g){validateRedGPUContext(i),this.#p=g,this.#l=i,this.#c=i.gpuDevice}get cacheKey(){return this.#d}set cacheKey(i){this.#d=i}get resourceManagerKey(){return this.#p}get name(){return this.#f||(this.#f=InstanceIdGenerator.getNextId(this.constructor)),this.#h||`${this.constructor.name} Instance ${this.#f}`}set name(i){this.#h=i}get uuid(){return this.#u}get gpuDevice(){return this.#c}get redGPUContext(){return this.#l}__addDirtyPipelineListener(i){this.#g(!0),this.#m.push(i)}__removeDirtyPipelineListener(i){const g=this.#m.indexOf(i);g>-1&&(this.#m.splice(g,1),this.#g(!1))}__fireListenerList(i=!1){for(const i of this.#m)i(this);i&&(this.#m.length=0)}#g(i){const{resourceManager:g}=this.#l;if("Sampler"!==this.constructor.name&&g){const x=g[this.#p];x||consoleAndThrowError("need managedStateKey",this.constructor.name);const _=x?.table.get(this.cacheKey);_&&(i?_.useNum++:_.useNum--)}}}const y=new Map,S=Object.values(v),w=Object.values(_),L=Object.values(b);class Sampler extends ResourceBase{#x;#_=v.LINEAR;#v=v.LINEAR;#b=b.LINEAR;#y=_.CLAMP_TO_EDGE;#S=_.CLAMP_TO_EDGE;#T=_.REPEAT;#M;#w;#C;#R=1;constructor(i,g){super(i),this.#P(g)}get addressModeU(){return this.#y}set addressModeU(i){this.#B(i,"addressModeU")}get addressModeV(){return this.#S}set addressModeV(i){this.#B(i,"addressModeV")}get addressModeW(){return this.#T}set addressModeW(i){this.#B(i,"addressModeW")}get mipmapFilter(){return this.#b}set mipmapFilter(i){this.#I(i,L,"mipmapFilter")}get gpuSampler(){return this.#x}get magFilter(){return this.#_}set magFilter(i){this.#I(i,S,"magFilter")}get minFilter(){return this.#v}set minFilter(i){this.#I(i,S,"minFilter")}get maxAnisotropy(){return this.#R}set maxAnisotropy(i){validateUintRange(i,1,16),this.#R=i,this.#P()}get isAnisotropyValid(){return!this.#R||"linear"===this.#_&&"linear"===this.#v&&"linear"===this.#b}#E(){this.__fireListenerList()}#B(i,g){if(w.includes(i)){switch(g){case"addressModeU":this.#y=i;break;case"addressModeV":this.#S=i;break;case"addressModeW":this.#T=i}this.#P()}else consoleAndThrowError(`Invalid ${g} value. Must be one of ${w.join(",")},but received:${i}.`)}#I(i,g,x){if(g.includes(i)||null===i){switch(x){case"mipmapFilter":this.#b=i;break;case"magFilter":this.#_=i;break;case"minFilter":this.#v=i}this.#P()}else consoleAndThrowError(`Invalid ${x} value. Must be one of ${g.join(",")},but received:${i}.`)}#D(){return`${this.#_}:${this.#v}:${this.#b}:${this.#y}:${this.#S}:${this.#T}:${this.#M}:${this.#w}:${this.#C}:${this.#R}`}#P(i){i&&(i.magFilter&&(this.#_=i.magFilter),i.minFilter&&(this.#v=i.minFilter),i.mipmapFilter&&(this.#b=i.mipmapFilter),i.addressModeU&&(this.#y=i.addressModeU),i.addressModeV&&(this.#S=i.addressModeV),i.addressModeW&&(this.#T=i.addressModeW),void 0!==i.lodMinClamp&&(this.#M=i.lodMinClamp),void 0!==i.lodMaxClamp&&(this.#w=i.lodMaxClamp),i.compare&&(this.#C=i.compare),i.maxAnisotropy&&(this.#R=i.maxAnisotropy)),this.isAnisotropyValid||1===this.#R||(console.warn(`Invalid maxAnisotropy setting (${this.#R}) detected:magFilter(${this.#_}),minFilter(${this.#v}),mipmapFilter(${this.#b}) must all be set to 'linear' for anisotropic filtering to work. Falling back to default (1).`),this.#R=1);const g=this.#D();if(!y.has(g)){let i={};this.#_&&(i.magFilter=this.#_),this.#v&&(i.minFilter=this.#v),this.#b&&(i.mipmapFilter=this.#b),this.#y&&(i.addressModeU=this.#y),this.#S&&(i.addressModeV=this.#S),this.#T&&(i.addressModeW=this.#T),void 0!==this.#M&&(i.lodMinClamp=this.#M),void 0!==this.#w&&(i.lodMaxClamp=this.#w),this.#C&&(i.compare=this.#C),this.#R&&(i.maxAnisotropy=this.#R),y.set(g,this.redGPUContext.gpuDevice.createSampler(i))}this.#x=y.get(g),this.#E()}}Object.freeze(Sampler);class ManagementResourceBase extends ResourceBase{#U;constructor(i,g){super(i,g),g||consoleAndThrowError("need managedStateKey",this.constructor.name),this.#U=i.resourceManager[g],this.#U||consoleAndThrowError(g,"is not exist in RedGPUContext.resourceManager",this.constructor.name)}get targetResourceManagedState(){return this.#U}}class ResourceStateBitmapTexture{texture;src;cacheKey;useNum=0;uuid;constructor(i){this.texture=i,this.src=i.src,this.cacheKey=i.cacheKey,this.useNum=0,this.uuid=i.uuid}}class BitmapTexture extends ManagementResourceBase{#L;#A;#G;#k;#O;#N=0;#V=!0;#F;#H;#z;constructor(i,g,x=!0,_,v,b,y=!1){if(super(i,"managedBitmapTextureState"),this.#H=_,this.#z=v,this.#V=y,this.#k=x,this.#F=b||`${navigator.gpu.getPreferredCanvasFormat()}-srgb`,g){this.#A=this.#$(g),this.cacheKey=this.#K(g);const{table:i}=this.targetResourceManagedState;let x=i.get(this.cacheKey);if(x){const i=x.texture;return this.#H?.(i),i}this.src=g,this.#X()}}get width(){return this.#O?.width||0}get height(){return this.#O?.height||0}get usePremultiplyAlpha(){return this.#V}get videoMemorySize(){return this.#N}get gpuTexture(){return this.#L}get mipLevelCount(){return this.#G}get src(){return this.#A}set src(i){this.#A=this.#$(i),this.cacheKey=this.#K(i),this.#A&&this.#j(this.#A)}get useMipmap(){return this.#k}set useMipmap(i){this.#k=i,this.#Y()}destroy(){const i=this.#L;this.#q(null),this.__fireListenerList(!0),this.#W(),this.cacheKey=null,this.#A=null,i&&i.destroy()}#K(i){return i?"string"==typeof i?getAbsoluteURL(window.location.href,i):i.cacheKey||getAbsoluteURL(window.location.href,i.src):this.uuid}#$(i){return"string"==typeof i?i:i.src}#q(i){this.#L=i,i||(this.#O=null),this.__fireListenerList()}#X(){this.redGPUContext.resourceManager.registerManagementResource(this,new ResourceStateBitmapTexture(this))}#W(){this.redGPUContext.resourceManager.unregisterManagementResource(this)}#Y(){const{gpuDevice:i,resourceManager:g}=this.redGPUContext,{mipmapGenerator:x}=g;this.#L&&(this.#L.destroy(),this.#L=null),this.targetResourceManagedState.videoMemory-=this.#N,this.#N=0;const{width:_,height:v}=this.#O;this.#G=1;const b={size:[_,v],format:this.#F,usage:GPUTextureUsage.RENDER_ATTACHMENT|GPUTextureUsage.TEXTURE_BINDING|GPUTextureUsage.COPY_DST,label:this.#A};this.#k&&(this.#G=getMipLevelCount(_,v),b.mipLevelCount=this.#G,b.usage|=GPUTextureUsage.RENDER_ATTACHMENT);const y=imageBitmapToGPUTexture(i,[this.#O],b,this.#V);this.#N=calculateTextureByteSize(y),this.targetResourceManagedState.videoMemory+=this.#N,this.#k&&x.generateMipmap(y,b),this.#q(y)}async#Z(i){return new Promise((g,x)=>{const _=new Image;_.src=i,_.onload=()=>{const i=document.createElement("canvas");i.width=_.width||512,i.height=_.height||512;const v=i.getContext("2d");v?(v.fillStyle="rgba(0,0,0,0)",v.fillRect(0,0,i.width,i.height),v.drawImage(_,0,0,i.width,i.height),createImageBitmap(i,{colorSpaceConversion:"none",premultiplyAlpha:this.#V?"premultiply":"none"}).then(g).catch(x)):x(new Error("Canvas context could not be created."))},_.onerror=i=>{x(new Error(`Failed to load SVG:${i}`))}})}async#j(i){try{i.endsWith(".svg")?this.#O=await this.#Z(i):this.#O=await loadAndCreateBitmapImage(i,"none",this.#V?"premultiply":"none"),this.#Y(),this.#H?.(this)}catch(i){console.error(i),this.#z?.(i)}}}Object.freeze(BitmapTexture);class BRDFGenerator{#l;#J;#Q;#ee;constructor(i){this.#l=i}get brdfLUTTexture(){return this.#ee||this.#te(),this.#ee}async#te(){const{gpuDevice:i,resourceManager:g}=this.#l,x="rg16float";this.#ee=g.createManagedTexture({size:[128,128],format:x,usage:GPUTextureUsage.TEXTURE_BINDING|GPUTextureUsage.COPY_DST|GPUTextureUsage.RENDER_ATTACHMENT,label:"BRDF_LUT_Texture"}),this.#J||(this.#J=g.createGPUShaderModule("BRDF_GENERATOR_SHADER_MODULE",{code:"\nconst PI=3.14159265359;\nfn radicalInverse_VdC(bits:u32) -> f32 { var b=bits; b=(b << 16u) | (b >> 16u); b=((b & 0x55555555u) << 1u) | ((b & 0xAAAAAAAAu) >> 1u); b=((b & 0x33333333u) << 2u) | ((b & 0xCCCCCCCCu) >> 2u); b=((b & 0x0F0F0F0Fu) << 4u) | ((b & 0xF0F0F0F0u) >> 4u); b=((b & 0x00FF00FFu) << 8u) | ((b & 0xFF00FF00u) >> 8u); return f32(b) * 2.3283064365386963e-10;\n}\nfn hammersley(i:u32,N:u32) -> vec2 { return vec2(f32(i)/f32(N),radicalInverse_VdC(i));\n}\nfn importanceSampleGGX(Xi:vec2,N:vec3,roughness:f32) -> vec3 { let a=roughness * roughness; let phi=2.0 * PI * Xi.x; let cosTheta=sqrt((1.0 - Xi.y)/(1.0 + (a * a - 1.0) * Xi.y)); let sinTheta=sqrt(1.0 - cosTheta * cosTheta); let H=vec3(cos(phi) * sinTheta,sin(phi) * sinTheta,cosTheta); let up=select(vec3(1.0,0.0,0.0),vec3(0.0,0.0,1.0),abs(N.z) < 0.999); let tangent=normalize(cross(up,N)); let bitangent=cross(N,tangent); return normalize(tangent * H.x + bitangent * H.y + N * H.z);\n}\nfn geometrySchlickGGX(NdotV:f32,roughness:f32) -> f32 { let a=roughness; let k=(a * a)/2.0; let nom=NdotV; let denom=NdotV * (1.0 - k) + k; return nom/denom;\n}\nfn geometrySmith(N:vec3,V:vec3,L:vec3,roughness:f32) -> f32 { let NdotV=max(dot(N,V),0.0); let NdotL=max(dot(N,L),0.0); let ggx2=geometrySchlickGGX(NdotV,roughness); let ggx1=geometrySchlickGGX(NdotL,roughness); return ggx1 * ggx2;\n}\nfn integrateBRDF(in_NdotV:f32,roughness:f32) -> vec2 { let NdotV=max(in_NdotV,0.001); var V:vec3; V.x=sqrt(1.0 - NdotV * NdotV); V.y=0.0; V.z=NdotV; var A=0.0; var B=0.0; let N=vec3(0.0,0.0,1.0); let sampleCount=1024u; for (var i=0u;i < sampleCount;i=i + 1u) { let Xi=hammersley(i,sampleCount); let H=importanceSampleGGX(Xi,N,roughness); let L=normalize(2.0 * dot(V,H) * H - V); let NdotL=max(L.z,0.0); let NdotH=max(H.z,0.0); let VdotH=max(dot(V,H),0.0); if (NdotL > 0.0) { let G=geometrySmith(N,V,L,roughness); let G_Vis=(G * VdotH)/(max(NdotH * NdotV,0.001)); let Fc=pow(1.0 - VdotH,5.0); A=A + (1.0 - Fc) * G_Vis; B=B + Fc * G_Vis; } } return vec2(A,B)/f32(sampleCount);\n}\nstruct VertexOutput { @builtin(position) position:vec4, @location(0) uv:vec2,\n};\n@vertex\nfn vs_main(@builtin(vertex_index) vertexIndex:u32) -> VertexOutput { var pos=array,3>( vec2(-1.0,-1.0), vec2(3.0,-1.0), vec2(-1.0,3.0) ); var output:VertexOutput; output.position=vec4(pos[vertexIndex],0.0,1.0); output.uv=pos[vertexIndex] * 0.5 + 0.5; return output;\n}\n@fragment\nfn fs_main(@location(0) uv:vec2) -> @location(0) vec4 { let integratedBRDF=integrateBRDF(uv.x,1.0 - uv.y); return vec4(integratedBRDF,0.0,1.0);\n}"})),this.#Q||(this.#Q=i.createRenderPipeline({label:"BRDF_GENERATOR_PIPELINE",layout:"auto",vertex:{module:this.#J,entryPoint:"vs_main"},fragment:{module:this.#J,entryPoint:"fs_main",targets:[{format:x}]},primitive:{topology:"triangle-list"}}));const _=i.createCommandEncoder({label:"BRDF_GENERATOR_COMMAND_ENCODER"}),v=_.beginRenderPass({label:"BRDF_GENERATOR_RENDER_PASS",colorAttachments:[{view:this.#ee.createView(),loadOp:"clear",clearValue:{r:0,g:0,b:0,a:1},storeOp:"store"}]});v.setPipeline(this.#Q),v.draw(3),v.end(),i.queue.submit([_.finish()]),await i.queue.onSubmittedWorkDone()}}Object.freeze(BRDFGenerator);class BRDFLUTTexture extends ManagementResourceBase{#L;constructor(i){super(i,"managedBitmapTextureState"),this.#ne()}#ne(){this.#L=this.redGPUContext.resourceManager.brdfGenerator.brdfLUTTexture,this.__fireListenerList()}get gpuTexture(){return this.#L}get videoMemorySize(){return 65536}}Object.freeze(BRDFLUTTexture);class CubeTexture extends ManagementResourceBase{static defaultViewDescriptor={dimension:"cube",aspect:"all",baseMipLevel:0,mipLevelCount:1,baseArrayLayer:0,arrayLayerCount:6};#L;#re;#G;#k;#ie;#N=0;#F;#H;#z;constructor(i,g,x=!0,_,v,b){super(i,"managedCubeTextureState"),this.#H=_,this.#z=v,this.#k=x,this.#F=b||`${navigator.gpu.getPreferredCanvasFormat()}-srgb`,this.#re=this.#$(g),this.cacheKey=this.#K(g);const{table:y}=this.targetResourceManagedState;if(g){let i=y.get(this.cacheKey);if(i){const g=i.texture;return this.#H?.(g),g}this.srcList=g,this.#X()}}get viewDescriptor(){return{...CubeTexture.defaultViewDescriptor,mipLevelCount:this.#G}}get videoMemorySize(){return this.#N}get gpuTexture(){return this.#L}get mipLevelCount(){return this.#G}get srcList(){return this.#re}set srcList(i){this.#re=this.#$(i),this.cacheKey=this.#K(i),this.#re?.length&&this.#j(this.#re)}get useMipmap(){return this.#k}set useMipmap(i){this.#k=i,this.#Y()}destroy(){const i=this.#L;this.#q(null),this.__fireListenerList(!0),this.#W(),this.#re=null,this.cacheKey=null,i&&i.destroy()}setGPUTextureDirectly(i,g,x=!0){this.#L&&(this.#L.destroy(),this.targetResourceManagedState.videoMemory-=this.#N),this.#L=i,this.#k=x,this.#G=i.mipLevelCount,this.cacheKey=g||`direct_${this.uuid}`,this.#N=calculateTextureByteSize(i),this.targetResourceManagedState.videoMemory+=this.#N,this.__fireListenerList()}#K(i){return i?i instanceof Array?i.length?i.toString():this.uuid:i.cacheKey||i.srcList.toString():this.uuid}#$(i){return i instanceof Array?i:i?.srcList}#q(i){this.#L=i,i||(this.#ie=null),this.__fireListenerList()}#X(){this.redGPUContext.resourceManager.registerManagementResource(this,new ResourceStateCubeTexture(this))}#W(){this.redGPUContext.resourceManager.unregisterManagementResource(this)}#Y(){const{gpuDevice:i,resourceManager:g}=this.redGPUContext,{mipmapGenerator:x}=g;this.#L&&(this.#L.destroy(),this.#L=null),this.#G=1;{const g=this.#ie,_=g[0],{width:v,height:b}=_,y={size:[v,b,6],format:this.#F,usage:GPUTextureUsage.RENDER_ATTACHMENT|GPUTextureUsage.TEXTURE_BINDING|GPUTextureUsage.COPY_DST,label:`cubeTexture_${this.#re?.toString()||this.uuid}`};this.#k&&(this.#G=getMipLevelCount(v,b),y.mipLevelCount=this.#G,y.usage|=GPUTextureUsage.RENDER_ATTACHMENT);const S=imageBitmapToGPUTexture(i,g,y);this.targetResourceManagedState.videoMemory-=this.#N,this.#N=calculateTextureByteSize(S),this.targetResourceManagedState.videoMemory+=this.#N,this.#k&&x.generateMipmap(S,y),this.#q(S)}}async#j(i){this.#ie=await async function(i){const g=i.map(i=>loadAndCreateBitmapImage(i));return await Promise.all(g)}(i);try{this.#Y(),this.#H?.(this)}catch(i){console.error(i),this.#z?.(i)}}}Object.freeze(CubeTexture);class ResourceStateCubeTexture{texture;srcList;cacheKey;useNum=0;uuid;constructor(i){this.texture=i,this.srcList=i instanceof CubeTexture?i.srcList:void 0,this.cacheKey=i.cacheKey,this.useNum=0,this.uuid=i.uuid}}class IBLCubeTexture extends ManagementResourceBase{#L;#G;#k=!0;#N=0;#F;constructor(i,g,x){super(i,"managedCubeTextureState"),this.cacheKey=g;const{table:_}=this.targetResourceManagedState;if(g){let i=_.get(g);if(i)return i.texture;x&&this.#q(x),this.#X()}}get viewDescriptor(){return{...CubeTexture.defaultViewDescriptor,mipLevelCount:this.#G}}get format(){return this.#F}get videoMemorySize(){return this.#N}get gpuTexture(){return this.#L}set gpuTexture(i){this.#q(i)}get mipLevelCount(){return this.#G}get useMipmap(){return this.#k}destroy(){const i=this.#L;this.#q(null),this.__fireListenerList(!0),this.#W(),this.cacheKey=null,i&&i.destroy()}#q(i){this.targetResourceManagedState.videoMemory-=this.#N,this.#L=i,i&&(this.#G=i.mipLevelCount,this.#k=i.mipLevelCount>1,this.#F=i.format,this.#N=calculateTextureByteSize(i)),this.targetResourceManagedState.videoMemory+=this.#N,this.__fireListenerList()}#X(){this.redGPUContext.resourceManager.registerManagementResource(this,new ResourceStateCubeTexture(this))}#W(){this.redGPUContext.resourceManager.unregisterManagementResource(this)}}Object.freeze(IBLCubeTexture);class IrradianceGenerator{#l;#ae;#Q;#se;constructor(i){this.#l=i,this.#ae=new Sampler(this.#l,{magFilter:v.LINEAR,minFilter:v.LINEAR,mipmapFilter:b.LINEAR,addressModeU:_.CLAMP_TO_EDGE,addressModeV:_.CLAMP_TO_EDGE,addressModeW:_.CLAMP_TO_EDGE})}async generate(i,g=32){const{gpuDevice:x,resourceManager:_}=this.#l,v=_.createManagedTexture({size:[g,g,6],format:"rgba16float",usage:GPUTextureUsage.TEXTURE_BINDING|GPUTextureUsage.STORAGE_BINDING|GPUTextureUsage.COPY_SRC|GPUTextureUsage.COPY_DST|GPUTextureUsage.RENDER_ATTACHMENT,dimension:"2d",mipLevelCount:1,label:`Irradiance_Map_Texture_${createUUID()}`});this.#se||(this.#se=_.createGPUShaderModule("IRRADIANCE_GENERATOR_SHADER_MODULE",{code:"\n@group(0) @binding(0) var environmentTexture:texture_cube;\n@group(0) @binding(1) var environmentSampler:sampler;\n@group(0) @binding(2) var outTexture:texture_storage_2d_array;\n@group(0) @binding(3) var faceMatrices:array,6>;\nconst PI=3.14159265359;\nfn radicalInverse_VdC(bits_in:u32) -> f32 { var bits=bits_in; bits=(bits << 16u) | (bits >> 16u); bits=((bits & 0x55555555u) << 1u) | ((bits & 0xAAAAAAAAu) >> 1u); bits=((bits & 0x33333333u) << 2u) | ((bits & 0xCCCCCCCCu) >> 2u); bits=((bits & 0x0F0F0F0Fu) << 4u) | ((bits & 0xF0F0F0F0u) >> 4u); bits=((bits & 0x00FF00FFu) << 8u) | ((bits & 0xFF00FF00u) >> 8u); return f32(bits) * 2.3283064365386963e-10;\n}\nfn hammersley(i:u32,n:u32) -> vec2 { return vec2(f32(i)/f32(n),radicalInverse_VdC(i));\n}\n@compute @workgroup_size(8,8,1)\nfn cs_main(@builtin(global_invocation_id) global_id:vec3) { let size_u=textureDimensions(outTexture); let size=vec2(size_u); if (global_id.x >=size_u.x || global_id.y >=size_u.y || global_id.z >=6u) { return; } let face=global_id.z; let uv=(vec2(global_id.xy) + 0.5)/size; let x=uv.x * 2.0 - 1.0; let y=uv.y * 2.0 - 1.0; let localPos=vec4(x,y,1.0,1.0); let normal=normalize((faceMatrices[face] * localPos).xyz); let s=select(1.0,-1.0,normal.z < 0.0); let a=-1.0/(s + normal.z); let b=normal.x * normal.y * a; let tangent=vec3(1.0 + s * normal.x * normal.x * a,s * b,-s * normal.x); let bitangent=vec3(b,s + normal.y * normal.y * a,-normal.y); var irradiance=vec3(0.0); var totalWeight=0.0; let totalSamples=1024u; let envSize=f32(textureDimensions(environmentTexture).x); let saTexel=4.0 * PI/(6.0 * envSize * envSize); for (var i=0u;i < totalSamples;i++) { let xi=hammersley(i,totalSamples); let phi=2.0 * PI * xi.x; let cosTheta=sqrt(1.0 - xi.y); let sinTheta=sqrt(xi.y); let sampleVec=vec3(sinTheta * cos(phi),sinTheta * sin(phi),cosTheta); let worldSample=normalize(tangent * sampleVec.x + bitangent * sampleVec.y + normal * sampleVec.z); let pdf=max(cosTheta,0.001)/PI; let saSample=1.0/(f32(totalSamples) * pdf + 0.0001); let mipLevel=max(0.5 * log2(saSample/saTexel),0.0); let sampleColor=textureSampleLevel(environmentTexture,environmentSampler,worldSample,mipLevel); irradiance +=sampleColor.rgb; totalWeight +=1.0; } irradiance=irradiance/totalWeight; textureStore(outTexture,global_id.xy,face,vec4(irradiance,1.0));\n}"})),this.#Q||(this.#Q=x.createComputePipeline({label:"IRRADIANCE_GENERATOR_PIPELINE",layout:"auto",compute:{module:this.#se,entryPoint:"cs_main"}}));const b=x.createCommandEncoder({label:"Irradiance_Generator_Command_Encoder"}),y=this.#oe(),S=x.createBuffer({size:384,usage:GPUBufferUsage.UNIFORM|GPUBufferUsage.COPY_DST,label:"Irradiance_face_matrices_uniform"}),w=new Float32Array(96);y.forEach((i,g)=>w.set(i,16*g)),x.queue.writeBuffer(S,0,w);const L=x.createBindGroup({layout:this.#Q.getBindGroupLayout(0),entries:[{binding:0,resource:i.createView({dimension:"cube"})},{binding:1,resource:this.#ae.gpuSampler},{binding:2,resource:v.createView({dimension:"2d-array"})},{binding:3,resource:{buffer:S}}]}),k=b.beginComputePass({label:"Irradiance_Generator_Compute_Pass"});return k.setPipeline(this.#Q),k.setBindGroup(0,L),k.dispatchWorkgroups(Math.ceil(g/8),Math.ceil(g/8),6),k.end(),x.queue.submit([b.finish()]),await x.queue.onSubmittedWorkDone(),S.destroy(),new IBLCubeTexture(this.#l,`Irradiance_Map_${createUUID()}`,v)}#oe(){return[new Float32Array([0,0,-1,0,0,-1,0,0,1,0,0,0,0,0,0,1]),new Float32Array([0,0,1,0,0,-1,0,0,-1,0,0,0,0,0,0,1]),new Float32Array([1,0,0,0,0,0,1,0,0,1,0,0,0,0,0,1]),new Float32Array([1,0,0,0,0,0,-1,0,0,-1,0,0,0,0,0,1]),new Float32Array([1,0,0,0,0,-1,0,0,0,0,1,0,0,0,0,1]),new Float32Array([-1,0,0,0,0,-1,0,0,0,0,-1,0,0,0,0,1])]}}Object.freeze(IrradianceGenerator);class PrefilterGenerator{#l;#ae;#Q;#se;constructor(i){this.#l=i,this.#ae=new Sampler(this.#l,{magFilter:v.LINEAR,minFilter:v.LINEAR,addressModeU:_.CLAMP_TO_EDGE,addressModeV:_.CLAMP_TO_EDGE,addressModeW:_.CLAMP_TO_EDGE})}async generate(i,g=512){const{gpuDevice:x,resourceManager:_}=this.#l,v=getMipLevelCount(g,g),b=_.createManagedTexture({size:[g,g,6],format:"rgba16float",usage:GPUTextureUsage.TEXTURE_BINDING|GPUTextureUsage.STORAGE_BINDING|GPUTextureUsage.COPY_SRC|GPUTextureUsage.COPY_DST|GPUTextureUsage.RENDER_ATTACHMENT,dimension:"2d",mipLevelCount:v,label:`Prefilter_Map_Texture_${createUUID()}`});this.#se||(this.#se=_.createGPUShaderModule("PREFILTER_GENERATOR_SHADER_MODULE",{code:"\n@group(0) @binding(0) var environmentTexture:texture_cube;\n@group(0) @binding(1) var textureSampler:sampler;\n@group(0) @binding(2) var outTexture:texture_storage_2d_array;\nstruct PrefilterUniforms { faceMatrices:array,6>, roughness:f32,\n}\n@group(0) @binding(3) var uniforms:PrefilterUniforms;\nconst PI:f32=3.14159265359;\nfn radicalInverse_VdC(bits_in:u32) -> f32 { var bits=bits_in; bits=(bits << 16u) | (bits >> 16u); bits=((bits & 0x55555555u) << 1u) | ((bits & 0xAAAAAAAAu) >> 1u); bits=((bits & 0x33333333u) << 2u) | ((bits & 0xCCCCCCCCu) >> 2u); bits=((bits & 0x0F0F0F0Fu) << 4u) | ((bits & 0xF0F0F0F0u) >> 4u); bits=((bits & 0x00FF00FFu) << 8u) | ((bits & 0xFF00FF00u) >> 8u); return f32(bits) * 2.3283064365386963e-10;\n}\nfn hammersley(i:u32,n:u32) -> vec2 { return vec2(f32(i)/f32(n),radicalInverse_VdC(i));\n}\nfn distribution_ggx(NdotH:f32,roughness:f32) -> f32 { let a=roughness * roughness; let a2=a * a; let NdotH2=NdotH * NdotH; let denom=(NdotH2 * (a2 - 1.0) + 1.0); return a2/(PI * denom * denom);\n}\nfn importanceSampleGGX(xi:vec2,N:vec3,roughness:f32) -> vec3 { let a=roughness * roughness; let phi=2.0 * PI * xi.x; let cosTheta=sqrt((1.0 - xi.y)/(1.0 + (a * a - 1.0) * xi.y)); let sinTheta=sqrt(max(0.0,1.0 - cosTheta * cosTheta)); let H=vec3(cos(phi) * sinTheta,sin(phi) * sinTheta,cosTheta); let up=select(vec3(1.0,0.0,0.0),vec3(0.0,0.0,1.0),abs(N.z) < 0.999); let tangent=normalize(cross(up,N)); let bitangent=cross(N,tangent); return normalize(tangent * H.x + bitangent * H.y + N * H.z);\n}\n@compute @workgroup_size(8,8,1)\nfn cs_main(@builtin(global_invocation_id) global_id:vec3) { let size_u=textureDimensions(outTexture); let size=vec2(size_u); if (global_id.x >=size_u.x || global_id.y >=size_u.y || global_id.z >=6u) { return; } let face=global_id.z; let roughness=uniforms.roughness; let uv=(vec2(global_id.xy) + 0.5)/size; let x=uv.x * 2.0 - 1.0; let y=uv.y * 2.0 - 1.0; let localPos=vec4(x,y,1.0,1.0); let N=normalize((uniforms.faceMatrices[face] * localPos).xyz); if (roughness <=0.0) { textureStore(outTexture,global_id.xy,face,textureSampleLevel(environmentTexture,textureSampler,N,0.0)); return; } let R=N; let V=R; var prefilteredColor=vec3(0.0); var totalWeight=0.0; let numSamples=1024u; let envSize=f32(textureDimensions(environmentTexture).x); let saTexel=4.0 * PI/(6.0 * envSize * envSize); for (var i=0u;i < numSamples;i++) { let xi=hammersley(i,numSamples); let H=importanceSampleGGX(xi,N,roughness); let L=normalize(2.0 * dot(V,H) * H - V); let NdotL=max(dot(N,L),0.0); if (NdotL > 0.0) { let NdotH=max(dot(N,H),0.001); let VdotH=max(dot(V,H),0.001); let D=distribution_ggx(NdotH,roughness); let pdf=(D * NdotH/(4.0 * VdotH)) + 0.0001; let saSample=1.0/(f32(numSamples) * pdf + 0.0001); let mipLevel=max(0.25 * log2(saSample/saTexel),0.0); prefilteredColor +=textureSampleLevel(environmentTexture,textureSampler,L,mipLevel).rgb * NdotL; totalWeight +=NdotL; } } if (totalWeight > 0.0) { textureStore(outTexture,global_id.xy,face,vec4(prefilteredColor/totalWeight,1.0)); } else { textureStore(outTexture,global_id.xy,face,textureSampleLevel(environmentTexture,textureSampler,N,0.0)); }\n}"})),this.#Q||(this.#Q=x.createComputePipeline({label:"PREFILTER_GENERATOR_PIPELINE",layout:"auto",compute:{module:this.#se,entryPoint:"cs_main"}}));const y=x.createCommandEncoder({label:"Prefilter_Generator_Command_Encoder"}),S=this.#oe(),w=[];for(let _=0;_>_),k=_/(v-1),H=new Float32Array(100);S.forEach((i,g)=>H.set(i,16*g)),H[96]=k;const z=x.createBuffer({size:H.byteLength,usage:GPUBufferUsage.UNIFORM|GPUBufferUsage.COPY_DST});x.queue.writeBuffer(z,0,H),w.push(z);const q=x.createBindGroup({layout:this.#Q.getBindGroupLayout(0),entries:[{binding:0,resource:i.createView({dimension:"cube"})},{binding:1,resource:this.#ae.gpuSampler},{binding:2,resource:b.createView({dimension:"2d-array",baseMipLevel:_,mipLevelCount:1})},{binding:3,resource:{buffer:z}}]}),W=y.beginComputePass({label:`Prefilter_mip_${_}_compute_pass`});W.setPipeline(this.#Q),W.setBindGroup(0,q),W.dispatchWorkgroups(Math.ceil(L/8),Math.ceil(L/8),6),W.end()}return x.queue.submit([y.finish()]),await x.queue.onSubmittedWorkDone(),w.forEach(i=>i.destroy()),new IBLCubeTexture(this.#l,`Prefilter_Map_${createUUID()}`,b)}#oe(){return[new Float32Array([0,0,-1,0,0,-1,0,0,1,0,0,0,0,0,0,1]),new Float32Array([0,0,1,0,0,-1,0,0,-1,0,0,0,0,0,0,1]),new Float32Array([1,0,0,0,0,0,1,0,0,1,0,0,0,0,0,1]),new Float32Array([1,0,0,0,0,0,-1,0,0,-1,0,0,0,0,0,1]),new Float32Array([1,0,0,0,0,-1,0,0,0,0,1,0,0,0,0,1]),new Float32Array([-1,0,0,0,0,-1,0,0,0,0,-1,0,0,0,0,1])]}}Object.freeze(PrefilterGenerator);class EquirectangularToCubeGenerator{#l;#se;#Q;#ae;constructor(i){this.#l=i,this.#ae=new Sampler(this.#l,{magFilter:v.LINEAR,minFilter:v.LINEAR,addressModeU:_.CLAMP_TO_EDGE,addressModeV:_.CLAMP_TO_EDGE})}async generate(i,g=512){const{gpuDevice:x,resourceManager:_}=this.#l,v=getMipLevelCount(g,g),b={size:[g,g,6],format:"rgba16float",usage:GPUTextureUsage.TEXTURE_BINDING|GPUTextureUsage.STORAGE_BINDING|GPUTextureUsage.COPY_SRC|GPUTextureUsage.COPY_DST|GPUTextureUsage.RENDER_ATTACHMENT,dimension:"2d",mipLevelCount:v,label:`EquirectangularToCube_Texture_${createUUID()}`},y=_.createManagedTexture(b);this.#se||(this.#se=_.createGPUShaderModule("EQUIRECTANGULAR_TO_CUBE_GENERATOR_SHADER_MODULE",{code:"\n@group(0) @binding(0) var equirectangularTexture:texture_2d;\n@group(0) @binding(1) var textureSampler:sampler;\n@group(0) @binding(2) var outTexture:texture_storage_2d_array;\n@group(0) @binding(3) var faceMatrices:array,6>;\nconst PI:f32=3.14159265359;\nfn directionToSphericalUV(dir:vec3) -> vec2 { let normalizedDir=normalize(dir); let theta=atan2(normalizedDir.x,normalizedDir.z); let phi=acos(clamp(normalizedDir.y,-1.0,1.0)); return vec2(0.5 - theta/(2.0 * PI),phi/PI);\n}\n@compute @workgroup_size(8,8,1)\nfn cs_main(@builtin(global_invocation_id) global_id:vec3) { let size=textureDimensions(outTexture); if (global_id.x >=size.x || global_id.y >=size.y || global_id.z >=6u) { return; } let face=global_id.z; let uv=(vec2(global_id.xy) + 0.5)/vec2(size); let x=uv.x * 2.0 - 1.0; let y=uv.y * 2.0 - 1.0; let localPos=vec4(x,y,1.0,1.0); let direction=(faceMatrices[face] * localPos).xyz; let sphericalUV=directionToSphericalUV(direction); let color=textureSampleLevel(equirectangularTexture,textureSampler,sphericalUV,0.0); textureStore(outTexture,global_id.xy,face,color);\n}\n"})),this.#Q||(this.#Q=x.createComputePipeline({label:"EQUIRECTANGULAR_TO_CUBE_GENERATOR_PIPELINE",layout:"auto",compute:{module:this.#se,entryPoint:"cs_main"}}));const S=x.createCommandEncoder({label:"EquirectangularToCube_Generator_Command_Encoder"}),w=this.#oe(),L=x.createBuffer({size:384,usage:GPUBufferUsage.UNIFORM|GPUBufferUsage.COPY_DST,label:"EquirectangularToCube_face_matrices_uniform"}),k=new Float32Array(96);w.forEach((i,g)=>k.set(i,16*g)),x.queue.writeBuffer(L,0,k);const H=x.createBindGroup({layout:this.#Q.getBindGroupLayout(0),entries:[{binding:0,resource:i.createView()},{binding:1,resource:this.#ae.gpuSampler},{binding:2,resource:y.createView({dimension:"2d-array",baseMipLevel:0,mipLevelCount:1})},{binding:3,resource:{buffer:L}}]}),z=S.beginComputePass({label:"EquirectangularToCube_Generator_Compute_Pass"});return z.setPipeline(this.#Q),z.setBindGroup(0,H),z.dispatchWorkgroups(Math.ceil(g/8),Math.ceil(g/8),6),z.end(),x.queue.submit([S.finish()]),_.mipmapGenerator.generateMipmap(y,b),await x.queue.onSubmittedWorkDone(),L.destroy(),new IBLCubeTexture(this.#l,`CubeMap_From_Equirect_${createUUID()}`,y)}#oe(){return[new Float32Array([0,0,-1,0,0,-1,0,0,1,0,0,0,0,0,0,1]),new Float32Array([0,0,1,0,0,-1,0,0,-1,0,0,0,0,0,0,1]),new Float32Array([1,0,0,0,0,0,1,0,0,1,0,0,0,0,0,1]),new Float32Array([1,0,0,0,0,0,-1,0,0,-1,0,0,0,0,0,1]),new Float32Array([1,0,0,0,0,-1,0,0,0,0,1,0,0,0,0,1]),new Float32Array([-1,0,0,0,0,-1,0,0,0,0,-1,0,0,0,0,1])]}}Object.freeze(EquirectangularToCubeGenerator);var k=Object.freeze({__proto__:null,BRDFGenerator:BRDFGenerator,BRDFLUTTexture:BRDFLUTTexture,EquirectangularToCubeGenerator:EquirectangularToCubeGenerator,IBLCubeTexture:IBLCubeTexture,IrradianceGenerator:IrradianceGenerator,PrefilterGenerator:PrefilterGenerator});class DownSampleCubeMapGenerator{#l;#ue=new Map;#le=new Map;#ce=null;#he=null;#fe=null;#de=null;#me=8;#pe=8;#ge=new Map;#xe=new Map;constructor(i){this.#l=i}createSourceTextureView(i,g){const x=`DOWN_SAMPLE_CUBE_GENERATOR_SOURCE_VIEW_${i.label}_${g}`;if(!this.#ge.has(x)){const _=i.createView({label:x,dimension:"cube",baseMipLevel:g,mipLevelCount:1});this.#ge.set(x,_)}return this.#ge.get(x)}createTargetTextureView(i,g){const x=`DOWN_SAMPLE_CUBE_GENERATOR_TARGET_VIEW_${i.label}_${g}`;if(!this.#ge.has(x)){const _=i.createView({label:x,dimension:"2d-array",baseMipLevel:g,mipLevelCount:1,arrayLayerCount:6});this.#ge.set(x,_)}return this.#ge.get(x)}createBindGroup(i,g,x){const _=`DOWN_SAMPLE_CUBE_GENERATOR_BIND_GROUP_${g.label}_${x.label}`;if(!this.#xe.has(_)){const{gpuDevice:v}=this.#l,b=v.createBindGroup({label:_,layout:i,entries:[{binding:0,resource:g},{binding:1,resource:x},{binding:2,resource:this.#de},{binding:3,resource:{buffer:this.#he}}]});this.#xe.set(_,b)}return this.#xe.get(_)}async downsampleCubemap(i,g=256,x="rgba16float"){try{this.#_e(),this.#ve();const{gpuDevice:_,resourceManager:v}=this.#l;if(!i)throw new Error("Invalid source cubemap texture");if(g<=0||!Number.isInteger(g))throw new Error("Target size must be a positive integer");const b=i.mipLevelCount,y=getMipLevelCount(g,g),S=v.createManagedTexture({size:[g,g,6],format:x,usage:GPUTextureUsage.STORAGE_BINDING|GPUTextureUsage.TEXTURE_BINDING|GPUTextureUsage.RENDER_ATTACHMENT,dimension:"2d",mipLevelCount:y,label:`DOWN_SAMPLE_CUBE_GENERATOR_TEXTURE_${g}x${g}_${y}mips_${Date.now()}`});for(let _=0;_>_),y=this.#be(i.width,g,_,b);await this.#ye(i,S,y,_,v,x)}return this.#_e(),S}catch(i){throw console.error("큐브맵 다운샘플링 실패:",i),this.#_e(),i}}destroy(){this.#_e(),this.#he&&(this.#he.destroy(),this.#he=null),this.#ue.clear(),this.#le.clear(),this.#ce=null,this.#de=null}#_e(){this.#ge.clear(),this.#xe.clear()}#ve(){if(this.#ce)return;const{gpuDevice:i,resourceManager:g}=this.#l;this.#de=new Sampler(this.#l,{minFilter:"linear",magFilter:"linear",mipmapFilter:"linear",addressModeU:"clamp-to-edge",addressModeV:"clamp-to-edge",addressModeW:"clamp-to-edge"}).gpuSampler,this.#ce=g.createGPUShaderModule("DOWN_SAMPLE_CUBE_GENERATOR_COMPUTE_SHADER",{code:"\nstruct Uniforms { targetSize:f32, sourceMipLevel:f32, targetMipLevel:f32, padding:f32,\n};\n@group(0) @binding(0) var sourceCubemap:texture_cube;\n@group(0) @binding(1) var targetCubemap:texture_storage_2d_array;\n@group(0) @binding(2) var cubemapSampler:sampler;\n@group(0) @binding(3) var uniforms:Uniforms;\nfn cubemapUVToDirection(uv:vec2,face:u32) -> vec3 { let u=uv.x * 2.0 - 1.0; let v=uv.y * 2.0 - 1.0; switch face { case 0u:{ return vec3(1.0,-v,-u); } case 1u:{ return vec3(-1.0,-v,u); } case 2u:{ return vec3(u,1.0,v); } case 3u:{ return vec3(u,-1.0,-v); } case 4u:{ return vec3(u,-v,1.0); } case 5u:{ return vec3(-u,-v,-1.0); } default:{ return vec3(0.0,0.0,1.0); } }\n}\nfn gaussianWeight(x:f32,y:f32,sigma:f32) -> f32 { let sigmaSq=sigma * sigma; return exp(-(x * x + y * y)/(2.0 * sigmaSq))/(2.0 * 3.14159265359 * sigmaSq);\n}\nfn clampCubemapUV(uv:vec2) -> vec2 { return clamp(uv,vec2(0.0),vec2(1.0));\n}\n@compute @workgroup_size(8,8,1)\nfn main(@builtin(global_invocation_id) global_id:vec3) { let face=global_id.z; let coord=vec2(global_id.xy); let targetSize=u32(uniforms.targetSize); if (coord.x >=targetSize || coord.y >=targetSize || face >=6u) { return; } let uv=(vec2(coord) + 0.5)/f32(targetSize); let direction=normalize(cubemapUVToDirection(uv,face)); let sourceMipLevel=uniforms.sourceMipLevel; let targetMipLevel=uniforms.targetMipLevel; var color=vec4(0.0); if (sourceMipLevel==0.0 && targetSize > 64u) { let sampleCount=16u; let sampleRadius=1.0/f32(targetSize); var totalWeight=0.0; for (var i=0u;i < sampleCount;i++) { let angle=2.0 * 3.14159265359 * f32(i)/f32(sampleCount); let radius=sampleRadius * (0.5 + 0.5 * f32(i % 4u)/4.0); let offsetUV=clampCubemapUV(uv + vec2( cos(angle) * radius, sin(angle) * radius )); let sampleDir=normalize(cubemapUVToDirection(offsetUV,face)); let sampleColor=textureSampleLevel(sourceCubemap,cubemapSampler,sampleDir,sourceMipLevel); let weight=gaussianWeight( cos(angle) * radius * f32(targetSize), sin(angle) * radius * f32(targetSize), 0.8 ); color +=sampleColor * weight; totalWeight +=weight; } if (totalWeight > 0.0) { color=color/totalWeight; } } else if (sourceMipLevel==0.0 && targetSize > 16u) { let sampleCount=4u; let invSampleCount=1.0/f32(sampleCount * sampleCount); let sampleOffset=0.5/f32(targetSize); for (var x=0u;x < sampleCount;x++) { for (var y=0u;y < sampleCount;y++) { let offset=vec2( (f32(x) - 1.5) * sampleOffset, (f32(y) - 1.5) * sampleOffset ); let offsetUV=clampCubemapUV(uv + offset); let sampleDir=normalize(cubemapUVToDirection(offsetUV,face)); color +=textureSampleLevel(sourceCubemap,cubemapSampler,sampleDir,sourceMipLevel); } } color *=invSampleCount; } else if (targetSize > 4u) { let sampleCount=2u; let invSampleCount=1.0/f32(sampleCount * sampleCount); let sampleOffset=0.25/f32(targetSize); for (var x=0u;x < sampleCount;x++) { for (var y=0u;y < sampleCount;y++) { let offset=vec2( (f32(x) - 0.5) * sampleOffset, (f32(y) - 0.5) * sampleOffset ); let offsetUV=clampCubemapUV(uv + offset); let sampleDir=normalize(cubemapUVToDirection(offsetUV,face)); color +=textureSampleLevel(sourceCubemap,cubemapSampler,sampleDir,sourceMipLevel); } } color *=invSampleCount; } else { color=textureSampleLevel(sourceCubemap,cubemapSampler,direction,sourceMipLevel); } if (targetMipLevel > 0.0) { let luminance=dot(color.rgb,vec3(0.299,0.587,0.114)); let saturation=0.9 + 0.1/(1.0 + targetMipLevel * 0.1); color=vec4(mix(vec3(luminance),color.rgb,saturation),color.a); } textureStore(targetCubemap,vec2(coord),i32(face),color);\n}\n"}),this.#Se()}#Te(i){if(!this.#ue.has(i)){const{gpuDevice:g,resourceManager:x}=this.#l,_=x.createBindGroupLayout(`DOWN_SAMPLE_CUBE_GENERATOR_BIND_GROUP_LAYOUT_${i}`,{entries:[{binding:0,visibility:GPUShaderStage.COMPUTE,texture:{viewDimension:"cube",sampleType:"float"}},{binding:1,visibility:GPUShaderStage.COMPUTE,storageTexture:{format:i,viewDimension:"2d-array"}},{binding:2,visibility:GPUShaderStage.COMPUTE,sampler:{type:"filtering"}},{binding:3,visibility:GPUShaderStage.COMPUTE,buffer:{type:"uniform"}}]}),v=g.createComputePipeline({label:`DOWN_SAMPLE_CUBE_GENERATOR_COMPUTE_PIPELINE_${i}`,layout:g.createPipelineLayout({label:`DOWN_SAMPLE_CUBE_GENERATOR_PIPELINE_LAYOUT_${i}`,bindGroupLayouts:[_]}),compute:{module:this.#ce,entryPoint:"main"}});this.#le.set(i,_),this.#ue.set(i,v)}return this.#ue.get(i)}#Se(){const{gpuDevice:i,resourceManager:g}=this.#l;this.#fe={arrayBufferByteLength:16,properties:{targetSize:{byteOffset:0,size:4},sourceMipLevel:{byteOffset:4,size:4},targetMipLevel:{byteOffset:8,size:4},padding:{byteOffset:12,size:4}}},this.#he=i.createBuffer({size:this.#fe.arrayBufferByteLength,usage:GPUBufferUsage.UNIFORM|GPUBufferUsage.COPY_DST,label:"DOWN_SAMPLE_CUBE_GENERATOR_UNIFORM_BUFFER"})}#be(i,g,x,_){const v=i/Math.max(1,g>>x),b=Math.max(0,Math.floor(Math.log2(v)));return Math.min(b,_-1)}async#ye(i,g,x,_,v,b){const{gpuDevice:y}=this.#l,S=this.#Te(b),w=this.#le.get(b),L=this.createSourceTextureView(i,x),k=this.createTargetTextureView(g,_),H=this.createBindGroup(w,L,k);this.#Me(x,_,v);const z=y.createCommandEncoder({label:`DOWN_SAMPLE_CUBE_GENERATOR_COMMAND_ENCODER_MIP${_}`}),q=z.beginComputePass({label:`DOWN_SAMPLE_CUBE_GENERATOR_COMPUTE_PASS_MIP${_}`});q.setPipeline(S),q.setBindGroup(0,H),q.dispatchWorkgroups(Math.ceil(v/this.#me),Math.ceil(v/this.#pe),6),q.end();const W=z.finish();y.queue.submit([W]),await y.queue.onSubmittedWorkDone()}#Me(i,g,x){const{gpuDevice:_}=this.#l,v=new Float32Array([x,i,g,0]);_.queue.writeBuffer(this.#he,0,v)}}Object.freeze(DownSampleCubeMapGenerator);const H={LOAD:"load",CLEAR:"clear"};Object.freeze(H);const z={STORE:"store",DISCARD:"discard"};Object.freeze(z);class MipmapGenerator{#l;#ae;#we;#Ce;#Re;#Pe;#ge=new Map;#xe=new Map;#Be=new WeakMap;#Ie=new WeakMap;constructor(i){this.#l=i,this.#ae=new Sampler(i,{minFilter:"linear"}).gpuSampler,this.#Ce={}}createTextureView(i,g,x,_=!1){const v=`${g}_${x}`;if(_){let _=this.#Ie.get(i);if(_||(_=new Map,this.#Ie.set(i,_)),_.has(v))return _.get(v);const b=i.createView({baseMipLevel:g,mipLevelCount:1,dimension:"2d",baseArrayLayer:x,arrayLayerCount:1,label:`MIPMAP_GENERATOR_CACHED_${i.label}_${v}`});return _.set(v,b),b}{const _=`MIPMAP_GENERATOR_${i.label}_${g}_${x}`;if(!this.#ge.has(_)){const v=i.createView({baseMipLevel:g,mipLevelCount:1,dimension:"2d",baseArrayLayer:x,arrayLayerCount:1,label:_});this.#ge.set(_,v)}return this.#ge.get(_)}}createBindGroup(i,g,x=!1){const{gpuDevice:_}=this.#l;if(x){let x=this.#Be.get(i);x||(x=new Map,this.#Be.set(i,x));const v=g.label||"unlabeled";if(x.has(v))return x.get(v);const b=_.createBindGroup({label:`MIPMAP_GENERATOR_BIND_GROUP_CACHED_${i.label}_${v}`,layout:this.#Re,entries:[{binding:0,resource:this.#ae},{binding:1,resource:g}]});return x.set(v,b),b}{const x=`${i.label}_${g.label}`;if(this.#xe.has(x))return this.#xe.get(x);const v=_.createBindGroup({label:`MIPMAP_GENERATOR_BIND_GROUP_TEMP_${x}`,layout:this.#Re,entries:[{binding:0,resource:this.#ae},{binding:1,resource:g}]});return this.#xe.set(x,v),v}}getMipmapPipeline(i){const{gpuDevice:g,resourceManager:x}=this.#l;let _=this.#Ce[i];return _||(this.#Pe||(this.#Pe=x.createGPUShaderModule("MIPMAP_GENERATOR_SHADER_MODULE",{code:"\nvar pos:array,3>=array,3>( vec2(-1.0,-1.0), vec2(-1.0,3.0), vec2(3.0,-1.0)\n);\nstruct VertexOutput { @builtin(position) position:vec4, @location(0) texCoord:vec2,\n};\n@vertex\nfn vertexMain(@builtin(vertex_index) vertexIndex:u32) -> VertexOutput { var output:VertexOutput; output.texCoord=pos[vertexIndex] * vec2(0.5,-0.5) + vec2(0.5); output.position=vec4(pos[vertexIndex],0.0,1.0); return output;\n}\n@group(0) @binding(0)\nvar imgSampler:sampler;\n@group(0) @binding(1)\nvar img:texture_2d;\n@fragment\nfn fragmentMain(@location(0) texCoord:vec2) -> @location(0) vec4 { return textureSample(img,imgSampler,texCoord);\n}\n"}),this.#Re=x.createBindGroupLayout("MIPMAP_GENERATOR_FRAGMENT_BIND_GROUP_LAYOUT",{entries:[{binding:0,visibility:GPUShaderStage.FRAGMENT,sampler:{}},{binding:1,visibility:GPUShaderStage.FRAGMENT,texture:{}}]}),this.#we=x.createGPUPipelineLayout("MIPMAP_GENERATOR_PIPELINE_LAYOUT",{bindGroupLayouts:[this.#Re]})),_=g.createRenderPipeline({label:`MIPMAP_GENERATOR_PIPELINE_${i}`,layout:this.#we,vertex:{module:this.#Pe,entryPoint:"vertexMain"},fragment:{module:this.#Pe,entryPoint:"fragmentMain",targets:[{format:i}]}}),this.#Ce[i]=_),_}generateMipmap(i,g,x=!1){x||this.#_e();const{gpuDevice:_,resourceManager:v}=this.#l,b=this.getMipmapPipeline(g.format);if("3d"==g.dimension||"1d"==g.dimension)throw new Error("Generating mipmaps for non-2d textures is currently unsupported!");let y=i;const S=g.size[0],w=g.size[1],L=g.size[2]||1,k=g.usage&GPUTextureUsage.RENDER_ATTACHMENT;if(!k){const i={size:{width:Math.max(1,S>>>1),height:Math.max(1,w>>>1),depthOrArrayLayers:L},format:g.format,usage:GPUTextureUsage.TEXTURE_BINDING|GPUTextureUsage.COPY_SRC|GPUTextureUsage.RENDER_ATTACHMENT,mipLevelCount:g.mipLevelCount-1};y=v.createManagedTexture(i)}const q=_.createCommandEncoder({});for(let _=0;_>>1),height:Math.max(1,w>>>1),depthOrArrayLayers:L};for(let _=1;_>>1),x.height=Math.max(1,x.height>>>1)}return _.queue.submit([q.finish()]),k||y.destroy(),x||this.#_e(),i}destroy(){this.#_e()}#_e(){this.#ge.clear(),this.#xe.clear()}}Object.freeze(MipmapGenerator);const q={TILE_COUNT_X:32,TILE_COUNT_Y:32,TILE_COUNT_Z:48,WORKGROUP_SIZE_X:8,WORKGROUP_SIZE_Y:4,WORKGROUP_SIZE_Z:8,MAX_LIGHTS_PER_CLUSTER:100,MAX_CLUSTER_LIGHTS:1024,getTotalTileSize:()=>q.TILE_COUNT_X*q.TILE_COUNT_Y*q.TILE_COUNT_Z,getClusterLightsBufferSize:()=>{const i=q.getTotalTileSize();return 8*i+8*q.MAX_LIGHTS_PER_CLUSTER*i+4},getDispatchSize:()=>[Math.ceil(q.TILE_COUNT_X/q.WORKGROUP_SIZE_X),Math.ceil(q.TILE_COUNT_Y/q.WORKGROUP_SIZE_Y),Math.ceil(q.TILE_COUNT_Z/q.WORKGROUP_SIZE_Z)]};Object.freeze(q);const W=Object.freeze({calcTintBlendMode:"\nfn rgbToHsl(rgb:vec3) -> vec3 { let maxVal:f32=max(max(rgb.r,rgb.g),rgb.b); let minVal:f32=min(min(rgb.r,rgb.g),rgb.b); let delta:f32=maxVal - minVal; let eps=1e-6; let lightness:f32=(maxVal + minVal) * 0.5; if (delta < eps) { return vec3(0.0,0.0,lightness); } var saturation:f32; if (lightness < 0.5) { saturation=delta/(maxVal + minVal + eps); } else { saturation=delta/(2.0 - maxVal - minVal + eps); } var hue:f32=0.0; if (abs(rgb.r - maxVal) < eps) { hue=(rgb.g - rgb.b)/delta; if (rgb.g < rgb.b) { hue +=6.0; } } else if (abs(rgb.g - maxVal) < eps) { hue=(rgb.b - rgb.r)/delta + 2.0; } else { hue=(rgb.r - rgb.g)/delta + 4.0; } hue=hue/6.0; return vec3(hue,saturation,lightness);\n}\nfn hslToRgb(hsl:vec3) -> vec3 { let h=hsl.x; let s=hsl.y; let l=hsl.z; if (s==0.0) { return vec3(l,l,l); } var q:f32; if (l < 0.5) { q=l * (1.0 + s); } else { q=l + s - l * s; } let p=2.0 * l - q; var r:f32; var g:f32; var b:f32; for (var i:i32=0;i < 3;i=i + 1) { var t:f32; if (i==0) { t=h + 1.0/3.0; } else if (i==1) { t=h; } else { t=h - 1.0/3.0; } if (t < 0.0) { t=t + 1.0; } if (t > 1.0) { t=t - 1.0; } var color:f32; if (t < 1.0/6.0) { color=p + (q - p) * 6.0 * t; } else if (t < 1.0/2.0) { color=q; } else if (t < 2.0/3.0) { color=p + (q - p) * (2.0/3.0 - t) * 6.0; } else { color=p; } if (i==0) { r=color; } else if (i==1) { g=color; } else { b=color; } } return vec3(r,g,b);\n}\nfn calcTintBlendMode(baseColor:vec4,tintBlendMode:u32,tint:vec4) -> vec4 { var tintedColor:vec3; let eps=1e-6; switch (tintBlendMode) { case 0u:{ tintedColor=mix(baseColor.rgb,tint.rgb,tint.a); } case 1u:{ tintedColor=baseColor.rgb * tint.rgb; } case 2u:{ tintedColor=max(baseColor.rgb,tint.rgb); } case 3u:{ tintedColor=1.0 - (1.0 - baseColor.rgb) * (1.0 - tint.rgb); } case 4u:{ tintedColor=clamp(baseColor.rgb + tint.rgb,vec3(0.0),vec3(1.0)); } case 5u:{ tintedColor=clamp(baseColor.rgb - tint.rgb,vec3(0.0),vec3(1.0)); } case 6u:{ tintedColor=min(baseColor.rgb,tint.rgb); } case 7u:{ tintedColor=mix( 2.0 * baseColor.rgb * tint.rgb, 1.0 - 2.0 * (1.0 - baseColor.rgb) * (1.0 - tint.rgb), step(vec3(0.5),baseColor.rgb) ); } case 8u:{ tintedColor=clamp(baseColor.rgb/(1.0 - tint.rgb + eps),vec3(0.0),vec3(1.0)); } case 9u:{ tintedColor=1.0 - clamp((1.0 - baseColor.rgb)/(tint.rgb + eps),vec3(0.0),vec3(1.0)); } case 10u:{ tintedColor=mix( 2.0 * baseColor.rgb * tint.rgb, 1.0 - 2.0 * (1.0 - baseColor.rgb) * (1.0 - tint.rgb), step(vec3(0.5),tint.rgb) ); } case 11u:{ tintedColor=mix( baseColor.rgb * (tint.rgb + tint.rgb - vec3(1.0)), baseColor.rgb + tint.rgb - baseColor.rgb * tint.rgb, step(vec3(0.5),tint.rgb) ); } case 12u:{ tintedColor=abs(baseColor.rgb - tint.rgb); } case 13u:{ tintedColor=baseColor.rgb + tint.rgb - 2.0 * baseColor.rgb * tint.rgb; } case 14u:{ tintedColor=clamp(baseColor.rgb/(tint.rgb + eps),vec3(0.0),vec3(1.0)); } case 15u:{ tintedColor=mix( clamp(baseColor.rgb/(1.0 - (tint.rgb - vec3(0.5)) * 2.0 + eps),vec3(0.0),vec3(1.0)), 1.0 - clamp((1.0 - baseColor.rgb)/(tint.rgb * 2.0 + eps),vec3(0.0),vec3(1.0)), step(vec3(0.5),tint.rgb) ); } case 16u:{ tintedColor=clamp(baseColor.rgb + tint.rgb - vec3(1.0),vec3(0.0),vec3(1.0)); } case 17u:{ tintedColor=mix( min(baseColor.rgb,2.0 * tint.rgb), max(baseColor.rgb,2.0 * tint.rgb - vec3(1.0)), step(vec3(0.5),tint.rgb) ); } case 18u:{ let baseHsl=rgbToHsl(baseColor.rgb); let tintHsl=rgbToHsl(tint.rgb); tintedColor=hslToRgb(vec3(baseHsl.x,tintHsl.y,baseHsl.z)); } case 19u:{ let baseHsl=rgbToHsl(baseColor.rgb); let tintHsl=rgbToHsl(tint.rgb); tintedColor=hslToRgb(vec3(tintHsl.x,baseHsl.y,baseHsl.z)); } case 20u:{ let baseHsl=rgbToHsl(baseColor.rgb); let tintHsl=rgbToHsl(tint.rgb); tintedColor=hslToRgb(vec3(baseHsl.x,baseHsl.y,tintHsl.z)); } case 21u:{ let baseHsl=rgbToHsl(baseColor.rgb); let tintHsl=rgbToHsl(tint.rgb); tintedColor=hslToRgb(vec3(tintHsl.x,tintHsl.y,baseHsl.z)); } case 22u:{ tintedColor=1.0 - abs(1.0 - baseColor.rgb - tint.rgb); } default:{ tintedColor=baseColor.rgb; } } return vec4(tintedColor,baseColor.a * tint.a);\n}\n",calcDirectionalShadowVisibility:"fn calcDirectionalShadowVisibility( directionalShadowMap:texture_depth_2d, directionalShadowMapSampler:sampler_comparison, shadowDepthTextureSize:u32, bias:f32, shadowPos:vec3\n) -> f32 { let oneOverShadowDepthTextureSize=1.0/f32(shadowDepthTextureSize); let shadowDepth=clamp(shadowPos.z,0.0,1.0); var visibility:f32=0.0; for (var y=-1;y <=1;y++) { for (var x=-1;x <=1;x++) { let offset=vec2f(vec2(x,y)) * oneOverShadowDepthTextureSize; let tUV=shadowPos.xy + offset; let sampleVisibility=textureSampleCompare( directionalShadowMap, directionalShadowMapSampler, tUV, shadowDepth - bias ); if (tUV.x < 0.0 || tUV.x > 1.0 || tUV.y < 0.0 || tUV.y > 1.0) { visibility +=1.0; } else { visibility +=sampleVisibility; } } } visibility/=9.0; let depthFactor=shadowDepth; let minVisibility=0.2 + depthFactor * 0.6; return max(visibility,minVisibility);\n}\n",drawDirectionalShadowDepth:"struct OutputShadowData { @builtin(position) position:vec4,\n};\n@vertex\nfn drawDirectionalShadowDepth(inputData:InputData) -> OutputShadowData { var output:OutputShadowData; let u_directionalLightProjectionViewMatrix=systemUniforms.directionalLightProjectionViewMatrix; let u_camera=systemUniforms.camera; let u_cameraMatrix=u_camera.cameraMatrix; let u_cameraPosition=u_camera.cameraPosition; let u_modelMatrix=vertexUniforms.matrixList.modelMatrix; let input_position=inputData.position; let input_vertexNormal=inputData.vertexNormal; let input_uv=inputData.uv; var position:vec4; position=u_modelMatrix * vec4(input_position,1.0); #redgpu_if useDisplacementTexture { let distance=distance(position.xyz,u_cameraPosition); let mipLevel=(distance/maxDistance) * maxMipLevel; let displacedPosition=calcDisplacementPosition( input_position, input_vertexNormal, displacementTexture, displacementTextureSampler, vertexUniforms.displacementScale, input_uv, mipLevel ); position=u_modelMatrix * vec4(displacedPosition,1.0); } #redgpu_endIf output.position=u_directionalLightProjectionViewMatrix * position; return output;\n}\n",normalFunctions:"\nfn cotangent_frame( N:vec3,p:vec3,uv:vec2) -> mat3x3{ let dp1:vec3=dpdx( p ); let dp2:vec3=dpdy( p ); let duv1:vec2=dpdx( uv ); let duv2:vec2=dpdy( uv ); let dp2perp:vec3=cross( dp2,N ); let dp1perp:vec3=cross( N,dp1 ); let T:vec3=dp2perp * duv1.x + dp1perp * duv2.x; let B:vec3=dp2perp * duv1.y + dp1perp * duv2.y; return mat3x3( normalize(T),normalize(B),N );\n}\nfn perturb_normal( N:vec3,position:vec3,texcoord:vec2,normalColor:vec3,normalPower:f32 ) -> vec3 { var map:vec3=normalColor; map=normalColor * 2.0 - 1.0; map=vec3(map.xy * -normalPower,map.z); let TBN:mat3x3=cotangent_frame(N,position,texcoord); return normalize(TBN * map);\n}\n",calcPrePathBackground:"fn calcPrePathBackground( u_useKHR_materials_volume:bool,thicknessParameter:f32,u_KHR_dispersion:f32,u_KHR_attenuationDistance:f32,u_KHR_attenuationColor:vec3, ior:f32,roughnessParameter:f32,albedo:vec3, projectionCameraMatrix:mat4x4,input_vertexPosition:vec3,input_ndcPosition:vec3, V:vec3,N:vec3, renderPath1ResultTexture:texture_2d,renderPath1ResultTextureSampler:sampler\n) -> vec3 { var prePathBackground=vec3(0.0); let maxMipLevel=f32(textureNumLevels(renderPath1ResultTexture) - 1); let transmissionMipLevel=clamp(roughnessParameter * maxMipLevel,0.0,maxMipLevel); if(u_useKHR_materials_volume){ var iorR:f32=ior; var iorG:f32=ior; var iorB:f32=ior; if(u_KHR_dispersion > 0.0){ let halfSpread:f32=(ior - 1.0) * 0.025 * u_KHR_dispersion; iorR=ior + halfSpread; iorG=ior; iorB=ior - halfSpread; } iorR=max(iorR,1.0001); iorG=max(iorG,1.0001); iorB=max(iorB,1.0001); let refractedVecR:vec3=refract(-V,N,1.0/iorR); let refractedVecG:vec3=refract(-V,N,1.0/iorG); let refractedVecB:vec3=refract(-V,N,1.0/iorB); let validR=dot(refractedVecR,refractedVecR) > 0.0; let validG=dot(refractedVecG,refractedVecG) > 0.0; let validB=dot(refractedVecB,refractedVecB) > 0.0; let finalRefractR=select(reflect(-V,N),refractedVecR,validR); let finalRefractG=select(reflect(-V,N),refractedVecG,validG); let finalRefractB=select(reflect(-V,N),refractedVecB,validB); let safeThickness=clamp(thicknessParameter,0.0,100.0); let worldPosR:vec3=input_vertexPosition + finalRefractR * safeThickness; let worldPosG:vec3=input_vertexPosition + finalRefractG * safeThickness; let worldPosB:vec3=input_vertexPosition + finalRefractB * safeThickness; let clipPosR:vec4=projectionCameraMatrix * vec4(worldPosR,1.0); let clipPosG:vec4=projectionCameraMatrix * vec4(worldPosG,1.0); let clipPosB:vec4=projectionCameraMatrix * vec4(worldPosB,1.0); let wR=max(abs(clipPosR.w),0.0001); let wG=max(abs(clipPosG.w),0.0001); let wB=max(abs(clipPosB.w),0.0001); let ndcR:vec2=clipPosR.xy/wR * 0.5 + 0.5; let ndcG:vec2=clipPosG.xy/wG * 0.5 + 0.5; let ndcB:vec2=clipPosB.xy/wB * 0.5 + 0.5; let finalUV_R:vec2=clamp(vec2(ndcR.x,1.0 - ndcR.y),vec2(0.0),vec2(1.0)); let finalUV_G:vec2=clamp(vec2(ndcG.x,1.0 - ndcG.y),vec2(0.0),vec2(1.0)); let finalUV_B:vec2=clamp(vec2(ndcB.x,1.0 - ndcB.y),vec2(0.0),vec2(1.0)); let sampledR=textureSampleLevel(renderPath1ResultTexture,renderPath1ResultTextureSampler,finalUV_R,transmissionMipLevel).r; let sampledG=textureSampleLevel(renderPath1ResultTexture,renderPath1ResultTextureSampler,finalUV_G,transmissionMipLevel).g; let sampledB=textureSampleLevel(renderPath1ResultTexture,renderPath1ResultTextureSampler,finalUV_B,transmissionMipLevel).b; prePathBackground.r=select(0.0,sampledR,isFiniteScalar(sampledR)); prePathBackground.g=select(0.0,sampledG,isFiniteScalar(sampledG)); prePathBackground.b=select(0.0,sampledB,isFiniteScalar(sampledB)); } else { let safeIor=max(ior,1.0001); let refractedVec:vec3=refract(-V,N,1.0/safeIor); let valid=dot(refractedVec,refractedVec) > 0.0; let finalRefract=select(reflect(-V,N),refractedVec,valid); let safeThickness=clamp(thicknessParameter,0.0,100.0); let worldPos:vec3=input_vertexPosition + finalRefract * safeThickness; let clipPos:vec4=projectionCameraMatrix * vec4(worldPos,1.0); let w=max(abs(clipPos.w),0.0001); let ndc:vec2=clipPos.xy/w * 0.5 + 0.5; let finalUV:vec2=clamp(vec2(ndc.x,1.0 - ndc.y),vec2(0.0),vec2(1.0)); let sampled=textureSampleLevel(renderPath1ResultTexture,renderPath1ResultTextureSampler,finalUV,transmissionMipLevel).rgb; prePathBackground=select(vec3(0.0),sampled,all(isFiniteVec3(sampled))); } let safeAlbedo=clamp(albedo,vec3(0.0),vec3(1.0)); prePathBackground *=safeAlbedo; prePathBackground=select(vec3(0.0),prePathBackground,all(isFiniteVec3(prePathBackground))); return prePathBackground;\n}\nfn isFiniteScalar(x:f32) -> bool { return x==x && abs(x) < 1e30;\n}\nfn isFiniteVec3(v:vec3) -> vec3 { return vec3( v.x==v.x && abs(v.x) < 1e30, v.y==v.y && abs(v.y) < 1e30, v.z==v.z && abs(v.z) < 1e30 );\n}",calculateMotionVector:"fn calculateMotionVector( currentClipPos:vec4, prevClipPos:vec4,\n) -> vec2 { let currentNDC=currentClipPos.xy/max(currentClipPos.w,1e-6); let prevNDC=prevClipPos.xy/max(prevClipPos.w,1e-6); var motionVector=currentNDC - prevNDC; motionVector.y=-motionVector.y; let uvMotionVector=motionVector * 0.5; return uvMotionVector;\n}\n",FragmentOutput:"struct FragmentOutput { @location(0) color:vec4, @location(1) gBufferNormal:vec4, @location(2) gBufferMotionVector:vec4,\n}\n",picking:"@vertex\nfn picking(inputData:InputData) -> OutputData { var output:OutputData; let input_position=inputData.position; let u_modelMatrix=vertexUniforms.matrixList.modelMatrix; let u_projectionMatrix=systemUniforms.projectionMatrix; let u_projectionCameraMatrix=systemUniforms.projectionCameraMatrix; let u_camera=systemUniforms.camera; let u_cameraMatrix=u_camera.cameraMatrix; var position:vec4=u_modelMatrix * vec4(input_position,1.0); output.position=u_projectionCameraMatrix * position; output.pickingId=unpack4x8unorm(vertexUniforms.pickingId); return output;\n}\n",drawPicking:"\n@fragment\nfn picking(inputData:InputData) -> @location(0) vec4 { var finalColor:vec4=inputData.pickingId; return finalColor;\n}\n"});Object.freeze(W);const be=Object.freeze({billboardPicking:"@vertex\nfn picking(inputData:InputData) -> OutputData { var output:OutputData; let u_resolution=systemUniforms.resolution; #redgpu_if disableJitter let u_projectionMatrix=systemUniforms.noneJitterProjectionMatrix; #redgpu_else let u_projectionMatrix=systemUniforms.projectionMatrix; #redgpu_endIf let u_cameraMatrix=systemUniforms.camera.cameraMatrix; let u_modelMatrix=vertexUniforms.matrixList.modelMatrix; let u_useBillboard=vertexUniforms.useBillboard; let u_usePixelSize=vertexUniforms.usePixelSize; let u_pixelSize=vertexUniforms.pixelSize; let u_renderRatioX=vertexUniforms._renderRatioX; let u_renderRatioY=vertexUniforms._renderRatioY; var ratioScaleMatrix:mat4x4=mat4x4( u_renderRatioX,0,0,0, 0,u_renderRatioY,0,0, 0,0,1,0, 0,0,0,1 ); if (u_useBillboard==1) { let billboardMatrix=getBillboardMatrix(u_cameraMatrix,u_modelMatrix); if (u_usePixelSize==1) { let viewPositionCenter=billboardMatrix * vec4(0.0,0.0,0.0,1.0); let clipCenter=u_projectionMatrix * viewPositionCenter; let scaleX=(u_pixelSize/u_resolution.x) * 2.0 * u_renderRatioX; let scaleY=(u_pixelSize/u_resolution.y) * 2.0 * u_renderRatioY; output.position=vec4( clipCenter.xy + inputData.position.xy * vec2(scaleX,scaleY) * clipCenter.w, clipCenter.zw ); } else { output.position=u_projectionMatrix * billboardMatrix * ratioScaleMatrix * vec4(inputData.position,1.0); } } else { output.position=u_projectionMatrix * u_cameraMatrix * u_modelMatrix * ratioScaleMatrix * vec4(inputData.position,1.0); } output.pickingId=unpack4x8unorm(vertexUniforms.pickingId); return output;\n}",billboardShadow:"struct OutputShadowData { @builtin(position) position:vec4,\n};\n@vertex\nfn drawDirectionalShadowDepth(inputData:InputData) -> OutputShadowData { var output:OutputShadowData; return output;\n}",calcBillboard:"struct BillboardResult { position:vec4, vertexPosition:vec3, vertexNormal:vec3,\n}\nfn calcBillboard( input_position:vec3, input_normal:vec3, modelMatrix:mat4x4, cameraMatrix:mat4x4, projectionMatrix:mat4x4, resolution:vec2, useBillboard:u32, usePixelSize:u32, pixelSize:f32, renderRatioX:f32, renderRatioY:f32\n) -> BillboardResult { var result:BillboardResult; let ratioScaleMatrix=mat4x4( renderRatioX,0,0,0, 0,renderRatioY,0,0, 0,0,1,0, 0,0,0,1 ); var viewPos:vec4; var viewNormal:vec4; if (useBillboard==1u) { let billboardMatrix=getBillboardMatrix(cameraMatrix,modelMatrix); if (usePixelSize==1u) { let viewCenter=billboardMatrix * vec4(0.0,0.0,0.0,1.0); let clipCenter=projectionMatrix * viewCenter; let scaleX=(pixelSize/resolution.x) * 2.0 * renderRatioX; let scaleY=(pixelSize/resolution.y) * 2.0 * renderRatioY; result.position=vec4( clipCenter.xy + input_position.xy * vec2(scaleX,scaleY) * clipCenter.w, clipCenter.zw ); viewPos=viewCenter; viewNormal=vec4(0.0,0.0,1.0,0.0); } else { viewPos=billboardMatrix * ratioScaleMatrix * vec4(input_position,1.0); viewNormal=vec4(0.0,0.0,1.0,0.0); result.position=projectionMatrix * viewPos; } } else { viewPos=cameraMatrix * modelMatrix * ratioScaleMatrix * vec4(input_position,1.0); viewNormal=cameraMatrix * modelMatrix * ratioScaleMatrix * vec4(input_normal,0.0); result.position=projectionMatrix * viewPos; } result.vertexPosition=viewPos.xyz; result.vertexNormal=normalize(viewNormal.xyz); return result;\n}\n",calcDisplacements:"fn calcDisplacementPosition(input_position:vec3,input_vertexNormal:vec3,displacementTexture:texture_2d,displacementTextureSampler:sampler,displacementScale:f32,input_uv:vec2,mipLevel:f32) -> vec3 { let displacementSample=textureSampleLevel(displacementTexture,displacementTextureSampler,input_uv,mipLevel).r; let scaledDisplacement=(displacementSample - 0.5) * displacementScale; let displacedPosition=input_position + input_vertexNormal * scaledDisplacement; return displacedPosition;\n}\nfn calcDisplacementNormal( input_vertexNormal:vec3, displacementTexture:texture_2d, displacementTextureSampler:sampler, displacementScale:f32, input_uv:vec2, mipLevel:f32\n) -> vec3 { let textureDimensions=vec2(textureDimensions(displacementTexture,0)); let adaptiveOffset=vec2(1.0)/textureDimensions; let actualMipLevel=mipLevel; let center=textureSampleLevel(displacementTexture,displacementTextureSampler,input_uv,actualMipLevel).r; let left=textureSampleLevel(displacementTexture,displacementTextureSampler,input_uv - vec2(adaptiveOffset.x,0.0),actualMipLevel).r; let right=textureSampleLevel(displacementTexture,displacementTextureSampler,input_uv + vec2(adaptiveOffset.x,0.0),actualMipLevel).r; let down=textureSampleLevel(displacementTexture,displacementTextureSampler,input_uv - vec2(0.0,adaptiveOffset.y),actualMipLevel).r; let up=textureSampleLevel(displacementTexture,displacementTextureSampler,input_uv + vec2(0.0,adaptiveOffset.y),actualMipLevel).r; let ddx=((right - 0.5) - (left - 0.5)) * displacementScale/(2.0 * adaptiveOffset.x); let ddy=((up - 0.5) - (down - 0.5)) * displacementScale/(2.0 * adaptiveOffset.y); let tangentSpaceNormal=normalize(vec3(-ddx,-ddy,1.0)); let worldNormal=normalize(input_vertexNormal); let normalStrength=clamp(1.0 - mipLevel * 0.1,0.2,1.0); let blendedNormal=normalize(mix(worldNormal,tangentSpaceNormal,normalStrength * 0.3)); return blendedNormal;\n}\n",getBillboardMatrix:"fn getBillboardMatrix(cameraMatrix:mat4x4,modelMatrix:mat4x4) -> mat4x4 { let scaleX=length(vec3(modelMatrix[0].xyz)); let scaleY=length(vec3(modelMatrix[1].xyz)); let scaleZ=length(vec3(modelMatrix[2].xyz)); let scaleMatrix=mat4x4( vec4(scaleX,0.0,0.0,0.0), vec4(0.0,scaleY,0.0,0.0), vec4(0.0,0.0,scaleZ,0.0), vec4(0.0,0.0,0.0,1.0) ); var resultMatrix=cameraMatrix * modelMatrix; resultMatrix[0][0]=1.0;resultMatrix[0][1]=0.0;resultMatrix[0][2]=0.0; resultMatrix[1][0]=0.0;resultMatrix[1][1]=1.0;resultMatrix[1][2]=0.0; resultMatrix[2][0]=0.0;resultMatrix[2][1]=0.0;resultMatrix[2][2]=1.0; return resultMatrix * scaleMatrix;\n}\nfn getBillboardMatrixNoScaleRatio( cameraMatrix:mat4x4,modelMatrix:mat4x4)-> mat4x4{ var resultMatrix=cameraMatrix * modelMatrix; resultMatrix[0][0]=modelMatrix[0][0];resultMatrix[0][1]=0.0;resultMatrix[0][2]=0.0; resultMatrix[1][0]=0.0;resultMatrix[1][1]=modelMatrix[1][1];resultMatrix[1][2]=0.0; resultMatrix[2][0]=0.0;resultMatrix[2][1]=0.0;resultMatrix[2][2]=modelMatrix[2][2]; return resultMatrix;\n}\n",extractScaleAndTranslation:"fn extractScaleAndTranslation(modelMatrix:mat4x4) -> mat4x4 { let scaleX=length(vec3(modelMatrix[0].xyz)); let scaleY=length(vec3(modelMatrix[1].xyz)); let scaleZ=length(vec3(modelMatrix[2].xyz)); let scaleMatrix=mat4x4( vec4(scaleX,0.0,0.0,0.0), vec4(0.0,scaleY,0.0,0.0), vec4(0.0,0.0,scaleZ,0.0), vec4(0.0,0.0,0.0,1.0) ); return mat4x4( scaleMatrix[0], scaleMatrix[1], scaleMatrix[2], modelMatrix[3] );\n}\n",meshVertexBasicUniform:"struct MatrixList{ localMatrix:mat4x4, modelMatrix:mat4x4, prevModelMatrix:mat4x4, normalModelMatrix:mat4x4,\n}\nstruct VertexUniforms { matrixList:MatrixList, pickingId:u32, receiveShadow:f32, combinedOpacity:f32, useDisplacementTexture:u32, displacementScale:f32, disableJitter:u32, uvTransform:vec4,\n};"});Object.freeze(be);const Ke=Object.freeze({SYSTEM_UNIFORM:"struct DirectionalLight { direction:vec3, color:vec3, intensity:f32,\n};\nstruct AmbientLight { color:vec3, intensity:f32\n};\nstruct Camera { cameraMatrix:mat4x4, cameraPosition:vec3, nearClipping:f32, farClipping:f32\n};\nstruct SystemUniform { projectionMatrix:mat4x4, projectionCameraMatrix:mat4x4, noneJitterProjectionMatrix:mat4x4, noneJitterProjectionCameraMatrix:mat4x4, inverseProjectionMatrix:mat4x4, prevNoneJitterProjectionCameraMatrix:mat4x4, resolution:vec2, camera:Camera, time:f32, usePrefilterTexture:u32, isView3D:u32, shadowDepthTextureSize:u32, bias:f32, directionalLightCount:u32, directionalLightProjectionViewMatrix:mat4x4, directionalLightProjectionMatrix:mat4x4, directionalLightViewMatrix:mat4x4, directionalLights:array, ambientLight:AmbientLight,\n};\n@group(0) @binding(0) var systemUniforms:SystemUniform;\n@group(0) @binding(1) var directionalShadowMapSampler:sampler_comparison;\n@group(0) @binding(2) var directionalShadowMap:texture_depth_2d;\n@group(0) @binding(3) var prefilterTextureSampler:sampler;\n@group(0) @binding(7) var renderPath1ResultTextureSampler:sampler;\n@group(0) @binding(8) var renderPath1ResultTexture:texture_2d;\n@group(0) @binding(9) var packedTextureSampler:sampler;\n@group(0) @binding(10) var ibl_environmentTexture:texture_cube;\n@group(0) @binding(11) var ibl_irradianceTexture:texture_cube;\n@group(0) @binding(12) var ibl_brdfLUTTexture:texture_2d;\nconst clusterLight_indicesLength:u32=u32(REDGPU_DEFINE_MAX_LIGHTS_PER_CLUSTERu * REDGPU_DEFINE_TOTAL_TILESu);\nconst clusterLight_tileCount=vec3(REDGPU_DEFINE_TILE_COUNT_Xu,REDGPU_DEFINE_TILE_COUNT_Yu,REDGPU_DEFINE_TILE_COUNT_Zu);\nstruct ClusterLights { offset:u32, count:u32\n};\nstruct ClusterLightsGroup { offset:atomic, lights:array, indices:array\n};\nstruct ClusterLight_ClusterCube { minAABB:vec4, maxAABB:vec4 };\nstruct ClusterLight_Clusters { cubeList:array\n};\nfn linearDepth(depthSample:f32) -> f32 { return systemUniforms.camera.farClipping*systemUniforms.camera.nearClipping/fma(depthSample,systemUniforms.camera.nearClipping-systemUniforms.camera.farClipping,systemUniforms.camera.farClipping);\n}\nfn getClusterLightClusterIndex(fragCoord:vec4) -> u32 { let tile=getClusterLightTile(fragCoord); return tile.x + tile.y * clusterLight_tileCount.x + tile.z * clusterLight_tileCount.x * clusterLight_tileCount.y;\n}\nfn getClusterLightTile(fragCoord:vec4) -> vec3 { let sliceScale=f32(clusterLight_tileCount.z)/log2(systemUniforms.camera.farClipping/systemUniforms.camera.nearClipping); let sliceBias=-(f32(clusterLight_tileCount.z) * log2(systemUniforms.camera.nearClipping)/log2(systemUniforms.camera.farClipping/systemUniforms.camera.nearClipping)); let zTile=u32(max(log2(linearDepth(fragCoord.z)) * sliceScale + sliceBias,0.0)); return vec3(u32(fragCoord.x/(systemUniforms.resolution.x/f32(clusterLight_tileCount.x))), u32(fragCoord.y/(systemUniforms.resolution.y/f32(clusterLight_tileCount.y))), zTile);\n}\nstruct ClusterLight { position:vec3,radius:f32, color:vec3,intensity:f32, isSpotLight:f32,directionX:f32,directionY:f32,directionZ:f32, outerCutoff:f32,innerCutoff:f32,\n};\nstruct ClusterLightList { count:vec4, lights:array\n};\n@group(0) @binding(5) var clusterLightList:ClusterLightList;\n@group(0) @binding(6) var clusterLightGroup:ClusterLightsGroup;\n",...be,...W});Object.freeze(Ke);class ShaderVariantGenerator{#Ee=new Map;#De;#Ue;#Le=[];#Ae=[];#Ge=new Map;#ke=new Map;constructor(i,g){this.#De=i,this.#Ue=g}setBaseInfo(i,g){this.#Le=i,this.#Ae=g}addConditionalInfo(i,g,x){this.#Ge.set(i,g),this.#ke.set(i,x)}getVariantTextures(i){const g="none"===i?[]:i.split("+"),x=[...this.#Le];return g.forEach(i=>{const g=this.#Ge.get(i);g&&g.forEach(i=>{x.find(g=>g.name===i.name)||x.push(i)})}),x}getVariantSamplers(i){const g="none"===i?[]:i.split("+"),x=[...this.#Ae];return g.forEach(i=>{const g=this.#ke.get(i);g&&g.forEach(i=>{x.find(g=>g.name===i.name)||x.push(i)})}),x}getUnionTextures(){const i=[...this.#Le];return this.#Ge.forEach(g=>{g.forEach(g=>{i.find(i=>i.name===g.name)||i.push(g)})}),i}getUnionSamplers(){const i=[...this.#Ae];return this.#ke.forEach(g=>{g.forEach(g=>{i.find(i=>i.name===g.name)||i.push(g)})}),i}getVariant(i){if(this.#Ee.has(i))return this.#Ee.get(i);const g="none"===i?[]:i.split("+"),x=this.#Oe(g);return this.#Ee.set(i,x),x}getCachedVariants(){return Array.from(this.#Ee.keys())}#Oe(i){let g=this.#De;for(let x=this.#Ue.length-1;x>=0;x--){const _=this.#Ue[x];g=i.includes(_.uniformName)?g.replace(_.fullMatch,_.ifBlock):g.replace(_.fullMatch,_.elseBlock||"")}return g}}const Xe=Object.keys(Ke).join("|"),je=new RegExp(`#redgpu_include (${Xe})`,"g"),Ye=/REDGPU_DEFINE_(?:TILE_COUNT_[XYZ]|TOTAL_TILES|WORKGROUP_SIZE_[XYZ]|MAX_LIGHTS_PER_CLUSTER)/g,Ze={REDGPU_DEFINE_TILE_COUNT_X:q.TILE_COUNT_X.toString(),REDGPU_DEFINE_TILE_COUNT_Y:q.TILE_COUNT_Y.toString(),REDGPU_DEFINE_TILE_COUNT_Z:q.TILE_COUNT_Z.toString(),REDGPU_DEFINE_TOTAL_TILES:q.getTotalTileSize().toString(),REDGPU_DEFINE_WORKGROUP_SIZE_X:q.WORKGROUP_SIZE_X.toString(),REDGPU_DEFINE_WORKGROUP_SIZE_Y:q.WORKGROUP_SIZE_Y.toString(),REDGPU_DEFINE_WORKGROUP_SIZE_Z:q.WORKGROUP_SIZE_Z.toString(),REDGPU_DEFINE_MAX_LIGHTS_PER_CLUSTER:q.MAX_LIGHTS_PER_CLUSTER.toString()},Je=new Map,preprocessWGSL=i=>{const g=(i=>{let g=0;for(let x=0;x{let g=i,x=0;for(;x<10;){const i=g;if(g=g.replace(je,(i,g)=>Ke[g]||i),g===i)break;x++}return g})(i),v=(i=>i.replace(Ye,i=>Ze[i]||i))(_),b=(i=>{const g=[],x=/#redgpu_if\s+(\w+)\b|#redgpu_else|#redgpu_endIf/g,_=[];let v,b=0;for(;null!==(v=x.exec(i));){const x=v[0];if(x.startsWith("#redgpu_if"))_.push({uniformName:v[1],startIndex:v.index,headerLength:x.length});else if("#redgpu_else"===x){const i=_[_.length-1];if(!i)throw new Error(`[preprocessWGSL] Mismatched #redgpu_else at index ${v.index}`);void 0===i.elseIndex&&(i.elseIndex=v.index)}else if("#redgpu_endIf"===x){const y=_.pop();if(!y)throw new Error(`[preprocessWGSL] Mismatched #redgpu_endIf at index ${v.index}`);{const _=i.substring(y.startIndex,v.index+x.length);let S,w;void 0!==y.elseIndex?(S=i.substring(y.startIndex+y.headerLength,y.elseIndex),w=i.substring(y.elseIndex+12,v.index)):S=i.substring(y.startIndex+y.headerLength,v.index),g.push({uniformName:y.uniformName,ifBlock:S.trim(),elseBlock:w?.trim(),fullMatch:_,blockIndex:b++})}}}if(_.length>0)throw new Error(`[preprocessWGSL] Unclosed #redgpu_if for:${_.map(i=>i.uniformName).join(",")}`);return g})(v);(i=>{if(!i.length)return;const g=new Map;i.forEach(i=>{g.set(i.uniformName,(g.get(i.uniformName)||0)+1)}),Array.from(g.entries()).filter(([i,g])=>g>1).length})(b);const y=[...new Set(b.map(i=>i.uniformName))],S=new ShaderVariantGenerator(v,b),w={cacheKey:g,defaultSource:S.getVariant("none"),shaderSourceVariant:S,conditionalBlocks:y,conditionalBlockInfos:b};return Math.pow(2,y.length),Je.set(g,w),w};class ResourceStatusInfo{table=new Map;videoMemory=0;constructor(){}}var Qe;Object.freeze(ResourceStatusInfo),function(i){i.GPUShaderModule="GPUShaderModule",i.GPUBindGroupLayout="GPUBindGroupLayout",i.GPUPipelineLayout="GPUPipelineLayout",i.GPUBuffer="GPUBuffer"}(Qe||(Qe={}));class ResourceManager{static PRESET_GPUBindGroupLayout_System="PRESET_GPUBindGroupLayout_System";static PRESET_VERTEX_GPUBindGroupLayout_Instancing="PRESET_VERTEX_GPUBindGroupLayout_Instancing";static PRESET_VERTEX_GPUBindGroupLayout="PRESET_VERTEX_GPUBindGroupLayout";static PRESET_VERTEX_GPUBindGroupLayout_SKIN="PRESET_VERTEX_GPUBindGroupLayout_SKIN";#Ne=0;#Ve=new ImmutableKeyMap([[Qe.GPUShaderModule,new Map],[Qe.GPUBindGroupLayout,new Map],[Qe.GPUPipelineLayout,new Map],[Qe.GPUBuffer,new MemoryTrackingMap]]);#Fe=new ResourceStatusInfo;#He=new ResourceStatusInfo;#ze=new ResourceStatusInfo;#$e=new ResourceStatusInfo;#Ke=new ResourceStatusInfo;#Xe=new ResourceStatusInfo;#je=new ResourceStatusInfo;#Ye={};#qe;#We;#Ze;#Je;#Qe;#et;#tt;#nt;#rt;#it=new WeakMap;#at=new WeakMap;#l;#c;constructor(i){this.#l=i,this.#c=i.gpuDevice,this.#Ze=new MipmapGenerator(i),this.#Je=new DownSampleCubeMapGenerator(i),this.#Qe=new BRDFGenerator(i),this.#et=new IrradianceGenerator(i),this.#tt=new PrefilterGenerator(i),this.#nt=new EquirectangularToCubeGenerator(i),this.#st()}get redGPUContext(){return this.#l}get gpuDevice(){return this.#c}get basicSampler(){return this.#rt}get brdfGenerator(){return this.#Qe}get irradianceGenerator(){return this.#et}get prefilterGenerator(){return this.#tt}get equirectangularToCubeGenerator(){return this.#nt}get mipmapGenerator(){return this.#Ze}get downSampleCubeMapGenerator(){return this.#Je}get cachedBufferState(){return this.#Ye}get emptyBitmapTextureView(){return this.#qe}get emptyCubeTextureView(){return this.#We}get managedBitmapTextureState(){return this.#Fe}get managedCubeTextureState(){return this.#He}get managedHDRTextureState(){return this.#ze}get managedUniformBufferState(){return this.#$e}get managedVertexBufferState(){return this.#Ke}get managedIndexBufferState(){return this.#Xe}get managedStorageBufferState(){return this.#je}get resources(){return this.#Ve}registerManagementResource(i,x){const{cacheKey:_,targetResourceManagedState:v}=i,{table:b}=v;b.get(_)?g(`Resource with cacheKey ${_} is already registered.`):(b.set(_,x),v.videoMemory+=i.videoMemorySize)}unregisterManagementResource(i){const{cacheKey:g,targetResourceManagedState:x}=i,{table:_}=x;_.get(g)&&(x.videoMemory-=i.videoMemorySize,_.delete(g))}createManagedTexture(i){const g=this.gpuDevice.createTexture(i),x=g.destroy.bind(g);return g.destroy=()=>{this.#ot(g,i),x()},g}getGPUResourceBitmapTextureView(i,g){const x=i instanceof GPUTexture?i:i?.gpuTexture;if(!x)return this.#qe;let _=this.#it.get(x);_||(_=new Map,this.#it.set(x,_));const v=this.#ut(g);let b=_.get(v);if(!b){const i=g?{...g,label:g.label||x.label}:{label:x.label};b=x.createView(i),_.set(v,b)}return b}getGPUResourceCubeTextureView(i,g){const x=i instanceof GPUTexture?i:i?.gpuTexture;if(!x)return this.#We;let _=this.#at.get(x);_||(_=new Map,this.#at.set(x,_)),i instanceof GPUTexture||g||(g=i.viewDescriptor);const v=g||CubeTexture.defaultViewDescriptor,b=this.#ut(v);let y=_.get(b);if(!y){const i={...v,label:x.label};y=x.createView(i),_.set(b,y)}return y}createGPUShaderModule(i,g){return this.#lt(i,g,g=>this.#ct(i,g),Qe.GPUShaderModule)}getGPUShaderModule(i){return this.#ht(i,Qe.GPUShaderModule)}deleteGPUShaderModule(i){this.#ft(i,Qe.GPUShaderModule)}createBindGroupLayout(i,g){return this.#lt(i,g,g=>(g.label||(g.label=i),this.redGPUContext.gpuDevice.createBindGroupLayout(g)),Qe.GPUBindGroupLayout)}getGPUBindGroupLayout(i){return this.#ht(i,Qe.GPUBindGroupLayout)}deleteGPUBindGroupLayout(i){this.#ft(i,Qe.GPUBindGroupLayout)}createGPUPipelineLayout(i,g){return this.#lt(i,g,g=>(g.label||(g.label=i),this.redGPUContext.gpuDevice.createPipelineLayout(g)),Qe.GPUPipelineLayout)}createGPUBuffer(i,g){return this.#lt(i,g,g=>(g.label||(g.label=i),this.gpuDevice.createBuffer(g)),Qe.GPUBuffer)}#ot(i,g){const x="3d"===g.dimension?this.#at:this.#it;x.get(i)?.clear(),x.delete(i)}#ut(i){return i?JSON.stringify(i):"default"}#st(){const{gpuDevice:i}=this.redGPUContext;{const g=i.createTexture({size:{width:1,height:1,depthOrArrayLayers:1},format:"rgba8unorm",usage:GPUTextureUsage.TEXTURE_BINDING|GPUTextureUsage.COPY_DST|GPUTextureUsage.STORAGE_BINDING,label:"EMPTY_BITMAP_TEXTURE"});this.#qe=g.createView({label:g.label});const x=new Uint8Array([0,0,0,0]);i.queue.writeTexture({texture:g},x,{bytesPerRow:4,rowsPerImage:1},{width:1,height:1,depthOrArrayLayers:1});const _=i.createTexture({size:{width:1,height:1,depthOrArrayLayers:6},format:"rgba8unorm",usage:GPUTextureUsage.RENDER_ATTACHMENT|GPUTextureUsage.TEXTURE_BINDING|GPUTextureUsage.COPY_DST,label:"EMPTY_CUBE_TEXTURE"});this.#We=_.createView(CubeTexture.defaultViewDescriptor);const v=new Uint8Array([0,0,0,0]);for(let g=0;g<6;g++)i.queue.writeTexture({texture:_,origin:{x:0,y:0,z:g}},v,{bytesPerRow:4,rowsPerImage:1},{width:1,height:1,depthOrArrayLayers:1});this.#rt=new Sampler(this.redGPUContext)}this.createBindGroupLayout(ResourceManager.PRESET_GPUBindGroupLayout_System,{entries:[{binding:0,visibility:GPUShaderStage.VERTEX|GPUShaderStage.FRAGMENT|GPUShaderStage.COMPUTE,buffer:{type:"uniform"}},{binding:1,visibility:GPUShaderStage.VERTEX|GPUShaderStage.FRAGMENT,sampler:{type:"comparison"}},{binding:2,visibility:GPUShaderStage.FRAGMENT,texture:{sampleType:"depth"}},{binding:3,visibility:GPUShaderStage.FRAGMENT,sampler:{type:"filtering"}},{binding:5,visibility:GPUShaderStage.FRAGMENT|GPUShaderStage.COMPUTE,buffer:{type:"read-only-storage"}},{binding:6,visibility:GPUShaderStage.FRAGMENT|GPUShaderStage.COMPUTE,buffer:{type:"storage"}},{binding:7,visibility:GPUShaderStage.FRAGMENT,sampler:{type:"filtering"}},{binding:8,visibility:GPUShaderStage.FRAGMENT,texture:{}},{binding:9,visibility:GPUShaderStage.FRAGMENT,sampler:{type:"filtering"}},{binding:10,visibility:GPUShaderStage.FRAGMENT,texture:{viewDimension:"cube"}},{binding:11,visibility:GPUShaderStage.FRAGMENT,texture:{viewDimension:"cube"}},{binding:12,visibility:GPUShaderStage.FRAGMENT,texture:{}}]}),this.createBindGroupLayout(ResourceManager.PRESET_VERTEX_GPUBindGroupLayout,{entries:[{binding:0,visibility:GPUShaderStage.VERTEX,buffer:{type:"uniform"}},{binding:1,visibility:GPUShaderStage.VERTEX,sampler:{type:"filtering"}},{binding:2,visibility:GPUShaderStage.VERTEX,texture:{}}]}),this.createBindGroupLayout(ResourceManager.PRESET_VERTEX_GPUBindGroupLayout_SKIN,{entries:[{binding:0,visibility:GPUShaderStage.VERTEX,buffer:{type:"uniform"}},{binding:1,visibility:GPUShaderStage.VERTEX,sampler:{type:"filtering"}},{binding:2,visibility:GPUShaderStage.VERTEX,texture:{}},{binding:3,visibility:GPUShaderStage.VERTEX,buffer:{type:"read-only-storage"}},{binding:4,visibility:GPUShaderStage.VERTEX,buffer:{type:"read-only-storage"}}]}),this.createBindGroupLayout(ResourceManager.PRESET_VERTEX_GPUBindGroupLayout_Instancing,{entries:[{binding:0,visibility:GPUShaderStage.VERTEX,buffer:{type:"read-only-storage"}},{binding:1,visibility:GPUShaderStage.VERTEX,sampler:{type:"filtering"}},{binding:2,visibility:GPUShaderStage.VERTEX,texture:{}},{binding:3,visibility:GPUShaderStage.VERTEX,buffer:{type:"read-only-storage"}}]})}#dt(i){return this.#Ve.get(i)}#ct(i,g){const{code:x}=g,_=preprocessWGSL(x).defaultSource,v=this.redGPUContext.gpuDevice.createShaderModule({...g,code:_});return this.#dt(Qe.GPUShaderModule).set(i,v),v}#mt(i,g){if(!i)throw new Error("Name is required");return this.#dt(g)}#lt(i,g,x,_){const v=this.#mt(i,_);if(v.has(i))return v.get(i);g.label||(g.label=i);const b=x(g);return v.set(i,b),b}#ht(i,g){return this.#mt(i,g).get(i)}#ft(i,g){const x=this.#mt(i,g);if(!x.has(i))throw new Error(`${g} with name ${i} doesn't exist.`);x.delete(i)}}Object.freeze(BitmapTexture);class ImmutableKeyMap extends Map{constructor(i=[]){super(),i?.forEach(([i,g])=>super.set(i,g))}set(i,g){if(this.has(i))throw new Error("Cannot change the value of an existing key");return super.set(i,g)}}class MemoryTrackingMap extends Map{#pt=0;constructor(){super()}get videoMemory(){return this.#pt}set(i,g){const x=g&&"videoMemorySize"in g?"videoMemorySize":g&&"size"in g?"size":void 0;if(this.has(i)){const g=this.get(i);g&&g[x]&&(this.#pt-=g[x])}g&&g&&(this.#pt+=g[x]);return super.set(i,g)}delete(i){if(this.has(i)){const g=this.get(i),x=g&&"videoMemorySize"in g?"videoMemorySize":g&&"size"in g?"size":void 0;g&&g[x]&&(this.#pt-=g[x])}return super.delete(i)}clear(){this.#pt=0,super.clear()}}class AntialiasingManager{#l;#gt;#xt=!0;#_t=!1;#vt=!1;#bt=!0;constructor(i){this.#l=i,window.devicePixelRatio>1?this.useTAA=!0:this.useMSAA=!0}get useTAA(){return this.#vt}set useTAA(i){this.#vt!==i&&(this.#yt(),this.#vt=i)}get useMSAA(){return this.#xt}set useMSAA(i){this.#xt!==i&&(this.#yt(),this.#gt=createUUID(),this.#xt=i,this.#bt=!0)}get useFXAA(){return this.#_t}set useFXAA(i){this.#_t!==i&&(this.#yt(),this.#_t=i)}get changedMSAA(){return this.#bt}set changedMSAA(i){this.#bt=i}get msaaID(){return this.#gt}#yt(){this.#xt=!1,this.#_t=!1,this.#vt=!1}}Object.freeze(AntialiasingManager);class RedGPUContextDetector{#St;#Tt;#Mt;#wt;#Ct;constructor(i){this.#ne(i.gpuAdapter)}get adapterInfo(){return this.#St}get limits(){return this.#Tt}get isFallbackAdapter(){return this.#Mt}get groupedLimits(){return this.#wt}get userAgent(){return this.#Ct}get isMobile(){return/Android|webOS|iPhone|iPad|iPod|BlackBerry|IEMobile|Opera Mini|Windows Phone|Kindle|Silk|PlayBook/i.test(navigator.userAgent)}#ne(i){this.#Ct=navigator.userAgent,this.#Rt(i),this.#Pt()}#Rt(i){if(i){const{limits:g,info:x}=i,{isFallbackAdapter:_}=x;this.#St=x,this.#Mt=_,this.#Tt=g}}#Pt(){const i={TextureLimits:["maxTextureDimension1D","maxTextureDimension2D","maxTextureDimension3D","maxTextureArrayLayers","maxSampledTexturesPerShaderStage","maxSamplersPerShaderStage"],BufferLimits:["maxBindGroups","maxBindGroupsPlusVertexBuffers","maxBindingsPerBindGroup","maxDynamicUniformBuffersPerPipelineLayout","maxDynamicStorageBuffersPerPipelineLayout","maxStorageBuffersPerShaderStage","maxStorageTexturesPerShaderStage","maxUniformBuffersPerShaderStage","maxUniformBufferBindingSize","maxStorageBufferBindingSize","minUniformBufferOffsetAlignment","minStorageBufferOffsetAlignment","maxBufferSize"],PipelineAndShaderLimits:["maxVertexBuffers","maxVertexAttributes","maxVertexBufferArrayStride","maxInterStageShaderComponents","maxInterStageShaderVariables"],ComputeLimits:["maxComputeWorkgroupStorageSize","maxComputeInvocationsPerWorkgroup","maxComputeWorkgroupSizeX","maxComputeWorkgroupSizeY","maxComputeWorkgroupSizeZ","maxComputeWorkgroupsPerDimension"],ColorLimits:["maxColorAttachments","maxColorAttachmentBytesPerSample"]},g={TextureLimits:{},BufferLimits:{},PipelineAndShaderLimits:{},ComputeLimits:{},ColorLimits:{},EtcLimit:{}};for(const x in this.#Tt){let _=!1;for(const v in i)if(i[v].includes(x)){g[v][x]=this.#Tt[x],_=!0;break}_||(g.EtcLimit[x]=this.#Tt[x])}this.#wt=g}}const validateNumber=i=>"number"==typeof i||(consoleAndThrowError("Only numbers allowed."),!1);class RedGPUContextSizeManager{#Bt;#It;#l;#Et=[0,0,0,0];#Dt;#Ut=1;constructor(i,g="100%",x="100%"){this.#l=i,this.#Dt=i.htmlCanvas,this.#Dt.style.boxSizing="border-box",this.#Bt=g,this.#It=x}get renderScale(){return this.#Ut}set renderScale(i){validateNumber(i),i<=0&&(i=.01),this.#Ut=i,this.setSize()}get width(){return this.#Bt}set width(i){this.setSize(i,this.#It)}get height(){return this.#It}set height(i){this.setSize(this.#Bt,i)}get pixelRectArray(){return this.#Et}get pixelRectObject(){return{x:this.#Et[0],y:this.#Et[1],width:this.#Et[2],height:this.#Et[3]}}get parentDomRect(){return(this.#Dt.parentNode||document.body).getBoundingClientRect()}get screenRectObject(){return{x:this.#Et[0]/devicePixelRatio,y:this.#Et[1]/devicePixelRatio,width:this.#Et[2]/devicePixelRatio,height:this.#Et[3]/devicePixelRatio}}static validateSizeValue=i=>{switch(typeof i){case"number":validatePositiveNumberRange(i);break;case"string":new RegExp(/^[+]?^[.]?(\d+)(\.\d+)?(?:px|%|$)/gm).test(i)||consoleAndThrowError(`allow positive number,%,px model/input:${i}`);break;default:consoleAndThrowError(`positive number,%,px model/input:${i}`)}};static validatePositionValue=i=>{switch(typeof i){case"number":validateNumber(i);break;case"string":new RegExp(/^-?\d+(\.\d+)?(px|%)?$/).test(i)||consoleAndThrowError(`allow number,%,px model /input:${i}`);break;default:consoleAndThrowError(`number,%,px model/input:${i}`)}};static getPixelDimension(i,g,x){return"number"==typeof x?x:RedGPUContextSizeManager.calculateSizeFromString(i,g,x)}static calculateSizeFromString(i,g,x){return x.includes("%")?Math.floor(i[g]*+x.replace("%","")/100):+x.replace("px","")}setSize(i=this.#Bt,g=this.#It){RedGPUContextSizeManager.validateSizeValue(i),RedGPUContextSizeManager.validateSizeValue(g),this.#Bt=i,this.#It=g;const x=RedGPUContextSizeManager.getPixelDimension(this.parentDomRect,"width",i),_=RedGPUContextSizeManager.getPixelDimension(this.parentDomRect,"height",g);this.#Lt(x,_),this.#At(x,_),this.#Gt()}#At(i,g){this.#Et[2]=Math.max(1,Math.floor(i*this.#Ut*window.devicePixelRatio)),this.#Et[3]=Math.max(1,Math.floor(g*this.#Ut*window.devicePixelRatio))}#Gt(){this.#l.onResize&&this.#l.onResize({target:this.#l,screenRectObject:this.screenRectObject,pixelRectObject:this.pixelRectObject}),this.#l.viewList.forEach(i=>{i.setSize(),i.setPosition()})}#Lt(i,g){const x=this.#Dt,{style:_}=x;x.width=Math.max(1,i*this.#Ut*window.devicePixelRatio),x.height=Math.max(1,g*this.#Ut*window.devicePixelRatio),_.width=`${i}px`,_.height=`${g}px`}}var et=1e-6,tt="undefined"!=typeof Float32Array?Float32Array:Array,it=Math.random;function round$3(i){return i>=0?Math.round(i):i%.5==0?Math.floor(i):Math.round(i)}function create$5(){var i=new tt(9);return tt!=Float32Array&&(i[1]=0,i[2]=0,i[3]=0,i[5]=0,i[6]=0,i[7]=0),i[0]=1,i[4]=1,i[8]=1,i}function multiply$5(i,g,x){var _=g[0],v=g[1],b=g[2],y=g[3],S=g[4],w=g[5],L=g[6],k=g[7],H=g[8],z=x[0],q=x[1],W=x[2],be=x[3],Ke=x[4],Xe=x[5],je=x[6],Ye=x[7],Ze=x[8];return i[0]=z*_+q*y+W*L,i[1]=z*v+q*S+W*k,i[2]=z*b+q*w+W*H,i[3]=be*_+Ke*y+Xe*L,i[4]=be*v+Ke*S+Xe*k,i[5]=be*b+Ke*w+Xe*H,i[6]=je*_+Ye*y+Ze*L,i[7]=je*v+Ye*S+Ze*k,i[8]=je*b+Ye*w+Ze*H,i}function subtract$4(i,g,x){return i[0]=g[0]-x[0],i[1]=g[1]-x[1],i[2]=g[2]-x[2],i[3]=g[3]-x[3],i[4]=g[4]-x[4],i[5]=g[5]-x[5],i[6]=g[6]-x[6],i[7]=g[7]-x[7],i[8]=g[8]-x[8],i}var ft=multiply$5,pt=subtract$4,xt=Object.freeze({__proto__:null,add:function(i,g,x){return i[0]=g[0]+x[0],i[1]=g[1]+x[1],i[2]=g[2]+x[2],i[3]=g[3]+x[3],i[4]=g[4]+x[4],i[5]=g[5]+x[5],i[6]=g[6]+x[6],i[7]=g[7]+x[7],i[8]=g[8]+x[8],i},adjoint:function(i,g){var x=g[0],_=g[1],v=g[2],b=g[3],y=g[4],S=g[5],w=g[6],L=g[7],k=g[8];return i[0]=y*k-S*L,i[1]=v*L-_*k,i[2]=_*S-v*y,i[3]=S*w-b*k,i[4]=x*k-v*w,i[5]=v*b-x*S,i[6]=b*L-y*w,i[7]=_*w-x*L,i[8]=x*y-_*b,i},clone:function(i){var g=new tt(9);return g[0]=i[0],g[1]=i[1],g[2]=i[2],g[3]=i[3],g[4]=i[4],g[5]=i[5],g[6]=i[6],g[7]=i[7],g[8]=i[8],g},copy:function(i,g){return i[0]=g[0],i[1]=g[1],i[2]=g[2],i[3]=g[3],i[4]=g[4],i[5]=g[5],i[6]=g[6],i[7]=g[7],i[8]=g[8],i},create:create$5,determinant:function(i){var g=i[0],x=i[1],_=i[2],v=i[3],b=i[4],y=i[5],S=i[6],w=i[7],L=i[8];return g*(L*b-y*w)+x*(-L*v+y*S)+_*(w*v-b*S)},equals:function(i,g){var x=i[0],_=i[1],v=i[2],b=i[3],y=i[4],S=i[5],w=i[6],L=i[7],k=i[8],H=g[0],z=g[1],q=g[2],W=g[3],be=g[4],Ke=g[5],Xe=g[6],je=g[7],Ye=g[8];return Math.abs(x-H)<=et*Math.max(1,Math.abs(x),Math.abs(H))&&Math.abs(_-z)<=et*Math.max(1,Math.abs(_),Math.abs(z))&&Math.abs(v-q)<=et*Math.max(1,Math.abs(v),Math.abs(q))&&Math.abs(b-W)<=et*Math.max(1,Math.abs(b),Math.abs(W))&&Math.abs(y-be)<=et*Math.max(1,Math.abs(y),Math.abs(be))&&Math.abs(S-Ke)<=et*Math.max(1,Math.abs(S),Math.abs(Ke))&&Math.abs(w-Xe)<=et*Math.max(1,Math.abs(w),Math.abs(Xe))&&Math.abs(L-je)<=et*Math.max(1,Math.abs(L),Math.abs(je))&&Math.abs(k-Ye)<=et*Math.max(1,Math.abs(k),Math.abs(Ye))},exactEquals:function(i,g){return i[0]===g[0]&&i[1]===g[1]&&i[2]===g[2]&&i[3]===g[3]&&i[4]===g[4]&&i[5]===g[5]&&i[6]===g[6]&&i[7]===g[7]&&i[8]===g[8]},frob:function(i){return Math.sqrt(i[0]*i[0]+i[1]*i[1]+i[2]*i[2]+i[3]*i[3]+i[4]*i[4]+i[5]*i[5]+i[6]*i[6]+i[7]*i[7]+i[8]*i[8])},fromMat2d:function(i,g){return i[0]=g[0],i[1]=g[1],i[2]=0,i[3]=g[2],i[4]=g[3],i[5]=0,i[6]=g[4],i[7]=g[5],i[8]=1,i},fromMat4:function(i,g){return i[0]=g[0],i[1]=g[1],i[2]=g[2],i[3]=g[4],i[4]=g[5],i[5]=g[6],i[6]=g[8],i[7]=g[9],i[8]=g[10],i},fromQuat:function(i,g){var x=g[0],_=g[1],v=g[2],b=g[3],y=x+x,S=_+_,w=v+v,L=x*y,k=_*y,H=_*S,z=v*y,q=v*S,W=v*w,be=b*y,Ke=b*S,Xe=b*w;return i[0]=1-H-W,i[3]=k-Xe,i[6]=z+Ke,i[1]=k+Xe,i[4]=1-L-W,i[7]=q-be,i[2]=z-Ke,i[5]=q+be,i[8]=1-L-H,i},fromRotation:function(i,g){var x=Math.sin(g),_=Math.cos(g);return i[0]=_,i[1]=x,i[2]=0,i[3]=-x,i[4]=_,i[5]=0,i[6]=0,i[7]=0,i[8]=1,i},fromScaling:function(i,g){return i[0]=g[0],i[1]=0,i[2]=0,i[3]=0,i[4]=g[1],i[5]=0,i[6]=0,i[7]=0,i[8]=1,i},fromTranslation:function(i,g){return i[0]=1,i[1]=0,i[2]=0,i[3]=0,i[4]=1,i[5]=0,i[6]=g[0],i[7]=g[1],i[8]=1,i},fromValues:function(i,g,x,_,v,b,y,S,w){var L=new tt(9);return L[0]=i,L[1]=g,L[2]=x,L[3]=_,L[4]=v,L[5]=b,L[6]=y,L[7]=S,L[8]=w,L},identity:function(i){return i[0]=1,i[1]=0,i[2]=0,i[3]=0,i[4]=1,i[5]=0,i[6]=0,i[7]=0,i[8]=1,i},invert:function(i,g){var x=g[0],_=g[1],v=g[2],b=g[3],y=g[4],S=g[5],w=g[6],L=g[7],k=g[8],H=k*y-S*L,z=-k*b+S*w,q=L*b-y*w,W=x*H+_*z+v*q;return W?(W=1/W,i[0]=H*W,i[1]=(-k*_+v*L)*W,i[2]=(S*_-v*y)*W,i[3]=z*W,i[4]=(k*x-v*w)*W,i[5]=(-S*x+v*b)*W,i[6]=q*W,i[7]=(-L*x+_*w)*W,i[8]=(y*x-_*b)*W,i):null},mul:ft,multiply:multiply$5,multiplyScalar:function(i,g,x){return i[0]=g[0]*x,i[1]=g[1]*x,i[2]=g[2]*x,i[3]=g[3]*x,i[4]=g[4]*x,i[5]=g[5]*x,i[6]=g[6]*x,i[7]=g[7]*x,i[8]=g[8]*x,i},multiplyScalarAndAdd:function(i,g,x,_){return i[0]=g[0]+x[0]*_,i[1]=g[1]+x[1]*_,i[2]=g[2]+x[2]*_,i[3]=g[3]+x[3]*_,i[4]=g[4]+x[4]*_,i[5]=g[5]+x[5]*_,i[6]=g[6]+x[6]*_,i[7]=g[7]+x[7]*_,i[8]=g[8]+x[8]*_,i},normalFromMat4:function(i,g){var x=g[0],_=g[1],v=g[2],b=g[3],y=g[4],S=g[5],w=g[6],L=g[7],k=g[8],H=g[9],z=g[10],q=g[11],W=g[12],be=g[13],Ke=g[14],Xe=g[15],je=x*S-_*y,Ye=x*w-v*y,Ze=x*L-b*y,Je=_*w-v*S,Qe=_*L-b*S,et=v*L-b*w,tt=k*be-H*W,it=k*Ke-z*W,ft=k*Xe-q*W,pt=H*Ke-z*be,xt=H*Xe-q*be,vt=z*Xe-q*Ke,bt=je*vt-Ye*xt+Ze*pt+Je*ft-Qe*it+et*tt;return bt?(bt=1/bt,i[0]=(S*vt-w*xt+L*pt)*bt,i[1]=(w*ft-y*vt-L*it)*bt,i[2]=(y*xt-S*ft+L*tt)*bt,i[3]=(v*xt-_*vt-b*pt)*bt,i[4]=(x*vt-v*ft+b*it)*bt,i[5]=(_*ft-x*xt-b*tt)*bt,i[6]=(be*et-Ke*Qe+Xe*Je)*bt,i[7]=(Ke*Ze-W*et-Xe*Ye)*bt,i[8]=(W*Qe-be*Ze+Xe*je)*bt,i):null},projection:function(i,g,x){return i[0]=2/g,i[1]=0,i[2]=0,i[3]=0,i[4]=-2/x,i[5]=0,i[6]=-1,i[7]=1,i[8]=1,i},rotate:function(i,g,x){var _=g[0],v=g[1],b=g[2],y=g[3],S=g[4],w=g[5],L=g[6],k=g[7],H=g[8],z=Math.sin(x),q=Math.cos(x);return i[0]=q*_+z*y,i[1]=q*v+z*S,i[2]=q*b+z*w,i[3]=q*y-z*_,i[4]=q*S-z*v,i[5]=q*w-z*b,i[6]=L,i[7]=k,i[8]=H,i},scale:function(i,g,x){var _=x[0],v=x[1];return i[0]=_*g[0],i[1]=_*g[1],i[2]=_*g[2],i[3]=v*g[3],i[4]=v*g[4],i[5]=v*g[5],i[6]=g[6],i[7]=g[7],i[8]=g[8],i},set:function(i,g,x,_,v,b,y,S,w,L){return i[0]=g,i[1]=x,i[2]=_,i[3]=v,i[4]=b,i[5]=y,i[6]=S,i[7]=w,i[8]=L,i},str:function(i){return"mat3("+i[0]+","+i[1]+","+i[2]+","+i[3]+","+i[4]+","+i[5]+","+i[6]+","+i[7]+","+i[8]+")"},sub:pt,subtract:subtract$4,translate:function(i,g,x){var _=g[0],v=g[1],b=g[2],y=g[3],S=g[4],w=g[5],L=g[6],k=g[7],H=g[8],z=x[0],q=x[1];return i[0]=_,i[1]=v,i[2]=b,i[3]=y,i[4]=S,i[5]=w,i[6]=z*_+q*y+L,i[7]=z*v+q*S+k,i[8]=z*b+q*w+H,i},transpose:function(i,g){if(i===g){var x=g[1],_=g[2],v=g[5];i[1]=g[3],i[2]=g[6],i[3]=x,i[5]=g[7],i[6]=_,i[7]=v}else i[0]=g[0],i[1]=g[3],i[2]=g[6],i[3]=g[1],i[4]=g[4],i[5]=g[7],i[6]=g[2],i[7]=g[5],i[8]=g[8];return i}});function create$4(){var i=new tt(16);return tt!=Float32Array&&(i[1]=0,i[2]=0,i[3]=0,i[4]=0,i[6]=0,i[7]=0,i[8]=0,i[9]=0,i[11]=0,i[12]=0,i[13]=0,i[14]=0),i[0]=1,i[5]=1,i[10]=1,i[15]=1,i}function clone$4(i){var g=new tt(16);return g[0]=i[0],g[1]=i[1],g[2]=i[2],g[3]=i[3],g[4]=i[4],g[5]=i[5],g[6]=i[6],g[7]=i[7],g[8]=i[8],g[9]=i[9],g[10]=i[10],g[11]=i[11],g[12]=i[12],g[13]=i[13],g[14]=i[14],g[15]=i[15],g}function copy$4(i,g){return i[0]=g[0],i[1]=g[1],i[2]=g[2],i[3]=g[3],i[4]=g[4],i[5]=g[5],i[6]=g[6],i[7]=g[7],i[8]=g[8],i[9]=g[9],i[10]=g[10],i[11]=g[11],i[12]=g[12],i[13]=g[13],i[14]=g[14],i[15]=g[15],i}function fromValues$4(i,g,x,_,v,b,y,S,w,L,k,H,z,q,W,be){var Ke=new tt(16);return Ke[0]=i,Ke[1]=g,Ke[2]=x,Ke[3]=_,Ke[4]=v,Ke[5]=b,Ke[6]=y,Ke[7]=S,Ke[8]=w,Ke[9]=L,Ke[10]=k,Ke[11]=H,Ke[12]=z,Ke[13]=q,Ke[14]=W,Ke[15]=be,Ke}function identity$1(i){return i[0]=1,i[1]=0,i[2]=0,i[3]=0,i[4]=0,i[5]=1,i[6]=0,i[7]=0,i[8]=0,i[9]=0,i[10]=1,i[11]=0,i[12]=0,i[13]=0,i[14]=0,i[15]=1,i}function invert$1(i,g){var x=g[0],_=g[1],v=g[2],b=g[3],y=g[4],S=g[5],w=g[6],L=g[7],k=g[8],H=g[9],z=g[10],q=g[11],W=g[12],be=g[13],Ke=g[14],Xe=g[15],je=x*S-_*y,Ye=x*w-v*y,Ze=x*L-b*y,Je=_*w-v*S,Qe=_*L-b*S,et=v*L-b*w,tt=k*be-H*W,it=k*Ke-z*W,ft=k*Xe-q*W,pt=H*Ke-z*be,xt=H*Xe-q*be,vt=z*Xe-q*Ke,bt=je*vt-Ye*xt+Ze*pt+Je*ft-Qe*it+et*tt;return bt?(bt=1/bt,i[0]=(S*vt-w*xt+L*pt)*bt,i[1]=(v*xt-_*vt-b*pt)*bt,i[2]=(be*et-Ke*Qe+Xe*Je)*bt,i[3]=(z*Qe-H*et-q*Je)*bt,i[4]=(w*ft-y*vt-L*it)*bt,i[5]=(x*vt-v*ft+b*it)*bt,i[6]=(Ke*Ze-W*et-Xe*Ye)*bt,i[7]=(k*et-z*Ze+q*Ye)*bt,i[8]=(y*xt-S*ft+L*tt)*bt,i[9]=(_*ft-x*xt-b*tt)*bt,i[10]=(W*Qe-be*Ze+Xe*je)*bt,i[11]=(H*Ze-k*Qe-q*je)*bt,i[12]=(S*it-y*pt-w*tt)*bt,i[13]=(x*pt-_*it+v*tt)*bt,i[14]=(be*Ye-W*Je-Ke*je)*bt,i[15]=(k*Je-H*Ye+z*je)*bt,i):null}function multiply$4(i,g,x){var _=g[0],v=g[1],b=g[2],y=g[3],S=g[4],w=g[5],L=g[6],k=g[7],H=g[8],z=g[9],q=g[10],W=g[11],be=g[12],Ke=g[13],Xe=g[14],je=g[15],Ye=x[0],Ze=x[1],Je=x[2],Qe=x[3];return i[0]=Ye*_+Ze*S+Je*H+Qe*be,i[1]=Ye*v+Ze*w+Je*z+Qe*Ke,i[2]=Ye*b+Ze*L+Je*q+Qe*Xe,i[3]=Ye*y+Ze*k+Je*W+Qe*je,Ye=x[4],Ze=x[5],Je=x[6],Qe=x[7],i[4]=Ye*_+Ze*S+Je*H+Qe*be,i[5]=Ye*v+Ze*w+Je*z+Qe*Ke,i[6]=Ye*b+Ze*L+Je*q+Qe*Xe,i[7]=Ye*y+Ze*k+Je*W+Qe*je,Ye=x[8],Ze=x[9],Je=x[10],Qe=x[11],i[8]=Ye*_+Ze*S+Je*H+Qe*be,i[9]=Ye*v+Ze*w+Je*z+Qe*Ke,i[10]=Ye*b+Ze*L+Je*q+Qe*Xe,i[11]=Ye*y+Ze*k+Je*W+Qe*je,Ye=x[12],Ze=x[13],Je=x[14],Qe=x[15],i[12]=Ye*_+Ze*S+Je*H+Qe*be,i[13]=Ye*v+Ze*w+Je*z+Qe*Ke,i[14]=Ye*b+Ze*L+Je*q+Qe*Xe,i[15]=Ye*y+Ze*k+Je*W+Qe*je,i}function translate(i,g,x){var _,v,b,y,S,w,L,k,H,z,q,W,be=x[0],Ke=x[1],Xe=x[2];return g===i?(i[12]=g[0]*be+g[4]*Ke+g[8]*Xe+g[12],i[13]=g[1]*be+g[5]*Ke+g[9]*Xe+g[13],i[14]=g[2]*be+g[6]*Ke+g[10]*Xe+g[14],i[15]=g[3]*be+g[7]*Ke+g[11]*Xe+g[15]):(_=g[0],v=g[1],b=g[2],y=g[3],S=g[4],w=g[5],L=g[6],k=g[7],H=g[8],z=g[9],q=g[10],W=g[11],i[0]=_,i[1]=v,i[2]=b,i[3]=y,i[4]=S,i[5]=w,i[6]=L,i[7]=k,i[8]=H,i[9]=z,i[10]=q,i[11]=W,i[12]=_*be+S*Ke+H*Xe+g[12],i[13]=v*be+w*Ke+z*Xe+g[13],i[14]=b*be+L*Ke+q*Xe+g[14],i[15]=y*be+k*Ke+W*Xe+g[15]),i}function scale$4(i,g,x){var _=x[0],v=x[1],b=x[2];return i[0]=g[0]*_,i[1]=g[1]*_,i[2]=g[2]*_,i[3]=g[3]*_,i[4]=g[4]*v,i[5]=g[5]*v,i[6]=g[6]*v,i[7]=g[7]*v,i[8]=g[8]*b,i[9]=g[9]*b,i[10]=g[10]*b,i[11]=g[11]*b,i[12]=g[12],i[13]=g[13],i[14]=g[14],i[15]=g[15],i}function rotateX$2(i,g,x){var _=Math.sin(x),v=Math.cos(x),b=g[4],y=g[5],S=g[6],w=g[7],L=g[8],k=g[9],H=g[10],z=g[11];return g!==i&&(i[0]=g[0],i[1]=g[1],i[2]=g[2],i[3]=g[3],i[12]=g[12],i[13]=g[13],i[14]=g[14],i[15]=g[15]),i[4]=b*v+L*_,i[5]=y*v+k*_,i[6]=S*v+H*_,i[7]=w*v+z*_,i[8]=L*v-b*_,i[9]=k*v-y*_,i[10]=H*v-S*_,i[11]=z*v-w*_,i}function rotateY$2(i,g,x){var _=Math.sin(x),v=Math.cos(x),b=g[0],y=g[1],S=g[2],w=g[3],L=g[8],k=g[9],H=g[10],z=g[11];return g!==i&&(i[4]=g[4],i[5]=g[5],i[6]=g[6],i[7]=g[7],i[12]=g[12],i[13]=g[13],i[14]=g[14],i[15]=g[15]),i[0]=b*v-L*_,i[1]=y*v-k*_,i[2]=S*v-H*_,i[3]=w*v-z*_,i[8]=b*_+L*v,i[9]=y*_+k*v,i[10]=S*_+H*v,i[11]=w*_+z*v,i}function rotateZ$2(i,g,x){var _=Math.sin(x),v=Math.cos(x),b=g[0],y=g[1],S=g[2],w=g[3],L=g[4],k=g[5],H=g[6],z=g[7];return g!==i&&(i[8]=g[8],i[9]=g[9],i[10]=g[10],i[11]=g[11],i[12]=g[12],i[13]=g[13],i[14]=g[14],i[15]=g[15]),i[0]=b*v+L*_,i[1]=y*v+k*_,i[2]=S*v+H*_,i[3]=w*v+z*_,i[4]=L*v-b*_,i[5]=k*v-y*_,i[6]=H*v-S*_,i[7]=z*v-w*_,i}function fromRotationTranslation(i,g,x){var _=g[0],v=g[1],b=g[2],y=g[3],S=_+_,w=v+v,L=b+b,k=_*S,H=_*w,z=_*L,q=v*w,W=v*L,be=b*L,Ke=y*S,Xe=y*w,je=y*L;return i[0]=1-(q+be),i[1]=H+je,i[2]=z-Xe,i[3]=0,i[4]=H-je,i[5]=1-(k+be),i[6]=W+Ke,i[7]=0,i[8]=z+Xe,i[9]=W-Ke,i[10]=1-(k+q),i[11]=0,i[12]=x[0],i[13]=x[1],i[14]=x[2],i[15]=1,i}function getScaling(i,g){var x=g[0],_=g[1],v=g[2],b=g[4],y=g[5],S=g[6],w=g[8],L=g[9],k=g[10];return i[0]=Math.sqrt(x*x+_*_+v*v),i[1]=Math.sqrt(b*b+y*y+S*S),i[2]=Math.sqrt(w*w+L*L+k*k),i}function perspectiveNO(i,g,x,_,v){var b=1/Math.tan(g/2);if(i[0]=b/x,i[1]=0,i[2]=0,i[3]=0,i[4]=0,i[5]=b,i[6]=0,i[7]=0,i[8]=0,i[9]=0,i[11]=-1,i[12]=0,i[13]=0,i[15]=0,null!=v&&v!==1/0){var y=1/(_-v);i[10]=(v+_)*y,i[14]=2*v*_*y}else i[10]=-1,i[14]=-2*_;return i}var vt=perspectiveNO;function orthoNO(i,g,x,_,v,b,y){var S=1/(g-x),w=1/(_-v),L=1/(b-y);return i[0]=-2*S,i[1]=0,i[2]=0,i[3]=0,i[4]=0,i[5]=-2*w,i[6]=0,i[7]=0,i[8]=0,i[9]=0,i[10]=2*L,i[11]=0,i[12]=(g+x)*S,i[13]=(v+_)*w,i[14]=(y+b)*L,i[15]=1,i}var bt=orthoNO;function orthoZO(i,g,x,_,v,b,y){var S=1/(g-x),w=1/(_-v),L=1/(b-y);return i[0]=-2*S,i[1]=0,i[2]=0,i[3]=0,i[4]=0,i[5]=-2*w,i[6]=0,i[7]=0,i[8]=0,i[9]=0,i[10]=L,i[11]=0,i[12]=(g+x)*S,i[13]=(v+_)*w,i[14]=b*L,i[15]=1,i}function lookAt(i,g,x,_){var v,b,y,S,w,L,k,H,z,q,W=g[0],be=g[1],Ke=g[2],Xe=_[0],je=_[1],Ye=_[2],Ze=x[0],Je=x[1],Qe=x[2];return Math.abs(W-Ze)0&&(k*=q=1/Math.sqrt(q),H*=q,z*=q);var W=w*z-L*H,be=L*k-S*z,Ke=S*H-w*k;return(q=W*W+be*be+Ke*Ke)>0&&(W*=q=1/Math.sqrt(q),be*=q,Ke*=q),i[0]=W,i[1]=be,i[2]=Ke,i[3]=0,i[4]=H*Ke-z*be,i[5]=z*W-k*Ke,i[6]=k*be-H*W,i[7]=0,i[8]=k,i[9]=H,i[10]=z,i[11]=0,i[12]=v,i[13]=b,i[14]=y,i[15]=1,i}function subtract$3(i,g,x){return i[0]=g[0]-x[0],i[1]=g[1]-x[1],i[2]=g[2]-x[2],i[3]=g[3]-x[3],i[4]=g[4]-x[4],i[5]=g[5]-x[5],i[6]=g[6]-x[6],i[7]=g[7]-x[7],i[8]=g[8]-x[8],i[9]=g[9]-x[9],i[10]=g[10]-x[10],i[11]=g[11]-x[11],i[12]=g[12]-x[12],i[13]=g[13]-x[13],i[14]=g[14]-x[14],i[15]=g[15]-x[15],i}var yt=multiply$4,St=subtract$3,Tt=Object.freeze({__proto__:null,add:function(i,g,x){return i[0]=g[0]+x[0],i[1]=g[1]+x[1],i[2]=g[2]+x[2],i[3]=g[3]+x[3],i[4]=g[4]+x[4],i[5]=g[5]+x[5],i[6]=g[6]+x[6],i[7]=g[7]+x[7],i[8]=g[8]+x[8],i[9]=g[9]+x[9],i[10]=g[10]+x[10],i[11]=g[11]+x[11],i[12]=g[12]+x[12],i[13]=g[13]+x[13],i[14]=g[14]+x[14],i[15]=g[15]+x[15],i},adjoint:function(i,g){var x=g[0],_=g[1],v=g[2],b=g[3],y=g[4],S=g[5],w=g[6],L=g[7],k=g[8],H=g[9],z=g[10],q=g[11],W=g[12],be=g[13],Ke=g[14],Xe=g[15],je=x*S-_*y,Ye=x*w-v*y,Ze=x*L-b*y,Je=_*w-v*S,Qe=_*L-b*S,et=v*L-b*w,tt=k*be-H*W,it=k*Ke-z*W,ft=k*Xe-q*W,pt=H*Ke-z*be,xt=H*Xe-q*be,vt=z*Xe-q*Ke;return i[0]=S*vt-w*xt+L*pt,i[1]=v*xt-_*vt-b*pt,i[2]=be*et-Ke*Qe+Xe*Je,i[3]=z*Qe-H*et-q*Je,i[4]=w*ft-y*vt-L*it,i[5]=x*vt-v*ft+b*it,i[6]=Ke*Ze-W*et-Xe*Ye,i[7]=k*et-z*Ze+q*Ye,i[8]=y*xt-S*ft+L*tt,i[9]=_*ft-x*xt-b*tt,i[10]=W*Qe-be*Ze+Xe*je,i[11]=H*Ze-k*Qe-q*je,i[12]=S*it-y*pt-w*tt,i[13]=x*pt-_*it+v*tt,i[14]=be*Ye-W*Je-Ke*je,i[15]=k*Je-H*Ye+z*je,i},clone:clone$4,copy:copy$4,create:create$4,decompose:function(i,g,x,_){g[0]=_[12],g[1]=_[13],g[2]=_[14];var v=_[0],b=_[1],y=_[2],S=_[4],w=_[5],L=_[6],k=_[8],H=_[9],z=_[10];x[0]=Math.sqrt(v*v+b*b+y*y),x[1]=Math.sqrt(S*S+w*w+L*L),x[2]=Math.sqrt(k*k+H*H+z*z);var q=1/x[0],W=1/x[1],be=1/x[2],Ke=v*q,Xe=b*W,je=y*be,Ye=S*q,Ze=w*W,Je=L*be,Qe=k*q,et=H*W,tt=z*be,it=Ke+Ze+tt,ft=0;return it>0?(ft=2*Math.sqrt(it+1),i[3]=.25*ft,i[0]=(Je-et)/ft,i[1]=(Qe-je)/ft,i[2]=(Xe-Ye)/ft):Ke>Ze&&Ke>tt?(ft=2*Math.sqrt(1+Ke-Ze-tt),i[3]=(Je-et)/ft,i[0]=.25*ft,i[1]=(Xe+Ye)/ft,i[2]=(Qe+je)/ft):Ze>tt?(ft=2*Math.sqrt(1+Ze-Ke-tt),i[3]=(Qe-je)/ft,i[0]=(Xe+Ye)/ft,i[1]=.25*ft,i[2]=(Je+et)/ft):(ft=2*Math.sqrt(1+tt-Ke-Ze),i[3]=(Xe-Ye)/ft,i[0]=(Qe+je)/ft,i[1]=(Je+et)/ft,i[2]=.25*ft),i},determinant:function(i){var g=i[0],x=i[1],_=i[2],v=i[3],b=i[4],y=i[5],S=i[6],w=i[7],L=i[8],k=i[9],H=i[10],z=i[11],q=i[12],W=i[13],be=i[14],Ke=g*y-x*b,Xe=g*S-_*b,je=x*S-_*y,Ye=L*W-k*q,Ze=L*be-H*q,Je=k*be-H*W;return w*(g*Je-x*Ze+_*Ye)-v*(b*Je-y*Ze+S*Ye)+i[15]*(L*je-k*Xe+H*Ke)-z*(q*je-W*Xe+be*Ke)},equals:function(i,g){var x=i[0],_=i[1],v=i[2],b=i[3],y=i[4],S=i[5],w=i[6],L=i[7],k=i[8],H=i[9],z=i[10],q=i[11],W=i[12],be=i[13],Ke=i[14],Xe=i[15],je=g[0],Ye=g[1],Ze=g[2],Je=g[3],Qe=g[4],tt=g[5],it=g[6],ft=g[7],pt=g[8],xt=g[9],vt=g[10],bt=g[11],yt=g[12],St=g[13],Tt=g[14],Mt=g[15];return Math.abs(x-je)<=et*Math.max(1,Math.abs(x),Math.abs(je))&&Math.abs(_-Ye)<=et*Math.max(1,Math.abs(_),Math.abs(Ye))&&Math.abs(v-Ze)<=et*Math.max(1,Math.abs(v),Math.abs(Ze))&&Math.abs(b-Je)<=et*Math.max(1,Math.abs(b),Math.abs(Je))&&Math.abs(y-Qe)<=et*Math.max(1,Math.abs(y),Math.abs(Qe))&&Math.abs(S-tt)<=et*Math.max(1,Math.abs(S),Math.abs(tt))&&Math.abs(w-it)<=et*Math.max(1,Math.abs(w),Math.abs(it))&&Math.abs(L-ft)<=et*Math.max(1,Math.abs(L),Math.abs(ft))&&Math.abs(k-pt)<=et*Math.max(1,Math.abs(k),Math.abs(pt))&&Math.abs(H-xt)<=et*Math.max(1,Math.abs(H),Math.abs(xt))&&Math.abs(z-vt)<=et*Math.max(1,Math.abs(z),Math.abs(vt))&&Math.abs(q-bt)<=et*Math.max(1,Math.abs(q),Math.abs(bt))&&Math.abs(W-yt)<=et*Math.max(1,Math.abs(W),Math.abs(yt))&&Math.abs(be-St)<=et*Math.max(1,Math.abs(be),Math.abs(St))&&Math.abs(Ke-Tt)<=et*Math.max(1,Math.abs(Ke),Math.abs(Tt))&&Math.abs(Xe-Mt)<=et*Math.max(1,Math.abs(Xe),Math.abs(Mt))},exactEquals:function(i,g){return i[0]===g[0]&&i[1]===g[1]&&i[2]===g[2]&&i[3]===g[3]&&i[4]===g[4]&&i[5]===g[5]&&i[6]===g[6]&&i[7]===g[7]&&i[8]===g[8]&&i[9]===g[9]&&i[10]===g[10]&&i[11]===g[11]&&i[12]===g[12]&&i[13]===g[13]&&i[14]===g[14]&&i[15]===g[15]},frob:function(i){return Math.sqrt(i[0]*i[0]+i[1]*i[1]+i[2]*i[2]+i[3]*i[3]+i[4]*i[4]+i[5]*i[5]+i[6]*i[6]+i[7]*i[7]+i[8]*i[8]+i[9]*i[9]+i[10]*i[10]+i[11]*i[11]+i[12]*i[12]+i[13]*i[13]+i[14]*i[14]+i[15]*i[15])},fromQuat:function(i,g){var x=g[0],_=g[1],v=g[2],b=g[3],y=x+x,S=_+_,w=v+v,L=x*y,k=_*y,H=_*S,z=v*y,q=v*S,W=v*w,be=b*y,Ke=b*S,Xe=b*w;return i[0]=1-H-W,i[1]=k+Xe,i[2]=z-Ke,i[3]=0,i[4]=k-Xe,i[5]=1-L-W,i[6]=q+be,i[7]=0,i[8]=z+Ke,i[9]=q-be,i[10]=1-L-H,i[11]=0,i[12]=0,i[13]=0,i[14]=0,i[15]=1,i},fromQuat2:function(i,g){var x=new tt(3),_=-g[0],v=-g[1],b=-g[2],y=g[3],S=g[4],w=g[5],L=g[6],k=g[7],H=_*_+v*v+b*b+y*y;return H>0?(x[0]=2*(S*y+k*_+w*b-L*v)/H,x[1]=2*(w*y+k*v+L*_-S*b)/H,x[2]=2*(L*y+k*b+S*v-w*_)/H):(x[0]=2*(S*y+k*_+w*b-L*v),x[1]=2*(w*y+k*v+L*_-S*b),x[2]=2*(L*y+k*b+S*v-w*_)),fromRotationTranslation(i,g,x),i},fromRotation:function(i,g,x){var _,v,b,y=x[0],S=x[1],w=x[2],L=Math.sqrt(y*y+S*S+w*w);return L0?(Ke=2*Math.sqrt(be+1),i[3]=.25*Ke,i[0]=(H-q)/Ke,i[1]=(z-w)/Ke,i[2]=(S-L)/Ke):y>k&&y>W?(Ke=2*Math.sqrt(1+y-k-W),i[3]=(H-q)/Ke,i[0]=.25*Ke,i[1]=(S+L)/Ke,i[2]=(z+w)/Ke):k>W?(Ke=2*Math.sqrt(1+k-y-W),i[3]=(z-w)/Ke,i[0]=(S+L)/Ke,i[1]=.25*Ke,i[2]=(H+q)/Ke):(Ke=2*Math.sqrt(1+W-y-k),i[3]=(S-L)/Ke,i[0]=(z+w)/Ke,i[1]=(H+q)/Ke,i[2]=.25*Ke),i},getScaling:getScaling,getTranslation:function(i,g){return i[0]=g[12],i[1]=g[13],i[2]=g[14],i},identity:identity$1,invert:invert$1,lookAt:lookAt,mul:yt,multiply:multiply$4,multiplyScalar:function(i,g,x){return i[0]=g[0]*x,i[1]=g[1]*x,i[2]=g[2]*x,i[3]=g[3]*x,i[4]=g[4]*x,i[5]=g[5]*x,i[6]=g[6]*x,i[7]=g[7]*x,i[8]=g[8]*x,i[9]=g[9]*x,i[10]=g[10]*x,i[11]=g[11]*x,i[12]=g[12]*x,i[13]=g[13]*x,i[14]=g[14]*x,i[15]=g[15]*x,i},multiplyScalarAndAdd:function(i,g,x,_){return i[0]=g[0]+x[0]*_,i[1]=g[1]+x[1]*_,i[2]=g[2]+x[2]*_,i[3]=g[3]+x[3]*_,i[4]=g[4]+x[4]*_,i[5]=g[5]+x[5]*_,i[6]=g[6]+x[6]*_,i[7]=g[7]+x[7]*_,i[8]=g[8]+x[8]*_,i[9]=g[9]+x[9]*_,i[10]=g[10]+x[10]*_,i[11]=g[11]+x[11]*_,i[12]=g[12]+x[12]*_,i[13]=g[13]+x[13]*_,i[14]=g[14]+x[14]*_,i[15]=g[15]+x[15]*_,i},ortho:bt,orthoNO:orthoNO,orthoZO:orthoZO,perspective:vt,perspectiveFromFieldOfView:function(i,g,x,_){var v=Math.tan(g.upDegrees*Math.PI/180),b=Math.tan(g.downDegrees*Math.PI/180),y=Math.tan(g.leftDegrees*Math.PI/180),S=Math.tan(g.rightDegrees*Math.PI/180),w=2/(y+S),L=2/(v+b);return i[0]=w,i[1]=0,i[2]=0,i[3]=0,i[4]=0,i[5]=L,i[6]=0,i[7]=0,i[8]=-(y-S)*w*.5,i[9]=(v-b)*L*.5,i[10]=_/(x-_),i[11]=-1,i[12]=0,i[13]=0,i[14]=_*x/(x-_),i[15]=0,i},perspectiveNO:perspectiveNO,perspectiveZO:function(i,g,x,_,v){var b=1/Math.tan(g/2);if(i[0]=b/x,i[1]=0,i[2]=0,i[3]=0,i[4]=0,i[5]=b,i[6]=0,i[7]=0,i[8]=0,i[9]=0,i[11]=-1,i[12]=0,i[13]=0,i[15]=0,null!=v&&v!==1/0){var y=1/(_-v);i[10]=v*y,i[14]=v*_*y}else i[10]=-1,i[14]=-_;return i},rotate:function(i,g,x,_){var v,b,y,S,w,L,k,H,z,q,W,be,Ke,Xe,je,Ye,Ze,Je,Qe,tt,it,ft,pt,xt,vt=_[0],bt=_[1],yt=_[2],St=Math.sqrt(vt*vt+bt*bt+yt*yt);return St0&&(b=1/Math.sqrt(b)),i[0]=g[0]*b,i[1]=g[1]*b,i[2]=g[2]*b,i}function dot$3(i,g){return i[0]*g[0]+i[1]*g[1]+i[2]*g[2]}function cross$2(i,g,x){var _=g[0],v=g[1],b=g[2],y=x[0],S=x[1],w=x[2];return i[0]=v*w-b*S,i[1]=b*y-_*w,i[2]=_*S-v*y,i}function lerp$3(i,g,x,_){var v=g[0],b=g[1],y=g[2];return i[0]=v+_*(x[0]-v),i[1]=b+_*(x[1]-b),i[2]=y+_*(x[2]-y),i}function transformMat4$2(i,g,x){var _=g[0],v=g[1],b=g[2],y=x[3]*_+x[7]*v+x[11]*b+x[15];return y=y||1,i[0]=(x[0]*_+x[4]*v+x[8]*b+x[12])/y,i[1]=(x[1]*_+x[5]*v+x[9]*b+x[13])/y,i[2]=(x[2]*_+x[6]*v+x[10]*b+x[14])/y,i}var Mt,wt=subtract$2,Ct=multiply$3,Rt=divide$2,Pt=distance$2,Bt=squaredDistance$2,It=length$3,Et=squaredLength$3,Dt=(Mt=create$3(),function(i,g,x,_,v,b){var y,S;for(g||(g=3),x||(x=0),S=_?Math.min(_*g+x,i.length):i.length,y=x;y0&&(y=1/Math.sqrt(y)),i[0]=x*y,i[1]=_*y,i[2]=v*y,i[3]=b*y,i}function dot$2(i,g){return i[0]*g[0]+i[1]*g[1]+i[2]*g[2]+i[3]*g[3]}function lerp$2(i,g,x,_){var v=g[0],b=g[1],y=g[2],S=g[3];return i[0]=v+_*(x[0]-v),i[1]=b+_*(x[1]-b),i[2]=y+_*(x[2]-y),i[3]=S+_*(x[3]-S),i}function transformMat4$1(i,g,x){var _=g[0],v=g[1],b=g[2],y=g[3];return i[0]=x[0]*_+x[4]*v+x[8]*b+x[12]*y,i[1]=x[1]*_+x[5]*v+x[9]*b+x[13]*y,i[2]=x[2]*_+x[6]*v+x[10]*b+x[14]*y,i[3]=x[3]*_+x[7]*v+x[11]*b+x[15]*y,i}function exactEquals$2(i,g){return i[0]===g[0]&&i[1]===g[1]&&i[2]===g[2]&&i[3]===g[3]}var Lt=subtract$1,At=multiply$2,Gt=divide$1,kt=distance$1,Ot=squaredDistance$1,Nt=length$2,Vt=squaredLength$2,Ft=function(){var i=create$2();return function(g,x,_,v,b,y){var S,w;for(x||(x=4),_||(_=0),w=v?Math.min(v*x+_,g.length):g.length,S=_;S0?S*Math.sin(y)/y:0;return i[0]=x*w,i[1]=_*w,i[2]=v*w,i[3]=S*Math.cos(y),i}function ln(i,g){var x=g[0],_=g[1],v=g[2],b=g[3],y=Math.sqrt(x*x+_*_+v*v),S=y>0?Math.atan2(y,b)/y:0;return i[0]=x*S,i[1]=_*S,i[2]=v*S,i[3]=.5*Math.log(x*x+_*_+v*v+b*b),i}function slerp(i,g,x,_){var v,b,y,S,w,L=g[0],k=g[1],H=g[2],z=g[3],q=x[0],W=x[1],be=x[2],Ke=x[3];return(b=L*q+k*W+H*be+z*Ke)<0&&(b=-b,q=-q,W=-W,be=-be,Ke=-Ke),1-b>et?(v=Math.acos(b),y=Math.sin(v),S=Math.sin((1-_)*v)/y,w=Math.sin(_*v)/y):(S=1-_,w=_),i[0]=S*L+w*q,i[1]=S*k+w*W,i[2]=S*H+w*be,i[3]=S*z+w*Ke,i}function fromMat3(i,g){var x,_=g[0]+g[4]+g[8];if(_>0)x=Math.sqrt(_+1),i[3]=.5*x,x=.5/x,i[0]=(g[5]-g[7])*x,i[1]=(g[6]-g[2])*x,i[2]=(g[1]-g[3])*x;else{var v=0;g[4]>g[0]&&(v=1),g[8]>g[3*v+v]&&(v=2);var b=(v+1)%3,y=(v+2)%3;x=Math.sqrt(g[3*v+v]-g[3*b+b]-g[3*y+y]+1),i[v]=.5*x,x=.5/x,i[3]=(g[3*b+y]-g[3*y+b])*x,i[b]=(g[3*b+v]+g[3*v+b])*x,i[y]=(g[3*y+v]+g[3*v+y])*x}return i}var zt=clone$2,$t=fromValues$2,Kt=copy$2,Xt=set$2,jt=add$2,Yt=multiply$1,qt=scale$2,Wt=dot$2,Zt=lerp$2,Jt=length$2,Qt=Jt,en=squaredLength$2,tn=en,nn=normalize$2,rn=exactEquals$2;var an,sn,on,un,cn=(an=create$3(),sn=fromValues$3(1,0,0),on=fromValues$3(0,1,0),function(i,g,x){var _=dot$3(g,x);return _<-.999999?(cross$2(an,sn,g),It(an)<1e-6&&cross$2(an,on,g),normalize$3(an,an),setAxisAngle(i,an,Math.PI),i):_>.999999?(i[0]=0,i[1]=0,i[2]=0,i[3]=1,i):(cross$2(an,g,x),i[0]=an[0],i[1]=an[1],i[2]=an[2],i[3]=1+_,nn(i,i))}),hn=function(){var i=create$1(),g=create$1();return function(x,_,v,b,y,S){return slerp(i,_,y,S),slerp(g,v,b,S),slerp(x,i,g,2*S*(1-S)),x}}(),fn=(un=create$5(),function(i,g,x,_){return un[0]=x[0],un[3]=x[1],un[6]=x[2],un[1]=_[0],un[4]=_[1],un[7]=_[2],un[2]=-g[0],un[5]=-g[1],un[8]=-g[2],nn(i,fromMat3(i,un))}),dn=Object.freeze({__proto__:null,add:jt,calculateW:function(i,g){var x=g[0],_=g[1],v=g[2];return i[0]=x,i[1]=_,i[2]=v,i[3]=Math.sqrt(Math.abs(1-x*x-_*_-v*v)),i},clone:zt,conjugate:function(i,g){return i[0]=-g[0],i[1]=-g[1],i[2]=-g[2],i[3]=g[3],i},copy:Kt,create:create$1,dot:Wt,equals:function(i,g){return Math.abs(dot$2(i,g))>=.999999},exactEquals:rn,exp:exp,fromEuler:function(i,g,x,_){var v=arguments.length>4&&void 0!==arguments[4]?arguments[4]:"zyx",b=Math.PI/360;g*=b,_*=b,x*=b;var y=Math.sin(g),S=Math.cos(g),w=Math.sin(x),L=Math.cos(x),k=Math.sin(_),H=Math.cos(_);switch(v){case"xyz":i[0]=y*L*H+S*w*k,i[1]=S*w*H-y*L*k,i[2]=S*L*k+y*w*H,i[3]=S*L*H-y*w*k;break;case"xzy":i[0]=y*L*H-S*w*k,i[1]=S*w*H-y*L*k,i[2]=S*L*k+y*w*H,i[3]=S*L*H+y*w*k;break;case"yxz":i[0]=y*L*H+S*w*k,i[1]=S*w*H-y*L*k,i[2]=S*L*k-y*w*H,i[3]=S*L*H+y*w*k;break;case"yzx":i[0]=y*L*H+S*w*k,i[1]=S*w*H+y*L*k,i[2]=S*L*k-y*w*H,i[3]=S*L*H-y*w*k;break;case"zxy":i[0]=y*L*H-S*w*k,i[1]=S*w*H+y*L*k,i[2]=S*L*k+y*w*H,i[3]=S*L*H-y*w*k;break;case"zyx":i[0]=y*L*H-S*w*k,i[1]=S*w*H+y*L*k,i[2]=S*L*k-y*w*H,i[3]=S*L*H+y*w*k;break;default:throw new Error("Unknown angle order "+v)}return i},fromMat3:fromMat3,fromValues:$t,getAngle:function(i,g){var x=Wt(i,g);return Math.acos(2*x*x-1)},getAxisAngle:function(i,g){var x=2*Math.acos(g[3]),_=Math.sin(x/2);return _>et?(i[0]=g[0]/_,i[1]=g[1]/_,i[2]=g[2]/_):(i[0]=1,i[1]=0,i[2]=0),x},identity:function(i){return i[0]=0,i[1]=0,i[2]=0,i[3]=1,i},invert:function(i,g){var x=g[0],_=g[1],v=g[2],b=g[3],y=x*x+_*_+v*v+b*b,S=y?1/y:0;return i[0]=-x*S,i[1]=-_*S,i[2]=-v*S,i[3]=b*S,i},len:Qt,length:Jt,lerp:Zt,ln:ln,mul:Yt,multiply:multiply$1,normalize:nn,pow:function(i,g,x){return ln(i,g),qt(i,i,x),exp(i,i),i},random:function(i){var g=it(),x=it(),_=it(),v=Math.sqrt(1-g),b=Math.sqrt(g);return i[0]=v*Math.sin(2*Math.PI*x),i[1]=v*Math.cos(2*Math.PI*x),i[2]=b*Math.sin(2*Math.PI*_),i[3]=b*Math.cos(2*Math.PI*_),i},rotateX:function(i,g,x){x*=.5;var _=g[0],v=g[1],b=g[2],y=g[3],S=Math.sin(x),w=Math.cos(x);return i[0]=_*w+y*S,i[1]=v*w+b*S,i[2]=b*w-v*S,i[3]=y*w-_*S,i},rotateY:function(i,g,x){x*=.5;var _=g[0],v=g[1],b=g[2],y=g[3],S=Math.sin(x),w=Math.cos(x);return i[0]=_*w-b*S,i[1]=v*w+y*S,i[2]=b*w+_*S,i[3]=y*w-v*S,i},rotateZ:function(i,g,x){x*=.5;var _=g[0],v=g[1],b=g[2],y=g[3],S=Math.sin(x),w=Math.cos(x);return i[0]=_*w+v*S,i[1]=v*w-_*S,i[2]=b*w+y*S,i[3]=y*w-b*S,i},rotationTo:cn,scale:qt,set:Xt,setAxes:fn,setAxisAngle:setAxisAngle,slerp:slerp,sqlerp:hn,sqrLen:tn,squaredLength:en,str:function(i){return"quat("+i[0]+","+i[1]+","+i[2]+","+i[3]+")"}});function create(){var i=new tt(2);return tt!=Float32Array&&(i[0]=0,i[1]=0),i}function fromValues(i,g){var x=new tt(2);return x[0]=i,x[1]=g,x}function set(i,g,x){return i[0]=g,i[1]=x,i}function subtract(i,g,x){return i[0]=g[0]-x[0],i[1]=g[1]-x[1],i}function multiply(i,g,x){return i[0]=g[0]*x[0],i[1]=g[1]*x[1],i}function divide(i,g,x){return i[0]=g[0]/x[0],i[1]=g[1]/x[1],i}function scaleAndAdd(i,g,x,_){return i[0]=g[0]+x[0]*_,i[1]=g[1]+x[1]*_,i}function distance(i,g){var x=g[0]-i[0],_=g[1]-i[1];return Math.sqrt(x*x+_*_)}function squaredDistance(i,g){var x=g[0]-i[0],_=g[1]-i[1];return x*x+_*_}function length(i){var g=i[0],x=i[1];return Math.sqrt(g*g+x*x)}function squaredLength(i){var g=i[0],x=i[1];return g*g+x*x}function lerp(i,g,x,_){var v=g[0],b=g[1];return i[0]=v+_*(x[0]-v),i[1]=b+_*(x[1]-b),i}var mn=length,pn=subtract,gn=multiply,xn=divide,_n=distance,vn=squaredDistance,bn=squaredLength,yn=function(){var i=create();return function(g,x,_,v,b,y){var S,w;for(x||(x=2),_||(_=0),w=v?Math.min(v*x+_,g.length):g.length,S=_;S0&&(v=1/Math.sqrt(v)),i[0]=g[0]*v,i[1]=g[1]*v,i},random:function(i,g){g=void 0===g?1:g;var x=2*it()*Math.PI;return i[0]=Math.cos(x)*g,i[1]=Math.sin(x)*g,i},rotate:function(i,g,x,_){var v=g[0]-x[0],b=g[1]-x[1],y=Math.sin(_),S=Math.cos(_);return i[0]=v*S-b*y+x[0],i[1]=v*y+b*S+x[1],i},round:function(i,g){return i[0]=round$3(g[0]),i[1]=round$3(g[1]),i},scale:function(i,g,x){return i[0]=g[0]*x,i[1]=g[1]*x,i},scaleAndAdd:scaleAndAdd,set:set,signedAngle:function(i,g){var x=i[0],_=i[1],v=g[0],b=g[1];return Math.atan2(x*b-_*v,x*v+_*b)},sqrDist:vn,sqrLen:bn,squaredDistance:squaredDistance,squaredLength:squaredLength,str:function(i){return"vec2("+i[0]+","+i[1]+")"},sub:pn,subtract:subtract,transformMat2:function(i,g,x){var _=g[0],v=g[1];return i[0]=x[0]*_+x[2]*v,i[1]=x[1]*_+x[3]*v,i},transformMat2d:function(i,g,x){var _=g[0],v=g[1];return i[0]=x[0]*_+x[2]*v+x[4],i[1]=x[1]*_+x[3]*v+x[5],i},transformMat3:function(i,g,x){var _=g[0],v=g[1];return i[0]=x[0]*_+x[3]*v+x[6],i[1]=x[1]*_+x[4]*v+x[7],i},transformMat4:function(i,g,x){var _=g[0],v=g[1];return i[0]=x[0]*_+x[4]*v+x[12],i[1]=x[1]*_+x[5]*v+x[13],i},zero:function(i){return i[0]=0,i[1]=0,i}});class Camera2D{#f;#kt=create$4();#Ot=0;#Nt=0;#Vt=0;#h;constructor(){}get name(){return this.#f||(this.#f=InstanceIdGenerator.getNextId(this.constructor)),this.#h||`${this.constructor.name} Instance ${this.#f}`}set name(i){this.#h=i}get modelMatrix(){return this.#kt}get z(){return this.#Vt}get x(){return this.#Ot}set x(i){this.#Ot=i,this.#kt[12]=i}get y(){return this.#Nt}set y(i){this.#Nt=i,this.#kt[13]=i}get position(){return[this.#Ot,this.#Nt]}setPosition(i,g){Array.isArray(i)?[this.#Ot,this.#Nt]=i:(this.#Ot=i,this.#Nt=g),[this.#kt[12],this.#kt[13],this.#kt[14]]=[this.#Ot,this.#Nt,0]}}const Tn={NEVER:"never",LESS:"less",EQUAL:"equal",LESS_EQUAL:"less-equal",GREATER:"greater",NOT_EQUAL:"not-equal",GREATER_EQUAL:"greater-equal",ALWAYS:"always"};Object.freeze(Tn);class e{constructor(i,g){this.name=i,this.attributes=g,this.size=0}get isArray(){return!1}get isStruct(){return!1}get isTemplate(){return!1}get isPointer(){return!1}getTypeName(){return this.name}}class t{constructor(i,g,x){this.name=i,this.type=g,this.attributes=x,this.offset=0,this.size=0}get isArray(){return this.type.isArray}get isStruct(){return this.type.isStruct}get isTemplate(){return this.type.isTemplate}get align(){return this.type.isStruct?this.type.align:0}get members(){return this.type.isStruct?this.type.members:null}get format(){return this.type.isArray||this.type.isTemplate?this.type.format:null}get count(){return this.type.isArray?this.type.count:0}get stride(){return this.type.isArray?this.type.stride:this.size}}class n extends e{constructor(i,g){super(i,g),this.members=[],this.align=0,this.startLine=-1,this.endLine=-1,this.inUse=!1}get isStruct(){return!0}}class s extends e{constructor(i,g){super(i,g),this.count=0,this.stride=0}get isArray(){return!0}getTypeName(){return`array<${this.format.getTypeName()},${this.count}>`}}class r extends e{constructor(i,g,x){super(i,x),this.format=g}get isPointer(){return!0}getTypeName(){return`&${this.format.getTypeName()}`}}class a extends e{constructor(i,g,x,_){super(i,x),this.format=g,this.access=_}get isTemplate(){return!0}getTypeName(){let i=this.name;if(null!==this.format){if("vec2"===i||"vec3"===i||"vec4"===i||"mat2x2"===i||"mat2x3"===i||"mat2x4"===i||"mat3x2"===i||"mat3x3"===i||"mat3x4"===i||"mat4x2"===i||"mat4x3"===i||"mat4x4"===i){if("f32"===this.format.name)return i+="f",i;if("i32"===this.format.name)return i+="i",i;if("u32"===this.format.name)return i+="u",i;if("bool"===this.format.name)return i+="b",i;if("f16"===this.format.name)return i+="h",i}i+=`<${this.format.name}>`}else if("vec2"===i||"vec3"===i||"vec4"===i)return i;return i}}var Mn;(i=>{i[i.Uniform=0]="Uniform",i[i.Storage=1]="Storage",i[i.Texture=2]="Texture",i[i.Sampler=3]="Sampler",i[i.StorageTexture=4]="StorageTexture"})(Mn||(Mn={}));class o{constructor(i,g,x,_,v,b,y){this.name=i,this.type=g,this.group=x,this.binding=_,this.attributes=v,this.resourceType=b,this.access=y}get isArray(){return this.type.isArray}get isStruct(){return this.type.isStruct}get isTemplate(){return this.type.isTemplate}get size(){return this.type.size}get align(){return this.type.isStruct?this.type.align:0}get members(){return this.type.isStruct?this.type.members:null}get format(){return this.type.isArray||this.type.isTemplate?this.type.format:null}get count(){return this.type.isArray?this.type.count:0}get stride(){return this.type.isArray?this.type.stride:this.size}}class c{constructor(i,g){this.name=i,this.type=g}}class l{constructor(i,g,x,_){this.name=i,this.type=g,this.locationType=x,this.location=_,this.interpolation=null}}class u{constructor(i,g,x,_){this.name=i,this.type=g,this.locationType=x,this.location=_}}class h{constructor(i,g,x,_){this.name=i,this.type=g,this.attributes=x,this.id=_}}class f{constructor(i,g,x){this.name=i,this.type=g,this.attributes=x}}class p{constructor(i,g=null,x){this.stage=null,this.inputs=[],this.outputs=[],this.arguments=[],this.returnType=null,this.resources=[],this.overrides=[],this.startLine=-1,this.endLine=-1,this.inUse=!1,this.calls=new Set,this.name=i,this.stage=g,this.attributes=x}}class d{constructor(){this.vertex=[],this.fragment=[],this.compute=[]}}function m(i){var g=(32768&i)>>15,x=(31744&i)>>10,_=1023&i;return 0==x?(g?-1:1)*Math.pow(2,-14)*(_/Math.pow(2,10)):31==x?_?NaN:1/0*(g?-1:1):(g?-1:1)*Math.pow(2,x-15)*(1+_/Math.pow(2,10))}const wn=new Float32Array(1),Cn=new Int32Array(wn.buffer),Rn=new Uint16Array(1);function y$1(i){wn[0]=i;const g=Cn[0],x=g>>31&1;let _=g>>23&255,v=8388607&g;if(255===_)return Rn[0]=x<<15|31744|(0!==v?512:0),Rn[0];if(0===_){if(0===v)return Rn[0]=x<<15,Rn[0];v|=8388608;let i=113;for(;!(8388608&v);)v<<=1,i--;return _=127-i,v&=8388607,_>0?(v=(v>>126-_)+(v>>127-_&1),Rn[0]=x<<15|_<<10|v>>13,Rn[0]):(Rn[0]=x<<15,Rn[0])}return _=_-127+15,_>=31?(Rn[0]=x<<15|31744,Rn[0]):_<=0?_<-10?(Rn[0]=x<<15,Rn[0]):(v=(8388608|v)>>1-_,Rn[0]=x<<15|v>>13,Rn[0]):(v>>=13,Rn[0]=x<<15|_<<10|v,Rn[0])}const Pn=new Uint32Array(1),Bn=new Float32Array(Pn.buffer,0,1);function w$1(i){const g=112+(i>>6&31)<<23|(63&i)<<17;return Pn[0]=g,Bn[0]}function I(i,g,x,_){const v=[0,0,0,0];for(let b=0;b<_;++b)switch(x){case"8unorm":v[b]=i[g]/255,g++;break;case"8snorm":v[b]=i[g]/255*2-1,g++;break;case"8uint":v[b]=i[g],g++;break;case"8sint":v[b]=i[g]-127,g++;break;case"16uint":v[b]=i[g]|i[g+1]<<8,g+=2;break;case"16sint":v[b]=(i[g]|i[g+1]<<8)-32768,g+=2;break;case"16float":v[b]=m(i[g]|i[g+1]<<8),g+=2;break;case"32uint":case"32sint":v[b]=i[g]|i[g+1]<<8|i[g+2]<<16|i[g+3]<<24,g+=4;break;case"32float":v[b]=new Float32Array(i.buffer,g,1)[0],g+=4}return v}function T(i,g,x,_,v){for(let b=0;b<_;++b)switch(x){case"8unorm":i[g]=255*v[b],g++;break;case"8snorm":i[g]=.5*(v[b]+1)*255,g++;break;case"8uint":i[g]=v[b],g++;break;case"8sint":i[g]=v[b]+127,g++;break;case"16uint":new Uint16Array(i.buffer,g,1)[0]=v[b],g+=2;break;case"16sint":new Int16Array(i.buffer,g,1)[0]=v[b],g+=2;break;case"16float":{const x=y$1(v[b]);new Uint16Array(i.buffer,g,1)[0]=x,g+=2;break}case"32uint":new Uint32Array(i.buffer,g,1)[0]=v[b],g+=4;break;case"32sint":new Int32Array(i.buffer,g,1)[0]=v[b],g+=4;break;case"32float":new Float32Array(i.buffer,g,1)[0]=v[b],g+=4}return v}const In={r8unorm:{bytesPerBlock:1,blockWidth:1,blockHeight:1,isCompressed:!1,channels:1},r8snorm:{bytesPerBlock:1,blockWidth:1,blockHeight:1,isCompressed:!1,channels:1},r8uint:{bytesPerBlock:1,blockWidth:1,blockHeight:1,isCompressed:!1,channels:1},r8sint:{bytesPerBlock:1,blockWidth:1,blockHeight:1,isCompressed:!1,channels:1},rg8unorm:{bytesPerBlock:2,blockWidth:1,blockHeight:1,isCompressed:!1,channels:2},rg8snorm:{bytesPerBlock:2,blockWidth:1,blockHeight:1,isCompressed:!1,channels:2},rg8uint:{bytesPerBlock:2,blockWidth:1,blockHeight:1,isCompressed:!1,channels:2},rg8sint:{bytesPerBlock:2,blockWidth:1,blockHeight:1,isCompressed:!1,channels:2},rgba8unorm:{bytesPerBlock:4,blockWidth:1,blockHeight:1,isCompressed:!1,channels:4},"rgba8unorm-srgb":{bytesPerBlock:4,blockWidth:1,blockHeight:1,isCompressed:!1,channels:4},rgba8snorm:{bytesPerBlock:4,blockWidth:1,blockHeight:1,isCompressed:!1,channels:4},rgba8uint:{bytesPerBlock:4,blockWidth:1,blockHeight:1,isCompressed:!1,channels:4},rgba8sint:{bytesPerBlock:4,blockWidth:1,blockHeight:1,isCompressed:!1,channels:4},bgra8unorm:{bytesPerBlock:4,blockWidth:1,blockHeight:1,isCompressed:!1,channels:4},"bgra8unorm-srgb":{bytesPerBlock:4,blockWidth:1,blockHeight:1,isCompressed:!1,channels:4},r16uint:{bytesPerBlock:2,blockWidth:1,blockHeight:1,isCompressed:!1,channels:1},r16sint:{bytesPerBlock:2,blockWidth:1,blockHeight:1,isCompressed:!1,channels:1},r16float:{bytesPerBlock:2,blockWidth:1,blockHeight:1,isCompressed:!1,channels:1},rg16uint:{bytesPerBlock:4,blockWidth:1,blockHeight:1,isCompressed:!1,channels:2},rg16sint:{bytesPerBlock:4,blockWidth:1,blockHeight:1,isCompressed:!1,channels:2},rg16float:{bytesPerBlock:4,blockWidth:1,blockHeight:1,isCompressed:!1,channels:2},rgba16uint:{bytesPerBlock:8,blockWidth:1,blockHeight:1,isCompressed:!1,channels:4},rgba16sint:{bytesPerBlock:8,blockWidth:1,blockHeight:1,isCompressed:!1,channels:4},rgba16float:{bytesPerBlock:8,blockWidth:1,blockHeight:1,isCompressed:!1,channels:4},r32uint:{bytesPerBlock:4,blockWidth:1,blockHeight:1,isCompressed:!1,channels:1},r32sint:{bytesPerBlock:4,blockWidth:1,blockHeight:1,isCompressed:!1,channels:1},r32float:{bytesPerBlock:4,blockWidth:1,blockHeight:1,isCompressed:!1,channels:1},rg32uint:{bytesPerBlock:8,blockWidth:1,blockHeight:1,isCompressed:!1,channels:2},rg32sint:{bytesPerBlock:8,blockWidth:1,blockHeight:1,isCompressed:!1,channels:2},rg32float:{bytesPerBlock:8,blockWidth:1,blockHeight:1,isCompressed:!1,channels:2},rgba32uint:{bytesPerBlock:16,blockWidth:1,blockHeight:1,isCompressed:!1,channels:4},rgba32sint:{bytesPerBlock:16,blockWidth:1,blockHeight:1,isCompressed:!1,channels:4},rgba32float:{bytesPerBlock:16,blockWidth:1,blockHeight:1,isCompressed:!1,channels:4},rgb10a2uint:{bytesPerBlock:4,blockWidth:1,blockHeight:1,isCompressed:!1,channels:4},rgb10a2unorm:{bytesPerBlock:4,blockWidth:1,blockHeight:1,isCompressed:!1,channels:4},rg11b10ufloat:{bytesPerBlock:4,blockWidth:1,blockHeight:1,isCompressed:!1,channels:4},stencil8:{bytesPerBlock:1,blockWidth:1,blockHeight:1,isCompressed:!1,isDepthStencil:!0,hasDepth:!1,hasStencil:!0,channels:1},depth16unorm:{bytesPerBlock:2,blockWidth:1,blockHeight:1,isCompressed:!1,isDepthStencil:!0,hasDepth:!0,hasStencil:!1,channels:1},depth24plus:{bytesPerBlock:4,blockWidth:1,blockHeight:1,isCompressed:!1,isDepthStencil:!0,hasDepth:!0,hasStencil:!1,depthOnlyFormat:"depth32float",channels:1},"depth24plus-stencil8":{bytesPerBlock:8,blockWidth:1,blockHeight:1,isCompressed:!1,isDepthStencil:!0,hasDepth:!0,hasStencil:!0,depthOnlyFormat:"depth32float",channels:1},depth32float:{bytesPerBlock:4,blockWidth:1,blockHeight:1,isCompressed:!1,isDepthStencil:!0,hasDepth:!0,hasStencil:!1,channels:1},"depth32float-stencil8":{bytesPerBlock:8,blockWidth:1,blockHeight:1,isCompressed:!1,isDepthStencil:!0,hasDepth:!0,hasStencil:!0,stencilOnlyFormat:"depth32float",channels:1},rgb9e5ufloat:{bytesPerBlock:4,blockWidth:1,blockHeight:1,isCompressed:!1,channels:4},"bc1-rgba-unorm":{bytesPerBlock:8,blockWidth:4,blockHeight:4,isCompressed:!0,channels:4},"bc1-rgba-unorm-srgb":{bytesPerBlock:8,blockWidth:4,blockHeight:4,isCompressed:!0,channels:4},"bc2-rgba-unorm":{bytesPerBlock:16,blockWidth:4,blockHeight:4,isCompressed:!0,channels:4},"bc2-rgba-unorm-srgb":{bytesPerBlock:16,blockWidth:4,blockHeight:4,isCompressed:!0,channels:4},"bc3-rgba-unorm":{bytesPerBlock:16,blockWidth:4,blockHeight:4,isCompressed:!0,channels:4},"bc3-rgba-unorm-srgb":{bytesPerBlock:16,blockWidth:4,blockHeight:4,isCompressed:!0,channels:4},"bc4-r-unorm":{bytesPerBlock:8,blockWidth:4,blockHeight:4,isCompressed:!0,channels:1},"bc4-r-snorm":{bytesPerBlock:8,blockWidth:4,blockHeight:4,isCompressed:!0,channels:1},"bc5-rg-unorm":{bytesPerBlock:16,blockWidth:4,blockHeight:4,isCompressed:!0,channels:2},"bc5-rg-snorm":{bytesPerBlock:16,blockWidth:4,blockHeight:4,isCompressed:!0,channels:2},"bc6h-rgb-ufloat":{bytesPerBlock:16,blockWidth:4,blockHeight:4,isCompressed:!0,channels:4},"bc6h-rgb-float":{bytesPerBlock:16,blockWidth:4,blockHeight:4,isCompressed:!0,channels:4},"bc7-rgba-unorm":{bytesPerBlock:16,blockWidth:4,blockHeight:4,isCompressed:!0,channels:4},"bc7-rgba-unorm-srgb":{bytesPerBlock:16,blockWidth:4,blockHeight:4,isCompressed:!0,channels:4},"etc2-rgb8unorm":{bytesPerBlock:8,blockWidth:4,blockHeight:4,isCompressed:!0,channels:4},"etc2-rgb8unorm-srgb":{bytesPerBlock:8,blockWidth:4,blockHeight:4,isCompressed:!0,channels:4},"etc2-rgb8a1unorm":{bytesPerBlock:8,blockWidth:4,blockHeight:4,isCompressed:!0,channels:4},"etc2-rgb8a1unorm-srgb":{bytesPerBlock:8,blockWidth:4,blockHeight:4,isCompressed:!0,channels:4},"etc2-rgba8unorm":{bytesPerBlock:16,blockWidth:4,blockHeight:4,isCompressed:!0,channels:4},"etc2-rgba8unorm-srgb":{bytesPerBlock:16,blockWidth:4,blockHeight:4,isCompressed:!0,channels:4},"eac-r11unorm":{bytesPerBlock:8,blockWidth:1,blockHeight:1,isCompressed:!0,channels:1},"eac-r11snorm":{bytesPerBlock:8,blockWidth:1,blockHeight:1,isCompressed:!0,channels:1},"eac-rg11unorm":{bytesPerBlock:16,blockWidth:1,blockHeight:1,isCompressed:!0,channels:2},"eac-rg11snorm":{bytesPerBlock:16,blockWidth:1,blockHeight:1,isCompressed:!0,channels:2},"astc-4x4-unorm":{bytesPerBlock:16,blockWidth:4,blockHeight:4,isCompressed:!0,channels:4},"astc-4x4-unorm-srgb":{bytesPerBlock:16,blockWidth:4,blockHeight:4,isCompressed:!0,channels:4},"astc-5x4-unorm":{bytesPerBlock:16,blockWidth:5,blockHeight:4,isCompressed:!0,channels:4},"astc-5x4-unorm-srgb":{bytesPerBlock:16,blockWidth:5,blockHeight:4,isCompressed:!0,channels:4},"astc-5x5-unorm":{bytesPerBlock:16,blockWidth:5,blockHeight:5,isCompressed:!0,channels:4},"astc-5x5-unorm-srgb":{bytesPerBlock:16,blockWidth:5,blockHeight:5,isCompressed:!0,channels:4},"astc-6x5-unorm":{bytesPerBlock:16,blockWidth:6,blockHeight:5,isCompressed:!0,channels:4},"astc-6x5-unorm-srgb":{bytesPerBlock:16,blockWidth:6,blockHeight:5,isCompressed:!0,channels:4},"astc-6x6-unorm":{bytesPerBlock:16,blockWidth:6,blockHeight:6,isCompressed:!0,channels:4},"astc-6x6-unorm-srgb":{bytesPerBlock:16,blockWidth:6,blockHeight:6,isCompressed:!0,channels:4},"astc-8x5-unorm":{bytesPerBlock:16,blockWidth:8,blockHeight:5,isCompressed:!0,channels:4},"astc-8x5-unorm-srgb":{bytesPerBlock:16,blockWidth:8,blockHeight:5,isCompressed:!0,channels:4},"astc-8x6-unorm":{bytesPerBlock:16,blockWidth:8,blockHeight:6,isCompressed:!0,channels:4},"astc-8x6-unorm-srgb":{bytesPerBlock:16,blockWidth:8,blockHeight:6,isCompressed:!0,channels:4},"astc-8x8-unorm":{bytesPerBlock:16,blockWidth:8,blockHeight:8,isCompressed:!0,channels:4},"astc-8x8-unorm-srgb":{bytesPerBlock:16,blockWidth:8,blockHeight:8,isCompressed:!0,channels:4},"astc-10x5-unorm":{bytesPerBlock:16,blockWidth:10,blockHeight:5,isCompressed:!0,channels:4},"astc-10x5-unorm-srgb":{bytesPerBlock:16,blockWidth:10,blockHeight:5,isCompressed:!0,channels:4},"astc-10x6-unorm":{bytesPerBlock:16,blockWidth:10,blockHeight:6,isCompressed:!0,channels:4},"astc-10x6-unorm-srgb":{bytesPerBlock:16,blockWidth:10,blockHeight:6,isCompressed:!0,channels:4},"astc-10x8-unorm":{bytesPerBlock:16,blockWidth:10,blockHeight:8,isCompressed:!0,channels:4},"astc-10x8-unorm-srgb":{bytesPerBlock:16,blockWidth:10,blockHeight:8,isCompressed:!0,channels:4},"astc-10x10-unorm":{bytesPerBlock:16,blockWidth:10,blockHeight:10,isCompressed:!0,channels:4},"astc-10x10-unorm-srgb":{bytesPerBlock:16,blockWidth:10,blockHeight:10,isCompressed:!0,channels:4},"astc-12x10-unorm":{bytesPerBlock:16,blockWidth:12,blockHeight:10,isCompressed:!0,channels:4},"astc-12x10-unorm-srgb":{bytesPerBlock:16,blockWidth:12,blockHeight:10,isCompressed:!0,channels:4},"astc-12x12-unorm":{bytesPerBlock:16,blockWidth:12,blockHeight:12,isCompressed:!0,channels:4},"astc-12x12-unorm-srgb":{bytesPerBlock:16,blockWidth:12,blockHeight:12,isCompressed:!0,channels:4}};class A{constructor(){this.id=A._id++,this.line=0}get isAstNode(){return!0}get astNodeType(){return""}search(i){i(this)}searchBlock(i,g){if(i){g(E.instance);for(const x of i)x instanceof Array?this.searchBlock(x,g):x.search(g);g($.instance)}}constEvaluate(i,g){throw new Error("Cannot evaluate node")}constEvaluateString(i){return this.constEvaluate(i).toString()}}A._id=0;class E extends A{}E.instance=new E;class $ extends A{}$.instance=new $;const En=new Set(["all","all","any","select","arrayLength","abs","acos","acosh","asin","asinh","atan","atanh","atan2","ceil","clamp","cos","cosh","countLeadingZeros","countOneBits","countTrailingZeros","cross","degrees","determinant","distance","dot","dot4U8Packed","dot4I8Packed","exp","exp2","extractBits","faceForward","firstLeadingBit","firstTrailingBit","floor","fma","fract","frexp","insertBits","inverseSqrt","ldexp","length","log","log2","max","min","mix","modf","normalize","pow","quantizeToF16","radians","reflect","refract","reverseBits","round","saturate","sign","sin","sinh","smoothStep","sqrt","step","tan","tanh","transpose","trunc","dpdx","dpdxCoarse","dpdxFine","dpdy","dpdyCoarse","dpdyFine","fwidth","fwidthCoarse","fwidthFine","textureDimensions","textureGather","textureGatherCompare","textureLoad","textureNumLayers","textureNumLevels","textureNumSamples","textureSample","textureSampleBias","textureSampleCompare","textureSampleCompareLevel","textureSampleGrad","textureSampleLevel","textureSampleBaseClampToEdge","textureStore","atomicLoad","atomicStore","atomicAdd","atomicSub","atomicMax","atomicMin","atomicAnd","atomicOr","atomicXor","atomicExchange","atomicCompareExchangeWeak","pack4x8snorm","pack4x8unorm","pack4xI8","pack4xU8","pack4x8Clamp","pack4xU8Clamp","pack2x16snorm","pack2x16unorm","pack2x16float","unpack4x8snorm","unpack4x8unorm","unpack4xI8","unpack4xU8","unpack2x16snorm","unpack2x16unorm","unpack2x16float","storageBarrier","textureBarrier","workgroupBarrier","workgroupUniformLoad","subgroupAdd","subgroupExclusiveAdd","subgroupInclusiveAdd","subgroupAll","subgroupAnd","subgroupAny","subgroupBallot","subgroupBroadcast","subgroupBroadcastFirst","subgroupElect","subgroupMax","subgroupMin","subgroupMul","subgroupExclusiveMul","subgroupInclusiveMul","subgroupOr","subgroupShuffle","subgroupShuffleDown","subgroupShuffleUp","subgroupShuffleXor","subgroupXor","quadBroadcast","quadSwapDiagonal","quadSwapX","quadSwapY"]);class C extends A{constructor(){super()}}class D extends C{constructor(i,g,x,_,v,b){super(),this.calls=new Set,this.name=i,this.args=g,this.returnType=x,this.body=_,this.startLine=v,this.endLine=b}get astNodeType(){return"function"}search(i){if(this.attributes)for(const g of this.attributes)i(g);i(this);for(const g of this.args)i(g);this.searchBlock(this.body,i)}}class N extends C{constructor(i){super(),this.expression=i}get astNodeType(){return"staticAssert"}search(i){this.expression.search(i)}}class V extends C{constructor(i,g){super(),this.condition=i,this.body=g}get astNodeType(){return"while"}search(i){this.condition.search(i),this.searchBlock(this.body,i)}}class O extends C{constructor(i,g){super(),this.body=i,this.loopId=g}get astNodeType(){return"continuing"}search(i){this.searchBlock(this.body,i)}}class B extends C{constructor(i,g,x,_){super(),this.init=i,this.condition=g,this.increment=x,this.body=_}get astNodeType(){return"for"}search(i){var g,x,_;null===(g=this.init)||void 0===g||g.search(i),null===(x=this.condition)||void 0===x||x.search(i),null===(_=this.increment)||void 0===_||_.search(i),this.searchBlock(this.body,i)}}class F extends C{constructor(i,g,x,_,v){super(),this.attributes=null,this.name=i,this.type=g,this.storage=x,this.access=_,this.value=v}get astNodeType(){return"var"}search(i){var g;i(this),null===(g=this.value)||void 0===g||g.search(i)}}class M extends C{constructor(i,g,x){super(),this.attributes=null,this.name=i,this.type=g,this.value=x}get astNodeType(){return"override"}search(i){var g;null===(g=this.value)||void 0===g||g.search(i)}}class U extends C{constructor(i,g,x,_,v){super(),this.attributes=null,this.name=i,this.type=g,this.storage=x,this.access=_,this.value=v}get astNodeType(){return"let"}search(i){var g;i(this),null===(g=this.value)||void 0===g||g.search(i)}}class P extends C{constructor(i,g,x,_,v){super(),this.attributes=null,this.name=i,this.type=g,this.storage=x,this.access=_,this.value=v}get astNodeType(){return"const"}constEvaluate(i,g){return this.value.constEvaluate(i,g)}search(i){var g;i(this),null===(g=this.value)||void 0===g||g.search(i)}}var Dn,Un,Ln,An;(i=>{i.increment="++",i.decrement="--"})(Dn||(Dn={})),(i=>{i.parse=function(g){const x=g;if("parse"==x)throw new Error("Invalid value for IncrementOperator");return i[x]}})(Dn||(Dn={}));class R extends C{constructor(i,g){super(),this.operator=i,this.variable=g}get astNodeType(){return"increment"}search(i){this.variable.search(i)}}(i=>{i.assign="=",i.addAssign="+=",i.subtractAssin="-=",i.multiplyAssign="*=",i.divideAssign="/=",i.moduloAssign="%=",i.andAssign="&=",i.orAssign="|=",i.xorAssign="^=",i.shiftLeftAssign="<<=",i.shiftRightAssign=">>="})(Un||(Un={})),(Un||(Un={})).parse=function(i){const g=i;if("parse"==g)throw new Error("Invalid value for AssignOperator");return g};class G extends C{constructor(i,g,x){super(),this.operator=i,this.variable=g,this.value=x}get astNodeType(){return"assign"}search(i){this.variable.search(i),this.value.search(i)}}class X extends C{constructor(i,g){super(),this.name=i,this.args=g}get astNodeType(){return"call"}isBuiltin(){return En.has(this.name)}search(i){for(const g of this.args)g.search(i);i(this)}}class j extends C{constructor(i,g){super(),this.body=i,this.continuing=g}get astNodeType(){return"loop"}search(i){var g;this.searchBlock(this.body,i),null===(g=this.continuing)||void 0===g||g.search(i)}}class Z extends C{constructor(i,g){super(),this.condition=i,this.cases=g}get astNodeType(){return"switch"}search(i){i(this);for(const g of this.cases)g.search(i)}}class Q extends C{constructor(i,g,x,_){super(),this.condition=i,this.body=g,this.elseif=x,this.else=_}get astNodeType(){return"if"}search(i){this.condition.search(i),this.searchBlock(this.body,i),this.searchBlock(this.elseif,i),this.searchBlock(this.else,i)}}class Y extends C{constructor(i){super(),this.value=i}get astNodeType(){return"return"}search(i){var g;null===(g=this.value)||void 0===g||g.search(i)}}class K extends C{constructor(i){super(),this.name=i}get astNodeType(){return"enable"}}class J extends C{constructor(i){super(),this.extensions=i}get astNodeType(){return"requires"}}class ee extends C{constructor(i,g){super(),this.severity=i,this.rule=g}get astNodeType(){return"diagnostic"}}class te extends C{constructor(i,g){super(),this.name=i,this.type=g}get astNodeType(){return"alias"}}class ne extends C{constructor(){super()}get astNodeType(){return"discard"}}class se extends C{constructor(){super(),this.condition=null,this.loopId=-1}get astNodeType(){return"break"}}class re extends C{constructor(){super(),this.loopId=-1}get astNodeType(){return"continue"}}class ae extends C{constructor(i){super(),this.attributes=null,this.name=i}get astNodeType(){return"type"}get isStruct(){return!1}get isArray(){return!1}static maxFormatType(i){let g=i[0];if("f32"===g.name)return g;for(let x=1;x`}else if("vec2"===i||"vec3"===i||"vec4"===i)return i;return i}}ce.vec2f=new ce("vec2",ae.f32,null),ce.vec3f=new ce("vec3",ae.f32,null),ce.vec4f=new ce("vec4",ae.f32,null),ce.vec2i=new ce("vec2",ae.i32,null),ce.vec3i=new ce("vec3",ae.i32,null),ce.vec4i=new ce("vec4",ae.i32,null),ce.vec2u=new ce("vec2",ae.u32,null),ce.vec3u=new ce("vec3",ae.u32,null),ce.vec4u=new ce("vec4",ae.u32,null),ce.vec2h=new ce("vec2",ae.f16,null),ce.vec3h=new ce("vec3",ae.f16,null),ce.vec4h=new ce("vec4",ae.f16,null),ce.vec2b=new ce("vec2",ae.bool,null),ce.vec3b=new ce("vec3",ae.bool,null),ce.vec4b=new ce("vec4",ae.bool,null),ce.mat2x2f=new ce("mat2x2",ae.f32,null),ce.mat2x3f=new ce("mat2x3",ae.f32,null),ce.mat2x4f=new ce("mat2x4",ae.f32,null),ce.mat3x2f=new ce("mat3x2",ae.f32,null),ce.mat3x3f=new ce("mat3x3",ae.f32,null),ce.mat3x4f=new ce("mat3x4",ae.f32,null),ce.mat4x2f=new ce("mat4x2",ae.f32,null),ce.mat4x3f=new ce("mat4x3",ae.f32,null),ce.mat4x4f=new ce("mat4x4",ae.f32,null),ce.mat2x2h=new ce("mat2x2",ae.f16,null),ce.mat2x3h=new ce("mat2x3",ae.f16,null),ce.mat2x4h=new ce("mat2x4",ae.f16,null),ce.mat3x2h=new ce("mat3x2",ae.f16,null),ce.mat3x3h=new ce("mat3x3",ae.f16,null),ce.mat3x4h=new ce("mat3x4",ae.f16,null),ce.mat4x2h=new ce("mat4x2",ae.f16,null),ce.mat4x3h=new ce("mat4x3",ae.f16,null),ce.mat4x4h=new ce("mat4x4",ae.f16,null),ce.mat2x2i=new ce("mat2x2",ae.i32,null),ce.mat2x3i=new ce("mat2x3",ae.i32,null),ce.mat2x4i=new ce("mat2x4",ae.i32,null),ce.mat3x2i=new ce("mat3x2",ae.i32,null),ce.mat3x3i=new ce("mat3x3",ae.i32,null),ce.mat3x4i=new ce("mat3x4",ae.i32,null),ce.mat4x2i=new ce("mat4x2",ae.i32,null),ce.mat4x3i=new ce("mat4x3",ae.i32,null),ce.mat4x4i=new ce("mat4x4",ae.i32,null),ce.mat2x2u=new ce("mat2x2",ae.u32,null),ce.mat2x3u=new ce("mat2x3",ae.u32,null),ce.mat2x4u=new ce("mat2x4",ae.u32,null),ce.mat3x2u=new ce("mat3x2",ae.u32,null),ce.mat3x3u=new ce("mat3x3",ae.u32,null),ce.mat3x4u=new ce("mat3x4",ae.u32,null),ce.mat4x2u=new ce("mat4x2",ae.u32,null),ce.mat4x3u=new ce("mat4x3",ae.u32,null),ce.mat4x4u=new ce("mat4x4",ae.u32,null);class le extends ae{constructor(i,g,x,_){super(i),this.storage=g,this.type=x,this.access=_}get astNodeType(){return"pointer"}}class ue extends ae{constructor(i,g,x,_){super(i),this.attributes=g,this.format=x,this.count=_}get astNodeType(){return"array"}get isArray(){return!0}}class he extends ae{constructor(i,g,x){super(i),this.format=g,this.access=x}get astNodeType(){return"sampler"}}class fe extends A{constructor(){super(),this.postfix=null}}class pe extends fe{constructor(i){super(),this.value=i}get astNodeType(){return"stringExpr"}toString(){return this.value}constEvaluateString(){return this.value}}class de extends fe{constructor(i,g){super(),this.type=i,this.args=g}get astNodeType(){return"createExpr"}search(i){if(i(this),this.args)for(const g of this.args)g.search(i)}constEvaluate(i,g){return g&&(g[0]=this.type),i.evalExpression(this,i.context)}}class me extends fe{constructor(i,g){super(),this.cachedReturnValue=null,this.name=i,this.args=g}get astNodeType(){return"callExpr"}setCachedReturnValue(i){this.cachedReturnValue=i}get isBuiltin(){return En.has(this.name)}constEvaluate(i,g){return i.evalExpression(this,i.context)}search(i){for(const g of this.args)g.search(i);i(this)}}class ge extends fe{constructor(i){super(),this.name=i}get astNodeType(){return"varExpr"}search(i){i(this),this.postfix&&this.postfix.search(i)}constEvaluate(i,g){return i.evalExpression(this,i.context)}}class _e extends fe{constructor(i,g){super(),this.name=i,this.initializer=g}get astNodeType(){return"constExpr"}constEvaluate(i,g){if(this.initializer){const g=i.evalExpression(this.initializer,i.context);return null!==g&&this.postfix?g.getSubData(i,this.postfix,i.context):g}return null}search(i){this.initializer.search(i)}}class xe extends fe{constructor(i,g){super(),this.value=i,this.type=g}get astNodeType(){return"literalExpr"}constEvaluate(i,g){return void 0!==g&&(g[0]=this.type),this.value}get isScalar(){return this.value instanceof Be}get isVector(){return this.value instanceof Me||this.value instanceof Ue}get scalarValue(){return this.value instanceof Be?this.value.value:(console.error("Value is not scalar."),0)}get vectorValue(){return this.value instanceof Me||this.value instanceof Ue?this.value.data:(console.error("Value is not a vector or matrix."),new Float32Array(0))}}class ye extends fe{constructor(i,g){super(),this.type=i,this.value=g}get astNodeType(){return"bitcastExpr"}search(i){this.value.search(i)}}class ve extends fe{constructor(i){super(),this.index=i}search(i){this.index.search(i)}}class we extends fe{constructor(){super()}}class ke extends we{constructor(i,g){super(),this.operator=i,this.right=g}get astNodeType(){return"unaryOp"}constEvaluate(i,g){return i.evalExpression(this,i.context)}search(i){this.right.search(i)}}class Ie extends we{constructor(i,g,x){super(),this.operator=i,this.left=g,this.right=x}get astNodeType(){return"binaryOp"}_getPromotedType(i,g){return i.name===g.name?i:"f32"===i.name||"f32"===g.name?ae.f32:"u32"===i.name||"u32"===g.name?ae.u32:ae.i32}constEvaluate(i,g){return i.evalExpression(this,i.context)}search(i){this.left.search(i),this.right.search(i)}}class Te extends A{constructor(i){super(),this.body=i}search(i){i(this),this.searchBlock(this.body,i)}}class Se extends fe{constructor(){super()}get astNodeType(){return"default"}}class Ae extends Te{constructor(i,g){super(g),this.selectors=i}get astNodeType(){return"case"}search(i){this.searchBlock(this.body,i)}}class Ee extends Te{constructor(i){super(i)}get astNodeType(){return"default"}search(i){this.searchBlock(this.body,i)}}class $e extends A{constructor(i,g,x){super(),this.name=i,this.type=g,this.attributes=x}get astNodeType(){return"argument"}}class Le extends A{constructor(i,g){super(),this.condition=i,this.body=g}get astNodeType(){return"elseif"}search(i){this.condition.search(i),this.searchBlock(this.body,i)}}class Ce extends A{constructor(i,g,x){super(),this.name=i,this.type=g,this.attributes=x}get astNodeType(){return"member"}}class De extends A{constructor(i,g){super(),this.name=i,this.value=g}get astNodeType(){return"attribute"}}class Ne{constructor(i,g){this.parent=null,this.typeInfo=i,this.parent=g,this.id=Ne._id++}clone(){throw`Clone:Not implemented for ${this.constructor.name}`}setDataValue(i,g,x,_){console.error(`SetDataValue:Not implemented for ${this.constructor.name}`)}getSubData(i,g,x){return console.error(`GetDataValue:Not implemented for ${this.constructor.name}`),null}toString(){return`<${this.typeInfo.getTypeName()}>`}}Ne._id=0;class Ve extends Ne{constructor(){super(new e("void",null),null)}toString(){return"void"}}Ve.void=new Ve;class Oe extends Ne{constructor(i){super(new r("pointer",i.typeInfo,null),null),this.reference=i}clone(){return this}setDataValue(i,g,x,_){this.reference.setDataValue(i,g,x,_)}getSubData(i,g,x){return g?this.reference.getSubData(i,g,x):this}toString(){return`&${this.reference.toString()}`}}class Be extends Ne{constructor(i,g,x=null){super(g,x),i instanceof Int32Array||i instanceof Uint32Array||i instanceof Float32Array?this.data=i:"x32"===this.typeInfo.name?i-Math.floor(i)!==0?this.data=new Float32Array([i]):this.data=i>=0?new Uint32Array([i]):new Int32Array([i]):"i32"===this.typeInfo.name||"bool"===this.typeInfo.name?this.data=new Int32Array([i]):"u32"===this.typeInfo.name?this.data=new Uint32Array([i]):"f32"===this.typeInfo.name||"f16"===this.typeInfo.name?this.data=new Float32Array([i]):console.error("ScalarData2:Invalid type",g)}clone(){if(this.data instanceof Float32Array)return new Be(new Float32Array(this.data),this.typeInfo,null);if(this.data instanceof Int32Array)return new Be(new Int32Array(this.data),this.typeInfo,null);if(this.data instanceof Uint32Array)return new Be(new Uint32Array(this.data),this.typeInfo,null);throw"ScalarData:Invalid data type"}get value(){return this.data[0]}set value(i){this.data[0]=i}setDataValue(i,g,x,_){if(x)return void console.error("SetDataValue:Scalar data does not support postfix",x);if(!(g instanceof Be))return void console.error("SetDataValue:Invalid value",g);let v=g.data[0];"i32"===this.typeInfo.name||"u32"===this.typeInfo.name?v=Math.floor(v):"bool"===this.typeInfo.name&&(v=v?1:0),this.data[0]=v}getSubData(i,g,x){return g?(console.error("getSubData:Scalar data does not support postfix",g),null):this}toString(){return`${this.value}`}}function Fe(i,g,x){const _=g.length;return 2===_?"f32"===x?new Me(new Float32Array(g),i.getTypeInfo("vec2f")):"i32"===x||"bool"===x?new Me(new Int32Array(g),i.getTypeInfo("vec2i")):"u32"===x?new Me(new Uint32Array(g),i.getTypeInfo("vec2u")):"f16"===x?new Me(new Float32Array(g),i.getTypeInfo("vec2h")):(console.error(`getSubData:Unknown format ${x}`),null):3===_?"f32"===x?new Me(new Float32Array(g),i.getTypeInfo("vec3f")):"i32"===x||"bool"===x?new Me(new Int32Array(g),i.getTypeInfo("vec3i")):"u32"===x?new Me(new Uint32Array(g),i.getTypeInfo("vec3u")):"f16"===x?new Me(new Float32Array(g),i.getTypeInfo("vec3h")):(console.error(`getSubData:Unknown format ${x}`),null):4===_?"f32"===x?new Me(new Float32Array(g),i.getTypeInfo("vec4f")):"i32"===x||"bool"===x?new Me(new Int32Array(g),i.getTypeInfo("vec4i")):"u32"===x?new Me(new Uint32Array(g),i.getTypeInfo("vec4u")):"f16"===x?new Me(new Float32Array(g),i.getTypeInfo("vec4h")):(console.error(`getSubData:Unknown format ${x}`),null):(console.error(`getSubData:Invalid vector size ${g.length}`),null)}class Me extends Ne{constructor(i,g,x=null){if(super(g,x),i instanceof Float32Array||i instanceof Uint32Array||i instanceof Int32Array)this.data=i;else{const g=this.typeInfo.name;"vec2f"===g||"vec3f"===g||"vec4f"===g?this.data=new Float32Array(i):"vec2i"===g||"vec3i"===g||"vec4i"===g?this.data=new Int32Array(i):"vec2u"===g||"vec3u"===g||"vec4u"===g?this.data=new Uint32Array(i):"vec2h"===g||"vec3h"===g||"vec4h"===g?this.data=new Float32Array(i):"vec2b"===g||"vec3b"===g||"vec4b"===g?this.data=new Int32Array(i):"vec2"===g||"vec3"===g||"vec4"===g?this.data=new Float32Array(i):console.error(`VectorData:Invalid type ${g}`)}}clone(){if(this.data instanceof Float32Array)return new Me(new Float32Array(this.data),this.typeInfo,null);if(this.data instanceof Int32Array)return new Me(new Int32Array(this.data),this.typeInfo,null);if(this.data instanceof Uint32Array)return new Me(new Uint32Array(this.data),this.typeInfo,null);throw"VectorData:Invalid data type"}setDataValue(i,g,x,_){x instanceof pe?console.error("TODO:Set vector postfix"):g instanceof Me?this.data=g.data:console.error("SetDataValue:Invalid value",g)}getSubData(i,g,x){if(null===g)return this;let _=i.getTypeInfo("f32");if(this.typeInfo instanceof a)_=this.typeInfo.format||_;else{const g=this.typeInfo.name;"vec2f"===g||"vec3f"===g||"vec4f"===g?_=i.getTypeInfo("f32"):"vec2i"===g||"vec3i"===g||"vec4i"===g?_=i.getTypeInfo("i32"):"vec2b"===g||"vec3b"===g||"vec4b"===g?_=i.getTypeInfo("bool"):"vec2u"===g||"vec3u"===g||"vec4u"===g?_=i.getTypeInfo("u32"):"vec2h"===g||"vec3h"===g||"vec4h"===g?_=i.getTypeInfo("f16"):console.error(`GetSubData:Unknown type ${g}`)}let v=this;for(;null!==g&&null!==v;){if(g instanceof ve){const b=g.index;let y=-1;if(b instanceof xe){if(!(b.value instanceof Be))return console.error(`GetSubData:Invalid array index ${b.value}`),null;y=b.value.value}else{const g=i.evalExpression(b,x);if(!(g instanceof Be))return console.error("GetSubData:Unknown index type",b),null;y=g.value}if(y<0||y>=v.data.length)return console.error("GetSubData:Index out of range",y),null;if(v.data instanceof Float32Array){const i=new Float32Array(v.data.buffer,v.data.byteOffset+4*y,1);return new Be(i,_)}if(v.data instanceof Int32Array){const i=new Int32Array(v.data.buffer,v.data.byteOffset+4*y,1);return new Be(i,_)}if(v.data instanceof Uint32Array){const i=new Uint32Array(v.data.buffer,v.data.byteOffset+4*y,1);return new Be(i,_)}throw"GetSubData:Invalid data type"}if(!(g instanceof pe))return console.error("GetSubData:Unknown postfix",g),null;{const x=g.value.toLowerCase();if(1===x.length){let i=0;if("x"===x||"r"===x)i=0;else if("y"===x||"g"===x)i=1;else if("z"===x||"b"===x)i=2;else{if("w"!==x&&"a"!==x)return console.error(`GetSubData:Unknown member ${x}`),null;i=3}if(this.data instanceof Float32Array){let g=new Float32Array(this.data.buffer,this.data.byteOffset+4*i,1);return new Be(g,_,this)}if(this.data instanceof Int32Array){let g=new Int32Array(this.data.buffer,this.data.byteOffset+4*i,1);return new Be(g,_,this)}if(this.data instanceof Uint32Array){let g=new Uint32Array(this.data.buffer,this.data.byteOffset+4*i,1);return new Be(g,_,this)}}const b=[];for(const i of x)"x"===i||"r"===i?b.push(this.data[0]):"y"===i||"g"===i?b.push(this.data[1]):"z"===i||"b"===i?b.push(this.data[2]):"w"===i||"a"===i?b.push(this.data[3]):console.error(`GetDataValue:Unknown member ${i}`);v=Fe(i,b,_.name)}g=g.postfix}return v}toString(){let i=`${this.data[0]}`;for(let g=1;g=this.data.length)return console.error("GetDataValue:Index out of range",b),null;const y=_.endsWith("h")?"h":"f";let S;if("mat2x2"===_||"mat2x2f"===_||"mat2x2h"===_||"mat3x2"===_||"mat3x2f"===_||"mat3x2h"===_||"mat4x2"===_||"mat4x2f"===_||"mat4x2h"===_)S=new Me(new Float32Array(this.data.buffer,this.data.byteOffset+2*b*4,2),i.getTypeInfo(`vec2${y}`));else if("mat2x3"===_||"mat2x3f"===_||"mat2x3h"===_||"mat3x3"===_||"mat3x3f"===_||"mat3x3h"===_||"mat4x3"===_||"mat4x3f"===_||"mat4x3h"===_)S=new Me(new Float32Array(this.data.buffer,this.data.byteOffset+3*b*4,3),i.getTypeInfo(`vec3${y}`));else{if("mat2x4"!==_&&"mat2x4f"!==_&&"mat2x4h"!==_&&"mat3x4"!==_&&"mat3x4f"!==_&&"mat3x4h"!==_&&"mat4x4"!==_&&"mat4x4f"!==_&&"mat4x4h"!==_)return console.error(`GetDataValue:Unknown type ${_}`),null;S=new Me(new Float32Array(this.data.buffer,this.data.byteOffset+4*b*4,4),i.getTypeInfo(`vec4${y}`))}return g.postfix?S.getSubData(i,g.postfix,x):S}return console.error("GetDataValue:Invalid postfix",g),null}toString(){let i=`${this.data[0]}`;for(let g=1;g"!==b&&"x32"!==b)if("u32"!==b&&"atomic"!==b)if("bool"!==b){if("vec2f"===b||"vec2h"===b){const i=new Float32Array(this.buffer,_,2);return void(g instanceof Me?(i[0]=g.data[0],i[1]=g.data[1]):(i[0]=g[0],i[1]=g[1]))}if("vec3f"===b||"vec3h"===b){const i=new Float32Array(this.buffer,_,3);return void(g instanceof Me?(i[0]=g.data[0],i[1]=g.data[1],i[2]=g.data[2]):(i[0]=g[0],i[1]=g[1],i[2]=g[2]))}if("vec4f"===b||"vec4h"===b){const i=new Float32Array(this.buffer,_,4);return void(g instanceof Me?(i[0]=g.data[0],i[1]=g.data[1],i[2]=g.data[2],i[3]=g.data[3]):(i[0]=g[0],i[1]=g[1],i[2]=g[2],i[3]=g[3]))}if("vec2i"===b){const i=new Int32Array(this.buffer,_,2);return void(g instanceof Me?(i[0]=g.data[0],i[1]=g.data[1]):(i[0]=g[0],i[1]=g[1]))}if("vec3i"===b){const i=new Int32Array(this.buffer,_,3);return void(g instanceof Me?(i[0]=g.data[0],i[1]=g.data[1],i[2]=g.data[2]):(i[0]=g[0],i[1]=g[1],i[2]=g[2]))}if("vec4i"===b){const i=new Int32Array(this.buffer,_,4);return void(g instanceof Me?(i[0]=g.data[0],i[1]=g.data[1],i[2]=g.data[2],i[3]=g.data[3]):(i[0]=g[0],i[1]=g[1],i[2]=g[2],i[3]=g[3]))}if("vec2u"===b){const i=new Uint32Array(this.buffer,_,2);return void(g instanceof Me?(i[0]=g.data[0],i[1]=g.data[1]):(i[0]=g[0],i[1]=g[1]))}if("vec3u"===b){const i=new Uint32Array(this.buffer,_,3);return void(g instanceof Me?(i[0]=g.data[0],i[1]=g.data[1],i[2]=g.data[2]):(i[0]=g[0],i[1]=g[1],i[2]=g[2]))}if("vec4u"===b){const i=new Uint32Array(this.buffer,_,4);return void(g instanceof Me?(i[0]=g.data[0],i[1]=g.data[1],i[2]=g.data[2],i[3]=g.data[3]):(i[0]=g[0],i[1]=g[1],i[2]=g[2],i[3]=g[3]))}if("vec2b"===b){const i=new Uint32Array(this.buffer,_,2);return void(g instanceof Me?(i[0]=g.data[0],i[1]=g.data[1]):(i[0]=g[0],i[1]=g[1]))}if("vec3b"===b){const i=new Uint32Array(this.buffer,_,3);return void(g instanceof Me?(i[0]=g.data[0],i[1]=g.data[1],i[2]=g.data[2]):(i[0]=g[0],i[1]=g[1],i[2]=g[2]))}if("vec4b"===b){const i=new Uint32Array(this.buffer,_,4);return void(g instanceof Me?(i[0]=g.data[0],i[1]=g.data[1],i[2]=g.data[2],i[3]=g.data[3]):(i[0]=g[0],i[1]=g[1],i[2]=g[2],i[3]=g[3]))}if("mat2x2f"===b||"mat2x2h"===b){const i=new Float32Array(this.buffer,_,4);return void(g instanceof Ue?(i[0]=g.data[0],i[1]=g.data[1],i[2]=g.data[2],i[3]=g.data[3]):(i[0]=g[0],i[1]=g[1],i[2]=g[2],i[3]=g[3]))}if("mat2x3f"===b||"mat2x3h"===b){const i=new Float32Array(this.buffer,_,6);return void(g instanceof Ue?(i[0]=g.data[0],i[1]=g.data[1],i[2]=g.data[2],i[3]=g.data[3],i[4]=g.data[4],i[5]=g.data[5]):(i[0]=g[0],i[1]=g[1],i[2]=g[2],i[3]=g[3],i[4]=g[4],i[5]=g[5]))}if("mat2x4f"===b||"mat2x4h"===b){const i=new Float32Array(this.buffer,_,8);return void(g instanceof Ue?(i[0]=g.data[0],i[1]=g.data[1],i[2]=g.data[2],i[3]=g.data[3],i[4]=g.data[4],i[5]=g.data[5],i[6]=g.data[6],i[7]=g.data[7]):(i[0]=g[0],i[1]=g[1],i[2]=g[2],i[3]=g[3],i[4]=g[4],i[5]=g[5],i[6]=g[6],i[7]=g[7]))}if("mat3x2f"===b||"mat3x2h"===b){const i=new Float32Array(this.buffer,_,6);return void(g instanceof Ue?(i[0]=g.data[0],i[1]=g.data[1],i[2]=g.data[2],i[3]=g.data[3],i[4]=g.data[4],i[5]=g.data[5]):(i[0]=g[0],i[1]=g[1],i[2]=g[2],i[3]=g[3],i[4]=g[4],i[5]=g[5]))}if("mat3x3f"===b||"mat3x3h"===b){const i=new Float32Array(this.buffer,_,9);return void(g instanceof Ue?(i[0]=g.data[0],i[1]=g.data[1],i[2]=g.data[2],i[3]=g.data[3],i[4]=g.data[4],i[5]=g.data[5],i[6]=g.data[6],i[7]=g.data[7],i[8]=g.data[8]):(i[0]=g[0],i[1]=g[1],i[2]=g[2],i[3]=g[3],i[4]=g[4],i[5]=g[5],i[6]=g[6],i[7]=g[7],i[8]=g[8]))}if("mat3x4f"===b||"mat3x4h"===b){const i=new Float32Array(this.buffer,_,12);return void(g instanceof Ue?(i[0]=g.data[0],i[1]=g.data[1],i[2]=g.data[2],i[3]=g.data[3],i[4]=g.data[4],i[5]=g.data[5],i[6]=g.data[6],i[7]=g.data[7],i[8]=g.data[8],i[9]=g.data[9],i[10]=g.data[10],i[11]=g.data[11]):(i[0]=g[0],i[1]=g[1],i[2]=g[2],i[3]=g[3],i[4]=g[4],i[5]=g[5],i[6]=g[6],i[7]=g[7],i[8]=g[8],i[9]=g[9],i[10]=g[10],i[11]=g[11]))}if("mat4x2f"===b||"mat4x2h"===b){const i=new Float32Array(this.buffer,_,8);return void(g instanceof Ue?(i[0]=g.data[0],i[1]=g.data[1],i[2]=g.data[2],i[3]=g.data[3],i[4]=g.data[4],i[5]=g.data[5],i[6]=g.data[6],i[7]=g.data[7]):(i[0]=g[0],i[1]=g[1],i[2]=g[2],i[3]=g[3],i[4]=g[4],i[5]=g[5],i[6]=g[6],i[7]=g[7]))}if("mat4x3f"===b||"mat4x3h"===b){const i=new Float32Array(this.buffer,_,12);return void(g instanceof Ue?(i[0]=g.data[0],i[1]=g.data[1],i[2]=g.data[2],i[3]=g.data[3],i[4]=g.data[4],i[5]=g.data[5],i[6]=g.data[6],i[7]=g.data[7],i[8]=g.data[8],i[9]=g.data[9],i[10]=g.data[10],i[11]=g.data[11]):(i[0]=g[0],i[1]=g[1],i[2]=g[2],i[3]=g[3],i[4]=g[4],i[5]=g[5],i[6]=g[6],i[7]=g[7],i[8]=g[8],i[9]=g[9],i[10]=g[10],i[11]=g[11]))}if("mat4x4f"===b||"mat4x4h"===b){const i=new Float32Array(this.buffer,_,16);return void(g instanceof Ue?(i[0]=g.data[0],i[1]=g.data[1],i[2]=g.data[2],i[3]=g.data[3],i[4]=g.data[4],i[5]=g.data[5],i[6]=g.data[6],i[7]=g.data[7],i[8]=g.data[8],i[9]=g.data[9],i[10]=g.data[10],i[11]=g.data[11],i[12]=g.data[12],i[13]=g.data[13],i[14]=g.data[14],i[15]=g.data[15]):(i[0]=g[0],i[1]=g[1],i[2]=g[2],i[3]=g[3],i[4]=g[4],i[5]=g[5],i[6]=g[6],i[7]=g[7],i[8]=g[8],i[9]=g[9],i[10]=g[10],i[11]=g[11],i[12]=g[12],i[13]=g[13],i[14]=g[14],i[15]=g[15]))}if(g instanceof Pe){if(x===g.typeInfo)return void new Uint8Array(this.buffer,_,g.buffer.byteLength).set(new Uint8Array(g.buffer));console.error("SetDataValue:Type mismatch",b,g.typeInfo.getTypeName())}else console.error(`SetData:Unknown type ${b}`)}else g instanceof Be&&(new Int32Array(this.buffer,_,1)[0]=g.value);else g instanceof Be&&(new Uint32Array(this.buffer,_,1)[0]=g.value);else g instanceof Be&&(new Int32Array(this.buffer,_,1)[0]=g.value);else g instanceof Be&&(new Float32Array(this.buffer,_,1)[0]=g.value)}getSubData(i,g,x){var _,v,b;if(null===g)return this;let y=this.offset,S=this.typeInfo;for(;g;){if(g instanceof ve){const _=g.index,v=_ instanceof fe?i.evalExpression(_,x):_;let b=0;if(v instanceof Be?b=v.value:"number"==typeof v?b=v:console.error("GetDataValue:Invalid index type",_),S instanceof s)y+=b*S.stride,S=S.format;else{const g=S.getTypeName();"mat4x4"===g||"mat4x4f"===g||"mat4x4h"===g?(y+=16*b,S=i.getTypeInfo("vec4f")):console.error(`getDataValue:Type ${S.getTypeName()} is not an array`)}}else{if(!(g instanceof pe))return console.error("GetDataValue:Unknown postfix type",g),null;{const x=g.value;if(S instanceof n){let i=!1;for(const g of S.members)if(g.name===x){y+=g.offset,S=g.type,i=!0;break}if(!i)return console.error(`GetDataValue:Member ${x} not found`),null}else if(S instanceof e){const g=S.getTypeName();if("vec2f"===g||"vec3f"===g||"vec4f"===g||"vec2i"===g||"vec3i"===g||"vec4i"===g||"vec2u"===g||"vec3u"===g||"vec4u"===g||"vec2b"===g||"vec3b"===g||"vec4b"===g||"vec2h"===g||"vec3h"===g||"vec4h"===g||"vec2"===g||"vec3"===g||"vec4"===g){if(x.length>0&&x.length<5){let _="f";const v=[];for(let b=0;b=this.buffer.byteLength)return console.log("Insufficient buffer data"),null;const i=new Float32Array(this.buffer,y,3);v.push(i[w])}else if("vec4f"===g)v.push(new Float32Array(this.buffer,y,4)[w]);else if("vec2i"===g)_="i",v.push(new Int32Array(this.buffer,y,2)[w]);else if("vec3i"===g)_="i",v.push(new Int32Array(this.buffer,y,3)[w]);else if("vec4i"===g)_="i",v.push(new Int32Array(this.buffer,y,4)[w]);else if("vec2u"===g){_="u";const i=new Uint32Array(this.buffer,y,2);v.push(i[w])}else"vec3u"===g?(_="u",v.push(new Uint32Array(this.buffer,y,3)[w])):"vec4u"===g&&(_="u",v.push(new Uint32Array(this.buffer,y,4)[w]))}return 2===v.length?S=i.getTypeInfo(`vec2${_}`):3===v.length?S=i.getTypeInfo(`vec3${_}`):4===v.length?S=i.getTypeInfo(`vec4${_}`):console.error(`GetDataValue:Invalid vector length ${v.length}`),new Me(v,S,null)}return console.error(`GetDataValue:Unknown member ${x}`),null}return console.error(`GetDataValue:Type ${g} is not a struct`),null}}}g=g.postfix}const w=S.getTypeName();return"f32"===w?new Be(new Float32Array(this.buffer,y,1),S,this):"i32"===w?new Be(new Int32Array(this.buffer,y,1),S,this):"u32"===w?new Be(new Uint32Array(this.buffer,y,1),S,this):"vec2f"===w?new Me(new Float32Array(this.buffer,y,2),S,this):"vec3f"===w?new Me(new Float32Array(this.buffer,y,3),S,this):"vec4f"===w?new Me(new Float32Array(this.buffer,y,4),S,this):"vec2i"===w?new Me(new Int32Array(this.buffer,y,2),S,this):"vec3i"===w?new Me(new Int32Array(this.buffer,y,3),S,this):"vec4i"===w?new Me(new Int32Array(this.buffer,y,4),S,this):"vec2u"===w?new Me(new Uint32Array(this.buffer,y,2),S,this):"vec3u"===w?new Me(new Uint32Array(this.buffer,y,3),S,this):"vec4u"===w?new Me(new Uint32Array(this.buffer,y,4),S,this):S instanceof a&&"atomic"===S.name?"u32"===(null===(_=S.format)||void 0===_?void 0:_.name)?new Be(new Uint32Array(this.buffer,y,1)[0],S.format,this):"i32"===(null===(v=S.format)||void 0===v?void 0:v.name)?new Be(new Int32Array(this.buffer,y,1)[0],S.format,this):(console.error(`GetDataValue:Invalid atomic format ${null===(b=S.format)||void 0===b?void 0:b.name}`),null):new Pe(this.buffer,S,y,this)}toString(){let i="";if(this.typeInfo instanceof s)if("f32"===this.typeInfo.format.name){const g=new Float32Array(this.buffer,this.offset);i=`[${g[0]}`;for(let x=1;x0?null!==(i=x[0])&&void 0!==i?i:0:x instanceof Object&&null!==(g=x.width)&&void 0!==g?g:0}get height(){var i,g;const x=this.descriptor.size;return x instanceof Array&&x.length>1?null!==(i=x[1])&&void 0!==i?i:0:x instanceof Object&&null!==(g=x.height)&&void 0!==g?g:0}get depthOrArrayLayers(){var i,g;const x=this.descriptor.size;return x instanceof Array&&x.length>2?null!==(i=x[2])&&void 0!==i?i:0:x instanceof Object&&null!==(g=x.depthOrArrayLayers)&&void 0!==g?g:0}get format(){var i;return this.descriptor&&null!==(i=this.descriptor.format)&&void 0!==i?i:"rgba8unorm"}get sampleCount(){var i;return this.descriptor&&null!==(i=this.descriptor.sampleCount)&&void 0!==i?i:1}get mipLevelCount(){var i;return this.descriptor&&null!==(i=this.descriptor.mipLevelCount)&&void 0!==i?i:1}get dimension(){var i;return this.descriptor&&null!==(i=this.descriptor.dimension)&&void 0!==i?i:"2d"}getMipLevelSize(i){if(i>=this.mipLevelCount)return[0,0,0];const g=[this.width,this.height,this.depthOrArrayLayers];for(let x=0;x>i);return g}get texelByteSize(){const i=this.format,g=In[i];return g?g.isDepthStencil?4:g.bytesPerBlock:0}get bytesPerRow(){return this.width*this.texelByteSize}get isDepthStencil(){const i=this.format,g=In[i];return!!g&&g.isDepthStencil}getGpuSize(){const i=this.format,g=In[i],x=this.width;if(!i||x<=0||!g)return-1;const _=this.height,v=this.depthOrArrayLayers,b=this.dimension;return x/g.blockWidth*("1d"===b?1:_/g.blockHeight)*g.bytesPerBlock*v}getPixel(i,g,x=0,_=0){const v=this.texelByteSize,b=this.bytesPerRow,y=this.height,S=this.data[_];return function(i,g,x,_,v,b,y,S,w){const L=_*(y>>=v)*(b>>=v)+x*y+g*S;switch(w){case"r8unorm":return[I(i,L,"8unorm",1)[0]];case"r8snorm":return[I(i,L,"8snorm",1)[0]];case"r8uint":return[I(i,L,"8uint",1)[0]];case"r8sint":return[I(i,L,"8sint",1)[0]];case"rg8unorm":{const g=I(i,L,"8unorm",2);return[g[0],g[1]]}case"rg8snorm":{const g=I(i,L,"8snorm",2);return[g[0],g[1]]}case"rg8uint":{const g=I(i,L,"8uint",2);return[g[0],g[1]]}case"rg8sint":{const g=I(i,L,"8sint",2);return[g[0],g[1]]}case"rgba8unorm-srgb":case"rgba8unorm":{const g=I(i,L,"8unorm",4);return[g[0],g[1],g[2],g[3]]}case"rgba8snorm":{const g=I(i,L,"8snorm",4);return[g[0],g[1],g[2],g[3]]}case"rgba8uint":{const g=I(i,L,"8uint",4);return[g[0],g[1],g[2],g[3]]}case"rgba8sint":{const g=I(i,L,"8sint",4);return[g[0],g[1],g[2],g[3]]}case"bgra8unorm-srgb":case"bgra8unorm":{const g=I(i,L,"8unorm",4);return[g[2],g[1],g[0],g[3]]}case"r16uint":return[I(i,L,"16uint",1)[0]];case"r16sint":return[I(i,L,"16sint",1)[0]];case"r16float":return[I(i,L,"16float",1)[0]];case"rg16uint":{const g=I(i,L,"16uint",2);return[g[0],g[1]]}case"rg16sint":{const g=I(i,L,"16sint",2);return[g[0],g[1]]}case"rg16float":{const g=I(i,L,"16float",2);return[g[0],g[1]]}case"rgba16uint":{const g=I(i,L,"16uint",4);return[g[0],g[1],g[2],g[3]]}case"rgba16sint":{const g=I(i,L,"16sint",4);return[g[0],g[1],g[2],g[3]]}case"rgba16float":{const g=I(i,L,"16float",4);return[g[0],g[1],g[2],g[3]]}case"r32uint":return[I(i,L,"32uint",1)[0]];case"r32sint":return[I(i,L,"32sint",1)[0]];case"depth16unorm":case"depth24plus":case"depth24plus-stencil8":case"depth32float":case"depth32float-stencil8":case"r32float":return[I(i,L,"32float",1)[0]];case"rg32uint":{const g=I(i,L,"32uint",2);return[g[0],g[1]]}case"rg32sint":{const g=I(i,L,"32sint",2);return[g[0],g[1]]}case"rg32float":{const g=I(i,L,"32float",2);return[g[0],g[1]]}case"rgba32uint":{const g=I(i,L,"32uint",4);return[g[0],g[1],g[2],g[3]]}case"rgba32sint":{const g=I(i,L,"32sint",4);return[g[0],g[1],g[2],g[3]]}case"rgba32float":{const g=I(i,L,"32float",4);return[g[0],g[1],g[2],g[3]]}case"rg11b10ufloat":{const g=new Uint32Array(i.buffer,L,1)[0],x=(4192256&g)>>11,_=(4290772992&g)>>22;return[w$1(2047&g),w$1(x),function(i){const g=112+(i>>5&31)<<23|(31&i)<<18;return Pn[0]=g,Bn[0]}(_),1]}}return null}(new Uint8Array(S),i,g,x,_,y,b,v,this.format)}setPixel(i,g,x,_,v){const b=this.texelByteSize,y=this.bytesPerRow,S=this.height,w=this.data[_];!function(i,g,x,_,v,b,y,S,w,L){const k=_*(y>>=v)*(b>>=v)+x*y+g*S;switch(w){case"r8unorm":return void T(i,k,"8unorm",1,L);case"r8snorm":return void T(i,k,"8snorm",1,L);case"r8uint":return void T(i,k,"8uint",1,L);case"r8sint":return void T(i,k,"8sint",1,L);case"rg8unorm":return void T(i,k,"8unorm",2,L);case"rg8snorm":return void T(i,k,"8snorm",2,L);case"rg8uint":return void T(i,k,"8uint",2,L);case"rg8sint":return void T(i,k,"8sint",2,L);case"rgba8unorm-srgb":case"rgba8unorm":case"bgra8unorm-srgb":case"bgra8unorm":return void T(i,k,"8unorm",4,L);case"rgba8snorm":return void T(i,k,"8snorm",4,L);case"rgba8uint":return void T(i,k,"8uint",4,L);case"rgba8sint":return void T(i,k,"8sint",4,L);case"r16uint":return void T(i,k,"16uint",1,L);case"r16sint":return void T(i,k,"16sint",1,L);case"r16float":return void T(i,k,"16float",1,L);case"rg16uint":return void T(i,k,"16uint",2,L);case"rg16sint":return void T(i,k,"16sint",2,L);case"rg16float":return void T(i,k,"16float",2,L);case"rgba16uint":return void T(i,k,"16uint",4,L);case"rgba16sint":return void T(i,k,"16sint",4,L);case"rgba16float":return void T(i,k,"16float",4,L);case"r32uint":return void T(i,k,"32uint",1,L);case"r32sint":return void T(i,k,"32sint",1,L);case"depth16unorm":case"depth24plus":case"depth24plus-stencil8":case"depth32float":case"depth32float-stencil8":case"r32float":return void T(i,k,"32float",1,L);case"rg32uint":return void T(i,k,"32uint",2,L);case"rg32sint":return void T(i,k,"32sint",2,L);case"rg32float":return void T(i,k,"32float",2,L);case"rgba32uint":return void T(i,k,"32uint",4,L);case"rgba32sint":return void T(i,k,"32sint",4,L);case"rgba32float":return void T(i,k,"32float",4,L);case"rg11b10ufloat":console.error("TODO:rg11b10ufloat not supported for writing")}}(new Uint8Array(w),i,g,x,_,S,y,b,this.format,v)}}(i=>{i[i.token=0]="token",i[i.keyword=1]="keyword",i[i.reserved=2]="reserved"})(An||(An={}));class qe{constructor(i,g,x){this.name=i,this.type=g,this.rule=x}toString(){return this.name}}class He{}Ln=He,He.none=new qe("",An.reserved,""),He.eof=new qe("EOF",An.token,""),He.reserved={asm:new qe("asm",An.reserved,"asm"),bf16:new qe("bf16",An.reserved,"bf16"),do:new qe("do",An.reserved,"do"),enum:new qe("enum",An.reserved,"enum"),f16:new qe("f16",An.reserved,"f16"),f64:new qe("f64",An.reserved,"f64"),handle:new qe("handle",An.reserved,"handle"),i8:new qe("i8",An.reserved,"i8"),i16:new qe("i16",An.reserved,"i16"),i64:new qe("i64",An.reserved,"i64"),mat:new qe("mat",An.reserved,"mat"),premerge:new qe("premerge",An.reserved,"premerge"),regardless:new qe("regardless",An.reserved,"regardless"),typedef:new qe("typedef",An.reserved,"typedef"),u8:new qe("u8",An.reserved,"u8"),u16:new qe("u16",An.reserved,"u16"),u64:new qe("u64",An.reserved,"u64"),unless:new qe("unless",An.reserved,"unless"),using:new qe("using",An.reserved,"using"),vec:new qe("vec",An.reserved,"vec"),void:new qe("void",An.reserved,"void")},He.keywords={array:new qe("array",An.keyword,"array"),atomic:new qe("atomic",An.keyword,"atomic"),bool:new qe("bool",An.keyword,"bool"),f32:new qe("f32",An.keyword,"f32"),i32:new qe("i32",An.keyword,"i32"),mat2x2:new qe("mat2x2",An.keyword,"mat2x2"),mat2x3:new qe("mat2x3",An.keyword,"mat2x3"),mat2x4:new qe("mat2x4",An.keyword,"mat2x4"),mat3x2:new qe("mat3x2",An.keyword,"mat3x2"),mat3x3:new qe("mat3x3",An.keyword,"mat3x3"),mat3x4:new qe("mat3x4",An.keyword,"mat3x4"),mat4x2:new qe("mat4x2",An.keyword,"mat4x2"),mat4x3:new qe("mat4x3",An.keyword,"mat4x3"),mat4x4:new qe("mat4x4",An.keyword,"mat4x4"),ptr:new qe("ptr",An.keyword,"ptr"),sampler:new qe("sampler",An.keyword,"sampler"),sampler_comparison:new qe("sampler_comparison",An.keyword,"sampler_comparison"),struct:new qe("struct",An.keyword,"struct"),texture_1d:new qe("texture_1d",An.keyword,"texture_1d"),texture_2d:new qe("texture_2d",An.keyword,"texture_2d"),texture_2d_array:new qe("texture_2d_array",An.keyword,"texture_2d_array"),texture_3d:new qe("texture_3d",An.keyword,"texture_3d"),texture_cube:new qe("texture_cube",An.keyword,"texture_cube"),texture_cube_array:new qe("texture_cube_array",An.keyword,"texture_cube_array"),texture_multisampled_2d:new qe("texture_multisampled_2d",An.keyword,"texture_multisampled_2d"),texture_storage_1d:new qe("texture_storage_1d",An.keyword,"texture_storage_1d"),texture_storage_2d:new qe("texture_storage_2d",An.keyword,"texture_storage_2d"),texture_storage_2d_array:new qe("texture_storage_2d_array",An.keyword,"texture_storage_2d_array"),texture_storage_3d:new qe("texture_storage_3d",An.keyword,"texture_storage_3d"),texture_depth_2d:new qe("texture_depth_2d",An.keyword,"texture_depth_2d"),texture_depth_2d_array:new qe("texture_depth_2d_array",An.keyword,"texture_depth_2d_array"),texture_depth_cube:new qe("texture_depth_cube",An.keyword,"texture_depth_cube"),texture_depth_cube_array:new qe("texture_depth_cube_array",An.keyword,"texture_depth_cube_array"),texture_depth_multisampled_2d:new qe("texture_depth_multisampled_2d",An.keyword,"texture_depth_multisampled_2d"),texture_external:new qe("texture_external",An.keyword,"texture_external"),u32:new qe("u32",An.keyword,"u32"),vec2:new qe("vec2",An.keyword,"vec2"),vec3:new qe("vec3",An.keyword,"vec3"),vec4:new qe("vec4",An.keyword,"vec4"),bitcast:new qe("bitcast",An.keyword,"bitcast"),block:new qe("block",An.keyword,"block"),break:new qe("break",An.keyword,"break"),case:new qe("case",An.keyword,"case"),continue:new qe("continue",An.keyword,"continue"),continuing:new qe("continuing",An.keyword,"continuing"),default:new qe("default",An.keyword,"default"),diagnostic:new qe("diagnostic",An.keyword,"diagnostic"),discard:new qe("discard",An.keyword,"discard"),else:new qe("else",An.keyword,"else"),enable:new qe("enable",An.keyword,"enable"),fallthrough:new qe("fallthrough",An.keyword,"fallthrough"),false:new qe("false",An.keyword,"false"),fn:new qe("fn",An.keyword,"fn"),for:new qe("for",An.keyword,"for"),function:new qe("function",An.keyword,"function"),if:new qe("if",An.keyword,"if"),let:new qe("let",An.keyword,"let"),const:new qe("const",An.keyword,"const"),loop:new qe("loop",An.keyword,"loop"),while:new qe("while",An.keyword,"while"),private:new qe("private",An.keyword,"private"),read:new qe("read",An.keyword,"read"),read_write:new qe("read_write",An.keyword,"read_write"),return:new qe("return",An.keyword,"return"),requires:new qe("requires",An.keyword,"requires"),storage:new qe("storage",An.keyword,"storage"),switch:new qe("switch",An.keyword,"switch"),true:new qe("true",An.keyword,"true"),alias:new qe("alias",An.keyword,"alias"),type:new qe("type",An.keyword,"type"),uniform:new qe("uniform",An.keyword,"uniform"),var:new qe("var",An.keyword,"var"),override:new qe("override",An.keyword,"override"),workgroup:new qe("workgroup",An.keyword,"workgroup"),write:new qe("write",An.keyword,"write"),r8unorm:new qe("r8unorm",An.keyword,"r8unorm"),r8snorm:new qe("r8snorm",An.keyword,"r8snorm"),r8uint:new qe("r8uint",An.keyword,"r8uint"),r8sint:new qe("r8sint",An.keyword,"r8sint"),r16uint:new qe("r16uint",An.keyword,"r16uint"),r16sint:new qe("r16sint",An.keyword,"r16sint"),r16float:new qe("r16float",An.keyword,"r16float"),rg8unorm:new qe("rg8unorm",An.keyword,"rg8unorm"),rg8snorm:new qe("rg8snorm",An.keyword,"rg8snorm"),rg8uint:new qe("rg8uint",An.keyword,"rg8uint"),rg8sint:new qe("rg8sint",An.keyword,"rg8sint"),r32uint:new qe("r32uint",An.keyword,"r32uint"),r32sint:new qe("r32sint",An.keyword,"r32sint"),r32float:new qe("r32float",An.keyword,"r32float"),rg16uint:new qe("rg16uint",An.keyword,"rg16uint"),rg16sint:new qe("rg16sint",An.keyword,"rg16sint"),rg16float:new qe("rg16float",An.keyword,"rg16float"),rgba8unorm:new qe("rgba8unorm",An.keyword,"rgba8unorm"),rgba8unorm_srgb:new qe("rgba8unorm_srgb",An.keyword,"rgba8unorm_srgb"),rgba8snorm:new qe("rgba8snorm",An.keyword,"rgba8snorm"),rgba8uint:new qe("rgba8uint",An.keyword,"rgba8uint"),rgba8sint:new qe("rgba8sint",An.keyword,"rgba8sint"),bgra8unorm:new qe("bgra8unorm",An.keyword,"bgra8unorm"),bgra8unorm_srgb:new qe("bgra8unorm_srgb",An.keyword,"bgra8unorm_srgb"),rgb10a2unorm:new qe("rgb10a2unorm",An.keyword,"rgb10a2unorm"),rg11b10float:new qe("rg11b10float",An.keyword,"rg11b10float"),rg32uint:new qe("rg32uint",An.keyword,"rg32uint"),rg32sint:new qe("rg32sint",An.keyword,"rg32sint"),rg32float:new qe("rg32float",An.keyword,"rg32float"),rgba16uint:new qe("rgba16uint",An.keyword,"rgba16uint"),rgba16sint:new qe("rgba16sint",An.keyword,"rgba16sint"),rgba16float:new qe("rgba16float",An.keyword,"rgba16float"),rgba32uint:new qe("rgba32uint",An.keyword,"rgba32uint"),rgba32sint:new qe("rgba32sint",An.keyword,"rgba32sint"),rgba32float:new qe("rgba32float",An.keyword,"rgba32float"),static_assert:new qe("static_assert",An.keyword,"static_assert")},He.tokens={decimal_float_literal:new qe("decimal_float_literal",An.token,/((-?[0-9]*\.[0-9]+|-?[0-9]+\.[0-9]*)((e|E)(\+|-)?[0-9]+)?[fh]?)|(-?[0-9]+(e|E)(\+|-)?[0-9]+[fh]?)|(-?[0-9]+[fh])/),hex_float_literal:new qe("hex_float_literal",An.token,/-?0x((([0-9a-fA-F]*\.[0-9a-fA-F]+|[0-9a-fA-F]+\.[0-9a-fA-F]*)((p|P)(\+|-)?[0-9]+[fh]?)?)|([0-9a-fA-F]+(p|P)(\+|-)?[0-9]+[fh]?))/),int_literal:new qe("int_literal",An.token,/-?0x[0-9a-fA-F]+|0i?|-?[1-9][0-9]*i?/),uint_literal:new qe("uint_literal",An.token,/0x[0-9a-fA-F]+u|0u|[1-9][0-9]*u/),name:new qe("name",An.token,/([_\p{XID_Start}][\p{XID_Continue}]+)|([\p{XID_Start}])/u),ident:new qe("ident",An.token,/[_a-zA-Z][0-9a-zA-Z_]*/),and:new qe("and",An.token,"&"),and_and:new qe("and_and",An.token,"&&"),arrow:new qe("arrow ",An.token,"->"),attr:new qe("attr",An.token,"@"),forward_slash:new qe("forward_slash",An.token,"/"),bang:new qe("bang",An.token,"!"),bracket_left:new qe("bracket_left",An.token,"["),bracket_right:new qe("bracket_right",An.token,"]"),brace_left:new qe("brace_left",An.token,"{"),brace_right:new qe("brace_right",An.token,"}"),colon:new qe("colon",An.token,":"),comma:new qe("comma",An.token,","),equal:new qe("equal",An.token,"="),equal_equal:new qe("equal_equal",An.token,"=="),not_equal:new qe("not_equal",An.token,"!="),greater_than:new qe("greater_than",An.token,">"),greater_than_equal:new qe("greater_than_equal",An.token,">="),shift_right:new qe("shift_right",An.token,">>"),less_than:new qe("less_than",An.token,"<"),less_than_equal:new qe("less_than_equal",An.token,"<="),shift_left:new qe("shift_left",An.token,"<<"),modulo:new qe("modulo",An.token,"%"),minus:new qe("minus",An.token,"-"),minus_minus:new qe("minus_minus",An.token,"--"),period:new qe("period",An.token,"."),plus:new qe("plus",An.token,"+"),plus_plus:new qe("plus_plus",An.token,"++"),or:new qe("or",An.token,"|"),or_or:new qe("or_or",An.token,"||"),paren_left:new qe("paren_left",An.token,"("),paren_right:new qe("paren_right",An.token,")"),semicolon:new qe("semicolon",An.token,";"),star:new qe("star",An.token,"*"),tilde:new qe("tilde",An.token,"~"),underscore:new qe("underscore",An.token,"_"),xor:new qe("xor",An.token,"^"),plus_equal:new qe("plus_equal",An.token,"+="),minus_equal:new qe("minus_equal",An.token,"-="),times_equal:new qe("times_equal",An.token,"*="),division_equal:new qe("division_equal",An.token,"/="),modulo_equal:new qe("modulo_equal",An.token,"%="),and_equal:new qe("and_equal",An.token,"&="),or_equal:new qe("or_equal",An.token,"|="),xor_equal:new qe("xor_equal",An.token,"^="),shift_right_equal:new qe("shift_right_equal",An.token,">>="),shift_left_equal:new qe("shift_left_equal",An.token,"<<=")},He.simpleTokens={"@":Ln.tokens.attr,"{":Ln.tokens.brace_left,"}":Ln.tokens.brace_right,":":Ln.tokens.colon,",":Ln.tokens.comma,"(":Ln.tokens.paren_left,")":Ln.tokens.paren_right,";":Ln.tokens.semicolon},He.literalTokens={"&":Ln.tokens.and,"&&":Ln.tokens.and_and,"->":Ln.tokens.arrow,"/":Ln.tokens.forward_slash,"!":Ln.tokens.bang,"[":Ln.tokens.bracket_left,"]":Ln.tokens.bracket_right,"=":Ln.tokens.equal,"==":Ln.tokens.equal_equal,"!=":Ln.tokens.not_equal,">":Ln.tokens.greater_than,">=":Ln.tokens.greater_than_equal,">>":Ln.tokens.shift_right,"<":Ln.tokens.less_than,"<=":Ln.tokens.less_than_equal,"<<":Ln.tokens.shift_left,"%":Ln.tokens.modulo,"-":Ln.tokens.minus,"--":Ln.tokens.minus_minus,".":Ln.tokens.period,"+":Ln.tokens.plus,"++":Ln.tokens.plus_plus,"|":Ln.tokens.or,"||":Ln.tokens.or_or,"*":Ln.tokens.star,"~":Ln.tokens.tilde,_:Ln.tokens.underscore,"^":Ln.tokens.xor,"+=":Ln.tokens.plus_equal,"-=":Ln.tokens.minus_equal,"*=":Ln.tokens.times_equal,"/=":Ln.tokens.division_equal,"%=":Ln.tokens.modulo_equal,"&=":Ln.tokens.and_equal,"|=":Ln.tokens.or_equal,"^=":Ln.tokens.xor_equal,">>=":Ln.tokens.shift_right_equal,"<<=":Ln.tokens.shift_left_equal},He.regexTokens={decimal_float_literal:Ln.tokens.decimal_float_literal,hex_float_literal:Ln.tokens.hex_float_literal,int_literal:Ln.tokens.int_literal,uint_literal:Ln.tokens.uint_literal,ident:Ln.tokens.ident},He.storage_class=[Ln.keywords.function,Ln.keywords.private,Ln.keywords.workgroup,Ln.keywords.uniform,Ln.keywords.storage],He.access_mode=[Ln.keywords.read,Ln.keywords.write,Ln.keywords.read_write],He.sampler_type=[Ln.keywords.sampler,Ln.keywords.sampler_comparison],He.sampled_texture_type=[Ln.keywords.texture_1d,Ln.keywords.texture_2d,Ln.keywords.texture_2d_array,Ln.keywords.texture_3d,Ln.keywords.texture_cube,Ln.keywords.texture_cube_array],He.multisampled_texture_type=[Ln.keywords.texture_multisampled_2d],He.storage_texture_type=[Ln.keywords.texture_storage_1d,Ln.keywords.texture_storage_2d,Ln.keywords.texture_storage_2d_array,Ln.keywords.texture_storage_3d],He.depth_texture_type=[Ln.keywords.texture_depth_2d,Ln.keywords.texture_depth_2d_array,Ln.keywords.texture_depth_cube,Ln.keywords.texture_depth_cube_array,Ln.keywords.texture_depth_multisampled_2d],He.texture_external_type=[Ln.keywords.texture_external],He.any_texture_type=[...Ln.sampled_texture_type,...Ln.multisampled_texture_type,...Ln.storage_texture_type,...Ln.depth_texture_type,...Ln.texture_external_type],He.texel_format=[Ln.keywords.r8unorm,Ln.keywords.r8snorm,Ln.keywords.r8uint,Ln.keywords.r8sint,Ln.keywords.r16uint,Ln.keywords.r16sint,Ln.keywords.r16float,Ln.keywords.rg8unorm,Ln.keywords.rg8snorm,Ln.keywords.rg8uint,Ln.keywords.rg8sint,Ln.keywords.r32uint,Ln.keywords.r32sint,Ln.keywords.r32float,Ln.keywords.rg16uint,Ln.keywords.rg16sint,Ln.keywords.rg16float,Ln.keywords.rgba8unorm,Ln.keywords.rgba8unorm_srgb,Ln.keywords.rgba8snorm,Ln.keywords.rgba8uint,Ln.keywords.rgba8sint,Ln.keywords.bgra8unorm,Ln.keywords.bgra8unorm_srgb,Ln.keywords.rgb10a2unorm,Ln.keywords.rg11b10float,Ln.keywords.rg32uint,Ln.keywords.rg32sint,Ln.keywords.rg32float,Ln.keywords.rgba16uint,Ln.keywords.rgba16sint,Ln.keywords.rgba16float,Ln.keywords.rgba32uint,Ln.keywords.rgba32sint,Ln.keywords.rgba32float],He.const_literal=[Ln.tokens.int_literal,Ln.tokens.uint_literal,Ln.tokens.decimal_float_literal,Ln.tokens.hex_float_literal,Ln.keywords.true,Ln.keywords.false],He.literal_or_ident=[Ln.tokens.ident,Ln.tokens.int_literal,Ln.tokens.uint_literal,Ln.tokens.decimal_float_literal,Ln.tokens.hex_float_literal,Ln.tokens.name],He.element_count_expression=[Ln.tokens.int_literal,Ln.tokens.uint_literal,Ln.tokens.ident],He.template_types=[Ln.keywords.vec2,Ln.keywords.vec3,Ln.keywords.vec4,Ln.keywords.mat2x2,Ln.keywords.mat2x3,Ln.keywords.mat2x4,Ln.keywords.mat3x2,Ln.keywords.mat3x3,Ln.keywords.mat3x4,Ln.keywords.mat4x2,Ln.keywords.mat4x3,Ln.keywords.mat4x4,Ln.keywords.atomic,Ln.keywords.bitcast,...Ln.any_texture_type],He.attribute_name=[Ln.tokens.ident,Ln.keywords.block,Ln.keywords.diagnostic],He.assignment_operators=[Ln.tokens.equal,Ln.tokens.plus_equal,Ln.tokens.minus_equal,Ln.tokens.times_equal,Ln.tokens.division_equal,Ln.tokens.modulo_equal,Ln.tokens.and_equal,Ln.tokens.or_equal,Ln.tokens.xor_equal,Ln.tokens.shift_right_equal,Ln.tokens.shift_left_equal],He.increment_operators=[Ln.tokens.plus_plus,Ln.tokens.minus_minus];class ze{constructor(i,g,x,_,v){this.type=i,this.lexeme=g,this.line=x,this.start=_,this.end=v}toString(){return this.lexeme}isTemplateType(){return-1!=He.template_types.indexOf(this.type)}isArrayType(){return this.type==He.keywords.array}isArrayOrTemplateType(){return this.isArrayType()||this.isTemplateType()}}class Re{constructor(i){this._tokens=[],this._start=0,this._current=0,this._line=1,this._source=null!=i?i:""}scanTokens(){for(;!this._isAtEnd();)if(this._start=this._current,!this.scanToken())throw`Invalid syntax at line ${this._line}`;return this._tokens.push(new ze(He.eof,"",this._line,this._current,this._current)),this._tokens}scanToken(){let i=this._advance();if("\n"==i)return this._line++,!0;if(this._isWhitespace(i))return!0;if("/"==i){if("/"==this._peekAhead()){for(;"\n"!=i;){if(this._isAtEnd())return!0;i=this._advance()}return this._line++,!0}if("*"==this._peekAhead()){this._advance();let g=1;for(;g>0;){if(this._isAtEnd())return!0;if(i=this._advance(),"\n"==i)this._line++;else if("*"==i){if("/"==this._peekAhead()&&(this._advance(),g--,0==g))return!0}else"/"==i&&"*"==this._peekAhead()&&(this._advance(),g++)}return!0}}const g=He.simpleTokens[i];if(g)return this._addToken(g),!0;let x=He.none;const _=this._isAlpha(i),v="_"===i;if(this._isAlphaNumeric(i)){let g=this._peekAhead();for(;this._isAlphaNumeric(g);)i+=this._advance(),g=this._peekAhead()}if(_){const g=He.keywords[i];if(g)return this._addToken(g),!0}if(_||v)return this._addToken(He.tokens.ident),!0;for(;;){let g=this._findType(i);const _=this._peekAhead();if("-"==i&&this._tokens.length>0){if("="==_)return this._current++,i+=_,this._addToken(He.tokens.minus_equal),!0;if("-"==_)return this._current++,i+=_,this._addToken(He.tokens.minus_minus),!0;const x=this._tokens.length-1;if((-1!=He.literal_or_ident.indexOf(this._tokens[x].type)||this._tokens[x].type==He.tokens.paren_right)&&">"!=_)return this._addToken(g),!0}if(">"==i&&(">"==_||"="==_)){let i=!1,x=this._tokens.length-1;for(let g=0;g<5&&x>=0&&-1===He.assignment_operators.indexOf(this._tokens[x].type);++g,--x)if(this._tokens[x].type===He.tokens.less_than){x>0&&this._tokens[x-1].isArrayOrTemplateType()&&(i=!0);break}if(i)return this._addToken(g),!0}if(g===He.none){let _=i,v=0;const b=2;for(let i=0;i=this._source.length}_isAlpha(i){return!this._isNumeric(i)&&!this._isWhitespace(i)&&"_"!==i&&"."!==i&&"("!==i&&")"!==i&&"["!==i&&"]"!==i&&"{"!==i&&"}"!==i&&","!==i&&";"!==i&&":"!==i&&"="!==i&&"!"!==i&&"<"!==i&&">"!==i&&"+"!==i&&"-"!==i&&"*"!==i&&"/"!==i&&"%"!==i&&"&"!==i&&"|"!==i&&"^"!==i&&"~"!==i&&"@"!==i&&"#"!==i&&"?"!==i&&"'"!==i&&"`"!==i&&'"'!==i&&"\\"!==i&&"\n"!==i&&"\r"!==i&&"\t"!==i&&"\0"!==i}_isNumeric(i){return i>="0"&&i<="9"}_isAlphaNumeric(i){return this._isAlpha(i)||this._isNumeric(i)||"_"===i}_isWhitespace(i){return" "==i||"\t"==i||"\r"==i}_advance(i=0){let g=this._source[this._current];return i=i||0,i++,this._current+=i,g}_peekAhead(i=0){return i=i||0,this._current+i>=this._source.length?"\0":this._source[this._current+i]}_addToken(i){const g=this._source.substring(this._start,this._current);this._tokens.push(new ze(i,g,this._line,this._start,this._current))}}function Ge(i){return Array.isArray(i)||(null==i?void 0:i.buffer)instanceof ArrayBuffer}const Gn=new Float32Array(1),kn=new Uint32Array(Gn.buffer),On=new Uint32Array(Gn.buffer),Nn=new Int32Array(1),Vn=new Float32Array(Nn.buffer),Fn=new Uint32Array(Nn.buffer),Hn=new Uint32Array(1),zn=new Float32Array(Hn.buffer),$n=new Int32Array(Hn.buffer);function nt(i,g,x){if(g===x)return i;if("f32"===g){if("i32"===x||"x32"===x)return Gn[0]=i,kn[0];if("u32"===x)return Gn[0]=i,On[0]}else if("i32"===g||"x32"===g){if("f32"===x)return Nn[0]=i,Vn[0];if("u32"===x)return Nn[0]=i,Fn[0]}else if("u32"===g){if("f32"===x)return Hn[0]=i,zn[0];if("i32"===x||"x32"===x)return Hn[0]=i,$n[0]}return console.error(`Unsupported cast from ${g} to ${x}`),i}class st{constructor(i){this.resources=null,this.inUse=!1,this.info=null,this.node=i}}class rt{constructor(i,g){this.align=i,this.size=g}}class at{constructor(){this.uniforms=[],this.storage=[],this.textures=[],this.samplers=[],this.aliases=[],this.overrides=[],this.structs=[],this.entry=new d,this.functions=[],this._types=new Map,this._functions=new Map}_isStorageTexture(i){return"texture_storage_1d"==i.name||"texture_storage_2d"==i.name||"texture_storage_2d_array"==i.name||"texture_storage_3d"==i.name}updateAST(i){for(const g of i)g instanceof D&&this._functions.set(g.name,new st(g));for(const g of i)if(g instanceof oe){const i=this.getTypeInfo(g,null);i instanceof n&&this.structs.push(i)}for(const g of i)if(g instanceof te)this.aliases.push(this._getAliasInfo(g));else{if(g instanceof M){const i=g,x=this._getAttributeNum(i.attributes,"id",0),_=null!=i.type?this.getTypeInfo(i.type,i.attributes):null;this.overrides.push(new h(i.name,_,i.attributes,x));continue}if(this._isUniformVar(g)){const i=g,x=this._getAttributeNum(i.attributes,"group",0),_=this._getAttributeNum(i.attributes,"binding",0),v=this.getTypeInfo(i.type,i.attributes),b=new o(i.name,v,x,_,i.attributes,Mn.Uniform,i.access);b.access||(b.access="read"),this.uniforms.push(b);continue}if(this._isStorageVar(g)){const i=g,x=this._getAttributeNum(i.attributes,"group",0),_=this._getAttributeNum(i.attributes,"binding",0),v=this.getTypeInfo(i.type,i.attributes),b=this._isStorageTexture(v),y=new o(i.name,v,x,_,i.attributes,b?Mn.StorageTexture:Mn.Storage,i.access);y.access||(y.access="read"),this.storage.push(y);continue}if(this._isTextureVar(g)){const i=g,x=this._getAttributeNum(i.attributes,"group",0),_=this._getAttributeNum(i.attributes,"binding",0),v=this.getTypeInfo(i.type,i.attributes),b=this._isStorageTexture(v),y=new o(i.name,v,x,_,i.attributes,b?Mn.StorageTexture:Mn.Texture,i.access);y.access||(y.access="read"),b?this.storage.push(y):this.textures.push(y);continue}if(this._isSamplerVar(g)){const i=g,x=this._getAttributeNum(i.attributes,"group",0),_=this._getAttributeNum(i.attributes,"binding",0),v=this.getTypeInfo(i.type,i.attributes),b=new o(i.name,v,x,_,i.attributes,Mn.Sampler,i.access);this.samplers.push(b);continue}}for(const g of i)if(g instanceof D){const i=this._getAttribute(g,"vertex"),x=this._getAttribute(g,"fragment"),_=this._getAttribute(g,"compute"),v=i||x||_,b=new p(g.name,null==v?void 0:v.name,g.attributes);b.attributes=g.attributes,b.startLine=g.startLine,b.endLine=g.endLine,this.functions.push(b),this._functions.get(g.name).info=b,v&&(this._functions.get(g.name).inUse=!0,b.inUse=!0,b.resources=this._findResources(g,!!v),b.inputs=this._getInputs(g.args),b.outputs=this._getOutputs(g.returnType),this.entry[v.name].push(b)),b.arguments=g.args.map(i=>new f(i.name,this.getTypeInfo(i.type,i.attributes),i.attributes)),b.returnType=g.returnType?this.getTypeInfo(g.returnType,g.attributes):null;continue}for(const i of this._functions.values())i.info&&(i.info.inUse=i.inUse,this._addCalls(i.node,i.info.calls));for(const i of this._functions.values())i.node.search(g=>{var x,_,v;if(g instanceof De){if(g.value)if(Ge(g.value))for(const _ of g.value)for(const g of this.overrides)_===g.name&&(null===(x=i.info)||void 0===x||x.overrides.push(g));else for(const x of this.overrides)g.value===x.name&&(null===(_=i.info)||void 0===_||_.overrides.push(x))}else if(g instanceof ge)for(const x of this.overrides)g.name===x.name&&(null===(v=i.info)||void 0===v||v.overrides.push(x))});for(const i of this.uniforms)this._markStructsInUse(i.type);for(const i of this.storage)this._markStructsInUse(i.type)}getFunctionInfo(i){for(const g of this.functions)if(g.name==i)return g;return null}getStructInfo(i){for(const g of this.structs)if(g.name==i)return g;return null}getOverrideInfo(i){for(const g of this.overrides)if(g.name==i)return g;return null}_markStructsInUse(i){if(i)if(i.isStruct){if(i.inUse=!0,i.members)for(const g of i.members)this._markStructsInUse(g.type)}else if(i.isArray)this._markStructsInUse(i.format);else if(i.isTemplate)i.format&&this._markStructsInUse(i.format);else{const g=this._getAlias(i.name);g&&this._markStructsInUse(g)}}_addCalls(i,g){var x;for(const _ of i.calls){const i=null===(x=this._functions.get(_.name))||void 0===x?void 0:x.info;i&&g.add(i)}}findResource(i,g,x){if(x){for(const _ of this.entry.compute)if(_.name===x)for(const x of _.resources)if(x.group==i&&x.binding==g)return x;for(const _ of this.entry.vertex)if(_.name===x)for(const x of _.resources)if(x.group==i&&x.binding==g)return x;for(const _ of this.entry.fragment)if(_.name===x)for(const x of _.resources)if(x.group==i&&x.binding==g)return x}for(const x of this.uniforms)if(x.group==i&&x.binding==g)return x;for(const x of this.storage)if(x.group==i&&x.binding==g)return x;for(const x of this.textures)if(x.group==i&&x.binding==g)return x;for(const x of this.samplers)if(x.group==i&&x.binding==g)return x;return null}_findResource(i){for(const g of this.uniforms)if(g.name==i)return g;for(const g of this.storage)if(g.name==i)return g;for(const g of this.textures)if(g.name==i)return g;for(const g of this.samplers)if(g.name==i)return g;return null}_markStructsFromAST(i){const g=this.getTypeInfo(i,null);this._markStructsInUse(g)}_findResources(i,g){const x=[],_=this,v=[];return i.search(b=>{if(b instanceof E)v.push({});else if(b instanceof $)v.pop();else if(b instanceof F){const i=b;g&&null!==i.type&&this._markStructsFromAST(i.type),v.length>0&&(v[v.length-1][i.name]=i)}else if(b instanceof de){const i=b;g&&null!==i.type&&this._markStructsFromAST(i.type)}else if(b instanceof U){const i=b;g&&null!==i.type&&this._markStructsFromAST(i.type),v.length>0&&(v[v.length-1][i.name]=i)}else if(b instanceof ge){const i=b;if(v.length>0&&v[v.length-1][i.name])return;const g=_._findResource(i.name);g&&x.push(g)}else if(b instanceof me){const v=b,y=_._functions.get(v.name);y&&(g&&(y.inUse=!0),i.calls.add(y.node),null===y.resources&&(y.resources=_._findResources(y.node,g)),x.push(...y.resources))}else if(b instanceof X){const v=b,y=_._functions.get(v.name);y&&(g&&(y.inUse=!0),i.calls.add(y.node),null===y.resources&&(y.resources=_._findResources(y.node,g)),x.push(...y.resources))}}),[...new Map(x.map(i=>[i.name,i])).values()]}getBindGroups(){const i=[];function t(g,x){g>=i.length&&(i.length=g+1),void 0===i[g]&&(i[g]=[]),x>=i[g].length&&(i[g].length=x+1)}for(const g of this.uniforms)t(g.group,g.binding),i[g.group][g.binding]=g;for(const g of this.storage)t(g.group,g.binding),i[g.group][g.binding]=g;for(const g of this.textures)t(g.group,g.binding),i[g.group][g.binding]=g;for(const g of this.samplers)t(g.group,g.binding),i[g.group][g.binding]=g;return i}_getOutputs(i,g=void 0){if(void 0===g&&(g=[]),i instanceof oe)this._getStructOutputs(i,g);else{const x=this._getOutputInfo(i);null!==x&&g.push(x)}return g}_getStructOutputs(i,g){for(const x of i.members)if(x.type instanceof oe)this._getStructOutputs(x.type,g);else{const i=this._getAttribute(x,"location")||this._getAttribute(x,"builtin");if(null!==i){const _=this.getTypeInfo(x.type,x.type.attributes),v=this._parseInt(i.value),b=new u(x.name,_,i.name,v);g.push(b)}}}_getOutputInfo(i){const g=this._getAttribute(i,"location")||this._getAttribute(i,"builtin");if(null!==g){const x=this.getTypeInfo(i,i.attributes),_=this._parseInt(g.value);return new u("",x,g.name,_)}return null}_getInputs(i,g=void 0){void 0===g&&(g=[]);for(const x of i)if(x.type instanceof oe)this._getStructInputs(x.type,g);else{const i=this._getInputInfo(x);null!==i&&g.push(i)}return g}_getStructInputs(i,g){for(const x of i.members)if(x.type instanceof oe)this._getStructInputs(x.type,g);else{const i=this._getInputInfo(x);null!==i&&g.push(i)}}_getInputInfo(i){const g=this._getAttribute(i,"location")||this._getAttribute(i,"builtin");if(null!==g){const x=this._getAttribute(i,"interpolation"),_=this.getTypeInfo(i.type,i.attributes),v=this._parseInt(g.value),b=new l(i.name,_,g.name,v);return null!==x&&(b.interpolation=this._parseString(x.value)),b}return null}_parseString(i){return i instanceof Array&&(i=i[0]),i}_parseInt(i){i instanceof Array&&(i=i[0]);const g=parseInt(i);return isNaN(g)?i:g}_getAlias(i){for(const g of this.aliases)if(g.name==i)return g.type;return null}_getAliasInfo(i){return new c(i.name,this.getTypeInfo(i.type,null))}getTypeInfoByName(i){for(const g of this.structs)if(g.name==i)return g;for(const g of this.aliases)if(g.name==i)return g.type;return null}getTypeInfo(i,g=null){if(this._types.has(i))return this._types.get(i);if(i instanceof le){const x=i.type?this.getTypeInfo(i.type,i.attributes):null,_=new r(i.name,x,g);return this._types.set(i,_),this._updateTypeInfo(_),_}if(i instanceof ue){const x=i,_=x.format?this.getTypeInfo(x.format,x.attributes):null,v=new s(x.name,g);return v.format=_,v.count=x.count,this._types.set(i,v),this._updateTypeInfo(v),v}if(i instanceof oe){const x=i,_=new n(x.name,g);_.startLine=x.startLine,_.endLine=x.endLine;for(const i of x.members){const g=this.getTypeInfo(i.type,i.attributes);_.members.push(new t(i.name,g,i.attributes))}return this._types.set(i,_),this._updateTypeInfo(_),_}if(i instanceof he){const x=i,_=x.format instanceof ae,v=x.format?_?this.getTypeInfo(x.format,null):new e(x.format,null):null,b=new a(x.name,v,g,x.access);return this._types.set(i,b),this._updateTypeInfo(b),b}if(i instanceof ce){const x=i,_=x.format?this.getTypeInfo(x.format,null):null,v=new a(x.name,_,g,x.access);return this._types.set(i,v),this._updateTypeInfo(v),v}const x=new e(i.name,g);return this._types.set(i,x),this._updateTypeInfo(x),x}_updateTypeInfo(i){var g,x,_;const v=this._getTypeSize(i);if(i.size=null!==(g=null==v?void 0:v.size)&&void 0!==g?g:0,i instanceof s&&i.format){const g=this._getTypeSize(i.format);i.stride=Math.max(null!==(x=null==g?void 0:g.size)&&void 0!==x?x:0,null!==(_=null==g?void 0:g.align)&&void 0!==_?_:0),this._updateTypeInfo(i.format)}i instanceof r&&this._updateTypeInfo(i.format),i instanceof n&&this._updateStructInfo(i)}_updateStructInfo(i){var g;let x=0,_=0,v=0,b=0;for(let y=0,S=i.members.length;yi.name),at._samplerTypes=He.sampler_type.map(i=>i.name);let Kn=0;class ot{constructor(i,g,x){this.id=Kn++,this.name=i,this.value=g,this.node=x}clone(){return new ot(this.name,this.value,this.node)}}class ct{constructor(i){this.id=Kn++,this.name=i.name,this.node=i}clone(){return new ct(this.node)}}class lt{constructor(i){this.parent=null,this.variables=new Map,this.functions=new Map,this.currentFunctionName="",this.id=Kn++,i&&(this.parent=i,this.currentFunctionName=i.currentFunctionName)}getVariable(i){var g;return this.variables.has(i)?null!==(g=this.variables.get(i))&&void 0!==g?g:null:this.parent?this.parent.getVariable(i):null}getFunction(i){var g;return this.functions.has(i)?null!==(g=this.functions.get(i))&&void 0!==g?g:null:this.parent?this.parent.getFunction(i):null}createVariable(i,g,x){this.variables.set(i,new ot(i,g,null!=x?x:null))}setVariable(i,g,x){const _=this.getVariable(i);null!==_?_.value=g:this.createVariable(i,g,x)}getVariableValue(i){var g;const x=this.getVariable(i);return null!==(g=null==x?void 0:x.value)&&void 0!==g?g:null}clone(){return new lt(this)}}class ut{evalExpression(i,g){return null}getTypeInfo(i){return null}getVariableName(i,g){return""}}class ht{constructor(i){this.exec=i}getTypeInfo(i){return this.exec.getTypeInfo(i)}All(i,g){const x=this.exec.evalExpression(i.args[0],g);let _=!0;if(x instanceof Me)return x.data.forEach(i=>{i||(_=!1)}),new Be(_?1:0,this.getTypeInfo("bool"));throw new Error(`All() expects a vector argument. Line ${i.line}`)}Any(i,g){const x=this.exec.evalExpression(i.args[0],g);if(x instanceof Me){const i=x.data.some(i=>i);return new Be(i?1:0,this.getTypeInfo("bool"))}throw new Error(`Any() expects a vector argument. Line ${i.line}`)}Select(i,g){const x=this.exec.evalExpression(i.args[2],g);if(!(x instanceof Be))throw new Error(`Select() expects a bool condition. Line ${i.line}`);return x.value?this.exec.evalExpression(i.args[1],g):this.exec.evalExpression(i.args[0],g)}ArrayLength(i,g){let x=i.args[0];x instanceof ke&&(x=x.right);const _=this.exec.evalExpression(x,g);if(_ instanceof Pe&&0===_.typeInfo.size){const i=_.typeInfo,g=_.buffer.byteLength/i.stride;return new Be(g,this.getTypeInfo("u32"))}return new Be(_.typeInfo.size,this.getTypeInfo("u32"))}Abs(i,g){const x=this.exec.evalExpression(i.args[0],g);if(x instanceof Me)return new Me(x.data.map(i=>Math.abs(i)),x.typeInfo);const _=x;return new Be(Math.abs(_.value),_.typeInfo)}Acos(i,g){const x=this.exec.evalExpression(i.args[0],g);if(x instanceof Me)return new Me(x.data.map(i=>Math.acos(i)),x.typeInfo);const _=x;return new Be(Math.acos(_.value),x.typeInfo)}Acosh(i,g){const x=this.exec.evalExpression(i.args[0],g);if(x instanceof Me)return new Me(x.data.map(i=>Math.acosh(i)),x.typeInfo);const _=x;return new Be(Math.acosh(_.value),x.typeInfo)}Asin(i,g){const x=this.exec.evalExpression(i.args[0],g);if(x instanceof Me)return new Me(x.data.map(i=>Math.asin(i)),x.typeInfo);const _=x;return new Be(Math.asin(_.value),x.typeInfo)}Asinh(i,g){const x=this.exec.evalExpression(i.args[0],g);if(x instanceof Me)return new Me(x.data.map(i=>Math.asinh(i)),x.typeInfo);const _=x;return new Be(Math.asinh(_.value),x.typeInfo)}Atan(i,g){const x=this.exec.evalExpression(i.args[0],g);if(x instanceof Me)return new Me(x.data.map(i=>Math.atan(i)),x.typeInfo);const _=x;return new Be(Math.atan(_.value),x.typeInfo)}Atanh(i,g){const x=this.exec.evalExpression(i.args[0],g);if(x instanceof Me)return new Me(x.data.map(i=>Math.atanh(i)),x.typeInfo);const _=x;return new Be(Math.atanh(_.value),x.typeInfo)}Atan2(i,g){const x=this.exec.evalExpression(i.args[0],g),_=this.exec.evalExpression(i.args[1],g);if(x instanceof Me&&_ instanceof Me)return new Me(x.data.map((i,g)=>Math.atan2(i,_.data[g])),x.typeInfo);const v=x,b=_;return new Be(Math.atan2(v.value,b.value),x.typeInfo)}Ceil(i,g){const x=this.exec.evalExpression(i.args[0],g);if(x instanceof Me)return new Me(x.data.map(i=>Math.ceil(i)),x.typeInfo);const _=x;return new Be(Math.ceil(_.value),x.typeInfo)}_clamp(i,g,x){return Math.min(Math.max(i,g),x)}Clamp(i,g){const x=this.exec.evalExpression(i.args[0],g),_=this.exec.evalExpression(i.args[1],g),v=this.exec.evalExpression(i.args[2],g);if(x instanceof Me&&_ instanceof Me&&v instanceof Me)return new Me(x.data.map((i,g)=>this._clamp(i,_.data[g],v.data[g])),x.typeInfo);const b=x,y=_,S=v;return new Be(this._clamp(b.value,y.value,S.value),x.typeInfo)}Cos(i,g){const x=this.exec.evalExpression(i.args[0],g);if(x instanceof Me)return new Me(x.data.map(i=>Math.cos(i)),x.typeInfo);const _=x;return new Be(Math.cos(_.value),x.typeInfo)}Cosh(i,g){const x=this.exec.evalExpression(i.args[0],g);if(x instanceof Me)return new Me(x.data.map(i=>Math.cosh(i)),x.typeInfo);const _=x;return new Be(Math.cos(_.value),x.typeInfo)}CountLeadingZeros(i,g){const x=this.exec.evalExpression(i.args[0],g);if(x instanceof Me)return new Me(x.data.map(i=>Math.clz32(i)),x.typeInfo);const _=x;return new Be(Math.clz32(_.value),x.typeInfo)}_countOneBits(i){let g=0;for(;0!==i;)1&i&&g++,i>>=1;return g}CountOneBits(i,g){const x=this.exec.evalExpression(i.args[0],g);if(x instanceof Me)return new Me(x.data.map(i=>this._countOneBits(i)),x.typeInfo);const _=x;return new Be(this._countOneBits(_.value),x.typeInfo)}_countTrailingZeros(i){if(0===i)return 32;let g=0;for(;!(1&i);)i>>=1,g++;return g}CountTrailingZeros(i,g){const x=this.exec.evalExpression(i.args[0],g);if(x instanceof Me)return new Me(x.data.map(i=>this._countTrailingZeros(i)),x.typeInfo);const _=x;return new Be(this._countTrailingZeros(_.value),x.typeInfo)}Cross(i,g){const x=this.exec.evalExpression(i.args[0],g),_=this.exec.evalExpression(i.args[1],g);if(x instanceof Me&&_ instanceof Me){if(3!==x.data.length||3!==_.data.length)return console.error(`Cross() expects 3D vectors. Line ${i.line}`),null;const g=x.data,v=_.data;return new Me([g[1]*v[2]-v[1]*g[2],g[2]*v[0]-v[2]*g[0],g[0]*v[1]-v[0]*g[1]],x.typeInfo)}return console.error(`Cross() expects vector arguments. Line ${i.line}`),null}Degrees(i,g){const x=this.exec.evalExpression(i.args[0],g),_=180/Math.PI;return x instanceof Me?new Me(x.data.map(i=>i*_),x.typeInfo):new Be(x.value*_,this.getTypeInfo("f32"))}Determinant(i,g){const x=this.exec.evalExpression(i.args[0],g);if(x instanceof Ue){const i=x.data,g=x.typeInfo.getTypeName(),_=g.endsWith("h")?this.getTypeInfo("f16"):this.getTypeInfo("f32");if("mat2x2"===g||"mat2x2f"===g||"mat2x2h"===g)return new Be(i[0]*i[3]-i[1]*i[2],_);if("mat2x3"===g||"mat2x3f"===g||"mat2x3h"===g)return new Be(i[0]*(i[4]*i[8]-i[5]*i[7])-i[1]*(i[3]*i[8]-i[5]*i[6])+i[2]*(i[3]*i[7]-i[4]*i[6]),_);if("mat2x4"===g||"mat2x4f"===g||"mat2x4h"===g)console.error(`TODO:Determinant for ${g}`);else if("mat3x2"===g||"mat3x2f"===g||"mat3x2h"===g)console.error(`TODO:Determinant for ${g}`);else{if("mat3x3"===g||"mat3x3f"===g||"mat3x3h"===g)return new Be(i[0]*(i[4]*i[8]-i[5]*i[7])-i[1]*(i[3]*i[8]-i[5]*i[6])+i[2]*(i[3]*i[7]-i[4]*i[6]),_);"mat3x4"===g||"mat3x4f"===g||"mat3x4h"===g||"mat4x2"===g||"mat4x2f"===g||"mat4x2h"===g||"mat4x3"===g||"mat4x3f"===g||"mat4x3h"===g?console.error(`TODO:Determinant for ${g}`):"mat4x4"!==g&&"mat4x4f"!==g&&"mat4x4h"!==g||console.error(`TODO:Determinant for ${g}`)}}return console.error(`Determinant expects a matrix argument. Line ${i.line}`),null}Distance(i,g){const x=this.exec.evalExpression(i.args[0],g),_=this.exec.evalExpression(i.args[1],g);if(x instanceof Me&&_ instanceof Me){let i=0;for(let g=0;gMath.exp(i)),x.typeInfo);const _=x;return new Be(Math.exp(_.value),x.typeInfo)}Exp2(i,g){const x=this.exec.evalExpression(i.args[0],g);if(x instanceof Me)return new Me(x.data.map(i=>Math.pow(2,i)),x.typeInfo);const _=x;return new Be(Math.pow(2,_.value),x.typeInfo)}ExtractBits(i,g){const x=this.exec.evalExpression(i.args[0],g),_=this.exec.evalExpression(i.args[1],g),v=this.exec.evalExpression(i.args[2],g);if("u32"!==_.typeInfo.name&&"x32"!==_.typeInfo.name)return console.error(`ExtractBits() expects an i32 offset argument. Line ${i.line}`),null;if("u32"!==v.typeInfo.name&&"x32"!==v.typeInfo.name)return console.error(`ExtractBits() expects an i32 count argument. Line ${i.line}`),null;const b=_.value,y=v.value;if(x instanceof Me)return new Me(x.data.map(i=>i>>b&(1<>b&(1<-i),x.typeInfo)}return console.error(`FaceForward() expects vector arguments. Line ${i.line}`),null}_firstLeadingBit(i){return 0===i?-1:31-Math.clz32(i)}FirstLeadingBit(i,g){const x=this.exec.evalExpression(i.args[0],g);if(x instanceof Me)return new Me(x.data.map(i=>this._firstLeadingBit(i)),x.typeInfo);const _=x;return new Be(this._firstLeadingBit(_.value),x.typeInfo)}_firstTrailingBit(i){return 0===i?-1:Math.log2(i&-i)}FirstTrailingBit(i,g){const x=this.exec.evalExpression(i.args[0],g);if(x instanceof Me)return new Me(x.data.map(i=>this._firstTrailingBit(i)),x.typeInfo);const _=x;return new Be(this._firstTrailingBit(_.value),x.typeInfo)}Floor(i,g){const x=this.exec.evalExpression(i.args[0],g);if(x instanceof Me)return new Me(x.data.map(i=>Math.floor(i)),x.typeInfo);const _=x;return new Be(Math.floor(_.value),x.typeInfo)}Fma(i,g){const x=this.exec.evalExpression(i.args[0],g),_=this.exec.evalExpression(i.args[1],g),v=this.exec.evalExpression(i.args[2],g);if(x instanceof Me&&_ instanceof Me&&v instanceof Me)return x.data.length!==_.data.length||x.data.length!==v.data.length?(console.error(`Fma() expects vectors of the same length. Line ${i.line}`),null):new Me(x.data.map((i,g)=>i*_.data[g]+v.data[g]),x.typeInfo);const b=x,y=_,S=v;return new Be(b.value*y.value+S.value,b.typeInfo)}Fract(i,g){const x=this.exec.evalExpression(i.args[0],g);if(x instanceof Me)return new Me(x.data.map(i=>i-Math.floor(i)),x.typeInfo);const _=x;return new Be(_.value-Math.floor(_.value),x.typeInfo)}Frexp(i,g){return console.error(`TODO:frexp. Line ${i.line}`),null}InsertBits(i,g){const x=this.exec.evalExpression(i.args[0],g),_=this.exec.evalExpression(i.args[1],g),v=this.exec.evalExpression(i.args[2],g),b=this.exec.evalExpression(i.args[3],g);if("u32"!==v.typeInfo.name&&"x32"!==v.typeInfo.name)return console.error(`InsertBits() expects an i32 offset argument. Line ${i.line}`),null;const y=v.value,S=(1<i&w|_.data[g]<1/Math.sqrt(i)),x.typeInfo);const _=x;return new Be(1/Math.sqrt(_.value),x.typeInfo)}Ldexp(i,g){return console.error(`TODO:ldexp. Line ${i.line}`),null}Length(i,g){const x=this.exec.evalExpression(i.args[0],g);if(x instanceof Me){let i=0;return x.data.forEach(g=>{i+=g*g}),new Be(Math.sqrt(i),this.getTypeInfo("f32"))}const _=x;return new Be(Math.abs(_.value),x.typeInfo)}Log(i,g){const x=this.exec.evalExpression(i.args[0],g);if(x instanceof Me)return new Me(x.data.map(i=>Math.log(i)),x.typeInfo);const _=x;return new Be(Math.log(_.value),x.typeInfo)}Log2(i,g){const x=this.exec.evalExpression(i.args[0],g);if(x instanceof Me)return new Me(x.data.map(i=>Math.log2(i)),x.typeInfo);const _=x;return new Be(Math.log2(_.value),x.typeInfo)}Max(i,g){const x=this.exec.evalExpression(i.args[0],g),_=this.exec.evalExpression(i.args[1],g);if(x instanceof Me&&_ instanceof Me)return new Me(x.data.map((i,g)=>Math.max(i,_.data[g])),x.typeInfo);const v=x,b=_;return new Be(Math.max(v.value,b.value),x.typeInfo)}Min(i,g){const x=this.exec.evalExpression(i.args[0],g),_=this.exec.evalExpression(i.args[1],g);if(x instanceof Me&&_ instanceof Me)return new Me(x.data.map((i,g)=>Math.min(i,_.data[g])),x.typeInfo);const v=x,b=_;return new Be(Math.min(v.value,b.value),x.typeInfo)}Mix(i,g){const x=this.exec.evalExpression(i.args[0],g),_=this.exec.evalExpression(i.args[1],g),v=this.exec.evalExpression(i.args[2],g);if(x instanceof Me&&_ instanceof Me&&v instanceof Me)return new Me(x.data.map((i,g)=>x.data[g]*(1-v.data[g])+_.data[g]*v.data[g]),x.typeInfo);const b=_,y=v;return new Be(x.value*(1-y.value)+b.value*y.value,x.typeInfo)}Modf(i,g){const x=this.exec.evalExpression(i.args[0],g),_=this.exec.evalExpression(i.args[1],g);if(x instanceof Me&&_ instanceof Me)return new Me(x.data.map((i,g)=>i%_.data[g]),x.typeInfo);const v=_;return new Be(x.value%v.value,x.typeInfo)}Normalize(i,g){const x=this.exec.evalExpression(i.args[0],g);if(x instanceof Me){const _=this.Length(i,g).value;return new Me(x.data.map(i=>i/_),x.typeInfo)}return console.error(`Normalize() expects a vector argument. Line ${i.line}`),null}Pow(i,g){const x=this.exec.evalExpression(i.args[0],g),_=this.exec.evalExpression(i.args[1],g);if(x instanceof Me&&_ instanceof Me)return new Me(x.data.map((i,g)=>Math.pow(i,_.data[g])),x.typeInfo);const v=x,b=_;return new Be(Math.pow(v.value,b.value),x.typeInfo)}QuantizeToF16(i,g){const x=this.exec.evalExpression(i.args[0],g);return x instanceof Me?new Me(x.data.map(i=>i),x.typeInfo):new Be(x.value,x.typeInfo)}Radians(i,g){const x=this.exec.evalExpression(i.args[0],g);return x instanceof Me?new Me(x.data.map(i=>i*Math.PI/180),x.typeInfo):new Be(x.value*Math.PI/180,this.getTypeInfo("f32"))}Reflect(i,g){let x=this.exec.evalExpression(i.args[0],g),_=this.exec.evalExpression(i.args[1],g);if(x instanceof Me&&_ instanceof Me){const i=this._dot(x.data,_.data);return new Me(x.data.map((g,x)=>g-2*i*_.data[x]),x.typeInfo)}return console.error(`Reflect() expects vector arguments. Line ${i.line}`),null}Refract(i,g){let x=this.exec.evalExpression(i.args[0],g),_=this.exec.evalExpression(i.args[1],g),v=this.exec.evalExpression(i.args[2],g);if(x instanceof Me&&_ instanceof Me&&v instanceof Be){const i=this._dot(_.data,x.data);return new Me(x.data.map((g,x)=>{const b=1-v.value*v.value*(1-i*i);if(b<0)return 0;const y=Math.sqrt(b);return v.value*g-(v.value*i+y)*_.data[x]}),x.typeInfo)}return console.error(`Refract() expects vector arguments and a scalar argument. Line ${i.line}`),null}ReverseBits(i,g){return console.error(`TODO:reverseBits. Line ${i.line}`),null}Round(i,g){const x=this.exec.evalExpression(i.args[0],g);if(x instanceof Me)return new Me(x.data.map(i=>Math.round(i)),x.typeInfo);const _=x;return new Be(Math.round(_.value),x.typeInfo)}Saturate(i,g){const x=this.exec.evalExpression(i.args[0],g);if(x instanceof Me)return new Me(x.data.map(i=>Math.min(Math.max(i,0),1)),x.typeInfo);const _=x;return new Be(Math.min(Math.max(_.value,0),1),x.typeInfo)}Sign(i,g){const x=this.exec.evalExpression(i.args[0],g);if(x instanceof Me)return new Me(x.data.map(i=>Math.sign(i)),x.typeInfo);const _=x;return new Be(Math.sign(_.value),x.typeInfo)}Sin(i,g){const x=this.exec.evalExpression(i.args[0],g);if(x instanceof Me)return new Me(x.data.map(i=>Math.sin(i)),x.typeInfo);const _=x;return new Be(Math.sin(_.value),x.typeInfo)}Sinh(i,g){const x=this.exec.evalExpression(i.args[0],g);if(x instanceof Me)return new Me(x.data.map(i=>Math.sinh(i)),x.typeInfo);const _=x;return new Be(Math.sinh(_.value),x.typeInfo)}_smoothstep(i,g,x){const _=Math.min(Math.max((x-i)/(g-i),0),1);return _*_*(3-2*_)}SmoothStep(i,g){const x=this.exec.evalExpression(i.args[0],g),_=this.exec.evalExpression(i.args[1],g),v=this.exec.evalExpression(i.args[2],g);if(v instanceof Me&&x instanceof Me&&_ instanceof Me)return new Me(v.data.map((i,g)=>this._smoothstep(x.data[g],_.data[g],i)),v.typeInfo);const b=x,y=_,S=v;return new Be(this._smoothstep(b.value,y.value,S.value),v.typeInfo)}Sqrt(i,g){const x=this.exec.evalExpression(i.args[0],g);if(x instanceof Me)return new Me(x.data.map(i=>Math.sqrt(i)),x.typeInfo);const _=x;return new Be(Math.sqrt(_.value),x.typeInfo)}Step(i,g){const x=this.exec.evalExpression(i.args[0],g),_=this.exec.evalExpression(i.args[1],g);if(_ instanceof Me&&x instanceof Me)return new Me(_.data.map((i,g)=>iMath.tan(i)),x.typeInfo);const _=x;return new Be(Math.tan(_.value),x.typeInfo)}Tanh(i,g){const x=this.exec.evalExpression(i.args[0],g);if(x instanceof Me)return new Me(x.data.map(i=>Math.tanh(i)),x.typeInfo);const _=x;return new Be(Math.tanh(_.value),x.typeInfo)}_getTransposeType(i){const g=i.getTypeName();return"mat2x2f"===g||"mat2x2h"===g?i:"mat2x3f"===g?this.getTypeInfo("mat3x2f"):"mat2x3h"===g?this.getTypeInfo("mat3x2h"):"mat2x4f"===g?this.getTypeInfo("mat4x2f"):"mat2x4h"===g?this.getTypeInfo("mat4x2h"):"mat3x2f"===g?this.getTypeInfo("mat2x3f"):"mat3x2h"===g?this.getTypeInfo("mat2x3h"):"mat3x3f"===g||"mat3x3h"===g?i:"mat3x4f"===g?this.getTypeInfo("mat4x3f"):"mat3x4h"===g?this.getTypeInfo("mat4x3h"):"mat4x2f"===g?this.getTypeInfo("mat2x4f"):"mat4x2h"===g?this.getTypeInfo("mat2x4h"):"mat4x3f"===g?this.getTypeInfo("mat3x4f"):"mat4x3h"===g?this.getTypeInfo("mat3x4h"):("mat4x4f"===g||"mat4x4h"===g||console.error(`Invalid matrix type ${g}`),i)}Transpose(i,g){const x=this.exec.evalExpression(i.args[0],g);if(!(x instanceof Ue))return console.error(`Transpose() expects a matrix argument. Line ${i.line}`),null;const _=this._getTransposeType(x.typeInfo);if("mat2x2"===x.typeInfo.name||"mat2x2f"===x.typeInfo.name||"mat2x2h"===x.typeInfo.name){const i=x.data;return new Ue([i[0],i[2],i[1],i[3]],_)}if("mat2x3"===x.typeInfo.name||"mat2x3f"===x.typeInfo.name||"mat2x3h"===x.typeInfo.name){const i=x.data;return new Ue([i[0],i[3],i[6],i[1],i[4],i[7]],_)}if("mat2x4"===x.typeInfo.name||"mat2x4f"===x.typeInfo.name||"mat2x4h"===x.typeInfo.name){const i=x.data;return new Ue([i[0],i[4],i[8],i[12],i[1],i[5],i[9],i[13]],_)}if("mat3x2"===x.typeInfo.name||"mat3x2f"===x.typeInfo.name||"mat3x2h"===x.typeInfo.name){const i=x.data;return new Ue([i[0],i[3],i[1],i[4],i[2],i[5]],_)}if("mat3x3"===x.typeInfo.name||"mat3x3f"===x.typeInfo.name||"mat3x3h"===x.typeInfo.name){const i=x.data;return new Ue([i[0],i[3],i[6],i[1],i[4],i[7],i[2],i[5],i[8]],_)}if("mat3x4"===x.typeInfo.name||"mat3x4f"===x.typeInfo.name||"mat3x4h"===x.typeInfo.name){const i=x.data;return new Ue([i[0],i[4],i[8],i[12],i[1],i[5],i[9],i[13],i[2],i[6],i[10],i[14]],_)}if("mat4x2"===x.typeInfo.name||"mat4x2f"===x.typeInfo.name||"mat4x2h"===x.typeInfo.name){const i=x.data;return new Ue([i[0],i[4],i[1],i[5],i[2],i[6]],_)}if("mat4x3"===x.typeInfo.name||"mat4x3f"===x.typeInfo.name||"mat4x3h"===x.typeInfo.name){const i=x.data;return new Ue([i[0],i[4],i[8],i[1],i[5],i[9],i[2],i[6],i[10]],_)}if("mat4x4"===x.typeInfo.name||"mat4x4f"===x.typeInfo.name||"mat4x4h"===x.typeInfo.name){const i=x.data;return new Ue([i[0],i[4],i[8],i[12],i[1],i[5],i[9],i[13],i[2],i[6],i[10],i[14],i[3],i[7],i[11],i[15]],_)}return console.error(`Invalid matrix type ${x.typeInfo.name}`),null}Trunc(i,g){const x=this.exec.evalExpression(i.args[0],g);if(x instanceof Me)return new Me(x.data.map(i=>Math.trunc(i)),x.typeInfo);const _=x;return new Be(Math.trunc(_.value),x.typeInfo)}Dpdx(i,g){return console.error(`TODO:dpdx. Line ${i.line}`),null}DpdxCoarse(i,g){return console.error(`TODO:dpdxCoarse. Line ${i.line}`),null}DpdxFine(i,g){return console.error("TODO:dpdxFine"),null}Dpdy(i,g){return console.error("TODO:dpdy"),null}DpdyCoarse(i,g){return console.error("TODO:dpdyCoarse"),null}DpdyFine(i,g){return console.error("TODO:dpdyFine"),null}Fwidth(i,g){return console.error("TODO:fwidth"),null}FwidthCoarse(i,g){return console.error("TODO:fwidthCoarse"),null}FwidthFine(i,g){return console.error("TODO:fwidthFine"),null}TextureDimensions(i,g){const x=i.args[0],_=i.args.length>1?this.exec.evalExpression(i.args[1],g).value:0;if(x instanceof ge){const v=x.name,b=g.getVariableValue(v);if(b instanceof We){if(_<0||_>=b.mipLevelCount)return console.error(`Invalid mip level for textureDimensions. Line ${i.line}`),null;const g=b.getMipLevelSize(_),x=b.dimension;return"1d"===x?new Be(g[0],this.getTypeInfo("u32")):"3d"===x?new Me(g,this.getTypeInfo("vec3u")):"2d"===x?new Me(g.slice(0,2),this.getTypeInfo("vec2u")):(console.error(`Invalid texture dimension ${x} not found. Line ${i.line}`),null)}return console.error(`Texture ${v} not found. Line ${i.line}`),null}return console.error(`Invalid texture argument for textureDimensions. Line ${i.line}`),null}TextureGather(i,g){return console.error("TODO:textureGather"),null}TextureGatherCompare(i,g){return console.error("TODO:textureGatherCompare"),null}TextureLoad(i,g){const x=i.args[0],_=this.exec.evalExpression(i.args[1],g),v=i.args.length>2?this.exec.evalExpression(i.args[2],g).value:0;if(!(_ instanceof Me)||2!==_.data.length)return console.error(`Invalid UV argument for textureLoad. Line ${i.line}`),null;if(x instanceof ge){const b=x.name,y=g.getVariableValue(b);if(y instanceof We){const g=Math.floor(_.data[0]),x=Math.floor(_.data[1]);if(g<0||g>=y.width||x<0||x>=y.height)return console.error(`Texture ${b} out of bounds. Line ${i.line}`),null;const S=y.getPixel(g,x,0,v);return null===S?(console.error(`Invalid texture format for textureLoad. Line ${i.line}`),null):new Me(S,this.getTypeInfo("vec4f"))}return console.error(`Texture ${b} not found. Line ${i.line}`),null}return console.error(`Invalid texture argument for textureLoad. Line ${i.line}`),null}TextureNumLayers(i,g){const x=i.args[0];if(x instanceof ge){const _=x.name,v=g.getVariableValue(_);return v instanceof We?new Be(v.depthOrArrayLayers,this.getTypeInfo("u32")):(console.error(`Texture ${_} not found. Line ${i.line}`),null)}return console.error(`Invalid texture argument for textureNumLayers. Line ${i.line}`),null}TextureNumLevels(i,g){const x=i.args[0];if(x instanceof ge){const _=x.name,v=g.getVariableValue(_);return v instanceof We?new Be(v.mipLevelCount,this.getTypeInfo("u32")):(console.error(`Texture ${_} not found. Line ${i.line}`),null)}return console.error(`Invalid texture argument for textureNumLevels. Line ${i.line}`),null}TextureNumSamples(i,g){const x=i.args[0];if(x instanceof ge){const _=x.name,v=g.getVariableValue(_);return v instanceof We?new Be(v.sampleCount,this.getTypeInfo("u32")):(console.error(`Texture ${_} not found. Line ${i.line}`),null)}return console.error(`Invalid texture argument for textureNumSamples. Line ${i.line}`),null}TextureSample(i,g){return console.error("TODO:textureSample"),null}TextureSampleBias(i,g){return console.error("TODO:textureSampleBias"),null}TextureSampleCompare(i,g){return console.error("TODO:textureSampleCompare"),null}TextureSampleCompareLevel(i,g){return console.error("TODO:textureSampleCompareLevel"),null}TextureSampleGrad(i,g){return console.error("TODO:textureSampleGrad"),null}TextureSampleLevel(i,g){return console.error("TODO:textureSampleLevel"),null}TextureSampleBaseClampToEdge(i,g){return console.error("TODO:textureSampleBaseClampToEdge"),null}TextureStore(i,g){const x=i.args[0],_=this.exec.evalExpression(i.args[1],g),v=4===i.args.length?this.exec.evalExpression(i.args[2],g).value:0,b=4===i.args.length?this.exec.evalExpression(i.args[3],g).data:this.exec.evalExpression(i.args[2],g).data;if(4!==b.length)return console.error(`Invalid value argument for textureStore. Line ${i.line}`),null;if(!(_ instanceof Me)||2!==_.data.length)return console.error(`Invalid UV argument for textureStore. Line ${i.line}`),null;if(x instanceof ge){const y=x.name,S=g.getVariableValue(y);if(S instanceof We){const g=S.getMipLevelSize(0),x=Math.floor(_.data[0]),w=Math.floor(_.data[1]);return x<0||x>=g[0]||w<0||w>=g[1]?(console.error(`Texture ${y} out of bounds. Line ${i.line}`),null):(S.setPixel(x,w,0,v,Array.from(b)),null)}return console.error(`Texture ${y} not found. Line ${i.line}`),null}return console.error(`Invalid texture argument for textureStore. Line ${i.line}`),null}AtomicLoad(i,g){let x=i.args[0];x instanceof ke&&(x=x.right);const _=this.exec.getVariableName(x,g);return g.getVariable(_).value.getSubData(this.exec,x.postfix,g)}AtomicStore(i,g){let x=i.args[0];x instanceof ke&&(x=x.right);const _=this.exec.getVariableName(x,g),v=g.getVariable(_);let b=i.args[1];const y=this.exec.evalExpression(b,g),S=v.value.getSubData(this.exec,x.postfix,g);return S instanceof Be&&y instanceof Be&&(S.value=y.value),v.value instanceof Pe&&v.value.setDataValue(this.exec,S,x.postfix,g),null}AtomicAdd(i,g){let x=i.args[0];x instanceof ke&&(x=x.right);const _=this.exec.getVariableName(x,g),v=g.getVariable(_);let b=i.args[1];const y=this.exec.evalExpression(b,g),S=v.value.getSubData(this.exec,x.postfix,g),w=new Be(S.value,S.typeInfo);return S instanceof Be&&y instanceof Be&&(S.value+=y.value),v.value instanceof Pe&&v.value.setDataValue(this.exec,S,x.postfix,g),w}AtomicSub(i,g){let x=i.args[0];x instanceof ke&&(x=x.right);const _=this.exec.getVariableName(x,g),v=g.getVariable(_);let b=i.args[1];const y=this.exec.evalExpression(b,g),S=v.value.getSubData(this.exec,x.postfix,g),w=new Be(S.value,S.typeInfo);return S instanceof Be&&y instanceof Be&&(S.value-=y.value),v.value instanceof Pe&&v.value.setDataValue(this.exec,S,x.postfix,g),w}AtomicMax(i,g){let x=i.args[0];x instanceof ke&&(x=x.right);const _=this.exec.getVariableName(x,g),v=g.getVariable(_);let b=i.args[1];const y=this.exec.evalExpression(b,g),S=v.value.getSubData(this.exec,x.postfix,g),w=new Be(S.value,S.typeInfo);return S instanceof Be&&y instanceof Be&&(S.value=Math.max(S.value,y.value)),v.value instanceof Pe&&v.value.setDataValue(this.exec,S,x.postfix,g),w}AtomicMin(i,g){let x=i.args[0];x instanceof ke&&(x=x.right);const _=this.exec.getVariableName(x,g),v=g.getVariable(_);let b=i.args[1];const y=this.exec.evalExpression(b,g),S=v.value.getSubData(this.exec,x.postfix,g),w=new Be(S.value,S.typeInfo);return S instanceof Be&&y instanceof Be&&(S.value=Math.min(S.value,y.value)),v.value instanceof Pe&&v.value.setDataValue(this.exec,S,x.postfix,g),w}AtomicAnd(i,g){let x=i.args[0];x instanceof ke&&(x=x.right);const _=this.exec.getVariableName(x,g),v=g.getVariable(_);let b=i.args[1];const y=this.exec.evalExpression(b,g),S=v.value.getSubData(this.exec,x.postfix,g),w=new Be(S.value,S.typeInfo);return S instanceof Be&&y instanceof Be&&(S.value=S.value&y.value),v.value instanceof Pe&&v.value.setDataValue(this.exec,S,x.postfix,g),w}AtomicOr(i,g){let x=i.args[0];x instanceof ke&&(x=x.right);const _=this.exec.getVariableName(x,g),v=g.getVariable(_);let b=i.args[1];const y=this.exec.evalExpression(b,g),S=v.value.getSubData(this.exec,x.postfix,g),w=new Be(S.value,S.typeInfo);return S instanceof Be&&y instanceof Be&&(S.value=S.value|y.value),v.value instanceof Pe&&v.value.setDataValue(this.exec,S,x.postfix,g),w}AtomicXor(i,g){let x=i.args[0];x instanceof ke&&(x=x.right);const _=this.exec.getVariableName(x,g),v=g.getVariable(_);let b=i.args[1];const y=this.exec.evalExpression(b,g),S=v.value.getSubData(this.exec,x.postfix,g),w=new Be(S.value,S.typeInfo);return S instanceof Be&&y instanceof Be&&(S.value=S.value^y.value),v.value instanceof Pe&&v.value.setDataValue(this.exec,S,x.postfix,g),w}AtomicExchange(i,g){let x=i.args[0];x instanceof ke&&(x=x.right);const _=this.exec.getVariableName(x,g),v=g.getVariable(_);let b=i.args[1];const y=this.exec.evalExpression(b,g),S=v.value.getSubData(this.exec,x.postfix,g),w=new Be(S.value,S.typeInfo);return S instanceof Be&&y instanceof Be&&(S.value=y.value),v.value instanceof Pe&&v.value.setDataValue(this.exec,S,x.postfix,g),w}AtomicCompareExchangeWeak(i,g){return console.error("TODO:atomicCompareExchangeWeak"),null}Pack4x8snorm(i,g){return console.error("TODO:pack4x8snorm"),null}Pack4x8unorm(i,g){return console.error("TODO:pack4x8unorm"),null}Pack4xI8(i,g){return console.error("TODO:pack4xI8"),null}Pack4xU8(i,g){return console.error("TODO:pack4xU8"),null}Pack4x8Clamp(i,g){return console.error("TODO:pack4x8Clamp"),null}Pack4xU8Clamp(i,g){return console.error("TODO:pack4xU8Clamp"),null}Pack2x16snorm(i,g){return console.error("TODO:pack2x16snorm"),null}Pack2x16unorm(i,g){return console.error("TODO:pack2x16unorm"),null}Pack2x16float(i,g){return console.error("TODO:pack2x16float"),null}Unpack4x8snorm(i,g){return console.error("TODO:unpack4x8snorm"),null}Unpack4x8unorm(i,g){return console.error("TODO:unpack4x8unorm"),null}Unpack4xI8(i,g){return console.error("TODO:unpack4xI8"),null}Unpack4xU8(i,g){return console.error("TODO:unpack4xU8"),null}Unpack2x16snorm(i,g){return console.error("TODO:unpack2x16snorm"),null}Unpack2x16unorm(i,g){return console.error("TODO:unpack2x16unorm"),null}Unpack2x16float(i,g){return console.error("TODO:unpack2x16float"),null}StorageBarrier(i,g){return null}TextureBarrier(i,g){return null}WorkgroupBarrier(i,g){return null}WorkgroupUniformLoad(i,g){return null}SubgroupAdd(i,g){return console.error("TODO:subgroupAdd"),null}SubgroupExclusiveAdd(i,g){return console.error("TODO:subgroupExclusiveAdd"),null}SubgroupInclusiveAdd(i,g){return console.error("TODO:subgroupInclusiveAdd"),null}SubgroupAll(i,g){return console.error("TODO:subgroupAll"),null}SubgroupAnd(i,g){return console.error("TODO:subgroupAnd"),null}SubgroupAny(i,g){return console.error("TODO:subgroupAny"),null}SubgroupBallot(i,g){return console.error("TODO:subgroupBallot"),null}SubgroupBroadcast(i,g){return console.error("TODO:subgroupBroadcast"),null}SubgroupBroadcastFirst(i,g){return console.error("TODO:subgroupBroadcastFirst"),null}SubgroupElect(i,g){return console.error("TODO:subgroupElect"),null}SubgroupMax(i,g){return console.error("TODO:subgroupMax"),null}SubgroupMin(i,g){return console.error("TODO:subgroupMin"),null}SubgroupMul(i,g){return console.error("TODO:subgroupMul"),null}SubgroupExclusiveMul(i,g){return console.error("TODO:subgroupExclusiveMul"),null}SubgroupInclusiveMul(i,g){return console.error("TODO:subgroupInclusiveMul"),null}SubgroupOr(i,g){return console.error("TODO:subgroupOr"),null}SubgroupShuffle(i,g){return console.error("TODO:subgroupShuffle"),null}SubgroupShuffleDown(i,g){return console.error("TODO:subgroupShuffleDown"),null}SubgroupShuffleUp(i,g){return console.error("TODO:subgroupShuffleUp"),null}SubgroupShuffleXor(i,g){return console.error("TODO:subgroupShuffleXor"),null}SubgroupXor(i,g){return console.error("TODO:subgroupXor"),null}QuadBroadcast(i,g){return console.error("TODO:quadBroadcast"),null}QuadSwapDiagonal(i,g){return console.error("TODO:quadSwapDiagonal"),null}QuadSwapX(i,g){return console.error("TODO:quadSwapX"),null}QuadSwapY(i,g){return console.error("TODO:quadSwapY"),null}}const Xn={vec2:2,vec2f:2,vec2i:2,vec2u:2,vec2b:2,vec2h:2,vec3:3,vec3f:3,vec3i:3,vec3u:3,vec3b:3,vec3h:3,vec4:4,vec4f:4,vec4i:4,vec4u:4,vec4b:4,vec4h:4},jn={mat2x2:[2,2,4],mat2x2f:[2,2,4],mat2x2h:[2,2,4],mat2x3:[2,3,6],mat2x3f:[2,3,6],mat2x3h:[2,3,6],mat2x4:[2,4,8],mat2x4f:[2,4,8],mat2x4h:[2,4,8],mat3x2:[3,2,6],mat3x2f:[3,2,6],mat3x2h:[3,2,6],mat3x3:[3,3,9],mat3x3f:[3,3,9],mat3x3h:[3,3,9],mat3x4:[3,4,12],mat3x4f:[3,4,12],mat3x4h:[3,4,12],mat4x2:[4,2,8],mat4x2f:[4,2,8],mat4x2h:[4,2,8],mat4x3:[4,3,12],mat4x3f:[4,3,12],mat4x3h:[4,3,12],mat4x4:[4,4,16],mat4x4f:[4,4,16],mat4x4h:[4,4,16]};class dt extends ut{constructor(i,g){var x;super(),this.ast=null!=i?i:[],this.reflection=new at,this.reflection.updateAST(this.ast),this.context=null!==(x=null==g?void 0:g.clone())&&void 0!==x?x:new lt,this.builtins=new ht(this),this.typeInfo={bool:this.getTypeInfo(ae.bool),i32:this.getTypeInfo(ae.i32),u32:this.getTypeInfo(ae.u32),f32:this.getTypeInfo(ae.f32),f16:this.getTypeInfo(ae.f16),vec2f:this.getTypeInfo(ce.vec2f),vec2u:this.getTypeInfo(ce.vec2u),vec2i:this.getTypeInfo(ce.vec2i),vec2h:this.getTypeInfo(ce.vec2h),vec3f:this.getTypeInfo(ce.vec3f),vec3u:this.getTypeInfo(ce.vec3u),vec3i:this.getTypeInfo(ce.vec3i),vec3h:this.getTypeInfo(ce.vec3h),vec4f:this.getTypeInfo(ce.vec4f),vec4u:this.getTypeInfo(ce.vec4u),vec4i:this.getTypeInfo(ce.vec4i),vec4h:this.getTypeInfo(ce.vec4h),mat2x2f:this.getTypeInfo(ce.mat2x2f),mat2x3f:this.getTypeInfo(ce.mat2x3f),mat2x4f:this.getTypeInfo(ce.mat2x4f),mat3x2f:this.getTypeInfo(ce.mat3x2f),mat3x3f:this.getTypeInfo(ce.mat3x3f),mat3x4f:this.getTypeInfo(ce.mat3x4f),mat4x2f:this.getTypeInfo(ce.mat4x2f),mat4x3f:this.getTypeInfo(ce.mat4x3f),mat4x4f:this.getTypeInfo(ce.mat4x4f)}}getVariableValue(i){var g,x;const _=null!==(x=null===(g=this.context.getVariable(i))||void 0===g?void 0:g.value)&&void 0!==x?x:null;if(null===_)return null;if(_ instanceof Be)return _.value;if(_ instanceof Me)return Array.from(_.data);if(_ instanceof Ue)return Array.from(_.data);if(_ instanceof Pe&&_.typeInfo instanceof s){if("u32"===_.typeInfo.format.name)return Array.from(new Uint32Array(_.buffer,_.offset,_.typeInfo.count));if("i32"===_.typeInfo.format.name)return Array.from(new Int32Array(_.buffer,_.offset,_.typeInfo.count));if("f32"===_.typeInfo.format.name)return Array.from(new Float32Array(_.buffer,_.offset,_.typeInfo.count))}return console.error(`Unsupported return variable type ${_.typeInfo.name}`),null}execute(i){(i=null!=i?i:{}).constants&&this._setOverrides(i.constants,this.context),this._execStatements(this.ast,this.context)}dispatchWorkgroups(i,g,x,_){const v=this.context.clone();(_=null!=_?_:{}).constants&&this._setOverrides(_.constants,v),this._execStatements(this.ast,v);const b=v.getFunction(i);if(!b)return void console.error(`Function ${i} not found`);if("number"==typeof g)g=[g,1,1];else{if(0===g.length)return void console.error("Invalid dispatch count");1===g.length?g=[g[0],1,1]:2===g.length?g=[g[0],g[1],1]:g.length>3&&(g=[g[0],g[1],g[2]])}const y=g[0],S=g[1],w=g[2],L=this.getTypeInfo("vec3u");v.setVariable("@num_workgroups",new Me(g,L));const k=this.reflection.getFunctionInfo(i);null===k&&console.error(`Function ${i} not found in reflection data`);for(const i in x)for(const g in x[i]){const _=x[i][g];v.variables.forEach(x=>{var v;const b=x.node;if(null==b?void 0:b.attributes){let y=null,S=null;for(const i of b.attributes)"binding"===i.name?y=i.value:"group"===i.name&&(S=i.value);if(g==y&&i==S){let y=!1;for(const _ of k.resources)if(_.name===x.name&&_.group===parseInt(i)&&_.binding===parseInt(g)){y=!0;break}if(y)if(void 0!==_.texture&&void 0!==_.descriptor){const i=new We(_.texture,this.getTypeInfo(b.type),_.descriptor,null!==(v=_.texture.view)&&void 0!==v?v:null);x.value=i}else void 0!==_.uniform?x.value=new Pe(_.uniform,this.getTypeInfo(b.type)):x.value=new Pe(_,this.getTypeInfo(b.type))}}})}for(let i=0;i0){const i=x.getVariableValue(g.value[0]);_[0]=i instanceof Be?i.value:parseInt(g.value[0])}if(g.value.length>1){const i=x.getVariableValue(g.value[1]);_[1]=i instanceof Be?i.value:parseInt(g.value[1])}if(g.value.length>2){const i=x.getVariableValue(g.value[2]);_[2]=i instanceof Be?i.value:parseInt(g.value[2])}}const v=this.getTypeInfo("vec3u"),b=this.getTypeInfo("u32");x.setVariable("@workgroup_size",new Me(_,v));const y=_[0],S=_[1],w=_[2];for(let L=0,k=0;L",v=null;if(i.variable instanceof ke){const x=this._getVariableData(i.variable,g),_=this.evalExpression(i.value,g),v=i.operator;if("="===v){if(x instanceof Be||x instanceof Me||x instanceof Ue){if(_ instanceof Be||_ instanceof Me||_ instanceof Ue&&x.data.length===_.data.length)return void x.data.set(_.data);console.error(`Invalid assignment. Line ${i.line}`)}else if(x instanceof Pe&&_ instanceof Pe&&x.buffer.byteLength-x.offset>=_.buffer.byteLength-_.offset)return void(x.buffer.byteLength%4==0?new Uint32Array(x.buffer,x.offset,x.typeInfo.size/4).set(new Uint32Array(_.buffer,_.offset,_.typeInfo.size/4)):new Uint8Array(x.buffer,x.offset,x.typeInfo.size).set(new Uint8Array(_.buffer,_.offset,_.typeInfo.size)));return console.error(`Invalid assignment. Line ${i.line}`),null}if("+="===v)return x instanceof Be||x instanceof Me||x instanceof Ue?_ instanceof Be||_ instanceof Me||_ instanceof Ue?void x.data.set(_.data.map((i,g)=>x.data[g]+i)):void console.error(`Invalid assignment . Line ${i.line}`):void console.error(`Invalid assignment. Line ${i.line}`);if("-="===v)return(x instanceof Be||x instanceof Me||x instanceof Ue)&&(_ instanceof Be||_ instanceof Me||_ instanceof Ue)?void x.data.set(_.data.map((i,g)=>x.data[g]-i)):void console.error(`Invalid assignment. Line ${i.line}`)}if(i.variable instanceof ke){if("*"===i.variable.operator){_=this.getVariableName(i.variable.right,g);const v=g.getVariable(_);if(!(v&&v.value instanceof Oe))return void console.error(`Variable ${_} is not a pointer. Line ${i.line}`);x=v.value.reference;let b=i.variable.postfix;if(!b){let g=i.variable.right;for(;g instanceof ke;){if(g.postfix){b=g.postfix;break}g=g.right}}b&&(x=x.getSubData(this,b,g))}}else{v=i.variable.postfix,_=this.getVariableName(i.variable,g);const b=g.getVariable(_);if(null===b)return void console.error(`Variable ${_} not found. Line ${i.line}`);x=b.value}if(x instanceof Oe&&(x=x.reference),null===x)return void console.error(`Variable ${_} not found. Line ${i.line}`);const b=this.evalExpression(i.value,g),y=i.operator;if("="!==y){const _=x.getSubData(this,v,g);if(_ instanceof Me&&b instanceof Be){const g=_.data,x=b.value;if("+="===y)for(let i=0;i>="===y)for(let i=0;i>=x;else console.error(`Invalid operator ${y}. Line ${i.line}`)}else if(_ instanceof Me&&b instanceof Me){const g=_.data,x=b.data;if(g.length!==x.length)return void console.error(`Vector length mismatch. Line ${i.line}`);if("+="===y)for(let i=0;i>="===y)for(let i=0;i>=x[i];else console.error(`Invalid operator ${y}. Line ${i.line}`)}else{if(!(_ instanceof Be&&b instanceof Be))return void console.error(`Invalid type for ${i.operator} operator. Line ${i.line}`);"+="===y?_.value+=b.value:"-="===y?_.value-=b.value:"*="===y?_.value*=b.value:"/="===y?_.value/=b.value:"%="===y?_.value%=b.value:"&="===y?_.value&=b.value:"|="===y?_.value|=b.value:"^="===y?_.value^=b.value:"<<="===y?_.value<<=b.value:">>="===y?_.value>>=b.value:console.error(`Invalid operator ${y}. Line ${i.line}`)}return void(x instanceof Pe&&x.setDataValue(this,_,v,g))}if(x instanceof Pe)x.setDataValue(this,b,v,g);else if(v){if(!(x instanceof Me||x instanceof Ue))return void console.error(`Variable ${_} is not a vector or matrix. Line ${i.line}`);if(v instanceof ve){const y=this.evalExpression(v.index,g).value;if(x instanceof Me){if(!(b instanceof Be))return void console.error(`Invalid assignment to ${_}. Line ${i.line}`);x.data[y]=b.value}else{if(!(x instanceof Ue))return void console.error(`Invalid assignment to ${_}. Line ${i.line}`);{const y=this.evalExpression(v.index,g).value;if(y<0)return void console.error(`Invalid assignment to ${_}. Line ${i.line}`);if(!(b instanceof Me))return void console.error(`Invalid assignment to ${_}. Line ${i.line}`);{const g=x.typeInfo.getTypeName();if("mat2x2"===g||"mat2x2f"===g||"mat2x2h"===g){if(!(y<2&&2===b.data.length))return void console.error(`Invalid assignment to ${_}. Line ${i.line}`);x.data[2*y]=b.data[0],x.data[2*y+1]=b.data[1]}else if("mat2x3"===g||"mat2x3f"===g||"mat2x3h"===g){if(!(y<2&&3===b.data.length))return void console.error(`Invalid assignment to ${_}. Line ${i.line}`);x.data[3*y]=b.data[0],x.data[3*y+1]=b.data[1],x.data[3*y+2]=b.data[2]}else if("mat2x4"===g||"mat2x4f"===g||"mat2x4h"===g){if(!(y<2&&4===b.data.length))return void console.error(`Invalid assignment to ${_}. Line ${i.line}`);x.data[4*y]=b.data[0],x.data[4*y+1]=b.data[1],x.data[4*y+2]=b.data[2],x.data[4*y+3]=b.data[3]}else if("mat3x2"===g||"mat3x2f"===g||"mat3x2h"===g){if(!(y<3&&2===b.data.length))return void console.error(`Invalid assignment to ${_}. Line ${i.line}`);x.data[2*y]=b.data[0],x.data[2*y+1]=b.data[1]}else if("mat3x3"===g||"mat3x3f"===g||"mat3x3h"===g){if(!(y<3&&3===b.data.length))return void console.error(`Invalid assignment to ${_}. Line ${i.line}`);x.data[3*y]=b.data[0],x.data[3*y+1]=b.data[1],x.data[3*y+2]=b.data[2]}else if("mat3x4"===g||"mat3x4f"===g||"mat3x4h"===g){if(!(y<3&&4===b.data.length))return void console.error(`Invalid assignment to ${_}. Line ${i.line}`);x.data[4*y]=b.data[0],x.data[4*y+1]=b.data[1],x.data[4*y+2]=b.data[2],x.data[4*y+3]=b.data[3]}else if("mat4x2"===g||"mat4x2f"===g||"mat4x2h"===g){if(!(y<4&&2===b.data.length))return void console.error(`Invalid assignment to ${_}. Line ${i.line}`);x.data[2*y]=b.data[0],x.data[2*y+1]=b.data[1]}else if("mat4x3"===g||"mat4x3f"===g||"mat4x3h"===g){if(!(y<4&&3===b.data.length))return void console.error(`Invalid assignment to ${_}. Line ${i.line}`);x.data[3*y]=b.data[0],x.data[3*y+1]=b.data[1],x.data[3*y+2]=b.data[2]}else{if("mat4x4"!==g&&"mat4x4f"!==g&&"mat4x4h"!==g)return void console.error(`Invalid assignment to ${_}. Line ${i.line}`);if(!(y<4&&4===b.data.length))return void console.error(`Invalid assignment to ${_}. Line ${i.line}`);x.data[4*y]=b.data[0],x.data[4*y+1]=b.data[1],x.data[4*y+2]=b.data[2],x.data[4*y+3]=b.data[3]}}}}}else if(v instanceof pe){const g=v.value;if(!(x instanceof Me))return void console.error(`Invalid assignment to ${g}. Variable ${_} is not a vector. Line ${i.line}`);if(b instanceof Be){if(g.length>1)return void console.error(`Invalid assignment to ${g} for variable ${_}. Line ${i.line}`);if("x"===g)x.data[0]=b.value;else if("y"===g){if(x.data.length<2)return void console.error(`Invalid assignment to ${g} for variable ${_}. Line ${i.line}`);x.data[1]=b.value}else if("z"===g){if(x.data.length<3)return void console.error(`Invalid assignment to ${g} for variable ${_}. Line ${i.line}`);x.data[2]=b.value}else if("w"===g){if(x.data.length<4)return void console.error(`Invalid assignment to ${g} for variable ${_}. Line ${i.line}`);x.data[3]=b.value}}else{if(!(b instanceof Me))return void console.error(`Invalid assignment to ${_}. Line ${i.line}`);if(g.length!==b.data.length)return void console.error(`Invalid assignment to ${g} for variable ${_}. Line ${i.line}`);for(let v=0;v+i);return new Me(i,x.typeInfo)}const i=_,g=this._maxFormatTypeInfo([x.typeInfo,x.typeInfo]);return new Be(+i,g)}case"-":{if(Ge(_)){const i=_.map((i,g)=>-i);return new Me(i,x.typeInfo)}const i=_,g=this._maxFormatTypeInfo([x.typeInfo,x.typeInfo]);return new Be(-i,g)}case"!":{if(Ge(_)){const i=_.map((i,g)=>i?0:1);return new Me(i,x.typeInfo)}const i=_,g=this._maxFormatTypeInfo([x.typeInfo,x.typeInfo]);return new Be(i?0:1,g)}case"~":{if(Ge(_)){const i=_.map((i,g)=>~i);return new Me(i,x.typeInfo)}const i=_,g=this._maxFormatTypeInfo([x.typeInfo,x.typeInfo]);return new Be(~i,g)}}return console.error(`Invalid unary operator ${i.operator}. Line ${i.line}`),null}_evalBinaryOp(i,g){const x=this.evalExpression(i.left,g),_=this.evalExpression(i.right,g),v=x instanceof Be?x.value:x instanceof Me||x instanceof Ue?Array.from(x.data):null,b=_ instanceof Be?_.value:_ instanceof Me||_ instanceof Ue?Array.from(_.data):null;switch(i.operator){case"+":{if(Ge(v)&&Ge(b)){const g=v,_=b;if(g.length!==_.length)return console.error(`Vector length mismatch. Line ${i.line}.`),null;const y=g.map((i,g)=>i+_[g]);return new Me(y,x.typeInfo)}if(Ge(v)){const i=b,g=v.map((g,x)=>g+i);return new Me(g,x.typeInfo)}if(Ge(b)){const i=v,g=b.map((g,x)=>i+g);return new Me(g,_.typeInfo)}const g=v,y=b,S=this._maxFormatTypeInfo([x.typeInfo,_.typeInfo]);return new Be(g+y,S)}case"-":{if(Ge(v)&&Ge(b)){const g=v,_=b;if(g.length!==_.length)return console.error(`Vector length mismatch. Line ${i.line}.`),null;const y=g.map((i,g)=>i-_[g]);return new Me(y,x.typeInfo)}if(Ge(v)){const i=b,g=v.map((g,x)=>g-i);return new Me(g,x.typeInfo)}if(Ge(b)){const i=v,g=b.map((g,x)=>i-g);return new Me(g,_.typeInfo)}const g=v,y=b,S=this._maxFormatTypeInfo([x.typeInfo,_.typeInfo]);return new Be(g-y,S)}case"*":{if(Ge(v)&&Ge(b)){const g=v,y=b;if(x instanceof Ue&&_ instanceof Ue){const v=function(i,g,x,_){if(void 0===jn[g.name]||void 0===jn[_.name])return null;const v=jn[g.name][0],b=jn[g.name][1],y=jn[_.name][0];if(v!==jn[_.name][1])return null;const S=new Array(y*b);for(let g=0;gi*y[g]);return new Me(_,x.typeInfo)}}if(Ge(v)){const i=b,g=v.map((g,x)=>g*i);return x instanceof Ue?new Ue(g,x.typeInfo):new Me(g,x.typeInfo)}if(Ge(b)){const i=v,g=b.map((g,x)=>i*g);return _ instanceof Ue?new Ue(g,_.typeInfo):new Me(g,_.typeInfo)}const g=v,y=b,S=this._maxFormatTypeInfo([x.typeInfo,_.typeInfo]);return new Be(g*y,S)}case"%":{if(Ge(v)&&Ge(b)){const g=v,_=b;if(g.length!==_.length)return console.error(`Vector length mismatch. Line ${i.line}.`),null;const y=g.map((i,g)=>i%_[g]);return new Me(y,x.typeInfo)}if(Ge(v)){const i=b,g=v.map((g,x)=>g%i);return new Me(g,x.typeInfo)}if(Ge(b)){const i=v,g=b.map((g,x)=>i%g);return new Me(g,_.typeInfo)}const g=v,y=b,S=this._maxFormatTypeInfo([x.typeInfo,_.typeInfo]);return new Be(g%y,S)}case"/":{if(Ge(v)&&Ge(b)){const g=v,_=b;if(g.length!==_.length)return console.error(`Vector length mismatch. Line ${i.line}.`),null;const y=g.map((i,g)=>i/_[g]);return new Me(y,x.typeInfo)}if(Ge(v)){const i=b,g=v.map((g,x)=>g/i);return new Me(g,x.typeInfo)}if(Ge(b)){const i=v,g=b.map((g,x)=>i/g);return new Me(g,_.typeInfo)}const g=v,y=b,S=this._maxFormatTypeInfo([x.typeInfo,_.typeInfo]);return new Be(g/y,S)}case"&":{if(Ge(v)&&Ge(b)){const g=v,_=b;if(g.length!==_.length)return console.error(`Vector length mismatch. Line ${i.line}.`),null;const y=g.map((i,g)=>i&_[g]);return new Me(y,x.typeInfo)}if(Ge(v)){const i=b,g=v.map((g,x)=>g&i);return new Me(g,x.typeInfo)}if(Ge(b)){const i=v,g=b.map((g,x)=>i&g);return new Me(g,_.typeInfo)}const g=v,y=b,S=this._maxFormatTypeInfo([x.typeInfo,_.typeInfo]);return new Be(g&y,S)}case"|":{if(Ge(v)&&Ge(b)){const g=v,_=b;if(g.length!==_.length)return console.error(`Vector length mismatch. Line ${i.line}.`),null;const y=g.map((i,g)=>i|_[g]);return new Me(y,x.typeInfo)}if(Ge(v)){const i=b,g=v.map((g,x)=>g|i);return new Me(g,x.typeInfo)}if(Ge(b)){const i=v,g=b.map((g,x)=>i|g);return new Me(g,_.typeInfo)}const g=v,y=b,S=this._maxFormatTypeInfo([x.typeInfo,_.typeInfo]);return new Be(g|y,S)}case"^":{if(Ge(v)&&Ge(b)){const g=v,_=b;if(g.length!==_.length)return console.error(`Vector length mismatch. Line ${i.line}.`),null;const y=g.map((i,g)=>i^_[g]);return new Me(y,x.typeInfo)}if(Ge(v)){const i=b,g=v.map((g,x)=>g^i);return new Me(g,x.typeInfo)}if(Ge(b)){const i=v,g=b.map((g,x)=>i^g);return new Me(g,_.typeInfo)}const g=v,y=b,S=this._maxFormatTypeInfo([x.typeInfo,_.typeInfo]);return new Be(g^y,S)}case"<<":{if(Ge(v)&&Ge(b)){const g=v,_=b;if(g.length!==_.length)return console.error(`Vector length mismatch. Line ${i.line}.`),null;const y=g.map((i,g)=>i<<_[g]);return new Me(y,x.typeInfo)}if(Ge(v)){const i=b,g=v.map((g,x)=>g<i<>":{if(Ge(v)&&Ge(b)){const g=v,_=b;if(g.length!==_.length)return console.error(`Vector length mismatch. Line ${i.line}.`),null;const y=g.map((i,g)=>i>>_[g]);return new Me(y,x.typeInfo)}if(Ge(v)){const i=b,g=v.map((g,x)=>g>>i);return new Me(g,x.typeInfo)}if(Ge(b)){const i=v,g=b.map((g,x)=>i>>g);return new Me(g,_.typeInfo)}const g=v,y=b,S=this._maxFormatTypeInfo([x.typeInfo,_.typeInfo]);return new Be(g>>y,S)}case">":if(Ge(v)&&Ge(b)){const g=v,_=b;if(g.length!==_.length)return console.error(`Vector length mismatch. Line ${i.line}.`),null;const y=g.map((i,g)=>i>_[g]?1:0);return new Me(y,x.typeInfo)}if(Ge(v)){const i=b,g=v.map((g,x)=>g>i?1:0);return new Me(g,x.typeInfo)}if(Ge(b)){const i=v,g=b.map((g,x)=>i>g?1:0);return new Me(g,_.typeInfo)}return new Be(v>b?1:0,this.getTypeInfo("bool"));case"<":if(Ge(v)&&Ge(b)){const g=v,_=b;if(g.length!==_.length)return console.error(`Vector length mismatch. Line ${i.line}.`),null;const y=g.map((i,g)=>i<_[g]?1:0);return new Me(y,x.typeInfo)}if(Ge(v)){const i=b,g=v.map((g,x)=>gii===_[g]?1:0);return new Me(y,x.typeInfo)}if(Ge(v)){const i=b,g=v.map((g,x)=>g==i?1:0);return new Me(g,x.typeInfo)}if(Ge(b)){const i=v,g=b.map((g,x)=>i==g?1:0);return new Me(g,_.typeInfo)}return new Be(v===b?1:0,this.getTypeInfo("bool"));case"!=":if(Ge(v)&&Ge(b)){const g=v,_=b;if(g.length!==_.length)return console.error(`Vector length mismatch. Line ${i.line}.`),null;const y=g.map((i,g)=>i!==_[g]?1:0);return new Me(y,x.typeInfo)}if(Ge(v)){const i=b,g=v.map((g,x)=>g!==i?1:0);return new Me(g,x.typeInfo)}if(Ge(b)){const i=v,g=b.map((g,x)=>i!==g?1:0);return new Me(g,_.typeInfo)}return new Be(v!==b?1:0,this.getTypeInfo("bool"));case">=":if(Ge(v)&&Ge(b)){const g=v,_=b;if(g.length!==_.length)return console.error(`Vector length mismatch. Line ${i.line}.`),null;const y=g.map((i,g)=>i>=_[g]?1:0);return new Me(y,x.typeInfo)}if(Ge(v)){const i=b,g=v.map((g,x)=>g>=i?1:0);return new Me(g,x.typeInfo)}if(Ge(b)){const i=v,g=b.map((g,x)=>i>=g?1:0);return new Me(g,_.typeInfo)}return new Be(v>=b?1:0,this.getTypeInfo("bool"));case"<=":if(Ge(v)&&Ge(b)){const g=v,_=b;if(g.length!==_.length)return console.error(`Vector length mismatch. Line ${i.line}.`),null;const y=g.map((i,g)=>i<=_[g]?1:0);return new Me(y,x.typeInfo)}if(Ge(v)){const i=b,g=v.map((g,x)=>g<=i?1:0);return new Me(g,x.typeInfo)}if(Ge(b)){const i=v,g=b.map((g,x)=>i<=g?1:0);return new Me(g,_.typeInfo)}return new Be(v<=b?1:0,this.getTypeInfo("bool"));case"&&":if(Ge(v)&&Ge(b)){const g=v,_=b;if(g.length!==_.length)return console.error(`Vector length mismatch. Line ${i.line}.`),null;const y=g.map((i,g)=>i&&_[g]?1:0);return new Me(y,x.typeInfo)}if(Ge(v)){const i=b,g=v.map((g,x)=>g&&i?1:0);return new Me(g,x.typeInfo)}if(Ge(b)){const i=v,g=b.map((g,x)=>i&&g?1:0);return new Me(g,_.typeInfo)}return new Be(v&&b?1:0,this.getTypeInfo("bool"));case"||":if(Ge(v)&&Ge(b)){const g=v,_=b;if(g.length!==_.length)return console.error(`Vector length mismatch. Line ${i.line}.`),null;const y=g.map((i,g)=>i||_[g]?1:0);return new Me(y,x.typeInfo)}if(Ge(v)){const i=b,g=v.map((g,x)=>g||i?1:0);return new Me(g,x.typeInfo)}if(Ge(b)){const i=v,g=b.map((g,x)=>i||g?1:0);return new Me(g,_.typeInfo)}return new Be(v||b?1:0,this.getTypeInfo("bool"))}return console.error(`Unknown operator ${i.operator}. Line ${i.line}`),null}_evalCall(i,g){if(null!==i.cachedReturnValue)return i.cachedReturnValue;const x=g.clone();x.currentFunctionName=i.name;const _=g.getFunction(i.name);if(!_)return i.isBuiltin?this._callBuiltinFunction(i,x):this.getTypeInfo(i.name)?this._evalCreate(i,g):(console.error(`Unknown function "${i.name}". Line ${i.line}`),null);for(let g=0;g<_.node.args.length;++g){const v=_.node.args[g],b=this.evalExpression(i.args[g],x);x.createVariable(v.name,b,v)}return this._execStatements(_.node.body,x)}_callBuiltinFunction(i,g){switch(i.name){case"all":return this.builtins.All(i,g);case"any":return this.builtins.Any(i,g);case"select":return this.builtins.Select(i,g);case"arrayLength":return this.builtins.ArrayLength(i,g);case"abs":return this.builtins.Abs(i,g);case"acos":return this.builtins.Acos(i,g);case"acosh":return this.builtins.Acosh(i,g);case"asin":return this.builtins.Asin(i,g);case"asinh":return this.builtins.Asinh(i,g);case"atan":return this.builtins.Atan(i,g);case"atanh":return this.builtins.Atanh(i,g);case"atan2":return this.builtins.Atan2(i,g);case"ceil":return this.builtins.Ceil(i,g);case"clamp":return this.builtins.Clamp(i,g);case"cos":return this.builtins.Cos(i,g);case"cosh":return this.builtins.Cosh(i,g);case"countLeadingZeros":return this.builtins.CountLeadingZeros(i,g);case"countOneBits":return this.builtins.CountOneBits(i,g);case"countTrailingZeros":return this.builtins.CountTrailingZeros(i,g);case"cross":return this.builtins.Cross(i,g);case"degrees":return this.builtins.Degrees(i,g);case"determinant":return this.builtins.Determinant(i,g);case"distance":return this.builtins.Distance(i,g);case"dot":return this.builtins.Dot(i,g);case"dot4U8Packed":return this.builtins.Dot4U8Packed(i,g);case"dot4I8Packed":return this.builtins.Dot4I8Packed(i,g);case"exp":return this.builtins.Exp(i,g);case"exp2":return this.builtins.Exp2(i,g);case"extractBits":return this.builtins.ExtractBits(i,g);case"faceForward":return this.builtins.FaceForward(i,g);case"firstLeadingBit":return this.builtins.FirstLeadingBit(i,g);case"firstTrailingBit":return this.builtins.FirstTrailingBit(i,g);case"floor":return this.builtins.Floor(i,g);case"fma":return this.builtins.Fma(i,g);case"fract":return this.builtins.Fract(i,g);case"frexp":return this.builtins.Frexp(i,g);case"insertBits":return this.builtins.InsertBits(i,g);case"inverseSqrt":return this.builtins.InverseSqrt(i,g);case"ldexp":return this.builtins.Ldexp(i,g);case"length":return this.builtins.Length(i,g);case"log":return this.builtins.Log(i,g);case"log2":return this.builtins.Log2(i,g);case"max":return this.builtins.Max(i,g);case"min":return this.builtins.Min(i,g);case"mix":return this.builtins.Mix(i,g);case"modf":return this.builtins.Modf(i,g);case"normalize":return this.builtins.Normalize(i,g);case"pow":return this.builtins.Pow(i,g);case"quantizeToF16":return this.builtins.QuantizeToF16(i,g);case"radians":return this.builtins.Radians(i,g);case"reflect":return this.builtins.Reflect(i,g);case"refract":return this.builtins.Refract(i,g);case"reverseBits":return this.builtins.ReverseBits(i,g);case"round":return this.builtins.Round(i,g);case"saturate":return this.builtins.Saturate(i,g);case"sign":return this.builtins.Sign(i,g);case"sin":return this.builtins.Sin(i,g);case"sinh":return this.builtins.Sinh(i,g);case"smoothstep":return this.builtins.SmoothStep(i,g);case"sqrt":return this.builtins.Sqrt(i,g);case"step":return this.builtins.Step(i,g);case"tan":return this.builtins.Tan(i,g);case"tanh":return this.builtins.Tanh(i,g);case"transpose":return this.builtins.Transpose(i,g);case"trunc":return this.builtins.Trunc(i,g);case"dpdx":return this.builtins.Dpdx(i,g);case"dpdxCoarse":return this.builtins.DpdxCoarse(i,g);case"dpdxFine":return this.builtins.DpdxFine(i,g);case"dpdy":return this.builtins.Dpdy(i,g);case"dpdyCoarse":return this.builtins.DpdyCoarse(i,g);case"dpdyFine":return this.builtins.DpdyFine(i,g);case"fwidth":return this.builtins.Fwidth(i,g);case"fwidthCoarse":return this.builtins.FwidthCoarse(i,g);case"fwidthFine":return this.builtins.FwidthFine(i,g);case"textureDimensions":return this.builtins.TextureDimensions(i,g);case"textureGather":return this.builtins.TextureGather(i,g);case"textureGatherCompare":return this.builtins.TextureGatherCompare(i,g);case"textureLoad":return this.builtins.TextureLoad(i,g);case"textureNumLayers":return this.builtins.TextureNumLayers(i,g);case"textureNumLevels":return this.builtins.TextureNumLevels(i,g);case"textureNumSamples":return this.builtins.TextureNumSamples(i,g);case"textureSample":return this.builtins.TextureSample(i,g);case"textureSampleBias":return this.builtins.TextureSampleBias(i,g);case"textureSampleCompare":return this.builtins.TextureSampleCompare(i,g);case"textureSampleCompareLevel":return this.builtins.TextureSampleCompareLevel(i,g);case"textureSampleGrad":return this.builtins.TextureSampleGrad(i,g);case"textureSampleLevel":return this.builtins.TextureSampleLevel(i,g);case"textureSampleBaseClampToEdge":return this.builtins.TextureSampleBaseClampToEdge(i,g);case"textureStore":return this.builtins.TextureStore(i,g);case"atomicLoad":return this.builtins.AtomicLoad(i,g);case"atomicStore":return this.builtins.AtomicStore(i,g);case"atomicAdd":return this.builtins.AtomicAdd(i,g);case"atomicSub":return this.builtins.AtomicSub(i,g);case"atomicMax":return this.builtins.AtomicMax(i,g);case"atomicMin":return this.builtins.AtomicMin(i,g);case"atomicAnd":return this.builtins.AtomicAnd(i,g);case"atomicOr":return this.builtins.AtomicOr(i,g);case"atomicXor":return this.builtins.AtomicXor(i,g);case"atomicExchange":return this.builtins.AtomicExchange(i,g);case"atomicCompareExchangeWeak":return this.builtins.AtomicCompareExchangeWeak(i,g);case"pack4x8snorm":return this.builtins.Pack4x8snorm(i,g);case"pack4x8unorm":return this.builtins.Pack4x8unorm(i,g);case"pack4xI8":return this.builtins.Pack4xI8(i,g);case"pack4xU8":return this.builtins.Pack4xU8(i,g);case"pack4x8Clamp":return this.builtins.Pack4x8Clamp(i,g);case"pack4xU8Clamp":return this.builtins.Pack4xU8Clamp(i,g);case"pack2x16snorm":return this.builtins.Pack2x16snorm(i,g);case"pack2x16unorm":return this.builtins.Pack2x16unorm(i,g);case"pack2x16float":return this.builtins.Pack2x16float(i,g);case"unpack4x8snorm":return this.builtins.Unpack4x8snorm(i,g);case"unpack4x8unorm":return this.builtins.Unpack4x8unorm(i,g);case"unpack4xI8":return this.builtins.Unpack4xI8(i,g);case"unpack4xU8":return this.builtins.Unpack4xU8(i,g);case"unpack2x16snorm":return this.builtins.Unpack2x16snorm(i,g);case"unpack2x16unorm":return this.builtins.Unpack2x16unorm(i,g);case"unpack2x16float":return this.builtins.Unpack2x16float(i,g);case"storageBarrier":return this.builtins.StorageBarrier(i,g);case"textureBarrier":return this.builtins.TextureBarrier(i,g);case"workgroupBarrier":return this.builtins.WorkgroupBarrier(i,g);case"workgroupUniformLoad":return this.builtins.WorkgroupUniformLoad(i,g);case"subgroupAdd":return this.builtins.SubgroupAdd(i,g);case"subgroupExclusiveAdd":return this.builtins.SubgroupExclusiveAdd(i,g);case"subgroupInclusiveAdd":return this.builtins.SubgroupInclusiveAdd(i,g);case"subgroupAll":return this.builtins.SubgroupAll(i,g);case"subgroupAnd":return this.builtins.SubgroupAnd(i,g);case"subgroupAny":return this.builtins.SubgroupAny(i,g);case"subgroupBallot":return this.builtins.SubgroupBallot(i,g);case"subgroupBroadcast":return this.builtins.SubgroupBroadcast(i,g);case"subgroupBroadcastFirst":return this.builtins.SubgroupBroadcastFirst(i,g);case"subgroupElect":return this.builtins.SubgroupElect(i,g);case"subgroupMax":return this.builtins.SubgroupMax(i,g);case"subgroupMin":return this.builtins.SubgroupMin(i,g);case"subgroupMul":return this.builtins.SubgroupMul(i,g);case"subgroupExclusiveMul":return this.builtins.SubgroupExclusiveMul(i,g);case"subgroupInclusiveMul":return this.builtins.SubgroupInclusiveMul(i,g);case"subgroupOr":return this.builtins.SubgroupOr(i,g);case"subgroupShuffle":return this.builtins.SubgroupShuffle(i,g);case"subgroupShuffleDown":return this.builtins.SubgroupShuffleDown(i,g);case"subgroupShuffleUp":return this.builtins.SubgroupShuffleUp(i,g);case"subgroupShuffleXor":return this.builtins.SubgroupShuffleXor(i,g);case"subgroupXor":return this.builtins.SubgroupXor(i,g);case"quadBroadcast":return this.builtins.QuadBroadcast(i,g);case"quadSwapDiagonal":return this.builtins.QuadSwapDiagonal(i,g);case"quadSwapX":return this.builtins.QuadSwapX(i,g);case"quadSwapY":return this.builtins.QuadSwapY(i,g)}const x=g.getFunction(i.name);if(x){const _=g.clone();for(let g=0;gv?b.slice(0,v):b,x).getSubData(this,i.postfix,g)}_callConstructorMatrix(i,g){const x=this.getTypeInfo(i.type),_=i.type.getTypeName(),v=jn[_];if(void 0===v)return console.error(`Invalid matrix constructor ${_}. Line ${i.line}`),null;const b=[];if(i instanceof xe)if(i.isVector){const g=i.vectorValue;for(const i of g)b.push(i)}else b.push(i.scalarValue);else if(i.args)for(const x of i.args){const i=this.evalExpression(x,g);i instanceof Me?b.push(...i.data):i instanceof Be?b.push(i.value):i instanceof Ue&&b.push(...i.data)}if(x instanceof a&&null===x.format&&(x.format=this.getTypeInfo("f32")),0===b.length){const _=new Array(v[2]).fill(0);return new Ue(_,x).getSubData(this,i.postfix,g)}return b.length!==v[2]?(console.error(`Invalid matrix constructor. Line ${i.line}`),null):new Ue(b,x).getSubData(this,i.postfix,g)}}dt._breakObj=new Ne(new e("BREAK",null),null),dt._continueObj=new Ne(new e("CONTINUE",null),null),dt._priority=new Map([["f32",0],["f16",1],["u32",2],["i32",3],["x32",3]]);class mt{constructor(){this.constants=new Map,this.aliases=new Map,this.structs=new Map}}class gt{constructor(){this._tokens=[],this._current=0,this._currentLine=1,this._deferArrayCountEval=[],this._currentLoop=[],this._context=new mt,this._exec=new dt,this._forwardTypeCount=0}parse(i){this._initialize(i),this._deferArrayCountEval.length=0;const g=[];for(;!this._isAtEnd();){const i=this._global_decl_or_directive();if(!i)break;g.push(i)}if(this._deferArrayCountEval.length>0){for(const g of this._deferArrayCountEval){const x=g.arrayType,_=g.countNode;if(_ instanceof ge){const g=_.name,v=this._context.constants.get(g);if(v)try{const i=v.constEvaluate(this._exec);x.count=i}catch(i){}}}this._deferArrayCountEval.length=0}if(this._forwardTypeCount>0)for(const i of g)i.search(i=>{i instanceof Ce||i instanceof le?i.type=this._forwardType(i.type):i instanceof ue?i.format=this._forwardType(i.format):i instanceof F||i instanceof U||i instanceof P?i.type=this._forwardType(i.type):i instanceof D?i.returnType=this._forwardType(i.returnType):i instanceof $e&&(i.type=this._forwardType(i.type))});return g}_forwardType(i){if(i instanceof ie){const g=this._getType(i.name);if(g)return g}else i instanceof le?i.type=this._forwardType(i.type):i instanceof ue&&(i.format=this._forwardType(i.format));return i}_initialize(i){if(i)if("string"==typeof i){const g=new Re(i);this._tokens=g.scanTokens()}else this._tokens=i;else this._tokens=[];this._current=0}_updateNode(i,g){return i.line=null!=g?g:this._currentLine,i}_error(i,g){return{token:i,message:g,toString:()=>`${g}`}}_isAtEnd(){return this._current>=this._tokens.length||this._peek().type==He.eof}_match(i){if(i instanceof qe)return!!this._check(i)&&(this._advance(),!0);for(let g=0,x=i.length;g0){const i=this._currentLoop[this._currentLoop.length-1];g.loopId=i.id}i=g,this._check(He.keywords.if)&&(this._advance(),g.condition=this._optional_paren_expression())}else if(this._match(He.keywords.continue)){const g=this._updateNode(new re);if(!(this._currentLoop.length>0))throw this._error(this._peek(),`Continue statement must be inside a loop. Line:${g.line}`);{const i=this._currentLoop[this._currentLoop.length-1];g.loopId=i.id}i=g}else i=this._increment_decrement_statement()||this._func_call_statement()||this._assignment_statement();return null!=i&&this._consume(He.tokens.semicolon,"Expected ';' after statement."),i}_static_assert_statement(){if(!this._match(He.keywords.static_assert))return null;const i=this._currentLine,g=this._optional_paren_expression();return this._updateNode(new N(g),i)}_while_statement(){if(!this._match(He.keywords.while))return null;const i=this._updateNode(new V(null,null));return this._currentLoop.push(i),i.condition=this._optional_paren_expression(),this._check(He.tokens.attr)&&this._attribute(),i.body=this._compound_statement(),this._currentLoop.pop(),i}_continuing_statement(){const i=this._currentLoop.length>0?this._currentLoop[this._currentLoop.length-1].id:-1;if(!this._match(He.keywords.continuing))return null;const g=this._currentLine,x=this._compound_statement();return this._updateNode(new O(x,i),g)}_for_statement(){if(!this._match(He.keywords.for))return null;this._consume(He.tokens.paren_left,"Expected '('.");const i=this._updateNode(new B(null,null,null,null));return this._currentLoop.push(i),i.init=this._check(He.tokens.semicolon)?null:this._for_init(),this._consume(He.tokens.semicolon,"Expected ';'."),i.condition=this._check(He.tokens.semicolon)?null:this._short_circuit_or_expression(),this._consume(He.tokens.semicolon,"Expected ';'."),i.increment=this._check(He.tokens.paren_right)?null:this._for_increment(),this._consume(He.tokens.paren_right,"Expected ')'."),this._check(He.tokens.attr)&&this._attribute(),i.body=this._compound_statement(),this._currentLoop.pop(),i}_for_init(){return this._variable_statement()||this._func_call_statement()||this._assignment_statement()}_for_increment(){return this._func_call_statement()||this._increment_decrement_statement()||this._assignment_statement()}_variable_statement(){if(this._check(He.keywords.var)){const i=this._variable_decl();if(null===i)throw this._error(this._peek(),"Variable declaration expected.");let g=null;return this._match(He.tokens.equal)&&(g=this._short_circuit_or_expression()),this._updateNode(new F(i.name,i.type,i.storage,i.access,g),i.line)}if(this._match(He.keywords.let)){const i=this._currentLine,g=this._consume(He.tokens.name,"Expected name for let.").toString();let x=null;if(this._match(He.tokens.colon)){const i=this._attribute();x=this._type_decl(),null!=x&&(x.attributes=i)}this._consume(He.tokens.equal,"Expected '=' for let.");const _=this._short_circuit_or_expression();return this._updateNode(new U(g,x,null,null,_),i)}if(this._match(He.keywords.const)){const i=this._currentLine,g=this._consume(He.tokens.name,"Expected name for const.").toString();let x=null;if(this._match(He.tokens.colon)){const i=this._attribute();x=this._type_decl(),null!=x&&(x.attributes=i)}this._consume(He.tokens.equal,"Expected '=' for const.");const _=this._short_circuit_or_expression();return null===x&&_ instanceof xe&&(x=_.type),this._updateNode(new P(g,x,null,null,_),i)}return null}_increment_decrement_statement(){const i=this._current,g=this._unary_expression();if(null==g)return null;if(!this._check(He.increment_operators))return this._current=i,null;const x=this._consume(He.increment_operators,"Expected increment operator");return this._updateNode(new R(x.type===He.tokens.plus_plus?Dn.increment:Dn.decrement,g))}_assignment_statement(){let i=null;const g=this._currentLine;if(this._check(He.tokens.brace_right))return null;let x=this._match(He.tokens.underscore);if(x||(i=this._unary_expression()),!x&&null==i)return null;const _=this._consume(He.assignment_operators,"Expected assignment operator."),v=this._short_circuit_or_expression();return this._updateNode(new G(Un.parse(_.lexeme),i,v),g)}_func_call_statement(){if(!this._check(He.tokens.ident))return null;const i=this._currentLine,g=this._current,x=this._consume(He.tokens.ident,"Expected function name."),_=this._argument_expression_list();return null===_?(this._current=g,null):this._updateNode(new X(x.lexeme,_),i)}_loop_statement(){if(!this._match(He.keywords.loop))return null;this._check(He.tokens.attr)&&this._attribute(),this._consume(He.tokens.brace_left,"Expected '{' for loop.");const i=this._updateNode(new j([],null));this._currentLoop.push(i);let g=this._statement();for(;null!==g;){if(Array.isArray(g))for(let x of g)i.body.push(x);else i.body.push(g);if(g instanceof O){i.continuing=g;break}g=this._statement()}return this._currentLoop.pop(),this._consume(He.tokens.brace_right,"Expected '}' for loop."),i}_switch_statement(){if(!this._match(He.keywords.switch))return null;const i=this._updateNode(new Z(null,[]));if(this._currentLoop.push(i),i.condition=this._optional_paren_expression(),this._check(He.tokens.attr)&&this._attribute(),this._consume(He.tokens.brace_left,"Expected '{' for switch."),i.cases=this._switch_body(),null==i.cases||0==i.cases.length)throw this._error(this._previous(),"Expected 'case' or 'default'.");return this._consume(He.tokens.brace_right,"Expected '}' for switch."),this._currentLoop.pop(),i}_switch_body(){const i=[];let g=!1;for(;this._check([He.keywords.default,He.keywords.case]);){if(this._match(He.keywords.case)){const x=this._case_selectors();for(const i of x)if(i instanceof Se){if(g)throw this._error(this._previous(),"Multiple default cases in switch statement.");g=!0;break}this._match(He.tokens.colon),this._check(He.tokens.attr)&&this._attribute(),this._consume(He.tokens.brace_left,"Exected '{' for switch case.");const _=this._case_body();this._consume(He.tokens.brace_right,"Exected '}' for switch case."),i.push(this._updateNode(new Ae(x,_)))}if(this._match(He.keywords.default)){if(g)throw this._error(this._previous(),"Multiple default cases in switch statement.");this._match(He.tokens.colon),this._check(He.tokens.attr)&&this._attribute(),this._consume(He.tokens.brace_left,"Exected '{' for switch default.");const x=this._case_body();this._consume(He.tokens.brace_right,"Exected '}' for switch default."),i.push(this._updateNode(new Ee(x)))}}return i}_case_selectors(){const i=[];for(this._match(He.keywords.default)?i.push(this._updateNode(new Se)):i.push(this._shift_expression());this._match(He.tokens.comma);)this._match(He.keywords.default)?i.push(this._updateNode(new Se)):i.push(this._shift_expression());return i}_case_body(){if(this._match(He.keywords.fallthrough))return this._consume(He.tokens.semicolon,"Expected ';'"),[];let i=this._statement();if(null==i)return[];i instanceof Array||(i=[i]);const g=this._case_body();return 0==g.length?i:[...i,g[0]]}_if_statement(){if(!this._match(He.keywords.if))return null;const i=this._currentLine,g=this._optional_paren_expression();this._check(He.tokens.attr)&&this._attribute();const x=this._compound_statement();let _=[];this._match_elseif()&&(this._check(He.tokens.attr)&&this._attribute(),_=this._elseif_statement(_));let v=null;return this._match(He.keywords.else)&&(this._check(He.tokens.attr)&&this._attribute(),v=this._compound_statement()),this._updateNode(new Q(g,x,_,v),i)}_match_elseif(){return this._tokens[this._current].type===He.keywords.else&&this._tokens[this._current+1].type===He.keywords.if&&(this._advance(),this._advance(),!0)}_elseif_statement(i=[]){const g=this._optional_paren_expression(),x=this._compound_statement();return i.push(this._updateNode(new Le(g,x))),this._match_elseif()&&(this._check(He.tokens.attr)&&this._attribute(),this._elseif_statement(i)),i}_return_statement(){if(!this._match(He.keywords.return))return null;const i=this._short_circuit_or_expression();return this._updateNode(new Y(i))}_short_circuit_or_expression(){let i=this._short_circuit_and_expr();for(;this._match(He.tokens.or_or);)i=this._updateNode(new Ie(this._previous().toString(),i,this._short_circuit_and_expr()));return i}_short_circuit_and_expr(){let i=this._inclusive_or_expression();for(;this._match(He.tokens.and_and);)i=this._updateNode(new Ie(this._previous().toString(),i,this._inclusive_or_expression()));return i}_inclusive_or_expression(){let i=this._exclusive_or_expression();for(;this._match(He.tokens.or);)i=this._updateNode(new Ie(this._previous().toString(),i,this._exclusive_or_expression()));return i}_exclusive_or_expression(){let i=this._and_expression();for(;this._match(He.tokens.xor);)i=this._updateNode(new Ie(this._previous().toString(),i,this._and_expression()));return i}_and_expression(){let i=this._equality_expression();for(;this._match(He.tokens.and);)i=this._updateNode(new Ie(this._previous().toString(),i,this._equality_expression()));return i}_equality_expression(){const i=this._relational_expression();return this._match([He.tokens.equal_equal,He.tokens.not_equal])?this._updateNode(new Ie(this._previous().toString(),i,this._relational_expression())):i}_relational_expression(){let i=this._shift_expression();for(;this._match([He.tokens.less_than,He.tokens.greater_than,He.tokens.less_than_equal,He.tokens.greater_than_equal]);)i=this._updateNode(new Ie(this._previous().toString(),i,this._shift_expression()));return i}_shift_expression(){let i=this._additive_expression();for(;this._match([He.tokens.shift_left,He.tokens.shift_right]);)i=this._updateNode(new Ie(this._previous().toString(),i,this._additive_expression()));return i}_additive_expression(){let i=this._multiplicative_expression();for(;this._match([He.tokens.plus,He.tokens.minus]);)i=this._updateNode(new Ie(this._previous().toString(),i,this._multiplicative_expression()));return i}_multiplicative_expression(){let i=this._unary_expression();for(;this._match([He.tokens.star,He.tokens.forward_slash,He.tokens.modulo]);)i=this._updateNode(new Ie(this._previous().toString(),i,this._unary_expression()));return i}_unary_expression(){return this._match([He.tokens.minus,He.tokens.bang,He.tokens.tilde,He.tokens.star,He.tokens.and])?this._updateNode(new ke(this._previous().toString(),this._unary_expression())):this._singular_expression()}_singular_expression(){const i=this._primary_expression(),g=this._postfix_expression();return g&&(i.postfix=g),i}_postfix_expression(){if(this._match(He.tokens.bracket_left)){const i=this._short_circuit_or_expression();this._consume(He.tokens.bracket_right,"Expected ']'.");const g=this._updateNode(new ve(i)),x=this._postfix_expression();return x&&(g.postfix=x),g}if(this._match(He.tokens.period)){const i=this._consume(He.tokens.name,"Expected member name."),g=this._postfix_expression(),x=this._updateNode(new pe(i.lexeme));return g&&(x.postfix=g),x}return null}_getStruct(i){return this._context.aliases.has(i)?this._context.aliases.get(i).type:this._context.structs.has(i)?this._context.structs.get(i):null}_getType(i){const g=this._getStruct(i);if(null!==g)return g;switch(i){case"void":return ae.void;case"bool":return ae.bool;case"i32":return ae.i32;case"u32":return ae.u32;case"f32":return ae.f32;case"f16":return ae.f16;case"vec2f":return ce.vec2f;case"vec3f":return ce.vec3f;case"vec4f":return ce.vec4f;case"vec2i":return ce.vec2i;case"vec3i":return ce.vec3i;case"vec4i":return ce.vec4i;case"vec2u":return ce.vec2u;case"vec3u":return ce.vec3u;case"vec4u":return ce.vec4u;case"vec2h":return ce.vec2h;case"vec3h":return ce.vec3h;case"vec4h":return ce.vec4h;case"mat2x2f":return ce.mat2x2f;case"mat2x3f":return ce.mat2x3f;case"mat2x4f":return ce.mat2x4f;case"mat3x2f":return ce.mat3x2f;case"mat3x3f":return ce.mat3x3f;case"mat3x4f":return ce.mat3x4f;case"mat4x2f":return ce.mat4x2f;case"mat4x3f":return ce.mat4x3f;case"mat4x4f":return ce.mat4x4f;case"mat2x2h":return ce.mat2x2h;case"mat2x3h":return ce.mat2x3h;case"mat2x4h":return ce.mat2x4h;case"mat3x2h":return ce.mat3x2h;case"mat3x3h":return ce.mat3x3h;case"mat3x4h":return ce.mat3x4h;case"mat4x2h":return ce.mat4x2h;case"mat4x3h":return ce.mat4x3h;case"mat4x4h":return ce.mat4x4h;case"mat2x2i":return ce.mat2x2i;case"mat2x3i":return ce.mat2x3i;case"mat2x4i":return ce.mat2x4i;case"mat3x2i":return ce.mat3x2i;case"mat3x3i":return ce.mat3x3i;case"mat3x4i":return ce.mat3x4i;case"mat4x2i":return ce.mat4x2i;case"mat4x3i":return ce.mat4x3i;case"mat4x4i":return ce.mat4x4i;case"mat2x2u":return ce.mat2x2u;case"mat2x3u":return ce.mat2x3u;case"mat2x4u":return ce.mat2x4u;case"mat3x2u":return ce.mat3x2u;case"mat3x3u":return ce.mat3x3u;case"mat3x4u":return ce.mat3x4u;case"mat4x2u":return ce.mat4x2u;case"mat4x3u":return ce.mat4x3u;case"mat4x4u":return ce.mat4x4u}return null}_validateTypeRange(i,g){if("i32"===g.name){if(i<-2147483648||i>2147483647)throw this._error(this._previous(),`Value out of range for i32:${i}. Line:${this._currentLine}.`)}else if("u32"===g.name&&(i<0||i>4294967295))throw this._error(this._previous(),`Value out of range for u32:${i}. Line:${this._currentLine}.`)}_primary_expression(){if(this._match(He.tokens.ident)){const i=this._previous().toString();if(this._check(He.tokens.paren_left)){const g=this._argument_expression_list(),x=this._getType(i);return null!==x?this._updateNode(new de(x,g)):this._updateNode(new me(i,g))}if(this._context.constants.has(i)){const g=this._context.constants.get(i);return this._updateNode(new _e(i,g.value))}return this._updateNode(new ge(i))}if(this._match(He.tokens.int_literal)){const i=this._previous().toString();let g=i.endsWith("i")||i.endsWith("i")?ae.i32:i.endsWith("u")||i.endsWith("U")?ae.u32:ae.x32;const x=parseInt(i);return this._validateTypeRange(x,g),this._updateNode(new xe(new Be(x,this._exec.getTypeInfo(g)),g))}if(this._match(He.tokens.uint_literal)){const i=parseInt(this._previous().toString());return this._validateTypeRange(i,ae.u32),this._updateNode(new xe(new Be(i,this._exec.getTypeInfo(ae.u32)),ae.u32))}if(this._match([He.tokens.decimal_float_literal,He.tokens.hex_float_literal])){let i=this._previous().toString(),g=i.endsWith("h");g&&(i=i.substring(0,i.length-1));const x=parseFloat(i);this._validateTypeRange(x,g?ae.f16:ae.f32);const _=g?ae.f16:ae.f32;return this._updateNode(new xe(new Be(x,this._exec.getTypeInfo(_)),_))}if(this._match([He.keywords.true,He.keywords.false])){let i=this._previous().toString()===He.keywords.true.rule;return this._updateNode(new xe(new Be(i?1:0,this._exec.getTypeInfo(ae.bool)),ae.bool))}if(this._check(He.tokens.paren_left))return this._paren_expression();if(this._match(He.keywords.bitcast)){this._consume(He.tokens.less_than,"Expected '<'.");const i=this._type_decl();this._consume(He.tokens.greater_than,"Expected '>'.");const g=this._paren_expression();return this._updateNode(new ye(i,g))}const i=this._type_decl(),g=this._argument_expression_list();return this._updateNode(new de(i,g))}_argument_expression_list(){if(!this._match(He.tokens.paren_left))return null;const i=[];do{if(this._check(He.tokens.paren_right))break;const g=this._short_circuit_or_expression();i.push(g)}while(this._match(He.tokens.comma));return this._consume(He.tokens.paren_right,"Expected ')' for agument list"),i}_optional_paren_expression(){this._match(He.tokens.paren_left);const i=this._short_circuit_or_expression();return this._match(He.tokens.paren_right),i}_paren_expression(){this._consume(He.tokens.paren_left,"Expected '('.");const i=this._short_circuit_or_expression();return this._consume(He.tokens.paren_right,"Expected ')'."),i}_struct_decl(){if(!this._match(He.keywords.struct))return null;const i=this._currentLine,g=this._consume(He.tokens.ident,"Expected name for struct.").toString();this._consume(He.tokens.brace_left,"Expected '{' for struct body.");const x=[];for(;!this._check(He.tokens.brace_right);){const i=this._attribute(),g=this._consume(He.tokens.name,"Expected variable name.").toString();this._consume(He.tokens.colon,"Expected ':' for struct member type.");const _=this._attribute(),v=this._type_decl();null!=v&&(v.attributes=_),this._check(He.tokens.brace_right)?this._match(He.tokens.comma):this._consume(He.tokens.comma,"Expected ',' for struct member."),x.push(this._updateNode(new Ce(g,v,i)))}this._consume(He.tokens.brace_right,"Expected '}' after struct body.");const _=this._currentLine,v=this._updateNode(new oe(g,x,i,_),i);return this._context.structs.set(g,v),v}_global_variable_decl(){const i=this._variable_decl();if(!i)return null;if(this._match(He.tokens.equal)){const g=this._const_expression();i.value=g}if(null!==i.type&&i.value instanceof xe){if("x32"!==i.value.type.name&&i.type.getTypeName()!==i.value.type.getTypeName())throw this._error(this._peek(),`Invalid cast from ${i.value.type.name} to ${i.type.name}. Line:${this._currentLine}`);i.value.isScalar&&this._validateTypeRange(i.value.scalarValue,i.type),i.value.type=i.type}else null===i.type&&i.value instanceof xe&&(i.type="x32"===i.value.type.name?ae.i32:i.value.type,i.value.isScalar&&this._validateTypeRange(i.value.scalarValue,i.type));return i}_override_variable_decl(){const i=this._override_decl();return i&&this._match(He.tokens.equal)&&(i.value=this._const_expression()),i}_global_const_decl(){var i;if(!this._match(He.keywords.const))return null;const g=this._consume(He.tokens.name,"Expected variable name"),x=this._currentLine;let _=null;if(this._match(He.tokens.colon)){const i=this._attribute();_=this._type_decl(),null!=_&&(_.attributes=i)}let v=null;this._consume(He.tokens.equal,"const declarations require an assignment");const b=this._short_circuit_or_expression();try{let i=[ae.f32],x=b.constEvaluate(this._exec,i);x instanceof Be&&this._validateTypeRange(x.value,i[0]),i[0]instanceof ce&&null===i[0].format&&x.typeInfo instanceof a&&null!==x.typeInfo.format&&("f16"===x.typeInfo.format.name?i[0].format=ae.f16:"f32"===x.typeInfo.format.name?i[0].format=ae.f32:"i32"===x.typeInfo.format.name?i[0].format=ae.i32:"u32"===x.typeInfo.format.name?i[0].format=ae.u32:"bool"===x.typeInfo.format.name?i[0].format=ae.bool:console.error(`TODO:impelement template format type ${x.typeInfo.format.name}`)),v=this._updateNode(new xe(x,i[0])),this._exec.context.setVariable(g.toString(),x)}catch(i){v=b}if(null!==_&&v instanceof xe){if("x32"!==v.type.name&&_.getTypeName()!==v.type.getTypeName())throw this._error(this._peek(),`Invalid cast from ${v.type.name} to ${_.name}. Line:${this._currentLine}`);v.type=_,v.isScalar&&this._validateTypeRange(v.scalarValue,v.type)}else null===_&&v instanceof xe&&(_=null!==(i=null==v?void 0:v.type)&&void 0!==i?i:ae.f32,_===ae.x32&&(_=ae.i32));const y=this._updateNode(new P(g.toString(),_,"","",v),x);return this._context.constants.set(y.name,y),y}_global_let_decl(){if(!this._match(He.keywords.let))return null;const i=this._currentLine,g=this._consume(He.tokens.name,"Expected variable name");let x=null;if(this._match(He.tokens.colon)){const i=this._attribute();x=this._type_decl(),null!=x&&(x.attributes=i)}let _=null;if(this._match(He.tokens.equal)&&(_=this._const_expression()),null!==x&&_ instanceof xe){if("x32"!==_.type.name&&x.getTypeName()!==_.type.getTypeName())throw this._error(this._peek(),`Invalid cast from ${_.type.name} to ${x.name}. Line:${this._currentLine}`);_.type=x}else null===x&&_ instanceof xe&&(x="x32"===_.type.name?ae.i32:_.type);return _ instanceof xe&&_.isScalar&&this._validateTypeRange(_.scalarValue,x),this._updateNode(new U(g.toString(),x,"","",_),i)}_const_expression(){return this._short_circuit_or_expression()}_variable_decl(){if(!this._match(He.keywords.var))return null;const i=this._currentLine;let g="",x="";this._match(He.tokens.less_than)&&(g=this._consume(He.storage_class,"Expected storage_class.").toString(),this._match(He.tokens.comma)&&(x=this._consume(He.access_mode,"Expected access_mode.").toString()),this._consume(He.tokens.greater_than,"Expected '>'."));const _=this._consume(He.tokens.name,"Expected variable name");let v=null;if(this._match(He.tokens.colon)){const i=this._attribute();v=this._type_decl(),null!=v&&(v.attributes=i)}return this._updateNode(new F(_.toString(),v,g,x,null),i)}_override_decl(){if(!this._match(He.keywords.override))return null;const i=this._consume(He.tokens.name,"Expected variable name");let g=null;if(this._match(He.tokens.colon)){const i=this._attribute();g=this._type_decl(),null!=g&&(g.attributes=i)}return this._updateNode(new M(i.toString(),g,null))}_diagnostic(){this._consume(He.tokens.paren_left,"Expected '('");const i=this._consume(He.tokens.ident,"Expected severity control name.");this._consume(He.tokens.comma,"Expected ','");let g=this._consume(He.tokens.ident,"Expected diagnostic rule name.").toString();return this._match(He.tokens.period)&&(g+=`.${this._consume(He.tokens.ident,"Expected diagnostic message.").toString()}`),this._consume(He.tokens.paren_right,"Expected ')'"),this._updateNode(new ee(i.toString(),g))}_enable_directive(){const i=this._consume(He.tokens.ident,"identity expected.");return this._updateNode(new K(i.toString()))}_requires_directive(){const i=[this._consume(He.tokens.ident,"identity expected.").toString()];for(;this._match(He.tokens.comma);){const g=this._consume(He.tokens.ident,"identity expected.");i.push(g.toString())}return this._updateNode(new J(i))}_type_alias(){const i=this._consume(He.tokens.ident,"identity expected.");this._consume(He.tokens.equal,"Expected '=' for type alias.");let g=this._type_decl();if(null===g)throw this._error(this._peek(),"Expected Type for Alias.");this._context.aliases.has(g.name)&&(g=this._context.aliases.get(g.name).type);const x=this._updateNode(new te(i.toString(),g));return this._context.aliases.set(x.name,x),x}_type_decl(){if(this._check([He.tokens.ident,...He.texel_format,He.keywords.bool,He.keywords.f32,He.keywords.i32,He.keywords.u32])){const i=this._advance().toString();if(this._context.structs.has(i))return this._context.structs.get(i);if(this._context.aliases.has(i))return this._context.aliases.get(i).type;if(!this._getType(i)){const g=this._updateNode(new ie(i));return this._forwardTypeCount++,g}return this._updateNode(new ae(i))}let i=this._texture_sampler_types();if(i)return i;if(this._check(He.template_types)){let i=this._advance().toString(),g=null,x=null;return this._match(He.tokens.less_than)&&(g=this._type_decl(),x=null,this._match(He.tokens.comma)&&(x=this._consume(He.access_mode,"Expected access_mode for pointer").toString()),this._consume(He.tokens.greater_than,"Expected '>' for type.")),this._updateNode(new ce(i,g,x))}if(this._match(He.keywords.ptr)){let i=this._previous().toString();this._consume(He.tokens.less_than,"Expected '<' for pointer.");const g=this._consume(He.storage_class,"Expected storage_class for pointer");this._consume(He.tokens.comma,"Expected ',' for pointer.");const x=this._type_decl();let _=null;return this._match(He.tokens.comma)&&(_=this._consume(He.access_mode,"Expected access_mode for pointer").toString()),this._consume(He.tokens.greater_than,"Expected '>' for pointer."),this._updateNode(new le(i,g.toString(),x,_))}const g=this._attribute();if(this._match(He.keywords.array)){let x=null,_=-1;const v=this._previous();let b=null;if(this._match(He.tokens.less_than)){x=this._type_decl(),this._context.aliases.has(x.name)&&(x=this._context.aliases.get(x.name).type);let g="";if(this._match(He.tokens.comma)){b=this._shift_expression();try{g=b.constEvaluate(this._exec).toString(),b=null}catch(i){g="1"}}this._consume(He.tokens.greater_than,"Expected '>' for array."),_=g?parseInt(g):0}const y=this._updateNode(new ue(v.toString(),g,x,_));return b&&this._deferArrayCountEval.push({arrayType:y,countNode:b}),y}return null}_texture_sampler_types(){if(this._match(He.sampler_type))return this._updateNode(new he(this._previous().toString(),null,null));if(this._match(He.depth_texture_type))return this._updateNode(new he(this._previous().toString(),null,null));if(this._match(He.sampled_texture_type)||this._match(He.multisampled_texture_type)){const i=this._previous();this._consume(He.tokens.less_than,"Expected '<' for sampler type.");const g=this._type_decl();return this._consume(He.tokens.greater_than,"Expected '>' for sampler type."),this._updateNode(new he(i.toString(),g,null))}if(this._match(He.storage_texture_type)){const i=this._previous();this._consume(He.tokens.less_than,"Expected '<' for sampler type.");const g=this._consume(He.texel_format,"Invalid texel format.").toString();this._consume(He.tokens.comma,"Expected ',' after texel format.");const x=this._consume(He.access_mode,"Expected access mode for storage texture type.").toString();return this._consume(He.tokens.greater_than,"Expected '>' for sampler type."),this._updateNode(new he(i.toString(),g,x))}return null}_attribute(){let i=[];for(;this._match(He.tokens.attr);){const g=this._consume(He.attribute_name,"Expected attribute name"),x=this._updateNode(new De(g.toString(),null));if(this._match(He.tokens.paren_left)){if(x.value=this._consume(He.literal_or_ident,"Expected attribute value").toString(),this._check(He.tokens.comma)){this._advance();do{const i=this._consume(He.literal_or_ident,"Expected attribute value").toString();x.value instanceof Array||(x.value=[x.value]),x.value.push(i)}while(this._match(He.tokens.comma))}this._consume(He.tokens.paren_right,"Expected ')'")}i.push(x)}return 0==i.length?null:i}}class _t extends at{constructor(i){super(),i&&this.update(i)}update(i){const g=(new gt).parse(i);this.updateAST(g)}}function ensureVertexIndexBuiltin(i){if(/@builtin\s*\(\s*vertex_index\s*\)/.test(i))return i;return i.replace(/(@vertex\s+fn\s+)([a-zA-Z_][a-zA-Z0-9_]*)\s*\(([^)]*)(\))/,(i,g,x,_,v)=>{const b=_.trim(),y="@builtin(vertex_index) redgpu_auto_builtin_vertex_index:u32";return`${g}${x}(${0===b.length?y:`${b},${y}`}${v}`})}class WGSLUniformTypes{static get i32(){return{numElements:1,align:4,size:4,type:"i32",wgslType:"i32",View:Int32Array}}static get u32(){return{numElements:1,align:4,size:4,type:"u32",wgslType:"u32",View:Uint32Array}}static get f32(){return{numElements:1,align:4,size:4,type:"f32",wgslType:"f32",View:Float32Array}}static get f16(){return{numElements:1,align:2,size:2,type:"f16",wgslType:"f16",View:Uint16Array}}static get vec2f32(){return{numElements:2,align:8,size:8,type:"f32",wgslType:"vec2",View:Float32Array}}static get vec2i32(){return{numElements:2,align:8,size:8,type:"i32",wgslType:"vec2",View:Int32Array}}static get vec2u32(){return{numElements:2,align:8,size:8,type:"u32",wgslType:"vec2",View:Uint32Array}}static get vec2u16(){return{numElements:2,align:4,size:4,type:"u16",wgslType:"vec2",View:Uint16Array}}static get vec3i32(){return{numElements:3,align:16,size:12,type:"i32",wgslType:"vec3",View:Int32Array}}static get vec3u32(){return{numElements:3,align:16,size:12,type:"u32",wgslType:"vec3",View:Uint32Array}}static get vec3f32(){return{numElements:3,align:16,size:12,type:"f32",wgslType:"vec3",View:Float32Array}}static get vec3u16(){return{numElements:3,align:8,size:6,type:"u16",wgslType:"vec3",View:Uint16Array}}static get vec4i32(){return{numElements:4,align:16,size:16,type:"i32",wgslType:"vec4",View:Int32Array}}static get vec4u32(){return{numElements:4,align:16,size:16,type:"u32",wgslType:"vec4",View:Uint32Array}}static get vec4f32(){return{numElements:4,align:16,size:16,type:"f32",wgslType:"vec4",View:Float32Array}}static get vec4u16(){return{numElements:4,align:8,size:8,type:"u16",wgslType:"vec4",View:Uint16Array}}static get mat2x2f32(){return{numElements:4,align:8,size:16,type:"f32",wgslType:"mat2x2",View:Float32Array}}static get mat2x2u16(){return{numElements:4,align:4,size:8,type:"u16",wgslType:"mat2x2",View:Uint16Array}}static get mat3x2f32(){return{numElements:6,align:8,size:24,type:"f32",wgslType:"mat3x2",View:Float32Array}}static get mat3x2u16(){return{numElements:6,align:4,size:12,type:"u16",wgslType:"mat3x2",View:Uint16Array}}static get mat3x3f32(){return{numElements:16,align:16,size:64,type:"f32",wgslType:"mat3x3",View:Float32Array}}static get mat4x2f32(){return{numElements:8,align:8,size:32,type:"f32",wgslType:"mat4x2",View:Float32Array}}static get mat4x2u16(){return{numElements:8,align:4,size:16,type:"u16",wgslType:"mat4x2",View:Uint16Array}}static get mat2x3f32(){return{numElements:8,align:16,size:32,type:"f32",wgslType:"mat2x3",View:Float32Array}}static get mat2x3u16(){return{numElements:8,align:8,size:16,type:"u16",wgslType:"mat2x3",View:Uint16Array}}static get mat4x4f32(){return{numElements:16,align:16,size:64,type:"f32",wgslType:"mat4x4",View:Float32Array}}static get mat4x4u16(){return{numElements:16,align:8,size:32,type:"u16",wgslType:"mat4x4",View:Uint16Array}}}Object.freeze(WGSLUniformTypes);const processMembers=(i,g=0,x=0)=>{let _=0,v=x;const b=i?.reduce((i,x,b)=>{const{type:y,offset:S,size:w,stride:L,count:k,isArray:H}=x,{format:z}=y,q="array"===y.name?`${z.name}${z.format?`${z.format.name}`:""}`:`${y.name}${z?`${z.name}`:""}`;if(_=g,v=S+w,i[x.name]=((i,g,x)=>{const _=WGSLUniformTypes[x];return{uniformOffset:i.offset+g,uniformOffsetForData:i.offset,stride:i.stride,isArray:i.isArray,typeInfo:_,View:_?.View}})(x,g,q),H&&z.members){const g=processMembers(z.members).members;i[x.name].memberList=Array.from({length:k},(i,x)=>{const _={};for(const i in g){const v=_[i]={...g[i]};v.uniformOffset=v.uniformOffset+S+L*x}return _})}else y.members&&(i[x.name]=processMembers(y.members,S+g,v));return i},{});return{members:b,startOffset:_,endOffset:v}},Yn=new Map,parseWGSL=i=>{i=ensureVertexIndexBuiltin(i);const{defaultSource:g,shaderSourceVariant:x,conditionalBlocks:_,cacheKey:v}=preprocessWGSL(i),b=Yn.get(v);let y;if(b)y=b;else{const i=new _t(g);y={uniforms:{...(w=i.uniforms,w.reduce((i,g)=>(i[g.name]={name:g.name,...processMembers(g.members),arrayBufferByteLength:g.size,stride:g.stride},g.attributes?.forEach(x=>i[g.name][x.name]=+x.value),i),{}))},storage:{...(S=i.storage,S.reduce((i,g)=>(i[g.name]={name:g.name,...processMembers(g.members),arrayBufferByteLength:g.size,stride:g.stride,acccess:g.access,type:g.type},g.attributes?.forEach(x=>i[g.name][x.name]=+x.value),i),{}))},samplers:i.samplers,textures:i.textures,vertexEntries:i.entry.vertex.map(i=>i.name),fragmentEntries:i.entry.fragment.map(i=>i.name),computeEntries:i.entry.compute.map(i=>i.name)},x.setBaseInfo(y.textures,y.samplers),_.forEach(i=>{const g=x.getVariant(i),_=new _t(g),v=_.textures.filter(i=>!y.textures.find(g=>g.name===i.name)),b=_.samplers.filter(i=>!y.samplers.find(g=>g.name===i.name));x.addConditionalInfo(i,v,b)}),y.textures=x.getUnionTextures(),y.samplers=x.getUnionSamplers(),Yn.set(v,y)}var S,w;return{...y,defaultSource:g,shaderSourceVariant:x,conditionalBlocks:_}};class PassClusterLightBound{#Ft;#Ht;#zt;#$t;#Kt;#l;constructor(i,g){validateRedGPUContext(i),this.#l=i,this.#Ft=g,this.#Xt()}get clusterBoundBuffer(){return this.#Ht}render(){const i=this.#Ft.systemUniform_Vertex_UniformBindGroup;if(i){const{gpuDevice:g}=this.#l,x=g.createCommandEncoder(),_=x.beginComputePass({label:"Bound cluster"}),v=q.getDispatchSize();_.setPipeline(this.#Kt),_.setBindGroup(0,i),_.setBindGroup(1,this.#$t),_.dispatchWorkgroups(v[0],v[1],v[2]),_.end(),g.queue.submit([x.finish()])}}#Xt(){const{gpuDevice:i,resourceManager:g}=this.#l,x=parseWGSL("#redgpu_include SYSTEM_UNIFORM;\n@group(1) @binding(0) var clusterLight_Clusters:ClusterLight_Clusters;\nfn lineIntersectionToZPlane(a:vec3,b:vec3,zDistance:f32) -> vec3 { let normal=vec3(0.0,0.0,0.5); let ab=b - a; let t=(zDistance - dot(normal,a))/dot(normal,ab); return a + t * ab;\n}\nfn clipToView(clip:vec4) -> vec4 { let view=systemUniforms.inverseProjectionMatrix * clip; return view/vec4(view.w,view.w,view.w,view.w);\n}\nfn screen2View(screen:vec4) -> vec4 { let texCoord=screen.xy/systemUniforms.resolution.xy; let clip=vec4(vec2(texCoord.x,1.0 - texCoord.y) * 2.0 - vec2(1.0,1.0),screen.z,screen.w ); return clipToView(clip);\n}\nconst eyePos=vec3(0.0);\n@compute @workgroup_size(REDGPU_DEFINE_WORKGROUP_SIZE_X,REDGPU_DEFINE_WORKGROUP_SIZE_Y,REDGPU_DEFINE_WORKGROUP_SIZE_Z)\nfn main(@builtin(global_invocation_id) global_id:vec3) { let tileIndex=global_id.x + global_id.y * clusterLight_tileCount.x + global_id.z * clusterLight_tileCount.x * clusterLight_tileCount.y; let tileSize=vec2( systemUniforms.resolution.x/f32(clusterLight_tileCount.x), systemUniforms.resolution.y/f32(clusterLight_tileCount.y) ); let global_id_x_pos_one=vec2(f32(global_id.x + 1u),f32(global_id.y + 1u)) * tileSize; let global_id_x_y=vec2(f32(global_id.x),f32(global_id.y)) * tileSize; let maxPoint_sS=vec4(global_id_x_pos_one,0.0,1.0); let minPoint_sS=vec4(global_id_x_y,0.0,1.0); let maxPoint_vS=screen2View(maxPoint_sS).xyz; let minPoint_vS=screen2View(minPoint_sS).xyz; let nearFarX=systemUniforms.camera.nearClipping; let nearFarY=systemUniforms.camera.farClipping; let tileZ=f32(global_id.z)/f32(clusterLight_tileCount.z); let tileZ_plus_one=f32(global_id.z + 1u)/f32(clusterLight_tileCount.z); let tileNear=-nearFarX * pow(nearFarY/nearFarX,tileZ); let tileFar=-nearFarX * pow(nearFarY/nearFarX,tileZ_plus_one); let minPointNear=lineIntersectionToZPlane(eyePos,minPoint_vS,tileNear); let minPointFar=lineIntersectionToZPlane(eyePos,minPoint_vS,tileFar); let maxPointNear=lineIntersectionToZPlane(eyePos,maxPoint_vS,tileNear); let maxPointFar=lineIntersectionToZPlane(eyePos,maxPoint_vS,tileFar); let minAABB=min(min(minPointNear,minPointFar),min(maxPointNear,maxPointFar)); let maxAABB=max(max(minPointNear,minPointFar),max(maxPointNear,maxPointFar)); clusterLight_Clusters.cubeList[tileIndex].minAABB=vec4(minAABB,0.0); clusterLight_Clusters.cubeList[tileIndex].maxAABB=vec4(maxAABB,0.0);\n}\n").defaultSource;this.#Ht=g.createGPUBuffer("PASS_CLUSTER_BOUND_BUFFER",{size:32*q.getTotalTileSize(),usage:GPUBufferUsage.STORAGE|GPUBufferUsage.COPY_DST}),this.#zt=i.createBindGroupLayout({entries:[{binding:0,visibility:GPUShaderStage.COMPUTE,buffer:{type:"storage"}}]}),this.#$t=i.createBindGroup({label:"CLUSTER_BOUND_BIND_GROUP",layout:this.#zt,entries:[{binding:0,resource:{buffer:this.#Ht}}]}),this.#Kt=i.createComputePipeline({label:"CLUSTER_BOUND_PIPELINE",layout:i.createPipelineLayout({bindGroupLayouts:[g.getGPUBindGroupLayout(ResourceManager.PRESET_GPUBindGroupLayout_System),this.#zt]}),compute:{module:g.createGPUShaderModule("CLUSTER_BOUND_SHADER",{code:x}),entryPoint:"main"}})}}const qn=new Uint32Array([0,0,0,0]);class PassClustersLight{#Ft;#jt;#Yt;#qt;#l;constructor(i,g){validateRedGPUContext(i),this.#l=i,this.#Ft=g,this.#Xt()}get clusterLightsBuffer(){return this.#qt}render(){const{gpuDevice:i}=this.#l,g=this.#Ft.systemUniform_Vertex_UniformBindGroup;if(g){const x=i.createCommandEncoder(),_=x.beginComputePass({label:"ClusterLight cluster"}),v=q.getDispatchSize();this.#l.gpuDevice.queue.writeBuffer(this.clusterLightsBuffer,0,qn),_.setPipeline(this.#Yt),_.setBindGroup(0,g),_.setBindGroup(1,this.#jt),_.dispatchWorkgroups(v[0],v[1],v[2]),_.end(),i.queue.submit([x.finish()])}}#Xt(){const{gpuDevice:i,resourceManager:g}=this.#l,x=parseWGSL("#redgpu_include SYSTEM_UNIFORM;\n@group(1) @binding(0) var clusterLight_Clusters:ClusterLight_Clusters;\nfn pointLight_testSphereAABB(light:u32,tile:u32) -> bool { let targetLight=clusterLightList.lights[light]; let targetTile=clusterLight_Clusters.cubeList[tile]; let radius:f32=targetLight.radius; let position:vec3=targetLight.position; let center:vec3=(systemUniforms.camera.cameraMatrix * vec4(position,1.0)).xyz; let squaredDistance:f32=pointLight_sqDistPointAABB(center,tile,targetTile.minAABB.xyz,targetTile.maxAABB.xyz); return squaredDistance <=(radius * radius);\n}\nfn pointLight_sqDistPointAABB(targetPoint:vec3,tile:u32,minAABB:vec3,maxAABB:vec3) -> f32 { var sqDist=0.0; for(var i=0u;i < 3u;i=i + 1u) { let v=targetPoint[i]; let _minAABB=minAABB[i]; let _maxAABB=maxAABB[i]; if(v < _minAABB){ sqDist +=(_minAABB - v) * (_minAABB - v); } if(v > _maxAABB){ sqDist +=(v - _maxAABB) * (v - _maxAABB); } } return sqDist;\n}\nfn spotLight_testSphereAABB(light:u32,tile:u32) -> bool { let targetLight=clusterLightList.lights[light]; let targetTile=clusterLight_Clusters.cubeList[tile]; let radius:f32=targetLight.radius; let position:vec3=targetLight.position; let center:vec3=(systemUniforms.camera.cameraMatrix * vec4(position,1.0)).xyz; let squaredDistance:f32=pointLight_sqDistPointAABB(center,tile,targetTile.minAABB.xyz,targetTile.maxAABB.xyz); return squaredDistance <=(radius * radius);\n}\n@compute @workgroup_size(REDGPU_DEFINE_WORKGROUP_SIZE_X,REDGPU_DEFINE_WORKGROUP_SIZE_Y,REDGPU_DEFINE_WORKGROUP_SIZE_Z)\nfn main(@builtin(global_invocation_id) global_id:vec3) { let tileIndex=global_id.x + global_id.y * clusterLight_tileCount.x + global_id.z * clusterLight_tileCount.x * clusterLight_tileCount.y; var clusterLightCount=0u; var clusterLightIndices:array; for (var i=0u;i < u32(clusterLightList.count[0]);i=i + 1u) { let lightInCluster=pointLight_testSphereAABB(i,tileIndex); if (lightInCluster) { clusterLightIndices[clusterLightCount]=i; clusterLightCount=clusterLightCount + 1u; } if (clusterLightCount==REDGPU_DEFINE_MAX_LIGHTS_PER_CLUSTERu) { break; } } let spotLightStartIndex=u32(clusterLightList.count[0]); for (var i=0u;i < u32(clusterLightList.count[1]);i=i + 1u) { let actualLightIndex=spotLightStartIndex + i; let sphereTest=spotLight_testSphereAABB(actualLightIndex,tileIndex); if (sphereTest) { clusterLightIndices[clusterLightCount]=actualLightIndex; clusterLightCount=clusterLightCount + 1u; } if (clusterLightCount==REDGPU_DEFINE_MAX_LIGHTS_PER_CLUSTERu) { break; } } var offset=atomicAdd(&clusterLightGroup.offset,clusterLightCount); for(var i=0u;i < clusterLightCount;i=i + 1u) { clusterLightGroup.indices[offset + i]=clusterLightIndices[i]; } clusterLightGroup.lights[tileIndex].offset=offset; clusterLightGroup.lights[tileIndex].count=clusterLightCount;\n}\n").defaultSource;this.#qt=g.createGPUBuffer("PASS_CLUSTER_LIGHTS_BUFFER",{size:q.getClusterLightsBufferSize(),usage:GPUBufferUsage.STORAGE|GPUBufferUsage.COPY_DST});const _=i.createBindGroupLayout({entries:[{binding:0,visibility:GPUShaderStage.COMPUTE,buffer:{type:"read-only-storage"}}]});this.#jt=i.createBindGroup({label:"CLUSTER_LIGHT_BIND_GROUP",layout:_,entries:[{binding:0,resource:{buffer:this.#Ft.passLightClustersBound.clusterBoundBuffer}}]}),this.#Yt=i.createComputePipeline({label:"CLUSTER_LIGHT_PIPELINE",layout:i.createPipelineLayout({label:"CLUSTER_LIGHT_PIPELINE_LAYOUT",bindGroupLayouts:[g.getGPUBindGroupLayout(ResourceManager.PRESET_GPUBindGroupLayout_System),_]}),compute:{module:g.createGPUShaderModule("CLUSTER_LIGHTS_SHADER",{code:x}),entryPoint:"main"}})}}class ResourceStateUniformBuffer{static dirtyList=[];buffer;uuid;#Wt=0;constructor(i){this.buffer=i,this.uuid=i.uuid}get useNum(){return this.#Wt}set useNum(i){this.#Wt=i,ResourceStateUniformBuffer.dirtyList.push(this)}}const Wn=Symbol("gpuBuffer"),Zn=Symbol("gpuBufferData"),Jn=Symbol("gpuBufferDataViewF32"),Qn=Symbol("gpuBufferDataViewU32"),er=Symbol("gpuBufferCacheKey");class ABaseBuffer extends ManagementResourceBase{[Wn];[er];#Zt;constructor(i,g,x){super(i,g),this.#Zt=x}get cacheKey(){return this[er]||this.uuid}get gpuBuffer(){return this[Wn]}get usage(){return this.#Zt}get size(){return this[Zn]?.byteLength||0}get videoMemorySize(){return this.size}destroy(){const i=this[Wn];i&&(this[Wn]=null,this.__fireListenerList(!0),this.redGPUContext.resourceManager.unregisterManagementResource(this),i&&i.destroy())}}class AUniformBaseBuffer extends ABaseBuffer{[Zn];#Jt;#Qt;constructor(i,g,x,_,v=""){super(i,g,x),this.#Qt=_.byteLength,this.#Jt={size:this.#Qt,usage:this.usage,label:v};try{this[Wn]=i.gpuDevice.createBuffer(this.#Jt)}catch(i){console.error("GPU 버퍼 생성에 실패했습니다:",i)}i.gpuDevice.queue.writeBuffer(this[Wn],0,_),this[Zn]=_,this[Jn]=new Float32Array(_),this[Qn]=new Uint32Array(_)}get data(){return this[Zn]}get dataViewF32(){return this[Jn]}get dataViewU32(){return this[Qn]}get size(){return this.#Qt}get uniformBufferDescriptor(){return this.#Jt}writeOnlyBuffer(i,g){this.redGPUContext.gpuDevice.queue.writeBuffer(this.gpuBuffer,i.uniformOffset,new i.View("number"==typeof g?[g]:g))}}class UniformBuffer extends AUniformBaseBuffer{constructor(i,g,x="",_=""){super(i,"managedUniformBufferState",GPUBufferUsage.UNIFORM|GPUBufferUsage.COPY_DST,g,x);const{table:v}=this.targetResourceManagedState,b=v.get(_);if(b)return b.buffer;_&&(this.name=_,this[er]=_),this.redGPUContext.resourceManager.registerManagementResource(this,new ResourceStateUniformBuffer(this))}}Object.freeze(UniformBuffer);var tr="struct Camera { cameraMatrix:mat4x4, inverseCameraMatrix:mat4x4, cameraPosition:vec3, nearClipping:f32, farClipping:f32, fieldOfView:f32\n};\nstruct SystemUniform { projectionMatrix:mat4x4, inverseProjectionMatrix:mat4x4, projectionCameraMatrix:mat4x4, inverseProjectionCameraMatrix:mat4x4, camera:Camera,\n};\n@group(1) @binding(1) var systemUniforms:SystemUniform;\n";const defineProperty=(i,g,x,_,...v)=>{Object.defineProperty(i.prototype,g,x(g,_,...v))},defineProperties=i=>(g,x)=>{x.forEach(x=>{if(Array.isArray(x)){const[_,v,...b]=x;defineProperty(g,_,i,v,...b)}else defineProperty(g,x,i)})},createDefineByPreset=i=>{const g={};return Object.keys(i).forEach(x=>{const[_,v]=i[x];Object.assign(g,(i=>g=>g.reduce((g,x)=>({...g,[x]:i}),{}))(_)(Object.values(v)))}),{defineByPreset:(i,x)=>((i,g,x)=>{g.forEach(g=>{if(Array.isArray(g)){const[_,v,...b]=g,y=x[_];y||consoleAndThrowError(_,"is a key not defined in Define Preset."),defineProperty(i,_,y,v,...b)}else{const _=x[g];_||consoleAndThrowError(g,"is a key not defined in Define Preset."),defineProperty(i,g,_)}})})(i,x,g)}},nr={enumerable:!0,configurable:!1};function createSetter$5(i,g,x){return function(_){this[g]=_;const{gpuRenderInfo:v}=this;if(x){const{fragmentUniformInfo:g,fragmentUniformBuffer:x}=v;x.writeOnlyBuffer(g.members[i],_?1:0),this.dirtyPipeline=!0}else if(v){const{vertexUniformInfo:g,vertexUniformBuffer:x}=v;g.members[i]&&(x.writeOnlyBuffer(g.members[i],_?1:0),this.dirtyPipeline=!0)}}}function defineBoolean(i,g=!1,x=!0){const _=Symbol(i);return{get:function(){return void 0===this[_]&&(this[_]=g),this[_]},set:createSetter$5(i,_,x),...nr}}function defineColorRGB(i,g="#fff",x=!0){const _=Symbol(i);return{get:function(){if(void 0===this[_]){let v=255,b=255,y=255;if(isHexColor(g)){const i=convertHexToRgb(g);v=i.r,b=i.g,y=i.b}this[_]=new ColorRGB(v,b,y,()=>{const{gpuRenderInfo:g}=this;if(g)if(x){const{fragmentUniformInfo:x,fragmentUniformBuffer:v}=g;v.writeOnlyBuffer(x.members[i],this[_].rgbNormalLinear)}else{const{vertexUniformInfo:x,vertexUniformBuffer:v}=g;v.writeOnlyBuffer(x.members[i],this[_].rgbNormalLinear)}})}return this[_]},...nr}}function defineColorRGBA(i,g="#fff",x=!0){const _=Symbol(i);return{get:function(){if(void 0===this[_]){let v=255,b=255,y=255,S=1;if(isHexColor(g)){const i=convertHexToRgb(g);v=i.r,b=i.g,y=i.b}this[_]=new ColorRGBA(v,b,y,S,()=>{const{gpuRenderInfo:g}=this;if(g)if(x){const{fragmentUniformInfo:x,fragmentUniformBuffer:v}=g;v.writeOnlyBuffer(x.members[i],this[_].rgbaNormalLinear)}else{const{vertexUniformInfo:x,vertexUniformBuffer:v}=g;v.writeOnlyBuffer(x.members[i],this[_].rgbaNormalLinear)}})}return this[_]},...nr}}function createSetter$4(i,g,x){const _=`use${i.charAt(0).toUpperCase()}${i.substring(1)}`;return function(i){const v=this[g];this[g]=i,this.updateTexture(v,i);const{gpuRenderInfo:b}=this;if(x){const{fragmentUniformInfo:g,fragmentUniformBuffer:x}=b;_ in this?this[_]=!!i:g.members[_]&&x.writeOnlyBuffer(g.members[_],i?1:0)}else if(b){const{vertexUniformInfo:g,vertexUniformBuffer:x}=b;g.members[_]&&x.writeOnlyBuffer(x.members[_],i?1:0)}}}function defineCubeTexture(i,g=!0){const x=Symbol(i);return{get:function(){return this[x]},set:createSetter$4(i,x,g),...nr}}function createSetter$3(i,g,x,_=0,v){return function(b){void 0!==_&&b<_&&(console.warn(`Value for ${i} is below the minimum (${_}). Received:${b}. Adjusted to ${_}.`),b=_),void 0!==v&&b>v&&(console.warn(`Value for ${i} exceeds the maximum (${v}). Received:${b}. Adjusted to ${v}.`),b=v),validatePositiveNumberRange(b),this[g]=b;const{gpuRenderInfo:y}=this;if(x){const{fragmentUniformInfo:x,fragmentUniformBuffer:_}=y;_.writeOnlyBuffer(x.members[i],this[g])}else if(y){const{vertexUniformInfo:x,vertexUniformBuffer:_}=y;_.writeOnlyBuffer(x.members[i],this[g])}}}function definePositiveNumberRange(i,g=1,x=!0,_=0,v){const b=Symbol(i);return{get:function(){return void 0===this[b]&&(this[b]=g),this[b]},set:createSetter$3(i,b,x,_,v),...nr}}function defineSampler(i){const g=Symbol(i);return{get:function(){return this[g]},set:function(i){const x=this[g];this[g]=i,this.updateSampler(x,i)},...nr}}function createSetter$2(i,g,x){const _=`use${i.charAt(0).toUpperCase()}${i.substring(1)}`;return function(i){const v=this[g];this[g]=i,this.updateTexture(v,i);const{gpuRenderInfo:b}=this;if(x){const{fragmentUniformInfo:g,fragmentUniformBuffer:x}=b;_ in this?this[_]=!!i:g.members[_]&&x.writeOnlyBuffer(g.members[_],i?1:0)}else if(b){const{vertexUniformInfo:g,vertexUniformBuffer:x}=b;g.members[_]&&x.writeOnlyBuffer(x.members[_],i?1:0)}}}function defineTexture$1(i,g=!0){const x=Symbol(i);return{get:function(){return this[x]},set:createSetter$2(i,x,g),...nr}}function createSetter$1(i,g,x,_=0,v){return function(b){validateUintRange(b),void 0!==_&&b<_&&(console.warn(`Value for ${i} is below the minimum (${_}). Received:${b}. Adjusted to ${_}.`),b=_),void 0!==v&&b>v&&(console.warn(`Value for ${i} exceeds the maximum (${v}). Received:${b}. Adjusted to ${v}.`),b=v),this[g]=b;const{gpuRenderInfo:y}=this;if(x){const{fragmentUniformInfo:x,fragmentUniformBuffer:_}=y;_.writeOnlyBuffer(x.members[i],this[g])}else if(y){const{vertexUniformInfo:x,vertexUniformBuffer:_}=y;_.writeOnlyBuffer(x.members[i],this[g])}}}function defineUintRange(i,g=0,x=!0,_=0,v){const b=Symbol(i);return{get:function(){return void 0===this[b]&&(this[b]=g),this[b]},set:createSetter$1(i,b,x,_,v),...nr}}function createSetter(i,g,x){return function(_){this[g]=_;const{gpuRenderInfo:v}=this;if(x){const{fragmentUniformInfo:g,fragmentUniformBuffer:x}=v;x.writeOnlyBuffer(g.members[i],_)}else if(v){const{vertexUniformInfo:g,vertexUniformBuffer:x}=v;x.writeOnlyBuffer(g.members[i],_)}}}function defineVector(i,g,x=!0){const _=Symbol(i);return{get:function(){return void 0===this[_]&&(this[_]=g),this[_]},set:createSetter(i,_,x),...nr}}function defineProperty_vec4$1(i,g=[0,0,0,0]){return defineVector(i,g)}function defineProperty_vec3$1(i,g=[0,0,0]){return defineVector(i,g)}function defineProperty_vec2$1(i,g=[0,0]){return defineVector(i,g)}function defineProperty_PositiveNumberRange$1(i,g=1,x,_){return definePositiveNumberRange(i,g,!0,x,_)}Object.freeze(nr),Object.freeze(defineBoolean),Object.freeze(defineColorRGB),Object.freeze(defineColorRGBA),Object.freeze(defineCubeTexture),Object.freeze(definePositiveNumberRange),Object.freeze(defineSampler),Object.freeze(defineTexture$1),Object.freeze(defineUintRange),Object.freeze(defineVector);const rr={},ir={AO_STRENGTH:"aoStrength",SPECULAR_STRENGTH:"specularStrength",EMISSIVE_STRENGTH:"emissiveStrength",OPACITY:"opacity",SHININESS:"shininess",NORMAL_SCALE:"normalScale"},ar={},sr={ALPHA_TEXTURE_SAMPLER:"alphaTextureSampler",AO_TEXTURE_SAMPLER:"aoTextureSampler",DIFFUSE_TEXTURE_SAMPLER:"diffuseTextureSampler",EMISSIVE_TEXTURE_SAMPLER:"emissiveTextureSampler",ENVIRONMENT_TEXTURE_SAMPLER:"environmentTextureSampler",NORMAL_TEXTURE_SAMPLER:"normalTextureSampler",SPECULAR_TEXTURE_SAMPLER:"specularTextureSampler"},or={ENVIRONMENT_TEXTURE:"environmentTexture"},ur={},lr={},cr={},hr={ALPHA_TEXTURE:"alphaTexture",AO_TEXTURE:"aoTexture",DIFFUSE_TEXTURE:"diffuseTexture",EMISSIVE_TEXTURE:"emissiveTexture",NORMAL_TEXTURE:"normalTexture",SPECULAR_TEXTURE:"specularTexture"},fr={COLOR:"color",EMISSIVE_COLOR:"emissiveColor",SPECULAR_COLOR:"specularColor"},dr={...createDefineByPreset({defineBoolean:[defineBoolean,rr],definePositiveNumber:[defineProperty_PositiveNumberRange$1,ir],defineUint:[defineUintRange,ar],defineVec2:[defineProperty_vec2$1,ur],defineVec3:[defineProperty_vec3$1,lr],defineVec4:[defineProperty_vec4$1,cr],defineColorRGB:[defineColorRGB,fr],defineSampler:[defineSampler,sr],defineTexture:[defineTexture$1,hr],defineCubeTexture:[defineCubeTexture,or]}),defineBoolean:defineProperties(defineBoolean),definePositiveNumber:defineProperties(defineProperty_PositiveNumberRange$1),defineUint:defineProperties(defineUintRange),defineVec2:defineProperties(defineProperty_vec2$1),defineVec3:defineProperties(defineProperty_vec3$1),defineVec4:defineProperties(defineProperty_vec4$1),defineColorRGB:defineProperties(defineColorRGB),defineColorRGBA:defineProperties(defineColorRGBA),defineSampler:defineProperties(defineSampler),defineTexture:defineProperties(defineTexture$1),defineCubeTexture:defineProperties(defineCubeTexture),PRESET_BOOLEAN:rr,PRESET_POSITIVE_NUMBER:ir,PRESET_UINT:ar,PRESET_SAMPLER:sr,PRESET_TEXTURE:hr,PRESET_CUBE_TEXTURE:or,PRESET_VEC2:ur,PRESET_VEC3:lr,PRESET_VEC4:cr,PRESET_COLOR_RGB:fr};Object.freeze(dr);const mr={ZERO:"zero",ONE:"one",SRC:"src",ONE_MINUS_SRC:"one-minus-src",SRC_ALPHA:"src-alpha",ONE_MINUS_SRC_ALPHA:"one-minus-src-alpha",DST:"dst",ONE_MINUS_DST:"one-minus-dst",DST_ALPHA:"dst-alpha",ONE_MINUS_DST_ALPHA:"one-minus-dst-alpha",SRC_ALPHA_SATURATED:"src-alpha-saturated",CONSTANT:"constant",ONE_MINUS_CONSTANT:"one-minus-constant",SRC1:"src1",ONE_MINUS_SRC1:"one-minus-src1",SRC1_ALPHA:"src1-alpha",ONE_MINUS_SRC1_ALPHA:"one-minus-src1-alpha"};Object.freeze(mr);const pr={ADD:"add",SUBTRACT:"subtract",REVERSE_SUBTRACT:"reverse-subtract",MIN:"min",MAX:"max"};Object.freeze(pr);const gr=Object.values(mr),xr=Object.values(pr);class BlendState{state;#en;#tn;#nn;#rn;constructor(i,g,x,_){this.#rn=i,this.srcFactor=g,this.dstFactor=x,this.operation=_}get operation(){return this.#nn}set operation(i){xr.includes(i)||consoleAndThrowError(`Invalid GPUBlendOperation:${i}. Valid operations are ${xr.join(",")}`),this.#nn=i,this.#in()}get srcFactor(){return this.#en}set srcFactor(i){gr.includes(i)||consoleAndThrowError(`Invalid GPUBlendFactor:${i}. Valid srcFactor factors are ${gr.join(",")}`),this.#en=i,this.#in()}get dstFactor(){return this.#tn}set dstFactor(i){gr.includes(i)||consoleAndThrowError(`Invalid GPUBlendFactor:${i}. Valid dstFactor factors are ${gr.join(",")}`),this.#tn=i,this.#in()}#in(){const i=this.#nn?{operation:this.#nn}:{},g=this.#en?{srcFactor:this.#en}:{},x=this.#tn?{dstFactor:this.#tn}:{};this.state={...i,...g,...x},this.#rn.dirtyPipeline=!0}}const _r=new Map,vr=new WeakMap;let br,yr,Sr;class PackedTexture{#u=createUUID();#l;#ae;#L;#c;#an;#xe=new Map;constructor(i){this.#l=i,this.#c=i.gpuDevice,this.#sn(),this.#ae=this.#on()}get uuid(){return this.#u}get gpuTexture(){return this.#L}static getCacheMap(){return _r}async packing(i,g,x,_,v){const b={r:"r",g:"g",b:"b",a:"a",...v},y=`${i.r?.label||""}_${i.g?.label||""}_${i.b?.label||""}_${i.a?.label||""}`,S=`${JSON.stringify(b)}_${y}`;if(!(i.r||i.g||i.b||i.a))return;this.#un(S);_r.get(S)||await this.#ln(i,g,x,_,b,S)}destroy(){const i=vr.get(this);if(i){const g=_r.get(i);g&&(g.useNum--,0===g.useNum&&(g.gpuTexture?.destroy(),_r.delete(i))),vr.delete(this)}}#sn(){Sr=this.#l.resourceManager.createGPUBuffer("PACK_TEXTURE_MAPPING_BUFFER",{size:16,usage:GPUBufferUsage.UNIFORM|GPUBufferUsage.COPY_DST}),yr||(yr=this.#l.resourceManager.createBindGroupLayout("PACK_TEXTURE_BIND_GROUP_LAYOUT",{entries:[{binding:0,visibility:GPUShaderStage.FRAGMENT,texture:{}},{binding:1,visibility:GPUShaderStage.FRAGMENT,texture:{}},{binding:2,visibility:GPUShaderStage.FRAGMENT,texture:{}},{binding:3,visibility:GPUShaderStage.FRAGMENT,texture:{}},{binding:4,visibility:GPUShaderStage.FRAGMENT,sampler:{}},{binding:5,visibility:GPUShaderStage.FRAGMENT,buffer:{type:"uniform"}}]})),br||(br=this.#cn())}#hn(i){const g=`${i.r?.label||"empty"}_${i.g?.label||"empty"}_${i.b?.label||"empty"}_${i.a?.label||"empty"}`,{resourceManager:x}=this.#l;if(!this.#xe.has(g)){const _=[{binding:0,resource:x.getGPUResourceBitmapTextureView(i.r)},{binding:1,resource:x.getGPUResourceBitmapTextureView(i.g)},{binding:2,resource:x.getGPUResourceBitmapTextureView(i.b)},{binding:3,resource:x.getGPUResourceBitmapTextureView(i.a)},{binding:4,resource:this.#ae},{binding:5,resource:{buffer:Sr}}],v=this.#c.createBindGroup({label:`PACK_TEXTURE_BIND_GROUP_${g}`,layout:yr,entries:_});this.#xe.set(g,v)}this.#an=this.#xe.get(g)}#un(i){const g=vr.get(this);if(g&&g!==i){const i=_r.get(g);i&&(i.useNum--,0===i.useNum&&(i.gpuTexture?.destroy(),_r.delete(g)))}const x=_r.get(i);x&&(this.#L=x.gpuTexture,x.useNum++),vr.set(this,i)}async#ln(i,g,x,_,v,b){const y={size:[g,x,1],format:"rgba8unorm",usage:GPUTextureUsage.RENDER_ATTACHMENT|GPUTextureUsage.TEXTURE_BINDING|GPUTextureUsage.COPY_SRC,label:_||`PACK_TEXTURE_${createUUID()}`,mipLevelCount:getMipLevelCount(g,x)};this.#L&&(this.#L=null);const S=this.#l.resourceManager.createManagedTexture(y),w=new Uint32Array([["r","g","b","a"].indexOf(v.r),["r","g","b","a"].indexOf(v.g),["r","g","b","a"].indexOf(v.b),["r","g","b","a"].indexOf(v.a)]);this.#c.queue.writeBuffer(Sr,0,w),this.#hn(i),this.#fn(S),this.#L=y.mipLevelCount>1?this.#l.resourceManager.mipmapGenerator.generateMipmap(S,y):S,_r.set(b,{gpuTexture:this.#L,useNum:1,mappingKey:b,uuid:this.#u}),this.#an=null}#fn(i){const{resourceManager:g}=this.#l,x=this.#c.createCommandEncoder({label:"PackedTexture_CommandEncoder"}),_=x.beginRenderPass({colorAttachments:[{view:g.getGPUResourceBitmapTextureView(i,{baseMipLevel:0,mipLevelCount:1,dimension:"2d",label:`${i.label}_RENDER_TARGET`}),loadOp:"clear",storeOp:"store",clearValue:[0,0,0,0]}]});_.setPipeline(br),_.setBindGroup(0,this.#an),_.draw(6,1,0,0),_.end(),this.#c.queue.submit([x.finish()])}#cn(){const i="struct VertexOut { @builtin(position) position:vec4, @location(0) uv:vec2,\n};\n@vertex\nfn vertexMain(@builtin(vertex_index) VertexIndex:u32) -> VertexOut { var pos=array,6>( vec2(-1.0,-1.0), vec2( 1.0,-1.0), vec2(-1.0,1.0), vec2(-1.0,1.0), vec2( 1.0,-1.0), vec2( 1.0,1.0) ); var uv=array,6>( vec2(0.0,1.0), vec2(1.0,1.0), vec2(0.0,0.0), vec2(0.0,0.0), vec2(1.0,1.0), vec2(1.0,0.0) ); var output:VertexOut; output.position=vec4(pos[VertexIndex],0.0,1.0); output.uv=uv[VertexIndex]; return output;\n}\nstruct ComponentMapping { r_component:u32, g_component:u32, b_component:u32, a_component:u32,\n};\n@group(0) @binding(0) var textureR:texture_2d;\n@group(0) @binding(1) var textureG:texture_2d;\n@group(0) @binding(2) var textureB:texture_2d;\n@group(0) @binding(3) var textureA:texture_2d;\n@group(0) @binding(4) var sampler0:sampler;\n@group(0) @binding(5) var mapping:ComponentMapping;\nfn getComponent(color:vec4,componentIndex:u32) -> f32 { switch componentIndex { case 0u:{ return color.r;} case 1u:{ return color.g;} case 2u:{ return color.b;} case 3u:{ return color.a;} default:{ return 0.0;} }\n}\n@fragment\nfn fragmentMain(input:VertexOut) -> @location(0) vec4 { let colorR=textureSample(textureR,sampler0,input.uv); let colorG=textureSample(textureG,sampler0,input.uv); let colorB=textureSample(textureB,sampler0,input.uv); let colorA=textureSample(textureA,sampler0,input.uv); let r=getComponent(colorR,mapping.r_component); let g=getComponent(colorG,mapping.g_component); let b=getComponent(colorB,mapping.b_component); let a=getComponent(colorA,mapping.a_component); return vec4(r,g,b,a);\n}\n",{resourceManager:g}=this.#l,x=this.#c.createPipelineLayout({label:"PACK_TEXTURE_PIPELINE_LAYOUT",bindGroupLayouts:[yr]});return this.#c.createRenderPipeline({label:"PACK_TEXTURE_PIPELINE",layout:x,vertex:{module:g.createGPUShaderModule("PACK_TEXTURE_SHADER_MODULE",{code:i}),entryPoint:"vertexMain"},fragment:{module:g.createGPUShaderModule("PACK_TEXTURE_SHADER_MODULE",{code:i}),entryPoint:"fragmentMain",targets:[{format:"rgba8unorm"}]},primitive:{topology:"triangle-list"}})}#on(){return new Sampler(this.#l).gpuSampler}}const Tr={NORMAL:0,MULTIPLY:1,LIGHTEN:2,SCREEN:3,LINEAR_DODGE:4,SUBTRACT:5,DARKEN:6,OVERLAY:7,COLOR_DODGE:8,COLOR_BURN:9,HARD_LIGHT:10,SOFT_LIGHT:11,DIFFERENCE:12,EXCLUSION:13,DIVIDE:14,VIVID_LIGHT:15,LINEAR_BURN:16,PIN_LIGHT:17,SATURATION:18,HUE:19,LUMINOSITY:20,COLOR:21,NEGATION:22};class FragmentGPURenderInfo{fragmentShaderModule;fragmentShaderSourceVariant;fragmentShaderVariantConditionalBlocks;fragmentUniformInfo;fragmentBindGroupLayout;fragmentUniformBuffer;fragmentUniformBindGroup;fragmentState;constructor(i,g,x,_,v,b,y,S){this.fragmentShaderModule=i,this.fragmentShaderSourceVariant=g,this.fragmentShaderVariantConditionalBlocks=x,this.fragmentUniformInfo=_,this.fragmentBindGroupLayout=v,this.fragmentUniformBuffer=b,this.fragmentUniformBindGroup=y,this.fragmentState=S}}Object.freeze(FragmentGPURenderInfo);const getBindGroupLayoutDescriptorFromShaderInfo=(i,g,x,_=!0)=>{const{textures:v,samplers:b,uniforms:y,storage:S}=i,w=[];for(const i in S){const _=S[i],{binding:v,name:b,group:y,type:L}=_;if(_.access){const i={write:"write-only-storage",read:"read-only-storage",read_write:"read-write-storage"}[_.access];g===y&&w.push({binding:v,visibility:x,buffer:{type:i}})}else if(g===y){const{access:i,format:g}=L,_={write:"write-only",read:"read-only",read_write:"read-write"}[i],b=g.name;w.push({binding:v,visibility:x,storageTexture:{access:_,format:b}})}}for(const i in v){const b=v[i],{binding:y,name:S,group:L,type:k}=b,{name:H}=k;g===L&&w.push({binding:y,visibility:x,texture:"texture_depth_2d"===H||"texture_depth_multisampled_2d"===H?{viewDimension:"2d",sampleType:"depth",multisampled:_}:"texture_cube"===H?{viewDimension:"cube"}:"texture_2d_array"===H?{viewDimension:"2d-array",sampleType:"float",multisampled:!1}:{}})}for(const i in b){const _=b[i],{binding:v,name:y,group:S}=_;g===S&&w.push({binding:v,visibility:x,sampler:{type:"filtering"}})}for(const i in y){const _=y[i],{binding:v,name:b,group:S}=_;g===S&&w.push({binding:v,visibility:x,buffer:{type:"uniform"}})}return{entries:w}},getFragmentBindGroupLayoutDescriptorFromShaderInfo=(i,g)=>getBindGroupLayoutDescriptorFromShaderInfo(i,g,GPUShaderStage.FRAGMENT),getVertexBindGroupLayoutDescriptorFromShaderInfo=(i,g)=>getBindGroupLayoutDescriptorFromShaderInfo(i,g,GPUShaderStage.VERTEX),getComputeBindGroupLayoutDescriptorFromShaderInfo=(i,g,x)=>getBindGroupLayoutDescriptorFromShaderInfo(i,g,GPUShaderStage.COMPUTE,x);class ABaseMaterial extends ResourceBase{use2PathRender;gpuRenderInfo;dirtyPipeline=!1;transparent=!1;#dn;#mn;#pn=GPUColorWrite.ALL;#gn;#xn;#_n;#We;#vn;#bn;#yn;#Sn;#Tn;#Mn;#wn;#Cn;#Rn;#Re;#Pn;#Bn=Tr.MULTIPLY;constructor(i,g,x,_){super(i),this.#Rn=g,this.#vn=`FRAGMENT_MODULE_${this.#Rn}`,this.#bn=`FRAGMENT_BIND_GROUP_DESCRIPTOR_${g}`,this.#yn=`FRAGMENT_BIND_GROUP_LAYOUT_${g}`,this.#Sn=x,this.#Tn=x?.storage,this.#Mn=x?.uniforms.uniforms,this.#Pn=_,this.#wn=x.shaderSourceVariant.getUnionTextures(),this.#Cn=x.shaderSourceVariant.getUnionSamplers(),this.#Re=i.resourceManager.getGPUBindGroupLayout(this.#yn)||i.resourceManager.createBindGroupLayout(this.#yn,getFragmentBindGroupLayoutDescriptorFromShaderInfo(x,_)),this.#dn=new BlendState(this,mr.SRC_ALPHA,mr.ONE_MINUS_SRC_ALPHA,pr.ADD),this.#mn=new BlendState(this,mr.SRC_ALPHA,mr.ONE_MINUS_SRC_ALPHA,pr.ADD),this.#gn=i.resourceManager,this.#xn=this.#gn.basicSampler.gpuSampler,this.#_n=this.#gn.emptyBitmapTextureView,this.#We=this.#gn.emptyCubeTextureView}get tintBlendMode(){const i=Object.entries(Tr).find(([,i])=>i===this.#Bn);if(!i)throw new Error(`Invalid tint mode value:${this.#Bn}`);return i[0]}set tintBlendMode(i){const{fragmentUniformInfo:g,fragmentUniformBuffer:x}=this.gpuRenderInfo;let _;if("string"==typeof i){if(!(i in Tr))throw new Error(`Invalid tint mode key:${i}`);_=Tr[i]}else{if("number"!=typeof i||!Object.values(Tr).includes(i))throw new Error(`Invalid tint mode:${i}`);_=i}x.writeOnlyBuffer(g.members.tintBlendMode,_),this.#Bn=_}get MODULE_NAME(){return this.#Rn}get FRAGMENT_SHADER_MODULE_NAME(){return this.#vn}get FRAGMENT_BIND_GROUP_DESCRIPTOR_NAME(){return this.#bn}get STORAGE_STRUCT(){return this.#Tn}get UNIFORM_STRUCT(){return this.#Mn}get blendColorState(){return this.#dn}get blendAlphaState(){return this.#mn}get writeMaskState(){return this.#pn}set writeMaskState(i){this.#pn=i}initGPURenderInfos(){const{redGPUContext:i}=this,{resourceManager:g}=i,x=g.createGPUShaderModule(this.#vn,{code:this.#Sn.defaultSource}),_=new ArrayBuffer(Math.max(this.#Mn.arrayBufferByteLength,16)),v=new UniformBuffer(i,_,`UniformBuffer_${this.#Rn}_${this.uuid}`);this.gpuRenderInfo=new FragmentGPURenderInfo(x,this.#Sn.shaderSourceVariant,this.#Sn.conditionalBlocks,this.#Mn,this.#Re,v,null,null),this._updateBaseProperty(),this._updateFragmentState()}_updateFragmentState(){const{gpuDevice:i,resourceManager:g}=this.redGPUContext;this.#In();const x=[];for(const i in this.#wn){const _=this.#wn[i],{binding:v,name:b,group:y,type:S}=_,{name:w}=S;let L;L="texture_cube"===w?g.getGPUResourceCubeTextureView(this[b]):this[b]instanceof PackedTexture?g.getGPUResourceBitmapTextureView(this[b]):g.getGPUResourceBitmapTextureView(this[b])||this.#_n,2===y&&x.push({binding:v,resource:L})}for(const i in this.#Cn){const g=this.#Cn[i],{binding:_,name:v,group:b}=g;2===b&&x.push({binding:_,resource:this.getGPUResourceSampler(this[v])})}this.#Mn&&x.push({binding:this.#Mn.binding,resource:{buffer:this.gpuRenderInfo.fragmentUniformBuffer.gpuBuffer,offset:0,size:this.gpuRenderInfo.fragmentUniformBuffer.size}});const _={layout:this.gpuRenderInfo.fragmentBindGroupLayout,label:this.#bn,entries:x},v=i.createBindGroup(_);this.gpuRenderInfo.fragmentState=this.getFragmentRenderState(),this.gpuRenderInfo.fragmentUniformBindGroup=v}getFragmentRenderState(i="main"){return{module:this.gpuRenderInfo.fragmentShaderModule,entryPoint:i,targets:[{format:"rgba16float",blend:{color:this.blendColorState.state,alpha:this.blendAlphaState.state},writeMask:this.writeMaskState},{format:navigator.gpu.getPreferredCanvasFormat(),blend:void 0,writeMask:this.writeMaskState},{format:"rgba16float",blend:void 0,writeMask:this.writeMaskState}]}}_updateBaseProperty(){const{fragmentUniformInfo:i,fragmentUniformBuffer:g}=this.gpuRenderInfo,{members:x}=i;for(const _ in x){const x=this[_];x instanceof ColorRGBA?g.writeOnlyBuffer(i.members[_],x.rgbaNormalLinear):x instanceof ColorRGB?g.writeOnlyBuffer(i.members[_],x.rgbNormalLinear):Mr.test(_)||(this[_]=x)}}getGPUResourceSampler(i){return i?.gpuSampler||this.#xn}#In(){const{gpuDevice:i,resourceManager:g}=this.redGPUContext,x=this.#En(),_=`${this.#vn}_${x}`;let v=g.getGPUShaderModule(_);if(!v){const i=this.gpuRenderInfo.fragmentShaderSourceVariant.getVariant(x);v=i?g.createGPUShaderModule(_,{code:i}):this.gpuRenderInfo.fragmentShaderModule}this.gpuRenderInfo.fragmentShaderModule=v,this.#wn=this.gpuRenderInfo.fragmentShaderSourceVariant.getVariantTextures(x),this.#Cn=this.gpuRenderInfo.fragmentShaderSourceVariant.getVariantSamplers(x);const b=`${this.#yn}_${x}`;let y=g.getGPUBindGroupLayout(b);if(!y){const i={...this.#Sn,textures:this.#wn,samplers:this.#Cn};y=g.createBindGroupLayout(b,getFragmentBindGroupLayoutDescriptorFromShaderInfo(i,this.#Pn))}this.gpuRenderInfo.fragmentBindGroupLayout=y}#En(){const{fragmentShaderVariantConditionalBlocks:i}=this.gpuRenderInfo,g=new Set;for(const x of i)this[x]&&g.add(x);const x=g.size>0?Array.from(g).sort().join("+"):"none";return g.size,x}}const Mr=/^use\w+Texture$/;dr.defineByPreset(ABaseMaterial,[dr.PRESET_POSITIVE_NUMBER.OPACITY]),dr.defineBoolean(ABaseMaterial,[["useTint",!1]]),dr.defineColorRGBA(ABaseMaterial,["tint","#ff0000"]),Object.freeze(ABaseMaterial);class ABitmapBaseMaterial extends ABaseMaterial{__packingList;constructor(i,g,x,_){super(i,g,x,_)}updateTexture(i,g){i&&i.__removeDirtyPipelineListener(this.#Dn),g&&g.__addDirtyPipelineListener(this.#Dn),this.#Dn()}updateSampler(i,g){i&&i.__removeDirtyPipelineListener(this.#Dn),g&&g.__addDirtyPipelineListener(this.#Dn),this.#Dn()}#Dn=()=>{this.dirtyPipeline=!0;{let i=(this.__packingList||[]).length;for(;i--;)this.__packingList[i]()}this.gpuRenderInfo?.fragmentShaderModule?this._updateFragmentState():this.initGPURenderInfos()}}Object.freeze(ABitmapBaseMaterial);class AUVTransformBaseMaterial extends ABitmapBaseMaterial{dirtyTextureTransform=!1;#Un=[0,0];#Ln=[1,1];get textureOffset(){return this.#Un}set textureOffset(i){this.dirtyTextureTransform=!0,this.#Un=i}get textureScale(){return this.#Ln}set textureScale(i){this.dirtyTextureTransform=!0,this.#Ln=i}constructor(i,g,x,_){super(i,g,x,_)}}Object.freeze(AUVTransformBaseMaterial);var wr=Object.freeze({__proto__:null,ABaseMaterial:ABaseMaterial,ABitmapBaseMaterial:ABitmapBaseMaterial,AUVTransformBaseMaterial:AUVTransformBaseMaterial,FragmentGPURenderInfo:FragmentGPURenderInfo,getComputeBindGroupLayoutDescriptorFromShaderInfo:getComputeBindGroupLayoutDescriptorFromShaderInfo,getFragmentBindGroupLayoutDescriptorFromShaderInfo:getFragmentBindGroupLayoutDescriptorFromShaderInfo,getVertexBindGroupLayoutDescriptorFromShaderInfo:getVertexBindGroupLayoutDescriptorFromShaderInfo});class ASinglePassPostEffect{#An;#Gn;#kn;#On;#Nn;#Vn;#Fn;#Hn;#zn;#$n;#Kn;#Xn;#jn;#Yn;#qn;#h;#Wn;#Zn;#Jn;#Qn;#er;#tr=16;#nr=16;#rr=1;#ir=!1;#ar=!1;#l;#sr;#or=[];#N=0;#ur;#lr;constructor(i){this.#l=i,this.#sr=i.antialiasingManager}get useGBufferNormalTexture(){return this.#ar}set useGBufferNormalTexture(i){this.#ar=i}get videoMemorySize(){return this.#N}get useDepthTexture(){return this.#ir}set useDepthTexture(i){this.#ir=i}get redGPUContext(){return this.#l}get storageInfo(){return this.#qn}get shaderInfo(){return this.#sr.useMSAA?this.#Wn:this.#Zn}get uniformBuffer(){return this.#Xn}get uniformsInfo(){return this.#jn}get systemUuniformsInfo(){return this.#Yn}get WORK_SIZE_X(){return this.#tr}set WORK_SIZE_X(i){this.#tr=i}get WORK_SIZE_Y(){return this.#nr}set WORK_SIZE_Y(i){this.#nr=i}get WORK_SIZE_Z(){return this.#rr}set WORK_SIZE_Z(i){this.#rr=i}get outputTextureView(){return this.#er}clear(){this.#Qn&&(this.#Qn.destroy(),this.#Qn=null,this.#er=null)}init(i,g,x,_){this.#h=g;const{resourceManager:v}=i;this.#An=v.createGPUShaderModule(`${g}_MSAA`,{code:x.msaa}),this.#Gn=v.createGPUShaderModule(`${g}_NonMSAA`,{code:x.nonMsaa}),this.#Wn=parseWGSL(x.msaa),this.#Zn=parseWGSL(x.nonMsaa);const b=this.#Wn.storage,y=this.#Wn.uniforms;if(this.#qn=b,this.#jn=y.uniforms,this.#Yn=y.systemUniforms,this.#jn){const g=new ArrayBuffer(this.#jn.arrayBufferByteLength);this.#Xn=new UniformBuffer(i,g,`${this.constructor.name}_UniformBuffer`)}}execute(i,g,x,_){const v=g.createCommandEncoder({label:"ASinglePassPostEffect_Execute_CommandEncoder"}),b=v.beginComputePass();b.setPipeline(this.#Kn),b.setBindGroup(0,i.renderViewStateData.swapBufferIndex?this.#Vn:this.#Nn),b.setBindGroup(1,this.#Fn),b.dispatchWorkgroups(Math.ceil(x/this.WORK_SIZE_X),Math.ceil(_/this.WORK_SIZE_Y)),b.end(),g.queue.submit([v.finish()])}render(i,g,x,..._){const{gpuDevice:v,antialiasingManager:b}=this.#l,{useMSAA:y,msaaID:S}=b,w=this.#cr(i),L=this.#ur!==y||this.#lr!==S,k=this.#hr(_),H=this.outputTextureView,{redGPUContext:z}=i;return(w||L||k)&&this.#fr(i,_,H,y,z,v),this.update(performance.now()),this.execute(i,v,g,x),this.#ur=y,this.#lr=S,{texture:this.#Qn,textureView:H}}update(i){}updateUniform(i,g){this.uniformBuffer.writeOnlyBuffer(this.uniformsInfo.members[i],g)}#fr(i,g,x,_,v,b){const y=this.storageInfo,S=this.uniformsInfo,w=this.systemUuniformsInfo;this.#Hn=[],this.#zn=[],this.#$n=[];for(const i in y){const x=y[i],{binding:_,name:v}=x;"outputTexture"!==v&&(this.#Hn.push({binding:_,resource:g[_].textureView}),this.#zn.push({binding:_,resource:g[_].textureView}))}this.#$n.push({binding:0,resource:x}),this.shaderInfo.textures.forEach(g=>{const{name:x,binding:_}=g;"depthTexture"===x&&(this.#Hn.push({binding:_,resource:i.viewRenderTextureManager.depthTextureView}),this.#zn.push({binding:_,resource:i.viewRenderTextureManager.prevDepthTextureView})),"gBufferNormalTexture"===x&&(this.#Hn.push({binding:_,resource:i.redGPUContext.antialiasingManager.useMSAA?i.viewRenderTextureManager.gBufferNormalResolveTextureView:i.viewRenderTextureManager.gBufferNormalTextureView}),this.#zn.push({binding:_,resource:i.redGPUContext.antialiasingManager.useMSAA?i.viewRenderTextureManager.gBufferNormalResolveTextureView:i.viewRenderTextureManager.gBufferNormalTextureView}))}),w&&this.#$n.push({binding:w.binding,resource:{buffer:i.postEffectManager.postEffectSystemUniformBuffer.gpuBuffer,offset:0,size:i.postEffectManager.postEffectSystemUniformBuffer.size}}),this.#Xn&&S&&this.#$n.push({binding:S.binding,resource:{buffer:this.#Xn.gpuBuffer,offset:0,size:this.#Xn.size}});const L=_?this.#Wn:this.#Zn,k=_?this.#An:this.#Gn;this.#kn=v.resourceManager.getGPUBindGroupLayout(`${this.#h}_BIND_GROUP_LAYOUT_0_USE_MSAA_${_}`)||v.resourceManager.createBindGroupLayout(`${this.#h}_BIND_GROUP_LAYOUT_0_USE_MSAA_${_}`,getComputeBindGroupLayoutDescriptorFromShaderInfo(L,0,_)),this.#On=v.resourceManager.getGPUBindGroupLayout(`${this.#h}_BIND_GROUP_LAYOUT_1_USE_MSAA_${_}`)||v.resourceManager.createBindGroupLayout(`${this.#h}_BIND_GROUP_LAYOUT_1_USE_MSAA_${_}`,getComputeBindGroupLayoutDescriptorFromShaderInfo(L,1,_)),this.#Nn=b.createBindGroup({label:`${this.#h}_BIND_GROUP_0_USE_MSAA_${_}_SWAP0`,layout:this.#kn,entries:this.#Hn}),this.#Vn=b.createBindGroup({label:`${this.#h}_BIND_GROUP_0_USE_MSAA_${_}_SWAP0`,layout:this.#kn,entries:this.#zn}),this.#Fn=b.createBindGroup({label:`${this.#h}_BIND_GROUP_1_USE_MSAA_${_}`,layout:this.#On,entries:this.#$n}),this.#Kn=b.createComputePipeline({label:`${this.#h}_COMPUTE_PIPELINE_USE_MSAA_${_}`,layout:b.createPipelineLayout({bindGroupLayouts:[this.#kn,this.#On]}),compute:{module:k,entryPoint:"main"}}),this.#dr(g)}#mr(){this.#N=0,this.#Qn&&(this.#N=calculateTextureByteSize(this.#Qn))}#hr(i){if(!this.#or||this.#or.length!==i.length)return!0;for(let g=0;gi.clear())}render(i,g,x,_){let v;return this.#pr.forEach((b,y)=>{y&&(_=v),v=b.render(i,g,x,_)}),v}#mr(){this.#N=0,this.#pr.forEach(i=>{this.#N+=i.videoMemorySize})}}Object.freeze(AMultiPassPostEffect);const validateNumberRange=(i,g=-Number.MAX_VALUE,x=Number.MAX_VALUE)=>("number"!=typeof i&&consoleAndThrowError("Only numbers allowed."),"number"!=typeof g&&consoleAndThrowError("Only numbers allowed."),"number"!=typeof x&&consoleAndThrowError("Only numbers allowed."),(ix)&&consoleAndThrowError(`Only numbers within the range of [${g},${x}] are allowed. input:${i}`),!0),createCode=(i,g,x="",_=!1)=>{const{WORK_SIZE_X:v,WORK_SIZE_Y:b,WORK_SIZE_Z:y}=i,S=_?"texture_depth_multisampled_2d":"texture_depth_2d";return`\n ${x} @group(0) @binding(0) var sourceTexture:texture_storage_2d; ${i.useDepthTexture?`@group(0) @binding(1) var depthTexture:${S}`:""}; ${i.useGBufferNormalTexture?`@group(0) @binding(${i.useDepthTexture?2:1}) var gBufferNormalTexture:texture_2d`:""}; @group(1) @binding(0) var outputTexture:texture_storage_2d; ${tr} ${x?"@group(1) @binding(2) var uniforms:Uniforms;":""} @compute @workgroup_size(${v},${b},${y}) fn main ( @builtin(global_invocation_id) global_id:vec3, ){ ${g} } `},createBasicPostEffectCode=(i,g,x="")=>({msaa:createCode(i,g,x,!0),nonMsaa:createCode(i,g,x,!1)});Object.freeze(createBasicPostEffectCode);class BlurX extends ASinglePassPostEffect{#Qt=32;constructor(i){super(i),this.init(i,"POST_EFFECT_BLUR_X",createBasicPostEffectCode(this,"let index=vec2(global_id.xy);\nlet dimensions=textureDimensions(sourceTexture);\nlet dimW=f32(dimensions.x);\nlet size_value:f32=uniforms.size;\nvar sum:vec4=vec4(0.0,0.0,0.0,0.0);\nvar offset=random(global_id,0.0);\nvar total=0.0;\nlet loopSize=10.0;\nfor (var t=-loopSize;t <=loopSize;t=t + 1.0) { var percent=(t + offset - 0.5)/loopSize; var weight=1.0 - abs(percent); var ix=clamp((f32(global_id.x) + f32(size_value * percent)),0.0,dimW - 1.0); let delta=vec2(i32(ix),i32(global_id.y)); sum +=textureLoad(sourceTexture,delta).xyzw * weight; total +=weight;\n}\nsum/=total;\ntextureStore(outputTexture,vec2(global_id.xy),sum);\n","struct Uniforms { size:f32,\n};\nfn random(id:vec3,delta:f32) -> f32 { let seed:u32=((id.x << 16) | (id.y & 0xFFFF)) ^ (id.z * 0x63641362); let t:vec3=vec3(f32(seed & 0xFF),f32((seed >> 8) & 0xFF),f32(seed >> 16)); return delta + fract(sin(dot(t,vec3(12.9898,78.233,12.9898))) * 43758.5453);\n}\n")),this.size=this.#Qt}get size(){return this.#Qt}set size(i){validateNumberRange(i,0),this.#Qt=i,this.updateUniform("size",i)}}Object.freeze(BlurX);class BlurY extends ASinglePassPostEffect{#Qt=32;constructor(i){super(i),this.init(i,"POST_EFFECT_BLUR_Y",createBasicPostEffectCode(this,"let index=vec2(global_id.xy);\nlet dimensions=textureDimensions(sourceTexture);\nlet dimH=f32(dimensions.y);\nlet size_value:f32=uniforms.size;\nvar sum:vec4=vec4(0.0,0.0,0.0,0.0);\nvar offset=random(global_id,0.0);\nvar total=0.0;\nlet loopSize=10.0;\nfor (var t=-loopSize;t <=loopSize;t=t + 1.0) { var percent=(t + offset - 0.5)/loopSize; var weight=1.0 - abs(percent); var iy=clamp((f32(global_id.y) + f32(size_value * percent)),0.0,dimH - 1.0); let delta=vec2(i32(global_id.x),i32(iy)); sum +=textureLoad(sourceTexture,delta).xyzw * weight; total +=weight;\n}\nsum/=total;\ntextureStore(outputTexture,vec2(global_id.xy),sum);\n","struct Uniforms { size:f32,\n};\nfn random(id:vec3,delta:f32) -> f32 { let seed:u32=((id.x << 16) | (id.y & 0xFFFF)) ^ (id.z * 0x63641362); let t:vec3=vec3(f32(seed & 0xFF),f32((seed >> 8) & 0xFF),f32(seed >> 16)); return delta + fract(sin(dot(t,vec3(12.9898,78.233,12.9898))) * 43758.5453);\n}\n")),this.size=this.#Qt}get size(){return this.#Qt}set size(i){validateNumberRange(i,0),this.#Qt=i,this.updateUniform("size",i)}}Object.freeze(BlurY);class GaussianBlur extends AMultiPassPostEffect{#Qt=32;constructor(i){super(i,[new BlurX(i),new BlurY(i)])}get size(){return this.#Qt}set size(i){this.#Qt=i,this.passList.forEach(g=>g.size=i)}}Object.freeze(GaussianBlur);class SSAO_AO extends ASinglePassPostEffect{#gr=.253;#xr=1;#_r=.02;#vr=.02;#br=30;#yr=20;#Sr=1.5;#Tr=!0;constructor(i){super(i),this.useDepthTexture=!0,this.useGBufferNormalTexture=!0,this.init(i,"POST_EFFECT_SSAO",createBasicPostEffectCode(this,"{ let screenCoord=vec2(global_id.xy); let texSize=vec2(textureDimensions(sourceTexture)); if (screenCoord.x >=texSize.x || screenCoord.y >=texSize.y) { return;} let originalColor=textureLoad(sourceTexture,screenCoord); let depth=textureLoad(depthTexture,screenCoord,0); var failColor=vec4(select(originalColor.rgb,vec3(1.0),uniforms.useBlur > 0.0),originalColor.a); if (depth < 0.001) { textureStore(outputTexture,screenCoord,failColor); return; } let normalData=textureLoad(gBufferNormalTexture,screenCoord,0); if (length(normalData.rgb)<0.001) { textureStore(outputTexture,screenCoord,failColor); return; } let viewPos=reconstructViewPosition(screenCoord,depth); let viewNormal=reconstructViewNormal(textureLoad(gBufferNormalTexture,screenCoord,0)); let distToCamera=-viewPos.z; let depthScale=distToCamera * 0.1; let adaptiveRadius=uniforms.radius * (1.0 + depthScale); let noiseVec=getNoiseVec(vec2(screenCoord)); let tangent=normalize(noiseVec - viewNormal * dot(noiseVec,viewNormal)); let bitangent=cross(viewNormal,tangent); let tbn=mat3x3(tangent,bitangent,viewNormal); let samples=array,8>( vec3(0.04,0.03,0.08),vec3(-0.04,0.04,0.08), vec3(0.10,-0.08,0.18),vec3(-0.09,-0.10,0.18), vec3(0.18,0.15,0.30),vec3(-0.17,0.18,0.30), vec3(0.28,-0.25,0.45),vec3(-0.27,-0.28,0.45) ); var totalOcclusion=0.0; for (var i=0u;i < 8u;i++) { let sampleOffset=tbn * samples[i]; let sampleDir=normalize(sampleOffset); let sampleViewPos=viewPos + sampleOffset * adaptiveRadius; let clipPos=systemUniforms.projectionMatrix * vec4(sampleViewPos,1.0); let sampleUV=(clipPos.xy/clipPos.w) * vec2(0.5,-0.5) + 0.5; if (sampleUV.x < 0.0 || sampleUV.x > 1.0 || sampleUV.y < 0.0 || sampleUV.y > 1.0) { continue; } let sampleCoord=vec2(sampleUV * vec2(texSize)); let realDepth=textureLoad(depthTexture,sampleCoord,0); if (realDepth < 0.001) { continue;} let realViewPos=reconstructViewPosition(sampleCoord,realDepth); let adaptiveBias=uniforms.bias * (1.0 + distToCamera * uniforms.biasDistanceScale); let deltaZ=realViewPos.z - sampleViewPos.z; if (deltaZ > adaptiveBias && deltaZ < adaptiveRadius * 1.5) { let sampleDist=length(viewPos - realViewPos); if (sampleDist < adaptiveRadius * 1.5) { let angleWeight=pow(max(0.0,dot(viewNormal,sampleDir)),2.0); let distFalloff=1.0 - smoothstep(0.0,adaptiveRadius * 1.5,sampleDist); totalOcclusion +=angleWeight * distFalloff; } } } let ao=(totalOcclusion/8.0) * uniforms.intensity; let distanceFade=smoothstep( uniforms.fadeDistanceStart + uniforms.fadeDistanceRange, uniforms.fadeDistanceStart, distToCamera ); var finalAO=saturate(1.0 - (ao * distanceFade)); finalAO=pow(finalAO,uniforms.contrast); let finalColor=vec4( select(originalColor.rgb * vec3(finalAO),vec3(finalAO),uniforms.useBlur > 0.0), originalColor.a ); textureStore(outputTexture,screenCoord,finalColor);\n}\n","struct Uniforms { radius:f32, intensity:f32, bias:f32, biasDistanceScale:f32, fadeDistanceStart:f32, fadeDistanceRange:f32, contrast:f32, useBlur:f32,\n}\nfn getTextureSize() -> vec2 { return vec2(textureDimensions(sourceTexture));\n}\nfn reconstructViewPosition(screenCoord:vec2,depth:f32) -> vec3 { let texSize=getTextureSize(); let uv=(vec2(screenCoord) + 0.5)/texSize; let ndc=vec3(uv.x * 2.0 - 1.0,(1.0 - uv.y) * 2.0 - 1.0,depth); let clipPos=vec4(ndc,1.0); let viewPos4=systemUniforms.inverseProjectionMatrix * clipPos; return viewPos4.xyz/viewPos4.w;\n}\nfn reconstructViewNormal(gBufferNormalData:vec4) -> vec3 { let worldNormal=normalize(gBufferNormalData.rgb * 2.0 - 1.0); let viewNormal=(systemUniforms.camera.cameraMatrix * vec4(worldNormal,0.0)).xyz; return normalize(viewNormal);\n}\nfn getNoiseVec(p:vec2) -> vec3 { let noise=fract(52.9829189 * fract(dot(p,vec2(0.06711056,0.00583715)))); let angle=noise * 6.28318530718; return vec3(cos(angle),sin(angle),0.0);\n}\n")),this.radius=this.#gr,this.intensity=this.#xr,this.bias=this.#_r,this.biasDistanceScale=this.#vr,this.fadeDistanceStart=this.#br,this.fadeDistanceRange=this.#yr,this.contrast=this.#Sr,this.useBlur=!0}get useBlur(){return this.#Tr}set useBlur(i){this.#Tr=i,this.updateUniform("useBlur",i?1:0)}get radius(){return this.#gr}set radius(i){validatePositiveNumberRange(i,.01,5),this.#gr=i,this.updateUniform("radius",i)}get intensity(){return this.#xr}set intensity(i){validateNumberRange(i,0,10),this.#xr=i,this.updateUniform("intensity",i)}get bias(){return this.#_r}set bias(i){validateNumberRange(i,0,.1),this.#_r=i,this.updateUniform("bias",i)}get biasDistanceScale(){return this.#vr}set biasDistanceScale(i){validateNumberRange(i,0,.5),this.#vr=i,this.updateUniform("biasDistanceScale",i)}get fadeDistanceStart(){return this.#br}set fadeDistanceStart(i){validatePositiveNumberRange(i,1,200),this.#br=i,this.updateUniform("fadeDistanceStart",i)}get fadeDistanceRange(){return this.#yr}set fadeDistanceRange(i){validatePositiveNumberRange(i,1,100),this.#yr=i,this.updateUniform("fadeDistanceRange",i)}get contrast(){return this.#Sr}set contrast(i){validateNumberRange(i,.5,4),this.#Sr=i,this.updateUniform("contrast",i)}}Object.freeze(SSAO_AO);class SSAOBlend extends ASinglePassPostEffect{constructor(i){super(i);const{WORK_SIZE_X:g,WORK_SIZE_Y:x,WORK_SIZE_Z:_}=this,v=`\n @group(0) @binding(0) var sourceTexture0:texture_storage_2d; @group(0) @binding(1) var sourceTexture1:texture_storage_2d; @group(1) @binding(0) var outputTexture:texture_storage_2d;\n @compute @workgroup_size(${g},${x},${_}) fn main ( @builtin(global_invocation_id) global_id:vec3, ){ let index=vec2(global_id.xy ); let dimensions:vec2=textureDimensions(sourceTexture0); let dimW=f32(dimensions.x); let dimH=f32(dimensions.y); let uv=\tvec2(f32(index.x)/dimW,f32(index.y)/dimH); var diffuse:vec4=textureLoad( sourceTexture0, index, ); var blur:vec4=textureLoad( sourceTexture1, index, ); let finalColor=vec4((diffuse.rgb * blur.rgb ) ,diffuse.a); textureStore(outputTexture,index,finalColor ); }; `;this.init(i,"POST_EFFECT_OLD_BLOOM",{msaa:v,nonMsaa:v})}render(i,g,x,_,v){return super.render(i,g,x,_,v)}}Object.freeze(SSAOBlend);class SSAO extends AMultiPassPostEffect{#Mr;#wr;#Cr;constructor(i){super(i,[new SSAO_AO(i),new GaussianBlur(i),new SSAOBlend(i)]),this.#Mr=this.passList[0],this.#wr=this.passList[1],this.#wr.size=3,this.#Cr=this.passList[2]}get useBlur(){return this.#Mr.useBlur}set useBlur(i){this.#Mr.useBlur=i}get radius(){return this.#Mr.radius}set radius(i){this.#Mr.radius=i}get intensity(){return this.#Mr.intensity}set intensity(i){this.#Mr.intensity=i}get bias(){return this.#Mr.bias}set bias(i){this.#Mr.bias=i}get biasDistanceScale(){return this.#Mr.biasDistanceScale}set biasDistanceScale(i){this.#Mr.biasDistanceScale=i}get fadeDistanceStart(){return this.#Mr.fadeDistanceStart}set fadeDistanceStart(i){this.#Mr.fadeDistanceStart=i}get fadeDistanceRange(){return this.#Mr.fadeDistanceRange}set fadeDistanceRange(i){this.#Mr.fadeDistanceRange=i}get contrast(){return this.#Mr.contrast}set contrast(i){this.#Mr.contrast=i}render(i,g,x,_){const v=this.#Mr.render(i,g,x,_);if(this.useBlur){const b=this.#wr.render(i,g,x,v);return this.#Cr.render(i,g,x,_,b)}return v}}Object.freeze(SSAO);class SSR extends ASinglePassPostEffect{#Rr=64;#Pr=15;#Br=.02;#Ir=1;#Er=12;#Dr=.15;constructor(i){super(i),this.WORK_SIZE_X=8,this.WORK_SIZE_Y=8,this.WORK_SIZE_Z=1,this.useDepthTexture=!0,this.useGBufferNormalTexture=!0,this.init(i,"POST_EFFECT_SSR",createBasicPostEffectCode(this,"let screenCoord=vec2(global_id.xy);\nlet texDims=textureDimensions(sourceTexture);\nlet texSize=vec2(texDims);\nif (screenCoord.x >=texSize.x || screenCoord.y >=texSize.y) { return;\n}\nlet originalColor=textureLoad(sourceTexture,screenCoord);\nlet depth=textureLoad(depthTexture,screenCoord,0);\nif (depth >=0.999) { textureStore(outputTexture,screenCoord,originalColor); return;\n}\nlet gBufferNormalData=textureLoad(gBufferNormalTexture,screenCoord,0);\nlet precomputedReflectionStrength=gBufferNormalData.a;\nif (precomputedReflectionStrength < 0.05) { textureStore(outputTexture,screenCoord,originalColor); return;\n}\nlet worldPos=reconstructWorldPosition(screenCoord,depth);\nlet worldNormal=reconstructWorldNormal(gBufferNormalData);\nif (length(worldNormal) < 0.01) { textureStore(outputTexture,screenCoord,originalColor); return;\n}\nlet normal=normalize(worldNormal);\nlet cameraWorldPos=systemUniforms.camera.inverseCameraMatrix[3].xyz;\nlet reflectionDir=calculateWorldReflectionRay(worldPos,normal,cameraWorldPos);\nlet reflection=performWorldRayMarching(worldPos,reflectionDir);\nif (reflection.a > 0.001) { let finalReflectionStrength=reflection.a * uniforms.reflectionIntensity * precomputedReflectionStrength; let reflectionColor=reflection.rgb * finalReflectionStrength; let diffuseColor=originalColor.rgb * (1.0 - finalReflectionStrength); let finalColor=diffuseColor + reflectionColor; textureStore(outputTexture,screenCoord,vec4(finalColor,originalColor.a));\n} else { textureStore(outputTexture,screenCoord,originalColor);\n}\n","struct Uniforms { maxSteps:u32, maxDistance:f32, stepSize:f32, reflectionIntensity:f32, fadeDistance:f32, edgeFade:f32, _padding:f32, _padding2:f32, } fn getTextureDimensions() -> vec2 { return textureDimensions(depthTexture); } fn reconstructWorldPosition(screenCoord:vec2,depth:f32) -> vec3 { let texDims=getTextureDimensions(); let invTexDims=1.0/vec2(texDims); let uv=(vec2(screenCoord) + 0.5) * invTexDims; let ndc=vec3( uv.x * 2.0 - 1.0, -(uv.y * 2.0 - 1.0), depth * 2.0 - 1.0 ); let clipPos=vec4(ndc,1.0); let viewPos4=systemUniforms.inverseProjectionMatrix * clipPos; if (abs(viewPos4.w) < 1e-6) { return vec3(0.0); } let viewPos=viewPos4.xyz/viewPos4.w; let worldPos4=systemUniforms.camera.inverseCameraMatrix * vec4(viewPos,1.0); return worldPos4.xyz; } fn reconstructWorldNormal(gBufferNormalData:vec4) -> vec3 { return normalize(gBufferNormalData.rgb * 2.0 - 1.0); } fn worldToScreen(worldPos:vec3) -> vec2 { let clipPos4=systemUniforms.projectionCameraMatrix * vec4(worldPos,1.0); if (abs(clipPos4.w) < 1e-6) { return vec2(-1.0); } let ndc=clipPos4.xyz/clipPos4.w; return vec2(ndc.x * 0.5 + 0.5,-ndc.y * 0.5 + 0.5); } fn calculateEdgeFade(screenUV:vec2) -> f32 { let edge=min(screenUV,1.0 - screenUV); let edgeDist=min(edge.x,edge.y); return smoothstep(0.0,uniforms.edgeFade,edgeDist); } fn calculateWorldReflectionRay(worldPos:vec3,worldNormal:vec3,cameraWorldPos:vec3) -> vec3 { let viewDir=normalize(cameraWorldPos - worldPos); return reflect(-viewDir,worldNormal); }\nfn performWorldRayMarching(startWorldPos:vec3,rayDir:vec3) -> vec4 { let cameraWorldPos=systemUniforms.camera.inverseCameraMatrix[3].xyz; let cameraDistance=length(startWorldPos - cameraWorldPos); let distanceScale=1.0 + cameraDistance * 0.1; let adaptiveStepSize=uniforms.stepSize * min(distanceScale,4.0); let stepScale=1.0 + cameraDistance * 0.067; let adaptiveMaxSteps=u32(f32(uniforms.maxSteps) * min(stepScale,2.0)); let maxDistanceSq=uniforms.maxDistance * uniforms.maxDistance; let texDims=getTextureDimensions(); let texSizeF=vec2(texDims); let maxRefinementLevels=4u; let invMaxSteps=1.0/f32(adaptiveMaxSteps); var currentWorldPos=startWorldPos + rayDir * 0.01; var currentStepSize=adaptiveStepSize; var refinementLevel=0u; for (var i=0u;i < adaptiveMaxSteps;i++) { currentWorldPos +=rayDir * currentStepSize; let travelVec=currentWorldPos - startWorldPos; let travelDistanceSq=dot(travelVec,travelVec); if (travelDistanceSq > maxDistanceSq) { break; } let currentScreenUV=worldToScreen(currentWorldPos); if (any(currentScreenUV < vec2(0.0)) || any(currentScreenUV > vec2(1.0))) { break; } let screenCoord=vec2(currentScreenUV * texSizeF); let sampledDepth=textureLoad(depthTexture,screenCoord,0); if (sampledDepth >=0.999) { continue; } let sampledWorldPos=reconstructWorldPosition(screenCoord,sampledDepth); let rayDistanceFromCamera=length(currentWorldPos - cameraWorldPos); let surfaceDistanceFromCamera=length(sampledWorldPos - cameraWorldPos); let distanceDiff=rayDistanceFromCamera - surfaceDistanceFromCamera; let intersectionThreshold=currentStepSize * (4.0 + cameraDistance * 0.033); if (distanceDiff > 0.0 && distanceDiff < intersectionThreshold) { if (refinementLevel < maxRefinementLevels) { currentWorldPos -=rayDir * currentStepSize; currentStepSize *=0.6; refinementLevel++; continue; } let reflectionColor=textureLoad(sourceTexture,screenCoord); let travelDistance=sqrt(travelDistanceSq); let distanceFade=1.0 - smoothstep(0.0,uniforms.fadeDistance,travelDistance); let edgeFade=calculateEdgeFade(currentScreenUV); let stepFade=1.0 - f32(i) * invMaxSteps; let distanceCompensation=min(1.5,1.0 + cameraDistance * 0.04); let totalFade=distanceFade * edgeFade * stepFade * distanceCompensation; return vec4(reflectionColor.rgb,totalFade); } } return vec4(0.0);\n}\n")),this.maxSteps=this.#Rr,this.maxDistance=this.#Pr,this.stepSize=this.#Br,this.reflectionIntensity=this.#Ir,this.fadeDistance=this.#Er,this.edgeFade=this.#Dr}get maxSteps(){return this.#Rr}set maxSteps(i){validateNumberRange(i,1,512),this.#Rr=i,this.updateUniform("maxSteps",i)}get maxDistance(){return this.#Pr}set maxDistance(i){validatePositiveNumberRange(i,1,200),this.#Pr=i,this.updateUniform("maxDistance",i)}get stepSize(){return this.#Br}set stepSize(i){validatePositiveNumberRange(i,.001,5),this.#Br=i,this.updateUniform("stepSize",i)}get reflectionIntensity(){return this.#Ir}set reflectionIntensity(i){validateNumberRange(i,0,5),this.#Ir=i,this.updateUniform("reflectionIntensity",i)}get fadeDistance(){return this.#Er}set fadeDistance(i){validatePositiveNumberRange(i,1,100),this.#Er=i,this.updateUniform("fadeDistance",i)}get edgeFade(){return this.#Dr}set edgeFade(i){validateNumberRange(i,0,.5),this.#Dr=i,this.updateUniform("edgeFade",i)}}Object.freeze(SSR);class TAASharpen extends ASinglePassPostEffect{#Ur=.5;constructor(i){super(i),this.init(i,"POST_EFFECT_TAA_SHARPEN",createBasicPostEffectCode(this,"let index=vec2(global_id.xy);\nlet dimensions:vec2=textureDimensions(sourceTexture);\nif (any(index >=dimensions)) { return;\n}\nlet centerRGBA=textureLoad(sourceTexture,index);\nlet leftRGBA=textureLoad(sourceTexture,index - vec2(select(0u,1u,index.x > 0u),0u));\nlet rightRGBA=textureLoad(sourceTexture,min(index + vec2(1u,0u),dimensions - 1u));\nlet upRGBA=textureLoad(sourceTexture,index - vec2(0u,select(0u,1u,index.y > 0u)));\nlet downRGBA=textureLoad(sourceTexture,min(index + vec2(0u,1u),dimensions - 1u));\nlet lumaWeight=vec3(0.299,0.587,0.114);\nlet lCenter=dot(centerRGBA.rgb,lumaWeight);\nlet lLeft=dot(leftRGBA.rgb,lumaWeight);\nlet lRight=dot(rightRGBA.rgb,lumaWeight);\nlet lUp=dot(upRGBA.rgb,lumaWeight);\nlet lDown=dot(downRGBA.rgb,lumaWeight);\nlet minL=min(lCenter,min(min(lLeft,lRight),min(lUp,lDown)));\nlet maxL=max(lCenter,max(max(lLeft,lRight),max(lUp,lDown)));\nlet contrast=maxL - minL;\nvar finalRGBA:vec4;\nlet k=uniforms.sharpness * 0.2;\nif (contrast > 0.001) { let edgeRGB=4.0 * centerRGBA.rgb - (leftRGBA.rgb + rightRGBA.rgb + upRGBA.rgb + downRGBA.rgb); let sharpRGB=centerRGBA.rgb + edgeRGB * k; let edgeAlpha=4.0 * centerRGBA.a - (leftRGBA.a + rightRGBA.a + upRGBA.a + downRGBA.a); let sharpAlpha=centerRGBA.a + edgeAlpha * k; finalRGBA=vec4(sharpRGB,sharpAlpha);\n} else { finalRGBA=centerRGBA;\n}\ntextureStore(outputTexture,index,saturate(finalRGBA));","struct Uniforms { sharpness:f32\n};")),this.sharpness=.5}get sharpness(){return this.#Ur}set sharpness(i){validateNumberRange(i,0,1),this.#Ur=i,this.updateUniform("sharpness",i)}}Object.freeze(TAASharpen);class PostEffectManager{#Ft;#Lr=[];#Ar;#Gr;#kr;#me=16;#pe=4;#Or=1;#Nr;#Vr;#Fr;#Hr;#zr;#$r;#Kr;#N=0;#Xr;#jr;#Yr;#qr;#Wr;#Zr=!1;#Jr;#Qr=!1;constructor(i){this.#Ft=i,this.#ne()}get useSSAO(){return this.#Zr}set useSSAO(i){this.#Zr=i,this.#ei()}get ssao(){return this.#Wr||(this.#Wr=new SSAO(this.#Ft.redGPUContext)),this.#Wr}get useSSR(){return this.#Qr}set useSSR(i){this.#Qr=i,this.#ti()}get ssr(){return this.#Jr||(this.#Jr=new SSR(this.#Ft.redGPUContext)),this.#Jr}get postEffectSystemUniformBuffer(){return this.#$r}get view(){return this.#Ft}get effectList(){return this.#Lr}get videoMemorySize(){return this.#mr(),this.#N}addEffect(i){this.#Lr.push(i)}getEffectAt(i){return this.#Lr[i]}removeAllEffect(){this.#Lr.forEach(i=>{i.clear()}),this.#Lr.length=0}render(){const{viewRenderTextureManager:i,redGPUContext:g,taa:x,fxaa:_,toneMappingManager:v}=this.#Ft,{antialiasingManager:b}=g,{useMSAA:y,useFXAA:S,useTAA:w}=b,{gBufferColorTextureView:L,gBufferColorResolveTextureView:k,gBufferColorTexture:H}=i,{width:z,height:q}=H,W=y?k:L;this.#ni(),this.#Gr=this.#ri(this.#Ft,W);let be={texture:this.#Ar,textureView:this.#Gr};return be=v.render(z,q,be),this.#Lr.forEach(i=>{be=i.render(this.#Ft,z,q,be)}),S&&(be=_.render(this.#Ft,z,q,be)),this.#Zr&&(be=this.ssao.render(this.#Ft,z,q,be)),this.#Qr&&(be=this.ssr.render(this.#Ft,z,q,be)),w&&("View3D"===this.#Ft.constructor.name?(be=x.render(this.#Ft,z,q,be),this.#qr||(this.#qr=new TAASharpen(g)),be=this.#qr.render(this.#Ft,z,q,be)):be=_.render(this.#Ft,z,q,be)),be}clear(){this.#Lr.forEach(i=>{i.clear()})}#ei(){!this.#Wr&&this.#Zr&&(this.#Wr=new SSAO(this.#Ft.redGPUContext))}#ti(){!this.#Jr&&this.#Qr&&(this.#Jr=new SSR(this.#Ft.redGPUContext))}#ii(i){i.forEach(({key:i,value:g,dataView:x,targetMembers:_})=>{const v=_[i];x.set("number"==typeof g?[g]:g,v.uniformOffset/v.View.BYTES_PER_ELEMENT)})}#ni(){const{inverseProjectionMatrix:i,projectionMatrix:g,rawCamera:x,redGPUContext:_,scene:v}=this.#Ft,{gpuDevice:b}=_,{modelMatrix:y,position:S}=x,w=this.#Kr,L=this.#$r.gpuBuffer,k=x instanceof Camera2D,H=multiply$4(Cr,g,y);{const{members:_}=w,v=_.camera.members;this.#ii([{key:"projectionMatrix",value:g,dataView:this.#jr,targetMembers:_},{key:"inverseProjectionMatrix",value:i,dataView:this.#jr,targetMembers:_},{key:"projectionCameraMatrix",value:H,dataView:this.#jr,targetMembers:_},{key:"inverseProjectionCameraMatrix",value:invert$1(Rr,H),dataView:this.#jr,targetMembers:_},{key:"cameraMatrix",value:y,dataView:this.#jr,targetMembers:v},{key:"inverseCameraMatrix",value:invert$1(Rr,y),dataView:this.#jr,targetMembers:v},{key:"cameraPosition",value:S,dataView:this.#jr,targetMembers:v},{key:"nearClipping",value:k?0:x.nearClipping,dataView:this.#jr,targetMembers:v},{key:"farClipping",value:k?0:x.farClipping,dataView:this.#jr,targetMembers:v},{key:"fieldOfView",value:x.fieldOfView*Math.PI/180,dataView:this.#jr,targetMembers:v}])}b.queue.writeBuffer(L,0,this.#Xr)}#ne(){const{redGPUContext:i}=this.#Ft,{gpuDevice:g,resourceManager:x}=i,_=this.#ai();this.#Nr=x.createGPUShaderModule("POST_EFFECT_TEXTURE_COPY_COMPUTE_SHADER",{code:_}),this.#Fr=this.#si(i),this.#Hr=this.#oi(g,this.#Nr,this.#Fr);const v=parseWGSL(tr).uniforms.systemUniforms,b=new ArrayBuffer(v.arrayBufferByteLength);this.#Kr=v,this.#$r=new UniformBuffer(i,b,`${this.#Ft.name}_POST_EFFECT_SYSTEM_UNIFORM_BUFFER`),this.#Xr=new ArrayBuffer(this.#Kr.endOffset),this.#jr=new Float32Array(this.#Xr),this.#Yr=new Uint32Array(this.#Xr)}#mr(){const i=this.#Ar;if(!i)return 0;this.#N=calculateTextureByteSize(i),this.#Lr.forEach(i=>{this.#N+=i.videoMemorySize})}#ri(i,g){const{redGPUContext:x,viewRenderTextureManager:_}=i,{gBufferColorTexture:v}=_,{gpuDevice:b,antialiasingManager:y,resourceManager:S}=x,{useMSAA:w,changedMSAA:L}=y,{width:k,height:H}=v,z=k!==this.#zr?.width||H!==this.#zr?.height;return z&&(this.#Ar&&(this.#Ar.destroy(),this.#Ar=null),this.#Ar=this.#ui(b,k,H),this.#kr=S.getGPUResourceBitmapTextureView(this.#Ar)),(z||L)&&(this.#Vr=this.#li(x,this.#Fr,g,this.#kr)),this.#zr={width:k,height:H},this.#ci(b,this.#Hr,this.#Vr,k,H),this.#kr}#ai(){return`\n\t @group(0) @binding(0) var sourceTextureSampler:sampler; @group(0) @binding(1) var sourceTexture:texture_2d; @group(0) @binding(2) var outputTexture:texture_storage_2d; @compute @workgroup_size(${this.#me},${this.#pe},${this.#Or}) fn main ( @builtin(global_invocation_id) global_id:vec3, ){ let index=vec2(global_id.xy ); let dimensions:vec2=textureDimensions(sourceTexture); let dimW=f32(dimensions.x); let dimH=f32(dimensions.y); let uv=\tvec2((f32(index.x)+0.5)/dimW,(f32(index.y)+0.5)/dimH); var color:vec4=textureSampleLevel( sourceTexture, sourceTextureSampler, uv, 0 ); textureStore(outputTexture,index,color ); }; `}#si(i){return i.resourceManager.createBindGroupLayout(`${this.#Ft.name}_POST_EFFECT_TEXTURE_COPY_BIND_GROUP_LAYOUT`,{entries:[{binding:0,visibility:GPUShaderStage.COMPUTE,sampler:{type:"filtering"}},{binding:1,visibility:GPUShaderStage.COMPUTE,texture:{}},{binding:2,visibility:GPUShaderStage.COMPUTE,storageTexture:{format:"rgba16float"}}]})}#ui(i,g,x){return this.#Ft.redGPUContext.resourceManager.createManagedTexture({size:{width:g,height:x},format:"rgba16float",usage:GPUTextureUsage.TEXTURE_BINDING|GPUTextureUsage.STORAGE_BINDING|GPUTextureUsage.COPY_SRC,label:`${this.#Ft.name}_POST_EFFECT_STORAGE_TEXTURE_${g}x${x}`})}#li(i,g,x,_){const v=Date.now();return i.gpuDevice.createBindGroup({label:`${this.#Ft.name}_POST_EFFECT_TEXTURE_COPY_BIND_GROUP_${v}`,layout:g,entries:[{binding:0,resource:new Sampler(i).gpuSampler},{binding:1,resource:x},{binding:2,resource:_}]})}#oi(i,g,x){return i.createComputePipeline({label:"POST_EFFECT_TEXTURE_COPY_COMPUTE_PIPELINE",layout:i.createPipelineLayout({label:"POST_EFFECT_TEXTURE_COPY_PIPELINE_LAYOUT",bindGroupLayouts:[x]}),compute:{module:g,entryPoint:"main"}})}#ci(i,g,x,_,v){const b=i.createCommandEncoder({label:"POST_EFFECT_TEXTURE_COPY_COMMAND_ENCODER"}),y=b.beginComputePass({label:"POST_EFFECT_TEXTURE_COPY_COMPUTE_PASS"});y.setPipeline(g),y.setBindGroup(0,x),y.dispatchWorkgroups(Math.ceil(_/this.#me),Math.ceil(v/this.#pe)),y.end(),i.queue.submit([b.finish()])}}let Cr=create$4(),Rr=create$4();function defineProperty_boolean(i,g=!1){return defineBoolean(i,g,!1)}function defineProperty_uintRange(i,g=0,x,_){return defineUintRange(i,g,!1,x,_)}function defineProperty_PositiveNumberRange(i,g=1,x,_){return definePositiveNumberRange(i,g,!1,x,_)}Object.freeze(PostEffectManager);const Pr={USE_BILLBOARD:"useBillboard",RECEIVE_SHADOW:"receiveShadow"},Br={},Ir={},Er={...createDefineByPreset({defineBoolean:[defineProperty_boolean,Pr],defineUint:[defineProperty_uintRange,Ir],definePositiveNumber:[defineProperty_PositiveNumberRange,Br]}),defineBoolean:defineProperties(defineProperty_boolean),defineUint:defineProperties(defineProperty_uintRange),definePositiveNumber:defineProperties(defineProperty_PositiveNumberRange),defineVec4:defineProperties(function(i,g=[0,0,0,0]){return defineVector(i,g,!1)}),defineVec3:defineProperties(function(i,g=[0,0,0]){return defineVector(i,g,!1)}),defineVec2:defineProperties(function(i,g=[0,0]){return defineVector(i,g,!1)}),PRESET_BOOLEAN:Pr,PRESET_POSITIVE_NUMBER:Br,PRESET_UINT:Ir,PRESET_SAMPLER:{},PRESET_TEXTURE:{},PRESET_CUBE_TEXTURE:{},PRESET_VEC2:{},PRESET_VEC3:{},PRESET_VEC4:{},PRESET_COLOR_RGB:{}};Object.freeze(Er);class GeometryGPURenderInfo{buffers;constructor(i){this.buffers=i}}Object.freeze(GeometryGPURenderInfo);class AABB{minX;maxX;minY;maxY;minZ;maxZ;centerX;centerY;centerZ;xSize;ySize;zSize;geometryRadius;constructor(i,g,x,_,v,b){this.minX=i,this.maxX=g,this.minY=x,this.maxY=_,this.minZ=v,this.maxZ=b,this.centerX=(g+i)/2,this.centerY=(_+x)/2,this.centerZ=(b+v)/2,this.xSize=g-i,this.ySize=_-x,this.zSize=b-v,this.geometryRadius=Math.sqrt((this.xSize/2)**2+(this.ySize/2)**2+(this.zSize/2)**2)}intersects(i){return i instanceof AABB||consoleAndThrowError("allow only AABB instance"),this.minX<=i.maxX&&this.maxX>=i.minX&&this.minY<=i.maxY&&this.maxY>=i.minY&&this.minZ<=i.maxZ&&this.maxZ>=i.minZ}contains(i,g,x){if(Array.isArray(i)){const[g,x,_]=i;return g>=this.minX&&g<=this.maxX&&x>=this.minY&&x<=this.maxY&&_>=this.minZ&&_<=this.maxZ}return i>=this.minX&&i<=this.maxX&&g>=this.minY&&g<=this.maxY&&x>=this.minZ&&x<=this.maxZ}clone(){return new AABB(this.minX,this.maxX,this.minY,this.maxY,this.minZ,this.maxZ)}}const calculateGeometryAABB=i=>{if(!i||!i.data||0===i.vertexCount)return new AABB(0,0,0,0,0,0);const g=i.stride,x=i.data,_=i.vertexCount;let v=1/0,b=1/0,y=1/0,S=-1/0,w=-1/0,L=-1/0,k=0;for(;k<=_-4;k+=4){let i=k*g;const _=x[i],H=x[i+1],z=x[i+2];i=(k+1)*g;const q=x[i],W=x[i+1],be=x[i+2];i=(k+2)*g;const Ke=x[i],Xe=x[i+1],je=x[i+2];i=(k+3)*g;const Ye=x[i],Ze=x[i+1],Je=x[i+2];_S&&(S=_),q>S&&(S=q),Ke>S&&(S=Ke),Ye>S&&(S=Ye),Hw&&(w=H),W>w&&(w=W),Xe>w&&(w=Xe),Ze>w&&(w=Ze),zL&&(L=z),be>L&&(L=be),je>L&&(L=je),Je>L&&(L=Je)}for(;k<_;k++){const i=k*g,_=x[i],H=x[i+1],z=x[i+2];_S&&(S=_),H>w&&(w=H),z>L&&(L=z)}return new AABB(v,S,b,w,y,L)};class Geometry extends ResourceBase{gpuRenderInfo;#hi;#fi;#di;constructor(i,g,x){super(i),this.#mi(g),this.#pi(x);const{interleavedStruct:_}=this.#hi;this.gpuRenderInfo=new GeometryGPURenderInfo([{arrayStride:_.arrayStride,attributes:_.attributes}])}get vertexBuffer(){return this.#hi}get indexBuffer(){return this.#fi}get volume(){return this.#di||(this.#di=calculateGeometryAABB(this.#hi)),this.#di}#mi(i){const g=this.#hi;this.#hi=i,g&&g.__removeDirtyPipelineListener(this.#gi),i&&i.__addDirtyPipelineListener(this.#gi),this.#di=null}#pi(i){const g=this.#fi;this.#fi=i,g&&g.__removeDirtyPipelineListener(this.#xi),i&&i.__addDirtyPipelineListener(this.#xi)}#gi(){this.__fireListenerList()}#xi(){this.__fireListenerList()}}Object.freeze(Geometry);const Dr={UINT16:"uint16",UINT32:"uint32"};Object.freeze(Dr);class ResourceStateIndexBuffer{static dirtyList=[];buffer;label;uuid;#Wt=0;constructor(i){this.buffer=i,this.label=i.name,this.uuid=i.uuid}get useNum(){return this.#Wt}set useNum(i){this.#Wt=i,ResourceStateIndexBuffer.dirtyList.push(this)}}class IndexBuffer extends ABaseBuffer{[Zn];#_i=0;#vi=0;#F=Dr.UINT32;constructor(i,g,x=GPUBufferUsage.INDEX|GPUBufferUsage.COPY_DST,_=""){super(i,"managedIndexBufferState",x);const{table:v}=this.targetResourceManagedState,b=v.get(_);if(b)return b.buffer;_&&(this.name=_,this[er]=_),this.changeData(g),this.redGPUContext.resourceManager.registerManagementResource(this,new ResourceStateIndexBuffer(this))}get format(){return this.#F}get triangleCount(){return this.#vi}get indexCount(){return this.#_i}get data(){return this[Zn]}changeData(i){const{gpuDevice:g}=this;if(Array.isArray(i)&&(i=new Uint32Array(i)),this[Wn]){this.targetResourceManagedState.videoMemory-=this[Zn].byteLength||0;let i=this[Wn];requestAnimationFrame(()=>{i.destroy()}),this[Wn]=null}this[Zn]=i,this.#_i=i.length;const x={size:this[Zn].byteLength,usage:this.usage,label:this.name};this[Wn]=g.createBuffer(x),this.targetResourceManagedState.videoMemory+=this[Zn].byteLength||0,this.#vi=this.#_i/3,g.queue.writeBuffer(this[Wn],0,this[Zn])}}Object.freeze(IndexBuffer);class ResourceStateVertexBuffer{static dirtyList=[];buffer;label;uuid;#Wt=0;constructor(i){this.buffer=i,this.label=i.name,this.uuid=i.uuid}get useNum(){return this.#Wt}set useNum(i){this.#Wt=i,ResourceStateVertexBuffer.dirtyList.push(this)}}class VertexBuffer extends ABaseBuffer{[Zn];#bi=0;#yi=0;#Si;#vi=0;constructor(i,g,x,_=GPUBufferUsage.VERTEX|GPUBufferUsage.COPY_DST|GPUBufferUsage.STORAGE,v=""){super(i,"managedVertexBufferState",_);const{table:b}=this.targetResourceManagedState,y=b.get(v);if(y)return y.buffer;this.#Si=x,v&&(this.name=v,this[er]=v),this.changeData(g,this.#Si),this.redGPUContext.resourceManager.registerManagementResource(this,new ResourceStateVertexBuffer(this))}get data(){return this[Zn]}get stride(){return this.#yi}get interleavedStruct(){return this.#Si}get vertexCount(){return this.#bi}get triangleCount(){return this.#vi}changeData(i,g){const{gpuDevice:x}=this;if(Array.isArray(i)&&(i=new Float32Array(i)),this[Zn]=i,g&&this.#Ti(g),this[Wn]){this.targetResourceManagedState.videoMemory-=this[Zn].byteLength||0;let i=this[Wn];requestAnimationFrame(()=>{i.destroy()}),this[Wn]=null}const _={size:this[Zn].byteLength,usage:this.usage,label:this.name};this[Wn]=x.createBuffer(_),this.targetResourceManagedState.videoMemory+=this[Zn].byteLength||0,this.#vi=this[Zn].length/this.#yi,x.queue.writeBuffer(this[Wn],0,this[Zn])}updateData(i,g=0){i instanceof Array&&(i=new Float32Array(i));const{gpuDevice:x}=this;x.queue.writeBuffer(this[Wn],g,i)}updateAllData(i){const{gpuDevice:g}=this;g.queue.writeBuffer(this[Wn],0,this[Zn])}#Ti(i){this.#Si=i,this.#bi=0,this.#yi=0;for(const i in this.#Si.define){const g=this.#Si.define[i].attributeStride/Float32Array.BYTES_PER_ELEMENT;this.#bi+=g,this.#yi+=g}this.#bi=this[Zn].length/this.#bi}}Object.freeze(VertexBuffer);class VertexInterleavedStructElement{attributeName;attributeStride;interleaveType;constructor(i,g,x){this.attributeName=i,this.attributeStride=g,this.interleaveType=x}}class VertexInterleavedStruct{#Mi;#h="";#wi=[];#Ci=0;constructor(i,g=""){this.#h=g,this.#Ri(i),this.#Pi()}get label(){return this.#h}get attributes(){return this.#wi}get arrayStride(){return this.#Ci}get define(){return{...this.#Mi}}#Ri(i){let g={};for(const x in i){const _=i[x],v=_.stride;g[x]=new VertexInterleavedStructElement(x,v,_),v%4!=0&&consoleAndThrowError(`Invalid attribute stride:${v}`)}this.#Mi=g}#Pi(){this.#Ci=0,this.#wi=[];for(const[i,{attributeStride:g,interleaveType:x}]of Object.entries(this.#Mi))this.#wi.push({attributeName:i,shaderLocation:this.#wi.length,offset:this.#Ci,format:x.gpuVertexFormat}),this.#Ci+=g}}class VertexInterleaveType{static get float32(){return{numElements:1,stride:Float32Array.BYTES_PER_ELEMENT,gpuVertexFormat:"float32",offset:0}}static get float32x2(){return{numElements:2,stride:2*Float32Array.BYTES_PER_ELEMENT,gpuVertexFormat:"float32x2",offset:0}}static get float32x3(){return{numElements:3,stride:3*Float32Array.BYTES_PER_ELEMENT,gpuVertexFormat:"float32x3",offset:0}}static get float32x4(){return{numElements:4,stride:4*Float32Array.BYTES_PER_ELEMENT,gpuVertexFormat:"float32x4",offset:0}}}Object.freeze(VertexInterleaveType);class Primitive{#Bi;#hi;#fi;#di;constructor(i){validateRedGPUContext(i)}static get primitiveInterleaveStruct(){return new VertexInterleavedStruct({vertexPosition:VertexInterleaveType.float32x3,vertexNormal:VertexInterleaveType.float32x3,texcoord:VertexInterleaveType.float32x2},"primitiveInterleaveStruct")}get gpuRenderInfo(){return this.#Bi}get vertexBuffer(){return this.#hi}get indexBuffer(){return this.#fi}get volume(){return this.#di||(this.#di=calculateGeometryAABB(this.#hi)),this.#di}_setData(i){if(this.#hi=i.vertexBuffer,this.#fi=i.indexBuffer,this.#hi){const{interleavedStruct:i}=this.#hi;this.#Bi=new GeometryGPURenderInfo([{arrayStride:i.arrayStride,attributes:i.attributes}])}}}Object.freeze(Primitive);const createPrimitiveGeometry=(i,g,x,_)=>new Geometry(i,new VertexBuffer(i,new Float32Array(g),Primitive.primitiveInterleaveStruct,void 0,`VertexBuffer_${_}`),new IndexBuffer(i,new Uint32Array(x),void 0,`IndexBuffer_${_}`));class Plane extends Primitive{#Ii=function(){const i=[],g=[];return function(x,_,v,b,y,S,w,L){const k=v/2,H=b/2,z=Math.floor(y)||1,q=Math.floor(S)||1,W=z+1,be=q+1,Ke=v/z,Xe=b/q;i.length=0,g.length=0;for(let x=0;x0?1:-1,b[0]=0,b[1]=0),lookAt(this.#kt,_,v,b)}}class OrthographicCamera extends PerspectiveCamera{#f;#h;#Oi=1;#Ni=-1;#Vi=-1;#Fi=1;#Hi=1;#zi=.1;#$i=10;constructor(){super(),this.nearClipping=.01,this.farClipping=1e4}get top(){return this.#Oi}set top(i){validateNumber(i),this.#Oi=i}get bottom(){return this.#Ni}set bottom(i){validateNumber(i),this.#Ni=i}get left(){return this.#Vi}set left(i){validateNumber(i),this.#Vi=i}get right(){return this.#Fi}set right(i){validateNumber(i),this.#Fi=i}get zoom(){return this.#Hi}set zoom(i){validateNumberRange(i,this.#zi,this.#$i),this.#Hi=i}get minZoom(){return this.#zi}set minZoom(i){validateNumberRange(i,.01),this.#zi=i}get maxZoom(){return this.#$i}set maxZoom(i){validateNumberRange(i,.01),this.#$i=i}get name(){return this.#f||(this.#f=InstanceIdGenerator.getNextId(this.constructor)),this.#h||`${this.constructor.name} Instance ${this.#f}`}set name(i){this.#h=i}setZoom(i){this.zoom=i}}class AController{static#Ki=null;static#Xi=null;#f;#h;#l;#ji;#Yi;#qi=-1;#Wi=0;#Zi=new Set;#Ji=!1;#Qi=null;#ea=!1;#ta;#na=0;#ra=0;#ia=0;#aa=!1;constructor(i,g){this.#l=i,this.#Yi=g||{},this.#ji=g.camera||new PerspectiveCamera;const x=this.#l.detector.isMobile;this.#ta={moveKey:x?"touchmove":"mousemove",upKey:x?"touchend":"mouseup",downKey:x?"touchstart":"mousedown"},this.#sa()}get name(){return this.#f||(this.#f=InstanceIdGenerator.getNextId(this.constructor)),this.#h||`${this.constructor.name} Instance ${this.#f}`}set name(i){this.#h=i}get redGPUContext(){return this.#l}get camera(){return this.#ji}get x(){return this.camera.x}get y(){return this.camera.y}get z(){return this.camera.z}get hoveredView(){return this.#Qi}get keyboardActiveView(){return AController.#Ki}set keyboardActiveView(i){AController.#Ki=i,AController.#Xi=null===i?null:this}get isKeyboardActiveController(){return AController.#Xi===this}get keyboardProcessedThisFrame(){return this.#Ji}set keyboardProcessedThisFrame(i){this.#Ji=i}destroy(){const{moveKey:i,upKey:g,downKey:x}=this.#ta,{htmlCanvas:_}=this.redGPUContext;_.removeEventListener(x,this.#oa),_.removeEventListener(i,this.#ua),_.removeEventListener(i,this.#la),window.removeEventListener(g,this.#ca),this.#Yi.HD_Wheel&&_.removeEventListener("wheel",this.#ha)}update(i,g,x){this.#qi!==g&&(this.#Wi=-1===this.#qi?0:(g-this.#qi)/1e3,this.#qi=g,this.#Zi.clear(),this.#Ji=!1),this.#Zi.has(i)||(this.#Zi.add(i),this.#Yi.useKeyboard&&this.keyboardActiveView&&this.keyboardActiveView!==i||x?.(this.#Wi))}checkKeyboardInput(i,g){if(this.keyboardProcessedThisFrame)return!1;const{keyboardKeyBuffer:x}=i.redGPUContext;let _=!1;for(const i in g)if(x[g[i]]){_=!0;break}if(!_)return this.keyboardActiveView=null,!1;if(!this.keyboardActiveView){if(this.hoveredView!==i)return!1;this.keyboardActiveView=i}return this.keyboardActiveView===i&&(this.keyboardProcessedThisFrame=!0,!0)}getCanvasEventPoint=(i,g)=>{g.htmlCanvas;const x=g.detector.isMobile,_=g.boundingClientRect,v="clientX",b="clientY";let y,S;if(x){const g=i instanceof WheelEvent?i:i.changedTouches[0];y=g[v],S=g[b]}else{const g=i;y=g[v],S=g[b]}return{x:y-_.left,y:S-_.top}};findTargetViewByInputEvent=i=>{const g=this.#l;g.detector.isMobile;const{x:x,y:_}=this.getCanvasEventPoint(i,g),v=window.devicePixelRatio*g.renderScale,b=x*v,y=_*v;let S=null;for(const i of this.redGPUContext.viewList){const g=i.pixelRectObject;g.x{if(i.length<2)return 0;const g=i[0].clientX-i[1].clientX,x=i[0].clientY-i[1].clientY;return Math.sqrt(g*g+x*x)};#sa(){const{redGPUContext:i}=this,{htmlCanvas:g}=i,{downKey:x,moveKey:_}=this.#ta;g.addEventListener(x,this.#oa),g.addEventListener(_,this.#ua),this.#Yi.HD_Wheel&&g.addEventListener("wheel",this.#ha,{passive:!1}),this.#Yi.HD_TouchPinch&&g.addEventListener("touchmove",this.#da,{passive:!1})}#ua=i=>{AController.#Ki||this.#ea||(this.#Qi=this.findTargetViewByInputEvent(i))};#oa=i=>{const g=this.findTargetViewByInputEvent(i);if(!g)return;AController.#Ki||this.#ea||(this.#Qi=g);const{redGPUContext:x}=this,{moveKey:_,upKey:v}=this.#ta,{x:b,y:y}=this.getCanvasEventPoint(i,x);this.#na=b,this.#ra=y,i instanceof TouchEvent&&(i.touches.length>=2?(this.#aa=!0,this.#ia=this.#fa(i.touches)):(this.#aa=!1,this.#ia=0)),this.#Zi.has(g)&&(this.#ea=!0,AController.#Ki=g,x.htmlCanvas.addEventListener(_,this.#la),window.addEventListener(v,this.#ca))};#la=i=>{if(i instanceof TouchEvent&&i.touches.length>=2)return void(this.#aa=!0);this.#aa=!1;const{x:g,y:x}=this.getCanvasEventPoint(i,this.#l),_=g-this.#na,v=x-this.#ra;this.#na=g,this.#ra=x,this.#Yi.HD_Move?.(_,v)};#da=i=>{if(i.touches.length<2||!this.#Yi.HD_TouchPinch)return;if(!this.#aa)return;i.preventDefault();const g=this.#fa(i.touches);if(0===this.#ia)return void(this.#ia=g);if(this.findTargetViewByInputEvent(i).rawCamera!==this.#ji)return;const x=g/this.#ia;this.#Yi.HD_TouchPinch?.(x),this.#ia=g};#ca=()=>{const{htmlCanvas:i}=this.#l,{moveKey:g,upKey:x}=this.#ta;this.#aa=!1,this.#ia=0,this.#ea=!1,i.removeEventListener(g,this.#la),window.removeEventListener(x,this.#ca)};#ha=i=>{const g=this.findTargetViewByInputEvent(i);g&&g.rawCamera===this.#ji&&(i.stopPropagation(),i.preventDefault(),this.#Yi.HD_Wheel?.(i))}}const Ur=Math.PI/180;class IsometricController extends AController{#ma=45;#pa=1;#ga=1;#xa=.1;#_a=.1;#zi=.5;#$i=3;#va=15;#ba=15;#ya=.1;#Sa=null;#Ta=0;#Ma=0;#wa=50;#Ca=.1;#Ra={moveUp:"w",moveDown:"s",moveLeft:"a",moveRight:"d"};#Pa=1;#Ba=.1;constructor(i){super(i,{camera:new OrthographicCamera,HD_Wheel:i=>{this.#ga-=i.deltaY/100*this.#_a,this.#ga=Math.max(this.#zi,Math.min(this.#$i,this.#ga))},HD_Move:(g,x)=>{if(!this.#Sa)return;const _=this.#ma*Ur,v=Math.cos(_),b=Math.sin(_),y=this.#va/this.#pa/i.boundingClientRect.height,S=g*y,w=x*y,L=-S*v-w*b,k=-S*-b-w*v;this.#Ta+=L,this.#Ma+=k},HD_TouchPinch:i=>{this.#ga/=i,this.#ga=Math.max(this.#zi,Math.min(this.#$i,this.#ga))},useKeyboard:!0}),this.#Sa=new Mesh(i),this.#Sa.setIgnoreFrustumCullingRecursively(!0)}get zoom(){return this.#ga}set zoom(i){validateNumberRange(i),this.#ga=Math.max(this.#zi,Math.min(this.#$i,i))}get zoomInterpolation(){return this.#xa}set zoomInterpolation(i){validateNumberRange(i,1e-4,1),this.#xa=i}get speedZoom(){return this.#_a}set speedZoom(i){validateNumberRange(i,.01),this.#_a=i}get minZoom(){return this.#zi}set minZoom(i){validateNumberRange(i,.01),this.#zi=i,this.zoom=this.#ga}get maxZoom(){return this.#$i}set maxZoom(i){validateNumberRange(i,.01),this.#$i=i,this.zoom=this.#ga}get viewHeight(){return this.#ba}set viewHeight(i){validateNumberRange(i,.1),this.#ba=i}get viewHeightInterpolation(){return this.#ya}set viewHeightInterpolation(i){validateNumberRange(i,1e-4,1),this.#ya=i}get moveSpeed(){return this.#wa}set moveSpeed(i){validateNumberRange(i,.01),this.#wa=i}get moveSpeedInterpolation(){return this.#Ca}set moveSpeedInterpolation(i){validateNumberRange(i,1e-4,1),this.#Ca=i}get mouseMoveSpeed(){return this.#Pa}set mouseMoveSpeed(i){validateNumberRange(i,.01),this.#Pa=i}get mouseMoveSpeedInterpolation(){return this.#Ba}set mouseMoveSpeedInterpolation(i){validateNumberRange(i,1e-4,1),this.#Ba=i}get keyNameMapper(){return{...this.#Ra}}get targetX(){return this.#Sa.x}get targetY(){return this.#Sa.y}get targetZ(){return this.#Sa.z}setMoveUpKey(i){this.#Ra.moveUp=i}setMoveDownKey(i){this.#Ra.moveDown=i}setMoveLeftKey(i){this.#Ra.moveLeft=i}setMoveRightKey(i){this.#Ra.moveRight=i}update(i,g){super.update(i,g,g=>{this.#Ia(i,g)})}#Ia(i,g){if(this.#Ea(i,g),this.#pa=this.#ga+(this.#pa-this.#ga)*Math.pow(this.#xa,g),this.#va=this.#ba+(this.#va-this.#ba)*Math.pow(this.#ya,g),!this.#Sa)return;const x=Math.pow(this.#Ca,g);this.#Sa.x=this.#Ta+(this.#Sa.x-this.#Ta)*x,this.#Sa.z=this.#Ma+(this.#Sa.z-this.#Ma)*x;const _=this.#Sa.position,v=this.#ma*Ur,{width:b,height:y}=i.pixelRectObject,S=b/y,w=this.#va/this.#pa,L=w*S,k=this.#va/15,H=15*k/this.#pa,z=12*k/this.#pa,q=_[0]+Math.cos(v)*H,W=_[1]+z,be=_[2]+Math.sin(v)*H;this.camera.setPosition(q,W,be),this.camera.lookAt(_[0],_[1],_[2]);const Ke=this.camera;Ke.left=-L/2,Ke.right=L/2,Ke.top=w/2,Ke.bottom=-w/2}#Ea(i,g){if(!this.checkKeyboardInput(i,this.#Ra))return!1;if(!this.#Sa)return!1;const{keyboardKeyBuffer:x}=i.redGPUContext,_=this.#Ra,v=this.#wa*g;let b=0,y=0,S=0,w=0;x[_.moveUp]&&(b=v),x[_.moveDown]&&(y=v),x[_.moveLeft]&&(S=v),x[_.moveRight]&&(w=v);const L=this.#ma*Ur,k=Math.cos(L),H=Math.sin(L),z=(y-b)*k+(w-S)*k,q=(y-b)*H+(w-S)*-H;return this.#Ta+=z,this.#Ma+=q,!0}}class DrawBufferManager{static#Da;static#Ua=5;#l;#La=[];#Aa=[];#Ga;#ka=0;#Oa=0;#Na;#Va=new Set;constructor(i){this.#l=i,this.#Fa()}static getInstance(i){return DrawBufferManager.#Da||(DrawBufferManager.#Da=new DrawBufferManager(i)),DrawBufferManager.#Da}allocateDrawCommand(i){this.#Oa>=this.#Ga&&(this.#ka=this.#Ha(),this.#Oa=0),this.#Va.add(this.#ka);const g={bufferIndex:this.#ka,commandOffset:this.#Oa*DrawBufferManager.#Ua,buffer:this.#La[this.#ka],dataArray:this.#Aa[this.#ka]};return this.#Oa++,g}setIndexedIndirectCommand(i,g,x=1,_=0,v=0,b=0){const y=i.commandOffset,S=i.dataArray;S[y]=g,S[y+1]=x,S[y+2]=_,S[y+3]=v,S[y+4]=b}setInstanceNum(i,g=0){const x=i.commandOffset;i.dataArray[x+1]=g}setIndirectCommand(i,g,x=1,_=0,v=0){const b=i.commandOffset,y=i.dataArray;y[b]=g,y[b+1]=x,y[b+2]=_,y[b+3]=v}updateSingleCommand(i){const g=this.#La[i.bufferIndex],x=this.#Aa[i.bufferIndex],_=DrawBufferManager.#Ua,v=4*i.commandOffset,b=_;this.#l.gpuDevice.queue.writeBuffer(g,v,x,i.commandOffset,b)}getTotalCommandCount(){let i=0;for(const g of this.#Va)g===this.#ka?i+=this.#Oa:i+=this.#Ga;return i}getMemoryUsage(){const i=this.#La.length,g=this.#Va.size,x=i*this.#Na,_=g*this.#Na;return{totalBuffers:i,usedBuffers:g,maxCommandsPerBuffer:this.#Ga,totalMemory:formatBytes(x),usedMemory:formatBytes(_),totalCommands:this.getTotalCommandCount()}}flushAllCommands(i){performance.now();for(const i of this.#Va){const g=this.#La[i],x=this.#Aa[i],_=(i===this.#ka?this.#Oa:this.#Ga)*DrawBufferManager.#Ua*4;this.#l.gpuDevice.queue.writeBuffer(g,0,x,0,_/4)}performance.now()}#Fa(){this.#za(),this.#$a()}#za(){this.#l.gpuDevice.limits,this.#Na=Math.floor(.9*Math.min(268435456,134217728)),this.#Ga=Math.floor(this.#Na/(4*DrawBufferManager.#Ua))}#$a(){this.#Ha()}#Ha(){const i=this.#Ga*DrawBufferManager.#Ua*4,g=this.#l.gpuDevice.createBuffer({size:i,usage:GPUBufferUsage.INDIRECT|GPUBufferUsage.COPY_DST,label:`DrawBuffer_${this.#La.length}`}),x=new Uint32Array(this.#Ga*DrawBufferManager.#Ua);return this.#La.push(g),this.#Aa.push(x),this.#La.length-1}}create$3(),create$3();const calculateMeshAABB=i=>{if(!i||!i._geometry){const g=i.modelMatrix;return g[12],g[13],g[14],new AABB(0,0,0,0,0,0)}const g=i._geometry.volume,{minX:x,maxX:_,minY:v,maxY:b,minZ:y,maxZ:S}=g;let w=1/0,L=1/0,k=1/0,H=-1/0,z=-1/0,q=-1/0;const W=i.modelMatrix;for(let i=0;i<8;i++){const g=1&i?_:x,be=2&i?b:v,Ke=4&i?S:y,Xe=W[0]*g+W[4]*be+W[8]*Ke+W[12],je=W[1]*g+W[5]*be+W[9]*Ke+W[13],Ye=W[2]*g+W[6]*be+W[10]*Ke+W[14];XeH&&(H=Xe),je>z&&(z=je),Ye>q&&(q=Ye)}return new AABB(w,H,L,z,k,q)},calculateMeshCombinedAABB=i=>{const g=[];return collectRecursive(i,g),0===g.length?new AABB(0,0,0,0,0,0):calculateCombinedAABBFromAABBs(g)},collectRecursive=(i,g)=>{if(i._geometry){const x=i.boundingAABB;g.push(x)}if(i.children)for(let x=0;x{if(0===i.length)return new AABB(0,0,0,0,0,0);if(1===i.length)return i[0];let g=1/0,x=1/0,_=1/0,v=-1/0,b=-1/0,y=-1/0;for(let S=0;Sv&&(v=w.maxX),w.maxY>b&&(b=w.maxY),w.maxZ>y&&(y=w.maxZ)}return new AABB(g,v,x,b,_,y)};class OBB{centerX;centerY;centerZ;halfExtentX;halfExtentY;halfExtentZ;orientation;center;halfExtents;geometryRadius;constructor(i,g,x){this.centerX=i[0],this.centerY=i[1],this.centerZ=i[2],this.halfExtentX=g[0],this.halfExtentY=g[1],this.halfExtentZ=g[2],this.center=[this.centerX,this.centerY,this.centerZ],this.halfExtents=[this.halfExtentX,this.halfExtentY,this.halfExtentZ],this.orientation=clone$4(x),this.geometryRadius=Math.sqrt(this.halfExtentX**2+this.halfExtentY**2+this.halfExtentZ**2)}intersects(i){i instanceof OBB||consoleAndThrowError("allow only OBB instance");const g=subtract$2(create$3(),this.center,i.center);if(length$3(g)>this.geometryRadius+i.geometryRadius)return!1;const x=[...this.#Ka(),...i.#Ka()];for(const _ of x){const x=this.#Xa(_),v=i.#Xa(_);if(Math.abs(dot$3(g,_))>x+v)return!1}return!0}contains(i,g,x){let _;_=Array.isArray(i)?fromValues$3(i[0],i[1],i[2]):fromValues$3(i,g,x);const v=subtract$2(create$3(),_,this.center),b=this.#Ka();for(let i=0;i<3;i++){const g=dot$3(v,b[i]);if(Math.abs(g)>this.halfExtents[i])return!1}return!0}clone(){return new OBB([this.centerX,this.centerY,this.centerZ],[this.halfExtentX,this.halfExtentY,this.halfExtentZ],this.orientation)}#Ka(){return[fromValues$3(this.orientation[0],this.orientation[1],this.orientation[2]),fromValues$3(this.orientation[4],this.orientation[5],this.orientation[6]),fromValues$3(this.orientation[8],this.orientation[9],this.orientation[10])]}#Xa(i){const g=this.#Ka();return Math.abs(dot$3(g[0],i))*this.halfExtentX+Math.abs(dot$3(g[1],i))*this.halfExtentY+Math.abs(dot$3(g[2],i))*this.halfExtentZ}}const calculateMeshOBB=i=>{if(!i||!i._geometry){const i=create$4();return new OBB([0,0,0],[0,0,0],i)}const g=i._geometry.volume;if(0===g.minX&&0===g.maxX&&0===g.minY&&0===g.maxY&&0===g.minZ&&0===g.maxZ){const i=create$4();return new OBB([0,0,0],[0,0,0],i)}const x=[g.centerX,g.centerY,g.centerZ],_=[(g.maxX-g.minX)/2,(g.maxY-g.minY)/2,(g.maxZ-g.minZ)/2],v=create$3();transformMat4$2(v,x,i.modelMatrix);const b=create$4();copy$4(b,i.modelMatrix),b[12]=0,b[13]=0,b[14]=0;const y=[create$3(),create$3(),create$3()],S=[0,0,0];for(let i=0;i<3;i++){const g=[0,0,0];g[i]=_[i],transformMat4$2(y[i],g,b),S[i]=length$3(y[i]),normalize$3(y[i],y[i])}const w=create$4();return w[0]=y[0][0],w[1]=y[0][1],w[2]=y[0][2],w[3]=0,w[4]=y[1][0],w[5]=y[1][1],w[6]=y[1][2],w[7]=0,w[8]=y[2][0],w[9]=y[2][1],w[10]=y[2][2],w[11]=0,w[12]=0,w[13]=0,w[14]=0,w[15]=1,new OBB([v[0],v[1],v[2]],S,w)},mat4ToEuler=(i,g,x)=>{g=g||[0,0,0],x=x||"XYZ";let _=i[0],v=i[4],b=i[8],y=i[1],S=i[5],w=i[9],L=i[2],k=i[6],H=i[10];return"XYZ"===x?(g[1]=Math.asin(clamp(b,-1,1)),Math.abs(b)<.99999?(g[0]=Math.atan2(-w,H),g[2]=Math.atan2(-v,_)):(g[0]=Math.atan2(k,S),g[2]=0)):"YXZ"===x?(g[0]=Math.asin(-clamp(w,-1,1)),Math.abs(w)<.99999?(g[1]=Math.atan2(b,H),g[2]=Math.atan2(y,S)):(g[1]=Math.atan2(-L,_),g[2]=0)):"ZXY"===x?(g[0]=Math.asin(clamp(k,-1,1)),Math.abs(k)<.99999?(g[1]=Math.atan2(-L,H),g[2]=Math.atan2(-v,S)):(g[1]=0,g[2]=Math.atan2(y,_))):"ZYX"===x?(g[1]=Math.asin(-clamp(L,-1,1)),Math.abs(L)<.99999?(g[0]=Math.atan2(k,H),g[2]=Math.atan2(y,_)):(g[0]=0,g[2]=Math.atan2(-v,S))):"YZX"===x?(g[2]=Math.asin(clamp(y,-1,1)),Math.abs(y)<.99999?(g[0]=Math.atan2(-w,S),g[1]=Math.atan2(-L,_)):(g[0]=0,g[1]=Math.atan2(b,H))):"XZY"===x&&(g[2]=Math.asin(-clamp(v,-1,1)),Math.abs(v)<.99999?(g[0]=Math.atan2(k,S),g[1]=Math.atan2(b,_)):(g[0]=Math.atan2(-w,H),g[1]=0)),g};let clamp=function(i,g,x){return Math.max(g,Math.min(x,i))};const Lr={POINT_LIST:"point-list",LINE_LIST:"line-list",LINE_STRIP:"line-strip",TRIANGLE_LIST:"triangle-list",TRIANGLE_STRIP:"triangle-strip"};Object.freeze(Lr);const Ar=parseWGSL("#redgpu_include drawPicking;\n#redgpu_include calcTintBlendMode;\n#redgpu_include FragmentOutput;\n#redgpu_include calculateMotionVector;\nstruct Uniforms { color:vec3, opacity:f32, useTint:u32, tint:vec4, tintBlendMode:u32,\n};\nstruct InputData { @builtin(position) position:vec4, @location(7) currentClipPos:vec4, @location(8) prevClipPos:vec4, @location(11) combinedOpacity:f32, @location(12) motionVector:vec3, @location(15) @interpolate(flat) pickingId:vec4,\n}\n@group(2) @binding(0) var uniforms:Uniforms;\n@fragment\nfn main(inputData:InputData) -> FragmentOutput { var output:FragmentOutput; var finalColor=vec4( uniforms.color.r,uniforms.color.g,uniforms.color.b,uniforms.opacity * inputData.combinedOpacity); #redgpu_if useTint finalColor=calcTintBlendMode(finalColor,uniforms.tintBlendMode,uniforms.tint); #redgpu_endIf if (finalColor.a==0.0) { discard; } output.color=finalColor; output.gBufferMotionVector=vec4(calculateMotionVector(inputData.currentClipPos,inputData.prevClipPos),0.0,1.0 ); return output;\n}\n");class ColorMaterial extends ABaseMaterial{constructor(i,g="#fff"){super(i,"COLOR_MATERIAL",Ar,2),this.initGPURenderInfos(),this.color.setColorByHEX(g)}}dr.defineByPreset(ColorMaterial,[dr.PRESET_COLOR_RGB.COLOR]),Object.freeze(ColorMaterial);class DrawDebuggerMesh{#l;#ja;#hi;#Ya;#qa;#Wa="AABB";#Za;#Ja;#Qa=null;#es=null;constructor(i,g){this.#l=i,this.#ja=g;const x=this.#ts(i);this.#hi=x.vertexBuffer,this.#Ya=new ColorMaterial(i),this.#Ya.color.setColorByRGB(255,0,0),this.#qa=new Mesh(i,x,this.#Ya),this.#qa.primitiveState.cullMode="none",this.#qa.primitiveState.topology=Lr.LINE_LIST;const _=this.#ts(i);this.#Za=new ColorMaterial(i),this.#Za.color.setColorByRGB(0,255,0),this.#Ja=new Mesh(i,_,this.#Za),this.#Ja.primitiveState.cullMode="none",this.#Ja.primitiveState.topology=Lr.LINE_LIST}get debugMode(){return this.#Wa}set debugMode(i){this.#Wa=i,"OBB"===i?this.#Ya.color.setColorByRGB(255,0,0):"AABB"===i||"COMBINED_AABB"===i?this.#Ya.color.setColorByRGB(0,255,0):"BOTH"===i&&(this.#Ya.color.setColorByRGB(255,0,0),this.#Za.color.setColorByRGB(0,255,0)),this.#Qa=null,this.#es=null}render(i){if(!this.#ja.enableDebugger)return;if("OBB"===this.#Wa){const i=this.#ja.boundingOBB;this.#ns(i)&&(this.#rs(i,this.#hi),this.#is(i)),this.#qa.setPosition(0,0,0),this.#qa.setRotation(0,0,0),this.#qa.setScale(1,1,1)}else if("AABB"===this.#Wa||"COMBINED_AABB"===this.#Wa){const i="COMBINED_AABB"===this.#Wa?this.#ja.combinedBoundingAABB:this.#ja.boundingAABB;this.#as(i)&&(this.#ss(i,this.#hi),this.#os(i)),this.#qa.setPosition(0,0,0),this.#qa.setRotation(0,0,0),this.#qa.setScale(1,1,1)}else if("BOTH"===this.#Wa){const i=this.#ja.boundingOBB,g=this.#ja.boundingAABB;this.#ns(i)&&(this.#rs(i,this.#hi),this.#is(i)),this.#qa.setPosition(0,0,0),this.#qa.setRotation(0,0,0),this.#qa.setScale(1,1,1),this.#as(g)&&(this.#ss(g,this.#Ja.geometry.vertexBuffer),this.#os(g)),this.#Ja.setPosition(0,0,0),this.#Ja.setRotation(0,0,0),this.#Ja.setScale(1,1,1)}let g=!0,x=!0;{const{frustumPlanes:_}=i,v=_[0],b=_[1],y=_[2],S=_[3],w=_[4],L=_[5];{const i=this.#ja.boundingAABB,x=i.centerX,_=i.centerY,k=i.centerZ,H=i.geometryRadius;(v[0]*x+v[1]*_+v[2]*k+v[3]<=-H||b[0]*x+b[1]*_+b[2]*k+b[3]<=-H||y[0]*x+y[1]*_+y[2]*k+y[3]<=-H||S[0]*x+S[1]*_+S[2]*k+S[3]<=-H||w[0]*x+w[1]*_+w[2]*k+w[3]<=-H||L[0]*x+L[1]*_+L[2]*k+L[3]<=-H)&&(g=!1)}{const i=this.#ja.boundingOBB,g=i.centerX,_=i.centerY,k=i.centerZ,H=i.geometryRadius;(v[0]*g+v[1]*_+v[2]*k+v[3]<=-H||b[0]*g+b[1]*_+b[2]*k+b[3]<=-H||y[0]*g+y[1]*_+y[2]*k+y[3]<=-H||S[0]*g+S[1]*_+S[2]*k+S[3]<=-H||w[0]*g+w[1]*_+w[2]*k+w[3]<=-H||L[0]*g+L[1]*_+L[2]*k+L[3]<=-H)&&(x=!1)}}"OBB"===this.#Wa?x&&this.#qa.render(i):"AABB"===this.#Wa||"COMBINED_AABB"===this.#Wa?g&&this.#qa.render(i):"BOTH"===this.#Wa&&(x&&this.#qa.render(i),g&&this.#Ja.render(i))}#ts(i){const g=new Float32Array(192),x=new VertexInterleavedStruct({vertexPosition:VertexInterleaveType.float32x3,vertexNormal:VertexInterleaveType.float32x3,texcoord:VertexInterleaveType.float32x2},`wireframeBoxStruct_${Math.random()}`),_=new VertexBuffer(i,g,x);return new Geometry(i,_)}#ns(i){if(!this.#Qa)return!0;const g=this.#Qa;return g.center[0]!==i.center[0]||g.center[1]!==i.center[1]||g.center[2]!==i.center[2]||g.halfExtents[0]!==i.halfExtents[0]||g.halfExtents[1]!==i.halfExtents[1]||g.halfExtents[2]!==i.halfExtents[2]||!this.#us(g.orientation,i.orientation)}#as(i){if(!this.#es)return!0;const g=this.#es;return g.minX!==i.minX||g.maxX!==i.maxX||g.minY!==i.minY||g.maxY!==i.maxY||g.minZ!==i.minZ||g.maxZ!==i.maxZ}#us(i,g){if(i.length!==g.length)return!1;for(let x=0;x1e-4)return!1;return!0}#is(i){this.#Qa=new OBB(i.center,i.halfExtents,i.orientation)}#os(i){this.#es=i.clone()}#rs(i,g){const{center:x,halfExtents:_,orientation:v}=i,b=[[-1,-1,-1],[1,-1,-1],[1,1,-1],[-1,1,-1],[-1,-1,1],[1,-1,1],[1,1,1],[-1,1,1]].map(i=>{const g=[i[0]*_[0],i[1]*_[1],i[2]*_[2]],b=[v[0]*g[0]+v[4]*g[1]+v[8]*g[2],v[1]*g[0]+v[5]*g[1]+v[9]*g[2],v[2]*g[0]+v[6]*g[1]+v[10]*g[2]];return[b[0]+x[0],b[1]+x[1],b[2]+x[2]]});this.#mi(b,g)}#ss(i,g){const{minX:x,maxX:_,minY:v,maxY:b,minZ:y,maxZ:S}=i,w=[[x,v,y],[_,v,y],[_,b,y],[x,b,y],[x,v,S],[_,v,S],[_,b,S],[x,b,S]];this.#mi(w,g)}#mi(i,g){const x=g.data;let _=0;[[0,1],[1,2],[2,3],[3,0],[4,5],[5,6],[6,7],[7,4],[0,4],[1,5],[2,6],[3,7]].forEach(([g,v])=>{x[_++]=i[g][0],x[_++]=i[g][1],x[_++]=i[g][2],x[_++]=0,x[_++]=0,x[_++]=1,x[_++]=0,x[_++]=0,x[_++]=i[v][0],x[_++]=i[v][1],x[_++]=i[v][2],x[_++]=0,x[_++]=0,x[_++]=1,x[_++]=0,x[_++]=0}),g.updateAllData(x)}}Object.freeze(DrawDebuggerMesh);const Gr={MESH:"mesh",PARTICLE:"particle",INSTANCED_MESH:"instancedMesh"};Object.freeze(Gr);const createMeshVertexUniformBuffers=(i,g=!1)=>{const{gpuRenderInfo:x,redGPUContext:_}=i,{resourceManager:v}=_,b=v.getGPUBindGroupLayout(g?ResourceManager.PRESET_VERTEX_GPUBindGroupLayout_SKIN:ResourceManager.PRESET_VERTEX_GPUBindGroupLayout),y=new ArrayBuffer(x.vertexUniformInfo.arrayBufferByteLength),S=new UniformBuffer(_,y,i.name);x.vertexBindGroupLayout=b,x.vertexUniformBuffer=S};const kr=[{textureList:["baseColorTexture"],vec4List:[["baseColorFactor",[1,1,1,1]]]},{textureList:["normalTexture"]},{textureList:["metallicRoughnessTexture"],positiveNumberList:["metallicFactor","roughnessFactor"]},{textureList:["emissiveTexture"],vec3List:["emissiveFactor"]},{textureList:["occlusionTexture"],positiveNumberList:["occlusionStrength"]},{extensionName:"KHR_materials_clearcoat",textureList:["KHR_clearcoatTexture","KHR_clearcoatNormalTexture","KHR_clearcoatRoughnessTexture"],positiveNumberList:[["KHR_clearcoatFactor",0],["KHR_clearcoatRoughnessFactor",0],"KHR_clearcoatNormalScale"]},{extensionName:"KHR_materials_sheen",textureList:["KHR_sheenColorTexture","KHR_sheenRoughnessTexture"],positiveNumberList:[["KHR_sheenRoughnessFactor",0]],vec3List:[["KHR_sheenColorFactor",[0,0,0]]]},{extensionName:"KHR_materials_specular",textureList:["KHR_specularTexture","KHR_specularColorTexture"],positiveNumberList:["KHR_specularFactor"],vec3List:[["KHR_specularColorFactor",[1,1,1]]]},{extensionName:"KHR_materials_transmission",textureList:["KHR_transmissionTexture"],positiveNumberList:[["KHR_transmissionFactor",0]]},{extensionName:"KHR_materials_volume",textureList:["KHR_thicknessTexture"],positiveNumberList:[["KHR_thicknessFactor",0],["KHR_attenuationDistance",1]],vec3List:[["KHR_attenuationColor",[1,1,1]]]},{extensionName:"KHR_materials_diffuse_transmission",textureList:["KHR_diffuseTransmissionTexture","KHR_diffuseTransmissionColorTexture"],positiveNumberList:[["KHR_diffuseTransmissionFactor",0]],vec3List:[["KHR_diffuseTransmissionColorFactor",[1,1,1]]]},{extensionName:"KHR_materials_anisotropy",textureList:["KHR_anisotropyTexture"],positiveNumberList:[["KHR_anisotropyStrength",0],["KHR_anisotropyRotation",0]]},{extensionName:"KHR_materials_iridescence",textureList:["KHR_iridescenceTexture","KHR_iridescenceThicknessTexture"],positiveNumberList:[["KHR_iridescenceFactor",0],["KHR_iridescenceIor",1.3],["KHR_iridescenceThicknessMinimum",100],["KHR_iridescenceThicknessMaximum",400]]}],Or=parseWGSL((i=>{const g=kr.map(i=>{const{textureList:g,positiveNumberList:x}=i,_=g?.map(i=>` use${i.charAt(0).toUpperCase()}${i.substring(1)}:u32, ${i}_texCoord_index:u32, use_${i}_KHR_texture_transform:u32, ${i}_KHR_texture_transform_offset:vec2, ${i}_KHR_texture_transform_scale:vec2, ${i}_KHR_texture_transform_rotation:f32,`).join("");return[_].join("\n")}).join("");return i.replace(/#redgpu_include KHR_texture_transform/g,g)})("#redgpu_include SYSTEM_UNIFORM;\n#redgpu_include calcDirectionalShadowVisibility;\n#redgpu_include calcTintBlendMode;\n#redgpu_include normalFunctions;\n#redgpu_include drawPicking;\n#redgpu_include calcPrePathBackground\n#redgpu_include FragmentOutput\n#redgpu_include calculateMotionVector;\nstruct Uniforms { useVertexColor:u32, useCutOff:u32, cutOff:f32, alphaBlend:u32, doubleSided:u32, useVertexTangent:u32, opacity:f32, useTint:u32, tint:vec4, tintBlendMode:u32, baseColorFactor:vec4, emissiveFactor:vec3, emissiveStrength:f32, occlusionStrength:f32, metallicFactor:f32, roughnessFactor:f32, normalScale:f32, useKHR_materials_unlit:u32, KHR_materials_ior:f32, useKHR_materials_transmission:u32, KHR_transmissionFactor:f32, useKHR_materials_diffuse_transmission:u32, KHR_diffuseTransmissionFactor:f32, KHR_diffuseTransmissionColorFactor:vec3, KHR_dispersion:f32, useKHR_materials_volume:u32, KHR_thicknessFactor:f32, KHR_attenuationDistance:f32, KHR_attenuationColor:vec3, useKHR_materials_specular:u32, KHR_specularFactor:f32, KHR_specularColorFactor:vec3, useKHR_materials_anisotropy:u32, KHR_anisotropyStrength:f32, KHR_anisotropyRotation:f32, useKHR_materials_iridescence:u32, KHR_iridescenceFactor:f32, KHR_iridescenceIor:f32, KHR_iridescenceThicknessMinimum:f32, KHR_iridescenceThicknessMaximum:f32, useKHR_materials_sheen:u32, KHR_sheenColorFactor:vec3, KHR_sheenRoughnessFactor:f32, useKHR_materials_clearcoat:u32, KHR_clearcoatFactor:f32, KHR_clearcoatRoughnessFactor:f32, KHR_clearcoatNormalScale:f32, #redgpu_include KHR_texture_transform\n};\n@group(2) @binding(0) var uniforms:Uniforms;\n@group(2) @binding(1) var baseColorTextureSampler:sampler;\n#redgpu_if baseColorTexture\n@group(2) @binding(2) var baseColorTexture:texture_2d;\n#redgpu_endIf\n#redgpu_if emissiveTexture\n@group(2) @binding(3) var emissiveTextureSampler:sampler;\n@group(2) @binding(4) var emissiveTexture:texture_2d;\n#redgpu_endIf\n#redgpu_if normalTexture\n@group(2) @binding(5) var normalTextureSampler:sampler;\n@group(2) @binding(6) var normalTexture:texture_2d;\n#redgpu_endIf\n#redgpu_if packedORMTexture\n@group(2) @binding(7) var packedORMTexture:texture_2d;\n#redgpu_endIf\n#redgpu_if useKHR_materials_specular\n@group(2) @binding(8) var KHR_specularTextureSampler:sampler;\n@group(2) @binding(9) var KHR_specularTexture:texture_2d;\n@group(2) @binding(10) var KHR_specularColorTextureSampler:sampler;\n@group(2) @binding(11) var KHR_specularColorTexture:texture_2d;\n#redgpu_endIf\n@group(2) @binding(12) var KHR_clearcoatNormalTexture:texture_2d;\n@group(2) @binding(13) var packedKHR_clearcoatTexture_transmission:texture_2d;\n#redgpu_if useKHR_materials_diffuse_transmission\n@group(2) @binding(14) var packedKHR_diffuse_transmission:texture_2d;\n#redgpu_endIf\n#redgpu_if useKHR_materials_sheen\n@group(2) @binding(15) var packedKHR_sheen:texture_2d;\n#redgpu_endIf\n#redgpu_if useKHR_materials_anisotropy\n@group(2) @binding(16) var KHR_anisotropyTexture:texture_2d;\n#redgpu_endIf\n#redgpu_if useKHR_materials_iridescence\n@group(2) @binding(17) var packedKHR_iridescence:texture_2d;\n#redgpu_endIf\nstruct InputData { @builtin(position) position:vec4, @location(0) vertexPosition:vec3, @location(1) vertexNormal:vec3, @location(2) uv:vec2, @location(3) uv1:vec2, @location(4) vertexColor_0:vec4, @location(5) vertexTangent:vec4, @location(7) currentClipPos:vec4, @location(8) prevClipPos:vec4, @location(10) localNodeScale_volumeScale:vec2, @location(11) combinedOpacity:f32, @location(12) motionVector:vec3, @location(13) shadowPos:vec3, @location(14) @interpolate(flat) receiveShadow:f32, @location(15) @interpolate(flat) pickingId:vec4,\n}\n@fragment\nfn main(inputData:InputData) -> FragmentOutput { var output:FragmentOutput; let input_vertexNormal=(inputData.vertexNormal.xyz); let input_vertexPosition=inputData.vertexPosition.xyz; let input_vertexColor_0=inputData.vertexColor_0; let input_vertexTangent=inputData.vertexTangent; let input_ndcPosition=inputData.position.xyz/inputData.position.w; let input_uv=inputData.uv; let input_uv1=inputData.uv1; let u_ambientLight=systemUniforms.ambientLight; let u_ambientLightColor=u_ambientLight.color; let u_ambientLightIntensity=u_ambientLight.intensity; let u_directionalLightCount=systemUniforms.directionalLightCount; let u_directionalLights=systemUniforms.directionalLights; let u_shadowDepthTextureSize=systemUniforms.shadowDepthTextureSize; let u_bias=systemUniforms.bias; let u_usePrefilterTexture=systemUniforms.usePrefilterTexture==1u; let receiveShadowYn=inputData.receiveShadow !=.0; let u_camera=systemUniforms.camera; let u_cameraMatrix=u_camera.cameraMatrix; let u_cameraPosition=u_camera.cameraPosition; let u_opacity=uniforms.opacity; let u_cutOff=uniforms.cutOff; let u_useVertexColor=uniforms.useVertexColor==1u; let u_useVertexTangent=uniforms.useVertexTangent==1u; let u_baseColorFactor=uniforms.baseColorFactor; let u_metallicFactor=uniforms.metallicFactor; let u_roughnessFactor=uniforms.roughnessFactor; let u_normalScale=uniforms.normalScale; let u_occlusionStrength=uniforms.occlusionStrength; let u_emissiveFactor=uniforms.emissiveFactor; let u_emissiveStrength=uniforms.emissiveStrength; let u_useKHR_materials_unlit=uniforms.useKHR_materials_unlit==1u; let u_KHR_materials_ior=uniforms.KHR_materials_ior; let u_KHR_dispersion=uniforms.KHR_dispersion; let u_KHR_transmissionFactor=uniforms.KHR_transmissionFactor; var u_useKHR_materials_volume=uniforms.useKHR_materials_volume==1u; var u_KHR_thicknessFactor=uniforms.KHR_thicknessFactor; var u_KHR_attenuationColor=uniforms.KHR_attenuationColor; var u_KHR_attenuationDistance=uniforms.KHR_attenuationDistance; let u_useKHR_materials_diffuse_transmission=uniforms.useKHR_materials_diffuse_transmission==1u; let u_KHR_diffuseTransmissionFactor=uniforms.KHR_diffuseTransmissionFactor; let u_KHR_diffuseTransmissionColorFactor=uniforms.KHR_diffuseTransmissionColorFactor; let u_KHR_specularFactor=uniforms.KHR_specularFactor; let u_KHR_specularColorFactor=uniforms.KHR_specularColorFactor; let u_KHR_anisotropyStrength=uniforms.KHR_anisotropyStrength; let u_KHR_anisotropyRotation=uniforms.KHR_anisotropyRotation; let u_useKHR_anisotropyTexture=uniforms.useKHR_anisotropyTexture==1u; let u_KHR_sheenColorFactor=uniforms.KHR_sheenColorFactor; let u_KHR_sheenRoughnessFactor=uniforms.KHR_sheenRoughnessFactor; let u_useKHR_materials_iridescence=uniforms.useKHR_materials_iridescence==1u; let u_KHR_iridescenceFactor=uniforms.KHR_iridescenceFactor; let u_KHR_iridescenceIor=uniforms.KHR_iridescenceIor; let u_KHR_iridescenceThicknessMinimum=uniforms.KHR_iridescenceThicknessMinimum; let u_KHR_iridescenceThicknessMaximum=uniforms.KHR_iridescenceThicknessMaximum; let u_KHR_clearcoatFactor=uniforms.KHR_clearcoatFactor; let u_KHR_clearcoatRoughnessFactor=uniforms.KHR_clearcoatRoughnessFactor; let u_KHR_clearcoatNormalScale=uniforms.KHR_clearcoatNormalScale; let diffuseUV=get_transformed_uv( input_uv,input_uv1, uniforms.baseColorTexture_texCoord_index, uniforms.use_baseColorTexture_KHR_texture_transform, uniforms.baseColorTexture_KHR_texture_transform_offset, uniforms.baseColorTexture_KHR_texture_transform_rotation, uniforms.baseColorTexture_KHR_texture_transform_scale ); let emissiveUV=get_transformed_uv( input_uv,input_uv1, uniforms.emissiveTexture_texCoord_index, uniforms.use_emissiveTexture_KHR_texture_transform, uniforms.emissiveTexture_KHR_texture_transform_offset, uniforms.emissiveTexture_KHR_texture_transform_rotation, uniforms.emissiveTexture_KHR_texture_transform_scale ); let occlusionUV=get_transformed_uv( input_uv,input_uv1, uniforms.occlusionTexture_texCoord_index, uniforms.use_occlusionTexture_KHR_texture_transform, uniforms.occlusionTexture_KHR_texture_transform_offset, uniforms.occlusionTexture_KHR_texture_transform_rotation, uniforms.occlusionTexture_KHR_texture_transform_scale ); let metallicRoughnessUV=get_transformed_uv( input_uv,input_uv1, uniforms.metallicRoughnessTexture_texCoord_index, uniforms.use_metallicRoughnessTexture_KHR_texture_transform, uniforms.metallicRoughnessTexture_KHR_texture_transform_offset, uniforms.metallicRoughnessTexture_KHR_texture_transform_rotation, uniforms.metallicRoughnessTexture_KHR_texture_transform_scale ); let normalUV=get_transformed_uv( input_uv,input_uv1, uniforms.normalTexture_texCoord_index, uniforms.use_normalTexture_KHR_texture_transform, uniforms.normalTexture_KHR_texture_transform_offset, uniforms.normalTexture_KHR_texture_transform_rotation, uniforms.normalTexture_KHR_texture_transform_scale ); let KHR_clearcoatUV=get_transformed_uv( input_uv,input_uv1, uniforms.KHR_clearcoatTexture_texCoord_index, uniforms.use_KHR_clearcoatTexture_KHR_texture_transform, uniforms.KHR_clearcoatTexture_KHR_texture_transform_offset, uniforms.KHR_clearcoatTexture_KHR_texture_transform_rotation, uniforms.KHR_clearcoatTexture_KHR_texture_transform_scale ); #redgpu_if useKHR_materials_clearcoat let KHR_clearcoatNormalUV=get_transformed_uv( input_uv,input_uv1, uniforms.KHR_clearcoatNormalTexture_texCoord_index, uniforms.use_KHR_clearcoatNormalTexture_KHR_texture_transform, uniforms.KHR_clearcoatNormalTexture_KHR_texture_transform_offset, uniforms.KHR_clearcoatNormalTexture_KHR_texture_transform_rotation, uniforms.KHR_clearcoatNormalTexture_KHR_texture_transform_scale ); #redgpu_endIf let KHR_clearcoatRoughnessUV=get_transformed_uv( input_uv,input_uv1, uniforms.KHR_clearcoatRoughnessTexture_texCoord_index, uniforms.use_KHR_clearcoatRoughnessTexture_KHR_texture_transform, uniforms.KHR_clearcoatRoughnessTexture_KHR_texture_transform_offset, uniforms.KHR_clearcoatRoughnessTexture_KHR_texture_transform_rotation, uniforms.KHR_clearcoatRoughnessTexture_KHR_texture_transform_scale ); let KHR_sheenColorUV=get_transformed_uv( input_uv,input_uv1, uniforms.KHR_sheenColorTexture_texCoord_index, uniforms.use_KHR_sheenColorTexture_KHR_texture_transform, uniforms.KHR_sheenColorTexture_KHR_texture_transform_offset, uniforms.KHR_sheenColorTexture_KHR_texture_transform_rotation, uniforms.KHR_sheenColorTexture_KHR_texture_transform_scale ); let KHR_sheenRoughnessUV=get_transformed_uv( input_uv,input_uv1, uniforms.KHR_sheenRoughnessTexture_texCoord_index, uniforms.use_KHR_sheenRoughnessTexture_KHR_texture_transform, uniforms.KHR_sheenRoughnessTexture_KHR_texture_transform_offset, uniforms.KHR_sheenRoughnessTexture_KHR_texture_transform_rotation, uniforms.KHR_sheenRoughnessTexture_KHR_texture_transform_scale ); let KHR_specularTextureUV=get_transformed_uv( input_uv,input_uv1, uniforms.KHR_specularTexture_texCoord_index, uniforms.use_KHR_specularTexture_KHR_texture_transform, uniforms.KHR_specularTexture_KHR_texture_transform_offset, uniforms.KHR_specularTexture_KHR_texture_transform_rotation, uniforms.KHR_specularTexture_KHR_texture_transform_scale ); let KHR_specularColorTextureUV=get_transformed_uv( input_uv,input_uv1, uniforms.KHR_specularColorTexture_texCoord_index, uniforms.use_KHR_specularColorTexture_KHR_texture_transform, uniforms.KHR_specularColorTexture_KHR_texture_transform_offset, uniforms.KHR_specularColorTexture_KHR_texture_transform_rotation, uniforms.KHR_specularColorTexture_KHR_texture_transform_scale ); let KHR_iridescenceTextureUV=get_transformed_uv( input_uv,input_uv1, uniforms.KHR_iridescenceTexture_texCoord_index, uniforms.use_KHR_iridescenceTexture_KHR_texture_transform, uniforms.KHR_iridescenceTexture_KHR_texture_transform_offset, uniforms.KHR_iridescenceTexture_KHR_texture_transform_rotation, uniforms.KHR_iridescenceTexture_KHR_texture_transform_scale ); let KHR_iridescenceThicknessTextureUV=get_transformed_uv( input_uv,input_uv1, uniforms.KHR_iridescenceThicknessTexture_texCoord_index, uniforms.use_KHR_iridescenceThicknessTexture_KHR_texture_transform, uniforms.KHR_iridescenceThicknessTexture_KHR_texture_transform_offset, uniforms.KHR_iridescenceThicknessTexture_KHR_texture_transform_rotation, uniforms.KHR_iridescenceThicknessTexture_KHR_texture_transform_scale ); let KHR_transmissionUV=get_transformed_uv( input_uv,input_uv1, uniforms.KHR_transmissionTexture_texCoord_index, uniforms.use_KHR_transmissionTexture_KHR_texture_transform, uniforms.KHR_transmissionTexture_KHR_texture_transform_offset, uniforms.KHR_transmissionTexture_KHR_texture_transform_rotation, uniforms.KHR_transmissionTexture_KHR_texture_transform_scale ); let KHR_diffuseTransmissionUV=get_transformed_uv( input_uv,input_uv1, uniforms.KHR_diffuseTransmissionTexture_texCoord_index, uniforms.use_KHR_diffuseTransmissionTexture_KHR_texture_transform, uniforms.KHR_diffuseTransmissionTexture_KHR_texture_transform_offset, uniforms.KHR_diffuseTransmissionTexture_KHR_texture_transform_rotation, uniforms.KHR_diffuseTransmissionTexture_KHR_texture_transform_scale ); let KHR_diffuseTransmissionColorUV=get_transformed_uv( input_uv,input_uv1, uniforms.KHR_diffuseTransmissionColorTexture_texCoord_index, uniforms.use_KHR_diffuseTransmissionColorTexture_KHR_texture_transform, uniforms.KHR_diffuseTransmissionColorTexture_KHR_texture_transform_offset, uniforms.KHR_diffuseTransmissionColorTexture_KHR_texture_transform_rotation, uniforms.KHR_diffuseTransmissionColorTexture_KHR_texture_transform_scale ); let KHR_anisotropyUV=get_transformed_uv( input_uv,input_uv1, uniforms.KHR_anisotropyTexture_texCoord_index, uniforms.use_KHR_anisotropyTexture_KHR_texture_transform, uniforms.KHR_anisotropyTexture_KHR_texture_transform_offset, uniforms.KHR_anisotropyTexture_KHR_texture_transform_rotation, uniforms.KHR_anisotropyTexture_KHR_texture_transform_scale ); var N:vec3=normalize(input_vertexNormal.xyz); var backFaceYn:bool=false; #redgpu_if doubleSided { var fdx:vec3=dpdx(input_vertexPosition); var fdy:vec3=dpdy(input_vertexPosition); var faceNormal:vec3=normalize(cross(fdy,fdx)); if (dot(N,faceNormal) < 0.0) { N=-N; backFaceYn=true; }; } #redgpu_endIf #redgpu_if normalTexture { var targetUv=select(normalUV,1.0 - normalUV,backFaceYn); let normalSamplerColor=textureSample(normalTexture,normalTextureSampler,normalUV).rgb; N=perturb_normal( N, input_vertexPosition, targetUv, vec3(normalSamplerColor.r,1.0 - normalSamplerColor.g,normalSamplerColor.b), u_normalScale ); N=select(N,select(N,-N,backFaceYn),u_useVertexTangent); } #redgpu_else { N=N * u_normalScale; } #redgpu_endIf let V:vec3=normalize(u_cameraPosition - input_vertexPosition); let NdotV=max(dot(N,V),0.04); let VdotN=max(dot(V,N),0.0); var visibility:f32=1.0; visibility=calcDirectionalShadowVisibility( directionalShadowMap, directionalShadowMapSampler, u_shadowDepthTextureSize, u_bias, inputData.shadowPos ); if(!receiveShadowYn){ visibility=1.0; } var finalColor:vec4; var ior:f32=u_KHR_materials_ior; var baseColor=u_baseColorFactor; var resultAlpha:f32=u_opacity * baseColor.a; baseColor *=select(vec4(1.0),input_vertexColor_0,u_useVertexColor); #redgpu_if baseColorTexture let diffuseSampleColor=(textureSample(baseColorTexture,baseColorTextureSampler,diffuseUV)); baseColor *=diffuseSampleColor; resultAlpha *=diffuseSampleColor.a; #redgpu_endIf let albedo:vec3=baseColor.rgb; #redgpu_if useKHR_materials_unlit if(u_useKHR_materials_unlit){ output.color=baseColor; return output; } #redgpu_endIf var occlusionParameter:f32=1; #redgpu_if useOcclusionTexture occlusionParameter=textureSample(packedORMTexture,packedTextureSampler,occlusionUV).r * u_occlusionStrength; #redgpu_endIf var metallicParameter:f32=u_metallicFactor; var roughnessParameter:f32=u_roughnessFactor; #redgpu_if useMetallicRoughnessTexture let metallicRoughnessSample=(textureSample(packedORMTexture,packedTextureSampler,metallicRoughnessUV)); metallicParameter=metallicRoughnessSample.b * metallicParameter; roughnessParameter=metallicRoughnessSample.g * roughnessParameter; #redgpu_endIf roughnessParameter=max(roughnessParameter,0.045); if (abs(ior - 1.0) < 0.0001) { roughnessParameter=0;} var clearcoatParameter=u_KHR_clearcoatFactor; var clearcoatRoughnessParameter=u_KHR_clearcoatRoughnessFactor; var clearcoatNormal:vec3=N; #redgpu_if useKHR_materials_clearcoat { if(clearcoatParameter !=0.0){ #redgpu_if useKHR_clearcoatTexture let clearcoatSample=textureSample(packedKHR_clearcoatTexture_transmission,packedTextureSampler,KHR_clearcoatUV); clearcoatParameter *=clearcoatSample.r; #redgpu_endIf #redgpu_if useKHR_clearcoatRoughnessTexture let clearcoatRoughnesstSample=textureSample(packedKHR_clearcoatTexture_transmission,packedTextureSampler,KHR_clearcoatRoughnessUV); clearcoatRoughnessParameter *=clearcoatRoughnesstSample.g; #redgpu_endIf var clearcoatNormalSampler=textureSample(KHR_clearcoatNormalTexture,baseColorTextureSampler,KHR_clearcoatNormalUV); #redgpu_if useKHR_clearcoatNormalTexture { var targetUv=KHR_clearcoatNormalUV; if(backFaceYn){ targetUv=1.0 - targetUv; } clearcoatNormal=clearcoatNormalSampler.rgb; clearcoatNormal=perturb_normal( N, input_vertexPosition, targetUv, clearcoatNormal, u_normalScale ); if(u_useVertexTangent){ if(backFaceYn ){ clearcoatNormal=-clearcoatNormal;} } clearcoatNormal=normalize(clearcoatNormal); } #redgpu_endIf } } #redgpu_endIf var specularParameter=u_KHR_specularFactor; var specularColor=u_KHR_specularColorFactor; #redgpu_if useKHR_materials_specular #redgpu_if KHR_specularColorTexture let specularColorTextureSample=textureSample( KHR_specularColorTexture, KHR_specularColorTextureSampler, KHR_specularColorTextureUV ); specularColor *=specularColorTextureSample.rgb; #redgpu_endIf #redgpu_if KHR_specularTexture let specularTextureSample=textureSample( KHR_specularTexture, KHR_specularTextureSampler, KHR_specularTextureUV ); specularParameter *=specularTextureSample.a; #redgpu_endIf #redgpu_endIf var transmissionParameter:f32=u_KHR_transmissionFactor; var thicknessParameter:f32=u_KHR_thicknessFactor; #redgpu_if useKHR_materials_transmission #redgpu_if useKHR_transmissionTexture let transmissionSample:vec4=textureSample( packedKHR_clearcoatTexture_transmission, packedTextureSampler, KHR_transmissionUV ); transmissionParameter *=transmissionSample.b; #redgpu_endIf #redgpu_if useKHR_thicknessTexture let thicknessSample:vec4=textureSample( packedKHR_clearcoatTexture_transmission, packedTextureSampler, KHR_transmissionUV ); thicknessParameter *=thicknessSample.a; #redgpu_endIf #redgpu_endIf var diffuseTransmissionColor:vec3=u_KHR_diffuseTransmissionColorFactor; var diffuseTransmissionParameter:f32=u_KHR_diffuseTransmissionFactor; #redgpu_if useKHR_materials_diffuse_transmission #redgpu_if useKHR_diffuseTransmissionTexture let diffuseTransmissionTextureSample=textureSample( packedKHR_diffuse_transmission, packedTextureSampler, KHR_diffuseTransmissionUV ); diffuseTransmissionParameter *=diffuseTransmissionTextureSample.a; #redgpu_endIf #redgpu_if useKHR_diffuseTransmissionColorTexture let diffuseTransmissionColorTextureSample=textureSample( packedKHR_diffuse_transmission, packedTextureSampler, KHR_diffuseTransmissionColorUV ); diffuseTransmissionColor *=diffuseTransmissionColorTextureSample.rgb; #redgpu_endIf #redgpu_endIf var sheenColor=u_KHR_sheenColorFactor; var sheenRoughnessParameter=u_KHR_sheenRoughnessFactor; #redgpu_if useKHR_materials_sheen #redgpu_if useKHR_sheenColorTexture let sheenColorSample=(textureSample(packedKHR_sheen,packedTextureSampler,KHR_sheenColorUV)); sheenColor *=sheenColorSample.rgb; #redgpu_endIf #redgpu_if useKHR_sheenRoughnessTexture let sheenRoughnessSample=(textureSample(packedKHR_sheen,packedTextureSampler,KHR_sheenRoughnessUV)); sheenRoughnessParameter *=sheenRoughnessSample.a; #redgpu_endIf #redgpu_endIf var iridescenceParameter=u_KHR_iridescenceFactor; var iridescenceThickness=u_KHR_iridescenceThicknessMaximum; #redgpu_if useKHR_materials_iridescence #redgpu_if useKHR_iridescenceTexture let iridescenceTextureSample:vec4=textureSample( packedKHR_iridescence, packedTextureSampler, KHR_iridescenceTextureUV ); iridescenceParameter *=iridescenceTextureSample.r; #redgpu_endIf #redgpu_if useKHR_iridescenceThicknessTexture let iridescenceThicknessTextureSample:vec4=textureSample( packedKHR_iridescence, packedTextureSampler, KHR_iridescenceThicknessTextureUV ); iridescenceThickness=mix(u_KHR_iridescenceThicknessMinimum,u_KHR_iridescenceThicknessMaximum,iridescenceThicknessTextureSample.g); #redgpu_endIf #redgpu_endIf var anisotropy:f32=u_KHR_anisotropyStrength; var anisotropicT:vec3=vec3(1.0); var anisotropicB:vec3=vec3(1.0); #redgpu_if useKHR_materials_anisotropy { var T:vec3; var B:vec3; if (u_useVertexTangent && length(input_vertexTangent.xyz) > 0.0) { T=normalize(input_vertexTangent.xyz); B=normalize(cross(N,T) * input_vertexTangent.w); } else { T=normalize(select(vec3(1.0,0.0,0.0),vec3(0.0,1.0,0.0),abs(N.x) > 0.9)); T=normalize(T - N * dot(T,N)); B=normalize(cross(N,T)); } var anisotropicDirection:vec2=vec2(1.0,0.0); if(u_useKHR_anisotropyTexture){ let anisotropyTex=textureSample(KHR_anisotropyTexture,baseColorTextureSampler,KHR_anisotropyUV).rgb; anisotropicDirection=anisotropyTex.rg * 2.0 - vec2(1.0,1.0); anisotropy *=anisotropyTex.b; } var cosR=cos(u_KHR_anisotropyRotation); var sinR=sin(u_KHR_anisotropyRotation); let rotationMtx:mat2x2=mat2x2( cosR,sinR, -sinR,cosR ); anisotropicDirection=rotationMtx * anisotropicDirection; anisotropicT=normalize(T * anisotropicDirection.x + B * anisotropicDirection.y); anisotropicB=normalize(cross(N,anisotropicT)); } #redgpu_endIf var prePathBackground=vec3(0.0); #redgpu_if useKHR_materials_transmission prePathBackground=calcPrePathBackground( u_useKHR_materials_volume,thicknessParameter * inputData.localNodeScale_volumeScale[1],u_KHR_dispersion,u_KHR_attenuationDistance,u_KHR_attenuationColor, ior,roughnessParameter,albedo, systemUniforms.projectionCameraMatrix,input_vertexPosition,input_ndcPosition, V,N, renderPath1ResultTexture,renderPath1ResultTextureSampler ); #redgpu_endIf let F0_dielectric_base=vec3(pow((1.0 - ior)/(1.0 + ior),2.0)); var F0_dielectric=F0_dielectric_base * specularColor; var F0_metal=baseColor.rgb; #redgpu_if useKHR_materials_iridescence if (iridescenceParameter > 0.0) { F0_dielectric=iridescent_fresnel(1.0,u_KHR_iridescenceIor,F0_dielectric,iridescenceThickness,iridescenceParameter,NdotV); F0_metal=iridescent_fresnel(1.0,u_KHR_iridescenceIor,baseColor.rgb,iridescenceThickness,iridescenceParameter,NdotV); } #redgpu_endIf let F0=mix(F0_dielectric,F0_metal,metallicParameter); var totalDirectLighting=vec3(0.0); for (var i=0u;i < u_directionalLightCount;i++) { totalDirectLighting +=calcLight( u_directionalLights[i].color,u_directionalLights[i].intensity * visibility, N,V,-normalize(u_directionalLights[i].direction), VdotN, roughnessParameter,metallicParameter,albedo, F0,ior, prePathBackground, specularColor,specularParameter, u_useKHR_materials_diffuse_transmission,diffuseTransmissionParameter,diffuseTransmissionColor, transmissionParameter, sheenColor,sheenRoughnessParameter, anisotropy,anisotropicT,anisotropicB, clearcoatParameter,clearcoatRoughnessParameter,clearcoatNormal ); } { let clusterIndex=getClusterLightClusterIndex(inputData.position); let lightOffset=clusterLightGroup.lights[clusterIndex].offset; let lightCount:u32=clusterLightGroup.lights[clusterIndex].count; for (var lightIndex=0u;lightIndex < lightCount;lightIndex=lightIndex + 1u) { let i=clusterLightGroup.indices[lightOffset + lightIndex]; let targetLight=clusterLightList.lights[i]; let u_clusterLightPosition=targetLight.position; let u_clusterLightRadius=targetLight.radius; let u_isSpotLight=targetLight.isSpotLight; let lightDistance=length(u_clusterLightPosition - input_vertexPosition); if (lightDistance > u_clusterLightRadius) { continue; } let lightDir=normalize(u_clusterLightPosition - input_vertexPosition);\nlet Lvec=u_clusterLightPosition - input_vertexPosition;\nlet dist2=max(dot(Lvec,Lvec),0.0001);\nlet d=sqrt(dist2);\nlet rangePart=pow(clamp(1.0 - d/u_clusterLightRadius,0.0,1.0),2.0);\nlet invSquare=(u_clusterLightRadius * u_clusterLightRadius)/dist2;\nlet attenuation=rangePart * invSquare; var finalAttenuation=attenuation; if (u_isSpotLight > 0.0) { let u_clusterLightDirection=normalize(vec3( targetLight.directionX, targetLight.directionY, targetLight.directionZ )); let u_clusterLightInnerAngle=targetLight.innerCutoff; let u_clusterLightOuterCutoff=targetLight.outerCutoff; let lightToVertex=normalize(-lightDir); let cosTheta=dot(lightToVertex,u_clusterLightDirection); let cosOuter=cos(radians(u_clusterLightOuterCutoff)); let cosInner=cos(radians(u_clusterLightInnerAngle)); if (cosTheta < cosOuter) { continue; } let epsilon=cosInner - cosOuter; let spotIntensity=clamp((cosTheta - cosOuter)/epsilon,0.0,1.0); finalAttenuation *=spotIntensity; } totalDirectLighting +=calcLight( targetLight.color,targetLight.intensity * finalAttenuation, N,V,lightDir, VdotN, roughnessParameter,metallicParameter,albedo, F0,ior, prePathBackground, specularColor,specularParameter, u_useKHR_materials_diffuse_transmission,diffuseTransmissionParameter,diffuseTransmissionColor, transmissionParameter, sheenColor,sheenRoughnessParameter, anisotropy,anisotropicT,anisotropicB, clearcoatParameter,clearcoatRoughnessParameter,clearcoatNormal ); } } if (u_usePrefilterTexture) { var R=(reflect(-V,N)); let NdotV=max(dot(N,V),1e-4); #redgpu_if useKHR_materials_anisotropy { var bentNormal=cross(anisotropicB,V); bentNormal=normalize(cross(bentNormal,anisotropicB)); let temp=1.0 - anisotropy * (1.0 - roughnessParameter); let tempSquared=temp * temp; var a=tempSquared * tempSquared; bentNormal=normalize(mix(bentNormal,N,a)); var reflectVec=reflect(-V,bentNormal); reflectVec=normalize(mix(reflectVec,bentNormal,roughnessParameter * roughnessParameter)); let roughnessT=roughnessParameter * (1.0 + anisotropy); let roughnessB=roughnessParameter * (1.0 - anisotropy); let TdotR=dot(anisotropicT,reflectVec); let BdotR=dot(anisotropicB,reflectVec); let TdotV=dot(anisotropicT,V); let BdotV=dot(anisotropicB,V); R=normalize(reflectVec - anisotropy * (TdotR * anisotropicT - BdotR * anisotropicB)); let VdotN=max(1e-4,dot(V,N)); let oneMinusVdotN=1.0 - VdotN; let directionFactor=oneMinusVdotN * oneMinusVdotN * oneMinusVdotN; let VdotT_abs=abs(TdotV); let VdotB_abs=abs(BdotV); let totalWeight=max(1e-4,VdotT_abs + VdotB_abs); let weightedRoughness=(roughnessT * VdotT_abs + roughnessB * VdotB_abs)/totalWeight; roughnessParameter=weightedRoughness; } #redgpu_endIf let iblMipmapCount:f32=f32(textureNumLevels(ibl_environmentTexture) - 1); var mipLevel=roughnessParameter * iblMipmapCount; var reflectedColor=textureSampleLevel( ibl_environmentTexture,prefilterTextureSampler,R,mipLevel ).rgb; let envBRDF=textureSampleLevel(ibl_brdfLUTTexture,prefilterTextureSampler,vec2(NdotV,roughnessParameter),0.0).rg; var F_IBL_dielectric=F0_dielectric * envBRDF.x + envBRDF.y; var F_IBL_metal=F0_metal * envBRDF.x + envBRDF.y; var F_IBL=F0 * envBRDF.x + envBRDF.y; let a2=roughnessParameter * roughnessParameter; let G_smith=NdotV/(NdotV * (1.0 - a2) + a2); let effectiveTransmission=transmissionParameter * (1.0 - metallicParameter); let iblDiffuseColor=textureSampleLevel(ibl_irradianceTexture,prefilterTextureSampler,N,0).rgb; var envIBL_DIFFUSE:vec3=albedo * iblDiffuseColor* (vec3(1.0) - F_IBL_dielectric); #redgpu_if useKHR_materials_diffuse_transmission { var backScatteringColor=textureSampleLevel(ibl_environmentTexture,prefilterTextureSampler,-N,mipLevel).rgb; let transmittedIBL=backScatteringColor * diffuseTransmissionColor * (vec3(1.0) - F_IBL_dielectric); envIBL_DIFFUSE=mix(envIBL_DIFFUSE,transmittedIBL,diffuseTransmissionParameter); } #redgpu_endIf var envIBL_SPECULAR:vec3; envIBL_SPECULAR=reflectedColor * F_IBL * specularParameter; var envIBL_SPECULAR_BTDF=vec3(0.0); #redgpu_if useKHR_materials_transmission var refractedDir:vec3; let eta=1.0/ior; if (abs(ior - 1.0) < 0.0001) { refractedDir=V;} else { refractedDir=refract(-V,-N,eta);} if(length(refractedDir) > 0.0001) { let NdotT=abs(dot(N,normalize(refractedDir))); let F_transmission=vec3(1.0) - mix(F_IBL_dielectric,F_IBL_metal,metallicParameter); var attenuatedBackground=prePathBackground; if (u_useKHR_materials_volume) { let localNodeScale=inputData.localNodeScale_volumeScale[0]; let volumeScale=inputData.localNodeScale_volumeScale[1]; let scaledThickness=thicknessParameter * localNodeScale; let safeAttenuationColor=clamp(u_KHR_attenuationColor,vec3(0.0001),vec3(1.0)); let safeAttenuationDistance=max(u_KHR_attenuationDistance,0.0001); let attenuationCoefficient=-log(safeAttenuationColor)/safeAttenuationDistance; let cosTheta=max(NdotT,0.001); let pathLength=scaledThickness/cosTheta; let transmittance=exp(-attenuationCoefficient * pathLength); attenuatedBackground *=transmittance; }else{ attenuatedBackground *=albedo; } envIBL_SPECULAR_BTDF=attenuatedBackground * F_transmission * transmissionParameter + reflectedColor * G_smith * mix(F_IBL_dielectric,F_IBL_metal,metallicParameter) * NdotT; } #redgpu_endIf let envIBL_DIELECTRIC=mix(envIBL_DIFFUSE,envIBL_SPECULAR_BTDF,transmissionParameter) + envIBL_SPECULAR; var envIBL_SHEEN=vec3(0.0); var sheen_albedo_scaling:f32=1.0; let maxSheenColor=max(sheenColor.x,max(sheenColor.y,sheenColor.z)); #redgpu_if useKHR_materials_sheen let sheenResult=calcIBLSheen( N, V, sheenColor, maxSheenColor, sheenRoughnessParameter, iblMipmapCount ); envIBL_SHEEN=sheenResult.envIBL_SHEEN; sheen_albedo_scaling=sheenResult.sheen_albedo_scaling; #redgpu_endIf let envIBL_METAL=reflectedColor * F_IBL_metal; let metallicPart=envIBL_METAL * metallicParameter; let dielectricPart=envIBL_DIELECTRIC * (1.0 - metallicParameter); var indirectLighting=(metallicPart + dielectricPart) * sheen_albedo_scaling + envIBL_SHEEN; #redgpu_if useKHR_materials_clearcoat if (clearcoatParameter > 0.0) { let clearcoatR=reflect(-V,clearcoatNormal); let clearcoatNdotV=max(dot(clearcoatNormal,V),0.04); let clearcoatMipLevel=clearcoatRoughnessParameter * iblMipmapCount; let clearcoatPrefilteredColor=textureSampleLevel(ibl_environmentTexture,prefilterTextureSampler,clearcoatR,clearcoatMipLevel).rgb; let clearcoatEnvBRDF=textureSampleLevel(ibl_brdfLUTTexture,prefilterTextureSampler,vec2(clearcoatNdotV,clearcoatRoughnessParameter),0.0).rg; let clearcoatF0=vec3(0.04); let clearcoatF=clearcoatF0 * clearcoatEnvBRDF.x + clearcoatEnvBRDF.y; let clearcoatSpecularIBL=clearcoatPrefilteredColor * clearcoatF * clearcoatParameter; indirectLighting=clearcoatSpecularIBL + (1.0 - max(clearcoatF.x,max(clearcoatF.y,clearcoatF.z)) * clearcoatParameter) * indirectLighting; } #redgpu_endIf let environmentIntensity=1.0; let surfaceColor=totalDirectLighting + indirectLighting * environmentIntensity * occlusionParameter; finalColor=vec4(surfaceColor,resultAlpha); } else { let ambientContribution=albedo * u_ambientLightColor * u_ambientLightIntensity * occlusionParameter; finalColor=vec4(totalDirectLighting + ambientContribution,resultAlpha); } var emissiveSamplerColor=vec3(1.0); #redgpu_if emissiveTexture emissiveSamplerColor=textureSample(emissiveTexture,emissiveTextureSampler,emissiveUV).rgb; #redgpu_endIf finalColor +=vec4( emissiveSamplerColor.rgb * u_emissiveFactor * u_emissiveStrength,0); #redgpu_if useCutOff if (resultAlpha <=u_cutOff) { discard;} #redgpu_endIf output.color=finalColor; { let smoothness=1.0 - roughnessParameter; let smoothnessCurved=smoothness * smoothness * (3.0 - 2.0 * smoothness); let metallicWeight=metallicParameter * metallicParameter; let baseReflection=0.04 + 0.96 * metallicWeight; let baseReflectionStrength=smoothnessCurved * baseReflection; output.gBufferNormal=vec4(N * 0.5 + 0.5,baseReflectionStrength); } output.gBufferMotionVector=vec4(calculateMotionVector(inputData.currentClipPos,inputData.prevClipPos),0.0,1.0 ); return output;\n};\nstruct SheenResult { envIBL_SHEEN:vec3, sheen_albedo_scaling:f32\n}\nfn calcIBLSheen( N:vec3, V:vec3, sheenColor:vec3, maxSheenColor:f32, sheenRoughness:f32, iblMipmapCount:f32,\n) -> SheenResult { let NdotV=clamp(dot(N,V),0.0001,1.0); let R=reflect(-V,N); let mipLevel=sheenRoughness * iblMipmapCount; let sheenRadiance=textureSampleLevel( ibl_irradianceTexture,prefilterTextureSampler,R,mipLevel ).rgb; let sheenDFG=charlieSheenDFG(NdotV,sheenRoughness); let envIBL_SHEEN=sheenRadiance * sheenColor * sheenDFG; let E=charlieSheenE(NdotV,sheenRoughness); let sheen_albedo_scaling=1.0 - maxSheenColor * E; return SheenResult(envIBL_SHEEN,sheen_albedo_scaling);\n}\nfn charlieSheenDFG(NdotV:f32,roughness:f32) -> f32 { if (roughness < 0.01) { return 0.0; } let r=clamp(roughness,0.01,1.0); let grazingFactor=1.0 - NdotV; let roughnessExp=1.0/max(r,0.1); let distribution=pow(grazingFactor,roughnessExp); let intensity=pow(roughnessExp,0.5); return distribution * intensity * 0.5;\n}\nfn charlieSheenE(NdotV:f32,roughness:f32) -> f32 { if (roughness < 0.01) { return 0.0; } let r=clamp(roughness,0.01,1.0); let grazingFactor=1.0 - NdotV; let roughnessExp=1.0/max(r,0.1); return pow(grazingFactor,roughnessExp) * pow(r,0.5);\n}\nfn calcLight( lightColor:vec3,lightIntensity:f32, N:vec3,V:vec3,L:vec3, VdotN:f32, roughnessParameter:f32,metallicParameter:f32,albedo:vec3, F0:vec3,ior:f32, prePathBackground:vec3, specularColor:vec3,specularParameter:f32, u_useKHR_materials_diffuse_transmission:bool,diffuseTransmissionParameter:f32,diffuseTransmissionColor:vec3, transmissionParameter:f32, sheenColor:vec3,sheenRoughnessParameter:f32, anisotropy:f32,anisotropicT:vec3,anisotropicB:vec3, clearcoatParameter:f32,clearcoatRoughnessParameter:f32,clearcoatNormal:vec3\n) -> vec3{ let dLight=lightColor * lightIntensity; let NdotL=max(dot(N,L),0.04); let NdotV=max(dot(N,V),0.04); let H=normalize(L + V); let LdotH=max(dot(L,H),0.0); let NdotH=max(dot(N,H),0.0); let VdotH=max(dot(V,H),0.0); var DIFFUSE_BRDF:vec3=diffuse_brdf_disney(NdotL,NdotV,LdotH,roughnessParameter,albedo); #redgpu_if useKHR_materials_diffuse_transmission DIFFUSE_BRDF=mix(DIFFUSE_BRDF,diffuse_btdf(N,L,diffuseTransmissionColor),diffuseTransmissionParameter); #redgpu_endIf var SPECULAR_BRDF:vec3; if (anisotropy > 0.0) { #redgpu_if useKHR_materials_anisotropy var TdotL=dot(anisotropicT,L); var TdotV=dot(anisotropicT,V); var BdotL=dot(anisotropicB,L); var TdotH=dot(anisotropicT,H); var BdotH=dot(anisotropicB,H); var BdotV=dot(anisotropicB,V); SPECULAR_BRDF=BRDF_specularAnisotropicGGX( albedo, vec3(1.0), roughnessParameter * roughnessParameter, VdotH,NdotL,NdotV,NdotH,BdotV,TdotV,TdotL,BdotL,TdotH,BdotH, anisotropy ); #redgpu_endIf }else{ SPECULAR_BRDF=specular_brdf( albedo,roughnessParameter,NdotH,NdotV,NdotL,LdotH); } let METAL_BRDF=conductor_fresnel( albedo,SPECULAR_BRDF,VdotH);; var SPECULAR_BTDF=vec3(0.0); #redgpu_if useKHR_materials_transmission if(transmissionParameter > 0.0){ SPECULAR_BTDF=specular_btdf( NdotV,NdotL,NdotH,VdotH,LdotH,roughnessParameter,albedo,ior); } #redgpu_endIf let DIELECTRIC_BRDF=fresnel_mix( F0, specularParameter, mix(DIFFUSE_BRDF,SPECULAR_BTDF,transmissionParameter), SPECULAR_BRDF, VdotH ); var SHEEN_BRDF:vec3=vec3(0.0); var sheen_albedo_scaling:f32=1.0; #redgpu_if useKHR_materials_sheen let maxSheenColor=max(sheenColor.x,max(sheenColor.y,sheenColor.z)); if(sheenRoughnessParameter > 0.0 && maxSheenColor > 0.001 && dot(N,V) > 0) { let NdotV=dot(N,V); let sheenRoughnessAlpha=sheenRoughnessParameter * sheenRoughnessParameter; let invR=1/sheenRoughnessAlpha; let cos2h=NdotH * NdotH; let sin2h=1 - cos2h; let sheenDistribution=(2 + invR) * pow(sin2h,invR * 0.5)/(2 * pi); let sheen_visibility=1.0/((1.0 + lambda_sheen(NdotV,sheenRoughnessAlpha) + lambda_sheen(NdotL,sheenRoughnessAlpha)) * (4.0 * NdotV * NdotL)); let LdotN=max(dot(L,N),0.04); let E_LdotN=1.0 - pow(1.0 - LdotN,5.0); let E_VdotN=1.0 - pow(1.0 - VdotN,5.0); sheen_albedo_scaling=max(min(1.0 - maxSheenColor * E_VdotN,1.0 - maxSheenColor * E_LdotN),0.04); SHEEN_BRDF=sheenColor * sheenDistribution * sheen_visibility; } #redgpu_endIf let metallicPart=METAL_BRDF * metallicParameter * sheen_albedo_scaling; let dielectricPart=DIELECTRIC_BRDF * sheen_albedo_scaling; let sheenPart=SHEEN_BRDF; var directLighting=(metallicPart + dielectricPart + sheenPart); #redgpu_if useKHR_materials_transmission if(transmissionParameter > 0.0) { let transmissionWeight=transmissionParameter * (vec3(1.0) - F0); directLighting=mix(directLighting,prePathBackground,transmissionWeight); } #redgpu_endIf #redgpu_if useKHR_materials_clearcoat if(clearcoatParameter > 0.0){ let clearcoatNdotL=max(dot(clearcoatNormal,L),0.04); let clearcoatNdotV=max(dot(clearcoatNormal,V),0.04); let clearcoatNdotH=max(dot(clearcoatNormal,H),0.0); let CLEARCOAT_BRDF=specular_brdf( F0,clearcoatRoughnessParameter,clearcoatNdotH,clearcoatNdotV,clearcoatNdotL,LdotH); directLighting=fresnel_coat(clearcoatNdotV,ior,clearcoatParameter,directLighting,CLEARCOAT_BRDF); } #redgpu_endIf var lightDirection:f32; #redgpu_if useKHR_materials_diffuse_transmission lightDirection=mix(abs(dot(N,L)),1.0,diffuseTransmissionParameter); #redgpu_else lightDirection=NdotL; #redgpu_endIf let lightContribution=directLighting * dLight * lightDirection; return lightContribution;\n}\nconst pi:f32=3.14159265359;\nfn BRDF_specularAnisotropicGGX( f0:vec3,f90:vec3,alphaRoughness:f32,VdotH:f32,NdotL:f32,NdotV:f32,NdotH:f32,BdotV:f32,TdotV:f32,TdotL:f32,BdotL:f32,TdotH:f32,BdotH:f32,anisotropy:f32 ) -> vec3 { var at=mix(alphaRoughness,1.0,anisotropy * anisotropy); var ab=alphaRoughness; var F:vec3=fresnel_schlick(VdotH,f0); var V:f32=V_GGX_anisotropic(NdotL,NdotV,BdotV,TdotV,TdotL,BdotL,at,ab); var D:f32=D_GGX_anisotropic(NdotH,TdotH,BdotH,at,ab); return F * (V * D);\n}\nfn D_GGX_anisotropic( NdotH:f32,TdotH:f32,BdotH:f32,at:f32,ab:f32 ) -> f32 { let a2:f32=at * ab; let f:vec3=vec3(ab * TdotH,at * BdotH,a2 * NdotH); let denominator:f32=dot(f,f); let w2:f32=a2/denominator; return a2 * w2 * w2/pi;\n}\nfn V_GGX_anisotropic( NdotL:f32,NdotV:f32,BdotV:f32,TdotV:f32,TdotL:f32,BdotL:f32,at:f32,ab:f32 ) -> f32 { let GGXV=NdotL * length(vec3(at * TdotV,ab * BdotV,NdotV)); let GGXL=NdotV * length(vec3(at * TdotL,ab * BdotL,NdotL)); let v=0.5/(GGXV + GGXL); return clamp(v,0.0,1.0);\n}\nfn iridescent_fresnel(outside_ior:f32,iridescence_ior:f32,base_f0:vec3, iridescence_thickness:f32,iridescence_factor:f32,cos_theta1:f32) -> vec3 { if (iridescence_thickness <=0.0 || iridescence_factor <=0.0) { return base_f0; } let cos_theta1_abs=abs(cos_theta1); let safe_iridescence_ior=max(iridescence_ior,1.01); let sin_theta1=sqrt(max(0.0,1.0 - cos_theta1_abs * cos_theta1_abs)); let sin_theta2=(outside_ior/safe_iridescence_ior) * sin_theta1; if (sin_theta2 >=1.0) { return base_f0 + iridescence_factor * (vec3(1.0) - base_f0); } let cos_theta2=sqrt(max(0.0,1.0 - sin_theta2 * sin_theta2)); let wavelengths=vec3(650.0,510.0,475.0); let effective_thickness=max(iridescence_thickness,10.0); let ior_scale=max(1.0,1.5 - 0.5 * (safe_iridescence_ior/1.5)); let optical_thickness=2.0 * effective_thickness * safe_iridescence_ior * cos_theta2 * ior_scale; let phase=(2.0 * 3.14159265359 * optical_thickness)/wavelengths; let cos_phase=cos(phase); let sin_phase=sin(phase); let outside_cos1=outside_ior * cos_theta1_abs; let iridescence_cos2=safe_iridescence_ior * cos_theta2; let iridescence_cos1=safe_iridescence_ior * cos_theta1_abs; let outside_cos2=outside_ior * cos_theta2; let r12_s=(outside_cos1 - iridescence_cos2)/(outside_cos1 + iridescence_cos2); let r12_p=(iridescence_cos1 - outside_cos2)/(iridescence_cos1 + outside_cos2); let sqrt_f0=sqrt(clamp(base_f0,vec3(0.01),vec3(0.99))); let safe_n3=max((1.0 + sqrt_f0)/(1.0 - sqrt_f0),vec3(1.2)); let iridescence_cos2_vec=vec3(iridescence_cos2); let cos_theta1_abs_vec=vec3(cos_theta1_abs); let iridescence_cos1_vec=vec3(iridescence_cos1); let cos_theta2_vec=vec3(cos_theta2); let r23_s=(iridescence_cos2_vec - safe_n3 * cos_theta1_abs_vec)/ (iridescence_cos2_vec + safe_n3 * cos_theta1_abs_vec); let r23_p=(safe_n3 * cos_theta2_vec - iridescence_cos1_vec)/ (safe_n3 * cos_theta2_vec + iridescence_cos1_vec); let r12_s_vec=vec3(r12_s); let r12_p_vec=vec3(r12_p); let num_s_real=r12_s_vec + r23_s * cos_phase; let num_s_imag=r23_s * sin_phase; let den_s_real=vec3(1.0) + r12_s_vec * r23_s * cos_phase; let den_s_imag=r12_s_vec * r23_s * sin_phase; let num_p_real=r12_p_vec + r23_p * cos_phase; let num_p_imag=r23_p * sin_phase; let den_p_real=vec3(1.0) + r12_p_vec * r23_p * cos_phase; let den_p_imag=r12_p_vec * r23_p * sin_phase; let den_s_squared=den_s_real * den_s_real + den_s_imag * den_s_imag + vec3(0.001); let rs_real=(num_s_real * den_s_real + num_s_imag * den_s_imag)/den_s_squared; let rs_imag=(num_s_imag * den_s_real - num_s_real * den_s_imag)/den_s_squared; let Rs=rs_real * rs_real + rs_imag * rs_imag; let den_p_squared=den_p_real * den_p_real + den_p_imag * den_p_imag + vec3(0.001); let rp_real=(num_p_real * den_p_real + num_p_imag * den_p_imag)/den_p_squared; let rp_imag=(num_p_imag * den_p_real - num_p_real * den_p_imag)/den_p_squared; let Rp=rp_real * rp_real + rp_imag * rp_imag; let reflectance=0.5 * (Rs + Rp); let ior_influence=smoothstep(1.0,2.0,safe_iridescence_ior); let enhanced_reflectance=mix( pow(reflectance,vec3(0.8)) * 1.2, reflectance, ior_influence ); let clamped_reflectance=clamp(enhanced_reflectance,vec3(0.0),vec3(1.0)); return mix(base_f0,clamped_reflectance,iridescence_factor);\n}\nfn specular_btdf( NdotV:f32, NdotL:f32, NdotH:f32, VdotH:f32, LdotH:f32, roughness:f32, F0:vec3, ior:f32\n) -> vec3 { let eta:f32=1.0/ior; let D_rough:f32=distribution_ggx(NdotH,roughness * roughness); let t:f32=clamp((ior - 1.0) * 100.0,0.0,1.0); let D:f32=mix(1.0,D_rough,t); let G:f32=min(1.0,min((2.0 * NdotH * NdotV)/VdotH,(2.0 * NdotH * NdotL)/VdotH)); let F:vec3=fresnel_schlick(VdotH,F0); let denom:f32=(eta * VdotH + LdotH) * (eta * VdotH + LdotH); let btdf:vec3= (vec3(1.0) - F) * abs(VdotH * LdotH) * (eta * eta) * D * G/ (NdotV * denom + 0.001); return btdf;\n}\nfn lambda_sheen_calc_l(x:f32,alpha_g:f32) -> f32 { let one_minus_alpha_sq=(1.0 - alpha_g) * (1.0 - alpha_g); let a=mix(21.5473,25.3245,one_minus_alpha_sq); let b=mix(3.82987,3.32435,one_minus_alpha_sq); let c=mix(0.19823,0.16801,one_minus_alpha_sq); let d=mix(-1.97760,-1.27393,one_minus_alpha_sq); let e=mix(-4.32054,-4.85967,one_minus_alpha_sq); return a/(1.0 + b * pow(x,c)) + d * x + e;\n}\nfn lambda_sheen(cos_theta:f32,alpha_g:f32) -> f32 { if (abs(cos_theta) < 0.5) { return exp(lambda_sheen_calc_l(cos_theta,alpha_g)); } else { return exp(2.0 * lambda_sheen_calc_l(0.5,alpha_g) - lambda_sheen_calc_l(1.0 - cos_theta,alpha_g)); }\n}\nfn fresnel_coat(NdotV:f32,ior:f32,weight:f32,base:vec3,layer:vec3) -> vec3 { let f0:f32=pow((1.0 - ior)/(1.0 + ior),2.0); let fr:f32=f0 + (1.0 - f0) * pow(1.0 - abs(NdotV),5.0); return mix(base,layer,weight * fr);\n}\nfn conductor_fresnel(F0:vec3,bsdf:vec3,VdotH:f32) -> vec3 { let fresnel=F0 + (vec3(1.0) - F0) * pow(1.0 - abs(VdotH),5.0); return bsdf * fresnel;\n}\nfn fresnel_mix( F0:vec3, weight:f32, base:vec3, layer:vec3, VdotH:f32\n) -> vec3 { var f0=F0; f0=min(f0,vec3(1.0)); let fr=f0 + (1.0 - f0) * pow(1.0 - abs(VdotH),5.0); return (1 - weight * max(max(fr.x,fr.y),fr.z)) * base + weight * fr * layer;\n}\nfn fresnel_mix_ibl( F0:vec3, weight:f32, base:vec3, layer:vec3, NdotV:f32\n) -> vec3 { var f0=F0; f0=min(f0,vec3(1.0)); let fr=f0 + (1.0 - f0) * pow(1.0 - max(NdotV,0.0),5.0); return base * (1.0 - fr * weight) + layer * fr * weight;\n}\nfn diffuse_brdf_disney(NdotL:f32,NdotV:f32,LdotH:f32,roughness:f32,albedo:vec3) -> vec3 { if (NdotL <=0.0) { return vec3(0.0);} let energyBias=mix(0.0,0.5,roughness); let energyFactor=mix(1.0,1.0/1.51,roughness); let fd90=energyBias + 2.0 * LdotH * LdotH * roughness; let f0=1.0; let lightScatter=f0 + (fd90 - f0) * pow(1.0 - NdotL,5.0); let viewScatter=f0 + (fd90 - f0) * pow(1.0 - NdotV,5.0); return albedo * NdotL * lightScatter * viewScatter * energyFactor/pi;\n}\nfn diffuse_brdf(NdotL:f32,albedo:vec3) -> vec3 { return albedo * NdotL/pi;\n}\nfn diffuse_btdf(N:vec3,L:vec3,Albedo:vec3) -> vec3 { let cos_theta=max(-dot(N,L),0.0); return Albedo * cos_theta/pi;\n}\nfn specular_brdf( F0:vec3, roughness:f32, NdotH:f32, NdotV:f32, NdotL:f32, LdotH:f32\n) -> vec3 { let D=distribution_ggx(NdotH,roughness); let G=geometry_smith(NdotV,NdotL,roughness); let F=fresnel_schlick(LdotH,F0); let numerator=D * G * F; let denominator=4.0 * NdotV * NdotL + 0.04; return (numerator/denominator);\n}\nfn distribution_ggx(NdotH:f32,roughness:f32) -> f32 { let alpha=roughness * roughness; let alpha2=alpha * alpha; let NdotH2=NdotH * NdotH; let nom=alpha2; let denom=(NdotH2 * (alpha2 - 1.0) + 1.0); let denom_squared=denom * denom; return nom/(denom_squared * 3.14159265359);\n}\nfn geometry_smith(NdotV:f32,NdotL:f32,roughness:f32) -> f32 { let alpha=roughness * roughness; let k=alpha/2.0; let ggx1=NdotV/(NdotV * (1.0 - k) + k); let ggx2=NdotL/(NdotL * (1.0 - k) + k); return ggx1 * ggx2;\n}\nfn fresnel_schlick(cosTheta:f32,F0:vec3) -> vec3 { return F0 + (vec3(1.0) - F0) * pow(1.0 - cosTheta,5.0);\n}\nfn get_transformed_uv( input_uv:vec2, input_uv1:vec2, texCoord_index:u32, use_transform:u32, transform_offset:vec2, transform_rotation:f32, transform_scale:vec2\n) -> vec2 { var result_uv=select(input_uv,input_uv1,texCoord_index==1); if (use_transform==1) { let translation=mat3x3( 1.0,0.0,0.0, 0.0,1.0,0.0, transform_offset.x,transform_offset.y,1.0 ); let cos_rot=cos(transform_rotation); let sin_rot=sin(transform_rotation); let rotation_matrix=mat3x3( cos_rot,-sin_rot,0.0, sin_rot,cos_rot,0.0, 0.0,0.0,1.0 ); let scale_matrix=mat3x3( transform_scale.x,0.0,0.0, 0.0,transform_scale.y,0.0, 0.0,0.0,1.0 ); let result_matrix=translation * rotation_matrix * scale_matrix; result_uv=(result_matrix * vec3(result_uv,1.0)).xy; } return result_uv;\n}\nfn linear_to_srgb(linearColor:vec4) -> vec4 { let cutoff=vec4(0.0031308); let higher=vec4(1.055) * pow(linearColor,vec4(1.0/2.4)) - vec4(0.055); let lower=linearColor * vec4(12.92); return vec4( mix(higher.r,lower.r,step(linearColor.r,cutoff.r)), mix(higher.g,lower.g,step(linearColor.g,cutoff.g)), mix(higher.b,lower.b,step(linearColor.b,cutoff.b)), linearColor.a );\n}\n"));class PBRMaterial extends ABitmapBaseMaterial{#ls;#cs;#hs;#fs;#ds;constructor(i){super(i,"PBR_MATERIAL",Or,2),this.initGPURenderInfos(),this.__packingList=[()=>{this.setupPackORMTexture(),this.setupPackedKHR_clearcoatTexture_transmission(),this.setupPackedKHR_diffuse_transmission(),this.setupPackedKHR_sheen(),this.setupPackedKHR_iridescence()}]}get packedKHR_clearcoatTexture_transmission(){return this.#ds}get packedKHR_iridescence(){return this.#fs}get packedORMTexture(){return this.#ls}get packedKHR_sheen(){return this.#hs}get packedKHR_diffuse_transmission(){return this.#cs}async setupPackORMTexture(){if(!this.occlusionTexture&&!this.metallicRoughnessTexture)return;this.#ls||(this.#ls=new PackedTexture(this.redGPUContext));const i=Math.max(this.occlusionTexture?.gpuTexture?.width||1,this.metallicRoughnessTexture?.gpuTexture?.width||1),g=Math.max(this.occlusionTexture?.gpuTexture?.height||1,this.metallicRoughnessTexture?.gpuTexture?.height||1);await this.#ls.packing({r:this.occlusionTexture?.gpuTexture,g:this.metallicRoughnessTexture?.gpuTexture,b:this.metallicRoughnessTexture?.gpuTexture},i,g,"packedORMTexture")}async setupPackedKHR_clearcoatTexture_transmission(){this.#ds||(this.#ds=new PackedTexture(this.redGPUContext));const i=Math.max(this.KHR_clearcoatTexture?.gpuTexture?.width||1,this.KHR_clearcoatRoughnessTexture?.gpuTexture?.width||1),g=Math.max(this.KHR_clearcoatTexture?.gpuTexture?.height||1,this.KHR_clearcoatRoughnessTexture?.gpuTexture?.height||1),x=Math.max(this.KHR_transmissionTexture?.gpuTexture?.width||1,this.KHR_thicknessTexture?.gpuTexture?.width||1),_=Math.max(this.KHR_transmissionTexture?.gpuTexture?.height||1,this.KHR_thicknessTexture?.gpuTexture?.height||1),v=Math.max(i,x),b=Math.max(g,_);await this.#ds.packing({r:this.KHR_clearcoatTexture?.gpuTexture,g:this.KHR_clearcoatRoughnessTexture?.gpuTexture,b:this.KHR_transmissionTexture?.gpuTexture,a:this.KHR_thicknessTexture?.gpuTexture},v,b,"packedKHR_clearcoatTexture_transmission",{b:"r",a:"g"})}async setupPackedKHR_diffuse_transmission(){if(!this.KHR_diffuseTransmissionColorTexture&&!this.KHR_diffuseTransmissionTexture)return;this.#cs||(this.#cs=new PackedTexture(this.redGPUContext));const i=Math.max(this.KHR_diffuseTransmissionColorTexture?.gpuTexture?.width||1,this.KHR_diffuseTransmissionTexture?.gpuTexture?.width||1),g=Math.max(this.KHR_diffuseTransmissionColorTexture?.gpuTexture?.height||1,this.KHR_diffuseTransmissionTexture?.gpuTexture?.height||1);await this.#cs.packing({r:this.KHR_diffuseTransmissionColorTexture?.gpuTexture,g:this.KHR_diffuseTransmissionColorTexture?.gpuTexture,b:this.KHR_diffuseTransmissionColorTexture?.gpuTexture,a:this.KHR_diffuseTransmissionTexture?.gpuTexture},i,g,"packedKHR_diffuse_transmission")}async setupPackedKHR_sheen(){if(!this.KHR_sheenColorTexture&&!this.KHR_sheenRoughnessTexture)return;this.#hs||(this.#hs=new PackedTexture(this.redGPUContext));const i=Math.max(this.KHR_sheenColorTexture?.gpuTexture?.width||1,this.KHR_sheenRoughnessTexture?.gpuTexture?.width||1),g=Math.max(this.KHR_sheenColorTexture?.gpuTexture?.height||1,this.KHR_sheenRoughnessTexture?.gpuTexture?.height||1);await this.#hs.packing({r:this.KHR_sheenColorTexture?.gpuTexture,g:this.KHR_sheenColorTexture?.gpuTexture,b:this.KHR_sheenColorTexture?.gpuTexture,a:this.KHR_sheenRoughnessTexture?.gpuTexture},i,g,"packedKHR_sheen")}async setupPackedKHR_iridescence(){if(!this.KHR_iridescenceTexture&&!this.KHR_iridescenceThicknessTexture)return;this.#fs||(this.#fs=new PackedTexture(this.redGPUContext));const i=Math.max(this.KHR_iridescenceTexture?.gpuTexture?.width||1,this.KHR_iridescenceThicknessTexture?.gpuTexture?.width||1),g=Math.max(this.KHR_iridescenceTexture?.gpuTexture?.height||1,this.KHR_iridescenceThicknessTexture?.gpuTexture?.height||1);await this.#fs.packing({r:this.KHR_iridescenceTexture?.gpuTexture,g:this.KHR_iridescenceThicknessTexture?.gpuTexture},i,g,"packedKHR_iridescence")}}dr.defineByPreset(PBRMaterial,[dr.PRESET_POSITIVE_NUMBER.EMISSIVE_STRENGTH,dr.PRESET_POSITIVE_NUMBER.NORMAL_SCALE]);kr.forEach(i=>{const{extensionName:g,textureList:x,useSampler:_}=i,{positiveNumberList:v,vec3List:b,vec4List:y}=i;g&&dr.defineBoolean(PBRMaterial,[`use${g}`]),((i,g)=>{i?.forEach(i=>{dr.defineBoolean(PBRMaterial,[`use${i.charAt(0).toUpperCase()}${i.substring(1)}`]),dr.definePositiveNumber(PBRMaterial,[[`${i}_KHR_texture_transform_rotation`,0]]),dr.defineBoolean(PBRMaterial,[`use_${i}_KHR_texture_transform`]),dr.defineVec2(PBRMaterial,[`${i}_KHR_texture_transform_offset`,[`${i}_KHR_texture_transform_scale`,[1,1]]]),dr.defineUint(PBRMaterial,[`${i}_texCoord_index`]),dr.defineTexture(PBRMaterial,[i]),g&&dr.defineSampler(PBRMaterial,[`${i}Sampler`])})})(x,!_),v?.forEach(i=>{dr.definePositiveNumber(PBRMaterial,[i])}),b?.forEach(i=>{dr.defineVec3(PBRMaterial,[i])}),y?.forEach(i=>{dr.defineVec4(PBRMaterial,[i])})}),dr.definePositiveNumber(PBRMaterial,[["cutOff",0],["KHR_materials_ior",1.5],["KHR_dispersion",0]]),dr.defineUint(PBRMaterial,["alphaBlend"]),dr.defineBoolean(PBRMaterial,["doubleSided","useCutOff","useVertexColor","useVertexTangent","useKHR_materials_unlit",["useSSR",!0]]),Object.freeze(PBRMaterial);var Nr="struct InputData { @location(0) position:vec3, @location(1) vertexNormal:vec3, @location(2) uv:vec2, @location(3) uv1:vec2, @location(4) vertexColor_0:vec4, @location(5) vertexTangent:vec4,\n};",Vr="struct OutputData { @builtin(position) position:vec4, @location(0) vertexPosition:vec3, @location(1) vertexNormal:vec3, @location(2) uv:vec2, @location(3) uv1:vec2, @location(4) vertexColor_0:vec4, @location(5) vertexTangent:vec4, @location(7) currentClipPos:vec4, @location(8) prevClipPos:vec4, @location(10) localNodeScale_volumeScale:vec2, @location(11) combinedOpacity:f32, @location(12) motionVector:vec3, @location(13) shadowPos:vec3, @location(14) @interpolate(flat) receiveShadow:f32, @location(15) @interpolate(flat) pickingId:vec4,\n};",Fr="struct InputData { @location(0) position:vec3, @location(1) vertexNormal:vec3, @location(2) uv:vec2,\n};\n",Hr="struct OutputData { @builtin(position) position:vec4, @location(0) vertexPosition:vec3, @location(1) vertexNormal:vec3, @location(2) uv:vec2, @location(7) currentClipPos:vec4, @location(8) prevClipPos:vec4, @location(11) combinedOpacity:f32, @location(12) motionVector:vec3, @location(13) shadowPos:vec3, @location(14) @interpolate(flat) receiveShadow:f32, @location(15) @interpolate(flat) pickingId:vec4,\n};",zr="#redgpu_include SYSTEM_UNIFORM;\n#redgpu_include drawDirectionalShadowDepth;\n#redgpu_include picking;\n#redgpu_include calcDisplacements;\n#redgpu_include meshVertexBasicUniform;\nconst maxDistance:f32=1000.0;\nconst maxMipLevel:f32=10.0;\n@group(1) @binding(0) var vertexUniforms:VertexUniforms;\n@group(1) @binding(1) var displacementTextureSampler:sampler;\n@group(1) @binding(2) var displacementTexture:texture_2d;\n@vertex\nfn main(inputData:InputData) -> OutputData { var output:OutputData; #redgpu_if disableJitter { let u_projectionMatrix=systemUniforms.noneJitterProjectionCameraMatrix; } #redgpu_else { let u_projectionMatrix=systemUniforms.projectionMatrix; } #redgpu_endIf let u_projectionCameraMatrix=systemUniforms.projectionCameraMatrix; let u_noneJitterProjectionCameraMatrix=systemUniforms.noneJitterProjectionCameraMatrix; let u_prevNoneJitterProjectionCameraMatrix=systemUniforms.prevNoneJitterProjectionCameraMatrix; let u_resolution=systemUniforms.resolution; let u_camera=systemUniforms.camera; let u_cameraMatrix=u_camera.cameraMatrix; let u_cameraPosition=u_camera.cameraPosition; let u_matrixList=vertexUniforms.matrixList; let u_modelMatrix=u_matrixList.modelMatrix; let u_prevModelMatrix=u_matrixList.prevModelMatrix; let u_normalModelMatrix=u_matrixList.normalModelMatrix; let u_displacementScale=vertexUniforms.displacementScale; let u_useDisplacementTexture=vertexUniforms.useDisplacementTexture==1u; let u_receiveShadow=vertexUniforms.receiveShadow; let u_directionalLightCount=systemUniforms.directionalLightCount; let u_directionalLights=systemUniforms.directionalLights; let u_directionalLightProjectionViewMatrix=systemUniforms.directionalLightProjectionViewMatrix; let input_position=inputData.position; let input_position_vec4=vec4(input_position,1.0); let input_vertexNormal=inputData.vertexNormal; let input_uv=inputData.uv; var position:vec4; var normalPosition:vec4; #redgpu_if useDisplacementTexture let tempPosition=u_modelMatrix * input_position_vec4; let distance=distance(tempPosition.xyz,u_cameraPosition); let mipLevel=(distance/maxDistance) * maxMipLevel; let displacedPosition=calcDisplacementPosition( input_position, input_vertexNormal, displacementTexture, displacementTextureSampler, u_displacementScale, input_uv, mipLevel ); position=u_modelMatrix * vec4(displacedPosition,1.0); let worldUV=input_uv; let displacedNormal=calcDisplacementNormal( normalize((u_normalModelMatrix * vec4(input_vertexNormal,0.0)).xyz), displacementTexture, displacementTextureSampler, u_displacementScale, worldUV, mipLevel ); normalPosition=vec4(displacedNormal,0.0); #redgpu_else position=u_modelMatrix * input_position_vec4; normalPosition=u_normalModelMatrix * vec4(input_vertexNormal,1.0); #redgpu_endIf output.position=u_projectionCameraMatrix * position; output.vertexPosition=position.xyz; output.vertexNormal=normalPosition.xyz; output.uv=input_uv * vertexUniforms.uvTransform.zw + vertexUniforms.uvTransform.xy; output.combinedOpacity=vertexUniforms.combinedOpacity; #redgpu_if receiveShadow { let posFromLight=u_directionalLightProjectionViewMatrix * vec4(position.xyz,1.0); output.shadowPos=vec3(posFromLight.xy * vec2(0.5,-0.5) + vec2(0.5),posFromLight.z); output.receiveShadow=vertexUniforms.receiveShadow; } #redgpu_endIf { output.currentClipPos=u_noneJitterProjectionCameraMatrix * position; output.prevClipPos=u_prevNoneJitterProjectionCameraMatrix * u_prevModelMatrix * input_position_vec4; } return output;\n}\n";const $r={SHADER_INFO_PBR:parseWGSL([Nr,Vr,"#redgpu_include SYSTEM_UNIFORM;\n#redgpu_include drawDirectionalShadowDepth;\n#redgpu_include picking;\n#redgpu_include meshVertexBasicUniform;\nconst maxDistance:f32=1000.0;\nconst maxMipLevel:f32=10.0;\n@group(1) @binding(0) var vertexUniforms:VertexUniforms;\n@group(1) @binding(1) var displacementTextureSampler:sampler;\n@group(1) @binding(2) var displacementTexture:texture_2d;\n@vertex\nfn main(inputData:InputData) -> OutputData { var output:OutputData; let input_position=inputData.position; let input_position_vec4=vec4(input_position,1.0); let input_vertexNormal=inputData.vertexNormal; let u_projectionMatrix=systemUniforms.projectionMatrix; let u_projectionCameraMatrix=systemUniforms.projectionCameraMatrix; let u_noneJitterProjectionCameraMatrix=systemUniforms.noneJitterProjectionCameraMatrix; let u_prevNoneJitterProjectionCameraMatrix=systemUniforms.prevNoneJitterProjectionCameraMatrix; let u_resolution=systemUniforms.resolution; let u_camera=systemUniforms.camera; let u_cameraMatrix=u_camera.cameraMatrix; let u_cameraPosition=u_camera.cameraPosition; let u_matrixList=vertexUniforms.matrixList; let u_localMatrix=u_matrixList.localMatrix; let u_modelMatrix=u_matrixList.modelMatrix; let u_normalModelMatrix=u_matrixList.normalModelMatrix; let u_prevModelMatrix=u_matrixList.prevModelMatrix; let u_receiveShadow=vertexUniforms.receiveShadow; let u_directionalLightCount=systemUniforms.directionalLightCount; let u_directionalLights=systemUniforms.directionalLights; let u_directionalLightProjectionViewMatrix=systemUniforms.directionalLightProjectionViewMatrix; var position:vec4; var normalPosition:vec4; position=u_modelMatrix * input_position_vec4; normalPosition=u_normalModelMatrix * vec4(input_vertexNormal,0.0); output.position=u_projectionCameraMatrix * position; output.vertexPosition=position.xyz; output.vertexNormal=normalize(normalPosition.xyz); output.uv=inputData.uv; output.uv1=inputData.uv1; output.vertexColor_0=inputData.vertexColor_0; let transformedTangentXYZ=(u_normalModelMatrix * vec4(inputData.vertexTangent.xyz,0.0)).xyz; output.vertexTangent=vec4( normalize(transformedTangentXYZ),inputData.vertexTangent.w ); #redgpu_if receiveShadow { let posFromLight=u_directionalLightProjectionViewMatrix * vec4(position.xyz,1.0); output.shadowPos=vec3(posFromLight.xy * vec2(0.5,-0.5) + vec2(0.5),posFromLight.z); output.receiveShadow=vertexUniforms.receiveShadow; } #redgpu_endIf { output.currentClipPos=u_noneJitterProjectionCameraMatrix * position; output.prevClipPos=u_prevNoneJitterProjectionCameraMatrix * u_prevModelMatrix * input_position_vec4; } let nodeScaleX=length(u_localMatrix[0].xyz); let nodeScaleY=length(u_localMatrix[1].xyz); let nodeScaleZ=length(u_localMatrix[2].xyz); let volumeScaleX=length(u_modelMatrix[0].xyz); let volumeScaleY=length(u_modelMatrix[1].xyz); let volumeScaleZ=length(u_modelMatrix[2].xyz); output.localNodeScale_volumeScale=vec2( pow(nodeScaleX * nodeScaleY * nodeScaleZ,1.0/3.0), pow(volumeScaleX * volumeScaleY * volumeScaleZ,1.0/3.0) ); return output;\n}\n"].join("\n")),SHADER_INFO_BASIC:parseWGSL([Fr,Hr,zr].join("\n")),SHADER_INFO_ONLY_FRAGMENT_PBR:parseWGSL([Fr,Vr,zr].join("\n")),SHADER_INFO_ONLY_VERTEX_PBR:parseWGSL([Nr,Hr,zr].join("\n"))};Object.freeze($r);const{SHADER_INFO_PBR:Kr,SHADER_INFO_BASIC:Xr,SHADER_INFO_ONLY_FRAGMENT_PBR:jr,SHADER_INFO_ONLY_VERTEX_PBR:Yr}=$r,qr=Kr.shaderSourceVariant.getVariant("none"),Wr=Xr.shaderSourceVariant.getVariant("none"),Zr=jr.shaderSourceVariant.getVariant("none"),Jr=Yr.shaderSourceVariant.getVariant("none");class LODManager{#ms=[];#ps;#gs=!1;constructor(i,g){"InstancingMesh"===i.constructor.name&&(this.#gs=!0),this.#ps=g}get LODList(){return[...this.#ms]}addLOD(i,g,x){if(validatePositiveNumberRange(i,1),this.#ms.length>=8)throw new Error("Maximum of 8 LOD levels allowed.");if(this.#ms.some(g=>g.distance===i))throw new Error(`LOD with distance ${i} already exists.`);const _="PBR"===g.vertexBuffer.interleavedStruct.label,v=x instanceof PBRMaterial,b={distance:i,distanceSquared:i*i,geometry:g,material:x,geometryIsPBR:_,materialIsPBR:v};this.#ms.push({...b,...this.#gs?{}:{label:`vertex_${_?"pbr":"noPbr"}_fragment_${v?"pbr":"noPbr"}`,source:this.#xs(g,x)}}),this.#ms.sort((i,g)=>i.distance-g.distance),this.#ps?.()}getLOD(i){for(const g of this.#ms)if(ig.distance!==i),this.#ps?.()}clearLOD(){this.#ms.length=0,this.#ps?.()}#xs(i,g){const x="PBR"===i.vertexBuffer.interleavedStruct.label,_=g instanceof PBRMaterial;return x&&_?qr:!x&&_?Zr:x&&!_?Jr:Wr}}const Qr=Object.values(Tn);class DepthStencilState{#_s;#F="depth32float";#vs=["r8unorm","r8snorm","r8uint","r8sint","r16uint","r16sint","r16float","rg8unorm","rg8snorm","rg8uint","rg8sint","r32uint","r32sint","r32float","rg16uint","rg16sint","rg16float","rgba8unorm","rgba8unorm-srgb","rgba8snorm","rgba8uint","rgba8sint","bgra8unorm","bgra8unorm-srgb","rgb9e5ufloat","rgb10a2uint","rgb10a2unorm","rg11b10ufloat","rg32uint","rg32sint","rg32float","rgba16uint","rgba16sint","rgba16float","rgba32uint","rgba32sint","rgba32float","stencil8","depth16unorm","depth24plus","depth24plus-stencil8","depth32float","depth32float-stencil8","bc1-rgba-unorm","bc1-rgba-unorm-srgb","bc2-rgba-unorm","bc2-rgba-unorm-srgb","bc3-rgba-unorm","bc3-rgba-unorm-srgb","bc4-r-unorm","bc4-r-snorm","bc5-rg-unorm","bc5-rg-snorm","bc6h-rgb-ufloat","bc6h-rgb-float","bc7-rgba-unorm","bc7-rgba-unorm-srgb","etc2-rgb8unorm","etc2-rgb8unorm-srgb","etc2-rgb8a1unorm","etc2-rgb8a1unorm-srgb","etc2-rgba8unorm","etc2-rgba8unorm-srgb","eac-r11unorm","eac-r11snorm","eac-rg11unorm","eac-rg11snorm","astc-4x4-unorm","astc-4x4-unorm-srgb","astc-5x4-unorm","astc-5x4-unorm-srgb","astc-5x5-unorm","astc-5x5-unorm-srgb","astc-6x5-unorm","astc-6x5-unorm-srgb","astc-6x6-unorm","astc-6x6-unorm-srgb","astc-8x5-unorm","astc-8x5-unorm-srgb","astc-8x6-unorm","astc-8x6-unorm-srgb","astc-8x8-unorm","astc-8x8-unorm-srgb","astc-10x5-unorm","astc-10x5-unorm-srgb","astc-10x6-unorm","astc-10x6-unorm-srgb","astc-10x8-unorm","astc-10x8-unorm-srgb","astc-10x10-unorm","astc-10x10-unorm-srgb","astc-12x10-unorm","astc-12x10-unorm-srgb","astc-12x12-unorm","astc-12x12-unorm-srgb"];#bs=!0;#ys=Tn.LESS_EQUAL;#Ss;#Ts;#Ms;#ws;#Cs=1;#Rs=1;#Ps=1;constructor(i){this.#_s=i}get format(){return this.#F}set format(i){this.#vs.includes(i)?(this.#F=i,this.#_s.dirtyPipeline=!0):consoleAndThrowError(`Invalid value for format. Received ${i}. Expected one of:${this.#vs.join(",")}`)}get depthWriteEnabled(){return this.#bs}set depthWriteEnabled(i){this.#bs=i,this.#_s.dirtyPipeline=!0}get depthCompare(){return this.#ys}set depthCompare(i){Qr.includes(i)?(this.#ys=i,this.#_s.dirtyPipeline=!0):consoleAndThrowError(`Invalid value for depthCompare. Received ${i}. Expected one of:${Qr.join(",")}`)}get stencilFront(){return this.#Ss}set stencilFront(i){this.#Ss=i,this.#_s.dirtyPipeline=!0}get stencilBack(){return this.#Ts}set stencilBack(i){this.#Ts=i,this.#_s.dirtyPipeline=!0}get stencilReadMask(){return this.#Ms}set stencilReadMask(i){this.#Ms=i,this.#_s.dirtyPipeline=!0}get stencilWriteMask(){return this.#ws}set stencilWriteMask(i){this.#ws=i,this.#_s.dirtyPipeline=!0}get depthBias(){return this.#Cs}set depthBias(i){this.#Cs=i,this.#_s.dirtyPipeline=!0}get depthBiasSlopeScale(){return this.#Rs}set depthBiasSlopeScale(i){this.#Rs=i,this.#_s.dirtyPipeline=!0}get depthBiasClamp(){return this.#Ps}set depthBiasClamp(i){this.#Ps=i,this.#_s.dirtyPipeline=!0}get state(){let i=!1;if(this.#_s?.primitiveState){const{topology:g}=this.#_s.primitiveState;i=g===Lr.TRIANGLE_LIST||g===Lr.TRIANGLE_STRIP}return{format:this.#F,depthWriteEnabled:this.#bs,depthCompare:this.#ys,stencilFront:this.#Ss,stencilBack:this.#Ts,stencilReadMask:this.#Ms,stencilWriteMask:this.#ws,depthBias:i?this.#Cs:null,depthBiasSlopeScale:i?this.#Rs:null,depthBiasClamp:i?this.#Ps:null}}}const ei={NONE:"none",FRONT:"front",BACK:"back"};Object.freeze(ei);const ti={CW:"cw",CCW:"ccw"};Object.freeze(ti);const ni=Object.values(Dr),ri=Object.values(ti),ii=Object.values(ei),ai=["point-list","line-list","line-strip","triangle-list","triangle-strip"];class PrimitiveState{dirtyPipeline=!1;state;#_s;#Bs=Lr.TRIANGLE_LIST;#Is;#Es=ti.CCW;#Ds=ei.BACK;#Us=!1;constructor(i){this.#_s=i,this.#in()}get topology(){return this.#Bs}set topology(i){ai.includes(i)?(this.#Bs=i,this.#in()):consoleAndThrowError(`Invalid value for topology. Received ${i}. Expected one of:${ai.join(",")}`)}get stripIndexFormat(){return this.#Is}set stripIndexFormat(i){ni.includes(i)?(this.#Is=i,this.#in()):consoleAndThrowError(`Invalid value for stripIndexFormat. Received ${i}. Expected one of:${ni.join(",")}`)}get frontFace(){return this.#Es}set frontFace(i){ri.includes(i)?(this.#Es=i,this.#in()):consoleAndThrowError(`Invalid value for frontFace. Received ${i}. Expected one of:${ri.join(",")}`)}get cullMode(){return this.#Ds}set cullMode(i){ii.includes(i)?(this.#Ds=i,this.#in()):consoleAndThrowError(`Invalid value for cullMode. Received ${i}. Expected one of:${ii.join(",")}`)}get unclippedDepth(){return this.#Us}set unclippedDepth(i){"boolean"==typeof i?(this.#Us=i,this.#in()):consoleAndThrowError(`Invalid type for unclippedDepth. Received ${typeof i}. Expected type:boolean.`)}#in(){this.state={topology:this.#Bs,stripIndexFormat:this.#Is,frontFace:this.#Es,cullMode:this.#Ds,unclippedDepth:this.#Us},this.#_s.dirtyPipeline=!0}}const si=create$4(),oi={x:0,y:0,z:0,w:0},getScreenPoint=(i,g)=>{"View3D"!==i?.constructor?.name&&consoleAndThrowError("allow only View3D instance"),identity$1(si);const{noneJitterProjectionMatrix:x,rawCamera:_,pixelRectArray:v}=i;return multiply$4(si,x,_.modelMatrix),multiply$4(si,si,g),oi.z=si[14],oi.w=si[15],oi.x=.5*si[12]/oi.w+.5,oi.y=.5*si[13]/oi.w+.5,[(v[0]+oi.x*v[2])/window.devicePixelRatio,(v[1]+(1-oi.y)*v[3])/window.devicePixelRatio]},ui=create$4(),localToWorld=(i,g,x,_)=>(validateNumber(g),validateNumber(x),validateNumber(_),identity$1(ui),translate(ui,ui,[g,x,_]),multiply$4(ui,i,ui),[ui[12],ui[13],ui[14]]),li=create$4(),ci=create$3(),worldToLocal=(i,g,x,_)=>(validateNumber(g),validateNumber(x),validateNumber(_),invert$1(li,i),set$3(ci,g,x,_),transformMat4$2(ci,ci,li),[ci[0],ci[1],ci[2]]);class Object3DContainer{modelMatrix=create$4();#Ls=[];constructor(){}get children(){return this.#Ls}get numChildren(){return this.#Ls.length}contains(i){return this.#As(i),this.#Ls.includes(i)}addChild(i){return this.#As(i),this.#Gs(i)?(this.#Ls.push(i),i.dirtyTransform=!0,i):null}addChildAt(i,g){if(validateUintRange(g),this.#Ls.lengththis.#Ls.length)&&this.#Gs(i))return this.#Ls.splice(g,0,i),i.dirtyTransform=!0,this}getChildAt(i){if(validateUintRange(i),!(i>=this.#Ls.length||i<0))return this.#Ls[i]}getChildIndex(i){this.#As(i);const g=this.#Ls.indexOf(i);return-1===g?-1:g}setChildIndex(i,g){this.#As(i),validateUintRange(g);const x=this.#Ls.length,_=g>=x,v=this.#Ls.indexOf(i);-1!==v?_?consoleAndThrowError(`Invalid index. Index ${g} is out of bounds. Index should be between 0 and ${x-1}.`):(this.#Ls.splice(v,1),this.#Ls.splice(g,0,i)):consoleAndThrowError(`The provided is not a child of the Object3DContainer.:${i}`)}swapChildren(i,g){if(this.#As(i),this.#As(g),i===g)return void consoleAndThrowError("Error:child1 and child2 are the same. Cannot swap a child with itself.");const x=this.#Ls.indexOf(i),_=this.#Ls.indexOf(g);-1!==x&&-1!==_||consoleAndThrowError(`Error:${-1===x?"child1":"child2"} is not a child of this Object3DContainer.`),this.swapChildrenAt(x,_)}swapChildrenAt(i,g){validateUintRange(i),validateUintRange(g),i===g&&consoleAndThrowError("Error:index1 and index2 are identical. Cannot swap a child with itself.");const x=this.#Ls.length;(i>=x||g>=x)&&consoleAndThrowError(`Error:Both index1 and index2 should be less than the number of children. Provided index1:${i},index2:${g},number of children:${x}`);let _=this.#Ls[i];this.#Ls[i]=this.#Ls[g],this.#Ls[g]=_}removeChild(i){this.#As(i);const g=this.#Ls.indexOf(i);if(g>-1)return i.parent=null,this.#Ls.splice(g,1)[0];consoleAndThrowError("Error:Child not found within parent.")}removeChildAt(i){validateUintRange(i);const g=this.#Ls[i];if(g)return g.parent=null,this.#Ls.splice(i,1)[0];throw new Error(`Error:No child found at provided index:${i}.`)}removeAllChildren(){let i=this.#Ls.length;for(;i--;)this.#Ls[i].parent=null;return this.#Ls.length=0,this}#As(i){i instanceof Object3DContainer||consoleAndThrowError("allow only Object3DContainer instance.")}#Gs=i=>(this.#As(i),i.parent?!!i.parent?.removeChild(i)&&(i.parent=this,!0):(i.parent=this,!0))}class MeshBase extends Object3DContainer{gpuRenderInfo;animationInfo={skinInfo:null,morphInfo:null,weightBuffer:null,jointBuffer:null,animationsList:null};gltfLoaderInfo;dirtyPipeline=!0;dirtyTransform=!0;dirtyOpacity=!0;modelMatrix=create$4();localMatrix=create$4();normalModelMatrix=create$4();#l;#c;#ks;#Os;#Ns;#m=[];#u=createUUID();constructor(i){super(),validateRedGPUContext(i),this.#l=i,this.#c=i.gpuDevice,this.#ks=new PrimitiveState(this),this.#Os=new DepthStencilState(this)}get uuid(){return this.#u}get currentShaderModuleName(){return this.#Ns}set currentShaderModuleName(i){this.#Ns=i}get primitiveState(){return this.#ks}get depthStencilState(){return this.#Os}get gpuDevice(){return this.#c}get redGPUContext(){return this.#l}worldToLocal(i,g,x){return worldToLocal(this.modelMatrix,i,g,x)}localToWorld(i,g,x){return localToWorld(this.modelMatrix,i,g,x)}getScreenPoint(i){return getScreenPoint(i,this.modelMatrix)}__fireListenerList(i=!1){for(const i of this.#m)i(this);i&&(this.#m.length=0)}}const hi="shadow",fi="picking",createBasePipeline=(i,g,x,_)=>{const{redGPUContext:v}=i,{gpuDevice:b,resourceManager:y}=v,S=i.material.gpuRenderInfo;let w,L;switch(_){case hi:w="drawDirectionalShadowDepth",L=`${g.label}_shadow_pipeline`;break;case fi:w="picking",L=`${g.label}_picking_pipeline`;break;default:w="main",L=`${g.label}_pipeline`}const k={module:g,entryPoint:w,buffers:i.vertexStateBuffers},H=[y.getGPUBindGroupLayout(ResourceManager.PRESET_GPUBindGroupLayout_System),x];_!==hi&&H.push(S.fragmentBindGroupLayout);const z={bindGroupLayouts:H,label:`${L}_${S.fragmentBindGroupLayout.label}`},q={label:L,layout:y.createGPUPipelineLayout(`${z.label}`,z),vertex:k,primitive:i.primitiveState.state};switch(_){case hi:q.depthStencil={depthWriteEnabled:!0,depthCompare:Tn.LESS_EQUAL,format:"depth32float"};break;case fi:i.material&&(q.fragment={module:i.material.gpuRenderInfo.fragmentShaderModule,entryPoint:"picking",targets:[{format:navigator.gpu.getPreferredCanvasFormat()}]},q.depthStencil=i.depthStencilState.state);break;default:q.fragment=S.fragmentState,q.depthStencil=i.depthStencilState.state,q.multisample={count:v.antialiasingManager.useMSAA?4:1}}return b.createRenderPipeline(q)};const getBasicMeshVertexBindGroupDescriptor=(i,g=!1)=>{const{redGPUContext:x,gpuRenderInfo:_,material:v}=i,{resourceManager:b}=x,{vertexUniformBuffer:y,vertexBindGroupLayout:S}=_,{basicSampler:w,emptyBitmapTextureView:L,emptyCubeTextureView:k}=b,{gpuSampler:H}=w;return{layout:S,label:g?"VERTEX_BIND_GROUP_DESCRIPTOR_MESH_SKIN":"VERTEX_BIND_GROUP_DESCRIPTOR_MESH",entries:g?[{binding:0,resource:{buffer:y.gpuBuffer,offset:0,size:y.size}},{binding:1,resource:getGPUResourceSampler(v?.displacementTextureSampler)||H},{binding:2,resource:b.getGPUResourceBitmapTextureView(v?.displacementTexture)||L},{binding:3,resource:{buffer:i.animationInfo.skinInfo.vertexStorageBuffer,offset:0,size:i.animationInfo.skinInfo.vertexStorageBuffer.size}},{binding:4,resource:{buffer:i.animationInfo.skinInfo.prevVertexStorageBuffer,offset:0,size:i.animationInfo.skinInfo.prevVertexStorageBuffer.size}}]:[{binding:0,resource:{buffer:y.gpuBuffer,offset:0,size:y.size}},{binding:1,resource:getGPUResourceSampler(v?.displacementTextureSampler)||H},{binding:2,resource:b.getGPUResourceBitmapTextureView(v?.displacementTexture)||L}]}},getGPUResourceSampler=i=>i?.gpuSampler,{SHADER_INFO_PBR:di,SHADER_INFO_BASIC:mi,SHADER_INFO_ONLY_FRAGMENT_PBR:pi,SHADER_INFO_ONLY_VERTEX_PBR:gi}=$r,xi=di.uniforms.vertexUniforms,_i=mi.uniforms.vertexUniforms,createMeshVertexShaderModule=i=>{const{material:g}=i;let x,_="basic";switch(g instanceof PBRMaterial&&i.animationInfo?.skinInfo?_="skin":i.createCustomMeshVertexShaderModule&&(_="custom"),_){case"basic":{const g=(i=>{const{geometry:g,material:x}=i,_="PBR"===g.vertexBuffer.interleavedStruct.label,v=x instanceof PBRMaterial,b=_&&!v,y=!_&&v;return _&&v?{name:"VERTEX_MODULE_MESH_PBR",shaderInfo:di,source:di.defaultSource,uniformStruct:xi}:y?{name:"VERTEX_MODULE_MESH_ONLY_FRAGMENT_PBR",shaderInfo:pi,source:pi.defaultSource,uniformStruct:_i}:b?{name:"VERTEX_MODULE_MESH_ONLY_VERTEX_PBR",shaderInfo:gi,source:gi.defaultSource,uniformStruct:_i}:{name:"VERTEX_MODULE_MESH",shaderInfo:mi,source:mi.defaultSource,uniformStruct:_i}})(i);x=i.createMeshVertexShaderModuleBASIC(g.name,g.shaderInfo,g.uniformStruct,g.source);break}case"skin":x=((i,g)=>{const{redGPUContext:x,currentShaderModuleName:_}=g,{resourceManager:v,gpuDevice:b}=x,{gpuRenderInfo:y}=g,S=`${g.animationInfo.skinInfo.joints.length}`,w=`${i}_${S}`,L="#redgpu_include SYSTEM_UNIFORM;\n#redgpu_include meshVertexBasicUniform;\nconst maxDistance:f32=1000.0;\nconst maxMipLevel:f32=10.0;\n@group(1) @binding(0) var vertexUniforms:VertexUniforms;\n@group(1) @binding(1) var displacementTextureSampler:sampler;\n@group(1) @binding(2) var displacementTexture:texture_2d;\n@group(1) @binding(3) var vertexStorages:array>;\n@group(1) @binding(4) var prevVertexStorages:array>;\nstruct InputDataSkin { @builtin(vertex_index) idx:u32, @location(0) position:vec3, @location(1) vertexNormal:vec3, @location(2) uv:vec2, @location(3) uv1:vec2, @location(4) vertexColor_0:vec4, @location(5) vertexTangent:vec4,\n};\nstruct OutputDataSkin { @builtin(position) position:vec4, @location(0) vertexPosition:vec3, @location(1) vertexNormal:vec3, @location(2) uv:vec2, @location(3) uv1:vec2, @location(4) vertexColor_0:vec4, @location(5) vertexTangent:vec4, @location(7) currentClipPos:vec4, @location(8) prevClipPos:vec4, @location(10) localNodeScale_volumeScale:vec2, @location(11) combinedOpacity:f32, @location(12) motionVector:vec3, @location(13) shadowPos:vec3, @location(14) @interpolate(flat) receiveShadow:f32, @location(15) @interpolate(flat) pickingId:vec4,\n};\nstruct OutputShadowData { @builtin(position) position:vec4,\n};\n@vertex\nfn main(inputData:InputDataSkin) -> OutputDataSkin { var output:OutputDataSkin; let input_position=inputData.position; let input_position_vec4=vec4(input_position,1.0); let input_vertexNormal=inputData.vertexNormal; let u_projectionMatrix=systemUniforms.projectionMatrix; let u_projectionCameraMatrix=systemUniforms.projectionCameraMatrix; let u_noneJitterProjectionCameraMatrix=systemUniforms.noneJitterProjectionCameraMatrix; let u_prevNoneJitterProjectionCameraMatrix=systemUniforms.prevNoneJitterProjectionCameraMatrix; let u_resolution=systemUniforms.resolution; let u_camera=systemUniforms.camera; let u_cameraMatrix=u_camera.cameraMatrix; let u_cameraPosition=u_camera.cameraPosition; let u_matrixList=vertexUniforms.matrixList; let u_localMatrix=u_matrixList.localMatrix; let u_modelMatrix=u_matrixList.modelMatrix; let u_prevModelMatrix=u_matrixList.prevModelMatrix; let u_normalModelMatrix=u_matrixList.normalModelMatrix; let u_receiveShadow=vertexUniforms.receiveShadow; let u_directionalLightCount=systemUniforms.directionalLightCount; let u_directionalLights=systemUniforms.directionalLights; let u_directionalLightProjectionViewMatrix=systemUniforms.directionalLightProjectionViewMatrix; let skinMat=vertexStorages[inputData.idx]; let prevSkinMat=prevVertexStorages[inputData.idx]; let skinnedPosition=(skinMat * vec4(inputData.position,1.0)); let position=u_modelMatrix * skinnedPosition; let skinnedNormal=(skinMat * vec4(input_vertexNormal,0.0)).xyz; let transformedNormal=normalize((u_normalModelMatrix * vec4(skinnedNormal,0.0)).xyz); output.vertexNormal=transformedNormal; let skinnedTangent=(skinMat * vec4(inputData.vertexTangent.xyz,0.0)).xyz; let transformedTangentXYZ=(u_normalModelMatrix * vec4(skinnedTangent,0.0)).xyz; output.vertexTangent=vec4(normalize(transformedTangentXYZ),inputData.vertexTangent.w); output.position=u_projectionCameraMatrix * position; output.vertexPosition=position.xyz; output.uv=inputData.uv; output.uv1=inputData.uv1; output.vertexColor_0=inputData.vertexColor_0; #redgpu_if receiveShadow { let posFromLight=u_directionalLightProjectionViewMatrix * vec4(position.xyz,1.0); output.shadowPos=vec3(posFromLight.xy * vec2(0.5,-0.5) + vec2(0.5),posFromLight.z); output.receiveShadow=vertexUniforms.receiveShadow; } #redgpu_endIf { output.currentClipPos=u_noneJitterProjectionCameraMatrix * position; output.prevClipPos=u_prevNoneJitterProjectionCameraMatrix * u_prevModelMatrix * (prevSkinMat * input_position_vec4); } let nodeScaleX=length(u_localMatrix[0].xyz); let nodeScaleY=length(u_localMatrix[1].xyz); let nodeScaleZ=length(u_localMatrix[2].xyz); let volumeScaleX=length(u_modelMatrix[0].xyz); let volumeScaleY=length(u_modelMatrix[1].xyz); let volumeScaleZ=length(u_modelMatrix[2].xyz); output.localNodeScale_volumeScale=vec2( pow(nodeScaleX * nodeScaleY * nodeScaleZ,1.0/3.0), pow(volumeScaleX * volumeScaleY * volumeScaleZ,1.0/3.0) ); return output;\n}\n@vertex\nfn drawDirectionalShadowDepth(inputData:InputDataSkin) -> OutputShadowData { var output:OutputShadowData; let u_directionalLightProjectionViewMatrix=systemUniforms.directionalLightProjectionViewMatrix; let u_modelMatrix=vertexUniforms.matrixList.modelMatrix; let input_position=inputData.position;\nlet skinMat=vertexStorages[inputData.idx]; let position=u_modelMatrix * skinMat * vec4(input_position,1.0); output.position=u_directionalLightProjectionViewMatrix * position; return output;\n}\n@vertex\nfn picking(inputData:InputDataSkin) -> OutputDataSkin { var output:OutputDataSkin; let u_projectionMatrix=systemUniforms.projectionMatrix; let u_projectionCameraMatrix=systemUniforms.projectionCameraMatrix; let u_camera=systemUniforms.camera; let u_cameraMatrix=u_camera.cameraMatrix; let u_modelMatrix=vertexUniforms.matrixList.modelMatrix;\nlet skinMat=vertexStorages[inputData.idx]; let position=u_modelMatrix * skinMat * vec4(inputData.position,1.0); output.position=u_projectionCameraMatrix * position; output.pickingId=unpack4x8unorm(vertexUniforms.pickingId); return output;\n}\n",k={code:L};if(_===w)return v.getGPUShaderModule(w);k.code=L.replaceAll("#JOINT_NUM",S),y.vertexUniformInfo=parseWGSL(k.code).uniforms.vertexUniforms,g.animationInfo.skinInfo?(createMeshVertexUniformBuffers(g,!0),g.animationInfo.skinInfo.vertexStorageInfo=parseWGSL(k.code).storage.vertexStorages,g.animationInfo.skinInfo.vertexStorageBuffer=b.createBuffer({size:16*g.geometry.vertexBuffer.vertexCount*4,usage:GPUBufferUsage.STORAGE|GPUBufferUsage.COPY_SRC|GPUBufferUsage.COPY_DST}),g.animationInfo.skinInfo.prevVertexStorageBuffer=b.createBuffer({size:16*g.geometry.vertexBuffer.vertexCount*4,usage:GPUBufferUsage.STORAGE|GPUBufferUsage.COPY_SRC|GPUBufferUsage.COPY_DST}),y.vertexUniformBindGroup=x.gpuDevice.createBindGroup(getBasicMeshVertexBindGroupDescriptor(g,!0))):(createMeshVertexUniformBuffers(g),y.vertexUniformBindGroup=x.gpuDevice.createBindGroup(getBasicMeshVertexBindGroupDescriptor(g)));const H=v.createGPUShaderModule(w,k);return g.gpuRenderInfo.vertexShaderModule=H,g.gpuRenderInfo.vertexShaderModule})("VERTEX_MODULE_MESH_PBR_SKIN",i);break;case"custom":x=i.createCustomMeshVertexShaderModule()}return i.currentShaderModuleName=x.label,x},updateMeshDirtyPipeline=(i,g)=>{const{material:x,gpuRenderInfo:_,redGPUContext:v}=i,{resourceManager:b}=v;i.dirtyTransform=!0,x.dirtyPipeline&&x._updateFragmentState();const y=createMeshVertexShaderModule(i),S=b.getGPUBindGroupLayout(i.animationInfo.skinInfo?ResourceManager.PRESET_VERTEX_GPUBindGroupLayout_SKIN:ResourceManager.PRESET_VERTEX_GPUBindGroupLayout);_.vertexShaderModule=y,_.pipeline=createBasePipeline(i,y,S),_.shadowPipeline=null,_.pickingPipeline=null;const{vertexUniformInfo:w}=i.gpuRenderInfo,{members:L}=w;for(const g in L)"pickingId"!==g&&"pixelSize"!==g&&(i[g]=i[g]);i.gpuRenderInfo.vertexUniformInfo.members.pickingId&&i.gpuRenderInfo.vertexUniformBuffer.writeOnlyBuffer(i.gpuRenderInfo.vertexUniformInfo.members.pickingId,i.pickingId),x.dirtyPipeline=!1,i.dirtyPipeline=!1,g&&g.numDirtyPipelines++};class VertexGPURenderInfo{vertexShaderModule;vertexShaderSourceVariant;vertexShaderVariantConditionalBlocks;vertexStructInfo;vertexUniformInfo;vertexBindGroupLayout;vertexUniformBindGroup;vertexUniformBuffer;pipeline;shadowPipeline;pickingPipeline;constructor(i,g,x,_,v,b,y,S,w,L){this.vertexShaderModule=i,this.vertexShaderSourceVariant=g,this.vertexShaderVariantConditionalBlocks=x,this.vertexUniformInfo=_,this.vertexBindGroupLayout=v,this.vertexUniformBindGroup=y,this.vertexUniformBuffer=b,this.pipeline=S,this.shadowPipeline=w,this.pickingPipeline=L}}Object.freeze(VertexGPURenderInfo);const vi="VERTEX_MODULE_MESH_PBR_SKIN",bi=Math.PI/180,yi=3.141592653589793,Si=6.283185307179586,Ti=.225,Mi=1.27323954,wi=.405284735,Ci=1.5707963267948966,Ri=new Float32Array(1),Pi=new Float32Array(4),Bi=new Float32Array([0,1,0]);class Mesh extends MeshBase{displacementTexture;castShadow=!1;dirtyLOD=!1;passFrustumCulling=!0;createCustomMeshVertexShaderModule;#f;#h;#Vs;#Ot=0;#Nt=0;#Vt=0;#Fs=new Float32Array([0,0,0]);#Hs=0;#zs=0;#$s=0;#Ks;#Xs=1;#js=1;#Ys=1;#qs=new Float32Array([1,1,1]);#Di=0;#Ui=0;#Li=0;#Ws=new Float32Array([0,0,0]);#Zs={};#Js=0;#Qs=!1;#eo=1;#to;#no=!1;#ro;#io;#ao;#so;#oo;#uo=[];#lo=[];#co;#ho=null;#fo=[];#do=null;#mo=!0;#po=!0;#go;#xo;#_o;#vo=[];#bo=-1;constructor(i,g,x,_){super(i),_&&(this.name=_),this._geometry=g,this._material=x,this.#Ks=uuidToUint(this.uuid),this.#do=DrawBufferManager.getInstance(i),this.#yo(),this.#_o=new LODManager(this,()=>{this.dirtyLOD=!0})}get LODManager(){return this.#_o}get enableDebugger(){return this.#no}set enableDebugger(i){this.#no=i,i&&!this.#to&&(this.#to=new DrawDebuggerMesh(this.redGPUContext,this))}get drawDebugger(){return this.#to}_material;get material(){return this._material}set material(i){this._material=i,this.dirtyPipeline=!0,"blendMode"in this&&(this.blendMode=this.blendMode)}_geometry;get geometry(){return this._geometry}set geometry(i){this._geometry=i,this.dirtyPipeline=!0,this.dirtyTransform=!0}get opacity(){return this.#eo}set opacity(i){validatePositiveNumberRange(i,0,1),this.#eo=i,this.dirtyOpacity=!0}get ignoreFrustumCulling(){return this.#Qs}set ignoreFrustumCulling(i){this.#Qs=i}get pickingId(){return this.#Ks}get events(){return this.#Zs}get name(){return this.#f||(this.#f=InstanceIdGenerator.getNextId(this.constructor)),this.#h||`${this.constructor.name} Instance ${this.#f}`}set name(i){this.#h=i}get vertexStateBuffers(){return this._geometry.gpuRenderInfo.buffers}get parent(){return this.#Vs}set parent(i){this.#Vs=i}get pivotX(){return this.#Hs}set pivotX(i){this.#Hs=i,this.dirtyTransform=!0}get pivotY(){return this.#zs}set pivotY(i){this.#zs=i,this.dirtyTransform=!0}get pivotZ(){return this.#$s}set pivotZ(i){this.#$s=i,this.dirtyTransform=!0}get x(){return this.#Ot}set x(i){this.#Ot=this.#Fs[0]=i,this.dirtyTransform=!0}get y(){return this.#Nt}set y(i){this.#Nt=this.#Fs[1]=i,this.dirtyTransform=!0}get z(){return this.#Vt}set z(i){this.#Vt=this.#Fs[2]=i,this.dirtyTransform=!0}get position(){return this.#Fs}get scaleX(){return this.#Xs}set scaleX(i){this.#Xs=this.#qs[0]=i,this.dirtyTransform=!0}get scaleY(){return this.#js}set scaleY(i){this.#js=this.#qs[1]=i,this.dirtyTransform=!0}get scaleZ(){return this.#Ys}set scaleZ(i){this.#Ys=this.#qs[2]=i,this.dirtyTransform=!0}get scale(){return this.#qs}get rotationX(){return this.#Di}set rotationX(i){this.#Di=this.#Ws[0]=i%360,this.dirtyTransform=!0}get rotationY(){return this.#Ui}set rotationY(i){this.#Ui=this.#Ws[1]=i%360,this.dirtyTransform=!0}get rotationZ(){return this.#Li}set rotationZ(i){this.#Li=this.#Ws[2]=i%360,this.dirtyTransform=!0}get rotation(){return this.#Ws}get boundingOBB(){return this.#io&&!this.dirtyTransform||(this.#io=null,this.#ro=null,this.#io=calculateMeshOBB(this)),this.#io}get boundingAABB(){return this.#ro&&!this.dirtyTransform||(this.#io=null,this.#ro=null,this.#ro=calculateMeshAABB(this)),this.#ro}get combinedBoundingAABB(){return calculateMeshCombinedAABB(this)}setEnableDebuggerRecursively(i=!1){"enableDebugger"in this&&(this.enableDebugger=i),this.children&&this.children.forEach(g=>{g.setEnableDebuggerRecursively(i)})}setCastShadowRecursively(i=!1){"castShadow"in this&&(this.castShadow=i),this.children&&this.children.forEach(g=>{g.setCastShadowRecursively(i)})}setReceiveShadowRecursively(i=!1){"receiveShadow"in this&&(this.receiveShadow=i),this.children&&this.children.forEach(g=>{g.setReceiveShadowRecursively(i)})}setIgnoreFrustumCullingRecursively(i=!1){"ignoreFrustumCulling"in this&&(this.ignoreFrustumCulling=i),this.children&&this.children.forEach(g=>{g.setIgnoreFrustumCullingRecursively(i)})}getCombinedOpacity(){if(this.is2DMeshType){const i=this.parent;return this.#eo*(i?.getCombinedOpacity?i.getCombinedOpacity():1)}return 1}addListener(i,g){this.#Zs[i]=g,this.#Js=Object.keys(this.#Zs).length}lookAt(i,g,x){var _,v=[];v[0]=i,v[1]=g,v[2]=x,identity$1(this.localMatrix),targetTo(this.localMatrix,[this.#Ot,this.#Nt,this.#Vt],v,Bi),_=mat4ToEuler(this.localMatrix,[]),this.rotationX=180*_[0]/Math.PI,this.rotationY=180*_[1]/Math.PI,this.rotationZ=180*_[2]/Math.PI}setScale(i,g,x){g=g??i,x=x??i;const _=this.#qs;this.#Xs=_[0]=i,this.#js=_[1]=g,this.#Ys=_[2]=x,this.dirtyTransform=!0}setPosition(i,g,x){g=g??i,x=x??i;const _=this.#Fs;this.#Ot=_[0]=i,this.#Nt=_[1]=g,this.#Vt=_[2]=x,this.dirtyTransform=!0}setRotation(i,g,x){g=g??i,x=x??i;const _=this.#Ws;this.#Di=_[0]=i,this.#Ui=_[1]=g,this.#Li=_[2]=x,this.dirtyTransform=!0}clone(){const i=new Mesh(this.redGPUContext,this._geometry,this._material);i.setPosition(this.#Ot,this.#Nt,this.#Vt),i.setRotation(this.#Di,this.#Ui,this.#Li),i.setScale(this.#Xs,this.#js,this.#Ys);let g=this.children.length;for(;g--;)i.addChild(this.children[g].clone());return i}render(i){const{redGPUContext:g}=this,{view:x,isScene2DMode:_,frustumPlanes:v,dirtyVertexUniformFromMaterial:b,useDistanceCulling:y,cullingDistanceSquared:S}=i,{antialiasingManager:w,gpuDevice:L}=g,{scene:k}=x,{shadowManager:H}=k,{directionalShadowManager:z}=H,{pickingManager:q}=x,{castingList:W}=z,be=this._geometry,Ke=this._material,{uuid:Xe}=Ke||{};let je,Ye,Ze=this.dirtyPipeline;const{skinInfo:Je}=this.animationInfo;if(_&&(this.#Vt=0,this.#$s=0,this.depthStencilState.depthWriteEnabled&&(this.depthStencilState.depthWriteEnabled=!1)),this.dirtyTransform){je=!0,this.#mo=!0,this.#po=!0;{const{pixelRectObject:i}=x,g=this.parent,v=this.localMatrix;let b,y,S,w,L,k,H,z,q,W,be,Ke,Xe,je,Ye,Ze,Je,Qe,et,tt,it,ft,pt,xt,vt,bt,yt,St,Tt,Mt,wt,Ct,Rt,Pt,Bt,It,Et,Dt,Ut;v[12]=this.#Ot,v[13]=this.#Nt,v[14]=this.#Vt,v[15]=1,b=this.#Di*bi,y=this.#Ui*bi,S=this.#Li*bi,pt=1,xt=0,vt=0,yt=0,St=1,Tt=0,wt=0,Ct=0,Rt=1,Ut=b%Si,Ut<-yi?Ut+=Si:Ut>yi&&(Ut-=Si),Ut=Ut<0?Mi*Ut+wi*Ut*Ut:Mi*Ut-wi*Ut*Ut,w=Ut<0?Ti*(Ut*-Ut-Ut)+Ut:Ti*(Ut*Ut-Ut)+Ut,Ut=(b+Ci)%Si,Ut<-yi?Ut+=Si:Ut>yi&&(Ut-=Si),Ut=Ut<0?Mi*Ut+wi*Ut*Ut:Mi*Ut-wi*Ut*Ut,H=Ut<0?Ti*(Ut*-Ut-Ut)+Ut:Ti*(Ut*Ut-Ut)+Ut,Ut=y%Si,Ut<-yi?Ut+=Si:Ut>yi&&(Ut-=Si),Ut=Ut<0?Mi*Ut+wi*Ut*Ut:Mi*Ut-wi*Ut*Ut,L=Ut<0?Ti*(Ut*-Ut-Ut)+Ut:Ti*(Ut*Ut-Ut)+Ut,Ut=(y+Ci)%Si,Ut<-yi?Ut+=Si:Ut>yi&&(Ut-=Si),Ut=Ut<0?Mi*Ut+wi*Ut*Ut:Mi*Ut-wi*Ut*Ut,z=Ut<0?Ti*(Ut*-Ut-Ut)+Ut:Ti*(Ut*Ut-Ut)+Ut,Ut=S%Si,Ut<-yi?Ut+=Si:Ut>yi&&(Ut-=Si),Ut=Ut<0?Mi*Ut+wi*Ut*Ut:Mi*Ut-wi*Ut*Ut,k=Ut<0?Ti*(Ut*-Ut-Ut)+Ut:Ti*(Ut*Ut-Ut)+Ut,Ut=(S+Ci)%Si,Ut<-yi?Ut+=Si:Ut>yi&&(Ut-=Si),Ut=Ut<0?Mi*Ut+wi*Ut*Ut:Mi*Ut-wi*Ut*Ut,q=Ut<0?Ti*(Ut*-Ut-Ut)+Ut:Ti*(Ut*Ut-Ut)+Ut,je=z*q,Ye=H*k+w*L*q,Ze=w*k-H*L*q,Je=-z*k,Qe=H*q-w*L*k,et=w*q+H*L*k,tt=L,it=-w*z,ft=H*z;let Lt=this.#Xs,At=this.#js,Gt=this.#Ys;if(this.renderTextureWidth&&(Lt*=this.renderTextureWidth,At*=this.renderTextureHeight),v[0]=je*Lt,v[1]=Ye*Lt,v[2]=Ze*Lt,v[3]=0,v[4]=Je*At,v[5]=Qe*At,v[6]=et*At,v[7]=0,v[8]=tt*Gt,v[9]=it*Gt,v[10]=ft*Gt,v[11]=0,(this.#Hs||this.#zs||this.#$s)&&(pt=v[0],xt=v[1],vt=v[2],bt=v[3],yt=v[4],St=v[5],Tt=v[6],Mt=v[7],wt=v[8],Ct=v[9],Rt=v[10],Pt=v[11],Bt=v[12],It=v[13],Et=v[14],Dt=v[15],W=1,be=0,Ke=0,Xe=0,v[0]=W*pt+be*yt+Ke*wt+Xe*Bt,v[1]=W*xt+be*St+Ke*Ct+Xe*It,v[2]=W*vt+be*Tt+Ke*Rt+Xe*Et,v[3]=W*bt+be*Mt+Ke*Pt+Xe*Dt,W=0,be=1,Ke=0,Xe=0,v[4]=W*pt+be*yt+Ke*wt+Xe*Bt,v[5]=W*xt+be*St+Ke*Ct+Xe*It,v[6]=W*vt+be*Tt+Ke*Rt+Xe*Et,v[7]=W*bt+be*Mt+Ke*Pt+Xe*Dt,W=0,be=0,Ke=1,Xe=0,v[8]=W*pt+be*yt+Ke*wt+Xe*Bt,v[9]=W*xt+be*St+Ke*Ct+Xe*It,v[10]=W*vt+be*Tt+Ke*Rt+Xe*Et,v[11]=W*bt+be*Mt+Ke*Pt+Xe*Dt,_?g?.modelMatrix?(W=-this.#Hs,be=-this.#zs,Ke=-this.#$s,Xe=1):(W=-this.#Hs/b,be=-this.#zs/y,Ke=-this.#$s,Xe=1):(W=-this.#Hs,be=-this.#zs,Ke=-this.#$s,Xe=1),v[12]=W*pt+be*yt+Ke*wt+Xe*Bt,v[13]=W*xt+be*St+Ke*Ct+Xe*It,v[14]=W*vt+be*Tt+Ke*Rt+Xe*Et,v[15]=W*bt+be*Mt+Ke*Pt+Xe*Dt),g?.modelMatrix){const i=g.modelMatrix,x=this.localMatrix,_=this.modelMatrix,v=i[0],b=i[1],y=i[2],S=i[3],w=i[4],L=i[5],k=i[6],H=i[7],z=i[8],q=i[9],W=i[10],be=i[11],Ke=i[12],Xe=i[13],je=i[14],Ye=i[15];let Ze=x[0],Je=x[1],Qe=x[2],et=x[3];_[0]=Ze*v+Je*w+Qe*z+et*Ke,_[1]=Ze*b+Je*L+Qe*q+et*Xe,_[2]=Ze*y+Je*k+Qe*W+et*je,_[3]=Ze*S+Je*H+Qe*be+et*Ye,Ze=x[4],Je=x[5],Qe=x[6],et=x[7],_[4]=Ze*v+Je*w+Qe*z+et*Ke,_[5]=Ze*b+Je*L+Qe*q+et*Xe,_[6]=Ze*y+Je*k+Qe*W+et*je,_[7]=Ze*S+Je*H+Qe*be+et*Ye,Ze=x[8],Je=x[9],Qe=x[10],et=x[11],_[8]=Ze*v+Je*w+Qe*z+et*Ke,_[9]=Ze*b+Je*L+Qe*q+et*Xe,_[10]=Ze*y+Je*k+Qe*W+et*je,_[11]=Ze*S+Je*H+Qe*be+et*Ye,Ze=x[12],Je=x[13],Qe=x[14],et=x[15],_[12]=Ze*v+Je*w+Qe*z+et*Ke,_[13]=Ze*b+Je*L+Qe*q+et*Xe,_[14]=Ze*y+Je*k+Qe*W+et*je,_[15]=Ze*S+Je*H+Qe*be+et*Ye}else{const{modelMatrix:i,localMatrix:g}=this;i[0]=g[0],i[1]=g[1],i[2]=g[2],i[3]=g[3],i[4]=g[4],i[5]=g[5],i[6]=g[6],i[7]=g[7],i[8]=g[8],i[9]=g[9],i[10]=g[10],i[11]=g[11],i[12]=g[12],i[13]=g[13],i[14]=g[14],i[15]=g[15]}}be||(this.#po=!1),this.dirtyTransform=!1,this.#ro=null,this.#io=null}if(w.useTAA&&this.#go){const{gpuRenderInfo:i}=this,{vertexUniformBuffer:x,vertexUniformInfo:_}=i,{members:v}=_,{members:b}=v.matrixList;this.#ao&&b.prevModelMatrix&&(this.#go.set(this.#ao,b.prevModelMatrix.uniformOffsetForData/Float32Array.BYTES_PER_ELEMENT),this.#po||g.gpuDevice.queue.writeBuffer(x.gpuBuffer,b.prevModelMatrix.uniformOffset,this.#ao));{this.#ao||(this.#ao=new Float32Array(16));const i=this.#ao,g=this.modelMatrix;i[0]=g[0],i[1]=g[1],i[2]=g[2],i[3]=g[3],i[4]=g[4],i[5]=g[5],i[6]=g[6],i[7]=g[7],i[8]=g[8],i[9]=g[9],i[10]=g[10],i[11]=g[11],i[12]=g[12],i[13]=g[13],i[14]=g[14],i[15]=g[15]}}else this.#ao=null;let Qe=this.passFrustumCulling=!0,et=0;const tt=this.#_o.LODList,it=tt.length;if(y&&be||this.#_o.LODList.length){const{rawCamera:i}=x,g=this.boundingAABB,_=i.x-g.centerX,v=i.y-g.centerY,b=i.z-g.centerZ;et=_*_+v*v+b*b}if(y&&be){const i=this.boundingAABB.geometryRadius;et>S+i*i&&(Qe=!1)}if(v&&Qe&&!this.#Qs){const{rawCamera:i}=x,g=this.boundingAABB;if(i instanceof IsometricController){const{centerX:x,centerY:_,centerZ:v,geometryRadius:b}=g,y=i,{left:S,right:w,top:L,bottom:k,nearClipping:H,farClipping:z}=y,{x:q,y:W,z:be}=y;{const i=x-q,g=_-W,y=v-be,Ke=45*(Math.PI/180),Xe=Math.cos(Ke),je=Math.sin(Ke),Ye=i*Xe+y*je,Ze=-i*je+y*Xe;(Ye+bw||g+bL||Ze+bz)&&(Qe=!1)}}else{const i=v[0],x=v[1],_=v[2],b=v[3],y=v[4],S=v[5],w=g.centerX,L=g.centerY,k=g.centerZ,H=g.geometryRadius;(i[0]*w+i[1]*L+i[2]*k+i[3]<=-H||x[0]*w+x[1]*L+x[2]*k+x[3]<=-H||_[0]*w+_[1]*L+_[2]*k+_[3]<=-H||b[0]*w+b[1]*L+b[2]*k+b[3]<=-H||y[0]*w+y[1]*L+y[2]*k+y[3]<=-H||S[0]*w+S[1]*L+S[2]*k+S[3]<=-H)&&(Qe=!1)}}Qe&&(this.gltfLoaderInfo?.activeAnimations?.length&&(i.animationList[i.animationList.length]=this.gltfLoaderInfo?.activeAnimations),Je&&(this.currentShaderModuleName.includes(vi)||(Ze=!0),this.currentShaderModuleName===`${vi}_${Je.joints?.length}`&&(i.skinList[i.skinList.length]=this,je=!1))),this.passFrustumCulling=Qe;const{displacementTexture:ft,displacementScale:pt}=Ke||{};if((Ze||Ke?.dirtyPipeline||b[Xe])&&(b[Xe]=!0),be){i.num3DObjects++,w.changedMSAA&&(Ze=!0,this.dirtyLOD=!0),this.gpuRenderInfo||this.initGPURenderInfos();const g=!!ft;this.useDisplacementTexture!==g&&(this.useDisplacementTexture=g,Ze=!0),(Ze||b[Xe])&&(updateMeshDirtyPipeline(this,i),this.#so=null,this.#oo=null);{const{gpuRenderInfo:i}=this,{vertexUniformBuffer:g,vertexUniformInfo:x}=i,{members:_}=x,{gpuBuffer:v}=g;if(this.#go||(this.#go=new Float32Array(_.matrixList.endOffset/Float32Array.BYTES_PER_ELEMENT)),_.uvTransform&&(Ke.dirtyTextureTransform||b[Xe])){const i=Ke,g=i.textureOffset,x=i.textureScale;g&&(b[Xe]=!0,Pi[0]=g[0],Pi[1]=g[1],Pi[2]=x[0],Pi[3]=x[1],L.queue.writeBuffer(v,_.uvTransform.uniformOffset,Pi),Ke.dirtyTextureTransform=!1)}}}else i.num3DGroups++;if(be&&Qe){const{gpuRenderInfo:g}=this,{vertexUniformBuffer:_,vertexUniformInfo:v}=g,{members:b}=v,{members:y}=b.matrixList,{gpuBuffer:S}=_;if(this.#go||(this.#go=new Float32Array(b.matrixList.endOffset/Float32Array.BYTES_PER_ELEMENT)),void 0!==b.displacementScale&&this.#xo!==pt&&(this.#xo=pt,Ri[0]=pt,L.queue.writeBuffer(S,b.displacementScale.uniformOffset,Ri)),this.#po){{const i=this.is2DMeshType?multiply$4(create$4(),this.modelMatrix,fromValues$4(this.width,0,0,0,0,this.height,0,0,0,0,1,0,0,0,0,1)):this.modelMatrix;this.#go.set(i,y.modelMatrix.uniformOffsetForData/Float32Array.BYTES_PER_ELEMENT)}if(this.#mo&&y.normalModelMatrix){this.#mo=!1;const i=this.modelMatrix,g=this.normalModelMatrix,x=i[0],_=i[1],v=i[2],b=i[4],y=i[5],S=i[6],w=i[8],L=i[9],k=i[10],H=x*(y*k-S*L)-_*(b*k-S*w)+v*(b*L-y*w);if(0===H)g[0]=1,g[1]=0,g[2]=0,g[3]=0,g[4]=0,g[5]=1,g[6]=0,g[7]=0,g[8]=0,g[9]=0,g[10]=1,g[11]=0,g[12]=0,g[13]=0,g[14]=0,g[15]=1;else{const i=1/H;g[0]=(y*k-S*L)*i,g[1]=(S*w-b*k)*i,g[2]=(b*L-y*w)*i,g[3]=0,g[4]=(v*L-_*k)*i,g[5]=(x*k-v*w)*i,g[6]=(_*w-x*L)*i,g[7]=0,g[8]=(_*S-v*y)*i,g[9]=(v*b-x*S)*i,g[10]=(x*y-_*b)*i,g[11]=0,g[12]=0,g[13]=0,g[14]=0,g[15]=1}}this.#go.set(this.normalModelMatrix,y.normalModelMatrix.uniformOffsetForData/Float32Array.BYTES_PER_ELEMENT),y.localMatrix&&this.#go.set(this.localMatrix,y.localMatrix.uniformOffsetForData/Float32Array.BYTES_PER_ELEMENT),je=!0,this.#po=!1,L.queue.writeBuffer(S,b.matrixList.startOffset,this.#go)}this.dirtyOpacity&&(Ye=!0,b.combinedOpacity&&(Ri[0]=this.getCombinedOpacity(),L.queue.writeBuffer(S,b.combinedOpacity.uniformOffset,Ri)),this.dirtyOpacity=!1);const{bundleListRender2PathLayer:w,bundleListParticleLayer:k,bundleListTransparentLayer:H,bundleListAlphaLayer:z,bundleListBasicList:W}=i;{const{fragmentUniformBindGroup:g}=Ke.gpuRenderInfo;if((!this.#so||Ze||this.#co!==g||this.#lo[i.viewIndex]!==x.systemUniform_Vertex_UniformBindGroup||this.dirtyLOD)&&this.#So(i),i.numDrawCalls++,be.indexBuffer){const{indexBuffer:g}=be,{indexCount:x,triangleCount:_}=g;i.numTriangles+=_,i.numPoints+=x}else{const{vertexBuffer:g}=be,{vertexCount:x,triangleCount:_}=g;i.numTriangles+=_,i.numPoints+=x}let _=this.#oo;if(it){let i=this.#bo;(i<0||i>=it)&&(i=-1);let g=!1;if(-1===i)et>=tt[0].distanceSquared&&(g=!0);else if(i===it-1)et=_)&&(g=!0)}if(g){let g=-1;for(let i=0;i=tt[i].distanceSquared;i++)g=i;g!==i&&(this.#bo=g,g>=0&&g=0&&i{const{redGPUContext:v}=this,{gpuRenderInfo:b}=this;return b.vertexUniformInfo!==x&&(b.vertexUniformInfo=x,b.vertexStructInfo=g,createMeshVertexUniformBuffers(this)),b.vertexShaderSourceVariant=g.shaderSourceVariant,b.vertexShaderVariantConditionalBlocks=g.conditionalBlocks,b.vertexUniformBindGroup=v.gpuDevice.createBindGroup(getBasicMeshVertexBindGroupDescriptor(this)),this.#In(i),this.gpuRenderInfo.vertexShaderModule};#To(i,g){let x=g-i;for(;x>180;)x-=360;for(;x<-180;)x+=360;return i+x}#Mo=()=>{const{gpuDevice:i,redGPUContext:g}=this,{resourceManager:x}=g;this.#vo.length=0;const _=x.getGPUBindGroupLayout(ResourceManager.PRESET_VERTEX_GPUBindGroupLayout);this.LODManager.LODList.forEach((i,v)=>{const b={code:i.source},y=x.createGPUShaderModule(i.label,b);this.#vo[v]={pipeline:createBasePipeline({vertexStateBuffers:i.geometry.gpuRenderInfo.buffers,primitiveState:this.primitiveState,depthStencilState:this.depthStencilState,geometry:i.geometry,material:i.material||this.material,redGPUContext:g,gpuRenderInfo:this.gpuRenderInfo},y,_),vertexUniformBindGroup:g.gpuDevice.createBindGroup(getBasicMeshVertexBindGroupDescriptor({redGPUContext:g,material:i.material||this.material,gpuRenderInfo:{vertexBindGroupLayout:_,vertexUniformBuffer:this.gpuRenderInfo.vertexUniformBuffer}}))}}),this.#bo=-1};#So(i){const{view:g}=i;this.#oo=this.#wo(g,this._geometry,this._material),this.dirtyLOD&&(this.#Mo(),this.dirtyLOD=!1),this.#uo.length=0,this.LODManager.LODList.forEach((i,x)=>{this.#uo[x]=this.#wo(g,i.geometry,i.material||this._material,x)})}#wo(i,g,x,_=null){const{gpuDevice:v}=this.redGPUContext,{renderViewStateData:b}=i,{vertexBuffer:y,indexBuffer:S}=g,{fragmentUniformBindGroup:w}=x.gpuRenderInfo;this.#Co(g,_);const L=null!==_,k=v.createRenderBundleEncoder({...i.basicRenderBundleEncoderDescriptor,label:this.uuid});L||(this.#so=k,this.#lo[b.viewIndex]=i.systemUniform_Vertex_UniformBindGroup,this.#co=w);const{gpuBuffer:H}=y,z=L?this.#vo[_].pipeline:this.gpuRenderInfo.pipeline,q=L?this.#vo[_].vertexUniformBindGroup:this.gpuRenderInfo.vertexUniformBindGroup;k.setPipeline(z),k.setVertexBuffer(0,H),this.particleBuffers?.length&&this.particleBuffers.forEach((i,g)=>{k.setVertexBuffer(g+1,i)}),k.setBindGroup(0,i.systemUniform_Vertex_UniformBindGroup),k.setBindGroup(1,q),k.setBindGroup(2,w);let W=this.#ho;if(null!==_&&(W=this.#fo[_]),S){const{gpuBuffer:i,format:g}=S;k.setIndexBuffer(i,g),k.drawIndexedIndirect(W.buffer,4*W.commandOffset)}else k.drawIndirect(W.buffer,4*W.commandOffset);const be=k.finish({label:`${this.name}_LOD${_||0}`});return be.mesh=null,be}#yo(){this.#ho||(this.#ho=this.#do.allocateDrawCommand(this.name))}#Co(i,g=null){const{vertexBuffer:x,indexBuffer:_}=i,v=this.#do;let b=this.#ho;if(null!==g&&(this.#fo[g]||(this.#fo[g]=this.#do.allocateDrawCommand(`${this.name}_LOD${g}`)),b=this.#fo[g]),this.#yo(),_){const{indexCount:i}=_;this.particleBuffers?v.setIndexedIndirectCommand(b,i,this.particleNum,0,0,0):v.setIndexedIndirectCommand(b,i,1,0,0,0)}else{const{vertexCount:i}=x;v.setIndirectCommand(b,i,1,0,0)}}#In(i){const{gpuDevice:g,resourceManager:x}=this.redGPUContext,_=this.#En(),v=`${i}_${_}`;let b=x.getGPUShaderModule(v);if(!b){let i=this.gpuRenderInfo.vertexShaderSourceVariant.getVariant(_);if(i)if(this.animationInfo?.skinInfo){const g=`${this.animationInfo.skinInfo.joints.length}`;i=i.replaceAll("#JOINT_NUM",g),this.gpuRenderInfo.vertexShaderSourceVariant.getVariant(_),b=x.createGPUShaderModule(`${v}_${g}`,{code:i})}else b=x.createGPUShaderModule(v,{code:i});else console.warn("⚠️ 버텍스 바리안트 소스를 찾을 수 없음:",_),b=this.gpuRenderInfo.vertexShaderModule}this.gpuRenderInfo.vertexShaderModule=b}#En(){const{vertexShaderVariantConditionalBlocks:i}=this.gpuRenderInfo,g=new Set;for(const x of i)this[x]&&g.add(x);const x=g.size>0?Array.from(g).sort().join("+"):"none";return g.size,x}}Object.defineProperty(Mesh.prototype,"meshType",{value:Gr.MESH,writable:!1}),Er.defineByPreset(Mesh,[Er.PRESET_BOOLEAN.RECEIVE_SHADOW]),Er.defineBoolean(Mesh,[["useDisplacementTexture",!1],["disableJitter",!1]]),Object.freeze(Mesh);const Ii=parseWGSL("#redgpu_include SYSTEM_UNIFORM;\n#redgpu_include calcTintBlendMode;\n#redgpu_include drawPicking;\n#redgpu_include FragmentOutput;\nstruct Uniforms { useDiffuseTexture:u32, opacity:f32, useTint:u32, tint:vec4, tintBlendMode:u32,\n};\n@group(2) @binding(0) var uniforms:Uniforms;\n@group(2) @binding(1) var diffuseTextureSampler:sampler;\n@group(2) @binding(2) var diffuseTexture:texture_2d;\nstruct InputData { @builtin(position) position:vec4, @location(0) vertexPosition:vec3, @location(1) vertexNormal:vec3, @location(2) uv:vec2, @location(11) combinedOpacity:f32, @location(13) shadowPos:vec3, @location(15) @interpolate(flat) pickingId:vec4,\n};\n@fragment\nfn main(inputData:InputData) -> FragmentOutput { var output:FragmentOutput; var finalColor:vec4=textureSample(diffuseTexture,diffuseTextureSampler,inputData.uv); finalColor=vec4(finalColor.rgb/finalColor.a,finalColor.a * uniforms.opacity * inputData.combinedOpacity); #redgpu_if useTint finalColor=calcTintBlendMode(finalColor,uniforms.tintBlendMode,uniforms.tint); #redgpu_endIf if (finalColor.a==0.0) { discard; } output.color=finalColor; output.gBufferMotionVector=vec4( 0.0,0.0,1.0,1.0 ); return output;\n};\n");class TextFieldMaterial extends ABitmapBaseMaterial{dirtyPipeline=!1;constructor(i,g,x){super(i,"TEXT_FILED_MATERIAL",Ii,2),x&&(this.name=x),this.diffuseTexture=g,this.diffuseTextureSampler=new Sampler(this.redGPUContext),this.initGPURenderInfos()}}dr.defineByPreset(TextFieldMaterial,[dr.PRESET_TEXTURE.DIFFUSE_TEXTURE,dr.PRESET_SAMPLER.DIFFUSE_TEXTURE_SAMPLER]),Object.freeze(TextFieldMaterial);const Ei=";box-sizing:content-box;white-space:nowrap;",Di={padding:0,background:"transparent",color:"#fff",fontFamily:"Arial",fontSize:24,fontWeight:"normal",fontStyle:"normal",letterSpacing:0,wordBreak:"keep-all",verticalAlign:"middle",textAlign:"center",borderRadius:0,lineHeight:1.4,border:"",boxShadow:"none",boxSizing:"border-box",filter:""};class ATextField extends Mesh{#Ro;#Po;#Bo;#Io;#Eo;#Do;#Uo;#Lo=!0;#l;#Ao;#Go=!1;#ko=1;#Oo=1;constructor(i,g,x=!0){super(i),this.#l=i,this.#Lo=x,this.#Uo=g,this._material=new TextFieldMaterial(i),this._material.transparent=!0,this._material.diffuseTextureSampler=new Sampler(i,x?{minFilter:v.LINEAR,magFilter:v.LINEAR,mipmapFilter:b.LINEAR}:{minFilter:v.NEAREST,magFilter:v.NEAREST,mipmapFilter:null}),this.depthStencilState.depthWriteEnabled=!1,this.#No(),this.#Vo(),this.#Fo(),this.#Ho(),this.#zo()}get text(){return this.#Do}set text(i){if(this.#Do===i)return;this.#Do=i;const g=this.#Bo.querySelector("foreignObject div"),x=this.#$o(i);this.#Io.innerHTML=x,g.innerHTML=x,this.#Go=!0}render(i){this.#Uo(this.#ko,this.#Oo),this.#Ko(),super.render(i)}#$o(i){return i.toString().replace(/\/gi,"
")}#No(){"undefined"!=typeof OffscreenCanvas?this.#Ro=new OffscreenCanvas(100,100):this.#Ro=document.createElement("canvas"),this.#Po=this.#Ro.getContext("2d")}#Xo(){const i=this.#Io.getBoundingClientRect();const g=i.width+3+3,x=i.height+3+3;return{width:-2&Math.ceil(g),height:-2&Math.ceil(x),extraTop:3,extraRight:3,extraBottom:3,extraLeft:3}}#jo(){const i=this.#Bo,g=i.querySelector("foreignObject"),{width:x,height:_,extraTop:v,extraRight:b,extraBottom:y,extraLeft:S}=this.#Xo();g.setAttribute("width",x.toString()),g.setAttribute("height",_.toString()),g.style.padding=`${v}px ${b}px ${y}px ${S}px`,i.setAttribute("width",x.toString()),i.setAttribute("height",_.toString()),this.#Eo.src="data:image/svg+xml;charset=utf-8,"+encodeURIComponent(i.outerHTML)}#Ho(){this.#Eo=new Image,this.#Eo.style.cssText="position:absolute;bottom:0px;left:0;",this.#Eo.onload=i=>{let g,x;const{width:_,height:v}=this.#Xo(),b=1===window.devicePixelRatio?2:window.devicePixelRatio;g=_*b,x=v*b,this.#Eo.width=_,this.#Eo.height=v,this.#Ro.width=g,this.#Ro.height=x,this.#Ro instanceof OffscreenCanvas||(this.#Ro.style.width=`${_}px`,this.#Ro.style.height=`${v}px`),this.#Po.imageSmoothingEnabled=!0,this.#Po.imageSmoothingQuality="high",this.#Po.clearRect(0,0,g,x),this.#Po.fillStyle="rgba(0,0,0,0)",this.#Po.fillRect(0,0,g,x),this.#Po.drawImage(this.#Eo,0,0,g,x),this.dirtyTransform=!0;const callback=i=>{if(this.material.diffuseTexture){const i=this.material.diffuseTexture.src,g="string"==typeof i&&i?.startsWith?.("blob:");this.material.diffuseTexture.destroy(),this.material.diffuseTexture=null,g&&URL.revokeObjectURL(i)}this.material.diffuseTexture=new BitmapTexture(this.#l,URL.createObjectURL(i),!0,i=>{this.#ko=_,this.#Oo=v},null,null,!0)};this.#Ro instanceof OffscreenCanvas?this.#Ro.convertToBlob({type:"image/png"}).then(callback):this.#Ro.toBlob(callback,"image/png")}}#Ko(){this.#Go&&(this.#Ao&&cancelAnimationFrame(this.#Ao),this.#Ao=requestAnimationFrame(()=>{this.#jo()})),this.#Go=!1}#Yo=(i,g)=>{const x=this.#Bo.querySelector("foreignObject > div").style,_=this.#Io.style,v=`_${i}`;this[v]=g,Object.defineProperty(this,i,{get:()=>this[v],set:g=>{const b=this[v];this[v]=g;const y=(i=>"number"==typeof i)(g)&&(i=>!["lineHeight","fontWeight"].includes(i))(i)?`${g}px`:g;x[i]=y,_[i]=y,b!==g&&(this.#Go=!0)},configurable:!0}),this[i]=g};#Vo(){this.#Io=document.createElement("div"),this.#Io.style.cssText=Ei+";position:absolute;top:200px;left:0;visibility:hidden;text-rendering:optimizeLegibility",document.body.appendChild(this.#Io)}#Fo(){const i=this.#Bo=document.createElementNS("http://www.w3.org/2000/svg","svg");i.setAttribute("xmlns","http://www.w3.org/2000/svg"),i.setAttribute("text-rendering","optimizeLegibility"),i.style.cssText="position:absolute;top:0px;left:0px;z-index:1;margin:0;padding:0;overflow:visible;background:transparent",i.innerHTML=`
`}#zo(){for(const[i,g]of Object.entries(Di))this.#Yo(i,g);this.#Go=!0}}Object.freeze(ATextField);var Ui="#redgpu_include SYSTEM_UNIFORM;\n#redgpu_include getBillboardMatrix;\n#redgpu_include calcBillboard;\n#redgpu_include billboardPicking;\n#redgpu_include billboardShadow;\nstruct MatrixList{ modelMatrix:mat4x4, normalModelMatrix:mat4x4,\n}\nstruct VertexUniforms { pickingId:u32, matrixList:MatrixList, normalModelMatrix:mat4x4, useSizeAttenuation:u32, useBillboard:u32, usePixelSize:u32, pixelSize:f32, _renderRatioX:f32, _renderRatioY:f32, combinedOpacity:f32,\n};\n@group(1) @binding(0) var vertexUniforms:VertexUniforms;\nstruct InputData { @location(0) position:vec3, @location(1) vertexNormal:vec3, @location(2) uv:vec2,\n};\nstruct OutputData { @builtin(position) position:vec4, @location(0) vertexPosition:vec3, @location(1) vertexNormal:vec3, @location(2) uv:vec2, @location(11) combinedOpacity:f32, @location(13) shadowPos:vec3, @location(15) @interpolate(flat) pickingId:vec4,\n};\n@vertex\nfn main(inputData:InputData) -> OutputData { var output:OutputData; let billboardResult=calcBillboard( inputData.position, inputData.vertexNormal, vertexUniforms.matrixList.modelMatrix, systemUniforms.camera.cameraMatrix, systemUniforms.noneJitterProjectionMatrix, systemUniforms.resolution, vertexUniforms.useBillboard, vertexUniforms.usePixelSize, vertexUniforms.pixelSize, vertexUniforms._renderRatioX, vertexUniforms._renderRatioY ); output.position=billboardResult.position; output.vertexPosition=billboardResult.vertexPosition; output.vertexNormal=billboardResult.vertexNormal; output.uv=inputData.uv; output.combinedOpacity=vertexUniforms.combinedOpacity; return output;\n}";const Li=parseWGSL(Ui),Ai=Li.uniforms.vertexUniforms;class TextField3D extends ATextField{#qo=1;#Wo=1;#Zo=1;#Jo=!1;constructor(i,g){super(i,(i,g)=>{i&&g&&(i===this.#qo&&g===this.#Wo||(this.#qo=i,this.#Wo=g,this.gpuRenderInfo&&this.redGPUContext.gpuDevice.queue.writeBuffer(this.gpuRenderInfo.vertexUniformBuffer.gpuBuffer,this.gpuRenderInfo.vertexUniformInfo.members.pixelSize.uniformOffset,new Float32Array([g*window.devicePixelRatio])),this.#Qo()))}),this._geometry=new Plane(i),this.disableJitter=!0,g&&(this.text=g)}get worldSize(){return this.#Zo}set worldSize(i){this.#Zo!==i&&(this.#Zo=i,this.#Qo())}get usePixelSize(){return this.#Jo}get pixelSize(){return this.#Wo}set usePixelSize(i){if(this.gpuRenderInfo){const{vertexUniformBuffer:g,vertexUniformInfo:x}=this.gpuRenderInfo;this.redGPUContext.gpuDevice.queue.writeBuffer(g.gpuBuffer,x.members.usePixelSize.uniformOffset,new Uint32Array([i?1:0])),this.redGPUContext.gpuDevice.queue.writeBuffer(g.gpuBuffer,x.members.pixelSize.uniformOffset,new Float32Array([this.#Wo*window.devicePixelRatio]))}this.#Jo!==i&&(this.#Jo=i,this.#Qo())}#Qo(){if(this.#Wo){const i=this._renderRatioX,g=this._renderRatioY;this.usePixelSize?(this._renderRatioY=1,this._renderRatioX=this.#qo/this.#Wo):(this._renderRatioY=this.#Zo,this._renderRatioX=this.#qo/this.#Wo*this.#Zo),i===this._renderRatioX&&g===this._renderRatioY||(this.dirtyTransform=!0)}}render(i){super.render(i)}get geometry(){return this._geometry}set geometry(i){console.error("TextField3D can not change geometry")}get material(){return this._material}set material(i){console.error("TextField3D can not change material")}createCustomMeshVertexShaderModule=()=>this.createMeshVertexShaderModuleBASIC("VERTEX_MODULE_TEXT_FIELD_3D",Li,Ai,Ui)}Er.definePositiveNumber(TextField3D,[["_renderRatioX",1],["_renderRatioY",1]]),Er.defineByPreset(TextField3D,[[Er.PRESET_BOOLEAN.USE_BILLBOARD,!0]]),Object.freeze(TextField3D);class ADrawDebuggerLight{#l;#eu;#tu;constructor(i,g,x=32){this.#l=i;const _=this.createLightDebugGeometry(i,x);this.#eu=new ColorMaterial(i),this.#eu.color.setColorByRGB(g[0],g[1],g[2]),this.#tu=new Mesh(i,_,this.#eu),this.#tu.primitiveState.cullMode="none",this.#tu.primitiveState.topology=Lr.LINE_LIST}get lightMaterial(){return this.#eu}get lightDebugMesh(){return this.#tu}updateVertexBuffer(i,g){const x=g.data;let _=0;const v=Math.min(i.length,Math.floor(x.length/16));for(let g=0;g.99&&(w=[1,0,0]);const L=[b[1]*w[2]-b[2]*w[1],b[2]*w[0]-b[0]*w[2],b[0]*w[1]-b[1]*w[0]],k=Math.sqrt(L[0]*L[0]+L[1]*L[1]+L[2]*L[2]),H=[L[0]/k,L[1]/k,L[2]/k],z=[H[1]*b[2]-H[2]*b[1],H[2]*b[0]-H[0]*b[2],H[0]*b[1]-H[1]*b[0]],q=[[x,y],[y,[y[0]+-.5*b[0]+H[0]*S,y[1]+-.5*b[1]+H[1]*S,y[2]+-.5*b[2]+H[2]*S]],[y,[y[0]+-.5*b[0]-H[0]*S,y[1]+-.5*b[1]-H[1]*S,y[2]+-.5*b[2]-H[2]*S]],[y,[y[0]+-.5*b[0]+z[0]*S,y[1]+-.5*b[1]+z[1]*S,y[2]+-.5*b[2]+z[2]*S]],[y,[y[0]+-.5*b[0]-z[0]*S,y[1]+-.5*b[1]-z[1]*S,y[2]+-.5*b[2]-z[2]*S]],[[x[0]-.3,x[1],x[2]],[x[0]+.3,x[1],x[2]]],[[x[0],x[1]-.3,x[2]],[x[0],x[1]+.3,x[2]]],[[x[0],x[1],x[2]-.3],[x[0],x[1],x[2]+.3]]];this.updateVertexBuffer(q,g)}}Object.freeze(DrawDebuggerDirectionalLight);class DrawDebuggerPointLight extends ADrawDebuggerLight{#ja;#nu;constructor(i,g){super(i,[0,255,255],51),this.#ja=g,this.#nu=new TextField3D(i),this.#nu.useBillboard=!0,this.#nu.fontSize=40,this.#nu.text="💡",this.lightDebugMesh.addChild(this.#nu)}render(i){i.view.systemUniform_Vertex_UniformBindGroup&&this.#ja.enableDebugger&&(this.#au(this.#ja,this.lightDebugMesh.geometry.vertexBuffer),this.lightDebugMesh.setPosition(0,0,0),this.lightDebugMesh.setRotation(0,0,0),this.lightDebugMesh.setScale(1,1,1),this.lightDebugMesh.render(i),this.#nu.setPosition(...this.#ja.position))}#au(i,g){const x=i.position||[0,0,0],_=i.radius||1,v=16,b=[];for(let i=0;i.99&&(q=[1,0,0]);const W=[L[1]*q[2]-L[2]*q[1],L[2]*q[0]-L[0]*q[2],L[0]*q[1]-L[1]*q[0]],be=Math.sqrt(W[0]*W[0]+W[1]*W[1]+W[2]*W[2]),Ke=[W[0]/be,W[1]/be,W[2]/be],Xe=[Ke[1]*L[2]-Ke[2]*L[1],Ke[2]*L[0]-Ke[0]*L[2],Ke[0]*L[1]-Ke[1]*L[0]],je=16;for(let i=0;iw){const i=S;S=w,w=i}g=Math.max(g,S),x=Math.min(x,w)}return x>=g&&x>=0}intersectTriangle(i,g,x,_=!0){const v=create$3(),b=create$3(),y=create$3(),S=create$3(),w=create$3();subtract$2(v,g,i),subtract$2(b,x,i),cross$2(y,this.direction,b);const L=dot$3(v,y);if(_){if(L<1e-5)return null}else if(L>-1e-5&&L<1e-5)return null;const k=1/L;subtract$2(S,this.origin,i);const H=k*dot$3(S,y);if(H<0||H>1)return null;cross$2(w,S,v);const z=k*dot$3(this.direction,w);if(z<0||H+z>1)return null;const q=k*dot$3(b,w);if(q>1e-5){const i=create$3();return scaleAndAdd$2(i,this.origin,this.direction,q),i}return null}intersectTriangleBarycentric(i,g,x,_=!0){const v=create$3(),b=create$3(),y=create$3(),S=create$3(),w=create$3();subtract$2(v,g,i),subtract$2(b,x,i),cross$2(y,this.direction,b);const L=dot$3(v,y);if(_){if(L<1e-5)return null}else if(L>-1e-5&&L<1e-5)return null;const k=1/L;subtract$2(S,this.origin,i);const H=k*dot$3(S,y);if(H<0||H>1)return null;cross$2(w,S,v);const z=k*dot$3(this.direction,w);if(z<0||H+z>1)return null;const q=k*dot$3(b,w);if(q>1e-5){const i=create$3();return scaleAndAdd$2(i,this.origin,this.direction,q),{point:i,t:q,u:H,v:z}}return null}}class Raycaster3D{ray;near=0;far=1/0;#ou=create$4();#uu=create$4();#lu=create$4();#cu=create$3();#hu=create$3();#Ft;#fu=create();constructor(){this.ray=new Ray}setFromCamera(i,g,x){const{rawCamera:_}=x,v=fromValues$3(_.x,_.y,_.z),b=x.screenToWorld(i,g),y=create$3();subtract$2(y,b,v),normalize$3(y,y),copy$3(this.ray.origin,v),copy$3(this.ray.direction,y),this.#Ft=x;const{pixelRectObject:S}=x,w=i*devicePixelRatio/S.width*2-1,L=-g*devicePixelRatio/S.height*2+1;set(this.#fu,w,L),"nearClipping"in _&&(this.near=_.nearClipping),"farClipping"in _&&(this.far=_.farClipping)}intersectObject(i,g=!0){const x=[];return this.#du(i,g,x),x.sort((i,g)=>i.distance-g.distance)}intersectObjects(i,g=!0){const x=[];for(const _ of i)this.#du(_,g,x);return x.sort((i,g)=>i.distance-g.distance)}#du(i,g,x){const _=i.useBillboard,v=i._renderRatioX||1,b=i._renderRatioY||1;if(_&&this.#Ft){i.usePixelSize?this.#mu(i,x):this.#pu(i,x)}else if(i.geometry){const g=this.#uu;if(copy$4(g,i.modelMatrix),1!==v||1!==b)scale$4(g,g,[v,b,1]),this.#gu(i,g,x,!0);else{const g=i.boundingAABB;this.ray.intersectBox(g)&&this.#gu(i,i.modelMatrix,x,!0)}}if(g&&i.children)for(const _ of i.children)this.#du(_,g,x)}#mu(i,x){const _=this.#Ft,v=i.modelMatrix,b=i.pixelSize;g(i.fontSize);const y=i._renderRatioX||1,S=i._renderRatioY||1,{rawCamera:w,projectionMatrix:L,pixelRectObject:k}=_,H=fromValues$3(v[12],v[13],v[14]),z=transformMat4$2(this.#cu,H,w.modelMatrix),q=transformMat4$1(this.#ou,fromValues$2(z[0],z[1],z[2],1),L);if(q[3]<=0)return;const W=q[0]/q[3],be=q[1]/q[3],Ke=this.#fu[0],Xe=this.#fu[1],je=b*window.devicePixelRatio,Ye=je/k.width*2*(y/S),Ze=je/k.height*2;if(Math.abs(Ke-W)<=.5*Ye&&Math.abs(Xe-be)<=.5*Ze){const g=distance$2(this.ray.origin,H);if(g>=this.near&&g<=this.far){const _=(Ke-W)/Ye+.5,v=(Xe-be)/Ze+.5;x.push({distance:g,point:H,localPoint:fromValues$3(0,0,0),object:i,faceIndex:0,uv:fromValues(_,1-v),ray:this.ray.clone()})}}}#pu(i,g){const x=this.#Ft,_=i.modelMatrix,v=i._renderRatioX||1,b=i._renderRatioY||1,y=invert$1(this.#uu,x.rawCamera.modelMatrix),S=this.#lu;copy$4(S,y),S[12]=_[12],S[13]=_[13],S[14]=_[14];scale$4(S,S,[Math.hypot(_[0],_[1],_[2])*v,Math.hypot(_[4],_[5],_[6])*b,Math.hypot(_[8],_[9],_[10])]),this.#gu(i,S,g,!1)}#gu(i,g,x,_){const v=new Ray;copy$3(v.origin,this.ray.origin),copy$3(v.direction,this.ray.direction);const b=invert$1(this.#ou,g);if(b){v.applyMatrix4(b);const y=i.geometry,S=y.vertexBuffer,w=y.indexBuffer,L=S.data,k=S.interleavedStruct.arrayStride/4;if(w){const b=w.data;for(let y=0;y=this.near&&z<=this.far){const x=fromValues(_[b*v+6],_[b*v+7]),q=fromValues(_[y*v+6],_[y*v+7]),W=fromValues(_[S*v+6],_[S*v+7]),be=create();scaleAndAdd(be,be,x,1-L-k),scaleAndAdd(be,be,q,L),scaleAndAdd(be,be,W,k),w.push({distance:z,point:H,localPoint:i,object:g,faceIndex:Math.floor(b/3),uv:be,ray:this.ray.clone()})}}}}class Raycaster2D{ray;#Ft;#_u=create$3();#ou=create$4();#uu=create$4();#cu=create$3();constructor(){this.ray=new Ray}setFromCamera(i,g,x){this.#Ft=x;const{pixelRectObject:_}=x,v=i*devicePixelRatio/_.width*2-1,b=1-g*devicePixelRatio/_.height*2;set$3(this.#_u,v,b,0);const y=x.screenToWorld(i,g);set$3(this.ray.origin,y[0],y[1],y[2]),set$3(this.ray.direction,0,0,-1)}intersectObject(i,g=!0){const x=[];return this.#du(i,g,x),x.sort((i,g)=>i.distance-g.distance)}intersectObjects(i,g=!0){const x=[];for(const _ of i)this.#du(_,g,x);return x.sort((i,g)=>i.distance-g.distance)}#du(i,g,x){if(i.geometry){const g=this.#Ft,_=g.projectionMatrix,v=g.rawCamera.modelMatrix,b=multiply$4(this.#ou,_,v);multiply$4(b,b,i.modelMatrix);const y=invert$1(this.#uu,b);if(y){const g=transformMat4$2(this.#cu,this.#_u,y);let b=!1,S=1,w=1;if(i.is2DMeshType?(S=i.width,w=i.height,g[0]>=-S/2&&g[0]<=S/2&&g[1]>=-w/2&&g[1]<=w/2&&(b=!0)):g[0]>=-.5&&g[0]<=.5&&g[1]>=-.5&&g[1]<=.5&&(b=!0),b){const b=invert$1(create$4(),multiply$4(create$4(),_,v)),y=transformMat4$2(create$3(),this.#_u,b),L=g[0]/S>g[1]/w?1:0;x.push({distance:0,point:y,localPoint:clone$3(g),object:i,uv:fromValues(g[0]/S+.5,g[1]/w+.5),ray:this.ray.clone(),faceIndex:L})}}}if(g&&i.children)for(const _ of i.children)this.#du(_,g,x)}}class PickingManager{lastMouseEvent;lastMouseClickEvent;#vu;#bu;#yu;#Su;#l;#Ft;#Tu=[];#Mu=0;#wu=0;#Cu;#Ru;#N=0;#Pu=new Raycaster3D;#Bu=new Raycaster2D;get videoMemorySize(){return this.#N}get mouseX(){return this.#Mu}set mouseX(i){this.#Mu=i}get mouseY(){return this.#wu}set mouseY(i){this.#wu=i}get castingList(){return this.#Tu}get pickingGPUTexture(){return this.#yu}get pickingGPUTextureView(){return this.#Su}get pickingDepthGPUTextureView(){return this.#bu}resetCastingList(){this.#Tu.length=0}destroy(){this.#yu&&(this.#yu.destroy(),this.#vu.destroy(),this.#yu=null,this.#Su=null,this.#vu=null,this.#bu=null)}checkTexture(i){const{redGPUContext:g}=i,{resourceManager:x}=g;this.#Ft=i,this.#l=g,this.#yu?.width===this.#Ft.pixelRectObject.width&&this.#yu?.height===this.#Ft.pixelRectObject.height||(this.destroy(),this.#yu=this.#Iu("picking",navigator.gpu.getPreferredCanvasFormat()),this.#Su=x.getGPUResourceBitmapTextureView(this.#yu),this.#vu=this.#Iu("pickingDepth","depth32float"),this.#bu=x.getGPUResourceBitmapTextureView(this.#vu),this.#mr())}checkEvents(i,g){this.castingList.length&&(this.#Eu(i,g),this.resetCastingList())}#mr(){const i=this.#yu;if(!i)return 0;this.#N=calculateTextureByteSize(i)+calculateTextureByteSize(this.#vu)}#Iu(i,g){const{resourceManager:x}=this.#l;return x.createManagedTexture({size:[this.#Ft.pixelRectObject.width,this.#Ft.pixelRectObject.height,1],usage:GPUTextureUsage.RENDER_ATTACHMENT|GPUTextureUsage.TEXTURE_BINDING|GPUTextureUsage.COPY_SRC,format:g,sampleCount:1,label:`${this.#Ft.name}_${i}_${this.#Ft.pixelRectObject.width}x${this.#Ft.pixelRectObject.height}`})}#Eu=async(i,g,x=1,_=1)=>{const{gpuDevice:v}=i.redGPUContext,{pixelRectArray:b}=i,y=this.#Mu,S=this.#wu;if(y<=0||y>=b[2]||S<=0||S>=b[3])return;const w=this.#Du();let L=this.#Uu(v,x,_,y,S);const k=await this.#Lu(L);L.destroy(),L=null,k?(this.#Au(k,y,S,g,w),this.#Gu(k,y,S,g,w)):this.#ku(),this.lastMouseEvent=null,this.lastMouseClickEvent=null};#Du=()=>this.#Tu.reduce((i,g)=>(i[g.pickingId]=g,i),{});#Uu=(i,g,x,_,v)=>{const b=i.createCommandEncoder({label:"PickingManager_ReadPixel_CommandEncoder"}),y=i.createBuffer({size:4,usage:GPUBufferUsage.COPY_DST|GPUBufferUsage.MAP_READ,label:"readPixelBuffer"}),S={texture:this.#yu,origin:{x:_,y:v,z:0}},w={buffer:y,bytesPerRow:256,rowsPerImage:1};return b.copyTextureToBuffer(S,w,{width:1,height:1,depthOrArrayLayers:1}),i.queue.submit([b.finish()]),y};#Ou(i,g,x,_,v,b,y){const S="Camera2D"===this.#Ft.rawCamera.constructor.name?this.#Bu:this.#Pu;let w;if(S.setFromCamera(this.#Mu/devicePixelRatio,this.#wu/devicePixelRatio,this.#Ft),_){w=S.intersectObject(_)[0]}const L=new PickingEvent(i,g,x,_,v,b,y,w);return L.ray||(L.ray=S.ray.clone()),L}#Au=(g,x,_,v,b)=>{const y=b[g],S=this.lastMouseClickEvent?.type;if(S===i.CLICK){const i=this.#Ou(g,x,_,y,v,S,this.lastMouseClickEvent);this.#Nu(S,i)}};#Gu=(g,x,_,v,b)=>{const y=b[g],S=this.lastMouseEvent?.type;if(S){const b=this.#Ou(g,x,_,y,v,S,this.lastMouseEvent);switch(this.#Cu&&(b.movementX=x-this.#Cu.mouseX,b.movementY=_-this.#Cu.mouseY),S){case i.DOWN:case i.UP:this.#Nu(S,b);break;case i.MOVE:this.#Vu(g,y,b)}this.#Cu=b}};#Vu=(g,x,_)=>{const v=this.#Cu?.pickingId;v!==g?(this.#Cu&&v&&v!==g&&this.#ku(),this.#Ru!==x&&(this.#Nu(i.OVER,_),document.body.style.cursor="pointer"),this.#Ru=x):this.#Nu(i.MOVE,_)};#ku=()=>{this.#Cu&&this.#Nu(i.OUT,this.#Cu),this.#Cu=null,this.#Ru=null,document.body.style.cursor="default"};async#Lu(i){await i.mapAsync(GPUMapMode.READ);const g=new DataView(i.getMappedRange()),x="rgba8unorm"==this.#yu.format?[0,1,2,3]:[2,1,0,3],_=g.getUint8(x[0]),v=g.getUint8(x[1]),b=g.getUint8(x[2]);return(g.getUint8(x[3])<<24|b<<16|v<<8|_)>>>0}#Nu(i,g){g.target&&g.target.events[i]&&g.target.events[i](g)}}Object.freeze(PickingManager);class FXAA extends ASinglePassPostEffect{#Fu=.75;#Hu=.166;#zu=.0833;constructor(i){super(i);this.init(i,"POST_EFFECT_FXAA",createBasicPostEffectCode(this,"\nlet index=vec2(global_id.xy);\nlet dims=textureDimensions(sourceTexture);\nlet i_index=vec2(index);\n\n//1. 현재 픽셀 및 주변 4방향 루마(Luma) 및 알파 샘플링\nlet colorM4=textureLoad(sourceTexture,index);\nlet colorM=colorM4.rgb;\nlet lumaM=getLuma(colorM);\n\nlet colorN4=fetchColor4(i_index + vec2(0,-1),dims);\nlet colorS4=fetchColor4(i_index + vec2(0,1),dims);\nlet colorW4=fetchColor4(i_index + vec2(-1,0),dims);\nlet colorE4=fetchColor4(i_index + vec2(1,0),dims);\n\nlet lumaN=getLuma(colorN4.rgb);\nlet lumaS=getLuma(colorS4.rgb);\nlet lumaW=getLuma(colorW4.rgb);\nlet lumaE=getLuma(colorE4.rgb);\n\n//2. 로컬 대비(Contrast) 분석을 통한 조기 종료 결정\nlet lumaMin=min(lumaM,min(min(lumaN,lumaS),min(lumaW,lumaE)));\nlet lumaMax=max(lumaM,max(max(lumaN,lumaS),max(lumaW,lumaE)));\nlet range=lumaMax - lumaMin;\n\nif (range < max(uniforms.edgeThresholdMin,lumaMax * uniforms.edgeThreshold)) { textureStore(outputTexture,index,colorM4); return;\n}\n\n//3. 대각선 루마 샘플링 (3x3 영역 완성)\nlet lumaNW=getLuma(fetchColor4(i_index + vec2(-1,-1),dims).rgb);\nlet lumaNE=getLuma(fetchColor4(i_index + vec2(1,-1),dims).rgb);\nlet lumaSW=getLuma(fetchColor4(i_index + vec2(-1,1),dims).rgb);\nlet lumaSE=getLuma(fetchColor4(i_index + vec2(1,1),dims).rgb);\n\n//4. 엣지 방향 판단 (수직 vs 수평)\nlet edgeVer=abs(lumaNW + lumaSW - 2.0 * lumaW) + abs(lumaN + lumaS - 2.0 * lumaM) * 2.0 + abs(lumaNE + lumaSE - 2.0 * lumaE);\nlet edgeHor=abs(lumaNW + lumaNE - 2.0 * lumaN) + abs(lumaW + lumaE - 2.0 * lumaM) * 2.0 + abs(lumaSW + lumaSE - 2.0 * lumaS);\nlet isHorizontal=edgeHor >=edgeVer;\n\n//5. 엣지 방향에 따른 기울기 및 오프셋 설정\nlet luma1=select(lumaW,lumaN,isHorizontal);\nlet luma2=select(lumaE,lumaS,isHorizontal);\nlet gradient1=luma1 - lumaM;\nlet gradient2=luma2 - lumaM;\nlet is1Steeper=abs(gradient1) >=abs(gradient2);\nlet gradientScaled=0.25 * max(abs(gradient1),abs(gradient2));\n\nvar lumaLocalAverage=0.0;\nvar edgeStep=vec2(0,0);\nif (is1Steeper) { edgeStep=select(vec2(-1,0),vec2(0,-1),isHorizontal); lumaLocalAverage=0.5 * (luma1 + lumaM);\n} else { edgeStep=select(vec2(1,0),vec2(0,1),isHorizontal); lumaLocalAverage=0.5 * (luma2 + lumaM);\n}\n\n//6. 언리얼급 품질을 위한 엣지 탐색 루프 (Edge Search Iteration)\nvar posP=i_index + edgeStep;\nvar posN=i_index + edgeStep;\nlet searchStep=select(vec2(1,0),vec2(0,1),isHorizontal);\n\nvar doneP=false;\nvar doneN=false;\nfor (var i=0;i < 10;i++) { if (!doneP) { if (abs(getLuma(fetchColor4(posP,dims).rgb) - lumaLocalAverage) >=gradientScaled) { doneP=true;} else { posP +=searchStep;} } if (!doneN) { if (abs(getLuma(fetchColor4(posN,dims).rgb) - lumaLocalAverage) >=gradientScaled) { doneN=true;} else { posN -=searchStep;} } if (doneP && doneN) { break;}\n}\n\n//7. 탐색된 끝점까지의 거리를 기반으로 한 엣지 블렌딩 계산\nlet distP=select(f32(posP.x - i_index.x),f32(posP.y - i_index.y),isHorizontal);\nlet distN=select(f32(i_index.x - posN.x),f32(i_index.y - posN.y),isHorizontal);\nlet distMin=min(abs(distP),abs(distN));\nlet edgeBlend=saturate(0.5 - distMin/(abs(distP) + abs(distN)));\n\n//8. 서브픽셀 필터링 (고주파 노이즈 제거용)\nlet lumaL=(lumaN + lumaS + lumaW + lumaE) * 2.0;\nlet lumaCorners=lumaNW + lumaNE + lumaSW + lumaSE;\nlet subpixFilter=saturate(abs((lumaL + lumaCorners)/12.0 - lumaM)/range);\nlet subpixBlend=smoothstep(0.0,1.0,subpixFilter) * uniforms.subpix;\n\n//9. 최종 블렌딩 및 알파 채널 보존 합성\nlet finalBlend=max(edgeBlend,subpixBlend);\nlet colorTarget4=fetchColor4(i_index + edgeStep,dims);\n\n//RGBA 전체를 보간하여 투명도 유지\nlet finalColor4=mix(colorM4,colorTarget4,finalBlend);\n\ntextureStore(outputTexture,index,finalColor4);\n","\nstruct Uniforms { subpix:f32, edgeThreshold:f32, edgeThresholdMin:f32, padding:f32\n};\n\nfn getLuma(rgb:vec3) -> f32 { return dot(rgb,vec3(0.299,0.587,0.114));\n}\n\nfn fetchColor4(pos:vec2,dims:vec2) -> vec4 { let p=vec2(clamp(vec2(pos),vec2(0),dims - 1)); return textureLoad(sourceTexture,p);\n}\n")),this.subpix=this.#Fu,this.edgeThreshold=this.#Hu,this.edgeThresholdMin=this.#zu}get subpix(){return this.#Fu}set subpix(i){validateNumberRange(i,0,1),this.#Fu=i,this.updateUniform("subpix",i)}get edgeThreshold(){return this.#Hu}set edgeThreshold(i){validateNumberRange(i,1e-4,.25),this.#Hu=i,this.updateUniform("edgeThreshold",i)}get edgeThresholdMin(){return this.#zu}set edgeThresholdMin(i){validateNumberRange(i,1e-5,.1),this.#zu=i,this.updateUniform("edgeThresholdMin",i)}}Object.freeze(FXAA);class TAA{#l;#sr;#An;#Gn;#kn;#On;#Kn;#Xn;#jn;#Yn;#qn;#h;#Wn;#Zn;#Jn;#$u=new Map;#Ku=new Map;#Xu=new Map;#ju=null;#Yu;#qu;#Wu;#Zu;#Ju;#Qu;#tr=8;#nr=8;#rr=1;#or=[];#N=0;#el=0;#tl=.5;#ur;#lr;#nl=[0,0];#rl=create$4();constructor(i){this.#l=i,this.#sr=i.antialiasingManager;const g=this.#il();this.#ne(i,"POST_EFFECT_TAA",{msaa:g.msaa,nonMsaa:g.nonMsaa}),this.jitterStrength=this.#tl}get prevNoneJitterProjectionCameraMatrix(){return this.#rl}get frameIndex(){return this.#el}get videoMemorySize(){return this.#N}get jitterStrength(){return this.#tl}set jitterStrength(i){this.#tl=i}render(i,g,x,_){const v=_.textureView;_.texture;const{gpuDevice:b,antialiasingManager:y}=this.#l,{useMSAA:S,msaaID:w}=y;this.#el++,this.#Xn&&(this.updateUniform("frameIndex",this.#el),this.updateUniform("currJitterOffset",i.jitterOffset),this.updateUniform("prevJitterOffset",this.#nl),copy$4(this.#rl,i.noneJitterProjectionCameraMatrix),this.#nl=[...i.jitterOffset]);const L=this.#cr(i),k=this.#ur!==S||this.#lr!==w,H=this.#hr([v]);(L||k||H)&&this.#al(i,[v],S,this.#l,b),this.#sl(b,g,x);{const i=b.createCommandEncoder({label:"TAA_CopyTexture_CommandEncoder_compute"});i.copyTextureToTexture({texture:this.#Yu},{texture:this.#Wu},[g,x,1]),b.queue.submit([i.finish()])}return this.#el<=20||this.#el,this.#ur=S,this.#lr=w,{texture:this.#Yu,textureView:this.#qu}}clear(){this.#Wu&&(this.#Wu.destroy(),this.#Wu=null,this.#Zu=null),this.#Yu&&(this.#Yu.destroy(),this.#Yu=null,this.#qu=null),this.#$u.clear(),this.#Ku.clear(),this.#Xu.clear(),this.#ju=null}updateUniform(i,g){this.#Xn.writeOnlyBuffer(this.#jn.members[i],g)}#il(){const createCode=i=>` \nstruct Uniforms { frameIndex:f32, currJitterOffset:vec2, prevJitterOffset:vec2,\n};\nstruct NeighborhoodStats { minColor:vec3, maxColor:vec3, mean:vec3, stdDev:vec3, minAlpha:f32, maxAlpha:f32, meanAlpha:f32,\n};\nstruct SampledColor { rgb:vec3, ycocg:vec3, alpha:f32,\n};\nfn rgb_to_ycocg(rgb:vec3) -> vec3 { let y=dot(rgb,vec3(0.25,0.5,0.25)); let co=dot(rgb,vec3(0.5,0.0,-0.5)); let cg=dot(rgb,vec3(-0.25,0.5,-0.25)); return vec3(y,co,cg);\n}\nfn ycocg_to_rgb(ycocg:vec3) -> vec3 { let y=ycocg.x; let co=ycocg.y; let cg=ycocg.z; return vec3(y + co - cg,y + cg,y - co - cg);\n}\nfn get_depth_confidence(currDepth:f32,prevDepth:f32) -> f32 { let depthDiff=abs(currDepth - prevDepth); return 1.0 - clamp((depthDiff - 0.01)/0.02,0.0,1.0);\n}\nfn fetch_depth_bilinear(tex:texture_depth_2d,uv:vec2,screenSize:vec2) -> f32 { let samplePos=uv * screenSize - 0.5; let f=fract(samplePos); let base=vec2(floor(samplePos)); let size=vec2(textureDimensions(tex)); let d00=textureLoad(tex,clamp(base + vec2(0,0),vec2(0),size - 1),0); let d10=textureLoad(tex,clamp(base + vec2(1,0),vec2(0),size - 1),0); let d01=textureLoad(tex,clamp(base + vec2(0,1),vec2(0),size - 1),0); let d11=textureLoad(tex,clamp(base + vec2(1,1),vec2(0),size - 1),0); return mix(mix(d00,d10,f.x),mix(d01,d11,f.x),f.y);\n}\nfn calculate_neighborhood_stats_ycocg(pixelCoord:vec2,screenSizeU:vec2) -> NeighborhoodStats { let screenSize=vec2(screenSizeU); var m1=vec3(0.0); var m2=vec3(0.0); var m1A=0.0; var minC=vec3(1e5); var maxC=vec3(-1e5); var minA=1e5; var maxA=-1e5; for (var y:i32=-1;y <=1;y++) { for (var x:i32=-1;x <=1;x++) { let sampleCoord=clamp(pixelCoord + vec2(x,y),vec2(0),vec2(screenSizeU) - 1); let colorRGBA=textureLoad(sourceTexture,sampleCoord,0); let colorYCoCg=rgb_to_ycocg(colorRGBA.rgb); let alpha=colorRGBA.a; m1 +=colorYCoCg; m2 +=colorYCoCg * colorYCoCg; m1A +=alpha; minC=min(minC,colorYCoCg); maxC=max(maxC,colorYCoCg); minA=min(minA,alpha); maxA=max(maxA,alpha); } } let sampleCount=9.0; var stats:NeighborhoodStats; stats.mean=m1/sampleCount; stats.stdDev=sqrt(max((m2/sampleCount) - (stats.mean * stats.mean),vec3(0.0))); stats.minColor=minC; stats.maxColor=maxC; stats.minAlpha=minA; stats.maxAlpha=maxA; stats.meanAlpha=m1A/sampleCount; return stats;\n}\nfn get_color_discrepancy_weight(stats:NeighborhoodStats,histYCoCg:vec3) -> f32 { let diff=abs(stats.mean.x - histYCoCg.x); let threshold=max(stats.stdDev.x * 0.45,0.01); return smoothstep(threshold,threshold * 2.0,diff);\n}\nfn sample_texture_catmull_rom_antiflicker(tex:texture_2d,smp:sampler,uv:vec2,texSize:vec2) -> SampledColor { let samplePos=uv * texSize; let texPos1=floor(samplePos - 0.5) + 0.5; let f=samplePos - texPos1; let w0=f * (-0.5 + f * (1.0 - 0.5 * f)); let w1=1.0 + f * f * (-2.5 + 1.5 * f); let w2=f * (0.5 + f * (2.0 - 1.5 * f)); let w3=f * f * (-0.5 + 0.5 * f); let w12=w1 + w2; let offset12=w2/w12; let invTexSize=1.0/texSize; let coords=array,5>( (texPos1 + vec2(offset12.x,-1.0)) * invTexSize, (texPos1 + vec2(-1.0,offset12.y)) * invTexSize, (texPos1 + offset12) * invTexSize, (texPos1 + vec2(2.0,offset12.y)) * invTexSize, (texPos1 + vec2(offset12.x,2.0)) * invTexSize ); let weights=array( w12.x * w0.y,w0.x * w12.y,w12.x * w12.y,w3.x * w12.y,w12.x * w3.y ); var sumRGB=vec3(0.0); var sumYCoCg=vec3(0.0); var sumAlpha=0.0; var sumW=0.0; for(var i=0;i < 5;i++) { let sampleRGBA=textureSampleLevel(tex,smp,coords[i],0.0); let sampleRGB=max(sampleRGBA.rgb,vec3(0.0)); let sampleYCoCg=rgb_to_ycocg(sampleRGB); let w=weights[i] * (1.0/(1.0 + sampleYCoCg.x)); sumRGB +=sampleRGB * w; sumYCoCg +=sampleYCoCg * w; sumAlpha +=sampleRGBA.a * w; sumW +=w; } var result:SampledColor; let invSumW=1.0/max(sumW,0.0001); result.rgb=sumRGB * invSumW; result.ycocg=sumYCoCg * invSumW; result.alpha=sumAlpha * invSumW; return result;\n}\nfn clip_history_ycocg(historyYCoCg:vec3,stats:NeighborhoodStats,motion:f32) -> vec3 { let gamma=mix(0.2,0.7,motion); let v_min=min(stats.minColor,stats.mean - stats.stdDev * gamma); let v_max=max(stats.maxColor,stats.mean + stats.stdDev * gamma); return clamp(historyYCoCg,v_min,v_max);\n}\n @group(0) @binding(0) var sourceTexture:texture_2d; @group(0) @binding(1) var historyTexture:texture_2d; @group(0) @binding(2) var motionVectorTexture:texture_2d; @group(0) @binding(3) var taaTextureSampler:sampler; @group(0) @binding(4) var depthTexture:texture_depth_2d; @group(0) @binding(5) var historyDepthTexture:texture_depth_2d; @group(1) @binding(0) var outputTexture:texture_storage_2d; ${tr} @group(1) @binding(2) var uniforms:Uniforms; @compute @workgroup_size(${this.#tr},${this.#nr},${this.#rr}) fn main(@builtin(global_invocation_id) global_id:vec3) { { let pixelCoord=vec2(global_id.xy); let screenSizeU=textureDimensions(sourceTexture); let screenSize=vec2(screenSizeU); let yFlipVec2=vec2(1.0,-1.0); if (any(pixelCoord >=vec2(screenSizeU))) { return; } let currentUV=(vec2(pixelCoord) + 0.5 - uniforms.currJitterOffset * yFlipVec2)/screenSize; let stats=calculate_neighborhood_stats_ycocg(pixelCoord,screenSizeU); let currentRGBA=textureSampleLevel(sourceTexture,taaTextureSampler,currentUV,0.0); let currentRGB=currentRGBA.rgb; let currentAlpha=currentRGBA.a; let currentYCoCg=rgb_to_ycocg(currentRGB); let currentDepth=textureLoad(depthTexture,pixelCoord,0); var closestDepth=1.0; var closestCoord=pixelCoord; for(var y:i32=-1;y <=1;y++) { for(var x:i32=-1;x <=1;x++) { let sc=clamp(pixelCoord + vec2(x,y),vec2(0),vec2(screenSizeU) - 1); let d=textureLoad(depthTexture,sc,0); if(d < closestDepth) { closestDepth=d; closestCoord=sc; } } } let motionData=textureLoad(motionVectorTexture,closestCoord,0); let velocity=motionData.xy; let jitterDisabled=motionData.z > 0.5; if (jitterDisabled) { textureStore(outputTexture,pixelCoord,vec4(currentRGB,currentAlpha)); return; } let historyUV=(vec2(pixelCoord) + 0.5 - uniforms.currJitterOffset * yFlipVec2 + uniforms.prevJitterOffset * yFlipVec2)/screenSize - velocity; var finalRGB:vec3; var finalAlpha:f32; if (any(historyUV < vec2(0.0)) || any(historyUV > vec2(1.0))) { finalRGB=currentRGB; finalAlpha=currentAlpha; } else { let prevDepth=fetch_depth_bilinear(historyDepthTexture,historyUV,screenSize); let historyData=sample_texture_catmull_rom_antiflicker(historyTexture,taaTextureSampler,historyUV,screenSize); let motionLen=length(velocity * screenSize); let motionSoft=smoothstep(0.0,1.0,motionLen); let clippedYCoCg=clip_history_ycocg(historyData.ycocg,stats,motionSoft); let clippedAlpha=clamp(historyData.alpha,stats.minAlpha,stats.maxAlpha); let clippedHistoryRGB=ycocg_to_rgb(clippedYCoCg); let lumaWeight=get_color_discrepancy_weight(stats,clippedYCoCg); var blendFactor=mix(0.08,0.4,motionSoft); let depthConfidence=get_depth_confidence(currentDepth,prevDepth); blendFactor=max(blendFactor,1.0 - depthConfidence * depthConfidence); blendFactor=max(blendFactor,lumaWeight * 0.5); let currentRGBA=vec4(currentRGB,currentAlpha); let clippedHistoryRGBA=vec4(clippedHistoryRGB,clippedAlpha); let finalRGBA=mix(clippedHistoryRGBA,currentRGBA,blendFactor); finalRGB=finalRGBA.rgb; finalAlpha=finalRGBA.a; } textureStore(outputTexture,pixelCoord,vec4(finalRGB,finalAlpha));\n} } `;return{msaa:createCode(),nonMsaa:createCode()}}#ne(i,g,x){this.#h=g;const{resourceManager:_}=i;this.#An=_.createGPUShaderModule(`${g}_MSAA`,{code:x.msaa}),this.#Gn=_.createGPUShaderModule(`${g}_NonMSAA`,{code:x.nonMsaa}),this.#Wn=parseWGSL(x.msaa),this.#Zn=parseWGSL(x.nonMsaa);const v=this.#Wn.storage,b=this.#Wn.uniforms;if(this.#qn=v,this.#jn=b.uniforms,this.#Yn=b.systemUniforms,this.#jn){const g=new ArrayBuffer(this.#jn.arrayBufferByteLength);this.#Xn=new UniformBuffer(i,g,"TAA_UniformBuffer")}}#sl(i,g,x){const _=i.createCommandEncoder({label:"TAA_Execute_CommandEncoder_compute"}),v=_.beginComputePass();v.setPipeline(this.#Kn),v.setBindGroup(0,this.#Ju),v.setBindGroup(1,this.#Qu),v.dispatchWorkgroups(Math.ceil(g/this.#tr),Math.ceil(x/this.#nr)),v.end(),i.queue.submit([_.finish()])}#al(i,g,x,_,v){const b=[],y=[];b.push({binding:0,resource:g[0]}),b.push({binding:1,resource:this.#Zu}),b.push({binding:4,resource:i.viewRenderTextureManager.depthTextureView}),b.push({binding:5,resource:i.viewRenderTextureManager.prevDepthTextureView});const S=x?i.viewRenderTextureManager.gBufferMotionVectorResolveTextureView:i.viewRenderTextureManager.gBufferMotionVectorTextureView;b.push({binding:2,resource:S}),b.push({binding:3,resource:i.redGPUContext.resourceManager.basicSampler.gpuSampler}),y.push({binding:0,resource:this.#qu}),this.#Yn&&y.push({binding:this.#Yn.binding,resource:{buffer:i.postEffectManager.postEffectSystemUniformBuffer.gpuBuffer,offset:0,size:i.postEffectManager.postEffectSystemUniformBuffer.size}}),this.#Xn&&this.#jn&&y.push({binding:this.#jn.binding,resource:{buffer:this.#Xn.gpuBuffer,offset:0,size:this.#Xn.size}}),this.#fr(b,y,x,_,v),this.#ol(x,_,v)}#fr(i,g,x,_,v){const b=x?this.#Wn:this.#Zn,y=`${this.#h}_BIND_GROUP_LAYOUT_0_USE_MSAA_${x}`,S=`${this.#h}_BIND_GROUP_LAYOUT_1_USE_MSAA_${x}`;if(!this.#$u.has(y)){const i=_.resourceManager.getGPUBindGroupLayout(y)||_.resourceManager.createBindGroupLayout(y,getComputeBindGroupLayoutDescriptorFromShaderInfo(b,0,x));this.#$u.set(y,i)}if(!this.#$u.has(S)){const i=_.resourceManager.getGPUBindGroupLayout(S)||_.resourceManager.createBindGroupLayout(S,getComputeBindGroupLayoutDescriptorFromShaderInfo(b,1,x));this.#$u.set(S,i)}this.#kn=this.#$u.get(y),this.#On=this.#$u.get(S),this.#Ju=v.createBindGroup({label:`${this.#h}_FRAME_BIND_GROUP_0_USE_MSAA_${x}`,layout:this.#kn,entries:i}),this.#Qu=v.createBindGroup({label:`${this.#h}_FRAME_BIND_GROUP_1_USE_MSAA_${x}`,layout:this.#On,entries:g})}#ol(i,g,x){const _=`${this.#h}_COMPUTE_PIPELINE_USE_MSAA_${i}`,v=`${this.#h}_PIPELINE_LAYOUT_USE_MSAA_${i}`;if(this.#ju!==i||!this.#Xu.has(_)){if(!this.#Ku.has(v)){const g=x.createPipelineLayout({label:`${this.#h}_PIPELINE_LAYOUT_USE_MSAA_${i}`,bindGroupLayouts:[this.#kn,this.#On]});this.#Ku.set(v,g)}const g=i?this.#An:this.#Gn,b=x.createComputePipeline({label:_,layout:this.#Ku.get(v),compute:{module:g,entryPoint:"main"}});this.#Xu.set(_,b),this.#ju=i}this.#Kn=this.#Xu.get(_)}#cr(i){const{redGPUContext:x,viewRenderTextureManager:_,name:v}=i,{gBufferColorTexture:b}=_,{resourceManager:y}=x,{width:S,height:w}=b,L=S!==this.#Jn?.width||w!==this.#Jn?.height||!this.#Yu||!this.#Wu||!this.#Yu;return L&&(g(`TAA 텍스처 재생성:${S}x${w},이전 프레임 히스토리 리셋`),this.#el=0,this.clear(),this.#Yu=y.createManagedTexture({size:{width:S,height:w},format:"rgba16float",usage:GPUTextureUsage.TEXTURE_BINDING|GPUTextureUsage.STORAGE_BINDING|GPUTextureUsage.COPY_SRC|GPUTextureUsage.RENDER_ATTACHMENT,label:`${v}_${this.#h}_currentFrame_${S}x${w}`}),this.#qu=y.getGPUResourceBitmapTextureView(this.#Yu,{dimension:"2d",format:"rgba16float",label:`${this.#h}_currentFrame_View`}),this.#Wu=y.createManagedTexture({size:{width:S,height:w},format:"rgba16float",usage:GPUTextureUsage.TEXTURE_BINDING|GPUTextureUsage.STORAGE_BINDING|GPUTextureUsage.COPY_DST,label:`${v}_${this.#h}_previousFrame_${S}x${w}`}),this.#Zu=y.getGPUResourceBitmapTextureView(this.#Wu,{dimension:"2d",format:"rgba16float",label:`${this.#h}_previousFrame`})),this.#Jn={width:S,height:w},this.#mr(),L}#mr(){this.#N=0,this.#Yu&&(this.#N+=calculateTextureByteSize(this.#Yu)),this.#Wu&&(this.#N+=calculateTextureByteSize(this.#Wu))}#hr(i){if(!this.#or||this.#or.length!==i.length)return this.#or=[...i],!0;for(let g=0;g{const{rawCamera:_,pixelRectArray:v}=x;return Gi=2*(i*window.devicePixelRatio+v[0])/v[2]-1,ki=-2*(g*window.devicePixelRatio+v[1])/v[3]+1,Oi=1,multiply$4($i,x.noneJitterProjectionMatrix,_.modelMatrix),Fi=clone$4($i),invert$1(Fi,Fi),Hi=fromValues$3(Gi,ki,1),identity$1(zi),translate(zi,zi,Hi),multiply$4(Fi,Fi,zi),Hi[0]=Fi[12],Hi[1]=Fi[13],Hi[2]=Fi[14],Ni=$i[12]*Gi+$i[13]*ki+$i[15],0!==Ni&&(Vi=1/Ni,Hi[0]/=Vi,Hi[1]/=Vi,Hi[2]/=Vi,Hi[0]=Hi[0]+_.x,Hi[1]=Hi[1]+_.y,Hi[2]=Hi[2]+_.z),[Hi[0],Hi[1],Hi[2]]};class Box extends Primitive{#Ii=function(){let i,g;return g=function(g,x,_,v,b,y,S,w,L,k,H,z,q){let W,be,Ke=w/H,Xe=L/z,je=w/2,Ye=L/2,Ze=k/2,Je=H+1,Qe=z+1,et=0,tt=[];for(be=0;be0?1:-1,g.push(tt.x,tt.y,tt.z),g.push(W/H*q,be/z*q),et+=1}}for(be=0;be0&&g(!0),b>0&&g(!1)),createPrimitiveGeometry(_,z,q,x)}}();constructor(i,g=1,x=1,_=1,v=8,b=8,y=!1,S=0,w=2*Math.PI){super(i);const L=`PRIMITIVE_CYLINDER_RT${g}_RB${x}_H${_}_RS${v}_HS${b}_TS${y}_TS${S}_TL${w}`,k=i.resourceManager.cachedBufferState;let H=k[L];H||(H=k[L]=this.#Ii(L,i,g,x,_,v,b,y,S,w)),this._setData(H)}}class Sphere extends Primitive{#Ii=function(){let i,g,x,_,v,b,y,S,w=[];const L=new Float32Array(3),k=new Float32Array(3);return function(H,z,q,W,be,Ke,Xe,je,Ye,Ze){i=je+Ye,_=0,w.length=0;const Je=[],Qe=[];for(x=0;x<=be;x++){const i=[],v=x/be;for(g=0;g<=W;g++){const x=g/W;L[0]=-q*Math.cos(Ke+x*Xe)*Math.sin(je+v*Ye),L[1]=q*Math.cos(je+v*Ye),L[2]=q*Math.sin(Ke+x*Xe)*Math.sin(je+v*Ye),Je.push(L[0],L[1],L[2]),k[0]=L[0],k[1]=L[1],k[2]=L[2],normalize$3(k,k),Je.push(k[0],k[1],k[2]),Je.push(x*Ze,v*Ze),i.push(_++)}w.push(i)}for(x=0;x0)&&Qe.push(v,b,S),(x!==be-1||i0&&(this.#xl=y/L,this.#_l=S/L,this.#vl=w/L)}}Object.freeze(SpotLight);class LightManager{#Sl=3;#Tl=q.MAX_CLUSTER_LIGHTS;#Ml=[];#wl=[];#Cl=[];#Rl;#Pl=create$4();get spotLights(){return this.#Cl}get spotLightCount(){return this.#Cl.length}get limitClusterLightCount(){return this.#Tl}get pointLights(){return this.#wl}get pointLightCount(){return this.#wl.length}get limitDirectionalLightCount(){return this.#Sl}get directionalLightCount(){return this.#Ml.length}get directionalLights(){return this.#Ml}get ambientLight(){return this.#Rl}set ambientLight(i){i instanceof AmbientLight||consoleAndThrowError("allow only AmbientLight instance"),this.#Rl=i}addSpotLight(i){i instanceof SpotLight||consoleAndThrowError("allow only SpotLight instance");this.#Cl.length+this.#wl.length>this.#Tl&&consoleAndThrowError("Cannot add more cluster lights. The limit has been reached."),this.#Cl.push(i)}addPointLight(i){i instanceof PointLight||consoleAndThrowError("allow only PointLight instance");this.#Cl.length+this.#wl.length>this.#Tl&&consoleAndThrowError("Cannot add more cluster lights. The limit has been reached."),this.#wl.push(i)}addDirectionalLight(i){i instanceof DirectionalLight||consoleAndThrowError("allow only DirectionalLight instance");this.#Ml.length>this.#Sl&&consoleAndThrowError("Cannot add more directional lights. The limit has been reached."),this.#Ml.push(i)}removeSpotLight(i){const g=this.#Cl.indexOf(i);-1!==g&&this.#Cl.splice(g,1)}removePointLight(i){const g=this.#wl.indexOf(i);-1!==g&&this.#wl.splice(g,1)}removeDirectionalLight(i){const g=this.#Ml.indexOf(i);-1!==g&&this.#Ml.splice(g,1)}removeAllSpotLight(){this.#Cl=[]}removeAllPointLight(){this.#wl=[]}removeAllDirectionalLight(){this.#Ml=[]}removeAllLight(){this.removeAllPointLight(),this.removeAllSpotLight(),this.removeAllDirectionalLight(),this.#Rl=null}getDirectionalLightProjectionViewMatrix(i){return multiply$4(create$4(),this.getDirectionalLightProjectionMatrix(i),this.getDirectionalLightViewMatrix(i))}getDirectionalLightProjectionMatrix(i){const g=create$4(),x=i.rawCamera instanceof Camera2D?fromValues$3(0,0,0):fromValues$3(i.rawCamera.x,i.rawCamera.y,i.rawCamera.z),_=Math.max(distance$2(x,create$3()),1);return bt(g,-_,_,-_,_,3*-_,3*_),g}getDirectionalLightViewMatrix(i){identity$1(this.#Pl);const g=i.rawCamera instanceof Camera2D?fromValues$3(0,0,0):fromValues$3(i.rawCamera.x,i.rawCamera.y,i.rawCamera.z),x=Math.max(distance$2(g,create$3()),1),_=fromValues$3(0,1,0),v=fromValues$3(0,0,0),b=i.scene.lightManager.directionalLights.length?fromValues$3(-i.scene.lightManager.directionalLights[0].direction[0]*x,-i.scene.lightManager.directionalLights[0].direction[1]*x,-i.scene.lightManager.directionalLights[0].direction[2]*x):create$3(),y=create$4();return lookAt(y,b,v,_),y}}Object.freeze(LightManager);class DirectionalShadowManager{#Bl=2048;#_r=.005;#Il;#El;#Dl;#l;#Tu=[];#N=0;get videoMemorySize(){return this.#N}get castingList(){return this.#Tu}get shadowDepthTextureView(){return this.#El}get shadowDepthTextureViewEmpty(){return this.#Dl}get bias(){return this.#_r}set bias(i){validatePositiveNumberRange(i,0,1),this.#_r=i}get shadowDepthTextureSize(){return this.#Bl}set shadowDepthTextureSize(i){validateUintRange(i,1),this.#Bl=i}reset(){this.destroy()}resetCastingList(){this.#Tu.length=0}update(i){this.#l=i,this.#Ul()}destroy(){this.#Il&&(this.#Il.destroy(),this.#Il=null,this.#El=null)}#mr(){const i=this.#Il;if(!i)return 0;this.#N=calculateTextureByteSize(i)}#Ul(){this.#Il?.width!==this.#Bl&&(this.destroy(),this.#Ll(),this.#mr())}#Al(i){const g=i.createTexture({size:[1,1,1],usage:GPUTextureUsage.RENDER_ATTACHMENT|GPUTextureUsage.TEXTURE_BINDING,format:"depth32float",label:`DirectionalShadowManager_EmptyDepthTexture_1x1_${Date.now()}`});this.#Dl=g.createView({label:g.label})}#Ll(){const{gpuDevice:i,resourceManager:g}=this.#l;this.#Il=g.createManagedTexture({size:[this.#Bl,this.#Bl,1],usage:GPUTextureUsage.RENDER_ATTACHMENT|GPUTextureUsage.TEXTURE_BINDING,format:"depth32float",label:`DirectionalShadowManager_shadowDepthTextureSize_${this.#Bl}x${this.#Bl}_${Date.now()}`}),this.#El=this.#Il.createView({label:this.#Il.label}),this.#Dl||this.#Al(i)}}Object.freeze(DirectionalShadowManager);class ShadowManager{#Gl=new DirectionalShadowManager;constructor(){}get directionalShadowManager(){return this.#Gl}update(i){this.#Gl.update(i)}}Object.freeze(ShadowManager);class Scene extends Object3DContainer{#f;#h;#kl=new ColorRGBA;#Ol=!1;#Nl=new LightManager;#Vl=new ShadowManager;#Fl;constructor(i){super(),this.#f=InstanceIdGenerator.getNextId(this.constructor),this.#h=i}get lightManager(){return this.#Nl}get shadowManager(){return this.#Vl}get physicsEngine(){return this.#Fl}set physicsEngine(i){this.#Fl=i}get name(){return this.#f||(this.#f=InstanceIdGenerator.getNextId(this.constructor)),this.#h||`${this.constructor.name} Instance ${this.#f}`}set name(i){this.#h=i}get backgroundColor(){return this.#kl}set backgroundColor(i){i instanceof ColorRGBA||consoleAndThrowError("allow only ColorRGBA instance"),this.#kl=i}get useBackgroundColor(){return this.#Ol}set useBackgroundColor(i){this.#Ol=i}}const Yi=create$4(),computeViewFrustumPlanes=(i,g)=>{multiply$4(Yi,i,g);const x=[[Yi[3]-Yi[0],Yi[7]-Yi[4],Yi[11]-Yi[8],Yi[15]-Yi[12]],[Yi[3]+Yi[0],Yi[7]+Yi[4],Yi[11]+Yi[8],Yi[15]+Yi[12]],[Yi[3]+Yi[1],Yi[7]+Yi[5],Yi[11]+Yi[9],Yi[15]+Yi[13]],[Yi[3]-Yi[1],Yi[7]-Yi[5],Yi[11]-Yi[9],Yi[15]-Yi[13]],[Yi[3]-Yi[2],Yi[7]-Yi[6],Yi[11]-Yi[10],Yi[15]-Yi[14]],[Yi[3]+Yi[2],Yi[7]+Yi[6],Yi[11]+Yi[10],Yi[15]+Yi[14]]];for(let i=0;i<6;i++){const g=x[i],_=Math.sqrt(g[0]*g[0]+g[1]*g[1]+g[2]*g[2]);g[0]/=_,g[1]/=_,g[2]/=_,g[3]/=_}return x};class ViewTransform{onResize=null;#l;#Hl=create$4();#zl=create$4();#ji;#Ot=0;#Nt=0;#Bt;#It;#Et=[0,0,0,0];#$l=0;#Kl=0;constructor(i){validateRedGPUContext(i),this.#l=i,this.setSize("100%","100%")}get redGPUContext(){return this.#l}get camera(){return this.#ji}set camera(i){i instanceof PerspectiveCamera||i instanceof Camera2D||i instanceof OrthographicCamera||i instanceof AController||consoleAndThrowError("allow PerspectiveCamera or OrthographicCamera or AController instance"),this.#ji=i}get x(){return this.#Ot}set x(i){this.setPosition(i,this.y)}get y(){return this.#Nt}set y(i){this.setPosition(this.x,i)}get width(){return this.#Bt}set width(i){this.setSize(i,this.#It)}get height(){return this.#It}set height(i){this.setSize(this.#Bt,i)}get pixelRectArray(){return this.#Et}get pixelRectObject(){return{x:this.#Et[0],y:this.#Et[1],width:this.#Et[2],height:this.#Et[3]}}get screenRectObject(){return{x:this.#Et[0]/devicePixelRatio,y:this.#Et[1]/devicePixelRatio,width:this.#Et[2]/devicePixelRatio,height:this.#Et[3]/devicePixelRatio}}get aspect(){return this.#Et[2]/this.#Et[3]}get frustumPlanes(){return this.#ji instanceof AController?computeViewFrustumPlanes(this.projectionMatrix,this.#ji.camera.modelMatrix):computeViewFrustumPlanes(this.projectionMatrix,this.#ji.modelMatrix)}get rawCamera(){return this.#ji instanceof AController?this.#ji.camera:this.#ji}get noneJitterProjectionMatrix(){const{pixelRectObject:i,redGPUContext:g}=this;if(this.rawCamera instanceof OrthographicCamera){const{nearClipping:i,farClipping:g}=this.rawCamera;orthoZO(this.#zl,this.rawCamera.left,this.rawCamera.right,this.rawCamera.bottom,this.rawCamera.top,i,g)}else if(this.rawCamera instanceof Camera2D)bt(this.#zl,-.5,.5,-.5,.5,-1e5,1e5),scale$4(this.#zl,this.#zl,[g.renderScale,g.renderScale,1]),translate(this.#zl,this.#zl,[-.5,.5,0]),scale$4(this.#zl,this.#zl,[1/i.width*window.devicePixelRatio,-1/i.height*window.devicePixelRatio,1]);else{const{fieldOfView:i,nearClipping:g,farClipping:x}=this.rawCamera;vt(this.#zl,Math.PI/180*i,this.aspect,g,x)}return this.#zl}get projectionMatrix(){const{redGPUContext:i}=this,{antialiasingManager:g}=i;this.#Hl=clone$4(this.noneJitterProjectionMatrix);if("View3D"===this.constructor.name&&!(this.camera instanceof IsometricController)&&g.useTAA&&this.rawCamera instanceof PerspectiveCamera&&(0!==this.#$l||0!==this.#Kl)){const i=this.#$l/this.pixelRectObject.width*2,g=this.#Kl/this.pixelRectObject.height*2;this.#Hl[8]+=i,this.#Hl[9]+=g}return this.#Hl}get inverseProjectionMatrix(){return invert$1(create$4(),this.#Hl)}get jitterOffset(){return[this.#$l,this.#Kl]}setJitterOffset(i,g){this.#$l=i,this.#Kl=g}clearJitterOffset(){this.#$l=0,this.#Kl=0}setPosition(i=this.#Ot,g=this.#Nt){const{sizeManager:x}=this.#l;RedGPUContextSizeManager.validatePositionValue(i),RedGPUContextSizeManager.validatePositionValue(g),this.#Ot=i,this.#Nt=g;const _=x.pixelRectObject,v=RedGPUContextSizeManager.getPixelDimension(_,"width",i),b=RedGPUContextSizeManager.getPixelDimension(_,"height",g);this.#Et[0]=Math.floor(v*(this.#Ot.toString().includes("%")?1:x.renderScale*window.devicePixelRatio)),this.#Et[1]=Math.floor(b*(this.#Nt.toString().includes("%")?1:x.renderScale*window.devicePixelRatio))}setSize(i=this.#Bt,g=this.#It){const{sizeManager:x}=this.#l;RedGPUContextSizeManager.validateSizeValue(i),RedGPUContextSizeManager.validateSizeValue(g),this.#Bt=i,this.#It=g;const _=x.pixelRectObject,v=RedGPUContextSizeManager.getPixelDimension(_,"width",i),b=RedGPUContextSizeManager.getPixelDimension(_,"height",g);this.#Et[2]=Math.max(1,Math.floor(v*(this.#Bt.toString().includes("%")?1:x.renderScale*window.devicePixelRatio))),this.#Et[3]=Math.max(1,Math.floor(b*(this.#It.toString().includes("%")?1:x.renderScale*window.devicePixelRatio))),this.onResize&&this.onResize({target:this,screenRectObject:this.screenRectObject,pixelRectObject:this.pixelRectObject})}}Object.freeze(ViewTransform);class AView extends ViewTransform{#h;#Xl;#f;#jl=new PickingManager;#Yl=!0;#ql=!1;#Wl=50;#Zl;#Jl;#Ql;#ec;constructor(i,g,x,_){super(i),this.scene=g,this.camera=x,_&&(this.name=_)}get name(){return this.#f||(this.#f=InstanceIdGenerator.getNextId(this.constructor)),this.#h||`${this.constructor.name} Instance ${this.#f}`}set name(i){this.#h=i}get scene(){return this.#Xl}set scene(i){i instanceof Scene||consoleAndThrowError("allow only Scene instance"),this.#Xl=i}get pickingManager(){return this.#jl}get useFrustumCulling(){return this.#Yl}set useFrustumCulling(i){this.#Yl=i}get useDistanceCulling(){return this.#ql}set useDistanceCulling(i){this.#ql=i}get distanceCulling(){return this.#Wl}set distanceCulling(i){this.#Wl=i}get grid(){return this.#Zl}set grid(i){if("boolean"==typeof i)i=!0===i?new DrawDebuggerGrid(this.redGPUContext):null;else if(!(i instanceof DrawDebuggerGrid)&&null!==i)throw new TypeError("grid must be of type 'DrawDebuggerGrid','boolean',or 'null'.");this.#Zl=i}get axis(){return this.#Jl}set axis(i){if("boolean"==typeof i)i=!0===i?new DrawDebuggerAxis(this.redGPUContext):null;else if(!(i instanceof DrawDebuggerAxis)&&null!==i)throw new TypeError("axis must be of type 'DrawDebuggerAxis','boolean',or 'null'.");this.#Jl=i}get fxaa(){return this.#ec||(this.#ec=new FXAA(this.redGPUContext)),this.#ec}get taa(){return this.#Ql||(this.#Ql=new TAA(this.redGPUContext)),this.#Ql}screenToWorld(i,g){return screenToWorld(i,g,this)}checkMouseInViewBounds(){const{pixelRectObject:i,pickingManager:g}=this,{mouseX:x,mouseY:_}=g;return 0i+calculateTextureByteSize(g),0)}#dc(i,x){const{antialiasingManager:_,resourceManager:v}=this.#l,{useMSAA:b}=_,y=this.#lc.get(i),S=y?.texture,{pixelRectObject:w,name:L}=this.#Ft,{width:k,height:H}=w,z=S?.width!==k||S?.height!==H,q=this.#cc[i]!==b,W=!S||z||q;if(this.#cc[i]=b,W){g(`새 텍스처 생성 중:${i}`),S&&(S?.destroy(),y.texture=null,y.textureView=null,y.resolveTexture?.destroy(),y.resolveTexture=null,y.resolveTextureView=null,this.#lc.delete(i));const _={texture:null,textureView:null,resolveTexture:null,resolveTextureView:null},w=v.createManagedTexture({size:[Math.max(k,1),Math.max(H,1),1],sampleCount:b?4:1,label:`${L}_${i}_texture_${k}x${H}`,format:x||navigator.gpu.getPreferredCanvasFormat(),usage:GPUTextureUsage.RENDER_ATTACHMENT|GPUTextureUsage.TEXTURE_BINDING|GPUTextureUsage.COPY_SRC});if(_.texture=w,_.textureView=v.getGPUResourceBitmapTextureView(w),b){const g=v.createManagedTexture({size:{width:Math.max(k,1),height:Math.max(H,1),depthOrArrayLayers:1},sampleCount:1,label:`${L}_${i}_resolveTexture_${k}x${H}`,format:x||navigator.gpu.getPreferredCanvasFormat(),usage:GPUTextureUsage.RENDER_ATTACHMENT|GPUTextureUsage.TEXTURE_BINDING|GPUTextureUsage.COPY_SRC});_.resolveTexture=g,_.resolveTextureView=v.getGPUResourceBitmapTextureView(g)}this.#lc.set(i,_),this.#mc()}}#fc(i){const{resourceManager:g}=this.#l,x=this.#nc,{pixelRectObject:_,name:v}=this.#Ft,{width:b,height:y}=_;(!x||(x?.width!==b||x?.height!==y))&&(x&&(this.#nc=null,this.#rc=null),this.#ic={size:{width:Math.max(1,b),height:Math.max(1,y),depthOrArrayLayers:1},format:i,usage:GPUTextureUsage.TEXTURE_BINDING|GPUTextureUsage.COPY_DST|GPUTextureUsage.RENDER_ATTACHMENT|GPUTextureUsage.COPY_SRC,mipLevelCount:getMipLevelCount(b,y),label:`${v}_renderPath1ResultTexture_${b}x${y}`},this.#nc=g.createManagedTexture(this.#ic),this.#rc=g.getGPUResourceBitmapTextureView(this.#nc),this.#mc(),requestAnimationFrame(()=>{x?.destroy()}))}#Ll(){const{antialiasingManager:i,resourceManager:g}=this.#l,{useMSAA:x}=i,_=this.#ac,{pixelRectObject:v,name:b}=this.#Ft,{width:y,height:S}=v,w=_?.width!==y||_?.height!==S,L=this.#cc.depth!==x,k=!_||w||L;if(this.#cc.depth=x,k){_&&(_?.destroy(),this.#sc?.destroy(),this.#ac=null,this.#sc=null,this.#oc=null,this.#uc=null);const i=g.createManagedTexture({size:[Math.max(y,1),Math.max(S,1),1],sampleCount:x?4:1,label:`${b}_depth0_${y}x${S}`,format:"depth32float",usage:GPUTextureUsage.RENDER_ATTACHMENT|GPUTextureUsage.TEXTURE_BINDING});this.#ac=i,this.#oc=g.getGPUResourceBitmapTextureView(i);{const i=g.createManagedTexture({size:[Math.max(y,1),Math.max(S,1),1],sampleCount:x?4:1,label:`${b}_depth1_${y}x${S}`,format:"depth32float",usage:GPUTextureUsage.RENDER_ATTACHMENT|GPUTextureUsage.TEXTURE_BINDING});this.#sc=i,this.#uc=g.getGPUResourceBitmapTextureView(i)}this.#mc()}}}Object.freeze(ViewRenderTextureManager);const qi={LINEAR:"linear",KHRONOS_PBR_NEUTRAL:"khronosPBRNeutral",ACES_FILMIC_HILL:"ACESFilmicHill",ACES_FILMIC_NARKOWICZ:"ACESFilmicNarkowicz"};Object.freeze(qi);var Wi="struct Uniforms { exposure:f32, contrast:f32, brightness:f32, _pad:f32,\n};\nfn linearToSRGB(linearColor:vec3) -> vec3 { let a=0.055; let cutoff=0.0031308; let gamma=2.4; var srgb:vec3; for (var i=0;i < 3;i++) { let c=linearColor[i]; if (c <=cutoff) { srgb[i]=12.92 * c; } else { srgb[i]=(1.0 + a) * pow(c,1.0/gamma) - a; } } return srgb;\n}\nfn linearToneMapping(color:vec3,exposure:f32) -> vec3 { let exposed=color * exposure; return exposed;\n}\nfn khronosPBRNeutralToneMapping(color:vec3,exposure:f32) -> vec3 { let startCompression:f32=0.8 - 0.04; let desaturation:f32=0.15; var col=color * exposure; let x=min(col.r,min(col.g,col.b)); var offset:f32; if (x < 0.08) { offset=x - 6.25 * x * x; } else { offset=0.04; } col=col - vec3(offset); let peak=max(col.r,max(col.g,col.b)); if (peak < startCompression) { return clamp(col,vec3(0.0),vec3(1.0)); } let d=1.0 - startCompression; let newPeak=1.0 - d * d/(peak + d - startCompression); col=col * (newPeak/peak); let g=1.0 - 1.0/(desaturation * (peak - newPeak) + 1.0); return clamp(mix(col,vec3(newPeak),g),vec3(0.0),vec3(1.0));\n}\nfn acesFilmicNarkowiczToneMapping(color:vec3,exposure:f32) -> vec3 { let x=color * exposure; let a=2.51; let b=0.03; let c=2.43; let d=0.59; let e=0.14; return clamp((x * (a * x + b))/(x * (c * x + d) + e),vec3(0.0),vec3(1.0));\n}\nfn acesFilmicHillToneMapping(color:vec3,exposure:f32) -> vec3 { let v=color * exposure; let a1=v.r * 0.59719 + v.g * 0.35458 + v.b * 0.04823; let a2=v.r * 0.07600 + v.g * 0.90834 + v.b * 0.01566; let a3=v.r * 0.02840 + v.g * 0.13383 + v.b * 0.83777; let a=vec3(a1,a2,a3); let b=(a * (a + 0.0245786) - 0.000090537)/(a * (0.983729 * a + 0.4329510) + 0.238081); let r=b.r * 1.60475 - b.g * 0.53108 - b.b * 0.07367; let g=b.r * -0.10208 + b.g * 1.10813 - b.b * 0.00605; let bl=b.r * -0.00327 - b.g * 0.07276 + b.b * 1.07602; return clamp(vec3(r,g,bl),vec3(0.0),vec3(1.0));\n}\nfn getFinalSRGB(toneMappedColor:vec3,contrast:f32,brightness:f32) -> vec3 { let contrastRGB=applyContrast(toneMappedColor,uniforms.contrast); let finalLinearRGB=applyBrightness(contrastRGB,uniforms.brightness); let finalSRGB=clamp(linearToSRGB(finalLinearRGB),vec3(0.0),vec3(1.0)); return finalSRGB;\n}\nfn applyContrast(color:vec3,contrast:f32) -> vec3 { return 0.5 + contrast * (color - 0.5);\n}\nfn applyBrightness(color:vec3,brightness:f32) -> vec3 { return color + brightness;\n}";class AToneMappingEffect extends ASinglePassPostEffect{#pc=1;#Sr=1;#gc=0;constructor(i){super(i)}get exposure(){return this.#pc}set exposure(i){this.#pc=Math.max(.1,Math.min(5,i)),this.updateUniform("exposure",this.#pc)}get contrast(){return this.#Sr}set contrast(i){this.#Sr=Math.max(.5,Math.min(2,i)),this.updateUniform("contrast",this.#Sr)}get brightness(){return this.#gc}set brightness(i){this.#gc=Math.max(-1,Math.min(1,i)),this.updateUniform("brightness",this.#gc)}updateUniforms(){this.updateUniform("exposure",this.#pc),this.updateUniform("contrast",this.#Sr),this.updateUniform("brightness",this.#gc)}}Object.freeze(AToneMappingEffect);class ToneLinear extends AToneMappingEffect{constructor(i){super(i),this.init(i,"POST_EFFECT_TONE_MAPPING_LINEAR",createBasicPostEffectCode(this,"{ let index=vec2(global_id.xy); let inputColor=textureLoad(sourceTexture,index); let toneMappedColor=linearToneMapping(inputColor.rgb,uniforms.exposure); let finalSRGB=getFinalSRGB( toneMappedColor,uniforms.contrast,uniforms.brightness ); textureStore(outputTexture,index,vec4(finalSRGB,inputColor.a));\n}",Wi)),this.updateUniforms()}}Object.freeze(ToneLinear);class ToneKhronosPBRNeutral extends AToneMappingEffect{constructor(i){super(i),this.init(i,"POST_EFFECT_TONE_MAPPING_KHRONOS_PBR_NEUTRAL",createBasicPostEffectCode(this,"{ let index=vec2(global_id.xy); let inputColor=textureLoad(sourceTexture,index); let toneMappedColor=khronosPBRNeutralToneMapping(inputColor.rgb,uniforms.exposure); let finalSRGB=getFinalSRGB( toneMappedColor,uniforms.contrast,uniforms.brightness ); textureStore(outputTexture,index,vec4(finalSRGB,inputColor.a));\n}",Wi)),this.updateUniforms()}}Object.freeze(ToneKhronosPBRNeutral);class ToneACESFilmicNarkowicz extends AToneMappingEffect{constructor(i){super(i),this.init(i,"POST_EFFECT_TONE_MAPPING_ACES_FILMIC_NARKOWICZ",createBasicPostEffectCode(this,"{ let index=vec2(global_id.xy); let inputColor=textureLoad(sourceTexture,index); let toneMappedColor=acesFilmicNarkowiczToneMapping(inputColor.rgb,uniforms.exposure); let finalSRGB=getFinalSRGB( toneMappedColor,uniforms.contrast,uniforms.brightness ); textureStore(outputTexture,index,vec4(finalSRGB,inputColor.a));\n}",Wi)),this.updateUniforms()}}Object.freeze(ToneACESFilmicNarkowicz);class ToneACESFilmicHill extends AToneMappingEffect{constructor(i){super(i),this.init(i,"POST_EFFECT_TONE_MAPPING_ACES_FILMIC_HILL",createBasicPostEffectCode(this,"{ let index=vec2(global_id.xy); let inputColor=textureLoad(sourceTexture,index); let toneMappedColor=acesFilmicHillToneMapping(inputColor.rgb,uniforms.exposure); let finalSRGB=getFinalSRGB( toneMappedColor,uniforms.contrast,uniforms.brightness ); textureStore(outputTexture,index,vec4(finalSRGB,inputColor.a));\n}",Wi)),this.updateUniforms()}}Object.freeze(ToneACESFilmicHill);class ToneMappingManager{#l;#Ft;#xc;#_c=qi.KHRONOS_PBR_NEUTRAL;#pc=1;#Sr=1;#gc=0;constructor(i){this.#l=i.redGPUContext,this.#Ft=i}get toneMapping(){return this.#vc(),this.#xc}get mode(){return this.#_c}set mode(i){this.#_c!==i&&(this.#_c=i,this.#xc&&(this.#xc.clear(),this.#xc=void 0))}get exposure(){return this.#pc}set exposure(i){validatePositiveNumberRange(i,0),this.#pc=i,this.#xc&&(this.#xc.exposure=i)}get contrast(){return this.#Sr}set contrast(i){validatePositiveNumberRange(i,0,2),this.#Sr=i,this.#xc&&(this.#xc.contrast=i)}get brightness(){return this.#gc}set brightness(i){validateNumberRange(i,-1,1),this.#gc=i,this.#xc&&(this.#xc.brightness=i)}render(i,g,x){const _=this.toneMapping;return _?_.render(this.#Ft,i,g,x):x}#vc(){if(!this.#xc){switch(this.#_c){case qi.LINEAR:this.#xc=new ToneLinear(this.#l);break;case qi.KHRONOS_PBR_NEUTRAL:this.#xc=new ToneKhronosPBRNeutral(this.#l);break;case qi.ACES_FILMIC_NARKOWICZ:this.#xc=new ToneACESFilmicNarkowicz(this.#l);break;case qi.ACES_FILMIC_HILL:this.#xc=new ToneACESFilmicHill(this.#l);break;default:this.#xc=new ToneKhronosPBRNeutral(this.#l)}this.#xc&&(this.#xc.exposure=this.#pc,this.#xc.contrast=this.#Sr,this.#xc.brightness=this.#gc)}}}const Zi=parseWGSL(Ke.SYSTEM_UNIFORM).uniforms.systemUniforms;let Ji=create$4(),Qi=create$4();create$4();class View3D extends AView{#bc=Zi;#yc;#Sc;#Tc;#Mc;#wc;#Cc;#Rc;#Pc;#Bc={};#Ic;#rt;#Ec;#qt;#Dc;#Uc;#Lc;#Ac=void 0;#Gc=void 0;#kc;#Oc;#Xr;#jr;#Yr;#Nc=create$4();constructor(i,g,x,_){super(i,g,x,_),this.#ne(),this.#Pc=new ViewRenderTextureManager(this),this.#wc=new RenderViewStateData(this),this.#Cc=new PostEffectManager(this),this.#Rc=new ToneMappingManager(this),this.#Xr=new ArrayBuffer(this.systemUniform_Vertex_StructInfo.endOffset),this.#jr=new Float32Array(this.#Xr),this.#Yr=new Uint32Array(this.#Xr)}get viewRenderTextureManager(){return this.#Pc}get systemUniform_Vertex_StructInfo(){return this.#bc}get systemUniform_Vertex_UniformBindGroup(){return this.#yc}get systemUniform_Vertex_UniformBuffer(){return this.#Sc}get passLightClustersBound(){return this.#Lc}get ibl(){return this.#Mc}set ibl(i){this.#Mc=i}get postEffectManager(){return this.#Cc}get toneMappingManager(){return this.#Rc}get renderViewStateData(){return this.#wc}get skybox(){return this.#Tc}set skybox(i){const{resourceManager:g}=this.redGPUContext,x=this.#Tc?.skyboxTexture,_=i?.skyboxTexture;x&&x!==_&&this.#Vc(g,x.cacheKey,!1),this.#Tc=i}get basicRenderBundleEncoderDescriptor(){const{antialiasingManager:i}=this.redGPUContext,{useMSAA:g}=i;return{colorFormats:["rgba16float",navigator.gpu.getPreferredCanvasFormat(),"rgba16float"],depthStencilFormat:"depth32float",sampleCount:g?4:1}}get noneJitterProjectionCameraMatrix(){return this.#Nc}update(i=!1,g=!1,x){const{scene:_,redGPUContext:v}=this,{shadowManager:b}=_;b.update(v);const{directionalShadowManager:y}=b,S=this.ibl,w=S?.prefilterTexture?.gpuTexture,L=S?.irradianceTexture?.gpuTexture;let k=i?y.shadowDepthTextureViewEmpty:y.shadowDepthTextureView;const H=this.redGPUContext.viewList.indexOf(this),z=`${H}_${i?"shadowRender":"basic"}_2path${!!x}`;if(H>-1){let i=!0,g=this.#Bc[z];g&&(i=g.ibl!==S||g.ibl_prefilterTexture!==w||g.ibl_irradianceTexture!==L||g.renderPath1ResultTextureView!==x||g.shadowDepthTextureView!==k||!this.#Uc),i?this.#Fc(z,k,this.ibl,x):this.#yc=this.#Bc[z].vertexUniformBindGroup,this.#Bc[z]={ibl:S,ibl_prefilterTexture:w,ibl_irradianceTexture:L,renderPath1ResultTextureView:x,shadowDepthTextureView:k,vertexUniformBindGroup:this.#yc}}this.#Hc(g),this.#zc()}#ii(i){i.forEach(({key:i,value:g,dataView:x,targetMembers:_})=>{const v=_[i];x.set("number"==typeof g?[g]:g,v.uniformOffset/v.View.BYTES_PER_ELEMENT)})}#zc(){const{inverseProjectionMatrix:i,noneJitterProjectionMatrix:g,projectionMatrix:x,rawCamera:_}=this,{redGPUContext:v,systemUniform_Vertex_UniformBuffer:b}=this,{gpuDevice:y}=v,{lightManager:S,shadowManager:w}=this.scene,{modelMatrix:L,position:k}=_,H=this.systemUniform_Vertex_StructInfo,{gpuBuffer:z}=b,q=_ instanceof Camera2D,{members:W}=H;{const{members:b}=H,y=b.camera.members;this.#Nc=multiply$4(Qi,g,L),this.#ii([{key:"projectionMatrix",value:x,dataView:this.#jr,targetMembers:b},{key:"projectionCameraMatrix",value:multiply$4(Ji,x,L),dataView:this.#jr,targetMembers:b},{key:"noneJitterProjectionMatrix",value:g,dataView:this.#jr,targetMembers:b},{key:"noneJitterProjectionCameraMatrix",value:this.#Nc,dataView:this.#jr,targetMembers:b},{key:"inverseProjectionMatrix",value:i,dataView:this.#jr,targetMembers:b},{key:"prevNoneJitterProjectionCameraMatrix",value:v.antialiasingManager.useTAA?this.taa.prevNoneJitterProjectionCameraMatrix:this.#Nc,dataView:this.#jr,targetMembers:b},{key:"resolution",value:[this.pixelRectObject.width,this.pixelRectObject.height],dataView:this.#jr,targetMembers:b},{key:"cameraMatrix",value:L,dataView:this.#jr,targetMembers:y},{key:"cameraPosition",value:k,dataView:this.#jr,targetMembers:y},{key:"nearClipping",value:q?0:_.nearClipping,dataView:this.#jr,targetMembers:y},{key:"farClipping",value:q?0:_.farClipping,dataView:this.#jr,targetMembers:y},{key:"usePrefilterTexture",value:this.ibl?.prefilterTexture?.gpuTexture?1:0,dataView:this.#Yr,targetMembers:b},{key:"time",value:this.renderViewStateData.timestamp||0,dataView:this.#jr,targetMembers:b},{key:"isView3D",value:this.constructor===View3D?1:0,dataView:this.#Yr,targetMembers:b},{key:"shadowDepthTextureSize",value:w.directionalShadowManager.shadowDepthTextureSize,dataView:this.#Yr,targetMembers:b},{key:"bias",value:w.directionalShadowManager.bias,dataView:this.#jr,targetMembers:b},{key:"directionalLightCount",value:S.directionalLightCount,dataView:this.#Yr,targetMembers:b},{key:"directionalLightProjectionViewMatrix",value:S.getDirectionalLightProjectionViewMatrix(this),dataView:this.#jr,targetMembers:b},{key:"directionalLightProjectionMatrix",value:S.getDirectionalLightProjectionMatrix(this),dataView:this.#jr,targetMembers:b},{key:"directionalLightViewMatrix",value:S.getDirectionalLightViewMatrix(this),dataView:this.#jr,targetMembers:b}])}S.directionalLights.forEach((i,g)=>{const{directionalLights:x}=W;i.enableDebugger&&(i.drawDebugger||(i.drawDebugger=new DrawDebuggerDirectionalLight(v,i)),i.drawDebugger.render(this.renderViewStateData));const _=x.memberList[g];this.#ii([{key:"direction",value:i.direction,dataView:this.#jr,targetMembers:_},{key:"color",value:i.color.rgbNormalLinear,dataView:this.#jr,targetMembers:_},{key:"intensity",value:i.intensity,dataView:this.#jr,targetMembers:_}])});{const i=S.ambientLight,{ambientLight:g}=W,x=g.members;i&&this.#ii([{key:"color",value:i.color.rgbNormalLinear,dataView:this.#jr,targetMembers:x},{key:"intensity",value:i.intensity,dataView:this.#jr,targetMembers:x}])}y.queue.writeBuffer(z,0,this.#Xr)}#Fc(i,g,x,_){this.#Hc(!0);const v=x?.prefilterTexture,b=x?.irradianceTexture,{redGPUContext:y}=this,{gpuDevice:S,resourceManager:w}=y,L={layout:w.getGPUBindGroupLayout(ResourceManager.PRESET_GPUBindGroupLayout_System),label:`SYSTEM_UNIFORM_bindGroup_${i}`,entries:[{binding:0,resource:{buffer:this.#Sc.gpuBuffer,offset:0,size:this.#Sc.size}},{binding:1,resource:this.#Ic},{binding:2,resource:g},{binding:3,resource:this.#rt},{binding:5,resource:{buffer:this.#qt,offset:0,size:this.#qt.size}},{binding:6,resource:{buffer:this.#Uc.clusterLightsBuffer,offset:0,size:this.#Uc.clusterLightsBuffer.size}},{binding:7,resource:this.#rt},{binding:8,resource:_||w.emptyBitmapTextureView},{binding:9,resource:this.#Ec},{binding:10,resource:w.getGPUResourceCubeTextureView(v,v?.viewDescriptor||CubeTexture.defaultViewDescriptor)},{binding:11,resource:w.getGPUResourceCubeTextureView(b,b?.viewDescriptor||CubeTexture.defaultViewDescriptor)},{binding:12,resource:w.brdfGenerator.brdfLUTTexture?.createView()||w.emptyBitmapTextureView}]};this.#yc=S.createBindGroup(L),this.#$c(w,v,b)}#$c(i,g,x){[[this.#kc,g],[this.#Oc,x]].forEach(([g,x])=>{g&&g!==x&&this.#Vc(i,g.cacheKey,!1),x&&g!==x&&this.#Vc(i,x.cacheKey,!0)}),this.#kc=g,this.#Oc=x}#Vc(i,g,x){const _=i.managedCubeTextureState,v=_?.table.get(g);v&&(x?v.useNum++:v.useNum--)}#ne(){const i=new ArrayBuffer(Zi.arrayBufferByteLength);this.#Sc=new UniformBuffer(this.redGPUContext,i,"SYSTEM_UNIFORM_BUFFER_VERTEX","SYSTEM_UNIFORM_BUFFER_VERTEX"),this.#Dc=new Float32Array(16*q.MAX_CLUSTER_LIGHTS+4),this.#qt=this.redGPUContext.resourceManager.createGPUBuffer("VIEW_CLUSTER_LIGHTS_BUFFER",{size:this.#Dc.byteLength,usage:GPUBufferUsage.STORAGE|GPUBufferUsage.COPY_DST|GPUBufferUsage.COPY_SRC}),this.redGPUContext.gpuDevice.queue.writeBuffer(this.#qt,0,this.#Dc),this.#Ic=new Sampler(this.redGPUContext,{addressModeU:_.CLAMP_TO_EDGE,addressModeV:_.CLAMP_TO_EDGE,addressModeW:_.CLAMP_TO_EDGE,compare:Tn.LESS_EQUAL}).gpuSampler,this.#rt=new Sampler(this.redGPUContext).gpuSampler,this.#Ec=new Sampler(this.redGPUContext,{addressModeU:_.REPEAT,addressModeV:_.REPEAT}).gpuSampler}#Hc(i=!1){if(!i)return;const{redGPUContext:g,scene:x,renderViewStateData:_}=this;if(this.#Lc||(this.#Lc=new PassClusterLightBound(g,this)),this.#Uc&&(this.#Lc.render(),this.#Ac=this.pixelRectArray[2],this.#Gc=this.pixelRectArray[3]),this.#Uc||(this.#Uc=new PassClustersLight(g,this)),x){const{pointLights:i,spotLights:v}=x.lightManager,b=i.length,y=v.length;if(b){let x=b;for(;x--;){const v=i[x],b=4+16*x;this.#Dc.set([...v.position,v.radius,...v.color.rgbNormalLinear,v.intensity,0],b),v.enableDebugger&&(v.drawDebugger||(v.drawDebugger=new DrawDebuggerPointLight(g,v)),v.drawDebugger.render(_))}}if(y){const i=16,x=b*i;let S=y;for(;S--;){const b=v[S],y=4+i*S+x;this.#Dc.set([...b.position,b.radius,...b.color.rgbNormalLinear,b.intensity,1,...b.direction,b.outerCutoff,b.innerCutoff],y),b.enableDebugger&&(b.drawDebugger||(b.drawDebugger=new DrawDebuggerSpotLight(g,b)),b.drawDebugger.render(_))}}this.#Dc.set([b,y,0,0],0),this.redGPUContext.gpuDevice.queue.writeBuffer(this.#qt,0,this.#Dc),this.#Uc.render()}}}Object.freeze(View3D);class RedGPUContextViewContainer{#Kc=[];constructor(){}get viewList(){return this.#Kc}get numViews(){return this.#Kc.length}contains(i){return this.#Kc.includes(i)}addView(i){this.#Xc(i),this.#Kc.push(i)}addViewAt(i,g){this.#Xc(i),validateUintRange(g);const x=this.#Kc.length;x=x,v=this.#Kc.indexOf(i);-1===v&&consoleAndThrowError("입력하신 View 는 RedGPUContext instance 에 등록되지 않은 View 입니다."),_&&consoleAndThrowError(`index must be smaller than the viewList length./index:${g}/this.#viewList.length:${x}`),this.#Kc.splice(v,1),this.#Kc.splice(g,0,i)}swapViews(i,g){this.#Xc(i),this.#Xc(g);const x=this.#Kc.indexOf(i),_=this.#Kc.indexOf(g);-1!==x&&-1!==_||consoleAndThrowError((-1===x?"view1":"view2")+" is not child of this RedGPUContext instance."),this.swapViewsAt(x,_)}swapViewsAt(i,g){i===g&&consoleAndThrowError("The indices to swap cannot be the same."),validateUintRange(i),validateUintRange(g);const x=this.#Kc.length;(i>=x||g>=x)&&consoleAndThrowError(`index1,index2 must be smaller than the viewList length./index1:${i}/index2:${g}/this.#viewList.length:${x}`);const _=this.#Kc[i];this.#Kc[i]=this.#Kc[g],this.#Kc[g]=_}removeView(i){this.#Xc(i);const g=this.#Kc.indexOf(i);g>-1?this.#Kc.splice(g,1):consoleAndThrowError("View3D is not found in the view list.")}removeViewAt(i){validateUintRange(i);const g=this.#Kc.length;i{i.setPosition(),i.setSize()})}destroy(){this.#c.destroy()}setSize(i=this.width,g=this.height){this.sizeManager.setSize(i,g)}#nh(){this.#rh(),this.sizeManager.setSize("100%","100%"),window?.addEventListener("resize",()=>{this.#th=this.#Dt.getBoundingClientRect(),this.sizeManager.setSize()}),this.#th=this.#Dt.getBoundingClientRect();(this.detector.isMobile?["click","touchmove","touchstart","touchend"]:["click","mousemove","mousedown","mouseup"]).forEach(g=>{const x=this.detector.isMobile?{click:i.CLICK,touchmove:i.MOVE,touchstart:i.DOWN,touchend:i.UP}:{click:i.CLICK,mousemove:i.MOVE,mousedown:i.DOWN,mouseup:i.UP};this.#Dt.addEventListener(g,g=>{const _=x[g.type];this.viewList.forEach(x=>{this.detector.isMobile&&g instanceof TouchEvent&&g.touches.length>0?(x.pickingManager.mouseX=g.touches[0].clientX*devicePixelRatio-x.pixelRectObject.x,x.pickingManager.mouseY=g.touches[0].clientY*devicePixelRatio-x.pixelRectObject.y):g instanceof MouseEvent&&(x.pickingManager.mouseX=g.offsetX*devicePixelRatio-x.pixelRectObject.x,x.pickingManager.mouseY=g.offsetY*devicePixelRatio-x.pixelRectObject.y),_===i.CLICK?x.pickingManager.lastMouseClickEvent={...g,type:_}:x.pickingManager.lastMouseEvent={...g,type:_}})})});{const HD_keyDown=i=>{this.#eh[i.key]=!0},HD_keyUp=i=>{this.#eh[i.key]=!1};window?.addEventListener("keyup",HD_keyUp),window?.addEventListener("keydown",HD_keyDown)}new ResizeObserver(i=>{}).observe(this.#Dt)}#rh(){const i=navigator.gpu.getPreferredCanvasFormat();this.#jc={device:this.#c,format:i,alphaMode:this.#qc},this.#Wc.configure(this.#jc)}}Object.freeze(RedGPUContext);const init=async(i,x,_,v,b="premultiplied",y={powerPreference:"high-performance",forceFallbackAdapter:!1})=>{if(isSearchEngineBot())return void g("🤖 Search engine bot detected - skipping WebGPU initialization");const{gpu:S}=navigator;if(!S){const i="WebGPU is not supported in this browser. Please use a modern browser with WebGPU enabled.";return void _?.(i)}const errorHandler=(i,g)=>{const x=generateErrorMessage(i,g);console.error("\n============\n",x,"\n============\n"),_?.(x)},validateAndRequestDevice=async g=>{const x=[];g?.features.has("texture-compression-astc")&&x.push("texture-compression-astc");const _={};["maxBufferSize","maxStorageBufferBindingSize","maxSampledTexturesPerShaderStage","maxSamplersPerShaderStage","maxStorageBuffersPerShaderStage","maxStorageTexturesPerShaderStage","maxUniformBuffersPerShaderStage","maxUniformBufferBindingSize","maxBindGroups","maxVertexAttributes","maxVertexBuffers","maxInterStageShaderComponents","maxComputeWorkgroupStorageSize","maxComputeInvocationsPerWorkgroup","maxComputeWorkgroupSizeX","maxComputeWorkgroupSizeY","maxComputeWorkgroupSizeZ","maxComputeWorkgroupsPerDimension"].forEach(i=>{g.limits[i]&&(_[i]=g.limits[i])});const v={requiredFeatures:x,requiredLimits:_};try{const x=await g.requestDevice(v);validateAndInitializeContext(i,g,x)}catch(i){errorHandler(null,`Failed to request device. Adapter was ${g},error message is ${i.message}`)}},validateAndInitializeContext=(i,_,y)=>{const S=i.getContext("webgpu");if(S)try{{const i=y.createShaderModule.bind(y);y.createShaderModule=function(g){g.code=ensureVertexIndexBuiltin(g.code);return i(g)}}const w=new RedGPUContext(i,_,y,S,b);x(w),y.addEventListener("uncapturederror",i=>{console.warn("TODO A WebGPU error was not captured:",i),console.warn(i.error?.message),window.cancelAnimationFrame(w.currentRequestAnimationFrame)}),y.lost.then(i=>{console.warn(i),console.warn(`Device lost occurred:${i.message}`),"destroyed"===i.reason&&v?.(i)});const clearDevice=()=>{if(w.gpuContext)try{w.gpuContext.unconfigure(),g("🧹 Canvas Context unconfigure 완료")}catch(i){g("⚠️ Canvas Context unconfigure 실패:",i)}window?.cancelAnimationFrame(w.currentRequestAnimationFrame),w.gpuDevice.destroy()};window?.addEventListener("beforeunload",()=>{w&&w.gpuDevice&&(g("🧹 페이지 종료 시 GPU 디바이스 정리"),clearDevice())}),window?.addEventListener("pageshow",i=>{i.persisted&&(g("🔄 bfcache에서 복원됨 (뒤로가기 또는 앞으로가기) - 페이지 재로드"),window.location.reload())}),window?.addEventListener("pagehide",i=>{i.persisted&&(g("💾 bfcache에 저장됨"),w&&w.gpuDevice&&clearDevice())})}catch(i){errorHandler(i,"")}else errorHandler(new Error(`Failed to get context from canvas:${i.id||i}`),"Failed to get webgpu initialize from canvas")},initializeWebGPU=async()=>{x instanceof Function?i instanceof HTMLCanvasElement?await(async i=>{i||errorHandler(null,"Cannot find navigator.gpu");try{const g=await i.requestAdapter(y);await validateAndRequestDevice(g)}catch(g){errorHandler(g,`Failed to request adapter or validate device with target GPU:${i},error message is ${g.message}`)}})(S):errorHandler(null,`Expected HTMLCanvasElement,but received:${i}`):errorHandler(null,`Expected onWebGPUInitialized,but received:${x}`)};try{await initializeWebGPU()}catch(i){errorHandler(i,`Unexpected error occurred during WebGPU initialization:${i.message}`)}},generateErrorMessage=(i,g)=>{let x=g;return i instanceof Error?(x=i.message??g,"string"==typeof i.stack&&(x+=`\nStack Trace:${i.stack}`)):console.warn("generateErrorMessage function expected an Error instance,but got:",i),x},isSearchEngineBot=()=>{if("undefined"==typeof navigator||"undefined"==typeof window)return!0;const i=navigator.userAgent.toLowerCase();return["googlebot","bingbot","slurp","duckduckbot","baiduspider","yandexbot","facebookexternalhit","twitterbot","rogerbot","linkedinbot","embedly","quora link preview","showyoubot","outbrain","pinterest/0.","developers.google.com/+/web/snippet","www.google.com/webmasters/tools/richsnippets","slackbot","vkshare","w3c_validator","redditbot","applebot","whatsapp","flipboard","tumblr","bitlybot","skypeuripreview","nuzzel","line","discordbot","telegrambot","crawler","spider","bot"].some(g=>i.includes(g))};class TextureLoaderData{src;texture;loadEnd;loadSuccess;srcInfo;idx;constructor(i,g,x){this.src=i,this.texture=null,this.loadEnd=!1,this.loadSuccess=!1,this.srcInfo=g,this.idx=x}}class TextureLoader{textures=[];#ih=0;#l;#ah;#ps;#sh;constructor(i,g=[],x,_){this.#l=i,this.#ah=g,this.#ps=x,this.#sh=_,this.#ah.length?this.#ah.forEach((i,g)=>this.#oh(i,g)):this.#uh()}getTextureByIndex(i){if(this.textures[i])return this.textures[i].texture}#oh(i,g){let x,_,v=BitmapTexture;_=i.hasOwnProperty("src")?i.src:i,_ instanceof Array&&(v=CubeTexture),x=new TextureLoaderData(_,i,g);const onLoadHandler=()=>{x.loadSuccess=!0,x.loadEnd=!0,this.#lh()},onErrorHandler=()=>{x.loadSuccess=!1,x.loadEnd=!0,this.#lh()};x.texture=v===BitmapTexture?new v(this.#l,{src:i.src,cacheKey:i.cacheKey},i.useMipmap,onLoadHandler,onErrorHandler,i.format,!1):new v(this.#l,{src:i.src,cacheKey:i.cacheKey},i.useMipmap,onLoadHandler,onErrorHandler,i.format),this.textures.push(x),this.#ch()}#ch(){const i=this.#ah.length,g=this.#ih;this.#sh&&this.#sh.call(this,{total:i,loaded:g,percent:Math.min(100,parseFloat((g/i*100).toFixed(2)))})}#lh(){this.#ih++,this.#ch(),this.#ih===this.#ah.length&&this.#uh()}#uh(){requestAnimationFrame(()=>{this.#ps&&this.#ps.call(this,this)})}}const checkProgress=(i,g,x)=>{const _=g.buffers.length;i.loadingProgressInfo.buffers={loaded:x,total:_,percent:Math.min(100,parseFloat((x/_*100).toFixed(2)))}},ea=new Map,ta=new Map,arrayBufferLoader=(i,g,x)=>{if(i=getAbsoluteURL(window.location.href,i),ea.has(i))return void g?.(ea.get(i));if(ta.has(i))return void ta.get(i).then(i=>g?.(i)).catch(i=>x?.(i));const _=fetch(i).then(i=>{if(!i.ok)throw new Error(`Network response was not ok:${i.statusText}`);return i.arrayBuffer()}).then(g=>(ea.set(i,g),g)).finally(()=>{ta.delete(i)});ta.set(i,_),_.then(i=>g?.(i)).catch(i=>x?.(i))},na={5120:Int8Array,5121:Uint8Array,5122:Int16Array,5123:Uint16Array,5125:Uint32Array,5126:Float32Array};Object.freeze(na);class AccessorInfo_GLTF{accessor;bufferView;bufferGlTfId;buffer;bufferURIDataView;componentType;componentType_BYTES_PER_ELEMENT;getMethod;accessorBufferOffset;bufferViewOffset;bufferViewByteStride;startIndex;constructor(i,g,x){switch(this.accessor=g.accessors[x],this.bufferView=g.bufferViews[this.accessor.bufferView],this.bufferGlTfId=this.bufferView.buffer,this.buffer=g.buffers[this.bufferGlTfId],this.bufferURIDataView=null,this.buffer.uri&&(this.bufferURIDataView=i.parsingResult.uris.buffers[this.bufferGlTfId]),this.componentType=na[this.accessor.componentType],this.componentType_BYTES_PER_ELEMENT=this.componentType.BYTES_PER_ELEMENT,this.componentType){case Float32Array:this.getMethod="getFloat32";break;case Uint32Array:this.getMethod="getUint32";break;case Uint16Array:this.getMethod="getUint16";break;case Int16Array:this.getMethod="getInt16";break;case Uint8Array:this.getMethod="getUint8";break;case Int8Array:this.getMethod="getInt8";break;default:consoleAndThrowError("파싱할수없는 타입",this.componentType)}this.accessorBufferOffset=this.accessor.byteOffset||0,this.bufferViewOffset=this.bufferView.byteOffset||0,this.bufferViewByteStride=this.bufferView.byteStride||0,this.startIndex=(this.bufferViewOffset+this.accessorBufferOffset)/this.componentType_BYTES_PER_ELEMENT}}class AnimationData_GLTF{gltfLoader;scenesData;accessorGlTfId;dataList;constructor(i,g,x){this.gltfLoader=i,this.scenesData=g,this.accessorGlTfId=x;const _=new AccessorInfo_GLTF(this.gltfLoader,this.scenesData,this.accessorGlTfId),{accessor:v,startIndex:b,componentType_BYTES_PER_ELEMENT:y,bufferURIDataView:S,getMethod:w}=_,{type:L,count:k}=v;let H=b,z=1;switch(L){case"SCALAR":z=1;break;case"VEC4":z=4;break;case"VEC3":z=3}const q=[];let W=0;for(;W animation_data_list:array;\n@group(0) @binding(1) var uniforms:Uniforms;\n@group(0) @binding(2) var vertices:array;\n@group(0) @binding(3) var origin_data:array;\n@group(0) @binding(4) var morph_interleave_data:array;\n@compute @workgroup_size(64)\nfn main(@builtin(global_invocation_id) global_id:vec3) { let vertex_index=global_id.x; let vertex_count=u32(uniforms.vertex_count); let stride=u32(uniforms.vertex_stride); let morph_length=u32(uniforms.morph_length); let base_vertex_index=vertex_index * stride; let base_vertex_index2=vertex_index * 3u; let prev_time_offset=u32(uniforms.prev_time_data_index) * morph_length; let next_time_offset=u32(uniforms.next_time_data_index) * morph_length; var prev_weight=origin_data[base_vertex_index]; var next_weight=origin_data[base_vertex_index]; var prev_weight1=origin_data[base_vertex_index + 1u]; var next_weight1=origin_data[base_vertex_index + 1u]; var prev_weight2=origin_data[base_vertex_index + 2u]; var next_weight2=origin_data[base_vertex_index + 2u]; for (var morph_index=0u;morph_index < morph_length;morph_index++) { let prev_animation_data=animation_data_list[prev_time_offset + morph_index]; let next_animation_data=animation_data_list[next_time_offset + morph_index]; let morph_base_offset=morph_index * vertex_count * 3u; let temp_weight_x=morph_interleave_data[morph_base_offset + base_vertex_index2]; prev_weight +=prev_animation_data * temp_weight_x; next_weight +=next_animation_data * temp_weight_x; let temp_weight_y=morph_interleave_data[morph_base_offset + base_vertex_index2 + 1u]; prev_weight1 +=prev_animation_data * temp_weight_y; next_weight1 +=next_animation_data * temp_weight_y; let temp_weight_z=morph_interleave_data[morph_base_offset + base_vertex_index2 + 2u]; prev_weight2 +=prev_animation_data * temp_weight_z; next_weight2 +=next_animation_data * temp_weight_z; } let interpolation_diff_x=next_weight - prev_weight; let interpolation_diff_y=next_weight1 - prev_weight1; let interpolation_diff_z=next_weight2 - prev_weight2; let final_x=prev_weight + uniforms.interpolation_value * interpolation_diff_x; let final_y=prev_weight1 + uniforms.interpolation_value * interpolation_diff_y; let final_z=prev_weight2 + uniforms.interpolation_value * interpolation_diff_z; vertices[base_vertex_index]=final_x; vertices[base_vertex_index + 1u]=final_y; vertices[base_vertex_index + 2u]=final_z;\n}\n"}),this.#Kn=g.createComputePipeline({layout:"auto",compute:{module:this.#hh,entryPoint:"main"}}),this.#fh=g.createBuffer({size:4*this.aniDataAnimationInfo.dataList.length,usage:GPUBufferUsage.STORAGE|GPUBufferUsage.COPY_DST}),this.#Xn=g.createBuffer({size:32,usage:GPUBufferUsage.UNIFORM|GPUBufferUsage.COPY_DST}),g.queue.writeBuffer(this.#fh,0,this.aniDataAnimationInfo.dataList)}#ph(i,g){const{gpuDevice:x}=i,_=g.animationInfo.morphInfo,v=g.geometry.vertexBuffer,b=x.createBuffer({size:4*_.origin.length,usage:GPUBufferUsage.STORAGE|GPUBufferUsage.COPY_DST}),y=_.morphInfoDataList.flatMap(i=>Array.from(i.interleaveData)),S=x.createBuffer({size:4*y.length,usage:GPUBufferUsage.STORAGE|GPUBufferUsage.COPY_DST});x.queue.writeBuffer(b,0,_.origin),x.queue.writeBuffer(S,0,new Float32Array(y));const w=x.createBindGroup({layout:this.#Kn.getBindGroupLayout(0),entries:[{binding:0,resource:{buffer:this.#fh}},{binding:1,resource:{buffer:this.#Xn}},{binding:2,resource:{buffer:v.gpuBuffer}},{binding:3,resource:{buffer:b}},{binding:4,resource:{buffer:S}}]});this.#dh.set(g,{bindGroup:w,originBuffer:b,morphInterleavedBuffer:S})}}const parseAnimations=(i,g)=>new Promise(async x=>{g.animations||(g.animations=[]);const{parsingResult:_}=i,{animations:v}=_,{animations:b}=g;if(b.length){const x=b.map(async x=>{const{samplers:_,channels:b}=x,y=[];y.minTime=1e7,y.maxTime=-1,y.name=x.name,v.push(y),await Promise.all(b.map(async x=>((i,g,x,_,v)=>{let b,y;const{nodes:S,meshes:w}=v,L=[],{sampler:k,target:H}=x,z=_[k],{node:q,path:W}=H,be=S[q];if("mesh"in be){b=be.Mesh;const{primitives:i}=w[be.mesh];let g=i.length;for(;g--;)L.push(i[g].Mesh)}else{let g;if(!i.parsingResult.groups[q])return;g=i.parsingResult.groups[q],b=g}if("scale"!=W&&"rotation"!=W&&"translation"!=W&&"weights"!=W||(y=new AniTrack_GLTF(W,new AnimationData_GLTF(i,v,z.input),new AnimationData_GLTF(i,v,z.output),z.interpolation,b,L),g.push(y)),y){const{timeAnimationInfo:i}=y,{dataList:x}=i;g.minTime>x[0]&&(g.minTime=x[0]),g.maxTimei.playAnimation(g))}x()});class ParsedSkinInfo_GLTF{joints;inverseBindMatrices;skeletonMesh;vertexStorageInfo;vertexStorageBuffer;prevVertexStorageBuffer;invertNodeGlobalTransform;usedJoints=null;WORK_SIZE=64;jointData;uniformBuffer;computeShader;computePipeline;bindGroup;constructor(){this.joints=[],this.inverseBindMatrices=null,this.skeletonMesh=null}getUsedJointIndices(i){const g=new Set,{jointBuffer:x}=i.animationInfo;if(!x.data.length)return[];const _=x.data,v=_.length;for(let i=0;i=0&&v, jointModelMatrices: array,${this.usedJoints.length}>, inverseBindMatrices: array,${this.joints.length}>, searchJointIndexTable: array,${this.joints.length}>, }; @group(0) @binding(0) var vertexWeight: array>; @group(0) @binding(1) var vertexJoint: array>; @group(0) @binding(2) var skinMatrixBuffer: array>; @group(0) @binding(3) var prevSkinMatrixBuffer: array>; @group(0) @binding(4) var uniforms: Uniforms; @compute @workgroup_size(${this.WORK_SIZE},1,1) fn main(@builtin(global_invocation_id) global_id:vec3) { let idx=global_id.x; if (idx >=arrayLength(&vertexWeight)) { return; } let weights=vertexWeight[idx]; let joints=vertexJoint[idx]; prevSkinMatrixBuffer[idx]=skinMatrixBuffer[idx]; skinMatrixBuffer[idx]=uniforms.invertNodeGlobalTransform * ( weights.x * ( \tuniforms.jointModelMatrices[uniforms.searchJointIndexTable[joints.x].x] * uniforms.inverseBindMatrices[joints.x] ) + weights.y * ( \tuniforms.jointModelMatrices[uniforms.searchJointIndexTable[joints.y].x] * uniforms.inverseBindMatrices[joints.y] ) + weights.z * ( \tuniforms.jointModelMatrices[uniforms.searchJointIndexTable[joints.z].x] * uniforms.inverseBindMatrices[joints.z] ) + weights.w * ( \tuniforms.jointModelMatrices[uniforms.searchJointIndexTable[joints.w].x] * uniforms.inverseBindMatrices[joints.w] ) ); } `;this.jointData=new Float32Array(16*(1+this.usedJoints.length)),this.computeShader=i.resourceManager.createGPUShaderModule(`calcSkinMatrix_${this.usedJoints.length}`,{code:b}),this.computePipeline=g.createComputePipeline({label:"calcSkinMatrix",layout:"auto",compute:{module:this.computeShader,entryPoint:"main"}}),this.uniformBuffer=g.createBuffer({size:this.jointData.byteLength+16*this.joints.length*4+4*this.joints.length*4,usage:GPUBufferUsage.UNIFORM|GPUBufferUsage.COPY_DST}),g.queue.writeBuffer(this.uniformBuffer,this.jointData.byteLength,new Float32Array(this.inverseBindMatrices.map(i=>Array.from(i)).flat()));const y=new Uint32Array(4*this.joints.length);y.fill(0),this.usedJoints.forEach((i,g)=>{y[4*i]=g}),g.queue.writeBuffer(this.uniformBuffer,this.jointData.byteLength+16*this.joints.length*4,y),this.bindGroup=g.createBindGroup({layout:this.computePipeline.getBindGroupLayout(0),entries:[{binding:0,resource:{buffer:_.gpuBuffer}},{binding:1,resource:{buffer:v.gpuBuffer}},{binding:2,resource:{buffer:this.vertexStorageBuffer}},{binding:3,resource:{buffer:this.prevVertexStorageBuffer}},{binding:4,resource:{buffer:this.uniformBuffer}}]})}}const parseJoint_GLTF=(i,g,x,_)=>{const{redGPUContext:v}=i,b=x[_].Mesh;b?g.joints.push(b):requestAnimationFrame(function(){parseJoint_GLTF(i,g,x,_)})},calculateNormals=(i,g)=>{let x,_,v=[],b=g;const y=i.length/3;if(!g||0===g.length){g=[];for(let i=0;i{const b=x.sparse;if(!b)return;const{values:y,indices:S,count:w}=b,L=_.bufferViews,k=L[y.bufferView],H=k.buffer,z=_.buffers,q=z[H],W=[],be=[],Ke=L[S.bufferView],Xe=Ke.buffer,je=z[Xe];let Ye;q.uri&&(Ye=i.parsingResult.uris.buffers[H]);const Ze=na[x.componentType],{BYTES_PER_ELEMENT:Je}=Ze;let Qe;switch(Ze){case Float32Array:Qe="getFloat32";break;case Uint32Array:Qe="getUint32";break;case Uint16Array:Qe="getUint16";break;case Int16Array:Qe="getInt16";break;case Uint8Array:Qe="getUint8";break;case Int8Array:Qe="getInt8"}const et=x.byteOffset||0;let tt,it,ft=((k.byteOffset||0)+et)/Je;switch(x.type){case"VEC3":for(tt=ft+Je*w/Je*3;ft{const v=new MorphInfoData_GLTF;for(let _ in x){const{vertices:b,verticesColor_0:y,normals:S,uvs:w,uvs1:L,uvs2:k,jointWeights:H,joints:z,tangents:q}=v,W=x[_],be=new AccessorInfo_GLTF(i,g,W),{accessor:Ke}=be;parseAttributeInfo_GLTF(_,be,b,w,L,0,S,H,z,y,q),Ke.sparse&&parseSparse_GLTF(i,_,Ke,g,b)}return _.length&&(v.interleaveData=new Float32Array(v.vertices)),v})),this.weights=_||[],this.origin=null}}const parseMaterialTexture=(i,g,x,_,v,b=!0)=>{const{redGPUContext:y,gltfData:S}=i,{textureRawList:w}=i.parsingResult,L=x.index,k=S.textures[L],H=k.extensions?.EXT_texture_webp?.source||k.source,z=getURL(i,S,H);if(z){const L=k.sampler,q=getSamplerInfo(i,S,L),{parsedURI:W,cacheKey:be}=z,Ke=`${_}SourceGlTfId_${H}`;if(w[Ke]?(w[Ke].materialList.push(g),w[Ke].samplerList.push(new Sampler(y,q))):w[Ke]={src:W,cacheKey:be,targetTextureKey:_,targetSamplerKey:`${_}Sampler`,materialList:[g],samplerList:[new Sampler(y,q)],format:v||navigator.gpu.getPreferredCanvasFormat(),useMipmap:b},g[`${_}_texCoord_index`]=x.texCoord||0,"extensions"in x){const{extensions:i}=x,{KHR_texture_transform:v}=i;v&&((i,g,x)=>{i[`${g}_KHR_texture_transform_offset`]=x.offset||[0,0],i[`${g}_KHR_texture_transform_scale`]=x.scale||[1,1],i[`${g}_KHR_texture_transform_rotation`]=x.rotation||0,i[`use_${g}_KHR_texture_transform`]=!0})(g,_,v)}}},getURL=function(i,g,x){if(!g.images[x])return null;const{uri:_}=g.images[x];let v;const b=`${i.url}_${x}`;return v=_.indexOf("blob:http")>-1?_:(_.indexOf(";base64,")>-1?"":i.filePath)+_,{parsedURI:v,cacheKey:b}},getSamplerInfo=function(i,g,x){const v={magFilter:b.LINEAR,minFilter:b.LINEAR,mipmapFilter:b.LINEAR,addressModeU:_.REPEAT,addressModeV:_.REPEAT,addressModeW:_.REPEAT},y={33071:_.CLAMP_TO_EDGE,33648:_.MIRRORED_REPEAT,10497:_.REPEAT},S={9728:b.NEAREST,9729:b.LINEAR},w={9728:b.NEAREST,9729:b.LINEAR};if(g.samplers){let i=g.samplers[x];i&&("magFilter"in i&&(v.magFilter=S[i.magFilter]||b.LINEAR),"minFilter"in i&&(v.minFilter=w[i.minFilter]||b.LINEAR),"wrapS"in i&&(v.addressModeU=y[i.wrapS]),"wrapT"in i&&(v.addressModeV=y[i.wrapT]))}return v.string=JSON.stringify(v),v},parseMaterialInfo_GLTF=(i,g,x)=>{const{redGPUContext:_}=i;let v,b=!1,y="OPAQUE",S=.5;if("material"in x){v=new PBRMaterial(_);const w=x.material,L=g.materials[w];b=!!L.doubleSided,y=L.alphaMode??y,S=L.alphaCutoff??S;const{pbrMetallicRoughness:k,normalTexture:H,emissiveTexture:z,occlusionTexture:q}=L;if(v.emissiveFactor=L.emissiveFactor||[0,0,0],k){const{metallicRoughnessTexture:g,baseColorTexture:x}=k;let _,b;v.baseColorFactor=k.baseColorFactor||[1,1,1,1],"metallicFactor"in k&&(_=k.metallicFactor),"roughnessFactor"in k&&(b=k.roughnessFactor),v.metallicFactor=null!=_?_:1,v.roughnessFactor=null!=b?b:1,x&&parseMaterialTexture(i,v,x,"baseColorTexture",`${navigator.gpu.getPreferredCanvasFormat()}-srgb`),g&&parseMaterialTexture(i,v,g,"metallicRoughnessTexture",null,!1)}if(H){parseMaterialTexture(i,v,H,"normalTexture");const{scale:g}=H;v.normalScale=null!=g?g:1}if(z&&parseMaterialTexture(i,v,z,"emissiveTexture",`${navigator.gpu.getPreferredCanvasFormat()}-srgb`),q&&(parseMaterialTexture(i,v,q,"occlusionTexture",null,!1),v.occlusionStrength=L.occlusionTexture.strength||1),"extensions"in L){const{extensions:g}=L,{KHR_materials_clearcoat:x,KHR_materials_emissive_strength:_,KHR_materials_transmission:b,KHR_materials_diffuse_transmission:S,KHR_materials_volume:w,KHR_materials_unlit:k,KHR_materials_ior:H,KHR_materials_sheen:z,KHR_materials_specular:q,KHR_materials_dispersion:W,KHR_materials_anisotropy:be,KHR_materials_iridescence:Ke}=g;if(Ke&&((i,g,x)=>{i.useKHR_materials_iridescence=!0,i.KHR_iridescenceFactor=g.iridescenceFactor||0,i.KHR_iridescenceIor=g.iridescenceIor||1.3,i.KHR_iridescenceThicknessMinimum=g.iridescenceThicknessMinimum||100,i.KHR_iridescenceThicknessMaximum=g.iridescenceThicknessMaximum||400,i.transparent=!0;{const{iridescenceTexture:_,iridescenceThicknessTexture:v}=g;_&&parseMaterialTexture(x,i,_,"KHR_iridescenceTexture",null,!1),v&&parseMaterialTexture(x,i,v,"KHR_iridescenceThicknessTexture",null,!1)}})(v,Ke,i),be&&((i,g,x)=>{i.useKHR_materials_anisotropy=!0,i.KHR_anisotropyStrength=g.anisotropyStrength||0,i.KHR_anisotropyRotation=g.anisotropyRotation||0;const{anisotropyTexture:_}=g;_&&parseMaterialTexture(x,i,_,"KHR_anisotropyTexture")})(v,be,i),x&&((i,g,x)=>{i.KHR_clearcoatFactor=g.clearcoatFactor||0,i.KHR_clearcoatRoughnessFactor=g.clearcoatRoughnessFactor||0,i.useKHR_materials_clearcoat=!0;const{clearcoatTexture:_,clearcoatNormalTexture:v,clearcoatRoughnessTexture:b}=g;_&&parseMaterialTexture(x,i,_,"KHR_clearcoatTexture",null,!1),v&&parseMaterialTexture(x,i,v,"KHR_clearcoatNormalTexture"),b&&parseMaterialTexture(x,i,b,"KHR_clearcoatRoughnessTexture",null,!1)})(v,x,i),_){const{emissiveStrength:i}=_;v.emissiveStrength=null!=i?i:1}if(b&&(((i,g,x)=>{i.useKHR_materials_transmission=!0,i.KHR_transmissionFactor=g.transmissionFactor||0,i.use2PathRender=!0;{const _=g.transmissionTexture;_&&parseMaterialTexture(x,i,_,"KHR_transmissionTexture",null,!1)}})(v,b,i),v.transparent="BLEND"===y),S&&((i,g,x)=>{i.useKHR_materials_diffuse_transmission=!0,i.KHR_diffuseTransmissionFactor=g.diffuseTransmissionFactor||0,i.KHR_diffuseTransmissionColorFactor=g.diffuseTransmissionColorFactor||[1,1,1],i.transparent=!0;{const _=g.diffuseTransmissionTexture;_&&parseMaterialTexture(x,i,_,"KHR_diffuseTransmissionTexture",null,!1);const v=g.diffuseTransmissionColorTexture;v&&parseMaterialTexture(x,i,v,"KHR_diffuseTransmissionColorTexture",`${navigator.gpu.getPreferredCanvasFormat()}-srgb`,!1)}})(v,S,i),w&&(((i,g,x)=>{i.useKHR_materials_volume=!0,i.KHR_thicknessFactor=g.thicknessFactor||1,i.KHR_attenuationDistance=g.attenuationDistance||1,i.KHR_attenuationColor=g.attenuationColor||[1,1,1],i.use2PathRender=!0,i.transparent=!0;{const _=g.thicknessTexture;_&&parseMaterialTexture(x,i,_,"KHR_thicknessTexture",null,!1)}})(v,w,i),y="BLEND"),k&&(v.useKHR_materials_unlit=!0),H){const{ior:i}=H;v.KHR_materials_ior=null!=i?i:1.5,v.use2PathRender=!0,v.transparent=!0}if(W){const{dispersion:i}=W;v.KHR_dispersion=i||0,v.use2PathRender=!0,v.transparent=!0}z&&((i,g,x)=>{i.KHR_sheenColorFactor=g.sheenColorFactor||[0,0,0],i.KHR_sheenRoughnessFactor=g.sheenRoughnessFactor||0,i.useKHR_materials_sheen=!0;const{sheenColorTexture:_,sheenRoughnessTexture:v}=g;_&&parseMaterialTexture(x,i,_,"KHR_sheenColorTexture",`${navigator.gpu.getPreferredCanvasFormat()}-srgb`,!1),v&&parseMaterialTexture(x,i,v,"KHR_sheenRoughnessTexture",null,!1)})(v,z,i),q&&((i,g,x)=>{i.useKHR_materials_specular=!0,i.KHR_specularFactor=g.specularFactor??1,i.KHR_specularColorFactor=g.specularColorFactor||[1,1,1];const{specularTexture:_,specularColorTexture:v}=g;_&&parseMaterialTexture(x,i,_,"KHR_specularTexture"),v&&parseMaterialTexture(x,i,v,"KHR_specularColorTexture",`${navigator.gpu.getPreferredCanvasFormat()}-srgb`)})(v,q,i)}}else v=new PBRMaterial(_);Object.hasOwn(x.attributes,"COLOR_0")&&(v.useVertexColor=!0),v.doubleSided=b,v.cutOff=S;const{blendColorState:w,blendAlphaState:L}=v;switch(y){case"BLEND":v.alphaBlend=2,w.srcFactor=mr.SRC_ALPHA,w.dstFactor=mr.ONE_MINUS_SRC_ALPHA,L.srcFactor=mr.SRC_ALPHA,L.dstFactor=mr.ONE_MINUS_SRC_ALPHA,v.transparent=!0;break;case"MASK":v.alphaBlend=1,v.useCutOff=!0,w.srcFactor=mr.ONE,w.dstFactor=mr.ZERO,L.srcFactor=mr.ONE,L.dstFactor=mr.ZERO;break;default:w.srcFactor=mr.ONE,w.dstFactor=mr.ZERO,L.srcFactor=mr.ONE,L.dstFactor=mr.ZERO,v.alphaBlend=0}return v},parseIndicesInfo_GLTF=(i,g)=>{const{accessor:x,startIndex:_,getMethod:v,bufferURIDataView:b,componentType_BYTES_PER_ELEMENT:y}=i,{type:S,count:w}=x;let L,k=_;if("SCALAR"===S)for(L=k+w;k{let z,q,W,be,Ke,Xe,je,Ye,Ze,Je=0,Qe=g.length/3,et=0;const tt=g.length,it=_.length,ft=b.length,pt=x.length,xt=S.length,vt=w.length,bt=L.length;if(z=W=Xe=0,q=be=je=1,Ke=Ye=2,Ze=3,k)for(;Je{let x=i[0],_=i[1],v=i[2],b=i[3],y=x+x,S=_+_,w=v+v,L=x*y,k=x*S,H=x*w,z=_*S,q=_*w,W=v*w,be=b*y,Ke=b*S,Xe=b*w;return g[0]=1-(z+W),g[4]=k-Xe,g[8]=H+Ke,g[1]=k+Xe,g[5]=1-(L+W),g[9]=q-be,g[2]=H-Ke,g[6]=q+be,g[10]=1-(L+z),g[3]=0,g[7]=0,g[11]=0,g[12]=0,g[13]=0,g[14]=0,g[15]=1,g},ra=180/Math.PI,setMeshRotation=(i,g)=>{g.setRotation(i[0]*ra,i[1]*ra,i[2]*ra)},parseTRSAndMATRIX_GLTF=(i,g)=>{const{matrix:x,rotation:_,translation:v,scale:b}=g;let y,S;if(y=create$4(),"matrix"in g){S=create$3(),mat4ToEuler(x,S),setMeshRotation(S,i),i.setPosition(x[12],x[13],x[14]);const g=fromValues$3(1,1,1);getScaling(g,x),i.setScale(g[0],g[1],g[2])}else"rotation"in g&&(S=create$3(),quaternionToRotationMat4(_,y),mat4ToEuler(y,S),setMeshRotation(S,i)),"translation"in g&&i.setPosition(v[0],v[1],v[2]),"scale"in g&&(i.setScale(b[0],b[1],b[2]),(b[0]<0||b[1]<0||b[2]<0)&&(i.primitiveState.frontFace=ti.CW))},parseChildrenAndSkin=(i,g,x,_,v)=>{if("children"in _){const v=_.children,b=v.length;for(let _=0;_{const v=new ParsedSkinInfo_GLTF,b=[],{nodes:y}=g,{joints:S,skeleton:w}=x;{let g=0;const x=S.length;for(;g{const{redGPUContext:v,parsingResult:b}=i,{nodes:y,meshes:S,skins:w}=g,{groups:L,cameras:k}=b,H=y[x];if("mesh"in H){const v=function(i,g,x,_){const{redGPUContext:v}=i;let b;x.name&&(b=x.name);const y=[],{primitives:S}=x;let w=0;const L=S.length;for(;w-1;if(b){const i=`TEXCOORD_${tt.size}`;tt.set(x,i)}parseAttributeInfo_GLTF(b?tt.get(x):x,v,W,Ke,Xe,0,Ye,Ze,Je,be,Qe),v.accessor.sparse&&parseSparse_GLTF(i,x,v.accessor,g,W)}if("indices"in L){let x=L.indices,_=new AccessorInfo_GLTF(i,g,x);parseIndicesInfo_GLTF(_,q)}H=parseMaterialInfo_GLTF(i,g,L),H instanceof PBRMaterial&&i.parsingResult.materials.push(H);let it,ft=!1;if("mode"in L)switch(L.mode){case 0:z=Lr.POINT_LIST;break;case 1:case 2:z=Lr.LINE_LIST;break;case 3:z=Lr.LINE_STRIP,ft=!0;break;case 4:case 6:z=Lr.TRIANGLE_LIST;break;case 5:z=Lr.TRIANGLE_STRIP,ft=!0}be.length&&(H.useVertexColor_0=!0),it=Ye.length?Ye:calculateNormals(W,q),Qe.length&&(H.useVertexTangent=!0);let pt,xt=[];parseInterleaveData_GLTF(xt,W,be,it,Ke,Xe,0,Ze,Je,Qe);let vt={};W.length&&(vt.aVertexPosition=VertexInterleaveType.float32x3),it.length&&(vt.aVertexNormal=VertexInterleaveType.float32x3),Ke.length&&(vt.aTexcoord=VertexInterleaveType.float32x2),(je.length||Xe.length||Ke.length)&&(vt.aTexcoord1=VertexInterleaveType.float32x2),vt.aVertexColor_0=VertexInterleaveType.float32x4,vt.aVertexTangent=VertexInterleaveType.float32x4;const bt=[],yt=[];parseInterleaveData_GLTF(bt,W,be,it,Ke,Xe,0,Ze,Je,Qe,!0),parseInterleaveData_GLTF(yt,W,be,it,Ke,Xe,0,Ze,Je,Qe,!1,!0);const St=new VertexBuffer(v,bt,new VertexInterleavedStruct({aVertexWeight:VertexInterleaveType.float32x4}),void 0,`Weight_${i.url}_${_}_${w}`),Tt=new IndexBuffer(v,yt,GPUBufferUsage.STORAGE|GPUBufferUsage.COPY_DST,`Joint_${i.url}_${_}_${w}`);let Mt=new MorphInfo_GLTF(i,g,L,x.weights);const wt=`Vertex_${i.url}_${_}_${w}_${Mt.weights.length?createUUID():""}`,Ct=v.resourceManager.managedVertexBufferState.table.get(wt)?.buffer;if(pt=new Geometry(v,Ct||new VertexBuffer(v,xt,new VertexInterleavedStruct(vt,"PBR"),void 0,wt),!ft&&q.length?new IndexBuffer(v,new Uint32Array(q),void 0,`Index_${i.url}_${_}_${w}`):null),H||consoleAndThrowError("재질을 파싱할수없는경우 ",L),k=new Mesh(v,pt,H),k.animationInfo.weightBuffer=St,k.animationInfo.jointBuffer=Tt,b&&(k.name=b,i.parsingOption))for(let g in i.parsingOption)b.toLowerCase().indexOf(g)>-1&&i.parsingOption[g](k);k.primitiveState.topology=z||Lr.TRIANGLE_LIST,k.material.doubleSided&&(k.primitiveState.cullMode=ei.NONE),k.material.use2PathRender&&(k.primitiveState.cullMode=ei.NONE,k.depthStencilState.depthCompare=Tn.LESS_EQUAL),2===k.material.alphaBlend&&(k.depthStencilState.depthCompare=Tn.LESS_EQUAL),k.animationInfo.morphInfo=Mt,k.animationInfo.morphInfo.origin=new Float32Array(xt);let Rt=k.geometry.vertexBuffer.data;k.gpuRenderInfo||k.initGPURenderInfos();let Pt=0;for(const i in vt)Pt+=vt[i].numElements;if(!Ct){const i=k.animationInfo.morphInfo.morphInfoDataList;let g=0;const x=i.length,_=Rt.length;for(;g{g.extensionsUsed?.includes("KHR_draco_mesh_compression")&&alert("RedGPU GLTFLoader does not support the KHR_draco_mesh_compression extension. Models using this extension may not load properly."),requestAnimationFrame(()=>{(i=>{const g=i?.asset;g||consoleAndThrowError("GLTFLoader - asset must be defined"),g.version||consoleAndThrowError("GLTFLoader - asset version must be defined");const x=parseFloat(g.version);isNaN(x)&&consoleAndThrowError("GLTFLoader - asset version must be a numerical value"),x<2&&consoleAndThrowError("GLTFLoader - asset version must be 2.0 or higher")})(g),requestAnimationFrame(()=>{((i,g,x,_)=>{const{parsingResult:v}=i,{uris:b}=v,y="buffers",S=b[y],w=g.buffers,L=w.length;let k=0;checkProgress(i,g,k),w.forEach((v,b)=>{var w;function checkLoadingStatus(){checkProgress(i,g,k),_?.(i.loadingProgressInfo),k===L&&x&&x()}v._redURIkey=y,v._redURIIndex=b,v.uri instanceof ArrayBuffer?(w=new DataView(v.uri),k++,S[b]=w,checkLoadingStatus()):function(g){const x=g.startsWith("data:")?g:i.filePath+g;arrayBufferLoader(x,function(i){k++,S[b]=new DataView(i),checkLoadingStatus()},function(i,g){})}(v.uri)})})(i,g,()=>{requestAnimationFrame(()=>{((i,g,x)=>{const{scenes:_}=g;_[0].nodes.forEach(x=>{parseNode_GLTF(i,g,x,i.resultMesh)}),x?.()})(i,g,()=>{requestAnimationFrame(()=>{((i,g)=>{const{cameras:x}=g;x&&x.forEach(function(g){let x=new PerspectiveCamera;"orthographic"==g.type||(x.fieldOfView=180*g.perspective.yfieldOfView/Math.PI,x.farClipping=g.perspective.zfar,x.nearClipping=g.perspective.znear),i.parsingResult.cameras.push(x)})})(i,g),new TextureLoader(i.redGPUContext,Object.values(i.parsingResult.textureRawList),_=>{_.textures.forEach(i=>{const{targetTextureKey:g,targetSamplerKey:x,samplerList:_}=i.srcInfo;i.srcInfo.materialList.forEach((v,b)=>{v[g]=i.texture,_[b]&&(v[x]=_[b])})}),parseAnimations(i,g).then(i=>{x&&x()})},g=>{i.loadingProgressInfo.textures=g,_?.(i.loadingProgressInfo)})})})})},_)})})},ia=new Map,aa=new Map,parseFileGLB=async(i,x,_)=>{const v=getAbsoluteURL(window.location.href,i.filePath+i.fileName),progress=()=>{if(_){const g=ia.get(v);i.loadingProgressInfo.model={loaded:g.byteLength,total:g.byteLength,lengthComputable:!0,percent:100,transferred:"Cached",totalSize:"Cached"},_(i.loadingProgressInfo)}};if(ia.has(v))return g("GLB Model parsing has cache",v),progress(),void await parseArrayBuffer(i,ia.get(v),x,_);if(aa.has(v))return await aa.get(v),progress(),void await parseArrayBuffer(i,ia.get(v),x,_);const b=new Promise((x,b)=>{(async(i,g,x=()=>{},_=()=>{})=>{try{const x=await fetch(i);if(!x.ok)throw new Error(`HTTP error! status:${x.status}`);const v=x.headers.get("content-length"),b=v?parseInt(v,10):0,y=b>0,S=y?formatBytes(b):"Unknown";if(!x.body)return void g(new ArrayBuffer(0));const w=x.body.getReader();let L=0;const k=[];for(;;){const{done:i,value:g}=await w.read();if(i)break;g&&(k.push(g),L+=g.length,_({loaded:L,total:b,lengthComputable:y,percent:y?Math.min(100,parseFloat((L/b*100).toFixed(2))):0,transferred:formatBytes(L),totalSize:S}))}if(0===L)return void g(new ArrayBuffer(0));const H=new Blob(k);g(await H.arrayBuffer())}catch(i){x?x(i):console.error("getArrayBufferFromSrc 로딩 중 오류 발생:",i)}})(v,i=>{ia.set(v,i),g("GLB Model parsing set cache",v),aa.delete(v),x(i)},i=>{g("GLB Model parsing error",i),aa.delete(v),b(i)},g=>{i.loadingProgressInfo.model=g,_?.(i.loadingProgressInfo)})});aa.set(v,b);try{const g=await b;await parseArrayBuffer(i,g,x,_)}catch(i){}},parseArrayBuffer=async(i,g,x,_)=>{const{content:v,binaryChunk:b}=parseBuffer(g);if(null===v)throw new Error("JSON content not found");const y=JSON.parse(v);processImagesIfExist(y,b),y.buffers[0].uri=b,i.gltfData=y,parseGLTF(i,y,x,_)},parseBuffer=i=>{let g=null,x=null;const _=new DataView(i,12),v=_.byteLength;for(let b=0;b{const{images:x,bufferViews:_}=i,v=["image/png","image/jpeg","image/gif","image/webp"],b=new Map;if(x)for(let i=0;i{let g="";for(let x of i)g+=String.fromCharCode(x);return g},sa=new Map,oa=new Map,getData=i=>({...i,meshes:JSON.parse(JSON.stringify(i.meshes))});class GLTFLoader{parsingResult;resultMesh;parsingOption;activeAnimations=[];#l;#gh;#xh;#_h;#vh;#bh;#H;#z;#yh;#Sh={url:"",model:{loaded:0,total:0,lengthComputable:!0,percent:0,transferred:"0",totalSize:"0"}};constructor(i,g,x,_,v){validateRedGPUContext(i),this.#l=i,this.#_h=g,this.#gh=getFilePath(g),this.#xh=getFileName(g),this.#vh=getFileExtension(g),this.#H=x,this.#yh=_,this.#z=v,this.parsingResult={groups:[],materials:[],uris:{buffers:[]},textures:{},textureRawList:[],cameras:[],animations:[]},this.resultMesh=new Mesh(this.#l),this.resultMesh.gltfLoaderInfo=this,this.resultMesh.animationInfo.animationsList=this.parsingResult.animations,this.#Sh.url=getFileName(g),this.#Th()}get loadingProgressInfo(){return this.#Sh}get redGPUContext(){return this.#l}get filePath(){return this.#gh}get gltfData(){return this.#bh}set gltfData(i){this.#bh=i}get fileName(){return this.#xh}get url(){return this.#_h}stopAnimation(){this.activeAnimations.length=0}playAnimation(i){const{activeAnimations:g}=this;g.push(new PlayAnimationInfo(performance.now(),i))}async#Th(){try{"glb"===this.#vh?parseFileGLB(this,()=>this.#H(this),this.#yh):"gltf"===this.#vh?(async(i,x,_)=>{const v=getAbsoluteURL(window.location.href,i.filePath+i.fileName),cachedProgress=()=>{if(_){const g=sa.get(v);i.loadingProgressInfo.model={loaded:g.byteLength,total:g.byteLength,lengthComputable:!0,percent:100,transferred:"Cached",totalSize:"Cached"},_(i.loadingProgressInfo)}};if(sa.has(v))return i.gltfData=getData(sa.get(v)),cachedProgress(),void requestAnimationFrame(()=>{parseGLTF(i,i.gltfData,x,_)});if(oa.has(v))return await oa.get(v),cachedProgress(),i.gltfData=getData(sa.get(v)),void requestAnimationFrame(()=>{parseGLTF(i,i.gltfData,x,_)});const b=new Promise(async(x,b)=>{try{const b=await fetch(i.url);if(!b.ok)throw new Error("GLTF 네트워크 오류:"+b.status);const y=b.headers.get("content-length"),S=y?parseInt(y,10):0;g(`전체 사이즈:${S} bytes`);const w=await b.json();sa.set(v,w),i.loadingProgressInfo.model={loaded:S,total:S,lengthComputable:!0,percent:100,transferred:formatBytes(S),totalSize:formatBytes(S)};{g(w);const x=w.buffers.length;if(x){let g=0;i.loadingProgressInfo.buffers={loaded:g,total:x,percent:Math.min(100,parseFloat((g/x*100).toFixed(2)))}}}_?.(i.loadingProgressInfo),x(w)}catch(i){b(i)}finally{oa.delete(v)}});oa.set(v,b);const y=await b;i.gltfData=getData(y),requestAnimationFrame(()=>{parseGLTF(i,i.gltfData,x,_)})})(this,()=>this.#H(this),this.#yh):consoleAndThrowError("Unknown file extension:"+this.#vh)}catch(i){this.#z?.(i)}}}Object.freeze(GLTFLoader);class PlayAnimationInfo{startTime;targetGLTFParsedSingleClip;constructor(i,g){this.startTime=i,this.targetGLTFParsedSingleClip=g}}var ua=Object.freeze({__proto__:null,AABB:AABB,OBB:OBB,calculateGeometryAABB:calculateGeometryAABB,calculateMeshAABB:calculateMeshAABB,calculateMeshCombinedAABB:calculateMeshCombinedAABB,calculateMeshOBB:calculateMeshOBB}),la=Object.freeze({__proto__:null,AController:AController});const ca=Math.PI/180,updateObject3DMatrix=(i,g)=>{const{pixelRectObject:x}=g,_=i.parent,v=i.localMatrix;identity$1(v),translate(v,v,[i.x,i.y,i.z]),rotateX$2(v,v,i.rotationX*ca),rotateY$2(v,v,i.rotationY*ca),rotateZ$2(v,v,i.rotationZ*ca);let b=[i.scaleX,i.scaleY,i.scaleZ];if(i.renderTextureWidth&&(b[0]*=i.renderTextureWidth/x.height,b[1]*=i.renderTextureHeight/x.height),scale$4(v,v,b),i.pivotX||i.pivotY||i.pivotZ){translate(v,v,[-i.pivotX,-i.pivotY,-i.pivotZ])}_?.modelMatrix?multiply$4(i.modelMatrix,_.modelMatrix,i.localMatrix):copy$4(i.modelMatrix,i.localMatrix)},ha=Math.PI/180;const fa=Math.PI/180,da=create$4(),ma=create$3();const pa=Math.PI/180,ga=1e-4,xa=create$4();var _a=Object.freeze({__proto__:null,Camera2D:Camera2D,Core:la,FollowController:class extends AController{#Mh=10;#wh=10;#Ch=.02;#Rh=5;#Ph=5;#Bh=.02;#Ih=.02;#Eh=0;#Dh=0;#Uh=.02;#Lh=20;#Ah=20;#Gh=.02;#kh=!0;#Oh=0;#Nh=0;#Vh=0;#Sa;#Fh=create$3();constructor(i,g){super(i,{HD_Wheel:i=>{this.#wh+=i.deltaY/100},HD_TouchPinch:i=>{const g=i-1;this.#wh-=g*this.#wh}}),this.targetMesh=g,this.#Sa.setIgnoreFrustumCullingRecursively(!0)}get distance(){return this.#wh}set distance(i){validateNumberRange(i,.1),this.#wh=i}get distanceInterpolation(){return this.#Ch}set distanceInterpolation(i){validateNumberRange(i,.01,1),this.#Ch=i}get height(){return this.#Ph}set height(i){validateNumber(i),this.#Ph=i}get heightInterpolation(){return this.#Bh}set heightInterpolation(i){validateNumberRange(i,.01,1),this.#Bh=i}get pan(){return this.#Dh}set pan(i){validateNumber(i),this.#Dh=i}get panInterpolation(){return this.#Uh}set panInterpolation(i){validateNumberRange(i,.01,1),this.#Uh=i}get tilt(){return this.#Ah}set tilt(i){validateNumber(i),this.#Ah=Math.max(-89,Math.min(89,i))}get tiltInterpolation(){return this.#Gh}set tiltInterpolation(i){validateNumberRange(i,.01,1),this.#Gh=i}get interpolation(){return this.#Ih}set interpolation(i){validateNumberRange(i,.01,1),this.#Ih=i}get followTargetRotation(){return this.#kh}set followTargetRotation(i){this.#kh=i}get targetOffsetX(){return this.#Oh}set targetOffsetX(i){validateNumber(i),this.#Oh=i}get targetOffsetY(){return this.#Nh}set targetOffsetY(i){validateNumber(i),this.#Nh=i}get targetOffsetZ(){return this.#Vh}set targetOffsetZ(i){validateNumber(i),this.#Vh=i}get targetMesh(){return this.#Sa}set targetMesh(i){if(!i)throw new Error("FollowController:targetMesh cannot be null or undefined");this.#Sa=i,this.#Sa.setIgnoreFrustumCullingRecursively(!0),this.#Hh()}setTargetOffset(i,g=0,x=0){validateNumber(i),validateNumber(g),validateNumber(x),this.#Oh=i,this.#Nh=g,this.#Vh=x}update(i,g){super.update(i,g,g=>{const{targetMesh:x}=this;x&&updateObject3DMatrix(x,i),this.#Mh=this.#wh+(this.#Mh-this.#wh)*Math.pow(this.#Ch,g),this.#Rh=this.#Ph+(this.#Rh-this.#Ph)*Math.pow(this.#Bh,g);let _=(this.#Dh-this.#Eh)%360;_>180&&(_-=360),_<-180&&(_+=360),this.#Eh+=_*(1-Math.pow(this.#Uh,g)),this.#Lh=this.#Ah+(this.#Lh-this.#Ah)*Math.pow(this.#Gh,g);const v=this.#zh(),b=Math.pow(this.#Ih,g);this.#Fh[0]=v[0]+(this.#Fh[0]-v[0])*b,this.#Fh[1]=v[1]+(this.#Fh[1]-v[1])*b,this.#Fh[2]=v[2]+(this.#Fh[2]-v[2])*b,this.camera.setPosition(this.#Fh[0],this.#Fh[1],this.#Fh[2]);const y=this.#$h();this.camera.lookAt(y[0],y[1],y[2])})}#zh(){const i=this.#Eh*fa,g=this.#Lh*fa,x=Math.cos(g),_=Math.sin(g),v=Math.cos(i),b=Math.sin(i),y=this.#Sa.modelMatrix,S=y[12],w=y[13],L=y[14];return this.#kh?(set$3(ma,b*this.#Mh*x,_*this.#Mh+this.#Rh,v*this.#Mh*x),copy$4(da,y),da[12]=da[13]=da[14]=0,transformMat4$2(ma,ma,da),fromValues$3(S+ma[0],w+ma[1],L+ma[2])):fromValues$3(S+this.#Mh*x*b,w+this.#Rh+this.#Mh*_,L+this.#Mh*x*v)}#$h(){set$3(ma,this.#Oh,this.#Nh,this.#Vh);const i=this.#Sa.modelMatrix,g=i[12],x=i[13],_=i[14];return!this.#kh||0===this.#Oh&&0===this.#Nh&&0===this.#Vh||(copy$4(da,i),da[12]=da[13]=da[14]=0,transformMat4$2(ma,ma,da)),fromValues$3(g+ma[0],x+ma[1],_+ma[2])}#Hh(){updateObject3DMatrix(this.#Sa,{pixelRectObject:{height:1}}),this.#Mh=this.#wh,this.#Rh=this.#Ph,this.#Eh=this.#Dh,this.#Lh=this.#Ah;const i=this.#zh();copy$3(this.#Fh,i),this.camera.setPosition(this.#Fh[0],this.#Fh[1],this.#Fh[2]);const g=this.#$h();this.camera.lookAt(g[0],g[1],g[2])}},FreeController:class extends AController{#Ra={moveForward:"w",moveBack:"s",moveLeft:"a",moveRight:"d",moveUp:"e",moveDown:"q",turnLeft:"z",turnRight:"c",turnUp:"r",turnDown:"f"};#wa=600;#Kh=.001;#Xh=1;#jh=0;#Yh=360;#qh=.001;#Wh=.15;#Zh=[0,0,0];#Jh=0;#Qh=0;#Sa;#ef=create$4();#tf=create$4();#nf=create$3();constructor(i){super(i,{HD_Move:(i,g)=>{this.#Jh-=i*this.#Wh,this.#Qh-=g*this.#Wh},useKeyboard:!0}),this.#sa()}get x(){return this.#Sa.x}set x(i){validateNumber(i),this.#Sa.x=i,this.#Zh[0]=i}get y(){return this.#Sa.y}set y(i){validateNumber(i),this.#Sa.y=i,this.#Zh[1]=i}get z(){return this.#Sa.z}set z(i){validateNumber(i),this.#Sa.z=i,this.#Zh[2]=i}get pan(){return this.#Jh}set pan(i){validateNumber(i),this.#Jh=i}get tilt(){return this.#Qh}set tilt(i){validateNumber(i),this.#Qh=Math.max(-89.9,Math.min(89.9,i))}get mouseSensitivity(){return this.#Wh}set mouseSensitivity(i){validateNumberRange(i,.01),this.#Wh=i}get moveSpeed(){return this.#wa}set moveSpeed(i){validateNumberRange(i,.01),this.#wa=i}get moveSpeedInterpolation(){return this.#Kh}set moveSpeedInterpolation(i){validateNumberRange(i,1e-4,1),this.#Kh=i}get rotationSpeed(){return this.#Yh}set rotationSpeed(i){validateNumberRange(i,.01),this.#Yh=i}get rotationSpeedInterpolation(){return this.#qh}set rotationSpeedInterpolation(i){validateNumberRange(i,1e-4,1),this.#qh=i}get maxAcceleration(){return this.#Xh}set maxAcceleration(i){this.#Xh=i}get keyNameMapper(){return{...this.#Ra}}setMoveForwardKey(i){this.#Ra.moveForward=i}setMoveBackKey(i){this.#Ra.moveBack=i}setMoveLeftKey(i){this.#Ra.moveLeft=i}setMoveRightKey(i){this.#Ra.moveRight=i}setMoveUpKey(i){this.#Ra.moveUp=i}setMoveDownKey(i){this.#Ra.moveDown=i}setTurnLeftKey(i){this.#Ra.turnLeft=i}setTurnRightKey(i){this.#Ra.turnRight=i}setTurnUpKey(i){this.#Ra.turnUp=i}setTurnDownKey(i){this.#Ra.turnDown=i}update(i,g){super.update(i,g,x=>{this.#Ia(i,g,x)})}#sa(){this.#Sa=new Mesh(this.redGPUContext)}#Ia(i,g,x){const _=this.#Sa,v=Math.pow(this.#Kh,x),b=Math.pow(this.#qh,x);let y=(this.#Jh-_.rotationY)%360;y>180&&(y-=360),y<-180&&(y+=360),_.rotationY+=y*(1-b);const S=this.#Qh-_.rotationX;_.rotationX+=S*(1-b),this.#rf(i,x)&&(updateObject3DMatrix(_,i),identity$1(this.#tf),rotateY$2(this.#tf,this.#tf,_.rotationY*ha),rotateX$2(this.#tf,this.#tf,_.rotationX*ha),translate(this.#tf,this.#tf,this.#nf),identity$1(this.#ef),translate(this.#ef,this.#ef,_.position),multiply$4(this.#ef,this.#ef,this.#tf),this.#Zh[0]=this.#ef[12],this.#Zh[1]=this.#ef[13],this.#Zh[2]=this.#ef[14]),_.x+=(this.#Zh[0]-_.x)*(1-v),_.y+=(this.#Zh[1]-_.y)*(1-v),_.z+=(this.#Zh[2]-_.z)*(1-v),identity$1(this.#ef),translate(this.#ef,this.#ef,_.position),rotateY$2(this.#ef,this.#ef,_.rotationY*ha),rotateX$2(this.#ef,this.#ef,_.rotationX*ha),this.camera.setPosition(_.x,_.y,_.z);const w=fromValues$3(0,0,-10);transformMat4$2(w,w,this.#ef),this.camera.lookAt(w[0],w[1],w[2])}#rf(i,g){if(!this.checkKeyboardInput(i,this.#Ra))return!1;const{keyboardKeyBuffer:x}=i.redGPUContext,_=this.#wa*g,v=this.#Yh*g,b=this.#Ra;let y=!1,S=!1,w=0,L=0;this.#nf[0]=0,this.#nf[1]=0,this.#nf[2]=0;const k=this.#jh*_;x[b.turnLeft]&&(S=!0,w=v),x[b.turnRight]&&(S=!0,w=-v),x[b.turnUp]&&(S=!0,L=v),x[b.turnDown]&&(S=!0,L=-v),x[b.moveForward]&&(y=!0,this.#nf[2]=-k),x[b.moveBack]&&(y=!0,this.#nf[2]=k),x[b.moveLeft]&&(y=!0,this.#nf[0]=-k),x[b.moveRight]&&(y=!0,this.#nf[0]=k),x[b.moveUp]&&(y=!0,this.#nf[1]=k),x[b.moveDown]&&(y=!0,this.#nf[1]=-k);const H=3*g;return this.#jh=S||y?Math.min(this.#Xh,this.#jh+H):Math.max(0,this.#jh-H),S&&(this.#Jh+=w,this.#Qh=Math.max(-89.9,Math.min(89.9,this.#Qh+L))),y||S}},IsometricController:IsometricController,OrbitController:class extends AController{#if=0;#af=0;#sf=0;#of=15;#uf=1.5;#Ch=.02;#lf=.1;#Pr=1/0;#Jh=0;#Qh=-35;#cf=3;#qh=.02;#hf=-90;#ff=90;#Eh=0;#Lh=0;#Mh=0;constructor(i){super(i,{HD_Move:(i,g)=>{this.#Jh-=i*this.#cf*.1,this.#Qh-=g*this.#cf*.1},HD_Wheel:i=>{this.#of+=i.deltaY/100*this.#uf,this.#ofthis.#Pr&&(this.#of=this.#Pr)},HD_TouchPinch:i=>{const g=(i-1)*this.#uf;this.#of-=g*this.#of,this.#ofthis.#Pr&&(this.#of=this.#Pr)}}),this.#Eh=this.#Jh,this.#Lh=this.#Qh,this.#Mh=this.#of}get centerX(){return this.#if}set centerX(i){this.#if=i}get centerY(){return this.#af}set centerY(i){this.#af=i}get centerZ(){return this.#sf}set centerZ(i){this.#sf=i}get distance(){return this.#of}set distance(i){validateNumberRange(i,0),this.#of=i}get speedDistance(){return this.#uf}set speedDistance(i){validateNumberRange(i,.01),this.#uf=i}get distanceInterpolation(){return this.#Ch}set distanceInterpolation(i){validateNumberRange(i,.01,1),this.#Ch=i}get minDistance(){return this.#lf}set minDistance(i){validateNumberRange(i,.1),this.#lf=i}get maxDistance(){return this.#Pr}set maxDistance(i){validateNumberRange(i,.1),this.#Pr=i}get speedRotation(){return this.#cf}set speedRotation(i){validateNumberRange(i,.01),this.#cf=i}get rotationInterpolation(){return this.#qh}set rotationInterpolation(i){validateNumberRange(i,.01,1),this.#qh=i}get pan(){return this.#Jh}set pan(i){this.#Jh=i}get tilt(){return this.#Qh}set tilt(i){validateNumberRange(i,-90,90),this.#Qh=i}get minTilt(){return this.#hf}set minTilt(i){validateNumberRange(i,-90,90),this.#hf=i}get maxTilt(){return this.#ff}set maxTilt(i){validateNumberRange(i,-90,90),this.#ff=i}#df(i,g){updateObject3DMatrix(i,g);let x=i.children.length;for(let _=0;_{this.#Ia(i)})}#Ia(i){this.#Qhthis.#ff&&(this.#Qh=this.#ff);const{camera:g}=this,x=this.#Jh-this.#Eh;Math.abs(x)>ga?this.#Eh+=x*(1-Math.pow(this.#qh,i)):this.#Eh=this.#Jh;const _=this.#Qh-this.#Lh;Math.abs(_)>ga?this.#Lh+=_*(1-Math.pow(this.#qh,i)):this.#Lh=this.#Qh,this.#ofthis.#Pr&&(this.#of=this.#Pr);const v=this.#of-this.#Mh;Math.abs(v)>1e-4?this.#Mh+=v*(1-Math.pow(this.#Ch,i)):this.#Mh=this.#of,this.#Mh uniforms:Uniforms;\n@group(2) @binding(1) var skyboxTextureSampler:sampler;\n@group(2) @binding(2) var skyboxTexture:texture_cube;\n@group(2) @binding(3) var transitionTexture:texture_cube;\n@group(2) @binding(4) var transitionAlphaTexture:texture_2d;\nstruct InputData { @location(0) vertexPosition:vec4,\n};\nfn sphericalToUV(dir:vec3) -> vec2 { let normalizedDir=normalize(dir); let phi=atan2(normalizedDir.z,normalizedDir.x); let theta=acos(clamp(normalizedDir.y,-1.0,1.0)); let u=(phi + 3.14159265359)/(2.0 * 3.14159265359); let v=theta/3.14159265359; return vec2(u,v);\n}\n@fragment\nfn main(inputData:InputData) -> FragmentOutput { var cubemapVec=(inputData.vertexPosition.xyz); let mipmapCount:f32=f32(textureNumLevels(skyboxTexture) - 1); let blurCurve=uniforms.blur * uniforms.blur; let skyboxColor=textureSampleLevel(skyboxTexture,skyboxTextureSampler,cubemapVec,mipmapCount * blurCurve); var sampleColor=skyboxColor; let u_transitionProgress=uniforms.transitionProgress; if (u_transitionProgress > 0.0) { let transitionSample=textureSampleLevel(transitionTexture,skyboxTextureSampler,cubemapVec,mipmapCount * blurCurve); #redgpu_if transitionAlphaTexture let uv=sphericalToUV(normalize(cubemapVec)); let transitionAlphaSample=textureSampleLevel(transitionAlphaTexture,skyboxTextureSampler,uv,0.0); let transitionAlphaValue=dot(transitionAlphaSample.rgb,vec3(0.299,0.587,0.114)); let threshold=u_transitionProgress; let noiseInfluence=0.3; let edgeSoftness=0.1; let maskValue=smoothstep( threshold - edgeSoftness, threshold + edgeSoftness, transitionAlphaValue + (u_transitionProgress - 0.5) * noiseInfluence ); sampleColor=mix(transitionSample,skyboxColor,maskValue * (1.0 - u_transitionProgress)); #redgpu_else sampleColor=mix(skyboxColor,transitionSample,u_transitionProgress); #redgpu_endIf } var outColor=vec4(sampleColor.rgb,sampleColor.a * uniforms.opacity); if (outColor.a==0.0) { discard; } var output:FragmentOutput; output.color=outColor; return output;\n}\n");class SkyBoxMaterial extends ABitmapBaseMaterial{dirtyPipeline=!1;constructor(i,g){super(i,"SKYBOX_MATERIAL",Sa,2),this.skyboxTexture=g,this.skyboxTextureSampler=new Sampler(this.redGPUContext,{addressModeU:"clamp-to-edge",addressModeV:"clamp-to-edge",addressModeW:"clamp-to-edge"}),this.initGPURenderInfos()}}dr.definePositiveNumber(SkyBoxMaterial,[["blur",0],["opacity",1,0,1]]),dr.definePositiveNumber(SkyBoxMaterial,[["transitionProgress",0]]),dr.defineCubeTexture(SkyBoxMaterial,["transitionTexture"]),dr.defineTexture(SkyBoxMaterial,["transitionAlphaTexture"]),dr.defineCubeTexture(SkyBoxMaterial,["skyboxTexture"]),dr.defineSampler(SkyBoxMaterial,["skyboxTextureSampler"]),Object.freeze(SkyBoxMaterial);var Ta="#redgpu_include SYSTEM_UNIFORM;\nstruct InputData { @location(0) position:vec3, @location(1) vertexNormal:vec3, @location(2) uv:vec2,\n};\nstruct OutData { @builtin(position) position:vec4, @location(0) vertexPosition:vec4,\n};\nstruct VertexUniforms { modelMatrix:mat4x4,\n};\n@group(1) @binding(0) var vertexUniforms:VertexUniforms;\n@vertex\nfn main(inputData:InputData) -> OutData { var outData:OutData; let u_projectionMatrix=systemUniforms.projectionMatrix; let u_projectionCameraMatrix=systemUniforms.projectionCameraMatrix; let u_camera=systemUniforms.camera; let u_cameraMatrix=u_camera.cameraMatrix; outData.position=u_projectionCameraMatrix * vertexUniforms.modelMatrix * vec4(inputData.position,1.0); outData.vertexPosition=vec4(inputData.position,1.0); return outData;\n}\n";const Ma=parseWGSL(Ta),wa=Ma.uniforms.vertexUniforms;class SkyBox{modelMatrix=create$4();gpuRenderInfo;#mf=!0;#oo;#pf;#Ya;#l;#ks;#Os;#gf;#xf;#_f=0;#vf=0;#bf=0;#dl;constructor(i,g){validateRedGPUContext(i),this.#l=i,this.#pf=new Box(i),this.#gf=g,this.#Ya=new SkyBoxMaterial(i,this.#gf),this.#ks=new PrimitiveState(this),this.#ks.cullMode=ei.NONE,this.#Os=new DepthStencilState(this)}get transitionDuration(){return this.#vf}get transitionElapsed(){return this.#bf}get transitionProgress(){return this.#Ya.transitionProgress}get blur(){return this.#Ya.blur}set blur(i){validatePositiveNumberRange(1,0,1),this.#Ya.blur=i}get opacity(){return this.#Ya.opacity}set opacity(i){validatePositiveNumberRange(1,0,1),this.#Ya.opacity=i}get skyboxTexture(){return this.#gf}set skyboxTexture(i){i?(this.#gf=i,this.#Ya.skyboxTexture=i):consoleAndThrowError("SkyBox requires a valid CubeTexture | IBLCubeTexture")}get transitionTexture(){return this.#xf}transition(i,g=300,x){this.#xf=i,this.#Ya.transitionTexture=i,this.#vf=g,this.#_f=performance.now(),this.#Ya.transitionAlphaTexture=x}render(i){const{currentRenderPassEncoder:g,startTime:x,view:_}=i,{indexBuffer:v}=this.#pf,{triangleCount:b,indexCount:y,format:S}=v,{gpuDevice:w,antialiasingManager:L}=this.#l,{useMSAA:k,changedMSAA:H}=L;if(this.#yf(),this.gpuRenderInfo||this.#Sf(this.#l),this.#_f)if(this.#bf=Math.max(x-this.#_f,0),this.#bf>this.#vf)this.#_f=0,this.#Ya.transitionProgress=0,this.skyboxTexture=this.#xf,this.#Ya.transitionTexture=null,this.#mf=!0;else{const i=this.#bf/this.#vf;this.#Ya.transitionProgress=i<0?0:i>1?1:i}if(this.#mf||this.#Ya.dirtyPipeline||this.#dl!==_.systemUniform_Vertex_UniformBindGroup){this.gpuRenderInfo.pipeline=this.#Tf(),this.#mf=!1,i.numDirtyPipelines++,this.#dl=_.systemUniform_Vertex_UniformBindGroup;{this.#Ya.dirtyPipeline=!1;const i=w.createRenderBundleEncoder({..._.basicRenderBundleEncoderDescriptor,label:"skybox"}),{gpuRenderInfo:g}=this,{vertexUniformBindGroup:x,pipeline:b}=g;i.setPipeline(b),i.setBindGroup(0,_.systemUniform_Vertex_UniformBindGroup),i.setVertexBuffer(0,this.#pf.vertexBuffer.gpuBuffer),i.setBindGroup(1,x),i.setBindGroup(2,this.#Ya.gpuRenderInfo.fragmentUniformBindGroup),i.setIndexBuffer(v.gpuBuffer,S),i.drawIndexed(v.indexCount,1,0,0,0),this.#oo=i.finish({label:"renderBundle skybox"})}}g.executeBundles([this.#oo]),i.num3DObjects++,i.numDrawCalls++,i.numTriangles+=b,i.numPoints+=y}#yf(){const{changedMSAA:i}=this.#l.antialiasingManager;i&&(this.#mf=!0)}#Sf(i){const{resourceManager:g}=this.#l,x=g.getGPUBindGroupLayout("SKYBOX_VERTEX_BIND_GROUP_LAYOUT")||g.createBindGroupLayout("SKYBOX_VERTEX_BIND_GROUP_LAYOUT",getVertexBindGroupLayoutDescriptorFromShaderInfo(Ma,1)),_=new ArrayBuffer(wa.arrayBufferByteLength),v=new UniformBuffer(i,_,"SKYBOX_VERTEX_UNIFORM_BUFFER","SKYBOX_VERTEX_UNIFORM_BUFFER");identity$1(this.modelMatrix),scale$4(this.modelMatrix,this.modelMatrix,[1e4,1e4,1e4]),v.writeOnlyBuffer(wa.members.modelMatrix,this.modelMatrix);const b={layout:x,label:"VERTEX_BIND_GROUP_DESCRIPTOR_SKYBOX",entries:[{binding:0,resource:{buffer:v.gpuBuffer,offset:0,size:v.size}}]},y=i.gpuDevice.createBindGroup(b);this.gpuRenderInfo=new VertexGPURenderInfo(null,Ma.shaderSourceVariant,Ma.conditionalBlocks,wa,x,v,y,this.#Tf())}#Tf(){const{resourceManager:i,gpuDevice:g,antialiasingManager:x}=this.#l,_={code:Ta},v={module:i.createGPUShaderModule("VERTEX_MODULE_SKYBOX",_),entryPoint:"main",buffers:this.#pf.gpuRenderInfo.buffers},b=i.getGPUBindGroupLayout("SKYBOX_VERTEX_BIND_GROUP_LAYOUT")||i.createBindGroupLayout("SKYBOX_VERTEX_BIND_GROUP_LAYOUT",getVertexBindGroupLayoutDescriptorFromShaderInfo(Ma,1)),y={bindGroupLayouts:[i.getGPUBindGroupLayout(ResourceManager.PRESET_GPUBindGroupLayout_System),b,this.#Ya.gpuRenderInfo.fragmentBindGroupLayout]},S={label:"PIPELINE_DESCRIPTOR_SKYBOX",layout:i.createGPUPipelineLayout("SKYBOX_PIPELINE_LAYOUT",y),vertex:v,fragment:this.#Ya.gpuRenderInfo.fragmentState,primitive:this.#ks.state,depthStencil:this.#Os.state,multisample:{count:x.useMSAA?4:1}};return g.createRenderPipeline(S)}}Object.freeze(SkyBox);var Ca=Object.freeze({__proto__:null,SkyBoxMaterial:SkyBoxMaterial});const Ra={NORMAL:0,MULTIPLY:1,LIGHTEN:2,SCREEN:3,LINEAR_DODGE:4,SUBTRACT:5,DIFFERENCE:6,EXCLUSION:7};function mixInMesh2D(i){const g=class extends i{#Mf=0;#wf=Ra.NORMAL;get blendMode(){const i=Object.entries(Ra).find(([,i])=>i===this.#wf);if(!i)throw new Error(`Invalid blendMode value:${this.#wf}`);return i[0]}set blendMode(i){let g;if("string"==typeof i){if(!(i in Ra))throw new Error(`Invalid blendMode key:${i}`);g=Ra[i]}else{if("number"!=typeof i||!Object.values(Ra).includes(i))throw new Error(`Invalid blendMode:${i}`);g=i}this.#wf=g,this.#Cf(g)}get rotation(){return this.#Mf}set rotation(i){this.#Mf=i,super.rotationZ=i}setScale(i,g){g=g??i,super.setScale(i,g,1)}setPosition(i,g){g=g??i,super.setPosition(i,g,0)}setRotation(i){this.rotation=i}#Cf(i){const{blendColorState:g,blendAlphaState:x}=this._material;switch(i){case Ra.NORMAL:g.operation=pr.ADD,g.srcFactor=mr.SRC_ALPHA,g.dstFactor=mr.ONE_MINUS_SRC_ALPHA,x.operation=pr.ADD,x.srcFactor=mr.SRC_ALPHA,x.dstFactor=mr.ONE_MINUS_SRC_ALPHA;break;case Ra.MULTIPLY:g.operation=pr.ADD,g.srcFactor=mr.ONE_MINUS_DST_ALPHA,g.dstFactor=mr.ONE_MINUS_SRC_ALPHA,x.operation=pr.ADD,x.srcFactor=mr.SRC_ALPHA,x.dstFactor=mr.ONE_MINUS_SRC_ALPHA;break;case Ra.LIGHTEN:g.operation=pr.MAX,g.srcFactor=mr.ONE,g.dstFactor=mr.ONE,x.operation=pr.ADD,x.srcFactor=mr.SRC_ALPHA,x.dstFactor=mr.ONE_MINUS_SRC_ALPHA;break;case Ra.SCREEN:g.operation=pr.ADD,g.srcFactor=mr.ONE,g.dstFactor=mr.ONE_MINUS_SRC,x.operation=pr.ADD,x.srcFactor=mr.SRC_ALPHA,x.dstFactor=mr.ONE_MINUS_SRC_ALPHA;break;case Ra.LINEAR_DODGE:g.operation=pr.ADD,g.srcFactor=mr.ONE,g.dstFactor=mr.ONE,x.operation=pr.ADD,x.srcFactor=mr.SRC_ALPHA,x.dstFactor=mr.ONE;break;case Ra.SUBTRACT:g.operation=pr.REVERSE_SUBTRACT,g.srcFactor=mr.SRC_ALPHA,g.dstFactor=mr.ONE_MINUS_SRC_ALPHA,x.operation=pr.REVERSE_SUBTRACT,x.srcFactor=mr.ONE,x.dstFactor=mr.ONE;break;case Ra.DIFFERENCE:g.operation=pr.SUBTRACT,g.srcFactor=mr.ONE,g.dstFactor=mr.ONE,x.operation=pr.SUBTRACT,x.srcFactor=mr.ONE,x.dstFactor=mr.ONE;break;case Ra.EXCLUSION:g.operation=pr.ADD,g.srcFactor=mr.ONE_MINUS_DST_ALPHA,g.dstFactor=mr.ONE_MINUS_SRC_ALPHA,x.operation=pr.ADD,x.srcFactor=mr.ONE,x.dstFactor=mr.ONE;break;default:console.warn(`Unsupported blend mode:${i}`)}}};return Object.defineProperty(g.prototype,"is2DMeshType",{value:!0,writable:!1}),g}var Pa=Object.freeze({__proto__:null,LODManager:LODManager,MeshBase:MeshBase,Object3DContainer:Object3DContainer,VertexGPURenderInfo:VertexGPURenderInfo,createMeshVertexUniformBuffers:createMeshVertexUniformBuffers,mixInMesh2D:mixInMesh2D}),Ba=Object.freeze({__proto__:null,AView:AView,RenderViewStateData:RenderViewStateData,ViewRenderTextureManager:ViewRenderTextureManager,ViewTransform:ViewTransform});class View2D extends View3D{constructor(i,g,x){super(i,g,new Camera2D,x)}}Object.freeze(View2D);class GroupBase extends Object3DContainer{modelMatrix=create$4();localMatrix=create$4();#f;#h;#Vs;#Ot=0;#Vt=0;#Nt=0;#Fs=[0,0,0];#Hs=0;#zs=0;#$s=0;#Xs=1;#js=1;#Ys=1;#qs=[1,1,1];#Di=0;#Ui=0;#Li=0;#Ws=[0,0,0];#Rf=!0;constructor(i){super(),i&&(this.name=i)}get dirtyTransform(){return this.#Rf}set dirtyTransform(i){this.#Rf=i}get name(){return this.#f||(this.#f=InstanceIdGenerator.getNextId(this.constructor)),this.#h||`${this.constructor.name} Instance ${this.#f}`}set name(i){this.#h=i}get parent(){return this.#Vs}set parent(i){this.#Vs=i}get pivotX(){return this.#Hs}set pivotX(i){this.#Hs=i,this.dirtyTransform=!0}get pivotY(){return this.#zs}set pivotY(i){this.#zs=i,this.dirtyTransform=!0}get pivotZ(){return this.#$s}set pivotZ(i){this.#$s=i,this.dirtyTransform=!0}get x(){return this.#Ot}set x(i){this.#Ot=this.#Fs[0]=i,this.dirtyTransform=!0}get y(){return this.#Nt}set y(i){this.#Nt=this.#Fs[1]=i,this.dirtyTransform=!0}get z(){return this.#Vt}set z(i){this.#Vt=this.#Fs[2]=i,this.dirtyTransform=!0}get position(){return this.#Fs}get scaleX(){return this.#Xs}set scaleX(i){this.#Xs=this.#qs[0]=i,this.dirtyTransform=!0}get scaleY(){return this.#js}set scaleY(i){this.#js=this.#qs[1]=i,this.dirtyTransform=!0}get scaleZ(){return this.#Ys}set scaleZ(i){this.#Ys=this.#qs[2]=i,this.dirtyTransform=!0}get scale(){return this.#Fs}get rotationX(){return this.#Di}set rotationX(i){this.#Di=this.#Ws[0]=i,this.dirtyTransform=!0}get rotationY(){return this.#Ui}set rotationY(i){this.#Ui=this.#Ws[1]=i,this.dirtyTransform=!0}get rotationZ(){return this.#Li}set rotationZ(i){this.#Li=this.#Ws[2]=i,this.dirtyTransform=!0}get rotation(){return this.#Ws}setScale(i,g,x){g=g??i,x=x??i;const _=this.#qs;this.#Xs=_[0]=i,this.#js=_[1]=g,this.#Ys=_[2]=x,this.dirtyTransform=!0}setPosition(i,g,x){g=g??i,x=x??i;const _=this.#Fs;this.#Ot=_[0]=i,this.#Nt=_[1]=g,this.#Vt=_[2]=x,this.dirtyTransform=!0}setRotation(i,g,x){g=g??i,x=x??i;const _=this.#Ws;this.#Di=_[0]=i,this.#Ui=_[1]=g,this.#Li=_[2]=x,this.dirtyTransform=!0}render(i){const{view:g,isScene2DMode:x}=i;let _;x&&(this.#Vt=0,this.#$s=0),this.dirtyTransform&&(_=!0,updateObject3DMatrix(this,g)),this.dirtyTransform&&(_=!0,this.dirtyTransform=!1),i.num3DGroups++;const{children:v}=this;let b=0;const y=v.length;for(;b, tintBlendMode:u32,\n};\n@group(2) @binding(0) var uniforms:Uniforms;\n@group(2) @binding(1) var diffuseTextureSampler:sampler;\n@group(2) @binding(2) var diffuseTexture:texture_2d;\nstruct InputData { @builtin(position) position:vec4, @location(0) vertexPosition:vec3, @location(1) vertexNormal:vec3, @location(2) uv:vec2, @location(7) currentClipPos:vec4, @location(8) prevClipPos:vec4, @location(11) combinedOpacity:f32, @location(12) motionVector:vec3, @location(13) shadowPos:vec3, @location(15) @interpolate(flat) pickingId:vec4,\n};\n@fragment\nfn main(inputData:InputData) -> FragmentOutput { var output:FragmentOutput; var finalColor:vec4=vec4(0.0); #redgpu_if diffuseTexture finalColor=textureSample(diffuseTexture,diffuseTextureSampler,inputData.uv); #redgpu_endIf let alpha2D=select(finalColor.a,1.0,systemUniforms.isView3D==1u); finalColor=vec4(finalColor.rgb * alpha2D,finalColor.a * uniforms.opacity * inputData.combinedOpacity); #redgpu_if useTint finalColor=calcTintBlendMode(finalColor,uniforms.tintBlendMode,uniforms.tint); #redgpu_endIf if (systemUniforms.isView3D==1 && finalColor.a==0.0) { discard; } output.color=finalColor; output.gBufferMotionVector=vec4(calculateMotionVector(inputData.currentClipPos,inputData.prevClipPos),0.0,1.0 ); return output;\n};\n");class BitmapMaterial extends AUVTransformBaseMaterial{dirtyPipeline=!1;constructor(i,g,x){super(i,"BITMAP_MATERIAL",Da,2),x&&(this.name=x),this.diffuseTexture=g,this.diffuseTextureSampler=new Sampler(this.redGPUContext),this.initGPURenderInfos()}}dr.defineByPreset(BitmapMaterial,[dr.PRESET_TEXTURE.DIFFUSE_TEXTURE,dr.PRESET_SAMPLER.DIFFUSE_TEXTURE_SAMPLER]),Object.freeze(BitmapMaterial);var Ua="#redgpu_include SYSTEM_UNIFORM;\n#redgpu_include getBillboardMatrix;\nstruct MatrixList{ modelMatrix:mat4x4, normalModelMatrix:mat4x4,\n}\nstruct VertexUniforms { matrixList:MatrixList, pickingId:u32, useBillboardPerspective:u32, useBillboard:u32, combinedOpacity:f32,\n};\n@group(1) @binding(0) var vertexUniforms:VertexUniforms;\nstruct InputData { @location(0) a_position:vec3, @location(1) a_normal:vec3, @location(2) a_uv:vec2, @location(3) position:vec3, @location(4) alpha:f32, @location(5) rotation:vec3, @location(6) scale:f32,\n};\nstruct OutputData { @builtin(position) position:vec4, @location(0) vertexPosition:vec3, @location(1) vertexNormal:vec3, @location(2) uv:vec2, @location(7) currentClipPos:vec4, @location(8) prevClipPos:vec4, @location(11) combinedOpacity:f32, @location(12) motionVector:vec3, @location(13) shadowPos:vec3, @location(14) @interpolate(flat) receiveShadow:f32, @location(15) @interpolate(flat) pickingId:vec4,\n};\nfn mat4_inverse(a:mat4x4) -> mat4x4 { var a00:f32=a[0][0]; var a01:f32=a[0][1]; var a02:f32=a[0][2]; var a03:f32=a[0][3]; var a10:f32=a[1][0]; var a11:f32=a[1][1]; var a12:f32=a[1][2]; var a13:f32=a[1][3]; var a20:f32=a[2][0]; var a21:f32=a[2][1]; var a22:f32=a[2][2]; var a23:f32=a[2][3]; var a30:f32=a[3][0]; var a31:f32=a[3][1]; var a32:f32=a[3][2]; var a33:f32=a[3][3]; var b00:f32=a00*a11 - a01*a10; var b01:f32=a00*a12 - a02*a10; var b02:f32=a00*a13 - a03*a10; var b03:f32=a01*a12 - a02*a11; var b04:f32=a01*a13 - a03*a11; var b05:f32=a02*a13 - a03*a12; var b06:f32=a20*a31 - a21*a30; var b07:f32=a20*a32 - a22*a30; var b08:f32=a20*a33 - a23*a30; var b09:f32=a21*a32 - a22*a31; var b10:f32=a21*a33 - a23*a31; var b11:f32=a22*a33 - a23*a32; var det:f32=b00*b11 - b01*b10 + b02*b09 + b03*b08 - b04*b07 + b05*b06; if (det !=0.0) { det=1.0/det; return mat4x4( (a11*b11 - a12*b10 + a13*b09) * det, (a02*b10 - a01*b11 - a03*b09) * det, (a31*b05 - a32*b04 + a33*b03) * det, (a22*b04 - a21*b05 - a23*b03) * det, (a12*b08 - a10*b11 - a13*b07) * det, (a00*b11 - a02*b08 + a03*b07) * det, (a32*b02 - a30*b05 - a33*b01) * det, (a20*b05 - a22*b02 + a23*b01) * det, (a10*b10 - a11*b08 + a13*b06) * det, (a01*b08 - a00*b10 - a03*b06) * det, (a30*b04 - a31*b02 + a33*b00) * det, (a21*b02 - a20*b04 - a23*b00) * det, (a11*b07 - a10*b09 - a12*b06) * det, (a00*b09 - a01*b07 + a02*b06) * det, (a31*b01 - a30*b03 - a32*b00) * det, (a20*b03 - a21*b01 + a22*b00) * det ); } return mat4x4( 0.0,0.0,0.0,0.0, 0.0,0.0,0.0,0.0, 0.0,0.0,0.0,0.0, 0.0,0.0,0.0,0.0 );\n}\nfn rotationMTX(t:vec3)->mat4x4\n{ var s:f32=sin(t.x); var c:f32=cos(t.x); var m1=mat4x4(1,0,0,0, 0,c,-s,0, 0,s,c,0, 0,0,0,1); s=sin(t[1]);c=cos(t[1]); var m2=mat4x4(c,0,s,0, 0,1,0,0, -s,0,c,0, 0,0,0,1); s=sin(t[2]);c=cos(t[2]); var m3=mat4x4(c,-s,0,0, s,c,0,0, 0,0,1,0, 0,0,0,1); return m1 * m2 * m3;\n}\n@vertex\nfn main( inputData:InputData) -> OutputData { var output:OutputData; let u_projectionMatrix=systemUniforms.projectionMatrix; let u_projectionCameraMatrix=systemUniforms.projectionCameraMatrix; let u_resolution=systemUniforms.resolution; let u_camera=systemUniforms.camera; let u_cameraMatrix=u_camera.cameraMatrix; let u_cameraPosition=u_camera.cameraPosition; let u_modelMatrix=vertexUniforms.matrixList.modelMatrix; let u_normalModelMatrix=vertexUniforms.matrixList.normalModelMatrix; let u_useBillboardPerspective=vertexUniforms.useBillboardPerspective==1u; let u_useBillboard=vertexUniforms.useBillboard==1u; let input_position=inputData.position; var position:vec4; var normalPosition:vec4; var scaleMTX=mat4x4( inputData.scale,0,0,0, 0,inputData.scale,0,0, 0,0,inputData.scale,0, 0,0,0,1 ); var translateTX=mat4x4( 1,0,0,0, 0,1,0,0, 0,0,1,0, inputData.position.x,inputData.position.y,inputData.position.z,1 ); var temp:mat4x4; if(u_useBillboard){ var rotateMTX2=rotationMTX( vec3(0,0,inputData.rotation.z) ); temp=translateTX * rotateMTX2; position=rotateMTX2 * vec4(inputData.a_position,1); output.position=u_projectionMatrix * getBillboardMatrixNoScaleRatio( u_cameraMatrix,temp ) * scaleMTX * position; }else{ var rotateMTX=rotationMTX( inputData.rotation ); temp=translateTX * rotateMTX * scaleMTX; position=temp * vec4(inputData.a_position,1); output.position=u_projectionCameraMatrix * position; } output.vertexPosition=position.xyz; output.vertexNormal=(transpose(mat4_inverse(temp) ) * vec4(inputData.a_normal,1.0)).xyz; output.uv=inputData.a_uv; output.combinedOpacity=inputData.alpha; return output;\n}\nstruct OutputShadowData { @builtin(position) position:vec4,\n};\n";const La=parseWGSL(Ua),Aa=La.uniforms.vertexUniforms;class ParticleEmitter extends Mesh{#Pf=1e3;#Bf=5e3;#If=0;#Ef=0;#Df=0;#Uf=0;#Lf=0;#Af=0;#Gf=-5;#kf=-5;#Of=-5;#Nf=5;#Vf=5;#Ff=5;#Hf=1;#zf=1;#$f=1;#Kf=1;#Xf=0;#jf=1;#Yf=0;#qf=0;#Wf=-360;#Zf=-360;#Jf=-360;#Qf=360;#ed=360;#td=360;#nd=-360;#rd=-360;#id=-360;#ad=360;#sd=360;#od=360;#ud=Ea.CubicOut;#ld=Ea.CubicOut;#cd=Ea.CubicOut;#hd=Ea.Linear;#fd=Ea.Linear;#dd=Ea.CubicOut;#md=Ea.CubicOut;#pd=Ea.CubicOut;#gd;#xd;#_d;#Kn;#vd;#bd=2e3;constructor(i){super(i),this.geometry=new Plane(i),this.material=new BitmapMaterial(i),this.ignoreFrustumCulling=!0,this.useBillboard=!0}get vertexStateBuffers(){return[{arrayStride:32,stepMode:"vertex",attributes:[{shaderLocation:0,offset:0,format:"float32x3"},{shaderLocation:1,offset:12,format:"float32x3"},{shaderLocation:2,offset:24,format:"float32x2"}]},{arrayStride:48,stepMode:"instance",attributes:[{shaderLocation:3,offset:16,format:"float32x3"},{shaderLocation:4,offset:28,format:"float32"},{shaderLocation:5,offset:32,format:"float32x3"},{shaderLocation:6,offset:44,format:"float32"}]}]}get particleNum(){return this.#bd}set particleNum(i){this.#bd=Math.max(Math.min(i,5e5),1),this.#gd||this.#ne(),this.#yd()}get minLife(){return this.#Pf}set minLife(i){this.#Pf=i}get maxLife(){return this.#Bf}set maxLife(i){this.#Bf=i}get minStartX(){return this.#If}set minStartX(i){this.#If=i}get minStartY(){return this.#Ef}set minStartY(i){this.#Ef=i}get minStartZ(){return this.#Df}set minStartZ(i){this.#Df=i}get maxStartX(){return this.#Uf}set maxStartX(i){this.#Uf=i}get maxStartY(){return this.#Lf}set maxStartY(i){this.#Lf=i}get maxStartZ(){return this.#Af}set maxStartZ(i){this.#Af=i}get minEndX(){return this.#Gf}set minEndX(i){this.#Gf=i}get minEndY(){return this.#kf}set minEndY(i){this.#kf=i}get minEndZ(){return this.#Of}set minEndZ(i){this.#Of=i}get maxEndX(){return this.#Nf}set maxEndX(i){this.#Nf=i}get maxEndY(){return this.#Vf}set maxEndY(i){this.#Vf=i}get maxEndZ(){return this.#Ff}set maxEndZ(i){this.#Ff=i}get minStartAlpha(){return this.#Hf}set minStartAlpha(i){this.#Hf=i}get maxStartAlpha(){return this.#zf}set maxStartAlpha(i){this.#zf=i}get minEndAlpha(){return this.#$f}set minEndAlpha(i){this.#$f=i}get maxEndAlpha(){return this.#Kf}set maxEndAlpha(i){this.#Kf=i}get minStartScale(){return this.#Xf}set minStartScale(i){this.#Xf=i}get maxStartScale(){return this.#jf}set maxStartScale(i){this.#jf=i}get minEndScale(){return this.#Yf}set minEndScale(i){this.#Yf=i}get maxEndScale(){return this.#qf}set maxEndScale(i){this.#qf=i}get minStartRotationX(){return this.#Wf}set minStartRotationX(i){this.#Wf=i}get minStartRotationY(){return this.#Zf}set minStartRotationY(i){this.#Zf=i}get minStartRotationZ(){return this.#Jf}set minStartRotationZ(i){this.#Jf=i}get maxStartRotationX(){return this.#Qf}set maxStartRotationX(i){this.#Qf=i}get maxStartRotationY(){return this.#ed}set maxStartRotationY(i){this.#ed=i}get maxStartRotationZ(){return this.#td}set maxStartRotationZ(i){this.#td=i}get minEndRotationX(){return this.#nd}set minEndRotationX(i){this.#nd=i}get minEndRotationY(){return this.#rd}set minEndRotationY(i){this.#rd=i}get minEndRotationZ(){return this.#id}set minEndRotationZ(i){this.#id=i}get maxEndRotationX(){return this.#ad}set maxEndRotationX(i){this.#ad=i}get maxEndRotationY(){return this.#sd}set maxEndRotationY(i){this.#sd=i}get maxEndRotationZ(){return this.#od}set maxEndRotationZ(i){this.#od=i}get easeX(){return this.#ud}set easeX(i){this.#ud=i}get easeY(){return this.#ld}set easeY(i){this.#ld=i}get easeZ(){return this.#cd}set easeZ(i){this.#cd=i}get easeAlpha(){return this.#hd}set easeAlpha(i){this.#hd=i}get easeScale(){return this.#fd}set easeScale(i){this.#fd=i}get easeRotationX(){return this.#dd}set easeRotationX(i){this.#dd=i}get easeRotationY(){return this.#md}set easeRotationY(i){this.#md=i}get easeRotationZ(){return this.#pd}set easeRotationZ(i){this.#pd=i}get particleBuffers(){return this.#xd}render(i){this.#gd||this.#ne(),this.#Sd(i.timestamp),super.render(i)}createCustomMeshVertexShaderModule=()=>this.createMeshVertexShaderModuleBASIC("VERTEX_MODULE_PARTICLE_EMITTER",La,Aa,Ua);#ne(){this.#_d=new Float32Array(46);let i={size:this.#_d.byteLength,usage:GPUBufferUsage.UNIFORM|GPUBufferUsage.COPY_DST};const{gpuDevice:g}=this.redGPUContext;this.#gd=g.createBuffer(i),g.queue.writeBuffer(this.#gd,0,this.#_d),this.#yd(),this.depthStencilState.depthWriteEnabled=!1}#yd(){this.dirtyPipeline=!0;let i=this.redGPUContext;const g=new Float32Array(12*this.#bd),x=new Float32Array(12*this.#bd),_=new Float32Array(12*this.#bd),v=new Float32Array(4*this.#bd),b=new Float32Array(4*this.#bd),y=performance.now(),S=this.localToWorld(this.x,this.y,this.z);for(let i=0;i{const _=i.gpuDevice.createBuffer({size:g.byteLength,usage:GPUBufferUsage.COPY_DST|GPUBufferUsage.COPY_SRC|GPUBufferUsage.VERTEX|GPUBufferUsage.STORAGE});i.gpuDevice.queue.writeBuffer(_,0,g),this.#xd.push(_),w?.length&©GPUBuffer(i.gpuDevice,w[x],_)}),w&&w.forEach(i=>i.destroy());let k={code:"\nstruct Info { startValue:f32, endValue:f32, easeType:f32, birthCenterValue:f32\n};\nstruct InfoGroup { infoX:Info, infoY:Info, infoZ:Info,\n};\nstruct Particle { startTime:f32, life:f32, valuePosition:vec3, valueAlpha:f32, valueRotation:vec3, valueScale:f32,\n};\nstruct SimParams { time:f32, currentPositionX:f32,currentPositionY:f32,currentPositionZ:f32, minLife:f32,maxLife:f32, minStartX:f32,maxStartX:f32,minEndX:f32,maxEndX:f32,easeX:f32, minStartY:f32,maxStartY:f32,minEndY:f32,maxEndY:f32,easeY:f32, minStartZ:f32,maxStartZ:f32,minEndZ:f32,maxEndZ:f32,easeZ:f32, minStartAlpha:f32,maxStartAlpha:f32,minEndAlpha:f32,maxEndAlpha:f32,easeAlpha:f32, minStartScale:f32,maxStartScale:f32,minEndScale:f32,maxEndScale:f32,easeScale:f32, minStartRotationX:f32,maxStartRotationX:f32,minEndRotationX:f32,maxEndRotationX:f32,easeRotationX:f32, minStartRotationY:f32,maxStartRotationY:f32,minEndRotationY:f32,maxEndRotationY:f32,easeRotationY:f32, minStartRotationZ:f32,maxStartRotationZ:f32,minEndRotationZ:f32,maxEndRotationZ:f32,easeRotationZ:f32,\n};\n@group(0) @binding(0) var params:SimParams;\n@group(0) @binding(1) var particles:array;\n@group(0) @binding(2) var infoPosition:array;\n@group(0) @binding(3) var infoRotation:array;\n@group(0) @binding(4) var infoScale:array;\n@group(0) @binding(5) var infoAlpha:array;\nconst PI:f32=3.141592653589793;\nconst HPI:f32=PI * 0.5;\nconst PI2:f32=PI * 2.0;\nfn calEasing(n:f32,easingType:f32) -> f32 { var m:f32=n; let easingInt:i32=i32(easingType); switch (easingInt) { case 0:{ m=m;} case 1:{ m=m * m * m * m * m;} case 2:{ m -=1.0; m=(m * m * m * m * m) + 1.0; } case 3:{ if(m * 2.0 < 1.0) { m *=2.0; m=m * m * m * m * m * 0.5; } else { m=m * 2.0 - 2.0; m=0.5 * (m * m * m * m * m + 2.0); } } case 4:{ m=m * m * (m * 1.70158 + m - 1.70158);} case 5:{ m -=1.0; m=m * m * (m * 1.70158 + m + 1.70158) + 1.0; } case 6:{ if(m * 2.0 < 1.0) { m *=2.0; m=0.5 * m * m * (m * 1.70158 + m - 1.70158); } else { m=m * 2.0 - 2.0; m=0.5 * m * m * (m * 1.70158 + m + 1.70158) + 1.0; } } case 7:{ m=-1.0 * (sqrt(1.0 - m * m) - 1.0);} case 8:{ m -=1.0; m=sqrt(1.0 - m * m); } case 9:{ if(m * 2.0 < 1.0) { m *=2.0; m=-0.5 * (sqrt(1.0 - m * m) - 1.0); } else { m=m * 2.0 - 2.0; m=0.5 * sqrt(1.0 - m * m) + 0.5; } } case 10:{ m=m * m * m;} case 11:{ m -=1.0; m=m * m * m + 1.0; } case 12:{ if(m * 2.0 < 1.0) { m *=2.0; m=m * m * m * 0.5; } else { m=m * 2.0 - 2.0; m=0.5 * (m * m * m + 2.0); } } case 13:{ if (m==0.0) { m=0.0;} else { m=pow(2.0,10.0 * (m - 1.0));} } case 14:{ if (m==1.0) { m=1.0;} else { m=-pow(2.0,-10.0 * m) + 1.0;} } case 15:{ if(m * 2.0 < 1.0) { if (m==0.0) { m=0.0;} else { m *=2.0;m=0.5 * pow(2.0,10.0 * (m - 1.0));} } else { if (m==2.0) { m=1.0;} else { m=m * 2.0 - 1.0;m=-0.5 * pow(2.0,-10.0 * m) + 1.0;} } } case 16:{ m=m * m;} case 17:{ m=(2.0 - m) * m;} case 18:{ if(m * 2.0 < 1.0) { m *=2.0; m=m * m * 0.5; } else { m=2.0 - m; m=0.5 * (m * m + 1.0); } } case 19:{ m=m * m * m * m;} case 20:{ m -=1.0; m=1.0 - (m * m * m * m); } case 21:{ if(m * 2.0 < 1.0) { m *=2.0; m=m * m * m * m * 0.5; } else { m=m * 2.0 - 2.0; m=1.0 - (m * m * m * m * 0.5); } } case 22:{ m=-cos(m * HPI) + 1.0;} case 23:{ m=sin(m * HPI);} case 24:{ m=(-cos(m * PI) + 1.0) * 0.5;} case 25:{ if (m==0.0) { m=0.0;} else if (m==1.0) { m=1.0;} else { m -=1.0;m=-1.0 * pow(2.0,10.0 * m) * sin((m - 0.075) * (PI2)/0.3);} } case 26:{ if (m==0.0) { m=0.0; } else if (m==1.0) { m=1.0; } else { m -=1.0; m=-pow(2.0,10.0 * m) * sin((m - 0.075) * PI2/0.3); } } case 27:{ if (m==0.0) { m=0.0; } else if (m==1.0) { m=1.0; } else { m=pow(2.0,-10.0 * m) * sin((m - 0.075) * PI2/0.3) + 1.0; } } default:{ m=m;} } return m;\n}\nfn rand(n:f32) -> f32 { return fract(sin(n) * 43758.5453123);\n}\nfn randomRange(min:f32,max:f32,v:f32)->f32\n{ var newValue:f32=rand(v); return (newValue * (max-min)) + min;\n}\nfn compute_value(tInfo:Info,lifeRatio:f32) -> f32 { return tInfo.startValue + ((tInfo.endValue - tInfo.startValue) * calEasing(lifeRatio,tInfo.easeType));\n}\n@compute @workgroup_size(256,1,1)\nfn main( @builtin(global_invocation_id) global_id:vec3 ) { let index:u32=(global_id.x); let age:f32=(params.time - particles[index].startTime); var lifeRatio:f32=(age/particles[index].life); if (lifeRatio >=1.0 ) { let uuid:f32=(params.time + f32(index)); particles[index].startTime=params.time; particles[index].life=randomRange( params.minLife,params.maxLife,uuid ); infoPosition[index].infoX.startValue=randomRange( params.minStartX + params.currentPositionX,params.maxStartX + params.currentPositionX,(uuid + 1.0) ); infoPosition[index].infoX.endValue=randomRange( params.minEndX + params.currentPositionX,params.maxEndX + params.currentPositionX,(uuid + 2.0) ); infoPosition[index].infoX.easeType=params.easeX; infoPosition[index].infoX.birthCenterValue=params.currentPositionX; infoPosition[index].infoY.startValue=randomRange( params.minStartY +params.currentPositionY,params.maxStartY+params.currentPositionY,(uuid + 3.0) ); infoPosition[index].infoY.endValue=randomRange( params.minEndY+params.currentPositionY,params.maxEndY+params.currentPositionY,(uuid + 4.0) ); infoPosition[index].infoY.easeType=params.easeY; infoPosition[index].infoY.birthCenterValue=params.currentPositionY; infoPosition[index].infoZ.startValue=randomRange( params.minStartZ+params.currentPositionZ,params.maxStartZ+params.currentPositionZ,(uuid + 5.0) ); infoPosition[index].infoZ.endValue=randomRange( params.minEndZ+params.currentPositionZ,params.maxEndZ+params.currentPositionZ,(uuid + 6.0) ); infoPosition[index].infoZ.easeType=params.easeZ; infoPosition[index].infoZ.birthCenterValue=params.currentPositionZ; infoAlpha[index].startValue=randomRange( params.minStartAlpha,params.maxStartAlpha,(uuid + 7.0) ); infoAlpha[index].endValue=randomRange( params.minEndAlpha,params.maxEndAlpha,(uuid + 8.0) ); infoAlpha[index].easeType=params.easeAlpha; infoScale[index].startValue=randomRange( params.minStartScale,params.maxStartScale,(uuid + 9.0) ); infoScale[index].endValue=randomRange( params.minEndScale,params.maxEndScale,(uuid + 10.0)); infoScale[index].easeType=params.easeScale; infoRotation[index].infoX.startValue=randomRange( params.minStartRotationX,params.maxStartRotationX,(uuid + 11.0)); infoRotation[index].infoX.endValue=randomRange( params.minEndRotationX,params.maxEndRotationX,(uuid + 12.0)); infoRotation[index].infoX.easeType=params.easeRotationX; infoRotation[index].infoY.startValue=randomRange( params.minStartRotationY,params.maxStartRotationY,(uuid + 13.0)); infoRotation[index].infoY.endValue=randomRange( params.minEndRotationY,params.maxEndRotationY,(uuid + 14.0)); infoRotation[index].infoY.easeType=params.easeRotationY; infoRotation[index].infoZ.startValue=randomRange( params.minStartRotationZ,params.maxStartRotationZ,(uuid + 15.0)); infoRotation[index].infoZ.endValue=randomRange( params.minEndRotationZ,params.maxEndRotationZ,(uuid + 16.0)); infoRotation[index].infoZ.easeType=params.easeRotationZ; lifeRatio=0.0; } var targetInfo:Info; let targetParticle=particles[index]; targetInfo=infoPosition[index].infoX; particles[index].valuePosition.x=compute_value(targetInfo,lifeRatio); targetInfo=infoPosition[index].infoY; particles[index].valuePosition.y=compute_value(targetInfo,lifeRatio); targetInfo=infoPosition[index].infoZ; particles[index].valuePosition.z=compute_value(targetInfo,lifeRatio); targetInfo=infoAlpha[index]; particles[index].valueAlpha=compute_value(targetInfo,lifeRatio); targetInfo=infoScale[index]; particles[index].valueScale=compute_value(targetInfo,lifeRatio); targetInfo=infoRotation[index].infoX; particles[index].valueRotation.x=compute_value(targetInfo,lifeRatio) * PI/180.0; targetInfo=infoRotation[index].infoY; particles[index].valueRotation.y=compute_value(targetInfo,lifeRatio) * PI/180.0; targetInfo=infoRotation[index].infoZ; particles[index].valueRotation.z=compute_value(targetInfo,lifeRatio) * PI/180.0;\n}\n"},H=i.resourceManager.createGPUShaderModule("PARTICLE_EMITTER_MODULE",k);const z=[{binding:0,visibility:GPUShaderStage.COMPUTE,buffer:{type:"uniform"}}],q=[{binding:0,resource:{buffer:this.#gd,offset:0,size:this.#_d.byteLength}}];L.forEach((i,g)=>{z.push({binding:g+1,visibility:GPUShaderStage.COMPUTE,buffer:{type:"storage"}}),q.push({binding:g+1,resource:{buffer:this.#xd[g],offset:0,size:i.byteLength}})});const W=i.gpuDevice.createBindGroupLayout({entries:z}),be=i.gpuDevice.createPipelineLayout({bindGroupLayouts:[W]});this.#vd=i.gpuDevice.createBindGroup({label:"PARTICLE_EMITTER_BIND_GROUP",layout:W,entries:q}),this.#Kn=i.gpuDevice.createComputePipeline({label:"PARTICLE_EMITTER_PIPELINE",layout:be,compute:{module:H,entryPoint:"main"}})}#Sd(i){const g=this.localToWorld(this.x,this.y,this.z);this.#_d.set([i,...g,this.#Pf,this.#Bf,this.#If,this.#Uf,this.#Gf,this.#Nf,this.#ud,this.#Ef,this.#Lf,this.#kf,this.#Vf,this.#ld,this.#Df,this.#Af,this.#Of,this.#Ff,this.#cd,this.#Hf,this.#zf,this.#$f,this.#Kf,this.#hd,this.#Xf,this.#jf,this.#Yf,this.#qf,this.#fd,this.#Wf,this.#Qf,this.#nd,this.#ad,this.#dd,this.#Zf,this.#ed,this.#rd,this.#sd,this.#md,this.#Jf,this.#td,this.#id,this.#od,this.#pd],0);const{gpuDevice:x}=this.redGPUContext;x.queue.writeBuffer(this.#gd,0,this.#_d);const _=x.createCommandEncoder({label:"PARTICLE_EMITTER_COMPUTE_COMMAND_ENCODER"}),v=_.beginComputePass({label:"PARTICLE_EMITTER_COMPUTE_PASS"});v.setPipeline(this.#Kn),v.setBindGroup(0,this.#vd),v.dispatchWorkgroups(Math.ceil(this.#bd/256)),v.end(),x.queue.submit([_.finish()])}}Object.defineProperty(ParticleEmitter.prototype,"meshType",{value:Gr.PARTICLE,writable:!1}),Er.defineByPreset(ParticleEmitter,[Er.PRESET_BOOLEAN.USE_BILLBOARD]),Er.definePositiveNumber(ParticleEmitter,[]),Object.freeze(ParticleEmitter);const Ga=mixInMesh2D(Mesh);class Sprite2D extends Ga{#Bt=1;#It=1;constructor(i,g){super(i,new Plane(i,1,1,1,1,1,!0),g),this.primitiveState.cullMode=ei.FRONT}get width(){return this.#Bt}set width(i){validatePositiveNumberRange(i),this.#Bt=i,this.dirtyTransform=!0}get height(){return this.#It}set height(i){validatePositiveNumberRange(i),this.#It=i,this.dirtyTransform=!0}setSize(i,g){this.width=i,this.height=void 0!==g?g:i}}Object.freeze(Sprite2D);var ka="#redgpu_include SYSTEM_UNIFORM;\n#redgpu_include getBillboardMatrix;\n#redgpu_include calcBillboard;\n#redgpu_include billboardPicking;\n#redgpu_include billboardShadow;\nstruct MatrixList{ modelMatrix:mat4x4, normalModelMatrix:mat4x4,\n}\nstruct VertexUniforms { matrixList:MatrixList, pickingId:u32, useBillboard:u32, usePixelSize:u32, pixelSize:f32, _renderRatioX:f32, _renderRatioY:f32, combinedOpacity:f32,\n};\n@group(1) @binding(0) var vertexUniforms:VertexUniforms;\nstruct InputData { @location(0) position:vec3, @location(1) vertexNormal:vec3, @location(2) uv:vec2,\n};\nstruct OutputData { @builtin(position) position:vec4, @location(0) vertexPosition:vec3, @location(1) vertexNormal:vec3, @location(2) uv:vec2, @location(7) currentClipPos:vec4, @location(8) prevClipPos:vec4, @location(11) combinedOpacity:f32, @location(12) motionVector:vec3, @location(13) shadowPos:vec3, @location(15) @interpolate(flat) pickingId:vec4,\n};\n@vertex\nfn main(inputData:InputData) -> OutputData { var output:OutputData; let billboardResult=calcBillboard( inputData.position, inputData.vertexNormal, vertexUniforms.matrixList.modelMatrix, systemUniforms.camera.cameraMatrix, systemUniforms.projectionMatrix, systemUniforms.resolution, vertexUniforms.useBillboard, vertexUniforms.usePixelSize, vertexUniforms.pixelSize, vertexUniforms._renderRatioX, vertexUniforms._renderRatioY ); output.position=billboardResult.position; output.vertexPosition=billboardResult.vertexPosition; output.vertexNormal=billboardResult.vertexNormal; output.uv=inputData.uv; output.combinedOpacity=vertexUniforms.combinedOpacity; return output;\n}\n";const Oa=parseWGSL(ka),Na=Oa.uniforms.vertexUniforms;class Sprite3D extends Mesh{#qo=1;#Wo=1;#Zo=1;#Td=0;#Jo=!1;constructor(i,g,x){super(i),this._geometry=x||new Plane(i),this._material=g,this._material&&(this._material.transparent=!0),this.dirtyPipeline=!0,this.dirtyTransform=!0,this.primitiveState.cullMode=ei.NONE}get worldSize(){return this.#Zo}set worldSize(i){this.#Zo!==i&&(this.#Zo=i,this.#Qo())}get usePixelSize(){return this.#Jo}set usePixelSize(i){if(this.gpuRenderInfo){const{vertexUniformBuffer:g,vertexUniformInfo:x}=this.gpuRenderInfo;this.redGPUContext.gpuDevice.queue.writeBuffer(g.gpuBuffer,x.members.usePixelSize.uniformOffset,new Uint32Array([i?1:0]))}this.#Jo!==i&&(this.#Jo=i,this.#Qo())}get pixelSize(){return this.#Td}set pixelSize(i){if(this.gpuRenderInfo){const{vertexUniformBuffer:g,vertexUniformInfo:x}=this.gpuRenderInfo;this.redGPUContext.gpuDevice.queue.writeBuffer(g.gpuBuffer,x.members.pixelSize.uniformOffset,new Float32Array([i*window.devicePixelRatio]))}this.#Td=i}#Qo(){if(this.#Wo){const i=this._renderRatioX,g=this._renderRatioY;this.usePixelSize?(this._renderRatioY=1,this._renderRatioX=this.#qo/this.#Wo):(this._renderRatioY=this.#Zo,this._renderRatioX=this.#qo/this.#Wo*this.#Zo),i===this._renderRatioX&&g===this._renderRatioY||(this.dirtyTransform=!0)}}render(i){if(this._material instanceof BitmapMaterial&&this._material.diffuseTexture){const{gpuTexture:i}=this._material.diffuseTexture;if(i){const g=i.width,x=i.height;if(g!==this.#qo||x!==this.#Wo){this.#qo=g,this.#Wo=x;const i=this.pixelSize;this.pixelSize=this.pixelSize||x,this.#Qo(),i!==this.pixelSize&&(this.dirtyTransform=!0)}}}super.render(i)}createCustomMeshVertexShaderModule=()=>this.createMeshVertexShaderModuleBASIC("VERTEX_MODULE_SPRITE_3D",Oa,Na,ka)}Er.definePositiveNumber(Sprite3D,[["_renderRatioX",1],["_renderRatioY",1]]),Er.defineByPreset(Sprite3D,[[Er.PRESET_BOOLEAN.USE_BILLBOARD,!0]]),Object.freeze(Sprite3D);class ASpriteSheet extends Mesh{#Md=0;#wd=0;#Cd=0;#Rd=!0;#Pd=!0;#Bd;#Id;#Ed="play";constructor(i,g,x){super(i),this.#Id=x,this._material=new BitmapMaterial(i),this._material.transparent=!0,this.dirtyPipeline=!0,this.dirtyTransform=!0,this.spriteSheetInfo=g,this._material.diffuseTextureSampler=new Sampler(i),this._material.diffuseTextureSampler.addressModeU=_.REPEAT,this._material.diffuseTextureSampler.addressModeV=_.REPEAT}get state(){return this.#Ed}get loop(){return this.#Pd}set loop(i){this.#Pd=i}get frameRate(){return this.#Md}set frameRate(i){i<0&&(i=0),0===this.#Md&&i&&(this.#wd=0),this.#Md=i,this.#Cd=1e3/this.#Md}get geometry(){return this._geometry}set geometry(i){consoleAndThrowError("ASpriteSheet can not change geometry")}get material(){return this._material}set material(i){consoleAndThrowError("ASpriteSheet can not change material")}get spriteSheetInfo(){return this.#Bd}set spriteSheetInfo(i){this.#Bd=i,this.frameRate=i.frameRate,this.segmentW=i.segmentW,this.segmentH=i.segmentH,this.totalFrame=i.totalFrame,this.currentIndex=i.startIndex,this.#Pd=!0,this.#wd=0,this._material.diffuseTexture=i.texture}play(){this.#Rd=!0,this.#Ed="play",this.#wd=0}pause(){this.#Rd=!1,this.#Ed="pause"}stop(){this.#Rd=!1,this.currentIndex=0,this.#Ed="stop"}render(i){const{diffuseTexture:g}=this._material;this.#Id(g,this.segmentW,this.segmentH);const{timestamp:x}=i;if(this.#wd||(this.#wd=this.#Cd+x),this.#Rd&&this.#wd=this.totalFrame&&(this.loop?(this.#Rd=!0,this.currentIndex=0):(this.#Rd=!1,this.currentIndex=this.totalFrame-1))}super.render(i)}}Er.definePositiveNumber(ASpriteSheet,[["segmentW",5],["segmentH",3],["totalFrame",15],["currentIndex",0]]),Object.freeze(ASpriteSheet);var Va=Object.freeze({__proto__:null,ASpriteSheet:ASpriteSheet}),Fa="#redgpu_include SYSTEM_UNIFORM;\n#redgpu_include getBillboardMatrix;\nstruct MatrixList{ modelMatrix:mat4x4, normalModelMatrix:mat4x4,\n}\nstruct VertexUniforms { matrixList:MatrixList, pickingId:u32, segmentW:f32, segmentH:f32, totalFrame:f32, currentIndex:f32, combinedOpacity:f32,\n};\n@group(1) @binding(0) var vertexUniforms:VertexUniforms;\nstruct InputData { @location(0) position:vec3, @location(1) vertexNormal:vec3, @location(2) uv:vec2,\n};\nstruct OutputData { @builtin(position) position:vec4, @location(0) vertexPosition:vec3, @location(1) vertexNormal:vec3, @location(2) uv:vec2, @location(7) currentClipPos:vec4, @location(8) prevClipPos:vec4, @location(11) combinedOpacity:f32, @location(12) motionVector:vec3, @location(13) shadowPos:vec3, @location(15) @interpolate(flat) pickingId:vec4,\n};\n@vertex\nfn main(inputData:InputData) -> OutputData { var output:OutputData; let u_projectionMatrix=systemUniforms.projectionMatrix; let u_camera=systemUniforms.camera; let u_cameraMatrix=u_camera.cameraMatrix; let u_cameraPosition=u_camera.cameraPosition; let u_modelMatrix=vertexUniforms.matrixList.modelMatrix; let u_normalModelMatrix=vertexUniforms.matrixList.normalModelMatrix; let input_position=inputData.position; let input_vertexNormal=inputData.vertexNormal; let input_uv=inputData.uv; var position:vec4; var normalPosition:vec4; position=u_cameraMatrix * u_modelMatrix * vec4(input_position,1.0); normalPosition=u_cameraMatrix * u_normalModelMatrix * vec4(input_vertexNormal,1.0); output.position=u_projectionMatrix * position; output.vertexPosition=position.xyz; output.vertexNormal=normalPosition.xyz; output.combinedOpacity=vertexUniforms.combinedOpacity; let uv=vec2( input_uv.x * 1/vertexUniforms.segmentW + ((vertexUniforms.currentIndex % vertexUniforms.segmentW)/vertexUniforms.segmentW), input_uv.y * 1/vertexUniforms.segmentH - (floor(vertexUniforms.currentIndex/vertexUniforms.segmentH)/vertexUniforms.segmentH) ); output.uv=uv; return output;\n}\n@vertex\nfn picking(inputData:InputData) -> OutputData { var output:OutputData; let u_projectionMatrix=systemUniforms.projectionMatrix; let u_camera=systemUniforms.camera; let u_cameraMatrix=u_camera.cameraMatrix; let u_cameraPosition=u_camera.cameraPosition; let u_modelMatrix=vertexUniforms.matrixList.modelMatrix; let u_normalModelMatrix=vertexUniforms.matrixList.normalModelMatrix; let input_position=inputData.position; let input_vertexNormal=inputData.vertexNormal; let input_uv=inputData.uv; var position:vec4; var normalPosition:vec4; position=u_cameraMatrix * u_modelMatrix * vec4(input_position,1.0); normalPosition=u_cameraMatrix * u_normalModelMatrix * vec4(input_vertexNormal,1.0); output.position=u_projectionMatrix * position; output.pickingId=unpack4x8unorm(vertexUniforms.pickingId); return output;\n}\n";const Ha=parseWGSL(Fa),za=Ha.uniforms.vertexUniforms,$a=mixInMesh2D(ASpriteSheet);class SpriteSheet2D extends $a{#Bt=1;#It=1;constructor(i,g){super(i,g,(i,g,x)=>{if(i){const{gpuTexture:_}=i,v=_?.width/g,b=_?.height/x;v===this.#Bt&&b===this.#It||(this.#Bt=_?.width/g,this.#It=_?.height/x,this.dirtyTransform=!0)}else this.#Bt=1,this.#It=1}),this._geometry=new Plane(i,1,1,1,1,1,!0),this.primitiveState.cullMode=ei.FRONT}get width(){return this.#Bt}get height(){return this.#It}get geometry(){return this._geometry}set geometry(i){consoleAndThrowError("SpriteSheet2D can not change geometry")}get material(){return this._material}set material(i){consoleAndThrowError("SpriteSheet2D can not change material")}createCustomMeshVertexShaderModule=()=>this.createMeshVertexShaderModuleBASIC("VERTEX_MODULE_SPRITE_SHEET_2D",Ha,za,Fa)}Object.freeze(SpriteSheet2D);var Ka="#redgpu_include SYSTEM_UNIFORM;\n#redgpu_include getBillboardMatrix;\n#redgpu_include calcBillboard;\n#redgpu_include billboardPicking;\n#redgpu_include billboardShadow;\nstruct MatrixList{ modelMatrix:mat4x4, normalModelMatrix:mat4x4,\n}\nstruct VertexUniforms { matrixList:MatrixList, pickingId:u32, useSizeAttenuation:u32, useBillboard:u32, segmentW:f32, segmentH:f32, totalFrame:f32, currentIndex:f32, usePixelSize:u32, pixelSize:f32, _renderRatioX:f32, _renderRatioY:f32, combinedOpacity:f32,\n};\n@group(1) @binding(0) var vertexUniforms:VertexUniforms;\nstruct InputData { @location(0) position:vec3, @location(1) vertexNormal:vec3, @location(2) uv:vec2,\n};\nstruct OutputData { @builtin(position) position:vec4, @location(0) vertexPosition:vec3, @location(1) vertexNormal:vec3, @location(2) uv:vec2, @location(7) currentClipPos:vec4, @location(8) prevClipPos:vec4, @location(11) combinedOpacity:f32, @location(12) motionVector:vec3, @location(13) shadowPos:vec3, @location(15) @interpolate(flat) pickingId:vec4,\n};\n@vertex\nfn main(inputData:InputData) -> OutputData { var output:OutputData; let billboardResult=calcBillboard( inputData.position, inputData.vertexNormal, vertexUniforms.matrixList.modelMatrix, systemUniforms.camera.cameraMatrix, systemUniforms.projectionMatrix, systemUniforms.resolution, vertexUniforms.useBillboard, vertexUniforms.usePixelSize, vertexUniforms.pixelSize, vertexUniforms._renderRatioX, vertexUniforms._renderRatioY ); output.position=billboardResult.position; output.vertexPosition=billboardResult.vertexPosition; output.vertexNormal=billboardResult.vertexNormal; output.uv=vec2( inputData.uv.x/vertexUniforms.segmentW + ((vertexUniforms.currentIndex % vertexUniforms.segmentW)/vertexUniforms.segmentW), inputData.uv.y/vertexUniforms.segmentH - (floor(vertexUniforms.currentIndex/vertexUniforms.segmentH)/vertexUniforms.segmentH) ); output.combinedOpacity=vertexUniforms.combinedOpacity; return output;\n}";const Xa=parseWGSL(Ka),ja=Xa.uniforms.vertexUniforms;class SpriteSheet3D extends ASpriteSheet{#qo=1;#Wo=1;#Zo=1;#Td=0;#Jo=!1;constructor(i,x){super(i,x,(i,x,_)=>{if(i){const{gpuTexture:v}=i;if(v){const i=v.width/x,b=v.height/_;i===this.#qo&&b===this.#Wo||(this.#qo=i,this.#Wo=b,this.pixelSize,this.pixelSize=this.#Td?this.#Td:b,this.#Qo(),g("오냐 ",this.pixelSize),this.dirtyTransform=!0)}}else this.#qo=1,this.#Wo=1}),this._geometry=new Plane(i)}get worldSize(){return this.#Zo}set worldSize(i){this.#Zo!==i&&(this.#Zo=i,this.#Qo())}get pixelSize(){return this.#Td}set pixelSize(i){if(this.gpuRenderInfo){const{vertexUniformBuffer:g,vertexUniformInfo:x}=this.gpuRenderInfo;this.redGPUContext.gpuDevice.queue.writeBuffer(g.gpuBuffer,x.members.pixelSize.uniformOffset,new Float32Array([i*window.devicePixelRatio]))}this.#Td=i}get usePixelSize(){return this.#Jo}set usePixelSize(i){if(this.gpuRenderInfo){const{vertexUniformBuffer:g,vertexUniformInfo:x}=this.gpuRenderInfo;this.redGPUContext.gpuDevice.queue.writeBuffer(g.gpuBuffer,x.members.usePixelSize.uniformOffset,new Uint32Array([i?1:0]))}this.#Jo!==i&&(this.#Jo=i,this.#Qo())}#Qo(){if(this.#Wo){const i=this._renderRatioX,g=this._renderRatioY;this.usePixelSize?(this._renderRatioY=1,this._renderRatioX=this.#qo/this.#Wo):(this._renderRatioY=this.#Zo,this._renderRatioX=this.#qo/this.#Wo*this.#Zo),i===this._renderRatioX&&g===this._renderRatioY||(this.dirtyTransform=!0)}}render(i){super.render(i)}get geometry(){return this._geometry}set geometry(i){consoleAndThrowError("SpriteSheet3D can not change geometry")}get material(){return this._material}set material(i){consoleAndThrowError("SpriteSheet3D can not change material")}createCustomMeshVertexShaderModule=()=>this.createMeshVertexShaderModuleBASIC("VERTEX_MODULE_SPRITE_SHEET_3D",Xa,ja,Ka)}Er.definePositiveNumber(SpriteSheet3D,[["_renderRatioX",1],["_renderRatioY",1]]),Er.defineByPreset(SpriteSheet3D,[[Er.PRESET_BOOLEAN.USE_BILLBOARD,!0]]),Object.freeze(SpriteSheet3D);class SpriteSheetInfo{#Dd=0;#Ud=0;#Ld=0;#Ad=0;#Md=0;#Pd=!0;#Gd;constructor(i,g,x,_,v,b,y=!0,S=60){validateRedGPUContext(i),validateUintRange(x),validateUintRange(_),validateUintRange(v),validateUintRange(b),validateUintRange(S),this.#Dd=x,this.#Ud=_,this.#Ld=v,this.#Ad=b,this.#Gd=new BitmapTexture(i,g),this.#Pd=y,this.#Md=S}get segmentW(){return this.#Dd}get segmentH(){return this.#Ud}get totalFrame(){return this.#Ld}get startIndex(){return this.#Ad}get texture(){return this.#Gd}get frameRate(){return this.#Md}get loop(){return this.#Pd}}Object.freeze(SpriteSheetInfo);const Ya=parseWGSL("#redgpu_include drawPicking;\n#redgpu_include FragmentOutput;\n#redgpu_include calculateMotionVector;\nstruct Uniforms { opacity:f32\n};\nstruct InputData { @builtin(position) position:vec4, @location(0) vertexPosition:vec3, @location(1) vertexColor:vec4, @location(7) currentClipPos:vec4, @location(8) prevClipPos:vec4, @location(15) @interpolate(flat) pickingId:vec4,\n}\n@group(2) @binding(0) var uniforms:Uniforms;\n@fragment\nfn main(inputData:InputData) -> FragmentOutput { var output:FragmentOutput; output.color=inputData.vertexColor; output.gBufferMotionVector=vec4(calculateMotionVector(inputData.currentClipPos,inputData.prevClipPos),0.0,1.0 ); return output;\n}\n");class LineMaterial extends ABaseMaterial{constructor(i,g){super(i,"LINE_MATERIAL",Ya,2),g&&(this.name=g),this.initGPURenderInfos()}}Object.freeze(LineMaterial);class LinePoint{position;colorRGBA;constructor(i=0,g=0,x=0,_){this.position=[i,g,x],this.colorRGBA=_}}const getPointsOnBezierCurveWithSplitting=(i,g,x,_)=>{let v=_||[];if(((i,g)=>{let x=i[g].position,_=i[g+1].position,v=i[g+2].position,b=i[g+3].position,y=3*_[0]-2*x[0]-b[0],S=3*_[1]-2*x[1]-b[1],w=3*v[0]-2*b[0]-x[0],L=3*v[1]-2*b[1]-x[1];return y*=y,S*=S,w*=w,L*=L,y{let b=v||[],y=i[g],S=i[x-1],w=0,L=1,k=g+1;for(;kw&&(w=g,L=k)}return Math.sqrt(w)>_?(lineSimplifyPoints(i,g,L+1,_,b),lineSimplifyPoints(i,L,x,_,b)):b.push(y,S),b},qa={LINEAR:"linear",CATMULL_ROM:"catmullRom",BEZIER:"bezier"};Object.freeze(qa);var Wa="#redgpu_include SYSTEM_UNIFORM;\nstruct MatrixList{ modelMatrix:mat4x4, prevModelMatrix:mat4x4, normalModelMatrix:mat4x4,\n}\nstruct VertexUniforms { matrixList:MatrixList, pickingId:u32,\n};\n@group(1) @binding(0) var vertexUniforms:VertexUniforms;\nstruct InputData { @location(0) position:vec3, @location(1) vertexColor:vec4,\n};\nstruct OutputData { @builtin(position) position:vec4, @location(0) vertexPosition:vec3, @location(1) vertexColor:vec4, @location(7) currentClipPos:vec4, @location(8) prevClipPos:vec4, @location(15) @interpolate(flat) pickingId:vec4,\n};\nstruct OutputShadowData { @builtin(position) position:vec4,\n};\n@vertex\nfn main(inputData:InputData) -> OutputData { var output:OutputData; let u_projectionCameraMatrix=systemUniforms.projectionCameraMatrix; let u_noneJitterProjectionCameraMatrix=systemUniforms.noneJitterProjectionCameraMatrix; let u_prevNoneJitterProjectionCameraMatrix=systemUniforms.prevNoneJitterProjectionCameraMatrix; let u_matrixList=vertexUniforms.matrixList; let u_modelMatrix=u_matrixList.modelMatrix; let u_prevModelMatrix=u_matrixList.prevModelMatrix; let input_position=inputData.position; let input_vertexColor=inputData.vertexColor; let input_position_vec4=vec4(input_position,1.0); var position:vec4; position=u_modelMatrix * input_position_vec4; output.position=u_projectionCameraMatrix * position; output.vertexPosition=position.xyz; output.vertexColor=input_vertexColor; { output.currentClipPos=u_noneJitterProjectionCameraMatrix * position; output.prevClipPos=u_prevNoneJitterProjectionCameraMatrix * u_prevModelMatrix * input_position_vec4; } return output;\n}\n@vertex\nfn picking(inputData:InputData) -> OutputData { var output:OutputData; return output;\n}\n";const Za=parseWGSL(Wa),Ja=Za.uniforms.vertexUniforms;class Line3D extends Mesh{baseColor;#kd;#Od=1;#Nd=.01;#of=.01;#Vd=[];#Fd=[];#Hd;constructor(i,g=qa.LINEAR,x="#fff"){super(i),this.primitiveState.topology=Lr.LINE_STRIP,this.baseColor=x,this.#kd=g,this._geometry=new Geometry(i,new VertexBuffer(i,this.#Vd,new VertexInterleavedStruct({vertexPosition:VertexInterleaveType.float32x3,vertexColor:VertexInterleaveType.float32x4}))),this._material=new LineMaterial(i)}get originalPoints(){return this.#Fd}get type(){return this.#kd}set type(i){this.#kd=i,this.#zd()}get interleaveData(){return this.#Vd}get tension(){return this.#Od}set tension(i){validatePositiveNumberRange(i),this.#Od=i,this.#zd()}get tolerance(){return this.#Nd}set tolerance(i){validatePositiveNumberRange(i),this.#Nd=i,this.#zd()}get distance(){return this.#of}set distance(i){validatePositiveNumberRange(i),this.#of=i,this.#zd()}get numPoints(){return this.#Fd.length}get geometry(){return this._geometry}set geometry(i){consoleAndThrowError("Line3D can not change geometry")}get material(){return this._material}set material(i){consoleAndThrowError("Line3D can not change material")}createCustomMeshVertexShaderModule=()=>this.createMeshVertexShaderModuleBASIC("VERTEX_MODULE_LINE_3D",Za,Ja,Wa);addPoint(i=0,g=0,x=0,_=this.baseColor,v=1,b=0,y=0,S=0,w=0,L=0,k=0){this.#Fd.push(new LinePointWithInOut(i,g,x,b,y,S,w,L,k,_,v)),this.#zd()}addPointAt(i,g=0,x=0,_=0,v=this.baseColor,b=1,y=0,S=0,w=0,L=0,k=0,H=0){this.#Fd.length1)for(this.#Hd=(i=>{let g,x=[],_=0,v=0;const b=i.length;for(;_{const x=i.length,_=x-2;for(let v=0;v{let x=[],_=(i.length-1)/3;_=Math.floor(_);let v,b=0;for(;b<_;++b)v=3*b,getPointsOnBezierCurveWithSplitting(i,v,g,x);return x})(this.#Hd,x),v=lineSimplifyPoints(v,0,v.length,_),b=0,y=v.length;b, normalModelMatrix:mat4x4,\n}\nstruct VertexUniforms { pickingId:u32, matrixList:MatrixList, combinedOpacity:f32,\n};\n@group(1) @binding(0) var vertexUniforms:VertexUniforms;\nstruct InputData { @location(0) position:vec3, @location(1) vertexNormal:vec3, @location(2) uv:vec2,\n};\nstruct OutputData { @builtin(position) position:vec4, @location(0) vertexPosition:vec3, @location(1) vertexNormal:vec3, @location(2) uv:vec2, @location(11) combinedOpacity:f32, @location(13) shadowPos:vec3, @location(15) @interpolate(flat) pickingId:vec4,\n};\nstruct OutputShadowData { @builtin(position) position:vec4,\n};\n@vertex\nfn main(inputData:InputData) -> OutputData { var output:OutputData; let u_projectionMatrix=systemUniforms.projectionMatrix; let u_camera=systemUniforms.camera; let u_cameraMatrix=u_camera.cameraMatrix; let u_cameraPosition=u_camera.cameraPosition; let u_modelMatrix=vertexUniforms.matrixList.modelMatrix; let u_normalModelMatrix=vertexUniforms.matrixList.normalModelMatrix; let input_position=inputData.position; let input_vertexNormal=inputData.vertexNormal; let input_uv=inputData.uv; var position:vec4; var normalPosition:vec4; position=u_cameraMatrix * u_modelMatrix * vec4(input_position,1.0); normalPosition=u_cameraMatrix * u_normalModelMatrix * vec4(input_vertexNormal,1.0); output.position=u_projectionMatrix * position; output.vertexPosition=position.xyz; output.vertexNormal=normalPosition.xyz; output.uv=input_uv; output.combinedOpacity=vertexUniforms.combinedOpacity; return output;\n}\n@vertex\nfn picking(inputData:InputData) -> OutputData { var output:OutputData; let u_projectionMatrix=systemUniforms.projectionMatrix; let u_camera=systemUniforms.camera; let u_cameraMatrix=u_camera.cameraMatrix; let u_cameraPosition=u_camera.cameraPosition; let u_modelMatrix=vertexUniforms.matrixList.modelMatrix; let u_normalModelMatrix=vertexUniforms.matrixList.normalModelMatrix; let input_position=inputData.position; let input_vertexNormal=inputData.vertexNormal; let input_uv=inputData.uv; var position:vec4; var normalPosition:vec4; position=u_cameraMatrix * u_modelMatrix * vec4(input_position,1.0); normalPosition=u_cameraMatrix * u_normalModelMatrix * vec4(input_vertexNormal,1.0); output.position=u_projectionMatrix * position; output.pickingId=unpack4x8unorm(vertexUniforms.pickingId); return output;\n}\n";const rs=parseWGSL(ns),is=rs.uniforms.vertexUniforms,as=mixInMesh2D(ATextField);class TextField2D extends as{#Bt=1;#It=1;#$d=!0;constructor(i,x=!0){super(i,(i,g)=>{this.#Bt===i&&this.#It===g||(this.dirtyTransform=!0),this.#Bt=i,this.#It=g},!1),this._geometry=new Plane(i,1,1,1,1,1,!0),this.useSmoothing=x,this.primitiveState.cullMode=ei.FRONT,g(this)}get useSmoothing(){return this.#$d}set useSmoothing(i){this.#$d=i,this.useSmoothing?(this._material.diffuseTextureSampler.minFilter=v.LINEAR,this._material.diffuseTextureSampler.magFilter=v.LINEAR,this._material.diffuseTextureSampler.mipmapFilter=b.LINEAR):(this._material.diffuseTextureSampler.minFilter=v.NEAREST,this._material.diffuseTextureSampler.magFilter=v.NEAREST,this._material.diffuseTextureSampler.mipmapFilter=null)}get width(){return this.#Bt}get height(){return this.#It}get geometry(){return this._geometry}set geometry(i){console.error("TextField2D can not change geometry")}get material(){return this._material}set material(i){console.error("TextField2D can not change material")}createCustomMeshVertexShaderModule=()=>this.createMeshVertexShaderModuleBASIC("VERTEX_MODULE_TEXT_FIELD_2D",rs,is,ns)}Object.freeze(TextField2D);const ss=3.141592653589793,os=6.283185307179586,us=.225,ls=1.27323954,cs=.405284735,hs=1.5707963267948966,fs=Math.PI/180;class InstancingMeshObject3D{modelMatrix=create$4();localMatrix=create$4();normalModelMatrix=create$4();#Ot=0;#Vt=0;#Nt=0;#Fs=[0,0,0];#Xs=1;#js=1;#Ys=1;#qs=[1,1,1];#Di=0;#Ui=0;#Li=0;#Ws=[0,0,0];#Kd=0;#Xd;#l;#eo=1;constructor(i,g,x){validateRedGPUContext(i),this.#l=i,this.#Xd=x,this.#Kd=g,this.#jd()}get opacity(){return this.#eo}set opacity(i){validatePositiveNumberRange(i,0,1),this.#eo=i,this.#jd()}get x(){return this.#Ot}set x(i){this.#Ot=this.#Fs[0]=i,this.#jd()}get y(){return this.#Nt}set y(i){this.#Nt=this.#Fs[1]=i,this.#jd()}get z(){return this.#Vt}set z(i){this.#Vt=this.#Fs[2]=i,this.#jd()}get position(){return this.#Fs}set position(i){this.#Ot=this.#Fs[0]=i,this.#Nt=this.#Fs[1]=i,this.#Vt=this.#Fs[2]=i,this.#jd()}get scaleX(){return this.#Xs}set scaleX(i){this.#Xs=this.#qs[0]=i,this.#jd()}get scaleY(){return this.#js}set scaleY(i){this.#js=this.#qs[1]=i,this.#jd()}get scaleZ(){return this.#Ys}set scaleZ(i){this.#Ys=this.#qs[2]=i,this.#jd()}get scale(){return this.#Fs}set scale(i){this.#Xs=this.#qs[0]=i,this.#js=this.#qs[1]=i,this.#Ys=this.#qs[2]=i,this.#jd()}get rotationX(){return this.#Di}set rotationX(i){this.#Di=this.#Ws[0]=i,this.#jd()}get rotationY(){return this.#Ui}set rotationY(i){this.#Ui=this.#Ws[1]=i,this.#jd()}get rotationZ(){return this.#Li}set rotationZ(i){this.#Li=this.#Ws[2]=i,this.#jd()}get rotation(){return this.#Ws}set rotation(i){this.#Di=this.#Ws[0]=i,this.#Ui=this.#Ws[1]=i,this.#Li=this.#Ws[2]=i,this.#jd()}setScale(i,g,x){g=g??i,x=x??i;const _=this.#qs;this.#Xs=_[0]=i,this.#js=_[1]=g,this.#Ys=_[2]=x,this.#jd()}setPosition(i,g,x){g=g??i,x=x??i;const _=this.#Fs;this.#Ot=_[0]=i,this.#Nt=_[1]=g,this.#Vt=_[2]=x,this.#jd()}setRotation(i,g,x){g=g??i,x=x??i;const _=this.#Ws;this.#Di=_[0]=i,this.#Ui=_[1]=g,this.#Li=_[2]=x,this.#jd()}#jd(){let i,g,x,_,v,b,y,S,w,L,k,H,z,q,W,be,Ke,Xe,je,Ye,Ze,Je,Qe,et,tt,it,ft,pt,xt,vt,bt,yt,St,Tt,Mt,wt,Ct,Rt;{const z=this.localMatrix;let Ke;L=1,k=0,H=0,q=0,W=1,be=0,Xe=0,je=0,Ye=1,z[12]=this.#Ot,z[13]=this.#Nt,z[14]=this.#Vt,z[15]=1,y=this.#Di*fs,S=this.#Ui*fs,w=this.#Li*fs,Ke=y%os,Ke<-ss?Ke+=os:Ke>ss&&(Ke-=os),Ke=Ke<0?ls*Ke+cs*Ke*Ke:ls*Ke-cs*Ke*Ke,i=Ke<0?us*(Ke*-Ke-Ke)+Ke:us*(Ke*Ke-Ke)+Ke,Ke=(y+hs)%os,Ke<-ss?Ke+=os:Ke>ss&&(Ke-=os),Ke=Ke<0?ls*Ke+cs*Ke*Ke:ls*Ke-cs*Ke*Ke,_=Ke<0?us*(Ke*-Ke-Ke)+Ke:us*(Ke*Ke-Ke)+Ke,Ke=S%os,Ke<-ss?Ke+=os:Ke>ss&&(Ke-=os),Ke=Ke<0?ls*Ke+cs*Ke*Ke:ls*Ke-cs*Ke*Ke,g=Ke<0?us*(Ke*-Ke-Ke)+Ke:us*(Ke*Ke-Ke)+Ke,Ke=(S+hs)%os,Ke<-ss?Ke+=os:Ke>ss&&(Ke-=os),Ke=Ke<0?ls*Ke+cs*Ke*Ke:ls*Ke-cs*Ke*Ke,v=Ke<0?us*(Ke*-Ke-Ke)+Ke:us*(Ke*Ke-Ke)+Ke,Ke=w%os,Ke<-ss?Ke+=os:Ke>ss&&(Ke-=os),Ke=Ke<0?ls*Ke+cs*Ke*Ke:ls*Ke-cs*Ke*Ke,x=Ke<0?us*(Ke*-Ke-Ke)+Ke:us*(Ke*Ke-Ke)+Ke,Ke=(w+hs)%os,Ke<-ss?Ke+=os:Ke>ss&&(Ke-=os),Ke=Ke<0?ls*Ke+cs*Ke*Ke:ls*Ke-cs*Ke*Ke,b=Ke<0?us*(Ke*-Ke-Ke)+Ke:us*(Ke*Ke-Ke)+Ke,vt=v*b,bt=_*x+i*g*b,yt=i*x-_*g*b,St=-v*x,Tt=_*b-i*g*x,Mt=i*b+_*g*x,wt=g,Ct=-i*v,Rt=_*v;let Ze=this.#Xs,Je=this.#js,Qe=this.#Ys;z[0]=vt*Ze,z[1]=bt*Ze,z[2]=yt*Ze,z[3]=0,z[4]=St*Je,z[5]=Tt*Je,z[6]=Mt*Je,z[7]=0,z[8]=wt*Qe,z[9]=Ct*Qe,z[10]=Rt*Qe,z[11]=0}this.modelMatrix=this.localMatrix;{let i=this.normalModelMatrix,g=this.modelMatrix;L=g[0],k=g[1],H=g[2],z=g[3],q=g[4],W=g[5],be=g[6],Ke=g[7],Xe=g[8],je=g[9],Ye=g[10],Ze=g[11],Qe=g[12],et=g[13],tt=g[14],it=g[15],Je=L*W-k*q,ft=L*be-H*q,pt=L*Ke-z*q,xt=k*be-H*W,vt=k*Ke-z*W,bt=H*Ke-z*be,yt=Xe*et-je*Qe,St=Xe*tt-Ye*Qe,Tt=Xe*it-Ze*Qe,wt=je*it-Ze*et,Mt=Ye*it-Ze*tt,Rt=Je*Mt-ft*wt+pt*Mt+xt*Tt-vt*St+bt*yt,Rt=1/Rt,i[0]=(W*Mt-be*wt+Ke*Mt)*Rt,i[4]=(-k*Mt+H*wt-z*Mt)*Rt,i[8]=(et*bt-tt*vt+it*xt)*Rt,i[12]=(-je*bt+Ye*vt-Ze*xt)*Rt,i[1]=(-q*Mt+be*Tt-Ke*St)*Rt,i[5]=(L*Mt-H*Tt+z*St)*Rt,i[9]=(-Qe*bt+tt*pt-it*ft)*Rt,i[13]=(Xe*bt-Ye*pt+Ze*ft)*Rt,i[2]=(q*wt-W*Tt+Ke*yt)*Rt,i[6]=(-L*wt+k*Tt-z*yt)*Rt,i[10]=(Qe*vt-et*pt+it*Je)*Rt,i[14]=(-Xe*vt+je*pt-Ze*Je)*Rt,i[3]=(-q*Mt+W*St-be*yt)*Rt,i[7]=(L*Mt-k*St+H*yt)*Rt,i[11]=(-Qe*xt+et*ft-tt*Je)*Rt,i[15]=(Xe*xt-je*ft+Ye*Je)*Rt}if(this.#Xd.gpuRenderInfo){const{vertexUniformBuffer:i,vertexUniformInfo:g}=this.#Xd.gpuRenderInfo,{dataViewF32:x}=i,{members:_}=g,v=_.instanceModelMatrixs,b=_.instanceNormalModelMatrix,y=_.instanceOpacity;x.set(this.modelMatrix,(v.uniformOffset+v.stride*this.#Kd)/4),x.set(this.normalModelMatrix,(b.uniformOffset+b.stride*this.#Kd)/4),x.set([this.opacity],(y.uniformOffset+y.stride*this.#Kd)/4),this.#Xd.dirtyInstanceMeshObject3D=!0}}}var ds=Object.freeze({__proto__:null,instancingMeshObject3D:InstancingMeshObject3D});class ResourceStateStorageBuffer{static dirtyList=[];buffer;uuid;#Wt=0;constructor(i){this.buffer=i,this.uuid=i.uuid}get useNum(){return this.#Wt}set useNum(i){this.#Wt=i,ResourceStateStorageBuffer.dirtyList.push(this)}}class StorageBuffer extends AUniformBaseBuffer{constructor(i,g,x="",_=""){super(i,"managedStorageBufferState",GPUBufferUsage.STORAGE|GPUBufferUsage.COPY_DST|GPUBufferUsage.COPY_SRC,g,x);const{table:v}=this.targetResourceManagedState,b=v.get(_);if(b)return b.buffer;_&&(this.name=_,this[er]=_),this.redGPUContext.resourceManager.registerManagementResource(this,new ResourceStateStorageBuffer(this))}}Object.freeze(StorageBuffer);var ms="struct OutputData { @builtin(position) position:vec4, @location(0) vertexPosition:vec3, @location(1) vertexNormal:vec3, @location(2) uv:vec2, @location(3) uv1:vec2, @location(4) vertexColor_0:vec4, @location(5) vertexTangent:vec4, @location(7) currentClipPos:vec4, @location(8) prevClipPos:vec4, @location(10) localNodeScale_volumeScale:vec2, @location(11) instanceOpacity:f32, @location(12) motionVector:vec3, @location(13) shadowPos:vec3, @location(14) @interpolate(flat) receiveShadow:f32, @location(15) @interpolate(flat) pickingId:vec4,\n};\n";const ps="VERTEX_MODULE_INSTANCING";class InstancingMesh extends Mesh{dirtyInstanceMeshObject3D=!0;dirtyInstanceNum=!0;#l;#Yd=1;#qd=1;#Wd=[];#xo;#Zd;#Jd;#Qd;#em;#tm;#nm=0;#rm=0;#im;#vo=[];constructor(i,g,x,_,v){super(i,_,v),this.#l=i,this.#ne(),this.maxInstanceCount=g,this.instanceCount=x}get instanceCount(){return this.#Yd}set instanceCount(i){validateUintRange(i),this.#Yd=Math.min(i,this.#qd),this.gpuRenderInfo.vertexUniformInfo=parseWGSL(this.#am(this.geometry,this.material)).storage.instanceUniforms,this.#sm(),this.#Wd.length>this.#Yd&&(this.#Wd.length=this.#Yd);let g=this.#Yd;for(;g--;)this.#Wd[g]||(this.#Wd[g]=new InstancingMeshObject3D(this.#l,g,this));this.#om(),this.#Sf(this.#l),this.dirtyInstanceNum=!0}get maxInstanceCount(){return this.#qd}set maxInstanceCount(i){validateUintRange(i);const g=InstancingMesh.getLimitSize();i=Math.min(i,g),this.#qd=i,this.#Yd>this.#qd&&(this.instanceCount=this.#qd)}get instanceChildren(){return this.#Wd}static getLimitSize(){const i=Math.floor(Math.min(268435456,134217728));return Math.floor((i-80)/132)}render(i,g=!1){if(this.dirtyLOD)return this.#om(),this.#Sf(this.#l),this.dirtyInstanceNum=!0,void(this.dirtyLOD=!1);const{view:x,currentRenderPassEncoder:_}=i,{scene:v}=x,{shadowManager:b}=v,{directionalShadowManager:y}=b,{castingList:S}=y;this.dirtyTransform&&this.#um(),this.geometry?i.num3DObjects++:i.num3DGroups++;const w=this.#l;if(this.geometry){const{antialiasingManager:x}=w;x.changedMSAA&&(this.dirtyPipeline=!0),this.gpuRenderInfo||this.#Sf(w);(this.dirtyPipeline||this.material.dirtyPipeline)&&this.#lm(i),g||this.#cm(i),this.#hm(i,g,_)}this.castShadow&&(S[S.length]=this);const{children:L}=this;let k=L.length;for(;k--;)L[k].dirtyTransform=this.dirtyTransform,L[k].render(i);this.dirtyTransform=!1}#um(){identity$1(this.localMatrix),translate(this.localMatrix,this.localMatrix,[this.x,this.y,this.z]),rotateX$2(this.localMatrix,this.localMatrix,this.rotationX),rotateY$2(this.localMatrix,this.localMatrix,this.rotationY),rotateZ$2(this.localMatrix,this.localMatrix,this.rotationZ),scale$4(this.localMatrix,this.localMatrix,[this.scaleX,this.scaleY,this.scaleZ]);const i=this.parent;i?.modelMatrix?multiply$4(this.modelMatrix,this.localMatrix,i.modelMatrix):this.modelMatrix=clone$4(this.localMatrix)}#lm(i){this.dirtyTransform=!0,this.material.dirtyPipeline&&this.material._updateFragmentState(),this.#fm(),this.material.dirtyPipeline=!1,this.dirtyPipeline=!1,i.numDirtyPipelines++}#hm(i,g,x){const{gpuRenderInfo:_}=this,{pipeline:v,shadowPipeline:b}=_;this.#dm(),this.#mm();const{fragmentUniformBindGroup:y}=this.material.gpuRenderInfo;x.setBindGroup(0,i.view.systemUniform_Vertex_UniformBindGroup),x.setBindGroup(2,y),x.setPipeline(g?b:v);this.#pm(x,this.geometry,this.gpuRenderInfo.vertexUniformBindGroup,this.material.gpuRenderInfo.fragmentUniformBindGroup,0,20),this.LODManager.LODList.forEach((i,g)=>{const _=this.#vo[g];x.setPipeline(_.pipeline),this.#pm(x,i.geometry,_.vertexUniformBindGroup,i.material?i.material.gpuRenderInfo.fragmentUniformBindGroup:this.material.gpuRenderInfo.fragmentUniformBindGroup,g+1,20)}),i.numDrawCalls++,i.numInstances++}#pm(i,g,x,_,v,b){const{vertexBuffer:y,indexBuffer:S}=g,w=b*v;if(i.setBindGroup(1,x),i.setBindGroup(2,_),i.setVertexBuffer(0,y.gpuBuffer),S){const{gpuBuffer:g,format:x}=S;i.setIndexBuffer(g,x),i.drawIndexedIndirect(this.#im,w)}else i.drawIndirect(this.#im,w)}#dm(){const{vertexUniformBuffer:i,vertexUniformInfo:g}=this.gpuRenderInfo,{displacementTexture:x,displacementScale:_}=this.material||{},{members:v}=g;void 0!==v.displacementScale&&this.#xo!==_&&(this.#xo=_,i.dataViewF32.set(new v.displacementScale.View([_]),v.displacementScale.uniformOffset/4)),void 0!==v.useDisplacementTexture&&this.#Zd!==!!x&&(this.#Zd=!!x,i.dataViewF32.set(new v.useDisplacementTexture.View([x?1:0]),v.useDisplacementTexture.uniformOffset/4))}#mm(){const{vertexUniformBuffer:i,vertexUniformInfo:g}=this.gpuRenderInfo,{gpuDevice:x}=this.#l,{members:_}=g;this.dirtyTransform&&(i.dataViewF32.set(this.modelMatrix,_.instanceGroupModelMatrix.uniformOffset/4),x.queue.writeBuffer(i.gpuBuffer,_.instanceGroupModelMatrix.uniformOffset,new _.instanceGroupModelMatrix.View(this.modelMatrix))),(this.dirtyInstanceMeshObject3D||this.dirtyInstanceNum)&&(x.queue.writeBuffer(i.gpuBuffer,0,i.data),this.dirtyInstanceMeshObject3D=!1,this.dirtyInstanceNum=!1)}#ne(){const{gpuDevice:i}=this.#l;this.gpuRenderInfo=new VertexGPURenderInfo(null,null,null,null,null,null,null,null);this.#im=i.createBuffer({size:160,usage:GPUBufferUsage.INDIRECT|GPUBufferUsage.STORAGE|GPUBufferUsage.COPY_DST,label:`IndirectDrawBuffer_${this.uuid}`});const g=new Float32Array(40);this.#em=new StorageBuffer(this.#l,g.buffer,`CullingUniformBuffer_${this.uuid}`)}#Sf(i){this.dirtyPipeline=!0;const g=new ArrayBuffer(this.#nm*(this.LODManager.LODList.length+1));this.#tm?.destroy(),this.#tm=new StorageBuffer(i,g,`VisibilityBuffer_${this.uuid}`),this.#fm(),this.#gm(this.#l)}#gm(i){const{gpuDevice:g,resourceManager:x}=i,_={code:this.#xm()},v=x.createGPUShaderModule(`CULLING_COMPUTE_MODULE_INSTANCING_${this.#qd}_${this.uuid}`,_),b=g.createBindGroupLayout({entries:[{binding:0,visibility:GPUShaderStage.COMPUTE,buffer:{type:"read-only-storage"}},{binding:1,visibility:GPUShaderStage.COMPUTE,buffer:{type:"read-only-storage"}},{binding:2,visibility:GPUShaderStage.COMPUTE,buffer:{type:"storage"}},{binding:3,visibility:GPUShaderStage.COMPUTE,buffer:{type:"storage"}}]});this.#Jd=g.createComputePipeline({layout:g.createPipelineLayout({bindGroupLayouts:[b]}),compute:{module:v,entryPoint:"main"}}),this.#Qd=g.createBindGroup({layout:b,entries:[{binding:0,resource:{buffer:this.gpuRenderInfo.vertexUniformBuffer.gpuBuffer}},{binding:1,resource:{buffer:this.#em.gpuBuffer}},{binding:2,resource:{buffer:this.#tm.gpuBuffer}},{binding:3,resource:{buffer:this.#im}}]})}#_m(i){const{view:g}=i,{gpuDevice:x}=this.#l,{data:_,dataViewU32:v,dataViewF32:b}=this.#em;v.set([this.#Yd],0),v.set([this.#rm],1),v.set([this.LODManager.LODList.length],2),b.set(g.rawCamera.position,4),b.set(g.frustumPlanes.flat(),8),b.set([...this.LODManager.LODList.map(i=>i.distance)],32),x.queue.writeBuffer(this.#em.gpuBuffer,0,_)}#cm(i){const{gpuDevice:g}=this.#l;this.#_m(i);const x=this.geometry.indexBuffer?this.geometry.indexBuffer.indexCount:this.geometry.vertexBuffer.vertexCount,_=new Uint32Array([x,0,0,0,0]);g.queue.writeBuffer(this.#im,0,_),this.LODManager.LODList.forEach((i,x)=>{const _=i.geometry.indexBuffer.indexCount,v=new Uint32Array([_,0,0,0,0]),b=20*(x+1);g.queue.writeBuffer(this.#im,b,v)});const v=g.createCommandEncoder(),b=v.beginComputePass();b.setPipeline(this.#Jd),b.setBindGroup(0,this.#Qd);const y=Math.ceil(this.#Yd/64);b.dispatchWorkgroups(y),b.end(),g.queue.submit([v.finish()])}#fm(){const{resourceManager:i,gpuDevice:g}=this.#l,x={code:this.#am(this.geometry,this.material)},_=i.createGPUShaderModule(`${ps}_${this.#qd}_${this.uuid}`,x),v=i.getGPUBindGroupLayout(ResourceManager.PRESET_VERTEX_GPUBindGroupLayout_Instancing);this.gpuRenderInfo.vertexShaderModule=_,this.gpuRenderInfo.pipeline=createBasePipeline(this,_,v),this.gpuRenderInfo.shadowPipeline=createBasePipeline(this,_,v,hi),this.gpuRenderInfo.vertexUniformBindGroup=g.createBindGroup(this.#vm()),this.#vo.length=0,this.LODManager.LODList.forEach((x,_)=>{const b={code:this.#am(x.geometry,x.material)},y=i.createGPUShaderModule(`${ps}_${this.#qd}_LOD${_}_${this.uuid}`,b);this.#vo[_]={pipeline:createBasePipeline({vertexStateBuffers:x.geometry.gpuRenderInfo.buffers,primitiveState:this.primitiveState,depthStencilState:this.depthStencilState,geometry:x.geometry,material:x.material||this.material,redGPUContext:this.#l,gpuRenderInfo:this.gpuRenderInfo},y,v),vertexUniformBindGroup:g.createBindGroup(this.#vm(_+1))}})}#vm(i=0){const{resourceManager:g}=this.#l,{vertexUniformBuffer:x}=this.gpuRenderInfo,{material:_}=this,{basicSampler:v,emptyBitmapTextureView:b}=g,{gpuSampler:y}=v,S=g.getGPUBindGroupLayout(ResourceManager.PRESET_VERTEX_GPUBindGroupLayout_Instancing),w=this.#nm,L=w*i,k=w;if(L+k>this.#tm.size)throw new Error("Binding range exceeds visibility buffer size.");return{layout:S,label:"VERTEX_BIND_GROUP_DESCRIPTOR_INSTANCING",entries:[{binding:0,resource:{buffer:x.gpuBuffer,offset:0,size:x.size}},{binding:1,resource:_?.displacementTextureSampler?.gpuSampler||y},{binding:2,resource:g.getGPUResourceBitmapTextureView(_?.displacementTexture)||b},{binding:3,resource:{buffer:this.#tm.gpuBuffer,offset:L,size:k}}]}}#om(){const i=4*this.#Yd;this.#nm=256*Math.ceil(i/256),this.#rm=this.#nm/4}#sm(){const i=this.gpuRenderInfo.vertexUniformInfo,g=new ArrayBuffer(i.arrayBufferByteLength),x=new StorageBuffer(this.#l,g,`InstanceBuffer_${this.uuid}`),_=this.gpuRenderInfo.vertexUniformBuffer;_?.gpuBuffer&&(x.dataViewF32.set(_.dataViewF32,0),x.dataViewU32.set([_.dataViewU32[0]],0),x.dataViewU32.set([_.dataViewU32[1]],4),_.destroy()),this.gpuRenderInfo.vertexUniformBuffer=x}#bm(i,g="",x="",_="",v=""){return[g,x,_,i.replaceAll(/__INSTANCE_COUNT__/g,this.#qd.toString()),v].join("\n")}#am(i,g){const x=i.vertexBuffer.interleavedStruct.label,_=g instanceof PBRMaterial,v="PBR"===x&&_,b=v?"struct InputData { @builtin(instance_index) instanceIdx:u32, @location(0) position:vec3, @location(1) vertexNormal:vec3, @location(2) uv:vec2, @location(3) uv1:vec2, @location(4) vertexColor_0:vec4, @location(5) vertexTangent:vec4,\n};\n":"struct InputData { @builtin(instance_index) instanceIdx:u32, @location(0) position:vec3, @location(1) vertexNormal:vec3, @location(2) uv:vec2,\n};",y="PBR"!==x&&_||v?ms:"struct OutputData { @builtin(position) position:vec4, @location(0) vertexPosition:vec3, @location(1) vertexNormal:vec3, @location(2) uv:vec2, @location(7) currentClipPos:vec4, @location(8) prevClipPos:vec4, @location(11) instanceOpacity:f32, @location(12) motionVector:vec3, @location(13) shadowPos:vec3, @location(14) @interpolate(flat) receiveShadow:f32, @location(15) @interpolate(flat) pickingId:vec4,\n};\n";return this.#bm("#redgpu_include SYSTEM_UNIFORM;\n#redgpu_include calcDisplacements;\nstruct InstanceUniforms { useDisplacementTexture:u32, displacementScale:f32, instanceGroupModelMatrix:mat4x4, instanceModelMatrixs:array,__INSTANCE_COUNT__>, instanceNormalModelMatrix:array,__INSTANCE_COUNT__>, instanceOpacity:array,\n};\n@group(1) @binding(0) var instanceUniforms:InstanceUniforms;\n@group(1) @binding(1) var displacementTextureSampler:sampler;\n@group(1) @binding(2) var displacementTexture:texture_2d;\n@group(1) @binding(3) var visibilityBuffer:array;\nconst maxDistance:f32=1000.0;\nconst maxMipLevel:f32=10.0;",v?"@vertex\nfn main(inputData:InputData) -> OutputData { var output:OutputData; let input_instanceIdx:u32=visibilityBuffer[inputData.instanceIdx]; let u_modelMatrix=instanceUniforms.instanceModelMatrixs[input_instanceIdx]; let u_normalModelMatrix=instanceUniforms.instanceNormalModelMatrix[input_instanceIdx]; let u_instanceGroupModelMatrix=instanceUniforms.instanceGroupModelMatrix; let u_useDisplacementTexture=instanceUniforms.useDisplacementTexture==1u; let u_displacementScale=instanceUniforms.displacementScale; let u_projectionMatrix=systemUniforms.projectionMatrix; let u_projectionCameraMatrix=systemUniforms.projectionCameraMatrix; let u_camera=systemUniforms.camera; let u_cameraMatrix=u_camera.cameraMatrix; let u_cameraPosition=u_camera.cameraPosition; let input_position=inputData.position; let input_vertexNormal=inputData.vertexNormal; let input_uv=inputData.uv; var position:vec4=u_modelMatrix * vec4(input_position,1.0); let worldPosition=position.xyz; if (u_useDisplacementTexture) { let distance=distance(position.xyz,u_cameraPosition); let mipLevel=(distance/maxDistance) * maxMipLevel; let displacedPosition=calcDisplacementPosition( input_position, input_vertexNormal, displacementTexture, displacementTextureSampler, u_displacementScale, input_uv, mipLevel ); position=u_modelMatrix * vec4(displacedPosition,1.0); } output.position=u_projectionCameraMatrix * u_instanceGroupModelMatrix * position; output.vertexPosition=position.xyz; var normalPosition:vec3=(u_instanceGroupModelMatrix * u_normalModelMatrix * vec4(input_vertexNormal,1.0)).xyz; output.vertexNormal=normalPosition; output.instanceOpacity=instanceUniforms.instanceOpacity[input_instanceIdx]; output.uv=inputData.uv; output.uv1=inputData.uv1; output.vertexColor_0=inputData.vertexColor_0; output.vertexTangent=u_normalModelMatrix * inputData.vertexTangent; return output;\n}\n":"@vertex\nfn main(inputData:InputData) -> OutputData { var output:OutputData; let input_instanceIdx:u32=visibilityBuffer[inputData.instanceIdx]; let u_modelMatrix=instanceUniforms.instanceModelMatrixs[input_instanceIdx]; let u_normalModelMatrix=instanceUniforms.instanceNormalModelMatrix[input_instanceIdx]; let u_instanceGroupModelMatrix=instanceUniforms.instanceGroupModelMatrix; let u_useDisplacementTexture=instanceUniforms.useDisplacementTexture==1u; let u_displacementScale=instanceUniforms.displacementScale; let u_projectionMatrix=systemUniforms.projectionMatrix; let u_projectionCameraMatrix=systemUniforms.projectionCameraMatrix; let u_camera=systemUniforms.camera; let u_cameraMatrix=u_camera.cameraMatrix; let u_cameraPosition=u_camera.cameraPosition; let input_position=inputData.position; let input_vertexNormal=inputData.vertexNormal; let input_uv=inputData.uv; var position:vec4=u_modelMatrix * vec4(input_position,1.0); let worldPosition=position.xyz; if (u_useDisplacementTexture) { let distance=distance(position.xyz,u_cameraPosition); let mipLevel=(distance/maxDistance) * maxMipLevel; let displacedPosition=calcDisplacementPosition( input_position, input_vertexNormal, displacementTexture, displacementTextureSampler, u_displacementScale, input_uv, mipLevel ); position=u_modelMatrix * vec4(displacedPosition,1.0); } output.position=u_projectionCameraMatrix * u_instanceGroupModelMatrix * position; output.vertexPosition=position.xyz; var normalPosition:vec3=(u_instanceGroupModelMatrix * u_normalModelMatrix * vec4(input_vertexNormal,1.0)).xyz; output.vertexNormal=normalPosition; output.uv=input_uv; output.instanceOpacity=instanceUniforms.instanceOpacity[input_instanceIdx]; return output;\n}\n",b,y,"\nstruct OutputShadowData { @builtin(position) position:vec4,\n};\n@vertex\nfn drawDirectionalShadowDepth(inputData:InputData) -> OutputShadowData { var output:OutputShadowData; let input_instanceIdx:u32=visibilityBuffer[inputData.instanceIdx]; let u_directionalLightProjectionViewMatrix=systemUniforms.directionalLightProjectionViewMatrix; let u_modelMatrix=instanceUniforms.instanceModelMatrixs[input_instanceIdx]; let u_useDisplacementTexture=instanceUniforms.useDisplacementTexture==1u; let u_displacementScale=instanceUniforms.displacementScale; let input_position=inputData.position; let input_vertexNormal=inputData.vertexNormal; let input_uv=inputData.uv; var position:vec4=u_modelMatrix * vec4(input_position,1.0); if (u_useDisplacementTexture) { let distance=distance(position.xyz,u_directionalLightProjectionViewMatrix[3].xyz); let mipLevel=(distance/maxDistance) * maxMipLevel; let displacedPosition=calcDisplacementPosition( input_position, input_vertexNormal, displacementTexture, displacementTextureSampler, u_displacementScale, input_uv, mipLevel ); position=u_modelMatrix * vec4(displacedPosition,1.0); } output.position=u_directionalLightProjectionViewMatrix * position; return output;\n}\n")}#xm(){return this.#bm("struct InstanceUniforms { useDisplacementTexture:u32, displacementScale:f32, instanceGroupModelMatrix:mat4x4, instanceModelMatrixs:array,__INSTANCE_COUNT__>, instanceNormalModelMatrix:array,__INSTANCE_COUNT__>, instanceOpacity:array,\n};\nstruct CullingUniforms { instanceCount:u32, stride:u32, lodNum:u32, padding:f32, cameraPosition:vec3, frustumPlanes:array,6>, lodDistanceList:array,\n};\nstruct IndirectDrawArgs { vertexCount:u32, instanceCount:atomic, firstVertex:u32, baseVertex:u32, firstInstance:u32,\n};\n@group(0) @binding(0) var instanceUniforms:InstanceUniforms;\n@group(0) @binding(1) var cullingUniforms:CullingUniforms;\n@group(0) @binding(2) var visibilityBuffer:array;\n@group(0) @binding(3) var indirectDrawBuffer:array;\nconst BOUNDING_RADIUS:f32=1.0;\nfn distanceToPlane(position:vec3,plane:vec4) -> f32 { return dot(vec4(position,1.0),plane);\n}\nfn isInsideFrustum(position:vec3,radius:f32) -> bool { for (var i:u32=0u;i < 6u;i=i + 1u) { let plane=cullingUniforms.frustumPlanes[i]; let distance=distanceToPlane(position,plane); if (distance < -radius) { return false; } } return true;\n}\nfn calculateLODLevel(distanceToCamera:f32) -> u32 { if (cullingUniforms.lodNum==0u) { return 0u; } for (var i:u32=0u;i < cullingUniforms.lodNum;i=i + 1u) { if (distanceToCamera < cullingUniforms.lodDistanceList[i]) { return i; } } return cullingUniforms.lodNum;\n}\n@compute @workgroup_size(64)\nfn main(@builtin(global_invocation_id) globalId:vec3) { let instanceIdx=globalId.x; if (instanceIdx >=(cullingUniforms.instanceCount)) { return; } let u_instanceGroupModelMatrix=instanceUniforms.instanceGroupModelMatrix; let modelMatrix=u_instanceGroupModelMatrix * instanceUniforms.instanceModelMatrixs[instanceIdx]; let worldPosition=vec3( modelMatrix[3][0], modelMatrix[3][1], modelMatrix[3][2] ); let scaleX=length(vec3(modelMatrix[0][0],modelMatrix[0][1],modelMatrix[0][2])); let scaleY=length(vec3(modelMatrix[1][0],modelMatrix[1][1],modelMatrix[1][2])); let scaleZ=length(vec3(modelMatrix[2][0],modelMatrix[2][1],modelMatrix[2][2])); let maxScale=max(max(scaleX,scaleY),scaleZ); let scaledRadius=BOUNDING_RADIUS * maxScale; let isVisible=isInsideFrustum(worldPosition,scaledRadius); if (isVisible) { let distanceToCamera=distance(worldPosition,cullingUniforms.cameraPosition); let lodLevel=calculateLODLevel(distanceToCamera); let visibilityStride=cullingUniforms.stride; let aliveIndex=atomicAdd(&indirectDrawBuffer[lodLevel].instanceCount,1u); visibilityBuffer[visibilityStride * lodLevel + aliveIndex]=instanceIdx; }\n}\n")}}Object.defineProperty(InstancingMesh.prototype,"meshType",{value:Gr.INSTANCED_MESH,writable:!1});var gs=Object.freeze({__proto__:null,CoreGroup:Ia,CoreInstancingMesh:ds,CoreMesh:Pa,CoreSkyBox:Ca,CoreSpriteSheet:Va,CoreTextField:ts,CoreView:Ba,Group2D:Group2D,Group3D:Group3D,InstancingMesh:InstancingMesh,LINE_TYPE:qa,Line2D:class extends Line3D{constructor(i,g=qa.LINEAR,x="#fff"){super(i,g,x),this._material=new LineMaterial(i)}get geometry(){return this._geometry}set geometry(i){consoleAndThrowError("Line2D can not change geometry")}get material(){return this._material}set material(i){consoleAndThrowError("Line2D can not change material")}createCustomMeshVertexShaderModule=()=>this.createMeshVertexShaderModuleBASIC("VERTEX_MODULE_LINE_2D",Qa,es,Wa);addPoint(i=0,g=0,x=this.baseColor,_=1,v=0,b=0,y=0,S=0){super.addPoint(i,g,0,x,_,v,b,0,y,S,0)}addPointAt(i,g=0,x=0,_=this.baseColor,v=1,b=0,y=0,S=0,w=0){super.addPointAt(i,g,x,0,_,v,b,y,0,S,w,0)}},Line3D:Line3D,Mesh:Mesh,PARTICLE_EASE:Ea,ParticleEmitter:ParticleEmitter,Scene:Scene,SkyBox:SkyBox,Sprite2D:Sprite2D,Sprite3D:Sprite3D,SpriteSheet2D:SpriteSheet2D,SpriteSheet3D:SpriteSheet3D,SpriteSheetInfo:SpriteSheetInfo,TextField2D:TextField2D,TextField3D:TextField3D,View2D:View2D,View3D:View3D}),xs=Object.freeze({__proto__:null,ABaseLight:ABaseLight}),_s=Object.freeze({__proto__:null,AmbientLight:AmbientLight,Core:xs,DirectionalLight:DirectionalLight,LightManager:LightManager,PointLight:PointLight,SpotLight:SpotLight});function sortTransparentObjects(i,g){const x={},{x:_,y:v,z:b}=i;return g.sort((i,g)=>{if(i=i.mesh,g=g.mesh,!x[i.uuid]){const g=i.x-_,y=i.y-v,S=i.z-b;x[i.uuid]=g*g+y*y+S*S}if(!x[g.uuid]){const i=g.x-_,y=g.y-v,S=g.z-b;x[g.uuid]=i*i+y*y+S*S}return x[g.uuid]-x[i.uuid]})}var vs=Object.freeze({__proto__:null,Ray:Ray,calculateNormals:calculateNormals,calculateTangents:(i,g,x,_,v)=>{const b=1e-6,y=i.length/3,S=_.length>0,w=S?_.length/3:y/3,L=new Float32Array(3*y),k=new Float32Array(3*y);for(let g=0;g=4*y;for(let i=0;ib){H.push(g,x,_,v[4*i+3]);continue}}const x=g[3*i],_=g[3*i+1],y=g[3*i+2],S=L[3*i],w=L[3*i+1],q=L[3*i+2],W=k[3*i],be=k[3*i+1],Ke=k[3*i+2],Xe=x*S+_*w+y*q;let je=S-x*Xe,Ye=w-_*Xe,Ze=q-y*Xe,Je=Math.sqrt(je*je+Ye*Ye+Ze*Ze);if(Jey+b?w-(i0&&(_=1/Math.sqrt(_||1)),W[0]=W[0]*_,W[1]=W[1]*_,W[2]=W[2]*_}{let i=Ke[0],g=Ke[1],x=Ke[2],_=i*i+g*g+x*x;_>0&&(_=1/Math.sqrt(_)),Ke[0]=Ke[0]*_,Ke[1]=Ke[1]*_,Ke[2]=Ke[2]*_}for(let g=0;g<=b;++g){const x=g/b*Math.PI*2,y=-_*Math.cos(x),S=_*Math.sin(x);k[0]=z[0]+(y*Ke[0]+S*W[0]),k[1]=z[1]+(y*Ke[1]+S*W[1]),k[2]=z[2]+(y*Ke[2]+S*W[2]),w.push(k[0],k[1],k[2]);{H[0]=k[0]-z[0],H[1]=k[1]-z[1],H[2]=k[2]-z[2];let i=H[0],g=H[1],x=H[2],_=i*i+g*g+x*x;_>0&&(_=1/Math.sqrt(_)),H[0]=H[0]*_,H[1]=H[1]*_,H[2]=H[2]*_}w.push(H[0],H[1],H[2],i/v,g/b)}}for(let i=1;i<=v;i++)for(let g=1;g<=b;g++){const x=(b+1)*(i-1)+(g-1),_=(b+1)*i+(g-1),v=(b+1)*i+g,y=(b+1)*(i-1)+g;L.push(x,_,y),L.push(_,v,y)}return createPrimitiveGeometry(g,w,L,i)}}();constructor(i,g=1,x=.4,_=64,v=8,b=2,y=3){super(i);const S=`PRIMITIVE_TORUS_NUT_R${g}_T${x}_TS${_}_RS${v}_P${b}_Q${y}`,w=i.resourceManager.cachedBufferState;let L=w[S];L||(L=w[S]=this.#Ii(S,i,g,x,_,v,b,y)),this._setData(L)}}});const Ss=parseWGSL("#redgpu_include SYSTEM_UNIFORM;\n#redgpu_include calcTintBlendMode;\n#redgpu_include calcDirectionalShadowVisibility;\n#redgpu_include normalFunctions;\n#redgpu_include drawPicking;\n#redgpu_include FragmentOutput;\n#redgpu_include calculateMotionVector;\nstruct Uniforms { color:vec3, emissiveColor:vec3, emissiveStrength:f32, specularColor:vec3, specularStrength:f32, shininess:f32, aoStrength:f32, normalScale:f32, opacity:f32, useTint:u32, tint:vec4, tintBlendMode:u32, useSSR:u32, metallic:f32, roughness:f32,\n};\nstruct InputData { @builtin(position) position:vec4, @location(0) vertexPosition:vec3, @location(1) vertexNormal:vec3, @location(2) uv:vec2, @location(7) currentClipPos:vec4, @location(8) prevClipPos:vec4, @location(11) combinedOpacity:f32, @location(12) motionVector:vec3, @location(13) shadowPos:vec3, @location(14) @interpolate(flat) receiveShadow:f32, @location(15) @interpolate(flat) pickingId:vec4,\n}\n@group(2) @binding(0) var uniforms:Uniforms;\n@group(2) @binding(1) var diffuseTextureSampler:sampler;\n@group(2) @binding(2) var diffuseTexture:texture_2d;\n@group(2) @binding(3) var alphaTextureSampler:sampler;\n@group(2) @binding(4) var alphaTexture:texture_2d;\n@group(2) @binding(5) var specularTextureSampler:sampler;\n@group(2) @binding(6) var specularTexture:texture_2d;\n@group(2) @binding(7) var emissiveTextureSampler:sampler;\n@group(2) @binding(8) var emissiveTexture:texture_2d;\n@group(2) @binding(9) var aoTextureSampler:sampler;\n@group(2) @binding(10) var aoTexture:texture_2d;\n@group(2) @binding(11) var normalTextureSampler:sampler;\n@group(2) @binding(12) var normalTexture:texture_2d;\n@fragment\nfn main(inputData:InputData) -> FragmentOutput { var output:FragmentOutput; let u_ambientLight=systemUniforms.ambientLight; let u_ambientLightColor=u_ambientLight.color; let u_ambientLightIntensity=u_ambientLight.intensity; let u_directionalLightCount=systemUniforms.directionalLightCount; let u_directionalLights=systemUniforms.directionalLights; let u_shadowDepthTextureSize=systemUniforms.shadowDepthTextureSize; let u_bias=systemUniforms.bias; let u_camera=systemUniforms.camera; let u_cameraMatrix=u_camera.cameraMatrix; let u_cameraPosition=u_camera.cameraPosition; let u_color=uniforms.color; let u_aoStrength=uniforms.aoStrength; let u_emissiveColor=uniforms.emissiveColor; let u_emissiveStrength=uniforms.emissiveStrength; let u_normalScale=uniforms.normalScale; let u_specularColor=uniforms.specularColor; let u_specularStrength=uniforms.specularStrength; let u_shininess=uniforms.shininess; let u_opacity=uniforms.opacity; let E=normalize(u_cameraPosition - inputData.vertexPosition); let receiveShadowYn=inputData.receiveShadow !=.0; var N=normalize(inputData.vertexNormal); #redgpu_if normalTexture let normalSamplerColor=textureSample(normalTexture,normalTextureSampler,inputData.uv).rgb; N=perturb_normal( N,inputData.vertexPosition,inputData.uv,normalSamplerColor,u_normalScale ); #redgpu_endIf var finalColor:vec4; var resultAlpha:f32=u_opacity * inputData.combinedOpacity; var diffuseColor:vec3=u_color; #redgpu_if diffuseTexture let diffuseSampleColor=textureSample(diffuseTexture,diffuseTextureSampler,inputData.uv); diffuseColor=diffuseSampleColor.rgb; resultAlpha=resultAlpha * diffuseSampleColor.a; #redgpu_endIf var specularSamplerValue:f32=1; #redgpu_if specularTexture specularSamplerValue=textureSample(specularTexture,specularTextureSampler,inputData.uv).r; #redgpu_endIf var mixColor:vec3; let ambientContribution=u_ambientLightColor * u_ambientLightIntensity; let ambientDiffuse=diffuseColor * ambientContribution; mixColor +=ambientDiffuse; var visibility:f32=1.0; visibility=calcDirectionalShadowVisibility( directionalShadowMap, directionalShadowMapSampler, u_shadowDepthTextureSize, u_bias, inputData.shadowPos, ); if(!receiveShadowYn){ visibility=1.0; } for (var i=0u;i < u_directionalLightCount;i=i + 1) { let u_directionalLightDirection=u_directionalLights[i].direction; let u_directionalLightColor=u_directionalLights[i].color; let u_directionalLightIntensity=u_directionalLights[i].intensity; let L=normalize(u_directionalLightDirection); let R=reflect(L,N); let lambertTerm=max(dot(N,-L),0.0); let specular=pow(max(dot(R,E),0.0),u_shininess) * specularSamplerValue; let lightContribution=u_directionalLightColor * u_directionalLightIntensity * visibility; let ld=diffuseColor * lightContribution * lambertTerm; let ls=u_specularColor * u_specularStrength * lightContribution * specular; mixColor +=ld + ls; } let clusterIndex=getClusterLightClusterIndex(inputData.position); let lightOffset=clusterLightGroup.lights[clusterIndex].offset; let lightCount:u32=clusterLightGroup.lights[clusterIndex].count; for (var lightIndex=0u;lightIndex < lightCount;lightIndex=lightIndex + 1u) { let i=clusterLightGroup.indices[lightOffset + lightIndex]; let u_clusterLightPosition=clusterLightList.lights[i].position; let u_clusterLightColor=clusterLightList.lights[i].color; let u_clusterLightIntensity=clusterLightList.lights[i].intensity; let u_clusterLightRadius=clusterLightList.lights[i].radius; let u_isSpotLight=clusterLightList.lights[i].isSpotLight; let lightDir=u_clusterLightPosition - inputData.vertexPosition; let lightDistance=length(lightDir); if (lightDistance > u_clusterLightRadius) { continue; } let L=normalize(lightDir); let dist2=max(dot(lightDir,lightDir),0.0001); let d=sqrt(dist2); let rangePart=pow(clamp(1.0 - d/u_clusterLightRadius,0.0,1.0),2.0); let invSquare=(u_clusterLightRadius * u_clusterLightRadius)/dist2; let attenuation=rangePart * invSquare; var finalAttenuation=attenuation; if (u_isSpotLight > 0.0) { let u_clusterLightDirection=normalize(vec3( clusterLightList.lights[i].directionX, clusterLightList.lights[i].directionY, clusterLightList.lights[i].directionZ )); let u_clusterLightInnerAngle=clusterLightList.lights[i].innerCutoff; let u_clusterLightOuterCutoff=clusterLightList.lights[i].outerCutoff; let lightToVertex=normalize(-lightDir); let cosTheta=dot(lightToVertex,u_clusterLightDirection); let cosOuter=cos(radians(u_clusterLightOuterCutoff)); let cosInner=cos(radians(u_clusterLightInnerAngle)); if (cosTheta < cosOuter) { continue; } let epsilon=cosInner - cosOuter; let spotIntensity=clamp((cosTheta - cosOuter)/epsilon,0.0,1.0); finalAttenuation *=spotIntensity; } let R=reflect(-L,N); let diffuse=diffuseColor * max(dot(N,L),0.0); let specular=pow(max(dot(R,E),0.0),u_shininess) * specularSamplerValue; let diffuseAttenuation=finalAttenuation; let specularAttenuation=finalAttenuation * finalAttenuation; let ld=u_clusterLightColor * diffuse * diffuseAttenuation * u_clusterLightIntensity; let ls=u_specularColor * u_specularStrength * specular * specularAttenuation * u_clusterLightIntensity; mixColor +=ld + ls; } #redgpu_if alphaTexture let alphaMapValue:f32=textureSample(alphaTexture,alphaTextureSampler,inputData.uv).r; resultAlpha=alphaMapValue * resultAlpha; if(resultAlpha==0){ discard;} #redgpu_endIf var emissiveColor=u_emissiveColor * u_emissiveStrength; #redgpu_if emissiveTexture emissiveColor=textureSample(emissiveTexture,emissiveTextureSampler,inputData.uv).rgb * u_emissiveStrength; #redgpu_endIf #redgpu_if aoTexture mixColor=mixColor * textureSample(aoTexture,aoTextureSampler,inputData.uv).rgb * u_aoStrength; #redgpu_endIf finalColor=vec4(mixColor + emissiveColor,resultAlpha); #redgpu_if useTint finalColor=calcTintBlendMode(finalColor,uniforms.tintBlendMode,uniforms.tint); #redgpu_endIf if (systemUniforms.isView3D==1 && finalColor.a==0.0) { discard; } output.color=finalColor; { let metallic=uniforms.metallic; let roughness=uniforms.roughness; let smoothness=1.0 - roughness; let smoothnessCurved=smoothness * smoothness * (3.0 - 2.0 * smoothness); let metallicWeight=metallic * metallic; let baseReflection=0.04 + 0.96 * metallicWeight; let baseReflectionStrength=smoothnessCurved * baseReflection; output.gBufferNormal=vec4(N * 0.5 + 0.5,baseReflectionStrength); } output.gBufferMotionVector=vec4(calculateMotionVector(inputData.currentClipPos,inputData.prevClipPos),0.0,1.0 ); return output;\n}\n");class PhongMaterial extends AUVTransformBaseMaterial{#ym;#xo=1;constructor(i,g="#fff",x){super(i,"PHONG_MATERIAL",Ss,2),x&&(this.name=x),this.initGPURenderInfos(),this.color.setColorByHEX(g),this.emissiveColor.setColorByHEX(this.emissiveColor.hex),this.specularColor.setColorByHEX(this.specularColor.hex)}get displacementScale(){return this.#xo}set displacementScale(i){this.#xo=i}get displacementTexture(){return this.#ym}set displacementTexture(i){const g=this.#ym;this.#ym=i,this.updateTexture(g,i),this.dirtyPipeline=!0}}dr.defineByPreset(PhongMaterial,[dr.PRESET_COLOR_RGB.COLOR,dr.PRESET_TEXTURE.ALPHA_TEXTURE,dr.PRESET_SAMPLER.ALPHA_TEXTURE_SAMPLER,dr.PRESET_TEXTURE.AO_TEXTURE,dr.PRESET_SAMPLER.AO_TEXTURE_SAMPLER,dr.PRESET_POSITIVE_NUMBER.AO_STRENGTH,dr.PRESET_TEXTURE.DIFFUSE_TEXTURE,dr.PRESET_SAMPLER.DIFFUSE_TEXTURE_SAMPLER,dr.PRESET_TEXTURE.EMISSIVE_TEXTURE,dr.PRESET_SAMPLER.EMISSIVE_TEXTURE_SAMPLER,dr.PRESET_POSITIVE_NUMBER.EMISSIVE_STRENGTH,[dr.PRESET_COLOR_RGB.EMISSIVE_COLOR,"#000000"],dr.PRESET_TEXTURE.NORMAL_TEXTURE,dr.PRESET_SAMPLER.NORMAL_TEXTURE_SAMPLER,dr.PRESET_POSITIVE_NUMBER.NORMAL_SCALE,dr.PRESET_TEXTURE.SPECULAR_TEXTURE,dr.PRESET_SAMPLER.SPECULAR_TEXTURE_SAMPLER,dr.PRESET_POSITIVE_NUMBER.SPECULAR_STRENGTH,[dr.PRESET_COLOR_RGB.SPECULAR_COLOR,"#ffffff"],[dr.PRESET_POSITIVE_NUMBER.SHININESS,32]]),dr.defineBoolean(PhongMaterial,[["useSSR",!1]]),dr.definePositiveNumber(PhongMaterial,[["metallic",0,0,1],["roughness",0,0,1]]),Object.freeze(PhongMaterial);var Ts=Object.freeze({__proto__:null,BLEND_MODE:Ra,BitmapMaterial:BitmapMaterial,COMPOSITE_MODE:{ADDITIVE:"additive",SOURCE_OVER:"source-over",SOURCE_IN:"source-in",SOURCE_OUT:"source-out",SOURCE_ATOP:"source-atop",DESTINATION_OVER:"destination-over",DESTINATION_IN:"destination-in",DESTINATION_OUT:"destination-out",DESTINATION_ATOP:"destination-atop"},ColorMaterial:ColorMaterial,Core:wr,PBRMaterial:PBRMaterial,PhongMaterial:PhongMaterial,TINT_BLEND_MODE:Tr}),Ms=Object.freeze({__proto__:null,ManagementResourceBase:ManagementResourceBase,ResourceBase:ResourceBase,ResourceManager:ResourceManager,ResourceStatusInfo:ResourceStatusInfo});var ws=Object.freeze({__proto__:null,ABaseBuffer:ABaseBuffer,AUniformBaseBuffer:AUniformBaseBuffer,getUniformOffsetByRoundUp:(i,g)=>((i+g-1)/g|0)*g}),Cs=Object.freeze({__proto__:null,VertexInterleavedStructElement:VertexInterleavedStructElement});class ResourceStateHDRTexture{texture;src;cacheKey;useNum=0;uuid;constructor(i){this.texture=i,this.src=i.src,this.cacheKey=i.cacheKey,this.useNum=0,this.uuid=i.uuid}}class HDRLoader{#Sm=!0;constructor(i=!0){this.#Sm=i}get enableDebugLogs(){return this.#Sm}set enableDebugLogs(i){this.#Sm=i}async loadHDRFile(i){this.#Sm&&g(`HDR 파일 로딩 시작:${i}`);const x=await fetch(i);if(!x.ok)throw new Error(`HTTP ${x.status}:${x.statusText}`);const _=await x.arrayBuffer(),v=new Uint8Array(_),b=this.#Tm(v,i);return g({...b}),{...b}}#Tm(i,x){const _=this.#Mm(i);if(this.#Sm&&g(`파일 형식:${_.format}`),!_.isValid)throw new Error(_.error||"지원되지 않는 파일 형식입니다");if(x.split("?")[0].toLowerCase().endsWith(".hdr")){this.#Sm&&this.#wm(i.slice(0,200));const g=this.#Cm(i);return this.#Sm&&this.#Rm(g),g}throw x.split("?")[0].toLowerCase().endsWith(".exr")?new Error("EXR format not supported yet"):new Error(`Unsupported HDR format:${x}`)}#Cm(i){let x=0,_="";const v={};for(;x0){const i=_.substring(0,g).trim(),x=_.substring(g+1).trim();v[i]=x}}for(_="";x>8&255)&&i[g+3]===(255&x)){g+=4;for(let v=0;v<4;v++){let b=v;for(;b<4*x;){const v=i[g++];if(v>128){const y=v-128,S=i[g++];for(let i=0;ii.toString(16).padStart(2,"0")).join(" "),Array.from(i.slice(g,g+16)).map(i=>i>=32&&i<=126?String.fromCharCode(i):".").join("")}}async function float32ToFloat16Linear(i,g,x){const _=performance.now(),{gpuDevice:v}=i,{width:b,height:y,workgroupSize:S=[8,8],maxValue:w=1e3}=x,L=g.length/4,k=function(i){return` struct Constants { width:u32, height:u32, }\n @group(0) @binding(0) var inputData:array; @group(0) @binding(1) var outputData:array; @group(0) @binding(2) var constants:Constants;\n fn floatToHalf(value:f32) -> u32 { let bits=bitcast(value); let sign=(bits >> 16u) & 0x8000u; var exp=(bits >> 23u) & 0xFFu; var mantissa=bits & 0x7FFFFFu;\n if (exp==0u) { return sign; }\n if (exp==255u) { return sign | 0x7C00u | select(0u,1u,mantissa !=0u); }\n let newExp=i32(exp) - 127 + 15; if (newExp <=0) { return sign; } if (newExp >=31) { return sign | 0x7C00u; }\n return sign | (u32(newExp) << 10u) | (mantissa >> 13u); }\n @compute @workgroup_size(${i[0]},${i[1]}) fn main(@builtin(global_invocation_id) global_id:vec3) { let x=global_id.x; let y=global_id.y;\n if (x >=constants.width || y >=constants.height) { return; }\n let pixelIndex=y * constants.width + x; let baseIndex=pixelIndex * 4u;\n let r=inputData[baseIndex]; let g=inputData[baseIndex + 1u]; let b=inputData[baseIndex + 2u]; let a=inputData[baseIndex + 3u];\n let r16=floatToHalf(r); let g16=floatToHalf(g); let b16=floatToHalf(b); let a16=floatToHalf(a);\n let outputIndex=pixelIndex * 2u; outputData[outputIndex]=(g16 << 16u) | r16; outputData[outputIndex + 1u]=(a16 << 16u) | b16; } `}(S);try{const i=v.createShaderModule({code:k,label:"float16_linear_conversion_shader"}),x=function(i,g,x){const _=i.createBuffer({size:g.byteLength,usage:GPUBufferUsage.STORAGE|GPUBufferUsage.COPY_DST,label:"float16_input_buffer"}),v=i.createBuffer({size:8*x,usage:GPUBufferUsage.STORAGE|GPUBufferUsage.COPY_SRC,label:"float16_output_buffer"}),b=i.createBuffer({size:16,usage:GPUBufferUsage.UNIFORM|GPUBufferUsage.COPY_DST,label:"float16_constants_buffer"}),y=i.createBuffer({size:8*x,usage:GPUBufferUsage.COPY_DST|GPUBufferUsage.MAP_READ,label:"float16_read_buffer"});return i.queue.writeBuffer(_,0,g),{inputBuffer:_,outputBuffer:v,constantsBuffer:b,readBuffer:y}}(v,g,L);!function(i,g,x,_,v){const b=new ArrayBuffer(16),y=new DataView(b);y.setUint32(0,x,!0),y.setUint32(4,_,!0),y.setFloat32(8,v,!0),i.queue.writeBuffer(g,0,b)}(v,x.constantsBuffer,b,y,w);const{computePipeline:H,bindGroup:z}=function(i,g,x){const _=i.createComputePipeline({layout:"auto",compute:{module:g,entryPoint:"main"},label:"float16_conversion_pipeline"}),v=i.createBindGroup({layout:_.getBindGroupLayout(0),entries:[{binding:0,resource:{buffer:x.inputBuffer}},{binding:1,resource:{buffer:x.outputBuffer}},{binding:2,resource:{buffer:x.constantsBuffer}}],label:"float16_conversion_bindgroup"});return{computePipeline:_,bindGroup:v}}(v,i,x),q=await async function(i,g,x,_,v,b,y,S,w){const L=Math.ceil(b/S[0]),k=Math.ceil(y/S[1]);if(L>65535||k>65535)throw new Error(`이미지 크기 초과:${L} × ${k}`);const H=i.createCommandEncoder(),z=H.beginComputePass();z.setPipeline(g),z.setBindGroup(0,x),z.dispatchWorkgroups(L,k),z.end(),H.copyBufferToBuffer(_,0,v,0,8*w),i.queue.submit([H.finish()]),await v.mapAsync(GPUMapMode.READ);const q=new Uint32Array(v.getMappedRange()),W=new Uint16Array(q.buffer.slice(q.byteOffset,q.byteOffset+q.byteLength));return v.unmap(),W}(v,H,z,x.outputBuffer,x.readBuffer,b,y,S,L);!function(i){i.inputBuffer.destroy(),i.outputBuffer.destroy(),i.constantsBuffer.destroy(),i.readBuffer.destroy()}(x);return{data:q,processedPixels:L,executionTime:performance.now()-_}}catch(i){throw console.error("Float16 변환 실패:",i),i}}class HDRTexture extends ManagementResourceBase{#L;#A;#N=0;#Bm=new HDRLoader;#F="rgba16float";#H;#z;#Bt=0;#It=0;constructor(i,g,x,_){if(super(i,"managedHDRTextureState"),this.#H=x,this.#z=_,g){const i=this.#$(g);this.#Im(i),this.#A=i,this.cacheKey=this.#K(g);const{table:x}=this.targetResourceManagedState;let _=x.get(this.cacheKey);if(_){const i=_.texture;return this.#H?.(i),i}this.src=g,this.#X()}}get width(){return this.#Bt}get height(){return this.#It}get videoMemorySize(){return this.#N}get gpuTexture(){return this.#L}get src(){return this.#A}set src(i){const g=this.#$(i);this.#Im(g),this.#A=g,this.cacheKey=this.#K(i),this.#A&&this.#Em(this.#A)}destroy(){const i=this.#L;this.#q(null),this.__fireListenerList(!0),this.#W(),this.#A=null,this.cacheKey=null,i&&i.destroy()}#K(i){let g;return i||(g=this.uuid),g="string"==typeof i?getAbsoluteURL(window.location.href,i):i.cacheKey||getAbsoluteURL(window.location.href,i.src),`HDRTexture_${g}`}#$(i){return"string"==typeof i?i:i.src}#Im(i){if(!i||"string"!=typeof i)throw new Error("HDR 파일 경로가 필요합니다");if(!i.split("?")[0].split("#")[0].toLowerCase().endsWith(".hdr"))throw new Error(`지원되지 않는 형식입니다. .hdr 형식만 지원됩니다. 입력된 파일:${i}`)}async#Em(i){try{const g=await this.#Bm.loadHDRFile(i);this.#Bt=g.width,this.#It=g.height,await this.#Y(g),this.#H?.(this),this.__fireListenerList()}catch(i){console.error("HDR loading error:",i),this.#z?.(i)}}async#Y(i){const{gpuDevice:g}=this.redGPUContext,x=this.#L,_={size:[this.#Bt,this.#It,1],format:this.#F,usage:GPUTextureUsage.TEXTURE_BINDING|GPUTextureUsage.COPY_DST,label:`HDRTexture_2D_${this.#A}`},v=g.createTexture(_),b=await float32ToFloat16Linear(this.redGPUContext,i.data,{width:this.#Bt,height:this.#It,workgroupSize:[8,8]});g.queue.writeTexture({texture:v},b.data.buffer,{bytesPerRow:8*this.#Bt,rowsPerImage:this.#It},{width:this.#Bt,height:this.#It}),this.#q(v),x&&(await g.queue.onSubmittedWorkDone(),x.destroy())}#q(i){this.targetResourceManagedState.videoMemory-=this.#N,this.#L=i,this.#N=i?calculateTextureByteSize(i):0,this.targetResourceManagedState.videoMemory+=this.#N,this.__fireListenerList()}#X(){this.redGPUContext.resourceManager.registerManagementResource(this,new ResourceStateHDRTexture(this))}#W(){this.redGPUContext.resourceManager.unregisterManagementResource(this)}}Object.freeze(HDRTexture);const Rs={MODE_1D:1,MODE_2D:2,MODE_3D:3};Object.freeze(Rs);const Ps="managedBitmapTextureState",Bs={animationSpeed:1,animationX:.1,animationY:.1};class ANoiseTexture extends ManagementResourceBase{mipLevelCount;useMipmap;src;#L;#me=8;#pe=8;#Or=1;#Nr;#Vr;#Fr;#Hr;#Xn;#Dm;#Bt;#It;#Um;#Lm=0;#Am=1;#Gm=Bs.animationX;#km=Bs.animationY;#N=0;constructor(i,g=1024,x=1024,_){super(i,Ps),validateUintRange(g,2,2048),validateUintRange(x,2,2048),this.#Bt=g,this.#It=x,this.#Um=_,this.#ne(i),this.cacheKey=`NoiseTexture_${g}x${x}_${Date.now()}`,this.#L=this.#ui(i,g,x),this.#N=calculateTextureByteSize(this.#L),this.#ci(),this.#X()}get videoMemorySize(){return this.#N}get resourceManagerKey(){return Ps}get animationSpeed(){return this.#Am}set animationSpeed(i){validatePositiveNumberRange(i),this.#Am=i,this.updateUniform("animationSpeed",i)}get animationX(){return this.#Gm}set animationX(i){validateNumber(i),this.#Gm=i,this.updateUniform("animationX",i)}get animationY(){return this.#km}set animationY(i){validateNumber(i),this.#km=i,this.updateUniform("animationY",i)}get uniformInfo(){return this.#Dm}get gpuTexture(){return this.#L}get time(){return this.#Lm}set time(i){validatePositiveNumberRange(i),this.#Lm=i,this.updateUniform("time",i/1e3)}updateUniform(i,g){this.#Dm.members[i]&&(this.#Xn.writeOnlyBuffer(this.#Dm.members[i],g),this.#Um[i]=g),this.#ci()}updateUniforms(i){Object.entries(i).forEach(([i,g])=>{this.#Dm.members[i]&&(this.#Xn.writeOnlyBuffer(this.#Dm.members[i],g),this.#Um[i]=g)}),this.#ci()}render(i){this.updateUniform("time",i),this.#ci()}destroy(){const i=this.#L;this.__fireListenerList(!0),this.#W(),i&&i.destroy(),this.src=null,this.cacheKey=null,this.#L=null}#ne(i){const{gpuDevice:g}=i,x=this.#Om();this.cacheKey=this.uuid,this.#Nr=g.createShaderModule({code:x}),this.#Fr=this.#si(i),this.#Hr=this.#oi(g,this.#Nr,this.#Fr);const _=parseWGSL(x);this.#Dm=_.uniforms.uniforms;const v=new ArrayBuffer(this.#Dm.arrayBufferByteLength);this.#Xn=new UniformBuffer(i,v,`${this.constructor.name}_UniformBuffer`),this.#Um.uniformDefaults&&this.updateUniforms({...Bs,...this.#Um.uniformDefaults})}#Om(){return` ${` struct Uniforms { time:f32, animationSpeed:f32, animationX:f32, animationY:f32, ${this.#Um.uniformStruct||""} }; `} @group(0) @binding(0) var uniforms:Uniforms; @group(0) @binding(1) var outputTexture:texture_storage_2d; ${this.#Um.helperFunctions||""} @compute @workgroup_size(${this.#me},${this.#pe},${this.#Or}) fn main ( @builtin(global_invocation_id) global_id:vec3, ){ let index=vec2(global_id.xy); let dimensions:vec2=textureDimensions(outputTexture); if (index.x >=dimensions.x || index.y >=dimensions.y) { return; } let dimW=f32(dimensions.x); let dimH=f32(dimensions.y); let base_uv=vec2((f32(index.x) + 0.5)/dimW,(f32(index.y) + 0.5)/dimH); ${this.#Um.mainLogic} textureStore(outputTexture,index,finalColor); } `}#ci(){if(!this.#Vr)return;const i=this.redGPUContext.gpuDevice.createCommandEncoder(),g=i.beginComputePass();g.setPipeline(this.#Hr),g.setBindGroup(0,this.#Vr),g.dispatchWorkgroups(Math.ceil(this.#Bt/this.#me),Math.ceil(this.#It/this.#pe)),g.end(),this.redGPUContext.gpuDevice.queue.submit([i.finish()])}#si(i){return i.resourceManager.createBindGroupLayout("NoiseTextureBindGroupLayout",{entries:[{binding:0,visibility:GPUShaderStage.COMPUTE,buffer:{type:"uniform"}},{binding:1,visibility:GPUShaderStage.COMPUTE,storageTexture:{format:"rgba8unorm"}}]})}#ui(i,g,x){const _=i.gpuDevice.createTexture({size:{width:g,height:x},format:"rgba8unorm",usage:GPUTextureUsage.TEXTURE_BINDING|GPUTextureUsage.STORAGE_BINDING,label:this.cacheKey}),v=_.createView();return this.#Vr=this.#li(i,this.#Fr,v),_}#li(i,g,x){return i.gpuDevice.createBindGroup({layout:g,entries:[{binding:0,resource:{buffer:this.#Xn.gpuBuffer,offset:0,size:this.#Xn.gpuBuffer.size}},{binding:1,resource:x}]})}#oi(i,g,x){return i.createComputePipeline({layout:i.createPipelineLayout({bindGroupLayouts:[x]}),compute:{module:g,entryPoint:"main"}})}#X(){this.redGPUContext.resourceManager.registerManagementResource(this,new ResourceStateBitmapTexture(this))}#W(){this.redGPUContext.resourceManager.unregisterManagementResource(this)}}const mergerNoiseUniformStruct=(i,g)=>[i,g].filter(Boolean).join("\n"),mergerNoiseUniformDefault=(i,g)=>({...i,...g||{}}),mergerNoiseHelperFunctions=(i,g)=>[i,g].filter(Boolean).join("\n");const Is=Object.values(Rs),Es={frequency:8,amplitude:1,octaves:1,persistence:.5,lacunarity:2,seed:0,noiseDimension:Rs.MODE_2D};const Ds={EUCLIDEAN:0,MANHATTAN:1,CHEBYSHEV:2};Object.freeze(Ds);const Us={F1:0,F2:1,F2_MINUS_F1:2,F1_PLUS_F2:3,CELL_ID:4,CELL_ID_COLOR:5};Object.freeze(Us);const Ls=Object.values(Ds),As=Object.values(Us),Gs={frequency:8,distanceScale:1,octaves:1,persistence:.5,lacunarity:2,seed:0,distanceType:Ds.EUCLIDEAN,outputType:Us.F1,jitter:1,cellIdColorIntensity:1};var ks=Object.freeze({__proto__:null,ANoiseTexture:ANoiseTexture,mergerNoiseHelperFunctions:mergerNoiseHelperFunctions,mergerNoiseUniformDefault:mergerNoiseUniformDefault,mergerNoiseUniformStruct:mergerNoiseUniformStruct});class IBL{#l;#Nm;#Vm;#Fm;#Hm;#zm;#$m;#Km;#Xm;#jm=!1;constructor(i,g,x=1024,_=512,v=64){const b=`${g}?key=${x}_${_}_${v}`;this.#Km=_,this.#$m=x,this.#Xm=v,this.#l=i,this.#Vm=new IBLCubeTexture(i,`IBL_ENV_${b}`),this.#Hm=new IBLCubeTexture(i,`IBL_SPECULAR_${b}`),this.#Fm=new IBLCubeTexture(i,`IBL_IRRADIANCE_${b}`);const onLoad=async i=>{i.__addDirtyPipelineListener(this.#Ym),i.gpuTexture&&await this.#Ym(i)};this.#zm="string"==typeof g?new HDRTexture(i,g,onLoad):new CubeTexture(i,g,!0,onLoad)}#Ym=async i=>{if((i=i||this.#zm)&&i.gpuTexture&&!this.#jm){this.#jm=!0;try{if(i instanceof HDRTexture){const{equirectangularToCubeGenerator:g}=this.#l.resourceManager,x=await g.generate(i.gpuTexture,this.#$m);this.#Nm=x.gpuTexture}else this.#Nm=i.gpuTexture;await this.#qm()}finally{this.#jm=!1}}};get environmentSize(){return this.#$m}get prefilterSize(){return this.#Km}get irradianceSize(){return this.#Xm}get irradianceTexture(){return this.#Fm}get environmentTexture(){return this.#Vm}get prefilterTexture(){return this.#Hm}async#qm(){const{resourceManager:i}=this.#l,{prefilterGenerator:g,irradianceGenerator:x}=i;if(this.#Nm){this.#Vm.gpuTexture=this.#Nm;const i=await g.generate(this.#Nm,this.#Km);this.#Hm.gpuTexture=i.gpuTexture;const _=await x.generate(this.#Nm,this.#Xm);this.#Fm.gpuTexture=_.gpuTexture}}}Object.freeze(IBL);var Os=Object.freeze({__proto__:null,ShaderVariantGenerator:ShaderVariantGenerator,WGSLUniformTypes:WGSLUniformTypes,ensureVertexIndexBuiltin:ensureVertexIndexBuiltin,preprocessWGSL:preprocessWGSL}),Ns=Object.freeze({__proto__:null,BitmapTexture:BitmapTexture,Core:Ms,CoreBuffer:ws,CoreIBL:k,CoreNoiseTexture:ks,CoreVertexBuffer:Cs,CoreWGSLParser:Os,CubeTexture:CubeTexture,HDRTexture:HDRTexture,IBL:IBL,IndexBuffer:IndexBuffer,NOISE_DIMENSION:Rs,PackedTexture:PackedTexture,Sampler:Sampler,SimplexTexture:class extends ANoiseTexture{#Wm=Es.frequency;#Zm=Es.amplitude;#Jm=Es.octaves;#Qm=Es.persistence;#ep=Es.lacunarity;#tp=Es.seed;#np=Es.noiseDimension;constructor(i,g=1024,x=1024,_){super(i,g,x,{..._,mainLogic:_?.mainLogic||" let uv=vec2( (base_uv.x + uniforms.time * ( uniforms.animationX * uniforms.animationSpeed )), (base_uv.y + uniforms.time * ( uniforms.animationY * uniforms.animationSpeed )) ); let noise=getSimplexNoiseByDimension( uv,uniforms ); let finalColor=vec4(noise,noise,noise,1.0); ",uniformStruct:mergerNoiseUniformStruct(" noiseDimension:f32, frequency:f32, amplitude:f32, octaves:i32, persistence:f32, lacunarity:f32, seed:f32, ",_?.uniformStruct),uniformDefaults:mergerNoiseUniformDefault(Es,_?.uniformDefaults),helperFunctions:mergerNoiseHelperFunctions("\nfn mod289_vec3(x:vec3) -> vec3 { return x - floor(x * (1.0/289.0)) * 289.0;\n}\nfn mod289_vec2(x:vec2) -> vec2 { return x - floor(x * (1.0/289.0)) * 289.0;\n}\nfn mod289_vec4(x:vec4) -> vec4 { return x - floor(x * (1.0/289.0)) * 289.0;\n}\nfn mod289_f32(x:f32) -> f32 { return x - floor(x * (1.0/289.0)) * 289.0;\n}\nfn permute(x:vec3) -> vec3 { return mod289_vec3(((x * 34.0) + 1.0) * x);\n}\nfn permute4(x:vec4) -> vec4 { return mod289_vec4(((x * 34.0) + 1.0) * x);\n}\nfn permute_f32(x:f32) -> f32 { return mod289_f32(((x * 34.0) + 1.0) * x);\n}\nfn taylorInvSqrt4(r:vec4) -> vec4 { return 1.79284291400159 - 0.85373472095314 * r;\n}\nfn simplex1D(x:f32) -> f32 { var i=floor(x); let f=fract(x); let g0=select(-1.0,1.0,(permute_f32(i) * 0.024390243902439) >=0.5); let g1=select(-1.0,1.0,(permute_f32(i + 1.0) * 0.024390243902439) >=0.5); let d0=f; let d1=f - 1.0; let t=f * f * f * (f * (f * 6.0 - 15.0) + 10.0); let n0=g0 * d0; let n1=g1 * d1; return mix(n0,n1,t) * 0.395;\n}\nfn simplex2D(v:vec2) -> f32 { let C=vec4(0.211324865405187,0.366025403784439,-0.577350269189626,0.024390243902439); var i=floor(v + dot(v,C.yy)); let x0=v - i + dot(i,C.xx); let i1=select(vec2(0.0,1.0),vec2(1.0,0.0),x0.x > x0.y); var x12=x0.xyxy + C.xxzz; x12.x=x12.x - i1.x; x12.y=x12.y - i1.y; i=mod289_vec2(i); let p=permute(permute(i.y + vec3(0.0,i1.y,1.0)) + i.x + vec3(0.0,i1.x,1.0)); var m=max(0.5 - vec3(dot(x0,x0),dot(x12.xy,x12.xy),dot(x12.zw,x12.zw)),vec3(0.0)); m=m * m; m=m * m; let x=2.0 * fract(p * C.www) - 1.0; let h=abs(x) - 0.5; let ox=floor(x + 0.5); let a0=x - ox; m=m * (1.79284291400159 - 0.85373472095314 * (a0 * a0 + h * h)); let g=vec3(a0.x * x0.x + h.x * x0.y,a0.y * x12.x + h.y * x12.y,a0.z * x12.z + h.z * x12.w); return 130.0 * dot(m,g);\n}\nfn simplex3D(v:vec3) -> f32 { let C=vec2(1.0/6.0,1.0/3.0); let D=vec4(0.0,0.5,1.0,2.0); var i=floor(v + dot(v,C.yyy)); let x0=v - i + dot(i,C.xxx); let g=step(x0.yzx,x0.xyz); let l=1.0 - g; let i1=min(g.xyz,l.zxy); let i2=max(g.xyz,l.zxy); let x1=x0 - i1 + C.xxx; let x2=x0 - i2 + C.yyy; let x3=x0 - D.yyy; i=mod289_vec3(i); let p=permute4(permute4(permute4( i.z + vec4(0.0,i1.z,i2.z,1.0 )) + i.y + vec4(0.0,i1.y,i2.y,1.0 )) + i.x + vec4(0.0,i1.x,i2.x,1.0 )); let n_=0.142857142857; let ns=n_ * D.wyz - D.xzx; let j=p - 49.0 * floor(p * ns.z * ns.z); let x_=floor(j * ns.z); let y_=floor(j - 7.0 * x_ ); let x=x_ *ns.x + ns.yyyy; let y=y_ *ns.x + ns.yyyy; let h=1.0 - abs(x) - abs(y); let b0=vec4( x.xy,y.xy ); let b1=vec4( x.zw,y.zw ); let s0=floor(b0)*2.0 + 1.0; let s1=floor(b1)*2.0 + 1.0; let sh=-step(h,vec4(0.0)); let a0=b0.xzyw + s0.xzyw*sh.xxyy; let a1=b1.xzyw + s1.xzyw*sh.zzww; var p0=vec3(a0.xy,h.x); var p1=vec3(a0.zw,h.y); var p2=vec3(a1.xy,h.z); var p3=vec3(a1.zw,h.w); let norm=taylorInvSqrt4(vec4(dot(p0,p0),dot(p1,p1),dot(p2,p2),dot(p3,p3))); p0 *=norm.x; p1 *=norm.y; p2 *=norm.z; p3 *=norm.w; var m=max(0.6 - vec4(dot(x0,x0),dot(x1,x1),dot(x2,x2),dot(x3,x3)),vec4(0.0)); m=m * m; return 42.0 * dot( m*m,vec4( dot(p0,x0),dot(p1,x1), dot(p2,x2),dot(p3,x3) ) );\n}\nfn fbm1D(pos:f32,octaves:i32) -> f32 { var value=0.0; var amplitude=0.5; var frequency=1.0; var max_value=0.0; for (var i=0;i < octaves;i++) { if (i >=octaves) { break;} value +=simplex1D(pos * frequency) * amplitude; max_value +=amplitude; amplitude *=0.5; frequency *=2.0; } return value/max_value;\n}\nfn fbm(pos:vec2,octaves:i32) -> f32 { var value=0.0; var amplitude=0.5; var frequency=1.0; var max_value=0.0; for (var i=0;i < octaves;i++) { if (i >=octaves) { break;} value +=simplex2D(pos * frequency) * amplitude; max_value +=amplitude; amplitude *=0.5; frequency *=2.0; } return value/max_value;\n}\nfn fbm3D(pos:vec3,octaves:i32) -> f32 { var value=0.0; var amplitude=0.5; var frequency=1.0; var max_value=0.0; for (var i=0;i < octaves;i++) { if (i >=octaves) { break;} value +=simplex3D(pos * frequency) * amplitude; max_value +=amplitude; amplitude *=0.5; frequency *=2.0; } return value/max_value;\n}\nfn getSimplexNoise1D(pos:f32,uniforms:Uniforms) -> f32 { var total_amplitude:f32=0.0; var noise_value:f32=0.0; var current_amplitude:f32=1.0; var current_frequency:f32=uniforms.frequency; for (var i:i32=0;i < uniforms.octaves;i++) { let noise_pos=(pos + uniforms.seed) * current_frequency; let octave_noise=simplex1D(noise_pos); noise_value +=octave_noise * current_amplitude; total_amplitude +=current_amplitude; current_amplitude *=uniforms.persistence; current_frequency *=uniforms.lacunarity; } noise_value/=total_amplitude; noise_value *=uniforms.amplitude; let normalized_noise=(noise_value + 1.0) * 0.5; return normalized_noise;\n}\nfn getSimplexNoise2D(uv:vec2,uniforms:Uniforms) -> f32 { var total_amplitude:f32=0.0; var noise_value:f32=0.0; var current_amplitude:f32=1.0; var current_frequency:f32=uniforms.frequency; for (var i:i32=0;i < uniforms.octaves;i++) { let noise_pos=(uv + uniforms.seed) * current_frequency; let octave_noise=simplex2D(noise_pos); noise_value +=octave_noise * current_amplitude; total_amplitude +=current_amplitude; current_amplitude *=uniforms.persistence; current_frequency *=uniforms.lacunarity; } noise_value/=total_amplitude; noise_value *=uniforms.amplitude; let normalized_noise=(noise_value + 1.0) * 0.5; return normalized_noise;\n}\nfn getSimplexNoise3D(pos:vec3,uniforms:Uniforms) -> f32 { var total_amplitude:f32=0.0; var noise_value:f32=0.0; var current_amplitude:f32=1.0; var current_frequency:f32=uniforms.frequency; for (var i:i32=0;i < uniforms.octaves;i++) { let noise_pos=(pos + vec3(uniforms.seed)) * current_frequency; let octave_noise=simplex3D(noise_pos); noise_value +=octave_noise * current_amplitude; total_amplitude +=current_amplitude; current_amplitude *=uniforms.persistence; current_frequency *=uniforms.lacunarity; } noise_value/=total_amplitude; noise_value *=uniforms.amplitude; let normalized_noise=(noise_value + 1.0) * 0.5; return normalized_noise;\n}\nfn getSimplexNoiseByDimension(uv:vec2,uniforms:Uniforms) -> f32 { if (uniforms.noiseDimension < 1.1) { return getSimplexNoise1D(uv.x,uniforms); } else if (uniforms.noiseDimension < 2.1) { return getSimplexNoise2D(uv,uniforms); } else if (uniforms.noiseDimension < 3.1) { return getSimplexNoise3D(vec3(uv.x,uv.y,uniforms.seed * 0.1),uniforms); } else { return getSimplexNoise2D(uv,uniforms); }\n}\n",_?.helperFunctions)})}get noiseDimension(){return this.#np}set noiseDimension(i){Is.includes(i)?(this.#np=i,this.updateUniform("noiseDimension",i)):consoleAndThrowError(`Invalid value for noiseDimension. Received ${i}. Expected one of:${Is.join(",")}`)}get frequency(){return this.#Wm}set frequency(i){validatePositiveNumberRange(i),this.#Wm=i,this.updateUniform("frequency",i)}get amplitude(){return this.#Zm}set amplitude(i){validatePositiveNumberRange(i),this.#Zm=i,this.updateUniform("amplitude",i)}get octaves(){return this.#Jm}set octaves(i){validateUintRange(i,1,8),this.#Jm=i,this.updateUniform("octaves",i)}get persistence(){return this.#Qm}set persistence(i){validatePositiveNumberRange(i,0,1),this.#Qm=i,this.updateUniform("persistence",i)}get lacunarity(){return this.#ep}set lacunarity(i){validatePositiveNumberRange(i),this.#ep=i,this.updateUniform("lacunarity",i)}get seed(){return this.#tp}set seed(i){this.#tp=i,this.updateUniform("seed",i)}randomizeSeed(){this.seed=1e3*Math.random()}getSettings(){return{frequency:this.#Wm,amplitude:this.#Zm,octaves:this.#Jm,persistence:this.#Qm,lacunarity:this.#ep,seed:this.#tp}}applySettings(i){void 0!==i.frequency&&(this.frequency=i.frequency),void 0!==i.amplitude&&(this.amplitude=i.amplitude),void 0!==i.octaves&&(this.octaves=i.octaves),void 0!==i.persistence&&(this.persistence=i.persistence),void 0!==i.lacunarity&&(this.lacunarity=i.lacunarity),void 0!==i.seed&&(this.seed=i.seed)}},StorageBuffer:StorageBuffer,UniformBuffer:UniformBuffer,VORONOI_DISTANCE_TYPE:Ds,VORONOI_OUTPUT_TYPE:Us,VertexBuffer:VertexBuffer,VertexInterleaveType:VertexInterleaveType,VertexInterleavedStruct:VertexInterleavedStruct,VoronoiTexture:class extends ANoiseTexture{#Wm=Gs.frequency;#rp=Gs.distanceScale;#Jm=Gs.octaves;#Qm=Gs.persistence;#ep=Gs.lacunarity;#tp=Gs.seed;#ip=Gs.distanceType;#ap=Gs.outputType;#sp=Gs.jitter;#op=Gs.cellIdColorIntensity;constructor(i,g=1024,x=1024,_){super(i,g,x,{..._,mainLogic:_?.mainLogic||" let uv=vec2( (base_uv.x + uniforms.time * (uniforms.animationX * uniforms.animationSpeed)), (base_uv.y + uniforms.time * (uniforms.animationY * uniforms.animationSpeed)) ); var finalColor:vec4; if (uniforms.outputType==5) { let colorNoise=getVoronoiColorNoise(uv,uniforms); finalColor=vec4(colorNoise,1.0); } else { let noise=getVoronoiNoise(uv,uniforms); finalColor=vec4(noise,noise,noise,1.0); } ",uniformStruct:mergerNoiseUniformStruct(" frequency:f32, distanceScale:f32, octaves:i32, persistence:f32, lacunarity:f32, seed:f32, distanceType:i32, outputType:i32, jitter:f32, cellIdColorIntensity:f32, ",_?.uniformStruct),uniformDefaults:mergerNoiseUniformDefault(Gs,_?.uniformDefaults),helperFunctions:mergerNoiseHelperFunctions("fn hash22(p:vec2) -> vec2 { var p3=fract(vec3(p.xyx) * vec3(0.1031,0.1030,0.0973)); p3 +=dot(p3,p3.yzx + 33.33); return fract((p3.xx + p3.yz) * p3.zy);\n}\nfn hash12(p:vec2) -> f32 { var p3=fract(vec3(p.xyx) * 0.1031); p3 +=dot(p3,p3.yzx + 33.33); return fract((p3.x + p3.y) * p3.z);\n}\nfn euclideanDistance(a:vec2,b:vec2) -> f32 { let d=a - b; return sqrt(d.x * d.x + d.y * d.y);\n}\nfn manhattanDistance(a:vec2,b:vec2) -> f32 { let d=abs(a - b); return d.x + d.y;\n}\nfn chebyshevDistance(a:vec2,b:vec2) -> f32 { let d=abs(a - b); return max(d.x,d.y);\n}\nfn calculateDistance(a:vec2,b:vec2,distanceType:i32) -> f32 { switch (distanceType) { case 0:{ return euclideanDistance(a,b);} case 1:{ return manhattanDistance(a,b);} case 2:{ return chebyshevDistance(a,b);} default:{ return euclideanDistance(a,b);} }\n}\nfn cellIdToColor(cellId:f32,intensity:f32) -> vec3 { let h=cellId * 6.28318; let s=0.7 + 0.3 * fract(cellId * 7.0); let v=0.6 + 0.4 * fract(cellId * 13.0); let c=v * s; let x=c * (1.0 - abs(((h/1.047198) % 2.0) - 1.0)); let m=v - c; var rgb:vec3; let sector=i32(h/1.047198) % 6; switch (sector) { case 0:{ rgb=vec3(c,x,0.0);} case 1:{ rgb=vec3(x,c,0.0);} case 2:{ rgb=vec3(0.0,c,x);} case 3:{ rgb=vec3(0.0,x,c);} case 4:{ rgb=vec3(x,0.0,c);} default:{ rgb=vec3(c,0.0,x);} } return (rgb + m) * intensity;\n}\nstruct VoronoiResult { f1:f32, f2:f32, cellId:f32,\n}\nfn voronoiSingle(pos:vec2,frequency:f32,seed:f32,jitter:f32,distanceType:i32) -> VoronoiResult { let scaledPos=pos * frequency; let gridPos=floor(scaledPos); let localPos=fract(scaledPos); var minDist1=999.0; var minDist2=999.0; var closestCellId=0.0; for (var y=-1;y <=1;y++) { for (var x=-1;x <=1;x++) { let neighborGrid=gridPos + vec2(f32(x),f32(y)); let randomOffset=hash22(neighborGrid + seed); let jitteredOffset=mix(vec2(0.5),randomOffset,jitter); let cellPoint=vec2(f32(x),f32(y)) + jitteredOffset; let dist=calculateDistance(localPos,cellPoint,distanceType); if (dist < minDist1) { minDist2=minDist1; minDist1=dist; closestCellId=hash12(neighborGrid + seed); } else if (dist < minDist2) { minDist2=dist; } } } return VoronoiResult(minDist1,minDist2,closestCellId);\n}\nfn getVoronoiNoise(uv:vec2,uniforms:Uniforms) -> f32 { var total=0.0; var frequency=uniforms.frequency; var amplitude=1.0; var maxValue=0.0; for (var i=0;i < uniforms.octaves;i++) { let voronoiResult=voronoiSingle( uv, frequency, uniforms.seed + f32(i) * 100.0, uniforms.jitter, uniforms.distanceType ); let F1=voronoiResult.f1 * uniforms.distanceScale; let F2=voronoiResult.f2 * uniforms.distanceScale; let cellId=voronoiResult.cellId; var octaveValue:f32; switch (uniforms.outputType) { case 0:{ octaveValue=F1;} case 1:{ octaveValue=F2;} case 2:{ octaveValue=F2 - F1;} case 3:{ octaveValue=(F1 + F2) * 0.5;} case 4:{ octaveValue=cellId;} case 5:{ let colorRGB=cellIdToColor(cellId,uniforms.cellIdColorIntensity); octaveValue=(colorRGB.r + colorRGB.g + colorRGB.b)/3.0; } default:{ octaveValue=F1;} } total +=octaveValue * amplitude; maxValue +=amplitude; frequency *=uniforms.lacunarity; amplitude *=uniforms.persistence; } return clamp(total/maxValue,0.0,1.0);\n}\nfn getVoronoiColorNoise(uv:vec2,uniforms:Uniforms) -> vec3 { if (uniforms.outputType==5) { let voronoiResult=voronoiSingle( uv, uniforms.frequency, uniforms.seed, uniforms.jitter, uniforms.distanceType ); return cellIdToColor(voronoiResult.cellId,uniforms.cellIdColorIntensity); } else { let grayValue=getVoronoiNoise(uv,uniforms); return vec3(grayValue,grayValue,grayValue); }\n}\n",_?.helperFunctions)})}get frequency(){return this.#Wm}set frequency(i){validatePositiveNumberRange(i),this.#Wm=i,this.updateUniform("frequency",i)}get distanceScale(){return this.#rp}set distanceScale(i){validatePositiveNumberRange(i),this.#rp=i,this.updateUniform("distanceScale",i)}get octaves(){return this.#Jm}set octaves(i){validateUintRange(i,1,8),this.#Jm=i,this.updateUniform("octaves",i)}get persistence(){return this.#Qm}set persistence(i){validatePositiveNumberRange(i,0,1),this.#Qm=i,this.updateUniform("persistence",i)}get lacunarity(){return this.#ep}set lacunarity(i){validatePositiveNumberRange(i),this.#ep=i,this.updateUniform("lacunarity",i)}get seed(){return this.#tp}set seed(i){this.#tp=i,this.updateUniform("seed",i)}get distanceType(){return this.#ip}set distanceType(i){Ls.includes(i)?(this.#ip=i,this.updateUniform("distanceType",i)):consoleAndThrowError(`Invalid value for distanceType. Received ${i}. Expected one of:${Ls.join(",")}`)}get outputType(){return this.#ap}set outputType(i){As.includes(i)?(this.#ap=i,this.updateUniform("outputType",i)):consoleAndThrowError(`Invalid value for outputType. Received ${i}. Expected one of:${As.join(",")}`)}get jitter(){return this.#sp}set jitter(i){validatePositiveNumberRange(i,0,1),this.#sp=i,this.updateUniform("jitter",i)}get cellIdColorIntensity(){return this.#op}set cellIdColorIntensity(i){validatePositiveNumberRange(i),this.#op=i,this.updateUniform("cellIdColorIntensity",i)}randomizeSeed(){this.seed=1e3*Math.random()}setEuclideanDistance(){this.distanceType=Ds.EUCLIDEAN}setManhattanDistance(){this.distanceType=Ds.MANHATTAN}setChebyshevDistance(){this.distanceType=Ds.CHEBYSHEV}setF1Output(){this.outputType=Us.F1}setF2Output(){this.outputType=Us.F2}setCrackPattern(){this.outputType=Us.F2_MINUS_F1}setSmoothBlend(){this.outputType=Us.F1_PLUS_F2}setCellIdOutput(){this.outputType=Us.CELL_ID}setCellIdColorOutput(){this.outputType=Us.CELL_ID_COLOR}setCellularPattern(){this.outputType=Us.F1,this.distanceType=Ds.EUCLIDEAN,this.jitter=1}setStonePattern(){this.outputType=Us.F2_MINUS_F1,this.distanceType=Ds.EUCLIDEAN,this.jitter=.8}setOrganicPattern(){this.distanceType=Ds.MANHATTAN,this.jitter=.6}setGridPattern(){this.jitter=0,this.distanceType=Ds.EUCLIDEAN}setCrystalPattern(){this.outputType=Us.F2_MINUS_F1,this.distanceType=Ds.CHEBYSHEV,this.jitter=.9}setStainedGlassPattern(){this.outputType=Us.CELL_ID_COLOR,this.distanceType=Ds.EUCLIDEAN,this.jitter=.7,this.cellIdColorIntensity=.8}setMosaicPattern(){this.outputType=Us.CELL_ID_COLOR,this.distanceType=Ds.MANHATTAN,this.jitter=.3,this.cellIdColorIntensity=1}setBiomeMapPattern(){this.outputType=Us.CELL_ID,this.distanceType=Ds.EUCLIDEAN,this.jitter=.8,this.frequency=4}getSettings(){return{frequency:this.#Wm,distanceScale:this.#rp,octaves:this.#Jm,persistence:this.#Qm,lacunarity:this.#ep,seed:this.#tp,distanceType:this.#ip,outputType:this.#ap,jitter:this.#sp,cellIdColorIntensity:this.#op}}applySettings(i){void 0!==i.frequency&&(this.frequency=i.frequency),void 0!==i.distanceScale&&(this.distanceScale=i.distanceScale),void 0!==i.octaves&&(this.octaves=i.octaves),void 0!==i.persistence&&(this.persistence=i.persistence),void 0!==i.lacunarity&&(this.lacunarity=i.lacunarity),void 0!==i.seed&&(this.seed=i.seed),void 0!==i.distanceType&&(this.distanceType=i.distanceType),void 0!==i.outputType&&(this.outputType=i.outputType),void 0!==i.jitter&&(this.jitter=i.jitter),void 0!==i.cellIdColorIntensity&&(this.cellIdColorIntensity=i.cellIdColorIntensity)}getDistanceTypeName(){return{[Ds.EUCLIDEAN]:"Euclidean",[Ds.MANHATTAN]:"Manhattan",[Ds.CHEBYSHEV]:"Chebyshev"}[this.#ip]||"Unknown"}getOutputTypeName(){return{[Us.F1]:"F1",[Us.F2]:"F2",[Us.F2_MINUS_F1]:"F2-F1 (Crack)",[Us.F1_PLUS_F2]:"F1+F2 (Blend)",[Us.CELL_ID]:"Cell ID",[Us.CELL_ID_COLOR]:"Cell ID Color"}[this.#ap]||"Unknown"}},parseWGSL:parseWGSL});class GltfAnimationLooperManager{#up=60;#lp=1e3/this.#up;#qi=0;#cp=0;render=(i,g,x,_)=>{const v=g;this.#qi;this.#lp,this.#qi=v,this.#cp++;const b=et,y=180/Math.PI;let S,w,L,k,H,z,q,W,be,Ke,Xe,je,Ye,Ze,Je,Qe,tt,it,ft,pt,xt,vt,bt,yt,St,Tt,Mt,wt,Ct,Rt,Pt,Bt,It,Et,Dt,Ut,Lt,At,Gt,kt,Ot,Nt,Vt,Ft,Ht,zt,$t,Kt,Xt,jt,Yt,qt,Wt,Zt,Jt,Qt,en,tn,nn,rn,an,sn,on,un,cn,hn,fn,dn,mn=_.length;for(;mn--;){an=_[mn],rn=an.targetGLTFParsedSingleClip,nn=rn.length;const v=rn.maxTime;for(;nn--;){sn=rn[nn],on=sn.cacheTable;const{animationTargetMesh:_,timeAnimationInfo:et,aniDataAnimationInfo:mn,weightMeshes:pn}=sn;_.dirtyTransform=!0,Jt=(g-an.startTime)%(1e3*v)/1e3,hn=et.dataList,fn=mn.dataList,dn=hn.length;const gn=sn.lastPrevIdx||0;if(gn=hn[dn-1])cn=dn-1,un=0;else{let i=0,g=dn-1;for(;i>1;hn[x]<=Jt?i=x:g=x}cn=i,un=g}else if(Jt<=hn[0])cn=dn-1,un=0;else if(Jt>=hn[dn-1])cn=dn-1,un=0;else{let i=0,g=dn-1;for(;i>1;hn[x]<=Jt?i=x:g=x}cn=i,un=g}let xn,_n,vn,bn,yn,Sn,Tn;sn.lastPrevIdx=cn,Qt=hn[cn],en=hn[un];const Mn=sn.interpolation;if("CUBICSPLINE"==Mn){const i=en-Qt;tn=i==i?i:0;const g=(Jt-Qt)/tn;xn=g==g?g:0,_n=xn*xn,vn=_n*xn,Sn=-2*vn+3*_n,Tn=vn-_n,bn=1-Sn,yn=Tn-_n+xn}else if("STEP"==Mn)tn=0;else{const i=(Jt-Qt)/(en-Qt);tn=i==i?i:0}switch(sn.key){case"rotation":if(cn!==dn-1){if("CUBICSPLINE"===Mn){let i,g,x,_,v,b,y,Je;Gt=12*cn,kt=12*un,S=fn[Gt+4],w=fn[Gt+5],L=fn[Gt+6],k=fn[Gt+7],H=S*S+w*w+L*L+k*k,H>0?(z=1/Math.sqrt(H),q=S*z,W=w*z,be=L*z,Ke=k*z):(q=W=be=0,Ke=1),S=fn[Gt+8],w=fn[Gt+9],L=fn[Gt+10],k=fn[Gt+11],H=S*S+w*w+L*L+k*k,H>0?(z=1/Math.sqrt(H),i=S*z,g=w*z,x=L*z,_=k*z):(i=g=x=0,_=1),S=fn[kt],w=fn[kt+1],L=fn[kt+2],k=fn[kt+3],H=S*S+w*w+L*L+k*k,H>0?(z=1/Math.sqrt(H),v=S*z,b=w*z,y=L*z,Je=k*z):(v=b=y=0,Je=1),S=fn[kt+4],w=fn[kt+5],L=fn[kt+6],k=fn[kt+7],H=S*S+w*w+L*L+k*k,H>0?(z=1/Math.sqrt(H),Xe=S*z,je=w*z,Ye=L*z,Ze=k*z):(Xe=je=Ye=0,Ze=1),S=bn*q+yn*i*tn+Sn*Xe+Tn*v*tn,w=bn*W+yn*g*tn+Sn*je+Tn*b*tn,L=bn*be+yn*x*tn+Sn*Ye+Tn*y*tn,k=bn*Ke+yn*_*tn+Sn*Ze+Tn*Je*tn}else{Gt=cn<<2,kt=un<<2;const i=Gt<<16|kt;let g=on[i];g?(Je=g[0],q=g[1],W=g[2],be=g[3],Ke=g[4],Xe=g[5],je=g[6],Ye=g[7],Ze=g[8]):(S=fn[Gt],w=fn[Gt+1],L=fn[Gt+2],k=fn[Gt+3],H=S*S+w*w+L*L+k*k,H>0?(z=1/Math.sqrt(H),q=S*z,W=w*z,be=L*z,Ke=k*z):(q=W=be=0,Ke=1),S=fn[kt],w=fn[kt+1],L=fn[kt+2],k=fn[kt+3],H=S*S+w*w+L*L+k*k,H>0?(z=1/Math.sqrt(H),Xe=S*z,je=w*z,Ye=L*z,Ze=k*z):(Xe=je=Ye=0,Ze=1),Je=q*Xe+W*je+be*Ye+Ke*Ze,Je<0&&(Je=-Je,Xe=-Xe,je=-je,Ye=-Ye,Ze=-Ze),g=new Float32Array(9),g[0]=Je,g[1]=q,g[2]=W,g[3]=be,g[4]=Ke,g[5]=Xe,g[6]=je,g[7]=Ye,g[8]=Ze,on[i]=g),1-Je>b?(Qe=Math.acos(Je),tt=Math.sin(Qe),it=Math.sin((1-tn)*Qe)/tt,ft=Math.sin(tn*Qe)/tt):(it=1-tn,ft=tn),S=it*q+ft*Xe,w=it*W+ft*je,L=it*be+ft*Ye,k=it*Ke+ft*Ze}pt=S+S,xt=w+w,vt=L+L,bt=S*pt,yt=S*xt,St=S*vt,Tt=w*xt,Mt=w*vt,wt=L*vt,Ct=k*pt,Rt=k*xt,Pt=k*vt,Et=St+Rt,Bt=1-(Tt+wt),It=yt-Pt,Ut=Mt-Ct,At=1-(bt+Tt),Lt=Mt+Ct,Dt=1-(bt+wt),w=Math.asin(Math.max(-1,Math.min(1,Et))),Math.abs(Et)<.99999?(S=Math.atan2(-Ut,At),L=Math.atan2(-It,Bt)):(S=Math.atan2(Lt,Dt),L=0),_.rotationX=S*y,_.rotationY=w*y,_.rotationZ=L*y}break;case"translation":"CUBICSPLINE"===Mn?cn!==dn-1&&(Gt=9*cn,Ot=fn[Gt+3],Nt=fn[Gt+4],Vt=fn[Gt+5],jt=fn[Gt+6],Yt=fn[Gt+7],qt=fn[Gt+8],kt=9*un,$t=fn[kt],Kt=fn[kt+1],Xt=fn[kt+2],Ft=fn[kt+3],Ht=fn[kt+4],zt=fn[kt+5],Wt=jt*tn,Zt=$t*tn,_.x=bn*Ft+yn*Wt+Sn*Ot+Tn*Zt,Wt=Yt*tn,Zt=Kt*tn,_.y=bn*Ht+yn*Wt+Sn*Nt+Tn*Zt,Wt=qt*tn,Zt=Xt*tn,_.z=bn*zt+yn*Wt+Sn*Vt+Tn*Zt):(Gt=3*un,Ot=fn[Gt],Nt=fn[Gt+1],Vt=fn[Gt+2],kt=3*cn,Ft=fn[kt],Ht=fn[kt+1],zt=fn[kt+2],_.x=Ft+tn*(Ot-Ft),_.y=Ht+tn*(Nt-Ht),_.z=zt+tn*(Vt-zt));break;case"scale":"CUBICSPLINE"===Mn?cn!==dn-1&&(Gt=9*cn,Ot=fn[Gt+3],Nt=fn[Gt+4],Vt=fn[Gt+5],jt=fn[Gt+6],Yt=fn[Gt+7],qt=fn[Gt+8],kt=9*un,$t=fn[kt],Kt=fn[kt+1],Xt=fn[kt+2],Ft=fn[kt+3],Ht=fn[kt+4],zt=fn[kt+5],Wt=jt*tn,Zt=$t*tn,_.scaleX=bn*Ft+yn*Wt+Sn*Ot+Tn*Zt,Wt=Yt*tn,Zt=Kt*tn,_.scaleY=bn*Ht+yn*Wt+Sn*Nt+Tn*Zt,Wt=qt*tn,Zt=Xt*tn,_.scaleZ=bn*zt+yn*Wt+Sn*Vt+Tn*Zt):(Gt=3*un,Ot=fn[Gt],Nt=fn[Gt+1],Vt=fn[Gt+2],kt=3*cn,Ft=fn[kt],Ht=fn[kt+1],zt=fn[kt+2],_.scaleX=Ft+tn*(Ot-Ft),_.scaleY=Ht+tn*(Nt-Ht),_.scaleZ=zt+tn*(Vt-zt));break;case"weights":{let g=pn.length;for(;g--;)sn.renderWeight(i,x,pn[g],tn,cn,un);break}}}}}}!function(i,g){void 0===g&&(g={});var x=g.insertAt;if("undefined"!=typeof document){var _=document.head||document.getElementsByTagName("head")[0],v=document.createElement("style");v.type="text/css","top"===x&&_.firstChild?_.insertBefore(v,_.firstChild):_.appendChild(v),v.styleSheet?v.styleSheet.cssText=i:v.appendChild(document.createTextNode(i))}}(".RedGPUDebugPanel{background:rgba(0,0,0,.9);bottom:0;color:#fff;font-size:11px;left:0;line-height:1;max-height:100%;min-width:250px;overflow-y:auto;position:fixed;transform:translateZ(0);width:330px;will-change:transform;z-index:2}.RedGPUDebugPanel::-webkit-scrollbar{width:6px}.RedGPUDebugPanel::-webkit-scrollbar-track{background:#000}.RedGPUDebugPanel::-webkit-scrollbar-thumb{background:#333}.RedGPUDebugPanel::-webkit-scrollbar-thumb:hover{background:#444}.debug-group{line-height:1.4;padding:10px;b{color:#fdb48d;font-weight:700}}.debug-sub-group{background:linear-gradient(90deg,hsla(0,0%,100%,.1),rgba(0,0,0,.01));border:1px solid hsla(0,0%,100%,.16);border-radius:6px;box-shadow:0 0 10px rgba(0,0,0,.16);line-height:1.4;margin:8px 0;padding:6px 10px;b{color:#fdb48d;font-weight:700}}.debug-sub-group-title{color:#e3b096}.debug-item{align-items:center;color:#ccc;display:flex;font-weight:400;gap:10px;justify-content:space-between;transform:translateZ(0);width:100%;will-change:transform;b{color:#fdb48d;font-weight:700}}.boolean-true{background:green}.boolean-false,.boolean-true{border-radius:4px;color:#fff;line-height:1;margin:2px 0;padding:2px 4px}.boolean-false{background:red}.debug-folder{background:rgba(0,0,0,.5);border-bottom:1px solid hsla(0,0%,100%,.05);display:flex;flex-direction:column;width:100%}.debug-folder-title{color:#fdb48d;font-size:15px;b{color:#fdb48d;font-size:11px;font-weight:700}}.debug-folder-small-title,.debug-folder-title{align-items:center;background:linear-gradient(0deg,rgba(0,0,0,.95),hsla(0,0%,100%,.055));cursor:pointer;display:flex;justify-content:space-between;line-height:1;padding:10px 8px;width:100%}.debug-folder-small-title{color:#fff;font-size:12px;b{color:#fdb48d;font-size:11px;font-weight:700}}.debug-folder-title .onoff{font-size:11px}.debug-item-title{color:#888;max-width:240px}.debug-item-cache-key,.debug-item-title{font-weight:500;overflow:hidden;text-overflow:ellipsis;text-shadow:1px 1px 0 rgba(0,0,0,.3)}.debug-item-cache-key{color:#fff;max-width:250px;white-space:nowrap}.div-line{background:hsla(0,0%,100%,.06);border-bottom:1px solid transparent;height:1px;margin:10px 0;width:100%}.root-padding{padding:6px;width:100%}.color-box{border:1px solid hsla(0,0%,100%,.2);border-radius:4px;margin:2px;padding:3px}");const createDebugTitle=i=>`
${i}
`,makeColorDebug=(i,g)=>`\n
\n\x3c!--\t${i} --\x3e\n\t \n\t
${g.rgba}\n\t
\n
\n`,makeBooleanDebug=(i,g)=>`${g?"TRUE":"FALSE"}`,getDebugFormatValue=i=>"boolean"==typeof i?i.toString():"number"==typeof i?i.toLocaleString():i,updateDebugItemValue=(i,g,x,_,v="")=>{const b=i.querySelector(`.${g}`);if(!b)return;const y=`${getDebugFormatValue(x)}${v}`;b.innerHTML!==y&&(b.innerHTML=y,_&&(b.style.background=x?"green":"rgba(255,255,255,0.1)"))};let Vs=class{dom;#hp;#fp=!1;constructor(i){this.#hp=i,this.dom=document.createElement("div"),this.dom.innerHTML=`
\t
${createDebugTitle(`${i} Num: ()`)}\n\x3c!--
${this.#fp?"close":"open"}
--\x3e
\n`}get openYn(){return this.#fp}set openYn(i){this.#fp=i,this.dom.querySelector(".onoff").innerHTML=this.openYn?"close":"open"}update(i,g){const{resourceManager:x}=g;if("Buffer"===this.#hp){const g=x.resources.get("GPUBuffer"),{videoMemory:_}=g;i.totalUsedVideoMemory+=_,updateDebugItemValue(this.dom,"totalCount",g.size),updateDebugItemValue(this.dom,"targetVideoMemorySize",formatBytes(_))}else{const g=x[`managed${this.#hp}State`],{table:_,videoMemory:v}=g;i.totalUsedVideoMemory+=v,updateDebugItemValue(this.dom,"totalCount",_.size),updateDebugItemValue(this.dom,"targetVideoMemorySize",formatBytes(v)),this.#hp}}#dp(i){let g=i;(i.startsWith("Vertex_")||i.startsWith("Index_"))&&(g=i.substring(i.indexOf("_")+1));try{const i=new URL(g),x=i.pathname.split("/").pop()||g;return{host:i.host,filename:x}}catch{return{host:null,filename:g}}}#mp(i){const g=this.dom.querySelector(".item-container"),x=new Set,_=this.#hp,v=new Map;g.querySelectorAll(".debug-group").forEach(i=>{const g=i.className.split(" ")[1].replace(`${_}_`,"");x.add(g),v.set(g,i)});let b=0;i.forEach((i,y)=>{const S=y,w=i.size||0,L=`${_}_${S}`;let k=v.get(S);k?x.delete(S):(k=document.createElement("div"),k.className=`debug-group ${L}`,k.innerHTML=`
${S}
`,g.appendChild(k));const{host:H,filename:z}=this.#dp(y);H?(updateDebugItemValue(k,"host",`${b} ${H}`),updateDebugItemValue(k,"name",z)):updateDebugItemValue(k,"host",`${b} ${y}`),updateDebugItemValue(k,"videoMemorySize",formatBytes(w)),b++});for(let i of x)v.get(i).remove()}#pp(i){const g=this.dom.querySelector(".item-container"),x=new Set,_=this.#hp,v=new Map;g.querySelectorAll(".debug-group").forEach(i=>{const g=i.className.split(" ")[1].replace(`${_}_`,"");x.add(g),v.set(g,i)});let b=0;const y="UniformBuffer"===this.#hp||"StorageBuffer"===this.#hp;i.forEach(i=>{const{useNum:S,buffer:w}=i,{uuid:L,size:k,name:H,gpuBuffer:z}=w,{label:q}=z,W=`${_}_${L}`;let be=v.get(L);be?x.delete(L):(be=document.createElement("div"),be.className=`debug-group ${W}`,be.innerHTML=`
${L}
`,g.appendChild(be));const{host:Ke,filename:Xe}=this.#dp(H);Ke?(updateDebugItemValue(be,"host",`${b} ${Ke}`),updateDebugItemValue(be,"name",Xe)):updateDebugItemValue(be,"host",`${b} ${q}`),y||updateDebugItemValue(be,"useNum",S,!0),updateDebugItemValue(be,"videoMemorySize",formatBytes(k)),b++});for(let i of x)v.get(i).remove()}};class DebugBufferList{debugStatisticsDomService;constructor(i){this.debugStatisticsDomService=new Vs(i)}get dom(){return this.debugStatisticsDomService.dom}update(i,g){this.debugStatisticsDomService.update(i,g)}}class ADebugItem{debugStatisticsDomService;constructor(){}get dom(){return this.debugStatisticsDomService.dom}update(i,g,x){this.debugStatisticsDomService.update(i,g)}}class ADebugStatisticsDomService{dom;#fp=!1;constructor(){}get openYn(){return this.#fp}set openYn(i){this.#fp=i,this.dom.querySelector(".onoff").innerHTML=this.openYn?"close":"open"}init(i,g=!1,x=!1){this.#fp=g,this.dom=document.createElement("div"),this.dom.innerHTML=`
\t
${i}\n\x3c!--
${this.openYn?"close":"open"}
--\x3e
\n`}update(i,g){}}const Fs=["useMSAA","useFXAA","useTAA","alphaMode","renderScale"];let Hs=class extends ADebugStatisticsDomService{constructor(){super(),this.init(`${createDebugTitle("RedGPUContext")}`,!0),this.#pp()}update(i,g){Fs.forEach(i=>this.#gp(g,i)),this.#xp(g)}#pp(){const i=this.dom.querySelector(".item-container"),g=['
',...Fs.map(i=>this.#_p(i)),this.#_p("width_height"),this.#_p("pixelRectArray"),this.#_p("backgroundColor"),"
"];i.innerHTML=g.join("")}#_p(i){return`
${i}
`}#gp(i,g){const x=["useMSAA","useFXAA","useTAA"].includes(g),_=x?i.antialiasingManager[g]:i[g];updateDebugItemValue(this.dom,`redGPUContext_${g}`,x?makeBooleanDebug(0,_):getDebugFormatValue(_))}#xp(i){const{sizeManager:g,width:x,height:_,backgroundColor:v}=i,{pixelRectArray:b}=g;updateDebugItemValue(this.dom,"redGPUContext_width_height",`${x},${_}`),updateDebugItemValue(this.dom,"redGPUContext_pixelRectArray",b),updateDebugItemValue(this.dom,"redGPUContext_backgroundColor",makeColorDebug("backgroundColor",v))}};class DebugRedGPUContext extends ADebugItem{constructor(){super(),this.debugStatisticsDomService=new Hs}}let zs=class extends ADebugStatisticsDomService{#vp;constructor(i){super(),this.#vp=i,this.init(`${createDebugTitle(`${i}Texture Num: ()`)}`,!1,!0)}update(i,g){if("Packed"===this.#vp)this.#bp(i,g);else{const{resourceManager:x}=g,{managedBitmapTextureState:_,managedCubeTextureState:v,managedHDRTextureState:b}=x,{table:y,videoMemory:S}="Bitmap"===this.#vp?_:"Cube"===this.#vp?v:b;i.totalUsedVideoMemory+=S,updateDebugItemValue(this.dom,"totalCount",y.size),updateDebugItemValue(this.dom,"targetVideoMemorySize",formatBytes(S))}}getTargetSrc(i){if("Packed"===this.#vp)return i.src||"packed texture";if(i instanceof ResourceStateCubeTexture){const{cacheKey:g}=i;return`${g}...`}{const{src:g}=i;return g?g.startsWith("data:")?"base64 texture":g:"null"}}getUpdatedTdom(i,g,x,_,v,b){return i||((i=document.createElement("div")).className=`debug-group ${x}`,i.innerHTML=`
\t
${_} ${v||""}
Place holder for host
Place holder for fileName
mipLevelCount:/useMipmap:
width:/height:
${b}
`,g.appendChild(i)),i}updateDebugItems(i,g,x,_,v,b,y,S,w){updateDebugItemValue(i,"mipLevelCount",g),updateDebugItemValue(i,"useMipmap",x),updateDebugItemValue(i,"width",_),updateDebugItemValue(i,"height",v),"HDR"!==this.#vp&&updateDebugItemValue(i,"useNum",b,!0);const{host:L,filename:k}=this.#dp(y);L?(updateDebugItemValue(i,"host",L),updateDebugItemValue(i,"fileName",k)):updateDebugItemValue(i,"fileName",y),updateDebugItemValue(i,"targetSrc","null"===S?"":S),updateDebugItemValue(i,"videoMemorySize",formatBytes(w))}#bp(i,g){const x=PackedTexture.getCacheMap(),_=this.#yp(x);let v=0;_.forEach(i=>{v+=i.texture.videoMemorySize}),i.totalUsedVideoMemory+=v,updateDebugItemValue(this.dom,"totalCount",_.size),updateDebugItemValue(this.dom,"targetVideoMemorySize",formatBytes(v))}#yp(i){const g=new Map;return i.forEach((i,x)=>{const _={gpuTexture:i.gpuTexture,uuid:i.uuid,mipLevelCount:i.gpuTexture.mipLevelCount||1,useMipmap:(i.gpuTexture.mipLevelCount||1)>1,videoMemorySize:this.#Sp(i.gpuTexture)},v={useNum:i.useNum,cacheKey:x,texture:_,src:`packed:${x.substring(0,50)}${x.length>50?"...":""}`,mappingKey:i.mappingKey};g.set(x,v)}),g}#Sp(i){const g=i.label?.match(/(\d+)x(\d+)/);if(g){const x=parseInt(g[1]),_=parseInt(g[2]),v=i.mipLevelCount||1;let b=0;for(let i=0;i>i)*Math.max(1,_>>i)*4}return b}return 4194304}#dp(i){if("Packed"===this.#vp){try{const g=i.split("}_");if(g.length>=2){const i=g[0]+"}";g[1];return{host:"packed",filename:`${i.substring(0,20)}...`}}}catch{}return{host:"packed",filename:i.length>30?i.substring(0,30)+"...":i}}try{const g=new URL(i),x=g.pathname.split("/").pop()||i;return{host:g.host,filename:x}}catch{const g=i.split("_");return{host:g[0],filename:g.pop()||i}}}#pp(i){const g=this.dom.querySelector(".item-container"),x=new Set,_="Bitmap"===this.#vp?"cube_texture":"Cube"===this.#vp?"bitmap_texture":"HDR"===this.#vp?"hdr_texture":"packed_texture";g.querySelectorAll(".debug-group").forEach(i=>{const g=i.className.split(" ")[1].replace(`${_}_`,"");x.add(g)});let v=0;for(const b of i.values()){const{useNum:i,cacheKey:y,texture:S}=b;let w=this.getTargetSrc(b);const{mipLevelCount:L,useMipmap:k,gpuTexture:H,uuid:z,videoMemorySize:q}=S,{width:W,height:be}=H||{},Ke=`${_}_${S.uuid}`;let Xe=g.querySelector(`.${Ke}`);Xe=this.getUpdatedTdom(Xe,g,Ke,v,w,z),x.delete(S.uuid),this.updateDebugItems(Xe,L,k,W,be,i,y,w,q),v++}for(let i of x)g.querySelector(`.${_}_${i}`)?.remove()}};class DebugTextureList extends ADebugItem{constructor(i="Bitmap"){super(),this.debugStatisticsDomService=new zs(i)}}const $s=["totalNum3DGroups","totalNum3DObjects","totalNumInstances","totalNumDrawCalls","totalNumTriangles","totalNumPoints","totalUsedVideoMemory"];let Ks=class{dom;constructor(){this.dom=document.createElement("div"),this.#Tp()}update(i){$s.forEach(g=>{const x=i[g],_="totalUsedVideoMemory"===g?`${formatBytes(x)}`:x;updateDebugItemValue(this.dom,g,_)})}#Tp(){const i=this.#pp();this.dom.innerHTML=`
${createDebugTitle("Total State")}
${i}
`}#pp(){return $s.map(i=>"totalUsedVideoMemory"===i?`
${i}
`:`
${i}
`).join("")}};class DebugTotalState extends ADebugItem{constructor(){super(),this.debugStatisticsDomService=new Ks}}const Xs=["usedVideoMemory","viewRenderTime","num3DGroups","num3DObjects","numInstances","numDrawCalls","numTriangles","numPoints"],js={viewRenderTime:"ms"},Ys={camera:"camera.name",scene:"scene.name",useBackgroundColor:"scene.useBackgroundColor",backgroundColor:"scene.backgroundColor",x_y:"x,y",width_height:"width,height"};let qs=class extends ADebugStatisticsDomService{#Mp=0;constructor(){super(),this.init(`${createDebugTitle("ViewList")}`,!0)}update(i,g){const{viewList:x,numViews:_}=g;this.#Mp!==_&&(this.#wp(x),this.#Mp=_),x.forEach((g,x)=>{Xs.forEach(_=>this.#gp(g,x,_,i)),this.#xp(g,x)})}#_p(i,g){return`
${Ys[g]||g}
`}#wp(i){const g=this.dom.querySelector(".item-container"),x=i.map((i,g)=>{const{name:x}=i,_=Xs.map(i=>this.#_p(g,i));return _.push('
',this.#_p(g,"x_y"),this.#_p(g,"width_height"),this.#_p(g,"pixelRectArray"),this.#_p(g,"camera"),this.#_p(g,"scene"),this.#_p(g,"useBackgroundColor"),this.#_p(g,"backgroundColor"),"
"),`${createDebugTitle(`
${x}
`)}${_.join("")}`});return g.innerHTML=`
${x.join('
')}
`}#gp(i,g,x,_){const{renderViewStateData:v}=i,b=`total${x.charAt(0).toUpperCase()}${x.substring(1)}`,y=v[x],S="usedVideoMemory"===x?`${formatBytes(y)}`:y,w=js[x];_[b]+=y,updateDebugItemValue(this.dom,`view${g}_${x}`,S,!1,w)}#xp(i,g){const{renderViewStateData:x,rawCamera:_,scene:v}=i,{backgroundColor:b,useBackgroundColor:y}=v,{viewportSize:S}=x,{pixelRectArray:w,x:L,y:k,width:H,height:z}=S;updateDebugItemValue(this.dom,`view${g}_x_y`,`${formatNumber(L)},${formatNumber(k)}`),updateDebugItemValue(this.dom,`view${g}_width_height`,`${H},${z}`),updateDebugItemValue(this.dom,`view${g}_pixelRectArray`,w),updateDebugItemValue(this.dom,`view${g}_useBackgroundColor`,makeBooleanDebug(0,y)),updateDebugItemValue(this.dom,`view${g}_backgroundColor`,makeColorDebug("backgroundColor",b)),updateDebugItemValue(this.dom,`view${g}_camera`,_.name),updateDebugItemValue(this.dom,`view${g}_scene`,v.name)}};class DebugViewList extends ADebugItem{constructor(){super(),this.debugStatisticsDomService=new qs}}const formatNumber=i=>{const g=String(i);if(g.includes("%")){const i=parseFloat(g);return isNaN(i)?g:`${i.toFixed(2)}%`}if(g.includes("px")){const i=parseFloat(g);return isNaN(i)?g:`${i.toFixed(2)}px`}const x=parseFloat(g);return isNaN(x)?g:x.toFixed(2)};class DebugStatisticsDomService{dom;constructor(i){this.dom=document.createElement("div"),this.dom.style.cssText="z-index:1;position:sticky;top:0;background:#000;border-bottom:1px solid rgba(255,255,255,0.06);box-shadow:0 10px 10px rgba(0,0,0,0.5)",this.#Tp(i)}update(i,g,x,_,v){const b={fps:i,avg:g,low1:x,low01:_,frameTime:v};Object.entries(b).forEach(([i,g])=>this.#Cp(i,g))}#Tp(i){this.dom.innerHTML='
Performance
Monitor
60 FPS
16.67ms
Avg:60
1%:60
0.1%:60
CLOSE
'}#Cp(i,g){const x=this.dom.querySelector(`.${i}`);x&&x.innerHTML!==g&&(x.innerHTML=g)}}class Fps extends ADebugItem{#Rp=0;#cp=0;#Pp=!1;#Bp=[];#Ip=1200;#Ep=[];#Dp=10;#Up=0;#Lp=60;#Ap=0;#Gp=0;#kp=0;#Op=60;constructor(i){super(),this.debugStatisticsDomService=new DebugStatisticsDomService(i)}update(i,g,x){if(0===this.#cp)return this.#Rp=x,void this.#cp++;const _=x-this.#Rp;if(this.#Rp=x,this.#cp++,!this.#Pp){const i=document.querySelector(".panel_close");i&&(i.addEventListener("click",()=>{g.useDebugPanel=!1}),this.#Pp=!0)}const v=this.#Np(_);this.#cp>this.#Op&&(this.#Bp.push(v),this.#Bp.length>this.#Ip&&this.#Bp.shift()),this.#Ep.push(v),this.#Ep.length>this.#Dp&&this.#Ep.shift();const b=this.#Vp();this.#Up++,this.#Up>=this.#Lp&&(this.#Fp(),this.#Up=0),this.debugStatisticsDomService.update(`${b} FPS`,`Avg:${this.#Ap}`,`1%:${this.#Gp}`,`0.1%:${this.#kp}`,`${v.toFixed(2)}ms`)}#Np(i){return Math.min(Math.max(i,.1),1e3)}#Vp(){if(0===this.#Ep.length)return 0;const i=this.#Ep.reduce((i,g)=>i+g,0)/this.#Ep.length;return Math.round(1e3/i)}#Fp(){if(this.#Bp.length<100)return this.#Ap=0,this.#Gp=0,void(this.#kp=0);const i=this.#Hp();this.#Ap=i.avgFps,this.#Gp=i.low1Fps,this.#kp=i.low01Fps}#Hp(){const i=this.#Bp.reduce((i,g)=>i+g,0),g=i/this.#Bp.length,x=Math.round(1e3/g),_=[...this.#Bp].sort((i,g)=>g-i),v=_.length,b=Math.max(1,Math.ceil(.01*v)),y=_.slice(0,b),S=y.reduce((i,g)=>i+g,0)/y.length,w=Math.round(1e3/S),L=Math.max(1,Math.ceil(.001*v)),k=_.slice(0,L),H=k.reduce((i,g)=>i+g,0)/k.length;return{avgFps:x,low1Fps:w,low01Fps:Math.round(1e3/H)}}}class DebugRender{fps;debugTotalState;debugViewList;debugRedGPUContext;debugBitmapTextureList;debugCubeTextureList;debugHDRTextureList;debugPackedTextureList;debugIndexBufferList;debugVertexBufferList;debugUniformBufferList;debugStorageBufferList;debugBufferList;totalNum3DGroups;totalNum3DObjects;totalNumDrawCalls;totalNumInstances;totalNumTriangles;totalNumPoints;totalUsedVideoMemory;#zp;constructor(i){this.fps=new Fps(i),this.debugTotalState=new DebugTotalState,this.debugRedGPUContext=new DebugRedGPUContext,this.debugViewList=new DebugViewList,this.debugBitmapTextureList=new DebugTextureList,this.debugCubeTextureList=new DebugTextureList("Cube"),this.debugHDRTextureList=new DebugTextureList("HDR"),this.debugPackedTextureList=new DebugTextureList("Packed"),this.debugIndexBufferList=new DebugBufferList("IndexBuffer"),this.debugVertexBufferList=new DebugBufferList("VertexBuffer"),this.debugUniformBufferList=new DebugBufferList("UniformBuffer"),this.debugStorageBufferList=new DebugBufferList("StorageBuffer"),this.debugBufferList=new DebugBufferList("Buffer"),this.#$p()}render(i,g){i.useDebugPanel?(this.#Kp(),this.fps.update(this,i,g),this.debugRedGPUContext.update(this,i,g),this.debugViewList.update(this,i,g),this.debugBitmapTextureList.update(this,i,g),this.debugCubeTextureList.update(this,i,g),this.debugHDRTextureList.update(this,i,g),this.debugPackedTextureList.update(this,i,g),this.debugIndexBufferList.update(this,i),this.debugVertexBufferList.update(this,i),this.debugUniformBufferList.update(this,i),this.debugStorageBufferList.update(this,i),this.debugBufferList.update(this,i),this.debugTotalState.update(this,i,g)):this.#Xp(),this.#$p()}#$p(){this.totalNum3DGroups=0,this.totalNum3DObjects=0,this.totalNumInstances=0,this.totalNumDrawCalls=0,this.totalNumTriangles=0,this.totalNumPoints=0,this.totalUsedVideoMemory=0}#Kp(){this.#zp||(this.#zp=document.createElement("div"),this.#zp.className="RedGPUDebugPanel",document.body.appendChild(this.#zp),[this.fps.debugStatisticsDomService,this.debugTotalState.debugStatisticsDomService,this.debugRedGPUContext.debugStatisticsDomService,this.debugViewList.debugStatisticsDomService,this.debugBufferList.debugStatisticsDomService,this.debugVertexBufferList.debugStatisticsDomService,this.debugIndexBufferList.debugStatisticsDomService,this.debugUniformBufferList.debugStatisticsDomService,this.debugStorageBufferList.debugStatisticsDomService,this.debugBitmapTextureList.debugStatisticsDomService,this.debugPackedTextureList.debugStatisticsDomService,this.debugCubeTextureList.debugStatisticsDomService,this.debugHDRTextureList.debugStatisticsDomService].forEach(i=>this.#zp.appendChild(i.dom)))}#Xp(){this.#zp&&(this.#zp.remove(),this.#zp=null)}}Object.freeze(DebugRender);var Ws="struct Uniforms{ backgroundColor:vec4\n}\n@group(1) @binding(0)\nvar _sampler:sampler;\n@group(1) @binding(1)\nvar _texture:texture_2d;\n@group(1) @binding(2)\nvar uniforms:Uniforms;\n@fragment\nfn main(@location(0) fragUV:vec2) -> @location(0) vec4 { var viewColor:vec4=textureSample(_texture,_sampler,fragUV); let backgroundColor=uniforms.backgroundColor; let blendedColor=vec4( viewColor.rgb + backgroundColor.rgb * (1.0 - viewColor.a), viewColor.a + backgroundColor.a * (1.0 - viewColor.a) ); return blendedColor;\n}\n",Zs="\nstruct VertexUniforms { modelMatrix:mat4x4,\n};\n@group(0) @binding(0)\nvar vertexUniforms:VertexUniforms;\nstruct VertexOutput { @builtin(position) Position:vec4, @location(0) fragUV:vec2,\n};\n@vertex\nfn main(@builtin(vertex_index) VertexIndex:u32) -> VertexOutput { var pos=array,6>( vec2( 1.0,1.0), vec2( 1.0,-1.0), vec2(-1.0,-1.0), vec2( 1.0,1.0), vec2(-1.0,-1.0), vec2(-1.0,1.0), ); var uv=array,6>( vec2(1.0,0.0), vec2(1.0,1.0), vec2(0.0,1.0), vec2(1.0,0.0), vec2(0.0,1.0), vec2(0.0,0.0), ); var output:VertexOutput; output.Position=vertexUniforms.modelMatrix * vec4(pos[VertexIndex],0.0,1.0); output.fragUV=uv[VertexIndex]; return output;\n}\n";const Js=parseWGSL(Zs),Qs=parseWGSL(Ws),eo=Js.uniforms.vertexUniforms;class FinalRender{#jp=[];#Yp=[];#qp;#Wp;#Zp;#Jp;#Qp;#eg=[];#Q;#tg=[];#ng=[];#ae;#rg=[];#ig=[];constructor(){}render(i,g){const{sizeManager:x,gpuDevice:_,antialiasingManager:v}=i,{changedMSAA:b,useMSAA:y}=v,{pixelRectObject:S}=x,{width:w,height:L}=S;if(0===w||0===L)return;const k=this.#ag(i),H=_.createCommandEncoder(),z=H.beginRenderPass(k);z.setViewport(0,0,w,L,0,1),z.setScissorRect(0,0,w,L),this.#qp&&!b||this.#sg(i),this.#og(i,z,g.map(i=>{const g=i.colorAttachments[0];return g.postEffectView||g.pickingView||g.resolveTarget||g.view}),w,L,y),z.end(),_.queue.submit([H.finish()])}#ug(i,g){{const{scene:x,redGPUContext:_}=i,{gpuDevice:v}=_,{backgroundColor:b,useBackgroundColor:y}=x,S=y?b.rgbaNormal:[0,0,0,0],w=_.backgroundColor.rgbaNormal;let L;const k=[S[0]*S[3],S[1]*S[3],S[2]*S[3],S[3]],H=[w[0]*w[3],w[1]*w[3],w[2]*w[3],w[3]];L=[k[0]+H[0]*(1-S[3]),k[1]+H[1]*(1-S[3]),k[2]+H[2]*(1-S[3]),S[3]+w[3]*(1-S[3])],this.#ig[g][0]=L[0],this.#ig[g][1]=L[1],this.#ig[g][2]=L[2],this.#ig[g][3]=L[3],v.queue.writeBuffer(this.#rg[g],0,this.#ig[g])}}#og(i,g,x,_,v,b){const{gpuDevice:y}=i;x.forEach((x,b)=>{const S=i.viewList[b],{x:w,y:L,width:k,height:H}=S.pixelRectObject,z=create$4();bt(z,0,1,0,1,-1e3,1e3),scale$4(z,z,[1/_,1/v,1]),translate(z,z,[k/2+w,v-H/2-L,0]),scale$4(z,z,[k/2,H/2,1]),this.#lg(i,b);const q=this.#jp[b],W=this.#Yp[b];y.queue.writeBuffer(q.gpuBuffer,eo.members.modelMatrix.uniformOffset,z);if(i.antialiasingManager.changedMSAA||!this.#tg[b]||this.#tg[b].width!==k||this.#tg[b].height!==H||this.#ng[b]!==x){this.#rg[b]||(this.#rg[b]=i.gpuDevice.createBuffer({label:`FINAL_RENDER_FRAGMENT_BUFFER_${b}`,size:16,usage:GPUBufferUsage.UNIFORM|GPUBufferUsage.COPY_DST}),this.#ig[b]=new Float32Array([1,0,0,1]));const g={layout:this.#Jp,label:"FRAGMENT_BIND_GROUP_DESCRIPTOR_FINAL_RENDER",entries:[{binding:0,resource:this.#ae.gpuSampler},{binding:1,resource:x},{binding:2,resource:{buffer:this.#rg[b],offset:0,size:this.#rg[b].size}}]};this.#eg[b]=y.createBindGroup(g),this.#tg[b]={width:k||1,height:H||1},this.#ng[b]=x}this.#ug(S,b),g.setPipeline(this.#cg(i)),g.setBindGroup(0,W),g.setBindGroup(1,this.#eg[b]),g.draw(6,1,0,0)})}#sg(i){const{resourceManager:g}=i;this.#qp=g.createBindGroupLayout("FINAL_RENDER_VERTEX_BIND_GROUP_LAYOUT",getVertexBindGroupLayoutDescriptorFromShaderInfo(Js,0)),this.#Wp=g.createGPUShaderModule("VERTEX_MODULE_FINAL_RENDER",{code:Zs}),this.#Zp={module:this.#Wp,entryPoint:"main"},this.#Qp=g.createGPUShaderModule("FRAGMENT_MODULE_FINAL_RENDER",{code:Ws}),this.#Jp=g.createBindGroupLayout("FINAL_RENDER_BIND_GROUP_LAYOUT",getFragmentBindGroupLayoutDescriptorFromShaderInfo(Qs,1)),this.#ae=new Sampler(i,{minFilter:"linear"})}#lg(i,g){const{gpuDevice:x}=i;if(!this.#jp[g]){const _=new ArrayBuffer(eo.arrayBufferByteLength),v=this.#jp[g]=new UniformBuffer(i,_,`FinalRender_View(${g})_VertexUniform`),b={layout:this.#qp,label:"VERTEX_BIND_GROUP_DESCRIPTOR_FINAL_RENDER",entries:[{binding:0,resource:{buffer:v.gpuBuffer,offset:0,size:v.size}}]};this.#Yp[g]=x.createBindGroup(b)}}#ag(i){const{backgroundColor:g,gpuContext:x}=i;return{colorAttachments:[{view:x.getCurrentTexture().createView({label:"FINAL_RENDER"}),clearValue:{r:0,g:0,b:0,a:0},loadOp:H.CLEAR,storeOp:z.STORE}]}}#cg(i){if(!this.#Q||i.antialiasingManager.changedMSAA){const{gpuDevice:g}=i,x={label:"PIPELINE_DESCRIPTOR_FINAL_RENDER",layout:g.createPipelineLayout({label:"FINAL_RENDER_PIPELINE_LAYOUT",bindGroupLayouts:[this.#qp,this.#Jp]}),vertex:this.#Zp,fragment:{module:this.#Qp,entryPoint:"main",targets:[{format:navigator.gpu.getPreferredCanvasFormat(),blend:{color:{srcFactor:mr.SRC_ALPHA,dstFactor:mr.ONE_MINUS_SRC_ALPHA,operation:pr.ADD},alpha:{srcFactor:mr.SRC_ALPHA,dstFactor:mr.ONE_MINUS_SRC_ALPHA,operation:pr.ADD}}}]}};this.#Q=g.createRenderPipeline(x)}return this.#Q}}const renderListForLayer=(i,g,x="pipeline")=>{let _=0;const v=i.length,{currentRenderPassEncoder:b}=g;for(b.setBindGroup(0,g.view.systemUniform_Vertex_UniformBindGroup);_{g?.(x),i.currentTime=x,this.renderFrame(i,x),this.#dg.render(i,x),i.currentRequestAnimationFrame=requestAnimationFrame(HD_render)};i.currentRequestAnimationFrame=requestAnimationFrame(HD_render)}stop(i){cancelAnimationFrame(i.currentRequestAnimationFrame),i.currentRequestAnimationFrame=null}renderFrame(i,g){this.#fg||(this.#fg=new FinalRender),this.#dg||(this.#dg=new DebugRender(i));const x=[];{let _=0;const v=i.viewList.length;for(;_=S){y.prevTimestamp=x-b%S;const{scene:g}=i;g.physicsEngine&&g.physicsEngine.step(S/1e3)}_.update?.(i,g)}this.#gg(i),this.#xg(i,H),this.#_g(i,H,z),this.#vg(i,H,z,w),this.#bg(i,H)}return z.colorAttachments[0].postEffectView=i.postEffectManager.render().textureView,x.gpuDevice.queue.submit([H.finish(),this.#yg(x,y)]),i.renderViewStateData.viewRenderTime=performance.now()-i.renderViewStateData.startTime,v?.checkEvents(i,g),z}#xg(i,g){const{scene:x}=i,{shadowManager:_}=x,{directionalShadowManager:v}=_,b={label:`${i.name} Shadow Render Pass`,colorAttachments:[],depthStencilAttachment:{view:v.shadowDepthTextureView,depthClearValue:1,depthLoadOp:H.CLEAR,depthStoreOp:z.STORE}},y=g.beginRenderPass(b);this.#Sg(i,y,!0),this.#Tg(i,y,!0,!1),v.castingList.length&&((i,g)=>{const{renderViewStateData:x,scene:_}=i;x.currentRenderPassEncoder=g;const{shadowManager:v}=_,{directionalShadowManager:b}=v,{castingList:y}=b;renderListForLayer(y,x,"shadowPipeline")})(i,y),y.end(),v.resetCastingList()}#_g(i,g,x){const{renderViewStateData:_,skybox:v,grid:b,axis:y}=i,S=g.beginRenderPass(x);{const g=i.viewRenderTextureManager.renderPath1ResultTextureView;this.#Sg(i,S),this.#Tg(i,S,!1,!0,g)}_.currentRenderPassEncoder=S,S.setBindGroup(0,i.systemUniform_Vertex_UniformBindGroup),v&&v.render(_),y&&y.render(_),((i,g)=>{const{renderViewStateData:x,scene:_}=i;x.currentRenderPassEncoder=g;const{children:v}=_;let b=0;const y=v.length;for(;b{const{renderViewStateData:x,rawCamera:_}=i;x.currentRenderPassEncoder=g;const{bundleListAlphaLayer:v,bundleListTransparentLayer:b,bundleListParticleLayer:y}=x;v.length&&g.executeBundles(v);const{x:S,y:w,z:L}=_;b.length&&g.executeBundles(sortTransparentObjects({x:S,y:w,z:L},b)),y.length&&g.executeBundles(y)})(i,S),S.end()}#vg(i,g,x,_){const{redGPUContext:v,renderViewStateData:b}=i,{antialiasingManager:y}=v,{useMSAA:S}=y;if(i.renderViewStateData.bundleListRender2PathLayer.length){const{mipmapGenerator:y}=v.resourceManager;let w=i.viewRenderTextureManager.renderPath1ResultTexture,L=S?i.viewRenderTextureManager.gBufferColorResolveTexture:i.viewRenderTextureManager.gBufferColorTexture;L||(S?console.error("MSAA가 활성화되어 있지만 gBufferColorResolveTexture가 정의되지 않았습니다"):console.error("gBufferColorTexture가 정의되지 않았습니다")),w||console.error("renderPath1ResultTexture가 정의되지 않았습니다"),g.copyTextureToTexture({texture:L},{texture:w},{width:i.pixelRectObject.width,height:i.pixelRectObject.height,depthOrArrayLayers:1}),y.generateMipmap(w,i.viewRenderTextureManager.renderPath1ResultTextureDescriptor,!0);const k=g.beginRenderPass({label:`${i.name} 2Path Render Pass`,colorAttachments:[...x.colorAttachments].map(i=>({...i,loadOp:H.LOAD})),depthStencilAttachment:{..._,depthLoadOp:H.LOAD}});k.executeBundles(b.bundleListRender2PathLayer),k.end()}}#bg(i,g){const{pickingManager:x}=i;if(x&&x.castingList.length){x.checkTexture(i);const _={label:`${i.name} Picking Render Pass`,colorAttachments:[{view:x.pickingGPUTextureView,clearValue:{r:0,g:0,b:0,a:0},loadOp:H.CLEAR,storeOp:z.STORE}],depthStencilAttachment:{view:x.pickingDepthGPUTextureView,depthClearValue:1,depthLoadOp:H.CLEAR,depthStoreOp:z.STORE}},v=g.beginRenderPass(_);this.#Sg(i,v),this.#Tg(i,v,!1,!1),((i,g)=>{const{renderViewStateData:x,pickingManager:_}=i;x.currentRenderPassEncoder=g;const{castingList:v}=_;renderListForLayer(v,x,"pickingPipeline")})(i,v),v.end()}}#gg(i){const{taa:g}=i,x=g.frameIndex||0,_=g.jitterStrength,v=x%16,b=this.#Mg(v+1,2),y=this.#Mg(v+1,3),S=window.devicePixelRatio||1,w=(b-.5)/S*_,L=(y-.5)/S*_;i.setJitterOffset(w,L)}#Mg(i,g){let x=0,_=1,v=i;for(;v>0;)_/=g,x+=_*(v%g),v=Math.floor(v/g);return x}#yg(i,g){const{animationList:x,skinList:_}=g,v=_.length,b=x.length,{gpuDevice:y}=i,S=y.createCommandEncoder({label:"BatchUpdateSkinMatrices_CommandEncoder"}),w=S.beginComputePass();b&&this.#mg.render(i,g.timestamp,w,x.flat());for(let g=0;g(global_id.xy );\nlet dimensions:vec2=textureDimensions(sourceTexture);\nlet dimW=f32(dimensions.x);\nlet dimH=f32(dimensions.y);\nlet uv=vec2(f32(index.x)/dimW,f32(index.y)/dimH);\nvar color:vec4=textureLoad( sourceTexture,index,);\nlet brightness_value:f32=uniforms.brightness/255.0;\nlet contrast_value:f32=uniforms.contrast/255.0;\nvar tempColor:vec3;\nif ( contrast_value > 0.0 ) { tempColor=( color.rgb - 0.5 )/( 1.0 - contrast_value ) + 0.5;\n}else { tempColor=( color.rgb - 0.5 ) * ( 1.0 + contrast_value ) + 0.5;\n}\ncolor=vec4(tempColor + brightness_value,color.a);\ntextureStore(outputTexture,index,color );\n","struct Uniforms { brightness:f32, contrast:f32\n};\n"))}get brightness(){return this.#gc}set brightness(i){validateNumberRange(i,-150,150),this.#gc=i,this.updateUniform("brightness",i)}get contrast(){return this.#Sr}set contrast(i){validateNumberRange(i,-50,100),this.#Sr=i,this.updateUniform("contrast",i)}}Object.freeze(BrightnessContrast);class ColorBalance extends ASinglePassPostEffect{#wg=0;#Cg=0;#Rg=0;#Pg=0;#Bg=0;#Ig=0;#Eg=0;#Dg=0;#Ug=0;#Lg=!0;constructor(i){super(i),this.init(i,"POST_EFFECT_COLOR_BALANCE",createBasicPostEffectCode(this,"let index=vec2(global_id.xy );\nlet dimensions:vec2=textureDimensions(sourceTexture);\nlet dimW=f32(dimensions.x);\nlet dimH=f32(dimensions.y);\nlet uv=vec2(f32(index.x)/dimW,f32(index.y)/dimH);\nvar color:vec4=textureLoad( sourceTexture,index,);\nlet original_luminance=0.299 * color.r + 0.587 * color.g + 0.114 * color.b;\nlet shadow_weight=1.0 - smoothstep(0.0,0.5,original_luminance);\nlet highlight_weight=smoothstep(0.5,1.0,original_luminance);\nlet midtone_weight=1.0 - shadow_weight - highlight_weight;\nlet cyan_red=shadow_weight * uniforms.shadowCyanRed +\nmidtone_weight * uniforms.midtoneCyanRed +\nhighlight_weight * uniforms.highlightCyanRed;\nlet magenta_green=shadow_weight * uniforms.shadowMagentaGreen +\nmidtone_weight * uniforms.midtoneMagentaGreen +\nhighlight_weight * uniforms.highlightMagentaGreen;\nlet yellow_blue=shadow_weight * uniforms.shadowYellowBlue +\nmidtone_weight * uniforms.midtoneYellowBlue +\nhighlight_weight * uniforms.highlightYellowBlue;\ncolor.r +=cyan_red * 0.01;\ncolor.g +=magenta_green * 0.01;\ncolor.b +=yellow_blue * 0.01;\nlet adjusted_luminance=0.299 * color.r + 0.587 * color.g + 0.114 * color.b;\nif (uniforms.preserveLuminosity==1 && adjusted_luminance > 0.0) { let ratio=original_luminance/adjusted_luminance; color=color * ratio;\n}\ntextureStore(outputTexture,index,color );\n","struct Uniforms { shadowCyanRed:f32, shadowMagentaGreen:f32, shadowYellowBlue:f32, midtoneCyanRed:f32, midtoneMagentaGreen:f32, midtoneYellowBlue:f32, highlightCyanRed:f32, highlightMagentaGreen:f32, highlightYellowBlue:f32, preserveLuminosity:u32\n};\n"))}get shadowCyanRed(){return this.#wg}set shadowCyanRed(i){validateNumberRange(i,-100,100),this.#wg=i,this.updateUniform("shadowCyanRed",i)}get shadowMagentaGreen(){return this.#Cg}set shadowMagentaGreen(i){validateNumberRange(i,-100,100),this.#Cg=i,this.updateUniform("shadowMagentaGreen",i)}get shadowYellowBlue(){return this.#Rg}set shadowYellowBlue(i){validateNumberRange(i,-100,100),this.#Rg=i,this.updateUniform("shadowYellowBlue",i)}get midtoneCyanRed(){return this.#Pg}set midtoneCyanRed(i){validateNumberRange(i,-100,100),this.#Pg=i,this.updateUniform("midtoneCyanRed",i)}get midtoneMagentaGreen(){return this.#Bg}set midtoneMagentaGreen(i){validateNumberRange(i,-100,100),this.#Bg=i,this.updateUniform("midtoneMagentaGreen",i)}get midtoneYellowBlue(){return this.#Ig}set midtoneYellowBlue(i){validateNumberRange(i,-100,100),this.#Ig=i,this.updateUniform("midtoneYellowBlue",i)}get highlightCyanRed(){return this.#Eg}set highlightCyanRed(i){validateNumberRange(i,-100,100),this.#Eg=i,this.updateUniform("highlightCyanRed",i)}get highlightMagentaGreen(){return this.#Dg}set highlightMagentaGreen(i){validateNumberRange(i,-100,100),this.#Dg=i,this.updateUniform("highlightMagentaGreen",i)}get highlightYellowBlue(){return this.#Ug}set highlightYellowBlue(i){validateNumberRange(i,-100,100),this.#Ug=i,this.updateUniform("highlightYellowBlue",i)}get preserveLuminosity(){return this.#Lg}set preserveLuminosity(i){this.#Lg=i,this.updateUniform("preserveLuminosity",i)}}Object.freeze(ColorBalance);class ColorTemperatureTint extends ASinglePassPostEffect{#Ag=6500;#Gg=0;#kg=100;constructor(i){super(i),this.init(i,"POST_EFFECT_COLOR_TEMPERATURE_TINT",createBasicPostEffectCode(this,"let index=vec2(global_id.xy);\nlet dimensions:vec2=textureDimensions(sourceTexture);\nlet dimW=f32(dimensions.x);\nlet dimH=f32(dimensions.y);\nlet uv=vec2(f32(index.x)/dimW,f32(index.y)/dimH);\nvar color:vec4=textureLoad(sourceTexture,index);\nlet temp=uniforms.temperature;\nvar tempRGB:vec3;\nif (temp <=6600.0) { tempRGB.r=1.0;\n} else { let t=temp - 6600.0; tempRGB.r=clamp(1.292936 * pow(t,-0.1332047),0.0,1.0);\n}\nif (temp <=6600.0) { let t=temp; tempRGB.g=clamp(0.39008157 * log(t) - 0.63184144,0.0,1.0);\n} else { let t=temp - 6600.0; tempRGB.g=clamp(1.292936 * pow(t,-0.1332047),0.0,1.0);\n}\nif (temp >=6600.0) { tempRGB.b=1.0;\n} else if (temp <=1900.0) { tempRGB.b=0.0;\n} else { let t=temp - 1000.0; tempRGB.b=clamp(0.543206789 * log(t) - 1.19625408,0.0,1.0);\n}\nlet neutralTemp:vec3=vec3(1.0,1.0,1.0);\nlet tempAdjust:vec3=tempRGB/neutralTemp;\nlet tintValue=uniforms.tint * 0.01;\nvar tintRGB:vec3;\nif (tintValue >=0.0) { tintRGB=vec3(1.0 - tintValue * 0.2,1.0,1.0 - tintValue * 0.2);\n} else { let mag=-tintValue; tintRGB=vec3(1.0,1.0 - mag * 0.2,1.0);\n}\nlet colorAdjust=tempAdjust * tintRGB;\nlet strength=uniforms.strength * 0.01;\nlet finalAdjust=mix(vec3(1.0,1.0,1.0),colorAdjust,strength);\ncolor=vec4(color.rgb * finalAdjust,color.a);\ncolor=vec4(clamp(color.rgb,vec3(0.0),vec3(1.0)),color.a);\ntextureStore(outputTexture,index,color);\n","struct Uniforms { temperature:f32, tint:f32, strength:f32\n};\n")),this.strength=this.#kg,this.tint=this.#Gg,this.temperature=this.#Ag}get temperature(){return this.#Ag}set temperature(i){validateNumberRange(i,1e3,2e4),this.#Ag=i,this.updateUniform("temperature",i)}get tint(){return this.#Gg}set tint(i){validateNumberRange(i,-100,100),this.#Gg=i,this.updateUniform("tint",i)}get strength(){return this.#kg}set strength(i){validateNumberRange(i,0,100),this.#kg=i,this.updateUniform("strength",i)}setWarmTone(){this.temperature=3200,this.tint=-10}setCoolTone(){this.temperature=8e3,this.tint=10}setNeutral(){this.temperature=6500,this.tint=0}setCandleLight(){this.temperature=1900,this.tint=-5}setDaylight(){this.temperature=5600,this.tint=0}setCloudyDay(){this.temperature=7500,this.tint=5}setNeonLight(){this.temperature=9e3,this.tint=15}}Object.freeze(ColorTemperatureTint);class Grayscale extends ASinglePassPostEffect{constructor(i){super(i);this.init(i,"POST_EFFECT_GRAYSCALE",createBasicPostEffectCode(this,"let index=vec2(global_id.xy );\nlet dimensions:vec2=textureDimensions(sourceTexture);\nlet dimW=f32(dimensions.x);\nlet dimH=f32(dimensions.y);\nlet uv=vec2(f32(index.x)/dimW,f32(index.y)/dimH);\nvar color:vec4=textureLoad( sourceTexture,index );\nlet gray=(color.r + color.g + color.b)/3.0;\ntextureStore(outputTexture,index,vec4( gray,gray,gray,color.a) );\n",""))}}Object.freeze(Grayscale);class HueSaturation extends ASinglePassPostEffect{#Og=0;#Ng=0;constructor(i){super(i),this.init(i,"POST_EFFECT_HUE_SATURATION",createBasicPostEffectCode(this,"let index=vec2(global_id.xy );\nlet dimensions:vec2=textureDimensions(sourceTexture);\nlet dimW=f32(dimensions.x);\nlet dimH=f32(dimensions.y);\nlet uv=vec2(f32(index.x)/dimW,f32(index.y)/dimH);\nvar color:vec4=textureLoad( sourceTexture,index,);\nlet hue_value:f32=uniforms.hue/180.0;\nlet saturation_value:f32=uniforms.saturation/100.0;\nlet angle:f32=hue_value * 3.1415926535897932384626433832795;\nlet s:f32=sin(angle);\nlet c:f32=cos(angle);\nvar weights:vec3=(vec3(2.0 * c,-sqrt(3.0) * s - c,sqrt(3.0) * s - c) + 1.0)/3.0;\nlet len:f32=length(color.rgb);\ncolor=vec4( vec3( dot(color.rgb,weights.xyz), dot(color.rgb,weights.zxy), dot(color.rgb,weights.yzx) ), color.a\n);\nlet average:f32=(color.r + color.g + color.b)/3.0;\nif (saturation_value > 0.0) { color=vec4( color.rgb + (average - color.rgb) * (1.0 - 1.0/(1.001 - saturation_value)), color.a );\n} else { color=vec4( color.rgb + (average - color.rgb) * (-saturation_value), color.a );\n}\ntextureStore(outputTexture,index,color );\n","struct Uniforms { hue:f32, saturation:f32\n};\n"))}get hue(){return this.#Og}set hue(i){validateNumberRange(i,-180,180),this.#Og=i,this.updateUniform("hue",i)}get saturation(){return this.#Ng}set saturation(i){validateNumberRange(i,-100,100),this.#Ng=i,this.updateUniform("saturation",i)}}Object.freeze(HueSaturation);class Invert extends ASinglePassPostEffect{constructor(i){super(i);this.init(i,"POST_EFFECT_INVERT",createBasicPostEffectCode(this,"let index=vec2(global_id.xy );\nlet dimensions:vec2=textureDimensions(sourceTexture);\nlet dimW=f32(dimensions.x);\nlet dimH=f32(dimensions.y);\nlet uv=vec2(f32(index.x)/dimW,f32(index.y)/dimH);\nvar color:vec4=textureLoad( sourceTexture,index,);\ncolor.r=1.0 - color.r;\ncolor.g=1.0 - color.g;\ncolor.b=1.0 - color.b;\ntextureStore(outputTexture,index,color );\n",""))}}Object.freeze(Invert);class Threshold extends ASinglePassPostEffect{#Vg=128;constructor(i){super(i),this.init(i,"POST_EFFECT_THRESHOLD",createBasicPostEffectCode(this,"let index=vec2(global_id.xy );\nlet dimensions:vec2=textureDimensions(sourceTexture);\nlet dimW=f32(dimensions.x);\nlet dimH=f32(dimensions.y);\nvar color:vec4=textureLoad( sourceTexture,index,);\nlet threshold_value:f32=uniforms.threshold/255.0;\nvar v=0.0;\nif( 0.2126 * color.r + 0.7152 * color.g + 0.0722 * color.b >=threshold_value) { v=1.0;\n}\ncolor=vec4(v,v,v,color.a);\ntextureStore(outputTexture,index,color );\n","struct Uniforms { threshold:f32\n};\n")),this.threshold=this.#Vg}get threshold(){return this.#Vg}set threshold(i){validateNumberRange(i,1,255),this.#Vg=i,this.updateUniform("threshold",i)}}Object.freeze(Threshold);class Vibrance extends ASinglePassPostEffect{#Fg=0;#Ng=0;constructor(i){super(i),this.init(i,"POST_EFFECT_VIBRANCE",createBasicPostEffectCode(this,"let index=vec2(global_id.xy);\nlet dimensions:vec2=textureDimensions(sourceTexture);\nlet dimW=f32(dimensions.x);\nlet dimH=f32(dimensions.y);\nlet uv=vec2(f32(index.x)/dimW,f32(index.y)/dimH);\nvar color:vec4=textureLoad(sourceTexture,index);\nlet originalColor=color;\nlet luminance=0.2126 * color.r + 0.7152 * color.g + 0.0722 * color.b;\nif (uniforms.saturation !=0.0) { let saturationFactor=1.0 + uniforms.saturation * 0.01; color=vec4( mix(luminance,color.r,saturationFactor), mix(luminance,color.g,saturationFactor), mix(luminance,color.b,saturationFactor), color.a );\n}\nif (uniforms.vibrance !=0.0) { let maxComponent=max(max(color.r,color.g),color.b); let minComponent=min(min(color.r,color.g),color.b); let currentSaturation=maxComponent - minComponent; let protectionFactor=1.0/(1.0 + exp(6.0 * (currentSaturation - 0.6))); var skinToneProtection=1.0; if (color.r > color.g && color.g > color.b) { let skinToneAmount=(color.r - color.b)/max(color.r,0.001); skinToneProtection=1.0 - smoothstep(0.3,0.8,skinToneAmount) * 0.7; } let finalProtection=protectionFactor * skinToneProtection; let vibranceStrength=uniforms.vibrance * 0.01 * finalProtection; let vibranceFactor=1.0 + vibranceStrength; color=vec4( mix(luminance,color.r,vibranceFactor), mix(luminance,color.g,vibranceFactor), mix(luminance,color.b,vibranceFactor), color.a );\n}\ncolor=clamp(color,vec4(0.0),vec4(1.0));\ntextureStore(outputTexture,index,color);\n","struct Uniforms { vibrance:f32, saturation:f32\n};\n"))}get vibrance(){return this.#Fg}set vibrance(i){validateNumberRange(i,-100,100),this.#Fg=i,this.updateUniform("vibrance",i)}get saturation(){return this.#Ng}set saturation(i){validateNumberRange(i,-100,100),this.#Ng=i,this.updateUniform("saturation",i)}}Object.freeze(Vibrance);const no=[0,0,0,0,0,1,0,0,0,0,0,0],ro=[0,-1,0,0,-1,5,-1,0,0,-1,0,0],io=[1,1,1,0,1,1,1,0,1,1,1,0],ao=[0,1,0,0,1,-4,1,0,0,1,0,0],so=[-2,-1,0,0,-1,1,1,0,0,1,2,0];class Convolution extends ASinglePassPostEffect{static NORMAL=no;static SHARPEN=ro;static BLUR=io;static EDGE=ao;static EMBOSE=so;#Hg=io;constructor(i){super(i),this.init(i,"POST_EFFECT_CONVOLUTION",createBasicPostEffectCode(this,"let index=vec2(global_id.xy );\nlet dimensions:vec2=textureDimensions(sourceTexture);\nlet dimW=f32(dimensions.x);\nlet dimH=f32(dimensions.y);\nlet perPX=vec2(1.0/dimW,1.0/dimH);\nlet uv=vec2(f32(index.x)/dimW,f32(index.y)/dimH);\nvar color:vec4=vec4(0.0);\nlet kernelWeight_value:f32=uniforms.kernelWeight;\nlet kernel_value:mat3x3=uniforms.kernel;\ncolor +=textureLoad(sourceTexture,index + vec2(-1,-1)) * kernel_value[0][0];\ncolor +=textureLoad(sourceTexture,index + vec2(0,-1)) * kernel_value[0][1];\ncolor +=textureLoad(sourceTexture,index + vec2(1,-1)) * kernel_value[0][2];\ncolor +=textureLoad(sourceTexture,index + vec2(-1,0)) * kernel_value[1][0];\ncolor +=textureLoad(sourceTexture,index + vec2(0,0)) * kernel_value[1][1];\ncolor +=textureLoad(sourceTexture,index + vec2(1,0)) * kernel_value[1][2];\ncolor +=textureLoad(sourceTexture,index + vec2(-1,1)) * kernel_value[2][0];\ncolor +=textureLoad(sourceTexture,index + vec2(0,1)) * kernel_value[2][1];\ncolor +=textureLoad(sourceTexture,index + vec2(1,1)) * kernel_value[2][2];\ntextureStore(outputTexture,index,color/kernelWeight_value );\n","struct Uniforms { kernelWeight:f32, kernel:mat3x3\n};\n")),this.kernel=this.#Hg}get kernel(){return this.#Hg}set kernel(i){this.#Hg=i;let g=0;for(const i in this.#Hg)g+=this.#Hg[i];this.updateUniform("kernelWeight",g),this.updateUniform("kernel",i)}}Object.freeze(Convolution);class Blur extends AMultiPassPostEffect{#zg;constructor(i){super(i,[new Convolution(i)]),this.#zg=this.passList[0],this.#zg.kernel=Convolution.BLUR}render(i,g,x,_){return this.#zg.render(i,g,x,_)}}Object.freeze(Blur);class DirectionalBlur extends ASinglePassPostEffect{#$g=15;#Kg=0;constructor(i){super(i),this.init(i,"POST_EFFECT_DIRECTIONAL_BLUR",createBasicPostEffectCode(this,"let dimensions=textureDimensions(sourceTexture);\nlet dimW=f32(dimensions.x);\nlet dimH=f32(dimensions.y);\nlet direction=vec2(uniforms.directionX,uniforms.directionY);\nlet dirLength=length(direction);\nlet normalizedDir=select(vec2(0.0),direction/dirLength,dirLength > 0.0);\nlet dir=normalizedDir * uniforms.amount;\nconst loopSize=30.0;\nlet offset=random(global_id,0.0);\nlet global_id_vec=vec2(f32(global_id.x),f32(global_id.y));\nvar sum=vec4(0.0,0.0,0.0,0.0);\nvar total=0.0;\nfor (var t=-loopSize;t <=loopSize;t=t + 1.0) { var percent=1.0 - (t + offset - 0.5)/loopSize; var weight=3.0 * (percent - percent * percent); let deltaPercent=dir * percent; let delta=vec2( i32(clamp(global_id_vec.x + deltaPercent.x,0.0,dimW - 1.0)), i32(clamp(global_id_vec.y + deltaPercent.y,0.0,dimH - 1.0)) ); sum +=textureLoad(sourceTexture,delta).xyzw * weight; total +=weight;\n}\ntextureStore(outputTexture,vec2(global_id.xy),sum/total);\n","struct Uniforms { amount:f32, directionX:f32, directionY:f32\n};\nfn random(id:vec3,delta:f32) -> f32 { let seed:u32=((id.x << 16) | (id.y & 0xFFFF)) ^ (id.z * 0x63641362); let t:vec3=vec3(f32(seed & 0xFF),f32((seed >> 8) & 0xFF),f32(seed >> 16)); return delta + fract(sin(dot(t,vec3(12.9898,78.233,12.9898))) * 43758.5453);\n}\n")),this.amount=this.#$g,this.angle=this.#Kg}get angle(){return this.#Kg}set angle(i){validateNumber(i),this.#Kg=i%360,this.#Xg()}get amount(){return this.#$g}set amount(i){validateNumberRange(i,0),this.#$g=i,this.updateUniform("amount",i)}#Xg(){const i=this.#Kg*Math.PI/180,g=Math.cos(i),x=Math.sin(i);this.updateUniform("directionX",g),this.updateUniform("directionY",x)}}Object.freeze(DirectionalBlur);class RadialBlur extends ASinglePassPostEffect{#$g=50;#if=0;#af=0;#jg=16;constructor(i){super(i),this.init(i,"POST_EFFECT_RADIAL_BLUR",createBasicPostEffectCode(this,"let dimensions=textureDimensions(sourceTexture);\nlet dimW=f32(dimensions.x);\nlet dimH=f32(dimensions.y);\nlet center=vec2(dimW * 0.5 + uniforms.centerX,dimH * 0.5 + uniforms.centerY);\nlet global_id_vec=vec2(f32(global_id.x),f32(global_id.y));\nlet toPixel=global_id_vec - center;\nlet distance=length(toPixel);\nlet angle=atan2(toPixel.y,toPixel.x);\nlet maxDist=min(dimW,dimH) * 0.5;\nlet normalizedDistance=distance/maxDist;\nlet rotationAngle=uniforms.amount * normalizedDistance * 0.001;\nlet sampleCount=i32(uniforms.sampleCount);\nvar sum=vec4(0.0,0.0,0.0,0.0);\nvar totalWeight=0.0;\nfor (var i=0;i < sampleCount;i=i + 1) { let t=f32(i)/f32(sampleCount - 1); let sampleAngle=angle + (t - 0.5) * rotationAngle; let samplePos=center + vec2( cos(sampleAngle) * distance, sin(sampleAngle) * distance ); var weight=1.0 - abs(t - 0.5) * 1.5; weight=max(weight,0.1); let sampleCoord=vec2( i32(clamp(samplePos.x,0.0,dimW - 1.0)), i32(clamp(samplePos.y,0.0,dimH - 1.0)) ); sum +=textureLoad(sourceTexture,sampleCoord).xyzw * weight; totalWeight +=weight;\n}\nlet centerFalloff=smoothstep(0.0,maxDist * 0.2,distance);\nlet originalColor=textureLoad(sourceTexture,vec2(global_id.xy)).xyzw;\nlet blurredColor=sum/totalWeight;\nlet finalColor=mix(originalColor,blurredColor,centerFalloff);\ntextureStore(outputTexture,vec2(global_id.xy),finalColor);\n","struct Uniforms { amount:f32, centerX:f32, centerY:f32, sampleCount:f32\n};\n")),this.amount=this.#$g,this.sampleCount=this.#jg}get centerX(){return this.#if}set centerX(i){validateNumber(i),this.#if=i,this.updateUniform("centerX",i)}get centerY(){return this.#af}set centerY(i){validateNumber(i),this.#af=i,this.updateUniform("centerY",i)}get amount(){return this.#$g}set amount(i){validateNumberRange(i,0),this.#$g=i,this.updateUniform("amount",i)}get sampleCount(){return this.#jg}set sampleCount(i){validateNumberRange(i,4),this.#jg=i,this.updateUniform("sampleCount",i)}}Object.freeze(RadialBlur);class ZoomBlur extends ASinglePassPostEffect{#$g=64;#if=0;#af=0;constructor(i){super(i),this.init(i,"POST_EFFECT_ZOOM_BLUR",createBasicPostEffectCode(this,"let dimensions=textureDimensions(sourceTexture);\nlet dimW=f32(dimensions.x);\nlet dimH=f32(dimensions.y);\nlet dimensionsVec=vec2(dimW,dimH);\nlet amount=uniforms.amount/min(dimW,dimH);\nconst loopSize=30.0;\nlet offset=random(global_id,0.0);\nlet center=vec2(dimW * 0.5 + uniforms.centerX,dimH * 0.5 + uniforms.centerY);\nlet global_id_vec=vec2(f32(global_id.x),f32(global_id.y));\nlet dir=(center - global_id_vec) * amount;\nvar sum=vec4(0.0,0.0,0.0,0.0);\nvar total=0.0;\nfor (var t=-loopSize;t <=loopSize;t=t + 1.0) { var percent=1.0 - (t + offset - 0.5)/loopSize; var weight=3.0 * (percent - percent * percent); let deltaPercent=dir * percent; let delta=vec2( i32(clamp(global_id_vec.x + deltaPercent.x,0.0,dimW - 1.0)), i32(clamp(global_id_vec.y + deltaPercent.y,0.0,dimH - 1.0)) ); sum +=textureLoad(sourceTexture,delta).xyzw * weight; total +=weight;\n}\ntextureStore(outputTexture,vec2(global_id.xy),sum/total);\n","struct Uniforms { amount:f32, centerX:f32, centerY:f32\n};\nfn random(id:vec3,delta:f32) -> f32 { let seed:u32=((id.x << 16) | (id.y & 0xFFFF)) ^ (id.z * 0x63641362); let t:vec3=vec3(f32(seed & 0xFF),f32((seed >> 8) & 0xFF),f32(seed >> 16)); return delta + fract(sin(dot(t,vec3(12.9898,78.233,12.9898))) * 43758.5453);\n}\n")),this.amount=this.#$g}get centerX(){return this.#if}set centerX(i){validateNumber(i),this.#if=i,this.updateUniform("centerX",i)}get centerY(){return this.#af}set centerY(i){validateNumber(i),this.#af=i,this.updateUniform("centerY",i)}get amount(){return this.#$g}set amount(i){validateNumberRange(i,0),this.#$g=i,this.updateUniform("amount",i)}}Object.freeze(ZoomBlur);const oo={filmGrainIntensity:.02,filmGrainResponse:.9,filmGrainScale:2.5,coloredGrain:.3,grainSaturation:.4},uo={filmGrainIntensity:.05,filmGrainResponse:.8,filmGrainScale:3,coloredGrain:.5,grainSaturation:.6},lo={filmGrainIntensity:.12,filmGrainResponse:.6,filmGrainScale:4,coloredGrain:.7,grainSaturation:.8},co={filmGrainIntensity:.08,filmGrainResponse:.7,filmGrainScale:5,coloredGrain:.9,grainSaturation:1};class FilmGrain extends ASinglePassPostEffect{static SUBTLE=oo;static MEDIUM=uo;static HEAVY=lo;static VINTAGE=co;#Yg=lo.filmGrainIntensity;#qg=lo.filmGrainResponse;#Wg=lo.filmGrainScale;#Zg=lo.coloredGrain;#Jg=lo.grainSaturation;#Lm=0;#Qg=1;constructor(i){super(i),this.#Qg=window?.devicePixelRatio||1,this.init(i,"POST_EFFECT_FILM_GRAIN",createBasicPostEffectCode(this,"let index=vec2(global_id.xy);\nlet dimensions:vec2=textureDimensions(sourceTexture);\nlet dimW=f32(dimensions.x);\nlet dimH=f32(dimensions.y);\nlet uv=vec2(f32(index.x)/dimW,f32(index.y)/dimH);\nlet originalColor=textureLoad(sourceTexture,index);\nlet filmGrainIntensity_value:f32=uniforms.filmGrainIntensity;\nlet filmGrainResponse_value:f32=uniforms.filmGrainResponse;\nlet filmGrainScale_value:f32=uniforms.filmGrainScale;\nlet coloredGrain_value:f32=uniforms.coloredGrain;\nlet grainSaturation_value:f32=uniforms.grainSaturation;\nlet time_value:f32=uniforms.time;\nlet devicePixelRatio_value:f32=uniforms.devicePixelRatio;\nif (filmGrainIntensity_value <=0.0) { textureStore(outputTexture,index,originalColor); return;\n}\nlet baseScale=max(filmGrainScale_value,0.1);\nlet scaledUV=uv * vec2(dimW,dimH) * devicePixelRatio_value/baseScale;\nlet timeOffset=vec2( fract(time_value * 0.0317) * 100.0, fract(time_value * 0.0271) * 100.0\n);\nlet grainCoord=scaledUV + timeOffset;\nlet sampleOffset=1.0/baseScale;\nlet noiseR=(filmGrainNoise(grainCoord) + filmGrainNoise(grainCoord + vec2(sampleOffset,0.0)) + filmGrainNoise(grainCoord + vec2(0.0,sampleOffset)))/3.0;\nlet noiseG=filmGrainNoise(grainCoord + vec2(127.1,311.7));\nlet noiseB=filmGrainNoise(grainCoord + vec2(269.5,183.3));\nlet monoGrain=(noiseR + noiseG + noiseB)/3.0;\nlet colorGrain=vec3(noiseR,noiseG,noiseB);\nvar grainColor=mix(vec3(monoGrain),colorGrain,coloredGrain_value);\nlet grainLuminance=dot(grainColor,vec3(0.299,0.587,0.114));\ngrainColor=mix(vec3(grainLuminance),grainColor,grainSaturation_value);\nlet luminance=dot(originalColor.rgb,vec3(0.299,0.587,0.114));\nlet luminanceWeight=pow(max(luminance,0.01),filmGrainResponse_value);\nlet grainIntensity=filmGrainIntensity_value * luminanceWeight;\nlet grain=grainColor * grainIntensity;\nlet finalColor=originalColor.rgb + grain;\nlet outputColor=vec4(clamp(finalColor,vec3(0.0),vec3(1.0)),originalColor.a);\ntextureStore(outputTexture,index,outputColor);\n","struct Uniforms { filmGrainIntensity:f32, filmGrainResponse:f32, filmGrainScale:f32, coloredGrain:f32, grainSaturation:f32, time:f32, devicePixelRatio:f32\n};\nfn filmGrainNoise(coord:vec2) -> f32 { let p=floor(coord); let f=fract(coord); let u=f * f * f * (f * (f * 6.0 - 15.0) + 10.0); let a=hash(p); let b=hash(p + vec2(1.0,0.0)); let c=hash(p + vec2(0.0,1.0)); let d=hash(p + vec2(1.0,1.0)); let noise=mix(mix(a,b,u.x),mix(c,d,u.x),u.y); return (noise - 0.5) * 2.0;\n}\nfn hash(p:vec2) -> f32 { var p3=fract(vec3(p.xyx) * 0.1031); p3 +=dot(p3,p3.yzx + 33.33); return fract((p3.x + p3.y) * p3.z);\n}\n")),this.#ex()}get filmGrainIntensity(){return this.#Yg}set filmGrainIntensity(i){this.#Yg=Math.max(0,Math.min(1,i)),this.updateUniform("filmGrainIntensity",this.#Yg)}get filmGrainResponse(){return this.#qg}set filmGrainResponse(i){this.#qg=Math.max(0,Math.min(2,i)),this.updateUniform("filmGrainResponse",this.#qg)}get filmGrainScale(){return this.#Wg}set filmGrainScale(i){this.#Wg=Math.max(.1,Math.min(20,i)),this.updateUniform("filmGrainScale",this.#Wg)}get coloredGrain(){return this.#Zg}set coloredGrain(i){this.#Zg=Math.max(0,Math.min(1,i)),this.updateUniform("coloredGrain",this.#Zg)}get grainSaturation(){return this.#Jg}set grainSaturation(i){this.#Jg=Math.max(0,Math.min(2,i)),this.updateUniform("grainSaturation",this.#Jg)}applyPreset(i){this.#Yg=i.filmGrainIntensity,this.#qg=i.filmGrainResponse,this.#Wg=i.filmGrainScale,this.#Zg=i.coloredGrain,this.#Jg=i.grainSaturation,this.#ex()}update(i){this.#Lm+=i,this.updateUniform("time",this.#Lm)}#ex(){this.updateUniform("filmGrainIntensity",this.#Yg),this.updateUniform("filmGrainResponse",this.#qg),this.updateUniform("filmGrainScale",this.#Wg),this.updateUniform("coloredGrain",this.#Zg),this.updateUniform("grainSaturation",this.#Jg),this.updateUniform("time",this.#Lm),this.updateUniform("devicePixelRatio",this.#Qg)}}Object.freeze(FilmGrain);class Fog extends ASinglePassPostEffect{static EXPONENTIAL=0;static EXPONENTIAL_SQUARED=1;#tx=Fog.EXPONENTIAL;#nx=.05;#rx=4.5;#ix=50;#ax;constructor(i){super(i),this.useDepthTexture=!0,this.init(i,"POST_EFFECT_FOG",createBasicPostEffectCode(this,"let index=vec2(global_id.xy);\nlet coord=vec2(global_id.xy);\nvar sceneColor:vec4=textureLoad(sourceTexture,coord);\nlet depth=textureLoad(depthTexture,coord,0);\nlet linearDepth=linearizeDepth(depth,systemUniforms.camera.nearClipping,systemUniforms.camera.farClipping);\nlet fogFactor=calculateFogFactor(linearDepth,systemUniforms.camera.farClipping);\nlet finalColor=mix(uniforms.fogColor.rgb,sceneColor.rgb,fogFactor);\ntextureStore(outputTexture,coord,vec4(finalColor,sceneColor.a));\n","struct Uniforms { fogType:u32, density:f32, nearDistance:f32, farDistance:f32, fogColor:vec3, padding1:f32,\n};\nfn linearizeDepth(depth:f32,cameraNear:f32,cameraFar:f32) -> f32 { let z=depth * 2.0 - 1.0; return (2.0 * cameraNear * cameraFar)/ (cameraFar + cameraNear - z * (cameraFar - cameraNear));\n}\nfn calculateFogFactor(linearDepth:f32,cameraFar:f32) -> f32 { let u_density=uniforms.density; let u_fogType=uniforms.fogType; let u_nearDistance=uniforms.nearDistance; let u_farDistance=uniforms.farDistance; let isBackground=linearDepth >=(cameraFar * 0.99); if (isBackground) { return 1.0 - u_density; } let distance=max(0.0,linearDepth - u_nearDistance); let maxDistance=u_farDistance - u_nearDistance; let normalizedDistance=clamp(distance/max(0.1,maxDistance),0.0,1.0); var fogFactor:f32; if (u_fogType==0u) { fogFactor=exp(-u_density * normalizedDistance * 10.0); } else { let expValue=u_density * normalizedDistance * 5.0; fogFactor=exp(-(expValue * expValue)); } return clamp(fogFactor,0.0,1.0);\n}\n")),this.#ax=new ColorRGB(178,178,204,()=>{this.updateUniform("fogColor",this.#ax.rgbNormalLinear)}),this.fogType=this.#tx,this.density=this.#nx,this.nearDistance=this.#rx,this.farDistance=this.#ix}get fogType(){return this.#tx}set fogType(i){validateNumberRange(i,0,1),this.#tx=Math.floor(i),this.updateUniform("fogType",this.#tx)}get density(){return this.#nx}set density(i){validateNumberRange(i,0,1),this.#nx=Math.max(0,Math.min(1,i)),this.updateUniform("density",this.#nx)}get nearDistance(){return this.#rx}set nearDistance(i){validateNumberRange(i,0),this.#rx=Math.max(.1,i),this.#ix<=this.#rx&&(this.#ix=this.#rx+.1,this.updateUniform("farDistance",this.#ix)),this.updateUniform("nearDistance",this.#rx)}get farDistance(){return this.#ix}set farDistance(i){validateNumberRange(i,0),this.#ix=Math.max(this.#rx+.1,i),this.updateUniform("farDistance",this.#ix)}get fogColor(){return this.#ax}render(i,g,x,_){return super.render(i,g,x,_)}}Object.freeze(Fog);class HeightFog extends ASinglePassPostEffect{static EXPONENTIAL=0;static EXPONENTIAL_SQUARED=1;#tx=HeightFog.EXPONENTIAL;#nx=1;#ax;#sx=0;#ox=100;#ux=.1;constructor(i){super(i),this.useDepthTexture=!0,this.init(i,"POST_EFFECT_HEIGHT_FOG",createBasicPostEffectCode(this,"let dimensions=textureDimensions(sourceTexture);\nlet dimW=f32(dimensions.x);\nlet dimH=f32(dimensions.y);\nlet global_id_vec=vec2(f32(global_id.x),f32(global_id.y));\nlet screenCoord=vec2( global_id_vec.x/dimW,global_id_vec.y/dimH );\nvar depth:f32=1.0;\nif (dimensions.x > u32(global_id.x) && dimensions.y > u32(global_id.y)) { depth=textureLoad(depthTexture,vec2(global_id.xy),0);\n}\nlet fogFactor=calculateHeightFogFactor(screenCoord,depth);\nlet originalColor=textureLoad(sourceTexture,vec2(global_id.xy)).rgb;\nlet foggedColor=mix(uniforms.fogColor,originalColor,fogFactor);\ntextureStore(outputTexture,vec2(global_id.xy),vec4(foggedColor,1.0));\n","struct Uniforms { fogType:u32, density:f32, baseHeight:f32, falloff:f32, maxHeight:f32, fogColor:vec3, padding1:f32, padding2:f32,\n};\nfn isFiniteValue(value:f32) -> bool { return value==value;\n}\nfn isFiniteVec3(v:vec3) -> bool { return isFiniteValue(v.x) && isFiniteValue(v.y) && isFiniteValue(v.z);\n}\nfn reconstructWorldPositionUltraPrecise(screenCoord:vec2,depth:f32) -> vec3 { let ndcX=fma(screenCoord.x,2.0,-1.0); let ndcY=fma(-screenCoord.y,2.0,1.0); let safeDepth=clamp(depth,1e-7,1.0 - 1e-7); let ndc=vec3(ndcX,ndcY,safeDepth); let clipPos=vec4(ndc,1.0); let worldPos4=systemUniforms.inverseProjectionCameraMatrix * clipPos; let epsilon=1e-6; let w=select(worldPos4.w,epsilon,abs(worldPos4.w) < epsilon); let worldPos=worldPos4.xyz/w; let maxCoord=1e6; let stabilizedX=clamp(worldPos.x,-maxCoord,maxCoord); let stabilizedY=clamp(worldPos.y,-maxCoord,maxCoord); let stabilizedZ=clamp(worldPos.z,-maxCoord,maxCoord); let finalPos=vec3(stabilizedX,stabilizedY,stabilizedZ); return select(vec3(0.0,0.0,0.0),finalPos,isFiniteVec3(finalPos));\n}\nfn calculateHeightFogFactor(screenCoord:vec2,depth:f32) -> f32 { let backgroundThreshold=1.0 - 1e-5; let isBackground=depth >=backgroundThreshold; var pixelWorldHeight:f32; if (isBackground) { let rayDirection=getRayDirectionMaxPrecision(screenCoord); pixelWorldHeight=getSkyboxHeightMaxPrecision(rayDirection); } else { let worldPos=reconstructWorldPositionUltraPrecise(screenCoord,depth); pixelWorldHeight=worldPos.y; } return calculateAbsoluteHeightFogMaxPrecision(pixelWorldHeight);\n}\nfn getSkyboxHeightMaxPrecision(rayDirection:vec3) -> f32 { let u_baseHeight=uniforms.baseHeight; let u_maxHeight=uniforms.maxHeight; let rayY=clamp(rayDirection.y,-0.999,0.999); let upThreshold=0.08; let downThreshold=-0.015; let transitionRange=upThreshold - downThreshold; let safeTransitionRange=max(transitionRange,1e-6); if (rayY > upThreshold) { return u_maxHeight + 25.0; } else if (rayY < downThreshold) { return fma(u_maxHeight - u_baseHeight,0.03,u_baseHeight); } else { let normalizedT=(rayY - downThreshold)/safeTransitionRange; let smoothT=smoothstep(0.0,1.0,normalizedT); let lowValue=fma(u_maxHeight - u_baseHeight,0.03,u_baseHeight); let highValue=u_maxHeight + 25.0; return fma(smoothT,highValue - lowValue,lowValue); }\n}\nfn calculateAbsoluteHeightFogMaxPrecision(worldHeight:f32) -> f32 { let u_baseHeight=uniforms.baseHeight; let u_maxHeight=uniforms.maxHeight; let u_density=uniforms.density; let u_falloff=uniforms.falloff; let u_fogType=uniforms.fogType; if (!isFiniteValue(worldHeight)) { return 1.0; } let heightRange=u_maxHeight - u_baseHeight; let safeHeightRange=max(heightRange,1e-3); let margin=fma(safeHeightRange,0.18,1.2); let extendedBaseHeight=u_baseHeight - margin; let extendedMaxHeight=u_maxHeight + margin; let extendedRange=extendedMaxHeight - extendedBaseHeight; if (worldHeight <=extendedBaseHeight || worldHeight >=extendedMaxHeight) { return 1.0; } let safeExtendedRange=max(extendedRange,1e-3); if (safeExtendedRange <=0.3) { return 1.0; } let normalizedHeight=clamp( (worldHeight - extendedBaseHeight)/safeExtendedRange, 0.0, 1.0 ); let centerOffset=normalizedHeight - 0.5; let edgeFactor=fma(-abs(centerOffset),0.25,1.0); let heightFactor=1.0 - normalizedHeight; let safeHeightFactor=max(heightFactor,1e-4); let safeFalloff=clamp(u_falloff,0.05,1.8); let expPower=fma(safeFalloff,0.73,1.05); var fogDensity:f32; if (u_fogType==0u) { fogDensity=pow(safeHeightFactor,expPower); fogDensity=smoothstep(0.0,1.0,fogDensity); } else { let expResult=pow(safeHeightFactor,expPower); fogDensity=expResult * expResult; fogDensity=smoothstep(0.0,1.0,fogDensity); } let densityWithEdge=fogDensity * edgeFactor; let safeDensity=clamp(u_density,0.0,4.0); let finalFogAmount=fma(densityWithEdge,safeDensity,0.0) * 0.42; let result=clamp(1.0 - finalFogAmount,0.0,1.0); return select(1.0,result,isFiniteValue(result));\n}\nfn getRayDirectionMaxPrecision(screenCoord:vec2) -> vec3 { let centeredX=fma(screenCoord.x,1.0,-0.5); let centeredY=fma(screenCoord.y,1.0,-0.5); let ndcX=centeredX * 2.0; let ndcY=-(centeredY * 2.0); let ndc=vec3(ndcX,ndcY,1.0); let clipPos=vec4(ndc,1.0); let worldPos4=systemUniforms.inverseProjectionCameraMatrix * clipPos; let epsilon=1e-6; let w=select(worldPos4.w,epsilon,abs(worldPos4.w) < epsilon); let worldPos=worldPos4.xyz/w; let cameraPos=systemUniforms.camera.cameraPosition; let rayDir=worldPos - cameraPos; let rayLength=length(rayDir); let minLength=1e-6; if (rayLength < minLength) { return vec3(0.0,0.0,1.0); } let normalizedRay=rayDir/rayLength; let safeRayX=clamp(normalizedRay.x,-0.999,0.999); let safeRayY=clamp(normalizedRay.y,-0.999,0.999); let safeRayZ=clamp(normalizedRay.z,-0.999,0.999); let safeRay=vec3(safeRayX,safeRayY,safeRayZ); let finalRayLength=length(safeRay); let isValidRay=finalRayLength > 1e-6 && isFiniteValue(finalRayLength); if (isValidRay) { let finalRay=safeRay/finalRayLength; return select(vec3(0.0,0.0,1.0),finalRay,isFiniteVec3(finalRay)); } return vec3(0.0,0.0,1.0);\n}\n")),this.#ax=new ColorRGB(178,178,204,()=>{this.updateUniform("fogColor",this.#ax.rgbNormal)}),this.fogType=this.#tx,this.density=this.#nx,this.baseHeight=this.#sx,this.thickness=this.#ox,this.falloff=this.#ux}get fogType(){return this.#tx}set fogType(i){validateNumberRange(i,0,1),this.#tx=Math.floor(i),this.updateUniform("fogType",this.#tx)}get density(){return this.#nx}set density(i){validateNumberRange(i,0,5),this.#nx=Math.max(0,Math.min(5,i)),this.updateUniform("density",this.#nx)}get fogColor(){return this.#ax}get baseHeight(){return this.#sx}set baseHeight(i){validateNumberRange(i),this.#sx=i,this.updateUniform("baseHeight",this.#sx),this.updateUniform("maxHeight",this.maxHeight)}get maxHeight(){return this.#sx+this.#ox}get thickness(){return this.#ox}set thickness(i){validateNumberRange(i,.1),this.#ox=Math.max(.1,i),this.updateUniform("maxHeight",this.#sx+this.#ox)}get falloff(){return this.#ux}set falloff(i){validateNumberRange(i,0,2),this.#ux=Math.max(.001,Math.min(2,i)),this.updateUniform("falloff",this.#ux)}render(i,g,x,_){return super.render(i,g,x,_)}}Object.freeze(HeightFog);class ChromaticAberration extends ASinglePassPostEffect{#kg=.015;#if=.5;#af=.5;#ux=1;constructor(i){super(i),this.init(i,"POST_EFFECT_CHROMATIC_ABERRATION",createBasicPostEffectCode(this,"let dimensions=textureDimensions(sourceTexture);\nlet dimW=f32(dimensions.x);\nlet dimH=f32(dimensions.y);\nlet uv=vec2(f32(global_id.x),f32(global_id.y))/vec2(dimW,dimH);\nlet center=vec2(uniforms.centerX,uniforms.centerY);\nlet offset=uv - center;\nlet distance=length(offset);\nlet distortion=uniforms.strength * pow(distance,uniforms.falloff);\nlet redOffset=uv + offset * distortion * vec2(-1.0,-1.0);\nlet greenOffset=uv;\nlet blueOffset=uv + offset * distortion * vec2(1.0,1.0);\nvar finalColor=vec3(0.0);\nif (redOffset.x >=0.0 && redOffset.x <=1.0 && redOffset.y >=0.0 && redOffset.y <=1.0) { let redCoord=vec2( i32(clamp(redOffset.x * dimW,0.0,dimW - 1.0)), i32(clamp(redOffset.y * dimH,0.0,dimH - 1.0)) ); finalColor.r=textureLoad(sourceTexture,redCoord).r;\n}\nlet greenCoord=vec2( i32(clamp(greenOffset.x * dimW,0.0,dimW - 1.0)), i32(clamp(greenOffset.y * dimH,0.0,dimH - 1.0))\n);\nfinalColor.g=textureLoad(sourceTexture,greenCoord).g;\nif (blueOffset.x >=0.0 && blueOffset.x <=1.0 && blueOffset.y >=0.0 && blueOffset.y <=1.0) { let blueCoord=vec2( i32(clamp(blueOffset.x * dimW,0.0,dimW - 1.0)), i32(clamp(blueOffset.y * dimH,0.0,dimH - 1.0)) ); finalColor.b=textureLoad(sourceTexture,blueCoord).b;\n}\nlet originalAlpha=textureLoad(sourceTexture,vec2(global_id.xy)).a;\ntextureStore(outputTexture,vec2(global_id.xy),vec4(finalColor,originalAlpha));\n","struct Uniforms { strength:f32, centerX:f32, centerY:f32, falloff:f32\n};\n")),this.strength=this.#kg,this.centerX=this.#if,this.centerY=this.#af,this.falloff=this.#ux}get strength(){return this.#kg}set strength(i){validateNumberRange(i,0),this.#kg=i,this.updateUniform("strength",i)}get centerX(){return this.#if}set centerX(i){validateNumberRange(i,0,1),this.#if=i,this.updateUniform("centerX",i)}get centerY(){return this.#af}set centerY(i){validateNumberRange(i,0,1),this.#af=i,this.updateUniform("centerY",i)}get falloff(){return this.#ux}set falloff(i){validateNumberRange(i,0,5),this.#ux=i,this.updateUniform("falloff",i)}}Object.freeze(ChromaticAberration);class DOFCoC extends ASinglePassPostEffect{#lx=15;#cx=1.4;#hx=32;#fx=.1;#dx=1e3;constructor(i){super(i),this.useDepthTexture=!0,this.init(i,"POST_EFFECT_DOF_COC",createBasicPostEffectCode(this,"let index=vec2(global_id.xy);\nlet coord=vec2(global_id.xy);\nlet originalColor=textureLoad(sourceTexture,coord).xyzw;\nlet depth=textureLoad(depthTexture,coord,0);\nlet linearDepth=linearizeDepth(depth);\nlet coc=calculateCoC(linearDepth);\nlet encodedCoC=encodeCoC(coc);\ntextureStore(outputTexture,coord,vec4(originalColor.rgb,encodedCoC));\n","struct Uniforms { focusDistance:f32, aperture:f32, maxCoC:f32, nearPlane:f32, farPlane:f32,\n};\nfn linearizeDepth(depth:f32) -> f32 { let z=depth * 2.0 - 1.0; return (2.0 * uniforms.nearPlane * uniforms.farPlane)/ (uniforms.farPlane + uniforms.nearPlane - z * (uniforms.farPlane - uniforms.nearPlane));\n}\nfn encodeCoC(coc:f32) -> f32 { return (coc + 1.0) * 0.5;\n}\nfn calculateCoC(linearDepth:f32) -> f32 { let subjectDistance=linearDepth; let focalLength=50.0; let focusRange=uniforms.focusDistance * 0.15; let transitionRange=uniforms.focusDistance * 0.35; let distanceFromFocus=abs(subjectDistance - uniforms.focusDistance); if (distanceFromFocus < focusRange) { let focusFactor=smoothstep(0.0,focusRange,distanceFromFocus); return mix(0.0,0.02,focusFactor); } var rawCoC:f32; var signedCoC:f32; if (subjectDistance < uniforms.focusDistance) { let nearDistance=uniforms.focusDistance - subjectDistance; let nearFactor=nearDistance/uniforms.focusDistance; rawCoC=(uniforms.aperture * focalLength * nearDistance)/ (subjectDistance * (uniforms.focusDistance - focalLength)); rawCoC=rawCoC * (1.0 + nearFactor * 1.5); signedCoC=-(rawCoC/uniforms.maxCoC); let absCoC=abs(signedCoC); if (absCoC > 0.05) { signedCoC=-min(1.0,absCoC * smoothstep(0.05,0.3,absCoC) * 1.5); } if (distanceFromFocus < transitionRange) { let transitionFactor=smoothstep(focusRange,transitionRange,distanceFromFocus); signedCoC=mix(0.0,signedCoC,transitionFactor); } return clamp(signedCoC,-1.0,0.0); } else { let farDistance=subjectDistance - uniforms.focusDistance; rawCoC=(uniforms.aperture * focalLength * farDistance)/ (subjectDistance * (uniforms.focusDistance + focalLength)); rawCoC=rawCoC * (1.0 + farDistance * 0.08); signedCoC=rawCoC/uniforms.maxCoC; let absCoC=abs(signedCoC); if (absCoC > 0.1) { signedCoC=min(1.0,absCoC * smoothstep(0.1,0.5,absCoC) * 1.2); } if (distanceFromFocus < transitionRange) { let transitionFactor=smoothstep(focusRange,transitionRange,distanceFromFocus); signedCoC=mix(0.0,signedCoC,transitionFactor); } return clamp(signedCoC,0.0,1.0); }\n}\n")),this.focusDistance=this.#lx,this.aperture=this.#cx,this.maxCoC=this.#hx,this.nearPlane=this.#fx,this.farPlane=this.#dx}get focusDistance(){return this.#lx}set focusDistance(i){validateNumberRange(i),this.#lx=i,this.updateUniform("focusDistance",i)}get aperture(){return this.#cx}set aperture(i){validateNumberRange(i),this.#cx=i,this.updateUniform("aperture",i)}get maxCoC(){return this.#hx}set maxCoC(i){validateNumberRange(i),this.#hx=i,this.updateUniform("maxCoC",i)}get nearPlane(){return this.#fx}set nearPlane(i){validateNumberRange(i),this.#fx=i,this.updateUniform("nearPlane",i)}get farPlane(){return this.#dx}set farPlane(i){validateNumberRange(i),this.#dx=i,this.updateUniform("farPlane",i)}}Object.freeze(DOFCoC);class DOFUnified extends ASinglePassPostEffect{#mx=16;#px=24;#gx=1;#xx=1;constructor(i){super(i);const{WORK_SIZE_X:g,WORK_SIZE_Y:x,WORK_SIZE_Z:_}=this,v=` struct Uniforms { nearBlurSize:f32, farBlurSize:f32, nearStrength:f32, farStrength:f32, }; @group(0) @binding(0) var sourceTexture:texture_storage_2d; @group(0) @binding(1) var cocTexture:texture_storage_2d; @group(1) @binding(0) var outputTexture:texture_storage_2d; @group(1) @binding(1) var uniforms:Uniforms; /* CoC 디코딩 함수 */ fn decodeCoC(encoded:f32) -> f32 { /* 0~1 범위를 -1~1 범위로 복원 */ return encoded * 2.0 - 1.0; } @compute @workgroup_size(${g},${x},${_}) fn main (@builtin(global_invocation_id) global_id:vec3) { let index=vec2(global_id.xy); let dimensions:vec2=textureDimensions(sourceTexture); if (index.x >=dimensions.x || index.y >=dimensions.y) { return; } let originalSample=textureLoad(sourceTexture,index); let originalColor=originalSample.rgb; let originalAlpha=originalSample.a; let encodedCoC=textureLoad(cocTexture,index).a; /* CoC 값 디코딩 */ let cocValue=decodeCoC(encodedCoC); /* CoC 임계값 체크 */ if (abs(cocValue) < 0.005) { textureStore(outputTexture,index,vec4(originalColor,originalAlpha)); return; } var finalColor=originalColor; var finalAlpha=originalAlpha; /* Near blur 처리 (CoC < 0) */ if (cocValue < 0.0) { let blurResult=calculateBlur(index,abs(cocValue),uniforms.nearBlurSize,true); let nearBlur=blurResult.rgb; let nearBlurAlpha=blurResult.a; /* Near strength 블렌딩 개선 - 더 강한 효과 */ let nearBlend=saturate(pow(abs(cocValue) * uniforms.nearStrength,0.7)); finalColor=mix(originalColor,nearBlur,nearBlend); finalAlpha=mix(originalAlpha,nearBlurAlpha,nearBlend); } /* Far blur 처리 (CoC > 0) */ else if (cocValue > 0.0) { let blurResult=calculateBlur(index,cocValue,uniforms.farBlurSize,false); let farBlur=blurResult.rgb; let farBlurAlpha=blurResult.a; let rawBlend=cocValue * uniforms.farStrength; let farBlend=saturate(smoothstep(0.0,0.8,rawBlend)); finalColor=mix(originalColor,farBlur,farBlend); finalAlpha=mix(originalAlpha,farBlurAlpha,farBlend); } textureStore(outputTexture,index,vec4(finalColor,finalAlpha)); } fn calculateBlur(center:vec2,intensity:f32,maxBlurSize:f32,isNear:bool) -> vec4 { let dimensions:vec2=textureDimensions(sourceTexture); let blurRadius=intensity * maxBlurSize; /* 최소 블러 반경 조정 */ if (blurRadius < 0.3) { return textureLoad(sourceTexture,center); } var sum:vec3=vec3(0.0); var sumAlpha:f32=0.0; var totalWeight=0.0; let maxRadius=min(blurRadius,maxBlurSize); /* Near blur에 더 많은 샘플 적용 */ let samples=select(8,16,isNear);/* near=16,far=8 */ let angleStep=6.28318530718/f32(samples); let originalSample=textureLoad(sourceTexture,center); let originalColor=originalSample.rgb; let originalAlpha=originalSample.a; /* Near blur에 더 강한 중앙 가중치 */ let centerWeight=select(0.4,0.2,isNear);/* near=0.2,far=0.4 */ sum +=originalColor * centerWeight; sumAlpha +=originalAlpha * centerWeight; totalWeight +=centerWeight; /* 방사형 샘플링 */ for (var i=0;i < samples;i=i + 1) { for (var r=1.0;r <=maxRadius;r=r + 1.0) { let angle=f32(i) * angleStep; let offset=vec2(cos(angle) * r,sin(angle) * r); let samplePos=vec2( clamp(i32(f32(center.x) + offset.x),0,i32(dimensions.x) - 1), clamp(i32(f32(center.y) + offset.y),0,i32(dimensions.y) - 1) ); let sampleData=textureLoad(sourceTexture,vec2(samplePos)); let sampleColor=sampleData.rgb; let sampleAlpha=sampleData.a; let sampleEncodedCoC=textureLoad(cocTexture,vec2(samplePos)).a; let sampleCoC=decodeCoC(sampleEncodedCoC);/* 디코딩 추가 */ /* 가우시안 가중치 */ var weight=exp(-r * r/(maxRadius * maxRadius * 0.5)); /* CoC 기반 가중치 조정 */ if (isNear) { /* Near blur:더 강한 조건으로 가중치 증가 */ if (sampleCoC < 0.0 && abs(sampleCoC) >=intensity * 0.5) { weight *=1.5; } } else { /* Far blur:기존 조건 유지 */ if (sampleCoC > 0.0 && sampleCoC >=intensity * 0.7) { weight *=1.2; } } sum +=sampleColor * weight; sumAlpha +=sampleAlpha * weight; totalWeight +=weight; } } /* 추가 근거리 샘플링 (near blur만) */ if (isNear && maxRadius > 2.0) { let additionalSamples=8; let innerRadius=maxRadius * 0.3; let innerAngleStep=6.28318530718/f32(additionalSamples); for (var i=0;i < additionalSamples;i=i + 1) { let angle=f32(i) * innerAngleStep + 0.5;/* 약간의 오프셋 */ let offset=vec2(cos(angle) * innerRadius,sin(angle) * innerRadius); let samplePos=vec2( clamp(i32(f32(center.x) + offset.x),0,i32(dimensions.x) - 1), clamp(i32(f32(center.y) + offset.y),0,i32(dimensions.y) - 1) ); let sampleData=textureLoad(sourceTexture,vec2(samplePos)); let sampleColor=sampleData.rgb; let sampleAlpha=sampleData.a; let weight=0.8; sum +=sampleColor * weight; sumAlpha +=sampleAlpha * weight; totalWeight +=weight; } } if (totalWeight > 0.0) { return vec4(sum/totalWeight,sumAlpha/totalWeight); } else { return vec4(originalColor,originalAlpha); } } `;this.init(i,"POST_EFFECT_DOF_UNIFIED",{msaa:v,nonMsaa:v}),this.nearBlurSize=this.#mx,this.farBlurSize=this.#px,this.nearStrength=this.#gx,this.farStrength=this.#xx}get nearBlurSize(){return this.#mx}set nearBlurSize(i){validateNumberRange(i),this.#mx=i,this.updateUniform("nearBlurSize",i)}get farBlurSize(){return this.#px}set farBlurSize(i){validateNumberRange(i),this.#px=i,this.updateUniform("farBlurSize",i)}get nearStrength(){return this.#gx}set nearStrength(i){validateNumberRange(i),this.#gx=i,this.updateUniform("nearStrength",i)}get farStrength(){return this.#xx}set farStrength(i){validateNumberRange(i),this.#xx=i,this.updateUniform("farStrength",i)}render(i,g,x,_,v){return super.render(i,g,x,_,v)}}Object.freeze(DOFUnified);class DOF extends AMultiPassPostEffect{#_x;#vx;#lx=15;#cx=2.8;#hx=25;#fx=.1;#dx=1e3;#mx=15;#px=15;#gx=1;#xx=1;constructor(i){super(i,[new DOFCoC(i),new DOFUnified(i)]),this.#_x=this.passList[0],this.#vx=this.passList[1],this.#_x.focusDistance=this.#lx,this.#_x.aperture=this.#cx,this.#_x.maxCoC=this.#hx,this.#_x.nearPlane=this.#fx,this.#_x.farPlane=this.#dx,this.#vx.nearBlurSize=this.#mx,this.#vx.farBlurSize=this.#px,this.#vx.nearStrength=this.#gx,this.#vx.farStrength=this.#xx}get focusDistance(){return this.#lx}set focusDistance(i){this.#lx=i,this.#_x.focusDistance=i}get aperture(){return this.#cx}set aperture(i){this.#cx=i,this.#_x.aperture=i}get maxCoC(){return this.#hx}set maxCoC(i){this.#hx=i,this.#_x.maxCoC=i}get nearPlane(){return this.#fx}set nearPlane(i){this.#fx=i,this.#_x.nearPlane=i}get farPlane(){return this.#dx}set farPlane(i){this.#dx=i,this.#_x.farPlane=i}get nearBlurSize(){return this.#mx}set nearBlurSize(i){this.#mx=i,this.#vx.nearBlurSize=i}get farBlurSize(){return this.#px}set farBlurSize(i){this.#px=i,this.#vx.farBlurSize=i}get nearStrength(){return this.#gx}set nearStrength(i){this.#gx=i,this.#vx.nearStrength=i}get farStrength(){return this.#xx}set farStrength(i){this.#xx=i,this.#vx.farStrength=i}setGameDefault(){this.focusDistance=15,this.aperture=2.8,this.maxCoC=25,this.nearBlurSize=15,this.farBlurSize=15,this.nearStrength=1,this.farStrength=1}setCinematic(){this.focusDistance=20,this.aperture=1.4,this.maxCoC=40,this.nearBlurSize=25,this.farBlurSize=30,this.nearStrength=1.2,this.farStrength=1.3}setPortrait(){this.focusDistance=8,this.aperture=1.8,this.maxCoC=35,this.nearBlurSize=12,this.farBlurSize=25,this.nearStrength=.8,this.farStrength=1.4}setLandscape(){this.focusDistance=50,this.aperture=8,this.maxCoC=20,this.nearBlurSize=20,this.farBlurSize=10,this.nearStrength=1.1,this.farStrength=.6}setMacro(){this.focusDistance=2,this.aperture=1,this.maxCoC=50,this.nearBlurSize=30,this.farBlurSize=35,this.nearStrength=1.5,this.farStrength=1.6}setSports(){this.focusDistance=25,this.aperture=4,this.maxCoC=18,this.nearBlurSize=10,this.farBlurSize=12,this.nearStrength=.8,this.farStrength=.9}setNightMode(){this.focusDistance=12,this.aperture=2,this.maxCoC=30,this.nearBlurSize=18,this.farBlurSize=20,this.nearStrength=1.1,this.farStrength=1.2}render(i,g,x,_){const v=this.#_x.render(i,g,x,_);return this.#vx.render(i,g,x,_,v)}}Object.freeze(DOF);class LensDistortion extends ASinglePassPostEffect{#bx=.1;#yx=0;#if=0;#af=0;constructor(i){super(i),this.init(i,"POST_EFFECT_LENS_DISTORTION",createBasicPostEffectCode(this,"let dimensions=textureDimensions(sourceTexture);\nlet dimW=f32(dimensions.x);\nlet dimH=f32(dimensions.y);\nlet center=vec2(dimW * 0.5 + uniforms.centerX,dimH * 0.5 + uniforms.centerY);\nlet global_id_vec=vec2(f32(global_id.x),f32(global_id.y));\nlet uv=global_id_vec/vec2(dimW,dimH);\nlet uvCenter=center/vec2(dimW,dimH);\nlet offset=uv - uvCenter;\nlet distance=length(offset);\nlet barrelFactor=1.0 + uniforms.barrelStrength * distance * distance;\nlet pincushionFactor=1.0 - uniforms.pincushionStrength * distance * distance;\nlet distortionFactor=barrelFactor * pincushionFactor;\nlet distortedUV=uvCenter + offset * distortionFactor;\nif (distortedUV.x < 0.0 || distortedUV.x > 1.0 || distortedUV.y < 0.0 || distortedUV.y > 1.0) { textureStore(outputTexture,vec2(global_id.xy),vec4(0.0,0.0,0.0,1.0));\n} else { let sampleCoord=vec2( i32(clamp(distortedUV.x * dimW,0.0,dimW - 1.0)), i32(clamp(distortedUV.y * dimH,0.0,dimH - 1.0)) ); let sampledColor=textureLoad(sourceTexture,sampleCoord).xyzw; textureStore(outputTexture,vec2(global_id.xy),sampledColor);\n}\n","struct Uniforms { barrelStrength:f32, pincushionStrength:f32, centerX:f32, centerY:f32\n};\n")),this.barrelStrength=this.#bx,this.pincushionStrength=this.#yx,this.centerX=this.#if,this.centerY=this.#af}get barrelStrength(){return this.#bx}set barrelStrength(i){validateNumberRange(i,0),this.#bx=i,this.updateUniform("barrelStrength",i)}get pincushionStrength(){return this.#yx}set pincushionStrength(i){validateNumberRange(i,0),this.#yx=i,this.updateUniform("pincushionStrength",i)}get centerX(){return this.#if}set centerX(i){validateNumber(i),this.#if=i,this.updateUniform("centerX",i)}get centerY(){return this.#af}set centerY(i){validateNumber(i),this.#af=i,this.updateUniform("centerY",i)}}Object.freeze(LensDistortion);class Vignetting extends ASinglePassPostEffect{#Sx=.2;#Qt=.5;constructor(i){super(i),this.init(i,"POST_EFFECT_VIGNETTING",createBasicPostEffectCode(this,"let dimensions=textureDimensions(sourceTexture);\nlet dimW=f32(dimensions.x);\nlet dimH=f32(dimensions.y);\nlet index=vec2(global_id.xy);\nlet uv=vec2(f32(index.x)/dimW,f32(index.y)/dimH);\nlet smoothness=uniforms.smoothness;\nlet size=uniforms.size;\nvar color:vec4=textureLoad(sourceTexture,index);\nvar diff=size - distance(uv,vec2(0.5));\nlet vignette=smoothstep(-smoothness,smoothness,diff);\ncolor.r *=vignette;\ncolor.g *=vignette;\ncolor.b *=vignette;\ntextureStore(outputTexture,index,color);\n","struct Uniforms { smoothness:f32, size:f32,\n};\n")),this.smoothness=this.#Sx,this.size=this.#Qt}get size(){return this.#Qt}set size(i){validateNumberRange(i,0),this.#Qt=i,this.updateUniform("size",i)}get smoothness(){return this.#Sx}set smoothness(i){validateNumberRange(i,0,1),this.#Sx=i,this.updateUniform("smoothness",i)}}Object.freeze(Vignetting);class OldBloomBlend extends ASinglePassPostEffect{#Tx=1;#pc=1;constructor(i){super(i);const{WORK_SIZE_X:g,WORK_SIZE_Y:x,WORK_SIZE_Z:_}=this,v=` struct Uniforms { bloomStrength:f32, exposure:f32 }; @group(0) @binding(0) var sourceTexture0:texture_storage_2d; @group(0) @binding(1) var sourceTexture1:texture_storage_2d; @group(1) @binding(0) var outputTexture:texture_storage_2d; @group(1) @binding(1) var uniforms:Uniforms; @compute @workgroup_size(${g},${x},${_}) fn main ( @builtin(global_invocation_id) global_id:vec3, ){ let index=vec2(global_id.xy ); let dimensions:vec2=textureDimensions(sourceTexture0); let dimW=f32(dimensions.x); let dimH=f32(dimensions.y); let uv=\tvec2(f32(index.x)/dimW,f32(index.y)/dimH); var diffuse:vec4=textureLoad( sourceTexture0, index, ); var blur:vec4=textureLoad( sourceTexture1, index, ); let finalColor=vec4((diffuse.rgb + blur.rgb * uniforms.bloomStrength ) * uniforms.exposure,diffuse.a); textureStore(outputTexture,index,finalColor ); }; `;this.init(i,"POST_EFFECT_OLD_BLOOM",{msaa:v,nonMsaa:v}),this.exposure=this.#pc,this.bloomStrength=this.#Tx}get bloomStrength(){return this.#Tx}set bloomStrength(i){this.#Tx=i,this.updateUniform("bloomStrength",i)}get exposure(){return this.#pc}set exposure(i){this.#pc=i,this.updateUniform("exposure",i)}render(i,g,x,_,v){return super.render(i,g,x,_,v)}}Object.freeze(OldBloomBlend);class OldBloom extends AMultiPassPostEffect{#Mx;#wx;#Cx;#Vg=156;#Rx=32;#pc=1;#Tx=1.2;constructor(i){super(i,[new Threshold(i),new GaussianBlur(i),new OldBloomBlend(i)]),this.#Mx=this.passList[0],this.#wx=this.passList[1],this.#Cx=this.passList[2],this.#Mx.threshold=this.#Vg,this.#wx.size=this.#Rx,this.#Cx.exposure=this.#pc,this.#Cx.bloomStrength=this.#Tx}get threshold(){return this.#Vg}set threshold(i){this.#Vg=i,this.#Mx.threshold=i}get gaussianBlurSize(){return this.#Rx}set gaussianBlurSize(i){this.#Rx=i,this.#wx.size=i}get exposure(){return this.#pc}set exposure(i){this.#pc=i,this.#Cx.exposure=i}get bloomStrength(){return this.#Tx}set bloomStrength(i){this.#Tx=i,this.#Cx.bloomStrength=i}render(i,g,x,_){const v=this.#Mx.render(i,g,x,_),b=this.#wx.render(i,g,x,v);return this.#Cx.render(i,g,x,_,b)}}Object.freeze(OldBloom);class Sharpen extends AMultiPassPostEffect{#zg;constructor(i){super(i,[new Convolution(i)]),this.#zg=this.passList[0],this.#zg.kernel=Convolution.SHARPEN}render(i,g,x,_){return this.#zg.render(i,g,x,_)}}Object.freeze(Sharpen);var ho=Object.freeze({__proto__:null,AMultiPassPostEffect:AMultiPassPostEffect,ASinglePassPostEffect:ASinglePassPostEffect,createBasicPostEffectCode:createBasicPostEffectCode}),fo=Object.freeze({__proto__:null,Blur:Blur,BlurX:BlurX,BlurY:BlurY,BrightnessContrast:BrightnessContrast,ChromaticAberration:ChromaticAberration,ColorBalance:ColorBalance,ColorTemperatureTint:ColorTemperatureTint,Convolution:Convolution,Core:ho,DOF:DOF,DirectionalBlur:DirectionalBlur,FilmGrain:FilmGrain,Fog:Fog,GaussianBlur:GaussianBlur,Grayscale:Grayscale,HeightFog:HeightFog,HueSaturation:HueSaturation,Invert:Invert,LensDistortion:LensDistortion,OldBloom:OldBloom,PostEffectManager:PostEffectManager,RadialBlur:RadialBlur,Sharpen:Sharpen,Threshold:Threshold,Vibrance:Vibrance,Vignetting:Vignetting,ZoomBlur:ZoomBlur}),mo=Object.freeze({__proto__:null,PICKING_EVENT_TYPE:i,PickingEvent:PickingEvent,PickingManager:PickingManager,Raycaster2D:Raycaster2D,Raycaster3D:Raycaster3D}),po=Object.freeze({__proto__:null,BlendState:BlendState,DepthStencilState:DepthStencilState,PrimitiveState:PrimitiveState}),go=Object.freeze({__proto__:null,TONE_MAPPING_MODE:qi,ToneMappingManager:ToneMappingManager}),xo=Object.freeze({__proto__:null,DirectionalShadowManager:DirectionalShadowManager,ShadowManager:ShadowManager}),_o=Object.freeze({__proto__:null,AntialiasingManager:AntialiasingManager,FXAA:FXAA,TAA:TAA,TAASharpen:TAASharpen});var vo=Object.freeze({__proto__:null,PHYSICS_BODY_TYPE:{DYNAMIC:"dynamic",STATIC:"static",KINEMATIC:"kinematic",KINEMATIC_POSITION:"kinematicPosition",KINEMATIC_VELOCITY:"kinematicVelocity"},PHYSICS_SHAPE:{BOX:"box",SPHERE:"sphere",CAPSULE:"capsule",CYLINDER:"cylinder",HEIGHTFIELD:"heightfield",MESH:"mesh"}});export{_o as Antialiasing,ua as Bound,_a as Camera,ya as Color,ba as Context,dr as DefineForFragment,Er as DefineForVertex,gs as Display,GLTFLoader,_ as GPU_ADDRESS_MODE,mr as GPU_BLEND_FACTOR,pr as GPU_BLEND_OPERATION,Tn as GPU_COMPARE_FUNCTION,ei as GPU_CULL_MODE,v as GPU_FILTER_MODE,ti as GPU_FRONT_FACE,Dr as GPU_INDEX_FORMAT,H as GPU_LOAD_OP,b as GPU_MIPMAP_FILTER_MODE,Lr as GPU_PRIMITIVE_TOPOLOGY,z as GPU_STORE_OP,Geometry,_s as Light,Ts as Material,vs as Math,vo as Physics,mo as Picking,fo as PostEffect,ys as Primitive,po as RenderState,Renderer,Ns as Resource,to as RuntimeChecker,xo as Shadow,Ke as SystemCode,go as ToneMapping,x as Util,init}; \ No newline at end of file diff --git a/src/camera/controller/OrbitController.ts b/src/camera/controller/OrbitController.ts index 444aab6e2..1b158ced8 100644 --- a/src/camera/controller/OrbitController.ts +++ b/src/camera/controller/OrbitController.ts @@ -560,10 +560,8 @@ class OrbitController extends AController { if (this.#tilt > this.#maxTilt) this.#tilt = this.#maxTilt; const {camera} = this; - // 팬(Pan) 보간 - 지수적 감쇄 및 최단 경로(Shortest Path) 적용 - let panDelta = (this.#pan - this.#currentPan) % 360; - if (panDelta > 180) panDelta -= 360; - if (panDelta < -180) panDelta += 360; + // 팬(Pan) 보간 - 지수적 감쇄 + const panDelta = this.#pan - this.#currentPan; if (Math.abs(panDelta) > ROTATION_THRESHOLD) { this.#currentPan += panDelta * (1 - Math.pow(this.#rotationInterpolation, deltaTime)); From 1761b11e74de5dd9cd79dab1799df5aeedf49a23 Mon Sep 17 00:00:00 2001 From: "github-actions[bot]" Date: Tue, 10 Feb 2026 08:58:55 +0000 Subject: [PATCH 4/4] chore: update build and examples --- examples/2d/blendMode/basic/index.html | 4 +-- examples/2d/blendMode/basic/index.js | 6 ++--- examples/2d/group2D/basic/index.html | 4 +-- examples/2d/group2D/basic/index.js | 6 ++--- examples/2d/helloWorld2D/index.html | 4 +-- examples/2d/helloWorld2D/index.js | 8 +++--- .../2d/interaction/keyboardEvent/index.html | 4 +-- .../2d/interaction/keyboardEvent/index.js | 6 ++--- .../mouseEvent/sprite2D/index.html | 6 ++--- .../interaction/mouseEvent/sprite2D/index.js | 6 ++--- .../mouseEvent/spriteSheet2D/index.html | 6 ++--- .../mouseEvent/spriteSheet2D/index.js | 6 ++--- .../mouseEvent/textField2D/index.html | 6 ++--- .../mouseEvent/textField2D/index.js | 6 ++--- examples/2d/line2D/linear/index.html | 4 +-- examples/2d/line2D/linear/index.js | 4 +-- examples/2d/opacity/basic/index.html | 4 +-- examples/2d/opacity/basic/index.js | 6 ++--- examples/2d/sprite2D/basic/index.html | 4 +-- examples/2d/sprite2D/basic/index.js | 6 ++--- examples/2d/sprite2D/childMethod/index.html | 4 +-- examples/2d/sprite2D/childMethod/index.js | 6 ++--- examples/2d/sprite2D/hierarchy/index.html | 4 +-- examples/2d/sprite2D/hierarchy/index.js | 6 ++--- examples/2d/sprite2D/pivot/index.html | 4 +-- examples/2d/sprite2D/pivot/index.js | 6 ++--- examples/2d/spriteSheet2D/basic/index.html | 4 +-- examples/2d/spriteSheet2D/basic/index.js | 6 ++--- examples/2d/textField2D/basic/index.html | 4 +-- examples/2d/textField2D/basic/index.js | 6 ++--- examples/2d/tint/2dObjectTint/index.html | 4 +-- examples/2d/tint/2dObjectTint/index.js | 6 ++--- examples/2d/tint/basic/index.html | 4 +-- examples/2d/tint/basic/index.js | 6 ++--- examples/2d/view/multiView/index.html | 4 +-- examples/2d/view/multiView/index.js | 6 ++--- examples/2d/view/multiViewWith3D/index.html | 4 +-- examples/2d/view/multiViewWith3D/index.js | 6 ++--- .../3d/controller/followController/index.html | 4 +-- .../3d/controller/followController/index.js | 6 ++--- .../3d/controller/freeController/index.html | 4 +-- .../3d/controller/freeController/index.js | 6 ++--- .../controller/isometricController/index.html | 4 +-- .../controller/isometricController/index.js | 6 ++--- .../3d/controller/orbitController/index.html | 4 +-- .../3d/controller/orbitController/index.js | 6 ++--- .../screenToWorld/index.html | 4 +-- .../screenToWorld/index.js | 4 +-- .../worldToLocal/index.html | 4 +-- .../worldToLocal/index.js | 4 +-- examples/3d/drawDebugger/basic/index.html | 4 +-- examples/3d/drawDebugger/basic/index.js | 6 ++--- .../frustumCulling/distanceCulling/index.html | 4 +-- .../frustumCulling/distanceCulling/index.js | 6 ++--- .../frustumCulling/frustumCulling/index.html | 4 +-- .../3d/frustumCulling/frustumCulling/index.js | 6 ++--- examples/3d/group3D/basic/index.html | 4 +-- examples/3d/group3D/basic/index.js | 6 ++--- examples/3d/helloWorld/index.html | 4 +-- examples/3d/helloWorld/index.js | 6 ++--- examples/3d/indirectDrawTest/index.html | 4 +-- examples/3d/indirectDrawTest/index.js | 6 ++--- examples/3d/instancedMesh/simple/index.html | 4 +-- examples/3d/instancedMesh/simple/index.js | 6 ++--- examples/3d/instancedMesh/sphere/index.html | 4 +-- examples/3d/instancedMesh/sphere/index.js | 6 ++--- .../3d/interaction/keyboardEvent/index.html | 4 +-- .../3d/interaction/keyboardEvent/index.js | 6 ++--- .../3d/interaction/mouseEvent/mesh/index.html | 6 ++--- .../3d/interaction/mouseEvent/mesh/index.js | 4 +-- .../mouseEvent/raycasting/index.html | 6 ++--- .../mouseEvent/raycasting/index.js | 6 ++--- .../mouseEvent/sprite3D/index.html | 6 ++--- .../interaction/mouseEvent/sprite3D/index.js | 6 ++--- .../mouseEvent/spriteSheet3D/index.html | 6 ++--- .../mouseEvent/spriteSheet3D/index.js | 6 ++--- .../mouseEvent/textField3D/index.html | 6 ++--- .../mouseEvent/textField3D/index.js | 6 ++--- examples/3d/light/directionalLight/index.html | 4 +-- examples/3d/light/directionalLight/index.js | 6 ++--- examples/3d/light/pointLight/index.html | 4 +-- examples/3d/light/pointLight/index.js | 6 ++--- .../3d/light/pointLightPerformance/index.html | 4 +-- .../3d/light/pointLightPerformance/index.js | 4 +-- examples/3d/light/spotLight/index.html | 4 +-- examples/3d/light/spotLight/index.js | 6 ++--- .../3d/light/spotLightPerformance/index.html | 4 +-- .../3d/light/spotLightPerformance/index.js | 4 +-- examples/3d/line3D/bezier/index.html | 4 +-- examples/3d/line3D/bezier/index.js | 6 ++--- examples/3d/line3D/catmullRom/index.html | 4 +-- examples/3d/line3D/catmullRom/index.js | 6 ++--- examples/3d/line3D/linear/index.html | 4 +-- examples/3d/line3D/linear/index.js | 6 ++--- examples/3d/lod/InstanceMeshGPULOD/index.html | 4 +-- examples/3d/lod/InstanceMeshGPULOD/index.js | 6 ++--- .../InstanceMeshGPULOD_material/index.html | 4 +-- .../lod/InstanceMeshGPULOD_material/index.js | 6 ++--- examples/3d/lod/MeshCPULOD/index.html | 4 +-- examples/3d/lod/MeshCPULOD/index.js | 6 ++--- .../3d/lod/MeshCPULOD_material/index.html | 4 +-- examples/3d/lod/MeshCPULOD_material/index.js | 6 ++--- .../3d/material/bitmapMaterial/index.html | 4 +-- examples/3d/material/bitmapMaterial/index.js | 6 ++--- examples/3d/material/colorMaterial/index.html | 4 +-- examples/3d/material/colorMaterial/index.js | 6 ++--- .../material/fragmentVariantTest/index.html | 4 +-- .../3d/material/fragmentVariantTest/index.js | 6 ++--- examples/3d/material/opacity/index.html | 4 +-- examples/3d/material/opacity/index.js | 6 ++--- examples/3d/material/phongMaterial/index.html | 4 +-- examples/3d/material/phongMaterial/index.js | 6 ++--- .../material/phongMaterialTextures/index.html | 4 +-- .../material/phongMaterialTextures/index.js | 4 +-- examples/3d/material/uvTransform/index.html | 4 +-- examples/3d/material/uvTransform/index.js | 6 ++--- examples/3d/mesh/basicMesh/index.html | 4 +-- examples/3d/mesh/basicMesh/index.js | 6 ++--- .../boundBox/meshAABBIntersects/index.html | 4 +-- .../mesh/boundBox/meshAABBIntersects/index.js | 4 +-- .../3d/mesh/boundBox/meshBoundBox/index.html | 4 +-- .../3d/mesh/boundBox/meshBoundBox/index.js | 4 +-- .../boundBox/meshOBBIntersects/index.html | 4 +-- .../mesh/boundBox/meshOBBIntersects/index.js | 4 +-- examples/3d/mesh/childMethod/index.html | 4 +-- examples/3d/mesh/childMethod/index.js | 6 ++--- examples/3d/mesh/hierarchy/index.html | 4 +-- examples/3d/mesh/hierarchy/index.js | 6 ++--- examples/3d/mesh/lookAt/index.html | 4 +-- examples/3d/mesh/lookAt/index.js | 4 +-- examples/3d/mesh/pivot/index.html | 4 +-- examples/3d/mesh/pivot/index.js | 6 ++--- .../3d/noiseTexture/simplex/basic/index.html | 4 +-- .../3d/noiseTexture/simplex/basic/index.js | 6 ++--- .../simplex/displacement/index.html | 4 +-- .../simplex/displacement/index.js | 6 ++--- .../3d/noiseTexture/simplex/fire/index.html | 4 +-- .../3d/noiseTexture/simplex/fire/index.js | 6 ++--- .../3d/noiseTexture/voronoi/basic/index.html | 4 +-- .../3d/noiseTexture/voronoi/basic/index.js | 6 ++--- examples/3d/particle/basic/index.html | 4 +-- examples/3d/particle/basic/index.js | 8 +++--- examples/3d/particle/performance/index.html | 4 +-- examples/3d/particle/performance/index.js | 4 +-- examples/3d/primitive/box/index.html | 4 +-- examples/3d/primitive/box/index.js | 6 ++--- examples/3d/primitive/capsule/index.html | 4 +-- examples/3d/primitive/capsule/index.js | 6 ++--- examples/3d/primitive/circle/index.html | 4 +-- examples/3d/primitive/circle/index.js | 6 ++--- examples/3d/primitive/cylinder/index.html | 4 +-- examples/3d/primitive/cylinder/index.js | 6 ++--- examples/3d/primitive/ground/index.html | 4 +-- examples/3d/primitive/ground/index.js | 6 ++--- examples/3d/primitive/plane/index.html | 4 +-- examples/3d/primitive/plane/index.js | 6 ++--- examples/3d/primitive/primitives/index.html | 4 +-- examples/3d/primitive/primitives/index.js | 4 +-- examples/3d/primitive/sphere/index.html | 4 +-- examples/3d/primitive/sphere/index.js | 6 ++--- examples/3d/primitive/torus/index.html | 4 +-- examples/3d/primitive/torus/index.js | 6 ++--- examples/3d/primitive/torusNut/index.html | 4 +-- examples/3d/primitive/torusNut/index.js | 6 ++--- examples/3d/scene/index.html | 4 +-- examples/3d/scene/index.js | 6 ++--- .../3d/shadow/directionalShadow/index.html | 4 +-- examples/3d/shadow/directionalShadow/index.js | 6 ++--- .../shadow/gltfDirectionalShadow/index.html | 4 +-- .../3d/shadow/gltfDirectionalShadow/index.js | 8 +++--- examples/3d/skybox/ibl/brdfLutTest/index.html | 4 +-- examples/3d/skybox/ibl/brdfLutTest/index.js | 2 +- examples/3d/skybox/ibl/iblTest/index.html | 4 +-- examples/3d/skybox/ibl/iblTest/index.js | 6 ++--- .../3d/skybox/ibl/iblTextureSize/index.html | 4 +-- .../3d/skybox/ibl/iblTextureSize/index.js | 8 +++--- .../3d/skybox/ibl/irradianceTest/index.html | 4 +-- .../3d/skybox/ibl/irradianceTest/index.js | 4 +-- .../3d/skybox/ibl/skyboxWithIbl/index.html | 4 +-- examples/3d/skybox/ibl/skyboxWithIbl/index.js | 6 ++--- examples/3d/skybox/skybox/index.html | 4 +-- examples/3d/skybox/skybox/index.js | 6 ++--- .../transition/skyboxTransition/index.html | 4 +-- .../transition/skyboxTransition/index.js | 6 ++--- .../index.html | 4 +-- .../skyboxTransitionWithNoiseTexture/index.js | 6 ++--- examples/3d/sprite/sprite3D/index.html | 4 +-- examples/3d/sprite/sprite3D/index.js | 6 ++--- examples/3d/sprite/sprite3DCompare/index.html | 4 +-- examples/3d/sprite/sprite3DCompare/index.js | 6 ++--- examples/3d/sprite/spriteSheet3D/index.html | 4 +-- examples/3d/sprite/spriteSheet3D/index.js | 6 ++--- .../3d/sprite/spriteSheet3DCompare/index.html | 4 +-- .../3d/sprite/spriteSheet3DCompare/index.js | 6 ++--- examples/3d/textField/textField3D/index.html | 4 +-- examples/3d/textField/textField3D/index.js | 6 ++--- .../textField/textField3DCompare/index.html | 4 +-- .../3d/textField/textField3DCompare/index.js | 6 ++--- .../texture/bitmapTextureSampler/index.html | 4 +-- .../3d/texture/bitmapTextureSampler/index.js | 6 ++--- examples/3d/texture/maxAnisotropy/index.html | 4 +-- examples/3d/texture/maxAnisotropy/index.js | 4 +-- .../3d/texture/samplerAddressMode/index.html | 4 +-- .../3d/texture/samplerAddressMode/index.js | 4 +-- .../3d/texture/samplerCombination/index.html | 4 +-- .../3d/texture/samplerCombination/index.js | 4 +-- examples/3d/tint/basic/index.html | 4 +-- examples/3d/tint/basic/index.js | 6 ++--- examples/3d/transparentSort/index.html | 4 +-- examples/3d/transparentSort/index.js | 6 ++--- examples/3d/view/multiView/index.html | 4 +-- examples/3d/view/multiView/index.js | 6 ++--- examples/3d/view/singleView/index.html | 4 +-- examples/3d/view/singleView/index.js | 6 ++--- .../createExample/loadExampleInfo/index.js | 6 ++--- .../createExample/panes/createIblHelper.js | 4 +-- .../createExample/panes/index.js | 26 +++++++++---------- .../panes/scene/setSceneListTest.js | 2 +- .../panes/view/setSingleViewTest.js | 2 +- .../panes/view/setViewListTest.js | 2 +- .../exampleList/createExampleList.js | 2 +- examples/exampleHelper/indexSample.html | 2 +- .../gltf/animation/basicAnimations/index.html | 4 +-- .../gltf/animation/basicAnimations/index.js | 8 +++--- examples/gltf/animation/brainStem/index.html | 4 +-- examples/gltf/animation/brainStem/index.js | 6 ++--- examples/gltf/animation/cesiumMan/index.html | 4 +-- examples/gltf/animation/cesiumMan/index.js | 8 +++--- .../animation/interpolationTest/index.html | 4 +-- .../gltf/animation/interpolationTest/index.js | 6 ++--- .../gltf/animation/morphStressTest/index.html | 4 +-- .../gltf/animation/morphStressTest/index.js | 6 ++--- .../performance/highMorphTarget/index.html | 4 +-- .../performance/highMorphTarget/index.js | 8 +++--- .../highVertexLoadSkinning/index.html | 4 +-- .../highVertexLoadSkinning/index.js | 8 +++--- .../performance/mediumLoadSkinning/index.html | 4 +-- .../performance/mediumLoadSkinning/index.js | 8 +++--- .../animation/recursiveSkeletons/index.html | 4 +-- .../animation/recursiveSkeletons/index.js | 6 ++--- .../gltf/animation/riggedFigure/index.html | 4 +-- examples/gltf/animation/riggedFigure/index.js | 6 ++--- .../gltf/animation/riggedSimple/index.html | 4 +-- examples/gltf/animation/riggedSimple/index.js | 6 ++--- .../gltf/animation/simpleMorph/index.html | 4 +-- examples/gltf/animation/simpleMorph/index.js | 6 ++--- examples/gltf/animation/simpleSkin/index.html | 4 +-- examples/gltf/animation/simpleSkin/index.js | 6 ++--- .../gltf/basic/alphaBlendModeTest/index.html | 4 +-- .../gltf/basic/alphaBlendModeTest/index.js | 8 +++--- .../gltf/basic/boxVertexColors/index.html | 4 +-- examples/gltf/basic/boxVertexColors/index.js | 8 +++--- .../basic/compareAlphaCoverage/index.html | 4 +-- .../gltf/basic/compareAlphaCoverage/index.js | 8 +++--- .../basic/compareAmbientOcclusion/index.html | 4 +-- .../basic/compareAmbientOcclusion/index.js | 8 +++--- .../gltf/basic/compareBaseColor/index.html | 4 +-- examples/gltf/basic/compareBaseColor/index.js | 8 +++--- .../gltf/basic/compareMetallic/index.html | 4 +-- examples/gltf/basic/compareMetallic/index.js | 8 +++--- examples/gltf/basic/compareNormal/index.html | 4 +-- examples/gltf/basic/compareNormal/index.js | 8 +++--- .../gltf/basic/compareRoughness/index.html | 4 +-- examples/gltf/basic/compareRoughness/index.js | 8 +++--- .../gltf/basic/environmentTest/index.html | 4 +-- examples/gltf/basic/environmentTest/index.js | 8 +++--- .../gltf/basic/generateNormalTest/index.html | 4 +-- .../gltf/basic/generateNormalTest/index.js | 8 +++--- .../gltf/basic/metalRoughSpheres/index.html | 4 +-- .../gltf/basic/metalRoughSpheres/index.js | 8 +++--- .../metalRoughSpheresNoTextures/index.html | 4 +-- .../metalRoughSpheresNoTextures/index.js | 8 +++--- examples/gltf/basic/multiUVTest/index.html | 4 +-- examples/gltf/basic/multiUVTest/index.js | 8 +++--- .../gltf/basic/negativeScaleTest/index.html | 4 +-- .../gltf/basic/negativeScaleTest/index.js | 8 +++--- .../basic/normalTangentMirrorTest/index.html | 4 +-- .../basic/normalTangentMirrorTest/index.js | 8 +++--- .../gltf/basic/normalTangentTest/index.html | 4 +-- .../gltf/basic/normalTangentTest/index.js | 8 +++--- .../gltf/basic/orientationTest/index.html | 4 +-- examples/gltf/basic/orientationTest/index.js | 8 +++--- .../basic/textureCoordinateTest/index.html | 4 +-- .../gltf/basic/textureCoordinateTest/index.js | 8 +++--- .../gltf/basic/textureEncodingTest/index.html | 4 +-- .../gltf/basic/textureEncodingTest/index.js | 8 +++--- .../textureLinearInterpolationTest/index.html | 4 +-- .../textureLinearInterpolationTest/index.js | 8 +++--- .../gltf/basic/textureSettingsTest/index.html | 4 +-- .../gltf/basic/textureSettingsTest/index.js | 8 +++--- .../gltf/basic/vertexColorTest/index.html | 4 +-- examples/gltf/basic/vertexColorTest/index.js | 8 +++--- examples/gltf/basic/waterBottle/index.html | 4 +-- examples/gltf/basic/waterBottle/index.js | 8 +++--- .../anisotropy/anisotropyBarnLamp/index.html | 4 +-- .../anisotropy/anisotropyBarnLamp/index.js | 8 +++--- .../anisotropy/anisotropyDiscTest/index.html | 4 +-- .../anisotropy/anisotropyDiscTest/index.js | 6 ++--- .../anisotropyRotationTest/index.html | 4 +-- .../anisotropyRotationTest/index.js | 6 ++--- .../anisotropyStrengthTest/index.html | 4 +-- .../anisotropyStrengthTest/index.js | 6 ++--- .../anisotropy/compareAnisotropy/index.html | 4 +-- .../anisotropy/compareAnisotropy/index.js | 8 +++--- .../clearcoat/clearCoatCarPaint/index.html | 4 +-- .../clearcoat/clearCoatCarPaint/index.js | 6 ++--- .../clearcoat/clearCoatTest/index.html | 4 +-- .../clearcoat/clearCoatTest/index.js | 6 ++--- .../clearcoat/clearcoatWicker/index.html | 4 +-- .../clearcoat/clearcoatWicker/index.js | 8 +++--- .../clearcoat/compareClearcoat/index.html | 4 +-- .../clearcoat/compareClearcoat/index.js | 6 ++--- .../diffuseTransmissionTeacup/index.html | 4 +-- .../diffuseTransmissionTeacup/index.js | 8 +++--- .../diffuseTransmissionTest/index.html | 4 +-- .../diffuseTransmissionTest/index.js | 6 ++--- .../dispersion/compareDispersion/index.html | 4 +-- .../dispersion/compareDispersion/index.js | 6 ++--- .../dispersion/dispersionTest/index.html | 4 +-- .../dispersion/dispersionTest/index.js | 8 +++--- .../dispersion/dragonDispersion/index.html | 4 +-- .../dispersion/dragonDispersion/index.js | 8 +++--- .../compareEmissiveStrength/index.html | 4 +-- .../compareEmissiveStrength/index.js | 6 ++--- .../emissiveStrengthTest/index.html | 4 +-- .../emissiveStrengthTest/index.js | 6 ++--- .../iridescence/compareIridescence/index.html | 4 +-- .../iridescence/compareIridescence/index.js | 6 ++--- .../iridescenceDielectricSpheres/index.html | 4 +-- .../iridescenceDielectricSpheres/index.js | 6 ++--- .../iridescence/iridescenceLamp/index.html | 4 +-- .../iridescence/iridescenceLamp/index.js | 8 +++--- .../iridescenceMetallicSpheres/index.html | 4 +-- .../iridescenceMetallicSpheres/index.js | 6 ++--- .../iridescence/iridescenceSuzanne/index.html | 4 +-- .../iridescence/iridescenceSuzanne/index.js | 6 ++--- .../iridescentDishWithOlives/index.html | 4 +-- .../iridescentDishWithOlives/index.js | 8 +++--- .../iridescence/sunglassesKhronos/index.html | 4 +-- .../iridescence/sunglassesKhronos/index.js | 6 ++--- .../sheen/chairDamaskPurplegold/index.html | 4 +-- .../sheen/chairDamaskPurplegold/index.js | 8 +++--- .../sheen/compareSheen/index.html | 4 +-- .../sheen/compareSheen/index.js | 6 ++--- .../sheen/glamVelvetSofa/index.html | 4 +-- .../sheen/glamVelvetSofa/index.js | 8 +++--- .../sheen/sheenChair/index.html | 4 +-- .../gltfExtensions/sheen/sheenChair/index.js | 8 +++--- .../sheen/sheenCloth/index.html | 4 +-- .../gltfExtensions/sheen/sheenCloth/index.js | 8 +++--- .../sheen/sheenTestGrid/index.html | 4 +-- .../sheen/sheenTestGrid/index.js | 8 +++--- .../sheen/sheenWoodLeatherSofa/index.html | 4 +-- .../sheen/sheenWoodLeatherSofa/index.js | 8 +++--- .../specular/compareSpecular/index.html | 4 +-- .../specular/compareSpecular/index.js | 8 +++--- .../specular/specularSilkPouf/index.html | 4 +-- .../specular/specularSilkPouf/index.js | 8 +++--- .../specular/specularTest/index.html | 4 +-- .../specular/specularTest/index.js | 6 ++--- .../textureTransformMultiTest/index.html | 4 +-- .../textureTransformMultiTest/index.js | 6 ++--- .../textureTransformTest/index.html | 4 +-- .../textureTransformTest/index.js | 6 ++--- .../transmission/chronographWatch/index.html | 4 +-- .../transmission/chronographWatch/index.js | 8 +++--- .../commercialRefrigerator/index.html | 4 +-- .../commercialRefrigerator/index.js | 8 +++--- .../compareTransmission/index.html | 4 +-- .../transmission/compareTransmission/index.js | 6 ++--- .../transmission/mosquitoInAmber/index.html | 4 +-- .../transmission/mosquitoInAmber/index.js | 8 +++--- .../transmission/stainedGlassLamp/index.html | 4 +-- .../transmission/stainedGlassLamp/index.js | 6 ++--- .../transmissionRoughnessTest/index.html | 4 +-- .../transmissionRoughnessTest/index.js | 6 ++--- .../transmission/transmissionTest/index.html | 4 +-- .../transmission/transmissionTest/index.js | 8 +++--- .../gltfExtensions/unlit/unlitTest/index.html | 4 +-- .../gltfExtensions/unlit/unlitTest/index.js | 6 ++--- .../volume/IORTestGrid/index.html | 4 +-- .../volume/IORTestGrid/index.js | 8 +++--- .../volume/attenuationTest/index.html | 4 +-- .../volume/attenuationTest/index.js | 6 ++--- .../volume/compareIor/index.html | 4 +-- .../gltfExtensions/volume/compareIor/index.js | 6 ++--- .../volume/compareVolume/index.html | 4 +-- .../volume/compareVolume/index.js | 6 ++--- .../volume/dragonAttenuation/index.html | 4 +-- .../volume/dragonAttenuation/index.js | 8 +++--- .../volume/glassBrokenWindow/index.html | 4 +-- .../volume/glassBrokenWindow/index.js | 8 +++--- .../glassHurricaneCandleHolder/index.html | 4 +-- .../glassHurricaneCandleHolder/index.js | 8 +++--- .../volume/glassVaseFlowers/index.html | 4 +-- .../volume/glassVaseFlowers/index.js | 8 +++--- .../transmissionThinwallTestGrid/index.html | 4 +-- .../transmissionThinwallTestGrid/index.js | 8 +++--- .../gltf/models/aBeautifulGame/index.html | 4 +-- examples/gltf/models/aBeautifulGame/index.js | 8 +++--- examples/gltf/models/corset/index.html | 4 +-- examples/gltf/models/corset/index.js | 8 +++--- examples/gltf/models/helmets/index.html | 4 +-- examples/gltf/models/helmets/index.js | 8 +++--- examples/gltf/models/sponza/index.html | 4 +-- examples/gltf/models/sponza/index.js | 8 +++--- .../gltf/models/texcooredNTest/index.html | 4 +-- examples/gltf/models/texcooredNTest/index.js | 8 +++--- examples/gltf/models/tokyo/index.html | 4 +-- examples/gltf/models/tokyo/index.js | 8 +++--- examples/index.html | 4 +-- examples/index.js | 2 +- .../advancedCharacterController/index.html | 4 +-- .../advancedCharacterController/index.js | 8 +++--- examples/physics/basic/index.html | 4 +-- examples/physics/basic/index.js | 8 +++--- examples/physics/bowling/index.html | 4 +-- examples/physics/bowling/index.js | 8 +++--- examples/physics/buoyancy/index.html | 4 +-- examples/physics/buoyancy/index.js | 8 +++--- .../physics/characterController/index.html | 4 +-- examples/physics/characterController/index.js | 8 +++--- examples/physics/collisionEvents/index.html | 4 +-- examples/physics/collisionEvents/index.js | 8 +++--- .../physics/collisionFiltering/index.html | 4 +-- examples/physics/collisionFiltering/index.js | 8 +++--- examples/physics/compound/index.html | 4 +-- examples/physics/compound/index.js | 8 +++--- examples/physics/explosion/index.html | 4 +-- examples/physics/explosion/index.js | 8 +++--- examples/physics/galton/index.html | 4 +-- examples/physics/galton/index.js | 8 +++--- examples/physics/gltfPhysics/index.html | 4 +-- examples/physics/gltfPhysics/index.js | 8 +++--- examples/physics/heightField/index.html | 4 +-- examples/physics/heightField/index.js | 8 +++--- examples/physics/joints/index.html | 4 +-- examples/physics/joints/index.js | 8 +++--- examples/physics/kinematic/index.html | 4 +-- examples/physics/kinematic/index.js | 8 +++--- examples/physics/meshCollider/index.html | 4 +-- examples/physics/meshCollider/index.js | 8 +++--- examples/physics/prismaticJoint/index.html | 4 +-- examples/physics/prismaticJoint/index.js | 8 +++--- examples/physics/ragdoll/index.html | 4 +-- examples/physics/ragdoll/index.js | 8 +++--- examples/physics/raycast/index.html | 4 +-- examples/physics/raycast/index.js | 8 +++--- examples/physics/revoluteJoint/index.html | 4 +-- examples/physics/revoluteJoint/index.js | 8 +++--- examples/physics/shapes/index.html | 4 +-- examples/physics/shapes/index.js | 8 +++--- examples/physics/softBody/index.html | 4 +-- examples/physics/softBody/index.js | 8 +++--- examples/physics/springJoint/index.html | 4 +-- examples/physics/springJoint/index.js | 6 ++--- examples/physics/stressTest/index.html | 4 +-- examples/physics/stressTest/index.js | 8 +++--- examples/physics/surfaceVelocity/index.html | 4 +-- examples/physics/surfaceVelocity/index.js | 8 +++--- examples/physics/triggers/index.html | 4 +-- examples/physics/triggers/index.js | 8 +++--- .../adjustments/brightnessContrast/index.html | 4 +-- .../adjustments/brightnessContrast/index.js | 8 +++--- .../adjustments/colorBalance/index.html | 4 +-- .../adjustments/colorBalance/index.js | 8 +++--- .../colorTemperatureTint/index.html | 4 +-- .../adjustments/colorTemperatureTint/index.js | 8 +++--- .../adjustments/grayscale/index.html | 4 +-- .../postEffect/adjustments/grayscale/index.js | 8 +++--- .../adjustments/hueSaturation/index.html | 4 +-- .../adjustments/hueSaturation/index.js | 8 +++--- .../postEffect/adjustments/invert/index.html | 4 +-- .../postEffect/adjustments/invert/index.js | 8 +++--- .../adjustments/threshold/index.html | 4 +-- .../postEffect/adjustments/threshold/index.js | 8 +++--- .../adjustments/vibrance/index.html | 4 +-- .../postEffect/adjustments/vibrance/index.js | 8 +++--- examples/postEffect/blur/blur/index.html | 4 +-- examples/postEffect/blur/blur/index.js | 8 +++--- examples/postEffect/blur/blurX/index.html | 4 +-- examples/postEffect/blur/blurX/index.js | 8 +++--- examples/postEffect/blur/blurY/index.html | 4 +-- examples/postEffect/blur/blurY/index.js | 8 +++--- .../blur/directionalBlur/index.html | 4 +-- .../postEffect/blur/directionalBlur/index.js | 8 +++--- .../postEffect/blur/gaussianBlur/index.html | 4 +-- .../postEffect/blur/gaussianBlur/index.js | 8 +++--- .../postEffect/blur/radialBlur/index.html | 4 +-- examples/postEffect/blur/radialBlur/index.js | 8 +++--- examples/postEffect/blur/zoomBlur/index.html | 4 +-- examples/postEffect/blur/zoomBlur/index.js | 8 +++--- examples/postEffect/convolution/index.html | 4 +-- examples/postEffect/convolution/index.js | 8 +++--- examples/postEffect/filmGrain/index.html | 4 +-- examples/postEffect/filmGrain/index.js | 8 +++--- examples/postEffect/fog/fog/index.html | 4 +-- examples/postEffect/fog/fog/index.js | 6 ++--- examples/postEffect/fog/heightFog/index.html | 4 +-- examples/postEffect/fog/heightFog/index.js | 6 ++--- .../lens/chromaticAberration/index.html | 4 +-- .../lens/chromaticAberration/index.js | 8 +++--- examples/postEffect/lens/dof/index.html | 4 +-- examples/postEffect/lens/dof/index.js | 8 +++--- .../postEffect/lens/lensDistortion/index.html | 4 +-- .../postEffect/lens/lensDistortion/index.js | 8 +++--- .../postEffect/lens/vignetting/index.html | 4 +-- examples/postEffect/lens/vignetting/index.js | 8 +++--- examples/postEffect/oldBloom/index.html | 4 +-- examples/postEffect/oldBloom/index.js | 8 +++--- examples/postEffect/sharpen/index.html | 4 +-- examples/postEffect/sharpen/index.js | 8 +++--- examples/postEffect/ssao/index.html | 4 +-- examples/postEffect/ssao/index.js | 6 ++--- examples/postEffect/ssr/index.html | 4 +-- examples/postEffect/ssr/index.js | 6 ++--- 516 files changed, 1391 insertions(+), 1391 deletions(-) diff --git a/examples/2d/blendMode/basic/index.html b/examples/2d/blendMode/basic/index.html index 77d781697..91601ab7d 100644 --- a/examples/2d/blendMode/basic/index.html +++ b/examples/2d/blendMode/basic/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/2d/blendMode/basic/index.js b/examples/2d/blendMode/basic/index.js index 9bac8fe1b..aab473b6c 100644 --- a/examples/2d/blendMode/basic/index.js +++ b/examples/2d/blendMode/basic/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; /** * [KO] Blend Mode 예제 @@ -208,11 +208,11 @@ function createSourceView(redGPUContext, scene, texture_blendTest_base, texture_ * @param {RedGPU.Display.Sprite2D} shape */ const renderTestPane = async (redGPUContext, base, shape) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { setRedGPUTest_pane, setDebugButtons - } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); setRedGPUTest_pane(pane, redGPUContext, false); diff --git a/examples/2d/group2D/basic/index.html b/examples/2d/group2D/basic/index.html index 77d781697..91601ab7d 100644 --- a/examples/2d/group2D/basic/index.html +++ b/examples/2d/group2D/basic/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/2d/group2D/basic/index.js b/examples/2d/group2D/basic/index.js index a41230328..3c7da33cd 100644 --- a/examples/2d/group2D/basic/index.js +++ b/examples/2d/group2D/basic/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; /** * [KO] Group2D 예제 @@ -116,9 +116,9 @@ const createChildSprite2D = (redGPUContext, parent) => { * @param {RedGPU.Display.Sprite2D} child */ const renderTestPane = async (redGPUContext, rootGroup, parent, child) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const pane = new Pane(); - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext); const maxW = redGPUContext.screenRectObject.width; const maxH = redGPUContext.screenRectObject.height; diff --git a/examples/2d/helloWorld2D/index.html b/examples/2d/helloWorld2D/index.html index b3924120d..a61628df1 100644 --- a/examples/2d/helloWorld2D/index.html +++ b/examples/2d/helloWorld2D/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/2d/helloWorld2D/index.js b/examples/2d/helloWorld2D/index.js index d992e4e9e..306a9dd83 100644 --- a/examples/2d/helloWorld2D/index.js +++ b/examples/2d/helloWorld2D/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../dist/index.js?t=1770713934910"; /** * [KO] Hello World 2D 예제 @@ -100,9 +100,9 @@ RedGPU.init( * @param {RedGPU.RedGPUContext} redGPUContext */ const renderTestPane = async (redGPUContext) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); - const {setRedGPUTest_pane} = await import("../../exampleHelper/createExample/panes/index.js?t=1770699661827"); - const {setDebugButtons} = await import('../../exampleHelper/createExample/panes/index.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); + const {setRedGPUTest_pane} = await import("../../exampleHelper/createExample/panes/index.js?t=1770713934910"); + const {setDebugButtons} = await import('../../exampleHelper/createExample/panes/index.js?t=1770713934910'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); setRedGPUTest_pane(pane, redGPUContext, true); diff --git a/examples/2d/interaction/keyboardEvent/index.html b/examples/2d/interaction/keyboardEvent/index.html index 6ca35a7e3..52b20dce5 100644 --- a/examples/2d/interaction/keyboardEvent/index.html +++ b/examples/2d/interaction/keyboardEvent/index.html @@ -7,8 +7,8 @@ - - + + diff --git a/examples/2d/interaction/keyboardEvent/index.js b/examples/2d/interaction/keyboardEvent/index.js index 2ba1d7e87..daf9499ed 100644 --- a/examples/2d/interaction/keyboardEvent/index.js +++ b/examples/2d/interaction/keyboardEvent/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -76,8 +76,8 @@ RedGPU.init( ); const renderTestPane = async (redGPUContext, keyboardKeyBuffer) => { - const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); - const { setDebugButtons } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); + const { setDebugButtons } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext) const pane = new Pane(); pane.addBlade({ diff --git a/examples/2d/interaction/mouseEvent/sprite2D/index.html b/examples/2d/interaction/mouseEvent/sprite2D/index.html index fa98ba6d3..9e5335be6 100644 --- a/examples/2d/interaction/mouseEvent/sprite2D/index.html +++ b/examples/2d/interaction/mouseEvent/sprite2D/index.html @@ -8,9 +8,9 @@ - - - + + + diff --git a/examples/2d/interaction/mouseEvent/sprite2D/index.js b/examples/2d/interaction/mouseEvent/sprite2D/index.js index 4cb3093da..4ac8e3e01 100644 --- a/examples/2d/interaction/mouseEvent/sprite2D/index.js +++ b/examples/2d/interaction/mouseEvent/sprite2D/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../../dist/index.js?t=1770713934910"; /** * [KO] Sprite2D Mouse Event 예제 @@ -145,7 +145,7 @@ const createSampleSprite2D = async (redGPUContext, scene, updateInfo) => { * @param {RedGPU.RedGPUContext} redGPUContext */ const renderTestPane = async (redGPUContext) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); - const {setDebugButtons} = await import("../../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); + const {setDebugButtons} = await import("../../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext); }; \ No newline at end of file diff --git a/examples/2d/interaction/mouseEvent/spriteSheet2D/index.html b/examples/2d/interaction/mouseEvent/spriteSheet2D/index.html index fa98ba6d3..9e5335be6 100644 --- a/examples/2d/interaction/mouseEvent/spriteSheet2D/index.html +++ b/examples/2d/interaction/mouseEvent/spriteSheet2D/index.html @@ -8,9 +8,9 @@ - - - + + + diff --git a/examples/2d/interaction/mouseEvent/spriteSheet2D/index.js b/examples/2d/interaction/mouseEvent/spriteSheet2D/index.js index 3e6620184..7e2067fad 100644 --- a/examples/2d/interaction/mouseEvent/spriteSheet2D/index.js +++ b/examples/2d/interaction/mouseEvent/spriteSheet2D/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../../dist/index.js?t=1770713934910"; /** * [KO] SpriteSheet2D Mouse Event 예제 @@ -143,7 +143,7 @@ const createSampleSprite2D = async (redGPUContext, scene, updateInfo) => { * @param {RedGPU.RedGPUContext} redGPUContext */ const renderTestPane = async (redGPUContext) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); - const {setDebugButtons} = await import("../../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); + const {setDebugButtons} = await import("../../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext); }; \ No newline at end of file diff --git a/examples/2d/interaction/mouseEvent/textField2D/index.html b/examples/2d/interaction/mouseEvent/textField2D/index.html index fa98ba6d3..9e5335be6 100644 --- a/examples/2d/interaction/mouseEvent/textField2D/index.html +++ b/examples/2d/interaction/mouseEvent/textField2D/index.html @@ -8,9 +8,9 @@ - - - + + + diff --git a/examples/2d/interaction/mouseEvent/textField2D/index.js b/examples/2d/interaction/mouseEvent/textField2D/index.js index 87c8a514c..7d9df1fa7 100644 --- a/examples/2d/interaction/mouseEvent/textField2D/index.js +++ b/examples/2d/interaction/mouseEvent/textField2D/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../../dist/index.js?t=1770713934910"; /** * [KO] TextField2D Mouse Event 예제 @@ -150,7 +150,7 @@ function getRandomHexValue() { * @param {RedGPU.RedGPUContext} redGPUContext */ const renderTestPane = async (redGPUContext) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); - const {setDebugButtons} = await import("../../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); + const {setDebugButtons} = await import("../../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext); }; \ No newline at end of file diff --git a/examples/2d/line2D/linear/index.html b/examples/2d/line2D/linear/index.html index 77d781697..91601ab7d 100644 --- a/examples/2d/line2D/linear/index.html +++ b/examples/2d/line2D/linear/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/2d/line2D/linear/index.js b/examples/2d/line2D/linear/index.js index 3f1690a62..02db06806 100644 --- a/examples/2d/line2D/linear/index.js +++ b/examples/2d/line2D/linear/index.js @@ -1,5 +1,5 @@ // RedGPU 사용을 위한 모듈 임포트 -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; /** * [KO] Line2D (Linear) 예제 @@ -130,7 +130,7 @@ function getRainbowColor(t) { /* 6. 디버그 UI 패널 */ async function setupDebugPanel(redGPUContext, groups, updateLinesCallback, getPointsPerLine, setPointsPerLine) { - const {Pane} = await import("https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827"); + const {Pane} = await import("https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910"); const pane = new Pane(); const debugOptions = { diff --git a/examples/2d/opacity/basic/index.html b/examples/2d/opacity/basic/index.html index 77d781697..91601ab7d 100644 --- a/examples/2d/opacity/basic/index.html +++ b/examples/2d/opacity/basic/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/2d/opacity/basic/index.js b/examples/2d/opacity/basic/index.js index 9e5e7d843..4cfa85693 100644 --- a/examples/2d/opacity/basic/index.js +++ b/examples/2d/opacity/basic/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; /** * [KO] Opacity 예제 @@ -148,9 +148,9 @@ const createChildTextField2D = (redGPUContext, parent) => { * @param {Array} children */ const renderTestPane = async (redGPUContext, parent, children) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const pane = new Pane(); - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext); const maxW = redGPUContext.screenRectObject.width; const maxH = redGPUContext.screenRectObject.height; diff --git a/examples/2d/sprite2D/basic/index.html b/examples/2d/sprite2D/basic/index.html index 77d781697..91601ab7d 100644 --- a/examples/2d/sprite2D/basic/index.html +++ b/examples/2d/sprite2D/basic/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/2d/sprite2D/basic/index.js b/examples/2d/sprite2D/basic/index.js index 103bb57ad..7a7b0006b 100644 --- a/examples/2d/sprite2D/basic/index.js +++ b/examples/2d/sprite2D/basic/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; /** * [KO] Sprite2D Basic 예제 @@ -63,11 +63,11 @@ RedGPU.init( * @param {RedGPU.Display.Sprite2D} sprite2D */ const renderTestPane = async (redGPUContext, sprite2D) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { setDebugButtons, setRedGPUTest_pane - } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); setRedGPUTest_pane(pane, redGPUContext, false); diff --git a/examples/2d/sprite2D/childMethod/index.html b/examples/2d/sprite2D/childMethod/index.html index 77d781697..91601ab7d 100644 --- a/examples/2d/sprite2D/childMethod/index.html +++ b/examples/2d/sprite2D/childMethod/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/2d/sprite2D/childMethod/index.js b/examples/2d/sprite2D/childMethod/index.js index be86cee20..9074436c2 100644 --- a/examples/2d/sprite2D/childMethod/index.js +++ b/examples/2d/sprite2D/childMethod/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; /** * [KO] Sprite2D Child Method 예제 @@ -79,12 +79,12 @@ const createInitialObjects = (redGPUContext, scene) => { * @param {RedGPU.Display.Scene} scene */ const createPaneUI = async (redGPUContext, scene) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const pane = new Pane(); const { setDebugButtons, setRedGPUTest_pane - } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext); pane.addButton({title: 'Add Child'}).on('click', () => { addChildObject(redGPUContext, scene); diff --git a/examples/2d/sprite2D/hierarchy/index.html b/examples/2d/sprite2D/hierarchy/index.html index 77d781697..91601ab7d 100644 --- a/examples/2d/sprite2D/hierarchy/index.html +++ b/examples/2d/sprite2D/hierarchy/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/2d/sprite2D/hierarchy/index.js b/examples/2d/sprite2D/hierarchy/index.js index 9d3e71b70..c9b787a0c 100644 --- a/examples/2d/sprite2D/hierarchy/index.js +++ b/examples/2d/sprite2D/hierarchy/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; /** * [KO] Sprite2D Hierarchy 예제 @@ -98,12 +98,12 @@ const createChildSprite2D = (redGPUContext, parent) => { * @param {RedGPU.Display.Sprite2D} child */ const renderTestPane = async (redGPUContext, parent, child) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const pane = new Pane(); const { setDebugButtons, setRedGPUTest_pane - } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext); const maxW = redGPUContext.screenRectObject.width; const maxH = redGPUContext.screenRectObject.height; diff --git a/examples/2d/sprite2D/pivot/index.html b/examples/2d/sprite2D/pivot/index.html index 77d781697..91601ab7d 100644 --- a/examples/2d/sprite2D/pivot/index.html +++ b/examples/2d/sprite2D/pivot/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/2d/sprite2D/pivot/index.js b/examples/2d/sprite2D/pivot/index.js index 3435a53ee..1923f628a 100644 --- a/examples/2d/sprite2D/pivot/index.js +++ b/examples/2d/sprite2D/pivot/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; /** * [KO] Sprite2D Pivot 예제 @@ -102,12 +102,12 @@ const createChildSprite2D = (redGPUContext, parent) => { * @param {RedGPU.Display.Sprite2D} child */ const renderTestPane = async (redGPUContext, parent, child) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const pane = new Pane(); const { setDebugButtons, setRedGPUTest_pane - } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext); const maxW = redGPUContext.screenRectObject.width; const maxH = redGPUContext.screenRectObject.height; diff --git a/examples/2d/spriteSheet2D/basic/index.html b/examples/2d/spriteSheet2D/basic/index.html index 77d781697..91601ab7d 100644 --- a/examples/2d/spriteSheet2D/basic/index.html +++ b/examples/2d/spriteSheet2D/basic/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/2d/spriteSheet2D/basic/index.js b/examples/2d/spriteSheet2D/basic/index.js index 26c2946dd..ce233d90f 100644 --- a/examples/2d/spriteSheet2D/basic/index.js +++ b/examples/2d/spriteSheet2D/basic/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; /** * [KO] SpriteSheet2D Basic 예제 @@ -72,9 +72,9 @@ const renderTestPane = async (scene, redGPUContext) => { const { setDebugButtons, setSeparator - } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext); - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const pane = new Pane(); const controls = { diff --git a/examples/2d/textField2D/basic/index.html b/examples/2d/textField2D/basic/index.html index 77d781697..91601ab7d 100644 --- a/examples/2d/textField2D/basic/index.html +++ b/examples/2d/textField2D/basic/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/2d/textField2D/basic/index.js b/examples/2d/textField2D/basic/index.js index 6e5996fb1..564d69438 100644 --- a/examples/2d/textField2D/basic/index.js +++ b/examples/2d/textField2D/basic/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; /** * [KO] TextField2D Basic 예제 @@ -75,9 +75,9 @@ const renderTestPane = async (scene, redGPUContext) => { const { setDebugButtons, setSeparator - } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext); - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const pane = new Pane(); const controls = {}; diff --git a/examples/2d/tint/2dObjectTint/index.html b/examples/2d/tint/2dObjectTint/index.html index 77d781697..91601ab7d 100644 --- a/examples/2d/tint/2dObjectTint/index.html +++ b/examples/2d/tint/2dObjectTint/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/2d/tint/2dObjectTint/index.js b/examples/2d/tint/2dObjectTint/index.js index acf3e6fbb..c34754a0d 100644 --- a/examples/2d/tint/2dObjectTint/index.js +++ b/examples/2d/tint/2dObjectTint/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; /** * [KO] 2D Object Tint 예제 @@ -90,9 +90,9 @@ RedGPU.init( * @param {RedGPU.Display.Scene} scene */ const renderTestPane = async (redGPUContext, scene) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const pane = new Pane(); - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext); const firstChild = scene.children[0]; const defaultTint = firstChild ? firstChild.material.tint : {r: 255, g: 255, b: 255, a: 1}; diff --git a/examples/2d/tint/basic/index.html b/examples/2d/tint/basic/index.html index 77d781697..91601ab7d 100644 --- a/examples/2d/tint/basic/index.html +++ b/examples/2d/tint/basic/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/2d/tint/basic/index.js b/examples/2d/tint/basic/index.js index b213fbf6f..1f4abd53c 100644 --- a/examples/2d/tint/basic/index.js +++ b/examples/2d/tint/basic/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; /** * [KO] Tint Basic 예제 @@ -75,9 +75,9 @@ RedGPU.init( * @param {RedGPU.Display.Sprite2D} sprite */ const renderTestPane = async (redGPUContext, sprite) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const pane = new Pane(); - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext); const folder = pane.addFolder({title: 'Material Tint Test'}); const targetTint = sprite.material.tint; diff --git a/examples/2d/view/multiView/index.html b/examples/2d/view/multiView/index.html index 77d781697..91601ab7d 100644 --- a/examples/2d/view/multiView/index.html +++ b/examples/2d/view/multiView/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/2d/view/multiView/index.js b/examples/2d/view/multiView/index.js index 2e4c3c6aa..44e7b9589 100644 --- a/examples/2d/view/multiView/index.js +++ b/examples/2d/view/multiView/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; /** * [KO] Multi View 예제 @@ -85,12 +85,12 @@ RedGPU.init( * @param {RedGPU.RedGPUContext} redGPUContext */ const renderTestPane = async (redGPUContext) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { setDebugButtons, setRedGPUTest_pane, setViewListTest - } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); setRedGPUTest_pane(pane, redGPUContext, false); diff --git a/examples/2d/view/multiViewWith3D/index.html b/examples/2d/view/multiViewWith3D/index.html index 77d781697..91601ab7d 100644 --- a/examples/2d/view/multiViewWith3D/index.html +++ b/examples/2d/view/multiViewWith3D/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/2d/view/multiViewWith3D/index.js b/examples/2d/view/multiViewWith3D/index.js index f7b9ba5e0..1cbcd0b65 100644 --- a/examples/2d/view/multiViewWith3D/index.js +++ b/examples/2d/view/multiViewWith3D/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; /** * [KO] Multi View with 3D 예제 @@ -85,12 +85,12 @@ RedGPU.init( * @param {RedGPU.RedGPUContext} redGPUContext */ const renderTestPane = async (redGPUContext) => { - const {Pane} = await import("https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827"); + const {Pane} = await import("https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910"); const { setDebugButtons, setRedGPUTest_pane, setViewListTest - } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); setRedGPUTest_pane(pane, redGPUContext, false); diff --git a/examples/3d/controller/followController/index.html b/examples/3d/controller/followController/index.html index a6887ba00..e648c97f0 100644 --- a/examples/3d/controller/followController/index.html +++ b/examples/3d/controller/followController/index.html @@ -7,8 +7,8 @@ - - + + diff --git a/examples/3d/controller/followController/index.js b/examples/3d/controller/followController/index.js index 8ab758345..c1f1012b6 100644 --- a/examples/3d/controller/followController/index.js +++ b/examples/3d/controller/followController/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; /** * [KO] Follow Controller 예제 @@ -115,10 +115,10 @@ RedGPU.init( * @param {RedGPU.Camera.FollowController} controller */ const renderTestPane = async (redGPUContext, controller) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { setDebugButtons - } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); diff --git a/examples/3d/controller/freeController/index.html b/examples/3d/controller/freeController/index.html index a6887ba00..e648c97f0 100644 --- a/examples/3d/controller/freeController/index.html +++ b/examples/3d/controller/freeController/index.html @@ -7,8 +7,8 @@ - - + + diff --git a/examples/3d/controller/freeController/index.js b/examples/3d/controller/freeController/index.js index 387917d74..0db4df24a 100644 --- a/examples/3d/controller/freeController/index.js +++ b/examples/3d/controller/freeController/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; /** * [KO] Free Controller 예제 @@ -67,8 +67,8 @@ RedGPU.init(canvas, (redGPUContext) => { * @param {RedGPU.Camera.FreeController} controller */ const renderTestPane = async (redGPUContext, controller) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); diff --git a/examples/3d/controller/isometricController/index.html b/examples/3d/controller/isometricController/index.html index a6887ba00..e648c97f0 100644 --- a/examples/3d/controller/isometricController/index.html +++ b/examples/3d/controller/isometricController/index.html @@ -7,8 +7,8 @@ - - + + diff --git a/examples/3d/controller/isometricController/index.js b/examples/3d/controller/isometricController/index.js index 9962d0e6a..764945b21 100644 --- a/examples/3d/controller/isometricController/index.js +++ b/examples/3d/controller/isometricController/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; /** * [KO] Isometric Controller 예제 @@ -83,10 +83,10 @@ RedGPU.init( * @param {RedGPU.Display.Mesh} targetMesh */ const renderTestPane = async (redGPUContext, controller, targetMesh) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { setDebugButtons - } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); diff --git a/examples/3d/controller/orbitController/index.html b/examples/3d/controller/orbitController/index.html index a6887ba00..e648c97f0 100644 --- a/examples/3d/controller/orbitController/index.html +++ b/examples/3d/controller/orbitController/index.html @@ -7,8 +7,8 @@ - - + + diff --git a/examples/3d/controller/orbitController/index.js b/examples/3d/controller/orbitController/index.js index c4d2eeeb0..b4281c14d 100644 --- a/examples/3d/controller/orbitController/index.js +++ b/examples/3d/controller/orbitController/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; /** * [KO] Orbit Controller 예제 @@ -70,10 +70,10 @@ RedGPU.init( * @param {RedGPU.Camera.OrbitController} controller */ const renderTestPane = async (redGPUContext, controller) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { setDebugButtons - } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); diff --git a/examples/3d/coordinateTransformation/screenToWorld/index.html b/examples/3d/coordinateTransformation/screenToWorld/index.html index 77d781697..91601ab7d 100644 --- a/examples/3d/coordinateTransformation/screenToWorld/index.html +++ b/examples/3d/coordinateTransformation/screenToWorld/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/coordinateTransformation/screenToWorld/index.js b/examples/3d/coordinateTransformation/screenToWorld/index.js index daa9e6e8e..25348b856 100644 --- a/examples/3d/coordinateTransformation/screenToWorld/index.js +++ b/examples/3d/coordinateTransformation/screenToWorld/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; /** * [KO] Screen To World 예제 @@ -49,7 +49,7 @@ RedGPU.init( * @param {RedGPU.RedGPUContext} redGPUContext */ const renderTestPane = async (redGPUContext) => { - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext); }; diff --git a/examples/3d/coordinateTransformation/worldToLocal/index.html b/examples/3d/coordinateTransformation/worldToLocal/index.html index 77d781697..91601ab7d 100644 --- a/examples/3d/coordinateTransformation/worldToLocal/index.html +++ b/examples/3d/coordinateTransformation/worldToLocal/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/coordinateTransformation/worldToLocal/index.js b/examples/3d/coordinateTransformation/worldToLocal/index.js index b8d731641..c59378b6a 100644 --- a/examples/3d/coordinateTransformation/worldToLocal/index.js +++ b/examples/3d/coordinateTransformation/worldToLocal/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; /** * [KO] World To Local 예제 @@ -56,7 +56,7 @@ RedGPU.init( * @param {RedGPU.RedGPUContext} redGPUContext */ const renderTestPane = async (redGPUContext) => { - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext); }; diff --git a/examples/3d/drawDebugger/basic/index.html b/examples/3d/drawDebugger/basic/index.html index 77d781697..91601ab7d 100644 --- a/examples/3d/drawDebugger/basic/index.html +++ b/examples/3d/drawDebugger/basic/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/drawDebugger/basic/index.js b/examples/3d/drawDebugger/basic/index.js index 71ae93da4..f4216aab1 100644 --- a/examples/3d/drawDebugger/basic/index.js +++ b/examples/3d/drawDebugger/basic/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; /** * [KO] Draw Debugger 예제 @@ -133,8 +133,8 @@ RedGPU.init( * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); - const {setDebugButtons} = await import( "../../../exampleHelper/createExample/panes/index.js?t=1770699661827" ); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); + const {setDebugButtons} = await import( "../../../exampleHelper/createExample/panes/index.js?t=1770713934910" ); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); const ibl = new RedGPU.Resource.IBL(redGPUContext, '../../../assets/hdr/2k/the_sky_is_on_fire_2k.hdr'); diff --git a/examples/3d/frustumCulling/distanceCulling/index.html b/examples/3d/frustumCulling/distanceCulling/index.html index 77d781697..91601ab7d 100644 --- a/examples/3d/frustumCulling/distanceCulling/index.html +++ b/examples/3d/frustumCulling/distanceCulling/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/frustumCulling/distanceCulling/index.js b/examples/3d/frustumCulling/distanceCulling/index.js index 8172c695f..fce67ae3f 100644 --- a/examples/3d/frustumCulling/distanceCulling/index.js +++ b/examples/3d/frustumCulling/distanceCulling/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; /** * [KO] Distance Culling 예제 @@ -94,9 +94,9 @@ const createTestMeshes = (redGPUContext, scene) => { * @param {RedGPU.Display.View3D} view */ const renderTestPane = async (redGPUContext, meshes, view) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const pane = new Pane(); - const {setDebugButtons} = await import( "../../../exampleHelper/createExample/panes/index.js?t=1770699661827" ); + const {setDebugButtons} = await import( "../../../exampleHelper/createExample/panes/index.js?t=1770713934910" ); setDebugButtons(RedGPU, redGPUContext); const config = { cameraDistance: view.camera.distance, diff --git a/examples/3d/frustumCulling/frustumCulling/index.html b/examples/3d/frustumCulling/frustumCulling/index.html index 77d781697..91601ab7d 100644 --- a/examples/3d/frustumCulling/frustumCulling/index.html +++ b/examples/3d/frustumCulling/frustumCulling/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/frustumCulling/frustumCulling/index.js b/examples/3d/frustumCulling/frustumCulling/index.js index e7b5b2141..d3fb7c8b1 100644 --- a/examples/3d/frustumCulling/frustumCulling/index.js +++ b/examples/3d/frustumCulling/frustumCulling/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; /** * [KO] Frustum Culling 예제 @@ -87,9 +87,9 @@ const createTestMeshes = (redGPUContext, scene) => { * @param {RedGPU.Display.View3D} view */ const renderTestPane = async (redGPUContext, meshes, view) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const pane = new Pane(); - const {setDebugButtons} = await import( "../../../exampleHelper/createExample/panes/index.js?t=1770699661827" ); + const {setDebugButtons} = await import( "../../../exampleHelper/createExample/panes/index.js?t=1770713934910" ); setDebugButtons(RedGPU, redGPUContext); const config = { cameraDistance: view.camera.distance, diff --git a/examples/3d/group3D/basic/index.html b/examples/3d/group3D/basic/index.html index 77d781697..91601ab7d 100644 --- a/examples/3d/group3D/basic/index.html +++ b/examples/3d/group3D/basic/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/group3D/basic/index.js b/examples/3d/group3D/basic/index.js index 35a48b71d..ffcce8f15 100644 --- a/examples/3d/group3D/basic/index.js +++ b/examples/3d/group3D/basic/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; /** * [KO] Group3D Basic 예제 @@ -108,9 +108,9 @@ const createChildMesh = (redGPUContext, parent) => { * @param {RedGPU.Display.Mesh} child */ const renderTestPane = async (redGPUContext, rootGroup, parent, child) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const pane = new Pane(); - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext); const rootConfig = { x: rootGroup.x, diff --git a/examples/3d/helloWorld/index.html b/examples/3d/helloWorld/index.html index 9579c4497..5d843cc60 100644 --- a/examples/3d/helloWorld/index.html +++ b/examples/3d/helloWorld/index.html @@ -7,8 +7,8 @@ - - + + diff --git a/examples/3d/helloWorld/index.js b/examples/3d/helloWorld/index.js index 599944c4f..35a129474 100644 --- a/examples/3d/helloWorld/index.js +++ b/examples/3d/helloWorld/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../dist/index.js?t=1770713934910"; /** * [KO] Hello World 3D 예제 @@ -47,11 +47,11 @@ RedGPU.init( * @param {RedGPU.Display.View3D} view */ const renderTestPane = async (redGPUContext, view) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { setRedGPUTest_pane, setDebugButtons - } = await import("../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + } = await import("../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext) const pane = new Pane(); setRedGPUTest_pane(pane, redGPUContext, true); diff --git a/examples/3d/indirectDrawTest/index.html b/examples/3d/indirectDrawTest/index.html index b3924120d..a61628df1 100644 --- a/examples/3d/indirectDrawTest/index.html +++ b/examples/3d/indirectDrawTest/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/indirectDrawTest/index.js b/examples/3d/indirectDrawTest/index.js index 476d783e7..d4e7da344 100644 --- a/examples/3d/indirectDrawTest/index.js +++ b/examples/3d/indirectDrawTest/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../dist/index.js?t=1770713934910"; /** * [KO] Indirect Draw 예제 @@ -201,11 +201,11 @@ function loadGLTFGrid(view, urls, gridSize = 3, spacing = 3) { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { createIblHelper, setDebugButtons - } = await import('../../exampleHelper/createExample/panes/index.js?t=1770699661827'); + } = await import('../../exampleHelper/createExample/panes/index.js?t=1770713934910'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/3d/instancedMesh/simple/index.html b/examples/3d/instancedMesh/simple/index.html index 77d781697..91601ab7d 100644 --- a/examples/3d/instancedMesh/simple/index.html +++ b/examples/3d/instancedMesh/simple/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/instancedMesh/simple/index.js b/examples/3d/instancedMesh/simple/index.js index 246695b4c..82a2bd8d8 100644 --- a/examples/3d/instancedMesh/simple/index.js +++ b/examples/3d/instancedMesh/simple/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; // 1. Create and append a canvas const canvas = document.createElement('canvas'); @@ -83,9 +83,9 @@ RedGPU.init( * @param {RedGPU.Material.PhongMaterial} material */ async function createTest(redGPUContext, scene, material) { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext); const maxInstanceCount = redGPUContext.detector.isMobile ? 100000 : RedGPU.Display.InstancingMesh.getLimitSize(); diff --git a/examples/3d/instancedMesh/sphere/index.html b/examples/3d/instancedMesh/sphere/index.html index 77d781697..91601ab7d 100644 --- a/examples/3d/instancedMesh/sphere/index.html +++ b/examples/3d/instancedMesh/sphere/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/instancedMesh/sphere/index.js b/examples/3d/instancedMesh/sphere/index.js index 7c98a4534..3ee136cd8 100644 --- a/examples/3d/instancedMesh/sphere/index.js +++ b/examples/3d/instancedMesh/sphere/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; // 1. Create and append a canvas const canvas = document.createElement('canvas'); @@ -83,9 +83,9 @@ RedGPU.init( * @param {RedGPU.Material.PhongMaterial} material */ async function createTest(redGPUContext, scene, material) { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext); const maxInstanceCount = redGPUContext.detector.isMobile ? 100000 : RedGPU.Display.InstancingMesh.getLimitSize(); diff --git a/examples/3d/interaction/keyboardEvent/index.html b/examples/3d/interaction/keyboardEvent/index.html index 6ca35a7e3..52b20dce5 100644 --- a/examples/3d/interaction/keyboardEvent/index.html +++ b/examples/3d/interaction/keyboardEvent/index.html @@ -7,8 +7,8 @@ - - + + diff --git a/examples/3d/interaction/keyboardEvent/index.js b/examples/3d/interaction/keyboardEvent/index.js index 8eed2f290..7e608d62a 100644 --- a/examples/3d/interaction/keyboardEvent/index.js +++ b/examples/3d/interaction/keyboardEvent/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -139,8 +139,8 @@ RedGPU.init( * @param {Object} activeKeysState */ const renderTestPane = async (redGPUContext, activeKeysState) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext) const pane = new Pane(); diff --git a/examples/3d/interaction/mouseEvent/mesh/index.html b/examples/3d/interaction/mouseEvent/mesh/index.html index fa98ba6d3..9e5335be6 100644 --- a/examples/3d/interaction/mouseEvent/mesh/index.html +++ b/examples/3d/interaction/mouseEvent/mesh/index.html @@ -8,9 +8,9 @@ - - - + + + diff --git a/examples/3d/interaction/mouseEvent/mesh/index.js b/examples/3d/interaction/mouseEvent/mesh/index.js index c11e9ac71..cb02de74a 100644 --- a/examples/3d/interaction/mouseEvent/mesh/index.js +++ b/examples/3d/interaction/mouseEvent/mesh/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../../dist/index.js?t=1770713934910"; /** * [KO] Mesh Mouse Event 예제 @@ -167,6 +167,6 @@ const createSampleMesh = (redGPUContext, scene, infoBox, updateInfo) => { const renderTestPane = async (redGPUContext) => { const { setDebugButtons - } = await import("../../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + } = await import("../../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext); }; diff --git a/examples/3d/interaction/mouseEvent/raycasting/index.html b/examples/3d/interaction/mouseEvent/raycasting/index.html index e9152e103..120410c2d 100644 --- a/examples/3d/interaction/mouseEvent/raycasting/index.html +++ b/examples/3d/interaction/mouseEvent/raycasting/index.html @@ -8,9 +8,9 @@ - - - + + + diff --git a/examples/3d/interaction/mouseEvent/raycasting/index.js b/examples/3d/interaction/mouseEvent/raycasting/index.js index 37dde2d55..125a93620 100644 --- a/examples/3d/interaction/mouseEvent/raycasting/index.js +++ b/examples/3d/interaction/mouseEvent/raycasting/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../../dist/index.js?t=1770713934910"; /** * [KO] Raycasting 예제 @@ -118,8 +118,8 @@ RedGPU.init( * @param {RedGPU.RedGPUContext} redGPUContext */ const renderTestPane = async (redGPUContext) => { - const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); - const { setDebugButtons } = await import("../../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); + const { setDebugButtons } = await import("../../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext); new Pane().addBlade({ view: 'text', label: 'Guide', value: 'Hover over objects to see raycasting in action!', parse: (v) => v, readonly: true }); }; \ No newline at end of file diff --git a/examples/3d/interaction/mouseEvent/sprite3D/index.html b/examples/3d/interaction/mouseEvent/sprite3D/index.html index fa98ba6d3..9e5335be6 100644 --- a/examples/3d/interaction/mouseEvent/sprite3D/index.html +++ b/examples/3d/interaction/mouseEvent/sprite3D/index.html @@ -8,9 +8,9 @@ - - - + + + diff --git a/examples/3d/interaction/mouseEvent/sprite3D/index.js b/examples/3d/interaction/mouseEvent/sprite3D/index.js index 4dd940bc0..cdbb79ff1 100644 --- a/examples/3d/interaction/mouseEvent/sprite3D/index.js +++ b/examples/3d/interaction/mouseEvent/sprite3D/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../../dist/index.js?t=1770713934910"; /** * [KO] Sprite3D Mouse Event 예제 @@ -167,9 +167,9 @@ const createSampleSprite3D = (redGPUContext, scene, infoBox, updateInfo) => { * @param {RedGPU.Display.Scene} scene */ const renderTestPane = async (redGPUContext, scene) => { - const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const pane = new Pane(); - const { setDebugButtons } = await import("../../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const { setDebugButtons } = await import("../../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext); const folder = pane.addFolder({ title: 'Sprite3D', expanded: true }); diff --git a/examples/3d/interaction/mouseEvent/spriteSheet3D/index.html b/examples/3d/interaction/mouseEvent/spriteSheet3D/index.html index fa98ba6d3..9e5335be6 100644 --- a/examples/3d/interaction/mouseEvent/spriteSheet3D/index.html +++ b/examples/3d/interaction/mouseEvent/spriteSheet3D/index.html @@ -8,9 +8,9 @@ - - - + + + diff --git a/examples/3d/interaction/mouseEvent/spriteSheet3D/index.js b/examples/3d/interaction/mouseEvent/spriteSheet3D/index.js index 7e7a03e8d..4401e6622 100644 --- a/examples/3d/interaction/mouseEvent/spriteSheet3D/index.js +++ b/examples/3d/interaction/mouseEvent/spriteSheet3D/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../../dist/index.js?t=1770713934910"; /** * [KO] SpriteSheet3D Mouse Event 예제 @@ -172,9 +172,9 @@ const createSampleSprite3D = (redGPUContext, scene, infoBox, updateInfo) => { * @param {RedGPU.Display.Scene} scene */ const renderTestPane = async (redGPUContext, scene) => { - const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const pane = new Pane(); - const { setDebugButtons } = await import("../../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const { setDebugButtons } = await import("../../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext); const folder = pane.addFolder({ title: 'SpriteSheet3D', expanded: true }); diff --git a/examples/3d/interaction/mouseEvent/textField3D/index.html b/examples/3d/interaction/mouseEvent/textField3D/index.html index fa98ba6d3..9e5335be6 100644 --- a/examples/3d/interaction/mouseEvent/textField3D/index.html +++ b/examples/3d/interaction/mouseEvent/textField3D/index.html @@ -8,9 +8,9 @@ - - - + + + diff --git a/examples/3d/interaction/mouseEvent/textField3D/index.js b/examples/3d/interaction/mouseEvent/textField3D/index.js index 62b38e3dc..0ac54d6b5 100644 --- a/examples/3d/interaction/mouseEvent/textField3D/index.js +++ b/examples/3d/interaction/mouseEvent/textField3D/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../../dist/index.js?t=1770713934910"; /** * [KO] TextField3D Mouse Event 예제 @@ -165,9 +165,9 @@ function getRandomHexValue() { * @param {RedGPU.Display.Scene} scene */ const renderTestPane = async (redGPUContext, scene) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const pane = new Pane(); - const {setDebugButtons} = await import("../../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const {setDebugButtons} = await import("../../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext); const child = scene.children.find(c => c instanceof RedGPU.Display.TextField3D); diff --git a/examples/3d/light/directionalLight/index.html b/examples/3d/light/directionalLight/index.html index 77d781697..91601ab7d 100644 --- a/examples/3d/light/directionalLight/index.html +++ b/examples/3d/light/directionalLight/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/light/directionalLight/index.js b/examples/3d/light/directionalLight/index.js index 9eb7660e7..70fb90b5f 100644 --- a/examples/3d/light/directionalLight/index.js +++ b/examples/3d/light/directionalLight/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; /** * [KO] Directional Light 예제 @@ -81,9 +81,9 @@ const createSampleMesh = (redGPUContext, scene) => { * @param {RedGPU.Light.DirectionalLight} light */ const renderTestPaneWithLightControl = async (redGPUContext, mesh, light) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const pane = new Pane(); - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext); const lightConfig = { directionX: light.direction[0], diff --git a/examples/3d/light/pointLight/index.html b/examples/3d/light/pointLight/index.html index 77d781697..91601ab7d 100644 --- a/examples/3d/light/pointLight/index.html +++ b/examples/3d/light/pointLight/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/light/pointLight/index.js b/examples/3d/light/pointLight/index.js index 1d63450bc..5bc869b04 100644 --- a/examples/3d/light/pointLight/index.js +++ b/examples/3d/light/pointLight/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; /** * [KO] Point Light 예제 @@ -98,9 +98,9 @@ const createSampleMeshes = (redGPUContext, scene) => { * @param {RedGPU.Light.PointLight} light */ const renderTestPaneWithLightControl = async (redGPUContext, light) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const pane = new Pane(); - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext); const lightConfig = { x: light.position[0], diff --git a/examples/3d/light/pointLightPerformance/index.html b/examples/3d/light/pointLightPerformance/index.html index 77d781697..91601ab7d 100644 --- a/examples/3d/light/pointLightPerformance/index.html +++ b/examples/3d/light/pointLightPerformance/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/light/pointLightPerformance/index.js b/examples/3d/light/pointLightPerformance/index.js index c2dab3955..e1609d9b0 100644 --- a/examples/3d/light/pointLightPerformance/index.js +++ b/examples/3d/light/pointLightPerformance/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; /** * [KO] Point Light Performance 예제 @@ -50,7 +50,7 @@ RedGPU.init( * @param {RedGPU.RedGPUContext} redGPUContext */ const renderTestPane = async (redGPUContext) => { - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext); }; diff --git a/examples/3d/light/spotLight/index.html b/examples/3d/light/spotLight/index.html index 77d781697..91601ab7d 100644 --- a/examples/3d/light/spotLight/index.html +++ b/examples/3d/light/spotLight/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/light/spotLight/index.js b/examples/3d/light/spotLight/index.js index c2376f227..60ef14774 100644 --- a/examples/3d/light/spotLight/index.js +++ b/examples/3d/light/spotLight/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; /** * [KO] Spot Light 예제 @@ -128,9 +128,9 @@ const createSampleMeshes = (redGPUContext, scene) => { * @param {RedGPU.Light.SpotLight} light */ const renderTestPaneWithLightControl = async (redGPUContext, light) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const pane = new Pane(); - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext); const lightConfig = { x: light.position[0], diff --git a/examples/3d/light/spotLightPerformance/index.html b/examples/3d/light/spotLightPerformance/index.html index 77d781697..91601ab7d 100644 --- a/examples/3d/light/spotLightPerformance/index.html +++ b/examples/3d/light/spotLightPerformance/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/light/spotLightPerformance/index.js b/examples/3d/light/spotLightPerformance/index.js index 2be54b6b1..6936089bc 100644 --- a/examples/3d/light/spotLightPerformance/index.js +++ b/examples/3d/light/spotLightPerformance/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; /** * [KO] Spot Light Performance 예제 @@ -56,7 +56,7 @@ RedGPU.init( * @param {RedGPU.RedGPUContext} redGPUContext */ const renderTestPane = async (redGPUContext) => { - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext); }; diff --git a/examples/3d/line3D/bezier/index.html b/examples/3d/line3D/bezier/index.html index 77d781697..91601ab7d 100644 --- a/examples/3d/line3D/bezier/index.html +++ b/examples/3d/line3D/bezier/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/line3D/bezier/index.js b/examples/3d/line3D/bezier/index.js index d30ad3252..dae1fa61f 100644 --- a/examples/3d/line3D/bezier/index.js +++ b/examples/3d/line3D/bezier/index.js @@ -1,5 +1,5 @@ // RedGPU 사용을 위한 모듈 임포트 -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; /** * [KO] Line3D (Bezier) 예제 @@ -143,9 +143,9 @@ function rainbowHex(t) { } const renderTestPane = async (redGPUContext) => { - const {Pane} = await import("https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827"); + const {Pane} = await import("https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910"); const pane = new Pane(); - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext); // **** UI 동작 대상이 되는 Line3D 오브젝트 및 디버그 마커 모음 **** const debugOptions = { diff --git a/examples/3d/line3D/catmullRom/index.html b/examples/3d/line3D/catmullRom/index.html index 77d781697..91601ab7d 100644 --- a/examples/3d/line3D/catmullRom/index.html +++ b/examples/3d/line3D/catmullRom/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/line3D/catmullRom/index.js b/examples/3d/line3D/catmullRom/index.js index 401f9b421..ab4b10f5d 100644 --- a/examples/3d/line3D/catmullRom/index.js +++ b/examples/3d/line3D/catmullRom/index.js @@ -1,5 +1,5 @@ // RedGPU 사용을 위한 모듈 임포트 -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; /** * [KO] Line3D (Catmull-Rom) 예제 @@ -121,9 +121,9 @@ function rainbowHex(t) { } const renderTestPane = async (redGPUContext) => { - const {Pane} = await import("https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827"); + const {Pane} = await import("https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910"); const pane = new Pane(); - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext); // **** UI 동작 대상이 되는 Line3D 오브젝트 및 디버그 마커 모음 **** const debugOptions = { diff --git a/examples/3d/line3D/linear/index.html b/examples/3d/line3D/linear/index.html index 77d781697..91601ab7d 100644 --- a/examples/3d/line3D/linear/index.html +++ b/examples/3d/line3D/linear/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/line3D/linear/index.js b/examples/3d/line3D/linear/index.js index 30b90a480..9a678845a 100644 --- a/examples/3d/line3D/linear/index.js +++ b/examples/3d/line3D/linear/index.js @@ -1,5 +1,5 @@ // RedGPU 사용을 위한 모듈 임포트 -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; /** * [KO] Line3D (Linear) 예제 @@ -122,9 +122,9 @@ function rainbowHex(t) { } const renderTestPane = async (redGPUContext, view) => { - const {Pane} = await import("https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827"); + const {Pane} = await import("https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910"); const pane = new Pane(); - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext); // 옵션 초기화 const debugOptions = { diff --git a/examples/3d/lod/InstanceMeshGPULOD/index.html b/examples/3d/lod/InstanceMeshGPULOD/index.html index 77d781697..91601ab7d 100644 --- a/examples/3d/lod/InstanceMeshGPULOD/index.html +++ b/examples/3d/lod/InstanceMeshGPULOD/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/lod/InstanceMeshGPULOD/index.js b/examples/3d/lod/InstanceMeshGPULOD/index.js index ea3556c2f..d88bed7b7 100644 --- a/examples/3d/lod/InstanceMeshGPULOD/index.js +++ b/examples/3d/lod/InstanceMeshGPULOD/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; // 1. Create and append a canvas const canvas = document.createElement('canvas'); @@ -83,9 +83,9 @@ RedGPU.init( * @param {RedGPU.Material.PhongMaterial} material */ async function createTest(redGPUContext, scene, material) { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext); const maxInstanceCount = redGPUContext.detector.isMobile ? 100000 : RedGPU.Display.InstancingMesh.getLimitSize(); diff --git a/examples/3d/lod/InstanceMeshGPULOD_material/index.html b/examples/3d/lod/InstanceMeshGPULOD_material/index.html index 77d781697..91601ab7d 100644 --- a/examples/3d/lod/InstanceMeshGPULOD_material/index.html +++ b/examples/3d/lod/InstanceMeshGPULOD_material/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/lod/InstanceMeshGPULOD_material/index.js b/examples/3d/lod/InstanceMeshGPULOD_material/index.js index 08d306386..f72be3259 100644 --- a/examples/3d/lod/InstanceMeshGPULOD_material/index.js +++ b/examples/3d/lod/InstanceMeshGPULOD_material/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -62,8 +62,8 @@ RedGPU.init( * @param {RedGPU.Material.PhongMaterial} material */ async function createTest(redGPUContext, scene, material) { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); const maxInstanceCount = 20000; const instanceCount = redGPUContext.detector.isMobile ? 5000 : 20000; diff --git a/examples/3d/lod/MeshCPULOD/index.html b/examples/3d/lod/MeshCPULOD/index.html index 77d781697..91601ab7d 100644 --- a/examples/3d/lod/MeshCPULOD/index.html +++ b/examples/3d/lod/MeshCPULOD/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/lod/MeshCPULOD/index.js b/examples/3d/lod/MeshCPULOD/index.js index a087f2493..1e3ad9b30 100644 --- a/examples/3d/lod/MeshCPULOD/index.js +++ b/examples/3d/lod/MeshCPULOD/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; // 1. Create and append a canvas const canvas = document.createElement('canvas'); @@ -83,9 +83,9 @@ RedGPU.init( * @param {RedGPU.Material.PhongMaterial} material */ async function createTest(redGPUContext, scene, material) { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext); const maxNum = redGPUContext.detector.isMobile ? 1000 : 5000; diff --git a/examples/3d/lod/MeshCPULOD_material/index.html b/examples/3d/lod/MeshCPULOD_material/index.html index 77d781697..91601ab7d 100644 --- a/examples/3d/lod/MeshCPULOD_material/index.html +++ b/examples/3d/lod/MeshCPULOD_material/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/lod/MeshCPULOD_material/index.js b/examples/3d/lod/MeshCPULOD_material/index.js index f420457f2..7b35e6cab 100644 --- a/examples/3d/lod/MeshCPULOD_material/index.js +++ b/examples/3d/lod/MeshCPULOD_material/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -54,8 +54,8 @@ RedGPU.init( * @param {RedGPU.Display.Scene} scene */ async function createTest(redGPUContext, scene) { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); const url = 'https://raw.githubusercontent.com/KhronosGroup/glTF-Sample-Assets/main/Models/Suzanne/glTF/Suzanne.gltf'; diff --git a/examples/3d/material/bitmapMaterial/index.html b/examples/3d/material/bitmapMaterial/index.html index 77d781697..91601ab7d 100644 --- a/examples/3d/material/bitmapMaterial/index.html +++ b/examples/3d/material/bitmapMaterial/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/material/bitmapMaterial/index.js b/examples/3d/material/bitmapMaterial/index.js index f50c68811..9031e5175 100644 --- a/examples/3d/material/bitmapMaterial/index.js +++ b/examples/3d/material/bitmapMaterial/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; /** * [KO] Bitmap Material 예제 @@ -67,11 +67,11 @@ const createSampleMesh = (redGPUContext, scene) => { * @param {RedGPU.Display.Mesh} mesh */ const renderTestPane = async (redGPUContext, mesh) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { setSeparator, setDebugButtons - } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); diff --git a/examples/3d/material/colorMaterial/index.html b/examples/3d/material/colorMaterial/index.html index 77d781697..91601ab7d 100644 --- a/examples/3d/material/colorMaterial/index.html +++ b/examples/3d/material/colorMaterial/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/material/colorMaterial/index.js b/examples/3d/material/colorMaterial/index.js index f5ed2b4d4..ab532bdbd 100644 --- a/examples/3d/material/colorMaterial/index.js +++ b/examples/3d/material/colorMaterial/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; /** * [KO] Color Material 예제 @@ -61,11 +61,11 @@ const createSampleMesh = (redGPUContext, scene) => { * @param {RedGPU.Display.Mesh} mesh */ const renderTestPane = async (redGPUContext, mesh) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { setSeparator, setDebugButtons - } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); diff --git a/examples/3d/material/fragmentVariantTest/index.html b/examples/3d/material/fragmentVariantTest/index.html index 77d781697..91601ab7d 100644 --- a/examples/3d/material/fragmentVariantTest/index.html +++ b/examples/3d/material/fragmentVariantTest/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/material/fragmentVariantTest/index.js b/examples/3d/material/fragmentVariantTest/index.js index e2ab78756..c0781e58e 100644 --- a/examples/3d/material/fragmentVariantTest/index.js +++ b/examples/3d/material/fragmentVariantTest/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; /** * [KO] Fragment Variant Test 예제 @@ -140,11 +140,11 @@ const createTextures = (redGPUContext) => { // ===== UI Rendering ===== const renderUI = async (redGPUContext, mesh) => { - const {Pane} = await import("https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827"); + const {Pane} = await import("https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910"); const { setSeparator, setDebugButtons - } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane({title: "Phong Shader Variants"}); diff --git a/examples/3d/material/opacity/index.html b/examples/3d/material/opacity/index.html index 77d781697..91601ab7d 100644 --- a/examples/3d/material/opacity/index.html +++ b/examples/3d/material/opacity/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/material/opacity/index.js b/examples/3d/material/opacity/index.js index 807aa7bc0..3e8d32cd2 100644 --- a/examples/3d/material/opacity/index.js +++ b/examples/3d/material/opacity/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; /** * [KO] Opacity 3D Material 예제 @@ -123,11 +123,11 @@ const createChildTextField3D = (redGPUContext, parent, x = 0, y = 0) => { * @param {Array} children */ const renderTestPane = async (redGPUContext, parent, children) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { setSeparator, setDebugButtons - } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); diff --git a/examples/3d/material/phongMaterial/index.html b/examples/3d/material/phongMaterial/index.html index 77d781697..91601ab7d 100644 --- a/examples/3d/material/phongMaterial/index.html +++ b/examples/3d/material/phongMaterial/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/material/phongMaterial/index.js b/examples/3d/material/phongMaterial/index.js index 353ac136b..159064e2d 100644 --- a/examples/3d/material/phongMaterial/index.js +++ b/examples/3d/material/phongMaterial/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; /** * [KO] Phong Material 예제 @@ -83,11 +83,11 @@ const createTextures = (redGPUContext) => { }; const renderUI = async (redGPUContext, mesh) => { - const {Pane} = await import("https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827"); + const {Pane} = await import("https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910"); const { setSeparator, setDebugButtons - } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); const material = mesh.material; diff --git a/examples/3d/material/phongMaterialTextures/index.html b/examples/3d/material/phongMaterialTextures/index.html index 77d781697..91601ab7d 100644 --- a/examples/3d/material/phongMaterialTextures/index.html +++ b/examples/3d/material/phongMaterialTextures/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/material/phongMaterialTextures/index.js b/examples/3d/material/phongMaterialTextures/index.js index 662c790a5..a0bd14be5 100644 --- a/examples/3d/material/phongMaterialTextures/index.js +++ b/examples/3d/material/phongMaterialTextures/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; /** * [KO] Phong Material Textures 예제 @@ -71,7 +71,7 @@ const renderTestPane = async (redGPUContext) => { const { setSeparator, setDebugButtons - } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext); } diff --git a/examples/3d/material/uvTransform/index.html b/examples/3d/material/uvTransform/index.html index 3991dbc06..e37f1b940 100644 --- a/examples/3d/material/uvTransform/index.html +++ b/examples/3d/material/uvTransform/index.html @@ -13,8 +13,8 @@ - - + + diff --git a/examples/3d/material/uvTransform/index.js b/examples/3d/material/uvTransform/index.js index bfea6765e..769dce12b 100644 --- a/examples/3d/material/uvTransform/index.js +++ b/examples/3d/material/uvTransform/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; /** * [KO] UV Transform 예제 @@ -136,8 +136,8 @@ RedGPU.init( * [EN] Create UI panel function for test manipulation */ async function renderTestPane(redGPUContext, testTarget) { - const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); - const { setDebugButtons } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); + const { setDebugButtons } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext); diff --git a/examples/3d/mesh/basicMesh/index.html b/examples/3d/mesh/basicMesh/index.html index 77d781697..91601ab7d 100644 --- a/examples/3d/mesh/basicMesh/index.html +++ b/examples/3d/mesh/basicMesh/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/mesh/basicMesh/index.js b/examples/3d/mesh/basicMesh/index.js index c09f648a1..47da91de5 100644 --- a/examples/3d/mesh/basicMesh/index.js +++ b/examples/3d/mesh/basicMesh/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; /** * [KO] Basic Mesh 예제 @@ -69,8 +69,8 @@ const createSampleMesh = (redGPUContext, scene) => { */ const renderTestPane = async (redGPUContext, mesh) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext) const pane = new Pane(); diff --git a/examples/3d/mesh/boundBox/meshAABBIntersects/index.html b/examples/3d/mesh/boundBox/meshAABBIntersects/index.html index c7c14d3dd..004b73e31 100644 --- a/examples/3d/mesh/boundBox/meshAABBIntersects/index.html +++ b/examples/3d/mesh/boundBox/meshAABBIntersects/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/3d/mesh/boundBox/meshAABBIntersects/index.js b/examples/3d/mesh/boundBox/meshAABBIntersects/index.js index 01702513b..6a1bc1822 100644 --- a/examples/3d/mesh/boundBox/meshAABBIntersects/index.js +++ b/examples/3d/mesh/boundBox/meshAABBIntersects/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../../dist/index.js?t=1770713934910"; /** * [KO] Mesh AABB Intersects 예제 @@ -48,7 +48,7 @@ RedGPU.init( * [EN] Sets up Tweakpane buttons for testing. */ const renderTestPane = async (redGPUContext, view) => { - const {setDebugButtons} = await import("../../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const {setDebugButtons} = await import("../../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext); }; diff --git a/examples/3d/mesh/boundBox/meshBoundBox/index.html b/examples/3d/mesh/boundBox/meshBoundBox/index.html index c7c14d3dd..004b73e31 100644 --- a/examples/3d/mesh/boundBox/meshBoundBox/index.html +++ b/examples/3d/mesh/boundBox/meshBoundBox/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/3d/mesh/boundBox/meshBoundBox/index.js b/examples/3d/mesh/boundBox/meshBoundBox/index.js index 47c2f3ca7..4b31ff9cd 100644 --- a/examples/3d/mesh/boundBox/meshBoundBox/index.js +++ b/examples/3d/mesh/boundBox/meshBoundBox/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../../dist/index.js?t=1770713934910"; /** * [KO] Mesh Bounding Box 예제 @@ -62,7 +62,7 @@ RedGPU.init( * [EN] Sets up test pane buttons. */ const renderTestPane = async (redGPUContext) => { - const {setDebugButtons} = await import("../../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const {setDebugButtons} = await import("../../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext); }; diff --git a/examples/3d/mesh/boundBox/meshOBBIntersects/index.html b/examples/3d/mesh/boundBox/meshOBBIntersects/index.html index c7c14d3dd..004b73e31 100644 --- a/examples/3d/mesh/boundBox/meshOBBIntersects/index.html +++ b/examples/3d/mesh/boundBox/meshOBBIntersects/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/3d/mesh/boundBox/meshOBBIntersects/index.js b/examples/3d/mesh/boundBox/meshOBBIntersects/index.js index 320393ecd..af39bcf28 100644 --- a/examples/3d/mesh/boundBox/meshOBBIntersects/index.js +++ b/examples/3d/mesh/boundBox/meshOBBIntersects/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../../dist/index.js?t=1770713934910"; /** * [KO] Mesh OBB Intersects 예제 @@ -48,7 +48,7 @@ RedGPU.init( * [EN] Initializes the test button pane. */ const renderTestPane = async (redGPUContext) => { - const {setDebugButtons} = await import("../../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const {setDebugButtons} = await import("../../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext); }; diff --git a/examples/3d/mesh/childMethod/index.html b/examples/3d/mesh/childMethod/index.html index 77d781697..91601ab7d 100644 --- a/examples/3d/mesh/childMethod/index.html +++ b/examples/3d/mesh/childMethod/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/mesh/childMethod/index.js b/examples/3d/mesh/childMethod/index.js index ada449c2a..8c3070da7 100644 --- a/examples/3d/mesh/childMethod/index.js +++ b/examples/3d/mesh/childMethod/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; /** * [KO] Mesh Child Method 예제 @@ -70,8 +70,8 @@ const createInitialMeshes = (redGPUContext, scene) => { * @param {RedGPU.Display.Scene} scene */ const createPaneUI = async (redGPUContext, scene) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext) const pane = new Pane(); diff --git a/examples/3d/mesh/hierarchy/index.html b/examples/3d/mesh/hierarchy/index.html index 77d781697..91601ab7d 100644 --- a/examples/3d/mesh/hierarchy/index.html +++ b/examples/3d/mesh/hierarchy/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/mesh/hierarchy/index.js b/examples/3d/mesh/hierarchy/index.js index 8e0386839..65a879d79 100644 --- a/examples/3d/mesh/hierarchy/index.js +++ b/examples/3d/mesh/hierarchy/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; /** * [KO] Mesh Hierarchy 예제 @@ -91,8 +91,8 @@ const createChildMesh = (redGPUContext, parentMesh) => { */ const renderTestPane = async (redGPUContext, parentMesh, childMesh) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext) const pane = new Pane(); diff --git a/examples/3d/mesh/lookAt/index.html b/examples/3d/mesh/lookAt/index.html index 77d781697..91601ab7d 100644 --- a/examples/3d/mesh/lookAt/index.html +++ b/examples/3d/mesh/lookAt/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/mesh/lookAt/index.js b/examples/3d/mesh/lookAt/index.js index e4f77e4f3..2f2ea8cbf 100644 --- a/examples/3d/mesh/lookAt/index.js +++ b/examples/3d/mesh/lookAt/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; /** * [KO] Mesh LookAt 예제 @@ -59,7 +59,7 @@ RedGPU.init( * @param {RedGPU.RedGPUContext} redGPUContext */ const renderTestPane = async (redGPUContext) => { - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext); }; diff --git a/examples/3d/mesh/pivot/index.html b/examples/3d/mesh/pivot/index.html index 77d781697..91601ab7d 100644 --- a/examples/3d/mesh/pivot/index.html +++ b/examples/3d/mesh/pivot/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/mesh/pivot/index.js b/examples/3d/mesh/pivot/index.js index 0a6483a88..0ec0c6b6e 100644 --- a/examples/3d/mesh/pivot/index.js +++ b/examples/3d/mesh/pivot/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; /** * [KO] Mesh Pivot 예제 @@ -138,8 +138,8 @@ const createPivotMesh = (redGPUContext, targetMesh) => { * @param {object} animationConfig */ const renderTestPane = async (redGPUContext, parentMesh, childMesh, animationConfig) => { - const {Pane} = await import("https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827"); - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const {Pane} = await import("https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext) const pane = new Pane(); diff --git a/examples/3d/noiseTexture/simplex/basic/index.html b/examples/3d/noiseTexture/simplex/basic/index.html index c7c14d3dd..004b73e31 100644 --- a/examples/3d/noiseTexture/simplex/basic/index.html +++ b/examples/3d/noiseTexture/simplex/basic/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/3d/noiseTexture/simplex/basic/index.js b/examples/3d/noiseTexture/simplex/basic/index.js index 8461bd7b1..0f06b8ce4 100644 --- a/examples/3d/noiseTexture/simplex/basic/index.js +++ b/examples/3d/noiseTexture/simplex/basic/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../../dist/index.js?t=1770713934910"; /** * [KO] Simplex Noise (Basic) 예제 @@ -64,11 +64,11 @@ RedGPU.init( * @param {object} testData */ const renderTestPane = async (redGPUContext, targetNoiseTexture, testData) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { setSeparator, setDebugButtons - } = await import("../../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + } = await import("../../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); diff --git a/examples/3d/noiseTexture/simplex/displacement/index.html b/examples/3d/noiseTexture/simplex/displacement/index.html index c7c14d3dd..004b73e31 100644 --- a/examples/3d/noiseTexture/simplex/displacement/index.html +++ b/examples/3d/noiseTexture/simplex/displacement/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/3d/noiseTexture/simplex/displacement/index.js b/examples/3d/noiseTexture/simplex/displacement/index.js index 8435d8c08..b00d1ee51 100644 --- a/examples/3d/noiseTexture/simplex/displacement/index.js +++ b/examples/3d/noiseTexture/simplex/displacement/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../../dist/index.js?t=1770713934910"; /** * [KO] Simplex Noise (Displacement) 예제 @@ -85,11 +85,11 @@ RedGPU.init( * @param {object} testData */ const renderTestPane = async (redGPUContext, targetNoiseTexture, testData) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { setSeparator, setDebugButtons - } = await import("../../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + } = await import("../../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); diff --git a/examples/3d/noiseTexture/simplex/fire/index.html b/examples/3d/noiseTexture/simplex/fire/index.html index c7c14d3dd..004b73e31 100644 --- a/examples/3d/noiseTexture/simplex/fire/index.html +++ b/examples/3d/noiseTexture/simplex/fire/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/3d/noiseTexture/simplex/fire/index.js b/examples/3d/noiseTexture/simplex/fire/index.js index df4756f38..0e65f391b 100644 --- a/examples/3d/noiseTexture/simplex/fire/index.js +++ b/examples/3d/noiseTexture/simplex/fire/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../../dist/index.js?t=1770713934910"; /** * [KO] Simplex Noise (Fire) 예제 @@ -120,11 +120,11 @@ RedGPU.init( * @param {object} testData */ const renderTestPane = async (redGPUContext, targetNoiseTexture, testData) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { setSeparator, setDebugButtons - } = await import("../../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + } = await import("../../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); diff --git a/examples/3d/noiseTexture/voronoi/basic/index.html b/examples/3d/noiseTexture/voronoi/basic/index.html index c7c14d3dd..004b73e31 100644 --- a/examples/3d/noiseTexture/voronoi/basic/index.html +++ b/examples/3d/noiseTexture/voronoi/basic/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/3d/noiseTexture/voronoi/basic/index.js b/examples/3d/noiseTexture/voronoi/basic/index.js index 08aa4ac63..d8b32afc9 100644 --- a/examples/3d/noiseTexture/voronoi/basic/index.js +++ b/examples/3d/noiseTexture/voronoi/basic/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../../dist/index.js?t=1770713934910"; /** * [KO] Voronoi Noise (Basic) 예제 @@ -65,11 +65,11 @@ RedGPU.init( * @param {object} testData */ const renderTestPane = async (redGPUContext, targetNoiseTexture, testData) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { setSeparator, setDebugButtons - } = await import("../../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + } = await import("../../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); diff --git a/examples/3d/particle/basic/index.html b/examples/3d/particle/basic/index.html index 77d781697..91601ab7d 100644 --- a/examples/3d/particle/basic/index.html +++ b/examples/3d/particle/basic/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/particle/basic/index.js b/examples/3d/particle/basic/index.js index b481a98a9..215adc46e 100644 --- a/examples/3d/particle/basic/index.js +++ b/examples/3d/particle/basic/index.js @@ -1,5 +1,5 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; -import {setSeparator} from "../../../exampleHelper/createExample/panes/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; +import {setSeparator} from "../../../exampleHelper/createExample/panes/index.js?t=1770713934910"; // 1. Create and append a canvas // 1. 캔버스를 생성하고 문서에 추가 @@ -76,8 +76,8 @@ RedGPU.init( * @param {RedGPU.Display.ParticleEmitter} testParticle */ const renderTestPane = async (redGPUContext, testParticle) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); { diff --git a/examples/3d/particle/performance/index.html b/examples/3d/particle/performance/index.html index 77d781697..91601ab7d 100644 --- a/examples/3d/particle/performance/index.html +++ b/examples/3d/particle/performance/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/particle/performance/index.js b/examples/3d/particle/performance/index.js index 1c0c59e71..8836d0f6c 100644 --- a/examples/3d/particle/performance/index.js +++ b/examples/3d/particle/performance/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; // 1. Create and append a canvas // 1. 캔버스를 생성하고 문서에 추가 @@ -102,7 +102,7 @@ RedGPU.init( * @param {RedGPU.RedGPUContext} redGPUContext */ const renderTestPane = async (redGPUContext) => { - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext); }; \ No newline at end of file diff --git a/examples/3d/primitive/box/index.html b/examples/3d/primitive/box/index.html index 77d781697..91601ab7d 100644 --- a/examples/3d/primitive/box/index.html +++ b/examples/3d/primitive/box/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/primitive/box/index.js b/examples/3d/primitive/box/index.js index 193ea8b7f..8705fa5a4 100644 --- a/examples/3d/primitive/box/index.js +++ b/examples/3d/primitive/box/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; /** * [KO] Box Primitive 예제 @@ -104,8 +104,8 @@ const createPrimitive = (redGPUContext, scene) => { * @param {RedGPU.RedGPUContext} redGPUContext - [KO] RedGPU 컨텍스트 [EN] RedGPU context */ const renderTestPane = async (redGPUContext) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext) const pane = new Pane(); diff --git a/examples/3d/primitive/capsule/index.html b/examples/3d/primitive/capsule/index.html index 77d781697..91601ab7d 100644 --- a/examples/3d/primitive/capsule/index.html +++ b/examples/3d/primitive/capsule/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/primitive/capsule/index.js b/examples/3d/primitive/capsule/index.js index f18c60ffd..e52c07b6a 100644 --- a/examples/3d/primitive/capsule/index.js +++ b/examples/3d/primitive/capsule/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; /** * [KO] Capsule Primitive 예제 @@ -119,8 +119,8 @@ const createPrimitive = (redGPUContext, scene) => { * @param {RedGPU.RedGPUContext} redGPUContext - [KO] RedGPU 컨텍스트 [EN] RedGPU context */ const renderTestPane = async (redGPUContext) => { - const {Pane} = await import("https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827"); - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const {Pane} = await import("https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext) const pane = new Pane(); diff --git a/examples/3d/primitive/circle/index.html b/examples/3d/primitive/circle/index.html index 77d781697..91601ab7d 100644 --- a/examples/3d/primitive/circle/index.html +++ b/examples/3d/primitive/circle/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/primitive/circle/index.js b/examples/3d/primitive/circle/index.js index 8dec66c57..e0fb9f2f2 100644 --- a/examples/3d/primitive/circle/index.js +++ b/examples/3d/primitive/circle/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; /** * [KO] Circle Primitive 예제 @@ -104,8 +104,8 @@ const createPrimitive = (redGPUContext, scene) => { * @param {RedGPU.RedGPUContext} redGPUContext - [KO] RedGPU 컨텍스트 [EN] RedGPU context */ const renderTestPane = async (redGPUContext) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext) const pane = new Pane(); diff --git a/examples/3d/primitive/cylinder/index.html b/examples/3d/primitive/cylinder/index.html index 77d781697..91601ab7d 100644 --- a/examples/3d/primitive/cylinder/index.html +++ b/examples/3d/primitive/cylinder/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/primitive/cylinder/index.js b/examples/3d/primitive/cylinder/index.js index 8985b59b3..1240c26f1 100644 --- a/examples/3d/primitive/cylinder/index.js +++ b/examples/3d/primitive/cylinder/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; /** * [KO] Cylinder Primitive 예제 @@ -125,8 +125,8 @@ const createPrimitive = (redGPUContext, scene) => { * @param {RedGPU.RedGPUContext} redGPUContext - [KO] RedGPU 컨텍스트 [EN] RedGPU context */ const renderTestPane = async (redGPUContext) => { - const {Pane} = await import("https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827"); - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const {Pane} = await import("https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext) const pane = new Pane(); diff --git a/examples/3d/primitive/ground/index.html b/examples/3d/primitive/ground/index.html index 77d781697..91601ab7d 100644 --- a/examples/3d/primitive/ground/index.html +++ b/examples/3d/primitive/ground/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/primitive/ground/index.js b/examples/3d/primitive/ground/index.js index db6ee97f1..221ac0303 100644 --- a/examples/3d/primitive/ground/index.js +++ b/examples/3d/primitive/ground/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; /** * [KO] Ground Primitive 예제 @@ -117,9 +117,9 @@ const createPrimitive = (redGPUContext, scene) => { * @param {RedGPU.RedGPUContext} redGPUContext - [KO] RedGPU 컨텍스트 [EN] RedGPU context */ const renderTestPane = async (redGPUContext) => { - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext) - const {Pane} = await import("https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827"); + const {Pane} = await import("https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910"); const pane = new Pane(); const config = { diff --git a/examples/3d/primitive/plane/index.html b/examples/3d/primitive/plane/index.html index 77d781697..91601ab7d 100644 --- a/examples/3d/primitive/plane/index.html +++ b/examples/3d/primitive/plane/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/primitive/plane/index.js b/examples/3d/primitive/plane/index.js index 7a24ace7d..d54d012d4 100644 --- a/examples/3d/primitive/plane/index.js +++ b/examples/3d/primitive/plane/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; /** * [KO] Plane Primitive 예제 @@ -117,9 +117,9 @@ const createPrimitive = (redGPUContext, scene) => { * @param {RedGPU.RedGPUContext} redGPUContext - [KO] RedGPU 컨텍스트 [EN] RedGPU context */ const renderTestPane = async (redGPUContext) => { - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext) - const {Pane} = await import("https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827"); + const {Pane} = await import("https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910"); const pane = new Pane(); const config = { diff --git a/examples/3d/primitive/primitives/index.html b/examples/3d/primitive/primitives/index.html index 77d781697..91601ab7d 100644 --- a/examples/3d/primitive/primitives/index.html +++ b/examples/3d/primitive/primitives/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/primitive/primitives/index.js b/examples/3d/primitive/primitives/index.js index 464c03d42..a5ee6710a 100644 --- a/examples/3d/primitive/primitives/index.js +++ b/examples/3d/primitive/primitives/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; /** * [KO] Primitives 예제 @@ -146,7 +146,7 @@ const createPrimitive = (redGPUContext, scene) => { const renderTestPane = async (redGPUContext) => { const { setDebugButtons - } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext) }; diff --git a/examples/3d/primitive/sphere/index.html b/examples/3d/primitive/sphere/index.html index 77d781697..91601ab7d 100644 --- a/examples/3d/primitive/sphere/index.html +++ b/examples/3d/primitive/sphere/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/primitive/sphere/index.js b/examples/3d/primitive/sphere/index.js index c2fcf9937..3fbaa1ea2 100644 --- a/examples/3d/primitive/sphere/index.js +++ b/examples/3d/primitive/sphere/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; /** * [KO] Sphere Primitive 예제 @@ -125,8 +125,8 @@ const createPrimitive = (redGPUContext, scene) => { * @param {RedGPU.RedGPUContext} redGPUContext - [KO] RedGPU 컨텍스트 [EN] RedGPU context */ const renderTestPane = async (redGPUContext) => { - const {Pane} = await import("https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827"); - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const {Pane} = await import("https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext) const pane = new Pane(); diff --git a/examples/3d/primitive/torus/index.html b/examples/3d/primitive/torus/index.html index 77d781697..91601ab7d 100644 --- a/examples/3d/primitive/torus/index.html +++ b/examples/3d/primitive/torus/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/primitive/torus/index.js b/examples/3d/primitive/torus/index.js index ab8a737b8..63b510b9f 100644 --- a/examples/3d/primitive/torus/index.js +++ b/examples/3d/primitive/torus/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; /** * [KO] Torus Primitive 예제 @@ -121,9 +121,9 @@ const createPrimitive = (redGPUContext, scene) => { * @param {RedGPU.RedGPUContext} redGPUContext - [KO] RedGPU 컨텍스트 [EN] RedGPU context */ const renderTestPane = async (redGPUContext) => { - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext) - const {Pane} = await import("https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827"); + const {Pane} = await import("https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910"); const pane = new Pane(); const config = { diff --git a/examples/3d/primitive/torusNut/index.html b/examples/3d/primitive/torusNut/index.html index 77d781697..91601ab7d 100644 --- a/examples/3d/primitive/torusNut/index.html +++ b/examples/3d/primitive/torusNut/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/primitive/torusNut/index.js b/examples/3d/primitive/torusNut/index.js index 2837c5cc9..a9ba681b6 100644 --- a/examples/3d/primitive/torusNut/index.js +++ b/examples/3d/primitive/torusNut/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; /** * [KO] TorusKnot Primitive 예제 @@ -121,9 +121,9 @@ const createPrimitive = (redGPUContext, scene) => { * @param {RedGPU.RedGPUContext} redGPUContext - [KO] RedGPU 컨텍스트 [EN] RedGPU context */ const renderTestPane = async (redGPUContext) => { - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext) - const {Pane} = await import("https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827"); + const {Pane} = await import("https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910"); const pane = new Pane(); const config = { diff --git a/examples/3d/scene/index.html b/examples/3d/scene/index.html index b3924120d..a61628df1 100644 --- a/examples/3d/scene/index.html +++ b/examples/3d/scene/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/scene/index.js b/examples/3d/scene/index.js index d8d8bb34a..6ddfd2d8f 100644 --- a/examples/3d/scene/index.js +++ b/examples/3d/scene/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../dist/index.js?t=1770713934910"; /** * [KO] Scene 예제 @@ -51,13 +51,13 @@ RedGPU.init( * @param {RedGPU.RedGPUContext} redGPUContext */ const renderTestPane = async (redGPUContext) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { setRedGPUTest_pane, setViewListTest, setSceneListTest, setDebugButtons - } = await import("../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + } = await import("../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext) const pane = new Pane(); setSceneListTest(pane, redGPUContext.viewList.flatMap(v => v.scene), true); diff --git a/examples/3d/shadow/directionalShadow/index.html b/examples/3d/shadow/directionalShadow/index.html index 77d781697..91601ab7d 100644 --- a/examples/3d/shadow/directionalShadow/index.html +++ b/examples/3d/shadow/directionalShadow/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/shadow/directionalShadow/index.js b/examples/3d/shadow/directionalShadow/index.js index 5103ddb2e..b140e4806 100644 --- a/examples/3d/shadow/directionalShadow/index.js +++ b/examples/3d/shadow/directionalShadow/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; /** * [KO] Directional Shadow 예제 @@ -135,8 +135,8 @@ const getRandomHexValue = () => { * @param {RedGPU.Display.Scene} scene */ const renderTestPane = async (redGPUContext, scene) => { - const {Pane} = await import("https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827"); - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const {Pane} = await import("https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); const {shadowManager} = scene; diff --git a/examples/3d/shadow/gltfDirectionalShadow/index.html b/examples/3d/shadow/gltfDirectionalShadow/index.html index 77d781697..91601ab7d 100644 --- a/examples/3d/shadow/gltfDirectionalShadow/index.html +++ b/examples/3d/shadow/gltfDirectionalShadow/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/shadow/gltfDirectionalShadow/index.js b/examples/3d/shadow/gltfDirectionalShadow/index.js index eb39c1670..11008a944 100644 --- a/examples/3d/shadow/gltfDirectionalShadow/index.js +++ b/examples/3d/shadow/gltfDirectionalShadow/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; /** * [KO] GLTF Directional Shadow 예제 @@ -99,10 +99,10 @@ const addGround = (redGPUContext, scene) => { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import("https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827"); - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const {Pane} = await import("https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext); - const {createIblHelper} = await import('../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); + const {createIblHelper} = await import('../../../exampleHelper/createExample/panes/index.js?t=1770713934910'); const pane = new Pane(); const {shadowManager} = targetView.scene; diff --git a/examples/3d/skybox/ibl/brdfLutTest/index.html b/examples/3d/skybox/ibl/brdfLutTest/index.html index beec74561..7167dc454 100644 --- a/examples/3d/skybox/ibl/brdfLutTest/index.html +++ b/examples/3d/skybox/ibl/brdfLutTest/index.html @@ -7,8 +7,8 @@ - - + + diff --git a/examples/3d/skybox/ibl/brdfLutTest/index.js b/examples/3d/skybox/ibl/brdfLutTest/index.js index f52e1e4c2..915145bc5 100644 --- a/examples/3d/skybox/ibl/brdfLutTest/index.js +++ b/examples/3d/skybox/ibl/brdfLutTest/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../../dist/index.js?t=1770713934910"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); diff --git a/examples/3d/skybox/ibl/iblTest/index.html b/examples/3d/skybox/ibl/iblTest/index.html index ea0e3b2db..1886d0819 100644 --- a/examples/3d/skybox/ibl/iblTest/index.html +++ b/examples/3d/skybox/ibl/iblTest/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/skybox/ibl/iblTest/index.js b/examples/3d/skybox/ibl/iblTest/index.js index d56fb204a..a3a744a6d 100644 --- a/examples/3d/skybox/ibl/iblTest/index.js +++ b/examples/3d/skybox/ibl/iblTest/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../../dist/index.js?t=1770713934910"; /** * [KO] IBL Test 예제 @@ -146,13 +146,13 @@ const createIBL = (view, src) => { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (targetView) => { - const {Pane} = await import( "https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827" ); + const {Pane} = await import( "https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910" ); const pane = new Pane(); const { createFieldOfView, createSkyBoxHelper, setDebugButtons - } = await import( "../../../../exampleHelper/createExample/panes/index.js?t=1770699661827" ); + } = await import( "../../../../exampleHelper/createExample/panes/index.js?t=1770713934910" ); setDebugButtons(RedGPU, targetView.redGPUContext); createFieldOfView(pane, targetView.camera) createSkyBoxHelper(pane, targetView); diff --git a/examples/3d/skybox/ibl/iblTextureSize/index.html b/examples/3d/skybox/ibl/iblTextureSize/index.html index 2b934b837..3387b9c57 100644 --- a/examples/3d/skybox/ibl/iblTextureSize/index.html +++ b/examples/3d/skybox/ibl/iblTextureSize/index.html @@ -8,8 +8,8 @@ - - + +
diff --git a/examples/3d/skybox/ibl/iblTextureSize/index.js b/examples/3d/skybox/ibl/iblTextureSize/index.js index 5073f6c7a..0ed0d0119 100644 --- a/examples/3d/skybox/ibl/iblTextureSize/index.js +++ b/examples/3d/skybox/ibl/iblTextureSize/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../../dist/index.js?t=1770713934910"; // 1. Create and append a canvas // 1. 캔버스를 생성하고 문서에 추가 @@ -144,9 +144,9 @@ function loadGLTF(redGPUContext, scene, url) { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); - const {createPostEffectLabel} = await import('../../../../exampleHelper/createExample/loadExampleInfo/createPostEffectLabel.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); + const {createPostEffectLabel} = await import('../../../../exampleHelper/createExample/loadExampleInfo/createPostEffectLabel.js?t=1770713934910'); createPostEffectLabel('Custom IBL Texture Size 16 * 16', redGPUContext.detector.isMobile, 'Basic IBL Texture Size 512 * 512') - const {setDebugButtons} = await import( "../../../../exampleHelper/createExample/panes/index.js?t=1770699661827" ); + const {setDebugButtons} = await import( "../../../../exampleHelper/createExample/panes/index.js?t=1770713934910" ); setDebugButtons(RedGPU, redGPUContext); }; \ No newline at end of file diff --git a/examples/3d/skybox/ibl/irradianceTest/index.html b/examples/3d/skybox/ibl/irradianceTest/index.html index beec74561..7167dc454 100644 --- a/examples/3d/skybox/ibl/irradianceTest/index.html +++ b/examples/3d/skybox/ibl/irradianceTest/index.html @@ -7,8 +7,8 @@ - - + + diff --git a/examples/3d/skybox/ibl/irradianceTest/index.js b/examples/3d/skybox/ibl/irradianceTest/index.js index fca3592f1..5ec4e54a0 100644 --- a/examples/3d/skybox/ibl/irradianceTest/index.js +++ b/examples/3d/skybox/ibl/irradianceTest/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../../dist/index.js?t=1770713934910"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -55,6 +55,6 @@ RedGPU.init( ); const renderTestPane = async (redGPUContext, scene, hdrTexture) => { - const {setDebugButtons} = await import("../../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const {setDebugButtons} = await import("../../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext); }; \ No newline at end of file diff --git a/examples/3d/skybox/ibl/skyboxWithIbl/index.html b/examples/3d/skybox/ibl/skyboxWithIbl/index.html index ea0e3b2db..1886d0819 100644 --- a/examples/3d/skybox/ibl/skyboxWithIbl/index.html +++ b/examples/3d/skybox/ibl/skyboxWithIbl/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/skybox/ibl/skyboxWithIbl/index.js b/examples/3d/skybox/ibl/skyboxWithIbl/index.js index 1d72bcec8..0f6290380 100644 --- a/examples/3d/skybox/ibl/skyboxWithIbl/index.js +++ b/examples/3d/skybox/ibl/skyboxWithIbl/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../../dist/index.js?t=1770713934910"; /** * [KO] Skybox With IBL 예제 @@ -42,13 +42,13 @@ RedGPU.init( * @param {RedGPU.Display.View3D} view */ const renderTestPane = async (view) => { - const {Pane} = await import( "https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827" ); + const {Pane} = await import( "https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910" ); const pane = new Pane(); const { createFieldOfView, createIblHelper, setDebugButtons - } = await import( "../../../../exampleHelper/createExample/panes/index.js?t=1770699661827" ); + } = await import( "../../../../exampleHelper/createExample/panes/index.js?t=1770713934910" ); setDebugButtons(RedGPU, view.redGPUContext); createFieldOfView(pane, view.camera); createIblHelper(pane, view, RedGPU); diff --git a/examples/3d/skybox/skybox/index.html b/examples/3d/skybox/skybox/index.html index 77d781697..91601ab7d 100644 --- a/examples/3d/skybox/skybox/index.html +++ b/examples/3d/skybox/skybox/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/skybox/skybox/index.js b/examples/3d/skybox/skybox/index.js index c7c2454fe..6f6983073 100644 --- a/examples/3d/skybox/skybox/index.js +++ b/examples/3d/skybox/skybox/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; /** * [KO] Skybox 예제 @@ -65,13 +65,13 @@ const createSkybox = (redGPUContext) => { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (targetView) => { - const {Pane} = await import( "https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827" ); + const {Pane} = await import( "https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910" ); const pane = new Pane(); const { createFieldOfView, createSkyBoxHelper, setDebugButtons - } = await import( "../../../exampleHelper/createExample/panes/index.js?t=1770699661827" ); + } = await import( "../../../exampleHelper/createExample/panes/index.js?t=1770713934910" ); setDebugButtons(RedGPU, targetView.redGPUContext); createFieldOfView(pane, targetView.camera) createSkyBoxHelper(pane, targetView) diff --git a/examples/3d/skybox/transition/skyboxTransition/index.html b/examples/3d/skybox/transition/skyboxTransition/index.html index c7c14d3dd..004b73e31 100644 --- a/examples/3d/skybox/transition/skyboxTransition/index.html +++ b/examples/3d/skybox/transition/skyboxTransition/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/3d/skybox/transition/skyboxTransition/index.js b/examples/3d/skybox/transition/skyboxTransition/index.js index b176dfe03..3aa7a890c 100644 --- a/examples/3d/skybox/transition/skyboxTransition/index.js +++ b/examples/3d/skybox/transition/skyboxTransition/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../../dist/index.js?t=1770713934910"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -98,12 +98,12 @@ const createTexture = (redGPUContext, option) => { * @param {RedGPU.RedGPUContext} redGPUContext */ const renderTestPane = async (targetView, redGPUContext) => { - const {Pane} = await import("https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827"); + const {Pane} = await import("https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910"); const pane = new Pane(); const { createFieldOfView, createSkyBoxHelper - } = await import("../../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + } = await import("../../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); createFieldOfView(pane, targetView.camera); createSkyBoxHelper(pane, targetView); diff --git a/examples/3d/skybox/transition/skyboxTransitionWithNoiseTexture/index.html b/examples/3d/skybox/transition/skyboxTransitionWithNoiseTexture/index.html index c7c14d3dd..004b73e31 100644 --- a/examples/3d/skybox/transition/skyboxTransitionWithNoiseTexture/index.html +++ b/examples/3d/skybox/transition/skyboxTransitionWithNoiseTexture/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/3d/skybox/transition/skyboxTransitionWithNoiseTexture/index.js b/examples/3d/skybox/transition/skyboxTransitionWithNoiseTexture/index.js index cbf3a549f..0f56e783f 100644 --- a/examples/3d/skybox/transition/skyboxTransitionWithNoiseTexture/index.js +++ b/examples/3d/skybox/transition/skyboxTransitionWithNoiseTexture/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../../dist/index.js?t=1770713934910"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -100,13 +100,13 @@ const createTexture = (redGPUContext, option) => { * @param {RedGPU.RedGPUContext} redGPUContext */ const renderTestPane = async (targetView, redGPUContext) => { - const {Pane} = await import("https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827"); + const {Pane} = await import("https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910"); const pane = new Pane(); const { createFieldOfView, setSeparator, createSkyBoxHelper - } = await import("../../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + } = await import("../../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); createFieldOfView(pane, targetView.camera); createSkyBoxHelper(pane, targetView); diff --git a/examples/3d/sprite/sprite3D/index.html b/examples/3d/sprite/sprite3D/index.html index 77d781697..91601ab7d 100644 --- a/examples/3d/sprite/sprite3D/index.html +++ b/examples/3d/sprite/sprite3D/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/sprite/sprite3D/index.js b/examples/3d/sprite/sprite3D/index.js index 4ee2d7106..10954b5d5 100644 --- a/examples/3d/sprite/sprite3D/index.js +++ b/examples/3d/sprite/sprite3D/index.js @@ -6,7 +6,7 @@ * [EN] Demonstrates the usage of Sprite3D in 3D space, including features like billboard and pixel size modes. * @packageDocumentation */ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -107,11 +107,11 @@ RedGPU.init( * [EN] Scene containing the sprites to control */ const renderTestPane = async (redGPUContext, scene) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { setDebugButtons, setSeparator - } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); diff --git a/examples/3d/sprite/sprite3DCompare/index.html b/examples/3d/sprite/sprite3DCompare/index.html index 3ac178d0f..8325a9b15 100644 --- a/examples/3d/sprite/sprite3DCompare/index.html +++ b/examples/3d/sprite/sprite3DCompare/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/sprite/sprite3DCompare/index.js b/examples/3d/sprite/sprite3DCompare/index.js index 17a5986ec..93371392e 100644 --- a/examples/3d/sprite/sprite3DCompare/index.js +++ b/examples/3d/sprite/sprite3DCompare/index.js @@ -6,7 +6,7 @@ * [EN] Demonstrates the difference between World Size (worldSize) and fixed Pixel Size (pixelSize) modes. * @packageDocumentation */ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -79,8 +79,8 @@ RedGPU.init(canvas, (redGPUContext) => { }); const renderTestPane = async (redGPUContext, spriteWorld, spritePixel) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); diff --git a/examples/3d/sprite/spriteSheet3D/index.html b/examples/3d/sprite/spriteSheet3D/index.html index 77d781697..91601ab7d 100644 --- a/examples/3d/sprite/spriteSheet3D/index.html +++ b/examples/3d/sprite/spriteSheet3D/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/sprite/spriteSheet3D/index.js b/examples/3d/sprite/spriteSheet3D/index.js index 118c8727a..83bea3824 100644 --- a/examples/3d/sprite/spriteSheet3D/index.js +++ b/examples/3d/sprite/spriteSheet3D/index.js @@ -6,7 +6,7 @@ * [EN] Demonstrates the usage of SpriteSheet3D in 3D space, including features like billboard and pixel size modes. * @packageDocumentation */ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -86,11 +86,11 @@ RedGPU.init(canvas, (redGPUContext) => { * [EN] Scene containing the sprites to control */ const renderTestPane = async (redGPUContext, scene) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { setDebugButtons, setSeparator - } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); diff --git a/examples/3d/sprite/spriteSheet3DCompare/index.html b/examples/3d/sprite/spriteSheet3DCompare/index.html index 0f3965117..5dcbcaf8e 100644 --- a/examples/3d/sprite/spriteSheet3DCompare/index.html +++ b/examples/3d/sprite/spriteSheet3DCompare/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/sprite/spriteSheet3DCompare/index.js b/examples/3d/sprite/spriteSheet3DCompare/index.js index 01b37e207..acf74cbc4 100644 --- a/examples/3d/sprite/spriteSheet3DCompare/index.js +++ b/examples/3d/sprite/spriteSheet3DCompare/index.js @@ -6,7 +6,7 @@ * [EN] Demonstrates the difference between World Size (worldSize) and fixed Pixel Size (pixelSize) modes. * @packageDocumentation */ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -89,8 +89,8 @@ RedGPU.init(canvas, (redGPUContext) => { }); const renderTestPane = async (redGPUContext, worldSprite, pixelSprite) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); diff --git a/examples/3d/textField/textField3D/index.html b/examples/3d/textField/textField3D/index.html index 0f3965117..5dcbcaf8e 100644 --- a/examples/3d/textField/textField3D/index.html +++ b/examples/3d/textField/textField3D/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/textField/textField3D/index.js b/examples/3d/textField/textField3D/index.js index 0affe66f9..8a3949cc2 100644 --- a/examples/3d/textField/textField3D/index.js +++ b/examples/3d/textField/textField3D/index.js @@ -6,7 +6,7 @@ * [EN] Demonstrates the usage of TextField3D in 3D space, including features like billboard and styling. * @packageDocumentation */ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -84,8 +84,8 @@ RedGPU.init(canvas, (redGPUContext) => { * [EN] Scene containing the text fields to control */ const renderTestPane = async (redGPUContext, scene) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); - const {setDebugButtons, setSeparator} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); + const {setDebugButtons, setSeparator} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); diff --git a/examples/3d/textField/textField3DCompare/index.html b/examples/3d/textField/textField3DCompare/index.html index 0f3965117..5dcbcaf8e 100644 --- a/examples/3d/textField/textField3DCompare/index.html +++ b/examples/3d/textField/textField3DCompare/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/textField/textField3DCompare/index.js b/examples/3d/textField/textField3DCompare/index.js index 27ed5d647..633c432d2 100644 --- a/examples/3d/textField/textField3DCompare/index.js +++ b/examples/3d/textField/textField3DCompare/index.js @@ -6,7 +6,7 @@ * [EN] Demonstrates the difference between World Size (worldSize) and fixed Pixel Size (usePixelSize) modes for TextField3D. * @packageDocumentation */ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -56,8 +56,8 @@ RedGPU.init( ); const renderTestPane = async (redGPUContext, textWorld, textPixel) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); diff --git a/examples/3d/texture/bitmapTextureSampler/index.html b/examples/3d/texture/bitmapTextureSampler/index.html index 77d781697..91601ab7d 100644 --- a/examples/3d/texture/bitmapTextureSampler/index.html +++ b/examples/3d/texture/bitmapTextureSampler/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/texture/bitmapTextureSampler/index.js b/examples/3d/texture/bitmapTextureSampler/index.js index f345d899d..ea7654eb8 100644 --- a/examples/3d/texture/bitmapTextureSampler/index.js +++ b/examples/3d/texture/bitmapTextureSampler/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; /** * [KO] Bitmap Texture Sampler 예제 @@ -70,11 +70,11 @@ const addSingleMesh = (redGPUContext, scene) => { * @param {RedGPU.Display.Mesh} mesh */ const renderTestPane = async (redGPUContext, mesh) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { setSeparator, setDebugButtons - } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); diff --git a/examples/3d/texture/maxAnisotropy/index.html b/examples/3d/texture/maxAnisotropy/index.html index 77d781697..91601ab7d 100644 --- a/examples/3d/texture/maxAnisotropy/index.html +++ b/examples/3d/texture/maxAnisotropy/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/texture/maxAnisotropy/index.js b/examples/3d/texture/maxAnisotropy/index.js index 9fd8eaa14..ce5c2e45b 100644 --- a/examples/3d/texture/maxAnisotropy/index.js +++ b/examples/3d/texture/maxAnisotropy/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; /** * [KO] Max Anisotropy 예제 @@ -50,7 +50,7 @@ const renderTestPane = async (redGPUContext, scene) => { const { setSeparator, setDebugButtons - } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext); const maxAnisotropyValues = [1, 8, 16]; const spacing = 105; diff --git a/examples/3d/texture/samplerAddressMode/index.html b/examples/3d/texture/samplerAddressMode/index.html index 77d781697..91601ab7d 100644 --- a/examples/3d/texture/samplerAddressMode/index.html +++ b/examples/3d/texture/samplerAddressMode/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/texture/samplerAddressMode/index.js b/examples/3d/texture/samplerAddressMode/index.js index c2f00a240..0214f2907 100644 --- a/examples/3d/texture/samplerAddressMode/index.js +++ b/examples/3d/texture/samplerAddressMode/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; /** * [KO] Sampler Address Mode 예제 @@ -53,7 +53,7 @@ const renderTestPane = async (redGPUContext,) => { const { setSeparator, setDebugButtons - } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext); } diff --git a/examples/3d/texture/samplerCombination/index.html b/examples/3d/texture/samplerCombination/index.html index 77d781697..91601ab7d 100644 --- a/examples/3d/texture/samplerCombination/index.html +++ b/examples/3d/texture/samplerCombination/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/texture/samplerCombination/index.js b/examples/3d/texture/samplerCombination/index.js index cde880f87..9797d79d2 100644 --- a/examples/3d/texture/samplerCombination/index.js +++ b/examples/3d/texture/samplerCombination/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; /** * [KO] Sampler Combination 예제 @@ -54,7 +54,7 @@ const renderTestPane = async (redGPUContext,) => { const { setSeparator, setDebugButtons - } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext); } diff --git a/examples/3d/tint/basic/index.html b/examples/3d/tint/basic/index.html index 77d781697..91601ab7d 100644 --- a/examples/3d/tint/basic/index.html +++ b/examples/3d/tint/basic/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/tint/basic/index.js b/examples/3d/tint/basic/index.js index ba8d367c1..95ba26138 100644 --- a/examples/3d/tint/basic/index.js +++ b/examples/3d/tint/basic/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; /** * [KO] Tint Basic (3D) 예제 @@ -70,9 +70,9 @@ RedGPU.init( * @param {RedGPU.Display.Mesh} mesh */ const renderTestPane = async (redGPUContext, mesh) => { - const {Pane} = await import("https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827"); + const {Pane} = await import("https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910"); const pane = new Pane(); - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext); // Tint 테스트 추가 const folder = pane.addFolder({title: "Material Tint Test"}); diff --git a/examples/3d/transparentSort/index.html b/examples/3d/transparentSort/index.html index b3924120d..a61628df1 100644 --- a/examples/3d/transparentSort/index.html +++ b/examples/3d/transparentSort/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/transparentSort/index.js b/examples/3d/transparentSort/index.js index 26df92dcc..551abfb0d 100644 --- a/examples/3d/transparentSort/index.js +++ b/examples/3d/transparentSort/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../dist/index.js?t=1770713934910"; /** * [KO] Transparent Sort 예제 @@ -131,9 +131,9 @@ const getRandomHexValue = () => { */ const renderTestPane = async (redGPUContext) => { const {Pane} = await import( - "https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827" + "https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910" ); - const {setDebugButtons} = await import( "../../exampleHelper/createExample/panes/index.js?t=1770699661827" ); + const {setDebugButtons} = await import( "../../exampleHelper/createExample/panes/index.js?t=1770713934910" ); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); const params = { diff --git a/examples/3d/view/multiView/index.html b/examples/3d/view/multiView/index.html index 77d781697..91601ab7d 100644 --- a/examples/3d/view/multiView/index.html +++ b/examples/3d/view/multiView/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/3d/view/multiView/index.js b/examples/3d/view/multiView/index.js index c35e3312d..ed73d197d 100644 --- a/examples/3d/view/multiView/index.js +++ b/examples/3d/view/multiView/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; /** * [KO] Multi View 예제 @@ -101,11 +101,11 @@ RedGPU.init( * @param {RedGPU.RedGPUContext} redGPUContext */ const renderTestPane = async (redGPUContext) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { setViewListTest, setDebugButtons - } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext) const pane = new Pane(); setViewListTest(pane, redGPUContext.viewList, true); diff --git a/examples/3d/view/singleView/index.html b/examples/3d/view/singleView/index.html index a6887ba00..e648c97f0 100644 --- a/examples/3d/view/singleView/index.html +++ b/examples/3d/view/singleView/index.html @@ -7,8 +7,8 @@ - - + + diff --git a/examples/3d/view/singleView/index.js b/examples/3d/view/singleView/index.js index 0bbb0ec52..29f958faf 100644 --- a/examples/3d/view/singleView/index.js +++ b/examples/3d/view/singleView/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; /** * [KO] Single View 예제 @@ -70,11 +70,11 @@ RedGPU.init( * @param {RedGPU.RedGPUContext} redGPUContext */ const renderTestPane = async (redGPUContext) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { setViewListTest, setDebugButtons - } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + } = await import("../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext) const pane = new Pane(); setViewListTest(pane, redGPUContext.viewList, true); diff --git a/examples/exampleHelper/createExample/loadExampleInfo/index.js b/examples/exampleHelper/createExample/loadExampleInfo/index.js index 34d03d22d..e37d270c3 100644 --- a/examples/exampleHelper/createExample/loadExampleInfo/index.js +++ b/examples/exampleHelper/createExample/loadExampleInfo/index.js @@ -1,6 +1,6 @@ -const codeSrc = 'index.js?t=1770699661827'; +const codeSrc = 'index.js?t=1770713934910'; const prismCSS = 'https://cdnjs.cloudflare.com/ajax/libs/prism/1.29.0/themes/prism-tomorrow.min.css'; -const prismJS = 'https://cdnjs.cloudflare.com/ajax/libs/prism/1.29.0/prism.min.js?t=1770699661827'; +const prismJS = 'https://cdnjs.cloudflare.com/ajax/libs/prism/1.29.0/prism.min.js?t=1770713934910'; const loadPrism = async () => { if (!document.querySelector(`link[href="${prismCSS}"]`)) { @@ -27,7 +27,7 @@ const loadDescription = async () => { const mainCategory = getCategoryFromPath(currentFullPath); - const ExampleList = await import('../../exampleList/exampleList.js?t=1770699661827'); + const ExampleList = await import('../../exampleList/exampleList.js?t=1770713934910'); const categoryData = ExampleList.default.find(category => category.name.toLowerCase() === mainCategory); if (!categoryData) { diff --git a/examples/exampleHelper/createExample/panes/createIblHelper.js b/examples/exampleHelper/createExample/panes/createIblHelper.js index 58ee730f7..1720a1dda 100644 --- a/examples/exampleHelper/createExample/panes/createIblHelper.js +++ b/examples/exampleHelper/createExample/panes/createIblHelper.js @@ -1,5 +1,5 @@ -import {hdrImages} from './index.js?t=1770699661827'; -import createSkyBoxHelper from './createSkyBoxHelper.js?t=1770699661827'; +import {hdrImages} from './index.js?t=1770713934910'; +import createSkyBoxHelper from './createSkyBoxHelper.js?t=1770713934910'; const createIblHelper = (pane, view, RedGPU, option = {}) => { const folder = pane.addFolder({title: 'Lighting', expanded: true}); diff --git a/examples/exampleHelper/createExample/panes/index.js b/examples/exampleHelper/createExample/panes/index.js index 7301d66e1..09805a690 100644 --- a/examples/exampleHelper/createExample/panes/index.js +++ b/examples/exampleHelper/createExample/panes/index.js @@ -1,16 +1,16 @@ -import createBitmapTextureTest from "./createBitmapTextureTest.js?t=1770699661827"; -import createCameraTest from "./createCameraTest.js?t=1770699661827"; -import createFieldOfView from "./createFieldOfView.js?t=1770699661827"; -import createGridTest from "./createGridTest.js?t=1770699661827"; -import createIblHelper from "./createIblHelper.js?t=1770699661827"; -import createSkyBoxHelper from "./createSkyBoxHelper.js?t=1770699661827"; -import setSceneListTest from "./scene/setSceneListTest.js?t=1770699661827"; -import setSingleSceneTest from "./scene/setSingleSceneTest.js?t=1770699661827"; -import setAntialiasing_pane from "./setAntialiasing_pane.js?t=1770699661827"; -import setRedGPUTest_pane from "./setRedGPUTest_pane.js?t=1770699661827"; -import setSingleViewTest from "./view/setSingleViewTest.js?t=1770699661827"; -import setViewListTest from "./view/setViewListTest.js?t=1770699661827"; -import setViewListTest_Pane from "./view/setViewListTest.js?t=1770699661827"; +import createBitmapTextureTest from "./createBitmapTextureTest.js?t=1770713934910"; +import createCameraTest from "./createCameraTest.js?t=1770713934910"; +import createFieldOfView from "./createFieldOfView.js?t=1770713934910"; +import createGridTest from "./createGridTest.js?t=1770713934910"; +import createIblHelper from "./createIblHelper.js?t=1770713934910"; +import createSkyBoxHelper from "./createSkyBoxHelper.js?t=1770713934910"; +import setSceneListTest from "./scene/setSceneListTest.js?t=1770713934910"; +import setSingleSceneTest from "./scene/setSingleSceneTest.js?t=1770713934910"; +import setAntialiasing_pane from "./setAntialiasing_pane.js?t=1770713934910"; +import setRedGPUTest_pane from "./setRedGPUTest_pane.js?t=1770713934910"; +import setSingleViewTest from "./view/setSingleViewTest.js?t=1770713934910"; +import setViewListTest from "./view/setViewListTest.js?t=1770713934910"; +import setViewListTest_Pane from "./view/setViewListTest.js?t=1770713934910"; /** * Sets a separator in the given pane. diff --git a/examples/exampleHelper/createExample/panes/scene/setSceneListTest.js b/examples/exampleHelper/createExample/panes/scene/setSceneListTest.js index 35e1ede4b..7b6953496 100644 --- a/examples/exampleHelper/createExample/panes/scene/setSceneListTest.js +++ b/examples/exampleHelper/createExample/panes/scene/setSceneListTest.js @@ -1,4 +1,4 @@ -import {setSingleSceneTest} from "../index.js?t=1770699661827"; +import {setSingleSceneTest} from "../index.js?t=1770713934910"; const setSceneListTest = (pane, sceneList, shouldExpand = false,) => { const title = sceneList.length === 1 ? sceneList[0].name : 'sceneList'; diff --git a/examples/exampleHelper/createExample/panes/view/setSingleViewTest.js b/examples/exampleHelper/createExample/panes/view/setSingleViewTest.js index 56bea0b65..68f0a2e9f 100644 --- a/examples/exampleHelper/createExample/panes/view/setSingleViewTest.js +++ b/examples/exampleHelper/createExample/panes/view/setSingleViewTest.js @@ -1,4 +1,4 @@ -import setSingleSceneTest from "../scene/setSingleSceneTest.js?t=1770699661827"; +import setSingleSceneTest from "../scene/setSingleSceneTest.js?t=1770713934910"; const PERCENT_MAX = 200; const PIXEL_MAX = 2048; diff --git a/examples/exampleHelper/createExample/panes/view/setViewListTest.js b/examples/exampleHelper/createExample/panes/view/setViewListTest.js index c0ebcc362..0a261bc5e 100644 --- a/examples/exampleHelper/createExample/panes/view/setViewListTest.js +++ b/examples/exampleHelper/createExample/panes/view/setViewListTest.js @@ -1,4 +1,4 @@ -import {setSingleViewTest} from "../index.js?t=1770699661827"; +import {setSingleViewTest} from "../index.js?t=1770713934910"; const setViewListTest = (pane, viewList, shouldExpand = false, camera2DYn = false) => { const title = viewList.length === 1 ? viewList[0].name : 'ViewList'; diff --git a/examples/exampleHelper/exampleList/createExampleList.js b/examples/exampleHelper/exampleList/createExampleList.js index 70186dbbe..e809f66c8 100644 --- a/examples/exampleHelper/exampleList/createExampleList.js +++ b/examples/exampleHelper/exampleList/createExampleList.js @@ -1,4 +1,4 @@ -import ExampleList from './exampleList.js?t=1770699661827'; +import ExampleList from './exampleList.js?t=1770713934910'; // 상태 관리 - sessionStorage에 저장/복원할 항목들 const STATE_KEY = 'redgpu_examples_state'; diff --git a/examples/exampleHelper/indexSample.html b/examples/exampleHelper/indexSample.html index 23a4dec82..4b7812b85 100644 --- a/examples/exampleHelper/indexSample.html +++ b/examples/exampleHelper/indexSample.html @@ -22,7 +22,7 @@ - + + diff --git a/examples/gltf/animation/basicAnimations/index.js b/examples/gltf/animation/basicAnimations/index.js index c68035eb9..abee1063e 100644 --- a/examples/gltf/animation/basicAnimations/index.js +++ b/examples/gltf/animation/basicAnimations/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; import { loadingProgressInfoHandler -} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' +} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770713934910' /** * [KO] Basic Animations 예제 @@ -89,11 +89,11 @@ function loadGLTFGrid(view, urls, gridSize = 5, spacing = 5) { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { createIblHelper, setDebugButtons - } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); + } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770713934910'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/animation/brainStem/index.html b/examples/gltf/animation/brainStem/index.html index 77d781697..91601ab7d 100644 --- a/examples/gltf/animation/brainStem/index.html +++ b/examples/gltf/animation/brainStem/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/gltf/animation/brainStem/index.js b/examples/gltf/animation/brainStem/index.js index 064a598a3..eda168ae2 100644 --- a/examples/gltf/animation/brainStem/index.js +++ b/examples/gltf/animation/brainStem/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; /** * [KO] BrainStem 예제 @@ -62,11 +62,11 @@ function loadGLTF(view, url) { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { createIblHelper, setDebugButtons - } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); + } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770713934910'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/animation/cesiumMan/index.html b/examples/gltf/animation/cesiumMan/index.html index 77d781697..91601ab7d 100644 --- a/examples/gltf/animation/cesiumMan/index.html +++ b/examples/gltf/animation/cesiumMan/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/gltf/animation/cesiumMan/index.js b/examples/gltf/animation/cesiumMan/index.js index be3ab60c3..996350e03 100644 --- a/examples/gltf/animation/cesiumMan/index.js +++ b/examples/gltf/animation/cesiumMan/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; import { loadingProgressInfoHandler -} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' +} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770713934910' /** * [KO] CesiumMan 예제 @@ -99,11 +99,11 @@ function loadGLTFGrid(view, urls, gridSize = 3, spacing = 3) { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { createIblHelper, setDebugButtons - } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); + } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770713934910'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/animation/interpolationTest/index.html b/examples/gltf/animation/interpolationTest/index.html index 77d781697..91601ab7d 100644 --- a/examples/gltf/animation/interpolationTest/index.html +++ b/examples/gltf/animation/interpolationTest/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/gltf/animation/interpolationTest/index.js b/examples/gltf/animation/interpolationTest/index.js index f87339b5a..dd10822e4 100644 --- a/examples/gltf/animation/interpolationTest/index.js +++ b/examples/gltf/animation/interpolationTest/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; /** * [KO] Interpolation Test 예제 @@ -63,11 +63,11 @@ function loadGLTF(view, url) { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { createIblHelper, setDebugButtons - } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); + } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770713934910'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/animation/morphStressTest/index.html b/examples/gltf/animation/morphStressTest/index.html index 77d781697..91601ab7d 100644 --- a/examples/gltf/animation/morphStressTest/index.html +++ b/examples/gltf/animation/morphStressTest/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/gltf/animation/morphStressTest/index.js b/examples/gltf/animation/morphStressTest/index.js index 8c9ed0414..a3c996f48 100644 --- a/examples/gltf/animation/morphStressTest/index.js +++ b/examples/gltf/animation/morphStressTest/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; /** * [KO] Morph Stress Test 예제 @@ -61,11 +61,11 @@ function loadGLTF(view, url) { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { createIblHelper, setDebugButtons - } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); + } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770713934910'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/animation/performance/highMorphTarget/index.html b/examples/gltf/animation/performance/highMorphTarget/index.html index c7c14d3dd..004b73e31 100644 --- a/examples/gltf/animation/performance/highMorphTarget/index.html +++ b/examples/gltf/animation/performance/highMorphTarget/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/animation/performance/highMorphTarget/index.js b/examples/gltf/animation/performance/highMorphTarget/index.js index 396db72ca..91b8cb3a3 100644 --- a/examples/gltf/animation/performance/highMorphTarget/index.js +++ b/examples/gltf/animation/performance/highMorphTarget/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../../dist/index.js?t=1770713934910"; import { loadingProgressInfoHandler -} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' +} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770713934910' /** * [KO] High Morph Target Performance 예제 @@ -126,11 +126,11 @@ let pane * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { setDebugButtons, createIblHelper - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770713934910'); setDebugButtons(RedGPU, redGPUContext); pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/animation/performance/highVertexLoadSkinning/index.html b/examples/gltf/animation/performance/highVertexLoadSkinning/index.html index c7c14d3dd..004b73e31 100644 --- a/examples/gltf/animation/performance/highVertexLoadSkinning/index.html +++ b/examples/gltf/animation/performance/highVertexLoadSkinning/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/animation/performance/highVertexLoadSkinning/index.js b/examples/gltf/animation/performance/highVertexLoadSkinning/index.js index 184f4f5c4..be291f050 100644 --- a/examples/gltf/animation/performance/highVertexLoadSkinning/index.js +++ b/examples/gltf/animation/performance/highVertexLoadSkinning/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../../dist/index.js?t=1770713934910"; import { loadingProgressInfoHandler -} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' +} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770713934910' /** * [KO] High Vertex Load Skinning 예제 @@ -84,11 +84,11 @@ let pane * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { setDebugButtons, createIblHelper - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770713934910'); setDebugButtons(RedGPU, redGPUContext); pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/animation/performance/mediumLoadSkinning/index.html b/examples/gltf/animation/performance/mediumLoadSkinning/index.html index c7c14d3dd..004b73e31 100644 --- a/examples/gltf/animation/performance/mediumLoadSkinning/index.html +++ b/examples/gltf/animation/performance/mediumLoadSkinning/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/animation/performance/mediumLoadSkinning/index.js b/examples/gltf/animation/performance/mediumLoadSkinning/index.js index e1a223aec..ea1419342 100644 --- a/examples/gltf/animation/performance/mediumLoadSkinning/index.js +++ b/examples/gltf/animation/performance/mediumLoadSkinning/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../../dist/index.js?t=1770713934910"; import { loadingProgressInfoHandler -} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' +} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770713934910' /** * [KO] Medium Load Skinning 예제 @@ -88,8 +88,8 @@ let pane * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); - const {setDebugButtons} = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); + const {setDebugButtons} = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770713934910'); setDebugButtons(RedGPU, redGPUContext); pane = new Pane(); diff --git a/examples/gltf/animation/recursiveSkeletons/index.html b/examples/gltf/animation/recursiveSkeletons/index.html index 77d781697..91601ab7d 100644 --- a/examples/gltf/animation/recursiveSkeletons/index.html +++ b/examples/gltf/animation/recursiveSkeletons/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/gltf/animation/recursiveSkeletons/index.js b/examples/gltf/animation/recursiveSkeletons/index.js index 790979782..6f9e2a356 100644 --- a/examples/gltf/animation/recursiveSkeletons/index.js +++ b/examples/gltf/animation/recursiveSkeletons/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; /** * [KO] Recursive Skeletons 예제 @@ -61,11 +61,11 @@ function loadGLTF(view, url) { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { createIblHelper, setDebugButtons - } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); + } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770713934910'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/animation/riggedFigure/index.html b/examples/gltf/animation/riggedFigure/index.html index 77d781697..91601ab7d 100644 --- a/examples/gltf/animation/riggedFigure/index.html +++ b/examples/gltf/animation/riggedFigure/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/gltf/animation/riggedFigure/index.js b/examples/gltf/animation/riggedFigure/index.js index 868b11b75..8ce8dfedd 100644 --- a/examples/gltf/animation/riggedFigure/index.js +++ b/examples/gltf/animation/riggedFigure/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; /** * [KO] Rigged Figure 예제 @@ -62,11 +62,11 @@ function loadGLTF(view, url) { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { createIblHelper, setDebugButtons - } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); + } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770713934910'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/animation/riggedSimple/index.html b/examples/gltf/animation/riggedSimple/index.html index 77d781697..91601ab7d 100644 --- a/examples/gltf/animation/riggedSimple/index.html +++ b/examples/gltf/animation/riggedSimple/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/gltf/animation/riggedSimple/index.js b/examples/gltf/animation/riggedSimple/index.js index 28e424393..dbd76a01f 100644 --- a/examples/gltf/animation/riggedSimple/index.js +++ b/examples/gltf/animation/riggedSimple/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; /** * [KO] Rigged Simple 예제 @@ -60,11 +60,11 @@ function loadGLTF(view, url) { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { createIblHelper, setDebugButtons - } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); + } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770713934910'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/animation/simpleMorph/index.html b/examples/gltf/animation/simpleMorph/index.html index 77d781697..91601ab7d 100644 --- a/examples/gltf/animation/simpleMorph/index.html +++ b/examples/gltf/animation/simpleMorph/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/gltf/animation/simpleMorph/index.js b/examples/gltf/animation/simpleMorph/index.js index e69977c92..4ee2862ba 100644 --- a/examples/gltf/animation/simpleMorph/index.js +++ b/examples/gltf/animation/simpleMorph/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; /** * [KO] Simple Morph 예제 @@ -61,11 +61,11 @@ function loadGLTF(view, url) { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { createIblHelper, setDebugButtons - } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); + } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770713934910'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/animation/simpleSkin/index.html b/examples/gltf/animation/simpleSkin/index.html index 77d781697..91601ab7d 100644 --- a/examples/gltf/animation/simpleSkin/index.html +++ b/examples/gltf/animation/simpleSkin/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/gltf/animation/simpleSkin/index.js b/examples/gltf/animation/simpleSkin/index.js index 2f9866b08..e709da5ac 100644 --- a/examples/gltf/animation/simpleSkin/index.js +++ b/examples/gltf/animation/simpleSkin/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; /** * [KO] Simple Skin 예제 @@ -60,11 +60,11 @@ function loadGLTF(view, url) { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { createIblHelper, setDebugButtons - } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); + } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770713934910'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/basic/alphaBlendModeTest/index.html b/examples/gltf/basic/alphaBlendModeTest/index.html index 77d781697..91601ab7d 100644 --- a/examples/gltf/basic/alphaBlendModeTest/index.html +++ b/examples/gltf/basic/alphaBlendModeTest/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/gltf/basic/alphaBlendModeTest/index.js b/examples/gltf/basic/alphaBlendModeTest/index.js index d288499e3..63346c4fd 100644 --- a/examples/gltf/basic/alphaBlendModeTest/index.js +++ b/examples/gltf/basic/alphaBlendModeTest/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; import { loadingProgressInfoHandler -} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' +} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770713934910' /** * [KO] Alpha Blend Mode Test 예제 @@ -76,11 +76,11 @@ const loadGLTF = async (view, url) => { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { createIblHelper, setDebugButtons - } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); + } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770713934910'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/basic/boxVertexColors/index.html b/examples/gltf/basic/boxVertexColors/index.html index 77d781697..91601ab7d 100644 --- a/examples/gltf/basic/boxVertexColors/index.html +++ b/examples/gltf/basic/boxVertexColors/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/gltf/basic/boxVertexColors/index.js b/examples/gltf/basic/boxVertexColors/index.js index 97daf0884..260e950af 100644 --- a/examples/gltf/basic/boxVertexColors/index.js +++ b/examples/gltf/basic/boxVertexColors/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; import { loadingProgressInfoHandler -} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' +} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770713934910' /** * [KO] Box Vertex Colors 예제 @@ -76,11 +76,11 @@ const loadGLTF = async (view, url) => { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { createIblHelper, setDebugButtons - } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); + } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770713934910'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/basic/compareAlphaCoverage/index.html b/examples/gltf/basic/compareAlphaCoverage/index.html index 77d781697..91601ab7d 100644 --- a/examples/gltf/basic/compareAlphaCoverage/index.html +++ b/examples/gltf/basic/compareAlphaCoverage/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/gltf/basic/compareAlphaCoverage/index.js b/examples/gltf/basic/compareAlphaCoverage/index.js index e16180698..61786c86a 100644 --- a/examples/gltf/basic/compareAlphaCoverage/index.js +++ b/examples/gltf/basic/compareAlphaCoverage/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; import { loadingProgressInfoHandler -} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' +} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770713934910' /** * [KO] Compare Alpha Coverage 예제 @@ -77,11 +77,11 @@ const loadGLTF = async (view, url) => { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { createIblHelper, setDebugButtons - } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); + } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770713934910'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/basic/compareAmbientOcclusion/index.html b/examples/gltf/basic/compareAmbientOcclusion/index.html index 77d781697..91601ab7d 100644 --- a/examples/gltf/basic/compareAmbientOcclusion/index.html +++ b/examples/gltf/basic/compareAmbientOcclusion/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/gltf/basic/compareAmbientOcclusion/index.js b/examples/gltf/basic/compareAmbientOcclusion/index.js index fff6255a3..4cf4f50c0 100644 --- a/examples/gltf/basic/compareAmbientOcclusion/index.js +++ b/examples/gltf/basic/compareAmbientOcclusion/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; import { loadingProgressInfoHandler -} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' +} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770713934910' /** * [KO] Compare Ambient Occlusion 예제 @@ -77,11 +77,11 @@ const loadGLTF = async (view, url) => { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { createIblHelper, setDebugButtons - } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); + } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770713934910'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/basic/compareBaseColor/index.html b/examples/gltf/basic/compareBaseColor/index.html index 77d781697..91601ab7d 100644 --- a/examples/gltf/basic/compareBaseColor/index.html +++ b/examples/gltf/basic/compareBaseColor/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/gltf/basic/compareBaseColor/index.js b/examples/gltf/basic/compareBaseColor/index.js index 73c876e59..3e2d21645 100644 --- a/examples/gltf/basic/compareBaseColor/index.js +++ b/examples/gltf/basic/compareBaseColor/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; import { loadingProgressInfoHandler -} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' +} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770713934910' /** * [KO] Compare Base Color 예제 @@ -76,11 +76,11 @@ const loadGLTF = async (view, url) => { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { createIblHelper, setDebugButtons - } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); + } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770713934910'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/basic/compareMetallic/index.html b/examples/gltf/basic/compareMetallic/index.html index 77d781697..91601ab7d 100644 --- a/examples/gltf/basic/compareMetallic/index.html +++ b/examples/gltf/basic/compareMetallic/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/gltf/basic/compareMetallic/index.js b/examples/gltf/basic/compareMetallic/index.js index f100c3cc1..992180350 100644 --- a/examples/gltf/basic/compareMetallic/index.js +++ b/examples/gltf/basic/compareMetallic/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; import { loadingProgressInfoHandler -} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' +} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770713934910' /** * [KO] Compare Metallic 예제 @@ -76,11 +76,11 @@ const loadGLTF = async (view, url) => { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { createIblHelper, setDebugButtons - } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); + } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770713934910'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/basic/compareNormal/index.html b/examples/gltf/basic/compareNormal/index.html index 77d781697..91601ab7d 100644 --- a/examples/gltf/basic/compareNormal/index.html +++ b/examples/gltf/basic/compareNormal/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/gltf/basic/compareNormal/index.js b/examples/gltf/basic/compareNormal/index.js index 9223b8e39..d32fb6518 100644 --- a/examples/gltf/basic/compareNormal/index.js +++ b/examples/gltf/basic/compareNormal/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; import { loadingProgressInfoHandler -} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' +} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770713934910' /** * [KO] Compare Normal 예제 @@ -76,11 +76,11 @@ const loadGLTF = async (view, url) => { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { createIblHelper, setDebugButtons - } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); + } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770713934910'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/basic/compareRoughness/index.html b/examples/gltf/basic/compareRoughness/index.html index 77d781697..91601ab7d 100644 --- a/examples/gltf/basic/compareRoughness/index.html +++ b/examples/gltf/basic/compareRoughness/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/gltf/basic/compareRoughness/index.js b/examples/gltf/basic/compareRoughness/index.js index 7057591c6..f2b14757f 100644 --- a/examples/gltf/basic/compareRoughness/index.js +++ b/examples/gltf/basic/compareRoughness/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; import { loadingProgressInfoHandler -} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' +} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770713934910' /** * [KO] Compare Roughness 예제 @@ -76,11 +76,11 @@ const loadGLTF = async (view, url) => { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { createIblHelper, setDebugButtons - } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); + } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770713934910'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/basic/environmentTest/index.html b/examples/gltf/basic/environmentTest/index.html index 77d781697..91601ab7d 100644 --- a/examples/gltf/basic/environmentTest/index.html +++ b/examples/gltf/basic/environmentTest/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/gltf/basic/environmentTest/index.js b/examples/gltf/basic/environmentTest/index.js index 5396c4425..a91ff5e8e 100644 --- a/examples/gltf/basic/environmentTest/index.js +++ b/examples/gltf/basic/environmentTest/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; import { loadingProgressInfoHandler -} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' +} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770713934910' /** * [KO] Environment Test 예제 @@ -76,11 +76,11 @@ const loadGLTF = async (view, url) => { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { createIblHelper, setDebugButtons - } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); + } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770713934910'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/basic/generateNormalTest/index.html b/examples/gltf/basic/generateNormalTest/index.html index 77d781697..91601ab7d 100644 --- a/examples/gltf/basic/generateNormalTest/index.html +++ b/examples/gltf/basic/generateNormalTest/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/gltf/basic/generateNormalTest/index.js b/examples/gltf/basic/generateNormalTest/index.js index 7f4adae3a..558889f70 100644 --- a/examples/gltf/basic/generateNormalTest/index.js +++ b/examples/gltf/basic/generateNormalTest/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; import { loadingProgressInfoHandler -} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' +} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770713934910' /** * [KO] Generate Normal Test 예제 @@ -76,11 +76,11 @@ const loadGLTF = async (view, url) => { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { createIblHelper, setDebugButtons - } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); + } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770713934910'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/basic/metalRoughSpheres/index.html b/examples/gltf/basic/metalRoughSpheres/index.html index 77d781697..91601ab7d 100644 --- a/examples/gltf/basic/metalRoughSpheres/index.html +++ b/examples/gltf/basic/metalRoughSpheres/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/gltf/basic/metalRoughSpheres/index.js b/examples/gltf/basic/metalRoughSpheres/index.js index b9bc1261f..0eba68e3b 100644 --- a/examples/gltf/basic/metalRoughSpheres/index.js +++ b/examples/gltf/basic/metalRoughSpheres/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; import { loadingProgressInfoHandler -} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' +} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770713934910' /** * [KO] Metal Rough Spheres 예제 @@ -77,11 +77,11 @@ const loadGLTF = async (view, url) => { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { createIblHelper, setDebugButtons - } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); + } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770713934910'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/basic/metalRoughSpheresNoTextures/index.html b/examples/gltf/basic/metalRoughSpheresNoTextures/index.html index 77d781697..91601ab7d 100644 --- a/examples/gltf/basic/metalRoughSpheresNoTextures/index.html +++ b/examples/gltf/basic/metalRoughSpheresNoTextures/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/gltf/basic/metalRoughSpheresNoTextures/index.js b/examples/gltf/basic/metalRoughSpheresNoTextures/index.js index 534294365..c83056462 100644 --- a/examples/gltf/basic/metalRoughSpheresNoTextures/index.js +++ b/examples/gltf/basic/metalRoughSpheresNoTextures/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; import { loadingProgressInfoHandler -} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' +} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770713934910' /** * [KO] Metal Rough Spheres (No Textures) 예제 @@ -77,11 +77,11 @@ const loadGLTF = async (view, url) => { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { createIblHelper, setDebugButtons - } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); + } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770713934910'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/basic/multiUVTest/index.html b/examples/gltf/basic/multiUVTest/index.html index 77d781697..91601ab7d 100644 --- a/examples/gltf/basic/multiUVTest/index.html +++ b/examples/gltf/basic/multiUVTest/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/gltf/basic/multiUVTest/index.js b/examples/gltf/basic/multiUVTest/index.js index 449d43627..7c53f2061 100644 --- a/examples/gltf/basic/multiUVTest/index.js +++ b/examples/gltf/basic/multiUVTest/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; import { loadingProgressInfoHandler -} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' +} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770713934910' /** * [KO] Multi UV Test 예제 @@ -77,11 +77,11 @@ const loadGLTF = async (view, url) => { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { createIblHelper, setDebugButtons - } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); + } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770713934910'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/basic/negativeScaleTest/index.html b/examples/gltf/basic/negativeScaleTest/index.html index 77d781697..91601ab7d 100644 --- a/examples/gltf/basic/negativeScaleTest/index.html +++ b/examples/gltf/basic/negativeScaleTest/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/gltf/basic/negativeScaleTest/index.js b/examples/gltf/basic/negativeScaleTest/index.js index 16efaf06a..84f901ab8 100644 --- a/examples/gltf/basic/negativeScaleTest/index.js +++ b/examples/gltf/basic/negativeScaleTest/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; import { loadingProgressInfoHandler -} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' +} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770713934910' /** * [KO] Negative Scale Test 예제 @@ -76,11 +76,11 @@ const loadGLTF = async (view, url) => { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { createIblHelper, setDebugButtons - } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); + } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770713934910'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/basic/normalTangentMirrorTest/index.html b/examples/gltf/basic/normalTangentMirrorTest/index.html index 77d781697..91601ab7d 100644 --- a/examples/gltf/basic/normalTangentMirrorTest/index.html +++ b/examples/gltf/basic/normalTangentMirrorTest/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/gltf/basic/normalTangentMirrorTest/index.js b/examples/gltf/basic/normalTangentMirrorTest/index.js index d199bea46..7bfa44413 100644 --- a/examples/gltf/basic/normalTangentMirrorTest/index.js +++ b/examples/gltf/basic/normalTangentMirrorTest/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; import { loadingProgressInfoHandler -} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' +} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770713934910' /** * [KO] Normal Tangent Mirror Test 예제 @@ -77,11 +77,11 @@ const loadGLTF = async (view, url) => { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { createIblHelper, setDebugButtons - } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); + } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770713934910'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/basic/normalTangentTest/index.html b/examples/gltf/basic/normalTangentTest/index.html index 77d781697..91601ab7d 100644 --- a/examples/gltf/basic/normalTangentTest/index.html +++ b/examples/gltf/basic/normalTangentTest/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/gltf/basic/normalTangentTest/index.js b/examples/gltf/basic/normalTangentTest/index.js index 613dd3ad2..c20c69b8c 100644 --- a/examples/gltf/basic/normalTangentTest/index.js +++ b/examples/gltf/basic/normalTangentTest/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; import { loadingProgressInfoHandler -} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' +} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770713934910' /** * [KO] Normal Tangent Test 예제 @@ -77,11 +77,11 @@ const loadGLTF = async (view, url) => { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { createIblHelper, setDebugButtons - } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); + } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770713934910'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/basic/orientationTest/index.html b/examples/gltf/basic/orientationTest/index.html index 77d781697..91601ab7d 100644 --- a/examples/gltf/basic/orientationTest/index.html +++ b/examples/gltf/basic/orientationTest/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/gltf/basic/orientationTest/index.js b/examples/gltf/basic/orientationTest/index.js index 41c325743..c0a96f8d3 100644 --- a/examples/gltf/basic/orientationTest/index.js +++ b/examples/gltf/basic/orientationTest/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; import { loadingProgressInfoHandler -} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' +} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770713934910' /** * [KO] Orientation Test 예제 @@ -76,11 +76,11 @@ const loadGLTF = async (view, url) => { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { createIblHelper, setDebugButtons - } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); + } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770713934910'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/basic/textureCoordinateTest/index.html b/examples/gltf/basic/textureCoordinateTest/index.html index 77d781697..91601ab7d 100644 --- a/examples/gltf/basic/textureCoordinateTest/index.html +++ b/examples/gltf/basic/textureCoordinateTest/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/gltf/basic/textureCoordinateTest/index.js b/examples/gltf/basic/textureCoordinateTest/index.js index c1da51bb1..94a287170 100644 --- a/examples/gltf/basic/textureCoordinateTest/index.js +++ b/examples/gltf/basic/textureCoordinateTest/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; import { loadingProgressInfoHandler -} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' +} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770713934910' /** * [KO] Texture Coordinate Test 예제 @@ -76,11 +76,11 @@ const loadGLTF = async (view, url) => { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { createIblHelper, setDebugButtons - } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); + } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770713934910'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/basic/textureEncodingTest/index.html b/examples/gltf/basic/textureEncodingTest/index.html index 77d781697..91601ab7d 100644 --- a/examples/gltf/basic/textureEncodingTest/index.html +++ b/examples/gltf/basic/textureEncodingTest/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/gltf/basic/textureEncodingTest/index.js b/examples/gltf/basic/textureEncodingTest/index.js index db57f123b..35aa55eb2 100644 --- a/examples/gltf/basic/textureEncodingTest/index.js +++ b/examples/gltf/basic/textureEncodingTest/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; import { loadingProgressInfoHandler -} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' +} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770713934910' /** * [KO] Texture Encoding Test 예제 @@ -77,11 +77,11 @@ const loadGLTF = async (view, url) => { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { createIblHelper, setDebugButtons - } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); + } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770713934910'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/basic/textureLinearInterpolationTest/index.html b/examples/gltf/basic/textureLinearInterpolationTest/index.html index 77d781697..91601ab7d 100644 --- a/examples/gltf/basic/textureLinearInterpolationTest/index.html +++ b/examples/gltf/basic/textureLinearInterpolationTest/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/gltf/basic/textureLinearInterpolationTest/index.js b/examples/gltf/basic/textureLinearInterpolationTest/index.js index 1beed5795..1cbba593f 100644 --- a/examples/gltf/basic/textureLinearInterpolationTest/index.js +++ b/examples/gltf/basic/textureLinearInterpolationTest/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; import { loadingProgressInfoHandler -} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' +} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770713934910' /** * [KO] Texture Linear Interpolation Test 예제 @@ -76,11 +76,11 @@ const loadGLTF = async (view, url) => { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { createIblHelper, setDebugButtons - } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); + } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770713934910'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/basic/textureSettingsTest/index.html b/examples/gltf/basic/textureSettingsTest/index.html index 77d781697..91601ab7d 100644 --- a/examples/gltf/basic/textureSettingsTest/index.html +++ b/examples/gltf/basic/textureSettingsTest/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/gltf/basic/textureSettingsTest/index.js b/examples/gltf/basic/textureSettingsTest/index.js index 282a2c212..83aff8324 100644 --- a/examples/gltf/basic/textureSettingsTest/index.js +++ b/examples/gltf/basic/textureSettingsTest/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; import { loadingProgressInfoHandler -} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' +} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770713934910' /** * [KO] Texture Settings Test 예제 @@ -76,11 +76,11 @@ const loadGLTF = async (view, url) => { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { createIblHelper, setDebugButtons - } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); + } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770713934910'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/basic/vertexColorTest/index.html b/examples/gltf/basic/vertexColorTest/index.html index 77d781697..91601ab7d 100644 --- a/examples/gltf/basic/vertexColorTest/index.html +++ b/examples/gltf/basic/vertexColorTest/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/gltf/basic/vertexColorTest/index.js b/examples/gltf/basic/vertexColorTest/index.js index fc94b9aa1..004ed214b 100644 --- a/examples/gltf/basic/vertexColorTest/index.js +++ b/examples/gltf/basic/vertexColorTest/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; import { loadingProgressInfoHandler -} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' +} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770713934910' /** * [KO] Vertex Color Test 예제 @@ -76,11 +76,11 @@ const loadGLTF = async (view, url) => { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { createIblHelper, setDebugButtons - } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); + } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770713934910'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/basic/waterBottle/index.html b/examples/gltf/basic/waterBottle/index.html index 77d781697..91601ab7d 100644 --- a/examples/gltf/basic/waterBottle/index.html +++ b/examples/gltf/basic/waterBottle/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/gltf/basic/waterBottle/index.js b/examples/gltf/basic/waterBottle/index.js index 1ec7a10ed..64c8cad76 100644 --- a/examples/gltf/basic/waterBottle/index.js +++ b/examples/gltf/basic/waterBottle/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; import { loadingProgressInfoHandler -} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' +} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770713934910' /** * [KO] Water Bottle 예제 @@ -77,11 +77,11 @@ const loadGLTF = async (view, url) => { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { createIblHelper, setDebugButtons - } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); + } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770713934910'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/gltfExtensions/anisotropy/anisotropyBarnLamp/index.html b/examples/gltf/gltfExtensions/anisotropy/anisotropyBarnLamp/index.html index c7c14d3dd..004b73e31 100644 --- a/examples/gltf/gltfExtensions/anisotropy/anisotropyBarnLamp/index.html +++ b/examples/gltf/gltfExtensions/anisotropy/anisotropyBarnLamp/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/gltfExtensions/anisotropy/anisotropyBarnLamp/index.js b/examples/gltf/gltfExtensions/anisotropy/anisotropyBarnLamp/index.js index 3ecc9f470..a4f34da11 100644 --- a/examples/gltf/gltfExtensions/anisotropy/anisotropyBarnLamp/index.js +++ b/examples/gltf/gltfExtensions/anisotropy/anisotropyBarnLamp/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../../dist/index.js?t=1770713934910"; import { loadingProgressInfoHandler -} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' +} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770713934910' /** * [KO] Anisotropy Barn Lamp 예제 @@ -77,11 +77,11 @@ const loadGLTF = async (view, url) => { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { createIblHelper, setDebugButtons - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770713934910'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/gltfExtensions/anisotropy/anisotropyDiscTest/index.html b/examples/gltf/gltfExtensions/anisotropy/anisotropyDiscTest/index.html index c7c14d3dd..004b73e31 100644 --- a/examples/gltf/gltfExtensions/anisotropy/anisotropyDiscTest/index.html +++ b/examples/gltf/gltfExtensions/anisotropy/anisotropyDiscTest/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/gltfExtensions/anisotropy/anisotropyDiscTest/index.js b/examples/gltf/gltfExtensions/anisotropy/anisotropyDiscTest/index.js index cc469b6eb..48c93e8fd 100644 --- a/examples/gltf/gltfExtensions/anisotropy/anisotropyDiscTest/index.js +++ b/examples/gltf/gltfExtensions/anisotropy/anisotropyDiscTest/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../../dist/index.js?t=1770713934910"; /** * [KO] Anisotropy Disc Test 예제 @@ -60,11 +60,11 @@ function loadGLTF(view, url) { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { createIblHelper, setDebugButtons - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770713934910'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/gltfExtensions/anisotropy/anisotropyRotationTest/index.html b/examples/gltf/gltfExtensions/anisotropy/anisotropyRotationTest/index.html index c7c14d3dd..004b73e31 100644 --- a/examples/gltf/gltfExtensions/anisotropy/anisotropyRotationTest/index.html +++ b/examples/gltf/gltfExtensions/anisotropy/anisotropyRotationTest/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/gltfExtensions/anisotropy/anisotropyRotationTest/index.js b/examples/gltf/gltfExtensions/anisotropy/anisotropyRotationTest/index.js index 2902372d6..b544eab74 100644 --- a/examples/gltf/gltfExtensions/anisotropy/anisotropyRotationTest/index.js +++ b/examples/gltf/gltfExtensions/anisotropy/anisotropyRotationTest/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../../dist/index.js?t=1770713934910"; /** * [KO] Anisotropy Rotation Test 예제 @@ -62,11 +62,11 @@ function loadGLTF(view, url) { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { createIblHelper, setDebugButtons - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770713934910'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/gltfExtensions/anisotropy/anisotropyStrengthTest/index.html b/examples/gltf/gltfExtensions/anisotropy/anisotropyStrengthTest/index.html index c7c14d3dd..004b73e31 100644 --- a/examples/gltf/gltfExtensions/anisotropy/anisotropyStrengthTest/index.html +++ b/examples/gltf/gltfExtensions/anisotropy/anisotropyStrengthTest/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/gltfExtensions/anisotropy/anisotropyStrengthTest/index.js b/examples/gltf/gltfExtensions/anisotropy/anisotropyStrengthTest/index.js index 76420ac6c..4107e6768 100644 --- a/examples/gltf/gltfExtensions/anisotropy/anisotropyStrengthTest/index.js +++ b/examples/gltf/gltfExtensions/anisotropy/anisotropyStrengthTest/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../../dist/index.js?t=1770713934910"; /** * [KO] Anisotropy Strength Test 예제 @@ -62,11 +62,11 @@ function loadGLTF(view, url) { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { createIblHelper, setDebugButtons - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770713934910'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/gltfExtensions/anisotropy/compareAnisotropy/index.html b/examples/gltf/gltfExtensions/anisotropy/compareAnisotropy/index.html index c7c14d3dd..004b73e31 100644 --- a/examples/gltf/gltfExtensions/anisotropy/compareAnisotropy/index.html +++ b/examples/gltf/gltfExtensions/anisotropy/compareAnisotropy/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/gltfExtensions/anisotropy/compareAnisotropy/index.js b/examples/gltf/gltfExtensions/anisotropy/compareAnisotropy/index.js index 03ef71eae..9a3175503 100644 --- a/examples/gltf/gltfExtensions/anisotropy/compareAnisotropy/index.js +++ b/examples/gltf/gltfExtensions/anisotropy/compareAnisotropy/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../../dist/index.js?t=1770713934910"; import { loadingProgressInfoHandler -} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' +} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770713934910' /** * [KO] Compare Anisotropy 예제 @@ -77,11 +77,11 @@ const loadGLTF = async (view, url) => { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { createIblHelper, setDebugButtons - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770713934910'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/gltfExtensions/clearcoat/clearCoatCarPaint/index.html b/examples/gltf/gltfExtensions/clearcoat/clearCoatCarPaint/index.html index c7c14d3dd..004b73e31 100644 --- a/examples/gltf/gltfExtensions/clearcoat/clearCoatCarPaint/index.html +++ b/examples/gltf/gltfExtensions/clearcoat/clearCoatCarPaint/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/gltfExtensions/clearcoat/clearCoatCarPaint/index.js b/examples/gltf/gltfExtensions/clearcoat/clearCoatCarPaint/index.js index aee0ba850..59ef680f3 100644 --- a/examples/gltf/gltfExtensions/clearcoat/clearCoatCarPaint/index.js +++ b/examples/gltf/gltfExtensions/clearcoat/clearCoatCarPaint/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../../dist/index.js?t=1770713934910"; /** * [KO] ClearCoat Car Paint 예제 @@ -60,11 +60,11 @@ function loadGLTF(view, url) { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { createIblHelper, setDebugButtons - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770713934910'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/gltfExtensions/clearcoat/clearCoatTest/index.html b/examples/gltf/gltfExtensions/clearcoat/clearCoatTest/index.html index c7c14d3dd..004b73e31 100644 --- a/examples/gltf/gltfExtensions/clearcoat/clearCoatTest/index.html +++ b/examples/gltf/gltfExtensions/clearcoat/clearCoatTest/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/gltfExtensions/clearcoat/clearCoatTest/index.js b/examples/gltf/gltfExtensions/clearcoat/clearCoatTest/index.js index 8aafdc9fc..0f0403786 100644 --- a/examples/gltf/gltfExtensions/clearcoat/clearCoatTest/index.js +++ b/examples/gltf/gltfExtensions/clearcoat/clearCoatTest/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../../dist/index.js?t=1770713934910"; /** * [KO] ClearCoat Test 예제 @@ -60,11 +60,11 @@ function loadGLTF(view, url) { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { createIblHelper, setDebugButtons - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770713934910'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/gltfExtensions/clearcoat/clearcoatWicker/index.html b/examples/gltf/gltfExtensions/clearcoat/clearcoatWicker/index.html index c7c14d3dd..004b73e31 100644 --- a/examples/gltf/gltfExtensions/clearcoat/clearcoatWicker/index.html +++ b/examples/gltf/gltfExtensions/clearcoat/clearcoatWicker/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/gltfExtensions/clearcoat/clearcoatWicker/index.js b/examples/gltf/gltfExtensions/clearcoat/clearcoatWicker/index.js index ebf92fa7d..6da53f8c3 100644 --- a/examples/gltf/gltfExtensions/clearcoat/clearcoatWicker/index.js +++ b/examples/gltf/gltfExtensions/clearcoat/clearcoatWicker/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../../dist/index.js?t=1770713934910"; import { loadingProgressInfoHandler -} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' +} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770713934910' /** * [KO] Clearcoat Wicker 예제 @@ -77,11 +77,11 @@ const loadGLTF = async (view, url) => { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { createIblHelper, setDebugButtons - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770713934910'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/gltfExtensions/clearcoat/compareClearcoat/index.html b/examples/gltf/gltfExtensions/clearcoat/compareClearcoat/index.html index c7c14d3dd..004b73e31 100644 --- a/examples/gltf/gltfExtensions/clearcoat/compareClearcoat/index.html +++ b/examples/gltf/gltfExtensions/clearcoat/compareClearcoat/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/gltfExtensions/clearcoat/compareClearcoat/index.js b/examples/gltf/gltfExtensions/clearcoat/compareClearcoat/index.js index 8891b9539..485761d8c 100644 --- a/examples/gltf/gltfExtensions/clearcoat/compareClearcoat/index.js +++ b/examples/gltf/gltfExtensions/clearcoat/compareClearcoat/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../../dist/index.js?t=1770713934910"; /** * [KO] Compare Clearcoat 예제 @@ -60,11 +60,11 @@ function loadGLTF(view, url) { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { createIblHelper, setDebugButtons - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770713934910'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/gltfExtensions/diffuseTransmission/diffuseTransmissionTeacup/index.html b/examples/gltf/gltfExtensions/diffuseTransmission/diffuseTransmissionTeacup/index.html index c7c14d3dd..004b73e31 100644 --- a/examples/gltf/gltfExtensions/diffuseTransmission/diffuseTransmissionTeacup/index.html +++ b/examples/gltf/gltfExtensions/diffuseTransmission/diffuseTransmissionTeacup/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/gltfExtensions/diffuseTransmission/diffuseTransmissionTeacup/index.js b/examples/gltf/gltfExtensions/diffuseTransmission/diffuseTransmissionTeacup/index.js index 8cd2a4ed1..afac73ebc 100644 --- a/examples/gltf/gltfExtensions/diffuseTransmission/diffuseTransmissionTeacup/index.js +++ b/examples/gltf/gltfExtensions/diffuseTransmission/diffuseTransmissionTeacup/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../../dist/index.js?t=1770713934910"; import { loadingProgressInfoHandler -} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' +} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770713934910' /** * [KO] Diffuse Transmission Teacup 예제 @@ -77,11 +77,11 @@ const loadGLTF = async (view, url) => { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { createIblHelper, setDebugButtons - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770713934910'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/gltfExtensions/diffuseTransmission/diffuseTransmissionTest/index.html b/examples/gltf/gltfExtensions/diffuseTransmission/diffuseTransmissionTest/index.html index c7c14d3dd..004b73e31 100644 --- a/examples/gltf/gltfExtensions/diffuseTransmission/diffuseTransmissionTest/index.html +++ b/examples/gltf/gltfExtensions/diffuseTransmission/diffuseTransmissionTest/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/gltfExtensions/diffuseTransmission/diffuseTransmissionTest/index.js b/examples/gltf/gltfExtensions/diffuseTransmission/diffuseTransmissionTest/index.js index d49a06f29..5d6987546 100644 --- a/examples/gltf/gltfExtensions/diffuseTransmission/diffuseTransmissionTest/index.js +++ b/examples/gltf/gltfExtensions/diffuseTransmission/diffuseTransmissionTest/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../../dist/index.js?t=1770713934910"; /** * [KO] Diffuse Transmission Test 예제 @@ -61,11 +61,11 @@ function loadGLTF(view, url) { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { createIblHelper, setDebugButtons - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770713934910'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/gltfExtensions/dispersion/compareDispersion/index.html b/examples/gltf/gltfExtensions/dispersion/compareDispersion/index.html index c7c14d3dd..004b73e31 100644 --- a/examples/gltf/gltfExtensions/dispersion/compareDispersion/index.html +++ b/examples/gltf/gltfExtensions/dispersion/compareDispersion/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/gltfExtensions/dispersion/compareDispersion/index.js b/examples/gltf/gltfExtensions/dispersion/compareDispersion/index.js index c28a0a125..abaf80c21 100644 --- a/examples/gltf/gltfExtensions/dispersion/compareDispersion/index.js +++ b/examples/gltf/gltfExtensions/dispersion/compareDispersion/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../../dist/index.js?t=1770713934910"; /** * [KO] Compare Dispersion 예제 @@ -61,11 +61,11 @@ function loadGLTF(view, url) { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { createIblHelper, setDebugButtons - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770713934910'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/gltfExtensions/dispersion/dispersionTest/index.html b/examples/gltf/gltfExtensions/dispersion/dispersionTest/index.html index c7c14d3dd..004b73e31 100644 --- a/examples/gltf/gltfExtensions/dispersion/dispersionTest/index.html +++ b/examples/gltf/gltfExtensions/dispersion/dispersionTest/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/gltfExtensions/dispersion/dispersionTest/index.js b/examples/gltf/gltfExtensions/dispersion/dispersionTest/index.js index 1d2585640..aad0af3db 100644 --- a/examples/gltf/gltfExtensions/dispersion/dispersionTest/index.js +++ b/examples/gltf/gltfExtensions/dispersion/dispersionTest/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../../dist/index.js?t=1770713934910"; import { loadingProgressInfoHandler -} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' +} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770713934910' /** * [KO] Dispersion Test 예제 @@ -77,11 +77,11 @@ const loadGLTF = async (view, url) => { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { createIblHelper, setDebugButtons - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770713934910'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/gltfExtensions/dispersion/dragonDispersion/index.html b/examples/gltf/gltfExtensions/dispersion/dragonDispersion/index.html index c7c14d3dd..004b73e31 100644 --- a/examples/gltf/gltfExtensions/dispersion/dragonDispersion/index.html +++ b/examples/gltf/gltfExtensions/dispersion/dragonDispersion/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/gltfExtensions/dispersion/dragonDispersion/index.js b/examples/gltf/gltfExtensions/dispersion/dragonDispersion/index.js index 76c5d563c..4e465bbe9 100644 --- a/examples/gltf/gltfExtensions/dispersion/dragonDispersion/index.js +++ b/examples/gltf/gltfExtensions/dispersion/dragonDispersion/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../../dist/index.js?t=1770713934910"; import { loadingProgressInfoHandler -} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' +} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770713934910' /** * [KO] Dragon Dispersion 예제 @@ -77,11 +77,11 @@ const loadGLTF = async (view, url) => { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { createIblHelper, setDebugButtons - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770713934910'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/gltfExtensions/emissiveStrength/compareEmissiveStrength/index.html b/examples/gltf/gltfExtensions/emissiveStrength/compareEmissiveStrength/index.html index c7c14d3dd..004b73e31 100644 --- a/examples/gltf/gltfExtensions/emissiveStrength/compareEmissiveStrength/index.html +++ b/examples/gltf/gltfExtensions/emissiveStrength/compareEmissiveStrength/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/gltfExtensions/emissiveStrength/compareEmissiveStrength/index.js b/examples/gltf/gltfExtensions/emissiveStrength/compareEmissiveStrength/index.js index 7b250e86b..35aea41ee 100644 --- a/examples/gltf/gltfExtensions/emissiveStrength/compareEmissiveStrength/index.js +++ b/examples/gltf/gltfExtensions/emissiveStrength/compareEmissiveStrength/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../../dist/index.js?t=1770713934910"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -40,11 +40,11 @@ function loadGLTF(view, url) { } const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { createIblHelper, setDebugButtons - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770713934910'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/gltfExtensions/emissiveStrength/emissiveStrengthTest/index.html b/examples/gltf/gltfExtensions/emissiveStrength/emissiveStrengthTest/index.html index c7c14d3dd..004b73e31 100644 --- a/examples/gltf/gltfExtensions/emissiveStrength/emissiveStrengthTest/index.html +++ b/examples/gltf/gltfExtensions/emissiveStrength/emissiveStrengthTest/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/gltfExtensions/emissiveStrength/emissiveStrengthTest/index.js b/examples/gltf/gltfExtensions/emissiveStrength/emissiveStrengthTest/index.js index f0a16c9e8..5d77f75a4 100644 --- a/examples/gltf/gltfExtensions/emissiveStrength/emissiveStrengthTest/index.js +++ b/examples/gltf/gltfExtensions/emissiveStrength/emissiveStrengthTest/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../../dist/index.js?t=1770713934910"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -40,11 +40,11 @@ function loadGLTF(view, url) { } const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { createIblHelper, setDebugButtons - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770713934910'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/gltfExtensions/iridescence/compareIridescence/index.html b/examples/gltf/gltfExtensions/iridescence/compareIridescence/index.html index c7c14d3dd..004b73e31 100644 --- a/examples/gltf/gltfExtensions/iridescence/compareIridescence/index.html +++ b/examples/gltf/gltfExtensions/iridescence/compareIridescence/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/gltfExtensions/iridescence/compareIridescence/index.js b/examples/gltf/gltfExtensions/iridescence/compareIridescence/index.js index a1508b115..fc045f5ac 100644 --- a/examples/gltf/gltfExtensions/iridescence/compareIridescence/index.js +++ b/examples/gltf/gltfExtensions/iridescence/compareIridescence/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../../dist/index.js?t=1770713934910"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -41,11 +41,11 @@ function loadGLTF(view, url) { } const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { createIblHelper, setDebugButtons - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770713934910'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/gltfExtensions/iridescence/iridescenceDielectricSpheres/index.html b/examples/gltf/gltfExtensions/iridescence/iridescenceDielectricSpheres/index.html index c7c14d3dd..004b73e31 100644 --- a/examples/gltf/gltfExtensions/iridescence/iridescenceDielectricSpheres/index.html +++ b/examples/gltf/gltfExtensions/iridescence/iridescenceDielectricSpheres/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/gltfExtensions/iridescence/iridescenceDielectricSpheres/index.js b/examples/gltf/gltfExtensions/iridescence/iridescenceDielectricSpheres/index.js index 0e11db8c7..8652a9de6 100644 --- a/examples/gltf/gltfExtensions/iridescence/iridescenceDielectricSpheres/index.js +++ b/examples/gltf/gltfExtensions/iridescence/iridescenceDielectricSpheres/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../../dist/index.js?t=1770713934910"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -41,11 +41,11 @@ function loadGLTF(view, url) { } const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { createIblHelper, setDebugButtons - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770713934910'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU, {useLight: false}); diff --git a/examples/gltf/gltfExtensions/iridescence/iridescenceLamp/index.html b/examples/gltf/gltfExtensions/iridescence/iridescenceLamp/index.html index c7c14d3dd..004b73e31 100644 --- a/examples/gltf/gltfExtensions/iridescence/iridescenceLamp/index.html +++ b/examples/gltf/gltfExtensions/iridescence/iridescenceLamp/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/gltfExtensions/iridescence/iridescenceLamp/index.js b/examples/gltf/gltfExtensions/iridescence/iridescenceLamp/index.js index 757da558e..26789e8ff 100644 --- a/examples/gltf/gltfExtensions/iridescence/iridescenceLamp/index.js +++ b/examples/gltf/gltfExtensions/iridescence/iridescenceLamp/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../../dist/index.js?t=1770713934910"; import { loadingProgressInfoHandler -} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' +} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770713934910' const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -57,11 +57,11 @@ const loadGLTF = async (view, url) => { } const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { createIblHelper, setDebugButtons - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770713934910'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/gltfExtensions/iridescence/iridescenceMetallicSpheres/index.html b/examples/gltf/gltfExtensions/iridescence/iridescenceMetallicSpheres/index.html index c7c14d3dd..004b73e31 100644 --- a/examples/gltf/gltfExtensions/iridescence/iridescenceMetallicSpheres/index.html +++ b/examples/gltf/gltfExtensions/iridescence/iridescenceMetallicSpheres/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/gltfExtensions/iridescence/iridescenceMetallicSpheres/index.js b/examples/gltf/gltfExtensions/iridescence/iridescenceMetallicSpheres/index.js index 604421d31..a3ab28653 100644 --- a/examples/gltf/gltfExtensions/iridescence/iridescenceMetallicSpheres/index.js +++ b/examples/gltf/gltfExtensions/iridescence/iridescenceMetallicSpheres/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../../dist/index.js?t=1770713934910"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -41,11 +41,11 @@ function loadGLTF(view, url) { } const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { createIblHelper, setDebugButtons - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770713934910'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU, {useLight: false}); diff --git a/examples/gltf/gltfExtensions/iridescence/iridescenceSuzanne/index.html b/examples/gltf/gltfExtensions/iridescence/iridescenceSuzanne/index.html index c7c14d3dd..004b73e31 100644 --- a/examples/gltf/gltfExtensions/iridescence/iridescenceSuzanne/index.html +++ b/examples/gltf/gltfExtensions/iridescence/iridescenceSuzanne/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/gltfExtensions/iridescence/iridescenceSuzanne/index.js b/examples/gltf/gltfExtensions/iridescence/iridescenceSuzanne/index.js index ad637b67f..de718c433 100644 --- a/examples/gltf/gltfExtensions/iridescence/iridescenceSuzanne/index.js +++ b/examples/gltf/gltfExtensions/iridescence/iridescenceSuzanne/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../../dist/index.js?t=1770713934910"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -41,11 +41,11 @@ function loadGLTF(view, url) { } const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { createIblHelper, setDebugButtons - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770713934910'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/gltfExtensions/iridescence/iridescentDishWithOlives/index.html b/examples/gltf/gltfExtensions/iridescence/iridescentDishWithOlives/index.html index c7c14d3dd..004b73e31 100644 --- a/examples/gltf/gltfExtensions/iridescence/iridescentDishWithOlives/index.html +++ b/examples/gltf/gltfExtensions/iridescence/iridescentDishWithOlives/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/gltfExtensions/iridescence/iridescentDishWithOlives/index.js b/examples/gltf/gltfExtensions/iridescence/iridescentDishWithOlives/index.js index 98e9dee24..41226e94b 100644 --- a/examples/gltf/gltfExtensions/iridescence/iridescentDishWithOlives/index.js +++ b/examples/gltf/gltfExtensions/iridescence/iridescentDishWithOlives/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../../dist/index.js?t=1770713934910"; import { loadingProgressInfoHandler -} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' +} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770713934910' const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -57,11 +57,11 @@ const loadGLTF = async (view, url) => { } const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { createIblHelper, setDebugButtons - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770713934910'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/gltfExtensions/iridescence/sunglassesKhronos/index.html b/examples/gltf/gltfExtensions/iridescence/sunglassesKhronos/index.html index c7c14d3dd..004b73e31 100644 --- a/examples/gltf/gltfExtensions/iridescence/sunglassesKhronos/index.html +++ b/examples/gltf/gltfExtensions/iridescence/sunglassesKhronos/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/gltfExtensions/iridescence/sunglassesKhronos/index.js b/examples/gltf/gltfExtensions/iridescence/sunglassesKhronos/index.js index 2c69f42f7..9734d3a6a 100644 --- a/examples/gltf/gltfExtensions/iridescence/sunglassesKhronos/index.js +++ b/examples/gltf/gltfExtensions/iridescence/sunglassesKhronos/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../../dist/index.js?t=1770713934910"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -42,11 +42,11 @@ function loadGLTF(view, url) { } const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { createIblHelper, setDebugButtons - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770713934910'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/gltfExtensions/sheen/chairDamaskPurplegold/index.html b/examples/gltf/gltfExtensions/sheen/chairDamaskPurplegold/index.html index c7c14d3dd..004b73e31 100644 --- a/examples/gltf/gltfExtensions/sheen/chairDamaskPurplegold/index.html +++ b/examples/gltf/gltfExtensions/sheen/chairDamaskPurplegold/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/gltfExtensions/sheen/chairDamaskPurplegold/index.js b/examples/gltf/gltfExtensions/sheen/chairDamaskPurplegold/index.js index dc9201dc2..4f4c560d6 100644 --- a/examples/gltf/gltfExtensions/sheen/chairDamaskPurplegold/index.js +++ b/examples/gltf/gltfExtensions/sheen/chairDamaskPurplegold/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../../dist/index.js?t=1770713934910"; import { loadingProgressInfoHandler -} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' +} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770713934910' const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -57,11 +57,11 @@ const loadGLTF = async (view, url) => { } const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { createIblHelper, setDebugButtons - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770713934910'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/gltfExtensions/sheen/compareSheen/index.html b/examples/gltf/gltfExtensions/sheen/compareSheen/index.html index c7c14d3dd..004b73e31 100644 --- a/examples/gltf/gltfExtensions/sheen/compareSheen/index.html +++ b/examples/gltf/gltfExtensions/sheen/compareSheen/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/gltfExtensions/sheen/compareSheen/index.js b/examples/gltf/gltfExtensions/sheen/compareSheen/index.js index f98f8e6ef..f02d7781f 100644 --- a/examples/gltf/gltfExtensions/sheen/compareSheen/index.js +++ b/examples/gltf/gltfExtensions/sheen/compareSheen/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../../dist/index.js?t=1770713934910"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -40,11 +40,11 @@ function loadGLTF(view, url) { } const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { createIblHelper, setDebugButtons - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770713934910'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/gltfExtensions/sheen/glamVelvetSofa/index.html b/examples/gltf/gltfExtensions/sheen/glamVelvetSofa/index.html index c7c14d3dd..004b73e31 100644 --- a/examples/gltf/gltfExtensions/sheen/glamVelvetSofa/index.html +++ b/examples/gltf/gltfExtensions/sheen/glamVelvetSofa/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/gltfExtensions/sheen/glamVelvetSofa/index.js b/examples/gltf/gltfExtensions/sheen/glamVelvetSofa/index.js index bd7007ba1..5f3027432 100644 --- a/examples/gltf/gltfExtensions/sheen/glamVelvetSofa/index.js +++ b/examples/gltf/gltfExtensions/sheen/glamVelvetSofa/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../../dist/index.js?t=1770713934910"; import { loadingProgressInfoHandler -} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' +} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770713934910' const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -57,11 +57,11 @@ const loadGLTF = async (view, url) => { } const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { createIblHelper, setDebugButtons - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770713934910'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/gltfExtensions/sheen/sheenChair/index.html b/examples/gltf/gltfExtensions/sheen/sheenChair/index.html index c7c14d3dd..004b73e31 100644 --- a/examples/gltf/gltfExtensions/sheen/sheenChair/index.html +++ b/examples/gltf/gltfExtensions/sheen/sheenChair/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/gltfExtensions/sheen/sheenChair/index.js b/examples/gltf/gltfExtensions/sheen/sheenChair/index.js index deafbc3e3..78158c1c2 100644 --- a/examples/gltf/gltfExtensions/sheen/sheenChair/index.js +++ b/examples/gltf/gltfExtensions/sheen/sheenChair/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../../dist/index.js?t=1770713934910"; import { loadingProgressInfoHandler -} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' +} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770713934910' const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -57,11 +57,11 @@ const loadGLTF = async (view, url) => { } const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { createIblHelper, setDebugButtons - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770713934910'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/gltfExtensions/sheen/sheenCloth/index.html b/examples/gltf/gltfExtensions/sheen/sheenCloth/index.html index c7c14d3dd..004b73e31 100644 --- a/examples/gltf/gltfExtensions/sheen/sheenCloth/index.html +++ b/examples/gltf/gltfExtensions/sheen/sheenCloth/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/gltfExtensions/sheen/sheenCloth/index.js b/examples/gltf/gltfExtensions/sheen/sheenCloth/index.js index 7bdd37429..c6751a98d 100644 --- a/examples/gltf/gltfExtensions/sheen/sheenCloth/index.js +++ b/examples/gltf/gltfExtensions/sheen/sheenCloth/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../../dist/index.js?t=1770713934910"; import { loadingProgressInfoHandler -} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' +} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770713934910' const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -57,11 +57,11 @@ const loadGLTF = async (view, url) => { } const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { createIblHelper, setDebugButtons - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770713934910'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/gltfExtensions/sheen/sheenTestGrid/index.html b/examples/gltf/gltfExtensions/sheen/sheenTestGrid/index.html index c7c14d3dd..004b73e31 100644 --- a/examples/gltf/gltfExtensions/sheen/sheenTestGrid/index.html +++ b/examples/gltf/gltfExtensions/sheen/sheenTestGrid/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/gltfExtensions/sheen/sheenTestGrid/index.js b/examples/gltf/gltfExtensions/sheen/sheenTestGrid/index.js index fd30a81b4..21aad0b99 100644 --- a/examples/gltf/gltfExtensions/sheen/sheenTestGrid/index.js +++ b/examples/gltf/gltfExtensions/sheen/sheenTestGrid/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../../dist/index.js?t=1770713934910"; import { loadingProgressInfoHandler -} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' +} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770713934910' const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -57,11 +57,11 @@ const loadGLTF = async (view, url) => { } const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { createIblHelper, setDebugButtons - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770713934910'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/gltfExtensions/sheen/sheenWoodLeatherSofa/index.html b/examples/gltf/gltfExtensions/sheen/sheenWoodLeatherSofa/index.html index c7c14d3dd..004b73e31 100644 --- a/examples/gltf/gltfExtensions/sheen/sheenWoodLeatherSofa/index.html +++ b/examples/gltf/gltfExtensions/sheen/sheenWoodLeatherSofa/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/gltfExtensions/sheen/sheenWoodLeatherSofa/index.js b/examples/gltf/gltfExtensions/sheen/sheenWoodLeatherSofa/index.js index 5e87163b0..b8b6a7bd7 100644 --- a/examples/gltf/gltfExtensions/sheen/sheenWoodLeatherSofa/index.js +++ b/examples/gltf/gltfExtensions/sheen/sheenWoodLeatherSofa/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../../dist/index.js?t=1770713934910"; import { loadingProgressInfoHandler -} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' +} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770713934910' const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -57,11 +57,11 @@ const loadGLTF = async (view, url) => { } const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { createIblHelper, setDebugButtons - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770713934910'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/gltfExtensions/specular/compareSpecular/index.html b/examples/gltf/gltfExtensions/specular/compareSpecular/index.html index c7c14d3dd..004b73e31 100644 --- a/examples/gltf/gltfExtensions/specular/compareSpecular/index.html +++ b/examples/gltf/gltfExtensions/specular/compareSpecular/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/gltfExtensions/specular/compareSpecular/index.js b/examples/gltf/gltfExtensions/specular/compareSpecular/index.js index ba847620d..c7fff4b01 100644 --- a/examples/gltf/gltfExtensions/specular/compareSpecular/index.js +++ b/examples/gltf/gltfExtensions/specular/compareSpecular/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../../dist/index.js?t=1770713934910"; import { loadingProgressInfoHandler -} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' +} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770713934910' const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -57,11 +57,11 @@ const loadGLTF = async (view, url) => { } const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { createIblHelper, setDebugButtons - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770713934910'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/gltfExtensions/specular/specularSilkPouf/index.html b/examples/gltf/gltfExtensions/specular/specularSilkPouf/index.html index c7c14d3dd..004b73e31 100644 --- a/examples/gltf/gltfExtensions/specular/specularSilkPouf/index.html +++ b/examples/gltf/gltfExtensions/specular/specularSilkPouf/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/gltfExtensions/specular/specularSilkPouf/index.js b/examples/gltf/gltfExtensions/specular/specularSilkPouf/index.js index 5fcb1de4c..615f28066 100644 --- a/examples/gltf/gltfExtensions/specular/specularSilkPouf/index.js +++ b/examples/gltf/gltfExtensions/specular/specularSilkPouf/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../../dist/index.js?t=1770713934910"; import { loadingProgressInfoHandler -} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' +} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770713934910' const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -57,11 +57,11 @@ const loadGLTF = async (view, url) => { } const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { createIblHelper, setDebugButtons - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770713934910'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/gltfExtensions/specular/specularTest/index.html b/examples/gltf/gltfExtensions/specular/specularTest/index.html index c7c14d3dd..004b73e31 100644 --- a/examples/gltf/gltfExtensions/specular/specularTest/index.html +++ b/examples/gltf/gltfExtensions/specular/specularTest/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/gltfExtensions/specular/specularTest/index.js b/examples/gltf/gltfExtensions/specular/specularTest/index.js index 5385d9797..fb1d632e4 100644 --- a/examples/gltf/gltfExtensions/specular/specularTest/index.js +++ b/examples/gltf/gltfExtensions/specular/specularTest/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../../dist/index.js?t=1770713934910"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -40,11 +40,11 @@ function loadGLTF(view, url) { } const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { createIblHelper, setDebugButtons - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770713934910'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/gltfExtensions/textureTransform/textureTransformMultiTest/index.html b/examples/gltf/gltfExtensions/textureTransform/textureTransformMultiTest/index.html index c7c14d3dd..004b73e31 100644 --- a/examples/gltf/gltfExtensions/textureTransform/textureTransformMultiTest/index.html +++ b/examples/gltf/gltfExtensions/textureTransform/textureTransformMultiTest/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/gltfExtensions/textureTransform/textureTransformMultiTest/index.js b/examples/gltf/gltfExtensions/textureTransform/textureTransformMultiTest/index.js index c73700e55..3fc2de3c8 100644 --- a/examples/gltf/gltfExtensions/textureTransform/textureTransformMultiTest/index.js +++ b/examples/gltf/gltfExtensions/textureTransform/textureTransformMultiTest/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../../dist/index.js?t=1770713934910"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -40,11 +40,11 @@ function loadGLTF(view, url) { } const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { createIblHelper, setDebugButtons - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770713934910'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/gltfExtensions/textureTransform/textureTransformTest/index.html b/examples/gltf/gltfExtensions/textureTransform/textureTransformTest/index.html index c7c14d3dd..004b73e31 100644 --- a/examples/gltf/gltfExtensions/textureTransform/textureTransformTest/index.html +++ b/examples/gltf/gltfExtensions/textureTransform/textureTransformTest/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/gltfExtensions/textureTransform/textureTransformTest/index.js b/examples/gltf/gltfExtensions/textureTransform/textureTransformTest/index.js index cac2ba455..d7d8538a2 100644 --- a/examples/gltf/gltfExtensions/textureTransform/textureTransformTest/index.js +++ b/examples/gltf/gltfExtensions/textureTransform/textureTransformTest/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../../dist/index.js?t=1770713934910"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -41,11 +41,11 @@ function loadGLTF(view, url) { } const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { createIblHelper, setDebugButtons - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770713934910'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/gltfExtensions/transmission/chronographWatch/index.html b/examples/gltf/gltfExtensions/transmission/chronographWatch/index.html index c7c14d3dd..004b73e31 100644 --- a/examples/gltf/gltfExtensions/transmission/chronographWatch/index.html +++ b/examples/gltf/gltfExtensions/transmission/chronographWatch/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/gltfExtensions/transmission/chronographWatch/index.js b/examples/gltf/gltfExtensions/transmission/chronographWatch/index.js index 6fc29e875..afca76f2c 100644 --- a/examples/gltf/gltfExtensions/transmission/chronographWatch/index.js +++ b/examples/gltf/gltfExtensions/transmission/chronographWatch/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../../dist/index.js?t=1770713934910"; import { loadingProgressInfoHandler -} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' +} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770713934910' const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -57,11 +57,11 @@ const loadGLTF = async (view, url) => { } const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { createIblHelper, setDebugButtons - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770713934910'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/gltfExtensions/transmission/commercialRefrigerator/index.html b/examples/gltf/gltfExtensions/transmission/commercialRefrigerator/index.html index c7c14d3dd..004b73e31 100644 --- a/examples/gltf/gltfExtensions/transmission/commercialRefrigerator/index.html +++ b/examples/gltf/gltfExtensions/transmission/commercialRefrigerator/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/gltfExtensions/transmission/commercialRefrigerator/index.js b/examples/gltf/gltfExtensions/transmission/commercialRefrigerator/index.js index 52505e301..8d77cd631 100644 --- a/examples/gltf/gltfExtensions/transmission/commercialRefrigerator/index.js +++ b/examples/gltf/gltfExtensions/transmission/commercialRefrigerator/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../../dist/index.js?t=1770713934910"; import { loadingProgressInfoHandler -} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' +} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770713934910' const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -57,11 +57,11 @@ const loadGLTF = async (view, url) => { } const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { createIblHelper, setDebugButtons - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770713934910'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/gltfExtensions/transmission/compareTransmission/index.html b/examples/gltf/gltfExtensions/transmission/compareTransmission/index.html index c7c14d3dd..004b73e31 100644 --- a/examples/gltf/gltfExtensions/transmission/compareTransmission/index.html +++ b/examples/gltf/gltfExtensions/transmission/compareTransmission/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/gltfExtensions/transmission/compareTransmission/index.js b/examples/gltf/gltfExtensions/transmission/compareTransmission/index.js index 15a5e6972..84a7460a1 100644 --- a/examples/gltf/gltfExtensions/transmission/compareTransmission/index.js +++ b/examples/gltf/gltfExtensions/transmission/compareTransmission/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../../dist/index.js?t=1770713934910"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -40,11 +40,11 @@ function loadGLTF(view, url) { } const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { createIblHelper, setDebugButtons - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770713934910'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/gltfExtensions/transmission/mosquitoInAmber/index.html b/examples/gltf/gltfExtensions/transmission/mosquitoInAmber/index.html index c7c14d3dd..004b73e31 100644 --- a/examples/gltf/gltfExtensions/transmission/mosquitoInAmber/index.html +++ b/examples/gltf/gltfExtensions/transmission/mosquitoInAmber/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/gltfExtensions/transmission/mosquitoInAmber/index.js b/examples/gltf/gltfExtensions/transmission/mosquitoInAmber/index.js index 16dd9f29c..19d069144 100644 --- a/examples/gltf/gltfExtensions/transmission/mosquitoInAmber/index.js +++ b/examples/gltf/gltfExtensions/transmission/mosquitoInAmber/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../../dist/index.js?t=1770713934910"; import { loadingProgressInfoHandler -} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' +} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770713934910' const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -57,11 +57,11 @@ const loadGLTF = async (view, url) => { } const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { createIblHelper, setDebugButtons - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770713934910'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/gltfExtensions/transmission/stainedGlassLamp/index.html b/examples/gltf/gltfExtensions/transmission/stainedGlassLamp/index.html index c7c14d3dd..004b73e31 100644 --- a/examples/gltf/gltfExtensions/transmission/stainedGlassLamp/index.html +++ b/examples/gltf/gltfExtensions/transmission/stainedGlassLamp/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/gltfExtensions/transmission/stainedGlassLamp/index.js b/examples/gltf/gltfExtensions/transmission/stainedGlassLamp/index.js index e65b2d68c..ee2dcb4be 100644 --- a/examples/gltf/gltfExtensions/transmission/stainedGlassLamp/index.js +++ b/examples/gltf/gltfExtensions/transmission/stainedGlassLamp/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../../dist/index.js?t=1770713934910"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -40,11 +40,11 @@ function loadGLTF(view, url) { } const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { createIblHelper, setDebugButtons - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770713934910'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/gltfExtensions/transmission/transmissionRoughnessTest/index.html b/examples/gltf/gltfExtensions/transmission/transmissionRoughnessTest/index.html index c7c14d3dd..004b73e31 100644 --- a/examples/gltf/gltfExtensions/transmission/transmissionRoughnessTest/index.html +++ b/examples/gltf/gltfExtensions/transmission/transmissionRoughnessTest/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/gltfExtensions/transmission/transmissionRoughnessTest/index.js b/examples/gltf/gltfExtensions/transmission/transmissionRoughnessTest/index.js index 9d820679b..2171e7086 100644 --- a/examples/gltf/gltfExtensions/transmission/transmissionRoughnessTest/index.js +++ b/examples/gltf/gltfExtensions/transmission/transmissionRoughnessTest/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../../dist/index.js?t=1770713934910"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -40,11 +40,11 @@ function loadGLTF(view, url) { } const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { createIblHelper, setDebugButtons - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770713934910'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/gltfExtensions/transmission/transmissionTest/index.html b/examples/gltf/gltfExtensions/transmission/transmissionTest/index.html index c7c14d3dd..004b73e31 100644 --- a/examples/gltf/gltfExtensions/transmission/transmissionTest/index.html +++ b/examples/gltf/gltfExtensions/transmission/transmissionTest/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/gltfExtensions/transmission/transmissionTest/index.js b/examples/gltf/gltfExtensions/transmission/transmissionTest/index.js index 982c1e01d..2a4f94b38 100644 --- a/examples/gltf/gltfExtensions/transmission/transmissionTest/index.js +++ b/examples/gltf/gltfExtensions/transmission/transmissionTest/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../../dist/index.js?t=1770713934910"; import { loadingProgressInfoHandler -} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' +} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770713934910' const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -57,11 +57,11 @@ const loadGLTF = async (view, url) => { } const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { createIblHelper, setDebugButtons - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770713934910'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/gltfExtensions/unlit/unlitTest/index.html b/examples/gltf/gltfExtensions/unlit/unlitTest/index.html index c7c14d3dd..004b73e31 100644 --- a/examples/gltf/gltfExtensions/unlit/unlitTest/index.html +++ b/examples/gltf/gltfExtensions/unlit/unlitTest/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/gltfExtensions/unlit/unlitTest/index.js b/examples/gltf/gltfExtensions/unlit/unlitTest/index.js index 6b3bce273..0c8f99483 100644 --- a/examples/gltf/gltfExtensions/unlit/unlitTest/index.js +++ b/examples/gltf/gltfExtensions/unlit/unlitTest/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../../dist/index.js?t=1770713934910"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -40,11 +40,11 @@ function loadGLTF(view, url) { } const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { createIblHelper, setDebugButtons - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770713934910'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/gltfExtensions/volume/IORTestGrid/index.html b/examples/gltf/gltfExtensions/volume/IORTestGrid/index.html index c7c14d3dd..004b73e31 100644 --- a/examples/gltf/gltfExtensions/volume/IORTestGrid/index.html +++ b/examples/gltf/gltfExtensions/volume/IORTestGrid/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/gltfExtensions/volume/IORTestGrid/index.js b/examples/gltf/gltfExtensions/volume/IORTestGrid/index.js index 5c3624c5e..e9b6d1715 100644 --- a/examples/gltf/gltfExtensions/volume/IORTestGrid/index.js +++ b/examples/gltf/gltfExtensions/volume/IORTestGrid/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../../dist/index.js?t=1770713934910"; import { loadingProgressInfoHandler -} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' +} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770713934910' const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -57,11 +57,11 @@ const loadGLTF = async (view, url) => { } const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { createIblHelper, setDebugButtons - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770713934910'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/gltfExtensions/volume/attenuationTest/index.html b/examples/gltf/gltfExtensions/volume/attenuationTest/index.html index c7c14d3dd..004b73e31 100644 --- a/examples/gltf/gltfExtensions/volume/attenuationTest/index.html +++ b/examples/gltf/gltfExtensions/volume/attenuationTest/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/gltfExtensions/volume/attenuationTest/index.js b/examples/gltf/gltfExtensions/volume/attenuationTest/index.js index 4a9a0ed0e..7fddce237 100644 --- a/examples/gltf/gltfExtensions/volume/attenuationTest/index.js +++ b/examples/gltf/gltfExtensions/volume/attenuationTest/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../../dist/index.js?t=1770713934910"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -40,11 +40,11 @@ function loadGLTF(view, url) { } const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { createIblHelper, setDebugButtons - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770713934910'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU, {useLight: false}); diff --git a/examples/gltf/gltfExtensions/volume/compareIor/index.html b/examples/gltf/gltfExtensions/volume/compareIor/index.html index c7c14d3dd..004b73e31 100644 --- a/examples/gltf/gltfExtensions/volume/compareIor/index.html +++ b/examples/gltf/gltfExtensions/volume/compareIor/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/gltfExtensions/volume/compareIor/index.js b/examples/gltf/gltfExtensions/volume/compareIor/index.js index 2b48a2eb0..e05daa2b1 100644 --- a/examples/gltf/gltfExtensions/volume/compareIor/index.js +++ b/examples/gltf/gltfExtensions/volume/compareIor/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../../dist/index.js?t=1770713934910"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -40,11 +40,11 @@ function loadGLTF(view, url) { } const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { createIblHelper, setDebugButtons - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770713934910'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/gltfExtensions/volume/compareVolume/index.html b/examples/gltf/gltfExtensions/volume/compareVolume/index.html index c7c14d3dd..004b73e31 100644 --- a/examples/gltf/gltfExtensions/volume/compareVolume/index.html +++ b/examples/gltf/gltfExtensions/volume/compareVolume/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/gltfExtensions/volume/compareVolume/index.js b/examples/gltf/gltfExtensions/volume/compareVolume/index.js index 5538a97bd..7c92b0e22 100644 --- a/examples/gltf/gltfExtensions/volume/compareVolume/index.js +++ b/examples/gltf/gltfExtensions/volume/compareVolume/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../../dist/index.js?t=1770713934910"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -40,11 +40,11 @@ function loadGLTF(view, url) { } const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { createIblHelper, setDebugButtons - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770713934910'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/gltfExtensions/volume/dragonAttenuation/index.html b/examples/gltf/gltfExtensions/volume/dragonAttenuation/index.html index c7c14d3dd..004b73e31 100644 --- a/examples/gltf/gltfExtensions/volume/dragonAttenuation/index.html +++ b/examples/gltf/gltfExtensions/volume/dragonAttenuation/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/gltfExtensions/volume/dragonAttenuation/index.js b/examples/gltf/gltfExtensions/volume/dragonAttenuation/index.js index eaa948564..a4dc5bb8a 100644 --- a/examples/gltf/gltfExtensions/volume/dragonAttenuation/index.js +++ b/examples/gltf/gltfExtensions/volume/dragonAttenuation/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../../dist/index.js?t=1770713934910"; import { loadingProgressInfoHandler -} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' +} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770713934910' const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -57,11 +57,11 @@ const loadGLTF = async (view, url) => { } const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { createIblHelper, setDebugButtons - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770713934910'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/gltfExtensions/volume/glassBrokenWindow/index.html b/examples/gltf/gltfExtensions/volume/glassBrokenWindow/index.html index c7c14d3dd..004b73e31 100644 --- a/examples/gltf/gltfExtensions/volume/glassBrokenWindow/index.html +++ b/examples/gltf/gltfExtensions/volume/glassBrokenWindow/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/gltfExtensions/volume/glassBrokenWindow/index.js b/examples/gltf/gltfExtensions/volume/glassBrokenWindow/index.js index 722ab31ea..b5d70cedc 100644 --- a/examples/gltf/gltfExtensions/volume/glassBrokenWindow/index.js +++ b/examples/gltf/gltfExtensions/volume/glassBrokenWindow/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../../dist/index.js?t=1770713934910"; import { loadingProgressInfoHandler -} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' +} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770713934910' const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -57,11 +57,11 @@ const loadGLTF = async (view, url) => { } const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { createIblHelper, setDebugButtons - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770713934910'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/gltfExtensions/volume/glassHurricaneCandleHolder/index.html b/examples/gltf/gltfExtensions/volume/glassHurricaneCandleHolder/index.html index c7c14d3dd..004b73e31 100644 --- a/examples/gltf/gltfExtensions/volume/glassHurricaneCandleHolder/index.html +++ b/examples/gltf/gltfExtensions/volume/glassHurricaneCandleHolder/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/gltfExtensions/volume/glassHurricaneCandleHolder/index.js b/examples/gltf/gltfExtensions/volume/glassHurricaneCandleHolder/index.js index 151f15b39..27388e5f5 100644 --- a/examples/gltf/gltfExtensions/volume/glassHurricaneCandleHolder/index.js +++ b/examples/gltf/gltfExtensions/volume/glassHurricaneCandleHolder/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../../dist/index.js?t=1770713934910"; import { loadingProgressInfoHandler -} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' +} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770713934910' const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -57,11 +57,11 @@ const loadGLTF = async (view, url) => { } const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { createIblHelper, setDebugButtons - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770713934910'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/gltfExtensions/volume/glassVaseFlowers/index.html b/examples/gltf/gltfExtensions/volume/glassVaseFlowers/index.html index c7c14d3dd..004b73e31 100644 --- a/examples/gltf/gltfExtensions/volume/glassVaseFlowers/index.html +++ b/examples/gltf/gltfExtensions/volume/glassVaseFlowers/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/gltfExtensions/volume/glassVaseFlowers/index.js b/examples/gltf/gltfExtensions/volume/glassVaseFlowers/index.js index 08358598f..052071c96 100644 --- a/examples/gltf/gltfExtensions/volume/glassVaseFlowers/index.js +++ b/examples/gltf/gltfExtensions/volume/glassVaseFlowers/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../../dist/index.js?t=1770713934910"; import { loadingProgressInfoHandler -} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' +} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770713934910' const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -57,11 +57,11 @@ const loadGLTF = async (view, url) => { } const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { createIblHelper, setDebugButtons - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770713934910'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/gltfExtensions/volume/transmissionThinwallTestGrid/index.html b/examples/gltf/gltfExtensions/volume/transmissionThinwallTestGrid/index.html index c7c14d3dd..004b73e31 100644 --- a/examples/gltf/gltfExtensions/volume/transmissionThinwallTestGrid/index.html +++ b/examples/gltf/gltfExtensions/volume/transmissionThinwallTestGrid/index.html @@ -8,8 +8,8 @@ - - + diff --git a/examples/gltf/gltfExtensions/volume/transmissionThinwallTestGrid/index.js b/examples/gltf/gltfExtensions/volume/transmissionThinwallTestGrid/index.js index 6267449f2..a6414836a 100644 --- a/examples/gltf/gltfExtensions/volume/transmissionThinwallTestGrid/index.js +++ b/examples/gltf/gltfExtensions/volume/transmissionThinwallTestGrid/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../../dist/index.js?t=1770713934910"; import { loadingProgressInfoHandler -} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' +} from '../../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770713934910' const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -57,11 +57,11 @@ const loadGLTF = async (view, url) => { } const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { createIblHelper, setDebugButtons - } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); + } = await import('../../../../exampleHelper/createExample/panes/index.js?t=1770713934910'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/models/aBeautifulGame/index.html b/examples/gltf/models/aBeautifulGame/index.html index 77d781697..91601ab7d 100644 --- a/examples/gltf/models/aBeautifulGame/index.html +++ b/examples/gltf/models/aBeautifulGame/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/gltf/models/aBeautifulGame/index.js b/examples/gltf/models/aBeautifulGame/index.js index e5cf346aa..59a692c8c 100644 --- a/examples/gltf/models/aBeautifulGame/index.js +++ b/examples/gltf/models/aBeautifulGame/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; import { loadingProgressInfoHandler -} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' +} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770713934910' const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -57,11 +57,11 @@ const loadGLTF = async (view, url) => { } const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { createIblHelper, setDebugButtons - } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); + } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770713934910'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/models/corset/index.html b/examples/gltf/models/corset/index.html index 77d781697..91601ab7d 100644 --- a/examples/gltf/models/corset/index.html +++ b/examples/gltf/models/corset/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/gltf/models/corset/index.js b/examples/gltf/models/corset/index.js index ba6252591..f5f50dad2 100644 --- a/examples/gltf/models/corset/index.js +++ b/examples/gltf/models/corset/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; import { loadingProgressInfoHandler -} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' +} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770713934910' const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -57,11 +57,11 @@ const loadGLTF = async (view, url) => { } const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { createIblHelper, setDebugButtons - } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); + } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770713934910'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/models/helmets/index.html b/examples/gltf/models/helmets/index.html index 77d781697..91601ab7d 100644 --- a/examples/gltf/models/helmets/index.html +++ b/examples/gltf/models/helmets/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/gltf/models/helmets/index.js b/examples/gltf/models/helmets/index.js index 54d3a0c60..9e42f10f9 100644 --- a/examples/gltf/models/helmets/index.js +++ b/examples/gltf/models/helmets/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; import { loadingProgressInfoHandler -} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' +} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770713934910' // 1. Create and append a canvas // 1. 캔버스를 생성하고 문서에 추가 @@ -99,11 +99,11 @@ function loadGLTFGrid(view, urls, gridSize = 4, spacing = 3) { } const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { createIblHelper, setDebugButtons - } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); + } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770713934910'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); diff --git a/examples/gltf/models/sponza/index.html b/examples/gltf/models/sponza/index.html index 77d781697..91601ab7d 100644 --- a/examples/gltf/models/sponza/index.html +++ b/examples/gltf/models/sponza/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/gltf/models/sponza/index.js b/examples/gltf/models/sponza/index.js index a3f74de2c..cd007d7a9 100644 --- a/examples/gltf/models/sponza/index.js +++ b/examples/gltf/models/sponza/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; import { loadingProgressInfoHandler -} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' +} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770713934910' const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -60,11 +60,11 @@ const loadGLTF = async (view, url) => { } const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { createIblHelper, setDebugButtons - } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); + } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770713934910'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/models/texcooredNTest/index.html b/examples/gltf/models/texcooredNTest/index.html index 77d781697..91601ab7d 100644 --- a/examples/gltf/models/texcooredNTest/index.html +++ b/examples/gltf/models/texcooredNTest/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/gltf/models/texcooredNTest/index.js b/examples/gltf/models/texcooredNTest/index.js index eb3a70959..fd45ff3fc 100644 --- a/examples/gltf/models/texcooredNTest/index.js +++ b/examples/gltf/models/texcooredNTest/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; import { loadingProgressInfoHandler -} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' +} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770713934910' const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -57,11 +57,11 @@ const loadGLTF = async (view, url) => { } const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { createIblHelper, setDebugButtons - } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); + } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770713934910'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/gltf/models/tokyo/index.html b/examples/gltf/models/tokyo/index.html index 77d781697..91601ab7d 100644 --- a/examples/gltf/models/tokyo/index.html +++ b/examples/gltf/models/tokyo/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/gltf/models/tokyo/index.js b/examples/gltf/models/tokyo/index.js index 7011a3b2f..39f277de2 100644 --- a/examples/gltf/models/tokyo/index.js +++ b/examples/gltf/models/tokyo/index.js @@ -1,7 +1,7 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; import { loadingProgressInfoHandler -} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770699661827' +} from '../../../exampleHelper/createExample/loadingProgressInfoHandler.js?t=1770713934910' const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -58,11 +58,11 @@ const loadGLTF = async (view, url) => { } const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { createIblHelper, setDebugButtons - } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770699661827'); + } = await import('../../../exampleHelper/createExample/panes/index.js?t=1770713934910'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/index.html b/examples/index.html index 3be700f10..7e41a123e 100644 --- a/examples/index.html +++ b/examples/index.html @@ -7,8 +7,8 @@ - - + + RedGPU Examples diff --git a/examples/index.js b/examples/index.js index f64837cd9..35e211768 100644 --- a/examples/index.js +++ b/examples/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../dist/index.js?t=1770699661827"; +import * as RedGPU from "../dist/index.js?t=1770713934910"; const canvas = document.createElement('canvas'); canvas.setAttribute('id', 'redGPUCanvas') diff --git a/examples/physics/advancedCharacterController/index.html b/examples/physics/advancedCharacterController/index.html index 9579c4497..5d843cc60 100644 --- a/examples/physics/advancedCharacterController/index.html +++ b/examples/physics/advancedCharacterController/index.html @@ -7,8 +7,8 @@ - - + + diff --git a/examples/physics/advancedCharacterController/index.js b/examples/physics/advancedCharacterController/index.js index 3c02c5b57..6843fae6c 100644 --- a/examples/physics/advancedCharacterController/index.js +++ b/examples/physics/advancedCharacterController/index.js @@ -1,5 +1,5 @@ -import * as RedGPU from "../../../dist/index.js?t=1770699661827"; -import { RapierPhysics } from "../../../dist/plugins/physics/rapier/index.js?t=1770699661827"; +import * as RedGPU from "../../../dist/index.js?t=1770713934910"; +import { RapierPhysics } from "../../../dist/plugins/physics/rapier/index.js?t=1770713934910"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -252,8 +252,8 @@ RedGPU.init( * @param {function} resetFunc */ const renderTestPane = async (redGPUContext, resetFunc) => { - const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); - const { setDebugButtons } = await import("../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); + const { setDebugButtons } = await import("../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext) const pane = new Pane(); pane.addBlade({ diff --git a/examples/physics/basic/index.html b/examples/physics/basic/index.html index 9579c4497..5d843cc60 100644 --- a/examples/physics/basic/index.html +++ b/examples/physics/basic/index.html @@ -7,8 +7,8 @@ - - + + diff --git a/examples/physics/basic/index.js b/examples/physics/basic/index.js index 22b1ffd3b..628556b24 100644 --- a/examples/physics/basic/index.js +++ b/examples/physics/basic/index.js @@ -1,5 +1,5 @@ -import * as RedGPU from "../../../dist/index.js?t=1770699661827"; -import { RapierPhysics } from "../../../dist/plugins/physics/rapier/index.js?t=1770699661827"; +import * as RedGPU from "../../../dist/index.js?t=1770713934910"; +import { RapierPhysics } from "../../../dist/plugins/physics/rapier/index.js?t=1770713934910"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -145,8 +145,8 @@ RedGPU.init( * @param {function} updateGravityY */ const renderTestPane = async (redGPUContext, physicsEngine, createBox, resetScene, updateGravityY) => { - const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); - const { setDebugButtons } = await import("../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); + const { setDebugButtons } = await import("../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext) const pane = new Pane(); diff --git a/examples/physics/bowling/index.html b/examples/physics/bowling/index.html index 9579c4497..5d843cc60 100644 --- a/examples/physics/bowling/index.html +++ b/examples/physics/bowling/index.html @@ -7,8 +7,8 @@ - - + + diff --git a/examples/physics/bowling/index.js b/examples/physics/bowling/index.js index e895ebcf5..639c997a6 100644 --- a/examples/physics/bowling/index.js +++ b/examples/physics/bowling/index.js @@ -1,5 +1,5 @@ -import * as RedGPU from "../../../dist/index.js?t=1770699661827"; -import { RapierPhysics } from "../../../dist/plugins/physics/rapier/index.js?t=1770699661827"; +import * as RedGPU from "../../../dist/index.js?t=1770713934910"; +import { RapierPhysics } from "../../../dist/plugins/physics/rapier/index.js?t=1770713934910"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -194,8 +194,8 @@ RedGPU.init( * @param {function} resetGame */ const renderTestPane = async (redGPUContext, throwBall, resetGame) => { - const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); - const { setDebugButtons } = await import("../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); + const { setDebugButtons } = await import("../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext) const pane = new Pane(); diff --git a/examples/physics/buoyancy/index.html b/examples/physics/buoyancy/index.html index 7f22fb32d..a60d33a4f 100644 --- a/examples/physics/buoyancy/index.html +++ b/examples/physics/buoyancy/index.html @@ -13,8 +13,8 @@ - - + + diff --git a/examples/physics/buoyancy/index.js b/examples/physics/buoyancy/index.js index 8ee424cbc..ff98ebe89 100644 --- a/examples/physics/buoyancy/index.js +++ b/examples/physics/buoyancy/index.js @@ -1,5 +1,5 @@ -import * as RedGPU from "../../../dist/index.js?t=1770699661827"; -import { RapierPhysics } from "../../../dist/plugins/physics/rapier/index.js?t=1770699661827"; +import * as RedGPU from "../../../dist/index.js?t=1770713934910"; +import { RapierPhysics } from "../../../dist/plugins/physics/rapier/index.js?t=1770713934910"; const canvas = document.body.appendChild(document.createElement('canvas')); @@ -228,8 +228,8 @@ RedGPU.init( * @param {function} resetScene */ const renderTestPane = async (redGPUContext, createObject, resetScene) => { - const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); - const { setDebugButtons } = await import("../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); + const { setDebugButtons } = await import("../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext) const pane = new Pane(); diff --git a/examples/physics/characterController/index.html b/examples/physics/characterController/index.html index 9579c4497..5d843cc60 100644 --- a/examples/physics/characterController/index.html +++ b/examples/physics/characterController/index.html @@ -7,8 +7,8 @@ - - + + diff --git a/examples/physics/characterController/index.js b/examples/physics/characterController/index.js index 916386996..dabfd4857 100644 --- a/examples/physics/characterController/index.js +++ b/examples/physics/characterController/index.js @@ -1,5 +1,5 @@ -import * as RedGPU from "../../../dist/index.js?t=1770699661827"; -import { RapierPhysics } from "../../../dist/plugins/physics/rapier/index.js?t=1770699661827"; +import * as RedGPU from "../../../dist/index.js?t=1770713934910"; +import { RapierPhysics } from "../../../dist/plugins/physics/rapier/index.js?t=1770713934910"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -187,8 +187,8 @@ RedGPU.init( * @param {function} resetCharacter */ const renderTestPane = async (redGPUContext, resetCharacter) => { - const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); - const { setDebugButtons } = await import("../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); + const { setDebugButtons } = await import("../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext) const pane = new Pane(); pane.addBlade({ diff --git a/examples/physics/collisionEvents/index.html b/examples/physics/collisionEvents/index.html index 52799e64c..34a7bfffe 100644 --- a/examples/physics/collisionEvents/index.html +++ b/examples/physics/collisionEvents/index.html @@ -13,8 +13,8 @@ - - + + diff --git a/examples/physics/collisionEvents/index.js b/examples/physics/collisionEvents/index.js index 5fa253071..9b9e16905 100644 --- a/examples/physics/collisionEvents/index.js +++ b/examples/physics/collisionEvents/index.js @@ -1,5 +1,5 @@ -import * as RedGPU from "../../../dist/index.js?t=1770699661827"; -import { RapierPhysics } from "../../../dist/plugins/physics/rapier/index.js?t=1770699661827"; +import * as RedGPU from "../../../dist/index.js?t=1770713934910"; +import { RapierPhysics } from "../../../dist/plugins/physics/rapier/index.js?t=1770713934910"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -142,8 +142,8 @@ RedGPU.init( * @param {function} resetScene */ const renderTestPane = async (redGPUContext, createBall, resetScene) => { - const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); - const { setDebugButtons } = await import("../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); + const { setDebugButtons } = await import("../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext) const pane = new Pane(); pane.addButton({ title: 'Spawn Ball' }).on('click', () => createBall((Math.random() * 2) - 1, 10, (Math.random() * 2) - 1)); diff --git a/examples/physics/collisionFiltering/index.html b/examples/physics/collisionFiltering/index.html index 9579c4497..5d843cc60 100644 --- a/examples/physics/collisionFiltering/index.html +++ b/examples/physics/collisionFiltering/index.html @@ -7,8 +7,8 @@ - - + + diff --git a/examples/physics/collisionFiltering/index.js b/examples/physics/collisionFiltering/index.js index 31383639b..dca14cf08 100644 --- a/examples/physics/collisionFiltering/index.js +++ b/examples/physics/collisionFiltering/index.js @@ -1,5 +1,5 @@ -import * as RedGPU from "../../../dist/index.js?t=1770699661827"; -import { RapierPhysics } from "../../../dist/plugins/physics/rapier/index.js?t=1770699661827"; +import * as RedGPU from "../../../dist/index.js?t=1770713934910"; +import { RapierPhysics } from "../../../dist/plugins/physics/rapier/index.js?t=1770713934910"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -170,8 +170,8 @@ RedGPU.init( * @param {function} resetScene */ const renderTestPane = async (redGPUContext, resetScene) => { - const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); - const { setDebugButtons } = await import("../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); + const { setDebugButtons } = await import("../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext) const pane = new Pane(); pane.addBlade({ diff --git a/examples/physics/compound/index.html b/examples/physics/compound/index.html index 377a8d38a..7f40223ed 100644 --- a/examples/physics/compound/index.html +++ b/examples/physics/compound/index.html @@ -16,8 +16,8 @@ - - + + diff --git a/examples/physics/compound/index.js b/examples/physics/compound/index.js index 74d180841..17896d5b9 100644 --- a/examples/physics/compound/index.js +++ b/examples/physics/compound/index.js @@ -1,5 +1,5 @@ -import * as RedGPU from "../../../dist/index.js?t=1770699661827"; -import { RapierPhysics } from "../../../dist/plugins/physics/rapier/index.js?t=1770699661827"; +import * as RedGPU from "../../../dist/index.js?t=1770713934910"; +import { RapierPhysics } from "../../../dist/plugins/physics/rapier/index.js?t=1770713934910"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -174,8 +174,8 @@ RedGPU.init( * @param {Array} activeDumbbells */ const renderTestPane = async (redGPUContext, createDumbbell, resetScene, activeDumbbells) => { - const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); - const { setDebugButtons } = await import("../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); + const { setDebugButtons } = await import("../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext) const pane = new Pane(); diff --git a/examples/physics/explosion/index.html b/examples/physics/explosion/index.html index d3d191a6d..ee1513045 100644 --- a/examples/physics/explosion/index.html +++ b/examples/physics/explosion/index.html @@ -13,8 +13,8 @@ - - + + diff --git a/examples/physics/explosion/index.js b/examples/physics/explosion/index.js index cb403b5f9..28323a689 100644 --- a/examples/physics/explosion/index.js +++ b/examples/physics/explosion/index.js @@ -1,5 +1,5 @@ -import * as RedGPU from "../../../dist/index.js?t=1770699661827"; -import { RapierPhysics } from "../../../dist/plugins/physics/rapier/index.js?t=1770699661827"; +import * as RedGPU from "../../../dist/index.js?t=1770713934910"; +import { RapierPhysics } from "../../../dist/plugins/physics/rapier/index.js?t=1770713934910"; const canvas = document.body.appendChild(document.createElement('canvas')); @@ -97,8 +97,8 @@ RedGPU.init( * @param {Array} activeBoxes */ const renderTestPane = async (redGPUContext, activeBoxes) => { - const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); - const { setDebugButtons } = await import("../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); + const { setDebugButtons } = await import("../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); pane.addBlade({ view: 'text', label: 'Interaction', value: 'Click to EXPLODE & SPAWN!', parse: (v) => v, readonly: true }); diff --git a/examples/physics/galton/index.html b/examples/physics/galton/index.html index 22f5b4a9e..80633ec75 100644 --- a/examples/physics/galton/index.html +++ b/examples/physics/galton/index.html @@ -13,8 +13,8 @@ - - + + diff --git a/examples/physics/galton/index.js b/examples/physics/galton/index.js index daa329e12..dd0f0c309 100644 --- a/examples/physics/galton/index.js +++ b/examples/physics/galton/index.js @@ -1,5 +1,5 @@ -import * as RedGPU from "../../../dist/index.js?t=1770699661827"; -import { RapierPhysics } from "../../../dist/plugins/physics/rapier/index.js?t=1770699661827"; +import * as RedGPU from "../../../dist/index.js?t=1770713934910"; +import { RapierPhysics } from "../../../dist/plugins/physics/rapier/index.js?t=1770713934910"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -180,8 +180,8 @@ RedGPU.init( * @param {function} resetScene */ const renderTestPane = async (redGPUContext, intervalId, createBall, resetScene) => { - const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); - const { setDebugButtons } = await import("../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); + const { setDebugButtons } = await import("../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext) const pane = new Pane(); const params = { diff --git a/examples/physics/gltfPhysics/index.html b/examples/physics/gltfPhysics/index.html index 9579c4497..5d843cc60 100644 --- a/examples/physics/gltfPhysics/index.html +++ b/examples/physics/gltfPhysics/index.html @@ -7,8 +7,8 @@ - - + + diff --git a/examples/physics/gltfPhysics/index.js b/examples/physics/gltfPhysics/index.js index fae351a7a..427ac1ba0 100644 --- a/examples/physics/gltfPhysics/index.js +++ b/examples/physics/gltfPhysics/index.js @@ -1,5 +1,5 @@ -import * as RedGPU from "../../../dist/index.js?t=1770699661827"; -import { RapierPhysics } from "../../../dist/plugins/physics/rapier/index.js?t=1770699661827"; +import * as RedGPU from "../../../dist/index.js?t=1770713934910"; +import { RapierPhysics } from "../../../dist/plugins/physics/rapier/index.js?t=1770713934910"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -149,8 +149,8 @@ RedGPU.init( * @param {function} resetScene */ const renderTestPane = async (redGPUContext, resetScene) => { - const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); - const { setDebugButtons } = await import("../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); + const { setDebugButtons } = await import("../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext) const pane = new Pane(); pane.addButton({ title: 'Reset Balls' }).on('click', () => resetScene()); diff --git a/examples/physics/heightField/index.html b/examples/physics/heightField/index.html index c81983f64..217918449 100644 --- a/examples/physics/heightField/index.html +++ b/examples/physics/heightField/index.html @@ -7,8 +7,8 @@ - - + + diff --git a/examples/physics/heightField/index.js b/examples/physics/heightField/index.js index af881ba95..a92771c7e 100644 --- a/examples/physics/heightField/index.js +++ b/examples/physics/heightField/index.js @@ -1,5 +1,5 @@ -import * as RedGPU from "../../../dist/index.js?t=1770699661827"; -import { RapierPhysics } from "../../../dist/plugins/physics/rapier/index.js?t=1770699661827"; +import * as RedGPU from "../../../dist/index.js?t=1770713934910"; +import { RapierPhysics } from "../../../dist/plugins/physics/rapier/index.js?t=1770713934910"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -198,8 +198,8 @@ RedGPU.init( * @param {function} resetScene */ const renderTestPane = async (redGPUContext, physicsEngine, spawnSpheres, resetScene) => { - const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); - const { setDebugButtons } = await import("../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); + const { setDebugButtons } = await import("../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext) const pane = new Pane(); diff --git a/examples/physics/joints/index.html b/examples/physics/joints/index.html index 19526b034..345a1d6f4 100644 --- a/examples/physics/joints/index.html +++ b/examples/physics/joints/index.html @@ -13,8 +13,8 @@ - - + + diff --git a/examples/physics/joints/index.js b/examples/physics/joints/index.js index 727c33aa0..7220859b8 100644 --- a/examples/physics/joints/index.js +++ b/examples/physics/joints/index.js @@ -1,5 +1,5 @@ -import * as RedGPU from "../../../dist/index.js?t=1770699661827"; -import { RapierPhysics } from "../../../dist/plugins/physics/rapier/index.js?t=1770699661827"; +import * as RedGPU from "../../../dist/index.js?t=1770713934910"; +import { RapierPhysics } from "../../../dist/plugins/physics/rapier/index.js?t=1770713934910"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -205,8 +205,8 @@ RedGPU.init( * @param {function} resetScene */ const renderTestPane = async (redGPUContext, getBigBallBody, resetScene) => { - const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); - const { setDebugButtons } = await import("../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); + const { setDebugButtons } = await import("../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext) const pane = new Pane(); diff --git a/examples/physics/kinematic/index.html b/examples/physics/kinematic/index.html index fd39c2ee1..77fe5a79a 100644 --- a/examples/physics/kinematic/index.html +++ b/examples/physics/kinematic/index.html @@ -9,8 +9,8 @@ - - + + diff --git a/examples/physics/kinematic/index.js b/examples/physics/kinematic/index.js index bdbfeffd7..9317d63e5 100644 --- a/examples/physics/kinematic/index.js +++ b/examples/physics/kinematic/index.js @@ -1,5 +1,5 @@ -import * as RedGPU from "../../../dist/index.js?t=1770699661827"; -import { RapierPhysics } from "../../../dist/plugins/physics/rapier/index.js?t=1770699661827"; +import * as RedGPU from "../../../dist/index.js?t=1770713934910"; +import { RapierPhysics } from "../../../dist/plugins/physics/rapier/index.js?t=1770713934910"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -148,8 +148,8 @@ RedGPU.init( * @param {function} resetScene */ const renderTestPane = async (redGPUContext, resetScene) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); - const {setDebugButtons} = await import("../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); + const {setDebugButtons} = await import("../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext) const pane = new Pane(); pane.addButton({title: 'Reset Scene'}).on('click', () => resetScene()); diff --git a/examples/physics/meshCollider/index.html b/examples/physics/meshCollider/index.html index 8ccdf064c..f01a76dca 100644 --- a/examples/physics/meshCollider/index.html +++ b/examples/physics/meshCollider/index.html @@ -13,8 +13,8 @@ - - + + diff --git a/examples/physics/meshCollider/index.js b/examples/physics/meshCollider/index.js index fb1fbbdea..909e3cbe6 100644 --- a/examples/physics/meshCollider/index.js +++ b/examples/physics/meshCollider/index.js @@ -1,5 +1,5 @@ -import * as RedGPU from "../../../dist/index.js?t=1770699661827"; -import { RapierPhysics } from "../../../dist/plugins/physics/rapier/index.js?t=1770699661827"; +import * as RedGPU from "../../../dist/index.js?t=1770713934910"; +import { RapierPhysics } from "../../../dist/plugins/physics/rapier/index.js?t=1770713934910"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -191,8 +191,8 @@ RedGPU.init( * @param {function} resetScene */ const renderTestPane = async (redGPUContext, resetScene) => { - const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); - const { setDebugButtons } = await import("../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); + const { setDebugButtons } = await import("../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext) const pane = new Pane(); pane.addBlade({ diff --git a/examples/physics/prismaticJoint/index.html b/examples/physics/prismaticJoint/index.html index 4f357461c..7ffdf11b7 100644 --- a/examples/physics/prismaticJoint/index.html +++ b/examples/physics/prismaticJoint/index.html @@ -13,8 +13,8 @@ - - + + diff --git a/examples/physics/prismaticJoint/index.js b/examples/physics/prismaticJoint/index.js index 87ef8d4d1..41ead462b 100644 --- a/examples/physics/prismaticJoint/index.js +++ b/examples/physics/prismaticJoint/index.js @@ -1,5 +1,5 @@ -import * as RedGPU from "../../../dist/index.js?t=1770699661827"; -import { RapierPhysics } from "../../../dist/plugins/physics/rapier/index.js?t=1770699661827"; +import * as RedGPU from "../../../dist/index.js?t=1770713934910"; +import { RapierPhysics } from "../../../dist/plugins/physics/rapier/index.js?t=1770713934910"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -219,8 +219,8 @@ RedGPU.init( * @param {function} resetScene */ const renderTestPane = async (redGPUContext, platformBody, resetScene) => { - const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); - const { setDebugButtons } = await import("../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); + const { setDebugButtons } = await import("../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext) const pane = new Pane(); diff --git a/examples/physics/ragdoll/index.html b/examples/physics/ragdoll/index.html index 9579c4497..5d843cc60 100644 --- a/examples/physics/ragdoll/index.html +++ b/examples/physics/ragdoll/index.html @@ -7,8 +7,8 @@ - - + + diff --git a/examples/physics/ragdoll/index.js b/examples/physics/ragdoll/index.js index 620f5d039..163c0b423 100644 --- a/examples/physics/ragdoll/index.js +++ b/examples/physics/ragdoll/index.js @@ -1,5 +1,5 @@ -import * as RedGPU from "../../../dist/index.js?t=1770699661827"; -import { RapierPhysics } from "../../../dist/plugins/physics/rapier/index.js?t=1770699661827"; +import * as RedGPU from "../../../dist/index.js?t=1770713934910"; +import { RapierPhysics } from "../../../dist/plugins/physics/rapier/index.js?t=1770713934910"; const canvas = document.body.appendChild(document.createElement('canvas')); @@ -155,8 +155,8 @@ RedGPU.init( * @param {function} resetScene */ const renderTestPane = async (redGPUContext, spawnRagdoll, resetScene) => { - const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); - const { setDebugButtons } = await import("../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); + const { setDebugButtons } = await import("../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext) const pane = new Pane(); pane.addButton({ title: 'Spawn Ragdoll' }).on('click', () => spawnRagdoll((Math.random() * 10) - 5, (Math.random() * 10) - 5)); diff --git a/examples/physics/raycast/index.html b/examples/physics/raycast/index.html index 9a1ba4a65..53919f02b 100644 --- a/examples/physics/raycast/index.html +++ b/examples/physics/raycast/index.html @@ -13,8 +13,8 @@ - - + + diff --git a/examples/physics/raycast/index.js b/examples/physics/raycast/index.js index 96a7563a5..1c53351fe 100644 --- a/examples/physics/raycast/index.js +++ b/examples/physics/raycast/index.js @@ -1,5 +1,5 @@ -import * as RedGPU from "../../../dist/index.js?t=1770699661827"; -import { RapierPhysics } from "../../../dist/plugins/physics/rapier/index.js?t=1770699661827"; +import * as RedGPU from "../../../dist/index.js?t=1770713934910"; +import { RapierPhysics } from "../../../dist/plugins/physics/rapier/index.js?t=1770713934910"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -85,8 +85,8 @@ RedGPU.init( * @param {function} resetScene */ const renderTestPane = async (redGPUContext, resetScene) => { - const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); - const { setDebugButtons } = await import("../../../examples/exampleHelper/createExample/panes/index.js?t=1770699661827"); + const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); + const { setDebugButtons } = await import("../../../examples/exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); pane.addBlade({ view: 'text', label: 'Guide', value: 'Click boxes to push them!', parse: (v) => v, readonly: true }); diff --git a/examples/physics/revoluteJoint/index.html b/examples/physics/revoluteJoint/index.html index 021f6e9e9..cf284764c 100644 --- a/examples/physics/revoluteJoint/index.html +++ b/examples/physics/revoluteJoint/index.html @@ -13,8 +13,8 @@ - - + + diff --git a/examples/physics/revoluteJoint/index.js b/examples/physics/revoluteJoint/index.js index a65040a98..98ee31668 100644 --- a/examples/physics/revoluteJoint/index.js +++ b/examples/physics/revoluteJoint/index.js @@ -1,5 +1,5 @@ -import * as RedGPU from "../../../dist/index.js?t=1770699661827"; -import { RapierPhysics } from "../../../dist/plugins/physics/rapier/index.js?t=1770699661827"; +import * as RedGPU from "../../../dist/index.js?t=1770713934910"; +import { RapierPhysics } from "../../../dist/plugins/physics/rapier/index.js?t=1770713934910"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -216,8 +216,8 @@ RedGPU.init( * @param {function} resetScene */ const renderTestPane = async (redGPUContext, joint, resetScene) => { - const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); - const { setDebugButtons } = await import("../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); + const { setDebugButtons } = await import("../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext) const pane = new Pane(); diff --git a/examples/physics/shapes/index.html b/examples/physics/shapes/index.html index 9579c4497..5d843cc60 100644 --- a/examples/physics/shapes/index.html +++ b/examples/physics/shapes/index.html @@ -7,8 +7,8 @@ - - + + diff --git a/examples/physics/shapes/index.js b/examples/physics/shapes/index.js index 568f98662..e582ee2c6 100644 --- a/examples/physics/shapes/index.js +++ b/examples/physics/shapes/index.js @@ -1,5 +1,5 @@ -import * as RedGPU from "../../../dist/index.js?t=1770699661827"; -import { RapierPhysics } from "../../../dist/plugins/physics/rapier/index.js?t=1770699661827"; +import * as RedGPU from "../../../dist/index.js?t=1770713934910"; +import { RapierPhysics } from "../../../dist/plugins/physics/rapier/index.js?t=1770713934910"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -179,8 +179,8 @@ RedGPU.init( * @param {function} createPhysicalObject */ const renderTestPane = async (redGPUContext, resetScene, createPhysicalObject) => { - const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); - const { setDebugButtons } = await import("../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); + const { setDebugButtons } = await import("../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext) const pane = new Pane(); const params = { diff --git a/examples/physics/softBody/index.html b/examples/physics/softBody/index.html index c81983f64..217918449 100644 --- a/examples/physics/softBody/index.html +++ b/examples/physics/softBody/index.html @@ -7,8 +7,8 @@ - - + + diff --git a/examples/physics/softBody/index.js b/examples/physics/softBody/index.js index 7434540e3..8e1190496 100644 --- a/examples/physics/softBody/index.js +++ b/examples/physics/softBody/index.js @@ -1,5 +1,5 @@ -import * as RedGPU from "../../../dist/index.js?t=1770699661827"; -import { RapierPhysics } from "../../../dist/plugins/physics/rapier/index.js?t=1770699661827"; +import * as RedGPU from "../../../dist/index.js?t=1770713934910"; +import { RapierPhysics } from "../../../dist/plugins/physics/rapier/index.js?t=1770713934910"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -260,8 +260,8 @@ RedGPU.init( * @param {function} resetScene */ const renderTestPane = async (redGPUContext, clothMesh, spawnObject, windBlast, resetScene) => { - const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); - const { setDebugButtons } = await import("../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); + const { setDebugButtons } = await import("../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext) const pane = new Pane(); diff --git a/examples/physics/springJoint/index.html b/examples/physics/springJoint/index.html index 9579c4497..5d843cc60 100644 --- a/examples/physics/springJoint/index.html +++ b/examples/physics/springJoint/index.html @@ -7,8 +7,8 @@ - - + + diff --git a/examples/physics/springJoint/index.js b/examples/physics/springJoint/index.js index bb07cb5b6..95a01e22c 100644 --- a/examples/physics/springJoint/index.js +++ b/examples/physics/springJoint/index.js @@ -1,5 +1,5 @@ -import * as RedGPU from "../../../dist/index.js?t=1770699661827"; -import { RapierPhysics } from "../../../dist/plugins/physics/rapier/index.js?t=1770699661827"; +import * as RedGPU from "../../../dist/index.js?t=1770713934910"; +import { RapierPhysics } from "../../../dist/plugins/physics/rapier/index.js?t=1770713934910"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -208,7 +208,7 @@ RedGPU.init( // [KO] 8. 테스트 UI 구성: 플랫폼 충격 주기 및 오브젝트 제거 기능 // [EN] 8. Set up test UI: Platform kick and object clearing functions - const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const pane = new Pane(); const params = { diff --git a/examples/physics/stressTest/index.html b/examples/physics/stressTest/index.html index 3cf44c062..debc6545d 100644 --- a/examples/physics/stressTest/index.html +++ b/examples/physics/stressTest/index.html @@ -13,8 +13,8 @@ - - + + diff --git a/examples/physics/stressTest/index.js b/examples/physics/stressTest/index.js index 8292cd2b6..9ace57ce3 100644 --- a/examples/physics/stressTest/index.js +++ b/examples/physics/stressTest/index.js @@ -1,5 +1,5 @@ -import * as RedGPU from "../../../dist/index.js?t=1770699661827"; -import { RapierPhysics } from "../../../dist/plugins/physics/rapier/index.js?t=1770699661827"; +import * as RedGPU from "../../../dist/index.js?t=1770713934910"; +import { RapierPhysics } from "../../../dist/plugins/physics/rapier/index.js?t=1770713934910"; const canvas = document.body.appendChild(document.createElement('canvas')); @@ -132,8 +132,8 @@ RedGPU.init( * @param {Array} activeObjects */ const renderTestPane = async (redGPUContext, createBall, resetScene, activeObjects) => { - const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); - const { setDebugButtons } = await import("../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); + const { setDebugButtons } = await import("../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext) const pane = new Pane(); diff --git a/examples/physics/surfaceVelocity/index.html b/examples/physics/surfaceVelocity/index.html index 9579c4497..5d843cc60 100644 --- a/examples/physics/surfaceVelocity/index.html +++ b/examples/physics/surfaceVelocity/index.html @@ -7,8 +7,8 @@ - - + + diff --git a/examples/physics/surfaceVelocity/index.js b/examples/physics/surfaceVelocity/index.js index a0ee4686b..62ae4dbbd 100644 --- a/examples/physics/surfaceVelocity/index.js +++ b/examples/physics/surfaceVelocity/index.js @@ -1,5 +1,5 @@ -import * as RedGPU from "../../../dist/index.js?t=1770699661827"; -import { RapierPhysics } from "../../../dist/plugins/physics/rapier/index.js?t=1770699661827"; +import * as RedGPU from "../../../dist/index.js?t=1770713934910"; +import { RapierPhysics } from "../../../dist/plugins/physics/rapier/index.js?t=1770713934910"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -235,8 +235,8 @@ RedGPU.init( * @param {function} resetScene */ const renderTestPane = async (redGPUContext, resetScene) => { - const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); - const { setDebugButtons } = await import("../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); + const { setDebugButtons } = await import("../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext) const pane = new Pane(); pane.addBlade({ diff --git a/examples/physics/triggers/index.html b/examples/physics/triggers/index.html index 5b18e3aad..d85e95233 100644 --- a/examples/physics/triggers/index.html +++ b/examples/physics/triggers/index.html @@ -13,8 +13,8 @@ - - + + diff --git a/examples/physics/triggers/index.js b/examples/physics/triggers/index.js index e8e435ab3..08a92d7bf 100644 --- a/examples/physics/triggers/index.js +++ b/examples/physics/triggers/index.js @@ -1,5 +1,5 @@ -import * as RedGPU from "../../../dist/index.js?t=1770699661827"; -import { RapierPhysics } from "../../../dist/plugins/physics/rapier/index.js?t=1770699661827"; +import * as RedGPU from "../../../dist/index.js?t=1770713934910"; +import { RapierPhysics } from "../../../dist/plugins/physics/rapier/index.js?t=1770713934910"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -189,8 +189,8 @@ RedGPU.init( * @param {function} resetScene */ const renderTestPane = async (redGPUContext, scene, triggerMesh, resetScene) => { - const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); - const { setDebugButtons } = await import("../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const { Pane } = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); + const { setDebugButtons } = await import("../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext) const pane = new Pane(); diff --git a/examples/postEffect/adjustments/brightnessContrast/index.html b/examples/postEffect/adjustments/brightnessContrast/index.html index 112d2b5eb..d8d82028d 100644 --- a/examples/postEffect/adjustments/brightnessContrast/index.html +++ b/examples/postEffect/adjustments/brightnessContrast/index.html @@ -8,8 +8,8 @@ - - + +
diff --git a/examples/postEffect/adjustments/brightnessContrast/index.js b/examples/postEffect/adjustments/brightnessContrast/index.js index c879150a7..34443b05d 100644 --- a/examples/postEffect/adjustments/brightnessContrast/index.js +++ b/examples/postEffect/adjustments/brightnessContrast/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; // 1. Create and append a canvas // 1. 캔버스를 생성하고 문서에 추가 @@ -126,10 +126,10 @@ function loadGLTF(redGPUContext, scene, url) { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); - const {createPostEffectLabel} = await import('../../../exampleHelper/createExample/loadExampleInfo/createPostEffectLabel.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); + const {createPostEffectLabel} = await import('../../../exampleHelper/createExample/loadExampleInfo/createPostEffectLabel.js?t=1770713934910'); createPostEffectLabel('BrightnessContrast', redGPUContext.detector.isMobile) - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); diff --git a/examples/postEffect/adjustments/colorBalance/index.html b/examples/postEffect/adjustments/colorBalance/index.html index 112d2b5eb..d8d82028d 100644 --- a/examples/postEffect/adjustments/colorBalance/index.html +++ b/examples/postEffect/adjustments/colorBalance/index.html @@ -8,8 +8,8 @@ - - + +
diff --git a/examples/postEffect/adjustments/colorBalance/index.js b/examples/postEffect/adjustments/colorBalance/index.js index 3734e6194..679515804 100644 --- a/examples/postEffect/adjustments/colorBalance/index.js +++ b/examples/postEffect/adjustments/colorBalance/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; // 1. Create and append a canvas // 1. 캔버스를 생성하고 문서에 추가 @@ -126,10 +126,10 @@ function loadGLTF(redGPUContext, scene, url) { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); - const {createPostEffectLabel} = await import('../../../exampleHelper/createExample/loadExampleInfo/createPostEffectLabel.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); + const {createPostEffectLabel} = await import('../../../exampleHelper/createExample/loadExampleInfo/createPostEffectLabel.js?t=1770713934910'); createPostEffectLabel('ColorBalance', redGPUContext.detector.isMobile) - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); diff --git a/examples/postEffect/adjustments/colorTemperatureTint/index.html b/examples/postEffect/adjustments/colorTemperatureTint/index.html index 112d2b5eb..d8d82028d 100644 --- a/examples/postEffect/adjustments/colorTemperatureTint/index.html +++ b/examples/postEffect/adjustments/colorTemperatureTint/index.html @@ -8,8 +8,8 @@ - - + +
diff --git a/examples/postEffect/adjustments/colorTemperatureTint/index.js b/examples/postEffect/adjustments/colorTemperatureTint/index.js index 5a6beabaf..2a99f6b6c 100644 --- a/examples/postEffect/adjustments/colorTemperatureTint/index.js +++ b/examples/postEffect/adjustments/colorTemperatureTint/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; // 1. Create and append a canvas // 1. 캔버스를 생성하고 문서에 추가 @@ -127,10 +127,10 @@ function loadGLTF(redGPUContext, scene, url) { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); - const {createPostEffectLabel} = await import('../../../exampleHelper/createExample/loadExampleInfo/createPostEffectLabel.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); + const {createPostEffectLabel} = await import('../../../exampleHelper/createExample/loadExampleInfo/createPostEffectLabel.js?t=1770713934910'); createPostEffectLabel('ColorTemperatureTint', redGPUContext.detector.isMobile) - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); const effect = targetView.postEffectManager.getEffectAt(0); diff --git a/examples/postEffect/adjustments/grayscale/index.html b/examples/postEffect/adjustments/grayscale/index.html index 112d2b5eb..d8d82028d 100644 --- a/examples/postEffect/adjustments/grayscale/index.html +++ b/examples/postEffect/adjustments/grayscale/index.html @@ -8,8 +8,8 @@ - - + +
diff --git a/examples/postEffect/adjustments/grayscale/index.js b/examples/postEffect/adjustments/grayscale/index.js index e06a8d79b..6a149ba28 100644 --- a/examples/postEffect/adjustments/grayscale/index.js +++ b/examples/postEffect/adjustments/grayscale/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; // 1. Create and append a canvas // 1. 캔버스를 생성하고 문서에 추가 @@ -126,10 +126,10 @@ function loadGLTF(redGPUContext, scene, url) { * @param {RedGPU.Display.View3D} viewEffect */ const renderTestPane = async (redGPUContext, viewEffect) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); - const {createPostEffectLabel} = await import('../../../exampleHelper/createExample/loadExampleInfo/createPostEffectLabel.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); + const {createPostEffectLabel} = await import('../../../exampleHelper/createExample/loadExampleInfo/createPostEffectLabel.js?t=1770713934910'); createPostEffectLabel('Grayscale', redGPUContext.detector.isMobile) - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); const view = viewEffect diff --git a/examples/postEffect/adjustments/hueSaturation/index.html b/examples/postEffect/adjustments/hueSaturation/index.html index 112d2b5eb..d8d82028d 100644 --- a/examples/postEffect/adjustments/hueSaturation/index.html +++ b/examples/postEffect/adjustments/hueSaturation/index.html @@ -8,8 +8,8 @@ - - + +
diff --git a/examples/postEffect/adjustments/hueSaturation/index.js b/examples/postEffect/adjustments/hueSaturation/index.js index 8333b12a9..a296aa2b8 100644 --- a/examples/postEffect/adjustments/hueSaturation/index.js +++ b/examples/postEffect/adjustments/hueSaturation/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; // 1. Create and append a canvas // 1. 캔버스를 생성하고 문서에 추가 @@ -126,10 +126,10 @@ function loadGLTF(redGPUContext, scene, url) { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); - const {createPostEffectLabel} = await import('../../../exampleHelper/createExample/loadExampleInfo/createPostEffectLabel.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); + const {createPostEffectLabel} = await import('../../../exampleHelper/createExample/loadExampleInfo/createPostEffectLabel.js?t=1770713934910'); createPostEffectLabel('HueSaturation', redGPUContext.detector.isMobile) - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); diff --git a/examples/postEffect/adjustments/invert/index.html b/examples/postEffect/adjustments/invert/index.html index 112d2b5eb..d8d82028d 100644 --- a/examples/postEffect/adjustments/invert/index.html +++ b/examples/postEffect/adjustments/invert/index.html @@ -8,8 +8,8 @@ - - + +
diff --git a/examples/postEffect/adjustments/invert/index.js b/examples/postEffect/adjustments/invert/index.js index d0516165a..fcbdd59a2 100644 --- a/examples/postEffect/adjustments/invert/index.js +++ b/examples/postEffect/adjustments/invert/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; // 1. Create and append a canvas // 1. 캔버스를 생성하고 문서에 추가 @@ -126,10 +126,10 @@ function loadGLTF(redGPUContext, scene, url) { * @param {RedGPU.Display.View3D} viewEffect */ const renderTestPane = async (redGPUContext, viewEffect) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); - const {createPostEffectLabel} = await import('../../../exampleHelper/createExample/loadExampleInfo/createPostEffectLabel.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); + const {createPostEffectLabel} = await import('../../../exampleHelper/createExample/loadExampleInfo/createPostEffectLabel.js?t=1770713934910'); createPostEffectLabel('Invert', redGPUContext.detector.isMobile) - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); const view = viewEffect diff --git a/examples/postEffect/adjustments/threshold/index.html b/examples/postEffect/adjustments/threshold/index.html index 112d2b5eb..d8d82028d 100644 --- a/examples/postEffect/adjustments/threshold/index.html +++ b/examples/postEffect/adjustments/threshold/index.html @@ -8,8 +8,8 @@ - - + +
diff --git a/examples/postEffect/adjustments/threshold/index.js b/examples/postEffect/adjustments/threshold/index.js index b3f9f56a6..416b4bec8 100644 --- a/examples/postEffect/adjustments/threshold/index.js +++ b/examples/postEffect/adjustments/threshold/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; // 1. Create and append a canvas // 1. 캔버스를 생성하고 문서에 추가 @@ -126,10 +126,10 @@ function loadGLTF(redGPUContext, scene, url) { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); - const {createPostEffectLabel} = await import('../../../exampleHelper/createExample/loadExampleInfo/createPostEffectLabel.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); + const {createPostEffectLabel} = await import('../../../exampleHelper/createExample/loadExampleInfo/createPostEffectLabel.js?t=1770713934910'); createPostEffectLabel('Threshold', redGPUContext.detector.isMobile) - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); diff --git a/examples/postEffect/adjustments/vibrance/index.html b/examples/postEffect/adjustments/vibrance/index.html index 112d2b5eb..d8d82028d 100644 --- a/examples/postEffect/adjustments/vibrance/index.html +++ b/examples/postEffect/adjustments/vibrance/index.html @@ -8,8 +8,8 @@ - - + +
diff --git a/examples/postEffect/adjustments/vibrance/index.js b/examples/postEffect/adjustments/vibrance/index.js index 53c26b3a4..767428538 100644 --- a/examples/postEffect/adjustments/vibrance/index.js +++ b/examples/postEffect/adjustments/vibrance/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; // 1. Create and append a canvas // 1. 캔버스를 생성하고 문서에 추가 @@ -126,10 +126,10 @@ function loadGLTF(redGPUContext, scene, url) { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); - const {createPostEffectLabel} = await import('../../../exampleHelper/createExample/loadExampleInfo/createPostEffectLabel.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); + const {createPostEffectLabel} = await import('../../../exampleHelper/createExample/loadExampleInfo/createPostEffectLabel.js?t=1770713934910'); createPostEffectLabel('Vibrance', redGPUContext.detector.isMobile) - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); diff --git a/examples/postEffect/blur/blur/index.html b/examples/postEffect/blur/blur/index.html index 112d2b5eb..d8d82028d 100644 --- a/examples/postEffect/blur/blur/index.html +++ b/examples/postEffect/blur/blur/index.html @@ -8,8 +8,8 @@ - - + +
diff --git a/examples/postEffect/blur/blur/index.js b/examples/postEffect/blur/blur/index.js index bd1f9f26c..812302524 100644 --- a/examples/postEffect/blur/blur/index.js +++ b/examples/postEffect/blur/blur/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; // 1. Create and append a canvas // 1. 캔버스를 생성하고 문서에 추가 @@ -127,10 +127,10 @@ function loadGLTF(redGPUContext, scene, url) { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); - const {createPostEffectLabel} = await import('../../../exampleHelper/createExample/loadExampleInfo/createPostEffectLabel.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); + const {createPostEffectLabel} = await import('../../../exampleHelper/createExample/loadExampleInfo/createPostEffectLabel.js?t=1770713934910'); createPostEffectLabel('Blur', redGPUContext.detector.isMobile) - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); diff --git a/examples/postEffect/blur/blurX/index.html b/examples/postEffect/blur/blurX/index.html index 112d2b5eb..d8d82028d 100644 --- a/examples/postEffect/blur/blurX/index.html +++ b/examples/postEffect/blur/blurX/index.html @@ -8,8 +8,8 @@ - - + +
diff --git a/examples/postEffect/blur/blurX/index.js b/examples/postEffect/blur/blurX/index.js index 37a67d91c..26408a7dd 100644 --- a/examples/postEffect/blur/blurX/index.js +++ b/examples/postEffect/blur/blurX/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; // 1. Create and append a canvas // 1. 캔버스를 생성하고 문서에 추가 @@ -126,10 +126,10 @@ function loadGLTF(redGPUContext, scene, url) { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); - const {createPostEffectLabel} = await import('../../../exampleHelper/createExample/loadExampleInfo/createPostEffectLabel.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); + const {createPostEffectLabel} = await import('../../../exampleHelper/createExample/loadExampleInfo/createPostEffectLabel.js?t=1770713934910'); createPostEffectLabel('Blur', redGPUContext.detector.isMobile) - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); diff --git a/examples/postEffect/blur/blurY/index.html b/examples/postEffect/blur/blurY/index.html index 112d2b5eb..d8d82028d 100644 --- a/examples/postEffect/blur/blurY/index.html +++ b/examples/postEffect/blur/blurY/index.html @@ -8,8 +8,8 @@ - - + +
diff --git a/examples/postEffect/blur/blurY/index.js b/examples/postEffect/blur/blurY/index.js index 520a43924..a193f40cc 100644 --- a/examples/postEffect/blur/blurY/index.js +++ b/examples/postEffect/blur/blurY/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; // 1. Create and append a canvas // 1. 캔버스를 생성하고 문서에 추가 @@ -126,10 +126,10 @@ function loadGLTF(redGPUContext, scene, url) { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); - const {createPostEffectLabel} = await import('../../../exampleHelper/createExample/loadExampleInfo/createPostEffectLabel.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); + const {createPostEffectLabel} = await import('../../../exampleHelper/createExample/loadExampleInfo/createPostEffectLabel.js?t=1770713934910'); createPostEffectLabel('Blur', redGPUContext.detector.isMobile) - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); diff --git a/examples/postEffect/blur/directionalBlur/index.html b/examples/postEffect/blur/directionalBlur/index.html index 112d2b5eb..d8d82028d 100644 --- a/examples/postEffect/blur/directionalBlur/index.html +++ b/examples/postEffect/blur/directionalBlur/index.html @@ -8,8 +8,8 @@ - - + +
diff --git a/examples/postEffect/blur/directionalBlur/index.js b/examples/postEffect/blur/directionalBlur/index.js index 4c7eaf6c5..57638e6e0 100644 --- a/examples/postEffect/blur/directionalBlur/index.js +++ b/examples/postEffect/blur/directionalBlur/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; // 1. Create and append a canvas // 1. 캔버스를 생성하고 문서에 추가 @@ -126,10 +126,10 @@ function loadGLTF(redGPUContext, scene, url) { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); - const {createPostEffectLabel} = await import('../../../exampleHelper/createExample/loadExampleInfo/createPostEffectLabel.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); + const {createPostEffectLabel} = await import('../../../exampleHelper/createExample/loadExampleInfo/createPostEffectLabel.js?t=1770713934910'); createPostEffectLabel('DirectionalBlur', redGPUContext.detector.isMobile) - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); diff --git a/examples/postEffect/blur/gaussianBlur/index.html b/examples/postEffect/blur/gaussianBlur/index.html index 112d2b5eb..d8d82028d 100644 --- a/examples/postEffect/blur/gaussianBlur/index.html +++ b/examples/postEffect/blur/gaussianBlur/index.html @@ -8,8 +8,8 @@ - - + +
diff --git a/examples/postEffect/blur/gaussianBlur/index.js b/examples/postEffect/blur/gaussianBlur/index.js index 2b7b6edd5..2b58ab549 100644 --- a/examples/postEffect/blur/gaussianBlur/index.js +++ b/examples/postEffect/blur/gaussianBlur/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; // 1. Create and append a canvas // 1. 캔버스를 생성하고 문서에 추가 @@ -126,10 +126,10 @@ function loadGLTF(redGPUContext, scene, url) { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); - const {createPostEffectLabel} = await import('../../../exampleHelper/createExample/loadExampleInfo/createPostEffectLabel.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); + const {createPostEffectLabel} = await import('../../../exampleHelper/createExample/loadExampleInfo/createPostEffectLabel.js?t=1770713934910'); createPostEffectLabel('GaussianBlur', redGPUContext.detector.isMobile) - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); diff --git a/examples/postEffect/blur/radialBlur/index.html b/examples/postEffect/blur/radialBlur/index.html index 112d2b5eb..d8d82028d 100644 --- a/examples/postEffect/blur/radialBlur/index.html +++ b/examples/postEffect/blur/radialBlur/index.html @@ -8,8 +8,8 @@ - - + +
diff --git a/examples/postEffect/blur/radialBlur/index.js b/examples/postEffect/blur/radialBlur/index.js index 7913dac1c..50be86a05 100644 --- a/examples/postEffect/blur/radialBlur/index.js +++ b/examples/postEffect/blur/radialBlur/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; // 1. Create and append a canvas // 1. 캔버스를 생성하고 문서에 추가 @@ -126,10 +126,10 @@ function loadGLTF(redGPUContext, scene, url) { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); - const {createPostEffectLabel} = await import('../../../exampleHelper/createExample/loadExampleInfo/createPostEffectLabel.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); + const {createPostEffectLabel} = await import('../../../exampleHelper/createExample/loadExampleInfo/createPostEffectLabel.js?t=1770713934910'); createPostEffectLabel('RadialBlur', redGPUContext.detector.isMobile) - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); diff --git a/examples/postEffect/blur/zoomBlur/index.html b/examples/postEffect/blur/zoomBlur/index.html index 112d2b5eb..d8d82028d 100644 --- a/examples/postEffect/blur/zoomBlur/index.html +++ b/examples/postEffect/blur/zoomBlur/index.html @@ -8,8 +8,8 @@ - - + +
diff --git a/examples/postEffect/blur/zoomBlur/index.js b/examples/postEffect/blur/zoomBlur/index.js index fc83c9ebd..a8d38001d 100644 --- a/examples/postEffect/blur/zoomBlur/index.js +++ b/examples/postEffect/blur/zoomBlur/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; // 1. Create and append a canvas // 1. 캔버스를 생성하고 문서에 추가 @@ -126,10 +126,10 @@ function loadGLTF(redGPUContext, scene, url) { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); - const {createPostEffectLabel} = await import('../../../exampleHelper/createExample/loadExampleInfo/createPostEffectLabel.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); + const {createPostEffectLabel} = await import('../../../exampleHelper/createExample/loadExampleInfo/createPostEffectLabel.js?t=1770713934910'); createPostEffectLabel('ZoomBlur', redGPUContext.detector.isMobile) - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); diff --git a/examples/postEffect/convolution/index.html b/examples/postEffect/convolution/index.html index 470caed74..9d076917b 100644 --- a/examples/postEffect/convolution/index.html +++ b/examples/postEffect/convolution/index.html @@ -8,8 +8,8 @@ - - + +
diff --git a/examples/postEffect/convolution/index.js b/examples/postEffect/convolution/index.js index 624f2e38a..37b0f6a5f 100644 --- a/examples/postEffect/convolution/index.js +++ b/examples/postEffect/convolution/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../dist/index.js?t=1770713934910"; // 1. Create and append a canvas // 1. 캔버스를 생성하고 문서에 추가 @@ -126,10 +126,10 @@ function loadGLTF(redGPUContext, scene, url) { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); - const {createPostEffectLabel} = await import('../../exampleHelper/createExample/loadExampleInfo/createPostEffectLabel.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); + const {createPostEffectLabel} = await import('../../exampleHelper/createExample/loadExampleInfo/createPostEffectLabel.js?t=1770713934910'); createPostEffectLabel('Convolution', redGPUContext.detector.isMobile) - const {setDebugButtons} = await import("../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const {setDebugButtons} = await import("../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); const TEST_STATE = { diff --git a/examples/postEffect/filmGrain/index.html b/examples/postEffect/filmGrain/index.html index 470caed74..9d076917b 100644 --- a/examples/postEffect/filmGrain/index.html +++ b/examples/postEffect/filmGrain/index.html @@ -8,8 +8,8 @@ - - + +
diff --git a/examples/postEffect/filmGrain/index.js b/examples/postEffect/filmGrain/index.js index 1eb9af1a4..de080aedf 100644 --- a/examples/postEffect/filmGrain/index.js +++ b/examples/postEffect/filmGrain/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../dist/index.js?t=1770713934910"; // 1. Create and append a canvas // 1. 캔버스를 생성하고 문서에 추가 @@ -126,10 +126,10 @@ function loadGLTF(redGPUContext, scene, url) { * @param {RedGPU.Display.View3D} targetView */ const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); - const {createPostEffectLabel} = await import('../../exampleHelper/createExample/loadExampleInfo/createPostEffectLabel.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); + const {createPostEffectLabel} = await import('../../exampleHelper/createExample/loadExampleInfo/createPostEffectLabel.js?t=1770713934910'); createPostEffectLabel('FilmGrain', redGPUContext.detector.isMobile) - const {setDebugButtons} = await import("../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const {setDebugButtons} = await import("../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); diff --git a/examples/postEffect/fog/fog/index.html b/examples/postEffect/fog/fog/index.html index 112d2b5eb..d8d82028d 100644 --- a/examples/postEffect/fog/fog/index.html +++ b/examples/postEffect/fog/fog/index.html @@ -8,8 +8,8 @@ - - + +
diff --git a/examples/postEffect/fog/fog/index.js b/examples/postEffect/fog/fog/index.js index 07a222e07..1906641e1 100644 --- a/examples/postEffect/fog/fog/index.js +++ b/examples/postEffect/fog/fog/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; const canvas = document.createElement('canvas'); document.querySelector('#example-container').appendChild(canvas); @@ -147,10 +147,10 @@ function createTestScene(redGPUContext, scene) { * @param {RedGPU.PostEffect.Fog} fogEffect */ async function createControlPanel(redGPUContext, view, fogEffect) { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const pane = new Pane({title: '🌫️ Fog Test'}); - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext); const PARAMS = { enabled: true, diff --git a/examples/postEffect/fog/heightFog/index.html b/examples/postEffect/fog/heightFog/index.html index 112d2b5eb..d8d82028d 100644 --- a/examples/postEffect/fog/heightFog/index.html +++ b/examples/postEffect/fog/heightFog/index.html @@ -8,8 +8,8 @@ - - + +
diff --git a/examples/postEffect/fog/heightFog/index.js b/examples/postEffect/fog/heightFog/index.js index f432e4a9e..9ada605a5 100644 --- a/examples/postEffect/fog/heightFog/index.js +++ b/examples/postEffect/fog/heightFog/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; const canvas = document.createElement('canvas'); document.querySelector('#example-container').appendChild(canvas); @@ -290,10 +290,10 @@ function createGroundLevelScene(redGPUContext, scene) { * @param {function} toggleAutoRotate */ async function createHeightFogControlPanel(redGPUContext, view, heightFog, controller, toggleAutoRotate) { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const pane = new Pane({title: 'Height Fog Demo', expanded: true}); - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext); const PARAMS = { enabled: true, diff --git a/examples/postEffect/lens/chromaticAberration/index.html b/examples/postEffect/lens/chromaticAberration/index.html index 112d2b5eb..d8d82028d 100644 --- a/examples/postEffect/lens/chromaticAberration/index.html +++ b/examples/postEffect/lens/chromaticAberration/index.html @@ -8,8 +8,8 @@ - - + +
diff --git a/examples/postEffect/lens/chromaticAberration/index.js b/examples/postEffect/lens/chromaticAberration/index.js index 9b6fe290d..bb7ffc7c7 100644 --- a/examples/postEffect/lens/chromaticAberration/index.js +++ b/examples/postEffect/lens/chromaticAberration/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; // 1. Create and append a canvas // 1. 캔버스를 생성하고 문서에 추가 @@ -114,10 +114,10 @@ function loadGLTF(redGPUContext, scene, url) { } const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); - const {createPostEffectLabel} = await import('../../../exampleHelper/createExample/loadExampleInfo/createPostEffectLabel.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); + const {createPostEffectLabel} = await import('../../../exampleHelper/createExample/loadExampleInfo/createPostEffectLabel.js?t=1770713934910'); createPostEffectLabel('ChromaticAberration', redGPUContext.detector.isMobile) - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); diff --git a/examples/postEffect/lens/dof/index.html b/examples/postEffect/lens/dof/index.html index 112d2b5eb..d8d82028d 100644 --- a/examples/postEffect/lens/dof/index.html +++ b/examples/postEffect/lens/dof/index.html @@ -8,8 +8,8 @@ - - + +
diff --git a/examples/postEffect/lens/dof/index.js b/examples/postEffect/lens/dof/index.js index 9ccbda5e7..f391ee70b 100644 --- a/examples/postEffect/lens/dof/index.js +++ b/examples/postEffect/lens/dof/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; // 1. Create and append a canvas const canvas = document.createElement('canvas'); @@ -207,11 +207,11 @@ function loadGLTF(redGPUContext, scene, url) { } const renderTestPane = async (redGPUContext, targetView) => { - const {createPostEffectLabel} = await import('../../../exampleHelper/createExample/loadExampleInfo/createPostEffectLabel.js?t=1770699661827'); + const {createPostEffectLabel} = await import('../../../exampleHelper/createExample/loadExampleInfo/createPostEffectLabel.js?t=1770713934910'); createPostEffectLabel('DOF', redGPUContext.detector.isMobile) - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext); - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const pane = new Pane(); const effect = targetView.postEffectManager.getEffectAt(0) diff --git a/examples/postEffect/lens/lensDistortion/index.html b/examples/postEffect/lens/lensDistortion/index.html index 112d2b5eb..d8d82028d 100644 --- a/examples/postEffect/lens/lensDistortion/index.html +++ b/examples/postEffect/lens/lensDistortion/index.html @@ -8,8 +8,8 @@ - - + +
diff --git a/examples/postEffect/lens/lensDistortion/index.js b/examples/postEffect/lens/lensDistortion/index.js index 0b9ef6f93..5cba0ab85 100644 --- a/examples/postEffect/lens/lensDistortion/index.js +++ b/examples/postEffect/lens/lensDistortion/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; // 1. Create and append a canvas // 1. 캔버스를 생성하고 문서에 추가 @@ -113,10 +113,10 @@ function loadGLTF(redGPUContext, scene, url) { } const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); - const {createPostEffectLabel} = await import('../../../exampleHelper/createExample/loadExampleInfo/createPostEffectLabel.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); + const {createPostEffectLabel} = await import('../../../exampleHelper/createExample/loadExampleInfo/createPostEffectLabel.js?t=1770713934910'); createPostEffectLabel('LensDistortion', redGPUContext.detector.isMobile) - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); diff --git a/examples/postEffect/lens/vignetting/index.html b/examples/postEffect/lens/vignetting/index.html index 112d2b5eb..d8d82028d 100644 --- a/examples/postEffect/lens/vignetting/index.html +++ b/examples/postEffect/lens/vignetting/index.html @@ -8,8 +8,8 @@ - - + +
diff --git a/examples/postEffect/lens/vignetting/index.js b/examples/postEffect/lens/vignetting/index.js index d9377a878..1f9e75e95 100644 --- a/examples/postEffect/lens/vignetting/index.js +++ b/examples/postEffect/lens/vignetting/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../../dist/index.js?t=1770713934910"; // 1. Create and append a canvas // 1. 캔버스를 생성하고 문서에 추가 @@ -113,10 +113,10 @@ function loadGLTF(redGPUContext, scene, url) { } const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); - const {createPostEffectLabel} = await import('../../../exampleHelper/createExample/loadExampleInfo/createPostEffectLabel.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); + const {createPostEffectLabel} = await import('../../../exampleHelper/createExample/loadExampleInfo/createPostEffectLabel.js?t=1770713934910'); createPostEffectLabel('Vignetting', redGPUContext.detector.isMobile) - const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const {setDebugButtons} = await import("../../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); diff --git a/examples/postEffect/oldBloom/index.html b/examples/postEffect/oldBloom/index.html index 470caed74..9d076917b 100644 --- a/examples/postEffect/oldBloom/index.html +++ b/examples/postEffect/oldBloom/index.html @@ -8,8 +8,8 @@ - - + +
diff --git a/examples/postEffect/oldBloom/index.js b/examples/postEffect/oldBloom/index.js index 80aa04232..07501cb56 100644 --- a/examples/postEffect/oldBloom/index.js +++ b/examples/postEffect/oldBloom/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../dist/index.js?t=1770713934910"; // 1. Create and append a canvas // 1. 캔버스를 생성하고 문서에 추가 @@ -113,10 +113,10 @@ function loadGLTF(redGPUContext, scene, url) { } const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); - const {createPostEffectLabel} = await import('../../exampleHelper/createExample/loadExampleInfo/createPostEffectLabel.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); + const {createPostEffectLabel} = await import('../../exampleHelper/createExample/loadExampleInfo/createPostEffectLabel.js?t=1770713934910'); createPostEffectLabel('OldBloom', redGPUContext.detector.isMobile) - const {setDebugButtons} = await import("../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const {setDebugButtons} = await import("../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); diff --git a/examples/postEffect/sharpen/index.html b/examples/postEffect/sharpen/index.html index 470caed74..9d076917b 100644 --- a/examples/postEffect/sharpen/index.html +++ b/examples/postEffect/sharpen/index.html @@ -8,8 +8,8 @@ - - + +
diff --git a/examples/postEffect/sharpen/index.js b/examples/postEffect/sharpen/index.js index 8705055c5..fe096a57e 100644 --- a/examples/postEffect/sharpen/index.js +++ b/examples/postEffect/sharpen/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../dist/index.js?t=1770713934910"; // 1. Create and append a canvas // 1. 캔버스를 생성하고 문서에 추가 @@ -113,10 +113,10 @@ function loadGLTF(redGPUContext, scene, url) { } const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); - const {createPostEffectLabel} = await import('../../exampleHelper/createExample/loadExampleInfo/createPostEffectLabel.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); + const {createPostEffectLabel} = await import('../../exampleHelper/createExample/loadExampleInfo/createPostEffectLabel.js?t=1770713934910'); createPostEffectLabel('Sharpen', redGPUContext.detector.isMobile) - const {setDebugButtons} = await import("../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const {setDebugButtons} = await import("../../exampleHelper/createExample/panes/index.js?t=1770713934910"); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); diff --git a/examples/postEffect/ssao/index.html b/examples/postEffect/ssao/index.html index b3924120d..a61628df1 100644 --- a/examples/postEffect/ssao/index.html +++ b/examples/postEffect/ssao/index.html @@ -8,8 +8,8 @@ - - + + diff --git a/examples/postEffect/ssao/index.js b/examples/postEffect/ssao/index.js index 61c44af29..41f3d4760 100644 --- a/examples/postEffect/ssao/index.js +++ b/examples/postEffect/ssao/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../dist/index.js?t=1770713934910"; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); @@ -57,11 +57,11 @@ function loadGLTF(view, url) { } const renderTestPane = async (redGPUContext, targetView) => { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); const { createIblHelper, setDebugButtons - } = await import('../../exampleHelper/createExample/panes/index.js?t=1770699661827'); + } = await import('../../exampleHelper/createExample/panes/index.js?t=1770713934910'); setDebugButtons(RedGPU, redGPUContext); const pane = new Pane(); createIblHelper(pane, targetView, RedGPU); diff --git a/examples/postEffect/ssr/index.html b/examples/postEffect/ssr/index.html index 470caed74..9d076917b 100644 --- a/examples/postEffect/ssr/index.html +++ b/examples/postEffect/ssr/index.html @@ -8,8 +8,8 @@ - - + +
diff --git a/examples/postEffect/ssr/index.js b/examples/postEffect/ssr/index.js index f0b0dae1a..1a1653965 100644 --- a/examples/postEffect/ssr/index.js +++ b/examples/postEffect/ssr/index.js @@ -1,4 +1,4 @@ -import * as RedGPU from "../../../dist/index.js?t=1770699661827"; +import * as RedGPU from "../../../dist/index.js?t=1770713934910"; /** * [KO] SSR 예제 @@ -111,8 +111,8 @@ function loadGLTFModels(redGPUContext, scene) { * SSR 설정 컨트롤러 (Tweakpane) */ async function createSSRControls(redGPUContext, targetView) { - const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770699661827'); - const {setDebugButtons} = await import("../../exampleHelper/createExample/panes/index.js?t=1770699661827"); + const {Pane} = await import('https://cdn.jsdelivr.net/npm/tweakpane@4.0.3/dist/tweakpane.min.js?t=1770713934910'); + const {setDebugButtons} = await import("../../exampleHelper/createExample/panes/index.js?t=1770713934910"); const pane = new Pane({title: 'SSR 옵션 조절'}); setDebugButtons(RedGPU, redGPUContext);