From 29b5f04a2710e3ab01a0a04271b649031eed6d80 Mon Sep 17 00:00:00 2001 From: "junwei.gu" Date: Wed, 21 Jun 2023 18:11:10 +0800 Subject: [PATCH] refactor(material/mesh/shader): refactor material set modelMatrix and fix vert/frag bug --- dist/index.js | 5313 +++++++++-------- example/index.html | 1 + example/mesh/instance.html | 1 + src/material/BillboardMaterial.ts | 14 +- src/material/BlinnPhongMaterial.ts | 6 +- src/material/ColorMaterial.ts | 6 +- src/material/Material.ts | 14 +- src/material/PbrMaterial.ts | 8 +- src/material/ShaderMaterial.ts | 3 +- src/material/SkyBoxMaterial.ts | 8 +- src/mesh/Billboard.ts | 18 + src/mesh/InstanceMesh.ts | 10 +- src/mesh/Mesh.ts | 17 +- src/render/DrawCommand.ts | 3 - src/shader/Shaders.ts | 26 +- src/shader/material/billboardFrag.ts | 10 - src/shader/material/billboardVert.ts | 26 - src/shader/material/billboard_fs.ts | 24 + src/shader/material/billboard_vs.ts | 37 + src/shader/material/pbr_fs.ts | 43 +- src/shader/material/phongFrag.ts | 41 +- src/shader/material/phongVert.ts | 31 +- src/shader/shaderChunk/ShaderChunk.ts | 4 +- src/shader/shaderChunk/attribute/FragInput.ts | 7 +- .../shaderChunk/attribute/VertexOutput.ts | 7 +- .../common/TextureAndSamplerDefine.ts | 41 + .../shaderChunk/normal/getNormalBackUp.ts | 4 +- src/utils/combine.ts | 76 +- src/utils/uniformUtils.ts | 11 +- 29 files changed, 2940 insertions(+), 2870 deletions(-) create mode 100644 src/mesh/Billboard.ts delete mode 100644 src/shader/material/billboardFrag.ts delete mode 100644 src/shader/material/billboardVert.ts create mode 100644 src/shader/material/billboard_fs.ts create mode 100644 src/shader/material/billboard_vs.ts create mode 100644 src/shader/shaderChunk/common/TextureAndSamplerDefine.ts diff --git a/dist/index.js b/dist/index.js index 169d5b5..f2d69bc 100644 --- a/dist/index.js +++ b/dist/index.js @@ -678,7 +678,6 @@ class DrawCommand { render(context, passEncoder, camera) { const { shaderData, - modelMatrix, renderState, vertexBuffer, indexBuffer, @@ -691,7 +690,6 @@ class DrawCommand { const currentPassEncoder = renderTarget?.beginRenderPassEncoder?.(context) ?? passEncoder; const defines = Object.assign({}, lightShaderData?.defines ?? {}, camera?.shaderData?.defines ?? {}); const { device } = context; - if (modelMatrix) shaderData?.replaceUniformBufferValue?.("modelMatrix", modelMatrix); shaderData?.bind?.(context, currentPassEncoder); camera?.shaderData?.bind(context, currentPassEncoder); lightShaderData?.bind?.(context, currentPassEncoder); @@ -5283,7 +5281,7 @@ class VertextBuffer { * const object2 = { * propTwo : 2 * } - * const final = Cesium.combine(object1, object2); + * const final = combine(object1, object2); * * // final === { * // propOne : 1, @@ -7362,6 +7360,31 @@ UniformBuffer.UniformType = { [UniformEnum.DirtectLightShadows]: UniformDirtectLightShadows }; +function billboard_fs(defines) { + return ` + struct SelfUniform { + modelMatrix: mat4x4, + color:vec3, + rotation:f32, + center:vec2, + opacity:f32, + } + @binding(${defines.billboardBinding}) @group(0) var selfUniform : SelfUniform; + #if${defines.USE_COLORTEXTURE} + @group(0) @binding(${defines.baseColorSamplerBinding}) var baseColorSampler: sampler; + @group(0) @binding(${defines.baseColorTextureBinding}) var baseColorTexture: texture_2d; + #endif + @fragment + fn main(input:VertexOutput) -> @location(0) vec4 { + #if${defines.USE_COLORTEXTURE} + return textureSample(baseColorTexture, baseColorSampler, input.uv); + #else + return vec4(selfUniform.color,selfUniform.opacity); + #endif + } + `; +} + const preprocessorSymbols = /#([^\s]*)(\s*)/gm; // Template literal tag that handles simple preprocessor symbols for WGSL // shaders. Supports #if/elif/else/endif statements. @@ -7441,2876 +7464,2871 @@ function wgslParseDefines(strings, ...values) { return state.frag; } -function FragInput(defines) { +function billboard_vs(defines) { return wgslParseDefines` - struct FragInput { - @builtin(front_facing) frontFacing: bool, - @location(0) worldPos:vec3, - @location(1) normal:vec3, - #if ${defines.HAS_UV} - @location(2) uv:vec2 - #endif - } + + #include + #include + #include + struct SelfUniform { + modelMatrix: mat4x4, + color:vec3, + rotation:f32, + center:vec2, + opacity:f32, + } + @binding(${defines.billboardBinding}) @group(0) var selfUniform : SelfUniform; + @binding(${defines.cameraBinding}) @group(1) var systemUniform : SystemUniform; + @vertex + fn main(input: VertexInput) -> VertexOutput { + var output:VertexOutput; + let mvPosition:vec4= ystemUniform.viewMatrix *selfUniform.modelMatrix*vec4(0.0,0.0,0.0, 1.0 ); + #if ${defines.HAS_UV} + output.uv=input.uv; + #endif + var scale:vec2; + scale.x = length( vec3( selfUniform.modelMatrix[ 0 ].x, selfUniform.modelMatrix[ 0 ].y, selfUniform.modelMatrix[ 0 ].z ) ); + scale.y = length( vec3( selfUniform.modelMatrix[ 1 ].x, selfUniform.modelMatrix[ 1 ].y, selfUniform.modelMatrix[ 1 ].z ) ); + + vec2 alignedPosition = ( input.position.xy - ( selfUniform.center - vec2( 0.5 ) ) ) * scale; + vec2 rotatedPosition; + rotatedPosition.x = cos( selfUniform.rotation ) * alignedPosition.x - sin( selfUniform.rotation ) * alignedPosition.y; + rotatedPosition.y = sin( selfUniform.rotation ) * alignedPosition.x + cos( selfUniform.rotation ) * alignedPosition.y; + mvPosition.xy += rotatedPosition; + output.position = systemUniform.projectionMatrix * mvPosition; + return output; + } `; } -function VertexInput(defines) { +// import Color from "../../math/Color"; +function colorFrag(defines) { + return ` + struct VertexOutput { + @builtin(position) position: vec4, + @location(0) color: vec4, + }; + @fragment + fn main(input:VertexOutput) -> @location(0) vec4 { + return input.color; + } + `; +} + +function colorVert(defines) { + return ` + struct VertexInput { + @location(${defines.positionLocation}) position: vec3, + @location(${defines.colorLocation}) color: vec4, + } + struct VertexOutput { + @builtin(position) position: vec4, + @location(0) color: vec4, + }; + struct SelfUniform { + modelMatrix: mat4x4, + } + struct SystemUniform { + projectionMatrix: mat4x4, + viewMatrix: mat4x4, + inverseViewMatrix: mat4x4, + cameraPosition: vec3, + }; + @binding(${defines.colorBinding}) @group(0) var selfUniform : SelfUniform; + @binding(${defines.cameraBinding}) @group(1) var systemUniform : SystemUniform; + @vertex + fn main(input: VertexInput) -> VertexOutput { + var output:VertexOutput; + output.color=input.color; + output.position = systemUniform.projectionMatrix * systemUniform.viewMatrix *selfUniform.modelMatrix*vec4(input.position,1.0); + return output; + } + `; +} + +function pbr_fs(defines) { return wgslParseDefines` - struct VertexInput { - @location(${defines.positionLocation}) position: vec3, - @location(${defines.normalLocation}) normal: vec3, - #if${defines.HAS_COLOR} - @location(${defines.colorLocation}) color: vec3, + // reference: https://github.com/KhronosGroup/glTF-WebGL-PBR/blob/master/shaders/pbr-frag.glsl + #include + #include + #include + #include + #include + #include + struct PhysicalMaterial { + diffuseColor:vec3, + roughness:f32, + specularColor:vec3, + #if ${defines.USE_CLEARCOAT} + clearcoat:f32, + clearcoatRoughness:f32, + clearcoatF0:vec3, + clearcoatF90:f32, + #endif + + #if ${defines.USE_IRIDESCENCE} + iridescence:f32, + iridescenceIOR:f32, + iridescenceThickness:f32, + iridescenceFresnel:vec3, + iridescenceF0:vec3, + #endif + + #if ${defines.USE_SHEEN} + sheenColor:vec3, + sheenRoughness:f32, + #endif + + #if ${defines.IOR} + ior:f32, + #endif + + #if ${defines.USE_TRANSMISSION} + transmission:f32, + transmissionAlpha:f32, + thickness:f32, + attenuationDistance:f32, + attenuationColor:vec3, + #endif + }; + const M_PI:f32 = 3.141592653589793; + const c_MinRoughness:f32 = 0.04; + #include + #if ${defines.USE_IBL} + #include + #endif + @binding(${defines.pbrBinding}) @group(0) var materialUniform : MaterialUniform; + @binding(${defines.cameraBinding}) @group(1) var systemUniform : SystemUniform; + @fragment + fn main(input:FragInput) -> @location(0) vec4 + { + var perceptualRoughness:f32 = materialUniform.roughness; + var metallic:f32 = materialUniform.metallic; + + #if ${defines.USE_METALNESSTEXTURE} + let mrSample:vec4 = textureSample(metalnessRoughnessTexture,metalnessRoughnessSampler, input.uv); + perceptualRoughness = mrSample.g * perceptualRoughness; + metallic = mrSample.b * metallic; #endif - #if ${defines.HAS_UV} - @location(${defines.uvLocation}) uv: vec2, + perceptualRoughness = clamp(perceptualRoughness, c_MinRoughness, 1.0); + metallic = clamp(metallic, 0.0, 1.0); + let alphaRoughness:f32 = perceptualRoughness * perceptualRoughness; + + + // The albedo may be defined from a base texture or a flat color + #if ${defines.USE_TEXTURE} + let baseColor:vec4 = textureSample(baseColorTexture,baseColorSampler, input.uv) ; + #else + let baseColor:vec4 = vec4(materialUniform.color,1.0); #endif - #if${defines.HAS_SKIN} - @location(${defines.joint0Location}) joint0:vec4, - @location(${defines.weight0Location}) weight0:vec4, + + #if ${defines.USE_NORMALTEXTURE} + let n:vec3 = getNormalByNormalTexture(input); + #else + let n:vec3 = getNormal(input); #endif - #if ${defines.USE_INSTANCE} - @builtin(instance_index) instanceIdx : u32 + var material:PhysicalMaterial; + material.diffuseColor=baseColor.rgb*( 1.0 - metallic ); + material.roughness=perceptualRoughness; + material.specularColor=mix( vec3( 0.04), baseColor.rgb, metallic ); + var geometry:Geometry; + geometry.normal=n; + geometry.viewDir=normalize(systemUniform.cameraPosition - input.worldPos); + geometry.position=input.worldPos; + geometry.dotNV = saturate(dot(geometry.normal, geometry.viewDir) ); + //light shading + var reflectedLight=parseLights(geometry,material); + var color=reflectedLight.directDiffuse+reflectedLight.directSpecular; + //IBL + #if ${defines.USE_IBL && defines.HAS_UV} + var reflectedLightDiffuse=indirectDiffuse_Physical(geometry,material); + var reflectedLightSpecular=indirectSpecular_Physical(geometry,material); + color+=reflectedLightDiffuse.indirectDiffuse; + color+=reflectedLightSpecular.indirectSpecular; #endif - } + #if ${defines.USE_AOTEXTURE} + let ao:f32 = textureSample(aoTexture,aoSampler, input.uv).r; + color = mix(color, color * ao, materialUniform.occlusionStrength); + #endif + + #if ${defines.USE_EMISSIVETEXTURE} + let emissive:vec3 = textureSample(emissiveTexture, emissiveSampler,input.uv).rgb ; + color += emissive; + #endif + return vec4(color, baseColor.a); + } `; } -function VertexOutput(defines) { +function pbr_vs(defines) { return wgslParseDefines` - struct VertexOutput { - @builtin(position) position:vec4, - @location(0) worldPos:vec3, - @location(1) normal:vec3, + #include + #include + #include + #include + #include + #include + @binding(${defines.pbrBinding}) @group(0) var materialUniform : MaterialUniform; + @binding(${defines.cameraBinding}) @group(1) var systemUniform : SystemUniform; + @vertex + fn main(input: VertexInput)-> VertexOutput + { + var output: VertexOutput; #if ${defines.HAS_UV} - @location(2) uv:vec2 + output.uv = input.uv; #endif - } - `; -} - -function SystemUniform(defines) { - return wgslParseDefines` - struct SystemUniform { - projectionMatrix: mat4x4, - viewMatrix: mat4x4, - inverseViewMatrix: mat4x4, - cameraPosition: vec3, - }; - `; + var modelMatrix:mat4x4; + var vNormalView:vec3; + vNormalView = normalize(materialUniform.normalMatrix * vec4(input.normal,0.0)).xyz; + modelMatrix=materialUniform.modelMatrix; + #include + #include + output.normal = vNormalView.xyz; + output.position = systemUniform.projectionMatrix * systemUniform.viewMatrix *modelMatrix* vec4(input.position, 1.0); + let modelPos=modelMatrix *vec4(input.position,1.0); + output.worldPos = modelPos.xyz/modelPos.w; + return output; + } + `; } -function environment(defines) { +function pbrFrag(defines) { return wgslParseDefines` - #if ${defines.ENVTEXTURE_TYPE_CUBE_UV} - const cubeUV_minMipLevel:f32= 4.0; - const cubeUV_minTileSize:f32= 16.0; - const CUBEUV_MAX_MIP:f32=6.0; - const CUBEUV_TEXEL_WIDTH:f32=1.0/256.0; - const CUBEUV_TEXEL_HEIGHT:f32=1.0/256.0; - fn getFace(direction:vec3 )->f32 { - let absDirection:vec3 = abs( direction ); - var face:f32 = - 1.0; - if ( absDirection.x > absDirection.z ) { - if ( absDirection.x > absDirection.y ){ - face =select(3.0,0.0,direction.x > 0.0); - }else{ - face =select(4.0,1.0,direction.y > 0.0); - } - - } - else { - if ( absDirection.z > absDirection.y ){ - face =select(5.0,2.0,direction.z > 0.0); - }else{ - face =select(4.0,1.0,direction.y > 0.0); - } - } - return face; - } - fn getUV( direction:vec3, face:f32 )->vec2 { - var uv:vec2; - if ( face == 0.0 ) { - uv = vec2( direction.z, direction.y ) / abs( direction.x ); - } - else if ( face == 1.0 ) { - uv = vec2( - direction.x, - direction.z ) / abs( direction.y ); - } - else if ( face == 2.0 ) { - uv = vec2( - direction.x, direction.y ) / abs( direction.z ); - } - else if ( face == 3.0 ) { - uv = vec2( - direction.z, direction.y ) / abs( direction.x ); - } - else if ( face == 4.0 ) { - uv = vec2( - direction.x, direction.z ) / abs( direction.y ); - } - else { - uv = vec2( direction.x, direction.y ) / abs( direction.z ); - } - return 0.5 * ( uv + 1.0 ); - } - fn bilinearCubeUV(envTexture:texture_cube,baseSampler:sampler,direction:vec3, mipInt:f32 )->vec3 { - var face:f32 = getFace( direction ); - let filterInt:f32 = max( cubeUV_minMipLevel - mipInt, 0.0 ); - let tempMipInt = max( mipInt, cubeUV_minMipLevel ); - let faceSize:f32 = exp2( tempMipInt ); - var uv:vec2 = getUV( direction, face ) * ( faceSize - 2.0 ) + 1.0; - if ( face > 2.0 ) { - uv.y += faceSize; - face -= 3.0; - } - uv.x += face * faceSize; - uv.x += filterInt * 3.0 * cubeUV_minTileSize; - uv.y += 4.0 * ( exp2( CUBEUV_MAX_MIP ) - faceSize ); - uv.x *= CUBEUV_TEXEL_WIDTH; - uv.y *= CUBEUV_TEXEL_HEIGHT; - return textureSample(envTexture,baseSampler,direction).rgb; - } - const cubeUV_r0:f32= 1.0; - const cubeUV_v0:f32= 0.339; - const cubeUV_m0:f32= - 2.0; - const cubeUV_r1:f32= 0.8; - const cubeUV_v1:f32= 0.276; - const cubeUV_m1:f32= - 1.0; - const cubeUV_r4:f32= 0.4; - const cubeUV_v4:f32= 0.046; - const cubeUV_m4:f32= 2.0; - const cubeUV_r5:f32= 0.305; - const cubeUV_v5:f32= 0.016; - const cubeUV_m5:f32= 3.0; - const cubeUV_r6:f32= 0.21; - const cubeUV_v6:f32= 0.0038; - const cubeUV_m6:f32= 4.0; - fn roughnessToMip( roughness:f32)->f32 { - var mip:f32 = 0.0; - if ( roughness >= cubeUV_r1 ) { - mip = ( cubeUV_r0 - roughness ) * ( cubeUV_m1 - cubeUV_m0 ) / ( cubeUV_r0 - cubeUV_r1 ) + cubeUV_m0; - } - else if ( roughness >= cubeUV_r4 ) { - mip = ( cubeUV_r1 - roughness ) * ( cubeUV_m4 - cubeUV_m1 ) / ( cubeUV_r1 - cubeUV_r4 ) + cubeUV_m1; - } - else if ( roughness >= cubeUV_r5 ) { - mip = ( cubeUV_r4 - roughness ) * ( cubeUV_m5 - cubeUV_m4 ) / ( cubeUV_r4 - cubeUV_r5 ) + cubeUV_m4; - } - else if ( roughness >= cubeUV_r6 ) { - mip = ( cubeUV_r5 - roughness ) * ( cubeUV_m6 - cubeUV_m5 ) / ( cubeUV_r5 - cubeUV_r6 ) + cubeUV_m5; - } - else { - mip = - 2.0 * log2( 1.16 * roughness ); - } - return mip; - } - fn textureCubeUV(envTexture:texture_cube, baseSampler:sampler,sampleDir:vec3,roughness:f32 )->vec4 { - let mip = clamp( roughnessToMip( roughness ), cubeUV_m0, CUBEUV_MAX_MIP ); - let mipF = fract( mip ); - let mipInt = floor( mip ); - let color0:vec3 = bilinearCubeUV( envTexture,baseSampler,sampleDir, mipInt ); - if ( mipF == 0.0 ) { - return vec4(color0, 1.0 ); - } - else { - let color1:vec3 = bilinearCubeUV( envTexture,baseSampler, sampleDir, mipInt + 1.0 ); - return vec4(mix( color0, color1, mipF ), 1.0 ); - } - - } - #endif - #if ${defines.USE_ENVTEXTURE} - fn getIBLIrradiance( normal:vec3,baseSampler:sampler,viewMatrix:mat4x4)->vec3 { - #if ${defines.ENVTEXTURE_TYPE_CUBE_UV} - let worldNormal:vec3 = inverseTransformDirection( normal, viewMatrix ); - let envTextureColor:vec4 = textureCubeUV( envTexture,baseSampler, worldNormal, 1.0 ); - return PI * envTextureColor.rgb * materialUniform.envTextureIntensity; - #else - return vec3( 0.0 ); - #endif - } - fn getIBLRadiance( viewDir:vec3,baseSampler:sampler,viewMatrix:mat4x4,normal:vec3, roughness:f32 )->vec3 { - #if ${defines.ENVTEXTURE_TYPE_CUBE_UV} - var reflectVec:vec3 = reflect( - viewDir, normal ); - reflectVec = normalize( mix( reflectVec, normal, roughness * roughness) ); - reflectVec = inverseTransformDirection( reflectVec, viewMatrix ); - let envTextureColor:vec4 = textureCubeUV( envTexture,baseSampler, reflectVec, roughness ); - return envTextureColor.rgb * materialUniform.envTextureIntensity; - #else - return vec3( 0.0 ); - #endif - } - #endif - `; -} - -function instanceVertHeader(defines) { - return wgslParseDefines` - #if ${defines.USE_INSTANCE} - struct InstancesUniform { - instanceMatrixs: array, ${defines.instanceCount}>, - }; - @group(0) @binding(${defines.instanceMatrixsBufferBinding}) var instancesUniform: InstancesUniform; - #endif - `; -} -function instanceVertMain(defines) { - return wgslParseDefines` - #if ${defines.USE_INSTANCE} - modelMatrix=instancesUniform.instanceMatrixs[input.instanceIdx]; - #endif - `; -} - -function light(defines) { - return wgslParseDefines` - struct ReflectedLight { - ambient: vec3, - directDiffuse:vec3, - directSpecular:vec3, - indirectDiffuse:vec3, - indirectSpecular:vec3, - testColor: vec3, - }; - struct IncidentLight { - color: vec3, - direction: vec3, - visible: bool, - }; - struct Geometry { - position: vec3, - normal: vec3, - viewDir: vec3, - dotNV:f32, - #if ${defines.USE_CLEARCOAT} - vec3 clearcoatNormal; - #endif - }; - - #if ${defines.spotLightsCount > 0} - struct SpotLight { - position: vec3, - distance: f32, - direction: vec3, - coneCos: f32, - color: vec3, - penumbraCos: f32, - decay: f32, - }; - fn getSpotLightInfo(spotLight:SpotLight,worldPos:vec3,shininess:f32,N:vec3,V:vec3)->ReflectedLight{ - var direction:vec3 = spotLight.position - worldPos; - var lightColor:ReflectedLight; - let lightDistance:f32 = length(direction); - direction = normalize(direction); - let angleCos:f32 = dot( direction, spotLight.direction ); - let decay:f32 = clamp(1.0 - pow(lightDistance/spotLight.distance, spotLight.decay), 0.0, 1.0); - let spotEffect:f32 = smoothstep( spotLight.penumbraCos, spotLight.coneCos, angleCos ); - let decayTotal:f32 = decay * spotEffect; - let d:f32 = max( dot( N, direction ), 0.0 ) * decayTotal; - lightColor.directDiffuse= spotLight.color * d; - let halfDir:vec3 = normalize( V + direction ); - let s:f32 = pow( clamp( dot( N, halfDir ), 0.0, 1.0 ), shininess ) * decayTotal; - lightColor.directSpecular= spotLight.color * s; - return lightColor; - } - fn getSpotLightIncidentLight(spotLight:SpotLight, geometry:Geometry)->IncidentLight { - var incidentLight:IncidentLight; - let lVector:vec3 = spotLight.position - geometry.position; - incidentLight.direction = normalize( lVector ); - - let lightDistance:f32 = length( lVector ); - let angleCos:f32 = dot( incidentLight.direction, spotLight.direction ); - - let spotEffect:f32 = smoothstep( spotLight.penumbraCos, spotLight.coneCos, angleCos ); - let decayEffect:f32 = clamp(1.0 - pow(lightDistance/spotLight.distance, 4.0), 0.0, 1.0); - - incidentLight.color=spotLight.color*spotEffect * decayEffect; - return incidentLight; - } - - #endif - - #if ${defines.pointLightsCount > 0} - struct PointLight { - position: vec3, - distance: f32, - color: vec3, - decay: f32, - }; - fn getPointLightInfo(pointLight:PointLight,worldPos:vec3,shininess:f32,N:vec3,V:vec3)->ReflectedLight{ - var lightColor:ReflectedLight; - var direction:vec3 = worldPos - pointLight.position; - let dist:f32 = length( direction ); - direction = normalize(direction); - let decay = clamp(1.0 - pow(dist / pointLight.distance, pointLight.decay), 0.0, 1.0); - - let d = max( dot( N, -direction ), 0.0 ) * decay; - lightColor.directDiffuse = pointLight.color * d; - - let halfDir:vec3 = normalize( V - direction ); - let s:f32 = pow( clamp( dot( N, halfDir ), 0.0, 1.0 ), shininess ) * decay; - lightColor.directSpecular = pointLight.color * s; - return lightColor; - } - fn getPointLightIncidentLight(pointLight:PointLight, geometry:Geometry)->IncidentLight { - var incidentLight:IncidentLight; - let lVector:vec3 = pointLight.position-geometry.position; - incidentLight.direction= normalize( lVector ); - let lightDistance:f32 = length( lVector ); - // let weight:f32=1.0 - pow(lightDistance/pointLight.distance, 4.0); - incidentLight.color=pointLight.color*clamp(1.0 - pow(lightDistance/pointLight.distance, 4.0), 0.0, 1.0); - return incidentLight; - } - #endif - #if ${defines.dirtectLightsCount > 0} - struct DirectionalLight { - direction: vec3, - color: vec3, - }; - fn getDirectLightInfo(directionalLight:DirectionalLight,shininess:f32,N:vec3,V:vec3)->ReflectedLight{ - var lightColor:ReflectedLight; - let d:f32 = max(dot(N, -directionalLight.direction), 0.0); - lightColor.directDiffuse += directionalLight.color * d; - - let halfDir:vec3 = normalize( V - directionalLight.direction ); - let s:f32 = pow( clamp( dot( N, halfDir ), 0.0, 1.0 ), shininess ); - lightColor.directSpecular += directionalLight.color * s; - return lightColor; - } - fn getDirectionalDirectLightIncidentLight(directionalLight:DirectionalLight,geometry:Geometry)->IncidentLight { - var incidentLight:IncidentLight; - incidentLight.color = directionalLight.color; - incidentLight.direction = normalize(directionalLight.direction); - return incidentLight; - } - #endif - - #if ${defines.openShadow} - struct LightInfo { - direction: vec3, - viewport: vec4, - }; - - fn linearizeDepth(depth: f32, near: f32, far: f32)->f32 { - return 2 * (near * far) / (far + near - depth * (far - near)); - } - - fn getCubeFace(v : vec3) -> i32{ - let vAbs = abs(v); - - if (vAbs.z >= vAbs.x && vAbs.z >= vAbs.y) { - if (v.z < 0.0) { - return 3; - } - return 2; - } - - if (vAbs.y >= vAbs.x) { - if (v.y < 0.0) { - return 5; - } - return 4; - } - - if (v.x < 0.0) { - return 1; - } - return 0; - } - - fn getShadowValue(shadowMapArray:texture_depth_2d_array, shadowSampler:sampler_comparison, lightPos:vec4, geometry:Geometry, lightInfo:LightInfo, index:u32, isPointLight: bool, near: f32, far: f32)->f32 { - var visibility = 0.0; - var projectPos: vec3 = lightPos.xyz / lightPos.w; - var shadowPos: vec3 = vec3(projectPos.xy * vec2(0.5, -0.5) + vec2(0.5), projectPos.z); - var d:f32 = dot(geometry.normal, -lightInfo.direction); - var bias = max(0.012 * (1.0 - d), 0.001) / lightPos.w; - let oneOverShadowDepthTextureSize = 1.0 / 1024.0; - // var depth = select(shadowPos.z, (linearizeDepth(shadowPos.z, near, far) - near) / (far- near), isPerspectiveCamera); - var depth = shadowPos.z; - - if (isPointLight) { - shadowPos.x = shadowPos.x * lightInfo.viewport.z; - shadowPos.y = shadowPos.y * lightInfo.viewport.w; - var viewportX = lightInfo.viewport.x * lightInfo.viewport.z; - var viewportY = lightInfo.viewport.y * lightInfo.viewport.w; - var uvOffset = 1.5 / 1024.0; - shadowPos.x = clamp(shadowPos.x + viewportX, viewportX + uvOffset, viewportX + lightInfo.viewport.z - uvOffset); - shadowPos.y = clamp(shadowPos.y + viewportY, viewportY + uvOffset, viewportY + lightInfo.viewport.w - uvOffset); - } - - for (var y = -1; y <= 1; y++) { - for (var x = -1; x <= 1; x++) { - let offset = vec2(vec2(x, y)) * oneOverShadowDepthTextureSize; - - visibility += textureSampleCompare( - shadowMapArray, shadowSampler, - shadowPos.xy + offset, index, depth - bias); - } - } - visibility /= 9.0; - var inFrustum = shadowPos.x >= 0.0 && shadowPos.x <= 1.0 && shadowPos.y >= 0.0 && shadowPos.y <= 1.0; - if (!inFrustum || depth > 1.0) { - visibility = 1.0; - } - return visibility; - } - #endif - - #if ${ - defines.ambientLightCount || defines.spotLightsCount || defines.pointLightsCount || defines.dirtectLightsCount - } - struct LightUniforms{ - #if ${defines.ambientLightCount} - ambient:vec4, - #endif - #if ${defines.spotLightsCount} - spotLights:array, - #endif - #if ${defines.pointLightsCount} - pointLights:array, - #endif - #if ${defines.dirtectLightsCount} - dirtectLights:array, - #endif - } - @group(2) @binding(${defines.lightBinding}) var lightUniforms: LightUniforms; - - #if ${defines.openShadow} - #if ${defines.spotLightShadowMapsCount} - struct SpotLightShadow { - shadowCameraVPMatrix: mat4x4, - shadowCameraNear: f32, - shadowCameraFar: f32 - } - #endif - #if ${defines.pointLightShadowMapsCount} - struct PointLightShadow { - shadowCameraVPMatrixArray: array, 6>, - shadowCameraViewportArray: array, 6>, - shadowCameraNear: f32, - shadowCameraFar: f32, - // shadowCameraVPMatrix: mat4x4, - // shadowCameraVPMatrixArray: array, 6>, - // shadowCameraViewportArray: array, 6>, - } - #endif - #if ${defines.directLightShadowMapsCount} - struct DirectLightShadow { - shadowCameraVPMatrix: mat4x4, - } - #endif - struct ShadowUniforms{ - #if ${defines.spotLightShadowMapsCount} - spotLightShadows:array, - #endif - #if ${defines.pointLightShadowMapsCount} - pointLightShadows:array, - #endif - #if ${defines.directLightShadowMapsCount} - directLightShadows:array, - #endif - } - @group(2) @binding(${defines.shadowBinding}) var shadowUniforms: ShadowUniforms; - - #if ${defines.spotLightShadowMapTextureArrayBinding} - @group(2) @binding(${ - defines.spotLightShadowMapTextureArrayBinding - }) var spotLightShadowMapTextureArray: texture_depth_2d_array; - #endif - #if ${defines.pointLightShadowMapTextureArrayBinding} - @group(2) @binding(${ - defines.pointLightShadowMapTextureArrayBinding - }) var pointLightShadowMapTextureArray: texture_depth_2d_array; - #endif - #if ${defines.directLightShadowMapTextureArrayBinding} - @group(2) @binding(${ - defines.directLightShadowMapTextureArrayBinding - }) var directLightShadowMapTextureArray: texture_depth_2d_array; - #endif - @group(2) @binding(${defines.shadowSamplerBinding}) var shadowSampler: sampler_comparison; - #endif - - #endif - #if ${defines.materialPhong} - fn parseLights(geometry:Geometry,shininess:f32)->ReflectedLight { - #elif ${defines.materialPbr} - fn parseLights(geometry:Geometry,material:PhysicalMaterial)->ReflectedLight{ - #endif - var reflectedLight:ReflectedLight; - var shadowValue:f32 = 1.0; - #if ${defines.ambientLightCount > 0} - //处理环境光 - var ambientColor:vec3 = lightUniforms.ambient.xyz * lightUniforms.ambient.w; - reflectedLight.ambient += ambientColor; - #endif - - #if ${defines.spotLightsCount > 0} - //处理聚光灯 - var spotLight:SpotLight; - for (var k = 0u; k < ${defines.spotLightsCount}; k = k + 1u) { - spotLight= lightUniforms.spotLights[k]; - #if ${defines.materialPhong && defines.openShadow && defines.spotLightShadowMapsCount} - if k < textureNumLayers(spotLightShadowMapTextureArray) { - var spotLightShadow:SpotLightShadow = shadowUniforms.spotLightShadows[k]; - var lightPos: vec4 = spotLightShadow.shadowCameraVPMatrix * vec4(geometry.position,1.0); - var lightInfo:LightInfo; - lightInfo.direction = normalize(geometry.position - spotLight.position); - - shadowValue = getShadowValue(spotLightShadowMapTextureArray, shadowSampler, lightPos, geometry, lightInfo, k, false, - spotLightShadow.shadowCameraNear, spotLightShadow.shadowCameraFar); - } - spotLight.color *= shadowValue; - #endif - #if ${defines.materialPhong} - let spReflectedLight=getSpotLightInfo(spotLight,geometry.position,shininess,geometry.normal,geometry.viewDir); - #elif ${defines.materialPbr} - let incidentLight=getSpotLightIncidentLight(spotLight,geometry); - let spReflectedLight=direct_Physical(incidentLight, geometry, material); - #endif - - reflectedLight.directDiffuse+=spReflectedLight.directDiffuse; - reflectedLight.directSpecular+=spReflectedLight.directSpecular; - } - #endif - #if ${defines.pointLightsCount > 0} - //处理点光源 - var pointLight:PointLight; - for (var j = 0u; j < ${defines.pointLightsCount};j = j + 1u) { - pointLight = lightUniforms.pointLights[j]; - #if ${defines.materialPhong && defines.openShadow && defines.pointLightShadowMapsCount} - if j < textureNumLayers(pointLightShadowMapTextureArray) { - var pointLightShadow:PointLightShadow = shadowUniforms.pointLightShadows[j]; - var lightInfo:LightInfo; - lightInfo.direction = normalize(geometry.position - pointLight.position); - var cubeFace = getCubeFace(lightInfo.direction); - var lightPos: vec4 = pointLightShadow.shadowCameraVPMatrixArray[cubeFace] * vec4(geometry.position,1.0); - lightInfo.viewport = pointLightShadow.shadowCameraViewportArray[cubeFace]; - - // var lightPos: vec4 = pointLightShadow.shadowCameraVPMatrix * vec4(geometry.position,1.0); - - shadowValue = getShadowValue(pointLightShadowMapTextureArray, shadowSampler, lightPos, geometry, lightInfo, j, true, - pointLightShadow.shadowCameraNear, pointLightShadow.shadowCameraFar); - - // reflectedLight.testColor = vec3(pointLightShadow.shadowCameraFar / 1000, - // pointLightShadow.shadowCameraVPMatrixArray[5][3][2] / 255, pointLightShadow.shadowCameraVPMatrixArray[5][3][3] / 255); - // reflectedLight.testColor = vec3(pointLightShadow.shadowCameraNear, pointLightShadow.shadowCameraNear, pointLightShadow.shadowCameraNear); - } - pointLight.color *= shadowValue; - #endif - #if ${defines.materialPhong} - let poiReflectedLight=getPointLightInfo(pointLight,geometry.position,shininess,geometry.normal,geometry.viewDir); - #elif ${defines.materialPbr} - let incidentLight=getPointLightIncidentLight(pointLight,geometry); - let poiReflectedLight=direct_Physical(incidentLight, geometry, material); - #endif - - reflectedLight.directDiffuse+=poiReflectedLight.directDiffuse; - reflectedLight.directSpecular+=poiReflectedLight.directSpecular; - } - #endif - #if ${defines.dirtectLightsCount > 0} - //处理方向光 - var directionalLight:DirectionalLight; - for (var i= 0u; i <${defines.dirtectLightsCount}; i = i + 1u) { - directionalLight = lightUniforms.dirtectLights[i]; - #if ${defines.materialPhong && defines.openShadow && defines.directLightShadowMapsCount} - if i < textureNumLayers(directLightShadowMapTextureArray) { - var directLightShadow:DirectLightShadow = shadowUniforms.directLightShadows[i]; - var lightPos: vec4 = directLightShadow.shadowCameraVPMatrix * vec4(geometry.position,1.0); - var lightInfo:LightInfo; - lightInfo.direction = directionalLight.direction; - - shadowValue = getShadowValue(directLightShadowMapTextureArray, shadowSampler, lightPos, geometry, lightInfo, i, false, 0, 0); - } - directionalLight.color *= shadowValue; - #endif - - #if ${defines.materialPhong} - let dirReflectedLight=getDirectLightInfo(directionalLight,shininess,geometry.normal,geometry.viewDir); - #elif ${defines.materialPbr} - let incidentLight=getDirectionalDirectLightIncidentLight(directionalLight,geometry); - let dirReflectedLight=direct_Physical(incidentLight, geometry, material); - #endif - - reflectedLight.directDiffuse+=dirReflectedLight.directDiffuse; - reflectedLight.directSpecular+=dirReflectedLight.directSpecular; - } - #endif - return reflectedLight; - }`; -} - -function lightCommon(defines) { - return wgslParseDefines` - struct ReflectedLight { - directDiffuse:vec3, - directSpecular:vec3, - indirectDiffuse:vec3, - indirectSpecular:vec3, - }; - struct Geometry { - position: vec3, - normal: vec3, - viewDir: vec3, - #if ${defines.USE_CLEARCOAT} - vec3 clearcoatNormal; - #endif - }; - fn getAmbientLightIrradiance(ambientLightColor: vec3) -> vec3 { - let irradiance = ambientLightColor; - return irradiance; - } - fn getDistanceAttenuation(lightDistance: f32, cutoffDistance: f32, decayExponent: f32) -> f32 { - if (cutoffDistance > 0.0 && decayExponent > 0.0) { - let x:f32 = saturate(- lightDistance / cutoffDistance + 1.0); - return pow(x, decayExponent); - } - return 1.0; - } - fn getSpotAttenuation(coneCosine: f32, penumbraCosine: f32, angleCosine: f32) -> f32 { - return smoothstep(coneCosine, penumbraCosine, angleCosine); - } - fn shGetIrradianceAt( normal:vec3, shCoefficients:array,9>)->vec3 { - let x:f32 = normal.x; - let y:f32 = normal.y; - let z:f32 = normal.z; - var result:vec3 = shCoefficients[ 0 ] * 0.886227; - result += shCoefficients[ 1 ] * 2.0 * 0.511664 * y; - result += shCoefficients[ 2 ] * 2.0 * 0.511664 * z; - result += shCoefficients[ 3 ] * 2.0 * 0.511664 * x; - result += shCoefficients[ 4 ] * 2.0 * 0.429043 * x * y; - result += shCoefficients[ 5 ] * 2.0 * 0.429043 * y * z; - result += shCoefficients[ 6 ] * ( 0.743125 * z * z - 0.247708 ); - result += shCoefficients[ 7 ] * 2.0 * 0.429043 * x * z; - result += shCoefficients[ 8 ] * 0.429043 * ( x * x - y * y ); - return result; - } - fn inverseTransformDirection( dir:vec3, matrix:mat4x4 )->vec3 { - return normalize( ( vec4( dir, 0.0 ) * matrix ).xyz ); - } - `; -} - -function getNormal(defines) { - return wgslParseDefines` - fn getNormal(input:FragInput)->vec3{ - var normal:vec3; - #if ${defines.HAS_NORMAL} - normal= input.normal; - #else - let pos_dx = dpdx(input.worldPos); - let pos_dy = dpdy(input.worldPos); - normal = normalize( cross(pos_dy, pos_dx) ); - #endif - return normal*(f32(input.frontFacing) * 2.0 - 1.0); - } - `; -} -function getNormalByNormalTexture(defines) { - return wgslParseDefines` - fn getNormalByNormalTexture(input:VertInput)->vec3{ - var n:vec3 = textureSample(normalTexture,normalSampler, input.uv).rgb; - let tbn:mat3x3 =getTBN(input); - n = normalize(tbn * (2.0 * n - vec3(1.0))); - n=n*(f32(input.frontFacing) * 2.0 - 1.0); - return n; - } - `; -} -function getTBN(defines) { - return wgslParseDefines` - fn getTBN(input:VertInput)->mat3x3{ - #if ${defines.HAS_TANGENT} - let tbn:mat3x3 = input.tbn; - #else - let normal:vec3 =normalize(input.normal); - let uv:vec2 = select(-input.uv,input.uv,input.frontFacing); - // ref: http://www.thetenthplanet.de/archives/1180 - // get edge vectors of the pixel triangle - let dp1:vec3 = vec3(dpdx(input.worldPos.x), dpdx(input.worldPos.y), dpdx(input.worldPos.z)); - let dp2:vec3 = vec3(dpdy(input.worldPos.x), dpdy(input.worldPos.y), dpdy(input.worldPos.z)); - let duv1:vec2 = dpdx(uv); - let duv2:vec2 = dpdy(uv); - - // solve the linear system - let dp2perp:vec3 = cross(dp2, normal); - let dp1perp:vec3 = cross(normal, dp1); - let tangent:vec3 = dp2perp * duv1.x + dp1perp * duv2.x; - let binormal:vec3 = dp2perp * duv1.y + dp1perp * duv2.y; - // construct a scale-invariant frame - let result:f32=max(dot(tangent, tangent), dot(binormal, binormal)); - let invmax:f32 = 1.0/sqrt(result); - let tbn:mat3x3 = mat3x3(tangent * invmax, binormal * invmax, normal); - #endif - return tbn; - } - `; -} - -function brdf(defines) { - return wgslParseDefines` - #if ${defines.USE_SHEEN} - fn D_Charlie( roughness:f32,dotNH:f32 )->f32 { - let alpha:f32 = pow2( roughness ); - let invAlpha:f32 = 1.0 / alpha; - let cos2h:f32 = dotNH * dotNH; - let sin2h:f32 = max( 1.0 - cos2h, 0.0078125 ); - return ( 2.0 + invAlpha ) * pow( sin2h, invAlpha * 0.5 ) / ( 2.0 * PI ); - } - fn V_Neubelt( dotNV:f32, dotNL:f32 )->f32 { - return saturate( 1.0 / ( 4.0 * ( dotNL + dotNV - dotNL * dotNV ) ) ); - } - fn BRDF_Sheen(lightDir:vec3, viewDir:vec3, normal:vec3,sheenColor:vec3,sheenRoughness:f32 )->vec3 { - let halfDir:vec3 = normalize( lightDir + viewDir ); - let dotNL:f32 = saturate( dot( normal, lightDir ) ); - let dotNV:f32 = saturate( dot( normal, viewDir ) ); - let dotNH:f32 = saturate( dot( normal, halfDir ) ); - let D:f32 = D_Charlie( sheenRoughness, dotNH ); - let V:f32 = V_Neubelt( dotNV, dotNL ); - return sheenColor * ( D * V ); - } - #endif - fn BRDF_Lambert(diffuseColor:vec3)->vec3 { + #include + #include + #include + #include + #include + #include + #include + #include + struct SystemUniform { + projectionMatrix: mat4x4, + viewMatrix: mat4x4, + inverseViewMatrix: mat4x4, + cameraPosition: vec3, + }; + // uniform vec3 lightProbe[9], +//////////////////////////////////// +struct VertexOutput { + @builtin(position) position: vec4, + @builtin(front_facing) is_front: bool, + @location(0) vUv: vec2, + @location(1) vViewPosition: vec3, // Vector from vertex to camera. + @location(2) vWorldPosition: vec3, + @location(3) vNormal: vec3, + // 可选 + #if ${defines.USE_LIGHTTEXTURE || defines.USE_AOTEXTURE} + @location(${defines.vUv2OutLocation}) vUv2: vec2, + #endif - return RECIPROCAL_PI * diffuseColor; + #if ${defines.USE_COLOR_ALPHA} + @location(${defines.vColorOutLocation}) vColor: vec4, + #elif ${defines.USE_COLOR || defines.USE_INSTANCING_COLOR} + @location(${defines.vColorOutLocation}) vColor: vec3, + #endif - } // validated + #if ${defines.USE_TANGENT} + @location(${defines.vTangentOutLocation}) vTangent: vec3, + @location(${defines.vBitangentOutLocation}) vBitangent: vec3, + #endif +}; + struct PhysicalMaterial { + diffuseColor:vec3, + roughness:f32, + specularColor:vec3, + specularF90:f32, + #if ${defines.USE_CLEARCOAT} + clearcoat:f32, + clearcoatRoughness:f32, + clearcoatF0:vec3, + clearcoatF90:f32, + #endif - fn F_Schlick( f0:vec3, dotVH:f32 )->vec3 { + #if ${defines.USE_IRIDESCENCE} + iridescence:f32, + iridescenceIOR:f32, + iridescenceThickness:f32, + iridescenceFresnel:vec3, + iridescenceF0:vec3, + #endif - // Original approximation by Christophe Schlick '94 - // float fresnel = pow( 1.0 - dotVH, 5.0 ); + #if ${defines.USE_SHEEN} + sheenColor:vec3, + sheenRoughness:f32, + #endif - // Optimized variant (presented by Epic at SIGGRAPH '13) - // https://cdn2.unrealengine.com/Resources/files/2013SiggraphPresentationsNotes-26915738.pdf - let fresnel = exp2( ( - 5.55473 * dotVH - 6.98316 ) * dotVH ); - return ( 1.0 - f0 ) * fresnel + f0; + #if ${defines.IOR} + ior:f32, + #endif - } // validated + #if ${defines.USE_TRANSMISSION} + transmission:f32, + transmissionAlpha:f32, + thickness:f32, + attenuationDistance:f32, + attenuationColor:vec3, + #endif + }; +@binding(0) @group(0) var materialUniform : MaterialUniform; +@binding(0) @group(1) var systemUniform : SystemUniform; +@fragment +fn main(input:VertexOutput)-> @location(0) vec4 { + var diffuseColor:vec4 = vec4(materialUniform.diffuse, materialUniform.opacity ); + // ReflectedLight reflectedLight = ReflectedLight( vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ) ); + var reflectedLight:ReflectedLight; + var totalEmissiveRadiance:vec3 = materialUniform.emissive; + #if ${defines.USE_TEXTURE} + var sampledDiffuseColor:vec4 =textureSample(baseTexture, baseSampler, input.vUv); + #if ${defines.DECODE_VIDEO_TEXTURE} + sampledDiffuseColor = vec4( mix( pow( sampledDiffuseColor.rgb * 0.9478672986 + vec3( 0.0521327014 ), vec3( 2.4 ) ), sampledDiffuseColor.rgb * 0.0773993808, vec3( lessThanEqual( sampledDiffuseColor.rgb, vec3( 0.04045 ) ) ) ), sampledDiffuseColor.w ); + #endif - fn Schlick_to_F0(f:vec3, f90:f32, dotVH:f32 )->vec3 { - let x:f32 = clamp( 1.0 - dotVH, 0.0, 1.0 ); - let x2:f32 = x * x; - let x5:f32 = clamp( x * x2 * x2, 0.0, 0.9999 ); + diffuseColor *= sampledDiffuseColor; + #endif - return ( f - vec3( f90 ) * x5 ) / ( 1.0 - x5 ); - } - fn V_GGX_SmithCorrelated( alpha:f32, dotNL:f32,dotNV:f32 )->f32 { + var roughnessFactor:f32 = materialUniform.roughness; + + #if ${defines.USE_ROUGHNESSTEXTURE} + let texelRoughness:vec4=textureSample(roughnessTexture, baseSampler, input.vUv); + roughnessFactor *= texelRoughness.g; + #endif - let a2 :f32= pow2( alpha ); + var metalnessFactor:f32 = materialUniform.metalness; + + #if ${defines.USE_METALNESSTEXTURE} + let texelMetalness:vec4 =textureSample(metalnessTexture, baseSampler, input.vUv); + metalnessFactor *= texelMetalness.b; + #endif - let gv:f32 = dotNL * sqrt( a2 + ( 1.0 - a2 ) * pow2( dotNV ) ); - let gl:f32 = dotNV * sqrt( a2 + ( 1.0 - a2 ) * pow2( dotNL ) ); + let faceDirection:f32 =select(-1.0,1.0,input.is_front); + #if ${defines.FLAT_SHADED} + let fdx:vec3 = dpdx( input.vViewPosition ); + let fdy:vec3 = dpdy( input.vViewPosition ); + let normal:vec3 = normalize( cross( fdy, fdx ) ); + #else + let normal:vec3 = normalize( input.vNormal ); + #if ${defines.DOUBLE_SIDED} + normal = normal * faceDirection; + #endif + #if ${defines.USE_TANGENT} + let tangent:vec3 = normalize( input.vTangent ); + let bitangent:vec3 = normalize( input.vBitangent ); + #if ${defines.DOUBLE_SIDED} + tangent = tangent * faceDirection; + bitangent = bitangent * faceDirection; + #endif + #if ${defines.TANGENTSPACE_NORMALTEXTURE || defines.USE_CLEARCOAT_NORMALTEXTURE} + let vTBN:mat3x3 = mat3x3( tangent, bitangent, normal ); + #endif + #endif + #endif + + let geometryNormal:vec3 = normal; - return 0.5 / max((gv + gl), 0.000000001 ); + #if ${defines.OBJECTSPACE_NORMALTEXTURE} + normal =textureSample(normalTexture, baseSampler, input.vUv).xyz * 2.0 - 1.0; + #if ${defines.FLIP_SIDED} + normal = - normal; + #endif + #if ${defines.DOUBLE_SIDED} + normal = normal * faceDirection; + #endif - } - fn D_GGX( alpha:f32, dotNH:f32 )->f32 { + normal = normalize(materialUniform.normalMatrix * normal ); - let a2:f32 = pow2( alpha ); + #elif ${defines.TANGENTSPACE_NORMALTEXTURE} + let tempMapN:vec3 =textureSample(normalTexture, baseSampler, input.vUv).xyz * 2.0 - 1.0; + let mapN:vec3 =tempMapN.xy *= materialUniform.normalScale; + #if ${defines.USE_TANGENT} + normal = normalize( vTBN * mapN ); + #else + normal = perturbNormal2Arb( - input.vViewPosition, normal, mapN, faceDirection ); + #endif - let denom:f32 = pow2( dotNH ) * ( a2 - 1.0 ) + 1.0; // avoid alpha = 0 with dotNH = 1 + #elif ${defines.USE_BUMPTEXTURE} - return RECIPROCAL_PI * a2 / pow2( denom ); + normal = perturbNormalArb( - input.vViewPosition, normal, dHdxy_fwd(), faceDirection ); + #endif - } - fn BRDF_GGX( lightDir:vec3, viewDir:vec3, normal:vec3, f0:vec3, roughness:f32 )->vec3 { + #if ${defines.USE_CLEARCOAT} + var clearcoatNormal:vec3 = geometryNormal; + #endif + #if ${defines.USE_CLEARCOAT_NORMALTEXTURE} + var clearcoatMapN:vec3 =textureSample(clearcoatNormalTexture, baseSampler, input.vUv).xyz * 2.0 - 1.0; + clearcoatMapN.xy *= materialUniform.clearcoatNormalScale; + #if ${defines.USE_TANGENT} + clearcoatNormal = normalize( vTBN * clearcoatMapN ); + #else + clearcoatNormal = perturbNormal2Arb( - input.vViewPosition, clearcoatNormal, clearcoatMapN, faceDirection ); + #endif + #endif + #if ${defines.USE_EMISSIVETEXTURE} + let emissiveColor:vec4 =textureSample(emissiveTexture, baseSampler, input.vUv); + totalEmissiveRadiance *= emissiveColor.rgb; + #endif - let alpha:f32 = pow2( roughness ); // UE4's roughness + var material:PhysicalMaterial; + material.diffuseColor = diffuseColor.rgb * ( 1.0 - metalnessFactor ); + let dxy:vec3 = max( abs( dpdx( geometryNormal ) ), abs( dpdy( geometryNormal ) ) ); + let geometryRoughness:f32 = max( max( dxy.x, dxy.y ), dxy.z ); + material.roughness = max( roughnessFactor, 0.0525 ); + material.roughness += geometryRoughness; + material.roughness = min( material.roughness, 1.0 ); - let halfDir = normalize( lightDir + viewDir ); + #if ${defines.IOR} + material.ior = materialUniform.ior; + #if ${defines.SPECULAR} + let specularIntensityFactor:f32 = materialUniform.specularIntensity; + let specularColorFactor:vec3 = materialUniform.specularColor; + #if ${defines.USE_SPECULARINTENSITYTEXTURE} + specularIntensityFactor *=textureSample(specularIntensityTexture, baseSampler, input.vUv).a; + #endif - let dotNL:f32 = saturate( dot( normal, lightDir ) ); - let dotNV:f32 = saturate( dot( normal, viewDir ) ); - let dotNH:f32 = saturate( dot( normal, halfDir ) ); - let dotVH:f32 = saturate( dot( lightDir, halfDir ) ); + #if ${defines.USE_SPECULARCOLORTEXTURE} + specularColorFactor *=textureSample(specularColorTexture, baseSampler, input.vUv).rgb; + #endif - let F = F_Schlick( f0, dotVH ); + material.specularF90 = mix( specularIntensityFactor, 1.0, metalnessFactor ); + #else + let specularIntensityFactor:f32 = 1.0; + let specularColorFactor:vec3 = vec3( 1.0 ); + material.specularF90 = 1.0; + #endif + material.specularColor = mix( min( pow2( ( material.ior - 1.0 ) / ( material.ior + 1.0 ) ) * specularColorFactor, vec3( 1.0 ) ) * specularIntensityFactor, diffuseColor.rgb, metalnessFactor ); + #else + material.specularColor = mix( vec3( 0.04 ), diffuseColor.rgb, metalnessFactor ); + material.specularF90 = 1.0; + #endif + #if ${defines.USE_CLEARCOAT} + material.clearcoat = materialUniform.clearcoat; + material.clearcoatRoughness = materialUniform.clearcoatRoughness; + material.clearcoatF0 = vec3( 0.04 ); + material.clearcoatF90 = 1.0; + #if ${defines.USE_CLEARCOATTEXTURE} + material.clearcoat *=textureSample(clearcoatTexture, baseSampler, input.vUv).x; + #endif + #if ${defines.USE_CLEARCOAT_ROUGHNESSTEXTURE} + material.clearcoatRoughness *=textureSample(clearcoatRoughnessTexture, baseSampler, input.vUv).y; + #endif + material.clearcoat = saturate( material.clearcoat ); + material.clearcoatRoughness = max( material.clearcoatRoughness, 0.0525 ); + material.clearcoatRoughness += geometryRoughness; + material.clearcoatRoughness = min( material.clearcoatRoughness, 1.0 ); + #endif + #if ${defines.USE_IRIDESCENCE} + material.iridescence = materialUniform.iridescence; + material.iridescenceIOR = materialUniform.iridescenceIOR; + #if ${defines.USE_IRIDESCENCETEXTURE} + material.iridescence *=textureSample(iridescenceTexture, baseSampler, input.vUv).r; + #endif + #if ${defines.USE_IRIDESCENCE_THICKNESSTEXTURE} + material.iridescenceThickness = (materialUniform.iridescenceThicknessMaximum - materialUniform.iridescenceThicknessMinimum) * textureSample(iridescenceThicknessTexture, baseSampler, input.vUv).g + materialUniform.iridescenceThicknessMinimum; + #else + material.iridescenceThickness = materialUniform.iridescenceThicknessMaximum; + #endif + #endif + #if ${defines.USE_SHEEN} + material.sheenColor = materialUniform.sheenColor; + #if ${defines.USE_SHEENCOLORTEXTURE} + material.sheenColor *=textureSample(sheenColorTexture, baseSampler, input.vUv).rgb; + #endif + material.sheenRoughness = clamp( materialUniform.sheenRoughness, 0.07, 1.0 ); + #if ${defines.USE_SHEENROUGHNESSTEXTURE} + material.sheenRoughness *=textureSample(sheenRoughnessTexture, baseSampler, input.vUv).a; + #endif + #endif + + var geometry:GeometricContext; + geometry.position = - input.vViewPosition; + geometry.normal = normal; + // geometry.viewDir = ( isOrthographic ) ? vec3( 0, 0, 1 ) : normalize( input.vViewPosition ); + geometry.viewDir = normalize( input.vViewPosition); - let V = V_GGX_SmithCorrelated( alpha, dotNL, dotNV ); + #if ${defines.USE_CLEARCOAT} + geometry.clearcoatNormal = clearcoatNormal; + #endif - let D = D_GGX( alpha, dotNH ); + #if ${defines.USE_IRIDESCENCE} + let dotNVi:f32 = saturate( dot( normal, geometry.viewDir ) ); + if ( material.iridescenceThickness == 0.0 ) { + material.iridescence = 0.0; + } + else { + material.iridescence = saturate( material.iridescence ); + } + if ( material.iridescence > 0.0 ) { + material.iridescenceFresnel = evalIridescence( 1.0, material.iridescenceIOR, dotNVi, material.iridescenceThickness, material.specularColor ); + material.iridescenceF0 = Schlick_to_F0( material.iridescenceFresnel, 1.0, dotNVi ); + } + #endif - return F * ( V * D ); + var iblIrradiance:vec3 = vec3( 0.0 ); + var irradiance:vec3 = getAmbientLightIrradiance(commonLightsParms.ambient); + //irradiance += getLightProbeIrradiance( lightProbe, geometry.normal,systemUniform.viewMatrix ); - } - fn direct_Physical( directLight:IncidentLight, geometry:Geometry,material:PhysicalMaterial)->ReflectedLight { - var reflectedLight:ReflectedLight; - let dotNL:f32 = saturate(dot( geometry.normal,geometry.viewDir)); - let irradiance:vec3 = dotNL * directLight.color*3.1415926; - reflectedLight.directSpecular = irradiance * BRDF_GGX( directLight.direction, geometry.viewDir, geometry.normal, material.specularColor, material.roughness ); - reflectedLight.directDiffuse = irradiance * BRDF_Lambert( material.diffuseColor ); - return reflectedLight; - } - `; -} + var radiance:vec3 = vec3( 0.0 ); + var clearcoatRadiance:vec3 = vec3( 0.0 ); -function ibl(defines) { - return wgslParseDefines` - fn getLightProbeRadiance( viewDir:vec3,normal:vec3, roughness:f32 )->vec3{ - var reflectVec:vec3 = reflect( -viewDir, normal ); - reflectVec.x = -reflectVec.x; // TextureCube is left-hand,so x need inverse - let mipCount:f32 = 10.0; // resolution of 256x256 - let lod:f32 = roughness * mipCount; - let specularLight:vec3 = textureSampleLevel(specularEnvTexture,specularEnvSampler, reflectVec, lod).rgb; - return specularLight; - } - fn getLightProbeIrradiance( lightProbe:array,9>, normal:vec3)->vec3 { - var worldNormal:vec3 = normal; - worldNormal.x = -normal.x; - var irradiance:vec3 = lightProbe[0]; - irradiance+=lightProbe[1] * (normal.y); - irradiance+=lightProbe[2] * (normal.z) ; - irradiance+=lightProbe[3] * (normal.x) ; + #if ${defines.USE_LIGHTTEXTURE} + let lightMapTexel:vec4 =textureSample(lightTexture, baseSampler, input.vUv2); + let lightMapIrradiance:vec3 = lightMapTexel.rgb * materialUniform.lightTextureIntensity; + irradiance += lightMapIrradiance; + #endif + //&& defines.STANDARD&&defines.ENVTEXTURE_TYPE_CUBE_UV + #if ${defines.USE_ENVTEXTURE} + iblIrradiance += getIBLIrradiance( geometry.normal,baseSampler,systemUniform.viewMatrix ); + #endif + #if ${defines.USE_ENVTEXTURE} + radiance += getIBLRadiance( geometry.viewDir,baseSampler,systemUniform.viewMatrix, geometry.normal, materialUniform.roughness ); + #if ${defines.USE_CLEARCOAT} + clearcoatRadiance += getIBLRadiance( geometry.viewDir,baseSampler,systemUniform.viewMatrix, geometry.clearcoatNormal, material.clearcoatRoughness ); + #endif + #endif + //直接光照 + let dirReflectedLight:ReflectedLight= parseLights(geometry,material); + reflectedLight.directDiffuse +=dirReflectedLight.directDiffuse; + reflectedLight.directSpecular +=dirReflectedLight.directSpecular; + //间接漫反射 + let indirectDiffuseLight:ReflectedLight= RE_IndirectDiffuse_Physical( irradiance, geometry, material); + reflectedLight.directDiffuse +=indirectDiffuseLight.indirectDiffuse; + reflectedLight.directSpecular +=indirectDiffuseLight.indirectSpecular; + //间接高光 + let indirectSpecularLight:ReflectedLight=RE_IndirectSpecular_Physical( radiance, iblIrradiance, clearcoatRadiance, geometry, material); + reflectedLight.directDiffuse +=indirectSpecularLight.indirectDiffuse; + reflectedLight.directSpecular +=indirectSpecularLight.indirectSpecular; + //环境光遮蔽 + #if ${defines.USE_AOTEXTURE} + let ambientOcclusion:f32 = (textureSample(aoTexture, baseSampler, input.vUv2).r - 1.0 ) * materialUniform.aoTextureIntensity + 1.0; - irradiance+=lightProbe[4] * (normal.y * normal.x) ; - irradiance+=lightProbe[5] * (normal.y * normal.z) ; - irradiance+=lightProbe[6] * (3.0 * normal.z * normal.z - 1.0); - irradiance+=lightProbe[7] * (normal.z * normal.x) ; - irradiance+=lightProbe[8] * (normal.x * normal.x - normal.y * normal.y); + reflectedLight.indirectDiffuse *= ambientOcclusion; + //&&defines.STANDARD + #if ${defines.USE_ENVTEXTURE} + let dotNV:f32 = saturate( dot( geometry.normal, geometry.viewDir ) ); + reflectedLight.indirectSpecular *= computeSpecularOcclusion( dotNV, ambientOcclusion, material.roughness ); + #endif + #endif - return max(irradiance, vec3(0.0,0.0,0.0)); - } - fn DFGApprox( specularColor:vec3, roughness:f32,dotNV:f32 )->vec3 { - const c0:vec4 = vec4( - 1, - 0.0275, - 0.572, 0.022 ); - let c1:vec4 = vec4( 1, 0.0425, 1.04, - 0.04 ); - let r:vec4 = roughness * c0 + c1; - let a004:f32 = min( r.x * r.x, exp2( - 9.28 * dotNV ) ) * r.x + r.y; - let fab:vec2 = vec2( - 1.04, 1.04 ) * a004 + r.zw; - return specularColor * fab.x + fab.y; - } - //间接光照 - fn indirectDiffuse_Physical(geometry:Geometry, material:PhysicalMaterial )->ReflectedLight { - var reflectedLight:ReflectedLight; - var irradiance:vec3 = lightUniforms.ambient.xyz*lightUniforms.ambient.w; - irradiance *= PI; - reflectedLight.indirectDiffuse += irradiance * BRDF_Lambert( material.diffuseColor ); - return reflectedLight; - } - //间接高光 - fn indirectSpecular_Physical(geometry:Geometry, material:PhysicalMaterial)->ReflectedLight { - var reflectedLight:ReflectedLight; - // IBL specular - let radiance:vec3 = getLightProbeRadiance(geometry.viewDir, geometry.normal, material.roughness); - let radianceAttenuation:f32 = 1.0; - reflectedLight.indirectSpecular += radianceAttenuation * radiance * DFGApprox(material.specularColor, material.roughness, geometry.dotNV ); - return reflectedLight; - } - `; -} + var totalDiffuse:vec3 = reflectedLight.directDiffuse + reflectedLight.indirectDiffuse; + var totalSpecular:vec3 = reflectedLight.directSpecular + reflectedLight.indirectSpecular; + //透射 + #if ${defines.USE_TRANSMISSION} + material.transmission = materialUniform.transmission; + material.transmissionAlpha = 1.0; + material.thickness = materialUniform.thickness; + material.attenuationDistance = materialUniform.attenuationDistance; + material.attenuationColor = materialUniform.attenuationColor; + #if ${defines.USE_TRANSMISSIONTEXTURE} + material.transmission *=textureSample(transmissionTexture, baseSampler, input.vUv).r; + #endif + #if ${defines.USE_THICKNESSTEXTURE} + material.thickness *=textureSample(thicknessTexture, baseSampler, input.vUv).g; + #endif + let pos:vec3 = vWorldPosition; + let v:vec3 = normalize( cameraPosition - pos ); + let n:vec3 = inverseTransformDirection( normal, systemUniform.viewMatrix ); + let transmission:vec4 = getIBLVolumeRefraction( + n, v, material.roughness, material.diffuseColor, material.specularColor, material.specularF90, pos, modelMatrix, systemUniform.viewMatrix, systemUniform.projectionMatrix, material.ior, material.thickness, material.attenuationColor, material.attenuationDistance ); + material.transmissionAlpha = mix( material.transmissionAlpha, transmission.a, material.transmission ); + totalDiffuse = mix( totalDiffuse, transmission.rgb, material.transmission ); + #endif -function pbrFunction(defines) { - return wgslParseDefines` + let outgoingLight:vec3 = totalDiffuse + totalSpecular + totalEmissiveRadiance; - #if ${defines.DITHERING} - fn dithering(color:vec3 )->vec3 { - let grid_position:f32 = rand( gl_FragCoord.xy ); - let dither_shift_RGB:vec3 = vec3( 0.25 / 255.0, -0.25 / 255.0, 0.25 / 255.0 ); - dither_shift_RGB = mix( 2.0 * dither_shift_RGB, -2.0 * dither_shift_RGB, grid_position ); - return color + dither_shift_RGB; - } - #endif + #if ${defines.USE_SHEEN} + let sheenEnergyComp:f32 = 1.0 - 0.157 * max3( material.sheenColor ); + outgoingLight = outgoingLight * sheenEnergyComp + sheenSpecular; + #endif - #if ${defines.USE_IRIDESCENCE} - fn BRDF_GGX_Iridescence( lightDir:vec3, viewDir:vec3,normal:vec3, f0:vec3, f90:f32,iridescence:f32, iridescenceFresnel:vec3,roughness:f32 )->vec3 { - let alpha:f32 = pow2( roughness ); - let halfDir:vec3 = normalize( lightDir + viewDir ); - let dotNL:f32 = saturate( dot( normal, lightDir ) ); - let dotNV:f32 = saturate( dot( normal, viewDir ) ); - let dotNH:f32 = saturate( dot( normal, halfDir ) ); - let dotVH:f32 = saturate( dot( viewDir, halfDir ) ); - let F:vec3 = mix( F_Schlick( f0, f90, dotVH ), iridescenceFresnel, iridescence ); - let V:f32 = V_GGX_SmithCorrelated( alpha, dotNL, dotNV ); - let D:f32 = D_GGX( alpha, dotNH ); - return F * ( V * D ); - } - #endif + #if ${defines.USE_CLEARCOAT} + let dotNVcc:f32 = saturate( dot( geometry.clearcoatNormal, geometry.viewDir ) ); + let Fcc:vec3 = F_Schlick( material.clearcoatF0, material.clearcoatF90, dotNVcc ); + outgoingLight = outgoingLight * ( 1.0 - material.clearcoat * Fcc ) + clearcoatSpecular * material.clearcoat; + #endif - #if ${defines.USE_SHEEN} - fn D_Charlie( roughness:f32,dotNH:f32 )->f32 { - let alpha:f32 = pow2( roughness ); - let invAlpha:f32 = 1.0 / alpha; - let cos2h:f32 = dotNH * dotNH; - let sin2h:f32 = max( 1.0 - cos2h, 0.0078125 ); - return ( 2.0 + invAlpha ) * pow( sin2h, invAlpha * 0.5 ) / ( 2.0 * PI ); - } - fn V_Neubelt( dotNV:f32, dotNL:f32 )->f32 { - return saturate( 1.0 / ( 4.0 * ( dotNL + dotNV - dotNL * dotNV ) ) ); - } - fn BRDF_Sheen(lightDir:vec3, viewDir:vec3, normal:vec3,sheenColor:vec3,sheenRoughness:f32 )->vec3 { - let halfDir:vec3 = normalize( lightDir + viewDir ); - let dotNL:f32 = saturate( dot( normal, lightDir ) ); - let dotNV:f32 = saturate( dot( normal, viewDir ) ); - let dotNH:f32 = saturate( dot( normal, halfDir ) ); - let D:f32 = D_Charlie( sheenRoughness, dotNH ); - let V:f32 = V_Neubelt( dotNV, dotNL ); - return sheenColor * ( D * V ); - } - #endif + #if ${defines.USE_TRANSMISSION} + diffuseColor.a *= material.transmissionAlpha + 0.1; + #endif - #if ${defines.USE_IRIDESCENCE} - let XYZ_TO_REC709: mat3x3 = mat3x3( - 3.2404542, -0.9692660, 0.0556434, -1.5371385, 1.8760108, -0.2040259, -0.4985314, 0.0415560, 1.0572252 - ); - fn Fresnel0ToIor( fresnel0:vec3 )->vec3 { - let sqrtF0:vec3 = sqrt( fresnel0 ); - return ( vec3( 1.0 ) + sqrtF0 ) / ( vec3( 1.0 ) - sqrtF0 ); - } - fn IorToFresnel0(transmittedIor:vec3,incidentIor:f32 )->vec3 { - return pow2Vector( ( transmittedIor - vec3( incidentIor ) ) / ( transmittedIor + vec3( incidentIor ) ) ); - } - fn IorToFresnel0(transmittedIor:f32, incidentIor:f32 )->f32 { - return pow2Vector( ( transmittedIor - incidentIor ) / ( transmittedIor + incidentIor )); - } - fn evalSensitivity(OPD:f32,shift:vec3 )->vec3 { - let phase:f32 = 2.0 * PI * OPD * 1.0e-9; - let val:vec3 = vec3( 5.4856e-13, 4.4201e-13, 5.2481e-13 ); - let pos:vec3 = vec3( 1.6810e+06, 1.7953e+06, 2.2084e+06 ); - let vart:vec3 = vec3( 4.3278e+09, 9.3046e+09, 6.6121e+09 ); - let xyz:vec3 = val * sqrt( 2.0 * PI * vart ) * cos( pos * phase + shift ) * exp( - pow2( phase ) * vart ); - xyz.x += 9.7470e-14 * sqrt( 2.0 * PI * 4.5282e+09 ) * cos( 2.2399e+06 * phase + shift[ 0 ] ) * exp( - 4.5282e+09 * pow2( phase ) ); - xyz /= 1.0685e-7; - let rgb:vec3 = XYZ_TO_REC709 * xyz; - return rgb; - } - fn evalIridescence(outsideIOR:f32, eta2:f32,cosTheta1:f32,thinFilmThickness:f32,baseF0:vec3 )->vec3 { - var I:vec3; - let iridescenceIOR:f32 = mix( outsideIOR, eta2, smoothstep( 0.0, 0.03, thinFilmThickness ) ); - let sinTheta2Sq:f32 = pow2( outsideIOR / iridescenceIOR ) * ( 1.0 - pow2( cosTheta1 ) ); - let cosTheta2Sq:f32 = 1.0 - sinTheta2Sq; - if ( cosTheta2Sq < 0.0 ) { - return vec3( 1.0 ); - } - let cosTheta2:f32 = sqrt( cosTheta2Sq ); - let R0:f32 = IorToFresnel0( iridescenceIOR, outsideIOR ); - let R12:f32 = F_Schlick( R0, 1.0, cosTheta1 ); - let R21:f32 = R12; - let T121:f32 = 1.0 - R12; - let phi12:f32 = 0.0; - if ( iridescenceIOR < outsideIOR ) phi12 = PI; - let phi21:f32 = PI - phi12; - let baseIOR:vec3 = Fresnel0ToIor( clamp( baseF0, 0.0, 0.9999 ) ); - let R1:vec3 = IorToFresnel0( baseIOR, iridescenceIOR ); - let R23:vec3 = F_Schlick( R1, 1.0, cosTheta2 ); - let phi23:vec3 = vec3( 0.0 ); - if ( baseIOR[ 0 ] < iridescenceIOR ) phi23[ 0 ] = PI; - if ( baseIOR[ 1 ] < iridescenceIOR ) phi23[ 1 ] = PI; - if ( baseIOR[ 2 ] < iridescenceIOR ) phi23[ 2 ] = PI; - let OPD:f32 = 2.0 * iridescenceIOR * thinFilmThickness * cosTheta2; - let phi:vec3 = vec3( phi21 ) + phi23; - let R123:vec3 = clamp( R12 * R23, 1e-5, 0.9999 ); - let r123:vec3 = sqrt( R123 ); - let Rs:vec3 = pow2( T121 ) * R23 / ( vec3( 1.0 ) - R123 ); - let C0:vec3 = R12 + Rs; - I = C0; - let Cm:vec3 = Rs - T121; - for ( let m : u32 = 1;m <= 2; ++ m ) { - Cm *= r123; - Sm:vec3 = 2.0 * evalSensitivity( f32( m ) * OPD, f32( m ) * phi ); - I += Cm * Sm; - } - return max( I, vec3( 0.0 ) ); - } - #endif - const clearcoatSpecular:vec3 = vec3( 0.0 ); - const sheenSpecular:vec3 = vec3( 0.0 ); + var finnalColor:vec4; + finnalColor = vec4( outgoingLight, diffuseColor.a ); + #if ${defines.TONE_MAPPING} + finnalColor.rgb = toneMapping( finnalColor.rgb,materialUniform.toneMappingExposure ); + #endif - fn IBLSheenBRDF( normal:vec3, viewDir:vec3, roughness:f32 )->f32 { - let dotNV:f32 = saturate( dot( normal, viewDir ) ); - let r2:f32 = roughness * roughness; - let a:f32 =select(-8.48 * r2 + 14.3 * roughness - 9.95,-339.2 * r2 + 161.4 * roughness - 25.9,roughness < 0.25); - //let a:f32 = roughness < 0.25 ? -339.2 * r2 + 161.4 * roughness - 25.9 : -8.48 * r2 + 14.3 * roughness - 9.95; - let b:f32=select(1.97 * r2 - 3.27 * roughness + 0.72,44.0 * r2 - 23.7 * roughness + 3.26, roughness < 0.25); - //let b:f32 = roughness < 0.25 ? 44.0 * r2 - 23.7 * roughness + 3.26 : 1.97 * r2 - 3.27 * roughness + 0.72; - //let DG:f32 = exp( a * dotNV + b ) + ( roughness < 0.25 ? 0.0 : 0.1 * ( roughness - 0.25 ) ); - let DG:f32 = exp( a * dotNV + b ) + select(0.1 * ( roughness - 0.25 ),0.0,roughness < 0.25); - return saturate( DG * RECIPROCAL_PI ); - } - fn DFGApprox( specularColor:vec3, roughness:f32,dotNV:f32 )->vec3 { - const c0:vec4 = vec4( - 1, - 0.0275, - 0.572, 0.022 ); - let c1:vec4 = vec4( 1, 0.0425, 1.04, - 0.04 ); - let r:vec4 = roughness * c0 + c1; - let a004:f32 = min( r.x * r.x, exp2( - 9.28 * dotNV ) ) * r.x + r.y; - let fab:vec2 = vec2( - 1.04, 1.04 ) * a004 + r.zw; - return specularColor * fab.x + fab.y; - } - fn EnvironmentBRDF( normal:vec3,viewDir:vec3,specularColor:vec3, specularF90:f32,roughness:f32 )->vec3 { - let fab:vec2 = DFGApprox( normal, viewDir, roughness ); - return specularColor * fab.x + specularF90 * fab.y; - } + finnalColor = linearToOutputTexel( finnalColor); + #if ${defines.PREMULTIPLIED_ALPHA} + finnalColor.rgb *= finnalColor.a; + #endif + #if ${defines.DITHERING} + finnalColor.rgb = dithering( finnalColor.rgb ); + #endif + return finnalColor; + }`; +} - fn computeSpecularOcclusion( dotNV:f32, ambientOcclusion:f32, roughness:f32 )->f32 { - return saturate( pow( dotNV + ambientOcclusion, exp2( - 16.0 * roughness - 1.0 ) ) - 1.0 + ambientOcclusion ); - } - #if ${defines.USE_TRANSMISSION} +function pbrVert(defines) { + return wgslParseDefines` + #include + struct VertexOutput { + @builtin(position) position: vec4, + @location(0) vUv: vec2, + @location(1) vViewPosition: vec3, // Vector from vertex to camera. + @location(2) vWorldPosition: vec3, + @location(3) vNormal: vec3, + // 可选 + #if ${defines.USE_LIGHTTEXTURE || defines.USE_AOTEXTURE} + @location(${defines.vUv2OutLocation}) vUv2: vec2, + #endif - fn getVolumeTransmissionRay( n:vec3, v:vec3, thickness:f32, ior:f32, modelMatrix:mat4x4:f32)->vec3 { - var refractionVector:vec3 = refract( - v, normalize( n ), 1.0 / ior ); - var modelScale:vec3; - modelScale.x = length( vec3( modelMatrix[0].xyz ) ); - modelScale.y = length( vec3( modelMatrix[1].xyz ) ); - modelScale.z = length( vec3( modelMatrix[2].xyz ) ); - return normalize( refractionVector ) * thickness * modelScale; - } - fn applyIorToRoughness(roughness:f32, ior:f32 )->f32 { - return roughness * clamp( ior * 2.0 - 2.0, 0.0, 1.0 ); - } - fn getTransmissionSample( fragCoord:vec2, roughness:f32,ior:f32 )->vec4 { - let framebufferLod:f32 = log2( materialUniform.transmissionSamplerSize.x ) * applyIorToRoughness( roughness, ior ); - return textureSampleLevel(transmissionSamplerTexture,baseSampler,fragCoord.xy, framebufferLod); + #if ${defines.USE_COLOR_ALPHA} + @location(${defines.vColorOutLocation}) vColor: vec4, + #elif ${defines.USE_COLOR || defines.USE_INSTANCING_COLOR} + @location(${defines.vColorOutLocation}) vColor: vec3, + #endif - } - fn applyVolumeAttenuation( radiance:vec3, transmissionDistance:f32,attenuationColor:vec3,attenuationDistance:f32 )->vec3 { - if ( isinf( attenuationDistance ) ) { - return radiance; - } - else { - let attenuationCoefficient:vec3 = -log( attenuationColor ) / attenuationDistance; - let transmittance:vec3 = exp( - attenuationCoefficient * transmissionDistance ); - return transmittance * radiance; - } - - } - fn getIBLVolumeRefraction( n:vec3,v:vec3, roughness:f32, diffuseColor:vec3,specularColor:vec3, specularF90:f32,position:vec3, modelMatrix:mat4x4, viewMatrix:mat4x4,projMatrix:mat4x4,ior:f32, thickness:f32,attenuationColor:vec3,attenuationDistance:f32 )->vec4 { - let transmissionRay:vec3 = getVolumeTransmissionRay( n, v, thickness, ior, modelMatrix ); - let refractedRayExit:vec3 = position + transmissionRay; - let ndcPos:vec4 = projMatrix * viewMatrix * vec4( refractedRayExit, 1.0 ); - let refractionCoords:vec2 = ndcPos.xy / ndcPos.w; - refractionCoords += 1.0; - refractionCoords /= 2.0; - let transmittedLight:vec4 = getTransmissionSample( refractionCoords, roughness, ior ); - let attenuatedColor:vec3 = applyVolumeAttenuation( transmittedLight.rgb, length( transmissionRay ), attenuationColor, attenuationDistance ); - let F:vec3 = EnvironmentBRDF( n, v, specularColor, specularF90, roughness ); - return vec4( ( 1.0 - F ) * attenuatedColor * diffuseColor, transmittedLight.a ); - } - #endif + #if ${defines.USE_TANGENT} + @location(${defines.vTangentOutLocation}) vTangent: vec3, + @location(${defines.vBitangentOutLocation}) vBitangent: vec3, + #endif + }; + struct GlobalUniform { + projectionMatrix: mat4x4, + viewMatrix: mat4x4, + inverseViewMatrix: mat4x4, + cameraPosition: vec3, + }; - #if ${defines.USE_BUMPTEXTURE} - fn dHdxy_fwd()->vec2 { - let dSTdx:vec2 = dpdx( vUv ); - let dSTdy:vec2 = dpdy( vUv ); + //texture and sampler + // @group(0) @binding(${defines.samplerBinding}) var baseSampler: sampler; + #if ${defines.USE_SKINNING} + //uniform highp sampler2D boneTexture; + @group(0) @binding(${defines.boneTextureBinding}) var boneTexture: texture_2d; + #endif - let Hll:f32 = materialUniform.bumpScale * textureSample(bumpTexture, baseSampler, vUv).x; - let dBx:f32 = materialUniform.bumpScale * textureSample(bumpTexture, baseSampler, vUv + dSTdx).x - Hll; - let dBy:f32 = materialUniform.bumpScale * textureSample(bumpTexture, baseSampler, vUv + dSTdy).x - Hll; - return vec2( dBx, dBy ); - } - fn perturbNormalArb( surf_pos:vec3, surf_norm:vec3, dHdxy:vec2, faceDirection:f32 )->vec3 { - let vSigmaX:vec3 = dpdx( surf_pos.xyz ); - let vSigmaY:vec3 = dpdy( surf_pos.xyz ); - let vN:vec3 = surf_norm; - let R1:vec3 = cross( vSigmaY, vN ); - let R2:vec3 = cross( vN, vSigmaX ); - let fDet:f32 = dot( vSigmaX, R1 ) * faceDirection; - let vGrad:vec3 = sign( fDet ) * ( dHdxy.x * R1 + dHdxy.y * R2 ); - return normalize( abs( fDet ) * surf_norm - vGrad ); - } + #if ${defines.USE_DISPLACEMENTTEXTURE} + //uniform sampler2D displacementMap; + @group(0) @binding(${defines.displacementTextureBinding}) var displacementMap: texture_2d; #endif - //! defined ( USE_TANGENT ) && ( defined ( TANGENTSPACE_NORMALTEXTURE ) || defined ( USE_CLEARCOAT_NORMALTEXTURE ) ) - #if ${(!defines.USE_TANGENT && defines.TANGENTSPACE_NORMALTEXTURE) || defines.USE_CLEARCOAT_NORMALTEXTURE} - fn perturbNormal2Arb( eye_pos:vec3, surf_norm:vec3, textureN:vec3, faceDirection:f32 )->vec3 { - let q0:vec3 = dpdx( eye_pos.xyz ); - let q1:vec3 = dpdy( eye_pos.xyz ); - let st0:vec2 = dpdx( vUv.st ); - let st1:vec2 = dpdy( vUv.st ); - let N:vec3 = surf_norm; - let q1perp:vec3 = cross( q1, N ); - let q0perp:vec3 = cross( N, q0 ); - let T:vec3 = q1perp * st0.x + q0perp * st1.x; - let B:vec3 = q1perp * st0.y + q0perp * st1.y; - let det:f32 = max( dot( T, T ), dot( B, B ) ); - let scale:f32 = ( det == 0.0 ) ? 0.0 : faceDirection * inversesqrt( det ); - return normalize( T * ( textureN.x * scale ) + B * ( textureN.y * scale ) + N * textureN.z ); - } + #if ${defines.MORPHTARGETS_TEXTURE} + //uniform sampler2DArray morphTargetsTexture; + @group(0) @binding(${defines.morphTargetsTextureBinding}) var morphTargetsTexture: texture_2d_array; #endif - struct MultiAndSingleScatter{ - multiScatter:vec3, - singleScatter:vec3 - } - #if ${defines.USE_IRIDESCENCE} - ////////inout vec3 singleScatter, inout vec3 multiScatter - fn computeMultiscatteringIridescence( normal:vec3, viewDir:vec3, specularColor:vec3, specularF90:f32, iridescence:f32,iridescenceF0:vec3, roughness:f32 )->MultiAndSingleScatter { - #else - ////////inout vec3 singleScatter, inout vec3 multiScatter - fn computeMultiscattering( normal:vec3,viewDir:vec3, specularColor:vec3, specularF90:f32, roughness:f32)->MultiAndSingleScatter { - #endif - let fab:vec2 = DFGApprox( normal, viewDir, roughness ); - var multiAndSingleScatter:MultiAndSingleScatter; + struct VertexInput { + @location(0) position: vec3, - #if ${defines.USE_IRIDESCENCE} - let Fr:vec3 = mix( specularColor, iridescenceF0, iridescence ); - #else - let Fr:vec3 = specularColor; - #endif - let FssEss:vec3 = Fr * fab.x + specularF90 * fab.y; - let Ess:f32 = fab.x + fab.y; - let Ems:f32 = 1.0 - Ess; - let Favg:vec3 = Fr + ( 1.0 - Fr ) * 0.047619; - let Fms:vec3 = FssEss * Favg / ( 1.0 - Ems * Favg ); - // singleScatter += FssEss; - // multiScatter += Fms * Ems; - multiAndSingleScatter.multiScatter=Fms * Ems; - multiAndSingleScatter.singleScatter=FssEss; - return multiAndSingleScatter; - } - //直接光照 - fn RE_Direct_Physical( directLight:IncidentLight, geometry:GeometricContext, material:PhysicalMaterial)->ReflectedLight { - var reflectedLight:ReflectedLight; - let dotNL:f32 = saturate(dot( geometry.normal, directLight.direction)); - let irradiance:vec3 = dotNL * directLight.color; - #if ${defines.USE_CLEARCOAT} - let dotNLcc:f32 = saturate( dot( geometry.clearcoatNormal, directLight.direction ) ); - let ccIrradiance:vec3 = dotNLcc * directLight.color; - clearcoatSpecular += ccIrradiance * BRDF_GGX( directLight.direction, geometry.viewDir, geometry.clearcoatNormal, material.clearcoatF0, material.clearcoatF90, material.clearcoatRoughness ); - #endif + @location(1) normal: vec3, - #if ${defines.USE_SHEEN} - sheenSpecular += irradiance * BRDF_Sheen( directLight.direction, geometry.viewDir, geometry.normal, material.sheenColor, material.sheenRoughness ); - #endif + @location(2) uv: vec2, + #if ${defines.USE_LIGHTTEXTURE || defines.USE_AOTEXTURE} + @location(${defines.uv2Location}) uv2:vec2, + #endif + #if ${defines.USE_INSTANCING} + @location(${defines.instanceMatrixLocation}) instanceMatrix:mat4x4, + #endif + #if ${defines.USE_INSTANCING_COLOR} + @location(${defines.instanceColorLocation}) instanceColor:vec3, + #endif + + #if ${defines.USE_TANGENT} + @location(${defines.tangentLocation}) tangent:vec4, + #endif + #if ${defines.USE_COLOR_ALPHA} + @location(${defines.colorLocation}) color:vec4, + #elif ${defines.USE_COLOR} + @location(${defines.colorLocation}) color:vec3, + #endif - #if ${defines.USE_IRIDESCENCE} - reflectedLight.directSpecular = irradiance * BRDF_GGX_Iridescence( directLight.direction, geometry.viewDir, geometry.normal, material.specularColor, material.specularF90, material.iridescence, material.iridescenceFresnel, material.roughness ); - #else - reflectedLight.directSpecular = irradiance * BRDF_GGX( directLight.direction, geometry.viewDir, geometry.normal, material.specularColor, material.specularF90, material.roughness ); - #endif - reflectedLight.directDiffuse = irradiance * BRDF_Lambert( material.diffuseColor ); - return reflectedLight; - } - //间接光照 - fn RE_IndirectDiffuse_Physical( irradiance:vec3, geometry:GeometricContext, material:PhysicalMaterial )->ReflectedLight { - var reflectedLight:ReflectedLight; - reflectedLight.indirectDiffuse = irradiance * BRDF_Lambert( material.diffuseColor ); - return reflectedLight; - } - //间接高光 - fn RE_IndirectSpecular_Physical( radiance:vec3, irradiance:vec3, clearcoatRadiance:vec3, geometry:GeometricContext, material:PhysicalMaterial)->ReflectedLight { - var reflectedLight:ReflectedLight; - #if ${defines.USE_CLEARCOAT} - clearcoatSpecular += clearcoatRadiance * EnvironmentBRDF( geometry.clearcoatNormal, geometry.viewDir, material.clearcoatF0, material.clearcoatF90, material.clearcoatRoughness ); - #endif - #if ${defines.USE_SHEEN} - sheenSpecular += irradiance * material.sheenColor * IBLSheenBRDF( geometry.normal, geometry.viewDir, material.sheenRoughness ); - #endif - var singleScattering:vec3; - var multiScattering:vec3; - let cosineWeightedIrradiance:vec3 = irradiance * RECIPROCAL_PI; - var tempMultiAndSingleScatter:MultiAndSingleScatter; - #if ${defines.USE_IRIDESCENCE} - tempMultiAndSingleScatter=computeMultiscatteringIridescence( geometry.normal, geometry.viewDir, material.specularColor, material.specularF90, material.iridescence, material.iridescenceFresnel, material.roughness ); - #else - tempMultiAndSingleScatter= computeMultiscattering( geometry.normal, geometry.viewDir, material.specularColor, material.specularF90, material.roughness ); - #endif - singleScattering=tempMultiAndSingleScatter.singleScatter; - multiScattering=tempMultiAndSingleScatter.multiScatter; - let totalScattering:vec3 = singleScattering + multiScattering; - let diffuse:vec3 = material.diffuseColor * ( 1.0 - max( max( totalScattering.r, totalScattering.g ), totalScattering.b ) ); - reflectedLight.indirectSpecular = radiance * singleScattering; - reflectedLight.indirectSpecular = multiScattering * cosineWeightedIrradiance; - reflectedLight.indirectDiffuse = diffuse * cosineWeightedIrradiance; - return reflectedLight; - } - `; -} + #if ${defines.USE_MORPHTARGETS && !defines.MORPHTARGETS_TEXTURE} + @location(${defines.morphTarget0Location}) morphTarget0:vec3, -function pbrStruct(defines) { - return wgslParseDefines` - struct MaterialUniform{ + @location(${defines.morphTarget1Location}) morphTarget1:vec3, - modelMatrix: mat4x4, - - diffuse:vec3, - - opacity:f32, - - normalMatrix: mat3x3, - - emissive:vec3, - - roughness:f32, - - metalness:f32, - - #if ${defines.TONE_MAPPING} - toneMappingExposure:f32, - #endif - - #if ${defines.SPECULAR} - - specularColor:vec3, - - specularIntensity:f32, - #endif - - #if ${defines.USE_SHEEN} - - sheenColor:vec3, - - sheenRoughness:f32, - #endif + @location(${defines.morphTarget2Location}) morphTarget2:vec3, - #if ${defines.USE_TRANSMISSION} - - attenuationColor:vec3, - - transmission:f32, - - transmissionSamplerSize:vec2, - - thickness:f32, - - attenuationDistance:f32, - - #endif + @location(${defines.morphTarget3Location}) morphTarget3:vec3, + #if ${defines.USE_MORPHNORMALS} + @location(${defines.morphNormal0Location}) morphNormal0:vec3, - #if ${defines.USE_SKINNING} - - bindMatrix:mat4x4, - - bindMatrixInverse:mat4x4, - - boneTextureSize:u32, - #endif + @location(${defines.morphNormal1Location}) morphNormal1:vec3, - #if ${defines.USE_NORMALTEXTURE} - normalScale:vec2, - #endif - - #if ${defines.IOR} - ior:f32, - #endif - - #if ${defines.USE_CLEARCOAT} - - #if ${defines.USE_CLEARCOAT_NORMALTEXTURE} - clearcoatNormalScale:vec2, - #endif - - clearcoat:f32, - - clearcoatRoughness:f32, - #endif - - #if ${defines.USE_IRIDESCENCE} - iridescence:f32, - - iridescenceIOR:f32, - - iridescenceThicknessMinimum:f32, - - iridescenceThicknessMaximum:f32, - - #endif + @location(${defines.morphNormal2Location}) morphNormal2:vec3, - #if ${defines.USE_AOTEXTURE} - aoTextureIntensity:f32, - #endif + @location(${defines.morphNormal3Location}) morphNormal3:vec3, + #else + @location(${defines.morphTarget4Location}) morphTarget4:vec3, + + @location(${defines.morphTarget5Location}) morphTarget5:vec3, - #if ${defines.USE_LIGHTTEXTURE} - lightTextureIntensity:f32, - #endif - - #if ${defines.USE_ENVTEXTURE} - envTextureIntensity:f32, - - flipEnvTexture:f32, - #endif + @location(${defines.morphTarget6Location}) morphTarget6:vec3, - #if ${defines.USE_BUMPTEXTURE} - bumpScale:f32; + @location(${defines.morphTarget7Location}) morphTarget7:vec3, #endif + #endif + #if ${defines.USE_SKINNING} + @location(${defines.skinIndexLocation}) skinIndex:vec4, + @location(${defines.skinWeightLocation}) skinWeight:vec4, + #endif + } - #if ${defines.USE_DISPLACEMENTTEXTURE} - - displacementScale:f32, - - displacementBias:f32, - #endif + #if ${defines.MORPHTARGETS_TEXTURE} + fn getMorph( vertexIndex:u32, morphTargetIndex:u32,offset:u32 )->vec4 { + let texelIndex:u32 = vertexIndex * MORPHTARGETS_TEXTURE_STRIDE + offset; + let y:u32 = texelIndex / materialUniform.morphTargetsTextureSize.x; + let x:u32 = texelIndex - y * materialUniform.morphTargetsTextureSize.x; + let morphUV:vec3 = vec3( x, y, morphTargetIndex ); + //textureLoad + //return texelFetch( morphTargetsTexture, morphUV, 0 ); + return textureLoad( morphTargetsTexture, morphUV, 0 ); + } + #endif + #if ${defines.USE_SKINNING} + fn getBoneMatrix( i:f32 )->mat4x4 { + let j:f32 = i * 4.0; + let x:f32 = j%f32( materialUniform.boneTextureSize ); + let y:f32 = floor( j / f32( materialUniform.boneTextureSize ) ); + let dx:f32 = 1.0 / f32( materialUniform.boneTextureSize ); + let dy:f32 = 1.0 / f32( materialUniform.boneTextureSize ); + y = dy * ( y + 0.5 ); - #if ${defines.USE_MORPHTARGETS} - - morphTargetBaseInfluence:f32, - - #if ${defines.MORPHTARGETS_TEXTURE} - - morphTargetsTextureSize:vec2, - - MORPHTARGETS_COUNT:u32, - - #endif - - morphTargetInfluences:array, - - #endif + let v1:vec4 = textureSample(boneTexture, baseSampler, vec2( dx * ( x + 0.5 ), y ) ); + let v2:vec4 = textureSample(boneTexture, baseSampler, vec2( dx * ( x + 1.5 ), y ) ); + let v3:vec4 = textureSample(boneTexture, baseSampler, vec2( dx * ( x + 2.5 ), y ) ); + let v4:vec4 = textureSample(boneTexture, baseSampler, vec2( dx * ( x + 3.5 ), y ) ); + let bone:mat4x4 = mat4x4( v1, v2, v3, v4 ); + return bone; } + #endif - `; -} - -function pbrTexture(defines) { - return wgslParseDefines` - #if ${defines.USE_BUMPTEXTURE} - @group(0) @binding(${defines.bumpTextureBinding}) var bumpTexture: texture_2d; - #endif - #if ${defines.USE_TRANSMISSION} - #if ${defines.USE_TRANSMISSIONTEXTURE} - @group(0) @binding(${defines.transmissionTextureBinding}) var transmissionTexture: texture_2d; - #endif - #if ${defines.USE_THICKNESSTEXTURE} - @group(0) @binding(${defines.thicknessTextureBinding}) var thicknessTexture: texture_2d; + @binding(0) @group(0) var materialUniform : MaterialUniform; + @binding(0) @group(1) var globalUniform : GlobalUniform; + @vertex + fn main(input:VertexInput)->VertexOutput { + var vertexOutput:VertexOutput; + #if ${defines.USE_TEXTURE} + vertexOutput.vUv = input.uv; + #endif + #if ${defines.USE_LIGHTTEXTURE || defines.USE_AOTEXTURE} + vertexOutput.vUv2 input.uv2; + #endif + #if ${defines.USE_COLOR_ALPHA} + vertexOutput.vColor = vec4( 1.0 ); + #elif ${defines.USE_COLOR || defines.USE_INSTANCING_COLOR} + vertexOutput.vColor = vec3( 1.0 ); + #endif + #if ${defines.USE_COLOR} + vertexOutput.vColor *= input.color; + #endif + #if ${defines.USE_INSTANCING_COLOR} + vertexOutput.vColor.xyz *= input.instanceColor.xyz; + #endif + #if ${defines.USE_MORPHCOLORS && defines.MORPHTARGETS_TEXTURE} + vertexOutput.vColor *= materialUniform.morphTargetBaseInfluence; + for (let i : u32 = 0u; i < materialUniform.MORPHTARGETS_COUNT; i = i + 1u ) { + #if ${defines.USE_COLOR_ALPHA} + if ( materialUniform.morphTargetInfluences[ i ] ! = 0.0 ) vertexOutput.vColor += getMorph( gl_VertexID, i, 2 ) * materialUniform.morphTargetInfluences[ i ]; + #elif ${defines.USE_COLOR} + if ( materialUniform.morphTargetInfluences[ i ] ! = 0.0 ) vertexOutput.vColor += getMorph( gl_VertexID, i, 2 ).rgb * materialUniform.morphTargetInfluences[ i ]; #endif - @group(0) @binding(${defines.transmissionSamplerTextureBinding}) var transmissionSamplerTexture: texture_2d; - #endif - #if ${defines.USE_ENVTEXTURE} - @group(0) @binding(${defines.envTextureBinding}) var envTexture: texture_cube; - #endif - #if ${defines.USE_NORMALTEXTURE} - @group(0) @binding(${defines.normalTextureBinding}) var normalTexture: texture_2d; - #endif - - #if ${defines.USE_CLEARCOATTEXTURE} - @group(0) @binding(${defines.clearcoatTextureBinding}) var clearcoatTexture: texture_2d; - #endif - - #if ${defines.USE_CLEARCOAT_ROUGHNESSTEXTURE} - @group(0) @binding(${defines.clearcoatRclearcoatRoughnessTextureBinding}) var clearcoatRoughnessTexture: texture_2d; - #endif - - #if ${defines.USE_CLEARCOAT_NORMALTEXTURE} - @group(0) @binding(${defines.clearcoatNormalTextureBinding}) var clearcoatNormalTexture: texture_2d; - #endif - - #if ${defines.USE_IRIDESCENCETEXTURE} - @group(0) @binding(${defines.iridescenceTextureBinding}) var iridescenceTexture: texture_2d; - #endif - - #if ${defines.USE_IRIDESCENCE_THICKNESSTEXTURE} - @group(0) @binding(${defines.iridescenceThicknessTextureBinding}) var iridescenceThicknessTexture: texture_2d; + } + #endif + var objectNormal:vec3 = vec3(input.normal); + #if ${defines.USE_TANGENT} + let objectTangent:vec3 = vec3( input.tangent.xyz ); + #endif + #if ${defines.USE_MORPHNORMALS} + objectNormal *= materialUniform.morphTargetBaseInfluence; + #if ${defines.MORPHTARGETS_TEXTURE} + for ( let i : u32 = 0u; i < materialUniform.MORPHTARGETS_COUNT; i = i + 1u) { + if ( materialUniform.morphTargetInfluences[ i ] ! = 0.0 ) objectNormal += getMorph( gl_VertexID, i, 1 ).xyz * materialUniform.morphTargetInfluences[ i ]; + } + #else + objectNormal += morphNormal0 * materialUniform.morphTargetInfluences[ 0 ]; + objectNormal += morphNormal1 * materialUniform.morphTargetInfluences[ 1 ]; + objectNormal += morphNormal2 * materialUniform.morphTargetInfluences[ 2 ]; + objectNormal += morphNormal3 * materialUniform.morphTargetInfluences[ 3 ]; #endif - - #if ${defines.USE_ROUGHNESSTEXTURE} - @group(0) @binding(${defines.roughnessTextureBinding}) var roughnessTexture: texture_2d; + #endif + #if ${defines.USE_SKINNING} + let boneMatX:mat4x4 = getBoneMatrix( input.skinIndex.x ); + let boneMatY:mat4x4 = getBoneMatrix( input.skinIndex.y ); + let boneMatZ:mat4x4 = getBoneMatrix( input.skinIndex.z ); + let boneMatW:mat4x4 = getBoneMatrix( input.skinIndex.w ); + #endif + #if ${defines.USE_SKINNING} + let skinMatrix:mat4x4 = mat4x4( 0.0 ); + skinMatrix += input.skinWeight.x * boneMatX; + skinMatrix += input.skinWeight.y * boneMatY; + skinMatrix += input.skinWeight.z * boneMatZ; + skinMatrix += input.skinWeight.w * boneMatW; + skinMatrix = materialUniform.bindMatrixInverse * skinMatrix * materialUniform.bindMatrix; + objectNormal = vec4( skinMatrix * vec4( objectNormal, 0.0 ) ).xyz; + #if ${defines.USE_TANGENT} + objectTangent = vec4( skinMatrix * vec4( objectTangent, 0.0 ) ).xyz; #endif - - #if ${defines.USE_METALNESSTEXTURE} - @group(0) @binding(${defines.metalnessTextureBinding}) var metalnessTexture: texture_2d; + #endif + var transformedNormal:vec3 = objectNormal; + // transformedNormal+=vec3(0.0); + #if ${defines.USE_INSTANCING} + let m:mat3x3 = mat3x3( input.instanceMatrix ); + transformedNormal /= vec3( dot( m[ 0 ], m[ 0 ] ), dot( m[ 1 ], m[ 1 ] ), dot( m[ 2 ], m[ 2 ] ) ); + transformedNormal = m * transformedNormal; + #endif + transformedNormal = materialUniform.normalMatrix * transformedNormal; + #if ${defines.FLIP_SIDED} + transformedNormal = - transformedNormal; + #endif + #if ${defines.USE_TANGENT} + let transformedTangent:vec3 = (globalUniform.viewMatrix*materialUniform.modelMatrix * vec4( objectTangent, 0.0 ) ).xyz; + #if ${defines.FLIP_SIDED} + transformedTangent = - transformedTangent; #endif - - #if ${defines.SPECULAR} - #if ${defines.USE_SPECULARINTENSITYTEXTURE} - @group(0) @binding(${defines.specularIntensityTextureBinding}) var specularIntensityTexture: texture_2d; - #endif - - #if ${defines.USE_SPECULARCOLORTEXTURE} - @group(0) @binding(${defines.specularColorTextureBinding}) var specularColorTexture: texture_2d; - #endif + #endif + vertexOutput.vNormal = normalize( transformedNormal ); + #if ${defines.FLAT_SHADED} + #if ${defines.USE_TANGENT} + vTangent = normalize( transformedTangent ); + vBitangent = normalize( cross( vNormal, vTangent ) * input.tangent.w ); #endif - - #if ${defines.USE_SHEEN} - #if ${defines.USE_SHEENCOLORTEXTURE} - @group(0) @binding(${defines.sheenColorTextureBinding}) var sheenColorTexture: texture_2d; - #endif - #if ${defines.USE_SHEENROUGHNESSTEXTURE} - @group(0) @binding(${defines.sheenRoughnessTextureBinding}) var sheenRoughnessTexture: texture_2d; + #endif + let transformed:vec3 = vec3( input.position ); + #if ${defines.USE_MORPHTARGETS} + transformed *= materialUniform.morphTargetBaseInfluence; + #if ${defines.MORPHTARGETS_TEXTURE} + for ( let i : u32 = 0u; i < materialUniform.MORPHTARGETS_COUNT; i = i + 1u ) { + if ( materialUniform.morphTargetInfluences[ i ] ! = 0.0 ) transformed += getMorph( gl_VertexID, i, 0 ).xyz * morphTargetInfluences[ i ]; + } + #else + transformed += input.morphTarget0 * materialUniform.morphTargetInfluences[ 0 ]; + transformed += input.morphTarget1 * materialUniform.morphTargetInfluences[ 1 ]; + transformed += input.morphTarget2 * materialUniform.morphTargetInfluences[ 2 ]; + transformed += input.morphTarget3 * materialUniform.morphTargetInfluences[ 3 ]; + #if ${defines.USE_MORPHNORMALS} + transformed += input.morphTarget4 * materialUniform.morphTargetInfluences[ 4 ]; + transformed += input.morphTarget5 * materialUniform.morphTargetInfluences[ 5 ]; + transformed += input.morphTarget6 * materialUniform.morphTargetInfluences[ 6 ]; + transformed += input.morphTarget7 * materialUniform.morphTargetInfluences[ 7 ]; #endif #endif - - #if ${defines.USE_TEXTURE} - @group(0) @binding(${defines.baseSamplerBinding}) var baseSampler: sampler; - @group(0) @binding(${defines.baseTextureBinding}) var baseTexture: texture_2d; + #endif + #if ${defines.USE_SKINNING} + let skinVertex:vec4 = materialUniform.bindMatrix * vec4( transformed, 1.0 ); + let skinned:vec4 = vec4( 0.0 ); + skinned += boneMatX * skinVertex * input.skinWeight.x; + skinned += boneMatY * skinVertex * input.skinWeight.y; + skinned += boneMatZ * skinVertex * input.skinWeight.z; + skinned += boneMatW * skinVertex * input.skinWeight.w; + transformed = ( materialUniform.bindMatrixInverse * skinned ).xyz; + #endif + #if ${defines.USE_DISPLACEMENTTEXTURE} + transformed += normalize( objectNormal ) * (textureSample(displacementMap, baseSampler, vUv).x * materialUniform.displacementScale + materialUniform.displacementBias ); + #endif + var mvPosition:vec4 = vec4( transformed, 1.0 ); + #if ${defines.USE_INSTANCING} + mvPosition = input.instanceMatrix * mvPosition; + #endif + mvPosition = globalUniform.viewMatrix*materialUniform.modelMatrix * mvPosition; + vertexOutput.position = globalUniform.projectionMatrix * mvPosition; + vertexOutput.vViewPosition = - mvPosition.xyz/mvPosition.w; + #if ${defines.USE_ENVTEXTURE || defines.DISTANCE || defines.USE_TRANSMISSION} + var worldPosition:vec4 = vec4( transformed, 1.0 ); + #if ${defines.USE_INSTANCING} + worldPosition = input.instanceMatrix * worldPosition; #endif + worldPosition = materialUniform.modelMatrix * worldPosition; + #endif + #if ${defines.USE_TRANSMISSION} + vertexOutput.vWorldPosition = worldPosition.xyz; + #endif + return vertexOutput; + } + `; +} - #if ${defines.USE_ALPHATEXTURE} - @group(0) @binding(${defines.alphaTextureBinding}) var alphaTexture: texture_2d; - #endif +function phongFrag(defines) { + return wgslParseDefines` + struct MaterialUniform { + modelMatrix: mat4x4, + color: vec3, + opacity:f32, + normalMatrix: mat4x4, + emissive:vec3, + shininess:f32, + specular:vec3, + } + #include + #include + #include + #include + @binding(${defines.phongBinding}) @group(0) var materialUniform : MaterialUniform; + @binding(${defines.cameraBinding}) @group(1) var systemUniform : SystemUniform; + @fragment + fn main(input:FragInput) -> @location(0) vec4 { + var totalEmissiveRadiance:vec3 = materialUniform.emissive; + var color:vec4; + #if${defines.USE_COLORTEXTURE} + color= vec4(textureSample(baseColorTexture, baseColorSampler, input.uv).rgb+materialUniform.color,materialUniform.opacity); + #else + color=vec4(materialUniform.color,materialUniform.opacity); + #endif + let V:vec3 = normalize( systemUniform.cameraPosition - input.worldPos); + #if ${defines.USE_NORMALTEXTURE} + let N:vec3 = getNormalByNormalTexture(input); + #else + let N:vec3 = getNormal(input); + #endif + var geometry:Geometry; + geometry.normal=N; + geometry.viewDir=V; + geometry.position=input.worldPos; + let lightColor:ReflectedLight=parseLights(geometry,materialUniform.shininess); + // var finnalColor:vec3=color.xyz + (lightColor.directDiffuse + lightColor.directSpecular + lightColor.ambient); + var finnalColor:vec3=color.xyz * (lightColor.directDiffuse + lightColor.directSpecular + lightColor.ambient); - #if ${defines.USE_AOTEXTURE} - @group(0) @binding(${defines.aoTextureBinding}) var aoTexture: texture_2d; - - #endif - #if ${defines.USE_LIGHTTEXTURE} - @group(0) @binding(${defines.lightTextureBinding}) var lightTexture: texture_2d; - #endif + // finnalColor = lightColor.testColor.xyz; - #if ${defines.USE_EMISSIVETEXTURE} - @group(0) @binding(${defines.emissiveTextureBinding}) var emissiveTexture: texture_2d; - #endif - `; + return vec4(finnalColor,color.a); + }`; } -function pbrUtils(defines) { +function phongVert(defines) { return wgslParseDefines` - const PI:f32= 3.141592653589793; - const PI2:f32= 6.283185307179586; - const PI_HALF:f32= 1.5707963267948966; - const RECIPROCAL_PI:f32= 0.3183098861837907; - const RECIPROCAL_PI2:f32= 0.15915494309189535; - const EPSILON:f32= 1e-6; - - fn pow2(x:f32 )->f32 { - return x*x; - } - fn pow2Vector(x:vec3 )->vec3 { - return x*x; - } - fn pow3( x:f32 )->f32 { - return x*x*x; - } - fn pow4( x:f32 )->f32 { - let x2:f32 = x*x; - return x2*x2; - } - fn max3( v:vec3 )->f32 { - return max( max( v.x, v.y ), v.z ); - } - fn average(v:vec3 )->f32 { - return dot( v, vec3( 0.3333333 ) ); - } - fn rand( uv:vec2 )->f32 { - let a:f32 = 12.9898; - let b:f32 = 78.233; - let c:f32 = 43758.5453; - let dt:f32 = dot( uv.xy, vec2( a, b ) ); - let sn:f32 = dt % PI; - return fract( sin( sn ) * c ); - } - fn transformDirection( dir:vec3, matrix:mat4x4 )->vec3 { - return normalize( ( matrix * vec4( dir, 0.0 ) ).xyz ); - } + struct MaterialUniform { + modelMatrix: mat4x4, + color: vec3, + opacity:f32, + normalMatrix: mat4x4, + emissive:vec3, + specular:vec3, + shininess:f32, + } + #include + #include + #include + @binding(${defines.phongBinding}) @group(0) var selfUniform : MaterialUniform; + @binding(${defines.cameraBinding}) @group(1) var systemUniform : SystemUniform; + @vertex + fn main(input: VertexInput) -> VertexOutput { + var output: VertexOutput; + #if ${defines.HAS_UV} + output.uv = input.uv; + #endif + let modelPos=selfUniform.modelMatrix *vec4(input.position,1.0); + output.worldPos = modelPos.xyz/modelPos.w; + let vNormalView = selfUniform.normalMatrix * vec4(input.normal,0.0); + output.normal = vNormalView.xyz; + output.view = systemUniform.cameraPosition.xyz - modelPos.xyz; + let viewPosition=systemUniform.viewMatrix * modelPos; + output.viewPosition = -viewPosition.xyz; + output.position = systemUniform.projectionMatrix * systemUniform.viewMatrix * modelPos; + return output; + }`; +} - fn transposeMat3( m:mat3x3 )->mat3x3 { - var tmp:mat3x3; - tmp[ 0 ] = vec3( m[ 0 ].x, m[ 1 ].x, m[ 2 ].x ); - tmp[ 1 ] = vec3( m[ 0 ].y, m[ 1 ].y, m[ 2 ].y ); - tmp[ 2 ] = vec3( m[ 0 ].z, m[ 1 ].z, m[ 2 ].z ); - return tmp; - } - fn luminance( rgb:vec3 )->f32 { - let weights:vec3 = vec3(0.2126729, 0.7151522, 0.0721750 ); - return dot( weights, rgb ); - } - fn LinearToneMapping( color:vec3,toneMappingExposure:f32 )->vec3 { - return toneMappingExposure * color; +function quadFrag(defines) { + return ` + @group(0) @binding(1) var baseSampler: sampler; + @group(0) @binding(0) var colorTexture: texture_2d; + struct VertexOutput { + @builtin(position) position: vec4, + @location(0) uv: vec2, + }; + @fragment + fn main(input:VertexOutput) -> @location(0) vec4 { + return textureSample(colorTexture, baseSampler, vec2(input.uv.x,1.0-input.uv.y)); } + `; +} - fn ReinhardToneMapping( color:vec3,toneMappingExposure:f32 )->vec3 { - var tempColor:vec3; - tempColor=color; - tempColor *= toneMappingExposure; - return saturate( tempColor / ( vec3( 1.0 ) + tempColor ) ); - } - fn CustomToneMapping( color:vec3 )->vec3 { - return color; +function quadVert(defines) { + return ` + struct VertexInput { + @location(${defines.positionLocation}) position: vec2, } - fn toneMapping( color:vec3,toneMappingExposure:f32 )->vec3 { - return ReinhardToneMapping( color,toneMappingExposure ); + struct VertexOutput { + @builtin(position) position: vec4, + @location(0) uv: vec2, + }; + @vertex + fn main(input: VertexInput) -> VertexOutput { + var output:VertexOutput; + output.uv = input.position * 0.5 + 0.5; + output.position = vec4(input.position, 0.0, 1.0);; + return output; } + `; +} - fn LinearToLinear( value:vec4 )->vec4 { - return value; - } +function skyBoxFrag(defines) { + return ` fn lessThanEqual(a:vec3,b:vec3)->vec3{ - let xValue:f32=select(b.x,a.x,a.x<=b.x); - let yValue:f32=select(b.y,a.y,a.y<=b.y); - let zValue:f32=select(b.z,a.z,a.z<=b.z); - return vec3(xValue,yValue,zValue); - } + let xValue:f32=select(b.x,a.x,a.x<=b.x); + let yValue:f32=select(b.y,a.y,a.y<=b.y); + let zValue:f32=select(b.z,a.z,a.z<=b.z); + return vec3(xValue,yValue,zValue); + } fn LinearTosRGB( value:vec4 )->vec4 { return vec4( mix( pow( value.rgb, vec3( 0.41666 ) ) * 1.055 - vec3( 0.055 ), value.rgb * 12.92, vec3( lessThanEqual( value.rgb, vec3( 0.0031308 ) ) ) ), value.a ); } - fn linearToOutputTexel(value:vec4 )->vec4 { - return LinearTosRGB( value ); - } - `; + struct FragmentInput { + @location(0) texCoord : vec3 + }; + @group(0) @binding(2) var defaultSampler: sampler; + @group(0) @binding(1) var skyboxTexture: texture_cube; + @fragment + fn main(input : FragmentInput) -> @location(0) vec4 { + let color = textureSample(skyboxTexture, defaultSampler, input.texCoord); + return LinearTosRGB(color); + } +`; } -function blinn_phong(defines) { +function skyBoxVert(defines) { return ` - fn getPointLightInfo(pointLight:PointLight,worldPos:vec3,shininess:f32,N:vec3,V:vec3)->vec3{ - var color=vec3(0.0,0.0,0.0); - var direction:vec3 = worldPos - pointLight.position; - let dist:f32 = length( direction ); - direction = normalize(direction); - let decay = clamp(1.0 - pow(dist / pointLight.distance, 4.0), 0.0, 1.0); - - let d = max( dot( N, -direction ), 0.0 ) * decay; - color += pointLight.color * d; + struct SystemUniform { + projectionMatrix: mat4x4, + viewMatrix: mat4x4, + inverseViewMatrix: mat4x4, + cameraPosition: vec3, + }; + struct MaterialUniform { + modelMatrix: mat4x4, + } + @binding(${defines.skyboxBinding}) @group(0) var selfUniform : MaterialUniform; + @binding(${defines.cameraBinding}) @group(1) var systemUniform : SystemUniform; + struct VertexInput { + @location(${defines.positionLocation}) position : vec3, + }; + struct VertexOutput { + @builtin(position) position : vec4, + @location(0) texCoord : vec3, + }; + @vertex + fn main(input : VertexInput) -> VertexOutput { + var output : VertexOutput; + output.texCoord = input.position.xyz; + var modelView = systemUniform.viewMatrix; + // Drop the translation portion of the modelView matrix + modelView[3] = vec4(0.0, 0.0, 0.0, modelView[3].w); + output.position = systemUniform.projectionMatrix * modelView * vec4(input.position,1.0); + output.position = output.position.xyww; + return output; + } + `; +} - let halfDir:vec3 = normalize( V - direction ); - let s:f32 = pow( clamp( dot( N, halfDir ), 0.0, 1.0 ), shininess ) * decay; - color += pointLight.color * s; - return color; - } - fn getSpotLightInfo(spotLight:SpotLight,worldPos:vec3,shininess:f32,N:vec3,V:vec3)->vec3{ - var color=vec3(0.0,0.0,0.0); - var direction:vec3 = spotLight.position - worldPos; - let lightDistance:f32 = length(direction); - direction = normalize(direction); - let angleCos:f32 = dot( direction, -spotLight.direction ); - let decay:f32 = clamp(1.0 - pow(lightDistance/spotLight.distance, 4.0), 0.0, 1.0); - let spotEffect:f32 = smoothstep( spotLight.penumbraCos, spotLight.coneCos, angleCos ); - let decayTotal:f32 = decay * spotEffect; - let d:f32 = max( dot( N, direction ), 0.0 ) * decayTotal; - color += spotLight.color * d; - let halfDir:vec3 = normalize( V + direction ); - let s:f32 = pow( clamp( dot( N, halfDir ), 0.0, 1.0 ), shininess ) * decayTotal; - color += spotLight.color * s; - return color; - } - struct DirectionalLight { - direction: vec3, - color: vec3, +function blendFrag(defines) { + return ` + struct FragInput { + @location(0) uv: vec2, }; - fn getDirectLightInfo(directionalLight:DirectionalLight,shininess:f32,N:vec3,V:vec3)->vec3{ - var color=vec3(0.0,0.0,0.0); - let d:f32 = max(dot(N, -directionalLight.direction), 0.0); - color += directionalLight.color * d; - - let halfDir:vec3 = normalize( V - directionalLight.direction ); - let s:f32 = pow( clamp( dot( N, halfDir ), 0.0, 1.0 ), shininess ); - color += directionalLight.color * s; - return color; - } + @group(0) @binding({{tDiffuseBinding}}) var tDiffuse: texture_2d; + @group(0) @binding({{baseColorTextureBinding}}) var baseColorTexture: texture_2d; + @group(0) @binding({{tSamplerBinding}}) var tSampler: sampler; + @fragment + fn main(input:FragInput) -> @location(0) vec4 { + let postColor:vec4 = textureSample(tDiffuse, tSampler, input.uv); + let baseColor:vec4 = textureSample(baseColorTexture, tSampler, input.uv); + return baseColor+postColor; + } `; } -function phongFunction(defines) { +function Blur(defines) { return ` - fn G_BlinnPhong_Implicit( )->f32 { - - // geometry term is (n dot l)(n dot v) / 4(n dot l)(n dot v) - return 0.25; - + struct FragInput { + @location(0) uv: vec2, } - fn D_BlinnPhong( shininess:f32, dotNH:f32 )->f32 { - - return RECIPROCAL_PI * ( shininess * 0.5 + 1.0 ) * pow(dotNH, shininess); - + struct BlurUniforms { + direction:vec2, } - fn BRDF_BlinnPhong( lightDir:vec3, viewDir:vec3, normal:vec3, specularColor:vec3, shininess:f32 )->vec3 { - - let halfDir = normalize( lightDir + viewDir ); - - let dotNH:f32 = saturate( dot( normal, halfDir ) ); - let dotVH:f32 = saturate( dot( viewDir, halfDir ) ); + fn gaussianPdf(x:f32, sigma:f32)->f32 { + return 0.39894 * exp( -0.5 * x * x/( sigma * sigma))/sigma; + } + @group(0) @binding(0) var blurUniforms : BlurUniforms; + @group(0) @binding({{tDiffuseBinding}}) var tDiffuse: texture_2d; + @group(0) @binding({{tSamplerBinding}}) var tSampler: sampler; + @fragment + fn main(input:FragInput) -> @location(0) vec4 { + let invSize:vec2 = vec2(1.0,1.0) / vec2(textureDimensions(tDiffuse)); + let fSigma:f32 =f32(${defines.SIGMA}); + var weightSum:f32 = gaussianPdf(0.0, fSigma); + let baseColor=textureSample(tDiffuse, tSampler, input.uv); + var diffuseSum:vec3 = baseColor.rgb * weightSum; + let uvOffset:vec2 = blurUniforms.direction * invSize; + for( var i : u32 = 1; i < ${defines.KERNEL_RADIUS};i = i + 1 ) { + let x:f32 = f32(i); + let w:f32 = gaussianPdf(x, fSigma); + let sample1:vec3=textureSample(tDiffuse, tSampler, input.uv+ uvOffset*x).rgb; + let sample2:vec3=textureSample(tDiffuse, tSampler, input.uv- uvOffset*x).rgb; + diffuseSum =diffuseSum+ (sample2+sample2)* w; + weightSum += 2.0 * w; + } + diffuseSum/=weightSum; + return vec4(diffuseSum,baseColor.a); + } + `; +} - let F = F_Schlick( specularColor, 1.0, dotVH ); +function LuminosityHigh(defines) { + return ` + struct LuminosityUniforms{ + luminosityThreshold:f32, + smoothWidth:f32, + defaultColor:vec3, + defaultOpacity:f32, + } + struct FragInput { + @location(0) uv: vec2, + }; + @group(0) @binding(0) var luminosityUniforms : LuminosityUniforms; + @group(0) @binding({{tDiffuseBinding}}) var tDiffuse: texture_2d; + @group(0) @binding({{tSamplerBinding}}) var tSampler: sampler; + @fragment + fn main(input:FragInput)-> @location(0) vec4 { - let G:f32 = G_BlinnPhong_Implicit( ); + let texel:vec4 = textureSample(tDiffuse, tSampler, input.uv); - let D = D_BlinnPhong( shininess, dotNH ); + let luma:vec3 = vec3( 0.299,0.587,0.114 ); - return F * ( G * D ); + let v:f32 = dot( texel.xyz, luma ); - } - fn RE_Direct_BlinnPhong( directLight:IncidentLight,geometry:GeometricContext, material:BlinnPhongMaterial )->ReflectedLight{ - var reflectedLight:ReflectedLight; - let dotNL:f32 = saturate(dot(geometry.normal, directLight.direction)); - let irradiance:vec3 = dotNL*directLight.color; + let outputColor:vec4 = vec4( luminosityUniforms.defaultColor.rgb, luminosityUniforms.defaultOpacity ); - reflectedLight.directDiffuse= irradiance * BRDF_Lambert( material.diffuseColor ); + let alpha:f32 = smoothstep( luminosityUniforms.luminosityThreshold, luminosityUniforms.luminosityThreshold + luminosityUniforms.smoothWidth, v ); - reflectedLight.directSpecular= irradiance * BRDF_BlinnPhong( directLight.direction, geometry.viewDir, geometry.normal, material.specularColor, material.specularShininess ) * material.specularStrength; - return reflectedLight; - } - fn RE_IndirectDiffuse_BlinnPhong( irradiance:vec3, geometry:GeometricContext, material:BlinnPhongMaterial)->ReflectedLight { - var reflectedLight:ReflectedLight; - reflectedLight.indirectDiffuse += irradiance * BRDF_Lambert( material.diffuseColor ); - return reflectedLight; + return mix( outputColor, texel, alpha ); } `; } -function phongUtils(defines) { - return ` - struct BlinnPhongMaterial { - diffuseColor:vec3, - specularColor:vec3, - specularShininess:f32, - specularStrength:f32, - }; - const RECIPROCAL_PI:f32= 0.3183098861837907; - fn pow2( x:f32 )->f32 { return x*x; } - fn pow3( x:f32 )->f32 { return x*x*x; } - fn pow4(x:f32 )->f32 { let x2 = x*x; return x2*x2; } - fn max3( v:vec3 )->f32 { return max( max( v.x, v.y ), v.z ); } - fn average(v:vec3 )->f32 { - let result=vec3( 0.3333333, 0.3333333, 0.3333333); - return dot( v,result ); - } - `; -} - -function skinVertHeader(defines) { - return wgslParseDefines` - #if ${defines.HAS_SKIN} - struct JointsUniform{ - matrixs:array, - } - struct InverseBindMatricesUniform{ - matrixs:array, - } - @binding(${defines.skinJointsBufferBinding}) @group(0) var jointsUniform : JointsUniform; - @binding(${defines.invsBufferBinding}) @group(0) var inverseBindMatricesUniform : InverseBindMatricesUniform; - fn getSkinMatrix(joints: vec4f, weights: vec4f) -> mat4x4 { - let joint0 = jointsUniform.matrixs[u32(joints.x)] * inverseBindMatricesUniform.matrixs[u32(joints.x)]; - let joint1 = jointsUniform.matrixs[u32(joints.y)] * inverseBindMatricesUniform.matrixs[u32(joints.y)]; - let joint2 = jointsUniform.matrixs[u32(joints.z)] * inverseBindMatricesUniform.matrixs[u32(joints.z)]; - let joint3 = jointsUniform.matrixs[u32(joints.w)] * inverseBindMatricesUniform.matrixs[u32(joints.w)]; - - let skinMatrix = joint0 * weights.x + - joint1 * weights.y + - joint2 * weights.z + - joint3 * weights.w; - return skinMatrix; - } - #endif - `; -} -function skinVertMain(defines) { +function FragInput(defines) { return wgslParseDefines` - #if ${defines.HAS_SKIN} - modelMatrix =getSkinMatrix(input.joint0,input.weight0); - vNormalView = normalize((materialUniform.normalMatrix * modelMatrix * vec4(input.normal, 0.0)).xyz); - #endif + struct FragInput { + @builtin(front_facing) frontFacing: bool, + @location(0) worldPos:vec3, + @location(1) normal:vec3, + @location(2) uv:vec2, + @location(3) view: vec3, // Vector from vertex to camera. + @location(4) color: vec4, + @location(5) viewPosition: vec3, + } `; } -function PbrMaterialStruct(defines) { - return wgslParseDefines` - struct MaterialUniform { - modelMatrix: mat4x4, - color: vec3, - opacity:f32, - normalMatrix: mat4x4, - emissive:vec3, - metallic:f32, - roughness:f32, - #if ${defines.USE_NORMALTEXTURE} - normalTextureScale:vec2, - #endif - #if ${defines.USE_AOTEXTURE} - occlusionStrength:f32, - #endif - } - `; -} - -const ShaderChunk = { - light: light, - brdf: brdf, - phongFunction: phongFunction, - phongUtils: phongUtils, - lightCommon: lightCommon, - pbrStruct: pbrStruct, - pbrFunction: pbrFunction, - pbrTexture: pbrTexture, - pbrUtils: pbrUtils, - environment: environment, - blinn_phong: blinn_phong, - getNormal: getNormal, - getTBN: getTBN, - getNormalByNormalTexture: getNormalByNormalTexture, - ibl: ibl, - skinVertMain, - skinVertHeader, - FragInput, - VertexInput, - VertexOutput, - PbrMaterialStruct, - SystemUniform, - instanceVertMain, - instanceVertHeader -}; - -function phongVert(defines) { - return ` - struct VertexOutput { - @builtin(position) position: vec4, - @location(0) uv: vec2, - @location(1) view: vec3, // Vector from vertex to camera. - @location(2) worldPos: vec3, - @location(3) color: vec4, - @location(4) normal: vec3, - @location(5) viewPosition: vec3, - }; - struct MaterialUniform { - modelMatrix: mat4x4, - color: vec3, - opacity:f32, - normalMatrix: mat4x4, - emissive:vec3, - specular:vec3, - shininess:f32, - } - struct SystemUniform { - projectionMatrix: mat4x4, - viewMatrix: mat4x4, - inverseViewMatrix: mat4x4, - cameraPosition: vec3, - }; - - @binding(${defines.phongBinding}) @group(0) var selfUniform : MaterialUniform; - @binding(${defines.cameraBinding}) @group(1) var systemUniform : SystemUniform; - - struct VertexInput { +function VertexInput(defines) { + return wgslParseDefines` + struct VertexInput { @location(${defines.positionLocation}) position: vec3, @location(${defines.normalLocation}) normal: vec3, - @location(${defines.uvLocation}) uv: vec2, - } - @vertex - fn main(input: VertexInput) -> VertexOutput { - var output: VertexOutput; - output.uv = input.uv; - let modelPos=selfUniform.modelMatrix *vec4(input.position,1.0); - output.worldPos = modelPos.xyz/modelPos.w; - let vNormalView = selfUniform.normalMatrix * vec4(input.normal,0.0); - output.normal = vNormalView.xyz; - output.view = systemUniform.cameraPosition.xyz - modelPos.xyz; - let viewPosition=systemUniform.viewMatrix * modelPos; - output.viewPosition = -viewPosition.xyz; - output.position = systemUniform.projectionMatrix * systemUniform.viewMatrix * modelPos; - return output; - }`; + #if${defines.HAS_COLOR} + @location(${defines.colorLocation}) color: vec3, + #endif + #if ${defines.HAS_UV} + @location(${defines.uvLocation}) uv: vec2, + #endif + #if${defines.HAS_SKIN} + @location(${defines.joint0Location}) joint0:vec4, + @location(${defines.weight0Location}) weight0:vec4, + #endif + #if ${defines.USE_INSTANCE} + @builtin(instance_index) instanceIdx : u32 + #endif + } + `; } -function phongFrag(defines) { - return wgslParseDefines` - struct VertInput { - @builtin(position) position: vec4, - @builtin(front_facing) frontFacing: bool, - @location(0) uv: vec2, - @location(1) view: vec3, // Vector from vertex to camera. - @location(2) worldPos: vec3, - @location(3) color: vec4, - @location(4) normal: vec3, - @location(5) viewPosition: vec3, - }; - - struct MaterialUniform { - modelMatrix: mat4x4, - color: vec3, - opacity:f32, - normalMatrix: mat4x4, - emissive:vec3, - shininess:f32, - specular:vec3, - } - struct SystemUniform { - projectionMatrix: mat4x4, - viewMatrix: mat4x4, - inverseViewMatrix: mat4x4, - cameraPosition: vec3, - }; +function VertexOutput(defines) { + return wgslParseDefines` + struct VertexOutput { + @builtin(position) position:vec4, + @location(0) worldPos:vec3, + @location(1) normal:vec3, + @location(2) uv:vec2, + @location(3) view: vec3, // Vector from vertex to camera. + @location(4) color: vec4, + @location(5) viewPosition: vec3, + } + `; +} - #if${defines.USE_COLORTEXTURE} - @group(0) @binding(${defines.baseColorSamplerBinding}) var baseColorSampler: sampler; +function SystemUniform(defines) { + return wgslParseDefines` + struct SystemUniform { + projectionMatrix: mat4x4, + viewMatrix: mat4x4, + inverseViewMatrix: mat4x4, + cameraPosition: vec3, + }; + `; +} + +function TextureAndSamplerDefine(defines) { + return wgslParseDefines` + #if ${defines.USE_IBL} + @group(0) @binding(${defines.specularEnvTextureBinding}) var specularEnvTexture: texture_cube; + @group(0) @binding(${defines.specularEnvSamplerBinding}) var specularEnvSampler: sampler; + #endif + #if ${defines.USE_TEXTURE} @group(0) @binding(${defines.baseColorTextureBinding}) var baseColorTexture: texture_2d; + @group(0) @binding(${defines.baseColorSamplerBinding}) var baseColorSampler: sampler; #endif + // normal map #if ${defines.USE_NORMALTEXTURE} @group(0) @binding(${defines.normalTextureBinding}) var normalTexture: texture_2d; @group(0) @binding(${defines.normalSamplerBinding}) var normalSampler: sampler; #endif - @binding(${defines.phongBinding}) @group(0) var materialUniform : MaterialUniform; - @binding(${defines.cameraBinding}) @group(1) var systemUniform : SystemUniform; + // emmisve map + #if ${defines.USE_EMISSIVETEXTURE} + @group(0) @binding(${defines.emissiveTextureBinding}) var emissiveTexture: texture_2d; + @group(0) @binding(${defines.emissiveSamplerBinding}) var emissiveSampler: sampler; + #endif + + // metal roughness + #if ${defines.USE_METALNESSTEXTURE} + @group(0) @binding(${defines.metalnessRoughnessTextureBinding}) var metalnessRoughnessTexture: texture_2d; + @group(0) @binding(${defines.metalnessRoughnessSamplerBinding}) var metalnessRoughnessSampler: sampler; + #endif + // occlusion texture + #if ${defines.USE_AOTEXTURE} + @group(0) @binding(${defines.aoTextureBinding}) var aoTexture: texture_2d; + @group(0) @binding(${defines.aoSamplerBinding}) var aoSampler: sampler; + #endif #if ${defines.USE_NORMALTEXTURE} #include #include #else - #include + #include #endif - - #include - - @fragment - fn main(input:VertInput) -> @location(0) vec4 { - var totalEmissiveRadiance:vec3 = materialUniform.emissive; - var color:vec4; - #if${defines.USE_COLORTEXTURE} - color= vec4(textureSample(baseColorTexture, baseColorSampler, input.uv).rgb+materialUniform.color,materialUniform.opacity); - #else - color=vec4(materialUniform.color,materialUniform.opacity); - #endif - let V:vec3 = normalize( systemUniform.cameraPosition - input.worldPos); - #if ${defines.USE_NORMALTEXTURE} - let N:vec3 = getNormalByNormalTexture(input); - #else - let N:vec3 = getNormal(input); - #endif - var geometry:Geometry; - geometry.normal=N; - geometry.viewDir=V; - geometry.position=input.worldPos; - let lightColor:ReflectedLight=parseLights(geometry,materialUniform.shininess); - // var finnalColor:vec3=color.xyz + (lightColor.directDiffuse + lightColor.directSpecular + lightColor.ambient); - var finnalColor:vec3=color.xyz * (lightColor.directDiffuse + lightColor.directSpecular + lightColor.ambient); - - // finnalColor = lightColor.testColor.xyz; - - return vec4(finnalColor,color.a); - }`; -} - -// import Color from "../../math/Color"; -function colorFrag(defines) { - return ` - struct VertexOutput { - @builtin(position) position: vec4, - @location(0) color: vec4, - }; - @fragment - fn main(input:VertexOutput) -> @location(0) vec4 { - return input.color; - } - `; + `; } -function colorVert(defines) { - return ` - struct VertexInput { - @location(${defines.positionLocation}) position: vec3, - @location(${defines.colorLocation}) color: vec4, - } - struct VertexOutput { - @builtin(position) position: vec4, - @location(0) color: vec4, - }; - struct SelfUniform { - modelMatrix: mat4x4, - } - struct SystemUniform { - projectionMatrix: mat4x4, - viewMatrix: mat4x4, - inverseViewMatrix: mat4x4, - cameraPosition: vec3, - }; - @binding(${defines.colorBinding}) @group(0) var selfUniform : SelfUniform; - @binding(${defines.cameraBinding}) @group(1) var systemUniform : SystemUniform; - @vertex - fn main(input: VertexInput) -> VertexOutput { - var output:VertexOutput; - output.color=input.color; - output.position = systemUniform.projectionMatrix * systemUniform.viewMatrix *selfUniform.modelMatrix*vec4(input.position,1.0); - return output; - } +function environment(defines) { + return wgslParseDefines` + #if ${defines.ENVTEXTURE_TYPE_CUBE_UV} + const cubeUV_minMipLevel:f32= 4.0; + const cubeUV_minTileSize:f32= 16.0; + const CUBEUV_MAX_MIP:f32=6.0; + const CUBEUV_TEXEL_WIDTH:f32=1.0/256.0; + const CUBEUV_TEXEL_HEIGHT:f32=1.0/256.0; + fn getFace(direction:vec3 )->f32 { + let absDirection:vec3 = abs( direction ); + var face:f32 = - 1.0; + if ( absDirection.x > absDirection.z ) { + if ( absDirection.x > absDirection.y ){ + face =select(3.0,0.0,direction.x > 0.0); + }else{ + face =select(4.0,1.0,direction.y > 0.0); + } + + } + else { + if ( absDirection.z > absDirection.y ){ + face =select(5.0,2.0,direction.z > 0.0); + }else{ + face =select(4.0,1.0,direction.y > 0.0); + } + } + return face; + } + fn getUV( direction:vec3, face:f32 )->vec2 { + var uv:vec2; + if ( face == 0.0 ) { + uv = vec2( direction.z, direction.y ) / abs( direction.x ); + } + else if ( face == 1.0 ) { + uv = vec2( - direction.x, - direction.z ) / abs( direction.y ); + } + else if ( face == 2.0 ) { + uv = vec2( - direction.x, direction.y ) / abs( direction.z ); + } + else if ( face == 3.0 ) { + uv = vec2( - direction.z, direction.y ) / abs( direction.x ); + } + else if ( face == 4.0 ) { + uv = vec2( - direction.x, direction.z ) / abs( direction.y ); + } + else { + uv = vec2( direction.x, direction.y ) / abs( direction.z ); + } + return 0.5 * ( uv + 1.0 ); + } + fn bilinearCubeUV(envTexture:texture_cube,baseSampler:sampler,direction:vec3, mipInt:f32 )->vec3 { + var face:f32 = getFace( direction ); + let filterInt:f32 = max( cubeUV_minMipLevel - mipInt, 0.0 ); + let tempMipInt = max( mipInt, cubeUV_minMipLevel ); + let faceSize:f32 = exp2( tempMipInt ); + var uv:vec2 = getUV( direction, face ) * ( faceSize - 2.0 ) + 1.0; + if ( face > 2.0 ) { + uv.y += faceSize; + face -= 3.0; + } + uv.x += face * faceSize; + uv.x += filterInt * 3.0 * cubeUV_minTileSize; + uv.y += 4.0 * ( exp2( CUBEUV_MAX_MIP ) - faceSize ); + uv.x *= CUBEUV_TEXEL_WIDTH; + uv.y *= CUBEUV_TEXEL_HEIGHT; + return textureSample(envTexture,baseSampler,direction).rgb; + } + const cubeUV_r0:f32= 1.0; + const cubeUV_v0:f32= 0.339; + const cubeUV_m0:f32= - 2.0; + const cubeUV_r1:f32= 0.8; + const cubeUV_v1:f32= 0.276; + const cubeUV_m1:f32= - 1.0; + const cubeUV_r4:f32= 0.4; + const cubeUV_v4:f32= 0.046; + const cubeUV_m4:f32= 2.0; + const cubeUV_r5:f32= 0.305; + const cubeUV_v5:f32= 0.016; + const cubeUV_m5:f32= 3.0; + const cubeUV_r6:f32= 0.21; + const cubeUV_v6:f32= 0.0038; + const cubeUV_m6:f32= 4.0; + fn roughnessToMip( roughness:f32)->f32 { + var mip:f32 = 0.0; + if ( roughness >= cubeUV_r1 ) { + mip = ( cubeUV_r0 - roughness ) * ( cubeUV_m1 - cubeUV_m0 ) / ( cubeUV_r0 - cubeUV_r1 ) + cubeUV_m0; + } + else if ( roughness >= cubeUV_r4 ) { + mip = ( cubeUV_r1 - roughness ) * ( cubeUV_m4 - cubeUV_m1 ) / ( cubeUV_r1 - cubeUV_r4 ) + cubeUV_m1; + } + else if ( roughness >= cubeUV_r5 ) { + mip = ( cubeUV_r4 - roughness ) * ( cubeUV_m5 - cubeUV_m4 ) / ( cubeUV_r4 - cubeUV_r5 ) + cubeUV_m4; + } + else if ( roughness >= cubeUV_r6 ) { + mip = ( cubeUV_r5 - roughness ) * ( cubeUV_m6 - cubeUV_m5 ) / ( cubeUV_r5 - cubeUV_r6 ) + cubeUV_m5; + } + else { + mip = - 2.0 * log2( 1.16 * roughness ); + } + return mip; + } + fn textureCubeUV(envTexture:texture_cube, baseSampler:sampler,sampleDir:vec3,roughness:f32 )->vec4 { + let mip = clamp( roughnessToMip( roughness ), cubeUV_m0, CUBEUV_MAX_MIP ); + let mipF = fract( mip ); + let mipInt = floor( mip ); + let color0:vec3 = bilinearCubeUV( envTexture,baseSampler,sampleDir, mipInt ); + if ( mipF == 0.0 ) { + return vec4(color0, 1.0 ); + } + else { + let color1:vec3 = bilinearCubeUV( envTexture,baseSampler, sampleDir, mipInt + 1.0 ); + return vec4(mix( color0, color1, mipF ), 1.0 ); + } + + } + #endif + #if ${defines.USE_ENVTEXTURE} + fn getIBLIrradiance( normal:vec3,baseSampler:sampler,viewMatrix:mat4x4)->vec3 { + #if ${defines.ENVTEXTURE_TYPE_CUBE_UV} + let worldNormal:vec3 = inverseTransformDirection( normal, viewMatrix ); + let envTextureColor:vec4 = textureCubeUV( envTexture,baseSampler, worldNormal, 1.0 ); + return PI * envTextureColor.rgb * materialUniform.envTextureIntensity; + #else + return vec3( 0.0 ); + #endif + } + fn getIBLRadiance( viewDir:vec3,baseSampler:sampler,viewMatrix:mat4x4,normal:vec3, roughness:f32 )->vec3 { + #if ${defines.ENVTEXTURE_TYPE_CUBE_UV} + var reflectVec:vec3 = reflect( - viewDir, normal ); + reflectVec = normalize( mix( reflectVec, normal, roughness * roughness) ); + reflectVec = inverseTransformDirection( reflectVec, viewMatrix ); + let envTextureColor:vec4 = textureCubeUV( envTexture,baseSampler, reflectVec, roughness ); + return envTextureColor.rgb * materialUniform.envTextureIntensity; + #else + return vec3( 0.0 ); + #endif + } + #endif `; } -function pbrFrag(defines) { +function instanceVertHeader(defines) { return wgslParseDefines` - #include - #include - #include - #include - #include - #include - #include - #include - struct SystemUniform { - projectionMatrix: mat4x4, - viewMatrix: mat4x4, - inverseViewMatrix: mat4x4, - cameraPosition: vec3, - }; - // uniform vec3 lightProbe[9], -//////////////////////////////////// -struct VertexOutput { - @builtin(position) position: vec4, - @builtin(front_facing) is_front: bool, - @location(0) vUv: vec2, - @location(1) vViewPosition: vec3, // Vector from vertex to camera. - @location(2) vWorldPosition: vec3, - @location(3) vNormal: vec3, - // 可选 - #if ${defines.USE_LIGHTTEXTURE || defines.USE_AOTEXTURE} - @location(${defines.vUv2OutLocation}) vUv2: vec2, - #endif - - #if ${defines.USE_COLOR_ALPHA} - @location(${defines.vColorOutLocation}) vColor: vec4, - #elif ${defines.USE_COLOR || defines.USE_INSTANCING_COLOR} - @location(${defines.vColorOutLocation}) vColor: vec3, - #endif - - #if ${defines.USE_TANGENT} - @location(${defines.vTangentOutLocation}) vTangent: vec3, - @location(${defines.vBitangentOutLocation}) vBitangent: vec3, + #if ${defines.USE_INSTANCE} + struct InstancesUniform { + instanceMatrixs: array, ${defines.instanceCount}>, + }; + @group(0) @binding(${defines.instanceMatrixsBufferBinding}) var instancesUniform: InstancesUniform; #endif -}; - struct PhysicalMaterial { - diffuseColor:vec3, - roughness:f32, - specularColor:vec3, - specularF90:f32, - #if ${defines.USE_CLEARCOAT} - clearcoat:f32, - clearcoatRoughness:f32, - clearcoatF0:vec3, - clearcoatF90:f32, - #endif + `; +} +function instanceVertMain(defines) { + return wgslParseDefines` + #if ${defines.USE_INSTANCE} + modelMatrix=instancesUniform.instanceMatrixs[input.instanceIdx]; + #endif + `; +} - #if ${defines.USE_IRIDESCENCE} - iridescence:f32, - iridescenceIOR:f32, - iridescenceThickness:f32, - iridescenceFresnel:vec3, - iridescenceF0:vec3, - #endif +function light(defines) { + return wgslParseDefines` + struct ReflectedLight { + ambient: vec3, + directDiffuse:vec3, + directSpecular:vec3, + indirectDiffuse:vec3, + indirectSpecular:vec3, + testColor: vec3, + }; + struct IncidentLight { + color: vec3, + direction: vec3, + visible: bool, + }; + struct Geometry { + position: vec3, + normal: vec3, + viewDir: vec3, + dotNV:f32, + #if ${defines.USE_CLEARCOAT} + vec3 clearcoatNormal; + #endif + }; - #if ${defines.USE_SHEEN} - sheenColor:vec3, - sheenRoughness:f32, - #endif + #if ${defines.spotLightsCount > 0} + struct SpotLight { + position: vec3, + distance: f32, + direction: vec3, + coneCos: f32, + color: vec3, + penumbraCos: f32, + decay: f32, + }; + fn getSpotLightInfo(spotLight:SpotLight,worldPos:vec3,shininess:f32,N:vec3,V:vec3)->ReflectedLight{ + var direction:vec3 = spotLight.position - worldPos; + var lightColor:ReflectedLight; + let lightDistance:f32 = length(direction); + direction = normalize(direction); + let angleCos:f32 = dot( direction, spotLight.direction ); + let decay:f32 = clamp(1.0 - pow(lightDistance/spotLight.distance, spotLight.decay), 0.0, 1.0); + let spotEffect:f32 = smoothstep( spotLight.penumbraCos, spotLight.coneCos, angleCos ); + let decayTotal:f32 = decay * spotEffect; + let d:f32 = max( dot( N, direction ), 0.0 ) * decayTotal; + lightColor.directDiffuse= spotLight.color * d; + let halfDir:vec3 = normalize( V + direction ); + let s:f32 = pow( clamp( dot( N, halfDir ), 0.0, 1.0 ), shininess ) * decayTotal; + lightColor.directSpecular= spotLight.color * s; + return lightColor; + } + fn getSpotLightIncidentLight(spotLight:SpotLight, geometry:Geometry)->IncidentLight { + var incidentLight:IncidentLight; + let lVector:vec3 = spotLight.position - geometry.position; + incidentLight.direction = normalize( lVector ); + + let lightDistance:f32 = length( lVector ); + let angleCos:f32 = dot( incidentLight.direction, spotLight.direction ); + + let spotEffect:f32 = smoothstep( spotLight.penumbraCos, spotLight.coneCos, angleCos ); + let decayEffect:f32 = clamp(1.0 - pow(lightDistance/spotLight.distance, 4.0), 0.0, 1.0); + + incidentLight.color=spotLight.color*spotEffect * decayEffect; + return incidentLight; + } - #if ${defines.IOR} - ior:f32, - #endif + #endif - #if ${defines.USE_TRANSMISSION} - transmission:f32, - transmissionAlpha:f32, - thickness:f32, - attenuationDistance:f32, - attenuationColor:vec3, - #endif + #if ${defines.pointLightsCount > 0} + struct PointLight { + position: vec3, + distance: f32, + color: vec3, + decay: f32, }; -@binding(0) @group(0) var materialUniform : MaterialUniform; -@binding(0) @group(1) var systemUniform : SystemUniform; -@fragment -fn main(input:VertexOutput)-> @location(0) vec4 { - var diffuseColor:vec4 = vec4(materialUniform.diffuse, materialUniform.opacity ); - // ReflectedLight reflectedLight = ReflectedLight( vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ) ); - var reflectedLight:ReflectedLight; - var totalEmissiveRadiance:vec3 = materialUniform.emissive; - #if ${defines.USE_TEXTURE} - var sampledDiffuseColor:vec4 =textureSample(baseTexture, baseSampler, input.vUv); - #if ${defines.DECODE_VIDEO_TEXTURE} - sampledDiffuseColor = vec4( mix( pow( sampledDiffuseColor.rgb * 0.9478672986 + vec3( 0.0521327014 ), vec3( 2.4 ) ), sampledDiffuseColor.rgb * 0.0773993808, vec3( lessThanEqual( sampledDiffuseColor.rgb, vec3( 0.04045 ) ) ) ), sampledDiffuseColor.w ); - #endif + fn getPointLightInfo(pointLight:PointLight,worldPos:vec3,shininess:f32,N:vec3,V:vec3)->ReflectedLight{ + var lightColor:ReflectedLight; + var direction:vec3 = worldPos - pointLight.position; + let dist:f32 = length( direction ); + direction = normalize(direction); + let decay = clamp(1.0 - pow(dist / pointLight.distance, pointLight.decay), 0.0, 1.0); + + let d = max( dot( N, -direction ), 0.0 ) * decay; + lightColor.directDiffuse = pointLight.color * d; + + let halfDir:vec3 = normalize( V - direction ); + let s:f32 = pow( clamp( dot( N, halfDir ), 0.0, 1.0 ), shininess ) * decay; + lightColor.directSpecular = pointLight.color * s; + return lightColor; + } + fn getPointLightIncidentLight(pointLight:PointLight, geometry:Geometry)->IncidentLight { + var incidentLight:IncidentLight; + let lVector:vec3 = pointLight.position-geometry.position; + incidentLight.direction= normalize( lVector ); + let lightDistance:f32 = length( lVector ); + // let weight:f32=1.0 - pow(lightDistance/pointLight.distance, 4.0); + incidentLight.color=pointLight.color*clamp(1.0 - pow(lightDistance/pointLight.distance, 4.0), 0.0, 1.0); + return incidentLight; + } + #endif + #if ${defines.dirtectLightsCount > 0} + struct DirectionalLight { + direction: vec3, + color: vec3, + }; + fn getDirectLightInfo(directionalLight:DirectionalLight,shininess:f32,N:vec3,V:vec3)->ReflectedLight{ + var lightColor:ReflectedLight; + let d:f32 = max(dot(N, -directionalLight.direction), 0.0); + lightColor.directDiffuse += directionalLight.color * d; + + let halfDir:vec3 = normalize( V - directionalLight.direction ); + let s:f32 = pow( clamp( dot( N, halfDir ), 0.0, 1.0 ), shininess ); + lightColor.directSpecular += directionalLight.color * s; + return lightColor; + } + fn getDirectionalDirectLightIncidentLight(directionalLight:DirectionalLight,geometry:Geometry)->IncidentLight { + var incidentLight:IncidentLight; + incidentLight.color = directionalLight.color; + incidentLight.direction = normalize(directionalLight.direction); + return incidentLight; + } + #endif - diffuseColor *= sampledDiffuseColor; - #endif + #if ${defines.openShadow} + struct LightInfo { + direction: vec3, + viewport: vec4, + }; + + fn linearizeDepth(depth: f32, near: f32, far: f32)->f32 { + return 2 * (near * far) / (far + near - depth * (far - near)); + } - var roughnessFactor:f32 = materialUniform.roughness; - - #if ${defines.USE_ROUGHNESSTEXTURE} - let texelRoughness:vec4=textureSample(roughnessTexture, baseSampler, input.vUv); - roughnessFactor *= texelRoughness.g; - #endif + fn getCubeFace(v : vec3) -> i32{ + let vAbs = abs(v); + + if (vAbs.z >= vAbs.x && vAbs.z >= vAbs.y) { + if (v.z < 0.0) { + return 3; + } + return 2; + } + + if (vAbs.y >= vAbs.x) { + if (v.y < 0.0) { + return 5; + } + return 4; + } + + if (v.x < 0.0) { + return 1; + } + return 0; + } - var metalnessFactor:f32 = materialUniform.metalness; - - #if ${defines.USE_METALNESSTEXTURE} - let texelMetalness:vec4 =textureSample(metalnessTexture, baseSampler, input.vUv); - metalnessFactor *= texelMetalness.b; - #endif + fn getShadowValue(shadowMapArray:texture_depth_2d_array, shadowSampler:sampler_comparison, lightPos:vec4, geometry:Geometry, lightInfo:LightInfo, index:u32, isPointLight: bool, near: f32, far: f32)->f32 { + var visibility = 0.0; + var projectPos: vec3 = lightPos.xyz / lightPos.w; + var shadowPos: vec3 = vec3(projectPos.xy * vec2(0.5, -0.5) + vec2(0.5), projectPos.z); + var d:f32 = dot(geometry.normal, -lightInfo.direction); + var bias = max(0.012 * (1.0 - d), 0.001) / lightPos.w; + let oneOverShadowDepthTextureSize = 1.0 / 1024.0; + // var depth = select(shadowPos.z, (linearizeDepth(shadowPos.z, near, far) - near) / (far- near), isPerspectiveCamera); + var depth = shadowPos.z; - let faceDirection:f32 =select(-1.0,1.0,input.is_front); - #if ${defines.FLAT_SHADED} - let fdx:vec3 = dpdx( input.vViewPosition ); - let fdy:vec3 = dpdy( input.vViewPosition ); - let normal:vec3 = normalize( cross( fdy, fdx ) ); - #else - let normal:vec3 = normalize( input.vNormal ); - #if ${defines.DOUBLE_SIDED} - normal = normal * faceDirection; + if (isPointLight) { + shadowPos.x = shadowPos.x * lightInfo.viewport.z; + shadowPos.y = shadowPos.y * lightInfo.viewport.w; + var viewportX = lightInfo.viewport.x * lightInfo.viewport.z; + var viewportY = lightInfo.viewport.y * lightInfo.viewport.w; + var uvOffset = 1.5 / 1024.0; + shadowPos.x = clamp(shadowPos.x + viewportX, viewportX + uvOffset, viewportX + lightInfo.viewport.z - uvOffset); + shadowPos.y = clamp(shadowPos.y + viewportY, viewportY + uvOffset, viewportY + lightInfo.viewport.w - uvOffset); + } + + for (var y = -1; y <= 1; y++) { + for (var x = -1; x <= 1; x++) { + let offset = vec2(vec2(x, y)) * oneOverShadowDepthTextureSize; + + visibility += textureSampleCompare( + shadowMapArray, shadowSampler, + shadowPos.xy + offset, index, depth - bias); + } + } + visibility /= 9.0; + var inFrustum = shadowPos.x >= 0.0 && shadowPos.x <= 1.0 && shadowPos.y >= 0.0 && shadowPos.y <= 1.0; + if (!inFrustum || depth > 1.0) { + visibility = 1.0; + } + return visibility; + } + #endif + + #if ${ + defines.ambientLightCount || defines.spotLightsCount || defines.pointLightsCount || defines.dirtectLightsCount + } + struct LightUniforms{ + #if ${defines.ambientLightCount} + ambient:vec4, #endif - #if ${defines.USE_TANGENT} - let tangent:vec3 = normalize( input.vTangent ); - let bitangent:vec3 = normalize( input.vBitangent ); - #if ${defines.DOUBLE_SIDED} - tangent = tangent * faceDirection; - bitangent = bitangent * faceDirection; - #endif - #if ${defines.TANGENTSPACE_NORMALTEXTURE || defines.USE_CLEARCOAT_NORMALTEXTURE} - let vTBN:mat3x3 = mat3x3( tangent, bitangent, normal ); - #endif + #if ${defines.spotLightsCount} + spotLights:array, #endif - #endif - - let geometryNormal:vec3 = normal; - - #if ${defines.OBJECTSPACE_NORMALTEXTURE} - normal =textureSample(normalTexture, baseSampler, input.vUv).xyz * 2.0 - 1.0; - #if ${defines.FLIP_SIDED} - normal = - normal; + #if ${defines.pointLightsCount} + pointLights:array, #endif - #if ${defines.DOUBLE_SIDED} - normal = normal * faceDirection; + #if ${defines.dirtectLightsCount} + dirtectLights:array, #endif + } + @group(2) @binding(${defines.lightBinding}) var lightUniforms: LightUniforms; - normal = normalize(materialUniform.normalMatrix * normal ); - - #elif ${defines.TANGENTSPACE_NORMALTEXTURE} - let tempMapN:vec3 =textureSample(normalTexture, baseSampler, input.vUv).xyz * 2.0 - 1.0; - let mapN:vec3 =tempMapN.xy *= materialUniform.normalScale; - #if ${defines.USE_TANGENT} - normal = normalize( vTBN * mapN ); - #else - normal = perturbNormal2Arb( - input.vViewPosition, normal, mapN, faceDirection ); + #if ${defines.openShadow} + #if ${defines.spotLightShadowMapsCount} + struct SpotLightShadow { + shadowCameraVPMatrix: mat4x4, + shadowCameraNear: f32, + shadowCameraFar: f32 + } #endif - - #elif ${defines.USE_BUMPTEXTURE} - - normal = perturbNormalArb( - input.vViewPosition, normal, dHdxy_fwd(), faceDirection ); - #endif - - #if ${defines.USE_CLEARCOAT} - var clearcoatNormal:vec3 = geometryNormal; - #endif - #if ${defines.USE_CLEARCOAT_NORMALTEXTURE} - var clearcoatMapN:vec3 =textureSample(clearcoatNormalTexture, baseSampler, input.vUv).xyz * 2.0 - 1.0; - clearcoatMapN.xy *= materialUniform.clearcoatNormalScale; - #if ${defines.USE_TANGENT} - clearcoatNormal = normalize( vTBN * clearcoatMapN ); - #else - clearcoatNormal = perturbNormal2Arb( - input.vViewPosition, clearcoatNormal, clearcoatMapN, faceDirection ); + #if ${defines.pointLightShadowMapsCount} + struct PointLightShadow { + shadowCameraVPMatrixArray: array, 6>, + shadowCameraViewportArray: array, 6>, + shadowCameraNear: f32, + shadowCameraFar: f32, + // shadowCameraVPMatrix: mat4x4, + // shadowCameraVPMatrixArray: array, 6>, + // shadowCameraViewportArray: array, 6>, + } #endif - #endif - #if ${defines.USE_EMISSIVETEXTURE} - let emissiveColor:vec4 =textureSample(emissiveTexture, baseSampler, input.vUv); - totalEmissiveRadiance *= emissiveColor.rgb; - #endif - - var material:PhysicalMaterial; - material.diffuseColor = diffuseColor.rgb * ( 1.0 - metalnessFactor ); - let dxy:vec3 = max( abs( dpdx( geometryNormal ) ), abs( dpdy( geometryNormal ) ) ); - let geometryRoughness:f32 = max( max( dxy.x, dxy.y ), dxy.z ); - material.roughness = max( roughnessFactor, 0.0525 ); - material.roughness += geometryRoughness; - material.roughness = min( material.roughness, 1.0 ); - - #if ${defines.IOR} - material.ior = materialUniform.ior; - #if ${defines.SPECULAR} - let specularIntensityFactor:f32 = materialUniform.specularIntensity; - let specularColorFactor:vec3 = materialUniform.specularColor; - #if ${defines.USE_SPECULARINTENSITYTEXTURE} - specularIntensityFactor *=textureSample(specularIntensityTexture, baseSampler, input.vUv).a; + #if ${defines.directLightShadowMapsCount} + struct DirectLightShadow { + shadowCameraVPMatrix: mat4x4, + } + #endif + struct ShadowUniforms{ + #if ${defines.spotLightShadowMapsCount} + spotLightShadows:array, #endif - - #if ${defines.USE_SPECULARCOLORTEXTURE} - specularColorFactor *=textureSample(specularColorTexture, baseSampler, input.vUv).rgb; + #if ${defines.pointLightShadowMapsCount} + pointLightShadows:array, + #endif + #if ${defines.directLightShadowMapsCount} + directLightShadows:array, #endif + } + @group(2) @binding(${defines.shadowBinding}) var shadowUniforms: ShadowUniforms; - material.specularF90 = mix( specularIntensityFactor, 1.0, metalnessFactor ); - #else - let specularIntensityFactor:f32 = 1.0; - let specularColorFactor:vec3 = vec3( 1.0 ); - material.specularF90 = 1.0; - #endif - material.specularColor = mix( min( pow2( ( material.ior - 1.0 ) / ( material.ior + 1.0 ) ) * specularColorFactor, vec3( 1.0 ) ) * specularIntensityFactor, diffuseColor.rgb, metalnessFactor ); - #else - material.specularColor = mix( vec3( 0.04 ), diffuseColor.rgb, metalnessFactor ); - material.specularF90 = 1.0; - #endif - #if ${defines.USE_CLEARCOAT} - material.clearcoat = materialUniform.clearcoat; - material.clearcoatRoughness = materialUniform.clearcoatRoughness; - material.clearcoatF0 = vec3( 0.04 ); - material.clearcoatF90 = 1.0; - #if ${defines.USE_CLEARCOATTEXTURE} - material.clearcoat *=textureSample(clearcoatTexture, baseSampler, input.vUv).x; - #endif - #if ${defines.USE_CLEARCOAT_ROUGHNESSTEXTURE} - material.clearcoatRoughness *=textureSample(clearcoatRoughnessTexture, baseSampler, input.vUv).y; - #endif - material.clearcoat = saturate( material.clearcoat ); - material.clearcoatRoughness = max( material.clearcoatRoughness, 0.0525 ); - material.clearcoatRoughness += geometryRoughness; - material.clearcoatRoughness = min( material.clearcoatRoughness, 1.0 ); - #endif - #if ${defines.USE_IRIDESCENCE} - material.iridescence = materialUniform.iridescence; - material.iridescenceIOR = materialUniform.iridescenceIOR; - #if ${defines.USE_IRIDESCENCETEXTURE} - material.iridescence *=textureSample(iridescenceTexture, baseSampler, input.vUv).r; - #endif - #if ${defines.USE_IRIDESCENCE_THICKNESSTEXTURE} - material.iridescenceThickness = (materialUniform.iridescenceThicknessMaximum - materialUniform.iridescenceThicknessMinimum) * textureSample(iridescenceThicknessTexture, baseSampler, input.vUv).g + materialUniform.iridescenceThicknessMinimum; - #else - material.iridescenceThickness = materialUniform.iridescenceThicknessMaximum; + #if ${defines.spotLightShadowMapTextureArrayBinding} + @group(2) @binding(${ + defines.spotLightShadowMapTextureArrayBinding + }) var spotLightShadowMapTextureArray: texture_depth_2d_array; #endif - #endif - #if ${defines.USE_SHEEN} - material.sheenColor = materialUniform.sheenColor; - #if ${defines.USE_SHEENCOLORTEXTURE} - material.sheenColor *=textureSample(sheenColorTexture, baseSampler, input.vUv).rgb; + #if ${defines.pointLightShadowMapTextureArrayBinding} + @group(2) @binding(${ + defines.pointLightShadowMapTextureArrayBinding + }) var pointLightShadowMapTextureArray: texture_depth_2d_array; #endif - material.sheenRoughness = clamp( materialUniform.sheenRoughness, 0.07, 1.0 ); - #if ${defines.USE_SHEENROUGHNESSTEXTURE} - material.sheenRoughness *=textureSample(sheenRoughnessTexture, baseSampler, input.vUv).a; + #if ${defines.directLightShadowMapTextureArrayBinding} + @group(2) @binding(${ + defines.directLightShadowMapTextureArrayBinding + }) var directLightShadowMapTextureArray: texture_depth_2d_array; #endif + @group(2) @binding(${defines.shadowSamplerBinding}) var shadowSampler: sampler_comparison; #endif - - var geometry:GeometricContext; - geometry.position = - input.vViewPosition; - geometry.normal = normal; - // geometry.viewDir = ( isOrthographic ) ? vec3( 0, 0, 1 ) : normalize( input.vViewPosition ); - geometry.viewDir = normalize( input.vViewPosition); - #if ${defines.USE_CLEARCOAT} - geometry.clearcoatNormal = clearcoatNormal; + #endif + #if ${defines.materialPhong} + fn parseLights(geometry:Geometry,shininess:f32)->ReflectedLight { + #elif ${defines.materialPbr} + fn parseLights(geometry:Geometry,material:PhysicalMaterial)->ReflectedLight{ + #endif + var reflectedLight:ReflectedLight; + var shadowValue:f32 = 1.0; + #if ${defines.ambientLightCount > 0} + //处理环境光 + var ambientColor:vec3 = lightUniforms.ambient.xyz * lightUniforms.ambient.w; + reflectedLight.ambient += ambientColor; #endif - #if ${defines.USE_IRIDESCENCE} - let dotNVi:f32 = saturate( dot( normal, geometry.viewDir ) ); - if ( material.iridescenceThickness == 0.0 ) { - material.iridescence = 0.0; - } - else { - material.iridescence = saturate( material.iridescence ); - } - if ( material.iridescence > 0.0 ) { - material.iridescenceFresnel = evalIridescence( 1.0, material.iridescenceIOR, dotNVi, material.iridescenceThickness, material.specularColor ); - material.iridescenceF0 = Schlick_to_F0( material.iridescenceFresnel, 1.0, dotNVi ); + #if ${defines.spotLightsCount > 0} + //处理聚光灯 + var spotLight:SpotLight; + for (var k = 0u; k < ${defines.spotLightsCount}; k = k + 1u) { + spotLight= lightUniforms.spotLights[k]; + #if ${defines.materialPhong && defines.openShadow && defines.spotLightShadowMapsCount} + if k < textureNumLayers(spotLightShadowMapTextureArray) { + var spotLightShadow:SpotLightShadow = shadowUniforms.spotLightShadows[k]; + var lightPos: vec4 = spotLightShadow.shadowCameraVPMatrix * vec4(geometry.position,1.0); + var lightInfo:LightInfo; + lightInfo.direction = normalize(geometry.position - spotLight.position); + + shadowValue = getShadowValue(spotLightShadowMapTextureArray, shadowSampler, lightPos, geometry, lightInfo, k, false, + spotLightShadow.shadowCameraNear, spotLightShadow.shadowCameraFar); + } + spotLight.color *= shadowValue; + #endif + #if ${defines.materialPhong} + let spReflectedLight=getSpotLightInfo(spotLight,geometry.position,shininess,geometry.normal,geometry.viewDir); + #elif ${defines.materialPbr} + let incidentLight=getSpotLightIncidentLight(spotLight,geometry); + let spReflectedLight=direct_Physical(incidentLight, geometry, material); + #endif + + reflectedLight.directDiffuse+=spReflectedLight.directDiffuse; + reflectedLight.directSpecular+=spReflectedLight.directSpecular; } #endif + #if ${defines.pointLightsCount > 0} + //处理点光源 + var pointLight:PointLight; + for (var j = 0u; j < ${defines.pointLightsCount};j = j + 1u) { + pointLight = lightUniforms.pointLights[j]; + #if ${defines.materialPhong && defines.openShadow && defines.pointLightShadowMapsCount} + if j < textureNumLayers(pointLightShadowMapTextureArray) { + var pointLightShadow:PointLightShadow = shadowUniforms.pointLightShadows[j]; + var lightInfo:LightInfo; + lightInfo.direction = normalize(geometry.position - pointLight.position); + var cubeFace = getCubeFace(lightInfo.direction); + var lightPos: vec4 = pointLightShadow.shadowCameraVPMatrixArray[cubeFace] * vec4(geometry.position,1.0); + lightInfo.viewport = pointLightShadow.shadowCameraViewportArray[cubeFace]; - var iblIrradiance:vec3 = vec3( 0.0 ); - var irradiance:vec3 = getAmbientLightIrradiance(commonLightsParms.ambient); - //irradiance += getLightProbeIrradiance( lightProbe, geometry.normal,systemUniform.viewMatrix ); + // var lightPos: vec4 = pointLightShadow.shadowCameraVPMatrix * vec4(geometry.position,1.0); - var radiance:vec3 = vec3( 0.0 ); - var clearcoatRadiance:vec3 = vec3( 0.0 ); + shadowValue = getShadowValue(pointLightShadowMapTextureArray, shadowSampler, lightPos, geometry, lightInfo, j, true, + pointLightShadow.shadowCameraNear, pointLightShadow.shadowCameraFar); + + // reflectedLight.testColor = vec3(pointLightShadow.shadowCameraFar / 1000, + // pointLightShadow.shadowCameraVPMatrixArray[5][3][2] / 255, pointLightShadow.shadowCameraVPMatrixArray[5][3][3] / 255); + // reflectedLight.testColor = vec3(pointLightShadow.shadowCameraNear, pointLightShadow.shadowCameraNear, pointLightShadow.shadowCameraNear); + } + pointLight.color *= shadowValue; + #endif + #if ${defines.materialPhong} + let poiReflectedLight=getPointLightInfo(pointLight,geometry.position,shininess,geometry.normal,geometry.viewDir); + #elif ${defines.materialPbr} + let incidentLight=getPointLightIncidentLight(pointLight,geometry); + let poiReflectedLight=direct_Physical(incidentLight, geometry, material); + #endif - #if ${defines.USE_LIGHTTEXTURE} - let lightMapTexel:vec4 =textureSample(lightTexture, baseSampler, input.vUv2); - let lightMapIrradiance:vec3 = lightMapTexel.rgb * materialUniform.lightTextureIntensity; - irradiance += lightMapIrradiance; + reflectedLight.directDiffuse+=poiReflectedLight.directDiffuse; + reflectedLight.directSpecular+=poiReflectedLight.directSpecular; + } #endif - //&& defines.STANDARD&&defines.ENVTEXTURE_TYPE_CUBE_UV - #if ${defines.USE_ENVTEXTURE} - iblIrradiance += getIBLIrradiance( geometry.normal,baseSampler,systemUniform.viewMatrix ); + #if ${defines.dirtectLightsCount > 0} + //处理方向光 + var directionalLight:DirectionalLight; + for (var i= 0u; i <${defines.dirtectLightsCount}; i = i + 1u) { + directionalLight = lightUniforms.dirtectLights[i]; + #if ${defines.materialPhong && defines.openShadow && defines.directLightShadowMapsCount} + if i < textureNumLayers(directLightShadowMapTextureArray) { + var directLightShadow:DirectLightShadow = shadowUniforms.directLightShadows[i]; + var lightPos: vec4 = directLightShadow.shadowCameraVPMatrix * vec4(geometry.position,1.0); + var lightInfo:LightInfo; + lightInfo.direction = directionalLight.direction; + + shadowValue = getShadowValue(directLightShadowMapTextureArray, shadowSampler, lightPos, geometry, lightInfo, i, false, 0, 0); + } + directionalLight.color *= shadowValue; + #endif + + #if ${defines.materialPhong} + let dirReflectedLight=getDirectLightInfo(directionalLight,shininess,geometry.normal,geometry.viewDir); + #elif ${defines.materialPbr} + let incidentLight=getDirectionalDirectLightIncidentLight(directionalLight,geometry); + let dirReflectedLight=direct_Physical(incidentLight, geometry, material); + #endif + + reflectedLight.directDiffuse+=dirReflectedLight.directDiffuse; + reflectedLight.directSpecular+=dirReflectedLight.directSpecular; + } #endif - #if ${defines.USE_ENVTEXTURE} - radiance += getIBLRadiance( geometry.viewDir,baseSampler,systemUniform.viewMatrix, geometry.normal, materialUniform.roughness ); - #if ${defines.USE_CLEARCOAT} - clearcoatRadiance += getIBLRadiance( geometry.viewDir,baseSampler,systemUniform.viewMatrix, geometry.clearcoatNormal, material.clearcoatRoughness ); - #endif + return reflectedLight; + }`; +} + +function lightCommon(defines) { + return wgslParseDefines` + struct ReflectedLight { + directDiffuse:vec3, + directSpecular:vec3, + indirectDiffuse:vec3, + indirectSpecular:vec3, + }; + struct Geometry { + position: vec3, + normal: vec3, + viewDir: vec3, + #if ${defines.USE_CLEARCOAT} + vec3 clearcoatNormal; #endif - //直接光照 - let dirReflectedLight:ReflectedLight= parseLights(geometry,material); - reflectedLight.directDiffuse +=dirReflectedLight.directDiffuse; - reflectedLight.directSpecular +=dirReflectedLight.directSpecular; - //间接漫反射 - let indirectDiffuseLight:ReflectedLight= RE_IndirectDiffuse_Physical( irradiance, geometry, material); - reflectedLight.directDiffuse +=indirectDiffuseLight.indirectDiffuse; - reflectedLight.directSpecular +=indirectDiffuseLight.indirectSpecular; - //间接高光 - let indirectSpecularLight:ReflectedLight=RE_IndirectSpecular_Physical( radiance, iblIrradiance, clearcoatRadiance, geometry, material); - reflectedLight.directDiffuse +=indirectSpecularLight.indirectDiffuse; - reflectedLight.directSpecular +=indirectSpecularLight.indirectSpecular; - //环境光遮蔽 - #if ${defines.USE_AOTEXTURE} - let ambientOcclusion:f32 = (textureSample(aoTexture, baseSampler, input.vUv2).r - 1.0 ) * materialUniform.aoTextureIntensity + 1.0; + }; + fn getAmbientLightIrradiance(ambientLightColor: vec3) -> vec3 { + let irradiance = ambientLightColor; + return irradiance; + } + fn getDistanceAttenuation(lightDistance: f32, cutoffDistance: f32, decayExponent: f32) -> f32 { + if (cutoffDistance > 0.0 && decayExponent > 0.0) { + let x:f32 = saturate(- lightDistance / cutoffDistance + 1.0); + return pow(x, decayExponent); + } + return 1.0; + } + fn getSpotAttenuation(coneCosine: f32, penumbraCosine: f32, angleCosine: f32) -> f32 { + return smoothstep(coneCosine, penumbraCosine, angleCosine); + } + fn shGetIrradianceAt( normal:vec3, shCoefficients:array,9>)->vec3 { + let x:f32 = normal.x; + let y:f32 = normal.y; + let z:f32 = normal.z; + var result:vec3 = shCoefficients[ 0 ] * 0.886227; + result += shCoefficients[ 1 ] * 2.0 * 0.511664 * y; + result += shCoefficients[ 2 ] * 2.0 * 0.511664 * z; + result += shCoefficients[ 3 ] * 2.0 * 0.511664 * x; + result += shCoefficients[ 4 ] * 2.0 * 0.429043 * x * y; + result += shCoefficients[ 5 ] * 2.0 * 0.429043 * y * z; + result += shCoefficients[ 6 ] * ( 0.743125 * z * z - 0.247708 ); + result += shCoefficients[ 7 ] * 2.0 * 0.429043 * x * z; + result += shCoefficients[ 8 ] * 0.429043 * ( x * x - y * y ); + return result; + } + fn inverseTransformDirection( dir:vec3, matrix:mat4x4 )->vec3 { + return normalize( ( vec4( dir, 0.0 ) * matrix ).xyz ); + } + `; +} - reflectedLight.indirectDiffuse *= ambientOcclusion; - //&&defines.STANDARD - #if ${defines.USE_ENVTEXTURE} - let dotNV:f32 = saturate( dot( geometry.normal, geometry.viewDir ) ); - reflectedLight.indirectSpecular *= computeSpecularOcclusion( dotNV, ambientOcclusion, material.roughness ); - #endif +function getNormal(defines) { + return wgslParseDefines` + fn getNormal(input:FragInput)->vec3{ + var normal:vec3; + #if ${defines.HAS_NORMAL} + normal= input.normal; + #else + let pos_dx = dpdx(input.worldPos); + let pos_dy = dpdy(input.worldPos); + normal = normalize( cross(pos_dy, pos_dx) ); + #endif + return normal*(f32(input.frontFacing) * 2.0 - 1.0); + } + `; +} +function getNormalByNormalTexture(defines) { + return wgslParseDefines` + fn getNormalByNormalTexture(input:FragInput)->vec3{ + var n:vec3 = textureSample(normalTexture,normalSampler, input.uv).rgb; + let tbn:mat3x3 =getTBN(input); + n = normalize(tbn * (2.0 * n - vec3(1.0))); + n=n*(f32(input.frontFacing) * 2.0 - 1.0); + return n; + } + `; +} +function getTBN(defines) { + return wgslParseDefines` + fn getTBN(input:FragInput)->mat3x3{ + #if ${defines.HAS_TANGENT} + let tbn:mat3x3 = input.tbn; + #else + let normal:vec3 =normalize(input.normal); + let uv:vec2 = select(-input.uv,input.uv,input.frontFacing); + // ref: http://www.thetenthplanet.de/archives/1180 + // get edge vectors of the pixel triangle + let dp1:vec3 = vec3(dpdx(input.worldPos.x), dpdx(input.worldPos.y), dpdx(input.worldPos.z)); + let dp2:vec3 = vec3(dpdy(input.worldPos.x), dpdy(input.worldPos.y), dpdy(input.worldPos.z)); + let duv1:vec2 = dpdx(uv); + let duv2:vec2 = dpdy(uv); + + // solve the linear system + let dp2perp:vec3 = cross(dp2, normal); + let dp1perp:vec3 = cross(normal, dp1); + let tangent:vec3 = dp2perp * duv1.x + dp1perp * duv2.x; + let binormal:vec3 = dp2perp * duv1.y + dp1perp * duv2.y; + // construct a scale-invariant frame + let result:f32=max(dot(tangent, tangent), dot(binormal, binormal)); + let invmax:f32 = 1.0/sqrt(result); + let tbn:mat3x3 = mat3x3(tangent * invmax, binormal * invmax, normal); #endif + return tbn; + } + `; +} - var totalDiffuse:vec3 = reflectedLight.directDiffuse + reflectedLight.indirectDiffuse; - var totalSpecular:vec3 = reflectedLight.directSpecular + reflectedLight.indirectSpecular; - //透射 - #if ${defines.USE_TRANSMISSION} - material.transmission = materialUniform.transmission; - material.transmissionAlpha = 1.0; - material.thickness = materialUniform.thickness; - material.attenuationDistance = materialUniform.attenuationDistance; - material.attenuationColor = materialUniform.attenuationColor; - #if ${defines.USE_TRANSMISSIONTEXTURE} - material.transmission *=textureSample(transmissionTexture, baseSampler, input.vUv).r; - #endif - #if ${defines.USE_THICKNESSTEXTURE} - material.thickness *=textureSample(thicknessTexture, baseSampler, input.vUv).g; - #endif - let pos:vec3 = vWorldPosition; - let v:vec3 = normalize( cameraPosition - pos ); - let n:vec3 = inverseTransformDirection( normal, systemUniform.viewMatrix ); - let transmission:vec4 = getIBLVolumeRefraction( - n, v, material.roughness, material.diffuseColor, material.specularColor, material.specularF90, pos, modelMatrix, systemUniform.viewMatrix, systemUniform.projectionMatrix, material.ior, material.thickness, material.attenuationColor, material.attenuationDistance ); - material.transmissionAlpha = mix( material.transmissionAlpha, transmission.a, material.transmission ); - totalDiffuse = mix( totalDiffuse, transmission.rgb, material.transmission ); +function brdf(defines) { + return wgslParseDefines` + #if ${defines.USE_SHEEN} + fn D_Charlie( roughness:f32,dotNH:f32 )->f32 { + let alpha:f32 = pow2( roughness ); + let invAlpha:f32 = 1.0 / alpha; + let cos2h:f32 = dotNH * dotNH; + let sin2h:f32 = max( 1.0 - cos2h, 0.0078125 ); + return ( 2.0 + invAlpha ) * pow( sin2h, invAlpha * 0.5 ) / ( 2.0 * PI ); + } + fn V_Neubelt( dotNV:f32, dotNL:f32 )->f32 { + return saturate( 1.0 / ( 4.0 * ( dotNL + dotNV - dotNL * dotNV ) ) ); + } + fn BRDF_Sheen(lightDir:vec3, viewDir:vec3, normal:vec3,sheenColor:vec3,sheenRoughness:f32 )->vec3 { + let halfDir:vec3 = normalize( lightDir + viewDir ); + let dotNL:f32 = saturate( dot( normal, lightDir ) ); + let dotNV:f32 = saturate( dot( normal, viewDir ) ); + let dotNH:f32 = saturate( dot( normal, halfDir ) ); + let D:f32 = D_Charlie( sheenRoughness, dotNH ); + let V:f32 = V_Neubelt( dotNV, dotNL ); + return sheenColor * ( D * V ); + } #endif + fn BRDF_Lambert(diffuseColor:vec3)->vec3 { - let outgoingLight:vec3 = totalDiffuse + totalSpecular + totalEmissiveRadiance; + return RECIPROCAL_PI * diffuseColor; - #if ${defines.USE_SHEEN} - let sheenEnergyComp:f32 = 1.0 - 0.157 * max3( material.sheenColor ); - outgoingLight = outgoingLight * sheenEnergyComp + sheenSpecular; - #endif + } // validated - #if ${defines.USE_CLEARCOAT} - let dotNVcc:f32 = saturate( dot( geometry.clearcoatNormal, geometry.viewDir ) ); - let Fcc:vec3 = F_Schlick( material.clearcoatF0, material.clearcoatF90, dotNVcc ); - outgoingLight = outgoingLight * ( 1.0 - material.clearcoat * Fcc ) + clearcoatSpecular * material.clearcoat; - #endif + fn F_Schlick( f0:vec3, dotVH:f32 )->vec3 { - #if ${defines.USE_TRANSMISSION} - diffuseColor.a *= material.transmissionAlpha + 0.1; - #endif + // Original approximation by Christophe Schlick '94 + // float fresnel = pow( 1.0 - dotVH, 5.0 ); - var finnalColor:vec4; - finnalColor = vec4( outgoingLight, diffuseColor.a ); - #if ${defines.TONE_MAPPING} - finnalColor.rgb = toneMapping( finnalColor.rgb,materialUniform.toneMappingExposure ); - #endif + // Optimized variant (presented by Epic at SIGGRAPH '13) + // https://cdn2.unrealengine.com/Resources/files/2013SiggraphPresentationsNotes-26915738.pdf + let fresnel = exp2( ( - 5.55473 * dotVH - 6.98316 ) * dotVH ); + return ( 1.0 - f0 ) * fresnel + f0; - finnalColor = linearToOutputTexel( finnalColor); + } // validated - #if ${defines.PREMULTIPLIED_ALPHA} - finnalColor.rgb *= finnalColor.a; - #endif - #if ${defines.DITHERING} - finnalColor.rgb = dithering( finnalColor.rgb ); - #endif - return finnalColor; - }`; -} + fn Schlick_to_F0(f:vec3, f90:f32, dotVH:f32 )->vec3 { + let x:f32 = clamp( 1.0 - dotVH, 0.0, 1.0 ); + let x2:f32 = x * x; + let x5:f32 = clamp( x * x2 * x2, 0.0, 0.9999 ); -function pbrVert(defines) { - return wgslParseDefines` - #include - struct VertexOutput { - @builtin(position) position: vec4, - @location(0) vUv: vec2, - @location(1) vViewPosition: vec3, // Vector from vertex to camera. - @location(2) vWorldPosition: vec3, - @location(3) vNormal: vec3, - // 可选 - #if ${defines.USE_LIGHTTEXTURE || defines.USE_AOTEXTURE} - @location(${defines.vUv2OutLocation}) vUv2: vec2, - #endif + return ( f - vec3( f90 ) * x5 ) / ( 1.0 - x5 ); + } + fn V_GGX_SmithCorrelated( alpha:f32, dotNL:f32,dotNV:f32 )->f32 { - #if ${defines.USE_COLOR_ALPHA} - @location(${defines.vColorOutLocation}) vColor: vec4, - #elif ${defines.USE_COLOR || defines.USE_INSTANCING_COLOR} - @location(${defines.vColorOutLocation}) vColor: vec3, - #endif + let a2 :f32= pow2( alpha ); - #if ${defines.USE_TANGENT} - @location(${defines.vTangentOutLocation}) vTangent: vec3, - @location(${defines.vBitangentOutLocation}) vBitangent: vec3, - #endif - }; - struct GlobalUniform { - projectionMatrix: mat4x4, - viewMatrix: mat4x4, - inverseViewMatrix: mat4x4, - cameraPosition: vec3, - }; + let gv:f32 = dotNL * sqrt( a2 + ( 1.0 - a2 ) * pow2( dotNV ) ); + let gl:f32 = dotNV * sqrt( a2 + ( 1.0 - a2 ) * pow2( dotNL ) ); - //texture and sampler - // @group(0) @binding(${defines.samplerBinding}) var baseSampler: sampler; - #if ${defines.USE_SKINNING} - //uniform highp sampler2D boneTexture; - @group(0) @binding(${defines.boneTextureBinding}) var boneTexture: texture_2d; - #endif + return 0.5 / max((gv + gl), 0.000000001 ); - #if ${defines.USE_DISPLACEMENTTEXTURE} - //uniform sampler2D displacementMap; - @group(0) @binding(${defines.displacementTextureBinding}) var displacementMap: texture_2d; - #endif + } + fn D_GGX( alpha:f32, dotNH:f32 )->f32 { - #if ${defines.MORPHTARGETS_TEXTURE} - //uniform sampler2DArray morphTargetsTexture; - @group(0) @binding(${defines.morphTargetsTextureBinding}) var morphTargetsTexture: texture_2d_array; - #endif + let a2:f32 = pow2( alpha ); - struct VertexInput { - @location(0) position: vec3, + let denom:f32 = pow2( dotNH ) * ( a2 - 1.0 ) + 1.0; // avoid alpha = 0 with dotNH = 1 - @location(1) normal: vec3, + return RECIPROCAL_PI * a2 / pow2( denom ); - @location(2) uv: vec2, - #if ${defines.USE_LIGHTTEXTURE || defines.USE_AOTEXTURE} - @location(${defines.uv2Location}) uv2:vec2, - #endif - #if ${defines.USE_INSTANCING} - @location(${defines.instanceMatrixLocation}) instanceMatrix:mat4x4, - #endif - #if ${defines.USE_INSTANCING_COLOR} - @location(${defines.instanceColorLocation}) instanceColor:vec3, - #endif - - #if ${defines.USE_TANGENT} - @location(${defines.tangentLocation}) tangent:vec4, - #endif - #if ${defines.USE_COLOR_ALPHA} - @location(${defines.colorLocation}) color:vec4, - #elif ${defines.USE_COLOR} - @location(${defines.colorLocation}) color:vec3, - #endif + } + fn BRDF_GGX( lightDir:vec3, viewDir:vec3, normal:vec3, f0:vec3, roughness:f32 )->vec3 { - #if ${defines.USE_MORPHTARGETS && !defines.MORPHTARGETS_TEXTURE} - @location(${defines.morphTarget0Location}) morphTarget0:vec3, + let alpha:f32 = pow2( roughness ); // UE4's roughness - @location(${defines.morphTarget1Location}) morphTarget1:vec3, + let halfDir = normalize( lightDir + viewDir ); - @location(${defines.morphTarget2Location}) morphTarget2:vec3, + let dotNL:f32 = saturate( dot( normal, lightDir ) ); + let dotNV:f32 = saturate( dot( normal, viewDir ) ); + let dotNH:f32 = saturate( dot( normal, halfDir ) ); + let dotVH:f32 = saturate( dot( lightDir, halfDir ) ); - @location(${defines.morphTarget3Location}) morphTarget3:vec3, - #if ${defines.USE_MORPHNORMALS} - @location(${defines.morphNormal0Location}) morphNormal0:vec3, + let F = F_Schlick( f0, dotVH ); - @location(${defines.morphNormal1Location}) morphNormal1:vec3, + let V = V_GGX_SmithCorrelated( alpha, dotNL, dotNV ); - @location(${defines.morphNormal2Location}) morphNormal2:vec3, + let D = D_GGX( alpha, dotNH ); - @location(${defines.morphNormal3Location}) morphNormal3:vec3, - #else - @location(${defines.morphTarget4Location}) morphTarget4:vec3, + return F * ( V * D ); - @location(${defines.morphTarget5Location}) morphTarget5:vec3, + } + fn direct_Physical( directLight:IncidentLight, geometry:Geometry,material:PhysicalMaterial)->ReflectedLight { + var reflectedLight:ReflectedLight; + let dotNL:f32 = saturate(dot( geometry.normal,geometry.viewDir)); + let irradiance:vec3 = dotNL * directLight.color*3.1415926; + reflectedLight.directSpecular = irradiance * BRDF_GGX( directLight.direction, geometry.viewDir, geometry.normal, material.specularColor, material.roughness ); + reflectedLight.directDiffuse = irradiance * BRDF_Lambert( material.diffuseColor ); + return reflectedLight; + } + `; +} + +function ibl(defines) { + return wgslParseDefines` + fn getLightProbeRadiance( viewDir:vec3,normal:vec3, roughness:f32 )->vec3{ + var reflectVec:vec3 = reflect( -viewDir, normal ); + reflectVec.x = -reflectVec.x; // TextureCube is left-hand,so x need inverse + let mipCount:f32 = 10.0; // resolution of 256x256 + let lod:f32 = roughness * mipCount; + let specularLight:vec3 = textureSampleLevel(specularEnvTexture,specularEnvSampler, reflectVec, lod).rgb; + return specularLight; + } + fn getLightProbeIrradiance( lightProbe:array,9>, normal:vec3)->vec3 { + var worldNormal:vec3 = normal; + worldNormal.x = -normal.x; + var irradiance:vec3 = lightProbe[0]; + irradiance+=lightProbe[1] * (normal.y); + irradiance+=lightProbe[2] * (normal.z) ; + irradiance+=lightProbe[3] * (normal.x) ; + + irradiance+=lightProbe[4] * (normal.y * normal.x) ; + irradiance+=lightProbe[5] * (normal.y * normal.z) ; + irradiance+=lightProbe[6] * (3.0 * normal.z * normal.z - 1.0); + irradiance+=lightProbe[7] * (normal.z * normal.x) ; + irradiance+=lightProbe[8] * (normal.x * normal.x - normal.y * normal.y); + + return max(irradiance, vec3(0.0,0.0,0.0)); + } + fn DFGApprox( specularColor:vec3, roughness:f32,dotNV:f32 )->vec3 { + const c0:vec4 = vec4( - 1, - 0.0275, - 0.572, 0.022 ); + let c1:vec4 = vec4( 1, 0.0425, 1.04, - 0.04 ); + let r:vec4 = roughness * c0 + c1; + let a004:f32 = min( r.x * r.x, exp2( - 9.28 * dotNV ) ) * r.x + r.y; + let fab:vec2 = vec2( - 1.04, 1.04 ) * a004 + r.zw; + return specularColor * fab.x + fab.y; + } + //间接光照 + fn indirectDiffuse_Physical(geometry:Geometry, material:PhysicalMaterial )->ReflectedLight { + var reflectedLight:ReflectedLight; + var irradiance:vec3 = lightUniforms.ambient.xyz*lightUniforms.ambient.w; + irradiance *= PI; + reflectedLight.indirectDiffuse += irradiance * BRDF_Lambert( material.diffuseColor ); + return reflectedLight; + } + //间接高光 + fn indirectSpecular_Physical(geometry:Geometry, material:PhysicalMaterial)->ReflectedLight { + var reflectedLight:ReflectedLight; + // IBL specular + let radiance:vec3 = getLightProbeRadiance(geometry.viewDir, geometry.normal, material.roughness); + let radianceAttenuation:f32 = 1.0; + reflectedLight.indirectSpecular += radianceAttenuation * radiance * DFGApprox(material.specularColor, material.roughness, geometry.dotNV ); + return reflectedLight; + } + `; +} - @location(${defines.morphTarget6Location}) morphTarget6:vec3, +function pbrFunction(defines) { + return wgslParseDefines` - @location(${defines.morphTarget7Location}) morphTarget7:vec3, - #endif - #endif - #if ${defines.USE_SKINNING} - @location(${defines.skinIndexLocation}) skinIndex:vec4, - @location(${defines.skinWeightLocation}) skinWeight:vec4, - #endif - } + #if ${defines.DITHERING} + fn dithering(color:vec3 )->vec3 { + let grid_position:f32 = rand( gl_FragCoord.xy ); + let dither_shift_RGB:vec3 = vec3( 0.25 / 255.0, -0.25 / 255.0, 0.25 / 255.0 ); + dither_shift_RGB = mix( 2.0 * dither_shift_RGB, -2.0 * dither_shift_RGB, grid_position ); + return color + dither_shift_RGB; + } + #endif - #if ${defines.MORPHTARGETS_TEXTURE} - fn getMorph( vertexIndex:u32, morphTargetIndex:u32,offset:u32 )->vec4 { - let texelIndex:u32 = vertexIndex * MORPHTARGETS_TEXTURE_STRIDE + offset; - let y:u32 = texelIndex / materialUniform.morphTargetsTextureSize.x; - let x:u32 = texelIndex - y * materialUniform.morphTargetsTextureSize.x; - let morphUV:vec3 = vec3( x, y, morphTargetIndex ); - //textureLoad - //return texelFetch( morphTargetsTexture, morphUV, 0 ); - return textureLoad( morphTargetsTexture, morphUV, 0 ); + #if ${defines.USE_IRIDESCENCE} + fn BRDF_GGX_Iridescence( lightDir:vec3, viewDir:vec3,normal:vec3, f0:vec3, f90:f32,iridescence:f32, iridescenceFresnel:vec3,roughness:f32 )->vec3 { + let alpha:f32 = pow2( roughness ); + let halfDir:vec3 = normalize( lightDir + viewDir ); + let dotNL:f32 = saturate( dot( normal, lightDir ) ); + let dotNV:f32 = saturate( dot( normal, viewDir ) ); + let dotNH:f32 = saturate( dot( normal, halfDir ) ); + let dotVH:f32 = saturate( dot( viewDir, halfDir ) ); + let F:vec3 = mix( F_Schlick( f0, f90, dotVH ), iridescenceFresnel, iridescence ); + let V:f32 = V_GGX_SmithCorrelated( alpha, dotNL, dotNV ); + let D:f32 = D_GGX( alpha, dotNH ); + return F * ( V * D ); } #endif - #if ${defines.USE_SKINNING} - fn getBoneMatrix( i:f32 )->mat4x4 { - let j:f32 = i * 4.0; - let x:f32 = j%f32( materialUniform.boneTextureSize ); - let y:f32 = floor( j / f32( materialUniform.boneTextureSize ) ); - let dx:f32 = 1.0 / f32( materialUniform.boneTextureSize ); - let dy:f32 = 1.0 / f32( materialUniform.boneTextureSize ); - y = dy * ( y + 0.5 ); - - let v1:vec4 = textureSample(boneTexture, baseSampler, vec2( dx * ( x + 0.5 ), y ) ); - let v2:vec4 = textureSample(boneTexture, baseSampler, vec2( dx * ( x + 1.5 ), y ) ); - let v3:vec4 = textureSample(boneTexture, baseSampler, vec2( dx * ( x + 2.5 ), y ) ); - let v4:vec4 = textureSample(boneTexture, baseSampler, vec2( dx * ( x + 3.5 ), y ) ); - let bone:mat4x4 = mat4x4( v1, v2, v3, v4 ); - return bone; + + #if ${defines.USE_SHEEN} + fn D_Charlie( roughness:f32,dotNH:f32 )->f32 { + let alpha:f32 = pow2( roughness ); + let invAlpha:f32 = 1.0 / alpha; + let cos2h:f32 = dotNH * dotNH; + let sin2h:f32 = max( 1.0 - cos2h, 0.0078125 ); + return ( 2.0 + invAlpha ) * pow( sin2h, invAlpha * 0.5 ) / ( 2.0 * PI ); + } + fn V_Neubelt( dotNV:f32, dotNL:f32 )->f32 { + return saturate( 1.0 / ( 4.0 * ( dotNL + dotNV - dotNL * dotNV ) ) ); + } + fn BRDF_Sheen(lightDir:vec3, viewDir:vec3, normal:vec3,sheenColor:vec3,sheenRoughness:f32 )->vec3 { + let halfDir:vec3 = normalize( lightDir + viewDir ); + let dotNL:f32 = saturate( dot( normal, lightDir ) ); + let dotNV:f32 = saturate( dot( normal, viewDir ) ); + let dotNH:f32 = saturate( dot( normal, halfDir ) ); + let D:f32 = D_Charlie( sheenRoughness, dotNH ); + let V:f32 = V_Neubelt( dotNV, dotNL ); + return sheenColor * ( D * V ); } #endif - @binding(0) @group(0) var materialUniform : MaterialUniform; - @binding(0) @group(1) var globalUniform : GlobalUniform; - @vertex - fn main(input:VertexInput)->VertexOutput { - var vertexOutput:VertexOutput; - #if ${defines.USE_TEXTURE} - vertexOutput.vUv = input.uv; - #endif - #if ${defines.USE_LIGHTTEXTURE || defines.USE_AOTEXTURE} - vertexOutput.vUv2 input.uv2; - #endif - #if ${defines.USE_COLOR_ALPHA} - vertexOutput.vColor = vec4( 1.0 ); - #elif ${defines.USE_COLOR || defines.USE_INSTANCING_COLOR} - vertexOutput.vColor = vec3( 1.0 ); - #endif - #if ${defines.USE_COLOR} - vertexOutput.vColor *= input.color; - #endif - #if ${defines.USE_INSTANCING_COLOR} - vertexOutput.vColor.xyz *= input.instanceColor.xyz; - #endif - #if ${defines.USE_MORPHCOLORS && defines.MORPHTARGETS_TEXTURE} - vertexOutput.vColor *= materialUniform.morphTargetBaseInfluence; - for (let i : u32 = 0u; i < materialUniform.MORPHTARGETS_COUNT; i = i + 1u ) { - #if ${defines.USE_COLOR_ALPHA} - if ( materialUniform.morphTargetInfluences[ i ] ! = 0.0 ) vertexOutput.vColor += getMorph( gl_VertexID, i, 2 ) * materialUniform.morphTargetInfluences[ i ]; - #elif ${defines.USE_COLOR} - if ( materialUniform.morphTargetInfluences[ i ] ! = 0.0 ) vertexOutput.vColor += getMorph( gl_VertexID, i, 2 ).rgb * materialUniform.morphTargetInfluences[ i ]; - #endif + #if ${defines.USE_IRIDESCENCE} + let XYZ_TO_REC709: mat3x3 = mat3x3( + 3.2404542, -0.9692660, 0.0556434, -1.5371385, 1.8760108, -0.2040259, -0.4985314, 0.0415560, 1.0572252 + ); + fn Fresnel0ToIor( fresnel0:vec3 )->vec3 { + let sqrtF0:vec3 = sqrt( fresnel0 ); + return ( vec3( 1.0 ) + sqrtF0 ) / ( vec3( 1.0 ) - sqrtF0 ); + } + fn IorToFresnel0(transmittedIor:vec3,incidentIor:f32 )->vec3 { + return pow2Vector( ( transmittedIor - vec3( incidentIor ) ) / ( transmittedIor + vec3( incidentIor ) ) ); + } + fn IorToFresnel0(transmittedIor:f32, incidentIor:f32 )->f32 { + return pow2Vector( ( transmittedIor - incidentIor ) / ( transmittedIor + incidentIor )); + } + fn evalSensitivity(OPD:f32,shift:vec3 )->vec3 { + let phase:f32 = 2.0 * PI * OPD * 1.0e-9; + let val:vec3 = vec3( 5.4856e-13, 4.4201e-13, 5.2481e-13 ); + let pos:vec3 = vec3( 1.6810e+06, 1.7953e+06, 2.2084e+06 ); + let vart:vec3 = vec3( 4.3278e+09, 9.3046e+09, 6.6121e+09 ); + let xyz:vec3 = val * sqrt( 2.0 * PI * vart ) * cos( pos * phase + shift ) * exp( - pow2( phase ) * vart ); + xyz.x += 9.7470e-14 * sqrt( 2.0 * PI * 4.5282e+09 ) * cos( 2.2399e+06 * phase + shift[ 0 ] ) * exp( - 4.5282e+09 * pow2( phase ) ); + xyz /= 1.0685e-7; + let rgb:vec3 = XYZ_TO_REC709 * xyz; + return rgb; + } + fn evalIridescence(outsideIOR:f32, eta2:f32,cosTheta1:f32,thinFilmThickness:f32,baseF0:vec3 )->vec3 { + var I:vec3; + let iridescenceIOR:f32 = mix( outsideIOR, eta2, smoothstep( 0.0, 0.03, thinFilmThickness ) ); + let sinTheta2Sq:f32 = pow2( outsideIOR / iridescenceIOR ) * ( 1.0 - pow2( cosTheta1 ) ); + let cosTheta2Sq:f32 = 1.0 - sinTheta2Sq; + if ( cosTheta2Sq < 0.0 ) { + return vec3( 1.0 ); } - #endif - var objectNormal:vec3 = vec3(input.normal); - #if ${defines.USE_TANGENT} - let objectTangent:vec3 = vec3( input.tangent.xyz ); - #endif - #if ${defines.USE_MORPHNORMALS} - objectNormal *= materialUniform.morphTargetBaseInfluence; - #if ${defines.MORPHTARGETS_TEXTURE} - for ( let i : u32 = 0u; i < materialUniform.MORPHTARGETS_COUNT; i = i + 1u) { - if ( materialUniform.morphTargetInfluences[ i ] ! = 0.0 ) objectNormal += getMorph( gl_VertexID, i, 1 ).xyz * materialUniform.morphTargetInfluences[ i ]; - } - #else - objectNormal += morphNormal0 * materialUniform.morphTargetInfluences[ 0 ]; - objectNormal += morphNormal1 * materialUniform.morphTargetInfluences[ 1 ]; - objectNormal += morphNormal2 * materialUniform.morphTargetInfluences[ 2 ]; - objectNormal += morphNormal3 * materialUniform.morphTargetInfluences[ 3 ]; - #endif - #endif - #if ${defines.USE_SKINNING} - let boneMatX:mat4x4 = getBoneMatrix( input.skinIndex.x ); - let boneMatY:mat4x4 = getBoneMatrix( input.skinIndex.y ); - let boneMatZ:mat4x4 = getBoneMatrix( input.skinIndex.z ); - let boneMatW:mat4x4 = getBoneMatrix( input.skinIndex.w ); - #endif - #if ${defines.USE_SKINNING} - let skinMatrix:mat4x4 = mat4x4( 0.0 ); - skinMatrix += input.skinWeight.x * boneMatX; - skinMatrix += input.skinWeight.y * boneMatY; - skinMatrix += input.skinWeight.z * boneMatZ; - skinMatrix += input.skinWeight.w * boneMatW; - skinMatrix = materialUniform.bindMatrixInverse * skinMatrix * materialUniform.bindMatrix; - objectNormal = vec4( skinMatrix * vec4( objectNormal, 0.0 ) ).xyz; - #if ${defines.USE_TANGENT} - objectTangent = vec4( skinMatrix * vec4( objectTangent, 0.0 ) ).xyz; - #endif - #endif - var transformedNormal:vec3 = objectNormal; - // transformedNormal+=vec3(0.0); - #if ${defines.USE_INSTANCING} - let m:mat3x3 = mat3x3( input.instanceMatrix ); - transformedNormal /= vec3( dot( m[ 0 ], m[ 0 ] ), dot( m[ 1 ], m[ 1 ] ), dot( m[ 2 ], m[ 2 ] ) ); - transformedNormal = m * transformedNormal; - #endif - transformedNormal = materialUniform.normalMatrix * transformedNormal; - #if ${defines.FLIP_SIDED} - transformedNormal = - transformedNormal; - #endif - #if ${defines.USE_TANGENT} - let transformedTangent:vec3 = (globalUniform.viewMatrix*materialUniform.modelMatrix * vec4( objectTangent, 0.0 ) ).xyz; - #if ${defines.FLIP_SIDED} - transformedTangent = - transformedTangent; - #endif - #endif - vertexOutput.vNormal = normalize( transformedNormal ); - #if ${defines.FLAT_SHADED} - #if ${defines.USE_TANGENT} - vTangent = normalize( transformedTangent ); - vBitangent = normalize( cross( vNormal, vTangent ) * input.tangent.w ); - #endif - #endif - let transformed:vec3 = vec3( input.position ); - #if ${defines.USE_MORPHTARGETS} - transformed *= materialUniform.morphTargetBaseInfluence; - #if ${defines.MORPHTARGETS_TEXTURE} - for ( let i : u32 = 0u; i < materialUniform.MORPHTARGETS_COUNT; i = i + 1u ) { - if ( materialUniform.morphTargetInfluences[ i ] ! = 0.0 ) transformed += getMorph( gl_VertexID, i, 0 ).xyz * morphTargetInfluences[ i ]; - } - #else - transformed += input.morphTarget0 * materialUniform.morphTargetInfluences[ 0 ]; - transformed += input.morphTarget1 * materialUniform.morphTargetInfluences[ 1 ]; - transformed += input.morphTarget2 * materialUniform.morphTargetInfluences[ 2 ]; - transformed += input.morphTarget3 * materialUniform.morphTargetInfluences[ 3 ]; - #if ${defines.USE_MORPHNORMALS} - transformed += input.morphTarget4 * materialUniform.morphTargetInfluences[ 4 ]; - transformed += input.morphTarget5 * materialUniform.morphTargetInfluences[ 5 ]; - transformed += input.morphTarget6 * materialUniform.morphTargetInfluences[ 6 ]; - transformed += input.morphTarget7 * materialUniform.morphTargetInfluences[ 7 ]; - #endif - #endif - #endif - #if ${defines.USE_SKINNING} - let skinVertex:vec4 = materialUniform.bindMatrix * vec4( transformed, 1.0 ); - let skinned:vec4 = vec4( 0.0 ); - skinned += boneMatX * skinVertex * input.skinWeight.x; - skinned += boneMatY * skinVertex * input.skinWeight.y; - skinned += boneMatZ * skinVertex * input.skinWeight.z; - skinned += boneMatW * skinVertex * input.skinWeight.w; - transformed = ( materialUniform.bindMatrixInverse * skinned ).xyz; - #endif - #if ${defines.USE_DISPLACEMENTTEXTURE} - transformed += normalize( objectNormal ) * (textureSample(displacementMap, baseSampler, vUv).x * materialUniform.displacementScale + materialUniform.displacementBias ); - #endif - var mvPosition:vec4 = vec4( transformed, 1.0 ); - #if ${defines.USE_INSTANCING} - mvPosition = input.instanceMatrix * mvPosition; - #endif - mvPosition = globalUniform.viewMatrix*materialUniform.modelMatrix * mvPosition; - vertexOutput.position = globalUniform.projectionMatrix * mvPosition; - vertexOutput.vViewPosition = - mvPosition.xyz/mvPosition.w; - #if ${defines.USE_ENVTEXTURE || defines.DISTANCE || defines.USE_TRANSMISSION} - var worldPosition:vec4 = vec4( transformed, 1.0 ); - #if ${defines.USE_INSTANCING} - worldPosition = input.instanceMatrix * worldPosition; - #endif - worldPosition = materialUniform.modelMatrix * worldPosition; - #endif - #if ${defines.USE_TRANSMISSION} - vertexOutput.vWorldPosition = worldPosition.xyz; - #endif - return vertexOutput; + let cosTheta2:f32 = sqrt( cosTheta2Sq ); + let R0:f32 = IorToFresnel0( iridescenceIOR, outsideIOR ); + let R12:f32 = F_Schlick( R0, 1.0, cosTheta1 ); + let R21:f32 = R12; + let T121:f32 = 1.0 - R12; + let phi12:f32 = 0.0; + if ( iridescenceIOR < outsideIOR ) phi12 = PI; + let phi21:f32 = PI - phi12; + let baseIOR:vec3 = Fresnel0ToIor( clamp( baseF0, 0.0, 0.9999 ) ); + let R1:vec3 = IorToFresnel0( baseIOR, iridescenceIOR ); + let R23:vec3 = F_Schlick( R1, 1.0, cosTheta2 ); + let phi23:vec3 = vec3( 0.0 ); + if ( baseIOR[ 0 ] < iridescenceIOR ) phi23[ 0 ] = PI; + if ( baseIOR[ 1 ] < iridescenceIOR ) phi23[ 1 ] = PI; + if ( baseIOR[ 2 ] < iridescenceIOR ) phi23[ 2 ] = PI; + let OPD:f32 = 2.0 * iridescenceIOR * thinFilmThickness * cosTheta2; + let phi:vec3 = vec3( phi21 ) + phi23; + let R123:vec3 = clamp( R12 * R23, 1e-5, 0.9999 ); + let r123:vec3 = sqrt( R123 ); + let Rs:vec3 = pow2( T121 ) * R23 / ( vec3( 1.0 ) - R123 ); + let C0:vec3 = R12 + Rs; + I = C0; + let Cm:vec3 = Rs - T121; + for ( let m : u32 = 1;m <= 2; ++ m ) { + Cm *= r123; + Sm:vec3 = 2.0 * evalSensitivity( f32( m ) * OPD, f32( m ) * phi ); + I += Cm * Sm; + } + return max( I, vec3( 0.0 ) ); + } + #endif + const clearcoatSpecular:vec3 = vec3( 0.0 ); + const sheenSpecular:vec3 = vec3( 0.0 ); + + fn IBLSheenBRDF( normal:vec3, viewDir:vec3, roughness:f32 )->f32 { + let dotNV:f32 = saturate( dot( normal, viewDir ) ); + let r2:f32 = roughness * roughness; + let a:f32 =select(-8.48 * r2 + 14.3 * roughness - 9.95,-339.2 * r2 + 161.4 * roughness - 25.9,roughness < 0.25); + //let a:f32 = roughness < 0.25 ? -339.2 * r2 + 161.4 * roughness - 25.9 : -8.48 * r2 + 14.3 * roughness - 9.95; + let b:f32=select(1.97 * r2 - 3.27 * roughness + 0.72,44.0 * r2 - 23.7 * roughness + 3.26, roughness < 0.25); + //let b:f32 = roughness < 0.25 ? 44.0 * r2 - 23.7 * roughness + 3.26 : 1.97 * r2 - 3.27 * roughness + 0.72; + //let DG:f32 = exp( a * dotNV + b ) + ( roughness < 0.25 ? 0.0 : 0.1 * ( roughness - 0.25 ) ); + let DG:f32 = exp( a * dotNV + b ) + select(0.1 * ( roughness - 0.25 ),0.0,roughness < 0.25); + return saturate( DG * RECIPROCAL_PI ); + } + fn DFGApprox( specularColor:vec3, roughness:f32,dotNV:f32 )->vec3 { + const c0:vec4 = vec4( - 1, - 0.0275, - 0.572, 0.022 ); + let c1:vec4 = vec4( 1, 0.0425, 1.04, - 0.04 ); + let r:vec4 = roughness * c0 + c1; + let a004:f32 = min( r.x * r.x, exp2( - 9.28 * dotNV ) ) * r.x + r.y; + let fab:vec2 = vec2( - 1.04, 1.04 ) * a004 + r.zw; + return specularColor * fab.x + fab.y; + } + fn EnvironmentBRDF( normal:vec3,viewDir:vec3,specularColor:vec3, specularF90:f32,roughness:f32 )->vec3 { + let fab:vec2 = DFGApprox( normal, viewDir, roughness ); + return specularColor * fab.x + specularF90 * fab.y; } - `; -} -function skyBoxFrag(defines) { - return ` - fn lessThanEqual(a:vec3,b:vec3)->vec3{ - let xValue:f32=select(b.x,a.x,a.x<=b.x); - let yValue:f32=select(b.y,a.y,a.y<=b.y); - let zValue:f32=select(b.z,a.z,a.z<=b.z); - return vec3(xValue,yValue,zValue); - } - fn LinearTosRGB( value:vec4 )->vec4 { - return vec4( mix( pow( value.rgb, vec3( 0.41666 ) ) * 1.055 - vec3( 0.055 ), value.rgb * 12.92, vec3( lessThanEqual( value.rgb, vec3( 0.0031308 ) ) ) ), value.a ); + + fn computeSpecularOcclusion( dotNV:f32, ambientOcclusion:f32, roughness:f32 )->f32 { + return saturate( pow( dotNV + ambientOcclusion, exp2( - 16.0 * roughness - 1.0 ) ) - 1.0 + ambientOcclusion ); } - struct FragmentInput { - @location(0) texCoord : vec3 - }; - @group(0) @binding(2) var defaultSampler: sampler; - @group(0) @binding(1) var skyboxTexture: texture_cube; - @fragment - fn main(input : FragmentInput) -> @location(0) vec4 { - let color = textureSample(skyboxTexture, defaultSampler, input.texCoord); - return LinearTosRGB(color); - } -`; -} + #if ${defines.USE_TRANSMISSION} -function skyBoxVert(defines) { - return ` - struct SystemUniform { - projectionMatrix: mat4x4, - viewMatrix: mat4x4, - inverseViewMatrix: mat4x4, - cameraPosition: vec3, - }; - struct MaterialUniform { - modelMatrix: mat4x4, - } - @binding(${defines.skyboxBinding}) @group(0) var selfUniform : MaterialUniform; - @binding(${defines.cameraBinding}) @group(1) var systemUniform : SystemUniform; - struct VertexInput { - @location(${defines.positionLocation}) position : vec3, - }; - struct VertexOutput { - @builtin(position) position : vec4, - @location(0) texCoord : vec3, - }; - @vertex - fn main(input : VertexInput) -> VertexOutput { - var output : VertexOutput; - output.texCoord = input.position.xyz; - var modelView = systemUniform.viewMatrix; - // Drop the translation portion of the modelView matrix - modelView[3] = vec4(0.0, 0.0, 0.0, modelView[3].w); - output.position = systemUniform.projectionMatrix * modelView * vec4(input.position,1.0); - output.position = output.position.xyww; - return output; - } - `; -} + fn getVolumeTransmissionRay( n:vec3, v:vec3, thickness:f32, ior:f32, modelMatrix:mat4x4:f32)->vec3 { + var refractionVector:vec3 = refract( - v, normalize( n ), 1.0 / ior ); + var modelScale:vec3; + modelScale.x = length( vec3( modelMatrix[0].xyz ) ); + modelScale.y = length( vec3( modelMatrix[1].xyz ) ); + modelScale.z = length( vec3( modelMatrix[2].xyz ) ); + return normalize( refractionVector ) * thickness * modelScale; + } + fn applyIorToRoughness(roughness:f32, ior:f32 )->f32 { + return roughness * clamp( ior * 2.0 - 2.0, 0.0, 1.0 ); + } + fn getTransmissionSample( fragCoord:vec2, roughness:f32,ior:f32 )->vec4 { + let framebufferLod:f32 = log2( materialUniform.transmissionSamplerSize.x ) * applyIorToRoughness( roughness, ior ); + return textureSampleLevel(transmissionSamplerTexture,baseSampler,fragCoord.xy, framebufferLod); -function quadFrag(defines) { - return ` - @group(0) @binding(1) var baseSampler: sampler; - @group(0) @binding(0) var colorTexture: texture_2d; - struct VertexOutput { - @builtin(position) position: vec4, - @location(0) uv: vec2, - }; - @fragment - fn main(input:VertexOutput) -> @location(0) vec4 { - return textureSample(colorTexture, baseSampler, vec2(input.uv.x,1.0-input.uv.y)); } - `; -} + fn applyVolumeAttenuation( radiance:vec3, transmissionDistance:f32,attenuationColor:vec3,attenuationDistance:f32 )->vec3 { + if ( isinf( attenuationDistance ) ) { + return radiance; + } + else { + let attenuationCoefficient:vec3 = -log( attenuationColor ) / attenuationDistance; + let transmittance:vec3 = exp( - attenuationCoefficient * transmissionDistance ); + return transmittance * radiance; + } + + } + fn getIBLVolumeRefraction( n:vec3,v:vec3, roughness:f32, diffuseColor:vec3,specularColor:vec3, specularF90:f32,position:vec3, modelMatrix:mat4x4, viewMatrix:mat4x4,projMatrix:mat4x4,ior:f32, thickness:f32,attenuationColor:vec3,attenuationDistance:f32 )->vec4 { + let transmissionRay:vec3 = getVolumeTransmissionRay( n, v, thickness, ior, modelMatrix ); + let refractedRayExit:vec3 = position + transmissionRay; + let ndcPos:vec4 = projMatrix * viewMatrix * vec4( refractedRayExit, 1.0 ); + let refractionCoords:vec2 = ndcPos.xy / ndcPos.w; + refractionCoords += 1.0; + refractionCoords /= 2.0; + let transmittedLight:vec4 = getTransmissionSample( refractionCoords, roughness, ior ); + let attenuatedColor:vec3 = applyVolumeAttenuation( transmittedLight.rgb, length( transmissionRay ), attenuationColor, attenuationDistance ); + let F:vec3 = EnvironmentBRDF( n, v, specularColor, specularF90, roughness ); + return vec4( ( 1.0 - F ) * attenuatedColor * diffuseColor, transmittedLight.a ); + } + #endif -function quadVert(defines) { - return ` - struct VertexInput { - @location(${defines.positionLocation}) position: vec2, + #if ${defines.USE_BUMPTEXTURE} + fn dHdxy_fwd()->vec2 { + let dSTdx:vec2 = dpdx( vUv ); + let dSTdy:vec2 = dpdy( vUv ); + + let Hll:f32 = materialUniform.bumpScale * textureSample(bumpTexture, baseSampler, vUv).x; + let dBx:f32 = materialUniform.bumpScale * textureSample(bumpTexture, baseSampler, vUv + dSTdx).x - Hll; + let dBy:f32 = materialUniform.bumpScale * textureSample(bumpTexture, baseSampler, vUv + dSTdy).x - Hll; + return vec2( dBx, dBy ); + } + fn perturbNormalArb( surf_pos:vec3, surf_norm:vec3, dHdxy:vec2, faceDirection:f32 )->vec3 { + let vSigmaX:vec3 = dpdx( surf_pos.xyz ); + let vSigmaY:vec3 = dpdy( surf_pos.xyz ); + let vN:vec3 = surf_norm; + let R1:vec3 = cross( vSigmaY, vN ); + let R2:vec3 = cross( vN, vSigmaX ); + let fDet:f32 = dot( vSigmaX, R1 ) * faceDirection; + let vGrad:vec3 = sign( fDet ) * ( dHdxy.x * R1 + dHdxy.y * R2 ); + return normalize( abs( fDet ) * surf_norm - vGrad ); + } + #endif + + //! defined ( USE_TANGENT ) && ( defined ( TANGENTSPACE_NORMALTEXTURE ) || defined ( USE_CLEARCOAT_NORMALTEXTURE ) ) + #if ${(!defines.USE_TANGENT && defines.TANGENTSPACE_NORMALTEXTURE) || defines.USE_CLEARCOAT_NORMALTEXTURE} + fn perturbNormal2Arb( eye_pos:vec3, surf_norm:vec3, textureN:vec3, faceDirection:f32 )->vec3 { + let q0:vec3 = dpdx( eye_pos.xyz ); + let q1:vec3 = dpdy( eye_pos.xyz ); + let st0:vec2 = dpdx( vUv.st ); + let st1:vec2 = dpdy( vUv.st ); + let N:vec3 = surf_norm; + let q1perp:vec3 = cross( q1, N ); + let q0perp:vec3 = cross( N, q0 ); + let T:vec3 = q1perp * st0.x + q0perp * st1.x; + let B:vec3 = q1perp * st0.y + q0perp * st1.y; + let det:f32 = max( dot( T, T ), dot( B, B ) ); + let scale:f32 = ( det == 0.0 ) ? 0.0 : faceDirection * inversesqrt( det ); + return normalize( T * ( textureN.x * scale ) + B * ( textureN.y * scale ) + N * textureN.z ); } - struct VertexOutput { - @builtin(position) position: vec4, - @location(0) uv: vec2, - }; - @vertex - fn main(input: VertexInput) -> VertexOutput { - var output:VertexOutput; - output.uv = input.position * 0.5 + 0.5; - output.position = vec4(input.position, 0.0, 1.0);; - return output; + #endif + struct MultiAndSingleScatter{ + multiScatter:vec3, + singleScatter:vec3 } - `; -} + #if ${defines.USE_IRIDESCENCE} + ////////inout vec3 singleScatter, inout vec3 multiScatter + fn computeMultiscatteringIridescence( normal:vec3, viewDir:vec3, specularColor:vec3, specularF90:f32, iridescence:f32,iridescenceF0:vec3, roughness:f32 )->MultiAndSingleScatter { + #else + ////////inout vec3 singleScatter, inout vec3 multiScatter + fn computeMultiscattering( normal:vec3,viewDir:vec3, specularColor:vec3, specularF90:f32, roughness:f32)->MultiAndSingleScatter { + #endif + let fab:vec2 = DFGApprox( normal, viewDir, roughness ); + + var multiAndSingleScatter:MultiAndSingleScatter; + + #if ${defines.USE_IRIDESCENCE} + let Fr:vec3 = mix( specularColor, iridescenceF0, iridescence ); + #else + let Fr:vec3 = specularColor; + #endif + let FssEss:vec3 = Fr * fab.x + specularF90 * fab.y; + let Ess:f32 = fab.x + fab.y; + let Ems:f32 = 1.0 - Ess; + let Favg:vec3 = Fr + ( 1.0 - Fr ) * 0.047619; + let Fms:vec3 = FssEss * Favg / ( 1.0 - Ems * Favg ); + // singleScatter += FssEss; + // multiScatter += Fms * Ems; + multiAndSingleScatter.multiScatter=Fms * Ems; + multiAndSingleScatter.singleScatter=FssEss; + return multiAndSingleScatter; + } + //直接光照 + fn RE_Direct_Physical( directLight:IncidentLight, geometry:GeometricContext, material:PhysicalMaterial)->ReflectedLight { + var reflectedLight:ReflectedLight; + let dotNL:f32 = saturate(dot( geometry.normal, directLight.direction)); + let irradiance:vec3 = dotNL * directLight.color; + #if ${defines.USE_CLEARCOAT} + let dotNLcc:f32 = saturate( dot( geometry.clearcoatNormal, directLight.direction ) ); + let ccIrradiance:vec3 = dotNLcc * directLight.color; + clearcoatSpecular += ccIrradiance * BRDF_GGX( directLight.direction, geometry.viewDir, geometry.clearcoatNormal, material.clearcoatF0, material.clearcoatF90, material.clearcoatRoughness ); + #endif -function pbr_vs(defines) { - return wgslParseDefines` - #include - #include - #include - #include - #include - #include - @binding(${defines.pbrBinding}) @group(0) var materialUniform : MaterialUniform; - @binding(${defines.cameraBinding}) @group(1) var systemUniform : SystemUniform; - @vertex - fn main(input: VertexInput)-> VertexOutput - { - var output: VertexOutput; - #if ${defines.HAS_UV} - output.uv = input.uv; - #endif - var modelMatrix:mat4x4; - var vNormalView:vec3; - vNormalView = normalize(materialUniform.normalMatrix * vec4(input.normal,0.0)).xyz; - modelMatrix=materialUniform.modelMatrix; - #include - #include - output.normal = vNormalView.xyz; - output.position = systemUniform.projectionMatrix * systemUniform.viewMatrix *modelMatrix* vec4(input.position, 1.0); - let modelPos=modelMatrix *vec4(input.position,1.0); - output.worldPos = modelPos.xyz/modelPos.w; - return output; + #if ${defines.USE_SHEEN} + sheenSpecular += irradiance * BRDF_Sheen( directLight.direction, geometry.viewDir, geometry.normal, material.sheenColor, material.sheenRoughness ); + #endif + + #if ${defines.USE_IRIDESCENCE} + reflectedLight.directSpecular = irradiance * BRDF_GGX_Iridescence( directLight.direction, geometry.viewDir, geometry.normal, material.specularColor, material.specularF90, material.iridescence, material.iridescenceFresnel, material.roughness ); + #else + reflectedLight.directSpecular = irradiance * BRDF_GGX( directLight.direction, geometry.viewDir, geometry.normal, material.specularColor, material.specularF90, material.roughness ); + #endif + reflectedLight.directDiffuse = irradiance * BRDF_Lambert( material.diffuseColor ); + return reflectedLight; + } + //间接光照 + fn RE_IndirectDiffuse_Physical( irradiance:vec3, geometry:GeometricContext, material:PhysicalMaterial )->ReflectedLight { + var reflectedLight:ReflectedLight; + reflectedLight.indirectDiffuse = irradiance * BRDF_Lambert( material.diffuseColor ); + return reflectedLight; + } + //间接高光 + fn RE_IndirectSpecular_Physical( radiance:vec3, irradiance:vec3, clearcoatRadiance:vec3, geometry:GeometricContext, material:PhysicalMaterial)->ReflectedLight { + var reflectedLight:ReflectedLight; + #if ${defines.USE_CLEARCOAT} + clearcoatSpecular += clearcoatRadiance * EnvironmentBRDF( geometry.clearcoatNormal, geometry.viewDir, material.clearcoatF0, material.clearcoatF90, material.clearcoatRoughness ); + #endif + #if ${defines.USE_SHEEN} + sheenSpecular += irradiance * material.sheenColor * IBLSheenBRDF( geometry.normal, geometry.viewDir, material.sheenRoughness ); + #endif + var singleScattering:vec3; + var multiScattering:vec3; + let cosineWeightedIrradiance:vec3 = irradiance * RECIPROCAL_PI; + var tempMultiAndSingleScatter:MultiAndSingleScatter; + #if ${defines.USE_IRIDESCENCE} + tempMultiAndSingleScatter=computeMultiscatteringIridescence( geometry.normal, geometry.viewDir, material.specularColor, material.specularF90, material.iridescence, material.iridescenceFresnel, material.roughness ); + #else + tempMultiAndSingleScatter= computeMultiscattering( geometry.normal, geometry.viewDir, material.specularColor, material.specularF90, material.roughness ); + #endif + singleScattering=tempMultiAndSingleScatter.singleScatter; + multiScattering=tempMultiAndSingleScatter.multiScatter; + let totalScattering:vec3 = singleScattering + multiScattering; + let diffuse:vec3 = material.diffuseColor * ( 1.0 - max( max( totalScattering.r, totalScattering.g ), totalScattering.b ) ); + reflectedLight.indirectSpecular = radiance * singleScattering; + reflectedLight.indirectSpecular = multiScattering * cosineWeightedIrradiance; + reflectedLight.indirectDiffuse = diffuse * cosineWeightedIrradiance; + return reflectedLight; } `; } -function pbr_fs(defines) { +function pbrStruct(defines) { return wgslParseDefines` - // reference: https://github.com/KhronosGroup/glTF-WebGL-PBR/blob/master/shaders/pbr-frag.glsl - #include - #include - #include - #include - #include - #include - struct PhysicalMaterial { - diffuseColor:vec3, + struct MaterialUniform{ + + modelMatrix: mat4x4, + + diffuse:vec3, + + opacity:f32, + + normalMatrix: mat3x3, + + emissive:vec3, + roughness:f32, - specularColor:vec3, - #if ${defines.USE_CLEARCOAT} - clearcoat:f32, - clearcoatRoughness:f32, - clearcoatF0:vec3, - clearcoatF90:f32, - #endif + + metalness:f32, + + #if ${defines.TONE_MAPPING} + toneMappingExposure:f32, + #endif + + #if ${defines.SPECULAR} + + specularColor:vec3, + + specularIntensity:f32, + #endif + + #if ${defines.USE_SHEEN} + + sheenColor:vec3, + + sheenRoughness:f32, + #endif - #if ${defines.USE_IRIDESCENCE} - iridescence:f32, - iridescenceIOR:f32, - iridescenceThickness:f32, - iridescenceFresnel:vec3, - iridescenceF0:vec3, - #endif + #if ${defines.USE_TRANSMISSION} + + attenuationColor:vec3, + + transmission:f32, + + transmissionSamplerSize:vec2, + + thickness:f32, + + attenuationDistance:f32, + + #endif - #if ${defines.USE_SHEEN} - sheenColor:vec3, - sheenRoughness:f32, - #endif + #if ${defines.USE_SKINNING} + + bindMatrix:mat4x4, + + bindMatrixInverse:mat4x4, + + boneTextureSize:u32, + #endif - #if ${defines.IOR} + #if ${defines.USE_NORMALTEXTURE} + normalScale:vec2, + #endif + + #if ${defines.IOR} ior:f32, - #endif + #endif + + #if ${defines.USE_CLEARCOAT} + + #if ${defines.USE_CLEARCOAT_NORMALTEXTURE} + clearcoatNormalScale:vec2, + #endif + + clearcoat:f32, + + clearcoatRoughness:f32, + #endif + + #if ${defines.USE_IRIDESCENCE} + iridescence:f32, + + iridescenceIOR:f32, + + iridescenceThicknessMinimum:f32, + + iridescenceThicknessMaximum:f32, + + #endif - #if ${defines.USE_TRANSMISSION} - transmission:f32, - transmissionAlpha:f32, - thickness:f32, - attenuationDistance:f32, - attenuationColor:vec3, - #endif - }; - const M_PI:f32 = 3.141592653589793; - const c_MinRoughness:f32 = 0.04; - @binding(${defines.pbrBinding}) @group(0) var materialUniform : MaterialUniform; - @binding(${defines.cameraBinding}) @group(1) var systemUniform : SystemUniform; - // IBL - #if ${defines.USE_IBL} - @group(0) @binding(${defines.specularEnvTextureBinding}) var specularEnvTexture: texture_cube; - @group(0) @binding(${defines.specularEnvSamplerBinding}) var specularEnvSampler: sampler; - #endif - #if ${defines.USE_TEXTURE} - @group(0) @binding(${defines.baseColorTextureBinding}) var baseColorTexture: texture_2d; - @group(0) @binding(${defines.baseColorSamplerBinding}) var baseColorSampler: sampler; - #endif - // normal map - #if ${defines.USE_NORMALTEXTURE} - @group(0) @binding(${defines.normalTextureBinding}) var normalTexture: texture_2d; - @group(0) @binding(${defines.normalSamplerBinding}) var normalSampler: sampler; - #endif - // emmisve map - #if ${defines.USE_EMISSIVETEXTURE} - @group(0) @binding(${defines.emissiveTextureBinding}) var emissiveTexture: texture_2d; - @group(0) @binding(${defines.emissiveSamplerBinding}) var emissiveSampler: sampler; - #endif + #if ${defines.USE_AOTEXTURE} + aoTextureIntensity:f32, + #endif - // metal roughness - #if ${defines.USE_METALNESSTEXTURE} - @group(0) @binding(${ - defines.metalnessRoughnessTextureBinding - }) var metalnessRoughnessTexture: texture_2d; - @group(0) @binding(${defines.metalnessRoughnessSamplerBinding}) var metalnessRoughnessSampler: sampler; - #endif - // occlusion texture - #if ${defines.USE_AOTEXTURE} - @group(0) @binding(${defines.aoTextureBinding}) var aoTexture: texture_2d; - @group(0) @binding(${defines.aoSamplerBinding}) var aoSampler: sampler; - #endif - #if ${defines.USE_NORMALTEXTURE} - #include - #include - #else - #include - #endif - #if ${defines.USE_IBL} - #include - #endif - @fragment - fn main(input:FragInput) -> @location(0) vec4 - { - var perceptualRoughness:f32 = materialUniform.roughness; - var metallic:f32 = materialUniform.metallic; + #if ${defines.USE_LIGHTTEXTURE} + lightTextureIntensity:f32, + #endif + + #if ${defines.USE_ENVTEXTURE} + envTextureIntensity:f32, + + flipEnvTexture:f32, + #endif + + #if ${defines.USE_BUMPTEXTURE} + bumpScale:f32; + #endif + + #if ${defines.USE_DISPLACEMENTTEXTURE} + + displacementScale:f32, + + displacementBias:f32, + #endif + + #if ${defines.USE_MORPHTARGETS} + + morphTargetBaseInfluence:f32, + + #if ${defines.MORPHTARGETS_TEXTURE} + + morphTargetsTextureSize:vec2, + + MORPHTARGETS_COUNT:u32, + + #endif + + morphTargetInfluences:array, + + #endif + } + + `; +} +function pbrTexture(defines) { + return wgslParseDefines` + #if ${defines.USE_BUMPTEXTURE} + @group(0) @binding(${defines.bumpTextureBinding}) var bumpTexture: texture_2d; + #endif + #if ${defines.USE_TRANSMISSION} + #if ${defines.USE_TRANSMISSIONTEXTURE} + @group(0) @binding(${defines.transmissionTextureBinding}) var transmissionTexture: texture_2d; + #endif + #if ${defines.USE_THICKNESSTEXTURE} + @group(0) @binding(${defines.thicknessTextureBinding}) var thicknessTexture: texture_2d; + #endif + @group(0) @binding(${defines.transmissionSamplerTextureBinding}) var transmissionSamplerTexture: texture_2d; + #endif + #if ${defines.USE_ENVTEXTURE} + @group(0) @binding(${defines.envTextureBinding}) var envTexture: texture_cube; + #endif + #if ${defines.USE_NORMALTEXTURE} + @group(0) @binding(${defines.normalTextureBinding}) var normalTexture: texture_2d; + #endif + + #if ${defines.USE_CLEARCOATTEXTURE} + @group(0) @binding(${defines.clearcoatTextureBinding}) var clearcoatTexture: texture_2d; + #endif + + #if ${defines.USE_CLEARCOAT_ROUGHNESSTEXTURE} + @group(0) @binding(${defines.clearcoatRclearcoatRoughnessTextureBinding}) var clearcoatRoughnessTexture: texture_2d; + #endif + + #if ${defines.USE_CLEARCOAT_NORMALTEXTURE} + @group(0) @binding(${defines.clearcoatNormalTextureBinding}) var clearcoatNormalTexture: texture_2d; + #endif + + #if ${defines.USE_IRIDESCENCETEXTURE} + @group(0) @binding(${defines.iridescenceTextureBinding}) var iridescenceTexture: texture_2d; + #endif + + #if ${defines.USE_IRIDESCENCE_THICKNESSTEXTURE} + @group(0) @binding(${defines.iridescenceThicknessTextureBinding}) var iridescenceThicknessTexture: texture_2d; + #endif + + #if ${defines.USE_ROUGHNESSTEXTURE} + @group(0) @binding(${defines.roughnessTextureBinding}) var roughnessTexture: texture_2d; + #endif + #if ${defines.USE_METALNESSTEXTURE} - let mrSample:vec4 = textureSample(metalnessRoughnessTexture,metalnessRoughnessSampler, input.uv); - perceptualRoughness = mrSample.g * perceptualRoughness; - metallic = mrSample.b * metallic; + @group(0) @binding(${defines.metalnessTextureBinding}) var metalnessTexture: texture_2d; #endif - perceptualRoughness = clamp(perceptualRoughness, c_MinRoughness, 1.0); - metallic = clamp(metallic, 0.0, 1.0); - let alphaRoughness:f32 = perceptualRoughness * perceptualRoughness; + #if ${defines.SPECULAR} + #if ${defines.USE_SPECULARINTENSITYTEXTURE} + @group(0) @binding(${defines.specularIntensityTextureBinding}) var specularIntensityTexture: texture_2d; + #endif - // The albedo may be defined from a base texture or a flat color - #if ${defines.USE_TEXTURE} - let baseColor:vec4 = textureSample(baseColorTexture,baseColorSampler, input.uv) ; - #else - let baseColor:vec4 = vec4(materialUniform.color,1.0); + #if ${defines.USE_SPECULARCOLORTEXTURE} + @group(0) @binding(${defines.specularColorTextureBinding}) var specularColorTexture: texture_2d; + #endif #endif - #if ${defines.USE_NORMALTEXTURE} - let n:vec3 = getNormalByNormalTexture(input); - #else - let n:vec3 = getNormal(input); + #if ${defines.USE_SHEEN} + #if ${defines.USE_SHEENCOLORTEXTURE} + @group(0) @binding(${defines.sheenColorTextureBinding}) var sheenColorTexture: texture_2d; + #endif + #if ${defines.USE_SHEENROUGHNESSTEXTURE} + @group(0) @binding(${defines.sheenRoughnessTextureBinding}) var sheenRoughnessTexture: texture_2d; + #endif #endif - var material:PhysicalMaterial; - material.diffuseColor=baseColor.rgb*( 1.0 - metallic ); - material.roughness=perceptualRoughness; - material.specularColor=mix( vec3( 0.04), baseColor.rgb, metallic ); - var geometry:Geometry; - geometry.normal=n; - geometry.viewDir=normalize(systemUniform.cameraPosition - input.worldPos); - geometry.position=input.worldPos; - geometry.dotNV = saturate(dot(geometry.normal, geometry.viewDir) ); - //light shading - var reflectedLight=parseLights(geometry,material); - var color=reflectedLight.directDiffuse+reflectedLight.directSpecular; - //IBL - #if ${defines.USE_IBL && defines.HAS_UV} - var reflectedLightDiffuse=indirectDiffuse_Physical(geometry,material); - var reflectedLightSpecular=indirectSpecular_Physical(geometry,material); - color+=reflectedLightDiffuse.indirectDiffuse; - color+=reflectedLightSpecular.indirectSpecular; + + #if ${defines.USE_TEXTURE} + @group(0) @binding(${defines.baseSamplerBinding}) var baseSampler: sampler; + @group(0) @binding(${defines.baseTextureBinding}) var baseTexture: texture_2d; + #endif + + #if ${defines.USE_ALPHATEXTURE} + @group(0) @binding(${defines.alphaTextureBinding}) var alphaTexture: texture_2d; #endif + #if ${defines.USE_AOTEXTURE} - let ao:f32 = textureSample(aoTexture,aoSampler, input.uv).r; - color = mix(color, color * ao, materialUniform.occlusionStrength); + @group(0) @binding(${defines.aoTextureBinding}) var aoTexture: texture_2d; + + #endif + #if ${defines.USE_LIGHTTEXTURE} + @group(0) @binding(${defines.lightTextureBinding}) var lightTexture: texture_2d; #endif #if ${defines.USE_EMISSIVETEXTURE} - let emissive:vec3 = textureSample(emissiveTexture, emissiveSampler,input.uv).rgb ; - color += emissive; + @group(0) @binding(${defines.emissiveTextureBinding}) var emissiveTexture: texture_2d; #endif - return vec4(color, baseColor.a); + `; +} + +function pbrUtils(defines) { + return wgslParseDefines` + const PI:f32= 3.141592653589793; + const PI2:f32= 6.283185307179586; + const PI_HALF:f32= 1.5707963267948966; + const RECIPROCAL_PI:f32= 0.3183098861837907; + const RECIPROCAL_PI2:f32= 0.15915494309189535; + const EPSILON:f32= 1e-6; + + fn pow2(x:f32 )->f32 { + return x*x; } - `; + fn pow2Vector(x:vec3 )->vec3 { + return x*x; + } + fn pow3( x:f32 )->f32 { + return x*x*x; + } + fn pow4( x:f32 )->f32 { + let x2:f32 = x*x; + return x2*x2; + } + fn max3( v:vec3 )->f32 { + return max( max( v.x, v.y ), v.z ); + } + fn average(v:vec3 )->f32 { + return dot( v, vec3( 0.3333333 ) ); + } + fn rand( uv:vec2 )->f32 { + let a:f32 = 12.9898; + let b:f32 = 78.233; + let c:f32 = 43758.5453; + let dt:f32 = dot( uv.xy, vec2( a, b ) ); + let sn:f32 = dt % PI; + return fract( sin( sn ) * c ); + } + fn transformDirection( dir:vec3, matrix:mat4x4 )->vec3 { + return normalize( ( matrix * vec4( dir, 0.0 ) ).xyz ); + } + + fn transposeMat3( m:mat3x3 )->mat3x3 { + var tmp:mat3x3; + tmp[ 0 ] = vec3( m[ 0 ].x, m[ 1 ].x, m[ 2 ].x ); + tmp[ 1 ] = vec3( m[ 0 ].y, m[ 1 ].y, m[ 2 ].y ); + tmp[ 2 ] = vec3( m[ 0 ].z, m[ 1 ].z, m[ 2 ].z ); + return tmp; + } + fn luminance( rgb:vec3 )->f32 { + let weights:vec3 = vec3(0.2126729, 0.7151522, 0.0721750 ); + return dot( weights, rgb ); + } + fn LinearToneMapping( color:vec3,toneMappingExposure:f32 )->vec3 { + return toneMappingExposure * color; + } + + fn ReinhardToneMapping( color:vec3,toneMappingExposure:f32 )->vec3 { + var tempColor:vec3; + tempColor=color; + tempColor *= toneMappingExposure; + return saturate( tempColor / ( vec3( 1.0 ) + tempColor ) ); + } + fn CustomToneMapping( color:vec3 )->vec3 { + return color; + } + fn toneMapping( color:vec3,toneMappingExposure:f32 )->vec3 { + return ReinhardToneMapping( color,toneMappingExposure ); + } + + fn LinearToLinear( value:vec4 )->vec4 { + return value; + } + fn lessThanEqual(a:vec3,b:vec3)->vec3{ + let xValue:f32=select(b.x,a.x,a.x<=b.x); + let yValue:f32=select(b.y,a.y,a.y<=b.y); + let zValue:f32=select(b.z,a.z,a.z<=b.z); + return vec3(xValue,yValue,zValue); + } + fn LinearTosRGB( value:vec4 )->vec4 { + return vec4( mix( pow( value.rgb, vec3( 0.41666 ) ) * 1.055 - vec3( 0.055 ), value.rgb * 12.92, vec3( lessThanEqual( value.rgb, vec3( 0.0031308 ) ) ) ), value.a ); + } + fn linearToOutputTexel(value:vec4 )->vec4 { + return LinearTosRGB( value ); + } + `; +} + +function blinn_phong(defines) { + return ` + fn getPointLightInfo(pointLight:PointLight,worldPos:vec3,shininess:f32,N:vec3,V:vec3)->vec3{ + var color=vec3(0.0,0.0,0.0); + var direction:vec3 = worldPos - pointLight.position; + let dist:f32 = length( direction ); + direction = normalize(direction); + let decay = clamp(1.0 - pow(dist / pointLight.distance, 4.0), 0.0, 1.0); + + let d = max( dot( N, -direction ), 0.0 ) * decay; + color += pointLight.color * d; + + let halfDir:vec3 = normalize( V - direction ); + let s:f32 = pow( clamp( dot( N, halfDir ), 0.0, 1.0 ), shininess ) * decay; + color += pointLight.color * s; + return color; + } + fn getSpotLightInfo(spotLight:SpotLight,worldPos:vec3,shininess:f32,N:vec3,V:vec3)->vec3{ + var color=vec3(0.0,0.0,0.0); + var direction:vec3 = spotLight.position - worldPos; + let lightDistance:f32 = length(direction); + direction = normalize(direction); + let angleCos:f32 = dot( direction, -spotLight.direction ); + let decay:f32 = clamp(1.0 - pow(lightDistance/spotLight.distance, 4.0), 0.0, 1.0); + let spotEffect:f32 = smoothstep( spotLight.penumbraCos, spotLight.coneCos, angleCos ); + let decayTotal:f32 = decay * spotEffect; + let d:f32 = max( dot( N, direction ), 0.0 ) * decayTotal; + color += spotLight.color * d; + let halfDir:vec3 = normalize( V + direction ); + let s:f32 = pow( clamp( dot( N, halfDir ), 0.0, 1.0 ), shininess ) * decayTotal; + color += spotLight.color * s; + return color; + } + struct DirectionalLight { + direction: vec3, + color: vec3, + }; + fn getDirectLightInfo(directionalLight:DirectionalLight,shininess:f32,N:vec3,V:vec3)->vec3{ + var color=vec3(0.0,0.0,0.0); + let d:f32 = max(dot(N, -directionalLight.direction), 0.0); + color += directionalLight.color * d; + + let halfDir:vec3 = normalize( V - directionalLight.direction ); + let s:f32 = pow( clamp( dot( N, halfDir ), 0.0, 1.0 ), shininess ); + color += directionalLight.color * s; + return color; + } + `; } -function Blur(defines) { +function phongFunction(defines) { return ` - struct FragInput { - @location(0) uv: vec2, - } - struct BlurUniforms { - direction:vec2, - } - fn gaussianPdf(x:f32, sigma:f32)->f32 { - return 0.39894 * exp( -0.5 * x * x/( sigma * sigma))/sigma; - } - @group(0) @binding(0) var blurUniforms : BlurUniforms; - @group(0) @binding({{tDiffuseBinding}}) var tDiffuse: texture_2d; - @group(0) @binding({{tSamplerBinding}}) var tSampler: sampler; - @fragment - fn main(input:FragInput) -> @location(0) vec4 { - let invSize:vec2 = vec2(1.0,1.0) / vec2(textureDimensions(tDiffuse)); - let fSigma:f32 =f32(${defines.SIGMA}); - var weightSum:f32 = gaussianPdf(0.0, fSigma); - let baseColor=textureSample(tDiffuse, tSampler, input.uv); - var diffuseSum:vec3 = baseColor.rgb * weightSum; - let uvOffset:vec2 = blurUniforms.direction * invSize; - for( var i : u32 = 1; i < ${defines.KERNEL_RADIUS};i = i + 1 ) { - let x:f32 = f32(i); - let w:f32 = gaussianPdf(x, fSigma); - let sample1:vec3=textureSample(tDiffuse, tSampler, input.uv+ uvOffset*x).rgb; - let sample2:vec3=textureSample(tDiffuse, tSampler, input.uv- uvOffset*x).rgb; - diffuseSum =diffuseSum+ (sample2+sample2)* w; - weightSum += 2.0 * w; - } - diffuseSum/=weightSum; - return vec4(diffuseSum,baseColor.a); + fn G_BlinnPhong_Implicit( )->f32 { + + // geometry term is (n dot l)(n dot v) / 4(n dot l)(n dot v) + return 0.25; + } - `; -} + fn D_BlinnPhong( shininess:f32, dotNH:f32 )->f32 { + + return RECIPROCAL_PI * ( shininess * 0.5 + 1.0 ) * pow(dotNH, shininess); -function LuminosityHigh(defines) { - return ` - struct LuminosityUniforms{ - luminosityThreshold:f32, - smoothWidth:f32, - defaultColor:vec3, - defaultOpacity:f32, } - struct FragInput { - @location(0) uv: vec2, - }; - @group(0) @binding(0) var luminosityUniforms : LuminosityUniforms; - @group(0) @binding({{tDiffuseBinding}}) var tDiffuse: texture_2d; - @group(0) @binding({{tSamplerBinding}}) var tSampler: sampler; - @fragment - fn main(input:FragInput)-> @location(0) vec4 { + fn BRDF_BlinnPhong( lightDir:vec3, viewDir:vec3, normal:vec3, specularColor:vec3, shininess:f32 )->vec3 { - let texel:vec4 = textureSample(tDiffuse, tSampler, input.uv); + let halfDir = normalize( lightDir + viewDir ); - let luma:vec3 = vec3( 0.299,0.587,0.114 ); + let dotNH:f32 = saturate( dot( normal, halfDir ) ); + let dotVH:f32 = saturate( dot( viewDir, halfDir ) ); - let v:f32 = dot( texel.xyz, luma ); + let F = F_Schlick( specularColor, 1.0, dotVH ); - let outputColor:vec4 = vec4( luminosityUniforms.defaultColor.rgb, luminosityUniforms.defaultOpacity ); + let G:f32 = G_BlinnPhong_Implicit( ); - let alpha:f32 = smoothstep( luminosityUniforms.luminosityThreshold, luminosityUniforms.luminosityThreshold + luminosityUniforms.smoothWidth, v ); + let D = D_BlinnPhong( shininess, dotNH ); - return mix( outputColor, texel, alpha ); + return F * ( G * D ); + + } + fn RE_Direct_BlinnPhong( directLight:IncidentLight,geometry:GeometricContext, material:BlinnPhongMaterial )->ReflectedLight{ + var reflectedLight:ReflectedLight; + let dotNL:f32 = saturate(dot(geometry.normal, directLight.direction)); + let irradiance:vec3 = dotNL*directLight.color; + + reflectedLight.directDiffuse= irradiance * BRDF_Lambert( material.diffuseColor ); + + reflectedLight.directSpecular= irradiance * BRDF_BlinnPhong( directLight.direction, geometry.viewDir, geometry.normal, material.specularColor, material.specularShininess ) * material.specularStrength; + return reflectedLight; + } + fn RE_IndirectDiffuse_BlinnPhong( irradiance:vec3, geometry:GeometricContext, material:BlinnPhongMaterial)->ReflectedLight { + var reflectedLight:ReflectedLight; + reflectedLight.indirectDiffuse += irradiance * BRDF_Lambert( material.diffuseColor ); + return reflectedLight; } `; } -function blendFrag(defines) { +function phongUtils(defines) { return ` - struct FragInput { - @location(0) uv: vec2, + struct BlinnPhongMaterial { + diffuseColor:vec3, + specularColor:vec3, + specularShininess:f32, + specularStrength:f32, }; - @group(0) @binding({{tDiffuseBinding}}) var tDiffuse: texture_2d; - @group(0) @binding({{baseColorTextureBinding}}) var baseColorTexture: texture_2d; - @group(0) @binding({{tSamplerBinding}}) var tSampler: sampler; - @fragment - fn main(input:FragInput) -> @location(0) vec4 { - let postColor:vec4 = textureSample(tDiffuse, tSampler, input.uv); - let baseColor:vec4 = textureSample(baseColorTexture, tSampler, input.uv); - return baseColor+postColor; - } - `; + const RECIPROCAL_PI:f32= 0.3183098861837907; + fn pow2( x:f32 )->f32 { return x*x; } + fn pow3( x:f32 )->f32 { return x*x*x; } + fn pow4(x:f32 )->f32 { let x2 = x*x; return x2*x2; } + fn max3( v:vec3 )->f32 { return max( max( v.x, v.y ), v.z ); } + fn average(v:vec3 )->f32 { + let result=vec3( 0.3333333, 0.3333333, 0.3333333); + return dot( v,result ); + } + `; +} + +function skinVertHeader(defines) { + return wgslParseDefines` + #if ${defines.HAS_SKIN} + struct JointsUniform{ + matrixs:array, + } + struct InverseBindMatricesUniform{ + matrixs:array, + } + @binding(${defines.skinJointsBufferBinding}) @group(0) var jointsUniform : JointsUniform; + @binding(${defines.invsBufferBinding}) @group(0) var inverseBindMatricesUniform : InverseBindMatricesUniform; + fn getSkinMatrix(joints: vec4f, weights: vec4f) -> mat4x4 { + let joint0 = jointsUniform.matrixs[u32(joints.x)] * inverseBindMatricesUniform.matrixs[u32(joints.x)]; + let joint1 = jointsUniform.matrixs[u32(joints.y)] * inverseBindMatricesUniform.matrixs[u32(joints.y)]; + let joint2 = jointsUniform.matrixs[u32(joints.z)] * inverseBindMatricesUniform.matrixs[u32(joints.z)]; + let joint3 = jointsUniform.matrixs[u32(joints.w)] * inverseBindMatricesUniform.matrixs[u32(joints.w)]; + + let skinMatrix = joint0 * weights.x + + joint1 * weights.y + + joint2 * weights.z + + joint3 * weights.w; + return skinMatrix; + } + #endif + `; +} +function skinVertMain(defines) { + return wgslParseDefines` + #if ${defines.HAS_SKIN} + modelMatrix =getSkinMatrix(input.joint0,input.weight0); + vNormalView = normalize((materialUniform.normalMatrix * modelMatrix * vec4(input.normal, 0.0)).xyz); + #endif + `; +} + +function PbrMaterialStruct(defines) { + return wgslParseDefines` + struct MaterialUniform { + modelMatrix: mat4x4, + color: vec3, + opacity:f32, + normalMatrix: mat4x4, + emissive:vec3, + metallic:f32, + roughness:f32, + #if ${defines.USE_NORMALTEXTURE} + normalTextureScale:vec2, + #endif + #if ${defines.USE_AOTEXTURE} + occlusionStrength:f32, + #endif + } + `; } +const ShaderChunk = { + light: light, + brdf: brdf, + phongFunction: phongFunction, + phongUtils: phongUtils, + lightCommon: lightCommon, + pbrStruct: pbrStruct, + pbrFunction: pbrFunction, + pbrTexture: pbrTexture, + pbrUtils: pbrUtils, + environment: environment, + blinn_phong: blinn_phong, + getNormal: getNormal, + getTBN: getTBN, + getNormalByNormalTexture: getNormalByNormalTexture, + ibl: ibl, + skinVertMain, + skinVertHeader, + FragInput, + VertexInput, + VertexOutput, + PbrMaterialStruct, + SystemUniform, + instanceVertMain, + instanceVertHeader, + TextureAndSamplerDefine +}; + function shadowMapDebuggerFrag(defines) { return ` @group(0) @binding(1) var shadowSampler: sampler; @@ -10360,6 +10378,20 @@ function shadowMapDebuggerVert(defines) { `; } +// import Color from "../../math/Color"; +function shadowMapFrag(defines) { + return ` + struct VertexOutput { + @builtin(position) position: vec4, + @location(0) color: vec4, + }; + @fragment + fn main(input:VertexOutput) -> @location(0) vec4 { + return input.color; + } + `; +} + function shadowMapVert(defines) { return wgslParseDefines` struct VertexInput { @@ -10402,22 +10434,8 @@ function shadowMapVert(defines) { `; } -// import Color from "../../math/Color"; -function shadowMapFrag(defines) { - return ` - struct VertexOutput { - @builtin(position) position: vec4, - @location(0) color: vec4, - }; - @fragment - fn main(input:VertexOutput) -> @location(0) vec4 { - return input.color; - } - `; -} - function reduceComma(shader) { - //对所有的include处理 + // 对所有的include处理 const str = resolveIncludes(shader); return str; } @@ -10467,6 +10485,10 @@ const shaders = { shadowMap: { vert: shadowMapVert, frag: shadowMapFrag + }, + billboard: { + vert: billboard_vs, + frag: billboard_fs } }; function resolveIncludes(string) { @@ -10604,7 +10626,7 @@ function checkContainFloatType(uniforms) { hasArraytype }; } -function addUniformToShaderData(name, uniform, uniforms, shaderData, uniformBuffer) { +function addUniformToShaderData(name, uniform, uniforms, shaderData, mesh, uniformBuffer) { switch (uniform.type) { case "float": uniformBuffer.setUniform( @@ -10650,6 +10672,7 @@ function addUniformToShaderData(name, uniform, uniforms, shaderData, uniformBuff }, UniformEnum.FloatVec4 ); + break; case "mat2": uniformBuffer.setUniform( name, @@ -10667,11 +10690,16 @@ function addUniformToShaderData(name, uniform, uniforms, shaderData, uniformBuff }, UniformEnum.Mat3 ); + break; case "mat4": uniformBuffer.setUniform( name, () => { - return uniforms[name].value; + return name == "modelMatrix" + ? mesh?.modelMatrix + : name === "normalMatrix" + ? mesh.normalMatrix + : uniforms[name].value; }, UniformEnum.Mat4 ); @@ -11028,13 +11056,19 @@ class Material { set opacity(v) { this._opacity = v; } - onBeforeRender() {} - onBeforeCompile() {} + onBeforeRender() { + // callback + } + onBeforeCompile() { + // callback + } clone() { return null; } - update(frameState, mesh) {} - createShaderData(mesh, frameState) { + update(frameState, mesh) { + // update material + } + createShaderData() { if (this.shaderData) this.shaderData.destroy(); this.shaderData = new ShaderData(this.type, 0); this.ready = true; @@ -11083,7 +11117,7 @@ class ShaderMaterial extends Material { return new ShaderMaterial(this.shaderMaterialParms); } createShaderData(mesh) { - super.createShaderData(mesh); + super.createShaderData(); const result = checkContainFloatType(this.uniforms); if (result.hasFloat) { this.uniformBuffer = result.hasArraytype @@ -11102,6 +11136,7 @@ class ShaderMaterial extends Material { this.uniforms[uniformsName], this.uniforms, this.shaderData, + mesh, this.uniformBuffer ); }); @@ -11123,6 +11158,7 @@ class Mesh extends RenderObject { this.geometry = geometry; this.material = material; this.type = RenderObjectType.Mesh; + this.frustumCull = true; this.uid = createGuid(); this.subCommands = {}; } @@ -11152,12 +11188,16 @@ class Mesh extends RenderObject { frameState.renderQueue.opaque.push(this); } } - beforeRender() {} - afterRender() {} + beforeRender() { + // before render + } + afterRender() { + // after render + } getDrawCommand(overrideMaterial, commandSubType, lightManger) { if (!this.drawCommand || this.material.dirty) { this.material.shaderSource.setDefines( - Object.assign(this.material.shaderData.defines, this.geometry.defines) + Object.assign({}, this.material.shaderData.defines, this.geometry.defines) ); if (this.material.dirty) this.material.dirty = false; this.drawCommand = new DrawCommand({ @@ -11177,8 +11217,7 @@ class Mesh extends RenderObject { if (overrideMaterial) { if (!this.subCommands[commandSubType]) { const copyMat = overrideMaterial.clone(); - overrideMaterial.update(); - copyMat.update(); + copyMat.update(undefined, this); if (copyMat.dirty) copyMat.dirty = false; this.subCommands[commandSubType] = this.drawCommand.shallowClone(copyMat); } @@ -11255,12 +11294,12 @@ class ColorMaterial extends Material { }); } update(frameState, mesh) { - if (!this.shaderData || this.dirty) this.createShaderData(mesh); + if (!this.shaderData || this.dirty) this.createShaderData(); const uniformBuffer = new UniformBuffer({ label: "color" }); uniformBuffer.setUniform( "modelMatrix", () => { - return null; + return mesh.modelMatrix; }, UniformEnum.Mat4 ); @@ -11495,12 +11534,12 @@ class SkyBoxMaterial extends Material { } } createShaderData(mesh) { - super.createShaderData(mesh); + super.createShaderData(); const uniformBuffer = new UniformBuffer({ label: "skybox" }); uniformBuffer.setUniform( "modelMatrix", () => { - return null; + return mesh.modelMatrix; }, UniformEnum.Mat4 ); @@ -11553,11 +11592,10 @@ class InstanceMesh extends Mesh { this.hasAddInstances = false; } update(frameState, camera) { - // create - this.geometry.update(frameState); - this.material.update(frameState, this); // update instances visiblity this.checkInstancesVisiblity({ frameState, camera }); + this.geometry.update(frameState); + this.material.update(frameState, this); if (!this.hasAddInstances) this.addUniformsToMaterial(); this.instanceCount = this.renderInstances.length; if (this.renderInstances.length < 1) return; @@ -11579,11 +11617,16 @@ class InstanceMesh extends Mesh { } checkInstancesVisiblity(options) { const { frameState, camera } = options; + const preFrameInstanceCount = this.renderInstances.length; + this.renderInstances = []; this.instances.forEach((instance) => { instance.updateMatrix(this?.parent?.modelMatrix); instance.visiblity = this.getInstanceVisiblity({ instance, frameState, camera }); if (instance.visiblity) this.renderInstances.push(instance); }); + this.material.dirty = this.renderInstances.length === preFrameInstanceCount; + // rebuild instanceMatrixsBuffer + if (this.material.dirty) this.hasAddInstances = false; } getInstanceVisiblity(options) { const { instance, frameState, camera } = options; @@ -12066,12 +12109,12 @@ class BlinnPhongMaterial extends Material { if (!this.shaderData || this.dirty) this.createShaderData(mesh); } createShaderData(mesh) { - super.createShaderData(mesh); + super.createShaderData(); const uniformBuffer = new UniformBuffer({ label: "phong" }); uniformBuffer.setUniform( "modelMatrix", () => { - return null; + return mesh.modelMatrix; }, UniformEnum.Mat4 ); @@ -12163,11 +12206,11 @@ class PbrMaterial extends Material { update(frameState, mesh) { if (!textureCache.getTexture("specular")) return; if (!this.shaderData || this.dirty) { - this.createShaderData(mesh, frameState); + this.createShaderData(mesh); } } - createShaderData(mesh, frameState) { - super.createShaderData(mesh); + createShaderData(mesh) { + super.createShaderData(); const uniformBuffer = new UniformBuffer({ label: "pbr" }); uniformBuffer.setUniform( "modelMatrix", @@ -15898,4 +15941,4 @@ export { loadGLTF, loadTexture }; -//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"index.js","sources":["../src/core/WebGPUConstant.ts","../src/render/Buffer.ts","../src/render/PipelineLayout.ts","../src/render/Pipeline.ts","../src/render/DrawCommand.ts","../src/core/WebGPUTypes.ts","../src/utils/MipmapGenerator.ts","../src/utils/defaultValue.ts","../src/render/RenderState.ts","../src/render/Context.ts","../src/render/Texture.ts","../src/render/Sampler.ts","../src/render/Attachment.ts","../src/utils/defined.ts","../node_modules/mersenne-twister/src/mersenne-twister.js","../src/math/Math.ts","../src/math/Vector2.ts","../src/math/Vector3.ts","../src/render/Attribute.ts","../src/render/BindGroup.ts","../src/render/BindGroupEntity.ts","../src/math/Matrix3.ts","../src/math/Vector4.ts","../src/math/Matrix4.ts","../src/core/BoundingSphere.ts","../src/render/IndexBuffer.ts","../src/render/Attributes.ts","../src/render/VertextBuffer.ts","../src/utils/combine.ts","../src/geometry/Geometry.ts","../src/geometry/PlaneGeometry.ts","../src/math/Quaternion.ts","../src/core/RenderObject.ts","../src/light/Light.ts","../src/math/Color.ts","../src/math/Matrix2.ts","../src/render/Uniforms.ts","../src/render/UniformBuffer.ts","../src/shader/WgslPreprocessor.ts","../src/shader/shaderChunk/attribute/FragInput.ts","../src/shader/shaderChunk/attribute/VertexInput.ts","../src/shader/shaderChunk/attribute/VertexOutput.ts","../src/shader/shaderChunk/common/SystemUniform.ts","../src/shader/shaderChunk/environment/environment.ts","../src/shader/shaderChunk/instance/Instance.ts","../src/shader/shaderChunk/light/light.ts","../src/shader/shaderChunk/light/lightCommon.ts","../src/shader/shaderChunk/normal/getNormalBackUp.ts","../src/shader/shaderChunk/pbr/brdf.ts","../src/shader/shaderChunk/pbr/ibl.ts","../src/shader/shaderChunk/pbr/pbrFunction.ts","../src/shader/shaderChunk/pbr/pbrStruct.ts","../src/shader/shaderChunk/pbr/pbrTexture.ts","../src/shader/shaderChunk/pbr/pbrUtils.ts","../src/shader/shaderChunk/phong/blinn_phong.ts","../src/shader/shaderChunk/phong/phongFunction.ts","../src/shader/shaderChunk/phong/phongUtils.ts","../src/shader/shaderChunk/skin/SkinVert.ts","../src/shader/shaderChunk/struct/PbrMaterialStruct.ts","../src/shader/shaderChunk/ShaderChunk.ts","../src/shader/material/phongVert.ts","../src/shader/material/phongFrag.ts","../src/shader/material/colorFrag.ts","../src/shader/material/colorVert.ts","../src/shader/material/pbrFrag.ts","../src/shader/material/pbrVert.ts","../src/shader/material/skyBoxFrag.ts","../src/shader/material/skyBoxVert.ts","../src/shader/material/quadFrag.ts","../src/shader/material/quadVert.ts","../src/shader/material/pbr_vs.ts","../src/shader/material/pbr_fs.ts","../src/shader/postProcess/bloom/Blur.ts","../src/shader/postProcess/bloom/LuminosityHigh.ts","../src/shader/postProcess/blend/blendFrag.ts","../src/shader/shaderChunk/shadow/shadowMapDebuggerFrag.ts","../src/shader/shaderChunk/shadow/shadowMapDebuggerVert.ts","../src/shader/shaderChunk/shadow/shadowMapVert.ts","../src/shader/shaderChunk/shadow/shadowMapFrag.ts","../src/shader/Shaders.ts","../src/shader/ShaderSource.ts","../src/utils/uniformUtils.ts","../src/render/BindGroupLayout.ts","../src/render/BindGroupLayoutEntry.ts","../src/render/ShaderData.ts","../src/material/Material.ts","../src/material/ShaderMaterial.ts","../src/utils/createGuid.ts","../src/mesh/Mesh.ts","../src/helper/ShadowMapDebugger.ts","../src/material/ColorMaterial.ts","../src/mesh/Axes.ts","../src/geometry/SkyBoxGeometry.ts","../src/utils/destroyObject.ts","../src/core/TextureCache.ts","../src/loader/CubeTextureLoader.ts","../src/material/SkyBoxMaterial.ts","../src/mesh/SkyBox.ts","../src/mesh/Instance.ts","../src/mesh/InstanceMesh.ts","../src/utils/GeometryUtils.ts","../src/geometry/SphereGeometry.ts","../src/geometry/BoxGeometry.ts","../src/geometry/TorusKnotGeometry.ts","../src/material/BlinnPhongMaterial.ts","../src/material/PbrMaterial.ts","../src/core/EventDispatcher.ts","../src/core/RenderQueue.ts","../src/core/FrameState.ts","../src/light/AmbientLight.ts","../src/core/LightManger.ts","../src/core/MeshManger.ts","../src/render/RenderTarget.ts","../src/post-process/ResolveFrame.ts","../src/post-process/PostEffectCollection.ts","../src/pass/Pass.ts","../src/pass/BasicPass.ts","../src/math/Plane.ts","../src/core/CullingVolume.ts","../src/camera/Camera.ts","../src/camera/PerspectiveCamera.ts","../src/camera/PointLightShadowCamera.ts","../src/light/shadows/BaseShadow.ts","../src/light/shadows/PointLightShadow.ts","../src/light/PointLight.ts","../src/pass/ShadowPass.ts","../src/renderpipeline/ForwardRenderLine.ts","../src/Scene.ts","../src/post-process/PostEffect.ts","../src/post-process/BloomPostEffect.ts","../src/camera/OrthographicCamera.ts","../src/light/shadows/SpotLightShadow.ts","../src/light/SpotLight.ts","../src/light/shadows/DirectionalLightShadow.ts","../src/light/DirectionalLight.ts","../src/mesh/Node.ts","../src/mesh/SKinMesh.ts","../src/utils/gltfUtils.ts","../src/loader/gltf/libs/Accessor.ts","../src/loader/gltf/libs/Animation.ts","../src/loader/gltf/libs/AnimationChannel.ts","../src/loader/gltf/libs/AnimationChannelTarget.ts","../src/loader/gltf/types/gltfType.ts","../src/loader/gltf/libs/AnimationSampler.ts","../src/loader/GLTFLoader.ts","../src/utils/utils.ts","../src/math/Spherical.ts","../src/control/OrbitControl.ts"],"sourcesContent":["/** @internal */\nexport enum PredefinedColorSpace {\n\tSRGB = \"srgb\"\n}\n\n/** @internal */\nexport enum PowerPreference {\n\tLowPower = \"low-power\",\n\tHighPerformance = \"high-performance\"\n}\n\n/** @internal */\nexport enum FeatureName {\n\tDepthClipControl = \"depth-clip-control\",\n\tDepth24UnormStencil8 = \"depth24unorm-stencil8\",\n\tDepth32FloatStencil8 = \"depth32float-stencil8\",\n\tTextureCompressionBC = \"texture-compression-bc\",\n\tTextureCompressionETC2 = \"texture-compression-etc2\",\n\tTextureCompressionASTC = \"texture-compression-astc\",\n\tTimestampQuery = \"timestamp-query\",\n\tIndirectFirstInstance = \"indirect-first-instance\",\n\tShaderF16 = \"shader-f16\",\n\tBGRA8UnormStorage = \"bgra8unorm-storage\"\n}\n\n/** @internal */\nexport enum BufferUsage {\n\tMapRead = 1,\n\tMapWrite = 2,\n\tCopySrc = 4,\n\tCopyDst = 8,\n\tIndex = 16,\n\tVertex = 32,\n\tUniform = 64,\n\tStorage = 128,\n\tIndirect = 256,\n\tQueryResolve = 512\n}\n\n/** @internal */\nexport enum MapMode {\n\tRead = 1,\n\tWrite = 2\n}\n\n/** @internal */\nexport enum TextureDimension {\n\tE1d = \"1d\",\n\tE2d = \"2d\",\n\tE3d = \"3d\"\n}\n\n/** @internal */\nexport enum TextureUsage {\n\tCopySrc = 1,\n\tCopyDst = 2,\n\tTextureBinding = 4,\n\tStorageBinding = 8,\n\tRenderAttachment = 16\n}\n\n/** @internal */\nexport enum TextureViewDimension {\n\tE1d = \"1d\",\n\tE2d = \"2d\",\n\tE2dArray = \"2d-array\",\n\tCube = \"cube\",\n\tCubeArray = \"cube-array\",\n\tE3d = \"3d\"\n}\n\n/** @internal */\nexport enum TextureAspect {\n\tAll = \"all\",\n\tStencilOnly = \"stencil-only\",\n\tDepthOnly = \"depth-only\"\n}\n\n/**\n * Comments taken from https://github.com/gfx-rs/wgpu/blob/master/wgpu-types/src/lib.rs\n * @internal\n */\nexport enum TextureFormat {\n\t// 8-bit formats\n\tR8Unorm = \"r8unorm\", // Red channel only. 8 bit integer per channel. [0, 255] converted to/from float [0, 1] in shader.\n\tR8Snorm = \"r8snorm\", // Red channel only. 8 bit integer per channel. [-127, 127] converted to/from float [-1, 1] in shader.\n\tR8Uint = \"r8uint\", // Red channel only. 8 bit integer per channel. Unsigned in shader.\n\tR8Sint = \"r8sint\", // Red channel only. 8 bit integer per channel. Signed in shader.\n\n\t// 16-bit formats\n\tR16Uint = \"r16uint\", // Red channel only. 16 bit integer per channel. Unsigned in shader.\n\tR16Sint = \"r16sint\", // Red channel only. 16 bit integer per channel. Signed in shader.\n\tR16Float = \"r16float\", // Red channel only. 16 bit float per channel. Float in shader.\n\tRG8Unorm = \"rg8unorm\", // Red and green channels. 8 bit integer per channel. [0, 255] converted to/from float [0, 1] in shader.\n\tRG8Snorm = \"rg8snorm\", // Red and green channels. 8 bit integer per channel. [-127, 127] converted to/from float [-1, 1] in shader.\n\tRG8Uint = \"rg8uint\", // Red and green channels. 8 bit integer per channel. Unsigned in shader.\n\tRG8Sint = \"rg8sint\", // Red and green channels. 8 bit integer per channel. Signed in shader.\n\n\t// 32-bit formats\n\tR32Uint = \"r32uint\", // Red channel only. 32 bit integer per channel. Unsigned in shader.\n\tR32Sint = \"r32sint\", // Red channel only. 32 bit integer per channel. Signed in shader.\n\tR32Float = \"r32float\", // Red channel only. 32 bit float per channel. Float in shader.\n\tRG16Uint = \"rg16uint\", // Red and green channels. 16 bit integer per channel. Unsigned in shader.\n\tRG16Sint = \"rg16sint\", // Red and green channels. 16 bit integer per channel. Signed in shader.\n\tRG16Float = \"rg16float\", // Red and green channels. 16 bit float per channel. Float in shader.\n\tRGBA8Unorm = \"rgba8unorm\", // Red, green, blue, and alpha channels. 8 bit integer per channel. [0, 255] converted to/from float [0, 1] in shader.\n\tRGBA8UnormSRGB = \"rgba8unorm-srgb\", // Red, green, blue, and alpha channels. 8 bit integer per channel. Srgb-color [0, 255] converted to/from linear-color float [0, 1] in shader.\n\tRGBA8Snorm = \"rgba8snorm\", // Red, green, blue, and alpha channels. 8 bit integer per channel. [-127, 127] converted to/from float [-1, 1] in shader.\n\tRGBA8Uint = \"rgba8uint\", // Red, green, blue, and alpha channels. 8 bit integer per channel. Unsigned in shader.\n\tRGBA8Sint = \"rgba8sint\", // Red, green, blue, and alpha channels. 8 bit integer per channel. Signed in shader.\n\tBGRA8Unorm = \"bgra8unorm\", // Blue, green, red, and alpha channels. 8 bit integer per channel. [0, 255] converted to/from float [0, 1] in shader.\n\tBGRA8UnormSRGB = \"bgra8unorm-srgb\", // Blue, green, red, and alpha channels. 8 bit integer per channel. Srgb-color [0, 255] converted to/from linear-color float [0, 1] in shader.\n\t// Packed 32-bit formats\n\tRGB9E5UFloat = \"rgb9e5ufloat\", // Packed unsigned float with 9 bits mantisa for each RGB component, then a common 5 bits exponent\n\tRGB10A2Unorm = \"rgb10a2unorm\", // Red, green, blue, and alpha channels. 10 bit integer for RGB channels, 2 bit integer for alpha channel. [0, 1023] ([0, 3] for alpha) converted to/from float [0, 1] in shader.\n\tRG11B10UFloat = \"rg11b10ufloat\", // Red, green, and blue channels. 11 bit float with no sign bit for RG channels. 10 bit float with no sign bit for blue channel. Float in shader.\n\n\t// 64-bit formats\n\tRG32Uint = \"rg32uint\", // Red and green channels. 32 bit integer per channel. Unsigned in shader.\n\tRG32Sint = \"rg32sint\", // Red and green channels. 32 bit integer per channel. Signed in shader.\n\tRG32Float = \"rg32float\", // Red and green channels. 32 bit float per channel. Float in shader.\n\tRGBA16Uint = \"rgba16uint\", // Red, green, blue, and alpha channels. 16 bit integer per channel. Unsigned in shader.\n\tRGBA16Sint = \"rgba16sint\", // Red, green, blue, and alpha channels. 16 bit integer per channel. Signed in shader.\n\tRGBA16Float = \"rgba16float\", // Red, green, blue, and alpha channels. 16 bit float per channel. Float in shader.\n\n\t// 128-bit formats\n\tRGBA32Uint = \"rgba32uint\", // Red, green, blue, and alpha channels. 32 bit integer per channel. Unsigned in shader.\n\tRGBA32Sint = \"rgba32sint\", // Red, green, blue, and alpha channels. 32 bit integer per channel. Signed in shader.\n\tRGBA32Float = \"rgba32float\", // Red, green, blue, and alpha channels. 32 bit float per channel. Float in shader.\n\n\t// Depth and stencil formats\n\tStencil8 = \"stencil8\",\n\tDepth16Unorm = \"depth16unorm\",\n\tDepth24Plus = \"depth24plus\", // Special depth format with at least 24 bit integer depth.\n\tDepth24PlusStencil8 = \"depth24plus-stencil8\", // Special depth/stencil format with at least 24 bit integer depth and 8 bits integer stencil.\n\tDepth32Float = \"depth32float\", // Special depth format with 32 bit floating point depth.\n\n\t// BC compressed formats usable if \"texture-compression-bc\" is both\n\t// supported by the device/user agent and enabled in requestDevice.\n\tBC1RGBAUnorm = \"bc1-rgba-unorm\", // 4x4 block compressed texture. 8 bytes per block (4 bit/px). 4 color + alpha pallet. 5 bit R + 6 bit G + 5 bit B + 1 bit alpha. Also known as DXT1.\n\tBC1RGBAUnormSRGB = \"bc1-rgba-unorm-srgb\", // 4x4 block compressed texture. 8 bytes per block (4 bit/px). 4 color + alpha pallet. 5 bit R + 6 bit G + 5 bit B + 1 bit alpha. Also known as DXT1.\n\tBC2RGBAUnorm = \"bc2-rgba-unorm\", // 4x4 block compressed texture. 16 bytes per block (8 bit/px). 4 color pallet. 5 bit R + 6 bit G + 5 bit B + 4 bit alpha. Also known as DXT3.\n\tBC2RGBAUnormSRGB = \"bc2-rgba-unorm-srgb\", // 4x4 block compressed texture. 16 bytes per block (8 bit/px). 4 color pallet. 5 bit R + 6 bit G + 5 bit B + 4 bit alpha. Also known as DXT3.\n\tBC3RGBAUnorm = \"bc3-rgba-unorm\", // 4x4 block compressed texture. 16 bytes per block (8 bit/px). 4 color pallet + 8 alpha pallet. 5 bit R + 6 bit G + 5 bit B + 8 bit alpha. Also known as DXT5.\n\tBC3RGBAUnormSRGB = \"bc3-rgba-unorm-srgb\", // 4x4 block compressed texture. 16 bytes per block (8 bit/px). 4 color pallet + 8 alpha pallet. 5 bit R + 6 bit G + 5 bit B + 8 bit alpha. Also known as DXT5.\n\tBC4RUnorm = \"bc4-r-unorm\", // 4x4 block compressed texture. 8 bytes per block (4 bit/px). 8 color pallet. 8 bit R. Also known as RGTC1.\n\tBC4RSnorm = \"bc4-r-snorm\", // 4x4 block compressed texture. 8 bytes per block (4 bit/px). 8 color pallet. 8 bit R. Also known as RGTC1.\n\tBC5RGUnorm = \"bc5-rg-unorm\", // 4x4 block compressed texture. 16 bytes per block (8 bit/px). 8 color red pallet + 8 color green pallet. 8 bit RG. Also known as RGTC2.\n\tBC5RGSnorm = \"bc5-rg-snorm\", // 4x4 block compressed texture. 16 bytes per block (8 bit/px). 8 color red pallet + 8 color green pallet. 8 bit RG. Also known as RGTC2.\n\tBC6HRGBUFloat = \"bc6h-rgb-ufloat\", // 4x4 block compressed texture. 16 bytes per block (8 bit/px). Variable sized pallet. 16 bit unsigned float RGB. Float in shader. Also known as BPTC (float).\n\tBC6HRGBFloat = \"bc6h-rgb-float\", // 4x4 block compressed texture. 16 bytes per block (8 bit/px). Variable sized pallet. 16 bit signed float RGB. Float in shader. Also known as BPTC (float).\n\tBC7RGBAUnorm = \"bc7-rgba-unorm\", // 4x4 block compressed texture. 16 bytes per block (8 bit/px). Variable sized pallet. 8 bit integer RGBA. Also known as BPTC (unorm).\n\tBC7RGBAUnormSRGB = \"bc7-rgba-unorm-srgb\", // 4x4 block compressed texture. 16 bytes per block (8 bit/px). Variable sized pallet. 8 bit integer RGBA. Also known as BPTC (unorm).\n\n\t// ETC2 compressed formats usable if \"texture-compression-etc2\" is both\n\t// supported by the device/user agent and enabled in requestDevice.\n\tETC2RGB8Unorm = \"etc2-rgb8unorm\", // 4x4 block compressed texture. 8 bytes per block (4 bit/px). Complex pallet. 8 bit integer RGB.\n\tETC2RGB8UnormSRGB = \"etc2-rgb8unorm-srgb\", // 4x4 block compressed texture. 8 bytes per block (4 bit/px). Complex pallet. 8 bit integer RGB.\n\tETC2RGB8A1Unorm = \"etc2-rgb8a1unorm\", // 4x4 block compressed texture. 8 bytes per block (4 bit/px). Complex pallet. 8 bit integer RGB + 1 bit alpha.\n\tETC2RGB8A1UnormSRGB = \"etc2-rgb8a1unorm-srgb\", // 4x4 block compressed texture. 8 bytes per block (4 bit/px). Complex pallet. 8 bit integer RGB + 1 bit alpha.\n\tETC2RGBA8Unorm = \"etc2-rgba8unorm\", // 4x4 block compressed texture. 16 bytes per block (8 bit/px). Complex pallet. 8 bit integer RGB + 8 bit alpha.\n\tETC2RGBA8UnormSRGB = \"etc2-rgba8unorm-srgb\", // 4x4 block compressed texture. 16 bytes per block (8 bit/px). Complex pallet. 8 bit integer RGB + 8 bit alpha.\n\tEACR11Unorm = \"eac-r11unorm\", // 4x4 block compressed texture. 8 bytes per block (4 bit/px). Complex pallet. 11 bit integer R.\n\tEACR11Snorm = \"eac-r11snorm\", // 4x4 block compressed texture. 8 bytes per block (4 bit/px). Complex pallet. 11 bit integer R.\n\tEACRG11Unorm = \"eac-rg11unorm\", // 4x4 block compressed texture. 16 bytes per block (8 bit/px). Complex pallet. 11 bit integer R + 11 bit integer G.\n\tEACRG11Snorm = \"eac-rg11snorm\", // 4x4 block compressed texture. 16 bytes per block (8 bit/px). Complex pallet. 11 bit integer R + 11 bit integer G.\n\n\t// ASTC compressed formats usable if \"texture-compression-astc\" is both\n\t// supported by the device/user agent and enabled in requestDevice.\n\tASTC4x4Unorm = \"astc-4x4-unorm\", // 4x4 block compressed texture. 16 bytes per block (8 bit/px). Complex pallet. 8 bit integer RGBA.\n\tASTC4x4UnormSRGB = \"astc-4x4-unorm-srgb\", // 4x4 block compressed texture. 16 bytes per block (8 bit/px). Complex pallet. 8 bit integer RGBA.\n\tASTC5x4Unorm = \"astc-5x4-unorm\", // 5x4 block compressed texture. 16 bytes per block (6.4 bit/px). Complex pallet. 8 bit integer RGBA.\n\tASTC5x4UnormSRGB = \"astc-5x4-unorm-srgb\", // 5x4 block compressed texture. 16 bytes per block (6.4 bit/px). Complex pallet. 8 bit integer RGBA.\n\tASTC5x5Unorm = \"astc-5x5-unorm\", // 5x5 block compressed texture. 16 bytes per block (5.12 bit/px). Complex pallet. 8 bit integer RGBA.\n\tASTC5x5UnormSRGB = \"astc-5x5-unorm-srgb\", // 5x5 block compressed texture. 16 bytes per block (5.12 bit/px). Complex pallet. 8 bit integer RGBA.\n\tASTC6x5Unorm = \"astc-6x5-unorm\", // 6x5 block compressed texture. 16 bytes per block (4.27 bit/px). Complex pallet. 8 bit integer RGBA.\n\tASTC6x5UnormSRGB = \"astc-6x5-unorm-srgb\", // 6x5 block compressed texture. 16 bytes per block (4.27 bit/px). Complex pallet. 8 bit integer RGBA.\n\tASTC6x6Unorm = \"astc-6x6-unorm\", // 6x6 block compressed texture. 16 bytes per block (3.56 bit/px). Complex pallet. 8 bit integer RGBA.\n\tASTC6x6UnormSRGB = \"astc-6x6-unorm-srgb\", // 6x6 block compressed texture. 16 bytes per block (3.56 bit/px). Complex pallet. 8 bit integer RGBA.\n\tASTC8x5Unorm = \"astc-8x5-unorm\", // 8x5 block compressed texture. 16 bytes per block (3.2 bit/px). Complex pallet. 8 bit integer RGBA.\n\tASTC8x5UnormSRGB = \"astc-8x5-unorm-srgb\", // 8x5 block compressed texture. 16 bytes per block (3.2 bit/px). Complex pallet. 8 bit integer RGBA.\n\tASTC8x6Unorm = \"astc-8x6-unorm\", // 8x6 block compressed texture. 16 bytes per block (2.67 bit/px). Complex pallet. 8 bit integer RGBA.\n\tASTC8x6UnormSRGB = \"astc-8x6-unorm-srgb\", // 8x6 block compressed texture. 16 bytes per block (2.67 bit/px). Complex pallet. 8 bit integer RGBA.\n\tASTC8x8Unorm = \"astc-8x8-unorm\", // 8x8 block compressed texture. 16 bytes per block (2 bit/px). Complex pallet. 8 bit integer RGBA.\n\tASTC8x8UnormSRGB = \"astc-8x8-unorm-srgb\", // 8x8 block compressed texture. 16 bytes per block (2 bit/px). Complex pallet. 8 bit integer RGBA.\n\tASTC10x5Unorm = \"astc-10x5-unorm\", // 10x5 block compressed texture. 16 bytes per block (2.56 bit/px). Complex pallet. 8 bit integer RGBA.\n\tASTC10x5UnormSRGB = \"astc-10x5-unorm-srgb\", // 10x5 block compressed texture. 16 bytes per block (2.56 bit/px). Complex pallet. 8 bit integer RGBA.\n\tASTC10x6Unorm = \"astc-10x6-unorm\", // 10x6 block compressed texture. 16 bytes per block (2.13 bit/px). Complex pallet. 8 bit integer RGBA.\n\tASTC10x6UnormSRGB = \"astc-10x6-unorm-srgb\", // 10x6 block compressed texture. 16 bytes per block (2.13 bit/px). Complex pallet. 8 bit integer RGBA.\n\tASTC10x8Unorm = \"astc-10x8-unorm\", // 10x8 block compressed texture. 16 bytes per block (1.6 bit/px). Complex pallet. 8 bit integer RGBA.\n\tASTC10x8UnormSRGB = \"astc-10x8-unorm-srgb\", // 10x8 block compressed texture. 16 bytes per block (1.6 bit/px). Complex pallet. 8 bit integer RGBA.\n\tASTC10x10Unorm = \"astc-10x10-unorm\", // 10x10 block compressed texture. 16 bytes per block (1.28 bit/px). Complex pallet. 8 bit integer RGBA.\n\tASTC10x10UnormSRGB = \"astc-10x10-unorm-srgb\", // 10x10 block compressed texture. 16 bytes per block (1.28 bit/px). Complex pallet. 8 bit integer RGBA.\n\tASTC12x10Unorm = \"astc-12x10-unorm\", // 12x10 block compressed texture. 16 bytes per block (1.07 bit/px). Complex pallet. 8 bit integer RGBA.\n\tASTC12x10UnormSRGB = \"astc-12x10-unorm-srgb\", // 12x10 block compressed texture. 16 bytes per block (1.07 bit/px). Complex pallet. 8 bit integer RGBA.\n\tASTC12x12Unorm = \"astc-12x12-unorm\", // 12x12 block compressed texture. 16 bytes per block (0.89 bit/px). Complex pallet. 8 bit integer RGBA.\n\tASTC12x12UnormSRGB = \"astc-12x12-unorm-srgb\", // 12x12 block compressed texture. 16 bytes per block (0.89 bit/px). Complex pallet. 8 bit integer RGBA.\n\n\t// \"depth24unorm-stencil8\" feature\n\tDepth24UnormStencil8 = \"depth24unorm-stencil8\",\n\n\t// \"depth32float-stencil8\" feature\n\tDepth32FloatStencil8 = \"depth32float-stencil8\"\n}\n\n/** @internal */\nexport enum AddressMode {\n\tClampToEdge = \"clamp-to-edge\",\n\tRepeat = \"repeat\",\n\tMirrorRepeat = \"mirror-repeat\"\n}\n\n/** @internal */\nexport enum FilterMode {\n\tNearest = \"nearest\",\n\tLinear = \"linear\"\n}\n\n/** @internal */\nexport enum CompareFunction {\n\tNever = \"never\",\n\tLess = \"less\",\n\tEqual = \"equal\",\n\tLessEqual = \"less-equal\",\n\tGreater = \"greater\",\n\tNotEqual = \"not-equal\",\n\tGreaterEqual = \"greater-equal\",\n\tAlways = \"always\"\n}\n\n/** @internal */\nexport enum ShaderStage {\n\tVertex = 1,\n\tFragment = 2,\n\tCompute = 4\n}\n\n/** @internal */\nexport enum BufferBindingType {\n\tUniform = \"uniform\",\n\tStorage = \"storage\",\n\tReadOnlyStorage = \"read-only-storage\"\n}\n\n/** @internal */\nexport enum SamplerBindingType {\n\tFiltering = \"filtering\",\n\tNonFiltering = \"non-filtering\",\n\tComparison = \"comparison\"\n}\n\n/** @internal */\nexport enum TextureSampleType {\n\tFloat = \"float\",\n\tUnfilterableFloat = \"unfilterable-float\",\n\tDepth = \"depth\",\n\tSint = \"sint\",\n\tUint = \"uint\"\n}\n\n/** @internal */\nexport enum StorageTextureAccess {\n\tWriteOnly = \"write-only\"\n}\n\n/** @internal */\nexport enum CompilationMessageType {\n\tError = \"error\",\n\tWarning = \"warning\",\n\tInfo = \"info\"\n}\n\n/** @internal */\nexport enum AutoLayoutMode {\n\tAuto = \"auto\"\n}\n\n/** @internal */\nexport enum PrimitiveTopology {\n\tPointList = \"point-list\",\n\tLineList = \"line-list\",\n\tLineStrip = \"line-strip\",\n\tTriangleList = \"triangle-list\",\n\tTriangleStrip = \"triangle-strip\"\n}\n\n/** @internal */\nexport enum FrontFace {\n\tCCW = \"ccw\",\n\tCW = \"cw\"\n}\n\n/** @internal */\nexport enum CullMode {\n\tNone = \"none\",\n\tFront = \"front\",\n\tBack = \"back\"\n}\n\n/** @internal */\nexport enum ColorWriteFlags {\n\tRed = 1,\n\tGreen = 2,\n\tBlue = 4,\n\tAlpha = 8,\n\tAll = 15\n}\n\n/** @internal */\nexport enum BlendFactor {\n\tZero = \"zero\",\n\tOne = \"one\",\n\tSrc = \"src\",\n\tOneMinusSrc = \"one-minus-src\",\n\tSrcAlpha = \"src-alpha\",\n\tOneMinusSrcAlpha = \"one-minus-src-alpha\",\n\tDst = \"dst\",\n\tOneMinusDst = \"one-minus-dst\",\n\tDstAlpha = \"dst-alpha\",\n\tOneMinusDstAlpha = \"one-minus-dst-alpha\",\n\tSrcAlphaSaturated = \"src-alpha-saturated\",\n\tConstant = \"constant\",\n\tOneMinusConstant = \"one-minus-constant\"\n}\n\n/** @internal */\nexport enum BlendOperation {\n\tAdd = \"add\",\n\tSubtract = \"subtract\",\n\tReverseSubtract = \"reverse-subtract\",\n\tMin = \"min\",\n\tMax = \"max\"\n}\n\n/** @internal */\nexport enum StencilOperation {\n\tKeep = \"keep\",\n\tZero = \"zero\",\n\tReplace = \"replace\",\n\tInvert = \"invert\",\n\tIncrementClamp = \"increment-clamp\",\n\tDecrementClamp = \"decrement-clamp\",\n\tIncrementWrap = \"increment-wrap\",\n\tDecrementWrap = \"decrement-wrap\"\n}\n\n/** @internal */\nexport enum IndexFormat {\n\tUint16 = \"uint16\",\n\tUint32 = \"uint32\"\n}\n\n/** @internal */\nexport enum VertexFormat {\n\tUint8x2 = \"uint8x2\",\n\tUint8x4 = \"uint8x4\",\n\tSint8x2 = \"sint8x2\",\n\tSint8x4 = \"sint8x4\",\n\tUnorm8x2 = \"unorm8x2\",\n\tUnorm8x4 = \"unorm8x4\",\n\tSnorm8x2 = \"snorm8x2\",\n\tSnorm8x4 = \"snorm8x4\",\n\tUint16x2 = \"uint16x2\",\n\tUint16x4 = \"uint16x4\",\n\tSint16x2 = \"sint16x2\",\n\tSint16x4 = \"sint16x4\",\n\tUnorm16x2 = \"unorm16x2\",\n\tUnorm16x4 = \"unorm16x4\",\n\tSnorm16x2 = \"snorm16x2\",\n\tSnorm16x4 = \"snorm16x4\",\n\tFloat16x2 = \"float16x2\",\n\tFloat16x4 = \"float16x4\",\n\tFloat32 = \"float32\",\n\tFloat32x2 = \"float32x2\",\n\tFloat32x3 = \"float32x3\",\n\tFloat32x4 = \"float32x4\",\n\tUint32 = \"uint32\",\n\tUint32x2 = \"uint32x2\",\n\tUint32x3 = \"uint32x3\",\n\tUint32x4 = \"uint32x4\",\n\tSint32 = \"sint32\",\n\tSint32x2 = \"sint32x2\",\n\tSint32x3 = \"sint32x3\",\n\tSint32x4 = \"sint32x4\"\n}\n\n/** @internal */\nexport enum InputStepMode {\n\tVertex = \"vertex\",\n\tInstance = \"instance\"\n}\n\n/** @internal */\nexport enum ComputePassTimestampLocation {\n\tBeginning = \"beginning\",\n\tEnd = \"end\"\n}\n\n/** @internal */\nexport enum RenderPassTimestampLocation {\n\tBeginning = \"beginning\",\n\tEnd = \"end\"\n}\n\n/** @internal */\nexport enum LoadOp {\n\tLoad = \"load\",\n\tClear = \"clear\"\n}\n\n/** @internal */\nexport enum StoreOp {\n\tStore = \"store\",\n\tDiscard = \"discard\"\n}\n\n/** @internal */\nexport enum QueryType {\n\tOcclusion = \"occlusion\",\n\tTimestamp = \"timestamp\"\n}\n\n/** @internal */\nexport enum CanvasAlphaMode {\n\tOpaque = \"opaque\",\n\tPremultiplied = \"premultiplied\"\n}\n\n/** @internal */\nexport enum DeviceLostReason {\n\tDestroyed = \"destroyed\"\n}\n\n/** @internal */\nexport enum ErrorFilter {\n\tOutOfMemory = \"out-of-memory\",\n\tValidation = \"validation\"\n}\n\nexport enum GPUColorWrite {\n\tRed = 0x1,\n\tGreen = 0x2,\n\tBlue = 0x4,\n\tAlpha = 0x8,\n\tAll = 0xf\n}\nexport enum CommandSubType {\n\tShadow = \"shadow\",\n\tPick = \"pick\"\n}\nexport enum Intersect {\n\tOUTSIDE = -1,\n\tINTERSECTING = 0,\n\tINSIDE = 1\n}\n","import { BufferUsage } from \"../core/WebGPUConstant\";\r\nclass Buffer {\r\n\tpublic gpuBuffer: GPUBuffer;\r\n\tdevice: GPUDevice;\r\n\tusage: number;\r\n\tdata: ArrayBufferView;\r\n\tsize: number;\r\n\tconstructor(\r\n\t\tlabel: string,\r\n\t\tdevice: GPUDevice,\r\n\t\tusage: GPUBufferUsageFlags,\r\n\t\tdata: ArrayBufferView | null,\r\n\t\tsize?: number\r\n\t) {\r\n\t\tthis.device = device;\r\n\t\tthis.usage = usage;\r\n\t\tthis.data = data;\r\n\t\tthis.size = size != undefined ? (size + 3) & ~3 : (data.byteLength + 3) & ~3; // 4 bytes alignments (because of the upload which requires this)\r\n\t\tthis.gpuBuffer = device.createBuffer({\r\n\t\t\tlabel: label || \"\",\r\n\t\t\tsize: this.size,\r\n\t\t\tusage\r\n\t\t});\r\n\t\tif (data) this.setSubData(0, data, this.size);\r\n\t}\r\n\tstatic create(\r\n\t\tlabel: string,\r\n\t\tdevice: GPUDevice,\r\n\t\tusage: GPUBufferUsageFlags,\r\n\t\tdata: ArrayBufferView | null,\r\n\t\tsize?: number\r\n\t) {\r\n\t\treturn new Buffer(label, device, usage, data, size);\r\n\t}\r\n\tstatic createVertexBuffer(label: string, device: GPUDevice, data: ArrayBufferView): Buffer {\r\n\t\treturn new Buffer(label, device, BufferUsage.Vertex | BufferUsage.CopyDst, data, data.byteLength);\r\n\t}\r\n\r\n\tstatic createIndexBuffer(label: string, device: GPUDevice, data: ArrayBufferView): Buffer {\r\n\t\treturn new Buffer(label, device, BufferUsage.Index | BufferUsage.CopyDst, data);\r\n\t}\r\n\r\n\tstatic createUniformBuffer(label: string, device: GPUDevice, size: number, usage?: BufferUsage): Buffer {\r\n\t\treturn new Buffer(label, device, usage, null, size);\r\n\t}\r\n\tstatic getBufferType(usage) {\r\n\t\tlet result;\r\n\t\tswitch (usage) {\r\n\t\t\tcase BufferUsage.Uniform:\r\n\t\t\t\tresult = \"uniform\";\r\n\t\t\t\tbreak;\r\n\t\t\tcase BufferUsage.Storage:\r\n\t\t\t\tresult = \"storage\";\r\n\t\t\t\tbreak;\r\n\t\t\tdefault:\r\n\t\t\t\tbreak;\r\n\t\t}\r\n\t}\r\n\t// https://github.com/gpuweb/gpuweb/blob/main/design/BufferOperations.md\r\n\tpublic setSubData(offset: number, data: ArrayBufferView, size?: number): void {\r\n\t\tconst srcArrayBuffer = data.buffer;\r\n\t\tconst byteCount = size ?? srcArrayBuffer.byteLength;\r\n\t\tconst srcBuffer = this.device.createBuffer({\r\n\t\t\tmappedAtCreation: true,\r\n\t\t\tsize: byteCount,\r\n\t\t\tusage: GPUBufferUsage.COPY_SRC\r\n\t\t});\r\n\t\tconst arrayBuffer = srcBuffer.getMappedRange();\r\n\r\n\t\tnew Uint16Array(arrayBuffer).set(new Uint16Array(srcArrayBuffer)); // memcpy\r\n\t\tsrcBuffer.unmap();\r\n\r\n\t\tthis.copyToBuffer(srcBuffer, offset, byteCount);\r\n\r\n\t\tsrcBuffer.destroy();\r\n\t}\r\n\r\n\tpublic copyToBuffer(srcBuffer: GPUBuffer, offset: number, byteCount: number): void {\r\n\t\tconst commandEncoder = this.device.createCommandEncoder();\r\n\t\tcommandEncoder.copyBufferToBuffer(srcBuffer, 0, this.gpuBuffer, offset, byteCount);\r\n\t\tthis.device.queue.submit([commandEncoder.finish()]);\r\n\t}\r\n\r\n\tpublic copyToTexture(\r\n\t\tbytesPerRow: number,\r\n\t\trowsPerImage: number,\r\n\t\tdestination: GPUImageCopyTexture,\r\n\t\textent: GPUExtent3D\r\n\t): void {\r\n\t\tconst commandEncoder = this.device.createCommandEncoder();\r\n\t\tcommandEncoder.copyBufferToTexture(\r\n\t\t\t{\r\n\t\t\t\tbuffer: this.gpuBuffer,\r\n\t\t\t\tbytesPerRow,\r\n\t\t\t\trowsPerImage\r\n\t\t\t},\r\n\t\t\tdestination,\r\n\t\t\textent\r\n\t\t);\r\n\t\tthis.device.queue.submit([commandEncoder.finish()]);\r\n\t}\r\n\r\n\tpublic destroy(): void {\r\n\t\tthis.gpuBuffer.destroy();\r\n\t}\r\n}\r\n\r\nexport default Buffer;\r\n","import BindGroupLayout from \"./BindGroupLayout\";\r\n\r\nconst pipelineLayoutCache = new Map();\r\nexport class PipelineLayout {\r\n  public gpuPipelineLayout: GPUPipelineLayout;\r\n  index: number;\r\n  private constructor(\r\n    device: GPUDevice,\r\n    label: string,\r\n    public groupLayouts: BindGroupLayout[] = [],\r\n    index?: number\r\n  ) {\r\n    this.index = index || 0;\r\n    this.gpuPipelineLayout = device.createPipelineLayout({\r\n      label: label,\r\n      bindGroupLayouts: groupLayouts.map((layout) => {\r\n        return layout.gpuBindGroupLayout;\r\n      }),\r\n    });\r\n  }\r\n  static getPipelineLayoutFromCache(\r\n    device: GPUDevice,\r\n    label: string,\r\n    groupLayouts: BindGroupLayout[]\r\n  ): PipelineLayout {\r\n    if (pipelineLayoutCache.has(label)) {\r\n      return pipelineLayoutCache.get(label);\r\n    } else {\r\n      const bindGroupLayout = new PipelineLayout(device, label, groupLayouts);\r\n      pipelineLayoutCache.set(label, bindGroupLayout);\r\n      return bindGroupLayout;\r\n    }\r\n  }\r\n}\r\n","import BindGroupLayout from \"./BindGroupLayout\";\r\nimport { ComputeCommand } from \"./ComputeCommand\";\r\nimport DrawCommand from \"./DrawCommand\";\r\nimport { PipelineLayout } from \"./PipelineLayout\";\r\nimport { RenderState } from \"./RenderState\";\r\n\r\nconst renderPipelines = new Map();\r\nconst computePipelines = new Map();\r\nexport default class Pipeline {\r\n\tgpuPipeline: GPURenderPipeline | GPUComputePipeline;\r\n\ttype: string;\r\n\tdevice: GPUDevice;\r\n\tdescriptor: GPURenderPipelineDescriptor | GPUComputePipelineDescriptor;\r\n\tconstructor(\r\n\t\ttype: string,\r\n\t\tdevice: GPUDevice,\r\n\t\tdescriptor: GPURenderPipelineDescriptor | GPUComputePipelineDescriptor\r\n\t) {\r\n\t\tthis.type = type;\r\n\t\tthis.descriptor = descriptor;\r\n\t\tthis.device = device;\r\n\t\tthis.createPipeline();\r\n\t}\r\n\tprivate createPipeline() {\r\n\t\tif (this.type == \"render\") {\r\n\t\t\tthis.gpuPipeline = this.device.createRenderPipeline(this.descriptor as GPURenderPipelineDescriptor);\r\n\t\t} else {\r\n\t\t\tthis.gpuPipeline = this.device.createComputePipeline(this.descriptor as GPUComputePipelineDescriptor);\r\n\t\t}\r\n\t}\r\n\tpublic bind(passEncoder: GPURenderPassEncoder | GPUComputePassEncoder) {\r\n\t\tif (this.type == \"render\") {\r\n\t\t\t(passEncoder as GPURenderPassEncoder).setPipeline(this.gpuPipeline as GPURenderPipeline);\r\n\t\t} else {\r\n\t\t\t(passEncoder as GPUComputePassEncoder).setPipeline(this.gpuPipeline as GPUComputePipeline);\r\n\t\t}\r\n\t}\r\n\tstatic getRenderPipelineFromCache(\r\n\t\tdevice: GPUDevice,\r\n\t\tdrawComand: DrawCommand,\r\n\t\tgroupLayouts: BindGroupLayout[]\r\n\t): Pipeline {\r\n\t\tconst { renderState, shaderSource } = drawComand;\r\n\t\tconst rsStr = JSON.stringify(renderState);\r\n\t\tconst combineStr = shaderSource.uid.concat(rsStr);\r\n\t\tconst hashId = stringToHash(combineStr);\r\n\t\tconst combineLayouts = groupLayouts\r\n\t\t\t?.filter((layout) => layout != undefined)\r\n\t\t\t?.sort((layout1, layout2) => layout1.index - layout2.index);\r\n\t\tlet pipeline = renderPipelines.get(hashId);\r\n\t\tif (!pipeline) {\r\n\t\t\tconst descriptor = Pipeline.getPipelineDescriptor(\r\n\t\t\t\tdevice,\r\n\t\t\t\tdrawComand,\r\n\t\t\t\trenderState,\r\n\t\t\t\tcombineLayouts,\r\n\t\t\t\thashId.toString()\r\n\t\t\t);\r\n\t\t\tpipeline = new Pipeline(\"render\", device, descriptor);\r\n\t\t\trenderPipelines.set(hashId, pipeline);\r\n\t\t}\r\n\t\treturn pipeline;\r\n\t}\r\n\tstatic getComputePipelineFromCache(\r\n\t\tdevice: GPUDevice,\r\n\t\tcomputeCommad: ComputeCommand,\r\n\t\tgroupLayouts: BindGroupLayout[]\r\n\t): Pipeline {\r\n\t\tconst { shaderSource } = computeCommad;\r\n\t\tconst hashId = stringToHash(shaderSource.uid);\r\n\t\tlet pipeline = computePipelines.get(hashId);\r\n\t\tif (!pipeline) {\r\n\t\t\tpipeline = device.createComputePipeline({\r\n\t\t\t\tlayout: PipelineLayout.getPipelineLayoutFromCache(device, hashId.toString(), groupLayouts)\r\n\t\t\t\t\t.gpuPipelineLayout,\r\n\t\t\t\tcompute: {\r\n\t\t\t\t\tmodule: shaderSource.createShaderModule(device) as GPUShaderModule,\r\n\t\t\t\t\tentryPoint: shaderSource.computeMain\r\n\t\t\t\t}\r\n\t\t\t});\r\n\t\t\tcomputePipelines.set(hashId, pipeline);\r\n\t\t}\r\n\t\treturn pipeline;\r\n\t}\r\n\tprivate static getPipelineDescriptor(\r\n\t\tdevice: GPUDevice,\r\n\t\tdrawComand: DrawCommand,\r\n\t\trenderState: RenderState,\r\n\t\tgroupLayouts: BindGroupLayout[],\r\n\t\thashId: string\r\n\t): GPURenderPipelineDescriptor {\r\n\t\tconst { vertexBuffer, shaderSource } = drawComand;\r\n\t\tconst { vert, frag } = shaderSource.createShaderModule(device) as {\r\n\t\t\tvert: GPUShaderModule;\r\n\t\t\tfrag: GPUShaderModule;\r\n\t\t};\r\n\t\tconst pipelineDec = {\r\n\t\t\tlayout: PipelineLayout.getPipelineLayoutFromCache(device, hashId, groupLayouts).gpuPipelineLayout\r\n\t\t} as any;\r\n\t\tif (vert)\r\n\t\t\tpipelineDec.vertex = {\r\n\t\t\t\tmodule: vert,\r\n\t\t\t\tentryPoint: shaderSource.vertEntryPoint,\r\n\t\t\t\tbuffers: vertexBuffer.getBufferDes() as Iterable<GPUVertexBufferLayout>\r\n\t\t\t};\r\n\t\tif (renderState.primitive) pipelineDec.primitive = renderState.primitive.getGPUPrimitiveDec();\r\n\t\tif (renderState.depthStencil) pipelineDec.depthStencil = renderState.depthStencil.getGPUDepthStencilDec();\r\n\t\tif (renderState.multisample) pipelineDec.multisample = renderState.multisample.getMultiSampleDec();\r\n\t\tif (frag)\r\n\t\t\tpipelineDec.fragment = {\r\n\t\t\t\tmodule: frag,\r\n\t\t\t\tentryPoint: shaderSource.fragEntryPoint,\r\n\t\t\t\ttargets: renderState.targets.map((target) => {\r\n\t\t\t\t\treturn target.getGPUTargetDec();\r\n\t\t\t\t})\r\n\t\t\t};\r\n\t\treturn pipelineDec;\r\n\t}\r\n}\r\n// Borrowed from https://werxltd.com/wp/2010/05/13/javascript-implementation-of-javas-string-hashcode-method/\r\nfunction stringToHash(str) {\r\n\tlet hash = 0;\r\n\tif (str.length == 0) return hash;\r\n\tfor (let i = 0; i < str.length; i++) {\r\n\t\tconst char = str.charCodeAt(i);\r\n\t\thash = (hash << 5) - hash + char;\r\n\t\thash = hash & hash; // Convert to 32bit integer\r\n\t}\r\n\treturn hash;\r\n}\r\n","import Camera from \"../camera/Camera\";\r\nimport { Material } from \"../material/Material\";\r\nimport Matrix4 from \"../math/Matrix4\";\r\nimport { ShaderSource } from \"../shader/ShaderSource\";\r\nimport { Command } from \"./Command\";\r\nimport Context from \"./Context\";\r\nimport IndexBuffer from \"./IndexBuffer\";\r\nimport Pipeline from \"./Pipeline\";\r\nimport { RenderState } from \"./RenderState\";\r\nimport RenderTarget from \"./RenderTarget\";\r\nimport ShaderData from \"./ShaderData\";\r\nimport VertextBuffer from \"./VertextBuffer\";\r\n\r\nclass DrawCommand implements Command {\r\n\tpublic type?: string;\r\n\r\n\tpublic shaderData?: ShaderData;\r\n\r\n\tpublic renderTarget?: RenderTarget;\r\n\r\n\tpublic vertexBuffer?: VertextBuffer;\r\n\r\n\tpublic indexBuffer?: IndexBuffer;\r\n\r\n\tpublic renderState?: RenderState;\r\n\r\n\tpublic queryIndex?: number;\r\n\r\n\tpublic count?: number;\r\n\r\n\tpublic instances?: number;\r\n\r\n\tpublic shaderSource?: ShaderSource;\r\n\r\n\tpublic dirty?: boolean;\r\n\r\n\tpublic light?: boolean;\r\n\r\n\tpublic indirectBuffer?: Buffer;\r\n\r\n\tpublic modelMatrix?: Matrix4;\r\n\r\n\tpublic lightShaderData?: ShaderData;\r\n\r\n\tconstructor(options: DrawCommandProps) {\r\n\t\tthis.type = options.type;\r\n\r\n\t\tthis.shaderData = options.shaderData;\r\n\r\n\t\tthis.renderTarget = options.renderTarget;\r\n\r\n\t\tthis.vertexBuffer = options.vertexBuffer;\r\n\r\n\t\tthis.indexBuffer = options.indexBuffer;\r\n\r\n\t\tthis.renderState = options.renderState;\r\n\r\n\t\tthis.queryIndex = options.queryIndex;\r\n\r\n\t\tthis.count = options.count;\r\n\r\n\t\tthis.instances = options.instances;\r\n\r\n\t\tthis.shaderSource = options.shaderSource;\r\n\r\n\t\tthis.dirty = options.dirty;\r\n\r\n\t\tthis.light = options.light;\r\n\r\n\t\tthis.modelMatrix = options.modelMatrix;\r\n\r\n\t\tthis.lightShaderData = options.lightShaderData;\r\n\t}\r\n\tpublic shallowClone(material?: Material) {\r\n\t\tif (material) {\r\n\t\t\treturn new DrawCommand({\r\n\t\t\t\tvertexBuffer: this.vertexBuffer,\r\n\t\t\t\tindexBuffer: this.indexBuffer,\r\n\t\t\t\tshaderData: material.shaderData,\r\n\t\t\t\tinstances: this.instances,\r\n\t\t\t\tcount: this.count,\r\n\t\t\t\trenderState: material.renderState,\r\n\t\t\t\tshaderSource: material.shaderSource,\r\n\t\t\t\ttype: \"render\",\r\n\t\t\t\tlight: material.light,\r\n\t\t\t\tmodelMatrix: this.modelMatrix,\r\n\t\t\t\tlightShaderData: material.light ? this.lightShaderData : undefined\r\n\t\t\t});\r\n\t\t}\r\n\t}\r\n\tpublic render(context?: Context, passEncoder?: GPURenderPassEncoder, camera?: Camera): void {\r\n\t\tconst {\r\n\t\t\tshaderData,\r\n\t\t\tmodelMatrix,\r\n\t\t\trenderState,\r\n\t\t\tvertexBuffer,\r\n\t\t\tindexBuffer,\r\n\t\t\tlightShaderData,\r\n\t\t\tshaderSource,\r\n\t\t\tcount,\r\n\t\t\tinstances,\r\n\t\t\trenderTarget\r\n\t\t} = this;\r\n\t\tconst currentPassEncoder = renderTarget?.beginRenderPassEncoder?.(context) ?? passEncoder;\r\n\t\tconst defines = Object.assign({}, lightShaderData?.defines ?? {}, camera?.shaderData?.defines ?? {});\r\n\t\tconst { device } = context;\r\n\r\n\t\tif (modelMatrix) shaderData?.replaceUniformBufferValue?.(\"modelMatrix\", modelMatrix);\r\n\r\n\t\tshaderData?.bind?.(context, currentPassEncoder);\r\n\r\n\t\tcamera?.shaderData?.bind(context, currentPassEncoder);\r\n\r\n\t\tlightShaderData?.bind?.(context, currentPassEncoder);\r\n\r\n\t\trenderState?.bind?.(currentPassEncoder, context);\r\n\r\n\t\tvertexBuffer?.bind?.(device, currentPassEncoder);\r\n\r\n\t\tindexBuffer?.bind?.(device, currentPassEncoder);\r\n\r\n\t\tshaderSource?.setDefines?.(defines);\r\n\r\n\t\tconst pipeline = Pipeline.getRenderPipelineFromCache(device, this, [\r\n\t\t\tshaderData?.groupLayout,\r\n\t\t\tlightShaderData?.groupLayout,\r\n\t\t\tcamera?.shaderData?.groupLayout\r\n\t\t]);\r\n\t\tpipeline.bind(currentPassEncoder);\r\n\t\tif (indexBuffer) {\r\n\t\t\tcurrentPassEncoder.drawIndexed(count || 0, instances || 1, 0, 0, 0);\r\n\t\t} else if (count) {\r\n\t\t\tcurrentPassEncoder.draw(count, instances || 1, 0, 0);\r\n\t\t}\r\n\t\trenderTarget?.endRenderPassEncoder?.();\r\n\t}\r\n}\r\ntype DrawCommandProps = {\r\n\ttype?: string;\r\n\r\n\tshaderData?: ShaderData;\r\n\r\n\trenderTarget?: RenderTarget;\r\n\r\n\tvertexBuffer?: VertextBuffer;\r\n\r\n\tindexBuffer?: IndexBuffer;\r\n\r\n\trenderState?: RenderState;\r\n\r\n\tqueryIndex?: number;\r\n\r\n\tcount?: number;\r\n\r\n\tinstances?: number;\r\n\r\n\tshaderSource?: ShaderSource;\r\n\r\n\tdirty?: boolean;\r\n\r\n\tlight?: boolean;\r\n\r\n\tmodelMatrix?: Matrix4;\r\n\r\n\tlightShaderData?: ShaderData;\r\n};\r\nexport default DrawCommand;\r\n","import BindGroupLayout from \"../render/BindGroupLayout\";\r\nimport BindGroupEntity from \"../render/BindGroupEntity\";\r\nimport Texture from \"../render/Texture\";\r\nimport {\r\n\tBlendFactor,\r\n\tBlendOperation,\r\n\tColorWriteFlags,\r\n\tCompareFunction,\r\n\tCullMode,\r\n\tFrontFace,\r\n\tIndexFormat,\r\n\tPrimitiveTopology,\r\n\tStencilOperation,\r\n\tTextureFormat\r\n} from \"./WebGPUConstant\";\r\nimport Sampler from \"../render/Sampler\";\r\nimport PostEffect from \"../post-process/PostEffect\";\r\nimport { Light } from \"../light/Light\";\r\nimport { Mesh } from \"../mesh/Mesh\";\r\nexport const GPUCanvasCompositingAlphaMode: {\r\n\t[key: string]: GPUCanvasCompositingAlphaMode;\r\n} = {\r\n\tOpaque: \"opaque\",\r\n\tPremultiplied: \"premultiplied\"\r\n};\r\nexport interface ContextState {\r\n\tdevice: GPUDevice;\r\n\tglslang: {\r\n\t\tcompileGLSL: (source: string, type: string) => string;\r\n\t};\r\n\tdebug: boolean;\r\n\terror: boolean;\r\n}\r\n\r\nexport interface ContextOptions {\r\n\tcanvas?: HTMLCanvasElement;\r\n\tcontainer?: HTMLDivElement;\r\n\tcontext?: GPUCanvasContext;\r\n\tpixelRatio?: number;\r\n}\r\n\r\nexport interface LightMangerOptions {\r\n\topenShadow: boolean;\r\n}\r\n\r\nexport interface BindGroupLayoutEntry extends GPUBindGroupLayoutEntry {\r\n\tname: string;\r\n\tuniforms?: any[];\r\n\tdimension?: GPUTextureDimension;\r\n}\r\n\r\nexport interface BindGroupOptions extends GPUBindGroupDescriptor {\r\n\tresources: GPUBindingResource[];\r\n}\r\n\r\nexport type ShaderStageName = \"vertex\" | \"fragment\" | \"compute\";\r\n\r\nexport type ShaderStageNameObjectKeys = {\r\n\t[key in ShaderStageName]?: string;\r\n};\r\nexport type ShaderStageBodyName = \"vertexBody\" | \"fragmentBody\" | \"computeBody\";\r\nexport type ShaderStageBodyNameObjectKeys = {\r\n\t[key in ShaderStageBodyName]?: string;\r\n};\r\nexport interface AttachmentOptions {\r\n\top?: GPUStoreOp;\r\n\ttexture?: Texture;\r\n\tresolveTarget?: Texture;\r\n\tstoreOp?: GPUStoreOp;\r\n}\r\n\r\nexport type PassType = \"render\" | \"compute\";\r\n\r\nexport type GPUBindingType =\r\n\t| GPUBufferBindingType\r\n\t| GPUSamplerBindingType\r\n\t| GPUTextureSampleType\r\n\t| GPUStorageTextureAccess;\r\n\r\nexport type BindGroupLayoutEntryType = {\r\n\tbinding: number;\r\n\tvisibility: GPUShaderStageFlags;\r\n\tuniforms?: any[];\r\n\tbuffer?: GPUBufferBindingLayout;\r\n\tsampler?: GPUSamplerBindingLayout;\r\n\ttexture?: GPUTextureBindingLayout;\r\n\tstorageTexture?: GPUStorageTextureBindingLayout;\r\n\texternalTexture?: GPUExternalTextureBindingLayout;\r\n};\r\nexport type BufferResourceType = {\r\n\tbuffer: GPUBufferBindingType;\r\n\toffset: number;\r\n\tsize: number;\r\n};\r\nexport type samplerBindEntityResourceType = {\r\n\tresource: GPUSampler;\r\n};\r\nexport type textureBindEntityResourceType = {\r\n\tresource: GPUTextureView;\r\n};\r\nexport type BindGroupEntityResourceType =\r\n\t| BufferResourceType\r\n\t| samplerBindEntityResourceType\r\n\t| textureBindEntityResourceType;\r\nexport type BindGroupEntityOptions = {\r\n\tbinding: number;\r\n\tresource: GPUBindingResource;\r\n};\r\nexport type BindGroupCacheOptions = {\r\n\tdevice: GPUDevice;\r\n\tlabel: string;\r\n\tlayout: BindGroupLayout;\r\n\tentires: BindGroupEntity[];\r\n\tindex?: number;\r\n\toffset?: number;\r\n\talignedSize?: number;\r\n\tmaxOffset?: number;\r\n\tdynamic?: boolean;\r\n};\r\nexport type ImageData = {\r\n\tsource: ImageBitmap | HTMLCanvasElement | Texture;\r\n\twidth?: number;\r\n\theight?: number;\r\n\tdepth?: number;\r\n\tsourceX?: number;\r\n\tsourceY?: number;\r\n\tmipLevel?: number;\r\n\tx?: number;\r\n\ty?: number;\r\n\tz?: number;\r\n\taspect?: \"all\" | \"stencil-only\" | \"depth-only\";\r\n\tcolorSpace?: \"srgb\";\r\n\tpremultipliedAlpha?: boolean;\r\n};\r\nexport type WebGPUTextureProps = {\r\n\tsize: textureSize;\r\n\r\n\tfixedSize?: boolean;\r\n\r\n\tformat: string;\r\n\r\n\tlabel?: string;\r\n\r\n\tusage?: number;\r\n\r\n\tsampler?: Sampler;\r\n\r\n\tdata?: ImageData | Array<ImageData>;\r\n\r\n\tmipLevelCount?: number;\r\n\r\n\tsampleCount?: number;\r\n\r\n\tdimension?: dimension;\r\n\r\n\tviewFormats?: string;\r\n\r\n\tsampleType?: string;\r\n\r\n\tneedMipMap?: boolean;\r\n\r\n\tdataIsTexture?: boolean;\r\n};\r\nexport type textureSize = {\r\n\twidth: number;\r\n\theight: number;\r\n\tdepth: number;\r\n};\r\nexport type dimension = \"1d\" | \"2d\" | \"3d\";\r\nexport type bufferLayoutType = {\r\n\ttype: string; //\"uniform\"\r\n\thasDynamicOffset?: Boolean;\r\n\tminBindingSize?: number;\r\n};\r\n//renderstate\r\nexport type DepthStencil = {\r\n\tformat: TextureFormat;\r\n\tdepthWriteEnabled: boolean;\r\n\tdepthCompare: CompareFunction;\r\n\tstencilReadMask?: number;\r\n\tstencilWriteMask?: number;\r\n\tstencilFront?: {\r\n\t\tcompare: CompareFunction;\r\n\t\tfailOp: StencilOperation;\r\n\t\tdepthFailOp: StencilOperation;\r\n\t\tpassOp: StencilOperation;\r\n\t};\r\n\tstencilBack?: {\r\n\t\tcompare: CompareFunction;\r\n\t\tfailOp: StencilOperation;\r\n\t\tdepthFailOp: StencilOperation;\r\n\t\tpassOp: StencilOperation;\r\n\t};\r\n\tdepthBias?: number;\r\n\tdepthBiasSlopeScale?: number;\r\n\tdepthBiasClamp?: number;\r\n};\r\nexport type PrimitiveState = {\r\n\tfrontFace?: FrontFace;\r\n\tcullMode?: CullMode;\r\n\tunclippedDepth?: boolean;\r\n\ttopology?: PrimitiveTopology;\r\n\tstripIndexFormat?: IndexFormat;\r\n};\r\nexport type MultiSample = {\r\n\tcount?: number;\r\n\tmask?: number;\r\n\talphaToCoverageEnabled?: boolean;\r\n};\r\nexport type Target = {\r\n\tformat: TextureFormat;\r\n\tblend?: {\r\n\t\tcolor: {\r\n\t\t\toperation: BlendOperation;\r\n\t\t\tsrcFactor: BlendFactor;\r\n\t\t\tdstFactor: BlendFactor;\r\n\t\t};\r\n\t\talpha: {\r\n\t\t\toperation: BlendOperation;\r\n\t\t\tsrcFactor: BlendFactor;\r\n\t\t\tdstFactor: BlendFactor;\r\n\t\t};\r\n\t};\r\n\twriteMask: ColorWriteFlags;\r\n};\r\nexport type BlendConstant = {\r\n\tr: number;\r\n\tg: number;\r\n\tb: number;\r\n\ta: number;\r\n};\r\nexport type RenderStateProps = {\r\n\tdepthStencil?: DepthStencil;\r\n\tprimitive?: PrimitiveState;\r\n\tmultisample?: MultiSample;\r\n\tstencilReference?: number;\r\n\ttargets?: Array<Target>;\r\n\tviewport?: { x: number; y: number; width: number; height: number };\r\n\tblendConstant?: BlendConstant;\r\n\tscissorTestEnabled?: boolean;\r\n\tstencilEnabled?: boolean;\r\n};\r\nexport type ViewPort = {\r\n\tx: number;\r\n\ty: number;\r\n\twidth: number;\r\n\theight: number;\r\n};\r\nexport type ScissorTest = {\r\n\tx: number;\r\n\ty: number;\r\n\twidth: number;\r\n\theight: number;\r\n};\r\nexport type ShaderMaterialParms = {\r\n\ttype: string;\r\n\tfrag: string | Function;\r\n\tvert: string | Function;\r\n\tuniforms: { [uniform: string]: IUniform };\r\n\tdefines?: any;\r\n\tlight?: boolean;\r\n};\r\nexport interface IUniform<TValue = any> {\r\n\ttype: string;\r\n\tvalue: TValue;\r\n}\r\nexport type Uniforms = { [uniform: string]: IUniform };\r\nexport type Instance = Mesh | PostEffect | Light;\r\n\r\nexport enum RenderObjectType {\r\n\tCamera = \"camera\",\r\n\tLight = \"light\",\r\n\tMesh = \"mesh\",\r\n\tSkinMesh = \"skinMesh\",\r\n\tNode = \"node\",\r\n\tAxes = \"axes\",\r\n\tSkybox = \"skyBox\",\r\n\tPostEffect = \"postEffect\",\r\n\tDebug = \"debug\"\r\n}\r\nexport enum LightType {\r\n\tSpotLight = \"spotLight\",\r\n\tPointLight = \"pointLight\",\r\n\tAmbientLight = \"ambientLight\",\r\n\tDirectionalLight = \"directionalLight\"\r\n}\r\n","import Texture from \"../render/Texture\";\r\n\r\nexport class MipmapGenerator {\r\n\tdevice: GPUDevice;\r\n\tsampler: GPUSampler;\r\n\tpipelines: object;\r\n\tmipmapShaderModule: GPUShaderModule;\r\n\tconstructor(device) {\r\n\t\tthis.device = device;\r\n\t\tthis.sampler = device.createSampler({ minFilter: \"linear\" });\r\n\t\t// We'll need a new pipeline for every texture format used.\r\n\t\tthis.pipelines = {};\r\n\t}\r\n\tprivate getMipmapPipeline(format) {\r\n\t\tlet pipeline = this.pipelines[format];\r\n\t\tif (!pipeline) {\r\n\t\t\t// Shader modules is shared between all pipelines, so only create once.\r\n\t\t\tif (!this.mipmapShaderModule) {\r\n\t\t\t\tthis.mipmapShaderModule = this.device.createShaderModule({\r\n\t\t\t\t\tcode: `\r\n              var<private> pos : array<vec2<f32>, 3> = array<vec2<f32>, 3>(\r\n                vec2<f32>(-1.0, -1.0), vec2<f32>(-1.0, 3.0), vec2<f32>(3.0, -1.0));\r\n              struct VertexOutput {\r\n                @builtin(position) position : vec4<f32>,\r\n                @location(0) texCoord : vec2<f32>,\r\n              };\r\n              @vertex\r\n              fn vertexMain(@builtin(vertex_index) vertexIndex : u32) -> VertexOutput {\r\n                var output : VertexOutput;\r\n                output.texCoord = pos[vertexIndex] * vec2<f32>(0.5, -0.5) + vec2<f32>(0.5);\r\n                output.position = vec4<f32>(pos[vertexIndex], 0.0, 1.0);\r\n                return output;\r\n              }\r\n              @group(0) @binding(0) var imgSampler : sampler;\r\n              @group(0) @binding(1) var img : texture_2d<f32>;\r\n              @fragment\r\n              fn fragmentMain(@location(0) texCoord : vec2<f32>) -> @location(0) vec4<f32> {\r\n                return textureSample(img, imgSampler, texCoord);\r\n              }\r\n            `\r\n\t\t\t\t});\r\n\t\t\t}\r\n\r\n\t\t\tpipeline = this.device.createRenderPipeline({\r\n\t\t\t\tlayout: \"auto\",\r\n\t\t\t\tvertex: {\r\n\t\t\t\t\tmodule: this.mipmapShaderModule,\r\n\t\t\t\t\tentryPoint: \"vertexMain\"\r\n\t\t\t\t},\r\n\t\t\t\tfragment: {\r\n\t\t\t\t\tmodule: this.mipmapShaderModule,\r\n\t\t\t\t\tentryPoint: \"fragmentMain\",\r\n\t\t\t\t\ttargets: [{ format }]\r\n\t\t\t\t}\r\n\t\t\t});\r\n\t\t\tthis.pipelines[format] = pipeline;\r\n\t\t}\r\n\t\treturn pipeline;\r\n\t}\r\n\r\n\t/**\r\n\t * Generates mipmaps for the given GPUTexture from the data in level 0.\r\n\t *\r\n\t * @param {module:External.GPUTexture} texture - Texture to generate mipmaps for.\r\n\t * @param {object} textureDescriptor - GPUTextureDescriptor the texture was created with.\r\n\t * @returns {module:External.GPUTexture} - The originally passed texture\r\n\t */\r\n\tgenerateMipmap(sourceTexture: Texture) {\r\n\t\tconst texture = sourceTexture.gpuTexture;\r\n\t\tconst textureDescriptor = sourceTexture.textureProp;\r\n\t\t// TODO: Does this need to handle sRGB formats differently?\r\n\t\tconst pipeline = this.getMipmapPipeline(textureDescriptor.format);\r\n\r\n\t\tif (textureDescriptor.dimension == \"3d\" || textureDescriptor.dimension == \"1d\") {\r\n\t\t\tthrow new Error(\"Generating mipmaps for non-2d textures is currently unsupported!\");\r\n\t\t}\r\n\r\n\t\tlet mipTexture = texture;\r\n\t\tconst arrayLayerCount = textureDescriptor.size.depth || 1; // Only valid for 2D textures.\r\n\r\n\t\t// If the texture was created with RENDER_ATTACHMENT usage we can render directly between mip levels.\r\n\t\tconst renderToSource = textureDescriptor.usage & GPUTextureUsage.RENDER_ATTACHMENT;\r\n\t\tif (!renderToSource) {\r\n\t\t\t// Otherwise we have to use a separate texture to render into. It can be one mip level smaller than the source\r\n\t\t\t// texture, since we already have the top level.\r\n\t\t\tconst mipTextureDescriptor = {\r\n\t\t\t\tsize: {\r\n\t\t\t\t\twidth: Math.ceil(textureDescriptor.size.width / 2),\r\n\t\t\t\t\theight: Math.ceil(textureDescriptor.size.height / 2),\r\n\t\t\t\t\tdepthOrArrayLayers: arrayLayerCount\r\n\t\t\t\t},\r\n\t\t\t\tformat: <GPUTextureFormat>textureDescriptor.format,\r\n\t\t\t\tusage: GPUTextureUsage.TEXTURE_BINDING | GPUTextureUsage.COPY_SRC | GPUTextureUsage.RENDER_ATTACHMENT,\r\n\t\t\t\tmipLevelCount: textureDescriptor.mipLevelCount - 1\r\n\t\t\t};\r\n\t\t\tmipTexture = this.device.createTexture(mipTextureDescriptor);\r\n\t\t}\r\n\r\n\t\tconst commandEncoder = this.device.createCommandEncoder({});\r\n\t\t// TODO: Consider making this static.\r\n\t\tconst bindGroupLayout = pipeline.getBindGroupLayout(0);\r\n\r\n\t\tfor (let arrayLayer = 0; arrayLayer < arrayLayerCount; ++arrayLayer) {\r\n\t\t\tlet srcView = texture.createView({\r\n\t\t\t\tbaseMipLevel: 0,\r\n\t\t\t\tmipLevelCount: 1,\r\n\t\t\t\tdimension: \"2d\",\r\n\t\t\t\tbaseArrayLayer: arrayLayer,\r\n\t\t\t\tarrayLayerCount: 1\r\n\t\t\t});\r\n\r\n\t\t\tlet dstMipLevel = renderToSource ? 1 : 0;\r\n\t\t\tfor (let i = 1; i < textureDescriptor.mipLevelCount; ++i) {\r\n\t\t\t\tconst dstView = mipTexture.createView({\r\n\t\t\t\t\tbaseMipLevel: dstMipLevel++,\r\n\t\t\t\t\tmipLevelCount: 1,\r\n\t\t\t\t\tdimension: \"2d\",\r\n\t\t\t\t\tbaseArrayLayer: arrayLayer,\r\n\t\t\t\t\tarrayLayerCount: 1\r\n\t\t\t\t});\r\n\r\n\t\t\t\tconst passEncoder = commandEncoder.beginRenderPass({\r\n\t\t\t\t\tcolorAttachments: [\r\n\t\t\t\t\t\t{\r\n\t\t\t\t\t\t\tview: dstView,\r\n\t\t\t\t\t\t\tloadOp: \"clear\",\r\n\t\t\t\t\t\t\tstoreOp: \"store\"\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t]\r\n\t\t\t\t});\r\n\r\n\t\t\t\tconst bindGroup = this.device.createBindGroup({\r\n\t\t\t\t\tlayout: bindGroupLayout,\r\n\t\t\t\t\tentries: [\r\n\t\t\t\t\t\t{\r\n\t\t\t\t\t\t\tbinding: 0,\r\n\t\t\t\t\t\t\tresource: this.sampler\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t\t{\r\n\t\t\t\t\t\t\tbinding: 1,\r\n\t\t\t\t\t\t\tresource: srcView\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t]\r\n\t\t\t\t});\r\n\r\n\t\t\t\tpassEncoder.setPipeline(pipeline);\r\n\t\t\t\tpassEncoder.setBindGroup(0, bindGroup);\r\n\t\t\t\tpassEncoder.draw(3, 1, 0, 0);\r\n\t\t\t\tpassEncoder.end();\r\n\r\n\t\t\t\tsrcView = dstView;\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\t// If we didn't render to the source texture, finish by copying the mip results from the temporary mipmap texture\r\n\t\t// to the source.\r\n\t\tif (!renderToSource) {\r\n\t\t\tconst mipLevelSize = {\r\n\t\t\t\twidth: Math.ceil(textureDescriptor.size.width / 2),\r\n\t\t\t\theight: Math.ceil(textureDescriptor.size.height / 2),\r\n\t\t\t\tdepthOrArrayLayers: arrayLayerCount\r\n\t\t\t};\r\n\r\n\t\t\tfor (let i = 1; i < textureDescriptor.mipLevelCount; ++i) {\r\n\t\t\t\tcommandEncoder.copyTextureToTexture(\r\n\t\t\t\t\t{\r\n\t\t\t\t\t\ttexture: mipTexture,\r\n\t\t\t\t\t\tmipLevel: i - 1\r\n\t\t\t\t\t},\r\n\t\t\t\t\t{\r\n\t\t\t\t\t\ttexture: texture,\r\n\t\t\t\t\t\tmipLevel: i\r\n\t\t\t\t\t},\r\n\t\t\t\t\tmipLevelSize\r\n\t\t\t\t);\r\n\r\n\t\t\t\tmipLevelSize.width = Math.ceil(mipLevelSize.width / 2);\r\n\t\t\t\tmipLevelSize.height = Math.ceil(mipLevelSize.height / 2);\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\tthis.device.queue.submit([commandEncoder.finish()]);\r\n\r\n\t\tif (!renderToSource) {\r\n\t\t\tmipTexture.destroy();\r\n\t\t}\r\n\r\n\t\treturn texture;\r\n\t}\r\n}\r\n","function defaultValue(a, b) {\n\tif (a !== undefined && a !== null) {\n\t\treturn a;\n\t}\n\treturn b;\n}\n\n/**\n * A frozen empty object that can be used as the default value for options passed as\n * an object literal.\n * @type {Object}\n * @memberof defaultValue\n */\ndefaultValue.EMPTY_OBJECT = Object.freeze({});\n\nexport default defaultValue;\n","import {\r\n\tBlendFactor,\r\n\tBlendOperation,\r\n\tTextureFormat,\r\n\tGPUColorWrite,\r\n\tCompareFunction,\r\n\tStencilOperation,\r\n\tFrontFace,\r\n\tCullMode,\r\n\tPrimitiveTopology\r\n} from \"../core/WebGPUConstant\";\r\nimport defaultValue from \"../utils/defaultValue\";\r\nimport Context from \"./Context\";\r\n\r\nexport class RenderState {\r\n\tscissorTest: ScissorTest;\r\n\tviewport: ViewPort;\r\n\ttargets: Array<Target>;\r\n\tdepthStencil: DepthStencil;\r\n\tblendConstant: BlendConstant;\r\n\tstencilReference: number;\r\n\tmultisample: MultiSample;\r\n\tprimitive: Primitive;\r\n\tstencilEnabled: boolean;\r\n\tscissorTestEnabled: boolean;\r\n\tconstructor() {\r\n\t\tthis.scissorTest = undefined;\r\n\t\tthis.viewport = undefined;\r\n\t\tthis.depthStencil = undefined;\r\n\t\tthis.blendConstant = undefined;\r\n\t\tthis.stencilReference = 0;\r\n\t\tthis.multisample = undefined;\r\n\t\tthis.primitive = undefined;\r\n\t\tthis.stencilEnabled = false;\r\n\t\tthis.scissorTestEnabled = false;\r\n\t\tthis.targets = undefined;\r\n\t}\r\n\tbind(passEncoder: GPURenderPassEncoder, context: Context) {\r\n\t\tconst { viewPort, scissorTest } = context;\r\n\t\tconst finalViewport = this.viewport ?? viewPort;\r\n\t\tconst finalScissorTest = this.scissorTest ?? scissorTest;\r\n\t\tif (this.stencilReference) passEncoder.setStencilReference(this.stencilReference);\r\n\t\tif (finalViewport.equalsAndUpdateCache(cacheViewPort)) {\r\n\t\t\tconst { x, y, width, height, minDepth, maxDepth } = finalViewport;\r\n\t\t\tpassEncoder.setViewport(x, y, width, height, minDepth, maxDepth);\r\n\t\t}\r\n\t\tif (this.blendConstant) passEncoder.setBlendConstant(this.blendConstant);\r\n\t\tif (finalScissorTest.equalsAndUpdateCache(cacheScissorTest)) {\r\n\t\t\tconst { x, y, width, height } = finalScissorTest;\r\n\t\t\tpassEncoder.setScissorRect(x, y, width, height);\r\n\t\t}\r\n\t}\r\n\tdestroy() {\r\n\t\tthis.scissorTest = undefined;\r\n\t\tthis.viewport = undefined;\r\n\t\tthis.depthStencil = undefined;\r\n\t\tthis.blendConstant = undefined;\r\n\t\tthis.stencilReference = -1;\r\n\t\tthis.multisample = undefined;\r\n\t\tthis.primitive = undefined;\r\n\t\tthis.stencilEnabled = false;\r\n\t\tthis.scissorTestEnabled = false;\r\n\t}\r\n}\r\nexport class BlendConstant {\r\n\tr: number;\r\n\tg: number;\r\n\tb: number;\r\n\ta: number;\r\n\tconstructor(r: number, g: number, b: number, a: number) {\r\n\t\tthis.r = r;\r\n\t\tthis.g = g;\r\n\t\tthis.b = b;\r\n\t\tthis.a = a;\r\n\t}\r\n}\r\nexport class MultiSample {\r\n\tcount: number;\r\n\tmask: number;\r\n\talphaToCoverageEnabled: boolean;\r\n\tconstructor(count = 1, mask = 0xffffffff, alphaToCoverageEnabled = false) {\r\n\t\tthis.count = count;\r\n\t\tthis.mask = mask;\r\n\t\tthis.alphaToCoverageEnabled = alphaToCoverageEnabled;\r\n\t}\r\n\tgetMultiSampleDec() {\r\n\t\treturn {\r\n\t\t\tcount: this.count,\r\n\t\t\tmask: this.mask,\r\n\t\t\talphaToCoverageEnabled: this.alphaToCoverageEnabled\r\n\t\t};\r\n\t}\r\n}\r\nexport class ScissorTest {\r\n\tx: number;\r\n\ty: number;\r\n\twidth: number;\r\n\theight: number;\r\n\tvariable: boolean;\r\n\tconstructor(x = 0, y = 0, width = 0, height = 0, variable = true) {\r\n\t\tthis.x = x;\r\n\t\tthis.y = y;\r\n\t\tthis.width = width;\r\n\t\tthis.height = height;\r\n\t\tthis.variable = variable;\r\n\t}\r\n\tset(x: number, y: number, width: number, height: number) {\r\n\t\tthis.x = x;\r\n\t\tthis.y = y;\r\n\t\tthis.width = width;\r\n\t\tthis.height = height;\r\n\t}\r\n\tequalsAndUpdateCache(scissorTest: ScissorTest): boolean {\r\n\t\tconst { x, y, width, height } = scissorTest;\r\n\t\tif (this.x != x || this.y != y || this.width != width || this.height != height) {\r\n\t\t\tscissorTest.set(this.x, this.y, this.width, this.height);\r\n\t\t\treturn true;\r\n\t\t}\r\n\t\treturn false;\r\n\t}\r\n}\r\nexport class ViewPort {\r\n\tx: number;\r\n\ty: number;\r\n\twidth: number;\r\n\theight: number;\r\n\tminDepth: number;\r\n\tmaxDepth: number;\r\n\tvariable: boolean;\r\n\tconstructor(x = 0, y = 0, width = 0, height = 0, minDepth = 0, maxDepth = 1, variable = true) {\r\n\t\tthis.x = x;\r\n\t\tthis.y = y;\r\n\t\tthis.width = width;\r\n\t\tthis.height = height;\r\n\t\tthis.minDepth = minDepth;\r\n\t\tthis.maxDepth = maxDepth;\r\n\t\tthis.variable = variable;\r\n\t}\r\n\tset(x: number, y: number, width: number, height: number, minDepth = 0, maxDepth = 1) {\r\n\t\tif (!this.variable) return;\r\n\t\tthis.x = x;\r\n\t\tthis.y = y;\r\n\t\tthis.width = width;\r\n\t\tthis.height = height;\r\n\t\tthis.minDepth = minDepth;\r\n\t\tthis.maxDepth = maxDepth;\r\n\t}\r\n\tequalsAndUpdateCache(viewPort: ViewPort): boolean {\r\n\t\tconst { x, y, width, height, minDepth, maxDepth } = viewPort;\r\n\t\tif (\r\n\t\t\tthis.x != x ||\r\n\t\t\tthis.y != y ||\r\n\t\t\tthis.width != width ||\r\n\t\t\tthis.height != height ||\r\n\t\t\tthis.minDepth != minDepth ||\r\n\t\t\tthis.maxDepth != maxDepth\r\n\t\t) {\r\n\t\t\tviewPort.set(this.x, this.y, this.width, this.height, this.minDepth, this.maxDepth);\r\n\t\t\treturn true;\r\n\t\t}\r\n\t\treturn false;\r\n\t}\r\n}\r\nexport class Primitive {\r\n\tfrontFace: FrontFace;\r\n\tcullMode: CullMode;\r\n\tunclippedDepth: boolean;\r\n\ttopology: PrimitiveTopology;\r\n\tconstructor(topology?: PrimitiveTopology, cullMode?: CullMode, frontFace?: FrontFace, unclippedDepth?: boolean) {\r\n\t\tthis.frontFace = defaultValue(frontFace, FrontFace.CCW);\r\n\t\tthis.cullMode = defaultValue(cullMode, CullMode.None);\r\n\t\tthis.unclippedDepth = defaultValue(unclippedDepth, false);\r\n\t\tthis.topology = defaultValue(topology, PrimitiveTopology.TriangleList);\r\n\t}\r\n\tgetGPUPrimitiveDec() {\r\n\t\treturn {\r\n\t\t\tfrontFace: this.frontFace,\r\n\t\t\tcullMode: this.cullMode,\r\n\t\t\tunclippedDepth: this.unclippedDepth,\r\n\t\t\ttopology: this.topology\r\n\t\t};\r\n\t}\r\n}\r\nexport class DepthStencil {\r\n\tformat: TextureFormat;\r\n\tdepthWriteEnabled: boolean;\r\n\tdepthCompare: CompareFunction;\r\n\tstencilReadMask: number;\r\n\tstencilWriteMask: number;\r\n\tstencilFrontCompare: CompareFunction;\r\n\tstencilFrontFailOp: StencilOperation;\r\n\tstencilFrontDepthFailOp: StencilOperation;\r\n\tstencilFrontPassOp: StencilOperation;\r\n\r\n\tstencilBackCompare: CompareFunction;\r\n\tstencilBackFailOp: StencilOperation;\r\n\tstencilBackDepthFailOp: StencilOperation;\r\n\tstencilBackPassOp: StencilOperation;\r\n\tdepthBias: number;\r\n\tdepthBiasSlopeScale: number;\r\n\tdepthBiasClamp: number;\r\n\tconstructor(options?: DepthStencilProps) {\r\n\t\tthis.format = defaultValue(options?.format, TextureFormat.Depth24Plus);\r\n\t\tthis.depthWriteEnabled = defaultValue(options?.depthWriteEnabled, true);\r\n\t\tthis.depthCompare = defaultValue(options?.depthCompare, CompareFunction.Less);\r\n\t\tthis.stencilReadMask = defaultValue(options?.stencilReadMask, 0xffffffff);\r\n\t\tthis.stencilWriteMask = defaultValue(options?.stencilWriteMask, 0xffffffff);\r\n\t\tthis.stencilFrontCompare = defaultValue(options?.stencilFrontCompare, CompareFunction.Always);\r\n\t\tthis.stencilFrontFailOp = defaultValue(options?.stencilFrontFailOp, StencilOperation.Keep);\r\n\t\tthis.stencilFrontDepthFailOp = defaultValue(options?.stencilFrontDepthFailOp, StencilOperation.Keep);\r\n\t\tthis.stencilFrontPassOp = defaultValue(options?.stencilFrontPassOp, StencilOperation.Keep);\r\n\t\tthis.stencilBackCompare = defaultValue(options?.stencilBackCompare, CompareFunction.Always);\r\n\t\tthis.stencilBackFailOp = defaultValue(options?.stencilBackFailOp, StencilOperation.Keep);\r\n\t\tthis.stencilBackDepthFailOp = defaultValue(options?.stencilBackDepthFailOp, StencilOperation.Keep);\r\n\t\tthis.stencilBackPassOp = defaultValue(options?.stencilBackPassOp, StencilOperation.Keep);\r\n\t\tthis.depthBias = defaultValue(options?.depthBias, 0);\r\n\t\tthis.depthBiasSlopeScale = defaultValue(options?.depthBiasSlopeScale, 0);\r\n\t\tthis.depthBiasClamp = defaultValue(options?.depthBiasClamp, 0);\r\n\t}\r\n\tgetGPUDepthStencilDec() {\r\n\t\treturn {\r\n\t\t\tformat: this.format,\r\n\t\t\tdepthWriteEnabled: this.depthWriteEnabled,\r\n\t\t\tdepthCompare: this.depthCompare,\r\n\t\t\tstencilReadMask: this.stencilReadMask,\r\n\t\t\tstencilWriteMask: this.stencilWriteMask,\r\n\t\t\tstencilFront: {\r\n\t\t\t\tcompare: this.stencilFrontCompare,\r\n\t\t\t\tfailOp: this.stencilFrontFailOp,\r\n\t\t\t\tdepthFailOp: this.stencilFrontDepthFailOp,\r\n\t\t\t\tpassOp: this.stencilFrontPassOp\r\n\t\t\t},\r\n\t\t\tstencilBack: {\r\n\t\t\t\tcompare: this.stencilBackCompare,\r\n\t\t\t\tfailOp: this.stencilBackFailOp,\r\n\t\t\t\tdepthFailOp: this.stencilBackDepthFailOp,\r\n\t\t\t\tpassOp: this.stencilBackPassOp\r\n\t\t\t},\r\n\t\t\tdepthBias: this.depthBias,\r\n\t\t\tdepthBiasSlopeScale: this.depthBiasSlopeScale,\r\n\t\t\tdepthBiasClamp: this.depthBiasClamp\r\n\t\t};\r\n\t}\r\n}\r\nexport class Target {\r\n\tformat: TextureFormat;\r\n\tblendColorOperation?: BlendOperation;\r\n\tblendColorSrcFactor?: BlendFactor;\r\n\tblendColorDstFactor?: BlendFactor;\r\n\tblendAlphaOperation?: BlendOperation;\r\n\tblendAlphaSrcFactor?: BlendFactor;\r\n\tblendAlphaDstFactor?: BlendFactor;\r\n\twriteMask: GPUColorWrite;\r\n\tconstructor(options?: TargetProps) {\r\n\t\tthis.format = defaultValue(options?.format, TextureFormat.BGRA8Unorm);\r\n\t\tthis.blendColorOperation = defaultValue(options?.blendColorOperation, BlendOperation.Add);\r\n\t\tthis.blendColorSrcFactor = defaultValue(options?.blendColorSrcFactor, BlendFactor?.SrcAlpha);\r\n\t\tthis.blendColorDstFactor = defaultValue(options?.blendColorDstFactor, BlendFactor.OneMinusSrcAlpha);\r\n\t\tthis.blendAlphaOperation = defaultValue(options?.blendAlphaOperation, BlendOperation.Add);\r\n\t\tthis.blendAlphaSrcFactor = defaultValue(options?.blendAlphaSrcFactor, BlendFactor.One);\r\n\t\tthis.blendAlphaDstFactor = defaultValue(options?.blendAlphaDstFactor, BlendFactor.One);\r\n\t\tthis.writeMask = defaultValue(options?.writeMask, GPUColorWrite.All);\r\n\t}\r\n\tgetGPUTargetDec() {\r\n\t\treturn {\r\n\t\t\tformat: this.format,\r\n\t\t\tblend: {\r\n\t\t\t\tcolor: {\r\n\t\t\t\t\toperation: this.blendColorOperation,\r\n\t\t\t\t\tsrcFactor: this.blendColorSrcFactor,\r\n\t\t\t\t\tdstFactor: this.blendColorDstFactor\r\n\t\t\t\t},\r\n\t\t\t\talpha: {\r\n\t\t\t\t\toperation: this.blendAlphaOperation,\r\n\t\t\t\t\tsrcFactor: this.blendAlphaSrcFactor,\r\n\t\t\t\t\tdstFactor: this.blendAlphaDstFactor\r\n\t\t\t\t}\r\n\t\t\t},\r\n\t\t\twriteMask: this.writeMask\r\n\t\t};\r\n\t}\r\n}\r\nconst cacheViewPort = new ViewPort();\r\nconst cacheScissorTest = new ScissorTest();\r\ntype DepthStencilProps = {\r\n\tformat?: TextureFormat;\r\n\tdepthWriteEnabled?: boolean;\r\n\tdepthCompare?: CompareFunction;\r\n\tstencilReadMask?: number;\r\n\tstencilWriteMask?: number;\r\n\tstencilFrontCompare?: CompareFunction;\r\n\tstencilFrontFailOp?: StencilOperation;\r\n\tstencilFrontDepthFailOp?: StencilOperation;\r\n\tstencilFrontPassOp?: StencilOperation;\r\n\r\n\tstencilBackCompare?: CompareFunction;\r\n\tstencilBackFailOp?: StencilOperation;\r\n\tstencilBackDepthFailOp?: StencilOperation;\r\n\tstencilBackPassOp?: StencilOperation;\r\n\tdepthBias?: number;\r\n\tdepthBiasSlopeScale?: number;\r\n\tdepthBiasClamp?: number;\r\n};\r\ntype TargetProps = {\r\n\tformat?: TextureFormat;\r\n\tblendColorOperation?: BlendOperation;\r\n\tblendColorSrcFactor?: BlendFactor;\r\n\tblendColorDstFactor?: BlendFactor;\r\n\tblendAlphaOperation?: BlendOperation;\r\n\tblendAlphaSrcFactor?: BlendFactor;\r\n\tblendAlphaDstFactor?: BlendFactor;\r\n\twriteMask?: GPUColorWrite;\r\n};\r\n","import { TextureUsage } from \"../core/WebGPUConstant\";\nimport { GPUCanvasCompositingAlphaMode, ContextOptions } from \"../core/WebGPUTypes\";\nimport { MipmapGenerator } from \"../utils/MipmapGenerator\";\nimport { ScissorTest, ViewPort } from \"./RenderState\";\n\nclass Context {\n\tpublic canvas: HTMLCanvasElement;\n\n\tpublic context: GPUCanvasContext;\n\n\tpublic pixelRatio: number;\n\n\tpublic device: GPUDevice;\n\n\tprivate adapter: GPUAdapter;\n\n\tpublic presentationSize: { width: number; height: number; depth: number };\n\n\tpublic presentationFormat: GPUTextureFormat;\n\n\tpublic mipmapTools: MipmapGenerator;\n\n\tprivate _viewPort: ViewPort;\n\n\tprivate _scissorTest: ScissorTest;\n\n\tpublic get viewPort(): ViewPort {\n\t\treturn this._viewPort;\n\t}\n\n\tpublic get scissorTest(): ScissorTest {\n\t\treturn this._scissorTest;\n\t}\n\tconstructor({ canvas, container, context, pixelRatio }: ContextOptions = {}) {\n\t\tif (!container.clientWidth || !container.clientHeight) throw new Error(\"container width or height illegality\");\n\t\tthis.canvas = canvas || document.createElement(\"canvas\");\n\t\t// this.canvas.style.display = \"block\";\n\t\tthis.pixelRatio = pixelRatio || window.devicePixelRatio || 1;\n\t\tconst width = container.clientWidth * this.pixelRatio;\n\t\tconst height = container.clientHeight * this.pixelRatio;\n\t\tthis.canvas.width = width;\n\t\tthis.canvas.height = height;\n\t\tthis.canvas.style.width = container.clientWidth + \"px\";\n\t\tthis.canvas.style.height = container.clientHeight + \"px\";\n\t\tcontainer.appendChild(this.canvas);\n\t\tthis.context = context || (this.canvas.getContext(\"webgpu\") as GPUCanvasContext);\n\n\t\tthis.device = undefined;\n\t}\n\n\tpublic async init(\n\t\trequestAdapter = {},\n\t\tdeviceDescriptor = {},\n\t\tpresentationContextDescriptor = {}\n\t): Promise<boolean> {\n\t\ttry {\n\t\t\tif (!this.context) {\n\t\t\t\tthrow new Error(`Failed to instantiate \"webgpu\" context.`);\n\t\t\t}\n\t\t\tif (!navigator.gpu) {\n\t\t\t\tthrow new Error(`Missing \"navigator.gpu\".`);\n\t\t\t}\n\n\t\t\tthis.adapter = await navigator.gpu.requestAdapter();\n\t\t\tthis.device = await this.adapter.requestDevice();\n\t\t\tthis.presentationSize = {\n\t\t\t\twidth: this.canvas.clientWidth * this.pixelRatio,\n\t\t\t\theight: this.canvas.clientHeight * this.pixelRatio,\n\t\t\t\tdepth: 1\n\t\t\t};\n\t\t\tthis.presentationFormat = navigator.gpu.getPreferredCanvasFormat();\n\t\t\tthis.device.addEventListener(\"uncapturederror\", (error) => {\n\t\t\t\tconsole.error(error);\n\t\t\t\t// State.error = true;\n\t\t\t});\n\t\t\tthis.mipmapTools = new MipmapGenerator(this.device);\n\t\t\tthis.context.configure({\n\t\t\t\tdevice: this.device,\n\t\t\t\tformat: this.presentationFormat,\n\t\t\t\tusage: TextureUsage.RenderAttachment,\n\t\t\t\talphaMode: \"premultiplied\",\n\t\t\t\t...presentationContextDescriptor\n\t\t\t});\n\t\t\tthis._viewPort = new ViewPort(\n\t\t\t\t0,\n\t\t\t\t0,\n\t\t\t\tthis.canvas.clientWidth * this.pixelRatio,\n\t\t\t\tthis.canvas.clientHeight * this.pixelRatio\n\t\t\t);\n\t\t\tthis._scissorTest = new ScissorTest(\n\t\t\t\t0,\n\t\t\t\t0,\n\t\t\t\tthis.canvas.clientWidth * this.pixelRatio,\n\t\t\t\tthis.canvas.clientHeight * this.pixelRatio\n\t\t\t);\n\t\t} catch (error) {\n\t\t\tconsole.error(error);\n\t\t\treturn false;\n\t\t}\n\n\t\treturn true;\n\t}\n\tpublic setViewPort(x: number, y: number, width: number, height: number) {\n\t\tthis._viewPort.set(x, y, width, height);\n\t}\n\n\tpublic resetViewPortToFullCanvas() {\n\t\tthis._viewPort.set(0, 0, this.canvas.clientWidth * this.pixelRatio, this.canvas.clientHeight * this.pixelRatio);\n\t}\n\n\tpublic setScissorTest(x: number, y: number, width: number, height: number) {\n\t\tthis._scissorTest.set(x, y, width, height);\n\t}\n\tpublic resize(width: number, height: number, presentationContextDescriptor = {}): void {\n\t\tconst w = width * this.pixelRatio;\n\t\tconst h = height * this.pixelRatio;\n\t\tthis.canvas.style.width = w + \"px\";\n\t\tthis.canvas.style.height = h + \"px\";\n\t\tthis.canvas.width = w;\n\t\tthis.canvas.height = h;\n\t\tthis.presentationSize = {\n\t\t\twidth: w,\n\t\t\theight: h,\n\t\t\tdepth: 1\n\t\t};\n\t\tthis.context.configure({\n\t\t\tdevice: this.device,\n\t\t\tformat: navigator.gpu.getPreferredCanvasFormat(),\n\t\t\tusage: TextureUsage.RenderAttachment,\n\t\t\talphaMode: GPUCanvasCompositingAlphaMode.Premultiplied,\n\t\t\t...presentationContextDescriptor\n\t\t});\n\t}\n}\n\nexport default Context;\n","import { TextureFormat } from \"../core/WebGPUConstant\";\r\nimport { WebGPUTextureProps, ImageData } from \"../core/WebGPUTypes\";\r\nimport defaultValue from \"../utils/defaultValue\";\r\nimport Context from \"./Context\";\r\nimport Sampler from \"./Sampler\";\r\n\r\nexport default class Texture {\r\n\t[x: string]: any;\r\n\tprivate _textureView: GPUTextureView;\r\n\tpublic gpuTexture?: GPUTexture;\r\n\tpublic mipLevelCount?: number;\r\n\tpublic sampler?: Sampler;\r\n\tpublic context?: Context;\r\n\tpublic textureProp?: WebGPUTextureProps;\r\n\tpublic dirty: boolean;\r\n\tpublic fixedSize: boolean;\r\n\tconstructor(textureProp: WebGPUTextureProps) {\r\n\t\tthis.textureProp = Object.assign(\r\n\t\t\t{\r\n\t\t\t\tformat: TextureFormat.RGBA8Unorm,\r\n\t\t\t\tusage: GPUTextureUsage.TEXTURE_BINDING | GPUTextureUsage.COPY_DST | GPUTextureUsage.RENDER_ATTACHMENT,\r\n\t\t\t\tdataIsTexture: false\r\n\t\t\t},\r\n\t\t\ttextureProp\r\n\t\t);\r\n\t\tthis.sampler = textureProp.sampler;\r\n\t\tthis.dirty = true;\r\n\t\tthis.fixedSize = textureProp.fixedSize || false;\r\n\t}\r\n\tget layoutType() {\r\n\t\tconst { viewFormats, sampleType, sampleCount } = this.textureProp;\r\n\t\t// const\r\n\t\treturn {\r\n\t\t\tsampleType: defaultValue(sampleType, \"float\"),\r\n\t\t\tviewDimension: defaultValue(viewFormats, \"2d\"),\r\n\t\t\tmultisampled: sampleCount && sampleCount > 1 ? true : false\r\n\t\t};\r\n\t}\r\n\tget textureView() {\r\n\t\tif (!this._textureView)\r\n\t\t\tthis._textureView = this.gpuTexture.createView({\r\n\t\t\t\tdimension: <GPUTextureViewDimension>defaultValue(this.textureProp.viewFormats, \"2d\")\r\n\t\t\t});\r\n\t\treturn this._textureView;\r\n\t}\r\n\tupdate(context: Context) {\r\n\t\tif (!this.context) this.context = context;\r\n\t\tif (this.dirty) {\r\n\t\t\tthis.checkNeedCreateTexture();\r\n\t\t\tthis.dirty = false;\r\n\t\t\tif (this.textureProp.data) {\r\n\t\t\t\tif (Array.isArray(this.textureProp.data)) {\r\n\t\t\t\t\tthis.textureProp.data.forEach((imageData) => {\r\n\t\t\t\t\t\tthis.setData(imageData);\r\n\t\t\t\t\t});\r\n\t\t\t\t} else {\r\n\t\t\t\t\tthis.setData(this.textureProp.data);\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t\tif (this.textureProp.needMipMap) {\r\n\t\t\t\tthis.gpuTexture = context.mipmapTools.generateMipmap(this);\r\n\t\t\t}\r\n\t\t\tif (this.sampler) this.sampler.update(context);\r\n\t\t}\r\n\t}\r\n\tprivate setData(options: ImageData) {\r\n\t\tconst {\r\n\t\t\tsource,\r\n\t\t\twidth = options.source.width,\r\n\t\t\theight = options.source.height,\r\n\t\t\tdepth = 1,\r\n\t\t\tsourceX = 0,\r\n\t\t\tsourceY = 0,\r\n\t\t\tmipLevel = 0,\r\n\t\t\tx = 0,\r\n\t\t\ty = 0,\r\n\t\t\tz = 0,\r\n\t\t\taspect = \"all\",\r\n\t\t\tcolorSpace = \"srgb\",\r\n\t\t\tpremultipliedAlpha = false\r\n\t\t} = options;\r\n\t\tif (source instanceof Texture) {\r\n\t\t\tlet commandEncoder = this.context.device.createCommandEncoder();\r\n\t\t\tcommandEncoder.copyTextureToTexture(\r\n\t\t\t\t{\r\n\t\t\t\t\ttexture: <GPUTexture>source.gpuTexture,\r\n\t\t\t\t\torigin: [sourceX, sourceY]\r\n\t\t\t\t\t// aspect\r\n\t\t\t\t},\r\n\t\t\t\t{\r\n\t\t\t\t\ttexture: this.gpuTexture,\r\n\t\t\t\t\torigin: { x: 0, y: 0, z },\r\n\t\t\t\t\tmipLevel\r\n\t\t\t\t\t// aspect\r\n\t\t\t\t},\r\n\t\t\t\t{\r\n\t\t\t\t\twidth,\r\n\t\t\t\t\theight,\r\n\t\t\t\t\tdepthOrArrayLayers: 1\r\n\t\t\t\t}\r\n\t\t\t);\r\n\t\t\tthis.context.device.queue.submit([commandEncoder.finish()]);\r\n\t\t\tcommandEncoder = null;\r\n\t\t} else {\r\n\t\t\tthis.context.device.queue.copyExternalImageToTexture(\r\n\t\t\t\t{\r\n\t\t\t\t\tsource,\r\n\t\t\t\t\torigin: [sourceX, sourceY]\r\n\t\t\t\t},\r\n\t\t\t\t{\r\n\t\t\t\t\ttexture: this.gpuTexture,\r\n\t\t\t\t\torigin: [x, y, z],\r\n\t\t\t\t\tmipLevel,\r\n\t\t\t\t\taspect,\r\n\t\t\t\t\tcolorSpace,\r\n\t\t\t\t\tpremultipliedAlpha\r\n\t\t\t\t},\r\n\t\t\t\t[width, height, depth]\r\n\t\t\t);\r\n\t\t}\r\n\t}\r\n\tsetSize(width: number, height: number, depth?: number) {\r\n\t\tif (this.fixedSize) return;\r\n\t\tthis.textureProp.size.width = width;\r\n\t\tthis.textureProp.size.height = height;\r\n\t\tif (depth) this.textureProp.size.depth = depth;\r\n\t\tthis.dirty = true;\r\n\t}\r\n\tdestroy(): void {\r\n\t\tthis.gpuTexture.destroy();\r\n\t}\r\n\tprivate createGPUTexture() {\r\n\t\tif (typeof this.textureProp.format === \"number\") {\r\n\t\t\tthrow new Error(\"number format\");\r\n\t\t}\r\n\t\tconst { width, height, depth } = this.textureProp.size;\r\n\t\treturn this.context.device.createTexture({\r\n\t\t\tlabel: this.textureProp?.label || \"undefined\",\r\n\t\t\tsize: [width, height, depth],\r\n\t\t\tdimension: this.textureProp.dimension || \"2d\",\r\n\t\t\tformat: this.textureProp.format as GPUTextureFormat,\r\n\t\t\tusage: this.textureProp.usage,\r\n\t\t\tmipLevelCount: this.textureProp.mipLevelCount || 1,\r\n\t\t\tsampleCount: this.textureProp.sampleCount || 1\r\n\t\t});\r\n\t}\r\n\tprivate checkNeedCreateTexture() {\r\n\t\tconst { width, height, depth } = this.textureProp.size;\r\n\t\tif (this.gpuTexture) {\r\n\t\t\tif (width != this.gpuTexture.width || height != this.gpuTexture.height) {\r\n\t\t\t\tthis._textureView = undefined;\r\n\t\t\t\tthis.gpuTexture.destroy();\r\n\t\t\t\tthis.gpuTexture = this.createGPUTexture();\r\n\t\t\t}\r\n\t\t} else {\r\n\t\t\tthis.gpuTexture = this.createGPUTexture();\r\n\t\t}\r\n\t}\r\n}\r\n","import Context from \"./Context\";\r\n\r\nclass Sampler {\r\n\tpublic gpuSampler: GPUSampler;\r\n\tpublic layoutType: GPUSamplerBindingLayout;\r\n\r\n\tstatic baseSampler = new Sampler({\r\n\t\tmagFilter: \"linear\",\r\n\t\tminFilter: \"linear\"\r\n\t});\r\n\r\n\tconstructor(\r\n\t\tpublic descriptor?: GPUSamplerDescriptor,\r\n\t\tlayoutType: GPUSamplerBindingLayout = {\r\n\t\t\ttype: \"filtering\"\r\n\t\t}\r\n\t) {\r\n\t\tthis.descriptor = {};\r\n\t\tObject.assign(\r\n\t\t\tthis.descriptor,\r\n\t\t\t{\r\n\t\t\t\tmagFilter: \"linear\",\r\n\t\t\t\tminFilter: \"linear\",\r\n\t\t\t\t// mipmapFilter: \"linear\",\r\n\t\t\t\taddressModeU: \"clamp-to-edge\",\r\n\t\t\t\taddressModeV: \"clamp-to-edge\"\r\n\t\t\t\t// addressModeW: \"clamp-to-edge\",\r\n\t\t\t},\r\n\t\t\tdescriptor\r\n\t\t);\r\n\t\tthis.layoutType = layoutType;\r\n\t}\r\n\tupdate(context: Context) {\r\n\t\tif (!this.gpuSampler) this.gpuSampler = context.device.createSampler(this.descriptor);\r\n\t}\r\n}\r\n\r\nexport default Sampler;\r\n","import { AttachmentOptions } from \"../core/WebGPUTypes\";\r\nimport Texture from \"./Texture\";\r\n\r\nclass Attachment {\r\n\tpublic op: GPULoadOp = \"clear\";\r\n\tpublic storeOp: GPUStoreOp = \"store\";\r\n\r\n\tpublic texture?: Texture;\r\n\tpublic resolveTarget?: Texture;\r\n\r\n\tpublic readOnly?: boolean;\r\n\r\n\tconstructor(public value: GPUColorDict | GPUColor | number, options?: AttachmentOptions) {\r\n\t\tObject.assign(this, options);\r\n\t}\r\n}\r\n\r\nexport default Attachment;\r\n","export default function defined(value) {\n\treturn value !== undefined && value !== null;\n}\n","/*\n  https://github.com/banksean wrapped Makoto Matsumoto and Takuji Nishimura's code in a namespace\n  so it's better encapsulated. Now you can have multiple random number generators\n  and they won't stomp all over eachother's state.\n\n  If you want to use this as a substitute for Math.random(), use the random()\n  method like so:\n\n  var m = new MersenneTwister();\n  var randomNumber = m.random();\n\n  You can also call the other genrand_{foo}() methods on the instance.\n\n  If you want to use a specific seed in order to get a repeatable random\n  sequence, pass an integer into the constructor:\n\n  var m = new MersenneTwister(123);\n\n  and that will always produce the same random sequence.\n\n  Sean McCullough (banksean@gmail.com)\n*/\n\n/*\n   A C-program for MT19937, with initialization improved 2002/1/26.\n   Coded by Takuji Nishimura and Makoto Matsumoto.\n\n   Before using, initialize the state by using init_seed(seed)\n   or init_by_array(init_key, key_length).\n\n   Copyright (C) 1997 - 2002, Makoto Matsumoto and Takuji Nishimura,\n   All rights reserved.\n\n   Redistribution and use in source and binary forms, with or without\n   modification, are permitted provided that the following conditions\n   are met:\n\n     1. Redistributions of source code must retain the above copyright\n        notice, this list of conditions and the following disclaimer.\n\n     2. Redistributions in binary form must reproduce the above copyright\n        notice, this list of conditions and the following disclaimer in the\n        documentation and/or other materials provided with the distribution.\n\n     3. The names of its contributors may not be used to endorse or promote\n        products derived from this software without specific prior written\n        permission.\n\n   THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS\n   \"AS IS\" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT\n   LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR\n   A PARTICULAR PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE COPYRIGHT OWNER OR\n   CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,\n   EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,\n   PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR\n   PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF\n   LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING\n   NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS\n   SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n\n\n   Any feedback is very welcome.\n   http://www.math.sci.hiroshima-u.ac.jp/~m-mat/MT/emt.html\n   email: m-mat @ math.sci.hiroshima-u.ac.jp (remove space)\n*/\n\nvar MersenneTwister = function(seed) {\n\tif (seed == undefined) {\n\t\tseed = new Date().getTime();\n\t}\n\n\t/* Period parameters */\n\tthis.N = 624;\n\tthis.M = 397;\n\tthis.MATRIX_A = 0x9908b0df;   /* constant vector a */\n\tthis.UPPER_MASK = 0x80000000; /* most significant w-r bits */\n\tthis.LOWER_MASK = 0x7fffffff; /* least significant r bits */\n\n\tthis.mt = new Array(this.N); /* the array for the state vector */\n\tthis.mti=this.N+1; /* mti==N+1 means mt[N] is not initialized */\n\n\tif (seed.constructor == Array) {\n\t\tthis.init_by_array(seed, seed.length);\n\t}\n\telse {\n\t\tthis.init_seed(seed);\n\t}\n}\n\n/* initializes mt[N] with a seed */\n/* origin name init_genrand */\nMersenneTwister.prototype.init_seed = function(s) {\n\tthis.mt[0] = s >>> 0;\n\tfor (this.mti=1; this.mti<this.N; this.mti++) {\n\t\tvar s = this.mt[this.mti-1] ^ (this.mt[this.mti-1] >>> 30);\n\t\tthis.mt[this.mti] = (((((s & 0xffff0000) >>> 16) * 1812433253) << 16) + (s & 0x0000ffff) * 1812433253)\n\t\t+ this.mti;\n\t\t/* See Knuth TAOCP Vol2. 3rd Ed. P.106 for multiplier. */\n\t\t/* In the previous versions, MSBs of the seed affect   */\n\t\t/* only MSBs of the array mt[].                        */\n\t\t/* 2002/01/09 modified by Makoto Matsumoto             */\n\t\tthis.mt[this.mti] >>>= 0;\n\t\t/* for >32 bit machines */\n\t}\n}\n\n/* initialize by an array with array-length */\n/* init_key is the array for initializing keys */\n/* key_length is its length */\n/* slight change for C++, 2004/2/26 */\nMersenneTwister.prototype.init_by_array = function(init_key, key_length) {\n\tvar i, j, k;\n\tthis.init_seed(19650218);\n\ti=1; j=0;\n\tk = (this.N>key_length ? this.N : key_length);\n\tfor (; k; k--) {\n\t\tvar s = this.mt[i-1] ^ (this.mt[i-1] >>> 30)\n\t\tthis.mt[i] = (this.mt[i] ^ (((((s & 0xffff0000) >>> 16) * 1664525) << 16) + ((s & 0x0000ffff) * 1664525)))\n\t\t+ init_key[j] + j; /* non linear */\n\t\tthis.mt[i] >>>= 0; /* for WORDSIZE > 32 machines */\n\t\ti++; j++;\n\t\tif (i>=this.N) { this.mt[0] = this.mt[this.N-1]; i=1; }\n\t\tif (j>=key_length) j=0;\n\t}\n\tfor (k=this.N-1; k; k--) {\n\t\tvar s = this.mt[i-1] ^ (this.mt[i-1] >>> 30);\n\t\tthis.mt[i] = (this.mt[i] ^ (((((s & 0xffff0000) >>> 16) * 1566083941) << 16) + (s & 0x0000ffff) * 1566083941))\n\t\t- i; /* non linear */\n\t\tthis.mt[i] >>>= 0; /* for WORDSIZE > 32 machines */\n\t\ti++;\n\t\tif (i>=this.N) { this.mt[0] = this.mt[this.N-1]; i=1; }\n\t}\n\n\tthis.mt[0] = 0x80000000; /* MSB is 1; assuring non-zero initial array */\n}\n\n/* generates a random number on [0,0xffffffff]-interval */\n/* origin name genrand_int32 */\nMersenneTwister.prototype.random_int = function() {\n\tvar y;\n\tvar mag01 = new Array(0x0, this.MATRIX_A);\n\t/* mag01[x] = x * MATRIX_A  for x=0,1 */\n\n\tif (this.mti >= this.N) { /* generate N words at one time */\n\t\tvar kk;\n\n\t\tif (this.mti == this.N+1)  /* if init_seed() has not been called, */\n\t\t\tthis.init_seed(5489);  /* a default initial seed is used */\n\n\t\tfor (kk=0;kk<this.N-this.M;kk++) {\n\t\t\ty = (this.mt[kk]&this.UPPER_MASK)|(this.mt[kk+1]&this.LOWER_MASK);\n\t\t\tthis.mt[kk] = this.mt[kk+this.M] ^ (y >>> 1) ^ mag01[y & 0x1];\n\t\t}\n\t\tfor (;kk<this.N-1;kk++) {\n\t\t\ty = (this.mt[kk]&this.UPPER_MASK)|(this.mt[kk+1]&this.LOWER_MASK);\n\t\t\tthis.mt[kk] = this.mt[kk+(this.M-this.N)] ^ (y >>> 1) ^ mag01[y & 0x1];\n\t\t}\n\t\ty = (this.mt[this.N-1]&this.UPPER_MASK)|(this.mt[0]&this.LOWER_MASK);\n\t\tthis.mt[this.N-1] = this.mt[this.M-1] ^ (y >>> 1) ^ mag01[y & 0x1];\n\n\t\tthis.mti = 0;\n\t}\n\n\ty = this.mt[this.mti++];\n\n\t/* Tempering */\n\ty ^= (y >>> 11);\n\ty ^= (y << 7) & 0x9d2c5680;\n\ty ^= (y << 15) & 0xefc60000;\n\ty ^= (y >>> 18);\n\n\treturn y >>> 0;\n}\n\n/* generates a random number on [0,0x7fffffff]-interval */\n/* origin name genrand_int31 */\nMersenneTwister.prototype.random_int31 = function() {\n\treturn (this.random_int()>>>1);\n}\n\n/* generates a random number on [0,1]-real-interval */\n/* origin name genrand_real1 */\nMersenneTwister.prototype.random_incl = function() {\n\treturn this.random_int()*(1.0/4294967295.0);\n\t/* divided by 2^32-1 */\n}\n\n/* generates a random number on [0,1)-real-interval */\nMersenneTwister.prototype.random = function() {\n\treturn this.random_int()*(1.0/4294967296.0);\n\t/* divided by 2^32 */\n}\n\n/* generates a random number on (0,1)-real-interval */\n/* origin name genrand_real3 */\nMersenneTwister.prototype.random_excl = function() {\n\treturn (this.random_int() + 0.5)*(1.0/4294967296.0);\n\t/* divided by 2^32 */\n}\n\n/* generates a random number on [0,1) with 53-bit resolution*/\n/* origin name genrand_res53 */\nMersenneTwister.prototype.random_long = function() {\n\tvar a=this.random_int()>>>5, b=this.random_int()>>>6;\n\treturn(a*67108864.0+b)*(1.0/9007199254740992.0);\n}\n\n/* These real versions are due to Isaku Wada, 2002/01/09 added */\n\nmodule.exports = MersenneTwister;\n","import MersenneTwister from \"mersenne-twister\";\r\nimport defaultValue from \"../utils/defaultValue\";\r\nimport defined from \"../utils/defined\";\r\n\r\nclass GMath {\r\n\tpublic static EPSILON1 = 0.1;\r\n\r\n\tpublic static EPSILON2 = 0.01;\r\n\r\n\tpublic static EPSILON3 = 0.001;\r\n\tpublic static EPSILON4 = 0.0001;\r\n\r\n\tpublic static EPSILON5 = 0.00001;\r\n\r\n\tpublic static EPSILON6 = 0.000001;\r\n\r\n\tpublic static EPSILON7 = 0.0000001;\r\n\r\n\tpublic static EPSILON8 = 0.00000001;\r\n\r\n\tpublic static EPSILON9 = 0.000000001;\r\n\r\n\tpublic static EPSILON10 = 0.0000000001;\r\n\r\n\tpublic static EPSILON11 = 0.00000000001;\r\n\r\n\tpublic static EPSILON12 = 0.000000000001;\r\n\r\n\tpublic static EPSILON13 = 0.0000000000001;\r\n\r\n\tpublic static EPSILON14 = 0.00000000000001;\r\n\r\n\tpublic static EPSILON15 = 0.000000000000001;\r\n\r\n\tpublic static EPSILON16 = 0.0000000000000001;\r\n\r\n\tpublic static EPSILON17 = 0.00000000000000001;\r\n\r\n\tpublic static EPSILON18 = 0.000000000000000001;\r\n\r\n\tpublic static EPSILON19 = 0.0000000000000000001;\r\n\r\n\tpublic static EPSILON20 = 0.00000000000000000001;\r\n\r\n\tpublic static EPSILON21 = 0.000000000000000000001;\r\n\r\n\tpublic static GRAVITATIONALPARAMETER = 3.986004418e14;\r\n\r\n\tpublic static SIXTY_FOUR_KILOBYTES = 64 * 1024;\r\n\r\n\tpublic static FOUR_GIGABYTES = 4 * 1024 * 1024 * 1024;\r\n\r\n\tstatic sign = defaultValue(Math.sign, function sign(value) {\r\n\t\tvalue = +value; // coerce to number\r\n\t\tif (value === 0 || value !== value) {\r\n\t\t\t// zero or NaN\r\n\t\t\treturn value;\r\n\t\t}\r\n\t\treturn value > 0 ? 1 : -1;\r\n\t});\r\n\r\n\tstatic signNotZero(value) {\r\n\t\treturn value < 0.0 ? -1.0 : 1.0;\r\n\t}\r\n\r\n\tstatic toSNorm(value: number, rangeMaximum: number): number {\r\n\t\trangeMaximum = defaultValue(rangeMaximum, 255);\r\n\t\treturn Math.round((GMath.clamp(value, -1.0, 1.0) * 0.5 + 0.5) * rangeMaximum);\r\n\t}\r\n\r\n\tstatic fromSNorm(value: number, rangeMaximum: number): number {\r\n\t\trangeMaximum = defaultValue(rangeMaximum, 255);\r\n\t\treturn (GMath.clamp(value, 0.0, rangeMaximum) / rangeMaximum) * 2.0 - 1.0;\r\n\t}\r\n\r\n\tstatic normalize(value: number, rangeMinimum: number, rangeMaximum: number): number {\r\n\t\trangeMaximum = Math.max(rangeMaximum - rangeMinimum, 0.0);\r\n\t\treturn rangeMaximum === 0.0 ? 0.0 : GMath.clamp((value - rangeMinimum) / rangeMaximum, 0.0, 1.0);\r\n\t}\r\n\r\n\tstatic sinh = defaultValue(Math.sinh, function sinh(value) {\r\n\t\treturn (Math.exp(value) - Math.exp(-value)) / 2.0;\r\n\t});\r\n\r\n\tstatic cosh = defaultValue(Math.cosh, function cosh(value) {\r\n\t\treturn (Math.exp(value) + Math.exp(-value)) / 2.0;\r\n\t});\r\n\r\n\tstatic lerp(p: number, q: number, time: number): number {\r\n\t\treturn (1.0 - time) * p + time * q;\r\n\t}\r\n\r\n\tstatic PI = Math.PI;\r\n\r\n\tstatic ONE_OVER_PI = 1.0 / Math.PI;\r\n\r\n\tstatic PI_OVER_TWO = Math.PI / 2.0;\r\n\r\n\tstatic PI_OVER_THREE = Math.PI / 3.0;\r\n\r\n\tstatic PI_OVER_FOUR = Math.PI / 4.0;\r\n\r\n\tstatic PI_OVER_SIX = Math.PI / 6.0;\r\n\r\n\tstatic THREE_PI_OVER_TWO = (3.0 * Math.PI) / 2.0;\r\n\r\n\tstatic TWO_PI = 2.0 * Math.PI;\r\n\r\n\tstatic ONE_OVER_TWO_PI = 1.0 / (2.0 * Math.PI);\r\n\r\n\tstatic RADIANS_PER_DEGREE = Math.PI / 180.0;\r\n\r\n\tstatic DEGREES_PER_RADIAN = 180.0 / Math.PI;\r\n\r\n\tstatic RADIANS_PER_ARCSECOND = GMath.RADIANS_PER_DEGREE / 3600.0;\r\n\r\n\tstatic toRadians(degrees: number): number {\r\n\t\tif (!defined(degrees)) {\r\n\t\t\tthrow new Error(\"degrees is required.\");\r\n\t\t}\r\n\t\treturn degrees * GMath.RADIANS_PER_DEGREE;\r\n\t}\r\n\r\n\tstatic toDegrees(radians: number): number {\r\n\t\tif (!defined(radians)) {\r\n\t\t\tthrow new Error(\"radians is required.\");\r\n\t\t}\r\n\t\treturn radians * GMath.DEGREES_PER_RADIAN;\r\n\t}\r\n\r\n\tstatic negativePiToPi(angle: number): number {\r\n\t\tif (!defined(angle)) {\r\n\t\t\tthrow new Error(\"angle is required.\");\r\n\t\t}\r\n\t\tif (angle >= -GMath.PI && angle <= GMath.PI) {\r\n\t\t\t// Early exit if the input is already inside the range. This avoids\r\n\t\t\t// unnecessary math which could introduce floating point error.\r\n\t\t\treturn angle;\r\n\t\t}\r\n\t\treturn GMath.zeroToTwoPi(angle + GMath.PI) - GMath.PI;\r\n\t}\r\n\r\n\tstatic zeroToTwoPi(angle: number): number {\r\n\t\tif (!defined(angle)) {\r\n\t\t\tthrow new Error(\"angle is required.\");\r\n\t\t}\r\n\t\tif (angle >= 0 && angle <= GMath.TWO_PI) {\r\n\t\t\t// Early exit if the input is already inside the range. This avoids\r\n\t\t\t// unnecessary math which could introduce floating point error.\r\n\t\t\treturn angle;\r\n\t\t}\r\n\t\tconst mod = GMath.mod(angle, GMath.TWO_PI);\r\n\t\tif (Math.abs(mod) < GMath.EPSILON14 && Math.abs(angle) > GMath.EPSILON14) {\r\n\t\t\treturn GMath.TWO_PI;\r\n\t\t}\r\n\t\treturn mod;\r\n\t}\r\n\r\n\tstatic mod(m: number, n: number): number {\r\n\t\tif (!defined(m)) {\r\n\t\t\tthrow new Error(\"m is required.\");\r\n\t\t}\r\n\t\tif (!defined(n)) {\r\n\t\t\tthrow new Error(\"n is required.\");\r\n\t\t}\r\n\t\tif (n === 0.0) {\r\n\t\t\tthrow new Error(\"divisor cannot be 0.\");\r\n\t\t}\r\n\t\tif (GMath.sign(m) === GMath.sign(n) && Math.abs(m) < Math.abs(n)) {\r\n\t\t\t// Early exit if the input does not need to be modded. This avoids\r\n\t\t\t// unnecessary math which could introduce floating point error.\r\n\t\t\treturn m;\r\n\t\t}\r\n\r\n\t\treturn ((m % n) + n) % n;\r\n\t}\r\n\r\n\tstatic equalsEpsilon(\r\n\t\tleft: number,\r\n\t\tright: number,\r\n\t\trelativeEpsilon: number,\r\n\t\tabsoluteEpsilon: number = relativeEpsilon\r\n\t): boolean {\r\n\t\tif (!defined(left)) {\r\n\t\t\tthrow new Error(\"left is required.\");\r\n\t\t}\r\n\t\tif (!defined(right)) {\r\n\t\t\tthrow new Error(\"right is required.\");\r\n\t\t}\r\n\r\n\t\trelativeEpsilon = defaultValue(relativeEpsilon, 0.0);\r\n\t\tabsoluteEpsilon = defaultValue(absoluteEpsilon, relativeEpsilon);\r\n\t\tconst absDiff = Math.abs(left - right);\r\n\t\treturn absDiff <= absoluteEpsilon || absDiff <= relativeEpsilon * Math.max(Math.abs(left), Math.abs(right));\r\n\t}\r\n\r\n\tstatic lessThan(left: number, right: number, absoluteEpsilon = 0): boolean {\r\n\t\tif (!defined(left)) {\r\n\t\t\tthrow new Error(\"first is required.\");\r\n\t\t}\r\n\t\tif (!defined(right)) {\r\n\t\t\tthrow new Error(\"second is required.\");\r\n\t\t}\r\n\t\tif (!defined(absoluteEpsilon)) {\r\n\t\t\tthrow new Error(\"absoluteEpsilon is required.\");\r\n\t\t}\r\n\t\treturn left - right < -absoluteEpsilon;\r\n\t}\r\n\r\n\tstatic lessThanOrEquals(left: number, right: number, absoluteEpsilon = 0): boolean {\r\n\t\tif (!defined(left)) {\r\n\t\t\tthrow new Error(\"first is required.\");\r\n\t\t}\r\n\t\tif (!defined(right)) {\r\n\t\t\tthrow new Error(\"second is required.\");\r\n\t\t}\r\n\t\tif (!defined(absoluteEpsilon)) {\r\n\t\t\tthrow new Error(\"absoluteEpsilon is required.\");\r\n\t\t}\r\n\t\treturn left - right < absoluteEpsilon;\r\n\t}\r\n\r\n\tstatic greaterThan(left: number, right: number, absoluteEpsilon = 0): boolean {\r\n\t\tif (!defined(left)) {\r\n\t\t\tthrow new Error(\"first is required.\");\r\n\t\t}\r\n\t\tif (!defined(right)) {\r\n\t\t\tthrow new Error(\"second is required.\");\r\n\t\t}\r\n\t\tif (!defined(absoluteEpsilon)) {\r\n\t\t\tthrow new Error(\"absoluteEpsilon is required.\");\r\n\t\t}\r\n\t\treturn left - right > absoluteEpsilon;\r\n\t}\r\n\r\n\tstatic greaterThanOrEquals(left: number, right: number, absoluteEpsilon = 0): boolean {\r\n\t\tif (!defined(left)) {\r\n\t\t\tthrow new Error(\"first is required.\");\r\n\t\t}\r\n\t\tif (!defined(right)) {\r\n\t\t\tthrow new Error(\"second is required.\");\r\n\t\t}\r\n\t\tif (!defined(absoluteEpsilon)) {\r\n\t\t\tthrow new Error(\"absoluteEpsilon is required.\");\r\n\t\t}\r\n\t\treturn left - right > -absoluteEpsilon;\r\n\t}\r\n\r\n\tstatic isPowerOfTwo(n: number): boolean {\r\n\t\t// >>includeStart('debug', pragmas.debug);\r\n\t\tif (typeof n !== \"number\" || n < 0 || n > 4294967295) {\r\n\t\t\tthrow new Error(\"A number between 0 and (2^32)-1 is required.\");\r\n\t\t}\r\n\t\t// >>includeEnd('debug');\r\n\r\n\t\treturn n !== 0 && (n & (n - 1)) === 0;\r\n\t}\r\n\r\n\tstatic nextPowerOfTwo(n: number): number {\r\n\t\tif (typeof n !== \"number\" || n < 0 || n > 2147483648) {\r\n\t\t\tthrow new Error(\"A number between 0 and 2^31 is required.\");\r\n\t\t}\r\n\t\t// From http://graphics.stanford.edu/~seander/bithacks.html#RoundUpPowerOf2\r\n\t\t--n;\r\n\t\tn |= n >> 1;\r\n\t\tn |= n >> 2;\r\n\t\tn |= n >> 4;\r\n\t\tn |= n >> 8;\r\n\t\tn |= n >> 16;\r\n\t\t++n;\r\n\r\n\t\treturn n;\r\n\t}\r\n\r\n\tstatic previousPowerOfTwo(n: number): number {\r\n\t\tif (typeof n !== \"number\" || n < 0 || n > 4294967295) {\r\n\t\t\tthrow new Error(\"A number between 0 and (2^32)-1 is required.\");\r\n\t\t}\r\n\r\n\t\tn |= n >> 1;\r\n\t\tn |= n >> 2;\r\n\t\tn |= n >> 4;\r\n\t\tn |= n >> 8;\r\n\t\tn |= n >> 16;\r\n\t\tn |= n >> 32;\r\n\r\n\t\t// The previous bitwise operations implicitly convert to signed 32-bit. Use `>>>` to convert to unsigned\r\n\t\tn = (n >>> 0) - (n >>> 1);\r\n\r\n\t\treturn n;\r\n\t}\r\n\r\n\tstatic clamp(value: number, min: number, max: number): number {\r\n\t\treturn value < min ? min : value > max ? max : value;\r\n\t}\r\n\r\n\tstatic nextRandomNumber = function (): number {\r\n\t\treturn randomNumberGenerator.random();\r\n\t};\r\n\r\n\tstatic randomBetween = function (min: number, max: number): number {\r\n\t\treturn GMath.nextRandomNumber() * (max - min) + min;\r\n\t};\r\n\r\n\tstatic acosClamped = function (value: number): number {\r\n\t\tif (!defined(value)) {\r\n\t\t\tthrow new Error(\"value is required.\");\r\n\t\t}\r\n\r\n\t\treturn Math.acos(GMath.clamp(value, -1.0, 1.0));\r\n\t};\r\n\r\n\tstatic asinClamped = function (value: number): number {\r\n\t\tif (!defined(value)) {\r\n\t\t\tthrow new Error(\"value is required.\");\r\n\t\t}\r\n\r\n\t\treturn Math.asin(GMath.clamp(value, -1.0, 1.0));\r\n\t};\r\n\r\n\tstatic chordLength = function (angle: number, radius: number): number {\r\n\t\tif (!defined(angle)) {\r\n\t\t\tthrow new Error(\"angle is required.\");\r\n\t\t}\r\n\t\tif (!defined(radius)) {\r\n\t\t\tthrow new Error(\"radius is required.\");\r\n\t\t}\r\n\r\n\t\treturn 2.0 * radius * Math.sin(angle * 0.5);\r\n\t};\r\n\r\n\tstatic logBase = function (number: number, base: number): number {\r\n\t\tif (!defined(number)) {\r\n\t\t\tthrow new Error(\"number is required.\");\r\n\t\t}\r\n\t\tif (!defined(base)) {\r\n\t\t\tthrow new Error(\"base is required.\");\r\n\t\t}\r\n\r\n\t\treturn Math.log(number) / Math.log(base);\r\n\t};\r\n\r\n\tstatic cbrt = defaultValue(Math.cbrt, function cbrt(number) {\r\n\t\tconst result = Math.pow(Math.abs(number), 1.0 / 3.0);\r\n\t\treturn number < 0.0 ? -result : result;\r\n\t});\r\n\tstatic log2 = defaultValue(Math.log2, function log2(number) {\r\n\t\treturn Math.log(number) * Math.LOG2E;\r\n\t});\r\n\r\n\t/**\r\n\t * @private\r\n\t */\r\n\tstatic fog(distanceToCamera: number, density: number): number {\r\n\t\tconst scalar = distanceToCamera * density;\r\n\t\treturn 1.0 - Math.exp(-(scalar * scalar));\r\n\t}\r\n}\r\nconst randomNumberGenerator = new MersenneTwister();\r\nconst factorials = [1];\r\nexport default GMath;\r\n","import { Attribute } from \"../render/Attribute\";\r\nimport defined from \"../utils/defined\";\r\nimport GMath from \"./Math\";\r\nimport Matrix3 from \"./Matrix3\";\r\n/**\r\n * A 2D Cartesian point.\r\n * @alias Vector2\r\n * @constructor\r\n *\r\n * @param {Number} [x=0.0] The X component.\r\n * @param {Number} [y=0.0] The Y component.\r\n *\r\n */\r\nclass Vector2 {\r\n\tpublic static ZERO = Object.freeze(new Vector2(0.0, 0.0));\r\n\r\n\tpublic static ONE = Object.freeze(new Vector2(1.0, 1.0));\r\n\r\n\tpublic static UNIT_X = Object.freeze(new Vector2(1.0, 0.0));\r\n\r\n\tpublic static UNIT_Y = Object.freeze(new Vector2(0.0, 1.0));\r\n\r\n\tconstructor(public x: number = 0.0, public y: number = 0.0) {\r\n\t\tthis.x = x;\r\n\t\tthis.y = y;\r\n\t}\r\n\tset(x: number, y: number): Vector2 {\r\n\t\tthis.x = x;\r\n\t\tthis.y = y;\r\n\t\treturn this;\r\n\t}\r\n\ttoArray() {\r\n\t\treturn [this.x, this.y];\r\n\t}\r\n\r\n\tclone(result: Vector2): Vector2 {\r\n\t\treturn Vector2.clone(this, result);\r\n\t}\r\n\r\n\tequals(right: Vector2): boolean {\r\n\t\treturn Vector2.equals(this, right);\r\n\t}\r\n\tequalsEpsilon(right: Vector2, relativeEpsilon = 0, absoluteEpsilon = 0): boolean {\r\n\t\treturn Vector2.equalsEpsilon(this, right, relativeEpsilon, absoluteEpsilon);\r\n\t}\r\n\r\n\ttoString() {\r\n\t\treturn `(${this.x}, ${this.y})`;\r\n\t}\r\n\tfromBufferAttribute(attribute: Attribute, index: number): Vector2 {\r\n\t\tthis.x = attribute.getX(index);\r\n\t\tthis.y = attribute.getY(index);\r\n\t\treturn this;\r\n\t}\r\n\tapplyMatrix3(matrix3: Matrix3): Vector2 {\r\n\t\tconst x = this.x,\r\n\t\t\ty = this.y;\r\n\t\tthis.x = matrix3[0] * x + matrix3[3] * y + matrix3[6];\r\n\t\tthis.y = matrix3[1] * x + matrix3[4] * y + matrix3[7];\r\n\t\treturn this;\r\n\t}\r\n\r\n\tstatic fromElements(x: number, y: number, result: Vector2): Vector2 {\r\n\t\tif (!defined(result)) {\r\n\t\t\treturn new Vector2(x, y);\r\n\t\t}\r\n\r\n\t\tresult.x = x;\r\n\t\tresult.y = y;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic clone(cartesian: Vector2, result: Vector2): Vector2 {\r\n\t\tif (!defined(cartesian)) {\r\n\t\t\treturn undefined;\r\n\t\t}\r\n\t\tif (!defined(result)) {\r\n\t\t\treturn new Vector2(cartesian.x, cartesian.y);\r\n\t\t}\r\n\r\n\t\tresult.x = cartesian.x;\r\n\t\tresult.y = cartesian.y;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic maximumComponent(cartesian: Vector2): number {\r\n\t\treturn Math.max(cartesian.x, cartesian.y);\r\n\t}\r\n\r\n\tstatic minimumComponent(cartesian: Vector2): number {\r\n\t\treturn Math.min(cartesian.x, cartesian.y);\r\n\t}\r\n\r\n\tstatic minimumByComponent(first: Vector2, second: Vector2, result: Vector2): Vector2 {\r\n\t\tresult.x = Math.min(first.x, second.x);\r\n\t\tresult.y = Math.min(first.y, second.y);\r\n\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic maximumByComponent(first: Vector2, second: Vector2, result: Vector2): Vector2 {\r\n\t\tresult.x = Math.max(first.x, second.x);\r\n\t\tresult.y = Math.max(first.y, second.y);\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic clamp(value: Vector2, min: Vector2, max: Vector2, result: Vector2): Vector2 {\r\n\t\tconst x = GMath.clamp(value.x, min.x, max.x);\r\n\t\tconst y = GMath.clamp(value.y, min.y, max.y);\r\n\r\n\t\tresult.x = x;\r\n\t\tresult.y = y;\r\n\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic magnitudeSquared(cartesian: Vector2): number {\r\n\t\treturn cartesian.x * cartesian.x + cartesian.y * cartesian.y;\r\n\t}\r\n\r\n\tstatic magnitude(cartesian: Vector2): number {\r\n\t\treturn Math.sqrt(Vector2.magnitudeSquared(cartesian));\r\n\t}\r\n\r\n\tstatic distance(left: Vector2, right: Vector2): number {\r\n\t\tVector2.subtract(left, right, distanceScratch);\r\n\t\treturn Vector2.magnitude(distanceScratch);\r\n\t}\r\n\r\n\tstatic distanceSquared(left: Vector2, right: Vector2): number {\r\n\t\tVector2.subtract(left, right, distanceScratch);\r\n\t\treturn Vector2.magnitudeSquared(distanceScratch);\r\n\t}\r\n\r\n\tstatic normalize(cartesian: Vector2, result: Vector2): Vector2 {\r\n\t\tconst magnitude = Vector2.magnitude(cartesian);\r\n\r\n\t\tresult.x = cartesian.x / magnitude;\r\n\t\tresult.y = cartesian.y / magnitude;\r\n\r\n\t\t// >>includeStart('debug', pragmas.debug);\r\n\t\tif (isNaN(result.x) || isNaN(result.y)) {\r\n\t\t\tthrow new Error(\"normalized result is not a number\");\r\n\t\t}\r\n\t\t// >>includeEnd('debug');\r\n\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic dot(left: Vector2, right: Vector2): number {\r\n\t\treturn left.x * right.x + left.y * right.y;\r\n\t}\r\n\r\n\tstatic cross(left: Vector2, right: Vector2): number {\r\n\t\treturn left.x * right.y - left.y * right.x;\r\n\t}\r\n\r\n\tstatic multiplyComponents(left: Vector2, right: Vector2, result: Vector2): Vector2 {\r\n\t\tresult.x = left.x * right.x;\r\n\t\tresult.y = left.y * right.y;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic divideComponents(left: Vector2, right: Vector2, result: Vector2): Vector2 {\r\n\t\tresult.x = left.x / right.x;\r\n\t\tresult.y = left.y / right.y;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic add(left: Vector2, right: Vector2, result: Vector2): Vector2 {\r\n\t\tresult.x = left.x + right.x;\r\n\t\tresult.y = left.y + right.y;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic subtract(left: Vector2, right: Vector2, result: Vector2): Vector2 {\r\n\t\tresult.x = left.x - right.x;\r\n\t\tresult.y = left.y - right.y;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic multiplyByScalar(cartesian: Vector2, scalar: number, result: Vector2): Vector2 {\r\n\t\tresult.x = cartesian.x * scalar;\r\n\t\tresult.y = cartesian.y * scalar;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic divideByScalar(cartesian: Vector2, scalar: number, result: Vector2): Vector2 {\r\n\t\tresult.x = cartesian.x / scalar;\r\n\t\tresult.y = cartesian.y / scalar;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic negate(cartesian: Vector2, result: Vector2): Vector2 {\r\n\t\tresult.x = -cartesian.x;\r\n\t\tresult.y = -cartesian.y;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic abs(cartesian: Vector2, result: Vector2): Vector2 {\r\n\t\tresult.x = Math.abs(cartesian.x);\r\n\t\tresult.y = Math.abs(cartesian.y);\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic lerp(start: Vector2, end: Vector2, t: number, result: Vector2): Vector2 {\r\n\t\tVector2.multiplyByScalar(end, t, lerpScratch);\r\n\t\tresult = Vector2.multiplyByScalar(start, 1.0 - t, result);\r\n\t\treturn Vector2.add(lerpScratch, result, result);\r\n\t}\r\n\r\n\tstatic angleBetween(left: Vector2, right: Vector2): number {\r\n\t\tVector2.normalize(left, angleBetweenScratch);\r\n\t\tVector2.normalize(right, angleBetweenScratch2);\r\n\t\treturn GMath.acosClamped(Vector2.dot(angleBetweenScratch, angleBetweenScratch2));\r\n\t}\r\n\r\n\tstatic mostOrthogonalAxis(cartesian: Vector2, result: Vector2): Vector2 {\r\n\t\tconst f = Vector2.normalize(cartesian, mostOrthogonalAxisScratch);\r\n\t\tVector2.abs(f, f);\r\n\r\n\t\tif (f.x <= f.y) {\r\n\t\t\tresult = Vector2.clone(Vector2.UNIT_X, result);\r\n\t\t} else {\r\n\t\t\tresult = Vector2.clone(Vector2.UNIT_Y, result);\r\n\t\t}\r\n\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic equals(left: Vector2, right: Vector2): boolean {\r\n\t\treturn left === right || (defined(left) && defined(right) && left.x === right.x && left.y === right.y);\r\n\t}\r\n\r\n\t/**\r\n\t * @private\r\n\t */\r\n\tstatic equalsArray(cartesian: Vector2, array: number[], offset: number): boolean {\r\n\t\treturn cartesian.x === array[offset] && cartesian.y === array[offset + 1];\r\n\t}\r\n\r\n\tstatic equalsEpsilon(left: Vector2, right: Vector2, relativeEpsilon = 0, absoluteEpsilon = 0): boolean {\r\n\t\treturn (\r\n\t\t\tleft === right ||\r\n\t\t\t(defined(left) &&\r\n\t\t\t\tdefined(right) &&\r\n\t\t\t\tGMath.equalsEpsilon(left.x, right.x, relativeEpsilon, absoluteEpsilon) &&\r\n\t\t\t\tGMath.equalsEpsilon(left.y, right.y, relativeEpsilon, absoluteEpsilon))\r\n\t\t);\r\n\t}\r\n}\r\nconst distanceScratch = new Vector2();\r\nconst lerpScratch = new Vector2();\r\nconst angleBetweenScratch = new Vector2();\r\nconst angleBetweenScratch2 = new Vector2();\r\nconst mostOrthogonalAxisScratch = new Vector2();\r\n\r\nexport default Vector2;\r\n","import { Attribute } from \"../render/Attribute\";\r\nimport defined from \"../utils/defined\";\r\nimport GMath from \"./Math\";\r\nimport Matrix3 from \"./Matrix3\";\r\nimport Matrix4 from \"./Matrix4\";\r\nimport { Quaternion } from \"./Quaternion\";\r\nimport { Spherical } from \"./Spherical\";\r\nimport Vector4 from \"./Vector4\";\r\nclass Vector3 {\r\n\tpublic static ZERO = Object.freeze(new Vector3(0.0, 0.0, 0.0));\r\n\r\n\tpublic static ONE = Object.freeze(new Vector3(1.0, 1.0, 1.0));\r\n\r\n\tpublic static UNIT_X = Object.freeze(new Vector3(1.0, 0.0, 0.0));\r\n\r\n\tpublic static UNIT_Y = Object.freeze(new Vector3(0.0, 1.0, 0.0));\r\n\r\n\tpublic static UNIT_Z = Object.freeze(new Vector3(0.0, 0.0, 1.0));\r\n\tx: number;\r\n\ty: number;\r\n\tz: number;\r\n\r\n\tconstructor(x = 0, y = 0, z = 0) {\r\n\t\tthis.x = x;\r\n\t\tthis.y = y;\r\n\t\tthis.z = z;\r\n\t}\r\n\tset(x: number, y: number, z: number): Vector3 {\r\n\t\tthis.x = x;\r\n\t\tthis.y = y;\r\n\t\tthis.z = z;\r\n\t\treturn this;\r\n\t}\r\n\ttoArray(): number[] {\r\n\t\treturn [this.x, this.y, this.z];\r\n\t}\r\n\r\n\tcopy(v: Vector3): Vector3 {\r\n\t\tthis.x = v.x;\r\n\t\tthis.y = v.y;\r\n\t\tthis.z = v.z;\r\n\t\treturn this;\r\n\t}\r\n\tlerp(end: Vector3, t: number): Vector3 {\r\n\t\tVector3.lerp(this, end, t, this);\r\n\t\treturn this;\r\n\t}\r\n\tadd(v: Vector3): Vector3 {\r\n\t\tVector3.add(this, v, this);\r\n\t\treturn this;\r\n\t}\r\n\taddScaledVector(v: Vector3, s: number): Vector3 {\r\n\t\tthis.x += v.x * s;\r\n\t\tthis.y += v.y * s;\r\n\t\tthis.z += v.z * s;\r\n\t\treturn this;\r\n\t}\r\n\tsubtract(v: Vector3): Vector3 {\r\n\t\tVector3.subtract(this, v, this);\r\n\t\treturn this;\r\n\t}\r\n\tapplyQuaternion(q: Quaternion): Vector3 {\r\n\t\tconst x = this.x,\r\n\t\t\ty = this.y,\r\n\t\t\tz = this.z;\r\n\t\tconst qx = q.x,\r\n\t\t\tqy = q.y,\r\n\t\t\tqz = q.z,\r\n\t\t\tqw = q.w;\r\n\r\n\t\t// calculate quat * vector\r\n\r\n\t\tconst ix = qw * x + qy * z - qz * y;\r\n\t\tconst iy = qw * y + qz * x - qx * z;\r\n\t\tconst iz = qw * z + qx * y - qy * x;\r\n\t\tconst iw = -qx * x - qy * y - qz * z;\r\n\r\n\t\t// calculate result * inverse quat\r\n\r\n\t\tthis.x = ix * qw + iw * -qx + iy * -qz - iz * -qy;\r\n\t\tthis.y = iy * qw + iw * -qy + iz * -qx - ix * -qz;\r\n\t\tthis.z = iz * qw + iw * -qz + ix * -qy - iy * -qx;\r\n\r\n\t\treturn this;\r\n\t}\r\n\tsetFromMatrixColumn(m: Matrix3 | Matrix4, index: number): Vector3 {\r\n\t\treturn this.fromArray(m, index * 4);\r\n\t}\r\n\tfromArray(array: Matrix3 | Matrix4, offset = 0): Vector3 {\r\n\t\tthis.x = array[offset];\r\n\t\tthis.y = array[offset + 1];\r\n\t\tthis.z = array[offset + 2];\r\n\r\n\t\treturn this;\r\n\t}\r\n\r\n\tmultiplyByScalar(scale: number): Vector3 {\r\n\t\tVector3.multiplyByScalar(this, scale, this);\r\n\t\treturn this;\r\n\t}\r\n\r\n\tclone(): Vector3 {\r\n\t\treturn Vector3.clone(this, new Vector3());\r\n\t}\r\n\tlength(): number {\r\n\t\treturn Math.sqrt(this.x * this.x + this.y * this.y + this.z * this.z);\r\n\t}\r\n\tapplyMatrix4(matrix: Matrix4): Vector3 {\r\n\t\tconst x = this.x,\r\n\t\t\ty = this.y,\r\n\t\t\tz = this.z;\r\n\t\tconst e = matrix;\r\n\t\tconst w = 1 / (e[3] * x + e[7] * y + e[11] * z + e[15]);\r\n\t\tthis.x = (e[0] * x + e[4] * y + e[8] * z + e[12]) * w;\r\n\t\tthis.y = (e[1] * x + e[5] * y + e[9] * z + e[13]) * w;\r\n\t\tthis.z = (e[2] * x + e[6] * y + e[10] * z + e[14]) * w;\r\n\t\treturn this;\r\n\t}\r\n\tapplyMatrix3(matrix: Matrix3): Vector3 {\r\n\t\tconst x = this.x,\r\n\t\t\ty = this.y,\r\n\t\t\tz = this.z;\r\n\t\tthis.x = x * matrix[0] + y * matrix[3] + z * matrix[6];\r\n\t\tthis.y = x * matrix[1] + y * matrix[4] + z * matrix[7];\r\n\t\tthis.z = x * matrix[2] + y * matrix[5] + z * matrix[8];\r\n\t\treturn this;\r\n\t}\r\n\ttransformDirection(matrix: Matrix3 | Matrix4): Vector3 {\r\n\t\tconst x = this.x,\r\n\t\t\ty = this.y,\r\n\t\t\tz = this.z;\r\n\t\tconst e = matrix;\r\n\t\tthis.x = e[0] * x + e[4] * y + e[8] * z;\r\n\t\tthis.y = e[1] * x + e[5] * y + e[9] * z;\r\n\t\tthis.z = e[2] * x + e[6] * y + e[10] * z;\r\n\t\treturn this.normalize();\r\n\t}\r\n\r\n\tsetFromMatrixPosition(matrix: Matrix4) {\r\n\t\tconst e = matrix;\r\n\r\n\t\tthis.x = e[12];\r\n\t\tthis.y = e[13];\r\n\t\tthis.z = e[14];\r\n\r\n\t\treturn this;\r\n\t}\r\n\r\n\tnormalize(): Vector3 {\r\n\t\tVector3.normalize(this, this);\r\n\t\treturn this;\r\n\t}\r\n\r\n\tequals(right: Vector3): boolean {\r\n\t\treturn Vector3.equals(this, right);\r\n\t}\r\n\r\n\tequalsEpsilon(right: Vector3, relativeEpsilon = 0, absoluteEpsilon = 0): boolean {\r\n\t\treturn Vector3.equalsEpsilon(this, right, relativeEpsilon, absoluteEpsilon);\r\n\t}\r\n\r\n\ttoString() {\r\n\t\treturn `(${this.x}, ${this.y}, ${this.z})`;\r\n\t}\r\n\tfromBufferAttribute(attribute: Attribute, index: number): Vector3 {\r\n\t\tthis.x = attribute.getX(index);\r\n\t\tthis.y = attribute.getY(index);\r\n\t\tthis.z = attribute.getZ(index);\r\n\t\treturn this;\r\n\t}\r\n\tstatic fromVector4(vec4: Vector4, result: Vector3): Vector3 {\r\n\t\tresult.x = vec4.x;\r\n\t\tresult.y = vec4.y;\r\n\t\tresult.z = vec4.z;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic fromSpherical(spherical: Spherical, result: Vector3): Vector3 {\r\n\t\tif (!defined(result)) {\r\n\t\t\tresult = new Vector3();\r\n\t\t}\r\n\t\tconst { phi, radius, theta } = spherical;\r\n\t\tconst sinPhiRadius = Math.sin(phi) * radius;\r\n\t\tresult.x = sinPhiRadius * Math.sin(theta);\r\n\t\tresult.y = Math.cos(phi) * radius;\r\n\t\tresult.z = sinPhiRadius * Math.cos(theta);\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic fromElements(x: number, y: number, z: number, result: Vector3): Vector3 {\r\n\t\tif (!defined(result)) {\r\n\t\t\treturn new Vector3(x, y, z);\r\n\t\t}\r\n\r\n\t\tresult.x = x;\r\n\t\tresult.y = y;\r\n\t\tresult.z = z;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic clone(cartesian: Vector3, result: Vector3 = new Vector3()): Vector3 {\r\n\t\tif (!defined(cartesian)) {\r\n\t\t\treturn undefined;\r\n\t\t}\r\n\t\tif (!defined(result)) {\r\n\t\t\treturn new Vector3(cartesian.x, cartesian.y, cartesian.z);\r\n\t\t}\r\n\r\n\t\tresult.x = cartesian.x;\r\n\t\tresult.y = cartesian.y;\r\n\t\tresult.z = cartesian.z;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic maximumComponent(cartesian: Vector3): number {\r\n\t\treturn Math.max(cartesian.x, cartesian.y, cartesian.z);\r\n\t}\r\n\r\n\tstatic minimumComponent(cartesian: Vector3): number {\r\n\t\treturn Math.min(cartesian.x, cartesian.y, cartesian.z);\r\n\t}\r\n\r\n\tstatic minimumByComponent(first: Vector3, second: Vector3, result: Vector3): Vector3 {\r\n\t\tresult.x = Math.min(first.x, second.x);\r\n\t\tresult.y = Math.min(first.y, second.y);\r\n\t\tresult.z = Math.min(first.z, second.z);\r\n\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic maximumByComponent(first: Vector3, second: Vector3, result: Vector3): Vector3 {\r\n\t\tresult.x = Math.max(first.x, second.x);\r\n\t\tresult.y = Math.max(first.y, second.y);\r\n\t\tresult.z = Math.max(first.z, second.z);\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic clamp(value: Vector3, min: Vector3, max: Vector3, result: Vector3): Vector3 {\r\n\t\tconst x = GMath.clamp(value.x, min.x, max.x);\r\n\t\tconst y = GMath.clamp(value.y, min.y, max.y);\r\n\t\tconst z = GMath.clamp(value.z, min.z, max.z);\r\n\r\n\t\tresult.x = x;\r\n\t\tresult.y = y;\r\n\t\tresult.z = z;\r\n\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic magnitudeSquared(cartesian: Vector3): number {\r\n\t\treturn cartesian.x * cartesian.x + cartesian.y * cartesian.y + cartesian.z * cartesian.z;\r\n\t}\r\n\r\n\tstatic magnitude(cartesian: Vector3): number {\r\n\t\treturn Math.sqrt(Vector3.magnitudeSquared(cartesian));\r\n\t}\r\n\r\n\tstatic distance(left: Vector3, right: Vector3): number {\r\n\t\tVector3.subtract(left, right, distanceScratch);\r\n\t\treturn Vector3.magnitude(distanceScratch);\r\n\t}\r\n\r\n\tstatic distanceSquared(left: Vector3, right: Vector3): number {\r\n\t\tVector3.subtract(left, right, distanceScratch);\r\n\t\treturn Vector3.magnitudeSquared(distanceScratch);\r\n\t}\r\n\r\n\tstatic normalize(cartesian: Vector3, result: Vector3): Vector3 {\r\n\t\tconst magnitude = Vector3.magnitude(cartesian);\r\n\r\n\t\tresult.x = cartesian.x / magnitude;\r\n\t\tresult.y = cartesian.y / magnitude;\r\n\t\tresult.z = cartesian.z / magnitude;\r\n\r\n\t\tif (isNaN(result.x) || isNaN(result.y) || isNaN(result.z)) {\r\n\t\t\tthrow new Error(\"normalized result is not a number\");\r\n\t\t}\r\n\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic dot(left: Vector3, right: Vector3): number {\r\n\t\treturn left.x * right.x + left.y * right.y + left.z * right.z;\r\n\t}\r\n\r\n\tstatic multiplyComponents(left: Vector3, right: Vector3, result: Vector3): Vector3 {\r\n\t\tresult.x = left.x * right.x;\r\n\t\tresult.y = left.y * right.y;\r\n\t\tresult.z = left.z * right.z;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic divideComponents(left: Vector3, right: Vector3, result: Vector3) {\r\n\t\tresult.x = left.x / right.x;\r\n\t\tresult.y = left.y / right.y;\r\n\t\tresult.z = left.z / right.z;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic add(left: Vector3, right: Vector3, result: Vector3): Vector3 {\r\n\t\tresult.x = left.x + right.x;\r\n\t\tresult.y = left.y + right.y;\r\n\t\tresult.z = left.z + right.z;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic subtract(left: Vector3, right: Vector3, result: Vector3): Vector3 {\r\n\t\tresult.x = left.x - right.x;\r\n\t\tresult.y = left.y - right.y;\r\n\t\tresult.z = left.z - right.z;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic multiplyByScalar(cartesian: Vector3, scalar: number, result: Vector3): Vector3 {\r\n\t\tresult.x = cartesian.x * scalar;\r\n\t\tresult.y = cartesian.y * scalar;\r\n\t\tresult.z = cartesian.z * scalar;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic divideByScalar(cartesian: Vector3, scalar: number, result: Vector3): Vector3 {\r\n\t\tresult.x = cartesian.x / scalar;\r\n\t\tresult.y = cartesian.y / scalar;\r\n\t\tresult.z = cartesian.z / scalar;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic negate(cartesian: Vector3, result: Vector3): Vector3 {\r\n\t\tresult.x = -cartesian.x;\r\n\t\tresult.y = -cartesian.y;\r\n\t\tresult.z = -cartesian.z;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic abs(cartesian: Vector3, result: Vector3): Vector3 {\r\n\t\tresult.x = Math.abs(cartesian.x);\r\n\t\tresult.y = Math.abs(cartesian.y);\r\n\t\tresult.z = Math.abs(cartesian.z);\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic lerp(start: Vector3, end: Vector3, t: number, result: Vector3): Vector3 {\r\n\t\tVector3.multiplyByScalar(end, t, lerpScratch);\r\n\t\tresult = Vector3.multiplyByScalar(start, 1.0 - t, result);\r\n\t\treturn Vector3.add(lerpScratch, result, result);\r\n\t}\r\n\r\n\tstatic angleBetween(left: Vector3, right: Vector3): number {\r\n\t\tVector3.normalize(left, angleBetweenScratch);\r\n\t\tVector3.normalize(right, angleBetweenScratch2);\r\n\t\tconst cosine = Vector3.dot(angleBetweenScratch, angleBetweenScratch2);\r\n\t\tconst sine = Vector3.magnitude(Vector3.cross(angleBetweenScratch, angleBetweenScratch2, angleBetweenScratch));\r\n\t\treturn Math.atan2(sine, cosine);\r\n\t}\r\n\r\n\tstatic mostOrthogonalAxis(cartesian: Vector3, result: Vector3): Vector3 {\r\n\t\tconst f = Vector3.normalize(cartesian, mostOrthogonalAxisScratch);\r\n\t\tVector3.abs(f, f);\r\n\r\n\t\tif (f.x <= f.y) {\r\n\t\t\tif (f.x <= f.z) {\r\n\t\t\t\tresult = Vector3.clone(Vector3.UNIT_X, result);\r\n\t\t\t} else {\r\n\t\t\t\tresult = Vector3.clone(Vector3.UNIT_Z, result);\r\n\t\t\t}\r\n\t\t} else if (f.y <= f.z) {\r\n\t\t\tresult = Vector3.clone(Vector3.UNIT_Y, result);\r\n\t\t} else {\r\n\t\t\tresult = Vector3.clone(Vector3.UNIT_Z, result);\r\n\t\t}\r\n\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic projectVector(a: Vector3, b: Vector3, result: Vector3): Vector3 {\r\n\t\tconst scalar = Vector3.dot(a, b) / Vector3.dot(b, b);\r\n\t\treturn Vector3.multiplyByScalar(b, scalar, result);\r\n\t}\r\n\r\n\tstatic equals(left: Vector3, right: Vector3): boolean {\r\n\t\treturn (\r\n\t\t\tleft === right ||\r\n\t\t\t(defined(left) && defined(right) && left.x === right.x && left.y === right.y && left.z === right.z)\r\n\t\t);\r\n\t}\r\n\r\n\t/**\r\n\t * @private\r\n\t */\r\n\tstatic equalsArray(cartesian: Vector3, array: number[], offset: number): boolean {\r\n\t\treturn cartesian.x === array[offset] && cartesian.y === array[offset + 1] && cartesian.z === array[offset + 2];\r\n\t}\r\n\r\n\tstatic equalsEpsilon(left: Vector3, right: Vector3, relativeEpsilon = 0, absoluteEpsilon = 0): boolean {\r\n\t\treturn (\r\n\t\t\tleft === right ||\r\n\t\t\t(defined(left) &&\r\n\t\t\t\tdefined(right) &&\r\n\t\t\t\tGMath.equalsEpsilon(left.x, right.x, relativeEpsilon, absoluteEpsilon) &&\r\n\t\t\t\tGMath.equalsEpsilon(left.y, right.y, relativeEpsilon, absoluteEpsilon) &&\r\n\t\t\t\tGMath.equalsEpsilon(left.z, right.z, relativeEpsilon, absoluteEpsilon))\r\n\t\t);\r\n\t}\r\n\r\n\tstatic cross(left: Vector3, right: Vector3, result: Vector3): Vector3 {\r\n\t\tconst leftX = left.x;\r\n\t\tconst leftY = left.y;\r\n\t\tconst leftZ = left.z;\r\n\t\tconst rightX = right.x;\r\n\t\tconst rightY = right.y;\r\n\t\tconst rightZ = right.z;\r\n\r\n\t\tconst x = leftY * rightZ - leftZ * rightY;\r\n\t\tconst y = leftZ * rightX - leftX * rightZ;\r\n\t\tconst z = leftX * rightY - leftY * rightX;\r\n\r\n\t\tresult.x = x;\r\n\t\tresult.y = y;\r\n\t\tresult.z = z;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic midpoint = function (left: Vector3, right: Vector3, result: Vector3): Vector3 {\r\n\t\tresult.x = (left.x + right.x) * 0.5;\r\n\t\tresult.y = (left.y + right.y) * 0.5;\r\n\t\tresult.z = (left.z + right.z) * 0.5;\r\n\r\n\t\treturn result;\r\n\t};\r\n}\r\nconst distanceScratch = new Vector3();\r\nconst lerpScratch = new Vector3();\r\nconst angleBetweenScratch = new Vector3();\r\nconst angleBetweenScratch2 = new Vector3();\r\nconst mostOrthogonalAxisScratch = new Vector3();\r\nexport default Vector3;\r\n","import { VertexFormat } from \"../core/WebGPUConstant\";\r\nimport Vector2 from \"../math/Vector2\";\r\nimport Vector3 from \"../math/Vector3\";\r\n\r\nexport class Attribute {\r\n\tpublic offset: number;\r\n\tpublic shaderLocation: number;\r\n\tpublic type: string;\r\n\tpublic format: string;\r\n\tpublic attributeByteSize: number;\r\n\tpublic attributeType:AttributeType;\r\n\tpublic static v3 = new Vector3();\r\n\tpublic static v2 = new Vector2();\r\n\tconstructor(public name: string, public value: Array<number>, public itemSize: number) {\r\n\t\tthis.name = name;\r\n\t\tthis.offset = 0;\r\n\t\tthis.shaderLocation = 0;\r\n\t\tthis.attributeType=AttributeType.attribute;\r\n\t}\r\n\tgetGPUAttribute():Array<GPUAttribute> {\r\n\t\treturn [{\r\n\t\t\tshaderLocation: this.shaderLocation,\r\n\t\t\tformat: this.format,\r\n\t\t\toffset: this.offset\r\n\t\t}];\r\n\t}\r\n\tdestroy() {\r\n\t\tthis.value = [];\r\n\t}\r\n\tapplyMatrix3(matrix3) {\r\n\t\tif (this.itemSize === 2) {\r\n\t\t\tfor (let i = 0, l = this.value.length / this.itemSize; i < l; i++) {\r\n\t\t\t\tAttribute.v2.fromBufferAttribute(this, i);\r\n\t\t\t\tAttribute.v2.applyMatrix3(matrix3);\r\n\t\t\t\tthis.setXY(i, Attribute.v2.x, Attribute.v2.y);\r\n\t\t\t}\r\n\t\t} else if (this.itemSize === 3) {\r\n\t\t\tfor (let i = 0, l = this.value.length / this.itemSize; i < l; i++) {\r\n\t\t\t\tAttribute.v3.fromBufferAttribute(this, i);\r\n\t\t\t\tAttribute.v3.applyMatrix3(matrix3);\r\n\t\t\t\tthis.setXYZ(i, Attribute.v3.x, Attribute.v3.y, Attribute.v3.z);\r\n\t\t\t}\r\n\t\t}\r\n\t\treturn this;\r\n\t}\r\n\tapplyMatrix4(matrix4) {\r\n\t\tfor (let i = 0, l = this.value.length / this.itemSize; i < l; i++) {\r\n\t\t\tAttribute.v3.fromBufferAttribute(this, i);\r\n\t\t\tAttribute.v3.applyMatrix4(matrix4);\r\n\t\t\tthis.setXYZ(i, Attribute.v3.x, Attribute.v3.y, Attribute.v3.z);\r\n\t\t}\r\n\t\treturn this;\r\n\t}\r\n\tsetX(index, x) {\r\n\t\tthis.value[index * this.itemSize] = x;\r\n\t\treturn this;\r\n\t}\r\n\tgetX(index) {\r\n\t\tconst x = this.value[index * this.itemSize];\r\n\t\treturn x;\r\n\t}\r\n\tsetY(index, y) {\r\n\t\tthis.value[index * this.itemSize + 1] = y;\r\n\t\treturn this;\r\n\t}\r\n\tgetY(index) {\r\n\t\tconst y = this.value[index * this.itemSize + 1];\r\n\t\treturn y;\r\n\t}\r\n\tsetZ(index, z) {\r\n\t\tthis.value[index * this.itemSize + 2] = z;\r\n\t\treturn this;\r\n\t}\r\n\tgetZ(index) {\r\n\t\tconst z = this.value[index * this.itemSize + 2];\r\n\t\treturn z;\r\n\t}\r\n\tgetW(index) {\r\n\t\tconst w = this.value[index * this.itemSize + 3];\r\n\t\treturn w;\r\n\t}\r\n\tsetXY(index, x, y) {\r\n\t\tindex *= this.itemSize;\r\n\t\tthis.value[index + 0] = x;\r\n\t\tthis.value[index + 1] = y;\r\n\t\treturn this;\r\n\t}\r\n\tsetXYZ(index, x, y, z) {\r\n\t\tindex *= this.itemSize;\r\n\t\tthis.value[index + 0] = x;\r\n\t\tthis.value[index + 1] = y;\r\n\t\tthis.value[index + 2] = z;\r\n\t\treturn this;\r\n\t}\r\n\tsetXYZW(index, x, y, z, w) {\r\n\t\tindex *= this.itemSize;\r\n\t\tthis.value[index + 0] = x;\r\n\t\tthis.value[index + 1] = y;\r\n\t\tthis.value[index + 2] = z;\r\n\t\tthis.value[index + 3] = w;\r\n\t\treturn this;\r\n\t}\r\n}\r\nexport class InterleavedAttribute {\r\n\tpublic names:string[];\r\n\tpublic value:Array<number>;\r\n\tpublic itemSizes:number[];\r\n\tpublic format: string;\r\n\tpublic byteSize:number;\r\n\tpublic attributeType:AttributeType;\r\n\tconstructor(names: string[], value: Array<number>, itemSizes: number[]){\r\n      this.names=names;\r\n\t\t\tthis.itemSizes=itemSizes;\r\n\t\t\tthis.value=value;\r\n\t\t\tthis.attributeType=AttributeType.interleavedAttribute;\r\n\t}\r\n\tgetGPUAttribute():Array<GPUAttribute>{\r\n\t\tconst result=[];\r\n    this.itemSizes.reduce((total,current,index)=>{\r\n\t\t\tresult.push({\r\n\t\t\t\tshaderLocation: index,\r\n\t\t\t\tformat: this.format,\r\n\t\t\t\toffset: total*this.byteSize\r\n\t\t\t})\r\n       return total+=current;\r\n\t\t},0);\r\n\t\treturn result;\r\n\t}\r\n\tdestroy(){\r\n\t\tthis.value=null;\r\n\t\tthis.names=null;\r\n\t\tthis.itemSizes=null;\r\n\t}\r\n\t\r\n}\r\nexport class Float32Attribute extends Attribute {\r\n\tconstructor(name: string, value: Array<number>, itemSize: number) {\r\n\t\tsuper(name, value, itemSize);\r\n\t\tconst {format,totalByteSize}=getAttributeFormat(VertexFormat.Float32, itemSize);\r\n\t\tthis.format =format \r\n\t\tthis.attributeByteSize = totalByteSize;\r\n\t}\r\n}\r\nexport class InterleavedFloat32Attribute extends InterleavedAttribute{\r\n\tconstructor(names: string[], value: Array<number>, itemSizes: number[]){\r\n\t\tsuper(names,value,itemSizes);\r\n\t\tthis.format=VertexFormat.Float32;\r\n\t\tthis.byteSize=Float32Array.BYTES_PER_ELEMENT;\r\n\t}\r\n}\r\nexport enum AttributeType {\r\n\tinterleavedAttribute=0,\r\n  attribute=1\r\n}\r\nexport type GPUAttribute={\r\n\tshaderLocation:number,\r\n\tformat: string,\r\n\toffset:number\r\n}\r\nfunction getAttributeFormat(type: string, itemSize: number) {\r\n\tconst key = `${type}x${itemSize}`;\r\n\treturn {\r\n\t\t[VertexFormat.Float32]:{format:\"float32\",totalByteSize:Float32Array.BYTES_PER_ELEMENT*itemSize,byteSize:Float32Array.BYTES_PER_ELEMENT},\r\n\t\t[VertexFormat.Float32x2]:{format:\"float32x2\",totalByteSize:Float32Array.BYTES_PER_ELEMENT*itemSize,byteSize:Float32Array.BYTES_PER_ELEMENT},\r\n\t\t[VertexFormat.Float32x3]:{format:\"float32x3\",totalByteSize:Float32Array.BYTES_PER_ELEMENT*itemSize,byteSize:Float32Array.BYTES_PER_ELEMENT},\r\n\t\t[VertexFormat.Float32x4]:{format:\"float32x4\",totalByteSize:Float32Array.BYTES_PER_ELEMENT*itemSize,byteSize:Float32Array.BYTES_PER_ELEMENT},\r\n\t}[key]\r\n}\r\n","import { BindGroupCacheOptions } from \"../core/WebGPUTypes\";\r\nconst bindGroupCache = new Map();\r\nclass BindGroup {\r\n\tdevice: GPUDevice;\r\n\tgpuBindGroup: GPUBindGroup;\r\n\tlabel: string;\r\n\tindex: number;\r\n\tdirty: boolean;\r\n\toffset?: number;\r\n\t// const uniformBytes = 5 * Float32Array.BYTES_PER_ELEMENT;\r\n\t// const alignedSizeBytes = Math.ceil(uniformBytes / 256) * 256;\r\n\t// const alignedSize =alignedSizeBytes / Float32Array.BYTES_PER_ELEMENT;\r\n\talignedSize?: number;\r\n\tmaxOffset?: number;\r\n\tdynamic?: boolean;\r\n\tconstructor(options: BindGroupCacheOptions) {\r\n\t\tthis.index = options.index || 0;\r\n\t\tthis.offset = options.offset ?? 0;\r\n\t\tthis.alignedSize = options.alignedSize ?? 0;\r\n\t\tthis.maxOffset = options.maxOffset ?? 0;\r\n\t\tthis.dynamic = options.dynamic ?? false;\r\n\t\tthis.gpuBindGroup = options.device.createBindGroup({\r\n\t\t\tlabel: options.label,\r\n\t\t\tlayout: options.layout.gpuBindGroupLayout,\r\n\t\t\tentries: options.entires.map((entity) => ({\r\n\t\t\t\tbinding: entity.binding,\r\n\t\t\t\tresource: entity.resource\r\n\t\t\t}))\r\n\t\t});\r\n\t}\r\n\tbind(passEncoder: GPURenderPassEncoder) {\r\n\t\t// dynamic uniforms must bind multiple times\r\n\t\tif (this.dynamic) {\r\n\t\t\tconst dynamicOffsets = [0];\r\n\t\t\tdynamicOffsets[0] = this.offset * this.alignedSize;\r\n\t\t\tthis.offset = ++this.offset < this.maxOffset ? this.offset : 0;\r\n\t\t\tpassEncoder.setBindGroup(this.index, this.gpuBindGroup, dynamicOffsets);\r\n\t\t} else {\r\n\t\t\tpassEncoder.setBindGroup(this.index, this.gpuBindGroup);\r\n\t\t}\r\n\t}\r\n\tdestroy() {\r\n\t\tthis.gpuBindGroup = undefined;\r\n\t\tthis.device = undefined;\r\n\t}\r\n\tstatic getBindGroupFromCache(options: BindGroupCacheOptions): BindGroup {\r\n\t\tif (bindGroupCache.has(options.label)) {\r\n\t\t\treturn bindGroupCache.get(options.label);\r\n\t\t} else {\r\n\t\t\tconst bindGroup = new BindGroup(options);\r\n\t\t\tbindGroupCache.set(options.label, bindGroup);\r\n\t\t\treturn bindGroup;\r\n\t\t}\r\n\t}\r\n\tstatic removeBindGroupFromCache(bindGroup: BindGroup) {\r\n\t\tbindGroupCache.delete(bindGroup);\r\n\t}\r\n}\r\n\r\nexport default BindGroup;\r\n","import { BindGroupEntityOptions } from \"../core/WebGPUTypes\";\nexport default class BindGroupEntity {\n\tbinding: number;\n\tresource: GPUBindingResource;\n\tconstructor(options: BindGroupEntityOptions) {\n\t\tthis.binding = options.binding;\n\t\tthis.resource = options.resource;\n\t}\n\tpublic getGPUGroupEntity() {\n\t\treturn {\n\t\t\tbinding: this.binding,\n\t\t\tresource: this.resource\n\t\t};\n\t}\n}\n","import defaultValue from \"../utils/defaultValue\";\r\nimport defined from \"../utils/defined\";\r\nimport GMath from \"./Math\";\r\nimport Matrix4 from \"./Matrix4\";\r\nimport { Quaternion } from \"./Quaternion\";\r\nimport Vector3 from \"./Vector3\";\r\n/**\r\n * A 3x3 matrix, indexable as a column-major order array.\r\n * @param {Number} [column0Row0=0.0] The value for column 0, row 0.\r\n * @param {Number} [column1Row0=0.0] The value for column 1, row 0.\r\n * @param {Number} [column2Row0=0.0] The value for column 2, row 0.\r\n * @param {Number} [column0Row1=0.0] The value for column 0, row 1.\r\n * @param {Number} [column1Row1=0.0] The value for column 1, row 1.\r\n * @param {Number} [column2Row1=0.0] The value for column 2, row 1.\r\n * @param {Number} [column0Row2=0.0] The value for column 0, row 2.\r\n * @param {Number} [column1Row2=0.0] The value for column 1, row 2.\r\n * @param {Number} [column2Row2=0.0] The value for column 2, row 2.\r\n */\r\nclass Matrix3 {\r\n\tconstructor(\r\n\t\tcolumn0Row0 = 0,\r\n\t\tcolumn1Row0 = 0,\r\n\t\tcolumn2Row0 = 0,\r\n\t\tcolumn0Row1 = 0,\r\n\t\tcolumn1Row1 = 0,\r\n\t\tcolumn2Row1 = 0,\r\n\t\tcolumn0Row2 = 0,\r\n\t\tcolumn1Row2 = 0,\r\n\t\tcolumn2Row2 = 0\r\n\t) {\r\n\t\tthis[0] = column0Row0;\r\n\t\tthis[1] = column0Row1;\r\n\t\tthis[2] = column0Row2;\r\n\t\tthis[3] = column1Row0;\r\n\t\tthis[4] = column1Row1;\r\n\t\tthis[5] = column1Row2;\r\n\t\tthis[6] = column2Row0;\r\n\t\tthis[7] = column2Row1;\r\n\t\tthis[8] = column2Row2;\r\n\t}\r\n\tsetFromMatrix4(matrix: Matrix4): Matrix3 {\r\n\t\tthis[0] = matrix[0];\r\n\t\tthis[1] = matrix[1];\r\n\t\tthis[2] = matrix[2];\r\n\t\tthis[3] = matrix[4];\r\n\t\tthis[4] = matrix[5];\r\n\t\tthis[5] = matrix[2];\r\n\t\tthis[6] = matrix[8];\r\n\t\tthis[7] = matrix[9];\r\n\t\tthis[8] = matrix[10];\r\n\t\treturn this;\r\n\t}\r\n\tgetNormalMatrix(matrix4: Matrix4): Matrix3 {\r\n\t\tthis.setFromMatrix4(matrix4);\r\n\t\tMatrix3.inverse(this, this);\r\n\t\tMatrix3.transpose(this, this);\r\n\t\treturn this;\r\n\t}\r\n\r\n\tstatic clone(matrix: Matrix3 | number[], result: Matrix3): Matrix3 {\r\n\t\tif (!defined(matrix)) {\r\n\t\t\treturn undefined;\r\n\t\t}\r\n\t\tif (!defined(result)) {\r\n\t\t\treturn new Matrix3(\r\n\t\t\t\tmatrix[0],\r\n\t\t\t\tmatrix[3],\r\n\t\t\t\tmatrix[6],\r\n\t\t\t\tmatrix[1],\r\n\t\t\t\tmatrix[4],\r\n\t\t\t\tmatrix[7],\r\n\t\t\t\tmatrix[2],\r\n\t\t\t\tmatrix[5],\r\n\t\t\t\tmatrix[8]\r\n\t\t\t);\r\n\t\t}\r\n\t\tresult[0] = matrix[0];\r\n\t\tresult[1] = matrix[1];\r\n\t\tresult[2] = matrix[2];\r\n\t\tresult[3] = matrix[3];\r\n\t\tresult[4] = matrix[4];\r\n\t\tresult[5] = matrix[5];\r\n\t\tresult[6] = matrix[6];\r\n\t\tresult[7] = matrix[7];\r\n\t\tresult[8] = matrix[8];\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic fromColumnMajorArray(values: Array<number>, result?: Matrix3): Matrix3 {\r\n\t\tif (!defined(result)) {\r\n\t\t\tresult = new Matrix3();\r\n\t\t}\r\n\t\treturn Matrix3.clone(values, result);\r\n\t}\r\n\r\n\tstatic fromRowMajorArray(values: Array<number>, result?: Matrix3): Matrix3 {\r\n\t\tif (!defined(result)) {\r\n\t\t\treturn new Matrix3(\r\n\t\t\t\tvalues[0],\r\n\t\t\t\tvalues[1],\r\n\t\t\t\tvalues[2],\r\n\t\t\t\tvalues[3],\r\n\t\t\t\tvalues[4],\r\n\t\t\t\tvalues[5],\r\n\t\t\t\tvalues[6],\r\n\t\t\t\tvalues[7],\r\n\t\t\t\tvalues[8]\r\n\t\t\t);\r\n\t\t}\r\n\t\tresult[0] = values[0];\r\n\t\tresult[1] = values[3];\r\n\t\tresult[2] = values[6];\r\n\t\tresult[3] = values[1];\r\n\t\tresult[4] = values[4];\r\n\t\tresult[5] = values[7];\r\n\t\tresult[6] = values[2];\r\n\t\tresult[7] = values[5];\r\n\t\tresult[8] = values[8];\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic fromQuaternion(quaternion: Quaternion, result?: Matrix3): Matrix3 {\r\n\t\tconst x2 = quaternion.x * quaternion.x;\r\n\t\tconst xy = quaternion.x * quaternion.y;\r\n\t\tconst xz = quaternion.x * quaternion.z;\r\n\t\tconst xw = quaternion.x * quaternion.w;\r\n\t\tconst y2 = quaternion.y * quaternion.y;\r\n\t\tconst yz = quaternion.y * quaternion.z;\r\n\t\tconst yw = quaternion.y * quaternion.w;\r\n\t\tconst z2 = quaternion.z * quaternion.z;\r\n\t\tconst zw = quaternion.z * quaternion.w;\r\n\t\tconst w2 = quaternion.w * quaternion.w;\r\n\r\n\t\tconst m00 = x2 - y2 - z2 + w2;\r\n\t\tconst m01 = 2.0 * (xy - zw);\r\n\t\tconst m02 = 2.0 * (xz + yw);\r\n\r\n\t\tconst m10 = 2.0 * (xy + zw);\r\n\t\tconst m11 = -x2 + y2 - z2 + w2;\r\n\t\tconst m12 = 2.0 * (yz - xw);\r\n\r\n\t\tconst m20 = 2.0 * (xz - yw);\r\n\t\tconst m21 = 2.0 * (yz + xw);\r\n\t\tconst m22 = -x2 - y2 + z2 + w2;\r\n\r\n\t\tif (!defined(result)) {\r\n\t\t\treturn new Matrix3(m00, m01, m02, m10, m11, m12, m20, m21, m22);\r\n\t\t}\r\n\t\tresult[0] = m00;\r\n\t\tresult[1] = m10;\r\n\t\tresult[2] = m20;\r\n\t\tresult[3] = m01;\r\n\t\tresult[4] = m11;\r\n\t\tresult[5] = m21;\r\n\t\tresult[6] = m02;\r\n\t\tresult[7] = m12;\r\n\t\tresult[8] = m22;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic fromScale(scale: Vector3, result: Matrix3): Matrix3 {\r\n\t\tif (!defined(result)) {\r\n\t\t\treturn new Matrix3(scale.x, 0.0, 0.0, 0.0, scale.y, 0.0, 0.0, 0.0, scale.z);\r\n\t\t}\r\n\r\n\t\tresult[0] = scale.x;\r\n\t\tresult[1] = 0.0;\r\n\t\tresult[2] = 0.0;\r\n\t\tresult[3] = 0.0;\r\n\t\tresult[4] = scale.y;\r\n\t\tresult[5] = 0.0;\r\n\t\tresult[6] = 0.0;\r\n\t\tresult[7] = 0.0;\r\n\t\tresult[8] = scale.z;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic fromRotationX(angle: number, result: Matrix3): Matrix3 {\r\n\t\tconst cosAngle = Math.cos(angle);\r\n\t\tconst sinAngle = Math.sin(angle);\r\n\r\n\t\tif (!defined(result)) {\r\n\t\t\treturn new Matrix3(1.0, 0.0, 0.0, 0.0, cosAngle, -sinAngle, 0.0, sinAngle, cosAngle);\r\n\t\t}\r\n\r\n\t\tresult[0] = 1.0;\r\n\t\tresult[1] = 0.0;\r\n\t\tresult[2] = 0.0;\r\n\t\tresult[3] = 0.0;\r\n\t\tresult[4] = cosAngle;\r\n\t\tresult[5] = sinAngle;\r\n\t\tresult[6] = 0.0;\r\n\t\tresult[7] = -sinAngle;\r\n\t\tresult[8] = cosAngle;\r\n\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic fromRotationY(angle: number, result: Matrix3): Matrix3 {\r\n\t\tconst cosAngle = Math.cos(angle);\r\n\t\tconst sinAngle = Math.sin(angle);\r\n\r\n\t\tif (!defined(result)) {\r\n\t\t\treturn new Matrix3(cosAngle, 0.0, sinAngle, 0.0, 1.0, 0.0, -sinAngle, 0.0, cosAngle);\r\n\t\t}\r\n\r\n\t\tresult[0] = cosAngle;\r\n\t\tresult[1] = 0.0;\r\n\t\tresult[2] = -sinAngle;\r\n\t\tresult[3] = 0.0;\r\n\t\tresult[4] = 1.0;\r\n\t\tresult[5] = 0.0;\r\n\t\tresult[6] = sinAngle;\r\n\t\tresult[7] = 0.0;\r\n\t\tresult[8] = cosAngle;\r\n\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic fromRotationZstatic(angle: number, result: Matrix3): Matrix3 {\r\n\t\tconst cosAngle = Math.cos(angle);\r\n\t\tconst sinAngle = Math.sin(angle);\r\n\r\n\t\tif (!defined(result)) {\r\n\t\t\treturn new Matrix3(cosAngle, -sinAngle, 0.0, sinAngle, cosAngle, 0.0, 0.0, 0.0, 1.0);\r\n\t\t}\r\n\r\n\t\tresult[0] = cosAngle;\r\n\t\tresult[1] = sinAngle;\r\n\t\tresult[2] = 0.0;\r\n\t\tresult[3] = -sinAngle;\r\n\t\tresult[4] = cosAngle;\r\n\t\tresult[5] = 0.0;\r\n\t\tresult[6] = 0.0;\r\n\t\tresult[7] = 0.0;\r\n\t\tresult[8] = 1.0;\r\n\r\n\t\treturn result;\r\n\t}\r\n\ttoArray() {\r\n\t\tconst result = [];\r\n\t\tMatrix3.toArray(this, result);\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic toArray(matrix: Matrix3, result: number[]): number[] {\r\n\t\tif (!defined(result)) {\r\n\t\t\treturn [matrix[0], matrix[1], matrix[2], matrix[3], matrix[4], matrix[5], matrix[6], matrix[7], matrix[8]];\r\n\t\t}\r\n\t\tresult[0] = matrix[0];\r\n\t\tresult[1] = matrix[1];\r\n\t\tresult[2] = matrix[2];\r\n\t\tresult[3] = matrix[3];\r\n\t\tresult[4] = matrix[4];\r\n\t\tresult[5] = matrix[5];\r\n\t\tresult[6] = matrix[6];\r\n\t\tresult[7] = matrix[7];\r\n\t\tresult[8] = matrix[8];\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic getElementIndex(column: number, row: number): number {\r\n\t\treturn column * 3 + row;\r\n\t}\r\n\r\n\tstatic getColumn(matrix: Matrix3, index: number, result: Vector3): Vector3 {\r\n\t\tconst startIndex = index * 3;\r\n\t\tconst x = matrix[startIndex];\r\n\t\tconst y = matrix[startIndex + 1];\r\n\t\tconst z = matrix[startIndex + 2];\r\n\r\n\t\tresult.x = x;\r\n\t\tresult.y = y;\r\n\t\tresult.z = z;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic setColumn(matrix: Matrix3, index: number, cartesian: Vector3, result: Matrix3): Matrix3 {\r\n\t\tresult = Matrix3.clone(matrix, result);\r\n\t\tconst startIndex = index * 3;\r\n\t\tresult[startIndex] = cartesian.x;\r\n\t\tresult[startIndex + 1] = cartesian.y;\r\n\t\tresult[startIndex + 2] = cartesian.z;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic getRow(matrix: Matrix3, index: number, result: Vector3): Vector3 {\r\n\t\tconst x = matrix[index];\r\n\t\tconst y = matrix[index + 3];\r\n\t\tconst z = matrix[index + 6];\r\n\r\n\t\tresult.x = x;\r\n\t\tresult.y = y;\r\n\t\tresult.z = z;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic setRow(matrix: Matrix3, index: number, cartesian: Vector3, result: Matrix3): Matrix3 {\r\n\t\tresult = Matrix3.clone(matrix, result);\r\n\t\tresult[index] = cartesian.x;\r\n\t\tresult[index + 3] = cartesian.y;\r\n\t\tresult[index + 6] = cartesian.z;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic setScale(matrix: Matrix3, scale: Vector3, result: Matrix3): Matrix3 {\r\n\t\tconst existingScale = Matrix3.getScale(matrix, scaleScratch1);\r\n\t\tconst scaleRatioX = scale.x / existingScale.x;\r\n\t\tconst scaleRatioY = scale.y / existingScale.y;\r\n\t\tconst scaleRatioZ = scale.z / existingScale.z;\r\n\r\n\t\tresult[0] = matrix[0] * scaleRatioX;\r\n\t\tresult[1] = matrix[1] * scaleRatioX;\r\n\t\tresult[2] = matrix[2] * scaleRatioX;\r\n\t\tresult[3] = matrix[3] * scaleRatioY;\r\n\t\tresult[4] = matrix[4] * scaleRatioY;\r\n\t\tresult[5] = matrix[5] * scaleRatioY;\r\n\t\tresult[6] = matrix[6] * scaleRatioZ;\r\n\t\tresult[7] = matrix[7] * scaleRatioZ;\r\n\t\tresult[8] = matrix[8] * scaleRatioZ;\r\n\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic getScale(matrix: Matrix3, result: Vector3): Vector3 {\r\n\t\tresult.x = Vector3.magnitude(Vector3.fromElements(matrix[0], matrix[1], matrix[2], scratchColumn));\r\n\t\tresult.y = Vector3.magnitude(Vector3.fromElements(matrix[3], matrix[4], matrix[5], scratchColumn));\r\n\t\tresult.z = Vector3.magnitude(Vector3.fromElements(matrix[6], matrix[7], matrix[8], scratchColumn));\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic getMaximumScale(matrix: Matrix3): number {\r\n\t\tMatrix3.getScale(matrix, scaleScratch3);\r\n\t\treturn Vector3.maximumComponent(scaleScratch3);\r\n\t}\r\n\r\n\tstatic setRotation(matrix: Matrix3, rotation: Matrix3, result: Matrix3): Matrix3 {\r\n\t\tconst scale = Matrix3.getScale(matrix, scaleScratch4);\r\n\r\n\t\tresult[0] = rotation[0] * scale.x;\r\n\t\tresult[1] = rotation[1] * scale.x;\r\n\t\tresult[2] = rotation[2] * scale.x;\r\n\t\tresult[3] = rotation[3] * scale.y;\r\n\t\tresult[4] = rotation[4] * scale.y;\r\n\t\tresult[5] = rotation[5] * scale.y;\r\n\t\tresult[6] = rotation[6] * scale.z;\r\n\t\tresult[7] = rotation[7] * scale.z;\r\n\t\tresult[8] = rotation[8] * scale.z;\r\n\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic getRotation(matrix: Matrix3, result: Matrix3): Matrix3 {\r\n\t\tconst scale = Matrix3.getScale(matrix, scaleScratch5);\r\n\r\n\t\tresult[0] = matrix[0] / scale.x;\r\n\t\tresult[1] = matrix[1] / scale.x;\r\n\t\tresult[2] = matrix[2] / scale.x;\r\n\t\tresult[3] = matrix[3] / scale.y;\r\n\t\tresult[4] = matrix[4] / scale.y;\r\n\t\tresult[5] = matrix[5] / scale.y;\r\n\t\tresult[6] = matrix[6] / scale.z;\r\n\t\tresult[7] = matrix[7] / scale.z;\r\n\t\tresult[8] = matrix[8] / scale.z;\r\n\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic multiply(left: Matrix3, right: Matrix3, result: Matrix3): Matrix3 {\r\n\t\tconst column0Row0 = left[0] * right[0] + left[3] * right[1] + left[6] * right[2];\r\n\t\tconst column0Row1 = left[1] * right[0] + left[4] * right[1] + left[7] * right[2];\r\n\t\tconst column0Row2 = left[2] * right[0] + left[5] * right[1] + left[8] * right[2];\r\n\r\n\t\tconst column1Row0 = left[0] * right[3] + left[3] * right[4] + left[6] * right[5];\r\n\t\tconst column1Row1 = left[1] * right[3] + left[4] * right[4] + left[7] * right[5];\r\n\t\tconst column1Row2 = left[2] * right[3] + left[5] * right[4] + left[8] * right[5];\r\n\r\n\t\tconst column2Row0 = left[0] * right[6] + left[3] * right[7] + left[6] * right[8];\r\n\t\tconst column2Row1 = left[1] * right[6] + left[4] * right[7] + left[7] * right[8];\r\n\t\tconst column2Row2 = left[2] * right[6] + left[5] * right[7] + left[8] * right[8];\r\n\r\n\t\tresult[0] = column0Row0;\r\n\t\tresult[1] = column0Row1;\r\n\t\tresult[2] = column0Row2;\r\n\t\tresult[3] = column1Row0;\r\n\t\tresult[4] = column1Row1;\r\n\t\tresult[5] = column1Row2;\r\n\t\tresult[6] = column2Row0;\r\n\t\tresult[7] = column2Row1;\r\n\t\tresult[8] = column2Row2;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic add(left: Matrix3, right: Matrix3, result: Matrix3): Matrix3 {\r\n\t\tresult[0] = left[0] + right[0];\r\n\t\tresult[1] = left[1] + right[1];\r\n\t\tresult[2] = left[2] + right[2];\r\n\t\tresult[3] = left[3] + right[3];\r\n\t\tresult[4] = left[4] + right[4];\r\n\t\tresult[5] = left[5] + right[5];\r\n\t\tresult[6] = left[6] + right[6];\r\n\t\tresult[7] = left[7] + right[7];\r\n\t\tresult[8] = left[8] + right[8];\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic subtract(left: Matrix3, right: Matrix3, result: Matrix3) {\r\n\t\tresult[0] = left[0] - right[0];\r\n\t\tresult[1] = left[1] - right[1];\r\n\t\tresult[2] = left[2] - right[2];\r\n\t\tresult[3] = left[3] - right[3];\r\n\t\tresult[4] = left[4] - right[4];\r\n\t\tresult[5] = left[5] - right[5];\r\n\t\tresult[6] = left[6] - right[6];\r\n\t\tresult[7] = left[7] - right[7];\r\n\t\tresult[8] = left[8] - right[8];\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic multiplyByVector(matrix: Matrix3, cartesian: Vector3, result: Vector3): Vector3 {\r\n\t\tconst vX = cartesian.x;\r\n\t\tconst vY = cartesian.y;\r\n\t\tconst vZ = cartesian.z;\r\n\r\n\t\tconst x = matrix[0] * vX + matrix[3] * vY + matrix[6] * vZ;\r\n\t\tconst y = matrix[1] * vX + matrix[4] * vY + matrix[7] * vZ;\r\n\t\tconst z = matrix[2] * vX + matrix[5] * vY + matrix[8] * vZ;\r\n\r\n\t\tresult.x = x;\r\n\t\tresult.y = y;\r\n\t\tresult.z = z;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic multiplyByScalar(matrix: Matrix3, scalar: number, result: Matrix3): Matrix3 {\r\n\t\tresult[0] = matrix[0] * scalar;\r\n\t\tresult[1] = matrix[1] * scalar;\r\n\t\tresult[2] = matrix[2] * scalar;\r\n\t\tresult[3] = matrix[3] * scalar;\r\n\t\tresult[4] = matrix[4] * scalar;\r\n\t\tresult[5] = matrix[5] * scalar;\r\n\t\tresult[6] = matrix[6] * scalar;\r\n\t\tresult[7] = matrix[7] * scalar;\r\n\t\tresult[8] = matrix[8] * scalar;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic multiplyByScale(matrix: Matrix3, scale: Vector3, result: Matrix3): Matrix3 {\r\n\t\tresult[0] = matrix[0] * scale.x;\r\n\t\tresult[1] = matrix[1] * scale.x;\r\n\t\tresult[2] = matrix[2] * scale.x;\r\n\t\tresult[3] = matrix[3] * scale.y;\r\n\t\tresult[4] = matrix[4] * scale.y;\r\n\t\tresult[5] = matrix[5] * scale.y;\r\n\t\tresult[6] = matrix[6] * scale.z;\r\n\t\tresult[7] = matrix[7] * scale.z;\r\n\t\tresult[8] = matrix[8] * scale.z;\r\n\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic negate(matrix: Matrix3, result: Matrix3): Matrix3 {\r\n\t\tresult[0] = -matrix[0];\r\n\t\tresult[1] = -matrix[1];\r\n\t\tresult[2] = -matrix[2];\r\n\t\tresult[3] = -matrix[3];\r\n\t\tresult[4] = -matrix[4];\r\n\t\tresult[5] = -matrix[5];\r\n\t\tresult[6] = -matrix[6];\r\n\t\tresult[7] = -matrix[7];\r\n\t\tresult[8] = -matrix[8];\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic transpose(matrix: Matrix3, result: Matrix3): Matrix3 {\r\n\t\tconst column0Row0 = matrix[0];\r\n\t\tconst column0Row1 = matrix[3];\r\n\t\tconst column0Row2 = matrix[6];\r\n\t\tconst column1Row0 = matrix[1];\r\n\t\tconst column1Row1 = matrix[4];\r\n\t\tconst column1Row2 = matrix[7];\r\n\t\tconst column2Row0 = matrix[2];\r\n\t\tconst column2Row1 = matrix[5];\r\n\t\tconst column2Row2 = matrix[8];\r\n\r\n\t\tresult[0] = column0Row0;\r\n\t\tresult[1] = column0Row1;\r\n\t\tresult[2] = column0Row2;\r\n\t\tresult[3] = column1Row0;\r\n\t\tresult[4] = column1Row1;\r\n\t\tresult[5] = column1Row2;\r\n\t\tresult[6] = column2Row0;\r\n\t\tresult[7] = column2Row1;\r\n\t\tresult[8] = column2Row2;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic abs(matrix: Matrix3, result: Matrix3): Matrix3 {\r\n\t\tresult[0] = Math.abs(matrix[0]);\r\n\t\tresult[1] = Math.abs(matrix[1]);\r\n\t\tresult[2] = Math.abs(matrix[2]);\r\n\t\tresult[3] = Math.abs(matrix[3]);\r\n\t\tresult[4] = Math.abs(matrix[4]);\r\n\t\tresult[5] = Math.abs(matrix[5]);\r\n\t\tresult[6] = Math.abs(matrix[6]);\r\n\t\tresult[7] = Math.abs(matrix[7]);\r\n\t\tresult[8] = Math.abs(matrix[8]);\r\n\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic determinant(matrix: Matrix3): number {\r\n\t\tconst m11 = matrix[0];\r\n\t\tconst m21 = matrix[3];\r\n\t\tconst m31 = matrix[6];\r\n\t\tconst m12 = matrix[1];\r\n\t\tconst m22 = matrix[4];\r\n\t\tconst m32 = matrix[7];\r\n\t\tconst m13 = matrix[2];\r\n\t\tconst m23 = matrix[5];\r\n\t\tconst m33 = matrix[8];\r\n\r\n\t\treturn m11 * (m22 * m33 - m23 * m32) + m12 * (m23 * m31 - m21 * m33) + m13 * (m21 * m32 - m22 * m31);\r\n\t}\r\n\r\n\tstatic inverse(matrix: Matrix3, result: Matrix3): Matrix3 {\r\n\t\tconst m11 = matrix[0];\r\n\t\tconst m21 = matrix[1];\r\n\t\tconst m31 = matrix[2];\r\n\t\tconst m12 = matrix[3];\r\n\t\tconst m22 = matrix[4];\r\n\t\tconst m32 = matrix[5];\r\n\t\tconst m13 = matrix[6];\r\n\t\tconst m23 = matrix[7];\r\n\t\tconst m33 = matrix[8];\r\n\r\n\t\tconst determinant = Matrix3.determinant(matrix);\r\n\r\n\t\t// >>includeStart('debug', pragmas.debug);\r\n\t\tif (Math.abs(determinant) <= GMath.EPSILON15) {\r\n\t\t\tthrow new Error(\"matrix is not invertible\");\r\n\t\t}\r\n\t\t// >>includeEnd('debug');\r\n\r\n\t\tresult[0] = m22 * m33 - m23 * m32;\r\n\t\tresult[1] = m23 * m31 - m21 * m33;\r\n\t\tresult[2] = m21 * m32 - m22 * m31;\r\n\t\tresult[3] = m13 * m32 - m12 * m33;\r\n\t\tresult[4] = m11 * m33 - m13 * m31;\r\n\t\tresult[5] = m12 * m31 - m11 * m32;\r\n\t\tresult[6] = m12 * m23 - m13 * m22;\r\n\t\tresult[7] = m13 * m21 - m11 * m23;\r\n\t\tresult[8] = m11 * m22 - m12 * m21;\r\n\r\n\t\tconst scale = 1.0 / determinant;\r\n\t\treturn Matrix3.multiplyByScalar(result, scale, result);\r\n\t}\r\n\r\n\tstatic inverseTranspose(matrix: Matrix3, result: Matrix3) {\r\n\t\treturn Matrix3.inverse(Matrix3.transpose(matrix, scratchTransposeMatrix), result);\r\n\t}\r\n\r\n\tstatic equals(left: Matrix3, right: Matrix3): boolean {\r\n\t\treturn (\r\n\t\t\tleft === right ||\r\n\t\t\t(defined(left) &&\r\n\t\t\t\tdefined(right) &&\r\n\t\t\t\tleft[0] === right[0] &&\r\n\t\t\t\tleft[1] === right[1] &&\r\n\t\t\t\tleft[2] === right[2] &&\r\n\t\t\t\tleft[3] === right[3] &&\r\n\t\t\t\tleft[4] === right[4] &&\r\n\t\t\t\tleft[5] === right[5] &&\r\n\t\t\t\tleft[6] === right[6] &&\r\n\t\t\t\tleft[7] === right[7] &&\r\n\t\t\t\tleft[8] === right[8])\r\n\t\t);\r\n\t}\r\n\r\n\tstatic equalsEpsilon(left: Matrix3, right: Matrix3, epsilon = 0): boolean {\r\n\t\tepsilon = defaultValue(epsilon, 0);\r\n\r\n\t\treturn (\r\n\t\t\tleft === right ||\r\n\t\t\t(defined(left) &&\r\n\t\t\t\tdefined(right) &&\r\n\t\t\t\tMath.abs(left[0] - right[0]) <= epsilon &&\r\n\t\t\t\tMath.abs(left[1] - right[1]) <= epsilon &&\r\n\t\t\t\tMath.abs(left[2] - right[2]) <= epsilon &&\r\n\t\t\t\tMath.abs(left[3] - right[3]) <= epsilon &&\r\n\t\t\t\tMath.abs(left[4] - right[4]) <= epsilon &&\r\n\t\t\t\tMath.abs(left[5] - right[5]) <= epsilon &&\r\n\t\t\t\tMath.abs(left[6] - right[6]) <= epsilon &&\r\n\t\t\t\tMath.abs(left[7] - right[7]) <= epsilon &&\r\n\t\t\t\tMath.abs(left[8] - right[8]) <= epsilon)\r\n\t\t);\r\n\t}\r\n\r\n\tstatic IDENTITY = Object.freeze(new Matrix3(1.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 1.0));\r\n\r\n\tstatic ZERO = Object.freeze(new Matrix3(0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0));\r\n\r\n\tclone(result: Matrix3): Matrix3 {\r\n\t\treturn Matrix3.clone(this, result);\r\n\t}\r\n\r\n\tequals(right: Matrix3): boolean {\r\n\t\treturn Matrix3.equals(this, right);\r\n\t}\r\n\r\n\t/**\r\n\t * @private\r\n\t */\r\n\tequalsArray(matrix: Matrix3 | number[], array: number[], offset: number): boolean {\r\n\t\treturn (\r\n\t\t\tmatrix[0] === array[offset] &&\r\n\t\t\tmatrix[1] === array[offset + 1] &&\r\n\t\t\tmatrix[2] === array[offset + 2] &&\r\n\t\t\tmatrix[3] === array[offset + 3] &&\r\n\t\t\tmatrix[4] === array[offset + 4] &&\r\n\t\t\tmatrix[5] === array[offset + 5] &&\r\n\t\t\tmatrix[6] === array[offset + 6] &&\r\n\t\t\tmatrix[7] === array[offset + 7] &&\r\n\t\t\tmatrix[8] === array[offset + 8]\r\n\t\t);\r\n\t}\r\n\r\n\t/**\r\n\t * Compares this matrix to the provided matrix componentwise and returns\r\n\t * <code>true</code> if they are within the provided epsilon,\r\n\t * <code>false</code> otherwise.\r\n\t *\r\n\t * @param {Matrix3} [right] The right hand side matrix.\r\n\t * @param {Number} [epsilon=0] The epsilon to use for equality testing.\r\n\t * @returns {Boolean} <code>true</code> if they are within the provided epsilon, <code>false</code> otherwise.\r\n\t */\r\n\tequalsEpsilon(right, epsilon) {\r\n\t\treturn Matrix3.equalsEpsilon(this, right, epsilon);\r\n\t}\r\n\r\n\ttoString() {\r\n\t\treturn (\r\n\t\t\t`(${this[0]}, ${this[3]}, ${this[6]})\\n` +\r\n\t\t\t`(${this[1]}, ${this[4]}, ${this[7]})\\n` +\r\n\t\t\t`(${this[2]}, ${this[5]}, ${this[8]})`\r\n\t\t);\r\n\t}\r\n}\r\n\r\nconst scaleScratch1 = new Vector3();\r\nconst scaleScratch2 = new Vector3();\r\nconst scratchColumn = new Vector3();\r\nconst scaleScratch3 = new Vector3();\r\nconst scaleScratch4 = new Vector3();\r\nconst scaleScratch5 = new Vector3();\r\n\r\nfunction computeFrobeniusNorm(matrix) {\r\n\tlet norm = 0.0;\r\n\tfor (let i = 0; i < 9; ++i) {\r\n\t\tconst temp = matrix[i];\r\n\t\tnorm += temp * temp;\r\n\t}\r\n\r\n\treturn Math.sqrt(norm);\r\n}\r\n\r\nconst rowVal = [1, 0, 0];\r\nconst colVal = [2, 2, 1];\r\n\r\nfunction offDiagonalFrobeniusNorm(matrix) {\r\n\t// Computes the \"off-diagonal\" Frobenius norm.\r\n\t// Assumes matrix is symmetric.\r\n\r\n\tlet norm = 0.0;\r\n\tfor (let i = 0; i < 3; ++i) {\r\n\t\tconst temp = matrix[Matrix3.getElementIndex(colVal[i], rowVal[i])];\r\n\t\tnorm += 2.0 * temp * temp;\r\n\t}\r\n\r\n\treturn Math.sqrt(norm);\r\n}\r\n\r\nfunction shurDecomposition(matrix, result) {\r\n\t// This routine was created based upon Matrix Computations, 3rd ed., by Golub and Van Loan,\r\n\t// section 8.4.2 The 2by2 Symmetric Schur Decomposition.\r\n\t//\r\n\t// The routine takes a matrix, which is assumed to be symmetric, and\r\n\t// finds the largest off-diagonal term, and then creates\r\n\t// a matrix (result) which can be used to help reduce it\r\n\r\n\tconst tolerance = GMath.EPSILON15;\r\n\r\n\tlet maxDiagonal = 0.0;\r\n\tlet rotAxis = 1;\r\n\r\n\t// find pivot (rotAxis) based on max diagonal of matrix\r\n\tfor (let i = 0; i < 3; ++i) {\r\n\t\tconst temp = Math.abs(matrix[Matrix3.getElementIndex(colVal[i], rowVal[i])]);\r\n\t\tif (temp > maxDiagonal) {\r\n\t\t\trotAxis = i;\r\n\t\t\tmaxDiagonal = temp;\r\n\t\t}\r\n\t}\r\n\r\n\tlet c = 1.0;\r\n\tlet s = 0.0;\r\n\r\n\tconst p = rowVal[rotAxis];\r\n\tconst q = colVal[rotAxis];\r\n\r\n\tif (Math.abs(matrix[Matrix3.getElementIndex(q, p)]) > tolerance) {\r\n\t\tconst qq = matrix[Matrix3.getElementIndex(q, q)];\r\n\t\tconst pp = matrix[Matrix3.getElementIndex(p, p)];\r\n\t\tconst qp = matrix[Matrix3.getElementIndex(q, p)];\r\n\r\n\t\tconst tau = (qq - pp) / 2.0 / qp;\r\n\t\tlet t;\r\n\r\n\t\tif (tau < 0.0) {\r\n\t\t\tt = -1.0 / (-tau + Math.sqrt(1.0 + tau * tau));\r\n\t\t} else {\r\n\t\t\tt = 1.0 / (tau + Math.sqrt(1.0 + tau * tau));\r\n\t\t}\r\n\r\n\t\tc = 1.0 / Math.sqrt(1.0 + t * t);\r\n\t\ts = t * c;\r\n\t}\r\n\r\n\tresult = Matrix3.clone(Matrix3.IDENTITY, result);\r\n\r\n\tresult[Matrix3.getElementIndex(p, p)] = result[Matrix3.getElementIndex(q, q)] = c;\r\n\tresult[Matrix3.getElementIndex(q, p)] = s;\r\n\tresult[Matrix3.getElementIndex(p, q)] = -s;\r\n\r\n\treturn result;\r\n}\r\nconst scratchTransposeMatrix = new Matrix3();\r\nexport default Matrix3;\r\n","import { Attribute } from \"../render/Attribute\";\r\nimport defined from \"../utils/defined\";\r\nimport GMath from \"./Math\";\r\n\r\nclass Vector4 {\r\n\tpublic static ZERO = Object.freeze(new Vector4(0.0, 0.0, 0.0, 0.0));\r\n\r\n\tpublic static ONE = Object.freeze(new Vector4(1.0, 1.0, 1.0, 1.0));\r\n\r\n\tpublic static UNIT_X = Object.freeze(new Vector4(1.0, 0.0, 0.0, 0.0));\r\n\r\n\tpublic static UNIT_Y = Object.freeze(new Vector4(0.0, 1.0, 0.0, 0.0));\r\n\r\n\tpublic static UNIT_Z = Object.freeze(new Vector4(0.0, 0.0, 1.0, 0.0));\r\n\r\n\tpublic static UNIT_W = Object.freeze(new Vector4(0.0, 0.0, 0.0, 1.0));\r\n\tx: number;\r\n\ty: number;\r\n\tz: number;\r\n\tw: number;\r\n\tconstructor(x = 0, y = 0, z = 0, w = 0) {\r\n\t\tthis.x = x;\r\n\t\tthis.y = y;\r\n\t\tthis.z = z;\r\n\t\tthis.w = w;\r\n\t}\r\n\tset(x: number, y: number, z: number, w: number): void {\r\n\t\tthis.x = x;\r\n\t\tthis.y = y;\r\n\t\tthis.z = z;\r\n\t\tthis.w = w;\r\n\t}\r\n\ttoArray(): number[] {\r\n\t\treturn [this.x, this.y, this.z, this.w];\r\n\t}\r\n\r\n\tclone(result: Vector4): Vector4 {\r\n\t\treturn Vector4.clone(this, result);\r\n\t}\r\n\r\n\tequals(right: Vector4): boolean {\r\n\t\treturn Vector4.equals(this, right);\r\n\t}\r\n\r\n\tequalsEpsilon(right: Vector4, relativeEpsilon = 0, absoluteEpsilon = 0): boolean {\r\n\t\treturn Vector4.equalsEpsilon(this, right, relativeEpsilon, absoluteEpsilon);\r\n\t}\r\n\r\n\ttoString(): string {\r\n\t\treturn `(${this.x}, ${this.y}, ${this.z}, ${this.w})`;\r\n\t}\r\n\tfromBufferAttribute(attribute: Attribute, index: number): Vector4 {\r\n\t\tthis.x = attribute.getX(index);\r\n\t\tthis.y = attribute.getY(index);\r\n\t\tthis.z = attribute.getZ(index);\r\n\t\tthis.w = attribute.getW(index);\r\n\r\n\t\treturn this;\r\n\t}\r\n\r\n\tstatic fromElements(x: number, y: number, z: number, w: number, result: Vector4): Vector4 {\r\n\t\tif (!defined(result)) {\r\n\t\t\treturn new Vector4(x, y, z, w);\r\n\t\t}\r\n\r\n\t\tresult.x = x;\r\n\t\tresult.y = y;\r\n\t\tresult.z = z;\r\n\t\tresult.w = w;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic clone(cartesian: Vector4, result: Vector4): Vector4 {\r\n\t\tif (!defined(cartesian)) {\r\n\t\t\treturn undefined;\r\n\t\t}\r\n\r\n\t\tif (!defined(result)) {\r\n\t\t\treturn new Vector4(cartesian.x, cartesian.y, cartesian.z, cartesian.w);\r\n\t\t}\r\n\r\n\t\tresult.x = cartesian.x;\r\n\t\tresult.y = cartesian.y;\r\n\t\tresult.z = cartesian.z;\r\n\t\tresult.w = cartesian.w;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic maximumComponent(cartesian: Vector4): number {\r\n\t\treturn Math.max(cartesian.x, cartesian.y, cartesian.z, cartesian.w);\r\n\t}\r\n\r\n\tstatic minimumComponent(cartesian: Vector4): number {\r\n\t\treturn Math.min(cartesian.x, cartesian.y, cartesian.z, cartesian.w);\r\n\t}\r\n\r\n\tstatic minimumByComponent(first: Vector4, second: Vector4, result: Vector4): Vector4 {\r\n\t\tresult.x = Math.min(first.x, second.x);\r\n\t\tresult.y = Math.min(first.y, second.y);\r\n\t\tresult.z = Math.min(first.z, second.z);\r\n\t\tresult.w = Math.min(first.w, second.w);\r\n\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic maximumByComponent(first: Vector4, second: Vector4, result: Vector4): Vector4 {\r\n\t\tresult.x = Math.max(first.x, second.x);\r\n\t\tresult.y = Math.max(first.y, second.y);\r\n\t\tresult.z = Math.max(first.z, second.z);\r\n\t\tresult.w = Math.max(first.w, second.w);\r\n\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic clamp(value: Vector4, min: Vector4, max: Vector4, result: Vector4): Vector4 {\r\n\t\tconst x = GMath.clamp(value.x, min.x, max.x);\r\n\t\tconst y = GMath.clamp(value.y, min.y, max.y);\r\n\t\tconst z = GMath.clamp(value.z, min.z, max.z);\r\n\t\tconst w = GMath.clamp(value.w, min.w, max.w);\r\n\r\n\t\tresult.x = x;\r\n\t\tresult.y = y;\r\n\t\tresult.z = z;\r\n\t\tresult.w = w;\r\n\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic magnitudeSquared(cartesian: Vector4): number {\r\n\t\treturn (\r\n\t\t\tcartesian.x * cartesian.x +\r\n\t\t\tcartesian.y * cartesian.y +\r\n\t\t\tcartesian.z * cartesian.z +\r\n\t\t\tcartesian.w * cartesian.w\r\n\t\t);\r\n\t}\r\n\r\n\tstatic magnitude(cartesian: Vector4): number {\r\n\t\treturn Math.sqrt(Vector4.magnitudeSquared(cartesian));\r\n\t}\r\n\r\n\tstatic distance(left: Vector4, right: Vector4): number {\r\n\t\tVector4.subtract(left, right, distanceScratch);\r\n\t\treturn Vector4.magnitude(distanceScratch);\r\n\t}\r\n\r\n\tstatic distanceSquared(left: Vector4, right: Vector4): number {\r\n\t\tVector4.subtract(left, right, distanceScratch);\r\n\t\treturn Vector4.magnitudeSquared(distanceScratch);\r\n\t}\r\n\r\n\tstatic normalize(cartesian: Vector4, result: Vector4): Vector4 {\r\n\t\tconst magnitude = Vector4.magnitude(cartesian);\r\n\r\n\t\tresult.x = cartesian.x / magnitude;\r\n\t\tresult.y = cartesian.y / magnitude;\r\n\t\tresult.z = cartesian.z / magnitude;\r\n\t\tresult.w = cartesian.w / magnitude;\r\n\r\n\t\t// >>includeStart('debug', pragmas.debug);\r\n\t\tif (isNaN(result.x) || isNaN(result.y) || isNaN(result.z) || isNaN(result.w)) {\r\n\t\t\tthrow new Error(\"normalized result is not a number\");\r\n\t\t}\r\n\t\t// >>includeEnd('debug');\r\n\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic dot(left: Vector4, right: Vector4): number {\r\n\t\treturn left.x * right.x + left.y * right.y + left.z * right.z + left.w * right.w;\r\n\t}\r\n\r\n\tstatic multiplyComponents(left: Vector4, right: Vector4, result: Vector4): Vector4 {\r\n\t\tresult.x = left.x * right.x;\r\n\t\tresult.y = left.y * right.y;\r\n\t\tresult.z = left.z * right.z;\r\n\t\tresult.w = left.w * right.w;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic divideComponents(left: Vector4, right: Vector4, result: Vector4): Vector4 {\r\n\t\tresult.x = left.x / right.x;\r\n\t\tresult.y = left.y / right.y;\r\n\t\tresult.z = left.z / right.z;\r\n\t\tresult.w = left.w / right.w;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic add(left: Vector4, right: Vector4, result: Vector4): Vector4 {\r\n\t\tresult.x = left.x + right.x;\r\n\t\tresult.y = left.y + right.y;\r\n\t\tresult.z = left.z + right.z;\r\n\t\tresult.w = left.w + right.w;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic subtract(left: Vector4, right: Vector4, result: Vector4): Vector4 {\r\n\t\tresult.x = left.x - right.x;\r\n\t\tresult.y = left.y - right.y;\r\n\t\tresult.z = left.z - right.z;\r\n\t\tresult.w = left.w - right.w;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic multiplyByScalar(cartesian: Vector4, scalar: number, result: Vector4): Vector4 {\r\n\t\tresult.x = cartesian.x * scalar;\r\n\t\tresult.y = cartesian.y * scalar;\r\n\t\tresult.z = cartesian.z * scalar;\r\n\t\tresult.w = cartesian.w * scalar;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic divideByScalar(cartesian: Vector4, scalar: number, result: Vector4): Vector4 {\r\n\t\tresult.x = cartesian.x / scalar;\r\n\t\tresult.y = cartesian.y / scalar;\r\n\t\tresult.z = cartesian.z / scalar;\r\n\t\tresult.w = cartesian.w / scalar;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic negate(cartesian: Vector4, result: Vector4): Vector4 {\r\n\t\tresult.x = -cartesian.x;\r\n\t\tresult.y = -cartesian.y;\r\n\t\tresult.z = -cartesian.z;\r\n\t\tresult.w = -cartesian.w;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic abs(cartesian: Vector4, result: Vector4): Vector4 {\r\n\t\tresult.x = Math.abs(cartesian.x);\r\n\t\tresult.y = Math.abs(cartesian.y);\r\n\t\tresult.z = Math.abs(cartesian.z);\r\n\t\tresult.w = Math.abs(cartesian.w);\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic lerp(start: Vector4, end: Vector4, t: number, result: Vector4): Vector4 {\r\n\t\tVector4.multiplyByScalar(end, t, lerpScratch);\r\n\t\tresult = Vector4.multiplyByScalar(start, 1.0 - t, result);\r\n\t\treturn Vector4.add(lerpScratch, result, result);\r\n\t}\r\n\r\n\tstatic equals(left: Vector4, right: Vector4): boolean {\r\n\t\treturn (\r\n\t\t\tleft === right ||\r\n\t\t\t(defined(left) &&\r\n\t\t\t\tdefined(right) &&\r\n\t\t\t\tleft.x === right.x &&\r\n\t\t\t\tleft.y === right.y &&\r\n\t\t\t\tleft.z === right.z &&\r\n\t\t\t\tleft.w === right.w)\r\n\t\t);\r\n\t}\r\n\r\n\tstatic equalsArray(cartesian: Vector4, array: number[], offset: number): boolean {\r\n\t\treturn (\r\n\t\t\tcartesian.x === array[offset] &&\r\n\t\t\tcartesian.y === array[offset + 1] &&\r\n\t\t\tcartesian.z === array[offset + 2] &&\r\n\t\t\tcartesian.w === array[offset + 3]\r\n\t\t);\r\n\t}\r\n\r\n\tstatic equalsEpsilon(left: Vector4, right: Vector4, relativeEpsilon = 0, absoluteEpsilon = 0): boolean {\r\n\t\treturn (\r\n\t\t\tleft === right ||\r\n\t\t\t(defined(left) &&\r\n\t\t\t\tdefined(right) &&\r\n\t\t\t\tGMath.equalsEpsilon(left.x, right.x, relativeEpsilon, absoluteEpsilon) &&\r\n\t\t\t\tGMath.equalsEpsilon(left.y, right.y, relativeEpsilon, absoluteEpsilon) &&\r\n\t\t\t\tGMath.equalsEpsilon(left.z, right.z, relativeEpsilon, absoluteEpsilon) &&\r\n\t\t\t\tGMath.equalsEpsilon(left.w, right.w, relativeEpsilon, absoluteEpsilon))\r\n\t\t);\r\n\t}\r\n}\r\n\r\n// scratchU8Array and scratchF32Array are views into the same buffer\r\nconst scratchF32Array = new Float32Array(1);\r\nconst scratchU8Array = new Uint8Array(scratchF32Array.buffer);\r\n\r\nconst testU32 = new Uint32Array([0x11223344]);\r\nconst testU8 = new Uint8Array(testU32.buffer);\r\nconst littleEndian = testU8[0] === 0x44;\r\nconst distanceScratch = new Vector4();\r\nconst lerpScratch = new Vector4();\r\nconst mostOrthogonalAxisScratch = new Vector4();\r\n\r\nexport default Vector4;\r\n","import defaultValue from \"../utils/defaultValue\";\nimport defined from \"../utils/defined\";\nimport GMath from \"./Math\";\nimport Matrix3 from \"./Matrix3\";\nimport { Quaternion } from \"./Quaternion\";\nimport Vector3 from \"./Vector3\";\nimport Vector4 from \"./Vector4\";\nclass Matrix4 {\n\tpublic static IDENTITY = Object.freeze(\n\t\tnew Matrix4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0)\n\t);\n\tpublic static ZERO = Object.freeze(\n\t\tnew Matrix4(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\t);\n\t/**\n\t * A 4x4 matrix, indexable as a column-major order array.\n\t * @param {Number} [column0Row0=0.0] The value for column 0, row 0.\n\t * @param {Number} [column1Row0=0.0] The value for column 1, row 0.\n\t * @param {Number} [column2Row0=0.0] The value for column 2, row 0.\n\t * @param {Number} [column3Row0=0.0] The value for column 3, row 0.\n\t * @param {Number} [column0Row1=0.0] The value for column 0, row 1.\n\t * @param {Number} [column1Row1=0.0] The value for column 1, row 1.\n\t * @param {Number} [column2Row1=0.0] The value for column 2, row 1.\n\t * @param {Number} [column3Row1=0.0] The value for column 3, row 1.\n\t * @param {Number} [column0Row2=0.0] The value for column 0, row 2.\n\t * @param {Number} [column1Row2=0.0] The value for column 1, row 2.\n\t * @param {Number} [column2Row2=0.0] The value for column 2, row 2.\n\t * @param {Number} [column3Row2=0.0] The value for column 3, row 2.\n\t * @param {Number} [column0Row3=0.0] The value for column 0, row 3.\n\t * @param {Number} [column1Row3=0.0] The value for column 1, row 3.\n\t * @param {Number} [column2Row3=0.0] The value for column 2, row 3.\n\t * @param {Number} [column3Row3=0.0] The value for column 3, row 3.\n\t */\n\tconstructor(\n\t\tcolumn0Row0 = 0,\n\t\tcolumn1Row0 = 0,\n\t\tcolumn2Row0 = 0,\n\t\tcolumn3Row0 = 0,\n\t\tcolumn0Row1 = 0,\n\t\tcolumn1Row1 = 0,\n\t\tcolumn2Row1 = 0,\n\t\tcolumn3Row1 = 0,\n\t\tcolumn0Row2 = 0,\n\t\tcolumn1Row2 = 0,\n\t\tcolumn2Row2 = 0,\n\t\tcolumn3Row2 = 0,\n\t\tcolumn0Row3 = 0,\n\t\tcolumn1Row3 = 0,\n\t\tcolumn2Row3 = 0,\n\t\tcolumn3Row3 = 0\n\t) {\n\t\tthis[0] = column0Row0;\n\t\tthis[1] = column0Row1;\n\t\tthis[2] = column0Row2;\n\t\tthis[3] = column0Row3;\n\t\tthis[4] = column1Row0;\n\t\tthis[5] = column1Row1;\n\t\tthis[6] = column1Row2;\n\t\tthis[7] = column1Row3;\n\t\tthis[8] = column2Row0;\n\t\tthis[9] = column2Row1;\n\t\tthis[10] = column2Row2;\n\t\tthis[11] = column2Row3;\n\t\tthis[12] = column3Row0;\n\t\tthis[13] = column3Row1;\n\t\tthis[14] = column3Row2;\n\t\tthis[15] = column3Row3;\n\t}\n\t// ????\n\tclone(result: Matrix4 = new Matrix4()): Matrix4 {\n\t\treturn Matrix4.clone(this, result);\n\t}\n\tset(mat4: Matrix4) {\n\t\tMatrix4.clone(mat4, this);\n\t\treturn this;\n\t}\n\tequals(right: Matrix4): boolean {\n\t\treturn Matrix4.equals(this, right);\n\t}\n\tcompose(position: Vector3, quaternion: Quaternion, scale: Vector3): Matrix4 {\n\t\tconst te = this;\n\n\t\tconst x = quaternion.x,\n\t\t\ty = quaternion.y,\n\t\t\tz = quaternion.z,\n\t\t\tw = quaternion.w;\n\t\tconst x2 = x + x,\n\t\t\ty2 = y + y,\n\t\t\tz2 = z + z;\n\t\tconst xx = x * x2,\n\t\t\txy = x * y2,\n\t\t\txz = x * z2;\n\t\tconst yy = y * y2,\n\t\t\tyz = y * z2,\n\t\t\tzz = z * z2;\n\t\tconst wx = w * x2,\n\t\t\twy = w * y2,\n\t\t\twz = w * z2;\n\n\t\tconst sx = scale.x,\n\t\t\tsy = scale.y,\n\t\t\tsz = scale.z;\n\n\t\tte[0] = (1 - (yy + zz)) * sx;\n\t\tte[1] = (xy + wz) * sx;\n\t\tte[2] = (xz - wy) * sx;\n\t\tte[3] = 0;\n\n\t\tte[4] = (xy - wz) * sy;\n\t\tte[5] = (1 - (xx + zz)) * sy;\n\t\tte[6] = (yz + wx) * sy;\n\t\tte[7] = 0;\n\n\t\tte[8] = (xz + wy) * sz;\n\t\tte[9] = (yz - wx) * sz;\n\t\tte[10] = (1 - (xx + yy)) * sz;\n\t\tte[11] = 0;\n\n\t\tte[12] = position.x;\n\t\tte[13] = position.y;\n\t\tte[14] = position.z;\n\t\tte[15] = 1;\n\n\t\treturn this;\n\t}\n\tequalsEpsilon(right: Matrix4, epsilon = 0): boolean {\n\t\treturn Matrix4.equalsEpsilon(this, right, epsilon);\n\t}\n\tlookAt(eye: Vector3, target: Vector3, up: Vector3): Matrix4 {\n\t\tconst matrix = this;\n\t\tVector3.subtract(eye, target, z);\n\t\tif (z.length() === 0) {\n\t\t\t// eye and target are in the same position\n\t\t\tz.z = 1;\n\t\t}\n\t\tz.normalize();\n\t\tVector3.cross(up, z, x);\n\t\tif (x.length() === 0) {\n\t\t\t// up and z are parallel\n\n\t\t\tif (Math.abs(up.z) === 1) {\n\t\t\t\tz.x += 0.0001;\n\t\t\t} else {\n\t\t\t\tz.z += 0.0001;\n\t\t\t}\n\t\t\tz.normalize();\n\t\t\tVector3.cross(up, z, x);\n\t\t}\n\t\tx.normalize();\n\t\tVector3.cross(z, x, y);\n\t\tmatrix[0] = x.x;\n\t\tmatrix[4] = y.x;\n\t\tmatrix[8] = z.x;\n\t\tmatrix[1] = x.y;\n\t\tmatrix[5] = y.y;\n\t\tmatrix[9] = z.y;\n\t\tmatrix[2] = x.z;\n\t\tmatrix[6] = y.z;\n\t\tmatrix[10] = z.z;\n\n\t\treturn this;\n\t}\n\ttoString() {\n\t\treturn (\n\t\t\t`(${this[0]}, ${this[4]}, ${this[8]}, ${this[12]})\\n` +\n\t\t\t`(${this[1]}, ${this[5]}, ${this[9]}, ${this[13]})\\n` +\n\t\t\t`(${this[2]}, ${this[6]}, ${this[10]}, ${this[14]})\\n` +\n\t\t\t`(${this[3]}, ${this[7]}, ${this[11]}, ${this[15]})`\n\t\t);\n\t}\n\tstatic clone(matrix: Matrix4 | number[], result: Matrix4): Matrix4 {\n\t\tif (!defined(matrix)) {\n\t\t\treturn undefined;\n\t\t}\n\t\tif (!defined(result)) {\n\t\t\treturn new Matrix4(\n\t\t\t\tmatrix[0],\n\t\t\t\tmatrix[4],\n\t\t\t\tmatrix[8],\n\t\t\t\tmatrix[12],\n\t\t\t\tmatrix[1],\n\t\t\t\tmatrix[5],\n\t\t\t\tmatrix[9],\n\t\t\t\tmatrix[13],\n\t\t\t\tmatrix[2],\n\t\t\t\tmatrix[6],\n\t\t\t\tmatrix[10],\n\t\t\t\tmatrix[14],\n\t\t\t\tmatrix[3],\n\t\t\t\tmatrix[7],\n\t\t\t\tmatrix[11],\n\t\t\t\tmatrix[15]\n\t\t\t);\n\t\t}\n\t\tresult[0] = matrix[0];\n\t\tresult[1] = matrix[1];\n\t\tresult[2] = matrix[2];\n\t\tresult[3] = matrix[3];\n\t\tresult[4] = matrix[4];\n\t\tresult[5] = matrix[5];\n\t\tresult[6] = matrix[6];\n\t\tresult[7] = matrix[7];\n\t\tresult[8] = matrix[8];\n\t\tresult[9] = matrix[9];\n\t\tresult[10] = matrix[10];\n\t\tresult[11] = matrix[11];\n\t\tresult[12] = matrix[12];\n\t\tresult[13] = matrix[13];\n\t\tresult[14] = matrix[14];\n\t\tresult[15] = matrix[15];\n\t\treturn result;\n\t}\n\n\tstatic fromColumnMajorArray(values: number[], result: Matrix4): Matrix4 {\n\t\treturn Matrix4.clone(values, result);\n\t}\n\n\tstatic fromRowMajorArray(values: number[], result: Matrix4): Matrix4 {\n\t\tif (!defined(result)) {\n\t\t\treturn new Matrix4(\n\t\t\t\tvalues[0],\n\t\t\t\tvalues[1],\n\t\t\t\tvalues[2],\n\t\t\t\tvalues[3],\n\t\t\t\tvalues[4],\n\t\t\t\tvalues[5],\n\t\t\t\tvalues[6],\n\t\t\t\tvalues[7],\n\t\t\t\tvalues[8],\n\t\t\t\tvalues[9],\n\t\t\t\tvalues[10],\n\t\t\t\tvalues[11],\n\t\t\t\tvalues[12],\n\t\t\t\tvalues[13],\n\t\t\t\tvalues[14],\n\t\t\t\tvalues[15]\n\t\t\t);\n\t\t}\n\t\tresult[0] = values[0];\n\t\tresult[1] = values[4];\n\t\tresult[2] = values[8];\n\t\tresult[3] = values[12];\n\t\tresult[4] = values[1];\n\t\tresult[5] = values[5];\n\t\tresult[6] = values[9];\n\t\tresult[7] = values[13];\n\t\tresult[8] = values[2];\n\t\tresult[9] = values[6];\n\t\tresult[10] = values[10];\n\t\tresult[11] = values[14];\n\t\tresult[12] = values[3];\n\t\tresult[13] = values[7];\n\t\tresult[14] = values[11];\n\t\tresult[15] = values[15];\n\t\treturn result;\n\t}\n\n\tstatic fromRotationTranslation(rotation: Matrix3, translation: Vector3, result: Matrix4): Matrix4 {\n\t\ttranslation = defaultValue(translation, Vector3.ZERO);\n\n\t\tif (!defined(result)) {\n\t\t\treturn new Matrix4(\n\t\t\t\trotation[0],\n\t\t\t\trotation[3],\n\t\t\t\trotation[6],\n\t\t\t\ttranslation.x,\n\t\t\t\trotation[1],\n\t\t\t\trotation[4],\n\t\t\t\trotation[7],\n\t\t\t\ttranslation.y,\n\t\t\t\trotation[2],\n\t\t\t\trotation[5],\n\t\t\t\trotation[8],\n\t\t\t\ttranslation.z,\n\t\t\t\t0.0,\n\t\t\t\t0.0,\n\t\t\t\t0.0,\n\t\t\t\t1.0\n\t\t\t);\n\t\t}\n\n\t\tresult[0] = rotation[0];\n\t\tresult[1] = rotation[1];\n\t\tresult[2] = rotation[2];\n\t\tresult[3] = 0.0;\n\t\tresult[4] = rotation[3];\n\t\tresult[5] = rotation[4];\n\t\tresult[6] = rotation[5];\n\t\tresult[7] = 0.0;\n\t\tresult[8] = rotation[6];\n\t\tresult[9] = rotation[7];\n\t\tresult[10] = rotation[8];\n\t\tresult[11] = 0.0;\n\t\tresult[12] = translation.x;\n\t\tresult[13] = translation.y;\n\t\tresult[14] = translation.z;\n\t\tresult[15] = 1.0;\n\t\treturn result;\n\t}\n\n\tstatic fromTranslationQuaternionRotationScale(\n\t\ttranslation: Vector3,\n\t\trotation: Quaternion,\n\t\tscale: Vector3,\n\t\tresult: Matrix4\n\t): Matrix4 {\n\t\tif (!defined(result)) {\n\t\t\tresult = new Matrix4();\n\t\t}\n\n\t\tconst scaleX = scale.x;\n\t\tconst scaleY = scale.y;\n\t\tconst scaleZ = scale.z;\n\n\t\tconst x2 = rotation.x * rotation.x;\n\t\tconst xy = rotation.x * rotation.y;\n\t\tconst xz = rotation.x * rotation.z;\n\t\tconst xw = rotation.x * rotation.w;\n\t\tconst y2 = rotation.y * rotation.y;\n\t\tconst yz = rotation.y * rotation.z;\n\t\tconst yw = rotation.y * rotation.w;\n\t\tconst z2 = rotation.z * rotation.z;\n\t\tconst zw = rotation.z * rotation.w;\n\t\tconst w2 = rotation.w * rotation.w;\n\n\t\tconst m00 = x2 - y2 - z2 + w2;\n\t\tconst m01 = 2.0 * (xy - zw);\n\t\tconst m02 = 2.0 * (xz + yw);\n\n\t\tconst m10 = 2.0 * (xy + zw);\n\t\tconst m11 = -x2 + y2 - z2 + w2;\n\t\tconst m12 = 2.0 * (yz - xw);\n\n\t\tconst m20 = 2.0 * (xz - yw);\n\t\tconst m21 = 2.0 * (yz + xw);\n\t\tconst m22 = -x2 - y2 + z2 + w2;\n\n\t\tresult[0] = m00 * scaleX;\n\t\tresult[1] = m10 * scaleX;\n\t\tresult[2] = m20 * scaleX;\n\t\tresult[3] = 0.0;\n\t\tresult[4] = m01 * scaleY;\n\t\tresult[5] = m11 * scaleY;\n\t\tresult[6] = m21 * scaleY;\n\t\tresult[7] = 0.0;\n\t\tresult[8] = m02 * scaleZ;\n\t\tresult[9] = m12 * scaleZ;\n\t\tresult[10] = m22 * scaleZ;\n\t\tresult[11] = 0.0;\n\t\tresult[12] = translation.x;\n\t\tresult[13] = translation.y;\n\t\tresult[14] = translation.z;\n\t\tresult[15] = 1.0;\n\n\t\treturn result;\n\t}\n\n\tstatic fromTranslationRotationScale(\n\t\ttranslationRotationScale: {\n\t\t\ttranslation: Vector3;\n\t\t\trotation: Quaternion;\n\t\t\tscale: Vector3;\n\t\t},\n\t\tresult: Matrix4\n\t): Matrix4 {\n\t\treturn Matrix4.fromTranslationQuaternionRotationScale(\n\t\t\ttranslationRotationScale.translation,\n\t\t\ttranslationRotationScale.rotation,\n\t\t\ttranslationRotationScale.scale,\n\t\t\tresult\n\t\t);\n\t}\n\n\tstatic fromTranslation(translation: Vector3, result: Matrix4): Matrix4 {\n\t\treturn Matrix4.fromRotationTranslation(Matrix3.IDENTITY, translation, result);\n\t}\n\n\tstatic fromScale(scale: Vector3, result: Matrix4): Matrix4 {\n\t\tif (!defined(result)) {\n\t\t\treturn new Matrix4(\n\t\t\t\tscale.x,\n\t\t\t\t0.0,\n\t\t\t\t0.0,\n\t\t\t\t0.0,\n\t\t\t\t0.0,\n\t\t\t\tscale.y,\n\t\t\t\t0.0,\n\t\t\t\t0.0,\n\t\t\t\t0.0,\n\t\t\t\t0.0,\n\t\t\t\tscale.z,\n\t\t\t\t0.0,\n\t\t\t\t0.0,\n\t\t\t\t0.0,\n\t\t\t\t0.0,\n\t\t\t\t1.0\n\t\t\t);\n\t\t}\n\n\t\tresult[0] = scale.x;\n\t\tresult[1] = 0.0;\n\t\tresult[2] = 0.0;\n\t\tresult[3] = 0.0;\n\t\tresult[4] = 0.0;\n\t\tresult[5] = scale.y;\n\t\tresult[6] = 0.0;\n\t\tresult[7] = 0.0;\n\t\tresult[8] = 0.0;\n\t\tresult[9] = 0.0;\n\t\tresult[10] = scale.z;\n\t\tresult[11] = 0.0;\n\t\tresult[12] = 0.0;\n\t\tresult[13] = 0.0;\n\t\tresult[14] = 0.0;\n\t\tresult[15] = 1.0;\n\t\treturn result;\n\t}\n\n\tstatic fromRotation(rotation: Matrix3, result: Matrix4): Matrix4 {\n\t\tif (!defined(result)) {\n\t\t\tresult = new Matrix4();\n\t\t}\n\t\tresult[0] = rotation[0];\n\t\tresult[1] = rotation[1];\n\t\tresult[2] = rotation[2];\n\t\tresult[3] = 0.0;\n\n\t\tresult[4] = rotation[3];\n\t\tresult[5] = rotation[4];\n\t\tresult[6] = rotation[5];\n\t\tresult[7] = 0.0;\n\n\t\tresult[8] = rotation[6];\n\t\tresult[9] = rotation[7];\n\t\tresult[10] = rotation[8];\n\t\tresult[11] = 0.0;\n\n\t\tresult[12] = 0.0;\n\t\tresult[13] = 0.0;\n\t\tresult[14] = 0.0;\n\t\tresult[15] = 1.0;\n\n\t\treturn result;\n\t}\n\n\tstatic makePerspective(\n\t\tleft: number,\n\t\tright: number,\n\t\ttop: number,\n\t\tbottom: number,\n\t\tnear: number,\n\t\tfar: number\n\t): Matrix4 {\n\t\t// from three.js\n\t\tconst matrix = new Matrix4();\n\t\tconst x = (2 * near) / (right - left);\n\t\tconst y = (2 * near) / (top - bottom);\n\n\t\tconst a = (right + left) / (right - left);\n\t\tconst b = (top + bottom) / (top - bottom);\n\t\tconst c = -far / (far - near);\n\t\tconst d = (-far * near) / (far - near);\n\n\t\tmatrix[0] = x;\n\t\tmatrix[4] = 0;\n\t\tmatrix[8] = a;\n\t\tmatrix[12] = 0;\n\t\tmatrix[1] = 0;\n\t\tmatrix[5] = y;\n\t\tmatrix[9] = b;\n\t\tmatrix[13] = 0;\n\t\tmatrix[2] = 0;\n\t\tmatrix[6] = 0;\n\t\tmatrix[10] = c;\n\t\tmatrix[14] = d;\n\t\tmatrix[3] = 0;\n\t\tmatrix[7] = 0;\n\t\tmatrix[11] = -1;\n\t\tmatrix[15] = 0;\n\t\treturn matrix;\n\t}\n\tstatic makeOrthographic(\n\t\tleft: number,\n\t\tright: number,\n\t\ttop: number,\n\t\tbottom: number,\n\t\tnear: number,\n\t\tfar: number\n\t): Matrix4 {\n\t\tconst matrix = new Matrix4();\n\t\tconst w = 1.0 / (right - left);\n\t\tconst h = 1.0 / (top - bottom);\n\t\tconst p = 1.0 / (far - near);\n\n\t\tconst x = (right + left) * w;\n\t\tconst y = (top + bottom) * h;\n\t\tconst z = near * p;\n\n\t\tmatrix[0] = 2 * w;\n\t\tmatrix[4] = 0;\n\t\tmatrix[8] = 0;\n\t\tmatrix[12] = -x;\n\t\tmatrix[1] = 0;\n\t\tmatrix[5] = 2 * h;\n\t\tmatrix[9] = 0;\n\t\tmatrix[13] = -y;\n\t\tmatrix[2] = 0;\n\t\tmatrix[6] = 0;\n\t\tmatrix[10] = -1 * p;\n\t\tmatrix[14] = -z;\n\t\tmatrix[3] = 0;\n\t\tmatrix[7] = 0;\n\t\tmatrix[11] = 0;\n\t\tmatrix[15] = 1;\n\t\treturn matrix;\n\t}\n\ttoArray() {\n\t\tconst result = [];\n\t\tMatrix4.toArray(this, result);\n\t\treturn result;\n\t}\n\t/**\n\t * Computes an Array from the provided Matrix4 instance.\n\t * The array will be in column-major order.\n\t * @example\n\t * //create an array from an instance of Matrix4\n\t * // m = [10.0, 14.0, 18.0, 22.0]\n\t * //     [11.0, 15.0, 19.0, 23.0]\n\t * //     [12.0, 16.0, 20.0, 24.0]\n\t * //     [13.0, 17.0, 21.0, 25.0]\n\t * const a = Matrix4.toArray(m);\n\t *\n\t * // m remains the same\n\t * //creates a = [10.0, 11.0, 12.0, 13.0, 14.0, 15.0, 16.0, 17.0, 18.0, 19.0, 20.0, 21.0, 22.0, 23.0, 24.0, 25.0]\n\t */\n\tstatic toArray(matrix: Array<number> | Matrix4, result: Array<number>): Array<number> {\n\t\tif (!defined(result)) {\n\t\t\treturn [\n\t\t\t\tmatrix[0],\n\t\t\t\tmatrix[1],\n\t\t\t\tmatrix[2],\n\t\t\t\tmatrix[3],\n\t\t\t\tmatrix[4],\n\t\t\t\tmatrix[5],\n\t\t\t\tmatrix[6],\n\t\t\t\tmatrix[7],\n\t\t\t\tmatrix[8],\n\t\t\t\tmatrix[9],\n\t\t\t\tmatrix[10],\n\t\t\t\tmatrix[11],\n\t\t\t\tmatrix[12],\n\t\t\t\tmatrix[13],\n\t\t\t\tmatrix[14],\n\t\t\t\tmatrix[15]\n\t\t\t];\n\t\t}\n\t\tresult[0] = matrix[0];\n\t\tresult[1] = matrix[1];\n\t\tresult[2] = matrix[2];\n\t\tresult[3] = matrix[3];\n\t\tresult[4] = matrix[4];\n\t\tresult[5] = matrix[5];\n\t\tresult[6] = matrix[6];\n\t\tresult[7] = matrix[7];\n\t\tresult[8] = matrix[8];\n\t\tresult[9] = matrix[9];\n\t\tresult[10] = matrix[10];\n\t\tresult[11] = matrix[11];\n\t\tresult[12] = matrix[12];\n\t\tresult[13] = matrix[13];\n\t\tresult[14] = matrix[14];\n\t\tresult[15] = matrix[15];\n\t\treturn result;\n\t}\n\n\tstatic getElementIndex(column: number, row: number): number {\n\t\treturn column * 4 + row;\n\t}\n\n\tstatic getColumn(matrix: Matrix4, index: number, result: Vector4): Vector4 {\n\t\tconst startIndex = index * 4;\n\t\tconst x = matrix[startIndex];\n\t\tconst y = matrix[startIndex + 1];\n\t\tconst z = matrix[startIndex + 2];\n\t\tconst w = matrix[startIndex + 3];\n\n\t\tresult.x = x;\n\t\tresult.y = y;\n\t\tresult.z = z;\n\t\tresult.w = w;\n\t\treturn result;\n\t}\n\n\tstatic setColumn(matrix: Matrix4, index: number, cartesian: Vector4, result: Matrix4): Matrix4 {\n\t\tresult = Matrix4.clone(matrix, result);\n\t\tconst startIndex = index * 4;\n\t\tresult[startIndex] = cartesian.x;\n\t\tresult[startIndex + 1] = cartesian.y;\n\t\tresult[startIndex + 2] = cartesian.z;\n\t\tresult[startIndex + 3] = cartesian.w;\n\t\treturn result;\n\t}\n\n\tstatic getRow(matrix: Matrix4, index: number, result: Vector4): Vector4 {\n\t\tconst x = matrix[index];\n\t\tconst y = matrix[index + 4];\n\t\tconst z = matrix[index + 8];\n\t\tconst w = matrix[index + 12];\n\n\t\tresult.x = x;\n\t\tresult.y = y;\n\t\tresult.z = z;\n\t\tresult.w = w;\n\t\treturn result;\n\t}\n\n\tstatic setRow(matrix: Matrix4, index: number, cartesian: Vector4, result: Matrix4): Matrix4 {\n\t\tresult = Matrix4.clone(matrix, result);\n\t\tresult[index] = cartesian.x;\n\t\tresult[index + 4] = cartesian.y;\n\t\tresult[index + 8] = cartesian.z;\n\t\tresult[index + 12] = cartesian.w;\n\t\treturn result;\n\t}\n\n\tstatic setTranslation(matrix: Matrix4, translation: Vector3, result: Matrix4): Matrix4 {\n\t\tresult[0] = matrix[0];\n\t\tresult[1] = matrix[1];\n\t\tresult[2] = matrix[2];\n\t\tresult[3] = matrix[3];\n\n\t\tresult[4] = matrix[4];\n\t\tresult[5] = matrix[5];\n\t\tresult[6] = matrix[6];\n\t\tresult[7] = matrix[7];\n\n\t\tresult[8] = matrix[8];\n\t\tresult[9] = matrix[9];\n\t\tresult[10] = matrix[10];\n\t\tresult[11] = matrix[11];\n\n\t\tresult[12] = translation.x;\n\t\tresult[13] = translation.y;\n\t\tresult[14] = translation.z;\n\t\tresult[15] = matrix[15];\n\n\t\treturn result;\n\t}\n\n\tstatic setScale(matrix: Matrix4, scale: Vector3, result: Matrix4): Matrix4 {\n\t\tconst existingScale = Matrix4.getScale(matrix, scaleScratch1);\n\t\tconst scaleRatioX = scale.x / existingScale.x;\n\t\tconst scaleRatioY = scale.y / existingScale.y;\n\t\tconst scaleRatioZ = scale.z / existingScale.z;\n\n\t\tresult[0] = matrix[0] * scaleRatioX;\n\t\tresult[1] = matrix[1] * scaleRatioX;\n\t\tresult[2] = matrix[2] * scaleRatioX;\n\t\tresult[3] = matrix[3];\n\n\t\tresult[4] = matrix[4] * scaleRatioY;\n\t\tresult[5] = matrix[5] * scaleRatioY;\n\t\tresult[6] = matrix[6] * scaleRatioY;\n\t\tresult[7] = matrix[7];\n\n\t\tresult[8] = matrix[8] * scaleRatioZ;\n\t\tresult[9] = matrix[9] * scaleRatioZ;\n\t\tresult[10] = matrix[10] * scaleRatioZ;\n\t\tresult[11] = matrix[11];\n\n\t\tresult[12] = matrix[12];\n\t\tresult[13] = matrix[13];\n\t\tresult[14] = matrix[14];\n\t\tresult[15] = matrix[15];\n\n\t\treturn result;\n\t}\n\n\tstatic getScale(matrix: Matrix4, result: Vector3): Vector3 {\n\t\tresult.x = Vector3.magnitude(Vector3.fromElements(matrix[0], matrix[1], matrix[2], scratchColumn));\n\t\tresult.y = Vector3.magnitude(Vector3.fromElements(matrix[4], matrix[5], matrix[6], scratchColumn));\n\t\tresult.z = Vector3.magnitude(Vector3.fromElements(matrix[8], matrix[9], matrix[10], scratchColumn));\n\t\treturn result;\n\t}\n\n\tstatic getMaximumScale(matrix: Matrix4): number {\n\t\tMatrix4.getScale(matrix, scaleScratch3);\n\t\treturn Vector3.maximumComponent(scaleScratch3);\n\t}\n\n\tstatic setRotation(matrix: Matrix4, rotation: Matrix3, result: Matrix4): Matrix4 {\n\t\tconst scale = Matrix4.getScale(matrix, scaleScratch4);\n\n\t\tresult[0] = rotation[0] * scale.x;\n\t\tresult[1] = rotation[1] * scale.x;\n\t\tresult[2] = rotation[2] * scale.x;\n\t\tresult[3] = matrix[3];\n\n\t\tresult[4] = rotation[3] * scale.y;\n\t\tresult[5] = rotation[4] * scale.y;\n\t\tresult[6] = rotation[5] * scale.y;\n\t\tresult[7] = matrix[7];\n\n\t\tresult[8] = rotation[6] * scale.z;\n\t\tresult[9] = rotation[7] * scale.z;\n\t\tresult[10] = rotation[8] * scale.z;\n\t\tresult[11] = matrix[11];\n\n\t\tresult[12] = matrix[12];\n\t\tresult[13] = matrix[13];\n\t\tresult[14] = matrix[14];\n\t\tresult[15] = matrix[15];\n\n\t\treturn result;\n\t}\n\n\tstatic getRotation(matrix: Matrix4, result: Quaternion): Quaternion {\n\t\tconst scale = Matrix4.getScale(matrix, scaleScratch5);\n\n\t\tconst is1 = 1 / scale.x;\n\t\tconst is2 = 1 / scale.y;\n\t\tconst is3 = 1 / scale.z;\n\n\t\tconst sm11 = matrix[0] * is1;\n\t\tconst sm12 = matrix[1] * is2;\n\t\tconst sm13 = matrix[2] * is3;\n\t\tconst sm21 = matrix[4] * is1;\n\t\tconst sm22 = matrix[5] * is2;\n\t\tconst sm23 = matrix[6] * is3;\n\t\tconst sm31 = matrix[8] * is1;\n\t\tconst sm32 = matrix[9] * is2;\n\t\tconst sm33 = matrix[10] * is3;\n\n\t\tconst trace = sm11 + sm22 + sm33;\n\t\tlet S = 0;\n\n\t\tif (trace > 0) {\n\t\t\tS = Math.sqrt(trace + 1.0) * 2;\n\t\t\tresult.w = 0.25 * S;\n\t\t\tresult.x = (sm23 - sm32) / S;\n\t\t\tresult.y = (sm31 - sm13) / S;\n\t\t\tresult.z = (sm12 - sm21) / S;\n\t\t} else if (sm11 > sm22 && sm11 > sm33) {\n\t\t\tS = Math.sqrt(1.0 + sm11 - sm22 - sm33) * 2;\n\t\t\tresult.w = (sm23 - sm32) / S;\n\t\t\tresult.x = 0.25 * S;\n\t\t\tresult.y = (sm12 + sm21) / S;\n\t\t\tresult.z = (sm31 + sm13) / S;\n\t\t} else if (sm22 > sm33) {\n\t\t\tS = Math.sqrt(1.0 + sm22 - sm11 - sm33) * 2;\n\t\t\tresult.w = (sm31 - sm13) / S;\n\t\t\tresult.x = (sm12 + sm21) / S;\n\t\t\tresult.y = 0.25 * S;\n\t\t\tresult.z = (sm23 + sm32) / S;\n\t\t} else {\n\t\t\tS = Math.sqrt(1.0 + sm33 - sm11 - sm22) * 2;\n\t\t\tresult.w = (sm12 - sm21) / S;\n\t\t\tresult.x = (sm31 + sm13) / S;\n\t\t\tresult.y = (sm23 + sm32) / S;\n\t\t\tresult.z = 0.25 * S;\n\t\t}\n\t\treturn result;\n\t}\n\n\tstatic multiply(left: Matrix4, right: Matrix4, result: Matrix4): Matrix4 {\n\t\tconst left0 = left[0];\n\t\tconst left1 = left[1];\n\t\tconst left2 = left[2];\n\t\tconst left3 = left[3];\n\t\tconst left4 = left[4];\n\t\tconst left5 = left[5];\n\t\tconst left6 = left[6];\n\t\tconst left7 = left[7];\n\t\tconst left8 = left[8];\n\t\tconst left9 = left[9];\n\t\tconst left10 = left[10];\n\t\tconst left11 = left[11];\n\t\tconst left12 = left[12];\n\t\tconst left13 = left[13];\n\t\tconst left14 = left[14];\n\t\tconst left15 = left[15];\n\n\t\tconst right0 = right[0];\n\t\tconst right1 = right[1];\n\t\tconst right2 = right[2];\n\t\tconst right3 = right[3];\n\t\tconst right4 = right[4];\n\t\tconst right5 = right[5];\n\t\tconst right6 = right[6];\n\t\tconst right7 = right[7];\n\t\tconst right8 = right[8];\n\t\tconst right9 = right[9];\n\t\tconst right10 = right[10];\n\t\tconst right11 = right[11];\n\t\tconst right12 = right[12];\n\t\tconst right13 = right[13];\n\t\tconst right14 = right[14];\n\t\tconst right15 = right[15];\n\n\t\tconst column0Row0 = left0 * right0 + left4 * right1 + left8 * right2 + left12 * right3;\n\t\tconst column0Row1 = left1 * right0 + left5 * right1 + left9 * right2 + left13 * right3;\n\t\tconst column0Row2 = left2 * right0 + left6 * right1 + left10 * right2 + left14 * right3;\n\t\tconst column0Row3 = left3 * right0 + left7 * right1 + left11 * right2 + left15 * right3;\n\n\t\tconst column1Row0 = left0 * right4 + left4 * right5 + left8 * right6 + left12 * right7;\n\t\tconst column1Row1 = left1 * right4 + left5 * right5 + left9 * right6 + left13 * right7;\n\t\tconst column1Row2 = left2 * right4 + left6 * right5 + left10 * right6 + left14 * right7;\n\t\tconst column1Row3 = left3 * right4 + left7 * right5 + left11 * right6 + left15 * right7;\n\n\t\tconst column2Row0 = left0 * right8 + left4 * right9 + left8 * right10 + left12 * right11;\n\t\tconst column2Row1 = left1 * right8 + left5 * right9 + left9 * right10 + left13 * right11;\n\t\tconst column2Row2 = left2 * right8 + left6 * right9 + left10 * right10 + left14 * right11;\n\t\tconst column2Row3 = left3 * right8 + left7 * right9 + left11 * right10 + left15 * right11;\n\n\t\tconst column3Row0 = left0 * right12 + left4 * right13 + left8 * right14 + left12 * right15;\n\t\tconst column3Row1 = left1 * right12 + left5 * right13 + left9 * right14 + left13 * right15;\n\t\tconst column3Row2 = left2 * right12 + left6 * right13 + left10 * right14 + left14 * right15;\n\t\tconst column3Row3 = left3 * right12 + left7 * right13 + left11 * right14 + left15 * right15;\n\n\t\tresult[0] = column0Row0;\n\t\tresult[1] = column0Row1;\n\t\tresult[2] = column0Row2;\n\t\tresult[3] = column0Row3;\n\t\tresult[4] = column1Row0;\n\t\tresult[5] = column1Row1;\n\t\tresult[6] = column1Row2;\n\t\tresult[7] = column1Row3;\n\t\tresult[8] = column2Row0;\n\t\tresult[9] = column2Row1;\n\t\tresult[10] = column2Row2;\n\t\tresult[11] = column2Row3;\n\t\tresult[12] = column3Row0;\n\t\tresult[13] = column3Row1;\n\t\tresult[14] = column3Row2;\n\t\tresult[15] = column3Row3;\n\t\treturn result;\n\t}\n\n\tstatic add(left: Matrix4, right: Matrix4, result: Matrix4): Matrix4 {\n\t\tresult[0] = left[0] + right[0];\n\t\tresult[1] = left[1] + right[1];\n\t\tresult[2] = left[2] + right[2];\n\t\tresult[3] = left[3] + right[3];\n\t\tresult[4] = left[4] + right[4];\n\t\tresult[5] = left[5] + right[5];\n\t\tresult[6] = left[6] + right[6];\n\t\tresult[7] = left[7] + right[7];\n\t\tresult[8] = left[8] + right[8];\n\t\tresult[9] = left[9] + right[9];\n\t\tresult[10] = left[10] + right[10];\n\t\tresult[11] = left[11] + right[11];\n\t\tresult[12] = left[12] + right[12];\n\t\tresult[13] = left[13] + right[13];\n\t\tresult[14] = left[14] + right[14];\n\t\tresult[15] = left[15] + right[15];\n\t\treturn result;\n\t}\n\n\tstatic subtract(left: Matrix4, right: Matrix4, result: Matrix4) {\n\t\tresult[0] = left[0] - right[0];\n\t\tresult[1] = left[1] - right[1];\n\t\tresult[2] = left[2] - right[2];\n\t\tresult[3] = left[3] - right[3];\n\t\tresult[4] = left[4] - right[4];\n\t\tresult[5] = left[5] - right[5];\n\t\tresult[6] = left[6] - right[6];\n\t\tresult[7] = left[7] - right[7];\n\t\tresult[8] = left[8] - right[8];\n\t\tresult[9] = left[9] - right[9];\n\t\tresult[10] = left[10] - right[10];\n\t\tresult[11] = left[11] - right[11];\n\t\tresult[12] = left[12] - right[12];\n\t\tresult[13] = left[13] - right[13];\n\t\tresult[14] = left[14] - right[14];\n\t\tresult[15] = left[15] - right[15];\n\t\treturn result;\n\t}\n\n\tstatic multiplyTransformation(left: Matrix4, right: Matrix4, result: Matrix4): Matrix4 {\n\t\tconst left0 = left[0];\n\t\tconst left1 = left[1];\n\t\tconst left2 = left[2];\n\t\tconst left4 = left[4];\n\t\tconst left5 = left[5];\n\t\tconst left6 = left[6];\n\t\tconst left8 = left[8];\n\t\tconst left9 = left[9];\n\t\tconst left10 = left[10];\n\t\tconst left12 = left[12];\n\t\tconst left13 = left[13];\n\t\tconst left14 = left[14];\n\n\t\tconst right0 = right[0];\n\t\tconst right1 = right[1];\n\t\tconst right2 = right[2];\n\t\tconst right4 = right[4];\n\t\tconst right5 = right[5];\n\t\tconst right6 = right[6];\n\t\tconst right8 = right[8];\n\t\tconst right9 = right[9];\n\t\tconst right10 = right[10];\n\t\tconst right12 = right[12];\n\t\tconst right13 = right[13];\n\t\tconst right14 = right[14];\n\n\t\tconst column0Row0 = left0 * right0 + left4 * right1 + left8 * right2;\n\t\tconst column0Row1 = left1 * right0 + left5 * right1 + left9 * right2;\n\t\tconst column0Row2 = left2 * right0 + left6 * right1 + left10 * right2;\n\n\t\tconst column1Row0 = left0 * right4 + left4 * right5 + left8 * right6;\n\t\tconst column1Row1 = left1 * right4 + left5 * right5 + left9 * right6;\n\t\tconst column1Row2 = left2 * right4 + left6 * right5 + left10 * right6;\n\n\t\tconst column2Row0 = left0 * right8 + left4 * right9 + left8 * right10;\n\t\tconst column2Row1 = left1 * right8 + left5 * right9 + left9 * right10;\n\t\tconst column2Row2 = left2 * right8 + left6 * right9 + left10 * right10;\n\n\t\tconst column3Row0 = left0 * right12 + left4 * right13 + left8 * right14 + left12;\n\t\tconst column3Row1 = left1 * right12 + left5 * right13 + left9 * right14 + left13;\n\t\tconst column3Row2 = left2 * right12 + left6 * right13 + left10 * right14 + left14;\n\n\t\tresult[0] = column0Row0;\n\t\tresult[1] = column0Row1;\n\t\tresult[2] = column0Row2;\n\t\tresult[3] = 0.0;\n\t\tresult[4] = column1Row0;\n\t\tresult[5] = column1Row1;\n\t\tresult[6] = column1Row2;\n\t\tresult[7] = 0.0;\n\t\tresult[8] = column2Row0;\n\t\tresult[9] = column2Row1;\n\t\tresult[10] = column2Row2;\n\t\tresult[11] = 0.0;\n\t\tresult[12] = column3Row0;\n\t\tresult[13] = column3Row1;\n\t\tresult[14] = column3Row2;\n\t\tresult[15] = 1.0;\n\t\treturn result;\n\t}\n\n\tstatic multiplyByMatrix3(matrix: Matrix4, rotation: Matrix3, result: Matrix4): Matrix4 {\n\t\tconst left0 = matrix[0];\n\t\tconst left1 = matrix[1];\n\t\tconst left2 = matrix[2];\n\t\tconst left4 = matrix[4];\n\t\tconst left5 = matrix[5];\n\t\tconst left6 = matrix[6];\n\t\tconst left8 = matrix[8];\n\t\tconst left9 = matrix[9];\n\t\tconst left10 = matrix[10];\n\n\t\tconst right0 = rotation[0];\n\t\tconst right1 = rotation[1];\n\t\tconst right2 = rotation[2];\n\t\tconst right4 = rotation[3];\n\t\tconst right5 = rotation[4];\n\t\tconst right6 = rotation[5];\n\t\tconst right8 = rotation[6];\n\t\tconst right9 = rotation[7];\n\t\tconst right10 = rotation[8];\n\n\t\tconst column0Row0 = left0 * right0 + left4 * right1 + left8 * right2;\n\t\tconst column0Row1 = left1 * right0 + left5 * right1 + left9 * right2;\n\t\tconst column0Row2 = left2 * right0 + left6 * right1 + left10 * right2;\n\n\t\tconst column1Row0 = left0 * right4 + left4 * right5 + left8 * right6;\n\t\tconst column1Row1 = left1 * right4 + left5 * right5 + left9 * right6;\n\t\tconst column1Row2 = left2 * right4 + left6 * right5 + left10 * right6;\n\n\t\tconst column2Row0 = left0 * right8 + left4 * right9 + left8 * right10;\n\t\tconst column2Row1 = left1 * right8 + left5 * right9 + left9 * right10;\n\t\tconst column2Row2 = left2 * right8 + left6 * right9 + left10 * right10;\n\n\t\tresult[0] = column0Row0;\n\t\tresult[1] = column0Row1;\n\t\tresult[2] = column0Row2;\n\t\tresult[3] = 0.0;\n\t\tresult[4] = column1Row0;\n\t\tresult[5] = column1Row1;\n\t\tresult[6] = column1Row2;\n\t\tresult[7] = 0.0;\n\t\tresult[8] = column2Row0;\n\t\tresult[9] = column2Row1;\n\t\tresult[10] = column2Row2;\n\t\tresult[11] = 0.0;\n\t\tresult[12] = matrix[12];\n\t\tresult[13] = matrix[13];\n\t\tresult[14] = matrix[14];\n\t\tresult[15] = matrix[15];\n\t\treturn result;\n\t}\n\n\tstatic multiplyByTranslation(matrix: Matrix4, translation: Vector3, result: Matrix4): Matrix4 {\n\t\tconst x = translation.x;\n\t\tconst y = translation.y;\n\t\tconst z = translation.z;\n\n\t\tconst tx = x * matrix[0] + y * matrix[4] + z * matrix[8] + matrix[12];\n\t\tconst ty = x * matrix[1] + y * matrix[5] + z * matrix[9] + matrix[13];\n\t\tconst tz = x * matrix[2] + y * matrix[6] + z * matrix[10] + matrix[14];\n\n\t\tresult[0] = matrix[0];\n\t\tresult[1] = matrix[1];\n\t\tresult[2] = matrix[2];\n\t\tresult[3] = matrix[3];\n\t\tresult[4] = matrix[4];\n\t\tresult[5] = matrix[5];\n\t\tresult[6] = matrix[6];\n\t\tresult[7] = matrix[7];\n\t\tresult[8] = matrix[8];\n\t\tresult[9] = matrix[9];\n\t\tresult[10] = matrix[10];\n\t\tresult[11] = matrix[11];\n\t\tresult[12] = tx;\n\t\tresult[13] = ty;\n\t\tresult[14] = tz;\n\t\tresult[15] = matrix[15];\n\t\treturn result;\n\t}\n\n\tstatic multiplyByScale(matrix: Matrix4, scale: Vector3, result: Matrix4): Matrix4 {\n\t\tconst scaleX = scale.x;\n\t\tconst scaleY = scale.y;\n\t\tconst scaleZ = scale.z;\n\n\t\t// Faster than Vector3.equals\n\t\tif (scaleX === 1.0 && scaleY === 1.0 && scaleZ === 1.0) {\n\t\t\treturn Matrix4.clone(matrix, result);\n\t\t}\n\n\t\tresult[0] = scaleX * matrix[0];\n\t\tresult[1] = scaleX * matrix[1];\n\t\tresult[2] = scaleX * matrix[2];\n\t\tresult[3] = matrix[3];\n\n\t\tresult[4] = scaleY * matrix[4];\n\t\tresult[5] = scaleY * matrix[5];\n\t\tresult[6] = scaleY * matrix[6];\n\t\tresult[7] = matrix[7];\n\n\t\tresult[8] = scaleZ * matrix[8];\n\t\tresult[9] = scaleZ * matrix[9];\n\t\tresult[10] = scaleZ * matrix[10];\n\t\tresult[11] = matrix[11];\n\n\t\tresult[12] = matrix[12];\n\t\tresult[13] = matrix[13];\n\t\tresult[14] = matrix[14];\n\t\tresult[15] = matrix[15];\n\n\t\treturn result;\n\t}\n\n\tstatic multiplyByUniformScale(matrix: Matrix4, scale: number, result: Matrix4): Matrix4 {\n\t\tresult[0] = matrix[0] * scale;\n\t\tresult[1] = matrix[1] * scale;\n\t\tresult[2] = matrix[2] * scale;\n\t\tresult[3] = matrix[3];\n\n\t\tresult[4] = matrix[4] * scale;\n\t\tresult[5] = matrix[5] * scale;\n\t\tresult[6] = matrix[6] * scale;\n\t\tresult[7] = matrix[7];\n\n\t\tresult[8] = matrix[8] * scale;\n\t\tresult[9] = matrix[9] * scale;\n\t\tresult[10] = matrix[10] * scale;\n\t\tresult[11] = matrix[11];\n\n\t\tresult[12] = matrix[12];\n\t\tresult[13] = matrix[13];\n\t\tresult[14] = matrix[14];\n\t\tresult[15] = matrix[15];\n\n\t\treturn result;\n\t}\n\n\tstatic multiplyByVector(matrix: Matrix4, cartesian: Vector4, result: Vector4): Vector4 {\n\t\tconst vX = cartesian.x;\n\t\tconst vY = cartesian.y;\n\t\tconst vZ = cartesian.z;\n\t\tconst vW = cartesian.w;\n\n\t\tconst x = matrix[0] * vX + matrix[4] * vY + matrix[8] * vZ + matrix[12] * vW;\n\t\tconst y = matrix[1] * vX + matrix[5] * vY + matrix[9] * vZ + matrix[13] * vW;\n\t\tconst z = matrix[2] * vX + matrix[6] * vY + matrix[10] * vZ + matrix[14] * vW;\n\t\tconst w = matrix[3] * vX + matrix[7] * vY + matrix[11] * vZ + matrix[15] * vW;\n\n\t\tresult.x = x;\n\t\tresult.y = y;\n\t\tresult.z = z;\n\t\tresult.w = w;\n\t\treturn result;\n\t}\n\n\tstatic multiplyByPointAsVector(matrix: Matrix4, cartesian: Vector3, result: Vector3): Vector3 {\n\t\tconst vX = cartesian.x;\n\t\tconst vY = cartesian.y;\n\t\tconst vZ = cartesian.z;\n\n\t\tconst x = matrix[0] * vX + matrix[4] * vY + matrix[8] * vZ;\n\t\tconst y = matrix[1] * vX + matrix[5] * vY + matrix[9] * vZ;\n\t\tconst z = matrix[2] * vX + matrix[6] * vY + matrix[10] * vZ;\n\n\t\tresult.x = x;\n\t\tresult.y = y;\n\t\tresult.z = z;\n\t\treturn result;\n\t}\n\n\tstatic multiplyByPoint(matrix: Matrix4, cartesian: Vector3, result: Vector3): Vector3 {\n\t\tconst vX = cartesian.x;\n\t\tconst vY = cartesian.y;\n\t\tconst vZ = cartesian.z;\n\n\t\tconst x = matrix[0] * vX + matrix[4] * vY + matrix[8] * vZ + matrix[12];\n\t\tconst y = matrix[1] * vX + matrix[5] * vY + matrix[9] * vZ + matrix[13];\n\t\tconst z = matrix[2] * vX + matrix[6] * vY + matrix[10] * vZ + matrix[14];\n\n\t\tresult.x = x;\n\t\tresult.y = y;\n\t\tresult.z = z;\n\t\treturn result;\n\t}\n\n\tstatic multiplyByScalar(matrix: Matrix4, scalar: number, result: Matrix4): Matrix4 {\n\t\tresult[0] = matrix[0] * scalar;\n\t\tresult[1] = matrix[1] * scalar;\n\t\tresult[2] = matrix[2] * scalar;\n\t\tresult[3] = matrix[3] * scalar;\n\t\tresult[4] = matrix[4] * scalar;\n\t\tresult[5] = matrix[5] * scalar;\n\t\tresult[6] = matrix[6] * scalar;\n\t\tresult[7] = matrix[7] * scalar;\n\t\tresult[8] = matrix[8] * scalar;\n\t\tresult[9] = matrix[9] * scalar;\n\t\tresult[10] = matrix[10] * scalar;\n\t\tresult[11] = matrix[11] * scalar;\n\t\tresult[12] = matrix[12] * scalar;\n\t\tresult[13] = matrix[13] * scalar;\n\t\tresult[14] = matrix[14] * scalar;\n\t\tresult[15] = matrix[15] * scalar;\n\t\treturn result;\n\t}\n\n\tstatic negate(matrix: Matrix4, result: Matrix4): Matrix4 {\n\t\tresult[0] = -matrix[0];\n\t\tresult[1] = -matrix[1];\n\t\tresult[2] = -matrix[2];\n\t\tresult[3] = -matrix[3];\n\t\tresult[4] = -matrix[4];\n\t\tresult[5] = -matrix[5];\n\t\tresult[6] = -matrix[6];\n\t\tresult[7] = -matrix[7];\n\t\tresult[8] = -matrix[8];\n\t\tresult[9] = -matrix[9];\n\t\tresult[10] = -matrix[10];\n\t\tresult[11] = -matrix[11];\n\t\tresult[12] = -matrix[12];\n\t\tresult[13] = -matrix[13];\n\t\tresult[14] = -matrix[14];\n\t\tresult[15] = -matrix[15];\n\t\treturn result;\n\t}\n\n\tstatic transpose(matrix: Matrix4, result: Matrix4): Matrix4 {\n\t\tconst matrix1 = matrix[1];\n\t\tconst matrix2 = matrix[2];\n\t\tconst matrix3 = matrix[3];\n\t\tconst matrix6 = matrix[6];\n\t\tconst matrix7 = matrix[7];\n\t\tconst matrix11 = matrix[11];\n\n\t\tresult[0] = matrix[0];\n\t\tresult[1] = matrix[4];\n\t\tresult[2] = matrix[8];\n\t\tresult[3] = matrix[12];\n\t\tresult[4] = matrix1;\n\t\tresult[5] = matrix[5];\n\t\tresult[6] = matrix[9];\n\t\tresult[7] = matrix[13];\n\t\tresult[8] = matrix2;\n\t\tresult[9] = matrix6;\n\t\tresult[10] = matrix[10];\n\t\tresult[11] = matrix[14];\n\t\tresult[12] = matrix3;\n\t\tresult[13] = matrix7;\n\t\tresult[14] = matrix11;\n\t\tresult[15] = matrix[15];\n\t\treturn result;\n\t}\n\n\tstatic abs(matrix: Matrix4, result: Matrix4) {\n\t\tresult[0] = Math.abs(matrix[0]);\n\t\tresult[1] = Math.abs(matrix[1]);\n\t\tresult[2] = Math.abs(matrix[2]);\n\t\tresult[3] = Math.abs(matrix[3]);\n\t\tresult[4] = Math.abs(matrix[4]);\n\t\tresult[5] = Math.abs(matrix[5]);\n\t\tresult[6] = Math.abs(matrix[6]);\n\t\tresult[7] = Math.abs(matrix[7]);\n\t\tresult[8] = Math.abs(matrix[8]);\n\t\tresult[9] = Math.abs(matrix[9]);\n\t\tresult[10] = Math.abs(matrix[10]);\n\t\tresult[11] = Math.abs(matrix[11]);\n\t\tresult[12] = Math.abs(matrix[12]);\n\t\tresult[13] = Math.abs(matrix[13]);\n\t\tresult[14] = Math.abs(matrix[14]);\n\t\tresult[15] = Math.abs(matrix[15]);\n\n\t\treturn result;\n\t}\n\n\tstatic equals(left: Matrix4, right: Matrix4): boolean {\n\t\t// Given that most matrices will be transformation matrices, the elements\n\t\t// are tested in order such that the test is likely to fail as early\n\t\t// as possible.  I _think_ this is just as friendly to the L1 cache\n\t\t// as testing in index order.  It is certainty faster in practice.\n\t\treturn (\n\t\t\tleft === right ||\n\t\t\t(defined(left) &&\n\t\t\t\tdefined(right) &&\n\t\t\t\t// Translation\n\t\t\t\tleft[12] === right[12] &&\n\t\t\t\tleft[13] === right[13] &&\n\t\t\t\tleft[14] === right[14] &&\n\t\t\t\t// Rotation/scale\n\t\t\t\tleft[0] === right[0] &&\n\t\t\t\tleft[1] === right[1] &&\n\t\t\t\tleft[2] === right[2] &&\n\t\t\t\tleft[4] === right[4] &&\n\t\t\t\tleft[5] === right[5] &&\n\t\t\t\tleft[6] === right[6] &&\n\t\t\t\tleft[8] === right[8] &&\n\t\t\t\tleft[9] === right[9] &&\n\t\t\t\tleft[10] === right[10] &&\n\t\t\t\t// Bottom row\n\t\t\t\tleft[3] === right[3] &&\n\t\t\t\tleft[7] === right[7] &&\n\t\t\t\tleft[11] === right[11] &&\n\t\t\t\tleft[15] === right[15])\n\t\t);\n\t}\n\n\tstatic equalsEpsilon(left: Matrix4, right: Matrix4, epsilon: number): boolean {\n\t\tepsilon = defaultValue(epsilon, 0);\n\n\t\treturn (\n\t\t\tleft === right ||\n\t\t\t(defined(left) &&\n\t\t\t\tdefined(right) &&\n\t\t\t\tMath.abs(left[0] - right[0]) <= epsilon &&\n\t\t\t\tMath.abs(left[1] - right[1]) <= epsilon &&\n\t\t\t\tMath.abs(left[2] - right[2]) <= epsilon &&\n\t\t\t\tMath.abs(left[3] - right[3]) <= epsilon &&\n\t\t\t\tMath.abs(left[4] - right[4]) <= epsilon &&\n\t\t\t\tMath.abs(left[5] - right[5]) <= epsilon &&\n\t\t\t\tMath.abs(left[6] - right[6]) <= epsilon &&\n\t\t\t\tMath.abs(left[7] - right[7]) <= epsilon &&\n\t\t\t\tMath.abs(left[8] - right[8]) <= epsilon &&\n\t\t\t\tMath.abs(left[9] - right[9]) <= epsilon &&\n\t\t\t\tMath.abs(left[10] - right[10]) <= epsilon &&\n\t\t\t\tMath.abs(left[11] - right[11]) <= epsilon &&\n\t\t\t\tMath.abs(left[12] - right[12]) <= epsilon &&\n\t\t\t\tMath.abs(left[13] - right[13]) <= epsilon &&\n\t\t\t\tMath.abs(left[14] - right[14]) <= epsilon &&\n\t\t\t\tMath.abs(left[15] - right[15]) <= epsilon)\n\t\t);\n\t}\n\n\tstatic getTranslation(matrix: Matrix4, result: Vector3): Vector3 {\n\t\tresult.x = matrix[12];\n\t\tresult.y = matrix[13];\n\t\tresult.z = matrix[14];\n\t\treturn result;\n\t}\n\n\tstatic getMatrix3(matrix: Matrix4, result: Matrix3): Matrix3 {\n\t\tresult[0] = matrix[0];\n\t\tresult[1] = matrix[1];\n\t\tresult[2] = matrix[2];\n\t\tresult[3] = matrix[4];\n\t\tresult[4] = matrix[5];\n\t\tresult[5] = matrix[6];\n\t\tresult[6] = matrix[8];\n\t\tresult[7] = matrix[9];\n\t\tresult[8] = matrix[10];\n\t\treturn result;\n\t}\n\n\tstatic inverse(matrix: Matrix4, result: Matrix4) {\n\t\t//\n\t\t// Ported from:\n\t\t//   ftp://download.intel.com/design/PentiumIII/sml/24504301.pdf\n\t\t//\n\t\tconst src0 = matrix[0];\n\t\tconst src1 = matrix[4];\n\t\tconst src2 = matrix[8];\n\t\tconst src3 = matrix[12];\n\t\tconst src4 = matrix[1];\n\t\tconst src5 = matrix[5];\n\t\tconst src6 = matrix[9];\n\t\tconst src7 = matrix[13];\n\t\tconst src8 = matrix[2];\n\t\tconst src9 = matrix[6];\n\t\tconst src10 = matrix[10];\n\t\tconst src11 = matrix[14];\n\t\tconst src12 = matrix[3];\n\t\tconst src13 = matrix[7];\n\t\tconst src14 = matrix[11];\n\t\tconst src15 = matrix[15];\n\n\t\t// calculate pairs for first 8 elements (cofactors)\n\t\tlet tmp0 = src10 * src15;\n\t\tlet tmp1 = src11 * src14;\n\t\tlet tmp2 = src9 * src15;\n\t\tlet tmp3 = src11 * src13;\n\t\tlet tmp4 = src9 * src14;\n\t\tlet tmp5 = src10 * src13;\n\t\tlet tmp6 = src8 * src15;\n\t\tlet tmp7 = src11 * src12;\n\t\tlet tmp8 = src8 * src14;\n\t\tlet tmp9 = src10 * src12;\n\t\tlet tmp10 = src8 * src13;\n\t\tlet tmp11 = src9 * src12;\n\n\t\t// calculate first 8 elements (cofactors)\n\t\tconst dst0 = tmp0 * src5 + tmp3 * src6 + tmp4 * src7 - (tmp1 * src5 + tmp2 * src6 + tmp5 * src7);\n\t\tconst dst1 = tmp1 * src4 + tmp6 * src6 + tmp9 * src7 - (tmp0 * src4 + tmp7 * src6 + tmp8 * src7);\n\t\tconst dst2 = tmp2 * src4 + tmp7 * src5 + tmp10 * src7 - (tmp3 * src4 + tmp6 * src5 + tmp11 * src7);\n\t\tconst dst3 = tmp5 * src4 + tmp8 * src5 + tmp11 * src6 - (tmp4 * src4 + tmp9 * src5 + tmp10 * src6);\n\t\tconst dst4 = tmp1 * src1 + tmp2 * src2 + tmp5 * src3 - (tmp0 * src1 + tmp3 * src2 + tmp4 * src3);\n\t\tconst dst5 = tmp0 * src0 + tmp7 * src2 + tmp8 * src3 - (tmp1 * src0 + tmp6 * src2 + tmp9 * src3);\n\t\tconst dst6 = tmp3 * src0 + tmp6 * src1 + tmp11 * src3 - (tmp2 * src0 + tmp7 * src1 + tmp10 * src3);\n\t\tconst dst7 = tmp4 * src0 + tmp9 * src1 + tmp10 * src2 - (tmp5 * src0 + tmp8 * src1 + tmp11 * src2);\n\n\t\t// calculate pairs for second 8 elements (cofactors)\n\t\ttmp0 = src2 * src7;\n\t\ttmp1 = src3 * src6;\n\t\ttmp2 = src1 * src7;\n\t\ttmp3 = src3 * src5;\n\t\ttmp4 = src1 * src6;\n\t\ttmp5 = src2 * src5;\n\t\ttmp6 = src0 * src7;\n\t\ttmp7 = src3 * src4;\n\t\ttmp8 = src0 * src6;\n\t\ttmp9 = src2 * src4;\n\t\ttmp10 = src0 * src5;\n\t\ttmp11 = src1 * src4;\n\n\t\t// calculate second 8 elements (cofactors)\n\t\tconst dst8 = tmp0 * src13 + tmp3 * src14 + tmp4 * src15 - (tmp1 * src13 + tmp2 * src14 + tmp5 * src15);\n\t\tconst dst9 = tmp1 * src12 + tmp6 * src14 + tmp9 * src15 - (tmp0 * src12 + tmp7 * src14 + tmp8 * src15);\n\t\tconst dst10 = tmp2 * src12 + tmp7 * src13 + tmp10 * src15 - (tmp3 * src12 + tmp6 * src13 + tmp11 * src15);\n\t\tconst dst11 = tmp5 * src12 + tmp8 * src13 + tmp11 * src14 - (tmp4 * src12 + tmp9 * src13 + tmp10 * src14);\n\t\tconst dst12 = tmp2 * src10 + tmp5 * src11 + tmp1 * src9 - (tmp4 * src11 + tmp0 * src9 + tmp3 * src10);\n\t\tconst dst13 = tmp8 * src11 + tmp0 * src8 + tmp7 * src10 - (tmp6 * src10 + tmp9 * src11 + tmp1 * src8);\n\t\tconst dst14 = tmp6 * src9 + tmp11 * src11 + tmp3 * src8 - (tmp10 * src11 + tmp2 * src8 + tmp7 * src9);\n\t\tconst dst15 = tmp10 * src10 + tmp4 * src8 + tmp9 * src9 - (tmp8 * src9 + tmp11 * src10 + tmp5 * src8);\n\n\t\t// calculate determinant\n\t\tlet det = src0 * dst0 + src1 * dst1 + src2 * dst2 + src3 * dst3;\n\n\t\tif (Math.abs(det) < GMath.EPSILON21) {\n\t\t\t// Special case for a zero scale matrix that can occur, for example,\n\t\t\t// when a model's node has a [0, 0, 0] scale.\n\t\t\tif (\n\t\t\t\tMatrix3.equalsEpsilon(\n\t\t\t\t\tMatrix4.getMatrix3(matrix, scratchInverseRotation),\n\t\t\t\t\tscratchMatrix3Zero,\n\t\t\t\t\tGMath.EPSILON7\n\t\t\t\t) &&\n\t\t\t\tVector4.equals(Matrix4.getRow(matrix, 3, scratchBottomRow), scratchExpectedBottomRow)\n\t\t\t) {\n\t\t\t\tresult[0] = 0.0;\n\t\t\t\tresult[1] = 0.0;\n\t\t\t\tresult[2] = 0.0;\n\t\t\t\tresult[3] = 0.0;\n\t\t\t\tresult[4] = 0.0;\n\t\t\t\tresult[5] = 0.0;\n\t\t\t\tresult[6] = 0.0;\n\t\t\t\tresult[7] = 0.0;\n\t\t\t\tresult[8] = 0.0;\n\t\t\t\tresult[9] = 0.0;\n\t\t\t\tresult[10] = 0.0;\n\t\t\t\tresult[11] = 0.0;\n\t\t\t\tresult[12] = -matrix[12];\n\t\t\t\tresult[13] = -matrix[13];\n\t\t\t\tresult[14] = -matrix[14];\n\t\t\t\tresult[15] = 1.0;\n\t\t\t\treturn result;\n\t\t\t}\n\n\t\t\tthrow new Error(\"matrix is not invertible because its determinate is zero.\");\n\t\t}\n\n\t\t// calculate matrix inverse\n\t\tdet = 1.0 / det;\n\n\t\tresult[0] = dst0 * det;\n\t\tresult[1] = dst1 * det;\n\t\tresult[2] = dst2 * det;\n\t\tresult[3] = dst3 * det;\n\t\tresult[4] = dst4 * det;\n\t\tresult[5] = dst5 * det;\n\t\tresult[6] = dst6 * det;\n\t\tresult[7] = dst7 * det;\n\t\tresult[8] = dst8 * det;\n\t\tresult[9] = dst9 * det;\n\t\tresult[10] = dst10 * det;\n\t\tresult[11] = dst11 * det;\n\t\tresult[12] = dst12 * det;\n\t\tresult[13] = dst13 * det;\n\t\tresult[14] = dst14 * det;\n\t\tresult[15] = dst15 * det;\n\t\treturn result;\n\t}\n\n\tstatic inverseTransformation(matrix: Matrix4, result: Matrix4): Matrix4 {\n\t\t// This function is an optimized version of the below 4 lines.\n\t\t// const rT = Matrix3.transpose(Matrix4.getMatrix3(matrix));\n\t\t// const rTN = Matrix3.negate(rT);\n\t\t// const rTT = Matrix3.multiplyByVector(rTN, Matrix4.getTranslation(matrix));\n\t\t// return Matrix4.fromRotationTranslation(rT, rTT, result);\n\n\t\tconst matrix0 = matrix[0];\n\t\tconst matrix1 = matrix[1];\n\t\tconst matrix2 = matrix[2];\n\t\tconst matrix4 = matrix[4];\n\t\tconst matrix5 = matrix[5];\n\t\tconst matrix6 = matrix[6];\n\t\tconst matrix8 = matrix[8];\n\t\tconst matrix9 = matrix[9];\n\t\tconst matrix10 = matrix[10];\n\n\t\tconst vX = matrix[12];\n\t\tconst vY = matrix[13];\n\t\tconst vZ = matrix[14];\n\n\t\tconst x = -matrix0 * vX - matrix1 * vY - matrix2 * vZ;\n\t\tconst y = -matrix4 * vX - matrix5 * vY - matrix6 * vZ;\n\t\tconst z = -matrix8 * vX - matrix9 * vY - matrix10 * vZ;\n\n\t\tresult[0] = matrix0;\n\t\tresult[1] = matrix4;\n\t\tresult[2] = matrix8;\n\t\tresult[3] = 0.0;\n\t\tresult[4] = matrix1;\n\t\tresult[5] = matrix5;\n\t\tresult[6] = matrix9;\n\t\tresult[7] = 0.0;\n\t\tresult[8] = matrix2;\n\t\tresult[9] = matrix6;\n\t\tresult[10] = matrix10;\n\t\tresult[11] = 0.0;\n\t\tresult[12] = x;\n\t\tresult[13] = y;\n\t\tresult[14] = z;\n\t\tresult[15] = 1.0;\n\t\treturn result;\n\t}\n\n\tstatic inverseTranspose(matrix: Matrix4, result: Matrix4): Matrix4 {\n\t\treturn Matrix4.inverse(Matrix4.transpose(matrix, scratchTransposeMatrix), result);\n\t}\n\t/**\n\t * @private\n\t */\n\tstatic equalsArray(matrix: Matrix4, array: Array<number>, offset: number): boolean {\n\t\treturn (\n\t\t\tmatrix[0] === array[offset] &&\n\t\t\tmatrix[1] === array[offset + 1] &&\n\t\t\tmatrix[2] === array[offset + 2] &&\n\t\t\tmatrix[3] === array[offset + 3] &&\n\t\t\tmatrix[4] === array[offset + 4] &&\n\t\t\tmatrix[5] === array[offset + 5] &&\n\t\t\tmatrix[6] === array[offset + 6] &&\n\t\t\tmatrix[7] === array[offset + 7] &&\n\t\t\tmatrix[8] === array[offset + 8] &&\n\t\t\tmatrix[9] === array[offset + 9] &&\n\t\t\tmatrix[10] === array[offset + 10] &&\n\t\t\tmatrix[11] === array[offset + 11] &&\n\t\t\tmatrix[12] === array[offset + 12] &&\n\t\t\tmatrix[13] === array[offset + 13] &&\n\t\t\tmatrix[14] === array[offset + 14] &&\n\t\t\tmatrix[15] === array[offset + 15]\n\t\t);\n\t}\n}\n\nconst scratchTransposeMatrix = new Matrix4();\n\nconst fromCameraF = new Vector3();\nconst fromCameraR = new Vector3();\nconst fromCameraU = new Vector3();\n\nconst scaleScratch1 = new Vector3();\nconst scaleScratch2 = new Vector3();\nconst scratchColumn = new Vector3();\nconst scaleScratch3 = new Vector3();\nconst scaleScratch4 = new Vector3();\nconst scaleScratch5 = new Vector3();\nconst scratchInverseRotation = new Matrix3();\nconst scratchMatrix3Zero = new Matrix3();\nconst scratchBottomRow = new Vector4();\nconst scratchExpectedBottomRow = new Vector4(0.0, 0.0, 0.0, 1.0);\nconst x = new Vector3();\nconst y = new Vector3();\nconst z = new Vector3();\nexport default Matrix4;\n","import Camera from \"../camera/Camera\";\r\nimport Matrix4 from \"../math/Matrix4\";\r\nimport Plane from \"../math/Plane\";\r\nimport Vector3 from \"../math/Vector3\";\r\nimport defaultValue from \"../utils/defaultValue\";\r\nimport defined from \"../utils/defined\";\r\nimport { Intersect } from \"./WebGPUConstant\";\r\n\r\nexport default class BoundingSphere {\r\n\tradius: number;\r\n\tcenter: Vector3;\r\n\toriginRadius: number;\r\n\toriginCenter: Vector3;\r\n\tconstructor(center: Vector3 = new Vector3(0, 0, 0), radius = 0) {\r\n\t\tthis.center = center;\r\n\t\tthis.radius = radius;\r\n\t\tthis.originCenter = this.center.clone();\r\n\t\tthis.originRadius = radius;\r\n\t}\r\n\t/**\r\n\t * @param {Vector3[]} [positions] An array of points that the bounding sphere will enclose.  Each point must have <code>x</code>, <code>y</code>, and <code>z</code> properties.\r\n\t * @returns {BoundingSphere} The modified result parameter or a new BoundingSphere instance if one was not provided.\r\n\t */\r\n\tstatic fromPoints(positions: Vector3[]) {\r\n\t\tconst result = new BoundingSphere();\r\n\r\n\t\tif (!defined(positions) || positions.length === 0) {\r\n\t\t\tresult.center = Vector3.clone(Vector3.ZERO, result.center);\r\n\t\t\tresult.radius = 0.0;\r\n\t\t\treturn result;\r\n\t\t}\r\n\r\n\t\tconst currentPos = Vector3.clone(positions[0], fromPointsCurrentPos);\r\n\r\n\t\tconst xMin = Vector3.clone(currentPos, fromPointsXMin);\r\n\t\tconst yMin = Vector3.clone(currentPos, fromPointsYMin);\r\n\t\tconst zMin = Vector3.clone(currentPos, fromPointsZMin);\r\n\r\n\t\tconst xMax = Vector3.clone(currentPos, fromPointsXMax);\r\n\t\tconst yMax = Vector3.clone(currentPos, fromPointsYMax);\r\n\t\tconst zMax = Vector3.clone(currentPos, fromPointsZMax);\r\n\r\n\t\tconst numPositions = positions.length;\r\n\t\tlet i;\r\n\t\tfor (i = 1; i < numPositions; i++) {\r\n\t\t\tVector3.clone(positions[i], currentPos);\r\n\r\n\t\t\tconst x = currentPos.x;\r\n\t\t\tconst y = currentPos.y;\r\n\t\t\tconst z = currentPos.z;\r\n\r\n\t\t\t// Store points containing the the smallest and largest components\r\n\t\t\tif (x < xMin.x) {\r\n\t\t\t\tVector3.clone(currentPos, xMin);\r\n\t\t\t}\r\n\r\n\t\t\tif (x > xMax.x) {\r\n\t\t\t\tVector3.clone(currentPos, xMax);\r\n\t\t\t}\r\n\r\n\t\t\tif (y < yMin.y) {\r\n\t\t\t\tVector3.clone(currentPos, yMin);\r\n\t\t\t}\r\n\r\n\t\t\tif (y > yMax.y) {\r\n\t\t\t\tVector3.clone(currentPos, yMax);\r\n\t\t\t}\r\n\r\n\t\t\tif (z < zMin.z) {\r\n\t\t\t\tVector3.clone(currentPos, zMin);\r\n\t\t\t}\r\n\r\n\t\t\tif (z > zMax.z) {\r\n\t\t\t\tVector3.clone(currentPos, zMax);\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\t// Compute x-, y-, and z-spans (Squared distances b/n each component's min. and max.).\r\n\t\tconst xSpan = Vector3.magnitudeSquared(Vector3.subtract(xMax, xMin, fromPointsScratch));\r\n\t\tconst ySpan = Vector3.magnitudeSquared(Vector3.subtract(yMax, yMin, fromPointsScratch));\r\n\t\tconst zSpan = Vector3.magnitudeSquared(Vector3.subtract(zMax, zMin, fromPointsScratch));\r\n\r\n\t\t// Set the diameter endpoints to the largest span.\r\n\t\tlet diameter1 = xMin;\r\n\t\tlet diameter2 = xMax;\r\n\t\tlet maxSpan = xSpan;\r\n\t\tif (ySpan > maxSpan) {\r\n\t\t\tmaxSpan = ySpan;\r\n\t\t\tdiameter1 = yMin;\r\n\t\t\tdiameter2 = yMax;\r\n\t\t}\r\n\t\tif (zSpan > maxSpan) {\r\n\t\t\tmaxSpan = zSpan;\r\n\t\t\tdiameter1 = zMin;\r\n\t\t\tdiameter2 = zMax;\r\n\t\t}\r\n\r\n\t\t// Calculate the center of the initial sphere found by Ritter's algorithm\r\n\t\tconst ritterCenter = fromPointsRitterCenter;\r\n\t\tritterCenter.x = (diameter1.x + diameter2.x) * 0.5;\r\n\t\tritterCenter.y = (diameter1.y + diameter2.y) * 0.5;\r\n\t\tritterCenter.z = (diameter1.z + diameter2.z) * 0.5;\r\n\r\n\t\t// Calculate the radius of the initial sphere found by Ritter's algorithm\r\n\t\tlet radiusSquared = Vector3.magnitudeSquared(Vector3.subtract(diameter2, ritterCenter, fromPointsScratch));\r\n\t\tlet ritterRadius = Math.sqrt(radiusSquared);\r\n\r\n\t\t// Find the center of the sphere found using the Naive method.\r\n\t\tconst minBoxPt = fromPointsMinBoxPt;\r\n\t\tminBoxPt.x = xMin.x;\r\n\t\tminBoxPt.y = yMin.y;\r\n\t\tminBoxPt.z = zMin.z;\r\n\r\n\t\tconst maxBoxPt = fromPointsMaxBoxPt;\r\n\t\tmaxBoxPt.x = xMax.x;\r\n\t\tmaxBoxPt.y = yMax.y;\r\n\t\tmaxBoxPt.z = zMax.z;\r\n\r\n\t\tconst naiveCenter = Vector3.midpoint(minBoxPt, maxBoxPt, fromPointsNaiveCenterScratch);\r\n\r\n\t\t// Begin 2nd pass to find naive radius and modify the ritter sphere.\r\n\t\tlet naiveRadius = 0;\r\n\t\tfor (i = 0; i < numPositions; i++) {\r\n\t\t\tVector3.clone(positions[i], currentPos);\r\n\r\n\t\t\t// Find the furthest point from the naive center to calculate the naive radius.\r\n\t\t\tconst r = Vector3.magnitude(Vector3.subtract(currentPos, naiveCenter, fromPointsScratch));\r\n\t\t\tif (r > naiveRadius) {\r\n\t\t\t\tnaiveRadius = r;\r\n\t\t\t}\r\n\r\n\t\t\t// Make adjustments to the Ritter Sphere to include all points.\r\n\t\t\tconst oldCenterToPointSquared = Vector3.magnitudeSquared(\r\n\t\t\t\tVector3.subtract(currentPos, ritterCenter, fromPointsScratch)\r\n\t\t\t);\r\n\t\t\tif (oldCenterToPointSquared > radiusSquared) {\r\n\t\t\t\tconst oldCenterToPoint = Math.sqrt(oldCenterToPointSquared);\r\n\t\t\t\t// Calculate new radius to include the point that lies outside\r\n\t\t\t\tritterRadius = (ritterRadius + oldCenterToPoint) * 0.5;\r\n\t\t\t\tradiusSquared = ritterRadius * ritterRadius;\r\n\t\t\t\t// Calculate center of new Ritter sphere\r\n\t\t\t\tconst oldToNew = oldCenterToPoint - ritterRadius;\r\n\t\t\t\tritterCenter.x = (ritterRadius * ritterCenter.x + oldToNew * currentPos.x) / oldCenterToPoint;\r\n\t\t\t\tritterCenter.y = (ritterRadius * ritterCenter.y + oldToNew * currentPos.y) / oldCenterToPoint;\r\n\t\t\t\tritterCenter.z = (ritterRadius * ritterCenter.z + oldToNew * currentPos.z) / oldCenterToPoint;\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\tif (ritterRadius < naiveRadius) {\r\n\t\t\tVector3.clone(ritterCenter, result.center);\r\n\t\t\tresult.radius = ritterRadius;\r\n\t\t} else {\r\n\t\t\tVector3.clone(naiveCenter, result.center);\r\n\t\t\tresult.radius = naiveRadius;\r\n\t\t}\r\n\r\n\t\treturn result;\r\n\t}\r\n\t/**\r\n\t * Computes a tight-fitting bounding sphere enclosing a list of 3D points, where the points are\r\n\t * stored in a flat array in X, Y, Z, order.  The bounding sphere is computed by running two\r\n\t * algorithms, a naive algorithm and Ritter's algorithm. The smaller of the two spheres is used to\r\n\t * ensure a tight fit.\r\n\t *\r\n\t * @param {Number[]} [positions] An array of points that the bounding sphere will enclose.  Each point\r\n\t *        is formed from three elements in the array in the order X, Y, Z.\r\n\t * @param {Vector3} [center=Vector3.ZERO] The position to which the positions are relative, which need not be the\r\n\t *        origin of the coordinate system.  This is useful when the positions are to be used for\r\n\t *        relative-to-center (RTC) rendering.\r\n\t * @param {Number} [stride=3] The number of array elements per vertex.  It must be at least 3, but it may\r\n\t *        be higher.  Regardless of the value of this parameter, the X coordinate of the first position\r\n\t *        is at array index 0, the Y coordinate is at array index 1, and the Z coordinate is at array index\r\n\t *        2.  When stride is 3, the X coordinate of the next position then begins at array index 3.  If\r\n\t *        the stride is 5, however, two array elements are skipped and the next position begins at array\r\n\t *        index 5.\r\n\t * @param {BoundingSphere} [result] The object onto which to store the result.\r\n\t * @returns {BoundingSphere} The modified result parameter or a new BoundingSphere instance if one was not provided.\r\n\t *\r\n\t * @example\r\n\t * // Compute the bounding sphere from 3 positions, each specified relative to a center.\r\n\t * // In addition to the X, Y, and Z coordinates, the points array contains two additional\r\n\t * // elements per point which are ignored for the purpose of computing the bounding sphere.\r\n\t * const center = new Vector3(1.0, 2.0, 3.0);\r\n\t * const points = [1.0, 2.0, 3.0, 0.1, 0.2,\r\n\t *               4.0, 5.0, 6.0, 0.1, 0.2,\r\n\t *               7.0, 8.0, 9.0, 0.1, 0.2];\r\n\t * const sphere = BoundingSphere.fromVertices(points, center, 5);\r\n\t *\r\n\t */\r\n\tstatic fromVertices(positions: number[], center: Vector3 = Vector3.ZERO, stride = 3) {\r\n\t\tconst result = new BoundingSphere();\r\n\r\n\t\tif (!defined(positions) || positions.length === 0) {\r\n\t\t\tresult.center = Vector3.clone(Vector3.ZERO, result.center);\r\n\t\t\tresult.radius = 0.0;\r\n\t\t\treturn result;\r\n\t\t}\r\n\r\n\t\tcenter = defaultValue(center, Vector3.ZERO);\r\n\r\n\t\tstride = defaultValue(stride, 3);\r\n\r\n\t\tconst currentPos = fromPointsCurrentPos;\r\n\t\tcurrentPos.x = positions[0] + center.x;\r\n\t\tcurrentPos.y = positions[1] + center.y;\r\n\t\tcurrentPos.z = positions[2] + center.z;\r\n\r\n\t\tconst xMin = Vector3.clone(currentPos, fromPointsXMin);\r\n\t\tconst yMin = Vector3.clone(currentPos, fromPointsYMin);\r\n\t\tconst zMin = Vector3.clone(currentPos, fromPointsZMin);\r\n\r\n\t\tconst xMax = Vector3.clone(currentPos, fromPointsXMax);\r\n\t\tconst yMax = Vector3.clone(currentPos, fromPointsYMax);\r\n\t\tconst zMax = Vector3.clone(currentPos, fromPointsZMax);\r\n\r\n\t\tconst numElements = positions.length;\r\n\t\tlet i;\r\n\t\tfor (i = 0; i < numElements; i += stride) {\r\n\t\t\tconst x = positions[i] + center.x;\r\n\t\t\tconst y = positions[i + 1] + center.y;\r\n\t\t\tconst z = positions[i + 2] + center.z;\r\n\r\n\t\t\tcurrentPos.x = x;\r\n\t\t\tcurrentPos.y = y;\r\n\t\t\tcurrentPos.z = z;\r\n\r\n\t\t\t// Store points containing the the smallest and largest components\r\n\t\t\tif (x < xMin.x) {\r\n\t\t\t\tVector3.clone(currentPos, xMin);\r\n\t\t\t}\r\n\r\n\t\t\tif (x > xMax.x) {\r\n\t\t\t\tVector3.clone(currentPos, xMax);\r\n\t\t\t}\r\n\r\n\t\t\tif (y < yMin.y) {\r\n\t\t\t\tVector3.clone(currentPos, yMin);\r\n\t\t\t}\r\n\r\n\t\t\tif (y > yMax.y) {\r\n\t\t\t\tVector3.clone(currentPos, yMax);\r\n\t\t\t}\r\n\r\n\t\t\tif (z < zMin.z) {\r\n\t\t\t\tVector3.clone(currentPos, zMin);\r\n\t\t\t}\r\n\r\n\t\t\tif (z > zMax.z) {\r\n\t\t\t\tVector3.clone(currentPos, zMax);\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\t// Compute x-, y-, and z-spans (Squared distances b/n each component's min. and max.).\r\n\t\tconst xSpan = Vector3.magnitudeSquared(Vector3.subtract(xMax, xMin, fromPointsScratch));\r\n\t\tconst ySpan = Vector3.magnitudeSquared(Vector3.subtract(yMax, yMin, fromPointsScratch));\r\n\t\tconst zSpan = Vector3.magnitudeSquared(Vector3.subtract(zMax, zMin, fromPointsScratch));\r\n\r\n\t\t// Set the diameter endpoints to the largest span.\r\n\t\tlet diameter1 = xMin;\r\n\t\tlet diameter2 = xMax;\r\n\t\tlet maxSpan = xSpan;\r\n\t\tif (ySpan > maxSpan) {\r\n\t\t\tmaxSpan = ySpan;\r\n\t\t\tdiameter1 = yMin;\r\n\t\t\tdiameter2 = yMax;\r\n\t\t}\r\n\t\tif (zSpan > maxSpan) {\r\n\t\t\tmaxSpan = zSpan;\r\n\t\t\tdiameter1 = zMin;\r\n\t\t\tdiameter2 = zMax;\r\n\t\t}\r\n\r\n\t\t// Calculate the center of the initial sphere found by Ritter's algorithm\r\n\t\tconst ritterCenter = fromPointsRitterCenter;\r\n\t\tritterCenter.x = (diameter1.x + diameter2.x) * 0.5;\r\n\t\tritterCenter.y = (diameter1.y + diameter2.y) * 0.5;\r\n\t\tritterCenter.z = (diameter1.z + diameter2.z) * 0.5;\r\n\r\n\t\t// Calculate the radius of the initial sphere found by Ritter's algorithm\r\n\t\tlet radiusSquared = Vector3.magnitudeSquared(Vector3.subtract(diameter2, ritterCenter, fromPointsScratch));\r\n\t\tlet ritterRadius = Math.sqrt(radiusSquared);\r\n\r\n\t\t// Find the center of the sphere found using the Naive method.\r\n\t\tconst minBoxPt = fromPointsMinBoxPt;\r\n\t\tminBoxPt.x = xMin.x;\r\n\t\tminBoxPt.y = yMin.y;\r\n\t\tminBoxPt.z = zMin.z;\r\n\r\n\t\tconst maxBoxPt = fromPointsMaxBoxPt;\r\n\t\tmaxBoxPt.x = xMax.x;\r\n\t\tmaxBoxPt.y = yMax.y;\r\n\t\tmaxBoxPt.z = zMax.z;\r\n\r\n\t\tconst naiveCenter = Vector3.midpoint(minBoxPt, maxBoxPt, fromPointsNaiveCenterScratch);\r\n\r\n\t\t// Begin 2nd pass to find naive radius and modify the ritter sphere.\r\n\t\tlet naiveRadius = 0;\r\n\t\tfor (i = 0; i < numElements; i += stride) {\r\n\t\t\tcurrentPos.x = positions[i] + center.x;\r\n\t\t\tcurrentPos.y = positions[i + 1] + center.y;\r\n\t\t\tcurrentPos.z = positions[i + 2] + center.z;\r\n\r\n\t\t\t// Find the furthest point from the naive center to calculate the naive radius.\r\n\t\t\tconst r = Vector3.magnitude(Vector3.subtract(currentPos, naiveCenter, fromPointsScratch));\r\n\t\t\tif (r > naiveRadius) {\r\n\t\t\t\tnaiveRadius = r;\r\n\t\t\t}\r\n\r\n\t\t\t// Make adjustments to the Ritter Sphere to include all points.\r\n\t\t\tconst oldCenterToPointSquared = Vector3.magnitudeSquared(\r\n\t\t\t\tVector3.subtract(currentPos, ritterCenter, fromPointsScratch)\r\n\t\t\t);\r\n\t\t\tif (oldCenterToPointSquared > radiusSquared) {\r\n\t\t\t\tconst oldCenterToPoint = Math.sqrt(oldCenterToPointSquared);\r\n\t\t\t\t// Calculate new radius to include the point that lies outside\r\n\t\t\t\tritterRadius = (ritterRadius + oldCenterToPoint) * 0.5;\r\n\t\t\t\tradiusSquared = ritterRadius * ritterRadius;\r\n\t\t\t\t// Calculate center of new Ritter sphere\r\n\t\t\t\tconst oldToNew = oldCenterToPoint - ritterRadius;\r\n\t\t\t\tritterCenter.x = (ritterRadius * ritterCenter.x + oldToNew * currentPos.x) / oldCenterToPoint;\r\n\t\t\t\tritterCenter.y = (ritterRadius * ritterCenter.y + oldToNew * currentPos.y) / oldCenterToPoint;\r\n\t\t\t\tritterCenter.z = (ritterRadius * ritterCenter.z + oldToNew * currentPos.z) / oldCenterToPoint;\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\tif (ritterRadius < naiveRadius) {\r\n\t\t\tVector3.clone(ritterCenter, result.center);\r\n\t\t\tresult.radius = ritterRadius;\r\n\t\t} else {\r\n\t\t\tVector3.clone(naiveCenter, result.center);\r\n\t\t\tresult.radius = naiveRadius;\r\n\t\t}\r\n\r\n\t\treturn result;\r\n\t}\r\n\r\n\tintersectPlane(plane: Plane) {\r\n\t\tconst center = this.center;\r\n\t\tconst radius = this.radius;\r\n\t\tconst normal = plane.normal;\r\n\t\tconst distanceToPlane = Vector3.dot(normal, center) + plane.distance;\r\n\r\n\t\tif (distanceToPlane < -radius) {\r\n\t\t\t// The center point is negative side of the plane normal\r\n\t\t\treturn Intersect.OUTSIDE;\r\n\t\t} else if (distanceToPlane < radius) {\r\n\t\t\t// The center point is positive side of the plane, but radius extends beyond it; partial overlap\r\n\t\t\treturn Intersect.INTERSECTING;\r\n\t\t}\r\n\t\treturn Intersect.INSIDE;\r\n\t}\r\n\tupdate(transform: Matrix4) {\r\n\t\tMatrix4.multiplyByPoint(transform, this.originCenter, this.center);\r\n\t\tthis.radius = Matrix4.getMaximumScale(transform) * this.originRadius;\r\n\t}\r\n\tdistanceToCamera(camera: Camera) {\r\n\t\treturn Math.max(0.0, Vector3.distance(this.center, camera.position) - this.radius);\r\n\t}\r\n}\r\nconst fromPointsXMin = new Vector3();\r\nconst fromPointsYMin = new Vector3();\r\nconst fromPointsZMin = new Vector3();\r\nconst fromPointsXMax = new Vector3();\r\nconst fromPointsYMax = new Vector3();\r\nconst fromPointsZMax = new Vector3();\r\nconst fromPointsCurrentPos = new Vector3();\r\nconst fromPointsScratch = new Vector3();\r\nconst fromPointsRitterCenter = new Vector3();\r\nconst fromPointsMinBoxPt = new Vector3();\r\nconst fromPointsMaxBoxPt = new Vector3();\r\nconst fromPointsNaiveCenterScratch = new Vector3();\r\n","import { IndexFormat } from \"../core/WebGPUConstant\";\r\nimport Buffer from \"./Buffer\";\r\nexport default class IndexBuffer {\r\n\tbuffer: Buffer;\r\n\tindices: Array<number>;\r\n\tindexFormat: GPUIndexFormat;\r\n\tdirty: boolean;\r\n\tprivate label: string;\r\n\tconstructor(label: string, indices?: Array<number>) {\r\n\t\tthis.label = label;\r\n\t\tthis.indices = indices;\r\n\t\tthis.indexFormat = IndexFormat.Uint16;\r\n\t\tthis.dirty = true;\r\n\t}\r\n\tsetIndices(indices) {\r\n\t\tthis.indices = indices;\r\n\t\tthis.dirty = true;\r\n\t}\r\n\tbind(device: GPUDevice, passEncoder: GPURenderPassEncoder) {\r\n\t\tif (this.dirty) {\r\n\t\t\tthis.dirty = false;\r\n\t\t\tthis.buffer = Buffer.createIndexBuffer(\r\n\t\t\t\tthis.label,\r\n\t\t\t\tdevice,\r\n\t\t\t\tthis.indexFormat == IndexFormat.Uint16 ? new Uint16Array(this.indices) : new Uint32Array(this.indices)\r\n\t\t\t);\r\n\t\t}\r\n\t\tpassEncoder.setIndexBuffer(this.buffer.gpuBuffer, this.indexFormat);\r\n\t}\r\n\tdestroy() {\r\n\t\tthis.buffer.destroy();\r\n\t}\r\n}\r\n","import { Attribute, AttributeType, InterleavedAttribute } from \"./Attribute\";\r\nexport default class Attributes {\r\n\tpublic interleave: boolean;\r\n\tprivate _attributes: Map<string, Attribute|InterleavedAttribute>;\r\n\tprivate shaderLocation: number;\r\n\tprivate offset: number;\r\n\tconstructor() {\r\n\t\tthis._attributes = new Map();\r\n\t\tthis.shaderLocation = 0;\r\n\t\tthis.offset = 0;\r\n\t\tthis.interleave = false;\r\n\t}\r\n\tgetAttribute(name):Attribute|InterleavedAttribute {\r\n\t\treturn this._attributes.get(name);\r\n\t}\r\n\tsetAttribute(attribute: Attribute|InterleavedAttribute) {\r\n\t\tif (attribute.attributeType===AttributeType.attribute) {\r\n      this.setNotInterleavedAttribute(attribute as Attribute)\r\n\t\t} else {\r\n\t\t\tthis.setInterleavedAttribute(attribute as InterleavedAttribute)\r\n\t\t}\r\n\t}\r\n\tprivate setNotInterleavedAttribute(attribute: Attribute){\r\n\t\tif (this._attributes.has(attribute.name)) return;\r\n\t\tattribute.shaderLocation = this.shaderLocation;\r\n\t\tthis.shaderLocation += 1;\r\n\t\tattribute.offset = this.offset;\r\n\t\tthis.offset += attribute.attributeByteSize;\r\n\t\tthis._attributes.set(attribute.name, attribute);\r\n\t}\r\n\tprivate setInterleavedAttribute(attribute: InterleavedAttribute){\r\n\t\tif (this._attributes.has(attribute.names.toString())) return;\r\n\t\tthis._attributes.set(attribute.names.toString(), attribute);\r\n\t}\r\n\tgetGPUAttributes() {\r\n\t\tconst result = [];\r\n\t\tthis._attributes.forEach((attribute) => {\r\n\t\t\tresult.push(...attribute.getGPUAttribute());\r\n\t\t});\r\n\t\treturn result;\r\n\t}\r\n\tgetAtrributeValues(): {\r\n\t\tarrayStride: number;\r\n\t\ttypeArray: Float32Array;\r\n\t} {\r\n\t\tconst arrayStrides = [];\r\n\t\tlet arrayStride = 0;\r\n\t\tlet values = null;\r\n\t\tconst arrays = [];\r\n\t\tthis._attributes.forEach((attribute:Attribute|InterleavedAttribute) => {\r\n\t\t\tif (attribute.attributeType===AttributeType.attribute) {\r\n\t\t\t\tarrayStrides.push((attribute as Attribute).itemSize);\r\n\t\t\t\tarrays.push(attribute.value);\r\n\t\t\t\tarrayStride += (attribute as Attribute).itemSize;\r\n\t\t\t} else {\r\n\t\t\t\tif(!this.interleave)this.interleave=true;\r\n\t\t\t\tvalues = values ?? attribute.value;\r\n\t\t\t\tarrayStride=(attribute as InterleavedAttribute).itemSizes.reduce((total,current)=>total+=current,0)\r\n\t\t\t}\r\n\t\t\t\r\n\t\t});\r\n\t\t\r\n\t\tconst typeArray = this.interleave\r\n\t\t\t? new Float32Array(values)\r\n\t\t\t: this.interleaveTypedArray(Float32Array, arrayStrides, ...arrays);\r\n\t\treturn {\r\n\t\t\tarrayStride: arrayStride * typeArray.BYTES_PER_ELEMENT,\r\n\t\t\ttypeArray\r\n\t\t};\r\n\t}\r\n\tdestroy() {\r\n\t\tthis._attributes.forEach((attribute) => {\r\n\t\t\tattribute.destroy();\r\n\t\t});\r\n\t}\r\n\t/**\r\n\t * Interleave n typed arrays\r\n\t * @alias module:interleaveTypedArray\r\n\t * @param {TypedArray} ResultConstructor Returned typed array constructor\r\n\t * @param {Array} elements Number of elements to group for each typed array\r\n\t * @param {...TypedArray} arrays Arrays to interleave\r\n\t * @returns {TypedArray}\r\n\t */\r\n\tinterleaveTypedArray(ResultConstructor, elements, ...arrays) {\r\n\t\tconst totalLength = arrays.reduce((total, arr) => total + arr.length, 0);\r\n\t\tconst result = new ResultConstructor(totalLength);\r\n\t\tconst stride = elements.reduce((a, b) => a + b);\r\n\r\n\t\tfor (let i = 0; i < totalLength; i++) {\r\n\t\t\tlet offset = 0;\r\n\t\t\tfor (let j = 0; j < elements.length; j++) {\r\n\t\t\t\tfor (let k = 0; k < elements[j]; k++) {\r\n\t\t\t\t\tresult[i * stride + offset] = arrays[j][elements[j] * i + k];\r\n\t\t\t\t\toffset++;\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t}\r\n\t\treturn result;\r\n\t}\r\n}\r\n","import { InputStepMode } from \"../core/WebGPUConstant\";\r\nimport { Attribute, InterleavedAttribute } from \"./Attribute\";\r\nimport Attributes from \"./Attributes\";\r\nimport Buffer from \"./Buffer\";\r\nexport default class VertextBuffer {\r\n\tpublic index: number;\r\n\tpublic arrayStride: number;\r\n\tpublic stepMode: string;\r\n\tpublic buffer: Buffer;\r\n\tpublic attributes: Attributes;\r\n\tpublic dirty: boolean;\r\n\tprivate label: string;\r\n\tconstructor(label: string, index?: number, stepMode?: string) {\r\n\t\tthis.index = index || 0;\r\n\t\tthis.attributes = new Attributes();\r\n\t\tthis.stepMode = InputStepMode.Vertex;\r\n\t\tthis.dirty = true;\r\n\t\tthis.label = label;\r\n\t}\r\n\tpublic getBufferDes() {\r\n\t\treturn [\r\n\t\t\t{\r\n\t\t\t\tarrayStride: this.arrayStride,\r\n\t\t\t\tstepMode: this.stepMode,\r\n\t\t\t\tattributes: this.attributes.getGPUAttributes()\r\n\t\t\t}\r\n\t\t];\r\n\t}\r\n\tpublic setAttribute(attribute: Attribute|InterleavedAttribute) {\r\n\t\tthis.attributes.setAttribute(attribute);\r\n\t\tthis.dirty = true;\r\n\t}\r\n\tpublic getAttribute(name: string): Attribute|InterleavedAttribute {\r\n\t\treturn this.attributes.getAttribute(name);\r\n\t}\r\n\tpublic bind(device: GPUDevice, passEncoder: GPURenderPassEncoder) {\r\n\t\tif (this.dirty) {\r\n\t\t\tthis.dirty = false;\r\n\t\t\tconst { arrayStride, typeArray } = this.attributes.getAtrributeValues();\r\n\t\t\tthis.arrayStride = arrayStride;\r\n\t\t\tthis.buffer = Buffer.createVertexBuffer(this.label, device, typeArray);\r\n\t\t}\r\n\t\tpassEncoder.setVertexBuffer(this.index, this.buffer.gpuBuffer);\r\n\t}\r\n\tdestroy() {\r\n\t\tthis.buffer.destroy();\r\n\t\tthis.attributes.destroy();\r\n\t}\r\n}\r\n","import defaultValue from \"./defaultValue\";\r\nimport defined from \"./defined\";\r\n\r\n/**\r\n * Merges two objects, copying their properties onto a new combined object. When two objects have the same\r\n * property, the value of the property on the first object is used.  If either object is undefined,\r\n * it will be treated as an empty object.\r\n *\r\n * @example\r\n * const object1 = {\r\n *     propOne : 1,\r\n *     propTwo : {\r\n *         value1 : 10\r\n *     }\r\n * }\r\n * const object2 = {\r\n *     propTwo : 2\r\n * }\r\n * const final = Cesium.combine(object1, object2);\r\n *\r\n * // final === {\r\n * //     propOne : 1,\r\n * //     propTwo : {\r\n * //         value1 : 10\r\n * //     }\r\n * // }\r\n *\r\n * @param {Object} [object1] The first object to merge.\r\n * @param {Object} [object2] The second object to merge.\r\n * @param {Boolean} [deep=false] Perform a recursive merge.\r\n * @returns {Object} The combined object containing all properties from both objects.\r\n *\r\n * @function\r\n */\r\nfunction combine(object1, object2, deep) {\r\n  deep = defaultValue(deep, false);\r\n\r\n  const result = {};\r\n\r\n  const object1Defined = defined(object1);\r\n  const object2Defined = defined(object2);\r\n  let property;\r\n  let object1Value;\r\n  let object2Value;\r\n  if (object1Defined) {\r\n    for (property in object1) {\r\n      if (object1.hasOwnProperty(property)) {\r\n        object1Value = object1[property];\r\n        if (\r\n          object2Defined &&\r\n          deep &&\r\n          typeof object1Value === \"object\" &&\r\n          object2.hasOwnProperty(property)\r\n        ) {\r\n          object2Value = object2[property];\r\n          if (typeof object2Value === \"object\") {\r\n            result[property] = combine(object1Value, object2Value, deep);\r\n          } else {\r\n            result[property] = object1Value;\r\n          }\r\n        } else {\r\n          result[property] = object1Value;\r\n        }\r\n      }\r\n    }\r\n  }\r\n  if (object2Defined) {\r\n    for (property in object2) {\r\n      if (\r\n        object2.hasOwnProperty(property) &&\r\n        !result.hasOwnProperty(property)\r\n      ) {\r\n        object2Value = object2[property];\r\n        result[property] = object2Value;\r\n      }\r\n    }\r\n  }\r\n  return result;\r\n}\r\nexport default combine;\r\n","import BoundingBox from \"../core/BoundingBox\";\r\nimport BoundingSphere from \"../core/BoundingSphere\";\r\nimport { FrameState } from \"../core/FrameState\";\r\nimport { PrimitiveTopology } from \"../core/WebGPUConstant\";\r\nimport Vector2 from \"../math/Vector2\";\r\nimport Vector3 from \"../math/Vector3\";\r\nimport Vector4 from \"../math/Vector4\";\r\nimport { Attribute, AttributeType, InterleavedFloat32Attribute } from \"../render/Attribute\";\r\nimport IndexBuffer from \"../render/IndexBuffer\";\r\nimport VertextBuffer from \"../render/VertextBuffer\";\r\nimport combine from \"../utils/combine\";\r\nexport default class Geometry {\r\n\tnormals: number[];\r\n\tuvs: number[];\r\n\tpositions: number[];\r\n\tindices: number[];\r\n\ttangents: number[];\r\n\ttype: string;\r\n\tdirty: boolean;\r\n\tindexBuffer?: IndexBuffer;\r\n\tvertBuffer: VertextBuffer;\r\n\tcount: number;\r\n\tboundingSphere?: BoundingSphere;\r\n\tboundingBox?: BoundingBox;\r\n\tprivate _defines: { [prop: string]: boolean | number };\r\n\tprivate locationIndex?: number;\r\n\tdefinesDirty: boolean;\r\n\ttopology: PrimitiveTopology;\r\n\tget defines() {\r\n\t\treturn this._defines;\r\n\t}\r\n\tset defines(value) {\r\n\t\tthis.definesDirty = true;\r\n\t\tthis._defines = combine(value, this._defines, false);\r\n\t}\r\n\tconstructor(options?: any) {\r\n\t\tthis.type = options.type || undefined;\r\n\t\tthis.boundingSphere = undefined;\r\n\t\tthis.dirty = false;\r\n\t\tthis.definesDirty = true;\r\n\t\tthis.locationIndex = 0;\r\n\t\tthis.vertBuffer = new VertextBuffer(this.type, 0);\r\n\t\tthis._defines = {};\r\n\t\tthis.normals = [];\r\n\t\tthis.uvs = [];\r\n\t\tthis.positions = [];\r\n\t\tthis.indices = [];\r\n\t\tthis.tangents = [];\r\n\t}\r\n\tgetAttribute(name: string) {\r\n\t\treturn this.vertBuffer.getAttribute(name);\r\n\t}\r\n\tsetAttribute(attribute: Attribute|InterleavedFloat32Attribute) {\r\n\t\tif(attribute.attributeType===AttributeType.attribute){\r\n\t\t\tthis.setLocationIndex((attribute as Attribute).name)\r\n\t\t}else{\r\n\t\t\t(attribute as InterleavedFloat32Attribute)?.names.forEach((name:string)=>this.setLocationIndex(name))\r\n\t\t}\r\n\t\tthis.vertBuffer.setAttribute(attribute);\r\n\t}\r\n\tprivate setLocationIndex(name:string){\r\n\t\tif(this._defines[name?.concat(\"Location\")]||!name) return;\r\n\t\tthis._defines[name?.concat(\"Location\")] = this.locationIndex;\r\n\t\tthis.locationIndex += 1;\r\n\t}\r\n\tcontainAttribute(name: string): boolean {\r\n\t\treturn this._defines[name?.concat(\"Location\")] != undefined ? true : false;\r\n\t}\r\n\tsetIndice(indices: Array<number>) {\r\n\t\tthis.indices = indices;\r\n\t\tif (!this.indexBuffer) this.indexBuffer = new IndexBuffer(this.type + \"IndexBuffer\");\r\n\t\tthis.indexBuffer.setIndices(indices);\r\n\t}\r\n\tupdate(frameState: FrameState) {}\r\n\tcomputeBoundingSphere(positions:number[],stride=3) {\r\n\t\tthis.boundingSphere = BoundingSphere.fromVertices(positions, new Vector3(0, 0, 0), stride);\r\n\t}\r\n\t/**\r\n\t * Calculate mesh tangent.\r\n\t * @remark need to set positions(with or not with indices), normals, uv before calculation.\r\n\t * @remark based on http://foundationsofgameenginedev.com/FGED2-sample.pdf\r\n\t */\r\n\tcalculateTangents(): void {\r\n\t\tif (!this.normals || !this.uvs) {\r\n\t\t\tthrow \"Set normal and uv before calculation.\";\r\n\t\t}\r\n\t\tconst { indices, positions, normals, uvs } = this;\r\n\t\tconst tempPos0 = new Vector3(),\r\n\t\t\ttempPos1 = new Vector3(),\r\n\t\t\ttempPos2 = new Vector3(),\r\n\t\t\ttempUV0 = new Vector2(),\r\n\t\t\ttempUV1 = new Vector2(),\r\n\t\t\ttempUV2 = new Vector2();\r\n\t\tconst e1 = new Vector3(),\r\n\t\t\te2 = new Vector3(),\r\n\t\t\tt = new Vector3(),\r\n\t\t\tb = new Vector3(),\r\n\t\t\ttemp = new Vector3();\r\n\t\tconst vertexCount = this.indices.length;\r\n\t\tconst triangleCount = indices ? indices.length / 3 : positions.length / 3;\r\n\t\tconst tangents = new Array<Vector4>(vertexCount);\r\n\t\tconst biTangents = new Array<Vector3>(vertexCount);\r\n\t\tthis.tangents = [];\r\n\t\tfor (let i = 0; i < vertexCount; i++) {\r\n\t\t\ttangents[i] = new Vector4();\r\n\t\t\tbiTangents[i] = new Vector3();\r\n\t\t}\r\n\r\n\t\t// Calculate tangent and bi-tangent for each triangle and add to all three vertices.\r\n\t\tfor (let k = 0; k < triangleCount; k++) {\r\n\t\t\tlet i0 = 3 * k;\r\n\t\t\tlet i1 = 3 * k + 1;\r\n\t\t\tlet i2 = 3 * k + 2;\r\n\t\t\tif (indices) {\r\n\t\t\t\ti0 = indices[i0];\r\n\t\t\t\ti1 = indices[i1];\r\n\t\t\t\ti2 = indices[i2];\r\n\t\t\t}\r\n\r\n\t\t\tconst p0 = tempPos0.set(positions[i0], positions[i0 + 1], positions[i0 + 2]);\r\n\t\t\tconst p1 = tempPos1.set(positions[i1], positions[i1 + 1], positions[i1 + 2]);\r\n\t\t\tconst p2 = tempPos2.set(positions[i2], positions[i2 + 1], positions[i2 + 2]);\r\n\t\t\tconst w0 = tempUV0.set(uvs[i0], uvs[i0 + 1]);\r\n\t\t\tconst w1 = tempUV1.set(uvs[i1], uvs[i1 + 1]);\r\n\t\t\tconst w2 = tempUV2.set(uvs[i2], uvs[i2 + 1]);\r\n\r\n\t\t\tVector3.subtract(p1, p0, e1);\r\n\t\t\tVector3.subtract(p2, p0, e2);\r\n\t\t\tconst x1 = w1.x - w0.x;\r\n\t\t\tconst x2 = w2.x - w0.x;\r\n\t\t\tconst y1 = w1.y - w0.y;\r\n\t\t\tconst y2 = w2.y - w0.y;\r\n\t\t\tconst r = 1.0 / (x1 * y2 - x2 * y1);\r\n\r\n\t\t\tVector3.multiplyByScalar(e1, y2 * r, t);\r\n\t\t\tVector3.multiplyByScalar(e2, y1 * r, temp);\r\n\t\t\tVector3.subtract(t, temp, t);\r\n\t\t\tVector3.multiplyByScalar(e2, x1 * r, b);\r\n\t\t\tVector3.multiplyByScalar(e1, x2 * r, temp);\r\n\t\t\tVector3.subtract(b, temp, b);\r\n\r\n\t\t\tlet tangent = tangents[i0];\r\n\t\t\ttangent.set(tangent.x + t.x, tangent.y + t.y, tangent.z + t.z, 1.0);\r\n\r\n\t\t\ttangent = tangents[i1];\r\n\t\t\ttangent.set(tangent.x + t.x, tangent.y + t.y, tangent.z + t.z, 1.0);\r\n\r\n\t\t\ttangent = tangents[i2];\r\n\t\t\ttangent.set(tangent.x + t.x, tangent.y + t.y, tangent.z + t.z, 1.0);\r\n\t\t\tbiTangents[i0].add(b);\r\n\t\t\tbiTangents[i1].add(b);\r\n\t\t\tbiTangents[i2].add(b);\r\n\t\t}\r\n\r\n\t\t// Orthonormalize each tangent and calculate the handedness.\r\n\t\tfor (let i = 0; i < vertexCount; i++) {\r\n\t\t\tconst n = new Vector3(normals[3 * i], normals[3 * i + 1], normals[3 * i + 2]);\r\n\t\t\tconst b = biTangents[i];\r\n\t\t\tconst tangent = tangents[i];\r\n\t\t\tt.set(tangent.x, tangent.y, tangent.z);\r\n\r\n\t\t\tVector3.cross(t, b, temp);\r\n\t\t\tconst w = Vector3.dot(temp, n) > 0.0 ? 1 : -1;\r\n\t\t\tVector3.multiplyByScalar(n, Vector3.dot(t, n), temp);\r\n\t\t\tVector3.subtract(t, temp, t);\r\n\t\t\tVector3.normalize(t, t);\r\n\t\t\t// t.normalize();\r\n\t\t\ttangent.set(t.x, t.y, t.z, w);\r\n\t\t\tthis.tangents.push(t.x, t.y, t.z, w);\r\n\t\t}\r\n\t\t// this.setTangents(tangents);\r\n\t}\r\n\tdestroy() {\r\n\t\tthis?.indexBuffer.destroy();\r\n\t\tthis.vertBuffer.destroy();\r\n\t\tthis.normals = null;\r\n\t\tthis.uvs = null;\r\n\t\tthis.positions = null;\r\n\t\tthis.indices = null;\r\n\t\tthis.tangents = null;\r\n\t\tthis.boundingSphere = undefined;\r\n\t}\r\n}\r\n","import { Float32Attribute } from \"../render/Attribute\";\r\nimport Geometry from \"./Geometry\";\r\nexport default class PlaneGeometry extends Geometry {\r\n\tconstructor(public width: number = 10, public height: number = 10) {\r\n\t\tsuper({\r\n\t\t\ttype: \"planeGeometry\"\r\n\t\t});\r\n\t\tthis.defines = {\r\n\t\t\tHAS_NORMAL: true\r\n\t\t};\r\n\t\tthis.init();\r\n\t}\r\n\tprivate init() {\r\n\t\t// generate pos uv normal so on\r\n\t\tconst { indices, normals, uvs, vertices } = this.createGrid(this.width, this.height);\r\n\t\tthis.computeBoundingSphere(vertices);\r\n\t\tthis.setAttribute(new Float32Attribute(\"position\", vertices, 3));\r\n\t\tthis.setAttribute(new Float32Attribute(\"normal\", normals, 3));\r\n\t\tthis.setAttribute(new Float32Attribute(\"uv\", uvs, 2));\r\n\t\tthis.setIndice(indices);\r\n\t\tthis.count = indices.length;\r\n\t}\r\n\tpublic update(frameState) {}\r\n\tprivate createGrid(width = 1, height = 1, widthSegments = 1, heightSegments = 1) {\r\n\t\tconst width_half = width / 2;\r\n\t\tconst height_half = height / 2;\r\n\r\n\t\tconst gridX = Math.floor(widthSegments);\r\n\t\tconst gridY = Math.floor(heightSegments);\r\n\r\n\t\tconst gridX1 = gridX + 1;\r\n\t\tconst gridY1 = gridY + 1;\r\n\r\n\t\tconst segment_width = width / gridX;\r\n\t\tconst segment_height = height / gridY;\r\n\r\n\t\t//\r\n\r\n\t\tconst indices = [];\r\n\t\tconst vertices = [];\r\n\t\tconst normals = [];\r\n\t\tconst uvs = [];\r\n\r\n\t\tfor (let iy = 0; iy < gridY1; iy++) {\r\n\t\t\tconst y = iy * segment_height - height_half;\r\n\r\n\t\t\tfor (let ix = 0; ix < gridX1; ix++) {\r\n\t\t\t\tconst x = ix * segment_width - width_half;\r\n\r\n\t\t\t\tvertices.push(x, -y, 0);\r\n\r\n\t\t\t\tnormals.push(0, 0, 1);\r\n\r\n\t\t\t\tuvs.push(ix / gridX);\r\n\t\t\t\tuvs.push(1 - iy / gridY);\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\tfor (let iy = 0; iy < gridY; iy++) {\r\n\t\t\tfor (let ix = 0; ix < gridX; ix++) {\r\n\t\t\t\tconst a = ix + gridX1 * iy;\r\n\t\t\t\tconst b = ix + gridX1 * (iy + 1);\r\n\t\t\t\tconst c = ix + 1 + gridX1 * (iy + 1);\r\n\t\t\t\tconst d = ix + 1 + gridX1 * iy;\r\n\r\n\t\t\t\tindices.push(a, b, d);\r\n\t\t\t\tindices.push(b, c, d);\r\n\t\t\t}\r\n\t\t}\r\n\t\treturn { indices, normals, uvs, vertices };\r\n\t}\r\n}\r\n","import defaultValue from \"../utils/defaultValue\";\r\nimport defined from \"../utils/defined\";\r\nimport GMath from \"./Math\";\r\nimport Matrix4 from \"./Matrix4\";\r\nimport Vector3 from \"./Vector3\";\r\n/**\r\n * A set of 4-dimensional coordinates used to represent rotation in 3-dimensional space.\r\n * @alias Quaternion\r\n * @constructor\r\n *\r\n * @param {Number} [x=0.0] The X component.\r\n * @param {Number} [y=0.0] The Y component.\r\n * @param {Number} [z=0.0] The Z component.\r\n * @param {Number} [w=0.0] The W component.\r\n *\r\n * @see PackableForInterpolation\r\n */\r\nexport class Quaternion {\r\n\tpublic static ZERO = Object.freeze(new Quaternion(0.0, 0.0, 0.0, 0.0));\r\n\r\n\tpublic static IDENTITY = Object.freeze(new Quaternion(0.0, 0.0, 0.0, 1.0));\r\n\r\n\tconstructor(public x: number = 0, public y: number = 0, public z: number = 0, public w: number = 1) {}\r\n\tset(x, y, z, w) {\r\n\t\tthis.x = x;\r\n\t\tthis.y = y;\r\n\t\tthis.z = z;\r\n\t\tthis.w = w;\r\n\t}\r\n\tnormalize() {\r\n\t\tconst inverseMagnitude = 1.0 / Quaternion.magnitude(this);\r\n\t\tconst x = this.x * inverseMagnitude;\r\n\t\tconst y = this.y * inverseMagnitude;\r\n\t\tconst z = this.z * inverseMagnitude;\r\n\t\tconst w = this.w * inverseMagnitude;\r\n\r\n\t\tthis.x = x;\r\n\t\tthis.y = y;\r\n\t\tthis.z = z;\r\n\t\tthis.w = w;\r\n\t\treturn this;\r\n\t}\r\n\tinvert() {\r\n\t\tthis.x *= -1;\r\n\t\tthis.y *= -1;\r\n\t\tthis.z *= -1;\r\n\r\n\t\treturn this;\r\n\t}\r\n\tdot(v: Quaternion): number {\r\n\t\treturn this.x * v.x + this.y * v.y + this.z * v.z + this.w * v.w;\r\n\t}\r\n\tsetFromUnitVectors(vFrom: Vector3, vTo: Vector3): Quaternion {\r\n\t\t// assumes direction vectors vFrom and vTo are normalized\r\n\t\tlet r = Vector3.dot(vFrom, vTo) + 1;\r\n\t\tif (r < Number.EPSILON) {\r\n\t\t\t// vFrom and vTo point in opposite directions\r\n\r\n\t\t\tr = 0;\r\n\r\n\t\t\tif (Math.abs(vFrom.x) > Math.abs(vFrom.z)) {\r\n\t\t\t\tthis.x = -vFrom.y;\r\n\t\t\t\tthis.y = vFrom.x;\r\n\t\t\t\tthis.z = 0;\r\n\t\t\t\tthis.w = r;\r\n\t\t\t} else {\r\n\t\t\t\tthis.x = 0;\r\n\t\t\t\tthis.y = -vFrom.z;\r\n\t\t\t\tthis.z = vFrom.y;\r\n\t\t\t\tthis.w = r;\r\n\t\t\t}\r\n\t\t} else {\r\n\t\t\t// crossVectors( vFrom, vTo ); // inlined to avoid cyclic dependency on Vector3\r\n\r\n\t\t\tthis.x = vFrom.y * vTo.z - vFrom.z * vTo.y;\r\n\t\t\tthis.y = vFrom.z * vTo.x - vFrom.x * vTo.z;\r\n\t\t\tthis.z = vFrom.x * vTo.y - vFrom.y * vTo.x;\r\n\t\t\tthis.w = r;\r\n\t\t}\r\n\r\n\t\treturn this.normalize();\r\n\t}\r\n\tsetFromRotationMatrix(matrix: Matrix4): Quaternion {\r\n\t\tconst te = matrix,\r\n\t\t\tm11 = te[0],\r\n\t\t\tm12 = te[4],\r\n\t\t\tm13 = te[8],\r\n\t\t\tm21 = te[1],\r\n\t\t\tm22 = te[5],\r\n\t\t\tm23 = te[9],\r\n\t\t\tm31 = te[2],\r\n\t\t\tm32 = te[6],\r\n\t\t\tm33 = te[10],\r\n\t\t\ttrace = m11 + m22 + m33;\r\n\r\n\t\tif (trace > 0) {\r\n\t\t\tconst s = 0.5 / Math.sqrt(trace + 1.0);\r\n\r\n\t\t\tthis.w = 0.25 / s;\r\n\t\t\tthis.x = (m32 - m23) * s;\r\n\t\t\tthis.y = (m13 - m31) * s;\r\n\t\t\tthis.z = (m21 - m12) * s;\r\n\t\t} else if (m11 > m22 && m11 > m33) {\r\n\t\t\tconst s = 2.0 * Math.sqrt(1.0 + m11 - m22 - m33);\r\n\r\n\t\t\tthis.w = (m32 - m23) / s;\r\n\t\t\tthis.x = 0.25 * s;\r\n\t\t\tthis.y = (m12 + m21) / s;\r\n\t\t\tthis.z = (m13 + m31) / s;\r\n\t\t} else if (m22 > m33) {\r\n\t\t\tconst s = 2.0 * Math.sqrt(1.0 + m22 - m11 - m33);\r\n\r\n\t\t\tthis.w = (m13 - m31) / s;\r\n\t\t\tthis.x = (m12 + m21) / s;\r\n\t\t\tthis.y = 0.25 * s;\r\n\t\t\tthis.z = (m23 + m32) / s;\r\n\t\t} else {\r\n\t\t\tconst s = 2.0 * Math.sqrt(1.0 + m33 - m11 - m22);\r\n\r\n\t\t\tthis.w = (m21 - m12) / s;\r\n\t\t\tthis.x = (m13 + m31) / s;\r\n\t\t\tthis.y = (m23 + m32) / s;\r\n\t\t\tthis.z = 0.25 * s;\r\n\t\t}\r\n\t\treturn this;\r\n\t}\r\n\tclone() {\r\n\t\treturn Quaternion.clone(this, this);\r\n\t}\r\n\r\n\tequals(right: Quaternion): boolean {\r\n\t\treturn Quaternion.equals(this, right);\r\n\t}\r\n\r\n\tequalsEpsilon(right: Quaternion, epsilon = 0): boolean {\r\n\t\treturn Quaternion.equalsEpsilon(this, right, epsilon);\r\n\t}\r\n\ttoArray(): number[] {\r\n\t\tconst { x, y, z, w } = this;\r\n\t\treturn [x, y, z, w];\r\n\t}\r\n\tstatic fromAxisAngle(axis: Vector3, angle: number): Quaternion {\r\n\t\tconst halfAngle = angle / 2.0;\r\n\t\tconst s = Math.sin(halfAngle);\r\n\t\tfromAxisAngleScratch = Vector3.normalize(axis, fromAxisAngleScratch);\r\n\r\n\t\tconst x = fromAxisAngleScratch.x * s;\r\n\t\tconst y = fromAxisAngleScratch.y * s;\r\n\t\tconst z = fromAxisAngleScratch.z * s;\r\n\t\tconst w = Math.cos(halfAngle);\r\n\t\t// if (!defined(result)) {\r\n\t\t//   return\r\n\t\t// }\r\n\t\tconst result = new Quaternion(x, y, z, w);\r\n\t\tresult.x = x;\r\n\t\tresult.y = y;\r\n\t\tresult.z = z;\r\n\t\tresult.w = w;\r\n\t\treturn result;\r\n\t}\r\n\r\n\t// static fromRotationMatrix(matrix: Matrix3, result: Quaternion): Quaternion {\r\n\t// \tlet root;\r\n\t// \tlet x;\r\n\t// \tlet y;\r\n\t// \tlet z;\r\n\t// \tlet w;\r\n\r\n\t// \tconst m00 = matrix[Matrix3.COLUMN0ROW0];\r\n\t// \tconst m11 = matrix[Matrix3.COLUMN1ROW1];\r\n\t// \tconst m22 = matrix[Matrix3.COLUMN2ROW2];\r\n\t// \tconst trace = m00 + m11 + m22;\r\n\r\n\t// \tif (trace > 0.0) {\r\n\t// \t\t// |w| > 1/2, may as well choose w > 1/2\r\n\t// \t\troot = Math.sqrt(trace + 1.0); // 2w\r\n\t// \t\tw = 0.5 * root;\r\n\t// \t\troot = 0.5 / root; // 1/(4w)\r\n\r\n\t// \t\tx = (matrix[Matrix3.COLUMN1ROW2] - matrix[Matrix3.COLUMN2ROW1]) * root;\r\n\t// \t\ty = (matrix[Matrix3.COLUMN2ROW0] - matrix[Matrix3.COLUMN0ROW2]) * root;\r\n\t// \t\tz = (matrix[Matrix3.COLUMN0ROW1] - matrix[Matrix3.COLUMN1ROW0]) * root;\r\n\t// \t} else {\r\n\t// \t\t// |w| <= 1/2\r\n\t// \t\tconst next = fromRotationMatrixNext;\r\n\r\n\t// \t\tlet i = 0;\r\n\t// \t\tif (m11 > m00) {\r\n\t// \t\t\ti = 1;\r\n\t// \t\t}\r\n\t// \t\tif (m22 > m00 && m22 > m11) {\r\n\t// \t\t\ti = 2;\r\n\t// \t\t}\r\n\t// \t\tconst j = next[i];\r\n\t// \t\tconst k = next[j];\r\n\r\n\t// \t\troot = Math.sqrt(\r\n\t// \t\t\tmatrix[Matrix3.getElementIndex(i, i)] -\r\n\t// \t\t\t\tmatrix[Matrix3.getElementIndex(j, j)] -\r\n\t// \t\t\t\tmatrix[Matrix3.getElementIndex(k, k)] +\r\n\t// \t\t\t\t1.0\r\n\t// \t\t);\r\n\r\n\t// \t\tconst quat = fromRotationMatrixQuat;\r\n\t// \t\tquat[i] = 0.5 * root;\r\n\t// \t\troot = 0.5 / root;\r\n\t// \t\tw = (matrix[Matrix3.getElementIndex(k, j)] - matrix[Matrix3.getElementIndex(j, k)]) * root;\r\n\t// \t\tquat[j] = (matrix[Matrix3.getElementIndex(j, i)] + matrix[Matrix3.getElementIndex(i, j)]) * root;\r\n\t// \t\tquat[k] = (matrix[Matrix3.getElementIndex(k, i)] + matrix[Matrix3.getElementIndex(i, k)]) * root;\r\n\r\n\t// \t\tx = -quat[0];\r\n\t// \t\ty = -quat[1];\r\n\t// \t\tz = -quat[2];\r\n\t// \t}\r\n\r\n\t// \tif (!defined(result)) {\r\n\t// \t\treturn new Quaternion(x, y, z, w);\r\n\t// \t}\r\n\t// \tresult.x = x;\r\n\t// \tresult.y = y;\r\n\t// \tresult.z = z;\r\n\t// \tresult.w = w;\r\n\t// \treturn result;\r\n\t// }\r\n\r\n\tstatic clone(quaternion: Quaternion, result: Quaternion): Quaternion {\r\n\t\tif (!defined(quaternion)) {\r\n\t\t\treturn undefined;\r\n\t\t}\r\n\r\n\t\tif (!defined(result)) {\r\n\t\t\treturn new Quaternion(quaternion.x, quaternion.y, quaternion.z, quaternion.w);\r\n\t\t}\r\n\r\n\t\tresult.x = quaternion.x;\r\n\t\tresult.y = quaternion.y;\r\n\t\tresult.z = quaternion.z;\r\n\t\tresult.w = quaternion.w;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic conjugate(quaternion: Quaternion, result: Quaternion): Quaternion {\r\n\t\tresult.x = -quaternion.x;\r\n\t\tresult.y = -quaternion.y;\r\n\t\tresult.z = -quaternion.z;\r\n\t\tresult.w = quaternion.w;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic magnitudeSquared(quaternion: Quaternion): number {\r\n\t\treturn (\r\n\t\t\tquaternion.x * quaternion.x +\r\n\t\t\tquaternion.y * quaternion.y +\r\n\t\t\tquaternion.z * quaternion.z +\r\n\t\t\tquaternion.w * quaternion.w\r\n\t\t);\r\n\t}\r\n\r\n\tstatic magnitude(quaternion: Quaternion): number {\r\n\t\treturn Math.sqrt(Quaternion.magnitudeSquared(quaternion));\r\n\t}\r\n\r\n\tstatic normalize(quaternion: Quaternion, result: Quaternion): Quaternion {\r\n\t\tconst inverseMagnitude = 1.0 / Quaternion.magnitude(quaternion);\r\n\t\tconst x = quaternion.x * inverseMagnitude;\r\n\t\tconst y = quaternion.y * inverseMagnitude;\r\n\t\tconst z = quaternion.z * inverseMagnitude;\r\n\t\tconst w = quaternion.w * inverseMagnitude;\r\n\r\n\t\tresult.x = x;\r\n\t\tresult.y = y;\r\n\t\tresult.z = z;\r\n\t\tresult.w = w;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic inverse(quaternion: Quaternion, result: Quaternion): Quaternion {\r\n\t\tconst magnitudeSquared = Quaternion.magnitudeSquared(quaternion);\r\n\t\tresult = Quaternion.conjugate(quaternion, result);\r\n\t\treturn Quaternion.multiplyByScalar(result, 1.0 / magnitudeSquared, result);\r\n\t}\r\n\r\n\tstatic add(left: Quaternion, right: Quaternion, result: Quaternion): Quaternion {\r\n\t\tresult.x = left.x + right.x;\r\n\t\tresult.y = left.y + right.y;\r\n\t\tresult.z = left.z + right.z;\r\n\t\tresult.w = left.w + right.w;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic subtract(left: Quaternion, right: Quaternion, result: Quaternion): Quaternion {\r\n\t\tresult.x = left.x - right.x;\r\n\t\tresult.y = left.y - right.y;\r\n\t\tresult.z = left.z - right.z;\r\n\t\tresult.w = left.w - right.w;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic negate(quaternion: Quaternion, result: Quaternion): Quaternion {\r\n\t\tresult.x = -quaternion.x;\r\n\t\tresult.y = -quaternion.y;\r\n\t\tresult.z = -quaternion.z;\r\n\t\tresult.w = -quaternion.w;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic dot(left: Quaternion, right: Quaternion): number {\r\n\t\treturn left.x * right.x + left.y * right.y + left.z * right.z + left.w * right.w;\r\n\t}\r\n\r\n\tstatic multiply(left: Quaternion, right: Quaternion, result: Quaternion): Quaternion {\r\n\t\tconst leftX = left.x;\r\n\t\tconst leftY = left.y;\r\n\t\tconst leftZ = left.z;\r\n\t\tconst leftW = left.w;\r\n\r\n\t\tconst rightX = right.x;\r\n\t\tconst rightY = right.y;\r\n\t\tconst rightZ = right.z;\r\n\t\tconst rightW = right.w;\r\n\r\n\t\tconst x = leftW * rightX + leftX * rightW + leftY * rightZ - leftZ * rightY;\r\n\t\tconst y = leftW * rightY - leftX * rightZ + leftY * rightW + leftZ * rightX;\r\n\t\tconst z = leftW * rightZ + leftX * rightY - leftY * rightX + leftZ * rightW;\r\n\t\tconst w = leftW * rightW - leftX * rightX - leftY * rightY - leftZ * rightZ;\r\n\r\n\t\tresult.x = x;\r\n\t\tresult.y = y;\r\n\t\tresult.z = z;\r\n\t\tresult.w = w;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic multiplyByScalar(quaternion: Quaternion, scalar: number, result: Quaternion): Quaternion {\r\n\t\tresult.x = quaternion.x * scalar;\r\n\t\tresult.y = quaternion.y * scalar;\r\n\t\tresult.z = quaternion.z * scalar;\r\n\t\tresult.w = quaternion.w * scalar;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic divideByScalar(quaternion: Quaternion, scalar: number, result: Quaternion): Quaternion {\r\n\t\tresult.x = quaternion.x / scalar;\r\n\t\tresult.y = quaternion.y / scalar;\r\n\t\tresult.z = quaternion.z / scalar;\r\n\t\tresult.w = quaternion.w / scalar;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic computeAxis(quaternion: Quaternion, result: Vector3): Vector3 {\r\n\t\tconst w = quaternion.w;\r\n\t\tif (Math.abs(w - 1.0) < GMath.EPSILON6) {\r\n\t\t\tresult.x = result.y = result.z = 0;\r\n\t\t\treturn result;\r\n\t\t}\r\n\r\n\t\tconst scalar = 1.0 / Math.sqrt(1.0 - w * w);\r\n\r\n\t\tresult.x = quaternion.x * scalar;\r\n\t\tresult.y = quaternion.y * scalar;\r\n\t\tresult.z = quaternion.z * scalar;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic computeAngle(quaternion: Quaternion): number {\r\n\t\tif (Math.abs(quaternion.w - 1.0) < GMath.EPSILON6) {\r\n\t\t\treturn 0.0;\r\n\t\t}\r\n\t\treturn 2.0 * Math.acos(quaternion.w);\r\n\t}\r\n\r\n\tstatic lerp(start: Quaternion, end: Quaternion, t: number, result: Quaternion): Quaternion {\r\n\t\tlerpScratch = Quaternion.multiplyByScalar(end, t, lerpScratch);\r\n\t\tresult = Quaternion.multiplyByScalar(start, 1.0 - t, result);\r\n\t\treturn Quaternion.add(lerpScratch, result, result);\r\n\t}\r\n\r\n\tstatic slerp(start: Quaternion, end: Quaternion, t: number, result: Quaternion): Quaternion {\r\n\t\tlet dot = Quaternion.dot(start, end);\r\n\r\n\t\t// The angle between start must be acute. Since q and -q represent\r\n\t\t// the same rotation, negate q to get the acute angle.\r\n\t\tlet r = end;\r\n\t\tif (dot < 0.0) {\r\n\t\t\tdot = -dot;\r\n\t\t\tr = slerpEndNegated = Quaternion.negate(end, slerpEndNegated);\r\n\t\t}\r\n\r\n\t\t// dot > 0, as the dot product approaches 1, the angle between the\r\n\t\t// quaternions vanishes. use linear interpolation.\r\n\t\tif (1.0 - dot < GMath.EPSILON6) {\r\n\t\t\treturn Quaternion.lerp(start, r, t, result);\r\n\t\t}\r\n\r\n\t\tconst theta = Math.acos(dot);\r\n\t\tslerpScaledP = Quaternion.multiplyByScalar(start, Math.sin((1 - t) * theta), slerpScaledP);\r\n\t\tslerpScaledR = Quaternion.multiplyByScalar(r, Math.sin(t * theta), slerpScaledR);\r\n\t\tresult = Quaternion.add(slerpScaledP, slerpScaledR, result);\r\n\t\treturn Quaternion.multiplyByScalar(result, 1.0 / Math.sin(theta), result);\r\n\t}\r\n\r\n\tstatic squad(\r\n\t\tq0: Quaternion,\r\n\t\tq1: Quaternion,\r\n\t\ts0: Quaternion,\r\n\t\ts1: Quaternion,\r\n\t\tt: number,\r\n\t\tresult: Quaternion\r\n\t): Quaternion {\r\n\t\tconst slerp0 = Quaternion.slerp(q0, q1, t, squadScratchQuaternion0);\r\n\t\tconst slerp1 = Quaternion.slerp(s0, s1, t, squadScratchQuaternion1);\r\n\t\treturn Quaternion.slerp(slerp0, slerp1, 2.0 * t * (1.0 - t), result);\r\n\t}\r\n\tstatic equals(left: Quaternion, right: Quaternion): boolean {\r\n\t\treturn (\r\n\t\t\tleft === right ||\r\n\t\t\t(defined(left) &&\r\n\t\t\t\tdefined(right) &&\r\n\t\t\t\tleft.x === right.x &&\r\n\t\t\t\tleft.y === right.y &&\r\n\t\t\t\tleft.z === right.z &&\r\n\t\t\t\tleft.w === right.w)\r\n\t\t);\r\n\t}\r\n\r\n\tstatic equalsEpsilon(left: Quaternion, right: Quaternion, epsilon = 0): boolean {\r\n\t\tepsilon = defaultValue(epsilon, 0);\r\n\r\n\t\treturn (\r\n\t\t\tleft === right ||\r\n\t\t\t(defined(left) &&\r\n\t\t\t\tdefined(right) &&\r\n\t\t\t\tMath.abs(left.x - right.x) <= epsilon &&\r\n\t\t\t\tMath.abs(left.y - right.y) <= epsilon &&\r\n\t\t\t\tMath.abs(left.z - right.z) <= epsilon &&\r\n\t\t\t\tMath.abs(left.w - right.w) <= epsilon)\r\n\t\t);\r\n\t}\r\n\r\n\tstatic exp(cartesian: Vector3, result: Quaternion): Quaternion {\r\n\t\tconst theta = Vector3.magnitude(cartesian);\r\n\t\tlet sinThetaOverTheta = 0.0;\r\n\r\n\t\tif (theta !== 0.0) {\r\n\t\t\tsinThetaOverTheta = Math.sin(theta) / theta;\r\n\t\t}\r\n\r\n\t\tresult.x = cartesian.x * sinThetaOverTheta;\r\n\t\tresult.y = cartesian.y * sinThetaOverTheta;\r\n\t\tresult.z = cartesian.z * sinThetaOverTheta;\r\n\t\tresult.w = Math.cos(theta);\r\n\r\n\t\treturn result;\r\n\t}\r\n}\r\n\r\nlet fromAxisAngleScratch = new Vector3();\r\n\r\nconst fromRotationMatrixNext = [1, 2, 0];\r\nconst fromRotationMatrixQuat = new Array(3);\r\n\r\nlet lerpScratch = new Quaternion();\r\n\r\nlet slerpEndNegated = new Quaternion();\r\nlet slerpScaledP = new Quaternion();\r\nlet slerpScaledR = new Quaternion();\r\n\r\nconst squadScratchCartesian0 = new Vector3();\r\nconst squadScratchCartesian1 = new Vector3();\r\nconst squadScratchQuaternion0 = new Quaternion();\r\nconst squadScratchQuaternion1 = new Quaternion();\r\n","import Matrix4 from \"../math/Matrix4\";\nimport { Quaternion } from \"../math/Quaternion\";\nimport Vector3 from \"../math/Vector3\";\nimport IClone from \"./IClone\";\nimport { RenderObjectType } from \"./WebGPUTypes\";\n\nexport default class RenderObject implements IClone {\n\tpublic up: Vector3;\n\tprotected _position: Vector3;\n\tprotected _scale: Vector3;\n\tprotected _quaternion: Quaternion;\n\tprotected _target: Vector3;\n\tprivate _normalMatrix: Matrix4;\n\tmodelMatrix: Matrix4;\n\tparent: RenderObject;\n\ttype: RenderObjectType;\n\tname: string;\n\tconstructor() {\n\t\tthis._position = new Vector3();\n\t\tthis._scale = new Vector3(1, 1, 1);\n\t\tthis._quaternion = new Quaternion();\n\t\tthis.modelMatrix = Matrix4.clone(Matrix4.IDENTITY, new Matrix4());\n\t\tthis._normalMatrix = Matrix4.clone(Matrix4.IDENTITY, new Matrix4());\n\t\tthis.up = new Vector3(0, 1, 0);\n\t\tthis._target = new Vector3(0, 0, 0);\n\t}\n\tpublic get normalMatrix(): Matrix4 {\n\t\treturn this._normalMatrix;\n\t}\n\n\tpublic get position(): Vector3 {\n\t\treturn this._position;\n\t}\n\tpublic get scale(): Vector3 {\n\t\treturn this._scale;\n\t}\n\tpublic get quaternion(): Quaternion {\n\t\treturn this._quaternion;\n\t}\n\tprivate updateNormalMatrix() {\n\t\tMatrix4.inverse(this.modelMatrix, this._normalMatrix);\n\t\tMatrix4.transpose(this._normalMatrix, this._normalMatrix);\n\t}\n\tupdateMatrix(matrix?: Matrix4) {\n\t\tthis.modelMatrix.compose(this.position, this.quaternion, this.scale);\n\t\tif (matrix) Matrix4.multiply(matrix, this.modelMatrix, this.modelMatrix);\n\t\tthis.updateNormalMatrix();\n\t}\n\tlookAt(x, y, z) {\n\t\tthis._target.set(x, y, z);\n\t\tif (this.type == RenderObjectType.Camera || this.type == RenderObjectType.Light) {\n\t\t\t_m1.lookAt(this.position, this._target, this.up);\n\t\t} else {\n\t\t\t_m1.lookAt(this._target, this.position, this.up);\n\t\t}\n\t\tthis.quaternion.setFromRotationMatrix(_m1);\n\t}\n\trotateOnAxis(axis, angle) {\n\t\tconst quat = Quaternion.fromAxisAngle(axis, angle);\n\t\tQuaternion.multiply(this.quaternion, quat, this.quaternion);\n\t}\n\trotateX(angle) {\n\t\treturn this.rotateOnAxis(_xAxis, angle);\n\t}\n\trotateY(angle) {\n\t\treturn this.rotateOnAxis(_yAxis, angle);\n\t}\n\trotateZ(angle) {\n\t\treturn this.rotateOnAxis(_zAxis, angle);\n\t}\n}\nconst _xAxis = new Vector3(1, 0, 0);\nconst _yAxis = new Vector3(0, 1, 0);\nconst _zAxis = new Vector3(0, 0, 1);\nconst _m1 = new Matrix4();\n","import RenderObject from \"../core/RenderObject\";\r\nimport { LightType, RenderObjectType } from \"../core/WebGPUTypes\";\r\nimport Vector3 from \"../math/Vector3\";\r\nimport { BaseShadow } from \"./shadows/BaseShadow\";\r\n\r\nexport class Light extends RenderObject {\r\n\tprivate _color: Vector3;\r\n\ttype: RenderObjectType;\r\n\tprivate _intensity: number;\r\n\tdirty: boolean;\r\n\tcolorDirty: boolean;\r\n\tshadowDirty: boolean;\r\n\tintensityDirty: boolean;\r\n\tpositionDirty: boolean;\r\n\tpublic _shadow: BaseShadow;\r\n\tpublic targetDirty: boolean;\r\n\tpublic lightType: LightType;\r\n\r\n\tconstructor(color: Vector3, intensity: number) {\r\n\t\tsuper();\r\n\t\tthis.type = RenderObjectType.Light;\r\n\t\tthis._color = Vector3.multiplyByScalar(color, intensity, new Vector3());\r\n\t\tthis._intensity = intensity;\r\n\t\tthis._position = new Vector3(0, 1, 0);\r\n\t\tthis._target = new Vector3();\r\n\t\tthis.positionDirty = true;\r\n\t\tthis.targetDirty = true;\r\n\t\tthis.colorDirty = true;\r\n\t\tthis.shadowDirty = true;\r\n\t\tthis.intensityDirty = true;\r\n\t\tthis._shadow = null;\r\n\t}\r\n\r\n\tget position() {\r\n\t\treturn this._position;\r\n\t}\r\n\r\n\tset position(value) {\r\n\t\tthis.positionDirty = true;\r\n\t\tthis._position = value;\r\n\t}\r\n\r\n\tget target() {\r\n\t\treturn this._target;\r\n\t}\r\n\r\n\tset target(value) {\r\n\t\tthis.targetDirty = true;\r\n\t\tthis._target = value;\r\n\t}\r\n\r\n\tget color() {\r\n\t\treturn this._color;\r\n\t}\r\n\r\n\tset color(value) {\r\n\t\tthis.colorDirty = true;\r\n\t\tthis._color = value;\r\n\t}\r\n\r\n\tset intensity(value) {\r\n\t\tthis.color = Vector3.multiplyByScalar(this.color, value, new Vector3());\r\n\t\tthis.intensityDirty = true;\r\n\t\tthis._intensity = value;\r\n\t}\r\n\r\n\tget intensity() {\r\n\t\treturn this._intensity;\r\n\t}\r\n\r\n\tget shadow() {\r\n\t\treturn this._shadow;\r\n\t}\r\n\r\n\tset shadow(value) {\r\n\t\tthis.shadowDirty = true;\r\n\t\tthis._shadow = value;\r\n\t}\r\n}\r\n","import defaultValue from \"../utils/defaultValue\";\r\nimport defined from \"../utils/defined\";\r\nimport GMath from \"./Math\";\r\n// #rgba\r\nconst rgbaMatcher = /^#([0-9a-f])([0-9a-f])([0-9a-f])([0-9a-f])?$/i;\r\n// #rrggbbaa\r\nconst rrggbbaaMatcher = /^#([0-9a-f]{2})([0-9a-f]{2})([0-9a-f]{2})([0-9a-f]{2})?$/i;\r\n// rgb(), rgba(), or rgb%()\r\nconst rgbParenthesesMatcher = /^rgba?\\(\\s*([0-9.]+%?)\\s*,\\s*([0-9.]+%?)\\s*,\\s*([0-9.]+%?)(?:\\s*,\\s*([0-9.]+))?\\s*\\)$/i;\r\n// hsl() or hsla()\r\nconst hslParenthesesMatcher = /^hsla?\\(\\s*([0-9.]+)\\s*,\\s*([0-9.]+%)\\s*,\\s*([0-9.]+%)(?:\\s*,\\s*([0-9.]+))?\\s*\\)$/i;\r\nfunction hue2rgb(m1, m2, h) {\r\n\tif (h < 0) {\r\n\t\th += 1;\r\n\t}\r\n\tif (h > 1) {\r\n\t\th -= 1;\r\n\t}\r\n\tif (h * 6 < 1) {\r\n\t\treturn m1 + (m2 - m1) * 6 * h;\r\n\t}\r\n\tif (h * 2 < 1) {\r\n\t\treturn m2;\r\n\t}\r\n\tif (h * 3 < 2) {\r\n\t\treturn m1 + (m2 - m1) * (2 / 3 - h) * 6;\r\n\t}\r\n\treturn m1;\r\n}\r\n\r\nclass Color {\r\n\tgreen: number;\r\n\tred: number;\r\n\tblue: number;\r\n\tconstructor(red = 1.0, green = 1.0, blue = 1.0) {\r\n\t\t/**\r\n\t\t * The red component.\r\n\t\t * @type {Number}\r\n\t\t * @default 1.0\r\n\t\t */\r\n\t\tthis.red = red;\r\n\t\t/**\r\n\t\t * The green component.\r\n\t\t * @type {Number}\r\n\t\t * @default 1.0\r\n\t\t */\r\n\t\tthis.green = green;\r\n\t\t/**\r\n\t\t * The blue component.\r\n\t\t * @type {Number}\r\n\t\t * @default 1.0\r\n\t\t */\r\n\t\tthis.blue = blue;\r\n\t}\r\n\tset(value: string): Color {\r\n\t\tif (typeof value === \"string\") {\r\n\t\t\tColor.fromCssColorString(value, this);\r\n\t\t}\r\n\t\treturn this;\r\n\t}\r\n\ttoArray(): number[] {\r\n\t\treturn [this.red, this.green, this.blue];\r\n\t}\r\n\r\n\tclone(result: Color): Color {\r\n\t\treturn Color.clone(this, result);\r\n\t}\r\n\r\n\tequals(other: Color): boolean {\r\n\t\treturn Color.equals(this, other);\r\n\t}\r\n\r\n\ttoCssHexString(): string {\r\n\t\tlet r = Color.floatToByte(this.red).toString(16);\r\n\t\tif (r.length < 2) {\r\n\t\t\tr = `0${r}`;\r\n\t\t}\r\n\t\tlet g = Color.floatToByte(this.green).toString(16);\r\n\t\tif (g.length < 2) {\r\n\t\t\tg = `0${g}`;\r\n\t\t}\r\n\t\tlet b = Color.floatToByte(this.blue).toString(16);\r\n\t\tif (b.length < 2) {\r\n\t\t\tb = `0${b}`;\r\n\t\t}\r\n\t\treturn `#${r}${g}${b}`;\r\n\t}\r\n\r\n\ttoBytes(result: number[]): number[] {\r\n\t\tconst red = Color.floatToByte(this.red);\r\n\t\tconst green = Color.floatToByte(this.green);\r\n\t\tconst blue = Color.floatToByte(this.blue);\r\n\r\n\t\tif (!defined(result)) {\r\n\t\t\treturn [red, green, blue];\r\n\t\t}\r\n\t\tresult[0] = red;\r\n\t\tresult[1] = green;\r\n\t\tresult[2] = blue;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic fromBytes(red: number, green: number, blue: number, result: Color): Color {\r\n\t\tred = Color.byteToFloat(defaultValue(red, 255.0));\r\n\t\tgreen = Color.byteToFloat(defaultValue(green, 255.0));\r\n\t\tblue = Color.byteToFloat(defaultValue(blue, 255.0));\r\n\r\n\t\tif (!defined(result)) {\r\n\t\t\treturn new Color(red, green, blue);\r\n\t\t}\r\n\r\n\t\tresult.red = red;\r\n\t\tresult.green = green;\r\n\t\tresult.blue = blue;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic fromHsl(hue: number, saturation: number, lightness: number, result: Color): Color {\r\n\t\thue = defaultValue(hue, 0.0) % 1.0;\r\n\t\tsaturation = defaultValue(saturation, 0.0);\r\n\t\tlightness = defaultValue(lightness, 0.0);\r\n\t\tlet red = lightness;\r\n\t\tlet green = lightness;\r\n\t\tlet blue = lightness;\r\n\r\n\t\tif (saturation !== 0) {\r\n\t\t\tlet m2;\r\n\t\t\tif (lightness < 0.5) {\r\n\t\t\t\tm2 = lightness * (1 + saturation);\r\n\t\t\t} else {\r\n\t\t\t\tm2 = lightness + saturation - lightness * saturation;\r\n\t\t\t}\r\n\r\n\t\t\tconst m1 = 2.0 * lightness - m2;\r\n\t\t\tred = hue2rgb(m1, m2, hue + 1 / 3);\r\n\t\t\tgreen = hue2rgb(m1, m2, hue);\r\n\t\t\tblue = hue2rgb(m1, m2, hue - 1 / 3);\r\n\t\t}\r\n\r\n\t\tif (!defined(result)) {\r\n\t\t\treturn new Color(red, green, blue);\r\n\t\t}\r\n\r\n\t\tresult.red = red;\r\n\t\tresult.green = green;\r\n\t\tresult.blue = blue;\r\n\t\treturn result;\r\n\t}\r\n\r\n\t/**\r\n\t * Creates a random color using the provided options. For reproducible random colors, you should\r\n\t * call {@link GMath#setRandomNumberSeed} once at the beginning of your application.\r\n\t *\r\n\t * @param {Object} [options] Object with the following properties:\r\n\t * @param {Number} [options.red] If specified, the red component to use instead of a randomized value.\r\n\t * @param {Number} [options.minimumRed=0.0] The maximum red value to generate if none was specified.\r\n\t * @param {Number} [options.maximumRed=1.0] The minimum red value to generate if none was specified.\r\n\t * @param {Number} [options.green] If specified, the green component to use instead of a randomized value.\r\n\t * @param {Number} [options.minimumGreen=0.0] The maximum green value to generate if none was specified.\r\n\t * @param {Number} [options.maximumGreen=1.0] The minimum green value to generate if none was specified.\r\n\t * @param {Number} [options.blue] If specified, the blue component to use instead of a randomized value.\r\n\t * @param {Number} [options.minimumBlue=0.0] The maximum blue value to generate if none was specified.\r\n\t * @param {Number} [options.maximumBlue=1.0] The minimum blue value to generate if none was specified.\r\n\t * @param {Color} [result] The object to store the result in, if undefined a new instance will be created.\r\n\t * @returns {Color} The modified result parameter or a new instance if result was undefined.\r\n\t *\r\n\t * @example\r\n\t * //Create a completely random color\r\n\t * const color = Color.fromRandom();\r\n\t *\r\n\t * //Create a random shade of yellow.\r\n\t * const color1 = Color.fromRandom({\r\n\t *     red : 1.0,\r\n\t *     green : 1.0,\r\n\t * });\r\n\t *\r\n\t * //Create a random bright color.\r\n\t * const color2 = Color.fromRandom({\r\n\t *     minimumRed : 0.75,\r\n\t *     minimumGreen : 0.75,\r\n\t *     minimumBlue : 0.75,\r\n\t * });\r\n\t */\r\n\tstatic fromRandom(options, result: Color): Color {\r\n\t\toptions = defaultValue(options, defaultValue.EMPTY_OBJECT);\r\n\r\n\t\tlet red = options.red;\r\n\t\tif (!defined(red)) {\r\n\t\t\tconst minimumRed = defaultValue(options.minimumRed, 0);\r\n\t\t\tconst maximumRed = defaultValue(options.maximumRed, 1.0);\r\n\r\n\t\t\tred = minimumRed + GMath.nextRandomNumber() * (maximumRed - minimumRed);\r\n\t\t}\r\n\r\n\t\tlet green = options.green;\r\n\t\tif (!defined(green)) {\r\n\t\t\tconst minimumGreen = defaultValue(options.minimumGreen, 0);\r\n\t\t\tconst maximumGreen = defaultValue(options.maximumGreen, 1.0);\r\n\r\n\t\t\tgreen = minimumGreen + GMath.nextRandomNumber() * (maximumGreen - minimumGreen);\r\n\t\t}\r\n\r\n\t\tlet blue = options.blue;\r\n\t\tif (!defined(blue)) {\r\n\t\t\tconst minimumBlue = defaultValue(options.minimumBlue, 0);\r\n\t\t\tconst maximumBlue = defaultValue(options.maximumBlue, 1.0);\r\n\r\n\t\t\tblue = minimumBlue + GMath.nextRandomNumber() * (maximumBlue - minimumBlue);\r\n\t\t}\r\n\t\tif (!defined(result)) {\r\n\t\t\treturn new Color(red, green, blue);\r\n\t\t}\r\n\r\n\t\tresult.red = red;\r\n\t\tresult.green = green;\r\n\t\tresult.blue = blue;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic fromCssColorString(color: string, result: Color = new Color()): Color {\r\n\t\t// Remove all whitespaces from the color string\r\n\t\tcolor = color.replace(/\\s/g, \"\");\r\n\r\n\t\tconst namedColor = Color[color.toUpperCase()];\r\n\t\tif (defined(namedColor)) {\r\n\t\t\tColor.clone(namedColor, result);\r\n\t\t\treturn result;\r\n\t\t}\r\n\r\n\t\tlet matches = rgbaMatcher.exec(color);\r\n\t\tif (matches !== null) {\r\n\t\t\tresult.red = parseInt(matches[1], 16) / 15;\r\n\t\t\tresult.green = parseInt(matches[2], 16) / 15.0;\r\n\t\t\tresult.blue = parseInt(matches[3], 16) / 15.0;\r\n\t\t\treturn result;\r\n\t\t}\r\n\r\n\t\tmatches = rrggbbaaMatcher.exec(color);\r\n\t\tif (matches !== null) {\r\n\t\t\tresult.red = parseInt(matches[1], 16) / 255.0;\r\n\t\t\tresult.green = parseInt(matches[2], 16) / 255.0;\r\n\t\t\tresult.blue = parseInt(matches[3], 16) / 255.0;\r\n\t\t\treturn result;\r\n\t\t}\r\n\r\n\t\tmatches = rgbParenthesesMatcher.exec(color);\r\n\t\tif (matches !== null) {\r\n\t\t\tresult.red = parseFloat(matches[1]) / (\"%\" === matches[1].substr(-1) ? 100.0 : 255.0);\r\n\t\t\tresult.green = parseFloat(matches[2]) / (\"%\" === matches[2].substr(-1) ? 100.0 : 255.0);\r\n\t\t\tresult.blue = parseFloat(matches[3]) / (\"%\" === matches[3].substr(-1) ? 100.0 : 255.0);\r\n\t\t\treturn result;\r\n\t\t}\r\n\r\n\t\tmatches = hslParenthesesMatcher.exec(color);\r\n\t\tif (matches !== null) {\r\n\t\t\treturn Color.fromHsl(\r\n\t\t\t\tparseFloat(matches[1]) / 360.0,\r\n\t\t\t\tparseFloat(matches[2]) / 100.0,\r\n\t\t\t\tparseFloat(matches[3]) / 100.0,\r\n\t\t\t\tresult\r\n\t\t\t);\r\n\t\t}\r\n\r\n\t\tresult = undefined;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic byteToFloat(value: number): number {\r\n\t\treturn value / 255.0;\r\n\t}\r\n\r\n\tstatic floatToByte(value: number): number {\r\n\t\treturn value === 1.0 ? 255.0 : (value * 256.0) | 0;\r\n\t}\r\n\r\n\tstatic clone(color: Color, result: Color): Color {\r\n\t\tif (!defined(color)) {\r\n\t\t\treturn undefined;\r\n\t\t}\r\n\t\tif (!defined(result)) {\r\n\t\t\treturn new Color(color.red, color.green, color.blue);\r\n\t\t}\r\n\t\tresult.red = color.red;\r\n\t\tresult.green = color.green;\r\n\t\tresult.blue = color.blue;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic equals(left: Color, right: Color): boolean {\r\n\t\treturn (\r\n\t\t\tleft === right || //\r\n\t\t\t(defined(left) && //\r\n\t\t\t\tdefined(right) && //\r\n\t\t\t\tleft.red === right.red && //\r\n\t\t\t\tleft.green === right.green && //\r\n\t\t\t\tleft.blue === right.blue)\r\n\t\t);\r\n\t}\r\n\r\n\t/**\r\n\t * @private\r\n\t */\r\n\tstatic equalsArray(color: Color, array: number[], offset: number): boolean {\r\n\t\treturn color.red === array[offset] && color.green === array[offset + 1] && color.blue === array[offset + 2];\r\n\t}\r\n}\r\nexport default Color;\r\n","import defaultValue from \"../utils/defaultValue\";\r\nimport defined from \"../utils/defined\";\r\nimport Vector2 from \"./Vector2\";\r\n\r\n/**\r\n * A 2x2 matrix, indexable as a column-major order array.\r\n * @param {Number} [column0Row0=0.0] The value for column 0, row 0.\r\n * @param {Number} [column1Row0=0.0] The value for column 1, row 0.\r\n * @param {Number} [column0Row1=0.0] The value for column 0, row 1.\r\n * @param {Number} [column1Row1=0.0] The value for column 1, row 1.\r\n */\r\nclass Matrix2 {\r\n\tconstructor(column0Row0 = 0, column1Row0 = 0, column0Row1 = 0, column1Row1 = 0) {\r\n\t\tthis[0] = column0Row0;\r\n\t\tthis[1] = column0Row1;\r\n\t\tthis[2] = column1Row0;\r\n\t\tthis[3] = column1Row1;\r\n\t}\r\n\r\n\tstatic clone(matrix: Matrix2 | number[], result: Matrix2): Matrix2 {\r\n\t\tif (!defined(matrix)) {\r\n\t\t\treturn undefined;\r\n\t\t}\r\n\t\tif (!defined(result)) {\r\n\t\t\treturn new Matrix2(matrix[0], matrix[2], matrix[1], matrix[3]);\r\n\t\t}\r\n\t\tresult[0] = matrix[0];\r\n\t\tresult[1] = matrix[1];\r\n\t\tresult[2] = matrix[2];\r\n\t\tresult[3] = matrix[3];\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic fromColumnMajorArray(values: number[], result: Matrix2): Matrix2 {\r\n\t\treturn Matrix2.clone(values, result);\r\n\t}\r\n\r\n\tstatic fromRowMajorArray(values: number, result: Matrix2): Matrix2 {\r\n\t\tif (!defined(result)) {\r\n\t\t\treturn new Matrix2(values[0], values[1], values[2], values[3]);\r\n\t\t}\r\n\t\tresult[0] = values[0];\r\n\t\tresult[1] = values[2];\r\n\t\tresult[2] = values[1];\r\n\t\tresult[3] = values[3];\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic fromScale(scale: Vector2, result: Matrix2): Matrix2 {\r\n\t\tif (!defined(result)) {\r\n\t\t\treturn new Matrix2(scale.x, 0.0, 0.0, scale.y);\r\n\t\t}\r\n\r\n\t\tresult[0] = scale.x;\r\n\t\tresult[1] = 0.0;\r\n\t\tresult[2] = 0.0;\r\n\t\tresult[3] = scale.y;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic fromRotation(angle: number, result: Matrix2): Matrix2 {\r\n\t\tconst cosAngle = Math.cos(angle);\r\n\t\tconst sinAngle = Math.sin(angle);\r\n\r\n\t\tif (!defined(result)) {\r\n\t\t\treturn new Matrix2(cosAngle, -sinAngle, sinAngle, cosAngle);\r\n\t\t}\r\n\t\tresult[0] = cosAngle;\r\n\t\tresult[1] = sinAngle;\r\n\t\tresult[2] = -sinAngle;\r\n\t\tresult[3] = cosAngle;\r\n\t\treturn result;\r\n\t}\r\n\ttoArray() {\r\n\t\tconst result = [];\r\n\t\tMatrix2.toArray(this, result);\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic toArray(matrix: Matrix2, result: number[]): number[] {\r\n\t\tif (!defined(result)) {\r\n\t\t\treturn [matrix[0], matrix[1], matrix[2], matrix[3]];\r\n\t\t}\r\n\t\tresult[0] = matrix[0];\r\n\t\tresult[1] = matrix[1];\r\n\t\tresult[2] = matrix[2];\r\n\t\tresult[3] = matrix[3];\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic getElementIndex(column: number, row: number): number {\r\n\t\treturn column * 2 + row;\r\n\t}\r\n\r\n\tstatic getColumn(matrix: Matrix2, index: number, result: Vector2): Vector2 {\r\n\t\tconst startIndex = index * 2;\r\n\t\tconst x = matrix[startIndex];\r\n\t\tconst y = matrix[startIndex + 1];\r\n\r\n\t\tresult.x = x;\r\n\t\tresult.y = y;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic setColumn(matrix: Matrix2, index: number, cartesian: Vector2, result: Matrix2): Matrix2 {\r\n\t\tresult = Matrix2.clone(matrix, result);\r\n\t\tconst startIndex = index * 2;\r\n\t\tresult[startIndex] = cartesian.x;\r\n\t\tresult[startIndex + 1] = cartesian.y;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic getRow(matrix: Matrix2, index: number, result: Vector2): Vector2 {\r\n\t\tconst x = matrix[index];\r\n\t\tconst y = matrix[index + 2];\r\n\r\n\t\tresult.x = x;\r\n\t\tresult.y = y;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic setRow(matrix: Matrix2, index: number, cartesian: Vector2, result: Matrix2): Matrix2 {\r\n\t\tresult = Matrix2.clone(matrix, result);\r\n\t\tresult[index] = cartesian.x;\r\n\t\tresult[index + 2] = cartesian.y;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic setScale(matrix: Matrix2, scale: Vector2, result: Matrix2): Matrix2 {\r\n\t\tconst existingScale = Matrix2.getScale(matrix, scaleScratch1);\r\n\t\tconst scaleRatioX = scale.x / existingScale.x;\r\n\t\tconst scaleRatioY = scale.y / existingScale.y;\r\n\r\n\t\tresult[0] = matrix[0] * scaleRatioX;\r\n\t\tresult[1] = matrix[1] * scaleRatioX;\r\n\t\tresult[2] = matrix[2] * scaleRatioY;\r\n\t\tresult[3] = matrix[3] * scaleRatioY;\r\n\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic getScale(matrix: Matrix2, result: Vector2): Vector2 {\r\n\t\tresult.x = Vector2.magnitude(Vector2.fromElements(matrix[0], matrix[1], scratchColumn));\r\n\t\tresult.y = Vector2.magnitude(Vector2.fromElements(matrix[2], matrix[3], scratchColumn));\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic getMaximumScale(matrix: Matrix2): number {\r\n\t\tMatrix2.getScale(matrix, scaleScratch3);\r\n\t\treturn Vector2.maximumComponent(scaleScratch3);\r\n\t}\r\n\r\n\tstatic setRotation(matrix: Matrix2, rotation: Matrix2, result: Matrix2): Matrix2 {\r\n\t\tconst scale = Matrix2.getScale(matrix, scaleScratch4);\r\n\r\n\t\tresult[0] = rotation[0] * scale.x;\r\n\t\tresult[1] = rotation[1] * scale.x;\r\n\t\tresult[2] = rotation[2] * scale.y;\r\n\t\tresult[3] = rotation[3] * scale.y;\r\n\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic getRotation(matrix: Matrix2, result: Matrix2): Matrix2 {\r\n\t\tconst scale = Matrix2.getScale(matrix, scaleScratch5);\r\n\r\n\t\tresult[0] = matrix[0] / scale.x;\r\n\t\tresult[1] = matrix[1] / scale.x;\r\n\t\tresult[2] = matrix[2] / scale.y;\r\n\t\tresult[3] = matrix[3] / scale.y;\r\n\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic multiply(left: Matrix2, right: Matrix2, result: Matrix2): Matrix2 {\r\n\t\tconst column0Row0 = left[0] * right[0] + left[2] * right[1];\r\n\t\tconst column1Row0 = left[0] * right[2] + left[2] * right[3];\r\n\t\tconst column0Row1 = left[1] * right[0] + left[3] * right[1];\r\n\t\tconst column1Row1 = left[1] * right[2] + left[3] * right[3];\r\n\r\n\t\tresult[0] = column0Row0;\r\n\t\tresult[1] = column0Row1;\r\n\t\tresult[2] = column1Row0;\r\n\t\tresult[3] = column1Row1;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic add(left: Matrix2, right: Matrix2, result: Matrix2) {\r\n\t\tresult[0] = left[0] + right[0];\r\n\t\tresult[1] = left[1] + right[1];\r\n\t\tresult[2] = left[2] + right[2];\r\n\t\tresult[3] = left[3] + right[3];\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic subtract(left: Matrix2, right: Matrix2, result: Matrix2): Matrix2 {\r\n\t\tresult[0] = left[0] - right[0];\r\n\t\tresult[1] = left[1] - right[1];\r\n\t\tresult[2] = left[2] - right[2];\r\n\t\tresult[3] = left[3] - right[3];\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic multiplyByVector(matrix: Matrix2, cartesian: Vector2, result: Vector2): Vector2 {\r\n\t\tconst x = matrix[0] * cartesian.x + matrix[2] * cartesian.y;\r\n\t\tconst y = matrix[1] * cartesian.x + matrix[3] * cartesian.y;\r\n\r\n\t\tresult.x = x;\r\n\t\tresult.y = y;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic multiplyByScalar(matrix: Matrix2, scalar: number, result: Matrix2): Matrix2 {\r\n\t\tresult[0] = matrix[0] * scalar;\r\n\t\tresult[1] = matrix[1] * scalar;\r\n\t\tresult[2] = matrix[2] * scalar;\r\n\t\tresult[3] = matrix[3] * scalar;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic multiplyByScale(matrix: Matrix2, scale: Vector2, result: Matrix2): Matrix2 {\r\n\t\tresult[0] = matrix[0] * scale.x;\r\n\t\tresult[1] = matrix[1] * scale.x;\r\n\t\tresult[2] = matrix[2] * scale.y;\r\n\t\tresult[3] = matrix[3] * scale.y;\r\n\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic negate(matrix: Matrix2, result: Matrix2): Matrix2 {\r\n\t\tresult[0] = -matrix[0];\r\n\t\tresult[1] = -matrix[1];\r\n\t\tresult[2] = -matrix[2];\r\n\t\tresult[3] = -matrix[3];\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic transpose(matrix: Matrix2, result: Matrix2): Matrix2 {\r\n\t\tconst column0Row0 = matrix[0];\r\n\t\tconst column0Row1 = matrix[2];\r\n\t\tconst column1Row0 = matrix[1];\r\n\t\tconst column1Row1 = matrix[3];\r\n\r\n\t\tresult[0] = column0Row0;\r\n\t\tresult[1] = column0Row1;\r\n\t\tresult[2] = column1Row0;\r\n\t\tresult[3] = column1Row1;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic abs(matrix: Matrix2, result: Matrix2): Matrix2 {\r\n\t\tresult[0] = Math.abs(matrix[0]);\r\n\t\tresult[1] = Math.abs(matrix[1]);\r\n\t\tresult[2] = Math.abs(matrix[2]);\r\n\t\tresult[3] = Math.abs(matrix[3]);\r\n\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic equals(left: Matrix2, right: Matrix2): boolean {\r\n\t\treturn (\r\n\t\t\tleft === right ||\r\n\t\t\t(defined(left) &&\r\n\t\t\t\tdefined(right) &&\r\n\t\t\t\tleft[0] === right[0] &&\r\n\t\t\t\tleft[1] === right[1] &&\r\n\t\t\t\tleft[2] === right[2] &&\r\n\t\t\t\tleft[3] === right[3])\r\n\t\t);\r\n\t}\r\n\r\n\t/**\r\n\t * @private\r\n\t */\r\n\tstatic equalsArray(matrix: Matrix2, array: number[], offset: number): boolean {\r\n\t\treturn (\r\n\t\t\tmatrix[0] === array[offset] &&\r\n\t\t\tmatrix[1] === array[offset + 1] &&\r\n\t\t\tmatrix[2] === array[offset + 2] &&\r\n\t\t\tmatrix[3] === array[offset + 3]\r\n\t\t);\r\n\t}\r\n\r\n\tstatic equalsEpsilon(left: Matrix2, right: Matrix2, epsilon = 0): boolean {\r\n\t\tepsilon = defaultValue(epsilon, 0);\r\n\t\treturn (\r\n\t\t\tleft === right ||\r\n\t\t\t(defined(left) &&\r\n\t\t\t\tdefined(right) &&\r\n\t\t\t\tMath.abs(left[0] - right[0]) <= epsilon &&\r\n\t\t\t\tMath.abs(left[1] - right[1]) <= epsilon &&\r\n\t\t\t\tMath.abs(left[2] - right[2]) <= epsilon &&\r\n\t\t\t\tMath.abs(left[3] - right[3]) <= epsilon)\r\n\t\t);\r\n\t}\r\n\r\n\tpublic static IDENTITY = Object.freeze(new Matrix2(1.0, 0.0, 0.0, 1.0));\r\n\r\n\tpublic static ZERO = Object.freeze(new Matrix2(0.0, 0.0, 0.0, 0.0));\r\n\r\n\tclone(result: Matrix2): Matrix2 {\r\n\t\treturn Matrix2.clone(this, result);\r\n\t}\r\n\r\n\tequals(right: Matrix2): boolean {\r\n\t\treturn Matrix2.equals(this, right);\r\n\t}\r\n\r\n\tequalsEpsilon(right: Matrix2, epsilon = 0): boolean {\r\n\t\treturn Matrix2.equalsEpsilon(this, right, epsilon);\r\n\t}\r\n\r\n\ttoString() {\r\n\t\treturn `(${this[0]}, ${this[2]})\\n` + `(${this[1]}, ${this[3]})`;\r\n\t}\r\n}\r\nconst scaleScratch1 = new Vector2();\r\nconst scaleScratch2 = new Vector2();\r\nconst scaleScratch3 = new Vector2();\r\nconst scaleScratch4 = new Vector2();\r\nconst scratchColumn = new Vector2();\r\nconst scaleScratch5 = new Vector2();\r\nexport default Matrix2;\r\n","import { ShaderStage } from \"../core/WebGPUConstant\";\r\nimport { DirectionalLight } from \"../light/DirectionalLight\";\r\nimport { PointLight } from \"../light/PointLight\";\r\nimport { SpotLight } from \"../light/SpotLight\";\r\nimport Color from \"../math/Color\";\r\nimport Matrix2 from \"../math/Matrix2\";\r\nimport Matrix3 from \"../math/Matrix3\";\r\nimport Matrix4 from \"../math/Matrix4\";\r\nimport Vector2 from \"../math/Vector2\";\r\nimport Vector3 from \"../math/Vector3\";\r\nimport Vector4 from \"../math/Vector4\";\r\nimport defaultValue from \"../utils/defaultValue\";\r\nimport Context from \"./Context\";\r\nimport Sampler from \"./Sampler\";\r\nimport Texture from \"./Texture\";\r\nimport UniformBuffer from \"./UniformBuffer\";\r\nexport class Uniform<T> {\r\n\t_value: T;\r\n\tname: string;\r\n\tvalue: T;\r\n\toffset: number;\r\n\tbuffer: Float32Array | Uint16Array | Uint32Array | Uint8Array | Float64Array | UniformBuffer;\r\n\tcb: Function | number | Object;\r\n\tbyteSize: number;\r\n\tvisibility?: number;\r\n\ttype?: string;\r\n\tdirty?: boolean;\r\n\r\n\tconstructor(uniformName: string, cb?: Function | number | Object, offset?: number) {\r\n\t\tthis.name = uniformName;\r\n\t\tthis.cb = cb;\r\n\t\tthis.offset = defaultValue(offset, 0);\r\n\t\tthis.visibility = ShaderStage.Vertex | ShaderStage.Fragment;\r\n\t\tthis.type = \"number\";\r\n\t}\r\n\tsetBuffer(array: Array<number>, offset = 0) {\r\n\t\tfor (let i = 0; i < array.length; i++) {\r\n\t\t\tthis.buffer[i + offset] = array[i];\r\n\t\t}\r\n\t}\r\n\tset() {\r\n\t\treturn undefined;\r\n\t}\r\n\tgetValue() {\r\n\t\tlet result;\r\n\t\tconst cbType = typeof this.cb;\r\n\t\tswitch (cbType) {\r\n\t\t\tcase \"object\":\r\n\t\t\t\tresult = this.cb[this.name] || this.cb;\r\n\t\t\t\tbreak;\r\n\t\t\tcase \"function\":\r\n\t\t\t\t// @ts-ignore\r\n\t\t\t\tresult = this.cb();\r\n\t\t\t\tbreak;\r\n\t\t\tcase \"number\":\r\n\t\t\t\tresult = this.cb;\r\n\t\t\t\tbreak;\r\n\t\t\tdefault:\r\n\t\t\t\tthrow new Error(\"type is error\");\r\n\t\t\t\tbreak;\r\n\t\t}\r\n\t\treturn result;\r\n\t}\r\n}\r\n\r\nexport class UniformUint extends Uniform<number> {\r\n\tstatic align = 4;\r\n\tconstructor(\r\n\t\tuniformName: string,\r\n\t\tbuffer: Float32Array,\r\n\t\tbyteOffset: number,\r\n\t\tcb: Function | number | Object,\r\n\t\toffset?: number\r\n\t) {\r\n\t\tsuper(uniformName, cb, offset);\r\n\t\tthis.value = undefined;\r\n\t\tthis._value = 0;\r\n\t\tthis.byteSize = 4;\r\n\t\tthis.buffer = new Uint32Array(buffer.buffer, byteOffset, 1);\r\n\t\tthis.type = \"uint\";\r\n\t}\r\n\tset() {\r\n\t\tif (this.cb != undefined) this.value = this.getValue();\r\n\t\tif (this.value !== this._value) {\r\n\t\t\tthis._value = this.value;\r\n\t\t\tthis.buffer[0] = this.value;\r\n\t\t\treturn true;\r\n\t\t}\r\n\t\treturn false;\r\n\t}\r\n}\r\n\r\nexport class UniformFloat extends Uniform<number> {\r\n\tstatic align = 4;\r\n\tconstructor(\r\n\t\tuniformName: string,\r\n\t\tbuffer: Float32Array,\r\n\t\tbyteOffset: number,\r\n\t\tcb: Function | number | Object,\r\n\t\toffset?: number\r\n\t) {\r\n\t\tsuper(uniformName, cb, offset);\r\n\t\tthis.value = undefined;\r\n\t\tthis._value = 0;\r\n\t\tthis.byteSize = 4;\r\n\t\tthis.buffer = new Float32Array(buffer.buffer, byteOffset, 1);\r\n\t\tthis.type = \"vec1\";\r\n\t}\r\n\tset() {\r\n\t\tif (this.cb != undefined) this.value = this.getValue();\r\n\t\tif (this.value !== this._value) {\r\n\t\t\tthis._value = this.value;\r\n\t\t\tthis.buffer[0] = this.value;\r\n\t\t\treturn true;\r\n\t\t}\r\n\t\treturn false;\r\n\t}\r\n}\r\nexport class UniformFloatVec2 extends Uniform<Vector2> {\r\n\tstatic align = 8;\r\n\tconstructor(\r\n\t\tuniformName: string,\r\n\t\tbuffer: Float32Array,\r\n\t\tbyteOffset: number,\r\n\t\tcb: Function | number | Object,\r\n\t\toffset?: number\r\n\t) {\r\n\t\tsuper(uniformName, cb, offset);\r\n\t\tthis.value = undefined;\r\n\t\tthis._value = new Vector2();\r\n\t\tthis.buffer = new Float32Array(buffer.buffer, byteOffset, 2);\r\n\t\tthis.byteSize = 8;\r\n\t\tthis.type = \"vec2\";\r\n\t}\r\n\tset(): boolean {\r\n\t\tif (this.cb != undefined) this.value = this.getValue();\r\n\t\tconst v = this.value;\r\n\t\tif (!Vector2.equals(v, this._value)) {\r\n\t\t\tVector2.clone(v, this._value);\r\n\t\t\tthis.setBuffer(this._value.toArray());\r\n\t\t\treturn true;\r\n\t\t}\r\n\t\treturn false;\r\n\t}\r\n}\r\nexport class UniformFloatVec3 extends Uniform<Vector3> {\r\n\tstatic align = 16;\r\n\tconstructor(\r\n\t\tuniformName: string,\r\n\t\tbuffer: Float32Array,\r\n\t\tbyteOffset: number,\r\n\t\tcb: Function | number | Object,\r\n\t\toffset?: number\r\n\t) {\r\n\t\tsuper(uniformName, cb, offset);\r\n\t\tthis.value = undefined;\r\n\t\tthis._value = new Vector3();\r\n\t\tthis.buffer = new Float32Array(buffer.buffer, byteOffset, 3);\r\n\t\tthis.byteSize = 12;\r\n\t\tthis.type = \"vec3\";\r\n\t}\r\n\tset(): boolean {\r\n\t\tif (this.cb != undefined) this.value = this.getValue();\r\n\t\tconst v = this.value;\r\n\t\tif (!Vector3.equals(v, this._value)) {\r\n\t\t\tVector3.clone(v, this._value);\r\n\t\t\tthis.setBuffer(this._value.toArray());\r\n\t\t\treturn true;\r\n\t\t}\r\n\t\treturn false;\r\n\t}\r\n}\r\nexport class UniformFloatVec4 extends Uniform<Vector4> {\r\n\tstatic align = 16;\r\n\tconstructor(\r\n\t\tuniformName: string,\r\n\t\tbuffer: Float32Array,\r\n\t\tbyteOffset: number,\r\n\t\tcb: Function | number | Object,\r\n\t\toffset?: number\r\n\t) {\r\n\t\tsuper(uniformName, cb, offset);\r\n\t\tthis.value = undefined;\r\n\t\tthis._value = new Vector4();\r\n\t\tthis.buffer = new Float32Array(buffer.buffer, byteOffset, 4);\r\n\t\tthis.byteSize = 16;\r\n\t\tthis.type = \"vec4\";\r\n\t}\r\n\tset(): boolean {\r\n\t\tif (this.cb != undefined) this.value = this.getValue();\r\n\t\tconst v = this.value;\r\n\t\tif (!Vector4.equals(v, this._value)) {\r\n\t\t\tVector4.clone(v, this._value);\r\n\t\t\tthis.setBuffer(this._value.toArray());\r\n\t\t\treturn true;\r\n\t\t}\r\n\t\treturn false;\r\n\t}\r\n}\r\nexport class UniformColor extends Uniform<Color> {\r\n\tstatic align = 16;\r\n\tconstructor(\r\n\t\tuniformName: string,\r\n\t\tbuffer: Float32Array,\r\n\t\tbyteOffset: number,\r\n\t\tcb: Function | number | Object,\r\n\t\toffset?: number\r\n\t) {\r\n\t\tsuper(uniformName, cb, offset);\r\n\t\tthis.value = undefined;\r\n\t\tthis._value = new Color();\r\n\t\tthis.buffer = new Float32Array(buffer.buffer, byteOffset, 3);\r\n\t\tthis.byteSize = 12;\r\n\t\tthis.type = \"vec3\";\r\n\t}\r\n\tset(): boolean {\r\n\t\tif (this.cb != undefined) this.value = this.getValue();\r\n\t\tconst v = this.value;\r\n\t\tif (!Color.equals(v, this._value)) {\r\n\t\t\tColor.clone(v, this._value);\r\n\t\t\tthis.setBuffer(this._value.toArray());\r\n\t\t\treturn true;\r\n\t\t}\r\n\t\treturn false;\r\n\t}\r\n}\r\n\r\nexport class UniformMat2 extends Uniform<Matrix2> {\r\n\tstatic align = 8;\r\n\tconstructor(\r\n\t\tuniformName: string,\r\n\t\tbuffer: Float32Array,\r\n\t\tbyteOffset: number,\r\n\t\tcb: Function | number | Object,\r\n\t\toffset?: number\r\n\t) {\r\n\t\tsuper(uniformName, cb, offset);\r\n\t\tthis.value = undefined;\r\n\t\tthis._value = new Matrix2();\r\n\t\tthis.buffer = new Float32Array(buffer.buffer, byteOffset, 4);\r\n\t\tthis.byteSize = 16;\r\n\t\tthis.type = \"mat2\";\r\n\t}\r\n\tset(): boolean {\r\n\t\tif (this.cb != undefined) this.value = this.getValue();\r\n\t\tconst v = this.value;\r\n\t\tif (!Matrix2.equals(v, this._value)) {\r\n\t\t\tMatrix2.clone(v, this._value);\r\n\t\t\tthis.setBuffer(this._value.toArray());\r\n\t\t\treturn true;\r\n\t\t}\r\n\t\treturn false;\r\n\t}\r\n}\r\nexport class UniformMat3 extends Uniform<Matrix3> {\r\n\tstatic align = 16;\r\n\tconstructor(\r\n\t\tuniformName: string,\r\n\t\tbuffer: Float32Array,\r\n\t\tbyteOffset: number,\r\n\t\tcb: Function | number | Object,\r\n\t\toffset?: number\r\n\t) {\r\n\t\tsuper(uniformName, cb, offset);\r\n\t\tthis.value = undefined;\r\n\t\tthis._value = new Matrix3();\r\n\t\tthis.buffer = new Float32Array(buffer.buffer, byteOffset, 9);\r\n\t\tthis.byteSize = 48;\r\n\t\tthis.type = \"mat3\";\r\n\t}\r\n\tset(): boolean {\r\n\t\tif (this.cb != undefined) this.value = this.getValue();\r\n\t\tconst v = this.value;\r\n\t\tif (!Matrix3.equals(v, this._value)) {\r\n\t\t\tMatrix3.clone(v, this._value);\r\n\t\t\tthis.setBuffer(this._value.toArray());\r\n\t\t\treturn true;\r\n\t\t}\r\n\t\treturn false;\r\n\t}\r\n}\r\nexport class UniformMat4 extends Uniform<Matrix4> {\r\n\tstatic align = 16;\r\n\tconstructor(\r\n\t\tuniformName: string,\r\n\t\tbuffer: Float32Array,\r\n\t\tbyteOffset: number,\r\n\t\tcb: Function | number | Object,\r\n\t\toffset?: number\r\n\t) {\r\n\t\tsuper(uniformName, cb, offset);\r\n\t\tthis.value = undefined;\r\n\t\tthis._value = new Matrix4();\r\n\t\tthis.buffer = new Float32Array(buffer.buffer, byteOffset, 16);\r\n\t\tthis.byteSize = 64;\r\n\t\tthis.type = \"mat4\";\r\n\t}\r\n\tset(): boolean {\r\n\t\tif (this.cb != undefined) this.value = this.getValue();\r\n\t\tconst v = this.value;\r\n\t\tif (!Matrix4.equals(v, this._value)) {\r\n\t\t\tMatrix4.clone(v, this._value);\r\n\t\t\tthis.setBuffer(this._value.toArray());\r\n\t\t\treturn true;\r\n\t\t}\r\n\t\treturn false;\r\n\t}\r\n}\r\nexport class UniformMatrix4Array extends Uniform<Array<Matrix4>> {\r\n\tstatic align = 16;\r\n\tconstructor(\r\n\t\tuniformName: string,\r\n\t\tbuffer: Float32Array,\r\n\t\tbyteOffset: number,\r\n\t\tcb: Function | number | Object,\r\n\t\toffset?: number,\r\n\t\tcount?: number,\r\n\t\tsize = 64\r\n\t) {\r\n\t\tsuper(uniformName, cb, offset);\r\n\t\tthis.visibility = ShaderStage.Vertex | ShaderStage.Fragment;\r\n\t\tthis.byteSize = count * size;\r\n\t\tthis.buffer = new Float32Array(buffer.buffer, byteOffset, this.byteSize / 4);\r\n\t\tthis.type = \"mat4-array\";\r\n\t}\r\n\tset(): boolean {\r\n\t\tthis.value = this.getValue();\r\n\t\tif (!this.value) return false;\r\n\t\tfor (let i = 0; i < this.value.length; i++) {\r\n\t\t\tthis.setBuffer(this.value[i].toArray(), i * 16);\r\n\t\t}\r\n\t\treturn true;\r\n\t}\r\n}\r\nexport class UniformFloatArray extends Uniform<Array<number>> {\r\n\tstatic align = 4;\r\n\t// cb: Function;\r\n\tconstructor(\r\n\t\tuniformName: string,\r\n\t\tbuffer: Float32Array,\r\n\t\tbyteOffset: number,\r\n\t\tcb: Function | number | Object,\r\n\t\toffset?: number,\r\n\t\tcount?: number\r\n\t) {\r\n\t\tsuper(uniformName, cb, offset);\r\n\t\tthis.visibility = ShaderStage.Vertex | ShaderStage.Fragment;\r\n\t\tthis.buffer = new Float32Array(buffer.buffer, byteOffset, count);\r\n\t\tthis.byteSize = 4 * count;\r\n\t\tthis.type = \"float-array\";\r\n\t}\r\n\tset(): boolean {\r\n\t\tthis.value = this.getValue();\r\n\t\tfor (let i = 0; i < this.value.length; i++) {\r\n\t\t\tthis.buffer[i] = this.value[i];\r\n\t\t}\r\n\t\treturn true;\r\n\t}\r\n}\r\nexport class UniformVec2Array extends Uniform<Array<Vector2>> {\r\n\tstatic align = 8;\r\n\tconstructor(\r\n\t\tuniformName: string,\r\n\t\tbuffer: Float32Array,\r\n\t\tbyteOffset: number,\r\n\t\tcb: Function | number | Object,\r\n\t\toffset?: number,\r\n\t\tcount?: number\r\n\t) {\r\n\t\tsuper(uniformName, cb, offset);\r\n\t\tthis.visibility = ShaderStage.Vertex | ShaderStage.Fragment;\r\n\t\tthis.byteSize = count * 8;\r\n\t\tthis.buffer = new Float32Array(buffer.buffer, byteOffset, this.byteSize / 4);\r\n\t\tthis.type = \"vec2-array\";\r\n\t}\r\n\tset(): boolean {\r\n\t\t// this.value = this.cb();\r\n\t\tthis.value = this.getValue();\r\n\t\tlet j = 0;\r\n\t\tfor (let i = 0; i < this.value.length; i++) {\r\n\t\t\tthis.buffer[j] = this.value[i].x;\r\n\t\t\tthis.buffer[j + 1] = this.value[i].y;\r\n\t\t\tj += 2;\r\n\t\t}\r\n\t\treturn true;\r\n\t}\r\n}\r\nexport class UniformVec3Array extends Uniform<Array<Vector3>> {\r\n\tstatic align = 16;\r\n\t// cb: Function;\r\n\tconstructor(\r\n\t\tuniformName: string,\r\n\t\tbuffer: Float32Array,\r\n\t\tbyteOffset: number,\r\n\t\tcb: Function | number | Object,\r\n\t\toffset?: number,\r\n\t\tcount?: number\r\n\t) {\r\n\t\tsuper(uniformName, cb, offset);\r\n\t\tthis.visibility = ShaderStage.Vertex | ShaderStage.Fragment;\r\n\t\tthis.byteSize = count * 16;\r\n\t\tthis.buffer = new Float32Array(buffer.buffer, byteOffset, this.byteSize / 4);\r\n\t\tthis.type = \"vec3-array\";\r\n\t}\r\n\tset(): boolean {\r\n\t\t// this.value = this.cb();\r\n\t\tthis.value = this.getValue();\r\n\t\tlet j = 0;\r\n\t\tfor (let i = 0; i < this.value.length; i++) {\r\n\t\t\tthis.buffer[j] = this.value[i].x;\r\n\t\t\tthis.buffer[j + 1] = this.value[i].y;\r\n\t\t\tthis.buffer[j + 2] = this.value[i].z;\r\n\t\t\tthis.buffer[j + 3] = 0;\r\n\t\t\tj += 4;\r\n\t\t}\r\n\t\treturn true;\r\n\t}\r\n}\r\nexport class UniformVec4Array extends Uniform<Array<Vector4>> {\r\n\tstatic align = 16;\r\n\t// cb: Function;\r\n\tconstructor(\r\n\t\tuniformName: string,\r\n\t\tbuffer: Float32Array,\r\n\t\tbyteOffset: number,\r\n\t\tcb: Function | number | Object,\r\n\t\toffset?: number,\r\n\t\tcount?: number\r\n\t) {\r\n\t\tsuper(uniformName, cb, offset);\r\n\t\tthis.visibility = ShaderStage.Vertex | ShaderStage.Fragment;\r\n\t\tthis.byteSize = count * 16;\r\n\t\tthis.buffer = new Float32Array(buffer.buffer, byteOffset, this.byteSize / 4);\r\n\t\tthis.type = \"vec4-array\";\r\n\t}\r\n\tset(): boolean {\r\n\t\tthis.value = this.getValue();\r\n\t\tlet j = 0;\r\n\t\tfor (let i = 0; i < this.value.length; i++) {\r\n\t\t\tthis.buffer[j] = this.value[i].x;\r\n\t\t\tthis.buffer[j + 1] = this.value[i].y;\r\n\t\t\tthis.buffer[j + 2] = this.value[i].z;\r\n\t\t\tthis.buffer[j + 3] = this.value[i].w;\r\n\t\t\tj += 4;\r\n\t\t}\r\n\t\treturn true;\r\n\t}\r\n}\r\nexport class UniformTexture extends Uniform<Texture> {\r\n\tpublic binding: number;\r\n\tpublic type: string;\r\n\tpublic visibility: ShaderStage;\r\n\tpublic name: string;\r\n\tpublic texture: Texture;\r\n\tpublic isTexture: boolean;\r\n\tprivate _texture: Function | Texture;\r\n\tconstructor(uniformName: string, binding: number, texture: Function | Texture) {\r\n\t\tsuper(uniformName);\r\n\t\tthis.binding = binding;\r\n\t\tthis.type = \"texture\";\r\n\t\tthis.isTexture = true;\r\n\t\tthis.visibility = ShaderStage.Fragment;\r\n\t\tthis._texture = texture;\r\n\t}\r\n\tget layoutType() {\r\n\t\treturn this.texture?.layoutType || \"not yet bind\";\r\n\t}\r\n\tbind(context: Context) {\r\n\t\tthis.texture = this._texture instanceof Function ? this._texture() : this._texture;\r\n\t\tthis.texture.update(context);\r\n\t}\r\n}\r\nexport class UniformSampler extends Uniform<Sampler> {\r\n\tpublic binding: number;\r\n\tpublic type: string;\r\n\tpublic visibility: ShaderStage;\r\n\tpublic name: string;\r\n\tpublic sampler: Sampler;\r\n\tpublic isSampler: boolean;\r\n\tprivate _sampler: Function | Sampler;\r\n\tconstructor(uniformName: string, binding: number, sampler: Function | Sampler) {\r\n\t\tsuper(uniformName);\r\n\t\tthis.name = uniformName;\r\n\t\tthis.binding = binding;\r\n\t\tthis.type = \"sampler\";\r\n\t\tthis.isSampler = true;\r\n\t\tthis.visibility = ShaderStage.Fragment;\r\n\t\tthis._sampler = sampler;\r\n\t}\r\n\tget layoutType() {\r\n\t\treturn this.sampler?.layoutType || \"not yet bind\";\r\n\t}\r\n\tbind(context: Context) {\r\n\t\tthis.sampler = this._sampler instanceof Function ? this._sampler() : this._sampler;\r\n\t\tthis.sampler.update(context);\r\n\t}\r\n}\r\nexport class UniformSpotLights extends Uniform<SpotLight> {\r\n\tstatic align = 16;\r\n\tlights: Array<SpotLight>;\r\n\t// cb: Function;\r\n\tconstructor(\r\n\t\tuniformName: string,\r\n\t\tbuffer: Float32Array,\r\n\t\tbyteOffset: number,\r\n\t\tcb: Function | number | Object,\r\n\t\toffset?: number,\r\n\t\tcount?: number\r\n\t) {\r\n\t\tsuper(uniformName, cb, offset);\r\n\t\tthis.cb = cb;\r\n\t\tthis.byteSize = count * 64;\r\n\t\tthis.buffer = new Float32Array(buffer.buffer, byteOffset, this.byteSize / 4);\r\n\t\tthis.type = \"spotsLight\";\r\n\t\tthis.visibility = ShaderStage.Fragment;\r\n\t\tthis.dirty = false;\r\n\t}\r\n\tset() {\r\n\t\tthis.lights = this.getValue();\r\n\t\tthis.lights.forEach((spotLight, index) => {\r\n\t\t\tthis.setSubData(spotLight, index);\r\n\t\t});\r\n\t\treturn this.dirty;\r\n\t}\r\n\tprivate setSubData(spotLight: SpotLight, index: number) {\r\n\t\tconst offset = index * 16;\r\n\t\tif (spotLight.positionDirty) {\r\n\t\t\tthis.dirty = setDataToTypeArray(this.buffer, spotLight.position.toArray(), offset + 0); // byteOffset=0;\r\n\t\t}\r\n\t\tif (spotLight.distanceDirty) {\r\n\t\t\tthis.dirty = setDataToTypeArray(this.buffer, spotLight.distance, offset + 3); // byteOffset=12;\r\n\t\t}\r\n\t\tif (spotLight.dirtectDirty) {\r\n\t\t\tthis.dirty = setDataToTypeArray(this.buffer, spotLight.directional.toArray(), offset + 4); // byteOffset=16;\r\n\t\t}\r\n\t\tif (spotLight.coneCosDirty) {\r\n\t\t\tthis.dirty = setDataToTypeArray(this.buffer, spotLight.coneCos, offset + 7); // byteOffset=28;\r\n\t\t}\r\n\t\tif (spotLight.colorDirty) {\r\n\t\t\tthis.dirty = setDataToTypeArray(this.buffer, spotLight.color.toArray(), offset + 8); // byteOffset=32;\r\n\t\t}\r\n\t\tif (spotLight.penumbraCosDirty) {\r\n\t\t\tthis.dirty = setDataToTypeArray(this.buffer, spotLight.penumbraCos, offset + 11); // byteOffset=44;\r\n\t\t}\r\n\t\tif (spotLight.decayDirty) {\r\n\t\t\tthis.dirty = setDataToTypeArray(this.buffer, spotLight.decay, offset + 12); // byteOffset=48;\r\n\t\t}\r\n\r\n\t\tspotLight.positionDirty = false;\r\n\t\tspotLight.distanceDirty = false;\r\n\t\tspotLight.dirtectDirty = false;\r\n\t\tspotLight.coneCosDirty = false;\r\n\t\tspotLight.colorDirty = false;\r\n\t\tspotLight.penumbraCosDirty = false;\r\n\t\tspotLight.decayDirty = false;\r\n\t}\r\n}\r\n\r\nexport class UniformSpotLightShadows extends Uniform<SpotLight> {\r\n\tstatic align = 16;\r\n\tstatic uniformSize = 18;\r\n\tlights: Array<SpotLight>;\r\n\t// cb: Function;\r\n\tprivate _nearValue: number;\r\n\tprivate _farValue: number;\r\n\tprivate _subDataSize: number;\r\n\r\n\tconstructor(\r\n\t\tuniformName: string,\r\n\t\tbuffer: Float32Array,\r\n\t\tbyteOffset: number,\r\n\t\tcb: Function | number | Object,\r\n\t\toffset?: number,\r\n\t\tcount?: number\r\n\t) {\r\n\t\tsuper(uniformName, cb, offset);\r\n\t\tconst bytesPerElement = Float32Array.BYTES_PER_ELEMENT;\r\n\t\tthis._subDataSize = UniformSpotLightShadows.uniformSize;\r\n\t\tthis.byteSize = count * this._subDataSize * bytesPerElement;\r\n\t\tthis.buffer = new Float32Array(buffer.buffer, byteOffset, this.byteSize / 4);\r\n\t\tthis.type = \"spotLightShadows\";\r\n\t\tthis.visibility = ShaderStage.Fragment;\r\n\t\tthis._nearValue = null;\r\n\t\tthis._farValue = null;\r\n\t}\r\n\tset() {\r\n\t\tthis.lights = this.getValue();\r\n\t\tthis.lights.forEach((spotLight, index) => {\r\n\t\t\tthis.setSubData(spotLight, index);\r\n\t\t});\r\n\t\treturn this.dirty;\r\n\t}\r\n\tprivate setSubData(spotLight: SpotLight, index: number) {\r\n\t\tconst offset = index * this._subDataSize;\r\n\t\tif (spotLight.shadow.vpMatrixDirty) {\r\n\t\t\tspotLight.shadow.vpMatrixDirty = false;\r\n\t\t\tthis.dirty = setDataToTypeArray(this.buffer, spotLight.shadow.camera.vpMatrix.toArray(), offset + 0); // byteOffset=0;\r\n\t\t}\r\n\t\tconst nearValue = spotLight.shadow.camera.near;\r\n\t\tif (nearValue != this._nearValue) {\r\n\t\t\tthis._nearValue = nearValue;\r\n\t\t\tthis.dirty = setDataToTypeArray(this.buffer, this._nearValue, offset + 16); // byteOffset=0;\r\n\t\t}\r\n\t\tconst farValue = spotLight.shadow.camera.far;\r\n\t\tif (farValue != this._farValue) {\r\n\t\t\tthis._farValue = farValue;\r\n\t\t\tthis.dirty = setDataToTypeArray(this.buffer, this._farValue, offset + 17); // byteOffset=0;\r\n\t\t}\r\n\t}\r\n}\r\nexport class UniformPointLights extends Uniform<PointLight> {\r\n\tstatic align = 16;\r\n\tlights: Array<PointLight>;\r\n\t// cb: Function;\r\n\tconstructor(\r\n\t\tuniformName: string,\r\n\t\tbuffer: Float32Array,\r\n\t\tbyteOffset: number,\r\n\t\tcb: Function | number | Object,\r\n\t\toffset?: number,\r\n\t\tcount?: number\r\n\t) {\r\n\t\tsuper(uniformName, cb, offset);\r\n\t\tthis.byteSize = count * 32;\r\n\t\tthis.buffer = new Float32Array(buffer.buffer, byteOffset, this.byteSize / 4);\r\n\t\tthis.type = \"pointsLight\";\r\n\t\tthis.visibility = ShaderStage.Fragment;\r\n\t}\r\n\tset() {\r\n\t\tthis.lights = this.getValue();\r\n\t\tthis.lights.forEach((pointLight, index) => {\r\n\t\t\tthis.setSubData(pointLight, index);\r\n\t\t});\r\n\t\treturn this.dirty;\r\n\t}\r\n\tprivate setSubData(pointLight: PointLight, index: number) {\r\n\t\tconst offset = index * 8;\r\n\t\tif (pointLight.positionDirty) {\r\n\t\t\tpointLight.positionDirty = false;\r\n\t\t\tthis.dirty = setDataToTypeArray(this.buffer, pointLight.position.toArray(), offset + 0); // byteOffset=0;\r\n\t\t}\r\n\t\tif (pointLight.distanceDirty) {\r\n\t\t\tpointLight.distanceDirty = false;\r\n\t\t\tthis.dirty = setDataToTypeArray(this.buffer, pointLight.distance, offset + 3); // byteOffset=12;\r\n\t\t}\r\n\t\tif (pointLight.colorDirty) {\r\n\t\t\tpointLight.colorDirty = false;\r\n\t\t\tthis.dirty = setDataToTypeArray(this.buffer, pointLight.color.toArray(), offset + 4); // byteOffset=32;\r\n\t\t}\r\n\t\tif (pointLight.decayDirty) {\r\n\t\t\tpointLight.decayDirty = false;\r\n\t\t\tthis.dirty = setDataToTypeArray(this.buffer, pointLight.decay, offset + 7); // byteOffset=12;\r\n\t\t}\r\n\t}\r\n}\r\n\r\nexport class UniformPointLightShadows extends Uniform<PointLight> {\r\n\tstatic align = 16;\r\n\tstatic uniformSize = 122;\r\n\tlights: Array<PointLight>;\r\n\t// cb: Function;\r\n\tprivate _nearValue: number;\r\n\tprivate _farValue: number;\r\n\tprivate _subDataSize: number;\r\n\r\n\tconstructor(\r\n\t\tuniformName: string,\r\n\t\tbuffer: Float32Array,\r\n\t\tbyteOffset: number,\r\n\t\tcb: Function | number | Object,\r\n\t\toffset?: number,\r\n\t\tcount?: number\r\n\t) {\r\n\t\tsuper(uniformName, cb, offset);\r\n\t\tconst bytesPerElement = Float32Array.BYTES_PER_ELEMENT;\r\n\t\tthis._subDataSize = UniformPointLightShadows.uniformSize;\r\n\t\tthis.byteSize = count * bytesPerElement * this._subDataSize;\r\n\t\tthis.buffer = new Float32Array(buffer.buffer, byteOffset, this.byteSize / 4);\r\n\t\tthis.type = \"pointLightShadows\";\r\n\t\tthis.visibility = ShaderStage.Fragment;\r\n\t\tthis._nearValue = null;\r\n\t\tthis._farValue = null;\r\n\t}\r\n\tset() {\r\n\t\tthis.lights = this.getValue();\r\n\t\tthis.lights.forEach((pointLight, index) => {\r\n\t\t\tthis.setSubData(pointLight, index);\r\n\t\t});\r\n\t\treturn this.dirty;\r\n\t}\r\n\tprivate setSubData(pointLight: PointLight, index: number) {\r\n\t\tconst offset = index * this._subDataSize;\r\n\r\n\t\tif (pointLight.shadow.vpMatrixArrayDirty) {\r\n\t\t\tpointLight.shadow.vpMatrixArrayDirty = false;\r\n\t\t\tconst vpMatrixArray = pointLight.shadow.camera.vpMatrixArray;\r\n\t\t\tfor (let i = 0; i < vpMatrixArray.length; i++) {\r\n\t\t\t\tconst vpMatrix = vpMatrixArray[i];\r\n\t\t\t\tthis.dirty = setDataToTypeArray(this.buffer, vpMatrix.toArray(), offset + 0 + 16 * i); // byteOffset=98 * 4;\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\tif (pointLight.shadow.viewPortDirty) {\r\n\t\t\tpointLight.shadow.viewPortDirty = false;\r\n\t\t\tfor (let i = 0; i < 6; i++) {\r\n\t\t\t\tthis.dirty = setDataToTypeArray(\r\n\t\t\t\t\tthis.buffer,\r\n\t\t\t\t\tpointLight.shadow.viewports[i].toArray(),\r\n\t\t\t\t\toffset + 96 + 4 * i\r\n\t\t\t\t); // byteOffset=0;\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\tconst nearValue = pointLight.shadow.camera.near;\r\n\t\tif (nearValue != this._nearValue) {\r\n\t\t\tthis._nearValue = nearValue;\r\n\t\t\tthis.dirty = setDataToTypeArray(this.buffer, this._nearValue, offset + 120); // byteOffset=0;\r\n\t\t}\r\n\t\tconst farValue = pointLight.shadow.camera.far;\r\n\t\tif (farValue != this._farValue) {\r\n\t\t\tthis._farValue = farValue;\r\n\t\t\tthis.dirty = setDataToTypeArray(this.buffer, this._farValue, offset + 121); // byteOffset=1;\r\n\t\t}\r\n\t}\r\n}\r\nexport class UniformDirtectLights extends Uniform<DirectionalLight> {\r\n\tstatic align = 16;\r\n\tlights: Array<DirectionalLight>;\r\n\tconstructor(\r\n\t\tuniformName: string,\r\n\t\tbuffer: Float32Array,\r\n\t\tbyteOffset: number,\r\n\t\tcb: Function | number | Object,\r\n\t\toffset?: number,\r\n\t\tcount?: number\r\n\t) {\r\n\t\tsuper(uniformName, cb, offset);\r\n\t\tthis.cb = cb;\r\n\t\tthis.byteSize = count * 32;\r\n\t\tthis.buffer = new Float32Array(buffer.buffer, byteOffset, this.byteSize / 4);\r\n\t\tthis.type = \"dirtectLights\";\r\n\t\tthis.visibility = ShaderStage.Fragment;\r\n\t}\r\n\tset() {\r\n\t\tthis.lights = this.getValue();\r\n\t\tthis.lights.forEach((directionalLight, index) => {\r\n\t\t\tthis.setSubData(directionalLight, index);\r\n\t\t});\r\n\t\treturn this.dirty;\r\n\t}\r\n\tprivate setSubData(directionalLight: DirectionalLight, index: number) {\r\n\t\tconst offset = index * 8;\r\n\t\tif (directionalLight.dirtectDirty) {\r\n\t\t\tdirectionalLight.dirtectDirty = false;\r\n\t\t\tthis.dirty = setDataToTypeArray(this.buffer, directionalLight.directional.toArray(), offset + 0); // byteOffset=16;\r\n\t\t}\r\n\t\tif (directionalLight.colorDirty) {\r\n\t\t\tdirectionalLight.colorDirty = false;\r\n\t\t\tthis.dirty = setDataToTypeArray(this.buffer, directionalLight.color.toArray(), offset + 4); // byteOffset=32;\r\n\t\t}\r\n\t}\r\n}\r\n\r\nexport class UniformDirtectLightShadows extends Uniform<DirectionalLight> {\r\n\tstatic align = 16;\r\n\tstatic uniformSize = 16;\r\n\tlights: Array<DirectionalLight>;\r\n\tprivate _subDataSize: number;\r\n\r\n\tconstructor(\r\n\t\tuniformName: string,\r\n\t\tbuffer: Float32Array,\r\n\t\tbyteOffset: number,\r\n\t\tcb: Function | number | Object,\r\n\t\toffset?: number,\r\n\t\tcount?: number\r\n\t) {\r\n\t\tsuper(uniformName, cb, offset);\r\n\t\tconst bytesPerElement = Float32Array.BYTES_PER_ELEMENT;\r\n\t\tthis._subDataSize = UniformDirtectLightShadows.uniformSize;\r\n\t\tthis.byteSize = count * bytesPerElement * this._subDataSize;\r\n\t\tthis.buffer = new Float32Array(buffer.buffer, byteOffset, this.byteSize / 4);\r\n\t\tthis.type = \"dirtectLightShadows\";\r\n\t\tthis.visibility = ShaderStage.Fragment;\r\n\t}\r\n\tset() {\r\n\t\tthis.lights = this.getValue();\r\n\t\tthis.lights.forEach((directionalLight, index) => {\r\n\t\t\tthis.setSubData(directionalLight, index);\r\n\t\t});\r\n\t\treturn this.dirty;\r\n\t}\r\n\tprivate setSubData(directionalLight: DirectionalLight, index: number) {\r\n\t\tconst offset = index * this._subDataSize;\r\n\t\tif (directionalLight.shadow.vpMatrixDirty) {\r\n\t\t\tdirectionalLight.shadow.vpMatrixDirty = false;\r\n\t\t\tthis.dirty = setDataToTypeArray(this.buffer, directionalLight.shadow.camera.vpMatrix.toArray(), offset + 0); // byteOffset=16;\r\n\t\t}\r\n\t}\r\n}\r\nexport enum UniformEnum {\r\n\tFloat = 0,\r\n\tFloatVec2 = 1,\r\n\tFloatVec3 = 2,\r\n\tFloatVec4 = 3,\r\n\tFloatArray = 4,\r\n\tMat2 = 5,\r\n\tMat3 = 6,\r\n\tMat4 = 7,\r\n\tColor = 8,\r\n\tMat4Array = 9,\r\n\tPointLights = 10,\r\n\tPointLightShadows = 11,\r\n\tSpotLights = 12,\r\n\tSpotLightShadows = 13,\r\n\tDirtectLights = 14,\r\n\tDirtectLightShadows = 15,\r\n\tVec2Array = 16,\r\n\tVec3Array = 17,\r\n\tVec4Array = 18,\r\n\tUniformUint = 19\r\n}\r\nfunction setDataToTypeArray(buffer, data, offset) {\r\n\tif (Array.isArray(data)) {\r\n\t\tdata.forEach((value, index) => {\r\n\t\t\tbuffer[index + offset] = value;\r\n\t\t});\r\n\t} else {\r\n\t\tbuffer[offset] = data;\r\n\t}\r\n\treturn true;\r\n}\r\n","import { BufferUsage, ShaderStage } from \"../core/WebGPUConstant\";\r\nimport defaultValue from \"../utils/defaultValue\";\r\nimport Buffer from \"./Buffer\";\r\nimport Context from \"./Context\";\r\n\r\nimport {\r\n\tUniform,\r\n\tUniformColor,\r\n\tUniformDirtectLights,\r\n\tUniformDirtectLightShadows,\r\n\tUniformFloat,\r\n\tUniformFloatArray,\r\n\tUniformFloatVec2,\r\n\tUniformFloatVec3,\r\n\tUniformFloatVec4,\r\n\tUniformMat2,\r\n\tUniformMat3,\r\n\tUniformMat4,\r\n\tUniformMatrix4Array,\r\n\tUniformPointLights,\r\n\tUniformPointLightShadows,\r\n\tUniformSpotLights,\r\n\tUniformSpotLightShadows,\r\n\tUniformUint,\r\n\tUniformVec2Array,\r\n\tUniformVec3Array,\r\n\tUniformVec4Array,\r\n\tUniformEnum\r\n} from \"./Uniforms\";\r\nexport default class UniformBuffer {\r\n\tpublic type: string;\r\n\tpublic hasDynamicOffset: boolean;\r\n\tpublic minBindingSize: number;\r\n\tprivate _uniformStruct: Map<string, Uniform<any>>;\r\n\tprivate _bufferSize: number;\r\n\tprivate label: string;\r\n\tbyteOffset: number;\r\n\tuniformDirty: boolean;\r\n\tbinding: number;\r\n\tvisibility: ShaderStage;\r\n\tusage: BufferUsage;\r\n\tbuffer: Buffer;\r\n\tdataBuffer: Float32Array;\r\n\toffset: number;\r\n\tmaxOffset: number;\r\n\tisUniformBuffer: boolean;\r\n\tname: string;\r\n\tprivate static UniformType = {\r\n\t\t[UniformEnum.UniformUint]: UniformUint,\r\n\t\t[UniformEnum.Float]: UniformFloat,\r\n\t\t[UniformEnum.FloatVec2]: UniformFloatVec2,\r\n\t\t[UniformEnum.FloatVec3]: UniformFloatVec3,\r\n\t\t[UniformEnum.FloatVec4]: UniformFloatVec4,\r\n\t\t[UniformEnum.Mat2]: UniformMat2,\r\n\t\t[UniformEnum.Mat3]: UniformMat3,\r\n\t\t[UniformEnum.Mat4]: UniformMat4,\r\n\t\t[UniformEnum.Color]: UniformColor,\r\n\t\t[UniformEnum.FloatArray]: UniformFloatArray,\r\n\t\t[UniformEnum.Vec2Array]: UniformVec2Array,\r\n\t\t[UniformEnum.Vec3Array]: UniformVec3Array,\r\n\t\t[UniformEnum.Vec4Array]: UniformVec4Array,\r\n\t\t[UniformEnum.Mat4Array]: UniformMatrix4Array,\r\n\t\t[UniformEnum.PointLights]: UniformPointLights,\r\n\t\t[UniformEnum.SpotLights]: UniformSpotLights,\r\n\t\t[UniformEnum.DirtectLights]: UniformDirtectLights,\r\n\t\t[UniformEnum.PointLightShadows]: UniformPointLightShadows,\r\n\t\t[UniformEnum.SpotLightShadows]: UniformSpotLightShadows,\r\n\t\t[UniformEnum.DirtectLightShadows]: UniformDirtectLightShadows\r\n\t};\r\n\tconstructor(options: UniformBufferType) {\r\n\t\tthis.type = defaultValue(options.type, \"uniform\");\r\n\t\tthis.label = defaultValue(options.label, \"\");\r\n\t\tthis.name = defaultValue(options.label, \"\");\r\n\t\tthis.hasDynamicOffset = options.hasDynamicOffset ?? false;\r\n\t\tthis.minBindingSize = options.minBindingSize ?? 0;\r\n\t\tthis.binding = options.binding ?? 0;\r\n\t\tthis.visibility = ShaderStage.Fragment | ShaderStage.Vertex;\r\n\t\tthis.usage = defaultValue(options.usage, BufferUsage.Uniform | BufferUsage.CopyDst);\r\n\t\tthis._uniformStruct = new Map();\r\n\t\tthis.uniformDirty = true;\r\n\t\tthis._bufferSize = options.size;\r\n\t\tthis.offset = 0;\r\n\t\tthis.dataBuffer = defaultValue(options.dataBuffer, new Float32Array(defaultValue(this._bufferSize, 400)));\r\n\t\tthis.byteOffset = 0;\r\n\t\tthis.isUniformBuffer = true;\r\n\t\tthis.maxOffset = options.maxOffset ?? 0;\r\n\t}\r\n\tget layoutType() {\r\n\t\treturn {\r\n\t\t\ttype: this.type,\r\n\t\t\thasDynamicOffset: this.hasDynamicOffset,\r\n\t\t\tminBindingSize: this.minBindingSize\r\n\t\t};\r\n\t}\r\n\tget bufferSize() {\r\n\t\treturn this.uniformsSize * 4;\r\n\t}\r\n\tget uniformsSize() {\r\n\t\t// https://gpuweb.github.io/gpuweb/wgsl/#address-space-layout-constraints\r\n\t\treturn Math.ceil(this.byteOffset / 16) * 16;\r\n\t}\r\n\tbind(context: Context) {\r\n\t\tthis._uniformStruct.forEach((uniform) => {\r\n\t\t\tconst result = uniform.set();\r\n\t\t\tif (uniform?.dirty != undefined) uniform.dirty = false;\r\n\t\t\tif (result != undefined && this.uniformDirty == false) this.uniformDirty = result;\r\n\t\t});\r\n\t\tif (this.uniformDirty) {\r\n\t\t\tthis.uniformDirty = false;\r\n\t\t\tif (!this.buffer)\r\n\t\t\t\tthis.buffer = Buffer.createUniformBuffer(this.label, context.device, this.bufferSize, this.usage);\r\n\t\t\tthis.buffer.setSubData(0, this.dataBuffer.slice(0, defaultValue(this?.bufferSize / 4, this.uniformsSize)));\r\n\t\t}\r\n\t}\r\n\tpublic getUniformBufferStruct() {\r\n\t\tlet uniformStruct = `struct MaterialUniform {\\n `;\r\n\t\tthis._uniformStruct.forEach((uniform) => {\r\n\t\t\tuniformStruct += this.createUniformString(uniform);\r\n\t\t});\r\n\t\tuniformStruct += `}\\n`;\r\n\t\treturn uniformStruct;\r\n\t}\r\n\tprivate createUniformString(uniform) {\r\n\t\tlet result = ``;\r\n\t\tswitch (uniform.type) {\r\n\t\t\tcase \"vec1\":\r\n\t\t\t\tresult = `${uniform.name} :f32,\\n`;\r\n\t\t\t\tbreak;\r\n\t\t\tcase \"vec2\":\r\n\t\t\t\tresult = `${uniform.name} :vec2<f32>,\\n`;\r\n\t\t\t\tbreak;\r\n\t\t\tcase \"vec3\":\r\n\t\t\t\tresult = `${uniform.name} :vec3<f32>,\\n`;\r\n\t\t\t\tbreak;\r\n\t\t\tcase \"vec4\":\r\n\t\t\t\tresult = `${uniform.name} :vec4<f32>,\\n`;\r\n\t\t\t\tbreak;\r\n\t\t\tcase \"mat2\":\r\n\t\t\t\tresult = `${uniform.name} :mat2x2<f32>,\\n`;\r\n\t\t\t\tbreak;\r\n\t\t\tcase \"mat3\":\r\n\t\t\t\tresult = `${uniform.name} :mat3x3<f32>,\\n`;\r\n\t\t\t\tbreak;\r\n\t\t\tcase \"mat4\":\r\n\t\t\t\tresult = `${uniform.name} :mat4x4<f32>,\\n`;\r\n\t\t\t\tbreak;\r\n\t\t}\r\n\t\treturn result;\r\n\t}\r\n\tcontains(name: string): Uniform<any> {\r\n\t\treturn this._uniformStruct.get(name);\r\n\t}\r\n\treplaceUniformValue(name: string, value: Function | number | Object) {\r\n\t\tconst uniform = this._uniformStruct.get(name);\r\n\t\tif (!uniform) return;\r\n\t\tuniform.cb = value;\r\n\t}\r\n\t// uniformBuffer.setVec3Array('test',()=>{return [new Vector3(1,0,0),new Vector3(1,0.8,0.5)]},2);\r\n\t// uniformBuffer.setFloatArray('test1',()=>{return [0.5,0.5,1.0]},3);\r\n\t// uniformBuffer.setVec4Array('test4',()=>{return [new Vector4(0.5,0.6,0.2,1.0),new Vector4(0.5,0.8,0.8,1.0)]},2);\r\n\t// uniformBuffer.setVec2Array('test2',()=>{return [new Vector2(0.5,0.6),new Vector2(0.5,0.8,)]},2);\r\n\tsetUniform(name: string, value: Function | number | Object, uniformType: UniformEnum, count?: number) {\r\n\t\tif (this._uniformStruct.get(name)) return;\r\n\t\tconst TypeUniform = UniformBuffer.UniformType[uniformType];\r\n\t\tthis.byteOffset += this.checkUniformOffset(this.byteOffset, TypeUniform.align);\r\n\t\tconst uniform =\r\n\t\t\tcount != undefined\r\n\t\t\t\t? new TypeUniform(name, this.dataBuffer, this.byteOffset, value, 0, count)\r\n\t\t\t\t: new TypeUniform(name, this.dataBuffer, this.byteOffset, value);\r\n\t\tthis._uniformStruct.set(name, uniform);\r\n\t\tthis.byteOffset += uniform.byteSize;\r\n\t}\r\n\tprivate checkUniformOffset(byteSize: number, Align: number): number {\r\n\t\t// from https://gpuweb.github.io/gpuweb/wgsl/#address-space-layout-constraints\r\n\t\t// return this.hasDynamicOffset\r\n\t\t// \t? Math.ceil(byteSize / 256) * 256 - byteSize\r\n\t\t// \t: Math.ceil(byteSize / Align) * Align - byteSize;\r\n\t\treturn Math.ceil(byteSize / Align) * Align - byteSize;\r\n\t}\r\n\tdestroy() {\r\n\t\tthis?.buffer?.destroy();\r\n\t}\r\n}\r\ntype UniformBufferType = {\r\n\tlabel: string;\r\n\ttype?: string;\r\n\tusage?: BufferUsage;\r\n\tsize?: number;\r\n\tdataBuffer?: Float32Array;\r\n\tbinding?: number;\r\n\thasDynamicOffset?: boolean;\r\n\tminBindingSize?: number;\r\n\tmaxOffset?: number;\r\n};\r\n","const preprocessorSymbols = /#([^\\s]*)(\\s*)/gm;\n// Template literal tag that handles simple preprocessor symbols for WGSL\n// shaders. Supports #if/elif/else/endif statements.\nexport function wgslParseDefines(strings, ...values) {\n\tconst stateStack = [];\n\tlet state = { frag: \"\", elseIsValid: false, expression: true };\n\tlet depth = 1;\n\n\tfor (let i = 0; i < strings.length; ++i) {\n\t\tconst frag = strings[i];\n\t\tconst matchedSymbols = frag.matchAll(preprocessorSymbols);\n\n\t\tlet lastIndex = 0;\n\t\tlet valueConsumed = false;\n\n\t\tfor (const match of matchedSymbols) {\n\t\t\tstate.frag += frag.substring(lastIndex, match.index);\n\n\t\t\tswitch (match[1]) {\n\t\t\t\tcase \"if\":\n\t\t\t\t\tif (match.index + match[0].length != frag.length) {\n\t\t\t\t\t\tthrow new Error(\"#if must be immediately followed by a template expression (ie: ${value})\");\n\t\t\t\t\t}\n\t\t\t\t\tvalueConsumed = true;\n\t\t\t\t\tstateStack.push(state);\n\t\t\t\t\tdepth++;\n\t\t\t\t\tstate = { frag: \"\", elseIsValid: true, expression: !!values[i] };\n\t\t\t\t\tbreak;\n\t\t\t\tcase \"elif\":\n\t\t\t\t\tif (match.index + match[0].length != frag.length) {\n\t\t\t\t\t\tthrow new Error(\"#elif must be immediately followed by a template expression (ie: ${value})\");\n\t\t\t\t\t} else if (!state.elseIsValid) {\n\t\t\t\t\t\tthrow new Error(\"#elif not preceeded by an #if or #elif\");\n\t\t\t\t\t}\n\t\t\t\t\tvalueConsumed = true;\n\t\t\t\t\tif (state.expression && stateStack.length != depth) {\n\t\t\t\t\t\tstateStack.push(state);\n\t\t\t\t\t}\n\t\t\t\t\tstate = { frag: \"\", elseIsValid: true, expression: !!values[i] };\n\t\t\t\t\tbreak;\n\t\t\t\tcase \"else\":\n\t\t\t\t\tif (!state.elseIsValid) {\n\t\t\t\t\t\tthrow new Error(\"#else not preceeded by an #if or #elif\");\n\t\t\t\t\t}\n\t\t\t\t\tif (state.expression && stateStack.length != depth) {\n\t\t\t\t\t\tstateStack.push(state);\n\t\t\t\t\t}\n\t\t\t\t\tstate = { frag: match[2], elseIsValid: false, expression: true };\n\t\t\t\t\tbreak;\n\t\t\t\tcase \"endif\":\n\t\t\t\t\tif (!stateStack.length) {\n\t\t\t\t\t\tthrow new Error(\"#endif not preceeded by an #if\");\n\t\t\t\t\t}\n\t\t\t\t\tconst branchState = stateStack.length == depth ? stateStack.pop() : state;\n\t\t\t\t\tstate = stateStack.pop();\n\t\t\t\t\tdepth--;\n\t\t\t\t\tif (branchState.expression) {\n\t\t\t\t\t\tstate.frag += branchState.frag;\n\t\t\t\t\t}\n\t\t\t\t\tstate.frag += match[2];\n\t\t\t\t\tbreak;\n\t\t\t\tdefault:\n\t\t\t\t\t// Unknown preprocessor symbol. Emit it back into the output frag unchanged.\n\t\t\t\t\tstate.frag += match[0];\n\t\t\t\t\tbreak;\n\t\t\t}\n\n\t\t\tlastIndex = match.index + match[0].length;\n\t\t}\n\n\t\t// If the frag didn't end on one of the preprocessor symbols append the rest of it here.\n\t\tif (lastIndex != frag.length) {\n\t\t\tstate.frag += frag.substring(lastIndex, frag.length);\n\t\t}\n\n\t\t// If the next value wasn't consumed by the preprocessor symbol, append it here.\n\t\tif (!valueConsumed && values.length > i) {\n\t\t\tstate.frag += values[i];\n\t\t}\n\t}\n\n\tif (stateStack.length) {\n\t\tthrow new Error(\"Mismatched #if/#endif count\");\n\t}\n\n\treturn state.frag;\n}\n","import { wgslParseDefines } from \"../../WgslPreprocessor\";\n\nexport function FragInput(defines) {\n\treturn wgslParseDefines`\n    struct FragInput {\n      @builtin(front_facing) frontFacing: bool,\n      @location(0) worldPos:vec3<f32>,\n      @location(1) normal:vec3<f32>,\n      #if ${defines.HAS_UV}\n          @location(2) uv:vec2<f32>\n      #endif\n  } \n  `;\n}\n","import { wgslParseDefines } from \"../../WgslPreprocessor\";\n\nexport function VertexInput(defines) {\n\treturn wgslParseDefines`\n        struct VertexInput {\n            @location(${defines.positionLocation}) position: vec3<f32>,       \n            @location(${defines.normalLocation}) normal: vec3<f32>,\n            #if${defines.HAS_COLOR} \n                @location(${defines.colorLocation}) color: vec3<f32>,\n            #endif\n            #if ${defines.HAS_UV}\n                @location(${defines.uvLocation}) uv: vec2<f32>,\n            #endif\n            #if${defines.HAS_SKIN} \n                @location(${defines.joint0Location}) joint0:vec4<f32>,\n                @location(${defines.weight0Location}) weight0:vec4<f32>,\n            #endif\n            #if ${defines.USE_INSTANCE}\n                @builtin(instance_index) instanceIdx : u32\n            #endif\n        }\n   `;\n}\n","import { wgslParseDefines } from \"../../WgslPreprocessor\";\n\nexport function VertexOutput(defines) {\n\treturn wgslParseDefines`\n    struct VertexOutput {\n        @builtin(position) position:vec4<f32>,\n        @location(0) worldPos:vec3<f32>,\n        @location(1) normal:vec3<f32>,\n        #if ${defines.HAS_UV}\n            @location(2) uv:vec2<f32>\n        #endif\n    } \n    `;\n}\n","import { wgslParseDefines } from \"../../WgslPreprocessor\";\n\nexport function SystemUniform(defines) {\n\treturn wgslParseDefines`\n      struct SystemUniform {\n          projectionMatrix: mat4x4<f32>,\n          viewMatrix: mat4x4<f32>,\n          inverseViewMatrix: mat4x4<f32>,\n          cameraPosition: vec3<f32>,\n      }; \n  `;\n}\n","import { wgslParseDefines } from \"../../WgslPreprocessor\";\r\nexport default function environment(defines) {\r\n  return wgslParseDefines`\r\n   #if ${defines.ENVTEXTURE_TYPE_CUBE_UV}\r\n        const cubeUV_minMipLevel:f32= 4.0;\r\n        const cubeUV_minTileSize:f32= 16.0;\r\n        const CUBEUV_MAX_MIP:f32=6.0;\r\n        const CUBEUV_TEXEL_WIDTH:f32=1.0/256.0;\r\n        const CUBEUV_TEXEL_HEIGHT:f32=1.0/256.0;\r\n        fn getFace(direction:vec3<f32> )->f32 {\r\n            let absDirection:vec3<f32> = abs( direction );\r\n            var face:f32 = - 1.0;\r\n            if ( absDirection.x > absDirection.z ) {\r\n                if ( absDirection.x > absDirection.y ){\r\n                    face =select(3.0,0.0,direction.x > 0.0);\r\n                }else{\r\n                    face =select(4.0,1.0,direction.y > 0.0);\r\n                }\r\n                \r\n            }\r\n            else {\r\n                if ( absDirection.z > absDirection.y ){\r\n                    face =select(5.0,2.0,direction.z > 0.0);\r\n                }else{\r\n                    face =select(4.0,1.0,direction.y > 0.0);\r\n                }       \r\n            }\r\n            return face;\r\n        }\r\n        fn getUV( direction:vec3<f32>, face:f32 )->vec2<f32> {\r\n            var uv:vec2<f32>;\r\n            if ( face == 0.0 ) {\r\n                uv = vec2<f32>( direction.z, direction.y ) / abs( direction.x );\r\n            }\r\n            else if ( face == 1.0 ) {\r\n                uv = vec2<f32>( - direction.x, - direction.z ) / abs( direction.y );\r\n            }\r\n            else if ( face == 2.0 ) {\r\n                uv = vec2<f32>( - direction.x, direction.y ) / abs( direction.z );\r\n            }\r\n            else if ( face == 3.0 ) {\r\n                uv = vec2<f32>( - direction.z, direction.y ) / abs( direction.x );\r\n            }\r\n            else if ( face == 4.0 ) {\r\n                uv = vec2<f32>( - direction.x, direction.z ) / abs( direction.y );\r\n            }\r\n            else {\r\n                uv = vec2<f32>( direction.x, direction.y ) / abs( direction.z );\r\n            }\r\n            return 0.5 * ( uv + 1.0 );\r\n        }\r\n        fn bilinearCubeUV(envTexture:texture_cube<f32>,baseSampler:sampler,direction:vec3<f32>, mipInt:f32 )->vec3<f32> {\r\n            var face:f32 = getFace( direction );\r\n            let filterInt:f32 = max( cubeUV_minMipLevel - mipInt, 0.0 );\r\n            let tempMipInt = max( mipInt, cubeUV_minMipLevel );\r\n            let faceSize:f32 = exp2( tempMipInt );\r\n            var uv:vec2<f32> = getUV( direction, face ) * ( faceSize - 2.0 ) + 1.0;\r\n            if ( face > 2.0 ) {\r\n                uv.y += faceSize;\r\n                face -= 3.0;\r\n            }\r\n            uv.x += face * faceSize;\r\n            uv.x += filterInt * 3.0 * cubeUV_minTileSize;\r\n            uv.y += 4.0 * ( exp2( CUBEUV_MAX_MIP ) - faceSize );\r\n            uv.x *= CUBEUV_TEXEL_WIDTH;\r\n            uv.y *= CUBEUV_TEXEL_HEIGHT;\r\n            return textureSample(envTexture,baseSampler,direction).rgb;\r\n        }\r\n        const cubeUV_r0:f32= 1.0;\r\n        const cubeUV_v0:f32= 0.339;\r\n        const cubeUV_m0:f32= - 2.0;\r\n        const cubeUV_r1:f32= 0.8;\r\n        const cubeUV_v1:f32= 0.276;\r\n        const cubeUV_m1:f32= - 1.0;\r\n        const cubeUV_r4:f32= 0.4;\r\n        const cubeUV_v4:f32= 0.046;\r\n        const cubeUV_m4:f32= 2.0;\r\n        const cubeUV_r5:f32= 0.305;\r\n        const cubeUV_v5:f32= 0.016;\r\n        const cubeUV_m5:f32= 3.0;\r\n        const cubeUV_r6:f32= 0.21;\r\n        const cubeUV_v6:f32= 0.0038;\r\n        const cubeUV_m6:f32= 4.0;\r\n        fn roughnessToMip( roughness:f32)->f32 {\r\n            var mip:f32 = 0.0;\r\n            if ( roughness >= cubeUV_r1 ) {\r\n                mip = ( cubeUV_r0 - roughness ) * ( cubeUV_m1 - cubeUV_m0 ) / ( cubeUV_r0 - cubeUV_r1 ) + cubeUV_m0;\r\n            }\r\n            else if ( roughness >= cubeUV_r4 ) {\r\n                mip = ( cubeUV_r1 - roughness ) * ( cubeUV_m4 - cubeUV_m1 ) / ( cubeUV_r1 - cubeUV_r4 ) + cubeUV_m1;\r\n            }\r\n            else if ( roughness >= cubeUV_r5 ) {\r\n                mip = ( cubeUV_r4 - roughness ) * ( cubeUV_m5 - cubeUV_m4 ) / ( cubeUV_r4 - cubeUV_r5 ) + cubeUV_m4;\r\n            }\r\n            else if ( roughness >= cubeUV_r6 ) {\r\n                mip = ( cubeUV_r5 - roughness ) * ( cubeUV_m6 - cubeUV_m5 ) / ( cubeUV_r5 - cubeUV_r6 ) + cubeUV_m5;\r\n            }\r\n            else {\r\n                mip = - 2.0 * log2( 1.16 * roughness );\r\n            }\r\n            return mip;\r\n        }\r\n        fn textureCubeUV(envTexture:texture_cube<f32>, baseSampler:sampler,sampleDir:vec3<f32>,roughness:f32 )->vec4<f32> {\r\n            let mip = clamp( roughnessToMip( roughness ), cubeUV_m0, CUBEUV_MAX_MIP );\r\n            let mipF = fract( mip );\r\n            let mipInt = floor( mip );\r\n            let color0:vec3<f32> = bilinearCubeUV( envTexture,baseSampler,sampleDir, mipInt );\r\n            if ( mipF == 0.0 ) {\r\n                return vec4<f32>(color0, 1.0 );\r\n            }\r\n            else {\r\n                let color1:vec3<f32> = bilinearCubeUV( envTexture,baseSampler, sampleDir, mipInt + 1.0 );\r\n                return vec4<f32>(mix( color0, color1, mipF ), 1.0 );\r\n            }\r\n        \r\n        }\r\n   #endif\r\n   #if ${defines.USE_ENVTEXTURE}\r\n        fn getIBLIrradiance( normal:vec3<f32>,baseSampler:sampler,viewMatrix:mat4x4<f32>)->vec3<f32> {\r\n            #if ${defines.ENVTEXTURE_TYPE_CUBE_UV}\r\n                let worldNormal:vec3<f32> = inverseTransformDirection( normal, viewMatrix );\r\n                let envTextureColor:vec4<f32> = textureCubeUV( envTexture,baseSampler, worldNormal, 1.0 );\r\n                return PI * envTextureColor.rgb * materialUniform.envTextureIntensity;\r\n            #else\r\n                return vec3<f32>( 0.0 );\r\n            #endif\r\n        }\r\n        fn getIBLRadiance( viewDir:vec3<f32>,baseSampler:sampler,viewMatrix:mat4x4<f32>,normal:vec3<f32>, roughness:f32 )->vec3<f32> {\r\n            #if ${defines.ENVTEXTURE_TYPE_CUBE_UV}\r\n                var reflectVec:vec3<f32> = reflect( - viewDir, normal );\r\n                reflectVec = normalize( mix( reflectVec, normal, roughness * roughness) );\r\n                reflectVec = inverseTransformDirection( reflectVec, viewMatrix );\r\n                let envTextureColor:vec4<f32> = textureCubeUV( envTexture,baseSampler, reflectVec, roughness );\r\n                return envTextureColor.rgb * materialUniform.envTextureIntensity;\r\n            #else\r\n                return vec3<f32>( 0.0 );\r\n            #endif\r\n            }\r\n    #endif\r\n   `;\r\n}\r\n","import { wgslParseDefines } from \"../../WgslPreprocessor\";\n\nexport function instanceVertHeader(defines) {\n\treturn wgslParseDefines`\n   #if ${defines.USE_INSTANCE}\n      struct InstancesUniform {\n         instanceMatrixs:  array<mat4x4<f32>, ${defines.instanceCount}>,\n      };\n      @group(0) @binding(${defines.instanceMatrixsBufferBinding}) var<storage, read> instancesUniform: InstancesUniform;\n    #endif\n   `;\n}\nexport function instanceVertMain(defines) {\n\treturn wgslParseDefines`\n      #if ${defines.USE_INSTANCE}\n         modelMatrix=instancesUniform.instanceMatrixs[input.instanceIdx];\n      #endif\n   `;\n}\n","import { wgslParseDefines } from \"../../WgslPreprocessor\";\r\nexport default function light(defines) {\r\n\treturn wgslParseDefines` \r\n    struct ReflectedLight {\r\n        ambient: vec3<f32>,\r\n        directDiffuse:vec3<f32>,\r\n        directSpecular:vec3<f32>,\r\n        indirectDiffuse:vec3<f32>,\r\n        indirectSpecular:vec3<f32>,\r\n        testColor: vec3<f32>,\r\n    }; \r\n    struct IncidentLight {\r\n        color: vec3<f32>,\r\n        direction: vec3<f32>,\r\n        visible: bool,\r\n    };\r\n    struct Geometry {\r\n        position: vec3<f32>,\r\n        normal: vec3<f32>,\r\n        viewDir: vec3<f32>,\r\n        dotNV:f32,\r\n        #if ${defines.USE_CLEARCOAT}\r\n            vec3 clearcoatNormal;\r\n        #endif\r\n    };\r\n\r\n    #if ${defines.spotLightsCount > 0}\r\n        struct SpotLight {\r\n            position: vec3<f32>,\r\n            distance: f32,\r\n            direction: vec3<f32>,\r\n            coneCos: f32,\r\n            color: vec3<f32>,\r\n            penumbraCos: f32,\r\n            decay: f32,\r\n        };\r\n        fn getSpotLightInfo(spotLight:SpotLight,worldPos:vec3<f32>,shininess:f32,N:vec3<f32>,V:vec3<f32>)->ReflectedLight{\r\n                var direction:vec3<f32> = spotLight.position - worldPos;\r\n                var lightColor:ReflectedLight;\r\n                let lightDistance:f32 = length(direction);\r\n                direction = normalize(direction);\r\n                let angleCos:f32 = dot( direction, spotLight.direction );\r\n                let decay:f32 = clamp(1.0 - pow(lightDistance/spotLight.distance, spotLight.decay), 0.0, 1.0);\r\n                let spotEffect:f32 = smoothstep( spotLight.penumbraCos, spotLight.coneCos, angleCos );\r\n                let decayTotal:f32 = decay * spotEffect;\r\n                let d:f32 = max( dot( N, direction ), 0.0 )  * decayTotal;\r\n                lightColor.directDiffuse= spotLight.color * d;\r\n                let halfDir:vec3<f32> = normalize( V + direction );\r\n                let s:f32 = pow( clamp( dot( N, halfDir ), 0.0, 1.0 ), shininess ) * decayTotal;\r\n                lightColor.directSpecular= spotLight.color * s;\r\n                return lightColor;\r\n        }\r\n        fn getSpotLightIncidentLight(spotLight:SpotLight, geometry:Geometry)->IncidentLight {\r\n            var incidentLight:IncidentLight;\r\n            let lVector:vec3<f32> = spotLight.position - geometry.position;\r\n            incidentLight.direction = normalize( lVector );\r\n    \r\n            let lightDistance:f32 = length( lVector );\r\n            let angleCos:f32 = dot( incidentLight.direction, spotLight.direction );\r\n    \r\n            let spotEffect:f32 = smoothstep( spotLight.penumbraCos, spotLight.coneCos, angleCos );\r\n            let decayEffect:f32 = clamp(1.0 - pow(lightDistance/spotLight.distance, 4.0), 0.0, 1.0);\r\n    \r\n            incidentLight.color=spotLight.color*spotEffect * decayEffect; \r\n            return  incidentLight;\r\n        }\r\n\r\n    #endif \r\n\r\n    #if ${defines.pointLightsCount > 0}\r\n        struct PointLight {\r\n            position: vec3<f32>,\r\n            distance: f32,\r\n            color: vec3<f32>,\r\n            decay: f32,\r\n        };\r\n        fn getPointLightInfo(pointLight:PointLight,worldPos:vec3<f32>,shininess:f32,N:vec3<f32>,V:vec3<f32>)->ReflectedLight{\r\n            var lightColor:ReflectedLight;\r\n            var direction:vec3<f32> = worldPos - pointLight.position;\r\n            let dist:f32 = length( direction );\r\n            direction = normalize(direction);\r\n            let decay = clamp(1.0 - pow(dist / pointLight.distance, pointLight.decay), 0.0, 1.0);\r\n    \r\n            let d =  max( dot( N, -direction ), 0.0 ) * decay;\r\n            lightColor.directDiffuse = pointLight.color * d;\r\n    \r\n            let halfDir:vec3<f32> = normalize( V - direction );\r\n            let s:f32 = pow( clamp( dot( N, halfDir ), 0.0, 1.0 ), shininess )  * decay;\r\n            lightColor.directSpecular = pointLight.color * s;\r\n            return lightColor;\r\n        }\r\n        fn getPointLightIncidentLight(pointLight:PointLight, geometry:Geometry)->IncidentLight {\r\n            var incidentLight:IncidentLight;\r\n            let lVector:vec3<f32> = pointLight.position-geometry.position;\r\n            incidentLight.direction= normalize( lVector );\r\n            let lightDistance:f32 = length( lVector );\r\n            // let weight:f32=1.0 - pow(lightDistance/pointLight.distance, 4.0);\r\n            incidentLight.color=pointLight.color*clamp(1.0 - pow(lightDistance/pointLight.distance, 4.0), 0.0, 1.0);\r\n            return incidentLight;\r\n        }\r\n    #endif\r\n    #if ${defines.dirtectLightsCount > 0}\r\n        struct DirectionalLight {\r\n            direction: vec3<f32>,\r\n            color: vec3<f32>,\r\n        };\r\n        fn getDirectLightInfo(directionalLight:DirectionalLight,shininess:f32,N:vec3<f32>,V:vec3<f32>)->ReflectedLight{\r\n            var lightColor:ReflectedLight;\r\n            let d:f32 = max(dot(N, -directionalLight.direction), 0.0);\r\n            lightColor.directDiffuse += directionalLight.color * d;\r\n    \r\n            let halfDir:vec3<f32> = normalize( V - directionalLight.direction );\r\n            let s:f32 = pow( clamp( dot( N, halfDir ), 0.0, 1.0 ), shininess );\r\n            lightColor.directSpecular += directionalLight.color * s;\r\n            return lightColor;\r\n        }\r\n        fn getDirectionalDirectLightIncidentLight(directionalLight:DirectionalLight,geometry:Geometry)->IncidentLight {\r\n            var incidentLight:IncidentLight;\r\n            incidentLight.color = directionalLight.color;\r\n            incidentLight.direction = normalize(directionalLight.direction);\r\n            return incidentLight;         \r\n        }\r\n    #endif\r\n\r\n    #if ${defines.openShadow} \r\n        struct LightInfo {\r\n            direction: vec3<f32>,\r\n            viewport: vec4<f32>,\r\n        };\r\n        \r\n        fn linearizeDepth(depth: f32, near: f32, far: f32)->f32 {\r\n            return 2 * (near * far) / (far + near - depth * (far - near));\r\n        }\r\n\r\n        fn getCubeFace(v : vec3<f32>) -> i32{\r\n            let vAbs = abs(v);\r\n        \r\n            if (vAbs.z >= vAbs.x && vAbs.z >= vAbs.y) {\r\n              if (v.z < 0.0) {\r\n                return 3;\r\n              }\r\n              return 2;\r\n            }\r\n        \r\n            if (vAbs.y >= vAbs.x) {\r\n              if (v.y < 0.0) {\r\n                return 5;\r\n              }\r\n              return 4;\r\n            }\r\n        \r\n            if (v.x < 0.0) {\r\n              return 1;\r\n            }\r\n            return 0;\r\n        }\r\n\r\n        fn getShadowValue(shadowMapArray:texture_depth_2d_array, shadowSampler:sampler_comparison, lightPos:vec4<f32>, geometry:Geometry, lightInfo:LightInfo, index:u32, isPointLight: bool, near: f32, far: f32)->f32 {\r\n            var visibility = 0.0;\r\n            var projectPos: vec3<f32> = lightPos.xyz / lightPos.w;\r\n            var shadowPos: vec3<f32> = vec3(projectPos.xy * vec2(0.5, -0.5) + vec2(0.5), projectPos.z);\r\n            var d:f32 = dot(geometry.normal, -lightInfo.direction);\r\n            var bias = max(0.012 * (1.0 - d), 0.001) / lightPos.w;\r\n            let oneOverShadowDepthTextureSize = 1.0 / 1024.0;\r\n            // var depth = select(shadowPos.z, (linearizeDepth(shadowPos.z, near, far) - near) / (far- near), isPerspectiveCamera);\r\n            var depth = shadowPos.z;\r\n\r\n            if (isPointLight) {\r\n                shadowPos.x = shadowPos.x * lightInfo.viewport.z;\r\n                shadowPos.y = shadowPos.y * lightInfo.viewport.w;\r\n                var viewportX = lightInfo.viewport.x * lightInfo.viewport.z;\r\n                var viewportY = lightInfo.viewport.y * lightInfo.viewport.w;\r\n                var uvOffset = 1.5 / 1024.0;\r\n                shadowPos.x = clamp(shadowPos.x + viewportX, viewportX + uvOffset, viewportX + lightInfo.viewport.z - uvOffset);\r\n                shadowPos.y = clamp(shadowPos.y + viewportY, viewportY + uvOffset, viewportY + lightInfo.viewport.w - uvOffset);\r\n            }\r\n\r\n            for (var y = -1; y <= 1; y++) {\r\n                for (var x = -1; x <= 1; x++) {\r\n                    let offset = vec2<f32>(vec2(x, y)) * oneOverShadowDepthTextureSize;\r\n                \r\n                    visibility += textureSampleCompare(\r\n                        shadowMapArray, shadowSampler,\r\n                        shadowPos.xy + offset, index, depth - bias);\r\n                }\r\n            }\r\n            visibility /= 9.0;\r\n            var inFrustum = shadowPos.x >= 0.0 && shadowPos.x <= 1.0 && shadowPos.y >= 0.0 && shadowPos.y <= 1.0;\r\n            if (!inFrustum || depth > 1.0) {\r\n                visibility = 1.0;\r\n            }\r\n            return visibility;\r\n        }\r\n    #endif\r\n\r\n    #if ${\r\n\t\tdefines.ambientLightCount || defines.spotLightsCount || defines.pointLightsCount || defines.dirtectLightsCount\r\n\t}\r\n        struct LightUniforms{\r\n            #if ${defines.ambientLightCount}\r\n                ambient:vec4<f32>,\r\n            #endif\r\n            #if ${defines.spotLightsCount}\r\n                spotLights:array<SpotLight,${defines.spotLightsCount}>,\r\n            #endif\r\n            #if ${defines.pointLightsCount}\r\n                pointLights:array<PointLight,${defines.pointLightsCount}>,\r\n            #endif\r\n            #if ${defines.dirtectLightsCount}\r\n                dirtectLights:array<DirectionalLight,${defines.dirtectLightsCount}>,\r\n            #endif\r\n        }\r\n        @group(2) @binding(${defines.lightBinding}) var<storage, read> lightUniforms: LightUniforms;\r\n\r\n        #if ${defines.openShadow}\r\n            #if ${defines.spotLightShadowMapsCount}\r\n                struct SpotLightShadow {\r\n                    shadowCameraVPMatrix: mat4x4<f32>,\r\n                    shadowCameraNear: f32,\r\n                    shadowCameraFar: f32\r\n                }\r\n            #endif\r\n            #if ${defines.pointLightShadowMapsCount}\r\n                struct PointLightShadow {\r\n                    shadowCameraVPMatrixArray: array<mat4x4<f32>, 6>,\r\n                    shadowCameraViewportArray: array<vec4<f32>, 6>,\r\n                    shadowCameraNear: f32,\r\n                    shadowCameraFar: f32,\r\n                    // shadowCameraVPMatrix: mat4x4<f32>,\r\n                    // shadowCameraVPMatrixArray: array<mat4x4<f32>, 6>,\r\n                    // shadowCameraViewportArray: array<vec4<f32>, 6>,\r\n                }\r\n            #endif\r\n            #if ${defines.directLightShadowMapsCount}\r\n                struct DirectLightShadow {\r\n                    shadowCameraVPMatrix: mat4x4<f32>,\r\n                }\r\n            #endif\r\n            struct ShadowUniforms{\r\n                #if ${defines.spotLightShadowMapsCount}\r\n                    spotLightShadows:array<SpotLightShadow,${defines.spotLightShadowMapsCount}>,\r\n                #endif\r\n                #if ${defines.pointLightShadowMapsCount}\r\n                    pointLightShadows:array<PointLightShadow,${defines.pointLightShadowMapsCount}>,\r\n                #endif\r\n                #if ${defines.directLightShadowMapsCount}\r\n                    directLightShadows:array<DirectLightShadow,${defines.directLightShadowMapsCount}>,\r\n                #endif\r\n            }\r\n            @group(2) @binding(${defines.shadowBinding}) var<storage, read> shadowUniforms: ShadowUniforms;\r\n\r\n            #if ${defines.spotLightShadowMapTextureArrayBinding}\r\n                @group(2) @binding(${\r\n\t\t\t\t\tdefines.spotLightShadowMapTextureArrayBinding\r\n\t\t\t\t}) var spotLightShadowMapTextureArray: texture_depth_2d_array;\r\n            #endif\r\n            #if ${defines.pointLightShadowMapTextureArrayBinding}\r\n                @group(2) @binding(${\r\n\t\t\t\t\tdefines.pointLightShadowMapTextureArrayBinding\r\n\t\t\t\t}) var pointLightShadowMapTextureArray: texture_depth_2d_array;\r\n            #endif\r\n            #if ${defines.directLightShadowMapTextureArrayBinding}\r\n                @group(2) @binding(${\r\n\t\t\t\t\tdefines.directLightShadowMapTextureArrayBinding\r\n\t\t\t\t}) var directLightShadowMapTextureArray: texture_depth_2d_array;\r\n            #endif\r\n            @group(2) @binding(${defines.shadowSamplerBinding}) var shadowSampler: sampler_comparison;\r\n        #endif\r\n\r\n    #endif\r\n    #if ${defines.materialPhong}\r\n        fn parseLights(geometry:Geometry,shininess:f32)->ReflectedLight {\r\n    #elif ${defines.materialPbr}\r\n        fn parseLights(geometry:Geometry,material:PhysicalMaterial)->ReflectedLight{\r\n    #endif\r\n        var reflectedLight:ReflectedLight;\r\n        var shadowValue:f32 = 1.0;\r\n        #if ${defines.ambientLightCount > 0}\r\n            //处理环境光\r\n            var ambientColor:vec3<f32> = lightUniforms.ambient.xyz * lightUniforms.ambient.w;\r\n            reflectedLight.ambient += ambientColor;\r\n        #endif\r\n\r\n        #if ${defines.spotLightsCount > 0}\r\n            //处理聚光灯\r\n            var spotLight:SpotLight;\r\n            for (var k = 0u; k < ${defines.spotLightsCount}; k = k + 1u) {\r\n                spotLight= lightUniforms.spotLights[k];\r\n                #if ${defines.materialPhong && defines.openShadow && defines.spotLightShadowMapsCount}\r\n                    if k < textureNumLayers(spotLightShadowMapTextureArray) {\r\n                        var spotLightShadow:SpotLightShadow = shadowUniforms.spotLightShadows[k];\r\n                        var lightPos: vec4<f32> = spotLightShadow.shadowCameraVPMatrix * vec4<f32>(geometry.position,1.0);\r\n                        var lightInfo:LightInfo;\r\n                        lightInfo.direction = normalize(geometry.position - spotLight.position);\r\n\r\n                        shadowValue = getShadowValue(spotLightShadowMapTextureArray, shadowSampler, lightPos, geometry, lightInfo, k, false,\r\n                            spotLightShadow.shadowCameraNear, spotLightShadow.shadowCameraFar);\r\n                    }\r\n                    spotLight.color *= shadowValue;\r\n                #endif\r\n                #if ${defines.materialPhong}\r\n                    let spReflectedLight=getSpotLightInfo(spotLight,geometry.position,shininess,geometry.normal,geometry.viewDir);\r\n                #elif ${defines.materialPbr}\r\n                    let incidentLight=getSpotLightIncidentLight(spotLight,geometry);\r\n                    let spReflectedLight=direct_Physical(incidentLight, geometry, material);\r\n                #endif\r\n\r\n                reflectedLight.directDiffuse+=spReflectedLight.directDiffuse;\r\n                reflectedLight.directSpecular+=spReflectedLight.directSpecular;\r\n            }\r\n        #endif\r\n        #if ${defines.pointLightsCount > 0}\r\n            //处理点光源\r\n            var pointLight:PointLight;\r\n            for (var j = 0u; j < ${defines.pointLightsCount};j = j + 1u) {\r\n                pointLight = lightUniforms.pointLights[j];\r\n                #if ${defines.materialPhong && defines.openShadow && defines.pointLightShadowMapsCount}\r\n                    if j < textureNumLayers(pointLightShadowMapTextureArray) {\r\n                        var pointLightShadow:PointLightShadow = shadowUniforms.pointLightShadows[j];\r\n                        var lightInfo:LightInfo;\r\n                        lightInfo.direction = normalize(geometry.position - pointLight.position);\r\n                        var cubeFace = getCubeFace(lightInfo.direction);\r\n                        var lightPos: vec4<f32> = pointLightShadow.shadowCameraVPMatrixArray[cubeFace] * vec4<f32>(geometry.position,1.0);\r\n                        lightInfo.viewport = pointLightShadow.shadowCameraViewportArray[cubeFace];\r\n\r\n                        // var lightPos: vec4<f32> = pointLightShadow.shadowCameraVPMatrix * vec4<f32>(geometry.position,1.0);\r\n\r\n                        shadowValue = getShadowValue(pointLightShadowMapTextureArray, shadowSampler, lightPos, geometry, lightInfo, j, true,\r\n                            pointLightShadow.shadowCameraNear, pointLightShadow.shadowCameraFar);\r\n                        \r\n                        // reflectedLight.testColor = vec3(pointLightShadow.shadowCameraFar / 1000, \r\n                        //     pointLightShadow.shadowCameraVPMatrixArray[5][3][2] / 255, pointLightShadow.shadowCameraVPMatrixArray[5][3][3] / 255);\r\n                        // reflectedLight.testColor = vec3(pointLightShadow.shadowCameraNear, pointLightShadow.shadowCameraNear, pointLightShadow.shadowCameraNear);\r\n                    }\r\n                    pointLight.color *= shadowValue;\r\n                #endif\r\n                #if ${defines.materialPhong}\r\n                    let poiReflectedLight=getPointLightInfo(pointLight,geometry.position,shininess,geometry.normal,geometry.viewDir);\r\n                #elif ${defines.materialPbr}\r\n                   let incidentLight=getPointLightIncidentLight(pointLight,geometry);\r\n                   let poiReflectedLight=direct_Physical(incidentLight, geometry, material);\r\n                #endif\r\n\r\n                reflectedLight.directDiffuse+=poiReflectedLight.directDiffuse;\r\n                reflectedLight.directSpecular+=poiReflectedLight.directSpecular;\r\n            }\r\n        #endif\r\n        #if ${defines.dirtectLightsCount > 0}\r\n            //处理方向光\r\n            var directionalLight:DirectionalLight;\r\n            for (var i= 0u; i <${defines.dirtectLightsCount}; i = i + 1u) {\r\n                directionalLight = lightUniforms.dirtectLights[i];\r\n                #if ${defines.materialPhong && defines.openShadow && defines.directLightShadowMapsCount}\r\n                    if i < textureNumLayers(directLightShadowMapTextureArray) {\r\n                        var directLightShadow:DirectLightShadow = shadowUniforms.directLightShadows[i];\r\n                        var lightPos: vec4<f32> = directLightShadow.shadowCameraVPMatrix * vec4<f32>(geometry.position,1.0);\r\n                        var lightInfo:LightInfo;\r\n                        lightInfo.direction = directionalLight.direction;\r\n                            \r\n                        shadowValue = getShadowValue(directLightShadowMapTextureArray, shadowSampler, lightPos, geometry, lightInfo, i, false, 0, 0);\r\n                    }\r\n                    directionalLight.color *= shadowValue;\r\n                #endif\r\n            \r\n                #if ${defines.materialPhong}\r\n                    let dirReflectedLight=getDirectLightInfo(directionalLight,shininess,geometry.normal,geometry.viewDir);\r\n                #elif ${defines.materialPbr}\r\n                    let incidentLight=getDirectionalDirectLightIncidentLight(directionalLight,geometry);\r\n                    let dirReflectedLight=direct_Physical(incidentLight, geometry, material);\r\n                #endif\r\n\r\n                reflectedLight.directDiffuse+=dirReflectedLight.directDiffuse;\r\n                reflectedLight.directSpecular+=dirReflectedLight.directSpecular;\r\n            }\r\n        #endif\r\n        return reflectedLight;\r\n    }`;\r\n}\r\n","import { wgslParseDefines } from \"../../WgslPreprocessor\";\r\nexport default function lightCommon(defines) {\r\n\treturn wgslParseDefines`\r\n    struct ReflectedLight {\r\n        directDiffuse:vec3<f32>,\r\n        directSpecular:vec3<f32>,\r\n        indirectDiffuse:vec3<f32>,\r\n        indirectSpecular:vec3<f32>,\r\n    };\r\n    struct Geometry {\r\n        position: vec3<f32>,\r\n        normal: vec3<f32>,\r\n        viewDir: vec3<f32>,\r\n        #if ${defines.USE_CLEARCOAT}\r\n            vec3 clearcoatNormal;\r\n        #endif\r\n    };\r\n    fn getAmbientLightIrradiance(ambientLightColor: vec3<f32>) -> vec3<f32> {\r\n        let irradiance = ambientLightColor;\r\n        return irradiance;\r\n    }\r\n    fn getDistanceAttenuation(lightDistance: f32, cutoffDistance: f32, decayExponent: f32) -> f32 {\r\n        if (cutoffDistance > 0.0 && decayExponent > 0.0) {\r\n            let x:f32 = saturate(- lightDistance / cutoffDistance + 1.0);\r\n            return pow(x, decayExponent);\r\n        }\r\n        return 1.0;\r\n    }\r\n    fn getSpotAttenuation(coneCosine: f32, penumbraCosine: f32, angleCosine: f32) -> f32 {\r\n        return smoothstep(coneCosine, penumbraCosine, angleCosine);\r\n    }\r\n    fn shGetIrradianceAt( normal:vec3<f32>, shCoefficients:array<vec3<f32>,9>)->vec3<f32> {\r\n        let x:f32 = normal.x; \r\n        let y:f32 = normal.y; \r\n        let z:f32 = normal.z;\r\n        var result:vec3<f32> = shCoefficients[ 0 ] * 0.886227;\r\n        result += shCoefficients[ 1 ] * 2.0 * 0.511664 * y;\r\n        result += shCoefficients[ 2 ] * 2.0 * 0.511664 * z;\r\n        result += shCoefficients[ 3 ] * 2.0 * 0.511664 * x;\r\n        result += shCoefficients[ 4 ] * 2.0 * 0.429043 * x * y;\r\n        result += shCoefficients[ 5 ] * 2.0 * 0.429043 * y * z;\r\n        result += shCoefficients[ 6 ] * ( 0.743125 * z * z - 0.247708 );\r\n        result += shCoefficients[ 7 ] * 2.0 * 0.429043 * x * z;\r\n        result += shCoefficients[ 8 ] * 0.429043 * ( x * x - y * y );\r\n        return result;\r\n    }\r\n    fn inverseTransformDirection( dir:vec3<f32>, matrix:mat4x4<f32> )->vec3<f32> {\r\n        return normalize( ( vec4<f32>( dir, 0.0 ) * matrix ).xyz );\r\n    }\r\n `;\r\n}\r\n","import { wgslParseDefines } from \"../../WgslPreprocessor\";\nexport function getNormal(defines) {\n\treturn wgslParseDefines`\n      fn getNormal(input:FragInput)->vec3<f32>{\n        var normal:vec3<f32>;\n        #if ${defines.HAS_NORMAL}\n            normal= input.normal;\n        #else\n          let pos_dx = dpdx(input.worldPos);\n          let pos_dy = dpdy(input.worldPos);\n          normal = normalize( cross(pos_dy, pos_dx) );\n        #endif\n        return normal*(f32(input.frontFacing) * 2.0 - 1.0);\n      }\n    `;\n}\nexport function getNormalByNormalTexture(defines) {\n\treturn wgslParseDefines`\n      fn getNormalByNormalTexture(input:VertInput)->vec3<f32>{\n        var n:vec3<f32> = textureSample(normalTexture,normalSampler, input.uv).rgb;\n        let tbn:mat3x3<f32> =getTBN(input);\n        n = normalize(tbn * (2.0 * n - vec3(1.0)));\n        n=n*(f32(input.frontFacing) * 2.0 - 1.0);\n        return n;\n      }\n    `;\n}\nexport function getTBN(defines) {\n\treturn wgslParseDefines`\n        fn getTBN(input:VertInput)->mat3x3<f32>{\n        #if ${defines.HAS_TANGENT}\n            let tbn:mat3x3<f32> = input.tbn;\n        #else\n            let normal:vec3<f32> =normalize(input.normal);\n            let uv:vec2<f32> = select(-input.uv,input.uv,input.frontFacing);\n              // ref: http://www.thetenthplanet.de/archives/1180\n              // get edge vectors of the pixel triangle\n              let dp1:vec3<f32> =  vec3<f32>(dpdx(input.worldPos.x), dpdx(input.worldPos.y), dpdx(input.worldPos.z));\n              let dp2:vec3<f32> =  vec3<f32>(dpdy(input.worldPos.x), dpdy(input.worldPos.y), dpdy(input.worldPos.z));\n              let duv1:vec2<f32> = dpdx(uv);\n              let duv2:vec2<f32> = dpdy(uv);\n\n              // solve the linear system\n              let dp2perp:vec3<f32> = cross(dp2, normal);\n              let dp1perp:vec3<f32> = cross(normal, dp1);\n              let tangent:vec3<f32> = dp2perp * duv1.x + dp1perp * duv2.x;\n              let binormal:vec3<f32> = dp2perp * duv1.y + dp1perp * duv2.y;\n              // construct a scale-invariant frame \n              let result:f32=max(dot(tangent, tangent), dot(binormal, binormal));\n              let invmax:f32 = 1.0/sqrt(result);\n              let tbn:mat3x3<f32> = mat3x3<f32>(tangent * invmax, binormal * invmax, normal);\n        #endif\n        return tbn;\n      }\n  `;\n}\n","import { wgslParseDefines } from \"../../WgslPreprocessor\";\r\nexport default function brdf(defines) {\r\n\treturn wgslParseDefines`\r\n        #if ${defines.USE_SHEEN}\r\n                fn D_Charlie( roughness:f32,dotNH:f32 )->f32 {\r\n                    let alpha:f32 = pow2( roughness );\r\n                    let invAlpha:f32 = 1.0 / alpha;\r\n                    let cos2h:f32 = dotNH * dotNH;\r\n                    let sin2h:f32 = max( 1.0 - cos2h, 0.0078125 );\r\n                    return ( 2.0 + invAlpha ) * pow( sin2h, invAlpha * 0.5 ) / ( 2.0 * PI );\r\n                }\r\n                fn V_Neubelt( dotNV:f32, dotNL:f32 )->f32 {\r\n                    return saturate( 1.0 / ( 4.0 * ( dotNL + dotNV - dotNL * dotNV ) ) );\r\n                }\r\n                fn BRDF_Sheen(lightDir:vec3<f32>, viewDir:vec3<f32>, normal:vec3<f32>,sheenColor:vec3<f32>,sheenRoughness:f32 )->vec3<f32> {\r\n                    let halfDir:vec3<f32> = normalize( lightDir + viewDir );\r\n                    let dotNL:f32 = saturate( dot( normal, lightDir ) );\r\n                    let dotNV:f32 = saturate( dot( normal, viewDir ) );\r\n                    let dotNH:f32 = saturate( dot( normal, halfDir ) );\r\n                    let D:f32 = D_Charlie( sheenRoughness, dotNH );\r\n                    let V:f32 = V_Neubelt( dotNV, dotNL );\r\n                    return sheenColor * ( D * V );\r\n                }\r\n        #endif\r\n        fn BRDF_Lambert(diffuseColor:vec3<f32>)->vec3<f32> {\r\n\r\n            return RECIPROCAL_PI * diffuseColor;\r\n\r\n        } // validated\r\n\r\n        fn F_Schlick( f0:vec3<f32>, dotVH:f32 )->vec3<f32> {\r\n\r\n            // Original approximation by Christophe Schlick '94\r\n            // float fresnel = pow( 1.0 - dotVH, 5.0 );\r\n\r\n            // Optimized variant (presented by Epic at SIGGRAPH '13)\r\n            // https://cdn2.unrealengine.com/Resources/files/2013SiggraphPresentationsNotes-26915738.pdf\r\n           let fresnel = exp2( ( - 5.55473 * dotVH - 6.98316 ) * dotVH );\r\n           return ( 1.0 - f0 ) * fresnel + f0;\r\n\r\n        } // validated\r\n\r\n        fn Schlick_to_F0(f:vec3<f32>, f90:f32, dotVH:f32 )->vec3<f32> {\r\n            let x:f32 = clamp( 1.0 - dotVH, 0.0, 1.0 );\r\n            let x2:f32 = x * x;\r\n            let x5:f32 = clamp( x * x2 * x2, 0.0, 0.9999 );\r\n\r\n            return ( f - vec3( f90 ) * x5 ) / ( 1.0 - x5 );\r\n        }\r\n        fn V_GGX_SmithCorrelated( alpha:f32, dotNL:f32,dotNV:f32 )->f32 {\r\n\r\n            let a2 :f32= pow2( alpha );\r\n\r\n            let gv:f32 = dotNL * sqrt( a2 + ( 1.0 - a2 ) * pow2( dotNV ) );\r\n            let gl:f32 = dotNV * sqrt( a2 + ( 1.0 - a2 ) * pow2( dotNL ) );\r\n\r\n            return 0.5 / max((gv + gl), 0.000000001 );\r\n\r\n        }\r\n        fn D_GGX( alpha:f32, dotNH:f32 )->f32 {\r\n\r\n            let a2:f32 = pow2( alpha );\r\n\r\n            let denom:f32 = pow2( dotNH ) * ( a2 - 1.0 ) + 1.0; // avoid alpha = 0 with dotNH = 1\r\n\r\n            return RECIPROCAL_PI * a2 / pow2( denom );\r\n\r\n        }\r\n        fn BRDF_GGX( lightDir:vec3<f32>, viewDir:vec3<f32>, normal:vec3<f32>, f0:vec3<f32>,  roughness:f32 )->vec3<f32> {\r\n\r\n            let alpha:f32 = pow2( roughness ); // UE4's roughness\r\n\r\n            let halfDir = normalize( lightDir + viewDir );\r\n\r\n            let dotNL:f32 = saturate( dot( normal, lightDir ) );\r\n            let dotNV:f32 = saturate( dot( normal, viewDir ) );\r\n            let dotNH:f32 = saturate( dot( normal, halfDir ) );\r\n            let dotVH:f32 = saturate( dot( lightDir, halfDir ) );\r\n\r\n            let F = F_Schlick( f0,  dotVH );\r\n\r\n            let V = V_GGX_SmithCorrelated( alpha, dotNL, dotNV );\r\n\r\n            let D = D_GGX( alpha, dotNH );\r\n\r\n            return F * ( V * D );\r\n\r\n        }\r\n        fn direct_Physical( directLight:IncidentLight, geometry:Geometry,material:PhysicalMaterial)->ReflectedLight {\r\n            var reflectedLight:ReflectedLight;\r\n            let dotNL:f32 = saturate(dot( geometry.normal,geometry.viewDir));\r\n            let irradiance:vec3<f32> = dotNL * directLight.color*3.1415926;\r\n            reflectedLight.directSpecular = irradiance * BRDF_GGX( directLight.direction, geometry.viewDir, geometry.normal, material.specularColor, material.roughness );\r\n            reflectedLight.directDiffuse = irradiance * BRDF_Lambert( material.diffuseColor );\r\n            return reflectedLight;\r\n        }\r\n  `;\r\n}\r\n","import { wgslParseDefines } from \"../../WgslPreprocessor\";\r\nexport default function ibl(defines) {\r\n\treturn wgslParseDefines`\r\n  fn getLightProbeRadiance( viewDir:vec3<f32>,normal:vec3<f32>, roughness:f32 )->vec3<f32>{\r\n    var reflectVec:vec3<f32> = reflect( -viewDir, normal );\r\n    reflectVec.x = -reflectVec.x; // TextureCube is left-hand,so x need inverse\r\n    let mipCount:f32 = 10.0; // resolution of 256x256\r\n    let lod:f32 = roughness * mipCount;\r\n    let specularLight:vec3<f32> = textureSampleLevel(specularEnvTexture,specularEnvSampler, reflectVec, lod).rgb;\r\n    return specularLight;\r\n  }\r\n  fn getLightProbeIrradiance( lightProbe:array<vec3<f32>,9>, normal:vec3<f32>)->vec3<f32> {\r\n    var worldNormal:vec3<f32> = normal;\r\n    worldNormal.x = -normal.x;\r\n    var irradiance:vec3<f32> = lightProbe[0];\r\n    irradiance+=lightProbe[1] * (normal.y);\r\n    irradiance+=lightProbe[2] * (normal.z) ;\r\n    irradiance+=lightProbe[3] * (normal.x) ;\r\n\r\n    irradiance+=lightProbe[4] * (normal.y * normal.x) ;\r\n    irradiance+=lightProbe[5] * (normal.y * normal.z) ;\r\n    irradiance+=lightProbe[6] * (3.0 * normal.z * normal.z - 1.0);\r\n    irradiance+=lightProbe[7] * (normal.z * normal.x) ;\r\n    irradiance+=lightProbe[8] * (normal.x * normal.x - normal.y * normal.y);\r\n\r\n    return max(irradiance, vec3<f32>(0.0,0.0,0.0));\r\n  }\r\n  fn DFGApprox( specularColor:vec3<f32>, roughness:f32,dotNV:f32 )->vec3<f32> {\r\n    const c0:vec4<f32> = vec4<f32>( - 1, - 0.0275, - 0.572, 0.022 );\r\n    let c1:vec4<f32> = vec4<f32>( 1, 0.0425, 1.04, - 0.04 );\r\n    let r:vec4<f32> = roughness * c0 + c1;\r\n    let a004:f32 = min( r.x * r.x, exp2( - 9.28 * dotNV ) ) * r.x + r.y;\r\n    let fab:vec2<f32> = vec2<f32>( - 1.04, 1.04 ) * a004 + r.zw;\r\n    return specularColor * fab.x + fab.y;\r\n  }\r\n  //间接光照\r\n  fn indirectDiffuse_Physical(geometry:Geometry, material:PhysicalMaterial )->ReflectedLight {\r\n      var reflectedLight:ReflectedLight;\r\n      var irradiance:vec3<f32> = lightUniforms.ambient.xyz*lightUniforms.ambient.w;\r\n      irradiance *= PI;\r\n      reflectedLight.indirectDiffuse += irradiance * BRDF_Lambert( material.diffuseColor );\r\n      return reflectedLight;\r\n  }\r\n  //间接高光\r\n  fn indirectSpecular_Physical(geometry:Geometry, material:PhysicalMaterial)->ReflectedLight {\r\n      var reflectedLight:ReflectedLight;\r\n      // IBL specular\r\n      let radiance:vec3<f32> = getLightProbeRadiance(geometry.viewDir, geometry.normal, material.roughness);\r\n      let radianceAttenuation:f32 = 1.0;\r\n      reflectedLight.indirectSpecular += radianceAttenuation * radiance * DFGApprox(material.specularColor, material.roughness, geometry.dotNV );\r\n      return reflectedLight;\r\n    }\r\n  `;\r\n}\r\n","import { wgslParseDefines } from \"../../WgslPreprocessor\";\r\n\r\nexport default function pbrFunction(defines) {\r\n\treturn wgslParseDefines`\r\n\r\n    #if ${defines.DITHERING}\r\n        fn dithering(color:vec3<f32> )->vec3<f32> {\r\n            let grid_position:f32 = rand( gl_FragCoord.xy );\r\n            let dither_shift_RGB:vec3<f32> = vec3<f32>( 0.25 / 255.0, -0.25 / 255.0, 0.25 / 255.0 );\r\n            dither_shift_RGB = mix( 2.0 * dither_shift_RGB, -2.0 * dither_shift_RGB, grid_position );\r\n            return color + dither_shift_RGB;\r\n        }\r\n    #endif\r\n\r\n    #if ${defines.USE_IRIDESCENCE}\r\n        fn BRDF_GGX_Iridescence( lightDir:vec3<f32>, viewDir:vec3<f32>,normal:vec3<f32>, f0:vec3<f32>, f90:f32,iridescence:f32, iridescenceFresnel:vec3<f32>,roughness:f32 )->vec3<f32> {\r\n            let alpha:f32 = pow2( roughness );\r\n            let halfDir:vec3<f32> = normalize( lightDir + viewDir );\r\n            let dotNL:f32 = saturate( dot( normal, lightDir ) );\r\n            let dotNV:f32 = saturate( dot( normal, viewDir ) );\r\n            let dotNH:f32 = saturate( dot( normal, halfDir ) );\r\n            let dotVH:f32 = saturate( dot( viewDir, halfDir ) );\r\n            let F:vec3<f32> = mix( F_Schlick( f0, f90, dotVH ), iridescenceFresnel, iridescence );\r\n            let V:f32 = V_GGX_SmithCorrelated( alpha, dotNL, dotNV );\r\n            let D:f32 = D_GGX( alpha, dotNH );\r\n            return F * ( V * D );\r\n        }\r\n    #endif\r\n\r\n    #if ${defines.USE_SHEEN}\r\n        fn D_Charlie( roughness:f32,dotNH:f32 )->f32 {\r\n            let alpha:f32 = pow2( roughness );\r\n            let invAlpha:f32 = 1.0 / alpha;\r\n            let cos2h:f32 = dotNH * dotNH;\r\n            let sin2h:f32 = max( 1.0 - cos2h, 0.0078125 );\r\n            return ( 2.0 + invAlpha ) * pow( sin2h, invAlpha * 0.5 ) / ( 2.0 * PI );\r\n        }\r\n        fn V_Neubelt( dotNV:f32, dotNL:f32 )->f32 {\r\n            return saturate( 1.0 / ( 4.0 * ( dotNL + dotNV - dotNL * dotNV ) ) );\r\n        }\r\n        fn BRDF_Sheen(lightDir:vec3<f32>, viewDir:vec3<f32>, normal:vec3<f32>,sheenColor:vec3<f32>,sheenRoughness:f32 )->vec3<f32> {\r\n            let halfDir:vec3<f32> = normalize( lightDir + viewDir );\r\n            let dotNL:f32 = saturate( dot( normal, lightDir ) );\r\n            let dotNV:f32 = saturate( dot( normal, viewDir ) );\r\n            let dotNH:f32 = saturate( dot( normal, halfDir ) );\r\n            let D:f32 = D_Charlie( sheenRoughness, dotNH );\r\n            let V:f32 = V_Neubelt( dotNV, dotNL );\r\n            return sheenColor * ( D * V );\r\n        }\r\n    #endif\r\n\r\n    #if ${defines.USE_IRIDESCENCE}\r\n        let XYZ_TO_REC709: mat3x3<f32> = mat3x3<f32>(\r\n        3.2404542, -0.9692660, 0.0556434, -1.5371385, 1.8760108, -0.2040259, -0.4985314, 0.0415560, 1.0572252\r\n        );\r\n        fn Fresnel0ToIor( fresnel0:vec3<f32> )->vec3<f32> {\r\n            let sqrtF0:vec3<f32> = sqrt( fresnel0 );\r\n            return ( vec3<f32>( 1.0 ) + sqrtF0 ) / ( vec3<f32>( 1.0 ) - sqrtF0 );\r\n        }\r\n        fn IorToFresnel0(transmittedIor:vec3<f32>,incidentIor:f32 )->vec3<f32> {\r\n            return pow2Vector( ( transmittedIor - vec3<f32>( incidentIor ) ) / ( transmittedIor + vec3<f32>( incidentIor ) ) );\r\n        }\r\n        fn IorToFresnel0(transmittedIor:f32, incidentIor:f32 )->f32 {\r\n            return pow2Vector( ( transmittedIor - incidentIor ) / ( transmittedIor + incidentIor ));\r\n        }\r\n        fn evalSensitivity(OPD:f32,shift:vec3<f32> )->vec3<f32> {\r\n            let phase:f32 = 2.0 * PI * OPD * 1.0e-9;\r\n            let val:vec3<f32> = vec3<f32>( 5.4856e-13, 4.4201e-13, 5.2481e-13 );\r\n            let pos:vec3<f32> = vec3<f32>( 1.6810e+06, 1.7953e+06, 2.2084e+06 );\r\n            let vart:vec3<f32> = vec3<f32>( 4.3278e+09, 9.3046e+09, 6.6121e+09 );\r\n            let xyz:vec3<f32> = val * sqrt( 2.0 * PI * vart ) * cos( pos * phase + shift ) * exp( - pow2( phase ) * vart );\r\n            xyz.x += 9.7470e-14 * sqrt( 2.0 * PI * 4.5282e+09 ) * cos( 2.2399e+06 * phase + shift[ 0 ] ) * exp( - 4.5282e+09 * pow2( phase ) );\r\n            xyz /= 1.0685e-7;\r\n            let rgb:vec3<f32> = XYZ_TO_REC709 * xyz;\r\n            return rgb;\r\n        }\r\n        fn evalIridescence(outsideIOR:f32, eta2:f32,cosTheta1:f32,thinFilmThickness:f32,baseF0:vec3<f32> )->vec3<f32> {\r\n            var I:vec3<f32>;\r\n            let iridescenceIOR:f32 = mix( outsideIOR, eta2, smoothstep( 0.0, 0.03, thinFilmThickness ) );\r\n            let sinTheta2Sq:f32 = pow2( outsideIOR / iridescenceIOR ) * ( 1.0 - pow2( cosTheta1 ) );\r\n            let cosTheta2Sq:f32 = 1.0 - sinTheta2Sq;\r\n            if ( cosTheta2Sq < 0.0 ) {\r\n                return vec3<f32>( 1.0 );\r\n            }\r\n            let cosTheta2:f32 = sqrt( cosTheta2Sq );\r\n            let R0:f32 = IorToFresnel0( iridescenceIOR, outsideIOR );\r\n            let R12:f32 = F_Schlick( R0, 1.0, cosTheta1 );\r\n            let R21:f32 = R12;\r\n            let T121:f32 = 1.0 - R12;\r\n            let phi12:f32 = 0.0;\r\n            if ( iridescenceIOR < outsideIOR ) phi12 = PI;\r\n            let phi21:f32 = PI - phi12;\r\n            let baseIOR:vec3<f32> = Fresnel0ToIor( clamp( baseF0, 0.0, 0.9999 ) );\r\n            let R1:vec3<f32> = IorToFresnel0( baseIOR, iridescenceIOR );\r\n            let R23:vec3<f32> = F_Schlick( R1, 1.0, cosTheta2 );\r\n            let phi23:vec3<f32> = vec3<f32>( 0.0 );\r\n            if ( baseIOR[ 0 ] < iridescenceIOR ) phi23[ 0 ] = PI;\r\n            if ( baseIOR[ 1 ] < iridescenceIOR ) phi23[ 1 ] = PI;\r\n            if ( baseIOR[ 2 ] < iridescenceIOR ) phi23[ 2 ] = PI;\r\n            let OPD:f32 = 2.0 * iridescenceIOR * thinFilmThickness * cosTheta2;\r\n            let phi:vec3<f32> = vec3<f32>( phi21 ) + phi23;\r\n            let R123:vec3<f32> = clamp( R12 * R23, 1e-5, 0.9999 );\r\n            let r123:vec3<f32> = sqrt( R123 );\r\n            let Rs:vec3<f32> = pow2( T121 ) * R23 / ( vec3<f32>( 1.0 ) - R123 );\r\n            let C0:vec3<f32> = R12 + Rs;\r\n            I = C0;\r\n            let Cm:vec3<f32> = Rs - T121;\r\n            for ( let m : u32 = 1;m <= 2; ++ m ) {\r\n                Cm *= r123;\r\n                Sm:vec3<f32> = 2.0 * evalSensitivity( f32( m ) * OPD, f32( m ) * phi );\r\n                I += Cm * Sm;\r\n            }\r\n            return max( I, vec3<f32>( 0.0 ) );\r\n        }\r\n    #endif\r\n    const clearcoatSpecular:vec3<f32> = vec3<f32>( 0.0 );\r\n    const sheenSpecular:vec3<f32> = vec3<f32>( 0.0 );\r\n\r\n    fn IBLSheenBRDF( normal:vec3<f32>, viewDir:vec3<f32>, roughness:f32 )->f32 {\r\n        let dotNV:f32 = saturate( dot( normal, viewDir ) );\r\n        let r2:f32 = roughness * roughness;\r\n        let a:f32 =select(-8.48 * r2 + 14.3 * roughness - 9.95,-339.2 * r2 + 161.4 * roughness - 25.9,roughness < 0.25);\r\n        //let a:f32 = roughness < 0.25 ? -339.2 * r2 + 161.4 * roughness - 25.9 : -8.48 * r2 + 14.3 * roughness - 9.95;\r\n        let b:f32=select(1.97 * r2 - 3.27 * roughness + 0.72,44.0 * r2 - 23.7 * roughness + 3.26, roughness < 0.25);\r\n        //let b:f32 = roughness < 0.25 ? 44.0 * r2 - 23.7 * roughness + 3.26 : 1.97 * r2 - 3.27 * roughness + 0.72;\r\n        //let DG:f32 = exp( a * dotNV + b ) + ( roughness < 0.25 ? 0.0 : 0.1 * ( roughness - 0.25 ) );\r\n        let DG:f32 = exp( a * dotNV + b ) + select(0.1 * ( roughness - 0.25 ),0.0,roughness < 0.25);\r\n        return saturate( DG * RECIPROCAL_PI );\r\n    }\r\n    fn DFGApprox( specularColor:vec3<f32>, roughness:f32,dotNV:f32 )->vec3<f32> {\r\n        const c0:vec4<f32> = vec4<f32>( - 1, - 0.0275, - 0.572, 0.022 );\r\n        let c1:vec4<f32> = vec4<f32>( 1, 0.0425, 1.04, - 0.04 );\r\n        let r:vec4<f32> = roughness * c0 + c1;\r\n        let a004:f32 = min( r.x * r.x, exp2( - 9.28 * dotNV ) ) * r.x + r.y;\r\n        let fab:vec2<f32> = vec2<f32>( - 1.04, 1.04 ) * a004 + r.zw;\r\n        return specularColor * fab.x + fab.y;\r\n    }\r\n    fn EnvironmentBRDF( normal:vec3<f32>,viewDir:vec3<f32>,specularColor:vec3<f32>, specularF90:f32,roughness:f32 )->vec3<f32> {\r\n        let fab:vec2<f32> = DFGApprox( normal, viewDir, roughness );\r\n        return specularColor * fab.x + specularF90 * fab.y;\r\n    }\r\n\r\n\r\n    fn computeSpecularOcclusion( dotNV:f32, ambientOcclusion:f32, roughness:f32 )->f32 {\r\n        return saturate( pow( dotNV + ambientOcclusion, exp2( - 16.0 * roughness - 1.0 ) ) - 1.0 + ambientOcclusion );\r\n    }\r\n    #if ${defines.USE_TRANSMISSION}\r\n\r\n    fn getVolumeTransmissionRay( n:vec3<f32>, v:vec3<f32>, thickness:f32, ior:f32, modelMatrix:mat4x4:f32)->vec3<f32> {\r\n        var refractionVector:vec3<f32> = refract( - v, normalize( n ), 1.0 / ior );\r\n        var modelScale:vec3<f32>;\r\n        modelScale.x = length( vec3<f32>( modelMatrix[0].xyz ) );\r\n        modelScale.y = length( vec3<f32>( modelMatrix[1].xyz ) );\r\n        modelScale.z = length( vec3<f32>( modelMatrix[2].xyz ) );\r\n        return normalize( refractionVector ) * thickness * modelScale;\r\n    }\r\n    fn applyIorToRoughness(roughness:f32, ior:f32 )->f32 {\r\n        return roughness * clamp( ior * 2.0 - 2.0, 0.0, 1.0 );\r\n    }\r\n    fn getTransmissionSample( fragCoord:vec2<f32>, roughness:f32,ior:f32 )->vec4<f32> {\r\n        let framebufferLod:f32 = log2( materialUniform.transmissionSamplerSize.x ) * applyIorToRoughness( roughness, ior );\r\n        return textureSampleLevel(transmissionSamplerTexture,baseSampler,fragCoord.xy, framebufferLod);\r\n\r\n    }\r\n    fn applyVolumeAttenuation( radiance:vec3<vec3>, transmissionDistance:f32,attenuationColor:vec3<f32>,attenuationDistance:f32 )->vec3<f32> {\r\n        if ( isinf( attenuationDistance ) ) {\r\n            return radiance;\r\n        }\r\n        else {\r\n            let attenuationCoefficient:vec3<f32> = -log( attenuationColor ) / attenuationDistance;\r\n            let transmittance:vec3<f32> = exp( - attenuationCoefficient * transmissionDistance );\r\n            return transmittance * radiance;\r\n        }\r\n    \r\n    }\r\n    fn getIBLVolumeRefraction( n:vec3<f32>,v:vec3<f32>, roughness:f32, diffuseColor:vec3<f32>,specularColor:vec3<f32>, specularF90:f32,position:vec3<f32>, modelMatrix:mat4x4<f32>, viewMatrix:mat4x4<f32>,projMatrix:mat4x4<f32>,ior:f32, thickness:f32,attenuationColor:vec3<f32>,attenuationDistance:f32 )->vec4<f32> {\r\n        let transmissionRay:vec3<f32> = getVolumeTransmissionRay( n, v, thickness, ior, modelMatrix );\r\n        let refractedRayExit:vec3<f32> = position + transmissionRay;\r\n        let ndcPos:vec4<f32> = projMatrix * viewMatrix * vec4( refractedRayExit, 1.0 );\r\n        let refractionCoords:vec2<f32> = ndcPos.xy / ndcPos.w;\r\n        refractionCoords += 1.0;\r\n        refractionCoords /= 2.0;\r\n        let transmittedLight:vec4<f32> = getTransmissionSample( refractionCoords, roughness, ior );\r\n        let attenuatedColor:vec3<f32> = applyVolumeAttenuation( transmittedLight.rgb, length( transmissionRay ), attenuationColor, attenuationDistance );\r\n        let F:vec3<f32> = EnvironmentBRDF( n, v, specularColor, specularF90, roughness );\r\n        return vec4<f32>( ( 1.0 - F ) * attenuatedColor * diffuseColor, transmittedLight.a );\r\n    }\r\n    #endif\r\n\r\n    #if ${defines.USE_BUMPTEXTURE}\r\n        fn dHdxy_fwd()->vec2<f32> {\r\n            let dSTdx:vec2<f32> = dpdx( vUv );\r\n            let dSTdy:vec2<f32> = dpdy( vUv );\r\n\r\n            let Hll:f32 = materialUniform.bumpScale * textureSample(bumpTexture, baseSampler, vUv).x;\r\n            let dBx:f32 = materialUniform.bumpScale * textureSample(bumpTexture, baseSampler, vUv + dSTdx).x - Hll;\r\n            let dBy:f32 = materialUniform.bumpScale * textureSample(bumpTexture, baseSampler, vUv + dSTdy).x - Hll;\r\n            return vec2<f32>( dBx, dBy );\r\n        }\r\n        fn perturbNormalArb( surf_pos:vec3<f32>, surf_norm:vec3<f32>, dHdxy:vec2<f32>, faceDirection:f32 )->vec3<f32> {\r\n            let vSigmaX:vec3<f32> = dpdx( surf_pos.xyz );\r\n            let vSigmaY:vec3<f32> = dpdy( surf_pos.xyz );\r\n            let vN:vec3<f32> = surf_norm;\r\n            let R1:vec3<f32> = cross( vSigmaY, vN );\r\n            let R2:vec3<f32> = cross( vN, vSigmaX );\r\n            let fDet:f32 = dot( vSigmaX, R1 ) * faceDirection;\r\n            let vGrad:vec3<f32> = sign( fDet ) * ( dHdxy.x * R1 + dHdxy.y * R2 );\r\n            return normalize( abs( fDet ) * surf_norm - vGrad );\r\n        }\r\n    #endif\r\n\r\n    //! defined ( USE_TANGENT ) && ( defined ( TANGENTSPACE_NORMALTEXTURE ) || defined ( USE_CLEARCOAT_NORMALTEXTURE ) )\r\n    #if ${(!defines.USE_TANGENT && defines.TANGENTSPACE_NORMALTEXTURE) || defines.USE_CLEARCOAT_NORMALTEXTURE}\r\n    fn perturbNormal2Arb( eye_pos:vec3<f32>, surf_norm:vec3<f32>, textureN:vec3<f32>, faceDirection:f32 )->vec3<f32> {\r\n        let q0:vec3<f32> = dpdx( eye_pos.xyz );\r\n        let q1:vec3<f32> = dpdy( eye_pos.xyz );\r\n        let st0:vec2<f32> = dpdx( vUv.st );\r\n        let st1:vec2<f32> = dpdy( vUv.st );\r\n        let N:vec3<f32> = surf_norm;\r\n        let q1perp:vec3<f32> = cross( q1, N );\r\n        let q0perp:vec3<f32> = cross( N, q0 );\r\n        let T:vec3<f32> = q1perp * st0.x + q0perp * st1.x;\r\n        let B:vec3<f32> = q1perp * st0.y + q0perp * st1.y;\r\n        let det:f32 = max( dot( T, T ), dot( B, B ) );\r\n        let scale:f32 = ( det == 0.0 ) ? 0.0 : faceDirection * inversesqrt( det );\r\n        return normalize( T * ( textureN.x * scale ) + B * ( textureN.y * scale ) + N * textureN.z );\r\n    }\r\n    #endif\r\n    struct MultiAndSingleScatter{\r\n        multiScatter:vec3<f32>,\r\n        singleScatter:vec3<f32>\r\n    }\r\n   #if ${defines.USE_IRIDESCENCE}\r\n   ////////inout vec3 singleScatter, inout vec3 multiScatter\r\n       fn computeMultiscatteringIridescence( normal:vec3<f32>, viewDir:vec3<f32>, specularColor:vec3<f32>, specularF90:f32, iridescence:f32,iridescenceF0:vec3<f32>, roughness:f32 )->MultiAndSingleScatter {\r\n   #else\r\n   ////////inout vec3 singleScatter, inout vec3 multiScatter\r\n       fn computeMultiscattering( normal:vec3<f32>,viewDir:vec3<f32>, specularColor:vec3<f32>, specularF90:f32, roughness:f32)->MultiAndSingleScatter {\r\n   #endif\r\n   let fab:vec2<f32> = DFGApprox( normal, viewDir, roughness );\r\n\r\n   var multiAndSingleScatter:MultiAndSingleScatter;\r\n\r\n   #if ${defines.USE_IRIDESCENCE}\r\n       let Fr:vec3<f32> = mix( specularColor, iridescenceF0, iridescence );\r\n   #else\r\n       let Fr:vec3<f32> = specularColor;\r\n   #endif\r\n       let FssEss:vec3<f32> = Fr * fab.x + specularF90 * fab.y;\r\n       let Ess:f32 = fab.x + fab.y;\r\n       let Ems:f32 = 1.0 - Ess;\r\n       let Favg:vec3<f32> = Fr + ( 1.0 - Fr ) * 0.047619;\r\n       let Fms:vec3<f32> = FssEss * Favg / ( 1.0 - Ems * Favg );\r\n    //    singleScatter += FssEss;\r\n    //    multiScatter += Fms * Ems;\r\n       multiAndSingleScatter.multiScatter=Fms * Ems;\r\n       multiAndSingleScatter.singleScatter=FssEss;\r\n       return multiAndSingleScatter;\r\n   }\r\n   //直接光照\r\n   fn RE_Direct_Physical( directLight:IncidentLight, geometry:GeometricContext,  material:PhysicalMaterial)->ReflectedLight {\r\n       var reflectedLight:ReflectedLight;\r\n       let dotNL:f32 = saturate(dot( geometry.normal, directLight.direction));\r\n       let irradiance:vec3<f32> = dotNL * directLight.color;\r\n       #if ${defines.USE_CLEARCOAT}\r\n           let dotNLcc:f32 = saturate( dot( geometry.clearcoatNormal, directLight.direction ) );\r\n           let ccIrradiance:vec3<f32> = dotNLcc * directLight.color;\r\n           clearcoatSpecular += ccIrradiance * BRDF_GGX( directLight.direction, geometry.viewDir, geometry.clearcoatNormal, material.clearcoatF0, material.clearcoatF90, material.clearcoatRoughness );\r\n       #endif\r\n\r\n       #if ${defines.USE_SHEEN}\r\n           sheenSpecular += irradiance * BRDF_Sheen( directLight.direction, geometry.viewDir, geometry.normal, material.sheenColor, material.sheenRoughness );\r\n       #endif\r\n\r\n       #if ${defines.USE_IRIDESCENCE}\r\n           reflectedLight.directSpecular = irradiance * BRDF_GGX_Iridescence( directLight.direction, geometry.viewDir, geometry.normal, material.specularColor, material.specularF90, material.iridescence, material.iridescenceFresnel, material.roughness );\r\n       #else\r\n           reflectedLight.directSpecular = irradiance * BRDF_GGX( directLight.direction, geometry.viewDir, geometry.normal, material.specularColor, material.specularF90, material.roughness );\r\n       #endif\r\n       reflectedLight.directDiffuse = irradiance * BRDF_Lambert( material.diffuseColor );\r\n       return reflectedLight;\r\n   }\r\n   //间接光照\r\n   fn RE_IndirectDiffuse_Physical( irradiance:vec3<f32>, geometry:GeometricContext, material:PhysicalMaterial )->ReflectedLight {\r\n       var reflectedLight:ReflectedLight;\r\n       reflectedLight.indirectDiffuse = irradiance * BRDF_Lambert( material.diffuseColor );\r\n       return reflectedLight;\r\n   }\r\n   //间接高光\r\n   fn RE_IndirectSpecular_Physical( radiance:vec3<f32>, irradiance:vec3<f32>, clearcoatRadiance:vec3<f32>, geometry:GeometricContext, material:PhysicalMaterial)->ReflectedLight {\r\n       var reflectedLight:ReflectedLight;\r\n       #if ${defines.USE_CLEARCOAT}\r\n           clearcoatSpecular += clearcoatRadiance * EnvironmentBRDF( geometry.clearcoatNormal, geometry.viewDir, material.clearcoatF0, material.clearcoatF90, material.clearcoatRoughness );\r\n       #endif\r\n       #if ${defines.USE_SHEEN}\r\n           sheenSpecular += irradiance * material.sheenColor * IBLSheenBRDF( geometry.normal, geometry.viewDir, material.sheenRoughness );\r\n       #endif\r\n       var singleScattering:vec3<f32>;\r\n       var multiScattering:vec3<f32>;\r\n       let cosineWeightedIrradiance:vec3<f32> = irradiance * RECIPROCAL_PI;\r\n       var tempMultiAndSingleScatter:MultiAndSingleScatter;\r\n       #if ${defines.USE_IRIDESCENCE}\r\n             tempMultiAndSingleScatter=computeMultiscatteringIridescence( geometry.normal, geometry.viewDir, material.specularColor, material.specularF90, material.iridescence, material.iridescenceFresnel, material.roughness );\r\n       #else\r\n            tempMultiAndSingleScatter= computeMultiscattering( geometry.normal, geometry.viewDir, material.specularColor, material.specularF90, material.roughness );\r\n       #endif\r\n       singleScattering=tempMultiAndSingleScatter.singleScatter; \r\n       multiScattering=tempMultiAndSingleScatter.multiScatter;\r\n       let totalScattering:vec3<f32> = singleScattering + multiScattering;\r\n       let diffuse:vec3<f32> = material.diffuseColor * ( 1.0 - max( max( totalScattering.r, totalScattering.g ), totalScattering.b ) );\r\n       reflectedLight.indirectSpecular = radiance * singleScattering;\r\n       reflectedLight.indirectSpecular = multiScattering * cosineWeightedIrradiance;\r\n       reflectedLight.indirectDiffuse = diffuse * cosineWeightedIrradiance;\r\n       return reflectedLight;\r\n   }\r\n   `;\r\n}\r\n","import { wgslParseDefines } from \"../../WgslPreprocessor\";\r\n\r\nexport default function pbrStruct(defines) {\r\n  return wgslParseDefines`\r\n        struct MaterialUniform{\r\n\r\n            modelMatrix: mat4x4<f32>,\r\n    \r\n            diffuse:vec3<f32>,\r\n    \r\n            opacity:f32,\r\n    \r\n            normalMatrix: mat3x3<f32>,\r\n    \r\n            emissive:vec3<f32>,\r\n    \r\n            roughness:f32,\r\n    \r\n            metalness:f32,\r\n    \r\n            #if ${defines.TONE_MAPPING}\r\n                toneMappingExposure:f32,\r\n            #endif\r\n           \r\n            #if ${defines.SPECULAR}\r\n    \r\n                 specularColor:vec3<f32>,\r\n    \r\n                 specularIntensity:f32,\r\n            #endif\r\n            \r\n            #if ${defines.USE_SHEEN}\r\n    \r\n                sheenColor:vec3<f32>,\r\n    \r\n                sheenRoughness:f32,\r\n            #endif\r\n\r\n            #if ${defines.USE_TRANSMISSION}\r\n    \r\n                attenuationColor:vec3<f32>,\r\n    \r\n                transmission:f32,\r\n    \r\n                transmissionSamplerSize:vec2<f32>,\r\n    \r\n                thickness:f32,\r\n    \r\n                attenuationDistance:f32,\r\n                \r\n            #endif\r\n\r\n            #if ${defines.USE_SKINNING}\r\n    \r\n                bindMatrix:mat4x4<f32>,\r\n    \r\n                bindMatrixInverse:mat4x4<f32>,\r\n    \r\n                boneTextureSize:u32,\r\n            #endif\r\n\r\n            #if ${defines.USE_NORMALTEXTURE}\r\n                 normalScale:vec2<f32>,\r\n            #endif\r\n    \r\n            #if ${defines.IOR}\r\n                ior:f32,\r\n            #endif\r\n    \r\n            #if ${defines.USE_CLEARCOAT}\r\n    \r\n                #if ${defines.USE_CLEARCOAT_NORMALTEXTURE}\r\n                    clearcoatNormalScale:vec2<f32>,\r\n                #endif\r\n    \r\n                 clearcoat:f32,\r\n    \r\n                 clearcoatRoughness:f32,\r\n            #endif\r\n    \r\n            #if ${defines.USE_IRIDESCENCE}\r\n                iridescence:f32,\r\n    \r\n                iridescenceIOR:f32,\r\n    \r\n                iridescenceThicknessMinimum:f32,\r\n    \r\n                iridescenceThicknessMaximum:f32,\r\n    \r\n            #endif\r\n\r\n            #if ${defines.USE_AOTEXTURE}\r\n                 aoTextureIntensity:f32,\r\n            #endif\r\n\r\n            #if ${defines.USE_LIGHTTEXTURE}\r\n                 lightTextureIntensity:f32,\r\n            #endif\r\n    \r\n            #if ${defines.USE_ENVTEXTURE}\r\n                envTextureIntensity:f32,\r\n    \r\n                flipEnvTexture:f32,\r\n            #endif\r\n\r\n            #if ${defines.USE_BUMPTEXTURE}\r\n                bumpScale:f32;\r\n            #endif\r\n\r\n            #if ${defines.USE_DISPLACEMENTTEXTURE}\r\n    \r\n                displacementScale:f32,\r\n    \r\n                displacementBias:f32,\r\n            #endif\r\n            \r\n            #if ${defines.USE_MORPHTARGETS}\r\n    \r\n                morphTargetBaseInfluence:f32,\r\n    \r\n                #if ${defines.MORPHTARGETS_TEXTURE} \r\n    \r\n                    morphTargetsTextureSize:vec2<u32>,\r\n    \r\n                    MORPHTARGETS_COUNT:u32,\r\n    \r\n                #endif\r\n    \r\n                morphTargetInfluences:array<f32>,\r\n                    \r\n            #endif\r\n        }\r\n\r\n   `;\r\n}\r\n","import { wgslParseDefines } from \"../../WgslPreprocessor\";\r\n\r\nexport default function pbrTexture(defines) {\r\n  return wgslParseDefines`        \r\n            #if ${defines.USE_BUMPTEXTURE}\r\n                @group(0) @binding(${defines.bumpTextureBinding}) var bumpTexture: texture_2d<f32>;\r\n            #endif\r\n            #if ${defines.USE_TRANSMISSION}\r\n                #if ${defines.USE_TRANSMISSIONTEXTURE}\r\n                    @group(0) @binding(${defines.transmissionTextureBinding}) var transmissionTexture: texture_2d<f32>;\r\n                #endif\r\n                #if ${defines.USE_THICKNESSTEXTURE}\r\n                    @group(0) @binding(${defines.thicknessTextureBinding}) var thicknessTexture: texture_2d<f32>;\r\n                #endif\r\n                @group(0) @binding(${defines.transmissionSamplerTextureBinding}) var transmissionSamplerTexture: texture_2d<f32>;\r\n            #endif\r\n            #if ${defines.USE_ENVTEXTURE}\r\n                @group(0) @binding(${defines.envTextureBinding}) var envTexture: texture_cube<f32>;\r\n            #endif\r\n            #if ${defines.USE_NORMALTEXTURE}\r\n                @group(0) @binding(${defines.normalTextureBinding}) var normalTexture: texture_2d<f32>;\r\n            #endif\r\n            \r\n            #if ${defines.USE_CLEARCOATTEXTURE}\r\n                @group(0) @binding(${defines.clearcoatTextureBinding}) var clearcoatTexture: texture_2d<f32>;\r\n            #endif\r\n            \r\n            #if ${defines.USE_CLEARCOAT_ROUGHNESSTEXTURE}\r\n                @group(0) @binding(${defines.clearcoatRclearcoatRoughnessTextureBinding}) var clearcoatRoughnessTexture: texture_2d<f32>;\r\n            #endif\r\n            \r\n            #if ${defines.USE_CLEARCOAT_NORMALTEXTURE}\r\n                @group(0) @binding(${defines.clearcoatNormalTextureBinding}) var clearcoatNormalTexture: texture_2d<f32>;\r\n            #endif\r\n            \r\n            #if ${defines.USE_IRIDESCENCETEXTURE}\r\n                @group(0) @binding(${defines.iridescenceTextureBinding}) var iridescenceTexture: texture_2d<f32>;\r\n            #endif\r\n            \r\n            #if ${defines.USE_IRIDESCENCE_THICKNESSTEXTURE}\r\n                @group(0) @binding(${defines.iridescenceThicknessTextureBinding}) var iridescenceThicknessTexture: texture_2d<f32>;\r\n            #endif\r\n            \r\n            #if ${defines.USE_ROUGHNESSTEXTURE}\r\n                @group(0) @binding(${defines.roughnessTextureBinding}) var roughnessTexture: texture_2d<f32>;\r\n            #endif\r\n            \r\n            #if ${defines.USE_METALNESSTEXTURE}\r\n                @group(0) @binding(${defines.metalnessTextureBinding}) var metalnessTexture: texture_2d<f32>;\r\n            #endif\r\n\r\n            #if ${defines.SPECULAR}\r\n                #if ${defines.USE_SPECULARINTENSITYTEXTURE}\r\n                    @group(0) @binding(${defines.specularIntensityTextureBinding}) var specularIntensityTexture: texture_2d<f32>;\r\n                #endif\r\n\r\n                #if ${defines.USE_SPECULARCOLORTEXTURE}\r\n                    @group(0) @binding(${defines.specularColorTextureBinding}) var specularColorTexture: texture_2d<f32>;\r\n                #endif\r\n            #endif\r\n\r\n            #if ${defines.USE_SHEEN}\r\n                #if ${defines.USE_SHEENCOLORTEXTURE}\r\n                    @group(0) @binding(${defines.sheenColorTextureBinding}) var sheenColorTexture: texture_2d<f32>;\r\n                #endif\r\n                #if ${defines.USE_SHEENROUGHNESSTEXTURE}\r\n                    @group(0) @binding(${defines.sheenRoughnessTextureBinding}) var sheenRoughnessTexture: texture_2d<f32>;\r\n                #endif\r\n            #endif\r\n\r\n            #if ${defines.USE_TEXTURE}\r\n                @group(0) @binding(${defines.baseSamplerBinding}) var baseSampler: sampler;\r\n                @group(0) @binding(${defines.baseTextureBinding}) var baseTexture: texture_2d<f32>;\r\n            #endif\r\n\r\n            #if ${defines.USE_ALPHATEXTURE}\r\n                @group(0) @binding(${defines.alphaTextureBinding}) var alphaTexture: texture_2d<f32>;\r\n            #endif\r\n\r\n            #if ${defines.USE_AOTEXTURE}\r\n                @group(0) @binding(${defines.aoTextureBinding}) var aoTexture: texture_2d<f32>;\r\n                \r\n            #endif\r\n            #if ${defines.USE_LIGHTTEXTURE}\r\n                @group(0) @binding(${defines.lightTextureBinding}) var lightTexture: texture_2d<f32>;\r\n            #endif\r\n\r\n            #if ${defines.USE_EMISSIVETEXTURE}\r\n                @group(0) @binding(${defines.emissiveTextureBinding}) var emissiveTexture: texture_2d<f32>;\r\n            #endif\r\n     `;\r\n}\r\n","import { wgslParseDefines } from \"../../WgslPreprocessor\";\r\n\r\nexport default function pbrUtils(defines) {\r\n  return wgslParseDefines`\r\n    const PI:f32= 3.141592653589793;\r\n    const PI2:f32= 6.283185307179586;\r\n    const PI_HALF:f32= 1.5707963267948966;\r\n    const RECIPROCAL_PI:f32= 0.3183098861837907;\r\n    const RECIPROCAL_PI2:f32= 0.15915494309189535;\r\n    const EPSILON:f32= 1e-6;\r\n\r\n    fn pow2(x:f32 )->f32 {\r\n        return x*x;\r\n    }\r\n    fn pow2Vector(x:vec3<f32> )->vec3<f32> {\r\n        return x*x;\r\n    }\r\n    fn pow3( x:f32 )->f32 {\r\n        return x*x*x;\r\n    }\r\n    fn pow4( x:f32 )->f32 {\r\n        let x2:f32 = x*x;\r\n        return x2*x2;\r\n    }\r\n    fn max3( v:vec3<f32> )->f32 {\r\n        return max( max( v.x, v.y ), v.z );\r\n    }\r\n    fn average(v:vec3<f32> )->f32 {\r\n        return dot( v, vec3<f32>( 0.3333333 ) );\r\n    }\r\n    fn rand( uv:vec2<f32> )->f32 {\r\n        let a:f32 = 12.9898;\r\n        let b:f32 = 78.233;\r\n        let c:f32 = 43758.5453;\r\n        let dt:f32 = dot( uv.xy, vec2<f32>( a, b ) );\r\n        let sn:f32 = dt % PI;\r\n        return fract( sin( sn ) * c );\r\n    }\r\n    fn transformDirection( dir:vec3<f32>, matrix:mat4x4<f32> )->vec3<f32> {\r\n        return normalize( ( matrix * vec4<f32>( dir, 0.0 ) ).xyz );\r\n    }\r\n\r\n    fn transposeMat3( m:mat3x3<f32> )->mat3x3<f32> {\r\n        var tmp:mat3x3<f32>;\r\n        tmp[ 0 ] = vec3<f32>( m[ 0 ].x, m[ 1 ].x, m[ 2 ].x );\r\n        tmp[ 1 ] = vec3<f32>( m[ 0 ].y, m[ 1 ].y, m[ 2 ].y );\r\n        tmp[ 2 ] = vec3<f32>( m[ 0 ].z, m[ 1 ].z, m[ 2 ].z );\r\n        return tmp;\r\n    }\r\n    fn luminance( rgb:vec3<f32> )->f32 {\r\n        let weights:vec3<f32> = vec3<f32>(0.2126729, 0.7151522, 0.0721750 );\r\n        return dot( weights, rgb );\r\n    }\r\n    fn LinearToneMapping( color:vec3<f32>,toneMappingExposure:f32  )->vec3<f32> {\r\n        return toneMappingExposure * color;\r\n    }\r\n\r\n    fn ReinhardToneMapping( color:vec3<f32>,toneMappingExposure:f32 )->vec3<f32> {\r\n        var tempColor:vec3<f32>;\r\n        tempColor=color;\r\n        tempColor *= toneMappingExposure;\r\n        return saturate( tempColor / ( vec3<f32>( 1.0 ) + tempColor ) );\r\n    }\r\n    fn CustomToneMapping( color:vec3<f32> )->vec3<f32> {\r\n        return color;\r\n    }\r\n    fn toneMapping( color:vec3<f32>,toneMappingExposure:f32  )->vec3<f32> {\r\n        return ReinhardToneMapping( color,toneMappingExposure );\r\n    }\r\n\r\n    fn LinearToLinear( value:vec4<f32> )->vec4<f32> {\r\n        return value;\r\n    }\r\n    fn lessThanEqual(a:vec3<f32>,b:vec3<f32>)->vec3<f32>{\r\n       let xValue:f32=select(b.x,a.x,a.x<=b.x);\r\n       let yValue:f32=select(b.y,a.y,a.y<=b.y);\r\n       let zValue:f32=select(b.z,a.z,a.z<=b.z);\r\n       return vec3<f32>(xValue,yValue,zValue);    \r\n    }\r\n    fn LinearTosRGB( value:vec4<f32> )->vec4<f32> {\r\n        return vec4<f32>( mix( pow( value.rgb, vec3<f32>( 0.41666 ) ) * 1.055 - vec3<f32>( 0.055 ), value.rgb * 12.92, vec3<f32>( lessThanEqual( value.rgb, vec3<f32>( 0.0031308 ) ) ) ), value.a );\r\n    }\r\n    fn linearToOutputTexel(value:vec4<f32> )->vec4<f32> {\r\n        return LinearTosRGB( value );\r\n    }\r\n    `;\r\n}\r\n","export default function blinn_phong(defines) {\r\n\treturn `\r\n       fn getPointLightInfo(pointLight:PointLight,worldPos:vec3<f32>,shininess:f32,N:vec3<f32>,V:vec3<f32>)->vec3<f32>{\r\n        var color=vec3<f32>(0.0,0.0,0.0);\r\n        var direction:vec3<f32> = worldPos - pointLight.position;\r\n        let dist:f32 = length( direction );\r\n        direction = normalize(direction);\r\n        let decay = clamp(1.0 - pow(dist / pointLight.distance, 4.0), 0.0, 1.0);\r\n\r\n        let d =  max( dot( N, -direction ), 0.0 ) * decay;\r\n        color += pointLight.color * d;\r\n\r\n        let halfDir:vec3<f32> = normalize( V - direction );\r\n        let s:f32 = pow( clamp( dot( N, halfDir ), 0.0, 1.0 ), shininess )  * decay;\r\n        color += pointLight.color * s;\r\n        return color;\r\n       }\r\n       fn getSpotLightInfo(spotLight:SpotLight,worldPos:vec3<f32>,shininess:f32,N:vec3<f32>,V:vec3<f32>)->vec3<f32>{\r\n        var color=vec3<f32>(0.0,0.0,0.0);\r\n            var direction:vec3<f32> = spotLight.position - worldPos;\r\n            let lightDistance:f32 = length(direction);\r\n            direction = normalize(direction);\r\n            let angleCos:f32 = dot( direction, -spotLight.direction );\r\n            let decay:f32 = clamp(1.0 - pow(lightDistance/spotLight.distance, 4.0), 0.0, 1.0);\r\n            let spotEffect:f32 = smoothstep( spotLight.penumbraCos, spotLight.coneCos, angleCos );\r\n            let decayTotal:f32 = decay * spotEffect;\r\n            let d:f32 = max( dot( N, direction ), 0.0 )  * decayTotal;\r\n            color += spotLight.color * d;\r\n            let halfDir:vec3<f32> = normalize( V + direction );\r\n            let s:f32 = pow( clamp( dot( N, halfDir ), 0.0, 1.0 ), shininess ) * decayTotal;\r\n            color += spotLight.color * s;\r\n            return color;\r\n       }\r\n    struct DirectionalLight {\r\n        direction: vec3<f32>,\r\n        color: vec3<f32>,\r\n    };\r\n      fn getDirectLightInfo(directionalLight:DirectionalLight,shininess:f32,N:vec3<f32>,V:vec3<f32>)->vec3<f32>{\r\n        var color=vec3<f32>(0.0,0.0,0.0);\r\n        let d:f32 = max(dot(N, -directionalLight.direction), 0.0);\r\n        color += directionalLight.color * d;\r\n\r\n        let halfDir:vec3<f32> = normalize( V - directionalLight.direction );\r\n        let s:f32 = pow( clamp( dot( N, halfDir ), 0.0, 1.0 ), shininess );\r\n        color += directionalLight.color * s;\r\n        return color;\r\n       }\r\n    `;\r\n}\r\n","export default function phongFunction(defines) {\r\n  return `\r\n    fn G_BlinnPhong_Implicit( )->f32 {\r\n\r\n        // geometry term is (n dot l)(n dot v) / 4(n dot l)(n dot v)\r\n        return 0.25;\r\n\r\n    }\r\n    fn D_BlinnPhong( shininess:f32, dotNH:f32 )->f32 {\r\n\r\n        return RECIPROCAL_PI * ( shininess * 0.5 + 1.0 ) * pow(dotNH, shininess);\r\n\r\n    }\r\n    fn BRDF_BlinnPhong( lightDir:vec3<f32>, viewDir:vec3<f32>, normal:vec3<f32>, specularColor:vec3<f32>, shininess:f32 )->vec3<f32> {\r\n\r\n        let  halfDir = normalize( lightDir + viewDir );\r\n\r\n        let  dotNH:f32 = saturate( dot( normal, halfDir ) );\r\n        let dotVH:f32 = saturate( dot( viewDir, halfDir ) );\r\n\r\n        let F = F_Schlick( specularColor, 1.0, dotVH );\r\n\r\n        let G:f32 = G_BlinnPhong_Implicit( );\r\n\r\n        let D = D_BlinnPhong( shininess, dotNH );\r\n\r\n        return F * ( G * D );\r\n\r\n    } \r\n    fn RE_Direct_BlinnPhong(  directLight:IncidentLight,geometry:GeometricContext, material:BlinnPhongMaterial )->ReflectedLight{\r\n        var reflectedLight:ReflectedLight; \r\n        let dotNL:f32 = saturate(dot(geometry.normal, directLight.direction));\r\n        let irradiance:vec3<f32> = dotNL*directLight.color;\r\n\r\n        reflectedLight.directDiffuse= irradiance * BRDF_Lambert( material.diffuseColor );\r\n\r\n        reflectedLight.directSpecular= irradiance * BRDF_BlinnPhong( directLight.direction, geometry.viewDir, geometry.normal, material.specularColor, material.specularShininess ) * material.specularStrength;\r\n        return reflectedLight;\r\n    }\r\n    fn RE_IndirectDiffuse_BlinnPhong( irradiance:vec3<f32>, geometry:GeometricContext, material:BlinnPhongMaterial)->ReflectedLight {\r\n        var reflectedLight:ReflectedLight; \r\n        reflectedLight.indirectDiffuse += irradiance * BRDF_Lambert( material.diffuseColor );\r\n        return reflectedLight;\r\n    }\r\n    `;\r\n}\r\n","export default function phongUtils(defines) {\r\n  return `\r\n   struct BlinnPhongMaterial {\r\n        diffuseColor:vec3<f32>,\r\n        specularColor:vec3<f32>,\r\n        specularShininess:f32,\r\n        specularStrength:f32,\r\n    };\r\n    const RECIPROCAL_PI:f32= 0.3183098861837907;\r\n   fn pow2( x:f32 )->f32 { return x*x; }\r\n   fn pow3( x:f32 )->f32 { return x*x*x; }\r\n   fn pow4(x:f32 )->f32 { let x2 = x*x; return x2*x2; }\r\n   fn max3( v:vec3<f32> )->f32 { return max( max( v.x, v.y ), v.z ); }\r\n   fn average(v:vec3<f32> )->f32 { \r\n       let result=vec3<f32>( 0.3333333,  0.3333333, 0.3333333);\r\n       return dot( v,result ); \r\n   }\r\n   `;\r\n}\r\n","import { wgslParseDefines } from \"../../WgslPreprocessor\";\n\nexport function getSkinMatrix(defines) {\n\treturn wgslParseDefines`\n   #if ${defines.HAS_SKIN} \n        struct JointsUniform{\n             matrixs:array<mat4x4f>,\n        }\n        struct InverseBindMatricesUniform{\n            matrixs:array<mat4x4f>,\n        }\n        @binding(${defines.skinJointsBufferBinding}) @group(0) var<storage, read> jointsUniform : JointsUniform;\n        @binding(${defines.invsBufferBinding}) @group(0) var<storage, read> inverseBindMatricesUniform : InverseBindMatricesUniform;\n        fn getSkinMatrix(joints: vec4f, weights: vec4f) -> mat4x4<f32> {\n            let joint0 = jointsUniform.matrixs[u32(joints.x)] * inverseBindMatricesUniform.matrixs[u32(joints.x)];\n            let joint1 = jointsUniform.matrixs[u32(joints.y)] * inverseBindMatricesUniform.matrixs[u32(joints.y)];\n            let joint2 = jointsUniform.matrixs[u32(joints.z)] * inverseBindMatricesUniform.matrixs[u32(joints.z)];\n            let joint3 = jointsUniform.matrixs[u32(joints.w)] * inverseBindMatricesUniform.matrixs[u32(joints.w)];\n        \n            let skinMatrix = joint0 * weights.x +\n                            joint1 * weights.y +\n                            joint2 * weights.z +\n                            joint3 * weights.w;\n            return skinMatrix;\n        }\n        #endif\n   `;\n}\nexport function skinVertHeader(defines) {\n\treturn wgslParseDefines`\n   #if ${defines.HAS_SKIN} \n        struct JointsUniform{\n             matrixs:array<mat4x4f>,\n        }\n        struct InverseBindMatricesUniform{\n            matrixs:array<mat4x4f>,\n        }\n        @binding(${defines.skinJointsBufferBinding}) @group(0) var<storage, read> jointsUniform : JointsUniform;\n        @binding(${defines.invsBufferBinding}) @group(0) var<storage, read> inverseBindMatricesUniform : InverseBindMatricesUniform;\n        fn getSkinMatrix(joints: vec4f, weights: vec4f) -> mat4x4<f32> {\n            let joint0 = jointsUniform.matrixs[u32(joints.x)] * inverseBindMatricesUniform.matrixs[u32(joints.x)];\n            let joint1 = jointsUniform.matrixs[u32(joints.y)] * inverseBindMatricesUniform.matrixs[u32(joints.y)];\n            let joint2 = jointsUniform.matrixs[u32(joints.z)] * inverseBindMatricesUniform.matrixs[u32(joints.z)];\n            let joint3 = jointsUniform.matrixs[u32(joints.w)] * inverseBindMatricesUniform.matrixs[u32(joints.w)];\n        \n            let skinMatrix = joint0 * weights.x +\n                            joint1 * weights.y +\n                            joint2 * weights.z +\n                            joint3 * weights.w;\n            return skinMatrix;\n        }\n        #endif\n   `;\n}\nexport function skinVertMain(defines) {\n\treturn wgslParseDefines`\n        #if ${defines.HAS_SKIN}\n            modelMatrix =getSkinMatrix(input.joint0,input.weight0);\n            vNormalView = normalize((materialUniform.normalMatrix * modelMatrix * vec4<f32>(input.normal, 0.0)).xyz);\n        #endif\n  `;\n}\n","import { wgslParseDefines } from \"../../WgslPreprocessor\";\n\nexport function PbrMaterialStruct(defines) {\n\treturn wgslParseDefines`\n    struct MaterialUniform {\n          modelMatrix: mat4x4<f32>,\n          color: vec3<f32>,\n          opacity:f32,\n          normalMatrix: mat4x4<f32>,\n          emissive:vec3<f32>,\n          metallic:f32,\n          roughness:f32,\n          #if ${defines.USE_NORMALTEXTURE}\n              normalTextureScale:vec2<f32>,\n          #endif\n          #if ${defines.USE_AOTEXTURE}\n              occlusionStrength:f32,\n          #endif\n      }\n   `;\n}\n","import { FragInput } from \"./attribute/FragInput\";\nimport { VertexInput } from \"./attribute/VertexInput\";\nimport { VertexOutput } from \"./attribute/VertexOutput\";\nimport { SystemUniform } from \"./common/SystemUniform\";\nimport environment from \"./environment/environment\";\nimport { instanceVertHeader, instanceVertMain } from \"./instance/Instance\";\nimport light from \"./light/light\";\nimport lightCommon from \"./light/lightCommon\";\nimport { getNormalByNormalTexture, getTBN, getNormal } from \"./normal/getNormalBackUp\";\nimport brdf from \"./pbr/brdf\";\nimport ibl from \"./pbr/ibl\";\nimport pbrFunction from \"./pbr/pbrFunction\";\nimport pbrStruct from \"./pbr/pbrStruct\";\nimport pbrTexture from \"./pbr/pbrTexture\";\nimport pbrUtils from \"./pbr/pbrUtils\";\nimport blinn_phong from \"./phong/blinn_phong\";\nimport phongFunction from \"./phong/phongFunction\";\nimport phongUtils from \"./phong/phongUtils\";\n// import getNormal from \"./normal/getNormal\";\nimport { skinVertHeader, skinVertMain } from \"./skin/SkinVert\";\nimport { PbrMaterialStruct } from \"./struct/PbrMaterialStruct\";\nconst ShaderChunk = {\n\tlight: light,\n\tbrdf: brdf,\n\tphongFunction: phongFunction,\n\tphongUtils: phongUtils,\n\tlightCommon: lightCommon,\n\tpbrStruct: pbrStruct,\n\tpbrFunction: pbrFunction,\n\tpbrTexture: pbrTexture,\n\tpbrUtils: pbrUtils,\n\tenvironment: environment,\n\tblinn_phong: blinn_phong,\n\tgetNormal: getNormal,\n\tgetTBN: getTBN,\n\tgetNormalByNormalTexture: getNormalByNormalTexture,\n\tibl: ibl,\n\tskinVertMain,\n\tskinVertHeader,\n\tFragInput,\n\tVertexInput,\n\tVertexOutput,\n\tPbrMaterialStruct,\n\tSystemUniform,\n\tinstanceVertMain,\n\tinstanceVertHeader\n};\nexport default ShaderChunk;\n","import { wgslParseDefines } from \"../WgslPreprocessor\";\nexport default function phongVert(defines) {\n\treturn `\n      struct VertexOutput {\n            @builtin(position) position: vec4<f32>,\n            @location(0) uv: vec2<f32>,\n            @location(1) view: vec3<f32>, // Vector from vertex to camera.\n            @location(2) worldPos: vec3<f32>,\n            @location(3) color: vec4<f32>,\n            @location(4) normal: vec3<f32>,\n            @location(5) viewPosition: vec3<f32>,\n      };\n      struct MaterialUniform {\n            modelMatrix: mat4x4<f32>,\n            color: vec3<f32>,\n            opacity:f32,\n            normalMatrix: mat4x4<f32>,\n            emissive:vec3<f32>,\n            specular:vec3<f32>,\n            shininess:f32,\n      }\n      struct SystemUniform {\n            projectionMatrix: mat4x4<f32>,\n            viewMatrix: mat4x4<f32>,\n            inverseViewMatrix: mat4x4<f32>,\n            cameraPosition: vec3<f32>,\n      }; \n\n      @binding(${defines.phongBinding}) @group(0) var<uniform> selfUniform : MaterialUniform;\n      @binding(${defines.cameraBinding}) @group(1) var<uniform> systemUniform : SystemUniform;\n\n      struct VertexInput {\n            @location(${defines.positionLocation}) position: vec3<f32>,       \n            @location(${defines.normalLocation}) normal: vec3<f32>,\n            @location(${defines.uvLocation}) uv: vec2<f32>,\n      }\n      @vertex\n      fn main(input: VertexInput) -> VertexOutput {\n            var output: VertexOutput;\n            output.uv = input.uv;\n            let modelPos=selfUniform.modelMatrix *vec4<f32>(input.position,1.0);\n            output.worldPos = modelPos.xyz/modelPos.w;\n            let vNormalView = selfUniform.normalMatrix * vec4<f32>(input.normal,0.0);\n            output.normal =  vNormalView.xyz;\n            output.view = systemUniform.cameraPosition.xyz - modelPos.xyz;\n            let viewPosition=systemUniform.viewMatrix * modelPos;\n            output.viewPosition = -viewPosition.xyz;\n            output.position = systemUniform.projectionMatrix * systemUniform.viewMatrix * modelPos;\n            return output;\n      }`;\n}\n","import { wgslParseDefines } from \"../WgslPreprocessor\";\r\nexport default function phongFrag(defines) {\r\n\treturn wgslParseDefines`  \r\n  struct VertInput {\r\n      @builtin(position) position: vec4<f32>,\r\n      @builtin(front_facing) frontFacing: bool,\r\n      @location(0) uv: vec2<f32>,\r\n      @location(1) view: vec3<f32>, // Vector from vertex to camera.\r\n      @location(2) worldPos: vec3<f32>,\r\n      @location(3) color: vec4<f32>,\r\n      @location(4) normal: vec3<f32>,\r\n      @location(5) viewPosition: vec3<f32>,\r\n    };\r\n    \r\n    struct MaterialUniform {\r\n      modelMatrix: mat4x4<f32>,\r\n      color: vec3<f32>,\r\n      opacity:f32,\r\n      normalMatrix: mat4x4<f32>,\r\n      emissive:vec3<f32>,\r\n      shininess:f32,\r\n      specular:vec3<f32>,      \r\n   }\r\n   struct SystemUniform {\r\n      projectionMatrix: mat4x4<f32>,\r\n      viewMatrix: mat4x4<f32>,\r\n      inverseViewMatrix: mat4x4<f32>,\r\n      cameraPosition: vec3<f32>,\r\n  }; \r\n\r\n    #if${defines.USE_COLORTEXTURE}\r\n      @group(0) @binding(${defines.baseColorSamplerBinding}) var baseColorSampler: sampler;\r\n      @group(0) @binding(${defines.baseColorTextureBinding}) var baseColorTexture: texture_2d<f32>;\r\n    #endif\r\n    #if ${defines.USE_NORMALTEXTURE}\r\n      @group(0) @binding(${defines.normalTextureBinding}) var normalTexture: texture_2d<f32>;\r\n      @group(0) @binding(${defines.normalSamplerBinding}) var normalSampler: sampler;\r\n    #endif\r\n    @binding(${defines.phongBinding}) @group(0) var<uniform> materialUniform : MaterialUniform;\r\n    @binding(${defines.cameraBinding}) @group(1) var<uniform> systemUniform : SystemUniform;\r\n    #if ${defines.USE_NORMALTEXTURE}\r\n      #include <getTBN>\r\n      #include <getNormalByNormalTexture>\r\n    #else\r\n        #include <getNormal>\r\n    #endif\r\n\r\n    #include <light>\r\n\r\n    @fragment\r\n    fn main(input:VertInput) -> @location(0) vec4<f32> {\r\n        var totalEmissiveRadiance:vec3<f32> = materialUniform.emissive;\r\n        var color:vec4<f32>;\r\n        #if${defines.USE_COLORTEXTURE}\r\n            color= vec4<f32>(textureSample(baseColorTexture, baseColorSampler, input.uv).rgb+materialUniform.color,materialUniform.opacity);\r\n        #else\r\n            color=vec4<f32>(materialUniform.color,materialUniform.opacity);\r\n        #endif     \r\n        let  V:vec3<f32> =  normalize( systemUniform.cameraPosition - input.worldPos);\r\n        #if ${defines.USE_NORMALTEXTURE}\r\n            let N:vec3<f32> = getNormalByNormalTexture(input);  \r\n        #else\r\n            let N:vec3<f32> = getNormal(input);\r\n        #endif\r\n        var geometry:Geometry;\r\n        geometry.normal=N;\r\n        geometry.viewDir=V;\r\n        geometry.position=input.worldPos;\r\n        let lightColor:ReflectedLight=parseLights(geometry,materialUniform.shininess);\r\n        // var finnalColor:vec3<f32>=color.xyz + (lightColor.directDiffuse + lightColor.directSpecular + lightColor.ambient);\r\n        var finnalColor:vec3<f32>=color.xyz * (lightColor.directDiffuse + lightColor.directSpecular + lightColor.ambient);\r\n\r\n        // finnalColor = lightColor.testColor.xyz;\r\n\r\n        return vec4<f32>(finnalColor,color.a);\r\n    }`;\r\n}\r\n","// import Color from \"../../math/Color\";\r\n\r\nexport default function colorFrag(defines) {\r\n  return `\r\n    struct VertexOutput {\r\n        @builtin(position) position: vec4<f32>,\r\n        @location(0) color: vec4<f32>,\r\n    };\r\n    @fragment\r\n    fn main(input:VertexOutput) -> @location(0) vec4<f32> {\r\n      return input.color;\r\n    }\r\n    `;\r\n}\r\n","export default function colorVert(defines) {\n\treturn `\n   struct VertexInput {\n        @location(${defines.positionLocation}) position: vec3<f32>,       \n        @location(${defines.colorLocation}) color: vec4<f32>,\n   }\n   struct VertexOutput {\n        @builtin(position) position: vec4<f32>,\n        @location(0) color: vec4<f32>,\n    };\n   struct SelfUniform {\n      modelMatrix: mat4x4<f32>,\n   }\n   struct SystemUniform {\n      projectionMatrix: mat4x4<f32>,\n      viewMatrix: mat4x4<f32>,\n      inverseViewMatrix: mat4x4<f32>,\n      cameraPosition: vec3<f32>,\n   }; \n   @binding(${defines.colorBinding}) @group(0) var<uniform> selfUniform : SelfUniform;\n   @binding(${defines.cameraBinding}) @group(1) var<uniform> systemUniform : SystemUniform;\n   @vertex\n   fn main(input: VertexInput) -> VertexOutput {\n    var output:VertexOutput;\n    output.color=input.color;\n    output.position = systemUniform.projectionMatrix * systemUniform.viewMatrix *selfUniform.modelMatrix*vec4<f32>(input.position,1.0);\n    return output;\n   }\n   `;\n}\n","import { wgslParseDefines } from \"../WgslPreprocessor\";\r\n\r\nexport default function pbrFrag(defines) {\r\n\treturn wgslParseDefines`\r\n    #include <lightCommon>\r\n    #include <light>\r\n    #include <brdf>\r\n    #include <pbrStruct>\r\n    #include <pbrUtils>\r\n    #include <pbrFunction>\r\n    #include <pbrTexture>\r\n    #include <environment>\r\n    struct SystemUniform {\r\n        projectionMatrix: mat4x4<f32>,\r\n        viewMatrix: mat4x4<f32>,\r\n        inverseViewMatrix: mat4x4<f32>,\r\n        cameraPosition: vec3<f32>,\r\n    }; \r\n    // uniform vec3 lightProbe[9],\r\n////////////////////////////////////\r\nstruct VertexOutput {\r\n    @builtin(position) position: vec4<f32>,\r\n    @builtin(front_facing) is_front: bool,\r\n    @location(0) vUv: vec2<f32>,\r\n    @location(1) vViewPosition: vec3<f32>, // Vector from vertex to camera.\r\n    @location(2) vWorldPosition: vec3<f32>,\r\n    @location(3) vNormal: vec3<f32>,\r\n    // 可选\r\n    #if ${defines.USE_LIGHTTEXTURE || defines.USE_AOTEXTURE}\r\n        @location(${defines.vUv2OutLocation}) vUv2: vec2<f32>,\r\n    #endif\r\n\r\n    #if ${defines.USE_COLOR_ALPHA}\r\n        @location(${defines.vColorOutLocation}) vColor: vec4<f32>,\r\n    #elif ${defines.USE_COLOR || defines.USE_INSTANCING_COLOR}\r\n        @location(${defines.vColorOutLocation}) vColor: vec3<f32>,\r\n    #endif\r\n\r\n    #if ${defines.USE_TANGENT}\r\n        @location(${defines.vTangentOutLocation}) vTangent: vec3<f32>,\r\n        @location(${defines.vBitangentOutLocation}) vBitangent: vec3<f32>,\r\n    #endif\r\n};\r\n        struct PhysicalMaterial {\r\n             diffuseColor:vec3<f32>,\r\n             roughness:f32,\r\n             specularColor:vec3<f32>,\r\n             specularF90:f32,\r\n            #if ${defines.USE_CLEARCOAT}\r\n                clearcoat:f32,\r\n                clearcoatRoughness:f32,\r\n                clearcoatF0:vec3<f32>,\r\n                clearcoatF90:f32,\r\n            #endif\r\n\r\n            #if ${defines.USE_IRIDESCENCE}\r\n                iridescence:f32,\r\n                iridescenceIOR:f32,\r\n                iridescenceThickness:f32,\r\n                iridescenceFresnel:vec3<f32>,\r\n                iridescenceF0:vec3<f32>,\r\n            #endif\r\n\r\n            #if ${defines.USE_SHEEN}\r\n                sheenColor:vec3<f32>,\r\n                sheenRoughness:f32,\r\n            #endif\r\n\r\n            #if ${defines.IOR}\r\n                 ior:f32,\r\n            #endif\r\n\r\n            #if ${defines.USE_TRANSMISSION}\r\n                transmission:f32,\r\n                transmissionAlpha:f32,\r\n                thickness:f32,\r\n                attenuationDistance:f32,\r\n                attenuationColor:vec3<f32>,\r\n            #endif\r\n        };\r\n@binding(0) @group(0) var<uniform> materialUniform : MaterialUniform;\r\n@binding(0) @group(1) var<uniform> systemUniform : SystemUniform;\r\n@fragment\r\nfn main(input:VertexOutput)-> @location(0) vec4<f32> {\r\n        var diffuseColor:vec4<f32> = vec4(materialUniform.diffuse, materialUniform.opacity );\r\n       // ReflectedLight reflectedLight = ReflectedLight( vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ) );\r\n        var reflectedLight:ReflectedLight;\r\n        var totalEmissiveRadiance:vec3<f32> = materialUniform.emissive;\r\n        #if ${defines.USE_TEXTURE}\r\n            var sampledDiffuseColor:vec4<f32> =textureSample(baseTexture, baseSampler, input.vUv);\r\n            #if ${defines.DECODE_VIDEO_TEXTURE}\r\n                sampledDiffuseColor = vec4<f32>( mix( pow( sampledDiffuseColor.rgb * 0.9478672986 + vec3<f32>( 0.0521327014 ), vec3<f32>( 2.4 ) ), sampledDiffuseColor.rgb * 0.0773993808, vec3<f32>( lessThanEqual( sampledDiffuseColor.rgb, vec3<f32>( 0.04045 ) ) ) ), sampledDiffuseColor.w );\r\n            #endif\r\n\r\n            diffuseColor *= sampledDiffuseColor;\r\n        #endif\r\n\r\n        var roughnessFactor:f32 = materialUniform.roughness;\r\n    \r\n        #if ${defines.USE_ROUGHNESSTEXTURE}\r\n            let texelRoughness:vec4<f32>=textureSample(roughnessTexture, baseSampler, input.vUv);\r\n            roughnessFactor *= texelRoughness.g;\r\n        #endif\r\n\r\n        var metalnessFactor:f32 = materialUniform.metalness;\r\n    \r\n        #if ${defines.USE_METALNESSTEXTURE}\r\n            let texelMetalness:vec4<f32> =textureSample(metalnessTexture, baseSampler, input.vUv);\r\n            metalnessFactor *= texelMetalness.b;\r\n        #endif\r\n\r\n        let faceDirection:f32 =select(-1.0,1.0,input.is_front);\r\n        #if ${defines.FLAT_SHADED}\r\n            let fdx:vec3<f32> = dpdx( input.vViewPosition );\r\n            let fdy:vec3<f32> = dpdy( input.vViewPosition );\r\n            let normal:vec3<f32> = normalize( cross( fdy, fdx ) );\r\n        #else\r\n            let normal:vec3<f32> = normalize( input.vNormal );\r\n            #if ${defines.DOUBLE_SIDED}\r\n                normal = normal * faceDirection;\r\n            #endif\r\n            #if ${defines.USE_TANGENT}\r\n                let tangent:vec3<f32> = normalize( input.vTangent );\r\n                let bitangent:vec3<f32> = normalize( input.vBitangent );\r\n                #if ${defines.DOUBLE_SIDED}\r\n                    tangent = tangent * faceDirection;\r\n                    bitangent = bitangent * faceDirection;\r\n                #endif\r\n                #if ${defines.TANGENTSPACE_NORMALTEXTURE || defines.USE_CLEARCOAT_NORMALTEXTURE}\r\n                    let vTBN:mat3x3<f32> = mat3x3<f32>( tangent, bitangent, normal );\r\n                #endif\r\n            #endif\r\n        #endif\r\n    \r\n        let geometryNormal:vec3<f32> = normal;\r\n\r\n        #if ${defines.OBJECTSPACE_NORMALTEXTURE}\r\n            normal =textureSample(normalTexture, baseSampler, input.vUv).xyz * 2.0 - 1.0;\r\n            #if ${defines.FLIP_SIDED}\r\n                normal = - normal;\r\n            #endif\r\n            #if ${defines.DOUBLE_SIDED}\r\n                normal = normal * faceDirection;\r\n            #endif\r\n\r\n            normal = normalize(materialUniform.normalMatrix * normal );\r\n\r\n            #elif ${defines.TANGENTSPACE_NORMALTEXTURE}\r\n            let tempMapN:vec3<f32> =textureSample(normalTexture, baseSampler, input.vUv).xyz * 2.0 - 1.0;\r\n            let mapN:vec3<f32> =tempMapN.xy *= materialUniform.normalScale;\r\n            #if ${defines.USE_TANGENT}\r\n                normal = normalize( vTBN * mapN );\r\n            #else\r\n                normal = perturbNormal2Arb( - input.vViewPosition, normal, mapN, faceDirection );\r\n            #endif\r\n\r\n            #elif ${defines.USE_BUMPTEXTURE}\r\n\r\n                normal = perturbNormalArb( - input.vViewPosition, normal, dHdxy_fwd(), faceDirection );\r\n        #endif\r\n\r\n        #if ${defines.USE_CLEARCOAT}\r\n            var clearcoatNormal:vec3<f32> = geometryNormal;\r\n        #endif\r\n        #if ${defines.USE_CLEARCOAT_NORMALTEXTURE}\r\n            var clearcoatMapN:vec3<f32> =textureSample(clearcoatNormalTexture, baseSampler, input.vUv).xyz * 2.0 - 1.0;\r\n            clearcoatMapN.xy *= materialUniform.clearcoatNormalScale;\r\n            #if ${defines.USE_TANGENT}\r\n                clearcoatNormal = normalize( vTBN * clearcoatMapN );\r\n            #else\r\n                clearcoatNormal = perturbNormal2Arb( - input.vViewPosition, clearcoatNormal, clearcoatMapN, faceDirection );\r\n            #endif\r\n        #endif\r\n        #if ${defines.USE_EMISSIVETEXTURE}\r\n            let emissiveColor:vec4<f32> =textureSample(emissiveTexture, baseSampler, input.vUv);\r\n            totalEmissiveRadiance *= emissiveColor.rgb;\r\n        #endif\r\n\r\n        var material:PhysicalMaterial;\r\n        material.diffuseColor = diffuseColor.rgb * ( 1.0 - metalnessFactor );\r\n        let dxy:vec3<f32> = max( abs( dpdx( geometryNormal ) ), abs( dpdy( geometryNormal ) ) );\r\n        let geometryRoughness:f32 = max( max( dxy.x, dxy.y ), dxy.z );\r\n        material.roughness = max( roughnessFactor, 0.0525 );\r\n        material.roughness += geometryRoughness;\r\n        material.roughness = min( material.roughness, 1.0 );\r\n\r\n        #if ${defines.IOR}\r\n            material.ior = materialUniform.ior;\r\n            #if ${defines.SPECULAR}\r\n                let specularIntensityFactor:f32 = materialUniform.specularIntensity;\r\n                let specularColorFactor:vec3<f32> = materialUniform.specularColor;\r\n                #if ${defines.USE_SPECULARINTENSITYTEXTURE}\r\n                    specularIntensityFactor *=textureSample(specularIntensityTexture, baseSampler, input.vUv).a;\r\n                #endif\r\n\r\n                #if ${defines.USE_SPECULARCOLORTEXTURE}\r\n                    specularColorFactor *=textureSample(specularColorTexture, baseSampler, input.vUv).rgb;\r\n                #endif\r\n\r\n                material.specularF90 = mix( specularIntensityFactor, 1.0, metalnessFactor );\r\n            #else\r\n                let specularIntensityFactor:f32 = 1.0;\r\n                let specularColorFactor:vec3<f32> = vec3<f32>( 1.0 );\r\n                material.specularF90 = 1.0;\r\n            #endif\r\n            material.specularColor = mix( min( pow2( ( material.ior - 1.0 ) / ( material.ior + 1.0 ) ) * specularColorFactor, vec3( 1.0 ) ) * specularIntensityFactor, diffuseColor.rgb, metalnessFactor );\r\n        #else\r\n            material.specularColor = mix( vec3<f32>( 0.04 ), diffuseColor.rgb, metalnessFactor );\r\n            material.specularF90 = 1.0;\r\n        #endif\r\n        #if ${defines.USE_CLEARCOAT}\r\n            material.clearcoat = materialUniform.clearcoat;\r\n            material.clearcoatRoughness = materialUniform.clearcoatRoughness;\r\n            material.clearcoatF0 = vec3<f32>( 0.04 );\r\n            material.clearcoatF90 = 1.0;\r\n            #if ${defines.USE_CLEARCOATTEXTURE}\r\n                material.clearcoat *=textureSample(clearcoatTexture, baseSampler, input.vUv).x;\r\n            #endif\r\n            #if ${defines.USE_CLEARCOAT_ROUGHNESSTEXTURE}\r\n                material.clearcoatRoughness *=textureSample(clearcoatRoughnessTexture, baseSampler, input.vUv).y;\r\n            #endif\r\n            material.clearcoat = saturate( material.clearcoat );\r\n            material.clearcoatRoughness = max( material.clearcoatRoughness, 0.0525 );\r\n            material.clearcoatRoughness += geometryRoughness;\r\n            material.clearcoatRoughness = min( material.clearcoatRoughness, 1.0 );\r\n        #endif\r\n        #if ${defines.USE_IRIDESCENCE}\r\n            material.iridescence = materialUniform.iridescence;\r\n            material.iridescenceIOR = materialUniform.iridescenceIOR;\r\n            #if ${defines.USE_IRIDESCENCETEXTURE}\r\n                material.iridescence *=textureSample(iridescenceTexture, baseSampler, input.vUv).r;\r\n            #endif\r\n            #if ${defines.USE_IRIDESCENCE_THICKNESSTEXTURE}\r\n                material.iridescenceThickness = (materialUniform.iridescenceThicknessMaximum - materialUniform.iridescenceThicknessMinimum) * textureSample(iridescenceThicknessTexture, baseSampler, input.vUv).g + materialUniform.iridescenceThicknessMinimum;\r\n            #else\r\n                material.iridescenceThickness = materialUniform.iridescenceThicknessMaximum;\r\n            #endif\r\n        #endif\r\n        #if ${defines.USE_SHEEN}\r\n            material.sheenColor = materialUniform.sheenColor;\r\n            #if ${defines.USE_SHEENCOLORTEXTURE}\r\n                material.sheenColor *=textureSample(sheenColorTexture, baseSampler, input.vUv).rgb;\r\n            #endif\r\n            material.sheenRoughness = clamp( materialUniform.sheenRoughness, 0.07, 1.0 );\r\n            #if ${defines.USE_SHEENROUGHNESSTEXTURE}\r\n                material.sheenRoughness *=textureSample(sheenRoughnessTexture, baseSampler, input.vUv).a;\r\n            #endif\r\n        #endif\r\n        \r\n        var geometry:GeometricContext;\r\n        geometry.position = - input.vViewPosition;\r\n        geometry.normal = normal;\r\n       // geometry.viewDir = ( isOrthographic ) ? vec3( 0, 0, 1 ) : normalize( input.vViewPosition );\r\n        geometry.viewDir = normalize( input.vViewPosition); \r\n\r\n        #if ${defines.USE_CLEARCOAT}\r\n            geometry.clearcoatNormal = clearcoatNormal;\r\n        #endif\r\n\r\n        #if ${defines.USE_IRIDESCENCE}\r\n            let dotNVi:f32 = saturate( dot( normal, geometry.viewDir ) );\r\n            if ( material.iridescenceThickness == 0.0 ) {\r\n                material.iridescence = 0.0;\r\n            }\r\n            else {\r\n                material.iridescence = saturate( material.iridescence );\r\n            }\r\n            if ( material.iridescence > 0.0 ) {\r\n                material.iridescenceFresnel = evalIridescence( 1.0, material.iridescenceIOR, dotNVi, material.iridescenceThickness, material.specularColor );\r\n                material.iridescenceF0 = Schlick_to_F0( material.iridescenceFresnel, 1.0, dotNVi );\r\n            }\r\n        #endif\r\n\r\n        var iblIrradiance:vec3<f32> = vec3<f32>( 0.0 );\r\n        var irradiance:vec3<f32> = getAmbientLightIrradiance(commonLightsParms.ambient);\r\n        //irradiance += getLightProbeIrradiance( lightProbe, geometry.normal,systemUniform.viewMatrix );\r\n\r\n        var radiance:vec3<f32> = vec3<f32>( 0.0 );\r\n        var clearcoatRadiance:vec3<f32> = vec3<f32>( 0.0 );\r\n\r\n        #if ${defines.USE_LIGHTTEXTURE}\r\n            let lightMapTexel:vec4<f32> =textureSample(lightTexture, baseSampler, input.vUv2);\r\n            let lightMapIrradiance:vec3<f32> = lightMapTexel.rgb * materialUniform.lightTextureIntensity;\r\n            irradiance += lightMapIrradiance;\r\n        #endif\r\n        //&& defines.STANDARD&&defines.ENVTEXTURE_TYPE_CUBE_UV\r\n        #if ${defines.USE_ENVTEXTURE} \r\n            iblIrradiance += getIBLIrradiance( geometry.normal,baseSampler,systemUniform.viewMatrix );\r\n        #endif\r\n        #if ${defines.USE_ENVTEXTURE}\r\n            radiance += getIBLRadiance( geometry.viewDir,baseSampler,systemUniform.viewMatrix, geometry.normal, materialUniform.roughness );\r\n            #if ${defines.USE_CLEARCOAT}\r\n                clearcoatRadiance += getIBLRadiance( geometry.viewDir,baseSampler,systemUniform.viewMatrix, geometry.clearcoatNormal, material.clearcoatRoughness );\r\n            #endif\r\n        #endif\r\n        //直接光照\r\n            let dirReflectedLight:ReflectedLight= parseLights(geometry,material);\r\n            reflectedLight.directDiffuse +=dirReflectedLight.directDiffuse;\r\n            reflectedLight.directSpecular +=dirReflectedLight.directSpecular;\r\n        //间接漫反射\r\n            let indirectDiffuseLight:ReflectedLight= RE_IndirectDiffuse_Physical( irradiance, geometry, material);\r\n            reflectedLight.directDiffuse +=indirectDiffuseLight.indirectDiffuse;\r\n            reflectedLight.directSpecular +=indirectDiffuseLight.indirectSpecular;\r\n        //间接高光\r\n            let indirectSpecularLight:ReflectedLight=RE_IndirectSpecular_Physical( radiance, iblIrradiance, clearcoatRadiance, geometry, material);\r\n            reflectedLight.directDiffuse +=indirectSpecularLight.indirectDiffuse;\r\n            reflectedLight.directSpecular +=indirectSpecularLight.indirectSpecular;\r\n        //环境光遮蔽\r\n        #if ${defines.USE_AOTEXTURE}\r\n            let ambientOcclusion:f32 = (textureSample(aoTexture, baseSampler, input.vUv2).r - 1.0 ) * materialUniform.aoTextureIntensity + 1.0;\r\n\r\n            reflectedLight.indirectDiffuse *= ambientOcclusion;\r\n            //&&defines.STANDARD\r\n            #if ${defines.USE_ENVTEXTURE} \r\n                let dotNV:f32 = saturate( dot( geometry.normal, geometry.viewDir ) );\r\n                reflectedLight.indirectSpecular *= computeSpecularOcclusion( dotNV, ambientOcclusion, material.roughness );\r\n            #endif\r\n        #endif\r\n\r\n        var totalDiffuse:vec3<f32> = reflectedLight.directDiffuse + reflectedLight.indirectDiffuse;\r\n        var totalSpecular:vec3<f32> = reflectedLight.directSpecular + reflectedLight.indirectSpecular;\r\n        //透射\r\n        #if ${defines.USE_TRANSMISSION}\r\n            material.transmission = materialUniform.transmission;\r\n            material.transmissionAlpha = 1.0;\r\n            material.thickness = materialUniform.thickness;\r\n            material.attenuationDistance = materialUniform.attenuationDistance;\r\n            material.attenuationColor = materialUniform.attenuationColor;\r\n            #if ${defines.USE_TRANSMISSIONTEXTURE}\r\n                material.transmission *=textureSample(transmissionTexture, baseSampler, input.vUv).r;\r\n            #endif\r\n            #if ${defines.USE_THICKNESSTEXTURE}\r\n                material.thickness *=textureSample(thicknessTexture, baseSampler, input.vUv).g;\r\n            #endif\r\n            let pos:vec3<f32> = vWorldPosition;\r\n            let v:vec3<f32> = normalize( cameraPosition - pos );\r\n            let n:vec3<f32> = inverseTransformDirection( normal, systemUniform.viewMatrix );\r\n            let transmission:vec4<f32> = getIBLVolumeRefraction(\r\n            n, v, material.roughness, material.diffuseColor, material.specularColor, material.specularF90, pos, modelMatrix, systemUniform.viewMatrix, systemUniform.projectionMatrix, material.ior, material.thickness, material.attenuationColor, material.attenuationDistance );\r\n            material.transmissionAlpha = mix( material.transmissionAlpha, transmission.a, material.transmission );\r\n            totalDiffuse = mix( totalDiffuse, transmission.rgb, material.transmission );\r\n        #endif\r\n\r\n        let outgoingLight:vec3<f32> = totalDiffuse + totalSpecular + totalEmissiveRadiance;\r\n\r\n        #if ${defines.USE_SHEEN}\r\n            let sheenEnergyComp:f32 = 1.0 - 0.157 * max3( material.sheenColor );\r\n            outgoingLight = outgoingLight * sheenEnergyComp + sheenSpecular;\r\n        #endif\r\n\r\n        #if ${defines.USE_CLEARCOAT}\r\n            let dotNVcc:f32 = saturate( dot( geometry.clearcoatNormal, geometry.viewDir ) );\r\n            let Fcc:vec3<f32> = F_Schlick( material.clearcoatF0, material.clearcoatF90, dotNVcc );\r\n            outgoingLight = outgoingLight * ( 1.0 - material.clearcoat * Fcc ) + clearcoatSpecular * material.clearcoat;\r\n        #endif\r\n\r\n        #if ${defines.USE_TRANSMISSION}\r\n            diffuseColor.a *= material.transmissionAlpha + 0.1;\r\n        #endif\r\n\r\n        var finnalColor:vec4<f32>;\r\n        finnalColor = vec4<f32>( outgoingLight, diffuseColor.a );\r\n        #if ${defines.TONE_MAPPING}\r\n           finnalColor.rgb = toneMapping( finnalColor.rgb,materialUniform.toneMappingExposure );\r\n        #endif\r\n\r\n          finnalColor = linearToOutputTexel( finnalColor);\r\n\r\n        #if ${defines.PREMULTIPLIED_ALPHA}\r\n            finnalColor.rgb *= finnalColor.a;\r\n        #endif\r\n        #if ${defines.DITHERING}\r\n            finnalColor.rgb = dithering( finnalColor.rgb );\r\n        #endif\r\n        return finnalColor;\r\n    }`;\r\n}\r\n","import { wgslParseDefines } from \"../WgslPreprocessor\";\r\n\r\nexport default function pbrVert(defines) {\r\n  return wgslParseDefines`\r\n    #include <pbrStruct>\r\n    struct VertexOutput {\r\n        @builtin(position) position: vec4<f32>,\r\n        @location(0) vUv: vec2<f32>,\r\n        @location(1) vViewPosition: vec3<f32>, // Vector from vertex to camera.\r\n        @location(2) vWorldPosition: vec3<f32>,\r\n        @location(3) vNormal: vec3<f32>,\r\n        // 可选\r\n        #if ${defines.USE_LIGHTTEXTURE || defines.USE_AOTEXTURE}\r\n            @location(${defines.vUv2OutLocation}) vUv2: vec2<f32>,\r\n        #endif\r\n\r\n        #if ${defines.USE_COLOR_ALPHA}\r\n            @location(${defines.vColorOutLocation}) vColor: vec4<f32>,\r\n        #elif ${defines.USE_COLOR || defines.USE_INSTANCING_COLOR}\r\n            @location(${defines.vColorOutLocation}) vColor: vec3<f32>,\r\n        #endif\r\n\r\n        #if ${defines.USE_TANGENT}\r\n            @location(${defines.vTangentOutLocation}) vTangent: vec3<f32>,\r\n            @location(${defines.vBitangentOutLocation}) vBitangent: vec3<f32>,\r\n        #endif\r\n    };\r\n    struct GlobalUniform {\r\n        projectionMatrix: mat4x4<f32>,\r\n        viewMatrix: mat4x4<f32>,\r\n        inverseViewMatrix: mat4x4<f32>,\r\n        cameraPosition: vec3<f32>,\r\n    };\r\n\r\n    //texture and sampler\r\n    // @group(0) @binding(${defines.samplerBinding}) var baseSampler: sampler;\r\n    #if ${defines.USE_SKINNING}\r\n        //uniform highp sampler2D boneTexture;\r\n        @group(0) @binding(${\r\n          defines.boneTextureBinding\r\n        }) var boneTexture: texture_2d<f32>;\r\n    #endif\r\n\r\n    #if ${defines.USE_DISPLACEMENTTEXTURE}\r\n        //uniform sampler2D displacementMap;\r\n        @group(0) @binding(${\r\n          defines.displacementTextureBinding\r\n        }) var displacementMap: texture_2d<f32>;\r\n    #endif\r\n\r\n    #if ${defines.MORPHTARGETS_TEXTURE}\r\n        //uniform sampler2DArray morphTargetsTexture;\r\n        @group(0) @binding(${\r\n          defines.morphTargetsTextureBinding\r\n        }) var morphTargetsTexture: texture_2d_array<f32>;\r\n    #endif\r\n\r\n    struct VertexInput {\r\n        @location(0) position: vec3<f32>,  \r\n\r\n        @location(1) normal: vec3<f32>,\r\n\r\n        @location(2) uv: vec2<f32>,\r\n        #if ${defines.USE_LIGHTTEXTURE || defines.USE_AOTEXTURE}\r\n            @location(${defines.uv2Location}) uv2:vec2<f32>,\r\n        #endif\r\n        #if ${defines.USE_INSTANCING}\r\n            @location(${\r\n              defines.instanceMatrixLocation\r\n            }) instanceMatrix:mat4x4<f32>,\r\n        #endif\r\n        #if ${defines.USE_INSTANCING_COLOR}\r\n            @location(${defines.instanceColorLocation}) instanceColor:vec3<f32>,\r\n        #endif\r\n        \r\n        #if ${defines.USE_TANGENT}\r\n            @location(${defines.tangentLocation}) tangent:vec4<f32>,\r\n        #endif\r\n        #if ${defines.USE_COLOR_ALPHA}\r\n            @location(${defines.colorLocation}) color:vec4<f32>,\r\n        #elif ${defines.USE_COLOR}\r\n            @location(${defines.colorLocation}) color:vec3<f32>,\r\n        #endif\r\n\r\n        #if ${defines.USE_MORPHTARGETS && !defines.MORPHTARGETS_TEXTURE}\r\n            @location(${defines.morphTarget0Location}) morphTarget0:vec3<f32>,\r\n\r\n            @location(${defines.morphTarget1Location}) morphTarget1:vec3<f32>,\r\n\r\n            @location(${defines.morphTarget2Location}) morphTarget2:vec3<f32>,\r\n\r\n            @location(${defines.morphTarget3Location}) morphTarget3:vec3<f32>,\r\n            #if ${defines.USE_MORPHNORMALS}\r\n                @location(${\r\n                  defines.morphNormal0Location\r\n                }) morphNormal0:vec3<f32>,\r\n\r\n                @location(${\r\n                  defines.morphNormal1Location\r\n                }) morphNormal1:vec3<f32>,\r\n\r\n                @location(${\r\n                  defines.morphNormal2Location\r\n                }) morphNormal2:vec3<f32>,\r\n\r\n                @location(${\r\n                  defines.morphNormal3Location\r\n                }) morphNormal3:vec3<f32>,\r\n            #else\r\n                @location(${\r\n                  defines.morphTarget4Location\r\n                }) morphTarget4:vec3<f32>,\r\n\r\n                @location(${\r\n                  defines.morphTarget5Location\r\n                }) morphTarget5:vec3<f32>,\r\n\r\n                @location(${\r\n                  defines.morphTarget6Location\r\n                }) morphTarget6:vec3<f32>,\r\n\r\n                @location(${\r\n                  defines.morphTarget7Location\r\n                }) morphTarget7:vec3<f32>,\r\n            #endif\r\n        #endif\r\n        #if ${defines.USE_SKINNING}\r\n            @location(${defines.skinIndexLocation}) skinIndex:vec4<f32>,\r\n            @location(${defines.skinWeightLocation}) skinWeight:vec4<f32>,\r\n        #endif\r\n  }\r\n\r\n    #if ${defines.MORPHTARGETS_TEXTURE}\r\n        fn getMorph( vertexIndex:u32, morphTargetIndex:u32,offset:u32 )->vec4<f32> {\r\n            let texelIndex:u32 = vertexIndex * MORPHTARGETS_TEXTURE_STRIDE + offset;\r\n            let y:u32 = texelIndex / materialUniform.morphTargetsTextureSize.x;\r\n            let x:u32 = texelIndex - y * materialUniform.morphTargetsTextureSize.x;\r\n            let morphUV:vec3<u32> = vec3<u32>( x, y, morphTargetIndex );\r\n            //textureLoad\r\n            //return texelFetch( morphTargetsTexture, morphUV, 0 );\r\n            return textureLoad( morphTargetsTexture, morphUV, 0 );\r\n        }\r\n    #endif\r\n    #if ${defines.USE_SKINNING}\r\n        fn getBoneMatrix( i:f32 )->mat4x4<f32> {\r\n            let j:f32 = i * 4.0;\r\n            let x:f32 = j%f32( materialUniform.boneTextureSize );\r\n            let y:f32 = floor( j / f32( materialUniform.boneTextureSize ) );\r\n            let dx:f32 = 1.0 / f32( materialUniform.boneTextureSize );\r\n            let dy:f32 = 1.0 / f32( materialUniform.boneTextureSize );\r\n            y = dy * ( y + 0.5 );\r\n            \r\n            let v1:vec4<f32> = textureSample(boneTexture, baseSampler, vec2<f32>( dx * ( x + 0.5 ), y ) );\r\n            let v2:vec4<f32> = textureSample(boneTexture, baseSampler, vec2<f32>( dx * ( x + 1.5 ), y ) );\r\n            let v3:vec4<f32> = textureSample(boneTexture, baseSampler, vec2<f32>( dx * ( x + 2.5 ), y ) );\r\n            let v4:vec4<f32> = textureSample(boneTexture, baseSampler, vec2<f32>( dx * ( x + 3.5 ), y ) );\r\n            let bone:mat4x4<f32> = mat4x4<f32>( v1, v2, v3, v4 );\r\n            return bone;\r\n        }\r\n    #endif\r\n\r\n    @binding(0) @group(0) var<uniform> materialUniform : MaterialUniform;\r\n    @binding(0) @group(1) var<uniform> globalUniform : GlobalUniform;\r\n    @vertex\r\n    fn main(input:VertexInput)->VertexOutput {\r\n        var vertexOutput:VertexOutput;\r\n        #if ${defines.USE_TEXTURE}\r\n            vertexOutput.vUv = input.uv;\r\n        #endif\r\n        #if ${defines.USE_LIGHTTEXTURE || defines.USE_AOTEXTURE}\r\n            vertexOutput.vUv2 input.uv2;\r\n        #endif\r\n        #if ${defines.USE_COLOR_ALPHA}\r\n            vertexOutput.vColor = vec4( 1.0 );\r\n            #elif ${defines.USE_COLOR || defines.USE_INSTANCING_COLOR}\r\n            vertexOutput.vColor = vec3( 1.0 );\r\n        #endif\r\n        #if ${defines.USE_COLOR}\r\n            vertexOutput.vColor *= input.color;\r\n        #endif\r\n        #if ${defines.USE_INSTANCING_COLOR}\r\n            vertexOutput.vColor.xyz *= input.instanceColor.xyz;\r\n        #endif\r\n        #if ${defines.USE_MORPHCOLORS && defines.MORPHTARGETS_TEXTURE}\r\n            vertexOutput.vColor *= materialUniform.morphTargetBaseInfluence;\r\n            for (let i : u32 = 0u; i < materialUniform.MORPHTARGETS_COUNT; i = i + 1u ) {\r\n                #if ${defines.USE_COLOR_ALPHA}\r\n                    if ( materialUniform.morphTargetInfluences[ i ] ! = 0.0 ) vertexOutput.vColor += getMorph( gl_VertexID, i, 2 ) * materialUniform.morphTargetInfluences[ i ];\r\n                    #elif ${defines.USE_COLOR}\r\n                    if ( materialUniform.morphTargetInfluences[ i ] ! = 0.0 ) vertexOutput.vColor += getMorph( gl_VertexID, i, 2 ).rgb * materialUniform.morphTargetInfluences[ i ];\r\n                #endif\r\n            }\r\n        #endif\r\n        var objectNormal:vec3<f32> = vec3<f32>(input.normal);\r\n        #if ${defines.USE_TANGENT}\r\n            let objectTangent:vec3<f32> = vec3<f32>( input.tangent.xyz );\r\n        #endif\r\n        #if ${defines.USE_MORPHNORMALS}\r\n            objectNormal *= materialUniform.morphTargetBaseInfluence;\r\n            #if ${defines.MORPHTARGETS_TEXTURE}\r\n                for ( let i : u32 = 0u; i < materialUniform.MORPHTARGETS_COUNT; i = i + 1u) {\r\n                    if ( materialUniform.morphTargetInfluences[ i ] ! = 0.0 ) objectNormal += getMorph( gl_VertexID, i, 1 ).xyz * materialUniform.morphTargetInfluences[ i ];\r\n                }\r\n            #else\r\n                objectNormal += morphNormal0 * materialUniform.morphTargetInfluences[ 0 ];\r\n                objectNormal += morphNormal1 * materialUniform.morphTargetInfluences[ 1 ];\r\n                objectNormal += morphNormal2 * materialUniform.morphTargetInfluences[ 2 ];\r\n                objectNormal += morphNormal3 * materialUniform.morphTargetInfluences[ 3 ];\r\n            #endif\r\n        #endif\r\n        #if ${defines.USE_SKINNING}\r\n            let boneMatX:mat4x4<f32> = getBoneMatrix( input.skinIndex.x );\r\n            let boneMatY:mat4x4<f32> = getBoneMatrix( input.skinIndex.y );\r\n            let boneMatZ:mat4x4<f32> = getBoneMatrix( input.skinIndex.z );\r\n            let boneMatW:mat4x4<f32> = getBoneMatrix( input.skinIndex.w );\r\n        #endif\r\n        #if ${defines.USE_SKINNING}\r\n            let skinMatrix:mat4x4<f32> = mat4x4<f32>( 0.0 );\r\n            skinMatrix += input.skinWeight.x * boneMatX;\r\n            skinMatrix += input.skinWeight.y * boneMatY;\r\n            skinMatrix += input.skinWeight.z * boneMatZ;\r\n            skinMatrix += input.skinWeight.w * boneMatW;\r\n            skinMatrix = materialUniform.bindMatrixInverse * skinMatrix * materialUniform.bindMatrix;\r\n            objectNormal = vec4<f32>( skinMatrix * vec4<f32>( objectNormal, 0.0 ) ).xyz;\r\n            #if ${defines.USE_TANGENT}\r\n                objectTangent = vec4<f32>( skinMatrix * vec4<f32>( objectTangent, 0.0 ) ).xyz;\r\n            #endif\r\n        #endif\r\n        var transformedNormal:vec3<f32> = objectNormal;\r\n        // transformedNormal+=vec3<f32>(0.0);\r\n        #if ${defines.USE_INSTANCING}\r\n            let m:mat3x3<f32> = mat3x3<f32>( input.instanceMatrix );\r\n            transformedNormal /= vec3<f32>( dot( m[ 0 ], m[ 0 ] ), dot( m[ 1 ], m[ 1 ] ), dot( m[ 2 ], m[ 2 ] ) );\r\n            transformedNormal = m * transformedNormal;\r\n        #endif\r\n        transformedNormal = materialUniform.normalMatrix * transformedNormal;\r\n        #if ${defines.FLIP_SIDED}\r\n            transformedNormal = - transformedNormal;\r\n        #endif\r\n        #if ${defines.USE_TANGENT}\r\n            let transformedTangent:vec3<f32> = (globalUniform.viewMatrix*materialUniform.modelMatrix * vec4<f32>( objectTangent, 0.0 ) ).xyz;\r\n            #if ${defines.FLIP_SIDED}\r\n                transformedTangent = - transformedTangent;\r\n            #endif\r\n        #endif\r\n        vertexOutput.vNormal = normalize( transformedNormal );\r\n        #if ${defines.FLAT_SHADED}\r\n            #if ${defines.USE_TANGENT}\r\n                vTangent = normalize( transformedTangent );\r\n                vBitangent = normalize( cross( vNormal, vTangent ) * input.tangent.w );\r\n            #endif\r\n        #endif\r\n        let transformed:vec3<f32> = vec3<f32>( input.position );\r\n        #if ${defines.USE_MORPHTARGETS}\r\n            transformed *= materialUniform.morphTargetBaseInfluence;\r\n            #if ${defines.MORPHTARGETS_TEXTURE}\r\n                for ( let i : u32 = 0u; i < materialUniform.MORPHTARGETS_COUNT; i = i + 1u ) {\r\n                    if ( materialUniform.morphTargetInfluences[ i ] ! = 0.0 ) transformed += getMorph( gl_VertexID, i, 0 ).xyz * morphTargetInfluences[ i ];\r\n                }\r\n            #else\r\n                transformed += input.morphTarget0 * materialUniform.morphTargetInfluences[ 0 ];\r\n                transformed += input.morphTarget1 * materialUniform.morphTargetInfluences[ 1 ];\r\n                transformed += input.morphTarget2 * materialUniform.morphTargetInfluences[ 2 ];\r\n                transformed += input.morphTarget3 * materialUniform.morphTargetInfluences[ 3 ];\r\n                #if ${defines.USE_MORPHNORMALS}\r\n                    transformed += input.morphTarget4 * materialUniform.morphTargetInfluences[ 4 ];\r\n                    transformed += input.morphTarget5 * materialUniform.morphTargetInfluences[ 5 ];\r\n                    transformed += input.morphTarget6 * materialUniform.morphTargetInfluences[ 6 ];\r\n                    transformed += input.morphTarget7 * materialUniform.morphTargetInfluences[ 7 ];\r\n                #endif\r\n            #endif\r\n        #endif\r\n        #if ${defines.USE_SKINNING}\r\n            let skinVertex:vec4<f32> = materialUniform.bindMatrix * vec4<f32>( transformed, 1.0 );\r\n            let skinned:vec4<f32> = vec4<f32>( 0.0 );\r\n            skinned += boneMatX * skinVertex * input.skinWeight.x;\r\n            skinned += boneMatY * skinVertex * input.skinWeight.y;\r\n            skinned += boneMatZ * skinVertex * input.skinWeight.z;\r\n            skinned += boneMatW * skinVertex * input.skinWeight.w;\r\n            transformed = ( materialUniform.bindMatrixInverse * skinned ).xyz;\r\n        #endif\r\n        #if ${defines.USE_DISPLACEMENTTEXTURE} \r\n            transformed += normalize( objectNormal ) * (textureSample(displacementMap, baseSampler, vUv).x * materialUniform.displacementScale + materialUniform.displacementBias );\r\n        #endif\r\n        var mvPosition:vec4<f32> = vec4<f32>( transformed, 1.0 );\r\n        #if ${defines.USE_INSTANCING}\r\n            mvPosition = input.instanceMatrix * mvPosition;\r\n        #endif\r\n        mvPosition = globalUniform.viewMatrix*materialUniform.modelMatrix * mvPosition;\r\n        vertexOutput.position = globalUniform.projectionMatrix * mvPosition;\r\n        vertexOutput.vViewPosition = - mvPosition.xyz/mvPosition.w;\r\n        #if ${\r\n          defines.USE_ENVTEXTURE || defines.DISTANCE || defines.USE_TRANSMISSION\r\n        } \r\n            var worldPosition:vec4<f32> = vec4<f32>( transformed, 1.0 );\r\n            #if ${defines.USE_INSTANCING}\r\n                worldPosition = input.instanceMatrix * worldPosition;\r\n            #endif\r\n            worldPosition = materialUniform.modelMatrix * worldPosition;\r\n        #endif\r\n        #if ${defines.USE_TRANSMISSION}\r\n            vertexOutput.vWorldPosition = worldPosition.xyz;\r\n        #endif\r\n        return vertexOutput;\r\n    }\r\n    `;\r\n}\r\n","export default function skyBoxFrag(defines) {\r\n  return `\r\n    fn lessThanEqual(a:vec3<f32>,b:vec3<f32>)->vec3<f32>{\r\n        let xValue:f32=select(b.x,a.x,a.x<=b.x);\r\n        let yValue:f32=select(b.y,a.y,a.y<=b.y);\r\n        let zValue:f32=select(b.z,a.z,a.z<=b.z);\r\n        return vec3<f32>(xValue,yValue,zValue);    \r\n     }\r\n    fn LinearTosRGB( value:vec4<f32> )->vec4<f32> {\r\n        return vec4<f32>( mix( pow( value.rgb, vec3<f32>( 0.41666 ) ) * 1.055 - vec3<f32>( 0.055 ), value.rgb * 12.92, vec3<f32>( lessThanEqual( value.rgb, vec3<f32>( 0.0031308 ) ) ) ), value.a );\r\n    }\r\n  struct FragmentInput {\r\n    @location(0) texCoord : vec3<f32>\r\n  };\r\n  @group(0) @binding(2) var defaultSampler: sampler;\r\n  @group(0) @binding(1) var skyboxTexture: texture_cube<f32>;\r\n  @fragment\r\n  fn main(input : FragmentInput) -> @location(0) vec4<f32> {\r\n    let color = textureSample(skyboxTexture, defaultSampler, input.texCoord);\r\n    return LinearTosRGB(color);\r\n  }\r\n`;\r\n}\r\n","export default function skyBoxVert(defines) {\n\treturn `\n   struct SystemUniform {\n       projectionMatrix: mat4x4<f32>,\n       viewMatrix: mat4x4<f32>,\n       inverseViewMatrix: mat4x4<f32>,\n       cameraPosition: vec3<f32>,\n   }; \n   struct MaterialUniform {\n    modelMatrix: mat4x4<f32>,\n }\n   @binding(${defines.skyboxBinding}) @group(0) var<uniform> selfUniform : MaterialUniform;\n   @binding(${defines.cameraBinding}) @group(1) var<uniform> systemUniform : SystemUniform;\n     struct VertexInput {\n       @location(${defines.positionLocation}) position : vec3<f32>,\n     };\n     struct VertexOutput {\n       @builtin(position) position : vec4<f32>,\n       @location(0) texCoord : vec3<f32>,\n     };\n     @vertex\n     fn main(input : VertexInput) -> VertexOutput {\n       var output : VertexOutput;\n       output.texCoord = input.position.xyz;\n       var modelView = systemUniform.viewMatrix;\n       // Drop the translation portion of the modelView matrix\n       modelView[3] = vec4(0.0, 0.0, 0.0, modelView[3].w);\n       output.position = systemUniform.projectionMatrix * modelView * vec4<f32>(input.position,1.0);\n       output.position = output.position.xyww;\n       return output;\n     }\n   `;\n}\n","export default function quadFrag(defines) {\r\n\treturn `\r\n    @group(0) @binding(1) var baseSampler: sampler;\r\n    @group(0) @binding(0) var colorTexture: texture_2d<f32>;\r\n    struct VertexOutput {\r\n        @builtin(position) position: vec4<f32>,\r\n        @location(0) uv: vec2<f32>,\r\n    };\r\n    @fragment\r\n    fn main(input:VertexOutput) -> @location(0) vec4<f32> {\r\n      return textureSample(colorTexture, baseSampler, vec2<f32>(input.uv.x,1.0-input.uv.y));\r\n    }\r\n    `;\r\n}\r\n","export default function quadVert(defines) {\n\treturn `\n    struct VertexInput {\n         @location(${defines.positionLocation}) position: vec2<f32>,       \n    }\n    struct VertexOutput {\n         @builtin(position) position: vec4<f32>,\n         @location(0) uv: vec2<f32>,\n     };\n    @vertex\n    fn main(input: VertexInput) -> VertexOutput {\n     var output:VertexOutput;\n     output.uv = input.position * 0.5 + 0.5;\n     output.position = vec4<f32>(input.position, 0.0, 1.0);;\n     return output;\n    }\n    `;\n}\n","import { wgslParseDefines } from \"../WgslPreprocessor\";\nexport default function pbr_vs(defines) {\n\treturn wgslParseDefines`\n    #include <PbrMaterialStruct>\n    #include <SystemUniform>\n    #include <VertexInput>\n    #include <VertexOutput> \n    #include <skinVertHeader>\n    #include <instanceVertHeader>\n    @binding(${defines.pbrBinding}) @group(0) var<uniform> materialUniform : MaterialUniform;\n    @binding(${defines.cameraBinding}) @group(1) var<uniform> systemUniform : SystemUniform;\n    @vertex\n    fn main(input: VertexInput)-> VertexOutput\n   {\n        var output: VertexOutput;\n        #if ${defines.HAS_UV}\n            output.uv = input.uv;\n        #endif\n        var modelMatrix:mat4x4<f32>;\n        var vNormalView:vec3<f32>;\n        vNormalView = normalize(materialUniform.normalMatrix * vec4<f32>(input.normal,0.0)).xyz;\n        modelMatrix=materialUniform.modelMatrix;   \n        #include <skinVertMain>\n        #include <instanceVertMain>  \n        output.normal = vNormalView.xyz;\n        output.position = systemUniform.projectionMatrix * systemUniform.viewMatrix *modelMatrix* vec4<f32>(input.position, 1.0);\n        let modelPos=modelMatrix *vec4<f32>(input.position,1.0);\n        output.worldPos = modelPos.xyz/modelPos.w;\n        return output;   \n   }\n   `;\n}\n","import { wgslParseDefines } from \"../WgslPreprocessor\";\nexport default function pbr_fs(defines) {\n\treturn wgslParseDefines`\n        // reference: https://github.com/KhronosGroup/glTF-WebGL-PBR/blob/master/shaders/pbr-frag.glsl\n        #include <pbrUtils>\n        #include <light>\n        #include <brdf>\n        #include <PbrMaterialStruct>\n        #include <SystemUniform> \n        #include <FragInput>   \n        struct PhysicalMaterial {\n            diffuseColor:vec3<f32>,\n            roughness:f32,\n            specularColor:vec3<f32>,\n           #if ${defines.USE_CLEARCOAT}\n               clearcoat:f32,\n               clearcoatRoughness:f32,\n               clearcoatF0:vec3<f32>,\n               clearcoatF90:f32,\n           #endif\n\n           #if ${defines.USE_IRIDESCENCE}\n               iridescence:f32,\n               iridescenceIOR:f32,\n               iridescenceThickness:f32,\n               iridescenceFresnel:vec3<f32>,\n               iridescenceF0:vec3<f32>,\n           #endif\n\n           #if ${defines.USE_SHEEN}\n               sheenColor:vec3<f32>,\n               sheenRoughness:f32,\n           #endif\n\n           #if ${defines.IOR}\n                ior:f32,\n           #endif\n\n           #if ${defines.USE_TRANSMISSION}\n               transmission:f32,\n               transmissionAlpha:f32,\n               thickness:f32,\n               attenuationDistance:f32,\n               attenuationColor:vec3<f32>,\n           #endif\n       };\n        const M_PI:f32 = 3.141592653589793;\n        const c_MinRoughness:f32 = 0.04;\n        @binding(${defines.pbrBinding}) @group(0) var<uniform> materialUniform : MaterialUniform;\n        @binding(${defines.cameraBinding}) @group(1) var<uniform> systemUniform : SystemUniform;\n        // IBL\n        #if ${defines.USE_IBL}\n            @group(0) @binding(${defines.specularEnvTextureBinding}) var specularEnvTexture: texture_cube<f32>;\n            @group(0) @binding(${defines.specularEnvSamplerBinding}) var specularEnvSampler: sampler;\n        #endif\n        #if ${defines.USE_TEXTURE}\n           @group(0) @binding(${defines.baseColorTextureBinding}) var baseColorTexture: texture_2d<f32>;\n           @group(0) @binding(${defines.baseColorSamplerBinding}) var baseColorSampler: sampler;\n        #endif\n        // normal map\n        #if ${defines.USE_NORMALTEXTURE}\n          @group(0) @binding(${defines.normalTextureBinding}) var normalTexture: texture_2d<f32>;\n          @group(0) @binding(${defines.normalSamplerBinding}) var normalSampler: sampler;\n        #endif\n        // emmisve map\n        #if ${defines.USE_EMISSIVETEXTURE}\n            @group(0) @binding(${defines.emissiveTextureBinding}) var emissiveTexture: texture_2d<f32>;\n            @group(0) @binding(${defines.emissiveSamplerBinding}) var emissiveSampler: sampler;\n        #endif\n\n        // metal roughness\n        #if ${defines.USE_METALNESSTEXTURE}\n             @group(0) @binding(${\n\t\t\t\t\tdefines.metalnessRoughnessTextureBinding\n\t\t\t\t}) var metalnessRoughnessTexture: texture_2d<f32>;\n             @group(0) @binding(${defines.metalnessRoughnessSamplerBinding}) var metalnessRoughnessSampler: sampler;\n        #endif\n        // occlusion texture\n        #if ${defines.USE_AOTEXTURE}\n             @group(0) @binding(${defines.aoTextureBinding}) var aoTexture: texture_2d<f32>;\n             @group(0) @binding(${defines.aoSamplerBinding}) var aoSampler: sampler;\n        #endif\n        #if ${defines.USE_NORMALTEXTURE}\n            #include <getTBN>\n            #include <getNormalByNormalTexture>\n        #else\n            #include <getNormal>\n        #endif\n        #if ${defines.USE_IBL}\n            #include <ibl>\n        #endif\n        @fragment\n        fn main(input:FragInput) -> @location(0) vec4<f32> \n        {\n            var perceptualRoughness:f32 = materialUniform.roughness;\n            var metallic:f32 = materialUniform.metallic;\n\n            #if ${defines.USE_METALNESSTEXTURE}\n                let mrSample:vec4<f32> = textureSample(metalnessRoughnessTexture,metalnessRoughnessSampler, input.uv);\n                perceptualRoughness = mrSample.g * perceptualRoughness;\n                metallic = mrSample.b * metallic;\n            #endif\n            perceptualRoughness = clamp(perceptualRoughness, c_MinRoughness, 1.0);\n            metallic = clamp(metallic, 0.0, 1.0);\n            let alphaRoughness:f32 = perceptualRoughness * perceptualRoughness;\n\n\n            // The albedo may be defined from a base texture or a flat color\n            #if ${defines.USE_TEXTURE}\n                let baseColor:vec4<f32> = textureSample(baseColorTexture,baseColorSampler, input.uv) ;\n            #else\n                let baseColor:vec4<f32> = vec4<f32>(materialUniform.color,1.0);\n            #endif\n\n            #if ${defines.USE_NORMALTEXTURE}\n                let n:vec3<f32> = getNormalByNormalTexture(input);  \n            #else\n                let n:vec3<f32> = getNormal(input);\n            #endif\n            var material:PhysicalMaterial;\n            material.diffuseColor=baseColor.rgb*( 1.0 - metallic );\n            material.roughness=perceptualRoughness;\n            material.specularColor=mix( vec3<f32>( 0.04), baseColor.rgb, metallic );\n            var geometry:Geometry;\n            geometry.normal=n;\n            geometry.viewDir=normalize(systemUniform.cameraPosition - input.worldPos);\n            geometry.position=input.worldPos;\n            geometry.dotNV = saturate(dot(geometry.normal, geometry.viewDir) );\n            //light shading\n            var reflectedLight=parseLights(geometry,material);\n            var color=reflectedLight.directDiffuse+reflectedLight.directSpecular;\n            //IBL\n            #if ${defines.USE_IBL && defines.HAS_UV}\n                var reflectedLightDiffuse=indirectDiffuse_Physical(geometry,material);\n                var reflectedLightSpecular=indirectSpecular_Physical(geometry,material);\n                color+=reflectedLightDiffuse.indirectDiffuse;\n                color+=reflectedLightSpecular.indirectSpecular;\n            #endif\n            #if ${defines.USE_AOTEXTURE}\n                let ao:f32 = textureSample(aoTexture,aoSampler, input.uv).r;\n                color = mix(color, color * ao, materialUniform.occlusionStrength);\n            #endif\n\n            #if ${defines.USE_EMISSIVETEXTURE}\n                let emissive:vec3<f32> = textureSample(emissiveTexture, emissiveSampler,input.uv).rgb ;\n                color += emissive;\n            #endif\n       return vec4<f32>(color, baseColor.a);\n    }\n   `;\n}\n","export default function Blur(defines) {\r\n\treturn `\r\n    struct FragInput {\r\n        @location(0) uv: vec2<f32>,\r\n    }\r\n    struct BlurUniforms {\r\n        direction:vec2<f32>,\r\n    }\r\n    fn gaussianPdf(x:f32, sigma:f32)->f32 {\r\n        return 0.39894 * exp( -0.5 * x * x/( sigma * sigma))/sigma;\r\n    }\r\n    @group(0) @binding(0)  var<uniform> blurUniforms : BlurUniforms;\r\n    @group(0) @binding({{tDiffuseBinding}}) var tDiffuse: texture_2d<f32>;\r\n    @group(0) @binding({{tSamplerBinding}}) var tSampler: sampler;\r\n    @fragment\r\n    fn main(input:FragInput) -> @location(0) vec4<f32> {\r\n        let invSize:vec2<f32> = vec2<f32>(1.0,1.0) / vec2<f32>(textureDimensions(tDiffuse));\r\n        let fSigma:f32 =f32(${defines.SIGMA});\r\n        var weightSum:f32 = gaussianPdf(0.0, fSigma);\r\n        let baseColor=textureSample(tDiffuse, tSampler, input.uv);\r\n        var diffuseSum:vec3<f32> = baseColor.rgb * weightSum;\r\n        let uvOffset:vec2<f32> = blurUniforms.direction * invSize;\r\n        for( var i : u32 = 1; i < ${defines.KERNEL_RADIUS};i = i + 1 ) {\r\n            let x:f32 = f32(i);\r\n            let w:f32 = gaussianPdf(x, fSigma);\r\n            let sample1:vec3<f32>=textureSample(tDiffuse, tSampler, input.uv+ uvOffset*x).rgb;\r\n            let sample2:vec3<f32>=textureSample(tDiffuse, tSampler, input.uv- uvOffset*x).rgb;\r\n            diffuseSum =diffuseSum+ (sample2+sample2)* w;\r\n            weightSum += 2.0 * w;\r\n        }\r\n        diffuseSum/=weightSum;\r\n      return vec4<f32>(diffuseSum,baseColor.a);\r\n    }\r\n  `;\r\n}\r\n","export default function LuminosityHigh(defines) {\r\n\treturn `\r\n    struct LuminosityUniforms{\r\n        luminosityThreshold:f32,\r\n        smoothWidth:f32,\r\n        defaultColor:vec3<f32>,\r\n        defaultOpacity:f32,\r\n    }\r\n    struct FragInput {\r\n        @location(0) uv: vec2<f32>,\r\n    };\r\n    @group(0) @binding(0)  var<uniform> luminosityUniforms : LuminosityUniforms;\r\n    @group(0) @binding({{tDiffuseBinding}}) var tDiffuse: texture_2d<f32>;\r\n    @group(0) @binding({{tSamplerBinding}}) var tSampler: sampler;\r\n    @fragment\r\n    fn main(input:FragInput)-> @location(0) vec4<f32> {\r\n\r\n        let texel:vec4<f32> = textureSample(tDiffuse, tSampler, input.uv);\r\n\r\n        let luma:vec3<f32> = vec3<f32>( 0.299,0.587,0.114 );\r\n\r\n        let v:f32 = dot( texel.xyz, luma );\r\n\r\n        let outputColor:vec4<f32> = vec4<f32>( luminosityUniforms.defaultColor.rgb, luminosityUniforms.defaultOpacity );\r\n\r\n        let alpha:f32 = smoothstep( luminosityUniforms.luminosityThreshold, luminosityUniforms.luminosityThreshold + luminosityUniforms.smoothWidth, v );\r\n\r\n       return mix( outputColor, texel, alpha );\r\n    }\r\n    `;\r\n}\r\n","export default function blendFrag(defines) {\r\n\treturn `\r\n    struct FragInput {\r\n        @location(0) uv: vec2<f32>,\r\n    };\r\n    @group(0) @binding({{tDiffuseBinding}}) var tDiffuse: texture_2d<f32>;\r\n    @group(0) @binding({{baseColorTextureBinding}}) var baseColorTexture: texture_2d<f32>;\r\n    @group(0) @binding({{tSamplerBinding}}) var tSampler: sampler;\r\n    @fragment\r\n    fn main(input:FragInput) -> @location(0) vec4<f32> {\r\n        let postColor:vec4<f32> = textureSample(tDiffuse, tSampler, input.uv);\r\n        let baseColor:vec4<f32> = textureSample(baseColorTexture, tSampler, input.uv);\r\n      return baseColor+postColor;\r\n    }   \r\n    `;\r\n}\r\n","export default function shadowMapDebuggerFrag(defines) {\r\n\treturn `\r\n    @group(0) @binding(1) var shadowSampler: sampler;\r\n    @group(0) @binding(0) var shadowMap: texture_depth_2d;\r\n    \r\n    // @group(0) @binding(0) var shadowMap: texture_depth_2d_array;\r\n    // @group(0) @binding(0) var shadowMap: texture_2d<f32>;\r\n\r\n    struct VertexOutput {\r\n        @builtin(position) position: vec4<f32>,\r\n        @location(0) uv: vec2<f32>,\r\n    };\r\n\r\n    fn linearizeDepth(depth: f32, near: f32, far: f32)->f32 {\r\n      return 2 * (near * far) / (far + near - depth * (far - near));\r\n    }\r\n\r\n    @fragment\r\n    fn main(input:VertexOutput) -> @location(0) vec4<f32> {\r\n\t\t\tlet color: vec4<f32> = textureGather(shadowMap, shadowSampler, vec2<f32>(input.uv.x,1.0-input.uv.y));\r\n      let depth = (linearizeDepth(color.r, 0.1, 500) - 0.1) / (500 - 0.1);\r\n      return vec4(vec3(depth), 1.0); // PerspectiveCamera\r\n      // return color;\r\n\r\n      // return textureSample(shadowMap, shadowSampler, vec2<f32>(input.uv.x,1.0-input.uv.y));\r\n\r\n    }\r\n    `;\r\n}\r\n","export default function shadowMapDebuggerVert(defines) {\r\n\treturn `\r\n    struct VertexInput {\r\n         @location(${defines.positionLocation}) position: vec2<f32>,       \r\n    }\r\n    struct VertexOutput {\r\n         @builtin(position) position: vec4<f32>,\r\n         @location(0) uv: vec2<f32>,\r\n     };\r\n    @vertex\r\n    fn main(input: VertexInput) -> VertexOutput {\r\n     var output:VertexOutput;\r\n     output.uv = input.position * 0.5 + 0.5;\r\n     output.position = vec4<f32>(input.position, 0.0, 1.0);;\r\n     return output;\r\n    }\r\n    `;\r\n}\r\n","import { wgslParseDefines } from \"../../WgslPreprocessor\";\r\nexport default function shadowMapVert(defines) {\r\n\treturn wgslParseDefines`\r\n   struct VertexInput {\r\n      @location(${defines.positionLocation}) position: vec3<f32>,       \r\n   };\r\n   struct VertexOutput {\r\n      @builtin(position) position: vec4<f32>,\r\n    };\r\n   struct SelfUniform {\r\n      modelMatrix: mat4x4<f32>,\r\n   };\r\n   struct SystemUniform {\r\n      projectionMatrix: mat4x4<f32>,\r\n      viewMatrix: mat4x4<f32>,\r\n      inverseViewMatrix: mat4x4<f32>,\r\n      cameraPosition: vec3<f32>,\r\n   };\r\n\r\n   #if ${defines.isPointLightShadowMap}\r\n      struct PointLightUniform {\r\n         vpMatrix: mat4x4<f32>,\r\n         // vpMatrixArray: array<mat4x4<f32>, 6>,\r\n      };\r\n      @group(1) @binding(${defines.pointLightShadowCameraBinding}) var<storage, read> pointLightUniform: PointLightUniform;\r\n   #endif\r\n\r\n   @group(0) @binding(${defines.selfBinding}) var<uniform> selfUniform : SelfUniform;\r\n   @group(1) @binding(${defines.cameraBinding}) var<uniform> systemUniform : SystemUniform;\r\n\r\n   @vertex\r\n   fn main(input: VertexInput) -> VertexOutput {\r\n      var output:VertexOutput;\r\n      #if ${defines.isPointLightShadowMap}\r\n         output.position = pointLightUniform.vpMatrix * selfUniform.modelMatrix * vec4<f32>(input.position,1.0);\r\n      #else\r\n         output.position = systemUniform.projectionMatrix * systemUniform.viewMatrix * selfUniform.modelMatrix * vec4<f32>(input.position,1.0);\r\n      #endif\r\n      return output;\r\n   }\r\n   `;\r\n}\r\n","// import Color from \"../../math/Color\";\r\n\r\nexport default function shadowMapFrag(defines) {\r\n\treturn `\r\n    struct VertexOutput {\r\n        @builtin(position) position: vec4<f32>,\r\n        @location(0) color: vec4<f32>,\r\n    };\r\n    @fragment\r\n    fn main(input:VertexOutput) -> @location(0) vec4<f32> {\r\n      return input.color;\r\n    }\r\n    `;\r\n}\r\n","import ShaderChunk from \"./shaderChunk/ShaderChunk\";\r\nimport phongVert from \"./material/phongVert\";\r\nimport phongFrag from \"./material/phongFrag\";\r\nimport colorFrag from \"./material/colorFrag\";\r\nimport colorVert from \"./material/colorVert\";\r\nimport pbrFrag from \"./material/pbrFrag\";\r\nimport pbrVert from \"./material/pbrVert\";\r\nimport skyBoxFrag from \"./material/skyBoxFrag\";\r\nimport skyBoxVert from \"./material/skyBoxVert\";\r\nimport quadFrag from \"./material/quadFrag\";\r\nimport quadVert from \"./material/quadVert\";\r\nimport pbr_vs from \"./material/pbr_vs\";\r\nimport pbr_fs from \"./material/pbr_fs\";\r\nimport Blur from \"./postProcess/bloom/Blur\";\r\nimport LuminosityHigh from \"./postProcess/bloom/LuminosityHigh\";\r\nimport blendFrag from \"./postProcess/blend/blendFrag\";\r\nimport shadowMapDebuggerFrag from \"./shaderChunk/shadow/shadowMapDebuggerFrag\";\r\nimport shadowMapDebuggerVert from \"./shaderChunk/shadow/shadowMapDebuggerVert\";\r\nimport shadowMapVert from \"./shaderChunk/shadow/shadowMapVert\";\r\nimport shadowMapFrag from \"./shaderChunk/shadow/shadowMapFrag\";\r\n\r\nfunction reduceComma(shader) {\r\n\t//对所有的include处理\r\n\tconst str = resolveIncludes(shader);\r\n\treturn str;\r\n}\r\nconst includePattern = /^[ \\t]*#include +<([\\w\\d./]+)>/gm;\r\nlet currentDefines = {};\r\nconst shaders = {\r\n\tphong: {\r\n\t\tfrag: phongFrag,\r\n\t\tvert: phongVert\r\n\t},\r\n\tcolor: {\r\n\t\tfrag: colorFrag,\r\n\t\tvert: colorVert\r\n\t},\r\n\tpbr: {\r\n\t\tfrag: pbrFrag,\r\n\t\tvert: pbrVert\r\n\t},\r\n\tskybox: {\r\n\t\tfrag: skyBoxFrag,\r\n\t\tvert: skyBoxVert\r\n\t},\r\n\tresolve: {\r\n\t\tfrag: quadFrag,\r\n\t\tvert: quadVert\r\n\t},\r\n\tpbr_mat: {\r\n\t\tfrag: pbr_fs,\r\n\t\tvert: pbr_vs\r\n\t},\r\n\tblur: {\r\n\t\tfrag: Blur,\r\n\t\tvert: quadVert\r\n\t},\r\n\tluminosityHigh: {\r\n\t\tfrag: LuminosityHigh,\r\n\t\tvert: quadVert\r\n\t},\r\n\tblend: {\r\n\t\tfrag: blendFrag,\r\n\t\tvert: quadVert\r\n\t},\r\n\tshadowMapDebugger: {\r\n\t\tfrag: shadowMapDebuggerFrag,\r\n\t\tvert: shadowMapDebuggerVert\r\n\t},\r\n\tshadowMap: {\r\n\t\tvert: shadowMapVert,\r\n\t\tfrag: shadowMapFrag\r\n\t}\r\n};\r\n\r\nfunction resolveIncludes(string) {\r\n\treturn string.replace(includePattern, includeReplacer);\r\n}\r\n\r\nfunction includeReplacer(match, include) {\r\n\tconst excute = ShaderChunk[include];\r\n\tif (excute === undefined) {\r\n\t\tthrow new Error(`Can not resolve #include <${include}>`);\r\n\t}\r\n\tconst result = excute(currentDefines);\r\n\treturn resolveIncludes(result);\r\n}\r\nexport default function getVertFrag(type, defines = {}) {\r\n\tconst excuteFunc = shaders[type];\r\n\tcurrentDefines = defines;\r\n\treturn {\r\n\t\tvert: reduceComma(excuteFunc.vert(currentDefines)),\r\n\t\tfrag: reduceComma(excuteFunc.frag(currentDefines))\r\n\t};\r\n}\r\n","import defaultValue from \"../utils/defaultValue\";\r\nimport getVertFrag from \"./Shaders\";\r\nexport interface GPUShaderModuleObject {\r\n\tvert: GPUShaderModule;\r\n\tfrag: GPUShaderModule;\r\n}\r\nexport class ShaderSource {\r\n\tvertEntryPoint?: string;\r\n\tfragEntryPoint?: string;\r\n\tvert?: string | Function;\r\n\tfrag?: string | Function;\r\n\tcompute?: string | Function;\r\n\tcomputeMain?: string;\r\n\tdefines?: {};\r\n\tdirty: boolean;\r\n\trender: boolean;\r\n\ttype: string;\r\n\tprivate _uid: string;\r\n\tprivate custom: boolean;\r\n\tconstructor(options) {\r\n\t\tthis.type = options.type;\r\n\t\tthis.defines = options.defines;\r\n\t\tthis.custom = defaultValue(options.custom, false);\r\n\t\tthis.dirty = true;\r\n\t\tif (options.render) {\r\n\t\t\tthis.render = true;\r\n\t\t\tthis.vertEntryPoint = options.vertMain || \"main\";\r\n\t\t\tthis.fragEntryPoint = options.fragMain || \"main\";\r\n\t\t\tthis.vert = options.vert || undefined;\r\n\t\t\tthis.frag = options.frag || undefined;\r\n\t\t} else {\r\n\t\t\tthis.compute = options.compute || undefined;\r\n\t\t\tthis.computeMain = options.computeMain || \"main\";\r\n\t\t}\r\n\t}\r\n\tget uid() {\r\n\t\tthis._uid = this.type.concat(JSON.stringify(this.defines));\r\n\t\treturn this._uid;\r\n\t}\r\n\tprivate updateShaderStr() {\r\n\t\tif (this.custom) {\r\n\t\t\tif (this.compute) {\r\n\t\t\t\tthis.compute = (<Function>this.compute)(this.defines);\r\n\t\t\t} else {\r\n\t\t\t\tthis.vert = this.vert instanceof Function ? this.vert(this.defines) : this.vert;\r\n\t\t\t\tthis.frag = this.frag instanceof Function ? this.frag(this.defines) : this.frag;\r\n\t\t\t}\r\n\t\t} else {\r\n\t\t\tconst source = getVertFrag(this.type, this.defines);\r\n\r\n\t\t\tthis.vert = source.vert;\r\n\t\t\tthis.frag = source.frag;\r\n\t\t}\r\n\t}\r\n\tpublic setDefines(defines) {\r\n\t\tif (!defines) return;\r\n\t\tthis.dirty = true;\r\n\t\tthis.defines = Object.assign(this.defines, defines);\r\n\t}\r\n\tcreateShaderModule(device: GPUDevice): { vert: GPUShaderModule; frag: GPUShaderModule } | GPUShaderModule {\r\n\t\tif (this.dirty) {\r\n\t\t\tthis.updateShaderStr();\r\n\t\t\tthis.dirty = false;\r\n\t\t}\r\n\t\tif (this.render) {\r\n\t\t\tconst vert = this.vert\r\n\t\t\t\t? device.createShaderModule({\r\n\t\t\t\t\t\tcode: <string>this.vert\r\n\t\t\t\t  })\r\n\t\t\t\t: undefined;\r\n\t\t\tconst frag = this.frag\r\n\t\t\t\t? device.createShaderModule({\r\n\t\t\t\t\t\tcode: <string>this.frag\r\n\t\t\t\t  })\r\n\t\t\t\t: undefined;\r\n\r\n\t\t\treturn { vert, frag };\r\n\t\t} else {\r\n\t\t\tconst compute = device.createShaderModule({\r\n\t\t\t\tcode: <string>this.compute\r\n\t\t\t});\r\n\t\t\treturn compute;\r\n\t\t}\r\n\t}\r\n\tstatic replaceMain(source: string, renamedMain: string) {\r\n\t\trenamedMain = `void ${renamedMain}()`;\r\n\t\treturn source.replace(/void\\s+main\\s*\\(\\s*(?:void)?\\s*\\)/g, renamedMain);\r\n\t}\r\n\tstatic compileCustomShaderbackUp(template, defines): string {\r\n\t\tconst reg = /\\{\\{(\\w+)\\}\\}/;\r\n\t\tif (reg.test(template)) {\r\n\t\t\tconst name = reg.exec(template)[1];\r\n\t\t\ttemplate = template.replace(reg, defines[name]);\r\n\t\t\treturn ShaderSource.compileCustomShader(template, defines);\r\n\t\t}\r\n\t\treturn template;\r\n\t}\r\n\tstatic compileCustomShader(template, defines): string {\r\n\t\tconst reg = /\\${(\\w+).(\\w+)}/;\r\n\t\tif (reg.test(template)) {\r\n\t\t\tconst regValue = reg.exec(template);\r\n\t\t\tconst define = regValue[2];\r\n\t\t\tconst name = regValue[0];\r\n\t\t\ttemplate = template.replace(name, defines[define]);\r\n\t\t\treturn ShaderSource.compileCustomShader(template, defines);\r\n\t\t}\r\n\t\treturn template;\r\n\t}\r\n}\r\n","import { IUniform, Uniforms } from \"../core/WebGPUTypes\";\r\nimport ShaderData from \"../render/ShaderData\";\r\nimport UniformBuffer from \"../render/UniformBuffer\";\r\nimport { UniformEnum } from \"../render/Uniforms\";\r\nconst uniformArrayNames = [\"float-array\", \"vec2-array\", \"vec3-array\", \"vec4-array\"];\r\nexport function checkContainFloatType(uniforms) {\r\n\tlet result = 0;\r\n\tlet hasArraytype = false;\r\n\tconst uniformsNames = Object.getOwnPropertyNames(uniforms);\r\n\tuniformsNames.map((uniformsName) => {\r\n\t\tif (uniforms[uniformsName].type == \"texture\" || uniforms[uniformsName].type == \"sampler\") {\r\n\t\t\tresult += 0;\r\n\t\t} else {\r\n\t\t\tif (\r\n\t\t\t\tuniformArrayNames.find((name) => {\r\n\t\t\t\t\treturn name === uniforms[uniformsName].type;\r\n\t\t\t\t})\r\n\t\t\t) {\r\n\t\t\t\thasArraytype = true;\r\n\t\t\t} else {\r\n\t\t\t\tresult += 1;\r\n\t\t\t}\r\n\t\t}\r\n\t});\r\n\treturn {\r\n\t\thasFloat: result,\r\n\t\thasArraytype\r\n\t};\r\n}\r\nexport function addUniformToShaderData(\r\n\tname: string,\r\n\tuniform: IUniform,\r\n\tuniforms: Uniforms,\r\n\tshaderData: ShaderData,\r\n\tuniformBuffer?: UniformBuffer\r\n) {\r\n\tswitch (uniform.type) {\r\n\t\tcase \"float\":\r\n\t\t\tuniformBuffer.setUniform(\r\n\t\t\t\tname,\r\n\t\t\t\t() => {\r\n\t\t\t\t\treturn uniforms[name].value;\r\n\t\t\t\t},\r\n\t\t\t\tUniformEnum.Float\r\n\t\t\t);\r\n\t\t\tbreak;\r\n\t\tcase \"vec2\":\r\n\t\t\tuniformBuffer.setUniform(\r\n\t\t\t\tname,\r\n\t\t\t\t() => {\r\n\t\t\t\t\treturn uniforms[name].value;\r\n\t\t\t\t},\r\n\t\t\t\tUniformEnum.FloatVec2\r\n\t\t\t);\r\n\t\t\tbreak;\r\n\t\tcase \"vec3\":\r\n\t\t\tuniformBuffer.setUniform(\r\n\t\t\t\tname,\r\n\t\t\t\t() => {\r\n\t\t\t\t\treturn uniforms[name].value;\r\n\t\t\t\t},\r\n\t\t\t\tUniformEnum.FloatVec3\r\n\t\t\t);\r\n\t\t\tbreak;\r\n\t\tcase \"color\":\r\n\t\t\tuniformBuffer.setUniform(\r\n\t\t\t\tname,\r\n\t\t\t\t() => {\r\n\t\t\t\t\treturn uniforms[name].value;\r\n\t\t\t\t},\r\n\t\t\t\tUniformEnum.Color\r\n\t\t\t);\r\n\t\t\tbreak;\r\n\t\tcase \"vec4\":\r\n\t\t\tuniformBuffer.setUniform(\r\n\t\t\t\tname,\r\n\t\t\t\t() => {\r\n\t\t\t\t\treturn uniforms[name].value;\r\n\t\t\t\t},\r\n\t\t\t\tUniformEnum.FloatVec4\r\n\t\t\t);\r\n\t\tcase \"mat2\":\r\n\t\t\tuniformBuffer.setUniform(\r\n\t\t\t\tname,\r\n\t\t\t\t() => {\r\n\t\t\t\t\treturn uniforms[name].value;\r\n\t\t\t\t},\r\n\t\t\t\tUniformEnum.Mat2\r\n\t\t\t);\r\n\t\t\tbreak;\r\n\t\tcase \"mat3\":\r\n\t\t\tuniformBuffer.setUniform(\r\n\t\t\t\tname,\r\n\t\t\t\t() => {\r\n\t\t\t\t\treturn uniforms[name].value;\r\n\t\t\t\t},\r\n\t\t\t\tUniformEnum.Mat3\r\n\t\t\t);\r\n\t\tcase \"mat4\":\r\n\t\t\tuniformBuffer.setUniform(\r\n\t\t\t\tname,\r\n\t\t\t\t() => {\r\n\t\t\t\t\treturn uniforms[name].value;\r\n\t\t\t\t},\r\n\t\t\t\tUniformEnum.Mat4\r\n\t\t\t);\r\n\t\t\tbreak;\r\n\t\tcase \"float-array\":\r\n\t\t\tuniformBuffer.setUniform(\r\n\t\t\t\tname,\r\n\t\t\t\t() => {\r\n\t\t\t\t\treturn uniforms[name].value;\r\n\t\t\t\t},\r\n\t\t\t\tUniformEnum.FloatArray,\r\n\t\t\t\tuniforms[name].value.length\r\n\t\t\t);\r\n\t\t\tbreak;\r\n\t\tcase \"vec2-array\":\r\n\t\t\tuniformBuffer.setUniform(\r\n\t\t\t\tname,\r\n\t\t\t\t() => {\r\n\t\t\t\t\treturn uniforms[name].value;\r\n\t\t\t\t},\r\n\t\t\t\tUniformEnum.Vec2Array,\r\n\t\t\t\tuniforms[name].value.length\r\n\t\t\t);\r\n\t\t\tbreak;\r\n\t\tcase \"vec3-array\":\r\n\t\t\tuniformBuffer.setUniform(\r\n\t\t\t\tname,\r\n\t\t\t\t() => {\r\n\t\t\t\t\treturn uniforms[name].value;\r\n\t\t\t\t},\r\n\t\t\t\tUniformEnum.Vec3Array,\r\n\t\t\t\tuniforms[name].value.length\r\n\t\t\t);\r\n\t\t\tbreak;\r\n\t\tcase \"vec4-array\":\r\n\t\t\tuniformBuffer.setUniform(\r\n\t\t\t\tname,\r\n\t\t\t\t() => {\r\n\t\t\t\t\treturn uniforms[name].value;\r\n\t\t\t\t},\r\n\t\t\t\tUniformEnum.Vec4Array,\r\n\t\t\t\tuniforms[name].value.length\r\n\t\t\t);\r\n\t\t\tbreak;\r\n\t\tcase \"texture\":\r\n\t\t\tshaderData.setTexture(name, () => {\r\n\t\t\t\treturn uniforms[name].value;\r\n\t\t\t});\r\n\t\t\tbreak;\r\n\t\tcase \"sampler\":\r\n\t\t\tshaderData.setSampler(name, () => {\r\n\t\t\t\treturn uniforms[name].value;\r\n\t\t\t});\r\n\t\t\tbreak;\r\n\t\tdefault:\r\n\t\t\tthrow new Error(\"not match unifrom type\");\r\n\t\t\tbreak;\r\n\t}\r\n}\r\n","import BindGroupLayoutEntry from \"./BindGroupLayoutEntry\";\r\nconst layoutCache = new Map();\r\nclass BindGroupLayout {\r\n\tpublic gpuBindGroupLayout: GPUBindGroupLayout;\r\n\tindex: number;\r\n\tprivate constructor(device: GPUDevice, label: string, public entries: BindGroupLayoutEntry[] = [], index = 0) {\r\n\t\tthis.index = index || 0;\r\n\t\tthis.gpuBindGroupLayout = device.createBindGroupLayout({\r\n\t\t\tlabel: label,\r\n\t\t\tentries: entries.map(({ visibility, buffer, sampler, texture, storageTexture, binding }) => ({\r\n\t\t\t\tbinding,\r\n\t\t\t\tvisibility,\r\n\t\t\t\tbuffer,\r\n\t\t\t\tsampler,\r\n\t\t\t\ttexture,\r\n\t\t\t\tstorageTexture\r\n\t\t\t}))\r\n\t\t});\r\n\t}\r\n\tstatic getBindGroupLayoutFromCache(\r\n\t\tdevice: GPUDevice,\r\n\t\tlabel: string,\r\n\t\tentires: BindGroupLayoutEntry[],\r\n\t\tindex\r\n\t): BindGroupLayout {\r\n\t\tif (layoutCache.has(label)) {\r\n\t\t\treturn layoutCache.get(label);\r\n\t\t} else {\r\n\t\t\tconst bindGroupLayout = new BindGroupLayout(device, label, entires, index);\r\n\t\t\tlayoutCache.set(label, bindGroupLayout);\r\n\t\t\treturn bindGroupLayout;\r\n\t\t}\r\n\t}\r\n\tstatic removeBindGroupLayoutFromCache(bindGroupLayout: BindGroupLayout) {\r\n\t\tlayoutCache.delete(bindGroupLayout);\r\n\t}\r\n}\r\n\r\nexport default BindGroupLayout;\r\n","import { BindGroupLayoutEntryType } from \"../core/WebGPUTypes\";\r\nexport default class BindGroupLayoutEntry {\r\n  binding: number;\r\n  visibility: GPUShaderStageFlags;\r\n  uniforms?: any[];\r\n  buffer?: GPUBufferBindingLayout;\r\n  sampler?: GPUSamplerBindingLayout;\r\n  texture?: GPUTextureBindingLayout;\r\n  storageTexture?: GPUStorageTextureBindingLayout;\r\n  externalTexture?: GPUExternalTextureBindingLayout;\r\n  constructor(options: BindGroupLayoutEntryType) {\r\n    this.binding = options.binding;\r\n    this.visibility = options.visibility;\r\n    this.buffer = options.buffer;\r\n    this.sampler = options.sampler;\r\n    this.texture = options.texture;\r\n    this.storageTexture = options.storageTexture;\r\n    this.externalTexture = options.storageTexture;\r\n  }\r\n  getGPULayoutEntity() {\r\n    return {\r\n      binding: this.binding,\r\n      visibility: this.visibility,\r\n      buffer: this.buffer,\r\n      sampler: this.sampler,\r\n      texture: this.texture,\r\n      storageTexture: this.storageTexture,\r\n    };\r\n  }\r\n}\r\n","import defaultValue from \"../utils/defaultValue\";\r\nimport BindGroup from \"./BindGroup\";\r\nimport BindGroupEntity from \"./BindGroupEntity\";\r\nimport BindGroupLayout from \"./BindGroupLayout\";\r\nimport BindGroupLayoutEntry from \"./BindGroupLayoutEntry\";\r\nimport Context from \"./Context\";\r\nimport Sampler from \"./Sampler\";\r\nimport Texture from \"./Texture\";\r\nimport UniformBuffer from \"./UniformBuffer\";\r\nimport { UniformSampler, UniformTexture } from \"./Uniforms\";\r\nexport default class ShaderData {\r\n\tcurrentBinding: number;\r\n\r\n\tdefines: { [prop: string]: boolean | number };\r\n\r\n\tdefineDirty: boolean;\r\n\r\n\tlabel: string;\r\n\r\n\tbindGroup: BindGroup;\r\n\r\n\tgroupLayout: BindGroupLayout;\r\n\r\n\tlayoutIndex: number;\r\n\r\n\tgroupIndex: number;\r\n\r\n\tprotected _uniforms: Map<string, any>;\r\n\r\n\tconstructor(label: string, size?: number, layoutIndex?: number, groupIndex?) {\r\n\t\tthis.label = label;\r\n\t\tthis.currentBinding = 0;\r\n\t\tthis.defineDirty = true;\r\n\t\tthis.defines = {};\r\n\t\tthis._uniforms = new Map();\r\n\t\tthis.groupIndex = defaultValue(groupIndex, 0);\r\n\t\tthis.layoutIndex = defaultValue(layoutIndex, 0);\r\n\t}\r\n\tgetUniformBuffer(name: string): UniformBuffer {\r\n\t\treturn this._uniforms.get(name);\r\n\t}\r\n\tsetUniformBuffer(name: string, uniformBuffer: UniformBuffer) {\r\n\t\tif (this._uniforms.get(name)) return;\r\n\t\tuniformBuffer.binding = this.currentBinding;\r\n\t\tthis.setDefine(name.concat(\"Binding\"), this.currentBinding);\r\n\t\tthis.currentBinding += 1;\r\n\t\tthis._uniforms.set(name, uniformBuffer);\r\n\t}\r\n\tsetTexture(name: string, value: Function | Texture, binding?: number) {\r\n\t\tif (this._uniforms.get(name)) return;\r\n\t\tconst uniform = new UniformTexture(name, this.currentBinding, value);\r\n\t\tthis.setDefine(name.concat(\"Binding\"), this.currentBinding);\r\n\t\tthis.currentBinding += 1;\r\n\t\tthis._uniforms.set(name, uniform);\r\n\t}\r\n\tsetSampler(name: string, value: Function | Sampler, binding?: number) {\r\n\t\tif (this._uniforms.get(name)) return;\r\n\t\tconst uniform = new UniformSampler(name, this.currentBinding, value);\r\n\t\tthis.setDefine(name.concat(\"Binding\"), this.currentBinding);\r\n\t\tthis.currentBinding += 1;\r\n\t\tthis._uniforms.set(name, uniform);\r\n\t}\r\n\tsetDefine(name: string, value: boolean | number) {\r\n\t\tif (this.defines[name] === undefined) {\r\n\t\t\tthis.defineDirty = true;\r\n\t\t\tthis.defines[name] = value;\r\n\t\t} else {\r\n\t\t\tif (this.defines[name] === value) {\r\n\t\t\t\treturn;\r\n\t\t\t} else {\r\n\t\t\t\tthis.defineDirty = true;\r\n\t\t\t\tthis.defines[name] = value;\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\treplaceUniformBufferValue(name: string, value: Function | number | Object) {\r\n\t\tthis._uniforms.forEach((uniform) => {\r\n\t\t\tif (uniform?.isUniformBuffer) {\r\n\t\t\t\tuniform.replaceUniformValue(name, value);\r\n\t\t\t}\r\n\t\t});\r\n\t}\r\n\tbind(context: Context, passEncoder: GPURenderPassEncoder) {\r\n\t\tthis.uploadUniform(context);\r\n\t\tif (!this.groupLayout)\r\n\t\t\tthis.groupLayout = this.createBindGroupLayout(context.device, this.label, this.layoutIndex);\r\n\t\tif (!this.bindGroup) this.bindGroup = this.createBindGroup(context.device, this.label, this.groupIndex);\r\n\t\tthis.bindGroup.bind(passEncoder);\r\n\t}\r\n\tdestroy() {\r\n\t\tthis._uniforms.forEach((uniform) => {\r\n\t\t\tif (uniform.destroy) uniform?.destroy();\r\n\t\t});\r\n\t\tthis.label = undefined;\r\n\t\tthis.currentBinding = 1;\r\n\t\tthis.defineDirty = true;\r\n\t\tthis.defines = undefined;\r\n\t\tthis._uniforms.clear();\r\n\t\tBindGroupLayout.removeBindGroupLayoutFromCache(this.groupLayout);\r\n\t\tthis.bindGroup = undefined;\r\n\t}\r\n\tprivate createBindGroup(device: GPUDevice, label: string, groupIndex?: number) {\r\n\t\tconst { entities, dynamic, alignedSize, maxOffset } = this.createBindGroupEntity();\r\n\t\tconst bindGroup = new BindGroup({\r\n\t\t\tlabel: label,\r\n\t\t\tentires: entities,\r\n\t\t\tdevice: device,\r\n\t\t\tlayout: this.groupLayout,\r\n\t\t\tindex: groupIndex || 0, // 后续改成groupIndex\r\n\t\t\tdynamic,\r\n\t\t\talignedSize,\r\n\t\t\tmaxOffset\r\n\t\t});\r\n\t\treturn bindGroup;\r\n\t}\r\n\tprivate createBindGroupLayout(device: GPUDevice, label: string, layoutIndex?: number) {\r\n\t\tconst result = this.createBindGroupLayoutEntry();\r\n\t\tconst groupLayout = BindGroupLayout.getBindGroupLayoutFromCache(\r\n\t\t\tdevice,\r\n\t\t\tlabel + \"-\" + result.uid,\r\n\t\t\tresult.layouts,\r\n\t\t\tlayoutIndex || 0\r\n\t\t);\r\n\t\treturn groupLayout;\r\n\t}\r\n\tprotected uploadUniform(context: Context) {\r\n\t\tthis._uniforms.forEach((uniform) => {\r\n\t\t\tuniform.bind(context);\r\n\t\t});\r\n\t}\r\n\tprivate createBindGroupLayoutEntry() {\r\n\t\tlet uid = \"\";\r\n\t\tconst result = new Map();\r\n\t\tthis._uniforms.forEach((uniform) => {\r\n\t\t\tif (!result.has(uniform.name)) {\r\n\t\t\t\tuid = uid === \"\" ? uid.concat(uniform.name) : uid.concat(\", \").concat(uniform.name);\r\n\t\t\t\tresult.set(uniform.name, this.createOneLayoutEntry(uniform));\r\n\t\t\t}\r\n\t\t});\r\n\t\tuid = `uniforms[${uid}]`;\r\n\t\treturn { uid, layouts: [...result.values()] };\r\n\t}\r\n\tprivate createBindGroupEntity() {\r\n\t\tconst result = new Map();\r\n\t\tlet dynamic = false,\r\n\t\t\talignedSize = 0,\r\n\t\t\tmaxOffset = 0;\r\n\t\tthis._uniforms.forEach((uniform) => {\r\n\t\t\tif (!result.has(uniform.name)) {\r\n\t\t\t\tif (uniform?.hasDynamicOffset) {\r\n\t\t\t\t\tdynamic = true;\r\n\t\t\t\t\tmaxOffset = uniform.maxOffset;\r\n\t\t\t\t\talignedSize = Math.ceil(uniform.uniformsSize / (4 * 256)) * 256;\r\n\t\t\t\t}\r\n\t\t\t\tresult.set(uniform.name, this.creayeOneGroupEntity(uniform));\r\n\t\t\t}\r\n\t\t});\r\n\t\treturn {\r\n\t\t\tentities: [...result.values()],\r\n\t\t\tdynamic,\r\n\t\t\talignedSize,\r\n\t\t\tmaxOffset\r\n\t\t};\r\n\t}\r\n\tprivate createOneLayoutEntry(uniform) {\r\n\t\tlet layoutEntity;\r\n\t\tif (uniform.isUniformBuffer) {\r\n\t\t\tlayoutEntity = new BindGroupLayoutEntry({\r\n\t\t\t\tbinding: uniform.binding,\r\n\t\t\t\tbuffer: uniform.layoutType,\r\n\t\t\t\tvisibility: uniform.visibility\r\n\t\t\t});\r\n\t\t} else if (uniform.isTexture) {\r\n\t\t\tlayoutEntity = new BindGroupLayoutEntry({\r\n\t\t\t\tbinding: uniform.binding,\r\n\t\t\t\tvisibility: uniform.visibility,\r\n\t\t\t\ttexture: uniform.layoutType\r\n\t\t\t});\r\n\t\t} else if (uniform.isSampler) {\r\n\t\t\tlayoutEntity = new BindGroupLayoutEntry({\r\n\t\t\t\tbinding: uniform.binding,\r\n\t\t\t\tvisibility: uniform.visibility,\r\n\t\t\t\tsampler: uniform.layoutType\r\n\t\t\t});\r\n\t\t}\r\n\t\treturn layoutEntity;\r\n\t}\r\n\tprivate creayeOneGroupEntity(uniform) {\r\n\t\tlet groupEntity;\r\n\t\tif (uniform.isUniformBuffer) {\r\n\t\t\tgroupEntity = new BindGroupEntity({\r\n\t\t\t\tbinding: uniform.binding,\r\n\t\t\t\tresource: {\r\n\t\t\t\t\tbuffer: uniform.buffer.gpuBuffer,\r\n\t\t\t\t\toffset: uniform.offset,\r\n\t\t\t\t\tsize: uniform.bufferSize\r\n\t\t\t\t}\r\n\t\t\t});\r\n\t\t} else if (uniform.isTexture) {\r\n\t\t\tgroupEntity = new BindGroupEntity({\r\n\t\t\t\tbinding: uniform.binding,\r\n\t\t\t\tresource: uniform.texture.textureView\r\n\t\t\t});\r\n\t\t} else if (uniform.isSampler) {\r\n\t\t\tgroupEntity = new BindGroupEntity({\r\n\t\t\t\tbinding: uniform.binding,\r\n\t\t\t\tresource: uniform.sampler.gpuSampler\r\n\t\t\t});\r\n\t\t}\r\n\t\treturn groupEntity;\r\n\t}\r\n}\r\n","import { FrameState } from \"../core/FrameState\";\r\nimport { CullMode, PrimitiveTopology } from \"../core/WebGPUConstant\";\r\nimport Color from \"../math/Color\";\r\nimport { Mesh } from \"../mesh/Mesh\";\r\nimport { DepthStencil, RenderState, Target, Primitive } from \"../render/RenderState\";\r\nimport Sampler from \"../render/Sampler\";\r\nimport ShaderData from \"../render/ShaderData\";\r\nimport Texture from \"../render/Texture\";\r\nimport { ShaderSource } from \"../shader/ShaderSource\";\r\nexport class Material {\r\n\tpublic shaderData: ShaderData;\r\n\r\n\tcolor?: Color;\r\n\r\n\tbaseSampler?: Sampler;\r\n\r\n\tbaseTexture?: Texture;\r\n\r\n\ttype: string;\r\n\r\n\tlabel: string;\r\n\r\n\tshaderSource: ShaderSource;\r\n\r\n\ttransparent: boolean;\r\n\r\n\tdirty: boolean;\r\n\r\n\tlight: boolean;\r\n\r\n\tready: boolean;\r\n\r\n\tprivate _emissive: Color;\r\n\r\n\tprivate _opacity: number;\r\n\r\n\tprivate _emissiveIntensity: number;\r\n\r\n\tprivate _diffuse: Color;\r\n\r\n\tprivate _renderState: RenderState;\r\n\r\n\tprivate _doubleSided: boolean;\r\n\r\n\tconstructor() {\r\n\t\tthis.label = undefined;\r\n\t\tthis.type = undefined;\r\n\t\tthis.baseTexture = undefined;\r\n\t\tthis.baseSampler = undefined;\r\n\t\tthis._diffuse = new Color(0.0, 0.0, 0.0);\r\n\t\tthis._opacity = 1.0;\r\n\t\t// Buffer\r\n\t\tthis.shaderData = undefined;\r\n\t\tthis.shaderSource = undefined;\r\n\t\tthis.dirty = true;\r\n\t\tthis._emissive = new Color(0.0, 0.0, 0);\r\n\t\tthis._emissiveIntensity = 1.0;\r\n\t\tthis._doubleSided = true;\r\n\t\tthis.light = false;\r\n\t\tthis.ready = false;\r\n\t\tthis.init();\r\n\t}\r\n\tpublic set wireframe(value: boolean) {\r\n\t\tthis.renderState.primitive.topology = value ? PrimitiveTopology.LineList : PrimitiveTopology.TriangleList;\r\n\t}\r\n\tpublic get doubleSided() {\r\n\t\treturn this._doubleSided;\r\n\t}\r\n\tpublic set doubleSided(value: boolean) {\r\n\t\tthis._renderState.primitive.cullMode = value ? CullMode.None : CullMode.Back;\r\n\t\tthis._doubleSided = value;\r\n\t}\r\n\tpublic get renderState() {\r\n\t\treturn this._renderState;\r\n\t}\r\n\tpublic set renderState(value: RenderState) {\r\n\t\tthis._renderState = value;\r\n\t}\r\n\tpublic get diffuse(): Color {\r\n\t\treturn this._diffuse;\r\n\t}\r\n\tpublic set diffuse(v: Color) {\r\n\t\tthis._diffuse = v;\r\n\t}\r\n\tpublic get emissive(): Color {\r\n\t\treturn this._emissive;\r\n\t}\r\n\tpublic set emissive(v: Color) {\r\n\t\tthis._emissive = v;\r\n\t}\r\n\tpublic get emissiveIntensity(): number {\r\n\t\treturn this._emissiveIntensity;\r\n\t}\r\n\tpublic set emissiveIntensity(v: number) {\r\n\t\tthis._emissiveIntensity = v;\r\n\t}\r\n\tpublic get opacity(): number {\r\n\t\treturn this._opacity;\r\n\t}\r\n\tpublic set opacity(v: number) {\r\n\t\tthis._opacity = v;\r\n\t}\r\n\tonBeforeRender() {}\r\n\r\n\tonBeforeCompile() {}\r\n\tclone(): Material {\r\n\t\treturn null;\r\n\t}\r\n\tupdate(frameState?: FrameState, mesh?: Mesh) {}\r\n\tprotected createShaderData(mesh: Mesh, frameState?: FrameState) {\r\n\t\tif (this.shaderData) this.shaderData.destroy();\r\n\t\tthis.shaderData = new ShaderData(this.type, 0);\r\n\t\tthis.ready = true;\r\n\t}\r\n\tprivate init() {\r\n\t\t// 默认渲染状态\r\n\t\tconst primitive = new Primitive();\r\n\t\tconst target = new Target();\r\n\t\tconst depthStencil = new DepthStencil();\r\n\t\tthis._renderState = new RenderState();\r\n\t\tthis._renderState.primitive = primitive;\r\n\t\tthis._renderState.targets = [target];\r\n\t\tthis._renderState.depthStencil = depthStencil;\r\n\t}\r\n\tpublic destroy() {\r\n\t\tthis.label = undefined;\r\n\t\tthis.type = undefined;\r\n\t\tthis.baseTexture = undefined;\r\n\t\tthis.baseSampler = undefined;\r\n\t\tthis.color = undefined;\r\n\t}\r\n}\r\n","import { FrameState } from \"../core/FrameState\";\r\nimport { BufferBindingType, BufferUsage } from \"../core/WebGPUConstant\";\r\nimport { ShaderMaterialParms, Uniforms } from \"../core/WebGPUTypes\";\r\nimport { Mesh } from \"../mesh/Mesh\";\r\nimport UniformBuffer from \"../render/UniformBuffer\";\r\nimport { ShaderSource } from \"../shader/ShaderSource\";\r\nimport defaultValue from \"../utils/defaultValue\";\r\nimport { addUniformToShaderData, checkContainFloatType } from \"../utils/uniformUtils\";\r\nimport { Material } from \"./Material\";\r\n\r\nexport default class ShaderMaterial extends Material {\r\n\tuniforms: Uniforms;\r\n\tuniformBuffer: UniformBuffer;\r\n\tprivate shaderMaterialParms: ShaderMaterialParms;\r\n\tconstructor(options: ShaderMaterialParms) {\r\n\t\tsuper();\r\n\t\tconst { type, frag, vert, defines, light } = options;\r\n\t\tthis.type = type;\r\n\t\tthis.shaderMaterialParms = options;\r\n\t\tthis.shaderSource = new ShaderSource({\r\n\t\t\ttype,\r\n\t\t\tfrag,\r\n\t\t\tvert,\r\n\t\t\tcustom: true,\r\n\t\t\tdefines: defaultValue(defines, {}),\r\n\t\t\trender: true\r\n\t\t});\r\n\t\tthis.uniforms = options.uniforms;\r\n\t\tthis.uniformBuffer = undefined;\r\n\t\tthis.light = light || false;\r\n\t}\r\n\tupdate(frameState?: FrameState, mesh?: Mesh) {\r\n\t\tif (!this.shaderData || this.dirty) this.createShaderData(mesh);\r\n\t}\r\n\tclone() {\r\n\t\treturn new ShaderMaterial(this.shaderMaterialParms);\r\n\t}\r\n\tprotected createShaderData(mesh?: Mesh) {\r\n\t\tsuper.createShaderData(mesh);\r\n\t\tconst result = checkContainFloatType(this.uniforms);\r\n\t\tif (result.hasFloat) {\r\n\t\t\tthis.uniformBuffer = result.hasArraytype\r\n\t\t\t\t? new UniformBuffer({\r\n\t\t\t\t\t\tlabel: this.type + \"UniformBuffer\",\r\n\t\t\t\t\t\ttype: BufferBindingType.ReadOnlyStorage,\r\n\t\t\t\t\t\tusage: BufferUsage.Storage | BufferUsage.CopyDst\r\n\t\t\t\t  })\r\n\t\t\t\t: new UniformBuffer({ label: this.type + \"UniformBuffer\" });\r\n\t\t\tthis.shaderData.setUniformBuffer(this.type, this.uniformBuffer);\r\n\t\t}\r\n\t\tconst uniformsNames = Object.getOwnPropertyNames(this.uniforms);\r\n\t\tuniformsNames.map((uniformsName) => {\r\n\t\t\taddUniformToShaderData(\r\n\t\t\t\tuniformsName,\r\n\t\t\t\tthis.uniforms[uniformsName],\r\n\t\t\t\tthis.uniforms,\r\n\t\t\t\tthis.shaderData,\r\n\t\t\t\tthis.uniformBuffer\r\n\t\t\t);\r\n\t\t});\r\n\t}\r\n}\r\n","function createGuid() {\r\n  // http://stackoverflow.com/questions/105034/how-to-create-a-guid-uuid-in-javascript\r\n  return \"xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx\".replace(/[xy]/g, function (c) {\r\n    const r = (Math.random() * 16) | 0;\r\n    const v = c === \"x\" ? r : (r & 0x3) | 0x8;\r\n    return v.toString(16);\r\n  });\r\n}\r\nexport default createGuid;\r\n","import Camera from \"../camera/Camera\";\nimport { FrameState } from \"../core/FrameState\";\nimport LightManger from \"../core/LightManger\";\nimport RenderObject from \"../core/RenderObject\";\nimport { CommandSubType, Intersect } from \"../core/WebGPUConstant\";\nimport { RenderObjectType } from \"../core/WebGPUTypes\";\nimport Geometry from \"../geometry/Geometry\";\nimport { Material } from \"../material/Material\";\nimport DrawCommand from \"../render/DrawCommand\";\nimport createGuid from \"../utils/createGuid\";\nexport class Mesh extends RenderObject {\n\t[x: string]: any;\n\tuid: string;\n\tgeometry?: Geometry;\n\tmaterial?: Material;\n\tinstanceCount?: number;\n\tpriority?: number;\n\tdrawCommand?: DrawCommand;\n\tsubCommands: { [prop: string]: DrawCommand };\n\tdistanceToCamera?: number;\n\tconstructor(geometry?: Geometry, material?: Material) {\n\t\tsuper();\n\t\tthis.geometry = geometry;\n\t\tthis.material = material;\n\t\tthis.type = RenderObjectType.Mesh;\n\t\tthis.uid = createGuid();\n\t\tthis.subCommands = {};\n\t}\n\tget ready() {\n\t\treturn this.material.ready;\n\t}\n\tupdate(frameState: FrameState, camera?: Camera) {\n\t\t// update matrix\n\t\tthis.updateMatrix(this?.parent?.modelMatrix);\n\t\t// create\n\t\tthis.geometry.update(frameState);\n\t\tthis.material.update(frameState, this);\n\t\t// update boundingSphere\n\t\tthis.geometry.boundingSphere.update(this.modelMatrix);\n\t\tthis.material.shaderSource.setDefines(frameState.defines);\n\t\tif (this.type == RenderObjectType.Debug) {\n\t\t\tframeState.renderQueue.debugQueue.push(this);\n\t\t\treturn;\n\t\t}\n\t\tthis.distanceToCamera = this.geometry.boundingSphere.distanceToCamera(camera);\n\n\t\tconst visibility = frameState.cullingVolume.computeVisibility(this.geometry.boundingSphere);\n\t\t// 视锥剔除\n\t\tif (visibility === Intersect.OUTSIDE) return;\n\t\tif (this.material.transparent) {\n\t\t\tframeState.renderQueue.transparent.push(this);\n\t\t} else {\n\t\t\tframeState.renderQueue.opaque.push(this);\n\t\t}\n\t}\n\tbeforeRender() {}\n\tafterRender() {}\n\tpublic getDrawCommand(overrideMaterial?: Material, commandSubType?: CommandSubType, lightManger?: LightManger) {\n\t\tif (!this.drawCommand || this.material.dirty) {\n\t\t\tthis.material.shaderSource.setDefines(\n\t\t\t\tObject.assign(this.material.shaderData.defines, this.geometry.defines)\n\t\t\t);\n\t\t\tif (this.material.dirty) this.material.dirty = false;\n\t\t\tthis.drawCommand = new DrawCommand({\n\t\t\t\tvertexBuffer: this.geometry.vertBuffer,\n\t\t\t\tindexBuffer: this.geometry.indexBuffer,\n\t\t\t\tshaderData: this.material.shaderData,\n\t\t\t\tinstances: this.instanceCount,\n\t\t\t\tcount: this.geometry.count,\n\t\t\t\trenderState: this.material.renderState,\n\t\t\t\tshaderSource: this.material.shaderSource,\n\t\t\t\ttype: \"render\",\n\t\t\t\tlight: this.material.light,\n\t\t\t\tmodelMatrix: this.modelMatrix,\n\t\t\t\tlightShaderData: this.material.light ? lightManger?.lightShaderData : undefined\n\t\t\t});\n\t\t}\n\t\tif (overrideMaterial) {\n\t\t\tif (!this.subCommands[commandSubType]) {\n\t\t\t\tconst copyMat = overrideMaterial.clone();\n\t\t\t\toverrideMaterial.update();\n\t\t\t\tcopyMat.update();\n\t\t\t\tif (copyMat.dirty) copyMat.dirty = false;\n\t\t\t\tthis.subCommands[commandSubType] = this.drawCommand.shallowClone(copyMat);\n\t\t\t}\n\t\t\treturn this.subCommands[commandSubType];\n\t\t}\n\t\treturn this.drawCommand;\n\t}\n\tdestroy() {\n\t\tthis.geometry.destroy();\n\t\tthis.material.destroy();\n\t}\n}\n","import { RenderObjectType } from \"../core/WebGPUTypes\";\r\nimport Geometry from \"../geometry/Geometry\";\r\nimport PlaneGeometry from \"../geometry/PlaneGeometry\";\r\nimport { Light } from \"../light/Light\";\r\nimport ShaderMaterial from \"../material/ShaderMaterial\";\r\nimport { Mesh } from \"../mesh/Mesh\";\r\nimport { ViewPort } from \"../render/RenderState\";\r\nimport Sampler from \"../render/Sampler\";\r\nimport { Scene } from \"../Scene\";\r\nimport getVertFrag from \"../shader/Shaders\";\r\n\r\nexport class ShadowMapDebugger {\r\n\tprivate mesh: Mesh;\r\n\tprivate debuggerSize: { width: number; height: number };\r\n\tpublic light: Light;\r\n\tprivate geometry: Geometry;\r\n\tprivate material: ShaderMaterial;\r\n\tprivate scene: Scene;\r\n\r\n\tconstructor(light: Light, scene: Scene) {\r\n\t\tif (!light || !(light instanceof Light)) throw new Error(\"The parameter must be Light instance\");\r\n\r\n\t\tthis.light = light;\r\n\t\tthis.scene = scene;\r\n\t\tthis.debuggerSize = {\r\n\t\t\twidth: 256,\r\n\t\t\theight: 256\r\n\t\t};\r\n\r\n\t\tthis.mesh = this._createShadowMapMesh();\r\n\t\tconst shadowMap = this.light.shadow.getShadowMapTexture();\r\n\t\tthis.material.uniforms.texture.value = shadowMap;\r\n\t\tthis.mesh.type = RenderObjectType.Debug;\r\n\t\tthis.scene.add(this.mesh);\r\n\t}\r\n\r\n\t_createShadowMapMesh() {\r\n\t\tconst shader = getVertFrag(\"shadowMapDebugger\", {\r\n\t\t\tpositionLocation: 0\r\n\t\t});\r\n\t\tthis.geometry = new PlaneGeometry(2, 2);\r\n\t\tthis.material = new ShaderMaterial({\r\n\t\t\ttype: \"shadowMapDebugger\",\r\n\t\t\tfrag: shader.frag,\r\n\t\t\tvert: shader.vert,\r\n\t\t\tuniforms: {\r\n\t\t\t\ttexture: {\r\n\t\t\t\t\ttype: \"texture\",\r\n\t\t\t\t\tvalue: undefined\r\n\t\t\t\t},\r\n\t\t\t\tsampler: {\r\n\t\t\t\t\ttype: \"sampler\",\r\n\t\t\t\t\tvalue: new Sampler({\r\n\t\t\t\t\t\tmagFilter: \"linear\",\r\n\t\t\t\t\t\tminFilter: \"linear\"\r\n\t\t\t\t\t})\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t});\r\n\t\tthis.material.renderState.viewport = new ViewPort(0, 0, this.debuggerSize.width, this.debuggerSize.height);\r\n\t\treturn new Mesh(this.geometry, this.material);\r\n\t}\r\n\r\n\tsetSize(width: number, height: number) {\r\n\t\tif (!width || !height) return;\r\n\t\tthis.debuggerSize.width = width;\r\n\t\tthis.debuggerSize.height = height;\r\n\t\tthis.update();\r\n\t}\r\n\r\n\tupdate() {\r\n\t\tthis.material.renderState.viewport = new ViewPort(0, 0, this.debuggerSize.width, this.debuggerSize.height);\r\n\t}\r\n}\r\n","import { FrameState } from \"../core/FrameState\";\nimport { Mesh } from \"../mesh/Mesh\";\nimport UniformBuffer from \"../render/UniformBuffer\";\nimport { UniformEnum } from \"../render/Uniforms\";\nimport { ShaderSource } from \"../shader/ShaderSource\";\nimport { Material } from \"./Material\";\nexport default class ColorMaterial extends Material {\n\tconstructor() {\n\t\tsuper();\n\t\tthis.type = \"color\";\n\t\tthis.shaderSource = new ShaderSource({\n\t\t\ttype: this.type,\n\t\t\trender: true,\n\t\t\tdefines: {}\n\t\t});\n\t}\n\tupdate(frameState: FrameState, mesh: Mesh) {\n\t\tif (!this.shaderData || this.dirty) this.createShaderData(mesh);\n\t\tconst uniformBuffer = new UniformBuffer({ label: \"color\" });\n\t\tuniformBuffer.setUniform(\n\t\t\t\"modelMatrix\",\n\t\t\t() => {\n\t\t\t\treturn null;\n\t\t\t},\n\t\t\tUniformEnum.Mat4\n\t\t);\n\t\tthis.shaderData.setUniformBuffer(\"color\", uniformBuffer);\n\t}\n}\n","import { FrameState } from \"../core/FrameState\";\r\nimport { RenderObjectType } from \"../core/WebGPUTypes\";\r\nimport Geometry from \"../geometry/Geometry\";\r\nimport ColorMaterial from \"../material/ColorMaterial\";\r\nimport { Float32Attribute } from \"../render/Attribute\";\r\nimport { Mesh } from \"./Mesh\";\r\nexport default class Axes extends Mesh {\r\n\tmaterial: ColorMaterial;\r\n\tconstructor() {\r\n\t\tsuper();\r\n\t\tthis.type = RenderObjectType.Axes;\r\n\t\tthis.distanceToCamera = 10;\r\n\t\tthis.material = new ColorMaterial();\r\n\t\tthis.material.wireframe = true;\r\n\t\tthis.init();\r\n\t}\r\n\tupdate(frameState: FrameState) {\r\n\t\tthis.updateMatrix();\r\n\t\tthis.material.update(frameState, this);\r\n\t\tframeState.renderQueue.opaque.push(this);\r\n\t}\r\n\tprivate init() {\r\n\t\tconst position = [0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1];\r\n\t\tconst colors = [1, 0, 0, 1, 1, 0.5, 0.5, 1, 0, 1, 0, 1, 0.5, 1, 0.5, 1, 0, 0, 1, 1, 0.5, 0.5, 1, 1];\r\n\t\tconst indices = [0, 1, 2, 3, 4, 5];\r\n\t\tthis.geometry = new Geometry({});\r\n\t\tthis.geometry.setAttribute(new Float32Attribute(\"position\", position, 3));\r\n\t\tthis.geometry.setAttribute(new Float32Attribute(\"color\", colors, 4));\r\n\t\tthis.geometry.setIndice(indices);\r\n\t\tthis.geometry.count = indices.length;\r\n\t}\r\n}\r\n","import { Float32Attribute } from \"../render/Attribute\";\r\nimport Geometry from \"./Geometry\";\r\nexport default class SkyBoxGeometry extends Geometry {\r\n\tconstructor() {\r\n\t\tsuper({\r\n\t\t\ttype: \"skyBoxGeometry\"\r\n\t\t});\r\n\t\tthis.init();\r\n\t}\r\n\tpublic update(frameState) {\r\n\t\tconst { device } = frameState.context;\r\n\t}\r\n\tpublic init() {\r\n\t\tconst positions = [\r\n\t\t\t1.0,\r\n\t\t\t1.0,\r\n\t\t\t1.0, // 0\r\n\t\t\t-1.0,\r\n\t\t\t1.0,\r\n\t\t\t1.0, // 1\r\n\t\t\t1.0,\r\n\t\t\t-1.0,\r\n\t\t\t1.0, // 2\r\n\t\t\t-1.0,\r\n\t\t\t-1.0,\r\n\t\t\t1.0, // 3\r\n\t\t\t1.0,\r\n\t\t\t1.0,\r\n\t\t\t-1.0, // 4\r\n\t\t\t-1.0,\r\n\t\t\t1.0,\r\n\t\t\t-1.0, // 5\r\n\t\t\t1.0,\r\n\t\t\t-1.0,\r\n\t\t\t-1.0, // 6\r\n\t\t\t-1.0,\r\n\t\t\t-1.0,\r\n\t\t\t-1.0 // 7\r\n\t\t];\r\n\t\tconst indices = [\r\n\t\t\t// PosX (Right)\r\n\t\t\t0, 2, 4, 6, 4, 2,\r\n\r\n\t\t\t// NegX (Left)\r\n\t\t\t5, 3, 1, 3, 5, 7,\r\n\r\n\t\t\t// PosY (Top)\r\n\t\t\t4, 1, 0, 1, 4, 5,\r\n\r\n\t\t\t// NegY (Bottom)\r\n\t\t\t2, 3, 6, 7, 6, 3,\r\n\r\n\t\t\t// PosZ (Front)\r\n\t\t\t0, 1, 2, 3, 2, 1,\r\n\r\n\t\t\t// NegZ (Back)\r\n\t\t\t6, 5, 4, 5, 6, 7\r\n\t\t];\r\n\t\tthis.setAttribute(new Float32Attribute(\"position\", positions, 3));\r\n\t\tthis.setIndice(indices);\r\n\t\tthis.count = indices.length;\r\n\t}\r\n}\r\n","function returnTrue() {\r\n\treturn true;\r\n}\r\nexport function destroyObject(object) {\r\n\t// message =message||\"This object was destroyed, i.e., destroy() was called.\";\r\n\r\n\tfunction throwOnDestroyed() {\r\n\t\tthrow new Error(\"This object was destroyed, i.e., destroy() was called.\");\r\n\t}\r\n\r\n\tfor (const key in object) {\r\n\t\tif (typeof object[key] === \"function\") {\r\n\t\t\tobject[key] = throwOnDestroyed;\r\n\t\t}\r\n\t}\r\n\r\n\tobject.isDestroyed = returnTrue;\r\n\r\n\treturn undefined;\r\n}\r\n","import Sampler from \"../render/Sampler\";\nimport Texture from \"../render/Texture\";\nimport defined from \"../utils/defined\";\nimport { destroyObject } from \"../utils/destroyObject\";\ntype TextureCacheProp = {\n\ttexture: Texture;\n\tcount: number;\n};\nclass TextureCache {\n\tpublic defaultSampler: Sampler;\n\tprivate _numberOfTextures: number;\n\tprivate _textures: Map<string, TextureCacheProp>;\n\tprivate _texturesToRelease: Map<string, TextureCacheProp>;\n\tconstructor() {\n\t\tthis._numberOfTextures = 0;\n\t\tthis._textures = new Map();\n\t\tthis._numberOfTextures = 0;\n\t\tthis._texturesToRelease = new Map();\n\t\tthis.defaultSampler = new Sampler({\n\t\t\tmagFilter: \"linear\",\n\t\t\tminFilter: \"linear\",\n\t\t\taddressModeU: \"repeat\",\n\t\t\taddressModeV: \"repeat\"\n\t\t});\n\t}\n\tget numberOfTextures(): number {\n\t\treturn this._numberOfTextures;\n\t}\n\tgetTexture(keyword) {\n\t\tconst cachedTexture = this._textures.get(keyword);\n\t\tif (!defined(cachedTexture)) {\n\t\t\treturn undefined;\n\t\t}\n\t\t// No longer want to release this if it was previously released.\n\t\tdelete this._texturesToRelease[keyword];\n\n\t\t++cachedTexture.count;\n\t\treturn cachedTexture.texture;\n\t}\n\taddTexture(keyword, texture) {\n\t\tconst cachedTexture = {\n\t\t\ttexture: texture,\n\t\t\tcount: 1\n\t\t};\n\n\t\ttexture.finalDestroy = texture.destroy;\n\n\t\t// const that = this;\n\t\ttexture.destroy = () => {\n\t\t\tif (--cachedTexture.count === 0) {\n\t\t\t\tthis._texturesToRelease.set(keyword, cachedTexture);\n\t\t\t}\n\t\t};\n\n\t\tthis._textures.set(keyword, cachedTexture);\n\t\t++this._numberOfTextures;\n\t}\n\treleasedTextures() {\n\t\tthis._texturesToRelease.forEach((cacheTexture) => {\n\t\t\tcacheTexture.texture?.finalDestroy();\n\t\t\t--this._numberOfTextures;\n\t\t});\n\n\t\tthis._texturesToRelease.clear();\n\t}\n\tdestroy() {\n\t\tthis._textures.forEach((cachedTexture) => {\n\t\t\tcachedTexture.texture?.finalDestroy();\n\t\t});\n\t\treturn destroyObject(this);\n\t}\n}\nconst textureCache = new TextureCache();\nexport default textureCache;\n","import Sampler from \"../render/Sampler\";\nimport Texture from \"../render/Texture\";\n\nexport default async function CubeTextureLoader(urls) {\n\tconst promises = urls.map((src) => {\n\t\tconst img = document.createElement(\"img\");\n\t\timg.src = src;\n\t\treturn img.decode().then(() => createImageBitmap(img));\n\t});\n\tconst images = await Promise.all(promises);\n\tawait Promise.all(images);\n\tconst baseSampler = new Sampler({\n\t\tmagFilter: \"linear\",\n\t\tminFilter: \"linear\"\n\t});\n\tconst data = images.map((image, i) => {\n\t\treturn {\n\t\t\tsource: image,\n\t\t\twidth: image.width,\n\t\t\theight: image.height,\n\t\t\tdepth: 1,\n\t\t\tx: 0,\n\t\t\ty: 0,\n\t\t\tz: i\n\t\t};\n\t});\n\tconst baseTexture = new Texture({\n\t\tsize: {\n\t\t\twidth: images[0].width,\n\t\t\theight: images[0].height,\n\t\t\tdepth: 6\n\t\t},\n\t\tformat: \"rgba8unorm\",\n\t\tusage: GPUTextureUsage.TEXTURE_BINDING | GPUTextureUsage.COPY_DST | GPUTextureUsage.RENDER_ATTACHMENT,\n\t\tsampler: baseSampler,\n\t\tdata,\n\t\tviewFormats: \"cube\",\n\t\tmipLevelCount: 6,\n\t\tneedMipMap: true\n\t});\n\treturn {\n\t\ttexture: baseTexture,\n\t\tsampler: baseSampler\n\t};\n}\n","import { FrameState } from \"../core/FrameState\";\r\nimport textureCache from \"../core/TextureCache\";\r\nimport { CompareFunction } from \"../core/WebGPUConstant\";\r\nimport CubeTextureLoader from \"../loader/CubeTextureLoader\";\r\nimport { Mesh } from \"../mesh/Mesh\";\r\nimport UniformBuffer from \"../render/UniformBuffer\";\r\nimport { UniformEnum } from \"../render/Uniforms\";\r\nimport { ShaderSource } from \"../shader/ShaderSource\";\r\nimport { Material } from \"./Material\";\r\nexport default class SkyBoxMaterial extends Material {\r\n\tloadFish: boolean;\r\n\tconstructor() {\r\n\t\tsuper();\r\n\t\tthis.type = \"skybox\";\r\n\t\tthis.shaderSource = new ShaderSource({\r\n\t\t\ttype: this.type,\r\n\t\t\trender: true,\r\n\t\t\tdefines: {}\r\n\t\t});\r\n\t\tthis.loadFish = false;\r\n\t\tthis.renderState.depthStencil.depthWriteEnabled = false;\r\n\t\tthis.renderState.depthStencil.depthCompare = CompareFunction.LessEqual;\r\n\t}\r\n\tasync loadTexture(urls) {\r\n\t\tconst result = await CubeTextureLoader(urls);\r\n\t\tthis.loadFish = true;\r\n\t\ttextureCache.addTexture(\"specular\", result.texture);\r\n\t\tthis.baseTexture = result.texture;\r\n\t\tthis.baseSampler = result.sampler;\r\n\t}\r\n\tupdate(frameState: FrameState, mesh: Mesh) {\r\n\t\tif (!this.loadFish) return;\r\n\t\tif (!this.shaderData) {\r\n\t\t\tthis.createShaderData(mesh);\r\n\t\t}\r\n\t}\r\n\tprotected createShaderData(mesh: Mesh) {\r\n\t\tsuper.createShaderData(mesh);\r\n\t\tconst uniformBuffer = new UniformBuffer({ label: \"skybox\" });\r\n\t\tuniformBuffer.setUniform(\r\n\t\t\t\"modelMatrix\",\r\n\t\t\t() => {\r\n\t\t\t\treturn null;\r\n\t\t\t},\r\n\t\t\tUniformEnum.Mat4\r\n\t\t);\r\n\t\tthis.shaderData.setUniformBuffer(\"skybox\", uniformBuffer);\r\n\t\tthis.shaderData.setTexture(\"baseTexture\", this.baseTexture);\r\n\t\tthis.shaderData.setSampler(\"baseSampler\", this.baseSampler);\r\n\t}\r\n}\r\n","import { FrameState } from \"../core/FrameState\";\r\nimport { RenderObjectType } from \"../core/WebGPUTypes\";\r\nimport SkyBoxGeometry from \"../geometry/SkyBoxGeometry\";\r\nimport SkyBoxMaterial from \"../material/SkyBoxMaterial\";\r\nimport { Mesh } from \"./Mesh\";\r\nexport default class SkyBox extends Mesh {\r\n\tmaterial: SkyBoxMaterial;\r\n\tpublic visibility: boolean;\r\n\tconstructor(urls?: Array<string>) {\r\n\t\tsuper();\r\n\t\tthis.type = RenderObjectType.Skybox;\r\n\t\tthis.visibility = true;\r\n\t\tthis.material = new SkyBoxMaterial();\r\n\t\tif (urls) this.material.loadTexture(urls);\r\n\t\tthis.geometry = new SkyBoxGeometry();\r\n\t\tthis.isSkyBox = true;\r\n\t}\r\n\tupdate(frameState: FrameState) {\r\n\t\tthis.updateMatrix();\r\n\t\tthis.geometry.update(frameState);\r\n\t\tthis.material.update(frameState, this);\r\n\t\tif (this.visibility) frameState.renderQueue.pre.push(this);\r\n\t}\r\n}\r\n","import RenderObject from \"../core/RenderObject\";\nimport Matrix4 from \"../math/Matrix4\";\nimport createGuid from \"../utils/createGuid\";\n\nexport class Instance extends RenderObject {\n\tpublic id: string | number;\n\tpublic visiblity: boolean;\n\tprivate _notUpdateMatrix: boolean;\n\tconstructor() {\n\t\tsuper();\n\t\tthis._notUpdateMatrix = false;\n\t\tthis.visiblity = false;\n\t\tthis.id = createGuid();\n\t}\n\tsetMatrix4(mat4: Matrix4) {\n\t\tthis.modelMatrix.set(mat4);\n\t\tthis._notUpdateMatrix = true;\n\t}\n\tupdateMatrix(matrix?: Matrix4) {\n\t\tif (this._notUpdateMatrix) return;\n\t\tsuper.updateMatrix(matrix);\n\t}\n}\n","import Camera from \"../camera/Camera\";\nimport { FrameState } from \"../core/FrameState\";\nimport { BufferBindingType, BufferUsage, Intersect } from \"../core/WebGPUConstant\";\nimport Geometry from \"../geometry/Geometry\";\nimport { Material } from \"../material/Material\";\nimport UniformBuffer from \"../render/UniformBuffer\";\nimport { UniformEnum } from \"../render/Uniforms\";\nimport { Instance } from \"./Instance\";\nimport { Mesh } from \"./Mesh\";\n\nexport class InstanceMesh extends Mesh {\n\tprivate instances: Map<string | number, Instance>;\n\tprivate renderInstances: Array<Instance>;\n\tprivate hasAddInstances: boolean;\n\tconstructor(geo: Geometry, mat: Material) {\n\t\tsuper(geo, mat);\n\t\tthis.instances = new Map();\n\t\tthis.renderInstances = [];\n\t\tthis.hasAddInstances = false;\n\t}\n\tupdate(frameState: FrameState, camera?: Camera) {\n\t\t// create\n\t\tthis.geometry.update(frameState);\n\t\tthis.material.update(frameState, this);\n\t\t// update instances visiblity\n\t\tthis.checkInstancesVisiblity({ frameState, camera });\n\t\tif (!this.hasAddInstances) this.addUniformsToMaterial();\n\t\tthis.instanceCount = this.renderInstances.length;\n\t\tif (this.renderInstances.length < 1) return;\n\t\tif (this.material.transparent) {\n\t\t\tframeState.renderQueue.transparent.push(this);\n\t\t} else {\n\t\t\tframeState.renderQueue.opaque.push(this);\n\t\t}\n\t}\n\taddInstance(instance: Instance) {\n\t\tif (this.instances.get(instance.id)) return;\n\t\tthis.instances.set(instance.id, instance);\n\t}\n\tremoveInstance(key: number | string) {\n\t\treturn this.instances.delete(key);\n\t}\n\tgetInstance(key: number | string) {\n\t\treturn this.instances.get(key);\n\t}\n\tprivate checkInstancesVisiblity(options: { frameState: FrameState; camera: Camera }) {\n\t\tconst { frameState, camera } = options;\n\t\tthis.instances.forEach((instance: Instance) => {\n\t\t\tinstance.updateMatrix(this?.parent?.modelMatrix);\n\t\t\tinstance.visiblity = this.getInstanceVisiblity({ instance, frameState, camera });\n\t\t\tif (instance.visiblity) this.renderInstances.push(instance);\n\t\t});\n\t}\n\tprivate getInstanceVisiblity(options: { instance: Instance; frameState: FrameState; camera: Camera }): boolean {\n\t\tconst { instance, frameState, camera } = options;\n\t\tthis.geometry.boundingSphere.update(instance.modelMatrix);\n\t\tthis.distanceToCamera = this.geometry.boundingSphere.distanceToCamera(camera);\n\t\tconst visibility = frameState.cullingVolume.computeVisibility(this.geometry.boundingSphere);\n\t\treturn visibility === Intersect.INTERSECTING || visibility === Intersect.INSIDE;\n\t}\n\tprivate addUniformsToMaterial() {\n\t\tif (!this.material.shaderData) return;\n\t\tthis.hasAddInstances = true;\n\t\tconst instanceMatrixsBuffer = new UniformBuffer({\n\t\t\tlabel: \"instanceMatrixsBuffer\",\n\t\t\ttype: BufferBindingType.ReadOnlyStorage,\n\t\t\tusage: BufferUsage.Storage | BufferUsage.CopyDst,\n\t\t\tsize: this.instances.size * 64\n\t\t});\n\t\tinstanceMatrixsBuffer.setUniform(\n\t\t\t\"instanceMatrixs\",\n\t\t\t() => {\n\t\t\t\treturn this?.renderInstances?.map((renderInstance: Instance) => renderInstance.modelMatrix);\n\t\t\t},\n\t\t\tUniformEnum.Mat4Array,\n\t\t\tthis?.renderInstances?.length\n\t\t);\n\t\tthis.material.shaderData.setUniformBuffer(\"instanceMatrixsBuffer\", instanceMatrixsBuffer);\n\t\tthis.material.shaderData.setDefine(\"USE_INSTANCE\", true);\n\t\tthis.material.shaderData.setDefine(\"instanceCount\", this?.renderInstances?.length);\n\t}\n}\n","/**\r\n * Ensure first argument passed to the primitive functions is an object\r\n * @param {...*} args\r\n */\r\nfunction checkArguments(args) {\r\n\tconst argumentType = typeof args[0];\r\n\tif (argumentType !== \"object\" && argumentType !== \"undefined\") {\r\n\t\tconsole.error(\"First argument must be an object.\");\r\n\t}\r\n}\r\n\r\n/**\r\n * @private\r\n */\r\nlet TYPED_ARRAY_TYPE;\r\n\r\n/**\r\n * Select cells typed array from a size determined by amount of vertices.\r\n *\r\n * @param {number} size The max value expected\r\n * @returns {(Uint8Array|Uint16Array|Uint32Array)}\r\n * @see [MDN TypedArray objects]{@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/TypedArray#typedarray_objects}\r\n */\r\nconst getCellsTypedArray = (size) =>\r\n\tTYPED_ARRAY_TYPE || (size <= 255 ? Uint8Array : size <= 65535 ? Uint16Array : Uint32Array);\r\n\r\n/**\r\n * @private\r\n */\r\nconst PLANE_DIRECTIONS = {\r\n\tz: [0, 1, 2, 1, -1, 1],\r\n\t\"-z\": [0, 1, 2, -1, -1, -1],\r\n\t\"-x\": [2, 1, 0, 1, -1, -1],\r\n\tx: [2, 1, 0, -1, -1, 1],\r\n\ty: [0, 2, 1, 1, 1, 1],\r\n\t\"-y\": [0, 2, 1, 1, -1, -1]\r\n};\r\n\r\n/**\r\n * @private\r\n */\r\nfunction computePlane(\r\n\tgeometry,\r\n\tindices,\r\n\tsu,\r\n\tsv,\r\n\tnu,\r\n\tnv,\r\n\tdirection = \"z\",\r\n\tpw = 0,\r\n\tquads = false,\r\n\tuvScale = [1, 1],\r\n\tuvOffset = [0, 0],\r\n\tcenter = [0, 0, 0],\r\n\tccw = true\r\n) {\r\n\tconst { positions, normals, uvs, cells } = geometry;\r\n\tconst [u, v, w, flipU, flipV, normal] = PLANE_DIRECTIONS[direction];\r\n\r\n\tconst vertexOffset = indices.vertex;\r\n\r\n\tfor (let j = 0; j <= nv; j++) {\r\n\t\tfor (let i = 0; i <= nu; i++) {\r\n\t\t\tpositions[indices.vertex * 3 + u] = (-su / 2 + (i * su) / nu) * flipU + center[u];\r\n\t\t\tpositions[indices.vertex * 3 + v] = (-sv / 2 + (j * sv) / nv) * flipV + center[v];\r\n\t\t\tpositions[indices.vertex * 3 + w] = pw + center[w];\r\n\r\n\t\t\tnormals[indices.vertex * 3 + w] = normal;\r\n\r\n\t\t\tuvs[indices.vertex * 2] = (i / nu) * uvScale[0] + uvOffset[0];\r\n\t\t\tuvs[indices.vertex * 2 + 1] = (1 - j / nv) * uvScale[1] + uvOffset[1];\r\n\r\n\t\t\tindices.vertex++;\r\n\r\n\t\t\tif (j < nv && i < nu) {\r\n\t\t\t\tconst n = vertexOffset + j * (nu + 1) + i;\r\n\t\t\t\tif (quads) {\r\n\t\t\t\t\tconst o = vertexOffset + (j + 1) * (nu + 1) + i;\r\n\t\t\t\t\tcells[indices.cell] = n;\r\n\t\t\t\t\tcells[indices.cell + 1] = o;\r\n\t\t\t\t\tcells[indices.cell + 2] = o + 1;\r\n\t\t\t\t\tcells[indices.cell + 3] = n + 1;\r\n\t\t\t\t} else {\r\n\t\t\t\t\tcells[indices.cell] = n;\r\n\t\t\t\t\tcells[indices.cell + (ccw ? 1 : 2)] = n + nu + 1;\r\n\t\t\t\t\tcells[indices.cell + (ccw ? 2 : 1)] = n + nu + 2;\r\n\r\n\t\t\t\t\tcells[indices.cell + 3] = n;\r\n\t\t\t\t\tcells[indices.cell + (ccw ? 4 : 5)] = n + nu + 2;\r\n\t\t\t\t\tcells[indices.cell + (ccw ? 5 : 4)] = n + 1;\r\n\t\t\t\t}\r\n\t\t\t\tindices.cell += quads ? 4 : 6;\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\r\n\treturn geometry;\r\n}\r\n/**\r\n * @typedef {Object} CubeOptions\r\n * @property {number} [sx=1]\r\n * @property {number} [sy=sx]\r\n * @property {number} [sz=sx]\r\n * @property {number} [nx=1]\r\n * @property {number} [ny=nx]\r\n * @property {number} [nz=nx]\r\n */\r\nexport function createCube({ sx = 1, sy = 1, sz = 1, nx = 1, ny = 1, nz = 1 } = {}) {\r\n\tcheckArguments(arguments);\r\n\r\n\tconst size = (nx + 1) * (ny + 1) * 2 + (nx + 1) * (nz + 1) * 2 + (nz + 1) * (ny + 1) * 2;\r\n\r\n\tconst geometry = {\r\n\t\tpositions: new Float32Array(size * 3),\r\n\t\tnormals: new Float32Array(size * 3),\r\n\t\tuvs: new Float32Array(size * 2),\r\n\t\tcells: new (getCellsTypedArray(size))((nx * ny * 2 + nx * nz * 2 + nz * ny * 2) * 6)\r\n\t};\r\n\r\n\tconst halfSX = sx * 0.5;\r\n\tconst halfSY = sy * 0.5;\r\n\tconst halfSZ = sz * 0.5;\r\n\r\n\tconst indices = { vertex: 0, cell: 0 };\r\n\r\n\tcomputePlane(geometry, indices, sx, sy, nx, ny, \"z\", halfSZ);\r\n\tcomputePlane(geometry, indices, sx, sy, nx, ny, \"-z\", -halfSZ);\r\n\tcomputePlane(geometry, indices, sz, sy, nz, ny, \"-x\", -halfSX);\r\n\tcomputePlane(geometry, indices, sz, sy, nz, ny, \"x\", halfSX);\r\n\tcomputePlane(geometry, indices, sx, sz, nx, nz, \"y\", halfSY);\r\n\tcomputePlane(geometry, indices, sx, sz, nx, nz, \"-y\", -halfSY);\r\n\r\n\treturn geometry;\r\n}\r\n\r\nexport function createBox(options) {\r\n\toptions = options || {};\r\n\r\n\tconst dimensions = options.dimensions || [1, 1, 1];\r\n\tconst position = options.position || [-dimensions[0] / 2, -dimensions[1] / 2, -dimensions[2] / 2];\r\n\tconst x = position[0];\r\n\tconst y = position[1];\r\n\tconst z = position[2];\r\n\tconst width = dimensions[0];\r\n\tconst height = dimensions[1];\r\n\tconst depth = dimensions[2];\r\n\r\n\tconst fbl = { x: x, y: y, z: z + depth };\r\n\tconst fbr = { x: x + width, y: y, z: z + depth };\r\n\tconst ftl = { x: x, y: y + height, z: z + depth };\r\n\tconst ftr = { x: x + width, y: y + height, z: z + depth };\r\n\tconst bbl = { x: x, y: y, z: z };\r\n\tconst bbr = { x: x + width, y: y, z: z };\r\n\tconst btl = { x: x, y: y + height, z: z };\r\n\tconst btr = { x: x + width, y: y + height, z: z };\r\n\r\n\tconst positions = [\r\n\t\t// front\r\n\t\tfbl.x,\r\n\t\tfbl.y,\r\n\t\tfbl.z,\r\n\t\tfbr.x,\r\n\t\tfbr.y,\r\n\t\tfbr.z,\r\n\t\tftl.x,\r\n\t\tftl.y,\r\n\t\tftl.z,\r\n\t\tftl.x,\r\n\t\tftl.y,\r\n\t\tftl.z,\r\n\t\tfbr.x,\r\n\t\tfbr.y,\r\n\t\tfbr.z,\r\n\t\tftr.x,\r\n\t\tftr.y,\r\n\t\tftr.z,\r\n\r\n\t\t// right\r\n\t\tfbr.x,\r\n\t\tfbr.y,\r\n\t\tfbr.z,\r\n\t\tbbr.x,\r\n\t\tbbr.y,\r\n\t\tbbr.z,\r\n\t\tftr.x,\r\n\t\tftr.y,\r\n\t\tftr.z,\r\n\t\tftr.x,\r\n\t\tftr.y,\r\n\t\tftr.z,\r\n\t\tbbr.x,\r\n\t\tbbr.y,\r\n\t\tbbr.z,\r\n\t\tbtr.x,\r\n\t\tbtr.y,\r\n\t\tbtr.z,\r\n\r\n\t\t// back\r\n\t\tfbr.x,\r\n\t\tbbr.y,\r\n\t\tbbr.z,\r\n\t\tbbl.x,\r\n\t\tbbl.y,\r\n\t\tbbl.z,\r\n\t\tbtr.x,\r\n\t\tbtr.y,\r\n\t\tbtr.z,\r\n\t\tbtr.x,\r\n\t\tbtr.y,\r\n\t\tbtr.z,\r\n\t\tbbl.x,\r\n\t\tbbl.y,\r\n\t\tbbl.z,\r\n\t\tbtl.x,\r\n\t\tbtl.y,\r\n\t\tbtl.z,\r\n\r\n\t\t// left\r\n\t\tbbl.x,\r\n\t\tbbl.y,\r\n\t\tbbl.z,\r\n\t\tfbl.x,\r\n\t\tfbl.y,\r\n\t\tfbl.z,\r\n\t\tbtl.x,\r\n\t\tbtl.y,\r\n\t\tbtl.z,\r\n\t\tbtl.x,\r\n\t\tbtl.y,\r\n\t\tbtl.z,\r\n\t\tfbl.x,\r\n\t\tfbl.y,\r\n\t\tfbl.z,\r\n\t\tftl.x,\r\n\t\tftl.y,\r\n\t\tftl.z,\r\n\r\n\t\t// top\r\n\t\tftl.x,\r\n\t\tftl.y,\r\n\t\tftl.z,\r\n\t\tftr.x,\r\n\t\tftr.y,\r\n\t\tftr.z,\r\n\t\tbtl.x,\r\n\t\tbtl.y,\r\n\t\tbtl.z,\r\n\t\tbtl.x,\r\n\t\tbtl.y,\r\n\t\tbtl.z,\r\n\t\tftr.x,\r\n\t\tftr.y,\r\n\t\tftr.z,\r\n\t\tbtr.x,\r\n\t\tbtr.y,\r\n\t\tbtr.z,\r\n\r\n\t\t// bottom\r\n\t\tbbl.x,\r\n\t\tbbl.y,\r\n\t\tbbl.z,\r\n\t\tbbr.x,\r\n\t\tbbr.y,\r\n\t\tbbr.z,\r\n\t\tfbl.x,\r\n\t\tfbl.y,\r\n\t\tfbl.z,\r\n\t\tfbl.x,\r\n\t\tfbl.y,\r\n\t\tfbl.z,\r\n\t\tbbr.x,\r\n\t\tbbr.y,\r\n\t\tbbr.z,\r\n\t\tfbr.x,\r\n\t\tfbr.y,\r\n\t\tfbr.z\r\n\t];\r\n\r\n\tconst uvs = [\r\n\t\t// front\r\n\t\t0, 0, 1, 0, 0, 1, 0, 1, 1, 0, 1, 1,\r\n\r\n\t\t// right\r\n\t\t0, 0, 1, 0, 0, 1, 0, 1, 1, 0, 1, 1,\r\n\r\n\t\t// back\r\n\t\t0, 0, 1, 0, 0, 1, 0, 1, 1, 0, 1, 1,\r\n\r\n\t\t// left\r\n\t\t0, 0, 1, 0, 0, 1, 0, 1, 1, 0, 1, 1,\r\n\r\n\t\t// top\r\n\t\t0, 0, 1, 0, 0, 1, 0, 1, 1, 0, 1, 1,\r\n\r\n\t\t// bottom\r\n\t\t0, 0, 1, 0, 0, 1, 0, 1, 1, 0, 1, 1\r\n\t];\r\n\r\n\tconst normals = [\r\n\t\t// front\r\n\t\t0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 1,\r\n\r\n\t\t// right\r\n\t\t1, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0,\r\n\r\n\t\t// back\r\n\t\t0, 0, -1, 0, 0, -1, 0, 0, -1, 0, 0, -1, 0, 0, -1, 0, 0, -1,\r\n\r\n\t\t// left\r\n\t\t-1, 0, 0, -1, 0, 0, -1, 0, 0, -1, 0, 0, -1, 0, 0, -1, 0, 0,\r\n\r\n\t\t// top\r\n\t\t0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0,\r\n\r\n\t\t// bottom\r\n\t\t0, -1, 0, 0, -1, 0, 0, -1, 0, 0, -1, 0, 0, -1, 0, 0, -1, 0\r\n\t];\r\n\treturn {\r\n\t\tpositions: positions,\r\n\t\tnormals: normals,\r\n\t\tuvs: uvs\r\n\t};\r\n}\r\n\r\nexport function createSphere(options) {\r\n\toptions = options || {};\r\n\r\n\tconst longBands = options.longBands || 32;\r\n\tconst latBands = options.latBands || 32;\r\n\tconst radius = options.radius || 1;\r\n\tconst lat_step = Math.PI / latBands;\r\n\tconst long_step = (2 * Math.PI) / longBands;\r\n\tconst num_positions = longBands * latBands * 4;\r\n\tconst num_indices = longBands * latBands * 6;\r\n\tlet lat_angle, long_angle;\r\n\tconst positions = new Array(num_positions * 3);\r\n\tconst normals = new Array(num_positions * 3);\r\n\tconst uvs = new Array(num_positions * 2);\r\n\tconst indices = new Array(num_indices);\r\n\tlet x1, x2, x3, x4, y1, y2, z1, z2, z3, z4, u1, u2, v1, v2;\r\n\tlet i, j;\r\n\tlet k = 0,\r\n\t\tl = 0;\r\n\tlet vi, ti;\r\n\r\n\tfor (i = 0; i < latBands; i++) {\r\n\t\tlat_angle = i * lat_step;\r\n\t\ty1 = Math.cos(lat_angle);\r\n\t\ty2 = Math.cos(lat_angle + lat_step);\r\n\t\tfor (j = 0; j < longBands; j++) {\r\n\t\t\tlong_angle = j * long_step;\r\n\t\t\tx1 = Math.sin(lat_angle) * Math.cos(long_angle);\r\n\t\t\tx2 = Math.sin(lat_angle) * Math.cos(long_angle + long_step);\r\n\t\t\tx3 = Math.sin(lat_angle + lat_step) * Math.cos(long_angle);\r\n\t\t\tx4 = Math.sin(lat_angle + lat_step) * Math.cos(long_angle + long_step);\r\n\t\t\tz1 = Math.sin(lat_angle) * Math.sin(long_angle);\r\n\t\t\tz2 = Math.sin(lat_angle) * Math.sin(long_angle + long_step);\r\n\t\t\tz3 = Math.sin(lat_angle + lat_step) * Math.sin(long_angle);\r\n\t\t\tz4 = Math.sin(lat_angle + lat_step) * Math.sin(long_angle + long_step);\r\n\t\t\tu1 = 1 - j / longBands;\r\n\t\t\tu2 = 1 - (j + 1) / longBands;\r\n\t\t\tv1 = 1 - i / latBands;\r\n\t\t\tv2 = 1 - (i + 1) / latBands;\r\n\t\t\tvi = k * 3;\r\n\t\t\tti = k * 2;\r\n\r\n\t\t\tpositions[vi] = x1 * radius;\r\n\t\t\tpositions[vi + 1] = y1 * radius;\r\n\t\t\tpositions[vi + 2] = z1 * radius; // v0\r\n\r\n\t\t\tpositions[vi + 3] = x2 * radius;\r\n\t\t\tpositions[vi + 4] = y1 * radius;\r\n\t\t\tpositions[vi + 5] = z2 * radius; // v1\r\n\r\n\t\t\tpositions[vi + 6] = x3 * radius;\r\n\t\t\tpositions[vi + 7] = y2 * radius;\r\n\t\t\tpositions[vi + 8] = z3 * radius; // v2\r\n\r\n\t\t\tpositions[vi + 9] = x4 * radius;\r\n\t\t\tpositions[vi + 10] = y2 * radius;\r\n\t\t\tpositions[vi + 11] = z4 * radius; // v3\r\n\r\n\t\t\tnormals[vi] = x1;\r\n\t\t\tnormals[vi + 1] = y1;\r\n\t\t\tnormals[vi + 2] = z1;\r\n\r\n\t\t\tnormals[vi + 3] = x2;\r\n\t\t\tnormals[vi + 4] = y1;\r\n\t\t\tnormals[vi + 5] = z2;\r\n\r\n\t\t\tnormals[vi + 6] = x3;\r\n\t\t\tnormals[vi + 7] = y2;\r\n\t\t\tnormals[vi + 8] = z3;\r\n\r\n\t\t\tnormals[vi + 9] = x4;\r\n\t\t\tnormals[vi + 10] = y2;\r\n\t\t\tnormals[vi + 11] = z4;\r\n\r\n\t\t\tuvs[ti] = u1;\r\n\t\t\tuvs[ti + 1] = v1;\r\n\r\n\t\t\tuvs[ti + 2] = u2;\r\n\t\t\tuvs[ti + 3] = v1;\r\n\r\n\t\t\tuvs[ti + 4] = u1;\r\n\t\t\tuvs[ti + 5] = v2;\r\n\r\n\t\t\tuvs[ti + 6] = u2;\r\n\t\t\tuvs[ti + 7] = v2;\r\n\r\n\t\t\tindices[l] = k;\r\n\t\t\tindices[l + 1] = k + 1;\r\n\t\t\tindices[l + 2] = k + 2;\r\n\t\t\tindices[l + 3] = k + 2;\r\n\t\t\tindices[l + 4] = k + 1;\r\n\t\t\tindices[l + 5] = k + 3;\r\n\r\n\t\t\tk += 4;\r\n\t\t\tl += 6;\r\n\t\t}\r\n\t}\r\n\r\n\treturn {\r\n\t\tpositions: positions,\r\n\t\tnormals: normals,\r\n\t\tuvs: uvs,\r\n\t\tindices: indices\r\n\t};\r\n}\r\n","import { Float32Attribute } from \"../render/Attribute\";\r\nimport { createSphere } from \"../utils/GeometryUtils\";\r\nimport Geometry from \"./Geometry\";\r\n\r\nexport default class SphereGeometry extends Geometry {\r\n\tradius: number;\r\n\tconstructor(radius: number) {\r\n\t\tsuper({\r\n\t\t\ttype: \"sphereGeometry\"\r\n\t\t});\r\n\t\tthis.defines = {\r\n\t\t\tHAS_NORMAL: true\r\n\t\t};\r\n\t\tthis.radius = radius;\r\n\t\tthis.init();\r\n\t}\r\n\tprivate init() {\r\n\t\tconst { positions, normals, uvs, indices } = createSphere({ radius: this.radius });\r\n\t\t// this.positions = positions;\r\n\t\t// this.normals = normals;\r\n\t\t// this.uvs = uvs;\r\n\t\t// this.indices = indices;\r\n\t\tthis.computeBoundingSphere(positions);\r\n\t\tthis.setAttribute(new Float32Attribute(\"position\", positions, 3));\r\n\t\tthis.setAttribute(new Float32Attribute(\"normal\", normals, 3));\r\n\t\tthis.setAttribute(new Float32Attribute(\"uv\", uvs, 2));\r\n\r\n\t\tthis.setIndice(indices);\r\n\t\tthis.count = indices.length;\r\n\t}\r\n}\r\n","import { Float32Attribute } from \"../render/Attribute\";\r\nimport { createBox } from \"../utils/GeometryUtils\";\r\nimport Geometry from \"./Geometry\";\r\nexport default class BoxGeometry extends Geometry {\r\n\tconstructor(public width: number = 10, public height: number = 10, public depth: number = 10) {\r\n\t\tsuper({\r\n\t\t\ttype: \"boxGeometry\"\r\n\t\t});\r\n\t\tthis.defines = {\r\n\t\t\tHAS_NORMAL: true\r\n\t\t};\r\n\t\tthis.init();\r\n\t}\r\n\tprivate init() {\r\n\t\t// generate pos uv normal so on\r\n\t\tconst { positions, normals, uvs } = createBox({\r\n\t\t\tdimensions: [this.depth, this.width, this.height]\r\n\t\t});\r\n\t\tthis.computeBoundingSphere(positions);\r\n\t\tthis.setAttribute(new Float32Attribute(\"position\", positions, 3));\r\n\t\tthis.setAttribute(new Float32Attribute(\"normal\", normals, 3));\r\n\t\tthis.setAttribute(new Float32Attribute(\"uv\", uvs, 2));\r\n\t\tthis.count = 36;\r\n\t}\r\n\tpublic update(frameState) {}\r\n}\r\n","import Vector3 from \"../math/Vector3\";\r\nimport { Float32Attribute } from \"../render/Attribute\";\r\nimport Geometry from \"./Geometry\";\r\nexport default class TorusKnotGeometry extends Geometry {\r\n\tradius: number;\r\n\ttube: number;\r\n\ttubularSegments: number;\r\n\tradialSegments: number;\r\n\tp: number;\r\n\tq: number;\r\n\tconstructor(radius = 1, tube = 0.4, tubularSegments = 64, radialSegments = 8, p = 2, q = 3) {\r\n\t\tsuper({\r\n\t\t\ttype: \"torusKnotGeometry\"\r\n\t\t});\r\n\t\tthis.defines = {\r\n\t\t\tHAS_NORMAL: true\r\n\t\t};\r\n\t\tthis.radius = radius;\r\n\t\tthis.tube = tube;\r\n\t\tthis.tubularSegments = tubularSegments;\r\n\t\tthis.radialSegments = radialSegments;\r\n\t\tthis.p = p;\r\n\t\tthis.q = q;\r\n\t\tthis.init();\r\n\t}\r\n\tpublic update(frameState) {\r\n\t\tconst { device } = frameState.context;\r\n\t}\r\n\tprivate init() {\r\n\t\tconst { normals, uvs, positions, indices } = this.createGeometry();\r\n\t\tthis.computeBoundingSphere(positions);\r\n\t\tthis.setAttribute(new Float32Attribute(\"position\", positions, 3));\r\n\t\tthis.setAttribute(new Float32Attribute(\"normal\", normals, 3));\r\n\t\tthis.setAttribute(new Float32Attribute(\"uv\", uvs, 2));\r\n\t\tthis.setIndice(indices);\r\n\t\tthis.count = indices.length;\r\n\t}\r\n\tprivate createGeometry() {\r\n\t\tconst positions = [],\r\n\t\t\tnormals = [],\r\n\t\t\tuvs = [],\r\n\t\t\tindices = [];\r\n\t\tconst tubularSegments = Math.floor(this.tubularSegments);\r\n\t\tconst radialSegments = Math.floor(this.radialSegments);\r\n\t\t// helper variables\r\n\r\n\t\tconst vertex = new Vector3();\r\n\t\tconst normal = new Vector3();\r\n\r\n\t\tconst P1 = new Vector3();\r\n\t\tconst P2 = new Vector3();\r\n\r\n\t\tconst B = new Vector3();\r\n\t\tconst T = new Vector3();\r\n\t\tconst N = new Vector3();\r\n\r\n\t\t// generate vertices, normals and uvs\r\n\r\n\t\tfor (let i = 0; i <= tubularSegments; ++i) {\r\n\t\t\t// the radian \"u\" is used to calculate the position on the torus curve of the current tubular segment\r\n\r\n\t\t\tconst u = (i / tubularSegments) * this.p * Math.PI * 2;\r\n\r\n\t\t\t// now we calculate two points. P1 is our current position on the curve, P2 is a little farther ahead.\r\n\t\t\t// these points are used to create a special \"coordinate space\", which is necessary to calculate the correct vertex positions\r\n\r\n\t\t\tcalculatePositionOnCurve(u, this.p, this.q, this.radius, P1);\r\n\t\t\tcalculatePositionOnCurve(u + 0.01, this.p, this.q, this.radius, P2);\r\n\r\n\t\t\t// calculate orthonormal basis\r\n\r\n\t\t\tVector3.subtract(P2, P1, T);\r\n\t\t\t// T.subVectors( P2, P1 );\r\n\t\t\tVector3.add(P2, P1, N);\r\n\t\t\t// N.addVectors( P2, P1 );\r\n\t\t\tVector3.cross(T, N, B);\r\n\t\t\t// B.crossVectors( T, N );\r\n\t\t\tVector3.cross(B, T, N);\r\n\t\t\t// N.crossVectors( B, T );\r\n\r\n\t\t\t// normalize B, N. T can be ignored, we don't use it\r\n\r\n\t\t\tB.normalize();\r\n\t\t\tN.normalize();\r\n\r\n\t\t\tfor (let j = 0; j <= radialSegments; ++j) {\r\n\t\t\t\t// now calculate the vertices. they are nothing more than an extrusion of the torus curve.\r\n\t\t\t\t// because we extrude a shape in the xy-plane, there is no need to calculate a z-value.\r\n\r\n\t\t\t\tconst v = (j / radialSegments) * Math.PI * 2;\r\n\t\t\t\tconst cx = -this.tube * Math.cos(v);\r\n\t\t\t\tconst cy = this.tube * Math.sin(v);\r\n\r\n\t\t\t\t// now calculate the final vertex position.\r\n\t\t\t\t// first we orient the extrusion with our basis vectors, then we add it to the current position on the curve\r\n\r\n\t\t\t\tvertex.x = P1.x + (cx * N.x + cy * B.x);\r\n\t\t\t\tvertex.y = P1.y + (cx * N.y + cy * B.y);\r\n\t\t\t\tvertex.z = P1.z + (cx * N.z + cy * B.z);\r\n\r\n\t\t\t\tpositions.push(vertex.x, vertex.y, vertex.z);\r\n\r\n\t\t\t\t// normal (P1 is always the center/origin of the extrusion, thus we can use it to calculate the normal)\r\n\t\t\t\tVector3.subtract(vertex, P1, normal);\r\n\t\t\t\tnormal.normalize();\r\n\r\n\t\t\t\tnormals.push(normal.x, normal.y, normal.z);\r\n\r\n\t\t\t\t// uv\r\n\r\n\t\t\t\tuvs.push(i / tubularSegments);\r\n\t\t\t\tuvs.push(j / radialSegments);\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\t// generate indices\r\n\r\n\t\tfor (let j = 1; j <= tubularSegments; j++) {\r\n\t\t\tfor (let i = 1; i <= radialSegments; i++) {\r\n\t\t\t\t// indices\r\n\r\n\t\t\t\tconst a = (radialSegments + 1) * (j - 1) + (i - 1);\r\n\t\t\t\tconst b = (radialSegments + 1) * j + (i - 1);\r\n\t\t\t\tconst c = (radialSegments + 1) * j + i;\r\n\t\t\t\tconst d = (radialSegments + 1) * (j - 1) + i;\r\n\r\n\t\t\t\t// faces\r\n\r\n\t\t\t\tindices.push(a, b, d);\r\n\t\t\t\tindices.push(b, c, d);\r\n\t\t\t}\r\n\t\t}\r\n\t\treturn {\r\n\t\t\tnormals,\r\n\t\t\tuvs,\r\n\t\t\tpositions,\r\n\t\t\tindices\r\n\t\t};\r\n\t}\r\n}\r\nfunction calculatePositionOnCurve(u, p, q, radius, position) {\r\n\tconst cu = Math.cos(u);\r\n\tconst su = Math.sin(u);\r\n\tconst quOverP = (q / p) * u;\r\n\tconst cs = Math.cos(quOverP);\r\n\r\n\tposition.x = radius * (2 + cs) * 0.5 * cu;\r\n\tposition.y = radius * (2 + cs) * su * 0.5;\r\n\tposition.z = radius * Math.sin(quOverP) * 0.5;\r\n}\r\n","import { FrameState } from \"../core/FrameState\";\r\nimport textureCache from \"../core/TextureCache\";\r\nimport Color from \"../math/Color\";\r\nimport { Mesh } from \"../mesh/Mesh\";\r\nimport Sampler from \"../render/Sampler\";\r\nimport Texture from \"../render/Texture\";\r\nimport UniformBuffer from \"../render/UniformBuffer\";\r\nimport { UniformEnum } from \"../render/Uniforms\";\r\nimport { ShaderSource } from \"../shader/ShaderSource\";\r\nimport { Material } from \"./Material\";\r\nexport default class BlinnPhongMaterial extends Material {\r\n\tpublic specular: Color;\r\n\tpublic shininess: number;\r\n\tpublic normalTexture: Texture;\r\n\tpublic normalSampler: Sampler;\r\n\tconstructor() {\r\n\t\tsuper();\r\n\t\tthis.type = \"phong\";\r\n\t\tthis.color = new Color(1.0, 0.0, 0.0);\r\n\t\tthis.shaderSource = new ShaderSource({\r\n\t\t\ttype: this.type,\r\n\t\t\trender: true,\r\n\t\t\tdefines: {\r\n\t\t\t\tmaterialPhong: true\r\n\t\t\t}\r\n\t\t});\r\n\t\tthis.light = true;\r\n\t\tthis.specular = new Color(1.0, 1.0, 1.0);\r\n\t\tthis.shininess = 30.0;\r\n\t\tthis.baseTexture = undefined;\r\n\t\tthis.baseSampler = undefined;\r\n\t}\r\n\tupdate(frameState: FrameState, mesh: Mesh) {\r\n\t\tif (!this.shaderData || this.dirty) this.createShaderData(mesh);\r\n\t}\r\n\tprotected createShaderData(mesh?: Mesh) {\r\n\t\tsuper.createShaderData(mesh);\r\n\t\tconst uniformBuffer = new UniformBuffer({ label: \"phong\" });\r\n\t\tuniformBuffer.setUniform(\r\n\t\t\t\"modelMatrix\",\r\n\t\t\t() => {\r\n\t\t\t\treturn null;\r\n\t\t\t},\r\n\t\t\tUniformEnum.Mat4\r\n\t\t);\r\n\t\tuniformBuffer.setUniform(\"color\", this, UniformEnum.Color);\r\n\t\tuniformBuffer.setUniform(\"opacity\", this, UniformEnum.Float);\r\n\t\tuniformBuffer.setUniform(\r\n\t\t\t\"normalMtrix\",\r\n\t\t\t() => {\r\n\t\t\t\treturn mesh.normalMatrix;\r\n\t\t\t},\r\n\t\t\tUniformEnum.Mat4\r\n\t\t);\r\n\t\tuniformBuffer.setUniform(\"emissive\", this, UniformEnum.Color);\r\n\t\tuniformBuffer.setUniform(\"shininess\", this, UniformEnum.Float);\r\n\t\tuniformBuffer.setUniform(\"specular\", this, UniformEnum.Color);\r\n\t\tthis.shaderData.setUniformBuffer(\"phong\", uniformBuffer);\r\n\t\tif (this.baseTexture) {\r\n\t\t\tthis.shaderData.setDefine(\"USE_COLORTEXTURE\", true);\r\n\t\t\tthis.shaderData.setTexture(\"baseColorTexture\", this.baseTexture);\r\n\t\t\tthis.shaderData.setSampler(\"baseColorSampler\", this.baseSampler || textureCache.defaultSampler);\r\n\t\t}\r\n\t\tif (this.normalTexture) {\r\n\t\t\tthis.shaderData.setDefine(\"USE_NORMALTEXTURE\", true);\r\n\t\t\tthis.shaderData.setTexture(\"normalTexture\", this.normalTexture);\r\n\t\t\tthis.shaderData.setSampler(\"normalSampler\", this.normalSampler || textureCache.defaultSampler);\r\n\t\t}\r\n\t}\r\n\tdestroy() {\r\n\t\tthis?.baseTexture?.destroy();\r\n\t\tsuper.destroy();\r\n\t}\r\n}\r\n","import { FrameState } from \"../core/FrameState\";\nimport textureCache from \"../core/TextureCache\";\nimport { CullMode } from \"../core/WebGPUConstant\";\nimport Vector2 from \"../math/Vector2\";\nimport { Mesh } from \"../mesh/Mesh\";\nimport Sampler from \"../render/Sampler\";\nimport Texture from \"../render/Texture\";\nimport UniformBuffer from \"../render/UniformBuffer\";\nimport { UniformEnum } from \"../render/Uniforms\";\nimport { ShaderSource } from \"../shader/ShaderSource\";\nimport { Material } from \"./Material\";\n\nexport default class PbrMaterial extends Material {\n\tpublic specularEnvTexture: Texture;\n\n\tpublic specularEnvSampler: Sampler;\n\n\tpublic emissiveTexture: Texture;\n\n\tpublic emissiveSampler: Sampler;\n\n\tpublic normalTexture: Texture;\n\n\tpublic normalSampler: Sampler;\n\n\tpublic aoTexture: Texture;\n\n\tpublic aoSampler: Sampler;\n\n\tpublic metalnessRoughnessTexture: Texture;\n\n\tpublic metalnessRoughnessSampler: Sampler;\n\n\tprivate _roughness: number;\n\n\tprivate _metalness: number;\n\n\tprivate _aoTextureIntensity: number;\n\n\tprivate _normalScale: Vector2;\n\n\tprivate _IBLRender: boolean;\n\n\tpublic get roughness(): number {\n\t\treturn this._roughness;\n\t}\n\tpublic set roughness(value) {\n\t\tthis._roughness = value;\n\t}\n\tpublic get metalness(): number {\n\t\treturn this._metalness;\n\t}\n\tpublic set metalness(v: number) {\n\t\tthis._metalness = v;\n\t}\n\tpublic get aoTextureIntensity(): number {\n\t\treturn this._aoTextureIntensity;\n\t}\n\tpublic set aoTextureIntensity(v: number) {\n\t\tthis._aoTextureIntensity = v;\n\t}\n\tpublic get normalScale(): Vector2 {\n\t\tif (this.renderState && this.renderState.primitive) {\n\t\t\tif (this.renderState.primitive.cullMode == CullMode.Back) {\n\t\t\t\treturn Vector2.negate(this._normalScale, new Vector2());\n\t\t\t}\n\t\t}\n\t\treturn this._normalScale;\n\t}\n\tpublic set normalScale(v: Vector2) {\n\t\tthis._normalScale = v;\n\t}\n\tpublic set IBLRender(value) {\n\t\tthis._IBLRender = value;\n\t\tthis.shaderSource.setDefines({\n\t\t\tUSE_IBL: this._IBLRender\n\t\t});\n\t\tthis.dirty = true;\n\t}\n\tconstructor() {\n\t\tsuper();\n\t\tthis.type = \"pbr_mat\";\n\n\t\tthis._roughness = 0.1;\n\n\t\tthis._metalness = 0.1;\n\n\t\tthis._aoTextureIntensity = 1.0;\n\t\tthis.light = true;\n\t\tthis._normalScale = new Vector2(1, 1);\n\t\tthis._IBLRender = true;\n\t\tthis.shaderSource = new ShaderSource({\n\t\t\ttype: this.type,\n\t\t\trender: true,\n\t\t\tdefines: {\n\t\t\t\tmaterialPbr: true,\n\t\t\t\tUSE_IBL: this._IBLRender\n\t\t\t}\n\t\t});\n\t}\n\tupdate(frameState: FrameState, mesh: Mesh) {\n\t\tif (!textureCache.getTexture(\"specular\")) return;\n\t\tif (!this.shaderData || this.dirty) {\n\t\t\tthis.createShaderData(mesh, frameState);\n\t\t}\n\t}\n\tprotected createShaderData(mesh: Mesh, frameState?: FrameState) {\n\t\tsuper.createShaderData(mesh);\n\t\tconst uniformBuffer = new UniformBuffer({ label: \"pbr\" });\n\t\tuniformBuffer.setUniform(\n\t\t\t\"modelMatrix\",\n\t\t\t() => {\n\t\t\t\treturn mesh.modelMatrix;\n\t\t\t},\n\t\t\tUniformEnum.Mat4\n\t\t);\n\t\tuniformBuffer.setUniform(\"color\", this, UniformEnum.Color);\n\t\tuniformBuffer.setUniform(\"opacity\", this, UniformEnum.Float);\n\t\tuniformBuffer.setUniform(\n\t\t\t\"normalMtrix\",\n\t\t\t() => {\n\t\t\t\treturn mesh.normalMatrix;\n\t\t\t},\n\t\t\tUniformEnum.Mat4\n\t\t);\n\t\tuniformBuffer.setUniform(\"emissive\", this, UniformEnum.Color);\n\t\tuniformBuffer.setUniform(\"metalness\", this, UniformEnum.Float);\n\t\tuniformBuffer.setUniform(\"roughness\", this, UniformEnum.Float);\n\t\tthis.shaderData.setUniformBuffer(\"pbr\", uniformBuffer);\n\t\tthis.specularEnvTexture = textureCache.getTexture(\"specular\");\n\t\tif (this.baseTexture) {\n\t\t\tthis.shaderData.setDefine(\"USE_TEXTURE\", true);\n\t\t\tthis.shaderData.setTexture(\"baseColorTexture\", this.baseTexture);\n\t\t\tthis.shaderData.setSampler(\"baseColorSampler\", this.baseSampler || textureCache.defaultSampler);\n\t\t}\n\t\tif (this.metalnessRoughnessTexture) {\n\t\t\tthis.shaderData.setDefine(\"USE_METALNESSTEXTURE\", true);\n\t\t\tthis.shaderData.setTexture(\"metalnessRoughnessTexture\", this.metalnessRoughnessTexture);\n\t\t\tthis.shaderData.setSampler(\n\t\t\t\t\"metalnessRoughnessSampler\",\n\t\t\t\tthis.metalnessRoughnessSampler || textureCache.defaultSampler\n\t\t\t);\n\t\t}\n\t\tif (this.normalTexture) {\n\t\t\tuniformBuffer.setUniform(\"normalScale\", this, UniformEnum.FloatVec2);\n\t\t\tthis.shaderData.setDefine(\"USE_NORMALTEXTURE\", true);\n\t\t\tthis.shaderData.setTexture(\"normalTexture\", this.normalTexture);\n\t\t\tthis.shaderData.setSampler(\"normalSampler\", this.normalSampler || textureCache.defaultSampler);\n\t\t}\n\t\tif (this.aoTexture) {\n\t\t\tthis.shaderData.setDefine(\"USE_AOTEXTURE\", true);\n\t\t\tthis.shaderData.setTexture(\"aoTexture\", this.aoTexture);\n\t\t\tthis.shaderData.setSampler(\"aoSampler\", this.aoSampler || textureCache.defaultSampler);\n\t\t\tuniformBuffer.setUniform(\"aoTextureIntensity\", this, UniformEnum.Float);\n\t\t}\n\t\tif (this.emissiveTexture) {\n\t\t\tthis.shaderData.setDefine(\"USE_EMISSIVETEXTURE\", true);\n\t\t\tthis.shaderData.setTexture(\"emissiveTexture\", this.emissiveTexture);\n\t\t\tthis.shaderData.setSampler(\"emissiveSampler\", this.emissiveSampler || textureCache.defaultSampler);\n\t\t}\n\t\tif (this.specularEnvTexture && this._IBLRender) {\n\t\t\tthis.shaderData.setTexture(\"specularEnvTexture\", this.specularEnvTexture);\n\t\t\tthis.shaderData.setSampler(\"specularEnvSampler\", this.specularEnvSampler || textureCache.defaultSampler);\n\t\t}\n\t}\n\tdestroy() {\n\t\tthis?.aoTexture?.destroy();\n\t\tthis?.baseTexture?.destroy();\n\t\tthis?.emissiveTexture?.destroy();\n\t\tthis?.normalTexture?.destroy();\n\t\tthis.specularEnvTexture = undefined;\n\t}\n}\n","export class EventDispatcher {\r\n\tprivate _listeners: object;\r\n\tconstructor() {\r\n\t\tthis._listeners = {};\r\n\t}\r\n\r\n\taddEventListener(type, listener) {\r\n\t\tif (this._listeners === undefined) this._listeners = {};\r\n\r\n\t\tconst listeners = this._listeners;\r\n\r\n\t\tif (listeners[type] === undefined) {\r\n\t\t\tlisteners[type] = [];\r\n\t\t}\r\n\r\n\t\tif (listeners[type].indexOf(listener) === -1) {\r\n\t\t\tlisteners[type].push(listener);\r\n\t\t}\r\n\t}\r\n\r\n\thasEventListener(type, listener) {\r\n\t\tif (this._listeners === undefined) return false;\r\n\r\n\t\tconst listeners = this._listeners;\r\n\r\n\t\treturn listeners[type] !== undefined && listeners[type].indexOf(listener) !== -1;\r\n\t}\r\n\r\n\tremoveEventListener(type, listener) {\r\n\t\tif (this._listeners === undefined) return;\r\n\r\n\t\tconst listeners = this._listeners;\r\n\t\tconst listenerArray = listeners[type];\r\n\r\n\t\tif (listenerArray !== undefined) {\r\n\t\t\tconst index = listenerArray.indexOf(listener);\r\n\r\n\t\t\tif (index !== -1) {\r\n\t\t\t\tlistenerArray.splice(index, 1);\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\r\n\tdispatchEvent(event) {\r\n\t\tif (this._listeners === undefined) return;\r\n\r\n\t\tconst listeners = this._listeners;\r\n\t\tconst listenerArray = listeners[event.type];\r\n\r\n\t\tif (listenerArray !== undefined) {\r\n\t\t\tevent.target = this;\r\n\r\n\t\t\tconst array = listenerArray.slice(0);\r\n\r\n\t\t\tfor (let i = 0, l = array.length; i < l; i++) {\r\n\t\t\t\tarray[i].call(this, event);\r\n\t\t\t}\r\n\t\t\tevent.target = null;\r\n\t\t}\r\n\t}\r\n}\r\n","import Camera from \"../camera/Camera\";\r\nimport { Compute } from \"../compute/Compute\";\r\nimport { Material } from \"../material/Material\";\r\nimport { Mesh } from \"../mesh/Mesh\";\r\nimport { ComputeCommand } from \"../render/ComputeCommand\";\r\nimport Context from \"../render/Context\";\r\nimport DrawCommand from \"../render/DrawCommand\";\r\nimport LightManger from \"./LightManger\";\r\nimport { CommandSubType } from \"./WebGPUConstant\";\r\nexport default class RenderQueue {\r\n\tpublic pre: Array<Mesh>;\r\n\tpublic opaque: Array<Mesh>;\r\n\tpublic transparent: Array<Mesh>;\r\n\tpublic debugQueue: Array<Mesh>;\r\n\tpublic computes: Array<Compute>;\r\n\tconstructor() {\r\n\t\tthis.pre = [];\r\n\t\tthis.opaque = [];\r\n\t\tthis.transparent = [];\r\n\t\tthis.computes = [];\r\n\t\tthis.debugQueue = [];\r\n\t}\r\n\tsort() {\r\n\t\tRenderQueue.sort(this.opaque, 0, this.opaque.length, RenderQueue._compareFromNearToFar);\r\n\t\tRenderQueue.sort(this.transparent, 0, this.transparent.length, RenderQueue._compareFromFarToNear);\r\n\t}\r\n\topaqueRender(\r\n\t\tcamera: Camera,\r\n\t\tcontext: Context,\r\n\t\tpassEncoder?: GPURenderPassEncoder,\r\n\t\treplaceMaterial?: Material,\r\n\t\tcommandSubType?: CommandSubType,\r\n\t\tlightManger?: LightManger\r\n\t) {\r\n\t\tthis.opaque.map((mesh) => {\r\n\t\t\tif (!mesh.ready) return;\r\n\t\t\tmesh.beforeRender();\r\n\t\t\tRenderQueue.excuteCommand(\r\n\t\t\t\tmesh.getDrawCommand(replaceMaterial, commandSubType, lightManger),\r\n\t\t\t\tcontext,\r\n\t\t\t\tpassEncoder,\r\n\t\t\t\tcamera\r\n\t\t\t);\r\n\t\t\tmesh.afterRender();\r\n\t\t});\r\n\t}\r\n\ttransparentRender(\r\n\t\tcamera: Camera,\r\n\t\tcontext: Context,\r\n\t\tpassEncoder?: GPURenderPassEncoder,\r\n\t\treplaceMaterial?: Material,\r\n\t\tcommandSubType?: CommandSubType,\r\n\t\tlightManger?: LightManger\r\n\t) {\r\n\t\tthis.transparent.map((mesh) => {\r\n\t\t\tif (!mesh.ready) return;\r\n\t\t\tmesh.beforeRender();\r\n\t\t\tRenderQueue.excuteCommand(\r\n\t\t\t\tmesh.getDrawCommand(replaceMaterial, commandSubType, lightManger),\r\n\t\t\t\tcontext,\r\n\t\t\t\tpassEncoder,\r\n\t\t\t\tcamera\r\n\t\t\t);\r\n\t\t\tmesh.afterRender();\r\n\t\t});\r\n\t}\r\n\tcomputeRender(context: Context, passEncoder?: GPUComputePassEncoder) {\r\n\t\tthis.computes.map((compute) => {\r\n\t\t\tRenderQueue.excuteCompute(compute.getCommand(), context, passEncoder);\r\n\t\t});\r\n\t}\r\n\tdebugQueueRender(\r\n\t\tcamera: Camera,\r\n\t\tcontext: Context,\r\n\t\tpassEncoder?: GPURenderPassEncoder,\r\n\t\treplaceMaterial?: Material,\r\n\t\tcommandSubType?: CommandSubType\r\n\t) {\r\n\t\tthis.debugQueue.map((mesh) => {\r\n\t\t\tif (!mesh.ready) return;\r\n\t\t\tmesh.beforeRender();\r\n\t\t\tRenderQueue.excuteCommand(\r\n\t\t\t\tmesh.getDrawCommand(replaceMaterial, commandSubType),\r\n\t\t\t\tcontext,\r\n\t\t\t\tpassEncoder,\r\n\t\t\t\tcamera\r\n\t\t\t);\r\n\t\t\tmesh.afterRender();\r\n\t\t});\r\n\t}\r\n\tpreRender(camera: Camera, context: Context, passEncoder?: GPURenderPassEncoder, replaceMaterial?: Material) {\r\n\t\tthis.pre.map((mesh) => {\r\n\t\t\tif (!mesh.ready) return;\r\n\t\t\tmesh.beforeRender();\r\n\t\t\tRenderQueue.excuteCommand(mesh.getDrawCommand(), context, passEncoder, camera);\r\n\t\t\tmesh.afterRender();\r\n\t\t});\r\n\t}\r\n\tstatic excuteCommand(command: DrawCommand, context?: Context, passEncoder?: GPURenderPassEncoder, camera?: Camera) {\r\n\t\tcommand.render(context, passEncoder, camera);\r\n\t}\r\n\tstatic excuteCompute(command: ComputeCommand, context?: Context, passEncoder?: GPUComputePassEncoder) {\r\n\t\tcommand.render(context, passEncoder);\r\n\t}\r\n\treset() {\r\n\t\tthis.pre = [];\r\n\t\tthis.opaque = [];\r\n\t\tthis.transparent = [];\r\n\t\tthis.computes = [];\r\n\t\tthis.debugQueue = [];\r\n\t}\r\n\tstatic _compareFromNearToFar(a: Mesh, b: Mesh): number {\r\n\t\treturn a.priority - b.priority || a.distanceToCamera - b.distanceToCamera;\r\n\t}\r\n\r\n\tstatic _compareFromFarToNear(a: Mesh, b: Mesh): number {\r\n\t\treturn a.priority - b.priority || b.distanceToCamera - a.distanceToCamera;\r\n\t}\r\n\t//according to camera distance\r\n\tstatic sort<T>(insatnce: T[], from: number, to: number, compareFunc: Function): void {\r\n\t\tRenderQueue._quickSort(insatnce, from, to, compareFunc);\r\n\t}\r\n\t//from https://github.com/oasis-engine/engine/blob/main/packages/core/src/RenderPipeline/RenderQueue.ts\r\n\tprivate static _quickSort<T>(a: T[], from: number, to: number, compareFunc: Function): void {\r\n\t\twhile (true) {\r\n\t\t\t// Insertion sort is faster for short arrays.\r\n\t\t\tif (to - from <= 10) {\r\n\t\t\t\tRenderQueue._insertionSort(a, from, to, compareFunc);\r\n\t\t\t\treturn;\r\n\t\t\t}\r\n\t\t\tconst third_index = (from + to) >> 1;\r\n\t\t\t// Find a pivot as the median of first, last and middle element.\r\n\t\t\tlet v0 = a[from];\r\n\t\t\tlet v1 = a[to - 1];\r\n\t\t\tlet v2 = a[third_index];\r\n\t\t\tconst c01 = compareFunc(v0, v1);\r\n\t\t\tif (c01 > 0) {\r\n\t\t\t\t// v1 < v0, so swap them.\r\n\t\t\t\tconst tmp = v0;\r\n\t\t\t\tv0 = v1;\r\n\t\t\t\tv1 = tmp;\r\n\t\t\t} // v0 <= v1.\r\n\t\t\tconst c02 = compareFunc(v0, v2);\r\n\t\t\tif (c02 >= 0) {\r\n\t\t\t\t// v2 <= v0 <= v1.\r\n\t\t\t\tconst tmp = v0;\r\n\t\t\t\tv0 = v2;\r\n\t\t\t\tv2 = v1;\r\n\t\t\t\tv1 = tmp;\r\n\t\t\t} else {\r\n\t\t\t\t// v0 <= v1 && v0 < v2\r\n\t\t\t\tconst c12 = compareFunc(v1, v2);\r\n\t\t\t\tif (c12 > 0) {\r\n\t\t\t\t\t// v0 <= v2 < v1\r\n\t\t\t\t\tconst tmp = v1;\r\n\t\t\t\t\tv1 = v2;\r\n\t\t\t\t\tv2 = tmp;\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t\t// v0 <= v1 <= v2\r\n\t\t\ta[from] = v0;\r\n\t\t\ta[to - 1] = v2;\r\n\t\t\tconst pivot = v1;\r\n\t\t\tlet low_end = from + 1; // Upper bound of elements lower than pivot.\r\n\t\t\tlet high_start = to - 1; // Lower bound of elements greater than pivot.\r\n\t\t\ta[third_index] = a[low_end];\r\n\t\t\ta[low_end] = pivot;\r\n\r\n\t\t\t// From low_end to i are elements equal to pivot.\r\n\t\t\t// From i to high_start are elements that haven't been compared yet.\r\n\t\t\tpartition: for (let i = low_end + 1; i < high_start; i++) {\r\n\t\t\t\tlet element = a[i];\r\n\t\t\t\tlet order = compareFunc(element, pivot);\r\n\t\t\t\tif (order < 0) {\r\n\t\t\t\t\ta[i] = a[low_end];\r\n\t\t\t\t\ta[low_end] = element;\r\n\t\t\t\t\tlow_end++;\r\n\t\t\t\t} else if (order > 0) {\r\n\t\t\t\t\tdo {\r\n\t\t\t\t\t\thigh_start--;\r\n\t\t\t\t\t\tif (high_start == i) break partition;\r\n\t\t\t\t\t\tconst top_elem = a[high_start];\r\n\t\t\t\t\t\torder = compareFunc(top_elem, pivot);\r\n\t\t\t\t\t} while (order > 0);\r\n\t\t\t\t\ta[i] = a[high_start];\r\n\t\t\t\t\ta[high_start] = element;\r\n\t\t\t\t\tif (order < 0) {\r\n\t\t\t\t\t\telement = a[i];\r\n\t\t\t\t\t\ta[i] = a[low_end];\r\n\t\t\t\t\t\ta[low_end] = element;\r\n\t\t\t\t\t\tlow_end++;\r\n\t\t\t\t\t}\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t\tif (to - high_start < low_end - from) {\r\n\t\t\t\tthis._quickSort(a, high_start, to, compareFunc);\r\n\t\t\t\tto = low_end;\r\n\t\t\t} else {\r\n\t\t\t\tthis._quickSort(a, from, low_end, compareFunc);\r\n\t\t\t\tfrom = high_start;\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\tprivate static _insertionSort<T>(a: T[], from: number, to: number, compareFunc: Function): void {\r\n\t\tfor (let i = from + 1; i < to; i++) {\r\n\t\t\tlet j;\r\n\t\t\tconst element = a[i];\r\n\t\t\tfor (j = i - 1; j >= from; j--) {\r\n\t\t\t\tconst tmp = a[j];\r\n\t\t\t\tconst order = compareFunc(tmp, element);\r\n\t\t\t\tif (order > 0) {\r\n\t\t\t\t\ta[j + 1] = tmp;\r\n\t\t\t\t} else {\r\n\t\t\t\t\tbreak;\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t\ta[j + 1] = element;\r\n\t\t}\r\n\t}\r\n}\r\n","import { Scene } from \"../Scene\";\r\nimport Camera from \"../camera/Camera\";\r\nimport Color from \"../math/Color\";\r\nimport Pass from \"../pass/Pass\";\r\nimport Context from \"../render/Context\";\r\nimport Texture from \"../render/Texture\";\r\nimport combine from \"../utils/combine\";\r\nimport CullingVolume from \"./CullingVolume\";\r\nimport LightManger from \"./LightManger\";\r\nimport RenderQueue from \"./RenderQueue\";\r\n\r\ninterface FrameStateOptions {\r\n\tbackground?: Background;\r\n}\r\n\r\nexport interface Background {\r\n\tvalue: Color | Texture;\r\n\topacity: number;\r\n}\r\n\r\nexport class FrameState {\r\n\tpublic background: Background;\r\n\tpublic pass: Pass;\r\n\tpublic renderQueue: RenderQueue;\r\n\tpublic drawCallnums: number;\r\n\tpublic geometryMemory: number;\r\n\tpublic textureMemory: number;\r\n\tpublic frameNumber: number;\r\n\tpublic cullingVolume: CullingVolume;\r\n\tpublic definesDirty: boolean;\r\n\tprivate _defines: object;\r\n\tconstructor(public context: Context, public lightManger?: LightManger, options: FrameStateOptions = {}) {\r\n\t\tthis.background = options.background;\r\n\t\tthis.renderQueue = new RenderQueue();\r\n\t\tthis.geometryMemory = 0;\r\n\t\tthis.textureMemory = 0;\r\n\t\tthis.frameNumber = 0;\r\n\t\tthis._defines = {};\r\n\t\tthis.definesDirty = true;\r\n\t}\r\n\tget defines() {\r\n\t\treturn this._defines;\r\n\t}\r\n\tset defines(value) {\r\n\t\tthis.definesDirty = true;\r\n\t\tthis._defines = combine(value, this._defines, false);\r\n\t}\r\n\tupdate(camera: Camera, options: FrameStateOptions = {}) {\r\n\t\tthis.background = options.background;\r\n\r\n\t\tthis.renderQueue.reset();\r\n\t\tthis?.lightManger?.update?.(this, camera);\r\n\t\tthis.cullingVolume = camera.getCullingVolume();\r\n\t\tthis.frameNumber += 1;\r\n\t}\r\n\r\n\tresetCullingVolume(camera: Camera) {\r\n\t\tthis.cullingVolume = camera.getCullingVolume();\r\n\t}\r\n\r\n\tstatic getFrameStateOptionsByScene(sceneInstance: Scene) {\r\n\t\treturn {\r\n\t\t\tbackground: sceneInstance.background\r\n\t\t};\r\n\t}\r\n}\r\n","import { LightType } from \"../core/WebGPUTypes\";\r\nimport Vector3 from \"../math/Vector3\";\r\nimport Vector4 from \"../math/Vector4\";\r\nimport { Light } from \"./Light\";\r\n\r\nexport class AmbientLight extends Light {\r\n\tprivate _colorAndIntensity: Vector4;\r\n\tconstructor(color: Vector3, intensity: number) {\r\n\t\tsuper(color, intensity);\r\n\t\tthis.lightType = LightType.AmbientLight;\r\n\t\tthis._colorAndIntensity = new Vector4(color.x, color.y, color.z, intensity);\r\n\t}\r\n\tget ColorAndIntensity() {\r\n\t\tthis._colorAndIntensity.set(this.color.x, this.color.y, this.color.z, this.intensity);\r\n\t\treturn this._colorAndIntensity;\r\n\t}\r\n}\r\n// light.color ).multiplyScalar( light.intensity * scaleFactor );\r\n","import { AmbientLight } from \"../light/AmbientLight\";\r\nimport { DirectionalLight } from \"../light/DirectionalLight\";\r\nimport { PointLight } from \"../light/PointLight\";\r\nimport { SpotLight } from \"../light/SpotLight\";\r\nimport { FrameState } from \"./FrameState\";\r\nimport ShaderData from \"../render/ShaderData\";\r\nimport {\r\n\tTextureUsage,\r\n\tBufferUsage,\r\n\tTextureFormat,\r\n\tCompareFunction,\r\n\tSamplerBindingType,\r\n\tTextureSampleType,\r\n\tTextureViewDimension,\r\n\tBufferBindingType\r\n} from \"./WebGPUConstant\";\r\nimport UniformBuffer from \"../render/UniformBuffer\";\r\nimport Camera from \"../camera/Camera\";\r\nimport { Light } from \"../light/Light\";\r\nimport Vector3 from \"../math/Vector3\";\r\nimport { LightMangerOptions, LightType } from \"../core/WebGPUTypes\";\r\nimport Texture from \"../render/Texture\";\r\nimport Sampler from \"../render/Sampler\";\r\nimport { UniformEnum } from \"../render/Uniforms\";\r\n\r\nexport default class LightManger {\r\n\tlightUniformBuffer: UniformBuffer;\r\n\tshadowUniformBuffer: UniformBuffer;\r\n\tpointLights: PointLight[];\r\n\r\n\tspotLights: SpotLight[];\r\n\r\n\tdirectLights: DirectionalLight[];\r\n\r\n\tambientLight: AmbientLight;\r\n\r\n\tlightShaderData: ShaderData;\r\n\r\n\tlightCountDirty: boolean;\r\n\r\n\tprivate openShadow: boolean;\r\n\tspotLightShadowMapTextureArray: Texture;\r\n\tpointLightShadowMapTextureArray: Texture;\r\n\tdirectLightShadowMapTextureArray: Texture;\r\n\t_testTexture: Texture;\r\n\r\n\tconstructor(options: LightMangerOptions) {\r\n\t\tthis.spotLights = [];\r\n\t\tthis.pointLights = [];\r\n\t\tthis.directLights = [];\r\n\t\tthis.ambientLight = new AmbientLight(new Vector3(1.0, 1.0, 1.0), 0.2);\r\n\t\tthis.lightCountDirty = true;\r\n\t\tthis.openShadow = options.openShadow;\r\n\t}\r\n\tupdate(frameState: FrameState, camera: Camera) {\r\n\t\tthis.checkLightShadowState();\r\n\t\tthis.updateLight(camera);\r\n\t}\r\n\tadd(light: Light) {\r\n\t\tthis.lightCountDirty = true;\r\n\t\tif (light.lightType == LightType.AmbientLight) {\r\n\t\t\tthis.ambientLight = <AmbientLight>light;\r\n\t\t} else if (light.lightType == LightType.DirectionalLight) {\r\n\t\t\tthis.directLights.push(<DirectionalLight>light);\r\n\t\t} else if (light.lightType == LightType.PointLight) {\r\n\t\t\tthis.pointLights.push(<PointLight>light);\r\n\t\t} else if (light.lightType == LightType.SpotLight) {\r\n\t\t\tthis.spotLights.push(<SpotLight>light);\r\n\t\t}\r\n\t}\r\n\tremove(light: Light) {\r\n\t\tthis.lightCountDirty = true;\r\n\t\tif (light.lightType == LightType.AmbientLight) {\r\n\t\t\tthis.ambientLight = new AmbientLight(new Vector3(1.0, 1.0, 1.0), 1.0);\r\n\t\t} else if (light.lightType == LightType.DirectionalLight) {\r\n\t\t\tthis.directLights.splice(this.directLights.indexOf(<DirectionalLight>light), 1);\r\n\t\t} else if (light.lightType == LightType.PointLight) {\r\n\t\t\tthis.pointLights.splice(this.pointLights.indexOf(<PointLight>light), 1);\r\n\t\t} else if (light.lightType == LightType.SpotLight) {\r\n\t\t\tthis.spotLights.splice(this.spotLights.indexOf(<SpotLight>light), 1);\r\n\t\t}\r\n\t}\r\n\tcheckLightShadowState() {\r\n\t\tconst lights = this.getAllLights();\r\n\t\tfor (let i = 0; i < lights.length; i++) {\r\n\t\t\tconst light = lights[i];\r\n\t\t\tif (light.shadowDirty) {\r\n\t\t\t\tlight.shadowDirty = false;\r\n\t\t\t\tthis.lightCountDirty = true;\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\r\n\tupdateLightShadow() {\r\n\t\tif (this.spotLightShadowMapTextureArray) this.spotLightShadowMapTextureArray.dirty = true;\r\n\r\n\t\tif (this.pointLightShadowMapTextureArray) this.pointLightShadowMapTextureArray.dirty = true;\r\n\r\n\t\tif (this.directLightShadowMapTextureArray) this.directLightShadowMapTextureArray.dirty = true;\r\n\t}\r\n\r\n\tprivate updateLight(camera: Camera) {\r\n\t\tif (this.lightCountDirty) {\r\n\t\t\tthis.lightCountDirty = false;\r\n\t\t\tif (this.lightShaderData) this.lightShaderData.destroy();\r\n\t\t\tthis.createLightShaderData();\r\n\t\t}\r\n\t}\r\n\tprivate createLightShaderData() {\r\n\t\tthis.lightShaderData = new ShaderData(\"light\", 0, 2, 2);\r\n\t\tthis.lightUniformBuffer = new UniformBuffer({\r\n\t\t\tlabel: \"light\",\r\n\t\t\ttype: BufferBindingType.ReadOnlyStorage,\r\n\t\t\tusage: BufferUsage.Storage | BufferUsage.CopyDst\r\n\t\t});\r\n\r\n\t\tthis.lightShaderData.setDefine(\"spotLightsCount\", this.spotLights.length);\r\n\t\tthis.lightShaderData.setDefine(\"pointLightsCount\", this.pointLights.length);\r\n\t\tthis.lightShaderData.setDefine(\"dirtectLightsCount\", this.directLights.length);\r\n\t\tthis.lightShaderData.setDefine(\"ambientLightCount\", 1);\r\n\t\tif (this.ambientLight)\r\n\t\t\tthis.lightUniformBuffer.setUniform(\r\n\t\t\t\t\"ambientLight\",\r\n\t\t\t\t() => {\r\n\t\t\t\t\treturn this.ambientLight.ColorAndIntensity;\r\n\t\t\t\t},\r\n\t\t\t\tUniformEnum.FloatVec4\r\n\t\t\t);\r\n\t\tif (this.spotLights.length) {\r\n\t\t\t//初始化聚光灯\r\n\t\t\tthis.lightUniformBuffer.setUniform(\r\n\t\t\t\t\"spotLights\",\r\n\t\t\t\t() => {\r\n\t\t\t\t\treturn this.spotLights;\r\n\t\t\t\t},\r\n\t\t\t\tUniformEnum.SpotLights,\r\n\t\t\t\tthis.spotLights.length\r\n\t\t\t);\r\n\t\t}\r\n\t\tif (this.pointLights.length) {\r\n\t\t\t//点光源\r\n\t\t\tthis.lightUniformBuffer.setUniform(\r\n\t\t\t\t\"pointLights\",\r\n\t\t\t\t() => {\r\n\t\t\t\t\treturn this.pointLights;\r\n\t\t\t\t},\r\n\t\t\t\tUniformEnum.PointLights,\r\n\t\t\t\tthis.pointLights.length\r\n\t\t\t);\r\n\t\t}\r\n\t\tif (this.directLights.length) {\r\n\t\t\t//方向光\r\n\t\t\tthis.lightUniformBuffer.setUniform(\r\n\t\t\t\t\"directLights\",\r\n\t\t\t\t() => {\r\n\t\t\t\t\treturn this.directLights;\r\n\t\t\t\t},\r\n\t\t\t\tUniformEnum.DirtectLights,\r\n\t\t\t\tthis.directLights.length\r\n\t\t\t);\r\n\t\t}\r\n\r\n\t\tshadowShaderData: {\r\n\t\t\tif (this.openShadow) {\r\n\t\t\t\tconst spotLightShadowMapTextureArray = (this.spotLightShadowMapTextureArray =\r\n\t\t\t\t\tthis.createShadowMapTextureArray(this.spotLights));\r\n\t\t\t\tconst pointLightShadowMapTextureArray = (this.pointLightShadowMapTextureArray =\r\n\t\t\t\t\tthis.createShadowMapTextureArray(this.pointLights));\r\n\t\t\t\tconst directLightShadowMapTextureArray = (this.directLightShadowMapTextureArray =\r\n\t\t\t\t\tthis.createShadowMapTextureArray(this.directLights));\r\n\t\t\t\tif (\r\n\t\t\t\t\t!spotLightShadowMapTextureArray &&\r\n\t\t\t\t\t!pointLightShadowMapTextureArray &&\r\n\t\t\t\t\t!directLightShadowMapTextureArray\r\n\t\t\t\t)\r\n\t\t\t\t\tbreak shadowShaderData;\r\n\r\n\t\t\t\t//define\r\n\t\t\t\tthis.lightShaderData.setDefine(\"openShadow\", this.openShadow);\r\n\r\n\t\t\t\t//shadowUniformBuffer\r\n\t\t\t\tthis.shadowUniformBuffer = new UniformBuffer({\r\n\t\t\t\t\tlabel: \"shadow\",\r\n\t\t\t\t\ttype: BufferBindingType.ReadOnlyStorage,\r\n\t\t\t\t\tusage: BufferUsage.Storage | BufferUsage.CopyDst\r\n\t\t\t\t});\r\n\r\n\t\t\t\t//matrix,near,far...\r\n\t\t\t\tconst spotLightWithShadowCount = this.setShadowUniform(\r\n\t\t\t\t\t\"spotLightShadows\",\r\n\t\t\t\t\tthis.spotLights,\r\n\t\t\t\t\tUniformEnum.SpotLightShadows\r\n\t\t\t\t);\r\n\t\t\t\tconst pointLightWithShadowCount = this.setShadowUniform(\r\n\t\t\t\t\t\"pointLightShadows\",\r\n\t\t\t\t\tthis.pointLights,\r\n\t\t\t\t\tUniformEnum.PointLightShadows\r\n\t\t\t\t);\r\n\t\t\t\tconst directLightWithShadowCount = this.setShadowUniform(\r\n\t\t\t\t\t\"directLightShadows\",\r\n\t\t\t\t\tthis.directLights,\r\n\t\t\t\t\tUniformEnum.DirtectLightShadows\r\n\t\t\t\t);\r\n\t\t\t\tthis.lightShaderData.setUniformBuffer(\"shadow\", this.shadowUniformBuffer);\r\n\r\n\t\t\t\tthis.lightShaderData.setDefine(\"spotLightShadowMapsCount\", spotLightWithShadowCount);\r\n\t\t\t\tthis.lightShaderData.setDefine(\"pointLightShadowMapsCount\", pointLightWithShadowCount);\r\n\t\t\t\tthis.lightShaderData.setDefine(\"directLightShadowMapsCount\", directLightWithShadowCount);\r\n\r\n\t\t\t\t//texture,sample\r\n\t\t\t\tif (spotLightShadowMapTextureArray !== undefined) {\r\n\t\t\t\t\tif (spotLightShadowMapTextureArray.textureProp.size.depth != spotLightWithShadowCount)\r\n\t\t\t\t\t\tconsole.warn(\"spotLightShadowMap align has problem\");\r\n\t\t\t\t\tthis.lightShaderData.setTexture(\"spotLightShadowMapTextureArray\", spotLightShadowMapTextureArray);\r\n\t\t\t\t\t// this._testTexture = spotLightShadowMapTextureArray\r\n\t\t\t\t}\r\n\t\t\t\tif (pointLightShadowMapTextureArray !== undefined) {\r\n\t\t\t\t\tif (pointLightShadowMapTextureArray.textureProp.size.depth != pointLightWithShadowCount)\r\n\t\t\t\t\t\tconsole.warn(\"pointLightShadowMap align has problem\");\r\n\t\t\t\t\tthis.lightShaderData.setTexture(\"pointLightShadowMapTextureArray\", pointLightShadowMapTextureArray);\r\n\t\t\t\t\t// this._testTexture = pointLightShadowMapTextureArray;\r\n\t\t\t\t}\r\n\t\t\t\tif (directLightShadowMapTextureArray !== undefined) {\r\n\t\t\t\t\tif (directLightShadowMapTextureArray.textureProp.size.depth != directLightWithShadowCount)\r\n\t\t\t\t\t\tconsole.warn(\"directLightShadowMap align has problem\");\r\n\t\t\t\t\tthis.lightShaderData.setTexture(\r\n\t\t\t\t\t\t\"directLightShadowMapTextureArray\",\r\n\t\t\t\t\t\tdirectLightShadowMapTextureArray\r\n\t\t\t\t\t);\r\n\t\t\t\t\t// this._testTexture = directLightShadowMapTextureArray\r\n\t\t\t\t}\r\n\t\t\t\tthis.lightShaderData.setSampler(\r\n\t\t\t\t\t\"shadowSampler\",\r\n\t\t\t\t\tnew Sampler({ compare: CompareFunction.Less }, { type: SamplerBindingType.Comparison })\r\n\t\t\t\t);\r\n\t\t\t\t// this.lightShaderData.setSampler(\"shadowSampler\", new Sampler());\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\tthis.lightShaderData.setUniformBuffer(\"light\", this.lightUniformBuffer);\r\n\t}\r\n\r\n\tpublic getAllLights(): Array<Light> {\r\n\t\tconst result = [];\r\n\t\treturn result.concat(this.spotLights, this.pointLights, this.directLights);\r\n\t}\r\n\r\n\tdestroy() {\r\n\t\tthis.lightShaderData.destroy();\r\n\t\tthis.lightUniformBuffer.destroy();\r\n\t}\r\n\r\n\tcreateShadowMapTextureArray(lights: Array<Light>) {\r\n\t\tif (lights.length <= 0) return undefined;\r\n\t\tconst shadowMapSources = [];\r\n\t\tfor (let i = 0; i < lights.length; i++) {\r\n\t\t\tconst light = lights[i];\r\n\t\t\tif (light.shadow) {\r\n\t\t\t\tconst shadowMapTexture = light.shadow.getShadowMapTexture();\r\n\t\t\t\tconst shadowMapSource = {\r\n\t\t\t\t\tsource: shadowMapTexture,\r\n\t\t\t\t\twidth: shadowMapTexture.textureProp.size.width,\r\n\t\t\t\t\theight: shadowMapTexture.textureProp.size.height,\r\n\t\t\t\t\tdepth: 1,\r\n\t\t\t\t\tx: 0,\r\n\t\t\t\t\ty: 0,\r\n\t\t\t\t\tz: i\r\n\t\t\t\t};\r\n\t\t\t\tshadowMapSources.push(shadowMapSource);\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\tif (shadowMapSources.length <= 0) return undefined;\r\n\r\n\t\tconst shadowMapTextureArray = new Texture({\r\n\t\t\tsize: {\r\n\t\t\t\twidth: shadowMapSources[0].width,\r\n\t\t\t\theight: shadowMapSources[0].height,\r\n\t\t\t\tdepth: shadowMapSources.length\r\n\t\t\t},\r\n\t\t\tfixedSize: true,\r\n\t\t\tsampleType: TextureSampleType.Depth,\r\n\t\t\tformat: TextureFormat.Depth24Plus,\r\n\t\t\tusage: TextureUsage.TextureBinding | TextureUsage.CopyDst,\r\n\t\t\tdata: shadowMapSources,\r\n\t\t\tviewFormats: TextureViewDimension.E2dArray\r\n\t\t});\r\n\r\n\t\treturn shadowMapTextureArray;\r\n\t}\r\n\r\n\tsetShadowUniform(uniformName: string, lights: Array<Light>, uniformType: UniformEnum) {\r\n\t\tif (lights.length) {\r\n\t\t\tconst lightWithShadowArray = [];\r\n\t\t\tfor (let i = 0; i < lights.length; i++) {\r\n\t\t\t\tconst light = lights[i];\r\n\t\t\t\tif (!light.shadow) continue;\r\n\t\t\t\tlightWithShadowArray.push(light);\r\n\t\t\t}\r\n\r\n\t\t\tthis.shadowUniformBuffer.setUniform(\r\n\t\t\t\tuniformName,\r\n\t\t\t\t() => {\r\n\t\t\t\t\treturn lightWithShadowArray;\r\n\t\t\t\t},\r\n\t\t\t\tuniformType,\r\n\t\t\t\tlightWithShadowArray.length\r\n\t\t\t);\r\n\r\n\t\t\treturn lightWithShadowArray.length;\r\n\t\t}\r\n\t}\r\n}\r\n","import Camera from \"../camera/Camera\";\nimport { Mesh } from \"../mesh/Mesh\";\nimport { FrameState } from \"./FrameState\";\nexport default class MeshManger {\n\tprivate _list: Map<string | number, Mesh>;\n\tconstructor() {\n\t\tthis._list = new Map();\n\t}\n\tget length() {\n\t\treturn this._list.size;\n\t}\n\tupdate(frameState: FrameState, camera: Camera): void {\n\t\tthis._list.forEach((instance) => {\n\t\t\tinstance.update(frameState, camera);\n\t\t});\n\t}\n\tadd(instance: Mesh): Mesh {\n\t\tif (this._list.get(instance.uid)) return this._list.get(instance.uid);\n\t\tthis._list.set(instance.uid, instance);\n\t\treturn instance;\n\t}\n\tremove(instance: Mesh): boolean {\n\t\tif (this._list.get(instance.uid)) {\n\t\t\tinstance.destroy();\n\t\t\tthis._list.delete(instance.uid);\n\t\t\treturn true;\n\t\t}\n\t\treturn false;\n\t}\n\tcontains(instance: Mesh) {\n\t\treturn !!this._list.get(instance.uid);\n\t}\n}\n","import { PassType } from \"../core/WebGPUTypes\";\r\nimport Attachment from \"./Attachment\";\r\nimport Context from \"./Context\";\r\nimport QuerySet from \"./QuerySet\";\r\nimport Texture from \"./Texture\";\r\n\r\nexport default class RenderTarget {\r\n\tpublic context: Context;\r\n\tprivate _renderPassDescriptor: GPURenderPassDescriptor;\r\n\tprivate renderEncoder: GPURenderPassEncoder;\r\n\tprivate commandEncoder: GPUCommandEncoder | null;\r\n\tprivate computeEncoder: GPUComputePassEncoder;\r\n\ttexture: any;\r\n\tconstructor(\r\n\t\tpublic type: PassType,\r\n\t\tpublic colorAttachments: Attachment[],\r\n\t\tpublic depthAttachment?: Attachment,\r\n\t\tpublic stencilAttachment?: Attachment,\r\n\t\tpublic querySet?: QuerySet\r\n\t) {\r\n\t\tthis.renderEncoder = undefined;\r\n\t\tthis.computeEncoder = undefined;\r\n\t\tthis._renderPassDescriptor = undefined;\r\n\t\tthis.commandEncoder = undefined;\r\n\t\tthis.context = undefined;\r\n\t}\r\n\tget renderPassDescriptor() {\r\n\t\tthis._renderPassDescriptor = this.getRenderPassDescriptor();\r\n\t\treturn this._renderPassDescriptor;\r\n\t}\r\n\tpublic getColorTexture(index = 0): Texture {\r\n\t\tconst colAtt = this.colorAttachments[index];\r\n\t\tif (colAtt) {\r\n\t\t\treturn colAtt.texture as Texture;\r\n\t\t} else {\r\n\t\t\treturn null;\r\n\t\t}\r\n\t}\r\n\tpublic getDepthTexture(): Texture {\r\n\t\tif (this.depthAttachment) {\r\n\t\t\treturn this.depthAttachment.texture as Texture;\r\n\t\t}\r\n\t}\r\n\tprivate getRenderPassDescriptor(): GPURenderPassDescriptor | null {\r\n\t\tthis.checkSize();\r\n\t\tthis.depthAttachment?.texture?.update(this.context);\r\n\t\treturn {\r\n\t\t\t...(this.colorAttachments && {\r\n\t\t\t\tcolorAttachments: this.colorAttachments.map((colorAttachment) => {\r\n\t\t\t\t\tcolorAttachment?.texture?.update && colorAttachment?.texture?.update(this.context);\r\n\t\t\t\t\treturn {\r\n\t\t\t\t\t\tview:\r\n\t\t\t\t\t\t\t// 暂时这么写\r\n\t\t\t\t\t\t\tcolorAttachment.texture.textureView || undefined,\r\n\t\t\t\t\t\tresolveTarget:\r\n\t\t\t\t\t\t\tcolorAttachment.resolveTarget != undefined\r\n\t\t\t\t\t\t\t\t? colorAttachment.resolveTarget.textureView\r\n\t\t\t\t\t\t\t\t: undefined,\r\n\t\t\t\t\t\tclearValue: colorAttachment.value,\r\n\t\t\t\t\t\tloadOp: colorAttachment.op,\r\n\t\t\t\t\t\tstoreOp: colorAttachment.storeOp\r\n\t\t\t\t\t} as GPURenderPassColorAttachment;\r\n\t\t\t\t})\r\n\t\t\t}),\r\n\t\t\t...((this.depthAttachment || this.stencilAttachment) && {\r\n\t\t\t\tdepthStencilAttachment: {\r\n\t\t\t\t\tview: this.depthAttachment?.texture?.textureView || undefined,\r\n\t\t\t\t\tdepthLoadOp: this.depthAttachment?.op || \"clear\",\r\n\t\t\t\t\tdepthClearValue: this.depthAttachment?.value || 1.0,\r\n\t\t\t\t\tdepthStoreOp: this.depthAttachment?.storeOp || \"store\",\r\n\t\t\t\t\tdepthReadOnly: this.depthAttachment?.readOnly || false\r\n\t\t\t\t\t// stencilLoadOp: this.stencilAttachment?.op || \"clear\",\r\n\t\t\t\t\t// stencilClearValue: this.stencilAttachment?.value || 0,\r\n\t\t\t\t\t// stencilStoreOp: this.stencilAttachment?.storeOp || \"store\",\r\n\t\t\t\t} as GPURenderPassDepthStencilAttachment\r\n\t\t\t})\r\n\t\t};\r\n\t}\r\n\r\n\tpublic beginRenderPassEncoder(context: Context) {\r\n\t\tif (!this.context) this.context = context;\r\n\t\tconst { device } = this.context;\r\n\t\tthis.commandEncoder = device.createCommandEncoder();\r\n\t\tthis.renderEncoder = this.commandEncoder.beginRenderPass(this.renderPassDescriptor);\r\n\t\treturn this.renderEncoder;\r\n\t}\r\n\tpublic endRenderPassEncoder() {\r\n\t\tthis.renderEncoder?.end();\r\n\t\tthis.context.device.queue.submit([this.commandEncoder.finish()]);\r\n\t\tthis.commandEncoder = null;\r\n\t\tthis.renderEncoder = null;\r\n\t}\r\n\tpublic beginComputePassEncoder(context: Context) {\r\n\t\tif (!this.context) this.context = context;\r\n\t\tconst { device } = this.context;\r\n\t\tthis.commandEncoder = device.createCommandEncoder();\r\n\t\tthis.computeEncoder = this.commandEncoder.beginComputePass();\r\n\t\treturn this.computeEncoder;\r\n\t}\r\n\tpublic endComputePassEncoder() {\r\n\t\tthis.computeEncoder?.end();\r\n\t\tthis.context.device.queue.submit([this.commandEncoder.finish()]);\r\n\t\tthis.commandEncoder = null;\r\n\t\tthis.renderEncoder = null;\r\n\t}\r\n\tprivate checkSize() {\r\n\t\tconst { width, height, depth } = this.context.presentationSize;\r\n\t\tif (this.depthAttachment.texture) {\r\n\t\t\tconst size = this.depthAttachment?.texture?.textureProp?.size;\r\n\t\t\tif (width != size?.width || height != size?.height || depth != size?.depth) {\r\n\t\t\t\tthis.depthAttachment.texture.setSize(width, height, depth);\r\n\t\t\t}\r\n\t\t}\r\n\t\tif (this.colorAttachments) {\r\n\t\t\tthis.colorAttachments.forEach((colorAttachment) => {\r\n\t\t\t\tif (colorAttachment.texture) {\r\n\t\t\t\t\tconst size = colorAttachment?.texture?.textureProp?.size;\r\n\t\t\t\t\tif (size && (width != size?.width || height != size?.height || depth != size?.depth))\r\n\t\t\t\t\t\tcolorAttachment.texture.setSize(width, height, depth);\r\n\t\t\t\t}\r\n\t\t\t});\r\n\t\t}\r\n\t}\r\n\tdestroy() {\r\n\t\tif (this.colorAttachments) {\r\n\t\t\tthis.colorAttachments.forEach((colorAttachment) => {\r\n\t\t\t\tif (colorAttachment.texture) {\r\n\t\t\t\t\tcolorAttachment.texture.destroy();\r\n\t\t\t\t}\r\n\t\t\t});\r\n\t\t}\r\n\t\tif (this.depthAttachment.texture) this.depthAttachment.texture.destroy();\r\n\t}\r\n}\r\n","import { TextureFormat, TextureUsage } from \"../core/WebGPUConstant\";\r\nimport Geometry from \"../geometry/Geometry\";\r\nimport ShaderMaterial from \"../material/ShaderMaterial\";\r\nimport { Mesh } from \"../mesh/Mesh\";\r\nimport Attachment from \"../render/Attachment\";\r\nimport { Float32Attribute } from \"../render/Attribute\";\r\nimport Context from \"../render/Context\";\r\nimport RenderTarget from \"../render/RenderTarget\";\r\nimport Sampler from \"../render/Sampler\";\r\nimport Texture from \"../render/Texture\";\r\nimport getVertFrag from \"../shader/Shaders\";\r\nexport default class ResolveFrame {\r\n\tcanvasRenderTarget: RenderTarget;\r\n\tmaterial: ShaderMaterial;\r\n\tgeometry: Geometry;\r\n\tquadMesh: Mesh;\r\n\tconstructor() {\r\n\t\tthis.geometry = new Geometry({});\r\n\t\tthis.geometry.setAttribute(\r\n\t\t\tnew Float32Attribute(\"position\", [-1.0, 1.0, -1.0, -1.0, 1.0, -1.0, 1.0, -1.0, 1.0, 1.0, -1.0, 1.0], 2)\r\n\t\t);\r\n\t\tthis.geometry.count = 6;\r\n\t\tconst shader = getVertFrag(\"resolve\", { positionLocation: 0 });\r\n\t\tthis.material = new ShaderMaterial({\r\n\t\t\ttype: \"resolve\",\r\n\t\t\tfrag: shader.frag,\r\n\t\t\tvert: shader.vert,\r\n\t\t\tuniforms: {\r\n\t\t\t\ttexture: {\r\n\t\t\t\t\ttype: \"texture\",\r\n\t\t\t\t\tvalue: undefined\r\n\t\t\t\t},\r\n\t\t\t\tsampler: {\r\n\t\t\t\t\ttype: \"sampler\",\r\n\t\t\t\t\tvalue: new Sampler({\r\n\t\t\t\t\t\tmagFilter: \"linear\",\r\n\t\t\t\t\t\tminFilter: \"linear\"\r\n\t\t\t\t\t})\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t});\r\n\t\tthis.quadMesh = new Mesh(this.geometry, this.material);\r\n\t}\r\n\trender(context: Context, colorTexture?: Texture) {\r\n\t\tif (!this.canvasRenderTarget) this.initRenderTarget(context);\r\n\t\t// this.material\r\n\t\tthis.material.uniforms.texture.value = colorTexture;\r\n\t\t// @ts-ignore\r\n\t\tthis.canvasRenderTarget.colorAttachments[0].texture = {\r\n\t\t\ttextureView: context.context.getCurrentTexture().createView()\r\n\t\t};\r\n\t\tthis.material.update(undefined, this.quadMesh);\r\n\r\n\t\tconst drawComand = this.quadMesh.getDrawCommand();\r\n\r\n\t\tconst currentRenderPassEncoder = this.canvasRenderTarget.beginRenderPassEncoder(context);\r\n\r\n\t\tdrawComand.render(context, currentRenderPassEncoder);\r\n\r\n\t\tthis.canvasRenderTarget.endRenderPassEncoder();\r\n\t}\r\n\tprivate initRenderTarget(context: Context) {\r\n\t\tconst { width, height, depth } = context.presentationSize;\r\n\t\tconst colorAttachment = new Attachment(\r\n\t\t\t{ r: 0.0, g: 0.0, b: 0.0, a: 0 },\r\n\t\t\t{\r\n\t\t\t\t// @ts-ignore\r\n\t\t\t\ttexture: {\r\n\t\t\t\t\ttextureView: undefined\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t);\r\n\t\tconst depthTexture = new Texture({\r\n\t\t\tlabel: \"resolveDepth\",\r\n\t\t\tsize: { width, height, depth },\r\n\t\t\tformat: TextureFormat.Depth24Plus,\r\n\t\t\tusage: TextureUsage.RenderAttachment\r\n\t\t});\r\n\t\tconst depthAttachment = new Attachment(1.0, { texture: depthTexture });\r\n\t\tthis.canvasRenderTarget = new RenderTarget(\"render\", [colorAttachment], depthAttachment);\r\n\t}\r\n}\r\n","import Context from \"../render/Context\";\r\nimport Texture from \"../render/Texture\";\r\nimport PostEffect from \"./PostEffect\";\r\nimport ResolveFrame from \"./ResolveFrame\";\r\n\r\nexport default class PostEffectCollection {\r\n\tprivate _postEffects: Map<string, PostEffect>;\r\n\tpublic currentColorTexture: Texture;\r\n\tprivate resolveFrame: ResolveFrame;\r\n\tconstructor() {\r\n\t\tthis._postEffects = new Map();\r\n\t\tthis.currentColorTexture = undefined;\r\n\t\tthis.resolveFrame = new ResolveFrame();\r\n\t}\r\n\tadd(postEffect: PostEffect) {\r\n\t\tthis._postEffects.set(postEffect.id, postEffect);\r\n\t}\r\n\tremove(postEffect: PostEffect) {\r\n\t\tthis._postEffects.delete(postEffect.id);\r\n\t\tpostEffect.destroy();\r\n\t}\r\n\trender(context: Context, colorTexture: Texture): void {\r\n\t\tthis.currentColorTexture = colorTexture;\r\n\t\tthis._postEffects.forEach((postEffect) => {\r\n\t\t\tthis.currentColorTexture = postEffect.render(context, this.currentColorTexture);\r\n\t\t});\r\n\t\tthis.resolveFrame.render(context, this.currentColorTexture);\r\n\t}\r\n\tsetResolveFrameDirty(value: boolean) {\r\n\t\tthis.resolveFrame.material.dirty = value;\r\n\t}\r\n\tprivate postEffectsSort() {\r\n\t\t// this._postEffects.sort()\r\n\t}\r\n}\r\n","import { FrameState } from \"../core/FrameState.js\";\r\nimport { Material } from \"../material/Material.js\";\r\nimport Context from \"../render/Context.js\";\r\nimport { Target } from \"../render/RenderState\";\r\nimport RenderTarget from \"../render/RenderTarget.js\";\r\nimport Texture from \"../render/Texture.js\";\r\n\r\nclass Pass {\r\n\tpublic renderTarget: RenderTarget;\r\n\tpublic computeTarget: RenderTarget;\r\n\tpublic context: Context;\r\n\tpublic overrideMaterial?: Material;\r\n\tpublic colorTargets?: Array<Target>;\r\n\tpublic passRenderEncoder: GPURenderPassEncoder | null;\r\n\tpublic passComputeEncoder: GPUComputePassEncoder;\r\n\tconstructor(context: Context) {\r\n\t\tthis.context = context;\r\n\t}\r\n\trender(frameState: FrameState): void {}\r\n\tbeforeRender(options?: any) {\r\n\t\tthis.passRenderEncoder = this.renderTarget.beginRenderPassEncoder(this.context);\r\n\t\tif (this.computeTarget) this.passComputeEncoder = this.computeTarget.beginComputePassEncoder(this.context);\r\n\t}\r\n\tgetColorTexture(index = 0): Texture {\r\n\t\treturn this.renderTarget.getColorTexture(index) as Texture;\r\n\t}\r\n\tgetDepthTexture(): Texture | { gpuTexture: GPUTexture } {\r\n\t\treturn this.renderTarget.getDepthTexture();\r\n\t}\r\n\tafterRender() {\r\n\t\tthis.renderTarget.endRenderPassEncoder();\r\n\t\tif (this.computeTarget) this.computeTarget.endComputePassEncoder();\r\n\t}\r\n}\r\n\r\nexport default Pass;\r\n","import Camera from \"../camera/Camera\";\r\nimport { FrameState } from \"../core/FrameState\";\r\nimport { TextureFormat, TextureUsage } from \"../core/WebGPUConstant\";\r\nimport Color from \"../math/Color\";\r\nimport Attachment from \"../render/Attachment\";\r\nimport Context from \"../render/Context\";\r\nimport DrawCommand from \"../render/DrawCommand\";\r\nimport RenderTarget from \"../render/RenderTarget\";\r\nimport Texture from \"../render/Texture\";\r\nimport Pass from \"./Pass\";\r\n\r\nexport class BasicPass extends Pass {\r\n\tskyboxDrawComand: DrawCommand;\r\n\tconstructor(context: Context) {\r\n\t\tsuper(context);\r\n\t\tthis.init(context);\r\n\t}\r\n\r\n\tbeforeRender(frameState: FrameState) {\r\n\t\tthis.updateRenderTarget(frameState);\r\n\r\n\t\tsuper.beforeRender();\r\n\t}\r\n\r\n\trender(frameState: FrameState, camera?: Camera) {\r\n\t\tconst { renderQueue, lightManger } = frameState;\r\n\r\n\t\trenderQueue.sort();\r\n\t\trenderQueue.preRender(camera, this.context, this.passRenderEncoder);\r\n\t\trenderQueue.transparentRender(camera, this.context, this.passRenderEncoder, undefined, undefined, lightManger);\r\n\t\trenderQueue.opaqueRender(camera, this.context, this.passRenderEncoder, undefined, undefined, lightManger);\r\n\t\trenderQueue.debugQueueRender(camera, this.context, this.passRenderEncoder);\r\n\t}\r\n\tprivate init(context: Context) {\r\n\t\tthis.createRenderTarget(context);\r\n\t}\r\n\tprivate createRenderTarget(context: Context) {\r\n\t\tconst { width, height, depth } = this.context.presentationSize;\r\n\t\tconst colorTexture = new Texture({\r\n\t\t\tlabel: \"basicPassColor\",\r\n\t\t\tsize: { width, height, depth },\r\n\t\t\tformat: this.context.presentationFormat,\r\n\t\t\tusage: TextureUsage.RenderAttachment | TextureUsage.TextureBinding\r\n\t\t});\r\n\t\tconst depthTexture = new Texture({\r\n\t\t\tlabel: \"basicPassDepth\",\r\n\t\t\tsize: { width, height, depth },\r\n\t\t\tformat: TextureFormat.Depth24Plus,\r\n\t\t\tusage: TextureUsage.RenderAttachment\r\n\t\t});\r\n\t\tconst colorAttachment = new Attachment({ r: 0.0, g: 0.0, b: 0.0, a: 0.0 }, { texture: colorTexture });\r\n\t\tconst depthAttachment = new Attachment(1.0, { texture: depthTexture });\r\n\t\tthis.renderTarget = new RenderTarget(\"render\", [colorAttachment], depthAttachment);\r\n\t}\r\n\r\n\tprivate updateRenderTarget(frameState: FrameState) {\r\n\t\tif (frameState?.background?.value instanceof Color) {\r\n\t\t\tconst { red, green, blue } = frameState.background.value;\r\n\t\t\tconst opacity = frameState.background?.opacity;\r\n\t\t\tconst clearValue = {\r\n\t\t\t\tr: red,\r\n\t\t\t\tg: green,\r\n\t\t\t\tb: blue,\r\n\t\t\t\ta: opacity ?? 1.0\r\n\t\t\t};\r\n\t\t\tthis.renderTarget.colorAttachments[0].value = clearValue;\r\n\t\t}\r\n\t}\r\n}\r\n","import defined from \"../utils/defined\";\r\nimport GMath from \"./Math\";\r\nimport Matrix4 from \"./Matrix4\";\r\nimport Vector3 from \"./Vector3\";\r\nimport Vector4 from \"./Vector4\";\r\n\r\n/**\r\n * A plane in Hessian Normal Form defined by\r\n * <pre>\r\n * ax + by + cz + d = 0\r\n * </pre>\r\n * where (a, b, c) is the plane's <code>normal</code>, d is the signed\r\n * <code>distance</code> to the plane, and (x, y, z) is any point on\r\n * the plane.\r\n *\r\n * @alias Plane\r\n * @constructor\r\n *\r\n * @param {Vector3} normal The plane's normal (normalized).\r\n * @param {Number} distance The shortest distance from the origin to the plane.  The sign of\r\n * @example\r\n * // The plane x=0\r\n * const plane = new Plane(Vector3.UNIT_X, 0.0);\r\n *\r\n * @exception {DeveloperError} Normal must be normalized\r\n */\r\nclass Plane {\r\n\tnormal: Vector3;\r\n\tdistance: number;\r\n\tpublic static ORIGIN_XY_PLANE = Object.freeze(new Plane(Vector3.UNIT_Z, 0.0));\r\n\r\n\tpublic static ORIGIN_YZ_PLANE = Object.freeze(new Plane(Vector3.UNIT_X, 0.0));\r\n\r\n\tpublic static ORIGIN_ZX_PLANE = Object.freeze(new Plane(Vector3.UNIT_Y, 0.0));\r\n\tconstructor(normal: Vector3, distance: number) {\r\n\t\tthis.normal = Vector3.clone(normal);\r\n\r\n\t\tthis.distance = distance;\r\n\t}\r\n\tnormalize() {\r\n\t\tconst inverseNormalLength = 1.0 / this.normal.length();\r\n\t\tthis.normal = Vector3.multiplyByScalar(this.normal, inverseNormalLength, this.normal);\r\n\t\tthis.distance *= inverseNormalLength;\r\n\t\treturn this;\r\n\t}\r\n\r\n\tstatic fromPointNormal(point: Vector3, normal: Vector3, result: Plane): Plane {\r\n\t\tif (!GMath.equalsEpsilon(Vector3.magnitude(normal), 1.0, GMath.EPSILON6)) {\r\n\t\t\tthrow new Error(\"normal must be normalized.\");\r\n\t\t}\r\n\t\t// >>includeEnd('debug');\r\n\r\n\t\tconst distance = -Vector3.dot(normal, point);\r\n\r\n\t\tif (!defined(result)) {\r\n\t\t\treturn new Plane(normal, distance);\r\n\t\t}\r\n\r\n\t\tVector3.clone(normal, result.normal);\r\n\t\tresult.distance = distance;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic fromVector4(coefficients: Vector4, result: Plane): Plane {\r\n\t\tconst normal = Vector3.fromVector4(coefficients, scratchNormal);\r\n\t\tconst distance = coefficients.w;\r\n\r\n\t\t// >>includeStart('debug', pragmas.debug);\r\n\t\tif (!GMath.equalsEpsilon(Vector3.magnitude(normal), 1.0, GMath.EPSILON6)) {\r\n\t\t\tthrow new Error(\"normal must be normalized.\");\r\n\t\t}\r\n\t\t// >>includeEnd('debug');\r\n\r\n\t\tif (!defined(result)) {\r\n\t\t\treturn new Plane(normal, distance);\r\n\t\t}\r\n\t\tVector3.clone(normal, result.normal);\r\n\t\tresult.distance = distance;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic getPointDistance(plane: Plane, point: Vector3): number {\r\n\t\treturn Vector3.dot(plane.normal, point) + plane.distance;\r\n\t}\r\n\r\n\tstatic projectPointOntoPlane(plane: Plane, point: Vector3, result: Vector3): Vector3 {\r\n\t\tif (!defined(result)) {\r\n\t\t\tresult = new Vector3();\r\n\t\t}\r\n\r\n\t\t// projectedPoint = point - (normal.point + scale) * normal\r\n\t\tconst pointDistance = Plane.getPointDistance(plane, point);\r\n\t\tconst scaledNormal = Vector3.multiplyByScalar(plane.normal, pointDistance, scratchCartesian);\r\n\r\n\t\treturn Vector3.subtract(point, scaledNormal, result);\r\n\t}\r\n\r\n\tstatic transform(plane: Plane, transform: Matrix4, result: Plane): Plane {\r\n\t\tconst normal = plane.normal;\r\n\t\tconst distance = plane.distance;\r\n\t\tconst inverseTranspose = Matrix4.inverseTranspose(transform, scratchInverseTranspose);\r\n\t\tlet planeAsCartesian4 = Vector4.fromElements(normal.x, normal.y, normal.z, distance, scratchPlaneCartesian4);\r\n\t\tplaneAsCartesian4 = Matrix4.multiplyByVector(inverseTranspose, planeAsCartesian4, planeAsCartesian4);\r\n\r\n\t\t// Convert the transformed plane to Hessian Normal Form\r\n\t\tconst transformedNormal = Vector3.fromVector4(planeAsCartesian4, scratchTransformNormal);\r\n\r\n\t\tplaneAsCartesian4 = Vector4.divideByScalar(\r\n\t\t\tplaneAsCartesian4,\r\n\t\t\tVector3.magnitude(transformedNormal),\r\n\t\t\tplaneAsCartesian4\r\n\t\t);\r\n\r\n\t\treturn Plane.fromVector4(planeAsCartesian4, result);\r\n\t}\r\n\r\n\tstatic clone(plane: Plane, result: Plane): Plane {\r\n\t\tif (!defined(result)) {\r\n\t\t\treturn new Plane(plane.normal, plane.distance);\r\n\t\t}\r\n\r\n\t\tVector3.clone(plane.normal, result.normal);\r\n\t\tresult.distance = plane.distance;\r\n\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic equals(left: Plane, right: Plane): boolean {\r\n\t\treturn left.distance === right.distance && Vector3.equals(left.normal, right.normal);\r\n\t}\r\n}\r\nconst scratchNormal = new Vector3();\r\nconst scratchCartesian = new Vector3();\r\nconst scratchInverseTranspose = new Matrix4();\r\nconst scratchPlaneCartesian4 = new Vector4();\r\nconst scratchTransformNormal = new Vector3();\r\n\r\nexport default Plane;\r\n","import Vector3 from \"../math/Vector3\";\r\nimport Vector4 from \"../math/Vector4\";\r\nimport defaultValue from \"../utils/defaultValue\";\r\nimport defined from \"../utils/defined\";\r\nimport { Intersect } from \"./WebGPUConstant\";\r\nimport Plane from \"../math/Plane\";\r\n\r\n/**\r\n * The culling volume defined by planes.\r\n *\r\n * @alias CullingVolume\r\n * @constructor\r\n *\r\n * @param {Vector4[]} [planes] An array of clipping planes.\r\n */\r\nclass CullingVolume {\r\n\tplanes: Plane[];\r\n\r\n\tpublic static MASK_OUTSIDE = 0xffffffff;\r\n\r\n\tpublic static MASK_INSIDE = 0x00000000;\r\n\r\n\tpublic static MASK_INDETERMINATE = 0x7fffffff;\r\n\r\n\tconstructor(planes?: Plane[]) {\r\n\t\tthis.planes = defaultValue(planes, [\r\n\t\t\tnew Plane(Vector3.UNIT_Z, 0.0),\r\n\t\t\tnew Plane(Vector3.UNIT_Z, 0.0),\r\n\t\t\tnew Plane(Vector3.UNIT_Z, 0.0),\r\n\t\t\tnew Plane(Vector3.UNIT_Z, 0.0),\r\n\t\t\tnew Plane(Vector3.UNIT_Z, 0.0),\r\n\t\t\tnew Plane(Vector3.UNIT_Z, 0.0)\r\n\t\t]);\r\n\t}\r\n\t/**\r\n\t * Constructs a culling volume from a bounding sphere. Creates six planes that create a box containing the sphere.\r\n\t * The planes are aligned to the x, y, and z axes in world coordinates.\r\n\t *\r\n\t * @param {BoundingSphere} boundingSphere The bounding sphere used to create the culling volume.\r\n\t * @param {CullingVolume} [result] The object onto which to store the result.\r\n\t * @returns {CullingVolume} The culling volume created from the bounding sphere.\r\n\t */\r\n\tstatic fromBoundingSphere(boundingSphere, result) {\r\n\t\tif (!defined(boundingSphere)) {\r\n\t\t\tthrow new Error(\"boundingSphere is required.\");\r\n\t\t}\r\n\t\tif (!defined(result)) {\r\n\t\t\tresult = new CullingVolume();\r\n\t\t}\r\n\r\n\t\tconst length = faces.length;\r\n\t\tconst planes = result.planes;\r\n\t\tplanes.length = 2 * length;\r\n\r\n\t\tconst center = boundingSphere.center;\r\n\t\tconst radius = boundingSphere.radius;\r\n\r\n\t\tlet planeIndex = 0;\r\n\r\n\t\tfor (let i = 0; i < length; ++i) {\r\n\t\t\tconst faceNormal = faces[i];\r\n\r\n\t\t\tlet plane0 = planes[planeIndex];\r\n\t\t\tlet plane1 = planes[planeIndex + 1];\r\n\r\n\t\t\tif (!defined(plane0)) {\r\n\t\t\t\tplane0 = planes[planeIndex] = new Vector4();\r\n\t\t\t}\r\n\t\t\tif (!defined(plane1)) {\r\n\t\t\t\tplane1 = planes[planeIndex + 1] = new Vector4();\r\n\t\t\t}\r\n\r\n\t\t\tVector3.multiplyByScalar(faceNormal, -radius, scratchPlaneCenter);\r\n\t\t\tVector3.add(center, scratchPlaneCenter, scratchPlaneCenter);\r\n\r\n\t\t\tplane0.x = faceNormal.x;\r\n\t\t\tplane0.y = faceNormal.y;\r\n\t\t\tplane0.z = faceNormal.z;\r\n\t\t\tplane0.w = -Vector3.dot(faceNormal, scratchPlaneCenter);\r\n\r\n\t\t\tVector3.multiplyByScalar(faceNormal, radius, scratchPlaneCenter);\r\n\t\t\tVector3.add(center, scratchPlaneCenter, scratchPlaneCenter);\r\n\r\n\t\t\tplane1.x = -faceNormal.x;\r\n\t\t\tplane1.y = -faceNormal.y;\r\n\t\t\tplane1.z = -faceNormal.z;\r\n\t\t\tplane1.w = -Vector3.dot(Vector3.negate(faceNormal, scratchPlaneNormal), scratchPlaneCenter);\r\n\r\n\t\t\tplaneIndex += 2;\r\n\t\t}\r\n\r\n\t\treturn result;\r\n\t}\r\n\t/**\r\n\t * Determines whether a bounding volume intersects the culling volume.\r\n\t *\r\n\t * @param {Object} boundingVolume The bounding volume whose intersection with the culling volume is to be tested.\r\n\t * @returns {Intersect}  Intersect.OUTSIDE, Intersect.INTERSECTING, or Intersect.INSIDE.\r\n\t */\r\n\tcomputeVisibility(boundingVolume) {\r\n\t\tif (!defined(boundingVolume)) {\r\n\t\t\tthrow new Error(\"boundingVolume is required.\");\r\n\t\t}\r\n\t\tconst planes = this.planes;\r\n\t\tlet intersecting = false;\r\n\t\tfor (let k = 0, len = planes.length; k < len; ++k) {\r\n\t\t\tconst result = boundingVolume.intersectPlane(planes[k]);\r\n\t\t\tif (result === Intersect.OUTSIDE) {\r\n\t\t\t\treturn Intersect.OUTSIDE;\r\n\t\t\t} else if (result === Intersect.INTERSECTING) {\r\n\t\t\t\tintersecting = true;\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\treturn intersecting ? Intersect.INTERSECTING : Intersect.INSIDE;\r\n\t}\r\n}\r\n\r\nconst faces = [new Vector3(), new Vector3(), new Vector3()];\r\nVector3.clone(Vector3.UNIT_X, faces[0]);\r\nVector3.clone(Vector3.UNIT_Y, faces[1]);\r\nVector3.clone(Vector3.UNIT_Z, faces[2]);\r\n\r\nconst scratchPlaneCenter = new Vector3();\r\nconst scratchPlaneNormal = new Vector3();\r\nconst scratchPlanes = new Vector4();\r\nconst scratchPlane = new Plane(new Vector3(1.0, 0.0, 0.0), 0.0);\r\n\r\nexport default CullingVolume;\r\n","import CullingVolume from \"../core/CullingVolume\";\r\nimport RenderObject from \"../core/RenderObject\";\r\nimport { RenderObjectType } from \"../core/WebGPUTypes\";\r\nimport Matrix4 from \"../math/Matrix4\";\r\nimport Plane from \"../math/Plane\";\r\nimport Vector3 from \"../math/Vector3\";\r\nimport ShaderData from \"../render/ShaderData\";\r\nimport UniformBuffer from \"../render/UniformBuffer\";\r\nimport { UniformEnum } from \"../render/Uniforms\";\r\n\r\nexport default class Camera extends RenderObject {\r\n\tprivate _viewMatrix: Matrix4;\r\n\tprotected _projectionMatrix: Matrix4;\r\n\tprivate _vpMatrix: Matrix4;\r\n\tcullingVolume: CullingVolume;\r\n\tprojectMatrixDirty: boolean;\r\n\tshaderData: ShaderData;\r\n\tnear: number;\r\n\tfar: number;\r\n\tconstructor() {\r\n\t\tsuper();\r\n\t\tthis._viewMatrix = undefined;\r\n\t\tthis.type = RenderObjectType.Camera;\r\n\t\tthis.cullingVolume = new CullingVolume();\r\n\t\tthis._viewMatrix = new Matrix4();\r\n\t\tthis._vpMatrix = new Matrix4();\r\n\t\tthis.projectMatrixDirty = true;\r\n\t\tthis.createShaderData();\r\n\t}\r\n\tget viewMatrix() {\r\n\t\tthis.updateMatrix();\r\n\t\tMatrix4.inverse(this.modelMatrix, this._viewMatrix);\r\n\t\treturn this._viewMatrix;\r\n\t}\r\n\tget projectionMatrix() {\r\n\t\tthis.updateProjectionMatrix();\r\n\t\treturn this._projectionMatrix;\r\n\t}\r\n\r\n\tget vpMatrix() {\r\n\t\tMatrix4.multiply(this.projectionMatrix, this.viewMatrix, this._vpMatrix);\r\n\t\treturn this._vpMatrix;\r\n\t}\r\n\r\n\tget inverseViewMatrix() {\r\n\t\tthis.updateMatrix();\r\n\t\treturn this.modelMatrix;\r\n\t}\r\n\tpublic updateProjectionMatrix() {}\r\n\t/**\r\n\t * get a culling volume for this frustum.\r\n\t */\r\n\tgetCullingVolume() {\r\n\t\tconst cloneViewMatrix = this.viewMatrix.clone(new Matrix4());\r\n\t\tconst vpMatrix = Matrix4.multiply(this.projectionMatrix, cloneViewMatrix, new Matrix4());\r\n\t\tconst planes = this.cullingVolume.planes;\r\n\t\tconst me = vpMatrix;\r\n\t\tconst me0 = me[0],\r\n\t\t\tme1 = me[1],\r\n\t\t\tme2 = me[2],\r\n\t\t\tme3 = me[3];\r\n\t\tconst me4 = me[4],\r\n\t\t\tme5 = me[5],\r\n\t\t\tme6 = me[6],\r\n\t\t\tme7 = me[7];\r\n\t\tconst me8 = me[8],\r\n\t\t\tme9 = me[9],\r\n\t\t\tme10 = me[10],\r\n\t\t\tme11 = me[11];\r\n\t\tconst me12 = me[12],\r\n\t\t\tme13 = me[13],\r\n\t\t\tme14 = me[14],\r\n\t\t\tme15 = me[15];\r\n\t\tplanes[0] = new Plane(new Vector3(me3 - me0, me7 - me4, me11 - me8), me15 - me12);\r\n\t\tplanes[0].normalize();\r\n\t\tplanes[1] = new Plane(new Vector3(me3 + me0, me7 + me4, me11 + me8), me15 + me12);\r\n\t\tplanes[1].normalize();\r\n\r\n\t\tplanes[2] = new Plane(new Vector3(me3 + me1, me7 + me5, me11 + me9), me15 + me13);\r\n\t\tplanes[2].normalize();\r\n\r\n\t\tplanes[3] = new Plane(new Vector3(me3 - me1, me7 - me5, me11 - me9), me15 - me13);\r\n\t\tplanes[3].normalize();\r\n\r\n\t\tplanes[4] = new Plane(new Vector3(me3 - me2, me7 - me6, me11 - me10), me15 - me14);\r\n\t\tplanes[4].normalize();\r\n\r\n\t\tplanes[5] = new Plane(new Vector3(me3 + me2, me7 + me6, me11 + me10), me15 + me14);\r\n\t\tplanes[5].normalize();\r\n\r\n\t\treturn this.cullingVolume;\r\n\t}\r\n\r\n\tcreateShaderData() {\r\n\t\tthis.shaderData = new ShaderData(\"camera\", 0, 1, 1);\r\n\t\tconst uniformBuffer = new UniformBuffer({ label: \"camera\" });\r\n\t\tuniformBuffer.setUniform(\r\n\t\t\t\"projectionMatrix\",\r\n\t\t\t() => {\r\n\t\t\t\treturn this.projectionMatrix;\r\n\t\t\t},\r\n\t\t\tUniformEnum.Mat4\r\n\t\t);\r\n\t\tuniformBuffer.setUniform(\r\n\t\t\t\"viewMatrix\",\r\n\t\t\t() => {\r\n\t\t\t\treturn this.viewMatrix;\r\n\t\t\t},\r\n\t\t\tUniformEnum.Mat4\r\n\t\t);\r\n\t\tuniformBuffer.setUniform(\r\n\t\t\t\"inverseViewMatrix\",\r\n\t\t\t() => {\r\n\t\t\t\treturn this.inverseViewMatrix;\r\n\t\t\t},\r\n\t\t\tUniformEnum.Mat4\r\n\t\t);\r\n\t\tuniformBuffer.setUniform(\r\n\t\t\t\"position\",\r\n\t\t\t() => {\r\n\t\t\t\treturn this.position;\r\n\t\t\t},\r\n\t\t\tUniformEnum.FloatVec3\r\n\t\t);\r\n\t\tthis.shaderData.setUniformBuffer(\"camera\", uniformBuffer);\r\n\t}\r\n}\r\n","import CullingVolume from \"../core/CullingVolume\";\r\nimport GMath from \"../math/Math\";\r\nimport Matrix4 from \"../math/Matrix4\";\r\nimport Camera from \"./Camera\";\r\nexport default class PerspectiveCamera extends Camera {\r\n\txOffset: number;\r\n\tyOffset: number;\r\n\tcullingVolume: CullingVolume;\r\n\tprivate _aspect: number;\r\n\tprivate _fov: number;\r\n\theight: number;\r\n\twidth: number;\r\n\tisPerspectiveCamera: boolean;\r\n\tnear: number;\r\n\tfar: number;\r\n\ttop: number;\r\n\tleft: number;\r\n\tconstructor(fov = 50, aspect = 1, near = 0.1, far = 2000) {\r\n\t\tsuper();\r\n\t\tthis._aspect = aspect;\r\n\t\tthis.fov = fov;\r\n\t\tthis.near = near;\r\n\t\tthis.far = far;\r\n\t\tthis.xOffset = 0;\r\n\t\tthis.yOffset = 0;\r\n\t\tthis.projectMatrixDirty = true;\r\n\t\tthis.updateCameraParms();\r\n\t\tthis.cullingVolume = new CullingVolume();\r\n\t\tthis.isPerspectiveCamera = true;\r\n\t}\r\n\tget aspect(): number {\r\n\t\treturn this._aspect;\r\n\t}\r\n\r\n\tset aspect(v: number) {\r\n\t\tthis.projectMatrixDirty = true;\r\n\t\tthis._aspect = v;\r\n\t}\r\n\tget fov(): number {\r\n\t\treturn this._fov;\r\n\t}\r\n\r\n\tset fov(v: number) {\r\n\t\tthis.projectMatrixDirty = true;\r\n\t\tthis._fov = v;\r\n\t}\r\n\tprivate updateCameraParms() {\r\n\t\tthis.top = this.near * Math.tan(0.5 * GMath.RADIANS_PER_DEGREE * this.fov);\r\n\t\tthis.height = 2 * this.top;\r\n\t\tthis.width = this.aspect * this.height;\r\n\t\tthis.left = -0.5 * this.width;\r\n\t}\r\n\tpublic updateProjectionMatrix() {\r\n\t\tif (this.projectMatrixDirty) {\r\n\t\t\tthis.updateCameraParms();\r\n\t\t\tthis._projectionMatrix = Matrix4.makePerspective(\r\n\t\t\t\tthis.left,\r\n\t\t\t\tthis.left + this.width,\r\n\t\t\t\tthis.top,\r\n\t\t\t\tthis.top - this.height,\r\n\t\t\t\tthis.near,\r\n\t\t\t\tthis.far\r\n\t\t\t);\r\n\t\t\tthis.projectMatrixDirty = false;\r\n\t\t}\r\n\t}\r\n}\r\n","import { BufferUsage } from \"../core/WebGPUConstant\";\r\nimport Matrix4 from \"../math/Matrix4\";\r\nimport ShaderData from \"../render/ShaderData\";\r\nimport UniformBuffer from \"../render/UniformBuffer\";\r\nimport { UniformEnum } from \"../render/Uniforms\";\r\nimport PerspectiveCamera from \"./PerspectiveCamera\";\r\n\r\nexport default class PointLightShadowCamera extends PerspectiveCamera {\r\n\tpublic vpMatrixArray: Array<Matrix4>;\r\n\tpublic vpMatrixIndexArray: Array<number>;\r\n\r\n\tconstructor(fov = 50, aspect = 1, near = 0.1, far = 2000) {\r\n\t\tsuper(fov, aspect, near, far);\r\n\t\tthis.vpMatrixArray = [new Matrix4(), new Matrix4(), new Matrix4(), new Matrix4(), new Matrix4(), new Matrix4()];\r\n\t}\r\n\r\n\t// createShaderData() {\r\n\t// \tthis.shaderData = new ShaderData(\"camera\", 0, 1, 1);\r\n\r\n\t// \tconst uniformBuffer = new UniformBuffer({\r\n\t// \t\tlabel: \"pointLightShadowCamera\",\r\n\t// \t\ttype: \"read-only-storage\",\r\n\t// \t\tusage: BufferUsage.Storage | BufferUsage.CopyDst,\r\n\t// \t\thasDynamicOffset: true,\r\n\t// \t\tminBindingSize: 64,\r\n\t// \t\tmaxOffset: 6,\r\n\t// \t\tsize: 256 * 6\r\n\t// \t});\r\n\t// \tuniformBuffer.setMatrix4Array(\r\n\t// \t\t\"vpMatrixArray\",\r\n\t// \t\t() => {\r\n\t// \t\t\tif (this.vpMatrixArray.length != 6) throw new Error(\"pointLightShadowCamera uniformBuffer has Error\");\r\n\r\n\t// \t\t\treturn this.vpMatrixArray;\r\n\t// \t\t},\r\n\t// \t\t6,\r\n\t// \t\t256\r\n\t// \t);\r\n\r\n\t// \tthis.shaderData.setUniformBuffer(\"pointLightShadowCamera\", uniformBuffer);\r\n\t// \tthis.shaderData.setDefine(\"isPointLightShadowMap\", true);\r\n\t// }\r\n\r\n\tcreateShaderData() {\r\n\t\tthis.shaderData = new ShaderData(\"camera\", 0, 1, 1);\r\n\r\n\t\tconst uniformBuffer = new UniformBuffer({\r\n\t\t\tlabel: \"pointLightShadowCamera\",\r\n\t\t\ttype: \"read-only-storage\",\r\n\t\t\tusage: BufferUsage.Storage | BufferUsage.CopyDst\r\n\t\t});\r\n\t\tuniformBuffer.setUniform(\r\n\t\t\t\"vpMatrix\",\r\n\t\t\t() => {\r\n\t\t\t\treturn this.vpMatrix;\r\n\t\t\t},\r\n\t\t\tUniformEnum.Mat4\r\n\t\t);\r\n\r\n\t\tthis.shaderData.setUniformBuffer(\"pointLightShadowCamera\", uniformBuffer);\r\n\t\tthis.shaderData.setDefine(\"isPointLightShadowMap\", true);\r\n\t}\r\n\r\n\tupdateVpMatrixArrayAndIndex(index: number) {\r\n\t\tMatrix4.clone(this.vpMatrix, this.vpMatrixArray[index]);\r\n\t}\r\n}\r\n","import Camera from \"../../camera/Camera\";\r\nimport { TextureFormat, TextureSampleType, TextureUsage } from \"../../core/WebGPUConstant\";\r\nimport Vector2 from \"../../math/Vector2\";\r\nimport Vector4 from \"../../math/Vector4\";\r\nimport Texture from \"../../render/Texture\";\r\nimport { Light } from \"../Light\";\r\nexport class BaseShadow {\r\n\tprotected _shadowMapSize: Vector2;\r\n\tprotected _camera: Camera;\r\n\tprotected _shadowMap: Texture;\r\n\tpublic type: string;\r\n\tpublic _viewports: Array<Vector4>;\r\n\tpublic viewportSize: Vector2;\r\n\tpublic currentViewportIndex: number;\r\n\tpublic viewPortDirty: boolean;\r\n\tpublic vpMatrixDirty: boolean;\r\n\r\n\tconstructor(shadowMapSize: Vector2, camera: Camera) {\r\n\t\tthis._shadowMapSize = shadowMapSize;\r\n\t\tthis._camera = camera;\r\n\t\tthis.viewPortDirty = true;\r\n\t\tthis.vpMatrixDirty = true;\r\n\r\n\t\tthis._init();\r\n\t}\r\n\r\n\tget camera() {\r\n\t\treturn this._camera;\r\n\t}\r\n\r\n\tget shadowMapSize() {\r\n\t\treturn this._shadowMapSize;\r\n\t}\r\n\r\n\tget viewports() {\r\n\t\treturn this._viewports;\r\n\t}\r\n\r\n\tpublic getShadowMapTexture() {\r\n\t\treturn this._shadowMap;\r\n\t}\r\n\r\n\tprotected _init() {\r\n\t\tthis._initShadowMapTexture();\r\n\t}\r\n\r\n\tprotected _initShadowMapTexture() {\r\n\t\tthis._createShadowMapTexture();\r\n\t}\r\n\r\n\tprotected _createShadowMapTexture() {\r\n\t\tthis._shadowMap = new Texture({\r\n\t\t\tsize: {\r\n\t\t\t\twidth: this._shadowMapSize.x,\r\n\t\t\t\theight: this._shadowMapSize.y,\r\n\t\t\t\tdepth: 1\r\n\t\t\t},\r\n\t\t\tfixedSize: true,\r\n\t\t\tsampleType: TextureSampleType.Depth,\r\n\t\t\tformat: TextureFormat.Depth24Plus,\r\n\t\t\tusage: TextureUsage.RenderAttachment | TextureUsage.TextureBinding | TextureUsage.CopySrc\r\n\t\t});\r\n\t}\r\n\r\n\tpublic update(light: Light) {}\r\n}\r\n","import PointLightShadowCamera from \"../../camera/PointLightShadowCamera\";\r\nimport Vector2 from \"../../math/Vector2\";\r\nimport Vector3 from \"../../math/Vector3\";\r\nimport Vector4 from \"../../math/Vector4\";\r\nimport { PointLight } from \"../PointLight\";\r\nimport { BaseShadow } from \"./BaseShadow\";\r\n\r\nexport class PointLightShadow extends BaseShadow {\r\n\tpublic type: string;\r\n\tprivate _pointLightShadowLookDirections: Array<Vector3>;\r\n\tprivate _pointLightShadowUps: Array<Vector3>;\r\n\tvpMatrixArrayDirty: boolean;\r\n\r\n\tget camera(): PointLightShadowCamera {\r\n\t\treturn this._camera as PointLightShadowCamera;\r\n\t}\r\n\r\n\tconstructor() {\r\n\t\tconst camera = new PointLightShadowCamera(90, 1, 0.1, 500);\r\n\t\tsuper(new Vector2(1536, 1024), camera);\r\n\t\tthis.viewportSize = new Vector2(512, 512);\r\n\t\tthis.currentViewportIndex = 0;\r\n\t\tthis.type = \"pointLightShadow\";\r\n\t\tthis.vpMatrixArrayDirty = true;\r\n\r\n\t\tthis._viewports = [\r\n\t\t\t// positive X 0\r\n\t\t\tnew Vector4(0, 0, 1 / 3, 1 / 2),\r\n\t\t\t// negative X 1\r\n\t\t\tnew Vector4(1, 0, 1 / 3, 1 / 2),\r\n\t\t\t// positive Z 2\r\n\t\t\tnew Vector4(2, 0, 1 / 3, 1 / 2),\r\n\t\t\t// negative Z 3\r\n\t\t\tnew Vector4(0, 1, 1 / 3, 1 / 2),\r\n\t\t\t// positive Y 4\r\n\t\t\tnew Vector4(1, 1, 1 / 3, 1 / 2),\r\n\t\t\t// negative Y 5\r\n\t\t\tnew Vector4(2, 1, 1 / 3, 1 / 2)\r\n\t\t];\r\n\r\n\t\tthis._pointLightShadowLookDirections = [\r\n\t\t\tnew Vector3(1, 0, 0),\r\n\t\t\tnew Vector3(-1, 0, 0),\r\n\t\t\tnew Vector3(0, 0, 1),\r\n\t\t\tnew Vector3(0, 0, -1),\r\n\t\t\tnew Vector3(0, 1, 0),\r\n\t\t\tnew Vector3(0, -1, 0)\r\n\t\t];\r\n\r\n\t\tthis._pointLightShadowUps = [\r\n\t\t\tnew Vector3(0, 1, 0),\r\n\t\t\tnew Vector3(0, 1, 0),\r\n\t\t\tnew Vector3(0, 1, 0),\r\n\t\t\tnew Vector3(0, 1, 0),\r\n\t\t\tnew Vector3(0, 0, 1),\r\n\t\t\tnew Vector3(0, 0, -1)\r\n\t\t];\r\n\t}\r\n\r\n\tpublic update(light: PointLight) {\r\n\t\tthis.updateMatrices(light);\r\n\t}\r\n\r\n\tupdateMatrices(light: PointLight) {\r\n\t\tif (this.camera instanceof PointLightShadowCamera) {\r\n\t\t\tthis.camera.position.copy(light.position);\r\n\t\t\tconst target = Vector3.clone(light.position);\r\n\t\t\ttarget.add(this._pointLightShadowLookDirections[this.currentViewportIndex]);\r\n\t\t\tthis.camera.up.copy(this._pointLightShadowUps[this.currentViewportIndex]);\r\n\t\t\tconst { x, y, z } = target;\r\n\t\t\tthis.camera.lookAt(x, y, z);\r\n\t\t\tthis.camera.updateMatrix();\r\n\t\t\tthis.camera.updateVpMatrixArrayAndIndex(this.currentViewportIndex);\r\n\t\t\tif (this.currentViewportIndex == 5) this.vpMatrixArrayDirty = true;\r\n\t\t}\r\n\t}\r\n}\r\n","import { LightType } from \"../core/WebGPUTypes\";\r\nimport Vector3 from \"../math/Vector3\";\r\nimport { Light } from \"./Light\";\r\nimport { PointLightShadow } from \"./shadows/PointLightShadow\";\r\n\r\nexport class PointLight extends Light {\r\n\tprivate _distance: number;\r\n\tprivate _decay: number;\r\n\tdistanceDirty: boolean;\r\n\tdecayDirty: boolean;\r\n\r\n\tget shadow(): PointLightShadow {\r\n\t\treturn this._shadow as PointLightShadow;\r\n\t}\r\n\r\n\tset shadow(value: PointLightShadow) {\r\n\t\tthis.shadowDirty = true;\r\n\t\tthis._shadow = value;\r\n\t}\r\n\r\n\tconstructor(color: Vector3, intensity: number, distance = 0, decay = 4, openShadow = true) {\r\n\t\tsuper(color, intensity);\r\n\t\tthis._distance = distance;\r\n\t\tthis._decay = decay;\r\n\t\tthis.distanceDirty = true;\r\n\t\tthis.decayDirty = true;\r\n\t\tthis.lightType = LightType.PointLight;\r\n\t\tif (openShadow) this.shadow = new PointLightShadow();\r\n\t}\r\n\tset distance(value) {\r\n\t\tthis.distanceDirty = true;\r\n\t\tthis._distance = value;\r\n\t}\r\n\tget distance() {\r\n\t\treturn this._distance;\r\n\t}\r\n\tset decay(value) {\r\n\t\tthis.decayDirty = true;\r\n\t\tthis._decay = value;\r\n\t}\r\n\tget decay() {\r\n\t\treturn this._decay;\r\n\t}\r\n}\r\n// uniform\r\n// color: {},\r\n// position: {},\r\n// decay: {},\r\n// distance: {}\r\n","import Camera from \"../camera/Camera\";\r\nimport { FrameState } from \"../core/FrameState\";\r\nimport LightManger from \"../core/LightManger\";\r\nimport RenderQueue from \"../core/RenderQueue\";\r\nimport { CommandSubType } from \"../core/WebGPUConstant\";\r\nimport { Light } from \"../light/Light\";\r\nimport { PointLight } from \"../light/PointLight\";\r\nimport { BaseShadow } from \"../light/shadows/BaseShadow\";\r\nimport { PointLightShadow } from \"../light/shadows/PointLightShadow\";\r\nimport ShaderMaterial from \"../material/ShaderMaterial\";\r\nimport Attachment from \"../render/Attachment\";\r\nimport Context from \"../render/Context\";\r\nimport RenderTarget from \"../render/RenderTarget\";\r\nimport Texture from \"../render/Texture\";\r\nimport getVertFrag from \"../shader/Shaders\";\r\nimport Pass from \"./Pass\";\r\nexport class ShadowPass extends Pass {\r\n\tpublic shadowMaterial: ShaderMaterial;\r\n\t_testTexture: Texture;\r\n\tconstructor(context: Context) {\r\n\t\tsuper(context);\r\n\t\tthis.init(context);\r\n\t}\r\n\trender(frameState: FrameState, camera?: Camera) {\r\n\t\tconst { renderQueue, context, lightManger } = frameState;\r\n\t\tconst lights = lightManger.getAllLights();\r\n\t\tif (lights.length === 0) return;\r\n\r\n\t\tfor (let i = 0; i < lights.length; i++) {\r\n\t\t\tconst light: PointLight | Light = lights[i];\r\n\t\t\tconst shadow = light.shadow;\r\n\t\t\tif (!shadow) continue;\r\n\t\t\t// this._testTexture = context.lightManger._testTexture\r\n\t\t\t// this.beforeRender({ shadow });\r\n\t\t\tif (shadow instanceof PointLightShadow && light instanceof PointLight) {\r\n\t\t\t\tfor (let i = 0; i < shadow.viewports.length; i++) {\r\n\t\t\t\t\t// 动态buffer暂未调通，先以此种方式解决\r\n\t\t\t\t\tswitch (i) {\r\n\t\t\t\t\t\tcase 0:\r\n\t\t\t\t\t\t\tthis.renderTarget.depthAttachment.op = \"clear\";\r\n\t\t\t\t\t\t\tbreak;\r\n\r\n\t\t\t\t\t\tdefault:\r\n\t\t\t\t\t\t\tthis.renderTarget.depthAttachment.op = \"load\";\r\n\t\t\t\t\t\t\tbreak;\r\n\t\t\t\t\t}\r\n\t\t\t\t\tthis.beforeRender({ shadow });\r\n\r\n\t\t\t\t\tconst viewport = shadow.viewports[i];\r\n\t\t\t\t\tconst viewportSize = shadow.viewportSize;\r\n\t\t\t\t\tshadow.currentViewportIndex = i;\r\n\t\t\t\t\tshadow.update(light);\r\n\t\t\t\t\t// light.forceUpdate = true;\r\n\t\t\t\t\tcontext.setViewPort(\r\n\t\t\t\t\t\tviewport.x * viewportSize.x,\r\n\t\t\t\t\t\tviewport.y * viewportSize.y,\r\n\t\t\t\t\t\tviewportSize.x,\r\n\t\t\t\t\t\tviewportSize.y\r\n\t\t\t\t\t);\r\n\t\t\t\t\tcontext.setScissorTest(\r\n\t\t\t\t\t\tviewport.x * viewportSize.x,\r\n\t\t\t\t\t\tviewport.y * viewportSize.y,\r\n\t\t\t\t\t\tviewportSize.x,\r\n\t\t\t\t\t\tviewportSize.y\r\n\t\t\t\t\t);\r\n\t\t\t\t\tthis.subRender(renderQueue, shadow, lightManger);\r\n\t\t\t\t\tsuper.afterRender();\r\n\t\t\t\t}\r\n\t\t\t} else {\r\n\t\t\t\tthis.renderTarget.depthAttachment.op = \"clear\";\r\n\t\t\t\tthis.beforeRender({ shadow });\r\n\t\t\t\tshadow.update(light);\r\n\t\t\t\tcontext.setViewPort(0, 0, shadow.shadowMapSize.x, shadow.shadowMapSize.y);\r\n\t\t\t\tcontext.setScissorTest(0, 0, shadow.shadowMapSize.x, shadow.shadowMapSize.y);\r\n\t\t\t\tthis.subRender(renderQueue, shadow, lightManger);\r\n\t\t\t\tsuper.afterRender();\r\n\t\t\t}\r\n\t\t}\r\n\t\t// super.afterRender();\r\n\t\tlightManger.updateLightShadow();\r\n\t\tcontext.resetViewPortToFullCanvas();\r\n\t}\r\n\r\n\tsubRender(renderQueue: RenderQueue, shadow: BaseShadow, lightManger: LightManger) {\r\n\t\trenderQueue.sort();\r\n\t\t// renderQueue.preRender(shadow.camera, this.context, this.passRenderEncoder);\r\n\t\trenderQueue.transparentRender(\r\n\t\t\tshadow.camera,\r\n\t\t\tthis.context,\r\n\t\t\tthis.passRenderEncoder,\r\n\t\t\tthis.shadowMaterial,\r\n\t\t\tCommandSubType.Shadow,\r\n\t\t\tlightManger\r\n\t\t);\r\n\t\trenderQueue.opaqueRender(\r\n\t\t\tshadow.camera,\r\n\t\t\tthis.context,\r\n\t\t\tthis.passRenderEncoder,\r\n\t\t\tthis.shadowMaterial,\r\n\t\t\tCommandSubType.Shadow,\r\n\t\t\tlightManger\r\n\t\t);\r\n\t}\r\n\r\n\t// getDepthTexture(): Texture {\r\n\t// \treturn this._testTexture;\r\n\t// }\r\n\tbeforeRender(options: { shadow: BaseShadow }) {\r\n\t\tconst { shadow } = options;\r\n\t\tthis.setRenderTarget(shadow);\r\n\t\tsuper.beforeRender();\r\n\t}\r\n\r\n\tprivate setRenderTarget(shadow: BaseShadow) {\r\n\t\tthis.renderTarget.depthAttachment.texture = shadow.getShadowMapTexture();\r\n\t}\r\n\r\n\tprivate init(context: Context) {\r\n\t\tthis.createRenderTarget(context);\r\n\t\tthis.createShadowMaterial();\r\n\t}\r\n\tprivate createRenderTarget(context: Context) {\r\n\t\tconst depthAttachment = new Attachment(1.0, { texture: undefined });\r\n\t\tthis.renderTarget = new RenderTarget(\"render\", [], depthAttachment);\r\n\t}\r\n\r\n\tprivate createShadowMaterial() {\r\n\t\tconst shadowMapShaderFunction = (defines = {}) => {\r\n\t\t\tconst finalDefines = Object.assign(\r\n\t\t\t\t{\r\n\t\t\t\t\tselfBinding: 0,\r\n\t\t\t\t\tcameraBinding: 0,\r\n\t\t\t\t\tpositionLocation: 0\r\n\t\t\t\t},\r\n\t\t\t\tdefines\r\n\t\t\t);\r\n\t\t\treturn getVertFrag(\"shadowMap\", finalDefines).vert;\r\n\t\t};\r\n\r\n\t\tthis.shadowMaterial = new ShaderMaterial({\r\n\t\t\ttype: \"shadowMaterial\",\r\n\t\t\tuniforms: {\r\n\t\t\t\tmodelMatrix: { type: \"mat4\", value: null }\r\n\t\t\t},\r\n\t\t\tvert: shadowMapShaderFunction,\r\n\t\t\tfrag: undefined,\r\n\t\t\tlight: false // TODO:先true，false有显示bug\r\n\t\t});\r\n\t}\r\n}\r\n","import Camera from \"../camera/Camera\";\r\nimport { FrameState } from \"../core/FrameState\";\r\nimport { BasicPass } from \"../pass/BasicPass\";\r\nimport { ShadowPass } from \"../pass/ShadowPass\";\r\nimport Context from \"../render/Context\";\r\nimport Texture from \"../render/Texture\";\r\nimport IBaseRenderLine from \"./IBaseRenderLine\";\r\n\r\nexport default class ForwardRenderLine implements IBaseRenderLine {\r\n\tprivate basicPass: BasicPass;\r\n\tprotected shadowPass: ShadowPass;\r\n\tconstructor(public context: Context) {\r\n\t\tthis.basicPass = new BasicPass(context);\r\n\t\tthis.shadowPass = new ShadowPass(context);\r\n\t\t// const bloom=new BloomPostEffect({\r\n\t\t// \twidth,\r\n\t\t// \theight,\r\n\t\t// \tstrength:0.3,\r\n\t\t// \tradius:0.3,\r\n\t\t// \tthreshold:0.5\r\n\t\t// });\r\n\t\t// this.postEffectCollection.add(bloom)\r\n\t}\r\n\tgetOutputTexture(): Texture {\r\n\t\treturn this.basicPass.getColorTexture(0);\r\n\t\t// return this.shadowPass.getDepthTexture()\r\n\t}\r\n\trender(frameState: FrameState, camera?: Camera) {\r\n\t\tthis.shadowPass.render(frameState, camera);\r\n\r\n\t\tthis.basicPass.beforeRender(frameState);\r\n\t\tthis.basicPass.render(frameState, camera);\r\n\t\tthis.basicPass.afterRender();\r\n\t}\r\n\tdestroy() {\r\n\t\tthis.basicPass = undefined;\r\n\t}\r\n}\r\n","import Camera from \"./camera/Camera\";\nimport PerspectiveCamera from \"./camera/PerspectiveCamera\";\nimport { EventDispatcher } from \"./core/EventDispatcher\";\nimport { FrameState, Background } from \"./core/FrameState\";\nimport LightManger from \"./core/LightManger\";\nimport MeshManger from \"./core/MeshManger\";\nimport textureCache from \"./core/TextureCache\";\nimport { Instance, RenderObjectType } from \"./core/WebGPUTypes\";\nimport { Light } from \"./light/Light\";\nimport { Mesh } from \"./mesh/Mesh\";\nimport Node from \"./mesh/Node\";\nimport PostEffect from \"./post-process/PostEffect\";\nimport PostEffectCollection from \"./post-process/PostEffectCollection\";\nimport Context from \"./render/Context\";\nimport { ViewPort } from \"./render/RenderState\";\nimport ForwardRenderLine from \"./renderpipeline/ForwardRenderLine\";\nimport IBaseRenderLine from \"./renderpipeline/IBaseRenderLine\";\n\nexport class Scene extends EventDispatcher {\n\tcamera: PerspectiveCamera;\n\tcontext: Context;\n\trequestAdapter: object;\n\tdeviceDescriptor: object;\n\tpresentationContextDescriptor: object;\n\tcontainer: HTMLDivElement;\n\tframeState: FrameState;\n\tcurrentRenderPipeline: IBaseRenderLine;\n\tviewport: ViewPort;\n\tbackground: Background;\n\tprivate ready: boolean;\n\tprivate inited: boolean;\n\tprivate meshManger: MeshManger;\n\tprivate postEffectCollection: PostEffectCollection;\n\tprivate lightManger: LightManger;\n\tconstructor(options) {\n\t\tsuper();\n\t\tthis.container =\n\t\t\toptions.container instanceof HTMLDivElement\n\t\t\t\t? options.container\n\t\t\t\t: document.getElementById(options.container);\n\t\tthis.meshManger = new MeshManger();\n\t\tthis.postEffectCollection = new PostEffectCollection();\n\t\tthis.context = new Context({\n\t\t\tcanvas: null,\n\t\t\tcontainer: this.container,\n\t\t\tpixelRatio: 1\n\t\t});\n\t\tthis.requestAdapter = options.requestAdapter || {};\n\t\tthis.deviceDescriptor = options.deviceDescriptor || {};\n\t\tthis.presentationContextDescriptor = options.presentationContextDescriptor;\n\t\tthis.ready = false;\n\t\tthis.inited = false;\n\t\tthis.lightManger = new LightManger({ openShadow: true });\n\t\tthis.background = options.background;\n\t}\n\tprivate async init() {\n\t\tawait this.context.init(this.requestAdapter, this.deviceDescriptor, this.presentationContextDescriptor);\n\t\tthis.currentRenderPipeline = new ForwardRenderLine(this.context);\n\t\tthis.frameState = new FrameState(this.context, this.lightManger, FrameState.getFrameStateOptionsByScene(this));\n\t\tthis.viewport = new ViewPort(0, 0, this.context.presentationSize.width, this.context.presentationSize.height);\n\t\tthis.ready = true;\n\t}\n\tadd(instance: Instance) {\n\t\tif (\n\t\t\t[RenderObjectType.Node, RenderObjectType.Skybox, RenderObjectType.Mesh, RenderObjectType.Debug].includes(\n\t\t\t\tinstance.type\n\t\t\t)\n\t\t) {\n\t\t\tthis.meshManger.add(<Mesh>instance);\n\t\t} else if (instance.type == RenderObjectType.Light) {\n\t\t\tthis.lightManger.add(<Light>instance);\n\t\t} else if (instance.type == RenderObjectType.PostEffect) {\n\t\t\tthis.postEffectCollection.add(<PostEffect>instance);\n\t\t}\n\t}\n\tremove(instance: Instance) {\n\t\tif ([RenderObjectType.Node, RenderObjectType.Skybox, RenderObjectType.Mesh].includes(instance.type)) {\n\t\t\tthis.meshManger.remove(<Mesh>instance);\n\t\t} else if (instance.type == RenderObjectType.Light) {\n\t\t\tthis.lightManger.remove(<Light>instance);\n\t\t} else if (instance.type == RenderObjectType.PostEffect) {\n\t\t\tthis.postEffectCollection.remove(<PostEffect>instance);\n\t\t}\n\t}\n\tsetCamera(camera) {\n\t\tthis.camera = camera;\n\t}\n\tresize(width: number, height: number) {\n\t\tthis.context.resize(width, height);\n\t\tthis.postEffectCollection.setResolveFrameDirty(true);\n\t}\n\tasync render(node?: Node, camera?: Camera) {\n\t\tif (!this.inited) {\n\t\t\tthis.inited = true;\n\t\t\tawait this.init();\n\t\t\tthis.update(node, camera);\n\t\t\tthis.afterRender();\n\t\t} else {\n\t\t\tthis.update(node, camera);\n\t\t\tthis.afterRender();\n\t\t}\n\t}\n\n\tafterRender() {}\n\n\tpublic setViewPort(x: number, y: number, width: number, height: number): boolean {\n\t\tif (!this.ready) return false;\n\t\tthis.context.setViewPort(x, y, width, height);\n\t\treturn true;\n\t}\n\tpublic setScissorTest(x: number, y: number, width: number, height: number): boolean {\n\t\tif (!this.ready) return false;\n\t\tthis.context.setScissorTest(x, y, width, height);\n\t\treturn true;\n\t}\n\tprivate update(node?: Node, camera?: Camera) {\n\t\tif (!this.ready) return;\n\t\t// 释放纹理\n\t\ttextureCache.releasedTextures();\n\t\t// 更新FrameState\n\t\tthis.frameState.update(camera ?? this.camera, FrameState.getFrameStateOptionsByScene(this));\n\t\t// update primitive and select\n\t\t(node ?? this.meshManger).update(this.frameState, camera ?? this.camera);\n\t\t// selct renderPipeline\n\t\tthis.currentRenderPipeline.render(this.frameState, camera ?? this.camera);\n\t\t// 后处理\n\t\tthis.postEffectCollection.render(this.context, this.currentRenderPipeline.getOutputTexture());\n\t}\n}\n","import IClone from \"../core/IClone\";\r\nimport { RenderObjectType } from \"../core/WebGPUTypes\";\r\nimport Geometry from \"../geometry/Geometry\";\r\nimport { Mesh } from \"../mesh/Mesh\";\r\nimport { Float32Attribute } from \"../render/Attribute\";\r\nimport Context from \"../render/Context\";\r\nimport { Primitive, RenderState, Target } from \"../render/RenderState\";\r\nimport RenderTarget from \"../render/RenderTarget\";\r\nimport Sampler from \"../render/Sampler\";\r\nimport Texture from \"../render/Texture\";\r\n\r\nexport default class PostEffect implements IClone {\r\n\twidth: number;\r\n\r\n\theight: number;\r\n\r\n\tdefaultSampler: Sampler;\r\n\r\n\tresolveToCanvas: boolean;\r\n\r\n\tcurrentRenderTarget: RenderTarget;\r\n\r\n\tfullScreenQuad: Mesh;\r\n\r\n\trenderState: RenderState;\r\n\r\n\tid: string;\r\n\r\n\tpriority: number;\r\n\r\n\tisPostEffect: boolean;\r\n\r\n\ttype: RenderObjectType;\r\n\r\n\tconstructor(width: number, height: number, id: string) {\r\n\t\tthis.width = width;\r\n\t\tthis.height = height;\r\n\t\tthis.initDefaultParms();\r\n\t\tthis.id = id;\r\n\t\tthis.priority = 0;\r\n\t\tthis.isPostEffect = true;\r\n\t\tthis.type = RenderObjectType.PostEffect;\r\n\t}\r\n\trender(context: Context, colorTexture: Texture): Texture {\r\n\t\treturn null;\r\n\t}\r\n\tdestroy() {\r\n\t\tthis?.currentRenderTarget?.destroy();\r\n\t}\r\n\tprotected renderMesh(context: Context) {\r\n\t\tthis.fullScreenQuad.material.dirty = true;\r\n\t\tthis.fullScreenQuad.material.update();\r\n\t\tconst drawComand = this.fullScreenQuad.getDrawCommand();\r\n\t\tconst currentRenderPassEncoder = this.currentRenderTarget.beginRenderPassEncoder(context);\r\n\t\tdrawComand.render(context, currentRenderPassEncoder);\r\n\t\tthis.currentRenderTarget.endRenderPassEncoder();\r\n\t}\r\n\tprivate initDefaultParms() {\r\n\t\tconst geometry = new Geometry({});\r\n\t\tgeometry.setAttribute(\r\n\t\t\tnew Float32Attribute(\"position\", [-1.0, 1.0, -1.0, -1.0, 1.0, -1.0, 1.0, -1.0, 1.0, 1.0, -1.0, 1.0], 2)\r\n\t\t);\r\n\t\tgeometry.count = 6;\r\n\t\t// rs\r\n\t\tconst primitive = new Primitive();\r\n\t\tconst target = new Target();\r\n\t\t// target.format=TextureFormat.RGBA8Unorm\r\n\t\tconst renderState = new RenderState();\r\n\t\trenderState.primitive = primitive;\r\n\t\trenderState.targets = [target];\r\n\t\tthis.renderState = renderState;\r\n\t\tthis.fullScreenQuad = new Mesh(geometry);\r\n\r\n\t\tthis.defaultSampler = new Sampler();\r\n\t}\r\n}\r\n","import { TextureFormat, TextureUsage } from \"../core/WebGPUConstant\";\r\nimport { Uniforms } from \"../core/WebGPUTypes\";\r\nimport ShaderMaterial from \"../material/ShaderMaterial\";\r\nimport Color from \"../math/Color\";\r\nimport Vector2 from \"../math/Vector2\";\r\nimport Vector3 from \"../math/Vector3\";\r\nimport Attachment from \"../render/Attachment\";\r\nimport Context from \"../render/Context\";\r\nimport RenderTarget from \"../render/RenderTarget\";\r\nimport Texture from \"../render/Texture\";\r\nimport getVertFrag from \"../shader/Shaders\";\r\nimport PostEffect from \"./PostEffect\";\r\n\r\nexport default class BloomPostEffect extends PostEffect {\r\n\tstatic BlurDirectionX = new Vector2(1.0, 0.0);\r\n\tstatic BlurDirectionY = new Vector2(0.0, 1.0);\r\n\tstrength: number;\r\n\tradius: number;\r\n\tthreshold: number;\r\n\trenderTargetsHorizontal: RenderTarget[];\r\n\trenderTargetsVertical: RenderTarget[];\r\n\tnMips: number;\r\n\trenderTargetBright: RenderTarget;\r\n\tmaterialHighPassFilter: ShaderMaterial;\r\n\thighPassUniforms: Uniforms;\r\n\tcompositeMaterial: ShaderMaterial;\r\n\tseparableBlurMaterials: ShaderMaterial[];\r\n\tseparableBlurYMaterials: ShaderMaterial[];\r\n\tblendUniforms: Uniforms;\r\n\tblendMaterial: ShaderMaterial;\r\n\tblendTarget: RenderTarget;\r\n\r\n\tconstructor(options: BloomPostEffectProps) {\r\n\t\tsuper(options.width, options.height, \"bloom\");\r\n\t\tthis.strength = options.strength;\r\n\t\tthis.radius = options.radius;\r\n\t\tthis.threshold = options.threshold;\r\n\t\tthis.init();\r\n\t}\r\n\tdestroy() {\r\n\t\tthis.renderTargetBright.destroy();\r\n\t}\r\n\trender(context: Context, colorTexture: Texture): Texture {\r\n\t\t// 1. Extract Bright Areas\r\n\t\tthis.currentRenderTarget = this.renderTargetBright;\r\n\t\tthis.highPassUniforms.tDiffuse.value = colorTexture;\r\n\t\tthis.fullScreenQuad.material = this.materialHighPassFilter;\r\n\t\tthis.renderMesh(context);\r\n\t\t// 2. Blur All the mips progressively\r\n\t\tlet inputRenderTarget = this.renderTargetBright;\r\n\t\tfor (let i = 0; i < this.nMips; i++) {\r\n\t\t\tthis.fullScreenQuad.material = this.separableBlurMaterials[i];\r\n\r\n\t\t\tthis.separableBlurMaterials[i].uniforms.tDiffuse.value = inputRenderTarget.getColorTexture();\r\n\t\t\tthis.separableBlurMaterials[i].uniforms.direction.value = BloomPostEffect.BlurDirectionX;\r\n\t\t\tthis.currentRenderTarget = this.renderTargetsHorizontal[i];\r\n\r\n\t\t\tthis.renderMesh(context);\r\n\t\t\tthis.fullScreenQuad.material = this.separableBlurYMaterials[i];\r\n\t\t\tthis.separableBlurYMaterials[i].uniforms.tDiffuse.value = this.renderTargetsHorizontal[i].getColorTexture();\r\n\t\t\tthis.separableBlurYMaterials[i].uniforms.direction.value = BloomPostEffect.BlurDirectionY;\r\n\t\t\tthis.currentRenderTarget = this.renderTargetsVertical[i];\r\n\r\n\t\t\tthis.renderMesh(context);\r\n\r\n\t\t\tinputRenderTarget = this.renderTargetsVertical[i];\r\n\t\t}\r\n\t\t// Composite All the mips\r\n\t\tthis.fullScreenQuad.material = this.compositeMaterial;\r\n\t\tthis.currentRenderTarget = this.renderTargetsHorizontal[0];\r\n\t\tthis.renderMesh(context);\r\n\t\t// blend\r\n\t\tthis.blendUniforms.baseColorTexture.value = colorTexture;\r\n\t\tthis.fullScreenQuad.material = this.blendMaterial;\r\n\t\tthis.currentRenderTarget = this.blendTarget;\r\n\t\tthis.renderMesh(context);\r\n\t\treturn this.currentRenderTarget.getColorTexture();\r\n\t}\r\n\tprivate init() {\r\n\t\tthis.renderTargetsHorizontal = [];\r\n\t\tthis.renderTargetsVertical = [];\r\n\t\tthis.nMips = 5;\r\n\t\tlet resx = Math.round(this.width / 2);\r\n\t\tlet resy = Math.round(this.height / 2);\r\n\r\n\t\tthis.renderTargetBright = new RenderTarget(\"render\", [this.createColorAttachment(resx, resy)]);\r\n\r\n\t\tfor (let i = 0; i < this.nMips; i++) {\r\n\t\t\tconst renderTargetHorizonal = new RenderTarget(\"render\", [this.createColorAttachment(resx, resy)]);\r\n\t\t\tthis.renderTargetsHorizontal.push(renderTargetHorizonal);\r\n\t\t\tconst renderTargetVertical = new RenderTarget(\"render\", [this.createColorAttachment(resx, resy)]);\r\n\t\t\tthis.renderTargetsVertical.push(renderTargetVertical);\r\n\t\t\tresx = Math.round(resx / 2);\r\n\t\t\tresy = Math.round(resy / 2);\r\n\t\t}\r\n\t\t// luminosity high pass material\r\n\t\tthis.highPassUniforms = {\r\n\t\t\ttDiffuse: { type: \"texture\", value: null },\r\n\t\t\ttSampler: {\r\n\t\t\t\ttype: \"sampler\",\r\n\t\t\t\tvalue: this.defaultSampler\r\n\t\t\t},\r\n\t\t\tluminosityThreshol: { type: \"float\", value: this.threshold },\r\n\t\t\tsmoothWidth: { type: \"float\", value: 0.01 },\r\n\t\t\tdefaultColor: { type: \"color\", value: new Color(0.0, 0, 0) },\r\n\t\t\tdefaultOpacity: { type: \"float\", value: 1.0 }\r\n\t\t};\r\n\t\tconst shader = getVertFrag(\"luminosityHigh\", { positionLocation: 0 });\r\n\t\tthis.materialHighPassFilter = new ShaderMaterial({\r\n\t\t\ttype: \"bloom\",\r\n\t\t\tuniforms: this.highPassUniforms,\r\n\t\t\tvert: shader.vert,\r\n\t\t\tfrag: shader.frag\r\n\t\t});\r\n\t\t// Gaussian Blur Materials\r\n\t\tthis.materialHighPassFilter.renderState = this.renderState;\r\n\t\tthis.separableBlurMaterials = [];\r\n\t\tthis.separableBlurYMaterials = [];\r\n\t\tconst kernelSizeArray = [3, 5, 7, 9, 11];\r\n\t\tresx = Math.round(this.width / 2);\r\n\t\tresy = Math.round(this.height / 2);\r\n\r\n\t\tfor (let i = 0; i < this.nMips; i++) {\r\n\t\t\tthis.separableBlurMaterials.push(this.getSeperableBlurMaterial(kernelSizeArray[i], \"BlurMaterial\" + i));\r\n\t\t\tthis.separableBlurYMaterials.push(this.getSeperableBlurMaterial(kernelSizeArray[i], \"BlurMaterialY\" + i));\r\n\t\t\tresx = Math.round(resx / 2);\r\n\r\n\t\t\tresy = Math.round(resy / 2);\r\n\t\t}\r\n\t\t// Composite material\r\n\t\tthis.compositeMaterial = this.getCompositeMaterial(this.nMips, \"compositeMaterial\");\r\n\t\tthis.compositeMaterial.renderState = this.renderState;\r\n\t\tthis.blendUniforms = {\r\n\t\t\ttDiffuse: { type: \"texture\", value: this.renderTargetsHorizontal[0].getColorTexture() },\r\n\t\t\tbaseColorTexture: { type: \"texture\", value: null },\r\n\t\t\ttSampler: {\r\n\t\t\t\ttype: \"sampler\",\r\n\t\t\t\tvalue: this.defaultSampler\r\n\t\t\t}\r\n\t\t};\r\n\t\tconst blendShader = getVertFrag(\"blend\", { positionLocation: 0 });\r\n\t\tthis.blendMaterial = new ShaderMaterial({\r\n\t\t\ttype: \"postBlend\",\r\n\t\t\tuniforms: this.blendUniforms,\r\n\t\t\tvert: blendShader.vert,\r\n\t\t\tfrag: blendShader.frag\r\n\t\t});\r\n\t\tthis.blendMaterial.renderState = this.renderState;\r\n\t\tthis.blendTarget = new RenderTarget(\"render\", [this.createColorAttachment(this.width, this.height)]);\r\n\t}\r\n\tprivate createColorAttachment(width: number, height: number): Attachment {\r\n\t\tconst colorTexture = new Texture({\r\n\t\t\tsize: { width, height, depth: 1 },\r\n\t\t\tformat: TextureFormat.BGRA8Unorm,\r\n\t\t\tusage: TextureUsage.RenderAttachment | TextureUsage.TextureBinding\r\n\t\t});\r\n\t\tconst colorAttachment = new Attachment({ r: 0.0, g: 0.0, b: 0.0, a: 0.0 }, { texture: colorTexture });\r\n\t\treturn colorAttachment;\r\n\t}\r\n\tprivate getCompositeMaterial(nMips: number, type): ShaderMaterial {\r\n\t\treturn new ShaderMaterial({\r\n\t\t\ttype,\r\n\t\t\tuniforms: {\r\n\t\t\t\tblurTexture1: { type: \"texture\", value: this.renderTargetsVertical[0].getColorTexture() },\r\n\t\t\t\tblurTexture2: { type: \"texture\", value: this.renderTargetsVertical[1].getColorTexture() },\r\n\t\t\t\tblurTexture3: { type: \"texture\", value: this.renderTargetsVertical[2].getColorTexture() },\r\n\t\t\t\tblurTexture4: { type: \"texture\", value: this.renderTargetsVertical[3].getColorTexture() },\r\n\t\t\t\tblurTexture5: { type: \"texture\", value: this.renderTargetsVertical[4].getColorTexture() },\r\n\t\t\t\ttSampler: {\r\n\t\t\t\t\ttype: \"sampler\",\r\n\t\t\t\t\tvalue: this.defaultSampler\r\n\t\t\t\t},\r\n\t\t\t\tbloomStrength: { type: \"float\", value: this.strength },\r\n\t\t\t\tbloomRadius: { type: \"float\", value: this.radius },\r\n\t\t\t\tbloomFactors: { type: \"float-array\", value: [1.0, 0.8, 0.6, 0.4, 0.2] },\r\n\t\t\t\tbloomTintColors: {\r\n\t\t\t\t\ttype: \"vec3-array\",\r\n\t\t\t\t\tvalue: [\r\n\t\t\t\t\t\tnew Vector3(1, 1, 1),\r\n\t\t\t\t\t\tnew Vector3(1, 1, 1),\r\n\t\t\t\t\t\tnew Vector3(1, 1, 1),\r\n\t\t\t\t\t\tnew Vector3(1, 1, 1),\r\n\t\t\t\t\t\tnew Vector3(1, 1, 1)\r\n\t\t\t\t\t]\r\n\t\t\t\t}\r\n\t\t\t},\r\n\r\n\t\t\tvert: (defines) => {\r\n\t\t\t\t`\r\n              struct VertexInput {\r\n                    @location(0) position: vec2<f32>,       \r\n               }\r\n               struct VertexOutput {\r\n                    @builtin(position) position: vec4<f32>,\r\n                    @location(0) uv: vec2<f32>,\r\n                };\r\n               @vertex\r\n               fn main(input: VertexInput) -> VertexOutput {\r\n                var output:VertexOutput;\r\n                output.uv = input.position * 0.5 + 0.5;\r\n                output.position = vec4<f32>(input.position, 0.0, 1.0);;\r\n                return output;\r\n               }\r\n                `;\r\n\t\t\t},\r\n\r\n\t\t\tfrag: (defines) => {\r\n\t\t\t\t`\r\n                struct FragInput {\r\n                    @location(0) uv: vec2<f32>,\r\n                };\r\n                struct BloomUniforms{\r\n                    bloomStrength:f32,\r\n                    bloomRadius:f32,\r\n                    bloomFactors : array<f32,5>,\r\n                    bloomTintColors : array<vec3<f32>,5>\r\n                }  \r\n                @group(0) @binding(0)  var<storage, read> bloomUniforms : BloomUniforms;\r\n\r\n                @group(0) @binding(${defines.blurTexture1Binding}) var blurTexture1: texture_2d<f32>;\r\n                @group(0) @binding(${defines.blurTexture2Binding}) var blurTexture2: texture_2d<f32>;\r\n                @group(0) @binding(${defines.blurTexture3Binding}) var blurTexture3: texture_2d<f32>;\r\n                @group(0) @binding(${defines.blurTexture4Binding}) var blurTexture4: texture_2d<f32>;\r\n                @group(0) @binding(${defines.blurTexture5Binding}) var blurTexture5: texture_2d<f32>;\r\n                @group(0) @binding(${defines.tSamplerBinding}}) var tSampler: sampler;\r\n\r\n\t\t\t\tfn lerpBloomFactor(factor:f32)->f32 {\r\n\t\t\t\t\tlet mirrorFactor:f32 = 1.2 - factor;\r\n\t\t\t\t\treturn mix(factor, mirrorFactor, bloomUniforms.bloomRadius);\r\n\t\t\t\t}\r\n                @fragment\r\n\t\t\t\tfn main(input:FragInput)-> @location(0) vec4<f32>  {\r\n\t\t\t\t\treturn bloomUniforms.bloomStrength * ( lerpBloomFactor(bloomUniforms.bloomFactors[0]) * vec4(bloomUniforms.bloomTintColors[0], 1.0) * textureSample(blurTexture1, tSampler, input.uv) +\r\n\t\t\t\t\t\tlerpBloomFactor(bloomUniforms.bloomFactors[1]) * vec4<f32>(bloomUniforms.bloomTintColors[1], 1.0) * textureSample(blurTexture2, tSampler, input.uv) +\r\n\t\t\t\t\t\tlerpBloomFactor(bloomUniforms.bloomFactors[2]) * vec4<f32>(bloomUniforms.bloomTintColors[2], 1.0) * textureSample(blurTexture3, tSampler, input.uv) +\r\n\t\t\t\t\t\tlerpBloomFactor(bloomUniforms.bloomFactors[3]) * vec4<f32>(bloomUniforms.bloomTintColors[3], 1.0) * textureSample(blurTexture4, tSampler, input.uv) +\r\n\t\t\t\t\t\tlerpBloomFactor(bloomUniforms.bloomFactors[4]) * vec4<f32>(bloomUniforms.bloomTintColors[4], 1.0) * textureSample(blurTexture5, tSampler, input.uv) );\r\n\t\t\t\t}`;\r\n\t\t\t}\r\n\t\t});\r\n\t}\r\n\tprivate getSeperableBlurMaterial(kernelRadius, type) {\r\n\t\tconst shader = getVertFrag(\"blur\", {\r\n\t\t\tKERNEL_RADIUS: kernelRadius,\r\n\t\t\tSIGMA: kernelRadius,\r\n\t\t\tpositionLocation: 0\r\n\t\t});\r\n\t\tconst mat = new ShaderMaterial({\r\n\t\t\ttype,\r\n\t\t\tuniforms: {\r\n\t\t\t\ttDiffuse: { type: \"texture\", value: null },\r\n\t\t\t\tdirection: { type: \"vec2\", value: new Vector2(0.0, 0.0) },\r\n\t\t\t\ttSampler: {\r\n\t\t\t\t\ttype: \"sampler\",\r\n\t\t\t\t\tvalue: this.defaultSampler\r\n\t\t\t\t}\r\n\t\t\t},\r\n\r\n\t\t\tvert: shader.vert,\r\n\r\n\t\t\tfrag: shader.frag\r\n\t\t});\r\n\t\tmat.renderState = this.renderState;\r\n\t\treturn mat;\r\n\t}\r\n}\r\n\r\ntype BloomPostEffectProps = {\r\n\twidth: number;\r\n\theight: number;\r\n\tstrength: number;\r\n\tradius: number;\r\n\tthreshold: number;\r\n};\r\n","import Matrix4 from \"../math/Matrix4\";\r\nimport Camera from \"./Camera\";\r\nexport default class OrthographicCamera extends Camera {\r\n\tright: number;\r\n\tisOrthographicCamera: boolean;\r\n\tbottom: number;\r\n\tleft: number;\r\n\tnear: number;\r\n\tfar: number;\r\n\ttop: number;\r\n\tconstructor(left = -1, right = 1, top = 1, bottom = -1, near = 0.1, far = 2000) {\r\n\t\tsuper();\r\n\t\tthis.near = near;\r\n\t\tthis.far = far;\r\n\t\tthis.left = left;\r\n\t\tthis.top = top;\r\n\t\tthis.bottom = bottom;\r\n\t\tthis.right = right;\r\n\t\tthis.isOrthographicCamera = true;\r\n\t}\r\n\tprivate updateCameraParms() {\r\n\t\tconst dx = (this.right - this.left) / 2;\r\n\t\tconst dy = (this.top - this.bottom) / 2;\r\n\t\tconst cx = (this.right + this.left) / 2;\r\n\t\tconst cy = (this.top + this.bottom) / 2;\r\n\t\treturn {\r\n\t\t\tleft: cx - dx,\r\n\t\t\tright: cx + dx,\r\n\t\t\ttop: cy + dy,\r\n\t\t\tbottom: cy - dy\r\n\t\t};\r\n\t}\r\n\tpublic updateProjectionMatrix() {\r\n\t\tif (this.projectMatrixDirty) {\r\n\t\t\tconst { left, right, top, bottom } = this.updateCameraParms();\r\n\t\t\tthis._projectionMatrix = Matrix4.makeOrthographic(left, right, top, bottom, this.near, this.far);\r\n\t\t\tthis.projectMatrixDirty = false;\r\n\t\t}\r\n\t}\r\n}\r\n","import PerspectiveCamera from \"../../camera/PerspectiveCamera\";\nimport Vector2 from \"../../math/Vector2\";\nimport { SpotLight } from \"../SpotLight\";\nimport { BaseShadow } from \"./BaseShadow\";\n\nexport class SpotLightShadow extends BaseShadow {\n\tpublic type: string;\n\tconstructor() {\n\t\tconst camera = new PerspectiveCamera(60, 1, 0.1, 500);\n\t\tsuper(new Vector2(1024, 1024), camera);\n\t\tthis.type = \"spotLightShadow\";\n\t}\n\n\tpublic update(light: SpotLight) {\n\t\tthis.updateMatrices(light);\n\t}\n\n\tupdateMatrices(light: SpotLight) {\n\t\tthis.camera.position.copy(light.position);\n\t\tconst { x, y, z } = light.target;\n\t\tthis.camera.lookAt(x, y, z);\n\t\tthis.camera.updateMatrix();\n\t\tthis.vpMatrixDirty = true;\n\t}\n}\n","import { LightType } from \"../core/WebGPUTypes\";\r\nimport Vector3 from \"../math/Vector3\";\r\nimport { Light } from \"./Light\";\r\nimport { SpotLightShadow } from \"./shadows/SpotLightShadow\";\r\n\r\nexport class SpotLight extends Light {\r\n\tprivate _distance: number;\r\n\tprivate _angle: number;\r\n\tprivate _penumbra: number;\r\n\tprivate _decay: number;\r\n\tdecayDirty: boolean;\r\n\tdistanceDirty: boolean;\r\n\tprivate _coneCos: number;\r\n\tprivate _penumbraCos: number;\r\n\tconeCosDirty: boolean;\r\n\tpenumbraDirty: boolean;\r\n\tangleDirty: boolean;\r\n\tpenumbraCosDirty: boolean;\r\n\tconstructor(color, intensity, distance = 0, angle = 60, penumbra = 60, decay = 4, openShadow = true) {\r\n\t\tsuper(color, intensity);\r\n\t\tthis._distance = distance;\r\n\t\tthis._angle = (angle / 180) * Math.PI;\r\n\t\tthis._penumbra = (penumbra / 180) * Math.PI;\r\n\t\tthis._decay = decay;\r\n\t\tthis.lightType = LightType.SpotLight;\r\n\t\tthis.angleDirty = true;\r\n\t\tthis.penumbraDirty = true;\r\n\t\tthis.distanceDirty = true;\r\n\t\tthis.decayDirty = true;\r\n\t\tthis.coneCosDirty = true;\r\n\t\tthis.penumbraCosDirty = true;\r\n\t\tif (openShadow) this.shadow = new SpotLightShadow();\r\n\t\tthis.updateConeCosOrPenumbraCos();\r\n\t}\r\n\r\n\tget dirtectDirty() {\r\n\t\treturn this.positionDirty || this.targetDirty;\r\n\t}\r\n\r\n\tset dirtectDirty(value) {\r\n\t\tthis.positionDirty = value;\r\n\t\tthis.targetDirty = value;\r\n\t}\r\n\r\n\tget directional() {\r\n\t\tconst result = new Vector3();\r\n\t\tVector3.subtract(this.position, this.target, result);\r\n\t\treturn Vector3.normalize(result, new Vector3());\r\n\t}\r\n\tget angle() {\r\n\t\treturn this._angle;\r\n\t}\r\n\tset angle(value) {\r\n\t\tthis.angleDirty = true;\r\n\t\tthis._angle = (value / 180) * Math.PI;\r\n\t\tthis.updateConeCosOrPenumbraCos();\r\n\t}\r\n\tget penumbra() {\r\n\t\treturn this._penumbra;\r\n\t}\r\n\tset penumbra(value) {\r\n\t\tthis.penumbraDirty = true;\r\n\t\tthis._penumbra = (value / 180) * Math.PI;\r\n\t\tthis.updateConeCosOrPenumbraCos();\r\n\t}\r\n\tset distance(value) {\r\n\t\tthis.distanceDirty = true;\r\n\t\tthis._distance = value;\r\n\t}\r\n\tget distance() {\r\n\t\treturn this._distance;\r\n\t}\r\n\tset decay(value) {\r\n\t\tthis.decayDirty = true;\r\n\t\tthis._decay = value;\r\n\t}\r\n\tget decay() {\r\n\t\treturn this._decay;\r\n\t}\r\n\tset coneCos(value) {\r\n\t\tthis.coneCosDirty = true;\r\n\t\tthis._coneCos = value;\r\n\t}\r\n\tget coneCos() {\r\n\t\treturn this._coneCos;\r\n\t}\r\n\tset penumbraCos(value) {\r\n\t\tthis.penumbraCosDirty = true;\r\n\t\tthis._penumbraCos = value;\r\n\t}\r\n\tget penumbraCos() {\r\n\t\treturn this._penumbraCos;\r\n\t}\r\n\tprivate updateConeCosOrPenumbraCos() {\r\n\t\tthis._coneCos = Math.cos(this.angle);\r\n\t\tthis._penumbraCos = Math.cos(this.angle + this.penumbra);\r\n\t}\r\n}\r\n// uniform\r\n// color: {},\r\n// position: {},\r\n// direction: {},\r\n// distance: {},\r\n// coneCos: {},\r\n// penumbraCos: {},\r\n// decay: {}\r\n","import OrthographicCamera from \"../../camera/OrthographicCamera\";\nimport Vector2 from \"../../math/Vector2\";\nimport { DirectionalLight } from \"../DirectionalLight\";\nimport { BaseShadow } from \"./BaseShadow\";\n\nexport class DirectionalLightShadow extends BaseShadow {\n\tpublic type: string;\n\tconstructor() {\n\t\tconst camera = new OrthographicCamera(-50, 50, 50, -50, 0, 100);\n\t\tsuper(new Vector2(1024, 1024), camera);\n\t\tthis.type = \"directionalLightShadow\";\n\t}\n\n\tpublic update(light: DirectionalLight) {\n\t\tthis.updateMatrices(light);\n\t}\n\n\tupdateMatrices(light: DirectionalLight) {\n\t\tthis.camera.position.copy(light.position);\n\t\tconst { x, y, z } = light.target;\n\t\tthis.camera.lookAt(x, y, z);\n\t\tthis.camera.updateMatrix();\n\t\tthis.vpMatrixDirty = true;\n\t}\n}\n","import { LightType } from \"../core/WebGPUTypes\";\nimport Vector3 from \"../math/Vector3\";\nimport { Light } from \"./Light\";\nimport { DirectionalLightShadow } from \"./shadows/DirectionalLightShadow\";\n\nexport class DirectionalLight extends Light {\n\tconstructor(color: Vector3, intensity: number, openShadow = true) {\n\t\tsuper(color, intensity);\n\t\tthis.lightType = LightType.DirectionalLight;\n\t\tif (openShadow) this.shadow = new DirectionalLightShadow();\n\t}\n\n\tget dirtectDirty() {\n\t\treturn this.positionDirty || this.targetDirty;\n\t}\n\n\tset dirtectDirty(value) {\n\t\tthis.positionDirty = value;\n\t\tthis.targetDirty = value;\n\t}\n\n\tget directional() {\n\t\tconst result = new Vector3();\n\t\tVector3.subtract(this.target, this.position, result);\n\t\treturn result.normalize();\n\t}\n}\n// uniform\n// direction: {},\n// color: {}\n","import Camera from \"../camera/Camera\";\r\nimport { FrameState } from \"../core/FrameState\";\r\nimport RenderObject from \"../core/RenderObject\";\r\nimport { RenderObjectType } from \"../core/WebGPUTypes\";\r\nimport createGuid from \"../utils/createGuid\";\r\nimport { Mesh } from \"./Mesh\";\r\n\r\nexport default class Node extends RenderObject {\r\n\tuid: string;\r\n\tchildren: Map<string, Node | Mesh>;\r\n\tname: string;\r\n\tconstructor() {\r\n\t\tsuper();\r\n\t\tthis.type = RenderObjectType.Node;\r\n\t\tthis.children = new Map();\r\n\t\tthis.parent = null;\r\n\t\tthis.uid = createGuid();\r\n\t}\r\n\tadd(node: Node | Mesh) {\r\n\t\tnode.parent = this;\r\n\t\tthis.children.set(node.uid, node);\r\n\t}\r\n\tremove(node: Node | Mesh) {\r\n\t\tthis.children.delete(node.uid);\r\n\t}\r\n\tupdate(frameState: FrameState, camera?: Camera) {\r\n\t\tthis.updateMatrix(this?.parent?.modelMatrix?.clone());\r\n\t\tthis?.children?.forEach?.((node) => {\r\n\t\t\tnode.update(frameState, camera);\r\n\t\t});\r\n\t}\r\n\tdestroy() {\r\n\t\tthis.children.forEach((node) => {\r\n\t\t\tnode.destroy();\r\n\t\t});\r\n\t\tthis?.children?.clear();\r\n\t}\r\n\ttraverse(traverseFunction: Function, param: { [prop: string]: any }): void {\r\n\t\tfor (let i = 0, len = this.children.size; i < len; i++) {\r\n\t\t\tthis.children.forEach((child) => {\r\n\t\t\t\tchild.traverse(traverseFunction, param);\r\n\t\t\t});\r\n\t\t}\r\n\t}\r\n}\r\n","import Camera from \"../camera/Camera\";\nimport { FrameState } from \"../core/FrameState\";\nimport { BufferBindingType, BufferUsage } from \"../core/WebGPUConstant\";\nimport { RenderObjectType } from \"../core/WebGPUTypes\";\nimport Geometry from \"../geometry/Geometry\";\nimport { Material } from \"../material/Material\";\nimport Matrix4 from \"../math/Matrix4\";\nimport UniformBuffer from \"../render/UniformBuffer\";\nimport { UniformEnum } from \"../render/Uniforms\";\nimport { Mesh } from \"./Mesh\";\nimport Node from \"./Node\";\n\nexport class SKinMesh extends Mesh {\n\tinverseBindMatrices: Array<Matrix4>;\n\tuniformMatrixs: Array<Matrix4>;\n\tjoints: Array<Node>;\n\tprivate hasAddJoints: boolean;\n\tconstructor(geometry?: Geometry, material?: Material) {\n\t\tsuper(geometry, material);\n\t\tthis.type = RenderObjectType.SkinMesh;\n\t\tthis.uniformMatrixs = [];\n\t\tthis.hasAddJoints = false;\n\t}\n\tsetSkinData(data: SkinDataType) {\n\t\tthis.inverseBindMatrices = data.inverseBindMatrices;\n\t\tthis.joints = data.joints;\n\t}\n\tupdate(frameState: FrameState, camera?: Camera) {\n\t\tthis.uniformMatrixs = this.joints.map((joint) => (joint as Node).modelMatrix);\n\t\tsuper.update(frameState, camera);\n\t\tif (!this.hasAddJoints) this.addUniformsToMaterial();\n\t}\n\tprivate addUniformsToMaterial() {\n\t\tif (!this.material.shaderData) return;\n\t\tthis.hasAddJoints = true;\n\t\tif (this.joints) {\n\t\t\tconst skinJointsBuffer = new UniformBuffer({\n\t\t\t\tlabel: \"skinJointsBuffer\",\n\t\t\t\ttype: BufferBindingType.ReadOnlyStorage,\n\t\t\t\tusage: BufferUsage.Storage | BufferUsage.CopyDst,\n\t\t\t\tsize: 3000\n\t\t\t});\n\t\t\tconst invsBuffer = new UniformBuffer({\n\t\t\t\tlabel: \"invsBuffer\",\n\t\t\t\ttype: BufferBindingType.ReadOnlyStorage,\n\t\t\t\tusage: BufferUsage.Storage | BufferUsage.CopyDst,\n\t\t\t\tsize: 3000\n\t\t\t});\n\t\t\tskinJointsBuffer.setUniform(\n\t\t\t\t\"joints\",\n\t\t\t\t() => {\n\t\t\t\t\treturn this.uniformMatrixs;\n\t\t\t\t},\n\t\t\t\tUniformEnum.Mat4Array,\n\t\t\t\tthis.uniformMatrixs.length\n\t\t\t);\n\t\t\tinvsBuffer.setUniform(\n\t\t\t\t\"jointsInv\",\n\t\t\t\t() => {\n\t\t\t\t\treturn this.inverseBindMatrices;\n\t\t\t\t},\n\t\t\t\tUniformEnum.Mat4Array,\n\t\t\t\tthis.inverseBindMatrices.length\n\t\t\t);\n\t\t\tthis.material.shaderData.setUniformBuffer(\"skinJointsBuffer\", skinJointsBuffer);\n\t\t\tthis.material.shaderData.setUniformBuffer(\"invsBuffer\", invsBuffer);\n\t\t}\n\t}\n}\nexport type SkinDataType = {\n\tinverseBindMatrices?: Array<Matrix4>;\n\tjoints?: Array<Node>;\n};\n","import { Quaternion } from \"../math/Quaternion\";\r\nimport Vector2 from \"../math/Vector2\";\r\nimport Vector3 from \"../math/Vector3\";\r\n\r\nexport function clamp(num: number, min: number, max: number) {\r\n\treturn Math.min(Math.max(num, min), max);\r\n}\r\n\r\nexport function toFloat(num: number | undefined, defaultValue = 1) {\r\n\tconst n = num !== undefined ? num : defaultValue;\r\n\tif (Number.isInteger(n)) {\r\n\t\treturn `${n}.0`;\r\n\t}\r\n\treturn n;\r\n}\r\n\r\nexport type TypedArray = Int8Array | Uint8Array | Int16Array | Uint16Array | Uint32Array | Float32Array;\r\n\r\nexport function newTypedArray(type: number, buffer: ArrayBuffer, byteOffset: number, length: number) {\r\n\tswitch (type) {\r\n\t\tcase 5120:\r\n\t\t\treturn new Int8Array(buffer, byteOffset, length);\r\n\t\tcase 5121:\r\n\t\t\treturn new Uint8Array(buffer, byteOffset, length);\r\n\t\tcase 5122:\r\n\t\t\treturn new Int16Array(buffer, byteOffset, length);\r\n\t\tcase 5123:\r\n\t\t\treturn new Uint16Array(buffer, byteOffset, length);\r\n\t\tcase 5124:\r\n\t\t\treturn new Int32Array(buffer, byteOffset, length);\r\n\t\tcase 5125:\r\n\t\t\treturn new Uint32Array(buffer, byteOffset, length);\r\n\t\tcase 5126:\r\n\t\t\treturn new Float32Array(buffer, byteOffset, length);\r\n\t\tdefault:\r\n\t\t\tthrow new Error(\"invalid component type\");\r\n\t}\r\n}\r\n\r\nexport function toIndices(array: TypedArray): Uint16Array | Uint32Array {\r\n\tif (array instanceof Uint16Array || array instanceof Uint32Array) {\r\n\t\treturn array;\r\n\t}\r\n\tlet toArray;\r\n\tif (array instanceof Float32Array) {\r\n\t\ttoArray = new Uint32Array(array.length);\r\n\t} else {\r\n\t\ttoArray = new Uint16Array(array.length);\r\n\t}\r\n\tarray.forEach((element, index) => {\r\n\t\ttoArray[index] = element;\r\n\t});\r\n\treturn toArray;\r\n}\r\n\r\nexport function joinArray(arrays: Array<Float32Array>) {\r\n\tlet length = 0;\r\n\tarrays.forEach((array) => {\r\n\t\tlength += array.length;\r\n\t});\r\n\tconst joined = new Float32Array(length);\r\n\tlength = 0;\r\n\tarrays.forEach((array) => {\r\n\t\tjoined.set(array, length);\r\n\t\tlength += array.length;\r\n\t});\r\n\treturn joined;\r\n}\r\n\r\nexport function createGPUBuffer(array: TypedArray, usage: number, device: GPUDevice) {\r\n\tconst buffer = device.createBuffer({\r\n\t\tsize: (array.byteLength + 3) & ~3, // eslint-disable-line no-bitwise\r\n\t\tusage,\r\n\t\tmappedAtCreation: true\r\n\t});\r\n\tlet writeArary;\r\n\tif (array instanceof Int8Array) {\r\n\t\twriteArary = new Int8Array(buffer.getMappedRange());\r\n\t} else if (array instanceof Uint8Array) {\r\n\t\twriteArary = new Uint8Array(buffer.getMappedRange());\r\n\t} else if (array instanceof Int16Array) {\r\n\t\twriteArary = new Int16Array(buffer.getMappedRange());\r\n\t} else if (array instanceof Uint16Array) {\r\n\t\twriteArary = new Uint16Array(buffer.getMappedRange());\r\n\t} else if (array instanceof Uint32Array) {\r\n\t\twriteArary = new Uint32Array(buffer.getMappedRange());\r\n\t} else {\r\n\t\twriteArary = new Float32Array(buffer.getMappedRange());\r\n\t}\r\n\twriteArary.set(array);\r\n\tbuffer.unmap();\r\n\treturn buffer;\r\n}\r\n\r\nexport function generateNormals(indices: TypedArray | null, positions: TypedArray) {\r\n\tconst normals = new Float32Array(positions.length);\r\n\tconst vertexCount = indices ? indices.length : positions.length;\r\n\tfor (let i = 0; i < vertexCount; i += 3) {\r\n\t\tconst triIndices = [];\r\n\t\tfor (let n = 0; n < 3; n += 1) {\r\n\t\t\tif (indices) {\r\n\t\t\t\ttriIndices.push(indices[i + n]);\r\n\t\t\t} else {\r\n\t\t\t\ttriIndices.push(i + n);\r\n\t\t\t}\r\n\t\t}\r\n\t\tconst triangle = triIndices.map((vertexIndex) => {\r\n\t\t\tconst index = vertexIndex * 3;\r\n\t\t\treturn new Vector3(positions[index], positions[index + 1], positions[index + 2]);\r\n\t\t});\r\n\t\tconst dv1 = new Vector3();\r\n\t\tVector3.subtract(triangle[1], triangle[0], dv1);\r\n\t\tconst dv2 = new Vector3();\r\n\t\tVector3.subtract(triangle[2], triangle[0], dv2);\r\n\t\tconst normal = new Vector3();\r\n\t\tVector3.cross(dv1.normalize(), dv2.normalize(), normal);\r\n\t\tfor (let n = 0; n < 3; n += 1) {\r\n\t\t\tconst index = (i + n) * 3;\r\n\t\t\tnormals[index + 0] += normal.x;\r\n\t\t\tnormals[index + 1] += normal.y;\r\n\t\t\tnormals[index + 2] += normal.z;\r\n\t\t}\r\n\t}\r\n\treturn normals;\r\n}\r\n\r\nexport function generateTangents(\r\n\tindices: TypedArray | null,\r\n\tpositions: TypedArray,\r\n\tnormals: TypedArray,\r\n\tuvs: TypedArray\r\n) {\r\n\tconst tangents = new Float32Array((normals.length / 3) * 4);\r\n\tconst vertexCount = indices ? indices.length : positions.length;\r\n\tfor (let i = 0; i < vertexCount; i += 3) {\r\n\t\tconst triIndices = [];\r\n\t\tfor (let n = 0; n < 3; n += 1) {\r\n\t\t\tif (indices) {\r\n\t\t\t\ttriIndices.push(indices[i + n]);\r\n\t\t\t} else {\r\n\t\t\t\ttriIndices.push(i + n);\r\n\t\t\t}\r\n\t\t}\r\n\t\tconst pos = triIndices.map((vertexIndex) => {\r\n\t\t\tconst index = vertexIndex * 3;\r\n\t\t\treturn new Vector3(positions[index], positions[index + 1], positions[index + 2]);\r\n\t\t});\r\n\t\tconst uv = triIndices.map((vertexIndex) => {\r\n\t\t\tconst index = vertexIndex * 2;\r\n\t\t\treturn new Vector2(uvs?.[index], uvs?.[index + 1]);\r\n\t\t});\r\n\r\n\t\tconst dv1 = new Vector3();\r\n\t\tVector3.subtract(pos[1], pos[0], dv1);\r\n\t\tconst dv2 = new Vector3();\r\n\t\tVector3.subtract(pos[2], pos[0], dv2);\r\n\t\tconst duv1 = new Vector2();\r\n\t\tVector2.subtract(uv[1], uv[0], duv1);\r\n\t\tconst duv2 = new Vector2();\r\n\t\tVector2.subtract(uv[2], uv[0], duv2);\r\n\r\n\t\tconst tangent = new Vector3();\r\n\t\tVector3.multiplyByScalar(dv1, duv1.y, dv1);\r\n\t\tVector3.multiplyByScalar(dv2, duv2.y, dv2);\r\n\t\tVector3.subtract(dv1, dv2, tangent);\r\n\r\n\t\tVector3.multiplyByScalar(tangent, duv2.y * duv1.x - duv1.y * duv2.x, tangent);\r\n\r\n\t\ttangent.normalize();\r\n\t\tfor (let n = 0; n < 3; n += 1) {\r\n\t\t\tconst index = (i + n) * 4;\r\n\r\n\t\t\ttangents[index + 0] += tangent.x;\r\n\t\t\ttangents[index + 1] += tangent.y;\r\n\t\t\ttangents[index + 2] += tangent.z;\r\n\t\t\ttangents[index + 3] = 1;\r\n\t\t}\r\n\t}\r\n\treturn tangents;\r\n}\r\n\r\nfunction lerp(a: number, b: number, x: number) {\r\n\tif (x < a) {\r\n\t\treturn 0;\r\n\t}\r\n\tif (x > b) {\r\n\t\treturn 1;\r\n\t}\r\n\treturn (x - a) / (b - a);\r\n}\r\n\r\nexport function interpQuat(input: TypedArray, o: TypedArray, time: number, method: string) {\r\n\tlet index = 1;\r\n\twhile (index < input.length - 1 && time >= input[index]) {\r\n\t\tindex += 1;\r\n\t}\r\n\tconst t = lerp(input[index - 1], input[index], time);\r\n\r\n\tif (method === \"CUBICSPLINE\") {\r\n\t\tconst td = input[index] - input[index - 1];\r\n\t\tconst t2 = t * t;\r\n\t\tconst t3 = t2 * t;\r\n\t\tconst i = 12 * index;\r\n\r\n\t\tconst v0 = new Quaternion(o[i - 8], o[i - 7], o[i - 6], o[i - 5]);\r\n\t\tconst b0 = new Quaternion(o[i - 4], o[i - 3], o[i - 2], o[i - 1]);\r\n\t\tconst v1 = new Quaternion(o[i + 4], o[i + 5], o[i + 6], o[i + 7]);\r\n\t\tconst a1 = new Quaternion(o[i], o[i + 1], o[i + 2], o[i + 3]);\r\n\t\tQuaternion.multiplyByScalar(v0, 2 * t3 - 3 * t2 + 1, v0);\r\n\t\tQuaternion.multiplyByScalar(b0, td * (t3 - 2 * t2 + t), b0);\r\n\t\tQuaternion.multiplyByScalar(v1, -2 * t3 + 3 * t2, v1);\r\n\t\tQuaternion.multiplyByScalar(a1, td * (t3 - t2), a1);\r\n\r\n\t\tconst result = new Quaternion();\r\n\t\tQuaternion.add(result, v0, result);\r\n\t\tQuaternion.add(result, b0, result);\r\n\t\tQuaternion.add(result, v1, result);\r\n\t\tQuaternion.add(result, a1, result);\r\n\t\tQuaternion.normalize(result, result);\r\n\t\treturn result;\r\n\t}\r\n\r\n\tconst q = [];\r\n\tfor (let n = -1; n < 1; n += 1) {\r\n\t\tconst i = 4 * (index + n);\r\n\t\tq.push(new Quaternion(o[i], o[i + 1], o[i + 2], o[i + 3]));\r\n\t}\r\n\r\n\tif (method === \"STEP\") {\r\n\t\treturn t < 1 ? q[0] : q[1];\r\n\t}\r\n\tconst result = new Quaternion();\r\n\tQuaternion.slerp(q[0], q[1], t, result);\r\n\treturn result;\r\n}\r\n\r\nexport function interpVec3(input: TypedArray, output: TypedArray, time: number, method: string) {\r\n\tlet index = 1;\r\n\twhile (index < input.length - 1 && time >= input[index]) {\r\n\t\tindex += 1;\r\n\t}\r\n\tconst t = lerp(input[index - 1], input[index], time);\r\n\r\n\tif (method === \"CUBICSPLINE\") {\r\n\t\tconst td = input[index] - input[index - 1];\r\n\t\tconst t2 = t * t;\r\n\t\tconst t3 = t2 * t;\r\n\t\tconst i = 9 * index;\r\n\t\tconst v0 = new Vector3(output[i - 6], output[i - 5], output[i - 4]);\r\n\t\tconst b0 = new Vector3(output[i - 3], output[i - 2], output[i - 1]);\r\n\t\tconst v1 = new Vector3(output[i + 3], output[i + 4], output[i + 5]);\r\n\t\tconst a1 = new Vector3(output[i], output[i + 1], output[i + 2]);\r\n\t\tVector3.multiplyByScalar(v0, 2 * t3 - 3 * t2 + 1, v0);\r\n\t\tVector3.multiplyByScalar(b0, td * (t3 - 2 * t2 + t), b0);\r\n\t\tVector3.multiplyByScalar(v1, -2 * t3 + 3 * t2, v1);\r\n\t\tVector3.multiplyByScalar(a1, td * (t3 - t2), a1);\r\n\t\tconst result = new Vector3();\r\n\t\tVector3.add(result, v0, result);\r\n\t\tVector3.add(result, b0, result);\r\n\t\tVector3.add(result, v1, result);\r\n\t\tVector3.add(result, a1, result);\r\n\t\treturn result;\r\n\t}\r\n\r\n\tconst v = [];\r\n\tfor (let n = -1; n < 1; n += 1) {\r\n\t\tconst i = 3 * (index + n);\r\n\t\tv.push(new Vector3(output[i], output[i + 1], output[i + 2]));\r\n\t}\r\n\r\n\tif (method === \"STEP\") {\r\n\t\treturn t < 1 ? v[0] : v[1];\r\n\t}\r\n\tconst result = new Vector3();\r\n\treturn Vector3.lerp(v[0], v[1], t, result);\r\n}\r\n\r\nexport const gltfEnum: { [key: string]: string | number } = {\r\n\tSCALAR: 1,\r\n\tVEC2: 2,\r\n\tVEC3: 3,\r\n\tVEC4: 4,\r\n\tMAT2: 4,\r\n\tMAT3: 9,\r\n\tMAT4: 16,\r\n\t5120: 1,\r\n\t5121: 1,\r\n\t5122: 2,\r\n\t5123: 2,\r\n\t5125: 4,\r\n\t5126: 4,\r\n\t9728: \"nearest\",\r\n\t9729: \"linear\",\r\n\t9984: \"linear\",\r\n\t9985: \"linear\",\r\n\t9986: \"linear\",\r\n\t9987: \"linear\",\r\n\t33071: \"clamp-to-edge\",\r\n\t33648: \"mirror-repeat\",\r\n\t10497: \"repeat\"\r\n};\r\n","import Matrix4 from \"../../../math/Matrix4\";\r\nimport Vector4 from \"../../../math/Vector4\";\r\n\r\nexport class Accessor {\r\n\tvalues: any;\r\n\tid: number;\r\n\tcount: number;\r\n\tcomponentType: number;\r\n\ttype: number;\r\n\tmin: number[];\r\n\tmax: number[];\r\n\tconstructor(options: AccessorParms) {\r\n\t\tthis.values = options.values ?? [];\r\n\t\tthis.id = options.id;\r\n\t\tthis.count = options.count;\r\n\t\tthis.componentType = options.componentType;\r\n\t\tthis.type = options.type;\r\n\t\tthis.min = options.min;\r\n\t\tthis.max = options.max;\r\n\t}\r\n\tgetArray(): number[] {\r\n\t\treturn Array.from(this.values);\r\n\t}\r\n\tgetVec4Array(): Vector4[] {\r\n\t\tconst result = [];\r\n\t\tfor (let i = 0; i < this.values.length; i += 4) {\r\n\t\t\tresult.push(new Vector4(this.values[i], this.values[i + 1], this.values[i + 2], this.values[i + 3]));\r\n\t\t}\r\n\t\treturn result;\r\n\t}\r\n\tgetMat4Array(): Matrix4[] {\r\n\t\tconst result = [];\r\n\t\tfor (let i = 0; i < this.values.length; i += 16) {\r\n\t\t\tconst mat4 = new Matrix4();\r\n\t\t\tMatrix4.fromColumnMajorArray(this.values.slice(i, i + 16), mat4);\r\n\t\t\tresult.push(mat4);\r\n\t\t}\r\n\t\treturn result;\r\n\t}\r\n}\r\nexport type AccessorParms = Partial<Accessor>;\r\n","import { Quaternion } from \"../../../math/Quaternion\";\nimport Vector4 from \"../../../math/Vector4\";\nimport { AnimationChannel } from \"./AnimationChannel\";\nimport { AnimationSampler } from \"./AnimationSampler\";\n\nexport class Animation {\n\tconstructor(public name: string, public samplers: AnimationSampler[], public channels: AnimationChannel[]) {}\n\tplay(time: number) {\n\t\tlet node, animationSampler, target;\n\t\tthis?.channels?.map((channel) => {\n\t\t\tanimationSampler = channel.sampler;\n\t\t\tanimationSampler.getValue(time);\n\t\t\ttarget = channel.target;\n\t\t\tnode = target.node;\n\t\t\tswitch (target.path) {\n\t\t\t\tcase \"rotation\":\n\t\t\t\t\tQuaternion.clone(animationSampler.currentValue, node.quaternion);\n\t\t\t\t\tbreak;\n\t\t\t\tcase \"translation\":\n\t\t\t\t\tVector4.clone(animationSampler.currentValue, node.position);\n\t\t\t\t\tbreak;\n\t\t\t\tcase \"scale\":\n\t\t\t\t\tVector4.clone(animationSampler.currentValue, node.scale);\n\t\t\t\t\tbreak;\n\t\t\t}\n\t\t});\n\t}\n}\n","import { AnimationChannelTarget } from \"./AnimationChannelTarget\";\nimport { AnimationSampler } from \"./AnimationSampler\";\n\nexport class AnimationChannel {\n\tsampler: AnimationSampler;\n\ttarget: AnimationChannelTarget;\n\tconstructor() {}\n}\n","import Node from \"../../../mesh/Node\";\n\nexport class AnimationChannelTarget {\n\tnode: Node;\n\tpath: \"translation\" | \"rotation\" | \"scale\" | \"weights\";\n\tconstructor(node, path) {\n\t\tthis.node = node;\n\t\tthis.path = path;\n\t}\n}\n","export enum Type2NumOfComponent {\r\n\t\"SCALAR\" = 1,\r\n\t\"VEC2\" = 2,\r\n\t\"VEC3\" = 3,\r\n\t\"VEC4\" = 4,\r\n\t\"MAT2\" = 4,\r\n\t\"MAT3\" = 9,\r\n\t\"MAT4\" = 16\r\n}\r\n","import { Quaternion } from \"../../../math/Quaternion\";\r\nimport Vector4 from \"../../../math/Vector4\";\r\nimport { Type2NumOfComponent } from \"../types/gltfType\";\r\nexport class AnimationSampler {\r\n\tinput: any;\r\n\tinterpolation: \"LINEAR\" | \"STEP\" | \"CUBICSPLINE\";\r\n\toutput: any;\r\n\tcurrentIndex: number;\r\n\tstartTime: number;\r\n\tendTime: number;\r\n\tcurrentValue: Vector4 | Quaternion;\r\n\tduration: number;\r\n\tinputMax: number;\r\n\tprivate inputType: string;\r\n\tprivate outputType: string;\r\n\tconstructor() {}\r\n\tformGltf(gltf, sampler) {\r\n\t\tthis.input = gltf.accessors[sampler.input].values; //required, accessor object\r\n\t\tthis.output = gltf.accessors[sampler.output].values; //required, accessor object\r\n\t\tthis.interpolation = sampler.interpolation !== undefined ? sampler.interpolation : \"LINEAR\";\r\n\t\tthis.currentIndex = 0;\r\n\t\t// this.currentValue=new Vector4();\r\n\t\tthis.endTime = this.input[this.input.length - 1];\r\n\t\tthis.inputMax = this.endTime - this.input[0];\r\n\t\tthis.inputType = gltf?.json?.accessors[sampler.input]?.type;\r\n\t\tthis.outputType = gltf?.json?.accessors[sampler.output]?.type;\r\n\t}\r\n\tgetValue(time: number): void {\r\n\t\tif (time > this.endTime) {\r\n\t\t\ttime -= this.inputMax * Math.ceil((time - this.endTime) / this.inputMax);\r\n\t\t\tthis.currentIndex = 0;\r\n\t\t}\r\n\r\n\t\tconst len = this.input.length;\r\n\t\twhile (this.currentIndex <= len - 2 && time >= this.input[this.currentIndex + 1]) {\r\n\t\t\tthis.currentIndex++;\r\n\t\t}\r\n\r\n\t\tif (this.currentIndex >= len - 1) {\r\n\t\t\t// loop\r\n\t\t\ttime -= this.inputMax;\r\n\t\t\tthis.currentIndex = 0;\r\n\t\t}\r\n\r\n\t\t// @tmp: assume no stride\r\n\t\tconst count = Type2NumOfComponent[this.outputType];\r\n\r\n\t\tconst animationOutputValueVec4a = count === 4 ? new Quaternion() : new Vector4();\r\n\t\tconst animationOutputValueVec4b = count === 4 ? new Quaternion() : new Vector4();\r\n\t\tif (!this.currentValue) this.currentValue = count === 4 ? new Quaternion() : new Vector4();\r\n\t\tconst i = this.currentIndex;\r\n\t\tconst o = i * count;\r\n\t\tconst on = o + count;\r\n\r\n\t\tconst u = Math.max(0, time - this.input[i]) / (this.input[i + 1] - this.input[i]);\r\n\t\tanimationOutputValueVec4a.set(this.output[o + 0], this.output[o + 1], this.output[o + 2], this.output[o + 3]);\r\n\t\tanimationOutputValueVec4b.set(\r\n\t\t\tthis.output[on + 0],\r\n\t\t\tthis.output[on + 1],\r\n\t\t\tthis.output[on + 2],\r\n\t\t\tthis.output[on + 3]\r\n\t\t);\r\n\t\tswitch (this.interpolation) {\r\n\t\t\tcase \"LINEAR\":\r\n\t\t\t\tcount === 4\r\n\t\t\t\t\t? Quaternion.slerp(\r\n\t\t\t\t\t\t\t<Quaternion>animationOutputValueVec4a,\r\n\t\t\t\t\t\t\t<Quaternion>animationOutputValueVec4b,\r\n\t\t\t\t\t\t\tu,\r\n\t\t\t\t\t\t\t<Quaternion>this.currentValue\r\n\t\t\t\t\t  )\r\n\t\t\t\t\t: Vector4.lerp(\r\n\t\t\t\t\t\t\t<Vector4>animationOutputValueVec4a,\r\n\t\t\t\t\t\t\t<Vector4>animationOutputValueVec4b,\r\n\t\t\t\t\t\t\tu,\r\n\t\t\t\t\t\t\t<Vector4>this.currentValue\r\n\t\t\t\t\t  );\r\n\t\t\t\tbreak;\r\n\t\t\tdefault:\r\n\t\t\t\tbreak;\r\n\t\t}\r\n\t}\r\n}\r\n","import { RenderObjectType } from \"../core/WebGPUTypes\";\r\nimport Geometry from \"../geometry/Geometry\";\r\nimport PbrMaterial from \"../material/PbrMaterial\";\r\nimport Color from \"../math/Color\";\r\nimport Matrix4 from \"../math/Matrix4\";\r\nimport { Quaternion } from \"../math/Quaternion\";\r\nimport Vector3 from \"../math/Vector3\";\r\nimport { Mesh } from \"../mesh/Mesh\";\r\nimport Node from \"../mesh/Node\";\r\nimport { SKinMesh } from \"../mesh/SKinMesh\";\r\nimport { Float32Attribute } from \"../render/Attribute\";\r\nimport Sampler from \"../render/Sampler\";\r\nimport Texture from \"../render/Texture\";\r\nimport { generateNormals, gltfEnum, newTypedArray, toIndices, TypedArray } from \"../utils/gltfUtils\";\r\nimport { Accessor } from \"./gltf/libs/Accessor\";\r\nimport { Animation } from \"./gltf/libs/Animation\";\r\nimport { AnimationChannel } from \"./gltf/libs/AnimationChannel\";\r\nimport { AnimationChannelTarget } from \"./gltf/libs/AnimationChannelTarget\";\r\nimport { AnimationSampler } from \"./gltf/libs/AnimationSampler\";\r\n\r\nexport type GLTFPrimitive = {\r\n\tvertexCount: number;\r\n\tindices: Uint16Array | Uint32Array | null;\r\n\tpositions: TypedArray;\r\n\tnormals: TypedArray;\r\n\tuvs: TypedArray | null;\r\n\tuv1s: TypedArray | null;\r\n\ttangents: TypedArray | null;\r\n\tcolors: TypedArray | null;\r\n\tmaterial: any;\r\n\tboundingBox: {\r\n\t\tmax: [number, number, number];\r\n\t\tmin: [number, number, number];\r\n\t};\r\n};\r\n\r\nexport type GLTFMesh = Array<GLTFPrimitive>;\r\n\r\nexport type GLTFAnimation = {\r\n\tchannels: Array<{\r\n\t\tinput: TypedArray;\r\n\t\toutput: TypedArray;\r\n\t\tinterpolation: string;\r\n\t\tnode: number;\r\n\t\tpath: string;\r\n\t}>;\r\n\tlength: number;\r\n};\r\n\r\nexport class GLTF {\r\n\tscenes: Array<Node>;\r\n\r\n\tnodes: Array<any>;\r\n\r\n\tcameras: Array<any>;\r\n\r\n\tmeshes: Array<any>;\r\n\r\n\timages: Array<ImageBitmap>;\r\n\r\n\tanimations: Array<GLTFAnimation>;\r\n\r\n\tprivate glbOffset: number;\r\n\r\n\tprivate buffers: ArrayBuffer[];\r\n\r\n\tprivate bufferViews: any;\r\n\r\n\taccessors: any;\r\n\r\n\tjson: any;\r\n\r\n\tprivate materials: any;\r\n\r\n\tprivate glbBin?: ArrayBuffer;\r\n\r\n\tprivate rootUrl: string;\r\n\r\n\ttextures: any[];\r\n\r\n\tsamplers: Sampler[];\r\n\r\n\tconstructor(json: any, rootUrl: string, glbOffset = 0, glbBin?: ArrayBuffer) {\r\n\t\tthis.json = json;\r\n\t\tthis.bufferViews = json.bufferViews;\r\n\t\tthis.glbOffset = glbOffset;\r\n\t\tthis.rootUrl = rootUrl;\r\n\t\tthis.scenes = json.scenes;\r\n\t\tthis.cameras = json.cameras || [];\r\n\t\tthis.glbBin = glbBin;\r\n\t\tthis.meshes = [];\r\n\t}\r\n\tasync parseData() {\r\n\t\tthis.buffers = await this.loadBuffes();\r\n\t\tthis.images = await this.loadImages();\r\n\t\tthis.parseSamplers();\r\n\t\tthis.parseTextures();\r\n\t\tthis.parseMaterials();\r\n\t\tthis.parseAccessors();\r\n\t\tthis.parseMeshs();\r\n\t\tthis.parseNodes();\r\n\t\tthis.normalizeData();\r\n\t\tthis.parseScenes();\r\n\t\tthis.parseAnimations();\r\n\t}\r\n\tprivate getAccessor(index: number) {\r\n\t\treturn this.accessors[index];\r\n\t}\r\n\tprivate parseSamplers() {\r\n\t\tthis.samplers = this.json.samplers\r\n\t\t\t? (this.json.samplers as Array<any>).map((sampler) => this.getSampler(sampler))\r\n\t\t\t: [];\r\n\t}\r\n\tprivate parseScenes() {\r\n\t\tthis.scenes = this.json.scenes.map((scene) => {\r\n\t\t\tconst nodes = scene?.nodes?.map((nodeId) => {\r\n\t\t\t\treturn this.nodes[nodeId];\r\n\t\t\t});\r\n\t\t\treturn nodes;\r\n\t\t});\r\n\t}\r\n\tprivate parseTextures() {\r\n\t\tthis.textures = this.json.textures\r\n\t\t\t? (this.json.textures as Array<any>).map((texture) => {\r\n\t\t\t\t\treturn {\r\n\t\t\t\t\t\tsampler: texture.sampler !== undefined ? this.samplers[texture.sampler] : this.getSampler({}),\r\n\t\t\t\t\t\ttexture: this.createTexture(texture.source)\r\n\t\t\t\t\t};\r\n\t\t\t  })\r\n\t\t\t: [];\r\n\t}\r\n\tprivate parseMaterials() {\r\n\t\tthis.materials = this.json.materials\r\n\t\t\t? (this.json.materials as Array<any>).map((material) => {\r\n\t\t\t\t\tconst mat = new PbrMaterial();\r\n\t\t\t\t\tconst {\r\n\t\t\t\t\t\tbaseColorFactor,\r\n\t\t\t\t\t\tmetallicFactor,\r\n\t\t\t\t\t\tmetallicRoughnessTexture,\r\n\t\t\t\t\t\tbaseColorTexture,\r\n\t\t\t\t\t\troughnessFactor\r\n\t\t\t\t\t} = material.pbrMetallicRoughness;\r\n\t\t\t\t\tif (material.normalTexture) mat.normalTexture = this.textures[material.normalTexture.index].texture;\r\n\t\t\t\t\tif (material.occlusionTexture)\r\n\t\t\t\t\t\tmat.aoTexture = this.textures[material.occlusionTexture.index].texture;\r\n\t\t\t\t\tif (material.emissiveTexture)\r\n\t\t\t\t\t\tmat.emissiveTexture = this.textures[material.emissiveTexture.index].texture;\r\n\t\t\t\t\tif (baseColorTexture) mat.baseTexture = this.textures[baseColorTexture.index].texture;\r\n\t\t\t\t\tif (metallicRoughnessTexture)\r\n\t\t\t\t\t\tmat.metalnessRoughnessTexture = this.textures[metallicRoughnessTexture.index].texture;\r\n\t\t\t\t\tif (baseColorFactor)\r\n\t\t\t\t\t\tmat.color = new Color(baseColorFactor[0], baseColorFactor[1], baseColorFactor[2]);\r\n\t\t\t\t\tmat.metalness = metallicFactor ?? 1.0;\r\n\t\t\t\t\tmat.roughness = roughnessFactor ?? 0.0;\r\n\t\t\t\t\tmat.baseSampler = new Sampler({\r\n\t\t\t\t\t\tmagFilter: \"linear\",\r\n\t\t\t\t\t\tminFilter: \"linear\",\r\n\t\t\t\t\t\taddressModeU: \"repeat\",\r\n\t\t\t\t\t\taddressModeV: \"repeat\"\r\n\t\t\t\t\t});\r\n\t\t\t\t\treturn mat;\r\n\t\t\t  })\r\n\t\t\t: [];\r\n\t}\r\n\tprivate parseAccessors() {\r\n\t\tthis.accessors = (this.json.accessors as Array<any>).map((accessor, index) => {\r\n\t\t\tconst n = gltfEnum[accessor.type] as number;\r\n\t\t\tlet array;\r\n\t\t\tif (accessor.bufferView === undefined) {\r\n\t\t\t\tarray = newTypedArray(\r\n\t\t\t\t\taccessor.componentType,\r\n\t\t\t\t\tnew ArrayBuffer(n * accessor.count * (gltfEnum[accessor.componentType] as number)),\r\n\t\t\t\t\t0,\r\n\t\t\t\t\taccessor.count * n\r\n\t\t\t\t);\r\n\t\t\t} else {\r\n\t\t\t\tarray = this.getBufferView(accessor, n);\r\n\t\t\t}\r\n\r\n\t\t\tif (accessor.sparse) {\r\n\t\t\t\taccessor.sparse.indices.count = accessor.sparse.count;\r\n\t\t\t\taccessor.sparse.values.count = accessor.sparse.count;\r\n\t\t\t\taccessor.sparse.values.componentType = accessor.componentType;\r\n\t\t\t\tconst indices = this.getBufferView(accessor.sparse.indices, 1);\r\n\t\t\t\tconst values = this.getBufferView(accessor.sparse.values, n);\r\n\t\t\t\tfor (let i = 0; i < accessor.sparse.count; i += 1) {\r\n\t\t\t\t\tfor (let j = 0; j < n; j += 1) {\r\n\t\t\t\t\t\tarray[indices[i] * n + j] = values[i * n + j];\r\n\t\t\t\t\t}\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t\treturn new Accessor({\r\n\t\t\t\tcomponentType: <number>gltfEnum[accessor.componentType],\r\n\t\t\t\tcount: accessor.count,\r\n\t\t\t\ttype: n,\r\n\t\t\t\tvalues: array,\r\n\t\t\t\tid: index,\r\n\t\t\t\tmin: accessor?.min,\r\n\t\t\t\tmax: accessor?.max\r\n\t\t\t});\r\n\t\t});\r\n\t}\r\n\tprivate parseAnimations() {\r\n\t\tthis.animations = this?.json?.animations?.map((gltfAnimation, index) => {\r\n\t\t\tconst samplers = gltfAnimation?.samplers?.map((gltfSampler) => {\r\n\t\t\t\tconst sampler = new AnimationSampler();\r\n\t\t\t\tsampler.formGltf(this, gltfSampler);\r\n\t\t\t\treturn sampler;\r\n\t\t\t});\r\n\t\t\tconst channels = gltfAnimation?.channels?.map((gltfChannel) => {\r\n\t\t\t\tconst animationChannel = new AnimationChannel();\r\n\t\t\t\tanimationChannel.sampler = samplers[gltfChannel.sampler];\r\n\t\t\t\tanimationChannel.target = new AnimationChannelTarget(\r\n\t\t\t\t\tthis.nodes[gltfChannel.target.node],\r\n\t\t\t\t\tgltfChannel.target.path\r\n\t\t\t\t);\r\n\t\t\t\treturn animationChannel;\r\n\t\t\t});\r\n\t\t\tconst animation = new Animation(index.toString(), samplers, channels);\r\n\t\t\treturn animation;\r\n\t\t});\r\n\t}\r\n\tprivate parseMeshs() {\r\n\t\tthis.meshes = this?.json?.meshes?.map?.((gltfmesh) => {\r\n\t\t\treturn {\r\n\t\t\t\tname: gltfmesh.name,\r\n\t\t\t\tprimitives: gltfmesh?.primitives?.map?.((primitive) => {\r\n\t\t\t\t\tconst material =\r\n\t\t\t\t\t\tprimitive.material !== undefined\r\n\t\t\t\t\t\t\t? this.materials[primitive.material]\r\n\t\t\t\t\t\t\t: { pbrMetallicRoughness: {} };\r\n\t\t\t\t\tconst geo = this.createGeometry(primitive, material);\r\n\t\t\t\t\tconst mesh = new Mesh(geo, material);\r\n\t\t\t\t\tmesh.name = gltfmesh.name;\r\n\t\t\t\t\treturn mesh;\r\n\t\t\t\t})\r\n\t\t\t};\r\n\t\t});\r\n\t}\r\n\tprivate getSampler(samplerJson: any) {\r\n\t\treturn new Sampler({\r\n\t\t\tmagFilter: gltfEnum[samplerJson.magFilter || 9729] as GPUFilterMode,\r\n\t\t\tminFilter: gltfEnum[samplerJson.minFilter || 9729] as GPUFilterMode,\r\n\t\t\taddressModeU: gltfEnum[samplerJson.wrapS || 10497] as GPUAddressMode,\r\n\t\t\taddressModeV: gltfEnum[samplerJson.wrapT || 10497] as GPUAddressMode\r\n\t\t});\r\n\t}\r\n\tprivate getBufferView(accessor: any, n: number) {\r\n\t\tconst bufferView = this.bufferViews[accessor.bufferView];\r\n\t\tconst offset = (bufferView.byteOffset || 0) + (accessor.byteOffset || 0);\r\n\t\tconst stride = Math.max(bufferView.byteStride / 4 || 0, n);\r\n\t\tlet array = newTypedArray(\r\n\t\t\taccessor.componentType,\r\n\t\t\tthis.buffers[bufferView.buffer],\r\n\t\t\tbufferView.buffer === 0 ? offset + this.glbOffset : offset,\r\n\t\t\t(accessor.count - 1) * stride + n\r\n\t\t);\r\n\t\tif (stride > n) {\r\n\t\t\tconst TypedArrayConstructor = array.constructor as {\r\n\t\t\t\tnew (...args: any): TypedArray;\r\n\t\t\t};\r\n\t\t\tconst strided = new TypedArrayConstructor(accessor.count * n);\r\n\t\t\tfor (let i = 0, j = 0; i < strided.length; i += n, j += stride) {\r\n\t\t\t\tfor (let k = 0; k < n; k += 1) {\r\n\t\t\t\t\tstrided[i + k] = array[j + k];\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t\tarray = strided;\r\n\t\t}\r\n\t\treturn array;\r\n\t}\r\n\tprivate createGeometry(primitive, material) {\r\n\t\tlet indices = null;\r\n\t\tlet accessor = null;\r\n\t\tconst defines: { [prop: string]: boolean | number } = { HAS_NORMAL: true };\r\n\t\tlet vertexCount;\r\n\t\taccessor = this.getAccessor(primitive.attributes.POSITION);\r\n\t\tconst positions = accessor.getArray();\r\n\t\tvertexCount = accessor.count;\r\n\t\t// const { max, min } = accessor;\r\n\t\t// const boundingBox = { max, min };\r\n\t\tif (primitive.indices !== undefined) {\r\n\t\t\taccessor = this.getAccessor(primitive.indices);\r\n\t\t\tindices = toIndices(accessor.getArray());\r\n\t\t\tvertexCount = accessor.count;\r\n\t\t}\r\n\t\tlet normals;\r\n\r\n\t\tif (primitive.attributes.NORMAL !== undefined) {\r\n\t\t\taccessor = this.getAccessor(primitive.attributes.NORMAL);\r\n\t\t\tnormals = accessor.getArray();\r\n\t\t} else {\r\n\t\t\tnormals = generateNormals(indices, positions);\r\n\t\t}\r\n\r\n\t\tlet uvs = null;\r\n\t\tif (primitive.attributes.TEXCOORD_0 !== undefined) {\r\n\t\t\taccessor = this.getAccessor(primitive.attributes.TEXCOORD_0);\r\n\t\t\tuvs = accessor.getArray();\r\n\t\t\tdefines.HAS_UV = true;\r\n\t\t}\r\n\t\tlet uv1s = null;\r\n\t\tif (primitive.attributes.TEXCOORD_1 !== undefined) {\r\n\t\t\taccessor = this.getAccessor(primitive.attributes.TEXCOORD_1);\r\n\t\t\tuv1s = accessor.getArray();\r\n\t\t\tdefines.HAS_UV1 = true;\r\n\t\t}\r\n\r\n\t\tlet tangents = null;\r\n\t\tif (primitive.attributes.TANGENT !== undefined && primitive.attributes.NORMAL !== undefined) {\r\n\t\t\taccessor = this.getAccessor(primitive.attributes.TANGENT);\r\n\t\t\ttangents = accessor.getArray();\r\n\t\t\t// defines.HAS_TANGENT = true;\r\n\t\t} else if (material.normalTexture) {\r\n\t\t\t// tangents = generateTangents(indices, positions, normals, uvs!);\r\n\t\t}\r\n\t\tlet colors = null;\r\n\t\tif (primitive.attributes.COLOR_0 !== undefined) {\r\n\t\t\tcolors = this.accessors[primitive.attributes.COLOR_0];\r\n\t\t\tdefines.HAS_COLOR = true;\r\n\t\t}\r\n\t\tlet joints = null;\r\n\t\tif (primitive.attributes.JOINTS_0 !== undefined) {\r\n\t\t\taccessor = this.getAccessor(primitive.attributes.JOINTS_0);\r\n\t\t\tjoints = accessor.getArray();\r\n\t\t\tdefines.HAS_SKIN = true;\r\n\t\t}\r\n\t\tlet weights = null;\r\n\t\tif (primitive.attributes.WEIGHTS_0 !== undefined) {\r\n\t\t\taccessor = this.getAccessor(primitive.attributes.WEIGHTS_0);\r\n\t\t\tweights = accessor.getArray();\r\n\t\t}\r\n\t\tconst geo = new Geometry({ type: \"pbrGeomtry\" });\r\n\t\tif (indices) geo.setIndice(Array.from(indices));\r\n\t\tif (positions) geo.setAttribute(new Float32Attribute(\"position\", Array.from(positions), 3));\r\n\t\tif (normals) geo.setAttribute(new Float32Attribute(\"normal\", Array.from(normals), 3));\r\n\t\tif (colors) geo.setAttribute(new Float32Attribute(\"color\", Array.from(colors), 3));\r\n\t\tif (uvs) geo.setAttribute(new Float32Attribute(\"uv\", Array.from(uvs), 2));\r\n\t\tif (joints) geo.setAttribute(new Float32Attribute(\"joint0\", Array.from(joints), 4));\r\n\t\tif (weights) geo.setAttribute(new Float32Attribute(\"weight0\", Array.from(weights), 4));\r\n\t\tgeo.defines = defines;\r\n\t\tgeo.computeBoundingSphere(Array.from(positions));\r\n\t\tgeo.count = vertexCount;\r\n\t\treturn geo;\r\n\t}\r\n\tprivate createTexture(source: number) {\r\n\t\treturn new Texture({\r\n\t\t\tsize: {\r\n\t\t\t\twidth: this.images[source].width,\r\n\t\t\t\theight: this.images[source].height,\r\n\t\t\t\tdepth: 1\r\n\t\t\t},\r\n\t\t\tdata: {\r\n\t\t\t\tsource: this.images[source]\r\n\t\t\t},\r\n\t\t\tformat: \"rgba8unorm\",\r\n\t\t\tusage: GPUTextureUsage.TEXTURE_BINDING | GPUTextureUsage.COPY_DST | GPUTextureUsage.RENDER_ATTACHMENT\r\n\t\t});\r\n\t}\r\n\tprivate async loadImages() {\r\n\t\tconst images: Array<ImageBitmap> = [];\r\n\t\tlet loadExternalImages: Promise<any> = Promise.resolve();\r\n\t\tif (this.json.images) {\r\n\t\t\tloadExternalImages = Promise.all(\r\n\t\t\t\tthis.json.images.map(async (image: any, index: number) => {\r\n\t\t\t\t\tif (image.uri) {\r\n\t\t\t\t\t\tconst imageUrl = image.uri.slice(0, 5) === \"data:\" ? image.uri : `${this.rootUrl}/${image.uri}`;\r\n\t\t\t\t\t\timages[index] = await fetch(imageUrl)\r\n\t\t\t\t\t\t\t.then((response) => response.blob())\r\n\t\t\t\t\t\t\t.then((blob) =>\r\n\t\t\t\t\t\t\t\tcreateImageBitmap(blob, {\r\n\t\t\t\t\t\t\t\t\tcolorSpaceConversion: \"none\"\r\n\t\t\t\t\t\t\t\t})\r\n\t\t\t\t\t\t\t);\r\n\t\t\t\t\t}\r\n\t\t\t\t})\r\n\t\t\t);\r\n\t\t}\r\n\t\tlet loadInternalImages: Promise<any> = Promise.resolve();\r\n\t\tif (this.json.images) {\r\n\t\t\tloadInternalImages = Promise.all(\r\n\t\t\t\tthis.json.images.map(async (image: any, index: number) => {\r\n\t\t\t\t\tif (image.bufferView !== undefined) {\r\n\t\t\t\t\t\tconst { buffer, byteOffset, byteLength } = this.json.bufferViews[image.bufferView];\r\n\t\t\t\t\t\tconst array = new Uint8Array(\r\n\t\t\t\t\t\t\tthis.buffers[buffer],\r\n\t\t\t\t\t\t\tbuffer === 0 ? byteOffset + this.glbOffset : byteOffset,\r\n\t\t\t\t\t\t\tbyteLength\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\t\tlet type;\r\n\t\t\t\t\t\tif (image.mimeType) {\r\n\t\t\t\t\t\t\ttype = image.mimeType;\r\n\t\t\t\t\t\t} else {\r\n\t\t\t\t\t\t\ttype = array[0] === 0xff ? \"image/jpeg\" : \"image/png\";\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t\tconst blob = new Blob([array], { type });\r\n\t\t\t\t\t\timages[index] = await createImageBitmap(blob, {\r\n\t\t\t\t\t\t\tcolorSpaceConversion: \"none\"\r\n\t\t\t\t\t\t});\r\n\t\t\t\t\t}\r\n\t\t\t\t})\r\n\t\t\t);\r\n\t\t}\r\n\r\n\t\tawait Promise.all([loadExternalImages, loadInternalImages]);\r\n\t\treturn images;\r\n\t}\r\n\tprivate async loadBuffes() {\r\n\t\tconst buffers: Array<ArrayBuffer> = [];\r\n\t\tawait Promise.all(\r\n\t\t\tthis.json.buffers.map((buffer: any, index: number) => {\r\n\t\t\t\tif (!buffer.uri) {\r\n\t\t\t\t\tif (index !== 0) {\r\n\t\t\t\t\t\tthrow new Error(\"buffer uri undefined\");\r\n\t\t\t\t\t}\r\n\t\t\t\t\tbuffers[index] = this.glbBin!;\r\n\t\t\t\t\treturn Promise.resolve();\r\n\t\t\t\t}\r\n\t\t\t\tconst bufferUrl = buffer.uri.slice(0, 5) === \"data:\" ? buffer.uri : `${this.rootUrl}/${buffer.uri}`;\r\n\t\t\t\treturn fetch(bufferUrl)\r\n\t\t\t\t\t.then((response) => response.arrayBuffer())\r\n\t\t\t\t\t.then((arrayBuffer: ArrayBuffer) => {\r\n\t\t\t\t\t\tbuffers[index] = arrayBuffer;\r\n\t\t\t\t\t});\r\n\t\t\t})\r\n\t\t);\r\n\t\treturn buffers;\r\n\t}\r\n\tprivate parseNodes() {\r\n\t\tthis.nodes = this?.json?.nodes?.map((gltfNode) => {\r\n\t\t\tconst node = new Node();\r\n\t\t\tthis.parseNodeTRS(node, gltfNode);\r\n\t\t\tif (gltfNode.name) node.name = gltfNode.name;\r\n\t\t\tif (gltfNode.mesh != undefined) {\r\n\t\t\t\tlet gltfSkin = undefined,\r\n\t\t\t\t\tisSkinMesh = false;\r\n\t\t\t\tif (gltfNode.skin != undefined) {\r\n\t\t\t\t\tgltfSkin = this.json.skins[gltfNode.skin];\r\n\t\t\t\t\tisSkinMesh = true;\r\n\t\t\t\t}\r\n\t\t\t\tthis.meshes[gltfNode.mesh].primitives.forEach((primitive: Mesh, index: number, source: Array<Mesh>) => {\r\n\t\t\t\t\tconst tempPrimitive =\r\n\t\t\t\t\t\tisSkinMesh && primitive.type == RenderObjectType.Mesh\r\n\t\t\t\t\t\t\t? new SKinMesh(primitive.geometry, primitive.material)\r\n\t\t\t\t\t\t\t: primitive;\r\n\t\t\t\t\tif (isSkinMesh && primitive.type == RenderObjectType.Mesh) {\r\n\t\t\t\t\t\tsource[index] = tempPrimitive;\r\n\t\t\t\t\t\ttempPrimitive.setSkinData({\r\n\t\t\t\t\t\t\tinverseBindMatrices: this.getAccessor(gltfSkin.inverseBindMatrices).getMat4Array(),\r\n\t\t\t\t\t\t\tjoints: gltfSkin.joints\r\n\t\t\t\t\t\t\t// name: gltfSkin.name,\r\n\t\t\t\t\t\t\t// skeleton: gltfSkin.skeleton\r\n\t\t\t\t\t\t});\r\n\t\t\t\t\t}\r\n\t\t\t\t\tnode.add(tempPrimitive);\r\n\t\t\t\t});\r\n\t\t\t}\r\n\t\t\treturn node;\r\n\t\t});\r\n\t}\r\n\tprivate parseNodeTRS(node: Node, gltfNode: GLTFNodeParms): Node {\r\n\t\tlet { matrix, rotation, translation, scale } = gltfNode;\r\n\t\tif (matrix) {\r\n\t\t\tconst tempMatrix4 = new Matrix4(),\r\n\t\t\t\ttempScale = new Vector3(),\r\n\t\t\t\ttempTranslation = new Vector3(),\r\n\t\t\t\ttempRotation = new Quaternion();\r\n\t\t\tMatrix4.fromColumnMajorArray(matrix, tempMatrix4);\r\n\t\t\tMatrix4.getScale(tempMatrix4, tempScale);\r\n\t\t\tMatrix4.getTranslation(tempMatrix4, tempTranslation);\r\n\t\t\tMatrix4.getRotation(tempMatrix4, tempRotation);\r\n\t\t\trotation = tempRotation.toArray();\r\n\t\t\ttranslation = tempTranslation.toArray();\r\n\t\t\tscale = tempScale.toArray();\r\n\t\t}\r\n\t\tif (rotation) node.quaternion.set(rotation[0], rotation[1], rotation[2], rotation[3]);\r\n\t\tif (translation) node.position.set(translation[0], translation[1], translation[2]);\r\n\t\tif (scale) node.scale.set(scale[0], scale[1], scale[2]);\r\n\t\treturn node;\r\n\t}\r\n\tprivate normalizeData() {\r\n\t\tthis?.nodes?.map?.((node: Node, index) => {\r\n\t\t\tthis.json?.nodes[index]?.children?.map((nodeId: number) => {\r\n\t\t\t\tconst childNode = this.nodes[nodeId];\r\n\t\t\t\tnode.add(childNode);\r\n\t\t\t});\r\n\t\t});\r\n\t\tthis.meshes.map((mesh) => {\r\n\t\t\tmesh.primitives.map((primitive) => {\r\n\t\t\t\tif (primitive.type == RenderObjectType.SkinMesh)\r\n\t\t\t\t\tprimitive.joints = primitive.joints.map((joint) => {\r\n\t\t\t\t\t\treturn this.nodes[<number>joint];\r\n\t\t\t\t\t});\r\n\t\t\t});\r\n\t\t});\r\n\t}\r\n}\r\nexport async function loadGLTF(url: string) {\r\n\tlet gltf;\r\n\tconst ext = url.split(\".\").pop();\r\n\tconst rootUrl = url.substring(0, url.lastIndexOf(\"/\"));\r\n\tif (ext === \"gltf\") {\r\n\t\tconst json = await fetch(url).then((response) => response.json());\r\n\t\tgltf = new GLTF(json, rootUrl, 0);\r\n\t} else {\r\n\t\tconst glb = await fetch(url).then((response) => response.arrayBuffer());\r\n\t\tconst jsonLength = new Uint32Array(glb, 12, 1)[0];\r\n\t\tconst jsonChunk = new Uint8Array(glb, 20, jsonLength);\r\n\t\tconst json = JSON.parse(new TextDecoder(\"utf-8\").decode(jsonChunk));\r\n\t\tgltf = new GLTF(json, rootUrl, 28 + jsonLength, glb);\r\n\t}\r\n\tawait gltf.parseData();\r\n\treturn gltf;\r\n}\r\ntype GLTFNodeParms = {\r\n\tchildren?: number[];\r\n\tmatrix?: number[];\r\n\tscale?: number[];\r\n\trotation?: number[];\r\n\ttranslation?: number[];\r\n};\r\n","import Texture from \"../render/Texture\";\r\nexport async function loadPbrTexture(brdf, diffuse, specular) {\r\n\tif (!brdf) return;\r\n\tconst brdfTexture = await loadTexture(brdf);\r\n\tconst diffuseTexture = await loadCubeTexture(diffuse);\r\n\tconst specularTexture = await loadCubeTexture(specular);\r\n\treturn {\r\n\t\tbrdfTexture,\r\n\t\tdiffuseTexture,\r\n\t\tspecularTexture\r\n\t};\r\n}\r\nexport async function loadCubeTexture(urls) {\r\n\tconst promises = urls.map((src) => {\r\n\t\tconst img = document.createElement(\"img\");\r\n\t\timg.src = src;\r\n\t\treturn img.decode().then(() => createImageBitmap(img));\r\n\t});\r\n\tconst images = await Promise.all(promises);\r\n\tawait Promise.all(images);\r\n\tconst data = images.map((image, i) => {\r\n\t\treturn {\r\n\t\t\tsource: image,\r\n\t\t\twidth: image.width,\r\n\t\t\theight: image.height,\r\n\t\t\tdepth: 1,\r\n\t\t\tx: 0,\r\n\t\t\ty: 0,\r\n\t\t\tz: i\r\n\t\t};\r\n\t});\r\n\treturn new Texture({\r\n\t\tsize: {\r\n\t\t\twidth: images[0].width,\r\n\t\t\theight: images[0].height,\r\n\t\t\tdepth: 6\r\n\t\t},\r\n\t\tformat: \"rgba8unorm\",\r\n\t\tusage: GPUTextureUsage.TEXTURE_BINDING | GPUTextureUsage.COPY_DST | GPUTextureUsage.RENDER_ATTACHMENT,\r\n\t\tdata,\r\n\t\tviewFormats: \"cube\",\r\n\t\tmipLevelCount: 6,\r\n\t\tneedMipMap: true\r\n\t});\r\n}\r\nexport async function loadTexture(url) {\r\n\tconst img = document.createElement(\"img\");\r\n\timg.src = url;\r\n\tawait img.decode();\r\n\tconst imageBitmap = await createImageBitmap(img);\r\n\tconst baseTexture = new Texture({\r\n\t\tsize: { width: imageBitmap.width, height: imageBitmap.height, depth: 1 },\r\n\t\tdata: {\r\n\t\t\tsource: imageBitmap\r\n\t\t},\r\n\t\tformat: \"rgba8unorm\"\r\n\t});\r\n\treturn baseTexture;\r\n}\r\n","import GMath from \"./Math.js\";\nimport Vector3 from \"./Vector3.js\";\n// from three.js\nclass Spherical {\n\tradius: number;\n\tphi: number;\n\ttheta: number;\n\n\tconstructor(radius = 1, phi = 0, theta = 0) {\n\t\tthis.radius = radius;\n\t\tthis.phi = phi; // polar angle\n\t\tthis.theta = theta; // azimuthal angle\n\n\t\treturn this;\n\t}\n\tset(radius: number, phi: number, theta: number): Spherical {\n\t\tthis.radius = radius;\n\t\tthis.phi = phi;\n\t\tthis.theta = theta;\n\n\t\treturn this;\n\t}\n\tcopy(other: Spherical): Spherical {\n\t\tthis.radius = other.radius;\n\t\tthis.phi = other.phi;\n\t\tthis.theta = other.theta;\n\n\t\treturn this;\n\t}\n\t// restrict phi to be between EPS and PI-EPS\n\tmakeSafe(): Spherical {\n\t\tconst EPS = 0.000001;\n\t\tthis.phi = Math.max(EPS, Math.min(Math.PI - EPS, this.phi));\n\n\t\treturn this;\n\t}\n\n\tsetFromVector3(v: Vector3): Spherical {\n\t\treturn this.setFromCartesianCoords(v.x, v.y, v.z);\n\t}\n\tsetFromCartesianCoords(x: number, y: number, z: number): Spherical {\n\t\tthis.radius = Math.sqrt(x * x + y * y + z * z);\n\n\t\tif (this.radius === 0) {\n\t\t\tthis.theta = 0;\n\t\t\tthis.phi = 0;\n\t\t} else {\n\t\t\tthis.theta = Math.atan2(x, z);\n\t\t\tthis.phi = Math.acos(GMath.clamp(y / this.radius, -1, 1));\n\t\t}\n\n\t\treturn this;\n\t}\n\n\tclone(): Spherical {\n\t\treturn new Spherical(this.radius, this.phi, this.theta);\n\t}\n}\n\nexport { Spherical };\n","import { EventDispatcher } from \"../core/EventDispatcher\";\r\nimport { Quaternion } from \"../math/Quaternion\";\r\nimport { Spherical } from \"../math/Spherical\";\r\nimport Vector2 from \"../math/Vector2\";\r\nimport Vector3 from \"../math/Vector3\";\r\n//from three.js\r\n\r\nconst _changeEvent = { type: \"change\" };\r\nconst _startEvent = { type: \"start\" };\r\nconst _endEvent = { type: \"end\" };\r\n\r\nexport default class OrbitControl extends EventDispatcher {\r\n  domElement: any;\r\n  object: any;\r\n  enabled: boolean;\r\n  target: any;\r\n  minDistance: number;\r\n  maxDistance: number;\r\n  minZoom: number;\r\n  maxZoom: number;\r\n  minPolarAngle: number;\r\n  maxPolarAngle: number;\r\n  minAzimuthAngle: number;\r\n  maxAzimuthAngle: number;\r\n  enableDamping: boolean;\r\n  dampingFactor: number;\r\n  enableZoom: boolean;\r\n  zoomSpeed: number;\r\n  enableRotate: boolean;\r\n  rotateSpeed: number;\r\n  enablePan: boolean;\r\n  panSpeed: number;\r\n  screenSpacePanning: boolean;\r\n  keyPanSpeed: number;\r\n  autoRotate: boolean;\r\n  autoRotateSpeed: number;\r\n  keys: { LEFT: string; UP: string; RIGHT: string; BOTTOM: string };\r\n  mouseButtons: { LEFT: any; MIDDLE: any; RIGHT: any };\r\n  touches: { ONE: any; TWO: any };\r\n  target0: any;\r\n  position0: any;\r\n  zoom0: any;\r\n  private _domElementKeyEvents: any;\r\n  spherical: any;\r\n  onPointerMove: (event: any) => void;\r\n  onPointerUp: (event: any) => void;\r\n  onContextMenu: (event: any) => void;\r\n  onPointerDown: (event: any) => void;\r\n  onMouseWheel: (event: any) => void;\r\n  onKeyDown: (event: any) => void;\r\n  getAutoRotationAngle: () => number;\r\n  update: () => boolean;\r\n  constructor(object, domElement) {\r\n    super();\r\n\r\n    if (domElement === undefined)\r\n      console.warn(\r\n        'OrbitControls: The second parameter \"domElement\" is now mandatory.'\r\n      );\r\n    if (domElement === document)\r\n      console.error(\r\n        'OrbitControls: \"document\" should not be used as the target \"domElement\". Please use \"renderer.domElement\" instead.'\r\n      );\r\n\r\n    this.object = object;\r\n    this.domElement = domElement;\r\n    this.domElement.style.touchAction = \"none\"; // disable touch scroll\r\n\r\n    // Set to false to disable this control\r\n    this.enabled = true;\r\n\r\n    // \"target\" sets the location of focus, where the object orbits around\r\n    this.target = new Vector3();\r\n\r\n    // How far you can dolly in and out ( PerspectiveCamera only )\r\n    this.minDistance = 0;\r\n    this.maxDistance = Infinity;\r\n\r\n    // How far you can zoom in and out ( OrthographicCamera only )\r\n    this.minZoom = 0;\r\n    this.maxZoom = Infinity;\r\n\r\n    // How far you can orbit vertically, upper and lower limits.\r\n    // Range is 0 to Math.PI radians.\r\n    this.minPolarAngle = 0; // radians\r\n    this.maxPolarAngle = Math.PI; // radians\r\n\r\n    // How far you can orbit horizontally, upper and lower limits.\r\n    // If set, the interval [ min, max ] must be a sub-interval of [ - 2 PI, 2 PI ], with ( max - min < 2 PI )\r\n    this.minAzimuthAngle = -Infinity; // radians\r\n    this.maxAzimuthAngle = Infinity; // radians\r\n\r\n    // Set to true to enable damping (inertia)\r\n    // If damping is enabled, you must call controls.update() in your animation loop\r\n    this.enableDamping = false;\r\n    this.dampingFactor = 0.05;\r\n\r\n    // This option actually enables dollying in and out; left as \"zoom\" for backwards compatibility.\r\n    // Set to false to disable zooming\r\n    this.enableZoom = true;\r\n    this.zoomSpeed = 1.0;\r\n\r\n    // Set to false to disable rotating\r\n    this.enableRotate = true;\r\n    this.rotateSpeed = 1.0;\r\n\r\n    // Set to false to disable panning\r\n    this.enablePan = true;\r\n    this.panSpeed = 1.0;\r\n    this.screenSpacePanning = false; // if false, pan orthogonal to world-space direction camera.up\r\n    this.keyPanSpeed = 7.0; // pixels moved per arrow key push\r\n\r\n    // Set to true to automatically rotate around the target\r\n    // If auto-rotate is enabled, you must call controls.update() in your animation loop\r\n    this.autoRotate = false;\r\n    this.autoRotateSpeed = 2.0; // 30 seconds per orbit when fps is 60\r\n\r\n    // The four arrow keys\r\n    this.keys = {\r\n      LEFT: \"ArrowLeft\",\r\n      UP: \"ArrowUp\",\r\n      RIGHT: \"ArrowRight\",\r\n      BOTTOM: \"ArrowDown\",\r\n    };\r\n\r\n    // Mouse buttons\r\n    this.mouseButtons = {\r\n      LEFT: MOUSE.ROTATE,\r\n      MIDDLE: MOUSE.DOLLY,\r\n      RIGHT: MOUSE.PAN,\r\n    };\r\n\r\n    // Touch fingers\r\n    this.touches = { ONE: TOUCH.ROTATE, TWO: TOUCH.DOLLY_PAN };\r\n\r\n    // for reset\r\n    this.target0 = this.target.clone();\r\n    this.position0 = this.object.position.clone();\r\n    this.zoom0 = this.object.zoom;\r\n\r\n    // the target DOM element for key events\r\n    this._domElementKeyEvents = null;\r\n\r\n    //\r\n    // public methods\r\n    //\r\n    // this method is exposed, but perhaps it would be better if we can make it private...\r\n    const that = this;\r\n    this.update = (function () {\r\n      const offset = new Vector3();\r\n      // so camera.up is the orbit axis\r\n      const quat = new Quaternion().setFromUnitVectors(\r\n        that.object.up,\r\n        new Vector3(0, 1, 0)\r\n      );\r\n      const quatInverse = quat.clone().invert();\r\n\r\n      const lastPosition = new Vector3();\r\n      const lastQuaternion = new Quaternion();\r\n\r\n      const twoPI = 2 * Math.PI;\r\n      return function update() {\r\n        const position = that.object.position;\r\n\r\n        offset.copy(position).subtract(that.target);\r\n\r\n        // rotate offset to \"y-axis-is-up\" space\r\n        offset.applyQuaternion(quat);\r\n\r\n        // angle from z-axis around y-axis\r\n        spherical.setFromVector3(offset);\r\n\r\n        if (that.autoRotate && state === STATE.NONE) {\r\n          rotateLeft(that.getAutoRotationAngle());\r\n        }\r\n\r\n        if (that.enableDamping) {\r\n          spherical.theta += sphericalDelta.theta * that.dampingFactor;\r\n          spherical.phi += sphericalDelta.phi * that.dampingFactor;\r\n        } else {\r\n          spherical.theta += sphericalDelta.theta;\r\n          spherical.phi += sphericalDelta.phi;\r\n        }\r\n\r\n        // restrict theta to be between desired limits\r\n\r\n        let min = that.minAzimuthAngle;\r\n        let max = that.maxAzimuthAngle;\r\n\r\n        if (isFinite(min) && isFinite(max)) {\r\n          if (min < -Math.PI) min += twoPI;\r\n          else if (min > Math.PI) min -= twoPI;\r\n\r\n          if (max < -Math.PI) max += twoPI;\r\n          else if (max > Math.PI) max -= twoPI;\r\n\r\n          if (min <= max) {\r\n            spherical.theta = Math.max(min, Math.min(max, spherical.theta));\r\n          } else {\r\n            spherical.theta =\r\n              spherical.theta > (min + max) / 2\r\n                ? Math.max(min, spherical.theta)\r\n                : Math.min(max, spherical.theta);\r\n          }\r\n        }\r\n\r\n        // restrict phi to be between desired limits\r\n        spherical.phi = Math.max(\r\n          that.minPolarAngle,\r\n          Math.min(that.maxPolarAngle, spherical.phi)\r\n        );\r\n\r\n        spherical.makeSafe();\r\n\r\n        spherical.radius *= scale;\r\n\r\n        // restrict radius to be between desired limits\r\n        spherical.radius = Math.max(\r\n          that.minDistance,\r\n          Math.min(that.maxDistance, spherical.radius)\r\n        );\r\n\r\n        // move target to panned location\r\n\r\n        if (that.enableDamping === true) {\r\n          that.target.addScaledVector(panOffset, that.dampingFactor);\r\n        } else {\r\n          that.target.add(panOffset);\r\n        }\r\n        Vector3.fromSpherical(spherical, offset);\r\n        // rotate offset back to \"camera-up-vector-is-up\" space\r\n        offset.applyQuaternion(quatInverse);\r\n\r\n        position.copy(that.target).add(offset);\r\n\r\n        that.object.lookAt(that.target.x, that.target.y, that.target.z);\r\n\r\n        if (that.enableDamping === true) {\r\n          sphericalDelta.theta *= 1 - that.dampingFactor;\r\n          sphericalDelta.phi *= 1 - that.dampingFactor;\r\n\r\n          Vector3.multiplyByScalar(\r\n            panOffset,\r\n            1 - that.dampingFactor,\r\n            panOffset\r\n          );\r\n          // panOffset.multiplyScalar( 1 - this.dampingFactor );\r\n        } else {\r\n          sphericalDelta.set(0, 0, 0);\r\n\r\n          panOffset.set(0, 0, 0);\r\n        }\r\n\r\n        scale = 1;\r\n\r\n        // update condition is:\r\n        // min(camera displacement, camera rotation in radians)^2 > EPS\r\n        // using small-angle approximation cos(x/2) = 1 - x^2 / 8\r\n\r\n        if (\r\n          zoomChanged ||\r\n          Vector3.distanceSquared(lastPosition, that.object.position) > EPS ||\r\n          8 * (1 - lastQuaternion.dot(that.object.quaternion)) > EPS\r\n        ) {\r\n          that.dispatchEvent(_changeEvent);\r\n\r\n          //lastPosition.copy( this.object.position );\r\n          Vector3.clone(that.object.position, lastPosition);\r\n          Quaternion.clone(that.object.quaternion, lastQuaternion);\r\n          //lastQuaternion.copy( this.object.quaternion );\r\n          zoomChanged = false;\r\n\r\n          return true;\r\n        }\r\n\r\n        return false;\r\n      };\r\n    })();\r\n    this.init();\r\n  }\r\n  getPolarAngle() {\r\n    return this.spherical.phi;\r\n  }\r\n  getAzimuthalAngle() {\r\n    return this.spherical.theta;\r\n  }\r\n\r\n  getDistance() {\r\n    return Vector3.distance(this.object.position, this.target);\r\n  }\r\n\r\n  listenToKeyEvents(domElement) {\r\n    domElement.addEventListener(\"keydown\", this.onKeyDown);\r\n    this._domElementKeyEvents = domElement;\r\n  }\r\n\r\n  saveState() {\r\n    Vector3.clone(this.target, this.target0);\r\n    //this.target0.copy( this.target );\r\n    Vector3.clone(this.object.position, this.position0);\r\n    //this.position0.copy( this.object.position );\r\n    this.zoom0 = this.object.zoom;\r\n  }\r\n\r\n  reset() {\r\n    Vector3.clone(this.target0, this.target);\r\n    //this.target.copy( this.target0 );\r\n    Vector3.clone(this.position0, this.object.position);\r\n    //this.object.position.copy( this.position0 );\r\n    this.object.zoom = this.zoom0;\r\n\r\n    this.object.updateProjectionMatrix();\r\n    this.dispatchEvent(_changeEvent);\r\n\r\n    this.update();\r\n\r\n    state = STATE.NONE;\r\n  }\r\n\r\n  private init() {\r\n    const that = this;\r\n    const panLeft = (function () {\r\n      const v = new Vector3();\r\n      return function panLeft(distance, objectMatrix) {\r\n        v.setFromMatrixColumn(objectMatrix, 0); // get X column of objectMatrix\r\n        v.multiplyByScalar(-distance);\r\n        panOffset.add(v);\r\n      };\r\n    })();\r\n    const panUp = (function () {\r\n      const panUpV = new Vector3();\r\n      return function panUp(distance, objectMatrix) {\r\n        if (that.screenSpacePanning === true) {\r\n          panUpV.setFromMatrixColumn(objectMatrix, 1);\r\n        } else {\r\n          panUpV.setFromMatrixColumn(objectMatrix, 0);\r\n          //panUpV.crossVectors( this.object.up, panUpV );\r\n          Vector3.cross(that.object.up, panUpV, panUpV);\r\n        }\r\n\r\n        panUpV.multiplyByScalar(distance);\r\n\r\n        panOffset.add(panUpV);\r\n      };\r\n    })();\r\n    // deltaX and deltaY are in pixels; right and down are positive\r\n    const pan = (function () {\r\n      const offset = new Vector3();\r\n      return function pan(deltaX, deltaY) {\r\n        const element = that.domElement;\r\n        if (that.object.isPerspectiveCamera) {\r\n          // perspective\r\n          const position = that.object.position;\r\n          offset.copy(position).subtract(that.target);\r\n          let targetDistance = offset.length();\r\n\r\n          // half of the fov is center to top of screen\r\n          targetDistance *= Math.tan(((that.object.fov / 2) * Math.PI) / 180.0);\r\n\r\n          // we use only clientHeight here so aspect ratio does not distort speed\r\n          panLeft(\r\n            (2 * deltaX * targetDistance) / element.clientHeight,\r\n            that.object.modelMatrix\r\n          );\r\n          panUp(\r\n            (2 * deltaY * targetDistance) / element.clientHeight,\r\n            that.object.modelMatrix\r\n          );\r\n        } else if (that.object.isOrthographicCamera) {\r\n          // orthographic\r\n          panLeft(\r\n            (deltaX * (that.object.right - that.object.left)) /\r\n              that.object.zoom /\r\n              element.clientWidth,\r\n            that.object.modelMatrix\r\n          );\r\n          panUp(\r\n            (deltaY * (that.object.top - that.object.bottom)) /\r\n              that.object.zoom /\r\n              element.clientHeight,\r\n            that.object.modelMatrix\r\n          );\r\n        } else {\r\n          // camera neither orthographic nor perspective\r\n          console.warn(\r\n            \"WARNING: OrbitControls.js encountered an unknown camera type - pan disabled.\"\r\n          );\r\n          that.enablePan = false;\r\n        }\r\n      };\r\n    })();\r\n    const dollyOut = (dollyScale) => {\r\n      if (this.object.isPerspectiveCamera) {\r\n        scale /= dollyScale;\r\n      } else if (this.object.isOrthographicCamera) {\r\n        this.object.zoom = Math.max(\r\n          this.minZoom,\r\n          Math.min(this.maxZoom, this.object.zoom * dollyScale)\r\n        );\r\n        this.object.updateProjectionMatrix();\r\n        zoomChanged = true;\r\n      } else {\r\n        console.warn(\r\n          \"WARNING: OrbitControls.js encountered an unknown camera type - dolly/zoom disabled.\"\r\n        );\r\n        this.enableZoom = false;\r\n      }\r\n    };\r\n\r\n    const dollyIn = (dollyScale) => {\r\n      if (this.object.isPerspectiveCamera) {\r\n        scale *= dollyScale;\r\n      } else if (this.object.isOrthographicCamera) {\r\n        this.object.zoom = Math.max(\r\n          this.minZoom,\r\n          Math.min(this.maxZoom, this.object.zoom / dollyScale)\r\n        );\r\n        this.object.updateProjectionMatrix();\r\n        zoomChanged = true;\r\n      } else {\r\n        console.warn(\r\n          \"WARNING: OrbitControls.js encountered an unknown camera type - dolly/zoom disabled.\"\r\n        );\r\n        this.enableZoom = false;\r\n      }\r\n    };\r\n    const handleMouseMoveRotate = (event) => {\r\n      rotateEnd.set(event.clientX, event.clientY);\r\n\r\n      Vector2.subtract(rotateEnd, rotateStart, rotateDelta);\r\n      Vector2.multiplyByScalar(rotateDelta, this.rotateSpeed, rotateDelta);\r\n      //rotateDelta.subVectors( rotateEnd, rotateStart ).multiplyScalar( this.rotateSpeed );\r\n\r\n      const element = this.domElement;\r\n\r\n      rotateLeft((2 * Math.PI * rotateDelta.x) / element.clientHeight); // yes, height\r\n\r\n      rotateUp((2 * Math.PI * rotateDelta.y) / element.clientHeight);\r\n\r\n      Vector2.clone(rotateEnd, rotateStart);\r\n      //rotateStart.copy( rotateEnd );\r\n\r\n      this.update();\r\n    };\r\n\r\n    const handleMouseMoveDolly = (event) => {\r\n      dollyEnd.set(event.clientX, event.clientY);\r\n\r\n      Vector2.subtract(dollyEnd, dollyStart, dollyDelta);\r\n      // dollyDelta.subVectors( dollyEnd, dollyStart );\r\n\r\n      if (dollyDelta.y > 0) {\r\n        dollyOut(getZoomScale());\r\n      } else if (dollyDelta.y < 0) {\r\n        dollyIn(getZoomScale());\r\n      }\r\n\r\n      Vector2.clone(dollyEnd, dollyStart);\r\n      // dollyStart.copy( dollyEnd );\r\n\r\n      this.update();\r\n    };\r\n\r\n    const handleMouseMovePan = (event) => {\r\n      panEnd.set(event.clientX, event.clientY);\r\n\r\n      Vector2.subtract(panEnd, panStart, panDelta);\r\n      Vector2.multiplyByScalar(panDelta, this.panSpeed, panDelta);\r\n      //panDelta.subVectors( panEnd, panStart ).multiplyScalar( this.panSpeed );\r\n\r\n      pan(panDelta.x, panDelta.y);\r\n\r\n      Vector2.clone(panEnd, panStart);\r\n      //panStart.copy( panEnd );\r\n\r\n      this.update();\r\n    };\r\n\r\n    const handleMouseWheel = (event) => {\r\n      if (event.deltaY < 0) {\r\n        dollyIn(getZoomScale());\r\n      } else if (event.deltaY > 0) {\r\n        dollyOut(getZoomScale());\r\n      }\r\n\r\n      this.update();\r\n    };\r\n\r\n    const handleKeyDown = (event) => {\r\n      let needsUpdate = false;\r\n\r\n      switch (event.code) {\r\n        case this.keys.UP:\r\n          pan(0, this.keyPanSpeed);\r\n          needsUpdate = true;\r\n          break;\r\n\r\n        case this.keys.BOTTOM:\r\n          pan(0, -this.keyPanSpeed);\r\n          needsUpdate = true;\r\n          break;\r\n\r\n        case this.keys.LEFT:\r\n          pan(this.keyPanSpeed, 0);\r\n          needsUpdate = true;\r\n          break;\r\n\r\n        case this.keys.RIGHT:\r\n          pan(-this.keyPanSpeed, 0);\r\n          needsUpdate = true;\r\n          break;\r\n      }\r\n\r\n      if (needsUpdate) {\r\n        // prevent the browser from scrolling on cursor keys\r\n        event.preventDefault();\r\n\r\n        this.update();\r\n      }\r\n    };\r\n\r\n    const handleTouchStartDollyPan = () => {\r\n      if (this.enableZoom) handleTouchStartDolly();\r\n\r\n      if (this.enablePan) handleTouchStartPan();\r\n    };\r\n    const handleTouchStartDollyRotate = () => {\r\n      if (this.enableZoom) handleTouchStartDolly();\r\n\r\n      if (this.enableRotate) handleTouchStartRotate();\r\n    };\r\n\r\n    const handleTouchMoveRotate = (event) => {\r\n      if (pointers.length == 1) {\r\n        rotateEnd.set(event.pageX, event.pageY);\r\n      } else {\r\n        const position = getSecondPointerPosition(event);\r\n\r\n        const x = 0.5 * (event.pageX + position.x);\r\n        const y = 0.5 * (event.pageY + position.y);\r\n\r\n        rotateEnd.set(x, y);\r\n      }\r\n\r\n      Vector2.subtract(rotateEnd, rotateStart, rotateDelta);\r\n      Vector2.multiplyByScalar(rotateDelta, this.rotateSpeed, rotateDelta);\r\n      //rotateDelta.subVectors( rotateEnd, rotateStart ).multiplyScalar( this.rotateSpeed );\r\n\r\n      const element = this.domElement;\r\n\r\n      rotateLeft((2 * Math.PI * rotateDelta.x) / element.clientHeight); // yes, height\r\n\r\n      rotateUp((2 * Math.PI * rotateDelta.y) / element.clientHeight);\r\n      Vector2.clone(rotateEnd, rotateStart);\r\n      //rotateStart.copy( rotateEnd );\r\n    };\r\n\r\n    const handleTouchMovePan = (event) => {\r\n      if (pointers.length === 1) {\r\n        panEnd.set(event.pageX, event.pageY);\r\n      } else {\r\n        const position = getSecondPointerPosition(event);\r\n\r\n        const x = 0.5 * (event.pageX + position.x);\r\n        const y = 0.5 * (event.pageY + position.y);\r\n\r\n        panEnd.set(x, y);\r\n      }\r\n      Vector2.subtract(panEnd, panStart, panDelta);\r\n      Vector2.multiplyByScalar(panDelta, this.panSpeed, panDelta);\r\n\r\n      //panDelta.subVectors( panEnd, panStart ).multiplyScalar( this.panSpeed );\r\n\r\n      pan(panDelta.x, panDelta.y);\r\n\r\n      Vector2.clone(panEnd, panStart);\r\n      // panStart.copy( panEnd );\r\n    };\r\n\r\n    const handleTouchMoveDolly = (event) => {\r\n      const position = getSecondPointerPosition(event);\r\n\r\n      const dx = event.pageX - position.x;\r\n      const dy = event.pageY - position.y;\r\n\r\n      const distance = Math.sqrt(dx * dx + dy * dy);\r\n\r\n      dollyEnd.set(0, distance);\r\n\r\n      dollyDelta.set(0, Math.pow(dollyEnd.y / dollyStart.y, this.zoomSpeed));\r\n\r\n      dollyOut(dollyDelta.y);\r\n\r\n      Vector2.clone(dollyEnd, dollyStart);\r\n      //dollyStart.copy( dollyEnd );\r\n    };\r\n\r\n    const handleTouchMoveDollyPan = (event) => {\r\n      if (this.enableZoom) handleTouchMoveDolly(event);\r\n\r\n      if (this.enablePan) handleTouchMovePan(event);\r\n    };\r\n\r\n    const handleTouchMoveDollyRotate = (event) => {\r\n      if (this.enableZoom) handleTouchMoveDolly(event);\r\n\r\n      if (this.enableRotate) handleTouchMoveRotate(event);\r\n    };\r\n\r\n    //\r\n    // event handlers - FSM: listen for events and reset state\r\n    //\r\n\r\n    this.onPointerDown = (event) => {\r\n      if (this.enabled === false) return;\r\n\r\n      if (pointers.length === 0) {\r\n        this.domElement.setPointerCapture(event.pointerId);\r\n\r\n        this.domElement.addEventListener(\"pointermove\", this.onPointerMove);\r\n        this.domElement.addEventListener(\"pointerup\", this.onPointerUp);\r\n      }\r\n\r\n      //\r\n\r\n      addPointer(event);\r\n\r\n      if (event.pointerType === \"touch\") {\r\n        onTouchStart(event);\r\n      } else {\r\n        onMouseDown(event);\r\n      }\r\n    };\r\n\r\n    this.onPointerMove = (event) => {\r\n      if (this.enabled === false) return;\r\n\r\n      if (event.pointerType === \"touch\") {\r\n        onTouchMove(event);\r\n      } else {\r\n        onMouseMove(event);\r\n      }\r\n    };\r\n\r\n    this.onPointerUp = (event) => {\r\n      removePointer(event);\r\n\r\n      if (pointers.length === 0) {\r\n        this.domElement.releasePointerCapture(event.pointerId);\r\n\r\n        this.domElement.removeEventListener(\"pointermove\", this.onPointerMove);\r\n        this.domElement.removeEventListener(\"pointerup\", this.onPointerUp);\r\n      }\r\n\r\n      this.dispatchEvent(_endEvent);\r\n\r\n      state = STATE.NONE;\r\n    };\r\n\r\n    const onMouseDown = (event) => {\r\n      let mouseAction;\r\n\r\n      switch (event.button) {\r\n        case 0:\r\n          mouseAction = this.mouseButtons.LEFT;\r\n          break;\r\n\r\n        case 1:\r\n          mouseAction = this.mouseButtons.MIDDLE;\r\n          break;\r\n\r\n        case 2:\r\n          mouseAction = this.mouseButtons.RIGHT;\r\n          break;\r\n\r\n        default:\r\n          mouseAction = -1;\r\n      }\r\n\r\n      switch (mouseAction) {\r\n        case MOUSE.DOLLY:\r\n          if (this.enableZoom === false) return;\r\n\r\n          handleMouseDownDolly(event);\r\n\r\n          state = STATE.DOLLY;\r\n\r\n          break;\r\n\r\n        case MOUSE.ROTATE:\r\n          if (event.ctrlKey || event.metaKey || event.shiftKey) {\r\n            if (this.enablePan === false) return;\r\n\r\n            handleMouseDownPan(event);\r\n\r\n            state = STATE.PAN;\r\n          } else {\r\n            if (this.enableRotate === false) return;\r\n\r\n            handleMouseDownRotate(event);\r\n\r\n            state = STATE.ROTATE;\r\n          }\r\n\r\n          break;\r\n\r\n        case MOUSE.PAN:\r\n          if (event.ctrlKey || event.metaKey || event.shiftKey) {\r\n            if (this.enableRotate === false) return;\r\n\r\n            handleMouseDownRotate(event);\r\n\r\n            state = STATE.ROTATE;\r\n          } else {\r\n            if (this.enablePan === false) return;\r\n\r\n            handleMouseDownPan(event);\r\n\r\n            state = STATE.PAN;\r\n          }\r\n\r\n          break;\r\n\r\n        default:\r\n          state = STATE.NONE;\r\n      }\r\n\r\n      if (state !== STATE.NONE) {\r\n        this.dispatchEvent(_startEvent);\r\n      }\r\n    };\r\n\r\n    const onMouseMove = (event) => {\r\n      switch (state) {\r\n        case STATE.ROTATE:\r\n          if (this.enableRotate === false) return;\r\n\r\n          handleMouseMoveRotate(event);\r\n\r\n          break;\r\n\r\n        case STATE.DOLLY:\r\n          if (this.enableZoom === false) return;\r\n\r\n          handleMouseMoveDolly(event);\r\n\r\n          break;\r\n\r\n        case STATE.PAN:\r\n          if (this.enablePan === false) return;\r\n\r\n          handleMouseMovePan(event);\r\n\r\n          break;\r\n      }\r\n    };\r\n\r\n    this.onMouseWheel = (event) => {\r\n      if (\r\n        this.enabled === false ||\r\n        this.enableZoom === false ||\r\n        state !== STATE.NONE\r\n      )\r\n        return;\r\n\r\n      event.preventDefault();\r\n\r\n      this.dispatchEvent(_startEvent);\r\n\r\n      handleMouseWheel(event);\r\n\r\n      this.dispatchEvent(_endEvent);\r\n    };\r\n\r\n    this.onKeyDown = (event) => {\r\n      if (this.enabled === false || this.enablePan === false) return;\r\n\r\n      handleKeyDown(event);\r\n    };\r\n\r\n    const onTouchStart = (event) => {\r\n      trackPointer(event);\r\n\r\n      switch (pointers.length) {\r\n        case 1:\r\n          switch (this.touches.ONE) {\r\n            case TOUCH.ROTATE:\r\n              if (this.enableRotate === false) return;\r\n\r\n              handleTouchStartRotate();\r\n\r\n              state = STATE.TOUCH_ROTATE;\r\n\r\n              break;\r\n\r\n            case TOUCH.PAN:\r\n              if (this.enablePan === false) return;\r\n\r\n              handleTouchStartPan();\r\n\r\n              state = STATE.TOUCH_PAN;\r\n\r\n              break;\r\n\r\n            default:\r\n              state = STATE.NONE;\r\n          }\r\n\r\n          break;\r\n\r\n        case 2:\r\n          switch (this.touches.TWO) {\r\n            case TOUCH.DOLLY_PAN:\r\n              if (this.enableZoom === false && this.enablePan === false) return;\r\n\r\n              handleTouchStartDollyPan();\r\n\r\n              state = STATE.TOUCH_DOLLY_PAN;\r\n\r\n              break;\r\n\r\n            case TOUCH.DOLLY_ROTATE:\r\n              if (this.enableZoom === false && this.enableRotate === false)\r\n                return;\r\n\r\n              handleTouchStartDollyRotate();\r\n\r\n              state = STATE.TOUCH_DOLLY_ROTATE;\r\n\r\n              break;\r\n\r\n            default:\r\n              state = STATE.NONE;\r\n          }\r\n\r\n          break;\r\n\r\n        default:\r\n          state = STATE.NONE;\r\n      }\r\n\r\n      if (state !== STATE.NONE) {\r\n        this.dispatchEvent(_startEvent);\r\n      }\r\n    };\r\n\r\n    const onTouchMove = (event) => {\r\n      trackPointer(event);\r\n\r\n      switch (state) {\r\n        case STATE.TOUCH_ROTATE:\r\n          if (this.enableRotate === false) return;\r\n\r\n          handleTouchMoveRotate(event);\r\n\r\n          this.update();\r\n\r\n          break;\r\n\r\n        case STATE.TOUCH_PAN:\r\n          if (this.enablePan === false) return;\r\n\r\n          handleTouchMovePan(event);\r\n\r\n          this.update();\r\n\r\n          break;\r\n\r\n        case STATE.TOUCH_DOLLY_PAN:\r\n          if (this.enableZoom === false && this.enablePan === false) return;\r\n\r\n          handleTouchMoveDollyPan(event);\r\n\r\n          this.update();\r\n\r\n          break;\r\n\r\n        case STATE.TOUCH_DOLLY_ROTATE:\r\n          if (this.enableZoom === false && this.enableRotate === false) return;\r\n\r\n          handleTouchMoveDollyRotate(event);\r\n\r\n          this.update();\r\n\r\n          break;\r\n\r\n        default:\r\n          state = STATE.NONE;\r\n      }\r\n    };\r\n\r\n    this.onContextMenu = (event) => {\r\n      if (this.enabled === false) return;\r\n\r\n      event.preventDefault();\r\n    };\r\n    this.getAutoRotationAngle = () => {\r\n      return ((2 * Math.PI) / 60 / 60) * this.autoRotateSpeed;\r\n    };\r\n\r\n    const getZoomScale = () => {\r\n      return Math.pow(0.95, this.zoomSpeed);\r\n    };\r\n    this.domElement.addEventListener(\"contextmenu\", this.onContextMenu);\r\n\r\n    this.domElement.addEventListener(\"pointerdown\", this.onPointerDown);\r\n    this.domElement.addEventListener(\"pointercancel\", onPointerCancel);\r\n    this.domElement.addEventListener(\"wheel\", this.onMouseWheel, {\r\n      passive: false,\r\n    });\r\n  }\r\n  dispose() {\r\n    this.domElement.removeEventListener(\"contextmenu\", this.onContextMenu);\r\n\r\n    this.domElement.removeEventListener(\"pointerdown\", this.onPointerDown);\r\n    this.domElement.removeEventListener(\"pointercancel\", onPointerCancel);\r\n    this.domElement.removeEventListener(\"wheel\", this.onMouseWheel);\r\n\r\n    this.domElement.removeEventListener(\"pointermove\", this.onPointerMove);\r\n    this.domElement.removeEventListener(\"pointerup\", this.onPointerUp);\r\n\r\n    if (this._domElementKeyEvents !== null) {\r\n      this._domElementKeyEvents.removeEventListener(\"keydown\", this.onKeyDown);\r\n    }\r\n\r\n    //this.dispatchEvent( { type: 'dispose' } ); // should this be added here?\r\n  }\r\n}\r\nconst STATE = {\r\n  NONE: -1,\r\n  ROTATE: 0,\r\n  DOLLY: 1,\r\n  PAN: 2,\r\n  TOUCH_ROTATE: 3,\r\n  TOUCH_PAN: 4,\r\n  TOUCH_DOLLY_PAN: 5,\r\n  TOUCH_DOLLY_ROTATE: 6,\r\n};\r\n\r\nlet state = STATE.NONE;\r\n\r\nconst EPS = 0.000001;\r\n\r\n// current position in spherical coordinates\r\nconst spherical = new Spherical();\r\nconst sphericalDelta = new Spherical();\r\n\r\nlet scale = 1;\r\nconst panOffset = new Vector3();\r\nlet zoomChanged = false;\r\n\r\nconst rotateStart = new Vector2();\r\nconst rotateEnd = new Vector2();\r\nconst rotateDelta = new Vector2();\r\n\r\nconst panStart = new Vector2();\r\nconst panEnd = new Vector2();\r\nconst panDelta = new Vector2();\r\n\r\nconst dollyStart = new Vector2();\r\nconst dollyEnd = new Vector2();\r\nconst dollyDelta = new Vector2();\r\n\r\nconst pointers = [];\r\nconst pointerPositions = {};\r\nexport enum MOUSE {\r\n  LEFT = 0,\r\n  MIDDLE = 1,\r\n  RIGHT = 2,\r\n  ROTATE = 0,\r\n  DOLLY = 1,\r\n  PAN = 2,\r\n}\r\n\r\nexport enum TOUCH {\r\n  ROTATE,\r\n  PAN,\r\n  DOLLY_PAN,\r\n  DOLLY_ROTATE,\r\n}\r\nfunction rotateLeft(angle) {\r\n  sphericalDelta.theta -= angle;\r\n}\r\n\r\nfunction rotateUp(angle) {\r\n  sphericalDelta.phi -= angle;\r\n}\r\n\r\nfunction addPointer(event) {\r\n  pointers.push(event);\r\n}\r\n\r\nfunction removePointer(event) {\r\n  delete pointerPositions[event.pointerId];\r\n\r\n  for (let i = 0; i < pointers.length; i++) {\r\n    if (pointers[i].pointerId == event.pointerId) {\r\n      pointers.splice(i, 1);\r\n      return;\r\n    }\r\n  }\r\n}\r\n\r\nfunction trackPointer(event) {\r\n  let position = pointerPositions[event.pointerId];\r\n\r\n  if (position === undefined) {\r\n    position = new Vector2();\r\n    pointerPositions[event.pointerId] = position;\r\n  }\r\n\r\n  position.set(event.pageX, event.pageY);\r\n}\r\n\r\nfunction getSecondPointerPosition(event) {\r\n  const pointer =\r\n    event.pointerId === pointers[0].pointerId ? pointers[1] : pointers[0];\r\n\r\n  return pointerPositions[pointer.pointerId];\r\n}\r\n\r\nfunction handleMouseDownRotate(event) {\r\n  rotateStart.set(event.clientX, event.clientY);\r\n}\r\n\r\nfunction handleMouseDownDolly(event) {\r\n  dollyStart.set(event.clientX, event.clientY);\r\n}\r\n\r\nfunction handleMouseDownPan(event) {\r\n  panStart.set(event.clientX, event.clientY);\r\n}\r\nfunction onPointerCancel(event) {\r\n  removePointer(event);\r\n}\r\nfunction handleTouchStartRotate() {\r\n  if (pointers.length === 1) {\r\n    rotateStart.set(pointers[0].pageX, pointers[0].pageY);\r\n  } else {\r\n    const x = 0.5 * (pointers[0].pageX + pointers[1].pageX);\r\n    const y = 0.5 * (pointers[0].pageY + pointers[1].pageY);\r\n\r\n    rotateStart.set(x, y);\r\n  }\r\n}\r\n\r\nfunction handleTouchStartPan() {\r\n  if (pointers.length === 1) {\r\n    panStart.set(pointers[0].pageX, pointers[0].pageY);\r\n  } else {\r\n    const x = 0.5 * (pointers[0].pageX + pointers[1].pageX);\r\n    const y = 0.5 * (pointers[0].pageY + pointers[1].pageY);\r\n\r\n    panStart.set(x, y);\r\n  }\r\n}\r\n\r\nfunction handleTouchStartDolly() {\r\n  const dx = pointers[0].pageX - pointers[1].pageX;\r\n  const dy = pointers[0].pageY - pointers[1].pageY;\r\n\r\n  const distance = Math.sqrt(dx * dx + dy * dy);\r\n\r\n  dollyStart.set(0, distance);\r\n}\r\n"],"names":["MersenneTwister","distanceScratch","lerpScratch","angleBetweenScratch","angleBetweenScratch2","mostOrthogonalAxisScratch","scaleScratch1","scratchColumn","scaleScratch3","scaleScratch4","scaleScratch5","scratchTransposeMatrix"],"mappings":"AAAA;AACA,IAAY,oBAEX,CAAA;AAFD,CAAA,UAAY,oBAAoB,EAAA;AAC/B,IAAA,oBAAA,CAAA,MAAA,CAAA,GAAA,MAAa,CAAA;AACd,CAAC,EAFW,oBAAoB,KAApB,oBAAoB,GAE/B,EAAA,CAAA,CAAA,CAAA;AAED;AACA,IAAY,eAGX,CAAA;AAHD,CAAA,UAAY,eAAe,EAAA;AAC1B,IAAA,eAAA,CAAA,UAAA,CAAA,GAAA,WAAsB,CAAA;AACtB,IAAA,eAAA,CAAA,iBAAA,CAAA,GAAA,kBAAoC,CAAA;AACrC,CAAC,EAHW,eAAe,KAAf,eAAe,GAG1B,EAAA,CAAA,CAAA,CAAA;AAED;AACA,IAAY,WAWX,CAAA;AAXD,CAAA,UAAY,WAAW,EAAA;AACtB,IAAA,WAAA,CAAA,kBAAA,CAAA,GAAA,oBAAuC,CAAA;AACvC,IAAA,WAAA,CAAA,sBAAA,CAAA,GAAA,uBAA8C,CAAA;AAC9C,IAAA,WAAA,CAAA,sBAAA,CAAA,GAAA,uBAA8C,CAAA;AAC9C,IAAA,WAAA,CAAA,sBAAA,CAAA,GAAA,wBAA+C,CAAA;AAC/C,IAAA,WAAA,CAAA,wBAAA,CAAA,GAAA,0BAAmD,CAAA;AACnD,IAAA,WAAA,CAAA,wBAAA,CAAA,GAAA,0BAAmD,CAAA;AACnD,IAAA,WAAA,CAAA,gBAAA,CAAA,GAAA,iBAAkC,CAAA;AAClC,IAAA,WAAA,CAAA,uBAAA,CAAA,GAAA,yBAAiD,CAAA;AACjD,IAAA,WAAA,CAAA,WAAA,CAAA,GAAA,YAAwB,CAAA;AACxB,IAAA,WAAA,CAAA,mBAAA,CAAA,GAAA,oBAAwC,CAAA;AACzC,CAAC,EAXW,WAAW,KAAX,WAAW,GAWtB,EAAA,CAAA,CAAA,CAAA;AAED;IACY,YAWX;AAXD,CAAA,UAAY,WAAW,EAAA;AACtB,IAAA,WAAA,CAAA,WAAA,CAAA,SAAA,CAAA,GAAA,CAAA,CAAA,GAAA,SAAW,CAAA;AACX,IAAA,WAAA,CAAA,WAAA,CAAA,UAAA,CAAA,GAAA,CAAA,CAAA,GAAA,UAAY,CAAA;AACZ,IAAA,WAAA,CAAA,WAAA,CAAA,SAAA,CAAA,GAAA,CAAA,CAAA,GAAA,SAAW,CAAA;AACX,IAAA,WAAA,CAAA,WAAA,CAAA,SAAA,CAAA,GAAA,CAAA,CAAA,GAAA,SAAW,CAAA;AACX,IAAA,WAAA,CAAA,WAAA,CAAA,OAAA,CAAA,GAAA,EAAA,CAAA,GAAA,OAAU,CAAA;AACV,IAAA,WAAA,CAAA,WAAA,CAAA,QAAA,CAAA,GAAA,EAAA,CAAA,GAAA,QAAW,CAAA;AACX,IAAA,WAAA,CAAA,WAAA,CAAA,SAAA,CAAA,GAAA,EAAA,CAAA,GAAA,SAAY,CAAA;AACZ,IAAA,WAAA,CAAA,WAAA,CAAA,SAAA,CAAA,GAAA,GAAA,CAAA,GAAA,SAAa,CAAA;AACb,IAAA,WAAA,CAAA,WAAA,CAAA,UAAA,CAAA,GAAA,GAAA,CAAA,GAAA,UAAc,CAAA;AACd,IAAA,WAAA,CAAA,WAAA,CAAA,cAAA,CAAA,GAAA,GAAA,CAAA,GAAA,cAAkB,CAAA;AACnB,CAAC,EAXW,WAAW,KAAX,WAAW,GAWtB,EAAA,CAAA,CAAA,CAAA;AAED;AACA,IAAY,OAGX,CAAA;AAHD,CAAA,UAAY,OAAO,EAAA;AAClB,IAAA,OAAA,CAAA,OAAA,CAAA,MAAA,CAAA,GAAA,CAAA,CAAA,GAAA,MAAQ,CAAA;AACR,IAAA,OAAA,CAAA,OAAA,CAAA,OAAA,CAAA,GAAA,CAAA,CAAA,GAAA,OAAS,CAAA;AACV,CAAC,EAHW,OAAO,KAAP,OAAO,GAGlB,EAAA,CAAA,CAAA,CAAA;AAED;IACY,iBAIX;AAJD,CAAA,UAAY,gBAAgB,EAAA;AAC3B,IAAA,gBAAA,CAAA,KAAA,CAAA,GAAA,IAAU,CAAA;AACV,IAAA,gBAAA,CAAA,KAAA,CAAA,GAAA,IAAU,CAAA;AACV,IAAA,gBAAA,CAAA,KAAA,CAAA,GAAA,IAAU,CAAA;AACX,CAAC,EAJW,gBAAgB,KAAhB,gBAAgB,GAI3B,EAAA,CAAA,CAAA,CAAA;AAED;IACY,aAMX;AAND,CAAA,UAAY,YAAY,EAAA;AACvB,IAAA,YAAA,CAAA,YAAA,CAAA,SAAA,CAAA,GAAA,CAAA,CAAA,GAAA,SAAW,CAAA;AACX,IAAA,YAAA,CAAA,YAAA,CAAA,SAAA,CAAA,GAAA,CAAA,CAAA,GAAA,SAAW,CAAA;AACX,IAAA,YAAA,CAAA,YAAA,CAAA,gBAAA,CAAA,GAAA,CAAA,CAAA,GAAA,gBAAkB,CAAA;AAClB,IAAA,YAAA,CAAA,YAAA,CAAA,gBAAA,CAAA,GAAA,CAAA,CAAA,GAAA,gBAAkB,CAAA;AAClB,IAAA,YAAA,CAAA,YAAA,CAAA,kBAAA,CAAA,GAAA,EAAA,CAAA,GAAA,kBAAqB,CAAA;AACtB,CAAC,EANW,YAAY,KAAZ,YAAY,GAMvB,EAAA,CAAA,CAAA,CAAA;AAED;IACY,qBAOX;AAPD,CAAA,UAAY,oBAAoB,EAAA;AAC/B,IAAA,oBAAA,CAAA,KAAA,CAAA,GAAA,IAAU,CAAA;AACV,IAAA,oBAAA,CAAA,KAAA,CAAA,GAAA,IAAU,CAAA;AACV,IAAA,oBAAA,CAAA,UAAA,CAAA,GAAA,UAAqB,CAAA;AACrB,IAAA,oBAAA,CAAA,MAAA,CAAA,GAAA,MAAa,CAAA;AACb,IAAA,oBAAA,CAAA,WAAA,CAAA,GAAA,YAAwB,CAAA;AACxB,IAAA,oBAAA,CAAA,KAAA,CAAA,GAAA,IAAU,CAAA;AACX,CAAC,EAPW,oBAAoB,KAApB,oBAAoB,GAO/B,EAAA,CAAA,CAAA,CAAA;AAED;IACY,cAIX;AAJD,CAAA,UAAY,aAAa,EAAA;AACxB,IAAA,aAAA,CAAA,KAAA,CAAA,GAAA,KAAW,CAAA;AACX,IAAA,aAAA,CAAA,aAAA,CAAA,GAAA,cAA4B,CAAA;AAC5B,IAAA,aAAA,CAAA,WAAA,CAAA,GAAA,YAAwB,CAAA;AACzB,CAAC,EAJW,aAAa,KAAb,aAAa,GAIxB,EAAA,CAAA,CAAA,CAAA;AAED;;;AAGG;IACS,cAyHX;AAzHD,CAAA,UAAY,aAAa,EAAA;;AAExB,IAAA,aAAA,CAAA,SAAA,CAAA,GAAA,SAAmB,CAAA;AACnB,IAAA,aAAA,CAAA,SAAA,CAAA,GAAA,SAAmB,CAAA;AACnB,IAAA,aAAA,CAAA,QAAA,CAAA,GAAA,QAAiB,CAAA;AACjB,IAAA,aAAA,CAAA,QAAA,CAAA,GAAA,QAAiB,CAAA;;AAGjB,IAAA,aAAA,CAAA,SAAA,CAAA,GAAA,SAAmB,CAAA;AACnB,IAAA,aAAA,CAAA,SAAA,CAAA,GAAA,SAAmB,CAAA;AACnB,IAAA,aAAA,CAAA,UAAA,CAAA,GAAA,UAAqB,CAAA;AACrB,IAAA,aAAA,CAAA,UAAA,CAAA,GAAA,UAAqB,CAAA;AACrB,IAAA,aAAA,CAAA,UAAA,CAAA,GAAA,UAAqB,CAAA;AACrB,IAAA,aAAA,CAAA,SAAA,CAAA,GAAA,SAAmB,CAAA;AACnB,IAAA,aAAA,CAAA,SAAA,CAAA,GAAA,SAAmB,CAAA;;AAGnB,IAAA,aAAA,CAAA,SAAA,CAAA,GAAA,SAAmB,CAAA;AACnB,IAAA,aAAA,CAAA,SAAA,CAAA,GAAA,SAAmB,CAAA;AACnB,IAAA,aAAA,CAAA,UAAA,CAAA,GAAA,UAAqB,CAAA;AACrB,IAAA,aAAA,CAAA,UAAA,CAAA,GAAA,UAAqB,CAAA;AACrB,IAAA,aAAA,CAAA,UAAA,CAAA,GAAA,UAAqB,CAAA;AACrB,IAAA,aAAA,CAAA,WAAA,CAAA,GAAA,WAAuB,CAAA;AACvB,IAAA,aAAA,CAAA,YAAA,CAAA,GAAA,YAAyB,CAAA;AACzB,IAAA,aAAA,CAAA,gBAAA,CAAA,GAAA,iBAAkC,CAAA;AAClC,IAAA,aAAA,CAAA,YAAA,CAAA,GAAA,YAAyB,CAAA;AACzB,IAAA,aAAA,CAAA,WAAA,CAAA,GAAA,WAAuB,CAAA;AACvB,IAAA,aAAA,CAAA,WAAA,CAAA,GAAA,WAAuB,CAAA;AACvB,IAAA,aAAA,CAAA,YAAA,CAAA,GAAA,YAAyB,CAAA;AACzB,IAAA,aAAA,CAAA,gBAAA,CAAA,GAAA,iBAAkC,CAAA;;AAElC,IAAA,aAAA,CAAA,cAAA,CAAA,GAAA,cAA6B,CAAA;AAC7B,IAAA,aAAA,CAAA,cAAA,CAAA,GAAA,cAA6B,CAAA;AAC7B,IAAA,aAAA,CAAA,eAAA,CAAA,GAAA,eAA+B,CAAA;;AAG/B,IAAA,aAAA,CAAA,UAAA,CAAA,GAAA,UAAqB,CAAA;AACrB,IAAA,aAAA,CAAA,UAAA,CAAA,GAAA,UAAqB,CAAA;AACrB,IAAA,aAAA,CAAA,WAAA,CAAA,GAAA,WAAuB,CAAA;AACvB,IAAA,aAAA,CAAA,YAAA,CAAA,GAAA,YAAyB,CAAA;AACzB,IAAA,aAAA,CAAA,YAAA,CAAA,GAAA,YAAyB,CAAA;AACzB,IAAA,aAAA,CAAA,aAAA,CAAA,GAAA,aAA2B,CAAA;;AAG3B,IAAA,aAAA,CAAA,YAAA,CAAA,GAAA,YAAyB,CAAA;AACzB,IAAA,aAAA,CAAA,YAAA,CAAA,GAAA,YAAyB,CAAA;AACzB,IAAA,aAAA,CAAA,aAAA,CAAA,GAAA,aAA2B,CAAA;;AAG3B,IAAA,aAAA,CAAA,UAAA,CAAA,GAAA,UAAqB,CAAA;AACrB,IAAA,aAAA,CAAA,cAAA,CAAA,GAAA,cAA6B,CAAA;AAC7B,IAAA,aAAA,CAAA,aAAA,CAAA,GAAA,aAA2B,CAAA;AAC3B,IAAA,aAAA,CAAA,qBAAA,CAAA,GAAA,sBAA4C,CAAA;AAC5C,IAAA,aAAA,CAAA,cAAA,CAAA,GAAA,cAA6B,CAAA;;;AAI7B,IAAA,aAAA,CAAA,cAAA,CAAA,GAAA,gBAA+B,CAAA;AAC/B,IAAA,aAAA,CAAA,kBAAA,CAAA,GAAA,qBAAwC,CAAA;AACxC,IAAA,aAAA,CAAA,cAAA,CAAA,GAAA,gBAA+B,CAAA;AAC/B,IAAA,aAAA,CAAA,kBAAA,CAAA,GAAA,qBAAwC,CAAA;AACxC,IAAA,aAAA,CAAA,cAAA,CAAA,GAAA,gBAA+B,CAAA;AAC/B,IAAA,aAAA,CAAA,kBAAA,CAAA,GAAA,qBAAwC,CAAA;AACxC,IAAA,aAAA,CAAA,WAAA,CAAA,GAAA,aAAyB,CAAA;AACzB,IAAA,aAAA,CAAA,WAAA,CAAA,GAAA,aAAyB,CAAA;AACzB,IAAA,aAAA,CAAA,YAAA,CAAA,GAAA,cAA2B,CAAA;AAC3B,IAAA,aAAA,CAAA,YAAA,CAAA,GAAA,cAA2B,CAAA;AAC3B,IAAA,aAAA,CAAA,eAAA,CAAA,GAAA,iBAAiC,CAAA;AACjC,IAAA,aAAA,CAAA,cAAA,CAAA,GAAA,gBAA+B,CAAA;AAC/B,IAAA,aAAA,CAAA,cAAA,CAAA,GAAA,gBAA+B,CAAA;AAC/B,IAAA,aAAA,CAAA,kBAAA,CAAA,GAAA,qBAAwC,CAAA;;;AAIxC,IAAA,aAAA,CAAA,eAAA,CAAA,GAAA,gBAAgC,CAAA;AAChC,IAAA,aAAA,CAAA,mBAAA,CAAA,GAAA,qBAAyC,CAAA;AACzC,IAAA,aAAA,CAAA,iBAAA,CAAA,GAAA,kBAAoC,CAAA;AACpC,IAAA,aAAA,CAAA,qBAAA,CAAA,GAAA,uBAA6C,CAAA;AAC7C,IAAA,aAAA,CAAA,gBAAA,CAAA,GAAA,iBAAkC,CAAA;AAClC,IAAA,aAAA,CAAA,oBAAA,CAAA,GAAA,sBAA2C,CAAA;AAC3C,IAAA,aAAA,CAAA,aAAA,CAAA,GAAA,cAA4B,CAAA;AAC5B,IAAA,aAAA,CAAA,aAAA,CAAA,GAAA,cAA4B,CAAA;AAC5B,IAAA,aAAA,CAAA,cAAA,CAAA,GAAA,eAA8B,CAAA;AAC9B,IAAA,aAAA,CAAA,cAAA,CAAA,GAAA,eAA8B,CAAA;;;AAI9B,IAAA,aAAA,CAAA,cAAA,CAAA,GAAA,gBAA+B,CAAA;AAC/B,IAAA,aAAA,CAAA,kBAAA,CAAA,GAAA,qBAAwC,CAAA;AACxC,IAAA,aAAA,CAAA,cAAA,CAAA,GAAA,gBAA+B,CAAA;AAC/B,IAAA,aAAA,CAAA,kBAAA,CAAA,GAAA,qBAAwC,CAAA;AACxC,IAAA,aAAA,CAAA,cAAA,CAAA,GAAA,gBAA+B,CAAA;AAC/B,IAAA,aAAA,CAAA,kBAAA,CAAA,GAAA,qBAAwC,CAAA;AACxC,IAAA,aAAA,CAAA,cAAA,CAAA,GAAA,gBAA+B,CAAA;AAC/B,IAAA,aAAA,CAAA,kBAAA,CAAA,GAAA,qBAAwC,CAAA;AACxC,IAAA,aAAA,CAAA,cAAA,CAAA,GAAA,gBAA+B,CAAA;AAC/B,IAAA,aAAA,CAAA,kBAAA,CAAA,GAAA,qBAAwC,CAAA;AACxC,IAAA,aAAA,CAAA,cAAA,CAAA,GAAA,gBAA+B,CAAA;AAC/B,IAAA,aAAA,CAAA,kBAAA,CAAA,GAAA,qBAAwC,CAAA;AACxC,IAAA,aAAA,CAAA,cAAA,CAAA,GAAA,gBAA+B,CAAA;AAC/B,IAAA,aAAA,CAAA,kBAAA,CAAA,GAAA,qBAAwC,CAAA;AACxC,IAAA,aAAA,CAAA,cAAA,CAAA,GAAA,gBAA+B,CAAA;AAC/B,IAAA,aAAA,CAAA,kBAAA,CAAA,GAAA,qBAAwC,CAAA;AACxC,IAAA,aAAA,CAAA,eAAA,CAAA,GAAA,iBAAiC,CAAA;AACjC,IAAA,aAAA,CAAA,mBAAA,CAAA,GAAA,sBAA0C,CAAA;AAC1C,IAAA,aAAA,CAAA,eAAA,CAAA,GAAA,iBAAiC,CAAA;AACjC,IAAA,aAAA,CAAA,mBAAA,CAAA,GAAA,sBAA0C,CAAA;AAC1C,IAAA,aAAA,CAAA,eAAA,CAAA,GAAA,iBAAiC,CAAA;AACjC,IAAA,aAAA,CAAA,mBAAA,CAAA,GAAA,sBAA0C,CAAA;AAC1C,IAAA,aAAA,CAAA,gBAAA,CAAA,GAAA,kBAAmC,CAAA;AACnC,IAAA,aAAA,CAAA,oBAAA,CAAA,GAAA,uBAA4C,CAAA;AAC5C,IAAA,aAAA,CAAA,gBAAA,CAAA,GAAA,kBAAmC,CAAA;AACnC,IAAA,aAAA,CAAA,oBAAA,CAAA,GAAA,uBAA4C,CAAA;AAC5C,IAAA,aAAA,CAAA,gBAAA,CAAA,GAAA,kBAAmC,CAAA;AACnC,IAAA,aAAA,CAAA,oBAAA,CAAA,GAAA,uBAA4C,CAAA;;AAG5C,IAAA,aAAA,CAAA,sBAAA,CAAA,GAAA,uBAA8C,CAAA;;AAG9C,IAAA,aAAA,CAAA,sBAAA,CAAA,GAAA,uBAA8C,CAAA;AAC/C,CAAC,EAzHW,aAAa,KAAb,aAAa,GAyHxB,EAAA,CAAA,CAAA,CAAA;AAED;IACY,YAIX;AAJD,CAAA,UAAY,WAAW,EAAA;AACtB,IAAA,WAAA,CAAA,aAAA,CAAA,GAAA,eAA6B,CAAA;AAC7B,IAAA,WAAA,CAAA,QAAA,CAAA,GAAA,QAAiB,CAAA;AACjB,IAAA,WAAA,CAAA,cAAA,CAAA,GAAA,eAA8B,CAAA;AAC/B,CAAC,EAJW,WAAW,KAAX,WAAW,GAItB,EAAA,CAAA,CAAA,CAAA;AAED;IACY,WAGX;AAHD,CAAA,UAAY,UAAU,EAAA;AACrB,IAAA,UAAA,CAAA,SAAA,CAAA,GAAA,SAAmB,CAAA;AACnB,IAAA,UAAA,CAAA,QAAA,CAAA,GAAA,QAAiB,CAAA;AAClB,CAAC,EAHW,UAAU,KAAV,UAAU,GAGrB,EAAA,CAAA,CAAA,CAAA;AAED;IACY,gBASX;AATD,CAAA,UAAY,eAAe,EAAA;AAC1B,IAAA,eAAA,CAAA,OAAA,CAAA,GAAA,OAAe,CAAA;AACf,IAAA,eAAA,CAAA,MAAA,CAAA,GAAA,MAAa,CAAA;AACb,IAAA,eAAA,CAAA,OAAA,CAAA,GAAA,OAAe,CAAA;AACf,IAAA,eAAA,CAAA,WAAA,CAAA,GAAA,YAAwB,CAAA;AACxB,IAAA,eAAA,CAAA,SAAA,CAAA,GAAA,SAAmB,CAAA;AACnB,IAAA,eAAA,CAAA,UAAA,CAAA,GAAA,WAAsB,CAAA;AACtB,IAAA,eAAA,CAAA,cAAA,CAAA,GAAA,eAA8B,CAAA;AAC9B,IAAA,eAAA,CAAA,QAAA,CAAA,GAAA,QAAiB,CAAA;AAClB,CAAC,EATW,eAAe,KAAf,eAAe,GAS1B,EAAA,CAAA,CAAA,CAAA;AAED;IACY,YAIX;AAJD,CAAA,UAAY,WAAW,EAAA;AACtB,IAAA,WAAA,CAAA,WAAA,CAAA,QAAA,CAAA,GAAA,CAAA,CAAA,GAAA,QAAU,CAAA;AACV,IAAA,WAAA,CAAA,WAAA,CAAA,UAAA,CAAA,GAAA,CAAA,CAAA,GAAA,UAAY,CAAA;AACZ,IAAA,WAAA,CAAA,WAAA,CAAA,SAAA,CAAA,GAAA,CAAA,CAAA,GAAA,SAAW,CAAA;AACZ,CAAC,EAJW,WAAW,KAAX,WAAW,GAItB,EAAA,CAAA,CAAA,CAAA;AAED;AACA,IAAY,iBAIX,CAAA;AAJD,CAAA,UAAY,iBAAiB,EAAA;AAC5B,IAAA,iBAAA,CAAA,SAAA,CAAA,GAAA,SAAmB,CAAA;AACnB,IAAA,iBAAA,CAAA,SAAA,CAAA,GAAA,SAAmB,CAAA;AACnB,IAAA,iBAAA,CAAA,iBAAA,CAAA,GAAA,mBAAqC,CAAA;AACtC,CAAC,EAJW,iBAAiB,KAAjB,iBAAiB,GAI5B,EAAA,CAAA,CAAA,CAAA;AAED;AACA,IAAY,kBAIX,CAAA;AAJD,CAAA,UAAY,kBAAkB,EAAA;AAC7B,IAAA,kBAAA,CAAA,WAAA,CAAA,GAAA,WAAuB,CAAA;AACvB,IAAA,kBAAA,CAAA,cAAA,CAAA,GAAA,eAA8B,CAAA;AAC9B,IAAA,kBAAA,CAAA,YAAA,CAAA,GAAA,YAAyB,CAAA;AAC1B,CAAC,EAJW,kBAAkB,KAAlB,kBAAkB,GAI7B,EAAA,CAAA,CAAA,CAAA;AAED;IACY,kBAMX;AAND,CAAA,UAAY,iBAAiB,EAAA;AAC5B,IAAA,iBAAA,CAAA,OAAA,CAAA,GAAA,OAAe,CAAA;AACf,IAAA,iBAAA,CAAA,mBAAA,CAAA,GAAA,oBAAwC,CAAA;AACxC,IAAA,iBAAA,CAAA,OAAA,CAAA,GAAA,OAAe,CAAA;AACf,IAAA,iBAAA,CAAA,MAAA,CAAA,GAAA,MAAa,CAAA;AACb,IAAA,iBAAA,CAAA,MAAA,CAAA,GAAA,MAAa,CAAA;AACd,CAAC,EANW,iBAAiB,KAAjB,iBAAiB,GAM5B,EAAA,CAAA,CAAA,CAAA;AAED;IACY,qBAEX;AAFD,CAAA,UAAY,oBAAoB,EAAA;AAC/B,IAAA,oBAAA,CAAA,WAAA,CAAA,GAAA,YAAwB,CAAA;AACzB,CAAC,EAFW,oBAAoB,KAApB,oBAAoB,GAE/B,EAAA,CAAA,CAAA,CAAA;AAED;AACA,IAAY,sBAIX,CAAA;AAJD,CAAA,UAAY,sBAAsB,EAAA;AACjC,IAAA,sBAAA,CAAA,OAAA,CAAA,GAAA,OAAe,CAAA;AACf,IAAA,sBAAA,CAAA,SAAA,CAAA,GAAA,SAAmB,CAAA;AACnB,IAAA,sBAAA,CAAA,MAAA,CAAA,GAAA,MAAa,CAAA;AACd,CAAC,EAJW,sBAAsB,KAAtB,sBAAsB,GAIjC,EAAA,CAAA,CAAA,CAAA;AAED;AACA,IAAY,cAEX,CAAA;AAFD,CAAA,UAAY,cAAc,EAAA;AACzB,IAAA,cAAA,CAAA,MAAA,CAAA,GAAA,MAAa,CAAA;AACd,CAAC,EAFW,cAAc,KAAd,cAAc,GAEzB,EAAA,CAAA,CAAA,CAAA;AAED;IACY,kBAMX;AAND,CAAA,UAAY,iBAAiB,EAAA;AAC5B,IAAA,iBAAA,CAAA,WAAA,CAAA,GAAA,YAAwB,CAAA;AACxB,IAAA,iBAAA,CAAA,UAAA,CAAA,GAAA,WAAsB,CAAA;AACtB,IAAA,iBAAA,CAAA,WAAA,CAAA,GAAA,YAAwB,CAAA;AACxB,IAAA,iBAAA,CAAA,cAAA,CAAA,GAAA,eAA8B,CAAA;AAC9B,IAAA,iBAAA,CAAA,eAAA,CAAA,GAAA,gBAAgC,CAAA;AACjC,CAAC,EANW,iBAAiB,KAAjB,iBAAiB,GAM5B,EAAA,CAAA,CAAA,CAAA;AAED;IACY,UAGX;AAHD,CAAA,UAAY,SAAS,EAAA;AACpB,IAAA,SAAA,CAAA,KAAA,CAAA,GAAA,KAAW,CAAA;AACX,IAAA,SAAA,CAAA,IAAA,CAAA,GAAA,IAAS,CAAA;AACV,CAAC,EAHW,SAAS,KAAT,SAAS,GAGpB,EAAA,CAAA,CAAA,CAAA;AAED;IACY,SAIX;AAJD,CAAA,UAAY,QAAQ,EAAA;AACnB,IAAA,QAAA,CAAA,MAAA,CAAA,GAAA,MAAa,CAAA;AACb,IAAA,QAAA,CAAA,OAAA,CAAA,GAAA,OAAe,CAAA;AACf,IAAA,QAAA,CAAA,MAAA,CAAA,GAAA,MAAa,CAAA;AACd,CAAC,EAJW,QAAQ,KAAR,QAAQ,GAInB,EAAA,CAAA,CAAA,CAAA;AAED;IACY,gBAMX;AAND,CAAA,UAAY,eAAe,EAAA;AAC1B,IAAA,eAAA,CAAA,eAAA,CAAA,KAAA,CAAA,GAAA,CAAA,CAAA,GAAA,KAAO,CAAA;AACP,IAAA,eAAA,CAAA,eAAA,CAAA,OAAA,CAAA,GAAA,CAAA,CAAA,GAAA,OAAS,CAAA;AACT,IAAA,eAAA,CAAA,eAAA,CAAA,MAAA,CAAA,GAAA,CAAA,CAAA,GAAA,MAAQ,CAAA;AACR,IAAA,eAAA,CAAA,eAAA,CAAA,OAAA,CAAA,GAAA,CAAA,CAAA,GAAA,OAAS,CAAA;AACT,IAAA,eAAA,CAAA,eAAA,CAAA,KAAA,CAAA,GAAA,EAAA,CAAA,GAAA,KAAQ,CAAA;AACT,CAAC,EANW,eAAe,KAAf,eAAe,GAM1B,EAAA,CAAA,CAAA,CAAA;AAED;IACY,YAcX;AAdD,CAAA,UAAY,WAAW,EAAA;AACtB,IAAA,WAAA,CAAA,MAAA,CAAA,GAAA,MAAa,CAAA;AACb,IAAA,WAAA,CAAA,KAAA,CAAA,GAAA,KAAW,CAAA;AACX,IAAA,WAAA,CAAA,KAAA,CAAA,GAAA,KAAW,CAAA;AACX,IAAA,WAAA,CAAA,aAAA,CAAA,GAAA,eAA6B,CAAA;AAC7B,IAAA,WAAA,CAAA,UAAA,CAAA,GAAA,WAAsB,CAAA;AACtB,IAAA,WAAA,CAAA,kBAAA,CAAA,GAAA,qBAAwC,CAAA;AACxC,IAAA,WAAA,CAAA,KAAA,CAAA,GAAA,KAAW,CAAA;AACX,IAAA,WAAA,CAAA,aAAA,CAAA,GAAA,eAA6B,CAAA;AAC7B,IAAA,WAAA,CAAA,UAAA,CAAA,GAAA,WAAsB,CAAA;AACtB,IAAA,WAAA,CAAA,kBAAA,CAAA,GAAA,qBAAwC,CAAA;AACxC,IAAA,WAAA,CAAA,mBAAA,CAAA,GAAA,qBAAyC,CAAA;AACzC,IAAA,WAAA,CAAA,UAAA,CAAA,GAAA,UAAqB,CAAA;AACrB,IAAA,WAAA,CAAA,kBAAA,CAAA,GAAA,oBAAuC,CAAA;AACxC,CAAC,EAdW,WAAW,KAAX,WAAW,GActB,EAAA,CAAA,CAAA,CAAA;AAED;IACY,eAMX;AAND,CAAA,UAAY,cAAc,EAAA;AACzB,IAAA,cAAA,CAAA,KAAA,CAAA,GAAA,KAAW,CAAA;AACX,IAAA,cAAA,CAAA,UAAA,CAAA,GAAA,UAAqB,CAAA;AACrB,IAAA,cAAA,CAAA,iBAAA,CAAA,GAAA,kBAAoC,CAAA;AACpC,IAAA,cAAA,CAAA,KAAA,CAAA,GAAA,KAAW,CAAA;AACX,IAAA,cAAA,CAAA,KAAA,CAAA,GAAA,KAAW,CAAA;AACZ,CAAC,EANW,cAAc,KAAd,cAAc,GAMzB,EAAA,CAAA,CAAA,CAAA;AAED;IACY,iBASX;AATD,CAAA,UAAY,gBAAgB,EAAA;AAC3B,IAAA,gBAAA,CAAA,MAAA,CAAA,GAAA,MAAa,CAAA;AACb,IAAA,gBAAA,CAAA,MAAA,CAAA,GAAA,MAAa,CAAA;AACb,IAAA,gBAAA,CAAA,SAAA,CAAA,GAAA,SAAmB,CAAA;AACnB,IAAA,gBAAA,CAAA,QAAA,CAAA,GAAA,QAAiB,CAAA;AACjB,IAAA,gBAAA,CAAA,gBAAA,CAAA,GAAA,iBAAkC,CAAA;AAClC,IAAA,gBAAA,CAAA,gBAAA,CAAA,GAAA,iBAAkC,CAAA;AAClC,IAAA,gBAAA,CAAA,eAAA,CAAA,GAAA,gBAAgC,CAAA;AAChC,IAAA,gBAAA,CAAA,eAAA,CAAA,GAAA,gBAAgC,CAAA;AACjC,CAAC,EATW,gBAAgB,KAAhB,gBAAgB,GAS3B,EAAA,CAAA,CAAA,CAAA;AAED;IACY,YAGX;AAHD,CAAA,UAAY,WAAW,EAAA;AACtB,IAAA,WAAA,CAAA,QAAA,CAAA,GAAA,QAAiB,CAAA;AACjB,IAAA,WAAA,CAAA,QAAA,CAAA,GAAA,QAAiB,CAAA;AAClB,CAAC,EAHW,WAAW,KAAX,WAAW,GAGtB,EAAA,CAAA,CAAA,CAAA;AAED;IACY,aA+BX;AA/BD,CAAA,UAAY,YAAY,EAAA;AACvB,IAAA,YAAA,CAAA,SAAA,CAAA,GAAA,SAAmB,CAAA;AACnB,IAAA,YAAA,CAAA,SAAA,CAAA,GAAA,SAAmB,CAAA;AACnB,IAAA,YAAA,CAAA,SAAA,CAAA,GAAA,SAAmB,CAAA;AACnB,IAAA,YAAA,CAAA,SAAA,CAAA,GAAA,SAAmB,CAAA;AACnB,IAAA,YAAA,CAAA,UAAA,CAAA,GAAA,UAAqB,CAAA;AACrB,IAAA,YAAA,CAAA,UAAA,CAAA,GAAA,UAAqB,CAAA;AACrB,IAAA,YAAA,CAAA,UAAA,CAAA,GAAA,UAAqB,CAAA;AACrB,IAAA,YAAA,CAAA,UAAA,CAAA,GAAA,UAAqB,CAAA;AACrB,IAAA,YAAA,CAAA,UAAA,CAAA,GAAA,UAAqB,CAAA;AACrB,IAAA,YAAA,CAAA,UAAA,CAAA,GAAA,UAAqB,CAAA;AACrB,IAAA,YAAA,CAAA,UAAA,CAAA,GAAA,UAAqB,CAAA;AACrB,IAAA,YAAA,CAAA,UAAA,CAAA,GAAA,UAAqB,CAAA;AACrB,IAAA,YAAA,CAAA,WAAA,CAAA,GAAA,WAAuB,CAAA;AACvB,IAAA,YAAA,CAAA,WAAA,CAAA,GAAA,WAAuB,CAAA;AACvB,IAAA,YAAA,CAAA,WAAA,CAAA,GAAA,WAAuB,CAAA;AACvB,IAAA,YAAA,CAAA,WAAA,CAAA,GAAA,WAAuB,CAAA;AACvB,IAAA,YAAA,CAAA,WAAA,CAAA,GAAA,WAAuB,CAAA;AACvB,IAAA,YAAA,CAAA,WAAA,CAAA,GAAA,WAAuB,CAAA;AACvB,IAAA,YAAA,CAAA,SAAA,CAAA,GAAA,SAAmB,CAAA;AACnB,IAAA,YAAA,CAAA,WAAA,CAAA,GAAA,WAAuB,CAAA;AACvB,IAAA,YAAA,CAAA,WAAA,CAAA,GAAA,WAAuB,CAAA;AACvB,IAAA,YAAA,CAAA,WAAA,CAAA,GAAA,WAAuB,CAAA;AACvB,IAAA,YAAA,CAAA,QAAA,CAAA,GAAA,QAAiB,CAAA;AACjB,IAAA,YAAA,CAAA,UAAA,CAAA,GAAA,UAAqB,CAAA;AACrB,IAAA,YAAA,CAAA,UAAA,CAAA,GAAA,UAAqB,CAAA;AACrB,IAAA,YAAA,CAAA,UAAA,CAAA,GAAA,UAAqB,CAAA;AACrB,IAAA,YAAA,CAAA,QAAA,CAAA,GAAA,QAAiB,CAAA;AACjB,IAAA,YAAA,CAAA,UAAA,CAAA,GAAA,UAAqB,CAAA;AACrB,IAAA,YAAA,CAAA,UAAA,CAAA,GAAA,UAAqB,CAAA;AACrB,IAAA,YAAA,CAAA,UAAA,CAAA,GAAA,UAAqB,CAAA;AACtB,CAAC,EA/BW,YAAY,KAAZ,YAAY,GA+BvB,EAAA,CAAA,CAAA,CAAA;AAED;IACY,cAGX;AAHD,CAAA,UAAY,aAAa,EAAA;AACxB,IAAA,aAAA,CAAA,QAAA,CAAA,GAAA,QAAiB,CAAA;AACjB,IAAA,aAAA,CAAA,UAAA,CAAA,GAAA,UAAqB,CAAA;AACtB,CAAC,EAHW,aAAa,KAAb,aAAa,GAGxB,EAAA,CAAA,CAAA,CAAA;AAED;AACA,IAAY,4BAGX,CAAA;AAHD,CAAA,UAAY,4BAA4B,EAAA;AACvC,IAAA,4BAAA,CAAA,WAAA,CAAA,GAAA,WAAuB,CAAA;AACvB,IAAA,4BAAA,CAAA,KAAA,CAAA,GAAA,KAAW,CAAA;AACZ,CAAC,EAHW,4BAA4B,KAA5B,4BAA4B,GAGvC,EAAA,CAAA,CAAA,CAAA;AAED;AACA,IAAY,2BAGX,CAAA;AAHD,CAAA,UAAY,2BAA2B,EAAA;AACtC,IAAA,2BAAA,CAAA,WAAA,CAAA,GAAA,WAAuB,CAAA;AACvB,IAAA,2BAAA,CAAA,KAAA,CAAA,GAAA,KAAW,CAAA;AACZ,CAAC,EAHW,2BAA2B,KAA3B,2BAA2B,GAGtC,EAAA,CAAA,CAAA,CAAA;AAED;AACA,IAAY,MAGX,CAAA;AAHD,CAAA,UAAY,MAAM,EAAA;AACjB,IAAA,MAAA,CAAA,MAAA,CAAA,GAAA,MAAa,CAAA;AACb,IAAA,MAAA,CAAA,OAAA,CAAA,GAAA,OAAe,CAAA;AAChB,CAAC,EAHW,MAAM,KAAN,MAAM,GAGjB,EAAA,CAAA,CAAA,CAAA;AAED;AACA,IAAY,OAGX,CAAA;AAHD,CAAA,UAAY,OAAO,EAAA;AAClB,IAAA,OAAA,CAAA,OAAA,CAAA,GAAA,OAAe,CAAA;AACf,IAAA,OAAA,CAAA,SAAA,CAAA,GAAA,SAAmB,CAAA;AACpB,CAAC,EAHW,OAAO,KAAP,OAAO,GAGlB,EAAA,CAAA,CAAA,CAAA;AAED;AACA,IAAY,SAGX,CAAA;AAHD,CAAA,UAAY,SAAS,EAAA;AACpB,IAAA,SAAA,CAAA,WAAA,CAAA,GAAA,WAAuB,CAAA;AACvB,IAAA,SAAA,CAAA,WAAA,CAAA,GAAA,WAAuB,CAAA;AACxB,CAAC,EAHW,SAAS,KAAT,SAAS,GAGpB,EAAA,CAAA,CAAA,CAAA;AAED;AACA,IAAY,eAGX,CAAA;AAHD,CAAA,UAAY,eAAe,EAAA;AAC1B,IAAA,eAAA,CAAA,QAAA,CAAA,GAAA,QAAiB,CAAA;AACjB,IAAA,eAAA,CAAA,eAAA,CAAA,GAAA,eAA+B,CAAA;AAChC,CAAC,EAHW,eAAe,KAAf,eAAe,GAG1B,EAAA,CAAA,CAAA,CAAA;AAED;AACA,IAAY,gBAEX,CAAA;AAFD,CAAA,UAAY,gBAAgB,EAAA;AAC3B,IAAA,gBAAA,CAAA,WAAA,CAAA,GAAA,WAAuB,CAAA;AACxB,CAAC,EAFW,gBAAgB,KAAhB,gBAAgB,GAE3B,EAAA,CAAA,CAAA,CAAA;AAED;AACA,IAAY,WAGX,CAAA;AAHD,CAAA,UAAY,WAAW,EAAA;AACtB,IAAA,WAAA,CAAA,aAAA,CAAA,GAAA,eAA6B,CAAA;AAC7B,IAAA,WAAA,CAAA,YAAA,CAAA,GAAA,YAAyB,CAAA;AAC1B,CAAC,EAHW,WAAW,KAAX,WAAW,GAGtB,EAAA,CAAA,CAAA,CAAA;AAED,IAAY,aAMX,CAAA;AAND,CAAA,UAAY,aAAa,EAAA;AACxB,IAAA,aAAA,CAAA,aAAA,CAAA,KAAA,CAAA,GAAA,CAAA,CAAA,GAAA,KAAS,CAAA;AACT,IAAA,aAAA,CAAA,aAAA,CAAA,OAAA,CAAA,GAAA,CAAA,CAAA,GAAA,OAAW,CAAA;AACX,IAAA,aAAA,CAAA,aAAA,CAAA,MAAA,CAAA,GAAA,CAAA,CAAA,GAAA,MAAU,CAAA;AACV,IAAA,aAAA,CAAA,aAAA,CAAA,OAAA,CAAA,GAAA,CAAA,CAAA,GAAA,OAAW,CAAA;AACX,IAAA,aAAA,CAAA,aAAA,CAAA,KAAA,CAAA,GAAA,EAAA,CAAA,GAAA,KAAS,CAAA;AACV,CAAC,EANW,aAAa,KAAb,aAAa,GAMxB,EAAA,CAAA,CAAA,CAAA;AACD,IAAY,cAGX,CAAA;AAHD,CAAA,UAAY,cAAc,EAAA;AACzB,IAAA,cAAA,CAAA,QAAA,CAAA,GAAA,QAAiB,CAAA;AACjB,IAAA,cAAA,CAAA,MAAA,CAAA,GAAA,MAAa,CAAA;AACd,CAAC,EAHW,cAAc,KAAd,cAAc,GAGzB,EAAA,CAAA,CAAA,CAAA;AACD,IAAY,SAIX,CAAA;AAJD,CAAA,UAAY,SAAS,EAAA;AACpB,IAAA,SAAA,CAAA,SAAA,CAAA,SAAA,CAAA,GAAA,CAAA,CAAA,CAAA,GAAA,SAAY,CAAA;AACZ,IAAA,SAAA,CAAA,SAAA,CAAA,cAAA,CAAA,GAAA,CAAA,CAAA,GAAA,cAAgB,CAAA;AAChB,IAAA,SAAA,CAAA,SAAA,CAAA,QAAA,CAAA,GAAA,CAAA,CAAA,GAAA,QAAU,CAAA;AACX,CAAC,EAJW,SAAS,KAAT,SAAS,GAIpB,EAAA,CAAA,CAAA;;ACrcD,MAAM,MAAM,CAAA;IAMX,WACC,CAAA,KAAa,EACb,MAAiB,EACjB,KAA0B,EAC1B,IAA4B,EAC5B,IAAa,EAAA;AAEb,QAAA,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;AACrB,QAAA,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;AACnB,QAAA,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;AACjB,QAAA,IAAI,CAAC,IAAI,GAAG,IAAI,IAAI,SAAS,GAAG,CAAC,IAAI,GAAG,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,UAAU,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC;AAC7E,QAAA,IAAI,CAAC,SAAS,GAAG,MAAM,CAAC,YAAY,CAAC;YACpC,KAAK,EAAE,KAAK,IAAI,EAAE;YAClB,IAAI,EAAE,IAAI,CAAC,IAAI;YACf,KAAK;AACL,SAAA,CAAC,CAAC;AACH,QAAA,IAAI,IAAI;YAAE,IAAI,CAAC,UAAU,CAAC,CAAC,EAAE,IAAI,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC;KAC9C;IACD,OAAO,MAAM,CACZ,KAAa,EACb,MAAiB,EACjB,KAA0B,EAC1B,IAA4B,EAC5B,IAAa,EAAA;AAEb,QAAA,OAAO,IAAI,MAAM,CAAC,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC;KACpD;AACD,IAAA,OAAO,kBAAkB,CAAC,KAAa,EAAE,MAAiB,EAAE,IAAqB,EAAA;QAChF,OAAO,IAAI,MAAM,CAAC,KAAK,EAAE,MAAM,EAAE,WAAW,CAAC,MAAM,GAAG,WAAW,CAAC,OAAO,EAAE,IAAI,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC;KAClG;AAED,IAAA,OAAO,iBAAiB,CAAC,KAAa,EAAE,MAAiB,EAAE,IAAqB,EAAA;AAC/E,QAAA,OAAO,IAAI,MAAM,CAAC,KAAK,EAAE,MAAM,EAAE,WAAW,CAAC,KAAK,GAAG,WAAW,CAAC,OAAO,EAAE,IAAI,CAAC,CAAC;KAChF;IAED,OAAO,mBAAmB,CAAC,KAAa,EAAE,MAAiB,EAAE,IAAY,EAAE,KAAmB,EAAA;AAC7F,QAAA,OAAO,IAAI,MAAM,CAAC,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC;KACpD;IACD,OAAO,aAAa,CAAC,KAAK,EAAA;AAEzB,QAAA,QAAQ,KAAK;YACZ,KAAK,WAAW,CAAC,OAAO;gBAEvB,MAAM;YACP,KAAK,WAAW,CAAC,OAAO;gBAEvB,MAAM;AAGP,SAAA;KACD;;AAEM,IAAA,UAAU,CAAC,MAAc,EAAE,IAAqB,EAAE,IAAa,EAAA;AACrE,QAAA,MAAM,cAAc,GAAG,IAAI,CAAC,MAAM,CAAC;AACnC,QAAA,MAAM,SAAS,GAAG,IAAI,IAAI,cAAc,CAAC,UAAU,CAAC;AACpD,QAAA,MAAM,SAAS,GAAG,IAAI,CAAC,MAAM,CAAC,YAAY,CAAC;AAC1C,YAAA,gBAAgB,EAAE,IAAI;AACtB,YAAA,IAAI,EAAE,SAAS;YACf,KAAK,EAAE,cAAc,CAAC,QAAQ;AAC9B,SAAA,CAAC,CAAC;AACH,QAAA,MAAM,WAAW,GAAG,SAAS,CAAC,cAAc,EAAE,CAAC;AAE/C,QAAA,IAAI,WAAW,CAAC,WAAW,CAAC,CAAC,GAAG,CAAC,IAAI,WAAW,CAAC,cAAc,CAAC,CAAC,CAAC;QAClE,SAAS,CAAC,KAAK,EAAE,CAAC;QAElB,IAAI,CAAC,YAAY,CAAC,SAAS,EAAE,MAAM,EAAE,SAAS,CAAC,CAAC;QAEhD,SAAS,CAAC,OAAO,EAAE,CAAC;KACpB;AAEM,IAAA,YAAY,CAAC,SAAoB,EAAE,MAAc,EAAE,SAAiB,EAAA;QAC1E,MAAM,cAAc,GAAG,IAAI,CAAC,MAAM,CAAC,oBAAoB,EAAE,CAAC;AAC1D,QAAA,cAAc,CAAC,kBAAkB,CAAC,SAAS,EAAE,CAAC,EAAE,IAAI,CAAC,SAAS,EAAE,MAAM,EAAE,SAAS,CAAC,CAAC;AACnF,QAAA,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,cAAc,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC;KACpD;AAEM,IAAA,aAAa,CACnB,WAAmB,EACnB,YAAoB,EACpB,WAAgC,EAChC,MAAmB,EAAA;QAEnB,MAAM,cAAc,GAAG,IAAI,CAAC,MAAM,CAAC,oBAAoB,EAAE,CAAC;QAC1D,cAAc,CAAC,mBAAmB,CACjC;YACC,MAAM,EAAE,IAAI,CAAC,SAAS;YACtB,WAAW;YACX,YAAY;AACZ,SAAA,EACD,WAAW,EACX,MAAM,CACN,CAAC;AACF,QAAA,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,cAAc,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC;KACpD;IAEM,OAAO,GAAA;AACb,QAAA,IAAI,CAAC,SAAS,CAAC,OAAO,EAAE,CAAC;KACzB;AACD;;ACvGD,MAAM,mBAAmB,GAAG,IAAI,GAAG,EAAE,CAAC;MACzB,cAAc,CAAA;AAGzB,IAAA,WAAA,CACE,MAAiB,EACjB,KAAa,EACN,YAAkC,GAAA,EAAE,EAC3C,KAAc,EAAA;QADP,IAAY,CAAA,YAAA,GAAZ,YAAY,CAAwB;AAG3C,QAAA,IAAI,CAAC,KAAK,GAAG,KAAK,IAAI,CAAC,CAAC;AACxB,QAAA,IAAI,CAAC,iBAAiB,GAAG,MAAM,CAAC,oBAAoB,CAAC;AACnD,YAAA,KAAK,EAAE,KAAK;YACZ,gBAAgB,EAAE,YAAY,CAAC,GAAG,CAAC,CAAC,MAAM,KAAI;gBAC5C,OAAO,MAAM,CAAC,kBAAkB,CAAC;AACnC,aAAC,CAAC;AACH,SAAA,CAAC,CAAC;KACJ;AACD,IAAA,OAAO,0BAA0B,CAC/B,MAAiB,EACjB,KAAa,EACb,YAA+B,EAAA;AAE/B,QAAA,IAAI,mBAAmB,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE;AAClC,YAAA,OAAO,mBAAmB,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;AACvC,SAAA;AAAM,aAAA;YACL,MAAM,eAAe,GAAG,IAAI,cAAc,CAAC,MAAM,EAAE,KAAK,EAAE,YAAY,CAAC,CAAC;AACxE,YAAA,mBAAmB,CAAC,GAAG,CAAC,KAAK,EAAE,eAAe,CAAC,CAAC;AAChD,YAAA,OAAO,eAAe,CAAC;AACxB,SAAA;KACF;AACF;;AC3BD,MAAM,eAAe,GAAG,IAAI,GAAG,EAAE,CAAC;AAClC,MAAM,gBAAgB,GAAG,IAAI,GAAG,EAAE,CAAC;AACrB,MAAO,QAAQ,CAAA;AAK5B,IAAA,WAAA,CACC,IAAY,EACZ,MAAiB,EACjB,UAAsE,EAAA;AAEtE,QAAA,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;AACjB,QAAA,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC;AAC7B,QAAA,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;QACrB,IAAI,CAAC,cAAc,EAAE,CAAC;KACtB;IACO,cAAc,GAAA;AACrB,QAAA,IAAI,IAAI,CAAC,IAAI,IAAI,QAAQ,EAAE;AAC1B,YAAA,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,MAAM,CAAC,oBAAoB,CAAC,IAAI,CAAC,UAAyC,CAAC,CAAC;AACpG,SAAA;AAAM,aAAA;AACN,YAAA,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,MAAM,CAAC,qBAAqB,CAAC,IAAI,CAAC,UAA0C,CAAC,CAAC;AACtG,SAAA;KACD;AACM,IAAA,IAAI,CAAC,WAAyD,EAAA;AACpE,QAAA,IAAI,IAAI,CAAC,IAAI,IAAI,QAAQ,EAAE;AACzB,YAAA,WAAoC,CAAC,WAAW,CAAC,IAAI,CAAC,WAAgC,CAAC,CAAC;AACzF,SAAA;AAAM,aAAA;AACL,YAAA,WAAqC,CAAC,WAAW,CAAC,IAAI,CAAC,WAAiC,CAAC,CAAC;AAC3F,SAAA;KACD;AACD,IAAA,OAAO,0BAA0B,CAChC,MAAiB,EACjB,UAAuB,EACvB,YAA+B,EAAA;AAE/B,QAAA,MAAM,EAAE,WAAW,EAAE,YAAY,EAAE,GAAG,UAAU,CAAC;QACjD,MAAM,KAAK,GAAG,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,CAAC;QAC1C,MAAM,UAAU,GAAG,YAAY,CAAC,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;AAClD,QAAA,MAAM,MAAM,GAAG,YAAY,CAAC,UAAU,CAAC,CAAC;QACxC,MAAM,cAAc,GAAG,YAAY;cAChC,MAAM,CAAC,CAAC,MAAM,KAAK,MAAM,IAAI,SAAS,CAAC;AACzC,cAAE,IAAI,CAAC,CAAC,OAAO,EAAE,OAAO,KAAK,OAAO,CAAC,KAAK,GAAG,OAAO,CAAC,KAAK,CAAC,CAAC;QAC7D,IAAI,QAAQ,GAAG,eAAe,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;QAC3C,IAAI,CAAC,QAAQ,EAAE;AACd,YAAA,MAAM,UAAU,GAAG,QAAQ,CAAC,qBAAqB,CAChD,MAAM,EACN,UAAU,EACV,WAAW,EACX,cAAc,EACd,MAAM,CAAC,QAAQ,EAAE,CACjB,CAAC;YACF,QAAQ,GAAG,IAAI,QAAQ,CAAC,QAAQ,EAAE,MAAM,EAAE,UAAU,CAAC,CAAC;AACtD,YAAA,eAAe,CAAC,GAAG,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC;AACtC,SAAA;AACD,QAAA,OAAO,QAAQ,CAAC;KAChB;AACD,IAAA,OAAO,2BAA2B,CACjC,MAAiB,EACjB,aAA6B,EAC7B,YAA+B,EAAA;AAE/B,QAAA,MAAM,EAAE,YAAY,EAAE,GAAG,aAAa,CAAC;QACvC,MAAM,MAAM,GAAG,YAAY,CAAC,YAAY,CAAC,GAAG,CAAC,CAAC;QAC9C,IAAI,QAAQ,GAAG,gBAAgB,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;QAC5C,IAAI,CAAC,QAAQ,EAAE;AACd,YAAA,QAAQ,GAAG,MAAM,CAAC,qBAAqB,CAAC;AACvC,gBAAA,MAAM,EAAE,cAAc,CAAC,0BAA0B,CAAC,MAAM,EAAE,MAAM,CAAC,QAAQ,EAAE,EAAE,YAAY,CAAC;qBACxF,iBAAiB;AACnB,gBAAA,OAAO,EAAE;AACR,oBAAA,MAAM,EAAE,YAAY,CAAC,kBAAkB,CAAC,MAAM,CAAoB;oBAClE,UAAU,EAAE,YAAY,CAAC,WAAW;AACpC,iBAAA;AACD,aAAA,CAAC,CAAC;AACH,YAAA,gBAAgB,CAAC,GAAG,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC;AACvC,SAAA;AACD,QAAA,OAAO,QAAQ,CAAC;KAChB;IACO,OAAO,qBAAqB,CACnC,MAAiB,EACjB,UAAuB,EACvB,WAAwB,EACxB,YAA+B,EAC/B,MAAc,EAAA;AAEd,QAAA,MAAM,EAAE,YAAY,EAAE,YAAY,EAAE,GAAG,UAAU,CAAC;AAClD,QAAA,MAAM,EAAE,IAAI,EAAE,IAAI,EAAE,GAAG,YAAY,CAAC,kBAAkB,CAAC,MAAM,CAG5D,CAAC;AACF,QAAA,MAAM,WAAW,GAAG;AACnB,YAAA,MAAM,EAAE,cAAc,CAAC,0BAA0B,CAAC,MAAM,EAAE,MAAM,EAAE,YAAY,CAAC,CAAC,iBAAiB;SAC1F,CAAC;AACT,QAAA,IAAI,IAAI;YACP,WAAW,CAAC,MAAM,GAAG;AACpB,gBAAA,MAAM,EAAE,IAAI;gBACZ,UAAU,EAAE,YAAY,CAAC,cAAc;AACvC,gBAAA,OAAO,EAAE,YAAY,CAAC,YAAY,EAAqC;aACvE,CAAC;QACH,IAAI,WAAW,CAAC,SAAS;YAAE,WAAW,CAAC,SAAS,GAAG,WAAW,CAAC,SAAS,CAAC,kBAAkB,EAAE,CAAC;QAC9F,IAAI,WAAW,CAAC,YAAY;YAAE,WAAW,CAAC,YAAY,GAAG,WAAW,CAAC,YAAY,CAAC,qBAAqB,EAAE,CAAC;QAC1G,IAAI,WAAW,CAAC,WAAW;YAAE,WAAW,CAAC,WAAW,GAAG,WAAW,CAAC,WAAW,CAAC,iBAAiB,EAAE,CAAC;AACnG,QAAA,IAAI,IAAI;YACP,WAAW,CAAC,QAAQ,GAAG;AACtB,gBAAA,MAAM,EAAE,IAAI;gBACZ,UAAU,EAAE,YAAY,CAAC,cAAc;gBACvC,OAAO,EAAE,WAAW,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,MAAM,KAAI;AAC3C,oBAAA,OAAO,MAAM,CAAC,eAAe,EAAE,CAAC;AACjC,iBAAC,CAAC;aACF,CAAC;AACH,QAAA,OAAO,WAAW,CAAC;KACnB;AACD,CAAA;AACD;AACA,SAAS,YAAY,CAAC,GAAG,EAAA;IACxB,IAAI,IAAI,GAAG,CAAC,CAAC;AACb,IAAA,IAAI,GAAG,CAAC,MAAM,IAAI,CAAC;AAAE,QAAA,OAAO,IAAI,CAAC;AACjC,IAAA,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,GAAG,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;QACpC,MAAM,IAAI,GAAG,GAAG,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;QAC/B,IAAI,GAAG,CAAC,IAAI,IAAI,CAAC,IAAI,IAAI,GAAG,IAAI,CAAC;AACjC,QAAA,IAAI,GAAG,IAAI,GAAG,IAAI,CAAC;AACnB,KAAA;AACD,IAAA,OAAO,IAAI,CAAC;AACb;;ACpHA,MAAM,WAAW,CAAA;AA+BhB,IAAA,WAAA,CAAY,OAAyB,EAAA;AACpC,QAAA,IAAI,CAAC,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC;AAEzB,QAAA,IAAI,CAAC,UAAU,GAAG,OAAO,CAAC,UAAU,CAAC;AAErC,QAAA,IAAI,CAAC,YAAY,GAAG,OAAO,CAAC,YAAY,CAAC;AAEzC,QAAA,IAAI,CAAC,YAAY,GAAG,OAAO,CAAC,YAAY,CAAC;AAEzC,QAAA,IAAI,CAAC,WAAW,GAAG,OAAO,CAAC,WAAW,CAAC;AAEvC,QAAA,IAAI,CAAC,WAAW,GAAG,OAAO,CAAC,WAAW,CAAC;AAEvC,QAAA,IAAI,CAAC,UAAU,GAAG,OAAO,CAAC,UAAU,CAAC;AAErC,QAAA,IAAI,CAAC,KAAK,GAAG,OAAO,CAAC,KAAK,CAAC;AAE3B,QAAA,IAAI,CAAC,SAAS,GAAG,OAAO,CAAC,SAAS,CAAC;AAEnC,QAAA,IAAI,CAAC,YAAY,GAAG,OAAO,CAAC,YAAY,CAAC;AAEzC,QAAA,IAAI,CAAC,KAAK,GAAG,OAAO,CAAC,KAAK,CAAC;AAE3B,QAAA,IAAI,CAAC,KAAK,GAAG,OAAO,CAAC,KAAK,CAAC;AAE3B,QAAA,IAAI,CAAC,WAAW,GAAG,OAAO,CAAC,WAAW,CAAC;AAEvC,QAAA,IAAI,CAAC,eAAe,GAAG,OAAO,CAAC,eAAe,CAAC;KAC/C;AACM,IAAA,YAAY,CAAC,QAAmB,EAAA;AACtC,QAAA,IAAI,QAAQ,EAAE;YACb,OAAO,IAAI,WAAW,CAAC;gBACtB,YAAY,EAAE,IAAI,CAAC,YAAY;gBAC/B,WAAW,EAAE,IAAI,CAAC,WAAW;gBAC7B,UAAU,EAAE,QAAQ,CAAC,UAAU;gBAC/B,SAAS,EAAE,IAAI,CAAC,SAAS;gBACzB,KAAK,EAAE,IAAI,CAAC,KAAK;gBACjB,WAAW,EAAE,QAAQ,CAAC,WAAW;gBACjC,YAAY,EAAE,QAAQ,CAAC,YAAY;AACnC,gBAAA,IAAI,EAAE,QAAQ;gBACd,KAAK,EAAE,QAAQ,CAAC,KAAK;gBACrB,WAAW,EAAE,IAAI,CAAC,WAAW;AAC7B,gBAAA,eAAe,EAAE,QAAQ,CAAC,KAAK,GAAG,IAAI,CAAC,eAAe,GAAG,SAAS;AAClE,aAAA,CAAC,CAAC;AACH,SAAA;KACD;AACM,IAAA,MAAM,CAAC,OAAiB,EAAE,WAAkC,EAAE,MAAe,EAAA;QACnF,MAAM,EACL,UAAU,EACV,WAAW,EACX,WAAW,EACX,YAAY,EACZ,WAAW,EACX,eAAe,EACf,YAAY,EACZ,KAAK,EACL,SAAS,EACT,YAAY,EACZ,GAAG,IAAI,CAAC;QACT,MAAM,kBAAkB,GAAG,YAAY,EAAE,sBAAsB,GAAG,OAAO,CAAC,IAAI,WAAW,CAAC;QAC1F,MAAM,OAAO,GAAG,MAAM,CAAC,MAAM,CAAC,EAAE,EAAE,eAAe,EAAE,OAAO,IAAI,EAAE,EAAE,MAAM,EAAE,UAAU,EAAE,OAAO,IAAI,EAAE,CAAC,CAAC;AACrG,QAAA,MAAM,EAAE,MAAM,EAAE,GAAG,OAAO,CAAC;AAE3B,QAAA,IAAI,WAAW;YAAE,UAAU,EAAE,yBAAyB,GAAG,aAAa,EAAE,WAAW,CAAC,CAAC;QAErF,UAAU,EAAE,IAAI,GAAG,OAAO,EAAE,kBAAkB,CAAC,CAAC;QAEhD,MAAM,EAAE,UAAU,EAAE,IAAI,CAAC,OAAO,EAAE,kBAAkB,CAAC,CAAC;QAEtD,eAAe,EAAE,IAAI,GAAG,OAAO,EAAE,kBAAkB,CAAC,CAAC;QAErD,WAAW,EAAE,IAAI,GAAG,kBAAkB,EAAE,OAAO,CAAC,CAAC;QAEjD,YAAY,EAAE,IAAI,GAAG,MAAM,EAAE,kBAAkB,CAAC,CAAC;QAEjD,WAAW,EAAE,IAAI,GAAG,MAAM,EAAE,kBAAkB,CAAC,CAAC;AAEhD,QAAA,YAAY,EAAE,UAAU,GAAG,OAAO,CAAC,CAAC;QAEpC,MAAM,QAAQ,GAAG,QAAQ,CAAC,0BAA0B,CAAC,MAAM,EAAE,IAAI,EAAE;AAClE,YAAA,UAAU,EAAE,WAAW;AACvB,YAAA,eAAe,EAAE,WAAW;YAC5B,MAAM,EAAE,UAAU,EAAE,WAAW;AAC/B,SAAA,CAAC,CAAC;AACH,QAAA,QAAQ,CAAC,IAAI,CAAC,kBAAkB,CAAC,CAAC;AAClC,QAAA,IAAI,WAAW,EAAE;AAChB,YAAA,kBAAkB,CAAC,WAAW,CAAC,KAAK,IAAI,CAAC,EAAE,SAAS,IAAI,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;AACpE,SAAA;AAAM,aAAA,IAAI,KAAK,EAAE;AACjB,YAAA,kBAAkB,CAAC,IAAI,CAAC,KAAK,EAAE,SAAS,IAAI,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;AACrD,SAAA;AACD,QAAA,YAAY,EAAE,oBAAoB,IAAI,CAAC;KACvC;AACD;;ACrHM,MAAM,6BAA6B,GAEtC;AACH,IAAA,MAAM,EAAE,QAAQ;AAChB,IAAA,aAAa,EAAE,eAAe;CAC9B,CAAC;AAqPF,IAAY,gBAUX,CAAA;AAVD,CAAA,UAAY,gBAAgB,EAAA;AAC3B,IAAA,gBAAA,CAAA,QAAA,CAAA,GAAA,QAAiB,CAAA;AACjB,IAAA,gBAAA,CAAA,OAAA,CAAA,GAAA,OAAe,CAAA;AACf,IAAA,gBAAA,CAAA,MAAA,CAAA,GAAA,MAAa,CAAA;AACb,IAAA,gBAAA,CAAA,UAAA,CAAA,GAAA,UAAqB,CAAA;AACrB,IAAA,gBAAA,CAAA,MAAA,CAAA,GAAA,MAAa,CAAA;AACb,IAAA,gBAAA,CAAA,MAAA,CAAA,GAAA,MAAa,CAAA;AACb,IAAA,gBAAA,CAAA,QAAA,CAAA,GAAA,QAAiB,CAAA;AACjB,IAAA,gBAAA,CAAA,YAAA,CAAA,GAAA,YAAyB,CAAA;AACzB,IAAA,gBAAA,CAAA,OAAA,CAAA,GAAA,OAAe,CAAA;AAChB,CAAC,EAVW,gBAAgB,KAAhB,gBAAgB,GAU3B,EAAA,CAAA,CAAA,CAAA;AACD,IAAY,SAKX,CAAA;AALD,CAAA,UAAY,SAAS,EAAA;AACpB,IAAA,SAAA,CAAA,WAAA,CAAA,GAAA,WAAuB,CAAA;AACvB,IAAA,SAAA,CAAA,YAAA,CAAA,GAAA,YAAyB,CAAA;AACzB,IAAA,SAAA,CAAA,cAAA,CAAA,GAAA,cAA6B,CAAA;AAC7B,IAAA,SAAA,CAAA,kBAAA,CAAA,GAAA,kBAAqC,CAAA;AACtC,CAAC,EALW,SAAS,KAAT,SAAS,GAKpB,EAAA,CAAA,CAAA;;MC3RY,eAAe,CAAA;AAK3B,IAAA,WAAA,CAAY,MAAM,EAAA;AACjB,QAAA,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;AACrB,QAAA,IAAI,CAAC,OAAO,GAAG,MAAM,CAAC,aAAa,CAAC,EAAE,SAAS,EAAE,QAAQ,EAAE,CAAC,CAAC;;AAE7D,QAAA,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;KACpB;AACO,IAAA,iBAAiB,CAAC,MAAM,EAAA;QAC/B,IAAI,QAAQ,GAAG,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC;QACtC,IAAI,CAAC,QAAQ,EAAE;;AAEd,YAAA,IAAI,CAAC,IAAI,CAAC,kBAAkB,EAAE;gBAC7B,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC,MAAM,CAAC,kBAAkB,CAAC;AACxD,oBAAA,IAAI,EAAE,CAAA;;;;;;;;;;;;;;;;;;;;AAoBE,YAAA,CAAA;AACR,iBAAA,CAAC,CAAC;AACH,aAAA;AAED,YAAA,QAAQ,GAAG,IAAI,CAAC,MAAM,CAAC,oBAAoB,CAAC;AAC3C,gBAAA,MAAM,EAAE,MAAM;AACd,gBAAA,MAAM,EAAE;oBACP,MAAM,EAAE,IAAI,CAAC,kBAAkB;AAC/B,oBAAA,UAAU,EAAE,YAAY;AACxB,iBAAA;AACD,gBAAA,QAAQ,EAAE;oBACT,MAAM,EAAE,IAAI,CAAC,kBAAkB;AAC/B,oBAAA,UAAU,EAAE,cAAc;AAC1B,oBAAA,OAAO,EAAE,CAAC,EAAE,MAAM,EAAE,CAAC;AACrB,iBAAA;AACD,aAAA,CAAC,CAAC;AACH,YAAA,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,GAAG,QAAQ,CAAC;AAClC,SAAA;AACD,QAAA,OAAO,QAAQ,CAAC;KAChB;AAED;;;;;;AAMG;AACH,IAAA,cAAc,CAAC,aAAsB,EAAA;AACpC,QAAA,MAAM,OAAO,GAAG,aAAa,CAAC,UAAU,CAAC;AACzC,QAAA,MAAM,iBAAiB,GAAG,aAAa,CAAC,WAAW,CAAC;;QAEpD,MAAM,QAAQ,GAAG,IAAI,CAAC,iBAAiB,CAAC,iBAAiB,CAAC,MAAM,CAAC,CAAC;QAElE,IAAI,iBAAiB,CAAC,SAAS,IAAI,IAAI,IAAI,iBAAiB,CAAC,SAAS,IAAI,IAAI,EAAE;AAC/E,YAAA,MAAM,IAAI,KAAK,CAAC,kEAAkE,CAAC,CAAC;AACpF,SAAA;QAED,IAAI,UAAU,GAAG,OAAO,CAAC;QACzB,MAAM,eAAe,GAAG,iBAAiB,CAAC,IAAI,CAAC,KAAK,IAAI,CAAC,CAAC;;QAG1D,MAAM,cAAc,GAAG,iBAAiB,CAAC,KAAK,GAAG,eAAe,CAAC,iBAAiB,CAAC;QACnF,IAAI,CAAC,cAAc,EAAE;;;AAGpB,YAAA,MAAM,oBAAoB,GAAG;AAC5B,gBAAA,IAAI,EAAE;AACL,oBAAA,KAAK,EAAE,IAAI,CAAC,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,KAAK,GAAG,CAAC,CAAC;AAClD,oBAAA,MAAM,EAAE,IAAI,CAAC,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC;AACpD,oBAAA,kBAAkB,EAAE,eAAe;AACnC,iBAAA;gBACD,MAAM,EAAoB,iBAAiB,CAAC,MAAM;gBAClD,KAAK,EAAE,eAAe,CAAC,eAAe,GAAG,eAAe,CAAC,QAAQ,GAAG,eAAe,CAAC,iBAAiB;AACrG,gBAAA,aAAa,EAAE,iBAAiB,CAAC,aAAa,GAAG,CAAC;aAClD,CAAC;YACF,UAAU,GAAG,IAAI,CAAC,MAAM,CAAC,aAAa,CAAC,oBAAoB,CAAC,CAAC;AAC7D,SAAA;QAED,MAAM,cAAc,GAAG,IAAI,CAAC,MAAM,CAAC,oBAAoB,CAAC,EAAE,CAAC,CAAC;;QAE5D,MAAM,eAAe,GAAG,QAAQ,CAAC,kBAAkB,CAAC,CAAC,CAAC,CAAC;QAEvD,KAAK,IAAI,UAAU,GAAG,CAAC,EAAE,UAAU,GAAG,eAAe,EAAE,EAAE,UAAU,EAAE;AACpE,YAAA,IAAI,OAAO,GAAG,OAAO,CAAC,UAAU,CAAC;AAChC,gBAAA,YAAY,EAAE,CAAC;AACf,gBAAA,aAAa,EAAE,CAAC;AAChB,gBAAA,SAAS,EAAE,IAAI;AACf,gBAAA,cAAc,EAAE,UAAU;AAC1B,gBAAA,eAAe,EAAE,CAAC;AAClB,aAAA,CAAC,CAAC;YAEH,IAAI,WAAW,GAAG,cAAc,GAAG,CAAC,GAAG,CAAC,CAAC;AACzC,YAAA,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,iBAAiB,CAAC,aAAa,EAAE,EAAE,CAAC,EAAE;AACzD,gBAAA,MAAM,OAAO,GAAG,UAAU,CAAC,UAAU,CAAC;oBACrC,YAAY,EAAE,WAAW,EAAE;AAC3B,oBAAA,aAAa,EAAE,CAAC;AAChB,oBAAA,SAAS,EAAE,IAAI;AACf,oBAAA,cAAc,EAAE,UAAU;AAC1B,oBAAA,eAAe,EAAE,CAAC;AAClB,iBAAA,CAAC,CAAC;AAEH,gBAAA,MAAM,WAAW,GAAG,cAAc,CAAC,eAAe,CAAC;AAClD,oBAAA,gBAAgB,EAAE;AACjB,wBAAA;AACC,4BAAA,IAAI,EAAE,OAAO;AACb,4BAAA,MAAM,EAAE,OAAO;AACf,4BAAA,OAAO,EAAE,OAAO;AAChB,yBAAA;AACD,qBAAA;AACD,iBAAA,CAAC,CAAC;AAEH,gBAAA,MAAM,SAAS,GAAG,IAAI,CAAC,MAAM,CAAC,eAAe,CAAC;AAC7C,oBAAA,MAAM,EAAE,eAAe;AACvB,oBAAA,OAAO,EAAE;AACR,wBAAA;AACC,4BAAA,OAAO,EAAE,CAAC;4BACV,QAAQ,EAAE,IAAI,CAAC,OAAO;AACtB,yBAAA;AACD,wBAAA;AACC,4BAAA,OAAO,EAAE,CAAC;AACV,4BAAA,QAAQ,EAAE,OAAO;AACjB,yBAAA;AACD,qBAAA;AACD,iBAAA,CAAC,CAAC;AAEH,gBAAA,WAAW,CAAC,WAAW,CAAC,QAAQ,CAAC,CAAC;AAClC,gBAAA,WAAW,CAAC,YAAY,CAAC,CAAC,EAAE,SAAS,CAAC,CAAC;gBACvC,WAAW,CAAC,IAAI,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;gBAC7B,WAAW,CAAC,GAAG,EAAE,CAAC;gBAElB,OAAO,GAAG,OAAO,CAAC;AAClB,aAAA;AACD,SAAA;;;QAID,IAAI,CAAC,cAAc,EAAE;AACpB,YAAA,MAAM,YAAY,GAAG;AACpB,gBAAA,KAAK,EAAE,IAAI,CAAC,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,KAAK,GAAG,CAAC,CAAC;AAClD,gBAAA,MAAM,EAAE,IAAI,CAAC,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC;AACpD,gBAAA,kBAAkB,EAAE,eAAe;aACnC,CAAC;AAEF,YAAA,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,iBAAiB,CAAC,aAAa,EAAE,EAAE,CAAC,EAAE;gBACzD,cAAc,CAAC,oBAAoB,CAClC;AACC,oBAAA,OAAO,EAAE,UAAU;oBACnB,QAAQ,EAAE,CAAC,GAAG,CAAC;iBACf,EACD;AACC,oBAAA,OAAO,EAAE,OAAO;AAChB,oBAAA,QAAQ,EAAE,CAAC;iBACX,EACD,YAAY,CACZ,CAAC;AAEF,gBAAA,YAAY,CAAC,KAAK,GAAG,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC;AACvD,gBAAA,YAAY,CAAC,MAAM,GAAG,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;AACzD,aAAA;AACD,SAAA;AAED,QAAA,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,cAAc,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC;QAEpD,IAAI,CAAC,cAAc,EAAE;YACpB,UAAU,CAAC,OAAO,EAAE,CAAC;AACrB,SAAA;AAED,QAAA,OAAO,OAAO,CAAC;KACf;AACD;;AC7LD,SAAS,YAAY,CAAC,CAAC,EAAE,CAAC,EAAA;AACzB,IAAA,IAAI,CAAC,KAAK,SAAS,IAAI,CAAC,KAAK,IAAI,EAAE;AAClC,QAAA,OAAO,CAAC,CAAC;AACT,KAAA;AACD,IAAA,OAAO,CAAC,CAAC;AACV,CAAC;AAED;;;;;AAKG;AACH,YAAY,CAAC,YAAY,GAAG,MAAM,CAAC,MAAM,CAAC,EAAE,CAAC;;MCChC,WAAW,CAAA;AAWvB,IAAA,WAAA,GAAA;AACC,QAAA,IAAI,CAAC,WAAW,GAAG,SAAS,CAAC;AAC7B,QAAA,IAAI,CAAC,QAAQ,GAAG,SAAS,CAAC;AAC1B,QAAA,IAAI,CAAC,YAAY,GAAG,SAAS,CAAC;AAC9B,QAAA,IAAI,CAAC,aAAa,GAAG,SAAS,CAAC;AAC/B,QAAA,IAAI,CAAC,gBAAgB,GAAG,CAAC,CAAC;AAC1B,QAAA,IAAI,CAAC,WAAW,GAAG,SAAS,CAAC;AAC7B,QAAA,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC;AAC3B,QAAA,IAAI,CAAC,cAAc,GAAG,KAAK,CAAC;AAC5B,QAAA,IAAI,CAAC,kBAAkB,GAAG,KAAK,CAAC;AAChC,QAAA,IAAI,CAAC,OAAO,GAAG,SAAS,CAAC;KACzB;IACD,IAAI,CAAC,WAAiC,EAAE,OAAgB,EAAA;AACvD,QAAA,MAAM,EAAE,QAAQ,EAAE,WAAW,EAAE,GAAG,OAAO,CAAC;AAC1C,QAAA,MAAM,aAAa,GAAG,IAAI,CAAC,QAAQ,IAAI,QAAQ,CAAC;AAChD,QAAA,MAAM,gBAAgB,GAAG,IAAI,CAAC,WAAW,IAAI,WAAW,CAAC;QACzD,IAAI,IAAI,CAAC,gBAAgB;AAAE,YAAA,WAAW,CAAC,mBAAmB,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC;AAClF,QAAA,IAAI,aAAa,CAAC,oBAAoB,CAAC,aAAa,CAAC,EAAE;AACtD,YAAA,MAAM,EAAE,CAAC,EAAE,CAAC,EAAE,KAAK,EAAE,MAAM,EAAE,QAAQ,EAAE,QAAQ,EAAE,GAAG,aAAa,CAAC;AAClE,YAAA,WAAW,CAAC,WAAW,CAAC,CAAC,EAAE,CAAC,EAAE,KAAK,EAAE,MAAM,EAAE,QAAQ,EAAE,QAAQ,CAAC,CAAC;AACjE,SAAA;QACD,IAAI,IAAI,CAAC,aAAa;AAAE,YAAA,WAAW,CAAC,gBAAgB,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;AACzE,QAAA,IAAI,gBAAgB,CAAC,oBAAoB,CAAC,gBAAgB,CAAC,EAAE;YAC5D,MAAM,EAAE,CAAC,EAAE,CAAC,EAAE,KAAK,EAAE,MAAM,EAAE,GAAG,gBAAgB,CAAC;YACjD,WAAW,CAAC,cAAc,CAAC,CAAC,EAAE,CAAC,EAAE,KAAK,EAAE,MAAM,CAAC,CAAC;AAChD,SAAA;KACD;IACD,OAAO,GAAA;AACN,QAAA,IAAI,CAAC,WAAW,GAAG,SAAS,CAAC;AAC7B,QAAA,IAAI,CAAC,QAAQ,GAAG,SAAS,CAAC;AAC1B,QAAA,IAAI,CAAC,YAAY,GAAG,SAAS,CAAC;AAC9B,QAAA,IAAI,CAAC,aAAa,GAAG,SAAS,CAAC;AAC/B,QAAA,IAAI,CAAC,gBAAgB,GAAG,CAAC,CAAC,CAAC;AAC3B,QAAA,IAAI,CAAC,WAAW,GAAG,SAAS,CAAC;AAC7B,QAAA,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC;AAC3B,QAAA,IAAI,CAAC,cAAc,GAAG,KAAK,CAAC;AAC5B,QAAA,IAAI,CAAC,kBAAkB,GAAG,KAAK,CAAC;KAChC;AACD,CAAA;MA8BY,WAAW,CAAA;AAMvB,IAAA,WAAA,CAAY,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,EAAE,KAAK,GAAG,CAAC,EAAE,MAAM,GAAG,CAAC,EAAE,QAAQ,GAAG,IAAI,EAAA;AAC/D,QAAA,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC;AACX,QAAA,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC;AACX,QAAA,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;AACnB,QAAA,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;AACrB,QAAA,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;KACzB;AACD,IAAA,GAAG,CAAC,CAAS,EAAE,CAAS,EAAE,KAAa,EAAE,MAAc,EAAA;AACtD,QAAA,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC;AACX,QAAA,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC;AACX,QAAA,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;AACnB,QAAA,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;KACrB;AACD,IAAA,oBAAoB,CAAC,WAAwB,EAAA;QAC5C,MAAM,EAAE,CAAC,EAAE,CAAC,EAAE,KAAK,EAAE,MAAM,EAAE,GAAG,WAAW,CAAC;QAC5C,IAAI,IAAI,CAAC,CAAC,IAAI,CAAC,IAAI,IAAI,CAAC,CAAC,IAAI,CAAC,IAAI,IAAI,CAAC,KAAK,IAAI,KAAK,IAAI,IAAI,CAAC,MAAM,IAAI,MAAM,EAAE;AAC/E,YAAA,WAAW,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC,EAAE,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC;AACzD,YAAA,OAAO,IAAI,CAAC;AACZ,SAAA;AACD,QAAA,OAAO,KAAK,CAAC;KACb;AACD,CAAA;MACY,QAAQ,CAAA;IAQpB,WAAY,CAAA,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,EAAE,KAAK,GAAG,CAAC,EAAE,MAAM,GAAG,CAAC,EAAE,QAAQ,GAAG,CAAC,EAAE,QAAQ,GAAG,CAAC,EAAE,QAAQ,GAAG,IAAI,EAAA;AAC3F,QAAA,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC;AACX,QAAA,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC;AACX,QAAA,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;AACnB,QAAA,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;AACrB,QAAA,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;AACzB,QAAA,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;AACzB,QAAA,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;KACzB;AACD,IAAA,GAAG,CAAC,CAAS,EAAE,CAAS,EAAE,KAAa,EAAE,MAAc,EAAE,QAAQ,GAAG,CAAC,EAAE,QAAQ,GAAG,CAAC,EAAA;QAClF,IAAI,CAAC,IAAI,CAAC,QAAQ;YAAE,OAAO;AAC3B,QAAA,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC;AACX,QAAA,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC;AACX,QAAA,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;AACnB,QAAA,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;AACrB,QAAA,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;AACzB,QAAA,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;KACzB;AACD,IAAA,oBAAoB,CAAC,QAAkB,EAAA;AACtC,QAAA,MAAM,EAAE,CAAC,EAAE,CAAC,EAAE,KAAK,EAAE,MAAM,EAAE,QAAQ,EAAE,QAAQ,EAAE,GAAG,QAAQ,CAAC;AAC7D,QAAA,IACC,IAAI,CAAC,CAAC,IAAI,CAAC;YACX,IAAI,CAAC,CAAC,IAAI,CAAC;YACX,IAAI,CAAC,KAAK,IAAI,KAAK;YACnB,IAAI,CAAC,MAAM,IAAI,MAAM;YACrB,IAAI,CAAC,QAAQ,IAAI,QAAQ;AACzB,YAAA,IAAI,CAAC,QAAQ,IAAI,QAAQ,EACxB;YACD,QAAQ,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC,EAAE,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC;AACpF,YAAA,OAAO,IAAI,CAAC;AACZ,SAAA;AACD,QAAA,OAAO,KAAK,CAAC;KACb;AACD,CAAA;MACY,SAAS,CAAA;AAKrB,IAAA,WAAA,CAAY,QAA4B,EAAE,QAAmB,EAAE,SAAqB,EAAE,cAAwB,EAAA;QAC7G,IAAI,CAAC,SAAS,GAAG,YAAY,CAAC,SAAS,EAAE,SAAS,CAAC,GAAG,CAAC,CAAC;QACxD,IAAI,CAAC,QAAQ,GAAG,YAAY,CAAC,QAAQ,EAAE,QAAQ,CAAC,IAAI,CAAC,CAAC;QACtD,IAAI,CAAC,cAAc,GAAG,YAAY,CAAC,cAAc,EAAE,KAAK,CAAC,CAAC;QAC1D,IAAI,CAAC,QAAQ,GAAG,YAAY,CAAC,QAAQ,EAAE,iBAAiB,CAAC,YAAY,CAAC,CAAC;KACvE;IACD,kBAAkB,GAAA;QACjB,OAAO;YACN,SAAS,EAAE,IAAI,CAAC,SAAS;YACzB,QAAQ,EAAE,IAAI,CAAC,QAAQ;YACvB,cAAc,EAAE,IAAI,CAAC,cAAc;YACnC,QAAQ,EAAE,IAAI,CAAC,QAAQ;SACvB,CAAC;KACF;AACD,CAAA;MACY,YAAY,CAAA;AAkBxB,IAAA,WAAA,CAAY,OAA2B,EAAA;AACtC,QAAA,IAAI,CAAC,MAAM,GAAG,YAAY,CAAC,OAAO,EAAE,MAAM,EAAE,aAAa,CAAC,WAAW,CAAC,CAAC;QACvE,IAAI,CAAC,iBAAiB,GAAG,YAAY,CAAC,OAAO,EAAE,iBAAiB,EAAE,IAAI,CAAC,CAAC;AACxE,QAAA,IAAI,CAAC,YAAY,GAAG,YAAY,CAAC,OAAO,EAAE,YAAY,EAAE,eAAe,CAAC,IAAI,CAAC,CAAC;QAC9E,IAAI,CAAC,eAAe,GAAG,YAAY,CAAC,OAAO,EAAE,eAAe,EAAE,UAAU,CAAC,CAAC;QAC1E,IAAI,CAAC,gBAAgB,GAAG,YAAY,CAAC,OAAO,EAAE,gBAAgB,EAAE,UAAU,CAAC,CAAC;AAC5E,QAAA,IAAI,CAAC,mBAAmB,GAAG,YAAY,CAAC,OAAO,EAAE,mBAAmB,EAAE,eAAe,CAAC,MAAM,CAAC,CAAC;AAC9F,QAAA,IAAI,CAAC,kBAAkB,GAAG,YAAY,CAAC,OAAO,EAAE,kBAAkB,EAAE,gBAAgB,CAAC,IAAI,CAAC,CAAC;AAC3F,QAAA,IAAI,CAAC,uBAAuB,GAAG,YAAY,CAAC,OAAO,EAAE,uBAAuB,EAAE,gBAAgB,CAAC,IAAI,CAAC,CAAC;AACrG,QAAA,IAAI,CAAC,kBAAkB,GAAG,YAAY,CAAC,OAAO,EAAE,kBAAkB,EAAE,gBAAgB,CAAC,IAAI,CAAC,CAAC;AAC3F,QAAA,IAAI,CAAC,kBAAkB,GAAG,YAAY,CAAC,OAAO,EAAE,kBAAkB,EAAE,eAAe,CAAC,MAAM,CAAC,CAAC;AAC5F,QAAA,IAAI,CAAC,iBAAiB,GAAG,YAAY,CAAC,OAAO,EAAE,iBAAiB,EAAE,gBAAgB,CAAC,IAAI,CAAC,CAAC;AACzF,QAAA,IAAI,CAAC,sBAAsB,GAAG,YAAY,CAAC,OAAO,EAAE,sBAAsB,EAAE,gBAAgB,CAAC,IAAI,CAAC,CAAC;AACnG,QAAA,IAAI,CAAC,iBAAiB,GAAG,YAAY,CAAC,OAAO,EAAE,iBAAiB,EAAE,gBAAgB,CAAC,IAAI,CAAC,CAAC;QACzF,IAAI,CAAC,SAAS,GAAG,YAAY,CAAC,OAAO,EAAE,SAAS,EAAE,CAAC,CAAC,CAAC;QACrD,IAAI,CAAC,mBAAmB,GAAG,YAAY,CAAC,OAAO,EAAE,mBAAmB,EAAE,CAAC,CAAC,CAAC;QACzE,IAAI,CAAC,cAAc,GAAG,YAAY,CAAC,OAAO,EAAE,cAAc,EAAE,CAAC,CAAC,CAAC;KAC/D;IACD,qBAAqB,GAAA;QACpB,OAAO;YACN,MAAM,EAAE,IAAI,CAAC,MAAM;YACnB,iBAAiB,EAAE,IAAI,CAAC,iBAAiB;YACzC,YAAY,EAAE,IAAI,CAAC,YAAY;YAC/B,eAAe,EAAE,IAAI,CAAC,eAAe;YACrC,gBAAgB,EAAE,IAAI,CAAC,gBAAgB;AACvC,YAAA,YAAY,EAAE;gBACb,OAAO,EAAE,IAAI,CAAC,mBAAmB;gBACjC,MAAM,EAAE,IAAI,CAAC,kBAAkB;gBAC/B,WAAW,EAAE,IAAI,CAAC,uBAAuB;gBACzC,MAAM,EAAE,IAAI,CAAC,kBAAkB;AAC/B,aAAA;AACD,YAAA,WAAW,EAAE;gBACZ,OAAO,EAAE,IAAI,CAAC,kBAAkB;gBAChC,MAAM,EAAE,IAAI,CAAC,iBAAiB;gBAC9B,WAAW,EAAE,IAAI,CAAC,sBAAsB;gBACxC,MAAM,EAAE,IAAI,CAAC,iBAAiB;AAC9B,aAAA;YACD,SAAS,EAAE,IAAI,CAAC,SAAS;YACzB,mBAAmB,EAAE,IAAI,CAAC,mBAAmB;YAC7C,cAAc,EAAE,IAAI,CAAC,cAAc;SACnC,CAAC;KACF;AACD,CAAA;MACY,MAAM,CAAA;AASlB,IAAA,WAAA,CAAY,OAAqB,EAAA;AAChC,QAAA,IAAI,CAAC,MAAM,GAAG,YAAY,CAAC,OAAO,EAAE,MAAM,EAAE,aAAa,CAAC,UAAU,CAAC,CAAC;AACtE,QAAA,IAAI,CAAC,mBAAmB,GAAG,YAAY,CAAC,OAAO,EAAE,mBAAmB,EAAE,cAAc,CAAC,GAAG,CAAC,CAAC;AAC1F,QAAA,IAAI,CAAC,mBAAmB,GAAG,YAAY,CAAC,OAAO,EAAE,mBAAmB,EAAE,WAAW,EAAE,QAAQ,CAAC,CAAC;AAC7F,QAAA,IAAI,CAAC,mBAAmB,GAAG,YAAY,CAAC,OAAO,EAAE,mBAAmB,EAAE,WAAW,CAAC,gBAAgB,CAAC,CAAC;AACpG,QAAA,IAAI,CAAC,mBAAmB,GAAG,YAAY,CAAC,OAAO,EAAE,mBAAmB,EAAE,cAAc,CAAC,GAAG,CAAC,CAAC;AAC1F,QAAA,IAAI,CAAC,mBAAmB,GAAG,YAAY,CAAC,OAAO,EAAE,mBAAmB,EAAE,WAAW,CAAC,GAAG,CAAC,CAAC;AACvF,QAAA,IAAI,CAAC,mBAAmB,GAAG,YAAY,CAAC,OAAO,EAAE,mBAAmB,EAAE,WAAW,CAAC,GAAG,CAAC,CAAC;AACvF,QAAA,IAAI,CAAC,SAAS,GAAG,YAAY,CAAC,OAAO,EAAE,SAAS,EAAE,aAAa,CAAC,GAAG,CAAC,CAAC;KACrE;IACD,eAAe,GAAA;QACd,OAAO;YACN,MAAM,EAAE,IAAI,CAAC,MAAM;AACnB,YAAA,KAAK,EAAE;AACN,gBAAA,KAAK,EAAE;oBACN,SAAS,EAAE,IAAI,CAAC,mBAAmB;oBACnC,SAAS,EAAE,IAAI,CAAC,mBAAmB;oBACnC,SAAS,EAAE,IAAI,CAAC,mBAAmB;AACnC,iBAAA;AACD,gBAAA,KAAK,EAAE;oBACN,SAAS,EAAE,IAAI,CAAC,mBAAmB;oBACnC,SAAS,EAAE,IAAI,CAAC,mBAAmB;oBACnC,SAAS,EAAE,IAAI,CAAC,mBAAmB;AACnC,iBAAA;AACD,aAAA;YACD,SAAS,EAAE,IAAI,CAAC,SAAS;SACzB,CAAC;KACF;AACD,CAAA;AACD,MAAM,aAAa,GAAG,IAAI,QAAQ,EAAE,CAAC;AACrC,MAAM,gBAAgB,GAAG,IAAI,WAAW,EAAE;;ACtR1C,MAAM,OAAO,CAAA;AAqBZ,IAAA,IAAW,QAAQ,GAAA;QAClB,OAAO,IAAI,CAAC,SAAS,CAAC;KACtB;AAED,IAAA,IAAW,WAAW,GAAA;QACrB,OAAO,IAAI,CAAC,YAAY,CAAC;KACzB;IACD,WAAY,CAAA,EAAE,MAAM,EAAE,SAAS,EAAE,OAAO,EAAE,UAAU,EAAA,GAAqB,EAAE,EAAA;QAC1E,IAAI,CAAC,SAAS,CAAC,WAAW,IAAI,CAAC,SAAS,CAAC,YAAY;AAAE,YAAA,MAAM,IAAI,KAAK,CAAC,sCAAsC,CAAC,CAAC;QAC/G,IAAI,CAAC,MAAM,GAAG,MAAM,IAAI,QAAQ,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC;;QAEzD,IAAI,CAAC,UAAU,GAAG,UAAU,IAAI,MAAM,CAAC,gBAAgB,IAAI,CAAC,CAAC;QAC7D,MAAM,KAAK,GAAG,SAAS,CAAC,WAAW,GAAG,IAAI,CAAC,UAAU,CAAC;QACtD,MAAM,MAAM,GAAG,SAAS,CAAC,YAAY,GAAG,IAAI,CAAC,UAAU,CAAC;AACxD,QAAA,IAAI,CAAC,MAAM,CAAC,KAAK,GAAG,KAAK,CAAC;AAC1B,QAAA,IAAI,CAAC,MAAM,CAAC,MAAM,GAAG,MAAM,CAAC;AAC5B,QAAA,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,KAAK,GAAG,SAAS,CAAC,WAAW,GAAG,IAAI,CAAC;AACvD,QAAA,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,MAAM,GAAG,SAAS,CAAC,YAAY,GAAG,IAAI,CAAC;AACzD,QAAA,SAAS,CAAC,WAAW,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;AACnC,QAAA,IAAI,CAAC,OAAO,GAAG,OAAO,IAAK,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,QAAQ,CAAsB,CAAC;AAEjF,QAAA,IAAI,CAAC,MAAM,GAAG,SAAS,CAAC;KACxB;AAEM,IAAA,MAAM,IAAI,CAChB,cAAc,GAAG,EAAE,EACnB,gBAAgB,GAAG,EAAE,EACrB,6BAA6B,GAAG,EAAE,EAAA;QAElC,IAAI;AACH,YAAA,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE;AAClB,gBAAA,MAAM,IAAI,KAAK,CAAC,CAAA,uCAAA,CAAyC,CAAC,CAAC;AAC3D,aAAA;AACD,YAAA,IAAI,CAAC,SAAS,CAAC,GAAG,EAAE;AACnB,gBAAA,MAAM,IAAI,KAAK,CAAC,CAAA,wBAAA,CAA0B,CAAC,CAAC;AAC5C,aAAA;YAED,IAAI,CAAC,OAAO,GAAG,MAAM,SAAS,CAAC,GAAG,CAAC,cAAc,EAAE,CAAC;YACpD,IAAI,CAAC,MAAM,GAAG,MAAM,IAAI,CAAC,OAAO,CAAC,aAAa,EAAE,CAAC;YACjD,IAAI,CAAC,gBAAgB,GAAG;gBACvB,KAAK,EAAE,IAAI,CAAC,MAAM,CAAC,WAAW,GAAG,IAAI,CAAC,UAAU;gBAChD,MAAM,EAAE,IAAI,CAAC,MAAM,CAAC,YAAY,GAAG,IAAI,CAAC,UAAU;AAClD,gBAAA,KAAK,EAAE,CAAC;aACR,CAAC;YACF,IAAI,CAAC,kBAAkB,GAAG,SAAS,CAAC,GAAG,CAAC,wBAAwB,EAAE,CAAC;YACnE,IAAI,CAAC,MAAM,CAAC,gBAAgB,CAAC,iBAAiB,EAAE,CAAC,KAAK,KAAI;AACzD,gBAAA,OAAO,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;;AAEtB,aAAC,CAAC,CAAC;YACH,IAAI,CAAC,WAAW,GAAG,IAAI,eAAe,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;AACpD,YAAA,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC;gBACtB,MAAM,EAAE,IAAI,CAAC,MAAM;gBACnB,MAAM,EAAE,IAAI,CAAC,kBAAkB;gBAC/B,KAAK,EAAE,YAAY,CAAC,gBAAgB;AACpC,gBAAA,SAAS,EAAE,eAAe;AAC1B,gBAAA,GAAG,6BAA6B;AAChC,aAAA,CAAC,CAAC;AACH,YAAA,IAAI,CAAC,SAAS,GAAG,IAAI,QAAQ,CAC5B,CAAC,EACD,CAAC,EACD,IAAI,CAAC,MAAM,CAAC,WAAW,GAAG,IAAI,CAAC,UAAU,EACzC,IAAI,CAAC,MAAM,CAAC,YAAY,GAAG,IAAI,CAAC,UAAU,CAC1C,CAAC;AACF,YAAA,IAAI,CAAC,YAAY,GAAG,IAAI,WAAW,CAClC,CAAC,EACD,CAAC,EACD,IAAI,CAAC,MAAM,CAAC,WAAW,GAAG,IAAI,CAAC,UAAU,EACzC,IAAI,CAAC,MAAM,CAAC,YAAY,GAAG,IAAI,CAAC,UAAU,CAC1C,CAAC;AACF,SAAA;AAAC,QAAA,OAAO,KAAK,EAAE;AACf,YAAA,OAAO,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;AACrB,YAAA,OAAO,KAAK,CAAC;AACb,SAAA;AAED,QAAA,OAAO,IAAI,CAAC;KACZ;AACM,IAAA,WAAW,CAAC,CAAS,EAAE,CAAS,EAAE,KAAa,EAAE,MAAc,EAAA;AACrE,QAAA,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,KAAK,EAAE,MAAM,CAAC,CAAC;KACxC;IAEM,yBAAyB,GAAA;AAC/B,QAAA,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,IAAI,CAAC,MAAM,CAAC,WAAW,GAAG,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,MAAM,CAAC,YAAY,GAAG,IAAI,CAAC,UAAU,CAAC,CAAC;KAChH;AAEM,IAAA,cAAc,CAAC,CAAS,EAAE,CAAS,EAAE,KAAa,EAAE,MAAc,EAAA;AACxE,QAAA,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,KAAK,EAAE,MAAM,CAAC,CAAC;KAC3C;AACM,IAAA,MAAM,CAAC,KAAa,EAAE,MAAc,EAAE,6BAA6B,GAAG,EAAE,EAAA;AAC9E,QAAA,MAAM,CAAC,GAAG,KAAK,GAAG,IAAI,CAAC,UAAU,CAAC;AAClC,QAAA,MAAM,CAAC,GAAG,MAAM,GAAG,IAAI,CAAC,UAAU,CAAC;QACnC,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,KAAK,GAAG,CAAC,GAAG,IAAI,CAAC;QACnC,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,GAAG,IAAI,CAAC;AACpC,QAAA,IAAI,CAAC,MAAM,CAAC,KAAK,GAAG,CAAC,CAAC;AACtB,QAAA,IAAI,CAAC,MAAM,CAAC,MAAM,GAAG,CAAC,CAAC;QACvB,IAAI,CAAC,gBAAgB,GAAG;AACvB,YAAA,KAAK,EAAE,CAAC;AACR,YAAA,MAAM,EAAE,CAAC;AACT,YAAA,KAAK,EAAE,CAAC;SACR,CAAC;AACF,QAAA,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC;YACtB,MAAM,EAAE,IAAI,CAAC,MAAM;AACnB,YAAA,MAAM,EAAE,SAAS,CAAC,GAAG,CAAC,wBAAwB,EAAE;YAChD,KAAK,EAAE,YAAY,CAAC,gBAAgB;YACpC,SAAS,EAAE,6BAA6B,CAAC,aAAa;AACtD,YAAA,GAAG,6BAA6B;AAChC,SAAA,CAAC,CAAC;KACH;AACD;;AC/Ha,MAAO,OAAO,CAAA;AAU3B,IAAA,WAAA,CAAY,WAA+B,EAAA;AAC1C,QAAA,IAAI,CAAC,WAAW,GAAG,MAAM,CAAC,MAAM,CAC/B;YACC,MAAM,EAAE,aAAa,CAAC,UAAU;YAChC,KAAK,EAAE,eAAe,CAAC,eAAe,GAAG,eAAe,CAAC,QAAQ,GAAG,eAAe,CAAC,iBAAiB;AACrG,YAAA,aAAa,EAAE,KAAK;SACpB,EACD,WAAW,CACX,CAAC;AACF,QAAA,IAAI,CAAC,OAAO,GAAG,WAAW,CAAC,OAAO,CAAC;AACnC,QAAA,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC;QAClB,IAAI,CAAC,SAAS,GAAG,WAAW,CAAC,SAAS,IAAI,KAAK,CAAC;KAChD;AACD,IAAA,IAAI,UAAU,GAAA;QACb,MAAM,EAAE,WAAW,EAAE,UAAU,EAAE,WAAW,EAAE,GAAG,IAAI,CAAC,WAAW,CAAC;;QAElE,OAAO;AACN,YAAA,UAAU,EAAE,YAAY,CAAC,UAAU,EAAE,OAAO,CAAC;AAC7C,YAAA,aAAa,EAAE,YAAY,CAAC,WAAW,EAAE,IAAI,CAAC;AAC9C,YAAA,YAAY,EAAE,WAAW,IAAI,WAAW,GAAG,CAAC,GAAG,IAAI,GAAG,KAAK;SAC3D,CAAC;KACF;AACD,IAAA,IAAI,WAAW,GAAA;QACd,IAAI,CAAC,IAAI,CAAC,YAAY;YACrB,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC;gBAC9C,SAAS,EAA2B,YAAY,CAAC,IAAI,CAAC,WAAW,CAAC,WAAW,EAAE,IAAI,CAAC;AACpF,aAAA,CAAC,CAAC;QACJ,OAAO,IAAI,CAAC,YAAY,CAAC;KACzB;AACD,IAAA,MAAM,CAAC,OAAgB,EAAA;QACtB,IAAI,CAAC,IAAI,CAAC,OAAO;AAAE,YAAA,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;QAC1C,IAAI,IAAI,CAAC,KAAK,EAAE;YACf,IAAI,CAAC,sBAAsB,EAAE,CAAC;AAC9B,YAAA,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;AACnB,YAAA,IAAI,IAAI,CAAC,WAAW,CAAC,IAAI,EAAE;gBAC1B,IAAI,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,EAAE;oBACzC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,SAAS,KAAI;AAC3C,wBAAA,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC;AACzB,qBAAC,CAAC,CAAC;AACH,iBAAA;AAAM,qBAAA;oBACN,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;AACpC,iBAAA;AACD,aAAA;AACD,YAAA,IAAI,IAAI,CAAC,WAAW,CAAC,UAAU,EAAE;gBAChC,IAAI,CAAC,UAAU,GAAG,OAAO,CAAC,WAAW,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC;AAC3D,aAAA;YACD,IAAI,IAAI,CAAC,OAAO;AAAE,gBAAA,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;AAC/C,SAAA;KACD;AACO,IAAA,OAAO,CAAC,OAAkB,EAAA;AACjC,QAAA,MAAM,EACL,MAAM,EACN,KAAK,GAAG,OAAO,CAAC,MAAM,CAAC,KAAK,EAC5B,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,MAAM,EAC9B,KAAK,GAAG,CAAC,EACT,OAAO,GAAG,CAAC,EACX,OAAO,GAAG,CAAC,EACX,QAAQ,GAAG,CAAC,EACZ,CAAC,GAAG,CAAC,EACL,CAAC,GAAG,CAAC,EACL,CAAC,GAAG,CAAC,EACL,MAAM,GAAG,KAAK,EACd,UAAU,GAAG,MAAM,EACnB,kBAAkB,GAAG,KAAK,EAC1B,GAAG,OAAO,CAAC;QACZ,IAAI,MAAM,YAAY,OAAO,EAAE;YAC9B,IAAI,cAAc,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,oBAAoB,EAAE,CAAC;YAChE,cAAc,CAAC,oBAAoB,CAClC;gBACC,OAAO,EAAc,MAAM,CAAC,UAAU;AACtC,gBAAA,MAAM,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC;;aAE1B,EACD;gBACC,OAAO,EAAE,IAAI,CAAC,UAAU;gBACxB,MAAM,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE;gBACzB,QAAQ;;aAER,EACD;gBACC,KAAK;gBACL,MAAM;AACN,gBAAA,kBAAkB,EAAE,CAAC;AACrB,aAAA,CACD,CAAC;AACF,YAAA,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,cAAc,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC;YAC5D,cAAc,GAAG,IAAI,CAAC;AACtB,SAAA;AAAM,aAAA;YACN,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,0BAA0B,CACnD;gBACC,MAAM;AACN,gBAAA,MAAM,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC;aAC1B,EACD;gBACC,OAAO,EAAE,IAAI,CAAC,UAAU;AACxB,gBAAA,MAAM,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC;gBACjB,QAAQ;gBACR,MAAM;gBACN,UAAU;gBACV,kBAAkB;aAClB,EACD,CAAC,KAAK,EAAE,MAAM,EAAE,KAAK,CAAC,CACtB,CAAC;AACF,SAAA;KACD;AACD,IAAA,OAAO,CAAC,KAAa,EAAE,MAAc,EAAE,KAAc,EAAA;QACpD,IAAI,IAAI,CAAC,SAAS;YAAE,OAAO;QAC3B,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACpC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;AACtC,QAAA,IAAI,KAAK;YAAE,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;AAC/C,QAAA,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC;KAClB;IACD,OAAO,GAAA;AACN,QAAA,IAAI,CAAC,UAAU,CAAC,OAAO,EAAE,CAAC;KAC1B;IACO,gBAAgB,GAAA;QACvB,IAAI,OAAO,IAAI,CAAC,WAAW,CAAC,MAAM,KAAK,QAAQ,EAAE;AAChD,YAAA,MAAM,IAAI,KAAK,CAAC,eAAe,CAAC,CAAC;AACjC,SAAA;AACD,QAAA,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,GAAG,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC;AACvD,QAAA,OAAO,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,aAAa,CAAC;AACxC,YAAA,KAAK,EAAE,IAAI,CAAC,WAAW,EAAE,KAAK,IAAI,WAAW;AAC7C,YAAA,IAAI,EAAE,CAAC,KAAK,EAAE,MAAM,EAAE,KAAK,CAAC;AAC5B,YAAA,SAAS,EAAE,IAAI,CAAC,WAAW,CAAC,SAAS,IAAI,IAAI;AAC7C,YAAA,MAAM,EAAE,IAAI,CAAC,WAAW,CAAC,MAA0B;AACnD,YAAA,KAAK,EAAE,IAAI,CAAC,WAAW,CAAC,KAAK;AAC7B,YAAA,aAAa,EAAE,IAAI,CAAC,WAAW,CAAC,aAAa,IAAI,CAAC;AAClD,YAAA,WAAW,EAAE,IAAI,CAAC,WAAW,CAAC,WAAW,IAAI,CAAC;AAC9C,SAAA,CAAC,CAAC;KACH;IACO,sBAAsB,GAAA;AAC7B,QAAA,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,GAAG,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC;QACvD,IAAI,IAAI,CAAC,UAAU,EAAE;AACpB,YAAA,IAAI,KAAK,IAAI,IAAI,CAAC,UAAU,CAAC,KAAK,IAAI,MAAM,IAAI,IAAI,CAAC,UAAU,CAAC,MAAM,EAAE;AACvE,gBAAA,IAAI,CAAC,YAAY,GAAG,SAAS,CAAC;AAC9B,gBAAA,IAAI,CAAC,UAAU,CAAC,OAAO,EAAE,CAAC;AAC1B,gBAAA,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,gBAAgB,EAAE,CAAC;AAC1C,aAAA;AACD,SAAA;AAAM,aAAA;AACN,YAAA,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,gBAAgB,EAAE,CAAC;AAC1C,SAAA;KACD;AACD;;AC5JD,MAAM,OAAO,CAAA;IASZ,WACQ,CAAA,UAAiC,EACxC,UAAsC,GAAA;AACrC,QAAA,IAAI,EAAE,WAAW;AACjB,KAAA,EAAA;QAHM,IAAU,CAAA,UAAA,GAAV,UAAU,CAAuB;AAKxC,QAAA,IAAI,CAAC,UAAU,GAAG,EAAE,CAAC;AACrB,QAAA,MAAM,CAAC,MAAM,CACZ,IAAI,CAAC,UAAU,EACf;AACC,YAAA,SAAS,EAAE,QAAQ;AACnB,YAAA,SAAS,EAAE,QAAQ;;AAEnB,YAAA,YAAY,EAAE,eAAe;AAC7B,YAAA,YAAY,EAAE,eAAe;;SAE7B,EACD,UAAU,CACV,CAAC;AACF,QAAA,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC;KAC7B;AACD,IAAA,MAAM,CAAC,OAAgB,EAAA;QACtB,IAAI,CAAC,IAAI,CAAC,UAAU;AAAE,YAAA,IAAI,CAAC,UAAU,GAAG,OAAO,CAAC,MAAM,CAAC,aAAa,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;KACtF;;AA5BM,OAAW,CAAA,WAAA,GAAG,IAAI,OAAO,CAAC;AAChC,IAAA,SAAS,EAAE,QAAQ;AACnB,IAAA,SAAS,EAAE,QAAQ;AACnB,CAAA,CAAC;;ACNH,MAAM,UAAU,CAAA;IASf,WAAmB,CAAA,KAAuC,EAAE,OAA2B,EAAA;QAApE,IAAK,CAAA,KAAA,GAAL,KAAK,CAAkC;QARnD,IAAE,CAAA,EAAA,GAAc,OAAO,CAAC;QACxB,IAAO,CAAA,OAAA,GAAe,OAAO,CAAC;AAQpC,QAAA,MAAM,CAAC,MAAM,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC;KAC7B;AACD;;ACfuB,SAAA,OAAO,CAAC,KAAK,EAAA;AACpC,IAAA,OAAO,KAAK,KAAK,SAAS,IAAI,KAAK,KAAK,IAAI,CAAC;AAC9C;;;;;;;;;;;;;;;;;;;;;;;;;ACqBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAI,eAAe,GAAG,SAAS,IAAI,EAAE;AACrC,CAAC,IAAI,IAAI,IAAI,SAAS,EAAE;AACxB,EAAE,IAAI,GAAG,IAAI,IAAI,EAAE,CAAC,OAAO,EAAE,CAAC;AAC9B,EAAE;AACF;AACA;AACA,CAAC,IAAI,CAAC,CAAC,GAAG,GAAG,CAAC;AACd,CAAC,IAAI,CAAC,CAAC,GAAG,GAAG,CAAC;AACd,CAAC,IAAI,CAAC,QAAQ,GAAG,UAAU,CAAC;AAC5B,CAAC,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC;AAC9B,CAAC,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC;AAC9B;AACA,CAAC,IAAI,CAAC,EAAE,GAAG,IAAI,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;AAC7B,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;AACnB;AACA,CAAC,IAAI,IAAI,CAAC,WAAW,IAAI,KAAK,EAAE;AAChC,EAAE,IAAI,CAAC,aAAa,CAAC,IAAI,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC;AACxC,EAAE;AACF,MAAM;AACN,EAAE,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;AACvB,EAAE;AACF,EAAC;AACD;AACA;AACA;AACA,eAAe,CAAC,SAAS,CAAC,SAAS,GAAG,SAAS,CAAC,EAAE;AAClD,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;AACtB,CAAC,KAAK,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,EAAE,IAAI,CAAC,GAAG,EAAE,EAAE;AAC/C,EAAE,IAAI,CAAC,GAAG,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,KAAK,EAAE,CAAC,CAAC;AAC7D,EAAE,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,UAAU,MAAM,EAAE,IAAI,UAAU,KAAK,EAAE,IAAI,CAAC,CAAC,GAAG,UAAU,IAAI,UAAU;AACvG,IAAI,IAAI,CAAC,GAAG,CAAC;AACb;AACA;AACA;AACA;AACA,EAAE,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;AAC3B;AACA,EAAE;AACF,EAAC;AACD;AACA;AACA;AACA;AACA;AACA,eAAe,CAAC,SAAS,CAAC,aAAa,GAAG,SAAS,QAAQ,EAAE,UAAU,EAAE;AACzE,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC;AACb,CAAC,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC;AAC1B,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;AACV,CAAC,CAAC,IAAI,IAAI,CAAC,CAAC,CAAC,UAAU,GAAG,IAAI,CAAC,CAAC,GAAG,UAAU,CAAC,CAAC;AAC/C,CAAC,OAAO,CAAC,EAAE,CAAC,EAAE,EAAE;AAChB,EAAE,IAAI,CAAC,GAAG,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,EAAE,EAAC;AAC9C,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,UAAU,MAAM,EAAE,IAAI,OAAO,KAAK,EAAE,KAAK,CAAC,CAAC,GAAG,UAAU,IAAI,OAAO,CAAC,CAAC;AAC3G,IAAI,QAAQ,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;AACpB,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC;AACpB,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;AACX,EAAE,IAAI,CAAC,EAAE,IAAI,CAAC,CAAC,EAAE,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE;AACzD,EAAE,IAAI,CAAC,EAAE,UAAU,EAAE,CAAC,CAAC,CAAC,CAAC;AACzB,EAAE;AACF,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE;AAC1B,EAAE,IAAI,CAAC,GAAG,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,EAAE,CAAC,CAAC;AAC/C,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,UAAU,MAAM,EAAE,IAAI,UAAU,KAAK,EAAE,IAAI,CAAC,CAAC,GAAG,UAAU,IAAI,UAAU,CAAC;AAC/G,IAAI,CAAC,CAAC;AACN,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC;AACpB,EAAE,CAAC,EAAE,CAAC;AACN,EAAE,IAAI,CAAC,EAAE,IAAI,CAAC,CAAC,EAAE,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE;AACzD,EAAE;AACF;AACA,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,UAAU,CAAC;AACzB,EAAC;AACD;AACA;AACA;AACA,eAAe,CAAC,SAAS,CAAC,UAAU,GAAG,WAAW;AAClD,CAAC,IAAI,CAAC,CAAC;AACP,CAAC,IAAI,KAAK,GAAG,IAAI,KAAK,CAAC,GAAG,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC;AAC3C;AACA;AACA,CAAC,IAAI,IAAI,CAAC,GAAG,IAAI,IAAI,CAAC,CAAC,EAAE;AACzB,EAAE,IAAI,EAAE,CAAC;AACT;AACA,EAAE,IAAI,IAAI,CAAC,GAAG,IAAI,IAAI,CAAC,CAAC,CAAC,CAAC;AAC1B,GAAG,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;AACxB;AACA,EAAE,KAAK,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,EAAE;AACnC,GAAG,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;AACrE,GAAG,IAAI,CAAC,EAAE,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,EAAE,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC;AACjE,GAAG;AACH,EAAE,MAAM,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,EAAE,EAAE;AAC1B,GAAG,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;AACrE,GAAG,IAAI,CAAC,EAAE,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,EAAE,CAAC,EAAE,EAAE,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC;AAC1E,GAAG;AACH,EAAE,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;AACvE,EAAE,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC;AACrE;AACA,EAAE,IAAI,CAAC,GAAG,GAAG,CAAC,CAAC;AACf,EAAE;AACF;AACA,CAAC,CAAC,GAAG,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC,CAAC;AACzB;AACA;AACA,CAAC,CAAC,KAAK,CAAC,KAAK,EAAE,CAAC,CAAC;AACjB,CAAC,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,IAAI,UAAU,CAAC;AAC5B,CAAC,CAAC,IAAI,CAAC,CAAC,IAAI,EAAE,IAAI,UAAU,CAAC;AAC7B,CAAC,CAAC,KAAK,CAAC,KAAK,EAAE,CAAC,CAAC;AACjB;AACA,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;AAChB,EAAC;AACD;AACA;AACA;AACA,eAAe,CAAC,SAAS,CAAC,YAAY,GAAG,WAAW;AACpD,CAAC,QAAQ,IAAI,CAAC,UAAU,EAAE,GAAG,CAAC,EAAE;AAChC,EAAC;AACD;AACA;AACA;AACA,eAAe,CAAC,SAAS,CAAC,WAAW,GAAG,WAAW;AACnD,CAAC,OAAO,IAAI,CAAC,UAAU,EAAE,EAAE,GAAG,CAAC,YAAY,CAAC,CAAC;AAC7C;AACA,EAAC;AACD;AACA;AACA,eAAe,CAAC,SAAS,CAAC,MAAM,GAAG,WAAW;AAC9C,CAAC,OAAO,IAAI,CAAC,UAAU,EAAE,EAAE,GAAG,CAAC,YAAY,CAAC,CAAC;AAC7C;AACA,EAAC;AACD;AACA;AACA;AACA,eAAe,CAAC,SAAS,CAAC,WAAW,GAAG,WAAW;AACnD,CAAC,OAAO,CAAC,IAAI,CAAC,UAAU,EAAE,GAAG,GAAG,GAAG,GAAG,CAAC,YAAY,CAAC,CAAC;AACrD;AACA,EAAC;AACD;AACA;AACA;AACA,eAAe,CAAC,SAAS,CAAC,WAAW,GAAG,WAAW;AACnD,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,UAAU,EAAE,GAAG,CAAC,EAAE,CAAC,CAAC,IAAI,CAAC,UAAU,EAAE,GAAG,CAAC,CAAC;AACtD,CAAC,OAAM,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,GAAG,GAAG,CAAC,kBAAkB,CAAC,CAAC;AACjD,EAAC;AACD;AACA;AACA;AACA,IAAA,eAAc,GAAG,eAAe;;AC7MhC,MAAM,KAAK,CAAA;IAyDV,OAAO,WAAW,CAAC,KAAK,EAAA;AACvB,QAAA,OAAO,KAAK,GAAG,GAAG,GAAG,CAAC,GAAG,GAAG,GAAG,CAAC;KAChC;AAED,IAAA,OAAO,OAAO,CAAC,KAAa,EAAE,YAAoB,EAAA;AACjD,QAAA,YAAY,GAAG,YAAY,CAAC,YAAY,EAAE,GAAG,CAAC,CAAC;QAC/C,OAAO,IAAI,CAAC,KAAK,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,KAAK,EAAE,CAAC,GAAG,EAAE,GAAG,CAAC,GAAG,GAAG,GAAG,GAAG,IAAI,YAAY,CAAC,CAAC;KAC9E;AAED,IAAA,OAAO,SAAS,CAAC,KAAa,EAAE,YAAoB,EAAA;AACnD,QAAA,YAAY,GAAG,YAAY,CAAC,YAAY,EAAE,GAAG,CAAC,CAAC;AAC/C,QAAA,OAAO,CAAC,KAAK,CAAC,KAAK,CAAC,KAAK,EAAE,GAAG,EAAE,YAAY,CAAC,GAAG,YAAY,IAAI,GAAG,GAAG,GAAG,CAAC;KAC1E;AAED,IAAA,OAAO,SAAS,CAAC,KAAa,EAAE,YAAoB,EAAE,YAAoB,EAAA;QACzE,YAAY,GAAG,IAAI,CAAC,GAAG,CAAC,YAAY,GAAG,YAAY,EAAE,GAAG,CAAC,CAAC;QAC1D,OAAO,YAAY,KAAK,GAAG,GAAG,GAAG,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC,KAAK,GAAG,YAAY,IAAI,YAAY,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC;KACjG;AAUD,IAAA,OAAO,IAAI,CAAC,CAAS,EAAE,CAAS,EAAE,IAAY,EAAA;QAC7C,OAAO,CAAC,GAAG,GAAG,IAAI,IAAI,CAAC,GAAG,IAAI,GAAG,CAAC,CAAC;KACnC;IA0BD,OAAO,SAAS,CAAC,OAAe,EAAA;AAC/B,QAAA,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE;AACtB,YAAA,MAAM,IAAI,KAAK,CAAC,sBAAsB,CAAC,CAAC;AACxC,SAAA;AACD,QAAA,OAAO,OAAO,GAAG,KAAK,CAAC,kBAAkB,CAAC;KAC1C;IAED,OAAO,SAAS,CAAC,OAAe,EAAA;AAC/B,QAAA,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE;AACtB,YAAA,MAAM,IAAI,KAAK,CAAC,sBAAsB,CAAC,CAAC;AACxC,SAAA;AACD,QAAA,OAAO,OAAO,GAAG,KAAK,CAAC,kBAAkB,CAAC;KAC1C;IAED,OAAO,cAAc,CAAC,KAAa,EAAA;AAClC,QAAA,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE;AACpB,YAAA,MAAM,IAAI,KAAK,CAAC,oBAAoB,CAAC,CAAC;AACtC,SAAA;AACD,QAAA,IAAI,KAAK,IAAI,CAAC,KAAK,CAAC,EAAE,IAAI,KAAK,IAAI,KAAK,CAAC,EAAE,EAAE;;;AAG5C,YAAA,OAAO,KAAK,CAAC;AACb,SAAA;AACD,QAAA,OAAO,KAAK,CAAC,WAAW,CAAC,KAAK,GAAG,KAAK,CAAC,EAAE,CAAC,GAAG,KAAK,CAAC,EAAE,CAAC;KACtD;IAED,OAAO,WAAW,CAAC,KAAa,EAAA;AAC/B,QAAA,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE;AACpB,YAAA,MAAM,IAAI,KAAK,CAAC,oBAAoB,CAAC,CAAC;AACtC,SAAA;QACD,IAAI,KAAK,IAAI,CAAC,IAAI,KAAK,IAAI,KAAK,CAAC,MAAM,EAAE;;;AAGxC,YAAA,OAAO,KAAK,CAAC;AACb,SAAA;AACD,QAAA,MAAM,GAAG,GAAG,KAAK,CAAC,GAAG,CAAC,KAAK,EAAE,KAAK,CAAC,MAAM,CAAC,CAAC;QAC3C,IAAI,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,KAAK,CAAC,SAAS,IAAI,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,GAAG,KAAK,CAAC,SAAS,EAAE;YACzE,OAAO,KAAK,CAAC,MAAM,CAAC;AACpB,SAAA;AACD,QAAA,OAAO,GAAG,CAAC;KACX;AAED,IAAA,OAAO,GAAG,CAAC,CAAS,EAAE,CAAS,EAAA;AAC9B,QAAA,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE;AAChB,YAAA,MAAM,IAAI,KAAK,CAAC,gBAAgB,CAAC,CAAC;AAClC,SAAA;AACD,QAAA,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE;AAChB,YAAA,MAAM,IAAI,KAAK,CAAC,gBAAgB,CAAC,CAAC;AAClC,SAAA;QACD,IAAI,CAAC,KAAK,GAAG,EAAE;AACd,YAAA,MAAM,IAAI,KAAK,CAAC,sBAAsB,CAAC,CAAC;AACxC,SAAA;QACD,IAAI,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE;;;AAGjE,YAAA,OAAO,CAAC,CAAC;AACT,SAAA;QAED,OAAO,CAAC,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;KACzB;IAED,OAAO,aAAa,CACnB,IAAY,EACZ,KAAa,EACb,eAAuB,EACvB,eAAA,GAA0B,eAAe,EAAA;AAEzC,QAAA,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE;AACnB,YAAA,MAAM,IAAI,KAAK,CAAC,mBAAmB,CAAC,CAAC;AACrC,SAAA;AACD,QAAA,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE;AACpB,YAAA,MAAM,IAAI,KAAK,CAAC,oBAAoB,CAAC,CAAC;AACtC,SAAA;AAED,QAAA,eAAe,GAAG,YAAY,CAAC,eAAe,EAAE,GAAG,CAAC,CAAC;AACrD,QAAA,eAAe,GAAG,YAAY,CAAC,eAAe,EAAE,eAAe,CAAC,CAAC;QACjE,MAAM,OAAO,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,GAAG,KAAK,CAAC,CAAC;QACvC,OAAO,OAAO,IAAI,eAAe,IAAI,OAAO,IAAI,eAAe,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC;KAC5G;IAED,OAAO,QAAQ,CAAC,IAAY,EAAE,KAAa,EAAE,eAAe,GAAG,CAAC,EAAA;AAC/D,QAAA,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE;AACnB,YAAA,MAAM,IAAI,KAAK,CAAC,oBAAoB,CAAC,CAAC;AACtC,SAAA;AACD,QAAA,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE;AACpB,YAAA,MAAM,IAAI,KAAK,CAAC,qBAAqB,CAAC,CAAC;AACvC,SAAA;AACD,QAAA,IAAI,CAAC,OAAO,CAAC,eAAe,CAAC,EAAE;AAC9B,YAAA,MAAM,IAAI,KAAK,CAAC,8BAA8B,CAAC,CAAC;AAChD,SAAA;AACD,QAAA,OAAO,IAAI,GAAG,KAAK,GAAG,CAAC,eAAe,CAAC;KACvC;IAED,OAAO,gBAAgB,CAAC,IAAY,EAAE,KAAa,EAAE,eAAe,GAAG,CAAC,EAAA;AACvE,QAAA,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE;AACnB,YAAA,MAAM,IAAI,KAAK,CAAC,oBAAoB,CAAC,CAAC;AACtC,SAAA;AACD,QAAA,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE;AACpB,YAAA,MAAM,IAAI,KAAK,CAAC,qBAAqB,CAAC,CAAC;AACvC,SAAA;AACD,QAAA,IAAI,CAAC,OAAO,CAAC,eAAe,CAAC,EAAE;AAC9B,YAAA,MAAM,IAAI,KAAK,CAAC,8BAA8B,CAAC,CAAC;AAChD,SAAA;AACD,QAAA,OAAO,IAAI,GAAG,KAAK,GAAG,eAAe,CAAC;KACtC;IAED,OAAO,WAAW,CAAC,IAAY,EAAE,KAAa,EAAE,eAAe,GAAG,CAAC,EAAA;AAClE,QAAA,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE;AACnB,YAAA,MAAM,IAAI,KAAK,CAAC,oBAAoB,CAAC,CAAC;AACtC,SAAA;AACD,QAAA,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE;AACpB,YAAA,MAAM,IAAI,KAAK,CAAC,qBAAqB,CAAC,CAAC;AACvC,SAAA;AACD,QAAA,IAAI,CAAC,OAAO,CAAC,eAAe,CAAC,EAAE;AAC9B,YAAA,MAAM,IAAI,KAAK,CAAC,8BAA8B,CAAC,CAAC;AAChD,SAAA;AACD,QAAA,OAAO,IAAI,GAAG,KAAK,GAAG,eAAe,CAAC;KACtC;IAED,OAAO,mBAAmB,CAAC,IAAY,EAAE,KAAa,EAAE,eAAe,GAAG,CAAC,EAAA;AAC1E,QAAA,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE;AACnB,YAAA,MAAM,IAAI,KAAK,CAAC,oBAAoB,CAAC,CAAC;AACtC,SAAA;AACD,QAAA,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE;AACpB,YAAA,MAAM,IAAI,KAAK,CAAC,qBAAqB,CAAC,CAAC;AACvC,SAAA;AACD,QAAA,IAAI,CAAC,OAAO,CAAC,eAAe,CAAC,EAAE;AAC9B,YAAA,MAAM,IAAI,KAAK,CAAC,8BAA8B,CAAC,CAAC;AAChD,SAAA;AACD,QAAA,OAAO,IAAI,GAAG,KAAK,GAAG,CAAC,eAAe,CAAC;KACvC;IAED,OAAO,YAAY,CAAC,CAAS,EAAA;;AAE5B,QAAA,IAAI,OAAO,CAAC,KAAK,QAAQ,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,UAAU,EAAE;AACrD,YAAA,MAAM,IAAI,KAAK,CAAC,8CAA8C,CAAC,CAAC;AAChE,SAAA;;AAGD,QAAA,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,MAAM,CAAC,CAAC;KACtC;IAED,OAAO,cAAc,CAAC,CAAS,EAAA;AAC9B,QAAA,IAAI,OAAO,CAAC,KAAK,QAAQ,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,UAAU,EAAE;AACrD,YAAA,MAAM,IAAI,KAAK,CAAC,0CAA0C,CAAC,CAAC;AAC5D,SAAA;;AAED,QAAA,EAAE,CAAC,CAAC;AACJ,QAAA,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;AACZ,QAAA,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;AACZ,QAAA,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;AACZ,QAAA,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;AACZ,QAAA,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC;AACb,QAAA,EAAE,CAAC,CAAC;AAEJ,QAAA,OAAO,CAAC,CAAC;KACT;IAED,OAAO,kBAAkB,CAAC,CAAS,EAAA;AAClC,QAAA,IAAI,OAAO,CAAC,KAAK,QAAQ,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,UAAU,EAAE;AACrD,YAAA,MAAM,IAAI,KAAK,CAAC,8CAA8C,CAAC,CAAC;AAChE,SAAA;AAED,QAAA,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;AACZ,QAAA,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;AACZ,QAAA,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;AACZ,QAAA,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;AACZ,QAAA,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC;AACb,QAAA,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC;;AAGb,QAAA,CAAC,GAAG,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC;AAE1B,QAAA,OAAO,CAAC,CAAC;KACT;AAED,IAAA,OAAO,KAAK,CAAC,KAAa,EAAE,GAAW,EAAE,GAAW,EAAA;QACnD,OAAO,KAAK,GAAG,GAAG,GAAG,GAAG,GAAG,KAAK,GAAG,GAAG,GAAG,GAAG,GAAG,KAAK,CAAC;KACrD;AAwDD;;AAEG;AACH,IAAA,OAAO,GAAG,CAAC,gBAAwB,EAAE,OAAe,EAAA;AACnD,QAAA,MAAM,MAAM,GAAG,gBAAgB,GAAG,OAAO,CAAC;AAC1C,QAAA,OAAO,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC,CAAC,CAAC;KAC1C;;AA/Va,KAAQ,CAAA,QAAA,GAAG,GAAG,CAAC;AAEf,KAAQ,CAAA,QAAA,GAAG,IAAI,CAAC;AAEhB,KAAQ,CAAA,QAAA,GAAG,KAAK,CAAC;AACjB,KAAQ,CAAA,QAAA,GAAG,MAAM,CAAC;AAElB,KAAQ,CAAA,QAAA,GAAG,OAAO,CAAC;AAEnB,KAAQ,CAAA,QAAA,GAAG,QAAQ,CAAC;AAEpB,KAAQ,CAAA,QAAA,GAAG,SAAS,CAAC;AAErB,KAAQ,CAAA,QAAA,GAAG,UAAU,CAAC;AAEtB,KAAQ,CAAA,QAAA,GAAG,WAAW,CAAC;AAEvB,KAAS,CAAA,SAAA,GAAG,YAAY,CAAC;AAEzB,KAAS,CAAA,SAAA,GAAG,aAAa,CAAC;AAE1B,KAAS,CAAA,SAAA,GAAG,cAAc,CAAC;AAE3B,KAAS,CAAA,SAAA,GAAG,eAAe,CAAC;AAE5B,KAAS,CAAA,SAAA,GAAG,gBAAgB,CAAC;AAE7B,KAAS,CAAA,SAAA,GAAG,iBAAiB,CAAC;AAE9B,KAAS,CAAA,SAAA,GAAG,kBAAkB,CAAC;AAE/B,KAAS,CAAA,SAAA,GAAG,mBAAmB,CAAC;AAEhC,KAAS,CAAA,SAAA,GAAG,oBAAoB,CAAC;AAEjC,KAAS,CAAA,SAAA,GAAG,qBAAqB,CAAC;AAElC,KAAS,CAAA,SAAA,GAAG,sBAAsB,CAAC;AAEnC,KAAS,CAAA,SAAA,GAAG,uBAAuB,CAAC;AAEpC,KAAsB,CAAA,sBAAA,GAAG,cAAc,CAAC;AAExC,KAAA,CAAA,oBAAoB,GAAG,EAAE,GAAG,IAAI,CAAC;AAEjC,KAAc,CAAA,cAAA,GAAG,CAAC,GAAG,IAAI,GAAG,IAAI,GAAG,IAAI,CAAC;AAE/C,KAAI,CAAA,IAAA,GAAG,YAAY,CAAC,IAAI,CAAC,IAAI,EAAE,SAAS,IAAI,CAAC,KAAK,EAAA;AACxD,IAAA,KAAK,GAAG,CAAC,KAAK,CAAC;AACf,IAAA,IAAI,KAAK,KAAK,CAAC,IAAI,KAAK,KAAK,KAAK,EAAE;;AAEnC,QAAA,OAAO,KAAK,CAAC;AACb,KAAA;AACD,IAAA,OAAO,KAAK,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC;AAC3B,CAAC,CAAC,CAAC;AAqBI,KAAI,CAAA,IAAA,GAAG,YAAY,CAAC,IAAI,CAAC,IAAI,EAAE,SAAS,IAAI,CAAC,KAAK,EAAA;AACxD,IAAA,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,KAAK,CAAC,IAAI,GAAG,CAAC;AACnD,CAAC,CAAC,CAAC;AAEI,KAAI,CAAA,IAAA,GAAG,YAAY,CAAC,IAAI,CAAC,IAAI,EAAE,SAAS,IAAI,CAAC,KAAK,EAAA;AACxD,IAAA,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,KAAK,CAAC,IAAI,GAAG,CAAC;AACnD,CAAC,CAAC,CAAC;AAMI,KAAA,CAAA,EAAE,GAAG,IAAI,CAAC,EAAE,CAAC;AAEb,KAAA,CAAA,WAAW,GAAG,GAAG,GAAG,IAAI,CAAC,EAAE,CAAC;AAE5B,KAAA,CAAA,WAAW,GAAG,IAAI,CAAC,EAAE,GAAG,GAAG,CAAC;AAE5B,KAAA,CAAA,aAAa,GAAG,IAAI,CAAC,EAAE,GAAG,GAAG,CAAC;AAE9B,KAAA,CAAA,YAAY,GAAG,IAAI,CAAC,EAAE,GAAG,GAAG,CAAC;AAE7B,KAAA,CAAA,WAAW,GAAG,IAAI,CAAC,EAAE,GAAG,GAAG,CAAC;AAE5B,KAAiB,CAAA,iBAAA,GAAG,CAAC,GAAG,GAAG,IAAI,CAAC,EAAE,IAAI,GAAG,CAAC;AAE1C,KAAA,CAAA,MAAM,GAAG,GAAG,GAAG,IAAI,CAAC,EAAE,CAAC;AAEvB,KAAe,CAAA,eAAA,GAAG,GAAG,IAAI,GAAG,GAAG,IAAI,CAAC,EAAE,CAAC,CAAC;AAExC,KAAA,CAAA,kBAAkB,GAAG,IAAI,CAAC,EAAE,GAAG,KAAK,CAAC;AAErC,KAAA,CAAA,kBAAkB,GAAG,KAAK,GAAG,IAAI,CAAC,EAAE,CAAC;AAErC,KAAA,CAAA,qBAAqB,GAAG,KAAK,CAAC,kBAAkB,GAAG,MAAM,CAAC;AAsL1D,KAAA,CAAA,gBAAgB,GAAG,YAAA;AACzB,IAAA,OAAO,qBAAqB,CAAC,MAAM,EAAE,CAAC;AACvC,CAAC,CAAC;AAEK,KAAA,CAAA,aAAa,GAAG,UAAU,GAAW,EAAE,GAAW,EAAA;AACxD,IAAA,OAAO,KAAK,CAAC,gBAAgB,EAAE,IAAI,GAAG,GAAG,GAAG,CAAC,GAAG,GAAG,CAAC;AACrD,CAAC,CAAC;AAEK,KAAW,CAAA,WAAA,GAAG,UAAU,KAAa,EAAA;AAC3C,IAAA,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE;AACpB,QAAA,MAAM,IAAI,KAAK,CAAC,oBAAoB,CAAC,CAAC;AACtC,KAAA;AAED,IAAA,OAAO,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,KAAK,EAAE,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC;AACjD,CAAC,CAAC;AAEK,KAAW,CAAA,WAAA,GAAG,UAAU,KAAa,EAAA;AAC3C,IAAA,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE;AACpB,QAAA,MAAM,IAAI,KAAK,CAAC,oBAAoB,CAAC,CAAC;AACtC,KAAA;AAED,IAAA,OAAO,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,KAAK,EAAE,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC;AACjD,CAAC,CAAC;AAEK,KAAA,CAAA,WAAW,GAAG,UAAU,KAAa,EAAE,MAAc,EAAA;AAC3D,IAAA,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE;AACpB,QAAA,MAAM,IAAI,KAAK,CAAC,oBAAoB,CAAC,CAAC;AACtC,KAAA;AACD,IAAA,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE;AACrB,QAAA,MAAM,IAAI,KAAK,CAAC,qBAAqB,CAAC,CAAC;AACvC,KAAA;AAED,IAAA,OAAO,GAAG,GAAG,MAAM,GAAG,IAAI,CAAC,GAAG,CAAC,KAAK,GAAG,GAAG,CAAC,CAAC;AAC7C,CAAC,CAAC;AAEK,KAAA,CAAA,OAAO,GAAG,UAAU,MAAc,EAAE,IAAY,EAAA;AACtD,IAAA,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE;AACrB,QAAA,MAAM,IAAI,KAAK,CAAC,qBAAqB,CAAC,CAAC;AACvC,KAAA;AACD,IAAA,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE;AACnB,QAAA,MAAM,IAAI,KAAK,CAAC,mBAAmB,CAAC,CAAC;AACrC,KAAA;AAED,IAAA,OAAO,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;AAC1C,CAAC,CAAC;AAEK,KAAI,CAAA,IAAA,GAAG,YAAY,CAAC,IAAI,CAAC,IAAI,EAAE,SAAS,IAAI,CAAC,MAAM,EAAA;AACzD,IAAA,MAAM,MAAM,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,GAAG,GAAG,GAAG,CAAC,CAAC;AACrD,IAAA,OAAO,MAAM,GAAG,GAAG,GAAG,CAAC,MAAM,GAAG,MAAM,CAAC;AACxC,CAAC,CAAC,CAAC;AACI,KAAI,CAAA,IAAA,GAAG,YAAY,CAAC,IAAI,CAAC,IAAI,EAAE,SAAS,IAAI,CAAC,MAAM,EAAA;IACzD,OAAO,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC;AACtC,CAAC,CAAC,CAAC;AAUJ,MAAM,qBAAqB,GAAG,IAAIA,eAAe,EAAE;;AClWnD;;;;;;;;AAQG;AACH,MAAM,OAAO,CAAA;AASZ,IAAA,WAAA,CAAmB,CAAY,GAAA,GAAG,EAAS,CAAA,GAAY,GAAG,EAAA;QAAvC,IAAC,CAAA,CAAA,GAAD,CAAC,CAAc;QAAS,IAAC,CAAA,CAAA,GAAD,CAAC,CAAc;AACzD,QAAA,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC;AACX,QAAA,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC;KACX;IACD,GAAG,CAAC,CAAS,EAAE,CAAS,EAAA;AACvB,QAAA,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC;AACX,QAAA,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC;AACX,QAAA,OAAO,IAAI,CAAC;KACZ;IACD,OAAO,GAAA;QACN,OAAO,CAAC,IAAI,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC,CAAC,CAAC;KACxB;AAED,IAAA,KAAK,CAAC,MAAe,EAAA;QACpB,OAAO,OAAO,CAAC,KAAK,CAAC,IAAI,EAAE,MAAM,CAAC,CAAC;KACnC;AAED,IAAA,MAAM,CAAC,KAAc,EAAA;QACpB,OAAO,OAAO,CAAC,MAAM,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC;KACnC;IACD,aAAa,CAAC,KAAc,EAAE,eAAe,GAAG,CAAC,EAAE,eAAe,GAAG,CAAC,EAAA;AACrE,QAAA,OAAO,OAAO,CAAC,aAAa,CAAC,IAAI,EAAE,KAAK,EAAE,eAAe,EAAE,eAAe,CAAC,CAAC;KAC5E;IAED,QAAQ,GAAA;QACP,OAAO,CAAA,CAAA,EAAI,IAAI,CAAC,CAAC,KAAK,IAAI,CAAC,CAAC,CAAA,CAAA,CAAG,CAAC;KAChC;IACD,mBAAmB,CAAC,SAAoB,EAAE,KAAa,EAAA;QACtD,IAAI,CAAC,CAAC,GAAG,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAC/B,IAAI,CAAC,CAAC,GAAG,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;AAC/B,QAAA,OAAO,IAAI,CAAC;KACZ;AACD,IAAA,YAAY,CAAC,OAAgB,EAAA;QAC5B,MAAM,CAAC,GAAG,IAAI,CAAC,CAAC,EACf,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC;QACZ,IAAI,CAAC,CAAC,GAAG,OAAO,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,OAAO,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,OAAO,CAAC,CAAC,CAAC,CAAC;QACtD,IAAI,CAAC,CAAC,GAAG,OAAO,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,OAAO,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,OAAO,CAAC,CAAC,CAAC,CAAC;AACtD,QAAA,OAAO,IAAI,CAAC;KACZ;AAED,IAAA,OAAO,YAAY,CAAC,CAAS,EAAE,CAAS,EAAE,MAAe,EAAA;AACxD,QAAA,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE;AACrB,YAAA,OAAO,IAAI,OAAO,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;AACzB,SAAA;AAED,QAAA,MAAM,CAAC,CAAC,GAAG,CAAC,CAAC;AACb,QAAA,MAAM,CAAC,CAAC,GAAG,CAAC,CAAC;AACb,QAAA,OAAO,MAAM,CAAC;KACd;AAED,IAAA,OAAO,KAAK,CAAC,SAAkB,EAAE,MAAe,EAAA;AAC/C,QAAA,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,EAAE;AACxB,YAAA,OAAO,SAAS,CAAC;AACjB,SAAA;AACD,QAAA,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE;YACrB,OAAO,IAAI,OAAO,CAAC,SAAS,CAAC,CAAC,EAAE,SAAS,CAAC,CAAC,CAAC,CAAC;AAC7C,SAAA;AAED,QAAA,MAAM,CAAC,CAAC,GAAG,SAAS,CAAC,CAAC,CAAC;AACvB,QAAA,MAAM,CAAC,CAAC,GAAG,SAAS,CAAC,CAAC,CAAC;AACvB,QAAA,OAAO,MAAM,CAAC;KACd;IAED,OAAO,gBAAgB,CAAC,SAAkB,EAAA;AACzC,QAAA,OAAO,IAAI,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,EAAE,SAAS,CAAC,CAAC,CAAC,CAAC;KAC1C;IAED,OAAO,gBAAgB,CAAC,SAAkB,EAAA;AACzC,QAAA,OAAO,IAAI,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,EAAE,SAAS,CAAC,CAAC,CAAC,CAAC;KAC1C;AAED,IAAA,OAAO,kBAAkB,CAAC,KAAc,EAAE,MAAe,EAAE,MAAe,EAAA;AACzE,QAAA,MAAM,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,CAAC;AACvC,QAAA,MAAM,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,CAAC;AAEvC,QAAA,OAAO,MAAM,CAAC;KACd;AAED,IAAA,OAAO,kBAAkB,CAAC,KAAc,EAAE,MAAe,EAAE,MAAe,EAAA;AACzE,QAAA,MAAM,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,CAAC;AACvC,QAAA,MAAM,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,CAAC;AACvC,QAAA,OAAO,MAAM,CAAC;KACd;IAED,OAAO,KAAK,CAAC,KAAc,EAAE,GAAY,EAAE,GAAY,EAAE,MAAe,EAAA;AACvE,QAAA,MAAM,CAAC,GAAG,KAAK,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC;AAC7C,QAAA,MAAM,CAAC,GAAG,KAAK,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC;AAE7C,QAAA,MAAM,CAAC,CAAC,GAAG,CAAC,CAAC;AACb,QAAA,MAAM,CAAC,CAAC,GAAG,CAAC,CAAC;AAEb,QAAA,OAAO,MAAM,CAAC;KACd;IAED,OAAO,gBAAgB,CAAC,SAAkB,EAAA;AACzC,QAAA,OAAO,SAAS,CAAC,CAAC,GAAG,SAAS,CAAC,CAAC,GAAG,SAAS,CAAC,CAAC,GAAG,SAAS,CAAC,CAAC,CAAC;KAC7D;IAED,OAAO,SAAS,CAAC,SAAkB,EAAA;QAClC,OAAO,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,gBAAgB,CAAC,SAAS,CAAC,CAAC,CAAC;KACtD;AAED,IAAA,OAAO,QAAQ,CAAC,IAAa,EAAE,KAAc,EAAA;QAC5C,OAAO,CAAC,QAAQ,CAAC,IAAI,EAAE,KAAK,EAAEC,iBAAe,CAAC,CAAC;AAC/C,QAAA,OAAO,OAAO,CAAC,SAAS,CAACA,iBAAe,CAAC,CAAC;KAC1C;AAED,IAAA,OAAO,eAAe,CAAC,IAAa,EAAE,KAAc,EAAA;QACnD,OAAO,CAAC,QAAQ,CAAC,IAAI,EAAE,KAAK,EAAEA,iBAAe,CAAC,CAAC;AAC/C,QAAA,OAAO,OAAO,CAAC,gBAAgB,CAACA,iBAAe,CAAC,CAAC;KACjD;AAED,IAAA,OAAO,SAAS,CAAC,SAAkB,EAAE,MAAe,EAAA;QACnD,MAAM,SAAS,GAAG,OAAO,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC;QAE/C,MAAM,CAAC,CAAC,GAAG,SAAS,CAAC,CAAC,GAAG,SAAS,CAAC;QACnC,MAAM,CAAC,CAAC,GAAG,SAAS,CAAC,CAAC,GAAG,SAAS,CAAC;;AAGnC,QAAA,IAAI,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE;AACvC,YAAA,MAAM,IAAI,KAAK,CAAC,mCAAmC,CAAC,CAAC;AACrD,SAAA;;AAGD,QAAA,OAAO,MAAM,CAAC;KACd;AAED,IAAA,OAAO,GAAG,CAAC,IAAa,EAAE,KAAc,EAAA;AACvC,QAAA,OAAO,IAAI,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;KAC3C;AAED,IAAA,OAAO,KAAK,CAAC,IAAa,EAAE,KAAc,EAAA;AACzC,QAAA,OAAO,IAAI,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;KAC3C;AAED,IAAA,OAAO,kBAAkB,CAAC,IAAa,EAAE,KAAc,EAAE,MAAe,EAAA;QACvE,MAAM,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;QAC5B,MAAM,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;AAC5B,QAAA,OAAO,MAAM,CAAC;KACd;AAED,IAAA,OAAO,gBAAgB,CAAC,IAAa,EAAE,KAAc,EAAE,MAAe,EAAA;QACrE,MAAM,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;QAC5B,MAAM,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;AAC5B,QAAA,OAAO,MAAM,CAAC;KACd;AAED,IAAA,OAAO,GAAG,CAAC,IAAa,EAAE,KAAc,EAAE,MAAe,EAAA;QACxD,MAAM,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;QAC5B,MAAM,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;AAC5B,QAAA,OAAO,MAAM,CAAC;KACd;AAED,IAAA,OAAO,QAAQ,CAAC,IAAa,EAAE,KAAc,EAAE,MAAe,EAAA;QAC7D,MAAM,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;QAC5B,MAAM,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;AAC5B,QAAA,OAAO,MAAM,CAAC;KACd;AAED,IAAA,OAAO,gBAAgB,CAAC,SAAkB,EAAE,MAAc,EAAE,MAAe,EAAA;QAC1E,MAAM,CAAC,CAAC,GAAG,SAAS,CAAC,CAAC,GAAG,MAAM,CAAC;QAChC,MAAM,CAAC,CAAC,GAAG,SAAS,CAAC,CAAC,GAAG,MAAM,CAAC;AAChC,QAAA,OAAO,MAAM,CAAC;KACd;AAED,IAAA,OAAO,cAAc,CAAC,SAAkB,EAAE,MAAc,EAAE,MAAe,EAAA;QACxE,MAAM,CAAC,CAAC,GAAG,SAAS,CAAC,CAAC,GAAG,MAAM,CAAC;QAChC,MAAM,CAAC,CAAC,GAAG,SAAS,CAAC,CAAC,GAAG,MAAM,CAAC;AAChC,QAAA,OAAO,MAAM,CAAC;KACd;AAED,IAAA,OAAO,MAAM,CAAC,SAAkB,EAAE,MAAe,EAAA;AAChD,QAAA,MAAM,CAAC,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,CAAC;AACxB,QAAA,MAAM,CAAC,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,CAAC;AACxB,QAAA,OAAO,MAAM,CAAC;KACd;AAED,IAAA,OAAO,GAAG,CAAC,SAAkB,EAAE,MAAe,EAAA;QAC7C,MAAM,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC;QACjC,MAAM,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC;AACjC,QAAA,OAAO,MAAM,CAAC;KACd;IAED,OAAO,IAAI,CAAC,KAAc,EAAE,GAAY,EAAE,CAAS,EAAE,MAAe,EAAA;QACnE,OAAO,CAAC,gBAAgB,CAAC,GAAG,EAAE,CAAC,EAAEC,aAAW,CAAC,CAAC;AAC9C,QAAA,MAAM,GAAG,OAAO,CAAC,gBAAgB,CAAC,KAAK,EAAE,GAAG,GAAG,CAAC,EAAE,MAAM,CAAC,CAAC;QAC1D,OAAO,OAAO,CAAC,GAAG,CAACA,aAAW,EAAE,MAAM,EAAE,MAAM,CAAC,CAAC;KAChD;AAED,IAAA,OAAO,YAAY,CAAC,IAAa,EAAE,KAAc,EAAA;AAChD,QAAA,OAAO,CAAC,SAAS,CAAC,IAAI,EAAEC,qBAAmB,CAAC,CAAC;AAC7C,QAAA,OAAO,CAAC,SAAS,CAAC,KAAK,EAAEC,sBAAoB,CAAC,CAAC;AAC/C,QAAA,OAAO,KAAK,CAAC,WAAW,CAAC,OAAO,CAAC,GAAG,CAACD,qBAAmB,EAAEC,sBAAoB,CAAC,CAAC,CAAC;KACjF;AAED,IAAA,OAAO,kBAAkB,CAAC,SAAkB,EAAE,MAAe,EAAA;QAC5D,MAAM,CAAC,GAAG,OAAO,CAAC,SAAS,CAAC,SAAS,EAAEC,2BAAyB,CAAC,CAAC;AAClE,QAAA,OAAO,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;AAElB,QAAA,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE;YACf,MAAM,GAAG,OAAO,CAAC,KAAK,CAAC,OAAO,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;AAC/C,SAAA;AAAM,aAAA;YACN,MAAM,GAAG,OAAO,CAAC,KAAK,CAAC,OAAO,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;AAC/C,SAAA;AAED,QAAA,OAAO,MAAM,CAAC;KACd;AAED,IAAA,OAAO,MAAM,CAAC,IAAa,EAAE,KAAc,EAAA;AAC1C,QAAA,OAAO,IAAI,KAAK,KAAK,KAAK,OAAO,CAAC,IAAI,CAAC,IAAI,OAAO,CAAC,KAAK,CAAC,IAAI,IAAI,CAAC,CAAC,KAAK,KAAK,CAAC,CAAC,IAAI,IAAI,CAAC,CAAC,KAAK,KAAK,CAAC,CAAC,CAAC,CAAC;KACvG;AAED;;AAEG;AACH,IAAA,OAAO,WAAW,CAAC,SAAkB,EAAE,KAAe,EAAE,MAAc,EAAA;AACrE,QAAA,OAAO,SAAS,CAAC,CAAC,KAAK,KAAK,CAAC,MAAM,CAAC,IAAI,SAAS,CAAC,CAAC,KAAK,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;KAC1E;AAED,IAAA,OAAO,aAAa,CAAC,IAAa,EAAE,KAAc,EAAE,eAAe,GAAG,CAAC,EAAE,eAAe,GAAG,CAAC,EAAA;QAC3F,QACC,IAAI,KAAK,KAAK;aACb,OAAO,CAAC,IAAI,CAAC;gBACb,OAAO,CAAC,KAAK,CAAC;AACd,gBAAA,KAAK,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC,EAAE,eAAe,EAAE,eAAe,CAAC;AACtE,gBAAA,KAAK,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC,EAAE,eAAe,EAAE,eAAe,CAAC,CAAC,EACvE;KACF;;AA3Oa,OAAA,CAAA,IAAI,GAAG,MAAM,CAAC,MAAM,CAAC,IAAI,OAAO,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC;AAE5C,OAAA,CAAA,GAAG,GAAG,MAAM,CAAC,MAAM,CAAC,IAAI,OAAO,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC;AAE3C,OAAA,CAAA,MAAM,GAAG,MAAM,CAAC,MAAM,CAAC,IAAI,OAAO,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC;AAE9C,OAAA,CAAA,MAAM,GAAG,MAAM,CAAC,MAAM,CAAC,IAAI,OAAO,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC;AAuO7D,MAAMJ,iBAAe,GAAG,IAAI,OAAO,EAAE,CAAC;AACtC,MAAMC,aAAW,GAAG,IAAI,OAAO,EAAE,CAAC;AAClC,MAAMC,qBAAmB,GAAG,IAAI,OAAO,EAAE,CAAC;AAC1C,MAAMC,sBAAoB,GAAG,IAAI,OAAO,EAAE,CAAC;AAC3C,MAAMC,2BAAyB,GAAG,IAAI,OAAO,EAAE;;ACvP/C,MAAM,OAAO,CAAA;IAcZ,WAAY,CAAA,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,EAAA;AAC9B,QAAA,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC;AACX,QAAA,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC;AACX,QAAA,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC;KACX;AACD,IAAA,GAAG,CAAC,CAAS,EAAE,CAAS,EAAE,CAAS,EAAA;AAClC,QAAA,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC;AACX,QAAA,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC;AACX,QAAA,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC;AACX,QAAA,OAAO,IAAI,CAAC;KACZ;IACD,OAAO,GAAA;AACN,QAAA,OAAO,CAAC,IAAI,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC,CAAC,CAAC;KAChC;AAED,IAAA,IAAI,CAAC,CAAU,EAAA;AACd,QAAA,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;AACb,QAAA,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;AACb,QAAA,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;AACb,QAAA,OAAO,IAAI,CAAC;KACZ;IACD,IAAI,CAAC,GAAY,EAAE,CAAS,EAAA;QAC3B,OAAO,CAAC,IAAI,CAAC,IAAI,EAAE,GAAG,EAAE,CAAC,EAAE,IAAI,CAAC,CAAC;AACjC,QAAA,OAAO,IAAI,CAAC;KACZ;AACD,IAAA,GAAG,CAAC,CAAU,EAAA;QACb,OAAO,CAAC,GAAG,CAAC,IAAI,EAAE,CAAC,EAAE,IAAI,CAAC,CAAC;AAC3B,QAAA,OAAO,IAAI,CAAC;KACZ;IACD,eAAe,CAAC,CAAU,EAAE,CAAS,EAAA;QACpC,IAAI,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;QAClB,IAAI,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;QAClB,IAAI,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;AAClB,QAAA,OAAO,IAAI,CAAC;KACZ;AACD,IAAA,QAAQ,CAAC,CAAU,EAAA;QAClB,OAAO,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC,EAAE,IAAI,CAAC,CAAC;AAChC,QAAA,OAAO,IAAI,CAAC;KACZ;AACD,IAAA,eAAe,CAAC,CAAa,EAAA;AAC5B,QAAA,MAAM,CAAC,GAAG,IAAI,CAAC,CAAC,EACf,CAAC,GAAG,IAAI,CAAC,CAAC,EACV,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC;QACZ,MAAM,EAAE,GAAG,CAAC,CAAC,CAAC,EACb,EAAE,GAAG,CAAC,CAAC,CAAC,EACR,EAAE,GAAG,CAAC,CAAC,CAAC,EACR,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC;;AAIV,QAAA,MAAM,EAAE,GAAG,EAAE,GAAG,CAAC,GAAG,EAAE,GAAG,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC;AACpC,QAAA,MAAM,EAAE,GAAG,EAAE,GAAG,CAAC,GAAG,EAAE,GAAG,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC;AACpC,QAAA,MAAM,EAAE,GAAG,EAAE,GAAG,CAAC,GAAG,EAAE,GAAG,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC;AACpC,QAAA,MAAM,EAAE,GAAG,CAAC,EAAE,GAAG,CAAC,GAAG,EAAE,GAAG,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC;;QAIrC,IAAI,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,EAAE,GAAG,EAAE,GAAG,CAAC,EAAE,GAAG,EAAE,GAAG,CAAC,EAAE,CAAC;QAClD,IAAI,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,EAAE,GAAG,EAAE,GAAG,CAAC,EAAE,GAAG,EAAE,GAAG,CAAC,EAAE,CAAC;QAClD,IAAI,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,EAAE,GAAG,EAAE,GAAG,CAAC,EAAE,GAAG,EAAE,GAAG,CAAC,EAAE,CAAC;AAElD,QAAA,OAAO,IAAI,CAAC;KACZ;IACD,mBAAmB,CAAC,CAAoB,EAAE,KAAa,EAAA;QACtD,OAAO,IAAI,CAAC,SAAS,CAAC,CAAC,EAAE,KAAK,GAAG,CAAC,CAAC,CAAC;KACpC;AACD,IAAA,SAAS,CAAC,KAAwB,EAAE,MAAM,GAAG,CAAC,EAAA;AAC7C,QAAA,IAAI,CAAC,CAAC,GAAG,KAAK,CAAC,MAAM,CAAC,CAAC;QACvB,IAAI,CAAC,CAAC,GAAG,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;QAC3B,IAAI,CAAC,CAAC,GAAG,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;AAE3B,QAAA,OAAO,IAAI,CAAC;KACZ;AAED,IAAA,gBAAgB,CAAC,KAAa,EAAA;QAC7B,OAAO,CAAC,gBAAgB,CAAC,IAAI,EAAE,KAAK,EAAE,IAAI,CAAC,CAAC;AAC5C,QAAA,OAAO,IAAI,CAAC;KACZ;IAED,KAAK,GAAA;QACJ,OAAO,OAAO,CAAC,KAAK,CAAC,IAAI,EAAE,IAAI,OAAO,EAAE,CAAC,CAAC;KAC1C;IACD,MAAM,GAAA;AACL,QAAA,OAAO,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC;KACtE;AACD,IAAA,YAAY,CAAC,MAAe,EAAA;AAC3B,QAAA,MAAM,CAAC,GAAG,IAAI,CAAC,CAAC,EACf,CAAC,GAAG,IAAI,CAAC,CAAC,EACV,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC;QACZ,MAAM,CAAC,GAAG,MAAM,CAAC;AACjB,QAAA,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;AACxD,QAAA,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC;AACtD,QAAA,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC;AACtD,QAAA,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC;AACvD,QAAA,OAAO,IAAI,CAAC;KACZ;AACD,IAAA,YAAY,CAAC,MAAe,EAAA;AAC3B,QAAA,MAAM,CAAC,GAAG,IAAI,CAAC,CAAC,EACf,CAAC,GAAG,IAAI,CAAC,CAAC,EACV,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC;QACZ,IAAI,CAAC,CAAC,GAAG,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QACvD,IAAI,CAAC,CAAC,GAAG,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QACvD,IAAI,CAAC,CAAC,GAAG,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;AACvD,QAAA,OAAO,IAAI,CAAC;KACZ;AACD,IAAA,kBAAkB,CAAC,MAAyB,EAAA;AAC3C,QAAA,MAAM,CAAC,GAAG,IAAI,CAAC,CAAC,EACf,CAAC,GAAG,IAAI,CAAC,CAAC,EACV,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC;QACZ,MAAM,CAAC,GAAG,MAAM,CAAC;QACjB,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;QACxC,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;QACxC,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC;AACzC,QAAA,OAAO,IAAI,CAAC,SAAS,EAAE,CAAC;KACxB;AAED,IAAA,qBAAqB,CAAC,MAAe,EAAA;QACpC,MAAM,CAAC,GAAG,MAAM,CAAC;AAEjB,QAAA,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC;AACf,QAAA,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC;AACf,QAAA,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC;AAEf,QAAA,OAAO,IAAI,CAAC;KACZ;IAED,SAAS,GAAA;AACR,QAAA,OAAO,CAAC,SAAS,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;AAC9B,QAAA,OAAO,IAAI,CAAC;KACZ;AAED,IAAA,MAAM,CAAC,KAAc,EAAA;QACpB,OAAO,OAAO,CAAC,MAAM,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC;KACnC;IAED,aAAa,CAAC,KAAc,EAAE,eAAe,GAAG,CAAC,EAAE,eAAe,GAAG,CAAC,EAAA;AACrE,QAAA,OAAO,OAAO,CAAC,aAAa,CAAC,IAAI,EAAE,KAAK,EAAE,eAAe,EAAE,eAAe,CAAC,CAAC;KAC5E;IAED,QAAQ,GAAA;AACP,QAAA,OAAO,CAAI,CAAA,EAAA,IAAI,CAAC,CAAC,CAAK,EAAA,EAAA,IAAI,CAAC,CAAC,CAAK,EAAA,EAAA,IAAI,CAAC,CAAC,GAAG,CAAC;KAC3C;IACD,mBAAmB,CAAC,SAAoB,EAAE,KAAa,EAAA;QACtD,IAAI,CAAC,CAAC,GAAG,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAC/B,IAAI,CAAC,CAAC,GAAG,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAC/B,IAAI,CAAC,CAAC,GAAG,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;AAC/B,QAAA,OAAO,IAAI,CAAC;KACZ;AACD,IAAA,OAAO,WAAW,CAAC,IAAa,EAAE,MAAe,EAAA;AAChD,QAAA,MAAM,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC;AAClB,QAAA,MAAM,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC;AAClB,QAAA,MAAM,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC;AAClB,QAAA,OAAO,MAAM,CAAC;KACd;AAED,IAAA,OAAO,aAAa,CAAC,SAAoB,EAAE,MAAe,EAAA;AACzD,QAAA,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE;AACrB,YAAA,MAAM,GAAG,IAAI,OAAO,EAAE,CAAC;AACvB,SAAA;QACD,MAAM,EAAE,GAAG,EAAE,MAAM,EAAE,KAAK,EAAE,GAAG,SAAS,CAAC;QACzC,MAAM,YAAY,GAAG,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,MAAM,CAAC;QAC5C,MAAM,CAAC,CAAC,GAAG,YAAY,GAAG,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;QAC1C,MAAM,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,MAAM,CAAC;QAClC,MAAM,CAAC,CAAC,GAAG,YAAY,GAAG,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;AAC1C,QAAA,OAAO,MAAM,CAAC;KACd;IAED,OAAO,YAAY,CAAC,CAAS,EAAE,CAAS,EAAE,CAAS,EAAE,MAAe,EAAA;AACnE,QAAA,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE;YACrB,OAAO,IAAI,OAAO,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;AAC5B,SAAA;AAED,QAAA,MAAM,CAAC,CAAC,GAAG,CAAC,CAAC;AACb,QAAA,MAAM,CAAC,CAAC,GAAG,CAAC,CAAC;AACb,QAAA,MAAM,CAAC,CAAC,GAAG,CAAC,CAAC;AACb,QAAA,OAAO,MAAM,CAAC;KACd;IAED,OAAO,KAAK,CAAC,SAAkB,EAAE,MAAkB,GAAA,IAAI,OAAO,EAAE,EAAA;AAC/D,QAAA,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,EAAE;AACxB,YAAA,OAAO,SAAS,CAAC;AACjB,SAAA;AACD,QAAA,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE;AACrB,YAAA,OAAO,IAAI,OAAO,CAAC,SAAS,CAAC,CAAC,EAAE,SAAS,CAAC,CAAC,EAAE,SAAS,CAAC,CAAC,CAAC,CAAC;AAC1D,SAAA;AAED,QAAA,MAAM,CAAC,CAAC,GAAG,SAAS,CAAC,CAAC,CAAC;AACvB,QAAA,MAAM,CAAC,CAAC,GAAG,SAAS,CAAC,CAAC,CAAC;AACvB,QAAA,MAAM,CAAC,CAAC,GAAG,SAAS,CAAC,CAAC,CAAC;AACvB,QAAA,OAAO,MAAM,CAAC;KACd;IAED,OAAO,gBAAgB,CAAC,SAAkB,EAAA;AACzC,QAAA,OAAO,IAAI,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,EAAE,SAAS,CAAC,CAAC,EAAE,SAAS,CAAC,CAAC,CAAC,CAAC;KACvD;IAED,OAAO,gBAAgB,CAAC,SAAkB,EAAA;AACzC,QAAA,OAAO,IAAI,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,EAAE,SAAS,CAAC,CAAC,EAAE,SAAS,CAAC,CAAC,CAAC,CAAC;KACvD;AAED,IAAA,OAAO,kBAAkB,CAAC,KAAc,EAAE,MAAe,EAAE,MAAe,EAAA;AACzE,QAAA,MAAM,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,CAAC;AACvC,QAAA,MAAM,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,CAAC;AACvC,QAAA,MAAM,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,CAAC;AAEvC,QAAA,OAAO,MAAM,CAAC;KACd;AAED,IAAA,OAAO,kBAAkB,CAAC,KAAc,EAAE,MAAe,EAAE,MAAe,EAAA;AACzE,QAAA,MAAM,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,CAAC;AACvC,QAAA,MAAM,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,CAAC;AACvC,QAAA,MAAM,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,CAAC;AACvC,QAAA,OAAO,MAAM,CAAC;KACd;IAED,OAAO,KAAK,CAAC,KAAc,EAAE,GAAY,EAAE,GAAY,EAAE,MAAe,EAAA;AACvE,QAAA,MAAM,CAAC,GAAG,KAAK,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC;AAC7C,QAAA,MAAM,CAAC,GAAG,KAAK,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC;AAC7C,QAAA,MAAM,CAAC,GAAG,KAAK,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC;AAE7C,QAAA,MAAM,CAAC,CAAC,GAAG,CAAC,CAAC;AACb,QAAA,MAAM,CAAC,CAAC,GAAG,CAAC,CAAC;AACb,QAAA,MAAM,CAAC,CAAC,GAAG,CAAC,CAAC;AAEb,QAAA,OAAO,MAAM,CAAC;KACd;IAED,OAAO,gBAAgB,CAAC,SAAkB,EAAA;QACzC,OAAO,SAAS,CAAC,CAAC,GAAG,SAAS,CAAC,CAAC,GAAG,SAAS,CAAC,CAAC,GAAG,SAAS,CAAC,CAAC,GAAG,SAAS,CAAC,CAAC,GAAG,SAAS,CAAC,CAAC,CAAC;KACzF;IAED,OAAO,SAAS,CAAC,SAAkB,EAAA;QAClC,OAAO,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,gBAAgB,CAAC,SAAS,CAAC,CAAC,CAAC;KACtD;AAED,IAAA,OAAO,QAAQ,CAAC,IAAa,EAAE,KAAc,EAAA;QAC5C,OAAO,CAAC,QAAQ,CAAC,IAAI,EAAE,KAAK,EAAEJ,iBAAe,CAAC,CAAC;AAC/C,QAAA,OAAO,OAAO,CAAC,SAAS,CAACA,iBAAe,CAAC,CAAC;KAC1C;AAED,IAAA,OAAO,eAAe,CAAC,IAAa,EAAE,KAAc,EAAA;QACnD,OAAO,CAAC,QAAQ,CAAC,IAAI,EAAE,KAAK,EAAEA,iBAAe,CAAC,CAAC;AAC/C,QAAA,OAAO,OAAO,CAAC,gBAAgB,CAACA,iBAAe,CAAC,CAAC;KACjD;AAED,IAAA,OAAO,SAAS,CAAC,SAAkB,EAAE,MAAe,EAAA;QACnD,MAAM,SAAS,GAAG,OAAO,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC;QAE/C,MAAM,CAAC,CAAC,GAAG,SAAS,CAAC,CAAC,GAAG,SAAS,CAAC;QACnC,MAAM,CAAC,CAAC,GAAG,SAAS,CAAC,CAAC,GAAG,SAAS,CAAC;QACnC,MAAM,CAAC,CAAC,GAAG,SAAS,CAAC,CAAC,GAAG,SAAS,CAAC;QAEnC,IAAI,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE;AAC1D,YAAA,MAAM,IAAI,KAAK,CAAC,mCAAmC,CAAC,CAAC;AACrD,SAAA;AAED,QAAA,OAAO,MAAM,CAAC;KACd;AAED,IAAA,OAAO,GAAG,CAAC,IAAa,EAAE,KAAc,EAAA;QACvC,OAAO,IAAI,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;KAC9D;AAED,IAAA,OAAO,kBAAkB,CAAC,IAAa,EAAE,KAAc,EAAE,MAAe,EAAA;QACvE,MAAM,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;QAC5B,MAAM,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;QAC5B,MAAM,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;AAC5B,QAAA,OAAO,MAAM,CAAC;KACd;AAED,IAAA,OAAO,gBAAgB,CAAC,IAAa,EAAE,KAAc,EAAE,MAAe,EAAA;QACrE,MAAM,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;QAC5B,MAAM,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;QAC5B,MAAM,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;AAC5B,QAAA,OAAO,MAAM,CAAC;KACd;AAED,IAAA,OAAO,GAAG,CAAC,IAAa,EAAE,KAAc,EAAE,MAAe,EAAA;QACxD,MAAM,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;QAC5B,MAAM,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;QAC5B,MAAM,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;AAC5B,QAAA,OAAO,MAAM,CAAC;KACd;AAED,IAAA,OAAO,QAAQ,CAAC,IAAa,EAAE,KAAc,EAAE,MAAe,EAAA;QAC7D,MAAM,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;QAC5B,MAAM,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;QAC5B,MAAM,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;AAC5B,QAAA,OAAO,MAAM,CAAC;KACd;AAED,IAAA,OAAO,gBAAgB,CAAC,SAAkB,EAAE,MAAc,EAAE,MAAe,EAAA;QAC1E,MAAM,CAAC,CAAC,GAAG,SAAS,CAAC,CAAC,GAAG,MAAM,CAAC;QAChC,MAAM,CAAC,CAAC,GAAG,SAAS,CAAC,CAAC,GAAG,MAAM,CAAC;QAChC,MAAM,CAAC,CAAC,GAAG,SAAS,CAAC,CAAC,GAAG,MAAM,CAAC;AAChC,QAAA,OAAO,MAAM,CAAC;KACd;AAED,IAAA,OAAO,cAAc,CAAC,SAAkB,EAAE,MAAc,EAAE,MAAe,EAAA;QACxE,MAAM,CAAC,CAAC,GAAG,SAAS,CAAC,CAAC,GAAG,MAAM,CAAC;QAChC,MAAM,CAAC,CAAC,GAAG,SAAS,CAAC,CAAC,GAAG,MAAM,CAAC;QAChC,MAAM,CAAC,CAAC,GAAG,SAAS,CAAC,CAAC,GAAG,MAAM,CAAC;AAChC,QAAA,OAAO,MAAM,CAAC;KACd;AAED,IAAA,OAAO,MAAM,CAAC,SAAkB,EAAE,MAAe,EAAA;AAChD,QAAA,MAAM,CAAC,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,CAAC;AACxB,QAAA,MAAM,CAAC,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,CAAC;AACxB,QAAA,MAAM,CAAC,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,CAAC;AACxB,QAAA,OAAO,MAAM,CAAC;KACd;AAED,IAAA,OAAO,GAAG,CAAC,SAAkB,EAAE,MAAe,EAAA;QAC7C,MAAM,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC;QACjC,MAAM,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC;QACjC,MAAM,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC;AACjC,QAAA,OAAO,MAAM,CAAC;KACd;IAED,OAAO,IAAI,CAAC,KAAc,EAAE,GAAY,EAAE,CAAS,EAAE,MAAe,EAAA;QACnE,OAAO,CAAC,gBAAgB,CAAC,GAAG,EAAE,CAAC,EAAEC,aAAW,CAAC,CAAC;AAC9C,QAAA,MAAM,GAAG,OAAO,CAAC,gBAAgB,CAAC,KAAK,EAAE,GAAG,GAAG,CAAC,EAAE,MAAM,CAAC,CAAC;QAC1D,OAAO,OAAO,CAAC,GAAG,CAACA,aAAW,EAAE,MAAM,EAAE,MAAM,CAAC,CAAC;KAChD;AAED,IAAA,OAAO,YAAY,CAAC,IAAa,EAAE,KAAc,EAAA;AAChD,QAAA,OAAO,CAAC,SAAS,CAAC,IAAI,EAAE,mBAAmB,CAAC,CAAC;AAC7C,QAAA,OAAO,CAAC,SAAS,CAAC,KAAK,EAAE,oBAAoB,CAAC,CAAC;QAC/C,MAAM,MAAM,GAAG,OAAO,CAAC,GAAG,CAAC,mBAAmB,EAAE,oBAAoB,CAAC,CAAC;AACtE,QAAA,MAAM,IAAI,GAAG,OAAO,CAAC,SAAS,CAAC,OAAO,CAAC,KAAK,CAAC,mBAAmB,EAAE,oBAAoB,EAAE,mBAAmB,CAAC,CAAC,CAAC;QAC9G,OAAO,IAAI,CAAC,KAAK,CAAC,IAAI,EAAE,MAAM,CAAC,CAAC;KAChC;AAED,IAAA,OAAO,kBAAkB,CAAC,SAAkB,EAAE,MAAe,EAAA;QAC5D,MAAM,CAAC,GAAG,OAAO,CAAC,SAAS,CAAC,SAAS,EAAE,yBAAyB,CAAC,CAAC;AAClE,QAAA,OAAO,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;AAElB,QAAA,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE;AACf,YAAA,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE;gBACf,MAAM,GAAG,OAAO,CAAC,KAAK,CAAC,OAAO,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;AAC/C,aAAA;AAAM,iBAAA;gBACN,MAAM,GAAG,OAAO,CAAC,KAAK,CAAC,OAAO,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;AAC/C,aAAA;AACD,SAAA;AAAM,aAAA,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE;YACtB,MAAM,GAAG,OAAO,CAAC,KAAK,CAAC,OAAO,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;AAC/C,SAAA;AAAM,aAAA;YACN,MAAM,GAAG,OAAO,CAAC,KAAK,CAAC,OAAO,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;AAC/C,SAAA;AAED,QAAA,OAAO,MAAM,CAAC;KACd;AAED,IAAA,OAAO,aAAa,CAAC,CAAU,EAAE,CAAU,EAAE,MAAe,EAAA;AAC3D,QAAA,MAAM,MAAM,GAAG,OAAO,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,GAAG,OAAO,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;QACrD,OAAO,OAAO,CAAC,gBAAgB,CAAC,CAAC,EAAE,MAAM,EAAE,MAAM,CAAC,CAAC;KACnD;AAED,IAAA,OAAO,MAAM,CAAC,IAAa,EAAE,KAAc,EAAA;QAC1C,QACC,IAAI,KAAK,KAAK;AACd,aAAC,OAAO,CAAC,IAAI,CAAC,IAAI,OAAO,CAAC,KAAK,CAAC,IAAI,IAAI,CAAC,CAAC,KAAK,KAAK,CAAC,CAAC,IAAI,IAAI,CAAC,CAAC,KAAK,KAAK,CAAC,CAAC,IAAI,IAAI,CAAC,CAAC,KAAK,KAAK,CAAC,CAAC,CAAC,EAClG;KACF;AAED;;AAEG;AACH,IAAA,OAAO,WAAW,CAAC,SAAkB,EAAE,KAAe,EAAE,MAAc,EAAA;AACrE,QAAA,OAAO,SAAS,CAAC,CAAC,KAAK,KAAK,CAAC,MAAM,CAAC,IAAI,SAAS,CAAC,CAAC,KAAK,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC,IAAI,SAAS,CAAC,CAAC,KAAK,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;KAC/G;AAED,IAAA,OAAO,aAAa,CAAC,IAAa,EAAE,KAAc,EAAE,eAAe,GAAG,CAAC,EAAE,eAAe,GAAG,CAAC,EAAA;QAC3F,QACC,IAAI,KAAK,KAAK;aACb,OAAO,CAAC,IAAI,CAAC;gBACb,OAAO,CAAC,KAAK,CAAC;AACd,gBAAA,KAAK,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC,EAAE,eAAe,EAAE,eAAe,CAAC;AACtE,gBAAA,KAAK,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC,EAAE,eAAe,EAAE,eAAe,CAAC;AACtE,gBAAA,KAAK,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC,EAAE,eAAe,EAAE,eAAe,CAAC,CAAC,EACvE;KACF;AAED,IAAA,OAAO,KAAK,CAAC,IAAa,EAAE,KAAc,EAAE,MAAe,EAAA;AAC1D,QAAA,MAAM,KAAK,GAAG,IAAI,CAAC,CAAC,CAAC;AACrB,QAAA,MAAM,KAAK,GAAG,IAAI,CAAC,CAAC,CAAC;AACrB,QAAA,MAAM,KAAK,GAAG,IAAI,CAAC,CAAC,CAAC;AACrB,QAAA,MAAM,MAAM,GAAG,KAAK,CAAC,CAAC,CAAC;AACvB,QAAA,MAAM,MAAM,GAAG,KAAK,CAAC,CAAC,CAAC;AACvB,QAAA,MAAM,MAAM,GAAG,KAAK,CAAC,CAAC,CAAC;QAEvB,MAAM,CAAC,GAAG,KAAK,GAAG,MAAM,GAAG,KAAK,GAAG,MAAM,CAAC;QAC1C,MAAM,CAAC,GAAG,KAAK,GAAG,MAAM,GAAG,KAAK,GAAG,MAAM,CAAC;QAC1C,MAAM,CAAC,GAAG,KAAK,GAAG,MAAM,GAAG,KAAK,GAAG,MAAM,CAAC;AAE1C,QAAA,MAAM,CAAC,CAAC,GAAG,CAAC,CAAC;AACb,QAAA,MAAM,CAAC,CAAC,GAAG,CAAC,CAAC;AACb,QAAA,MAAM,CAAC,CAAC,GAAG,CAAC,CAAC;AACb,QAAA,OAAO,MAAM,CAAC;KACd;;AA3Za,OAAA,CAAA,IAAI,GAAG,MAAM,CAAC,MAAM,CAAC,IAAI,OAAO,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC;AAEjD,OAAA,CAAA,GAAG,GAAG,MAAM,CAAC,MAAM,CAAC,IAAI,OAAO,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC;AAEhD,OAAA,CAAA,MAAM,GAAG,MAAM,CAAC,MAAM,CAAC,IAAI,OAAO,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC;AAEnD,OAAA,CAAA,MAAM,GAAG,MAAM,CAAC,MAAM,CAAC,IAAI,OAAO,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC;AAEnD,OAAA,CAAA,MAAM,GAAG,MAAM,CAAC,MAAM,CAAC,IAAI,OAAO,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC;AAqZ1D,OAAA,CAAA,QAAQ,GAAG,UAAU,IAAa,EAAE,KAAc,EAAE,MAAe,EAAA;AACzE,IAAA,MAAM,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,IAAI,GAAG,CAAC;AACpC,IAAA,MAAM,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,IAAI,GAAG,CAAC;AACpC,IAAA,MAAM,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,IAAI,GAAG,CAAC;AAEpC,IAAA,OAAO,MAAM,CAAC;AACf,CAAC,CAAC;AAEH,MAAMD,iBAAe,GAAG,IAAI,OAAO,EAAE,CAAC;AACtC,MAAMC,aAAW,GAAG,IAAI,OAAO,EAAE,CAAC;AAClC,MAAM,mBAAmB,GAAG,IAAI,OAAO,EAAE,CAAC;AAC1C,MAAM,oBAAoB,GAAG,IAAI,OAAO,EAAE,CAAC;AAC3C,MAAM,yBAAyB,GAAG,IAAI,OAAO,EAAE;;MC9alC,SAAS,CAAA;AASrB,IAAA,WAAA,CAAmB,IAAY,EAAS,KAAoB,EAAS,QAAgB,EAAA;QAAlE,IAAI,CAAA,IAAA,GAAJ,IAAI,CAAQ;QAAS,IAAK,CAAA,KAAA,GAAL,KAAK,CAAe;QAAS,IAAQ,CAAA,QAAA,GAAR,QAAQ,CAAQ;AACpF,QAAA,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;AACjB,QAAA,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC;AAChB,QAAA,IAAI,CAAC,cAAc,GAAG,CAAC,CAAC;AACxB,QAAA,IAAI,CAAC,aAAa,GAAC,aAAa,CAAC,SAAS,CAAC;KAC3C;IACD,eAAe,GAAA;AACd,QAAA,OAAO,CAAC;gBACP,cAAc,EAAE,IAAI,CAAC,cAAc;gBACnC,MAAM,EAAE,IAAI,CAAC,MAAM;gBACnB,MAAM,EAAE,IAAI,CAAC,MAAM;AACnB,aAAA,CAAC,CAAC;KACH;IACD,OAAO,GAAA;AACN,QAAA,IAAI,CAAC,KAAK,GAAG,EAAE,CAAC;KAChB;AACD,IAAA,YAAY,CAAC,OAAO,EAAA;AACnB,QAAA,IAAI,IAAI,CAAC,QAAQ,KAAK,CAAC,EAAE;YACxB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,GAAG,IAAI,CAAC,QAAQ,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,EAAE;gBAClE,SAAS,CAAC,EAAE,CAAC,mBAAmB,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC;AAC1C,gBAAA,SAAS,CAAC,EAAE,CAAC,YAAY,CAAC,OAAO,CAAC,CAAC;AACnC,gBAAA,IAAI,CAAC,KAAK,CAAC,CAAC,EAAE,SAAS,CAAC,EAAE,CAAC,CAAC,EAAE,SAAS,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;AAC9C,aAAA;AACD,SAAA;AAAM,aAAA,IAAI,IAAI,CAAC,QAAQ,KAAK,CAAC,EAAE;YAC/B,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,GAAG,IAAI,CAAC,QAAQ,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,EAAE;gBAClE,SAAS,CAAC,EAAE,CAAC,mBAAmB,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC;AAC1C,gBAAA,SAAS,CAAC,EAAE,CAAC,YAAY,CAAC,OAAO,CAAC,CAAC;gBACnC,IAAI,CAAC,MAAM,CAAC,CAAC,EAAE,SAAS,CAAC,EAAE,CAAC,CAAC,EAAE,SAAS,CAAC,EAAE,CAAC,CAAC,EAAE,SAAS,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;AAC/D,aAAA;AACD,SAAA;AACD,QAAA,OAAO,IAAI,CAAC;KACZ;AACD,IAAA,YAAY,CAAC,OAAO,EAAA;QACnB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,GAAG,IAAI,CAAC,QAAQ,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,EAAE;YAClE,SAAS,CAAC,EAAE,CAAC,mBAAmB,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC;AAC1C,YAAA,SAAS,CAAC,EAAE,CAAC,YAAY,CAAC,OAAO,CAAC,CAAC;YACnC,IAAI,CAAC,MAAM,CAAC,CAAC,EAAE,SAAS,CAAC,EAAE,CAAC,CAAC,EAAE,SAAS,CAAC,EAAE,CAAC,CAAC,EAAE,SAAS,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;AAC/D,SAAA;AACD,QAAA,OAAO,IAAI,CAAC;KACZ;IACD,IAAI,CAAC,KAAK,EAAE,CAAC,EAAA;QACZ,IAAI,CAAC,KAAK,CAAC,KAAK,GAAG,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC;AACtC,QAAA,OAAO,IAAI,CAAC;KACZ;AACD,IAAA,IAAI,CAAC,KAAK,EAAA;AACT,QAAA,MAAM,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,KAAK,GAAG,IAAI,CAAC,QAAQ,CAAC,CAAC;AAC5C,QAAA,OAAO,CAAC,CAAC;KACT;IACD,IAAI,CAAC,KAAK,EAAE,CAAC,EAAA;AACZ,QAAA,IAAI,CAAC,KAAK,CAAC,KAAK,GAAG,IAAI,CAAC,QAAQ,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC;AAC1C,QAAA,OAAO,IAAI,CAAC;KACZ;AACD,IAAA,IAAI,CAAC,KAAK,EAAA;AACT,QAAA,MAAM,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,KAAK,GAAG,IAAI,CAAC,QAAQ,GAAG,CAAC,CAAC,CAAC;AAChD,QAAA,OAAO,CAAC,CAAC;KACT;IACD,IAAI,CAAC,KAAK,EAAE,CAAC,EAAA;AACZ,QAAA,IAAI,CAAC,KAAK,CAAC,KAAK,GAAG,IAAI,CAAC,QAAQ,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC;AAC1C,QAAA,OAAO,IAAI,CAAC;KACZ;AACD,IAAA,IAAI,CAAC,KAAK,EAAA;AACT,QAAA,MAAM,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,KAAK,GAAG,IAAI,CAAC,QAAQ,GAAG,CAAC,CAAC,CAAC;AAChD,QAAA,OAAO,CAAC,CAAC;KACT;AACD,IAAA,IAAI,CAAC,KAAK,EAAA;AACT,QAAA,MAAM,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,KAAK,GAAG,IAAI,CAAC,QAAQ,GAAG,CAAC,CAAC,CAAC;AAChD,QAAA,OAAO,CAAC,CAAC;KACT;AACD,IAAA,KAAK,CAAC,KAAK,EAAE,CAAC,EAAE,CAAC,EAAA;AAChB,QAAA,KAAK,IAAI,IAAI,CAAC,QAAQ,CAAC;QACvB,IAAI,CAAC,KAAK,CAAC,KAAK,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC;QAC1B,IAAI,CAAC,KAAK,CAAC,KAAK,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC;AAC1B,QAAA,OAAO,IAAI,CAAC;KACZ;AACD,IAAA,MAAM,CAAC,KAAK,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAA;AACpB,QAAA,KAAK,IAAI,IAAI,CAAC,QAAQ,CAAC;QACvB,IAAI,CAAC,KAAK,CAAC,KAAK,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC;QAC1B,IAAI,CAAC,KAAK,CAAC,KAAK,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC;QAC1B,IAAI,CAAC,KAAK,CAAC,KAAK,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC;AAC1B,QAAA,OAAO,IAAI,CAAC;KACZ;IACD,OAAO,CAAC,KAAK,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAA;AACxB,QAAA,KAAK,IAAI,IAAI,CAAC,QAAQ,CAAC;QACvB,IAAI,CAAC,KAAK,CAAC,KAAK,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC;QAC1B,IAAI,CAAC,KAAK,CAAC,KAAK,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC;QAC1B,IAAI,CAAC,KAAK,CAAC,KAAK,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC;QAC1B,IAAI,CAAC,KAAK,CAAC,KAAK,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC;AAC1B,QAAA,OAAO,IAAI,CAAC;KACZ;;AA1Fa,SAAA,CAAA,EAAE,GAAG,IAAI,OAAO,EAAE,CAAC;AACnB,SAAA,CAAA,EAAE,GAAG,IAAI,OAAO,EAAE,CAAC;AA2H5B,MAAO,gBAAiB,SAAQ,SAAS,CAAA;AAC9C,IAAA,WAAA,CAAY,IAAY,EAAE,KAAoB,EAAE,QAAgB,EAAA;AAC/D,QAAA,KAAK,CAAC,IAAI,EAAE,KAAK,EAAE,QAAQ,CAAC,CAAC;AAC7B,QAAA,MAAM,EAAC,MAAM,EAAC,aAAa,EAAC,GAAC,kBAAkB,CAAC,YAAY,CAAC,OAAO,EAAE,QAAQ,CAAC,CAAC;AAChF,QAAA,IAAI,CAAC,MAAM,GAAE,MAAM,CAAA;AACnB,QAAA,IAAI,CAAC,iBAAiB,GAAG,aAAa,CAAC;KACvC;AACD,CAAA;AAQD,IAAY,aAGX,CAAA;AAHD,CAAA,UAAY,aAAa,EAAA;AACxB,IAAA,aAAA,CAAA,aAAA,CAAA,sBAAA,CAAA,GAAA,CAAA,CAAA,GAAA,sBAAsB,CAAA;AACrB,IAAA,aAAA,CAAA,aAAA,CAAA,WAAA,CAAA,GAAA,CAAA,CAAA,GAAA,WAAW,CAAA;AACb,CAAC,EAHW,aAAa,KAAb,aAAa,GAGxB,EAAA,CAAA,CAAA,CAAA;AAMD,SAAS,kBAAkB,CAAC,IAAY,EAAE,QAAgB,EAAA;AACzD,IAAA,MAAM,GAAG,GAAG,CAAA,EAAG,IAAI,CAAI,CAAA,EAAA,QAAQ,EAAE,CAAC;IAClC,OAAO;QACN,CAAC,YAAY,CAAC,OAAO,GAAE,EAAC,MAAM,EAAC,SAAS,EAAC,aAAa,EAAC,YAAY,CAAC,iBAAiB,GAAC,QAAQ,EAAC,QAAQ,EAAC,YAAY,CAAC,iBAAiB,EAAC;QACvI,CAAC,YAAY,CAAC,SAAS,GAAE,EAAC,MAAM,EAAC,WAAW,EAAC,aAAa,EAAC,YAAY,CAAC,iBAAiB,GAAC,QAAQ,EAAC,QAAQ,EAAC,YAAY,CAAC,iBAAiB,EAAC;QAC3I,CAAC,YAAY,CAAC,SAAS,GAAE,EAAC,MAAM,EAAC,WAAW,EAAC,aAAa,EAAC,YAAY,CAAC,iBAAiB,GAAC,QAAQ,EAAC,QAAQ,EAAC,YAAY,CAAC,iBAAiB,EAAC;QAC3I,CAAC,YAAY,CAAC,SAAS,GAAE,EAAC,MAAM,EAAC,WAAW,EAAC,aAAa,EAAC,YAAY,CAAC,iBAAiB,GAAC,QAAQ,EAAC,QAAQ,EAAC,YAAY,CAAC,iBAAiB,EAAC;KAC3I,CAAC,GAAG,CAAC,CAAA;AACP;;ACtKA,MAAM,cAAc,GAAG,IAAI,GAAG,EAAE,CAAC;AACjC,MAAM,SAAS,CAAA;AAad,IAAA,WAAA,CAAY,OAA8B,EAAA;QACzC,IAAI,CAAC,KAAK,GAAG,OAAO,CAAC,KAAK,IAAI,CAAC,CAAC;QAChC,IAAI,CAAC,MAAM,GAAG,OAAO,CAAC,MAAM,IAAI,CAAC,CAAC;QAClC,IAAI,CAAC,WAAW,GAAG,OAAO,CAAC,WAAW,IAAI,CAAC,CAAC;QAC5C,IAAI,CAAC,SAAS,GAAG,OAAO,CAAC,SAAS,IAAI,CAAC,CAAC;QACxC,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC,OAAO,IAAI,KAAK,CAAC;QACxC,IAAI,CAAC,YAAY,GAAG,OAAO,CAAC,MAAM,CAAC,eAAe,CAAC;YAClD,KAAK,EAAE,OAAO,CAAC,KAAK;AACpB,YAAA,MAAM,EAAE,OAAO,CAAC,MAAM,CAAC,kBAAkB;AACzC,YAAA,OAAO,EAAE,OAAO,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,MAAM,MAAM;gBACzC,OAAO,EAAE,MAAM,CAAC,OAAO;gBACvB,QAAQ,EAAE,MAAM,CAAC,QAAQ;AACzB,aAAA,CAAC,CAAC;AACH,SAAA,CAAC,CAAC;KACH;AACD,IAAA,IAAI,CAAC,WAAiC,EAAA;;QAErC,IAAI,IAAI,CAAC,OAAO,EAAE;AACjB,YAAA,MAAM,cAAc,GAAG,CAAC,CAAC,CAAC,CAAC;YAC3B,cAAc,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,WAAW,CAAC;YACnD,IAAI,CAAC,MAAM,GAAG,EAAE,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC;AAC/D,YAAA,WAAW,CAAC,YAAY,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,YAAY,EAAE,cAAc,CAAC,CAAC;AACxE,SAAA;AAAM,aAAA;YACN,WAAW,CAAC,YAAY,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,YAAY,CAAC,CAAC;AACxD,SAAA;KACD;IACD,OAAO,GAAA;AACN,QAAA,IAAI,CAAC,YAAY,GAAG,SAAS,CAAC;AAC9B,QAAA,IAAI,CAAC,MAAM,GAAG,SAAS,CAAC;KACxB;IACD,OAAO,qBAAqB,CAAC,OAA8B,EAAA;QAC1D,IAAI,cAAc,CAAC,GAAG,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE;YACtC,OAAO,cAAc,CAAC,GAAG,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;AACzC,SAAA;AAAM,aAAA;AACN,YAAA,MAAM,SAAS,GAAG,IAAI,SAAS,CAAC,OAAO,CAAC,CAAC;YACzC,cAAc,CAAC,GAAG,CAAC,OAAO,CAAC,KAAK,EAAE,SAAS,CAAC,CAAC;AAC7C,YAAA,OAAO,SAAS,CAAC;AACjB,SAAA;KACD;IACD,OAAO,wBAAwB,CAAC,SAAoB,EAAA;AACnD,QAAA,cAAc,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC;KACjC;AACD;;ACxDa,MAAO,eAAe,CAAA;AAGnC,IAAA,WAAA,CAAY,OAA+B,EAAA;AAC1C,QAAA,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC,OAAO,CAAC;AAC/B,QAAA,IAAI,CAAC,QAAQ,GAAG,OAAO,CAAC,QAAQ,CAAC;KACjC;IACM,iBAAiB,GAAA;QACvB,OAAO;YACN,OAAO,EAAE,IAAI,CAAC,OAAO;YACrB,QAAQ,EAAE,IAAI,CAAC,QAAQ;SACvB,CAAC;KACF;AACD;;ACRD;;;;;;;;;;;AAWG;AACH,MAAM,OAAO,CAAA;AACZ,IAAA,WAAA,CACC,WAAW,GAAG,CAAC,EACf,WAAW,GAAG,CAAC,EACf,WAAW,GAAG,CAAC,EACf,WAAW,GAAG,CAAC,EACf,WAAW,GAAG,CAAC,EACf,WAAW,GAAG,CAAC,EACf,WAAW,GAAG,CAAC,EACf,WAAW,GAAG,CAAC,EACf,WAAW,GAAG,CAAC,EAAA;AAEf,QAAA,IAAI,CAAC,CAAC,CAAC,GAAG,WAAW,CAAC;AACtB,QAAA,IAAI,CAAC,CAAC,CAAC,GAAG,WAAW,CAAC;AACtB,QAAA,IAAI,CAAC,CAAC,CAAC,GAAG,WAAW,CAAC;AACtB,QAAA,IAAI,CAAC,CAAC,CAAC,GAAG,WAAW,CAAC;AACtB,QAAA,IAAI,CAAC,CAAC,CAAC,GAAG,WAAW,CAAC;AACtB,QAAA,IAAI,CAAC,CAAC,CAAC,GAAG,WAAW,CAAC;AACtB,QAAA,IAAI,CAAC,CAAC,CAAC,GAAG,WAAW,CAAC;AACtB,QAAA,IAAI,CAAC,CAAC,CAAC,GAAG,WAAW,CAAC;AACtB,QAAA,IAAI,CAAC,CAAC,CAAC,GAAG,WAAW,CAAC;KACtB;AACD,IAAA,cAAc,CAAC,MAAe,EAAA;QAC7B,IAAI,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QACpB,IAAI,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QACpB,IAAI,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QACpB,IAAI,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QACpB,IAAI,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QACpB,IAAI,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QACpB,IAAI,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QACpB,IAAI,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QACpB,IAAI,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,EAAE,CAAC,CAAC;AACrB,QAAA,OAAO,IAAI,CAAC;KACZ;AACD,IAAA,eAAe,CAAC,OAAgB,EAAA;AAC/B,QAAA,IAAI,CAAC,cAAc,CAAC,OAAO,CAAC,CAAC;AAC7B,QAAA,OAAO,CAAC,OAAO,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;AAC5B,QAAA,OAAO,CAAC,SAAS,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;AAC9B,QAAA,OAAO,IAAI,CAAC;KACZ;AAED,IAAA,OAAO,KAAK,CAAC,MAA0B,EAAE,MAAe,EAAA;AACvD,QAAA,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE;AACrB,YAAA,OAAO,SAAS,CAAC;AACjB,SAAA;AACD,QAAA,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE;YACrB,OAAO,IAAI,OAAO,CACjB,MAAM,CAAC,CAAC,CAAC,EACT,MAAM,CAAC,CAAC,CAAC,EACT,MAAM,CAAC,CAAC,CAAC,EACT,MAAM,CAAC,CAAC,CAAC,EACT,MAAM,CAAC,CAAC,CAAC,EACT,MAAM,CAAC,CAAC,CAAC,EACT,MAAM,CAAC,CAAC,CAAC,EACT,MAAM,CAAC,CAAC,CAAC,EACT,MAAM,CAAC,CAAC,CAAC,CACT,CAAC;AACF,SAAA;QACD,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QACtB,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QACtB,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QACtB,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QACtB,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QACtB,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QACtB,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QACtB,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QACtB,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;AACtB,QAAA,OAAO,MAAM,CAAC;KACd;AAED,IAAA,OAAO,oBAAoB,CAAC,MAAqB,EAAE,MAAgB,EAAA;AAClE,QAAA,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE;AACrB,YAAA,MAAM,GAAG,IAAI,OAAO,EAAE,CAAC;AACvB,SAAA;QACD,OAAO,OAAO,CAAC,KAAK,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;KACrC;AAED,IAAA,OAAO,iBAAiB,CAAC,MAAqB,EAAE,MAAgB,EAAA;AAC/D,QAAA,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE;YACrB,OAAO,IAAI,OAAO,CACjB,MAAM,CAAC,CAAC,CAAC,EACT,MAAM,CAAC,CAAC,CAAC,EACT,MAAM,CAAC,CAAC,CAAC,EACT,MAAM,CAAC,CAAC,CAAC,EACT,MAAM,CAAC,CAAC,CAAC,EACT,MAAM,CAAC,CAAC,CAAC,EACT,MAAM,CAAC,CAAC,CAAC,EACT,MAAM,CAAC,CAAC,CAAC,EACT,MAAM,CAAC,CAAC,CAAC,CACT,CAAC;AACF,SAAA;QACD,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QACtB,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QACtB,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QACtB,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QACtB,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QACtB,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QACtB,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QACtB,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QACtB,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;AACtB,QAAA,OAAO,MAAM,CAAC;KACd;AAED,IAAA,OAAO,cAAc,CAAC,UAAsB,EAAE,MAAgB,EAAA;QAC7D,MAAM,EAAE,GAAG,UAAU,CAAC,CAAC,GAAG,UAAU,CAAC,CAAC,CAAC;QACvC,MAAM,EAAE,GAAG,UAAU,CAAC,CAAC,GAAG,UAAU,CAAC,CAAC,CAAC;QACvC,MAAM,EAAE,GAAG,UAAU,CAAC,CAAC,GAAG,UAAU,CAAC,CAAC,CAAC;QACvC,MAAM,EAAE,GAAG,UAAU,CAAC,CAAC,GAAG,UAAU,CAAC,CAAC,CAAC;QACvC,MAAM,EAAE,GAAG,UAAU,CAAC,CAAC,GAAG,UAAU,CAAC,CAAC,CAAC;QACvC,MAAM,EAAE,GAAG,UAAU,CAAC,CAAC,GAAG,UAAU,CAAC,CAAC,CAAC;QACvC,MAAM,EAAE,GAAG,UAAU,CAAC,CAAC,GAAG,UAAU,CAAC,CAAC,CAAC;QACvC,MAAM,EAAE,GAAG,UAAU,CAAC,CAAC,GAAG,UAAU,CAAC,CAAC,CAAC;QACvC,MAAM,EAAE,GAAG,UAAU,CAAC,CAAC,GAAG,UAAU,CAAC,CAAC,CAAC;QACvC,MAAM,EAAE,GAAG,UAAU,CAAC,CAAC,GAAG,UAAU,CAAC,CAAC,CAAC;QAEvC,MAAM,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC;QAC9B,MAAM,GAAG,GAAG,GAAG,IAAI,EAAE,GAAG,EAAE,CAAC,CAAC;QAC5B,MAAM,GAAG,GAAG,GAAG,IAAI,EAAE,GAAG,EAAE,CAAC,CAAC;QAE5B,MAAM,GAAG,GAAG,GAAG,IAAI,EAAE,GAAG,EAAE,CAAC,CAAC;QAC5B,MAAM,GAAG,GAAG,CAAC,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC;QAC/B,MAAM,GAAG,GAAG,GAAG,IAAI,EAAE,GAAG,EAAE,CAAC,CAAC;QAE5B,MAAM,GAAG,GAAG,GAAG,IAAI,EAAE,GAAG,EAAE,CAAC,CAAC;QAC5B,MAAM,GAAG,GAAG,GAAG,IAAI,EAAE,GAAG,EAAE,CAAC,CAAC;QAC5B,MAAM,GAAG,GAAG,CAAC,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC;AAE/B,QAAA,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE;YACrB,OAAO,IAAI,OAAO,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC;AAChE,SAAA;AACD,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC;AAChB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC;AAChB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC;AAChB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC;AAChB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC;AAChB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC;AAChB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC;AAChB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC;AAChB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC;AAChB,QAAA,OAAO,MAAM,CAAC;KACd;AAED,IAAA,OAAO,SAAS,CAAC,KAAc,EAAE,MAAe,EAAA;AAC/C,QAAA,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE;YACrB,OAAO,IAAI,OAAO,CAAC,KAAK,CAAC,CAAC,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,KAAK,CAAC,CAAC,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,KAAK,CAAC,CAAC,CAAC,CAAC;AAC5E,SAAA;AAED,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;AACpB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC;AAChB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC;AAChB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC;AAChB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;AACpB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC;AAChB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC;AAChB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC;AAChB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;AACpB,QAAA,OAAO,MAAM,CAAC;KACd;AAED,IAAA,OAAO,aAAa,CAAC,KAAa,EAAE,MAAe,EAAA;QAClD,MAAM,QAAQ,GAAG,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;QACjC,MAAM,QAAQ,GAAG,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;AAEjC,QAAA,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE;YACrB,OAAO,IAAI,OAAO,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,QAAQ,EAAE,CAAC,QAAQ,EAAE,GAAG,EAAE,QAAQ,EAAE,QAAQ,CAAC,CAAC;AACrF,SAAA;AAED,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC;AAChB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC;AAChB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC;AAChB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC;AAChB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,QAAQ,CAAC;AACrB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,QAAQ,CAAC;AACrB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC;AAChB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,QAAQ,CAAC;AACtB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,QAAQ,CAAC;AAErB,QAAA,OAAO,MAAM,CAAC;KACd;AAED,IAAA,OAAO,aAAa,CAAC,KAAa,EAAE,MAAe,EAAA;QAClD,MAAM,QAAQ,GAAG,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;QACjC,MAAM,QAAQ,GAAG,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;AAEjC,QAAA,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE;YACrB,OAAO,IAAI,OAAO,CAAC,QAAQ,EAAE,GAAG,EAAE,QAAQ,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC,QAAQ,EAAE,GAAG,EAAE,QAAQ,CAAC,CAAC;AACrF,SAAA;AAED,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,QAAQ,CAAC;AACrB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC;AAChB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,QAAQ,CAAC;AACtB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC;AAChB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC;AAChB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC;AAChB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,QAAQ,CAAC;AACrB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC;AAChB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,QAAQ,CAAC;AAErB,QAAA,OAAO,MAAM,CAAC;KACd;AAED,IAAA,OAAO,mBAAmB,CAAC,KAAa,EAAE,MAAe,EAAA;QACxD,MAAM,QAAQ,GAAG,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;QACjC,MAAM,QAAQ,GAAG,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;AAEjC,QAAA,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE;YACrB,OAAO,IAAI,OAAO,CAAC,QAAQ,EAAE,CAAC,QAAQ,EAAE,GAAG,EAAE,QAAQ,EAAE,QAAQ,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC;AACrF,SAAA;AAED,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,QAAQ,CAAC;AACrB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,QAAQ,CAAC;AACrB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC;AAChB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,QAAQ,CAAC;AACtB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,QAAQ,CAAC;AACrB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC;AAChB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC;AAChB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC;AAChB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC;AAEhB,QAAA,OAAO,MAAM,CAAC;KACd;IACD,OAAO,GAAA;QACN,MAAM,MAAM,GAAG,EAAE,CAAC;AAClB,QAAA,OAAO,CAAC,OAAO,CAAC,IAAI,EAAE,MAAM,CAAC,CAAC;AAC9B,QAAA,OAAO,MAAM,CAAC;KACd;AAED,IAAA,OAAO,OAAO,CAAC,MAAe,EAAE,MAAgB,EAAA;AAC/C,QAAA,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE;YACrB,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;AAC3G,SAAA;QACD,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QACtB,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QACtB,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QACtB,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QACtB,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QACtB,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QACtB,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QACtB,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QACtB,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;AACtB,QAAA,OAAO,MAAM,CAAC;KACd;AAED,IAAA,OAAO,eAAe,CAAC,MAAc,EAAE,GAAW,EAAA;AACjD,QAAA,OAAO,MAAM,GAAG,CAAC,GAAG,GAAG,CAAC;KACxB;AAED,IAAA,OAAO,SAAS,CAAC,MAAe,EAAE,KAAa,EAAE,MAAe,EAAA;AAC/D,QAAA,MAAM,UAAU,GAAG,KAAK,GAAG,CAAC,CAAC;AAC7B,QAAA,MAAM,CAAC,GAAG,MAAM,CAAC,UAAU,CAAC,CAAC;QAC7B,MAAM,CAAC,GAAG,MAAM,CAAC,UAAU,GAAG,CAAC,CAAC,CAAC;QACjC,MAAM,CAAC,GAAG,MAAM,CAAC,UAAU,GAAG,CAAC,CAAC,CAAC;AAEjC,QAAA,MAAM,CAAC,CAAC,GAAG,CAAC,CAAC;AACb,QAAA,MAAM,CAAC,CAAC,GAAG,CAAC,CAAC;AACb,QAAA,MAAM,CAAC,CAAC,GAAG,CAAC,CAAC;AACb,QAAA,OAAO,MAAM,CAAC;KACd;IAED,OAAO,SAAS,CAAC,MAAe,EAAE,KAAa,EAAE,SAAkB,EAAE,MAAe,EAAA;QACnF,MAAM,GAAG,OAAO,CAAC,KAAK,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;AACvC,QAAA,MAAM,UAAU,GAAG,KAAK,GAAG,CAAC,CAAC;AAC7B,QAAA,MAAM,CAAC,UAAU,CAAC,GAAG,SAAS,CAAC,CAAC,CAAC;QACjC,MAAM,CAAC,UAAU,GAAG,CAAC,CAAC,GAAG,SAAS,CAAC,CAAC,CAAC;QACrC,MAAM,CAAC,UAAU,GAAG,CAAC,CAAC,GAAG,SAAS,CAAC,CAAC,CAAC;AACrC,QAAA,OAAO,MAAM,CAAC;KACd;AAED,IAAA,OAAO,MAAM,CAAC,MAAe,EAAE,KAAa,EAAE,MAAe,EAAA;AAC5D,QAAA,MAAM,CAAC,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;QACxB,MAAM,CAAC,GAAG,MAAM,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC;QAC5B,MAAM,CAAC,GAAG,MAAM,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC;AAE5B,QAAA,MAAM,CAAC,CAAC,GAAG,CAAC,CAAC;AACb,QAAA,MAAM,CAAC,CAAC,GAAG,CAAC,CAAC;AACb,QAAA,MAAM,CAAC,CAAC,GAAG,CAAC,CAAC;AACb,QAAA,OAAO,MAAM,CAAC;KACd;IAED,OAAO,MAAM,CAAC,MAAe,EAAE,KAAa,EAAE,SAAkB,EAAE,MAAe,EAAA;QAChF,MAAM,GAAG,OAAO,CAAC,KAAK,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;AACvC,QAAA,MAAM,CAAC,KAAK,CAAC,GAAG,SAAS,CAAC,CAAC,CAAC;QAC5B,MAAM,CAAC,KAAK,GAAG,CAAC,CAAC,GAAG,SAAS,CAAC,CAAC,CAAC;QAChC,MAAM,CAAC,KAAK,GAAG,CAAC,CAAC,GAAG,SAAS,CAAC,CAAC,CAAC;AAChC,QAAA,OAAO,MAAM,CAAC;KACd;AAED,IAAA,OAAO,QAAQ,CAAC,MAAe,EAAE,KAAc,EAAE,MAAe,EAAA;QAC/D,MAAM,aAAa,GAAG,OAAO,CAAC,QAAQ,CAAC,MAAM,EAAEI,eAAa,CAAC,CAAC;QAC9D,MAAM,WAAW,GAAG,KAAK,CAAC,CAAC,GAAG,aAAa,CAAC,CAAC,CAAC;QAC9C,MAAM,WAAW,GAAG,KAAK,CAAC,CAAC,GAAG,aAAa,CAAC,CAAC,CAAC;QAC9C,MAAM,WAAW,GAAG,KAAK,CAAC,CAAC,GAAG,aAAa,CAAC,CAAC,CAAC;QAE9C,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,WAAW,CAAC;QACpC,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,WAAW,CAAC;QACpC,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,WAAW,CAAC;QACpC,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,WAAW,CAAC;QACpC,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,WAAW,CAAC;QACpC,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,WAAW,CAAC;QACpC,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,WAAW,CAAC;QACpC,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,WAAW,CAAC;QACpC,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,WAAW,CAAC;AAEpC,QAAA,OAAO,MAAM,CAAC;KACd;AAED,IAAA,OAAO,QAAQ,CAAC,MAAe,EAAE,MAAe,EAAA;AAC/C,QAAA,MAAM,CAAC,CAAC,GAAG,OAAO,CAAC,SAAS,CAAC,OAAO,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,EAAEC,eAAa,CAAC,CAAC,CAAC;AACnG,QAAA,MAAM,CAAC,CAAC,GAAG,OAAO,CAAC,SAAS,CAAC,OAAO,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,EAAEA,eAAa,CAAC,CAAC,CAAC;AACnG,QAAA,MAAM,CAAC,CAAC,GAAG,OAAO,CAAC,SAAS,CAAC,OAAO,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,EAAEA,eAAa,CAAC,CAAC,CAAC;AACnG,QAAA,OAAO,MAAM,CAAC;KACd;IAED,OAAO,eAAe,CAAC,MAAe,EAAA;AACrC,QAAA,OAAO,CAAC,QAAQ,CAAC,MAAM,EAAEC,eAAa,CAAC,CAAC;AACxC,QAAA,OAAO,OAAO,CAAC,gBAAgB,CAACA,eAAa,CAAC,CAAC;KAC/C;AAED,IAAA,OAAO,WAAW,CAAC,MAAe,EAAE,QAAiB,EAAE,MAAe,EAAA;QACrE,MAAM,KAAK,GAAG,OAAO,CAAC,QAAQ,CAAC,MAAM,EAAEC,eAAa,CAAC,CAAC;AAEtD,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;AAClC,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;AAClC,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;AAClC,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;AAClC,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;AAClC,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;AAClC,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;AAClC,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;AAClC,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;AAElC,QAAA,OAAO,MAAM,CAAC;KACd;AAED,IAAA,OAAO,WAAW,CAAC,MAAe,EAAE,MAAe,EAAA;QAClD,MAAM,KAAK,GAAG,OAAO,CAAC,QAAQ,CAAC,MAAM,EAAEC,eAAa,CAAC,CAAC;AAEtD,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;AAChC,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;AAChC,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;AAChC,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;AAChC,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;AAChC,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;AAChC,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;AAChC,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;AAChC,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;AAEhC,QAAA,OAAO,MAAM,CAAC;KACd;AAED,IAAA,OAAO,QAAQ,CAAC,IAAa,EAAE,KAAc,EAAE,MAAe,EAAA;AAC7D,QAAA,MAAM,WAAW,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;AACjF,QAAA,MAAM,WAAW,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;AACjF,QAAA,MAAM,WAAW,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;AAEjF,QAAA,MAAM,WAAW,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;AACjF,QAAA,MAAM,WAAW,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;AACjF,QAAA,MAAM,WAAW,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;AAEjF,QAAA,MAAM,WAAW,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;AACjF,QAAA,MAAM,WAAW,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;AACjF,QAAA,MAAM,WAAW,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;AAEjF,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,WAAW,CAAC;AACxB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,WAAW,CAAC;AACxB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,WAAW,CAAC;AACxB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,WAAW,CAAC;AACxB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,WAAW,CAAC;AACxB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,WAAW,CAAC;AACxB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,WAAW,CAAC;AACxB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,WAAW,CAAC;AACxB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,WAAW,CAAC;AACxB,QAAA,OAAO,MAAM,CAAC;KACd;AAED,IAAA,OAAO,GAAG,CAAC,IAAa,EAAE,KAAc,EAAE,MAAe,EAAA;AACxD,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;AAC/B,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;AAC/B,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;AAC/B,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;AAC/B,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;AAC/B,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;AAC/B,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;AAC/B,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;AAC/B,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;AAC/B,QAAA,OAAO,MAAM,CAAC;KACd;AAED,IAAA,OAAO,QAAQ,CAAC,IAAa,EAAE,KAAc,EAAE,MAAe,EAAA;AAC7D,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;AAC/B,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;AAC/B,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;AAC/B,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;AAC/B,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;AAC/B,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;AAC/B,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;AAC/B,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;AAC/B,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;AAC/B,QAAA,OAAO,MAAM,CAAC;KACd;AAED,IAAA,OAAO,gBAAgB,CAAC,MAAe,EAAE,SAAkB,EAAE,MAAe,EAAA;AAC3E,QAAA,MAAM,EAAE,GAAG,SAAS,CAAC,CAAC,CAAC;AACvB,QAAA,MAAM,EAAE,GAAG,SAAS,CAAC,CAAC,CAAC;AACvB,QAAA,MAAM,EAAE,GAAG,SAAS,CAAC,CAAC,CAAC;QAEvB,MAAM,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,EAAE,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,EAAE,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC;QAC3D,MAAM,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,EAAE,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,EAAE,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC;QAC3D,MAAM,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,EAAE,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,EAAE,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC;AAE3D,QAAA,MAAM,CAAC,CAAC,GAAG,CAAC,CAAC;AACb,QAAA,MAAM,CAAC,CAAC,GAAG,CAAC,CAAC;AACb,QAAA,MAAM,CAAC,CAAC,GAAG,CAAC,CAAC;AACb,QAAA,OAAO,MAAM,CAAC;KACd;AAED,IAAA,OAAO,gBAAgB,CAAC,MAAe,EAAE,MAAc,EAAE,MAAe,EAAA;QACvE,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC;QAC/B,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC;QAC/B,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC;QAC/B,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC;QAC/B,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC;QAC/B,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC;QAC/B,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC;QAC/B,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC;QAC/B,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC;AAC/B,QAAA,OAAO,MAAM,CAAC;KACd;AAED,IAAA,OAAO,eAAe,CAAC,MAAe,EAAE,KAAc,EAAE,MAAe,EAAA;AACtE,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;AAChC,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;AAChC,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;AAChC,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;AAChC,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;AAChC,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;AAChC,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;AAChC,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;AAChC,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;AAEhC,QAAA,OAAO,MAAM,CAAC;KACd;AAED,IAAA,OAAO,MAAM,CAAC,MAAe,EAAE,MAAe,EAAA;QAC7C,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;QACvB,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;QACvB,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;QACvB,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;QACvB,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;QACvB,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;QACvB,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;QACvB,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;QACvB,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;AACvB,QAAA,OAAO,MAAM,CAAC;KACd;AAED,IAAA,OAAO,SAAS,CAAC,MAAe,EAAE,MAAe,EAAA;AAChD,QAAA,MAAM,WAAW,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;AAC9B,QAAA,MAAM,WAAW,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;AAC9B,QAAA,MAAM,WAAW,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;AAC9B,QAAA,MAAM,WAAW,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;AAC9B,QAAA,MAAM,WAAW,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;AAC9B,QAAA,MAAM,WAAW,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;AAC9B,QAAA,MAAM,WAAW,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;AAC9B,QAAA,MAAM,WAAW,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;AAC9B,QAAA,MAAM,WAAW,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;AAE9B,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,WAAW,CAAC;AACxB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,WAAW,CAAC;AACxB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,WAAW,CAAC;AACxB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,WAAW,CAAC;AACxB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,WAAW,CAAC;AACxB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,WAAW,CAAC;AACxB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,WAAW,CAAC;AACxB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,WAAW,CAAC;AACxB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,WAAW,CAAC;AACxB,QAAA,OAAO,MAAM,CAAC;KACd;AAED,IAAA,OAAO,GAAG,CAAC,MAAe,EAAE,MAAe,EAAA;AAC1C,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;AAChC,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;AAChC,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;AAChC,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;AAChC,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;AAChC,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;AAChC,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;AAChC,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;AAChC,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;AAEhC,QAAA,OAAO,MAAM,CAAC;KACd;IAED,OAAO,WAAW,CAAC,MAAe,EAAA;AACjC,QAAA,MAAM,GAAG,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;AACtB,QAAA,MAAM,GAAG,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;AACtB,QAAA,MAAM,GAAG,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;AACtB,QAAA,MAAM,GAAG,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;AACtB,QAAA,MAAM,GAAG,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;AACtB,QAAA,MAAM,GAAG,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;AACtB,QAAA,MAAM,GAAG,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;AACtB,QAAA,MAAM,GAAG,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;AACtB,QAAA,MAAM,GAAG,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;AAEtB,QAAA,OAAO,GAAG,IAAI,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC,GAAG,GAAG,IAAI,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC,GAAG,GAAG,IAAI,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC,CAAC;KACrG;AAED,IAAA,OAAO,OAAO,CAAC,MAAe,EAAE,MAAe,EAAA;AAC9C,QAAA,MAAM,GAAG,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;AACtB,QAAA,MAAM,GAAG,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;AACtB,QAAA,MAAM,GAAG,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;AACtB,QAAA,MAAM,GAAG,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;AACtB,QAAA,MAAM,GAAG,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;AACtB,QAAA,MAAM,GAAG,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;AACtB,QAAA,MAAM,GAAG,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;AACtB,QAAA,MAAM,GAAG,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;AACtB,QAAA,MAAM,GAAG,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QAEtB,MAAM,WAAW,GAAG,OAAO,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC;;QAGhD,IAAI,IAAI,CAAC,GAAG,CAAC,WAAW,CAAC,IAAI,KAAK,CAAC,SAAS,EAAE;AAC7C,YAAA,MAAM,IAAI,KAAK,CAAC,0BAA0B,CAAC,CAAC;AAC5C,SAAA;;QAGD,MAAM,CAAC,CAAC,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC;QAClC,MAAM,CAAC,CAAC,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC;QAClC,MAAM,CAAC,CAAC,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC;QAClC,MAAM,CAAC,CAAC,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC;QAClC,MAAM,CAAC,CAAC,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC;QAClC,MAAM,CAAC,CAAC,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC;QAClC,MAAM,CAAC,CAAC,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC;QAClC,MAAM,CAAC,CAAC,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC;QAClC,MAAM,CAAC,CAAC,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC;AAElC,QAAA,MAAM,KAAK,GAAG,GAAG,GAAG,WAAW,CAAC;QAChC,OAAO,OAAO,CAAC,gBAAgB,CAAC,MAAM,EAAE,KAAK,EAAE,MAAM,CAAC,CAAC;KACvD;AAED,IAAA,OAAO,gBAAgB,CAAC,MAAe,EAAE,MAAe,EAAA;AACvD,QAAA,OAAO,OAAO,CAAC,OAAO,CAAC,OAAO,CAAC,SAAS,CAAC,MAAM,EAAEC,wBAAsB,CAAC,EAAE,MAAM,CAAC,CAAC;KAClF;AAED,IAAA,OAAO,MAAM,CAAC,IAAa,EAAE,KAAc,EAAA;QAC1C,QACC,IAAI,KAAK,KAAK;aACb,OAAO,CAAC,IAAI,CAAC;gBACb,OAAO,CAAC,KAAK,CAAC;AACd,gBAAA,IAAI,CAAC,CAAC,CAAC,KAAK,KAAK,CAAC,CAAC,CAAC;AACpB,gBAAA,IAAI,CAAC,CAAC,CAAC,KAAK,KAAK,CAAC,CAAC,CAAC;AACpB,gBAAA,IAAI,CAAC,CAAC,CAAC,KAAK,KAAK,CAAC,CAAC,CAAC;AACpB,gBAAA,IAAI,CAAC,CAAC,CAAC,KAAK,KAAK,CAAC,CAAC,CAAC;AACpB,gBAAA,IAAI,CAAC,CAAC,CAAC,KAAK,KAAK,CAAC,CAAC,CAAC;AACpB,gBAAA,IAAI,CAAC,CAAC,CAAC,KAAK,KAAK,CAAC,CAAC,CAAC;AACpB,gBAAA,IAAI,CAAC,CAAC,CAAC,KAAK,KAAK,CAAC,CAAC,CAAC;AACpB,gBAAA,IAAI,CAAC,CAAC,CAAC,KAAK,KAAK,CAAC,CAAC,CAAC;gBACpB,IAAI,CAAC,CAAC,CAAC,KAAK,KAAK,CAAC,CAAC,CAAC,CAAC,EACrB;KACF;IAED,OAAO,aAAa,CAAC,IAAa,EAAE,KAAc,EAAE,OAAO,GAAG,CAAC,EAAA;AAC9D,QAAA,OAAO,GAAG,YAAY,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC;QAEnC,QACC,IAAI,KAAK,KAAK;aACb,OAAO,CAAC,IAAI,CAAC;gBACb,OAAO,CAAC,KAAK,CAAC;AACd,gBAAA,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,OAAO;AACvC,gBAAA,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,OAAO;AACvC,gBAAA,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,OAAO;AACvC,gBAAA,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,OAAO;AACvC,gBAAA,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,OAAO;AACvC,gBAAA,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,OAAO;AACvC,gBAAA,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,OAAO;AACvC,gBAAA,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,OAAO;AACvC,gBAAA,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,OAAO,CAAC,EACxC;KACF;AAMD,IAAA,KAAK,CAAC,MAAe,EAAA;QACpB,OAAO,OAAO,CAAC,KAAK,CAAC,IAAI,EAAE,MAAM,CAAC,CAAC;KACnC;AAED,IAAA,MAAM,CAAC,KAAc,EAAA;QACpB,OAAO,OAAO,CAAC,MAAM,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC;KACnC;AAED;;AAEG;AACH,IAAA,WAAW,CAAC,MAA0B,EAAE,KAAe,EAAE,MAAc,EAAA;QACtE,QACC,MAAM,CAAC,CAAC,CAAC,KAAK,KAAK,CAAC,MAAM,CAAC;YAC3B,MAAM,CAAC,CAAC,CAAC,KAAK,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC;YAC/B,MAAM,CAAC,CAAC,CAAC,KAAK,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC;YAC/B,MAAM,CAAC,CAAC,CAAC,KAAK,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC;YAC/B,MAAM,CAAC,CAAC,CAAC,KAAK,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC;YAC/B,MAAM,CAAC,CAAC,CAAC,KAAK,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC;YAC/B,MAAM,CAAC,CAAC,CAAC,KAAK,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC;YAC/B,MAAM,CAAC,CAAC,CAAC,KAAK,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC;YAC/B,MAAM,CAAC,CAAC,CAAC,KAAK,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC,EAC9B;KACF;AAED;;;;;;;;AAQG;IACH,aAAa,CAAC,KAAK,EAAE,OAAO,EAAA;QAC3B,OAAO,OAAO,CAAC,aAAa,CAAC,IAAI,EAAE,KAAK,EAAE,OAAO,CAAC,CAAC;KACnD;IAED,QAAQ,GAAA;AACP,QAAA,QACC,CAAI,CAAA,EAAA,IAAI,CAAC,CAAC,CAAC,CAAK,EAAA,EAAA,IAAI,CAAC,CAAC,CAAC,CAAK,EAAA,EAAA,IAAI,CAAC,CAAC,CAAC,CAAK,GAAA,CAAA;AACxC,YAAA,CAAA,CAAA,EAAI,IAAI,CAAC,CAAC,CAAC,KAAK,IAAI,CAAC,CAAC,CAAC,CAAK,EAAA,EAAA,IAAI,CAAC,CAAC,CAAC,CAAK,GAAA,CAAA;AACxC,YAAA,CAAA,CAAA,EAAI,IAAI,CAAC,CAAC,CAAC,CAAA,EAAA,EAAK,IAAI,CAAC,CAAC,CAAC,CAAA,EAAA,EAAK,IAAI,CAAC,CAAC,CAAC,CAAA,CAAA,CAAG,EACrC;KACF;;AAhDM,OAAQ,CAAA,QAAA,GAAG,MAAM,CAAC,MAAM,CAAC,IAAI,OAAO,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC;AAEnF,OAAI,CAAA,IAAA,GAAG,MAAM,CAAC,MAAM,CAAC,IAAI,OAAO,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC;AAiDvF,MAAML,eAAa,GAAG,IAAI,OAAO,EAAE,CAAC;AACd,IAAI,OAAO,GAAG;AACpC,MAAMC,eAAa,GAAG,IAAI,OAAO,EAAE,CAAC;AACpC,MAAMC,eAAa,GAAG,IAAI,OAAO,EAAE,CAAC;AACpC,MAAMC,eAAa,GAAG,IAAI,OAAO,EAAE,CAAC;AACpC,MAAMC,eAAa,GAAG,IAAI,OAAO,EAAE,CAAC;AAkFpC,MAAMC,wBAAsB,GAAG,IAAI,OAAO,EAAE;;AC5tB5C,MAAM,OAAO,CAAA;AAgBZ,IAAA,WAAA,CAAY,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,EAAA;AACrC,QAAA,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC;AACX,QAAA,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC;AACX,QAAA,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC;AACX,QAAA,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC;KACX;AACD,IAAA,GAAG,CAAC,CAAS,EAAE,CAAS,EAAE,CAAS,EAAE,CAAS,EAAA;AAC7C,QAAA,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC;AACX,QAAA,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC;AACX,QAAA,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC;AACX,QAAA,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC;KACX;IACD,OAAO,GAAA;AACN,QAAA,OAAO,CAAC,IAAI,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC,CAAC,CAAC;KACxC;AAED,IAAA,KAAK,CAAC,MAAe,EAAA;QACpB,OAAO,OAAO,CAAC,KAAK,CAAC,IAAI,EAAE,MAAM,CAAC,CAAC;KACnC;AAED,IAAA,MAAM,CAAC,KAAc,EAAA;QACpB,OAAO,OAAO,CAAC,MAAM,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC;KACnC;IAED,aAAa,CAAC,KAAc,EAAE,eAAe,GAAG,CAAC,EAAE,eAAe,GAAG,CAAC,EAAA;AACrE,QAAA,OAAO,OAAO,CAAC,aAAa,CAAC,IAAI,EAAE,KAAK,EAAE,eAAe,EAAE,eAAe,CAAC,CAAC;KAC5E;IAED,QAAQ,GAAA;AACP,QAAA,OAAO,IAAI,IAAI,CAAC,CAAC,CAAA,EAAA,EAAK,IAAI,CAAC,CAAC,CAAK,EAAA,EAAA,IAAI,CAAC,CAAC,CAAA,EAAA,EAAK,IAAI,CAAC,CAAC,GAAG,CAAC;KACtD;IACD,mBAAmB,CAAC,SAAoB,EAAE,KAAa,EAAA;QACtD,IAAI,CAAC,CAAC,GAAG,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAC/B,IAAI,CAAC,CAAC,GAAG,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAC/B,IAAI,CAAC,CAAC,GAAG,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAC/B,IAAI,CAAC,CAAC,GAAG,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;AAE/B,QAAA,OAAO,IAAI,CAAC;KACZ;IAED,OAAO,YAAY,CAAC,CAAS,EAAE,CAAS,EAAE,CAAS,EAAE,CAAS,EAAE,MAAe,EAAA;AAC9E,QAAA,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE;YACrB,OAAO,IAAI,OAAO,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;AAC/B,SAAA;AAED,QAAA,MAAM,CAAC,CAAC,GAAG,CAAC,CAAC;AACb,QAAA,MAAM,CAAC,CAAC,GAAG,CAAC,CAAC;AACb,QAAA,MAAM,CAAC,CAAC,GAAG,CAAC,CAAC;AACb,QAAA,MAAM,CAAC,CAAC,GAAG,CAAC,CAAC;AACb,QAAA,OAAO,MAAM,CAAC;KACd;AAED,IAAA,OAAO,KAAK,CAAC,SAAkB,EAAE,MAAe,EAAA;AAC/C,QAAA,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,EAAE;AACxB,YAAA,OAAO,SAAS,CAAC;AACjB,SAAA;AAED,QAAA,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE;AACrB,YAAA,OAAO,IAAI,OAAO,CAAC,SAAS,CAAC,CAAC,EAAE,SAAS,CAAC,CAAC,EAAE,SAAS,CAAC,CAAC,EAAE,SAAS,CAAC,CAAC,CAAC,CAAC;AACvE,SAAA;AAED,QAAA,MAAM,CAAC,CAAC,GAAG,SAAS,CAAC,CAAC,CAAC;AACvB,QAAA,MAAM,CAAC,CAAC,GAAG,SAAS,CAAC,CAAC,CAAC;AACvB,QAAA,MAAM,CAAC,CAAC,GAAG,SAAS,CAAC,CAAC,CAAC;AACvB,QAAA,MAAM,CAAC,CAAC,GAAG,SAAS,CAAC,CAAC,CAAC;AACvB,QAAA,OAAO,MAAM,CAAC;KACd;IAED,OAAO,gBAAgB,CAAC,SAAkB,EAAA;QACzC,OAAO,IAAI,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,EAAE,SAAS,CAAC,CAAC,EAAE,SAAS,CAAC,CAAC,EAAE,SAAS,CAAC,CAAC,CAAC,CAAC;KACpE;IAED,OAAO,gBAAgB,CAAC,SAAkB,EAAA;QACzC,OAAO,IAAI,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,EAAE,SAAS,CAAC,CAAC,EAAE,SAAS,CAAC,CAAC,EAAE,SAAS,CAAC,CAAC,CAAC,CAAC;KACpE;AAED,IAAA,OAAO,kBAAkB,CAAC,KAAc,EAAE,MAAe,EAAE,MAAe,EAAA;AACzE,QAAA,MAAM,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,CAAC;AACvC,QAAA,MAAM,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,CAAC;AACvC,QAAA,MAAM,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,CAAC;AACvC,QAAA,MAAM,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,CAAC;AAEvC,QAAA,OAAO,MAAM,CAAC;KACd;AAED,IAAA,OAAO,kBAAkB,CAAC,KAAc,EAAE,MAAe,EAAE,MAAe,EAAA;AACzE,QAAA,MAAM,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,CAAC;AACvC,QAAA,MAAM,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,CAAC;AACvC,QAAA,MAAM,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,CAAC;AACvC,QAAA,MAAM,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,CAAC;AAEvC,QAAA,OAAO,MAAM,CAAC;KACd;IAED,OAAO,KAAK,CAAC,KAAc,EAAE,GAAY,EAAE,GAAY,EAAE,MAAe,EAAA;AACvE,QAAA,MAAM,CAAC,GAAG,KAAK,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC;AAC7C,QAAA,MAAM,CAAC,GAAG,KAAK,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC;AAC7C,QAAA,MAAM,CAAC,GAAG,KAAK,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC;AAC7C,QAAA,MAAM,CAAC,GAAG,KAAK,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC;AAE7C,QAAA,MAAM,CAAC,CAAC,GAAG,CAAC,CAAC;AACb,QAAA,MAAM,CAAC,CAAC,GAAG,CAAC,CAAC;AACb,QAAA,MAAM,CAAC,CAAC,GAAG,CAAC,CAAC;AACb,QAAA,MAAM,CAAC,CAAC,GAAG,CAAC,CAAC;AAEb,QAAA,OAAO,MAAM,CAAC;KACd;IAED,OAAO,gBAAgB,CAAC,SAAkB,EAAA;AACzC,QAAA,QACC,SAAS,CAAC,CAAC,GAAG,SAAS,CAAC,CAAC;AACzB,YAAA,SAAS,CAAC,CAAC,GAAG,SAAS,CAAC,CAAC;AACzB,YAAA,SAAS,CAAC,CAAC,GAAG,SAAS,CAAC,CAAC;AACzB,YAAA,SAAS,CAAC,CAAC,GAAG,SAAS,CAAC,CAAC,EACxB;KACF;IAED,OAAO,SAAS,CAAC,SAAkB,EAAA;QAClC,OAAO,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,gBAAgB,CAAC,SAAS,CAAC,CAAC,CAAC;KACtD;AAED,IAAA,OAAO,QAAQ,CAAC,IAAa,EAAE,KAAc,EAAA;QAC5C,OAAO,CAAC,QAAQ,CAAC,IAAI,EAAE,KAAK,EAAE,eAAe,CAAC,CAAC;AAC/C,QAAA,OAAO,OAAO,CAAC,SAAS,CAAC,eAAe,CAAC,CAAC;KAC1C;AAED,IAAA,OAAO,eAAe,CAAC,IAAa,EAAE,KAAc,EAAA;QACnD,OAAO,CAAC,QAAQ,CAAC,IAAI,EAAE,KAAK,EAAE,eAAe,CAAC,CAAC;AAC/C,QAAA,OAAO,OAAO,CAAC,gBAAgB,CAAC,eAAe,CAAC,CAAC;KACjD;AAED,IAAA,OAAO,SAAS,CAAC,SAAkB,EAAE,MAAe,EAAA;QACnD,MAAM,SAAS,GAAG,OAAO,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC;QAE/C,MAAM,CAAC,CAAC,GAAG,SAAS,CAAC,CAAC,GAAG,SAAS,CAAC;QACnC,MAAM,CAAC,CAAC,GAAG,SAAS,CAAC,CAAC,GAAG,SAAS,CAAC;QACnC,MAAM,CAAC,CAAC,GAAG,SAAS,CAAC,CAAC,GAAG,SAAS,CAAC;QACnC,MAAM,CAAC,CAAC,GAAG,SAAS,CAAC,CAAC,GAAG,SAAS,CAAC;;QAGnC,IAAI,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE;AAC7E,YAAA,MAAM,IAAI,KAAK,CAAC,mCAAmC,CAAC,CAAC;AACrD,SAAA;;AAGD,QAAA,OAAO,MAAM,CAAC;KACd;AAED,IAAA,OAAO,GAAG,CAAC,IAAa,EAAE,KAAc,EAAA;AACvC,QAAA,OAAO,IAAI,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;KACjF;AAED,IAAA,OAAO,kBAAkB,CAAC,IAAa,EAAE,KAAc,EAAE,MAAe,EAAA;QACvE,MAAM,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;QAC5B,MAAM,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;QAC5B,MAAM,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;QAC5B,MAAM,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;AAC5B,QAAA,OAAO,MAAM,CAAC;KACd;AAED,IAAA,OAAO,gBAAgB,CAAC,IAAa,EAAE,KAAc,EAAE,MAAe,EAAA;QACrE,MAAM,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;QAC5B,MAAM,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;QAC5B,MAAM,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;QAC5B,MAAM,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;AAC5B,QAAA,OAAO,MAAM,CAAC;KACd;AAED,IAAA,OAAO,GAAG,CAAC,IAAa,EAAE,KAAc,EAAE,MAAe,EAAA;QACxD,MAAM,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;QAC5B,MAAM,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;QAC5B,MAAM,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;QAC5B,MAAM,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;AAC5B,QAAA,OAAO,MAAM,CAAC;KACd;AAED,IAAA,OAAO,QAAQ,CAAC,IAAa,EAAE,KAAc,EAAE,MAAe,EAAA;QAC7D,MAAM,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;QAC5B,MAAM,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;QAC5B,MAAM,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;QAC5B,MAAM,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;AAC5B,QAAA,OAAO,MAAM,CAAC;KACd;AAED,IAAA,OAAO,gBAAgB,CAAC,SAAkB,EAAE,MAAc,EAAE,MAAe,EAAA;QAC1E,MAAM,CAAC,CAAC,GAAG,SAAS,CAAC,CAAC,GAAG,MAAM,CAAC;QAChC,MAAM,CAAC,CAAC,GAAG,SAAS,CAAC,CAAC,GAAG,MAAM,CAAC;QAChC,MAAM,CAAC,CAAC,GAAG,SAAS,CAAC,CAAC,GAAG,MAAM,CAAC;QAChC,MAAM,CAAC,CAAC,GAAG,SAAS,CAAC,CAAC,GAAG,MAAM,CAAC;AAChC,QAAA,OAAO,MAAM,CAAC;KACd;AAED,IAAA,OAAO,cAAc,CAAC,SAAkB,EAAE,MAAc,EAAE,MAAe,EAAA;QACxE,MAAM,CAAC,CAAC,GAAG,SAAS,CAAC,CAAC,GAAG,MAAM,CAAC;QAChC,MAAM,CAAC,CAAC,GAAG,SAAS,CAAC,CAAC,GAAG,MAAM,CAAC;QAChC,MAAM,CAAC,CAAC,GAAG,SAAS,CAAC,CAAC,GAAG,MAAM,CAAC;QAChC,MAAM,CAAC,CAAC,GAAG,SAAS,CAAC,CAAC,GAAG,MAAM,CAAC;AAChC,QAAA,OAAO,MAAM,CAAC;KACd;AAED,IAAA,OAAO,MAAM,CAAC,SAAkB,EAAE,MAAe,EAAA;AAChD,QAAA,MAAM,CAAC,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,CAAC;AACxB,QAAA,MAAM,CAAC,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,CAAC;AACxB,QAAA,MAAM,CAAC,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,CAAC;AACxB,QAAA,MAAM,CAAC,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,CAAC;AACxB,QAAA,OAAO,MAAM,CAAC;KACd;AAED,IAAA,OAAO,GAAG,CAAC,SAAkB,EAAE,MAAe,EAAA;QAC7C,MAAM,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC;QACjC,MAAM,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC;QACjC,MAAM,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC;QACjC,MAAM,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC;AACjC,QAAA,OAAO,MAAM,CAAC;KACd;IAED,OAAO,IAAI,CAAC,KAAc,EAAE,GAAY,EAAE,CAAS,EAAE,MAAe,EAAA;QACnE,OAAO,CAAC,gBAAgB,CAAC,GAAG,EAAE,CAAC,EAAET,aAAW,CAAC,CAAC;AAC9C,QAAA,MAAM,GAAG,OAAO,CAAC,gBAAgB,CAAC,KAAK,EAAE,GAAG,GAAG,CAAC,EAAE,MAAM,CAAC,CAAC;QAC1D,OAAO,OAAO,CAAC,GAAG,CAACA,aAAW,EAAE,MAAM,EAAE,MAAM,CAAC,CAAC;KAChD;AAED,IAAA,OAAO,MAAM,CAAC,IAAa,EAAE,KAAc,EAAA;QAC1C,QACC,IAAI,KAAK,KAAK;aACb,OAAO,CAAC,IAAI,CAAC;gBACb,OAAO,CAAC,KAAK,CAAC;AACd,gBAAA,IAAI,CAAC,CAAC,KAAK,KAAK,CAAC,CAAC;AAClB,gBAAA,IAAI,CAAC,CAAC,KAAK,KAAK,CAAC,CAAC;AAClB,gBAAA,IAAI,CAAC,CAAC,KAAK,KAAK,CAAC,CAAC;gBAClB,IAAI,CAAC,CAAC,KAAK,KAAK,CAAC,CAAC,CAAC,EACnB;KACF;AAED,IAAA,OAAO,WAAW,CAAC,SAAkB,EAAE,KAAe,EAAE,MAAc,EAAA;QACrE,QACC,SAAS,CAAC,CAAC,KAAK,KAAK,CAAC,MAAM,CAAC;YAC7B,SAAS,CAAC,CAAC,KAAK,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC;YACjC,SAAS,CAAC,CAAC,KAAK,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC;YACjC,SAAS,CAAC,CAAC,KAAK,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC,EAChC;KACF;AAED,IAAA,OAAO,aAAa,CAAC,IAAa,EAAE,KAAc,EAAE,eAAe,GAAG,CAAC,EAAE,eAAe,GAAG,CAAC,EAAA;QAC3F,QACC,IAAI,KAAK,KAAK;aACb,OAAO,CAAC,IAAI,CAAC;gBACb,OAAO,CAAC,KAAK,CAAC;AACd,gBAAA,KAAK,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC,EAAE,eAAe,EAAE,eAAe,CAAC;AACtE,gBAAA,KAAK,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC,EAAE,eAAe,EAAE,eAAe,CAAC;AACtE,gBAAA,KAAK,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC,EAAE,eAAe,EAAE,eAAe,CAAC;AACtE,gBAAA,KAAK,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC,EAAE,eAAe,EAAE,eAAe,CAAC,CAAC,EACvE;KACF;;AA5Qa,OAAA,CAAA,IAAI,GAAG,MAAM,CAAC,MAAM,CAAC,IAAI,OAAO,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC;AAEtD,OAAA,CAAA,GAAG,GAAG,MAAM,CAAC,MAAM,CAAC,IAAI,OAAO,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC;AAErD,OAAA,CAAA,MAAM,GAAG,MAAM,CAAC,MAAM,CAAC,IAAI,OAAO,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC;AAExD,OAAA,CAAA,MAAM,GAAG,MAAM,CAAC,MAAM,CAAC,IAAI,OAAO,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC;AAExD,OAAA,CAAA,MAAM,GAAG,MAAM,CAAC,MAAM,CAAC,IAAI,OAAO,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC;AAExD,OAAA,CAAA,MAAM,GAAG,MAAM,CAAC,MAAM,CAAC,IAAI,OAAO,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC;AAqQvE;AACA,MAAM,eAAe,GAAG,IAAI,YAAY,CAAC,CAAC,CAAC,CAAC;AACrB,IAAI,UAAU,CAAC,eAAe,CAAC,MAAM,EAAE;AAE9D,MAAM,OAAO,GAAG,IAAI,WAAW,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC;AAC9C,MAAM,MAAM,GAAG,IAAI,UAAU,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;AACzB,MAAM,CAAC,CAAC,CAAC,KAAK,KAAK;AACxC,MAAM,eAAe,GAAG,IAAI,OAAO,EAAE,CAAC;AACtC,MAAMA,aAAW,GAAG,IAAI,OAAO,EAAE,CAAC;AACA,IAAI,OAAO;;ACtR7C,MAAM,OAAO,CAAA;AAOZ;;;;;;;;;;;;;;;;;;AAkBG;AACH,IAAA,WAAA,CACC,WAAW,GAAG,CAAC,EACf,WAAW,GAAG,CAAC,EACf,WAAW,GAAG,CAAC,EACf,WAAW,GAAG,CAAC,EACf,WAAW,GAAG,CAAC,EACf,WAAW,GAAG,CAAC,EACf,WAAW,GAAG,CAAC,EACf,WAAW,GAAG,CAAC,EACf,WAAW,GAAG,CAAC,EACf,WAAW,GAAG,CAAC,EACf,WAAW,GAAG,CAAC,EACf,WAAW,GAAG,CAAC,EACf,WAAW,GAAG,CAAC,EACf,WAAW,GAAG,CAAC,EACf,WAAW,GAAG,CAAC,EACf,WAAW,GAAG,CAAC,EAAA;AAEf,QAAA,IAAI,CAAC,CAAC,CAAC,GAAG,WAAW,CAAC;AACtB,QAAA,IAAI,CAAC,CAAC,CAAC,GAAG,WAAW,CAAC;AACtB,QAAA,IAAI,CAAC,CAAC,CAAC,GAAG,WAAW,CAAC;AACtB,QAAA,IAAI,CAAC,CAAC,CAAC,GAAG,WAAW,CAAC;AACtB,QAAA,IAAI,CAAC,CAAC,CAAC,GAAG,WAAW,CAAC;AACtB,QAAA,IAAI,CAAC,CAAC,CAAC,GAAG,WAAW,CAAC;AACtB,QAAA,IAAI,CAAC,CAAC,CAAC,GAAG,WAAW,CAAC;AACtB,QAAA,IAAI,CAAC,CAAC,CAAC,GAAG,WAAW,CAAC;AACtB,QAAA,IAAI,CAAC,CAAC,CAAC,GAAG,WAAW,CAAC;AACtB,QAAA,IAAI,CAAC,CAAC,CAAC,GAAG,WAAW,CAAC;AACtB,QAAA,IAAI,CAAC,EAAE,CAAC,GAAG,WAAW,CAAC;AACvB,QAAA,IAAI,CAAC,EAAE,CAAC,GAAG,WAAW,CAAC;AACvB,QAAA,IAAI,CAAC,EAAE,CAAC,GAAG,WAAW,CAAC;AACvB,QAAA,IAAI,CAAC,EAAE,CAAC,GAAG,WAAW,CAAC;AACvB,QAAA,IAAI,CAAC,EAAE,CAAC,GAAG,WAAW,CAAC;AACvB,QAAA,IAAI,CAAC,EAAE,CAAC,GAAG,WAAW,CAAC;KACvB;;AAED,IAAA,KAAK,CAAC,MAAA,GAAkB,IAAI,OAAO,EAAE,EAAA;QACpC,OAAO,OAAO,CAAC,KAAK,CAAC,IAAI,EAAE,MAAM,CAAC,CAAC;KACnC;AACD,IAAA,GAAG,CAAC,IAAa,EAAA;AAChB,QAAA,OAAO,CAAC,KAAK,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;AAC1B,QAAA,OAAO,IAAI,CAAC;KACZ;AACD,IAAA,MAAM,CAAC,KAAc,EAAA;QACpB,OAAO,OAAO,CAAC,MAAM,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC;KACnC;AACD,IAAA,OAAO,CAAC,QAAiB,EAAE,UAAsB,EAAE,KAAc,EAAA;QAChE,MAAM,EAAE,GAAG,IAAI,CAAC;QAEhB,MAAM,CAAC,GAAG,UAAU,CAAC,CAAC,EACrB,CAAC,GAAG,UAAU,CAAC,CAAC,EAChB,CAAC,GAAG,UAAU,CAAC,CAAC,EAChB,CAAC,GAAG,UAAU,CAAC,CAAC,CAAC;AAClB,QAAA,MAAM,EAAE,GAAG,CAAC,GAAG,CAAC,EACf,EAAE,GAAG,CAAC,GAAG,CAAC,EACV,EAAE,GAAG,CAAC,GAAG,CAAC,CAAC;AACZ,QAAA,MAAM,EAAE,GAAG,CAAC,GAAG,EAAE,EAChB,EAAE,GAAG,CAAC,GAAG,EAAE,EACX,EAAE,GAAG,CAAC,GAAG,EAAE,CAAC;AACb,QAAA,MAAM,EAAE,GAAG,CAAC,GAAG,EAAE,EAChB,EAAE,GAAG,CAAC,GAAG,EAAE,EACX,EAAE,GAAG,CAAC,GAAG,EAAE,CAAC;AACb,QAAA,MAAM,EAAE,GAAG,CAAC,GAAG,EAAE,EAChB,EAAE,GAAG,CAAC,GAAG,EAAE,EACX,EAAE,GAAG,CAAC,GAAG,EAAE,CAAC;AAEb,QAAA,MAAM,EAAE,GAAG,KAAK,CAAC,CAAC,EACjB,EAAE,GAAG,KAAK,CAAC,CAAC,EACZ,EAAE,GAAG,KAAK,CAAC,CAAC,CAAC;AAEd,QAAA,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,GAAG,EAAE,CAAC,IAAI,EAAE,CAAC;QAC7B,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,EAAE,GAAG,EAAE,IAAI,EAAE,CAAC;QACvB,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,EAAE,GAAG,EAAE,IAAI,EAAE,CAAC;AACvB,QAAA,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;QAEV,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,EAAE,GAAG,EAAE,IAAI,EAAE,CAAC;AACvB,QAAA,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,GAAG,EAAE,CAAC,IAAI,EAAE,CAAC;QAC7B,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,EAAE,GAAG,EAAE,IAAI,EAAE,CAAC;AACvB,QAAA,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;QAEV,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,EAAE,GAAG,EAAE,IAAI,EAAE,CAAC;QACvB,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,EAAE,GAAG,EAAE,IAAI,EAAE,CAAC;AACvB,QAAA,EAAE,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,GAAG,EAAE,CAAC,IAAI,EAAE,CAAC;AAC9B,QAAA,EAAE,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC;AAEX,QAAA,EAAE,CAAC,EAAE,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC;AACpB,QAAA,EAAE,CAAC,EAAE,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC;AACpB,QAAA,EAAE,CAAC,EAAE,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC;AACpB,QAAA,EAAE,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC;AAEX,QAAA,OAAO,IAAI,CAAC;KACZ;AACD,IAAA,aAAa,CAAC,KAAc,EAAE,OAAO,GAAG,CAAC,EAAA;QACxC,OAAO,OAAO,CAAC,aAAa,CAAC,IAAI,EAAE,KAAK,EAAE,OAAO,CAAC,CAAC;KACnD;AACD,IAAA,MAAM,CAAC,GAAY,EAAE,MAAe,EAAE,EAAW,EAAA;QAChD,MAAM,MAAM,GAAG,IAAI,CAAC;QACpB,OAAO,CAAC,QAAQ,CAAC,GAAG,EAAE,MAAM,EAAE,CAAC,CAAC,CAAC;AACjC,QAAA,IAAI,CAAC,CAAC,MAAM,EAAE,KAAK,CAAC,EAAE;;AAErB,YAAA,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;AACR,SAAA;QACD,CAAC,CAAC,SAAS,EAAE,CAAC;QACd,OAAO,CAAC,KAAK,CAAC,EAAE,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;AACxB,QAAA,IAAI,CAAC,CAAC,MAAM,EAAE,KAAK,CAAC,EAAE;;YAGrB,IAAI,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,EAAE;AACzB,gBAAA,CAAC,CAAC,CAAC,IAAI,MAAM,CAAC;AACd,aAAA;AAAM,iBAAA;AACN,gBAAA,CAAC,CAAC,CAAC,IAAI,MAAM,CAAC;AACd,aAAA;YACD,CAAC,CAAC,SAAS,EAAE,CAAC;YACd,OAAO,CAAC,KAAK,CAAC,EAAE,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;AACxB,SAAA;QACD,CAAC,CAAC,SAAS,EAAE,CAAC;QACd,OAAO,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;AACvB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;AAChB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;AAChB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;AAChB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;AAChB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;AAChB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;AAChB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;AAChB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;AAChB,QAAA,MAAM,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;AAEjB,QAAA,OAAO,IAAI,CAAC;KACZ;IACD,QAAQ,GAAA;QACP,QACC,IAAI,IAAI,CAAC,CAAC,CAAC,CAAA,EAAA,EAAK,IAAI,CAAC,CAAC,CAAC,CAAK,EAAA,EAAA,IAAI,CAAC,CAAC,CAAC,KAAK,IAAI,CAAC,EAAE,CAAC,CAAK,GAAA,CAAA;AACrD,YAAA,CAAA,CAAA,EAAI,IAAI,CAAC,CAAC,CAAC,CAAK,EAAA,EAAA,IAAI,CAAC,CAAC,CAAC,KAAK,IAAI,CAAC,CAAC,CAAC,CAAA,EAAA,EAAK,IAAI,CAAC,EAAE,CAAC,CAAK,GAAA,CAAA;AACrD,YAAA,CAAA,CAAA,EAAI,IAAI,CAAC,CAAC,CAAC,CAAK,EAAA,EAAA,IAAI,CAAC,CAAC,CAAC,KAAK,IAAI,CAAC,EAAE,CAAC,CAAA,EAAA,EAAK,IAAI,CAAC,EAAE,CAAC,CAAK,GAAA,CAAA;YACtD,CAAI,CAAA,EAAA,IAAI,CAAC,CAAC,CAAC,KAAK,IAAI,CAAC,CAAC,CAAC,CAAA,EAAA,EAAK,IAAI,CAAC,EAAE,CAAC,CAAK,EAAA,EAAA,IAAI,CAAC,EAAE,CAAC,CAAG,CAAA,CAAA,EACnD;KACF;AACD,IAAA,OAAO,KAAK,CAAC,MAA0B,EAAE,MAAe,EAAA;AACvD,QAAA,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE;AACrB,YAAA,OAAO,SAAS,CAAC;AACjB,SAAA;AACD,QAAA,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE;AACrB,YAAA,OAAO,IAAI,OAAO,CACjB,MAAM,CAAC,CAAC,CAAC,EACT,MAAM,CAAC,CAAC,CAAC,EACT,MAAM,CAAC,CAAC,CAAC,EACT,MAAM,CAAC,EAAE,CAAC,EACV,MAAM,CAAC,CAAC,CAAC,EACT,MAAM,CAAC,CAAC,CAAC,EACT,MAAM,CAAC,CAAC,CAAC,EACT,MAAM,CAAC,EAAE,CAAC,EACV,MAAM,CAAC,CAAC,CAAC,EACT,MAAM,CAAC,CAAC,CAAC,EACT,MAAM,CAAC,EAAE,CAAC,EACV,MAAM,CAAC,EAAE,CAAC,EACV,MAAM,CAAC,CAAC,CAAC,EACT,MAAM,CAAC,CAAC,CAAC,EACT,MAAM,CAAC,EAAE,CAAC,EACV,MAAM,CAAC,EAAE,CAAC,CACV,CAAC;AACF,SAAA;QACD,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QACtB,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QACtB,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QACtB,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QACtB,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QACtB,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QACtB,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QACtB,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QACtB,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QACtB,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QACtB,MAAM,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,EAAE,CAAC,CAAC;QACxB,MAAM,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,EAAE,CAAC,CAAC;QACxB,MAAM,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,EAAE,CAAC,CAAC;QACxB,MAAM,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,EAAE,CAAC,CAAC;QACxB,MAAM,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,EAAE,CAAC,CAAC;QACxB,MAAM,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,EAAE,CAAC,CAAC;AACxB,QAAA,OAAO,MAAM,CAAC;KACd;AAED,IAAA,OAAO,oBAAoB,CAAC,MAAgB,EAAE,MAAe,EAAA;QAC5D,OAAO,OAAO,CAAC,KAAK,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;KACrC;AAED,IAAA,OAAO,iBAAiB,CAAC,MAAgB,EAAE,MAAe,EAAA;AACzD,QAAA,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE;AACrB,YAAA,OAAO,IAAI,OAAO,CACjB,MAAM,CAAC,CAAC,CAAC,EACT,MAAM,CAAC,CAAC,CAAC,EACT,MAAM,CAAC,CAAC,CAAC,EACT,MAAM,CAAC,CAAC,CAAC,EACT,MAAM,CAAC,CAAC,CAAC,EACT,MAAM,CAAC,CAAC,CAAC,EACT,MAAM,CAAC,CAAC,CAAC,EACT,MAAM,CAAC,CAAC,CAAC,EACT,MAAM,CAAC,CAAC,CAAC,EACT,MAAM,CAAC,CAAC,CAAC,EACT,MAAM,CAAC,EAAE,CAAC,EACV,MAAM,CAAC,EAAE,CAAC,EACV,MAAM,CAAC,EAAE,CAAC,EACV,MAAM,CAAC,EAAE,CAAC,EACV,MAAM,CAAC,EAAE,CAAC,EACV,MAAM,CAAC,EAAE,CAAC,CACV,CAAC;AACF,SAAA;QACD,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QACtB,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QACtB,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QACtB,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,EAAE,CAAC,CAAC;QACvB,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QACtB,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QACtB,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QACtB,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,EAAE,CAAC,CAAC;QACvB,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QACtB,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QACtB,MAAM,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,EAAE,CAAC,CAAC;QACxB,MAAM,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,EAAE,CAAC,CAAC;QACxB,MAAM,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QACvB,MAAM,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QACvB,MAAM,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,EAAE,CAAC,CAAC;QACxB,MAAM,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,EAAE,CAAC,CAAC;AACxB,QAAA,OAAO,MAAM,CAAC;KACd;AAED,IAAA,OAAO,uBAAuB,CAAC,QAAiB,EAAE,WAAoB,EAAE,MAAe,EAAA;QACtF,WAAW,GAAG,YAAY,CAAC,WAAW,EAAE,OAAO,CAAC,IAAI,CAAC,CAAC;AAEtD,QAAA,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE;AACrB,YAAA,OAAO,IAAI,OAAO,CACjB,QAAQ,CAAC,CAAC,CAAC,EACX,QAAQ,CAAC,CAAC,CAAC,EACX,QAAQ,CAAC,CAAC,CAAC,EACX,WAAW,CAAC,CAAC,EACb,QAAQ,CAAC,CAAC,CAAC,EACX,QAAQ,CAAC,CAAC,CAAC,EACX,QAAQ,CAAC,CAAC,CAAC,EACX,WAAW,CAAC,CAAC,EACb,QAAQ,CAAC,CAAC,CAAC,EACX,QAAQ,CAAC,CAAC,CAAC,EACX,QAAQ,CAAC,CAAC,CAAC,EACX,WAAW,CAAC,CAAC,EACb,GAAG,EACH,GAAG,EACH,GAAG,EACH,GAAG,CACH,CAAC;AACF,SAAA;QAED,MAAM,CAAC,CAAC,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC;QACxB,MAAM,CAAC,CAAC,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC;QACxB,MAAM,CAAC,CAAC,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC;AACxB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC;QAChB,MAAM,CAAC,CAAC,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC;QACxB,MAAM,CAAC,CAAC,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC;QACxB,MAAM,CAAC,CAAC,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC;AACxB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC;QAChB,MAAM,CAAC,CAAC,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC;QACxB,MAAM,CAAC,CAAC,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC;QACxB,MAAM,CAAC,EAAE,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC;AACzB,QAAA,MAAM,CAAC,EAAE,CAAC,GAAG,GAAG,CAAC;AACjB,QAAA,MAAM,CAAC,EAAE,CAAC,GAAG,WAAW,CAAC,CAAC,CAAC;AAC3B,QAAA,MAAM,CAAC,EAAE,CAAC,GAAG,WAAW,CAAC,CAAC,CAAC;AAC3B,QAAA,MAAM,CAAC,EAAE,CAAC,GAAG,WAAW,CAAC,CAAC,CAAC;AAC3B,QAAA,MAAM,CAAC,EAAE,CAAC,GAAG,GAAG,CAAC;AACjB,QAAA,OAAO,MAAM,CAAC;KACd;IAED,OAAO,sCAAsC,CAC5C,WAAoB,EACpB,QAAoB,EACpB,KAAc,EACd,MAAe,EAAA;AAEf,QAAA,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE;AACrB,YAAA,MAAM,GAAG,IAAI,OAAO,EAAE,CAAC;AACvB,SAAA;AAED,QAAA,MAAM,MAAM,GAAG,KAAK,CAAC,CAAC,CAAC;AACvB,QAAA,MAAM,MAAM,GAAG,KAAK,CAAC,CAAC,CAAC;AACvB,QAAA,MAAM,MAAM,GAAG,KAAK,CAAC,CAAC,CAAC;QAEvB,MAAM,EAAE,GAAG,QAAQ,CAAC,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC;QACnC,MAAM,EAAE,GAAG,QAAQ,CAAC,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC;QACnC,MAAM,EAAE,GAAG,QAAQ,CAAC,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC;QACnC,MAAM,EAAE,GAAG,QAAQ,CAAC,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC;QACnC,MAAM,EAAE,GAAG,QAAQ,CAAC,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC;QACnC,MAAM,EAAE,GAAG,QAAQ,CAAC,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC;QACnC,MAAM,EAAE,GAAG,QAAQ,CAAC,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC;QACnC,MAAM,EAAE,GAAG,QAAQ,CAAC,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC;QACnC,MAAM,EAAE,GAAG,QAAQ,CAAC,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC;QACnC,MAAM,EAAE,GAAG,QAAQ,CAAC,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC;QAEnC,MAAM,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC;QAC9B,MAAM,GAAG,GAAG,GAAG,IAAI,EAAE,GAAG,EAAE,CAAC,CAAC;QAC5B,MAAM,GAAG,GAAG,GAAG,IAAI,EAAE,GAAG,EAAE,CAAC,CAAC;QAE5B,MAAM,GAAG,GAAG,GAAG,IAAI,EAAE,GAAG,EAAE,CAAC,CAAC;QAC5B,MAAM,GAAG,GAAG,CAAC,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC;QAC/B,MAAM,GAAG,GAAG,GAAG,IAAI,EAAE,GAAG,EAAE,CAAC,CAAC;QAE5B,MAAM,GAAG,GAAG,GAAG,IAAI,EAAE,GAAG,EAAE,CAAC,CAAC;QAC5B,MAAM,GAAG,GAAG,GAAG,IAAI,EAAE,GAAG,EAAE,CAAC,CAAC;QAC5B,MAAM,GAAG,GAAG,CAAC,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC;AAE/B,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,GAAG,GAAG,MAAM,CAAC;AACzB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,GAAG,GAAG,MAAM,CAAC;AACzB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,GAAG,GAAG,MAAM,CAAC;AACzB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC;AAChB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,GAAG,GAAG,MAAM,CAAC;AACzB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,GAAG,GAAG,MAAM,CAAC;AACzB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,GAAG,GAAG,MAAM,CAAC;AACzB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC;AAChB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,GAAG,GAAG,MAAM,CAAC;AACzB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,GAAG,GAAG,MAAM,CAAC;AACzB,QAAA,MAAM,CAAC,EAAE,CAAC,GAAG,GAAG,GAAG,MAAM,CAAC;AAC1B,QAAA,MAAM,CAAC,EAAE,CAAC,GAAG,GAAG,CAAC;AACjB,QAAA,MAAM,CAAC,EAAE,CAAC,GAAG,WAAW,CAAC,CAAC,CAAC;AAC3B,QAAA,MAAM,CAAC,EAAE,CAAC,GAAG,WAAW,CAAC,CAAC,CAAC;AAC3B,QAAA,MAAM,CAAC,EAAE,CAAC,GAAG,WAAW,CAAC,CAAC,CAAC;AAC3B,QAAA,MAAM,CAAC,EAAE,CAAC,GAAG,GAAG,CAAC;AAEjB,QAAA,OAAO,MAAM,CAAC;KACd;AAED,IAAA,OAAO,4BAA4B,CAClC,wBAIC,EACD,MAAe,EAAA;AAEf,QAAA,OAAO,OAAO,CAAC,sCAAsC,CACpD,wBAAwB,CAAC,WAAW,EACpC,wBAAwB,CAAC,QAAQ,EACjC,wBAAwB,CAAC,KAAK,EAC9B,MAAM,CACN,CAAC;KACF;AAED,IAAA,OAAO,eAAe,CAAC,WAAoB,EAAE,MAAe,EAAA;AAC3D,QAAA,OAAO,OAAO,CAAC,uBAAuB,CAAC,OAAO,CAAC,QAAQ,EAAE,WAAW,EAAE,MAAM,CAAC,CAAC;KAC9E;AAED,IAAA,OAAO,SAAS,CAAC,KAAc,EAAE,MAAe,EAAA;AAC/C,QAAA,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE;AACrB,YAAA,OAAO,IAAI,OAAO,CACjB,KAAK,CAAC,CAAC,EACP,GAAG,EACH,GAAG,EACH,GAAG,EACH,GAAG,EACH,KAAK,CAAC,CAAC,EACP,GAAG,EACH,GAAG,EACH,GAAG,EACH,GAAG,EACH,KAAK,CAAC,CAAC,EACP,GAAG,EACH,GAAG,EACH,GAAG,EACH,GAAG,EACH,GAAG,CACH,CAAC;AACF,SAAA;AAED,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;AACpB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC;AAChB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC;AAChB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC;AAChB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC;AAChB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;AACpB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC;AAChB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC;AAChB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC;AAChB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC;AAChB,QAAA,MAAM,CAAC,EAAE,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;AACrB,QAAA,MAAM,CAAC,EAAE,CAAC,GAAG,GAAG,CAAC;AACjB,QAAA,MAAM,CAAC,EAAE,CAAC,GAAG,GAAG,CAAC;AACjB,QAAA,MAAM,CAAC,EAAE,CAAC,GAAG,GAAG,CAAC;AACjB,QAAA,MAAM,CAAC,EAAE,CAAC,GAAG,GAAG,CAAC;AACjB,QAAA,MAAM,CAAC,EAAE,CAAC,GAAG,GAAG,CAAC;AACjB,QAAA,OAAO,MAAM,CAAC;KACd;AAED,IAAA,OAAO,YAAY,CAAC,QAAiB,EAAE,MAAe,EAAA;AACrD,QAAA,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE;AACrB,YAAA,MAAM,GAAG,IAAI,OAAO,EAAE,CAAC;AACvB,SAAA;QACD,MAAM,CAAC,CAAC,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC;QACxB,MAAM,CAAC,CAAC,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC;QACxB,MAAM,CAAC,CAAC,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC;AACxB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC;QAEhB,MAAM,CAAC,CAAC,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC;QACxB,MAAM,CAAC,CAAC,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC;QACxB,MAAM,CAAC,CAAC,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC;AACxB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC;QAEhB,MAAM,CAAC,CAAC,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC;QACxB,MAAM,CAAC,CAAC,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC;QACxB,MAAM,CAAC,EAAE,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC;AACzB,QAAA,MAAM,CAAC,EAAE,CAAC,GAAG,GAAG,CAAC;AAEjB,QAAA,MAAM,CAAC,EAAE,CAAC,GAAG,GAAG,CAAC;AACjB,QAAA,MAAM,CAAC,EAAE,CAAC,GAAG,GAAG,CAAC;AACjB,QAAA,MAAM,CAAC,EAAE,CAAC,GAAG,GAAG,CAAC;AACjB,QAAA,MAAM,CAAC,EAAE,CAAC,GAAG,GAAG,CAAC;AAEjB,QAAA,OAAO,MAAM,CAAC;KACd;AAED,IAAA,OAAO,eAAe,CACrB,IAAY,EACZ,KAAa,EACb,GAAW,EACX,MAAc,EACd,IAAY,EACZ,GAAW,EAAA;;AAGX,QAAA,MAAM,MAAM,GAAG,IAAI,OAAO,EAAE,CAAC;AAC7B,QAAA,MAAM,CAAC,GAAG,CAAC,CAAC,GAAG,IAAI,KAAK,KAAK,GAAG,IAAI,CAAC,CAAC;AACtC,QAAA,MAAM,CAAC,GAAG,CAAC,CAAC,GAAG,IAAI,KAAK,GAAG,GAAG,MAAM,CAAC,CAAC;AAEtC,QAAA,MAAM,CAAC,GAAG,CAAC,KAAK,GAAG,IAAI,KAAK,KAAK,GAAG,IAAI,CAAC,CAAC;AAC1C,QAAA,MAAM,CAAC,GAAG,CAAC,GAAG,GAAG,MAAM,KAAK,GAAG,GAAG,MAAM,CAAC,CAAC;QAC1C,MAAM,CAAC,GAAG,CAAC,GAAG,IAAI,GAAG,GAAG,IAAI,CAAC,CAAC;AAC9B,QAAA,MAAM,CAAC,GAAG,CAAC,CAAC,GAAG,GAAG,IAAI,KAAK,GAAG,GAAG,IAAI,CAAC,CAAC;AAEvC,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;AACd,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;AACd,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;AACd,QAAA,MAAM,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC;AACf,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;AACd,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;AACd,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;AACd,QAAA,MAAM,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC;AACf,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;AACd,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;AACd,QAAA,MAAM,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC;AACf,QAAA,MAAM,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC;AACf,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;AACd,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;AACd,QAAA,MAAM,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC;AAChB,QAAA,MAAM,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC;AACf,QAAA,OAAO,MAAM,CAAC;KACd;AACD,IAAA,OAAO,gBAAgB,CACtB,IAAY,EACZ,KAAa,EACb,GAAW,EACX,MAAc,EACd,IAAY,EACZ,GAAW,EAAA;AAEX,QAAA,MAAM,MAAM,GAAG,IAAI,OAAO,EAAE,CAAC;QAC7B,MAAM,CAAC,GAAG,GAAG,IAAI,KAAK,GAAG,IAAI,CAAC,CAAC;QAC/B,MAAM,CAAC,GAAG,GAAG,IAAI,GAAG,GAAG,MAAM,CAAC,CAAC;QAC/B,MAAM,CAAC,GAAG,GAAG,IAAI,GAAG,GAAG,IAAI,CAAC,CAAC;QAE7B,MAAM,CAAC,GAAG,CAAC,KAAK,GAAG,IAAI,IAAI,CAAC,CAAC;QAC7B,MAAM,CAAC,GAAG,CAAC,GAAG,GAAG,MAAM,IAAI,CAAC,CAAC;AAC7B,QAAA,MAAM,CAAC,GAAG,IAAI,GAAG,CAAC,CAAC;AAEnB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;AAClB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;AACd,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;AACd,QAAA,MAAM,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC;AAChB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;AACd,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;AAClB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;AACd,QAAA,MAAM,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC;AAChB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;AACd,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;QACd,MAAM,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC;AACpB,QAAA,MAAM,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC;AAChB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;AACd,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;AACd,QAAA,MAAM,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC;AACf,QAAA,MAAM,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC;AACf,QAAA,OAAO,MAAM,CAAC;KACd;IACD,OAAO,GAAA;QACN,MAAM,MAAM,GAAG,EAAE,CAAC;AAClB,QAAA,OAAO,CAAC,OAAO,CAAC,IAAI,EAAE,MAAM,CAAC,CAAC;AAC9B,QAAA,OAAO,MAAM,CAAC;KACd;AACD;;;;;;;;;;;;;AAaG;AACH,IAAA,OAAO,OAAO,CAAC,MAA+B,EAAE,MAAqB,EAAA;AACpE,QAAA,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE;YACrB,OAAO;gBACN,MAAM,CAAC,CAAC,CAAC;gBACT,MAAM,CAAC,CAAC,CAAC;gBACT,MAAM,CAAC,CAAC,CAAC;gBACT,MAAM,CAAC,CAAC,CAAC;gBACT,MAAM,CAAC,CAAC,CAAC;gBACT,MAAM,CAAC,CAAC,CAAC;gBACT,MAAM,CAAC,CAAC,CAAC;gBACT,MAAM,CAAC,CAAC,CAAC;gBACT,MAAM,CAAC,CAAC,CAAC;gBACT,MAAM,CAAC,CAAC,CAAC;gBACT,MAAM,CAAC,EAAE,CAAC;gBACV,MAAM,CAAC,EAAE,CAAC;gBACV,MAAM,CAAC,EAAE,CAAC;gBACV,MAAM,CAAC,EAAE,CAAC;gBACV,MAAM,CAAC,EAAE,CAAC;gBACV,MAAM,CAAC,EAAE,CAAC;aACV,CAAC;AACF,SAAA;QACD,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QACtB,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QACtB,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QACtB,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QACtB,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QACtB,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QACtB,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QACtB,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QACtB,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QACtB,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QACtB,MAAM,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,EAAE,CAAC,CAAC;QACxB,MAAM,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,EAAE,CAAC,CAAC;QACxB,MAAM,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,EAAE,CAAC,CAAC;QACxB,MAAM,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,EAAE,CAAC,CAAC;QACxB,MAAM,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,EAAE,CAAC,CAAC;QACxB,MAAM,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,EAAE,CAAC,CAAC;AACxB,QAAA,OAAO,MAAM,CAAC;KACd;AAED,IAAA,OAAO,eAAe,CAAC,MAAc,EAAE,GAAW,EAAA;AACjD,QAAA,OAAO,MAAM,GAAG,CAAC,GAAG,GAAG,CAAC;KACxB;AAED,IAAA,OAAO,SAAS,CAAC,MAAe,EAAE,KAAa,EAAE,MAAe,EAAA;AAC/D,QAAA,MAAM,UAAU,GAAG,KAAK,GAAG,CAAC,CAAC;AAC7B,QAAA,MAAM,CAAC,GAAG,MAAM,CAAC,UAAU,CAAC,CAAC;QAC7B,MAAM,CAAC,GAAG,MAAM,CAAC,UAAU,GAAG,CAAC,CAAC,CAAC;QACjC,MAAM,CAAC,GAAG,MAAM,CAAC,UAAU,GAAG,CAAC,CAAC,CAAC;QACjC,MAAM,CAAC,GAAG,MAAM,CAAC,UAAU,GAAG,CAAC,CAAC,CAAC;AAEjC,QAAA,MAAM,CAAC,CAAC,GAAG,CAAC,CAAC;AACb,QAAA,MAAM,CAAC,CAAC,GAAG,CAAC,CAAC;AACb,QAAA,MAAM,CAAC,CAAC,GAAG,CAAC,CAAC;AACb,QAAA,MAAM,CAAC,CAAC,GAAG,CAAC,CAAC;AACb,QAAA,OAAO,MAAM,CAAC;KACd;IAED,OAAO,SAAS,CAAC,MAAe,EAAE,KAAa,EAAE,SAAkB,EAAE,MAAe,EAAA;QACnF,MAAM,GAAG,OAAO,CAAC,KAAK,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;AACvC,QAAA,MAAM,UAAU,GAAG,KAAK,GAAG,CAAC,CAAC;AAC7B,QAAA,MAAM,CAAC,UAAU,CAAC,GAAG,SAAS,CAAC,CAAC,CAAC;QACjC,MAAM,CAAC,UAAU,GAAG,CAAC,CAAC,GAAG,SAAS,CAAC,CAAC,CAAC;QACrC,MAAM,CAAC,UAAU,GAAG,CAAC,CAAC,GAAG,SAAS,CAAC,CAAC,CAAC;QACrC,MAAM,CAAC,UAAU,GAAG,CAAC,CAAC,GAAG,SAAS,CAAC,CAAC,CAAC;AACrC,QAAA,OAAO,MAAM,CAAC;KACd;AAED,IAAA,OAAO,MAAM,CAAC,MAAe,EAAE,KAAa,EAAE,MAAe,EAAA;AAC5D,QAAA,MAAM,CAAC,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;QACxB,MAAM,CAAC,GAAG,MAAM,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC;QAC5B,MAAM,CAAC,GAAG,MAAM,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC;QAC5B,MAAM,CAAC,GAAG,MAAM,CAAC,KAAK,GAAG,EAAE,CAAC,CAAC;AAE7B,QAAA,MAAM,CAAC,CAAC,GAAG,CAAC,CAAC;AACb,QAAA,MAAM,CAAC,CAAC,GAAG,CAAC,CAAC;AACb,QAAA,MAAM,CAAC,CAAC,GAAG,CAAC,CAAC;AACb,QAAA,MAAM,CAAC,CAAC,GAAG,CAAC,CAAC;AACb,QAAA,OAAO,MAAM,CAAC;KACd;IAED,OAAO,MAAM,CAAC,MAAe,EAAE,KAAa,EAAE,SAAkB,EAAE,MAAe,EAAA;QAChF,MAAM,GAAG,OAAO,CAAC,KAAK,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;AACvC,QAAA,MAAM,CAAC,KAAK,CAAC,GAAG,SAAS,CAAC,CAAC,CAAC;QAC5B,MAAM,CAAC,KAAK,GAAG,CAAC,CAAC,GAAG,SAAS,CAAC,CAAC,CAAC;QAChC,MAAM,CAAC,KAAK,GAAG,CAAC,CAAC,GAAG,SAAS,CAAC,CAAC,CAAC;QAChC,MAAM,CAAC,KAAK,GAAG,EAAE,CAAC,GAAG,SAAS,CAAC,CAAC,CAAC;AACjC,QAAA,OAAO,MAAM,CAAC;KACd;AAED,IAAA,OAAO,cAAc,CAAC,MAAe,EAAE,WAAoB,EAAE,MAAe,EAAA;QAC3E,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QACtB,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QACtB,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QACtB,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QAEtB,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QACtB,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QACtB,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QACtB,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QAEtB,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QACtB,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QACtB,MAAM,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,EAAE,CAAC,CAAC;QACxB,MAAM,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,EAAE,CAAC,CAAC;AAExB,QAAA,MAAM,CAAC,EAAE,CAAC,GAAG,WAAW,CAAC,CAAC,CAAC;AAC3B,QAAA,MAAM,CAAC,EAAE,CAAC,GAAG,WAAW,CAAC,CAAC,CAAC;AAC3B,QAAA,MAAM,CAAC,EAAE,CAAC,GAAG,WAAW,CAAC,CAAC,CAAC;QAC3B,MAAM,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,EAAE,CAAC,CAAC;AAExB,QAAA,OAAO,MAAM,CAAC;KACd;AAED,IAAA,OAAO,QAAQ,CAAC,MAAe,EAAE,KAAc,EAAE,MAAe,EAAA;QAC/D,MAAM,aAAa,GAAG,OAAO,CAAC,QAAQ,CAAC,MAAM,EAAEI,eAAa,CAAC,CAAC;QAC9D,MAAM,WAAW,GAAG,KAAK,CAAC,CAAC,GAAG,aAAa,CAAC,CAAC,CAAC;QAC9C,MAAM,WAAW,GAAG,KAAK,CAAC,CAAC,GAAG,aAAa,CAAC,CAAC,CAAC;QAC9C,MAAM,WAAW,GAAG,KAAK,CAAC,CAAC,GAAG,aAAa,CAAC,CAAC,CAAC;QAE9C,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,WAAW,CAAC;QACpC,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,WAAW,CAAC;QACpC,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,WAAW,CAAC;QACpC,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QAEtB,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,WAAW,CAAC;QACpC,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,WAAW,CAAC;QACpC,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,WAAW,CAAC;QACpC,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QAEtB,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,WAAW,CAAC;QACpC,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,WAAW,CAAC;QACpC,MAAM,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,EAAE,CAAC,GAAG,WAAW,CAAC;QACtC,MAAM,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,EAAE,CAAC,CAAC;QAExB,MAAM,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,EAAE,CAAC,CAAC;QACxB,MAAM,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,EAAE,CAAC,CAAC;QACxB,MAAM,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,EAAE,CAAC,CAAC;QACxB,MAAM,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,EAAE,CAAC,CAAC;AAExB,QAAA,OAAO,MAAM,CAAC;KACd;AAED,IAAA,OAAO,QAAQ,CAAC,MAAe,EAAE,MAAe,EAAA;AAC/C,QAAA,MAAM,CAAC,CAAC,GAAG,OAAO,CAAC,SAAS,CAAC,OAAO,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,EAAEC,eAAa,CAAC,CAAC,CAAC;AACnG,QAAA,MAAM,CAAC,CAAC,GAAG,OAAO,CAAC,SAAS,CAAC,OAAO,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,EAAEA,eAAa,CAAC,CAAC,CAAC;AACnG,QAAA,MAAM,CAAC,CAAC,GAAG,OAAO,CAAC,SAAS,CAAC,OAAO,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,EAAE,MAAM,CAAC,EAAE,CAAC,EAAEA,eAAa,CAAC,CAAC,CAAC;AACpG,QAAA,OAAO,MAAM,CAAC;KACd;IAED,OAAO,eAAe,CAAC,MAAe,EAAA;AACrC,QAAA,OAAO,CAAC,QAAQ,CAAC,MAAM,EAAEC,eAAa,CAAC,CAAC;AACxC,QAAA,OAAO,OAAO,CAAC,gBAAgB,CAACA,eAAa,CAAC,CAAC;KAC/C;AAED,IAAA,OAAO,WAAW,CAAC,MAAe,EAAE,QAAiB,EAAE,MAAe,EAAA;QACrE,MAAM,KAAK,GAAG,OAAO,CAAC,QAAQ,CAAC,MAAM,EAAEC,eAAa,CAAC,CAAC;AAEtD,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;AAClC,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;AAClC,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;QAClC,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;AAEtB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;AAClC,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;AAClC,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;QAClC,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;AAEtB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;AAClC,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;AAClC,QAAA,MAAM,CAAC,EAAE,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;QACnC,MAAM,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,EAAE,CAAC,CAAC;QAExB,MAAM,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,EAAE,CAAC,CAAC;QACxB,MAAM,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,EAAE,CAAC,CAAC;QACxB,MAAM,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,EAAE,CAAC,CAAC;QACxB,MAAM,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,EAAE,CAAC,CAAC;AAExB,QAAA,OAAO,MAAM,CAAC;KACd;AAED,IAAA,OAAO,WAAW,CAAC,MAAe,EAAE,MAAkB,EAAA;QACrD,MAAM,KAAK,GAAG,OAAO,CAAC,QAAQ,CAAC,MAAM,EAAEC,eAAa,CAAC,CAAC;AAEtD,QAAA,MAAM,GAAG,GAAG,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;AACxB,QAAA,MAAM,GAAG,GAAG,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;AACxB,QAAA,MAAM,GAAG,GAAG,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;QAExB,MAAM,IAAI,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC;QAC7B,MAAM,IAAI,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC;QAC7B,MAAM,IAAI,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC;QAC7B,MAAM,IAAI,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC;QAC7B,MAAM,IAAI,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC;QAC7B,MAAM,IAAI,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC;QAC7B,MAAM,IAAI,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC;QAC7B,MAAM,IAAI,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC;QAC7B,MAAM,IAAI,GAAG,MAAM,CAAC,EAAE,CAAC,GAAG,GAAG,CAAC;AAE9B,QAAA,MAAM,KAAK,GAAG,IAAI,GAAG,IAAI,GAAG,IAAI,CAAC;QACjC,IAAI,CAAC,GAAG,CAAC,CAAC;QAEV,IAAI,KAAK,GAAG,CAAC,EAAE;YACd,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,KAAK,GAAG,GAAG,CAAC,GAAG,CAAC,CAAC;AAC/B,YAAA,MAAM,CAAC,CAAC,GAAG,IAAI,GAAG,CAAC,CAAC;YACpB,MAAM,CAAC,CAAC,GAAG,CAAC,IAAI,GAAG,IAAI,IAAI,CAAC,CAAC;YAC7B,MAAM,CAAC,CAAC,GAAG,CAAC,IAAI,GAAG,IAAI,IAAI,CAAC,CAAC;YAC7B,MAAM,CAAC,CAAC,GAAG,CAAC,IAAI,GAAG,IAAI,IAAI,CAAC,CAAC;AAC7B,SAAA;AAAM,aAAA,IAAI,IAAI,GAAG,IAAI,IAAI,IAAI,GAAG,IAAI,EAAE;AACtC,YAAA,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,GAAG,GAAG,IAAI,GAAG,IAAI,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC;YAC5C,MAAM,CAAC,CAAC,GAAG,CAAC,IAAI,GAAG,IAAI,IAAI,CAAC,CAAC;AAC7B,YAAA,MAAM,CAAC,CAAC,GAAG,IAAI,GAAG,CAAC,CAAC;YACpB,MAAM,CAAC,CAAC,GAAG,CAAC,IAAI,GAAG,IAAI,IAAI,CAAC,CAAC;YAC7B,MAAM,CAAC,CAAC,GAAG,CAAC,IAAI,GAAG,IAAI,IAAI,CAAC,CAAC;AAC7B,SAAA;aAAM,IAAI,IAAI,GAAG,IAAI,EAAE;AACvB,YAAA,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,GAAG,GAAG,IAAI,GAAG,IAAI,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC;YAC5C,MAAM,CAAC,CAAC,GAAG,CAAC,IAAI,GAAG,IAAI,IAAI,CAAC,CAAC;YAC7B,MAAM,CAAC,CAAC,GAAG,CAAC,IAAI,GAAG,IAAI,IAAI,CAAC,CAAC;AAC7B,YAAA,MAAM,CAAC,CAAC,GAAG,IAAI,GAAG,CAAC,CAAC;YACpB,MAAM,CAAC,CAAC,GAAG,CAAC,IAAI,GAAG,IAAI,IAAI,CAAC,CAAC;AAC7B,SAAA;AAAM,aAAA;AACN,YAAA,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,GAAG,GAAG,IAAI,GAAG,IAAI,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC;YAC5C,MAAM,CAAC,CAAC,GAAG,CAAC,IAAI,GAAG,IAAI,IAAI,CAAC,CAAC;YAC7B,MAAM,CAAC,CAAC,GAAG,CAAC,IAAI,GAAG,IAAI,IAAI,CAAC,CAAC;YAC7B,MAAM,CAAC,CAAC,GAAG,CAAC,IAAI,GAAG,IAAI,IAAI,CAAC,CAAC;AAC7B,YAAA,MAAM,CAAC,CAAC,GAAG,IAAI,GAAG,CAAC,CAAC;AACpB,SAAA;AACD,QAAA,OAAO,MAAM,CAAC;KACd;AAED,IAAA,OAAO,QAAQ,CAAC,IAAa,EAAE,KAAc,EAAE,MAAe,EAAA;AAC7D,QAAA,MAAM,KAAK,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC;AACtB,QAAA,MAAM,KAAK,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC;AACtB,QAAA,MAAM,KAAK,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC;AACtB,QAAA,MAAM,KAAK,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC;AACtB,QAAA,MAAM,KAAK,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC;AACtB,QAAA,MAAM,KAAK,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC;AACtB,QAAA,MAAM,KAAK,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC;AACtB,QAAA,MAAM,KAAK,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC;AACtB,QAAA,MAAM,KAAK,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC;AACtB,QAAA,MAAM,KAAK,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC;AACtB,QAAA,MAAM,MAAM,GAAG,IAAI,CAAC,EAAE,CAAC,CAAC;AACxB,QAAA,MAAM,MAAM,GAAG,IAAI,CAAC,EAAE,CAAC,CAAC;AACxB,QAAA,MAAM,MAAM,GAAG,IAAI,CAAC,EAAE,CAAC,CAAC;AACxB,QAAA,MAAM,MAAM,GAAG,IAAI,CAAC,EAAE,CAAC,CAAC;AACxB,QAAA,MAAM,MAAM,GAAG,IAAI,CAAC,EAAE,CAAC,CAAC;AACxB,QAAA,MAAM,MAAM,GAAG,IAAI,CAAC,EAAE,CAAC,CAAC;AAExB,QAAA,MAAM,MAAM,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;AACxB,QAAA,MAAM,MAAM,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;AACxB,QAAA,MAAM,MAAM,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;AACxB,QAAA,MAAM,MAAM,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;AACxB,QAAA,MAAM,MAAM,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;AACxB,QAAA,MAAM,MAAM,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;AACxB,QAAA,MAAM,MAAM,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;AACxB,QAAA,MAAM,MAAM,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;AACxB,QAAA,MAAM,MAAM,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;AACxB,QAAA,MAAM,MAAM,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;AACxB,QAAA,MAAM,OAAO,GAAG,KAAK,CAAC,EAAE,CAAC,CAAC;AAC1B,QAAA,MAAM,OAAO,GAAG,KAAK,CAAC,EAAE,CAAC,CAAC;AAC1B,QAAA,MAAM,OAAO,GAAG,KAAK,CAAC,EAAE,CAAC,CAAC;AAC1B,QAAA,MAAM,OAAO,GAAG,KAAK,CAAC,EAAE,CAAC,CAAC;AAC1B,QAAA,MAAM,OAAO,GAAG,KAAK,CAAC,EAAE,CAAC,CAAC;AAC1B,QAAA,MAAM,OAAO,GAAG,KAAK,CAAC,EAAE,CAAC,CAAC;AAE1B,QAAA,MAAM,WAAW,GAAG,KAAK,GAAG,MAAM,GAAG,KAAK,GAAG,MAAM,GAAG,KAAK,GAAG,MAAM,GAAG,MAAM,GAAG,MAAM,CAAC;AACvF,QAAA,MAAM,WAAW,GAAG,KAAK,GAAG,MAAM,GAAG,KAAK,GAAG,MAAM,GAAG,KAAK,GAAG,MAAM,GAAG,MAAM,GAAG,MAAM,CAAC;AACvF,QAAA,MAAM,WAAW,GAAG,KAAK,GAAG,MAAM,GAAG,KAAK,GAAG,MAAM,GAAG,MAAM,GAAG,MAAM,GAAG,MAAM,GAAG,MAAM,CAAC;AACxF,QAAA,MAAM,WAAW,GAAG,KAAK,GAAG,MAAM,GAAG,KAAK,GAAG,MAAM,GAAG,MAAM,GAAG,MAAM,GAAG,MAAM,GAAG,MAAM,CAAC;AAExF,QAAA,MAAM,WAAW,GAAG,KAAK,GAAG,MAAM,GAAG,KAAK,GAAG,MAAM,GAAG,KAAK,GAAG,MAAM,GAAG,MAAM,GAAG,MAAM,CAAC;AACvF,QAAA,MAAM,WAAW,GAAG,KAAK,GAAG,MAAM,GAAG,KAAK,GAAG,MAAM,GAAG,KAAK,GAAG,MAAM,GAAG,MAAM,GAAG,MAAM,CAAC;AACvF,QAAA,MAAM,WAAW,GAAG,KAAK,GAAG,MAAM,GAAG,KAAK,GAAG,MAAM,GAAG,MAAM,GAAG,MAAM,GAAG,MAAM,GAAG,MAAM,CAAC;AACxF,QAAA,MAAM,WAAW,GAAG,KAAK,GAAG,MAAM,GAAG,KAAK,GAAG,MAAM,GAAG,MAAM,GAAG,MAAM,GAAG,MAAM,GAAG,MAAM,CAAC;AAExF,QAAA,MAAM,WAAW,GAAG,KAAK,GAAG,MAAM,GAAG,KAAK,GAAG,MAAM,GAAG,KAAK,GAAG,OAAO,GAAG,MAAM,GAAG,OAAO,CAAC;AACzF,QAAA,MAAM,WAAW,GAAG,KAAK,GAAG,MAAM,GAAG,KAAK,GAAG,MAAM,GAAG,KAAK,GAAG,OAAO,GAAG,MAAM,GAAG,OAAO,CAAC;AACzF,QAAA,MAAM,WAAW,GAAG,KAAK,GAAG,MAAM,GAAG,KAAK,GAAG,MAAM,GAAG,MAAM,GAAG,OAAO,GAAG,MAAM,GAAG,OAAO,CAAC;AAC1F,QAAA,MAAM,WAAW,GAAG,KAAK,GAAG,MAAM,GAAG,KAAK,GAAG,MAAM,GAAG,MAAM,GAAG,OAAO,GAAG,MAAM,GAAG,OAAO,CAAC;AAE1F,QAAA,MAAM,WAAW,GAAG,KAAK,GAAG,OAAO,GAAG,KAAK,GAAG,OAAO,GAAG,KAAK,GAAG,OAAO,GAAG,MAAM,GAAG,OAAO,CAAC;AAC3F,QAAA,MAAM,WAAW,GAAG,KAAK,GAAG,OAAO,GAAG,KAAK,GAAG,OAAO,GAAG,KAAK,GAAG,OAAO,GAAG,MAAM,GAAG,OAAO,CAAC;AAC3F,QAAA,MAAM,WAAW,GAAG,KAAK,GAAG,OAAO,GAAG,KAAK,GAAG,OAAO,GAAG,MAAM,GAAG,OAAO,GAAG,MAAM,GAAG,OAAO,CAAC;AAC5F,QAAA,MAAM,WAAW,GAAG,KAAK,GAAG,OAAO,GAAG,KAAK,GAAG,OAAO,GAAG,MAAM,GAAG,OAAO,GAAG,MAAM,GAAG,OAAO,CAAC;AAE5F,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,WAAW,CAAC;AACxB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,WAAW,CAAC;AACxB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,WAAW,CAAC;AACxB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,WAAW,CAAC;AACxB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,WAAW,CAAC;AACxB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,WAAW,CAAC;AACxB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,WAAW,CAAC;AACxB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,WAAW,CAAC;AACxB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,WAAW,CAAC;AACxB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,WAAW,CAAC;AACxB,QAAA,MAAM,CAAC,EAAE,CAAC,GAAG,WAAW,CAAC;AACzB,QAAA,MAAM,CAAC,EAAE,CAAC,GAAG,WAAW,CAAC;AACzB,QAAA,MAAM,CAAC,EAAE,CAAC,GAAG,WAAW,CAAC;AACzB,QAAA,MAAM,CAAC,EAAE,CAAC,GAAG,WAAW,CAAC;AACzB,QAAA,MAAM,CAAC,EAAE,CAAC,GAAG,WAAW,CAAC;AACzB,QAAA,MAAM,CAAC,EAAE,CAAC,GAAG,WAAW,CAAC;AACzB,QAAA,OAAO,MAAM,CAAC;KACd;AAED,IAAA,OAAO,GAAG,CAAC,IAAa,EAAE,KAAc,EAAE,MAAe,EAAA;AACxD,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;AAC/B,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;AAC/B,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;AAC/B,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;AAC/B,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;AAC/B,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;AAC/B,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;AAC/B,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;AAC/B,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;AAC/B,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;AAC/B,QAAA,MAAM,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,EAAE,CAAC,GAAG,KAAK,CAAC,EAAE,CAAC,CAAC;AAClC,QAAA,MAAM,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,EAAE,CAAC,GAAG,KAAK,CAAC,EAAE,CAAC,CAAC;AAClC,QAAA,MAAM,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,EAAE,CAAC,GAAG,KAAK,CAAC,EAAE,CAAC,CAAC;AAClC,QAAA,MAAM,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,EAAE,CAAC,GAAG,KAAK,CAAC,EAAE,CAAC,CAAC;AAClC,QAAA,MAAM,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,EAAE,CAAC,GAAG,KAAK,CAAC,EAAE,CAAC,CAAC;AAClC,QAAA,MAAM,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,EAAE,CAAC,GAAG,KAAK,CAAC,EAAE,CAAC,CAAC;AAClC,QAAA,OAAO,MAAM,CAAC;KACd;AAED,IAAA,OAAO,QAAQ,CAAC,IAAa,EAAE,KAAc,EAAE,MAAe,EAAA;AAC7D,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;AAC/B,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;AAC/B,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;AAC/B,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;AAC/B,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;AAC/B,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;AAC/B,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;AAC/B,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;AAC/B,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;AAC/B,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;AAC/B,QAAA,MAAM,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,EAAE,CAAC,GAAG,KAAK,CAAC,EAAE,CAAC,CAAC;AAClC,QAAA,MAAM,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,EAAE,CAAC,GAAG,KAAK,CAAC,EAAE,CAAC,CAAC;AAClC,QAAA,MAAM,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,EAAE,CAAC,GAAG,KAAK,CAAC,EAAE,CAAC,CAAC;AAClC,QAAA,MAAM,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,EAAE,CAAC,GAAG,KAAK,CAAC,EAAE,CAAC,CAAC;AAClC,QAAA,MAAM,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,EAAE,CAAC,GAAG,KAAK,CAAC,EAAE,CAAC,CAAC;AAClC,QAAA,MAAM,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,EAAE,CAAC,GAAG,KAAK,CAAC,EAAE,CAAC,CAAC;AAClC,QAAA,OAAO,MAAM,CAAC;KACd;AAED,IAAA,OAAO,sBAAsB,CAAC,IAAa,EAAE,KAAc,EAAE,MAAe,EAAA;AAC3E,QAAA,MAAM,KAAK,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC;AACtB,QAAA,MAAM,KAAK,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC;AACtB,QAAA,MAAM,KAAK,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC;AACtB,QAAA,MAAM,KAAK,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC;AACtB,QAAA,MAAM,KAAK,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC;AACtB,QAAA,MAAM,KAAK,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC;AACtB,QAAA,MAAM,KAAK,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC;AACtB,QAAA,MAAM,KAAK,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC;AACtB,QAAA,MAAM,MAAM,GAAG,IAAI,CAAC,EAAE,CAAC,CAAC;AACxB,QAAA,MAAM,MAAM,GAAG,IAAI,CAAC,EAAE,CAAC,CAAC;AACxB,QAAA,MAAM,MAAM,GAAG,IAAI,CAAC,EAAE,CAAC,CAAC;AACxB,QAAA,MAAM,MAAM,GAAG,IAAI,CAAC,EAAE,CAAC,CAAC;AAExB,QAAA,MAAM,MAAM,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;AACxB,QAAA,MAAM,MAAM,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;AACxB,QAAA,MAAM,MAAM,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;AACxB,QAAA,MAAM,MAAM,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;AACxB,QAAA,MAAM,MAAM,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;AACxB,QAAA,MAAM,MAAM,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;AACxB,QAAA,MAAM,MAAM,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;AACxB,QAAA,MAAM,MAAM,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;AACxB,QAAA,MAAM,OAAO,GAAG,KAAK,CAAC,EAAE,CAAC,CAAC;AAC1B,QAAA,MAAM,OAAO,GAAG,KAAK,CAAC,EAAE,CAAC,CAAC;AAC1B,QAAA,MAAM,OAAO,GAAG,KAAK,CAAC,EAAE,CAAC,CAAC;AAC1B,QAAA,MAAM,OAAO,GAAG,KAAK,CAAC,EAAE,CAAC,CAAC;AAE1B,QAAA,MAAM,WAAW,GAAG,KAAK,GAAG,MAAM,GAAG,KAAK,GAAG,MAAM,GAAG,KAAK,GAAG,MAAM,CAAC;AACrE,QAAA,MAAM,WAAW,GAAG,KAAK,GAAG,MAAM,GAAG,KAAK,GAAG,MAAM,GAAG,KAAK,GAAG,MAAM,CAAC;AACrE,QAAA,MAAM,WAAW,GAAG,KAAK,GAAG,MAAM,GAAG,KAAK,GAAG,MAAM,GAAG,MAAM,GAAG,MAAM,CAAC;AAEtE,QAAA,MAAM,WAAW,GAAG,KAAK,GAAG,MAAM,GAAG,KAAK,GAAG,MAAM,GAAG,KAAK,GAAG,MAAM,CAAC;AACrE,QAAA,MAAM,WAAW,GAAG,KAAK,GAAG,MAAM,GAAG,KAAK,GAAG,MAAM,GAAG,KAAK,GAAG,MAAM,CAAC;AACrE,QAAA,MAAM,WAAW,GAAG,KAAK,GAAG,MAAM,GAAG,KAAK,GAAG,MAAM,GAAG,MAAM,GAAG,MAAM,CAAC;AAEtE,QAAA,MAAM,WAAW,GAAG,KAAK,GAAG,MAAM,GAAG,KAAK,GAAG,MAAM,GAAG,KAAK,GAAG,OAAO,CAAC;AACtE,QAAA,MAAM,WAAW,GAAG,KAAK,GAAG,MAAM,GAAG,KAAK,GAAG,MAAM,GAAG,KAAK,GAAG,OAAO,CAAC;AACtE,QAAA,MAAM,WAAW,GAAG,KAAK,GAAG,MAAM,GAAG,KAAK,GAAG,MAAM,GAAG,MAAM,GAAG,OAAO,CAAC;AAEvE,QAAA,MAAM,WAAW,GAAG,KAAK,GAAG,OAAO,GAAG,KAAK,GAAG,OAAO,GAAG,KAAK,GAAG,OAAO,GAAG,MAAM,CAAC;AACjF,QAAA,MAAM,WAAW,GAAG,KAAK,GAAG,OAAO,GAAG,KAAK,GAAG,OAAO,GAAG,KAAK,GAAG,OAAO,GAAG,MAAM,CAAC;AACjF,QAAA,MAAM,WAAW,GAAG,KAAK,GAAG,OAAO,GAAG,KAAK,GAAG,OAAO,GAAG,MAAM,GAAG,OAAO,GAAG,MAAM,CAAC;AAElF,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,WAAW,CAAC;AACxB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,WAAW,CAAC;AACxB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,WAAW,CAAC;AACxB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC;AAChB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,WAAW,CAAC;AACxB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,WAAW,CAAC;AACxB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,WAAW,CAAC;AACxB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC;AAChB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,WAAW,CAAC;AACxB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,WAAW,CAAC;AACxB,QAAA,MAAM,CAAC,EAAE,CAAC,GAAG,WAAW,CAAC;AACzB,QAAA,MAAM,CAAC,EAAE,CAAC,GAAG,GAAG,CAAC;AACjB,QAAA,MAAM,CAAC,EAAE,CAAC,GAAG,WAAW,CAAC;AACzB,QAAA,MAAM,CAAC,EAAE,CAAC,GAAG,WAAW,CAAC;AACzB,QAAA,MAAM,CAAC,EAAE,CAAC,GAAG,WAAW,CAAC;AACzB,QAAA,MAAM,CAAC,EAAE,CAAC,GAAG,GAAG,CAAC;AACjB,QAAA,OAAO,MAAM,CAAC;KACd;AAED,IAAA,OAAO,iBAAiB,CAAC,MAAe,EAAE,QAAiB,EAAE,MAAe,EAAA;AAC3E,QAAA,MAAM,KAAK,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;AACxB,QAAA,MAAM,KAAK,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;AACxB,QAAA,MAAM,KAAK,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;AACxB,QAAA,MAAM,KAAK,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;AACxB,QAAA,MAAM,KAAK,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;AACxB,QAAA,MAAM,KAAK,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;AACxB,QAAA,MAAM,KAAK,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;AACxB,QAAA,MAAM,KAAK,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;AACxB,QAAA,MAAM,MAAM,GAAG,MAAM,CAAC,EAAE,CAAC,CAAC;AAE1B,QAAA,MAAM,MAAM,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC;AAC3B,QAAA,MAAM,MAAM,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC;AAC3B,QAAA,MAAM,MAAM,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC;AAC3B,QAAA,MAAM,MAAM,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC;AAC3B,QAAA,MAAM,MAAM,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC;AAC3B,QAAA,MAAM,MAAM,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC;AAC3B,QAAA,MAAM,MAAM,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC;AAC3B,QAAA,MAAM,MAAM,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC;AAC3B,QAAA,MAAM,OAAO,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC;AAE5B,QAAA,MAAM,WAAW,GAAG,KAAK,GAAG,MAAM,GAAG,KAAK,GAAG,MAAM,GAAG,KAAK,GAAG,MAAM,CAAC;AACrE,QAAA,MAAM,WAAW,GAAG,KAAK,GAAG,MAAM,GAAG,KAAK,GAAG,MAAM,GAAG,KAAK,GAAG,MAAM,CAAC;AACrE,QAAA,MAAM,WAAW,GAAG,KAAK,GAAG,MAAM,GAAG,KAAK,GAAG,MAAM,GAAG,MAAM,GAAG,MAAM,CAAC;AAEtE,QAAA,MAAM,WAAW,GAAG,KAAK,GAAG,MAAM,GAAG,KAAK,GAAG,MAAM,GAAG,KAAK,GAAG,MAAM,CAAC;AACrE,QAAA,MAAM,WAAW,GAAG,KAAK,GAAG,MAAM,GAAG,KAAK,GAAG,MAAM,GAAG,KAAK,GAAG,MAAM,CAAC;AACrE,QAAA,MAAM,WAAW,GAAG,KAAK,GAAG,MAAM,GAAG,KAAK,GAAG,MAAM,GAAG,MAAM,GAAG,MAAM,CAAC;AAEtE,QAAA,MAAM,WAAW,GAAG,KAAK,GAAG,MAAM,GAAG,KAAK,GAAG,MAAM,GAAG,KAAK,GAAG,OAAO,CAAC;AACtE,QAAA,MAAM,WAAW,GAAG,KAAK,GAAG,MAAM,GAAG,KAAK,GAAG,MAAM,GAAG,KAAK,GAAG,OAAO,CAAC;AACtE,QAAA,MAAM,WAAW,GAAG,KAAK,GAAG,MAAM,GAAG,KAAK,GAAG,MAAM,GAAG,MAAM,GAAG,OAAO,CAAC;AAEvE,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,WAAW,CAAC;AACxB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,WAAW,CAAC;AACxB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,WAAW,CAAC;AACxB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC;AAChB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,WAAW,CAAC;AACxB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,WAAW,CAAC;AACxB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,WAAW,CAAC;AACxB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC;AAChB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,WAAW,CAAC;AACxB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,WAAW,CAAC;AACxB,QAAA,MAAM,CAAC,EAAE,CAAC,GAAG,WAAW,CAAC;AACzB,QAAA,MAAM,CAAC,EAAE,CAAC,GAAG,GAAG,CAAC;QACjB,MAAM,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,EAAE,CAAC,CAAC;QACxB,MAAM,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,EAAE,CAAC,CAAC;QACxB,MAAM,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,EAAE,CAAC,CAAC;QACxB,MAAM,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,EAAE,CAAC,CAAC;AACxB,QAAA,OAAO,MAAM,CAAC;KACd;AAED,IAAA,OAAO,qBAAqB,CAAC,MAAe,EAAE,WAAoB,EAAE,MAAe,EAAA;AAClF,QAAA,MAAM,CAAC,GAAG,WAAW,CAAC,CAAC,CAAC;AACxB,QAAA,MAAM,CAAC,GAAG,WAAW,CAAC,CAAC,CAAC;AACxB,QAAA,MAAM,CAAC,GAAG,WAAW,CAAC,CAAC,CAAC;QAExB,MAAM,EAAE,GAAG,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,EAAE,CAAC,CAAC;QACtE,MAAM,EAAE,GAAG,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,EAAE,CAAC,CAAC;QACtE,MAAM,EAAE,GAAG,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,MAAM,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,EAAE,CAAC,CAAC;QAEvE,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QACtB,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QACtB,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QACtB,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QACtB,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QACtB,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QACtB,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QACtB,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QACtB,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QACtB,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QACtB,MAAM,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,EAAE,CAAC,CAAC;QACxB,MAAM,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,EAAE,CAAC,CAAC;AACxB,QAAA,MAAM,CAAC,EAAE,CAAC,GAAG,EAAE,CAAC;AAChB,QAAA,MAAM,CAAC,EAAE,CAAC,GAAG,EAAE,CAAC;AAChB,QAAA,MAAM,CAAC,EAAE,CAAC,GAAG,EAAE,CAAC;QAChB,MAAM,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,EAAE,CAAC,CAAC;AACxB,QAAA,OAAO,MAAM,CAAC;KACd;AAED,IAAA,OAAO,eAAe,CAAC,MAAe,EAAE,KAAc,EAAE,MAAe,EAAA;AACtE,QAAA,MAAM,MAAM,GAAG,KAAK,CAAC,CAAC,CAAC;AACvB,QAAA,MAAM,MAAM,GAAG,KAAK,CAAC,CAAC,CAAC;AACvB,QAAA,MAAM,MAAM,GAAG,KAAK,CAAC,CAAC,CAAC;;QAGvB,IAAI,MAAM,KAAK,GAAG,IAAI,MAAM,KAAK,GAAG,IAAI,MAAM,KAAK,GAAG,EAAE;YACvD,OAAO,OAAO,CAAC,KAAK,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;AACrC,SAAA;QAED,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QAC/B,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QAC/B,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QAC/B,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QAEtB,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QAC/B,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QAC/B,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QAC/B,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QAEtB,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QAC/B,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QAC/B,MAAM,CAAC,EAAE,CAAC,GAAG,MAAM,GAAG,MAAM,CAAC,EAAE,CAAC,CAAC;QACjC,MAAM,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,EAAE,CAAC,CAAC;QAExB,MAAM,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,EAAE,CAAC,CAAC;QACxB,MAAM,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,EAAE,CAAC,CAAC;QACxB,MAAM,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,EAAE,CAAC,CAAC;QACxB,MAAM,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,EAAE,CAAC,CAAC;AAExB,QAAA,OAAO,MAAM,CAAC;KACd;AAED,IAAA,OAAO,sBAAsB,CAAC,MAAe,EAAE,KAAa,EAAE,MAAe,EAAA;QAC5E,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC;QAC9B,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC;QAC9B,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC;QAC9B,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QAEtB,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC;QAC9B,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC;QAC9B,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC;QAC9B,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QAEtB,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC;QAC9B,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC;QAC9B,MAAM,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,EAAE,CAAC,GAAG,KAAK,CAAC;QAChC,MAAM,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,EAAE,CAAC,CAAC;QAExB,MAAM,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,EAAE,CAAC,CAAC;QACxB,MAAM,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,EAAE,CAAC,CAAC;QACxB,MAAM,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,EAAE,CAAC,CAAC;QACxB,MAAM,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,EAAE,CAAC,CAAC;AAExB,QAAA,OAAO,MAAM,CAAC;KACd;AAED,IAAA,OAAO,gBAAgB,CAAC,MAAe,EAAE,SAAkB,EAAE,MAAe,EAAA;AAC3E,QAAA,MAAM,EAAE,GAAG,SAAS,CAAC,CAAC,CAAC;AACvB,QAAA,MAAM,EAAE,GAAG,SAAS,CAAC,CAAC,CAAC;AACvB,QAAA,MAAM,EAAE,GAAG,SAAS,CAAC,CAAC,CAAC;AACvB,QAAA,MAAM,EAAE,GAAG,SAAS,CAAC,CAAC,CAAC;AAEvB,QAAA,MAAM,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,EAAE,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,EAAE,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,EAAE,GAAG,MAAM,CAAC,EAAE,CAAC,GAAG,EAAE,CAAC;AAC7E,QAAA,MAAM,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,EAAE,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,EAAE,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,EAAE,GAAG,MAAM,CAAC,EAAE,CAAC,GAAG,EAAE,CAAC;AAC7E,QAAA,MAAM,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,EAAE,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,EAAE,GAAG,MAAM,CAAC,EAAE,CAAC,GAAG,EAAE,GAAG,MAAM,CAAC,EAAE,CAAC,GAAG,EAAE,CAAC;AAC9E,QAAA,MAAM,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,EAAE,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,EAAE,GAAG,MAAM,CAAC,EAAE,CAAC,GAAG,EAAE,GAAG,MAAM,CAAC,EAAE,CAAC,GAAG,EAAE,CAAC;AAE9E,QAAA,MAAM,CAAC,CAAC,GAAG,CAAC,CAAC;AACb,QAAA,MAAM,CAAC,CAAC,GAAG,CAAC,CAAC;AACb,QAAA,MAAM,CAAC,CAAC,GAAG,CAAC,CAAC;AACb,QAAA,MAAM,CAAC,CAAC,GAAG,CAAC,CAAC;AACb,QAAA,OAAO,MAAM,CAAC;KACd;AAED,IAAA,OAAO,uBAAuB,CAAC,MAAe,EAAE,SAAkB,EAAE,MAAe,EAAA;AAClF,QAAA,MAAM,EAAE,GAAG,SAAS,CAAC,CAAC,CAAC;AACvB,QAAA,MAAM,EAAE,GAAG,SAAS,CAAC,CAAC,CAAC;AACvB,QAAA,MAAM,EAAE,GAAG,SAAS,CAAC,CAAC,CAAC;QAEvB,MAAM,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,EAAE,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,EAAE,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC;QAC3D,MAAM,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,EAAE,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,EAAE,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC;QAC3D,MAAM,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,EAAE,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,EAAE,GAAG,MAAM,CAAC,EAAE,CAAC,GAAG,EAAE,CAAC;AAE5D,QAAA,MAAM,CAAC,CAAC,GAAG,CAAC,CAAC;AACb,QAAA,MAAM,CAAC,CAAC,GAAG,CAAC,CAAC;AACb,QAAA,MAAM,CAAC,CAAC,GAAG,CAAC,CAAC;AACb,QAAA,OAAO,MAAM,CAAC;KACd;AAED,IAAA,OAAO,eAAe,CAAC,MAAe,EAAE,SAAkB,EAAE,MAAe,EAAA;AAC1E,QAAA,MAAM,EAAE,GAAG,SAAS,CAAC,CAAC,CAAC;AACvB,QAAA,MAAM,EAAE,GAAG,SAAS,CAAC,CAAC,CAAC;AACvB,QAAA,MAAM,EAAE,GAAG,SAAS,CAAC,CAAC,CAAC;QAEvB,MAAM,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,EAAE,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,EAAE,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,EAAE,GAAG,MAAM,CAAC,EAAE,CAAC,CAAC;QACxE,MAAM,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,EAAE,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,EAAE,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,EAAE,GAAG,MAAM,CAAC,EAAE,CAAC,CAAC;QACxE,MAAM,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,EAAE,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,EAAE,GAAG,MAAM,CAAC,EAAE,CAAC,GAAG,EAAE,GAAG,MAAM,CAAC,EAAE,CAAC,CAAC;AAEzE,QAAA,MAAM,CAAC,CAAC,GAAG,CAAC,CAAC;AACb,QAAA,MAAM,CAAC,CAAC,GAAG,CAAC,CAAC;AACb,QAAA,MAAM,CAAC,CAAC,GAAG,CAAC,CAAC;AACb,QAAA,OAAO,MAAM,CAAC;KACd;AAED,IAAA,OAAO,gBAAgB,CAAC,MAAe,EAAE,MAAc,EAAE,MAAe,EAAA;QACvE,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC;QAC/B,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC;QAC/B,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC;QAC/B,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC;QAC/B,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC;QAC/B,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC;QAC/B,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC;QAC/B,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC;QAC/B,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC;QAC/B,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC;QAC/B,MAAM,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC;QACjC,MAAM,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC;QACjC,MAAM,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC;QACjC,MAAM,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC;QACjC,MAAM,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC;QACjC,MAAM,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC;AACjC,QAAA,OAAO,MAAM,CAAC;KACd;AAED,IAAA,OAAO,MAAM,CAAC,MAAe,EAAE,MAAe,EAAA;QAC7C,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;QACvB,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;QACvB,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;QACvB,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;QACvB,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;QACvB,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;QACvB,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;QACvB,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;QACvB,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;QACvB,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;QACvB,MAAM,CAAC,EAAE,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;QACzB,MAAM,CAAC,EAAE,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;QACzB,MAAM,CAAC,EAAE,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;QACzB,MAAM,CAAC,EAAE,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;QACzB,MAAM,CAAC,EAAE,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;QACzB,MAAM,CAAC,EAAE,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;AACzB,QAAA,OAAO,MAAM,CAAC;KACd;AAED,IAAA,OAAO,SAAS,CAAC,MAAe,EAAE,MAAe,EAAA;AAChD,QAAA,MAAM,OAAO,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;AAC1B,QAAA,MAAM,OAAO,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;AAC1B,QAAA,MAAM,OAAO,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;AAC1B,QAAA,MAAM,OAAO,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;AAC1B,QAAA,MAAM,OAAO,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;AAC1B,QAAA,MAAM,QAAQ,GAAG,MAAM,CAAC,EAAE,CAAC,CAAC;QAE5B,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QACtB,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QACtB,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QACtB,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,EAAE,CAAC,CAAC;AACvB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,OAAO,CAAC;QACpB,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QACtB,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QACtB,MAAM,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,EAAE,CAAC,CAAC;AACvB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,OAAO,CAAC;AACpB,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,OAAO,CAAC;QACpB,MAAM,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,EAAE,CAAC,CAAC;QACxB,MAAM,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,EAAE,CAAC,CAAC;AACxB,QAAA,MAAM,CAAC,EAAE,CAAC,GAAG,OAAO,CAAC;AACrB,QAAA,MAAM,CAAC,EAAE,CAAC,GAAG,OAAO,CAAC;AACrB,QAAA,MAAM,CAAC,EAAE,CAAC,GAAG,QAAQ,CAAC;QACtB,MAAM,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,EAAE,CAAC,CAAC;AACxB,QAAA,OAAO,MAAM,CAAC;KACd;AAED,IAAA,OAAO,GAAG,CAAC,MAAe,EAAE,MAAe,EAAA;AAC1C,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;AAChC,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;AAChC,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;AAChC,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;AAChC,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;AAChC,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;AAChC,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;AAChC,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;AAChC,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;AAChC,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;AAChC,QAAA,MAAM,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,CAAC;AAClC,QAAA,MAAM,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,CAAC;AAClC,QAAA,MAAM,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,CAAC;AAClC,QAAA,MAAM,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,CAAC;AAClC,QAAA,MAAM,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,CAAC;AAClC,QAAA,MAAM,CAAC,EAAE,CAAC,GA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AC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;;AAGL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;;AAGL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;;AAGL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;;AAGL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;;AAGL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GA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"} +//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"index.js","sources":["../src/core/WebGPUConstant.ts","../src/render/Buffer.ts","../src/render/PipelineLayout.ts","../src/render/Pipeline.ts","../src/render/DrawCommand.ts","../src/core/WebGPUTypes.ts","../src/utils/MipmapGenerator.ts","../src/utils/defaultValue.ts","../src/render/RenderState.ts","../src/render/Context.ts","../src/render/Texture.ts","../src/render/Sampler.ts","../src/render/Attachment.ts","../src/utils/defined.ts","../node_modules/mersenne-twister/src/mersenne-twister.js","../src/math/Math.ts","../src/math/Vector2.ts","../src/math/Vector3.ts","../src/render/Attribute.ts","../src/render/BindGroup.ts","../src/render/BindGroupEntity.ts","../src/math/Matrix3.ts","../src/math/Vector4.ts","../src/math/Matrix4.ts","../src/core/BoundingSphere.ts","../src/render/IndexBuffer.ts","../src/render/Attributes.ts","../src/render/VertextBuffer.ts","../src/utils/combine.ts","../src/geometry/Geometry.ts","../src/geometry/PlaneGeometry.ts","../src/math/Quaternion.ts","../src/core/RenderObject.ts","../src/light/Light.ts","../src/math/Color.ts","../src/math/Matrix2.ts","../src/render/Uniforms.ts","../src/render/UniformBuffer.ts","../src/shader/material/billboard_fs.ts","../src/shader/WgslPreprocessor.ts","../src/shader/material/billboard_vs.ts","../src/shader/material/colorFrag.ts","../src/shader/material/colorVert.ts","../src/shader/material/pbr_fs.ts","../src/shader/material/pbr_vs.ts","../src/shader/material/pbrFrag.ts","../src/shader/material/pbrVert.ts","../src/shader/material/phongFrag.ts","../src/shader/material/phongVert.ts","../src/shader/material/quadFrag.ts","../src/shader/material/quadVert.ts","../src/shader/material/skyBoxFrag.ts","../src/shader/material/skyBoxVert.ts","../src/shader/postProcess/blend/blendFrag.ts","../src/shader/postProcess/bloom/Blur.ts","../src/shader/postProcess/bloom/LuminosityHigh.ts","../src/shader/shaderChunk/attribute/FragInput.ts","../src/shader/shaderChunk/attribute/VertexInput.ts","../src/shader/shaderChunk/attribute/VertexOutput.ts","../src/shader/shaderChunk/common/SystemUniform.ts","../src/shader/shaderChunk/common/TextureAndSamplerDefine.ts","../src/shader/shaderChunk/environment/environment.ts","../src/shader/shaderChunk/instance/Instance.ts","../src/shader/shaderChunk/light/light.ts","../src/shader/shaderChunk/light/lightCommon.ts","../src/shader/shaderChunk/normal/getNormalBackUp.ts","../src/shader/shaderChunk/pbr/brdf.ts","../src/shader/shaderChunk/pbr/ibl.ts","../src/shader/shaderChunk/pbr/pbrFunction.ts","../src/shader/shaderChunk/pbr/pbrStruct.ts","../src/shader/shaderChunk/pbr/pbrTexture.ts","../src/shader/shaderChunk/pbr/pbrUtils.ts","../src/shader/shaderChunk/phong/blinn_phong.ts","../src/shader/shaderChunk/phong/phongFunction.ts","../src/shader/shaderChunk/phong/phongUtils.ts","../src/shader/shaderChunk/skin/SkinVert.ts","../src/shader/shaderChunk/struct/PbrMaterialStruct.ts","../src/shader/shaderChunk/ShaderChunk.ts","../src/shader/shaderChunk/shadow/shadowMapDebuggerFrag.ts","../src/shader/shaderChunk/shadow/shadowMapDebuggerVert.ts","../src/shader/shaderChunk/shadow/shadowMapFrag.ts","../src/shader/shaderChunk/shadow/shadowMapVert.ts","../src/shader/Shaders.ts","../src/shader/ShaderSource.ts","../src/utils/uniformUtils.ts","../src/render/BindGroupLayout.ts","../src/render/BindGroupLayoutEntry.ts","../src/render/ShaderData.ts","../src/material/Material.ts","../src/material/ShaderMaterial.ts","../src/utils/createGuid.ts","../src/mesh/Mesh.ts","../src/helper/ShadowMapDebugger.ts","../src/material/ColorMaterial.ts","../src/mesh/Axes.ts","../src/geometry/SkyBoxGeometry.ts","../src/utils/destroyObject.ts","../src/core/TextureCache.ts","../src/loader/CubeTextureLoader.ts","../src/material/SkyBoxMaterial.ts","../src/mesh/SkyBox.ts","../src/mesh/Instance.ts","../src/mesh/InstanceMesh.ts","../src/utils/GeometryUtils.ts","../src/geometry/SphereGeometry.ts","../src/geometry/BoxGeometry.ts","../src/geometry/TorusKnotGeometry.ts","../src/material/BlinnPhongMaterial.ts","../src/material/PbrMaterial.ts","../src/core/EventDispatcher.ts","../src/core/RenderQueue.ts","../src/core/FrameState.ts","../src/light/AmbientLight.ts","../src/core/LightManger.ts","../src/core/MeshManger.ts","../src/render/RenderTarget.ts","../src/post-process/ResolveFrame.ts","../src/post-process/PostEffectCollection.ts","../src/pass/Pass.ts","../src/pass/BasicPass.ts","../src/math/Plane.ts","../src/core/CullingVolume.ts","../src/camera/Camera.ts","../src/camera/PerspectiveCamera.ts","../src/camera/PointLightShadowCamera.ts","../src/light/shadows/BaseShadow.ts","../src/light/shadows/PointLightShadow.ts","../src/light/PointLight.ts","../src/pass/ShadowPass.ts","../src/renderpipeline/ForwardRenderLine.ts","../src/Scene.ts","../src/post-process/PostEffect.ts","../src/post-process/BloomPostEffect.ts","../src/camera/OrthographicCamera.ts","../src/light/shadows/SpotLightShadow.ts","../src/light/SpotLight.ts","../src/light/shadows/DirectionalLightShadow.ts","../src/light/DirectionalLight.ts","../src/mesh/Node.ts","../src/mesh/SKinMesh.ts","../src/utils/gltfUtils.ts","../src/loader/gltf/libs/Accessor.ts","../src/loader/gltf/libs/Animation.ts","../src/loader/gltf/libs/AnimationChannel.ts","../src/loader/gltf/libs/AnimationChannelTarget.ts","../src/loader/gltf/types/gltfType.ts","../src/loader/gltf/libs/AnimationSampler.ts","../src/loader/GLTFLoader.ts","../src/utils/utils.ts","../src/math/Spherical.ts","../src/control/OrbitControl.ts"],"sourcesContent":["/** @internal */\nexport enum PredefinedColorSpace {\n\tSRGB = \"srgb\"\n}\n\n/** @internal */\nexport enum PowerPreference {\n\tLowPower = \"low-power\",\n\tHighPerformance = \"high-performance\"\n}\n\n/** @internal */\nexport enum FeatureName {\n\tDepthClipControl = \"depth-clip-control\",\n\tDepth24UnormStencil8 = \"depth24unorm-stencil8\",\n\tDepth32FloatStencil8 = \"depth32float-stencil8\",\n\tTextureCompressionBC = \"texture-compression-bc\",\n\tTextureCompressionETC2 = \"texture-compression-etc2\",\n\tTextureCompressionASTC = \"texture-compression-astc\",\n\tTimestampQuery = \"timestamp-query\",\n\tIndirectFirstInstance = \"indirect-first-instance\",\n\tShaderF16 = \"shader-f16\",\n\tBGRA8UnormStorage = \"bgra8unorm-storage\"\n}\n\n/** @internal */\nexport enum BufferUsage {\n\tMapRead = 1,\n\tMapWrite = 2,\n\tCopySrc = 4,\n\tCopyDst = 8,\n\tIndex = 16,\n\tVertex = 32,\n\tUniform = 64,\n\tStorage = 128,\n\tIndirect = 256,\n\tQueryResolve = 512\n}\n\n/** @internal */\nexport enum MapMode {\n\tRead = 1,\n\tWrite = 2\n}\n\n/** @internal */\nexport enum TextureDimension {\n\tE1d = \"1d\",\n\tE2d = \"2d\",\n\tE3d = \"3d\"\n}\n\n/** @internal */\nexport enum TextureUsage {\n\tCopySrc = 1,\n\tCopyDst = 2,\n\tTextureBinding = 4,\n\tStorageBinding = 8,\n\tRenderAttachment = 16\n}\n\n/** @internal */\nexport enum TextureViewDimension {\n\tE1d = \"1d\",\n\tE2d = \"2d\",\n\tE2dArray = \"2d-array\",\n\tCube = \"cube\",\n\tCubeArray = \"cube-array\",\n\tE3d = \"3d\"\n}\n\n/** @internal */\nexport enum TextureAspect {\n\tAll = \"all\",\n\tStencilOnly = \"stencil-only\",\n\tDepthOnly = \"depth-only\"\n}\n\n/**\n * Comments taken from https://github.com/gfx-rs/wgpu/blob/master/wgpu-types/src/lib.rs\n * @internal\n */\nexport enum TextureFormat {\n\t// 8-bit formats\n\tR8Unorm = \"r8unorm\", // Red channel only. 8 bit integer per channel. [0, 255] converted to/from float [0, 1] in shader.\n\tR8Snorm = \"r8snorm\", // Red channel only. 8 bit integer per channel. [-127, 127] converted to/from float [-1, 1] in shader.\n\tR8Uint = \"r8uint\", // Red channel only. 8 bit integer per channel. Unsigned in shader.\n\tR8Sint = \"r8sint\", // Red channel only. 8 bit integer per channel. Signed in shader.\n\n\t// 16-bit formats\n\tR16Uint = \"r16uint\", // Red channel only. 16 bit integer per channel. Unsigned in shader.\n\tR16Sint = \"r16sint\", // Red channel only. 16 bit integer per channel. Signed in shader.\n\tR16Float = \"r16float\", // Red channel only. 16 bit float per channel. Float in shader.\n\tRG8Unorm = \"rg8unorm\", // Red and green channels. 8 bit integer per channel. [0, 255] converted to/from float [0, 1] in shader.\n\tRG8Snorm = \"rg8snorm\", // Red and green channels. 8 bit integer per channel. [-127, 127] converted to/from float [-1, 1] in shader.\n\tRG8Uint = \"rg8uint\", // Red and green channels. 8 bit integer per channel. Unsigned in shader.\n\tRG8Sint = \"rg8sint\", // Red and green channels. 8 bit integer per channel. Signed in shader.\n\n\t// 32-bit formats\n\tR32Uint = \"r32uint\", // Red channel only. 32 bit integer per channel. Unsigned in shader.\n\tR32Sint = \"r32sint\", // Red channel only. 32 bit integer per channel. Signed in shader.\n\tR32Float = \"r32float\", // Red channel only. 32 bit float per channel. Float in shader.\n\tRG16Uint = \"rg16uint\", // Red and green channels. 16 bit integer per channel. Unsigned in shader.\n\tRG16Sint = \"rg16sint\", // Red and green channels. 16 bit integer per channel. Signed in shader.\n\tRG16Float = \"rg16float\", // Red and green channels. 16 bit float per channel. Float in shader.\n\tRGBA8Unorm = \"rgba8unorm\", // Red, green, blue, and alpha channels. 8 bit integer per channel. [0, 255] converted to/from float [0, 1] in shader.\n\tRGBA8UnormSRGB = \"rgba8unorm-srgb\", // Red, green, blue, and alpha channels. 8 bit integer per channel. Srgb-color [0, 255] converted to/from linear-color float [0, 1] in shader.\n\tRGBA8Snorm = \"rgba8snorm\", // Red, green, blue, and alpha channels. 8 bit integer per channel. [-127, 127] converted to/from float [-1, 1] in shader.\n\tRGBA8Uint = \"rgba8uint\", // Red, green, blue, and alpha channels. 8 bit integer per channel. Unsigned in shader.\n\tRGBA8Sint = \"rgba8sint\", // Red, green, blue, and alpha channels. 8 bit integer per channel. Signed in shader.\n\tBGRA8Unorm = \"bgra8unorm\", // Blue, green, red, and alpha channels. 8 bit integer per channel. [0, 255] converted to/from float [0, 1] in shader.\n\tBGRA8UnormSRGB = \"bgra8unorm-srgb\", // Blue, green, red, and alpha channels. 8 bit integer per channel. Srgb-color [0, 255] converted to/from linear-color float [0, 1] in shader.\n\t// Packed 32-bit formats\n\tRGB9E5UFloat = \"rgb9e5ufloat\", // Packed unsigned float with 9 bits mantisa for each RGB component, then a common 5 bits exponent\n\tRGB10A2Unorm = \"rgb10a2unorm\", // Red, green, blue, and alpha channels. 10 bit integer for RGB channels, 2 bit integer for alpha channel. [0, 1023] ([0, 3] for alpha) converted to/from float [0, 1] in shader.\n\tRG11B10UFloat = \"rg11b10ufloat\", // Red, green, and blue channels. 11 bit float with no sign bit for RG channels. 10 bit float with no sign bit for blue channel. Float in shader.\n\n\t// 64-bit formats\n\tRG32Uint = \"rg32uint\", // Red and green channels. 32 bit integer per channel. Unsigned in shader.\n\tRG32Sint = \"rg32sint\", // Red and green channels. 32 bit integer per channel. Signed in shader.\n\tRG32Float = \"rg32float\", // Red and green channels. 32 bit float per channel. Float in shader.\n\tRGBA16Uint = \"rgba16uint\", // Red, green, blue, and alpha channels. 16 bit integer per channel. Unsigned in shader.\n\tRGBA16Sint = \"rgba16sint\", // Red, green, blue, and alpha channels. 16 bit integer per channel. Signed in shader.\n\tRGBA16Float = \"rgba16float\", // Red, green, blue, and alpha channels. 16 bit float per channel. Float in shader.\n\n\t// 128-bit formats\n\tRGBA32Uint = \"rgba32uint\", // Red, green, blue, and alpha channels. 32 bit integer per channel. Unsigned in shader.\n\tRGBA32Sint = \"rgba32sint\", // Red, green, blue, and alpha channels. 32 bit integer per channel. Signed in shader.\n\tRGBA32Float = \"rgba32float\", // Red, green, blue, and alpha channels. 32 bit float per channel. Float in shader.\n\n\t// Depth and stencil formats\n\tStencil8 = \"stencil8\",\n\tDepth16Unorm = \"depth16unorm\",\n\tDepth24Plus = \"depth24plus\", // Special depth format with at least 24 bit integer depth.\n\tDepth24PlusStencil8 = \"depth24plus-stencil8\", // Special depth/stencil format with at least 24 bit integer depth and 8 bits integer stencil.\n\tDepth32Float = \"depth32float\", // Special depth format with 32 bit floating point depth.\n\n\t// BC compressed formats usable if \"texture-compression-bc\" is both\n\t// supported by the device/user agent and enabled in requestDevice.\n\tBC1RGBAUnorm = \"bc1-rgba-unorm\", // 4x4 block compressed texture. 8 bytes per block (4 bit/px). 4 color + alpha pallet. 5 bit R + 6 bit G + 5 bit B + 1 bit alpha. Also known as DXT1.\n\tBC1RGBAUnormSRGB = \"bc1-rgba-unorm-srgb\", // 4x4 block compressed texture. 8 bytes per block (4 bit/px). 4 color + alpha pallet. 5 bit R + 6 bit G + 5 bit B + 1 bit alpha. Also known as DXT1.\n\tBC2RGBAUnorm = \"bc2-rgba-unorm\", // 4x4 block compressed texture. 16 bytes per block (8 bit/px). 4 color pallet. 5 bit R + 6 bit G + 5 bit B + 4 bit alpha. Also known as DXT3.\n\tBC2RGBAUnormSRGB = \"bc2-rgba-unorm-srgb\", // 4x4 block compressed texture. 16 bytes per block (8 bit/px). 4 color pallet. 5 bit R + 6 bit G + 5 bit B + 4 bit alpha. Also known as DXT3.\n\tBC3RGBAUnorm = \"bc3-rgba-unorm\", // 4x4 block compressed texture. 16 bytes per block (8 bit/px). 4 color pallet + 8 alpha pallet. 5 bit R + 6 bit G + 5 bit B + 8 bit alpha. Also known as DXT5.\n\tBC3RGBAUnormSRGB = \"bc3-rgba-unorm-srgb\", // 4x4 block compressed texture. 16 bytes per block (8 bit/px). 4 color pallet + 8 alpha pallet. 5 bit R + 6 bit G + 5 bit B + 8 bit alpha. Also known as DXT5.\n\tBC4RUnorm = \"bc4-r-unorm\", // 4x4 block compressed texture. 8 bytes per block (4 bit/px). 8 color pallet. 8 bit R. Also known as RGTC1.\n\tBC4RSnorm = \"bc4-r-snorm\", // 4x4 block compressed texture. 8 bytes per block (4 bit/px). 8 color pallet. 8 bit R. Also known as RGTC1.\n\tBC5RGUnorm = \"bc5-rg-unorm\", // 4x4 block compressed texture. 16 bytes per block (8 bit/px). 8 color red pallet + 8 color green pallet. 8 bit RG. Also known as RGTC2.\n\tBC5RGSnorm = \"bc5-rg-snorm\", // 4x4 block compressed texture. 16 bytes per block (8 bit/px). 8 color red pallet + 8 color green pallet. 8 bit RG. Also known as RGTC2.\n\tBC6HRGBUFloat = \"bc6h-rgb-ufloat\", // 4x4 block compressed texture. 16 bytes per block (8 bit/px). Variable sized pallet. 16 bit unsigned float RGB. Float in shader. Also known as BPTC (float).\n\tBC6HRGBFloat = \"bc6h-rgb-float\", // 4x4 block compressed texture. 16 bytes per block (8 bit/px). Variable sized pallet. 16 bit signed float RGB. Float in shader. Also known as BPTC (float).\n\tBC7RGBAUnorm = \"bc7-rgba-unorm\", // 4x4 block compressed texture. 16 bytes per block (8 bit/px). Variable sized pallet. 8 bit integer RGBA. Also known as BPTC (unorm).\n\tBC7RGBAUnormSRGB = \"bc7-rgba-unorm-srgb\", // 4x4 block compressed texture. 16 bytes per block (8 bit/px). Variable sized pallet. 8 bit integer RGBA. Also known as BPTC (unorm).\n\n\t// ETC2 compressed formats usable if \"texture-compression-etc2\" is both\n\t// supported by the device/user agent and enabled in requestDevice.\n\tETC2RGB8Unorm = \"etc2-rgb8unorm\", // 4x4 block compressed texture. 8 bytes per block (4 bit/px). Complex pallet. 8 bit integer RGB.\n\tETC2RGB8UnormSRGB = \"etc2-rgb8unorm-srgb\", // 4x4 block compressed texture. 8 bytes per block (4 bit/px). Complex pallet. 8 bit integer RGB.\n\tETC2RGB8A1Unorm = \"etc2-rgb8a1unorm\", // 4x4 block compressed texture. 8 bytes per block (4 bit/px). Complex pallet. 8 bit integer RGB + 1 bit alpha.\n\tETC2RGB8A1UnormSRGB = \"etc2-rgb8a1unorm-srgb\", // 4x4 block compressed texture. 8 bytes per block (4 bit/px). Complex pallet. 8 bit integer RGB + 1 bit alpha.\n\tETC2RGBA8Unorm = \"etc2-rgba8unorm\", // 4x4 block compressed texture. 16 bytes per block (8 bit/px). Complex pallet. 8 bit integer RGB + 8 bit alpha.\n\tETC2RGBA8UnormSRGB = \"etc2-rgba8unorm-srgb\", // 4x4 block compressed texture. 16 bytes per block (8 bit/px). Complex pallet. 8 bit integer RGB + 8 bit alpha.\n\tEACR11Unorm = \"eac-r11unorm\", // 4x4 block compressed texture. 8 bytes per block (4 bit/px). Complex pallet. 11 bit integer R.\n\tEACR11Snorm = \"eac-r11snorm\", // 4x4 block compressed texture. 8 bytes per block (4 bit/px). Complex pallet. 11 bit integer R.\n\tEACRG11Unorm = \"eac-rg11unorm\", // 4x4 block compressed texture. 16 bytes per block (8 bit/px). Complex pallet. 11 bit integer R + 11 bit integer G.\n\tEACRG11Snorm = \"eac-rg11snorm\", // 4x4 block compressed texture. 16 bytes per block (8 bit/px). Complex pallet. 11 bit integer R + 11 bit integer G.\n\n\t// ASTC compressed formats usable if \"texture-compression-astc\" is both\n\t// supported by the device/user agent and enabled in requestDevice.\n\tASTC4x4Unorm = \"astc-4x4-unorm\", // 4x4 block compressed texture. 16 bytes per block (8 bit/px). Complex pallet. 8 bit integer RGBA.\n\tASTC4x4UnormSRGB = \"astc-4x4-unorm-srgb\", // 4x4 block compressed texture. 16 bytes per block (8 bit/px). Complex pallet. 8 bit integer RGBA.\n\tASTC5x4Unorm = \"astc-5x4-unorm\", // 5x4 block compressed texture. 16 bytes per block (6.4 bit/px). Complex pallet. 8 bit integer RGBA.\n\tASTC5x4UnormSRGB = \"astc-5x4-unorm-srgb\", // 5x4 block compressed texture. 16 bytes per block (6.4 bit/px). Complex pallet. 8 bit integer RGBA.\n\tASTC5x5Unorm = \"astc-5x5-unorm\", // 5x5 block compressed texture. 16 bytes per block (5.12 bit/px). Complex pallet. 8 bit integer RGBA.\n\tASTC5x5UnormSRGB = \"astc-5x5-unorm-srgb\", // 5x5 block compressed texture. 16 bytes per block (5.12 bit/px). Complex pallet. 8 bit integer RGBA.\n\tASTC6x5Unorm = \"astc-6x5-unorm\", // 6x5 block compressed texture. 16 bytes per block (4.27 bit/px). Complex pallet. 8 bit integer RGBA.\n\tASTC6x5UnormSRGB = \"astc-6x5-unorm-srgb\", // 6x5 block compressed texture. 16 bytes per block (4.27 bit/px). Complex pallet. 8 bit integer RGBA.\n\tASTC6x6Unorm = \"astc-6x6-unorm\", // 6x6 block compressed texture. 16 bytes per block (3.56 bit/px). Complex pallet. 8 bit integer RGBA.\n\tASTC6x6UnormSRGB = \"astc-6x6-unorm-srgb\", // 6x6 block compressed texture. 16 bytes per block (3.56 bit/px). Complex pallet. 8 bit integer RGBA.\n\tASTC8x5Unorm = \"astc-8x5-unorm\", // 8x5 block compressed texture. 16 bytes per block (3.2 bit/px). Complex pallet. 8 bit integer RGBA.\n\tASTC8x5UnormSRGB = \"astc-8x5-unorm-srgb\", // 8x5 block compressed texture. 16 bytes per block (3.2 bit/px). Complex pallet. 8 bit integer RGBA.\n\tASTC8x6Unorm = \"astc-8x6-unorm\", // 8x6 block compressed texture. 16 bytes per block (2.67 bit/px). Complex pallet. 8 bit integer RGBA.\n\tASTC8x6UnormSRGB = \"astc-8x6-unorm-srgb\", // 8x6 block compressed texture. 16 bytes per block (2.67 bit/px). Complex pallet. 8 bit integer RGBA.\n\tASTC8x8Unorm = \"astc-8x8-unorm\", // 8x8 block compressed texture. 16 bytes per block (2 bit/px). Complex pallet. 8 bit integer RGBA.\n\tASTC8x8UnormSRGB = \"astc-8x8-unorm-srgb\", // 8x8 block compressed texture. 16 bytes per block (2 bit/px). Complex pallet. 8 bit integer RGBA.\n\tASTC10x5Unorm = \"astc-10x5-unorm\", // 10x5 block compressed texture. 16 bytes per block (2.56 bit/px). Complex pallet. 8 bit integer RGBA.\n\tASTC10x5UnormSRGB = \"astc-10x5-unorm-srgb\", // 10x5 block compressed texture. 16 bytes per block (2.56 bit/px). Complex pallet. 8 bit integer RGBA.\n\tASTC10x6Unorm = \"astc-10x6-unorm\", // 10x6 block compressed texture. 16 bytes per block (2.13 bit/px). Complex pallet. 8 bit integer RGBA.\n\tASTC10x6UnormSRGB = \"astc-10x6-unorm-srgb\", // 10x6 block compressed texture. 16 bytes per block (2.13 bit/px). Complex pallet. 8 bit integer RGBA.\n\tASTC10x8Unorm = \"astc-10x8-unorm\", // 10x8 block compressed texture. 16 bytes per block (1.6 bit/px). Complex pallet. 8 bit integer RGBA.\n\tASTC10x8UnormSRGB = \"astc-10x8-unorm-srgb\", // 10x8 block compressed texture. 16 bytes per block (1.6 bit/px). Complex pallet. 8 bit integer RGBA.\n\tASTC10x10Unorm = \"astc-10x10-unorm\", // 10x10 block compressed texture. 16 bytes per block (1.28 bit/px). Complex pallet. 8 bit integer RGBA.\n\tASTC10x10UnormSRGB = \"astc-10x10-unorm-srgb\", // 10x10 block compressed texture. 16 bytes per block (1.28 bit/px). Complex pallet. 8 bit integer RGBA.\n\tASTC12x10Unorm = \"astc-12x10-unorm\", // 12x10 block compressed texture. 16 bytes per block (1.07 bit/px). Complex pallet. 8 bit integer RGBA.\n\tASTC12x10UnormSRGB = \"astc-12x10-unorm-srgb\", // 12x10 block compressed texture. 16 bytes per block (1.07 bit/px). Complex pallet. 8 bit integer RGBA.\n\tASTC12x12Unorm = \"astc-12x12-unorm\", // 12x12 block compressed texture. 16 bytes per block (0.89 bit/px). Complex pallet. 8 bit integer RGBA.\n\tASTC12x12UnormSRGB = \"astc-12x12-unorm-srgb\", // 12x12 block compressed texture. 16 bytes per block (0.89 bit/px). Complex pallet. 8 bit integer RGBA.\n\n\t// \"depth24unorm-stencil8\" feature\n\tDepth24UnormStencil8 = \"depth24unorm-stencil8\",\n\n\t// \"depth32float-stencil8\" feature\n\tDepth32FloatStencil8 = \"depth32float-stencil8\"\n}\n\n/** @internal */\nexport enum AddressMode {\n\tClampToEdge = \"clamp-to-edge\",\n\tRepeat = \"repeat\",\n\tMirrorRepeat = \"mirror-repeat\"\n}\n\n/** @internal */\nexport enum FilterMode {\n\tNearest = \"nearest\",\n\tLinear = \"linear\"\n}\n\n/** @internal */\nexport enum CompareFunction {\n\tNever = \"never\",\n\tLess = \"less\",\n\tEqual = \"equal\",\n\tLessEqual = \"less-equal\",\n\tGreater = \"greater\",\n\tNotEqual = \"not-equal\",\n\tGreaterEqual = \"greater-equal\",\n\tAlways = \"always\"\n}\n\n/** @internal */\nexport enum ShaderStage {\n\tVertex = 1,\n\tFragment = 2,\n\tCompute = 4\n}\n\n/** @internal */\nexport enum BufferBindingType {\n\tUniform = \"uniform\",\n\tStorage = \"storage\",\n\tReadOnlyStorage = \"read-only-storage\"\n}\n\n/** @internal */\nexport enum SamplerBindingType {\n\tFiltering = \"filtering\",\n\tNonFiltering = \"non-filtering\",\n\tComparison = \"comparison\"\n}\n\n/** @internal */\nexport enum TextureSampleType {\n\tFloat = \"float\",\n\tUnfilterableFloat = \"unfilterable-float\",\n\tDepth = \"depth\",\n\tSint = \"sint\",\n\tUint = \"uint\"\n}\n\n/** @internal */\nexport enum StorageTextureAccess {\n\tWriteOnly = \"write-only\"\n}\n\n/** @internal */\nexport enum CompilationMessageType {\n\tError = \"error\",\n\tWarning = \"warning\",\n\tInfo = \"info\"\n}\n\n/** @internal */\nexport enum AutoLayoutMode {\n\tAuto = \"auto\"\n}\n\n/** @internal */\nexport enum PrimitiveTopology {\n\tPointList = \"point-list\",\n\tLineList = \"line-list\",\n\tLineStrip = \"line-strip\",\n\tTriangleList = \"triangle-list\",\n\tTriangleStrip = \"triangle-strip\"\n}\n\n/** @internal */\nexport enum FrontFace {\n\tCCW = \"ccw\",\n\tCW = \"cw\"\n}\n\n/** @internal */\nexport enum CullMode {\n\tNone = \"none\",\n\tFront = \"front\",\n\tBack = \"back\"\n}\n\n/** @internal */\nexport enum ColorWriteFlags {\n\tRed = 1,\n\tGreen = 2,\n\tBlue = 4,\n\tAlpha = 8,\n\tAll = 15\n}\n\n/** @internal */\nexport enum BlendFactor {\n\tZero = \"zero\",\n\tOne = \"one\",\n\tSrc = \"src\",\n\tOneMinusSrc = \"one-minus-src\",\n\tSrcAlpha = \"src-alpha\",\n\tOneMinusSrcAlpha = \"one-minus-src-alpha\",\n\tDst = \"dst\",\n\tOneMinusDst = \"one-minus-dst\",\n\tDstAlpha = \"dst-alpha\",\n\tOneMinusDstAlpha = \"one-minus-dst-alpha\",\n\tSrcAlphaSaturated = \"src-alpha-saturated\",\n\tConstant = \"constant\",\n\tOneMinusConstant = \"one-minus-constant\"\n}\n\n/** @internal */\nexport enum BlendOperation {\n\tAdd = \"add\",\n\tSubtract = \"subtract\",\n\tReverseSubtract = \"reverse-subtract\",\n\tMin = \"min\",\n\tMax = \"max\"\n}\n\n/** @internal */\nexport enum StencilOperation {\n\tKeep = \"keep\",\n\tZero = \"zero\",\n\tReplace = \"replace\",\n\tInvert = \"invert\",\n\tIncrementClamp = \"increment-clamp\",\n\tDecrementClamp = \"decrement-clamp\",\n\tIncrementWrap = \"increment-wrap\",\n\tDecrementWrap = \"decrement-wrap\"\n}\n\n/** @internal */\nexport enum IndexFormat {\n\tUint16 = \"uint16\",\n\tUint32 = \"uint32\"\n}\n\n/** @internal */\nexport enum VertexFormat {\n\tUint8x2 = \"uint8x2\",\n\tUint8x4 = \"uint8x4\",\n\tSint8x2 = \"sint8x2\",\n\tSint8x4 = \"sint8x4\",\n\tUnorm8x2 = \"unorm8x2\",\n\tUnorm8x4 = \"unorm8x4\",\n\tSnorm8x2 = \"snorm8x2\",\n\tSnorm8x4 = \"snorm8x4\",\n\tUint16x2 = \"uint16x2\",\n\tUint16x4 = \"uint16x4\",\n\tSint16x2 = \"sint16x2\",\n\tSint16x4 = \"sint16x4\",\n\tUnorm16x2 = \"unorm16x2\",\n\tUnorm16x4 = \"unorm16x4\",\n\tSnorm16x2 = \"snorm16x2\",\n\tSnorm16x4 = \"snorm16x4\",\n\tFloat16x2 = \"float16x2\",\n\tFloat16x4 = \"float16x4\",\n\tFloat32 = \"float32\",\n\tFloat32x2 = \"float32x2\",\n\tFloat32x3 = \"float32x3\",\n\tFloat32x4 = \"float32x4\",\n\tUint32 = \"uint32\",\n\tUint32x2 = \"uint32x2\",\n\tUint32x3 = \"uint32x3\",\n\tUint32x4 = \"uint32x4\",\n\tSint32 = \"sint32\",\n\tSint32x2 = \"sint32x2\",\n\tSint32x3 = \"sint32x3\",\n\tSint32x4 = \"sint32x4\"\n}\n\n/** @internal */\nexport enum InputStepMode {\n\tVertex = \"vertex\",\n\tInstance = \"instance\"\n}\n\n/** @internal */\nexport enum ComputePassTimestampLocation {\n\tBeginning = \"beginning\",\n\tEnd = \"end\"\n}\n\n/** @internal */\nexport enum RenderPassTimestampLocation {\n\tBeginning = \"beginning\",\n\tEnd = \"end\"\n}\n\n/** @internal */\nexport enum LoadOp {\n\tLoad = \"load\",\n\tClear = \"clear\"\n}\n\n/** @internal */\nexport enum StoreOp {\n\tStore = \"store\",\n\tDiscard = \"discard\"\n}\n\n/** @internal */\nexport enum QueryType {\n\tOcclusion = \"occlusion\",\n\tTimestamp = \"timestamp\"\n}\n\n/** @internal */\nexport enum CanvasAlphaMode {\n\tOpaque = \"opaque\",\n\tPremultiplied = \"premultiplied\"\n}\n\n/** @internal */\nexport enum DeviceLostReason {\n\tDestroyed = \"destroyed\"\n}\n\n/** @internal */\nexport enum ErrorFilter {\n\tOutOfMemory = \"out-of-memory\",\n\tValidation = \"validation\"\n}\n\nexport enum GPUColorWrite {\n\tRed = 0x1,\n\tGreen = 0x2,\n\tBlue = 0x4,\n\tAlpha = 0x8,\n\tAll = 0xf\n}\nexport enum CommandSubType {\n\tShadow = \"shadow\",\n\tPick = \"pick\"\n}\nexport enum Intersect {\n\tOUTSIDE = -1,\n\tINTERSECTING = 0,\n\tINSIDE = 1\n}\n","import { BufferUsage } from \"../core/WebGPUConstant\";\r\nclass Buffer {\r\n\tpublic gpuBuffer: GPUBuffer;\r\n\tdevice: GPUDevice;\r\n\tusage: number;\r\n\tdata: ArrayBufferView;\r\n\tsize: number;\r\n\tconstructor(\r\n\t\tlabel: string,\r\n\t\tdevice: GPUDevice,\r\n\t\tusage: GPUBufferUsageFlags,\r\n\t\tdata: ArrayBufferView | null,\r\n\t\tsize?: number\r\n\t) {\r\n\t\tthis.device = device;\r\n\t\tthis.usage = usage;\r\n\t\tthis.data = data;\r\n\t\tthis.size = size != undefined ? (size + 3) & ~3 : (data.byteLength + 3) & ~3; // 4 bytes alignments (because of the upload which requires this)\r\n\t\tthis.gpuBuffer = device.createBuffer({\r\n\t\t\tlabel: label || \"\",\r\n\t\t\tsize: this.size,\r\n\t\t\tusage\r\n\t\t});\r\n\t\tif (data) this.setSubData(0, data, this.size);\r\n\t}\r\n\tstatic create(\r\n\t\tlabel: string,\r\n\t\tdevice: GPUDevice,\r\n\t\tusage: GPUBufferUsageFlags,\r\n\t\tdata: ArrayBufferView | null,\r\n\t\tsize?: number\r\n\t) {\r\n\t\treturn new Buffer(label, device, usage, data, size);\r\n\t}\r\n\tstatic createVertexBuffer(label: string, device: GPUDevice, data: ArrayBufferView): Buffer {\r\n\t\treturn new Buffer(label, device, BufferUsage.Vertex | BufferUsage.CopyDst, data, data.byteLength);\r\n\t}\r\n\r\n\tstatic createIndexBuffer(label: string, device: GPUDevice, data: ArrayBufferView): Buffer {\r\n\t\treturn new Buffer(label, device, BufferUsage.Index | BufferUsage.CopyDst, data);\r\n\t}\r\n\r\n\tstatic createUniformBuffer(label: string, device: GPUDevice, size: number, usage?: BufferUsage): Buffer {\r\n\t\treturn new Buffer(label, device, usage, null, size);\r\n\t}\r\n\tstatic getBufferType(usage) {\r\n\t\tlet result;\r\n\t\tswitch (usage) {\r\n\t\t\tcase BufferUsage.Uniform:\r\n\t\t\t\tresult = \"uniform\";\r\n\t\t\t\tbreak;\r\n\t\t\tcase BufferUsage.Storage:\r\n\t\t\t\tresult = \"storage\";\r\n\t\t\t\tbreak;\r\n\t\t\tdefault:\r\n\t\t\t\tbreak;\r\n\t\t}\r\n\t}\r\n\t// https://github.com/gpuweb/gpuweb/blob/main/design/BufferOperations.md\r\n\tpublic setSubData(offset: number, data: ArrayBufferView, size?: number): void {\r\n\t\tconst srcArrayBuffer = data.buffer;\r\n\t\tconst byteCount = size ?? srcArrayBuffer.byteLength;\r\n\t\tconst srcBuffer = this.device.createBuffer({\r\n\t\t\tmappedAtCreation: true,\r\n\t\t\tsize: byteCount,\r\n\t\t\tusage: GPUBufferUsage.COPY_SRC\r\n\t\t});\r\n\t\tconst arrayBuffer = srcBuffer.getMappedRange();\r\n\r\n\t\tnew Uint16Array(arrayBuffer).set(new Uint16Array(srcArrayBuffer)); // memcpy\r\n\t\tsrcBuffer.unmap();\r\n\r\n\t\tthis.copyToBuffer(srcBuffer, offset, byteCount);\r\n\r\n\t\tsrcBuffer.destroy();\r\n\t}\r\n\r\n\tpublic copyToBuffer(srcBuffer: GPUBuffer, offset: number, byteCount: number): void {\r\n\t\tconst commandEncoder = this.device.createCommandEncoder();\r\n\t\tcommandEncoder.copyBufferToBuffer(srcBuffer, 0, this.gpuBuffer, offset, byteCount);\r\n\t\tthis.device.queue.submit([commandEncoder.finish()]);\r\n\t}\r\n\r\n\tpublic copyToTexture(\r\n\t\tbytesPerRow: number,\r\n\t\trowsPerImage: number,\r\n\t\tdestination: GPUImageCopyTexture,\r\n\t\textent: GPUExtent3D\r\n\t): void {\r\n\t\tconst commandEncoder = this.device.createCommandEncoder();\r\n\t\tcommandEncoder.copyBufferToTexture(\r\n\t\t\t{\r\n\t\t\t\tbuffer: this.gpuBuffer,\r\n\t\t\t\tbytesPerRow,\r\n\t\t\t\trowsPerImage\r\n\t\t\t},\r\n\t\t\tdestination,\r\n\t\t\textent\r\n\t\t);\r\n\t\tthis.device.queue.submit([commandEncoder.finish()]);\r\n\t}\r\n\r\n\tpublic destroy(): void {\r\n\t\tthis.gpuBuffer.destroy();\r\n\t}\r\n}\r\n\r\nexport default Buffer;\r\n","import BindGroupLayout from \"./BindGroupLayout\";\r\n\r\nconst pipelineLayoutCache = new Map();\r\nexport class PipelineLayout {\r\n  public gpuPipelineLayout: GPUPipelineLayout;\r\n  index: number;\r\n  private constructor(\r\n    device: GPUDevice,\r\n    label: string,\r\n    public groupLayouts: BindGroupLayout[] = [],\r\n    index?: number\r\n  ) {\r\n    this.index = index || 0;\r\n    this.gpuPipelineLayout = device.createPipelineLayout({\r\n      label: label,\r\n      bindGroupLayouts: groupLayouts.map((layout) => {\r\n        return layout.gpuBindGroupLayout;\r\n      }),\r\n    });\r\n  }\r\n  static getPipelineLayoutFromCache(\r\n    device: GPUDevice,\r\n    label: string,\r\n    groupLayouts: BindGroupLayout[]\r\n  ): PipelineLayout {\r\n    if (pipelineLayoutCache.has(label)) {\r\n      return pipelineLayoutCache.get(label);\r\n    } else {\r\n      const bindGroupLayout = new PipelineLayout(device, label, groupLayouts);\r\n      pipelineLayoutCache.set(label, bindGroupLayout);\r\n      return bindGroupLayout;\r\n    }\r\n  }\r\n}\r\n","import BindGroupLayout from \"./BindGroupLayout\";\r\nimport { ComputeCommand } from \"./ComputeCommand\";\r\nimport DrawCommand from \"./DrawCommand\";\r\nimport { PipelineLayout } from \"./PipelineLayout\";\r\nimport { RenderState } from \"./RenderState\";\r\n\r\nconst renderPipelines = new Map();\r\nconst computePipelines = new Map();\r\nexport default class Pipeline {\r\n\tgpuPipeline: GPURenderPipeline | GPUComputePipeline;\r\n\ttype: string;\r\n\tdevice: GPUDevice;\r\n\tdescriptor: GPURenderPipelineDescriptor | GPUComputePipelineDescriptor;\r\n\tconstructor(\r\n\t\ttype: string,\r\n\t\tdevice: GPUDevice,\r\n\t\tdescriptor: GPURenderPipelineDescriptor | GPUComputePipelineDescriptor\r\n\t) {\r\n\t\tthis.type = type;\r\n\t\tthis.descriptor = descriptor;\r\n\t\tthis.device = device;\r\n\t\tthis.createPipeline();\r\n\t}\r\n\tprivate createPipeline() {\r\n\t\tif (this.type == \"render\") {\r\n\t\t\tthis.gpuPipeline = this.device.createRenderPipeline(this.descriptor as GPURenderPipelineDescriptor);\r\n\t\t} else {\r\n\t\t\tthis.gpuPipeline = this.device.createComputePipeline(this.descriptor as GPUComputePipelineDescriptor);\r\n\t\t}\r\n\t}\r\n\tpublic bind(passEncoder: GPURenderPassEncoder | GPUComputePassEncoder) {\r\n\t\tif (this.type == \"render\") {\r\n\t\t\t(passEncoder as GPURenderPassEncoder).setPipeline(this.gpuPipeline as GPURenderPipeline);\r\n\t\t} else {\r\n\t\t\t(passEncoder as GPUComputePassEncoder).setPipeline(this.gpuPipeline as GPUComputePipeline);\r\n\t\t}\r\n\t}\r\n\tstatic getRenderPipelineFromCache(\r\n\t\tdevice: GPUDevice,\r\n\t\tdrawComand: DrawCommand,\r\n\t\tgroupLayouts: BindGroupLayout[]\r\n\t): Pipeline {\r\n\t\tconst { renderState, shaderSource } = drawComand;\r\n\t\tconst rsStr = JSON.stringify(renderState);\r\n\t\tconst combineStr = shaderSource.uid.concat(rsStr);\r\n\t\tconst hashId = stringToHash(combineStr);\r\n\t\tconst combineLayouts = groupLayouts\r\n\t\t\t?.filter((layout) => layout != undefined)\r\n\t\t\t?.sort((layout1, layout2) => layout1.index - layout2.index);\r\n\t\tlet pipeline = renderPipelines.get(hashId);\r\n\t\tif (!pipeline) {\r\n\t\t\tconst descriptor = Pipeline.getPipelineDescriptor(\r\n\t\t\t\tdevice,\r\n\t\t\t\tdrawComand,\r\n\t\t\t\trenderState,\r\n\t\t\t\tcombineLayouts,\r\n\t\t\t\thashId.toString()\r\n\t\t\t);\r\n\t\t\tpipeline = new Pipeline(\"render\", device, descriptor);\r\n\t\t\trenderPipelines.set(hashId, pipeline);\r\n\t\t}\r\n\t\treturn pipeline;\r\n\t}\r\n\tstatic getComputePipelineFromCache(\r\n\t\tdevice: GPUDevice,\r\n\t\tcomputeCommad: ComputeCommand,\r\n\t\tgroupLayouts: BindGroupLayout[]\r\n\t): Pipeline {\r\n\t\tconst { shaderSource } = computeCommad;\r\n\t\tconst hashId = stringToHash(shaderSource.uid);\r\n\t\tlet pipeline = computePipelines.get(hashId);\r\n\t\tif (!pipeline) {\r\n\t\t\tpipeline = device.createComputePipeline({\r\n\t\t\t\tlayout: PipelineLayout.getPipelineLayoutFromCache(device, hashId.toString(), groupLayouts)\r\n\t\t\t\t\t.gpuPipelineLayout,\r\n\t\t\t\tcompute: {\r\n\t\t\t\t\tmodule: shaderSource.createShaderModule(device) as GPUShaderModule,\r\n\t\t\t\t\tentryPoint: shaderSource.computeMain\r\n\t\t\t\t}\r\n\t\t\t});\r\n\t\t\tcomputePipelines.set(hashId, pipeline);\r\n\t\t}\r\n\t\treturn pipeline;\r\n\t}\r\n\tprivate static getPipelineDescriptor(\r\n\t\tdevice: GPUDevice,\r\n\t\tdrawComand: DrawCommand,\r\n\t\trenderState: RenderState,\r\n\t\tgroupLayouts: BindGroupLayout[],\r\n\t\thashId: string\r\n\t): GPURenderPipelineDescriptor {\r\n\t\tconst { vertexBuffer, shaderSource } = drawComand;\r\n\t\tconst { vert, frag } = shaderSource.createShaderModule(device) as {\r\n\t\t\tvert: GPUShaderModule;\r\n\t\t\tfrag: GPUShaderModule;\r\n\t\t};\r\n\t\tconst pipelineDec = {\r\n\t\t\tlayout: PipelineLayout.getPipelineLayoutFromCache(device, hashId, groupLayouts).gpuPipelineLayout\r\n\t\t} as any;\r\n\t\tif (vert)\r\n\t\t\tpipelineDec.vertex = {\r\n\t\t\t\tmodule: vert,\r\n\t\t\t\tentryPoint: shaderSource.vertEntryPoint,\r\n\t\t\t\tbuffers: vertexBuffer.getBufferDes() as Iterable<GPUVertexBufferLayout>\r\n\t\t\t};\r\n\t\tif (renderState.primitive) pipelineDec.primitive = renderState.primitive.getGPUPrimitiveDec();\r\n\t\tif (renderState.depthStencil) pipelineDec.depthStencil = renderState.depthStencil.getGPUDepthStencilDec();\r\n\t\tif (renderState.multisample) pipelineDec.multisample = renderState.multisample.getMultiSampleDec();\r\n\t\tif (frag)\r\n\t\t\tpipelineDec.fragment = {\r\n\t\t\t\tmodule: frag,\r\n\t\t\t\tentryPoint: shaderSource.fragEntryPoint,\r\n\t\t\t\ttargets: renderState.targets.map((target) => {\r\n\t\t\t\t\treturn target.getGPUTargetDec();\r\n\t\t\t\t})\r\n\t\t\t};\r\n\t\treturn pipelineDec;\r\n\t}\r\n}\r\n// Borrowed from https://werxltd.com/wp/2010/05/13/javascript-implementation-of-javas-string-hashcode-method/\r\nfunction stringToHash(str) {\r\n\tlet hash = 0;\r\n\tif (str.length == 0) return hash;\r\n\tfor (let i = 0; i < str.length; i++) {\r\n\t\tconst char = str.charCodeAt(i);\r\n\t\thash = (hash << 5) - hash + char;\r\n\t\thash = hash & hash; // Convert to 32bit integer\r\n\t}\r\n\treturn hash;\r\n}\r\n","import Camera from \"../camera/Camera\";\r\nimport { Material } from \"../material/Material\";\r\nimport Matrix4 from \"../math/Matrix4\";\r\nimport { ShaderSource } from \"../shader/ShaderSource\";\r\nimport { Command } from \"./Command\";\r\nimport Context from \"./Context\";\r\nimport IndexBuffer from \"./IndexBuffer\";\r\nimport Pipeline from \"./Pipeline\";\r\nimport { RenderState } from \"./RenderState\";\r\nimport RenderTarget from \"./RenderTarget\";\r\nimport ShaderData from \"./ShaderData\";\r\nimport VertextBuffer from \"./VertextBuffer\";\r\n\r\nclass DrawCommand implements Command {\r\n\tpublic type?: string;\r\n\r\n\tpublic shaderData?: ShaderData;\r\n\r\n\tpublic renderTarget?: RenderTarget;\r\n\r\n\tpublic vertexBuffer?: VertextBuffer;\r\n\r\n\tpublic indexBuffer?: IndexBuffer;\r\n\r\n\tpublic renderState?: RenderState;\r\n\r\n\tpublic queryIndex?: number;\r\n\r\n\tpublic count?: number;\r\n\r\n\tpublic instances?: number;\r\n\r\n\tpublic shaderSource?: ShaderSource;\r\n\r\n\tpublic dirty?: boolean;\r\n\r\n\tpublic light?: boolean;\r\n\r\n\tpublic indirectBuffer?: Buffer;\r\n\r\n\tpublic modelMatrix?: Matrix4;\r\n\r\n\tpublic lightShaderData?: ShaderData;\r\n\r\n\tconstructor(options: DrawCommandProps) {\r\n\t\tthis.type = options.type;\r\n\r\n\t\tthis.shaderData = options.shaderData;\r\n\r\n\t\tthis.renderTarget = options.renderTarget;\r\n\r\n\t\tthis.vertexBuffer = options.vertexBuffer;\r\n\r\n\t\tthis.indexBuffer = options.indexBuffer;\r\n\r\n\t\tthis.renderState = options.renderState;\r\n\r\n\t\tthis.queryIndex = options.queryIndex;\r\n\r\n\t\tthis.count = options.count;\r\n\r\n\t\tthis.instances = options.instances;\r\n\r\n\t\tthis.shaderSource = options.shaderSource;\r\n\r\n\t\tthis.dirty = options.dirty;\r\n\r\n\t\tthis.light = options.light;\r\n\r\n\t\tthis.modelMatrix = options.modelMatrix;\r\n\r\n\t\tthis.lightShaderData = options.lightShaderData;\r\n\t}\r\n\tpublic shallowClone(material?: Material) {\r\n\t\tif (material) {\r\n\t\t\treturn new DrawCommand({\r\n\t\t\t\tvertexBuffer: this.vertexBuffer,\r\n\t\t\t\tindexBuffer: this.indexBuffer,\r\n\t\t\t\tshaderData: material.shaderData,\r\n\t\t\t\tinstances: this.instances,\r\n\t\t\t\tcount: this.count,\r\n\t\t\t\trenderState: material.renderState,\r\n\t\t\t\tshaderSource: material.shaderSource,\r\n\t\t\t\ttype: \"render\",\r\n\t\t\t\tlight: material.light,\r\n\t\t\t\tmodelMatrix: this.modelMatrix,\r\n\t\t\t\tlightShaderData: material.light ? this.lightShaderData : undefined\r\n\t\t\t});\r\n\t\t}\r\n\t}\r\n\tpublic render(context?: Context, passEncoder?: GPURenderPassEncoder, camera?: Camera): void {\r\n\t\tconst {\r\n\t\t\tshaderData,\r\n\t\t\trenderState,\r\n\t\t\tvertexBuffer,\r\n\t\t\tindexBuffer,\r\n\t\t\tlightShaderData,\r\n\t\t\tshaderSource,\r\n\t\t\tcount,\r\n\t\t\tinstances,\r\n\t\t\trenderTarget\r\n\t\t} = this;\r\n\t\tconst currentPassEncoder = renderTarget?.beginRenderPassEncoder?.(context) ?? passEncoder;\r\n\t\tconst defines = Object.assign({}, lightShaderData?.defines ?? {}, camera?.shaderData?.defines ?? {});\r\n\t\tconst { device } = context;\r\n\r\n\t\tshaderData?.bind?.(context, currentPassEncoder);\r\n\r\n\t\tcamera?.shaderData?.bind(context, currentPassEncoder);\r\n\r\n\t\tlightShaderData?.bind?.(context, currentPassEncoder);\r\n\r\n\t\trenderState?.bind?.(currentPassEncoder, context);\r\n\r\n\t\tvertexBuffer?.bind?.(device, currentPassEncoder);\r\n\r\n\t\tindexBuffer?.bind?.(device, currentPassEncoder);\r\n\r\n\t\tshaderSource?.setDefines?.(defines);\r\n\r\n\t\tconst pipeline = Pipeline.getRenderPipelineFromCache(device, this, [\r\n\t\t\tshaderData?.groupLayout,\r\n\t\t\tlightShaderData?.groupLayout,\r\n\t\t\tcamera?.shaderData?.groupLayout\r\n\t\t]);\r\n\t\tpipeline.bind(currentPassEncoder);\r\n\t\tif (indexBuffer) {\r\n\t\t\tcurrentPassEncoder.drawIndexed(count || 0, instances || 1, 0, 0, 0);\r\n\t\t} else if (count) {\r\n\t\t\tcurrentPassEncoder.draw(count, instances || 1, 0, 0);\r\n\t\t}\r\n\t\trenderTarget?.endRenderPassEncoder?.();\r\n\t}\r\n}\r\ntype DrawCommandProps = {\r\n\ttype?: string;\r\n\r\n\tshaderData?: ShaderData;\r\n\r\n\trenderTarget?: RenderTarget;\r\n\r\n\tvertexBuffer?: VertextBuffer;\r\n\r\n\tindexBuffer?: IndexBuffer;\r\n\r\n\trenderState?: RenderState;\r\n\r\n\tqueryIndex?: number;\r\n\r\n\tcount?: number;\r\n\r\n\tinstances?: number;\r\n\r\n\tshaderSource?: ShaderSource;\r\n\r\n\tdirty?: boolean;\r\n\r\n\tlight?: boolean;\r\n\r\n\tmodelMatrix?: Matrix4;\r\n\r\n\tlightShaderData?: ShaderData;\r\n};\r\nexport default DrawCommand;\r\n","import BindGroupLayout from \"../render/BindGroupLayout\";\r\nimport BindGroupEntity from \"../render/BindGroupEntity\";\r\nimport Texture from \"../render/Texture\";\r\nimport {\r\n\tBlendFactor,\r\n\tBlendOperation,\r\n\tColorWriteFlags,\r\n\tCompareFunction,\r\n\tCullMode,\r\n\tFrontFace,\r\n\tIndexFormat,\r\n\tPrimitiveTopology,\r\n\tStencilOperation,\r\n\tTextureFormat\r\n} from \"./WebGPUConstant\";\r\nimport Sampler from \"../render/Sampler\";\r\nimport PostEffect from \"../post-process/PostEffect\";\r\nimport { Light } from \"../light/Light\";\r\nimport { Mesh } from \"../mesh/Mesh\";\r\nexport const GPUCanvasCompositingAlphaMode: {\r\n\t[key: string]: GPUCanvasCompositingAlphaMode;\r\n} = {\r\n\tOpaque: \"opaque\",\r\n\tPremultiplied: \"premultiplied\"\r\n};\r\nexport interface ContextState {\r\n\tdevice: GPUDevice;\r\n\tglslang: {\r\n\t\tcompileGLSL: (source: string, type: string) => string;\r\n\t};\r\n\tdebug: boolean;\r\n\terror: boolean;\r\n}\r\n\r\nexport interface ContextOptions {\r\n\tcanvas?: HTMLCanvasElement;\r\n\tcontainer?: HTMLDivElement;\r\n\tcontext?: GPUCanvasContext;\r\n\tpixelRatio?: number;\r\n}\r\n\r\nexport interface LightMangerOptions {\r\n\topenShadow: boolean;\r\n}\r\n\r\nexport interface BindGroupLayoutEntry extends GPUBindGroupLayoutEntry {\r\n\tname: string;\r\n\tuniforms?: any[];\r\n\tdimension?: GPUTextureDimension;\r\n}\r\n\r\nexport interface BindGroupOptions extends GPUBindGroupDescriptor {\r\n\tresources: GPUBindingResource[];\r\n}\r\n\r\nexport type ShaderStageName = \"vertex\" | \"fragment\" | \"compute\";\r\n\r\nexport type ShaderStageNameObjectKeys = {\r\n\t[key in ShaderStageName]?: string;\r\n};\r\nexport type ShaderStageBodyName = \"vertexBody\" | \"fragmentBody\" | \"computeBody\";\r\nexport type ShaderStageBodyNameObjectKeys = {\r\n\t[key in ShaderStageBodyName]?: string;\r\n};\r\nexport interface AttachmentOptions {\r\n\top?: GPUStoreOp;\r\n\ttexture?: Texture;\r\n\tresolveTarget?: Texture;\r\n\tstoreOp?: GPUStoreOp;\r\n}\r\n\r\nexport type PassType = \"render\" | \"compute\";\r\n\r\nexport type GPUBindingType =\r\n\t| GPUBufferBindingType\r\n\t| GPUSamplerBindingType\r\n\t| GPUTextureSampleType\r\n\t| GPUStorageTextureAccess;\r\n\r\nexport type BindGroupLayoutEntryType = {\r\n\tbinding: number;\r\n\tvisibility: GPUShaderStageFlags;\r\n\tuniforms?: any[];\r\n\tbuffer?: GPUBufferBindingLayout;\r\n\tsampler?: GPUSamplerBindingLayout;\r\n\ttexture?: GPUTextureBindingLayout;\r\n\tstorageTexture?: GPUStorageTextureBindingLayout;\r\n\texternalTexture?: GPUExternalTextureBindingLayout;\r\n};\r\nexport type BufferResourceType = {\r\n\tbuffer: GPUBufferBindingType;\r\n\toffset: number;\r\n\tsize: number;\r\n};\r\nexport type samplerBindEntityResourceType = {\r\n\tresource: GPUSampler;\r\n};\r\nexport type textureBindEntityResourceType = {\r\n\tresource: GPUTextureView;\r\n};\r\nexport type BindGroupEntityResourceType =\r\n\t| BufferResourceType\r\n\t| samplerBindEntityResourceType\r\n\t| textureBindEntityResourceType;\r\nexport type BindGroupEntityOptions = {\r\n\tbinding: number;\r\n\tresource: GPUBindingResource;\r\n};\r\nexport type BindGroupCacheOptions = {\r\n\tdevice: GPUDevice;\r\n\tlabel: string;\r\n\tlayout: BindGroupLayout;\r\n\tentires: BindGroupEntity[];\r\n\tindex?: number;\r\n\toffset?: number;\r\n\talignedSize?: number;\r\n\tmaxOffset?: number;\r\n\tdynamic?: boolean;\r\n};\r\nexport type ImageData = {\r\n\tsource: ImageBitmap | HTMLCanvasElement | Texture;\r\n\twidth?: number;\r\n\theight?: number;\r\n\tdepth?: number;\r\n\tsourceX?: number;\r\n\tsourceY?: number;\r\n\tmipLevel?: number;\r\n\tx?: number;\r\n\ty?: number;\r\n\tz?: number;\r\n\taspect?: \"all\" | \"stencil-only\" | \"depth-only\";\r\n\tcolorSpace?: \"srgb\";\r\n\tpremultipliedAlpha?: boolean;\r\n};\r\nexport type WebGPUTextureProps = {\r\n\tsize: textureSize;\r\n\r\n\tfixedSize?: boolean;\r\n\r\n\tformat: string;\r\n\r\n\tlabel?: string;\r\n\r\n\tusage?: number;\r\n\r\n\tsampler?: Sampler;\r\n\r\n\tdata?: ImageData | Array<ImageData>;\r\n\r\n\tmipLevelCount?: number;\r\n\r\n\tsampleCount?: number;\r\n\r\n\tdimension?: dimension;\r\n\r\n\tviewFormats?: string;\r\n\r\n\tsampleType?: string;\r\n\r\n\tneedMipMap?: boolean;\r\n\r\n\tdataIsTexture?: boolean;\r\n};\r\nexport type textureSize = {\r\n\twidth: number;\r\n\theight: number;\r\n\tdepth: number;\r\n};\r\nexport type dimension = \"1d\" | \"2d\" | \"3d\";\r\nexport type bufferLayoutType = {\r\n\ttype: string; //\"uniform\"\r\n\thasDynamicOffset?: Boolean;\r\n\tminBindingSize?: number;\r\n};\r\n//renderstate\r\nexport type DepthStencil = {\r\n\tformat: TextureFormat;\r\n\tdepthWriteEnabled: boolean;\r\n\tdepthCompare: CompareFunction;\r\n\tstencilReadMask?: number;\r\n\tstencilWriteMask?: number;\r\n\tstencilFront?: {\r\n\t\tcompare: CompareFunction;\r\n\t\tfailOp: StencilOperation;\r\n\t\tdepthFailOp: StencilOperation;\r\n\t\tpassOp: StencilOperation;\r\n\t};\r\n\tstencilBack?: {\r\n\t\tcompare: CompareFunction;\r\n\t\tfailOp: StencilOperation;\r\n\t\tdepthFailOp: StencilOperation;\r\n\t\tpassOp: StencilOperation;\r\n\t};\r\n\tdepthBias?: number;\r\n\tdepthBiasSlopeScale?: number;\r\n\tdepthBiasClamp?: number;\r\n};\r\nexport type PrimitiveState = {\r\n\tfrontFace?: FrontFace;\r\n\tcullMode?: CullMode;\r\n\tunclippedDepth?: boolean;\r\n\ttopology?: PrimitiveTopology;\r\n\tstripIndexFormat?: IndexFormat;\r\n};\r\nexport type MultiSample = {\r\n\tcount?: number;\r\n\tmask?: number;\r\n\talphaToCoverageEnabled?: boolean;\r\n};\r\nexport type Target = {\r\n\tformat: TextureFormat;\r\n\tblend?: {\r\n\t\tcolor: {\r\n\t\t\toperation: BlendOperation;\r\n\t\t\tsrcFactor: BlendFactor;\r\n\t\t\tdstFactor: BlendFactor;\r\n\t\t};\r\n\t\talpha: {\r\n\t\t\toperation: BlendOperation;\r\n\t\t\tsrcFactor: BlendFactor;\r\n\t\t\tdstFactor: BlendFactor;\r\n\t\t};\r\n\t};\r\n\twriteMask: ColorWriteFlags;\r\n};\r\nexport type BlendConstant = {\r\n\tr: number;\r\n\tg: number;\r\n\tb: number;\r\n\ta: number;\r\n};\r\nexport type RenderStateProps = {\r\n\tdepthStencil?: DepthStencil;\r\n\tprimitive?: PrimitiveState;\r\n\tmultisample?: MultiSample;\r\n\tstencilReference?: number;\r\n\ttargets?: Array<Target>;\r\n\tviewport?: { x: number; y: number; width: number; height: number };\r\n\tblendConstant?: BlendConstant;\r\n\tscissorTestEnabled?: boolean;\r\n\tstencilEnabled?: boolean;\r\n};\r\nexport type ViewPort = {\r\n\tx: number;\r\n\ty: number;\r\n\twidth: number;\r\n\theight: number;\r\n};\r\nexport type ScissorTest = {\r\n\tx: number;\r\n\ty: number;\r\n\twidth: number;\r\n\theight: number;\r\n};\r\nexport type ShaderMaterialParms = {\r\n\ttype: string;\r\n\tfrag: string | Function;\r\n\tvert: string | Function;\r\n\tuniforms: { [uniform: string]: IUniform };\r\n\tdefines?: any;\r\n\tlight?: boolean;\r\n};\r\nexport interface IUniform<TValue = any> {\r\n\ttype: string;\r\n\tvalue: TValue;\r\n}\r\nexport type Uniforms = { [uniform: string]: IUniform };\r\nexport type Instance = Mesh | PostEffect | Light;\r\n\r\nexport enum RenderObjectType {\r\n\tCamera = \"camera\",\r\n\tLight = \"light\",\r\n\tMesh = \"mesh\",\r\n\tSkinMesh = \"skinMesh\",\r\n\tNode = \"node\",\r\n\tAxes = \"axes\",\r\n\tSkybox = \"skyBox\",\r\n\tPostEffect = \"postEffect\",\r\n\tDebug = \"debug\"\r\n}\r\nexport enum LightType {\r\n\tSpotLight = \"spotLight\",\r\n\tPointLight = \"pointLight\",\r\n\tAmbientLight = \"ambientLight\",\r\n\tDirectionalLight = \"directionalLight\"\r\n}\r\n","import Texture from \"../render/Texture\";\r\n\r\nexport class MipmapGenerator {\r\n\tdevice: GPUDevice;\r\n\tsampler: GPUSampler;\r\n\tpipelines: object;\r\n\tmipmapShaderModule: GPUShaderModule;\r\n\tconstructor(device) {\r\n\t\tthis.device = device;\r\n\t\tthis.sampler = device.createSampler({ minFilter: \"linear\" });\r\n\t\t// We'll need a new pipeline for every texture format used.\r\n\t\tthis.pipelines = {};\r\n\t}\r\n\tprivate getMipmapPipeline(format) {\r\n\t\tlet pipeline = this.pipelines[format];\r\n\t\tif (!pipeline) {\r\n\t\t\t// Shader modules is shared between all pipelines, so only create once.\r\n\t\t\tif (!this.mipmapShaderModule) {\r\n\t\t\t\tthis.mipmapShaderModule = this.device.createShaderModule({\r\n\t\t\t\t\tcode: `\r\n              var<private> pos : array<vec2<f32>, 3> = array<vec2<f32>, 3>(\r\n                vec2<f32>(-1.0, -1.0), vec2<f32>(-1.0, 3.0), vec2<f32>(3.0, -1.0));\r\n              struct VertexOutput {\r\n                @builtin(position) position : vec4<f32>,\r\n                @location(0) texCoord : vec2<f32>,\r\n              };\r\n              @vertex\r\n              fn vertexMain(@builtin(vertex_index) vertexIndex : u32) -> VertexOutput {\r\n                var output : VertexOutput;\r\n                output.texCoord = pos[vertexIndex] * vec2<f32>(0.5, -0.5) + vec2<f32>(0.5);\r\n                output.position = vec4<f32>(pos[vertexIndex], 0.0, 1.0);\r\n                return output;\r\n              }\r\n              @group(0) @binding(0) var imgSampler : sampler;\r\n              @group(0) @binding(1) var img : texture_2d<f32>;\r\n              @fragment\r\n              fn fragmentMain(@location(0) texCoord : vec2<f32>) -> @location(0) vec4<f32> {\r\n                return textureSample(img, imgSampler, texCoord);\r\n              }\r\n            `\r\n\t\t\t\t});\r\n\t\t\t}\r\n\r\n\t\t\tpipeline = this.device.createRenderPipeline({\r\n\t\t\t\tlayout: \"auto\",\r\n\t\t\t\tvertex: {\r\n\t\t\t\t\tmodule: this.mipmapShaderModule,\r\n\t\t\t\t\tentryPoint: \"vertexMain\"\r\n\t\t\t\t},\r\n\t\t\t\tfragment: {\r\n\t\t\t\t\tmodule: this.mipmapShaderModule,\r\n\t\t\t\t\tentryPoint: \"fragmentMain\",\r\n\t\t\t\t\ttargets: [{ format }]\r\n\t\t\t\t}\r\n\t\t\t});\r\n\t\t\tthis.pipelines[format] = pipeline;\r\n\t\t}\r\n\t\treturn pipeline;\r\n\t}\r\n\r\n\t/**\r\n\t * Generates mipmaps for the given GPUTexture from the data in level 0.\r\n\t *\r\n\t * @param {module:External.GPUTexture} texture - Texture to generate mipmaps for.\r\n\t * @param {object} textureDescriptor - GPUTextureDescriptor the texture was created with.\r\n\t * @returns {module:External.GPUTexture} - The originally passed texture\r\n\t */\r\n\tgenerateMipmap(sourceTexture: Texture) {\r\n\t\tconst texture = sourceTexture.gpuTexture;\r\n\t\tconst textureDescriptor = sourceTexture.textureProp;\r\n\t\t// TODO: Does this need to handle sRGB formats differently?\r\n\t\tconst pipeline = this.getMipmapPipeline(textureDescriptor.format);\r\n\r\n\t\tif (textureDescriptor.dimension == \"3d\" || textureDescriptor.dimension == \"1d\") {\r\n\t\t\tthrow new Error(\"Generating mipmaps for non-2d textures is currently unsupported!\");\r\n\t\t}\r\n\r\n\t\tlet mipTexture = texture;\r\n\t\tconst arrayLayerCount = textureDescriptor.size.depth || 1; // Only valid for 2D textures.\r\n\r\n\t\t// If the texture was created with RENDER_ATTACHMENT usage we can render directly between mip levels.\r\n\t\tconst renderToSource = textureDescriptor.usage & GPUTextureUsage.RENDER_ATTACHMENT;\r\n\t\tif (!renderToSource) {\r\n\t\t\t// Otherwise we have to use a separate texture to render into. It can be one mip level smaller than the source\r\n\t\t\t// texture, since we already have the top level.\r\n\t\t\tconst mipTextureDescriptor = {\r\n\t\t\t\tsize: {\r\n\t\t\t\t\twidth: Math.ceil(textureDescriptor.size.width / 2),\r\n\t\t\t\t\theight: Math.ceil(textureDescriptor.size.height / 2),\r\n\t\t\t\t\tdepthOrArrayLayers: arrayLayerCount\r\n\t\t\t\t},\r\n\t\t\t\tformat: <GPUTextureFormat>textureDescriptor.format,\r\n\t\t\t\tusage: GPUTextureUsage.TEXTURE_BINDING | GPUTextureUsage.COPY_SRC | GPUTextureUsage.RENDER_ATTACHMENT,\r\n\t\t\t\tmipLevelCount: textureDescriptor.mipLevelCount - 1\r\n\t\t\t};\r\n\t\t\tmipTexture = this.device.createTexture(mipTextureDescriptor);\r\n\t\t}\r\n\r\n\t\tconst commandEncoder = this.device.createCommandEncoder({});\r\n\t\t// TODO: Consider making this static.\r\n\t\tconst bindGroupLayout = pipeline.getBindGroupLayout(0);\r\n\r\n\t\tfor (let arrayLayer = 0; arrayLayer < arrayLayerCount; ++arrayLayer) {\r\n\t\t\tlet srcView = texture.createView({\r\n\t\t\t\tbaseMipLevel: 0,\r\n\t\t\t\tmipLevelCount: 1,\r\n\t\t\t\tdimension: \"2d\",\r\n\t\t\t\tbaseArrayLayer: arrayLayer,\r\n\t\t\t\tarrayLayerCount: 1\r\n\t\t\t});\r\n\r\n\t\t\tlet dstMipLevel = renderToSource ? 1 : 0;\r\n\t\t\tfor (let i = 1; i < textureDescriptor.mipLevelCount; ++i) {\r\n\t\t\t\tconst dstView = mipTexture.createView({\r\n\t\t\t\t\tbaseMipLevel: dstMipLevel++,\r\n\t\t\t\t\tmipLevelCount: 1,\r\n\t\t\t\t\tdimension: \"2d\",\r\n\t\t\t\t\tbaseArrayLayer: arrayLayer,\r\n\t\t\t\t\tarrayLayerCount: 1\r\n\t\t\t\t});\r\n\r\n\t\t\t\tconst passEncoder = commandEncoder.beginRenderPass({\r\n\t\t\t\t\tcolorAttachments: [\r\n\t\t\t\t\t\t{\r\n\t\t\t\t\t\t\tview: dstView,\r\n\t\t\t\t\t\t\tloadOp: \"clear\",\r\n\t\t\t\t\t\t\tstoreOp: \"store\"\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t]\r\n\t\t\t\t});\r\n\r\n\t\t\t\tconst bindGroup = this.device.createBindGroup({\r\n\t\t\t\t\tlayout: bindGroupLayout,\r\n\t\t\t\t\tentries: [\r\n\t\t\t\t\t\t{\r\n\t\t\t\t\t\t\tbinding: 0,\r\n\t\t\t\t\t\t\tresource: this.sampler\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t\t{\r\n\t\t\t\t\t\t\tbinding: 1,\r\n\t\t\t\t\t\t\tresource: srcView\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t]\r\n\t\t\t\t});\r\n\r\n\t\t\t\tpassEncoder.setPipeline(pipeline);\r\n\t\t\t\tpassEncoder.setBindGroup(0, bindGroup);\r\n\t\t\t\tpassEncoder.draw(3, 1, 0, 0);\r\n\t\t\t\tpassEncoder.end();\r\n\r\n\t\t\t\tsrcView = dstView;\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\t// If we didn't render to the source texture, finish by copying the mip results from the temporary mipmap texture\r\n\t\t// to the source.\r\n\t\tif (!renderToSource) {\r\n\t\t\tconst mipLevelSize = {\r\n\t\t\t\twidth: Math.ceil(textureDescriptor.size.width / 2),\r\n\t\t\t\theight: Math.ceil(textureDescriptor.size.height / 2),\r\n\t\t\t\tdepthOrArrayLayers: arrayLayerCount\r\n\t\t\t};\r\n\r\n\t\t\tfor (let i = 1; i < textureDescriptor.mipLevelCount; ++i) {\r\n\t\t\t\tcommandEncoder.copyTextureToTexture(\r\n\t\t\t\t\t{\r\n\t\t\t\t\t\ttexture: mipTexture,\r\n\t\t\t\t\t\tmipLevel: i - 1\r\n\t\t\t\t\t},\r\n\t\t\t\t\t{\r\n\t\t\t\t\t\ttexture: texture,\r\n\t\t\t\t\t\tmipLevel: i\r\n\t\t\t\t\t},\r\n\t\t\t\t\tmipLevelSize\r\n\t\t\t\t);\r\n\r\n\t\t\t\tmipLevelSize.width = Math.ceil(mipLevelSize.width / 2);\r\n\t\t\t\tmipLevelSize.height = Math.ceil(mipLevelSize.height / 2);\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\tthis.device.queue.submit([commandEncoder.finish()]);\r\n\r\n\t\tif (!renderToSource) {\r\n\t\t\tmipTexture.destroy();\r\n\t\t}\r\n\r\n\t\treturn texture;\r\n\t}\r\n}\r\n","function defaultValue(a, b) {\n\tif (a !== undefined && a !== null) {\n\t\treturn a;\n\t}\n\treturn b;\n}\n\n/**\n * A frozen empty object that can be used as the default value for options passed as\n * an object literal.\n * @type {Object}\n * @memberof defaultValue\n */\ndefaultValue.EMPTY_OBJECT = Object.freeze({});\n\nexport default defaultValue;\n","import {\r\n\tBlendFactor,\r\n\tBlendOperation,\r\n\tTextureFormat,\r\n\tGPUColorWrite,\r\n\tCompareFunction,\r\n\tStencilOperation,\r\n\tFrontFace,\r\n\tCullMode,\r\n\tPrimitiveTopology\r\n} from \"../core/WebGPUConstant\";\r\nimport defaultValue from \"../utils/defaultValue\";\r\nimport Context from \"./Context\";\r\n\r\nexport class RenderState {\r\n\tscissorTest: ScissorTest;\r\n\tviewport: ViewPort;\r\n\ttargets: Array<Target>;\r\n\tdepthStencil: DepthStencil;\r\n\tblendConstant: BlendConstant;\r\n\tstencilReference: number;\r\n\tmultisample: MultiSample;\r\n\tprimitive: Primitive;\r\n\tstencilEnabled: boolean;\r\n\tscissorTestEnabled: boolean;\r\n\tconstructor() {\r\n\t\tthis.scissorTest = undefined;\r\n\t\tthis.viewport = undefined;\r\n\t\tthis.depthStencil = undefined;\r\n\t\tthis.blendConstant = undefined;\r\n\t\tthis.stencilReference = 0;\r\n\t\tthis.multisample = undefined;\r\n\t\tthis.primitive = undefined;\r\n\t\tthis.stencilEnabled = false;\r\n\t\tthis.scissorTestEnabled = false;\r\n\t\tthis.targets = undefined;\r\n\t}\r\n\tbind(passEncoder: GPURenderPassEncoder, context: Context) {\r\n\t\tconst { viewPort, scissorTest } = context;\r\n\t\tconst finalViewport = this.viewport ?? viewPort;\r\n\t\tconst finalScissorTest = this.scissorTest ?? scissorTest;\r\n\t\tif (this.stencilReference) passEncoder.setStencilReference(this.stencilReference);\r\n\t\tif (finalViewport.equalsAndUpdateCache(cacheViewPort)) {\r\n\t\t\tconst { x, y, width, height, minDepth, maxDepth } = finalViewport;\r\n\t\t\tpassEncoder.setViewport(x, y, width, height, minDepth, maxDepth);\r\n\t\t}\r\n\t\tif (this.blendConstant) passEncoder.setBlendConstant(this.blendConstant);\r\n\t\tif (finalScissorTest.equalsAndUpdateCache(cacheScissorTest)) {\r\n\t\t\tconst { x, y, width, height } = finalScissorTest;\r\n\t\t\tpassEncoder.setScissorRect(x, y, width, height);\r\n\t\t}\r\n\t}\r\n\tdestroy() {\r\n\t\tthis.scissorTest = undefined;\r\n\t\tthis.viewport = undefined;\r\n\t\tthis.depthStencil = undefined;\r\n\t\tthis.blendConstant = undefined;\r\n\t\tthis.stencilReference = -1;\r\n\t\tthis.multisample = undefined;\r\n\t\tthis.primitive = undefined;\r\n\t\tthis.stencilEnabled = false;\r\n\t\tthis.scissorTestEnabled = false;\r\n\t}\r\n}\r\nexport class BlendConstant {\r\n\tr: number;\r\n\tg: number;\r\n\tb: number;\r\n\ta: number;\r\n\tconstructor(r: number, g: number, b: number, a: number) {\r\n\t\tthis.r = r;\r\n\t\tthis.g = g;\r\n\t\tthis.b = b;\r\n\t\tthis.a = a;\r\n\t}\r\n}\r\nexport class MultiSample {\r\n\tcount: number;\r\n\tmask: number;\r\n\talphaToCoverageEnabled: boolean;\r\n\tconstructor(count = 1, mask = 0xffffffff, alphaToCoverageEnabled = false) {\r\n\t\tthis.count = count;\r\n\t\tthis.mask = mask;\r\n\t\tthis.alphaToCoverageEnabled = alphaToCoverageEnabled;\r\n\t}\r\n\tgetMultiSampleDec() {\r\n\t\treturn {\r\n\t\t\tcount: this.count,\r\n\t\t\tmask: this.mask,\r\n\t\t\talphaToCoverageEnabled: this.alphaToCoverageEnabled\r\n\t\t};\r\n\t}\r\n}\r\nexport class ScissorTest {\r\n\tx: number;\r\n\ty: number;\r\n\twidth: number;\r\n\theight: number;\r\n\tvariable: boolean;\r\n\tconstructor(x = 0, y = 0, width = 0, height = 0, variable = true) {\r\n\t\tthis.x = x;\r\n\t\tthis.y = y;\r\n\t\tthis.width = width;\r\n\t\tthis.height = height;\r\n\t\tthis.variable = variable;\r\n\t}\r\n\tset(x: number, y: number, width: number, height: number) {\r\n\t\tthis.x = x;\r\n\t\tthis.y = y;\r\n\t\tthis.width = width;\r\n\t\tthis.height = height;\r\n\t}\r\n\tequalsAndUpdateCache(scissorTest: ScissorTest): boolean {\r\n\t\tconst { x, y, width, height } = scissorTest;\r\n\t\tif (this.x != x || this.y != y || this.width != width || this.height != height) {\r\n\t\t\tscissorTest.set(this.x, this.y, this.width, this.height);\r\n\t\t\treturn true;\r\n\t\t}\r\n\t\treturn false;\r\n\t}\r\n}\r\nexport class ViewPort {\r\n\tx: number;\r\n\ty: number;\r\n\twidth: number;\r\n\theight: number;\r\n\tminDepth: number;\r\n\tmaxDepth: number;\r\n\tvariable: boolean;\r\n\tconstructor(x = 0, y = 0, width = 0, height = 0, minDepth = 0, maxDepth = 1, variable = true) {\r\n\t\tthis.x = x;\r\n\t\tthis.y = y;\r\n\t\tthis.width = width;\r\n\t\tthis.height = height;\r\n\t\tthis.minDepth = minDepth;\r\n\t\tthis.maxDepth = maxDepth;\r\n\t\tthis.variable = variable;\r\n\t}\r\n\tset(x: number, y: number, width: number, height: number, minDepth = 0, maxDepth = 1) {\r\n\t\tif (!this.variable) return;\r\n\t\tthis.x = x;\r\n\t\tthis.y = y;\r\n\t\tthis.width = width;\r\n\t\tthis.height = height;\r\n\t\tthis.minDepth = minDepth;\r\n\t\tthis.maxDepth = maxDepth;\r\n\t}\r\n\tequalsAndUpdateCache(viewPort: ViewPort): boolean {\r\n\t\tconst { x, y, width, height, minDepth, maxDepth } = viewPort;\r\n\t\tif (\r\n\t\t\tthis.x != x ||\r\n\t\t\tthis.y != y ||\r\n\t\t\tthis.width != width ||\r\n\t\t\tthis.height != height ||\r\n\t\t\tthis.minDepth != minDepth ||\r\n\t\t\tthis.maxDepth != maxDepth\r\n\t\t) {\r\n\t\t\tviewPort.set(this.x, this.y, this.width, this.height, this.minDepth, this.maxDepth);\r\n\t\t\treturn true;\r\n\t\t}\r\n\t\treturn false;\r\n\t}\r\n}\r\nexport class Primitive {\r\n\tfrontFace: FrontFace;\r\n\tcullMode: CullMode;\r\n\tunclippedDepth: boolean;\r\n\ttopology: PrimitiveTopology;\r\n\tconstructor(topology?: PrimitiveTopology, cullMode?: CullMode, frontFace?: FrontFace, unclippedDepth?: boolean) {\r\n\t\tthis.frontFace = defaultValue(frontFace, FrontFace.CCW);\r\n\t\tthis.cullMode = defaultValue(cullMode, CullMode.None);\r\n\t\tthis.unclippedDepth = defaultValue(unclippedDepth, false);\r\n\t\tthis.topology = defaultValue(topology, PrimitiveTopology.TriangleList);\r\n\t}\r\n\tgetGPUPrimitiveDec() {\r\n\t\treturn {\r\n\t\t\tfrontFace: this.frontFace,\r\n\t\t\tcullMode: this.cullMode,\r\n\t\t\tunclippedDepth: this.unclippedDepth,\r\n\t\t\ttopology: this.topology\r\n\t\t};\r\n\t}\r\n}\r\nexport class DepthStencil {\r\n\tformat: TextureFormat;\r\n\tdepthWriteEnabled: boolean;\r\n\tdepthCompare: CompareFunction;\r\n\tstencilReadMask: number;\r\n\tstencilWriteMask: number;\r\n\tstencilFrontCompare: CompareFunction;\r\n\tstencilFrontFailOp: StencilOperation;\r\n\tstencilFrontDepthFailOp: StencilOperation;\r\n\tstencilFrontPassOp: StencilOperation;\r\n\r\n\tstencilBackCompare: CompareFunction;\r\n\tstencilBackFailOp: StencilOperation;\r\n\tstencilBackDepthFailOp: StencilOperation;\r\n\tstencilBackPassOp: StencilOperation;\r\n\tdepthBias: number;\r\n\tdepthBiasSlopeScale: number;\r\n\tdepthBiasClamp: number;\r\n\tconstructor(options?: DepthStencilProps) {\r\n\t\tthis.format = defaultValue(options?.format, TextureFormat.Depth24Plus);\r\n\t\tthis.depthWriteEnabled = defaultValue(options?.depthWriteEnabled, true);\r\n\t\tthis.depthCompare = defaultValue(options?.depthCompare, CompareFunction.Less);\r\n\t\tthis.stencilReadMask = defaultValue(options?.stencilReadMask, 0xffffffff);\r\n\t\tthis.stencilWriteMask = defaultValue(options?.stencilWriteMask, 0xffffffff);\r\n\t\tthis.stencilFrontCompare = defaultValue(options?.stencilFrontCompare, CompareFunction.Always);\r\n\t\tthis.stencilFrontFailOp = defaultValue(options?.stencilFrontFailOp, StencilOperation.Keep);\r\n\t\tthis.stencilFrontDepthFailOp = defaultValue(options?.stencilFrontDepthFailOp, StencilOperation.Keep);\r\n\t\tthis.stencilFrontPassOp = defaultValue(options?.stencilFrontPassOp, StencilOperation.Keep);\r\n\t\tthis.stencilBackCompare = defaultValue(options?.stencilBackCompare, CompareFunction.Always);\r\n\t\tthis.stencilBackFailOp = defaultValue(options?.stencilBackFailOp, StencilOperation.Keep);\r\n\t\tthis.stencilBackDepthFailOp = defaultValue(options?.stencilBackDepthFailOp, StencilOperation.Keep);\r\n\t\tthis.stencilBackPassOp = defaultValue(options?.stencilBackPassOp, StencilOperation.Keep);\r\n\t\tthis.depthBias = defaultValue(options?.depthBias, 0);\r\n\t\tthis.depthBiasSlopeScale = defaultValue(options?.depthBiasSlopeScale, 0);\r\n\t\tthis.depthBiasClamp = defaultValue(options?.depthBiasClamp, 0);\r\n\t}\r\n\tgetGPUDepthStencilDec() {\r\n\t\treturn {\r\n\t\t\tformat: this.format,\r\n\t\t\tdepthWriteEnabled: this.depthWriteEnabled,\r\n\t\t\tdepthCompare: this.depthCompare,\r\n\t\t\tstencilReadMask: this.stencilReadMask,\r\n\t\t\tstencilWriteMask: this.stencilWriteMask,\r\n\t\t\tstencilFront: {\r\n\t\t\t\tcompare: this.stencilFrontCompare,\r\n\t\t\t\tfailOp: this.stencilFrontFailOp,\r\n\t\t\t\tdepthFailOp: this.stencilFrontDepthFailOp,\r\n\t\t\t\tpassOp: this.stencilFrontPassOp\r\n\t\t\t},\r\n\t\t\tstencilBack: {\r\n\t\t\t\tcompare: this.stencilBackCompare,\r\n\t\t\t\tfailOp: this.stencilBackFailOp,\r\n\t\t\t\tdepthFailOp: this.stencilBackDepthFailOp,\r\n\t\t\t\tpassOp: this.stencilBackPassOp\r\n\t\t\t},\r\n\t\t\tdepthBias: this.depthBias,\r\n\t\t\tdepthBiasSlopeScale: this.depthBiasSlopeScale,\r\n\t\t\tdepthBiasClamp: this.depthBiasClamp\r\n\t\t};\r\n\t}\r\n}\r\nexport class Target {\r\n\tformat: TextureFormat;\r\n\tblendColorOperation?: BlendOperation;\r\n\tblendColorSrcFactor?: BlendFactor;\r\n\tblendColorDstFactor?: BlendFactor;\r\n\tblendAlphaOperation?: BlendOperation;\r\n\tblendAlphaSrcFactor?: BlendFactor;\r\n\tblendAlphaDstFactor?: BlendFactor;\r\n\twriteMask: GPUColorWrite;\r\n\tconstructor(options?: TargetProps) {\r\n\t\tthis.format = defaultValue(options?.format, TextureFormat.BGRA8Unorm);\r\n\t\tthis.blendColorOperation = defaultValue(options?.blendColorOperation, BlendOperation.Add);\r\n\t\tthis.blendColorSrcFactor = defaultValue(options?.blendColorSrcFactor, BlendFactor?.SrcAlpha);\r\n\t\tthis.blendColorDstFactor = defaultValue(options?.blendColorDstFactor, BlendFactor.OneMinusSrcAlpha);\r\n\t\tthis.blendAlphaOperation = defaultValue(options?.blendAlphaOperation, BlendOperation.Add);\r\n\t\tthis.blendAlphaSrcFactor = defaultValue(options?.blendAlphaSrcFactor, BlendFactor.One);\r\n\t\tthis.blendAlphaDstFactor = defaultValue(options?.blendAlphaDstFactor, BlendFactor.One);\r\n\t\tthis.writeMask = defaultValue(options?.writeMask, GPUColorWrite.All);\r\n\t}\r\n\tgetGPUTargetDec() {\r\n\t\treturn {\r\n\t\t\tformat: this.format,\r\n\t\t\tblend: {\r\n\t\t\t\tcolor: {\r\n\t\t\t\t\toperation: this.blendColorOperation,\r\n\t\t\t\t\tsrcFactor: this.blendColorSrcFactor,\r\n\t\t\t\t\tdstFactor: this.blendColorDstFactor\r\n\t\t\t\t},\r\n\t\t\t\talpha: {\r\n\t\t\t\t\toperation: this.blendAlphaOperation,\r\n\t\t\t\t\tsrcFactor: this.blendAlphaSrcFactor,\r\n\t\t\t\t\tdstFactor: this.blendAlphaDstFactor\r\n\t\t\t\t}\r\n\t\t\t},\r\n\t\t\twriteMask: this.writeMask\r\n\t\t};\r\n\t}\r\n}\r\nconst cacheViewPort = new ViewPort();\r\nconst cacheScissorTest = new ScissorTest();\r\ntype DepthStencilProps = {\r\n\tformat?: TextureFormat;\r\n\tdepthWriteEnabled?: boolean;\r\n\tdepthCompare?: CompareFunction;\r\n\tstencilReadMask?: number;\r\n\tstencilWriteMask?: number;\r\n\tstencilFrontCompare?: CompareFunction;\r\n\tstencilFrontFailOp?: StencilOperation;\r\n\tstencilFrontDepthFailOp?: StencilOperation;\r\n\tstencilFrontPassOp?: StencilOperation;\r\n\r\n\tstencilBackCompare?: CompareFunction;\r\n\tstencilBackFailOp?: StencilOperation;\r\n\tstencilBackDepthFailOp?: StencilOperation;\r\n\tstencilBackPassOp?: StencilOperation;\r\n\tdepthBias?: number;\r\n\tdepthBiasSlopeScale?: number;\r\n\tdepthBiasClamp?: number;\r\n};\r\ntype TargetProps = {\r\n\tformat?: TextureFormat;\r\n\tblendColorOperation?: BlendOperation;\r\n\tblendColorSrcFactor?: BlendFactor;\r\n\tblendColorDstFactor?: BlendFactor;\r\n\tblendAlphaOperation?: BlendOperation;\r\n\tblendAlphaSrcFactor?: BlendFactor;\r\n\tblendAlphaDstFactor?: BlendFactor;\r\n\twriteMask?: GPUColorWrite;\r\n};\r\n","import { TextureUsage } from \"../core/WebGPUConstant\";\nimport { GPUCanvasCompositingAlphaMode, ContextOptions } from \"../core/WebGPUTypes\";\nimport { MipmapGenerator } from \"../utils/MipmapGenerator\";\nimport { ScissorTest, ViewPort } from \"./RenderState\";\n\nclass Context {\n\tpublic canvas: HTMLCanvasElement;\n\n\tpublic context: GPUCanvasContext;\n\n\tpublic pixelRatio: number;\n\n\tpublic device: GPUDevice;\n\n\tprivate adapter: GPUAdapter;\n\n\tpublic presentationSize: { width: number; height: number; depth: number };\n\n\tpublic presentationFormat: GPUTextureFormat;\n\n\tpublic mipmapTools: MipmapGenerator;\n\n\tprivate _viewPort: ViewPort;\n\n\tprivate _scissorTest: ScissorTest;\n\n\tpublic get viewPort(): ViewPort {\n\t\treturn this._viewPort;\n\t}\n\n\tpublic get scissorTest(): ScissorTest {\n\t\treturn this._scissorTest;\n\t}\n\tconstructor({ canvas, container, context, pixelRatio }: ContextOptions = {}) {\n\t\tif (!container.clientWidth || !container.clientHeight) throw new Error(\"container width or height illegality\");\n\t\tthis.canvas = canvas || document.createElement(\"canvas\");\n\t\t// this.canvas.style.display = \"block\";\n\t\tthis.pixelRatio = pixelRatio || window.devicePixelRatio || 1;\n\t\tconst width = container.clientWidth * this.pixelRatio;\n\t\tconst height = container.clientHeight * this.pixelRatio;\n\t\tthis.canvas.width = width;\n\t\tthis.canvas.height = height;\n\t\tthis.canvas.style.width = container.clientWidth + \"px\";\n\t\tthis.canvas.style.height = container.clientHeight + \"px\";\n\t\tcontainer.appendChild(this.canvas);\n\t\tthis.context = context || (this.canvas.getContext(\"webgpu\") as GPUCanvasContext);\n\n\t\tthis.device = undefined;\n\t}\n\n\tpublic async init(\n\t\trequestAdapter = {},\n\t\tdeviceDescriptor = {},\n\t\tpresentationContextDescriptor = {}\n\t): Promise<boolean> {\n\t\ttry {\n\t\t\tif (!this.context) {\n\t\t\t\tthrow new Error(`Failed to instantiate \"webgpu\" context.`);\n\t\t\t}\n\t\t\tif (!navigator.gpu) {\n\t\t\t\tthrow new Error(`Missing \"navigator.gpu\".`);\n\t\t\t}\n\n\t\t\tthis.adapter = await navigator.gpu.requestAdapter();\n\t\t\tthis.device = await this.adapter.requestDevice();\n\t\t\tthis.presentationSize = {\n\t\t\t\twidth: this.canvas.clientWidth * this.pixelRatio,\n\t\t\t\theight: this.canvas.clientHeight * this.pixelRatio,\n\t\t\t\tdepth: 1\n\t\t\t};\n\t\t\tthis.presentationFormat = navigator.gpu.getPreferredCanvasFormat();\n\t\t\tthis.device.addEventListener(\"uncapturederror\", (error) => {\n\t\t\t\tconsole.error(error);\n\t\t\t\t// State.error = true;\n\t\t\t});\n\t\t\tthis.mipmapTools = new MipmapGenerator(this.device);\n\t\t\tthis.context.configure({\n\t\t\t\tdevice: this.device,\n\t\t\t\tformat: this.presentationFormat,\n\t\t\t\tusage: TextureUsage.RenderAttachment,\n\t\t\t\talphaMode: \"premultiplied\",\n\t\t\t\t...presentationContextDescriptor\n\t\t\t});\n\t\t\tthis._viewPort = new ViewPort(\n\t\t\t\t0,\n\t\t\t\t0,\n\t\t\t\tthis.canvas.clientWidth * this.pixelRatio,\n\t\t\t\tthis.canvas.clientHeight * this.pixelRatio\n\t\t\t);\n\t\t\tthis._scissorTest = new ScissorTest(\n\t\t\t\t0,\n\t\t\t\t0,\n\t\t\t\tthis.canvas.clientWidth * this.pixelRatio,\n\t\t\t\tthis.canvas.clientHeight * this.pixelRatio\n\t\t\t);\n\t\t} catch (error) {\n\t\t\tconsole.error(error);\n\t\t\treturn false;\n\t\t}\n\n\t\treturn true;\n\t}\n\tpublic setViewPort(x: number, y: number, width: number, height: number) {\n\t\tthis._viewPort.set(x, y, width, height);\n\t}\n\n\tpublic resetViewPortToFullCanvas() {\n\t\tthis._viewPort.set(0, 0, this.canvas.clientWidth * this.pixelRatio, this.canvas.clientHeight * this.pixelRatio);\n\t}\n\n\tpublic setScissorTest(x: number, y: number, width: number, height: number) {\n\t\tthis._scissorTest.set(x, y, width, height);\n\t}\n\tpublic resize(width: number, height: number, presentationContextDescriptor = {}): void {\n\t\tconst w = width * this.pixelRatio;\n\t\tconst h = height * this.pixelRatio;\n\t\tthis.canvas.style.width = w + \"px\";\n\t\tthis.canvas.style.height = h + \"px\";\n\t\tthis.canvas.width = w;\n\t\tthis.canvas.height = h;\n\t\tthis.presentationSize = {\n\t\t\twidth: w,\n\t\t\theight: h,\n\t\t\tdepth: 1\n\t\t};\n\t\tthis.context.configure({\n\t\t\tdevice: this.device,\n\t\t\tformat: navigator.gpu.getPreferredCanvasFormat(),\n\t\t\tusage: TextureUsage.RenderAttachment,\n\t\t\talphaMode: GPUCanvasCompositingAlphaMode.Premultiplied,\n\t\t\t...presentationContextDescriptor\n\t\t});\n\t}\n}\n\nexport default Context;\n","import { TextureFormat } from \"../core/WebGPUConstant\";\r\nimport { WebGPUTextureProps, ImageData } from \"../core/WebGPUTypes\";\r\nimport defaultValue from \"../utils/defaultValue\";\r\nimport Context from \"./Context\";\r\nimport Sampler from \"./Sampler\";\r\n\r\nexport default class Texture {\r\n\t[x: string]: any;\r\n\tprivate _textureView: GPUTextureView;\r\n\tpublic gpuTexture?: GPUTexture;\r\n\tpublic mipLevelCount?: number;\r\n\tpublic sampler?: Sampler;\r\n\tpublic context?: Context;\r\n\tpublic textureProp?: WebGPUTextureProps;\r\n\tpublic dirty: boolean;\r\n\tpublic fixedSize: boolean;\r\n\tconstructor(textureProp: WebGPUTextureProps) {\r\n\t\tthis.textureProp = Object.assign(\r\n\t\t\t{\r\n\t\t\t\tformat: TextureFormat.RGBA8Unorm,\r\n\t\t\t\tusage: GPUTextureUsage.TEXTURE_BINDING | GPUTextureUsage.COPY_DST | GPUTextureUsage.RENDER_ATTACHMENT,\r\n\t\t\t\tdataIsTexture: false\r\n\t\t\t},\r\n\t\t\ttextureProp\r\n\t\t);\r\n\t\tthis.sampler = textureProp.sampler;\r\n\t\tthis.dirty = true;\r\n\t\tthis.fixedSize = textureProp.fixedSize || false;\r\n\t}\r\n\tget layoutType() {\r\n\t\tconst { viewFormats, sampleType, sampleCount } = this.textureProp;\r\n\t\t// const\r\n\t\treturn {\r\n\t\t\tsampleType: defaultValue(sampleType, \"float\"),\r\n\t\t\tviewDimension: defaultValue(viewFormats, \"2d\"),\r\n\t\t\tmultisampled: sampleCount && sampleCount > 1 ? true : false\r\n\t\t};\r\n\t}\r\n\tget textureView() {\r\n\t\tif (!this._textureView)\r\n\t\t\tthis._textureView = this.gpuTexture.createView({\r\n\t\t\t\tdimension: <GPUTextureViewDimension>defaultValue(this.textureProp.viewFormats, \"2d\")\r\n\t\t\t});\r\n\t\treturn this._textureView;\r\n\t}\r\n\tupdate(context: Context) {\r\n\t\tif (!this.context) this.context = context;\r\n\t\tif (this.dirty) {\r\n\t\t\tthis.checkNeedCreateTexture();\r\n\t\t\tthis.dirty = false;\r\n\t\t\tif (this.textureProp.data) {\r\n\t\t\t\tif (Array.isArray(this.textureProp.data)) {\r\n\t\t\t\t\tthis.textureProp.data.forEach((imageData) => {\r\n\t\t\t\t\t\tthis.setData(imageData);\r\n\t\t\t\t\t});\r\n\t\t\t\t} else {\r\n\t\t\t\t\tthis.setData(this.textureProp.data);\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t\tif (this.textureProp.needMipMap) {\r\n\t\t\t\tthis.gpuTexture = context.mipmapTools.generateMipmap(this);\r\n\t\t\t}\r\n\t\t\tif (this.sampler) this.sampler.update(context);\r\n\t\t}\r\n\t}\r\n\tprivate setData(options: ImageData) {\r\n\t\tconst {\r\n\t\t\tsource,\r\n\t\t\twidth = options.source.width,\r\n\t\t\theight = options.source.height,\r\n\t\t\tdepth = 1,\r\n\t\t\tsourceX = 0,\r\n\t\t\tsourceY = 0,\r\n\t\t\tmipLevel = 0,\r\n\t\t\tx = 0,\r\n\t\t\ty = 0,\r\n\t\t\tz = 0,\r\n\t\t\taspect = \"all\",\r\n\t\t\tcolorSpace = \"srgb\",\r\n\t\t\tpremultipliedAlpha = false\r\n\t\t} = options;\r\n\t\tif (source instanceof Texture) {\r\n\t\t\tlet commandEncoder = this.context.device.createCommandEncoder();\r\n\t\t\tcommandEncoder.copyTextureToTexture(\r\n\t\t\t\t{\r\n\t\t\t\t\ttexture: <GPUTexture>source.gpuTexture,\r\n\t\t\t\t\torigin: [sourceX, sourceY]\r\n\t\t\t\t\t// aspect\r\n\t\t\t\t},\r\n\t\t\t\t{\r\n\t\t\t\t\ttexture: this.gpuTexture,\r\n\t\t\t\t\torigin: { x: 0, y: 0, z },\r\n\t\t\t\t\tmipLevel\r\n\t\t\t\t\t// aspect\r\n\t\t\t\t},\r\n\t\t\t\t{\r\n\t\t\t\t\twidth,\r\n\t\t\t\t\theight,\r\n\t\t\t\t\tdepthOrArrayLayers: 1\r\n\t\t\t\t}\r\n\t\t\t);\r\n\t\t\tthis.context.device.queue.submit([commandEncoder.finish()]);\r\n\t\t\tcommandEncoder = null;\r\n\t\t} else {\r\n\t\t\tthis.context.device.queue.copyExternalImageToTexture(\r\n\t\t\t\t{\r\n\t\t\t\t\tsource,\r\n\t\t\t\t\torigin: [sourceX, sourceY]\r\n\t\t\t\t},\r\n\t\t\t\t{\r\n\t\t\t\t\ttexture: this.gpuTexture,\r\n\t\t\t\t\torigin: [x, y, z],\r\n\t\t\t\t\tmipLevel,\r\n\t\t\t\t\taspect,\r\n\t\t\t\t\tcolorSpace,\r\n\t\t\t\t\tpremultipliedAlpha\r\n\t\t\t\t},\r\n\t\t\t\t[width, height, depth]\r\n\t\t\t);\r\n\t\t}\r\n\t}\r\n\tsetSize(width: number, height: number, depth?: number) {\r\n\t\tif (this.fixedSize) return;\r\n\t\tthis.textureProp.size.width = width;\r\n\t\tthis.textureProp.size.height = height;\r\n\t\tif (depth) this.textureProp.size.depth = depth;\r\n\t\tthis.dirty = true;\r\n\t}\r\n\tdestroy(): void {\r\n\t\tthis.gpuTexture.destroy();\r\n\t}\r\n\tprivate createGPUTexture() {\r\n\t\tif (typeof this.textureProp.format === \"number\") {\r\n\t\t\tthrow new Error(\"number format\");\r\n\t\t}\r\n\t\tconst { width, height, depth } = this.textureProp.size;\r\n\t\treturn this.context.device.createTexture({\r\n\t\t\tlabel: this.textureProp?.label || \"undefined\",\r\n\t\t\tsize: [width, height, depth],\r\n\t\t\tdimension: this.textureProp.dimension || \"2d\",\r\n\t\t\tformat: this.textureProp.format as GPUTextureFormat,\r\n\t\t\tusage: this.textureProp.usage,\r\n\t\t\tmipLevelCount: this.textureProp.mipLevelCount || 1,\r\n\t\t\tsampleCount: this.textureProp.sampleCount || 1\r\n\t\t});\r\n\t}\r\n\tprivate checkNeedCreateTexture() {\r\n\t\tconst { width, height, depth } = this.textureProp.size;\r\n\t\tif (this.gpuTexture) {\r\n\t\t\tif (width != this.gpuTexture.width || height != this.gpuTexture.height) {\r\n\t\t\t\tthis._textureView = undefined;\r\n\t\t\t\tthis.gpuTexture.destroy();\r\n\t\t\t\tthis.gpuTexture = this.createGPUTexture();\r\n\t\t\t}\r\n\t\t} else {\r\n\t\t\tthis.gpuTexture = this.createGPUTexture();\r\n\t\t}\r\n\t}\r\n}\r\n","import Context from \"./Context\";\r\n\r\nclass Sampler {\r\n\tpublic gpuSampler: GPUSampler;\r\n\tpublic layoutType: GPUSamplerBindingLayout;\r\n\r\n\tstatic baseSampler = new Sampler({\r\n\t\tmagFilter: \"linear\",\r\n\t\tminFilter: \"linear\"\r\n\t});\r\n\r\n\tconstructor(\r\n\t\tpublic descriptor?: GPUSamplerDescriptor,\r\n\t\tlayoutType: GPUSamplerBindingLayout = {\r\n\t\t\ttype: \"filtering\"\r\n\t\t}\r\n\t) {\r\n\t\tthis.descriptor = {};\r\n\t\tObject.assign(\r\n\t\t\tthis.descriptor,\r\n\t\t\t{\r\n\t\t\t\tmagFilter: \"linear\",\r\n\t\t\t\tminFilter: \"linear\",\r\n\t\t\t\t// mipmapFilter: \"linear\",\r\n\t\t\t\taddressModeU: \"clamp-to-edge\",\r\n\t\t\t\taddressModeV: \"clamp-to-edge\"\r\n\t\t\t\t// addressModeW: \"clamp-to-edge\",\r\n\t\t\t},\r\n\t\t\tdescriptor\r\n\t\t);\r\n\t\tthis.layoutType = layoutType;\r\n\t}\r\n\tupdate(context: Context) {\r\n\t\tif (!this.gpuSampler) this.gpuSampler = context.device.createSampler(this.descriptor);\r\n\t}\r\n}\r\n\r\nexport default Sampler;\r\n","import { AttachmentOptions } from \"../core/WebGPUTypes\";\r\nimport Texture from \"./Texture\";\r\n\r\nclass Attachment {\r\n\tpublic op: GPULoadOp = \"clear\";\r\n\tpublic storeOp: GPUStoreOp = \"store\";\r\n\r\n\tpublic texture?: Texture;\r\n\tpublic resolveTarget?: Texture;\r\n\r\n\tpublic readOnly?: boolean;\r\n\r\n\tconstructor(public value: GPUColorDict | GPUColor | number, options?: AttachmentOptions) {\r\n\t\tObject.assign(this, options);\r\n\t}\r\n}\r\n\r\nexport default Attachment;\r\n","export default function defined(value) {\n\treturn value !== undefined && value !== null;\n}\n","/*\n  https://github.com/banksean wrapped Makoto Matsumoto and Takuji Nishimura's code in a namespace\n  so it's better encapsulated. Now you can have multiple random number generators\n  and they won't stomp all over eachother's state.\n\n  If you want to use this as a substitute for Math.random(), use the random()\n  method like so:\n\n  var m = new MersenneTwister();\n  var randomNumber = m.random();\n\n  You can also call the other genrand_{foo}() methods on the instance.\n\n  If you want to use a specific seed in order to get a repeatable random\n  sequence, pass an integer into the constructor:\n\n  var m = new MersenneTwister(123);\n\n  and that will always produce the same random sequence.\n\n  Sean McCullough (banksean@gmail.com)\n*/\n\n/*\n   A C-program for MT19937, with initialization improved 2002/1/26.\n   Coded by Takuji Nishimura and Makoto Matsumoto.\n\n   Before using, initialize the state by using init_seed(seed)\n   or init_by_array(init_key, key_length).\n\n   Copyright (C) 1997 - 2002, Makoto Matsumoto and Takuji Nishimura,\n   All rights reserved.\n\n   Redistribution and use in source and binary forms, with or without\n   modification, are permitted provided that the following conditions\n   are met:\n\n     1. Redistributions of source code must retain the above copyright\n        notice, this list of conditions and the following disclaimer.\n\n     2. Redistributions in binary form must reproduce the above copyright\n        notice, this list of conditions and the following disclaimer in the\n        documentation and/or other materials provided with the distribution.\n\n     3. The names of its contributors may not be used to endorse or promote\n        products derived from this software without specific prior written\n        permission.\n\n   THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS\n   \"AS IS\" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT\n   LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR\n   A PARTICULAR PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE COPYRIGHT OWNER OR\n   CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,\n   EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,\n   PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR\n   PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF\n   LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING\n   NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS\n   SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n\n\n   Any feedback is very welcome.\n   http://www.math.sci.hiroshima-u.ac.jp/~m-mat/MT/emt.html\n   email: m-mat @ math.sci.hiroshima-u.ac.jp (remove space)\n*/\n\nvar MersenneTwister = function(seed) {\n\tif (seed == undefined) {\n\t\tseed = new Date().getTime();\n\t}\n\n\t/* Period parameters */\n\tthis.N = 624;\n\tthis.M = 397;\n\tthis.MATRIX_A = 0x9908b0df;   /* constant vector a */\n\tthis.UPPER_MASK = 0x80000000; /* most significant w-r bits */\n\tthis.LOWER_MASK = 0x7fffffff; /* least significant r bits */\n\n\tthis.mt = new Array(this.N); /* the array for the state vector */\n\tthis.mti=this.N+1; /* mti==N+1 means mt[N] is not initialized */\n\n\tif (seed.constructor == Array) {\n\t\tthis.init_by_array(seed, seed.length);\n\t}\n\telse {\n\t\tthis.init_seed(seed);\n\t}\n}\n\n/* initializes mt[N] with a seed */\n/* origin name init_genrand */\nMersenneTwister.prototype.init_seed = function(s) {\n\tthis.mt[0] = s >>> 0;\n\tfor (this.mti=1; this.mti<this.N; this.mti++) {\n\t\tvar s = this.mt[this.mti-1] ^ (this.mt[this.mti-1] >>> 30);\n\t\tthis.mt[this.mti] = (((((s & 0xffff0000) >>> 16) * 1812433253) << 16) + (s & 0x0000ffff) * 1812433253)\n\t\t+ this.mti;\n\t\t/* See Knuth TAOCP Vol2. 3rd Ed. P.106 for multiplier. */\n\t\t/* In the previous versions, MSBs of the seed affect   */\n\t\t/* only MSBs of the array mt[].                        */\n\t\t/* 2002/01/09 modified by Makoto Matsumoto             */\n\t\tthis.mt[this.mti] >>>= 0;\n\t\t/* for >32 bit machines */\n\t}\n}\n\n/* initialize by an array with array-length */\n/* init_key is the array for initializing keys */\n/* key_length is its length */\n/* slight change for C++, 2004/2/26 */\nMersenneTwister.prototype.init_by_array = function(init_key, key_length) {\n\tvar i, j, k;\n\tthis.init_seed(19650218);\n\ti=1; j=0;\n\tk = (this.N>key_length ? this.N : key_length);\n\tfor (; k; k--) {\n\t\tvar s = this.mt[i-1] ^ (this.mt[i-1] >>> 30)\n\t\tthis.mt[i] = (this.mt[i] ^ (((((s & 0xffff0000) >>> 16) * 1664525) << 16) + ((s & 0x0000ffff) * 1664525)))\n\t\t+ init_key[j] + j; /* non linear */\n\t\tthis.mt[i] >>>= 0; /* for WORDSIZE > 32 machines */\n\t\ti++; j++;\n\t\tif (i>=this.N) { this.mt[0] = this.mt[this.N-1]; i=1; }\n\t\tif (j>=key_length) j=0;\n\t}\n\tfor (k=this.N-1; k; k--) {\n\t\tvar s = this.mt[i-1] ^ (this.mt[i-1] >>> 30);\n\t\tthis.mt[i] = (this.mt[i] ^ (((((s & 0xffff0000) >>> 16) * 1566083941) << 16) + (s & 0x0000ffff) * 1566083941))\n\t\t- i; /* non linear */\n\t\tthis.mt[i] >>>= 0; /* for WORDSIZE > 32 machines */\n\t\ti++;\n\t\tif (i>=this.N) { this.mt[0] = this.mt[this.N-1]; i=1; }\n\t}\n\n\tthis.mt[0] = 0x80000000; /* MSB is 1; assuring non-zero initial array */\n}\n\n/* generates a random number on [0,0xffffffff]-interval */\n/* origin name genrand_int32 */\nMersenneTwister.prototype.random_int = function() {\n\tvar y;\n\tvar mag01 = new Array(0x0, this.MATRIX_A);\n\t/* mag01[x] = x * MATRIX_A  for x=0,1 */\n\n\tif (this.mti >= this.N) { /* generate N words at one time */\n\t\tvar kk;\n\n\t\tif (this.mti == this.N+1)  /* if init_seed() has not been called, */\n\t\t\tthis.init_seed(5489);  /* a default initial seed is used */\n\n\t\tfor (kk=0;kk<this.N-this.M;kk++) {\n\t\t\ty = (this.mt[kk]&this.UPPER_MASK)|(this.mt[kk+1]&this.LOWER_MASK);\n\t\t\tthis.mt[kk] = this.mt[kk+this.M] ^ (y >>> 1) ^ mag01[y & 0x1];\n\t\t}\n\t\tfor (;kk<this.N-1;kk++) {\n\t\t\ty = (this.mt[kk]&this.UPPER_MASK)|(this.mt[kk+1]&this.LOWER_MASK);\n\t\t\tthis.mt[kk] = this.mt[kk+(this.M-this.N)] ^ (y >>> 1) ^ mag01[y & 0x1];\n\t\t}\n\t\ty = (this.mt[this.N-1]&this.UPPER_MASK)|(this.mt[0]&this.LOWER_MASK);\n\t\tthis.mt[this.N-1] = this.mt[this.M-1] ^ (y >>> 1) ^ mag01[y & 0x1];\n\n\t\tthis.mti = 0;\n\t}\n\n\ty = this.mt[this.mti++];\n\n\t/* Tempering */\n\ty ^= (y >>> 11);\n\ty ^= (y << 7) & 0x9d2c5680;\n\ty ^= (y << 15) & 0xefc60000;\n\ty ^= (y >>> 18);\n\n\treturn y >>> 0;\n}\n\n/* generates a random number on [0,0x7fffffff]-interval */\n/* origin name genrand_int31 */\nMersenneTwister.prototype.random_int31 = function() {\n\treturn (this.random_int()>>>1);\n}\n\n/* generates a random number on [0,1]-real-interval */\n/* origin name genrand_real1 */\nMersenneTwister.prototype.random_incl = function() {\n\treturn this.random_int()*(1.0/4294967295.0);\n\t/* divided by 2^32-1 */\n}\n\n/* generates a random number on [0,1)-real-interval */\nMersenneTwister.prototype.random = function() {\n\treturn this.random_int()*(1.0/4294967296.0);\n\t/* divided by 2^32 */\n}\n\n/* generates a random number on (0,1)-real-interval */\n/* origin name genrand_real3 */\nMersenneTwister.prototype.random_excl = function() {\n\treturn (this.random_int() + 0.5)*(1.0/4294967296.0);\n\t/* divided by 2^32 */\n}\n\n/* generates a random number on [0,1) with 53-bit resolution*/\n/* origin name genrand_res53 */\nMersenneTwister.prototype.random_long = function() {\n\tvar a=this.random_int()>>>5, b=this.random_int()>>>6;\n\treturn(a*67108864.0+b)*(1.0/9007199254740992.0);\n}\n\n/* These real versions are due to Isaku Wada, 2002/01/09 added */\n\nmodule.exports = MersenneTwister;\n","import MersenneTwister from \"mersenne-twister\";\r\nimport defaultValue from \"../utils/defaultValue\";\r\nimport defined from \"../utils/defined\";\r\n\r\nclass GMath {\r\n\tpublic static EPSILON1 = 0.1;\r\n\r\n\tpublic static EPSILON2 = 0.01;\r\n\r\n\tpublic static EPSILON3 = 0.001;\r\n\tpublic static EPSILON4 = 0.0001;\r\n\r\n\tpublic static EPSILON5 = 0.00001;\r\n\r\n\tpublic static EPSILON6 = 0.000001;\r\n\r\n\tpublic static EPSILON7 = 0.0000001;\r\n\r\n\tpublic static EPSILON8 = 0.00000001;\r\n\r\n\tpublic static EPSILON9 = 0.000000001;\r\n\r\n\tpublic static EPSILON10 = 0.0000000001;\r\n\r\n\tpublic static EPSILON11 = 0.00000000001;\r\n\r\n\tpublic static EPSILON12 = 0.000000000001;\r\n\r\n\tpublic static EPSILON13 = 0.0000000000001;\r\n\r\n\tpublic static EPSILON14 = 0.00000000000001;\r\n\r\n\tpublic static EPSILON15 = 0.000000000000001;\r\n\r\n\tpublic static EPSILON16 = 0.0000000000000001;\r\n\r\n\tpublic static EPSILON17 = 0.00000000000000001;\r\n\r\n\tpublic static EPSILON18 = 0.000000000000000001;\r\n\r\n\tpublic static EPSILON19 = 0.0000000000000000001;\r\n\r\n\tpublic static EPSILON20 = 0.00000000000000000001;\r\n\r\n\tpublic static EPSILON21 = 0.000000000000000000001;\r\n\r\n\tpublic static GRAVITATIONALPARAMETER = 3.986004418e14;\r\n\r\n\tpublic static SIXTY_FOUR_KILOBYTES = 64 * 1024;\r\n\r\n\tpublic static FOUR_GIGABYTES = 4 * 1024 * 1024 * 1024;\r\n\r\n\tstatic sign = defaultValue(Math.sign, function sign(value) {\r\n\t\tvalue = +value; // coerce to number\r\n\t\tif (value === 0 || value !== value) {\r\n\t\t\t// zero or NaN\r\n\t\t\treturn value;\r\n\t\t}\r\n\t\treturn value > 0 ? 1 : -1;\r\n\t});\r\n\r\n\tstatic signNotZero(value) {\r\n\t\treturn value < 0.0 ? -1.0 : 1.0;\r\n\t}\r\n\r\n\tstatic toSNorm(value: number, rangeMaximum: number): number {\r\n\t\trangeMaximum = defaultValue(rangeMaximum, 255);\r\n\t\treturn Math.round((GMath.clamp(value, -1.0, 1.0) * 0.5 + 0.5) * rangeMaximum);\r\n\t}\r\n\r\n\tstatic fromSNorm(value: number, rangeMaximum: number): number {\r\n\t\trangeMaximum = defaultValue(rangeMaximum, 255);\r\n\t\treturn (GMath.clamp(value, 0.0, rangeMaximum) / rangeMaximum) * 2.0 - 1.0;\r\n\t}\r\n\r\n\tstatic normalize(value: number, rangeMinimum: number, rangeMaximum: number): number {\r\n\t\trangeMaximum = Math.max(rangeMaximum - rangeMinimum, 0.0);\r\n\t\treturn rangeMaximum === 0.0 ? 0.0 : GMath.clamp((value - rangeMinimum) / rangeMaximum, 0.0, 1.0);\r\n\t}\r\n\r\n\tstatic sinh = defaultValue(Math.sinh, function sinh(value) {\r\n\t\treturn (Math.exp(value) - Math.exp(-value)) / 2.0;\r\n\t});\r\n\r\n\tstatic cosh = defaultValue(Math.cosh, function cosh(value) {\r\n\t\treturn (Math.exp(value) + Math.exp(-value)) / 2.0;\r\n\t});\r\n\r\n\tstatic lerp(p: number, q: number, time: number): number {\r\n\t\treturn (1.0 - time) * p + time * q;\r\n\t}\r\n\r\n\tstatic PI = Math.PI;\r\n\r\n\tstatic ONE_OVER_PI = 1.0 / Math.PI;\r\n\r\n\tstatic PI_OVER_TWO = Math.PI / 2.0;\r\n\r\n\tstatic PI_OVER_THREE = Math.PI / 3.0;\r\n\r\n\tstatic PI_OVER_FOUR = Math.PI / 4.0;\r\n\r\n\tstatic PI_OVER_SIX = Math.PI / 6.0;\r\n\r\n\tstatic THREE_PI_OVER_TWO = (3.0 * Math.PI) / 2.0;\r\n\r\n\tstatic TWO_PI = 2.0 * Math.PI;\r\n\r\n\tstatic ONE_OVER_TWO_PI = 1.0 / (2.0 * Math.PI);\r\n\r\n\tstatic RADIANS_PER_DEGREE = Math.PI / 180.0;\r\n\r\n\tstatic DEGREES_PER_RADIAN = 180.0 / Math.PI;\r\n\r\n\tstatic RADIANS_PER_ARCSECOND = GMath.RADIANS_PER_DEGREE / 3600.0;\r\n\r\n\tstatic toRadians(degrees: number): number {\r\n\t\tif (!defined(degrees)) {\r\n\t\t\tthrow new Error(\"degrees is required.\");\r\n\t\t}\r\n\t\treturn degrees * GMath.RADIANS_PER_DEGREE;\r\n\t}\r\n\r\n\tstatic toDegrees(radians: number): number {\r\n\t\tif (!defined(radians)) {\r\n\t\t\tthrow new Error(\"radians is required.\");\r\n\t\t}\r\n\t\treturn radians * GMath.DEGREES_PER_RADIAN;\r\n\t}\r\n\r\n\tstatic negativePiToPi(angle: number): number {\r\n\t\tif (!defined(angle)) {\r\n\t\t\tthrow new Error(\"angle is required.\");\r\n\t\t}\r\n\t\tif (angle >= -GMath.PI && angle <= GMath.PI) {\r\n\t\t\t// Early exit if the input is already inside the range. This avoids\r\n\t\t\t// unnecessary math which could introduce floating point error.\r\n\t\t\treturn angle;\r\n\t\t}\r\n\t\treturn GMath.zeroToTwoPi(angle + GMath.PI) - GMath.PI;\r\n\t}\r\n\r\n\tstatic zeroToTwoPi(angle: number): number {\r\n\t\tif (!defined(angle)) {\r\n\t\t\tthrow new Error(\"angle is required.\");\r\n\t\t}\r\n\t\tif (angle >= 0 && angle <= GMath.TWO_PI) {\r\n\t\t\t// Early exit if the input is already inside the range. This avoids\r\n\t\t\t// unnecessary math which could introduce floating point error.\r\n\t\t\treturn angle;\r\n\t\t}\r\n\t\tconst mod = GMath.mod(angle, GMath.TWO_PI);\r\n\t\tif (Math.abs(mod) < GMath.EPSILON14 && Math.abs(angle) > GMath.EPSILON14) {\r\n\t\t\treturn GMath.TWO_PI;\r\n\t\t}\r\n\t\treturn mod;\r\n\t}\r\n\r\n\tstatic mod(m: number, n: number): number {\r\n\t\tif (!defined(m)) {\r\n\t\t\tthrow new Error(\"m is required.\");\r\n\t\t}\r\n\t\tif (!defined(n)) {\r\n\t\t\tthrow new Error(\"n is required.\");\r\n\t\t}\r\n\t\tif (n === 0.0) {\r\n\t\t\tthrow new Error(\"divisor cannot be 0.\");\r\n\t\t}\r\n\t\tif (GMath.sign(m) === GMath.sign(n) && Math.abs(m) < Math.abs(n)) {\r\n\t\t\t// Early exit if the input does not need to be modded. This avoids\r\n\t\t\t// unnecessary math which could introduce floating point error.\r\n\t\t\treturn m;\r\n\t\t}\r\n\r\n\t\treturn ((m % n) + n) % n;\r\n\t}\r\n\r\n\tstatic equalsEpsilon(\r\n\t\tleft: number,\r\n\t\tright: number,\r\n\t\trelativeEpsilon: number,\r\n\t\tabsoluteEpsilon: number = relativeEpsilon\r\n\t): boolean {\r\n\t\tif (!defined(left)) {\r\n\t\t\tthrow new Error(\"left is required.\");\r\n\t\t}\r\n\t\tif (!defined(right)) {\r\n\t\t\tthrow new Error(\"right is required.\");\r\n\t\t}\r\n\r\n\t\trelativeEpsilon = defaultValue(relativeEpsilon, 0.0);\r\n\t\tabsoluteEpsilon = defaultValue(absoluteEpsilon, relativeEpsilon);\r\n\t\tconst absDiff = Math.abs(left - right);\r\n\t\treturn absDiff <= absoluteEpsilon || absDiff <= relativeEpsilon * Math.max(Math.abs(left), Math.abs(right));\r\n\t}\r\n\r\n\tstatic lessThan(left: number, right: number, absoluteEpsilon = 0): boolean {\r\n\t\tif (!defined(left)) {\r\n\t\t\tthrow new Error(\"first is required.\");\r\n\t\t}\r\n\t\tif (!defined(right)) {\r\n\t\t\tthrow new Error(\"second is required.\");\r\n\t\t}\r\n\t\tif (!defined(absoluteEpsilon)) {\r\n\t\t\tthrow new Error(\"absoluteEpsilon is required.\");\r\n\t\t}\r\n\t\treturn left - right < -absoluteEpsilon;\r\n\t}\r\n\r\n\tstatic lessThanOrEquals(left: number, right: number, absoluteEpsilon = 0): boolean {\r\n\t\tif (!defined(left)) {\r\n\t\t\tthrow new Error(\"first is required.\");\r\n\t\t}\r\n\t\tif (!defined(right)) {\r\n\t\t\tthrow new Error(\"second is required.\");\r\n\t\t}\r\n\t\tif (!defined(absoluteEpsilon)) {\r\n\t\t\tthrow new Error(\"absoluteEpsilon is required.\");\r\n\t\t}\r\n\t\treturn left - right < absoluteEpsilon;\r\n\t}\r\n\r\n\tstatic greaterThan(left: number, right: number, absoluteEpsilon = 0): boolean {\r\n\t\tif (!defined(left)) {\r\n\t\t\tthrow new Error(\"first is required.\");\r\n\t\t}\r\n\t\tif (!defined(right)) {\r\n\t\t\tthrow new Error(\"second is required.\");\r\n\t\t}\r\n\t\tif (!defined(absoluteEpsilon)) {\r\n\t\t\tthrow new Error(\"absoluteEpsilon is required.\");\r\n\t\t}\r\n\t\treturn left - right > absoluteEpsilon;\r\n\t}\r\n\r\n\tstatic greaterThanOrEquals(left: number, right: number, absoluteEpsilon = 0): boolean {\r\n\t\tif (!defined(left)) {\r\n\t\t\tthrow new Error(\"first is required.\");\r\n\t\t}\r\n\t\tif (!defined(right)) {\r\n\t\t\tthrow new Error(\"second is required.\");\r\n\t\t}\r\n\t\tif (!defined(absoluteEpsilon)) {\r\n\t\t\tthrow new Error(\"absoluteEpsilon is required.\");\r\n\t\t}\r\n\t\treturn left - right > -absoluteEpsilon;\r\n\t}\r\n\r\n\tstatic isPowerOfTwo(n: number): boolean {\r\n\t\t// >>includeStart('debug', pragmas.debug);\r\n\t\tif (typeof n !== \"number\" || n < 0 || n > 4294967295) {\r\n\t\t\tthrow new Error(\"A number between 0 and (2^32)-1 is required.\");\r\n\t\t}\r\n\t\t// >>includeEnd('debug');\r\n\r\n\t\treturn n !== 0 && (n & (n - 1)) === 0;\r\n\t}\r\n\r\n\tstatic nextPowerOfTwo(n: number): number {\r\n\t\tif (typeof n !== \"number\" || n < 0 || n > 2147483648) {\r\n\t\t\tthrow new Error(\"A number between 0 and 2^31 is required.\");\r\n\t\t}\r\n\t\t// From http://graphics.stanford.edu/~seander/bithacks.html#RoundUpPowerOf2\r\n\t\t--n;\r\n\t\tn |= n >> 1;\r\n\t\tn |= n >> 2;\r\n\t\tn |= n >> 4;\r\n\t\tn |= n >> 8;\r\n\t\tn |= n >> 16;\r\n\t\t++n;\r\n\r\n\t\treturn n;\r\n\t}\r\n\r\n\tstatic previousPowerOfTwo(n: number): number {\r\n\t\tif (typeof n !== \"number\" || n < 0 || n > 4294967295) {\r\n\t\t\tthrow new Error(\"A number between 0 and (2^32)-1 is required.\");\r\n\t\t}\r\n\r\n\t\tn |= n >> 1;\r\n\t\tn |= n >> 2;\r\n\t\tn |= n >> 4;\r\n\t\tn |= n >> 8;\r\n\t\tn |= n >> 16;\r\n\t\tn |= n >> 32;\r\n\r\n\t\t// The previous bitwise operations implicitly convert to signed 32-bit. Use `>>>` to convert to unsigned\r\n\t\tn = (n >>> 0) - (n >>> 1);\r\n\r\n\t\treturn n;\r\n\t}\r\n\r\n\tstatic clamp(value: number, min: number, max: number): number {\r\n\t\treturn value < min ? min : value > max ? max : value;\r\n\t}\r\n\r\n\tstatic nextRandomNumber = function (): number {\r\n\t\treturn randomNumberGenerator.random();\r\n\t};\r\n\r\n\tstatic randomBetween = function (min: number, max: number): number {\r\n\t\treturn GMath.nextRandomNumber() * (max - min) + min;\r\n\t};\r\n\r\n\tstatic acosClamped = function (value: number): number {\r\n\t\tif (!defined(value)) {\r\n\t\t\tthrow new Error(\"value is required.\");\r\n\t\t}\r\n\r\n\t\treturn Math.acos(GMath.clamp(value, -1.0, 1.0));\r\n\t};\r\n\r\n\tstatic asinClamped = function (value: number): number {\r\n\t\tif (!defined(value)) {\r\n\t\t\tthrow new Error(\"value is required.\");\r\n\t\t}\r\n\r\n\t\treturn Math.asin(GMath.clamp(value, -1.0, 1.0));\r\n\t};\r\n\r\n\tstatic chordLength = function (angle: number, radius: number): number {\r\n\t\tif (!defined(angle)) {\r\n\t\t\tthrow new Error(\"angle is required.\");\r\n\t\t}\r\n\t\tif (!defined(radius)) {\r\n\t\t\tthrow new Error(\"radius is required.\");\r\n\t\t}\r\n\r\n\t\treturn 2.0 * radius * Math.sin(angle * 0.5);\r\n\t};\r\n\r\n\tstatic logBase = function (number: number, base: number): number {\r\n\t\tif (!defined(number)) {\r\n\t\t\tthrow new Error(\"number is required.\");\r\n\t\t}\r\n\t\tif (!defined(base)) {\r\n\t\t\tthrow new Error(\"base is required.\");\r\n\t\t}\r\n\r\n\t\treturn Math.log(number) / Math.log(base);\r\n\t};\r\n\r\n\tstatic cbrt = defaultValue(Math.cbrt, function cbrt(number) {\r\n\t\tconst result = Math.pow(Math.abs(number), 1.0 / 3.0);\r\n\t\treturn number < 0.0 ? -result : result;\r\n\t});\r\n\tstatic log2 = defaultValue(Math.log2, function log2(number) {\r\n\t\treturn Math.log(number) * Math.LOG2E;\r\n\t});\r\n\r\n\t/**\r\n\t * @private\r\n\t */\r\n\tstatic fog(distanceToCamera: number, density: number): number {\r\n\t\tconst scalar = distanceToCamera * density;\r\n\t\treturn 1.0 - Math.exp(-(scalar * scalar));\r\n\t}\r\n}\r\nconst randomNumberGenerator = new MersenneTwister();\r\nconst factorials = [1];\r\nexport default GMath;\r\n","import { Attribute } from \"../render/Attribute\";\r\nimport defined from \"../utils/defined\";\r\nimport GMath from \"./Math\";\r\nimport Matrix3 from \"./Matrix3\";\r\n/**\r\n * A 2D Cartesian point.\r\n * @alias Vector2\r\n * @constructor\r\n *\r\n * @param {Number} [x=0.0] The X component.\r\n * @param {Number} [y=0.0] The Y component.\r\n *\r\n */\r\nclass Vector2 {\r\n\tpublic static ZERO = Object.freeze(new Vector2(0.0, 0.0));\r\n\r\n\tpublic static ONE = Object.freeze(new Vector2(1.0, 1.0));\r\n\r\n\tpublic static UNIT_X = Object.freeze(new Vector2(1.0, 0.0));\r\n\r\n\tpublic static UNIT_Y = Object.freeze(new Vector2(0.0, 1.0));\r\n\r\n\tconstructor(public x: number = 0.0, public y: number = 0.0) {\r\n\t\tthis.x = x;\r\n\t\tthis.y = y;\r\n\t}\r\n\tset(x: number, y: number): Vector2 {\r\n\t\tthis.x = x;\r\n\t\tthis.y = y;\r\n\t\treturn this;\r\n\t}\r\n\ttoArray() {\r\n\t\treturn [this.x, this.y];\r\n\t}\r\n\r\n\tclone(result: Vector2): Vector2 {\r\n\t\treturn Vector2.clone(this, result);\r\n\t}\r\n\r\n\tequals(right: Vector2): boolean {\r\n\t\treturn Vector2.equals(this, right);\r\n\t}\r\n\tequalsEpsilon(right: Vector2, relativeEpsilon = 0, absoluteEpsilon = 0): boolean {\r\n\t\treturn Vector2.equalsEpsilon(this, right, relativeEpsilon, absoluteEpsilon);\r\n\t}\r\n\r\n\ttoString() {\r\n\t\treturn `(${this.x}, ${this.y})`;\r\n\t}\r\n\tfromBufferAttribute(attribute: Attribute, index: number): Vector2 {\r\n\t\tthis.x = attribute.getX(index);\r\n\t\tthis.y = attribute.getY(index);\r\n\t\treturn this;\r\n\t}\r\n\tapplyMatrix3(matrix3: Matrix3): Vector2 {\r\n\t\tconst x = this.x,\r\n\t\t\ty = this.y;\r\n\t\tthis.x = matrix3[0] * x + matrix3[3] * y + matrix3[6];\r\n\t\tthis.y = matrix3[1] * x + matrix3[4] * y + matrix3[7];\r\n\t\treturn this;\r\n\t}\r\n\r\n\tstatic fromElements(x: number, y: number, result: Vector2): Vector2 {\r\n\t\tif (!defined(result)) {\r\n\t\t\treturn new Vector2(x, y);\r\n\t\t}\r\n\r\n\t\tresult.x = x;\r\n\t\tresult.y = y;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic clone(cartesian: Vector2, result: Vector2): Vector2 {\r\n\t\tif (!defined(cartesian)) {\r\n\t\t\treturn undefined;\r\n\t\t}\r\n\t\tif (!defined(result)) {\r\n\t\t\treturn new Vector2(cartesian.x, cartesian.y);\r\n\t\t}\r\n\r\n\t\tresult.x = cartesian.x;\r\n\t\tresult.y = cartesian.y;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic maximumComponent(cartesian: Vector2): number {\r\n\t\treturn Math.max(cartesian.x, cartesian.y);\r\n\t}\r\n\r\n\tstatic minimumComponent(cartesian: Vector2): number {\r\n\t\treturn Math.min(cartesian.x, cartesian.y);\r\n\t}\r\n\r\n\tstatic minimumByComponent(first: Vector2, second: Vector2, result: Vector2): Vector2 {\r\n\t\tresult.x = Math.min(first.x, second.x);\r\n\t\tresult.y = Math.min(first.y, second.y);\r\n\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic maximumByComponent(first: Vector2, second: Vector2, result: Vector2): Vector2 {\r\n\t\tresult.x = Math.max(first.x, second.x);\r\n\t\tresult.y = Math.max(first.y, second.y);\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic clamp(value: Vector2, min: Vector2, max: Vector2, result: Vector2): Vector2 {\r\n\t\tconst x = GMath.clamp(value.x, min.x, max.x);\r\n\t\tconst y = GMath.clamp(value.y, min.y, max.y);\r\n\r\n\t\tresult.x = x;\r\n\t\tresult.y = y;\r\n\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic magnitudeSquared(cartesian: Vector2): number {\r\n\t\treturn cartesian.x * cartesian.x + cartesian.y * cartesian.y;\r\n\t}\r\n\r\n\tstatic magnitude(cartesian: Vector2): number {\r\n\t\treturn Math.sqrt(Vector2.magnitudeSquared(cartesian));\r\n\t}\r\n\r\n\tstatic distance(left: Vector2, right: Vector2): number {\r\n\t\tVector2.subtract(left, right, distanceScratch);\r\n\t\treturn Vector2.magnitude(distanceScratch);\r\n\t}\r\n\r\n\tstatic distanceSquared(left: Vector2, right: Vector2): number {\r\n\t\tVector2.subtract(left, right, distanceScratch);\r\n\t\treturn Vector2.magnitudeSquared(distanceScratch);\r\n\t}\r\n\r\n\tstatic normalize(cartesian: Vector2, result: Vector2): Vector2 {\r\n\t\tconst magnitude = Vector2.magnitude(cartesian);\r\n\r\n\t\tresult.x = cartesian.x / magnitude;\r\n\t\tresult.y = cartesian.y / magnitude;\r\n\r\n\t\t// >>includeStart('debug', pragmas.debug);\r\n\t\tif (isNaN(result.x) || isNaN(result.y)) {\r\n\t\t\tthrow new Error(\"normalized result is not a number\");\r\n\t\t}\r\n\t\t// >>includeEnd('debug');\r\n\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic dot(left: Vector2, right: Vector2): number {\r\n\t\treturn left.x * right.x + left.y * right.y;\r\n\t}\r\n\r\n\tstatic cross(left: Vector2, right: Vector2): number {\r\n\t\treturn left.x * right.y - left.y * right.x;\r\n\t}\r\n\r\n\tstatic multiplyComponents(left: Vector2, right: Vector2, result: Vector2): Vector2 {\r\n\t\tresult.x = left.x * right.x;\r\n\t\tresult.y = left.y * right.y;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic divideComponents(left: Vector2, right: Vector2, result: Vector2): Vector2 {\r\n\t\tresult.x = left.x / right.x;\r\n\t\tresult.y = left.y / right.y;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic add(left: Vector2, right: Vector2, result: Vector2): Vector2 {\r\n\t\tresult.x = left.x + right.x;\r\n\t\tresult.y = left.y + right.y;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic subtract(left: Vector2, right: Vector2, result: Vector2): Vector2 {\r\n\t\tresult.x = left.x - right.x;\r\n\t\tresult.y = left.y - right.y;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic multiplyByScalar(cartesian: Vector2, scalar: number, result: Vector2): Vector2 {\r\n\t\tresult.x = cartesian.x * scalar;\r\n\t\tresult.y = cartesian.y * scalar;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic divideByScalar(cartesian: Vector2, scalar: number, result: Vector2): Vector2 {\r\n\t\tresult.x = cartesian.x / scalar;\r\n\t\tresult.y = cartesian.y / scalar;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic negate(cartesian: Vector2, result: Vector2): Vector2 {\r\n\t\tresult.x = -cartesian.x;\r\n\t\tresult.y = -cartesian.y;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic abs(cartesian: Vector2, result: Vector2): Vector2 {\r\n\t\tresult.x = Math.abs(cartesian.x);\r\n\t\tresult.y = Math.abs(cartesian.y);\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic lerp(start: Vector2, end: Vector2, t: number, result: Vector2): Vector2 {\r\n\t\tVector2.multiplyByScalar(end, t, lerpScratch);\r\n\t\tresult = Vector2.multiplyByScalar(start, 1.0 - t, result);\r\n\t\treturn Vector2.add(lerpScratch, result, result);\r\n\t}\r\n\r\n\tstatic angleBetween(left: Vector2, right: Vector2): number {\r\n\t\tVector2.normalize(left, angleBetweenScratch);\r\n\t\tVector2.normalize(right, angleBetweenScratch2);\r\n\t\treturn GMath.acosClamped(Vector2.dot(angleBetweenScratch, angleBetweenScratch2));\r\n\t}\r\n\r\n\tstatic mostOrthogonalAxis(cartesian: Vector2, result: Vector2): Vector2 {\r\n\t\tconst f = Vector2.normalize(cartesian, mostOrthogonalAxisScratch);\r\n\t\tVector2.abs(f, f);\r\n\r\n\t\tif (f.x <= f.y) {\r\n\t\t\tresult = Vector2.clone(Vector2.UNIT_X, result);\r\n\t\t} else {\r\n\t\t\tresult = Vector2.clone(Vector2.UNIT_Y, result);\r\n\t\t}\r\n\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic equals(left: Vector2, right: Vector2): boolean {\r\n\t\treturn left === right || (defined(left) && defined(right) && left.x === right.x && left.y === right.y);\r\n\t}\r\n\r\n\t/**\r\n\t * @private\r\n\t */\r\n\tstatic equalsArray(cartesian: Vector2, array: number[], offset: number): boolean {\r\n\t\treturn cartesian.x === array[offset] && cartesian.y === array[offset + 1];\r\n\t}\r\n\r\n\tstatic equalsEpsilon(left: Vector2, right: Vector2, relativeEpsilon = 0, absoluteEpsilon = 0): boolean {\r\n\t\treturn (\r\n\t\t\tleft === right ||\r\n\t\t\t(defined(left) &&\r\n\t\t\t\tdefined(right) &&\r\n\t\t\t\tGMath.equalsEpsilon(left.x, right.x, relativeEpsilon, absoluteEpsilon) &&\r\n\t\t\t\tGMath.equalsEpsilon(left.y, right.y, relativeEpsilon, absoluteEpsilon))\r\n\t\t);\r\n\t}\r\n}\r\nconst distanceScratch = new Vector2();\r\nconst lerpScratch = new Vector2();\r\nconst angleBetweenScratch = new Vector2();\r\nconst angleBetweenScratch2 = new Vector2();\r\nconst mostOrthogonalAxisScratch = new Vector2();\r\n\r\nexport default Vector2;\r\n","import { Attribute } from \"../render/Attribute\";\r\nimport defined from \"../utils/defined\";\r\nimport GMath from \"./Math\";\r\nimport Matrix3 from \"./Matrix3\";\r\nimport Matrix4 from \"./Matrix4\";\r\nimport { Quaternion } from \"./Quaternion\";\r\nimport { Spherical } from \"./Spherical\";\r\nimport Vector4 from \"./Vector4\";\r\nclass Vector3 {\r\n\tpublic static ZERO = Object.freeze(new Vector3(0.0, 0.0, 0.0));\r\n\r\n\tpublic static ONE = Object.freeze(new Vector3(1.0, 1.0, 1.0));\r\n\r\n\tpublic static UNIT_X = Object.freeze(new Vector3(1.0, 0.0, 0.0));\r\n\r\n\tpublic static UNIT_Y = Object.freeze(new Vector3(0.0, 1.0, 0.0));\r\n\r\n\tpublic static UNIT_Z = Object.freeze(new Vector3(0.0, 0.0, 1.0));\r\n\tx: number;\r\n\ty: number;\r\n\tz: number;\r\n\r\n\tconstructor(x = 0, y = 0, z = 0) {\r\n\t\tthis.x = x;\r\n\t\tthis.y = y;\r\n\t\tthis.z = z;\r\n\t}\r\n\tset(x: number, y: number, z: number): Vector3 {\r\n\t\tthis.x = x;\r\n\t\tthis.y = y;\r\n\t\tthis.z = z;\r\n\t\treturn this;\r\n\t}\r\n\ttoArray(): number[] {\r\n\t\treturn [this.x, this.y, this.z];\r\n\t}\r\n\r\n\tcopy(v: Vector3): Vector3 {\r\n\t\tthis.x = v.x;\r\n\t\tthis.y = v.y;\r\n\t\tthis.z = v.z;\r\n\t\treturn this;\r\n\t}\r\n\tlerp(end: Vector3, t: number): Vector3 {\r\n\t\tVector3.lerp(this, end, t, this);\r\n\t\treturn this;\r\n\t}\r\n\tadd(v: Vector3): Vector3 {\r\n\t\tVector3.add(this, v, this);\r\n\t\treturn this;\r\n\t}\r\n\taddScaledVector(v: Vector3, s: number): Vector3 {\r\n\t\tthis.x += v.x * s;\r\n\t\tthis.y += v.y * s;\r\n\t\tthis.z += v.z * s;\r\n\t\treturn this;\r\n\t}\r\n\tsubtract(v: Vector3): Vector3 {\r\n\t\tVector3.subtract(this, v, this);\r\n\t\treturn this;\r\n\t}\r\n\tapplyQuaternion(q: Quaternion): Vector3 {\r\n\t\tconst x = this.x,\r\n\t\t\ty = this.y,\r\n\t\t\tz = this.z;\r\n\t\tconst qx = q.x,\r\n\t\t\tqy = q.y,\r\n\t\t\tqz = q.z,\r\n\t\t\tqw = q.w;\r\n\r\n\t\t// calculate quat * vector\r\n\r\n\t\tconst ix = qw * x + qy * z - qz * y;\r\n\t\tconst iy = qw * y + qz * x - qx * z;\r\n\t\tconst iz = qw * z + qx * y - qy * x;\r\n\t\tconst iw = -qx * x - qy * y - qz * z;\r\n\r\n\t\t// calculate result * inverse quat\r\n\r\n\t\tthis.x = ix * qw + iw * -qx + iy * -qz - iz * -qy;\r\n\t\tthis.y = iy * qw + iw * -qy + iz * -qx - ix * -qz;\r\n\t\tthis.z = iz * qw + iw * -qz + ix * -qy - iy * -qx;\r\n\r\n\t\treturn this;\r\n\t}\r\n\tsetFromMatrixColumn(m: Matrix3 | Matrix4, index: number): Vector3 {\r\n\t\treturn this.fromArray(m, index * 4);\r\n\t}\r\n\tfromArray(array: Matrix3 | Matrix4, offset = 0): Vector3 {\r\n\t\tthis.x = array[offset];\r\n\t\tthis.y = array[offset + 1];\r\n\t\tthis.z = array[offset + 2];\r\n\r\n\t\treturn this;\r\n\t}\r\n\r\n\tmultiplyByScalar(scale: number): Vector3 {\r\n\t\tVector3.multiplyByScalar(this, scale, this);\r\n\t\treturn this;\r\n\t}\r\n\r\n\tclone(): Vector3 {\r\n\t\treturn Vector3.clone(this, new Vector3());\r\n\t}\r\n\tlength(): number {\r\n\t\treturn Math.sqrt(this.x * this.x + this.y * this.y + this.z * this.z);\r\n\t}\r\n\tapplyMatrix4(matrix: Matrix4): Vector3 {\r\n\t\tconst x = this.x,\r\n\t\t\ty = this.y,\r\n\t\t\tz = this.z;\r\n\t\tconst e = matrix;\r\n\t\tconst w = 1 / (e[3] * x + e[7] * y + e[11] * z + e[15]);\r\n\t\tthis.x = (e[0] * x + e[4] * y + e[8] * z + e[12]) * w;\r\n\t\tthis.y = (e[1] * x + e[5] * y + e[9] * z + e[13]) * w;\r\n\t\tthis.z = (e[2] * x + e[6] * y + e[10] * z + e[14]) * w;\r\n\t\treturn this;\r\n\t}\r\n\tapplyMatrix3(matrix: Matrix3): Vector3 {\r\n\t\tconst x = this.x,\r\n\t\t\ty = this.y,\r\n\t\t\tz = this.z;\r\n\t\tthis.x = x * matrix[0] + y * matrix[3] + z * matrix[6];\r\n\t\tthis.y = x * matrix[1] + y * matrix[4] + z * matrix[7];\r\n\t\tthis.z = x * matrix[2] + y * matrix[5] + z * matrix[8];\r\n\t\treturn this;\r\n\t}\r\n\ttransformDirection(matrix: Matrix3 | Matrix4): Vector3 {\r\n\t\tconst x = this.x,\r\n\t\t\ty = this.y,\r\n\t\t\tz = this.z;\r\n\t\tconst e = matrix;\r\n\t\tthis.x = e[0] * x + e[4] * y + e[8] * z;\r\n\t\tthis.y = e[1] * x + e[5] * y + e[9] * z;\r\n\t\tthis.z = e[2] * x + e[6] * y + e[10] * z;\r\n\t\treturn this.normalize();\r\n\t}\r\n\r\n\tsetFromMatrixPosition(matrix: Matrix4) {\r\n\t\tconst e = matrix;\r\n\r\n\t\tthis.x = e[12];\r\n\t\tthis.y = e[13];\r\n\t\tthis.z = e[14];\r\n\r\n\t\treturn this;\r\n\t}\r\n\r\n\tnormalize(): Vector3 {\r\n\t\tVector3.normalize(this, this);\r\n\t\treturn this;\r\n\t}\r\n\r\n\tequals(right: Vector3): boolean {\r\n\t\treturn Vector3.equals(this, right);\r\n\t}\r\n\r\n\tequalsEpsilon(right: Vector3, relativeEpsilon = 0, absoluteEpsilon = 0): boolean {\r\n\t\treturn Vector3.equalsEpsilon(this, right, relativeEpsilon, absoluteEpsilon);\r\n\t}\r\n\r\n\ttoString() {\r\n\t\treturn `(${this.x}, ${this.y}, ${this.z})`;\r\n\t}\r\n\tfromBufferAttribute(attribute: Attribute, index: number): Vector3 {\r\n\t\tthis.x = attribute.getX(index);\r\n\t\tthis.y = attribute.getY(index);\r\n\t\tthis.z = attribute.getZ(index);\r\n\t\treturn this;\r\n\t}\r\n\tstatic fromVector4(vec4: Vector4, result: Vector3): Vector3 {\r\n\t\tresult.x = vec4.x;\r\n\t\tresult.y = vec4.y;\r\n\t\tresult.z = vec4.z;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic fromSpherical(spherical: Spherical, result: Vector3): Vector3 {\r\n\t\tif (!defined(result)) {\r\n\t\t\tresult = new Vector3();\r\n\t\t}\r\n\t\tconst { phi, radius, theta } = spherical;\r\n\t\tconst sinPhiRadius = Math.sin(phi) * radius;\r\n\t\tresult.x = sinPhiRadius * Math.sin(theta);\r\n\t\tresult.y = Math.cos(phi) * radius;\r\n\t\tresult.z = sinPhiRadius * Math.cos(theta);\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic fromElements(x: number, y: number, z: number, result: Vector3): Vector3 {\r\n\t\tif (!defined(result)) {\r\n\t\t\treturn new Vector3(x, y, z);\r\n\t\t}\r\n\r\n\t\tresult.x = x;\r\n\t\tresult.y = y;\r\n\t\tresult.z = z;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic clone(cartesian: Vector3, result: Vector3 = new Vector3()): Vector3 {\r\n\t\tif (!defined(cartesian)) {\r\n\t\t\treturn undefined;\r\n\t\t}\r\n\t\tif (!defined(result)) {\r\n\t\t\treturn new Vector3(cartesian.x, cartesian.y, cartesian.z);\r\n\t\t}\r\n\r\n\t\tresult.x = cartesian.x;\r\n\t\tresult.y = cartesian.y;\r\n\t\tresult.z = cartesian.z;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic maximumComponent(cartesian: Vector3): number {\r\n\t\treturn Math.max(cartesian.x, cartesian.y, cartesian.z);\r\n\t}\r\n\r\n\tstatic minimumComponent(cartesian: Vector3): number {\r\n\t\treturn Math.min(cartesian.x, cartesian.y, cartesian.z);\r\n\t}\r\n\r\n\tstatic minimumByComponent(first: Vector3, second: Vector3, result: Vector3): Vector3 {\r\n\t\tresult.x = Math.min(first.x, second.x);\r\n\t\tresult.y = Math.min(first.y, second.y);\r\n\t\tresult.z = Math.min(first.z, second.z);\r\n\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic maximumByComponent(first: Vector3, second: Vector3, result: Vector3): Vector3 {\r\n\t\tresult.x = Math.max(first.x, second.x);\r\n\t\tresult.y = Math.max(first.y, second.y);\r\n\t\tresult.z = Math.max(first.z, second.z);\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic clamp(value: Vector3, min: Vector3, max: Vector3, result: Vector3): Vector3 {\r\n\t\tconst x = GMath.clamp(value.x, min.x, max.x);\r\n\t\tconst y = GMath.clamp(value.y, min.y, max.y);\r\n\t\tconst z = GMath.clamp(value.z, min.z, max.z);\r\n\r\n\t\tresult.x = x;\r\n\t\tresult.y = y;\r\n\t\tresult.z = z;\r\n\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic magnitudeSquared(cartesian: Vector3): number {\r\n\t\treturn cartesian.x * cartesian.x + cartesian.y * cartesian.y + cartesian.z * cartesian.z;\r\n\t}\r\n\r\n\tstatic magnitude(cartesian: Vector3): number {\r\n\t\treturn Math.sqrt(Vector3.magnitudeSquared(cartesian));\r\n\t}\r\n\r\n\tstatic distance(left: Vector3, right: Vector3): number {\r\n\t\tVector3.subtract(left, right, distanceScratch);\r\n\t\treturn Vector3.magnitude(distanceScratch);\r\n\t}\r\n\r\n\tstatic distanceSquared(left: Vector3, right: Vector3): number {\r\n\t\tVector3.subtract(left, right, distanceScratch);\r\n\t\treturn Vector3.magnitudeSquared(distanceScratch);\r\n\t}\r\n\r\n\tstatic normalize(cartesian: Vector3, result: Vector3): Vector3 {\r\n\t\tconst magnitude = Vector3.magnitude(cartesian);\r\n\r\n\t\tresult.x = cartesian.x / magnitude;\r\n\t\tresult.y = cartesian.y / magnitude;\r\n\t\tresult.z = cartesian.z / magnitude;\r\n\r\n\t\tif (isNaN(result.x) || isNaN(result.y) || isNaN(result.z)) {\r\n\t\t\tthrow new Error(\"normalized result is not a number\");\r\n\t\t}\r\n\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic dot(left: Vector3, right: Vector3): number {\r\n\t\treturn left.x * right.x + left.y * right.y + left.z * right.z;\r\n\t}\r\n\r\n\tstatic multiplyComponents(left: Vector3, right: Vector3, result: Vector3): Vector3 {\r\n\t\tresult.x = left.x * right.x;\r\n\t\tresult.y = left.y * right.y;\r\n\t\tresult.z = left.z * right.z;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic divideComponents(left: Vector3, right: Vector3, result: Vector3) {\r\n\t\tresult.x = left.x / right.x;\r\n\t\tresult.y = left.y / right.y;\r\n\t\tresult.z = left.z / right.z;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic add(left: Vector3, right: Vector3, result: Vector3): Vector3 {\r\n\t\tresult.x = left.x + right.x;\r\n\t\tresult.y = left.y + right.y;\r\n\t\tresult.z = left.z + right.z;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic subtract(left: Vector3, right: Vector3, result: Vector3): Vector3 {\r\n\t\tresult.x = left.x - right.x;\r\n\t\tresult.y = left.y - right.y;\r\n\t\tresult.z = left.z - right.z;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic multiplyByScalar(cartesian: Vector3, scalar: number, result: Vector3): Vector3 {\r\n\t\tresult.x = cartesian.x * scalar;\r\n\t\tresult.y = cartesian.y * scalar;\r\n\t\tresult.z = cartesian.z * scalar;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic divideByScalar(cartesian: Vector3, scalar: number, result: Vector3): Vector3 {\r\n\t\tresult.x = cartesian.x / scalar;\r\n\t\tresult.y = cartesian.y / scalar;\r\n\t\tresult.z = cartesian.z / scalar;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic negate(cartesian: Vector3, result: Vector3): Vector3 {\r\n\t\tresult.x = -cartesian.x;\r\n\t\tresult.y = -cartesian.y;\r\n\t\tresult.z = -cartesian.z;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic abs(cartesian: Vector3, result: Vector3): Vector3 {\r\n\t\tresult.x = Math.abs(cartesian.x);\r\n\t\tresult.y = Math.abs(cartesian.y);\r\n\t\tresult.z = Math.abs(cartesian.z);\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic lerp(start: Vector3, end: Vector3, t: number, result: Vector3): Vector3 {\r\n\t\tVector3.multiplyByScalar(end, t, lerpScratch);\r\n\t\tresult = Vector3.multiplyByScalar(start, 1.0 - t, result);\r\n\t\treturn Vector3.add(lerpScratch, result, result);\r\n\t}\r\n\r\n\tstatic angleBetween(left: Vector3, right: Vector3): number {\r\n\t\tVector3.normalize(left, angleBetweenScratch);\r\n\t\tVector3.normalize(right, angleBetweenScratch2);\r\n\t\tconst cosine = Vector3.dot(angleBetweenScratch, angleBetweenScratch2);\r\n\t\tconst sine = Vector3.magnitude(Vector3.cross(angleBetweenScratch, angleBetweenScratch2, angleBetweenScratch));\r\n\t\treturn Math.atan2(sine, cosine);\r\n\t}\r\n\r\n\tstatic mostOrthogonalAxis(cartesian: Vector3, result: Vector3): Vector3 {\r\n\t\tconst f = Vector3.normalize(cartesian, mostOrthogonalAxisScratch);\r\n\t\tVector3.abs(f, f);\r\n\r\n\t\tif (f.x <= f.y) {\r\n\t\t\tif (f.x <= f.z) {\r\n\t\t\t\tresult = Vector3.clone(Vector3.UNIT_X, result);\r\n\t\t\t} else {\r\n\t\t\t\tresult = Vector3.clone(Vector3.UNIT_Z, result);\r\n\t\t\t}\r\n\t\t} else if (f.y <= f.z) {\r\n\t\t\tresult = Vector3.clone(Vector3.UNIT_Y, result);\r\n\t\t} else {\r\n\t\t\tresult = Vector3.clone(Vector3.UNIT_Z, result);\r\n\t\t}\r\n\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic projectVector(a: Vector3, b: Vector3, result: Vector3): Vector3 {\r\n\t\tconst scalar = Vector3.dot(a, b) / Vector3.dot(b, b);\r\n\t\treturn Vector3.multiplyByScalar(b, scalar, result);\r\n\t}\r\n\r\n\tstatic equals(left: Vector3, right: Vector3): boolean {\r\n\t\treturn (\r\n\t\t\tleft === right ||\r\n\t\t\t(defined(left) && defined(right) && left.x === right.x && left.y === right.y && left.z === right.z)\r\n\t\t);\r\n\t}\r\n\r\n\t/**\r\n\t * @private\r\n\t */\r\n\tstatic equalsArray(cartesian: Vector3, array: number[], offset: number): boolean {\r\n\t\treturn cartesian.x === array[offset] && cartesian.y === array[offset + 1] && cartesian.z === array[offset + 2];\r\n\t}\r\n\r\n\tstatic equalsEpsilon(left: Vector3, right: Vector3, relativeEpsilon = 0, absoluteEpsilon = 0): boolean {\r\n\t\treturn (\r\n\t\t\tleft === right ||\r\n\t\t\t(defined(left) &&\r\n\t\t\t\tdefined(right) &&\r\n\t\t\t\tGMath.equalsEpsilon(left.x, right.x, relativeEpsilon, absoluteEpsilon) &&\r\n\t\t\t\tGMath.equalsEpsilon(left.y, right.y, relativeEpsilon, absoluteEpsilon) &&\r\n\t\t\t\tGMath.equalsEpsilon(left.z, right.z, relativeEpsilon, absoluteEpsilon))\r\n\t\t);\r\n\t}\r\n\r\n\tstatic cross(left: Vector3, right: Vector3, result: Vector3): Vector3 {\r\n\t\tconst leftX = left.x;\r\n\t\tconst leftY = left.y;\r\n\t\tconst leftZ = left.z;\r\n\t\tconst rightX = right.x;\r\n\t\tconst rightY = right.y;\r\n\t\tconst rightZ = right.z;\r\n\r\n\t\tconst x = leftY * rightZ - leftZ * rightY;\r\n\t\tconst y = leftZ * rightX - leftX * rightZ;\r\n\t\tconst z = leftX * rightY - leftY * rightX;\r\n\r\n\t\tresult.x = x;\r\n\t\tresult.y = y;\r\n\t\tresult.z = z;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic midpoint = function (left: Vector3, right: Vector3, result: Vector3): Vector3 {\r\n\t\tresult.x = (left.x + right.x) * 0.5;\r\n\t\tresult.y = (left.y + right.y) * 0.5;\r\n\t\tresult.z = (left.z + right.z) * 0.5;\r\n\r\n\t\treturn result;\r\n\t};\r\n}\r\nconst distanceScratch = new Vector3();\r\nconst lerpScratch = new Vector3();\r\nconst angleBetweenScratch = new Vector3();\r\nconst angleBetweenScratch2 = new Vector3();\r\nconst mostOrthogonalAxisScratch = new Vector3();\r\nexport default Vector3;\r\n","import { VertexFormat } from \"../core/WebGPUConstant\";\nimport Vector2 from \"../math/Vector2\";\nimport Vector3 from \"../math/Vector3\";\n\nexport class Attribute {\n\tpublic offset: number;\n\tpublic shaderLocation: number;\n\tpublic type: string;\n\tpublic format: string;\n\tpublic attributeByteSize: number;\n\tpublic attributeType: AttributeType;\n\tpublic static v3 = new Vector3();\n\tpublic static v2 = new Vector2();\n\tconstructor(public name: string, public value: Array<number>, public itemSize: number) {\n\t\tthis.name = name;\n\t\tthis.offset = 0;\n\t\tthis.shaderLocation = 0;\n\t\tthis.attributeType = AttributeType.attribute;\n\t}\n\tgetGPUAttribute(): Array<GPUAttribute> {\n\t\treturn [\n\t\t\t{\n\t\t\t\tshaderLocation: this.shaderLocation,\n\t\t\t\tformat: this.format,\n\t\t\t\toffset: this.offset\n\t\t\t}\n\t\t];\n\t}\n\tdestroy() {\n\t\tthis.value = [];\n\t}\n\tapplyMatrix3(matrix3) {\n\t\tif (this.itemSize === 2) {\n\t\t\tfor (let i = 0, l = this.value.length / this.itemSize; i < l; i++) {\n\t\t\t\tAttribute.v2.fromBufferAttribute(this, i);\n\t\t\t\tAttribute.v2.applyMatrix3(matrix3);\n\t\t\t\tthis.setXY(i, Attribute.v2.x, Attribute.v2.y);\n\t\t\t}\n\t\t} else if (this.itemSize === 3) {\n\t\t\tfor (let i = 0, l = this.value.length / this.itemSize; i < l; i++) {\n\t\t\t\tAttribute.v3.fromBufferAttribute(this, i);\n\t\t\t\tAttribute.v3.applyMatrix3(matrix3);\n\t\t\t\tthis.setXYZ(i, Attribute.v3.x, Attribute.v3.y, Attribute.v3.z);\n\t\t\t}\n\t\t}\n\t\treturn this;\n\t}\n\tapplyMatrix4(matrix4) {\n\t\tfor (let i = 0, l = this.value.length / this.itemSize; i < l; i++) {\n\t\t\tAttribute.v3.fromBufferAttribute(this, i);\n\t\t\tAttribute.v3.applyMatrix4(matrix4);\n\t\t\tthis.setXYZ(i, Attribute.v3.x, Attribute.v3.y, Attribute.v3.z);\n\t\t}\n\t\treturn this;\n\t}\n\tsetX(index, x) {\n\t\tthis.value[index * this.itemSize] = x;\n\t\treturn this;\n\t}\n\tgetX(index) {\n\t\tconst x = this.value[index * this.itemSize];\n\t\treturn x;\n\t}\n\tsetY(index, y) {\n\t\tthis.value[index * this.itemSize + 1] = y;\n\t\treturn this;\n\t}\n\tgetY(index) {\n\t\tconst y = this.value[index * this.itemSize + 1];\n\t\treturn y;\n\t}\n\tsetZ(index, z) {\n\t\tthis.value[index * this.itemSize + 2] = z;\n\t\treturn this;\n\t}\n\tgetZ(index) {\n\t\tconst z = this.value[index * this.itemSize + 2];\n\t\treturn z;\n\t}\n\tgetW(index) {\n\t\tconst w = this.value[index * this.itemSize + 3];\n\t\treturn w;\n\t}\n\tsetXY(index, x, y) {\n\t\tindex *= this.itemSize;\n\t\tthis.value[index + 0] = x;\n\t\tthis.value[index + 1] = y;\n\t\treturn this;\n\t}\n\tsetXYZ(index, x, y, z) {\n\t\tindex *= this.itemSize;\n\t\tthis.value[index + 0] = x;\n\t\tthis.value[index + 1] = y;\n\t\tthis.value[index + 2] = z;\n\t\treturn this;\n\t}\n\tsetXYZW(index, x, y, z, w) {\n\t\tindex *= this.itemSize;\n\t\tthis.value[index + 0] = x;\n\t\tthis.value[index + 1] = y;\n\t\tthis.value[index + 2] = z;\n\t\tthis.value[index + 3] = w;\n\t\treturn this;\n\t}\n}\nexport class InterleavedAttribute {\n\tpublic names: string[];\n\tpublic value: Array<number>;\n\tpublic itemSizes: number[];\n\tpublic format: string;\n\tpublic byteSize: number;\n\tpublic attributeType: AttributeType;\n\tconstructor(names: string[], value: Array<number>, itemSizes: number[]) {\n\t\tthis.names = names;\n\t\tthis.itemSizes = itemSizes;\n\t\tthis.value = value;\n\t\tthis.attributeType = AttributeType.interleavedAttribute;\n\t}\n\tgetGPUAttribute(): Array<GPUAttribute> {\n\t\tconst result = [];\n\t\tthis.itemSizes.reduce((total, current, index) => {\n\t\t\tresult.push({\n\t\t\t\tshaderLocation: index,\n\t\t\t\tformat: this.format,\n\t\t\t\toffset: total * this.byteSize\n\t\t\t});\n\t\t\treturn (total += current);\n\t\t}, 0);\n\t\treturn result;\n\t}\n\tdestroy() {\n\t\tthis.value = null;\n\t\tthis.names = null;\n\t\tthis.itemSizes = null;\n\t}\n}\nexport class Float32Attribute extends Attribute {\n\tconstructor(name: string, value: Array<number>, itemSize: number) {\n\t\tsuper(name, value, itemSize);\n\t\tconst { format, totalByteSize } = getAttributeFormat(VertexFormat.Float32, itemSize);\n\t\tthis.format = format;\n\t\tthis.attributeByteSize = totalByteSize;\n\t}\n}\nexport class InterleavedFloat32Attribute extends InterleavedAttribute {\n\tconstructor(names: string[], value: Array<number>, itemSizes: number[]) {\n\t\tsuper(names, value, itemSizes);\n\t\tthis.format = VertexFormat.Float32;\n\t\tthis.byteSize = Float32Array.BYTES_PER_ELEMENT;\n\t}\n}\nexport enum AttributeType {\n\tinterleavedAttribute = 0,\n\tattribute = 1\n}\nexport type GPUAttribute = {\n\tshaderLocation: number;\n\tformat: string;\n\toffset: number;\n};\nfunction getAttributeFormat(type: string, itemSize: number) {\n\tconst key = `${type}x${itemSize}`;\n\treturn {\n\t\t[VertexFormat.Float32]: {\n\t\t\tformat: \"float32\",\n\t\t\ttotalByteSize: Float32Array.BYTES_PER_ELEMENT * itemSize,\n\t\t\tbyteSize: Float32Array.BYTES_PER_ELEMENT\n\t\t},\n\t\t[VertexFormat.Float32x2]: {\n\t\t\tformat: \"float32x2\",\n\t\t\ttotalByteSize: Float32Array.BYTES_PER_ELEMENT * itemSize,\n\t\t\tbyteSize: Float32Array.BYTES_PER_ELEMENT\n\t\t},\n\t\t[VertexFormat.Float32x3]: {\n\t\t\tformat: \"float32x3\",\n\t\t\ttotalByteSize: Float32Array.BYTES_PER_ELEMENT * itemSize,\n\t\t\tbyteSize: Float32Array.BYTES_PER_ELEMENT\n\t\t},\n\t\t[VertexFormat.Float32x4]: {\n\t\t\tformat: \"float32x4\",\n\t\t\ttotalByteSize: Float32Array.BYTES_PER_ELEMENT * itemSize,\n\t\t\tbyteSize: Float32Array.BYTES_PER_ELEMENT\n\t\t}\n\t}[key];\n}\n","import { BindGroupCacheOptions } from \"../core/WebGPUTypes\";\r\nconst bindGroupCache = new Map();\r\nclass BindGroup {\r\n\tdevice: GPUDevice;\r\n\tgpuBindGroup: GPUBindGroup;\r\n\tlabel: string;\r\n\tindex: number;\r\n\tdirty: boolean;\r\n\toffset?: number;\r\n\t// const uniformBytes = 5 * Float32Array.BYTES_PER_ELEMENT;\r\n\t// const alignedSizeBytes = Math.ceil(uniformBytes / 256) * 256;\r\n\t// const alignedSize =alignedSizeBytes / Float32Array.BYTES_PER_ELEMENT;\r\n\talignedSize?: number;\r\n\tmaxOffset?: number;\r\n\tdynamic?: boolean;\r\n\tconstructor(options: BindGroupCacheOptions) {\r\n\t\tthis.index = options.index || 0;\r\n\t\tthis.offset = options.offset ?? 0;\r\n\t\tthis.alignedSize = options.alignedSize ?? 0;\r\n\t\tthis.maxOffset = options.maxOffset ?? 0;\r\n\t\tthis.dynamic = options.dynamic ?? false;\r\n\t\tthis.gpuBindGroup = options.device.createBindGroup({\r\n\t\t\tlabel: options.label,\r\n\t\t\tlayout: options.layout.gpuBindGroupLayout,\r\n\t\t\tentries: options.entires.map((entity) => ({\r\n\t\t\t\tbinding: entity.binding,\r\n\t\t\t\tresource: entity.resource\r\n\t\t\t}))\r\n\t\t});\r\n\t}\r\n\tbind(passEncoder: GPURenderPassEncoder) {\r\n\t\t// dynamic uniforms must bind multiple times\r\n\t\tif (this.dynamic) {\r\n\t\t\tconst dynamicOffsets = [0];\r\n\t\t\tdynamicOffsets[0] = this.offset * this.alignedSize;\r\n\t\t\tthis.offset = ++this.offset < this.maxOffset ? this.offset : 0;\r\n\t\t\tpassEncoder.setBindGroup(this.index, this.gpuBindGroup, dynamicOffsets);\r\n\t\t} else {\r\n\t\t\tpassEncoder.setBindGroup(this.index, this.gpuBindGroup);\r\n\t\t}\r\n\t}\r\n\tdestroy() {\r\n\t\tthis.gpuBindGroup = undefined;\r\n\t\tthis.device = undefined;\r\n\t}\r\n\tstatic getBindGroupFromCache(options: BindGroupCacheOptions): BindGroup {\r\n\t\tif (bindGroupCache.has(options.label)) {\r\n\t\t\treturn bindGroupCache.get(options.label);\r\n\t\t} else {\r\n\t\t\tconst bindGroup = new BindGroup(options);\r\n\t\t\tbindGroupCache.set(options.label, bindGroup);\r\n\t\t\treturn bindGroup;\r\n\t\t}\r\n\t}\r\n\tstatic removeBindGroupFromCache(bindGroup: BindGroup) {\r\n\t\tbindGroupCache.delete(bindGroup);\r\n\t}\r\n}\r\n\r\nexport default BindGroup;\r\n","import { BindGroupEntityOptions } from \"../core/WebGPUTypes\";\nexport default class BindGroupEntity {\n\tbinding: number;\n\tresource: GPUBindingResource;\n\tconstructor(options: BindGroupEntityOptions) {\n\t\tthis.binding = options.binding;\n\t\tthis.resource = options.resource;\n\t}\n\tpublic getGPUGroupEntity() {\n\t\treturn {\n\t\t\tbinding: this.binding,\n\t\t\tresource: this.resource\n\t\t};\n\t}\n}\n","import defaultValue from \"../utils/defaultValue\";\r\nimport defined from \"../utils/defined\";\r\nimport GMath from \"./Math\";\r\nimport Matrix4 from \"./Matrix4\";\r\nimport { Quaternion } from \"./Quaternion\";\r\nimport Vector3 from \"./Vector3\";\r\n/**\r\n * A 3x3 matrix, indexable as a column-major order array.\r\n * @param {Number} [column0Row0=0.0] The value for column 0, row 0.\r\n * @param {Number} [column1Row0=0.0] The value for column 1, row 0.\r\n * @param {Number} [column2Row0=0.0] The value for column 2, row 0.\r\n * @param {Number} [column0Row1=0.0] The value for column 0, row 1.\r\n * @param {Number} [column1Row1=0.0] The value for column 1, row 1.\r\n * @param {Number} [column2Row1=0.0] The value for column 2, row 1.\r\n * @param {Number} [column0Row2=0.0] The value for column 0, row 2.\r\n * @param {Number} [column1Row2=0.0] The value for column 1, row 2.\r\n * @param {Number} [column2Row2=0.0] The value for column 2, row 2.\r\n */\r\nclass Matrix3 {\r\n\tconstructor(\r\n\t\tcolumn0Row0 = 0,\r\n\t\tcolumn1Row0 = 0,\r\n\t\tcolumn2Row0 = 0,\r\n\t\tcolumn0Row1 = 0,\r\n\t\tcolumn1Row1 = 0,\r\n\t\tcolumn2Row1 = 0,\r\n\t\tcolumn0Row2 = 0,\r\n\t\tcolumn1Row2 = 0,\r\n\t\tcolumn2Row2 = 0\r\n\t) {\r\n\t\tthis[0] = column0Row0;\r\n\t\tthis[1] = column0Row1;\r\n\t\tthis[2] = column0Row2;\r\n\t\tthis[3] = column1Row0;\r\n\t\tthis[4] = column1Row1;\r\n\t\tthis[5] = column1Row2;\r\n\t\tthis[6] = column2Row0;\r\n\t\tthis[7] = column2Row1;\r\n\t\tthis[8] = column2Row2;\r\n\t}\r\n\tsetFromMatrix4(matrix: Matrix4): Matrix3 {\r\n\t\tthis[0] = matrix[0];\r\n\t\tthis[1] = matrix[1];\r\n\t\tthis[2] = matrix[2];\r\n\t\tthis[3] = matrix[4];\r\n\t\tthis[4] = matrix[5];\r\n\t\tthis[5] = matrix[2];\r\n\t\tthis[6] = matrix[8];\r\n\t\tthis[7] = matrix[9];\r\n\t\tthis[8] = matrix[10];\r\n\t\treturn this;\r\n\t}\r\n\tgetNormalMatrix(matrix4: Matrix4): Matrix3 {\r\n\t\tthis.setFromMatrix4(matrix4);\r\n\t\tMatrix3.inverse(this, this);\r\n\t\tMatrix3.transpose(this, this);\r\n\t\treturn this;\r\n\t}\r\n\r\n\tstatic clone(matrix: Matrix3 | number[], result: Matrix3): Matrix3 {\r\n\t\tif (!defined(matrix)) {\r\n\t\t\treturn undefined;\r\n\t\t}\r\n\t\tif (!defined(result)) {\r\n\t\t\treturn new Matrix3(\r\n\t\t\t\tmatrix[0],\r\n\t\t\t\tmatrix[3],\r\n\t\t\t\tmatrix[6],\r\n\t\t\t\tmatrix[1],\r\n\t\t\t\tmatrix[4],\r\n\t\t\t\tmatrix[7],\r\n\t\t\t\tmatrix[2],\r\n\t\t\t\tmatrix[5],\r\n\t\t\t\tmatrix[8]\r\n\t\t\t);\r\n\t\t}\r\n\t\tresult[0] = matrix[0];\r\n\t\tresult[1] = matrix[1];\r\n\t\tresult[2] = matrix[2];\r\n\t\tresult[3] = matrix[3];\r\n\t\tresult[4] = matrix[4];\r\n\t\tresult[5] = matrix[5];\r\n\t\tresult[6] = matrix[6];\r\n\t\tresult[7] = matrix[7];\r\n\t\tresult[8] = matrix[8];\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic fromColumnMajorArray(values: Array<number>, result?: Matrix3): Matrix3 {\r\n\t\tif (!defined(result)) {\r\n\t\t\tresult = new Matrix3();\r\n\t\t}\r\n\t\treturn Matrix3.clone(values, result);\r\n\t}\r\n\r\n\tstatic fromRowMajorArray(values: Array<number>, result?: Matrix3): Matrix3 {\r\n\t\tif (!defined(result)) {\r\n\t\t\treturn new Matrix3(\r\n\t\t\t\tvalues[0],\r\n\t\t\t\tvalues[1],\r\n\t\t\t\tvalues[2],\r\n\t\t\t\tvalues[3],\r\n\t\t\t\tvalues[4],\r\n\t\t\t\tvalues[5],\r\n\t\t\t\tvalues[6],\r\n\t\t\t\tvalues[7],\r\n\t\t\t\tvalues[8]\r\n\t\t\t);\r\n\t\t}\r\n\t\tresult[0] = values[0];\r\n\t\tresult[1] = values[3];\r\n\t\tresult[2] = values[6];\r\n\t\tresult[3] = values[1];\r\n\t\tresult[4] = values[4];\r\n\t\tresult[5] = values[7];\r\n\t\tresult[6] = values[2];\r\n\t\tresult[7] = values[5];\r\n\t\tresult[8] = values[8];\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic fromQuaternion(quaternion: Quaternion, result?: Matrix3): Matrix3 {\r\n\t\tconst x2 = quaternion.x * quaternion.x;\r\n\t\tconst xy = quaternion.x * quaternion.y;\r\n\t\tconst xz = quaternion.x * quaternion.z;\r\n\t\tconst xw = quaternion.x * quaternion.w;\r\n\t\tconst y2 = quaternion.y * quaternion.y;\r\n\t\tconst yz = quaternion.y * quaternion.z;\r\n\t\tconst yw = quaternion.y * quaternion.w;\r\n\t\tconst z2 = quaternion.z * quaternion.z;\r\n\t\tconst zw = quaternion.z * quaternion.w;\r\n\t\tconst w2 = quaternion.w * quaternion.w;\r\n\r\n\t\tconst m00 = x2 - y2 - z2 + w2;\r\n\t\tconst m01 = 2.0 * (xy - zw);\r\n\t\tconst m02 = 2.0 * (xz + yw);\r\n\r\n\t\tconst m10 = 2.0 * (xy + zw);\r\n\t\tconst m11 = -x2 + y2 - z2 + w2;\r\n\t\tconst m12 = 2.0 * (yz - xw);\r\n\r\n\t\tconst m20 = 2.0 * (xz - yw);\r\n\t\tconst m21 = 2.0 * (yz + xw);\r\n\t\tconst m22 = -x2 - y2 + z2 + w2;\r\n\r\n\t\tif (!defined(result)) {\r\n\t\t\treturn new Matrix3(m00, m01, m02, m10, m11, m12, m20, m21, m22);\r\n\t\t}\r\n\t\tresult[0] = m00;\r\n\t\tresult[1] = m10;\r\n\t\tresult[2] = m20;\r\n\t\tresult[3] = m01;\r\n\t\tresult[4] = m11;\r\n\t\tresult[5] = m21;\r\n\t\tresult[6] = m02;\r\n\t\tresult[7] = m12;\r\n\t\tresult[8] = m22;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic fromScale(scale: Vector3, result: Matrix3): Matrix3 {\r\n\t\tif (!defined(result)) {\r\n\t\t\treturn new Matrix3(scale.x, 0.0, 0.0, 0.0, scale.y, 0.0, 0.0, 0.0, scale.z);\r\n\t\t}\r\n\r\n\t\tresult[0] = scale.x;\r\n\t\tresult[1] = 0.0;\r\n\t\tresult[2] = 0.0;\r\n\t\tresult[3] = 0.0;\r\n\t\tresult[4] = scale.y;\r\n\t\tresult[5] = 0.0;\r\n\t\tresult[6] = 0.0;\r\n\t\tresult[7] = 0.0;\r\n\t\tresult[8] = scale.z;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic fromRotationX(angle: number, result: Matrix3): Matrix3 {\r\n\t\tconst cosAngle = Math.cos(angle);\r\n\t\tconst sinAngle = Math.sin(angle);\r\n\r\n\t\tif (!defined(result)) {\r\n\t\t\treturn new Matrix3(1.0, 0.0, 0.0, 0.0, cosAngle, -sinAngle, 0.0, sinAngle, cosAngle);\r\n\t\t}\r\n\r\n\t\tresult[0] = 1.0;\r\n\t\tresult[1] = 0.0;\r\n\t\tresult[2] = 0.0;\r\n\t\tresult[3] = 0.0;\r\n\t\tresult[4] = cosAngle;\r\n\t\tresult[5] = sinAngle;\r\n\t\tresult[6] = 0.0;\r\n\t\tresult[7] = -sinAngle;\r\n\t\tresult[8] = cosAngle;\r\n\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic fromRotationY(angle: number, result: Matrix3): Matrix3 {\r\n\t\tconst cosAngle = Math.cos(angle);\r\n\t\tconst sinAngle = Math.sin(angle);\r\n\r\n\t\tif (!defined(result)) {\r\n\t\t\treturn new Matrix3(cosAngle, 0.0, sinAngle, 0.0, 1.0, 0.0, -sinAngle, 0.0, cosAngle);\r\n\t\t}\r\n\r\n\t\tresult[0] = cosAngle;\r\n\t\tresult[1] = 0.0;\r\n\t\tresult[2] = -sinAngle;\r\n\t\tresult[3] = 0.0;\r\n\t\tresult[4] = 1.0;\r\n\t\tresult[5] = 0.0;\r\n\t\tresult[6] = sinAngle;\r\n\t\tresult[7] = 0.0;\r\n\t\tresult[8] = cosAngle;\r\n\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic fromRotationZstatic(angle: number, result: Matrix3): Matrix3 {\r\n\t\tconst cosAngle = Math.cos(angle);\r\n\t\tconst sinAngle = Math.sin(angle);\r\n\r\n\t\tif (!defined(result)) {\r\n\t\t\treturn new Matrix3(cosAngle, -sinAngle, 0.0, sinAngle, cosAngle, 0.0, 0.0, 0.0, 1.0);\r\n\t\t}\r\n\r\n\t\tresult[0] = cosAngle;\r\n\t\tresult[1] = sinAngle;\r\n\t\tresult[2] = 0.0;\r\n\t\tresult[3] = -sinAngle;\r\n\t\tresult[4] = cosAngle;\r\n\t\tresult[5] = 0.0;\r\n\t\tresult[6] = 0.0;\r\n\t\tresult[7] = 0.0;\r\n\t\tresult[8] = 1.0;\r\n\r\n\t\treturn result;\r\n\t}\r\n\ttoArray() {\r\n\t\tconst result = [];\r\n\t\tMatrix3.toArray(this, result);\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic toArray(matrix: Matrix3, result: number[]): number[] {\r\n\t\tif (!defined(result)) {\r\n\t\t\treturn [matrix[0], matrix[1], matrix[2], matrix[3], matrix[4], matrix[5], matrix[6], matrix[7], matrix[8]];\r\n\t\t}\r\n\t\tresult[0] = matrix[0];\r\n\t\tresult[1] = matrix[1];\r\n\t\tresult[2] = matrix[2];\r\n\t\tresult[3] = matrix[3];\r\n\t\tresult[4] = matrix[4];\r\n\t\tresult[5] = matrix[5];\r\n\t\tresult[6] = matrix[6];\r\n\t\tresult[7] = matrix[7];\r\n\t\tresult[8] = matrix[8];\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic getElementIndex(column: number, row: number): number {\r\n\t\treturn column * 3 + row;\r\n\t}\r\n\r\n\tstatic getColumn(matrix: Matrix3, index: number, result: Vector3): Vector3 {\r\n\t\tconst startIndex = index * 3;\r\n\t\tconst x = matrix[startIndex];\r\n\t\tconst y = matrix[startIndex + 1];\r\n\t\tconst z = matrix[startIndex + 2];\r\n\r\n\t\tresult.x = x;\r\n\t\tresult.y = y;\r\n\t\tresult.z = z;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic setColumn(matrix: Matrix3, index: number, cartesian: Vector3, result: Matrix3): Matrix3 {\r\n\t\tresult = Matrix3.clone(matrix, result);\r\n\t\tconst startIndex = index * 3;\r\n\t\tresult[startIndex] = cartesian.x;\r\n\t\tresult[startIndex + 1] = cartesian.y;\r\n\t\tresult[startIndex + 2] = cartesian.z;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic getRow(matrix: Matrix3, index: number, result: Vector3): Vector3 {\r\n\t\tconst x = matrix[index];\r\n\t\tconst y = matrix[index + 3];\r\n\t\tconst z = matrix[index + 6];\r\n\r\n\t\tresult.x = x;\r\n\t\tresult.y = y;\r\n\t\tresult.z = z;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic setRow(matrix: Matrix3, index: number, cartesian: Vector3, result: Matrix3): Matrix3 {\r\n\t\tresult = Matrix3.clone(matrix, result);\r\n\t\tresult[index] = cartesian.x;\r\n\t\tresult[index + 3] = cartesian.y;\r\n\t\tresult[index + 6] = cartesian.z;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic setScale(matrix: Matrix3, scale: Vector3, result: Matrix3): Matrix3 {\r\n\t\tconst existingScale = Matrix3.getScale(matrix, scaleScratch1);\r\n\t\tconst scaleRatioX = scale.x / existingScale.x;\r\n\t\tconst scaleRatioY = scale.y / existingScale.y;\r\n\t\tconst scaleRatioZ = scale.z / existingScale.z;\r\n\r\n\t\tresult[0] = matrix[0] * scaleRatioX;\r\n\t\tresult[1] = matrix[1] * scaleRatioX;\r\n\t\tresult[2] = matrix[2] * scaleRatioX;\r\n\t\tresult[3] = matrix[3] * scaleRatioY;\r\n\t\tresult[4] = matrix[4] * scaleRatioY;\r\n\t\tresult[5] = matrix[5] * scaleRatioY;\r\n\t\tresult[6] = matrix[6] * scaleRatioZ;\r\n\t\tresult[7] = matrix[7] * scaleRatioZ;\r\n\t\tresult[8] = matrix[8] * scaleRatioZ;\r\n\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic getScale(matrix: Matrix3, result: Vector3): Vector3 {\r\n\t\tresult.x = Vector3.magnitude(Vector3.fromElements(matrix[0], matrix[1], matrix[2], scratchColumn));\r\n\t\tresult.y = Vector3.magnitude(Vector3.fromElements(matrix[3], matrix[4], matrix[5], scratchColumn));\r\n\t\tresult.z = Vector3.magnitude(Vector3.fromElements(matrix[6], matrix[7], matrix[8], scratchColumn));\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic getMaximumScale(matrix: Matrix3): number {\r\n\t\tMatrix3.getScale(matrix, scaleScratch3);\r\n\t\treturn Vector3.maximumComponent(scaleScratch3);\r\n\t}\r\n\r\n\tstatic setRotation(matrix: Matrix3, rotation: Matrix3, result: Matrix3): Matrix3 {\r\n\t\tconst scale = Matrix3.getScale(matrix, scaleScratch4);\r\n\r\n\t\tresult[0] = rotation[0] * scale.x;\r\n\t\tresult[1] = rotation[1] * scale.x;\r\n\t\tresult[2] = rotation[2] * scale.x;\r\n\t\tresult[3] = rotation[3] * scale.y;\r\n\t\tresult[4] = rotation[4] * scale.y;\r\n\t\tresult[5] = rotation[5] * scale.y;\r\n\t\tresult[6] = rotation[6] * scale.z;\r\n\t\tresult[7] = rotation[7] * scale.z;\r\n\t\tresult[8] = rotation[8] * scale.z;\r\n\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic getRotation(matrix: Matrix3, result: Matrix3): Matrix3 {\r\n\t\tconst scale = Matrix3.getScale(matrix, scaleScratch5);\r\n\r\n\t\tresult[0] = matrix[0] / scale.x;\r\n\t\tresult[1] = matrix[1] / scale.x;\r\n\t\tresult[2] = matrix[2] / scale.x;\r\n\t\tresult[3] = matrix[3] / scale.y;\r\n\t\tresult[4] = matrix[4] / scale.y;\r\n\t\tresult[5] = matrix[5] / scale.y;\r\n\t\tresult[6] = matrix[6] / scale.z;\r\n\t\tresult[7] = matrix[7] / scale.z;\r\n\t\tresult[8] = matrix[8] / scale.z;\r\n\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic multiply(left: Matrix3, right: Matrix3, result: Matrix3): Matrix3 {\r\n\t\tconst column0Row0 = left[0] * right[0] + left[3] * right[1] + left[6] * right[2];\r\n\t\tconst column0Row1 = left[1] * right[0] + left[4] * right[1] + left[7] * right[2];\r\n\t\tconst column0Row2 = left[2] * right[0] + left[5] * right[1] + left[8] * right[2];\r\n\r\n\t\tconst column1Row0 = left[0] * right[3] + left[3] * right[4] + left[6] * right[5];\r\n\t\tconst column1Row1 = left[1] * right[3] + left[4] * right[4] + left[7] * right[5];\r\n\t\tconst column1Row2 = left[2] * right[3] + left[5] * right[4] + left[8] * right[5];\r\n\r\n\t\tconst column2Row0 = left[0] * right[6] + left[3] * right[7] + left[6] * right[8];\r\n\t\tconst column2Row1 = left[1] * right[6] + left[4] * right[7] + left[7] * right[8];\r\n\t\tconst column2Row2 = left[2] * right[6] + left[5] * right[7] + left[8] * right[8];\r\n\r\n\t\tresult[0] = column0Row0;\r\n\t\tresult[1] = column0Row1;\r\n\t\tresult[2] = column0Row2;\r\n\t\tresult[3] = column1Row0;\r\n\t\tresult[4] = column1Row1;\r\n\t\tresult[5] = column1Row2;\r\n\t\tresult[6] = column2Row0;\r\n\t\tresult[7] = column2Row1;\r\n\t\tresult[8] = column2Row2;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic add(left: Matrix3, right: Matrix3, result: Matrix3): Matrix3 {\r\n\t\tresult[0] = left[0] + right[0];\r\n\t\tresult[1] = left[1] + right[1];\r\n\t\tresult[2] = left[2] + right[2];\r\n\t\tresult[3] = left[3] + right[3];\r\n\t\tresult[4] = left[4] + right[4];\r\n\t\tresult[5] = left[5] + right[5];\r\n\t\tresult[6] = left[6] + right[6];\r\n\t\tresult[7] = left[7] + right[7];\r\n\t\tresult[8] = left[8] + right[8];\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic subtract(left: Matrix3, right: Matrix3, result: Matrix3) {\r\n\t\tresult[0] = left[0] - right[0];\r\n\t\tresult[1] = left[1] - right[1];\r\n\t\tresult[2] = left[2] - right[2];\r\n\t\tresult[3] = left[3] - right[3];\r\n\t\tresult[4] = left[4] - right[4];\r\n\t\tresult[5] = left[5] - right[5];\r\n\t\tresult[6] = left[6] - right[6];\r\n\t\tresult[7] = left[7] - right[7];\r\n\t\tresult[8] = left[8] - right[8];\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic multiplyByVector(matrix: Matrix3, cartesian: Vector3, result: Vector3): Vector3 {\r\n\t\tconst vX = cartesian.x;\r\n\t\tconst vY = cartesian.y;\r\n\t\tconst vZ = cartesian.z;\r\n\r\n\t\tconst x = matrix[0] * vX + matrix[3] * vY + matrix[6] * vZ;\r\n\t\tconst y = matrix[1] * vX + matrix[4] * vY + matrix[7] * vZ;\r\n\t\tconst z = matrix[2] * vX + matrix[5] * vY + matrix[8] * vZ;\r\n\r\n\t\tresult.x = x;\r\n\t\tresult.y = y;\r\n\t\tresult.z = z;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic multiplyByScalar(matrix: Matrix3, scalar: number, result: Matrix3): Matrix3 {\r\n\t\tresult[0] = matrix[0] * scalar;\r\n\t\tresult[1] = matrix[1] * scalar;\r\n\t\tresult[2] = matrix[2] * scalar;\r\n\t\tresult[3] = matrix[3] * scalar;\r\n\t\tresult[4] = matrix[4] * scalar;\r\n\t\tresult[5] = matrix[5] * scalar;\r\n\t\tresult[6] = matrix[6] * scalar;\r\n\t\tresult[7] = matrix[7] * scalar;\r\n\t\tresult[8] = matrix[8] * scalar;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic multiplyByScale(matrix: Matrix3, scale: Vector3, result: Matrix3): Matrix3 {\r\n\t\tresult[0] = matrix[0] * scale.x;\r\n\t\tresult[1] = matrix[1] * scale.x;\r\n\t\tresult[2] = matrix[2] * scale.x;\r\n\t\tresult[3] = matrix[3] * scale.y;\r\n\t\tresult[4] = matrix[4] * scale.y;\r\n\t\tresult[5] = matrix[5] * scale.y;\r\n\t\tresult[6] = matrix[6] * scale.z;\r\n\t\tresult[7] = matrix[7] * scale.z;\r\n\t\tresult[8] = matrix[8] * scale.z;\r\n\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic negate(matrix: Matrix3, result: Matrix3): Matrix3 {\r\n\t\tresult[0] = -matrix[0];\r\n\t\tresult[1] = -matrix[1];\r\n\t\tresult[2] = -matrix[2];\r\n\t\tresult[3] = -matrix[3];\r\n\t\tresult[4] = -matrix[4];\r\n\t\tresult[5] = -matrix[5];\r\n\t\tresult[6] = -matrix[6];\r\n\t\tresult[7] = -matrix[7];\r\n\t\tresult[8] = -matrix[8];\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic transpose(matrix: Matrix3, result: Matrix3): Matrix3 {\r\n\t\tconst column0Row0 = matrix[0];\r\n\t\tconst column0Row1 = matrix[3];\r\n\t\tconst column0Row2 = matrix[6];\r\n\t\tconst column1Row0 = matrix[1];\r\n\t\tconst column1Row1 = matrix[4];\r\n\t\tconst column1Row2 = matrix[7];\r\n\t\tconst column2Row0 = matrix[2];\r\n\t\tconst column2Row1 = matrix[5];\r\n\t\tconst column2Row2 = matrix[8];\r\n\r\n\t\tresult[0] = column0Row0;\r\n\t\tresult[1] = column0Row1;\r\n\t\tresult[2] = column0Row2;\r\n\t\tresult[3] = column1Row0;\r\n\t\tresult[4] = column1Row1;\r\n\t\tresult[5] = column1Row2;\r\n\t\tresult[6] = column2Row0;\r\n\t\tresult[7] = column2Row1;\r\n\t\tresult[8] = column2Row2;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic abs(matrix: Matrix3, result: Matrix3): Matrix3 {\r\n\t\tresult[0] = Math.abs(matrix[0]);\r\n\t\tresult[1] = Math.abs(matrix[1]);\r\n\t\tresult[2] = Math.abs(matrix[2]);\r\n\t\tresult[3] = Math.abs(matrix[3]);\r\n\t\tresult[4] = Math.abs(matrix[4]);\r\n\t\tresult[5] = Math.abs(matrix[5]);\r\n\t\tresult[6] = Math.abs(matrix[6]);\r\n\t\tresult[7] = Math.abs(matrix[7]);\r\n\t\tresult[8] = Math.abs(matrix[8]);\r\n\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic determinant(matrix: Matrix3): number {\r\n\t\tconst m11 = matrix[0];\r\n\t\tconst m21 = matrix[3];\r\n\t\tconst m31 = matrix[6];\r\n\t\tconst m12 = matrix[1];\r\n\t\tconst m22 = matrix[4];\r\n\t\tconst m32 = matrix[7];\r\n\t\tconst m13 = matrix[2];\r\n\t\tconst m23 = matrix[5];\r\n\t\tconst m33 = matrix[8];\r\n\r\n\t\treturn m11 * (m22 * m33 - m23 * m32) + m12 * (m23 * m31 - m21 * m33) + m13 * (m21 * m32 - m22 * m31);\r\n\t}\r\n\r\n\tstatic inverse(matrix: Matrix3, result: Matrix3): Matrix3 {\r\n\t\tconst m11 = matrix[0];\r\n\t\tconst m21 = matrix[1];\r\n\t\tconst m31 = matrix[2];\r\n\t\tconst m12 = matrix[3];\r\n\t\tconst m22 = matrix[4];\r\n\t\tconst m32 = matrix[5];\r\n\t\tconst m13 = matrix[6];\r\n\t\tconst m23 = matrix[7];\r\n\t\tconst m33 = matrix[8];\r\n\r\n\t\tconst determinant = Matrix3.determinant(matrix);\r\n\r\n\t\t// >>includeStart('debug', pragmas.debug);\r\n\t\tif (Math.abs(determinant) <= GMath.EPSILON15) {\r\n\t\t\tthrow new Error(\"matrix is not invertible\");\r\n\t\t}\r\n\t\t// >>includeEnd('debug');\r\n\r\n\t\tresult[0] = m22 * m33 - m23 * m32;\r\n\t\tresult[1] = m23 * m31 - m21 * m33;\r\n\t\tresult[2] = m21 * m32 - m22 * m31;\r\n\t\tresult[3] = m13 * m32 - m12 * m33;\r\n\t\tresult[4] = m11 * m33 - m13 * m31;\r\n\t\tresult[5] = m12 * m31 - m11 * m32;\r\n\t\tresult[6] = m12 * m23 - m13 * m22;\r\n\t\tresult[7] = m13 * m21 - m11 * m23;\r\n\t\tresult[8] = m11 * m22 - m12 * m21;\r\n\r\n\t\tconst scale = 1.0 / determinant;\r\n\t\treturn Matrix3.multiplyByScalar(result, scale, result);\r\n\t}\r\n\r\n\tstatic inverseTranspose(matrix: Matrix3, result: Matrix3) {\r\n\t\treturn Matrix3.inverse(Matrix3.transpose(matrix, scratchTransposeMatrix), result);\r\n\t}\r\n\r\n\tstatic equals(left: Matrix3, right: Matrix3): boolean {\r\n\t\treturn (\r\n\t\t\tleft === right ||\r\n\t\t\t(defined(left) &&\r\n\t\t\t\tdefined(right) &&\r\n\t\t\t\tleft[0] === right[0] &&\r\n\t\t\t\tleft[1] === right[1] &&\r\n\t\t\t\tleft[2] === right[2] &&\r\n\t\t\t\tleft[3] === right[3] &&\r\n\t\t\t\tleft[4] === right[4] &&\r\n\t\t\t\tleft[5] === right[5] &&\r\n\t\t\t\tleft[6] === right[6] &&\r\n\t\t\t\tleft[7] === right[7] &&\r\n\t\t\t\tleft[8] === right[8])\r\n\t\t);\r\n\t}\r\n\r\n\tstatic equalsEpsilon(left: Matrix3, right: Matrix3, epsilon = 0): boolean {\r\n\t\tepsilon = defaultValue(epsilon, 0);\r\n\r\n\t\treturn (\r\n\t\t\tleft === right ||\r\n\t\t\t(defined(left) &&\r\n\t\t\t\tdefined(right) &&\r\n\t\t\t\tMath.abs(left[0] - right[0]) <= epsilon &&\r\n\t\t\t\tMath.abs(left[1] - right[1]) <= epsilon &&\r\n\t\t\t\tMath.abs(left[2] - right[2]) <= epsilon &&\r\n\t\t\t\tMath.abs(left[3] - right[3]) <= epsilon &&\r\n\t\t\t\tMath.abs(left[4] - right[4]) <= epsilon &&\r\n\t\t\t\tMath.abs(left[5] - right[5]) <= epsilon &&\r\n\t\t\t\tMath.abs(left[6] - right[6]) <= epsilon &&\r\n\t\t\t\tMath.abs(left[7] - right[7]) <= epsilon &&\r\n\t\t\t\tMath.abs(left[8] - right[8]) <= epsilon)\r\n\t\t);\r\n\t}\r\n\r\n\tstatic IDENTITY = Object.freeze(new Matrix3(1.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 1.0));\r\n\r\n\tstatic ZERO = Object.freeze(new Matrix3(0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0));\r\n\r\n\tclone(result: Matrix3): Matrix3 {\r\n\t\treturn Matrix3.clone(this, result);\r\n\t}\r\n\r\n\tequals(right: Matrix3): boolean {\r\n\t\treturn Matrix3.equals(this, right);\r\n\t}\r\n\r\n\t/**\r\n\t * @private\r\n\t */\r\n\tequalsArray(matrix: Matrix3 | number[], array: number[], offset: number): boolean {\r\n\t\treturn (\r\n\t\t\tmatrix[0] === array[offset] &&\r\n\t\t\tmatrix[1] === array[offset + 1] &&\r\n\t\t\tmatrix[2] === array[offset + 2] &&\r\n\t\t\tmatrix[3] === array[offset + 3] &&\r\n\t\t\tmatrix[4] === array[offset + 4] &&\r\n\t\t\tmatrix[5] === array[offset + 5] &&\r\n\t\t\tmatrix[6] === array[offset + 6] &&\r\n\t\t\tmatrix[7] === array[offset + 7] &&\r\n\t\t\tmatrix[8] === array[offset + 8]\r\n\t\t);\r\n\t}\r\n\r\n\t/**\r\n\t * Compares this matrix to the provided matrix componentwise and returns\r\n\t * <code>true</code> if they are within the provided epsilon,\r\n\t * <code>false</code> otherwise.\r\n\t *\r\n\t * @param {Matrix3} [right] The right hand side matrix.\r\n\t * @param {Number} [epsilon=0] The epsilon to use for equality testing.\r\n\t * @returns {Boolean} <code>true</code> if they are within the provided epsilon, <code>false</code> otherwise.\r\n\t */\r\n\tequalsEpsilon(right, epsilon) {\r\n\t\treturn Matrix3.equalsEpsilon(this, right, epsilon);\r\n\t}\r\n\r\n\ttoString() {\r\n\t\treturn (\r\n\t\t\t`(${this[0]}, ${this[3]}, ${this[6]})\\n` +\r\n\t\t\t`(${this[1]}, ${this[4]}, ${this[7]})\\n` +\r\n\t\t\t`(${this[2]}, ${this[5]}, ${this[8]})`\r\n\t\t);\r\n\t}\r\n}\r\n\r\nconst scaleScratch1 = new Vector3();\r\nconst scaleScratch2 = new Vector3();\r\nconst scratchColumn = new Vector3();\r\nconst scaleScratch3 = new Vector3();\r\nconst scaleScratch4 = new Vector3();\r\nconst scaleScratch5 = new Vector3();\r\n\r\nfunction computeFrobeniusNorm(matrix) {\r\n\tlet norm = 0.0;\r\n\tfor (let i = 0; i < 9; ++i) {\r\n\t\tconst temp = matrix[i];\r\n\t\tnorm += temp * temp;\r\n\t}\r\n\r\n\treturn Math.sqrt(norm);\r\n}\r\n\r\nconst rowVal = [1, 0, 0];\r\nconst colVal = [2, 2, 1];\r\n\r\nfunction offDiagonalFrobeniusNorm(matrix) {\r\n\t// Computes the \"off-diagonal\" Frobenius norm.\r\n\t// Assumes matrix is symmetric.\r\n\r\n\tlet norm = 0.0;\r\n\tfor (let i = 0; i < 3; ++i) {\r\n\t\tconst temp = matrix[Matrix3.getElementIndex(colVal[i], rowVal[i])];\r\n\t\tnorm += 2.0 * temp * temp;\r\n\t}\r\n\r\n\treturn Math.sqrt(norm);\r\n}\r\n\r\nfunction shurDecomposition(matrix, result) {\r\n\t// This routine was created based upon Matrix Computations, 3rd ed., by Golub and Van Loan,\r\n\t// section 8.4.2 The 2by2 Symmetric Schur Decomposition.\r\n\t//\r\n\t// The routine takes a matrix, which is assumed to be symmetric, and\r\n\t// finds the largest off-diagonal term, and then creates\r\n\t// a matrix (result) which can be used to help reduce it\r\n\r\n\tconst tolerance = GMath.EPSILON15;\r\n\r\n\tlet maxDiagonal = 0.0;\r\n\tlet rotAxis = 1;\r\n\r\n\t// find pivot (rotAxis) based on max diagonal of matrix\r\n\tfor (let i = 0; i < 3; ++i) {\r\n\t\tconst temp = Math.abs(matrix[Matrix3.getElementIndex(colVal[i], rowVal[i])]);\r\n\t\tif (temp > maxDiagonal) {\r\n\t\t\trotAxis = i;\r\n\t\t\tmaxDiagonal = temp;\r\n\t\t}\r\n\t}\r\n\r\n\tlet c = 1.0;\r\n\tlet s = 0.0;\r\n\r\n\tconst p = rowVal[rotAxis];\r\n\tconst q = colVal[rotAxis];\r\n\r\n\tif (Math.abs(matrix[Matrix3.getElementIndex(q, p)]) > tolerance) {\r\n\t\tconst qq = matrix[Matrix3.getElementIndex(q, q)];\r\n\t\tconst pp = matrix[Matrix3.getElementIndex(p, p)];\r\n\t\tconst qp = matrix[Matrix3.getElementIndex(q, p)];\r\n\r\n\t\tconst tau = (qq - pp) / 2.0 / qp;\r\n\t\tlet t;\r\n\r\n\t\tif (tau < 0.0) {\r\n\t\t\tt = -1.0 / (-tau + Math.sqrt(1.0 + tau * tau));\r\n\t\t} else {\r\n\t\t\tt = 1.0 / (tau + Math.sqrt(1.0 + tau * tau));\r\n\t\t}\r\n\r\n\t\tc = 1.0 / Math.sqrt(1.0 + t * t);\r\n\t\ts = t * c;\r\n\t}\r\n\r\n\tresult = Matrix3.clone(Matrix3.IDENTITY, result);\r\n\r\n\tresult[Matrix3.getElementIndex(p, p)] = result[Matrix3.getElementIndex(q, q)] = c;\r\n\tresult[Matrix3.getElementIndex(q, p)] = s;\r\n\tresult[Matrix3.getElementIndex(p, q)] = -s;\r\n\r\n\treturn result;\r\n}\r\nconst scratchTransposeMatrix = new Matrix3();\r\nexport default Matrix3;\r\n","import { Attribute } from \"../render/Attribute\";\r\nimport defined from \"../utils/defined\";\r\nimport GMath from \"./Math\";\r\n\r\nclass Vector4 {\r\n\tpublic static ZERO = Object.freeze(new Vector4(0.0, 0.0, 0.0, 0.0));\r\n\r\n\tpublic static ONE = Object.freeze(new Vector4(1.0, 1.0, 1.0, 1.0));\r\n\r\n\tpublic static UNIT_X = Object.freeze(new Vector4(1.0, 0.0, 0.0, 0.0));\r\n\r\n\tpublic static UNIT_Y = Object.freeze(new Vector4(0.0, 1.0, 0.0, 0.0));\r\n\r\n\tpublic static UNIT_Z = Object.freeze(new Vector4(0.0, 0.0, 1.0, 0.0));\r\n\r\n\tpublic static UNIT_W = Object.freeze(new Vector4(0.0, 0.0, 0.0, 1.0));\r\n\tx: number;\r\n\ty: number;\r\n\tz: number;\r\n\tw: number;\r\n\tconstructor(x = 0, y = 0, z = 0, w = 0) {\r\n\t\tthis.x = x;\r\n\t\tthis.y = y;\r\n\t\tthis.z = z;\r\n\t\tthis.w = w;\r\n\t}\r\n\tset(x: number, y: number, z: number, w: number): void {\r\n\t\tthis.x = x;\r\n\t\tthis.y = y;\r\n\t\tthis.z = z;\r\n\t\tthis.w = w;\r\n\t}\r\n\ttoArray(): number[] {\r\n\t\treturn [this.x, this.y, this.z, this.w];\r\n\t}\r\n\r\n\tclone(result: Vector4): Vector4 {\r\n\t\treturn Vector4.clone(this, result);\r\n\t}\r\n\r\n\tequals(right: Vector4): boolean {\r\n\t\treturn Vector4.equals(this, right);\r\n\t}\r\n\r\n\tequalsEpsilon(right: Vector4, relativeEpsilon = 0, absoluteEpsilon = 0): boolean {\r\n\t\treturn Vector4.equalsEpsilon(this, right, relativeEpsilon, absoluteEpsilon);\r\n\t}\r\n\r\n\ttoString(): string {\r\n\t\treturn `(${this.x}, ${this.y}, ${this.z}, ${this.w})`;\r\n\t}\r\n\tfromBufferAttribute(attribute: Attribute, index: number): Vector4 {\r\n\t\tthis.x = attribute.getX(index);\r\n\t\tthis.y = attribute.getY(index);\r\n\t\tthis.z = attribute.getZ(index);\r\n\t\tthis.w = attribute.getW(index);\r\n\r\n\t\treturn this;\r\n\t}\r\n\r\n\tstatic fromElements(x: number, y: number, z: number, w: number, result: Vector4): Vector4 {\r\n\t\tif (!defined(result)) {\r\n\t\t\treturn new Vector4(x, y, z, w);\r\n\t\t}\r\n\r\n\t\tresult.x = x;\r\n\t\tresult.y = y;\r\n\t\tresult.z = z;\r\n\t\tresult.w = w;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic clone(cartesian: Vector4, result: Vector4): Vector4 {\r\n\t\tif (!defined(cartesian)) {\r\n\t\t\treturn undefined;\r\n\t\t}\r\n\r\n\t\tif (!defined(result)) {\r\n\t\t\treturn new Vector4(cartesian.x, cartesian.y, cartesian.z, cartesian.w);\r\n\t\t}\r\n\r\n\t\tresult.x = cartesian.x;\r\n\t\tresult.y = cartesian.y;\r\n\t\tresult.z = cartesian.z;\r\n\t\tresult.w = cartesian.w;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic maximumComponent(cartesian: Vector4): number {\r\n\t\treturn Math.max(cartesian.x, cartesian.y, cartesian.z, cartesian.w);\r\n\t}\r\n\r\n\tstatic minimumComponent(cartesian: Vector4): number {\r\n\t\treturn Math.min(cartesian.x, cartesian.y, cartesian.z, cartesian.w);\r\n\t}\r\n\r\n\tstatic minimumByComponent(first: Vector4, second: Vector4, result: Vector4): Vector4 {\r\n\t\tresult.x = Math.min(first.x, second.x);\r\n\t\tresult.y = Math.min(first.y, second.y);\r\n\t\tresult.z = Math.min(first.z, second.z);\r\n\t\tresult.w = Math.min(first.w, second.w);\r\n\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic maximumByComponent(first: Vector4, second: Vector4, result: Vector4): Vector4 {\r\n\t\tresult.x = Math.max(first.x, second.x);\r\n\t\tresult.y = Math.max(first.y, second.y);\r\n\t\tresult.z = Math.max(first.z, second.z);\r\n\t\tresult.w = Math.max(first.w, second.w);\r\n\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic clamp(value: Vector4, min: Vector4, max: Vector4, result: Vector4): Vector4 {\r\n\t\tconst x = GMath.clamp(value.x, min.x, max.x);\r\n\t\tconst y = GMath.clamp(value.y, min.y, max.y);\r\n\t\tconst z = GMath.clamp(value.z, min.z, max.z);\r\n\t\tconst w = GMath.clamp(value.w, min.w, max.w);\r\n\r\n\t\tresult.x = x;\r\n\t\tresult.y = y;\r\n\t\tresult.z = z;\r\n\t\tresult.w = w;\r\n\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic magnitudeSquared(cartesian: Vector4): number {\r\n\t\treturn (\r\n\t\t\tcartesian.x * cartesian.x +\r\n\t\t\tcartesian.y * cartesian.y +\r\n\t\t\tcartesian.z * cartesian.z +\r\n\t\t\tcartesian.w * cartesian.w\r\n\t\t);\r\n\t}\r\n\r\n\tstatic magnitude(cartesian: Vector4): number {\r\n\t\treturn Math.sqrt(Vector4.magnitudeSquared(cartesian));\r\n\t}\r\n\r\n\tstatic distance(left: Vector4, right: Vector4): number {\r\n\t\tVector4.subtract(left, right, distanceScratch);\r\n\t\treturn Vector4.magnitude(distanceScratch);\r\n\t}\r\n\r\n\tstatic distanceSquared(left: Vector4, right: Vector4): number {\r\n\t\tVector4.subtract(left, right, distanceScratch);\r\n\t\treturn Vector4.magnitudeSquared(distanceScratch);\r\n\t}\r\n\r\n\tstatic normalize(cartesian: Vector4, result: Vector4): Vector4 {\r\n\t\tconst magnitude = Vector4.magnitude(cartesian);\r\n\r\n\t\tresult.x = cartesian.x / magnitude;\r\n\t\tresult.y = cartesian.y / magnitude;\r\n\t\tresult.z = cartesian.z / magnitude;\r\n\t\tresult.w = cartesian.w / magnitude;\r\n\r\n\t\t// >>includeStart('debug', pragmas.debug);\r\n\t\tif (isNaN(result.x) || isNaN(result.y) || isNaN(result.z) || isNaN(result.w)) {\r\n\t\t\tthrow new Error(\"normalized result is not a number\");\r\n\t\t}\r\n\t\t// >>includeEnd('debug');\r\n\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic dot(left: Vector4, right: Vector4): number {\r\n\t\treturn left.x * right.x + left.y * right.y + left.z * right.z + left.w * right.w;\r\n\t}\r\n\r\n\tstatic multiplyComponents(left: Vector4, right: Vector4, result: Vector4): Vector4 {\r\n\t\tresult.x = left.x * right.x;\r\n\t\tresult.y = left.y * right.y;\r\n\t\tresult.z = left.z * right.z;\r\n\t\tresult.w = left.w * right.w;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic divideComponents(left: Vector4, right: Vector4, result: Vector4): Vector4 {\r\n\t\tresult.x = left.x / right.x;\r\n\t\tresult.y = left.y / right.y;\r\n\t\tresult.z = left.z / right.z;\r\n\t\tresult.w = left.w / right.w;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic add(left: Vector4, right: Vector4, result: Vector4): Vector4 {\r\n\t\tresult.x = left.x + right.x;\r\n\t\tresult.y = left.y + right.y;\r\n\t\tresult.z = left.z + right.z;\r\n\t\tresult.w = left.w + right.w;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic subtract(left: Vector4, right: Vector4, result: Vector4): Vector4 {\r\n\t\tresult.x = left.x - right.x;\r\n\t\tresult.y = left.y - right.y;\r\n\t\tresult.z = left.z - right.z;\r\n\t\tresult.w = left.w - right.w;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic multiplyByScalar(cartesian: Vector4, scalar: number, result: Vector4): Vector4 {\r\n\t\tresult.x = cartesian.x * scalar;\r\n\t\tresult.y = cartesian.y * scalar;\r\n\t\tresult.z = cartesian.z * scalar;\r\n\t\tresult.w = cartesian.w * scalar;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic divideByScalar(cartesian: Vector4, scalar: number, result: Vector4): Vector4 {\r\n\t\tresult.x = cartesian.x / scalar;\r\n\t\tresult.y = cartesian.y / scalar;\r\n\t\tresult.z = cartesian.z / scalar;\r\n\t\tresult.w = cartesian.w / scalar;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic negate(cartesian: Vector4, result: Vector4): Vector4 {\r\n\t\tresult.x = -cartesian.x;\r\n\t\tresult.y = -cartesian.y;\r\n\t\tresult.z = -cartesian.z;\r\n\t\tresult.w = -cartesian.w;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic abs(cartesian: Vector4, result: Vector4): Vector4 {\r\n\t\tresult.x = Math.abs(cartesian.x);\r\n\t\tresult.y = Math.abs(cartesian.y);\r\n\t\tresult.z = Math.abs(cartesian.z);\r\n\t\tresult.w = Math.abs(cartesian.w);\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic lerp(start: Vector4, end: Vector4, t: number, result: Vector4): Vector4 {\r\n\t\tVector4.multiplyByScalar(end, t, lerpScratch);\r\n\t\tresult = Vector4.multiplyByScalar(start, 1.0 - t, result);\r\n\t\treturn Vector4.add(lerpScratch, result, result);\r\n\t}\r\n\r\n\tstatic equals(left: Vector4, right: Vector4): boolean {\r\n\t\treturn (\r\n\t\t\tleft === right ||\r\n\t\t\t(defined(left) &&\r\n\t\t\t\tdefined(right) &&\r\n\t\t\t\tleft.x === right.x &&\r\n\t\t\t\tleft.y === right.y &&\r\n\t\t\t\tleft.z === right.z &&\r\n\t\t\t\tleft.w === right.w)\r\n\t\t);\r\n\t}\r\n\r\n\tstatic equalsArray(cartesian: Vector4, array: number[], offset: number): boolean {\r\n\t\treturn (\r\n\t\t\tcartesian.x === array[offset] &&\r\n\t\t\tcartesian.y === array[offset + 1] &&\r\n\t\t\tcartesian.z === array[offset + 2] &&\r\n\t\t\tcartesian.w === array[offset + 3]\r\n\t\t);\r\n\t}\r\n\r\n\tstatic equalsEpsilon(left: Vector4, right: Vector4, relativeEpsilon = 0, absoluteEpsilon = 0): boolean {\r\n\t\treturn (\r\n\t\t\tleft === right ||\r\n\t\t\t(defined(left) &&\r\n\t\t\t\tdefined(right) &&\r\n\t\t\t\tGMath.equalsEpsilon(left.x, right.x, relativeEpsilon, absoluteEpsilon) &&\r\n\t\t\t\tGMath.equalsEpsilon(left.y, right.y, relativeEpsilon, absoluteEpsilon) &&\r\n\t\t\t\tGMath.equalsEpsilon(left.z, right.z, relativeEpsilon, absoluteEpsilon) &&\r\n\t\t\t\tGMath.equalsEpsilon(left.w, right.w, relativeEpsilon, absoluteEpsilon))\r\n\t\t);\r\n\t}\r\n}\r\n\r\n// scratchU8Array and scratchF32Array are views into the same buffer\r\nconst scratchF32Array = new Float32Array(1);\r\nconst scratchU8Array = new Uint8Array(scratchF32Array.buffer);\r\n\r\nconst testU32 = new Uint32Array([0x11223344]);\r\nconst testU8 = new Uint8Array(testU32.buffer);\r\nconst littleEndian = testU8[0] === 0x44;\r\nconst distanceScratch = new Vector4();\r\nconst lerpScratch = new Vector4();\r\nconst mostOrthogonalAxisScratch = new Vector4();\r\n\r\nexport default Vector4;\r\n","import defaultValue from \"../utils/defaultValue\";\nimport defined from \"../utils/defined\";\nimport GMath from \"./Math\";\nimport Matrix3 from \"./Matrix3\";\nimport { Quaternion } from \"./Quaternion\";\nimport Vector3 from \"./Vector3\";\nimport Vector4 from \"./Vector4\";\nclass Matrix4 {\n\tpublic static IDENTITY = Object.freeze(\n\t\tnew Matrix4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0)\n\t);\n\tpublic static ZERO = Object.freeze(\n\t\tnew Matrix4(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\t);\n\t/**\n\t * A 4x4 matrix, indexable as a column-major order array.\n\t * @param {Number} [column0Row0=0.0] The value for column 0, row 0.\n\t * @param {Number} [column1Row0=0.0] The value for column 1, row 0.\n\t * @param {Number} [column2Row0=0.0] The value for column 2, row 0.\n\t * @param {Number} [column3Row0=0.0] The value for column 3, row 0.\n\t * @param {Number} [column0Row1=0.0] The value for column 0, row 1.\n\t * @param {Number} [column1Row1=0.0] The value for column 1, row 1.\n\t * @param {Number} [column2Row1=0.0] The value for column 2, row 1.\n\t * @param {Number} [column3Row1=0.0] The value for column 3, row 1.\n\t * @param {Number} [column0Row2=0.0] The value for column 0, row 2.\n\t * @param {Number} [column1Row2=0.0] The value for column 1, row 2.\n\t * @param {Number} [column2Row2=0.0] The value for column 2, row 2.\n\t * @param {Number} [column3Row2=0.0] The value for column 3, row 2.\n\t * @param {Number} [column0Row3=0.0] The value for column 0, row 3.\n\t * @param {Number} [column1Row3=0.0] The value for column 1, row 3.\n\t * @param {Number} [column2Row3=0.0] The value for column 2, row 3.\n\t * @param {Number} [column3Row3=0.0] The value for column 3, row 3.\n\t */\n\tconstructor(\n\t\tcolumn0Row0 = 0,\n\t\tcolumn1Row0 = 0,\n\t\tcolumn2Row0 = 0,\n\t\tcolumn3Row0 = 0,\n\t\tcolumn0Row1 = 0,\n\t\tcolumn1Row1 = 0,\n\t\tcolumn2Row1 = 0,\n\t\tcolumn3Row1 = 0,\n\t\tcolumn0Row2 = 0,\n\t\tcolumn1Row2 = 0,\n\t\tcolumn2Row2 = 0,\n\t\tcolumn3Row2 = 0,\n\t\tcolumn0Row3 = 0,\n\t\tcolumn1Row3 = 0,\n\t\tcolumn2Row3 = 0,\n\t\tcolumn3Row3 = 0\n\t) {\n\t\tthis[0] = column0Row0;\n\t\tthis[1] = column0Row1;\n\t\tthis[2] = column0Row2;\n\t\tthis[3] = column0Row3;\n\t\tthis[4] = column1Row0;\n\t\tthis[5] = column1Row1;\n\t\tthis[6] = column1Row2;\n\t\tthis[7] = column1Row3;\n\t\tthis[8] = column2Row0;\n\t\tthis[9] = column2Row1;\n\t\tthis[10] = column2Row2;\n\t\tthis[11] = column2Row3;\n\t\tthis[12] = column3Row0;\n\t\tthis[13] = column3Row1;\n\t\tthis[14] = column3Row2;\n\t\tthis[15] = column3Row3;\n\t}\n\t// ????\n\tclone(result: Matrix4 = new Matrix4()): Matrix4 {\n\t\treturn Matrix4.clone(this, result);\n\t}\n\tset(mat4: Matrix4) {\n\t\tMatrix4.clone(mat4, this);\n\t\treturn this;\n\t}\n\tequals(right: Matrix4): boolean {\n\t\treturn Matrix4.equals(this, right);\n\t}\n\tcompose(position: Vector3, quaternion: Quaternion, scale: Vector3): Matrix4 {\n\t\tconst te = this;\n\n\t\tconst x = quaternion.x,\n\t\t\ty = quaternion.y,\n\t\t\tz = quaternion.z,\n\t\t\tw = quaternion.w;\n\t\tconst x2 = x + x,\n\t\t\ty2 = y + y,\n\t\t\tz2 = z + z;\n\t\tconst xx = x * x2,\n\t\t\txy = x * y2,\n\t\t\txz = x * z2;\n\t\tconst yy = y * y2,\n\t\t\tyz = y * z2,\n\t\t\tzz = z * z2;\n\t\tconst wx = w * x2,\n\t\t\twy = w * y2,\n\t\t\twz = w * z2;\n\n\t\tconst sx = scale.x,\n\t\t\tsy = scale.y,\n\t\t\tsz = scale.z;\n\n\t\tte[0] = (1 - (yy + zz)) * sx;\n\t\tte[1] = (xy + wz) * sx;\n\t\tte[2] = (xz - wy) * sx;\n\t\tte[3] = 0;\n\n\t\tte[4] = (xy - wz) * sy;\n\t\tte[5] = (1 - (xx + zz)) * sy;\n\t\tte[6] = (yz + wx) * sy;\n\t\tte[7] = 0;\n\n\t\tte[8] = (xz + wy) * sz;\n\t\tte[9] = (yz - wx) * sz;\n\t\tte[10] = (1 - (xx + yy)) * sz;\n\t\tte[11] = 0;\n\n\t\tte[12] = position.x;\n\t\tte[13] = position.y;\n\t\tte[14] = position.z;\n\t\tte[15] = 1;\n\n\t\treturn this;\n\t}\n\tequalsEpsilon(right: Matrix4, epsilon = 0): boolean {\n\t\treturn Matrix4.equalsEpsilon(this, right, epsilon);\n\t}\n\tlookAt(eye: Vector3, target: Vector3, up: Vector3): Matrix4 {\n\t\tconst matrix = this;\n\t\tVector3.subtract(eye, target, z);\n\t\tif (z.length() === 0) {\n\t\t\t// eye and target are in the same position\n\t\t\tz.z = 1;\n\t\t}\n\t\tz.normalize();\n\t\tVector3.cross(up, z, x);\n\t\tif (x.length() === 0) {\n\t\t\t// up and z are parallel\n\n\t\t\tif (Math.abs(up.z) === 1) {\n\t\t\t\tz.x += 0.0001;\n\t\t\t} else {\n\t\t\t\tz.z += 0.0001;\n\t\t\t}\n\t\t\tz.normalize();\n\t\t\tVector3.cross(up, z, x);\n\t\t}\n\t\tx.normalize();\n\t\tVector3.cross(z, x, y);\n\t\tmatrix[0] = x.x;\n\t\tmatrix[4] = y.x;\n\t\tmatrix[8] = z.x;\n\t\tmatrix[1] = x.y;\n\t\tmatrix[5] = y.y;\n\t\tmatrix[9] = z.y;\n\t\tmatrix[2] = x.z;\n\t\tmatrix[6] = y.z;\n\t\tmatrix[10] = z.z;\n\n\t\treturn this;\n\t}\n\ttoString() {\n\t\treturn (\n\t\t\t`(${this[0]}, ${this[4]}, ${this[8]}, ${this[12]})\\n` +\n\t\t\t`(${this[1]}, ${this[5]}, ${this[9]}, ${this[13]})\\n` +\n\t\t\t`(${this[2]}, ${this[6]}, ${this[10]}, ${this[14]})\\n` +\n\t\t\t`(${this[3]}, ${this[7]}, ${this[11]}, ${this[15]})`\n\t\t);\n\t}\n\tstatic clone(matrix: Matrix4 | number[], result: Matrix4): Matrix4 {\n\t\tif (!defined(matrix)) {\n\t\t\treturn undefined;\n\t\t}\n\t\tif (!defined(result)) {\n\t\t\treturn new Matrix4(\n\t\t\t\tmatrix[0],\n\t\t\t\tmatrix[4],\n\t\t\t\tmatrix[8],\n\t\t\t\tmatrix[12],\n\t\t\t\tmatrix[1],\n\t\t\t\tmatrix[5],\n\t\t\t\tmatrix[9],\n\t\t\t\tmatrix[13],\n\t\t\t\tmatrix[2],\n\t\t\t\tmatrix[6],\n\t\t\t\tmatrix[10],\n\t\t\t\tmatrix[14],\n\t\t\t\tmatrix[3],\n\t\t\t\tmatrix[7],\n\t\t\t\tmatrix[11],\n\t\t\t\tmatrix[15]\n\t\t\t);\n\t\t}\n\t\tresult[0] = matrix[0];\n\t\tresult[1] = matrix[1];\n\t\tresult[2] = matrix[2];\n\t\tresult[3] = matrix[3];\n\t\tresult[4] = matrix[4];\n\t\tresult[5] = matrix[5];\n\t\tresult[6] = matrix[6];\n\t\tresult[7] = matrix[7];\n\t\tresult[8] = matrix[8];\n\t\tresult[9] = matrix[9];\n\t\tresult[10] = matrix[10];\n\t\tresult[11] = matrix[11];\n\t\tresult[12] = matrix[12];\n\t\tresult[13] = matrix[13];\n\t\tresult[14] = matrix[14];\n\t\tresult[15] = matrix[15];\n\t\treturn result;\n\t}\n\n\tstatic fromColumnMajorArray(values: number[], result: Matrix4): Matrix4 {\n\t\treturn Matrix4.clone(values, result);\n\t}\n\n\tstatic fromRowMajorArray(values: number[], result: Matrix4): Matrix4 {\n\t\tif (!defined(result)) {\n\t\t\treturn new Matrix4(\n\t\t\t\tvalues[0],\n\t\t\t\tvalues[1],\n\t\t\t\tvalues[2],\n\t\t\t\tvalues[3],\n\t\t\t\tvalues[4],\n\t\t\t\tvalues[5],\n\t\t\t\tvalues[6],\n\t\t\t\tvalues[7],\n\t\t\t\tvalues[8],\n\t\t\t\tvalues[9],\n\t\t\t\tvalues[10],\n\t\t\t\tvalues[11],\n\t\t\t\tvalues[12],\n\t\t\t\tvalues[13],\n\t\t\t\tvalues[14],\n\t\t\t\tvalues[15]\n\t\t\t);\n\t\t}\n\t\tresult[0] = values[0];\n\t\tresult[1] = values[4];\n\t\tresult[2] = values[8];\n\t\tresult[3] = values[12];\n\t\tresult[4] = values[1];\n\t\tresult[5] = values[5];\n\t\tresult[6] = values[9];\n\t\tresult[7] = values[13];\n\t\tresult[8] = values[2];\n\t\tresult[9] = values[6];\n\t\tresult[10] = values[10];\n\t\tresult[11] = values[14];\n\t\tresult[12] = values[3];\n\t\tresult[13] = values[7];\n\t\tresult[14] = values[11];\n\t\tresult[15] = values[15];\n\t\treturn result;\n\t}\n\n\tstatic fromRotationTranslation(rotation: Matrix3, translation: Vector3, result: Matrix4): Matrix4 {\n\t\ttranslation = defaultValue(translation, Vector3.ZERO);\n\n\t\tif (!defined(result)) {\n\t\t\treturn new Matrix4(\n\t\t\t\trotation[0],\n\t\t\t\trotation[3],\n\t\t\t\trotation[6],\n\t\t\t\ttranslation.x,\n\t\t\t\trotation[1],\n\t\t\t\trotation[4],\n\t\t\t\trotation[7],\n\t\t\t\ttranslation.y,\n\t\t\t\trotation[2],\n\t\t\t\trotation[5],\n\t\t\t\trotation[8],\n\t\t\t\ttranslation.z,\n\t\t\t\t0.0,\n\t\t\t\t0.0,\n\t\t\t\t0.0,\n\t\t\t\t1.0\n\t\t\t);\n\t\t}\n\n\t\tresult[0] = rotation[0];\n\t\tresult[1] = rotation[1];\n\t\tresult[2] = rotation[2];\n\t\tresult[3] = 0.0;\n\t\tresult[4] = rotation[3];\n\t\tresult[5] = rotation[4];\n\t\tresult[6] = rotation[5];\n\t\tresult[7] = 0.0;\n\t\tresult[8] = rotation[6];\n\t\tresult[9] = rotation[7];\n\t\tresult[10] = rotation[8];\n\t\tresult[11] = 0.0;\n\t\tresult[12] = translation.x;\n\t\tresult[13] = translation.y;\n\t\tresult[14] = translation.z;\n\t\tresult[15] = 1.0;\n\t\treturn result;\n\t}\n\n\tstatic fromTranslationQuaternionRotationScale(\n\t\ttranslation: Vector3,\n\t\trotation: Quaternion,\n\t\tscale: Vector3,\n\t\tresult: Matrix4\n\t): Matrix4 {\n\t\tif (!defined(result)) {\n\t\t\tresult = new Matrix4();\n\t\t}\n\n\t\tconst scaleX = scale.x;\n\t\tconst scaleY = scale.y;\n\t\tconst scaleZ = scale.z;\n\n\t\tconst x2 = rotation.x * rotation.x;\n\t\tconst xy = rotation.x * rotation.y;\n\t\tconst xz = rotation.x * rotation.z;\n\t\tconst xw = rotation.x * rotation.w;\n\t\tconst y2 = rotation.y * rotation.y;\n\t\tconst yz = rotation.y * rotation.z;\n\t\tconst yw = rotation.y * rotation.w;\n\t\tconst z2 = rotation.z * rotation.z;\n\t\tconst zw = rotation.z * rotation.w;\n\t\tconst w2 = rotation.w * rotation.w;\n\n\t\tconst m00 = x2 - y2 - z2 + w2;\n\t\tconst m01 = 2.0 * (xy - zw);\n\t\tconst m02 = 2.0 * (xz + yw);\n\n\t\tconst m10 = 2.0 * (xy + zw);\n\t\tconst m11 = -x2 + y2 - z2 + w2;\n\t\tconst m12 = 2.0 * (yz - xw);\n\n\t\tconst m20 = 2.0 * (xz - yw);\n\t\tconst m21 = 2.0 * (yz + xw);\n\t\tconst m22 = -x2 - y2 + z2 + w2;\n\n\t\tresult[0] = m00 * scaleX;\n\t\tresult[1] = m10 * scaleX;\n\t\tresult[2] = m20 * scaleX;\n\t\tresult[3] = 0.0;\n\t\tresult[4] = m01 * scaleY;\n\t\tresult[5] = m11 * scaleY;\n\t\tresult[6] = m21 * scaleY;\n\t\tresult[7] = 0.0;\n\t\tresult[8] = m02 * scaleZ;\n\t\tresult[9] = m12 * scaleZ;\n\t\tresult[10] = m22 * scaleZ;\n\t\tresult[11] = 0.0;\n\t\tresult[12] = translation.x;\n\t\tresult[13] = translation.y;\n\t\tresult[14] = translation.z;\n\t\tresult[15] = 1.0;\n\n\t\treturn result;\n\t}\n\n\tstatic fromTranslationRotationScale(\n\t\ttranslationRotationScale: {\n\t\t\ttranslation: Vector3;\n\t\t\trotation: Quaternion;\n\t\t\tscale: Vector3;\n\t\t},\n\t\tresult: Matrix4\n\t): Matrix4 {\n\t\treturn Matrix4.fromTranslationQuaternionRotationScale(\n\t\t\ttranslationRotationScale.translation,\n\t\t\ttranslationRotationScale.rotation,\n\t\t\ttranslationRotationScale.scale,\n\t\t\tresult\n\t\t);\n\t}\n\n\tstatic fromTranslation(translation: Vector3, result: Matrix4): Matrix4 {\n\t\treturn Matrix4.fromRotationTranslation(Matrix3.IDENTITY, translation, result);\n\t}\n\n\tstatic fromScale(scale: Vector3, result: Matrix4): Matrix4 {\n\t\tif (!defined(result)) {\n\t\t\treturn new Matrix4(\n\t\t\t\tscale.x,\n\t\t\t\t0.0,\n\t\t\t\t0.0,\n\t\t\t\t0.0,\n\t\t\t\t0.0,\n\t\t\t\tscale.y,\n\t\t\t\t0.0,\n\t\t\t\t0.0,\n\t\t\t\t0.0,\n\t\t\t\t0.0,\n\t\t\t\tscale.z,\n\t\t\t\t0.0,\n\t\t\t\t0.0,\n\t\t\t\t0.0,\n\t\t\t\t0.0,\n\t\t\t\t1.0\n\t\t\t);\n\t\t}\n\n\t\tresult[0] = scale.x;\n\t\tresult[1] = 0.0;\n\t\tresult[2] = 0.0;\n\t\tresult[3] = 0.0;\n\t\tresult[4] = 0.0;\n\t\tresult[5] = scale.y;\n\t\tresult[6] = 0.0;\n\t\tresult[7] = 0.0;\n\t\tresult[8] = 0.0;\n\t\tresult[9] = 0.0;\n\t\tresult[10] = scale.z;\n\t\tresult[11] = 0.0;\n\t\tresult[12] = 0.0;\n\t\tresult[13] = 0.0;\n\t\tresult[14] = 0.0;\n\t\tresult[15] = 1.0;\n\t\treturn result;\n\t}\n\n\tstatic fromRotation(rotation: Matrix3, result: Matrix4): Matrix4 {\n\t\tif (!defined(result)) {\n\t\t\tresult = new Matrix4();\n\t\t}\n\t\tresult[0] = rotation[0];\n\t\tresult[1] = rotation[1];\n\t\tresult[2] = rotation[2];\n\t\tresult[3] = 0.0;\n\n\t\tresult[4] = rotation[3];\n\t\tresult[5] = rotation[4];\n\t\tresult[6] = rotation[5];\n\t\tresult[7] = 0.0;\n\n\t\tresult[8] = rotation[6];\n\t\tresult[9] = rotation[7];\n\t\tresult[10] = rotation[8];\n\t\tresult[11] = 0.0;\n\n\t\tresult[12] = 0.0;\n\t\tresult[13] = 0.0;\n\t\tresult[14] = 0.0;\n\t\tresult[15] = 1.0;\n\n\t\treturn result;\n\t}\n\n\tstatic makePerspective(\n\t\tleft: number,\n\t\tright: number,\n\t\ttop: number,\n\t\tbottom: number,\n\t\tnear: number,\n\t\tfar: number\n\t): Matrix4 {\n\t\t// from three.js\n\t\tconst matrix = new Matrix4();\n\t\tconst x = (2 * near) / (right - left);\n\t\tconst y = (2 * near) / (top - bottom);\n\n\t\tconst a = (right + left) / (right - left);\n\t\tconst b = (top + bottom) / (top - bottom);\n\t\tconst c = -far / (far - near);\n\t\tconst d = (-far * near) / (far - near);\n\n\t\tmatrix[0] = x;\n\t\tmatrix[4] = 0;\n\t\tmatrix[8] = a;\n\t\tmatrix[12] = 0;\n\t\tmatrix[1] = 0;\n\t\tmatrix[5] = y;\n\t\tmatrix[9] = b;\n\t\tmatrix[13] = 0;\n\t\tmatrix[2] = 0;\n\t\tmatrix[6] = 0;\n\t\tmatrix[10] = c;\n\t\tmatrix[14] = d;\n\t\tmatrix[3] = 0;\n\t\tmatrix[7] = 0;\n\t\tmatrix[11] = -1;\n\t\tmatrix[15] = 0;\n\t\treturn matrix;\n\t}\n\tstatic makeOrthographic(\n\t\tleft: number,\n\t\tright: number,\n\t\ttop: number,\n\t\tbottom: number,\n\t\tnear: number,\n\t\tfar: number\n\t): Matrix4 {\n\t\tconst matrix = new Matrix4();\n\t\tconst w = 1.0 / (right - left);\n\t\tconst h = 1.0 / (top - bottom);\n\t\tconst p = 1.0 / (far - near);\n\n\t\tconst x = (right + left) * w;\n\t\tconst y = (top + bottom) * h;\n\t\tconst z = near * p;\n\n\t\tmatrix[0] = 2 * w;\n\t\tmatrix[4] = 0;\n\t\tmatrix[8] = 0;\n\t\tmatrix[12] = -x;\n\t\tmatrix[1] = 0;\n\t\tmatrix[5] = 2 * h;\n\t\tmatrix[9] = 0;\n\t\tmatrix[13] = -y;\n\t\tmatrix[2] = 0;\n\t\tmatrix[6] = 0;\n\t\tmatrix[10] = -1 * p;\n\t\tmatrix[14] = -z;\n\t\tmatrix[3] = 0;\n\t\tmatrix[7] = 0;\n\t\tmatrix[11] = 0;\n\t\tmatrix[15] = 1;\n\t\treturn matrix;\n\t}\n\ttoArray() {\n\t\tconst result = [];\n\t\tMatrix4.toArray(this, result);\n\t\treturn result;\n\t}\n\t/**\n\t * Computes an Array from the provided Matrix4 instance.\n\t * The array will be in column-major order.\n\t * @example\n\t * //create an array from an instance of Matrix4\n\t * // m = [10.0, 14.0, 18.0, 22.0]\n\t * //     [11.0, 15.0, 19.0, 23.0]\n\t * //     [12.0, 16.0, 20.0, 24.0]\n\t * //     [13.0, 17.0, 21.0, 25.0]\n\t * const a = Matrix4.toArray(m);\n\t *\n\t * // m remains the same\n\t * //creates a = [10.0, 11.0, 12.0, 13.0, 14.0, 15.0, 16.0, 17.0, 18.0, 19.0, 20.0, 21.0, 22.0, 23.0, 24.0, 25.0]\n\t */\n\tstatic toArray(matrix: Array<number> | Matrix4, result: Array<number>): Array<number> {\n\t\tif (!defined(result)) {\n\t\t\treturn [\n\t\t\t\tmatrix[0],\n\t\t\t\tmatrix[1],\n\t\t\t\tmatrix[2],\n\t\t\t\tmatrix[3],\n\t\t\t\tmatrix[4],\n\t\t\t\tmatrix[5],\n\t\t\t\tmatrix[6],\n\t\t\t\tmatrix[7],\n\t\t\t\tmatrix[8],\n\t\t\t\tmatrix[9],\n\t\t\t\tmatrix[10],\n\t\t\t\tmatrix[11],\n\t\t\t\tmatrix[12],\n\t\t\t\tmatrix[13],\n\t\t\t\tmatrix[14],\n\t\t\t\tmatrix[15]\n\t\t\t];\n\t\t}\n\t\tresult[0] = matrix[0];\n\t\tresult[1] = matrix[1];\n\t\tresult[2] = matrix[2];\n\t\tresult[3] = matrix[3];\n\t\tresult[4] = matrix[4];\n\t\tresult[5] = matrix[5];\n\t\tresult[6] = matrix[6];\n\t\tresult[7] = matrix[7];\n\t\tresult[8] = matrix[8];\n\t\tresult[9] = matrix[9];\n\t\tresult[10] = matrix[10];\n\t\tresult[11] = matrix[11];\n\t\tresult[12] = matrix[12];\n\t\tresult[13] = matrix[13];\n\t\tresult[14] = matrix[14];\n\t\tresult[15] = matrix[15];\n\t\treturn result;\n\t}\n\n\tstatic getElementIndex(column: number, row: number): number {\n\t\treturn column * 4 + row;\n\t}\n\n\tstatic getColumn(matrix: Matrix4, index: number, result: Vector4): Vector4 {\n\t\tconst startIndex = index * 4;\n\t\tconst x = matrix[startIndex];\n\t\tconst y = matrix[startIndex + 1];\n\t\tconst z = matrix[startIndex + 2];\n\t\tconst w = matrix[startIndex + 3];\n\n\t\tresult.x = x;\n\t\tresult.y = y;\n\t\tresult.z = z;\n\t\tresult.w = w;\n\t\treturn result;\n\t}\n\n\tstatic setColumn(matrix: Matrix4, index: number, cartesian: Vector4, result: Matrix4): Matrix4 {\n\t\tresult = Matrix4.clone(matrix, result);\n\t\tconst startIndex = index * 4;\n\t\tresult[startIndex] = cartesian.x;\n\t\tresult[startIndex + 1] = cartesian.y;\n\t\tresult[startIndex + 2] = cartesian.z;\n\t\tresult[startIndex + 3] = cartesian.w;\n\t\treturn result;\n\t}\n\n\tstatic getRow(matrix: Matrix4, index: number, result: Vector4): Vector4 {\n\t\tconst x = matrix[index];\n\t\tconst y = matrix[index + 4];\n\t\tconst z = matrix[index + 8];\n\t\tconst w = matrix[index + 12];\n\n\t\tresult.x = x;\n\t\tresult.y = y;\n\t\tresult.z = z;\n\t\tresult.w = w;\n\t\treturn result;\n\t}\n\n\tstatic setRow(matrix: Matrix4, index: number, cartesian: Vector4, result: Matrix4): Matrix4 {\n\t\tresult = Matrix4.clone(matrix, result);\n\t\tresult[index] = cartesian.x;\n\t\tresult[index + 4] = cartesian.y;\n\t\tresult[index + 8] = cartesian.z;\n\t\tresult[index + 12] = cartesian.w;\n\t\treturn result;\n\t}\n\n\tstatic setTranslation(matrix: Matrix4, translation: Vector3, result: Matrix4): Matrix4 {\n\t\tresult[0] = matrix[0];\n\t\tresult[1] = matrix[1];\n\t\tresult[2] = matrix[2];\n\t\tresult[3] = matrix[3];\n\n\t\tresult[4] = matrix[4];\n\t\tresult[5] = matrix[5];\n\t\tresult[6] = matrix[6];\n\t\tresult[7] = matrix[7];\n\n\t\tresult[8] = matrix[8];\n\t\tresult[9] = matrix[9];\n\t\tresult[10] = matrix[10];\n\t\tresult[11] = matrix[11];\n\n\t\tresult[12] = translation.x;\n\t\tresult[13] = translation.y;\n\t\tresult[14] = translation.z;\n\t\tresult[15] = matrix[15];\n\n\t\treturn result;\n\t}\n\n\tstatic setScale(matrix: Matrix4, scale: Vector3, result: Matrix4): Matrix4 {\n\t\tconst existingScale = Matrix4.getScale(matrix, scaleScratch1);\n\t\tconst scaleRatioX = scale.x / existingScale.x;\n\t\tconst scaleRatioY = scale.y / existingScale.y;\n\t\tconst scaleRatioZ = scale.z / existingScale.z;\n\n\t\tresult[0] = matrix[0] * scaleRatioX;\n\t\tresult[1] = matrix[1] * scaleRatioX;\n\t\tresult[2] = matrix[2] * scaleRatioX;\n\t\tresult[3] = matrix[3];\n\n\t\tresult[4] = matrix[4] * scaleRatioY;\n\t\tresult[5] = matrix[5] * scaleRatioY;\n\t\tresult[6] = matrix[6] * scaleRatioY;\n\t\tresult[7] = matrix[7];\n\n\t\tresult[8] = matrix[8] * scaleRatioZ;\n\t\tresult[9] = matrix[9] * scaleRatioZ;\n\t\tresult[10] = matrix[10] * scaleRatioZ;\n\t\tresult[11] = matrix[11];\n\n\t\tresult[12] = matrix[12];\n\t\tresult[13] = matrix[13];\n\t\tresult[14] = matrix[14];\n\t\tresult[15] = matrix[15];\n\n\t\treturn result;\n\t}\n\n\tstatic getScale(matrix: Matrix4, result: Vector3): Vector3 {\n\t\tresult.x = Vector3.magnitude(Vector3.fromElements(matrix[0], matrix[1], matrix[2], scratchColumn));\n\t\tresult.y = Vector3.magnitude(Vector3.fromElements(matrix[4], matrix[5], matrix[6], scratchColumn));\n\t\tresult.z = Vector3.magnitude(Vector3.fromElements(matrix[8], matrix[9], matrix[10], scratchColumn));\n\t\treturn result;\n\t}\n\n\tstatic getMaximumScale(matrix: Matrix4): number {\n\t\tMatrix4.getScale(matrix, scaleScratch3);\n\t\treturn Vector3.maximumComponent(scaleScratch3);\n\t}\n\n\tstatic setRotation(matrix: Matrix4, rotation: Matrix3, result: Matrix4): Matrix4 {\n\t\tconst scale = Matrix4.getScale(matrix, scaleScratch4);\n\n\t\tresult[0] = rotation[0] * scale.x;\n\t\tresult[1] = rotation[1] * scale.x;\n\t\tresult[2] = rotation[2] * scale.x;\n\t\tresult[3] = matrix[3];\n\n\t\tresult[4] = rotation[3] * scale.y;\n\t\tresult[5] = rotation[4] * scale.y;\n\t\tresult[6] = rotation[5] * scale.y;\n\t\tresult[7] = matrix[7];\n\n\t\tresult[8] = rotation[6] * scale.z;\n\t\tresult[9] = rotation[7] * scale.z;\n\t\tresult[10] = rotation[8] * scale.z;\n\t\tresult[11] = matrix[11];\n\n\t\tresult[12] = matrix[12];\n\t\tresult[13] = matrix[13];\n\t\tresult[14] = matrix[14];\n\t\tresult[15] = matrix[15];\n\n\t\treturn result;\n\t}\n\n\tstatic getRotation(matrix: Matrix4, result: Quaternion): Quaternion {\n\t\tconst scale = Matrix4.getScale(matrix, scaleScratch5);\n\n\t\tconst is1 = 1 / scale.x;\n\t\tconst is2 = 1 / scale.y;\n\t\tconst is3 = 1 / scale.z;\n\n\t\tconst sm11 = matrix[0] * is1;\n\t\tconst sm12 = matrix[1] * is2;\n\t\tconst sm13 = matrix[2] * is3;\n\t\tconst sm21 = matrix[4] * is1;\n\t\tconst sm22 = matrix[5] * is2;\n\t\tconst sm23 = matrix[6] * is3;\n\t\tconst sm31 = matrix[8] * is1;\n\t\tconst sm32 = matrix[9] * is2;\n\t\tconst sm33 = matrix[10] * is3;\n\n\t\tconst trace = sm11 + sm22 + sm33;\n\t\tlet S = 0;\n\n\t\tif (trace > 0) {\n\t\t\tS = Math.sqrt(trace + 1.0) * 2;\n\t\t\tresult.w = 0.25 * S;\n\t\t\tresult.x = (sm23 - sm32) / S;\n\t\t\tresult.y = (sm31 - sm13) / S;\n\t\t\tresult.z = (sm12 - sm21) / S;\n\t\t} else if (sm11 > sm22 && sm11 > sm33) {\n\t\t\tS = Math.sqrt(1.0 + sm11 - sm22 - sm33) * 2;\n\t\t\tresult.w = (sm23 - sm32) / S;\n\t\t\tresult.x = 0.25 * S;\n\t\t\tresult.y = (sm12 + sm21) / S;\n\t\t\tresult.z = (sm31 + sm13) / S;\n\t\t} else if (sm22 > sm33) {\n\t\t\tS = Math.sqrt(1.0 + sm22 - sm11 - sm33) * 2;\n\t\t\tresult.w = (sm31 - sm13) / S;\n\t\t\tresult.x = (sm12 + sm21) / S;\n\t\t\tresult.y = 0.25 * S;\n\t\t\tresult.z = (sm23 + sm32) / S;\n\t\t} else {\n\t\t\tS = Math.sqrt(1.0 + sm33 - sm11 - sm22) * 2;\n\t\t\tresult.w = (sm12 - sm21) / S;\n\t\t\tresult.x = (sm31 + sm13) / S;\n\t\t\tresult.y = (sm23 + sm32) / S;\n\t\t\tresult.z = 0.25 * S;\n\t\t}\n\t\treturn result;\n\t}\n\n\tstatic multiply(left: Matrix4, right: Matrix4, result: Matrix4): Matrix4 {\n\t\tconst left0 = left[0];\n\t\tconst left1 = left[1];\n\t\tconst left2 = left[2];\n\t\tconst left3 = left[3];\n\t\tconst left4 = left[4];\n\t\tconst left5 = left[5];\n\t\tconst left6 = left[6];\n\t\tconst left7 = left[7];\n\t\tconst left8 = left[8];\n\t\tconst left9 = left[9];\n\t\tconst left10 = left[10];\n\t\tconst left11 = left[11];\n\t\tconst left12 = left[12];\n\t\tconst left13 = left[13];\n\t\tconst left14 = left[14];\n\t\tconst left15 = left[15];\n\n\t\tconst right0 = right[0];\n\t\tconst right1 = right[1];\n\t\tconst right2 = right[2];\n\t\tconst right3 = right[3];\n\t\tconst right4 = right[4];\n\t\tconst right5 = right[5];\n\t\tconst right6 = right[6];\n\t\tconst right7 = right[7];\n\t\tconst right8 = right[8];\n\t\tconst right9 = right[9];\n\t\tconst right10 = right[10];\n\t\tconst right11 = right[11];\n\t\tconst right12 = right[12];\n\t\tconst right13 = right[13];\n\t\tconst right14 = right[14];\n\t\tconst right15 = right[15];\n\n\t\tconst column0Row0 = left0 * right0 + left4 * right1 + left8 * right2 + left12 * right3;\n\t\tconst column0Row1 = left1 * right0 + left5 * right1 + left9 * right2 + left13 * right3;\n\t\tconst column0Row2 = left2 * right0 + left6 * right1 + left10 * right2 + left14 * right3;\n\t\tconst column0Row3 = left3 * right0 + left7 * right1 + left11 * right2 + left15 * right3;\n\n\t\tconst column1Row0 = left0 * right4 + left4 * right5 + left8 * right6 + left12 * right7;\n\t\tconst column1Row1 = left1 * right4 + left5 * right5 + left9 * right6 + left13 * right7;\n\t\tconst column1Row2 = left2 * right4 + left6 * right5 + left10 * right6 + left14 * right7;\n\t\tconst column1Row3 = left3 * right4 + left7 * right5 + left11 * right6 + left15 * right7;\n\n\t\tconst column2Row0 = left0 * right8 + left4 * right9 + left8 * right10 + left12 * right11;\n\t\tconst column2Row1 = left1 * right8 + left5 * right9 + left9 * right10 + left13 * right11;\n\t\tconst column2Row2 = left2 * right8 + left6 * right9 + left10 * right10 + left14 * right11;\n\t\tconst column2Row3 = left3 * right8 + left7 * right9 + left11 * right10 + left15 * right11;\n\n\t\tconst column3Row0 = left0 * right12 + left4 * right13 + left8 * right14 + left12 * right15;\n\t\tconst column3Row1 = left1 * right12 + left5 * right13 + left9 * right14 + left13 * right15;\n\t\tconst column3Row2 = left2 * right12 + left6 * right13 + left10 * right14 + left14 * right15;\n\t\tconst column3Row3 = left3 * right12 + left7 * right13 + left11 * right14 + left15 * right15;\n\n\t\tresult[0] = column0Row0;\n\t\tresult[1] = column0Row1;\n\t\tresult[2] = column0Row2;\n\t\tresult[3] = column0Row3;\n\t\tresult[4] = column1Row0;\n\t\tresult[5] = column1Row1;\n\t\tresult[6] = column1Row2;\n\t\tresult[7] = column1Row3;\n\t\tresult[8] = column2Row0;\n\t\tresult[9] = column2Row1;\n\t\tresult[10] = column2Row2;\n\t\tresult[11] = column2Row3;\n\t\tresult[12] = column3Row0;\n\t\tresult[13] = column3Row1;\n\t\tresult[14] = column3Row2;\n\t\tresult[15] = column3Row3;\n\t\treturn result;\n\t}\n\n\tstatic add(left: Matrix4, right: Matrix4, result: Matrix4): Matrix4 {\n\t\tresult[0] = left[0] + right[0];\n\t\tresult[1] = left[1] + right[1];\n\t\tresult[2] = left[2] + right[2];\n\t\tresult[3] = left[3] + right[3];\n\t\tresult[4] = left[4] + right[4];\n\t\tresult[5] = left[5] + right[5];\n\t\tresult[6] = left[6] + right[6];\n\t\tresult[7] = left[7] + right[7];\n\t\tresult[8] = left[8] + right[8];\n\t\tresult[9] = left[9] + right[9];\n\t\tresult[10] = left[10] + right[10];\n\t\tresult[11] = left[11] + right[11];\n\t\tresult[12] = left[12] + right[12];\n\t\tresult[13] = left[13] + right[13];\n\t\tresult[14] = left[14] + right[14];\n\t\tresult[15] = left[15] + right[15];\n\t\treturn result;\n\t}\n\n\tstatic subtract(left: Matrix4, right: Matrix4, result: Matrix4) {\n\t\tresult[0] = left[0] - right[0];\n\t\tresult[1] = left[1] - right[1];\n\t\tresult[2] = left[2] - right[2];\n\t\tresult[3] = left[3] - right[3];\n\t\tresult[4] = left[4] - right[4];\n\t\tresult[5] = left[5] - right[5];\n\t\tresult[6] = left[6] - right[6];\n\t\tresult[7] = left[7] - right[7];\n\t\tresult[8] = left[8] - right[8];\n\t\tresult[9] = left[9] - right[9];\n\t\tresult[10] = left[10] - right[10];\n\t\tresult[11] = left[11] - right[11];\n\t\tresult[12] = left[12] - right[12];\n\t\tresult[13] = left[13] - right[13];\n\t\tresult[14] = left[14] - right[14];\n\t\tresult[15] = left[15] - right[15];\n\t\treturn result;\n\t}\n\n\tstatic multiplyTransformation(left: Matrix4, right: Matrix4, result: Matrix4): Matrix4 {\n\t\tconst left0 = left[0];\n\t\tconst left1 = left[1];\n\t\tconst left2 = left[2];\n\t\tconst left4 = left[4];\n\t\tconst left5 = left[5];\n\t\tconst left6 = left[6];\n\t\tconst left8 = left[8];\n\t\tconst left9 = left[9];\n\t\tconst left10 = left[10];\n\t\tconst left12 = left[12];\n\t\tconst left13 = left[13];\n\t\tconst left14 = left[14];\n\n\t\tconst right0 = right[0];\n\t\tconst right1 = right[1];\n\t\tconst right2 = right[2];\n\t\tconst right4 = right[4];\n\t\tconst right5 = right[5];\n\t\tconst right6 = right[6];\n\t\tconst right8 = right[8];\n\t\tconst right9 = right[9];\n\t\tconst right10 = right[10];\n\t\tconst right12 = right[12];\n\t\tconst right13 = right[13];\n\t\tconst right14 = right[14];\n\n\t\tconst column0Row0 = left0 * right0 + left4 * right1 + left8 * right2;\n\t\tconst column0Row1 = left1 * right0 + left5 * right1 + left9 * right2;\n\t\tconst column0Row2 = left2 * right0 + left6 * right1 + left10 * right2;\n\n\t\tconst column1Row0 = left0 * right4 + left4 * right5 + left8 * right6;\n\t\tconst column1Row1 = left1 * right4 + left5 * right5 + left9 * right6;\n\t\tconst column1Row2 = left2 * right4 + left6 * right5 + left10 * right6;\n\n\t\tconst column2Row0 = left0 * right8 + left4 * right9 + left8 * right10;\n\t\tconst column2Row1 = left1 * right8 + left5 * right9 + left9 * right10;\n\t\tconst column2Row2 = left2 * right8 + left6 * right9 + left10 * right10;\n\n\t\tconst column3Row0 = left0 * right12 + left4 * right13 + left8 * right14 + left12;\n\t\tconst column3Row1 = left1 * right12 + left5 * right13 + left9 * right14 + left13;\n\t\tconst column3Row2 = left2 * right12 + left6 * right13 + left10 * right14 + left14;\n\n\t\tresult[0] = column0Row0;\n\t\tresult[1] = column0Row1;\n\t\tresult[2] = column0Row2;\n\t\tresult[3] = 0.0;\n\t\tresult[4] = column1Row0;\n\t\tresult[5] = column1Row1;\n\t\tresult[6] = column1Row2;\n\t\tresult[7] = 0.0;\n\t\tresult[8] = column2Row0;\n\t\tresult[9] = column2Row1;\n\t\tresult[10] = column2Row2;\n\t\tresult[11] = 0.0;\n\t\tresult[12] = column3Row0;\n\t\tresult[13] = column3Row1;\n\t\tresult[14] = column3Row2;\n\t\tresult[15] = 1.0;\n\t\treturn result;\n\t}\n\n\tstatic multiplyByMatrix3(matrix: Matrix4, rotation: Matrix3, result: Matrix4): Matrix4 {\n\t\tconst left0 = matrix[0];\n\t\tconst left1 = matrix[1];\n\t\tconst left2 = matrix[2];\n\t\tconst left4 = matrix[4];\n\t\tconst left5 = matrix[5];\n\t\tconst left6 = matrix[6];\n\t\tconst left8 = matrix[8];\n\t\tconst left9 = matrix[9];\n\t\tconst left10 = matrix[10];\n\n\t\tconst right0 = rotation[0];\n\t\tconst right1 = rotation[1];\n\t\tconst right2 = rotation[2];\n\t\tconst right4 = rotation[3];\n\t\tconst right5 = rotation[4];\n\t\tconst right6 = rotation[5];\n\t\tconst right8 = rotation[6];\n\t\tconst right9 = rotation[7];\n\t\tconst right10 = rotation[8];\n\n\t\tconst column0Row0 = left0 * right0 + left4 * right1 + left8 * right2;\n\t\tconst column0Row1 = left1 * right0 + left5 * right1 + left9 * right2;\n\t\tconst column0Row2 = left2 * right0 + left6 * right1 + left10 * right2;\n\n\t\tconst column1Row0 = left0 * right4 + left4 * right5 + left8 * right6;\n\t\tconst column1Row1 = left1 * right4 + left5 * right5 + left9 * right6;\n\t\tconst column1Row2 = left2 * right4 + left6 * right5 + left10 * right6;\n\n\t\tconst column2Row0 = left0 * right8 + left4 * right9 + left8 * right10;\n\t\tconst column2Row1 = left1 * right8 + left5 * right9 + left9 * right10;\n\t\tconst column2Row2 = left2 * right8 + left6 * right9 + left10 * right10;\n\n\t\tresult[0] = column0Row0;\n\t\tresult[1] = column0Row1;\n\t\tresult[2] = column0Row2;\n\t\tresult[3] = 0.0;\n\t\tresult[4] = column1Row0;\n\t\tresult[5] = column1Row1;\n\t\tresult[6] = column1Row2;\n\t\tresult[7] = 0.0;\n\t\tresult[8] = column2Row0;\n\t\tresult[9] = column2Row1;\n\t\tresult[10] = column2Row2;\n\t\tresult[11] = 0.0;\n\t\tresult[12] = matrix[12];\n\t\tresult[13] = matrix[13];\n\t\tresult[14] = matrix[14];\n\t\tresult[15] = matrix[15];\n\t\treturn result;\n\t}\n\n\tstatic multiplyByTranslation(matrix: Matrix4, translation: Vector3, result: Matrix4): Matrix4 {\n\t\tconst x = translation.x;\n\t\tconst y = translation.y;\n\t\tconst z = translation.z;\n\n\t\tconst tx = x * matrix[0] + y * matrix[4] + z * matrix[8] + matrix[12];\n\t\tconst ty = x * matrix[1] + y * matrix[5] + z * matrix[9] + matrix[13];\n\t\tconst tz = x * matrix[2] + y * matrix[6] + z * matrix[10] + matrix[14];\n\n\t\tresult[0] = matrix[0];\n\t\tresult[1] = matrix[1];\n\t\tresult[2] = matrix[2];\n\t\tresult[3] = matrix[3];\n\t\tresult[4] = matrix[4];\n\t\tresult[5] = matrix[5];\n\t\tresult[6] = matrix[6];\n\t\tresult[7] = matrix[7];\n\t\tresult[8] = matrix[8];\n\t\tresult[9] = matrix[9];\n\t\tresult[10] = matrix[10];\n\t\tresult[11] = matrix[11];\n\t\tresult[12] = tx;\n\t\tresult[13] = ty;\n\t\tresult[14] = tz;\n\t\tresult[15] = matrix[15];\n\t\treturn result;\n\t}\n\n\tstatic multiplyByScale(matrix: Matrix4, scale: Vector3, result: Matrix4): Matrix4 {\n\t\tconst scaleX = scale.x;\n\t\tconst scaleY = scale.y;\n\t\tconst scaleZ = scale.z;\n\n\t\t// Faster than Vector3.equals\n\t\tif (scaleX === 1.0 && scaleY === 1.0 && scaleZ === 1.0) {\n\t\t\treturn Matrix4.clone(matrix, result);\n\t\t}\n\n\t\tresult[0] = scaleX * matrix[0];\n\t\tresult[1] = scaleX * matrix[1];\n\t\tresult[2] = scaleX * matrix[2];\n\t\tresult[3] = matrix[3];\n\n\t\tresult[4] = scaleY * matrix[4];\n\t\tresult[5] = scaleY * matrix[5];\n\t\tresult[6] = scaleY * matrix[6];\n\t\tresult[7] = matrix[7];\n\n\t\tresult[8] = scaleZ * matrix[8];\n\t\tresult[9] = scaleZ * matrix[9];\n\t\tresult[10] = scaleZ * matrix[10];\n\t\tresult[11] = matrix[11];\n\n\t\tresult[12] = matrix[12];\n\t\tresult[13] = matrix[13];\n\t\tresult[14] = matrix[14];\n\t\tresult[15] = matrix[15];\n\n\t\treturn result;\n\t}\n\n\tstatic multiplyByUniformScale(matrix: Matrix4, scale: number, result: Matrix4): Matrix4 {\n\t\tresult[0] = matrix[0] * scale;\n\t\tresult[1] = matrix[1] * scale;\n\t\tresult[2] = matrix[2] * scale;\n\t\tresult[3] = matrix[3];\n\n\t\tresult[4] = matrix[4] * scale;\n\t\tresult[5] = matrix[5] * scale;\n\t\tresult[6] = matrix[6] * scale;\n\t\tresult[7] = matrix[7];\n\n\t\tresult[8] = matrix[8] * scale;\n\t\tresult[9] = matrix[9] * scale;\n\t\tresult[10] = matrix[10] * scale;\n\t\tresult[11] = matrix[11];\n\n\t\tresult[12] = matrix[12];\n\t\tresult[13] = matrix[13];\n\t\tresult[14] = matrix[14];\n\t\tresult[15] = matrix[15];\n\n\t\treturn result;\n\t}\n\n\tstatic multiplyByVector(matrix: Matrix4, cartesian: Vector4, result: Vector4): Vector4 {\n\t\tconst vX = cartesian.x;\n\t\tconst vY = cartesian.y;\n\t\tconst vZ = cartesian.z;\n\t\tconst vW = cartesian.w;\n\n\t\tconst x = matrix[0] * vX + matrix[4] * vY + matrix[8] * vZ + matrix[12] * vW;\n\t\tconst y = matrix[1] * vX + matrix[5] * vY + matrix[9] * vZ + matrix[13] * vW;\n\t\tconst z = matrix[2] * vX + matrix[6] * vY + matrix[10] * vZ + matrix[14] * vW;\n\t\tconst w = matrix[3] * vX + matrix[7] * vY + matrix[11] * vZ + matrix[15] * vW;\n\n\t\tresult.x = x;\n\t\tresult.y = y;\n\t\tresult.z = z;\n\t\tresult.w = w;\n\t\treturn result;\n\t}\n\n\tstatic multiplyByPointAsVector(matrix: Matrix4, cartesian: Vector3, result: Vector3): Vector3 {\n\t\tconst vX = cartesian.x;\n\t\tconst vY = cartesian.y;\n\t\tconst vZ = cartesian.z;\n\n\t\tconst x = matrix[0] * vX + matrix[4] * vY + matrix[8] * vZ;\n\t\tconst y = matrix[1] * vX + matrix[5] * vY + matrix[9] * vZ;\n\t\tconst z = matrix[2] * vX + matrix[6] * vY + matrix[10] * vZ;\n\n\t\tresult.x = x;\n\t\tresult.y = y;\n\t\tresult.z = z;\n\t\treturn result;\n\t}\n\n\tstatic multiplyByPoint(matrix: Matrix4, cartesian: Vector3, result: Vector3): Vector3 {\n\t\tconst vX = cartesian.x;\n\t\tconst vY = cartesian.y;\n\t\tconst vZ = cartesian.z;\n\n\t\tconst x = matrix[0] * vX + matrix[4] * vY + matrix[8] * vZ + matrix[12];\n\t\tconst y = matrix[1] * vX + matrix[5] * vY + matrix[9] * vZ + matrix[13];\n\t\tconst z = matrix[2] * vX + matrix[6] * vY + matrix[10] * vZ + matrix[14];\n\n\t\tresult.x = x;\n\t\tresult.y = y;\n\t\tresult.z = z;\n\t\treturn result;\n\t}\n\n\tstatic multiplyByScalar(matrix: Matrix4, scalar: number, result: Matrix4): Matrix4 {\n\t\tresult[0] = matrix[0] * scalar;\n\t\tresult[1] = matrix[1] * scalar;\n\t\tresult[2] = matrix[2] * scalar;\n\t\tresult[3] = matrix[3] * scalar;\n\t\tresult[4] = matrix[4] * scalar;\n\t\tresult[5] = matrix[5] * scalar;\n\t\tresult[6] = matrix[6] * scalar;\n\t\tresult[7] = matrix[7] * scalar;\n\t\tresult[8] = matrix[8] * scalar;\n\t\tresult[9] = matrix[9] * scalar;\n\t\tresult[10] = matrix[10] * scalar;\n\t\tresult[11] = matrix[11] * scalar;\n\t\tresult[12] = matrix[12] * scalar;\n\t\tresult[13] = matrix[13] * scalar;\n\t\tresult[14] = matrix[14] * scalar;\n\t\tresult[15] = matrix[15] * scalar;\n\t\treturn result;\n\t}\n\n\tstatic negate(matrix: Matrix4, result: Matrix4): Matrix4 {\n\t\tresult[0] = -matrix[0];\n\t\tresult[1] = -matrix[1];\n\t\tresult[2] = -matrix[2];\n\t\tresult[3] = -matrix[3];\n\t\tresult[4] = -matrix[4];\n\t\tresult[5] = -matrix[5];\n\t\tresult[6] = -matrix[6];\n\t\tresult[7] = -matrix[7];\n\t\tresult[8] = -matrix[8];\n\t\tresult[9] = -matrix[9];\n\t\tresult[10] = -matrix[10];\n\t\tresult[11] = -matrix[11];\n\t\tresult[12] = -matrix[12];\n\t\tresult[13] = -matrix[13];\n\t\tresult[14] = -matrix[14];\n\t\tresult[15] = -matrix[15];\n\t\treturn result;\n\t}\n\n\tstatic transpose(matrix: Matrix4, result: Matrix4): Matrix4 {\n\t\tconst matrix1 = matrix[1];\n\t\tconst matrix2 = matrix[2];\n\t\tconst matrix3 = matrix[3];\n\t\tconst matrix6 = matrix[6];\n\t\tconst matrix7 = matrix[7];\n\t\tconst matrix11 = matrix[11];\n\n\t\tresult[0] = matrix[0];\n\t\tresult[1] = matrix[4];\n\t\tresult[2] = matrix[8];\n\t\tresult[3] = matrix[12];\n\t\tresult[4] = matrix1;\n\t\tresult[5] = matrix[5];\n\t\tresult[6] = matrix[9];\n\t\tresult[7] = matrix[13];\n\t\tresult[8] = matrix2;\n\t\tresult[9] = matrix6;\n\t\tresult[10] = matrix[10];\n\t\tresult[11] = matrix[14];\n\t\tresult[12] = matrix3;\n\t\tresult[13] = matrix7;\n\t\tresult[14] = matrix11;\n\t\tresult[15] = matrix[15];\n\t\treturn result;\n\t}\n\n\tstatic abs(matrix: Matrix4, result: Matrix4) {\n\t\tresult[0] = Math.abs(matrix[0]);\n\t\tresult[1] = Math.abs(matrix[1]);\n\t\tresult[2] = Math.abs(matrix[2]);\n\t\tresult[3] = Math.abs(matrix[3]);\n\t\tresult[4] = Math.abs(matrix[4]);\n\t\tresult[5] = Math.abs(matrix[5]);\n\t\tresult[6] = Math.abs(matrix[6]);\n\t\tresult[7] = Math.abs(matrix[7]);\n\t\tresult[8] = Math.abs(matrix[8]);\n\t\tresult[9] = Math.abs(matrix[9]);\n\t\tresult[10] = Math.abs(matrix[10]);\n\t\tresult[11] = Math.abs(matrix[11]);\n\t\tresult[12] = Math.abs(matrix[12]);\n\t\tresult[13] = Math.abs(matrix[13]);\n\t\tresult[14] = Math.abs(matrix[14]);\n\t\tresult[15] = Math.abs(matrix[15]);\n\n\t\treturn result;\n\t}\n\n\tstatic equals(left: Matrix4, right: Matrix4): boolean {\n\t\t// Given that most matrices will be transformation matrices, the elements\n\t\t// are tested in order such that the test is likely to fail as early\n\t\t// as possible.  I _think_ this is just as friendly to the L1 cache\n\t\t// as testing in index order.  It is certainty faster in practice.\n\t\treturn (\n\t\t\tleft === right ||\n\t\t\t(defined(left) &&\n\t\t\t\tdefined(right) &&\n\t\t\t\t// Translation\n\t\t\t\tleft[12] === right[12] &&\n\t\t\t\tleft[13] === right[13] &&\n\t\t\t\tleft[14] === right[14] &&\n\t\t\t\t// Rotation/scale\n\t\t\t\tleft[0] === right[0] &&\n\t\t\t\tleft[1] === right[1] &&\n\t\t\t\tleft[2] === right[2] &&\n\t\t\t\tleft[4] === right[4] &&\n\t\t\t\tleft[5] === right[5] &&\n\t\t\t\tleft[6] === right[6] &&\n\t\t\t\tleft[8] === right[8] &&\n\t\t\t\tleft[9] === right[9] &&\n\t\t\t\tleft[10] === right[10] &&\n\t\t\t\t// Bottom row\n\t\t\t\tleft[3] === right[3] &&\n\t\t\t\tleft[7] === right[7] &&\n\t\t\t\tleft[11] === right[11] &&\n\t\t\t\tleft[15] === right[15])\n\t\t);\n\t}\n\n\tstatic equalsEpsilon(left: Matrix4, right: Matrix4, epsilon: number): boolean {\n\t\tepsilon = defaultValue(epsilon, 0);\n\n\t\treturn (\n\t\t\tleft === right ||\n\t\t\t(defined(left) &&\n\t\t\t\tdefined(right) &&\n\t\t\t\tMath.abs(left[0] - right[0]) <= epsilon &&\n\t\t\t\tMath.abs(left[1] - right[1]) <= epsilon &&\n\t\t\t\tMath.abs(left[2] - right[2]) <= epsilon &&\n\t\t\t\tMath.abs(left[3] - right[3]) <= epsilon &&\n\t\t\t\tMath.abs(left[4] - right[4]) <= epsilon &&\n\t\t\t\tMath.abs(left[5] - right[5]) <= epsilon &&\n\t\t\t\tMath.abs(left[6] - right[6]) <= epsilon &&\n\t\t\t\tMath.abs(left[7] - right[7]) <= epsilon &&\n\t\t\t\tMath.abs(left[8] - right[8]) <= epsilon &&\n\t\t\t\tMath.abs(left[9] - right[9]) <= epsilon &&\n\t\t\t\tMath.abs(left[10] - right[10]) <= epsilon &&\n\t\t\t\tMath.abs(left[11] - right[11]) <= epsilon &&\n\t\t\t\tMath.abs(left[12] - right[12]) <= epsilon &&\n\t\t\t\tMath.abs(left[13] - right[13]) <= epsilon &&\n\t\t\t\tMath.abs(left[14] - right[14]) <= epsilon &&\n\t\t\t\tMath.abs(left[15] - right[15]) <= epsilon)\n\t\t);\n\t}\n\n\tstatic getTranslation(matrix: Matrix4, result: Vector3): Vector3 {\n\t\tresult.x = matrix[12];\n\t\tresult.y = matrix[13];\n\t\tresult.z = matrix[14];\n\t\treturn result;\n\t}\n\n\tstatic getMatrix3(matrix: Matrix4, result: Matrix3): Matrix3 {\n\t\tresult[0] = matrix[0];\n\t\tresult[1] = matrix[1];\n\t\tresult[2] = matrix[2];\n\t\tresult[3] = matrix[4];\n\t\tresult[4] = matrix[5];\n\t\tresult[5] = matrix[6];\n\t\tresult[6] = matrix[8];\n\t\tresult[7] = matrix[9];\n\t\tresult[8] = matrix[10];\n\t\treturn result;\n\t}\n\n\tstatic inverse(matrix: Matrix4, result: Matrix4) {\n\t\t//\n\t\t// Ported from:\n\t\t//   ftp://download.intel.com/design/PentiumIII/sml/24504301.pdf\n\t\t//\n\t\tconst src0 = matrix[0];\n\t\tconst src1 = matrix[4];\n\t\tconst src2 = matrix[8];\n\t\tconst src3 = matrix[12];\n\t\tconst src4 = matrix[1];\n\t\tconst src5 = matrix[5];\n\t\tconst src6 = matrix[9];\n\t\tconst src7 = matrix[13];\n\t\tconst src8 = matrix[2];\n\t\tconst src9 = matrix[6];\n\t\tconst src10 = matrix[10];\n\t\tconst src11 = matrix[14];\n\t\tconst src12 = matrix[3];\n\t\tconst src13 = matrix[7];\n\t\tconst src14 = matrix[11];\n\t\tconst src15 = matrix[15];\n\n\t\t// calculate pairs for first 8 elements (cofactors)\n\t\tlet tmp0 = src10 * src15;\n\t\tlet tmp1 = src11 * src14;\n\t\tlet tmp2 = src9 * src15;\n\t\tlet tmp3 = src11 * src13;\n\t\tlet tmp4 = src9 * src14;\n\t\tlet tmp5 = src10 * src13;\n\t\tlet tmp6 = src8 * src15;\n\t\tlet tmp7 = src11 * src12;\n\t\tlet tmp8 = src8 * src14;\n\t\tlet tmp9 = src10 * src12;\n\t\tlet tmp10 = src8 * src13;\n\t\tlet tmp11 = src9 * src12;\n\n\t\t// calculate first 8 elements (cofactors)\n\t\tconst dst0 = tmp0 * src5 + tmp3 * src6 + tmp4 * src7 - (tmp1 * src5 + tmp2 * src6 + tmp5 * src7);\n\t\tconst dst1 = tmp1 * src4 + tmp6 * src6 + tmp9 * src7 - (tmp0 * src4 + tmp7 * src6 + tmp8 * src7);\n\t\tconst dst2 = tmp2 * src4 + tmp7 * src5 + tmp10 * src7 - (tmp3 * src4 + tmp6 * src5 + tmp11 * src7);\n\t\tconst dst3 = tmp5 * src4 + tmp8 * src5 + tmp11 * src6 - (tmp4 * src4 + tmp9 * src5 + tmp10 * src6);\n\t\tconst dst4 = tmp1 * src1 + tmp2 * src2 + tmp5 * src3 - (tmp0 * src1 + tmp3 * src2 + tmp4 * src3);\n\t\tconst dst5 = tmp0 * src0 + tmp7 * src2 + tmp8 * src3 - (tmp1 * src0 + tmp6 * src2 + tmp9 * src3);\n\t\tconst dst6 = tmp3 * src0 + tmp6 * src1 + tmp11 * src3 - (tmp2 * src0 + tmp7 * src1 + tmp10 * src3);\n\t\tconst dst7 = tmp4 * src0 + tmp9 * src1 + tmp10 * src2 - (tmp5 * src0 + tmp8 * src1 + tmp11 * src2);\n\n\t\t// calculate pairs for second 8 elements (cofactors)\n\t\ttmp0 = src2 * src7;\n\t\ttmp1 = src3 * src6;\n\t\ttmp2 = src1 * src7;\n\t\ttmp3 = src3 * src5;\n\t\ttmp4 = src1 * src6;\n\t\ttmp5 = src2 * src5;\n\t\ttmp6 = src0 * src7;\n\t\ttmp7 = src3 * src4;\n\t\ttmp8 = src0 * src6;\n\t\ttmp9 = src2 * src4;\n\t\ttmp10 = src0 * src5;\n\t\ttmp11 = src1 * src4;\n\n\t\t// calculate second 8 elements (cofactors)\n\t\tconst dst8 = tmp0 * src13 + tmp3 * src14 + tmp4 * src15 - (tmp1 * src13 + tmp2 * src14 + tmp5 * src15);\n\t\tconst dst9 = tmp1 * src12 + tmp6 * src14 + tmp9 * src15 - (tmp0 * src12 + tmp7 * src14 + tmp8 * src15);\n\t\tconst dst10 = tmp2 * src12 + tmp7 * src13 + tmp10 * src15 - (tmp3 * src12 + tmp6 * src13 + tmp11 * src15);\n\t\tconst dst11 = tmp5 * src12 + tmp8 * src13 + tmp11 * src14 - (tmp4 * src12 + tmp9 * src13 + tmp10 * src14);\n\t\tconst dst12 = tmp2 * src10 + tmp5 * src11 + tmp1 * src9 - (tmp4 * src11 + tmp0 * src9 + tmp3 * src10);\n\t\tconst dst13 = tmp8 * src11 + tmp0 * src8 + tmp7 * src10 - (tmp6 * src10 + tmp9 * src11 + tmp1 * src8);\n\t\tconst dst14 = tmp6 * src9 + tmp11 * src11 + tmp3 * src8 - (tmp10 * src11 + tmp2 * src8 + tmp7 * src9);\n\t\tconst dst15 = tmp10 * src10 + tmp4 * src8 + tmp9 * src9 - (tmp8 * src9 + tmp11 * src10 + tmp5 * src8);\n\n\t\t// calculate determinant\n\t\tlet det = src0 * dst0 + src1 * dst1 + src2 * dst2 + src3 * dst3;\n\n\t\tif (Math.abs(det) < GMath.EPSILON21) {\n\t\t\t// Special case for a zero scale matrix that can occur, for example,\n\t\t\t// when a model's node has a [0, 0, 0] scale.\n\t\t\tif (\n\t\t\t\tMatrix3.equalsEpsilon(\n\t\t\t\t\tMatrix4.getMatrix3(matrix, scratchInverseRotation),\n\t\t\t\t\tscratchMatrix3Zero,\n\t\t\t\t\tGMath.EPSILON7\n\t\t\t\t) &&\n\t\t\t\tVector4.equals(Matrix4.getRow(matrix, 3, scratchBottomRow), scratchExpectedBottomRow)\n\t\t\t) {\n\t\t\t\tresult[0] = 0.0;\n\t\t\t\tresult[1] = 0.0;\n\t\t\t\tresult[2] = 0.0;\n\t\t\t\tresult[3] = 0.0;\n\t\t\t\tresult[4] = 0.0;\n\t\t\t\tresult[5] = 0.0;\n\t\t\t\tresult[6] = 0.0;\n\t\t\t\tresult[7] = 0.0;\n\t\t\t\tresult[8] = 0.0;\n\t\t\t\tresult[9] = 0.0;\n\t\t\t\tresult[10] = 0.0;\n\t\t\t\tresult[11] = 0.0;\n\t\t\t\tresult[12] = -matrix[12];\n\t\t\t\tresult[13] = -matrix[13];\n\t\t\t\tresult[14] = -matrix[14];\n\t\t\t\tresult[15] = 1.0;\n\t\t\t\treturn result;\n\t\t\t}\n\n\t\t\tthrow new Error(\"matrix is not invertible because its determinate is zero.\");\n\t\t}\n\n\t\t// calculate matrix inverse\n\t\tdet = 1.0 / det;\n\n\t\tresult[0] = dst0 * det;\n\t\tresult[1] = dst1 * det;\n\t\tresult[2] = dst2 * det;\n\t\tresult[3] = dst3 * det;\n\t\tresult[4] = dst4 * det;\n\t\tresult[5] = dst5 * det;\n\t\tresult[6] = dst6 * det;\n\t\tresult[7] = dst7 * det;\n\t\tresult[8] = dst8 * det;\n\t\tresult[9] = dst9 * det;\n\t\tresult[10] = dst10 * det;\n\t\tresult[11] = dst11 * det;\n\t\tresult[12] = dst12 * det;\n\t\tresult[13] = dst13 * det;\n\t\tresult[14] = dst14 * det;\n\t\tresult[15] = dst15 * det;\n\t\treturn result;\n\t}\n\n\tstatic inverseTransformation(matrix: Matrix4, result: Matrix4): Matrix4 {\n\t\t// This function is an optimized version of the below 4 lines.\n\t\t// const rT = Matrix3.transpose(Matrix4.getMatrix3(matrix));\n\t\t// const rTN = Matrix3.negate(rT);\n\t\t// const rTT = Matrix3.multiplyByVector(rTN, Matrix4.getTranslation(matrix));\n\t\t// return Matrix4.fromRotationTranslation(rT, rTT, result);\n\n\t\tconst matrix0 = matrix[0];\n\t\tconst matrix1 = matrix[1];\n\t\tconst matrix2 = matrix[2];\n\t\tconst matrix4 = matrix[4];\n\t\tconst matrix5 = matrix[5];\n\t\tconst matrix6 = matrix[6];\n\t\tconst matrix8 = matrix[8];\n\t\tconst matrix9 = matrix[9];\n\t\tconst matrix10 = matrix[10];\n\n\t\tconst vX = matrix[12];\n\t\tconst vY = matrix[13];\n\t\tconst vZ = matrix[14];\n\n\t\tconst x = -matrix0 * vX - matrix1 * vY - matrix2 * vZ;\n\t\tconst y = -matrix4 * vX - matrix5 * vY - matrix6 * vZ;\n\t\tconst z = -matrix8 * vX - matrix9 * vY - matrix10 * vZ;\n\n\t\tresult[0] = matrix0;\n\t\tresult[1] = matrix4;\n\t\tresult[2] = matrix8;\n\t\tresult[3] = 0.0;\n\t\tresult[4] = matrix1;\n\t\tresult[5] = matrix5;\n\t\tresult[6] = matrix9;\n\t\tresult[7] = 0.0;\n\t\tresult[8] = matrix2;\n\t\tresult[9] = matrix6;\n\t\tresult[10] = matrix10;\n\t\tresult[11] = 0.0;\n\t\tresult[12] = x;\n\t\tresult[13] = y;\n\t\tresult[14] = z;\n\t\tresult[15] = 1.0;\n\t\treturn result;\n\t}\n\n\tstatic inverseTranspose(matrix: Matrix4, result: Matrix4): Matrix4 {\n\t\treturn Matrix4.inverse(Matrix4.transpose(matrix, scratchTransposeMatrix), result);\n\t}\n\t/**\n\t * @private\n\t */\n\tstatic equalsArray(matrix: Matrix4, array: Array<number>, offset: number): boolean {\n\t\treturn (\n\t\t\tmatrix[0] === array[offset] &&\n\t\t\tmatrix[1] === array[offset + 1] &&\n\t\t\tmatrix[2] === array[offset + 2] &&\n\t\t\tmatrix[3] === array[offset + 3] &&\n\t\t\tmatrix[4] === array[offset + 4] &&\n\t\t\tmatrix[5] === array[offset + 5] &&\n\t\t\tmatrix[6] === array[offset + 6] &&\n\t\t\tmatrix[7] === array[offset + 7] &&\n\t\t\tmatrix[8] === array[offset + 8] &&\n\t\t\tmatrix[9] === array[offset + 9] &&\n\t\t\tmatrix[10] === array[offset + 10] &&\n\t\t\tmatrix[11] === array[offset + 11] &&\n\t\t\tmatrix[12] === array[offset + 12] &&\n\t\t\tmatrix[13] === array[offset + 13] &&\n\t\t\tmatrix[14] === array[offset + 14] &&\n\t\t\tmatrix[15] === array[offset + 15]\n\t\t);\n\t}\n}\n\nconst scratchTransposeMatrix = new Matrix4();\n\nconst fromCameraF = new Vector3();\nconst fromCameraR = new Vector3();\nconst fromCameraU = new Vector3();\n\nconst scaleScratch1 = new Vector3();\nconst scaleScratch2 = new Vector3();\nconst scratchColumn = new Vector3();\nconst scaleScratch3 = new Vector3();\nconst scaleScratch4 = new Vector3();\nconst scaleScratch5 = new Vector3();\nconst scratchInverseRotation = new Matrix3();\nconst scratchMatrix3Zero = new Matrix3();\nconst scratchBottomRow = new Vector4();\nconst scratchExpectedBottomRow = new Vector4(0.0, 0.0, 0.0, 1.0);\nconst x = new Vector3();\nconst y = new Vector3();\nconst z = new Vector3();\nexport default Matrix4;\n","import Camera from \"../camera/Camera\";\nimport Matrix4 from \"../math/Matrix4\";\nimport Plane from \"../math/Plane\";\nimport Vector3 from \"../math/Vector3\";\nimport defaultValue from \"../utils/defaultValue\";\nimport defined from \"../utils/defined\";\nimport { Intersect } from \"./WebGPUConstant\";\n\nexport default class BoundingSphere {\n\tradius: number;\n\tcenter: Vector3;\n\toriginRadius: number;\n\toriginCenter: Vector3;\n\tconstructor(center: Vector3 = new Vector3(0, 0, 0), radius = 0) {\n\t\tthis.center = center;\n\t\tthis.radius = radius;\n\t\tthis.originCenter = this.center.clone();\n\t\tthis.originRadius = radius;\n\t}\n\t/**\n\t * @param {Vector3[]} [positions] An array of points that the bounding sphere will enclose.  Each point must have <code>x</code>, <code>y</code>, and <code>z</code> properties.\n\t * @returns {BoundingSphere} The modified result parameter or a new BoundingSphere instance if one was not provided.\n\t */\n\tstatic fromPoints(positions: Vector3[]) {\n\t\tconst result = new BoundingSphere();\n\n\t\tif (!defined(positions) || positions.length === 0) {\n\t\t\tresult.center = Vector3.clone(Vector3.ZERO, result.center);\n\t\t\tresult.radius = 0.0;\n\t\t\treturn result;\n\t\t}\n\n\t\tconst currentPos = Vector3.clone(positions[0], fromPointsCurrentPos);\n\n\t\tconst xMin = Vector3.clone(currentPos, fromPointsXMin);\n\t\tconst yMin = Vector3.clone(currentPos, fromPointsYMin);\n\t\tconst zMin = Vector3.clone(currentPos, fromPointsZMin);\n\n\t\tconst xMax = Vector3.clone(currentPos, fromPointsXMax);\n\t\tconst yMax = Vector3.clone(currentPos, fromPointsYMax);\n\t\tconst zMax = Vector3.clone(currentPos, fromPointsZMax);\n\n\t\tconst numPositions = positions.length;\n\t\tlet i;\n\t\tfor (i = 1; i < numPositions; i++) {\n\t\t\tVector3.clone(positions[i], currentPos);\n\n\t\t\tconst x = currentPos.x;\n\t\t\tconst y = currentPos.y;\n\t\t\tconst z = currentPos.z;\n\n\t\t\t// Store points containing the the smallest and largest components\n\t\t\tif (x < xMin.x) {\n\t\t\t\tVector3.clone(currentPos, xMin);\n\t\t\t}\n\n\t\t\tif (x > xMax.x) {\n\t\t\t\tVector3.clone(currentPos, xMax);\n\t\t\t}\n\n\t\t\tif (y < yMin.y) {\n\t\t\t\tVector3.clone(currentPos, yMin);\n\t\t\t}\n\n\t\t\tif (y > yMax.y) {\n\t\t\t\tVector3.clone(currentPos, yMax);\n\t\t\t}\n\n\t\t\tif (z < zMin.z) {\n\t\t\t\tVector3.clone(currentPos, zMin);\n\t\t\t}\n\n\t\t\tif (z > zMax.z) {\n\t\t\t\tVector3.clone(currentPos, zMax);\n\t\t\t}\n\t\t}\n\n\t\t// Compute x-, y-, and z-spans (Squared distances b/n each component's min. and max.).\n\t\tconst xSpan = Vector3.magnitudeSquared(Vector3.subtract(xMax, xMin, fromPointsScratch));\n\t\tconst ySpan = Vector3.magnitudeSquared(Vector3.subtract(yMax, yMin, fromPointsScratch));\n\t\tconst zSpan = Vector3.magnitudeSquared(Vector3.subtract(zMax, zMin, fromPointsScratch));\n\n\t\t// Set the diameter endpoints to the largest span.\n\t\tlet diameter1 = xMin;\n\t\tlet diameter2 = xMax;\n\t\tlet maxSpan = xSpan;\n\t\tif (ySpan > maxSpan) {\n\t\t\tmaxSpan = ySpan;\n\t\t\tdiameter1 = yMin;\n\t\t\tdiameter2 = yMax;\n\t\t}\n\t\tif (zSpan > maxSpan) {\n\t\t\tmaxSpan = zSpan;\n\t\t\tdiameter1 = zMin;\n\t\t\tdiameter2 = zMax;\n\t\t}\n\n\t\t// Calculate the center of the initial sphere found by Ritter's algorithm\n\t\tconst ritterCenter = fromPointsRitterCenter;\n\t\tritterCenter.x = (diameter1.x + diameter2.x) * 0.5;\n\t\tritterCenter.y = (diameter1.y + diameter2.y) * 0.5;\n\t\tritterCenter.z = (diameter1.z + diameter2.z) * 0.5;\n\n\t\t// Calculate the radius of the initial sphere found by Ritter's algorithm\n\t\tlet radiusSquared = Vector3.magnitudeSquared(Vector3.subtract(diameter2, ritterCenter, fromPointsScratch));\n\t\tlet ritterRadius = Math.sqrt(radiusSquared);\n\n\t\t// Find the center of the sphere found using the Naive method.\n\t\tconst minBoxPt = fromPointsMinBoxPt;\n\t\tminBoxPt.x = xMin.x;\n\t\tminBoxPt.y = yMin.y;\n\t\tminBoxPt.z = zMin.z;\n\n\t\tconst maxBoxPt = fromPointsMaxBoxPt;\n\t\tmaxBoxPt.x = xMax.x;\n\t\tmaxBoxPt.y = yMax.y;\n\t\tmaxBoxPt.z = zMax.z;\n\n\t\tconst naiveCenter = Vector3.midpoint(minBoxPt, maxBoxPt, fromPointsNaiveCenterScratch);\n\n\t\t// Begin 2nd pass to find naive radius and modify the ritter sphere.\n\t\tlet naiveRadius = 0;\n\t\tfor (i = 0; i < numPositions; i++) {\n\t\t\tVector3.clone(positions[i], currentPos);\n\n\t\t\t// Find the furthest point from the naive center to calculate the naive radius.\n\t\t\tconst r = Vector3.magnitude(Vector3.subtract(currentPos, naiveCenter, fromPointsScratch));\n\t\t\tif (r > naiveRadius) {\n\t\t\t\tnaiveRadius = r;\n\t\t\t}\n\n\t\t\t// Make adjustments to the Ritter Sphere to include all points.\n\t\t\tconst oldCenterToPointSquared = Vector3.magnitudeSquared(\n\t\t\t\tVector3.subtract(currentPos, ritterCenter, fromPointsScratch)\n\t\t\t);\n\t\t\tif (oldCenterToPointSquared > radiusSquared) {\n\t\t\t\tconst oldCenterToPoint = Math.sqrt(oldCenterToPointSquared);\n\t\t\t\t// Calculate new radius to include the point that lies outside\n\t\t\t\tritterRadius = (ritterRadius + oldCenterToPoint) * 0.5;\n\t\t\t\tradiusSquared = ritterRadius * ritterRadius;\n\t\t\t\t// Calculate center of new Ritter sphere\n\t\t\t\tconst oldToNew = oldCenterToPoint - ritterRadius;\n\t\t\t\tritterCenter.x = (ritterRadius * ritterCenter.x + oldToNew * currentPos.x) / oldCenterToPoint;\n\t\t\t\tritterCenter.y = (ritterRadius * ritterCenter.y + oldToNew * currentPos.y) / oldCenterToPoint;\n\t\t\t\tritterCenter.z = (ritterRadius * ritterCenter.z + oldToNew * currentPos.z) / oldCenterToPoint;\n\t\t\t}\n\t\t}\n\n\t\tif (ritterRadius < naiveRadius) {\n\t\t\tVector3.clone(ritterCenter, result.center);\n\t\t\tresult.radius = ritterRadius;\n\t\t} else {\n\t\t\tVector3.clone(naiveCenter, result.center);\n\t\t\tresult.radius = naiveRadius;\n\t\t}\n\n\t\treturn result;\n\t}\n\t/**\n\t * Computes a tight-fitting bounding sphere enclosing a list of 3D points, where the points are\n\t * stored in a flat array in X, Y, Z, order.  The bounding sphere is computed by running two\n\t * algorithms, a naive algorithm and Ritter's algorithm. The smaller of the two spheres is used to\n\t * ensure a tight fit.\n\t *\n\t * @param {Number[]} [positions] An array of points that the bounding sphere will enclose.  Each point\n\t *        is formed from three elements in the array in the order X, Y, Z.\n\t * @param {Vector3} [center=Vector3.ZERO] The position to which the positions are relative, which need not be the\n\t *        origin of the coordinate system.  This is useful when the positions are to be used for\n\t *        relative-to-center (RTC) rendering.\n\t * @param {Number} [stride=3] The number of array elements per vertex.  It must be at least 3, but it may\n\t *        be higher.  Regardless of the value of this parameter, the X coordinate of the first position\n\t *        is at array index 0, the Y coordinate is at array index 1, and the Z coordinate is at array index\n\t *        2.  When stride is 3, the X coordinate of the next position then begins at array index 3.  If\n\t *        the stride is 5, however, two array elements are skipped and the next position begins at array\n\t *        index 5.\n\t * @param {BoundingSphere} [result] The object onto which to store the result.\n\t * @returns {BoundingSphere} The modified result parameter or a new BoundingSphere instance if one was not provided.\n\t *\n\t * @example\n\t * // Compute the bounding sphere from 3 positions, each specified relative to a center.\n\t * // In addition to the X, Y, and Z coordinates, the points array contains two additional\n\t * // elements per point which are ignored for the purpose of computing the bounding sphere.\n\t * const center = new Vector3(1.0, 2.0, 3.0);\n\t * const points = [1.0, 2.0, 3.0, 0.1, 0.2,\n\t *               4.0, 5.0, 6.0, 0.1, 0.2,\n\t *               7.0, 8.0, 9.0, 0.1, 0.2];\n\t * const sphere = BoundingSphere.fromVertices(points, center, 5);\n\t *\n\t */\n\tstatic fromVertices(positions: number[], center: Vector3 = Vector3.ZERO, stride = 3) {\n\t\tconst result = new BoundingSphere();\n\n\t\tif (!defined(positions) || positions.length === 0) {\n\t\t\tresult.center = Vector3.clone(Vector3.ZERO, result.center);\n\t\t\tresult.radius = 0.0;\n\t\t\treturn result;\n\t\t}\n\n\t\tcenter = defaultValue(center, Vector3.ZERO);\n\n\t\tstride = defaultValue(stride, 3);\n\n\t\tconst currentPos = fromPointsCurrentPos;\n\t\tcurrentPos.x = positions[0] + center.x;\n\t\tcurrentPos.y = positions[1] + center.y;\n\t\tcurrentPos.z = positions[2] + center.z;\n\n\t\tconst xMin = Vector3.clone(currentPos, fromPointsXMin);\n\t\tconst yMin = Vector3.clone(currentPos, fromPointsYMin);\n\t\tconst zMin = Vector3.clone(currentPos, fromPointsZMin);\n\n\t\tconst xMax = Vector3.clone(currentPos, fromPointsXMax);\n\t\tconst yMax = Vector3.clone(currentPos, fromPointsYMax);\n\t\tconst zMax = Vector3.clone(currentPos, fromPointsZMax);\n\n\t\tconst numElements = positions.length;\n\t\tlet i;\n\t\tfor (i = 0; i < numElements; i += stride) {\n\t\t\tconst x = positions[i] + center.x;\n\t\t\tconst y = positions[i + 1] + center.y;\n\t\t\tconst z = positions[i + 2] + center.z;\n\n\t\t\tcurrentPos.x = x;\n\t\t\tcurrentPos.y = y;\n\t\t\tcurrentPos.z = z;\n\n\t\t\t// Store points containing the the smallest and largest components\n\t\t\tif (x < xMin.x) {\n\t\t\t\tVector3.clone(currentPos, xMin);\n\t\t\t}\n\n\t\t\tif (x > xMax.x) {\n\t\t\t\tVector3.clone(currentPos, xMax);\n\t\t\t}\n\n\t\t\tif (y < yMin.y) {\n\t\t\t\tVector3.clone(currentPos, yMin);\n\t\t\t}\n\n\t\t\tif (y > yMax.y) {\n\t\t\t\tVector3.clone(currentPos, yMax);\n\t\t\t}\n\n\t\t\tif (z < zMin.z) {\n\t\t\t\tVector3.clone(currentPos, zMin);\n\t\t\t}\n\n\t\t\tif (z > zMax.z) {\n\t\t\t\tVector3.clone(currentPos, zMax);\n\t\t\t}\n\t\t}\n\n\t\t// Compute x-, y-, and z-spans (Squared distances b/n each component's min. and max.).\n\t\tconst xSpan = Vector3.magnitudeSquared(Vector3.subtract(xMax, xMin, fromPointsScratch));\n\t\tconst ySpan = Vector3.magnitudeSquared(Vector3.subtract(yMax, yMin, fromPointsScratch));\n\t\tconst zSpan = Vector3.magnitudeSquared(Vector3.subtract(zMax, zMin, fromPointsScratch));\n\n\t\t// Set the diameter endpoints to the largest span.\n\t\tlet diameter1 = xMin;\n\t\tlet diameter2 = xMax;\n\t\tlet maxSpan = xSpan;\n\t\tif (ySpan > maxSpan) {\n\t\t\tmaxSpan = ySpan;\n\t\t\tdiameter1 = yMin;\n\t\t\tdiameter2 = yMax;\n\t\t}\n\t\tif (zSpan > maxSpan) {\n\t\t\tmaxSpan = zSpan;\n\t\t\tdiameter1 = zMin;\n\t\t\tdiameter2 = zMax;\n\t\t}\n\n\t\t// Calculate the center of the initial sphere found by Ritter's algorithm\n\t\tconst ritterCenter = fromPointsRitterCenter;\n\t\tritterCenter.x = (diameter1.x + diameter2.x) * 0.5;\n\t\tritterCenter.y = (diameter1.y + diameter2.y) * 0.5;\n\t\tritterCenter.z = (diameter1.z + diameter2.z) * 0.5;\n\n\t\t// Calculate the radius of the initial sphere found by Ritter's algorithm\n\t\tlet radiusSquared = Vector3.magnitudeSquared(Vector3.subtract(diameter2, ritterCenter, fromPointsScratch));\n\t\tlet ritterRadius = Math.sqrt(radiusSquared);\n\n\t\t// Find the center of the sphere found using the Naive method.\n\t\tconst minBoxPt = fromPointsMinBoxPt;\n\t\tminBoxPt.x = xMin.x;\n\t\tminBoxPt.y = yMin.y;\n\t\tminBoxPt.z = zMin.z;\n\n\t\tconst maxBoxPt = fromPointsMaxBoxPt;\n\t\tmaxBoxPt.x = xMax.x;\n\t\tmaxBoxPt.y = yMax.y;\n\t\tmaxBoxPt.z = zMax.z;\n\n\t\tconst naiveCenter = Vector3.midpoint(minBoxPt, maxBoxPt, fromPointsNaiveCenterScratch);\n\n\t\t// Begin 2nd pass to find naive radius and modify the ritter sphere.\n\t\tlet naiveRadius = 0;\n\t\tfor (i = 0; i < numElements; i += stride) {\n\t\t\tcurrentPos.x = positions[i] + center.x;\n\t\t\tcurrentPos.y = positions[i + 1] + center.y;\n\t\t\tcurrentPos.z = positions[i + 2] + center.z;\n\n\t\t\t// Find the furthest point from the naive center to calculate the naive radius.\n\t\t\tconst r = Vector3.magnitude(Vector3.subtract(currentPos, naiveCenter, fromPointsScratch));\n\t\t\tif (r > naiveRadius) {\n\t\t\t\tnaiveRadius = r;\n\t\t\t}\n\n\t\t\t// Make adjustments to the Ritter Sphere to include all points.\n\t\t\tconst oldCenterToPointSquared = Vector3.magnitudeSquared(\n\t\t\t\tVector3.subtract(currentPos, ritterCenter, fromPointsScratch)\n\t\t\t);\n\t\t\tif (oldCenterToPointSquared > radiusSquared) {\n\t\t\t\tconst oldCenterToPoint = Math.sqrt(oldCenterToPointSquared);\n\t\t\t\t// Calculate new radius to include the point that lies outside\n\t\t\t\tritterRadius = (ritterRadius + oldCenterToPoint) * 0.5;\n\t\t\t\tradiusSquared = ritterRadius * ritterRadius;\n\t\t\t\t// Calculate center of new Ritter sphere\n\t\t\t\tconst oldToNew = oldCenterToPoint - ritterRadius;\n\t\t\t\tritterCenter.x = (ritterRadius * ritterCenter.x + oldToNew * currentPos.x) / oldCenterToPoint;\n\t\t\t\tritterCenter.y = (ritterRadius * ritterCenter.y + oldToNew * currentPos.y) / oldCenterToPoint;\n\t\t\t\tritterCenter.z = (ritterRadius * ritterCenter.z + oldToNew * currentPos.z) / oldCenterToPoint;\n\t\t\t}\n\t\t}\n\n\t\tif (ritterRadius < naiveRadius) {\n\t\t\tVector3.clone(ritterCenter, result.center);\n\t\t\tresult.radius = ritterRadius;\n\t\t} else {\n\t\t\tVector3.clone(naiveCenter, result.center);\n\t\t\tresult.radius = naiveRadius;\n\t\t}\n\n\t\treturn result;\n\t}\n\n\tintersectPlane(plane: Plane) {\n\t\tconst center = this.center;\n\t\tconst radius = this.radius;\n\t\tconst normal = plane.normal;\n\t\tconst distanceToPlane = Vector3.dot(normal, center) + plane.distance;\n\n\t\tif (distanceToPlane < -radius) {\n\t\t\t// The center point is negative side of the plane normal\n\t\t\treturn Intersect.OUTSIDE;\n\t\t} else if (distanceToPlane < radius) {\n\t\t\t// The center point is positive side of the plane, but radius extends beyond it; partial overlap\n\t\t\treturn Intersect.INTERSECTING;\n\t\t}\n\t\treturn Intersect.INSIDE;\n\t}\n\tupdate(transform: Matrix4) {\n\t\tMatrix4.multiplyByPoint(transform, this.originCenter, this.center);\n\t\tthis.radius = Matrix4.getMaximumScale(transform) * this.originRadius;\n\t}\n\tdistanceToCamera(camera: Camera) {\n\t\treturn Math.max(0.0, Vector3.distance(this.center, camera.position) - this.radius);\n\t}\n}\nconst fromPointsXMin = new Vector3();\nconst fromPointsYMin = new Vector3();\nconst fromPointsZMin = new Vector3();\nconst fromPointsXMax = new Vector3();\nconst fromPointsYMax = new Vector3();\nconst fromPointsZMax = new Vector3();\nconst fromPointsCurrentPos = new Vector3();\nconst fromPointsScratch = new Vector3();\nconst fromPointsRitterCenter = new Vector3();\nconst fromPointsMinBoxPt = new Vector3();\nconst fromPointsMaxBoxPt = new Vector3();\nconst fromPointsNaiveCenterScratch = new Vector3();\n","import { IndexFormat } from \"../core/WebGPUConstant\";\r\nimport Buffer from \"./Buffer\";\r\nexport default class IndexBuffer {\r\n\tbuffer: Buffer;\r\n\tindices: Array<number>;\r\n\tindexFormat: GPUIndexFormat;\r\n\tdirty: boolean;\r\n\tprivate label: string;\r\n\tconstructor(label: string, indices?: Array<number>) {\r\n\t\tthis.label = label;\r\n\t\tthis.indices = indices;\r\n\t\tthis.indexFormat = IndexFormat.Uint16;\r\n\t\tthis.dirty = true;\r\n\t}\r\n\tsetIndices(indices) {\r\n\t\tthis.indices = indices;\r\n\t\tthis.dirty = true;\r\n\t}\r\n\tbind(device: GPUDevice, passEncoder: GPURenderPassEncoder) {\r\n\t\tif (this.dirty) {\r\n\t\t\tthis.dirty = false;\r\n\t\t\tthis.buffer = Buffer.createIndexBuffer(\r\n\t\t\t\tthis.label,\r\n\t\t\t\tdevice,\r\n\t\t\t\tthis.indexFormat == IndexFormat.Uint16 ? new Uint16Array(this.indices) : new Uint32Array(this.indices)\r\n\t\t\t);\r\n\t\t}\r\n\t\tpassEncoder.setIndexBuffer(this.buffer.gpuBuffer, this.indexFormat);\r\n\t}\r\n\tdestroy() {\r\n\t\tthis.buffer.destroy();\r\n\t}\r\n}\r\n","import { Attribute, AttributeType, InterleavedAttribute } from \"./Attribute\";\nexport default class Attributes {\n\tpublic interleave: boolean;\n\tprivate _attributes: Map<string, Attribute | InterleavedAttribute>;\n\tprivate shaderLocation: number;\n\tprivate offset: number;\n\tconstructor() {\n\t\tthis._attributes = new Map();\n\t\tthis.shaderLocation = 0;\n\t\tthis.offset = 0;\n\t\tthis.interleave = false;\n\t}\n\tgetAttribute(name): Attribute | InterleavedAttribute {\n\t\treturn this._attributes.get(name);\n\t}\n\tsetAttribute(attribute: Attribute | InterleavedAttribute) {\n\t\tif (attribute.attributeType === AttributeType.attribute) {\n\t\t\tthis.setNotInterleavedAttribute(attribute as Attribute);\n\t\t} else {\n\t\t\tthis.setInterleavedAttribute(attribute as InterleavedAttribute);\n\t\t}\n\t}\n\tprivate setNotInterleavedAttribute(attribute: Attribute) {\n\t\tif (this._attributes.has(attribute.name)) return;\n\t\tattribute.shaderLocation = this.shaderLocation;\n\t\tthis.shaderLocation += 1;\n\t\tattribute.offset = this.offset;\n\t\tthis.offset += attribute.attributeByteSize;\n\t\tthis._attributes.set(attribute.name, attribute);\n\t}\n\tprivate setInterleavedAttribute(attribute: InterleavedAttribute) {\n\t\tif (this._attributes.has(attribute.names.toString())) return;\n\t\tthis._attributes.set(attribute.names.toString(), attribute);\n\t}\n\tgetGPUAttributes() {\n\t\tconst result = [];\n\t\tthis._attributes.forEach((attribute) => {\n\t\t\tresult.push(...attribute.getGPUAttribute());\n\t\t});\n\t\treturn result;\n\t}\n\tgetAtrributeValues(): {\n\t\tarrayStride: number;\n\t\ttypeArray: Float32Array;\n\t} {\n\t\tconst arrayStrides = [];\n\t\tlet arrayStride = 0;\n\t\tlet values = null;\n\t\tconst arrays = [];\n\t\tthis._attributes.forEach((attribute: Attribute | InterleavedAttribute) => {\n\t\t\tif (attribute.attributeType === AttributeType.attribute) {\n\t\t\t\tarrayStrides.push((attribute as Attribute).itemSize);\n\t\t\t\tarrays.push(attribute.value);\n\t\t\t\tarrayStride += (attribute as Attribute).itemSize;\n\t\t\t} else {\n\t\t\t\tif (!this.interleave) this.interleave = true;\n\t\t\t\tvalues = values ?? attribute.value;\n\t\t\t\tarrayStride = (attribute as InterleavedAttribute).itemSizes.reduce(\n\t\t\t\t\t(total, current) => (total += current),\n\t\t\t\t\t0\n\t\t\t\t);\n\t\t\t}\n\t\t});\n\n\t\tconst typeArray = this.interleave\n\t\t\t? new Float32Array(values)\n\t\t\t: this.interleaveTypedArray(Float32Array, arrayStrides, ...arrays);\n\t\treturn {\n\t\t\tarrayStride: arrayStride * typeArray.BYTES_PER_ELEMENT,\n\t\t\ttypeArray\n\t\t};\n\t}\n\tdestroy() {\n\t\tthis._attributes.forEach((attribute) => {\n\t\t\tattribute.destroy();\n\t\t});\n\t}\n\t/**\n\t * Interleave n typed arrays\n\t * @alias module:interleaveTypedArray\n\t * @param {TypedArray} ResultConstructor Returned typed array constructor\n\t * @param {Array} elements Number of elements to group for each typed array\n\t * @param {...TypedArray} arrays Arrays to interleave\n\t * @returns {TypedArray}\n\t */\n\tinterleaveTypedArray(ResultConstructor, elements, ...arrays) {\n\t\tconst totalLength = arrays.reduce((total, arr) => total + arr.length, 0);\n\t\tconst result = new ResultConstructor(totalLength);\n\t\tconst stride = elements.reduce((a, b) => a + b);\n\n\t\tfor (let i = 0; i < totalLength; i++) {\n\t\t\tlet offset = 0;\n\t\t\tfor (let j = 0; j < elements.length; j++) {\n\t\t\t\tfor (let k = 0; k < elements[j]; k++) {\n\t\t\t\t\tresult[i * stride + offset] = arrays[j][elements[j] * i + k];\n\t\t\t\t\toffset++;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\treturn result;\n\t}\n}\n","import { InputStepMode } from \"../core/WebGPUConstant\";\nimport { Attribute, InterleavedAttribute } from \"./Attribute\";\nimport Attributes from \"./Attributes\";\nimport Buffer from \"./Buffer\";\nexport default class VertextBuffer {\n\tpublic index: number;\n\tpublic arrayStride: number;\n\tpublic stepMode: string;\n\tpublic buffer: Buffer;\n\tpublic attributes: Attributes;\n\tpublic dirty: boolean;\n\tprivate label: string;\n\tconstructor(label: string, index?: number, stepMode?: string) {\n\t\tthis.index = index || 0;\n\t\tthis.attributes = new Attributes();\n\t\tthis.stepMode = InputStepMode.Vertex;\n\t\tthis.dirty = true;\n\t\tthis.label = label;\n\t}\n\tpublic getBufferDes() {\n\t\treturn [\n\t\t\t{\n\t\t\t\tarrayStride: this.arrayStride,\n\t\t\t\tstepMode: this.stepMode,\n\t\t\t\tattributes: this.attributes.getGPUAttributes()\n\t\t\t}\n\t\t];\n\t}\n\tpublic setAttribute(attribute: Attribute | InterleavedAttribute) {\n\t\tthis.attributes.setAttribute(attribute);\n\t\tthis.dirty = true;\n\t}\n\tpublic getAttribute(name: string): Attribute | InterleavedAttribute {\n\t\treturn this.attributes.getAttribute(name);\n\t}\n\tpublic bind(device: GPUDevice, passEncoder: GPURenderPassEncoder) {\n\t\tif (this.dirty) {\n\t\t\tthis.dirty = false;\n\t\t\tconst { arrayStride, typeArray } = this.attributes.getAtrributeValues();\n\t\t\tthis.arrayStride = arrayStride;\n\t\t\tthis.buffer = Buffer.createVertexBuffer(this.label, device, typeArray);\n\t\t}\n\t\tpassEncoder.setVertexBuffer(this.index, this.buffer.gpuBuffer);\n\t}\n\tdestroy() {\n\t\tthis.buffer.destroy();\n\t\tthis.attributes.destroy();\n\t}\n}\n","import defaultValue from \"./defaultValue\";\r\nimport defined from \"./defined\";\r\n\r\n/**\r\n * Merges two objects, copying their properties onto a new combined object. When two objects have the same\r\n * property, the value of the property on the first object is used.  If either object is undefined,\r\n * it will be treated as an empty object.\r\n *\r\n * @example\r\n * const object1 = {\r\n *     propOne : 1,\r\n *     propTwo : {\r\n *         value1 : 10\r\n *     }\r\n * }\r\n * const object2 = {\r\n *     propTwo : 2\r\n * }\r\n * const final = combine(object1, object2);\r\n *\r\n * // final === {\r\n * //     propOne : 1,\r\n * //     propTwo : {\r\n * //         value1 : 10\r\n * //     }\r\n * // }\r\n *\r\n * @param {Object} [object1] The first object to merge.\r\n * @param {Object} [object2] The second object to merge.\r\n * @param {Boolean} [deep=false] Perform a recursive merge.\r\n * @returns {Object} The combined object containing all properties from both objects.\r\n *\r\n * @function\r\n */\r\nfunction combine(object1, object2, deep) {\r\n  deep = defaultValue(deep, false);\r\n\r\n  const result = {};\r\n\r\n  const object1Defined = defined(object1);\r\n  const object2Defined = defined(object2);\r\n  let property;\r\n  let object1Value;\r\n  let object2Value;\r\n  if (object1Defined) {\r\n    for (property in object1) {\r\n      if (object1.hasOwnProperty(property)) {\r\n        object1Value = object1[property];\r\n        if (\r\n          object2Defined &&\r\n          deep &&\r\n          typeof object1Value === \"object\" &&\r\n          object2.hasOwnProperty(property)\r\n        ) {\r\n          object2Value = object2[property];\r\n          if (typeof object2Value === \"object\") {\r\n            result[property] = combine(object1Value, object2Value, deep);\r\n          } else {\r\n            result[property] = object1Value;\r\n          }\r\n        } else {\r\n          result[property] = object1Value;\r\n        }\r\n      }\r\n    }\r\n  }\r\n  if (object2Defined) {\r\n    for (property in object2) {\r\n      if (\r\n        object2.hasOwnProperty(property) &&\r\n        !result.hasOwnProperty(property)\r\n      ) {\r\n        object2Value = object2[property];\r\n        result[property] = object2Value;\r\n      }\r\n    }\r\n  }\r\n  return result;\r\n}\r\nexport default combine;\r\n","import BoundingBox from \"../core/BoundingBox\";\nimport BoundingSphere from \"../core/BoundingSphere\";\nimport { FrameState } from \"../core/FrameState\";\nimport { PrimitiveTopology } from \"../core/WebGPUConstant\";\nimport Vector2 from \"../math/Vector2\";\nimport Vector3 from \"../math/Vector3\";\nimport Vector4 from \"../math/Vector4\";\nimport { Attribute, AttributeType, InterleavedFloat32Attribute } from \"../render/Attribute\";\nimport IndexBuffer from \"../render/IndexBuffer\";\nimport VertextBuffer from \"../render/VertextBuffer\";\nimport combine from \"../utils/combine\";\nexport default class Geometry {\n\tnormals: number[];\n\tuvs: number[];\n\tpositions: number[];\n\tindices: number[];\n\ttangents: number[];\n\ttype: string;\n\tdirty: boolean;\n\tindexBuffer?: IndexBuffer;\n\tvertBuffer: VertextBuffer;\n\tcount: number;\n\tboundingSphere?: BoundingSphere;\n\tboundingBox?: BoundingBox;\n\tprivate _defines: { [prop: string]: boolean | number };\n\tprivate locationIndex?: number;\n\tdefinesDirty: boolean;\n\ttopology: PrimitiveTopology;\n\tget defines() {\n\t\treturn this._defines;\n\t}\n\tset defines(value) {\n\t\tthis.definesDirty = true;\n\t\tthis._defines = combine(value, this._defines, false);\n\t}\n\tconstructor(options?: any) {\n\t\tthis.type = options.type || undefined;\n\t\tthis.boundingSphere = undefined;\n\t\tthis.dirty = false;\n\t\tthis.definesDirty = true;\n\t\tthis.locationIndex = 0;\n\t\tthis.vertBuffer = new VertextBuffer(this.type, 0);\n\t\tthis._defines = {};\n\t\tthis.normals = [];\n\t\tthis.uvs = [];\n\t\tthis.positions = [];\n\t\tthis.indices = [];\n\t\tthis.tangents = [];\n\t}\n\tgetAttribute(name: string) {\n\t\treturn this.vertBuffer.getAttribute(name);\n\t}\n\tsetAttribute(attribute: Attribute | InterleavedFloat32Attribute) {\n\t\tif (attribute.attributeType === AttributeType.attribute) {\n\t\t\tthis.setLocationIndex((attribute as Attribute).name);\n\t\t} else {\n\t\t\t(attribute as InterleavedFloat32Attribute)?.names.forEach((name: string) => this.setLocationIndex(name));\n\t\t}\n\t\tthis.vertBuffer.setAttribute(attribute);\n\t}\n\tprivate setLocationIndex(name: string) {\n\t\tif (this._defines[name?.concat(\"Location\")] || !name) return;\n\t\tthis._defines[name?.concat(\"Location\")] = this.locationIndex;\n\t\tthis.locationIndex += 1;\n\t}\n\tcontainAttribute(name: string): boolean {\n\t\treturn this._defines[name?.concat(\"Location\")] != undefined ? true : false;\n\t}\n\tsetIndice(indices: Array<number>) {\n\t\tthis.indices = indices;\n\t\tif (!this.indexBuffer) this.indexBuffer = new IndexBuffer(this.type + \"IndexBuffer\");\n\t\tthis.indexBuffer.setIndices(indices);\n\t}\n\tupdate(frameState: FrameState) {}\n\tcomputeBoundingSphere(positions: number[], stride = 3) {\n\t\tthis.boundingSphere = BoundingSphere.fromVertices(positions, new Vector3(0, 0, 0), stride);\n\t}\n\t/**\n\t * Calculate mesh tangent.\n\t * @remark need to set positions(with or not with indices), normals, uv before calculation.\n\t * @remark based on http://foundationsofgameenginedev.com/FGED2-sample.pdf\n\t */\n\tcalculateTangents(): void {\n\t\tif (!this.normals || !this.uvs) {\n\t\t\tthrow \"Set normal and uv before calculation.\";\n\t\t}\n\t\tconst { indices, positions, normals, uvs } = this;\n\t\tconst tempPos0 = new Vector3(),\n\t\t\ttempPos1 = new Vector3(),\n\t\t\ttempPos2 = new Vector3(),\n\t\t\ttempUV0 = new Vector2(),\n\t\t\ttempUV1 = new Vector2(),\n\t\t\ttempUV2 = new Vector2();\n\t\tconst e1 = new Vector3(),\n\t\t\te2 = new Vector3(),\n\t\t\tt = new Vector3(),\n\t\t\tb = new Vector3(),\n\t\t\ttemp = new Vector3();\n\t\tconst vertexCount = this.indices.length;\n\t\tconst triangleCount = indices ? indices.length / 3 : positions.length / 3;\n\t\tconst tangents = new Array<Vector4>(vertexCount);\n\t\tconst biTangents = new Array<Vector3>(vertexCount);\n\t\tthis.tangents = [];\n\t\tfor (let i = 0; i < vertexCount; i++) {\n\t\t\ttangents[i] = new Vector4();\n\t\t\tbiTangents[i] = new Vector3();\n\t\t}\n\n\t\t// Calculate tangent and bi-tangent for each triangle and add to all three vertices.\n\t\tfor (let k = 0; k < triangleCount; k++) {\n\t\t\tlet i0 = 3 * k;\n\t\t\tlet i1 = 3 * k + 1;\n\t\t\tlet i2 = 3 * k + 2;\n\t\t\tif (indices) {\n\t\t\t\ti0 = indices[i0];\n\t\t\t\ti1 = indices[i1];\n\t\t\t\ti2 = indices[i2];\n\t\t\t}\n\n\t\t\tconst p0 = tempPos0.set(positions[i0], positions[i0 + 1], positions[i0 + 2]);\n\t\t\tconst p1 = tempPos1.set(positions[i1], positions[i1 + 1], positions[i1 + 2]);\n\t\t\tconst p2 = tempPos2.set(positions[i2], positions[i2 + 1], positions[i2 + 2]);\n\t\t\tconst w0 = tempUV0.set(uvs[i0], uvs[i0 + 1]);\n\t\t\tconst w1 = tempUV1.set(uvs[i1], uvs[i1 + 1]);\n\t\t\tconst w2 = tempUV2.set(uvs[i2], uvs[i2 + 1]);\n\n\t\t\tVector3.subtract(p1, p0, e1);\n\t\t\tVector3.subtract(p2, p0, e2);\n\t\t\tconst x1 = w1.x - w0.x;\n\t\t\tconst x2 = w2.x - w0.x;\n\t\t\tconst y1 = w1.y - w0.y;\n\t\t\tconst y2 = w2.y - w0.y;\n\t\t\tconst r = 1.0 / (x1 * y2 - x2 * y1);\n\n\t\t\tVector3.multiplyByScalar(e1, y2 * r, t);\n\t\t\tVector3.multiplyByScalar(e2, y1 * r, temp);\n\t\t\tVector3.subtract(t, temp, t);\n\t\t\tVector3.multiplyByScalar(e2, x1 * r, b);\n\t\t\tVector3.multiplyByScalar(e1, x2 * r, temp);\n\t\t\tVector3.subtract(b, temp, b);\n\n\t\t\tlet tangent = tangents[i0];\n\t\t\ttangent.set(tangent.x + t.x, tangent.y + t.y, tangent.z + t.z, 1.0);\n\n\t\t\ttangent = tangents[i1];\n\t\t\ttangent.set(tangent.x + t.x, tangent.y + t.y, tangent.z + t.z, 1.0);\n\n\t\t\ttangent = tangents[i2];\n\t\t\ttangent.set(tangent.x + t.x, tangent.y + t.y, tangent.z + t.z, 1.0);\n\t\t\tbiTangents[i0].add(b);\n\t\t\tbiTangents[i1].add(b);\n\t\t\tbiTangents[i2].add(b);\n\t\t}\n\n\t\t// Orthonormalize each tangent and calculate the handedness.\n\t\tfor (let i = 0; i < vertexCount; i++) {\n\t\t\tconst n = new Vector3(normals[3 * i], normals[3 * i + 1], normals[3 * i + 2]);\n\t\t\tconst b = biTangents[i];\n\t\t\tconst tangent = tangents[i];\n\t\t\tt.set(tangent.x, tangent.y, tangent.z);\n\n\t\t\tVector3.cross(t, b, temp);\n\t\t\tconst w = Vector3.dot(temp, n) > 0.0 ? 1 : -1;\n\t\t\tVector3.multiplyByScalar(n, Vector3.dot(t, n), temp);\n\t\t\tVector3.subtract(t, temp, t);\n\t\t\tVector3.normalize(t, t);\n\t\t\t// t.normalize();\n\t\t\ttangent.set(t.x, t.y, t.z, w);\n\t\t\tthis.tangents.push(t.x, t.y, t.z, w);\n\t\t}\n\t\t// this.setTangents(tangents);\n\t}\n\tdestroy() {\n\t\tthis?.indexBuffer.destroy();\n\t\tthis.vertBuffer.destroy();\n\t\tthis.normals = null;\n\t\tthis.uvs = null;\n\t\tthis.positions = null;\n\t\tthis.indices = null;\n\t\tthis.tangents = null;\n\t\tthis.boundingSphere = undefined;\n\t}\n}\n","import { Float32Attribute } from \"../render/Attribute\";\r\nimport Geometry from \"./Geometry\";\r\nexport default class PlaneGeometry extends Geometry {\r\n\tconstructor(public width: number = 10, public height: number = 10) {\r\n\t\tsuper({\r\n\t\t\ttype: \"planeGeometry\"\r\n\t\t});\r\n\t\tthis.defines = {\r\n\t\t\tHAS_NORMAL: true\r\n\t\t};\r\n\t\tthis.init();\r\n\t}\r\n\tprivate init() {\r\n\t\t// generate pos uv normal so on\r\n\t\tconst { indices, normals, uvs, vertices } = this.createGrid(this.width, this.height);\r\n\t\tthis.computeBoundingSphere(vertices);\r\n\t\tthis.setAttribute(new Float32Attribute(\"position\", vertices, 3));\r\n\t\tthis.setAttribute(new Float32Attribute(\"normal\", normals, 3));\r\n\t\tthis.setAttribute(new Float32Attribute(\"uv\", uvs, 2));\r\n\t\tthis.setIndice(indices);\r\n\t\tthis.count = indices.length;\r\n\t}\r\n\tpublic update(frameState) {}\r\n\tprivate createGrid(width = 1, height = 1, widthSegments = 1, heightSegments = 1) {\r\n\t\tconst width_half = width / 2;\r\n\t\tconst height_half = height / 2;\r\n\r\n\t\tconst gridX = Math.floor(widthSegments);\r\n\t\tconst gridY = Math.floor(heightSegments);\r\n\r\n\t\tconst gridX1 = gridX + 1;\r\n\t\tconst gridY1 = gridY + 1;\r\n\r\n\t\tconst segment_width = width / gridX;\r\n\t\tconst segment_height = height / gridY;\r\n\r\n\t\t//\r\n\r\n\t\tconst indices = [];\r\n\t\tconst vertices = [];\r\n\t\tconst normals = [];\r\n\t\tconst uvs = [];\r\n\r\n\t\tfor (let iy = 0; iy < gridY1; iy++) {\r\n\t\t\tconst y = iy * segment_height - height_half;\r\n\r\n\t\t\tfor (let ix = 0; ix < gridX1; ix++) {\r\n\t\t\t\tconst x = ix * segment_width - width_half;\r\n\r\n\t\t\t\tvertices.push(x, -y, 0);\r\n\r\n\t\t\t\tnormals.push(0, 0, 1);\r\n\r\n\t\t\t\tuvs.push(ix / gridX);\r\n\t\t\t\tuvs.push(1 - iy / gridY);\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\tfor (let iy = 0; iy < gridY; iy++) {\r\n\t\t\tfor (let ix = 0; ix < gridX; ix++) {\r\n\t\t\t\tconst a = ix + gridX1 * iy;\r\n\t\t\t\tconst b = ix + gridX1 * (iy + 1);\r\n\t\t\t\tconst c = ix + 1 + gridX1 * (iy + 1);\r\n\t\t\t\tconst d = ix + 1 + gridX1 * iy;\r\n\r\n\t\t\t\tindices.push(a, b, d);\r\n\t\t\t\tindices.push(b, c, d);\r\n\t\t\t}\r\n\t\t}\r\n\t\treturn { indices, normals, uvs, vertices };\r\n\t}\r\n}\r\n","import defaultValue from \"../utils/defaultValue\";\r\nimport defined from \"../utils/defined\";\r\nimport GMath from \"./Math\";\r\nimport Matrix4 from \"./Matrix4\";\r\nimport Vector3 from \"./Vector3\";\r\n/**\r\n * A set of 4-dimensional coordinates used to represent rotation in 3-dimensional space.\r\n * @alias Quaternion\r\n * @constructor\r\n *\r\n * @param {Number} [x=0.0] The X component.\r\n * @param {Number} [y=0.0] The Y component.\r\n * @param {Number} [z=0.0] The Z component.\r\n * @param {Number} [w=0.0] The W component.\r\n *\r\n * @see PackableForInterpolation\r\n */\r\nexport class Quaternion {\r\n\tpublic static ZERO = Object.freeze(new Quaternion(0.0, 0.0, 0.0, 0.0));\r\n\r\n\tpublic static IDENTITY = Object.freeze(new Quaternion(0.0, 0.0, 0.0, 1.0));\r\n\r\n\tconstructor(public x: number = 0, public y: number = 0, public z: number = 0, public w: number = 1) {}\r\n\tset(x, y, z, w) {\r\n\t\tthis.x = x;\r\n\t\tthis.y = y;\r\n\t\tthis.z = z;\r\n\t\tthis.w = w;\r\n\t}\r\n\tnormalize() {\r\n\t\tconst inverseMagnitude = 1.0 / Quaternion.magnitude(this);\r\n\t\tconst x = this.x * inverseMagnitude;\r\n\t\tconst y = this.y * inverseMagnitude;\r\n\t\tconst z = this.z * inverseMagnitude;\r\n\t\tconst w = this.w * inverseMagnitude;\r\n\r\n\t\tthis.x = x;\r\n\t\tthis.y = y;\r\n\t\tthis.z = z;\r\n\t\tthis.w = w;\r\n\t\treturn this;\r\n\t}\r\n\tinvert() {\r\n\t\tthis.x *= -1;\r\n\t\tthis.y *= -1;\r\n\t\tthis.z *= -1;\r\n\r\n\t\treturn this;\r\n\t}\r\n\tdot(v: Quaternion): number {\r\n\t\treturn this.x * v.x + this.y * v.y + this.z * v.z + this.w * v.w;\r\n\t}\r\n\tsetFromUnitVectors(vFrom: Vector3, vTo: Vector3): Quaternion {\r\n\t\t// assumes direction vectors vFrom and vTo are normalized\r\n\t\tlet r = Vector3.dot(vFrom, vTo) + 1;\r\n\t\tif (r < Number.EPSILON) {\r\n\t\t\t// vFrom and vTo point in opposite directions\r\n\r\n\t\t\tr = 0;\r\n\r\n\t\t\tif (Math.abs(vFrom.x) > Math.abs(vFrom.z)) {\r\n\t\t\t\tthis.x = -vFrom.y;\r\n\t\t\t\tthis.y = vFrom.x;\r\n\t\t\t\tthis.z = 0;\r\n\t\t\t\tthis.w = r;\r\n\t\t\t} else {\r\n\t\t\t\tthis.x = 0;\r\n\t\t\t\tthis.y = -vFrom.z;\r\n\t\t\t\tthis.z = vFrom.y;\r\n\t\t\t\tthis.w = r;\r\n\t\t\t}\r\n\t\t} else {\r\n\t\t\t// crossVectors( vFrom, vTo ); // inlined to avoid cyclic dependency on Vector3\r\n\r\n\t\t\tthis.x = vFrom.y * vTo.z - vFrom.z * vTo.y;\r\n\t\t\tthis.y = vFrom.z * vTo.x - vFrom.x * vTo.z;\r\n\t\t\tthis.z = vFrom.x * vTo.y - vFrom.y * vTo.x;\r\n\t\t\tthis.w = r;\r\n\t\t}\r\n\r\n\t\treturn this.normalize();\r\n\t}\r\n\tsetFromRotationMatrix(matrix: Matrix4): Quaternion {\r\n\t\tconst te = matrix,\r\n\t\t\tm11 = te[0],\r\n\t\t\tm12 = te[4],\r\n\t\t\tm13 = te[8],\r\n\t\t\tm21 = te[1],\r\n\t\t\tm22 = te[5],\r\n\t\t\tm23 = te[9],\r\n\t\t\tm31 = te[2],\r\n\t\t\tm32 = te[6],\r\n\t\t\tm33 = te[10],\r\n\t\t\ttrace = m11 + m22 + m33;\r\n\r\n\t\tif (trace > 0) {\r\n\t\t\tconst s = 0.5 / Math.sqrt(trace + 1.0);\r\n\r\n\t\t\tthis.w = 0.25 / s;\r\n\t\t\tthis.x = (m32 - m23) * s;\r\n\t\t\tthis.y = (m13 - m31) * s;\r\n\t\t\tthis.z = (m21 - m12) * s;\r\n\t\t} else if (m11 > m22 && m11 > m33) {\r\n\t\t\tconst s = 2.0 * Math.sqrt(1.0 + m11 - m22 - m33);\r\n\r\n\t\t\tthis.w = (m32 - m23) / s;\r\n\t\t\tthis.x = 0.25 * s;\r\n\t\t\tthis.y = (m12 + m21) / s;\r\n\t\t\tthis.z = (m13 + m31) / s;\r\n\t\t} else if (m22 > m33) {\r\n\t\t\tconst s = 2.0 * Math.sqrt(1.0 + m22 - m11 - m33);\r\n\r\n\t\t\tthis.w = (m13 - m31) / s;\r\n\t\t\tthis.x = (m12 + m21) / s;\r\n\t\t\tthis.y = 0.25 * s;\r\n\t\t\tthis.z = (m23 + m32) / s;\r\n\t\t} else {\r\n\t\t\tconst s = 2.0 * Math.sqrt(1.0 + m33 - m11 - m22);\r\n\r\n\t\t\tthis.w = (m21 - m12) / s;\r\n\t\t\tthis.x = (m13 + m31) / s;\r\n\t\t\tthis.y = (m23 + m32) / s;\r\n\t\t\tthis.z = 0.25 * s;\r\n\t\t}\r\n\t\treturn this;\r\n\t}\r\n\tclone() {\r\n\t\treturn Quaternion.clone(this, this);\r\n\t}\r\n\r\n\tequals(right: Quaternion): boolean {\r\n\t\treturn Quaternion.equals(this, right);\r\n\t}\r\n\r\n\tequalsEpsilon(right: Quaternion, epsilon = 0): boolean {\r\n\t\treturn Quaternion.equalsEpsilon(this, right, epsilon);\r\n\t}\r\n\ttoArray(): number[] {\r\n\t\tconst { x, y, z, w } = this;\r\n\t\treturn [x, y, z, w];\r\n\t}\r\n\tstatic fromAxisAngle(axis: Vector3, angle: number): Quaternion {\r\n\t\tconst halfAngle = angle / 2.0;\r\n\t\tconst s = Math.sin(halfAngle);\r\n\t\tfromAxisAngleScratch = Vector3.normalize(axis, fromAxisAngleScratch);\r\n\r\n\t\tconst x = fromAxisAngleScratch.x * s;\r\n\t\tconst y = fromAxisAngleScratch.y * s;\r\n\t\tconst z = fromAxisAngleScratch.z * s;\r\n\t\tconst w = Math.cos(halfAngle);\r\n\t\t// if (!defined(result)) {\r\n\t\t//   return\r\n\t\t// }\r\n\t\tconst result = new Quaternion(x, y, z, w);\r\n\t\tresult.x = x;\r\n\t\tresult.y = y;\r\n\t\tresult.z = z;\r\n\t\tresult.w = w;\r\n\t\treturn result;\r\n\t}\r\n\r\n\t// static fromRotationMatrix(matrix: Matrix3, result: Quaternion): Quaternion {\r\n\t// \tlet root;\r\n\t// \tlet x;\r\n\t// \tlet y;\r\n\t// \tlet z;\r\n\t// \tlet w;\r\n\r\n\t// \tconst m00 = matrix[Matrix3.COLUMN0ROW0];\r\n\t// \tconst m11 = matrix[Matrix3.COLUMN1ROW1];\r\n\t// \tconst m22 = matrix[Matrix3.COLUMN2ROW2];\r\n\t// \tconst trace = m00 + m11 + m22;\r\n\r\n\t// \tif (trace > 0.0) {\r\n\t// \t\t// |w| > 1/2, may as well choose w > 1/2\r\n\t// \t\troot = Math.sqrt(trace + 1.0); // 2w\r\n\t// \t\tw = 0.5 * root;\r\n\t// \t\troot = 0.5 / root; // 1/(4w)\r\n\r\n\t// \t\tx = (matrix[Matrix3.COLUMN1ROW2] - matrix[Matrix3.COLUMN2ROW1]) * root;\r\n\t// \t\ty = (matrix[Matrix3.COLUMN2ROW0] - matrix[Matrix3.COLUMN0ROW2]) * root;\r\n\t// \t\tz = (matrix[Matrix3.COLUMN0ROW1] - matrix[Matrix3.COLUMN1ROW0]) * root;\r\n\t// \t} else {\r\n\t// \t\t// |w| <= 1/2\r\n\t// \t\tconst next = fromRotationMatrixNext;\r\n\r\n\t// \t\tlet i = 0;\r\n\t// \t\tif (m11 > m00) {\r\n\t// \t\t\ti = 1;\r\n\t// \t\t}\r\n\t// \t\tif (m22 > m00 && m22 > m11) {\r\n\t// \t\t\ti = 2;\r\n\t// \t\t}\r\n\t// \t\tconst j = next[i];\r\n\t// \t\tconst k = next[j];\r\n\r\n\t// \t\troot = Math.sqrt(\r\n\t// \t\t\tmatrix[Matrix3.getElementIndex(i, i)] -\r\n\t// \t\t\t\tmatrix[Matrix3.getElementIndex(j, j)] -\r\n\t// \t\t\t\tmatrix[Matrix3.getElementIndex(k, k)] +\r\n\t// \t\t\t\t1.0\r\n\t// \t\t);\r\n\r\n\t// \t\tconst quat = fromRotationMatrixQuat;\r\n\t// \t\tquat[i] = 0.5 * root;\r\n\t// \t\troot = 0.5 / root;\r\n\t// \t\tw = (matrix[Matrix3.getElementIndex(k, j)] - matrix[Matrix3.getElementIndex(j, k)]) * root;\r\n\t// \t\tquat[j] = (matrix[Matrix3.getElementIndex(j, i)] + matrix[Matrix3.getElementIndex(i, j)]) * root;\r\n\t// \t\tquat[k] = (matrix[Matrix3.getElementIndex(k, i)] + matrix[Matrix3.getElementIndex(i, k)]) * root;\r\n\r\n\t// \t\tx = -quat[0];\r\n\t// \t\ty = -quat[1];\r\n\t// \t\tz = -quat[2];\r\n\t// \t}\r\n\r\n\t// \tif (!defined(result)) {\r\n\t// \t\treturn new Quaternion(x, y, z, w);\r\n\t// \t}\r\n\t// \tresult.x = x;\r\n\t// \tresult.y = y;\r\n\t// \tresult.z = z;\r\n\t// \tresult.w = w;\r\n\t// \treturn result;\r\n\t// }\r\n\r\n\tstatic clone(quaternion: Quaternion, result: Quaternion): Quaternion {\r\n\t\tif (!defined(quaternion)) {\r\n\t\t\treturn undefined;\r\n\t\t}\r\n\r\n\t\tif (!defined(result)) {\r\n\t\t\treturn new Quaternion(quaternion.x, quaternion.y, quaternion.z, quaternion.w);\r\n\t\t}\r\n\r\n\t\tresult.x = quaternion.x;\r\n\t\tresult.y = quaternion.y;\r\n\t\tresult.z = quaternion.z;\r\n\t\tresult.w = quaternion.w;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic conjugate(quaternion: Quaternion, result: Quaternion): Quaternion {\r\n\t\tresult.x = -quaternion.x;\r\n\t\tresult.y = -quaternion.y;\r\n\t\tresult.z = -quaternion.z;\r\n\t\tresult.w = quaternion.w;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic magnitudeSquared(quaternion: Quaternion): number {\r\n\t\treturn (\r\n\t\t\tquaternion.x * quaternion.x +\r\n\t\t\tquaternion.y * quaternion.y +\r\n\t\t\tquaternion.z * quaternion.z +\r\n\t\t\tquaternion.w * quaternion.w\r\n\t\t);\r\n\t}\r\n\r\n\tstatic magnitude(quaternion: Quaternion): number {\r\n\t\treturn Math.sqrt(Quaternion.magnitudeSquared(quaternion));\r\n\t}\r\n\r\n\tstatic normalize(quaternion: Quaternion, result: Quaternion): Quaternion {\r\n\t\tconst inverseMagnitude = 1.0 / Quaternion.magnitude(quaternion);\r\n\t\tconst x = quaternion.x * inverseMagnitude;\r\n\t\tconst y = quaternion.y * inverseMagnitude;\r\n\t\tconst z = quaternion.z * inverseMagnitude;\r\n\t\tconst w = quaternion.w * inverseMagnitude;\r\n\r\n\t\tresult.x = x;\r\n\t\tresult.y = y;\r\n\t\tresult.z = z;\r\n\t\tresult.w = w;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic inverse(quaternion: Quaternion, result: Quaternion): Quaternion {\r\n\t\tconst magnitudeSquared = Quaternion.magnitudeSquared(quaternion);\r\n\t\tresult = Quaternion.conjugate(quaternion, result);\r\n\t\treturn Quaternion.multiplyByScalar(result, 1.0 / magnitudeSquared, result);\r\n\t}\r\n\r\n\tstatic add(left: Quaternion, right: Quaternion, result: Quaternion): Quaternion {\r\n\t\tresult.x = left.x + right.x;\r\n\t\tresult.y = left.y + right.y;\r\n\t\tresult.z = left.z + right.z;\r\n\t\tresult.w = left.w + right.w;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic subtract(left: Quaternion, right: Quaternion, result: Quaternion): Quaternion {\r\n\t\tresult.x = left.x - right.x;\r\n\t\tresult.y = left.y - right.y;\r\n\t\tresult.z = left.z - right.z;\r\n\t\tresult.w = left.w - right.w;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic negate(quaternion: Quaternion, result: Quaternion): Quaternion {\r\n\t\tresult.x = -quaternion.x;\r\n\t\tresult.y = -quaternion.y;\r\n\t\tresult.z = -quaternion.z;\r\n\t\tresult.w = -quaternion.w;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic dot(left: Quaternion, right: Quaternion): number {\r\n\t\treturn left.x * right.x + left.y * right.y + left.z * right.z + left.w * right.w;\r\n\t}\r\n\r\n\tstatic multiply(left: Quaternion, right: Quaternion, result: Quaternion): Quaternion {\r\n\t\tconst leftX = left.x;\r\n\t\tconst leftY = left.y;\r\n\t\tconst leftZ = left.z;\r\n\t\tconst leftW = left.w;\r\n\r\n\t\tconst rightX = right.x;\r\n\t\tconst rightY = right.y;\r\n\t\tconst rightZ = right.z;\r\n\t\tconst rightW = right.w;\r\n\r\n\t\tconst x = leftW * rightX + leftX * rightW + leftY * rightZ - leftZ * rightY;\r\n\t\tconst y = leftW * rightY - leftX * rightZ + leftY * rightW + leftZ * rightX;\r\n\t\tconst z = leftW * rightZ + leftX * rightY - leftY * rightX + leftZ * rightW;\r\n\t\tconst w = leftW * rightW - leftX * rightX - leftY * rightY - leftZ * rightZ;\r\n\r\n\t\tresult.x = x;\r\n\t\tresult.y = y;\r\n\t\tresult.z = z;\r\n\t\tresult.w = w;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic multiplyByScalar(quaternion: Quaternion, scalar: number, result: Quaternion): Quaternion {\r\n\t\tresult.x = quaternion.x * scalar;\r\n\t\tresult.y = quaternion.y * scalar;\r\n\t\tresult.z = quaternion.z * scalar;\r\n\t\tresult.w = quaternion.w * scalar;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic divideByScalar(quaternion: Quaternion, scalar: number, result: Quaternion): Quaternion {\r\n\t\tresult.x = quaternion.x / scalar;\r\n\t\tresult.y = quaternion.y / scalar;\r\n\t\tresult.z = quaternion.z / scalar;\r\n\t\tresult.w = quaternion.w / scalar;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic computeAxis(quaternion: Quaternion, result: Vector3): Vector3 {\r\n\t\tconst w = quaternion.w;\r\n\t\tif (Math.abs(w - 1.0) < GMath.EPSILON6) {\r\n\t\t\tresult.x = result.y = result.z = 0;\r\n\t\t\treturn result;\r\n\t\t}\r\n\r\n\t\tconst scalar = 1.0 / Math.sqrt(1.0 - w * w);\r\n\r\n\t\tresult.x = quaternion.x * scalar;\r\n\t\tresult.y = quaternion.y * scalar;\r\n\t\tresult.z = quaternion.z * scalar;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic computeAngle(quaternion: Quaternion): number {\r\n\t\tif (Math.abs(quaternion.w - 1.0) < GMath.EPSILON6) {\r\n\t\t\treturn 0.0;\r\n\t\t}\r\n\t\treturn 2.0 * Math.acos(quaternion.w);\r\n\t}\r\n\r\n\tstatic lerp(start: Quaternion, end: Quaternion, t: number, result: Quaternion): Quaternion {\r\n\t\tlerpScratch = Quaternion.multiplyByScalar(end, t, lerpScratch);\r\n\t\tresult = Quaternion.multiplyByScalar(start, 1.0 - t, result);\r\n\t\treturn Quaternion.add(lerpScratch, result, result);\r\n\t}\r\n\r\n\tstatic slerp(start: Quaternion, end: Quaternion, t: number, result: Quaternion): Quaternion {\r\n\t\tlet dot = Quaternion.dot(start, end);\r\n\r\n\t\t// The angle between start must be acute. Since q and -q represent\r\n\t\t// the same rotation, negate q to get the acute angle.\r\n\t\tlet r = end;\r\n\t\tif (dot < 0.0) {\r\n\t\t\tdot = -dot;\r\n\t\t\tr = slerpEndNegated = Quaternion.negate(end, slerpEndNegated);\r\n\t\t}\r\n\r\n\t\t// dot > 0, as the dot product approaches 1, the angle between the\r\n\t\t// quaternions vanishes. use linear interpolation.\r\n\t\tif (1.0 - dot < GMath.EPSILON6) {\r\n\t\t\treturn Quaternion.lerp(start, r, t, result);\r\n\t\t}\r\n\r\n\t\tconst theta = Math.acos(dot);\r\n\t\tslerpScaledP = Quaternion.multiplyByScalar(start, Math.sin((1 - t) * theta), slerpScaledP);\r\n\t\tslerpScaledR = Quaternion.multiplyByScalar(r, Math.sin(t * theta), slerpScaledR);\r\n\t\tresult = Quaternion.add(slerpScaledP, slerpScaledR, result);\r\n\t\treturn Quaternion.multiplyByScalar(result, 1.0 / Math.sin(theta), result);\r\n\t}\r\n\r\n\tstatic squad(\r\n\t\tq0: Quaternion,\r\n\t\tq1: Quaternion,\r\n\t\ts0: Quaternion,\r\n\t\ts1: Quaternion,\r\n\t\tt: number,\r\n\t\tresult: Quaternion\r\n\t): Quaternion {\r\n\t\tconst slerp0 = Quaternion.slerp(q0, q1, t, squadScratchQuaternion0);\r\n\t\tconst slerp1 = Quaternion.slerp(s0, s1, t, squadScratchQuaternion1);\r\n\t\treturn Quaternion.slerp(slerp0, slerp1, 2.0 * t * (1.0 - t), result);\r\n\t}\r\n\tstatic equals(left: Quaternion, right: Quaternion): boolean {\r\n\t\treturn (\r\n\t\t\tleft === right ||\r\n\t\t\t(defined(left) &&\r\n\t\t\t\tdefined(right) &&\r\n\t\t\t\tleft.x === right.x &&\r\n\t\t\t\tleft.y === right.y &&\r\n\t\t\t\tleft.z === right.z &&\r\n\t\t\t\tleft.w === right.w)\r\n\t\t);\r\n\t}\r\n\r\n\tstatic equalsEpsilon(left: Quaternion, right: Quaternion, epsilon = 0): boolean {\r\n\t\tepsilon = defaultValue(epsilon, 0);\r\n\r\n\t\treturn (\r\n\t\t\tleft === right ||\r\n\t\t\t(defined(left) &&\r\n\t\t\t\tdefined(right) &&\r\n\t\t\t\tMath.abs(left.x - right.x) <= epsilon &&\r\n\t\t\t\tMath.abs(left.y - right.y) <= epsilon &&\r\n\t\t\t\tMath.abs(left.z - right.z) <= epsilon &&\r\n\t\t\t\tMath.abs(left.w - right.w) <= epsilon)\r\n\t\t);\r\n\t}\r\n\r\n\tstatic exp(cartesian: Vector3, result: Quaternion): Quaternion {\r\n\t\tconst theta = Vector3.magnitude(cartesian);\r\n\t\tlet sinThetaOverTheta = 0.0;\r\n\r\n\t\tif (theta !== 0.0) {\r\n\t\t\tsinThetaOverTheta = Math.sin(theta) / theta;\r\n\t\t}\r\n\r\n\t\tresult.x = cartesian.x * sinThetaOverTheta;\r\n\t\tresult.y = cartesian.y * sinThetaOverTheta;\r\n\t\tresult.z = cartesian.z * sinThetaOverTheta;\r\n\t\tresult.w = Math.cos(theta);\r\n\r\n\t\treturn result;\r\n\t}\r\n}\r\n\r\nlet fromAxisAngleScratch = new Vector3();\r\n\r\nconst fromRotationMatrixNext = [1, 2, 0];\r\nconst fromRotationMatrixQuat = new Array(3);\r\n\r\nlet lerpScratch = new Quaternion();\r\n\r\nlet slerpEndNegated = new Quaternion();\r\nlet slerpScaledP = new Quaternion();\r\nlet slerpScaledR = new Quaternion();\r\n\r\nconst squadScratchCartesian0 = new Vector3();\r\nconst squadScratchCartesian1 = new Vector3();\r\nconst squadScratchQuaternion0 = new Quaternion();\r\nconst squadScratchQuaternion1 = new Quaternion();\r\n","import Matrix4 from \"../math/Matrix4\";\nimport { Quaternion } from \"../math/Quaternion\";\nimport Vector3 from \"../math/Vector3\";\nimport IClone from \"./IClone\";\nimport { RenderObjectType } from \"./WebGPUTypes\";\n\nexport default class RenderObject implements IClone {\n\tpublic up: Vector3;\n\tprotected _position: Vector3;\n\tprotected _scale: Vector3;\n\tprotected _quaternion: Quaternion;\n\tprotected _target: Vector3;\n\tprivate _normalMatrix: Matrix4;\n\tmodelMatrix: Matrix4;\n\tparent: RenderObject;\n\ttype: RenderObjectType;\n\tname: string;\n\tconstructor() {\n\t\tthis._position = new Vector3();\n\t\tthis._scale = new Vector3(1, 1, 1);\n\t\tthis._quaternion = new Quaternion();\n\t\tthis.modelMatrix = Matrix4.clone(Matrix4.IDENTITY, new Matrix4());\n\t\tthis._normalMatrix = Matrix4.clone(Matrix4.IDENTITY, new Matrix4());\n\t\tthis.up = new Vector3(0, 1, 0);\n\t\tthis._target = new Vector3(0, 0, 0);\n\t}\n\tpublic get normalMatrix(): Matrix4 {\n\t\treturn this._normalMatrix;\n\t}\n\n\tpublic get position(): Vector3 {\n\t\treturn this._position;\n\t}\n\tpublic get scale(): Vector3 {\n\t\treturn this._scale;\n\t}\n\tpublic get quaternion(): Quaternion {\n\t\treturn this._quaternion;\n\t}\n\tprivate updateNormalMatrix() {\n\t\tMatrix4.inverse(this.modelMatrix, this._normalMatrix);\n\t\tMatrix4.transpose(this._normalMatrix, this._normalMatrix);\n\t}\n\tupdateMatrix(matrix?: Matrix4) {\n\t\tthis.modelMatrix.compose(this.position, this.quaternion, this.scale);\n\t\tif (matrix) Matrix4.multiply(matrix, this.modelMatrix, this.modelMatrix);\n\t\tthis.updateNormalMatrix();\n\t}\n\tlookAt(x, y, z) {\n\t\tthis._target.set(x, y, z);\n\t\tif (this.type == RenderObjectType.Camera || this.type == RenderObjectType.Light) {\n\t\t\t_m1.lookAt(this.position, this._target, this.up);\n\t\t} else {\n\t\t\t_m1.lookAt(this._target, this.position, this.up);\n\t\t}\n\t\tthis.quaternion.setFromRotationMatrix(_m1);\n\t}\n\trotateOnAxis(axis, angle) {\n\t\tconst quat = Quaternion.fromAxisAngle(axis, angle);\n\t\tQuaternion.multiply(this.quaternion, quat, this.quaternion);\n\t}\n\trotateX(angle) {\n\t\treturn this.rotateOnAxis(_xAxis, angle);\n\t}\n\trotateY(angle) {\n\t\treturn this.rotateOnAxis(_yAxis, angle);\n\t}\n\trotateZ(angle) {\n\t\treturn this.rotateOnAxis(_zAxis, angle);\n\t}\n}\nconst _xAxis = new Vector3(1, 0, 0);\nconst _yAxis = new Vector3(0, 1, 0);\nconst _zAxis = new Vector3(0, 0, 1);\nconst _m1 = new Matrix4();\n","import RenderObject from \"../core/RenderObject\";\r\nimport { LightType, RenderObjectType } from \"../core/WebGPUTypes\";\r\nimport Vector3 from \"../math/Vector3\";\r\nimport { BaseShadow } from \"./shadows/BaseShadow\";\r\n\r\nexport class Light extends RenderObject {\r\n\tprivate _color: Vector3;\r\n\ttype: RenderObjectType;\r\n\tprivate _intensity: number;\r\n\tdirty: boolean;\r\n\tcolorDirty: boolean;\r\n\tshadowDirty: boolean;\r\n\tintensityDirty: boolean;\r\n\tpositionDirty: boolean;\r\n\tpublic _shadow: BaseShadow;\r\n\tpublic targetDirty: boolean;\r\n\tpublic lightType: LightType;\r\n\r\n\tconstructor(color: Vector3, intensity: number) {\r\n\t\tsuper();\r\n\t\tthis.type = RenderObjectType.Light;\r\n\t\tthis._color = Vector3.multiplyByScalar(color, intensity, new Vector3());\r\n\t\tthis._intensity = intensity;\r\n\t\tthis._position = new Vector3(0, 1, 0);\r\n\t\tthis._target = new Vector3();\r\n\t\tthis.positionDirty = true;\r\n\t\tthis.targetDirty = true;\r\n\t\tthis.colorDirty = true;\r\n\t\tthis.shadowDirty = true;\r\n\t\tthis.intensityDirty = true;\r\n\t\tthis._shadow = null;\r\n\t}\r\n\r\n\tget position() {\r\n\t\treturn this._position;\r\n\t}\r\n\r\n\tset position(value) {\r\n\t\tthis.positionDirty = true;\r\n\t\tthis._position = value;\r\n\t}\r\n\r\n\tget target() {\r\n\t\treturn this._target;\r\n\t}\r\n\r\n\tset target(value) {\r\n\t\tthis.targetDirty = true;\r\n\t\tthis._target = value;\r\n\t}\r\n\r\n\tget color() {\r\n\t\treturn this._color;\r\n\t}\r\n\r\n\tset color(value) {\r\n\t\tthis.colorDirty = true;\r\n\t\tthis._color = value;\r\n\t}\r\n\r\n\tset intensity(value) {\r\n\t\tthis.color = Vector3.multiplyByScalar(this.color, value, new Vector3());\r\n\t\tthis.intensityDirty = true;\r\n\t\tthis._intensity = value;\r\n\t}\r\n\r\n\tget intensity() {\r\n\t\treturn this._intensity;\r\n\t}\r\n\r\n\tget shadow() {\r\n\t\treturn this._shadow;\r\n\t}\r\n\r\n\tset shadow(value) {\r\n\t\tthis.shadowDirty = true;\r\n\t\tthis._shadow = value;\r\n\t}\r\n}\r\n","import defaultValue from \"../utils/defaultValue\";\r\nimport defined from \"../utils/defined\";\r\nimport GMath from \"./Math\";\r\n// #rgba\r\nconst rgbaMatcher = /^#([0-9a-f])([0-9a-f])([0-9a-f])([0-9a-f])?$/i;\r\n// #rrggbbaa\r\nconst rrggbbaaMatcher = /^#([0-9a-f]{2})([0-9a-f]{2})([0-9a-f]{2})([0-9a-f]{2})?$/i;\r\n// rgb(), rgba(), or rgb%()\r\nconst rgbParenthesesMatcher = /^rgba?\\(\\s*([0-9.]+%?)\\s*,\\s*([0-9.]+%?)\\s*,\\s*([0-9.]+%?)(?:\\s*,\\s*([0-9.]+))?\\s*\\)$/i;\r\n// hsl() or hsla()\r\nconst hslParenthesesMatcher = /^hsla?\\(\\s*([0-9.]+)\\s*,\\s*([0-9.]+%)\\s*,\\s*([0-9.]+%)(?:\\s*,\\s*([0-9.]+))?\\s*\\)$/i;\r\nfunction hue2rgb(m1, m2, h) {\r\n\tif (h < 0) {\r\n\t\th += 1;\r\n\t}\r\n\tif (h > 1) {\r\n\t\th -= 1;\r\n\t}\r\n\tif (h * 6 < 1) {\r\n\t\treturn m1 + (m2 - m1) * 6 * h;\r\n\t}\r\n\tif (h * 2 < 1) {\r\n\t\treturn m2;\r\n\t}\r\n\tif (h * 3 < 2) {\r\n\t\treturn m1 + (m2 - m1) * (2 / 3 - h) * 6;\r\n\t}\r\n\treturn m1;\r\n}\r\n\r\nclass Color {\r\n\tgreen: number;\r\n\tred: number;\r\n\tblue: number;\r\n\tconstructor(red = 1.0, green = 1.0, blue = 1.0) {\r\n\t\t/**\r\n\t\t * The red component.\r\n\t\t * @type {Number}\r\n\t\t * @default 1.0\r\n\t\t */\r\n\t\tthis.red = red;\r\n\t\t/**\r\n\t\t * The green component.\r\n\t\t * @type {Number}\r\n\t\t * @default 1.0\r\n\t\t */\r\n\t\tthis.green = green;\r\n\t\t/**\r\n\t\t * The blue component.\r\n\t\t * @type {Number}\r\n\t\t * @default 1.0\r\n\t\t */\r\n\t\tthis.blue = blue;\r\n\t}\r\n\tset(value: string): Color {\r\n\t\tif (typeof value === \"string\") {\r\n\t\t\tColor.fromCssColorString(value, this);\r\n\t\t}\r\n\t\treturn this;\r\n\t}\r\n\ttoArray(): number[] {\r\n\t\treturn [this.red, this.green, this.blue];\r\n\t}\r\n\r\n\tclone(result: Color): Color {\r\n\t\treturn Color.clone(this, result);\r\n\t}\r\n\r\n\tequals(other: Color): boolean {\r\n\t\treturn Color.equals(this, other);\r\n\t}\r\n\r\n\ttoCssHexString(): string {\r\n\t\tlet r = Color.floatToByte(this.red).toString(16);\r\n\t\tif (r.length < 2) {\r\n\t\t\tr = `0${r}`;\r\n\t\t}\r\n\t\tlet g = Color.floatToByte(this.green).toString(16);\r\n\t\tif (g.length < 2) {\r\n\t\t\tg = `0${g}`;\r\n\t\t}\r\n\t\tlet b = Color.floatToByte(this.blue).toString(16);\r\n\t\tif (b.length < 2) {\r\n\t\t\tb = `0${b}`;\r\n\t\t}\r\n\t\treturn `#${r}${g}${b}`;\r\n\t}\r\n\r\n\ttoBytes(result: number[]): number[] {\r\n\t\tconst red = Color.floatToByte(this.red);\r\n\t\tconst green = Color.floatToByte(this.green);\r\n\t\tconst blue = Color.floatToByte(this.blue);\r\n\r\n\t\tif (!defined(result)) {\r\n\t\t\treturn [red, green, blue];\r\n\t\t}\r\n\t\tresult[0] = red;\r\n\t\tresult[1] = green;\r\n\t\tresult[2] = blue;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic fromBytes(red: number, green: number, blue: number, result: Color): Color {\r\n\t\tred = Color.byteToFloat(defaultValue(red, 255.0));\r\n\t\tgreen = Color.byteToFloat(defaultValue(green, 255.0));\r\n\t\tblue = Color.byteToFloat(defaultValue(blue, 255.0));\r\n\r\n\t\tif (!defined(result)) {\r\n\t\t\treturn new Color(red, green, blue);\r\n\t\t}\r\n\r\n\t\tresult.red = red;\r\n\t\tresult.green = green;\r\n\t\tresult.blue = blue;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic fromHsl(hue: number, saturation: number, lightness: number, result: Color): Color {\r\n\t\thue = defaultValue(hue, 0.0) % 1.0;\r\n\t\tsaturation = defaultValue(saturation, 0.0);\r\n\t\tlightness = defaultValue(lightness, 0.0);\r\n\t\tlet red = lightness;\r\n\t\tlet green = lightness;\r\n\t\tlet blue = lightness;\r\n\r\n\t\tif (saturation !== 0) {\r\n\t\t\tlet m2;\r\n\t\t\tif (lightness < 0.5) {\r\n\t\t\t\tm2 = lightness * (1 + saturation);\r\n\t\t\t} else {\r\n\t\t\t\tm2 = lightness + saturation - lightness * saturation;\r\n\t\t\t}\r\n\r\n\t\t\tconst m1 = 2.0 * lightness - m2;\r\n\t\t\tred = hue2rgb(m1, m2, hue + 1 / 3);\r\n\t\t\tgreen = hue2rgb(m1, m2, hue);\r\n\t\t\tblue = hue2rgb(m1, m2, hue - 1 / 3);\r\n\t\t}\r\n\r\n\t\tif (!defined(result)) {\r\n\t\t\treturn new Color(red, green, blue);\r\n\t\t}\r\n\r\n\t\tresult.red = red;\r\n\t\tresult.green = green;\r\n\t\tresult.blue = blue;\r\n\t\treturn result;\r\n\t}\r\n\r\n\t/**\r\n\t * Creates a random color using the provided options. For reproducible random colors, you should\r\n\t * call {@link GMath#setRandomNumberSeed} once at the beginning of your application.\r\n\t *\r\n\t * @param {Object} [options] Object with the following properties:\r\n\t * @param {Number} [options.red] If specified, the red component to use instead of a randomized value.\r\n\t * @param {Number} [options.minimumRed=0.0] The maximum red value to generate if none was specified.\r\n\t * @param {Number} [options.maximumRed=1.0] The minimum red value to generate if none was specified.\r\n\t * @param {Number} [options.green] If specified, the green component to use instead of a randomized value.\r\n\t * @param {Number} [options.minimumGreen=0.0] The maximum green value to generate if none was specified.\r\n\t * @param {Number} [options.maximumGreen=1.0] The minimum green value to generate if none was specified.\r\n\t * @param {Number} [options.blue] If specified, the blue component to use instead of a randomized value.\r\n\t * @param {Number} [options.minimumBlue=0.0] The maximum blue value to generate if none was specified.\r\n\t * @param {Number} [options.maximumBlue=1.0] The minimum blue value to generate if none was specified.\r\n\t * @param {Color} [result] The object to store the result in, if undefined a new instance will be created.\r\n\t * @returns {Color} The modified result parameter or a new instance if result was undefined.\r\n\t *\r\n\t * @example\r\n\t * //Create a completely random color\r\n\t * const color = Color.fromRandom();\r\n\t *\r\n\t * //Create a random shade of yellow.\r\n\t * const color1 = Color.fromRandom({\r\n\t *     red : 1.0,\r\n\t *     green : 1.0,\r\n\t * });\r\n\t *\r\n\t * //Create a random bright color.\r\n\t * const color2 = Color.fromRandom({\r\n\t *     minimumRed : 0.75,\r\n\t *     minimumGreen : 0.75,\r\n\t *     minimumBlue : 0.75,\r\n\t * });\r\n\t */\r\n\tstatic fromRandom(options, result: Color): Color {\r\n\t\toptions = defaultValue(options, defaultValue.EMPTY_OBJECT);\r\n\r\n\t\tlet red = options.red;\r\n\t\tif (!defined(red)) {\r\n\t\t\tconst minimumRed = defaultValue(options.minimumRed, 0);\r\n\t\t\tconst maximumRed = defaultValue(options.maximumRed, 1.0);\r\n\r\n\t\t\tred = minimumRed + GMath.nextRandomNumber() * (maximumRed - minimumRed);\r\n\t\t}\r\n\r\n\t\tlet green = options.green;\r\n\t\tif (!defined(green)) {\r\n\t\t\tconst minimumGreen = defaultValue(options.minimumGreen, 0);\r\n\t\t\tconst maximumGreen = defaultValue(options.maximumGreen, 1.0);\r\n\r\n\t\t\tgreen = minimumGreen + GMath.nextRandomNumber() * (maximumGreen - minimumGreen);\r\n\t\t}\r\n\r\n\t\tlet blue = options.blue;\r\n\t\tif (!defined(blue)) {\r\n\t\t\tconst minimumBlue = defaultValue(options.minimumBlue, 0);\r\n\t\t\tconst maximumBlue = defaultValue(options.maximumBlue, 1.0);\r\n\r\n\t\t\tblue = minimumBlue + GMath.nextRandomNumber() * (maximumBlue - minimumBlue);\r\n\t\t}\r\n\t\tif (!defined(result)) {\r\n\t\t\treturn new Color(red, green, blue);\r\n\t\t}\r\n\r\n\t\tresult.red = red;\r\n\t\tresult.green = green;\r\n\t\tresult.blue = blue;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic fromCssColorString(color: string, result: Color = new Color()): Color {\r\n\t\t// Remove all whitespaces from the color string\r\n\t\tcolor = color.replace(/\\s/g, \"\");\r\n\r\n\t\tconst namedColor = Color[color.toUpperCase()];\r\n\t\tif (defined(namedColor)) {\r\n\t\t\tColor.clone(namedColor, result);\r\n\t\t\treturn result;\r\n\t\t}\r\n\r\n\t\tlet matches = rgbaMatcher.exec(color);\r\n\t\tif (matches !== null) {\r\n\t\t\tresult.red = parseInt(matches[1], 16) / 15;\r\n\t\t\tresult.green = parseInt(matches[2], 16) / 15.0;\r\n\t\t\tresult.blue = parseInt(matches[3], 16) / 15.0;\r\n\t\t\treturn result;\r\n\t\t}\r\n\r\n\t\tmatches = rrggbbaaMatcher.exec(color);\r\n\t\tif (matches !== null) {\r\n\t\t\tresult.red = parseInt(matches[1], 16) / 255.0;\r\n\t\t\tresult.green = parseInt(matches[2], 16) / 255.0;\r\n\t\t\tresult.blue = parseInt(matches[3], 16) / 255.0;\r\n\t\t\treturn result;\r\n\t\t}\r\n\r\n\t\tmatches = rgbParenthesesMatcher.exec(color);\r\n\t\tif (matches !== null) {\r\n\t\t\tresult.red = parseFloat(matches[1]) / (\"%\" === matches[1].substr(-1) ? 100.0 : 255.0);\r\n\t\t\tresult.green = parseFloat(matches[2]) / (\"%\" === matches[2].substr(-1) ? 100.0 : 255.0);\r\n\t\t\tresult.blue = parseFloat(matches[3]) / (\"%\" === matches[3].substr(-1) ? 100.0 : 255.0);\r\n\t\t\treturn result;\r\n\t\t}\r\n\r\n\t\tmatches = hslParenthesesMatcher.exec(color);\r\n\t\tif (matches !== null) {\r\n\t\t\treturn Color.fromHsl(\r\n\t\t\t\tparseFloat(matches[1]) / 360.0,\r\n\t\t\t\tparseFloat(matches[2]) / 100.0,\r\n\t\t\t\tparseFloat(matches[3]) / 100.0,\r\n\t\t\t\tresult\r\n\t\t\t);\r\n\t\t}\r\n\r\n\t\tresult = undefined;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic byteToFloat(value: number): number {\r\n\t\treturn value / 255.0;\r\n\t}\r\n\r\n\tstatic floatToByte(value: number): number {\r\n\t\treturn value === 1.0 ? 255.0 : (value * 256.0) | 0;\r\n\t}\r\n\r\n\tstatic clone(color: Color, result: Color): Color {\r\n\t\tif (!defined(color)) {\r\n\t\t\treturn undefined;\r\n\t\t}\r\n\t\tif (!defined(result)) {\r\n\t\t\treturn new Color(color.red, color.green, color.blue);\r\n\t\t}\r\n\t\tresult.red = color.red;\r\n\t\tresult.green = color.green;\r\n\t\tresult.blue = color.blue;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic equals(left: Color, right: Color): boolean {\r\n\t\treturn (\r\n\t\t\tleft === right || //\r\n\t\t\t(defined(left) && //\r\n\t\t\t\tdefined(right) && //\r\n\t\t\t\tleft.red === right.red && //\r\n\t\t\t\tleft.green === right.green && //\r\n\t\t\t\tleft.blue === right.blue)\r\n\t\t);\r\n\t}\r\n\r\n\t/**\r\n\t * @private\r\n\t */\r\n\tstatic equalsArray(color: Color, array: number[], offset: number): boolean {\r\n\t\treturn color.red === array[offset] && color.green === array[offset + 1] && color.blue === array[offset + 2];\r\n\t}\r\n}\r\nexport default Color;\r\n","import defaultValue from \"../utils/defaultValue\";\r\nimport defined from \"../utils/defined\";\r\nimport Vector2 from \"./Vector2\";\r\n\r\n/**\r\n * A 2x2 matrix, indexable as a column-major order array.\r\n * @param {Number} [column0Row0=0.0] The value for column 0, row 0.\r\n * @param {Number} [column1Row0=0.0] The value for column 1, row 0.\r\n * @param {Number} [column0Row1=0.0] The value for column 0, row 1.\r\n * @param {Number} [column1Row1=0.0] The value for column 1, row 1.\r\n */\r\nclass Matrix2 {\r\n\tconstructor(column0Row0 = 0, column1Row0 = 0, column0Row1 = 0, column1Row1 = 0) {\r\n\t\tthis[0] = column0Row0;\r\n\t\tthis[1] = column0Row1;\r\n\t\tthis[2] = column1Row0;\r\n\t\tthis[3] = column1Row1;\r\n\t}\r\n\r\n\tstatic clone(matrix: Matrix2 | number[], result: Matrix2): Matrix2 {\r\n\t\tif (!defined(matrix)) {\r\n\t\t\treturn undefined;\r\n\t\t}\r\n\t\tif (!defined(result)) {\r\n\t\t\treturn new Matrix2(matrix[0], matrix[2], matrix[1], matrix[3]);\r\n\t\t}\r\n\t\tresult[0] = matrix[0];\r\n\t\tresult[1] = matrix[1];\r\n\t\tresult[2] = matrix[2];\r\n\t\tresult[3] = matrix[3];\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic fromColumnMajorArray(values: number[], result: Matrix2): Matrix2 {\r\n\t\treturn Matrix2.clone(values, result);\r\n\t}\r\n\r\n\tstatic fromRowMajorArray(values: number, result: Matrix2): Matrix2 {\r\n\t\tif (!defined(result)) {\r\n\t\t\treturn new Matrix2(values[0], values[1], values[2], values[3]);\r\n\t\t}\r\n\t\tresult[0] = values[0];\r\n\t\tresult[1] = values[2];\r\n\t\tresult[2] = values[1];\r\n\t\tresult[3] = values[3];\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic fromScale(scale: Vector2, result: Matrix2): Matrix2 {\r\n\t\tif (!defined(result)) {\r\n\t\t\treturn new Matrix2(scale.x, 0.0, 0.0, scale.y);\r\n\t\t}\r\n\r\n\t\tresult[0] = scale.x;\r\n\t\tresult[1] = 0.0;\r\n\t\tresult[2] = 0.0;\r\n\t\tresult[3] = scale.y;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic fromRotation(angle: number, result: Matrix2): Matrix2 {\r\n\t\tconst cosAngle = Math.cos(angle);\r\n\t\tconst sinAngle = Math.sin(angle);\r\n\r\n\t\tif (!defined(result)) {\r\n\t\t\treturn new Matrix2(cosAngle, -sinAngle, sinAngle, cosAngle);\r\n\t\t}\r\n\t\tresult[0] = cosAngle;\r\n\t\tresult[1] = sinAngle;\r\n\t\tresult[2] = -sinAngle;\r\n\t\tresult[3] = cosAngle;\r\n\t\treturn result;\r\n\t}\r\n\ttoArray() {\r\n\t\tconst result = [];\r\n\t\tMatrix2.toArray(this, result);\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic toArray(matrix: Matrix2, result: number[]): number[] {\r\n\t\tif (!defined(result)) {\r\n\t\t\treturn [matrix[0], matrix[1], matrix[2], matrix[3]];\r\n\t\t}\r\n\t\tresult[0] = matrix[0];\r\n\t\tresult[1] = matrix[1];\r\n\t\tresult[2] = matrix[2];\r\n\t\tresult[3] = matrix[3];\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic getElementIndex(column: number, row: number): number {\r\n\t\treturn column * 2 + row;\r\n\t}\r\n\r\n\tstatic getColumn(matrix: Matrix2, index: number, result: Vector2): Vector2 {\r\n\t\tconst startIndex = index * 2;\r\n\t\tconst x = matrix[startIndex];\r\n\t\tconst y = matrix[startIndex + 1];\r\n\r\n\t\tresult.x = x;\r\n\t\tresult.y = y;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic setColumn(matrix: Matrix2, index: number, cartesian: Vector2, result: Matrix2): Matrix2 {\r\n\t\tresult = Matrix2.clone(matrix, result);\r\n\t\tconst startIndex = index * 2;\r\n\t\tresult[startIndex] = cartesian.x;\r\n\t\tresult[startIndex + 1] = cartesian.y;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic getRow(matrix: Matrix2, index: number, result: Vector2): Vector2 {\r\n\t\tconst x = matrix[index];\r\n\t\tconst y = matrix[index + 2];\r\n\r\n\t\tresult.x = x;\r\n\t\tresult.y = y;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic setRow(matrix: Matrix2, index: number, cartesian: Vector2, result: Matrix2): Matrix2 {\r\n\t\tresult = Matrix2.clone(matrix, result);\r\n\t\tresult[index] = cartesian.x;\r\n\t\tresult[index + 2] = cartesian.y;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic setScale(matrix: Matrix2, scale: Vector2, result: Matrix2): Matrix2 {\r\n\t\tconst existingScale = Matrix2.getScale(matrix, scaleScratch1);\r\n\t\tconst scaleRatioX = scale.x / existingScale.x;\r\n\t\tconst scaleRatioY = scale.y / existingScale.y;\r\n\r\n\t\tresult[0] = matrix[0] * scaleRatioX;\r\n\t\tresult[1] = matrix[1] * scaleRatioX;\r\n\t\tresult[2] = matrix[2] * scaleRatioY;\r\n\t\tresult[3] = matrix[3] * scaleRatioY;\r\n\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic getScale(matrix: Matrix2, result: Vector2): Vector2 {\r\n\t\tresult.x = Vector2.magnitude(Vector2.fromElements(matrix[0], matrix[1], scratchColumn));\r\n\t\tresult.y = Vector2.magnitude(Vector2.fromElements(matrix[2], matrix[3], scratchColumn));\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic getMaximumScale(matrix: Matrix2): number {\r\n\t\tMatrix2.getScale(matrix, scaleScratch3);\r\n\t\treturn Vector2.maximumComponent(scaleScratch3);\r\n\t}\r\n\r\n\tstatic setRotation(matrix: Matrix2, rotation: Matrix2, result: Matrix2): Matrix2 {\r\n\t\tconst scale = Matrix2.getScale(matrix, scaleScratch4);\r\n\r\n\t\tresult[0] = rotation[0] * scale.x;\r\n\t\tresult[1] = rotation[1] * scale.x;\r\n\t\tresult[2] = rotation[2] * scale.y;\r\n\t\tresult[3] = rotation[3] * scale.y;\r\n\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic getRotation(matrix: Matrix2, result: Matrix2): Matrix2 {\r\n\t\tconst scale = Matrix2.getScale(matrix, scaleScratch5);\r\n\r\n\t\tresult[0] = matrix[0] / scale.x;\r\n\t\tresult[1] = matrix[1] / scale.x;\r\n\t\tresult[2] = matrix[2] / scale.y;\r\n\t\tresult[3] = matrix[3] / scale.y;\r\n\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic multiply(left: Matrix2, right: Matrix2, result: Matrix2): Matrix2 {\r\n\t\tconst column0Row0 = left[0] * right[0] + left[2] * right[1];\r\n\t\tconst column1Row0 = left[0] * right[2] + left[2] * right[3];\r\n\t\tconst column0Row1 = left[1] * right[0] + left[3] * right[1];\r\n\t\tconst column1Row1 = left[1] * right[2] + left[3] * right[3];\r\n\r\n\t\tresult[0] = column0Row0;\r\n\t\tresult[1] = column0Row1;\r\n\t\tresult[2] = column1Row0;\r\n\t\tresult[3] = column1Row1;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic add(left: Matrix2, right: Matrix2, result: Matrix2) {\r\n\t\tresult[0] = left[0] + right[0];\r\n\t\tresult[1] = left[1] + right[1];\r\n\t\tresult[2] = left[2] + right[2];\r\n\t\tresult[3] = left[3] + right[3];\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic subtract(left: Matrix2, right: Matrix2, result: Matrix2): Matrix2 {\r\n\t\tresult[0] = left[0] - right[0];\r\n\t\tresult[1] = left[1] - right[1];\r\n\t\tresult[2] = left[2] - right[2];\r\n\t\tresult[3] = left[3] - right[3];\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic multiplyByVector(matrix: Matrix2, cartesian: Vector2, result: Vector2): Vector2 {\r\n\t\tconst x = matrix[0] * cartesian.x + matrix[2] * cartesian.y;\r\n\t\tconst y = matrix[1] * cartesian.x + matrix[3] * cartesian.y;\r\n\r\n\t\tresult.x = x;\r\n\t\tresult.y = y;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic multiplyByScalar(matrix: Matrix2, scalar: number, result: Matrix2): Matrix2 {\r\n\t\tresult[0] = matrix[0] * scalar;\r\n\t\tresult[1] = matrix[1] * scalar;\r\n\t\tresult[2] = matrix[2] * scalar;\r\n\t\tresult[3] = matrix[3] * scalar;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic multiplyByScale(matrix: Matrix2, scale: Vector2, result: Matrix2): Matrix2 {\r\n\t\tresult[0] = matrix[0] * scale.x;\r\n\t\tresult[1] = matrix[1] * scale.x;\r\n\t\tresult[2] = matrix[2] * scale.y;\r\n\t\tresult[3] = matrix[3] * scale.y;\r\n\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic negate(matrix: Matrix2, result: Matrix2): Matrix2 {\r\n\t\tresult[0] = -matrix[0];\r\n\t\tresult[1] = -matrix[1];\r\n\t\tresult[2] = -matrix[2];\r\n\t\tresult[3] = -matrix[3];\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic transpose(matrix: Matrix2, result: Matrix2): Matrix2 {\r\n\t\tconst column0Row0 = matrix[0];\r\n\t\tconst column0Row1 = matrix[2];\r\n\t\tconst column1Row0 = matrix[1];\r\n\t\tconst column1Row1 = matrix[3];\r\n\r\n\t\tresult[0] = column0Row0;\r\n\t\tresult[1] = column0Row1;\r\n\t\tresult[2] = column1Row0;\r\n\t\tresult[3] = column1Row1;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic abs(matrix: Matrix2, result: Matrix2): Matrix2 {\r\n\t\tresult[0] = Math.abs(matrix[0]);\r\n\t\tresult[1] = Math.abs(matrix[1]);\r\n\t\tresult[2] = Math.abs(matrix[2]);\r\n\t\tresult[3] = Math.abs(matrix[3]);\r\n\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic equals(left: Matrix2, right: Matrix2): boolean {\r\n\t\treturn (\r\n\t\t\tleft === right ||\r\n\t\t\t(defined(left) &&\r\n\t\t\t\tdefined(right) &&\r\n\t\t\t\tleft[0] === right[0] &&\r\n\t\t\t\tleft[1] === right[1] &&\r\n\t\t\t\tleft[2] === right[2] &&\r\n\t\t\t\tleft[3] === right[3])\r\n\t\t);\r\n\t}\r\n\r\n\t/**\r\n\t * @private\r\n\t */\r\n\tstatic equalsArray(matrix: Matrix2, array: number[], offset: number): boolean {\r\n\t\treturn (\r\n\t\t\tmatrix[0] === array[offset] &&\r\n\t\t\tmatrix[1] === array[offset + 1] &&\r\n\t\t\tmatrix[2] === array[offset + 2] &&\r\n\t\t\tmatrix[3] === array[offset + 3]\r\n\t\t);\r\n\t}\r\n\r\n\tstatic equalsEpsilon(left: Matrix2, right: Matrix2, epsilon = 0): boolean {\r\n\t\tepsilon = defaultValue(epsilon, 0);\r\n\t\treturn (\r\n\t\t\tleft === right ||\r\n\t\t\t(defined(left) &&\r\n\t\t\t\tdefined(right) &&\r\n\t\t\t\tMath.abs(left[0] - right[0]) <= epsilon &&\r\n\t\t\t\tMath.abs(left[1] - right[1]) <= epsilon &&\r\n\t\t\t\tMath.abs(left[2] - right[2]) <= epsilon &&\r\n\t\t\t\tMath.abs(left[3] - right[3]) <= epsilon)\r\n\t\t);\r\n\t}\r\n\r\n\tpublic static IDENTITY = Object.freeze(new Matrix2(1.0, 0.0, 0.0, 1.0));\r\n\r\n\tpublic static ZERO = Object.freeze(new Matrix2(0.0, 0.0, 0.0, 0.0));\r\n\r\n\tclone(result: Matrix2): Matrix2 {\r\n\t\treturn Matrix2.clone(this, result);\r\n\t}\r\n\r\n\tequals(right: Matrix2): boolean {\r\n\t\treturn Matrix2.equals(this, right);\r\n\t}\r\n\r\n\tequalsEpsilon(right: Matrix2, epsilon = 0): boolean {\r\n\t\treturn Matrix2.equalsEpsilon(this, right, epsilon);\r\n\t}\r\n\r\n\ttoString() {\r\n\t\treturn `(${this[0]}, ${this[2]})\\n` + `(${this[1]}, ${this[3]})`;\r\n\t}\r\n}\r\nconst scaleScratch1 = new Vector2();\r\nconst scaleScratch2 = new Vector2();\r\nconst scaleScratch3 = new Vector2();\r\nconst scaleScratch4 = new Vector2();\r\nconst scratchColumn = new Vector2();\r\nconst scaleScratch5 = new Vector2();\r\nexport default Matrix2;\r\n","import { ShaderStage } from \"../core/WebGPUConstant\";\r\nimport { DirectionalLight } from \"../light/DirectionalLight\";\r\nimport { PointLight } from \"../light/PointLight\";\r\nimport { SpotLight } from \"../light/SpotLight\";\r\nimport Color from \"../math/Color\";\r\nimport Matrix2 from \"../math/Matrix2\";\r\nimport Matrix3 from \"../math/Matrix3\";\r\nimport Matrix4 from \"../math/Matrix4\";\r\nimport Vector2 from \"../math/Vector2\";\r\nimport Vector3 from \"../math/Vector3\";\r\nimport Vector4 from \"../math/Vector4\";\r\nimport defaultValue from \"../utils/defaultValue\";\r\nimport Context from \"./Context\";\r\nimport Sampler from \"./Sampler\";\r\nimport Texture from \"./Texture\";\r\nimport UniformBuffer from \"./UniformBuffer\";\r\nexport class Uniform<T> {\r\n\t_value: T;\r\n\tname: string;\r\n\tvalue: T;\r\n\toffset: number;\r\n\tbuffer: Float32Array | Uint16Array | Uint32Array | Uint8Array | Float64Array | UniformBuffer;\r\n\tcb: Function | number | Object;\r\n\tbyteSize: number;\r\n\tvisibility?: number;\r\n\ttype?: string;\r\n\tdirty?: boolean;\r\n\r\n\tconstructor(uniformName: string, cb?: Function | number | Object, offset?: number) {\r\n\t\tthis.name = uniformName;\r\n\t\tthis.cb = cb;\r\n\t\tthis.offset = defaultValue(offset, 0);\r\n\t\tthis.visibility = ShaderStage.Vertex | ShaderStage.Fragment;\r\n\t\tthis.type = \"number\";\r\n\t}\r\n\tsetBuffer(array: Array<number>, offset = 0) {\r\n\t\tfor (let i = 0; i < array.length; i++) {\r\n\t\t\tthis.buffer[i + offset] = array[i];\r\n\t\t}\r\n\t}\r\n\tset() {\r\n\t\treturn undefined;\r\n\t}\r\n\tgetValue() {\r\n\t\tlet result;\r\n\t\tconst cbType = typeof this.cb;\r\n\t\tswitch (cbType) {\r\n\t\t\tcase \"object\":\r\n\t\t\t\tresult = this.cb[this.name] || this.cb;\r\n\t\t\t\tbreak;\r\n\t\t\tcase \"function\":\r\n\t\t\t\t// @ts-ignore\r\n\t\t\t\tresult = this.cb();\r\n\t\t\t\tbreak;\r\n\t\t\tcase \"number\":\r\n\t\t\t\tresult = this.cb;\r\n\t\t\t\tbreak;\r\n\t\t\tdefault:\r\n\t\t\t\tthrow new Error(\"type is error\");\r\n\t\t\t\tbreak;\r\n\t\t}\r\n\t\treturn result;\r\n\t}\r\n}\r\n\r\nexport class UniformUint extends Uniform<number> {\r\n\tstatic align = 4;\r\n\tconstructor(\r\n\t\tuniformName: string,\r\n\t\tbuffer: Float32Array,\r\n\t\tbyteOffset: number,\r\n\t\tcb: Function | number | Object,\r\n\t\toffset?: number\r\n\t) {\r\n\t\tsuper(uniformName, cb, offset);\r\n\t\tthis.value = undefined;\r\n\t\tthis._value = 0;\r\n\t\tthis.byteSize = 4;\r\n\t\tthis.buffer = new Uint32Array(buffer.buffer, byteOffset, 1);\r\n\t\tthis.type = \"uint\";\r\n\t}\r\n\tset() {\r\n\t\tif (this.cb != undefined) this.value = this.getValue();\r\n\t\tif (this.value !== this._value) {\r\n\t\t\tthis._value = this.value;\r\n\t\t\tthis.buffer[0] = this.value;\r\n\t\t\treturn true;\r\n\t\t}\r\n\t\treturn false;\r\n\t}\r\n}\r\n\r\nexport class UniformFloat extends Uniform<number> {\r\n\tstatic align = 4;\r\n\tconstructor(\r\n\t\tuniformName: string,\r\n\t\tbuffer: Float32Array,\r\n\t\tbyteOffset: number,\r\n\t\tcb: Function | number | Object,\r\n\t\toffset?: number\r\n\t) {\r\n\t\tsuper(uniformName, cb, offset);\r\n\t\tthis.value = undefined;\r\n\t\tthis._value = 0;\r\n\t\tthis.byteSize = 4;\r\n\t\tthis.buffer = new Float32Array(buffer.buffer, byteOffset, 1);\r\n\t\tthis.type = \"vec1\";\r\n\t}\r\n\tset() {\r\n\t\tif (this.cb != undefined) this.value = this.getValue();\r\n\t\tif (this.value !== this._value) {\r\n\t\t\tthis._value = this.value;\r\n\t\t\tthis.buffer[0] = this.value;\r\n\t\t\treturn true;\r\n\t\t}\r\n\t\treturn false;\r\n\t}\r\n}\r\nexport class UniformFloatVec2 extends Uniform<Vector2> {\r\n\tstatic align = 8;\r\n\tconstructor(\r\n\t\tuniformName: string,\r\n\t\tbuffer: Float32Array,\r\n\t\tbyteOffset: number,\r\n\t\tcb: Function | number | Object,\r\n\t\toffset?: number\r\n\t) {\r\n\t\tsuper(uniformName, cb, offset);\r\n\t\tthis.value = undefined;\r\n\t\tthis._value = new Vector2();\r\n\t\tthis.buffer = new Float32Array(buffer.buffer, byteOffset, 2);\r\n\t\tthis.byteSize = 8;\r\n\t\tthis.type = \"vec2\";\r\n\t}\r\n\tset(): boolean {\r\n\t\tif (this.cb != undefined) this.value = this.getValue();\r\n\t\tconst v = this.value;\r\n\t\tif (!Vector2.equals(v, this._value)) {\r\n\t\t\tVector2.clone(v, this._value);\r\n\t\t\tthis.setBuffer(this._value.toArray());\r\n\t\t\treturn true;\r\n\t\t}\r\n\t\treturn false;\r\n\t}\r\n}\r\nexport class UniformFloatVec3 extends Uniform<Vector3> {\r\n\tstatic align = 16;\r\n\tconstructor(\r\n\t\tuniformName: string,\r\n\t\tbuffer: Float32Array,\r\n\t\tbyteOffset: number,\r\n\t\tcb: Function | number | Object,\r\n\t\toffset?: number\r\n\t) {\r\n\t\tsuper(uniformName, cb, offset);\r\n\t\tthis.value = undefined;\r\n\t\tthis._value = new Vector3();\r\n\t\tthis.buffer = new Float32Array(buffer.buffer, byteOffset, 3);\r\n\t\tthis.byteSize = 12;\r\n\t\tthis.type = \"vec3\";\r\n\t}\r\n\tset(): boolean {\r\n\t\tif (this.cb != undefined) this.value = this.getValue();\r\n\t\tconst v = this.value;\r\n\t\tif (!Vector3.equals(v, this._value)) {\r\n\t\t\tVector3.clone(v, this._value);\r\n\t\t\tthis.setBuffer(this._value.toArray());\r\n\t\t\treturn true;\r\n\t\t}\r\n\t\treturn false;\r\n\t}\r\n}\r\nexport class UniformFloatVec4 extends Uniform<Vector4> {\r\n\tstatic align = 16;\r\n\tconstructor(\r\n\t\tuniformName: string,\r\n\t\tbuffer: Float32Array,\r\n\t\tbyteOffset: number,\r\n\t\tcb: Function | number | Object,\r\n\t\toffset?: number\r\n\t) {\r\n\t\tsuper(uniformName, cb, offset);\r\n\t\tthis.value = undefined;\r\n\t\tthis._value = new Vector4();\r\n\t\tthis.buffer = new Float32Array(buffer.buffer, byteOffset, 4);\r\n\t\tthis.byteSize = 16;\r\n\t\tthis.type = \"vec4\";\r\n\t}\r\n\tset(): boolean {\r\n\t\tif (this.cb != undefined) this.value = this.getValue();\r\n\t\tconst v = this.value;\r\n\t\tif (!Vector4.equals(v, this._value)) {\r\n\t\t\tVector4.clone(v, this._value);\r\n\t\t\tthis.setBuffer(this._value.toArray());\r\n\t\t\treturn true;\r\n\t\t}\r\n\t\treturn false;\r\n\t}\r\n}\r\nexport class UniformColor extends Uniform<Color> {\r\n\tstatic align = 16;\r\n\tconstructor(\r\n\t\tuniformName: string,\r\n\t\tbuffer: Float32Array,\r\n\t\tbyteOffset: number,\r\n\t\tcb: Function | number | Object,\r\n\t\toffset?: number\r\n\t) {\r\n\t\tsuper(uniformName, cb, offset);\r\n\t\tthis.value = undefined;\r\n\t\tthis._value = new Color();\r\n\t\tthis.buffer = new Float32Array(buffer.buffer, byteOffset, 3);\r\n\t\tthis.byteSize = 12;\r\n\t\tthis.type = \"vec3\";\r\n\t}\r\n\tset(): boolean {\r\n\t\tif (this.cb != undefined) this.value = this.getValue();\r\n\t\tconst v = this.value;\r\n\t\tif (!Color.equals(v, this._value)) {\r\n\t\t\tColor.clone(v, this._value);\r\n\t\t\tthis.setBuffer(this._value.toArray());\r\n\t\t\treturn true;\r\n\t\t}\r\n\t\treturn false;\r\n\t}\r\n}\r\n\r\nexport class UniformMat2 extends Uniform<Matrix2> {\r\n\tstatic align = 8;\r\n\tconstructor(\r\n\t\tuniformName: string,\r\n\t\tbuffer: Float32Array,\r\n\t\tbyteOffset: number,\r\n\t\tcb: Function | number | Object,\r\n\t\toffset?: number\r\n\t) {\r\n\t\tsuper(uniformName, cb, offset);\r\n\t\tthis.value = undefined;\r\n\t\tthis._value = new Matrix2();\r\n\t\tthis.buffer = new Float32Array(buffer.buffer, byteOffset, 4);\r\n\t\tthis.byteSize = 16;\r\n\t\tthis.type = \"mat2\";\r\n\t}\r\n\tset(): boolean {\r\n\t\tif (this.cb != undefined) this.value = this.getValue();\r\n\t\tconst v = this.value;\r\n\t\tif (!Matrix2.equals(v, this._value)) {\r\n\t\t\tMatrix2.clone(v, this._value);\r\n\t\t\tthis.setBuffer(this._value.toArray());\r\n\t\t\treturn true;\r\n\t\t}\r\n\t\treturn false;\r\n\t}\r\n}\r\nexport class UniformMat3 extends Uniform<Matrix3> {\r\n\tstatic align = 16;\r\n\tconstructor(\r\n\t\tuniformName: string,\r\n\t\tbuffer: Float32Array,\r\n\t\tbyteOffset: number,\r\n\t\tcb: Function | number | Object,\r\n\t\toffset?: number\r\n\t) {\r\n\t\tsuper(uniformName, cb, offset);\r\n\t\tthis.value = undefined;\r\n\t\tthis._value = new Matrix3();\r\n\t\tthis.buffer = new Float32Array(buffer.buffer, byteOffset, 9);\r\n\t\tthis.byteSize = 48;\r\n\t\tthis.type = \"mat3\";\r\n\t}\r\n\tset(): boolean {\r\n\t\tif (this.cb != undefined) this.value = this.getValue();\r\n\t\tconst v = this.value;\r\n\t\tif (!Matrix3.equals(v, this._value)) {\r\n\t\t\tMatrix3.clone(v, this._value);\r\n\t\t\tthis.setBuffer(this._value.toArray());\r\n\t\t\treturn true;\r\n\t\t}\r\n\t\treturn false;\r\n\t}\r\n}\r\nexport class UniformMat4 extends Uniform<Matrix4> {\r\n\tstatic align = 16;\r\n\tconstructor(\r\n\t\tuniformName: string,\r\n\t\tbuffer: Float32Array,\r\n\t\tbyteOffset: number,\r\n\t\tcb: Function | number | Object,\r\n\t\toffset?: number\r\n\t) {\r\n\t\tsuper(uniformName, cb, offset);\r\n\t\tthis.value = undefined;\r\n\t\tthis._value = new Matrix4();\r\n\t\tthis.buffer = new Float32Array(buffer.buffer, byteOffset, 16);\r\n\t\tthis.byteSize = 64;\r\n\t\tthis.type = \"mat4\";\r\n\t}\r\n\tset(): boolean {\r\n\t\tif (this.cb != undefined) this.value = this.getValue();\r\n\t\tconst v = this.value;\r\n\t\tif (!Matrix4.equals(v, this._value)) {\r\n\t\t\tMatrix4.clone(v, this._value);\r\n\t\t\tthis.setBuffer(this._value.toArray());\r\n\t\t\treturn true;\r\n\t\t}\r\n\t\treturn false;\r\n\t}\r\n}\r\nexport class UniformMatrix4Array extends Uniform<Array<Matrix4>> {\r\n\tstatic align = 16;\r\n\tconstructor(\r\n\t\tuniformName: string,\r\n\t\tbuffer: Float32Array,\r\n\t\tbyteOffset: number,\r\n\t\tcb: Function | number | Object,\r\n\t\toffset?: number,\r\n\t\tcount?: number,\r\n\t\tsize = 64\r\n\t) {\r\n\t\tsuper(uniformName, cb, offset);\r\n\t\tthis.visibility = ShaderStage.Vertex | ShaderStage.Fragment;\r\n\t\tthis.byteSize = count * size;\r\n\t\tthis.buffer = new Float32Array(buffer.buffer, byteOffset, this.byteSize / 4);\r\n\t\tthis.type = \"mat4-array\";\r\n\t}\r\n\tset(): boolean {\r\n\t\tthis.value = this.getValue();\r\n\t\tif (!this.value) return false;\r\n\t\tfor (let i = 0; i < this.value.length; i++) {\r\n\t\t\tthis.setBuffer(this.value[i].toArray(), i * 16);\r\n\t\t}\r\n\t\treturn true;\r\n\t}\r\n}\r\nexport class UniformFloatArray extends Uniform<Array<number>> {\r\n\tstatic align = 4;\r\n\t// cb: Function;\r\n\tconstructor(\r\n\t\tuniformName: string,\r\n\t\tbuffer: Float32Array,\r\n\t\tbyteOffset: number,\r\n\t\tcb: Function | number | Object,\r\n\t\toffset?: number,\r\n\t\tcount?: number\r\n\t) {\r\n\t\tsuper(uniformName, cb, offset);\r\n\t\tthis.visibility = ShaderStage.Vertex | ShaderStage.Fragment;\r\n\t\tthis.buffer = new Float32Array(buffer.buffer, byteOffset, count);\r\n\t\tthis.byteSize = 4 * count;\r\n\t\tthis.type = \"float-array\";\r\n\t}\r\n\tset(): boolean {\r\n\t\tthis.value = this.getValue();\r\n\t\tfor (let i = 0; i < this.value.length; i++) {\r\n\t\t\tthis.buffer[i] = this.value[i];\r\n\t\t}\r\n\t\treturn true;\r\n\t}\r\n}\r\nexport class UniformVec2Array extends Uniform<Array<Vector2>> {\r\n\tstatic align = 8;\r\n\tconstructor(\r\n\t\tuniformName: string,\r\n\t\tbuffer: Float32Array,\r\n\t\tbyteOffset: number,\r\n\t\tcb: Function | number | Object,\r\n\t\toffset?: number,\r\n\t\tcount?: number\r\n\t) {\r\n\t\tsuper(uniformName, cb, offset);\r\n\t\tthis.visibility = ShaderStage.Vertex | ShaderStage.Fragment;\r\n\t\tthis.byteSize = count * 8;\r\n\t\tthis.buffer = new Float32Array(buffer.buffer, byteOffset, this.byteSize / 4);\r\n\t\tthis.type = \"vec2-array\";\r\n\t}\r\n\tset(): boolean {\r\n\t\t// this.value = this.cb();\r\n\t\tthis.value = this.getValue();\r\n\t\tlet j = 0;\r\n\t\tfor (let i = 0; i < this.value.length; i++) {\r\n\t\t\tthis.buffer[j] = this.value[i].x;\r\n\t\t\tthis.buffer[j + 1] = this.value[i].y;\r\n\t\t\tj += 2;\r\n\t\t}\r\n\t\treturn true;\r\n\t}\r\n}\r\nexport class UniformVec3Array extends Uniform<Array<Vector3>> {\r\n\tstatic align = 16;\r\n\t// cb: Function;\r\n\tconstructor(\r\n\t\tuniformName: string,\r\n\t\tbuffer: Float32Array,\r\n\t\tbyteOffset: number,\r\n\t\tcb: Function | number | Object,\r\n\t\toffset?: number,\r\n\t\tcount?: number\r\n\t) {\r\n\t\tsuper(uniformName, cb, offset);\r\n\t\tthis.visibility = ShaderStage.Vertex | ShaderStage.Fragment;\r\n\t\tthis.byteSize = count * 16;\r\n\t\tthis.buffer = new Float32Array(buffer.buffer, byteOffset, this.byteSize / 4);\r\n\t\tthis.type = \"vec3-array\";\r\n\t}\r\n\tset(): boolean {\r\n\t\t// this.value = this.cb();\r\n\t\tthis.value = this.getValue();\r\n\t\tlet j = 0;\r\n\t\tfor (let i = 0; i < this.value.length; i++) {\r\n\t\t\tthis.buffer[j] = this.value[i].x;\r\n\t\t\tthis.buffer[j + 1] = this.value[i].y;\r\n\t\t\tthis.buffer[j + 2] = this.value[i].z;\r\n\t\t\tthis.buffer[j + 3] = 0;\r\n\t\t\tj += 4;\r\n\t\t}\r\n\t\treturn true;\r\n\t}\r\n}\r\nexport class UniformVec4Array extends Uniform<Array<Vector4>> {\r\n\tstatic align = 16;\r\n\t// cb: Function;\r\n\tconstructor(\r\n\t\tuniformName: string,\r\n\t\tbuffer: Float32Array,\r\n\t\tbyteOffset: number,\r\n\t\tcb: Function | number | Object,\r\n\t\toffset?: number,\r\n\t\tcount?: number\r\n\t) {\r\n\t\tsuper(uniformName, cb, offset);\r\n\t\tthis.visibility = ShaderStage.Vertex | ShaderStage.Fragment;\r\n\t\tthis.byteSize = count * 16;\r\n\t\tthis.buffer = new Float32Array(buffer.buffer, byteOffset, this.byteSize / 4);\r\n\t\tthis.type = \"vec4-array\";\r\n\t}\r\n\tset(): boolean {\r\n\t\tthis.value = this.getValue();\r\n\t\tlet j = 0;\r\n\t\tfor (let i = 0; i < this.value.length; i++) {\r\n\t\t\tthis.buffer[j] = this.value[i].x;\r\n\t\t\tthis.buffer[j + 1] = this.value[i].y;\r\n\t\t\tthis.buffer[j + 2] = this.value[i].z;\r\n\t\t\tthis.buffer[j + 3] = this.value[i].w;\r\n\t\t\tj += 4;\r\n\t\t}\r\n\t\treturn true;\r\n\t}\r\n}\r\nexport class UniformTexture extends Uniform<Texture> {\r\n\tpublic binding: number;\r\n\tpublic type: string;\r\n\tpublic visibility: ShaderStage;\r\n\tpublic name: string;\r\n\tpublic texture: Texture;\r\n\tpublic isTexture: boolean;\r\n\tprivate _texture: Function | Texture;\r\n\tconstructor(uniformName: string, binding: number, texture: Function | Texture) {\r\n\t\tsuper(uniformName);\r\n\t\tthis.binding = binding;\r\n\t\tthis.type = \"texture\";\r\n\t\tthis.isTexture = true;\r\n\t\tthis.visibility = ShaderStage.Fragment;\r\n\t\tthis._texture = texture;\r\n\t}\r\n\tget layoutType() {\r\n\t\treturn this.texture?.layoutType || \"not yet bind\";\r\n\t}\r\n\tbind(context: Context) {\r\n\t\tthis.texture = this._texture instanceof Function ? this._texture() : this._texture;\r\n\t\tthis.texture.update(context);\r\n\t}\r\n}\r\nexport class UniformSampler extends Uniform<Sampler> {\r\n\tpublic binding: number;\r\n\tpublic type: string;\r\n\tpublic visibility: ShaderStage;\r\n\tpublic name: string;\r\n\tpublic sampler: Sampler;\r\n\tpublic isSampler: boolean;\r\n\tprivate _sampler: Function | Sampler;\r\n\tconstructor(uniformName: string, binding: number, sampler: Function | Sampler) {\r\n\t\tsuper(uniformName);\r\n\t\tthis.name = uniformName;\r\n\t\tthis.binding = binding;\r\n\t\tthis.type = \"sampler\";\r\n\t\tthis.isSampler = true;\r\n\t\tthis.visibility = ShaderStage.Fragment;\r\n\t\tthis._sampler = sampler;\r\n\t}\r\n\tget layoutType() {\r\n\t\treturn this.sampler?.layoutType || \"not yet bind\";\r\n\t}\r\n\tbind(context: Context) {\r\n\t\tthis.sampler = this._sampler instanceof Function ? this._sampler() : this._sampler;\r\n\t\tthis.sampler.update(context);\r\n\t}\r\n}\r\nexport class UniformSpotLights extends Uniform<SpotLight> {\r\n\tstatic align = 16;\r\n\tlights: Array<SpotLight>;\r\n\t// cb: Function;\r\n\tconstructor(\r\n\t\tuniformName: string,\r\n\t\tbuffer: Float32Array,\r\n\t\tbyteOffset: number,\r\n\t\tcb: Function | number | Object,\r\n\t\toffset?: number,\r\n\t\tcount?: number\r\n\t) {\r\n\t\tsuper(uniformName, cb, offset);\r\n\t\tthis.cb = cb;\r\n\t\tthis.byteSize = count * 64;\r\n\t\tthis.buffer = new Float32Array(buffer.buffer, byteOffset, this.byteSize / 4);\r\n\t\tthis.type = \"spotsLight\";\r\n\t\tthis.visibility = ShaderStage.Fragment;\r\n\t\tthis.dirty = false;\r\n\t}\r\n\tset() {\r\n\t\tthis.lights = this.getValue();\r\n\t\tthis.lights.forEach((spotLight, index) => {\r\n\t\t\tthis.setSubData(spotLight, index);\r\n\t\t});\r\n\t\treturn this.dirty;\r\n\t}\r\n\tprivate setSubData(spotLight: SpotLight, index: number) {\r\n\t\tconst offset = index * 16;\r\n\t\tif (spotLight.positionDirty) {\r\n\t\t\tthis.dirty = setDataToTypeArray(this.buffer, spotLight.position.toArray(), offset + 0); // byteOffset=0;\r\n\t\t}\r\n\t\tif (spotLight.distanceDirty) {\r\n\t\t\tthis.dirty = setDataToTypeArray(this.buffer, spotLight.distance, offset + 3); // byteOffset=12;\r\n\t\t}\r\n\t\tif (spotLight.dirtectDirty) {\r\n\t\t\tthis.dirty = setDataToTypeArray(this.buffer, spotLight.directional.toArray(), offset + 4); // byteOffset=16;\r\n\t\t}\r\n\t\tif (spotLight.coneCosDirty) {\r\n\t\t\tthis.dirty = setDataToTypeArray(this.buffer, spotLight.coneCos, offset + 7); // byteOffset=28;\r\n\t\t}\r\n\t\tif (spotLight.colorDirty) {\r\n\t\t\tthis.dirty = setDataToTypeArray(this.buffer, spotLight.color.toArray(), offset + 8); // byteOffset=32;\r\n\t\t}\r\n\t\tif (spotLight.penumbraCosDirty) {\r\n\t\t\tthis.dirty = setDataToTypeArray(this.buffer, spotLight.penumbraCos, offset + 11); // byteOffset=44;\r\n\t\t}\r\n\t\tif (spotLight.decayDirty) {\r\n\t\t\tthis.dirty = setDataToTypeArray(this.buffer, spotLight.decay, offset + 12); // byteOffset=48;\r\n\t\t}\r\n\r\n\t\tspotLight.positionDirty = false;\r\n\t\tspotLight.distanceDirty = false;\r\n\t\tspotLight.dirtectDirty = false;\r\n\t\tspotLight.coneCosDirty = false;\r\n\t\tspotLight.colorDirty = false;\r\n\t\tspotLight.penumbraCosDirty = false;\r\n\t\tspotLight.decayDirty = false;\r\n\t}\r\n}\r\n\r\nexport class UniformSpotLightShadows extends Uniform<SpotLight> {\r\n\tstatic align = 16;\r\n\tstatic uniformSize = 18;\r\n\tlights: Array<SpotLight>;\r\n\t// cb: Function;\r\n\tprivate _nearValue: number;\r\n\tprivate _farValue: number;\r\n\tprivate _subDataSize: number;\r\n\r\n\tconstructor(\r\n\t\tuniformName: string,\r\n\t\tbuffer: Float32Array,\r\n\t\tbyteOffset: number,\r\n\t\tcb: Function | number | Object,\r\n\t\toffset?: number,\r\n\t\tcount?: number\r\n\t) {\r\n\t\tsuper(uniformName, cb, offset);\r\n\t\tconst bytesPerElement = Float32Array.BYTES_PER_ELEMENT;\r\n\t\tthis._subDataSize = UniformSpotLightShadows.uniformSize;\r\n\t\tthis.byteSize = count * this._subDataSize * bytesPerElement;\r\n\t\tthis.buffer = new Float32Array(buffer.buffer, byteOffset, this.byteSize / 4);\r\n\t\tthis.type = \"spotLightShadows\";\r\n\t\tthis.visibility = ShaderStage.Fragment;\r\n\t\tthis._nearValue = null;\r\n\t\tthis._farValue = null;\r\n\t}\r\n\tset() {\r\n\t\tthis.lights = this.getValue();\r\n\t\tthis.lights.forEach((spotLight, index) => {\r\n\t\t\tthis.setSubData(spotLight, index);\r\n\t\t});\r\n\t\treturn this.dirty;\r\n\t}\r\n\tprivate setSubData(spotLight: SpotLight, index: number) {\r\n\t\tconst offset = index * this._subDataSize;\r\n\t\tif (spotLight.shadow.vpMatrixDirty) {\r\n\t\t\tspotLight.shadow.vpMatrixDirty = false;\r\n\t\t\tthis.dirty = setDataToTypeArray(this.buffer, spotLight.shadow.camera.vpMatrix.toArray(), offset + 0); // byteOffset=0;\r\n\t\t}\r\n\t\tconst nearValue = spotLight.shadow.camera.near;\r\n\t\tif (nearValue != this._nearValue) {\r\n\t\t\tthis._nearValue = nearValue;\r\n\t\t\tthis.dirty = setDataToTypeArray(this.buffer, this._nearValue, offset + 16); // byteOffset=0;\r\n\t\t}\r\n\t\tconst farValue = spotLight.shadow.camera.far;\r\n\t\tif (farValue != this._farValue) {\r\n\t\t\tthis._farValue = farValue;\r\n\t\t\tthis.dirty = setDataToTypeArray(this.buffer, this._farValue, offset + 17); // byteOffset=0;\r\n\t\t}\r\n\t}\r\n}\r\nexport class UniformPointLights extends Uniform<PointLight> {\r\n\tstatic align = 16;\r\n\tlights: Array<PointLight>;\r\n\t// cb: Function;\r\n\tconstructor(\r\n\t\tuniformName: string,\r\n\t\tbuffer: Float32Array,\r\n\t\tbyteOffset: number,\r\n\t\tcb: Function | number | Object,\r\n\t\toffset?: number,\r\n\t\tcount?: number\r\n\t) {\r\n\t\tsuper(uniformName, cb, offset);\r\n\t\tthis.byteSize = count * 32;\r\n\t\tthis.buffer = new Float32Array(buffer.buffer, byteOffset, this.byteSize / 4);\r\n\t\tthis.type = \"pointsLight\";\r\n\t\tthis.visibility = ShaderStage.Fragment;\r\n\t}\r\n\tset() {\r\n\t\tthis.lights = this.getValue();\r\n\t\tthis.lights.forEach((pointLight, index) => {\r\n\t\t\tthis.setSubData(pointLight, index);\r\n\t\t});\r\n\t\treturn this.dirty;\r\n\t}\r\n\tprivate setSubData(pointLight: PointLight, index: number) {\r\n\t\tconst offset = index * 8;\r\n\t\tif (pointLight.positionDirty) {\r\n\t\t\tpointLight.positionDirty = false;\r\n\t\t\tthis.dirty = setDataToTypeArray(this.buffer, pointLight.position.toArray(), offset + 0); // byteOffset=0;\r\n\t\t}\r\n\t\tif (pointLight.distanceDirty) {\r\n\t\t\tpointLight.distanceDirty = false;\r\n\t\t\tthis.dirty = setDataToTypeArray(this.buffer, pointLight.distance, offset + 3); // byteOffset=12;\r\n\t\t}\r\n\t\tif (pointLight.colorDirty) {\r\n\t\t\tpointLight.colorDirty = false;\r\n\t\t\tthis.dirty = setDataToTypeArray(this.buffer, pointLight.color.toArray(), offset + 4); // byteOffset=32;\r\n\t\t}\r\n\t\tif (pointLight.decayDirty) {\r\n\t\t\tpointLight.decayDirty = false;\r\n\t\t\tthis.dirty = setDataToTypeArray(this.buffer, pointLight.decay, offset + 7); // byteOffset=12;\r\n\t\t}\r\n\t}\r\n}\r\n\r\nexport class UniformPointLightShadows extends Uniform<PointLight> {\r\n\tstatic align = 16;\r\n\tstatic uniformSize = 122;\r\n\tlights: Array<PointLight>;\r\n\t// cb: Function;\r\n\tprivate _nearValue: number;\r\n\tprivate _farValue: number;\r\n\tprivate _subDataSize: number;\r\n\r\n\tconstructor(\r\n\t\tuniformName: string,\r\n\t\tbuffer: Float32Array,\r\n\t\tbyteOffset: number,\r\n\t\tcb: Function | number | Object,\r\n\t\toffset?: number,\r\n\t\tcount?: number\r\n\t) {\r\n\t\tsuper(uniformName, cb, offset);\r\n\t\tconst bytesPerElement = Float32Array.BYTES_PER_ELEMENT;\r\n\t\tthis._subDataSize = UniformPointLightShadows.uniformSize;\r\n\t\tthis.byteSize = count * bytesPerElement * this._subDataSize;\r\n\t\tthis.buffer = new Float32Array(buffer.buffer, byteOffset, this.byteSize / 4);\r\n\t\tthis.type = \"pointLightShadows\";\r\n\t\tthis.visibility = ShaderStage.Fragment;\r\n\t\tthis._nearValue = null;\r\n\t\tthis._farValue = null;\r\n\t}\r\n\tset() {\r\n\t\tthis.lights = this.getValue();\r\n\t\tthis.lights.forEach((pointLight, index) => {\r\n\t\t\tthis.setSubData(pointLight, index);\r\n\t\t});\r\n\t\treturn this.dirty;\r\n\t}\r\n\tprivate setSubData(pointLight: PointLight, index: number) {\r\n\t\tconst offset = index * this._subDataSize;\r\n\r\n\t\tif (pointLight.shadow.vpMatrixArrayDirty) {\r\n\t\t\tpointLight.shadow.vpMatrixArrayDirty = false;\r\n\t\t\tconst vpMatrixArray = pointLight.shadow.camera.vpMatrixArray;\r\n\t\t\tfor (let i = 0; i < vpMatrixArray.length; i++) {\r\n\t\t\t\tconst vpMatrix = vpMatrixArray[i];\r\n\t\t\t\tthis.dirty = setDataToTypeArray(this.buffer, vpMatrix.toArray(), offset + 0 + 16 * i); // byteOffset=98 * 4;\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\tif (pointLight.shadow.viewPortDirty) {\r\n\t\t\tpointLight.shadow.viewPortDirty = false;\r\n\t\t\tfor (let i = 0; i < 6; i++) {\r\n\t\t\t\tthis.dirty = setDataToTypeArray(\r\n\t\t\t\t\tthis.buffer,\r\n\t\t\t\t\tpointLight.shadow.viewports[i].toArray(),\r\n\t\t\t\t\toffset + 96 + 4 * i\r\n\t\t\t\t); // byteOffset=0;\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\tconst nearValue = pointLight.shadow.camera.near;\r\n\t\tif (nearValue != this._nearValue) {\r\n\t\t\tthis._nearValue = nearValue;\r\n\t\t\tthis.dirty = setDataToTypeArray(this.buffer, this._nearValue, offset + 120); // byteOffset=0;\r\n\t\t}\r\n\t\tconst farValue = pointLight.shadow.camera.far;\r\n\t\tif (farValue != this._farValue) {\r\n\t\t\tthis._farValue = farValue;\r\n\t\t\tthis.dirty = setDataToTypeArray(this.buffer, this._farValue, offset + 121); // byteOffset=1;\r\n\t\t}\r\n\t}\r\n}\r\nexport class UniformDirtectLights extends Uniform<DirectionalLight> {\r\n\tstatic align = 16;\r\n\tlights: Array<DirectionalLight>;\r\n\tconstructor(\r\n\t\tuniformName: string,\r\n\t\tbuffer: Float32Array,\r\n\t\tbyteOffset: number,\r\n\t\tcb: Function | number | Object,\r\n\t\toffset?: number,\r\n\t\tcount?: number\r\n\t) {\r\n\t\tsuper(uniformName, cb, offset);\r\n\t\tthis.cb = cb;\r\n\t\tthis.byteSize = count * 32;\r\n\t\tthis.buffer = new Float32Array(buffer.buffer, byteOffset, this.byteSize / 4);\r\n\t\tthis.type = \"dirtectLights\";\r\n\t\tthis.visibility = ShaderStage.Fragment;\r\n\t}\r\n\tset() {\r\n\t\tthis.lights = this.getValue();\r\n\t\tthis.lights.forEach((directionalLight, index) => {\r\n\t\t\tthis.setSubData(directionalLight, index);\r\n\t\t});\r\n\t\treturn this.dirty;\r\n\t}\r\n\tprivate setSubData(directionalLight: DirectionalLight, index: number) {\r\n\t\tconst offset = index * 8;\r\n\t\tif (directionalLight.dirtectDirty) {\r\n\t\t\tdirectionalLight.dirtectDirty = false;\r\n\t\t\tthis.dirty = setDataToTypeArray(this.buffer, directionalLight.directional.toArray(), offset + 0); // byteOffset=16;\r\n\t\t}\r\n\t\tif (directionalLight.colorDirty) {\r\n\t\t\tdirectionalLight.colorDirty = false;\r\n\t\t\tthis.dirty = setDataToTypeArray(this.buffer, directionalLight.color.toArray(), offset + 4); // byteOffset=32;\r\n\t\t}\r\n\t}\r\n}\r\n\r\nexport class UniformDirtectLightShadows extends Uniform<DirectionalLight> {\r\n\tstatic align = 16;\r\n\tstatic uniformSize = 16;\r\n\tlights: Array<DirectionalLight>;\r\n\tprivate _subDataSize: number;\r\n\r\n\tconstructor(\r\n\t\tuniformName: string,\r\n\t\tbuffer: Float32Array,\r\n\t\tbyteOffset: number,\r\n\t\tcb: Function | number | Object,\r\n\t\toffset?: number,\r\n\t\tcount?: number\r\n\t) {\r\n\t\tsuper(uniformName, cb, offset);\r\n\t\tconst bytesPerElement = Float32Array.BYTES_PER_ELEMENT;\r\n\t\tthis._subDataSize = UniformDirtectLightShadows.uniformSize;\r\n\t\tthis.byteSize = count * bytesPerElement * this._subDataSize;\r\n\t\tthis.buffer = new Float32Array(buffer.buffer, byteOffset, this.byteSize / 4);\r\n\t\tthis.type = \"dirtectLightShadows\";\r\n\t\tthis.visibility = ShaderStage.Fragment;\r\n\t}\r\n\tset() {\r\n\t\tthis.lights = this.getValue();\r\n\t\tthis.lights.forEach((directionalLight, index) => {\r\n\t\t\tthis.setSubData(directionalLight, index);\r\n\t\t});\r\n\t\treturn this.dirty;\r\n\t}\r\n\tprivate setSubData(directionalLight: DirectionalLight, index: number) {\r\n\t\tconst offset = index * this._subDataSize;\r\n\t\tif (directionalLight.shadow.vpMatrixDirty) {\r\n\t\t\tdirectionalLight.shadow.vpMatrixDirty = false;\r\n\t\t\tthis.dirty = setDataToTypeArray(this.buffer, directionalLight.shadow.camera.vpMatrix.toArray(), offset + 0); // byteOffset=16;\r\n\t\t}\r\n\t}\r\n}\r\nexport enum UniformEnum {\r\n\tFloat = 0,\r\n\tFloatVec2 = 1,\r\n\tFloatVec3 = 2,\r\n\tFloatVec4 = 3,\r\n\tFloatArray = 4,\r\n\tMat2 = 5,\r\n\tMat3 = 6,\r\n\tMat4 = 7,\r\n\tColor = 8,\r\n\tMat4Array = 9,\r\n\tPointLights = 10,\r\n\tPointLightShadows = 11,\r\n\tSpotLights = 12,\r\n\tSpotLightShadows = 13,\r\n\tDirtectLights = 14,\r\n\tDirtectLightShadows = 15,\r\n\tVec2Array = 16,\r\n\tVec3Array = 17,\r\n\tVec4Array = 18,\r\n\tUniformUint = 19\r\n}\r\nfunction setDataToTypeArray(buffer, data, offset) {\r\n\tif (Array.isArray(data)) {\r\n\t\tdata.forEach((value, index) => {\r\n\t\t\tbuffer[index + offset] = value;\r\n\t\t});\r\n\t} else {\r\n\t\tbuffer[offset] = data;\r\n\t}\r\n\treturn true;\r\n}\r\n","import { BufferUsage, ShaderStage } from \"../core/WebGPUConstant\";\r\nimport defaultValue from \"../utils/defaultValue\";\r\nimport Buffer from \"./Buffer\";\r\nimport Context from \"./Context\";\r\n\r\nimport {\r\n\tUniform,\r\n\tUniformColor,\r\n\tUniformDirtectLights,\r\n\tUniformDirtectLightShadows,\r\n\tUniformFloat,\r\n\tUniformFloatArray,\r\n\tUniformFloatVec2,\r\n\tUniformFloatVec3,\r\n\tUniformFloatVec4,\r\n\tUniformMat2,\r\n\tUniformMat3,\r\n\tUniformMat4,\r\n\tUniformMatrix4Array,\r\n\tUniformPointLights,\r\n\tUniformPointLightShadows,\r\n\tUniformSpotLights,\r\n\tUniformSpotLightShadows,\r\n\tUniformUint,\r\n\tUniformVec2Array,\r\n\tUniformVec3Array,\r\n\tUniformVec4Array,\r\n\tUniformEnum\r\n} from \"./Uniforms\";\r\nexport default class UniformBuffer {\r\n\tpublic type: string;\r\n\tpublic hasDynamicOffset: boolean;\r\n\tpublic minBindingSize: number;\r\n\tprivate _uniformStruct: Map<string, Uniform<any>>;\r\n\tprivate _bufferSize: number;\r\n\tprivate label: string;\r\n\tbyteOffset: number;\r\n\tuniformDirty: boolean;\r\n\tbinding: number;\r\n\tvisibility: ShaderStage;\r\n\tusage: BufferUsage;\r\n\tbuffer: Buffer;\r\n\tdataBuffer: Float32Array;\r\n\toffset: number;\r\n\tmaxOffset: number;\r\n\tisUniformBuffer: boolean;\r\n\tname: string;\r\n\tprivate static UniformType = {\r\n\t\t[UniformEnum.UniformUint]: UniformUint,\r\n\t\t[UniformEnum.Float]: UniformFloat,\r\n\t\t[UniformEnum.FloatVec2]: UniformFloatVec2,\r\n\t\t[UniformEnum.FloatVec3]: UniformFloatVec3,\r\n\t\t[UniformEnum.FloatVec4]: UniformFloatVec4,\r\n\t\t[UniformEnum.Mat2]: UniformMat2,\r\n\t\t[UniformEnum.Mat3]: UniformMat3,\r\n\t\t[UniformEnum.Mat4]: UniformMat4,\r\n\t\t[UniformEnum.Color]: UniformColor,\r\n\t\t[UniformEnum.FloatArray]: UniformFloatArray,\r\n\t\t[UniformEnum.Vec2Array]: UniformVec2Array,\r\n\t\t[UniformEnum.Vec3Array]: UniformVec3Array,\r\n\t\t[UniformEnum.Vec4Array]: UniformVec4Array,\r\n\t\t[UniformEnum.Mat4Array]: UniformMatrix4Array,\r\n\t\t[UniformEnum.PointLights]: UniformPointLights,\r\n\t\t[UniformEnum.SpotLights]: UniformSpotLights,\r\n\t\t[UniformEnum.DirtectLights]: UniformDirtectLights,\r\n\t\t[UniformEnum.PointLightShadows]: UniformPointLightShadows,\r\n\t\t[UniformEnum.SpotLightShadows]: UniformSpotLightShadows,\r\n\t\t[UniformEnum.DirtectLightShadows]: UniformDirtectLightShadows\r\n\t};\r\n\tconstructor(options: UniformBufferType) {\r\n\t\tthis.type = defaultValue(options.type, \"uniform\");\r\n\t\tthis.label = defaultValue(options.label, \"\");\r\n\t\tthis.name = defaultValue(options.label, \"\");\r\n\t\tthis.hasDynamicOffset = options.hasDynamicOffset ?? false;\r\n\t\tthis.minBindingSize = options.minBindingSize ?? 0;\r\n\t\tthis.binding = options.binding ?? 0;\r\n\t\tthis.visibility = ShaderStage.Fragment | ShaderStage.Vertex;\r\n\t\tthis.usage = defaultValue(options.usage, BufferUsage.Uniform | BufferUsage.CopyDst);\r\n\t\tthis._uniformStruct = new Map();\r\n\t\tthis.uniformDirty = true;\r\n\t\tthis._bufferSize = options.size;\r\n\t\tthis.offset = 0;\r\n\t\tthis.dataBuffer = defaultValue(options.dataBuffer, new Float32Array(defaultValue(this._bufferSize, 400)));\r\n\t\tthis.byteOffset = 0;\r\n\t\tthis.isUniformBuffer = true;\r\n\t\tthis.maxOffset = options.maxOffset ?? 0;\r\n\t}\r\n\tget layoutType() {\r\n\t\treturn {\r\n\t\t\ttype: this.type,\r\n\t\t\thasDynamicOffset: this.hasDynamicOffset,\r\n\t\t\tminBindingSize: this.minBindingSize\r\n\t\t};\r\n\t}\r\n\tget bufferSize() {\r\n\t\treturn this.uniformsSize * 4;\r\n\t}\r\n\tget uniformsSize() {\r\n\t\t// https://gpuweb.github.io/gpuweb/wgsl/#address-space-layout-constraints\r\n\t\treturn Math.ceil(this.byteOffset / 16) * 16;\r\n\t}\r\n\tbind(context: Context) {\r\n\t\tthis._uniformStruct.forEach((uniform) => {\r\n\t\t\tconst result = uniform.set();\r\n\t\t\tif (uniform?.dirty != undefined) uniform.dirty = false;\r\n\t\t\tif (result != undefined && this.uniformDirty == false) this.uniformDirty = result;\r\n\t\t});\r\n\t\tif (this.uniformDirty) {\r\n\t\t\tthis.uniformDirty = false;\r\n\t\t\tif (!this.buffer)\r\n\t\t\t\tthis.buffer = Buffer.createUniformBuffer(this.label, context.device, this.bufferSize, this.usage);\r\n\t\t\tthis.buffer.setSubData(0, this.dataBuffer.slice(0, defaultValue(this?.bufferSize / 4, this.uniformsSize)));\r\n\t\t}\r\n\t}\r\n\tpublic getUniformBufferStruct() {\r\n\t\tlet uniformStruct = `struct MaterialUniform {\\n `;\r\n\t\tthis._uniformStruct.forEach((uniform) => {\r\n\t\t\tuniformStruct += this.createUniformString(uniform);\r\n\t\t});\r\n\t\tuniformStruct += `}\\n`;\r\n\t\treturn uniformStruct;\r\n\t}\r\n\tprivate createUniformString(uniform) {\r\n\t\tlet result = ``;\r\n\t\tswitch (uniform.type) {\r\n\t\t\tcase \"vec1\":\r\n\t\t\t\tresult = `${uniform.name} :f32,\\n`;\r\n\t\t\t\tbreak;\r\n\t\t\tcase \"vec2\":\r\n\t\t\t\tresult = `${uniform.name} :vec2<f32>,\\n`;\r\n\t\t\t\tbreak;\r\n\t\t\tcase \"vec3\":\r\n\t\t\t\tresult = `${uniform.name} :vec3<f32>,\\n`;\r\n\t\t\t\tbreak;\r\n\t\t\tcase \"vec4\":\r\n\t\t\t\tresult = `${uniform.name} :vec4<f32>,\\n`;\r\n\t\t\t\tbreak;\r\n\t\t\tcase \"mat2\":\r\n\t\t\t\tresult = `${uniform.name} :mat2x2<f32>,\\n`;\r\n\t\t\t\tbreak;\r\n\t\t\tcase \"mat3\":\r\n\t\t\t\tresult = `${uniform.name} :mat3x3<f32>,\\n`;\r\n\t\t\t\tbreak;\r\n\t\t\tcase \"mat4\":\r\n\t\t\t\tresult = `${uniform.name} :mat4x4<f32>,\\n`;\r\n\t\t\t\tbreak;\r\n\t\t}\r\n\t\treturn result;\r\n\t}\r\n\tcontains(name: string): Uniform<any> {\r\n\t\treturn this._uniformStruct.get(name);\r\n\t}\r\n\treplaceUniformValue(name: string, value: Function | number | Object) {\r\n\t\tconst uniform = this._uniformStruct.get(name);\r\n\t\tif (!uniform) return;\r\n\t\tuniform.cb = value;\r\n\t}\r\n\t// uniformBuffer.setVec3Array('test',()=>{return [new Vector3(1,0,0),new Vector3(1,0.8,0.5)]},2);\r\n\t// uniformBuffer.setFloatArray('test1',()=>{return [0.5,0.5,1.0]},3);\r\n\t// uniformBuffer.setVec4Array('test4',()=>{return [new Vector4(0.5,0.6,0.2,1.0),new Vector4(0.5,0.8,0.8,1.0)]},2);\r\n\t// uniformBuffer.setVec2Array('test2',()=>{return [new Vector2(0.5,0.6),new Vector2(0.5,0.8,)]},2);\r\n\tsetUniform(name: string, value: Function | number | Object, uniformType: UniformEnum, count?: number) {\r\n\t\tif (this._uniformStruct.get(name)) return;\r\n\t\tconst TypeUniform = UniformBuffer.UniformType[uniformType];\r\n\t\tthis.byteOffset += this.checkUniformOffset(this.byteOffset, TypeUniform.align);\r\n\t\tconst uniform =\r\n\t\t\tcount != undefined\r\n\t\t\t\t? new TypeUniform(name, this.dataBuffer, this.byteOffset, value, 0, count)\r\n\t\t\t\t: new TypeUniform(name, this.dataBuffer, this.byteOffset, value);\r\n\t\tthis._uniformStruct.set(name, uniform);\r\n\t\tthis.byteOffset += uniform.byteSize;\r\n\t}\r\n\tprivate checkUniformOffset(byteSize: number, Align: number): number {\r\n\t\t// from https://gpuweb.github.io/gpuweb/wgsl/#address-space-layout-constraints\r\n\t\t// return this.hasDynamicOffset\r\n\t\t// \t? Math.ceil(byteSize / 256) * 256 - byteSize\r\n\t\t// \t: Math.ceil(byteSize / Align) * Align - byteSize;\r\n\t\treturn Math.ceil(byteSize / Align) * Align - byteSize;\r\n\t}\r\n\tdestroy() {\r\n\t\tthis?.buffer?.destroy();\r\n\t}\r\n}\r\ntype UniformBufferType = {\r\n\tlabel: string;\r\n\ttype?: string;\r\n\tusage?: BufferUsage;\r\n\tsize?: number;\r\n\tdataBuffer?: Float32Array;\r\n\tbinding?: number;\r\n\thasDynamicOffset?: boolean;\r\n\tminBindingSize?: number;\r\n\tmaxOffset?: number;\r\n};\r\n","export function billboard_fs(defines){\n  return `\n  struct SelfUniform {\n    modelMatrix: mat4x4<f32>,\n    color:vec3<f32>,\n    rotation:f32,\n    center:vec2<f32>,\n    opacity:f32,\n  }\n  @binding(${defines.billboardBinding}) @group(0) var<uniform> selfUniform : SelfUniform;\n  #if${defines.USE_COLORTEXTURE}\n    @group(0) @binding(${defines.baseColorSamplerBinding}) var baseColorSampler: sampler;\n    @group(0) @binding(${defines.baseColorTextureBinding}) var baseColorTexture: texture_2d<f32>;\n  #endif\n  @fragment\n  fn main(input:VertexOutput) -> @location(0) vec4<f32> {\n    #if${defines.USE_COLORTEXTURE}\n      return textureSample(baseColorTexture, baseColorSampler, input.uv);\n    #else\n      return vec4<f32>(selfUniform.color,selfUniform.opacity);\n    #endif\n  }\n  `\n}","const preprocessorSymbols = /#([^\\s]*)(\\s*)/gm;\n// Template literal tag that handles simple preprocessor symbols for WGSL\n// shaders. Supports #if/elif/else/endif statements.\nexport function wgslParseDefines(strings, ...values) {\n\tconst stateStack = [];\n\tlet state = { frag: \"\", elseIsValid: false, expression: true };\n\tlet depth = 1;\n\n\tfor (let i = 0; i < strings.length; ++i) {\n\t\tconst frag = strings[i];\n\t\tconst matchedSymbols = frag.matchAll(preprocessorSymbols);\n\n\t\tlet lastIndex = 0;\n\t\tlet valueConsumed = false;\n\n\t\tfor (const match of matchedSymbols) {\n\t\t\tstate.frag += frag.substring(lastIndex, match.index);\n\n\t\t\tswitch (match[1]) {\n\t\t\t\tcase \"if\":\n\t\t\t\t\tif (match.index + match[0].length != frag.length) {\n\t\t\t\t\t\tthrow new Error(\"#if must be immediately followed by a template expression (ie: ${value})\");\n\t\t\t\t\t}\n\t\t\t\t\tvalueConsumed = true;\n\t\t\t\t\tstateStack.push(state);\n\t\t\t\t\tdepth++;\n\t\t\t\t\tstate = { frag: \"\", elseIsValid: true, expression: !!values[i] };\n\t\t\t\t\tbreak;\n\t\t\t\tcase \"elif\":\n\t\t\t\t\tif (match.index + match[0].length != frag.length) {\n\t\t\t\t\t\tthrow new Error(\"#elif must be immediately followed by a template expression (ie: ${value})\");\n\t\t\t\t\t} else if (!state.elseIsValid) {\n\t\t\t\t\t\tthrow new Error(\"#elif not preceeded by an #if or #elif\");\n\t\t\t\t\t}\n\t\t\t\t\tvalueConsumed = true;\n\t\t\t\t\tif (state.expression && stateStack.length != depth) {\n\t\t\t\t\t\tstateStack.push(state);\n\t\t\t\t\t}\n\t\t\t\t\tstate = { frag: \"\", elseIsValid: true, expression: !!values[i] };\n\t\t\t\t\tbreak;\n\t\t\t\tcase \"else\":\n\t\t\t\t\tif (!state.elseIsValid) {\n\t\t\t\t\t\tthrow new Error(\"#else not preceeded by an #if or #elif\");\n\t\t\t\t\t}\n\t\t\t\t\tif (state.expression && stateStack.length != depth) {\n\t\t\t\t\t\tstateStack.push(state);\n\t\t\t\t\t}\n\t\t\t\t\tstate = { frag: match[2], elseIsValid: false, expression: true };\n\t\t\t\t\tbreak;\n\t\t\t\tcase \"endif\":\n\t\t\t\t\tif (!stateStack.length) {\n\t\t\t\t\t\tthrow new Error(\"#endif not preceeded by an #if\");\n\t\t\t\t\t}\n\t\t\t\t\tconst branchState = stateStack.length == depth ? stateStack.pop() : state;\n\t\t\t\t\tstate = stateStack.pop();\n\t\t\t\t\tdepth--;\n\t\t\t\t\tif (branchState.expression) {\n\t\t\t\t\t\tstate.frag += branchState.frag;\n\t\t\t\t\t}\n\t\t\t\t\tstate.frag += match[2];\n\t\t\t\t\tbreak;\n\t\t\t\tdefault:\n\t\t\t\t\t// Unknown preprocessor symbol. Emit it back into the output frag unchanged.\n\t\t\t\t\tstate.frag += match[0];\n\t\t\t\t\tbreak;\n\t\t\t}\n\n\t\t\tlastIndex = match.index + match[0].length;\n\t\t}\n\n\t\t// If the frag didn't end on one of the preprocessor symbols append the rest of it here.\n\t\tif (lastIndex != frag.length) {\n\t\t\tstate.frag += frag.substring(lastIndex, frag.length);\n\t\t}\n\n\t\t// If the next value wasn't consumed by the preprocessor symbol, append it here.\n\t\tif (!valueConsumed && values.length > i) {\n\t\t\tstate.frag += values[i];\n\t\t}\n\t}\n\n\tif (stateStack.length) {\n\t\tthrow new Error(\"Mismatched #if/#endif count\");\n\t}\n\n\treturn state.frag;\n}\n","\nimport { wgslParseDefines } from \"../WgslPreprocessor\";\nexport function billboard_vs(defines){\n  return wgslParseDefines`\n\n  #include <VertexInput>\n  #include <VertexOutput>\n  #include <SystemUniform>\n  struct SelfUniform {\n    modelMatrix: mat4x4<f32>,\n    color:vec3<f32>,\n    rotation:f32,\n    center:vec2<f32>,\n    opacity:f32,\n  }\n  @binding(${defines.billboardBinding}) @group(0) var<uniform> selfUniform : SelfUniform;\n  @binding(${defines.cameraBinding}) @group(1) var<uniform> systemUniform : SystemUniform;\n  @vertex\n    fn main(input: VertexInput) -> VertexOutput {\n    var output:VertexOutput;\n    let mvPosition:vec4<f32>= ystemUniform.viewMatrix *selfUniform.modelMatrix*vec4<f32>(0.0,0.0,0.0, 1.0 );\n    #if ${defines.HAS_UV}\n       output.uv=input.uv;\n    #endif\n    var scale:vec2<f32>;\n    scale.x = length( vec3<f32>( selfUniform.modelMatrix[ 0 ].x, selfUniform.modelMatrix[ 0 ].y, selfUniform.modelMatrix[ 0 ].z ) );\n    scale.y = length( vec3<f32>( selfUniform.modelMatrix[ 1 ].x, selfUniform.modelMatrix[ 1 ].y, selfUniform.modelMatrix[ 1 ].z ) );\n\n    vec2 alignedPosition = ( input.position.xy - ( selfUniform.center - vec2<f32>( 0.5 ) ) ) * scale;\n    vec2 rotatedPosition;\n    rotatedPosition.x = cos( selfUniform.rotation ) * alignedPosition.x - sin( selfUniform.rotation ) * alignedPosition.y;\n    rotatedPosition.y = sin( selfUniform.rotation ) * alignedPosition.x + cos( selfUniform.rotation ) * alignedPosition.y;\n    mvPosition.xy += rotatedPosition;\n    output.position = systemUniform.projectionMatrix * mvPosition;\n    return output;\n    }\n  `\n}","// import Color from \"../../math/Color\";\r\n\r\nexport default function colorFrag(defines) {\r\n  return `\r\n    struct VertexOutput {\r\n        @builtin(position) position: vec4<f32>,\r\n        @location(0) color: vec4<f32>,\r\n    };\r\n    @fragment\r\n    fn main(input:VertexOutput) -> @location(0) vec4<f32> {\r\n      return input.color;\r\n    }\r\n    `;\r\n}\r\n","export default function colorVert(defines) {\n\treturn `\n   struct VertexInput {\n        @location(${defines.positionLocation}) position: vec3<f32>,       \n        @location(${defines.colorLocation}) color: vec4<f32>,\n   }\n   struct VertexOutput {\n        @builtin(position) position: vec4<f32>,\n        @location(0) color: vec4<f32>,\n    };\n   struct SelfUniform {\n      modelMatrix: mat4x4<f32>,\n   }\n   struct SystemUniform {\n      projectionMatrix: mat4x4<f32>,\n      viewMatrix: mat4x4<f32>,\n      inverseViewMatrix: mat4x4<f32>,\n      cameraPosition: vec3<f32>,\n   }; \n   @binding(${defines.colorBinding}) @group(0) var<uniform> selfUniform : SelfUniform;\n   @binding(${defines.cameraBinding}) @group(1) var<uniform> systemUniform : SystemUniform;\n   @vertex\n   fn main(input: VertexInput) -> VertexOutput {\n    var output:VertexOutput;\n    output.color=input.color;\n    output.position = systemUniform.projectionMatrix * systemUniform.viewMatrix *selfUniform.modelMatrix*vec4<f32>(input.position,1.0);\n    return output;\n   }\n   `;\n}\n","import { wgslParseDefines } from \"../WgslPreprocessor\";\nexport default function pbr_fs(defines) {\n\treturn wgslParseDefines`\n        // reference: https://github.com/KhronosGroup/glTF-WebGL-PBR/blob/master/shaders/pbr-frag.glsl\n        #include <pbrUtils>\n        #include <light>\n        #include <brdf>\n        #include <PbrMaterialStruct>\n        #include <SystemUniform> \n        #include <FragInput>   \n        struct PhysicalMaterial {\n            diffuseColor:vec3<f32>,\n            roughness:f32,\n            specularColor:vec3<f32>,\n           #if ${defines.USE_CLEARCOAT}\n               clearcoat:f32,\n               clearcoatRoughness:f32,\n               clearcoatF0:vec3<f32>,\n               clearcoatF90:f32,\n           #endif\n\n           #if ${defines.USE_IRIDESCENCE}\n               iridescence:f32,\n               iridescenceIOR:f32,\n               iridescenceThickness:f32,\n               iridescenceFresnel:vec3<f32>,\n               iridescenceF0:vec3<f32>,\n           #endif\n\n           #if ${defines.USE_SHEEN}\n               sheenColor:vec3<f32>,\n               sheenRoughness:f32,\n           #endif\n\n           #if ${defines.IOR}\n                ior:f32,\n           #endif\n\n           #if ${defines.USE_TRANSMISSION}\n               transmission:f32,\n               transmissionAlpha:f32,\n               thickness:f32,\n               attenuationDistance:f32,\n               attenuationColor:vec3<f32>,\n           #endif\n       };\n        const M_PI:f32 = 3.141592653589793;\n        const c_MinRoughness:f32 = 0.04;\n        #include <TextureAndSamplerDefine>\n        #if ${defines.USE_IBL}\n            #include <ibl>\n        #endif\n        @binding(${defines.pbrBinding}) @group(0) var<uniform> materialUniform : MaterialUniform;\n        @binding(${defines.cameraBinding}) @group(1) var<uniform> systemUniform : SystemUniform;\n        @fragment\n        fn main(input:FragInput) -> @location(0) vec4<f32> \n        {\n            var perceptualRoughness:f32 = materialUniform.roughness;\n            var metallic:f32 = materialUniform.metallic;\n\n            #if ${defines.USE_METALNESSTEXTURE}\n                let mrSample:vec4<f32> = textureSample(metalnessRoughnessTexture,metalnessRoughnessSampler, input.uv);\n                perceptualRoughness = mrSample.g * perceptualRoughness;\n                metallic = mrSample.b * metallic;\n            #endif\n            perceptualRoughness = clamp(perceptualRoughness, c_MinRoughness, 1.0);\n            metallic = clamp(metallic, 0.0, 1.0);\n            let alphaRoughness:f32 = perceptualRoughness * perceptualRoughness;\n\n\n            // The albedo may be defined from a base texture or a flat color\n            #if ${defines.USE_TEXTURE}\n                let baseColor:vec4<f32> = textureSample(baseColorTexture,baseColorSampler, input.uv) ;\n            #else\n                let baseColor:vec4<f32> = vec4<f32>(materialUniform.color,1.0);\n            #endif\n\n            #if ${defines.USE_NORMALTEXTURE}\n                let n:vec3<f32> = getNormalByNormalTexture(input);  \n            #else\n                let n:vec3<f32> = getNormal(input);\n            #endif\n            var material:PhysicalMaterial;\n            material.diffuseColor=baseColor.rgb*( 1.0 - metallic );\n            material.roughness=perceptualRoughness;\n            material.specularColor=mix( vec3<f32>( 0.04), baseColor.rgb, metallic );\n            var geometry:Geometry;\n            geometry.normal=n;\n            geometry.viewDir=normalize(systemUniform.cameraPosition - input.worldPos);\n            geometry.position=input.worldPos;\n            geometry.dotNV = saturate(dot(geometry.normal, geometry.viewDir) );\n            //light shading\n            var reflectedLight=parseLights(geometry,material);\n            var color=reflectedLight.directDiffuse+reflectedLight.directSpecular;\n            //IBL\n            #if ${defines.USE_IBL && defines.HAS_UV}\n                var reflectedLightDiffuse=indirectDiffuse_Physical(geometry,material);\n                var reflectedLightSpecular=indirectSpecular_Physical(geometry,material);\n                color+=reflectedLightDiffuse.indirectDiffuse;\n                color+=reflectedLightSpecular.indirectSpecular;\n            #endif\n            #if ${defines.USE_AOTEXTURE}\n                let ao:f32 = textureSample(aoTexture,aoSampler, input.uv).r;\n                color = mix(color, color * ao, materialUniform.occlusionStrength);\n            #endif\n\n            #if ${defines.USE_EMISSIVETEXTURE}\n                let emissive:vec3<f32> = textureSample(emissiveTexture, emissiveSampler,input.uv).rgb ;\n                color += emissive;\n            #endif\n       return vec4<f32>(color, baseColor.a);\n    }\n   `;\n}\n","import { wgslParseDefines } from \"../WgslPreprocessor\";\nexport default function pbr_vs(defines) {\n\treturn wgslParseDefines`\n    #include <PbrMaterialStruct>\n    #include <SystemUniform>\n    #include <VertexInput>\n    #include <VertexOutput> \n    #include <skinVertHeader>\n    #include <instanceVertHeader>\n    @binding(${defines.pbrBinding}) @group(0) var<uniform> materialUniform : MaterialUniform;\n    @binding(${defines.cameraBinding}) @group(1) var<uniform> systemUniform : SystemUniform;\n    @vertex\n    fn main(input: VertexInput)-> VertexOutput\n   {\n        var output: VertexOutput;\n        #if ${defines.HAS_UV}\n            output.uv = input.uv;\n        #endif\n        var modelMatrix:mat4x4<f32>;\n        var vNormalView:vec3<f32>;\n        vNormalView = normalize(materialUniform.normalMatrix * vec4<f32>(input.normal,0.0)).xyz;\n        modelMatrix=materialUniform.modelMatrix;   \n        #include <skinVertMain>\n        #include <instanceVertMain>  \n        output.normal = vNormalView.xyz;\n        output.position = systemUniform.projectionMatrix * systemUniform.viewMatrix *modelMatrix* vec4<f32>(input.position, 1.0);\n        let modelPos=modelMatrix *vec4<f32>(input.position,1.0);\n        output.worldPos = modelPos.xyz/modelPos.w;\n        return output;   \n   }\n   `;\n}\n","import { wgslParseDefines } from \"../WgslPreprocessor\";\r\n\r\nexport default function pbrFrag(defines) {\r\n\treturn wgslParseDefines`\r\n    #include <lightCommon>\r\n    #include <light>\r\n    #include <brdf>\r\n    #include <pbrStruct>\r\n    #include <pbrUtils>\r\n    #include <pbrFunction>\r\n    #include <pbrTexture>\r\n    #include <environment>\r\n    struct SystemUniform {\r\n        projectionMatrix: mat4x4<f32>,\r\n        viewMatrix: mat4x4<f32>,\r\n        inverseViewMatrix: mat4x4<f32>,\r\n        cameraPosition: vec3<f32>,\r\n    }; \r\n    // uniform vec3 lightProbe[9],\r\n////////////////////////////////////\r\nstruct VertexOutput {\r\n    @builtin(position) position: vec4<f32>,\r\n    @builtin(front_facing) is_front: bool,\r\n    @location(0) vUv: vec2<f32>,\r\n    @location(1) vViewPosition: vec3<f32>, // Vector from vertex to camera.\r\n    @location(2) vWorldPosition: vec3<f32>,\r\n    @location(3) vNormal: vec3<f32>,\r\n    // 可选\r\n    #if ${defines.USE_LIGHTTEXTURE || defines.USE_AOTEXTURE}\r\n        @location(${defines.vUv2OutLocation}) vUv2: vec2<f32>,\r\n    #endif\r\n\r\n    #if ${defines.USE_COLOR_ALPHA}\r\n        @location(${defines.vColorOutLocation}) vColor: vec4<f32>,\r\n    #elif ${defines.USE_COLOR || defines.USE_INSTANCING_COLOR}\r\n        @location(${defines.vColorOutLocation}) vColor: vec3<f32>,\r\n    #endif\r\n\r\n    #if ${defines.USE_TANGENT}\r\n        @location(${defines.vTangentOutLocation}) vTangent: vec3<f32>,\r\n        @location(${defines.vBitangentOutLocation}) vBitangent: vec3<f32>,\r\n    #endif\r\n};\r\n        struct PhysicalMaterial {\r\n             diffuseColor:vec3<f32>,\r\n             roughness:f32,\r\n             specularColor:vec3<f32>,\r\n             specularF90:f32,\r\n            #if ${defines.USE_CLEARCOAT}\r\n                clearcoat:f32,\r\n                clearcoatRoughness:f32,\r\n                clearcoatF0:vec3<f32>,\r\n                clearcoatF90:f32,\r\n            #endif\r\n\r\n            #if ${defines.USE_IRIDESCENCE}\r\n                iridescence:f32,\r\n                iridescenceIOR:f32,\r\n                iridescenceThickness:f32,\r\n                iridescenceFresnel:vec3<f32>,\r\n                iridescenceF0:vec3<f32>,\r\n            #endif\r\n\r\n            #if ${defines.USE_SHEEN}\r\n                sheenColor:vec3<f32>,\r\n                sheenRoughness:f32,\r\n            #endif\r\n\r\n            #if ${defines.IOR}\r\n                 ior:f32,\r\n            #endif\r\n\r\n            #if ${defines.USE_TRANSMISSION}\r\n                transmission:f32,\r\n                transmissionAlpha:f32,\r\n                thickness:f32,\r\n                attenuationDistance:f32,\r\n                attenuationColor:vec3<f32>,\r\n            #endif\r\n        };\r\n@binding(0) @group(0) var<uniform> materialUniform : MaterialUniform;\r\n@binding(0) @group(1) var<uniform> systemUniform : SystemUniform;\r\n@fragment\r\nfn main(input:VertexOutput)-> @location(0) vec4<f32> {\r\n        var diffuseColor:vec4<f32> = vec4(materialUniform.diffuse, materialUniform.opacity );\r\n       // ReflectedLight reflectedLight = ReflectedLight( vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ) );\r\n        var reflectedLight:ReflectedLight;\r\n        var totalEmissiveRadiance:vec3<f32> = materialUniform.emissive;\r\n        #if ${defines.USE_TEXTURE}\r\n            var sampledDiffuseColor:vec4<f32> =textureSample(baseTexture, baseSampler, input.vUv);\r\n            #if ${defines.DECODE_VIDEO_TEXTURE}\r\n                sampledDiffuseColor = vec4<f32>( mix( pow( sampledDiffuseColor.rgb * 0.9478672986 + vec3<f32>( 0.0521327014 ), vec3<f32>( 2.4 ) ), sampledDiffuseColor.rgb * 0.0773993808, vec3<f32>( lessThanEqual( sampledDiffuseColor.rgb, vec3<f32>( 0.04045 ) ) ) ), sampledDiffuseColor.w );\r\n            #endif\r\n\r\n            diffuseColor *= sampledDiffuseColor;\r\n        #endif\r\n\r\n        var roughnessFactor:f32 = materialUniform.roughness;\r\n    \r\n        #if ${defines.USE_ROUGHNESSTEXTURE}\r\n            let texelRoughness:vec4<f32>=textureSample(roughnessTexture, baseSampler, input.vUv);\r\n            roughnessFactor *= texelRoughness.g;\r\n        #endif\r\n\r\n        var metalnessFactor:f32 = materialUniform.metalness;\r\n    \r\n        #if ${defines.USE_METALNESSTEXTURE}\r\n            let texelMetalness:vec4<f32> =textureSample(metalnessTexture, baseSampler, input.vUv);\r\n            metalnessFactor *= texelMetalness.b;\r\n        #endif\r\n\r\n        let faceDirection:f32 =select(-1.0,1.0,input.is_front);\r\n        #if ${defines.FLAT_SHADED}\r\n            let fdx:vec3<f32> = dpdx( input.vViewPosition );\r\n            let fdy:vec3<f32> = dpdy( input.vViewPosition );\r\n            let normal:vec3<f32> = normalize( cross( fdy, fdx ) );\r\n        #else\r\n            let normal:vec3<f32> = normalize( input.vNormal );\r\n            #if ${defines.DOUBLE_SIDED}\r\n                normal = normal * faceDirection;\r\n            #endif\r\n            #if ${defines.USE_TANGENT}\r\n                let tangent:vec3<f32> = normalize( input.vTangent );\r\n                let bitangent:vec3<f32> = normalize( input.vBitangent );\r\n                #if ${defines.DOUBLE_SIDED}\r\n                    tangent = tangent * faceDirection;\r\n                    bitangent = bitangent * faceDirection;\r\n                #endif\r\n                #if ${defines.TANGENTSPACE_NORMALTEXTURE || defines.USE_CLEARCOAT_NORMALTEXTURE}\r\n                    let vTBN:mat3x3<f32> = mat3x3<f32>( tangent, bitangent, normal );\r\n                #endif\r\n            #endif\r\n        #endif\r\n    \r\n        let geometryNormal:vec3<f32> = normal;\r\n\r\n        #if ${defines.OBJECTSPACE_NORMALTEXTURE}\r\n            normal =textureSample(normalTexture, baseSampler, input.vUv).xyz * 2.0 - 1.0;\r\n            #if ${defines.FLIP_SIDED}\r\n                normal = - normal;\r\n            #endif\r\n            #if ${defines.DOUBLE_SIDED}\r\n                normal = normal * faceDirection;\r\n            #endif\r\n\r\n            normal = normalize(materialUniform.normalMatrix * normal );\r\n\r\n            #elif ${defines.TANGENTSPACE_NORMALTEXTURE}\r\n            let tempMapN:vec3<f32> =textureSample(normalTexture, baseSampler, input.vUv).xyz * 2.0 - 1.0;\r\n            let mapN:vec3<f32> =tempMapN.xy *= materialUniform.normalScale;\r\n            #if ${defines.USE_TANGENT}\r\n                normal = normalize( vTBN * mapN );\r\n            #else\r\n                normal = perturbNormal2Arb( - input.vViewPosition, normal, mapN, faceDirection );\r\n            #endif\r\n\r\n            #elif ${defines.USE_BUMPTEXTURE}\r\n\r\n                normal = perturbNormalArb( - input.vViewPosition, normal, dHdxy_fwd(), faceDirection );\r\n        #endif\r\n\r\n        #if ${defines.USE_CLEARCOAT}\r\n            var clearcoatNormal:vec3<f32> = geometryNormal;\r\n        #endif\r\n        #if ${defines.USE_CLEARCOAT_NORMALTEXTURE}\r\n            var clearcoatMapN:vec3<f32> =textureSample(clearcoatNormalTexture, baseSampler, input.vUv).xyz * 2.0 - 1.0;\r\n            clearcoatMapN.xy *= materialUniform.clearcoatNormalScale;\r\n            #if ${defines.USE_TANGENT}\r\n                clearcoatNormal = normalize( vTBN * clearcoatMapN );\r\n            #else\r\n                clearcoatNormal = perturbNormal2Arb( - input.vViewPosition, clearcoatNormal, clearcoatMapN, faceDirection );\r\n            #endif\r\n        #endif\r\n        #if ${defines.USE_EMISSIVETEXTURE}\r\n            let emissiveColor:vec4<f32> =textureSample(emissiveTexture, baseSampler, input.vUv);\r\n            totalEmissiveRadiance *= emissiveColor.rgb;\r\n        #endif\r\n\r\n        var material:PhysicalMaterial;\r\n        material.diffuseColor = diffuseColor.rgb * ( 1.0 - metalnessFactor );\r\n        let dxy:vec3<f32> = max( abs( dpdx( geometryNormal ) ), abs( dpdy( geometryNormal ) ) );\r\n        let geometryRoughness:f32 = max( max( dxy.x, dxy.y ), dxy.z );\r\n        material.roughness = max( roughnessFactor, 0.0525 );\r\n        material.roughness += geometryRoughness;\r\n        material.roughness = min( material.roughness, 1.0 );\r\n\r\n        #if ${defines.IOR}\r\n            material.ior = materialUniform.ior;\r\n            #if ${defines.SPECULAR}\r\n                let specularIntensityFactor:f32 = materialUniform.specularIntensity;\r\n                let specularColorFactor:vec3<f32> = materialUniform.specularColor;\r\n                #if ${defines.USE_SPECULARINTENSITYTEXTURE}\r\n                    specularIntensityFactor *=textureSample(specularIntensityTexture, baseSampler, input.vUv).a;\r\n                #endif\r\n\r\n                #if ${defines.USE_SPECULARCOLORTEXTURE}\r\n                    specularColorFactor *=textureSample(specularColorTexture, baseSampler, input.vUv).rgb;\r\n                #endif\r\n\r\n                material.specularF90 = mix( specularIntensityFactor, 1.0, metalnessFactor );\r\n            #else\r\n                let specularIntensityFactor:f32 = 1.0;\r\n                let specularColorFactor:vec3<f32> = vec3<f32>( 1.0 );\r\n                material.specularF90 = 1.0;\r\n            #endif\r\n            material.specularColor = mix( min( pow2( ( material.ior - 1.0 ) / ( material.ior + 1.0 ) ) * specularColorFactor, vec3( 1.0 ) ) * specularIntensityFactor, diffuseColor.rgb, metalnessFactor );\r\n        #else\r\n            material.specularColor = mix( vec3<f32>( 0.04 ), diffuseColor.rgb, metalnessFactor );\r\n            material.specularF90 = 1.0;\r\n        #endif\r\n        #if ${defines.USE_CLEARCOAT}\r\n            material.clearcoat = materialUniform.clearcoat;\r\n            material.clearcoatRoughness = materialUniform.clearcoatRoughness;\r\n            material.clearcoatF0 = vec3<f32>( 0.04 );\r\n            material.clearcoatF90 = 1.0;\r\n            #if ${defines.USE_CLEARCOATTEXTURE}\r\n                material.clearcoat *=textureSample(clearcoatTexture, baseSampler, input.vUv).x;\r\n            #endif\r\n            #if ${defines.USE_CLEARCOAT_ROUGHNESSTEXTURE}\r\n                material.clearcoatRoughness *=textureSample(clearcoatRoughnessTexture, baseSampler, input.vUv).y;\r\n            #endif\r\n            material.clearcoat = saturate( material.clearcoat );\r\n            material.clearcoatRoughness = max( material.clearcoatRoughness, 0.0525 );\r\n            material.clearcoatRoughness += geometryRoughness;\r\n            material.clearcoatRoughness = min( material.clearcoatRoughness, 1.0 );\r\n        #endif\r\n        #if ${defines.USE_IRIDESCENCE}\r\n            material.iridescence = materialUniform.iridescence;\r\n            material.iridescenceIOR = materialUniform.iridescenceIOR;\r\n            #if ${defines.USE_IRIDESCENCETEXTURE}\r\n                material.iridescence *=textureSample(iridescenceTexture, baseSampler, input.vUv).r;\r\n            #endif\r\n            #if ${defines.USE_IRIDESCENCE_THICKNESSTEXTURE}\r\n                material.iridescenceThickness = (materialUniform.iridescenceThicknessMaximum - materialUniform.iridescenceThicknessMinimum) * textureSample(iridescenceThicknessTexture, baseSampler, input.vUv).g + materialUniform.iridescenceThicknessMinimum;\r\n            #else\r\n                material.iridescenceThickness = materialUniform.iridescenceThicknessMaximum;\r\n            #endif\r\n        #endif\r\n        #if ${defines.USE_SHEEN}\r\n            material.sheenColor = materialUniform.sheenColor;\r\n            #if ${defines.USE_SHEENCOLORTEXTURE}\r\n                material.sheenColor *=textureSample(sheenColorTexture, baseSampler, input.vUv).rgb;\r\n            #endif\r\n            material.sheenRoughness = clamp( materialUniform.sheenRoughness, 0.07, 1.0 );\r\n            #if ${defines.USE_SHEENROUGHNESSTEXTURE}\r\n                material.sheenRoughness *=textureSample(sheenRoughnessTexture, baseSampler, input.vUv).a;\r\n            #endif\r\n        #endif\r\n        \r\n        var geometry:GeometricContext;\r\n        geometry.position = - input.vViewPosition;\r\n        geometry.normal = normal;\r\n       // geometry.viewDir = ( isOrthographic ) ? vec3( 0, 0, 1 ) : normalize( input.vViewPosition );\r\n        geometry.viewDir = normalize( input.vViewPosition); \r\n\r\n        #if ${defines.USE_CLEARCOAT}\r\n            geometry.clearcoatNormal = clearcoatNormal;\r\n        #endif\r\n\r\n        #if ${defines.USE_IRIDESCENCE}\r\n            let dotNVi:f32 = saturate( dot( normal, geometry.viewDir ) );\r\n            if ( material.iridescenceThickness == 0.0 ) {\r\n                material.iridescence = 0.0;\r\n            }\r\n            else {\r\n                material.iridescence = saturate( material.iridescence );\r\n            }\r\n            if ( material.iridescence > 0.0 ) {\r\n                material.iridescenceFresnel = evalIridescence( 1.0, material.iridescenceIOR, dotNVi, material.iridescenceThickness, material.specularColor );\r\n                material.iridescenceF0 = Schlick_to_F0( material.iridescenceFresnel, 1.0, dotNVi );\r\n            }\r\n        #endif\r\n\r\n        var iblIrradiance:vec3<f32> = vec3<f32>( 0.0 );\r\n        var irradiance:vec3<f32> = getAmbientLightIrradiance(commonLightsParms.ambient);\r\n        //irradiance += getLightProbeIrradiance( lightProbe, geometry.normal,systemUniform.viewMatrix );\r\n\r\n        var radiance:vec3<f32> = vec3<f32>( 0.0 );\r\n        var clearcoatRadiance:vec3<f32> = vec3<f32>( 0.0 );\r\n\r\n        #if ${defines.USE_LIGHTTEXTURE}\r\n            let lightMapTexel:vec4<f32> =textureSample(lightTexture, baseSampler, input.vUv2);\r\n            let lightMapIrradiance:vec3<f32> = lightMapTexel.rgb * materialUniform.lightTextureIntensity;\r\n            irradiance += lightMapIrradiance;\r\n        #endif\r\n        //&& defines.STANDARD&&defines.ENVTEXTURE_TYPE_CUBE_UV\r\n        #if ${defines.USE_ENVTEXTURE} \r\n            iblIrradiance += getIBLIrradiance( geometry.normal,baseSampler,systemUniform.viewMatrix );\r\n        #endif\r\n        #if ${defines.USE_ENVTEXTURE}\r\n            radiance += getIBLRadiance( geometry.viewDir,baseSampler,systemUniform.viewMatrix, geometry.normal, materialUniform.roughness );\r\n            #if ${defines.USE_CLEARCOAT}\r\n                clearcoatRadiance += getIBLRadiance( geometry.viewDir,baseSampler,systemUniform.viewMatrix, geometry.clearcoatNormal, material.clearcoatRoughness );\r\n            #endif\r\n        #endif\r\n        //直接光照\r\n            let dirReflectedLight:ReflectedLight= parseLights(geometry,material);\r\n            reflectedLight.directDiffuse +=dirReflectedLight.directDiffuse;\r\n            reflectedLight.directSpecular +=dirReflectedLight.directSpecular;\r\n        //间接漫反射\r\n            let indirectDiffuseLight:ReflectedLight= RE_IndirectDiffuse_Physical( irradiance, geometry, material);\r\n            reflectedLight.directDiffuse +=indirectDiffuseLight.indirectDiffuse;\r\n            reflectedLight.directSpecular +=indirectDiffuseLight.indirectSpecular;\r\n        //间接高光\r\n            let indirectSpecularLight:ReflectedLight=RE_IndirectSpecular_Physical( radiance, iblIrradiance, clearcoatRadiance, geometry, material);\r\n            reflectedLight.directDiffuse +=indirectSpecularLight.indirectDiffuse;\r\n            reflectedLight.directSpecular +=indirectSpecularLight.indirectSpecular;\r\n        //环境光遮蔽\r\n        #if ${defines.USE_AOTEXTURE}\r\n            let ambientOcclusion:f32 = (textureSample(aoTexture, baseSampler, input.vUv2).r - 1.0 ) * materialUniform.aoTextureIntensity + 1.0;\r\n\r\n            reflectedLight.indirectDiffuse *= ambientOcclusion;\r\n            //&&defines.STANDARD\r\n            #if ${defines.USE_ENVTEXTURE} \r\n                let dotNV:f32 = saturate( dot( geometry.normal, geometry.viewDir ) );\r\n                reflectedLight.indirectSpecular *= computeSpecularOcclusion( dotNV, ambientOcclusion, material.roughness );\r\n            #endif\r\n        #endif\r\n\r\n        var totalDiffuse:vec3<f32> = reflectedLight.directDiffuse + reflectedLight.indirectDiffuse;\r\n        var totalSpecular:vec3<f32> = reflectedLight.directSpecular + reflectedLight.indirectSpecular;\r\n        //透射\r\n        #if ${defines.USE_TRANSMISSION}\r\n            material.transmission = materialUniform.transmission;\r\n            material.transmissionAlpha = 1.0;\r\n            material.thickness = materialUniform.thickness;\r\n            material.attenuationDistance = materialUniform.attenuationDistance;\r\n            material.attenuationColor = materialUniform.attenuationColor;\r\n            #if ${defines.USE_TRANSMISSIONTEXTURE}\r\n                material.transmission *=textureSample(transmissionTexture, baseSampler, input.vUv).r;\r\n            #endif\r\n            #if ${defines.USE_THICKNESSTEXTURE}\r\n                material.thickness *=textureSample(thicknessTexture, baseSampler, input.vUv).g;\r\n            #endif\r\n            let pos:vec3<f32> = vWorldPosition;\r\n            let v:vec3<f32> = normalize( cameraPosition - pos );\r\n            let n:vec3<f32> = inverseTransformDirection( normal, systemUniform.viewMatrix );\r\n            let transmission:vec4<f32> = getIBLVolumeRefraction(\r\n            n, v, material.roughness, material.diffuseColor, material.specularColor, material.specularF90, pos, modelMatrix, systemUniform.viewMatrix, systemUniform.projectionMatrix, material.ior, material.thickness, material.attenuationColor, material.attenuationDistance );\r\n            material.transmissionAlpha = mix( material.transmissionAlpha, transmission.a, material.transmission );\r\n            totalDiffuse = mix( totalDiffuse, transmission.rgb, material.transmission );\r\n        #endif\r\n\r\n        let outgoingLight:vec3<f32> = totalDiffuse + totalSpecular + totalEmissiveRadiance;\r\n\r\n        #if ${defines.USE_SHEEN}\r\n            let sheenEnergyComp:f32 = 1.0 - 0.157 * max3( material.sheenColor );\r\n            outgoingLight = outgoingLight * sheenEnergyComp + sheenSpecular;\r\n        #endif\r\n\r\n        #if ${defines.USE_CLEARCOAT}\r\n            let dotNVcc:f32 = saturate( dot( geometry.clearcoatNormal, geometry.viewDir ) );\r\n            let Fcc:vec3<f32> = F_Schlick( material.clearcoatF0, material.clearcoatF90, dotNVcc );\r\n            outgoingLight = outgoingLight * ( 1.0 - material.clearcoat * Fcc ) + clearcoatSpecular * material.clearcoat;\r\n        #endif\r\n\r\n        #if ${defines.USE_TRANSMISSION}\r\n            diffuseColor.a *= material.transmissionAlpha + 0.1;\r\n        #endif\r\n\r\n        var finnalColor:vec4<f32>;\r\n        finnalColor = vec4<f32>( outgoingLight, diffuseColor.a );\r\n        #if ${defines.TONE_MAPPING}\r\n           finnalColor.rgb = toneMapping( finnalColor.rgb,materialUniform.toneMappingExposure );\r\n        #endif\r\n\r\n          finnalColor = linearToOutputTexel( finnalColor);\r\n\r\n        #if ${defines.PREMULTIPLIED_ALPHA}\r\n            finnalColor.rgb *= finnalColor.a;\r\n        #endif\r\n        #if ${defines.DITHERING}\r\n            finnalColor.rgb = dithering( finnalColor.rgb );\r\n        #endif\r\n        return finnalColor;\r\n    }`;\r\n}\r\n","import { wgslParseDefines } from \"../WgslPreprocessor\";\r\n\r\nexport default function pbrVert(defines) {\r\n  return wgslParseDefines`\r\n    #include <pbrStruct>\r\n    struct VertexOutput {\r\n        @builtin(position) position: vec4<f32>,\r\n        @location(0) vUv: vec2<f32>,\r\n        @location(1) vViewPosition: vec3<f32>, // Vector from vertex to camera.\r\n        @location(2) vWorldPosition: vec3<f32>,\r\n        @location(3) vNormal: vec3<f32>,\r\n        // 可选\r\n        #if ${defines.USE_LIGHTTEXTURE || defines.USE_AOTEXTURE}\r\n            @location(${defines.vUv2OutLocation}) vUv2: vec2<f32>,\r\n        #endif\r\n\r\n        #if ${defines.USE_COLOR_ALPHA}\r\n            @location(${defines.vColorOutLocation}) vColor: vec4<f32>,\r\n        #elif ${defines.USE_COLOR || defines.USE_INSTANCING_COLOR}\r\n            @location(${defines.vColorOutLocation}) vColor: vec3<f32>,\r\n        #endif\r\n\r\n        #if ${defines.USE_TANGENT}\r\n            @location(${defines.vTangentOutLocation}) vTangent: vec3<f32>,\r\n            @location(${defines.vBitangentOutLocation}) vBitangent: vec3<f32>,\r\n        #endif\r\n    };\r\n    struct GlobalUniform {\r\n        projectionMatrix: mat4x4<f32>,\r\n        viewMatrix: mat4x4<f32>,\r\n        inverseViewMatrix: mat4x4<f32>,\r\n        cameraPosition: vec3<f32>,\r\n    };\r\n\r\n    //texture and sampler\r\n    // @group(0) @binding(${defines.samplerBinding}) var baseSampler: sampler;\r\n    #if ${defines.USE_SKINNING}\r\n        //uniform highp sampler2D boneTexture;\r\n        @group(0) @binding(${\r\n          defines.boneTextureBinding\r\n        }) var boneTexture: texture_2d<f32>;\r\n    #endif\r\n\r\n    #if ${defines.USE_DISPLACEMENTTEXTURE}\r\n        //uniform sampler2D displacementMap;\r\n        @group(0) @binding(${\r\n          defines.displacementTextureBinding\r\n        }) var displacementMap: texture_2d<f32>;\r\n    #endif\r\n\r\n    #if ${defines.MORPHTARGETS_TEXTURE}\r\n        //uniform sampler2DArray morphTargetsTexture;\r\n        @group(0) @binding(${\r\n          defines.morphTargetsTextureBinding\r\n        }) var morphTargetsTexture: texture_2d_array<f32>;\r\n    #endif\r\n\r\n    struct VertexInput {\r\n        @location(0) position: vec3<f32>,  \r\n\r\n        @location(1) normal: vec3<f32>,\r\n\r\n        @location(2) uv: vec2<f32>,\r\n        #if ${defines.USE_LIGHTTEXTURE || defines.USE_AOTEXTURE}\r\n            @location(${defines.uv2Location}) uv2:vec2<f32>,\r\n        #endif\r\n        #if ${defines.USE_INSTANCING}\r\n            @location(${\r\n              defines.instanceMatrixLocation\r\n            }) instanceMatrix:mat4x4<f32>,\r\n        #endif\r\n        #if ${defines.USE_INSTANCING_COLOR}\r\n            @location(${defines.instanceColorLocation}) instanceColor:vec3<f32>,\r\n        #endif\r\n        \r\n        #if ${defines.USE_TANGENT}\r\n            @location(${defines.tangentLocation}) tangent:vec4<f32>,\r\n        #endif\r\n        #if ${defines.USE_COLOR_ALPHA}\r\n            @location(${defines.colorLocation}) color:vec4<f32>,\r\n        #elif ${defines.USE_COLOR}\r\n            @location(${defines.colorLocation}) color:vec3<f32>,\r\n        #endif\r\n\r\n        #if ${defines.USE_MORPHTARGETS && !defines.MORPHTARGETS_TEXTURE}\r\n            @location(${defines.morphTarget0Location}) morphTarget0:vec3<f32>,\r\n\r\n            @location(${defines.morphTarget1Location}) morphTarget1:vec3<f32>,\r\n\r\n            @location(${defines.morphTarget2Location}) morphTarget2:vec3<f32>,\r\n\r\n            @location(${defines.morphTarget3Location}) morphTarget3:vec3<f32>,\r\n            #if ${defines.USE_MORPHNORMALS}\r\n                @location(${\r\n                  defines.morphNormal0Location\r\n                }) morphNormal0:vec3<f32>,\r\n\r\n                @location(${\r\n                  defines.morphNormal1Location\r\n                }) morphNormal1:vec3<f32>,\r\n\r\n                @location(${\r\n                  defines.morphNormal2Location\r\n                }) morphNormal2:vec3<f32>,\r\n\r\n                @location(${\r\n                  defines.morphNormal3Location\r\n                }) morphNormal3:vec3<f32>,\r\n            #else\r\n                @location(${\r\n                  defines.morphTarget4Location\r\n                }) morphTarget4:vec3<f32>,\r\n\r\n                @location(${\r\n                  defines.morphTarget5Location\r\n                }) morphTarget5:vec3<f32>,\r\n\r\n                @location(${\r\n                  defines.morphTarget6Location\r\n                }) morphTarget6:vec3<f32>,\r\n\r\n                @location(${\r\n                  defines.morphTarget7Location\r\n                }) morphTarget7:vec3<f32>,\r\n            #endif\r\n        #endif\r\n        #if ${defines.USE_SKINNING}\r\n            @location(${defines.skinIndexLocation}) skinIndex:vec4<f32>,\r\n            @location(${defines.skinWeightLocation}) skinWeight:vec4<f32>,\r\n        #endif\r\n  }\r\n\r\n    #if ${defines.MORPHTARGETS_TEXTURE}\r\n        fn getMorph( vertexIndex:u32, morphTargetIndex:u32,offset:u32 )->vec4<f32> {\r\n            let texelIndex:u32 = vertexIndex * MORPHTARGETS_TEXTURE_STRIDE + offset;\r\n            let y:u32 = texelIndex / materialUniform.morphTargetsTextureSize.x;\r\n            let x:u32 = texelIndex - y * materialUniform.morphTargetsTextureSize.x;\r\n            let morphUV:vec3<u32> = vec3<u32>( x, y, morphTargetIndex );\r\n            //textureLoad\r\n            //return texelFetch( morphTargetsTexture, morphUV, 0 );\r\n            return textureLoad( morphTargetsTexture, morphUV, 0 );\r\n        }\r\n    #endif\r\n    #if ${defines.USE_SKINNING}\r\n        fn getBoneMatrix( i:f32 )->mat4x4<f32> {\r\n            let j:f32 = i * 4.0;\r\n            let x:f32 = j%f32( materialUniform.boneTextureSize );\r\n            let y:f32 = floor( j / f32( materialUniform.boneTextureSize ) );\r\n            let dx:f32 = 1.0 / f32( materialUniform.boneTextureSize );\r\n            let dy:f32 = 1.0 / f32( materialUniform.boneTextureSize );\r\n            y = dy * ( y + 0.5 );\r\n            \r\n            let v1:vec4<f32> = textureSample(boneTexture, baseSampler, vec2<f32>( dx * ( x + 0.5 ), y ) );\r\n            let v2:vec4<f32> = textureSample(boneTexture, baseSampler, vec2<f32>( dx * ( x + 1.5 ), y ) );\r\n            let v3:vec4<f32> = textureSample(boneTexture, baseSampler, vec2<f32>( dx * ( x + 2.5 ), y ) );\r\n            let v4:vec4<f32> = textureSample(boneTexture, baseSampler, vec2<f32>( dx * ( x + 3.5 ), y ) );\r\n            let bone:mat4x4<f32> = mat4x4<f32>( v1, v2, v3, v4 );\r\n            return bone;\r\n        }\r\n    #endif\r\n\r\n    @binding(0) @group(0) var<uniform> materialUniform : MaterialUniform;\r\n    @binding(0) @group(1) var<uniform> globalUniform : GlobalUniform;\r\n    @vertex\r\n    fn main(input:VertexInput)->VertexOutput {\r\n        var vertexOutput:VertexOutput;\r\n        #if ${defines.USE_TEXTURE}\r\n            vertexOutput.vUv = input.uv;\r\n        #endif\r\n        #if ${defines.USE_LIGHTTEXTURE || defines.USE_AOTEXTURE}\r\n            vertexOutput.vUv2 input.uv2;\r\n        #endif\r\n        #if ${defines.USE_COLOR_ALPHA}\r\n            vertexOutput.vColor = vec4( 1.0 );\r\n            #elif ${defines.USE_COLOR || defines.USE_INSTANCING_COLOR}\r\n            vertexOutput.vColor = vec3( 1.0 );\r\n        #endif\r\n        #if ${defines.USE_COLOR}\r\n            vertexOutput.vColor *= input.color;\r\n        #endif\r\n        #if ${defines.USE_INSTANCING_COLOR}\r\n            vertexOutput.vColor.xyz *= input.instanceColor.xyz;\r\n        #endif\r\n        #if ${defines.USE_MORPHCOLORS && defines.MORPHTARGETS_TEXTURE}\r\n            vertexOutput.vColor *= materialUniform.morphTargetBaseInfluence;\r\n            for (let i : u32 = 0u; i < materialUniform.MORPHTARGETS_COUNT; i = i + 1u ) {\r\n                #if ${defines.USE_COLOR_ALPHA}\r\n                    if ( materialUniform.morphTargetInfluences[ i ] ! = 0.0 ) vertexOutput.vColor += getMorph( gl_VertexID, i, 2 ) * materialUniform.morphTargetInfluences[ i ];\r\n                    #elif ${defines.USE_COLOR}\r\n                    if ( materialUniform.morphTargetInfluences[ i ] ! = 0.0 ) vertexOutput.vColor += getMorph( gl_VertexID, i, 2 ).rgb * materialUniform.morphTargetInfluences[ i ];\r\n                #endif\r\n            }\r\n        #endif\r\n        var objectNormal:vec3<f32> = vec3<f32>(input.normal);\r\n        #if ${defines.USE_TANGENT}\r\n            let objectTangent:vec3<f32> = vec3<f32>( input.tangent.xyz );\r\n        #endif\r\n        #if ${defines.USE_MORPHNORMALS}\r\n            objectNormal *= materialUniform.morphTargetBaseInfluence;\r\n            #if ${defines.MORPHTARGETS_TEXTURE}\r\n                for ( let i : u32 = 0u; i < materialUniform.MORPHTARGETS_COUNT; i = i + 1u) {\r\n                    if ( materialUniform.morphTargetInfluences[ i ] ! = 0.0 ) objectNormal += getMorph( gl_VertexID, i, 1 ).xyz * materialUniform.morphTargetInfluences[ i ];\r\n                }\r\n            #else\r\n                objectNormal += morphNormal0 * materialUniform.morphTargetInfluences[ 0 ];\r\n                objectNormal += morphNormal1 * materialUniform.morphTargetInfluences[ 1 ];\r\n                objectNormal += morphNormal2 * materialUniform.morphTargetInfluences[ 2 ];\r\n                objectNormal += morphNormal3 * materialUniform.morphTargetInfluences[ 3 ];\r\n            #endif\r\n        #endif\r\n        #if ${defines.USE_SKINNING}\r\n            let boneMatX:mat4x4<f32> = getBoneMatrix( input.skinIndex.x );\r\n            let boneMatY:mat4x4<f32> = getBoneMatrix( input.skinIndex.y );\r\n            let boneMatZ:mat4x4<f32> = getBoneMatrix( input.skinIndex.z );\r\n            let boneMatW:mat4x4<f32> = getBoneMatrix( input.skinIndex.w );\r\n        #endif\r\n        #if ${defines.USE_SKINNING}\r\n            let skinMatrix:mat4x4<f32> = mat4x4<f32>( 0.0 );\r\n            skinMatrix += input.skinWeight.x * boneMatX;\r\n            skinMatrix += input.skinWeight.y * boneMatY;\r\n            skinMatrix += input.skinWeight.z * boneMatZ;\r\n            skinMatrix += input.skinWeight.w * boneMatW;\r\n            skinMatrix = materialUniform.bindMatrixInverse * skinMatrix * materialUniform.bindMatrix;\r\n            objectNormal = vec4<f32>( skinMatrix * vec4<f32>( objectNormal, 0.0 ) ).xyz;\r\n            #if ${defines.USE_TANGENT}\r\n                objectTangent = vec4<f32>( skinMatrix * vec4<f32>( objectTangent, 0.0 ) ).xyz;\r\n            #endif\r\n        #endif\r\n        var transformedNormal:vec3<f32> = objectNormal;\r\n        // transformedNormal+=vec3<f32>(0.0);\r\n        #if ${defines.USE_INSTANCING}\r\n            let m:mat3x3<f32> = mat3x3<f32>( input.instanceMatrix );\r\n            transformedNormal /= vec3<f32>( dot( m[ 0 ], m[ 0 ] ), dot( m[ 1 ], m[ 1 ] ), dot( m[ 2 ], m[ 2 ] ) );\r\n            transformedNormal = m * transformedNormal;\r\n        #endif\r\n        transformedNormal = materialUniform.normalMatrix * transformedNormal;\r\n        #if ${defines.FLIP_SIDED}\r\n            transformedNormal = - transformedNormal;\r\n        #endif\r\n        #if ${defines.USE_TANGENT}\r\n            let transformedTangent:vec3<f32> = (globalUniform.viewMatrix*materialUniform.modelMatrix * vec4<f32>( objectTangent, 0.0 ) ).xyz;\r\n            #if ${defines.FLIP_SIDED}\r\n                transformedTangent = - transformedTangent;\r\n            #endif\r\n        #endif\r\n        vertexOutput.vNormal = normalize( transformedNormal );\r\n        #if ${defines.FLAT_SHADED}\r\n            #if ${defines.USE_TANGENT}\r\n                vTangent = normalize( transformedTangent );\r\n                vBitangent = normalize( cross( vNormal, vTangent ) * input.tangent.w );\r\n            #endif\r\n        #endif\r\n        let transformed:vec3<f32> = vec3<f32>( input.position );\r\n        #if ${defines.USE_MORPHTARGETS}\r\n            transformed *= materialUniform.morphTargetBaseInfluence;\r\n            #if ${defines.MORPHTARGETS_TEXTURE}\r\n                for ( let i : u32 = 0u; i < materialUniform.MORPHTARGETS_COUNT; i = i + 1u ) {\r\n                    if ( materialUniform.morphTargetInfluences[ i ] ! = 0.0 ) transformed += getMorph( gl_VertexID, i, 0 ).xyz * morphTargetInfluences[ i ];\r\n                }\r\n            #else\r\n                transformed += input.morphTarget0 * materialUniform.morphTargetInfluences[ 0 ];\r\n                transformed += input.morphTarget1 * materialUniform.morphTargetInfluences[ 1 ];\r\n                transformed += input.morphTarget2 * materialUniform.morphTargetInfluences[ 2 ];\r\n                transformed += input.morphTarget3 * materialUniform.morphTargetInfluences[ 3 ];\r\n                #if ${defines.USE_MORPHNORMALS}\r\n                    transformed += input.morphTarget4 * materialUniform.morphTargetInfluences[ 4 ];\r\n                    transformed += input.morphTarget5 * materialUniform.morphTargetInfluences[ 5 ];\r\n                    transformed += input.morphTarget6 * materialUniform.morphTargetInfluences[ 6 ];\r\n                    transformed += input.morphTarget7 * materialUniform.morphTargetInfluences[ 7 ];\r\n                #endif\r\n            #endif\r\n        #endif\r\n        #if ${defines.USE_SKINNING}\r\n            let skinVertex:vec4<f32> = materialUniform.bindMatrix * vec4<f32>( transformed, 1.0 );\r\n            let skinned:vec4<f32> = vec4<f32>( 0.0 );\r\n            skinned += boneMatX * skinVertex * input.skinWeight.x;\r\n            skinned += boneMatY * skinVertex * input.skinWeight.y;\r\n            skinned += boneMatZ * skinVertex * input.skinWeight.z;\r\n            skinned += boneMatW * skinVertex * input.skinWeight.w;\r\n            transformed = ( materialUniform.bindMatrixInverse * skinned ).xyz;\r\n        #endif\r\n        #if ${defines.USE_DISPLACEMENTTEXTURE} \r\n            transformed += normalize( objectNormal ) * (textureSample(displacementMap, baseSampler, vUv).x * materialUniform.displacementScale + materialUniform.displacementBias );\r\n        #endif\r\n        var mvPosition:vec4<f32> = vec4<f32>( transformed, 1.0 );\r\n        #if ${defines.USE_INSTANCING}\r\n            mvPosition = input.instanceMatrix * mvPosition;\r\n        #endif\r\n        mvPosition = globalUniform.viewMatrix*materialUniform.modelMatrix * mvPosition;\r\n        vertexOutput.position = globalUniform.projectionMatrix * mvPosition;\r\n        vertexOutput.vViewPosition = - mvPosition.xyz/mvPosition.w;\r\n        #if ${\r\n          defines.USE_ENVTEXTURE || defines.DISTANCE || defines.USE_TRANSMISSION\r\n        } \r\n            var worldPosition:vec4<f32> = vec4<f32>( transformed, 1.0 );\r\n            #if ${defines.USE_INSTANCING}\r\n                worldPosition = input.instanceMatrix * worldPosition;\r\n            #endif\r\n            worldPosition = materialUniform.modelMatrix * worldPosition;\r\n        #endif\r\n        #if ${defines.USE_TRANSMISSION}\r\n            vertexOutput.vWorldPosition = worldPosition.xyz;\r\n        #endif\r\n        return vertexOutput;\r\n    }\r\n    `;\r\n}\r\n","import { wgslParseDefines } from \"../WgslPreprocessor\";\r\nexport default function phongFrag(defines) {\r\n\treturn wgslParseDefines`  \r\n    struct MaterialUniform {\r\n      modelMatrix: mat4x4<f32>,\r\n      color: vec3<f32>,\r\n      opacity:f32,\r\n      normalMatrix: mat4x4<f32>,\r\n      emissive:vec3<f32>,\r\n      shininess:f32,\r\n      specular:vec3<f32>,      \r\n   }\r\n    #include <FragInput>\r\n    #include <SystemUniform>\r\n    #include <TextureAndSamplerDefine>\r\n    #include <light>\r\n    @binding(${defines.phongBinding}) @group(0) var<uniform> materialUniform : MaterialUniform;\r\n    @binding(${defines.cameraBinding}) @group(1) var<uniform> systemUniform : SystemUniform;\r\n    @fragment\r\n    fn main(input:FragInput) -> @location(0) vec4<f32> {\r\n        var totalEmissiveRadiance:vec3<f32> = materialUniform.emissive;\r\n        var color:vec4<f32>;\r\n        #if${defines.USE_COLORTEXTURE}\r\n            color= vec4<f32>(textureSample(baseColorTexture, baseColorSampler, input.uv).rgb+materialUniform.color,materialUniform.opacity);\r\n        #else\r\n            color=vec4<f32>(materialUniform.color,materialUniform.opacity);\r\n        #endif     \r\n        let  V:vec3<f32> =  normalize( systemUniform.cameraPosition - input.worldPos);\r\n        #if ${defines.USE_NORMALTEXTURE}\r\n            let N:vec3<f32> = getNormalByNormalTexture(input);  \r\n        #else\r\n            let N:vec3<f32> = getNormal(input);\r\n        #endif\r\n        var geometry:Geometry;\r\n        geometry.normal=N;\r\n        geometry.viewDir=V;\r\n        geometry.position=input.worldPos;\r\n        let lightColor:ReflectedLight=parseLights(geometry,materialUniform.shininess);\r\n        // var finnalColor:vec3<f32>=color.xyz + (lightColor.directDiffuse + lightColor.directSpecular + lightColor.ambient);\r\n        var finnalColor:vec3<f32>=color.xyz * (lightColor.directDiffuse + lightColor.directSpecular + lightColor.ambient);\r\n\r\n        // finnalColor = lightColor.testColor.xyz;\r\n\r\n        return vec4<f32>(finnalColor,color.a);\r\n    }`;\r\n}\r\n","import { wgslParseDefines } from \"../WgslPreprocessor\";\nexport default function phongVert(defines) {\n\treturn wgslParseDefines`\n      struct MaterialUniform {\n            modelMatrix: mat4x4<f32>,\n            color: vec3<f32>,\n            opacity:f32,\n            normalMatrix: mat4x4<f32>,\n            emissive:vec3<f32>,\n            specular:vec3<f32>,\n            shininess:f32,\n      }\n      #include <VertexOutput>\n      #include <SystemUniform>\n      #include <VertexInput>\n      @binding(${defines.phongBinding}) @group(0) var<uniform> selfUniform : MaterialUniform;\n      @binding(${defines.cameraBinding}) @group(1) var<uniform> systemUniform : SystemUniform;\n      @vertex\n      fn main(input: VertexInput) -> VertexOutput {\n            var output: VertexOutput;\n            #if ${defines.HAS_UV}\n               output.uv = input.uv;\n            #endif \n            let modelPos=selfUniform.modelMatrix *vec4<f32>(input.position,1.0);\n            output.worldPos = modelPos.xyz/modelPos.w;\n            let vNormalView = selfUniform.normalMatrix * vec4<f32>(input.normal,0.0);\n            output.normal =  vNormalView.xyz;\n            output.view = systemUniform.cameraPosition.xyz - modelPos.xyz;\n            let viewPosition=systemUniform.viewMatrix * modelPos;\n            output.viewPosition = -viewPosition.xyz;\n            output.position = systemUniform.projectionMatrix * systemUniform.viewMatrix * modelPos;\n            return output;\n      }`;\n}\n","export default function quadFrag(defines) {\r\n\treturn `\r\n    @group(0) @binding(1) var baseSampler: sampler;\r\n    @group(0) @binding(0) var colorTexture: texture_2d<f32>;\r\n    struct VertexOutput {\r\n        @builtin(position) position: vec4<f32>,\r\n        @location(0) uv: vec2<f32>,\r\n    };\r\n    @fragment\r\n    fn main(input:VertexOutput) -> @location(0) vec4<f32> {\r\n      return textureSample(colorTexture, baseSampler, vec2<f32>(input.uv.x,1.0-input.uv.y));\r\n    }\r\n    `;\r\n}\r\n","export default function quadVert(defines) {\n\treturn `\n    struct VertexInput {\n         @location(${defines.positionLocation}) position: vec2<f32>,       \n    }\n    struct VertexOutput {\n         @builtin(position) position: vec4<f32>,\n         @location(0) uv: vec2<f32>,\n     };\n    @vertex\n    fn main(input: VertexInput) -> VertexOutput {\n     var output:VertexOutput;\n     output.uv = input.position * 0.5 + 0.5;\n     output.position = vec4<f32>(input.position, 0.0, 1.0);;\n     return output;\n    }\n    `;\n}\n","export default function skyBoxFrag(defines) {\r\n  return `\r\n    fn lessThanEqual(a:vec3<f32>,b:vec3<f32>)->vec3<f32>{\r\n        let xValue:f32=select(b.x,a.x,a.x<=b.x);\r\n        let yValue:f32=select(b.y,a.y,a.y<=b.y);\r\n        let zValue:f32=select(b.z,a.z,a.z<=b.z);\r\n        return vec3<f32>(xValue,yValue,zValue);    \r\n     }\r\n    fn LinearTosRGB( value:vec4<f32> )->vec4<f32> {\r\n        return vec4<f32>( mix( pow( value.rgb, vec3<f32>( 0.41666 ) ) * 1.055 - vec3<f32>( 0.055 ), value.rgb * 12.92, vec3<f32>( lessThanEqual( value.rgb, vec3<f32>( 0.0031308 ) ) ) ), value.a );\r\n    }\r\n  struct FragmentInput {\r\n    @location(0) texCoord : vec3<f32>\r\n  };\r\n  @group(0) @binding(2) var defaultSampler: sampler;\r\n  @group(0) @binding(1) var skyboxTexture: texture_cube<f32>;\r\n  @fragment\r\n  fn main(input : FragmentInput) -> @location(0) vec4<f32> {\r\n    let color = textureSample(skyboxTexture, defaultSampler, input.texCoord);\r\n    return LinearTosRGB(color);\r\n  }\r\n`;\r\n}\r\n","export default function skyBoxVert(defines) {\n\treturn `\n   struct SystemUniform {\n       projectionMatrix: mat4x4<f32>,\n       viewMatrix: mat4x4<f32>,\n       inverseViewMatrix: mat4x4<f32>,\n       cameraPosition: vec3<f32>,\n   }; \n   struct MaterialUniform {\n    modelMatrix: mat4x4<f32>,\n }\n   @binding(${defines.skyboxBinding}) @group(0) var<uniform> selfUniform : MaterialUniform;\n   @binding(${defines.cameraBinding}) @group(1) var<uniform> systemUniform : SystemUniform;\n     struct VertexInput {\n       @location(${defines.positionLocation}) position : vec3<f32>,\n     };\n     struct VertexOutput {\n       @builtin(position) position : vec4<f32>,\n       @location(0) texCoord : vec3<f32>,\n     };\n     @vertex\n     fn main(input : VertexInput) -> VertexOutput {\n       var output : VertexOutput;\n       output.texCoord = input.position.xyz;\n       var modelView = systemUniform.viewMatrix;\n       // Drop the translation portion of the modelView matrix\n       modelView[3] = vec4(0.0, 0.0, 0.0, modelView[3].w);\n       output.position = systemUniform.projectionMatrix * modelView * vec4<f32>(input.position,1.0);\n       output.position = output.position.xyww;\n       return output;\n     }\n   `;\n}\n","export default function blendFrag(defines) {\r\n\treturn `\r\n    struct FragInput {\r\n        @location(0) uv: vec2<f32>,\r\n    };\r\n    @group(0) @binding({{tDiffuseBinding}}) var tDiffuse: texture_2d<f32>;\r\n    @group(0) @binding({{baseColorTextureBinding}}) var baseColorTexture: texture_2d<f32>;\r\n    @group(0) @binding({{tSamplerBinding}}) var tSampler: sampler;\r\n    @fragment\r\n    fn main(input:FragInput) -> @location(0) vec4<f32> {\r\n        let postColor:vec4<f32> = textureSample(tDiffuse, tSampler, input.uv);\r\n        let baseColor:vec4<f32> = textureSample(baseColorTexture, tSampler, input.uv);\r\n      return baseColor+postColor;\r\n    }   \r\n    `;\r\n}\r\n","export default function Blur(defines) {\r\n\treturn `\r\n    struct FragInput {\r\n        @location(0) uv: vec2<f32>,\r\n    }\r\n    struct BlurUniforms {\r\n        direction:vec2<f32>,\r\n    }\r\n    fn gaussianPdf(x:f32, sigma:f32)->f32 {\r\n        return 0.39894 * exp( -0.5 * x * x/( sigma * sigma))/sigma;\r\n    }\r\n    @group(0) @binding(0)  var<uniform> blurUniforms : BlurUniforms;\r\n    @group(0) @binding({{tDiffuseBinding}}) var tDiffuse: texture_2d<f32>;\r\n    @group(0) @binding({{tSamplerBinding}}) var tSampler: sampler;\r\n    @fragment\r\n    fn main(input:FragInput) -> @location(0) vec4<f32> {\r\n        let invSize:vec2<f32> = vec2<f32>(1.0,1.0) / vec2<f32>(textureDimensions(tDiffuse));\r\n        let fSigma:f32 =f32(${defines.SIGMA});\r\n        var weightSum:f32 = gaussianPdf(0.0, fSigma);\r\n        let baseColor=textureSample(tDiffuse, tSampler, input.uv);\r\n        var diffuseSum:vec3<f32> = baseColor.rgb * weightSum;\r\n        let uvOffset:vec2<f32> = blurUniforms.direction * invSize;\r\n        for( var i : u32 = 1; i < ${defines.KERNEL_RADIUS};i = i + 1 ) {\r\n            let x:f32 = f32(i);\r\n            let w:f32 = gaussianPdf(x, fSigma);\r\n            let sample1:vec3<f32>=textureSample(tDiffuse, tSampler, input.uv+ uvOffset*x).rgb;\r\n            let sample2:vec3<f32>=textureSample(tDiffuse, tSampler, input.uv- uvOffset*x).rgb;\r\n            diffuseSum =diffuseSum+ (sample2+sample2)* w;\r\n            weightSum += 2.0 * w;\r\n        }\r\n        diffuseSum/=weightSum;\r\n      return vec4<f32>(diffuseSum,baseColor.a);\r\n    }\r\n  `;\r\n}\r\n","export default function LuminosityHigh(defines) {\r\n\treturn `\r\n    struct LuminosityUniforms{\r\n        luminosityThreshold:f32,\r\n        smoothWidth:f32,\r\n        defaultColor:vec3<f32>,\r\n        defaultOpacity:f32,\r\n    }\r\n    struct FragInput {\r\n        @location(0) uv: vec2<f32>,\r\n    };\r\n    @group(0) @binding(0)  var<uniform> luminosityUniforms : LuminosityUniforms;\r\n    @group(0) @binding({{tDiffuseBinding}}) var tDiffuse: texture_2d<f32>;\r\n    @group(0) @binding({{tSamplerBinding}}) var tSampler: sampler;\r\n    @fragment\r\n    fn main(input:FragInput)-> @location(0) vec4<f32> {\r\n\r\n        let texel:vec4<f32> = textureSample(tDiffuse, tSampler, input.uv);\r\n\r\n        let luma:vec3<f32> = vec3<f32>( 0.299,0.587,0.114 );\r\n\r\n        let v:f32 = dot( texel.xyz, luma );\r\n\r\n        let outputColor:vec4<f32> = vec4<f32>( luminosityUniforms.defaultColor.rgb, luminosityUniforms.defaultOpacity );\r\n\r\n        let alpha:f32 = smoothstep( luminosityUniforms.luminosityThreshold, luminosityUniforms.luminosityThreshold + luminosityUniforms.smoothWidth, v );\r\n\r\n       return mix( outputColor, texel, alpha );\r\n    }\r\n    `;\r\n}\r\n","import { wgslParseDefines } from \"../../WgslPreprocessor\";\n\nexport function FragInput(defines) {\n\treturn wgslParseDefines`\n    struct FragInput {\n      @builtin(front_facing) frontFacing: bool,\n      @location(0) worldPos:vec3<f32>,\n      @location(1) normal:vec3<f32>,\n      @location(2) uv:vec2<f32>,\n      @location(3) view: vec3<f32>, // Vector from vertex to camera.\n      @location(4) color: vec4<f32>,\n      @location(5) viewPosition: vec3<f32>,\n  } \n  `;\n}\n","import { wgslParseDefines } from \"../../WgslPreprocessor\";\n\nexport function VertexInput(defines) {\n\treturn wgslParseDefines`\n        struct VertexInput {\n            @location(${defines.positionLocation}) position: vec3<f32>,       \n            @location(${defines.normalLocation}) normal: vec3<f32>,\n            #if${defines.HAS_COLOR} \n                @location(${defines.colorLocation}) color: vec3<f32>,\n            #endif\n            #if ${defines.HAS_UV}\n                @location(${defines.uvLocation}) uv: vec2<f32>,\n            #endif\n            #if${defines.HAS_SKIN} \n                @location(${defines.joint0Location}) joint0:vec4<f32>,\n                @location(${defines.weight0Location}) weight0:vec4<f32>,\n            #endif\n            #if ${defines.USE_INSTANCE}\n                @builtin(instance_index) instanceIdx : u32\n            #endif\n        }\n   `;\n}\n","import { wgslParseDefines } from \"../../WgslPreprocessor\";\n\nexport function VertexOutput(defines) {\n\treturn wgslParseDefines`\n    struct VertexOutput {\n        @builtin(position) position:vec4<f32>,\n        @location(0) worldPos:vec3<f32>,\n        @location(1) normal:vec3<f32>,\n        @location(2) uv:vec2<f32>,\n        @location(3) view: vec3<f32>, // Vector from vertex to camera.\n        @location(4) color: vec4<f32>,\n        @location(5) viewPosition: vec3<f32>,\n    } \n    `;\n}\n","import { wgslParseDefines } from \"../../WgslPreprocessor\";\n\nexport function SystemUniform(defines) {\n\treturn wgslParseDefines`\n      struct SystemUniform {\n          projectionMatrix: mat4x4<f32>,\n          viewMatrix: mat4x4<f32>,\n          inverseViewMatrix: mat4x4<f32>,\n          cameraPosition: vec3<f32>,\n      }; \n  `;\n}\n","import { wgslParseDefines } from \"../../WgslPreprocessor\";\r\n\r\nexport function TextureAndSamplerDefine(defines){\r\n  return  wgslParseDefines`\r\n    #if ${defines.USE_IBL}\r\n      @group(0) @binding(${defines.specularEnvTextureBinding}) var specularEnvTexture: texture_cube<f32>;\r\n      @group(0) @binding(${defines.specularEnvSamplerBinding}) var specularEnvSampler: sampler;\r\n    #endif\r\n    #if ${defines.USE_TEXTURE}\r\n      @group(0) @binding(${defines.baseColorTextureBinding}) var baseColorTexture: texture_2d<f32>;\r\n      @group(0) @binding(${defines.baseColorSamplerBinding}) var baseColorSampler: sampler;\r\n    #endif\r\n    // normal map\r\n    #if ${defines.USE_NORMALTEXTURE}\r\n      @group(0) @binding(${defines.normalTextureBinding}) var normalTexture: texture_2d<f32>;\r\n      @group(0) @binding(${defines.normalSamplerBinding}) var normalSampler: sampler;\r\n    #endif\r\n    // emmisve map\r\n    #if ${defines.USE_EMISSIVETEXTURE}\r\n      @group(0) @binding(${defines.emissiveTextureBinding}) var emissiveTexture: texture_2d<f32>;\r\n      @group(0) @binding(${defines.emissiveSamplerBinding}) var emissiveSampler: sampler;\r\n    #endif\r\n\r\n    // metal roughness\r\n    #if ${defines.USE_METALNESSTEXTURE}\r\n      @group(0) @binding(${defines.metalnessRoughnessTextureBinding}) var metalnessRoughnessTexture: texture_2d<f32>;\r\n      @group(0) @binding(${defines.metalnessRoughnessSamplerBinding}) var metalnessRoughnessSampler: sampler;\r\n    #endif\r\n    // occlusion texture\r\n    #if ${defines.USE_AOTEXTURE}\r\n      @group(0) @binding(${defines.aoTextureBinding}) var aoTexture: texture_2d<f32>;\r\n      @group(0) @binding(${defines.aoSamplerBinding}) var aoSampler: sampler;\r\n    #endif\r\n    #if ${defines.USE_NORMALTEXTURE}\r\n      #include <getTBN>\r\n      #include <getNormalByNormalTexture>\r\n    #else\r\n      #include <getNormal>\r\n    #endif\r\n  `\r\n}","import { wgslParseDefines } from \"../../WgslPreprocessor\";\r\nexport default function environment(defines) {\r\n  return wgslParseDefines`\r\n   #if ${defines.ENVTEXTURE_TYPE_CUBE_UV}\r\n        const cubeUV_minMipLevel:f32= 4.0;\r\n        const cubeUV_minTileSize:f32= 16.0;\r\n        const CUBEUV_MAX_MIP:f32=6.0;\r\n        const CUBEUV_TEXEL_WIDTH:f32=1.0/256.0;\r\n        const CUBEUV_TEXEL_HEIGHT:f32=1.0/256.0;\r\n        fn getFace(direction:vec3<f32> )->f32 {\r\n            let absDirection:vec3<f32> = abs( direction );\r\n            var face:f32 = - 1.0;\r\n            if ( absDirection.x > absDirection.z ) {\r\n                if ( absDirection.x > absDirection.y ){\r\n                    face =select(3.0,0.0,direction.x > 0.0);\r\n                }else{\r\n                    face =select(4.0,1.0,direction.y > 0.0);\r\n                }\r\n                \r\n            }\r\n            else {\r\n                if ( absDirection.z > absDirection.y ){\r\n                    face =select(5.0,2.0,direction.z > 0.0);\r\n                }else{\r\n                    face =select(4.0,1.0,direction.y > 0.0);\r\n                }       \r\n            }\r\n            return face;\r\n        }\r\n        fn getUV( direction:vec3<f32>, face:f32 )->vec2<f32> {\r\n            var uv:vec2<f32>;\r\n            if ( face == 0.0 ) {\r\n                uv = vec2<f32>( direction.z, direction.y ) / abs( direction.x );\r\n            }\r\n            else if ( face == 1.0 ) {\r\n                uv = vec2<f32>( - direction.x, - direction.z ) / abs( direction.y );\r\n            }\r\n            else if ( face == 2.0 ) {\r\n                uv = vec2<f32>( - direction.x, direction.y ) / abs( direction.z );\r\n            }\r\n            else if ( face == 3.0 ) {\r\n                uv = vec2<f32>( - direction.z, direction.y ) / abs( direction.x );\r\n            }\r\n            else if ( face == 4.0 ) {\r\n                uv = vec2<f32>( - direction.x, direction.z ) / abs( direction.y );\r\n            }\r\n            else {\r\n                uv = vec2<f32>( direction.x, direction.y ) / abs( direction.z );\r\n            }\r\n            return 0.5 * ( uv + 1.0 );\r\n        }\r\n        fn bilinearCubeUV(envTexture:texture_cube<f32>,baseSampler:sampler,direction:vec3<f32>, mipInt:f32 )->vec3<f32> {\r\n            var face:f32 = getFace( direction );\r\n            let filterInt:f32 = max( cubeUV_minMipLevel - mipInt, 0.0 );\r\n            let tempMipInt = max( mipInt, cubeUV_minMipLevel );\r\n            let faceSize:f32 = exp2( tempMipInt );\r\n            var uv:vec2<f32> = getUV( direction, face ) * ( faceSize - 2.0 ) + 1.0;\r\n            if ( face > 2.0 ) {\r\n                uv.y += faceSize;\r\n                face -= 3.0;\r\n            }\r\n            uv.x += face * faceSize;\r\n            uv.x += filterInt * 3.0 * cubeUV_minTileSize;\r\n            uv.y += 4.0 * ( exp2( CUBEUV_MAX_MIP ) - faceSize );\r\n            uv.x *= CUBEUV_TEXEL_WIDTH;\r\n            uv.y *= CUBEUV_TEXEL_HEIGHT;\r\n            return textureSample(envTexture,baseSampler,direction).rgb;\r\n        }\r\n        const cubeUV_r0:f32= 1.0;\r\n        const cubeUV_v0:f32= 0.339;\r\n        const cubeUV_m0:f32= - 2.0;\r\n        const cubeUV_r1:f32= 0.8;\r\n        const cubeUV_v1:f32= 0.276;\r\n        const cubeUV_m1:f32= - 1.0;\r\n        const cubeUV_r4:f32= 0.4;\r\n        const cubeUV_v4:f32= 0.046;\r\n        const cubeUV_m4:f32= 2.0;\r\n        const cubeUV_r5:f32= 0.305;\r\n        const cubeUV_v5:f32= 0.016;\r\n        const cubeUV_m5:f32= 3.0;\r\n        const cubeUV_r6:f32= 0.21;\r\n        const cubeUV_v6:f32= 0.0038;\r\n        const cubeUV_m6:f32= 4.0;\r\n        fn roughnessToMip( roughness:f32)->f32 {\r\n            var mip:f32 = 0.0;\r\n            if ( roughness >= cubeUV_r1 ) {\r\n                mip = ( cubeUV_r0 - roughness ) * ( cubeUV_m1 - cubeUV_m0 ) / ( cubeUV_r0 - cubeUV_r1 ) + cubeUV_m0;\r\n            }\r\n            else if ( roughness >= cubeUV_r4 ) {\r\n                mip = ( cubeUV_r1 - roughness ) * ( cubeUV_m4 - cubeUV_m1 ) / ( cubeUV_r1 - cubeUV_r4 ) + cubeUV_m1;\r\n            }\r\n            else if ( roughness >= cubeUV_r5 ) {\r\n                mip = ( cubeUV_r4 - roughness ) * ( cubeUV_m5 - cubeUV_m4 ) / ( cubeUV_r4 - cubeUV_r5 ) + cubeUV_m4;\r\n            }\r\n            else if ( roughness >= cubeUV_r6 ) {\r\n                mip = ( cubeUV_r5 - roughness ) * ( cubeUV_m6 - cubeUV_m5 ) / ( cubeUV_r5 - cubeUV_r6 ) + cubeUV_m5;\r\n            }\r\n            else {\r\n                mip = - 2.0 * log2( 1.16 * roughness );\r\n            }\r\n            return mip;\r\n        }\r\n        fn textureCubeUV(envTexture:texture_cube<f32>, baseSampler:sampler,sampleDir:vec3<f32>,roughness:f32 )->vec4<f32> {\r\n            let mip = clamp( roughnessToMip( roughness ), cubeUV_m0, CUBEUV_MAX_MIP );\r\n            let mipF = fract( mip );\r\n            let mipInt = floor( mip );\r\n            let color0:vec3<f32> = bilinearCubeUV( envTexture,baseSampler,sampleDir, mipInt );\r\n            if ( mipF == 0.0 ) {\r\n                return vec4<f32>(color0, 1.0 );\r\n            }\r\n            else {\r\n                let color1:vec3<f32> = bilinearCubeUV( envTexture,baseSampler, sampleDir, mipInt + 1.0 );\r\n                return vec4<f32>(mix( color0, color1, mipF ), 1.0 );\r\n            }\r\n        \r\n        }\r\n   #endif\r\n   #if ${defines.USE_ENVTEXTURE}\r\n        fn getIBLIrradiance( normal:vec3<f32>,baseSampler:sampler,viewMatrix:mat4x4<f32>)->vec3<f32> {\r\n            #if ${defines.ENVTEXTURE_TYPE_CUBE_UV}\r\n                let worldNormal:vec3<f32> = inverseTransformDirection( normal, viewMatrix );\r\n                let envTextureColor:vec4<f32> = textureCubeUV( envTexture,baseSampler, worldNormal, 1.0 );\r\n                return PI * envTextureColor.rgb * materialUniform.envTextureIntensity;\r\n            #else\r\n                return vec3<f32>( 0.0 );\r\n            #endif\r\n        }\r\n        fn getIBLRadiance( viewDir:vec3<f32>,baseSampler:sampler,viewMatrix:mat4x4<f32>,normal:vec3<f32>, roughness:f32 )->vec3<f32> {\r\n            #if ${defines.ENVTEXTURE_TYPE_CUBE_UV}\r\n                var reflectVec:vec3<f32> = reflect( - viewDir, normal );\r\n                reflectVec = normalize( mix( reflectVec, normal, roughness * roughness) );\r\n                reflectVec = inverseTransformDirection( reflectVec, viewMatrix );\r\n                let envTextureColor:vec4<f32> = textureCubeUV( envTexture,baseSampler, reflectVec, roughness );\r\n                return envTextureColor.rgb * materialUniform.envTextureIntensity;\r\n            #else\r\n                return vec3<f32>( 0.0 );\r\n            #endif\r\n            }\r\n    #endif\r\n   `;\r\n}\r\n","import { wgslParseDefines } from \"../../WgslPreprocessor\";\n\nexport function instanceVertHeader(defines) {\n\treturn wgslParseDefines`\n   #if ${defines.USE_INSTANCE}\n      struct InstancesUniform {\n         instanceMatrixs:  array<mat4x4<f32>, ${defines.instanceCount}>,\n      };\n      @group(0) @binding(${defines.instanceMatrixsBufferBinding}) var<storage, read> instancesUniform: InstancesUniform;\n    #endif\n   `;\n}\nexport function instanceVertMain(defines) {\n\treturn wgslParseDefines`\n      #if ${defines.USE_INSTANCE}\n         modelMatrix=instancesUniform.instanceMatrixs[input.instanceIdx];\n      #endif\n   `;\n}\n","import { wgslParseDefines } from \"../../WgslPreprocessor\";\r\nexport default function light(defines) {\r\n\treturn wgslParseDefines` \r\n    struct ReflectedLight {\r\n        ambient: vec3<f32>,\r\n        directDiffuse:vec3<f32>,\r\n        directSpecular:vec3<f32>,\r\n        indirectDiffuse:vec3<f32>,\r\n        indirectSpecular:vec3<f32>,\r\n        testColor: vec3<f32>,\r\n    }; \r\n    struct IncidentLight {\r\n        color: vec3<f32>,\r\n        direction: vec3<f32>,\r\n        visible: bool,\r\n    };\r\n    struct Geometry {\r\n        position: vec3<f32>,\r\n        normal: vec3<f32>,\r\n        viewDir: vec3<f32>,\r\n        dotNV:f32,\r\n        #if ${defines.USE_CLEARCOAT}\r\n            vec3 clearcoatNormal;\r\n        #endif\r\n    };\r\n\r\n    #if ${defines.spotLightsCount > 0}\r\n        struct SpotLight {\r\n            position: vec3<f32>,\r\n            distance: f32,\r\n            direction: vec3<f32>,\r\n            coneCos: f32,\r\n            color: vec3<f32>,\r\n            penumbraCos: f32,\r\n            decay: f32,\r\n        };\r\n        fn getSpotLightInfo(spotLight:SpotLight,worldPos:vec3<f32>,shininess:f32,N:vec3<f32>,V:vec3<f32>)->ReflectedLight{\r\n                var direction:vec3<f32> = spotLight.position - worldPos;\r\n                var lightColor:ReflectedLight;\r\n                let lightDistance:f32 = length(direction);\r\n                direction = normalize(direction);\r\n                let angleCos:f32 = dot( direction, spotLight.direction );\r\n                let decay:f32 = clamp(1.0 - pow(lightDistance/spotLight.distance, spotLight.decay), 0.0, 1.0);\r\n                let spotEffect:f32 = smoothstep( spotLight.penumbraCos, spotLight.coneCos, angleCos );\r\n                let decayTotal:f32 = decay * spotEffect;\r\n                let d:f32 = max( dot( N, direction ), 0.0 )  * decayTotal;\r\n                lightColor.directDiffuse= spotLight.color * d;\r\n                let halfDir:vec3<f32> = normalize( V + direction );\r\n                let s:f32 = pow( clamp( dot( N, halfDir ), 0.0, 1.0 ), shininess ) * decayTotal;\r\n                lightColor.directSpecular= spotLight.color * s;\r\n                return lightColor;\r\n        }\r\n        fn getSpotLightIncidentLight(spotLight:SpotLight, geometry:Geometry)->IncidentLight {\r\n            var incidentLight:IncidentLight;\r\n            let lVector:vec3<f32> = spotLight.position - geometry.position;\r\n            incidentLight.direction = normalize( lVector );\r\n    \r\n            let lightDistance:f32 = length( lVector );\r\n            let angleCos:f32 = dot( incidentLight.direction, spotLight.direction );\r\n    \r\n            let spotEffect:f32 = smoothstep( spotLight.penumbraCos, spotLight.coneCos, angleCos );\r\n            let decayEffect:f32 = clamp(1.0 - pow(lightDistance/spotLight.distance, 4.0), 0.0, 1.0);\r\n    \r\n            incidentLight.color=spotLight.color*spotEffect * decayEffect; \r\n            return  incidentLight;\r\n        }\r\n\r\n    #endif \r\n\r\n    #if ${defines.pointLightsCount > 0}\r\n        struct PointLight {\r\n            position: vec3<f32>,\r\n            distance: f32,\r\n            color: vec3<f32>,\r\n            decay: f32,\r\n        };\r\n        fn getPointLightInfo(pointLight:PointLight,worldPos:vec3<f32>,shininess:f32,N:vec3<f32>,V:vec3<f32>)->ReflectedLight{\r\n            var lightColor:ReflectedLight;\r\n            var direction:vec3<f32> = worldPos - pointLight.position;\r\n            let dist:f32 = length( direction );\r\n            direction = normalize(direction);\r\n            let decay = clamp(1.0 - pow(dist / pointLight.distance, pointLight.decay), 0.0, 1.0);\r\n    \r\n            let d =  max( dot( N, -direction ), 0.0 ) * decay;\r\n            lightColor.directDiffuse = pointLight.color * d;\r\n    \r\n            let halfDir:vec3<f32> = normalize( V - direction );\r\n            let s:f32 = pow( clamp( dot( N, halfDir ), 0.0, 1.0 ), shininess )  * decay;\r\n            lightColor.directSpecular = pointLight.color * s;\r\n            return lightColor;\r\n        }\r\n        fn getPointLightIncidentLight(pointLight:PointLight, geometry:Geometry)->IncidentLight {\r\n            var incidentLight:IncidentLight;\r\n            let lVector:vec3<f32> = pointLight.position-geometry.position;\r\n            incidentLight.direction= normalize( lVector );\r\n            let lightDistance:f32 = length( lVector );\r\n            // let weight:f32=1.0 - pow(lightDistance/pointLight.distance, 4.0);\r\n            incidentLight.color=pointLight.color*clamp(1.0 - pow(lightDistance/pointLight.distance, 4.0), 0.0, 1.0);\r\n            return incidentLight;\r\n        }\r\n    #endif\r\n    #if ${defines.dirtectLightsCount > 0}\r\n        struct DirectionalLight {\r\n            direction: vec3<f32>,\r\n            color: vec3<f32>,\r\n        };\r\n        fn getDirectLightInfo(directionalLight:DirectionalLight,shininess:f32,N:vec3<f32>,V:vec3<f32>)->ReflectedLight{\r\n            var lightColor:ReflectedLight;\r\n            let d:f32 = max(dot(N, -directionalLight.direction), 0.0);\r\n            lightColor.directDiffuse += directionalLight.color * d;\r\n    \r\n            let halfDir:vec3<f32> = normalize( V - directionalLight.direction );\r\n            let s:f32 = pow( clamp( dot( N, halfDir ), 0.0, 1.0 ), shininess );\r\n            lightColor.directSpecular += directionalLight.color * s;\r\n            return lightColor;\r\n        }\r\n        fn getDirectionalDirectLightIncidentLight(directionalLight:DirectionalLight,geometry:Geometry)->IncidentLight {\r\n            var incidentLight:IncidentLight;\r\n            incidentLight.color = directionalLight.color;\r\n            incidentLight.direction = normalize(directionalLight.direction);\r\n            return incidentLight;         \r\n        }\r\n    #endif\r\n\r\n    #if ${defines.openShadow} \r\n        struct LightInfo {\r\n            direction: vec3<f32>,\r\n            viewport: vec4<f32>,\r\n        };\r\n        \r\n        fn linearizeDepth(depth: f32, near: f32, far: f32)->f32 {\r\n            return 2 * (near * far) / (far + near - depth * (far - near));\r\n        }\r\n\r\n        fn getCubeFace(v : vec3<f32>) -> i32{\r\n            let vAbs = abs(v);\r\n        \r\n            if (vAbs.z >= vAbs.x && vAbs.z >= vAbs.y) {\r\n              if (v.z < 0.0) {\r\n                return 3;\r\n              }\r\n              return 2;\r\n            }\r\n        \r\n            if (vAbs.y >= vAbs.x) {\r\n              if (v.y < 0.0) {\r\n                return 5;\r\n              }\r\n              return 4;\r\n            }\r\n        \r\n            if (v.x < 0.0) {\r\n              return 1;\r\n            }\r\n            return 0;\r\n        }\r\n\r\n        fn getShadowValue(shadowMapArray:texture_depth_2d_array, shadowSampler:sampler_comparison, lightPos:vec4<f32>, geometry:Geometry, lightInfo:LightInfo, index:u32, isPointLight: bool, near: f32, far: f32)->f32 {\r\n            var visibility = 0.0;\r\n            var projectPos: vec3<f32> = lightPos.xyz / lightPos.w;\r\n            var shadowPos: vec3<f32> = vec3(projectPos.xy * vec2(0.5, -0.5) + vec2(0.5), projectPos.z);\r\n            var d:f32 = dot(geometry.normal, -lightInfo.direction);\r\n            var bias = max(0.012 * (1.0 - d), 0.001) / lightPos.w;\r\n            let oneOverShadowDepthTextureSize = 1.0 / 1024.0;\r\n            // var depth = select(shadowPos.z, (linearizeDepth(shadowPos.z, near, far) - near) / (far- near), isPerspectiveCamera);\r\n            var depth = shadowPos.z;\r\n\r\n            if (isPointLight) {\r\n                shadowPos.x = shadowPos.x * lightInfo.viewport.z;\r\n                shadowPos.y = shadowPos.y * lightInfo.viewport.w;\r\n                var viewportX = lightInfo.viewport.x * lightInfo.viewport.z;\r\n                var viewportY = lightInfo.viewport.y * lightInfo.viewport.w;\r\n                var uvOffset = 1.5 / 1024.0;\r\n                shadowPos.x = clamp(shadowPos.x + viewportX, viewportX + uvOffset, viewportX + lightInfo.viewport.z - uvOffset);\r\n                shadowPos.y = clamp(shadowPos.y + viewportY, viewportY + uvOffset, viewportY + lightInfo.viewport.w - uvOffset);\r\n            }\r\n\r\n            for (var y = -1; y <= 1; y++) {\r\n                for (var x = -1; x <= 1; x++) {\r\n                    let offset = vec2<f32>(vec2(x, y)) * oneOverShadowDepthTextureSize;\r\n                \r\n                    visibility += textureSampleCompare(\r\n                        shadowMapArray, shadowSampler,\r\n                        shadowPos.xy + offset, index, depth - bias);\r\n                }\r\n            }\r\n            visibility /= 9.0;\r\n            var inFrustum = shadowPos.x >= 0.0 && shadowPos.x <= 1.0 && shadowPos.y >= 0.0 && shadowPos.y <= 1.0;\r\n            if (!inFrustum || depth > 1.0) {\r\n                visibility = 1.0;\r\n            }\r\n            return visibility;\r\n        }\r\n    #endif\r\n\r\n    #if ${\r\n\t\tdefines.ambientLightCount || defines.spotLightsCount || defines.pointLightsCount || defines.dirtectLightsCount\r\n\t}\r\n        struct LightUniforms{\r\n            #if ${defines.ambientLightCount}\r\n                ambient:vec4<f32>,\r\n            #endif\r\n            #if ${defines.spotLightsCount}\r\n                spotLights:array<SpotLight,${defines.spotLightsCount}>,\r\n            #endif\r\n            #if ${defines.pointLightsCount}\r\n                pointLights:array<PointLight,${defines.pointLightsCount}>,\r\n            #endif\r\n            #if ${defines.dirtectLightsCount}\r\n                dirtectLights:array<DirectionalLight,${defines.dirtectLightsCount}>,\r\n            #endif\r\n        }\r\n        @group(2) @binding(${defines.lightBinding}) var<storage, read> lightUniforms: LightUniforms;\r\n\r\n        #if ${defines.openShadow}\r\n            #if ${defines.spotLightShadowMapsCount}\r\n                struct SpotLightShadow {\r\n                    shadowCameraVPMatrix: mat4x4<f32>,\r\n                    shadowCameraNear: f32,\r\n                    shadowCameraFar: f32\r\n                }\r\n            #endif\r\n            #if ${defines.pointLightShadowMapsCount}\r\n                struct PointLightShadow {\r\n                    shadowCameraVPMatrixArray: array<mat4x4<f32>, 6>,\r\n                    shadowCameraViewportArray: array<vec4<f32>, 6>,\r\n                    shadowCameraNear: f32,\r\n                    shadowCameraFar: f32,\r\n                    // shadowCameraVPMatrix: mat4x4<f32>,\r\n                    // shadowCameraVPMatrixArray: array<mat4x4<f32>, 6>,\r\n                    // shadowCameraViewportArray: array<vec4<f32>, 6>,\r\n                }\r\n            #endif\r\n            #if ${defines.directLightShadowMapsCount}\r\n                struct DirectLightShadow {\r\n                    shadowCameraVPMatrix: mat4x4<f32>,\r\n                }\r\n            #endif\r\n            struct ShadowUniforms{\r\n                #if ${defines.spotLightShadowMapsCount}\r\n                    spotLightShadows:array<SpotLightShadow,${defines.spotLightShadowMapsCount}>,\r\n                #endif\r\n                #if ${defines.pointLightShadowMapsCount}\r\n                    pointLightShadows:array<PointLightShadow,${defines.pointLightShadowMapsCount}>,\r\n                #endif\r\n                #if ${defines.directLightShadowMapsCount}\r\n                    directLightShadows:array<DirectLightShadow,${defines.directLightShadowMapsCount}>,\r\n                #endif\r\n            }\r\n            @group(2) @binding(${defines.shadowBinding}) var<storage, read> shadowUniforms: ShadowUniforms;\r\n\r\n            #if ${defines.spotLightShadowMapTextureArrayBinding}\r\n                @group(2) @binding(${\r\n\t\t\t\t\tdefines.spotLightShadowMapTextureArrayBinding\r\n\t\t\t\t}) var spotLightShadowMapTextureArray: texture_depth_2d_array;\r\n            #endif\r\n            #if ${defines.pointLightShadowMapTextureArrayBinding}\r\n                @group(2) @binding(${\r\n\t\t\t\t\tdefines.pointLightShadowMapTextureArrayBinding\r\n\t\t\t\t}) var pointLightShadowMapTextureArray: texture_depth_2d_array;\r\n            #endif\r\n            #if ${defines.directLightShadowMapTextureArrayBinding}\r\n                @group(2) @binding(${\r\n\t\t\t\t\tdefines.directLightShadowMapTextureArrayBinding\r\n\t\t\t\t}) var directLightShadowMapTextureArray: texture_depth_2d_array;\r\n            #endif\r\n            @group(2) @binding(${defines.shadowSamplerBinding}) var shadowSampler: sampler_comparison;\r\n        #endif\r\n\r\n    #endif\r\n    #if ${defines.materialPhong}\r\n        fn parseLights(geometry:Geometry,shininess:f32)->ReflectedLight {\r\n    #elif ${defines.materialPbr}\r\n        fn parseLights(geometry:Geometry,material:PhysicalMaterial)->ReflectedLight{\r\n    #endif\r\n        var reflectedLight:ReflectedLight;\r\n        var shadowValue:f32 = 1.0;\r\n        #if ${defines.ambientLightCount > 0}\r\n            //处理环境光\r\n            var ambientColor:vec3<f32> = lightUniforms.ambient.xyz * lightUniforms.ambient.w;\r\n            reflectedLight.ambient += ambientColor;\r\n        #endif\r\n\r\n        #if ${defines.spotLightsCount > 0}\r\n            //处理聚光灯\r\n            var spotLight:SpotLight;\r\n            for (var k = 0u; k < ${defines.spotLightsCount}; k = k + 1u) {\r\n                spotLight= lightUniforms.spotLights[k];\r\n                #if ${defines.materialPhong && defines.openShadow && defines.spotLightShadowMapsCount}\r\n                    if k < textureNumLayers(spotLightShadowMapTextureArray) {\r\n                        var spotLightShadow:SpotLightShadow = shadowUniforms.spotLightShadows[k];\r\n                        var lightPos: vec4<f32> = spotLightShadow.shadowCameraVPMatrix * vec4<f32>(geometry.position,1.0);\r\n                        var lightInfo:LightInfo;\r\n                        lightInfo.direction = normalize(geometry.position - spotLight.position);\r\n\r\n                        shadowValue = getShadowValue(spotLightShadowMapTextureArray, shadowSampler, lightPos, geometry, lightInfo, k, false,\r\n                            spotLightShadow.shadowCameraNear, spotLightShadow.shadowCameraFar);\r\n                    }\r\n                    spotLight.color *= shadowValue;\r\n                #endif\r\n                #if ${defines.materialPhong}\r\n                    let spReflectedLight=getSpotLightInfo(spotLight,geometry.position,shininess,geometry.normal,geometry.viewDir);\r\n                #elif ${defines.materialPbr}\r\n                    let incidentLight=getSpotLightIncidentLight(spotLight,geometry);\r\n                    let spReflectedLight=direct_Physical(incidentLight, geometry, material);\r\n                #endif\r\n\r\n                reflectedLight.directDiffuse+=spReflectedLight.directDiffuse;\r\n                reflectedLight.directSpecular+=spReflectedLight.directSpecular;\r\n            }\r\n        #endif\r\n        #if ${defines.pointLightsCount > 0}\r\n            //处理点光源\r\n            var pointLight:PointLight;\r\n            for (var j = 0u; j < ${defines.pointLightsCount};j = j + 1u) {\r\n                pointLight = lightUniforms.pointLights[j];\r\n                #if ${defines.materialPhong && defines.openShadow && defines.pointLightShadowMapsCount}\r\n                    if j < textureNumLayers(pointLightShadowMapTextureArray) {\r\n                        var pointLightShadow:PointLightShadow = shadowUniforms.pointLightShadows[j];\r\n                        var lightInfo:LightInfo;\r\n                        lightInfo.direction = normalize(geometry.position - pointLight.position);\r\n                        var cubeFace = getCubeFace(lightInfo.direction);\r\n                        var lightPos: vec4<f32> = pointLightShadow.shadowCameraVPMatrixArray[cubeFace] * vec4<f32>(geometry.position,1.0);\r\n                        lightInfo.viewport = pointLightShadow.shadowCameraViewportArray[cubeFace];\r\n\r\n                        // var lightPos: vec4<f32> = pointLightShadow.shadowCameraVPMatrix * vec4<f32>(geometry.position,1.0);\r\n\r\n                        shadowValue = getShadowValue(pointLightShadowMapTextureArray, shadowSampler, lightPos, geometry, lightInfo, j, true,\r\n                            pointLightShadow.shadowCameraNear, pointLightShadow.shadowCameraFar);\r\n                        \r\n                        // reflectedLight.testColor = vec3(pointLightShadow.shadowCameraFar / 1000, \r\n                        //     pointLightShadow.shadowCameraVPMatrixArray[5][3][2] / 255, pointLightShadow.shadowCameraVPMatrixArray[5][3][3] / 255);\r\n                        // reflectedLight.testColor = vec3(pointLightShadow.shadowCameraNear, pointLightShadow.shadowCameraNear, pointLightShadow.shadowCameraNear);\r\n                    }\r\n                    pointLight.color *= shadowValue;\r\n                #endif\r\n                #if ${defines.materialPhong}\r\n                    let poiReflectedLight=getPointLightInfo(pointLight,geometry.position,shininess,geometry.normal,geometry.viewDir);\r\n                #elif ${defines.materialPbr}\r\n                   let incidentLight=getPointLightIncidentLight(pointLight,geometry);\r\n                   let poiReflectedLight=direct_Physical(incidentLight, geometry, material);\r\n                #endif\r\n\r\n                reflectedLight.directDiffuse+=poiReflectedLight.directDiffuse;\r\n                reflectedLight.directSpecular+=poiReflectedLight.directSpecular;\r\n            }\r\n        #endif\r\n        #if ${defines.dirtectLightsCount > 0}\r\n            //处理方向光\r\n            var directionalLight:DirectionalLight;\r\n            for (var i= 0u; i <${defines.dirtectLightsCount}; i = i + 1u) {\r\n                directionalLight = lightUniforms.dirtectLights[i];\r\n                #if ${defines.materialPhong && defines.openShadow && defines.directLightShadowMapsCount}\r\n                    if i < textureNumLayers(directLightShadowMapTextureArray) {\r\n                        var directLightShadow:DirectLightShadow = shadowUniforms.directLightShadows[i];\r\n                        var lightPos: vec4<f32> = directLightShadow.shadowCameraVPMatrix * vec4<f32>(geometry.position,1.0);\r\n                        var lightInfo:LightInfo;\r\n                        lightInfo.direction = directionalLight.direction;\r\n                            \r\n                        shadowValue = getShadowValue(directLightShadowMapTextureArray, shadowSampler, lightPos, geometry, lightInfo, i, false, 0, 0);\r\n                    }\r\n                    directionalLight.color *= shadowValue;\r\n                #endif\r\n            \r\n                #if ${defines.materialPhong}\r\n                    let dirReflectedLight=getDirectLightInfo(directionalLight,shininess,geometry.normal,geometry.viewDir);\r\n                #elif ${defines.materialPbr}\r\n                    let incidentLight=getDirectionalDirectLightIncidentLight(directionalLight,geometry);\r\n                    let dirReflectedLight=direct_Physical(incidentLight, geometry, material);\r\n                #endif\r\n\r\n                reflectedLight.directDiffuse+=dirReflectedLight.directDiffuse;\r\n                reflectedLight.directSpecular+=dirReflectedLight.directSpecular;\r\n            }\r\n        #endif\r\n        return reflectedLight;\r\n    }`;\r\n}\r\n","import { wgslParseDefines } from \"../../WgslPreprocessor\";\r\nexport default function lightCommon(defines) {\r\n\treturn wgslParseDefines`\r\n    struct ReflectedLight {\r\n        directDiffuse:vec3<f32>,\r\n        directSpecular:vec3<f32>,\r\n        indirectDiffuse:vec3<f32>,\r\n        indirectSpecular:vec3<f32>,\r\n    };\r\n    struct Geometry {\r\n        position: vec3<f32>,\r\n        normal: vec3<f32>,\r\n        viewDir: vec3<f32>,\r\n        #if ${defines.USE_CLEARCOAT}\r\n            vec3 clearcoatNormal;\r\n        #endif\r\n    };\r\n    fn getAmbientLightIrradiance(ambientLightColor: vec3<f32>) -> vec3<f32> {\r\n        let irradiance = ambientLightColor;\r\n        return irradiance;\r\n    }\r\n    fn getDistanceAttenuation(lightDistance: f32, cutoffDistance: f32, decayExponent: f32) -> f32 {\r\n        if (cutoffDistance > 0.0 && decayExponent > 0.0) {\r\n            let x:f32 = saturate(- lightDistance / cutoffDistance + 1.0);\r\n            return pow(x, decayExponent);\r\n        }\r\n        return 1.0;\r\n    }\r\n    fn getSpotAttenuation(coneCosine: f32, penumbraCosine: f32, angleCosine: f32) -> f32 {\r\n        return smoothstep(coneCosine, penumbraCosine, angleCosine);\r\n    }\r\n    fn shGetIrradianceAt( normal:vec3<f32>, shCoefficients:array<vec3<f32>,9>)->vec3<f32> {\r\n        let x:f32 = normal.x; \r\n        let y:f32 = normal.y; \r\n        let z:f32 = normal.z;\r\n        var result:vec3<f32> = shCoefficients[ 0 ] * 0.886227;\r\n        result += shCoefficients[ 1 ] * 2.0 * 0.511664 * y;\r\n        result += shCoefficients[ 2 ] * 2.0 * 0.511664 * z;\r\n        result += shCoefficients[ 3 ] * 2.0 * 0.511664 * x;\r\n        result += shCoefficients[ 4 ] * 2.0 * 0.429043 * x * y;\r\n        result += shCoefficients[ 5 ] * 2.0 * 0.429043 * y * z;\r\n        result += shCoefficients[ 6 ] * ( 0.743125 * z * z - 0.247708 );\r\n        result += shCoefficients[ 7 ] * 2.0 * 0.429043 * x * z;\r\n        result += shCoefficients[ 8 ] * 0.429043 * ( x * x - y * y );\r\n        return result;\r\n    }\r\n    fn inverseTransformDirection( dir:vec3<f32>, matrix:mat4x4<f32> )->vec3<f32> {\r\n        return normalize( ( vec4<f32>( dir, 0.0 ) * matrix ).xyz );\r\n    }\r\n `;\r\n}\r\n","import { wgslParseDefines } from \"../../WgslPreprocessor\";\nexport function getNormal(defines) {\n\treturn wgslParseDefines`\n      fn getNormal(input:FragInput)->vec3<f32>{\n        var normal:vec3<f32>;\n        #if ${defines.HAS_NORMAL}\n            normal= input.normal;\n        #else\n          let pos_dx = dpdx(input.worldPos);\n          let pos_dy = dpdy(input.worldPos);\n          normal = normalize( cross(pos_dy, pos_dx) );\n        #endif\n        return normal*(f32(input.frontFacing) * 2.0 - 1.0);\n      }\n    `;\n}\nexport function getNormalByNormalTexture(defines) {\n\treturn wgslParseDefines`\n      fn getNormalByNormalTexture(input:FragInput)->vec3<f32>{\n        var n:vec3<f32> = textureSample(normalTexture,normalSampler, input.uv).rgb;\n        let tbn:mat3x3<f32> =getTBN(input);\n        n = normalize(tbn * (2.0 * n - vec3(1.0)));\n        n=n*(f32(input.frontFacing) * 2.0 - 1.0);\n        return n;\n      }\n    `;\n}\nexport function getTBN(defines) {\n\treturn wgslParseDefines`\n        fn getTBN(input:FragInput)->mat3x3<f32>{\n        #if ${defines.HAS_TANGENT}\n            let tbn:mat3x3<f32> = input.tbn;\n        #else\n            let normal:vec3<f32> =normalize(input.normal);\n            let uv:vec2<f32> = select(-input.uv,input.uv,input.frontFacing);\n              // ref: http://www.thetenthplanet.de/archives/1180\n              // get edge vectors of the pixel triangle\n              let dp1:vec3<f32> =  vec3<f32>(dpdx(input.worldPos.x), dpdx(input.worldPos.y), dpdx(input.worldPos.z));\n              let dp2:vec3<f32> =  vec3<f32>(dpdy(input.worldPos.x), dpdy(input.worldPos.y), dpdy(input.worldPos.z));\n              let duv1:vec2<f32> = dpdx(uv);\n              let duv2:vec2<f32> = dpdy(uv);\n\n              // solve the linear system\n              let dp2perp:vec3<f32> = cross(dp2, normal);\n              let dp1perp:vec3<f32> = cross(normal, dp1);\n              let tangent:vec3<f32> = dp2perp * duv1.x + dp1perp * duv2.x;\n              let binormal:vec3<f32> = dp2perp * duv1.y + dp1perp * duv2.y;\n              // construct a scale-invariant frame \n              let result:f32=max(dot(tangent, tangent), dot(binormal, binormal));\n              let invmax:f32 = 1.0/sqrt(result);\n              let tbn:mat3x3<f32> = mat3x3<f32>(tangent * invmax, binormal * invmax, normal);\n        #endif\n        return tbn;\n      }\n  `;\n}\n","import { wgslParseDefines } from \"../../WgslPreprocessor\";\r\nexport default function brdf(defines) {\r\n\treturn wgslParseDefines`\r\n        #if ${defines.USE_SHEEN}\r\n                fn D_Charlie( roughness:f32,dotNH:f32 )->f32 {\r\n                    let alpha:f32 = pow2( roughness );\r\n                    let invAlpha:f32 = 1.0 / alpha;\r\n                    let cos2h:f32 = dotNH * dotNH;\r\n                    let sin2h:f32 = max( 1.0 - cos2h, 0.0078125 );\r\n                    return ( 2.0 + invAlpha ) * pow( sin2h, invAlpha * 0.5 ) / ( 2.0 * PI );\r\n                }\r\n                fn V_Neubelt( dotNV:f32, dotNL:f32 )->f32 {\r\n                    return saturate( 1.0 / ( 4.0 * ( dotNL + dotNV - dotNL * dotNV ) ) );\r\n                }\r\n                fn BRDF_Sheen(lightDir:vec3<f32>, viewDir:vec3<f32>, normal:vec3<f32>,sheenColor:vec3<f32>,sheenRoughness:f32 )->vec3<f32> {\r\n                    let halfDir:vec3<f32> = normalize( lightDir + viewDir );\r\n                    let dotNL:f32 = saturate( dot( normal, lightDir ) );\r\n                    let dotNV:f32 = saturate( dot( normal, viewDir ) );\r\n                    let dotNH:f32 = saturate( dot( normal, halfDir ) );\r\n                    let D:f32 = D_Charlie( sheenRoughness, dotNH );\r\n                    let V:f32 = V_Neubelt( dotNV, dotNL );\r\n                    return sheenColor * ( D * V );\r\n                }\r\n        #endif\r\n        fn BRDF_Lambert(diffuseColor:vec3<f32>)->vec3<f32> {\r\n\r\n            return RECIPROCAL_PI * diffuseColor;\r\n\r\n        } // validated\r\n\r\n        fn F_Schlick( f0:vec3<f32>, dotVH:f32 )->vec3<f32> {\r\n\r\n            // Original approximation by Christophe Schlick '94\r\n            // float fresnel = pow( 1.0 - dotVH, 5.0 );\r\n\r\n            // Optimized variant (presented by Epic at SIGGRAPH '13)\r\n            // https://cdn2.unrealengine.com/Resources/files/2013SiggraphPresentationsNotes-26915738.pdf\r\n           let fresnel = exp2( ( - 5.55473 * dotVH - 6.98316 ) * dotVH );\r\n           return ( 1.0 - f0 ) * fresnel + f0;\r\n\r\n        } // validated\r\n\r\n        fn Schlick_to_F0(f:vec3<f32>, f90:f32, dotVH:f32 )->vec3<f32> {\r\n            let x:f32 = clamp( 1.0 - dotVH, 0.0, 1.0 );\r\n            let x2:f32 = x * x;\r\n            let x5:f32 = clamp( x * x2 * x2, 0.0, 0.9999 );\r\n\r\n            return ( f - vec3( f90 ) * x5 ) / ( 1.0 - x5 );\r\n        }\r\n        fn V_GGX_SmithCorrelated( alpha:f32, dotNL:f32,dotNV:f32 )->f32 {\r\n\r\n            let a2 :f32= pow2( alpha );\r\n\r\n            let gv:f32 = dotNL * sqrt( a2 + ( 1.0 - a2 ) * pow2( dotNV ) );\r\n            let gl:f32 = dotNV * sqrt( a2 + ( 1.0 - a2 ) * pow2( dotNL ) );\r\n\r\n            return 0.5 / max((gv + gl), 0.000000001 );\r\n\r\n        }\r\n        fn D_GGX( alpha:f32, dotNH:f32 )->f32 {\r\n\r\n            let a2:f32 = pow2( alpha );\r\n\r\n            let denom:f32 = pow2( dotNH ) * ( a2 - 1.0 ) + 1.0; // avoid alpha = 0 with dotNH = 1\r\n\r\n            return RECIPROCAL_PI * a2 / pow2( denom );\r\n\r\n        }\r\n        fn BRDF_GGX( lightDir:vec3<f32>, viewDir:vec3<f32>, normal:vec3<f32>, f0:vec3<f32>,  roughness:f32 )->vec3<f32> {\r\n\r\n            let alpha:f32 = pow2( roughness ); // UE4's roughness\r\n\r\n            let halfDir = normalize( lightDir + viewDir );\r\n\r\n            let dotNL:f32 = saturate( dot( normal, lightDir ) );\r\n            let dotNV:f32 = saturate( dot( normal, viewDir ) );\r\n            let dotNH:f32 = saturate( dot( normal, halfDir ) );\r\n            let dotVH:f32 = saturate( dot( lightDir, halfDir ) );\r\n\r\n            let F = F_Schlick( f0,  dotVH );\r\n\r\n            let V = V_GGX_SmithCorrelated( alpha, dotNL, dotNV );\r\n\r\n            let D = D_GGX( alpha, dotNH );\r\n\r\n            return F * ( V * D );\r\n\r\n        }\r\n        fn direct_Physical( directLight:IncidentLight, geometry:Geometry,material:PhysicalMaterial)->ReflectedLight {\r\n            var reflectedLight:ReflectedLight;\r\n            let dotNL:f32 = saturate(dot( geometry.normal,geometry.viewDir));\r\n            let irradiance:vec3<f32> = dotNL * directLight.color*3.1415926;\r\n            reflectedLight.directSpecular = irradiance * BRDF_GGX( directLight.direction, geometry.viewDir, geometry.normal, material.specularColor, material.roughness );\r\n            reflectedLight.directDiffuse = irradiance * BRDF_Lambert( material.diffuseColor );\r\n            return reflectedLight;\r\n        }\r\n  `;\r\n}\r\n","import { wgslParseDefines } from \"../../WgslPreprocessor\";\r\nexport default function ibl(defines) {\r\n\treturn wgslParseDefines`\r\n  fn getLightProbeRadiance( viewDir:vec3<f32>,normal:vec3<f32>, roughness:f32 )->vec3<f32>{\r\n    var reflectVec:vec3<f32> = reflect( -viewDir, normal );\r\n    reflectVec.x = -reflectVec.x; // TextureCube is left-hand,so x need inverse\r\n    let mipCount:f32 = 10.0; // resolution of 256x256\r\n    let lod:f32 = roughness * mipCount;\r\n    let specularLight:vec3<f32> = textureSampleLevel(specularEnvTexture,specularEnvSampler, reflectVec, lod).rgb;\r\n    return specularLight;\r\n  }\r\n  fn getLightProbeIrradiance( lightProbe:array<vec3<f32>,9>, normal:vec3<f32>)->vec3<f32> {\r\n    var worldNormal:vec3<f32> = normal;\r\n    worldNormal.x = -normal.x;\r\n    var irradiance:vec3<f32> = lightProbe[0];\r\n    irradiance+=lightProbe[1] * (normal.y);\r\n    irradiance+=lightProbe[2] * (normal.z) ;\r\n    irradiance+=lightProbe[3] * (normal.x) ;\r\n\r\n    irradiance+=lightProbe[4] * (normal.y * normal.x) ;\r\n    irradiance+=lightProbe[5] * (normal.y * normal.z) ;\r\n    irradiance+=lightProbe[6] * (3.0 * normal.z * normal.z - 1.0);\r\n    irradiance+=lightProbe[7] * (normal.z * normal.x) ;\r\n    irradiance+=lightProbe[8] * (normal.x * normal.x - normal.y * normal.y);\r\n\r\n    return max(irradiance, vec3<f32>(0.0,0.0,0.0));\r\n  }\r\n  fn DFGApprox( specularColor:vec3<f32>, roughness:f32,dotNV:f32 )->vec3<f32> {\r\n    const c0:vec4<f32> = vec4<f32>( - 1, - 0.0275, - 0.572, 0.022 );\r\n    let c1:vec4<f32> = vec4<f32>( 1, 0.0425, 1.04, - 0.04 );\r\n    let r:vec4<f32> = roughness * c0 + c1;\r\n    let a004:f32 = min( r.x * r.x, exp2( - 9.28 * dotNV ) ) * r.x + r.y;\r\n    let fab:vec2<f32> = vec2<f32>( - 1.04, 1.04 ) * a004 + r.zw;\r\n    return specularColor * fab.x + fab.y;\r\n  }\r\n  //间接光照\r\n  fn indirectDiffuse_Physical(geometry:Geometry, material:PhysicalMaterial )->ReflectedLight {\r\n      var reflectedLight:ReflectedLight;\r\n      var irradiance:vec3<f32> = lightUniforms.ambient.xyz*lightUniforms.ambient.w;\r\n      irradiance *= PI;\r\n      reflectedLight.indirectDiffuse += irradiance * BRDF_Lambert( material.diffuseColor );\r\n      return reflectedLight;\r\n  }\r\n  //间接高光\r\n  fn indirectSpecular_Physical(geometry:Geometry, material:PhysicalMaterial)->ReflectedLight {\r\n      var reflectedLight:ReflectedLight;\r\n      // IBL specular\r\n      let radiance:vec3<f32> = getLightProbeRadiance(geometry.viewDir, geometry.normal, material.roughness);\r\n      let radianceAttenuation:f32 = 1.0;\r\n      reflectedLight.indirectSpecular += radianceAttenuation * radiance * DFGApprox(material.specularColor, material.roughness, geometry.dotNV );\r\n      return reflectedLight;\r\n    }\r\n  `;\r\n}\r\n","import { wgslParseDefines } from \"../../WgslPreprocessor\";\r\n\r\nexport default function pbrFunction(defines) {\r\n\treturn wgslParseDefines`\r\n\r\n    #if ${defines.DITHERING}\r\n        fn dithering(color:vec3<f32> )->vec3<f32> {\r\n            let grid_position:f32 = rand( gl_FragCoord.xy );\r\n            let dither_shift_RGB:vec3<f32> = vec3<f32>( 0.25 / 255.0, -0.25 / 255.0, 0.25 / 255.0 );\r\n            dither_shift_RGB = mix( 2.0 * dither_shift_RGB, -2.0 * dither_shift_RGB, grid_position );\r\n            return color + dither_shift_RGB;\r\n        }\r\n    #endif\r\n\r\n    #if ${defines.USE_IRIDESCENCE}\r\n        fn BRDF_GGX_Iridescence( lightDir:vec3<f32>, viewDir:vec3<f32>,normal:vec3<f32>, f0:vec3<f32>, f90:f32,iridescence:f32, iridescenceFresnel:vec3<f32>,roughness:f32 )->vec3<f32> {\r\n            let alpha:f32 = pow2( roughness );\r\n            let halfDir:vec3<f32> = normalize( lightDir + viewDir );\r\n            let dotNL:f32 = saturate( dot( normal, lightDir ) );\r\n            let dotNV:f32 = saturate( dot( normal, viewDir ) );\r\n            let dotNH:f32 = saturate( dot( normal, halfDir ) );\r\n            let dotVH:f32 = saturate( dot( viewDir, halfDir ) );\r\n            let F:vec3<f32> = mix( F_Schlick( f0, f90, dotVH ), iridescenceFresnel, iridescence );\r\n            let V:f32 = V_GGX_SmithCorrelated( alpha, dotNL, dotNV );\r\n            let D:f32 = D_GGX( alpha, dotNH );\r\n            return F * ( V * D );\r\n        }\r\n    #endif\r\n\r\n    #if ${defines.USE_SHEEN}\r\n        fn D_Charlie( roughness:f32,dotNH:f32 )->f32 {\r\n            let alpha:f32 = pow2( roughness );\r\n            let invAlpha:f32 = 1.0 / alpha;\r\n            let cos2h:f32 = dotNH * dotNH;\r\n            let sin2h:f32 = max( 1.0 - cos2h, 0.0078125 );\r\n            return ( 2.0 + invAlpha ) * pow( sin2h, invAlpha * 0.5 ) / ( 2.0 * PI );\r\n        }\r\n        fn V_Neubelt( dotNV:f32, dotNL:f32 )->f32 {\r\n            return saturate( 1.0 / ( 4.0 * ( dotNL + dotNV - dotNL * dotNV ) ) );\r\n        }\r\n        fn BRDF_Sheen(lightDir:vec3<f32>, viewDir:vec3<f32>, normal:vec3<f32>,sheenColor:vec3<f32>,sheenRoughness:f32 )->vec3<f32> {\r\n            let halfDir:vec3<f32> = normalize( lightDir + viewDir );\r\n            let dotNL:f32 = saturate( dot( normal, lightDir ) );\r\n            let dotNV:f32 = saturate( dot( normal, viewDir ) );\r\n            let dotNH:f32 = saturate( dot( normal, halfDir ) );\r\n            let D:f32 = D_Charlie( sheenRoughness, dotNH );\r\n            let V:f32 = V_Neubelt( dotNV, dotNL );\r\n            return sheenColor * ( D * V );\r\n        }\r\n    #endif\r\n\r\n    #if ${defines.USE_IRIDESCENCE}\r\n        let XYZ_TO_REC709: mat3x3<f32> = mat3x3<f32>(\r\n        3.2404542, -0.9692660, 0.0556434, -1.5371385, 1.8760108, -0.2040259, -0.4985314, 0.0415560, 1.0572252\r\n        );\r\n        fn Fresnel0ToIor( fresnel0:vec3<f32> )->vec3<f32> {\r\n            let sqrtF0:vec3<f32> = sqrt( fresnel0 );\r\n            return ( vec3<f32>( 1.0 ) + sqrtF0 ) / ( vec3<f32>( 1.0 ) - sqrtF0 );\r\n        }\r\n        fn IorToFresnel0(transmittedIor:vec3<f32>,incidentIor:f32 )->vec3<f32> {\r\n            return pow2Vector( ( transmittedIor - vec3<f32>( incidentIor ) ) / ( transmittedIor + vec3<f32>( incidentIor ) ) );\r\n        }\r\n        fn IorToFresnel0(transmittedIor:f32, incidentIor:f32 )->f32 {\r\n            return pow2Vector( ( transmittedIor - incidentIor ) / ( transmittedIor + incidentIor ));\r\n        }\r\n        fn evalSensitivity(OPD:f32,shift:vec3<f32> )->vec3<f32> {\r\n            let phase:f32 = 2.0 * PI * OPD * 1.0e-9;\r\n            let val:vec3<f32> = vec3<f32>( 5.4856e-13, 4.4201e-13, 5.2481e-13 );\r\n            let pos:vec3<f32> = vec3<f32>( 1.6810e+06, 1.7953e+06, 2.2084e+06 );\r\n            let vart:vec3<f32> = vec3<f32>( 4.3278e+09, 9.3046e+09, 6.6121e+09 );\r\n            let xyz:vec3<f32> = val * sqrt( 2.0 * PI * vart ) * cos( pos * phase + shift ) * exp( - pow2( phase ) * vart );\r\n            xyz.x += 9.7470e-14 * sqrt( 2.0 * PI * 4.5282e+09 ) * cos( 2.2399e+06 * phase + shift[ 0 ] ) * exp( - 4.5282e+09 * pow2( phase ) );\r\n            xyz /= 1.0685e-7;\r\n            let rgb:vec3<f32> = XYZ_TO_REC709 * xyz;\r\n            return rgb;\r\n        }\r\n        fn evalIridescence(outsideIOR:f32, eta2:f32,cosTheta1:f32,thinFilmThickness:f32,baseF0:vec3<f32> )->vec3<f32> {\r\n            var I:vec3<f32>;\r\n            let iridescenceIOR:f32 = mix( outsideIOR, eta2, smoothstep( 0.0, 0.03, thinFilmThickness ) );\r\n            let sinTheta2Sq:f32 = pow2( outsideIOR / iridescenceIOR ) * ( 1.0 - pow2( cosTheta1 ) );\r\n            let cosTheta2Sq:f32 = 1.0 - sinTheta2Sq;\r\n            if ( cosTheta2Sq < 0.0 ) {\r\n                return vec3<f32>( 1.0 );\r\n            }\r\n            let cosTheta2:f32 = sqrt( cosTheta2Sq );\r\n            let R0:f32 = IorToFresnel0( iridescenceIOR, outsideIOR );\r\n            let R12:f32 = F_Schlick( R0, 1.0, cosTheta1 );\r\n            let R21:f32 = R12;\r\n            let T121:f32 = 1.0 - R12;\r\n            let phi12:f32 = 0.0;\r\n            if ( iridescenceIOR < outsideIOR ) phi12 = PI;\r\n            let phi21:f32 = PI - phi12;\r\n            let baseIOR:vec3<f32> = Fresnel0ToIor( clamp( baseF0, 0.0, 0.9999 ) );\r\n            let R1:vec3<f32> = IorToFresnel0( baseIOR, iridescenceIOR );\r\n            let R23:vec3<f32> = F_Schlick( R1, 1.0, cosTheta2 );\r\n            let phi23:vec3<f32> = vec3<f32>( 0.0 );\r\n            if ( baseIOR[ 0 ] < iridescenceIOR ) phi23[ 0 ] = PI;\r\n            if ( baseIOR[ 1 ] < iridescenceIOR ) phi23[ 1 ] = PI;\r\n            if ( baseIOR[ 2 ] < iridescenceIOR ) phi23[ 2 ] = PI;\r\n            let OPD:f32 = 2.0 * iridescenceIOR * thinFilmThickness * cosTheta2;\r\n            let phi:vec3<f32> = vec3<f32>( phi21 ) + phi23;\r\n            let R123:vec3<f32> = clamp( R12 * R23, 1e-5, 0.9999 );\r\n            let r123:vec3<f32> = sqrt( R123 );\r\n            let Rs:vec3<f32> = pow2( T121 ) * R23 / ( vec3<f32>( 1.0 ) - R123 );\r\n            let C0:vec3<f32> = R12 + Rs;\r\n            I = C0;\r\n            let Cm:vec3<f32> = Rs - T121;\r\n            for ( let m : u32 = 1;m <= 2; ++ m ) {\r\n                Cm *= r123;\r\n                Sm:vec3<f32> = 2.0 * evalSensitivity( f32( m ) * OPD, f32( m ) * phi );\r\n                I += Cm * Sm;\r\n            }\r\n            return max( I, vec3<f32>( 0.0 ) );\r\n        }\r\n    #endif\r\n    const clearcoatSpecular:vec3<f32> = vec3<f32>( 0.0 );\r\n    const sheenSpecular:vec3<f32> = vec3<f32>( 0.0 );\r\n\r\n    fn IBLSheenBRDF( normal:vec3<f32>, viewDir:vec3<f32>, roughness:f32 )->f32 {\r\n        let dotNV:f32 = saturate( dot( normal, viewDir ) );\r\n        let r2:f32 = roughness * roughness;\r\n        let a:f32 =select(-8.48 * r2 + 14.3 * roughness - 9.95,-339.2 * r2 + 161.4 * roughness - 25.9,roughness < 0.25);\r\n        //let a:f32 = roughness < 0.25 ? -339.2 * r2 + 161.4 * roughness - 25.9 : -8.48 * r2 + 14.3 * roughness - 9.95;\r\n        let b:f32=select(1.97 * r2 - 3.27 * roughness + 0.72,44.0 * r2 - 23.7 * roughness + 3.26, roughness < 0.25);\r\n        //let b:f32 = roughness < 0.25 ? 44.0 * r2 - 23.7 * roughness + 3.26 : 1.97 * r2 - 3.27 * roughness + 0.72;\r\n        //let DG:f32 = exp( a * dotNV + b ) + ( roughness < 0.25 ? 0.0 : 0.1 * ( roughness - 0.25 ) );\r\n        let DG:f32 = exp( a * dotNV + b ) + select(0.1 * ( roughness - 0.25 ),0.0,roughness < 0.25);\r\n        return saturate( DG * RECIPROCAL_PI );\r\n    }\r\n    fn DFGApprox( specularColor:vec3<f32>, roughness:f32,dotNV:f32 )->vec3<f32> {\r\n        const c0:vec4<f32> = vec4<f32>( - 1, - 0.0275, - 0.572, 0.022 );\r\n        let c1:vec4<f32> = vec4<f32>( 1, 0.0425, 1.04, - 0.04 );\r\n        let r:vec4<f32> = roughness * c0 + c1;\r\n        let a004:f32 = min( r.x * r.x, exp2( - 9.28 * dotNV ) ) * r.x + r.y;\r\n        let fab:vec2<f32> = vec2<f32>( - 1.04, 1.04 ) * a004 + r.zw;\r\n        return specularColor * fab.x + fab.y;\r\n    }\r\n    fn EnvironmentBRDF( normal:vec3<f32>,viewDir:vec3<f32>,specularColor:vec3<f32>, specularF90:f32,roughness:f32 )->vec3<f32> {\r\n        let fab:vec2<f32> = DFGApprox( normal, viewDir, roughness );\r\n        return specularColor * fab.x + specularF90 * fab.y;\r\n    }\r\n\r\n\r\n    fn computeSpecularOcclusion( dotNV:f32, ambientOcclusion:f32, roughness:f32 )->f32 {\r\n        return saturate( pow( dotNV + ambientOcclusion, exp2( - 16.0 * roughness - 1.0 ) ) - 1.0 + ambientOcclusion );\r\n    }\r\n    #if ${defines.USE_TRANSMISSION}\r\n\r\n    fn getVolumeTransmissionRay( n:vec3<f32>, v:vec3<f32>, thickness:f32, ior:f32, modelMatrix:mat4x4:f32)->vec3<f32> {\r\n        var refractionVector:vec3<f32> = refract( - v, normalize( n ), 1.0 / ior );\r\n        var modelScale:vec3<f32>;\r\n        modelScale.x = length( vec3<f32>( modelMatrix[0].xyz ) );\r\n        modelScale.y = length( vec3<f32>( modelMatrix[1].xyz ) );\r\n        modelScale.z = length( vec3<f32>( modelMatrix[2].xyz ) );\r\n        return normalize( refractionVector ) * thickness * modelScale;\r\n    }\r\n    fn applyIorToRoughness(roughness:f32, ior:f32 )->f32 {\r\n        return roughness * clamp( ior * 2.0 - 2.0, 0.0, 1.0 );\r\n    }\r\n    fn getTransmissionSample( fragCoord:vec2<f32>, roughness:f32,ior:f32 )->vec4<f32> {\r\n        let framebufferLod:f32 = log2( materialUniform.transmissionSamplerSize.x ) * applyIorToRoughness( roughness, ior );\r\n        return textureSampleLevel(transmissionSamplerTexture,baseSampler,fragCoord.xy, framebufferLod);\r\n\r\n    }\r\n    fn applyVolumeAttenuation( radiance:vec3<vec3>, transmissionDistance:f32,attenuationColor:vec3<f32>,attenuationDistance:f32 )->vec3<f32> {\r\n        if ( isinf( attenuationDistance ) ) {\r\n            return radiance;\r\n        }\r\n        else {\r\n            let attenuationCoefficient:vec3<f32> = -log( attenuationColor ) / attenuationDistance;\r\n            let transmittance:vec3<f32> = exp( - attenuationCoefficient * transmissionDistance );\r\n            return transmittance * radiance;\r\n        }\r\n    \r\n    }\r\n    fn getIBLVolumeRefraction( n:vec3<f32>,v:vec3<f32>, roughness:f32, diffuseColor:vec3<f32>,specularColor:vec3<f32>, specularF90:f32,position:vec3<f32>, modelMatrix:mat4x4<f32>, viewMatrix:mat4x4<f32>,projMatrix:mat4x4<f32>,ior:f32, thickness:f32,attenuationColor:vec3<f32>,attenuationDistance:f32 )->vec4<f32> {\r\n        let transmissionRay:vec3<f32> = getVolumeTransmissionRay( n, v, thickness, ior, modelMatrix );\r\n        let refractedRayExit:vec3<f32> = position + transmissionRay;\r\n        let ndcPos:vec4<f32> = projMatrix * viewMatrix * vec4( refractedRayExit, 1.0 );\r\n        let refractionCoords:vec2<f32> = ndcPos.xy / ndcPos.w;\r\n        refractionCoords += 1.0;\r\n        refractionCoords /= 2.0;\r\n        let transmittedLight:vec4<f32> = getTransmissionSample( refractionCoords, roughness, ior );\r\n        let attenuatedColor:vec3<f32> = applyVolumeAttenuation( transmittedLight.rgb, length( transmissionRay ), attenuationColor, attenuationDistance );\r\n        let F:vec3<f32> = EnvironmentBRDF( n, v, specularColor, specularF90, roughness );\r\n        return vec4<f32>( ( 1.0 - F ) * attenuatedColor * diffuseColor, transmittedLight.a );\r\n    }\r\n    #endif\r\n\r\n    #if ${defines.USE_BUMPTEXTURE}\r\n        fn dHdxy_fwd()->vec2<f32> {\r\n            let dSTdx:vec2<f32> = dpdx( vUv );\r\n            let dSTdy:vec2<f32> = dpdy( vUv );\r\n\r\n            let Hll:f32 = materialUniform.bumpScale * textureSample(bumpTexture, baseSampler, vUv).x;\r\n            let dBx:f32 = materialUniform.bumpScale * textureSample(bumpTexture, baseSampler, vUv + dSTdx).x - Hll;\r\n            let dBy:f32 = materialUniform.bumpScale * textureSample(bumpTexture, baseSampler, vUv + dSTdy).x - Hll;\r\n            return vec2<f32>( dBx, dBy );\r\n        }\r\n        fn perturbNormalArb( surf_pos:vec3<f32>, surf_norm:vec3<f32>, dHdxy:vec2<f32>, faceDirection:f32 )->vec3<f32> {\r\n            let vSigmaX:vec3<f32> = dpdx( surf_pos.xyz );\r\n            let vSigmaY:vec3<f32> = dpdy( surf_pos.xyz );\r\n            let vN:vec3<f32> = surf_norm;\r\n            let R1:vec3<f32> = cross( vSigmaY, vN );\r\n            let R2:vec3<f32> = cross( vN, vSigmaX );\r\n            let fDet:f32 = dot( vSigmaX, R1 ) * faceDirection;\r\n            let vGrad:vec3<f32> = sign( fDet ) * ( dHdxy.x * R1 + dHdxy.y * R2 );\r\n            return normalize( abs( fDet ) * surf_norm - vGrad );\r\n        }\r\n    #endif\r\n\r\n    //! defined ( USE_TANGENT ) && ( defined ( TANGENTSPACE_NORMALTEXTURE ) || defined ( USE_CLEARCOAT_NORMALTEXTURE ) )\r\n    #if ${(!defines.USE_TANGENT && defines.TANGENTSPACE_NORMALTEXTURE) || defines.USE_CLEARCOAT_NORMALTEXTURE}\r\n    fn perturbNormal2Arb( eye_pos:vec3<f32>, surf_norm:vec3<f32>, textureN:vec3<f32>, faceDirection:f32 )->vec3<f32> {\r\n        let q0:vec3<f32> = dpdx( eye_pos.xyz );\r\n        let q1:vec3<f32> = dpdy( eye_pos.xyz );\r\n        let st0:vec2<f32> = dpdx( vUv.st );\r\n        let st1:vec2<f32> = dpdy( vUv.st );\r\n        let N:vec3<f32> = surf_norm;\r\n        let q1perp:vec3<f32> = cross( q1, N );\r\n        let q0perp:vec3<f32> = cross( N, q0 );\r\n        let T:vec3<f32> = q1perp * st0.x + q0perp * st1.x;\r\n        let B:vec3<f32> = q1perp * st0.y + q0perp * st1.y;\r\n        let det:f32 = max( dot( T, T ), dot( B, B ) );\r\n        let scale:f32 = ( det == 0.0 ) ? 0.0 : faceDirection * inversesqrt( det );\r\n        return normalize( T * ( textureN.x * scale ) + B * ( textureN.y * scale ) + N * textureN.z );\r\n    }\r\n    #endif\r\n    struct MultiAndSingleScatter{\r\n        multiScatter:vec3<f32>,\r\n        singleScatter:vec3<f32>\r\n    }\r\n   #if ${defines.USE_IRIDESCENCE}\r\n   ////////inout vec3 singleScatter, inout vec3 multiScatter\r\n       fn computeMultiscatteringIridescence( normal:vec3<f32>, viewDir:vec3<f32>, specularColor:vec3<f32>, specularF90:f32, iridescence:f32,iridescenceF0:vec3<f32>, roughness:f32 )->MultiAndSingleScatter {\r\n   #else\r\n   ////////inout vec3 singleScatter, inout vec3 multiScatter\r\n       fn computeMultiscattering( normal:vec3<f32>,viewDir:vec3<f32>, specularColor:vec3<f32>, specularF90:f32, roughness:f32)->MultiAndSingleScatter {\r\n   #endif\r\n   let fab:vec2<f32> = DFGApprox( normal, viewDir, roughness );\r\n\r\n   var multiAndSingleScatter:MultiAndSingleScatter;\r\n\r\n   #if ${defines.USE_IRIDESCENCE}\r\n       let Fr:vec3<f32> = mix( specularColor, iridescenceF0, iridescence );\r\n   #else\r\n       let Fr:vec3<f32> = specularColor;\r\n   #endif\r\n       let FssEss:vec3<f32> = Fr * fab.x + specularF90 * fab.y;\r\n       let Ess:f32 = fab.x + fab.y;\r\n       let Ems:f32 = 1.0 - Ess;\r\n       let Favg:vec3<f32> = Fr + ( 1.0 - Fr ) * 0.047619;\r\n       let Fms:vec3<f32> = FssEss * Favg / ( 1.0 - Ems * Favg );\r\n    //    singleScatter += FssEss;\r\n    //    multiScatter += Fms * Ems;\r\n       multiAndSingleScatter.multiScatter=Fms * Ems;\r\n       multiAndSingleScatter.singleScatter=FssEss;\r\n       return multiAndSingleScatter;\r\n   }\r\n   //直接光照\r\n   fn RE_Direct_Physical( directLight:IncidentLight, geometry:GeometricContext,  material:PhysicalMaterial)->ReflectedLight {\r\n       var reflectedLight:ReflectedLight;\r\n       let dotNL:f32 = saturate(dot( geometry.normal, directLight.direction));\r\n       let irradiance:vec3<f32> = dotNL * directLight.color;\r\n       #if ${defines.USE_CLEARCOAT}\r\n           let dotNLcc:f32 = saturate( dot( geometry.clearcoatNormal, directLight.direction ) );\r\n           let ccIrradiance:vec3<f32> = dotNLcc * directLight.color;\r\n           clearcoatSpecular += ccIrradiance * BRDF_GGX( directLight.direction, geometry.viewDir, geometry.clearcoatNormal, material.clearcoatF0, material.clearcoatF90, material.clearcoatRoughness );\r\n       #endif\r\n\r\n       #if ${defines.USE_SHEEN}\r\n           sheenSpecular += irradiance * BRDF_Sheen( directLight.direction, geometry.viewDir, geometry.normal, material.sheenColor, material.sheenRoughness );\r\n       #endif\r\n\r\n       #if ${defines.USE_IRIDESCENCE}\r\n           reflectedLight.directSpecular = irradiance * BRDF_GGX_Iridescence( directLight.direction, geometry.viewDir, geometry.normal, material.specularColor, material.specularF90, material.iridescence, material.iridescenceFresnel, material.roughness );\r\n       #else\r\n           reflectedLight.directSpecular = irradiance * BRDF_GGX( directLight.direction, geometry.viewDir, geometry.normal, material.specularColor, material.specularF90, material.roughness );\r\n       #endif\r\n       reflectedLight.directDiffuse = irradiance * BRDF_Lambert( material.diffuseColor );\r\n       return reflectedLight;\r\n   }\r\n   //间接光照\r\n   fn RE_IndirectDiffuse_Physical( irradiance:vec3<f32>, geometry:GeometricContext, material:PhysicalMaterial )->ReflectedLight {\r\n       var reflectedLight:ReflectedLight;\r\n       reflectedLight.indirectDiffuse = irradiance * BRDF_Lambert( material.diffuseColor );\r\n       return reflectedLight;\r\n   }\r\n   //间接高光\r\n   fn RE_IndirectSpecular_Physical( radiance:vec3<f32>, irradiance:vec3<f32>, clearcoatRadiance:vec3<f32>, geometry:GeometricContext, material:PhysicalMaterial)->ReflectedLight {\r\n       var reflectedLight:ReflectedLight;\r\n       #if ${defines.USE_CLEARCOAT}\r\n           clearcoatSpecular += clearcoatRadiance * EnvironmentBRDF( geometry.clearcoatNormal, geometry.viewDir, material.clearcoatF0, material.clearcoatF90, material.clearcoatRoughness );\r\n       #endif\r\n       #if ${defines.USE_SHEEN}\r\n           sheenSpecular += irradiance * material.sheenColor * IBLSheenBRDF( geometry.normal, geometry.viewDir, material.sheenRoughness );\r\n       #endif\r\n       var singleScattering:vec3<f32>;\r\n       var multiScattering:vec3<f32>;\r\n       let cosineWeightedIrradiance:vec3<f32> = irradiance * RECIPROCAL_PI;\r\n       var tempMultiAndSingleScatter:MultiAndSingleScatter;\r\n       #if ${defines.USE_IRIDESCENCE}\r\n             tempMultiAndSingleScatter=computeMultiscatteringIridescence( geometry.normal, geometry.viewDir, material.specularColor, material.specularF90, material.iridescence, material.iridescenceFresnel, material.roughness );\r\n       #else\r\n            tempMultiAndSingleScatter= computeMultiscattering( geometry.normal, geometry.viewDir, material.specularColor, material.specularF90, material.roughness );\r\n       #endif\r\n       singleScattering=tempMultiAndSingleScatter.singleScatter; \r\n       multiScattering=tempMultiAndSingleScatter.multiScatter;\r\n       let totalScattering:vec3<f32> = singleScattering + multiScattering;\r\n       let diffuse:vec3<f32> = material.diffuseColor * ( 1.0 - max( max( totalScattering.r, totalScattering.g ), totalScattering.b ) );\r\n       reflectedLight.indirectSpecular = radiance * singleScattering;\r\n       reflectedLight.indirectSpecular = multiScattering * cosineWeightedIrradiance;\r\n       reflectedLight.indirectDiffuse = diffuse * cosineWeightedIrradiance;\r\n       return reflectedLight;\r\n   }\r\n   `;\r\n}\r\n","import { wgslParseDefines } from \"../../WgslPreprocessor\";\r\n\r\nexport default function pbrStruct(defines) {\r\n  return wgslParseDefines`\r\n        struct MaterialUniform{\r\n\r\n            modelMatrix: mat4x4<f32>,\r\n    \r\n            diffuse:vec3<f32>,\r\n    \r\n            opacity:f32,\r\n    \r\n            normalMatrix: mat3x3<f32>,\r\n    \r\n            emissive:vec3<f32>,\r\n    \r\n            roughness:f32,\r\n    \r\n            metalness:f32,\r\n    \r\n            #if ${defines.TONE_MAPPING}\r\n                toneMappingExposure:f32,\r\n            #endif\r\n           \r\n            #if ${defines.SPECULAR}\r\n    \r\n                 specularColor:vec3<f32>,\r\n    \r\n                 specularIntensity:f32,\r\n            #endif\r\n            \r\n            #if ${defines.USE_SHEEN}\r\n    \r\n                sheenColor:vec3<f32>,\r\n    \r\n                sheenRoughness:f32,\r\n            #endif\r\n\r\n            #if ${defines.USE_TRANSMISSION}\r\n    \r\n                attenuationColor:vec3<f32>,\r\n    \r\n                transmission:f32,\r\n    \r\n                transmissionSamplerSize:vec2<f32>,\r\n    \r\n                thickness:f32,\r\n    \r\n                attenuationDistance:f32,\r\n                \r\n            #endif\r\n\r\n            #if ${defines.USE_SKINNING}\r\n    \r\n                bindMatrix:mat4x4<f32>,\r\n    \r\n                bindMatrixInverse:mat4x4<f32>,\r\n    \r\n                boneTextureSize:u32,\r\n            #endif\r\n\r\n            #if ${defines.USE_NORMALTEXTURE}\r\n                 normalScale:vec2<f32>,\r\n            #endif\r\n    \r\n            #if ${defines.IOR}\r\n                ior:f32,\r\n            #endif\r\n    \r\n            #if ${defines.USE_CLEARCOAT}\r\n    \r\n                #if ${defines.USE_CLEARCOAT_NORMALTEXTURE}\r\n                    clearcoatNormalScale:vec2<f32>,\r\n                #endif\r\n    \r\n                 clearcoat:f32,\r\n    \r\n                 clearcoatRoughness:f32,\r\n            #endif\r\n    \r\n            #if ${defines.USE_IRIDESCENCE}\r\n                iridescence:f32,\r\n    \r\n                iridescenceIOR:f32,\r\n    \r\n                iridescenceThicknessMinimum:f32,\r\n    \r\n                iridescenceThicknessMaximum:f32,\r\n    \r\n            #endif\r\n\r\n            #if ${defines.USE_AOTEXTURE}\r\n                 aoTextureIntensity:f32,\r\n            #endif\r\n\r\n            #if ${defines.USE_LIGHTTEXTURE}\r\n                 lightTextureIntensity:f32,\r\n            #endif\r\n    \r\n            #if ${defines.USE_ENVTEXTURE}\r\n                envTextureIntensity:f32,\r\n    \r\n                flipEnvTexture:f32,\r\n            #endif\r\n\r\n            #if ${defines.USE_BUMPTEXTURE}\r\n                bumpScale:f32;\r\n            #endif\r\n\r\n            #if ${defines.USE_DISPLACEMENTTEXTURE}\r\n    \r\n                displacementScale:f32,\r\n    \r\n                displacementBias:f32,\r\n            #endif\r\n            \r\n            #if ${defines.USE_MORPHTARGETS}\r\n    \r\n                morphTargetBaseInfluence:f32,\r\n    \r\n                #if ${defines.MORPHTARGETS_TEXTURE} \r\n    \r\n                    morphTargetsTextureSize:vec2<u32>,\r\n    \r\n                    MORPHTARGETS_COUNT:u32,\r\n    \r\n                #endif\r\n    \r\n                morphTargetInfluences:array<f32>,\r\n                    \r\n            #endif\r\n        }\r\n\r\n   `;\r\n}\r\n","import { wgslParseDefines } from \"../../WgslPreprocessor\";\r\n\r\nexport default function pbrTexture(defines) {\r\n  return wgslParseDefines`        \r\n            #if ${defines.USE_BUMPTEXTURE}\r\n                @group(0) @binding(${defines.bumpTextureBinding}) var bumpTexture: texture_2d<f32>;\r\n            #endif\r\n            #if ${defines.USE_TRANSMISSION}\r\n                #if ${defines.USE_TRANSMISSIONTEXTURE}\r\n                    @group(0) @binding(${defines.transmissionTextureBinding}) var transmissionTexture: texture_2d<f32>;\r\n                #endif\r\n                #if ${defines.USE_THICKNESSTEXTURE}\r\n                    @group(0) @binding(${defines.thicknessTextureBinding}) var thicknessTexture: texture_2d<f32>;\r\n                #endif\r\n                @group(0) @binding(${defines.transmissionSamplerTextureBinding}) var transmissionSamplerTexture: texture_2d<f32>;\r\n            #endif\r\n            #if ${defines.USE_ENVTEXTURE}\r\n                @group(0) @binding(${defines.envTextureBinding}) var envTexture: texture_cube<f32>;\r\n            #endif\r\n            #if ${defines.USE_NORMALTEXTURE}\r\n                @group(0) @binding(${defines.normalTextureBinding}) var normalTexture: texture_2d<f32>;\r\n            #endif\r\n            \r\n            #if ${defines.USE_CLEARCOATTEXTURE}\r\n                @group(0) @binding(${defines.clearcoatTextureBinding}) var clearcoatTexture: texture_2d<f32>;\r\n            #endif\r\n            \r\n            #if ${defines.USE_CLEARCOAT_ROUGHNESSTEXTURE}\r\n                @group(0) @binding(${defines.clearcoatRclearcoatRoughnessTextureBinding}) var clearcoatRoughnessTexture: texture_2d<f32>;\r\n            #endif\r\n            \r\n            #if ${defines.USE_CLEARCOAT_NORMALTEXTURE}\r\n                @group(0) @binding(${defines.clearcoatNormalTextureBinding}) var clearcoatNormalTexture: texture_2d<f32>;\r\n            #endif\r\n            \r\n            #if ${defines.USE_IRIDESCENCETEXTURE}\r\n                @group(0) @binding(${defines.iridescenceTextureBinding}) var iridescenceTexture: texture_2d<f32>;\r\n            #endif\r\n            \r\n            #if ${defines.USE_IRIDESCENCE_THICKNESSTEXTURE}\r\n                @group(0) @binding(${defines.iridescenceThicknessTextureBinding}) var iridescenceThicknessTexture: texture_2d<f32>;\r\n            #endif\r\n            \r\n            #if ${defines.USE_ROUGHNESSTEXTURE}\r\n                @group(0) @binding(${defines.roughnessTextureBinding}) var roughnessTexture: texture_2d<f32>;\r\n            #endif\r\n            \r\n            #if ${defines.USE_METALNESSTEXTURE}\r\n                @group(0) @binding(${defines.metalnessTextureBinding}) var metalnessTexture: texture_2d<f32>;\r\n            #endif\r\n\r\n            #if ${defines.SPECULAR}\r\n                #if ${defines.USE_SPECULARINTENSITYTEXTURE}\r\n                    @group(0) @binding(${defines.specularIntensityTextureBinding}) var specularIntensityTexture: texture_2d<f32>;\r\n                #endif\r\n\r\n                #if ${defines.USE_SPECULARCOLORTEXTURE}\r\n                    @group(0) @binding(${defines.specularColorTextureBinding}) var specularColorTexture: texture_2d<f32>;\r\n                #endif\r\n            #endif\r\n\r\n            #if ${defines.USE_SHEEN}\r\n                #if ${defines.USE_SHEENCOLORTEXTURE}\r\n                    @group(0) @binding(${defines.sheenColorTextureBinding}) var sheenColorTexture: texture_2d<f32>;\r\n                #endif\r\n                #if ${defines.USE_SHEENROUGHNESSTEXTURE}\r\n                    @group(0) @binding(${defines.sheenRoughnessTextureBinding}) var sheenRoughnessTexture: texture_2d<f32>;\r\n                #endif\r\n            #endif\r\n\r\n            #if ${defines.USE_TEXTURE}\r\n                @group(0) @binding(${defines.baseSamplerBinding}) var baseSampler: sampler;\r\n                @group(0) @binding(${defines.baseTextureBinding}) var baseTexture: texture_2d<f32>;\r\n            #endif\r\n\r\n            #if ${defines.USE_ALPHATEXTURE}\r\n                @group(0) @binding(${defines.alphaTextureBinding}) var alphaTexture: texture_2d<f32>;\r\n            #endif\r\n\r\n            #if ${defines.USE_AOTEXTURE}\r\n                @group(0) @binding(${defines.aoTextureBinding}) var aoTexture: texture_2d<f32>;\r\n                \r\n            #endif\r\n            #if ${defines.USE_LIGHTTEXTURE}\r\n                @group(0) @binding(${defines.lightTextureBinding}) var lightTexture: texture_2d<f32>;\r\n            #endif\r\n\r\n            #if ${defines.USE_EMISSIVETEXTURE}\r\n                @group(0) @binding(${defines.emissiveTextureBinding}) var emissiveTexture: texture_2d<f32>;\r\n            #endif\r\n     `;\r\n}\r\n","import { wgslParseDefines } from \"../../WgslPreprocessor\";\r\n\r\nexport default function pbrUtils(defines) {\r\n  return wgslParseDefines`\r\n    const PI:f32= 3.141592653589793;\r\n    const PI2:f32= 6.283185307179586;\r\n    const PI_HALF:f32= 1.5707963267948966;\r\n    const RECIPROCAL_PI:f32= 0.3183098861837907;\r\n    const RECIPROCAL_PI2:f32= 0.15915494309189535;\r\n    const EPSILON:f32= 1e-6;\r\n\r\n    fn pow2(x:f32 )->f32 {\r\n        return x*x;\r\n    }\r\n    fn pow2Vector(x:vec3<f32> )->vec3<f32> {\r\n        return x*x;\r\n    }\r\n    fn pow3( x:f32 )->f32 {\r\n        return x*x*x;\r\n    }\r\n    fn pow4( x:f32 )->f32 {\r\n        let x2:f32 = x*x;\r\n        return x2*x2;\r\n    }\r\n    fn max3( v:vec3<f32> )->f32 {\r\n        return max( max( v.x, v.y ), v.z );\r\n    }\r\n    fn average(v:vec3<f32> )->f32 {\r\n        return dot( v, vec3<f32>( 0.3333333 ) );\r\n    }\r\n    fn rand( uv:vec2<f32> )->f32 {\r\n        let a:f32 = 12.9898;\r\n        let b:f32 = 78.233;\r\n        let c:f32 = 43758.5453;\r\n        let dt:f32 = dot( uv.xy, vec2<f32>( a, b ) );\r\n        let sn:f32 = dt % PI;\r\n        return fract( sin( sn ) * c );\r\n    }\r\n    fn transformDirection( dir:vec3<f32>, matrix:mat4x4<f32> )->vec3<f32> {\r\n        return normalize( ( matrix * vec4<f32>( dir, 0.0 ) ).xyz );\r\n    }\r\n\r\n    fn transposeMat3( m:mat3x3<f32> )->mat3x3<f32> {\r\n        var tmp:mat3x3<f32>;\r\n        tmp[ 0 ] = vec3<f32>( m[ 0 ].x, m[ 1 ].x, m[ 2 ].x );\r\n        tmp[ 1 ] = vec3<f32>( m[ 0 ].y, m[ 1 ].y, m[ 2 ].y );\r\n        tmp[ 2 ] = vec3<f32>( m[ 0 ].z, m[ 1 ].z, m[ 2 ].z );\r\n        return tmp;\r\n    }\r\n    fn luminance( rgb:vec3<f32> )->f32 {\r\n        let weights:vec3<f32> = vec3<f32>(0.2126729, 0.7151522, 0.0721750 );\r\n        return dot( weights, rgb );\r\n    }\r\n    fn LinearToneMapping( color:vec3<f32>,toneMappingExposure:f32  )->vec3<f32> {\r\n        return toneMappingExposure * color;\r\n    }\r\n\r\n    fn ReinhardToneMapping( color:vec3<f32>,toneMappingExposure:f32 )->vec3<f32> {\r\n        var tempColor:vec3<f32>;\r\n        tempColor=color;\r\n        tempColor *= toneMappingExposure;\r\n        return saturate( tempColor / ( vec3<f32>( 1.0 ) + tempColor ) );\r\n    }\r\n    fn CustomToneMapping( color:vec3<f32> )->vec3<f32> {\r\n        return color;\r\n    }\r\n    fn toneMapping( color:vec3<f32>,toneMappingExposure:f32  )->vec3<f32> {\r\n        return ReinhardToneMapping( color,toneMappingExposure );\r\n    }\r\n\r\n    fn LinearToLinear( value:vec4<f32> )->vec4<f32> {\r\n        return value;\r\n    }\r\n    fn lessThanEqual(a:vec3<f32>,b:vec3<f32>)->vec3<f32>{\r\n       let xValue:f32=select(b.x,a.x,a.x<=b.x);\r\n       let yValue:f32=select(b.y,a.y,a.y<=b.y);\r\n       let zValue:f32=select(b.z,a.z,a.z<=b.z);\r\n       return vec3<f32>(xValue,yValue,zValue);    \r\n    }\r\n    fn LinearTosRGB( value:vec4<f32> )->vec4<f32> {\r\n        return vec4<f32>( mix( pow( value.rgb, vec3<f32>( 0.41666 ) ) * 1.055 - vec3<f32>( 0.055 ), value.rgb * 12.92, vec3<f32>( lessThanEqual( value.rgb, vec3<f32>( 0.0031308 ) ) ) ), value.a );\r\n    }\r\n    fn linearToOutputTexel(value:vec4<f32> )->vec4<f32> {\r\n        return LinearTosRGB( value );\r\n    }\r\n    `;\r\n}\r\n","export default function blinn_phong(defines) {\r\n\treturn `\r\n       fn getPointLightInfo(pointLight:PointLight,worldPos:vec3<f32>,shininess:f32,N:vec3<f32>,V:vec3<f32>)->vec3<f32>{\r\n        var color=vec3<f32>(0.0,0.0,0.0);\r\n        var direction:vec3<f32> = worldPos - pointLight.position;\r\n        let dist:f32 = length( direction );\r\n        direction = normalize(direction);\r\n        let decay = clamp(1.0 - pow(dist / pointLight.distance, 4.0), 0.0, 1.0);\r\n\r\n        let d =  max( dot( N, -direction ), 0.0 ) * decay;\r\n        color += pointLight.color * d;\r\n\r\n        let halfDir:vec3<f32> = normalize( V - direction );\r\n        let s:f32 = pow( clamp( dot( N, halfDir ), 0.0, 1.0 ), shininess )  * decay;\r\n        color += pointLight.color * s;\r\n        return color;\r\n       }\r\n       fn getSpotLightInfo(spotLight:SpotLight,worldPos:vec3<f32>,shininess:f32,N:vec3<f32>,V:vec3<f32>)->vec3<f32>{\r\n        var color=vec3<f32>(0.0,0.0,0.0);\r\n            var direction:vec3<f32> = spotLight.position - worldPos;\r\n            let lightDistance:f32 = length(direction);\r\n            direction = normalize(direction);\r\n            let angleCos:f32 = dot( direction, -spotLight.direction );\r\n            let decay:f32 = clamp(1.0 - pow(lightDistance/spotLight.distance, 4.0), 0.0, 1.0);\r\n            let spotEffect:f32 = smoothstep( spotLight.penumbraCos, spotLight.coneCos, angleCos );\r\n            let decayTotal:f32 = decay * spotEffect;\r\n            let d:f32 = max( dot( N, direction ), 0.0 )  * decayTotal;\r\n            color += spotLight.color * d;\r\n            let halfDir:vec3<f32> = normalize( V + direction );\r\n            let s:f32 = pow( clamp( dot( N, halfDir ), 0.0, 1.0 ), shininess ) * decayTotal;\r\n            color += spotLight.color * s;\r\n            return color;\r\n       }\r\n    struct DirectionalLight {\r\n        direction: vec3<f32>,\r\n        color: vec3<f32>,\r\n    };\r\n      fn getDirectLightInfo(directionalLight:DirectionalLight,shininess:f32,N:vec3<f32>,V:vec3<f32>)->vec3<f32>{\r\n        var color=vec3<f32>(0.0,0.0,0.0);\r\n        let d:f32 = max(dot(N, -directionalLight.direction), 0.0);\r\n        color += directionalLight.color * d;\r\n\r\n        let halfDir:vec3<f32> = normalize( V - directionalLight.direction );\r\n        let s:f32 = pow( clamp( dot( N, halfDir ), 0.0, 1.0 ), shininess );\r\n        color += directionalLight.color * s;\r\n        return color;\r\n       }\r\n    `;\r\n}\r\n","export default function phongFunction(defines) {\r\n  return `\r\n    fn G_BlinnPhong_Implicit( )->f32 {\r\n\r\n        // geometry term is (n dot l)(n dot v) / 4(n dot l)(n dot v)\r\n        return 0.25;\r\n\r\n    }\r\n    fn D_BlinnPhong( shininess:f32, dotNH:f32 )->f32 {\r\n\r\n        return RECIPROCAL_PI * ( shininess * 0.5 + 1.0 ) * pow(dotNH, shininess);\r\n\r\n    }\r\n    fn BRDF_BlinnPhong( lightDir:vec3<f32>, viewDir:vec3<f32>, normal:vec3<f32>, specularColor:vec3<f32>, shininess:f32 )->vec3<f32> {\r\n\r\n        let  halfDir = normalize( lightDir + viewDir );\r\n\r\n        let  dotNH:f32 = saturate( dot( normal, halfDir ) );\r\n        let dotVH:f32 = saturate( dot( viewDir, halfDir ) );\r\n\r\n        let F = F_Schlick( specularColor, 1.0, dotVH );\r\n\r\n        let G:f32 = G_BlinnPhong_Implicit( );\r\n\r\n        let D = D_BlinnPhong( shininess, dotNH );\r\n\r\n        return F * ( G * D );\r\n\r\n    } \r\n    fn RE_Direct_BlinnPhong(  directLight:IncidentLight,geometry:GeometricContext, material:BlinnPhongMaterial )->ReflectedLight{\r\n        var reflectedLight:ReflectedLight; \r\n        let dotNL:f32 = saturate(dot(geometry.normal, directLight.direction));\r\n        let irradiance:vec3<f32> = dotNL*directLight.color;\r\n\r\n        reflectedLight.directDiffuse= irradiance * BRDF_Lambert( material.diffuseColor );\r\n\r\n        reflectedLight.directSpecular= irradiance * BRDF_BlinnPhong( directLight.direction, geometry.viewDir, geometry.normal, material.specularColor, material.specularShininess ) * material.specularStrength;\r\n        return reflectedLight;\r\n    }\r\n    fn RE_IndirectDiffuse_BlinnPhong( irradiance:vec3<f32>, geometry:GeometricContext, material:BlinnPhongMaterial)->ReflectedLight {\r\n        var reflectedLight:ReflectedLight; \r\n        reflectedLight.indirectDiffuse += irradiance * BRDF_Lambert( material.diffuseColor );\r\n        return reflectedLight;\r\n    }\r\n    `;\r\n}\r\n","export default function phongUtils(defines) {\r\n  return `\r\n   struct BlinnPhongMaterial {\r\n        diffuseColor:vec3<f32>,\r\n        specularColor:vec3<f32>,\r\n        specularShininess:f32,\r\n        specularStrength:f32,\r\n    };\r\n    const RECIPROCAL_PI:f32= 0.3183098861837907;\r\n   fn pow2( x:f32 )->f32 { return x*x; }\r\n   fn pow3( x:f32 )->f32 { return x*x*x; }\r\n   fn pow4(x:f32 )->f32 { let x2 = x*x; return x2*x2; }\r\n   fn max3( v:vec3<f32> )->f32 { return max( max( v.x, v.y ), v.z ); }\r\n   fn average(v:vec3<f32> )->f32 { \r\n       let result=vec3<f32>( 0.3333333,  0.3333333, 0.3333333);\r\n       return dot( v,result ); \r\n   }\r\n   `;\r\n}\r\n","import { wgslParseDefines } from \"../../WgslPreprocessor\";\n\nexport function getSkinMatrix(defines) {\n\treturn wgslParseDefines`\n   #if ${defines.HAS_SKIN} \n        struct JointsUniform{\n             matrixs:array<mat4x4f>,\n        }\n        struct InverseBindMatricesUniform{\n            matrixs:array<mat4x4f>,\n        }\n        @binding(${defines.skinJointsBufferBinding}) @group(0) var<storage, read> jointsUniform : JointsUniform;\n        @binding(${defines.invsBufferBinding}) @group(0) var<storage, read> inverseBindMatricesUniform : InverseBindMatricesUniform;\n        fn getSkinMatrix(joints: vec4f, weights: vec4f) -> mat4x4<f32> {\n            let joint0 = jointsUniform.matrixs[u32(joints.x)] * inverseBindMatricesUniform.matrixs[u32(joints.x)];\n            let joint1 = jointsUniform.matrixs[u32(joints.y)] * inverseBindMatricesUniform.matrixs[u32(joints.y)];\n            let joint2 = jointsUniform.matrixs[u32(joints.z)] * inverseBindMatricesUniform.matrixs[u32(joints.z)];\n            let joint3 = jointsUniform.matrixs[u32(joints.w)] * inverseBindMatricesUniform.matrixs[u32(joints.w)];\n        \n            let skinMatrix = joint0 * weights.x +\n                            joint1 * weights.y +\n                            joint2 * weights.z +\n                            joint3 * weights.w;\n            return skinMatrix;\n        }\n        #endif\n   `;\n}\nexport function skinVertHeader(defines) {\n\treturn wgslParseDefines`\n   #if ${defines.HAS_SKIN} \n        struct JointsUniform{\n             matrixs:array<mat4x4f>,\n        }\n        struct InverseBindMatricesUniform{\n            matrixs:array<mat4x4f>,\n        }\n        @binding(${defines.skinJointsBufferBinding}) @group(0) var<storage, read> jointsUniform : JointsUniform;\n        @binding(${defines.invsBufferBinding}) @group(0) var<storage, read> inverseBindMatricesUniform : InverseBindMatricesUniform;\n        fn getSkinMatrix(joints: vec4f, weights: vec4f) -> mat4x4<f32> {\n            let joint0 = jointsUniform.matrixs[u32(joints.x)] * inverseBindMatricesUniform.matrixs[u32(joints.x)];\n            let joint1 = jointsUniform.matrixs[u32(joints.y)] * inverseBindMatricesUniform.matrixs[u32(joints.y)];\n            let joint2 = jointsUniform.matrixs[u32(joints.z)] * inverseBindMatricesUniform.matrixs[u32(joints.z)];\n            let joint3 = jointsUniform.matrixs[u32(joints.w)] * inverseBindMatricesUniform.matrixs[u32(joints.w)];\n        \n            let skinMatrix = joint0 * weights.x +\n                            joint1 * weights.y +\n                            joint2 * weights.z +\n                            joint3 * weights.w;\n            return skinMatrix;\n        }\n        #endif\n   `;\n}\nexport function skinVertMain(defines) {\n\treturn wgslParseDefines`\n        #if ${defines.HAS_SKIN}\n            modelMatrix =getSkinMatrix(input.joint0,input.weight0);\n            vNormalView = normalize((materialUniform.normalMatrix * modelMatrix * vec4<f32>(input.normal, 0.0)).xyz);\n        #endif\n  `;\n}\n","import { wgslParseDefines } from \"../../WgslPreprocessor\";\n\nexport function PbrMaterialStruct(defines) {\n\treturn wgslParseDefines`\n    struct MaterialUniform {\n          modelMatrix: mat4x4<f32>,\n          color: vec3<f32>,\n          opacity:f32,\n          normalMatrix: mat4x4<f32>,\n          emissive:vec3<f32>,\n          metallic:f32,\n          roughness:f32,\n          #if ${defines.USE_NORMALTEXTURE}\n              normalTextureScale:vec2<f32>,\n          #endif\n          #if ${defines.USE_AOTEXTURE}\n              occlusionStrength:f32,\n          #endif\n      }\n   `;\n}\n","import { FragInput } from \"./attribute/FragInput\";\nimport { VertexInput } from \"./attribute/VertexInput\";\nimport { VertexOutput } from \"./attribute/VertexOutput\";\nimport { SystemUniform } from \"./common/SystemUniform\";\nimport { TextureAndSamplerDefine } from \"./common/TextureAndSamplerDefine\";\nimport environment from \"./environment/environment\";\nimport { instanceVertHeader, instanceVertMain } from \"./instance/Instance\";\nimport light from \"./light/light\";\nimport lightCommon from \"./light/lightCommon\";\nimport { getNormalByNormalTexture, getTBN, getNormal } from \"./normal/getNormalBackUp\";\nimport brdf from \"./pbr/brdf\";\nimport ibl from \"./pbr/ibl\";\nimport pbrFunction from \"./pbr/pbrFunction\";\nimport pbrStruct from \"./pbr/pbrStruct\";\nimport pbrTexture from \"./pbr/pbrTexture\";\nimport pbrUtils from \"./pbr/pbrUtils\";\nimport blinn_phong from \"./phong/blinn_phong\";\nimport phongFunction from \"./phong/phongFunction\";\nimport phongUtils from \"./phong/phongUtils\";\n// import getNormal from \"./normal/getNormal\";\nimport { skinVertHeader, skinVertMain } from \"./skin/SkinVert\";\nimport { PbrMaterialStruct } from \"./struct/PbrMaterialStruct\";\nconst ShaderChunk = {\n\tlight: light,\n\tbrdf: brdf,\n\tphongFunction: phongFunction,\n\tphongUtils: phongUtils,\n\tlightCommon: lightCommon,\n\tpbrStruct: pbrStruct,\n\tpbrFunction: pbrFunction,\n\tpbrTexture: pbrTexture,\n\tpbrUtils: pbrUtils,\n\tenvironment: environment,\n\tblinn_phong: blinn_phong,\n\tgetNormal: getNormal,\n\tgetTBN: getTBN,\n\tgetNormalByNormalTexture: getNormalByNormalTexture,\n\tibl: ibl,\n\tskinVertMain,\n\tskinVertHeader,\n\tFragInput,\n\tVertexInput,\n\tVertexOutput,\n\tPbrMaterialStruct,\n\tSystemUniform,\n\tinstanceVertMain,\n\tinstanceVertHeader,\n\tTextureAndSamplerDefine\n};\nexport default ShaderChunk;\n","export default function shadowMapDebuggerFrag(defines) {\r\n\treturn `\r\n    @group(0) @binding(1) var shadowSampler: sampler;\r\n    @group(0) @binding(0) var shadowMap: texture_depth_2d;\r\n    \r\n    // @group(0) @binding(0) var shadowMap: texture_depth_2d_array;\r\n    // @group(0) @binding(0) var shadowMap: texture_2d<f32>;\r\n\r\n    struct VertexOutput {\r\n        @builtin(position) position: vec4<f32>,\r\n        @location(0) uv: vec2<f32>,\r\n    };\r\n\r\n    fn linearizeDepth(depth: f32, near: f32, far: f32)->f32 {\r\n      return 2 * (near * far) / (far + near - depth * (far - near));\r\n    }\r\n\r\n    @fragment\r\n    fn main(input:VertexOutput) -> @location(0) vec4<f32> {\r\n\t\t\tlet color: vec4<f32> = textureGather(shadowMap, shadowSampler, vec2<f32>(input.uv.x,1.0-input.uv.y));\r\n      let depth = (linearizeDepth(color.r, 0.1, 500) - 0.1) / (500 - 0.1);\r\n      return vec4(vec3(depth), 1.0); // PerspectiveCamera\r\n      // return color;\r\n\r\n      // return textureSample(shadowMap, shadowSampler, vec2<f32>(input.uv.x,1.0-input.uv.y));\r\n\r\n    }\r\n    `;\r\n}\r\n","export default function shadowMapDebuggerVert(defines) {\r\n\treturn `\r\n    struct VertexInput {\r\n         @location(${defines.positionLocation}) position: vec2<f32>,       \r\n    }\r\n    struct VertexOutput {\r\n         @builtin(position) position: vec4<f32>,\r\n         @location(0) uv: vec2<f32>,\r\n     };\r\n    @vertex\r\n    fn main(input: VertexInput) -> VertexOutput {\r\n     var output:VertexOutput;\r\n     output.uv = input.position * 0.5 + 0.5;\r\n     output.position = vec4<f32>(input.position, 0.0, 1.0);;\r\n     return output;\r\n    }\r\n    `;\r\n}\r\n","// import Color from \"../../math/Color\";\r\n\r\nexport default function shadowMapFrag(defines) {\r\n\treturn `\r\n    struct VertexOutput {\r\n        @builtin(position) position: vec4<f32>,\r\n        @location(0) color: vec4<f32>,\r\n    };\r\n    @fragment\r\n    fn main(input:VertexOutput) -> @location(0) vec4<f32> {\r\n      return input.color;\r\n    }\r\n    `;\r\n}\r\n","import { wgslParseDefines } from \"../../WgslPreprocessor\";\r\nexport default function shadowMapVert(defines) {\r\n\treturn wgslParseDefines`\r\n   struct VertexInput {\r\n      @location(${defines.positionLocation}) position: vec3<f32>,       \r\n   };\r\n   struct VertexOutput {\r\n      @builtin(position) position: vec4<f32>,\r\n    };\r\n   struct SelfUniform {\r\n      modelMatrix: mat4x4<f32>,\r\n   };\r\n   struct SystemUniform {\r\n      projectionMatrix: mat4x4<f32>,\r\n      viewMatrix: mat4x4<f32>,\r\n      inverseViewMatrix: mat4x4<f32>,\r\n      cameraPosition: vec3<f32>,\r\n   };\r\n\r\n   #if ${defines.isPointLightShadowMap}\r\n      struct PointLightUniform {\r\n         vpMatrix: mat4x4<f32>,\r\n         // vpMatrixArray: array<mat4x4<f32>, 6>,\r\n      };\r\n      @group(1) @binding(${defines.pointLightShadowCameraBinding}) var<storage, read> pointLightUniform: PointLightUniform;\r\n   #endif\r\n\r\n   @group(0) @binding(${defines.selfBinding}) var<uniform> selfUniform : SelfUniform;\r\n   @group(1) @binding(${defines.cameraBinding}) var<uniform> systemUniform : SystemUniform;\r\n\r\n   @vertex\r\n   fn main(input: VertexInput) -> VertexOutput {\r\n      var output:VertexOutput;\r\n      #if ${defines.isPointLightShadowMap}\r\n         output.position = pointLightUniform.vpMatrix * selfUniform.modelMatrix * vec4<f32>(input.position,1.0);\r\n      #else\r\n         output.position = systemUniform.projectionMatrix * systemUniform.viewMatrix * selfUniform.modelMatrix * vec4<f32>(input.position,1.0);\r\n      #endif\r\n      return output;\r\n   }\r\n   `;\r\n}\r\n","import { billboard_fs } from \"./material/billboard_fs\";\r\nimport { billboard_vs } from \"./material/billboard_vs\";\r\nimport colorFrag from \"./material/colorFrag\";\r\nimport colorVert from \"./material/colorVert\";\r\nimport pbr_fs from \"./material/pbr_fs\";\r\nimport pbr_vs from \"./material/pbr_vs\";\r\nimport pbrFrag from \"./material/pbrFrag\";\r\nimport pbrVert from \"./material/pbrVert\";\r\nimport phongFrag from \"./material/phongFrag\";\r\nimport phongVert from \"./material/phongVert\";\r\nimport quadFrag from \"./material/quadFrag\";\r\nimport quadVert from \"./material/quadVert\";\r\nimport skyBoxFrag from \"./material/skyBoxFrag\";\r\nimport skyBoxVert from \"./material/skyBoxVert\";\r\nimport blendFrag from \"./postProcess/blend/blendFrag\";\r\nimport Blur from \"./postProcess/bloom/Blur\";\r\nimport LuminosityHigh from \"./postProcess/bloom/LuminosityHigh\";\r\nimport ShaderChunk from \"./shaderChunk/ShaderChunk\";\r\nimport shadowMapDebuggerFrag from \"./shaderChunk/shadow/shadowMapDebuggerFrag\";\r\nimport shadowMapDebuggerVert from \"./shaderChunk/shadow/shadowMapDebuggerVert\";\r\nimport shadowMapFrag from \"./shaderChunk/shadow/shadowMapFrag\";\r\nimport shadowMapVert from \"./shaderChunk/shadow/shadowMapVert\";\r\n\r\nfunction reduceComma(shader) {\r\n\t// 对所有的include处理\r\n\tconst str = resolveIncludes(shader);\r\n\treturn str;\r\n}\r\nconst includePattern = /^[ \\t]*#include +<([\\w\\d./]+)>/gm;\r\nlet currentDefines = {};\r\nconst shaders = {\r\n\tphong: {\r\n\t\tfrag: phongFrag,\r\n\t\tvert: phongVert\r\n\t},\r\n\tcolor: {\r\n\t\tfrag: colorFrag,\r\n\t\tvert: colorVert\r\n\t},\r\n\tpbr: {\r\n\t\tfrag: pbrFrag,\r\n\t\tvert: pbrVert\r\n\t},\r\n\tskybox: {\r\n\t\tfrag: skyBoxFrag,\r\n\t\tvert: skyBoxVert\r\n\t},\r\n\tresolve: {\r\n\t\tfrag: quadFrag,\r\n\t\tvert: quadVert\r\n\t},\r\n\tpbr_mat: {\r\n\t\tfrag: pbr_fs,\r\n\t\tvert: pbr_vs\r\n\t},\r\n\tblur: {\r\n\t\tfrag: Blur,\r\n\t\tvert: quadVert\r\n\t},\r\n\tluminosityHigh: {\r\n\t\tfrag: LuminosityHigh,\r\n\t\tvert: quadVert\r\n\t},\r\n\tblend: {\r\n\t\tfrag: blendFrag,\r\n\t\tvert: quadVert\r\n\t},\r\n\tshadowMapDebugger: {\r\n\t\tfrag: shadowMapDebuggerFrag,\r\n\t\tvert: shadowMapDebuggerVert\r\n\t},\r\n\tshadowMap: {\r\n\t\tvert: shadowMapVert,\r\n\t\tfrag: shadowMapFrag\r\n\t},\r\n\tbillboard:{\r\n\t\tvert: billboard_vs,\r\n\t\tfrag: billboard_fs\r\n\t}\r\n};\r\n\r\nfunction resolveIncludes(string) {\r\n\treturn string.replace(includePattern, includeReplacer);\r\n}\r\n\r\nfunction includeReplacer(match, include) {\r\n\tconst excute = ShaderChunk[include];\r\n\tif (excute === undefined) {\r\n\t\tthrow new Error(`Can not resolve #include <${include}>`);\r\n\t}\r\n\tconst result = excute(currentDefines);\r\n\treturn resolveIncludes(result);\r\n}\r\nexport default function getVertFrag(type, defines = {}) {\r\n\tconst excuteFunc = shaders[type];\r\n\tcurrentDefines = defines;\r\n\treturn {\r\n\t\tvert: reduceComma(excuteFunc.vert(currentDefines)),\r\n\t\tfrag: reduceComma(excuteFunc.frag(currentDefines))\r\n\t};\r\n}\r\n","import defaultValue from \"../utils/defaultValue\";\r\nimport getVertFrag from \"./Shaders\";\r\nexport interface GPUShaderModuleObject {\r\n\tvert: GPUShaderModule;\r\n\tfrag: GPUShaderModule;\r\n}\r\nexport class ShaderSource {\r\n\tvertEntryPoint?: string;\r\n\tfragEntryPoint?: string;\r\n\tvert?: string | Function;\r\n\tfrag?: string | Function;\r\n\tcompute?: string | Function;\r\n\tcomputeMain?: string;\r\n\tdefines?: {};\r\n\tdirty: boolean;\r\n\trender: boolean;\r\n\ttype: string;\r\n\tprivate _uid: string;\r\n\tprivate custom: boolean;\r\n\tconstructor(options) {\r\n\t\tthis.type = options.type;\r\n\t\tthis.defines = options.defines;\r\n\t\tthis.custom = defaultValue(options.custom, false);\r\n\t\tthis.dirty = true;\r\n\t\tif (options.render) {\r\n\t\t\tthis.render = true;\r\n\t\t\tthis.vertEntryPoint = options.vertMain || \"main\";\r\n\t\t\tthis.fragEntryPoint = options.fragMain || \"main\";\r\n\t\t\tthis.vert = options.vert || undefined;\r\n\t\t\tthis.frag = options.frag || undefined;\r\n\t\t} else {\r\n\t\t\tthis.compute = options.compute || undefined;\r\n\t\t\tthis.computeMain = options.computeMain || \"main\";\r\n\t\t}\r\n\t}\r\n\tget uid() {\r\n\t\tthis._uid = this.type.concat(JSON.stringify(this.defines));\r\n\t\treturn this._uid;\r\n\t}\r\n\tprivate updateShaderStr() {\r\n\t\tif (this.custom) {\r\n\t\t\tif (this.compute) {\r\n\t\t\t\tthis.compute = (<Function>this.compute)(this.defines);\r\n\t\t\t} else {\r\n\t\t\t\tthis.vert = this.vert instanceof Function ? this.vert(this.defines) : this.vert;\r\n\t\t\t\tthis.frag = this.frag instanceof Function ? this.frag(this.defines) : this.frag;\r\n\t\t\t}\r\n\t\t} else {\r\n\t\t\tconst source = getVertFrag(this.type, this.defines);\r\n\r\n\t\t\tthis.vert = source.vert;\r\n\t\t\tthis.frag = source.frag;\r\n\t\t}\r\n\t}\r\n\tpublic setDefines(defines) {\r\n\t\tif (!defines) return;\r\n\t\tthis.dirty = true;\r\n\t\tthis.defines = Object.assign(this.defines, defines);\r\n\t}\r\n\tcreateShaderModule(device: GPUDevice): { vert: GPUShaderModule; frag: GPUShaderModule } | GPUShaderModule {\r\n\t\tif (this.dirty) {\r\n\t\t\tthis.updateShaderStr();\r\n\t\t\tthis.dirty = false;\r\n\t\t}\r\n\t\tif (this.render) {\r\n\t\t\tconst vert = this.vert\r\n\t\t\t\t? device.createShaderModule({\r\n\t\t\t\t\t\tcode: <string>this.vert\r\n\t\t\t\t  })\r\n\t\t\t\t: undefined;\r\n\t\t\tconst frag = this.frag\r\n\t\t\t\t? device.createShaderModule({\r\n\t\t\t\t\t\tcode: <string>this.frag\r\n\t\t\t\t  })\r\n\t\t\t\t: undefined;\r\n\r\n\t\t\treturn { vert, frag };\r\n\t\t} else {\r\n\t\t\tconst compute = device.createShaderModule({\r\n\t\t\t\tcode: <string>this.compute\r\n\t\t\t});\r\n\t\t\treturn compute;\r\n\t\t}\r\n\t}\r\n\tstatic replaceMain(source: string, renamedMain: string) {\r\n\t\trenamedMain = `void ${renamedMain}()`;\r\n\t\treturn source.replace(/void\\s+main\\s*\\(\\s*(?:void)?\\s*\\)/g, renamedMain);\r\n\t}\r\n\tstatic compileCustomShaderbackUp(template, defines): string {\r\n\t\tconst reg = /\\{\\{(\\w+)\\}\\}/;\r\n\t\tif (reg.test(template)) {\r\n\t\t\tconst name = reg.exec(template)[1];\r\n\t\t\ttemplate = template.replace(reg, defines[name]);\r\n\t\t\treturn ShaderSource.compileCustomShader(template, defines);\r\n\t\t}\r\n\t\treturn template;\r\n\t}\r\n\tstatic compileCustomShader(template, defines): string {\r\n\t\tconst reg = /\\${(\\w+).(\\w+)}/;\r\n\t\tif (reg.test(template)) {\r\n\t\t\tconst regValue = reg.exec(template);\r\n\t\t\tconst define = regValue[2];\r\n\t\t\tconst name = regValue[0];\r\n\t\t\ttemplate = template.replace(name, defines[define]);\r\n\t\t\treturn ShaderSource.compileCustomShader(template, defines);\r\n\t\t}\r\n\t\treturn template;\r\n\t}\r\n}\r\n","import { IUniform, Uniforms } from \"../core/WebGPUTypes\";\r\nimport { Mesh } from \"../mesh/Mesh\";\r\nimport ShaderData from \"../render/ShaderData\";\r\nimport UniformBuffer from \"../render/UniformBuffer\";\r\nimport { UniformEnum } from \"../render/Uniforms\";\r\nconst uniformArrayNames = [\"float-array\", \"vec2-array\", \"vec3-array\", \"vec4-array\"];\r\nexport function checkContainFloatType(uniforms) {\r\n\tlet result = 0;\r\n\tlet hasArraytype = false;\r\n\tconst uniformsNames = Object.getOwnPropertyNames(uniforms);\r\n\tuniformsNames.map((uniformsName) => {\r\n\t\tif (uniforms[uniformsName].type == \"texture\" || uniforms[uniformsName].type == \"sampler\") {\r\n\t\t\tresult += 0;\r\n\t\t} else {\r\n\t\t\tif (\r\n\t\t\t\tuniformArrayNames.find((name) => {\r\n\t\t\t\t\treturn name === uniforms[uniformsName].type;\r\n\t\t\t\t})\r\n\t\t\t) {\r\n\t\t\t\thasArraytype = true;\r\n\t\t\t} else {\r\n\t\t\t\tresult += 1;\r\n\t\t\t}\r\n\t\t}\r\n\t});\r\n\treturn {\r\n\t\thasFloat: result,\r\n\t\thasArraytype\r\n\t};\r\n}\r\nexport function addUniformToShaderData(\r\n\tname: string,\r\n\tuniform: IUniform,\r\n\tuniforms: Uniforms,\r\n\tshaderData: ShaderData,\r\n\tmesh?:Mesh,\r\n\tuniformBuffer?: UniformBuffer\r\n) {\r\n\tswitch (uniform.type) {\r\n\t\tcase \"float\":\r\n\t\t\tuniformBuffer.setUniform(\r\n\t\t\t\tname,\r\n\t\t\t\t() => {\r\n\t\t\t\t\treturn uniforms[name].value;\r\n\t\t\t\t},\r\n\t\t\t\tUniformEnum.Float\r\n\t\t\t);\r\n\t\t\tbreak;\r\n\t\tcase \"vec2\":\r\n\t\t\tuniformBuffer.setUniform(\r\n\t\t\t\tname,\r\n\t\t\t\t() => {\r\n\t\t\t\t\treturn uniforms[name].value;\r\n\t\t\t\t},\r\n\t\t\t\tUniformEnum.FloatVec2\r\n\t\t\t);\r\n\t\t\tbreak;\r\n\t\tcase \"vec3\":\r\n\t\t\tuniformBuffer.setUniform(\r\n\t\t\t\tname,\r\n\t\t\t\t() => {\r\n\t\t\t\t\treturn uniforms[name].value;\r\n\t\t\t\t},\r\n\t\t\t\tUniformEnum.FloatVec3\r\n\t\t\t);\r\n\t\t\tbreak;\r\n\t\tcase \"color\":\r\n\t\t\tuniformBuffer.setUniform(\r\n\t\t\t\tname,\r\n\t\t\t\t() => {\r\n\t\t\t\t\treturn uniforms[name].value;\r\n\t\t\t\t},\r\n\t\t\t\tUniformEnum.Color\r\n\t\t\t);\r\n\t\t\tbreak;\r\n\t\tcase \"vec4\":\r\n\t\t\tuniformBuffer.setUniform(\r\n\t\t\t\tname,\r\n\t\t\t\t() => {\r\n\t\t\t\t\treturn uniforms[name].value;\r\n\t\t\t\t},\r\n\t\t\t\tUniformEnum.FloatVec4\r\n\t\t\t);\r\n\t\t\tbreak;\r\n\t\tcase \"mat2\":\r\n\t\t\tuniformBuffer.setUniform(\r\n\t\t\t\tname,\r\n\t\t\t\t() => {\r\n\t\t\t\t\treturn uniforms[name].value;\r\n\t\t\t\t},\r\n\t\t\t\tUniformEnum.Mat2\r\n\t\t\t);\r\n\t\t\tbreak;\r\n\t\tcase \"mat3\":\r\n\t\t\tuniformBuffer.setUniform(\r\n\t\t\t\tname,\r\n\t\t\t\t() => {\r\n\t\t\t\t\treturn uniforms[name].value;\r\n\t\t\t\t},\r\n\t\t\t\tUniformEnum.Mat3\r\n\t\t\t);\r\n\t\t\tbreak;\r\n\t\tcase \"mat4\":\r\n\t\t\tuniformBuffer.setUniform(\r\n\t\t\t\tname,\r\n\t\t\t\t() => {\r\n\t\t\t\t\treturn name==\"modelMatrix\"? mesh?.modelMatrix: name===\"normalMatrix\"?mesh.normalMatrix:uniforms[name].value;\r\n\t\t\t\t},\r\n\t\t\t\tUniformEnum.Mat4\r\n\t\t\t);\r\n\t\t\tbreak;\r\n\t\tcase \"float-array\":\r\n\t\t\tuniformBuffer.setUniform(\r\n\t\t\t\tname,\r\n\t\t\t\t() => {\r\n\t\t\t\t\treturn uniforms[name].value;\r\n\t\t\t\t},\r\n\t\t\t\tUniformEnum.FloatArray,\r\n\t\t\t\tuniforms[name].value.length\r\n\t\t\t);\r\n\t\t\tbreak;\r\n\t\tcase \"vec2-array\":\r\n\t\t\tuniformBuffer.setUniform(\r\n\t\t\t\tname,\r\n\t\t\t\t() => {\r\n\t\t\t\t\treturn uniforms[name].value;\r\n\t\t\t\t},\r\n\t\t\t\tUniformEnum.Vec2Array,\r\n\t\t\t\tuniforms[name].value.length\r\n\t\t\t);\r\n\t\t\tbreak;\r\n\t\tcase \"vec3-array\":\r\n\t\t\tuniformBuffer.setUniform(\r\n\t\t\t\tname,\r\n\t\t\t\t() => {\r\n\t\t\t\t\treturn uniforms[name].value;\r\n\t\t\t\t},\r\n\t\t\t\tUniformEnum.Vec3Array,\r\n\t\t\t\tuniforms[name].value.length\r\n\t\t\t);\r\n\t\t\tbreak;\r\n\t\tcase \"vec4-array\":\r\n\t\t\tuniformBuffer.setUniform(\r\n\t\t\t\tname,\r\n\t\t\t\t() => {\r\n\t\t\t\t\treturn uniforms[name].value;\r\n\t\t\t\t},\r\n\t\t\t\tUniformEnum.Vec4Array,\r\n\t\t\t\tuniforms[name].value.length\r\n\t\t\t);\r\n\t\t\tbreak;\r\n\t\tcase \"texture\":\r\n\t\t\tshaderData.setTexture(name, () => {\r\n\t\t\t\treturn uniforms[name].value;\r\n\t\t\t});\r\n\t\t\tbreak;\r\n\t\tcase \"sampler\":\r\n\t\t\tshaderData.setSampler(name, () => {\r\n\t\t\t\treturn uniforms[name].value;\r\n\t\t\t});\r\n\t\t\tbreak;\r\n\t\tdefault:\r\n\t\t\tthrow new Error(\"not match unifrom type\");\r\n\t}\r\n}\r\n","import BindGroupLayoutEntry from \"./BindGroupLayoutEntry\";\r\nconst layoutCache = new Map();\r\nclass BindGroupLayout {\r\n\tpublic gpuBindGroupLayout: GPUBindGroupLayout;\r\n\tindex: number;\r\n\tprivate constructor(device: GPUDevice, label: string, public entries: BindGroupLayoutEntry[] = [], index = 0) {\r\n\t\tthis.index = index || 0;\r\n\t\tthis.gpuBindGroupLayout = device.createBindGroupLayout({\r\n\t\t\tlabel: label,\r\n\t\t\tentries: entries.map(({ visibility, buffer, sampler, texture, storageTexture, binding }) => ({\r\n\t\t\t\tbinding,\r\n\t\t\t\tvisibility,\r\n\t\t\t\tbuffer,\r\n\t\t\t\tsampler,\r\n\t\t\t\ttexture,\r\n\t\t\t\tstorageTexture\r\n\t\t\t}))\r\n\t\t});\r\n\t}\r\n\tstatic getBindGroupLayoutFromCache(\r\n\t\tdevice: GPUDevice,\r\n\t\tlabel: string,\r\n\t\tentires: BindGroupLayoutEntry[],\r\n\t\tindex\r\n\t): BindGroupLayout {\r\n\t\tif (layoutCache.has(label)) {\r\n\t\t\treturn layoutCache.get(label);\r\n\t\t} else {\r\n\t\t\tconst bindGroupLayout = new BindGroupLayout(device, label, entires, index);\r\n\t\t\tlayoutCache.set(label, bindGroupLayout);\r\n\t\t\treturn bindGroupLayout;\r\n\t\t}\r\n\t}\r\n\tstatic removeBindGroupLayoutFromCache(bindGroupLayout: BindGroupLayout) {\r\n\t\tlayoutCache.delete(bindGroupLayout);\r\n\t}\r\n}\r\n\r\nexport default BindGroupLayout;\r\n","import { BindGroupLayoutEntryType } from \"../core/WebGPUTypes\";\r\nexport default class BindGroupLayoutEntry {\r\n  binding: number;\r\n  visibility: GPUShaderStageFlags;\r\n  uniforms?: any[];\r\n  buffer?: GPUBufferBindingLayout;\r\n  sampler?: GPUSamplerBindingLayout;\r\n  texture?: GPUTextureBindingLayout;\r\n  storageTexture?: GPUStorageTextureBindingLayout;\r\n  externalTexture?: GPUExternalTextureBindingLayout;\r\n  constructor(options: BindGroupLayoutEntryType) {\r\n    this.binding = options.binding;\r\n    this.visibility = options.visibility;\r\n    this.buffer = options.buffer;\r\n    this.sampler = options.sampler;\r\n    this.texture = options.texture;\r\n    this.storageTexture = options.storageTexture;\r\n    this.externalTexture = options.storageTexture;\r\n  }\r\n  getGPULayoutEntity() {\r\n    return {\r\n      binding: this.binding,\r\n      visibility: this.visibility,\r\n      buffer: this.buffer,\r\n      sampler: this.sampler,\r\n      texture: this.texture,\r\n      storageTexture: this.storageTexture,\r\n    };\r\n  }\r\n}\r\n","import defaultValue from \"../utils/defaultValue\";\r\nimport BindGroup from \"./BindGroup\";\r\nimport BindGroupEntity from \"./BindGroupEntity\";\r\nimport BindGroupLayout from \"./BindGroupLayout\";\r\nimport BindGroupLayoutEntry from \"./BindGroupLayoutEntry\";\r\nimport Context from \"./Context\";\r\nimport Sampler from \"./Sampler\";\r\nimport Texture from \"./Texture\";\r\nimport UniformBuffer from \"./UniformBuffer\";\r\nimport { UniformSampler, UniformTexture } from \"./Uniforms\";\r\nexport default class ShaderData {\r\n\tcurrentBinding: number;\r\n\r\n\tdefines: { [prop: string]: boolean | number };\r\n\r\n\tdefineDirty: boolean;\r\n\r\n\tlabel: string;\r\n\r\n\tbindGroup: BindGroup;\r\n\r\n\tgroupLayout: BindGroupLayout;\r\n\r\n\tlayoutIndex: number;\r\n\r\n\tgroupIndex: number;\r\n\r\n\tprotected _uniforms: Map<string, any>;\r\n\r\n\tconstructor(label: string, size?: number, layoutIndex?: number, groupIndex?) {\r\n\t\tthis.label = label;\r\n\t\tthis.currentBinding = 0;\r\n\t\tthis.defineDirty = true;\r\n\t\tthis.defines = {};\r\n\t\tthis._uniforms = new Map();\r\n\t\tthis.groupIndex = defaultValue(groupIndex, 0);\r\n\t\tthis.layoutIndex = defaultValue(layoutIndex, 0);\r\n\t}\r\n\tgetUniformBuffer(name: string): UniformBuffer {\r\n\t\treturn this._uniforms.get(name);\r\n\t}\r\n\tsetUniformBuffer(name: string, uniformBuffer: UniformBuffer) {\r\n\t\tif (this._uniforms.get(name)) return;\r\n\t\tuniformBuffer.binding = this.currentBinding;\r\n\t\tthis.setDefine(name.concat(\"Binding\"), this.currentBinding);\r\n\t\tthis.currentBinding += 1;\r\n\t\tthis._uniforms.set(name, uniformBuffer);\r\n\t}\r\n\tsetTexture(name: string, value: Function | Texture, binding?: number) {\r\n\t\tif (this._uniforms.get(name)) return;\r\n\t\tconst uniform = new UniformTexture(name, this.currentBinding, value);\r\n\t\tthis.setDefine(name.concat(\"Binding\"), this.currentBinding);\r\n\t\tthis.currentBinding += 1;\r\n\t\tthis._uniforms.set(name, uniform);\r\n\t}\r\n\tsetSampler(name: string, value: Function | Sampler, binding?: number) {\r\n\t\tif (this._uniforms.get(name)) return;\r\n\t\tconst uniform = new UniformSampler(name, this.currentBinding, value);\r\n\t\tthis.setDefine(name.concat(\"Binding\"), this.currentBinding);\r\n\t\tthis.currentBinding += 1;\r\n\t\tthis._uniforms.set(name, uniform);\r\n\t}\r\n\tsetDefine(name: string, value: boolean | number) {\r\n\t\tif (this.defines[name] === undefined) {\r\n\t\t\tthis.defineDirty = true;\r\n\t\t\tthis.defines[name] = value;\r\n\t\t} else {\r\n\t\t\tif (this.defines[name] === value) {\r\n\t\t\t\treturn;\r\n\t\t\t} else {\r\n\t\t\t\tthis.defineDirty = true;\r\n\t\t\t\tthis.defines[name] = value;\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\treplaceUniformBufferValue(name: string, value: Function | number | Object) {\r\n\t\tthis._uniforms.forEach((uniform) => {\r\n\t\t\tif (uniform?.isUniformBuffer) {\r\n\t\t\t\tuniform.replaceUniformValue(name, value);\r\n\t\t\t}\r\n\t\t});\r\n\t}\r\n\tbind(context: Context, passEncoder: GPURenderPassEncoder) {\r\n\t\tthis.uploadUniform(context);\r\n\t\tif (!this.groupLayout)\r\n\t\t\tthis.groupLayout = this.createBindGroupLayout(context.device, this.label, this.layoutIndex);\r\n\t\tif (!this.bindGroup) this.bindGroup = this.createBindGroup(context.device, this.label, this.groupIndex);\r\n\t\tthis.bindGroup.bind(passEncoder);\r\n\t}\r\n\tdestroy() {\r\n\t\tthis._uniforms.forEach((uniform) => {\r\n\t\t\tif (uniform.destroy) uniform?.destroy();\r\n\t\t});\r\n\t\tthis.label = undefined;\r\n\t\tthis.currentBinding = 1;\r\n\t\tthis.defineDirty = true;\r\n\t\tthis.defines = undefined;\r\n\t\tthis._uniforms.clear();\r\n\t\tBindGroupLayout.removeBindGroupLayoutFromCache(this.groupLayout);\r\n\t\tthis.bindGroup = undefined;\r\n\t}\r\n\tprivate createBindGroup(device: GPUDevice, label: string, groupIndex?: number) {\r\n\t\tconst { entities, dynamic, alignedSize, maxOffset } = this.createBindGroupEntity();\r\n\t\tconst bindGroup = new BindGroup({\r\n\t\t\tlabel: label,\r\n\t\t\tentires: entities,\r\n\t\t\tdevice: device,\r\n\t\t\tlayout: this.groupLayout,\r\n\t\t\tindex: groupIndex || 0, // 后续改成groupIndex\r\n\t\t\tdynamic,\r\n\t\t\talignedSize,\r\n\t\t\tmaxOffset\r\n\t\t});\r\n\t\treturn bindGroup;\r\n\t}\r\n\tprivate createBindGroupLayout(device: GPUDevice, label: string, layoutIndex?: number) {\r\n\t\tconst result = this.createBindGroupLayoutEntry();\r\n\t\tconst groupLayout = BindGroupLayout.getBindGroupLayoutFromCache(\r\n\t\t\tdevice,\r\n\t\t\tlabel + \"-\" + result.uid,\r\n\t\t\tresult.layouts,\r\n\t\t\tlayoutIndex || 0\r\n\t\t);\r\n\t\treturn groupLayout;\r\n\t}\r\n\tprotected uploadUniform(context: Context) {\r\n\t\tthis._uniforms.forEach((uniform) => {\r\n\t\t\tuniform.bind(context);\r\n\t\t});\r\n\t}\r\n\tprivate createBindGroupLayoutEntry() {\r\n\t\tlet uid = \"\";\r\n\t\tconst result = new Map();\r\n\t\tthis._uniforms.forEach((uniform) => {\r\n\t\t\tif (!result.has(uniform.name)) {\r\n\t\t\t\tuid = uid === \"\" ? uid.concat(uniform.name) : uid.concat(\", \").concat(uniform.name);\r\n\t\t\t\tresult.set(uniform.name, this.createOneLayoutEntry(uniform));\r\n\t\t\t}\r\n\t\t});\r\n\t\tuid = `uniforms[${uid}]`;\r\n\t\treturn { uid, layouts: [...result.values()] };\r\n\t}\r\n\tprivate createBindGroupEntity() {\r\n\t\tconst result = new Map();\r\n\t\tlet dynamic = false,\r\n\t\t\talignedSize = 0,\r\n\t\t\tmaxOffset = 0;\r\n\t\tthis._uniforms.forEach((uniform) => {\r\n\t\t\tif (!result.has(uniform.name)) {\r\n\t\t\t\tif (uniform?.hasDynamicOffset) {\r\n\t\t\t\t\tdynamic = true;\r\n\t\t\t\t\tmaxOffset = uniform.maxOffset;\r\n\t\t\t\t\talignedSize = Math.ceil(uniform.uniformsSize / (4 * 256)) * 256;\r\n\t\t\t\t}\r\n\t\t\t\tresult.set(uniform.name, this.creayeOneGroupEntity(uniform));\r\n\t\t\t}\r\n\t\t});\r\n\t\treturn {\r\n\t\t\tentities: [...result.values()],\r\n\t\t\tdynamic,\r\n\t\t\talignedSize,\r\n\t\t\tmaxOffset\r\n\t\t};\r\n\t}\r\n\tprivate createOneLayoutEntry(uniform) {\r\n\t\tlet layoutEntity;\r\n\t\tif (uniform.isUniformBuffer) {\r\n\t\t\tlayoutEntity = new BindGroupLayoutEntry({\r\n\t\t\t\tbinding: uniform.binding,\r\n\t\t\t\tbuffer: uniform.layoutType,\r\n\t\t\t\tvisibility: uniform.visibility\r\n\t\t\t});\r\n\t\t} else if (uniform.isTexture) {\r\n\t\t\tlayoutEntity = new BindGroupLayoutEntry({\r\n\t\t\t\tbinding: uniform.binding,\r\n\t\t\t\tvisibility: uniform.visibility,\r\n\t\t\t\ttexture: uniform.layoutType\r\n\t\t\t});\r\n\t\t} else if (uniform.isSampler) {\r\n\t\t\tlayoutEntity = new BindGroupLayoutEntry({\r\n\t\t\t\tbinding: uniform.binding,\r\n\t\t\t\tvisibility: uniform.visibility,\r\n\t\t\t\tsampler: uniform.layoutType\r\n\t\t\t});\r\n\t\t}\r\n\t\treturn layoutEntity;\r\n\t}\r\n\tprivate creayeOneGroupEntity(uniform) {\r\n\t\tlet groupEntity;\r\n\t\tif (uniform.isUniformBuffer) {\r\n\t\t\tgroupEntity = new BindGroupEntity({\r\n\t\t\t\tbinding: uniform.binding,\r\n\t\t\t\tresource: {\r\n\t\t\t\t\tbuffer: uniform.buffer.gpuBuffer,\r\n\t\t\t\t\toffset: uniform.offset,\r\n\t\t\t\t\tsize: uniform.bufferSize\r\n\t\t\t\t}\r\n\t\t\t});\r\n\t\t} else if (uniform.isTexture) {\r\n\t\t\tgroupEntity = new BindGroupEntity({\r\n\t\t\t\tbinding: uniform.binding,\r\n\t\t\t\tresource: uniform.texture.textureView\r\n\t\t\t});\r\n\t\t} else if (uniform.isSampler) {\r\n\t\t\tgroupEntity = new BindGroupEntity({\r\n\t\t\t\tbinding: uniform.binding,\r\n\t\t\t\tresource: uniform.sampler.gpuSampler\r\n\t\t\t});\r\n\t\t}\r\n\t\treturn groupEntity;\r\n\t}\r\n}\r\n","import { FrameState } from \"../core/FrameState\";\r\nimport { CullMode, PrimitiveTopology } from \"../core/WebGPUConstant\";\r\nimport Color from \"../math/Color\";\r\nimport { Mesh } from \"../mesh/Mesh\";\r\nimport { DepthStencil, RenderState, Target, Primitive } from \"../render/RenderState\";\r\nimport Sampler from \"../render/Sampler\";\r\nimport ShaderData from \"../render/ShaderData\";\r\nimport Texture from \"../render/Texture\";\r\nimport { ShaderSource } from \"../shader/ShaderSource\";\r\nexport class Material {\r\n\tpublic shaderData: ShaderData;\r\n\r\n\tcolor?: Color;\r\n\r\n\tbaseSampler?: Sampler;\r\n\r\n\tbaseTexture?: Texture;\r\n\r\n\ttype: string;\r\n\r\n\tlabel: string;\r\n\r\n\tshaderSource: ShaderSource;\r\n\r\n\ttransparent: boolean;\r\n\r\n\tdirty: boolean;\r\n\r\n\tlight: boolean;\r\n\r\n\tready: boolean;\r\n\r\n\tprivate _emissive: Color;\r\n\r\n\tprivate _opacity: number;\r\n\r\n\tprivate _emissiveIntensity: number;\r\n\r\n\tprivate _diffuse: Color;\r\n\r\n\tprivate _renderState: RenderState;\r\n\r\n\tprivate _doubleSided: boolean;\r\n\r\n\tconstructor() {\r\n\t\tthis.label = undefined;\r\n\t\tthis.type = undefined;\r\n\t\tthis.baseTexture = undefined;\r\n\t\tthis.baseSampler = undefined;\r\n\t\tthis._diffuse = new Color(0.0, 0.0, 0.0);\r\n\t\tthis._opacity = 1.0;\r\n\t\t// Buffer\r\n\t\tthis.shaderData = undefined;\r\n\t\tthis.shaderSource = undefined;\r\n\t\tthis.dirty = true;\r\n\t\tthis._emissive = new Color(0.0, 0.0, 0);\r\n\t\tthis._emissiveIntensity = 1.0;\r\n\t\tthis._doubleSided = true;\r\n\t\tthis.light = false;\r\n\t\tthis.ready = false;\r\n\t\tthis.init();\r\n\t}\r\n\tpublic set wireframe(value: boolean) {\r\n\t\tthis.renderState.primitive.topology = value ? PrimitiveTopology.LineList : PrimitiveTopology.TriangleList;\r\n\t}\r\n\tpublic get doubleSided() {\r\n\t\treturn this._doubleSided;\r\n\t}\r\n\tpublic set doubleSided(value: boolean) {\r\n\t\tthis._renderState.primitive.cullMode = value ? CullMode.None : CullMode.Back;\r\n\t\tthis._doubleSided = value;\r\n\t}\r\n\tpublic get renderState() {\r\n\t\treturn this._renderState;\r\n\t}\r\n\tpublic set renderState(value: RenderState) {\r\n\t\tthis._renderState = value;\r\n\t}\r\n\tpublic get diffuse(): Color {\r\n\t\treturn this._diffuse;\r\n\t}\r\n\tpublic set diffuse(v: Color) {\r\n\t\tthis._diffuse = v;\r\n\t}\r\n\tpublic get emissive(): Color {\r\n\t\treturn this._emissive;\r\n\t}\r\n\tpublic set emissive(v: Color) {\r\n\t\tthis._emissive = v;\r\n\t}\r\n\tpublic get emissiveIntensity(): number {\r\n\t\treturn this._emissiveIntensity;\r\n\t}\r\n\tpublic set emissiveIntensity(v: number) {\r\n\t\tthis._emissiveIntensity = v;\r\n\t}\r\n\tpublic get opacity(): number {\r\n\t\treturn this._opacity;\r\n\t}\r\n\tpublic set opacity(v: number) {\r\n\t\tthis._opacity = v;\r\n\t}\r\n\tonBeforeRender() {\r\n\t\t// callback\r\n\t}\r\n\r\n\tonBeforeCompile() {\r\n\t\t// callback\r\n\t}\r\n\tclone(): Material {\r\n\t\treturn null;\r\n\t}\r\n\tupdate(frameState?: FrameState, mesh?: Mesh) {\r\n\t\t// update material\r\n\t}\r\n\tprotected createShaderData() {\r\n\t\tif (this.shaderData) this.shaderData.destroy();\r\n\t\tthis.shaderData = new ShaderData(this.type, 0);\r\n\t\tthis.ready = true;\r\n\t}\r\n\tprivate init() {\r\n\t\t// 默认渲染状态\r\n\t\tconst primitive = new Primitive();\r\n\t\tconst target = new Target();\r\n\t\tconst depthStencil = new DepthStencil();\r\n\t\tthis._renderState = new RenderState();\r\n\t\tthis._renderState.primitive = primitive;\r\n\t\tthis._renderState.targets = [target];\r\n\t\tthis._renderState.depthStencil = depthStencil;\r\n\t}\r\n\tpublic destroy() {\r\n\t\tthis.label = undefined;\r\n\t\tthis.type = undefined;\r\n\t\tthis.baseTexture = undefined;\r\n\t\tthis.baseSampler = undefined;\r\n\t\tthis.color = undefined;\r\n\t}\r\n}\r\n","import { FrameState } from \"../core/FrameState\";\r\nimport { BufferBindingType, BufferUsage } from \"../core/WebGPUConstant\";\r\nimport { ShaderMaterialParms, Uniforms } from \"../core/WebGPUTypes\";\r\nimport { Mesh } from \"../mesh/Mesh\";\r\nimport UniformBuffer from \"../render/UniformBuffer\";\r\nimport { ShaderSource } from \"../shader/ShaderSource\";\r\nimport defaultValue from \"../utils/defaultValue\";\r\nimport { addUniformToShaderData, checkContainFloatType } from \"../utils/uniformUtils\";\r\nimport { Material } from \"./Material\";\r\n\r\nexport default class ShaderMaterial extends Material {\r\n\tuniforms: Uniforms;\r\n\tuniformBuffer: UniformBuffer;\r\n\tprivate shaderMaterialParms: ShaderMaterialParms;\r\n\tconstructor(options: ShaderMaterialParms) {\r\n\t\tsuper();\r\n\t\tconst { type, frag, vert, defines, light } = options;\r\n\t\tthis.type = type;\r\n\t\tthis.shaderMaterialParms = options;\r\n\t\tthis.shaderSource = new ShaderSource({\r\n\t\t\ttype,\r\n\t\t\tfrag,\r\n\t\t\tvert,\r\n\t\t\tcustom: true,\r\n\t\t\tdefines: defaultValue(defines, {}),\r\n\t\t\trender: true\r\n\t\t});\r\n\t\tthis.uniforms = options.uniforms;\r\n\t\tthis.uniformBuffer = undefined;\r\n\t\tthis.light = light || false;\r\n\t}\r\n\tupdate(frameState?: FrameState, mesh?: Mesh) {\r\n\t\tif (!this.shaderData || this.dirty) this.createShaderData(mesh);\r\n\t}\r\n\tclone() {\r\n\t\treturn new ShaderMaterial(this.shaderMaterialParms);\r\n\t}\r\n\tprotected createShaderData(mesh?: Mesh) {\r\n\t\tsuper.createShaderData();\r\n\t\tconst result = checkContainFloatType(this.uniforms);\r\n\t\tif (result.hasFloat) {\r\n\t\t\tthis.uniformBuffer = result.hasArraytype\r\n\t\t\t\t? new UniformBuffer({\r\n\t\t\t\t\t\tlabel: this.type + \"UniformBuffer\",\r\n\t\t\t\t\t\ttype: BufferBindingType.ReadOnlyStorage,\r\n\t\t\t\t\t\tusage: BufferUsage.Storage | BufferUsage.CopyDst\r\n\t\t\t\t  })\r\n\t\t\t\t: new UniformBuffer({ label: this.type + \"UniformBuffer\" });\r\n\t\t\tthis.shaderData.setUniformBuffer(this.type, this.uniformBuffer);\r\n\t\t}\r\n\t\tconst uniformsNames = Object.getOwnPropertyNames(this.uniforms);\r\n\t\tuniformsNames.map((uniformsName) => {\r\n\t\t\taddUniformToShaderData(\r\n\t\t\t\tuniformsName,\r\n\t\t\t\tthis.uniforms[uniformsName],\r\n\t\t\t\tthis.uniforms,\r\n\t\t\t\tthis.shaderData,\r\n\t\t\t\tmesh,\r\n\t\t\t\tthis.uniformBuffer\r\n\t\t\t);\r\n\t\t});\r\n\t}\r\n}\r\n","function createGuid() {\r\n  // http://stackoverflow.com/questions/105034/how-to-create-a-guid-uuid-in-javascript\r\n  return \"xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx\".replace(/[xy]/g, function (c) {\r\n    const r = (Math.random() * 16) | 0;\r\n    const v = c === \"x\" ? r : (r & 0x3) | 0x8;\r\n    return v.toString(16);\r\n  });\r\n}\r\nexport default createGuid;\r\n","import Camera from \"../camera/Camera\";\nimport { FrameState } from \"../core/FrameState\";\nimport LightManger from \"../core/LightManger\";\nimport RenderObject from \"../core/RenderObject\";\nimport { CommandSubType, Intersect } from \"../core/WebGPUConstant\";\nimport { RenderObjectType } from \"../core/WebGPUTypes\";\nimport Geometry from \"../geometry/Geometry\";\nimport { Material } from \"../material/Material\";\nimport DrawCommand from \"../render/DrawCommand\";\nimport createGuid from \"../utils/createGuid\";\nexport class Mesh extends RenderObject {\n\t[x: string]: any;\n\tuid: string;\n\tfrustumCull:boolean;\n\tsubCommands: { [prop: string]: DrawCommand };\n\tgeometry?: Geometry;\n\tmaterial?: Material;\n\tinstanceCount?: number;\n\tpriority?: number;\n\tdrawCommand?: DrawCommand;\n\tdistanceToCamera?: number; \n\tconstructor(geometry?: Geometry, material?: Material) {\n\t\tsuper();\n\t\tthis.geometry = geometry;\n\t\tthis.material = material;\n\t\tthis.type = RenderObjectType.Mesh;\n\t\tthis.frustumCull=true;\n\t\tthis.uid = createGuid();\n\t\tthis.subCommands = {};\n\t}\n\tget ready() {\n\t\treturn this.material.ready;\n\t}\n\tupdate(frameState: FrameState, camera?: Camera) {\n\t\t// update matrix\n\t\tthis.updateMatrix(this?.parent?.modelMatrix);\n\t\t// create\n\t\tthis.geometry.update(frameState);\n\t\tthis.material.update(frameState, this);\n\t\t// update boundingSphere\n\t\tthis.geometry.boundingSphere.update(this.modelMatrix);\n\t\tthis.material.shaderSource.setDefines(frameState.defines);\n\t\tif (this.type == RenderObjectType.Debug) {\n\t\t\tframeState.renderQueue.debugQueue.push(this);\n\t\t\treturn;\n\t\t}\n\t\tthis.distanceToCamera = this.geometry.boundingSphere.distanceToCamera(camera);\n\n\t\tconst visibility = frameState.cullingVolume.computeVisibility(this.geometry.boundingSphere);\n\t\t// 视锥剔除\n\t\tif (visibility === Intersect.OUTSIDE) return;\n\t\tif (this.material.transparent) {\n\t\t\tframeState.renderQueue.transparent.push(this);\n\t\t} else {\n\t\t\tframeState.renderQueue.opaque.push(this);\n\t\t}\n\t}\n\tbeforeRender() {\n\t\t// before render\n\t}\n\tafterRender() {\n\t\t// after render\n\t}\n\tpublic getDrawCommand(overrideMaterial?: Material, commandSubType?: CommandSubType, lightManger?: LightManger) {\n\t\tif (!this.drawCommand || this.material.dirty) {\n\t\t\tthis.material.shaderSource.setDefines(\n\t\t\t\tObject.assign({},this.material.shaderData.defines, this.geometry.defines)\n\t\t\t);\n\t\t\tif (this.material.dirty) this.material.dirty = false;\n\t\t\tthis.drawCommand = new DrawCommand({\n\t\t\t\tvertexBuffer: this.geometry.vertBuffer,\n\t\t\t\tindexBuffer: this.geometry.indexBuffer,\n\t\t\t\tshaderData: this.material.shaderData,\n\t\t\t\tinstances: this.instanceCount,\n\t\t\t\tcount: this.geometry.count,\n\t\t\t\trenderState: this.material.renderState,\n\t\t\t\tshaderSource: this.material.shaderSource,\n\t\t\t\ttype: \"render\",\n\t\t\t\tlight: this.material.light,\n\t\t\t\tmodelMatrix: this.modelMatrix,\n\t\t\t\tlightShaderData: this.material.light ? lightManger?.lightShaderData : undefined\n\t\t\t});\n\t\t}\n\t\tif (overrideMaterial) {\n\t\t\tif (!this.subCommands[commandSubType]) {\n\t\t\t\tconst copyMat = overrideMaterial.clone();\n\t\t\t\tcopyMat.update(undefined,this);\n\t\t\t\tif (copyMat.dirty) copyMat.dirty = false;\n\t\t\t\tthis.subCommands[commandSubType] = this.drawCommand.shallowClone(copyMat);\n\t\t\t}\n\t\t\treturn this.subCommands[commandSubType];\n\t\t}\n\t\treturn this.drawCommand;\n\t}\n\tdestroy() {\n\t\tthis.geometry.destroy();\n\t\tthis.material.destroy();\n\t}\n}\n","import { RenderObjectType } from \"../core/WebGPUTypes\";\r\nimport Geometry from \"../geometry/Geometry\";\r\nimport PlaneGeometry from \"../geometry/PlaneGeometry\";\r\nimport { Light } from \"../light/Light\";\r\nimport ShaderMaterial from \"../material/ShaderMaterial\";\r\nimport { Mesh } from \"../mesh/Mesh\";\r\nimport { ViewPort } from \"../render/RenderState\";\r\nimport Sampler from \"../render/Sampler\";\r\nimport { Scene } from \"../Scene\";\r\nimport getVertFrag from \"../shader/Shaders\";\r\n\r\nexport class ShadowMapDebugger {\r\n\tprivate mesh: Mesh;\r\n\tprivate debuggerSize: { width: number; height: number };\r\n\tpublic light: Light;\r\n\tprivate geometry: Geometry;\r\n\tprivate material: ShaderMaterial;\r\n\tprivate scene: Scene;\r\n\r\n\tconstructor(light: Light, scene: Scene) {\r\n\t\tif (!light || !(light instanceof Light)) throw new Error(\"The parameter must be Light instance\");\r\n\r\n\t\tthis.light = light;\r\n\t\tthis.scene = scene;\r\n\t\tthis.debuggerSize = {\r\n\t\t\twidth: 256,\r\n\t\t\theight: 256\r\n\t\t};\r\n\r\n\t\tthis.mesh = this._createShadowMapMesh();\r\n\t\tconst shadowMap = this.light.shadow.getShadowMapTexture();\r\n\t\tthis.material.uniforms.texture.value = shadowMap;\r\n\t\tthis.mesh.type = RenderObjectType.Debug;\r\n\t\tthis.scene.add(this.mesh);\r\n\t}\r\n\r\n\t_createShadowMapMesh() {\r\n\t\tconst shader = getVertFrag(\"shadowMapDebugger\", {\r\n\t\t\tpositionLocation: 0\r\n\t\t});\r\n\t\tthis.geometry = new PlaneGeometry(2, 2);\r\n\t\tthis.material = new ShaderMaterial({\r\n\t\t\ttype: \"shadowMapDebugger\",\r\n\t\t\tfrag: shader.frag,\r\n\t\t\tvert: shader.vert,\r\n\t\t\tuniforms: {\r\n\t\t\t\ttexture: {\r\n\t\t\t\t\ttype: \"texture\",\r\n\t\t\t\t\tvalue: undefined\r\n\t\t\t\t},\r\n\t\t\t\tsampler: {\r\n\t\t\t\t\ttype: \"sampler\",\r\n\t\t\t\t\tvalue: new Sampler({\r\n\t\t\t\t\t\tmagFilter: \"linear\",\r\n\t\t\t\t\t\tminFilter: \"linear\"\r\n\t\t\t\t\t})\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t});\r\n\t\tthis.material.renderState.viewport = new ViewPort(0, 0, this.debuggerSize.width, this.debuggerSize.height);\r\n\t\treturn new Mesh(this.geometry, this.material);\r\n\t}\r\n\r\n\tsetSize(width: number, height: number) {\r\n\t\tif (!width || !height) return;\r\n\t\tthis.debuggerSize.width = width;\r\n\t\tthis.debuggerSize.height = height;\r\n\t\tthis.update();\r\n\t}\r\n\r\n\tupdate() {\r\n\t\tthis.material.renderState.viewport = new ViewPort(0, 0, this.debuggerSize.width, this.debuggerSize.height);\r\n\t}\r\n}\r\n","import { FrameState } from \"../core/FrameState\";\nimport { Mesh } from \"../mesh/Mesh\";\nimport UniformBuffer from \"../render/UniformBuffer\";\nimport { UniformEnum } from \"../render/Uniforms\";\nimport { ShaderSource } from \"../shader/ShaderSource\";\nimport { Material } from \"./Material\";\nexport default class ColorMaterial extends Material {\n\tconstructor() {\n\t\tsuper();\n\t\tthis.type = \"color\";\n\t\tthis.shaderSource = new ShaderSource({\n\t\t\ttype: this.type,\n\t\t\trender: true,\n\t\t\tdefines: {}\n\t\t});\n\t}\n\tupdate(frameState?: FrameState, mesh?: Mesh) {\n\t\tif (!this.shaderData || this.dirty) this.createShaderData();\n\t\tconst uniformBuffer = new UniformBuffer({ label: \"color\" });\n\t\tuniformBuffer.setUniform(\n\t\t\t\"modelMatrix\",\n\t\t\t() => {\n\t\t\t\treturn mesh.modelMatrix;\n\t\t\t},\n\t\t\tUniformEnum.Mat4\n\t\t);\n\t\tthis.shaderData.setUniformBuffer(\"color\", uniformBuffer);\n\t}\n}\n","import { FrameState } from \"../core/FrameState\";\r\nimport { RenderObjectType } from \"../core/WebGPUTypes\";\r\nimport Geometry from \"../geometry/Geometry\";\r\nimport ColorMaterial from \"../material/ColorMaterial\";\r\nimport { Float32Attribute } from \"../render/Attribute\";\r\nimport { Mesh } from \"./Mesh\";\r\nexport default class Axes extends Mesh {\r\n\tmaterial: ColorMaterial;\r\n\tconstructor() {\r\n\t\tsuper();\r\n\t\tthis.type = RenderObjectType.Axes;\r\n\t\tthis.distanceToCamera = 10;\r\n\t\tthis.material = new ColorMaterial();\r\n\t\tthis.material.wireframe = true;\r\n\t\tthis.init();\r\n\t}\r\n\tupdate(frameState: FrameState) {\r\n\t\tthis.updateMatrix();\r\n\t\tthis.material.update(frameState, this);\r\n\t\tframeState.renderQueue.opaque.push(this);\r\n\t}\r\n\tprivate init() {\r\n\t\tconst position = [0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1];\r\n\t\tconst colors = [1, 0, 0, 1, 1, 0.5, 0.5, 1, 0, 1, 0, 1, 0.5, 1, 0.5, 1, 0, 0, 1, 1, 0.5, 0.5, 1, 1];\r\n\t\tconst indices = [0, 1, 2, 3, 4, 5];\r\n\t\tthis.geometry = new Geometry({});\r\n\t\tthis.geometry.setAttribute(new Float32Attribute(\"position\", position, 3));\r\n\t\tthis.geometry.setAttribute(new Float32Attribute(\"color\", colors, 4));\r\n\t\tthis.geometry.setIndice(indices);\r\n\t\tthis.geometry.count = indices.length;\r\n\t}\r\n}\r\n","import { Float32Attribute } from \"../render/Attribute\";\r\nimport Geometry from \"./Geometry\";\r\nexport default class SkyBoxGeometry extends Geometry {\r\n\tconstructor() {\r\n\t\tsuper({\r\n\t\t\ttype: \"skyBoxGeometry\"\r\n\t\t});\r\n\t\tthis.init();\r\n\t}\r\n\tpublic update(frameState) {\r\n\t\tconst { device } = frameState.context;\r\n\t}\r\n\tpublic init() {\r\n\t\tconst positions = [\r\n\t\t\t1.0,\r\n\t\t\t1.0,\r\n\t\t\t1.0, // 0\r\n\t\t\t-1.0,\r\n\t\t\t1.0,\r\n\t\t\t1.0, // 1\r\n\t\t\t1.0,\r\n\t\t\t-1.0,\r\n\t\t\t1.0, // 2\r\n\t\t\t-1.0,\r\n\t\t\t-1.0,\r\n\t\t\t1.0, // 3\r\n\t\t\t1.0,\r\n\t\t\t1.0,\r\n\t\t\t-1.0, // 4\r\n\t\t\t-1.0,\r\n\t\t\t1.0,\r\n\t\t\t-1.0, // 5\r\n\t\t\t1.0,\r\n\t\t\t-1.0,\r\n\t\t\t-1.0, // 6\r\n\t\t\t-1.0,\r\n\t\t\t-1.0,\r\n\t\t\t-1.0 // 7\r\n\t\t];\r\n\t\tconst indices = [\r\n\t\t\t// PosX (Right)\r\n\t\t\t0, 2, 4, 6, 4, 2,\r\n\r\n\t\t\t// NegX (Left)\r\n\t\t\t5, 3, 1, 3, 5, 7,\r\n\r\n\t\t\t// PosY (Top)\r\n\t\t\t4, 1, 0, 1, 4, 5,\r\n\r\n\t\t\t// NegY (Bottom)\r\n\t\t\t2, 3, 6, 7, 6, 3,\r\n\r\n\t\t\t// PosZ (Front)\r\n\t\t\t0, 1, 2, 3, 2, 1,\r\n\r\n\t\t\t// NegZ (Back)\r\n\t\t\t6, 5, 4, 5, 6, 7\r\n\t\t];\r\n\t\tthis.setAttribute(new Float32Attribute(\"position\", positions, 3));\r\n\t\tthis.setIndice(indices);\r\n\t\tthis.count = indices.length;\r\n\t}\r\n}\r\n","function returnTrue() {\r\n\treturn true;\r\n}\r\nexport function destroyObject(object) {\r\n\t// message =message||\"This object was destroyed, i.e., destroy() was called.\";\r\n\r\n\tfunction throwOnDestroyed() {\r\n\t\tthrow new Error(\"This object was destroyed, i.e., destroy() was called.\");\r\n\t}\r\n\r\n\tfor (const key in object) {\r\n\t\tif (typeof object[key] === \"function\") {\r\n\t\t\tobject[key] = throwOnDestroyed;\r\n\t\t}\r\n\t}\r\n\r\n\tobject.isDestroyed = returnTrue;\r\n\r\n\treturn undefined;\r\n}\r\n","import Sampler from \"../render/Sampler\";\nimport Texture from \"../render/Texture\";\nimport defined from \"../utils/defined\";\nimport { destroyObject } from \"../utils/destroyObject\";\ntype TextureCacheProp = {\n\ttexture: Texture;\n\tcount: number;\n};\nclass TextureCache {\n\tpublic defaultSampler: Sampler;\n\tprivate _numberOfTextures: number;\n\tprivate _textures: Map<string, TextureCacheProp>;\n\tprivate _texturesToRelease: Map<string, TextureCacheProp>;\n\tconstructor() {\n\t\tthis._numberOfTextures = 0;\n\t\tthis._textures = new Map();\n\t\tthis._numberOfTextures = 0;\n\t\tthis._texturesToRelease = new Map();\n\t\tthis.defaultSampler = new Sampler({\n\t\t\tmagFilter: \"linear\",\n\t\t\tminFilter: \"linear\",\n\t\t\taddressModeU: \"repeat\",\n\t\t\taddressModeV: \"repeat\"\n\t\t});\n\t}\n\tget numberOfTextures(): number {\n\t\treturn this._numberOfTextures;\n\t}\n\tgetTexture(keyword) {\n\t\tconst cachedTexture = this._textures.get(keyword);\n\t\tif (!defined(cachedTexture)) {\n\t\t\treturn undefined;\n\t\t}\n\t\t// No longer want to release this if it was previously released.\n\t\tdelete this._texturesToRelease[keyword];\n\n\t\t++cachedTexture.count;\n\t\treturn cachedTexture.texture;\n\t}\n\taddTexture(keyword, texture) {\n\t\tconst cachedTexture = {\n\t\t\ttexture: texture,\n\t\t\tcount: 1\n\t\t};\n\n\t\ttexture.finalDestroy = texture.destroy;\n\n\t\t// const that = this;\n\t\ttexture.destroy = () => {\n\t\t\tif (--cachedTexture.count === 0) {\n\t\t\t\tthis._texturesToRelease.set(keyword, cachedTexture);\n\t\t\t}\n\t\t};\n\n\t\tthis._textures.set(keyword, cachedTexture);\n\t\t++this._numberOfTextures;\n\t}\n\treleasedTextures() {\n\t\tthis._texturesToRelease.forEach((cacheTexture) => {\n\t\t\tcacheTexture.texture?.finalDestroy();\n\t\t\t--this._numberOfTextures;\n\t\t});\n\n\t\tthis._texturesToRelease.clear();\n\t}\n\tdestroy() {\n\t\tthis._textures.forEach((cachedTexture) => {\n\t\t\tcachedTexture.texture?.finalDestroy();\n\t\t});\n\t\treturn destroyObject(this);\n\t}\n}\nconst textureCache = new TextureCache();\nexport default textureCache;\n","import Sampler from \"../render/Sampler\";\nimport Texture from \"../render/Texture\";\n\nexport default async function CubeTextureLoader(urls) {\n\tconst promises = urls.map((src) => {\n\t\tconst img = document.createElement(\"img\");\n\t\timg.src = src;\n\t\treturn img.decode().then(() => createImageBitmap(img));\n\t});\n\tconst images = await Promise.all(promises);\n\tawait Promise.all(images);\n\tconst baseSampler = new Sampler({\n\t\tmagFilter: \"linear\",\n\t\tminFilter: \"linear\"\n\t});\n\tconst data = images.map((image, i) => {\n\t\treturn {\n\t\t\tsource: image,\n\t\t\twidth: image.width,\n\t\t\theight: image.height,\n\t\t\tdepth: 1,\n\t\t\tx: 0,\n\t\t\ty: 0,\n\t\t\tz: i\n\t\t};\n\t});\n\tconst baseTexture = new Texture({\n\t\tsize: {\n\t\t\twidth: images[0].width,\n\t\t\theight: images[0].height,\n\t\t\tdepth: 6\n\t\t},\n\t\tformat: \"rgba8unorm\",\n\t\tusage: GPUTextureUsage.TEXTURE_BINDING | GPUTextureUsage.COPY_DST | GPUTextureUsage.RENDER_ATTACHMENT,\n\t\tsampler: baseSampler,\n\t\tdata,\n\t\tviewFormats: \"cube\",\n\t\tmipLevelCount: 6,\n\t\tneedMipMap: true\n\t});\n\treturn {\n\t\ttexture: baseTexture,\n\t\tsampler: baseSampler\n\t};\n}\n","import { FrameState } from \"../core/FrameState\";\r\nimport textureCache from \"../core/TextureCache\";\r\nimport { CompareFunction } from \"../core/WebGPUConstant\";\r\nimport CubeTextureLoader from \"../loader/CubeTextureLoader\";\r\nimport { Mesh } from \"../mesh/Mesh\";\r\nimport UniformBuffer from \"../render/UniformBuffer\";\r\nimport { UniformEnum } from \"../render/Uniforms\";\r\nimport { ShaderSource } from \"../shader/ShaderSource\";\r\nimport { Material } from \"./Material\";\r\nexport default class SkyBoxMaterial extends Material {\r\n\tloadFish: boolean;\r\n\tconstructor() {\r\n\t\tsuper();\r\n\t\tthis.type = \"skybox\";\r\n\t\tthis.shaderSource = new ShaderSource({\r\n\t\t\ttype: this.type,\r\n\t\t\trender: true,\r\n\t\t\tdefines: {}\r\n\t\t});\r\n\t\tthis.loadFish = false;\r\n\t\tthis.renderState.depthStencil.depthWriteEnabled = false;\r\n\t\tthis.renderState.depthStencil.depthCompare = CompareFunction.LessEqual;\r\n\t}\r\n\tasync loadTexture(urls) {\r\n\t\tconst result = await CubeTextureLoader(urls);\r\n\t\tthis.loadFish = true;\r\n\t\ttextureCache.addTexture(\"specular\", result.texture);\r\n\t\tthis.baseTexture = result.texture;\r\n\t\tthis.baseSampler = result.sampler;\r\n\t}\r\n\tupdate(frameState?: FrameState, mesh?: Mesh) {\r\n\t\tif (!this.loadFish) return;\r\n\t\tif (!this.shaderData) {\r\n\t\t\tthis.createShaderData(mesh);\r\n\t\t}\r\n\t}\r\n\tprotected createShaderData(mesh?: Mesh) {\r\n\t\tsuper.createShaderData();\r\n\t\tconst uniformBuffer = new UniformBuffer({ label: \"skybox\" });\r\n\t\tuniformBuffer.setUniform(\r\n\t\t\t\"modelMatrix\",\r\n\t\t\t() => {\r\n\t\t\t\treturn mesh.modelMatrix;\r\n\t\t\t},\r\n\t\t\tUniformEnum.Mat4\r\n\t\t);\r\n\t\tthis.shaderData.setUniformBuffer(\"skybox\", uniformBuffer);\r\n\t\tthis.shaderData.setTexture(\"baseTexture\", this.baseTexture);\r\n\t\tthis.shaderData.setSampler(\"baseSampler\", this.baseSampler);\r\n\t}\r\n}\r\n","import { FrameState } from \"../core/FrameState\";\r\nimport { RenderObjectType } from \"../core/WebGPUTypes\";\r\nimport SkyBoxGeometry from \"../geometry/SkyBoxGeometry\";\r\nimport SkyBoxMaterial from \"../material/SkyBoxMaterial\";\r\nimport { Mesh } from \"./Mesh\";\r\nexport default class SkyBox extends Mesh {\r\n\tmaterial: SkyBoxMaterial;\r\n\tpublic visibility: boolean;\r\n\tconstructor(urls?: Array<string>) {\r\n\t\tsuper();\r\n\t\tthis.type = RenderObjectType.Skybox;\r\n\t\tthis.visibility = true;\r\n\t\tthis.material = new SkyBoxMaterial();\r\n\t\tif (urls) this.material.loadTexture(urls);\r\n\t\tthis.geometry = new SkyBoxGeometry();\r\n\t\tthis.isSkyBox = true;\r\n\t}\r\n\tupdate(frameState: FrameState) {\r\n\t\tthis.updateMatrix();\r\n\t\tthis.geometry.update(frameState);\r\n\t\tthis.material.update(frameState, this);\r\n\t\tif (this.visibility) frameState.renderQueue.pre.push(this);\r\n\t}\r\n}\r\n","import RenderObject from \"../core/RenderObject\";\nimport Matrix4 from \"../math/Matrix4\";\nimport createGuid from \"../utils/createGuid\";\n\nexport class Instance extends RenderObject {\n\tpublic id: string | number;\n\tpublic visiblity: boolean;\n\tprivate _notUpdateMatrix: boolean;\n\tconstructor() {\n\t\tsuper();\n\t\tthis._notUpdateMatrix = false;\n\t\tthis.visiblity = false;\n\t\tthis.id = createGuid();\n\t}\n\tsetMatrix4(mat4: Matrix4) {\n\t\tthis.modelMatrix.set(mat4);\n\t\tthis._notUpdateMatrix = true;\n\t}\n\tupdateMatrix(matrix?: Matrix4) {\n\t\tif (this._notUpdateMatrix) return;\n\t\tsuper.updateMatrix(matrix);\n\t}\n}\n","import Camera from \"../camera/Camera\";\nimport { FrameState } from \"../core/FrameState\";\nimport { BufferBindingType, BufferUsage, Intersect } from \"../core/WebGPUConstant\";\nimport Geometry from \"../geometry/Geometry\";\nimport { Material } from \"../material/Material\";\nimport UniformBuffer from \"../render/UniformBuffer\";\nimport { UniformEnum } from \"../render/Uniforms\";\nimport { Instance } from \"./Instance\";\nimport { Mesh } from \"./Mesh\";\n\nexport class InstanceMesh extends Mesh {\n\tprivate instances: Map<string | number, Instance>;\n\tprivate renderInstances: Array<Instance>;\n\tprivate hasAddInstances: boolean; \n\tconstructor(geo: Geometry, mat: Material) {\n\t\tsuper(geo, mat);\n\t\tthis.instances = new Map();\n\t\tthis.renderInstances = [];\n\t\tthis.hasAddInstances = false;\n\t}\n\tupdate(frameState: FrameState, camera?: Camera) {\n\t\t// update instances visiblity\n\t\tthis.checkInstancesVisiblity({ frameState, camera });\n\t\tthis.geometry.update(frameState);\n\t\tthis.material.update(frameState, this);\n\t\tif (!this.hasAddInstances) this.addUniformsToMaterial();\n\t\tthis.instanceCount = this.renderInstances.length;\n\t\tif (this.renderInstances.length < 1) return;\n\t\tif (this.material.transparent) {\n\t\t\tframeState.renderQueue.transparent.push(this);\n\t\t} else {\n\t\t\tframeState.renderQueue.opaque.push(this);\n\t\t}\n\t}\n\taddInstance(instance: Instance) {\n\t\tif (this.instances.get(instance.id)) return;\n\t\tthis.instances.set(instance.id, instance);\n\t}\n\tremoveInstance(key: number | string) {\n\t\treturn this.instances.delete(key);\n\t}\n\tgetInstance(key: number | string) {\n\t\treturn this.instances.get(key);\n\t}\n\tprivate checkInstancesVisiblity(options: { frameState: FrameState; camera: Camera }) {\n\t\tconst { frameState, camera } = options;\n\t\tconst preFrameInstanceCount=this.renderInstances.length;\n\t\tthis.renderInstances=[];\n\t\tthis.instances.forEach((instance: Instance) => {\n\t\t\tinstance.updateMatrix(this?.parent?.modelMatrix);\n\t\t\tinstance.visiblity = this.getInstanceVisiblity({ instance, frameState, camera });\n\t\t\tif (instance.visiblity) this.renderInstances.push(instance);\n\t\t});\n\t\tthis.material.dirty=this.renderInstances.length===preFrameInstanceCount;\n\t\t// rebuild instanceMatrixsBuffer\n\t\tif(this.material.dirty) this.hasAddInstances=false;\n\t}\n\tprivate getInstanceVisiblity(options: { instance: Instance; frameState: FrameState; camera: Camera }): boolean {\n\t\tconst { instance, frameState, camera } = options;\n\t\tthis.geometry.boundingSphere.update(instance.modelMatrix);\n\t\tthis.distanceToCamera = this.geometry.boundingSphere.distanceToCamera(camera);\n\t\tconst visibility = frameState.cullingVolume.computeVisibility(this.geometry.boundingSphere);\n\t\treturn visibility === Intersect.INTERSECTING || visibility === Intersect.INSIDE;\n\t}\n\tprivate addUniformsToMaterial() {\n\t\tif (!this.material.shaderData) return;\n\t\tthis.hasAddInstances = true;\n\t\tconst instanceMatrixsBuffer = new UniformBuffer({\n\t\t\tlabel: \"instanceMatrixsBuffer\",\n\t\t\ttype: BufferBindingType.ReadOnlyStorage,\n\t\t\tusage: BufferUsage.Storage | BufferUsage.CopyDst,\n\t\t\tsize: this.instances.size * 64\n\t\t});\n\t\tinstanceMatrixsBuffer.setUniform(\n\t\t\t\"instanceMatrixs\",\n\t\t\t() => {\n\t\t\t\treturn this?.renderInstances?.map((renderInstance: Instance) => renderInstance.modelMatrix);\n\t\t\t},\n\t\t\tUniformEnum.Mat4Array,\n\t\t\tthis?.renderInstances?.length\n\t\t);\n\t\tthis.material.shaderData.setUniformBuffer(\"instanceMatrixsBuffer\", instanceMatrixsBuffer);\n\t\tthis.material.shaderData.setDefine(\"USE_INSTANCE\", true);\n\t\tthis.material.shaderData.setDefine(\"instanceCount\", this?.renderInstances?.length);\n\t}\n}\n","/**\r\n * Ensure first argument passed to the primitive functions is an object\r\n * @param {...*} args\r\n */\r\nfunction checkArguments(args) {\r\n\tconst argumentType = typeof args[0];\r\n\tif (argumentType !== \"object\" && argumentType !== \"undefined\") {\r\n\t\tconsole.error(\"First argument must be an object.\");\r\n\t}\r\n}\r\n\r\n/**\r\n * @private\r\n */\r\nlet TYPED_ARRAY_TYPE;\r\n\r\n/**\r\n * Select cells typed array from a size determined by amount of vertices.\r\n *\r\n * @param {number} size The max value expected\r\n * @returns {(Uint8Array|Uint16Array|Uint32Array)}\r\n * @see [MDN TypedArray objects]{@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/TypedArray#typedarray_objects}\r\n */\r\nconst getCellsTypedArray = (size) =>\r\n\tTYPED_ARRAY_TYPE || (size <= 255 ? Uint8Array : size <= 65535 ? Uint16Array : Uint32Array);\r\n\r\n/**\r\n * @private\r\n */\r\nconst PLANE_DIRECTIONS = {\r\n\tz: [0, 1, 2, 1, -1, 1],\r\n\t\"-z\": [0, 1, 2, -1, -1, -1],\r\n\t\"-x\": [2, 1, 0, 1, -1, -1],\r\n\tx: [2, 1, 0, -1, -1, 1],\r\n\ty: [0, 2, 1, 1, 1, 1],\r\n\t\"-y\": [0, 2, 1, 1, -1, -1]\r\n};\r\n\r\n/**\r\n * @private\r\n */\r\nfunction computePlane(\r\n\tgeometry,\r\n\tindices,\r\n\tsu,\r\n\tsv,\r\n\tnu,\r\n\tnv,\r\n\tdirection = \"z\",\r\n\tpw = 0,\r\n\tquads = false,\r\n\tuvScale = [1, 1],\r\n\tuvOffset = [0, 0],\r\n\tcenter = [0, 0, 0],\r\n\tccw = true\r\n) {\r\n\tconst { positions, normals, uvs, cells } = geometry;\r\n\tconst [u, v, w, flipU, flipV, normal] = PLANE_DIRECTIONS[direction];\r\n\r\n\tconst vertexOffset = indices.vertex;\r\n\r\n\tfor (let j = 0; j <= nv; j++) {\r\n\t\tfor (let i = 0; i <= nu; i++) {\r\n\t\t\tpositions[indices.vertex * 3 + u] = (-su / 2 + (i * su) / nu) * flipU + center[u];\r\n\t\t\tpositions[indices.vertex * 3 + v] = (-sv / 2 + (j * sv) / nv) * flipV + center[v];\r\n\t\t\tpositions[indices.vertex * 3 + w] = pw + center[w];\r\n\r\n\t\t\tnormals[indices.vertex * 3 + w] = normal;\r\n\r\n\t\t\tuvs[indices.vertex * 2] = (i / nu) * uvScale[0] + uvOffset[0];\r\n\t\t\tuvs[indices.vertex * 2 + 1] = (1 - j / nv) * uvScale[1] + uvOffset[1];\r\n\r\n\t\t\tindices.vertex++;\r\n\r\n\t\t\tif (j < nv && i < nu) {\r\n\t\t\t\tconst n = vertexOffset + j * (nu + 1) + i;\r\n\t\t\t\tif (quads) {\r\n\t\t\t\t\tconst o = vertexOffset + (j + 1) * (nu + 1) + i;\r\n\t\t\t\t\tcells[indices.cell] = n;\r\n\t\t\t\t\tcells[indices.cell + 1] = o;\r\n\t\t\t\t\tcells[indices.cell + 2] = o + 1;\r\n\t\t\t\t\tcells[indices.cell + 3] = n + 1;\r\n\t\t\t\t} else {\r\n\t\t\t\t\tcells[indices.cell] = n;\r\n\t\t\t\t\tcells[indices.cell + (ccw ? 1 : 2)] = n + nu + 1;\r\n\t\t\t\t\tcells[indices.cell + (ccw ? 2 : 1)] = n + nu + 2;\r\n\r\n\t\t\t\t\tcells[indices.cell + 3] = n;\r\n\t\t\t\t\tcells[indices.cell + (ccw ? 4 : 5)] = n + nu + 2;\r\n\t\t\t\t\tcells[indices.cell + (ccw ? 5 : 4)] = n + 1;\r\n\t\t\t\t}\r\n\t\t\t\tindices.cell += quads ? 4 : 6;\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\r\n\treturn geometry;\r\n}\r\n/**\r\n * @typedef {Object} CubeOptions\r\n * @property {number} [sx=1]\r\n * @property {number} [sy=sx]\r\n * @property {number} [sz=sx]\r\n * @property {number} [nx=1]\r\n * @property {number} [ny=nx]\r\n * @property {number} [nz=nx]\r\n */\r\nexport function createCube({ sx = 1, sy = 1, sz = 1, nx = 1, ny = 1, nz = 1 } = {}) {\r\n\tcheckArguments(arguments);\r\n\r\n\tconst size = (nx + 1) * (ny + 1) * 2 + (nx + 1) * (nz + 1) * 2 + (nz + 1) * (ny + 1) * 2;\r\n\r\n\tconst geometry = {\r\n\t\tpositions: new Float32Array(size * 3),\r\n\t\tnormals: new Float32Array(size * 3),\r\n\t\tuvs: new Float32Array(size * 2),\r\n\t\tcells: new (getCellsTypedArray(size))((nx * ny * 2 + nx * nz * 2 + nz * ny * 2) * 6)\r\n\t};\r\n\r\n\tconst halfSX = sx * 0.5;\r\n\tconst halfSY = sy * 0.5;\r\n\tconst halfSZ = sz * 0.5;\r\n\r\n\tconst indices = { vertex: 0, cell: 0 };\r\n\r\n\tcomputePlane(geometry, indices, sx, sy, nx, ny, \"z\", halfSZ);\r\n\tcomputePlane(geometry, indices, sx, sy, nx, ny, \"-z\", -halfSZ);\r\n\tcomputePlane(geometry, indices, sz, sy, nz, ny, \"-x\", -halfSX);\r\n\tcomputePlane(geometry, indices, sz, sy, nz, ny, \"x\", halfSX);\r\n\tcomputePlane(geometry, indices, sx, sz, nx, nz, \"y\", halfSY);\r\n\tcomputePlane(geometry, indices, sx, sz, nx, nz, \"-y\", -halfSY);\r\n\r\n\treturn geometry;\r\n}\r\n\r\nexport function createBox(options) {\r\n\toptions = options || {};\r\n\r\n\tconst dimensions = options.dimensions || [1, 1, 1];\r\n\tconst position = options.position || [-dimensions[0] / 2, -dimensions[1] / 2, -dimensions[2] / 2];\r\n\tconst x = position[0];\r\n\tconst y = position[1];\r\n\tconst z = position[2];\r\n\tconst width = dimensions[0];\r\n\tconst height = dimensions[1];\r\n\tconst depth = dimensions[2];\r\n\r\n\tconst fbl = { x: x, y: y, z: z + depth };\r\n\tconst fbr = { x: x + width, y: y, z: z + depth };\r\n\tconst ftl = { x: x, y: y + height, z: z + depth };\r\n\tconst ftr = { x: x + width, y: y + height, z: z + depth };\r\n\tconst bbl = { x: x, y: y, z: z };\r\n\tconst bbr = { x: x + width, y: y, z: z };\r\n\tconst btl = { x: x, y: y + height, z: z };\r\n\tconst btr = { x: x + width, y: y + height, z: z };\r\n\r\n\tconst positions = [\r\n\t\t// front\r\n\t\tfbl.x,\r\n\t\tfbl.y,\r\n\t\tfbl.z,\r\n\t\tfbr.x,\r\n\t\tfbr.y,\r\n\t\tfbr.z,\r\n\t\tftl.x,\r\n\t\tftl.y,\r\n\t\tftl.z,\r\n\t\tftl.x,\r\n\t\tftl.y,\r\n\t\tftl.z,\r\n\t\tfbr.x,\r\n\t\tfbr.y,\r\n\t\tfbr.z,\r\n\t\tftr.x,\r\n\t\tftr.y,\r\n\t\tftr.z,\r\n\r\n\t\t// right\r\n\t\tfbr.x,\r\n\t\tfbr.y,\r\n\t\tfbr.z,\r\n\t\tbbr.x,\r\n\t\tbbr.y,\r\n\t\tbbr.z,\r\n\t\tftr.x,\r\n\t\tftr.y,\r\n\t\tftr.z,\r\n\t\tftr.x,\r\n\t\tftr.y,\r\n\t\tftr.z,\r\n\t\tbbr.x,\r\n\t\tbbr.y,\r\n\t\tbbr.z,\r\n\t\tbtr.x,\r\n\t\tbtr.y,\r\n\t\tbtr.z,\r\n\r\n\t\t// back\r\n\t\tfbr.x,\r\n\t\tbbr.y,\r\n\t\tbbr.z,\r\n\t\tbbl.x,\r\n\t\tbbl.y,\r\n\t\tbbl.z,\r\n\t\tbtr.x,\r\n\t\tbtr.y,\r\n\t\tbtr.z,\r\n\t\tbtr.x,\r\n\t\tbtr.y,\r\n\t\tbtr.z,\r\n\t\tbbl.x,\r\n\t\tbbl.y,\r\n\t\tbbl.z,\r\n\t\tbtl.x,\r\n\t\tbtl.y,\r\n\t\tbtl.z,\r\n\r\n\t\t// left\r\n\t\tbbl.x,\r\n\t\tbbl.y,\r\n\t\tbbl.z,\r\n\t\tfbl.x,\r\n\t\tfbl.y,\r\n\t\tfbl.z,\r\n\t\tbtl.x,\r\n\t\tbtl.y,\r\n\t\tbtl.z,\r\n\t\tbtl.x,\r\n\t\tbtl.y,\r\n\t\tbtl.z,\r\n\t\tfbl.x,\r\n\t\tfbl.y,\r\n\t\tfbl.z,\r\n\t\tftl.x,\r\n\t\tftl.y,\r\n\t\tftl.z,\r\n\r\n\t\t// top\r\n\t\tftl.x,\r\n\t\tftl.y,\r\n\t\tftl.z,\r\n\t\tftr.x,\r\n\t\tftr.y,\r\n\t\tftr.z,\r\n\t\tbtl.x,\r\n\t\tbtl.y,\r\n\t\tbtl.z,\r\n\t\tbtl.x,\r\n\t\tbtl.y,\r\n\t\tbtl.z,\r\n\t\tftr.x,\r\n\t\tftr.y,\r\n\t\tftr.z,\r\n\t\tbtr.x,\r\n\t\tbtr.y,\r\n\t\tbtr.z,\r\n\r\n\t\t// bottom\r\n\t\tbbl.x,\r\n\t\tbbl.y,\r\n\t\tbbl.z,\r\n\t\tbbr.x,\r\n\t\tbbr.y,\r\n\t\tbbr.z,\r\n\t\tfbl.x,\r\n\t\tfbl.y,\r\n\t\tfbl.z,\r\n\t\tfbl.x,\r\n\t\tfbl.y,\r\n\t\tfbl.z,\r\n\t\tbbr.x,\r\n\t\tbbr.y,\r\n\t\tbbr.z,\r\n\t\tfbr.x,\r\n\t\tfbr.y,\r\n\t\tfbr.z\r\n\t];\r\n\r\n\tconst uvs = [\r\n\t\t// front\r\n\t\t0, 0, 1, 0, 0, 1, 0, 1, 1, 0, 1, 1,\r\n\r\n\t\t// right\r\n\t\t0, 0, 1, 0, 0, 1, 0, 1, 1, 0, 1, 1,\r\n\r\n\t\t// back\r\n\t\t0, 0, 1, 0, 0, 1, 0, 1, 1, 0, 1, 1,\r\n\r\n\t\t// left\r\n\t\t0, 0, 1, 0, 0, 1, 0, 1, 1, 0, 1, 1,\r\n\r\n\t\t// top\r\n\t\t0, 0, 1, 0, 0, 1, 0, 1, 1, 0, 1, 1,\r\n\r\n\t\t// bottom\r\n\t\t0, 0, 1, 0, 0, 1, 0, 1, 1, 0, 1, 1\r\n\t];\r\n\r\n\tconst normals = [\r\n\t\t// front\r\n\t\t0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 1,\r\n\r\n\t\t// right\r\n\t\t1, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0,\r\n\r\n\t\t// back\r\n\t\t0, 0, -1, 0, 0, -1, 0, 0, -1, 0, 0, -1, 0, 0, -1, 0, 0, -1,\r\n\r\n\t\t// left\r\n\t\t-1, 0, 0, -1, 0, 0, -1, 0, 0, -1, 0, 0, -1, 0, 0, -1, 0, 0,\r\n\r\n\t\t// top\r\n\t\t0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0,\r\n\r\n\t\t// bottom\r\n\t\t0, -1, 0, 0, -1, 0, 0, -1, 0, 0, -1, 0, 0, -1, 0, 0, -1, 0\r\n\t];\r\n\treturn {\r\n\t\tpositions: positions,\r\n\t\tnormals: normals,\r\n\t\tuvs: uvs\r\n\t};\r\n}\r\n\r\nexport function createSphere(options) {\r\n\toptions = options || {};\r\n\r\n\tconst longBands = options.longBands || 32;\r\n\tconst latBands = options.latBands || 32;\r\n\tconst radius = options.radius || 1;\r\n\tconst lat_step = Math.PI / latBands;\r\n\tconst long_step = (2 * Math.PI) / longBands;\r\n\tconst num_positions = longBands * latBands * 4;\r\n\tconst num_indices = longBands * latBands * 6;\r\n\tlet lat_angle, long_angle;\r\n\tconst positions = new Array(num_positions * 3);\r\n\tconst normals = new Array(num_positions * 3);\r\n\tconst uvs = new Array(num_positions * 2);\r\n\tconst indices = new Array(num_indices);\r\n\tlet x1, x2, x3, x4, y1, y2, z1, z2, z3, z4, u1, u2, v1, v2;\r\n\tlet i, j;\r\n\tlet k = 0,\r\n\t\tl = 0;\r\n\tlet vi, ti;\r\n\r\n\tfor (i = 0; i < latBands; i++) {\r\n\t\tlat_angle = i * lat_step;\r\n\t\ty1 = Math.cos(lat_angle);\r\n\t\ty2 = Math.cos(lat_angle + lat_step);\r\n\t\tfor (j = 0; j < longBands; j++) {\r\n\t\t\tlong_angle = j * long_step;\r\n\t\t\tx1 = Math.sin(lat_angle) * Math.cos(long_angle);\r\n\t\t\tx2 = Math.sin(lat_angle) * Math.cos(long_angle + long_step);\r\n\t\t\tx3 = Math.sin(lat_angle + lat_step) * Math.cos(long_angle);\r\n\t\t\tx4 = Math.sin(lat_angle + lat_step) * Math.cos(long_angle + long_step);\r\n\t\t\tz1 = Math.sin(lat_angle) * Math.sin(long_angle);\r\n\t\t\tz2 = Math.sin(lat_angle) * Math.sin(long_angle + long_step);\r\n\t\t\tz3 = Math.sin(lat_angle + lat_step) * Math.sin(long_angle);\r\n\t\t\tz4 = Math.sin(lat_angle + lat_step) * Math.sin(long_angle + long_step);\r\n\t\t\tu1 = 1 - j / longBands;\r\n\t\t\tu2 = 1 - (j + 1) / longBands;\r\n\t\t\tv1 = 1 - i / latBands;\r\n\t\t\tv2 = 1 - (i + 1) / latBands;\r\n\t\t\tvi = k * 3;\r\n\t\t\tti = k * 2;\r\n\r\n\t\t\tpositions[vi] = x1 * radius;\r\n\t\t\tpositions[vi + 1] = y1 * radius;\r\n\t\t\tpositions[vi + 2] = z1 * radius; // v0\r\n\r\n\t\t\tpositions[vi + 3] = x2 * radius;\r\n\t\t\tpositions[vi + 4] = y1 * radius;\r\n\t\t\tpositions[vi + 5] = z2 * radius; // v1\r\n\r\n\t\t\tpositions[vi + 6] = x3 * radius;\r\n\t\t\tpositions[vi + 7] = y2 * radius;\r\n\t\t\tpositions[vi + 8] = z3 * radius; // v2\r\n\r\n\t\t\tpositions[vi + 9] = x4 * radius;\r\n\t\t\tpositions[vi + 10] = y2 * radius;\r\n\t\t\tpositions[vi + 11] = z4 * radius; // v3\r\n\r\n\t\t\tnormals[vi] = x1;\r\n\t\t\tnormals[vi + 1] = y1;\r\n\t\t\tnormals[vi + 2] = z1;\r\n\r\n\t\t\tnormals[vi + 3] = x2;\r\n\t\t\tnormals[vi + 4] = y1;\r\n\t\t\tnormals[vi + 5] = z2;\r\n\r\n\t\t\tnormals[vi + 6] = x3;\r\n\t\t\tnormals[vi + 7] = y2;\r\n\t\t\tnormals[vi + 8] = z3;\r\n\r\n\t\t\tnormals[vi + 9] = x4;\r\n\t\t\tnormals[vi + 10] = y2;\r\n\t\t\tnormals[vi + 11] = z4;\r\n\r\n\t\t\tuvs[ti] = u1;\r\n\t\t\tuvs[ti + 1] = v1;\r\n\r\n\t\t\tuvs[ti + 2] = u2;\r\n\t\t\tuvs[ti + 3] = v1;\r\n\r\n\t\t\tuvs[ti + 4] = u1;\r\n\t\t\tuvs[ti + 5] = v2;\r\n\r\n\t\t\tuvs[ti + 6] = u2;\r\n\t\t\tuvs[ti + 7] = v2;\r\n\r\n\t\t\tindices[l] = k;\r\n\t\t\tindices[l + 1] = k + 1;\r\n\t\t\tindices[l + 2] = k + 2;\r\n\t\t\tindices[l + 3] = k + 2;\r\n\t\t\tindices[l + 4] = k + 1;\r\n\t\t\tindices[l + 5] = k + 3;\r\n\r\n\t\t\tk += 4;\r\n\t\t\tl += 6;\r\n\t\t}\r\n\t}\r\n\r\n\treturn {\r\n\t\tpositions: positions,\r\n\t\tnormals: normals,\r\n\t\tuvs: uvs,\r\n\t\tindices: indices\r\n\t};\r\n}\r\n","import { Float32Attribute } from \"../render/Attribute\";\r\nimport { createSphere } from \"../utils/GeometryUtils\";\r\nimport Geometry from \"./Geometry\";\r\n\r\nexport default class SphereGeometry extends Geometry {\r\n\tradius: number;\r\n\tconstructor(radius: number) {\r\n\t\tsuper({\r\n\t\t\ttype: \"sphereGeometry\"\r\n\t\t});\r\n\t\tthis.defines = {\r\n\t\t\tHAS_NORMAL: true\r\n\t\t};\r\n\t\tthis.radius = radius;\r\n\t\tthis.init();\r\n\t}\r\n\tprivate init() {\r\n\t\tconst { positions, normals, uvs, indices } = createSphere({ radius: this.radius });\r\n\t\t// this.positions = positions;\r\n\t\t// this.normals = normals;\r\n\t\t// this.uvs = uvs;\r\n\t\t// this.indices = indices;\r\n\t\tthis.computeBoundingSphere(positions);\r\n\t\tthis.setAttribute(new Float32Attribute(\"position\", positions, 3));\r\n\t\tthis.setAttribute(new Float32Attribute(\"normal\", normals, 3));\r\n\t\tthis.setAttribute(new Float32Attribute(\"uv\", uvs, 2));\r\n\r\n\t\tthis.setIndice(indices);\r\n\t\tthis.count = indices.length;\r\n\t}\r\n}\r\n","import { Float32Attribute } from \"../render/Attribute\";\r\nimport { createBox } from \"../utils/GeometryUtils\";\r\nimport Geometry from \"./Geometry\";\r\nexport default class BoxGeometry extends Geometry {\r\n\tconstructor(public width: number = 10, public height: number = 10, public depth: number = 10) {\r\n\t\tsuper({\r\n\t\t\ttype: \"boxGeometry\"\r\n\t\t});\r\n\t\tthis.defines = {\r\n\t\t\tHAS_NORMAL: true\r\n\t\t};\r\n\t\tthis.init();\r\n\t}\r\n\tprivate init() {\r\n\t\t// generate pos uv normal so on\r\n\t\tconst { positions, normals, uvs } = createBox({\r\n\t\t\tdimensions: [this.depth, this.width, this.height]\r\n\t\t});\r\n\t\tthis.computeBoundingSphere(positions);\r\n\t\tthis.setAttribute(new Float32Attribute(\"position\", positions, 3));\r\n\t\tthis.setAttribute(new Float32Attribute(\"normal\", normals, 3));\r\n\t\tthis.setAttribute(new Float32Attribute(\"uv\", uvs, 2));\r\n\t\tthis.count = 36;\r\n\t}\r\n\tpublic update(frameState) {}\r\n}\r\n","import Vector3 from \"../math/Vector3\";\r\nimport { Float32Attribute } from \"../render/Attribute\";\r\nimport Geometry from \"./Geometry\";\r\nexport default class TorusKnotGeometry extends Geometry {\r\n\tradius: number;\r\n\ttube: number;\r\n\ttubularSegments: number;\r\n\tradialSegments: number;\r\n\tp: number;\r\n\tq: number;\r\n\tconstructor(radius = 1, tube = 0.4, tubularSegments = 64, radialSegments = 8, p = 2, q = 3) {\r\n\t\tsuper({\r\n\t\t\ttype: \"torusKnotGeometry\"\r\n\t\t});\r\n\t\tthis.defines = {\r\n\t\t\tHAS_NORMAL: true\r\n\t\t};\r\n\t\tthis.radius = radius;\r\n\t\tthis.tube = tube;\r\n\t\tthis.tubularSegments = tubularSegments;\r\n\t\tthis.radialSegments = radialSegments;\r\n\t\tthis.p = p;\r\n\t\tthis.q = q;\r\n\t\tthis.init();\r\n\t}\r\n\tpublic update(frameState) {\r\n\t\tconst { device } = frameState.context;\r\n\t}\r\n\tprivate init() {\r\n\t\tconst { normals, uvs, positions, indices } = this.createGeometry();\r\n\t\tthis.computeBoundingSphere(positions);\r\n\t\tthis.setAttribute(new Float32Attribute(\"position\", positions, 3));\r\n\t\tthis.setAttribute(new Float32Attribute(\"normal\", normals, 3));\r\n\t\tthis.setAttribute(new Float32Attribute(\"uv\", uvs, 2));\r\n\t\tthis.setIndice(indices);\r\n\t\tthis.count = indices.length;\r\n\t}\r\n\tprivate createGeometry() {\r\n\t\tconst positions = [],\r\n\t\t\tnormals = [],\r\n\t\t\tuvs = [],\r\n\t\t\tindices = [];\r\n\t\tconst tubularSegments = Math.floor(this.tubularSegments);\r\n\t\tconst radialSegments = Math.floor(this.radialSegments);\r\n\t\t// helper variables\r\n\r\n\t\tconst vertex = new Vector3();\r\n\t\tconst normal = new Vector3();\r\n\r\n\t\tconst P1 = new Vector3();\r\n\t\tconst P2 = new Vector3();\r\n\r\n\t\tconst B = new Vector3();\r\n\t\tconst T = new Vector3();\r\n\t\tconst N = new Vector3();\r\n\r\n\t\t// generate vertices, normals and uvs\r\n\r\n\t\tfor (let i = 0; i <= tubularSegments; ++i) {\r\n\t\t\t// the radian \"u\" is used to calculate the position on the torus curve of the current tubular segment\r\n\r\n\t\t\tconst u = (i / tubularSegments) * this.p * Math.PI * 2;\r\n\r\n\t\t\t// now we calculate two points. P1 is our current position on the curve, P2 is a little farther ahead.\r\n\t\t\t// these points are used to create a special \"coordinate space\", which is necessary to calculate the correct vertex positions\r\n\r\n\t\t\tcalculatePositionOnCurve(u, this.p, this.q, this.radius, P1);\r\n\t\t\tcalculatePositionOnCurve(u + 0.01, this.p, this.q, this.radius, P2);\r\n\r\n\t\t\t// calculate orthonormal basis\r\n\r\n\t\t\tVector3.subtract(P2, P1, T);\r\n\t\t\t// T.subVectors( P2, P1 );\r\n\t\t\tVector3.add(P2, P1, N);\r\n\t\t\t// N.addVectors( P2, P1 );\r\n\t\t\tVector3.cross(T, N, B);\r\n\t\t\t// B.crossVectors( T, N );\r\n\t\t\tVector3.cross(B, T, N);\r\n\t\t\t// N.crossVectors( B, T );\r\n\r\n\t\t\t// normalize B, N. T can be ignored, we don't use it\r\n\r\n\t\t\tB.normalize();\r\n\t\t\tN.normalize();\r\n\r\n\t\t\tfor (let j = 0; j <= radialSegments; ++j) {\r\n\t\t\t\t// now calculate the vertices. they are nothing more than an extrusion of the torus curve.\r\n\t\t\t\t// because we extrude a shape in the xy-plane, there is no need to calculate a z-value.\r\n\r\n\t\t\t\tconst v = (j / radialSegments) * Math.PI * 2;\r\n\t\t\t\tconst cx = -this.tube * Math.cos(v);\r\n\t\t\t\tconst cy = this.tube * Math.sin(v);\r\n\r\n\t\t\t\t// now calculate the final vertex position.\r\n\t\t\t\t// first we orient the extrusion with our basis vectors, then we add it to the current position on the curve\r\n\r\n\t\t\t\tvertex.x = P1.x + (cx * N.x + cy * B.x);\r\n\t\t\t\tvertex.y = P1.y + (cx * N.y + cy * B.y);\r\n\t\t\t\tvertex.z = P1.z + (cx * N.z + cy * B.z);\r\n\r\n\t\t\t\tpositions.push(vertex.x, vertex.y, vertex.z);\r\n\r\n\t\t\t\t// normal (P1 is always the center/origin of the extrusion, thus we can use it to calculate the normal)\r\n\t\t\t\tVector3.subtract(vertex, P1, normal);\r\n\t\t\t\tnormal.normalize();\r\n\r\n\t\t\t\tnormals.push(normal.x, normal.y, normal.z);\r\n\r\n\t\t\t\t// uv\r\n\r\n\t\t\t\tuvs.push(i / tubularSegments);\r\n\t\t\t\tuvs.push(j / radialSegments);\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\t// generate indices\r\n\r\n\t\tfor (let j = 1; j <= tubularSegments; j++) {\r\n\t\t\tfor (let i = 1; i <= radialSegments; i++) {\r\n\t\t\t\t// indices\r\n\r\n\t\t\t\tconst a = (radialSegments + 1) * (j - 1) + (i - 1);\r\n\t\t\t\tconst b = (radialSegments + 1) * j + (i - 1);\r\n\t\t\t\tconst c = (radialSegments + 1) * j + i;\r\n\t\t\t\tconst d = (radialSegments + 1) * (j - 1) + i;\r\n\r\n\t\t\t\t// faces\r\n\r\n\t\t\t\tindices.push(a, b, d);\r\n\t\t\t\tindices.push(b, c, d);\r\n\t\t\t}\r\n\t\t}\r\n\t\treturn {\r\n\t\t\tnormals,\r\n\t\t\tuvs,\r\n\t\t\tpositions,\r\n\t\t\tindices\r\n\t\t};\r\n\t}\r\n}\r\nfunction calculatePositionOnCurve(u, p, q, radius, position) {\r\n\tconst cu = Math.cos(u);\r\n\tconst su = Math.sin(u);\r\n\tconst quOverP = (q / p) * u;\r\n\tconst cs = Math.cos(quOverP);\r\n\r\n\tposition.x = radius * (2 + cs) * 0.5 * cu;\r\n\tposition.y = radius * (2 + cs) * su * 0.5;\r\n\tposition.z = radius * Math.sin(quOverP) * 0.5;\r\n}\r\n","import { FrameState } from \"../core/FrameState\";\r\nimport textureCache from \"../core/TextureCache\";\r\nimport Color from \"../math/Color\";\r\nimport { Mesh } from \"../mesh/Mesh\";\r\nimport Sampler from \"../render/Sampler\";\r\nimport Texture from \"../render/Texture\";\r\nimport UniformBuffer from \"../render/UniformBuffer\";\r\nimport { UniformEnum } from \"../render/Uniforms\";\r\nimport { ShaderSource } from \"../shader/ShaderSource\";\r\nimport { Material } from \"./Material\";\r\nexport default class BlinnPhongMaterial extends Material {\r\n\tpublic specular: Color;\r\n\tpublic shininess: number;\r\n\tpublic normalTexture: Texture;\r\n\tpublic normalSampler: Sampler;\r\n\tconstructor() {\r\n\t\tsuper();\r\n\t\tthis.type = \"phong\";\r\n\t\tthis.color = new Color(1.0, 0.0, 0.0);\r\n\t\tthis.shaderSource = new ShaderSource({\r\n\t\t\ttype: this.type,\r\n\t\t\trender: true,\r\n\t\t\tdefines: {\r\n\t\t\t\tmaterialPhong: true\r\n\t\t\t}\r\n\t\t});\r\n\t\tthis.light = true;\r\n\t\tthis.specular = new Color(1.0, 1.0, 1.0);\r\n\t\tthis.shininess = 30.0;\r\n\t\tthis.baseTexture = undefined;\r\n\t\tthis.baseSampler = undefined;\r\n\t}\r\n\tupdate(frameState?: FrameState, mesh?: Mesh) {\r\n\t\tif (!this.shaderData || this.dirty) this.createShaderData(mesh);\r\n\t}\r\n\tprotected createShaderData(mesh?: Mesh) {\r\n\t\tsuper.createShaderData();\r\n\t\tconst uniformBuffer = new UniformBuffer({ label: \"phong\" });\r\n\t\tuniformBuffer.setUniform(\r\n\t\t\t\"modelMatrix\",\r\n\t\t\t() => {\r\n\t\t\t\treturn mesh.modelMatrix;\r\n\t\t\t},\r\n\t\t\tUniformEnum.Mat4\r\n\t\t);\r\n\t\tuniformBuffer.setUniform(\"color\", this, UniformEnum.Color);\r\n\t\tuniformBuffer.setUniform(\"opacity\", this, UniformEnum.Float);\r\n\t\tuniformBuffer.setUniform(\r\n\t\t\t\"normalMtrix\",\r\n\t\t\t() => {\r\n\t\t\t\treturn mesh.normalMatrix;\r\n\t\t\t},\r\n\t\t\tUniformEnum.Mat4\r\n\t\t);\r\n\t\tuniformBuffer.setUniform(\"emissive\", this, UniformEnum.Color);\r\n\t\tuniformBuffer.setUniform(\"shininess\", this, UniformEnum.Float);\r\n\t\tuniformBuffer.setUniform(\"specular\", this, UniformEnum.Color);\r\n\t\tthis.shaderData.setUniformBuffer(\"phong\", uniformBuffer);\r\n\t\tif (this.baseTexture) {\r\n\t\t\tthis.shaderData.setDefine(\"USE_COLORTEXTURE\", true);\r\n\t\t\tthis.shaderData.setTexture(\"baseColorTexture\", this.baseTexture);\r\n\t\t\tthis.shaderData.setSampler(\"baseColorSampler\", this.baseSampler || textureCache.defaultSampler);\r\n\t\t}\r\n\t\tif (this.normalTexture) {\r\n\t\t\tthis.shaderData.setDefine(\"USE_NORMALTEXTURE\", true);\r\n\t\t\tthis.shaderData.setTexture(\"normalTexture\", this.normalTexture);\r\n\t\t\tthis.shaderData.setSampler(\"normalSampler\", this.normalSampler || textureCache.defaultSampler);\r\n\t\t}\r\n\t}\r\n\tdestroy() {\r\n\t\tthis?.baseTexture?.destroy();\r\n\t\tsuper.destroy();\r\n\t}\r\n}\r\n","import { FrameState } from \"../core/FrameState\";\nimport textureCache from \"../core/TextureCache\";\nimport { CullMode } from \"../core/WebGPUConstant\";\nimport Vector2 from \"../math/Vector2\";\nimport { Mesh } from \"../mesh/Mesh\";\nimport Sampler from \"../render/Sampler\";\nimport Texture from \"../render/Texture\";\nimport UniformBuffer from \"../render/UniformBuffer\";\nimport { UniformEnum } from \"../render/Uniforms\";\nimport { ShaderSource } from \"../shader/ShaderSource\";\nimport { Material } from \"./Material\";\n\nexport default class PbrMaterial extends Material {\n\tpublic specularEnvTexture: Texture;\n\n\tpublic specularEnvSampler: Sampler;\n\n\tpublic emissiveTexture: Texture;\n\n\tpublic emissiveSampler: Sampler;\n\n\tpublic normalTexture: Texture;\n\n\tpublic normalSampler: Sampler;\n\n\tpublic aoTexture: Texture;\n\n\tpublic aoSampler: Sampler;\n\n\tpublic metalnessRoughnessTexture: Texture;\n\n\tpublic metalnessRoughnessSampler: Sampler;\n\n\tprivate _roughness: number;\n\n\tprivate _metalness: number;\n\n\tprivate _aoTextureIntensity: number;\n\n\tprivate _normalScale: Vector2;\n\n\tprivate _IBLRender: boolean;\n\n\tpublic get roughness(): number {\n\t\treturn this._roughness;\n\t}\n\tpublic set roughness(value) {\n\t\tthis._roughness = value;\n\t}\n\tpublic get metalness(): number {\n\t\treturn this._metalness;\n\t}\n\tpublic set metalness(v: number) {\n\t\tthis._metalness = v;\n\t}\n\tpublic get aoTextureIntensity(): number {\n\t\treturn this._aoTextureIntensity;\n\t}\n\tpublic set aoTextureIntensity(v: number) {\n\t\tthis._aoTextureIntensity = v;\n\t}\n\tpublic get normalScale(): Vector2 {\n\t\tif (this.renderState && this.renderState.primitive) {\n\t\t\tif (this.renderState.primitive.cullMode == CullMode.Back) {\n\t\t\t\treturn Vector2.negate(this._normalScale, new Vector2());\n\t\t\t}\n\t\t}\n\t\treturn this._normalScale;\n\t}\n\tpublic set normalScale(v: Vector2) {\n\t\tthis._normalScale = v;\n\t}\n\tpublic set IBLRender(value) {\n\t\tthis._IBLRender = value;\n\t\tthis.shaderSource.setDefines({\n\t\t\tUSE_IBL: this._IBLRender\n\t\t});\n\t\tthis.dirty = true;\n\t}\n\tconstructor() {\n\t\tsuper();\n\t\tthis.type = \"pbr_mat\";\n\n\t\tthis._roughness = 0.1;\n\n\t\tthis._metalness = 0.1;\n\n\t\tthis._aoTextureIntensity = 1.0;\n\t\tthis.light = true;\n\t\tthis._normalScale = new Vector2(1, 1);\n\t\tthis._IBLRender = true;\n\t\tthis.shaderSource = new ShaderSource({\n\t\t\ttype: this.type,\n\t\t\trender: true,\n\t\t\tdefines: {\n\t\t\t\tmaterialPbr: true,\n\t\t\t\tUSE_IBL: this._IBLRender\n\t\t\t}\n\t\t});\n\t}\n\tupdate(frameState?: FrameState, mesh?: Mesh) {\n\t\tif (!textureCache.getTexture(\"specular\")) return;\n\t\tif (!this.shaderData || this.dirty) {\n\t\t\tthis.createShaderData(mesh,);\n\t\t}\n\t}\n\tprotected createShaderData(mesh?: Mesh,) {\n\t\tsuper.createShaderData();\n\t\tconst uniformBuffer = new UniformBuffer({ label: \"pbr\" });\n\t\tuniformBuffer.setUniform(\n\t\t\t\"modelMatrix\",\n\t\t\t() => {\n\t\t\t\treturn mesh.modelMatrix;\n\t\t\t},\n\t\t\tUniformEnum.Mat4\n\t\t);\n\t\tuniformBuffer.setUniform(\"color\", this, UniformEnum.Color);\n\t\tuniformBuffer.setUniform(\"opacity\", this, UniformEnum.Float);\n\t\tuniformBuffer.setUniform(\n\t\t\t\"normalMtrix\",\n\t\t\t() => {\n\t\t\t\treturn mesh.normalMatrix;\n\t\t\t},\n\t\t\tUniformEnum.Mat4\n\t\t);\n\t\tuniformBuffer.setUniform(\"emissive\", this, UniformEnum.Color);\n\t\tuniformBuffer.setUniform(\"metalness\", this, UniformEnum.Float);\n\t\tuniformBuffer.setUniform(\"roughness\", this, UniformEnum.Float);\n\t\tthis.shaderData.setUniformBuffer(\"pbr\", uniformBuffer);\n\t\tthis.specularEnvTexture = textureCache.getTexture(\"specular\");\n\t\tif (this.baseTexture) {\n\t\t\tthis.shaderData.setDefine(\"USE_TEXTURE\", true);\n\t\t\tthis.shaderData.setTexture(\"baseColorTexture\", this.baseTexture);\n\t\t\tthis.shaderData.setSampler(\"baseColorSampler\", this.baseSampler || textureCache.defaultSampler);\n\t\t}\n\t\tif (this.metalnessRoughnessTexture) {\n\t\t\tthis.shaderData.setDefine(\"USE_METALNESSTEXTURE\", true);\n\t\t\tthis.shaderData.setTexture(\"metalnessRoughnessTexture\", this.metalnessRoughnessTexture);\n\t\t\tthis.shaderData.setSampler(\n\t\t\t\t\"metalnessRoughnessSampler\",\n\t\t\t\tthis.metalnessRoughnessSampler || textureCache.defaultSampler\n\t\t\t);\n\t\t}\n\t\tif (this.normalTexture) {\n\t\t\tuniformBuffer.setUniform(\"normalScale\", this, UniformEnum.FloatVec2);\n\t\t\tthis.shaderData.setDefine(\"USE_NORMALTEXTURE\", true);\n\t\t\tthis.shaderData.setTexture(\"normalTexture\", this.normalTexture);\n\t\t\tthis.shaderData.setSampler(\"normalSampler\", this.normalSampler || textureCache.defaultSampler);\n\t\t}\n\t\tif (this.aoTexture) {\n\t\t\tthis.shaderData.setDefine(\"USE_AOTEXTURE\", true);\n\t\t\tthis.shaderData.setTexture(\"aoTexture\", this.aoTexture);\n\t\t\tthis.shaderData.setSampler(\"aoSampler\", this.aoSampler || textureCache.defaultSampler);\n\t\t\tuniformBuffer.setUniform(\"aoTextureIntensity\", this, UniformEnum.Float);\n\t\t}\n\t\tif (this.emissiveTexture) {\n\t\t\tthis.shaderData.setDefine(\"USE_EMISSIVETEXTURE\", true);\n\t\t\tthis.shaderData.setTexture(\"emissiveTexture\", this.emissiveTexture);\n\t\t\tthis.shaderData.setSampler(\"emissiveSampler\", this.emissiveSampler || textureCache.defaultSampler);\n\t\t}\n\t\tif (this.specularEnvTexture && this._IBLRender) {\n\t\t\tthis.shaderData.setTexture(\"specularEnvTexture\", this.specularEnvTexture);\n\t\t\tthis.shaderData.setSampler(\"specularEnvSampler\", this.specularEnvSampler || textureCache.defaultSampler);\n\t\t}\n\t}\n\tdestroy() {\n\t\tthis?.aoTexture?.destroy();\n\t\tthis?.baseTexture?.destroy();\n\t\tthis?.emissiveTexture?.destroy();\n\t\tthis?.normalTexture?.destroy();\n\t\tthis.specularEnvTexture = undefined;\n\t}\n}\n","export class EventDispatcher {\r\n\tprivate _listeners: object;\r\n\tconstructor() {\r\n\t\tthis._listeners = {};\r\n\t}\r\n\r\n\taddEventListener(type, listener) {\r\n\t\tif (this._listeners === undefined) this._listeners = {};\r\n\r\n\t\tconst listeners = this._listeners;\r\n\r\n\t\tif (listeners[type] === undefined) {\r\n\t\t\tlisteners[type] = [];\r\n\t\t}\r\n\r\n\t\tif (listeners[type].indexOf(listener) === -1) {\r\n\t\t\tlisteners[type].push(listener);\r\n\t\t}\r\n\t}\r\n\r\n\thasEventListener(type, listener) {\r\n\t\tif (this._listeners === undefined) return false;\r\n\r\n\t\tconst listeners = this._listeners;\r\n\r\n\t\treturn listeners[type] !== undefined && listeners[type].indexOf(listener) !== -1;\r\n\t}\r\n\r\n\tremoveEventListener(type, listener) {\r\n\t\tif (this._listeners === undefined) return;\r\n\r\n\t\tconst listeners = this._listeners;\r\n\t\tconst listenerArray = listeners[type];\r\n\r\n\t\tif (listenerArray !== undefined) {\r\n\t\t\tconst index = listenerArray.indexOf(listener);\r\n\r\n\t\t\tif (index !== -1) {\r\n\t\t\t\tlistenerArray.splice(index, 1);\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\r\n\tdispatchEvent(event) {\r\n\t\tif (this._listeners === undefined) return;\r\n\r\n\t\tconst listeners = this._listeners;\r\n\t\tconst listenerArray = listeners[event.type];\r\n\r\n\t\tif (listenerArray !== undefined) {\r\n\t\t\tevent.target = this;\r\n\r\n\t\t\tconst array = listenerArray.slice(0);\r\n\r\n\t\t\tfor (let i = 0, l = array.length; i < l; i++) {\r\n\t\t\t\tarray[i].call(this, event);\r\n\t\t\t}\r\n\t\t\tevent.target = null;\r\n\t\t}\r\n\t}\r\n}\r\n","import Camera from \"../camera/Camera\";\r\nimport { Compute } from \"../compute/Compute\";\r\nimport { Material } from \"../material/Material\";\r\nimport { Mesh } from \"../mesh/Mesh\";\r\nimport { ComputeCommand } from \"../render/ComputeCommand\";\r\nimport Context from \"../render/Context\";\r\nimport DrawCommand from \"../render/DrawCommand\";\r\nimport LightManger from \"./LightManger\";\r\nimport { CommandSubType } from \"./WebGPUConstant\";\r\nexport default class RenderQueue {\r\n\tpublic pre: Array<Mesh>;\r\n\tpublic opaque: Array<Mesh>;\r\n\tpublic transparent: Array<Mesh>;\r\n\tpublic debugQueue: Array<Mesh>;\r\n\tpublic computes: Array<Compute>;\r\n\tconstructor() {\r\n\t\tthis.pre = [];\r\n\t\tthis.opaque = [];\r\n\t\tthis.transparent = [];\r\n\t\tthis.computes = [];\r\n\t\tthis.debugQueue = [];\r\n\t}\r\n\tsort() {\r\n\t\tRenderQueue.sort(this.opaque, 0, this.opaque.length, RenderQueue._compareFromNearToFar);\r\n\t\tRenderQueue.sort(this.transparent, 0, this.transparent.length, RenderQueue._compareFromFarToNear);\r\n\t}\r\n\topaqueRender(\r\n\t\tcamera: Camera,\r\n\t\tcontext: Context,\r\n\t\tpassEncoder?: GPURenderPassEncoder,\r\n\t\treplaceMaterial?: Material,\r\n\t\tcommandSubType?: CommandSubType,\r\n\t\tlightManger?: LightManger\r\n\t) {\r\n\t\tthis.opaque.map((mesh) => {\r\n\t\t\tif (!mesh.ready) return;\r\n\t\t\tmesh.beforeRender();\r\n\t\t\tRenderQueue.excuteCommand(\r\n\t\t\t\tmesh.getDrawCommand(replaceMaterial, commandSubType, lightManger),\r\n\t\t\t\tcontext,\r\n\t\t\t\tpassEncoder,\r\n\t\t\t\tcamera\r\n\t\t\t);\r\n\t\t\tmesh.afterRender();\r\n\t\t});\r\n\t}\r\n\ttransparentRender(\r\n\t\tcamera: Camera,\r\n\t\tcontext: Context,\r\n\t\tpassEncoder?: GPURenderPassEncoder,\r\n\t\treplaceMaterial?: Material,\r\n\t\tcommandSubType?: CommandSubType,\r\n\t\tlightManger?: LightManger\r\n\t) {\r\n\t\tthis.transparent.map((mesh) => {\r\n\t\t\tif (!mesh.ready) return;\r\n\t\t\tmesh.beforeRender();\r\n\t\t\tRenderQueue.excuteCommand(\r\n\t\t\t\tmesh.getDrawCommand(replaceMaterial, commandSubType, lightManger),\r\n\t\t\t\tcontext,\r\n\t\t\t\tpassEncoder,\r\n\t\t\t\tcamera\r\n\t\t\t);\r\n\t\t\tmesh.afterRender();\r\n\t\t});\r\n\t}\r\n\tcomputeRender(context: Context, passEncoder?: GPUComputePassEncoder) {\r\n\t\tthis.computes.map((compute) => {\r\n\t\t\tRenderQueue.excuteCompute(compute.getCommand(), context, passEncoder);\r\n\t\t});\r\n\t}\r\n\tdebugQueueRender(\r\n\t\tcamera: Camera,\r\n\t\tcontext: Context,\r\n\t\tpassEncoder?: GPURenderPassEncoder,\r\n\t\treplaceMaterial?: Material,\r\n\t\tcommandSubType?: CommandSubType\r\n\t) {\r\n\t\tthis.debugQueue.map((mesh) => {\r\n\t\t\tif (!mesh.ready) return;\r\n\t\t\tmesh.beforeRender();\r\n\t\t\tRenderQueue.excuteCommand(\r\n\t\t\t\tmesh.getDrawCommand(replaceMaterial, commandSubType),\r\n\t\t\t\tcontext,\r\n\t\t\t\tpassEncoder,\r\n\t\t\t\tcamera\r\n\t\t\t);\r\n\t\t\tmesh.afterRender();\r\n\t\t});\r\n\t}\r\n\tpreRender(camera: Camera, context: Context, passEncoder?: GPURenderPassEncoder, replaceMaterial?: Material) {\r\n\t\tthis.pre.map((mesh) => {\r\n\t\t\tif (!mesh.ready) return;\r\n\t\t\tmesh.beforeRender();\r\n\t\t\tRenderQueue.excuteCommand(mesh.getDrawCommand(), context, passEncoder, camera);\r\n\t\t\tmesh.afterRender();\r\n\t\t});\r\n\t}\r\n\tstatic excuteCommand(command: DrawCommand, context?: Context, passEncoder?: GPURenderPassEncoder, camera?: Camera) {\r\n\t\tcommand.render(context, passEncoder, camera);\r\n\t}\r\n\tstatic excuteCompute(command: ComputeCommand, context?: Context, passEncoder?: GPUComputePassEncoder) {\r\n\t\tcommand.render(context, passEncoder);\r\n\t}\r\n\treset() {\r\n\t\tthis.pre = [];\r\n\t\tthis.opaque = [];\r\n\t\tthis.transparent = [];\r\n\t\tthis.computes = [];\r\n\t\tthis.debugQueue = [];\r\n\t}\r\n\tstatic _compareFromNearToFar(a: Mesh, b: Mesh): number {\r\n\t\treturn a.priority - b.priority || a.distanceToCamera - b.distanceToCamera;\r\n\t}\r\n\r\n\tstatic _compareFromFarToNear(a: Mesh, b: Mesh): number {\r\n\t\treturn a.priority - b.priority || b.distanceToCamera - a.distanceToCamera;\r\n\t}\r\n\t//according to camera distance\r\n\tstatic sort<T>(insatnce: T[], from: number, to: number, compareFunc: Function): void {\r\n\t\tRenderQueue._quickSort(insatnce, from, to, compareFunc);\r\n\t}\r\n\t//from https://github.com/oasis-engine/engine/blob/main/packages/core/src/RenderPipeline/RenderQueue.ts\r\n\tprivate static _quickSort<T>(a: T[], from: number, to: number, compareFunc: Function): void {\r\n\t\twhile (true) {\r\n\t\t\t// Insertion sort is faster for short arrays.\r\n\t\t\tif (to - from <= 10) {\r\n\t\t\t\tRenderQueue._insertionSort(a, from, to, compareFunc);\r\n\t\t\t\treturn;\r\n\t\t\t}\r\n\t\t\tconst third_index = (from + to) >> 1;\r\n\t\t\t// Find a pivot as the median of first, last and middle element.\r\n\t\t\tlet v0 = a[from];\r\n\t\t\tlet v1 = a[to - 1];\r\n\t\t\tlet v2 = a[third_index];\r\n\t\t\tconst c01 = compareFunc(v0, v1);\r\n\t\t\tif (c01 > 0) {\r\n\t\t\t\t// v1 < v0, so swap them.\r\n\t\t\t\tconst tmp = v0;\r\n\t\t\t\tv0 = v1;\r\n\t\t\t\tv1 = tmp;\r\n\t\t\t} // v0 <= v1.\r\n\t\t\tconst c02 = compareFunc(v0, v2);\r\n\t\t\tif (c02 >= 0) {\r\n\t\t\t\t// v2 <= v0 <= v1.\r\n\t\t\t\tconst tmp = v0;\r\n\t\t\t\tv0 = v2;\r\n\t\t\t\tv2 = v1;\r\n\t\t\t\tv1 = tmp;\r\n\t\t\t} else {\r\n\t\t\t\t// v0 <= v1 && v0 < v2\r\n\t\t\t\tconst c12 = compareFunc(v1, v2);\r\n\t\t\t\tif (c12 > 0) {\r\n\t\t\t\t\t// v0 <= v2 < v1\r\n\t\t\t\t\tconst tmp = v1;\r\n\t\t\t\t\tv1 = v2;\r\n\t\t\t\t\tv2 = tmp;\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t\t// v0 <= v1 <= v2\r\n\t\t\ta[from] = v0;\r\n\t\t\ta[to - 1] = v2;\r\n\t\t\tconst pivot = v1;\r\n\t\t\tlet low_end = from + 1; // Upper bound of elements lower than pivot.\r\n\t\t\tlet high_start = to - 1; // Lower bound of elements greater than pivot.\r\n\t\t\ta[third_index] = a[low_end];\r\n\t\t\ta[low_end] = pivot;\r\n\r\n\t\t\t// From low_end to i are elements equal to pivot.\r\n\t\t\t// From i to high_start are elements that haven't been compared yet.\r\n\t\t\tpartition: for (let i = low_end + 1; i < high_start; i++) {\r\n\t\t\t\tlet element = a[i];\r\n\t\t\t\tlet order = compareFunc(element, pivot);\r\n\t\t\t\tif (order < 0) {\r\n\t\t\t\t\ta[i] = a[low_end];\r\n\t\t\t\t\ta[low_end] = element;\r\n\t\t\t\t\tlow_end++;\r\n\t\t\t\t} else if (order > 0) {\r\n\t\t\t\t\tdo {\r\n\t\t\t\t\t\thigh_start--;\r\n\t\t\t\t\t\tif (high_start == i) break partition;\r\n\t\t\t\t\t\tconst top_elem = a[high_start];\r\n\t\t\t\t\t\torder = compareFunc(top_elem, pivot);\r\n\t\t\t\t\t} while (order > 0);\r\n\t\t\t\t\ta[i] = a[high_start];\r\n\t\t\t\t\ta[high_start] = element;\r\n\t\t\t\t\tif (order < 0) {\r\n\t\t\t\t\t\telement = a[i];\r\n\t\t\t\t\t\ta[i] = a[low_end];\r\n\t\t\t\t\t\ta[low_end] = element;\r\n\t\t\t\t\t\tlow_end++;\r\n\t\t\t\t\t}\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t\tif (to - high_start < low_end - from) {\r\n\t\t\t\tthis._quickSort(a, high_start, to, compareFunc);\r\n\t\t\t\tto = low_end;\r\n\t\t\t} else {\r\n\t\t\t\tthis._quickSort(a, from, low_end, compareFunc);\r\n\t\t\t\tfrom = high_start;\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\tprivate static _insertionSort<T>(a: T[], from: number, to: number, compareFunc: Function): void {\r\n\t\tfor (let i = from + 1; i < to; i++) {\r\n\t\t\tlet j;\r\n\t\t\tconst element = a[i];\r\n\t\t\tfor (j = i - 1; j >= from; j--) {\r\n\t\t\t\tconst tmp = a[j];\r\n\t\t\t\tconst order = compareFunc(tmp, element);\r\n\t\t\t\tif (order > 0) {\r\n\t\t\t\t\ta[j + 1] = tmp;\r\n\t\t\t\t} else {\r\n\t\t\t\t\tbreak;\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t\ta[j + 1] = element;\r\n\t\t}\r\n\t}\r\n}\r\n","import { Scene } from \"../Scene\";\r\nimport Camera from \"../camera/Camera\";\r\nimport Color from \"../math/Color\";\r\nimport Pass from \"../pass/Pass\";\r\nimport Context from \"../render/Context\";\r\nimport Texture from \"../render/Texture\";\r\nimport combine from \"../utils/combine\";\r\nimport CullingVolume from \"./CullingVolume\";\r\nimport LightManger from \"./LightManger\";\r\nimport RenderQueue from \"./RenderQueue\";\r\n\r\ninterface FrameStateOptions {\r\n\tbackground?: Background;\r\n}\r\n\r\nexport interface Background {\r\n\tvalue: Color | Texture;\r\n\topacity: number;\r\n}\r\n\r\nexport class FrameState {\r\n\tpublic background: Background;\r\n\tpublic pass: Pass;\r\n\tpublic renderQueue: RenderQueue;\r\n\tpublic drawCallnums: number;\r\n\tpublic geometryMemory: number;\r\n\tpublic textureMemory: number;\r\n\tpublic frameNumber: number;\r\n\tpublic cullingVolume: CullingVolume;\r\n\tpublic definesDirty: boolean;\r\n\tprivate _defines: object;\r\n\tconstructor(public context: Context, public lightManger?: LightManger, options: FrameStateOptions = {}) {\r\n\t\tthis.background = options.background;\r\n\t\tthis.renderQueue = new RenderQueue();\r\n\t\tthis.geometryMemory = 0;\r\n\t\tthis.textureMemory = 0;\r\n\t\tthis.frameNumber = 0;\r\n\t\tthis._defines = {};\r\n\t\tthis.definesDirty = true;\r\n\t}\r\n\tget defines() {\r\n\t\treturn this._defines;\r\n\t}\r\n\tset defines(value) {\r\n\t\tthis.definesDirty = true;\r\n\t\tthis._defines = combine(value, this._defines, false);\r\n\t}\r\n\tupdate(camera: Camera, options: FrameStateOptions = {}) {\r\n\t\tthis.background = options.background;\r\n\r\n\t\tthis.renderQueue.reset();\r\n\t\tthis?.lightManger?.update?.(this, camera);\r\n\t\tthis.cullingVolume = camera.getCullingVolume();\r\n\t\tthis.frameNumber += 1;\r\n\t}\r\n\r\n\tresetCullingVolume(camera: Camera) {\r\n\t\tthis.cullingVolume = camera.getCullingVolume();\r\n\t}\r\n\r\n\tstatic getFrameStateOptionsByScene(sceneInstance: Scene) {\r\n\t\treturn {\r\n\t\t\tbackground: sceneInstance.background\r\n\t\t};\r\n\t}\r\n}\r\n","import { LightType } from \"../core/WebGPUTypes\";\r\nimport Vector3 from \"../math/Vector3\";\r\nimport Vector4 from \"../math/Vector4\";\r\nimport { Light } from \"./Light\";\r\n\r\nexport class AmbientLight extends Light {\r\n\tprivate _colorAndIntensity: Vector4;\r\n\tconstructor(color: Vector3, intensity: number) {\r\n\t\tsuper(color, intensity);\r\n\t\tthis.lightType = LightType.AmbientLight;\r\n\t\tthis._colorAndIntensity = new Vector4(color.x, color.y, color.z, intensity);\r\n\t}\r\n\tget ColorAndIntensity() {\r\n\t\tthis._colorAndIntensity.set(this.color.x, this.color.y, this.color.z, this.intensity);\r\n\t\treturn this._colorAndIntensity;\r\n\t}\r\n}\r\n// light.color ).multiplyScalar( light.intensity * scaleFactor );\r\n","import { AmbientLight } from \"../light/AmbientLight\";\r\nimport { DirectionalLight } from \"../light/DirectionalLight\";\r\nimport { PointLight } from \"../light/PointLight\";\r\nimport { SpotLight } from \"../light/SpotLight\";\r\nimport { FrameState } from \"./FrameState\";\r\nimport ShaderData from \"../render/ShaderData\";\r\nimport {\r\n\tTextureUsage,\r\n\tBufferUsage,\r\n\tTextureFormat,\r\n\tCompareFunction,\r\n\tSamplerBindingType,\r\n\tTextureSampleType,\r\n\tTextureViewDimension,\r\n\tBufferBindingType\r\n} from \"./WebGPUConstant\";\r\nimport UniformBuffer from \"../render/UniformBuffer\";\r\nimport Camera from \"../camera/Camera\";\r\nimport { Light } from \"../light/Light\";\r\nimport Vector3 from \"../math/Vector3\";\r\nimport { LightMangerOptions, LightType } from \"../core/WebGPUTypes\";\r\nimport Texture from \"../render/Texture\";\r\nimport Sampler from \"../render/Sampler\";\r\nimport { UniformEnum } from \"../render/Uniforms\";\r\n\r\nexport default class LightManger {\r\n\tlightUniformBuffer: UniformBuffer;\r\n\tshadowUniformBuffer: UniformBuffer;\r\n\tpointLights: PointLight[];\r\n\r\n\tspotLights: SpotLight[];\r\n\r\n\tdirectLights: DirectionalLight[];\r\n\r\n\tambientLight: AmbientLight;\r\n\r\n\tlightShaderData: ShaderData;\r\n\r\n\tlightCountDirty: boolean;\r\n\r\n\tprivate openShadow: boolean;\r\n\tspotLightShadowMapTextureArray: Texture;\r\n\tpointLightShadowMapTextureArray: Texture;\r\n\tdirectLightShadowMapTextureArray: Texture;\r\n\t_testTexture: Texture;\r\n\r\n\tconstructor(options: LightMangerOptions) {\r\n\t\tthis.spotLights = [];\r\n\t\tthis.pointLights = [];\r\n\t\tthis.directLights = [];\r\n\t\tthis.ambientLight = new AmbientLight(new Vector3(1.0, 1.0, 1.0), 0.2);\r\n\t\tthis.lightCountDirty = true;\r\n\t\tthis.openShadow = options.openShadow;\r\n\t}\r\n\tupdate(frameState: FrameState, camera: Camera) {\r\n\t\tthis.checkLightShadowState();\r\n\t\tthis.updateLight(camera);\r\n\t}\r\n\tadd(light: Light) {\r\n\t\tthis.lightCountDirty = true;\r\n\t\tif (light.lightType == LightType.AmbientLight) {\r\n\t\t\tthis.ambientLight = <AmbientLight>light;\r\n\t\t} else if (light.lightType == LightType.DirectionalLight) {\r\n\t\t\tthis.directLights.push(<DirectionalLight>light);\r\n\t\t} else if (light.lightType == LightType.PointLight) {\r\n\t\t\tthis.pointLights.push(<PointLight>light);\r\n\t\t} else if (light.lightType == LightType.SpotLight) {\r\n\t\t\tthis.spotLights.push(<SpotLight>light);\r\n\t\t}\r\n\t}\r\n\tremove(light: Light) {\r\n\t\tthis.lightCountDirty = true;\r\n\t\tif (light.lightType == LightType.AmbientLight) {\r\n\t\t\tthis.ambientLight = new AmbientLight(new Vector3(1.0, 1.0, 1.0), 1.0);\r\n\t\t} else if (light.lightType == LightType.DirectionalLight) {\r\n\t\t\tthis.directLights.splice(this.directLights.indexOf(<DirectionalLight>light), 1);\r\n\t\t} else if (light.lightType == LightType.PointLight) {\r\n\t\t\tthis.pointLights.splice(this.pointLights.indexOf(<PointLight>light), 1);\r\n\t\t} else if (light.lightType == LightType.SpotLight) {\r\n\t\t\tthis.spotLights.splice(this.spotLights.indexOf(<SpotLight>light), 1);\r\n\t\t}\r\n\t}\r\n\tcheckLightShadowState() {\r\n\t\tconst lights = this.getAllLights();\r\n\t\tfor (let i = 0; i < lights.length; i++) {\r\n\t\t\tconst light = lights[i];\r\n\t\t\tif (light.shadowDirty) {\r\n\t\t\t\tlight.shadowDirty = false;\r\n\t\t\t\tthis.lightCountDirty = true;\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\r\n\tupdateLightShadow() {\r\n\t\tif (this.spotLightShadowMapTextureArray) this.spotLightShadowMapTextureArray.dirty = true;\r\n\r\n\t\tif (this.pointLightShadowMapTextureArray) this.pointLightShadowMapTextureArray.dirty = true;\r\n\r\n\t\tif (this.directLightShadowMapTextureArray) this.directLightShadowMapTextureArray.dirty = true;\r\n\t}\r\n\r\n\tprivate updateLight(camera: Camera) {\r\n\t\tif (this.lightCountDirty) {\r\n\t\t\tthis.lightCountDirty = false;\r\n\t\t\tif (this.lightShaderData) this.lightShaderData.destroy();\r\n\t\t\tthis.createLightShaderData();\r\n\t\t}\r\n\t}\r\n\tprivate createLightShaderData() {\r\n\t\tthis.lightShaderData = new ShaderData(\"light\", 0, 2, 2);\r\n\t\tthis.lightUniformBuffer = new UniformBuffer({\r\n\t\t\tlabel: \"light\",\r\n\t\t\ttype: BufferBindingType.ReadOnlyStorage,\r\n\t\t\tusage: BufferUsage.Storage | BufferUsage.CopyDst\r\n\t\t});\r\n\r\n\t\tthis.lightShaderData.setDefine(\"spotLightsCount\", this.spotLights.length);\r\n\t\tthis.lightShaderData.setDefine(\"pointLightsCount\", this.pointLights.length);\r\n\t\tthis.lightShaderData.setDefine(\"dirtectLightsCount\", this.directLights.length);\r\n\t\tthis.lightShaderData.setDefine(\"ambientLightCount\", 1);\r\n\t\tif (this.ambientLight)\r\n\t\t\tthis.lightUniformBuffer.setUniform(\r\n\t\t\t\t\"ambientLight\",\r\n\t\t\t\t() => {\r\n\t\t\t\t\treturn this.ambientLight.ColorAndIntensity;\r\n\t\t\t\t},\r\n\t\t\t\tUniformEnum.FloatVec4\r\n\t\t\t);\r\n\t\tif (this.spotLights.length) {\r\n\t\t\t//初始化聚光灯\r\n\t\t\tthis.lightUniformBuffer.setUniform(\r\n\t\t\t\t\"spotLights\",\r\n\t\t\t\t() => {\r\n\t\t\t\t\treturn this.spotLights;\r\n\t\t\t\t},\r\n\t\t\t\tUniformEnum.SpotLights,\r\n\t\t\t\tthis.spotLights.length\r\n\t\t\t);\r\n\t\t}\r\n\t\tif (this.pointLights.length) {\r\n\t\t\t//点光源\r\n\t\t\tthis.lightUniformBuffer.setUniform(\r\n\t\t\t\t\"pointLights\",\r\n\t\t\t\t() => {\r\n\t\t\t\t\treturn this.pointLights;\r\n\t\t\t\t},\r\n\t\t\t\tUniformEnum.PointLights,\r\n\t\t\t\tthis.pointLights.length\r\n\t\t\t);\r\n\t\t}\r\n\t\tif (this.directLights.length) {\r\n\t\t\t//方向光\r\n\t\t\tthis.lightUniformBuffer.setUniform(\r\n\t\t\t\t\"directLights\",\r\n\t\t\t\t() => {\r\n\t\t\t\t\treturn this.directLights;\r\n\t\t\t\t},\r\n\t\t\t\tUniformEnum.DirtectLights,\r\n\t\t\t\tthis.directLights.length\r\n\t\t\t);\r\n\t\t}\r\n\r\n\t\tshadowShaderData: {\r\n\t\t\tif (this.openShadow) {\r\n\t\t\t\tconst spotLightShadowMapTextureArray = (this.spotLightShadowMapTextureArray =\r\n\t\t\t\t\tthis.createShadowMapTextureArray(this.spotLights));\r\n\t\t\t\tconst pointLightShadowMapTextureArray = (this.pointLightShadowMapTextureArray =\r\n\t\t\t\t\tthis.createShadowMapTextureArray(this.pointLights));\r\n\t\t\t\tconst directLightShadowMapTextureArray = (this.directLightShadowMapTextureArray =\r\n\t\t\t\t\tthis.createShadowMapTextureArray(this.directLights));\r\n\t\t\t\tif (\r\n\t\t\t\t\t!spotLightShadowMapTextureArray &&\r\n\t\t\t\t\t!pointLightShadowMapTextureArray &&\r\n\t\t\t\t\t!directLightShadowMapTextureArray\r\n\t\t\t\t)\r\n\t\t\t\t\tbreak shadowShaderData;\r\n\r\n\t\t\t\t//define\r\n\t\t\t\tthis.lightShaderData.setDefine(\"openShadow\", this.openShadow);\r\n\r\n\t\t\t\t//shadowUniformBuffer\r\n\t\t\t\tthis.shadowUniformBuffer = new UniformBuffer({\r\n\t\t\t\t\tlabel: \"shadow\",\r\n\t\t\t\t\ttype: BufferBindingType.ReadOnlyStorage,\r\n\t\t\t\t\tusage: BufferUsage.Storage | BufferUsage.CopyDst\r\n\t\t\t\t});\r\n\r\n\t\t\t\t//matrix,near,far...\r\n\t\t\t\tconst spotLightWithShadowCount = this.setShadowUniform(\r\n\t\t\t\t\t\"spotLightShadows\",\r\n\t\t\t\t\tthis.spotLights,\r\n\t\t\t\t\tUniformEnum.SpotLightShadows\r\n\t\t\t\t);\r\n\t\t\t\tconst pointLightWithShadowCount = this.setShadowUniform(\r\n\t\t\t\t\t\"pointLightShadows\",\r\n\t\t\t\t\tthis.pointLights,\r\n\t\t\t\t\tUniformEnum.PointLightShadows\r\n\t\t\t\t);\r\n\t\t\t\tconst directLightWithShadowCount = this.setShadowUniform(\r\n\t\t\t\t\t\"directLightShadows\",\r\n\t\t\t\t\tthis.directLights,\r\n\t\t\t\t\tUniformEnum.DirtectLightShadows\r\n\t\t\t\t);\r\n\t\t\t\tthis.lightShaderData.setUniformBuffer(\"shadow\", this.shadowUniformBuffer);\r\n\r\n\t\t\t\tthis.lightShaderData.setDefine(\"spotLightShadowMapsCount\", spotLightWithShadowCount);\r\n\t\t\t\tthis.lightShaderData.setDefine(\"pointLightShadowMapsCount\", pointLightWithShadowCount);\r\n\t\t\t\tthis.lightShaderData.setDefine(\"directLightShadowMapsCount\", directLightWithShadowCount);\r\n\r\n\t\t\t\t//texture,sample\r\n\t\t\t\tif (spotLightShadowMapTextureArray !== undefined) {\r\n\t\t\t\t\tif (spotLightShadowMapTextureArray.textureProp.size.depth != spotLightWithShadowCount)\r\n\t\t\t\t\t\tconsole.warn(\"spotLightShadowMap align has problem\");\r\n\t\t\t\t\tthis.lightShaderData.setTexture(\"spotLightShadowMapTextureArray\", spotLightShadowMapTextureArray);\r\n\t\t\t\t\t// this._testTexture = spotLightShadowMapTextureArray\r\n\t\t\t\t}\r\n\t\t\t\tif (pointLightShadowMapTextureArray !== undefined) {\r\n\t\t\t\t\tif (pointLightShadowMapTextureArray.textureProp.size.depth != pointLightWithShadowCount)\r\n\t\t\t\t\t\tconsole.warn(\"pointLightShadowMap align has problem\");\r\n\t\t\t\t\tthis.lightShaderData.setTexture(\"pointLightShadowMapTextureArray\", pointLightShadowMapTextureArray);\r\n\t\t\t\t\t// this._testTexture = pointLightShadowMapTextureArray;\r\n\t\t\t\t}\r\n\t\t\t\tif (directLightShadowMapTextureArray !== undefined) {\r\n\t\t\t\t\tif (directLightShadowMapTextureArray.textureProp.size.depth != directLightWithShadowCount)\r\n\t\t\t\t\t\tconsole.warn(\"directLightShadowMap align has problem\");\r\n\t\t\t\t\tthis.lightShaderData.setTexture(\r\n\t\t\t\t\t\t\"directLightShadowMapTextureArray\",\r\n\t\t\t\t\t\tdirectLightShadowMapTextureArray\r\n\t\t\t\t\t);\r\n\t\t\t\t\t// this._testTexture = directLightShadowMapTextureArray\r\n\t\t\t\t}\r\n\t\t\t\tthis.lightShaderData.setSampler(\r\n\t\t\t\t\t\"shadowSampler\",\r\n\t\t\t\t\tnew Sampler({ compare: CompareFunction.Less }, { type: SamplerBindingType.Comparison })\r\n\t\t\t\t);\r\n\t\t\t\t// this.lightShaderData.setSampler(\"shadowSampler\", new Sampler());\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\tthis.lightShaderData.setUniformBuffer(\"light\", this.lightUniformBuffer);\r\n\t}\r\n\r\n\tpublic getAllLights(): Array<Light> {\r\n\t\tconst result = [];\r\n\t\treturn result.concat(this.spotLights, this.pointLights, this.directLights);\r\n\t}\r\n\r\n\tdestroy() {\r\n\t\tthis.lightShaderData.destroy();\r\n\t\tthis.lightUniformBuffer.destroy();\r\n\t}\r\n\r\n\tcreateShadowMapTextureArray(lights: Array<Light>) {\r\n\t\tif (lights.length <= 0) return undefined;\r\n\t\tconst shadowMapSources = [];\r\n\t\tfor (let i = 0; i < lights.length; i++) {\r\n\t\t\tconst light = lights[i];\r\n\t\t\tif (light.shadow) {\r\n\t\t\t\tconst shadowMapTexture = light.shadow.getShadowMapTexture();\r\n\t\t\t\tconst shadowMapSource = {\r\n\t\t\t\t\tsource: shadowMapTexture,\r\n\t\t\t\t\twidth: shadowMapTexture.textureProp.size.width,\r\n\t\t\t\t\theight: shadowMapTexture.textureProp.size.height,\r\n\t\t\t\t\tdepth: 1,\r\n\t\t\t\t\tx: 0,\r\n\t\t\t\t\ty: 0,\r\n\t\t\t\t\tz: i\r\n\t\t\t\t};\r\n\t\t\t\tshadowMapSources.push(shadowMapSource);\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\tif (shadowMapSources.length <= 0) return undefined;\r\n\r\n\t\tconst shadowMapTextureArray = new Texture({\r\n\t\t\tsize: {\r\n\t\t\t\twidth: shadowMapSources[0].width,\r\n\t\t\t\theight: shadowMapSources[0].height,\r\n\t\t\t\tdepth: shadowMapSources.length\r\n\t\t\t},\r\n\t\t\tfixedSize: true,\r\n\t\t\tsampleType: TextureSampleType.Depth,\r\n\t\t\tformat: TextureFormat.Depth24Plus,\r\n\t\t\tusage: TextureUsage.TextureBinding | TextureUsage.CopyDst,\r\n\t\t\tdata: shadowMapSources,\r\n\t\t\tviewFormats: TextureViewDimension.E2dArray\r\n\t\t});\r\n\r\n\t\treturn shadowMapTextureArray;\r\n\t}\r\n\r\n\tsetShadowUniform(uniformName: string, lights: Array<Light>, uniformType: UniformEnum) {\r\n\t\tif (lights.length) {\r\n\t\t\tconst lightWithShadowArray = [];\r\n\t\t\tfor (let i = 0; i < lights.length; i++) {\r\n\t\t\t\tconst light = lights[i];\r\n\t\t\t\tif (!light.shadow) continue;\r\n\t\t\t\tlightWithShadowArray.push(light);\r\n\t\t\t}\r\n\r\n\t\t\tthis.shadowUniformBuffer.setUniform(\r\n\t\t\t\tuniformName,\r\n\t\t\t\t() => {\r\n\t\t\t\t\treturn lightWithShadowArray;\r\n\t\t\t\t},\r\n\t\t\t\tuniformType,\r\n\t\t\t\tlightWithShadowArray.length\r\n\t\t\t);\r\n\r\n\t\t\treturn lightWithShadowArray.length;\r\n\t\t}\r\n\t}\r\n}\r\n","import Camera from \"../camera/Camera\";\nimport { Mesh } from \"../mesh/Mesh\";\nimport { FrameState } from \"./FrameState\";\nexport default class MeshManger {\n\tprivate _list: Map<string | number, Mesh>;\n\tconstructor() {\n\t\tthis._list = new Map();\n\t}\n\tget length() {\n\t\treturn this._list.size;\n\t}\n\tupdate(frameState: FrameState, camera: Camera): void {\n\t\tthis._list.forEach((instance) => {\n\t\t\tinstance.update(frameState, camera);\n\t\t});\n\t}\n\tadd(instance: Mesh): Mesh {\n\t\tif (this._list.get(instance.uid)) return this._list.get(instance.uid);\n\t\tthis._list.set(instance.uid, instance);\n\t\treturn instance;\n\t}\n\tremove(instance: Mesh): boolean {\n\t\tif (this._list.get(instance.uid)) {\n\t\t\tinstance.destroy();\n\t\t\tthis._list.delete(instance.uid);\n\t\t\treturn true;\n\t\t}\n\t\treturn false;\n\t}\n\tcontains(instance: Mesh) {\n\t\treturn !!this._list.get(instance.uid);\n\t}\n}\n","import { PassType } from \"../core/WebGPUTypes\";\r\nimport Attachment from \"./Attachment\";\r\nimport Context from \"./Context\";\r\nimport QuerySet from \"./QuerySet\";\r\nimport Texture from \"./Texture\";\r\n\r\nexport default class RenderTarget {\r\n\tpublic context: Context;\r\n\tprivate _renderPassDescriptor: GPURenderPassDescriptor;\r\n\tprivate renderEncoder: GPURenderPassEncoder;\r\n\tprivate commandEncoder: GPUCommandEncoder | null;\r\n\tprivate computeEncoder: GPUComputePassEncoder;\r\n\ttexture: any;\r\n\tconstructor(\r\n\t\tpublic type: PassType,\r\n\t\tpublic colorAttachments: Attachment[],\r\n\t\tpublic depthAttachment?: Attachment,\r\n\t\tpublic stencilAttachment?: Attachment,\r\n\t\tpublic querySet?: QuerySet\r\n\t) {\r\n\t\tthis.renderEncoder = undefined;\r\n\t\tthis.computeEncoder = undefined;\r\n\t\tthis._renderPassDescriptor = undefined;\r\n\t\tthis.commandEncoder = undefined;\r\n\t\tthis.context = undefined;\r\n\t}\r\n\tget renderPassDescriptor() {\r\n\t\tthis._renderPassDescriptor = this.getRenderPassDescriptor();\r\n\t\treturn this._renderPassDescriptor;\r\n\t}\r\n\tpublic getColorTexture(index = 0): Texture {\r\n\t\tconst colAtt = this.colorAttachments[index];\r\n\t\tif (colAtt) {\r\n\t\t\treturn colAtt.texture as Texture;\r\n\t\t} else {\r\n\t\t\treturn null;\r\n\t\t}\r\n\t}\r\n\tpublic getDepthTexture(): Texture {\r\n\t\tif (this.depthAttachment) {\r\n\t\t\treturn this.depthAttachment.texture as Texture;\r\n\t\t}\r\n\t}\r\n\tprivate getRenderPassDescriptor(): GPURenderPassDescriptor | null {\r\n\t\tthis.checkSize();\r\n\t\tthis.depthAttachment?.texture?.update(this.context);\r\n\t\treturn {\r\n\t\t\t...(this.colorAttachments && {\r\n\t\t\t\tcolorAttachments: this.colorAttachments.map((colorAttachment) => {\r\n\t\t\t\t\tcolorAttachment?.texture?.update && colorAttachment?.texture?.update(this.context);\r\n\t\t\t\t\treturn {\r\n\t\t\t\t\t\tview:\r\n\t\t\t\t\t\t\t// 暂时这么写\r\n\t\t\t\t\t\t\tcolorAttachment.texture.textureView || undefined,\r\n\t\t\t\t\t\tresolveTarget:\r\n\t\t\t\t\t\t\tcolorAttachment.resolveTarget != undefined\r\n\t\t\t\t\t\t\t\t? colorAttachment.resolveTarget.textureView\r\n\t\t\t\t\t\t\t\t: undefined,\r\n\t\t\t\t\t\tclearValue: colorAttachment.value,\r\n\t\t\t\t\t\tloadOp: colorAttachment.op,\r\n\t\t\t\t\t\tstoreOp: colorAttachment.storeOp\r\n\t\t\t\t\t} as GPURenderPassColorAttachment;\r\n\t\t\t\t})\r\n\t\t\t}),\r\n\t\t\t...((this.depthAttachment || this.stencilAttachment) && {\r\n\t\t\t\tdepthStencilAttachment: {\r\n\t\t\t\t\tview: this.depthAttachment?.texture?.textureView || undefined,\r\n\t\t\t\t\tdepthLoadOp: this.depthAttachment?.op || \"clear\",\r\n\t\t\t\t\tdepthClearValue: this.depthAttachment?.value || 1.0,\r\n\t\t\t\t\tdepthStoreOp: this.depthAttachment?.storeOp || \"store\",\r\n\t\t\t\t\tdepthReadOnly: this.depthAttachment?.readOnly || false\r\n\t\t\t\t\t// stencilLoadOp: this.stencilAttachment?.op || \"clear\",\r\n\t\t\t\t\t// stencilClearValue: this.stencilAttachment?.value || 0,\r\n\t\t\t\t\t// stencilStoreOp: this.stencilAttachment?.storeOp || \"store\",\r\n\t\t\t\t} as GPURenderPassDepthStencilAttachment\r\n\t\t\t})\r\n\t\t};\r\n\t}\r\n\r\n\tpublic beginRenderPassEncoder(context: Context) {\r\n\t\tif (!this.context) this.context = context;\r\n\t\tconst { device } = this.context;\r\n\t\tthis.commandEncoder = device.createCommandEncoder();\r\n\t\tthis.renderEncoder = this.commandEncoder.beginRenderPass(this.renderPassDescriptor);\r\n\t\treturn this.renderEncoder;\r\n\t}\r\n\tpublic endRenderPassEncoder() {\r\n\t\tthis.renderEncoder?.end();\r\n\t\tthis.context.device.queue.submit([this.commandEncoder.finish()]);\r\n\t\tthis.commandEncoder = null;\r\n\t\tthis.renderEncoder = null;\r\n\t}\r\n\tpublic beginComputePassEncoder(context: Context) {\r\n\t\tif (!this.context) this.context = context;\r\n\t\tconst { device } = this.context;\r\n\t\tthis.commandEncoder = device.createCommandEncoder();\r\n\t\tthis.computeEncoder = this.commandEncoder.beginComputePass();\r\n\t\treturn this.computeEncoder;\r\n\t}\r\n\tpublic endComputePassEncoder() {\r\n\t\tthis.computeEncoder?.end();\r\n\t\tthis.context.device.queue.submit([this.commandEncoder.finish()]);\r\n\t\tthis.commandEncoder = null;\r\n\t\tthis.renderEncoder = null;\r\n\t}\r\n\tprivate checkSize() {\r\n\t\tconst { width, height, depth } = this.context.presentationSize;\r\n\t\tif (this.depthAttachment.texture) {\r\n\t\t\tconst size = this.depthAttachment?.texture?.textureProp?.size;\r\n\t\t\tif (width != size?.width || height != size?.height || depth != size?.depth) {\r\n\t\t\t\tthis.depthAttachment.texture.setSize(width, height, depth);\r\n\t\t\t}\r\n\t\t}\r\n\t\tif (this.colorAttachments) {\r\n\t\t\tthis.colorAttachments.forEach((colorAttachment) => {\r\n\t\t\t\tif (colorAttachment.texture) {\r\n\t\t\t\t\tconst size = colorAttachment?.texture?.textureProp?.size;\r\n\t\t\t\t\tif (size && (width != size?.width || height != size?.height || depth != size?.depth))\r\n\t\t\t\t\t\tcolorAttachment.texture.setSize(width, height, depth);\r\n\t\t\t\t}\r\n\t\t\t});\r\n\t\t}\r\n\t}\r\n\tdestroy() {\r\n\t\tif (this.colorAttachments) {\r\n\t\t\tthis.colorAttachments.forEach((colorAttachment) => {\r\n\t\t\t\tif (colorAttachment.texture) {\r\n\t\t\t\t\tcolorAttachment.texture.destroy();\r\n\t\t\t\t}\r\n\t\t\t});\r\n\t\t}\r\n\t\tif (this.depthAttachment.texture) this.depthAttachment.texture.destroy();\r\n\t}\r\n}\r\n","import { TextureFormat, TextureUsage } from \"../core/WebGPUConstant\";\r\nimport Geometry from \"../geometry/Geometry\";\r\nimport ShaderMaterial from \"../material/ShaderMaterial\";\r\nimport { Mesh } from \"../mesh/Mesh\";\r\nimport Attachment from \"../render/Attachment\";\r\nimport { Float32Attribute } from \"../render/Attribute\";\r\nimport Context from \"../render/Context\";\r\nimport RenderTarget from \"../render/RenderTarget\";\r\nimport Sampler from \"../render/Sampler\";\r\nimport Texture from \"../render/Texture\";\r\nimport getVertFrag from \"../shader/Shaders\";\r\nexport default class ResolveFrame {\r\n\tcanvasRenderTarget: RenderTarget;\r\n\tmaterial: ShaderMaterial;\r\n\tgeometry: Geometry;\r\n\tquadMesh: Mesh;\r\n\tconstructor() {\r\n\t\tthis.geometry = new Geometry({});\r\n\t\tthis.geometry.setAttribute(\r\n\t\t\tnew Float32Attribute(\"position\", [-1.0, 1.0, -1.0, -1.0, 1.0, -1.0, 1.0, -1.0, 1.0, 1.0, -1.0, 1.0], 2)\r\n\t\t);\r\n\t\tthis.geometry.count = 6;\r\n\t\tconst shader = getVertFrag(\"resolve\", { positionLocation: 0 });\r\n\t\tthis.material = new ShaderMaterial({\r\n\t\t\ttype: \"resolve\",\r\n\t\t\tfrag: shader.frag,\r\n\t\t\tvert: shader.vert,\r\n\t\t\tuniforms: {\r\n\t\t\t\ttexture: {\r\n\t\t\t\t\ttype: \"texture\",\r\n\t\t\t\t\tvalue: undefined\r\n\t\t\t\t},\r\n\t\t\t\tsampler: {\r\n\t\t\t\t\ttype: \"sampler\",\r\n\t\t\t\t\tvalue: new Sampler({\r\n\t\t\t\t\t\tmagFilter: \"linear\",\r\n\t\t\t\t\t\tminFilter: \"linear\"\r\n\t\t\t\t\t})\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t});\r\n\t\tthis.quadMesh = new Mesh(this.geometry, this.material);\r\n\t}\r\n\trender(context: Context, colorTexture?: Texture) {\r\n\t\tif (!this.canvasRenderTarget) this.initRenderTarget(context);\r\n\t\t// this.material\r\n\t\tthis.material.uniforms.texture.value = colorTexture;\r\n\t\t// @ts-ignore\r\n\t\tthis.canvasRenderTarget.colorAttachments[0].texture = {\r\n\t\t\ttextureView: context.context.getCurrentTexture().createView()\r\n\t\t};\r\n\t\tthis.material.update(undefined, this.quadMesh);\r\n\r\n\t\tconst drawComand = this.quadMesh.getDrawCommand();\r\n\r\n\t\tconst currentRenderPassEncoder = this.canvasRenderTarget.beginRenderPassEncoder(context);\r\n\r\n\t\tdrawComand.render(context, currentRenderPassEncoder);\r\n\r\n\t\tthis.canvasRenderTarget.endRenderPassEncoder();\r\n\t}\r\n\tprivate initRenderTarget(context: Context) {\r\n\t\tconst { width, height, depth } = context.presentationSize;\r\n\t\tconst colorAttachment = new Attachment(\r\n\t\t\t{ r: 0.0, g: 0.0, b: 0.0, a: 0 },\r\n\t\t\t{\r\n\t\t\t\t// @ts-ignore\r\n\t\t\t\ttexture: {\r\n\t\t\t\t\ttextureView: undefined\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t);\r\n\t\tconst depthTexture = new Texture({\r\n\t\t\tlabel: \"resolveDepth\",\r\n\t\t\tsize: { width, height, depth },\r\n\t\t\tformat: TextureFormat.Depth24Plus,\r\n\t\t\tusage: TextureUsage.RenderAttachment\r\n\t\t});\r\n\t\tconst depthAttachment = new Attachment(1.0, { texture: depthTexture });\r\n\t\tthis.canvasRenderTarget = new RenderTarget(\"render\", [colorAttachment], depthAttachment);\r\n\t}\r\n}\r\n","import Context from \"../render/Context\";\r\nimport Texture from \"../render/Texture\";\r\nimport PostEffect from \"./PostEffect\";\r\nimport ResolveFrame from \"./ResolveFrame\";\r\n\r\nexport default class PostEffectCollection {\r\n\tprivate _postEffects: Map<string, PostEffect>;\r\n\tpublic currentColorTexture: Texture;\r\n\tprivate resolveFrame: ResolveFrame;\r\n\tconstructor() {\r\n\t\tthis._postEffects = new Map();\r\n\t\tthis.currentColorTexture = undefined;\r\n\t\tthis.resolveFrame = new ResolveFrame();\r\n\t}\r\n\tadd(postEffect: PostEffect) {\r\n\t\tthis._postEffects.set(postEffect.id, postEffect);\r\n\t}\r\n\tremove(postEffect: PostEffect) {\r\n\t\tthis._postEffects.delete(postEffect.id);\r\n\t\tpostEffect.destroy();\r\n\t}\r\n\trender(context: Context, colorTexture: Texture): void {\r\n\t\tthis.currentColorTexture = colorTexture;\r\n\t\tthis._postEffects.forEach((postEffect) => {\r\n\t\t\tthis.currentColorTexture = postEffect.render(context, this.currentColorTexture);\r\n\t\t});\r\n\t\tthis.resolveFrame.render(context, this.currentColorTexture);\r\n\t}\r\n\tsetResolveFrameDirty(value: boolean) {\r\n\t\tthis.resolveFrame.material.dirty = value;\r\n\t}\r\n\tprivate postEffectsSort() {\r\n\t\t// this._postEffects.sort()\r\n\t}\r\n}\r\n","import { FrameState } from \"../core/FrameState.js\";\r\nimport { Material } from \"../material/Material.js\";\r\nimport Context from \"../render/Context.js\";\r\nimport { Target } from \"../render/RenderState\";\r\nimport RenderTarget from \"../render/RenderTarget.js\";\r\nimport Texture from \"../render/Texture.js\";\r\n\r\nclass Pass {\r\n\tpublic renderTarget: RenderTarget;\r\n\tpublic computeTarget: RenderTarget;\r\n\tpublic context: Context;\r\n\tpublic overrideMaterial?: Material;\r\n\tpublic colorTargets?: Array<Target>;\r\n\tpublic passRenderEncoder: GPURenderPassEncoder | null;\r\n\tpublic passComputeEncoder: GPUComputePassEncoder;\r\n\tconstructor(context: Context) {\r\n\t\tthis.context = context;\r\n\t}\r\n\trender(frameState: FrameState): void {}\r\n\tbeforeRender(options?: any) {\r\n\t\tthis.passRenderEncoder = this.renderTarget.beginRenderPassEncoder(this.context);\r\n\t\tif (this.computeTarget) this.passComputeEncoder = this.computeTarget.beginComputePassEncoder(this.context);\r\n\t}\r\n\tgetColorTexture(index = 0): Texture {\r\n\t\treturn this.renderTarget.getColorTexture(index) as Texture;\r\n\t}\r\n\tgetDepthTexture(): Texture | { gpuTexture: GPUTexture } {\r\n\t\treturn this.renderTarget.getDepthTexture();\r\n\t}\r\n\tafterRender() {\r\n\t\tthis.renderTarget.endRenderPassEncoder();\r\n\t\tif (this.computeTarget) this.computeTarget.endComputePassEncoder();\r\n\t}\r\n}\r\n\r\nexport default Pass;\r\n","import Camera from \"../camera/Camera\";\r\nimport { FrameState } from \"../core/FrameState\";\r\nimport { TextureFormat, TextureUsage } from \"../core/WebGPUConstant\";\r\nimport Color from \"../math/Color\";\r\nimport Attachment from \"../render/Attachment\";\r\nimport Context from \"../render/Context\";\r\nimport DrawCommand from \"../render/DrawCommand\";\r\nimport RenderTarget from \"../render/RenderTarget\";\r\nimport Texture from \"../render/Texture\";\r\nimport Pass from \"./Pass\";\r\n\r\nexport class BasicPass extends Pass {\r\n\tskyboxDrawComand: DrawCommand;\r\n\tconstructor(context: Context) {\r\n\t\tsuper(context);\r\n\t\tthis.init(context);\r\n\t}\r\n\r\n\tbeforeRender(frameState: FrameState) {\r\n\t\tthis.updateRenderTarget(frameState);\r\n\r\n\t\tsuper.beforeRender();\r\n\t}\r\n\r\n\trender(frameState: FrameState, camera?: Camera) {\r\n\t\tconst { renderQueue, lightManger } = frameState;\r\n\r\n\t\trenderQueue.sort();\r\n\t\trenderQueue.preRender(camera, this.context, this.passRenderEncoder);\r\n\t\trenderQueue.transparentRender(camera, this.context, this.passRenderEncoder, undefined, undefined, lightManger);\r\n\t\trenderQueue.opaqueRender(camera, this.context, this.passRenderEncoder, undefined, undefined, lightManger);\r\n\t\trenderQueue.debugQueueRender(camera, this.context, this.passRenderEncoder);\r\n\t}\r\n\tprivate init(context: Context) {\r\n\t\tthis.createRenderTarget(context);\r\n\t}\r\n\tprivate createRenderTarget(context: Context) {\r\n\t\tconst { width, height, depth } = this.context.presentationSize;\r\n\t\tconst colorTexture = new Texture({\r\n\t\t\tlabel: \"basicPassColor\",\r\n\t\t\tsize: { width, height, depth },\r\n\t\t\tformat: this.context.presentationFormat,\r\n\t\t\tusage: TextureUsage.RenderAttachment | TextureUsage.TextureBinding\r\n\t\t});\r\n\t\tconst depthTexture = new Texture({\r\n\t\t\tlabel: \"basicPassDepth\",\r\n\t\t\tsize: { width, height, depth },\r\n\t\t\tformat: TextureFormat.Depth24Plus,\r\n\t\t\tusage: TextureUsage.RenderAttachment\r\n\t\t});\r\n\t\tconst colorAttachment = new Attachment({ r: 0.0, g: 0.0, b: 0.0, a: 0.0 }, { texture: colorTexture });\r\n\t\tconst depthAttachment = new Attachment(1.0, { texture: depthTexture });\r\n\t\tthis.renderTarget = new RenderTarget(\"render\", [colorAttachment], depthAttachment);\r\n\t}\r\n\r\n\tprivate updateRenderTarget(frameState: FrameState) {\r\n\t\tif (frameState?.background?.value instanceof Color) {\r\n\t\t\tconst { red, green, blue } = frameState.background.value;\r\n\t\t\tconst opacity = frameState.background?.opacity;\r\n\t\t\tconst clearValue = {\r\n\t\t\t\tr: red,\r\n\t\t\t\tg: green,\r\n\t\t\t\tb: blue,\r\n\t\t\t\ta: opacity ?? 1.0\r\n\t\t\t};\r\n\t\t\tthis.renderTarget.colorAttachments[0].value = clearValue;\r\n\t\t}\r\n\t}\r\n}\r\n","import defined from \"../utils/defined\";\r\nimport GMath from \"./Math\";\r\nimport Matrix4 from \"./Matrix4\";\r\nimport Vector3 from \"./Vector3\";\r\nimport Vector4 from \"./Vector4\";\r\n\r\n/**\r\n * A plane in Hessian Normal Form defined by\r\n * <pre>\r\n * ax + by + cz + d = 0\r\n * </pre>\r\n * where (a, b, c) is the plane's <code>normal</code>, d is the signed\r\n * <code>distance</code> to the plane, and (x, y, z) is any point on\r\n * the plane.\r\n *\r\n * @alias Plane\r\n * @constructor\r\n *\r\n * @param {Vector3} normal The plane's normal (normalized).\r\n * @param {Number} distance The shortest distance from the origin to the plane.  The sign of\r\n * @example\r\n * // The plane x=0\r\n * const plane = new Plane(Vector3.UNIT_X, 0.0);\r\n *\r\n * @exception {DeveloperError} Normal must be normalized\r\n */\r\nclass Plane {\r\n\tnormal: Vector3;\r\n\tdistance: number;\r\n\tpublic static ORIGIN_XY_PLANE = Object.freeze(new Plane(Vector3.UNIT_Z, 0.0));\r\n\r\n\tpublic static ORIGIN_YZ_PLANE = Object.freeze(new Plane(Vector3.UNIT_X, 0.0));\r\n\r\n\tpublic static ORIGIN_ZX_PLANE = Object.freeze(new Plane(Vector3.UNIT_Y, 0.0));\r\n\tconstructor(normal: Vector3, distance: number) {\r\n\t\tthis.normal = Vector3.clone(normal);\r\n\r\n\t\tthis.distance = distance;\r\n\t}\r\n\tnormalize() {\r\n\t\tconst inverseNormalLength = 1.0 / this.normal.length();\r\n\t\tthis.normal = Vector3.multiplyByScalar(this.normal, inverseNormalLength, this.normal);\r\n\t\tthis.distance *= inverseNormalLength;\r\n\t\treturn this;\r\n\t}\r\n\r\n\tstatic fromPointNormal(point: Vector3, normal: Vector3, result: Plane): Plane {\r\n\t\tif (!GMath.equalsEpsilon(Vector3.magnitude(normal), 1.0, GMath.EPSILON6)) {\r\n\t\t\tthrow new Error(\"normal must be normalized.\");\r\n\t\t}\r\n\t\t// >>includeEnd('debug');\r\n\r\n\t\tconst distance = -Vector3.dot(normal, point);\r\n\r\n\t\tif (!defined(result)) {\r\n\t\t\treturn new Plane(normal, distance);\r\n\t\t}\r\n\r\n\t\tVector3.clone(normal, result.normal);\r\n\t\tresult.distance = distance;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic fromVector4(coefficients: Vector4, result: Plane): Plane {\r\n\t\tconst normal = Vector3.fromVector4(coefficients, scratchNormal);\r\n\t\tconst distance = coefficients.w;\r\n\r\n\t\t// >>includeStart('debug', pragmas.debug);\r\n\t\tif (!GMath.equalsEpsilon(Vector3.magnitude(normal), 1.0, GMath.EPSILON6)) {\r\n\t\t\tthrow new Error(\"normal must be normalized.\");\r\n\t\t}\r\n\t\t// >>includeEnd('debug');\r\n\r\n\t\tif (!defined(result)) {\r\n\t\t\treturn new Plane(normal, distance);\r\n\t\t}\r\n\t\tVector3.clone(normal, result.normal);\r\n\t\tresult.distance = distance;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic getPointDistance(plane: Plane, point: Vector3): number {\r\n\t\treturn Vector3.dot(plane.normal, point) + plane.distance;\r\n\t}\r\n\r\n\tstatic projectPointOntoPlane(plane: Plane, point: Vector3, result: Vector3): Vector3 {\r\n\t\tif (!defined(result)) {\r\n\t\t\tresult = new Vector3();\r\n\t\t}\r\n\r\n\t\t// projectedPoint = point - (normal.point + scale) * normal\r\n\t\tconst pointDistance = Plane.getPointDistance(plane, point);\r\n\t\tconst scaledNormal = Vector3.multiplyByScalar(plane.normal, pointDistance, scratchCartesian);\r\n\r\n\t\treturn Vector3.subtract(point, scaledNormal, result);\r\n\t}\r\n\r\n\tstatic transform(plane: Plane, transform: Matrix4, result: Plane): Plane {\r\n\t\tconst normal = plane.normal;\r\n\t\tconst distance = plane.distance;\r\n\t\tconst inverseTranspose = Matrix4.inverseTranspose(transform, scratchInverseTranspose);\r\n\t\tlet planeAsCartesian4 = Vector4.fromElements(normal.x, normal.y, normal.z, distance, scratchPlaneCartesian4);\r\n\t\tplaneAsCartesian4 = Matrix4.multiplyByVector(inverseTranspose, planeAsCartesian4, planeAsCartesian4);\r\n\r\n\t\t// Convert the transformed plane to Hessian Normal Form\r\n\t\tconst transformedNormal = Vector3.fromVector4(planeAsCartesian4, scratchTransformNormal);\r\n\r\n\t\tplaneAsCartesian4 = Vector4.divideByScalar(\r\n\t\t\tplaneAsCartesian4,\r\n\t\t\tVector3.magnitude(transformedNormal),\r\n\t\t\tplaneAsCartesian4\r\n\t\t);\r\n\r\n\t\treturn Plane.fromVector4(planeAsCartesian4, result);\r\n\t}\r\n\r\n\tstatic clone(plane: Plane, result: Plane): Plane {\r\n\t\tif (!defined(result)) {\r\n\t\t\treturn new Plane(plane.normal, plane.distance);\r\n\t\t}\r\n\r\n\t\tVector3.clone(plane.normal, result.normal);\r\n\t\tresult.distance = plane.distance;\r\n\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic equals(left: Plane, right: Plane): boolean {\r\n\t\treturn left.distance === right.distance && Vector3.equals(left.normal, right.normal);\r\n\t}\r\n}\r\nconst scratchNormal = new Vector3();\r\nconst scratchCartesian = new Vector3();\r\nconst scratchInverseTranspose = new Matrix4();\r\nconst scratchPlaneCartesian4 = new Vector4();\r\nconst scratchTransformNormal = new Vector3();\r\n\r\nexport default Plane;\r\n","import Vector3 from \"../math/Vector3\";\r\nimport Vector4 from \"../math/Vector4\";\r\nimport defaultValue from \"../utils/defaultValue\";\r\nimport defined from \"../utils/defined\";\r\nimport { Intersect } from \"./WebGPUConstant\";\r\nimport Plane from \"../math/Plane\";\r\n\r\n/**\r\n * The culling volume defined by planes.\r\n *\r\n * @alias CullingVolume\r\n * @constructor\r\n *\r\n * @param {Vector4[]} [planes] An array of clipping planes.\r\n */\r\nclass CullingVolume {\r\n\tplanes: Plane[];\r\n\r\n\tpublic static MASK_OUTSIDE = 0xffffffff;\r\n\r\n\tpublic static MASK_INSIDE = 0x00000000;\r\n\r\n\tpublic static MASK_INDETERMINATE = 0x7fffffff;\r\n\r\n\tconstructor(planes?: Plane[]) {\r\n\t\tthis.planes = defaultValue(planes, [\r\n\t\t\tnew Plane(Vector3.UNIT_Z, 0.0),\r\n\t\t\tnew Plane(Vector3.UNIT_Z, 0.0),\r\n\t\t\tnew Plane(Vector3.UNIT_Z, 0.0),\r\n\t\t\tnew Plane(Vector3.UNIT_Z, 0.0),\r\n\t\t\tnew Plane(Vector3.UNIT_Z, 0.0),\r\n\t\t\tnew Plane(Vector3.UNIT_Z, 0.0)\r\n\t\t]);\r\n\t}\r\n\t/**\r\n\t * Constructs a culling volume from a bounding sphere. Creates six planes that create a box containing the sphere.\r\n\t * The planes are aligned to the x, y, and z axes in world coordinates.\r\n\t *\r\n\t * @param {BoundingSphere} boundingSphere The bounding sphere used to create the culling volume.\r\n\t * @param {CullingVolume} [result] The object onto which to store the result.\r\n\t * @returns {CullingVolume} The culling volume created from the bounding sphere.\r\n\t */\r\n\tstatic fromBoundingSphere(boundingSphere, result) {\r\n\t\tif (!defined(boundingSphere)) {\r\n\t\t\tthrow new Error(\"boundingSphere is required.\");\r\n\t\t}\r\n\t\tif (!defined(result)) {\r\n\t\t\tresult = new CullingVolume();\r\n\t\t}\r\n\r\n\t\tconst length = faces.length;\r\n\t\tconst planes = result.planes;\r\n\t\tplanes.length = 2 * length;\r\n\r\n\t\tconst center = boundingSphere.center;\r\n\t\tconst radius = boundingSphere.radius;\r\n\r\n\t\tlet planeIndex = 0;\r\n\r\n\t\tfor (let i = 0; i < length; ++i) {\r\n\t\t\tconst faceNormal = faces[i];\r\n\r\n\t\t\tlet plane0 = planes[planeIndex];\r\n\t\t\tlet plane1 = planes[planeIndex + 1];\r\n\r\n\t\t\tif (!defined(plane0)) {\r\n\t\t\t\tplane0 = planes[planeIndex] = new Vector4();\r\n\t\t\t}\r\n\t\t\tif (!defined(plane1)) {\r\n\t\t\t\tplane1 = planes[planeIndex + 1] = new Vector4();\r\n\t\t\t}\r\n\r\n\t\t\tVector3.multiplyByScalar(faceNormal, -radius, scratchPlaneCenter);\r\n\t\t\tVector3.add(center, scratchPlaneCenter, scratchPlaneCenter);\r\n\r\n\t\t\tplane0.x = faceNormal.x;\r\n\t\t\tplane0.y = faceNormal.y;\r\n\t\t\tplane0.z = faceNormal.z;\r\n\t\t\tplane0.w = -Vector3.dot(faceNormal, scratchPlaneCenter);\r\n\r\n\t\t\tVector3.multiplyByScalar(faceNormal, radius, scratchPlaneCenter);\r\n\t\t\tVector3.add(center, scratchPlaneCenter, scratchPlaneCenter);\r\n\r\n\t\t\tplane1.x = -faceNormal.x;\r\n\t\t\tplane1.y = -faceNormal.y;\r\n\t\t\tplane1.z = -faceNormal.z;\r\n\t\t\tplane1.w = -Vector3.dot(Vector3.negate(faceNormal, scratchPlaneNormal), scratchPlaneCenter);\r\n\r\n\t\t\tplaneIndex += 2;\r\n\t\t}\r\n\r\n\t\treturn result;\r\n\t}\r\n\t/**\r\n\t * Determines whether a bounding volume intersects the culling volume.\r\n\t *\r\n\t * @param {Object} boundingVolume The bounding volume whose intersection with the culling volume is to be tested.\r\n\t * @returns {Intersect}  Intersect.OUTSIDE, Intersect.INTERSECTING, or Intersect.INSIDE.\r\n\t */\r\n\tcomputeVisibility(boundingVolume) {\r\n\t\tif (!defined(boundingVolume)) {\r\n\t\t\tthrow new Error(\"boundingVolume is required.\");\r\n\t\t}\r\n\t\tconst planes = this.planes;\r\n\t\tlet intersecting = false;\r\n\t\tfor (let k = 0, len = planes.length; k < len; ++k) {\r\n\t\t\tconst result = boundingVolume.intersectPlane(planes[k]);\r\n\t\t\tif (result === Intersect.OUTSIDE) {\r\n\t\t\t\treturn Intersect.OUTSIDE;\r\n\t\t\t} else if (result === Intersect.INTERSECTING) {\r\n\t\t\t\tintersecting = true;\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\treturn intersecting ? Intersect.INTERSECTING : Intersect.INSIDE;\r\n\t}\r\n}\r\n\r\nconst faces = [new Vector3(), new Vector3(), new Vector3()];\r\nVector3.clone(Vector3.UNIT_X, faces[0]);\r\nVector3.clone(Vector3.UNIT_Y, faces[1]);\r\nVector3.clone(Vector3.UNIT_Z, faces[2]);\r\n\r\nconst scratchPlaneCenter = new Vector3();\r\nconst scratchPlaneNormal = new Vector3();\r\nconst scratchPlanes = new Vector4();\r\nconst scratchPlane = new Plane(new Vector3(1.0, 0.0, 0.0), 0.0);\r\n\r\nexport default CullingVolume;\r\n","import CullingVolume from \"../core/CullingVolume\";\r\nimport RenderObject from \"../core/RenderObject\";\r\nimport { RenderObjectType } from \"../core/WebGPUTypes\";\r\nimport Matrix4 from \"../math/Matrix4\";\r\nimport Plane from \"../math/Plane\";\r\nimport Vector3 from \"../math/Vector3\";\r\nimport ShaderData from \"../render/ShaderData\";\r\nimport UniformBuffer from \"../render/UniformBuffer\";\r\nimport { UniformEnum } from \"../render/Uniforms\";\r\n\r\nexport default class Camera extends RenderObject {\r\n\tprivate _viewMatrix: Matrix4;\r\n\tprotected _projectionMatrix: Matrix4;\r\n\tprivate _vpMatrix: Matrix4;\r\n\tcullingVolume: CullingVolume;\r\n\tprojectMatrixDirty: boolean;\r\n\tshaderData: ShaderData;\r\n\tnear: number;\r\n\tfar: number;\r\n\tconstructor() {\r\n\t\tsuper();\r\n\t\tthis._viewMatrix = undefined;\r\n\t\tthis.type = RenderObjectType.Camera;\r\n\t\tthis.cullingVolume = new CullingVolume();\r\n\t\tthis._viewMatrix = new Matrix4();\r\n\t\tthis._vpMatrix = new Matrix4();\r\n\t\tthis.projectMatrixDirty = true;\r\n\t\tthis.createShaderData();\r\n\t}\r\n\tget viewMatrix() {\r\n\t\tthis.updateMatrix();\r\n\t\tMatrix4.inverse(this.modelMatrix, this._viewMatrix);\r\n\t\treturn this._viewMatrix;\r\n\t}\r\n\tget projectionMatrix() {\r\n\t\tthis.updateProjectionMatrix();\r\n\t\treturn this._projectionMatrix;\r\n\t}\r\n\r\n\tget vpMatrix() {\r\n\t\tMatrix4.multiply(this.projectionMatrix, this.viewMatrix, this._vpMatrix);\r\n\t\treturn this._vpMatrix;\r\n\t}\r\n\r\n\tget inverseViewMatrix() {\r\n\t\tthis.updateMatrix();\r\n\t\treturn this.modelMatrix;\r\n\t}\r\n\tpublic updateProjectionMatrix() {}\r\n\t/**\r\n\t * get a culling volume for this frustum.\r\n\t */\r\n\tgetCullingVolume() {\r\n\t\tconst cloneViewMatrix = this.viewMatrix.clone(new Matrix4());\r\n\t\tconst vpMatrix = Matrix4.multiply(this.projectionMatrix, cloneViewMatrix, new Matrix4());\r\n\t\tconst planes = this.cullingVolume.planes;\r\n\t\tconst me = vpMatrix;\r\n\t\tconst me0 = me[0],\r\n\t\t\tme1 = me[1],\r\n\t\t\tme2 = me[2],\r\n\t\t\tme3 = me[3];\r\n\t\tconst me4 = me[4],\r\n\t\t\tme5 = me[5],\r\n\t\t\tme6 = me[6],\r\n\t\t\tme7 = me[7];\r\n\t\tconst me8 = me[8],\r\n\t\t\tme9 = me[9],\r\n\t\t\tme10 = me[10],\r\n\t\t\tme11 = me[11];\r\n\t\tconst me12 = me[12],\r\n\t\t\tme13 = me[13],\r\n\t\t\tme14 = me[14],\r\n\t\t\tme15 = me[15];\r\n\t\tplanes[0] = new Plane(new Vector3(me3 - me0, me7 - me4, me11 - me8), me15 - me12);\r\n\t\tplanes[0].normalize();\r\n\t\tplanes[1] = new Plane(new Vector3(me3 + me0, me7 + me4, me11 + me8), me15 + me12);\r\n\t\tplanes[1].normalize();\r\n\r\n\t\tplanes[2] = new Plane(new Vector3(me3 + me1, me7 + me5, me11 + me9), me15 + me13);\r\n\t\tplanes[2].normalize();\r\n\r\n\t\tplanes[3] = new Plane(new Vector3(me3 - me1, me7 - me5, me11 - me9), me15 - me13);\r\n\t\tplanes[3].normalize();\r\n\r\n\t\tplanes[4] = new Plane(new Vector3(me3 - me2, me7 - me6, me11 - me10), me15 - me14);\r\n\t\tplanes[4].normalize();\r\n\r\n\t\tplanes[5] = new Plane(new Vector3(me3 + me2, me7 + me6, me11 + me10), me15 + me14);\r\n\t\tplanes[5].normalize();\r\n\r\n\t\treturn this.cullingVolume;\r\n\t}\r\n\r\n\tcreateShaderData() {\r\n\t\tthis.shaderData = new ShaderData(\"camera\", 0, 1, 1);\r\n\t\tconst uniformBuffer = new UniformBuffer({ label: \"camera\" });\r\n\t\tuniformBuffer.setUniform(\r\n\t\t\t\"projectionMatrix\",\r\n\t\t\t() => {\r\n\t\t\t\treturn this.projectionMatrix;\r\n\t\t\t},\r\n\t\t\tUniformEnum.Mat4\r\n\t\t);\r\n\t\tuniformBuffer.setUniform(\r\n\t\t\t\"viewMatrix\",\r\n\t\t\t() => {\r\n\t\t\t\treturn this.viewMatrix;\r\n\t\t\t},\r\n\t\t\tUniformEnum.Mat4\r\n\t\t);\r\n\t\tuniformBuffer.setUniform(\r\n\t\t\t\"inverseViewMatrix\",\r\n\t\t\t() => {\r\n\t\t\t\treturn this.inverseViewMatrix;\r\n\t\t\t},\r\n\t\t\tUniformEnum.Mat4\r\n\t\t);\r\n\t\tuniformBuffer.setUniform(\r\n\t\t\t\"position\",\r\n\t\t\t() => {\r\n\t\t\t\treturn this.position;\r\n\t\t\t},\r\n\t\t\tUniformEnum.FloatVec3\r\n\t\t);\r\n\t\tthis.shaderData.setUniformBuffer(\"camera\", uniformBuffer);\r\n\t}\r\n}\r\n","import CullingVolume from \"../core/CullingVolume\";\r\nimport GMath from \"../math/Math\";\r\nimport Matrix4 from \"../math/Matrix4\";\r\nimport Camera from \"./Camera\";\r\nexport default class PerspectiveCamera extends Camera {\r\n\txOffset: number;\r\n\tyOffset: number;\r\n\tcullingVolume: CullingVolume;\r\n\tprivate _aspect: number;\r\n\tprivate _fov: number;\r\n\theight: number;\r\n\twidth: number;\r\n\tisPerspectiveCamera: boolean;\r\n\tnear: number;\r\n\tfar: number;\r\n\ttop: number;\r\n\tleft: number;\r\n\tconstructor(fov = 50, aspect = 1, near = 0.1, far = 2000) {\r\n\t\tsuper();\r\n\t\tthis._aspect = aspect;\r\n\t\tthis.fov = fov;\r\n\t\tthis.near = near;\r\n\t\tthis.far = far;\r\n\t\tthis.xOffset = 0;\r\n\t\tthis.yOffset = 0;\r\n\t\tthis.projectMatrixDirty = true;\r\n\t\tthis.updateCameraParms();\r\n\t\tthis.cullingVolume = new CullingVolume();\r\n\t\tthis.isPerspectiveCamera = true;\r\n\t}\r\n\tget aspect(): number {\r\n\t\treturn this._aspect;\r\n\t}\r\n\r\n\tset aspect(v: number) {\r\n\t\tthis.projectMatrixDirty = true;\r\n\t\tthis._aspect = v;\r\n\t}\r\n\tget fov(): number {\r\n\t\treturn this._fov;\r\n\t}\r\n\r\n\tset fov(v: number) {\r\n\t\tthis.projectMatrixDirty = true;\r\n\t\tthis._fov = v;\r\n\t}\r\n\tprivate updateCameraParms() {\r\n\t\tthis.top = this.near * Math.tan(0.5 * GMath.RADIANS_PER_DEGREE * this.fov);\r\n\t\tthis.height = 2 * this.top;\r\n\t\tthis.width = this.aspect * this.height;\r\n\t\tthis.left = -0.5 * this.width;\r\n\t}\r\n\tpublic updateProjectionMatrix() {\r\n\t\tif (this.projectMatrixDirty) {\r\n\t\t\tthis.updateCameraParms();\r\n\t\t\tthis._projectionMatrix = Matrix4.makePerspective(\r\n\t\t\t\tthis.left,\r\n\t\t\t\tthis.left + this.width,\r\n\t\t\t\tthis.top,\r\n\t\t\t\tthis.top - this.height,\r\n\t\t\t\tthis.near,\r\n\t\t\t\tthis.far\r\n\t\t\t);\r\n\t\t\tthis.projectMatrixDirty = false;\r\n\t\t}\r\n\t}\r\n}\r\n","import { BufferUsage } from \"../core/WebGPUConstant\";\r\nimport Matrix4 from \"../math/Matrix4\";\r\nimport ShaderData from \"../render/ShaderData\";\r\nimport UniformBuffer from \"../render/UniformBuffer\";\r\nimport { UniformEnum } from \"../render/Uniforms\";\r\nimport PerspectiveCamera from \"./PerspectiveCamera\";\r\n\r\nexport default class PointLightShadowCamera extends PerspectiveCamera {\r\n\tpublic vpMatrixArray: Array<Matrix4>;\r\n\tpublic vpMatrixIndexArray: Array<number>;\r\n\r\n\tconstructor(fov = 50, aspect = 1, near = 0.1, far = 2000) {\r\n\t\tsuper(fov, aspect, near, far);\r\n\t\tthis.vpMatrixArray = [new Matrix4(), new Matrix4(), new Matrix4(), new Matrix4(), new Matrix4(), new Matrix4()];\r\n\t}\r\n\r\n\t// createShaderData() {\r\n\t// \tthis.shaderData = new ShaderData(\"camera\", 0, 1, 1);\r\n\r\n\t// \tconst uniformBuffer = new UniformBuffer({\r\n\t// \t\tlabel: \"pointLightShadowCamera\",\r\n\t// \t\ttype: \"read-only-storage\",\r\n\t// \t\tusage: BufferUsage.Storage | BufferUsage.CopyDst,\r\n\t// \t\thasDynamicOffset: true,\r\n\t// \t\tminBindingSize: 64,\r\n\t// \t\tmaxOffset: 6,\r\n\t// \t\tsize: 256 * 6\r\n\t// \t});\r\n\t// \tuniformBuffer.setMatrix4Array(\r\n\t// \t\t\"vpMatrixArray\",\r\n\t// \t\t() => {\r\n\t// \t\t\tif (this.vpMatrixArray.length != 6) throw new Error(\"pointLightShadowCamera uniformBuffer has Error\");\r\n\r\n\t// \t\t\treturn this.vpMatrixArray;\r\n\t// \t\t},\r\n\t// \t\t6,\r\n\t// \t\t256\r\n\t// \t);\r\n\r\n\t// \tthis.shaderData.setUniformBuffer(\"pointLightShadowCamera\", uniformBuffer);\r\n\t// \tthis.shaderData.setDefine(\"isPointLightShadowMap\", true);\r\n\t// }\r\n\r\n\tcreateShaderData() {\r\n\t\tthis.shaderData = new ShaderData(\"camera\", 0, 1, 1);\r\n\r\n\t\tconst uniformBuffer = new UniformBuffer({\r\n\t\t\tlabel: \"pointLightShadowCamera\",\r\n\t\t\ttype: \"read-only-storage\",\r\n\t\t\tusage: BufferUsage.Storage | BufferUsage.CopyDst\r\n\t\t});\r\n\t\tuniformBuffer.setUniform(\r\n\t\t\t\"vpMatrix\",\r\n\t\t\t() => {\r\n\t\t\t\treturn this.vpMatrix;\r\n\t\t\t},\r\n\t\t\tUniformEnum.Mat4\r\n\t\t);\r\n\r\n\t\tthis.shaderData.setUniformBuffer(\"pointLightShadowCamera\", uniformBuffer);\r\n\t\tthis.shaderData.setDefine(\"isPointLightShadowMap\", true);\r\n\t}\r\n\r\n\tupdateVpMatrixArrayAndIndex(index: number) {\r\n\t\tMatrix4.clone(this.vpMatrix, this.vpMatrixArray[index]);\r\n\t}\r\n}\r\n","import Camera from \"../../camera/Camera\";\r\nimport { TextureFormat, TextureSampleType, TextureUsage } from \"../../core/WebGPUConstant\";\r\nimport Vector2 from \"../../math/Vector2\";\r\nimport Vector4 from \"../../math/Vector4\";\r\nimport Texture from \"../../render/Texture\";\r\nimport { Light } from \"../Light\";\r\nexport class BaseShadow {\r\n\tprotected _shadowMapSize: Vector2;\r\n\tprotected _camera: Camera;\r\n\tprotected _shadowMap: Texture;\r\n\tpublic type: string;\r\n\tpublic _viewports: Array<Vector4>;\r\n\tpublic viewportSize: Vector2;\r\n\tpublic currentViewportIndex: number;\r\n\tpublic viewPortDirty: boolean;\r\n\tpublic vpMatrixDirty: boolean;\r\n\r\n\tconstructor(shadowMapSize: Vector2, camera: Camera) {\r\n\t\tthis._shadowMapSize = shadowMapSize;\r\n\t\tthis._camera = camera;\r\n\t\tthis.viewPortDirty = true;\r\n\t\tthis.vpMatrixDirty = true;\r\n\r\n\t\tthis._init();\r\n\t}\r\n\r\n\tget camera() {\r\n\t\treturn this._camera;\r\n\t}\r\n\r\n\tget shadowMapSize() {\r\n\t\treturn this._shadowMapSize;\r\n\t}\r\n\r\n\tget viewports() {\r\n\t\treturn this._viewports;\r\n\t}\r\n\r\n\tpublic getShadowMapTexture() {\r\n\t\treturn this._shadowMap;\r\n\t}\r\n\r\n\tprotected _init() {\r\n\t\tthis._initShadowMapTexture();\r\n\t}\r\n\r\n\tprotected _initShadowMapTexture() {\r\n\t\tthis._createShadowMapTexture();\r\n\t}\r\n\r\n\tprotected _createShadowMapTexture() {\r\n\t\tthis._shadowMap = new Texture({\r\n\t\t\tsize: {\r\n\t\t\t\twidth: this._shadowMapSize.x,\r\n\t\t\t\theight: this._shadowMapSize.y,\r\n\t\t\t\tdepth: 1\r\n\t\t\t},\r\n\t\t\tfixedSize: true,\r\n\t\t\tsampleType: TextureSampleType.Depth,\r\n\t\t\tformat: TextureFormat.Depth24Plus,\r\n\t\t\tusage: TextureUsage.RenderAttachment | TextureUsage.TextureBinding | TextureUsage.CopySrc\r\n\t\t});\r\n\t}\r\n\r\n\tpublic update(light: Light) {}\r\n}\r\n","import PointLightShadowCamera from \"../../camera/PointLightShadowCamera\";\r\nimport Vector2 from \"../../math/Vector2\";\r\nimport Vector3 from \"../../math/Vector3\";\r\nimport Vector4 from \"../../math/Vector4\";\r\nimport { PointLight } from \"../PointLight\";\r\nimport { BaseShadow } from \"./BaseShadow\";\r\n\r\nexport class PointLightShadow extends BaseShadow {\r\n\tpublic type: string;\r\n\tprivate _pointLightShadowLookDirections: Array<Vector3>;\r\n\tprivate _pointLightShadowUps: Array<Vector3>;\r\n\tvpMatrixArrayDirty: boolean;\r\n\r\n\tget camera(): PointLightShadowCamera {\r\n\t\treturn this._camera as PointLightShadowCamera;\r\n\t}\r\n\r\n\tconstructor() {\r\n\t\tconst camera = new PointLightShadowCamera(90, 1, 0.1, 500);\r\n\t\tsuper(new Vector2(1536, 1024), camera);\r\n\t\tthis.viewportSize = new Vector2(512, 512);\r\n\t\tthis.currentViewportIndex = 0;\r\n\t\tthis.type = \"pointLightShadow\";\r\n\t\tthis.vpMatrixArrayDirty = true;\r\n\r\n\t\tthis._viewports = [\r\n\t\t\t// positive X 0\r\n\t\t\tnew Vector4(0, 0, 1 / 3, 1 / 2),\r\n\t\t\t// negative X 1\r\n\t\t\tnew Vector4(1, 0, 1 / 3, 1 / 2),\r\n\t\t\t// positive Z 2\r\n\t\t\tnew Vector4(2, 0, 1 / 3, 1 / 2),\r\n\t\t\t// negative Z 3\r\n\t\t\tnew Vector4(0, 1, 1 / 3, 1 / 2),\r\n\t\t\t// positive Y 4\r\n\t\t\tnew Vector4(1, 1, 1 / 3, 1 / 2),\r\n\t\t\t// negative Y 5\r\n\t\t\tnew Vector4(2, 1, 1 / 3, 1 / 2)\r\n\t\t];\r\n\r\n\t\tthis._pointLightShadowLookDirections = [\r\n\t\t\tnew Vector3(1, 0, 0),\r\n\t\t\tnew Vector3(-1, 0, 0),\r\n\t\t\tnew Vector3(0, 0, 1),\r\n\t\t\tnew Vector3(0, 0, -1),\r\n\t\t\tnew Vector3(0, 1, 0),\r\n\t\t\tnew Vector3(0, -1, 0)\r\n\t\t];\r\n\r\n\t\tthis._pointLightShadowUps = [\r\n\t\t\tnew Vector3(0, 1, 0),\r\n\t\t\tnew Vector3(0, 1, 0),\r\n\t\t\tnew Vector3(0, 1, 0),\r\n\t\t\tnew Vector3(0, 1, 0),\r\n\t\t\tnew Vector3(0, 0, 1),\r\n\t\t\tnew Vector3(0, 0, -1)\r\n\t\t];\r\n\t}\r\n\r\n\tpublic update(light: PointLight) {\r\n\t\tthis.updateMatrices(light);\r\n\t}\r\n\r\n\tupdateMatrices(light: PointLight) {\r\n\t\tif (this.camera instanceof PointLightShadowCamera) {\r\n\t\t\tthis.camera.position.copy(light.position);\r\n\t\t\tconst target = Vector3.clone(light.position);\r\n\t\t\ttarget.add(this._pointLightShadowLookDirections[this.currentViewportIndex]);\r\n\t\t\tthis.camera.up.copy(this._pointLightShadowUps[this.currentViewportIndex]);\r\n\t\t\tconst { x, y, z } = target;\r\n\t\t\tthis.camera.lookAt(x, y, z);\r\n\t\t\tthis.camera.updateMatrix();\r\n\t\t\tthis.camera.updateVpMatrixArrayAndIndex(this.currentViewportIndex);\r\n\t\t\tif (this.currentViewportIndex == 5) this.vpMatrixArrayDirty = true;\r\n\t\t}\r\n\t}\r\n}\r\n","import { LightType } from \"../core/WebGPUTypes\";\r\nimport Vector3 from \"../math/Vector3\";\r\nimport { Light } from \"./Light\";\r\nimport { PointLightShadow } from \"./shadows/PointLightShadow\";\r\n\r\nexport class PointLight extends Light {\r\n\tprivate _distance: number;\r\n\tprivate _decay: number;\r\n\tdistanceDirty: boolean;\r\n\tdecayDirty: boolean;\r\n\r\n\tget shadow(): PointLightShadow {\r\n\t\treturn this._shadow as PointLightShadow;\r\n\t}\r\n\r\n\tset shadow(value: PointLightShadow) {\r\n\t\tthis.shadowDirty = true;\r\n\t\tthis._shadow = value;\r\n\t}\r\n\r\n\tconstructor(color: Vector3, intensity: number, distance = 0, decay = 4, openShadow = true) {\r\n\t\tsuper(color, intensity);\r\n\t\tthis._distance = distance;\r\n\t\tthis._decay = decay;\r\n\t\tthis.distanceDirty = true;\r\n\t\tthis.decayDirty = true;\r\n\t\tthis.lightType = LightType.PointLight;\r\n\t\tif (openShadow) this.shadow = new PointLightShadow();\r\n\t}\r\n\tset distance(value) {\r\n\t\tthis.distanceDirty = true;\r\n\t\tthis._distance = value;\r\n\t}\r\n\tget distance() {\r\n\t\treturn this._distance;\r\n\t}\r\n\tset decay(value) {\r\n\t\tthis.decayDirty = true;\r\n\t\tthis._decay = value;\r\n\t}\r\n\tget decay() {\r\n\t\treturn this._decay;\r\n\t}\r\n}\r\n// uniform\r\n// color: {},\r\n// position: {},\r\n// decay: {},\r\n// distance: {}\r\n","import Camera from \"../camera/Camera\";\r\nimport { FrameState } from \"../core/FrameState\";\r\nimport LightManger from \"../core/LightManger\";\r\nimport RenderQueue from \"../core/RenderQueue\";\r\nimport { CommandSubType } from \"../core/WebGPUConstant\";\r\nimport { Light } from \"../light/Light\";\r\nimport { PointLight } from \"../light/PointLight\";\r\nimport { BaseShadow } from \"../light/shadows/BaseShadow\";\r\nimport { PointLightShadow } from \"../light/shadows/PointLightShadow\";\r\nimport ShaderMaterial from \"../material/ShaderMaterial\";\r\nimport Attachment from \"../render/Attachment\";\r\nimport Context from \"../render/Context\";\r\nimport RenderTarget from \"../render/RenderTarget\";\r\nimport Texture from \"../render/Texture\";\r\nimport getVertFrag from \"../shader/Shaders\";\r\nimport Pass from \"./Pass\";\r\nexport class ShadowPass extends Pass {\r\n\tpublic shadowMaterial: ShaderMaterial;\r\n\t_testTexture: Texture;\r\n\tconstructor(context: Context) {\r\n\t\tsuper(context);\r\n\t\tthis.init(context);\r\n\t}\r\n\trender(frameState: FrameState, camera?: Camera) {\r\n\t\tconst { renderQueue, context, lightManger } = frameState;\r\n\t\tconst lights = lightManger.getAllLights();\r\n\t\tif (lights.length === 0) return;\r\n\r\n\t\tfor (let i = 0; i < lights.length; i++) {\r\n\t\t\tconst light: PointLight | Light = lights[i];\r\n\t\t\tconst shadow = light.shadow;\r\n\t\t\tif (!shadow) continue;\r\n\t\t\t// this._testTexture = context.lightManger._testTexture\r\n\t\t\t// this.beforeRender({ shadow });\r\n\t\t\tif (shadow instanceof PointLightShadow && light instanceof PointLight) {\r\n\t\t\t\tfor (let i = 0; i < shadow.viewports.length; i++) {\r\n\t\t\t\t\t// 动态buffer暂未调通，先以此种方式解决\r\n\t\t\t\t\tswitch (i) {\r\n\t\t\t\t\t\tcase 0:\r\n\t\t\t\t\t\t\tthis.renderTarget.depthAttachment.op = \"clear\";\r\n\t\t\t\t\t\t\tbreak;\r\n\r\n\t\t\t\t\t\tdefault:\r\n\t\t\t\t\t\t\tthis.renderTarget.depthAttachment.op = \"load\";\r\n\t\t\t\t\t\t\tbreak;\r\n\t\t\t\t\t}\r\n\t\t\t\t\tthis.beforeRender({ shadow });\r\n\r\n\t\t\t\t\tconst viewport = shadow.viewports[i];\r\n\t\t\t\t\tconst viewportSize = shadow.viewportSize;\r\n\t\t\t\t\tshadow.currentViewportIndex = i;\r\n\t\t\t\t\tshadow.update(light);\r\n\t\t\t\t\t// light.forceUpdate = true;\r\n\t\t\t\t\tcontext.setViewPort(\r\n\t\t\t\t\t\tviewport.x * viewportSize.x,\r\n\t\t\t\t\t\tviewport.y * viewportSize.y,\r\n\t\t\t\t\t\tviewportSize.x,\r\n\t\t\t\t\t\tviewportSize.y\r\n\t\t\t\t\t);\r\n\t\t\t\t\tcontext.setScissorTest(\r\n\t\t\t\t\t\tviewport.x * viewportSize.x,\r\n\t\t\t\t\t\tviewport.y * viewportSize.y,\r\n\t\t\t\t\t\tviewportSize.x,\r\n\t\t\t\t\t\tviewportSize.y\r\n\t\t\t\t\t);\r\n\t\t\t\t\tthis.subRender(renderQueue, shadow, lightManger);\r\n\t\t\t\t\tsuper.afterRender();\r\n\t\t\t\t}\r\n\t\t\t} else {\r\n\t\t\t\tthis.renderTarget.depthAttachment.op = \"clear\";\r\n\t\t\t\tthis.beforeRender({ shadow });\r\n\t\t\t\tshadow.update(light);\r\n\t\t\t\tcontext.setViewPort(0, 0, shadow.shadowMapSize.x, shadow.shadowMapSize.y);\r\n\t\t\t\tcontext.setScissorTest(0, 0, shadow.shadowMapSize.x, shadow.shadowMapSize.y);\r\n\t\t\t\tthis.subRender(renderQueue, shadow, lightManger);\r\n\t\t\t\tsuper.afterRender();\r\n\t\t\t}\r\n\t\t}\r\n\t\t// super.afterRender();\r\n\t\tlightManger.updateLightShadow();\r\n\t\tcontext.resetViewPortToFullCanvas();\r\n\t}\r\n\r\n\tsubRender(renderQueue: RenderQueue, shadow: BaseShadow, lightManger: LightManger) {\r\n\t\trenderQueue.sort();\r\n\t\t// renderQueue.preRender(shadow.camera, this.context, this.passRenderEncoder);\r\n\t\trenderQueue.transparentRender(\r\n\t\t\tshadow.camera,\r\n\t\t\tthis.context,\r\n\t\t\tthis.passRenderEncoder,\r\n\t\t\tthis.shadowMaterial,\r\n\t\t\tCommandSubType.Shadow,\r\n\t\t\tlightManger\r\n\t\t);\r\n\t\trenderQueue.opaqueRender(\r\n\t\t\tshadow.camera,\r\n\t\t\tthis.context,\r\n\t\t\tthis.passRenderEncoder,\r\n\t\t\tthis.shadowMaterial,\r\n\t\t\tCommandSubType.Shadow,\r\n\t\t\tlightManger\r\n\t\t);\r\n\t}\r\n\r\n\t// getDepthTexture(): Texture {\r\n\t// \treturn this._testTexture;\r\n\t// }\r\n\tbeforeRender(options: { shadow: BaseShadow }) {\r\n\t\tconst { shadow } = options;\r\n\t\tthis.setRenderTarget(shadow);\r\n\t\tsuper.beforeRender();\r\n\t}\r\n\r\n\tprivate setRenderTarget(shadow: BaseShadow) {\r\n\t\tthis.renderTarget.depthAttachment.texture = shadow.getShadowMapTexture();\r\n\t}\r\n\r\n\tprivate init(context: Context) {\r\n\t\tthis.createRenderTarget(context);\r\n\t\tthis.createShadowMaterial();\r\n\t}\r\n\tprivate createRenderTarget(context: Context) {\r\n\t\tconst depthAttachment = new Attachment(1.0, { texture: undefined });\r\n\t\tthis.renderTarget = new RenderTarget(\"render\", [], depthAttachment);\r\n\t}\r\n\r\n\tprivate createShadowMaterial() {\r\n\t\tconst shadowMapShaderFunction = (defines = {}) => {\r\n\t\t\tconst finalDefines = Object.assign(\r\n\t\t\t\t{\r\n\t\t\t\t\tselfBinding: 0,\r\n\t\t\t\t\tcameraBinding: 0,\r\n\t\t\t\t\tpositionLocation: 0\r\n\t\t\t\t},\r\n\t\t\t\tdefines\r\n\t\t\t);\r\n\t\t\treturn getVertFrag(\"shadowMap\", finalDefines).vert;\r\n\t\t};\r\n\r\n\t\tthis.shadowMaterial = new ShaderMaterial({\r\n\t\t\ttype: \"shadowMaterial\",\r\n\t\t\tuniforms: {\r\n\t\t\t\tmodelMatrix: { type: \"mat4\", value: null }\r\n\t\t\t},\r\n\t\t\tvert: shadowMapShaderFunction,\r\n\t\t\tfrag: undefined,\r\n\t\t\tlight: false // TODO:先true，false有显示bug\r\n\t\t});\r\n\t}\r\n}\r\n","import Camera from \"../camera/Camera\";\r\nimport { FrameState } from \"../core/FrameState\";\r\nimport { BasicPass } from \"../pass/BasicPass\";\r\nimport { ShadowPass } from \"../pass/ShadowPass\";\r\nimport Context from \"../render/Context\";\r\nimport Texture from \"../render/Texture\";\r\nimport IBaseRenderLine from \"./IBaseRenderLine\";\r\n\r\nexport default class ForwardRenderLine implements IBaseRenderLine {\r\n\tprivate basicPass: BasicPass;\r\n\tprotected shadowPass: ShadowPass;\r\n\tconstructor(public context: Context) {\r\n\t\tthis.basicPass = new BasicPass(context);\r\n\t\tthis.shadowPass = new ShadowPass(context);\r\n\t\t// const bloom=new BloomPostEffect({\r\n\t\t// \twidth,\r\n\t\t// \theight,\r\n\t\t// \tstrength:0.3,\r\n\t\t// \tradius:0.3,\r\n\t\t// \tthreshold:0.5\r\n\t\t// });\r\n\t\t// this.postEffectCollection.add(bloom)\r\n\t}\r\n\tgetOutputTexture(): Texture {\r\n\t\treturn this.basicPass.getColorTexture(0);\r\n\t\t// return this.shadowPass.getDepthTexture()\r\n\t}\r\n\trender(frameState: FrameState, camera?: Camera) {\r\n\t\tthis.shadowPass.render(frameState, camera);\r\n\r\n\t\tthis.basicPass.beforeRender(frameState);\r\n\t\tthis.basicPass.render(frameState, camera);\r\n\t\tthis.basicPass.afterRender();\r\n\t}\r\n\tdestroy() {\r\n\t\tthis.basicPass = undefined;\r\n\t}\r\n}\r\n","import Camera from \"./camera/Camera\";\nimport PerspectiveCamera from \"./camera/PerspectiveCamera\";\nimport { EventDispatcher } from \"./core/EventDispatcher\";\nimport { FrameState, Background } from \"./core/FrameState\";\nimport LightManger from \"./core/LightManger\";\nimport MeshManger from \"./core/MeshManger\";\nimport textureCache from \"./core/TextureCache\";\nimport { Instance, RenderObjectType } from \"./core/WebGPUTypes\";\nimport { Light } from \"./light/Light\";\nimport { Mesh } from \"./mesh/Mesh\";\nimport Node from \"./mesh/Node\";\nimport PostEffect from \"./post-process/PostEffect\";\nimport PostEffectCollection from \"./post-process/PostEffectCollection\";\nimport Context from \"./render/Context\";\nimport { ViewPort } from \"./render/RenderState\";\nimport ForwardRenderLine from \"./renderpipeline/ForwardRenderLine\";\nimport IBaseRenderLine from \"./renderpipeline/IBaseRenderLine\";\n\nexport class Scene extends EventDispatcher {\n\tcamera: PerspectiveCamera;\n\tcontext: Context;\n\trequestAdapter: object;\n\tdeviceDescriptor: object;\n\tpresentationContextDescriptor: object;\n\tcontainer: HTMLDivElement;\n\tframeState: FrameState;\n\tcurrentRenderPipeline: IBaseRenderLine;\n\tviewport: ViewPort;\n\tbackground: Background;\n\tprivate ready: boolean;\n\tprivate inited: boolean;\n\tprivate meshManger: MeshManger;\n\tprivate postEffectCollection: PostEffectCollection;\n\tprivate lightManger: LightManger;\n\tconstructor(options) {\n\t\tsuper();\n\t\tthis.container =\n\t\t\toptions.container instanceof HTMLDivElement\n\t\t\t\t? options.container\n\t\t\t\t: document.getElementById(options.container);\n\t\tthis.meshManger = new MeshManger();\n\t\tthis.postEffectCollection = new PostEffectCollection();\n\t\tthis.context = new Context({\n\t\t\tcanvas: null,\n\t\t\tcontainer: this.container,\n\t\t\tpixelRatio: 1\n\t\t});\n\t\tthis.requestAdapter = options.requestAdapter || {};\n\t\tthis.deviceDescriptor = options.deviceDescriptor || {};\n\t\tthis.presentationContextDescriptor = options.presentationContextDescriptor;\n\t\tthis.ready = false;\n\t\tthis.inited = false;\n\t\tthis.lightManger = new LightManger({ openShadow: true });\n\t\tthis.background = options.background;\n\t}\n\tprivate async init() {\n\t\tawait this.context.init(this.requestAdapter, this.deviceDescriptor, this.presentationContextDescriptor);\n\t\tthis.currentRenderPipeline = new ForwardRenderLine(this.context);\n\t\tthis.frameState = new FrameState(this.context, this.lightManger, FrameState.getFrameStateOptionsByScene(this));\n\t\tthis.viewport = new ViewPort(0, 0, this.context.presentationSize.width, this.context.presentationSize.height);\n\t\tthis.ready = true;\n\t}\n\tadd(instance: Instance) {\n\t\tif (\n\t\t\t[RenderObjectType.Node, RenderObjectType.Skybox, RenderObjectType.Mesh, RenderObjectType.Debug].includes(\n\t\t\t\tinstance.type\n\t\t\t)\n\t\t) {\n\t\t\tthis.meshManger.add(<Mesh>instance);\n\t\t} else if (instance.type == RenderObjectType.Light) {\n\t\t\tthis.lightManger.add(<Light>instance);\n\t\t} else if (instance.type == RenderObjectType.PostEffect) {\n\t\t\tthis.postEffectCollection.add(<PostEffect>instance);\n\t\t}\n\t}\n\tremove(instance: Instance) {\n\t\tif ([RenderObjectType.Node, RenderObjectType.Skybox, RenderObjectType.Mesh].includes(instance.type)) {\n\t\t\tthis.meshManger.remove(<Mesh>instance);\n\t\t} else if (instance.type == RenderObjectType.Light) {\n\t\t\tthis.lightManger.remove(<Light>instance);\n\t\t} else if (instance.type == RenderObjectType.PostEffect) {\n\t\t\tthis.postEffectCollection.remove(<PostEffect>instance);\n\t\t}\n\t}\n\tsetCamera(camera) {\n\t\tthis.camera = camera;\n\t}\n\tresize(width: number, height: number) {\n\t\tthis.context.resize(width, height);\n\t\tthis.postEffectCollection.setResolveFrameDirty(true);\n\t}\n\tasync render(node?: Node, camera?: Camera) {\n\t\tif (!this.inited) {\n\t\t\tthis.inited = true;\n\t\t\tawait this.init();\n\t\t\tthis.update(node, camera);\n\t\t\tthis.afterRender();\n\t\t} else {\n\t\t\tthis.update(node, camera);\n\t\t\tthis.afterRender();\n\t\t}\n\t}\n\n\tafterRender() {}\n\n\tpublic setViewPort(x: number, y: number, width: number, height: number): boolean {\n\t\tif (!this.ready) return false;\n\t\tthis.context.setViewPort(x, y, width, height);\n\t\treturn true;\n\t}\n\tpublic setScissorTest(x: number, y: number, width: number, height: number): boolean {\n\t\tif (!this.ready) return false;\n\t\tthis.context.setScissorTest(x, y, width, height);\n\t\treturn true;\n\t}\n\tprivate update(node?: Node, camera?: Camera) {\n\t\tif (!this.ready) return;\n\t\t// 释放纹理\n\t\ttextureCache.releasedTextures();\n\t\t// 更新FrameState\n\t\tthis.frameState.update(camera ?? this.camera, FrameState.getFrameStateOptionsByScene(this));\n\t\t// update primitive and select\n\t\t(node ?? this.meshManger).update(this.frameState, camera ?? this.camera);\n\t\t// selct renderPipeline\n\t\tthis.currentRenderPipeline.render(this.frameState, camera ?? this.camera);\n\t\t// 后处理\n\t\tthis.postEffectCollection.render(this.context, this.currentRenderPipeline.getOutputTexture());\n\t}\n}\n","import IClone from \"../core/IClone\";\r\nimport { RenderObjectType } from \"../core/WebGPUTypes\";\r\nimport Geometry from \"../geometry/Geometry\";\r\nimport { Mesh } from \"../mesh/Mesh\";\r\nimport { Float32Attribute } from \"../render/Attribute\";\r\nimport Context from \"../render/Context\";\r\nimport { Primitive, RenderState, Target } from \"../render/RenderState\";\r\nimport RenderTarget from \"../render/RenderTarget\";\r\nimport Sampler from \"../render/Sampler\";\r\nimport Texture from \"../render/Texture\";\r\n\r\nexport default class PostEffect implements IClone {\r\n\twidth: number;\r\n\r\n\theight: number;\r\n\r\n\tdefaultSampler: Sampler;\r\n\r\n\tresolveToCanvas: boolean;\r\n\r\n\tcurrentRenderTarget: RenderTarget;\r\n\r\n\tfullScreenQuad: Mesh;\r\n\r\n\trenderState: RenderState;\r\n\r\n\tid: string;\r\n\r\n\tpriority: number;\r\n\r\n\tisPostEffect: boolean;\r\n\r\n\ttype: RenderObjectType;\r\n\r\n\tconstructor(width: number, height: number, id: string) {\r\n\t\tthis.width = width;\r\n\t\tthis.height = height;\r\n\t\tthis.initDefaultParms();\r\n\t\tthis.id = id;\r\n\t\tthis.priority = 0;\r\n\t\tthis.isPostEffect = true;\r\n\t\tthis.type = RenderObjectType.PostEffect;\r\n\t}\r\n\trender(context: Context, colorTexture: Texture): Texture {\r\n\t\treturn null;\r\n\t}\r\n\tdestroy() {\r\n\t\tthis?.currentRenderTarget?.destroy();\r\n\t}\r\n\tprotected renderMesh(context: Context) {\r\n\t\tthis.fullScreenQuad.material.dirty = true;\r\n\t\tthis.fullScreenQuad.material.update();\r\n\t\tconst drawComand = this.fullScreenQuad.getDrawCommand();\r\n\t\tconst currentRenderPassEncoder = this.currentRenderTarget.beginRenderPassEncoder(context);\r\n\t\tdrawComand.render(context, currentRenderPassEncoder);\r\n\t\tthis.currentRenderTarget.endRenderPassEncoder();\r\n\t}\r\n\tprivate initDefaultParms() {\r\n\t\tconst geometry = new Geometry({});\r\n\t\tgeometry.setAttribute(\r\n\t\t\tnew Float32Attribute(\"position\", [-1.0, 1.0, -1.0, -1.0, 1.0, -1.0, 1.0, -1.0, 1.0, 1.0, -1.0, 1.0], 2)\r\n\t\t);\r\n\t\tgeometry.count = 6;\r\n\t\t// rs\r\n\t\tconst primitive = new Primitive();\r\n\t\tconst target = new Target();\r\n\t\t// target.format=TextureFormat.RGBA8Unorm\r\n\t\tconst renderState = new RenderState();\r\n\t\trenderState.primitive = primitive;\r\n\t\trenderState.targets = [target];\r\n\t\tthis.renderState = renderState;\r\n\t\tthis.fullScreenQuad = new Mesh(geometry);\r\n\r\n\t\tthis.defaultSampler = new Sampler();\r\n\t}\r\n}\r\n","import { TextureFormat, TextureUsage } from \"../core/WebGPUConstant\";\r\nimport { Uniforms } from \"../core/WebGPUTypes\";\r\nimport ShaderMaterial from \"../material/ShaderMaterial\";\r\nimport Color from \"../math/Color\";\r\nimport Vector2 from \"../math/Vector2\";\r\nimport Vector3 from \"../math/Vector3\";\r\nimport Attachment from \"../render/Attachment\";\r\nimport Context from \"../render/Context\";\r\nimport RenderTarget from \"../render/RenderTarget\";\r\nimport Texture from \"../render/Texture\";\r\nimport getVertFrag from \"../shader/Shaders\";\r\nimport PostEffect from \"./PostEffect\";\r\n\r\nexport default class BloomPostEffect extends PostEffect {\r\n\tstatic BlurDirectionX = new Vector2(1.0, 0.0);\r\n\tstatic BlurDirectionY = new Vector2(0.0, 1.0);\r\n\tstrength: number;\r\n\tradius: number;\r\n\tthreshold: number;\r\n\trenderTargetsHorizontal: RenderTarget[];\r\n\trenderTargetsVertical: RenderTarget[];\r\n\tnMips: number;\r\n\trenderTargetBright: RenderTarget;\r\n\tmaterialHighPassFilter: ShaderMaterial;\r\n\thighPassUniforms: Uniforms;\r\n\tcompositeMaterial: ShaderMaterial;\r\n\tseparableBlurMaterials: ShaderMaterial[];\r\n\tseparableBlurYMaterials: ShaderMaterial[];\r\n\tblendUniforms: Uniforms;\r\n\tblendMaterial: ShaderMaterial;\r\n\tblendTarget: RenderTarget;\r\n\r\n\tconstructor(options: BloomPostEffectProps) {\r\n\t\tsuper(options.width, options.height, \"bloom\");\r\n\t\tthis.strength = options.strength;\r\n\t\tthis.radius = options.radius;\r\n\t\tthis.threshold = options.threshold;\r\n\t\tthis.init();\r\n\t}\r\n\tdestroy() {\r\n\t\tthis.renderTargetBright.destroy();\r\n\t}\r\n\trender(context: Context, colorTexture: Texture): Texture {\r\n\t\t// 1. Extract Bright Areas\r\n\t\tthis.currentRenderTarget = this.renderTargetBright;\r\n\t\tthis.highPassUniforms.tDiffuse.value = colorTexture;\r\n\t\tthis.fullScreenQuad.material = this.materialHighPassFilter;\r\n\t\tthis.renderMesh(context);\r\n\t\t// 2. Blur All the mips progressively\r\n\t\tlet inputRenderTarget = this.renderTargetBright;\r\n\t\tfor (let i = 0; i < this.nMips; i++) {\r\n\t\t\tthis.fullScreenQuad.material = this.separableBlurMaterials[i];\r\n\r\n\t\t\tthis.separableBlurMaterials[i].uniforms.tDiffuse.value = inputRenderTarget.getColorTexture();\r\n\t\t\tthis.separableBlurMaterials[i].uniforms.direction.value = BloomPostEffect.BlurDirectionX;\r\n\t\t\tthis.currentRenderTarget = this.renderTargetsHorizontal[i];\r\n\r\n\t\t\tthis.renderMesh(context);\r\n\t\t\tthis.fullScreenQuad.material = this.separableBlurYMaterials[i];\r\n\t\t\tthis.separableBlurYMaterials[i].uniforms.tDiffuse.value = this.renderTargetsHorizontal[i].getColorTexture();\r\n\t\t\tthis.separableBlurYMaterials[i].uniforms.direction.value = BloomPostEffect.BlurDirectionY;\r\n\t\t\tthis.currentRenderTarget = this.renderTargetsVertical[i];\r\n\r\n\t\t\tthis.renderMesh(context);\r\n\r\n\t\t\tinputRenderTarget = this.renderTargetsVertical[i];\r\n\t\t}\r\n\t\t// Composite All the mips\r\n\t\tthis.fullScreenQuad.material = this.compositeMaterial;\r\n\t\tthis.currentRenderTarget = this.renderTargetsHorizontal[0];\r\n\t\tthis.renderMesh(context);\r\n\t\t// blend\r\n\t\tthis.blendUniforms.baseColorTexture.value = colorTexture;\r\n\t\tthis.fullScreenQuad.material = this.blendMaterial;\r\n\t\tthis.currentRenderTarget = this.blendTarget;\r\n\t\tthis.renderMesh(context);\r\n\t\treturn this.currentRenderTarget.getColorTexture();\r\n\t}\r\n\tprivate init() {\r\n\t\tthis.renderTargetsHorizontal = [];\r\n\t\tthis.renderTargetsVertical = [];\r\n\t\tthis.nMips = 5;\r\n\t\tlet resx = Math.round(this.width / 2);\r\n\t\tlet resy = Math.round(this.height / 2);\r\n\r\n\t\tthis.renderTargetBright = new RenderTarget(\"render\", [this.createColorAttachment(resx, resy)]);\r\n\r\n\t\tfor (let i = 0; i < this.nMips; i++) {\r\n\t\t\tconst renderTargetHorizonal = new RenderTarget(\"render\", [this.createColorAttachment(resx, resy)]);\r\n\t\t\tthis.renderTargetsHorizontal.push(renderTargetHorizonal);\r\n\t\t\tconst renderTargetVertical = new RenderTarget(\"render\", [this.createColorAttachment(resx, resy)]);\r\n\t\t\tthis.renderTargetsVertical.push(renderTargetVertical);\r\n\t\t\tresx = Math.round(resx / 2);\r\n\t\t\tresy = Math.round(resy / 2);\r\n\t\t}\r\n\t\t// luminosity high pass material\r\n\t\tthis.highPassUniforms = {\r\n\t\t\ttDiffuse: { type: \"texture\", value: null },\r\n\t\t\ttSampler: {\r\n\t\t\t\ttype: \"sampler\",\r\n\t\t\t\tvalue: this.defaultSampler\r\n\t\t\t},\r\n\t\t\tluminosityThreshol: { type: \"float\", value: this.threshold },\r\n\t\t\tsmoothWidth: { type: \"float\", value: 0.01 },\r\n\t\t\tdefaultColor: { type: \"color\", value: new Color(0.0, 0, 0) },\r\n\t\t\tdefaultOpacity: { type: \"float\", value: 1.0 }\r\n\t\t};\r\n\t\tconst shader = getVertFrag(\"luminosityHigh\", { positionLocation: 0 });\r\n\t\tthis.materialHighPassFilter = new ShaderMaterial({\r\n\t\t\ttype: \"bloom\",\r\n\t\t\tuniforms: this.highPassUniforms,\r\n\t\t\tvert: shader.vert,\r\n\t\t\tfrag: shader.frag\r\n\t\t});\r\n\t\t// Gaussian Blur Materials\r\n\t\tthis.materialHighPassFilter.renderState = this.renderState;\r\n\t\tthis.separableBlurMaterials = [];\r\n\t\tthis.separableBlurYMaterials = [];\r\n\t\tconst kernelSizeArray = [3, 5, 7, 9, 11];\r\n\t\tresx = Math.round(this.width / 2);\r\n\t\tresy = Math.round(this.height / 2);\r\n\r\n\t\tfor (let i = 0; i < this.nMips; i++) {\r\n\t\t\tthis.separableBlurMaterials.push(this.getSeperableBlurMaterial(kernelSizeArray[i], \"BlurMaterial\" + i));\r\n\t\t\tthis.separableBlurYMaterials.push(this.getSeperableBlurMaterial(kernelSizeArray[i], \"BlurMaterialY\" + i));\r\n\t\t\tresx = Math.round(resx / 2);\r\n\r\n\t\t\tresy = Math.round(resy / 2);\r\n\t\t}\r\n\t\t// Composite material\r\n\t\tthis.compositeMaterial = this.getCompositeMaterial(this.nMips, \"compositeMaterial\");\r\n\t\tthis.compositeMaterial.renderState = this.renderState;\r\n\t\tthis.blendUniforms = {\r\n\t\t\ttDiffuse: { type: \"texture\", value: this.renderTargetsHorizontal[0].getColorTexture() },\r\n\t\t\tbaseColorTexture: { type: \"texture\", value: null },\r\n\t\t\ttSampler: {\r\n\t\t\t\ttype: \"sampler\",\r\n\t\t\t\tvalue: this.defaultSampler\r\n\t\t\t}\r\n\t\t};\r\n\t\tconst blendShader = getVertFrag(\"blend\", { positionLocation: 0 });\r\n\t\tthis.blendMaterial = new ShaderMaterial({\r\n\t\t\ttype: \"postBlend\",\r\n\t\t\tuniforms: this.blendUniforms,\r\n\t\t\tvert: blendShader.vert,\r\n\t\t\tfrag: blendShader.frag\r\n\t\t});\r\n\t\tthis.blendMaterial.renderState = this.renderState;\r\n\t\tthis.blendTarget = new RenderTarget(\"render\", [this.createColorAttachment(this.width, this.height)]);\r\n\t}\r\n\tprivate createColorAttachment(width: number, height: number): Attachment {\r\n\t\tconst colorTexture = new Texture({\r\n\t\t\tsize: { width, height, depth: 1 },\r\n\t\t\tformat: TextureFormat.BGRA8Unorm,\r\n\t\t\tusage: TextureUsage.RenderAttachment | TextureUsage.TextureBinding\r\n\t\t});\r\n\t\tconst colorAttachment = new Attachment({ r: 0.0, g: 0.0, b: 0.0, a: 0.0 }, { texture: colorTexture });\r\n\t\treturn colorAttachment;\r\n\t}\r\n\tprivate getCompositeMaterial(nMips: number, type): ShaderMaterial {\r\n\t\treturn new ShaderMaterial({\r\n\t\t\ttype,\r\n\t\t\tuniforms: {\r\n\t\t\t\tblurTexture1: { type: \"texture\", value: this.renderTargetsVertical[0].getColorTexture() },\r\n\t\t\t\tblurTexture2: { type: \"texture\", value: this.renderTargetsVertical[1].getColorTexture() },\r\n\t\t\t\tblurTexture3: { type: \"texture\", value: this.renderTargetsVertical[2].getColorTexture() },\r\n\t\t\t\tblurTexture4: { type: \"texture\", value: this.renderTargetsVertical[3].getColorTexture() },\r\n\t\t\t\tblurTexture5: { type: \"texture\", value: this.renderTargetsVertical[4].getColorTexture() },\r\n\t\t\t\ttSampler: {\r\n\t\t\t\t\ttype: \"sampler\",\r\n\t\t\t\t\tvalue: this.defaultSampler\r\n\t\t\t\t},\r\n\t\t\t\tbloomStrength: { type: \"float\", value: this.strength },\r\n\t\t\t\tbloomRadius: { type: \"float\", value: this.radius },\r\n\t\t\t\tbloomFactors: { type: \"float-array\", value: [1.0, 0.8, 0.6, 0.4, 0.2] },\r\n\t\t\t\tbloomTintColors: {\r\n\t\t\t\t\ttype: \"vec3-array\",\r\n\t\t\t\t\tvalue: [\r\n\t\t\t\t\t\tnew Vector3(1, 1, 1),\r\n\t\t\t\t\t\tnew Vector3(1, 1, 1),\r\n\t\t\t\t\t\tnew Vector3(1, 1, 1),\r\n\t\t\t\t\t\tnew Vector3(1, 1, 1),\r\n\t\t\t\t\t\tnew Vector3(1, 1, 1)\r\n\t\t\t\t\t]\r\n\t\t\t\t}\r\n\t\t\t},\r\n\r\n\t\t\tvert: (defines) => {\r\n\t\t\t\t`\r\n              struct VertexInput {\r\n                    @location(0) position: vec2<f32>,       \r\n               }\r\n               struct VertexOutput {\r\n                    @builtin(position) position: vec4<f32>,\r\n                    @location(0) uv: vec2<f32>,\r\n                };\r\n               @vertex\r\n               fn main(input: VertexInput) -> VertexOutput {\r\n                var output:VertexOutput;\r\n                output.uv = input.position * 0.5 + 0.5;\r\n                output.position = vec4<f32>(input.position, 0.0, 1.0);;\r\n                return output;\r\n               }\r\n                `;\r\n\t\t\t},\r\n\r\n\t\t\tfrag: (defines) => {\r\n\t\t\t\t`\r\n                struct FragInput {\r\n                    @location(0) uv: vec2<f32>,\r\n                };\r\n                struct BloomUniforms{\r\n                    bloomStrength:f32,\r\n                    bloomRadius:f32,\r\n                    bloomFactors : array<f32,5>,\r\n                    bloomTintColors : array<vec3<f32>,5>\r\n                }  \r\n                @group(0) @binding(0)  var<storage, read> bloomUniforms : BloomUniforms;\r\n\r\n                @group(0) @binding(${defines.blurTexture1Binding}) var blurTexture1: texture_2d<f32>;\r\n                @group(0) @binding(${defines.blurTexture2Binding}) var blurTexture2: texture_2d<f32>;\r\n                @group(0) @binding(${defines.blurTexture3Binding}) var blurTexture3: texture_2d<f32>;\r\n                @group(0) @binding(${defines.blurTexture4Binding}) var blurTexture4: texture_2d<f32>;\r\n                @group(0) @binding(${defines.blurTexture5Binding}) var blurTexture5: texture_2d<f32>;\r\n                @group(0) @binding(${defines.tSamplerBinding}}) var tSampler: sampler;\r\n\r\n\t\t\t\tfn lerpBloomFactor(factor:f32)->f32 {\r\n\t\t\t\t\tlet mirrorFactor:f32 = 1.2 - factor;\r\n\t\t\t\t\treturn mix(factor, mirrorFactor, bloomUniforms.bloomRadius);\r\n\t\t\t\t}\r\n                @fragment\r\n\t\t\t\tfn main(input:FragInput)-> @location(0) vec4<f32>  {\r\n\t\t\t\t\treturn bloomUniforms.bloomStrength * ( lerpBloomFactor(bloomUniforms.bloomFactors[0]) * vec4(bloomUniforms.bloomTintColors[0], 1.0) * textureSample(blurTexture1, tSampler, input.uv) +\r\n\t\t\t\t\t\tlerpBloomFactor(bloomUniforms.bloomFactors[1]) * vec4<f32>(bloomUniforms.bloomTintColors[1], 1.0) * textureSample(blurTexture2, tSampler, input.uv) +\r\n\t\t\t\t\t\tlerpBloomFactor(bloomUniforms.bloomFactors[2]) * vec4<f32>(bloomUniforms.bloomTintColors[2], 1.0) * textureSample(blurTexture3, tSampler, input.uv) +\r\n\t\t\t\t\t\tlerpBloomFactor(bloomUniforms.bloomFactors[3]) * vec4<f32>(bloomUniforms.bloomTintColors[3], 1.0) * textureSample(blurTexture4, tSampler, input.uv) +\r\n\t\t\t\t\t\tlerpBloomFactor(bloomUniforms.bloomFactors[4]) * vec4<f32>(bloomUniforms.bloomTintColors[4], 1.0) * textureSample(blurTexture5, tSampler, input.uv) );\r\n\t\t\t\t}`;\r\n\t\t\t}\r\n\t\t});\r\n\t}\r\n\tprivate getSeperableBlurMaterial(kernelRadius, type) {\r\n\t\tconst shader = getVertFrag(\"blur\", {\r\n\t\t\tKERNEL_RADIUS: kernelRadius,\r\n\t\t\tSIGMA: kernelRadius,\r\n\t\t\tpositionLocation: 0\r\n\t\t});\r\n\t\tconst mat = new ShaderMaterial({\r\n\t\t\ttype,\r\n\t\t\tuniforms: {\r\n\t\t\t\ttDiffuse: { type: \"texture\", value: null },\r\n\t\t\t\tdirection: { type: \"vec2\", value: new Vector2(0.0, 0.0) },\r\n\t\t\t\ttSampler: {\r\n\t\t\t\t\ttype: \"sampler\",\r\n\t\t\t\t\tvalue: this.defaultSampler\r\n\t\t\t\t}\r\n\t\t\t},\r\n\r\n\t\t\tvert: shader.vert,\r\n\r\n\t\t\tfrag: shader.frag\r\n\t\t});\r\n\t\tmat.renderState = this.renderState;\r\n\t\treturn mat;\r\n\t}\r\n}\r\n\r\ntype BloomPostEffectProps = {\r\n\twidth: number;\r\n\theight: number;\r\n\tstrength: number;\r\n\tradius: number;\r\n\tthreshold: number;\r\n};\r\n","import Matrix4 from \"../math/Matrix4\";\r\nimport Camera from \"./Camera\";\r\nexport default class OrthographicCamera extends Camera {\r\n\tright: number;\r\n\tisOrthographicCamera: boolean;\r\n\tbottom: number;\r\n\tleft: number;\r\n\tnear: number;\r\n\tfar: number;\r\n\ttop: number;\r\n\tconstructor(left = -1, right = 1, top = 1, bottom = -1, near = 0.1, far = 2000) {\r\n\t\tsuper();\r\n\t\tthis.near = near;\r\n\t\tthis.far = far;\r\n\t\tthis.left = left;\r\n\t\tthis.top = top;\r\n\t\tthis.bottom = bottom;\r\n\t\tthis.right = right;\r\n\t\tthis.isOrthographicCamera = true;\r\n\t}\r\n\tprivate updateCameraParms() {\r\n\t\tconst dx = (this.right - this.left) / 2;\r\n\t\tconst dy = (this.top - this.bottom) / 2;\r\n\t\tconst cx = (this.right + this.left) / 2;\r\n\t\tconst cy = (this.top + this.bottom) / 2;\r\n\t\treturn {\r\n\t\t\tleft: cx - dx,\r\n\t\t\tright: cx + dx,\r\n\t\t\ttop: cy + dy,\r\n\t\t\tbottom: cy - dy\r\n\t\t};\r\n\t}\r\n\tpublic updateProjectionMatrix() {\r\n\t\tif (this.projectMatrixDirty) {\r\n\t\t\tconst { left, right, top, bottom } = this.updateCameraParms();\r\n\t\t\tthis._projectionMatrix = Matrix4.makeOrthographic(left, right, top, bottom, this.near, this.far);\r\n\t\t\tthis.projectMatrixDirty = false;\r\n\t\t}\r\n\t}\r\n}\r\n","import PerspectiveCamera from \"../../camera/PerspectiveCamera\";\nimport Vector2 from \"../../math/Vector2\";\nimport { SpotLight } from \"../SpotLight\";\nimport { BaseShadow } from \"./BaseShadow\";\n\nexport class SpotLightShadow extends BaseShadow {\n\tpublic type: string;\n\tconstructor() {\n\t\tconst camera = new PerspectiveCamera(60, 1, 0.1, 500);\n\t\tsuper(new Vector2(1024, 1024), camera);\n\t\tthis.type = \"spotLightShadow\";\n\t}\n\n\tpublic update(light: SpotLight) {\n\t\tthis.updateMatrices(light);\n\t}\n\n\tupdateMatrices(light: SpotLight) {\n\t\tthis.camera.position.copy(light.position);\n\t\tconst { x, y, z } = light.target;\n\t\tthis.camera.lookAt(x, y, z);\n\t\tthis.camera.updateMatrix();\n\t\tthis.vpMatrixDirty = true;\n\t}\n}\n","import { LightType } from \"../core/WebGPUTypes\";\r\nimport Vector3 from \"../math/Vector3\";\r\nimport { Light } from \"./Light\";\r\nimport { SpotLightShadow } from \"./shadows/SpotLightShadow\";\r\n\r\nexport class SpotLight extends Light {\r\n\tprivate _distance: number;\r\n\tprivate _angle: number;\r\n\tprivate _penumbra: number;\r\n\tprivate _decay: number;\r\n\tdecayDirty: boolean;\r\n\tdistanceDirty: boolean;\r\n\tprivate _coneCos: number;\r\n\tprivate _penumbraCos: number;\r\n\tconeCosDirty: boolean;\r\n\tpenumbraDirty: boolean;\r\n\tangleDirty: boolean;\r\n\tpenumbraCosDirty: boolean;\r\n\tconstructor(color, intensity, distance = 0, angle = 60, penumbra = 60, decay = 4, openShadow = true) {\r\n\t\tsuper(color, intensity);\r\n\t\tthis._distance = distance;\r\n\t\tthis._angle = (angle / 180) * Math.PI;\r\n\t\tthis._penumbra = (penumbra / 180) * Math.PI;\r\n\t\tthis._decay = decay;\r\n\t\tthis.lightType = LightType.SpotLight;\r\n\t\tthis.angleDirty = true;\r\n\t\tthis.penumbraDirty = true;\r\n\t\tthis.distanceDirty = true;\r\n\t\tthis.decayDirty = true;\r\n\t\tthis.coneCosDirty = true;\r\n\t\tthis.penumbraCosDirty = true;\r\n\t\tif (openShadow) this.shadow = new SpotLightShadow();\r\n\t\tthis.updateConeCosOrPenumbraCos();\r\n\t}\r\n\r\n\tget dirtectDirty() {\r\n\t\treturn this.positionDirty || this.targetDirty;\r\n\t}\r\n\r\n\tset dirtectDirty(value) {\r\n\t\tthis.positionDirty = value;\r\n\t\tthis.targetDirty = value;\r\n\t}\r\n\r\n\tget directional() {\r\n\t\tconst result = new Vector3();\r\n\t\tVector3.subtract(this.position, this.target, result);\r\n\t\treturn Vector3.normalize(result, new Vector3());\r\n\t}\r\n\tget angle() {\r\n\t\treturn this._angle;\r\n\t}\r\n\tset angle(value) {\r\n\t\tthis.angleDirty = true;\r\n\t\tthis._angle = (value / 180) * Math.PI;\r\n\t\tthis.updateConeCosOrPenumbraCos();\r\n\t}\r\n\tget penumbra() {\r\n\t\treturn this._penumbra;\r\n\t}\r\n\tset penumbra(value) {\r\n\t\tthis.penumbraDirty = true;\r\n\t\tthis._penumbra = (value / 180) * Math.PI;\r\n\t\tthis.updateConeCosOrPenumbraCos();\r\n\t}\r\n\tset distance(value) {\r\n\t\tthis.distanceDirty = true;\r\n\t\tthis._distance = value;\r\n\t}\r\n\tget distance() {\r\n\t\treturn this._distance;\r\n\t}\r\n\tset decay(value) {\r\n\t\tthis.decayDirty = true;\r\n\t\tthis._decay = value;\r\n\t}\r\n\tget decay() {\r\n\t\treturn this._decay;\r\n\t}\r\n\tset coneCos(value) {\r\n\t\tthis.coneCosDirty = true;\r\n\t\tthis._coneCos = value;\r\n\t}\r\n\tget coneCos() {\r\n\t\treturn this._coneCos;\r\n\t}\r\n\tset penumbraCos(value) {\r\n\t\tthis.penumbraCosDirty = true;\r\n\t\tthis._penumbraCos = value;\r\n\t}\r\n\tget penumbraCos() {\r\n\t\treturn this._penumbraCos;\r\n\t}\r\n\tprivate updateConeCosOrPenumbraCos() {\r\n\t\tthis._coneCos = Math.cos(this.angle);\r\n\t\tthis._penumbraCos = Math.cos(this.angle + this.penumbra);\r\n\t}\r\n}\r\n// uniform\r\n// color: {},\r\n// position: {},\r\n// direction: {},\r\n// distance: {},\r\n// coneCos: {},\r\n// penumbraCos: {},\r\n// decay: {}\r\n","import OrthographicCamera from \"../../camera/OrthographicCamera\";\nimport Vector2 from \"../../math/Vector2\";\nimport { DirectionalLight } from \"../DirectionalLight\";\nimport { BaseShadow } from \"./BaseShadow\";\n\nexport class DirectionalLightShadow extends BaseShadow {\n\tpublic type: string;\n\tconstructor() {\n\t\tconst camera = new OrthographicCamera(-50, 50, 50, -50, 0, 100);\n\t\tsuper(new Vector2(1024, 1024), camera);\n\t\tthis.type = \"directionalLightShadow\";\n\t}\n\n\tpublic update(light: DirectionalLight) {\n\t\tthis.updateMatrices(light);\n\t}\n\n\tupdateMatrices(light: DirectionalLight) {\n\t\tthis.camera.position.copy(light.position);\n\t\tconst { x, y, z } = light.target;\n\t\tthis.camera.lookAt(x, y, z);\n\t\tthis.camera.updateMatrix();\n\t\tthis.vpMatrixDirty = true;\n\t}\n}\n","import { LightType } from \"../core/WebGPUTypes\";\nimport Vector3 from \"../math/Vector3\";\nimport { Light } from \"./Light\";\nimport { DirectionalLightShadow } from \"./shadows/DirectionalLightShadow\";\n\nexport class DirectionalLight extends Light {\n\tconstructor(color: Vector3, intensity: number, openShadow = true) {\n\t\tsuper(color, intensity);\n\t\tthis.lightType = LightType.DirectionalLight;\n\t\tif (openShadow) this.shadow = new DirectionalLightShadow();\n\t}\n\n\tget dirtectDirty() {\n\t\treturn this.positionDirty || this.targetDirty;\n\t}\n\n\tset dirtectDirty(value) {\n\t\tthis.positionDirty = value;\n\t\tthis.targetDirty = value;\n\t}\n\n\tget directional() {\n\t\tconst result = new Vector3();\n\t\tVector3.subtract(this.target, this.position, result);\n\t\treturn result.normalize();\n\t}\n}\n// uniform\n// direction: {},\n// color: {}\n","import Camera from \"../camera/Camera\";\r\nimport { FrameState } from \"../core/FrameState\";\r\nimport RenderObject from \"../core/RenderObject\";\r\nimport { RenderObjectType } from \"../core/WebGPUTypes\";\r\nimport createGuid from \"../utils/createGuid\";\r\nimport { Mesh } from \"./Mesh\";\r\n\r\nexport default class Node extends RenderObject {\r\n\tuid: string;\r\n\tchildren: Map<string, Node | Mesh>;\r\n\tname: string;\r\n\tconstructor() {\r\n\t\tsuper();\r\n\t\tthis.type = RenderObjectType.Node;\r\n\t\tthis.children = new Map();\r\n\t\tthis.parent = null;\r\n\t\tthis.uid = createGuid();\r\n\t}\r\n\tadd(node: Node | Mesh) {\r\n\t\tnode.parent = this;\r\n\t\tthis.children.set(node.uid, node);\r\n\t}\r\n\tremove(node: Node | Mesh) {\r\n\t\tthis.children.delete(node.uid);\r\n\t}\r\n\tupdate(frameState: FrameState, camera?: Camera) {\r\n\t\tthis.updateMatrix(this?.parent?.modelMatrix?.clone());\r\n\t\tthis?.children?.forEach?.((node) => {\r\n\t\t\tnode.update(frameState, camera);\r\n\t\t});\r\n\t}\r\n\tdestroy() {\r\n\t\tthis.children.forEach((node) => {\r\n\t\t\tnode.destroy();\r\n\t\t});\r\n\t\tthis?.children?.clear();\r\n\t}\r\n\ttraverse(traverseFunction: Function, param: { [prop: string]: any }): void {\r\n\t\tfor (let i = 0, len = this.children.size; i < len; i++) {\r\n\t\t\tthis.children.forEach((child) => {\r\n\t\t\t\tchild.traverse(traverseFunction, param);\r\n\t\t\t});\r\n\t\t}\r\n\t}\r\n}\r\n","import Camera from \"../camera/Camera\";\nimport { FrameState } from \"../core/FrameState\";\nimport { BufferBindingType, BufferUsage } from \"../core/WebGPUConstant\";\nimport { RenderObjectType } from \"../core/WebGPUTypes\";\nimport Geometry from \"../geometry/Geometry\";\nimport { Material } from \"../material/Material\";\nimport Matrix4 from \"../math/Matrix4\";\nimport UniformBuffer from \"../render/UniformBuffer\";\nimport { UniformEnum } from \"../render/Uniforms\";\nimport { Mesh } from \"./Mesh\";\nimport Node from \"./Node\";\n\nexport class SKinMesh extends Mesh {\n\tinverseBindMatrices: Array<Matrix4>;\n\tuniformMatrixs: Array<Matrix4>;\n\tjoints: Array<Node>;\n\tprivate hasAddJoints: boolean;\n\tconstructor(geometry?: Geometry, material?: Material) {\n\t\tsuper(geometry, material);\n\t\tthis.type = RenderObjectType.SkinMesh;\n\t\tthis.uniformMatrixs = [];\n\t\tthis.hasAddJoints = false;\n\t}\n\tsetSkinData(data: SkinDataType) {\n\t\tthis.inverseBindMatrices = data.inverseBindMatrices;\n\t\tthis.joints = data.joints;\n\t}\n\tupdate(frameState: FrameState, camera?: Camera) {\n\t\tthis.uniformMatrixs = this.joints.map((joint) => (joint as Node).modelMatrix);\n\t\tsuper.update(frameState, camera);\n\t\tif (!this.hasAddJoints) this.addUniformsToMaterial();\n\t}\n\tprivate addUniformsToMaterial() {\n\t\tif (!this.material.shaderData) return;\n\t\tthis.hasAddJoints = true;\n\t\tif (this.joints) {\n\t\t\tconst skinJointsBuffer = new UniformBuffer({\n\t\t\t\tlabel: \"skinJointsBuffer\",\n\t\t\t\ttype: BufferBindingType.ReadOnlyStorage,\n\t\t\t\tusage: BufferUsage.Storage | BufferUsage.CopyDst,\n\t\t\t\tsize: 3000\n\t\t\t});\n\t\t\tconst invsBuffer = new UniformBuffer({\n\t\t\t\tlabel: \"invsBuffer\",\n\t\t\t\ttype: BufferBindingType.ReadOnlyStorage,\n\t\t\t\tusage: BufferUsage.Storage | BufferUsage.CopyDst,\n\t\t\t\tsize: 3000\n\t\t\t});\n\t\t\tskinJointsBuffer.setUniform(\n\t\t\t\t\"joints\",\n\t\t\t\t() => {\n\t\t\t\t\treturn this.uniformMatrixs;\n\t\t\t\t},\n\t\t\t\tUniformEnum.Mat4Array,\n\t\t\t\tthis.uniformMatrixs.length\n\t\t\t);\n\t\t\tinvsBuffer.setUniform(\n\t\t\t\t\"jointsInv\",\n\t\t\t\t() => {\n\t\t\t\t\treturn this.inverseBindMatrices;\n\t\t\t\t},\n\t\t\t\tUniformEnum.Mat4Array,\n\t\t\t\tthis.inverseBindMatrices.length\n\t\t\t);\n\t\t\tthis.material.shaderData.setUniformBuffer(\"skinJointsBuffer\", skinJointsBuffer);\n\t\t\tthis.material.shaderData.setUniformBuffer(\"invsBuffer\", invsBuffer);\n\t\t}\n\t}\n}\nexport type SkinDataType = {\n\tinverseBindMatrices?: Array<Matrix4>;\n\tjoints?: Array<Node>;\n};\n","import { Quaternion } from \"../math/Quaternion\";\r\nimport Vector2 from \"../math/Vector2\";\r\nimport Vector3 from \"../math/Vector3\";\r\n\r\nexport function clamp(num: number, min: number, max: number) {\r\n\treturn Math.min(Math.max(num, min), max);\r\n}\r\n\r\nexport function toFloat(num: number | undefined, defaultValue = 1) {\r\n\tconst n = num !== undefined ? num : defaultValue;\r\n\tif (Number.isInteger(n)) {\r\n\t\treturn `${n}.0`;\r\n\t}\r\n\treturn n;\r\n}\r\n\r\nexport type TypedArray = Int8Array | Uint8Array | Int16Array | Uint16Array | Uint32Array | Float32Array;\r\n\r\nexport function newTypedArray(type: number, buffer: ArrayBuffer, byteOffset: number, length: number) {\r\n\tswitch (type) {\r\n\t\tcase 5120:\r\n\t\t\treturn new Int8Array(buffer, byteOffset, length);\r\n\t\tcase 5121:\r\n\t\t\treturn new Uint8Array(buffer, byteOffset, length);\r\n\t\tcase 5122:\r\n\t\t\treturn new Int16Array(buffer, byteOffset, length);\r\n\t\tcase 5123:\r\n\t\t\treturn new Uint16Array(buffer, byteOffset, length);\r\n\t\tcase 5124:\r\n\t\t\treturn new Int32Array(buffer, byteOffset, length);\r\n\t\tcase 5125:\r\n\t\t\treturn new Uint32Array(buffer, byteOffset, length);\r\n\t\tcase 5126:\r\n\t\t\treturn new Float32Array(buffer, byteOffset, length);\r\n\t\tdefault:\r\n\t\t\tthrow new Error(\"invalid component type\");\r\n\t}\r\n}\r\n\r\nexport function toIndices(array: TypedArray): Uint16Array | Uint32Array {\r\n\tif (array instanceof Uint16Array || array instanceof Uint32Array) {\r\n\t\treturn array;\r\n\t}\r\n\tlet toArray;\r\n\tif (array instanceof Float32Array) {\r\n\t\ttoArray = new Uint32Array(array.length);\r\n\t} else {\r\n\t\ttoArray = new Uint16Array(array.length);\r\n\t}\r\n\tarray.forEach((element, index) => {\r\n\t\ttoArray[index] = element;\r\n\t});\r\n\treturn toArray;\r\n}\r\n\r\nexport function joinArray(arrays: Array<Float32Array>) {\r\n\tlet length = 0;\r\n\tarrays.forEach((array) => {\r\n\t\tlength += array.length;\r\n\t});\r\n\tconst joined = new Float32Array(length);\r\n\tlength = 0;\r\n\tarrays.forEach((array) => {\r\n\t\tjoined.set(array, length);\r\n\t\tlength += array.length;\r\n\t});\r\n\treturn joined;\r\n}\r\n\r\nexport function createGPUBuffer(array: TypedArray, usage: number, device: GPUDevice) {\r\n\tconst buffer = device.createBuffer({\r\n\t\tsize: (array.byteLength + 3) & ~3, // eslint-disable-line no-bitwise\r\n\t\tusage,\r\n\t\tmappedAtCreation: true\r\n\t});\r\n\tlet writeArary;\r\n\tif (array instanceof Int8Array) {\r\n\t\twriteArary = new Int8Array(buffer.getMappedRange());\r\n\t} else if (array instanceof Uint8Array) {\r\n\t\twriteArary = new Uint8Array(buffer.getMappedRange());\r\n\t} else if (array instanceof Int16Array) {\r\n\t\twriteArary = new Int16Array(buffer.getMappedRange());\r\n\t} else if (array instanceof Uint16Array) {\r\n\t\twriteArary = new Uint16Array(buffer.getMappedRange());\r\n\t} else if (array instanceof Uint32Array) {\r\n\t\twriteArary = new Uint32Array(buffer.getMappedRange());\r\n\t} else {\r\n\t\twriteArary = new Float32Array(buffer.getMappedRange());\r\n\t}\r\n\twriteArary.set(array);\r\n\tbuffer.unmap();\r\n\treturn buffer;\r\n}\r\n\r\nexport function generateNormals(indices: TypedArray | null, positions: TypedArray) {\r\n\tconst normals = new Float32Array(positions.length);\r\n\tconst vertexCount = indices ? indices.length : positions.length;\r\n\tfor (let i = 0; i < vertexCount; i += 3) {\r\n\t\tconst triIndices = [];\r\n\t\tfor (let n = 0; n < 3; n += 1) {\r\n\t\t\tif (indices) {\r\n\t\t\t\ttriIndices.push(indices[i + n]);\r\n\t\t\t} else {\r\n\t\t\t\ttriIndices.push(i + n);\r\n\t\t\t}\r\n\t\t}\r\n\t\tconst triangle = triIndices.map((vertexIndex) => {\r\n\t\t\tconst index = vertexIndex * 3;\r\n\t\t\treturn new Vector3(positions[index], positions[index + 1], positions[index + 2]);\r\n\t\t});\r\n\t\tconst dv1 = new Vector3();\r\n\t\tVector3.subtract(triangle[1], triangle[0], dv1);\r\n\t\tconst dv2 = new Vector3();\r\n\t\tVector3.subtract(triangle[2], triangle[0], dv2);\r\n\t\tconst normal = new Vector3();\r\n\t\tVector3.cross(dv1.normalize(), dv2.normalize(), normal);\r\n\t\tfor (let n = 0; n < 3; n += 1) {\r\n\t\t\tconst index = (i + n) * 3;\r\n\t\t\tnormals[index + 0] += normal.x;\r\n\t\t\tnormals[index + 1] += normal.y;\r\n\t\t\tnormals[index + 2] += normal.z;\r\n\t\t}\r\n\t}\r\n\treturn normals;\r\n}\r\n\r\nexport function generateTangents(\r\n\tindices: TypedArray | null,\r\n\tpositions: TypedArray,\r\n\tnormals: TypedArray,\r\n\tuvs: TypedArray\r\n) {\r\n\tconst tangents = new Float32Array((normals.length / 3) * 4);\r\n\tconst vertexCount = indices ? indices.length : positions.length;\r\n\tfor (let i = 0; i < vertexCount; i += 3) {\r\n\t\tconst triIndices = [];\r\n\t\tfor (let n = 0; n < 3; n += 1) {\r\n\t\t\tif (indices) {\r\n\t\t\t\ttriIndices.push(indices[i + n]);\r\n\t\t\t} else {\r\n\t\t\t\ttriIndices.push(i + n);\r\n\t\t\t}\r\n\t\t}\r\n\t\tconst pos = triIndices.map((vertexIndex) => {\r\n\t\t\tconst index = vertexIndex * 3;\r\n\t\t\treturn new Vector3(positions[index], positions[index + 1], positions[index + 2]);\r\n\t\t});\r\n\t\tconst uv = triIndices.map((vertexIndex) => {\r\n\t\t\tconst index = vertexIndex * 2;\r\n\t\t\treturn new Vector2(uvs?.[index], uvs?.[index + 1]);\r\n\t\t});\r\n\r\n\t\tconst dv1 = new Vector3();\r\n\t\tVector3.subtract(pos[1], pos[0], dv1);\r\n\t\tconst dv2 = new Vector3();\r\n\t\tVector3.subtract(pos[2], pos[0], dv2);\r\n\t\tconst duv1 = new Vector2();\r\n\t\tVector2.subtract(uv[1], uv[0], duv1);\r\n\t\tconst duv2 = new Vector2();\r\n\t\tVector2.subtract(uv[2], uv[0], duv2);\r\n\r\n\t\tconst tangent = new Vector3();\r\n\t\tVector3.multiplyByScalar(dv1, duv1.y, dv1);\r\n\t\tVector3.multiplyByScalar(dv2, duv2.y, dv2);\r\n\t\tVector3.subtract(dv1, dv2, tangent);\r\n\r\n\t\tVector3.multiplyByScalar(tangent, duv2.y * duv1.x - duv1.y * duv2.x, tangent);\r\n\r\n\t\ttangent.normalize();\r\n\t\tfor (let n = 0; n < 3; n += 1) {\r\n\t\t\tconst index = (i + n) * 4;\r\n\r\n\t\t\ttangents[index + 0] += tangent.x;\r\n\t\t\ttangents[index + 1] += tangent.y;\r\n\t\t\ttangents[index + 2] += tangent.z;\r\n\t\t\ttangents[index + 3] = 1;\r\n\t\t}\r\n\t}\r\n\treturn tangents;\r\n}\r\n\r\nfunction lerp(a: number, b: number, x: number) {\r\n\tif (x < a) {\r\n\t\treturn 0;\r\n\t}\r\n\tif (x > b) {\r\n\t\treturn 1;\r\n\t}\r\n\treturn (x - a) / (b - a);\r\n}\r\n\r\nexport function interpQuat(input: TypedArray, o: TypedArray, time: number, method: string) {\r\n\tlet index = 1;\r\n\twhile (index < input.length - 1 && time >= input[index]) {\r\n\t\tindex += 1;\r\n\t}\r\n\tconst t = lerp(input[index - 1], input[index], time);\r\n\r\n\tif (method === \"CUBICSPLINE\") {\r\n\t\tconst td = input[index] - input[index - 1];\r\n\t\tconst t2 = t * t;\r\n\t\tconst t3 = t2 * t;\r\n\t\tconst i = 12 * index;\r\n\r\n\t\tconst v0 = new Quaternion(o[i - 8], o[i - 7], o[i - 6], o[i - 5]);\r\n\t\tconst b0 = new Quaternion(o[i - 4], o[i - 3], o[i - 2], o[i - 1]);\r\n\t\tconst v1 = new Quaternion(o[i + 4], o[i + 5], o[i + 6], o[i + 7]);\r\n\t\tconst a1 = new Quaternion(o[i], o[i + 1], o[i + 2], o[i + 3]);\r\n\t\tQuaternion.multiplyByScalar(v0, 2 * t3 - 3 * t2 + 1, v0);\r\n\t\tQuaternion.multiplyByScalar(b0, td * (t3 - 2 * t2 + t), b0);\r\n\t\tQuaternion.multiplyByScalar(v1, -2 * t3 + 3 * t2, v1);\r\n\t\tQuaternion.multiplyByScalar(a1, td * (t3 - t2), a1);\r\n\r\n\t\tconst result = new Quaternion();\r\n\t\tQuaternion.add(result, v0, result);\r\n\t\tQuaternion.add(result, b0, result);\r\n\t\tQuaternion.add(result, v1, result);\r\n\t\tQuaternion.add(result, a1, result);\r\n\t\tQuaternion.normalize(result, result);\r\n\t\treturn result;\r\n\t}\r\n\r\n\tconst q = [];\r\n\tfor (let n = -1; n < 1; n += 1) {\r\n\t\tconst i = 4 * (index + n);\r\n\t\tq.push(new Quaternion(o[i], o[i + 1], o[i + 2], o[i + 3]));\r\n\t}\r\n\r\n\tif (method === \"STEP\") {\r\n\t\treturn t < 1 ? q[0] : q[1];\r\n\t}\r\n\tconst result = new Quaternion();\r\n\tQuaternion.slerp(q[0], q[1], t, result);\r\n\treturn result;\r\n}\r\n\r\nexport function interpVec3(input: TypedArray, output: TypedArray, time: number, method: string) {\r\n\tlet index = 1;\r\n\twhile (index < input.length - 1 && time >= input[index]) {\r\n\t\tindex += 1;\r\n\t}\r\n\tconst t = lerp(input[index - 1], input[index], time);\r\n\r\n\tif (method === \"CUBICSPLINE\") {\r\n\t\tconst td = input[index] - input[index - 1];\r\n\t\tconst t2 = t * t;\r\n\t\tconst t3 = t2 * t;\r\n\t\tconst i = 9 * index;\r\n\t\tconst v0 = new Vector3(output[i - 6], output[i - 5], output[i - 4]);\r\n\t\tconst b0 = new Vector3(output[i - 3], output[i - 2], output[i - 1]);\r\n\t\tconst v1 = new Vector3(output[i + 3], output[i + 4], output[i + 5]);\r\n\t\tconst a1 = new Vector3(output[i], output[i + 1], output[i + 2]);\r\n\t\tVector3.multiplyByScalar(v0, 2 * t3 - 3 * t2 + 1, v0);\r\n\t\tVector3.multiplyByScalar(b0, td * (t3 - 2 * t2 + t), b0);\r\n\t\tVector3.multiplyByScalar(v1, -2 * t3 + 3 * t2, v1);\r\n\t\tVector3.multiplyByScalar(a1, td * (t3 - t2), a1);\r\n\t\tconst result = new Vector3();\r\n\t\tVector3.add(result, v0, result);\r\n\t\tVector3.add(result, b0, result);\r\n\t\tVector3.add(result, v1, result);\r\n\t\tVector3.add(result, a1, result);\r\n\t\treturn result;\r\n\t}\r\n\r\n\tconst v = [];\r\n\tfor (let n = -1; n < 1; n += 1) {\r\n\t\tconst i = 3 * (index + n);\r\n\t\tv.push(new Vector3(output[i], output[i + 1], output[i + 2]));\r\n\t}\r\n\r\n\tif (method === \"STEP\") {\r\n\t\treturn t < 1 ? v[0] : v[1];\r\n\t}\r\n\tconst result = new Vector3();\r\n\treturn Vector3.lerp(v[0], v[1], t, result);\r\n}\r\n\r\nexport const gltfEnum: { [key: string]: string | number } = {\r\n\tSCALAR: 1,\r\n\tVEC2: 2,\r\n\tVEC3: 3,\r\n\tVEC4: 4,\r\n\tMAT2: 4,\r\n\tMAT3: 9,\r\n\tMAT4: 16,\r\n\t5120: 1,\r\n\t5121: 1,\r\n\t5122: 2,\r\n\t5123: 2,\r\n\t5125: 4,\r\n\t5126: 4,\r\n\t9728: \"nearest\",\r\n\t9729: \"linear\",\r\n\t9984: \"linear\",\r\n\t9985: \"linear\",\r\n\t9986: \"linear\",\r\n\t9987: \"linear\",\r\n\t33071: \"clamp-to-edge\",\r\n\t33648: \"mirror-repeat\",\r\n\t10497: \"repeat\"\r\n};\r\n","import Matrix4 from \"../../../math/Matrix4\";\r\nimport Vector4 from \"../../../math/Vector4\";\r\n\r\nexport class Accessor {\r\n\tvalues: any;\r\n\tid: number;\r\n\tcount: number;\r\n\tcomponentType: number;\r\n\ttype: number;\r\n\tmin: number[];\r\n\tmax: number[];\r\n\tconstructor(options: AccessorParms) {\r\n\t\tthis.values = options.values ?? [];\r\n\t\tthis.id = options.id;\r\n\t\tthis.count = options.count;\r\n\t\tthis.componentType = options.componentType;\r\n\t\tthis.type = options.type;\r\n\t\tthis.min = options.min;\r\n\t\tthis.max = options.max;\r\n\t}\r\n\tgetArray(): number[] {\r\n\t\treturn Array.from(this.values);\r\n\t}\r\n\tgetVec4Array(): Vector4[] {\r\n\t\tconst result = [];\r\n\t\tfor (let i = 0; i < this.values.length; i += 4) {\r\n\t\t\tresult.push(new Vector4(this.values[i], this.values[i + 1], this.values[i + 2], this.values[i + 3]));\r\n\t\t}\r\n\t\treturn result;\r\n\t}\r\n\tgetMat4Array(): Matrix4[] {\r\n\t\tconst result = [];\r\n\t\tfor (let i = 0; i < this.values.length; i += 16) {\r\n\t\t\tconst mat4 = new Matrix4();\r\n\t\t\tMatrix4.fromColumnMajorArray(this.values.slice(i, i + 16), mat4);\r\n\t\t\tresult.push(mat4);\r\n\t\t}\r\n\t\treturn result;\r\n\t}\r\n}\r\nexport type AccessorParms = Partial<Accessor>;\r\n","import { Quaternion } from \"../../../math/Quaternion\";\nimport Vector4 from \"../../../math/Vector4\";\nimport { AnimationChannel } from \"./AnimationChannel\";\nimport { AnimationSampler } from \"./AnimationSampler\";\n\nexport class Animation {\n\tconstructor(public name: string, public samplers: AnimationSampler[], public channels: AnimationChannel[]) {}\n\tplay(time: number) {\n\t\tlet node, animationSampler, target;\n\t\tthis?.channels?.map((channel) => {\n\t\t\tanimationSampler = channel.sampler;\n\t\t\tanimationSampler.getValue(time);\n\t\t\ttarget = channel.target;\n\t\t\tnode = target.node;\n\t\t\tswitch (target.path) {\n\t\t\t\tcase \"rotation\":\n\t\t\t\t\tQuaternion.clone(animationSampler.currentValue, node.quaternion);\n\t\t\t\t\tbreak;\n\t\t\t\tcase \"translation\":\n\t\t\t\t\tVector4.clone(animationSampler.currentValue, node.position);\n\t\t\t\t\tbreak;\n\t\t\t\tcase \"scale\":\n\t\t\t\t\tVector4.clone(animationSampler.currentValue, node.scale);\n\t\t\t\t\tbreak;\n\t\t\t}\n\t\t});\n\t}\n}\n","import { AnimationChannelTarget } from \"./AnimationChannelTarget\";\nimport { AnimationSampler } from \"./AnimationSampler\";\n\nexport class AnimationChannel {\n\tsampler: AnimationSampler;\n\ttarget: AnimationChannelTarget;\n\tconstructor() {}\n}\n","import Node from \"../../../mesh/Node\";\n\nexport class AnimationChannelTarget {\n\tnode: Node;\n\tpath: \"translation\" | \"rotation\" | \"scale\" | \"weights\";\n\tconstructor(node, path) {\n\t\tthis.node = node;\n\t\tthis.path = path;\n\t}\n}\n","export enum Type2NumOfComponent {\r\n\t\"SCALAR\" = 1,\r\n\t\"VEC2\" = 2,\r\n\t\"VEC3\" = 3,\r\n\t\"VEC4\" = 4,\r\n\t\"MAT2\" = 4,\r\n\t\"MAT3\" = 9,\r\n\t\"MAT4\" = 16\r\n}\r\n","import { Quaternion } from \"../../../math/Quaternion\";\r\nimport Vector4 from \"../../../math/Vector4\";\r\nimport { Type2NumOfComponent } from \"../types/gltfType\";\r\nexport class AnimationSampler {\r\n\tinput: any;\r\n\tinterpolation: \"LINEAR\" | \"STEP\" | \"CUBICSPLINE\";\r\n\toutput: any;\r\n\tcurrentIndex: number;\r\n\tstartTime: number;\r\n\tendTime: number;\r\n\tcurrentValue: Vector4 | Quaternion;\r\n\tduration: number;\r\n\tinputMax: number;\r\n\tprivate inputType: string;\r\n\tprivate outputType: string;\r\n\tconstructor() {}\r\n\tformGltf(gltf, sampler) {\r\n\t\tthis.input = gltf.accessors[sampler.input].values; //required, accessor object\r\n\t\tthis.output = gltf.accessors[sampler.output].values; //required, accessor object\r\n\t\tthis.interpolation = sampler.interpolation !== undefined ? sampler.interpolation : \"LINEAR\";\r\n\t\tthis.currentIndex = 0;\r\n\t\t// this.currentValue=new Vector4();\r\n\t\tthis.endTime = this.input[this.input.length - 1];\r\n\t\tthis.inputMax = this.endTime - this.input[0];\r\n\t\tthis.inputType = gltf?.json?.accessors[sampler.input]?.type;\r\n\t\tthis.outputType = gltf?.json?.accessors[sampler.output]?.type;\r\n\t}\r\n\tgetValue(time: number): void {\r\n\t\tif (time > this.endTime) {\r\n\t\t\ttime -= this.inputMax * Math.ceil((time - this.endTime) / this.inputMax);\r\n\t\t\tthis.currentIndex = 0;\r\n\t\t}\r\n\r\n\t\tconst len = this.input.length;\r\n\t\twhile (this.currentIndex <= len - 2 && time >= this.input[this.currentIndex + 1]) {\r\n\t\t\tthis.currentIndex++;\r\n\t\t}\r\n\r\n\t\tif (this.currentIndex >= len - 1) {\r\n\t\t\t// loop\r\n\t\t\ttime -= this.inputMax;\r\n\t\t\tthis.currentIndex = 0;\r\n\t\t}\r\n\r\n\t\t// @tmp: assume no stride\r\n\t\tconst count = Type2NumOfComponent[this.outputType];\r\n\r\n\t\tconst animationOutputValueVec4a = count === 4 ? new Quaternion() : new Vector4();\r\n\t\tconst animationOutputValueVec4b = count === 4 ? new Quaternion() : new Vector4();\r\n\t\tif (!this.currentValue) this.currentValue = count === 4 ? new Quaternion() : new Vector4();\r\n\t\tconst i = this.currentIndex;\r\n\t\tconst o = i * count;\r\n\t\tconst on = o + count;\r\n\r\n\t\tconst u = Math.max(0, time - this.input[i]) / (this.input[i + 1] - this.input[i]);\r\n\t\tanimationOutputValueVec4a.set(this.output[o + 0], this.output[o + 1], this.output[o + 2], this.output[o + 3]);\r\n\t\tanimationOutputValueVec4b.set(\r\n\t\t\tthis.output[on + 0],\r\n\t\t\tthis.output[on + 1],\r\n\t\t\tthis.output[on + 2],\r\n\t\t\tthis.output[on + 3]\r\n\t\t);\r\n\t\tswitch (this.interpolation) {\r\n\t\t\tcase \"LINEAR\":\r\n\t\t\t\tcount === 4\r\n\t\t\t\t\t? Quaternion.slerp(\r\n\t\t\t\t\t\t\t<Quaternion>animationOutputValueVec4a,\r\n\t\t\t\t\t\t\t<Quaternion>animationOutputValueVec4b,\r\n\t\t\t\t\t\t\tu,\r\n\t\t\t\t\t\t\t<Quaternion>this.currentValue\r\n\t\t\t\t\t  )\r\n\t\t\t\t\t: Vector4.lerp(\r\n\t\t\t\t\t\t\t<Vector4>animationOutputValueVec4a,\r\n\t\t\t\t\t\t\t<Vector4>animationOutputValueVec4b,\r\n\t\t\t\t\t\t\tu,\r\n\t\t\t\t\t\t\t<Vector4>this.currentValue\r\n\t\t\t\t\t  );\r\n\t\t\t\tbreak;\r\n\t\t\tdefault:\r\n\t\t\t\tbreak;\r\n\t\t}\r\n\t}\r\n}\r\n","import { RenderObjectType } from \"../core/WebGPUTypes\";\r\nimport Geometry from \"../geometry/Geometry\";\r\nimport PbrMaterial from \"../material/PbrMaterial\";\r\nimport Color from \"../math/Color\";\r\nimport Matrix4 from \"../math/Matrix4\";\r\nimport { Quaternion } from \"../math/Quaternion\";\r\nimport Vector3 from \"../math/Vector3\";\r\nimport { Mesh } from \"../mesh/Mesh\";\r\nimport Node from \"../mesh/Node\";\r\nimport { SKinMesh } from \"../mesh/SKinMesh\";\r\nimport { Float32Attribute } from \"../render/Attribute\";\r\nimport Sampler from \"../render/Sampler\";\r\nimport Texture from \"../render/Texture\";\r\nimport { generateNormals, gltfEnum, newTypedArray, toIndices, TypedArray } from \"../utils/gltfUtils\";\r\nimport { Accessor } from \"./gltf/libs/Accessor\";\r\nimport { Animation } from \"./gltf/libs/Animation\";\r\nimport { AnimationChannel } from \"./gltf/libs/AnimationChannel\";\r\nimport { AnimationChannelTarget } from \"./gltf/libs/AnimationChannelTarget\";\r\nimport { AnimationSampler } from \"./gltf/libs/AnimationSampler\";\r\n\r\nexport type GLTFPrimitive = {\r\n\tvertexCount: number;\r\n\tindices: Uint16Array | Uint32Array | null;\r\n\tpositions: TypedArray;\r\n\tnormals: TypedArray;\r\n\tuvs: TypedArray | null;\r\n\tuv1s: TypedArray | null;\r\n\ttangents: TypedArray | null;\r\n\tcolors: TypedArray | null;\r\n\tmaterial: any;\r\n\tboundingBox: {\r\n\t\tmax: [number, number, number];\r\n\t\tmin: [number, number, number];\r\n\t};\r\n};\r\n\r\nexport type GLTFMesh = Array<GLTFPrimitive>;\r\n\r\nexport type GLTFAnimation = {\r\n\tchannels: Array<{\r\n\t\tinput: TypedArray;\r\n\t\toutput: TypedArray;\r\n\t\tinterpolation: string;\r\n\t\tnode: number;\r\n\t\tpath: string;\r\n\t}>;\r\n\tlength: number;\r\n};\r\n\r\nexport class GLTF {\r\n\tscenes: Array<Node>;\r\n\r\n\tnodes: Array<any>;\r\n\r\n\tcameras: Array<any>;\r\n\r\n\tmeshes: Array<any>;\r\n\r\n\timages: Array<ImageBitmap>;\r\n\r\n\tanimations: Array<GLTFAnimation>;\r\n\r\n\tprivate glbOffset: number;\r\n\r\n\tprivate buffers: ArrayBuffer[];\r\n\r\n\tprivate bufferViews: any;\r\n\r\n\taccessors: any;\r\n\r\n\tjson: any;\r\n\r\n\tprivate materials: any;\r\n\r\n\tprivate glbBin?: ArrayBuffer;\r\n\r\n\tprivate rootUrl: string;\r\n\r\n\ttextures: any[];\r\n\r\n\tsamplers: Sampler[];\r\n\r\n\tconstructor(json: any, rootUrl: string, glbOffset = 0, glbBin?: ArrayBuffer) {\r\n\t\tthis.json = json;\r\n\t\tthis.bufferViews = json.bufferViews;\r\n\t\tthis.glbOffset = glbOffset;\r\n\t\tthis.rootUrl = rootUrl;\r\n\t\tthis.scenes = json.scenes;\r\n\t\tthis.cameras = json.cameras || [];\r\n\t\tthis.glbBin = glbBin;\r\n\t\tthis.meshes = [];\r\n\t}\r\n\tasync parseData() {\r\n\t\tthis.buffers = await this.loadBuffes();\r\n\t\tthis.images = await this.loadImages();\r\n\t\tthis.parseSamplers();\r\n\t\tthis.parseTextures();\r\n\t\tthis.parseMaterials();\r\n\t\tthis.parseAccessors();\r\n\t\tthis.parseMeshs();\r\n\t\tthis.parseNodes();\r\n\t\tthis.normalizeData();\r\n\t\tthis.parseScenes();\r\n\t\tthis.parseAnimations();\r\n\t}\r\n\tprivate getAccessor(index: number) {\r\n\t\treturn this.accessors[index];\r\n\t}\r\n\tprivate parseSamplers() {\r\n\t\tthis.samplers = this.json.samplers\r\n\t\t\t? (this.json.samplers as Array<any>).map((sampler) => this.getSampler(sampler))\r\n\t\t\t: [];\r\n\t}\r\n\tprivate parseScenes() {\r\n\t\tthis.scenes = this.json.scenes.map((scene) => {\r\n\t\t\tconst nodes = scene?.nodes?.map((nodeId) => {\r\n\t\t\t\treturn this.nodes[nodeId];\r\n\t\t\t});\r\n\t\t\treturn nodes;\r\n\t\t});\r\n\t}\r\n\tprivate parseTextures() {\r\n\t\tthis.textures = this.json.textures\r\n\t\t\t? (this.json.textures as Array<any>).map((texture) => {\r\n\t\t\t\t\treturn {\r\n\t\t\t\t\t\tsampler: texture.sampler !== undefined ? this.samplers[texture.sampler] : this.getSampler({}),\r\n\t\t\t\t\t\ttexture: this.createTexture(texture.source)\r\n\t\t\t\t\t};\r\n\t\t\t  })\r\n\t\t\t: [];\r\n\t}\r\n\tprivate parseMaterials() {\r\n\t\tthis.materials = this.json.materials\r\n\t\t\t? (this.json.materials as Array<any>).map((material) => {\r\n\t\t\t\t\tconst mat = new PbrMaterial();\r\n\t\t\t\t\tconst {\r\n\t\t\t\t\t\tbaseColorFactor,\r\n\t\t\t\t\t\tmetallicFactor,\r\n\t\t\t\t\t\tmetallicRoughnessTexture,\r\n\t\t\t\t\t\tbaseColorTexture,\r\n\t\t\t\t\t\troughnessFactor\r\n\t\t\t\t\t} = material.pbrMetallicRoughness;\r\n\t\t\t\t\tif (material.normalTexture) mat.normalTexture = this.textures[material.normalTexture.index].texture;\r\n\t\t\t\t\tif (material.occlusionTexture)\r\n\t\t\t\t\t\tmat.aoTexture = this.textures[material.occlusionTexture.index].texture;\r\n\t\t\t\t\tif (material.emissiveTexture)\r\n\t\t\t\t\t\tmat.emissiveTexture = this.textures[material.emissiveTexture.index].texture;\r\n\t\t\t\t\tif (baseColorTexture) mat.baseTexture = this.textures[baseColorTexture.index].texture;\r\n\t\t\t\t\tif (metallicRoughnessTexture)\r\n\t\t\t\t\t\tmat.metalnessRoughnessTexture = this.textures[metallicRoughnessTexture.index].texture;\r\n\t\t\t\t\tif (baseColorFactor)\r\n\t\t\t\t\t\tmat.color = new Color(baseColorFactor[0], baseColorFactor[1], baseColorFactor[2]);\r\n\t\t\t\t\tmat.metalness = metallicFactor ?? 1.0;\r\n\t\t\t\t\tmat.roughness = roughnessFactor ?? 0.0;\r\n\t\t\t\t\tmat.baseSampler = new Sampler({\r\n\t\t\t\t\t\tmagFilter: \"linear\",\r\n\t\t\t\t\t\tminFilter: \"linear\",\r\n\t\t\t\t\t\taddressModeU: \"repeat\",\r\n\t\t\t\t\t\taddressModeV: \"repeat\"\r\n\t\t\t\t\t});\r\n\t\t\t\t\treturn mat;\r\n\t\t\t  })\r\n\t\t\t: [];\r\n\t}\r\n\tprivate parseAccessors() {\r\n\t\tthis.accessors = (this.json.accessors as Array<any>).map((accessor, index) => {\r\n\t\t\tconst n = gltfEnum[accessor.type] as number;\r\n\t\t\tlet array;\r\n\t\t\tif (accessor.bufferView === undefined) {\r\n\t\t\t\tarray = newTypedArray(\r\n\t\t\t\t\taccessor.componentType,\r\n\t\t\t\t\tnew ArrayBuffer(n * accessor.count * (gltfEnum[accessor.componentType] as number)),\r\n\t\t\t\t\t0,\r\n\t\t\t\t\taccessor.count * n\r\n\t\t\t\t);\r\n\t\t\t} else {\r\n\t\t\t\tarray = this.getBufferView(accessor, n);\r\n\t\t\t}\r\n\r\n\t\t\tif (accessor.sparse) {\r\n\t\t\t\taccessor.sparse.indices.count = accessor.sparse.count;\r\n\t\t\t\taccessor.sparse.values.count = accessor.sparse.count;\r\n\t\t\t\taccessor.sparse.values.componentType = accessor.componentType;\r\n\t\t\t\tconst indices = this.getBufferView(accessor.sparse.indices, 1);\r\n\t\t\t\tconst values = this.getBufferView(accessor.sparse.values, n);\r\n\t\t\t\tfor (let i = 0; i < accessor.sparse.count; i += 1) {\r\n\t\t\t\t\tfor (let j = 0; j < n; j += 1) {\r\n\t\t\t\t\t\tarray[indices[i] * n + j] = values[i * n + j];\r\n\t\t\t\t\t}\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t\treturn new Accessor({\r\n\t\t\t\tcomponentType: <number>gltfEnum[accessor.componentType],\r\n\t\t\t\tcount: accessor.count,\r\n\t\t\t\ttype: n,\r\n\t\t\t\tvalues: array,\r\n\t\t\t\tid: index,\r\n\t\t\t\tmin: accessor?.min,\r\n\t\t\t\tmax: accessor?.max\r\n\t\t\t});\r\n\t\t});\r\n\t}\r\n\tprivate parseAnimations() {\r\n\t\tthis.animations = this?.json?.animations?.map((gltfAnimation, index) => {\r\n\t\t\tconst samplers = gltfAnimation?.samplers?.map((gltfSampler) => {\r\n\t\t\t\tconst sampler = new AnimationSampler();\r\n\t\t\t\tsampler.formGltf(this, gltfSampler);\r\n\t\t\t\treturn sampler;\r\n\t\t\t});\r\n\t\t\tconst channels = gltfAnimation?.channels?.map((gltfChannel) => {\r\n\t\t\t\tconst animationChannel = new AnimationChannel();\r\n\t\t\t\tanimationChannel.sampler = samplers[gltfChannel.sampler];\r\n\t\t\t\tanimationChannel.target = new AnimationChannelTarget(\r\n\t\t\t\t\tthis.nodes[gltfChannel.target.node],\r\n\t\t\t\t\tgltfChannel.target.path\r\n\t\t\t\t);\r\n\t\t\t\treturn animationChannel;\r\n\t\t\t});\r\n\t\t\tconst animation = new Animation(index.toString(), samplers, channels);\r\n\t\t\treturn animation;\r\n\t\t});\r\n\t}\r\n\tprivate parseMeshs() {\r\n\t\tthis.meshes = this?.json?.meshes?.map?.((gltfmesh) => {\r\n\t\t\treturn {\r\n\t\t\t\tname: gltfmesh.name,\r\n\t\t\t\tprimitives: gltfmesh?.primitives?.map?.((primitive) => {\r\n\t\t\t\t\tconst material =\r\n\t\t\t\t\t\tprimitive.material !== undefined\r\n\t\t\t\t\t\t\t? this.materials[primitive.material]\r\n\t\t\t\t\t\t\t: { pbrMetallicRoughness: {} };\r\n\t\t\t\t\tconst geo = this.createGeometry(primitive, material);\r\n\t\t\t\t\tconst mesh = new Mesh(geo, material);\r\n\t\t\t\t\tmesh.name = gltfmesh.name;\r\n\t\t\t\t\treturn mesh;\r\n\t\t\t\t})\r\n\t\t\t};\r\n\t\t});\r\n\t}\r\n\tprivate getSampler(samplerJson: any) {\r\n\t\treturn new Sampler({\r\n\t\t\tmagFilter: gltfEnum[samplerJson.magFilter || 9729] as GPUFilterMode,\r\n\t\t\tminFilter: gltfEnum[samplerJson.minFilter || 9729] as GPUFilterMode,\r\n\t\t\taddressModeU: gltfEnum[samplerJson.wrapS || 10497] as GPUAddressMode,\r\n\t\t\taddressModeV: gltfEnum[samplerJson.wrapT || 10497] as GPUAddressMode\r\n\t\t});\r\n\t}\r\n\tprivate getBufferView(accessor: any, n: number) {\r\n\t\tconst bufferView = this.bufferViews[accessor.bufferView];\r\n\t\tconst offset = (bufferView.byteOffset || 0) + (accessor.byteOffset || 0);\r\n\t\tconst stride = Math.max(bufferView.byteStride / 4 || 0, n);\r\n\t\tlet array = newTypedArray(\r\n\t\t\taccessor.componentType,\r\n\t\t\tthis.buffers[bufferView.buffer],\r\n\t\t\tbufferView.buffer === 0 ? offset + this.glbOffset : offset,\r\n\t\t\t(accessor.count - 1) * stride + n\r\n\t\t);\r\n\t\tif (stride > n) {\r\n\t\t\tconst TypedArrayConstructor = array.constructor as {\r\n\t\t\t\tnew (...args: any): TypedArray;\r\n\t\t\t};\r\n\t\t\tconst strided = new TypedArrayConstructor(accessor.count * n);\r\n\t\t\tfor (let i = 0, j = 0; i < strided.length; i += n, j += stride) {\r\n\t\t\t\tfor (let k = 0; k < n; k += 1) {\r\n\t\t\t\t\tstrided[i + k] = array[j + k];\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t\tarray = strided;\r\n\t\t}\r\n\t\treturn array;\r\n\t}\r\n\tprivate createGeometry(primitive, material) {\r\n\t\tlet indices = null;\r\n\t\tlet accessor = null;\r\n\t\tconst defines: { [prop: string]: boolean | number } = { HAS_NORMAL: true };\r\n\t\tlet vertexCount;\r\n\t\taccessor = this.getAccessor(primitive.attributes.POSITION);\r\n\t\tconst positions = accessor.getArray();\r\n\t\tvertexCount = accessor.count;\r\n\t\t// const { max, min } = accessor;\r\n\t\t// const boundingBox = { max, min };\r\n\t\tif (primitive.indices !== undefined) {\r\n\t\t\taccessor = this.getAccessor(primitive.indices);\r\n\t\t\tindices = toIndices(accessor.getArray());\r\n\t\t\tvertexCount = accessor.count;\r\n\t\t}\r\n\t\tlet normals;\r\n\r\n\t\tif (primitive.attributes.NORMAL !== undefined) {\r\n\t\t\taccessor = this.getAccessor(primitive.attributes.NORMAL);\r\n\t\t\tnormals = accessor.getArray();\r\n\t\t} else {\r\n\t\t\tnormals = generateNormals(indices, positions);\r\n\t\t}\r\n\r\n\t\tlet uvs = null;\r\n\t\tif (primitive.attributes.TEXCOORD_0 !== undefined) {\r\n\t\t\taccessor = this.getAccessor(primitive.attributes.TEXCOORD_0);\r\n\t\t\tuvs = accessor.getArray();\r\n\t\t\tdefines.HAS_UV = true;\r\n\t\t}\r\n\t\tlet uv1s = null;\r\n\t\tif (primitive.attributes.TEXCOORD_1 !== undefined) {\r\n\t\t\taccessor = this.getAccessor(primitive.attributes.TEXCOORD_1);\r\n\t\t\tuv1s = accessor.getArray();\r\n\t\t\tdefines.HAS_UV1 = true;\r\n\t\t}\r\n\r\n\t\tlet tangents = null;\r\n\t\tif (primitive.attributes.TANGENT !== undefined && primitive.attributes.NORMAL !== undefined) {\r\n\t\t\taccessor = this.getAccessor(primitive.attributes.TANGENT);\r\n\t\t\ttangents = accessor.getArray();\r\n\t\t\t// defines.HAS_TANGENT = true;\r\n\t\t} else if (material.normalTexture) {\r\n\t\t\t// tangents = generateTangents(indices, positions, normals, uvs!);\r\n\t\t}\r\n\t\tlet colors = null;\r\n\t\tif (primitive.attributes.COLOR_0 !== undefined) {\r\n\t\t\tcolors = this.accessors[primitive.attributes.COLOR_0];\r\n\t\t\tdefines.HAS_COLOR = true;\r\n\t\t}\r\n\t\tlet joints = null;\r\n\t\tif (primitive.attributes.JOINTS_0 !== undefined) {\r\n\t\t\taccessor = this.getAccessor(primitive.attributes.JOINTS_0);\r\n\t\t\tjoints = accessor.getArray();\r\n\t\t\tdefines.HAS_SKIN = true;\r\n\t\t}\r\n\t\tlet weights = null;\r\n\t\tif (primitive.attributes.WEIGHTS_0 !== undefined) {\r\n\t\t\taccessor = this.getAccessor(primitive.attributes.WEIGHTS_0);\r\n\t\t\tweights = accessor.getArray();\r\n\t\t}\r\n\t\tconst geo = new Geometry({ type: \"pbrGeomtry\" });\r\n\t\tif (indices) geo.setIndice(Array.from(indices));\r\n\t\tif (positions) geo.setAttribute(new Float32Attribute(\"position\", Array.from(positions), 3));\r\n\t\tif (normals) geo.setAttribute(new Float32Attribute(\"normal\", Array.from(normals), 3));\r\n\t\tif (colors) geo.setAttribute(new Float32Attribute(\"color\", Array.from(colors), 3));\r\n\t\tif (uvs) geo.setAttribute(new Float32Attribute(\"uv\", Array.from(uvs), 2));\r\n\t\tif (joints) geo.setAttribute(new Float32Attribute(\"joint0\", Array.from(joints), 4));\r\n\t\tif (weights) geo.setAttribute(new Float32Attribute(\"weight0\", Array.from(weights), 4));\r\n\t\tgeo.defines = defines;\r\n\t\tgeo.computeBoundingSphere(Array.from(positions));\r\n\t\tgeo.count = vertexCount;\r\n\t\treturn geo;\r\n\t}\r\n\tprivate createTexture(source: number) {\r\n\t\treturn new Texture({\r\n\t\t\tsize: {\r\n\t\t\t\twidth: this.images[source].width,\r\n\t\t\t\theight: this.images[source].height,\r\n\t\t\t\tdepth: 1\r\n\t\t\t},\r\n\t\t\tdata: {\r\n\t\t\t\tsource: this.images[source]\r\n\t\t\t},\r\n\t\t\tformat: \"rgba8unorm\",\r\n\t\t\tusage: GPUTextureUsage.TEXTURE_BINDING | GPUTextureUsage.COPY_DST | GPUTextureUsage.RENDER_ATTACHMENT\r\n\t\t});\r\n\t}\r\n\tprivate async loadImages() {\r\n\t\tconst images: Array<ImageBitmap> = [];\r\n\t\tlet loadExternalImages: Promise<any> = Promise.resolve();\r\n\t\tif (this.json.images) {\r\n\t\t\tloadExternalImages = Promise.all(\r\n\t\t\t\tthis.json.images.map(async (image: any, index: number) => {\r\n\t\t\t\t\tif (image.uri) {\r\n\t\t\t\t\t\tconst imageUrl = image.uri.slice(0, 5) === \"data:\" ? image.uri : `${this.rootUrl}/${image.uri}`;\r\n\t\t\t\t\t\timages[index] = await fetch(imageUrl)\r\n\t\t\t\t\t\t\t.then((response) => response.blob())\r\n\t\t\t\t\t\t\t.then((blob) =>\r\n\t\t\t\t\t\t\t\tcreateImageBitmap(blob, {\r\n\t\t\t\t\t\t\t\t\tcolorSpaceConversion: \"none\"\r\n\t\t\t\t\t\t\t\t})\r\n\t\t\t\t\t\t\t);\r\n\t\t\t\t\t}\r\n\t\t\t\t})\r\n\t\t\t);\r\n\t\t}\r\n\t\tlet loadInternalImages: Promise<any> = Promise.resolve();\r\n\t\tif (this.json.images) {\r\n\t\t\tloadInternalImages = Promise.all(\r\n\t\t\t\tthis.json.images.map(async (image: any, index: number) => {\r\n\t\t\t\t\tif (image.bufferView !== undefined) {\r\n\t\t\t\t\t\tconst { buffer, byteOffset, byteLength } = this.json.bufferViews[image.bufferView];\r\n\t\t\t\t\t\tconst array = new Uint8Array(\r\n\t\t\t\t\t\t\tthis.buffers[buffer],\r\n\t\t\t\t\t\t\tbuffer === 0 ? byteOffset + this.glbOffset : byteOffset,\r\n\t\t\t\t\t\t\tbyteLength\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\t\tlet type;\r\n\t\t\t\t\t\tif (image.mimeType) {\r\n\t\t\t\t\t\t\ttype = image.mimeType;\r\n\t\t\t\t\t\t} else {\r\n\t\t\t\t\t\t\ttype = array[0] === 0xff ? \"image/jpeg\" : \"image/png\";\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t\tconst blob = new Blob([array], { type });\r\n\t\t\t\t\t\timages[index] = await createImageBitmap(blob, {\r\n\t\t\t\t\t\t\tcolorSpaceConversion: \"none\"\r\n\t\t\t\t\t\t});\r\n\t\t\t\t\t}\r\n\t\t\t\t})\r\n\t\t\t);\r\n\t\t}\r\n\r\n\t\tawait Promise.all([loadExternalImages, loadInternalImages]);\r\n\t\treturn images;\r\n\t}\r\n\tprivate async loadBuffes() {\r\n\t\tconst buffers: Array<ArrayBuffer> = [];\r\n\t\tawait Promise.all(\r\n\t\t\tthis.json.buffers.map((buffer: any, index: number) => {\r\n\t\t\t\tif (!buffer.uri) {\r\n\t\t\t\t\tif (index !== 0) {\r\n\t\t\t\t\t\tthrow new Error(\"buffer uri undefined\");\r\n\t\t\t\t\t}\r\n\t\t\t\t\tbuffers[index] = this.glbBin!;\r\n\t\t\t\t\treturn Promise.resolve();\r\n\t\t\t\t}\r\n\t\t\t\tconst bufferUrl = buffer.uri.slice(0, 5) === \"data:\" ? buffer.uri : `${this.rootUrl}/${buffer.uri}`;\r\n\t\t\t\treturn fetch(bufferUrl)\r\n\t\t\t\t\t.then((response) => response.arrayBuffer())\r\n\t\t\t\t\t.then((arrayBuffer: ArrayBuffer) => {\r\n\t\t\t\t\t\tbuffers[index] = arrayBuffer;\r\n\t\t\t\t\t});\r\n\t\t\t})\r\n\t\t);\r\n\t\treturn buffers;\r\n\t}\r\n\tprivate parseNodes() {\r\n\t\tthis.nodes = this?.json?.nodes?.map((gltfNode) => {\r\n\t\t\tconst node = new Node();\r\n\t\t\tthis.parseNodeTRS(node, gltfNode);\r\n\t\t\tif (gltfNode.name) node.name = gltfNode.name;\r\n\t\t\tif (gltfNode.mesh != undefined) {\r\n\t\t\t\tlet gltfSkin = undefined,\r\n\t\t\t\t\tisSkinMesh = false;\r\n\t\t\t\tif (gltfNode.skin != undefined) {\r\n\t\t\t\t\tgltfSkin = this.json.skins[gltfNode.skin];\r\n\t\t\t\t\tisSkinMesh = true;\r\n\t\t\t\t}\r\n\t\t\t\tthis.meshes[gltfNode.mesh].primitives.forEach((primitive: Mesh, index: number, source: Array<Mesh>) => {\r\n\t\t\t\t\tconst tempPrimitive =\r\n\t\t\t\t\t\tisSkinMesh && primitive.type == RenderObjectType.Mesh\r\n\t\t\t\t\t\t\t? new SKinMesh(primitive.geometry, primitive.material)\r\n\t\t\t\t\t\t\t: primitive;\r\n\t\t\t\t\tif (isSkinMesh && primitive.type == RenderObjectType.Mesh) {\r\n\t\t\t\t\t\tsource[index] = tempPrimitive;\r\n\t\t\t\t\t\ttempPrimitive.setSkinData({\r\n\t\t\t\t\t\t\tinverseBindMatrices: this.getAccessor(gltfSkin.inverseBindMatrices).getMat4Array(),\r\n\t\t\t\t\t\t\tjoints: gltfSkin.joints\r\n\t\t\t\t\t\t\t// name: gltfSkin.name,\r\n\t\t\t\t\t\t\t// skeleton: gltfSkin.skeleton\r\n\t\t\t\t\t\t});\r\n\t\t\t\t\t}\r\n\t\t\t\t\tnode.add(tempPrimitive);\r\n\t\t\t\t});\r\n\t\t\t}\r\n\t\t\treturn node;\r\n\t\t});\r\n\t}\r\n\tprivate parseNodeTRS(node: Node, gltfNode: GLTFNodeParms): Node {\r\n\t\tlet { matrix, rotation, translation, scale } = gltfNode;\r\n\t\tif (matrix) {\r\n\t\t\tconst tempMatrix4 = new Matrix4(),\r\n\t\t\t\ttempScale = new Vector3(),\r\n\t\t\t\ttempTranslation = new Vector3(),\r\n\t\t\t\ttempRotation = new Quaternion();\r\n\t\t\tMatrix4.fromColumnMajorArray(matrix, tempMatrix4);\r\n\t\t\tMatrix4.getScale(tempMatrix4, tempScale);\r\n\t\t\tMatrix4.getTranslation(tempMatrix4, tempTranslation);\r\n\t\t\tMatrix4.getRotation(tempMatrix4, tempRotation);\r\n\t\t\trotation = tempRotation.toArray();\r\n\t\t\ttranslation = tempTranslation.toArray();\r\n\t\t\tscale = tempScale.toArray();\r\n\t\t}\r\n\t\tif (rotation) node.quaternion.set(rotation[0], rotation[1], rotation[2], rotation[3]);\r\n\t\tif (translation) node.position.set(translation[0], translation[1], translation[2]);\r\n\t\tif (scale) node.scale.set(scale[0], scale[1], scale[2]);\r\n\t\treturn node;\r\n\t}\r\n\tprivate normalizeData() {\r\n\t\tthis?.nodes?.map?.((node: Node, index) => {\r\n\t\t\tthis.json?.nodes[index]?.children?.map((nodeId: number) => {\r\n\t\t\t\tconst childNode = this.nodes[nodeId];\r\n\t\t\t\tnode.add(childNode);\r\n\t\t\t});\r\n\t\t});\r\n\t\tthis.meshes.map((mesh) => {\r\n\t\t\tmesh.primitives.map((primitive) => {\r\n\t\t\t\tif (primitive.type == RenderObjectType.SkinMesh)\r\n\t\t\t\t\tprimitive.joints = primitive.joints.map((joint) => {\r\n\t\t\t\t\t\treturn this.nodes[<number>joint];\r\n\t\t\t\t\t});\r\n\t\t\t});\r\n\t\t});\r\n\t}\r\n}\r\nexport async function loadGLTF(url: string) {\r\n\tlet gltf;\r\n\tconst ext = url.split(\".\").pop();\r\n\tconst rootUrl = url.substring(0, url.lastIndexOf(\"/\"));\r\n\tif (ext === \"gltf\") {\r\n\t\tconst json = await fetch(url).then((response) => response.json());\r\n\t\tgltf = new GLTF(json, rootUrl, 0);\r\n\t} else {\r\n\t\tconst glb = await fetch(url).then((response) => response.arrayBuffer());\r\n\t\tconst jsonLength = new Uint32Array(glb, 12, 1)[0];\r\n\t\tconst jsonChunk = new Uint8Array(glb, 20, jsonLength);\r\n\t\tconst json = JSON.parse(new TextDecoder(\"utf-8\").decode(jsonChunk));\r\n\t\tgltf = new GLTF(json, rootUrl, 28 + jsonLength, glb);\r\n\t}\r\n\tawait gltf.parseData();\r\n\treturn gltf;\r\n}\r\ntype GLTFNodeParms = {\r\n\tchildren?: number[];\r\n\tmatrix?: number[];\r\n\tscale?: number[];\r\n\trotation?: number[];\r\n\ttranslation?: number[];\r\n};\r\n","import Texture from \"../render/Texture\";\r\nexport async function loadPbrTexture(brdf, diffuse, specular) {\r\n\tif (!brdf) return;\r\n\tconst brdfTexture = await loadTexture(brdf);\r\n\tconst diffuseTexture = await loadCubeTexture(diffuse);\r\n\tconst specularTexture = await loadCubeTexture(specular);\r\n\treturn {\r\n\t\tbrdfTexture,\r\n\t\tdiffuseTexture,\r\n\t\tspecularTexture\r\n\t};\r\n}\r\nexport async function loadCubeTexture(urls) {\r\n\tconst promises = urls.map((src) => {\r\n\t\tconst img = document.createElement(\"img\");\r\n\t\timg.src = src;\r\n\t\treturn img.decode().then(() => createImageBitmap(img));\r\n\t});\r\n\tconst images = await Promise.all(promises);\r\n\tawait Promise.all(images);\r\n\tconst data = images.map((image, i) => {\r\n\t\treturn {\r\n\t\t\tsource: image,\r\n\t\t\twidth: image.width,\r\n\t\t\theight: image.height,\r\n\t\t\tdepth: 1,\r\n\t\t\tx: 0,\r\n\t\t\ty: 0,\r\n\t\t\tz: i\r\n\t\t};\r\n\t});\r\n\treturn new Texture({\r\n\t\tsize: {\r\n\t\t\twidth: images[0].width,\r\n\t\t\theight: images[0].height,\r\n\t\t\tdepth: 6\r\n\t\t},\r\n\t\tformat: \"rgba8unorm\",\r\n\t\tusage: GPUTextureUsage.TEXTURE_BINDING | GPUTextureUsage.COPY_DST | GPUTextureUsage.RENDER_ATTACHMENT,\r\n\t\tdata,\r\n\t\tviewFormats: \"cube\",\r\n\t\tmipLevelCount: 6,\r\n\t\tneedMipMap: true\r\n\t});\r\n}\r\nexport async function loadTexture(url) {\r\n\tconst img = document.createElement(\"img\");\r\n\timg.src = url;\r\n\tawait img.decode();\r\n\tconst imageBitmap = await createImageBitmap(img);\r\n\tconst baseTexture = new Texture({\r\n\t\tsize: { width: imageBitmap.width, height: imageBitmap.height, depth: 1 },\r\n\t\tdata: {\r\n\t\t\tsource: imageBitmap\r\n\t\t},\r\n\t\tformat: \"rgba8unorm\"\r\n\t});\r\n\treturn baseTexture;\r\n}\r\n","import GMath from \"./Math.js\";\nimport Vector3 from \"./Vector3.js\";\n// from three.js\nclass Spherical {\n\tradius: number;\n\tphi: number;\n\ttheta: number;\n\n\tconstructor(radius = 1, phi = 0, theta = 0) {\n\t\tthis.radius = radius;\n\t\tthis.phi = phi; // polar angle\n\t\tthis.theta = theta; // azimuthal angle\n\n\t\treturn this;\n\t}\n\tset(radius: number, phi: number, theta: number): Spherical {\n\t\tthis.radius = radius;\n\t\tthis.phi = phi;\n\t\tthis.theta = theta;\n\n\t\treturn this;\n\t}\n\tcopy(other: Spherical): Spherical {\n\t\tthis.radius = other.radius;\n\t\tthis.phi = other.phi;\n\t\tthis.theta = other.theta;\n\n\t\treturn this;\n\t}\n\t// restrict phi to be between EPS and PI-EPS\n\tmakeSafe(): Spherical {\n\t\tconst EPS = 0.000001;\n\t\tthis.phi = Math.max(EPS, Math.min(Math.PI - EPS, this.phi));\n\n\t\treturn this;\n\t}\n\n\tsetFromVector3(v: Vector3): Spherical {\n\t\treturn this.setFromCartesianCoords(v.x, v.y, v.z);\n\t}\n\tsetFromCartesianCoords(x: number, y: number, z: number): Spherical {\n\t\tthis.radius = Math.sqrt(x * x + y * y + z * z);\n\n\t\tif (this.radius === 0) {\n\t\t\tthis.theta = 0;\n\t\t\tthis.phi = 0;\n\t\t} else {\n\t\t\tthis.theta = Math.atan2(x, z);\n\t\t\tthis.phi = Math.acos(GMath.clamp(y / this.radius, -1, 1));\n\t\t}\n\n\t\treturn this;\n\t}\n\n\tclone(): Spherical {\n\t\treturn new Spherical(this.radius, this.phi, this.theta);\n\t}\n}\n\nexport { Spherical };\n","import { EventDispatcher } from \"../core/EventDispatcher\";\r\nimport { Quaternion } from \"../math/Quaternion\";\r\nimport { Spherical } from \"../math/Spherical\";\r\nimport Vector2 from \"../math/Vector2\";\r\nimport Vector3 from \"../math/Vector3\";\r\n//from three.js\r\n\r\nconst _changeEvent = { type: \"change\" };\r\nconst _startEvent = { type: \"start\" };\r\nconst _endEvent = { type: \"end\" };\r\n\r\nexport default class OrbitControl extends EventDispatcher {\r\n  domElement: any;\r\n  object: any;\r\n  enabled: boolean;\r\n  target: any;\r\n  minDistance: number;\r\n  maxDistance: number;\r\n  minZoom: number;\r\n  maxZoom: number;\r\n  minPolarAngle: number;\r\n  maxPolarAngle: number;\r\n  minAzimuthAngle: number;\r\n  maxAzimuthAngle: number;\r\n  enableDamping: boolean;\r\n  dampingFactor: number;\r\n  enableZoom: boolean;\r\n  zoomSpeed: number;\r\n  enableRotate: boolean;\r\n  rotateSpeed: number;\r\n  enablePan: boolean;\r\n  panSpeed: number;\r\n  screenSpacePanning: boolean;\r\n  keyPanSpeed: number;\r\n  autoRotate: boolean;\r\n  autoRotateSpeed: number;\r\n  keys: { LEFT: string; UP: string; RIGHT: string; BOTTOM: string };\r\n  mouseButtons: { LEFT: any; MIDDLE: any; RIGHT: any };\r\n  touches: { ONE: any; TWO: any };\r\n  target0: any;\r\n  position0: any;\r\n  zoom0: any;\r\n  private _domElementKeyEvents: any;\r\n  spherical: any;\r\n  onPointerMove: (event: any) => void;\r\n  onPointerUp: (event: any) => void;\r\n  onContextMenu: (event: any) => void;\r\n  onPointerDown: (event: any) => void;\r\n  onMouseWheel: (event: any) => void;\r\n  onKeyDown: (event: any) => void;\r\n  getAutoRotationAngle: () => number;\r\n  update: () => boolean;\r\n  constructor(object, domElement) {\r\n    super();\r\n\r\n    if (domElement === undefined)\r\n      console.warn(\r\n        'OrbitControls: The second parameter \"domElement\" is now mandatory.'\r\n      );\r\n    if (domElement === document)\r\n      console.error(\r\n        'OrbitControls: \"document\" should not be used as the target \"domElement\". Please use \"renderer.domElement\" instead.'\r\n      );\r\n\r\n    this.object = object;\r\n    this.domElement = domElement;\r\n    this.domElement.style.touchAction = \"none\"; // disable touch scroll\r\n\r\n    // Set to false to disable this control\r\n    this.enabled = true;\r\n\r\n    // \"target\" sets the location of focus, where the object orbits around\r\n    this.target = new Vector3();\r\n\r\n    // How far you can dolly in and out ( PerspectiveCamera only )\r\n    this.minDistance = 0;\r\n    this.maxDistance = Infinity;\r\n\r\n    // How far you can zoom in and out ( OrthographicCamera only )\r\n    this.minZoom = 0;\r\n    this.maxZoom = Infinity;\r\n\r\n    // How far you can orbit vertically, upper and lower limits.\r\n    // Range is 0 to Math.PI radians.\r\n    this.minPolarAngle = 0; // radians\r\n    this.maxPolarAngle = Math.PI; // radians\r\n\r\n    // How far you can orbit horizontally, upper and lower limits.\r\n    // If set, the interval [ min, max ] must be a sub-interval of [ - 2 PI, 2 PI ], with ( max - min < 2 PI )\r\n    this.minAzimuthAngle = -Infinity; // radians\r\n    this.maxAzimuthAngle = Infinity; // radians\r\n\r\n    // Set to true to enable damping (inertia)\r\n    // If damping is enabled, you must call controls.update() in your animation loop\r\n    this.enableDamping = false;\r\n    this.dampingFactor = 0.05;\r\n\r\n    // This option actually enables dollying in and out; left as \"zoom\" for backwards compatibility.\r\n    // Set to false to disable zooming\r\n    this.enableZoom = true;\r\n    this.zoomSpeed = 1.0;\r\n\r\n    // Set to false to disable rotating\r\n    this.enableRotate = true;\r\n    this.rotateSpeed = 1.0;\r\n\r\n    // Set to false to disable panning\r\n    this.enablePan = true;\r\n    this.panSpeed = 1.0;\r\n    this.screenSpacePanning = false; // if false, pan orthogonal to world-space direction camera.up\r\n    this.keyPanSpeed = 7.0; // pixels moved per arrow key push\r\n\r\n    // Set to true to automatically rotate around the target\r\n    // If auto-rotate is enabled, you must call controls.update() in your animation loop\r\n    this.autoRotate = false;\r\n    this.autoRotateSpeed = 2.0; // 30 seconds per orbit when fps is 60\r\n\r\n    // The four arrow keys\r\n    this.keys = {\r\n      LEFT: \"ArrowLeft\",\r\n      UP: \"ArrowUp\",\r\n      RIGHT: \"ArrowRight\",\r\n      BOTTOM: \"ArrowDown\",\r\n    };\r\n\r\n    // Mouse buttons\r\n    this.mouseButtons = {\r\n      LEFT: MOUSE.ROTATE,\r\n      MIDDLE: MOUSE.DOLLY,\r\n      RIGHT: MOUSE.PAN,\r\n    };\r\n\r\n    // Touch fingers\r\n    this.touches = { ONE: TOUCH.ROTATE, TWO: TOUCH.DOLLY_PAN };\r\n\r\n    // for reset\r\n    this.target0 = this.target.clone();\r\n    this.position0 = this.object.position.clone();\r\n    this.zoom0 = this.object.zoom;\r\n\r\n    // the target DOM element for key events\r\n    this._domElementKeyEvents = null;\r\n\r\n    //\r\n    // public methods\r\n    //\r\n    // this method is exposed, but perhaps it would be better if we can make it private...\r\n    const that = this;\r\n    this.update = (function () {\r\n      const offset = new Vector3();\r\n      // so camera.up is the orbit axis\r\n      const quat = new Quaternion().setFromUnitVectors(\r\n        that.object.up,\r\n        new Vector3(0, 1, 0)\r\n      );\r\n      const quatInverse = quat.clone().invert();\r\n\r\n      const lastPosition = new Vector3();\r\n      const lastQuaternion = new Quaternion();\r\n\r\n      const twoPI = 2 * Math.PI;\r\n      return function update() {\r\n        const position = that.object.position;\r\n\r\n        offset.copy(position).subtract(that.target);\r\n\r\n        // rotate offset to \"y-axis-is-up\" space\r\n        offset.applyQuaternion(quat);\r\n\r\n        // angle from z-axis around y-axis\r\n        spherical.setFromVector3(offset);\r\n\r\n        if (that.autoRotate && state === STATE.NONE) {\r\n          rotateLeft(that.getAutoRotationAngle());\r\n        }\r\n\r\n        if (that.enableDamping) {\r\n          spherical.theta += sphericalDelta.theta * that.dampingFactor;\r\n          spherical.phi += sphericalDelta.phi * that.dampingFactor;\r\n        } else {\r\n          spherical.theta += sphericalDelta.theta;\r\n          spherical.phi += sphericalDelta.phi;\r\n        }\r\n\r\n        // restrict theta to be between desired limits\r\n\r\n        let min = that.minAzimuthAngle;\r\n        let max = that.maxAzimuthAngle;\r\n\r\n        if (isFinite(min) && isFinite(max)) {\r\n          if (min < -Math.PI) min += twoPI;\r\n          else if (min > Math.PI) min -= twoPI;\r\n\r\n          if (max < -Math.PI) max += twoPI;\r\n          else if (max > Math.PI) max -= twoPI;\r\n\r\n          if (min <= max) {\r\n            spherical.theta = Math.max(min, Math.min(max, spherical.theta));\r\n          } else {\r\n            spherical.theta =\r\n              spherical.theta > (min + max) / 2\r\n                ? Math.max(min, spherical.theta)\r\n                : Math.min(max, spherical.theta);\r\n          }\r\n        }\r\n\r\n        // restrict phi to be between desired limits\r\n        spherical.phi = Math.max(\r\n          that.minPolarAngle,\r\n          Math.min(that.maxPolarAngle, spherical.phi)\r\n        );\r\n\r\n        spherical.makeSafe();\r\n\r\n        spherical.radius *= scale;\r\n\r\n        // restrict radius to be between desired limits\r\n        spherical.radius = Math.max(\r\n          that.minDistance,\r\n          Math.min(that.maxDistance, spherical.radius)\r\n        );\r\n\r\n        // move target to panned location\r\n\r\n        if (that.enableDamping === true) {\r\n          that.target.addScaledVector(panOffset, that.dampingFactor);\r\n        } else {\r\n          that.target.add(panOffset);\r\n        }\r\n        Vector3.fromSpherical(spherical, offset);\r\n        // rotate offset back to \"camera-up-vector-is-up\" space\r\n        offset.applyQuaternion(quatInverse);\r\n\r\n        position.copy(that.target).add(offset);\r\n\r\n        that.object.lookAt(that.target.x, that.target.y, that.target.z);\r\n\r\n        if (that.enableDamping === true) {\r\n          sphericalDelta.theta *= 1 - that.dampingFactor;\r\n          sphericalDelta.phi *= 1 - that.dampingFactor;\r\n\r\n          Vector3.multiplyByScalar(\r\n            panOffset,\r\n            1 - that.dampingFactor,\r\n            panOffset\r\n          );\r\n          // panOffset.multiplyScalar( 1 - this.dampingFactor );\r\n        } else {\r\n          sphericalDelta.set(0, 0, 0);\r\n\r\n          panOffset.set(0, 0, 0);\r\n        }\r\n\r\n        scale = 1;\r\n\r\n        // update condition is:\r\n        // min(camera displacement, camera rotation in radians)^2 > EPS\r\n        // using small-angle approximation cos(x/2) = 1 - x^2 / 8\r\n\r\n        if (\r\n          zoomChanged ||\r\n          Vector3.distanceSquared(lastPosition, that.object.position) > EPS ||\r\n          8 * (1 - lastQuaternion.dot(that.object.quaternion)) > EPS\r\n        ) {\r\n          that.dispatchEvent(_changeEvent);\r\n\r\n          //lastPosition.copy( this.object.position );\r\n          Vector3.clone(that.object.position, lastPosition);\r\n          Quaternion.clone(that.object.quaternion, lastQuaternion);\r\n          //lastQuaternion.copy( this.object.quaternion );\r\n          zoomChanged = false;\r\n\r\n          return true;\r\n        }\r\n\r\n        return false;\r\n      };\r\n    })();\r\n    this.init();\r\n  }\r\n  getPolarAngle() {\r\n    return this.spherical.phi;\r\n  }\r\n  getAzimuthalAngle() {\r\n    return this.spherical.theta;\r\n  }\r\n\r\n  getDistance() {\r\n    return Vector3.distance(this.object.position, this.target);\r\n  }\r\n\r\n  listenToKeyEvents(domElement) {\r\n    domElement.addEventListener(\"keydown\", this.onKeyDown);\r\n    this._domElementKeyEvents = domElement;\r\n  }\r\n\r\n  saveState() {\r\n    Vector3.clone(this.target, this.target0);\r\n    //this.target0.copy( this.target );\r\n    Vector3.clone(this.object.position, this.position0);\r\n    //this.position0.copy( this.object.position );\r\n    this.zoom0 = this.object.zoom;\r\n  }\r\n\r\n  reset() {\r\n    Vector3.clone(this.target0, this.target);\r\n    //this.target.copy( this.target0 );\r\n    Vector3.clone(this.position0, this.object.position);\r\n    //this.object.position.copy( this.position0 );\r\n    this.object.zoom = this.zoom0;\r\n\r\n    this.object.updateProjectionMatrix();\r\n    this.dispatchEvent(_changeEvent);\r\n\r\n    this.update();\r\n\r\n    state = STATE.NONE;\r\n  }\r\n\r\n  private init() {\r\n    const that = this;\r\n    const panLeft = (function () {\r\n      const v = new Vector3();\r\n      return function panLeft(distance, objectMatrix) {\r\n        v.setFromMatrixColumn(objectMatrix, 0); // get X column of objectMatrix\r\n        v.multiplyByScalar(-distance);\r\n        panOffset.add(v);\r\n      };\r\n    })();\r\n    const panUp = (function () {\r\n      const panUpV = new Vector3();\r\n      return function panUp(distance, objectMatrix) {\r\n        if (that.screenSpacePanning === true) {\r\n          panUpV.setFromMatrixColumn(objectMatrix, 1);\r\n        } else {\r\n          panUpV.setFromMatrixColumn(objectMatrix, 0);\r\n          //panUpV.crossVectors( this.object.up, panUpV );\r\n          Vector3.cross(that.object.up, panUpV, panUpV);\r\n        }\r\n\r\n        panUpV.multiplyByScalar(distance);\r\n\r\n        panOffset.add(panUpV);\r\n      };\r\n    })();\r\n    // deltaX and deltaY are in pixels; right and down are positive\r\n    const pan = (function () {\r\n      const offset = new Vector3();\r\n      return function pan(deltaX, deltaY) {\r\n        const element = that.domElement;\r\n        if (that.object.isPerspectiveCamera) {\r\n          // perspective\r\n          const position = that.object.position;\r\n          offset.copy(position).subtract(that.target);\r\n          let targetDistance = offset.length();\r\n\r\n          // half of the fov is center to top of screen\r\n          targetDistance *= Math.tan(((that.object.fov / 2) * Math.PI) / 180.0);\r\n\r\n          // we use only clientHeight here so aspect ratio does not distort speed\r\n          panLeft(\r\n            (2 * deltaX * targetDistance) / element.clientHeight,\r\n            that.object.modelMatrix\r\n          );\r\n          panUp(\r\n            (2 * deltaY * targetDistance) / element.clientHeight,\r\n            that.object.modelMatrix\r\n          );\r\n        } else if (that.object.isOrthographicCamera) {\r\n          // orthographic\r\n          panLeft(\r\n            (deltaX * (that.object.right - that.object.left)) /\r\n              that.object.zoom /\r\n              element.clientWidth,\r\n            that.object.modelMatrix\r\n          );\r\n          panUp(\r\n            (deltaY * (that.object.top - that.object.bottom)) /\r\n              that.object.zoom /\r\n              element.clientHeight,\r\n            that.object.modelMatrix\r\n          );\r\n        } else {\r\n          // camera neither orthographic nor perspective\r\n          console.warn(\r\n            \"WARNING: OrbitControls.js encountered an unknown camera type - pan disabled.\"\r\n          );\r\n          that.enablePan = false;\r\n        }\r\n      };\r\n    })();\r\n    const dollyOut = (dollyScale) => {\r\n      if (this.object.isPerspectiveCamera) {\r\n        scale /= dollyScale;\r\n      } else if (this.object.isOrthographicCamera) {\r\n        this.object.zoom = Math.max(\r\n          this.minZoom,\r\n          Math.min(this.maxZoom, this.object.zoom * dollyScale)\r\n        );\r\n        this.object.updateProjectionMatrix();\r\n        zoomChanged = true;\r\n      } else {\r\n        console.warn(\r\n          \"WARNING: OrbitControls.js encountered an unknown camera type - dolly/zoom disabled.\"\r\n        );\r\n        this.enableZoom = false;\r\n      }\r\n    };\r\n\r\n    const dollyIn = (dollyScale) => {\r\n      if (this.object.isPerspectiveCamera) {\r\n        scale *= dollyScale;\r\n      } else if (this.object.isOrthographicCamera) {\r\n        this.object.zoom = Math.max(\r\n          this.minZoom,\r\n          Math.min(this.maxZoom, this.object.zoom / dollyScale)\r\n        );\r\n        this.object.updateProjectionMatrix();\r\n        zoomChanged = true;\r\n      } else {\r\n        console.warn(\r\n          \"WARNING: OrbitControls.js encountered an unknown camera type - dolly/zoom disabled.\"\r\n        );\r\n        this.enableZoom = false;\r\n      }\r\n    };\r\n    const handleMouseMoveRotate = (event) => {\r\n      rotateEnd.set(event.clientX, event.clientY);\r\n\r\n      Vector2.subtract(rotateEnd, rotateStart, rotateDelta);\r\n      Vector2.multiplyByScalar(rotateDelta, this.rotateSpeed, rotateDelta);\r\n      //rotateDelta.subVectors( rotateEnd, rotateStart ).multiplyScalar( this.rotateSpeed );\r\n\r\n      const element = this.domElement;\r\n\r\n      rotateLeft((2 * Math.PI * rotateDelta.x) / element.clientHeight); // yes, height\r\n\r\n      rotateUp((2 * Math.PI * rotateDelta.y) / element.clientHeight);\r\n\r\n      Vector2.clone(rotateEnd, rotateStart);\r\n      //rotateStart.copy( rotateEnd );\r\n\r\n      this.update();\r\n    };\r\n\r\n    const handleMouseMoveDolly = (event) => {\r\n      dollyEnd.set(event.clientX, event.clientY);\r\n\r\n      Vector2.subtract(dollyEnd, dollyStart, dollyDelta);\r\n      // dollyDelta.subVectors( dollyEnd, dollyStart );\r\n\r\n      if (dollyDelta.y > 0) {\r\n        dollyOut(getZoomScale());\r\n      } else if (dollyDelta.y < 0) {\r\n        dollyIn(getZoomScale());\r\n      }\r\n\r\n      Vector2.clone(dollyEnd, dollyStart);\r\n      // dollyStart.copy( dollyEnd );\r\n\r\n      this.update();\r\n    };\r\n\r\n    const handleMouseMovePan = (event) => {\r\n      panEnd.set(event.clientX, event.clientY);\r\n\r\n      Vector2.subtract(panEnd, panStart, panDelta);\r\n      Vector2.multiplyByScalar(panDelta, this.panSpeed, panDelta);\r\n      //panDelta.subVectors( panEnd, panStart ).multiplyScalar( this.panSpeed );\r\n\r\n      pan(panDelta.x, panDelta.y);\r\n\r\n      Vector2.clone(panEnd, panStart);\r\n      //panStart.copy( panEnd );\r\n\r\n      this.update();\r\n    };\r\n\r\n    const handleMouseWheel = (event) => {\r\n      if (event.deltaY < 0) {\r\n        dollyIn(getZoomScale());\r\n      } else if (event.deltaY > 0) {\r\n        dollyOut(getZoomScale());\r\n      }\r\n\r\n      this.update();\r\n    };\r\n\r\n    const handleKeyDown = (event) => {\r\n      let needsUpdate = false;\r\n\r\n      switch (event.code) {\r\n        case this.keys.UP:\r\n          pan(0, this.keyPanSpeed);\r\n          needsUpdate = true;\r\n          break;\r\n\r\n        case this.keys.BOTTOM:\r\n          pan(0, -this.keyPanSpeed);\r\n          needsUpdate = true;\r\n          break;\r\n\r\n        case this.keys.LEFT:\r\n          pan(this.keyPanSpeed, 0);\r\n          needsUpdate = true;\r\n          break;\r\n\r\n        case this.keys.RIGHT:\r\n          pan(-this.keyPanSpeed, 0);\r\n          needsUpdate = true;\r\n          break;\r\n      }\r\n\r\n      if (needsUpdate) {\r\n        // prevent the browser from scrolling on cursor keys\r\n        event.preventDefault();\r\n\r\n        this.update();\r\n      }\r\n    };\r\n\r\n    const handleTouchStartDollyPan = () => {\r\n      if (this.enableZoom) handleTouchStartDolly();\r\n\r\n      if (this.enablePan) handleTouchStartPan();\r\n    };\r\n    const handleTouchStartDollyRotate = () => {\r\n      if (this.enableZoom) handleTouchStartDolly();\r\n\r\n      if (this.enableRotate) handleTouchStartRotate();\r\n    };\r\n\r\n    const handleTouchMoveRotate = (event) => {\r\n      if (pointers.length == 1) {\r\n        rotateEnd.set(event.pageX, event.pageY);\r\n      } else {\r\n        const position = getSecondPointerPosition(event);\r\n\r\n        const x = 0.5 * (event.pageX + position.x);\r\n        const y = 0.5 * (event.pageY + position.y);\r\n\r\n        rotateEnd.set(x, y);\r\n      }\r\n\r\n      Vector2.subtract(rotateEnd, rotateStart, rotateDelta);\r\n      Vector2.multiplyByScalar(rotateDelta, this.rotateSpeed, rotateDelta);\r\n      //rotateDelta.subVectors( rotateEnd, rotateStart ).multiplyScalar( this.rotateSpeed );\r\n\r\n      const element = this.domElement;\r\n\r\n      rotateLeft((2 * Math.PI * rotateDelta.x) / element.clientHeight); // yes, height\r\n\r\n      rotateUp((2 * Math.PI * rotateDelta.y) / element.clientHeight);\r\n      Vector2.clone(rotateEnd, rotateStart);\r\n      //rotateStart.copy( rotateEnd );\r\n    };\r\n\r\n    const handleTouchMovePan = (event) => {\r\n      if (pointers.length === 1) {\r\n        panEnd.set(event.pageX, event.pageY);\r\n      } else {\r\n        const position = getSecondPointerPosition(event);\r\n\r\n        const x = 0.5 * (event.pageX + position.x);\r\n        const y = 0.5 * (event.pageY + position.y);\r\n\r\n        panEnd.set(x, y);\r\n      }\r\n      Vector2.subtract(panEnd, panStart, panDelta);\r\n      Vector2.multiplyByScalar(panDelta, this.panSpeed, panDelta);\r\n\r\n      //panDelta.subVectors( panEnd, panStart ).multiplyScalar( this.panSpeed );\r\n\r\n      pan(panDelta.x, panDelta.y);\r\n\r\n      Vector2.clone(panEnd, panStart);\r\n      // panStart.copy( panEnd );\r\n    };\r\n\r\n    const handleTouchMoveDolly = (event) => {\r\n      const position = getSecondPointerPosition(event);\r\n\r\n      const dx = event.pageX - position.x;\r\n      const dy = event.pageY - position.y;\r\n\r\n      const distance = Math.sqrt(dx * dx + dy * dy);\r\n\r\n      dollyEnd.set(0, distance);\r\n\r\n      dollyDelta.set(0, Math.pow(dollyEnd.y / dollyStart.y, this.zoomSpeed));\r\n\r\n      dollyOut(dollyDelta.y);\r\n\r\n      Vector2.clone(dollyEnd, dollyStart);\r\n      //dollyStart.copy( dollyEnd );\r\n    };\r\n\r\n    const handleTouchMoveDollyPan = (event) => {\r\n      if (this.enableZoom) handleTouchMoveDolly(event);\r\n\r\n      if (this.enablePan) handleTouchMovePan(event);\r\n    };\r\n\r\n    const handleTouchMoveDollyRotate = (event) => {\r\n      if (this.enableZoom) handleTouchMoveDolly(event);\r\n\r\n      if (this.enableRotate) handleTouchMoveRotate(event);\r\n    };\r\n\r\n    //\r\n    // event handlers - FSM: listen for events and reset state\r\n    //\r\n\r\n    this.onPointerDown = (event) => {\r\n      if (this.enabled === false) return;\r\n\r\n      if (pointers.length === 0) {\r\n        this.domElement.setPointerCapture(event.pointerId);\r\n\r\n        this.domElement.addEventListener(\"pointermove\", this.onPointerMove);\r\n        this.domElement.addEventListener(\"pointerup\", this.onPointerUp);\r\n      }\r\n\r\n      //\r\n\r\n      addPointer(event);\r\n\r\n      if (event.pointerType === \"touch\") {\r\n        onTouchStart(event);\r\n      } else {\r\n        onMouseDown(event);\r\n      }\r\n    };\r\n\r\n    this.onPointerMove = (event) => {\r\n      if (this.enabled === false) return;\r\n\r\n      if (event.pointerType === \"touch\") {\r\n        onTouchMove(event);\r\n      } else {\r\n        onMouseMove(event);\r\n      }\r\n    };\r\n\r\n    this.onPointerUp = (event) => {\r\n      removePointer(event);\r\n\r\n      if (pointers.length === 0) {\r\n        this.domElement.releasePointerCapture(event.pointerId);\r\n\r\n        this.domElement.removeEventListener(\"pointermove\", this.onPointerMove);\r\n        this.domElement.removeEventListener(\"pointerup\", this.onPointerUp);\r\n      }\r\n\r\n      this.dispatchEvent(_endEvent);\r\n\r\n      state = STATE.NONE;\r\n    };\r\n\r\n    const onMouseDown = (event) => {\r\n      let mouseAction;\r\n\r\n      switch (event.button) {\r\n        case 0:\r\n          mouseAction = this.mouseButtons.LEFT;\r\n          break;\r\n\r\n        case 1:\r\n          mouseAction = this.mouseButtons.MIDDLE;\r\n          break;\r\n\r\n        case 2:\r\n          mouseAction = this.mouseButtons.RIGHT;\r\n          break;\r\n\r\n        default:\r\n          mouseAction = -1;\r\n      }\r\n\r\n      switch (mouseAction) {\r\n        case MOUSE.DOLLY:\r\n          if (this.enableZoom === false) return;\r\n\r\n          handleMouseDownDolly(event);\r\n\r\n          state = STATE.DOLLY;\r\n\r\n          break;\r\n\r\n        case MOUSE.ROTATE:\r\n          if (event.ctrlKey || event.metaKey || event.shiftKey) {\r\n            if (this.enablePan === false) return;\r\n\r\n            handleMouseDownPan(event);\r\n\r\n            state = STATE.PAN;\r\n          } else {\r\n            if (this.enableRotate === false) return;\r\n\r\n            handleMouseDownRotate(event);\r\n\r\n            state = STATE.ROTATE;\r\n          }\r\n\r\n          break;\r\n\r\n        case MOUSE.PAN:\r\n          if (event.ctrlKey || event.metaKey || event.shiftKey) {\r\n            if (this.enableRotate === false) return;\r\n\r\n            handleMouseDownRotate(event);\r\n\r\n            state = STATE.ROTATE;\r\n          } else {\r\n            if (this.enablePan === false) return;\r\n\r\n            handleMouseDownPan(event);\r\n\r\n            state = STATE.PAN;\r\n          }\r\n\r\n          break;\r\n\r\n        default:\r\n          state = STATE.NONE;\r\n      }\r\n\r\n      if (state !== STATE.NONE) {\r\n        this.dispatchEvent(_startEvent);\r\n      }\r\n    };\r\n\r\n    const onMouseMove = (event) => {\r\n      switch (state) {\r\n        case STATE.ROTATE:\r\n          if (this.enableRotate === false) return;\r\n\r\n          handleMouseMoveRotate(event);\r\n\r\n          break;\r\n\r\n        case STATE.DOLLY:\r\n          if (this.enableZoom === false) return;\r\n\r\n          handleMouseMoveDolly(event);\r\n\r\n          break;\r\n\r\n        case STATE.PAN:\r\n          if (this.enablePan === false) return;\r\n\r\n          handleMouseMovePan(event);\r\n\r\n          break;\r\n      }\r\n    };\r\n\r\n    this.onMouseWheel = (event) => {\r\n      if (\r\n        this.enabled === false ||\r\n        this.enableZoom === false ||\r\n        state !== STATE.NONE\r\n      )\r\n        return;\r\n\r\n      event.preventDefault();\r\n\r\n      this.dispatchEvent(_startEvent);\r\n\r\n      handleMouseWheel(event);\r\n\r\n      this.dispatchEvent(_endEvent);\r\n    };\r\n\r\n    this.onKeyDown = (event) => {\r\n      if (this.enabled === false || this.enablePan === false) return;\r\n\r\n      handleKeyDown(event);\r\n    };\r\n\r\n    const onTouchStart = (event) => {\r\n      trackPointer(event);\r\n\r\n      switch (pointers.length) {\r\n        case 1:\r\n          switch (this.touches.ONE) {\r\n            case TOUCH.ROTATE:\r\n              if (this.enableRotate === false) return;\r\n\r\n              handleTouchStartRotate();\r\n\r\n              state = STATE.TOUCH_ROTATE;\r\n\r\n              break;\r\n\r\n            case TOUCH.PAN:\r\n              if (this.enablePan === false) return;\r\n\r\n              handleTouchStartPan();\r\n\r\n              state = STATE.TOUCH_PAN;\r\n\r\n              break;\r\n\r\n            default:\r\n              state = STATE.NONE;\r\n          }\r\n\r\n          break;\r\n\r\n        case 2:\r\n          switch (this.touches.TWO) {\r\n            case TOUCH.DOLLY_PAN:\r\n              if (this.enableZoom === false && this.enablePan === false) return;\r\n\r\n              handleTouchStartDollyPan();\r\n\r\n              state = STATE.TOUCH_DOLLY_PAN;\r\n\r\n              break;\r\n\r\n            case TOUCH.DOLLY_ROTATE:\r\n              if (this.enableZoom === false && this.enableRotate === false)\r\n                return;\r\n\r\n              handleTouchStartDollyRotate();\r\n\r\n              state = STATE.TOUCH_DOLLY_ROTATE;\r\n\r\n              break;\r\n\r\n            default:\r\n              state = STATE.NONE;\r\n          }\r\n\r\n          break;\r\n\r\n        default:\r\n          state = STATE.NONE;\r\n      }\r\n\r\n      if (state !== STATE.NONE) {\r\n        this.dispatchEvent(_startEvent);\r\n      }\r\n    };\r\n\r\n    const onTouchMove = (event) => {\r\n      trackPointer(event);\r\n\r\n      switch (state) {\r\n        case STATE.TOUCH_ROTATE:\r\n          if (this.enableRotate === false) return;\r\n\r\n          handleTouchMoveRotate(event);\r\n\r\n          this.update();\r\n\r\n          break;\r\n\r\n        case STATE.TOUCH_PAN:\r\n          if (this.enablePan === false) return;\r\n\r\n          handleTouchMovePan(event);\r\n\r\n          this.update();\r\n\r\n          break;\r\n\r\n        case STATE.TOUCH_DOLLY_PAN:\r\n          if (this.enableZoom === false && this.enablePan === false) return;\r\n\r\n          handleTouchMoveDollyPan(event);\r\n\r\n          this.update();\r\n\r\n          break;\r\n\r\n        case STATE.TOUCH_DOLLY_ROTATE:\r\n          if (this.enableZoom === false && this.enableRotate === false) return;\r\n\r\n          handleTouchMoveDollyRotate(event);\r\n\r\n          this.update();\r\n\r\n          break;\r\n\r\n        default:\r\n          state = STATE.NONE;\r\n      }\r\n    };\r\n\r\n    this.onContextMenu = (event) => {\r\n      if (this.enabled === false) return;\r\n\r\n      event.preventDefault();\r\n    };\r\n    this.getAutoRotationAngle = () => {\r\n      return ((2 * Math.PI) / 60 / 60) * this.autoRotateSpeed;\r\n    };\r\n\r\n    const getZoomScale = () => {\r\n      return Math.pow(0.95, this.zoomSpeed);\r\n    };\r\n    this.domElement.addEventListener(\"contextmenu\", this.onContextMenu);\r\n\r\n    this.domElement.addEventListener(\"pointerdown\", this.onPointerDown);\r\n    this.domElement.addEventListener(\"pointercancel\", onPointerCancel);\r\n    this.domElement.addEventListener(\"wheel\", this.onMouseWheel, {\r\n      passive: false,\r\n    });\r\n  }\r\n  dispose() {\r\n    this.domElement.removeEventListener(\"contextmenu\", this.onContextMenu);\r\n\r\n    this.domElement.removeEventListener(\"pointerdown\", this.onPointerDown);\r\n    this.domElement.removeEventListener(\"pointercancel\", onPointerCancel);\r\n    this.domElement.removeEventListener(\"wheel\", this.onMouseWheel);\r\n\r\n    this.domElement.removeEventListener(\"pointermove\", this.onPointerMove);\r\n    this.domElement.removeEventListener(\"pointerup\", this.onPointerUp);\r\n\r\n    if (this._domElementKeyEvents !== null) {\r\n      this._domElementKeyEvents.removeEventListener(\"keydown\", this.onKeyDown);\r\n    }\r\n\r\n    //this.dispatchEvent( { type: 'dispose' } ); // should this be added here?\r\n  }\r\n}\r\nconst STATE = {\r\n  NONE: -1,\r\n  ROTATE: 0,\r\n  DOLLY: 1,\r\n  PAN: 2,\r\n  TOUCH_ROTATE: 3,\r\n  TOUCH_PAN: 4,\r\n  TOUCH_DOLLY_PAN: 5,\r\n  TOUCH_DOLLY_ROTATE: 6,\r\n};\r\n\r\nlet state = STATE.NONE;\r\n\r\nconst EPS = 0.000001;\r\n\r\n// current position in spherical coordinates\r\nconst spherical = new Spherical();\r\nconst sphericalDelta = new Spherical();\r\n\r\nlet scale = 1;\r\nconst panOffset = new Vector3();\r\nlet zoomChanged = false;\r\n\r\nconst rotateStart = new Vector2();\r\nconst rotateEnd = new Vector2();\r\nconst rotateDelta = new Vector2();\r\n\r\nconst panStart = new Vector2();\r\nconst panEnd = new Vector2();\r\nconst panDelta = new Vector2();\r\n\r\nconst dollyStart = new Vector2();\r\nconst dollyEnd = new Vector2();\r\nconst dollyDelta = new Vector2();\r\n\r\nconst pointers = [];\r\nconst pointerPositions = {};\r\nexport enum MOUSE {\r\n  LEFT = 0,\r\n  MIDDLE = 1,\r\n  RIGHT = 2,\r\n  ROTATE = 0,\r\n  DOLLY = 1,\r\n  PAN = 2,\r\n}\r\n\r\nexport enum TOUCH {\r\n  ROTATE,\r\n  PAN,\r\n  DOLLY_PAN,\r\n  DOLLY_ROTATE,\r\n}\r\nfunction rotateLeft(angle) {\r\n  sphericalDelta.theta -= angle;\r\n}\r\n\r\nfunction rotateUp(angle) {\r\n  sphericalDelta.phi -= angle;\r\n}\r\n\r\nfunction addPointer(event) {\r\n  pointers.push(event);\r\n}\r\n\r\nfunction removePointer(event) {\r\n  delete pointerPositions[event.pointerId];\r\n\r\n  for (let i = 0; i < pointers.length; i++) {\r\n    if (pointers[i].pointerId == event.pointerId) {\r\n      pointers.splice(i, 1);\r\n      return;\r\n    }\r\n  }\r\n}\r\n\r\nfunction trackPointer(event) {\r\n  let position = pointerPositions[event.pointerId];\r\n\r\n  if (position === undefined) {\r\n    position = new Vector2();\r\n    pointerPositions[event.pointerId] = position;\r\n  }\r\n\r\n  position.set(event.pageX, event.pageY);\r\n}\r\n\r\nfunction getSecondPointerPosition(event) {\r\n  const pointer =\r\n    event.pointerId === pointers[0].pointerId ? pointers[1] : pointers[0];\r\n\r\n  return pointerPositions[pointer.pointerId];\r\n}\r\n\r\nfunction handleMouseDownRotate(event) {\r\n  rotateStart.set(event.clientX, event.clientY);\r\n}\r\n\r\nfunction handleMouseDownDolly(event) {\r\n  dollyStart.set(event.clientX, event.clientY);\r\n}\r\n\r\nfunction handleMouseDownPan(event) {\r\n  panStart.set(event.clientX, event.clientY);\r\n}\r\nfunction onPointerCancel(event) {\r\n  removePointer(event);\r\n}\r\nfunction handleTouchStartRotate() {\r\n  if (pointers.length === 1) {\r\n    rotateStart.set(pointers[0].pageX, pointers[0].pageY);\r\n  } else {\r\n    const x = 0.5 * (pointers[0].pageX + pointers[1].pageX);\r\n    const y = 0.5 * (pointers[0].pageY + pointers[1].pageY);\r\n\r\n    rotateStart.set(x, y);\r\n  }\r\n}\r\n\r\nfunction handleTouchStartPan() {\r\n  if (pointers.length === 1) {\r\n    panStart.set(pointers[0].pageX, pointers[0].pageY);\r\n  } else {\r\n    const x = 0.5 * (pointers[0].pageX + pointers[1].pageX);\r\n    const y = 0.5 * (pointers[0].pageY + pointers[1].pageY);\r\n\r\n    panStart.set(x, y);\r\n  }\r\n}\r\n\r\nfunction handleTouchStartDolly() {\r\n  const dx = pointers[0].pageX - pointers[1].pageX;\r\n  const dy = pointers[0].pageY - pointers[1].pageY;\r\n\r\n  const distance = Math.sqrt(dx * dx + dy * dy);\r\n\r\n  dollyStart.set(0, distance);\r\n}\r\n"],"names":["MersenneTwister","distanceScratch","lerpScratch","angleBetweenScratch","angleBetweenScratch2","mostOrthogonalAxisScratch","scaleScratch1","scratchColumn","scaleScratch3","scaleScratch4","scaleScratch5","scratchTransposeMatrix"],"mappings":"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AC,GAAG,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;AAChC,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;AAChC,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;AAChC,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;AAChC,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;AAChC,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;AAChC,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;AAChC,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;AAChC,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;AAChC,QAAA,MAAM,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,CAAC;AAClC,QAAA,MAAM,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,CAAC;AAClC,QAAA,MAAM,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,CAAC;AAClC,QAAA,MAAM,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,CAAC;AAClC,QAAA,MAAM,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,CAAC;AAClC,QAAA,MAAM,CAAC,EAA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CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;;AAGL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;;AAGL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;;AAGL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GA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"} diff --git a/example/index.html b/example/index.html index a74d9c6..15a484c 100644 --- a/example/index.html +++ b/example/index.html @@ -29,6 +29,7 @@
Mesh
Axes SkyBox + InstanceMesh
Materials
Blinn-PhongMaterial { - return null; + return mesh.modelMatrix; }, UniformEnum.Mat4 ); uniformBuffer.setUniform("color", this, UniformEnum.Color); - uniformBuffer.setUniform("opacity", this, UniformEnum.Float); uniformBuffer.setUniform("rotation", this, UniformEnum.Float); uniformBuffer.setUniform("center", this, UniformEnum.FloatVec2); - uniformBuffer.setUniform("specular", this, UniformEnum.Color); - this.shaderData.setUniformBuffer("phong", uniformBuffer); + uniformBuffer.setUniform("opacity", this, UniformEnum.Float); + this.shaderData.setUniformBuffer("billboard", uniformBuffer); if (this.baseTexture) { this.shaderData.setDefine("USE_COLORTEXTURE", true); this.shaderData.setTexture("baseColorTexture", this.baseTexture); diff --git a/src/material/BlinnPhongMaterial.ts b/src/material/BlinnPhongMaterial.ts index 64a97a2..7c07902 100644 --- a/src/material/BlinnPhongMaterial.ts +++ b/src/material/BlinnPhongMaterial.ts @@ -30,16 +30,16 @@ export default class BlinnPhongMaterial extends Material { this.baseTexture = undefined; this.baseSampler = undefined; } - update(frameState: FrameState, mesh: Mesh) { + update(frameState?: FrameState, mesh?: Mesh) { if (!this.shaderData || this.dirty) this.createShaderData(mesh); } protected createShaderData(mesh?: Mesh) { - super.createShaderData(mesh); + super.createShaderData(); const uniformBuffer = new UniformBuffer({ label: "phong" }); uniformBuffer.setUniform( "modelMatrix", () => { - return null; + return mesh.modelMatrix; }, UniformEnum.Mat4 ); diff --git a/src/material/ColorMaterial.ts b/src/material/ColorMaterial.ts index 1cbc9d4..de6e09d 100644 --- a/src/material/ColorMaterial.ts +++ b/src/material/ColorMaterial.ts @@ -14,13 +14,13 @@ export default class ColorMaterial extends Material { defines: {} }); } - update(frameState: FrameState, mesh: Mesh) { - if (!this.shaderData || this.dirty) this.createShaderData(mesh); + update(frameState?: FrameState, mesh?: Mesh) { + if (!this.shaderData || this.dirty) this.createShaderData(); const uniformBuffer = new UniformBuffer({ label: "color" }); uniformBuffer.setUniform( "modelMatrix", () => { - return null; + return mesh.modelMatrix; }, UniformEnum.Mat4 ); diff --git a/src/material/Material.ts b/src/material/Material.ts index a31c327..85c80c1 100644 --- a/src/material/Material.ts +++ b/src/material/Material.ts @@ -100,14 +100,20 @@ export class Material { public set opacity(v: number) { this._opacity = v; } - onBeforeRender() {} + onBeforeRender() { + // callback + } - onBeforeCompile() {} + onBeforeCompile() { + // callback + } clone(): Material { return null; } - update(frameState?: FrameState, mesh?: Mesh) {} - protected createShaderData(mesh: Mesh, frameState?: FrameState) { + update(frameState?: FrameState, mesh?: Mesh) { + // update material + } + protected createShaderData() { if (this.shaderData) this.shaderData.destroy(); this.shaderData = new ShaderData(this.type, 0); this.ready = true; diff --git a/src/material/PbrMaterial.ts b/src/material/PbrMaterial.ts index 013b646..4e9cdb2 100644 --- a/src/material/PbrMaterial.ts +++ b/src/material/PbrMaterial.ts @@ -98,14 +98,14 @@ export default class PbrMaterial extends Material { } }); } - update(frameState: FrameState, mesh: Mesh) { + update(frameState?: FrameState, mesh?: Mesh) { if (!textureCache.getTexture("specular")) return; if (!this.shaderData || this.dirty) { - this.createShaderData(mesh, frameState); + this.createShaderData(mesh); } } - protected createShaderData(mesh: Mesh, frameState?: FrameState) { - super.createShaderData(mesh); + protected createShaderData(mesh?: Mesh) { + super.createShaderData(); const uniformBuffer = new UniformBuffer({ label: "pbr" }); uniformBuffer.setUniform( "modelMatrix", diff --git a/src/material/ShaderMaterial.ts b/src/material/ShaderMaterial.ts index fe43495..d62cf2b 100644 --- a/src/material/ShaderMaterial.ts +++ b/src/material/ShaderMaterial.ts @@ -36,7 +36,7 @@ export default class ShaderMaterial extends Material { return new ShaderMaterial(this.shaderMaterialParms); } protected createShaderData(mesh?: Mesh) { - super.createShaderData(mesh); + super.createShaderData(); const result = checkContainFloatType(this.uniforms); if (result.hasFloat) { this.uniformBuffer = result.hasArraytype @@ -55,6 +55,7 @@ export default class ShaderMaterial extends Material { this.uniforms[uniformsName], this.uniforms, this.shaderData, + mesh, this.uniformBuffer ); }); diff --git a/src/material/SkyBoxMaterial.ts b/src/material/SkyBoxMaterial.ts index 33b9f47..73f71cf 100644 --- a/src/material/SkyBoxMaterial.ts +++ b/src/material/SkyBoxMaterial.ts @@ -28,19 +28,19 @@ export default class SkyBoxMaterial extends Material { this.baseTexture = result.texture; this.baseSampler = result.sampler; } - update(frameState: FrameState, mesh: Mesh) { + update(frameState?: FrameState, mesh?: Mesh) { if (!this.loadFish) return; if (!this.shaderData) { this.createShaderData(mesh); } } - protected createShaderData(mesh: Mesh) { - super.createShaderData(mesh); + protected createShaderData(mesh?: Mesh) { + super.createShaderData(); const uniformBuffer = new UniformBuffer({ label: "skybox" }); uniformBuffer.setUniform( "modelMatrix", () => { - return null; + return mesh.modelMatrix; }, UniformEnum.Mat4 ); diff --git a/src/mesh/Billboard.ts b/src/mesh/Billboard.ts new file mode 100644 index 0000000..4372dcf --- /dev/null +++ b/src/mesh/Billboard.ts @@ -0,0 +1,18 @@ +import BillboardGeometry from "../geometry/BillboardGeometry"; +import { BillboardMaterial } from "../material/BillboardMaterial"; +import Texture from "../render/Texture"; +import { Mesh } from "./Mesh"; + +export class Billboard extends Mesh { + constructor() { + super(); + this.material = new BillboardMaterial(); + this.geometry = new BillboardGeometry(); + } + setTexture(texture: Texture) { + this.material.baseTexture = texture; + } + // set center(){ + + // } +} diff --git a/src/mesh/InstanceMesh.ts b/src/mesh/InstanceMesh.ts index 91f322f..e14567a 100644 --- a/src/mesh/InstanceMesh.ts +++ b/src/mesh/InstanceMesh.ts @@ -19,11 +19,10 @@ export class InstanceMesh extends Mesh { this.hasAddInstances = false; } update(frameState: FrameState, camera?: Camera) { - // create - this.geometry.update(frameState); - this.material.update(frameState, this); // update instances visiblity this.checkInstancesVisiblity({ frameState, camera }); + this.geometry.update(frameState); + this.material.update(frameState, this); if (!this.hasAddInstances) this.addUniformsToMaterial(); this.instanceCount = this.renderInstances.length; if (this.renderInstances.length < 1) return; @@ -45,11 +44,16 @@ export class InstanceMesh extends Mesh { } private checkInstancesVisiblity(options: { frameState: FrameState; camera: Camera }) { const { frameState, camera } = options; + const preFrameInstanceCount = this.renderInstances.length; + this.renderInstances = []; this.instances.forEach((instance: Instance) => { instance.updateMatrix(this?.parent?.modelMatrix); instance.visiblity = this.getInstanceVisiblity({ instance, frameState, camera }); if (instance.visiblity) this.renderInstances.push(instance); }); + this.material.dirty = this.renderInstances.length === preFrameInstanceCount; + // rebuild instanceMatrixsBuffer + if (this.material.dirty) this.hasAddInstances = false; } private getInstanceVisiblity(options: { instance: Instance; frameState: FrameState; camera: Camera }): boolean { const { instance, frameState, camera } = options; diff --git a/src/mesh/Mesh.ts b/src/mesh/Mesh.ts index 1dd04b3..832bbff 100644 --- a/src/mesh/Mesh.ts +++ b/src/mesh/Mesh.ts @@ -11,18 +11,20 @@ import createGuid from "../utils/createGuid"; export class Mesh extends RenderObject { [x: string]: any; uid: string; + frustumCull: boolean; + subCommands: { [prop: string]: DrawCommand }; geometry?: Geometry; material?: Material; instanceCount?: number; priority?: number; drawCommand?: DrawCommand; - subCommands: { [prop: string]: DrawCommand }; distanceToCamera?: number; constructor(geometry?: Geometry, material?: Material) { super(); this.geometry = geometry; this.material = material; this.type = RenderObjectType.Mesh; + this.frustumCull = true; this.uid = createGuid(); this.subCommands = {}; } @@ -53,12 +55,16 @@ export class Mesh extends RenderObject { frameState.renderQueue.opaque.push(this); } } - beforeRender() {} - afterRender() {} + beforeRender() { + // before render + } + afterRender() { + // after render + } public getDrawCommand(overrideMaterial?: Material, commandSubType?: CommandSubType, lightManger?: LightManger) { if (!this.drawCommand || this.material.dirty) { this.material.shaderSource.setDefines( - Object.assign(this.material.shaderData.defines, this.geometry.defines) + Object.assign({}, this.material.shaderData.defines, this.geometry.defines) ); if (this.material.dirty) this.material.dirty = false; this.drawCommand = new DrawCommand({ @@ -78,8 +84,7 @@ export class Mesh extends RenderObject { if (overrideMaterial) { if (!this.subCommands[commandSubType]) { const copyMat = overrideMaterial.clone(); - overrideMaterial.update(); - copyMat.update(); + copyMat.update(undefined, this); if (copyMat.dirty) copyMat.dirty = false; this.subCommands[commandSubType] = this.drawCommand.shallowClone(copyMat); } diff --git a/src/render/DrawCommand.ts b/src/render/DrawCommand.ts index e735a34..3185cfd 100644 --- a/src/render/DrawCommand.ts +++ b/src/render/DrawCommand.ts @@ -91,7 +91,6 @@ class DrawCommand implements Command { public render(context?: Context, passEncoder?: GPURenderPassEncoder, camera?: Camera): void { const { shaderData, - modelMatrix, renderState, vertexBuffer, indexBuffer, @@ -105,8 +104,6 @@ class DrawCommand implements Command { const defines = Object.assign({}, lightShaderData?.defines ?? {}, camera?.shaderData?.defines ?? {}); const { device } = context; - if (modelMatrix) shaderData?.replaceUniformBufferValue?.("modelMatrix", modelMatrix); - shaderData?.bind?.(context, currentPassEncoder); camera?.shaderData?.bind(context, currentPassEncoder); diff --git a/src/shader/Shaders.ts b/src/shader/Shaders.ts index c758dc3..a182bc8 100644 --- a/src/shader/Shaders.ts +++ b/src/shader/Shaders.ts @@ -1,26 +1,28 @@ -import ShaderChunk from "./shaderChunk/ShaderChunk"; -import phongVert from "./material/phongVert"; -import phongFrag from "./material/phongFrag"; +import { billboard_fs } from "./material/billboard_fs"; +import { billboard_vs } from "./material/billboard_vs"; import colorFrag from "./material/colorFrag"; import colorVert from "./material/colorVert"; +import pbr_fs from "./material/pbr_fs"; +import pbr_vs from "./material/pbr_vs"; import pbrFrag from "./material/pbrFrag"; import pbrVert from "./material/pbrVert"; -import skyBoxFrag from "./material/skyBoxFrag"; -import skyBoxVert from "./material/skyBoxVert"; +import phongFrag from "./material/phongFrag"; +import phongVert from "./material/phongVert"; import quadFrag from "./material/quadFrag"; import quadVert from "./material/quadVert"; -import pbr_vs from "./material/pbr_vs"; -import pbr_fs from "./material/pbr_fs"; +import skyBoxFrag from "./material/skyBoxFrag"; +import skyBoxVert from "./material/skyBoxVert"; +import blendFrag from "./postProcess/blend/blendFrag"; import Blur from "./postProcess/bloom/Blur"; import LuminosityHigh from "./postProcess/bloom/LuminosityHigh"; -import blendFrag from "./postProcess/blend/blendFrag"; +import ShaderChunk from "./shaderChunk/ShaderChunk"; import shadowMapDebuggerFrag from "./shaderChunk/shadow/shadowMapDebuggerFrag"; import shadowMapDebuggerVert from "./shaderChunk/shadow/shadowMapDebuggerVert"; -import shadowMapVert from "./shaderChunk/shadow/shadowMapVert"; import shadowMapFrag from "./shaderChunk/shadow/shadowMapFrag"; +import shadowMapVert from "./shaderChunk/shadow/shadowMapVert"; function reduceComma(shader) { - //对所有的include处理 + // 对所有的include处理 const str = resolveIncludes(shader); return str; } @@ -70,6 +72,10 @@ const shaders = { shadowMap: { vert: shadowMapVert, frag: shadowMapFrag + }, + billboard: { + vert: billboard_vs, + frag: billboard_fs } }; diff --git a/src/shader/material/billboardFrag.ts b/src/shader/material/billboardFrag.ts deleted file mode 100644 index 817cbb5..0000000 --- a/src/shader/material/billboardFrag.ts +++ /dev/null @@ -1,10 +0,0 @@ -// uniform sampler2D u_BaseColorSampler; -// uniform vec4 u_color; -// varying vec2 v_TexCoord; -// void main() { -// #if defined(M_USE_BILLBOARDTEXTURE) -// gl_FragColor=texture2D(u_BaseColorSampler,vec2(v_TexCoord.x,1.0-v_TexCoord.y)); -// #else -// gl_FragColor = u_color; -// #endif -// } diff --git a/src/shader/material/billboardVert.ts b/src/shader/material/billboardVert.ts deleted file mode 100644 index f963780..0000000 --- a/src/shader/material/billboardVert.ts +++ /dev/null @@ -1,26 +0,0 @@ -// attribute vec3 a_POSITION; -// attribute vec2 a_TEXCOORD_0; -// uniform float u_rotation; -// uniform vec2 u_center; -// uniform mat4 u_modelMatrix; -// uniform mat4 u_modelViewMatrix; -// uniform mat4 u_projectionMatrix; -// varying vec2 v_TexCoord; - -// void main() { -// v_TexCoord= a_TEXCOORD_0; -// vec4 mvPosition = u_modelViewMatrix * vec4( 0.0, 0.0, 0.0, 1.0 ); -// vec2 scale; -// scale.x = length( vec3( u_modelMatrix[ 0 ].x, u_modelMatrix[ 0 ].y, u_modelMatrix[ 0 ].z ) ); -// scale.y = length( vec3( u_modelMatrix[ 1 ].x, u_modelMatrix[ 1 ].y, u_modelMatrix[ 1 ].z ) ); -// #if defined(M_SIZEATTENUATION) -// // bool isPerspective = isPerspectiveMatrix( u_projectionMatrix ); -// scale *= - mvPosition.z; -// #endif -// vec2 alignedPosition = ( a_POSITION.xy - ( u_center - vec2( 0.5 ) ) ) * scale; -// vec2 rotatedPosition; -// rotatedPosition.x = cos( u_rotation ) * alignedPosition.x - sin( u_rotation ) * alignedPosition.y; -// rotatedPosition.y = sin( u_rotation ) * alignedPosition.x + cos( u_rotation ) * alignedPosition.y; -// mvPosition.xy += rotatedPosition; -// gl_Position = u_projectionMatrix * mvPosition; -// } diff --git a/src/shader/material/billboard_fs.ts b/src/shader/material/billboard_fs.ts new file mode 100644 index 0000000..05f8f15 --- /dev/null +++ b/src/shader/material/billboard_fs.ts @@ -0,0 +1,24 @@ +export function billboard_fs(defines) { + return ` + struct SelfUniform { + modelMatrix: mat4x4, + color:vec3, + rotation:f32, + center:vec2, + opacity:f32, + } + @binding(${defines.billboardBinding}) @group(0) var selfUniform : SelfUniform; + #if${defines.USE_COLORTEXTURE} + @group(0) @binding(${defines.baseColorSamplerBinding}) var baseColorSampler: sampler; + @group(0) @binding(${defines.baseColorTextureBinding}) var baseColorTexture: texture_2d; + #endif + @fragment + fn main(input:VertexOutput) -> @location(0) vec4 { + #if${defines.USE_COLORTEXTURE} + return textureSample(baseColorTexture, baseColorSampler, input.uv); + #else + return vec4(selfUniform.color,selfUniform.opacity); + #endif + } + `; +} diff --git a/src/shader/material/billboard_vs.ts b/src/shader/material/billboard_vs.ts new file mode 100644 index 0000000..29edac8 --- /dev/null +++ b/src/shader/material/billboard_vs.ts @@ -0,0 +1,37 @@ +import { wgslParseDefines } from "../WgslPreprocessor"; +export function billboard_vs(defines) { + return wgslParseDefines` + + #include + #include + #include + struct SelfUniform { + modelMatrix: mat4x4, + color:vec3, + rotation:f32, + center:vec2, + opacity:f32, + } + @binding(${defines.billboardBinding}) @group(0) var selfUniform : SelfUniform; + @binding(${defines.cameraBinding}) @group(1) var systemUniform : SystemUniform; + @vertex + fn main(input: VertexInput) -> VertexOutput { + var output:VertexOutput; + let mvPosition:vec4= ystemUniform.viewMatrix *selfUniform.modelMatrix*vec4(0.0,0.0,0.0, 1.0 ); + #if ${defines.HAS_UV} + output.uv=input.uv; + #endif + var scale:vec2; + scale.x = length( vec3( selfUniform.modelMatrix[ 0 ].x, selfUniform.modelMatrix[ 0 ].y, selfUniform.modelMatrix[ 0 ].z ) ); + scale.y = length( vec3( selfUniform.modelMatrix[ 1 ].x, selfUniform.modelMatrix[ 1 ].y, selfUniform.modelMatrix[ 1 ].z ) ); + + vec2 alignedPosition = ( input.position.xy - ( selfUniform.center - vec2( 0.5 ) ) ) * scale; + vec2 rotatedPosition; + rotatedPosition.x = cos( selfUniform.rotation ) * alignedPosition.x - sin( selfUniform.rotation ) * alignedPosition.y; + rotatedPosition.y = sin( selfUniform.rotation ) * alignedPosition.x + cos( selfUniform.rotation ) * alignedPosition.y; + mvPosition.xy += rotatedPosition; + output.position = systemUniform.projectionMatrix * mvPosition; + return output; + } + `; +} diff --git a/src/shader/material/pbr_fs.ts b/src/shader/material/pbr_fs.ts index ce40cab..804dd36 100644 --- a/src/shader/material/pbr_fs.ts +++ b/src/shader/material/pbr_fs.ts @@ -46,49 +46,12 @@ export default function pbr_fs(defines) { }; const M_PI:f32 = 3.141592653589793; const c_MinRoughness:f32 = 0.04; - @binding(${defines.pbrBinding}) @group(0) var materialUniform : MaterialUniform; - @binding(${defines.cameraBinding}) @group(1) var systemUniform : SystemUniform; - // IBL - #if ${defines.USE_IBL} - @group(0) @binding(${defines.specularEnvTextureBinding}) var specularEnvTexture: texture_cube; - @group(0) @binding(${defines.specularEnvSamplerBinding}) var specularEnvSampler: sampler; - #endif - #if ${defines.USE_TEXTURE} - @group(0) @binding(${defines.baseColorTextureBinding}) var baseColorTexture: texture_2d; - @group(0) @binding(${defines.baseColorSamplerBinding}) var baseColorSampler: sampler; - #endif - // normal map - #if ${defines.USE_NORMALTEXTURE} - @group(0) @binding(${defines.normalTextureBinding}) var normalTexture: texture_2d; - @group(0) @binding(${defines.normalSamplerBinding}) var normalSampler: sampler; - #endif - // emmisve map - #if ${defines.USE_EMISSIVETEXTURE} - @group(0) @binding(${defines.emissiveTextureBinding}) var emissiveTexture: texture_2d; - @group(0) @binding(${defines.emissiveSamplerBinding}) var emissiveSampler: sampler; - #endif - - // metal roughness - #if ${defines.USE_METALNESSTEXTURE} - @group(0) @binding(${ - defines.metalnessRoughnessTextureBinding - }) var metalnessRoughnessTexture: texture_2d; - @group(0) @binding(${defines.metalnessRoughnessSamplerBinding}) var metalnessRoughnessSampler: sampler; - #endif - // occlusion texture - #if ${defines.USE_AOTEXTURE} - @group(0) @binding(${defines.aoTextureBinding}) var aoTexture: texture_2d; - @group(0) @binding(${defines.aoSamplerBinding}) var aoSampler: sampler; - #endif - #if ${defines.USE_NORMALTEXTURE} - #include - #include - #else - #include - #endif + #include #if ${defines.USE_IBL} #include #endif + @binding(${defines.pbrBinding}) @group(0) var materialUniform : MaterialUniform; + @binding(${defines.cameraBinding}) @group(1) var systemUniform : SystemUniform; @fragment fn main(input:FragInput) -> @location(0) vec4 { diff --git a/src/shader/material/phongFrag.ts b/src/shader/material/phongFrag.ts index 116b0d3..c3b82bb 100644 --- a/src/shader/material/phongFrag.ts +++ b/src/shader/material/phongFrag.ts @@ -1,17 +1,6 @@ import { wgslParseDefines } from "../WgslPreprocessor"; export default function phongFrag(defines) { return wgslParseDefines` - struct VertInput { - @builtin(position) position: vec4, - @builtin(front_facing) frontFacing: bool, - @location(0) uv: vec2, - @location(1) view: vec3, // Vector from vertex to camera. - @location(2) worldPos: vec3, - @location(3) color: vec4, - @location(4) normal: vec3, - @location(5) viewPosition: vec3, - }; - struct MaterialUniform { modelMatrix: mat4x4, color: vec3, @@ -21,34 +10,14 @@ export default function phongFrag(defines) { shininess:f32, specular:vec3, } - struct SystemUniform { - projectionMatrix: mat4x4, - viewMatrix: mat4x4, - inverseViewMatrix: mat4x4, - cameraPosition: vec3, - }; - - #if${defines.USE_COLORTEXTURE} - @group(0) @binding(${defines.baseColorSamplerBinding}) var baseColorSampler: sampler; - @group(0) @binding(${defines.baseColorTextureBinding}) var baseColorTexture: texture_2d; - #endif - #if ${defines.USE_NORMALTEXTURE} - @group(0) @binding(${defines.normalTextureBinding}) var normalTexture: texture_2d; - @group(0) @binding(${defines.normalSamplerBinding}) var normalSampler: sampler; - #endif + #include + #include + #include + #include @binding(${defines.phongBinding}) @group(0) var materialUniform : MaterialUniform; @binding(${defines.cameraBinding}) @group(1) var systemUniform : SystemUniform; - #if ${defines.USE_NORMALTEXTURE} - #include - #include - #else - #include - #endif - - #include - @fragment - fn main(input:VertInput) -> @location(0) vec4 { + fn main(input:FragInput) -> @location(0) vec4 { var totalEmissiveRadiance:vec3 = materialUniform.emissive; var color:vec4; #if${defines.USE_COLORTEXTURE} diff --git a/src/shader/material/phongVert.ts b/src/shader/material/phongVert.ts index d6d6f62..e08352c 100644 --- a/src/shader/material/phongVert.ts +++ b/src/shader/material/phongVert.ts @@ -1,15 +1,6 @@ import { wgslParseDefines } from "../WgslPreprocessor"; export default function phongVert(defines) { - return ` - struct VertexOutput { - @builtin(position) position: vec4, - @location(0) uv: vec2, - @location(1) view: vec3, // Vector from vertex to camera. - @location(2) worldPos: vec3, - @location(3) color: vec4, - @location(4) normal: vec3, - @location(5) viewPosition: vec3, - }; + return wgslParseDefines` struct MaterialUniform { modelMatrix: mat4x4, color: vec3, @@ -19,25 +10,17 @@ export default function phongVert(defines) { specular:vec3, shininess:f32, } - struct SystemUniform { - projectionMatrix: mat4x4, - viewMatrix: mat4x4, - inverseViewMatrix: mat4x4, - cameraPosition: vec3, - }; - + #include + #include + #include @binding(${defines.phongBinding}) @group(0) var selfUniform : MaterialUniform; @binding(${defines.cameraBinding}) @group(1) var systemUniform : SystemUniform; - - struct VertexInput { - @location(${defines.positionLocation}) position: vec3, - @location(${defines.normalLocation}) normal: vec3, - @location(${defines.uvLocation}) uv: vec2, - } @vertex fn main(input: VertexInput) -> VertexOutput { var output: VertexOutput; - output.uv = input.uv; + #if ${defines.HAS_UV} + output.uv = input.uv; + #endif let modelPos=selfUniform.modelMatrix *vec4(input.position,1.0); output.worldPos = modelPos.xyz/modelPos.w; let vNormalView = selfUniform.normalMatrix * vec4(input.normal,0.0); diff --git a/src/shader/shaderChunk/ShaderChunk.ts b/src/shader/shaderChunk/ShaderChunk.ts index c2f9f7e..c914516 100644 --- a/src/shader/shaderChunk/ShaderChunk.ts +++ b/src/shader/shaderChunk/ShaderChunk.ts @@ -2,6 +2,7 @@ import { FragInput } from "./attribute/FragInput"; import { VertexInput } from "./attribute/VertexInput"; import { VertexOutput } from "./attribute/VertexOutput"; import { SystemUniform } from "./common/SystemUniform"; +import { TextureAndSamplerDefine } from "./common/TextureAndSamplerDefine"; import environment from "./environment/environment"; import { instanceVertHeader, instanceVertMain } from "./instance/Instance"; import light from "./light/light"; @@ -43,6 +44,7 @@ const ShaderChunk = { PbrMaterialStruct, SystemUniform, instanceVertMain, - instanceVertHeader + instanceVertHeader, + TextureAndSamplerDefine }; export default ShaderChunk; diff --git a/src/shader/shaderChunk/attribute/FragInput.ts b/src/shader/shaderChunk/attribute/FragInput.ts index 7592e33..dae6c0b 100644 --- a/src/shader/shaderChunk/attribute/FragInput.ts +++ b/src/shader/shaderChunk/attribute/FragInput.ts @@ -6,9 +6,10 @@ export function FragInput(defines) { @builtin(front_facing) frontFacing: bool, @location(0) worldPos:vec3, @location(1) normal:vec3, - #if ${defines.HAS_UV} - @location(2) uv:vec2 - #endif + @location(2) uv:vec2, + @location(3) view: vec3, // Vector from vertex to camera. + @location(4) color: vec4, + @location(5) viewPosition: vec3, } `; } diff --git a/src/shader/shaderChunk/attribute/VertexOutput.ts b/src/shader/shaderChunk/attribute/VertexOutput.ts index 161d1ee..e66e0b5 100644 --- a/src/shader/shaderChunk/attribute/VertexOutput.ts +++ b/src/shader/shaderChunk/attribute/VertexOutput.ts @@ -6,9 +6,10 @@ export function VertexOutput(defines) { @builtin(position) position:vec4, @location(0) worldPos:vec3, @location(1) normal:vec3, - #if ${defines.HAS_UV} - @location(2) uv:vec2 - #endif + @location(2) uv:vec2, + @location(3) view: vec3, // Vector from vertex to camera. + @location(4) color: vec4, + @location(5) viewPosition: vec3, } `; } diff --git a/src/shader/shaderChunk/common/TextureAndSamplerDefine.ts b/src/shader/shaderChunk/common/TextureAndSamplerDefine.ts new file mode 100644 index 0000000..87d2a10 --- /dev/null +++ b/src/shader/shaderChunk/common/TextureAndSamplerDefine.ts @@ -0,0 +1,41 @@ +import { wgslParseDefines } from "../../WgslPreprocessor"; + +export function TextureAndSamplerDefine(defines) { + return wgslParseDefines` + #if ${defines.USE_IBL} + @group(0) @binding(${defines.specularEnvTextureBinding}) var specularEnvTexture: texture_cube; + @group(0) @binding(${defines.specularEnvSamplerBinding}) var specularEnvSampler: sampler; + #endif + #if ${defines.USE_TEXTURE} + @group(0) @binding(${defines.baseColorTextureBinding}) var baseColorTexture: texture_2d; + @group(0) @binding(${defines.baseColorSamplerBinding}) var baseColorSampler: sampler; + #endif + // normal map + #if ${defines.USE_NORMALTEXTURE} + @group(0) @binding(${defines.normalTextureBinding}) var normalTexture: texture_2d; + @group(0) @binding(${defines.normalSamplerBinding}) var normalSampler: sampler; + #endif + // emmisve map + #if ${defines.USE_EMISSIVETEXTURE} + @group(0) @binding(${defines.emissiveTextureBinding}) var emissiveTexture: texture_2d; + @group(0) @binding(${defines.emissiveSamplerBinding}) var emissiveSampler: sampler; + #endif + + // metal roughness + #if ${defines.USE_METALNESSTEXTURE} + @group(0) @binding(${defines.metalnessRoughnessTextureBinding}) var metalnessRoughnessTexture: texture_2d; + @group(0) @binding(${defines.metalnessRoughnessSamplerBinding}) var metalnessRoughnessSampler: sampler; + #endif + // occlusion texture + #if ${defines.USE_AOTEXTURE} + @group(0) @binding(${defines.aoTextureBinding}) var aoTexture: texture_2d; + @group(0) @binding(${defines.aoSamplerBinding}) var aoSampler: sampler; + #endif + #if ${defines.USE_NORMALTEXTURE} + #include + #include + #else + #include + #endif + `; +} diff --git a/src/shader/shaderChunk/normal/getNormalBackUp.ts b/src/shader/shaderChunk/normal/getNormalBackUp.ts index d676c0a..3c0f3d3 100644 --- a/src/shader/shaderChunk/normal/getNormalBackUp.ts +++ b/src/shader/shaderChunk/normal/getNormalBackUp.ts @@ -16,7 +16,7 @@ export function getNormal(defines) { } export function getNormalByNormalTexture(defines) { return wgslParseDefines` - fn getNormalByNormalTexture(input:VertInput)->vec3{ + fn getNormalByNormalTexture(input:FragInput)->vec3{ var n:vec3 = textureSample(normalTexture,normalSampler, input.uv).rgb; let tbn:mat3x3 =getTBN(input); n = normalize(tbn * (2.0 * n - vec3(1.0))); @@ -27,7 +27,7 @@ export function getNormalByNormalTexture(defines) { } export function getTBN(defines) { return wgslParseDefines` - fn getTBN(input:VertInput)->mat3x3{ + fn getTBN(input:FragInput)->mat3x3{ #if ${defines.HAS_TANGENT} let tbn:mat3x3 = input.tbn; #else diff --git a/src/utils/combine.ts b/src/utils/combine.ts index 41412f6..28a687c 100644 --- a/src/utils/combine.ts +++ b/src/utils/combine.ts @@ -16,7 +16,7 @@ import defined from "./defined"; * const object2 = { * propTwo : 2 * } - * const final = Cesium.combine(object1, object2); + * const final = combine(object1, object2); * * // final === { * // propOne : 1, @@ -33,48 +33,40 @@ import defined from "./defined"; * @function */ function combine(object1, object2, deep) { - deep = defaultValue(deep, false); + deep = defaultValue(deep, false); - const result = {}; + const result = {}; - const object1Defined = defined(object1); - const object2Defined = defined(object2); - let property; - let object1Value; - let object2Value; - if (object1Defined) { - for (property in object1) { - if (object1.hasOwnProperty(property)) { - object1Value = object1[property]; - if ( - object2Defined && - deep && - typeof object1Value === "object" && - object2.hasOwnProperty(property) - ) { - object2Value = object2[property]; - if (typeof object2Value === "object") { - result[property] = combine(object1Value, object2Value, deep); - } else { - result[property] = object1Value; - } - } else { - result[property] = object1Value; - } - } - } - } - if (object2Defined) { - for (property in object2) { - if ( - object2.hasOwnProperty(property) && - !result.hasOwnProperty(property) - ) { - object2Value = object2[property]; - result[property] = object2Value; - } - } - } - return result; + const object1Defined = defined(object1); + const object2Defined = defined(object2); + let property; + let object1Value; + let object2Value; + if (object1Defined) { + for (property in object1) { + if (object1.hasOwnProperty(property)) { + object1Value = object1[property]; + if (object2Defined && deep && typeof object1Value === "object" && object2.hasOwnProperty(property)) { + object2Value = object2[property]; + if (typeof object2Value === "object") { + result[property] = combine(object1Value, object2Value, deep); + } else { + result[property] = object1Value; + } + } else { + result[property] = object1Value; + } + } + } + } + if (object2Defined) { + for (property in object2) { + if (object2.hasOwnProperty(property) && !result.hasOwnProperty(property)) { + object2Value = object2[property]; + result[property] = object2Value; + } + } + } + return result; } export default combine; diff --git a/src/utils/uniformUtils.ts b/src/utils/uniformUtils.ts index ed0c5b2..b3066ca 100644 --- a/src/utils/uniformUtils.ts +++ b/src/utils/uniformUtils.ts @@ -1,4 +1,5 @@ import { IUniform, Uniforms } from "../core/WebGPUTypes"; +import { Mesh } from "../mesh/Mesh"; import ShaderData from "../render/ShaderData"; import UniformBuffer from "../render/UniformBuffer"; import { UniformEnum } from "../render/Uniforms"; @@ -32,6 +33,7 @@ export function addUniformToShaderData( uniform: IUniform, uniforms: Uniforms, shaderData: ShaderData, + mesh?: Mesh, uniformBuffer?: UniformBuffer ) { switch (uniform.type) { @@ -79,6 +81,7 @@ export function addUniformToShaderData( }, UniformEnum.FloatVec4 ); + break; case "mat2": uniformBuffer.setUniform( name, @@ -96,11 +99,16 @@ export function addUniformToShaderData( }, UniformEnum.Mat3 ); + break; case "mat4": uniformBuffer.setUniform( name, () => { - return uniforms[name].value; + return name == "modelMatrix" + ? mesh?.modelMatrix + : name === "normalMatrix" + ? mesh.normalMatrix + : uniforms[name].value; }, UniformEnum.Mat4 ); @@ -157,6 +165,5 @@ export function addUniformToShaderData( break; default: throw new Error("not match unifrom type"); - break; } }