@soonspacejs/plugin-effect 2.11.49 → 2.11.50

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/index.esm.js CHANGED
@@ -1 +1 @@
1
- import{Color as t,Vector4 as e,Vector3 as r,Vector2 as a,Matrix3 as A,MathUtils as s,BufferGeometry as i,BufferAttribute as o,Points as n,PointsMaterial as l,Quaternion as p,Matrix4 as y,Mesh as u,PlaneGeometry as k,MeshBasicMaterial as S,TextureLoader as g,DoubleSide as W,CylinderGeometry as c,Shape as d,ShapeGeometry as I,RepeatWrapping as b,BoxGeometry as V,Clock as m,NormalBlending as J,AdditiveBlending as q,DynamicDrawUsage as U,Scene as R,PerspectiveCamera as N,ShaderMaterial as T,LinearFilter as h,ClampToEdgeWrapping as v,UniformsUtils as C,ShaderLib as L}from"three";import B from"soonspacejs";import{Water as x}from"three/examples/jsm/objects/Water.js";function j(t,e){var r={};for(var a in t)Object.prototype.hasOwnProperty.call(t,a)&&e.indexOf(a)<0&&(r[a]=t[a]);if(null!=t&&"function"==typeof Object.getOwnPropertySymbols){var A=0;for(a=Object.getOwnPropertySymbols(t);A<a.length;A++)e.indexOf(a[A])<0&&Object.prototype.propertyIsEnumerable.call(t,a[A])&&(r[a[A]]=t[a[A]])}return r}"function"==typeof SuppressedError&&SuppressedError;var H={vertexShader:"\n varying vec3 vViewPosition;\n varying vec3 vWorldPos;\n varying vec3 vNormal;\n\n #include <common>\n #include <uv_pars_vertex>\n #include <displacementmap_pars_vertex>\n #include <envmap_pars_vertex>\n #include <color_pars_vertex>\n #include <morphtarget_pars_vertex>\n #include <skinning_pars_vertex>\n #include <shadowmap_pars_vertex>\n #include <logdepthbuf_pars_vertex>\n #include <clipping_planes_pars_vertex>\n \n void main() {\n\n #include <uv_vertex>\n #include <color_vertex>\n \n //# include <begin_vertex>\n vec3 transformed = vec3( position.x, position.y, position.z );\n //<begin_vertex>\n \n #include <morphtarget_vertex>\n #include <displacementmap_vertex>\n #include <project_vertex>\n #include <logdepthbuf_vertex>\n #include <clipping_planes_vertex>\n\n vViewPosition = - mvPosition.xyz;\n\n #include <worldpos_vertex>\n\n vWorldPos = (modelMatrix * vec4(position, 1.0)).xyz;\n }",fragmentShader:"\n #include <packing>\n #include <logdepthbuf_pars_fragment>\n \n uniform vec3 color;\n uniform float time;\n uniform float seed;\n uniform mat4 invModelMatrix;\n uniform vec3 scale;\n \n uniform vec4 noiseScale;\n uniform float magnitude;\n uniform float lacunarity;\n uniform float gain;\n \n uniform sampler2D fireTex;\n \n varying vec3 vWorldPos;\n \n // GLSL simplex noise function by ashima / https://github.com/ashima/webgl-noise/blob/master/src/noise3D.glsl\n // -------- simplex noise\n vec3 mod289(vec3 x) {\n return x - floor(x * (1.0 / 289.0)) * 289.0;\n }\n \n vec4 mod289(vec4 x) {\n return x - floor(x * (1.0 / 289.0)) * 289.0;\n }\n \n vec4 permute(vec4 x) {\n return mod289(((x * 34.0) + 1.0) * x);\n }\n \n vec4 taylorInvSqrt(vec4 r) {\n return 1.79284291400159 - 0.85373472095314 * r;\n }\n \n float snoise(vec3 v) {\n const vec2 C = vec2(1.0 / 6.0, 1.0 / 3.0);\n const vec4 D = vec4(0.0, 0.5, 1.0, 2.0);\n \n // First corner\n vec3 i = floor(v + dot(v, C.yyy));\n vec3 x0 = v - i + dot(i, C.xxx);\n \n // Other corners\n vec3 g = step(x0.yzx, x0.xyz);\n vec3 l = 1.0 - g;\n vec3 i1 = min(g.xyz, l.zxy);\n vec3 i2 = max(g.xyz, l.zxy);\n \n // x0 = x0 - 0.0 + 0.0 * C.xxx;\n // x1 = x0 - i1 + 1.0 * C.xxx;\n // x2 = x0 - i2 + 2.0 * C.xxx;\n // x3 = x0 - 1.0 + 3.0 * C.xxx;\n vec3 x1 = x0 - i1 + C.xxx;\n vec3 x2 = x0 - i2 + C.yyy; // 2.0*C.x = 1/3 = C.y\n vec3 x3 = x0 - D.yyy; // -1.0+3.0*C.x = -0.5 = -D.y\n \n // Permutations\n i = mod289(i); \n vec4 p = permute(permute(permute( \n i.z + vec4(0.0, i1.z, i2.z, 1.0))\n + i.y + vec4(0.0, i1.y, i2.y, 1.0))\n + i.x + vec4(0.0, i1.x, i2.x, 1.0));\n \n // Gradients: 7x7 points over a square, mapped onto an octahedron.\n // The ring size 17*17 = 289 is close to a multiple of 49 (49*6 = 294)\n float n_ = 0.142857142857; // 1.0/7.0\n vec3 ns = n_ * D.wyz - D.xzx;\n \n vec4 j = p - 49.0 * floor(p * ns.z * ns.z); // mod(p,7*7)\n \n vec4 x_ = floor(j * ns.z);\n vec4 y_ = floor(j - 7.0 * x_); // mod(j,N)\n \n vec4 x = x_ * ns.x + ns.yyyy;\n vec4 y = y_ * ns.x + ns.yyyy;\n vec4 h = 1.0 - abs(x) - abs(y);\n \n vec4 b0 = vec4(x.xy, y.xy);\n vec4 b1 = vec4(x.zw, y.zw);\n \n //vec4 s0 = vec4(lessThan(b0,0.0))*2.0 - 1.0;\n //vec4 s1 = vec4(lessThan(b1,0.0))*2.0 - 1.0;\n vec4 s0 = floor(b0) * 2.0 + 1.0;\n vec4 s1 = floor(b1) * 2.0 + 1.0;\n vec4 sh = -step(h, vec4(0.0));\n \n vec4 a0 = b0.xzyw + s0.xzyw * sh.xxyy;\n vec4 a1 = b1.xzyw + s1.xzyw * sh.zzww;\n \n vec3 p0 = vec3(a0.xy, h.x);\n vec3 p1 = vec3(a0.zw, h.y);\n vec3 p2 = vec3(a1.xy, h.z);\n vec3 p3 = vec3(a1.zw, h.w);\n \n //Normalise gradients\n vec4 norm = taylorInvSqrt(vec4(dot(p0, p0), dot(p1, p1), dot(p2, p2), dot(p3, p3)));\n p0 *= norm.x;\n p1 *= norm.y;\n p2 *= norm.z;\n p3 *= norm.w;\n \n // Mix final noise value\n vec4 m = max(0.6 - vec4(dot(x0, x0), dot(x1, x1), dot(x2, x2), dot(x3, x3)), 0.0);\n m = m * m;\n return 42.0 * dot(m * m, vec4(dot(p0, x0), dot(p1, x1), dot(p2, x2), dot(p3, x3)));\n }\n // simplex noise --------\n \n float turbulence(vec3 p) {\n float sum = 0.0;\n float freq = 1.0;\n float amp = 1.0;\n \n for(int i = 0; i < OCTIVES; i++) {\n sum += abs(snoise(p * freq)) * amp;\n freq *= lacunarity;\n amp *= gain;\n }\n \n return sum;\n }\n \n vec4 samplerFire (vec3 p, vec4 scale) {\n vec2 st = vec2(sqrt(dot(p.xz, p.xz)), p.y);\n \n if(st.x <= 0.0 || st.x >= 1.0 || st.y <= 0.0 || st.y >= 1.0) return vec4(0.0);\n \n p.y -= (seed + time) * scale.w;\n p *= scale.xyz;\n \n st.y += sqrt(st.y) * magnitude * turbulence(p);\n \n if(st.y <= 0.0 || st.y >= 1.0) return vec4(0.0);\n \n return texture2D(fireTex, st);\n }\n \n vec3 localize(vec3 p) {\n return (invModelMatrix * vec4(p, 1.0)).xyz;\n }\n \n void main() {\n #include <logdepthbuf_fragment>\n \n vec3 rayPos = vWorldPos;\n vec3 rayDir = normalize(rayPos - cameraPosition);\n float rayLen = 0.0288 * length(scale.xyz);\n \n vec4 col = vec4(0.0);\n \n for(int i = 0; i < ITERATIONS; i++) {\n rayPos += rayDir * rayLen;\n \n vec3 lp = localize(rayPos);\n \n lp.y += 0.5;\n lp.xz *= 2.0;\n col += samplerFire(lp, noiseScale);\n }\n \n col.a = col.r;\n gl_FragColor.a = 1.0;\n gl_FragColor = col;\n }"},K="";const{THREE:F}=B;var f,X,Z={distributions:{BOX:1,SPHERE:2,DISC:3,LINE:4},valueOverLifetimeLength:4};Z.TypedArrayHelper=function(t,e,r,a){this.componentSize=r||1,this.size=e||1,this.TypedArrayConstructor=t||Float32Array,this.array=new t(e*this.componentSize),this.indexOffset=a||0},Z.TypedArrayHelper.constructor=Z.TypedArrayHelper,Z.TypedArrayHelper.prototype.setSize=function(t,e){var r=this.array.length;return e||(t*=this.componentSize),t<r?this.shrink(t):t>r?this.grow(t):void console.info("TypedArray is already of size:",t+".","Will not resize.")},Z.TypedArrayHelper.prototype.shrink=function(t){return this.array=this.array.subarray(0,t),this.size=t,this},Z.TypedArrayHelper.prototype.grow=function(t){var e=this.array,r=new this.TypedArrayConstructor(t);return r.set(e),this.array=r,this.size=t,this},Z.TypedArrayHelper.prototype.splice=function(t,e){t*=this.componentSize,e*=this.componentSize;for(var r=[],a=this.array,A=a.length,s=0;s<A;++s)(s<t||s>=e)&&r.push(a[s]);return this.setFromArray(0,r),this},Z.TypedArrayHelper.prototype.setFromArray=function(t,e){var r=t+e.length;return r>this.array.length?this.grow(r):r<this.array.length&&this.shrink(r),this.array.set(e,this.indexOffset+t),this},Z.TypedArrayHelper.prototype.setVec2=function(t,e){return this.setVec2Components(t,e.x,e.y)},Z.TypedArrayHelper.prototype.setVec2Components=function(t,e,r){var a=this.array,A=this.indexOffset+t*this.componentSize;return a[A]=e,a[A+1]=r,this},Z.TypedArrayHelper.prototype.setVec3=function(t,e){return this.setVec3Components(t,e.x,e.y,e.z)},Z.TypedArrayHelper.prototype.setVec3Components=function(t,e,r,a){var A=this.array,s=this.indexOffset+t*this.componentSize;return A[s]=e,A[s+1]=r,A[s+2]=a,this},Z.TypedArrayHelper.prototype.setVec4=function(t,e){return this.setVec4Components(t,e.x,e.y,e.z,e.w)},Z.TypedArrayHelper.prototype.setVec4Components=function(t,e,r,a,A){var s=this.array,i=this.indexOffset+t*this.componentSize;return s[i]=e,s[i+1]=r,s[i+2]=a,s[i+3]=A,this},Z.TypedArrayHelper.prototype.setMat3=function(t,e){return this.setFromArray(this.indexOffset+t*this.componentSize,e.elements)},Z.TypedArrayHelper.prototype.setMat4=function(t,e){return this.setFromArray(this.indexOffset+t*this.componentSize,e.elements)},Z.TypedArrayHelper.prototype.setColor=function(t,e){return this.setVec3Components(t,e.r,e.g,e.b)},Z.TypedArrayHelper.prototype.setNumber=function(t,e){return this.array[this.indexOffset+t*this.componentSize]=e,this},Z.TypedArrayHelper.prototype.getValueAtIndex=function(t){return this.array[this.indexOffset+t]},Z.TypedArrayHelper.prototype.getComponentValueAtIndex=function(t){return this.array.subarray(this.indexOffset+t*this.componentSize)},Z.ShaderAttribute=function(t,e,r){var a=Z.ShaderAttribute.typeSizeMap;this.type="string"==typeof t&&a.hasOwnProperty(t)?t:"f",this.componentSize=a[this.type],this.arrayType=r||Float32Array,this.typedArray=null,this.bufferAttribute=null,this.dynamicBuffer=!!e,this.updateMin=0,this.updateMax=0},Z.ShaderAttribute.constructor=Z.ShaderAttribute,Z.ShaderAttribute.typeSizeMap={f:1,v2:2,v3:3,v4:4,c:3,m3:9,m4:16},Z.ShaderAttribute.prototype.setUpdateRange=function(t,e){this.updateMin=Math.min(t*this.componentSize,this.updateMin*this.componentSize),this.updateMax=Math.max(e*this.componentSize,this.updateMax*this.componentSize)},Z.ShaderAttribute.prototype.flagUpdate=function(){var t=this.bufferAttribute,e=t.updateRange;e.offset=this.updateMin,e.count=Math.min(this.updateMax-this.updateMin+this.componentSize,this.typedArray.array.length),t.needsUpdate=!0},Z.ShaderAttribute.prototype.resetUpdateRange=function(){this.updateMin=0,this.updateMax=0},Z.ShaderAttribute.prototype.resetDynamic=function(){this.bufferAttribute.usage=this.dynamicBuffer?F.DynamicDrawUsage:F.StaticDrawUsage},Z.ShaderAttribute.prototype.splice=function(t,e){this.typedArray.splice(t,e),this.forceUpdateAll()},Z.ShaderAttribute.prototype.forceUpdateAll=function(){this.bufferAttribute.array=this.typedArray.array,this.bufferAttribute.updateRange.offset=0,this.bufferAttribute.updateRange.count=-1,this.bufferAttribute.usage=F.StaticDrawUsage,this.bufferAttribute.needsUpdate=!0},Z.ShaderAttribute.prototype._ensureTypedArray=function(t){null!==this.typedArray&&this.typedArray.size===t*this.componentSize||(null!==this.typedArray&&this.typedArray.size!==t?this.typedArray.setSize(t):null===this.typedArray&&(this.typedArray=new Z.TypedArrayHelper(this.arrayType,t,this.componentSize)))},Z.ShaderAttribute.prototype._createBufferAttribute=function(t){if(this._ensureTypedArray(t),null!==this.bufferAttribute)return this.bufferAttribute.array=this.typedArray.array,parseFloat(F.REVISION)>=81&&(this.bufferAttribute.count=this.bufferAttribute.array.length/this.bufferAttribute.itemSize),void(this.bufferAttribute.needsUpdate=!0);this.bufferAttribute=new F.BufferAttribute(this.typedArray.array,this.componentSize),this.bufferAttribute.usage=this.dynamicBuffer?F.DynamicDrawUsage:F.StaticDrawUsage},Z.ShaderAttribute.prototype.getLength=function(){return null===this.typedArray?0:this.typedArray.array.length},Z.shaderChunks={defines:["#define PACKED_COLOR_SIZE 256.0","#define PACKED_COLOR_DIVISOR 255.0"].join("\n"),uniforms:["uniform float deltaTime;","uniform float runTime;","uniform sampler2D tex;","uniform vec4 textureAnimation;","uniform float scale;"].join("\n"),attributes:["attribute vec4 acceleration;","attribute vec3 velocity;","attribute vec4 rotation;","attribute vec3 rotationCenter;","attribute vec4 params;","attribute vec4 size;","attribute vec4 angle;","attribute vec4 color;","attribute vec4 opacity;"].join("\n"),varyings:["varying vec4 vColor;","#ifdef SHOULD_ROTATE_TEXTURE"," varying float vAngle;","#endif","#ifdef SHOULD_CALCULATE_SPRITE"," varying vec4 vSpriteSheet;","#endif"].join("\n"),branchAvoidanceFunctions:["float when_gt(float x, float y) {"," return max(sign(x - y), 0.0);","}","float when_lt(float x, float y) {"," return min( max(1.0 - sign(x - y), 0.0), 1.0 );","}","float when_eq( float x, float y ) {"," return 1.0 - abs( sign( x - y ) );","}","float when_ge(float x, float y) {"," return 1.0 - when_lt(x, y);","}","float when_le(float x, float y) {"," return 1.0 - when_gt(x, y);","}","float and(float a, float b) {"," return a * b;","}","float or(float a, float b) {"," return min(a + b, 1.0);","}"].join("\n"),unpackColor:["vec3 unpackColor( in float hex ) {"," vec3 c = vec3( 0.0 );"," float r = mod( (hex / PACKED_COLOR_SIZE / PACKED_COLOR_SIZE), PACKED_COLOR_SIZE );"," float g = mod( (hex / PACKED_COLOR_SIZE), PACKED_COLOR_SIZE );"," float b = mod( hex, PACKED_COLOR_SIZE );"," c.r = r / PACKED_COLOR_DIVISOR;"," c.g = g / PACKED_COLOR_DIVISOR;"," c.b = b / PACKED_COLOR_DIVISOR;"," return c;","}"].join("\n"),unpackRotationAxis:["vec3 unpackRotationAxis( in float hex ) {"," vec3 c = vec3( 0.0 );"," float r = mod( (hex / PACKED_COLOR_SIZE / PACKED_COLOR_SIZE), PACKED_COLOR_SIZE );"," float g = mod( (hex / PACKED_COLOR_SIZE), PACKED_COLOR_SIZE );"," float b = mod( hex, PACKED_COLOR_SIZE );"," c.r = r / PACKED_COLOR_DIVISOR;"," c.g = g / PACKED_COLOR_DIVISOR;"," c.b = b / PACKED_COLOR_DIVISOR;"," c *= vec3( 2.0 );"," c -= vec3( 1.0 );"," return c;","}"].join("\n"),floatOverLifetime:["float getFloatOverLifetime( in float positionInTime, in vec4 attr ) {"," highp float value = 0.0;"," float deltaAge = positionInTime * float( VALUE_OVER_LIFETIME_LENGTH - 1 );"," float fIndex = 0.0;"," float shouldApplyValue = 0.0;"," value += attr[ 0 ] * when_eq( deltaAge, 0.0 );",""," for( int i = 0; i < VALUE_OVER_LIFETIME_LENGTH - 1; ++i ) {"," fIndex = float( i );"," shouldApplyValue = and( when_gt( deltaAge, fIndex ), when_le( deltaAge, fIndex + 1.0 ) );"," value += shouldApplyValue * mix( attr[ i ], attr[ i + 1 ], deltaAge - fIndex );"," }",""," return value;","}"].join("\n"),colorOverLifetime:["vec3 getColorOverLifetime( in float positionInTime, in vec3 color1, in vec3 color2, in vec3 color3, in vec3 color4 ) {"," vec3 value = vec3( 0.0 );"," value.x = getFloatOverLifetime( positionInTime, vec4( color1.x, color2.x, color3.x, color4.x ) );"," value.y = getFloatOverLifetime( positionInTime, vec4( color1.y, color2.y, color3.y, color4.y ) );"," value.z = getFloatOverLifetime( positionInTime, vec4( color1.z, color2.z, color3.z, color4.z ) );"," return value;","}"].join("\n"),paramFetchingFunctions:["float getAlive() {"," return params.x;","}","float getAge() {"," return params.y;","}","float getMaxAge() {"," return params.z;","}","float getWiggle() {"," return params.w;","}"].join("\n"),forceFetchingFunctions:["vec4 getPosition( in float age ) {"," return modelViewMatrix * vec4( position, 1.0 );","}","vec3 getVelocity( in float age ) {"," return velocity * age;","}","vec3 getAcceleration( in float age ) {"," return acceleration.xyz * age;","}"].join("\n"),rotationFunctions:["#ifdef SHOULD_ROTATE_PARTICLES"," mat4 getRotationMatrix( in vec3 axis, in float angle) {"," axis = normalize(axis);"," float s = sin(angle);"," float c = cos(angle);"," float oc = 1.0 - c;",""," return mat4(oc * axis.x * axis.x + c, oc * axis.x * axis.y - axis.z * s, oc * axis.z * axis.x + axis.y * s, 0.0,"," oc * axis.x * axis.y + axis.z * s, oc * axis.y * axis.y + c, oc * axis.y * axis.z - axis.x * s, 0.0,"," oc * axis.z * axis.x - axis.y * s, oc * axis.y * axis.z + axis.x * s, oc * axis.z * axis.z + c, 0.0,"," 0.0, 0.0, 0.0, 1.0);"," }",""," vec3 getRotation( in vec3 pos, in float positionInTime ) {"," if( rotation.y == 0.0 ) {"," return pos;"," }",""," vec3 axis = unpackRotationAxis( rotation.x );"," vec3 center = rotationCenter;"," vec3 translated;"," mat4 rotationMatrix;"," float angle = 0.0;"," angle += when_eq( rotation.z, 0.0 ) * rotation.y;"," angle += when_gt( rotation.z, 0.0 ) * mix( 0.0, rotation.y, positionInTime );"," translated = rotationCenter - pos;"," rotationMatrix = getRotationMatrix( axis, angle );"," return center - vec3( rotationMatrix * vec4( translated, 0.0 ) );"," }","#endif"].join("\n"),rotateTexture:[" vec2 vUv = vec2( gl_PointCoord.x, 1.0 - gl_PointCoord.y );",""," #ifdef SHOULD_ROTATE_TEXTURE"," float x = gl_PointCoord.x - 0.5;"," float y = 1.0 - gl_PointCoord.y - 0.5;"," float c = cos( -vAngle );"," float s = sin( -vAngle );"," vUv = vec2( c * x + s * y + 0.5, c * y - s * x + 0.5 );"," #endif",""," #ifdef SHOULD_CALCULATE_SPRITE"," float framesX = vSpriteSheet.x;"," float framesY = vSpriteSheet.y;"," float columnNorm = vSpriteSheet.z;"," float rowNorm = vSpriteSheet.w;"," vUv.x = gl_PointCoord.x * framesX + columnNorm;"," vUv.y = 1.0 - (gl_PointCoord.y * framesY + rowNorm);"," #endif",""," vec4 rotatedTexture = texture2D( tex, vUv );"].join("\n")},Z.shaders={vertex:[Z.shaderChunks.defines,Z.shaderChunks.uniforms,Z.shaderChunks.attributes,Z.shaderChunks.varyings,F.ShaderChunk.common,F.ShaderChunk.logdepthbuf_pars_vertex,F.ShaderChunk.fog_pars_vertex,Z.shaderChunks.branchAvoidanceFunctions,Z.shaderChunks.unpackColor,Z.shaderChunks.unpackRotationAxis,Z.shaderChunks.floatOverLifetime,Z.shaderChunks.colorOverLifetime,Z.shaderChunks.paramFetchingFunctions,Z.shaderChunks.forceFetchingFunctions,Z.shaderChunks.rotationFunctions,"void main() {"," highp float age = getAge();"," highp float alive = getAlive();"," highp float maxAge = getMaxAge();"," highp float positionInTime = (age / maxAge);"," highp float isAlive = when_gt( alive, 0.0 );"," #ifdef SHOULD_WIGGLE_PARTICLES"," float wiggleAmount = positionInTime * getWiggle();"," float wiggleSin = isAlive * sin( wiggleAmount );"," float wiggleCos = isAlive * cos( wiggleAmount );"," #endif"," vec3 vel = getVelocity( age );"," vec3 accel = getAcceleration( age );"," vec3 force = vec3( 0.0 );"," vec3 pos = vec3( position );"," float drag = 1.0 - (positionInTime * 0.5) * acceleration.w;"," force += vel;"," force *= drag;"," force += accel * age;"," pos += force;"," #ifdef SHOULD_WIGGLE_PARTICLES"," pos.x += wiggleSin;"," pos.y += wiggleCos;"," pos.z += wiggleSin;"," #endif"," #ifdef SHOULD_ROTATE_PARTICLES"," pos = getRotation( pos, positionInTime );"," #endif"," vec4 mvPosition = modelViewMatrix * vec4( pos, 1.0 );"," highp float pointSize = getFloatOverLifetime( positionInTime, size ) * isAlive;"," #ifdef HAS_PERSPECTIVE"," float perspective = scale / length( mvPosition.xyz );"," #else"," float perspective = 1.0;"," #endif"," float pointSizePerspective = pointSize * perspective;"," #ifdef COLORIZE"," vec3 c = isAlive * getColorOverLifetime("," positionInTime,"," unpackColor( color.x ),"," unpackColor( color.y ),"," unpackColor( color.z ),"," unpackColor( color.w )"," );"," #else"," vec3 c = vec3(1.0);"," #endif"," float o = isAlive * getFloatOverLifetime( positionInTime, opacity );"," vColor = vec4( c, o );"," #ifdef SHOULD_ROTATE_TEXTURE"," vAngle = isAlive * getFloatOverLifetime( positionInTime, angle );"," #endif"," #ifdef SHOULD_CALCULATE_SPRITE"," float framesX = textureAnimation.x;"," float framesY = textureAnimation.y;"," float loopCount = textureAnimation.w;"," float totalFrames = textureAnimation.z;"," float frameNumber = mod( (positionInTime * loopCount) * totalFrames, totalFrames );"," float column = floor(mod( frameNumber, framesX ));"," float row = floor( (frameNumber - column) / framesX );"," float columnNorm = column / framesX;"," float rowNorm = row / framesY;"," vSpriteSheet.x = 1.0 / framesX;"," vSpriteSheet.y = 1.0 / framesY;"," vSpriteSheet.z = columnNorm;"," vSpriteSheet.w = rowNorm;"," #endif"," gl_PointSize = pointSizePerspective;"," gl_Position = projectionMatrix * mvPosition;",F.ShaderChunk.logdepthbuf_vertex,F.ShaderChunk.fog_vertex,"}"].join("\n"),fragment:[Z.shaderChunks.uniforms,F.ShaderChunk.common,F.ShaderChunk.fog_pars_fragment,F.ShaderChunk.logdepthbuf_pars_fragment,Z.shaderChunks.varyings,Z.shaderChunks.branchAvoidanceFunctions,"void main() {"," vec3 outgoingLight = vColor.xyz;"," "," #ifdef ALPHATEST"," if ( vColor.w < float(ALPHATEST) ) discard;"," #endif",Z.shaderChunks.rotateTexture,F.ShaderChunk.logdepthbuf_fragment," outgoingLight = vColor.xyz * rotatedTexture.xyz;"," gl_FragColor = vec4( outgoingLight.xyz, rotatedTexture.w * vColor.w );",F.ShaderChunk.fog_fragment,"}"].join("\n")},Z.utils={types:{BOOLEAN:"boolean",STRING:"string",NUMBER:"number",OBJECT:"object"},ensureTypedArg:function(t,e,r){return typeof t===e?t:r},ensureArrayTypedArg:function(t,e,r){if(Array.isArray(t)){for(var a=t.length-1;a>=0;--a)if(typeof t[a]!==e)return r;return t}return this.ensureTypedArg(t,e,r)},ensureInstanceOf:function(t,e,r){return void 0!==e&&t instanceof e?t:r},ensureArrayInstanceOf:function(t,e,r){if(Array.isArray(t)){for(var a=t.length-1;a>=0;--a)if(void 0!==e&&t[a]instanceof e==!1)return r;return t}return this.ensureInstanceOf(t,e,r)},ensureValueOverLifetimeCompliance:function(t,e,r){e=e||3,r=r||3,!1===Array.isArray(t._value)&&(t._value=[t._value]),!1===Array.isArray(t._spread)&&(t._spread=[t._spread]);var a=this.clamp(t._value.length,e,r),A=this.clamp(t._spread.length,e,r),s=Math.max(a,A);t._value.length!==s&&(t._value=this.interpolateArray(t._value,s)),t._spread.length!==s&&(t._spread=this.interpolateArray(t._spread,s))},interpolateArray:function(t,e){for(var r=t.length,a=["function"==typeof t[0].clone?t[0].clone():t[0]],A=(r-1)/(e-1),s=1;s<e-1;++s){var i=s*A,o=Math.floor(i),n=Math.ceil(i),l=i-o;a[s]=this.lerpTypeAgnostic(t[o],t[n],l)}return a.push("function"==typeof t[r-1].clone?t[r-1].clone():t[r-1]),a},clamp:function(t,e,r){return Math.max(e,Math.min(t,r))},zeroToEpsilon:function(t,e){var r=1e-5,a=t;return a=e?Math.random()*r*10:r,t<0&&t>-1e-5&&(a=-a),a},lerpTypeAgnostic:function(t,e,r){var a,A=this.types;return typeof t===A.NUMBER&&typeof e===A.NUMBER?t+(e-t)*r:t instanceof F.Vector2&&e instanceof F.Vector2?((a=t.clone()).x=this.lerp(t.x,e.x,r),a.y=this.lerp(t.y,e.y,r),a):t instanceof F.Vector3&&e instanceof F.Vector3?((a=t.clone()).x=this.lerp(t.x,e.x,r),a.y=this.lerp(t.y,e.y,r),a.z=this.lerp(t.z,e.z,r),a):t instanceof F.Vector4&&e instanceof F.Vector4?((a=t.clone()).x=this.lerp(t.x,e.x,r),a.y=this.lerp(t.y,e.y,r),a.z=this.lerp(t.z,e.z,r),a.w=this.lerp(t.w,e.w,r),a):t instanceof F.Color&&e instanceof F.Color?((a=t.clone()).r=this.lerp(t.r,e.r,r),a.g=this.lerp(t.g,e.g,r),a.b=this.lerp(t.b,e.b,r),a):void console.warn("Invalid argument types, or argument types do not match:",t,e)},lerp:function(t,e,r){return t+(e-t)*r},roundToNearestMultiple:function(t,e){var r;return 0===e||0===(r=Math.abs(t)%e)?t:t<0?-(Math.abs(t)-r):t+e-r},arrayValuesAreEqual:function(t){for(var e=0;e<t.length-1;++e)if(t[e]!==t[e+1])return!1;return!0},randomFloat:function(t,e){return t+e*(Math.random()-.5)},randomVector3:function(t,e,r,a,A){var s=r.x+(Math.random()*a.x-.5*a.x),i=r.y+(Math.random()*a.y-.5*a.y),o=r.z+(Math.random()*a.z-.5*a.z);A&&(s=.5*-A.x+this.roundToNearestMultiple(s,A.x),i=.5*-A.y+this.roundToNearestMultiple(i,A.y),o=.5*-A.z+this.roundToNearestMultiple(o,A.z)),t.typedArray.setVec3Components(e,s,i,o)},randomColor:function(t,e,r,a){var A=r.r+Math.random()*a.x,s=r.g+Math.random()*a.y,i=r.b+Math.random()*a.z;A=this.clamp(A,0,1),s=this.clamp(s,0,1),i=this.clamp(i,0,1),t.typedArray.setVec3Components(e,A,s,i)},randomColorAsHex:(X=new F.Color,function(t,e,r,a){for(var A=r.length,s=[],i=0;i<A;++i){var o=a[i];X.copy(r[i]),X.r+=Math.random()*o.x-.5*o.x,X.g+=Math.random()*o.y-.5*o.y,X.b+=Math.random()*o.z-.5*o.z,X.r=this.clamp(X.r,0,1),X.g=this.clamp(X.g,0,1),X.b=this.clamp(X.b,0,1),s.push(X.getHex())}t.typedArray.setVec4Components(e,s[0],s[1],s[2],s[3])}),randomVector3OnLine:function(t,e,r,a){var A=r.clone();A.lerp(a,Math.random()),t.typedArray.setVec3Components(e,A.x,A.y,A.z)},randomVector3OnSphere:function(t,e,r,a,A,s,i,o){var n=2*Math.random()-1,l=6.2832*Math.random(),p=Math.sqrt(1-n*n),y=this.randomFloat(a,A),u=0,k=0,S=0;i&&(y=Math.round(y/i)*i),u=p*Math.cos(l)*y,k=p*Math.sin(l)*y,S=n*y,u*=s.x,k*=s.y,S*=s.z,u+=r.x,k+=r.y,S+=r.z,t.typedArray.setVec3Components(e,u,k,S)},seededRandom:function(t){var e=1e4*Math.sin(t);return e-(0|e)},randomVector3OnDisc:function(t,e,r,a,A,s,i){var o=6.2832*Math.random(),n=Math.abs(this.randomFloat(a,A)),l=0,p=0,y=0;i&&(n=Math.round(n/i)*i),l=Math.cos(o)*n,p=Math.sin(o)*n,l*=s.x,p*=s.y,l+=r.x,p+=r.y,y+=r.z,t.typedArray.setVec3Components(e,l,p,y)},randomDirectionVector3OnSphere:(f=new F.Vector3,function(t,e,r,a,A,s,i,o){f.copy(s),f.x-=r,f.y-=a,f.z-=A,f.normalize().multiplyScalar(-this.randomFloat(i,o)),t.typedArray.setVec3Components(e,f.x,f.y,f.z)}),randomDirectionVector3OnDisc:function(){var t=new F.Vector3;return function(e,r,a,A,s,i,o,n){t.copy(i),t.x-=a,t.y-=A,t.z-=s,t.normalize().multiplyScalar(-this.randomFloat(o,n)),e.typedArray.setVec3Components(r,t.x,t.y,0)}}(),getPackedRotationAxis:function(){var t=new F.Vector3,e=new F.Vector3,r=new F.Color,a=new F.Vector3(1,1,1);return function(A,s){return t.copy(A).normalize(),e.copy(s).normalize(),t.x+=.5*-s.x+Math.random()*s.x,t.y+=.5*-s.y+Math.random()*s.y,t.z+=.5*-s.z+Math.random()*s.z,t.normalize().add(a).multiplyScalar(.5),r.setRGB(t.x,t.y,t.z),r.getHex()}}()},Z.Group=function(t){var e=Z.utils,r=e.types;(t=e.ensureTypedArg(t,r.OBJECT,{})).texture=e.ensureTypedArg(t.texture,r.OBJECT,{}),this.uuid=F.MathUtils.generateUUID(),this.fixedTimeStep=e.ensureTypedArg(t.fixedTimeStep,r.NUMBER,.016),this.texture=e.ensureInstanceOf(t.texture.value,F.Texture,null),this.textureFrames=e.ensureInstanceOf(t.texture.frames,F.Vector2,new F.Vector2(1,1)),this.textureFrameCount=e.ensureTypedArg(t.texture.frameCount,r.NUMBER,this.textureFrames.x*this.textureFrames.y),this.textureLoop=e.ensureTypedArg(t.texture.loop,r.NUMBER,1),this.textureFrames.max(new F.Vector2(1,1)),this.hasPerspective=e.ensureTypedArg(t.hasPerspective,r.BOOLEAN,!0),this.colorize=e.ensureTypedArg(t.colorize,r.BOOLEAN,!0),this.maxParticleCount=e.ensureTypedArg(t.maxParticleCount,r.NUMBER,null),this.blending=e.ensureTypedArg(t.blending,r.NUMBER,F.AdditiveBlending),this.transparent=e.ensureTypedArg(t.transparent,r.BOOLEAN,!0),this.alphaTest=parseFloat(e.ensureTypedArg(t.alphaTest,r.NUMBER,0)),this.depthWrite=e.ensureTypedArg(t.depthWrite,r.BOOLEAN,!1),this.depthTest=e.ensureTypedArg(t.depthTest,r.BOOLEAN,!0),this.fog=e.ensureTypedArg(t.fog,r.BOOLEAN,!0),this.scale=e.ensureTypedArg(t.scale,r.NUMBER,300),this.emitters=[],this.emitterIDs=[],this._pool=[],this._poolCreationSettings=null,this._createNewWhenPoolEmpty=0,this._attributesNeedRefresh=!1,this._attributesNeedDynamicReset=!1,this.particleCount=0,this.uniforms={tex:{type:"t",value:this.texture},textureAnimation:{type:"v4",value:new F.Vector4(this.textureFrames.x,this.textureFrames.y,this.textureFrameCount,Math.max(Math.abs(this.textureLoop),1))},fogColor:{type:"c",value:this.fog?new F.Color:null},fogNear:{type:"f",value:10},fogFar:{type:"f",value:200},fogDensity:{type:"f",value:.5},deltaTime:{type:"f",value:0},runTime:{type:"f",value:0},scale:{type:"f",value:this.scale}},this.defines={HAS_PERSPECTIVE:this.hasPerspective,COLORIZE:this.colorize,VALUE_OVER_LIFETIME_LENGTH:Z.valueOverLifetimeLength,SHOULD_ROTATE_TEXTURE:!1,SHOULD_ROTATE_PARTICLES:!1,SHOULD_WIGGLE_PARTICLES:!1,SHOULD_CALCULATE_SPRITE:this.textureFrames.x>1||this.textureFrames.y>1},this.attributes={position:new Z.ShaderAttribute("v3",!0),acceleration:new Z.ShaderAttribute("v4",!0),velocity:new Z.ShaderAttribute("v3",!0),rotation:new Z.ShaderAttribute("v4",!0),rotationCenter:new Z.ShaderAttribute("v3",!0),params:new Z.ShaderAttribute("v4",!0),size:new Z.ShaderAttribute("v4",!0),angle:new Z.ShaderAttribute("v4",!0),color:new Z.ShaderAttribute("v4",!0),opacity:new Z.ShaderAttribute("v4",!0)},this.attributeKeys=Object.keys(this.attributes),this.attributeCount=this.attributeKeys.length,this.material=new F.ShaderMaterial({uniforms:this.uniforms,vertexShader:Z.shaders.vertex,fragmentShader:Z.shaders.fragment,blending:this.blending,transparent:this.transparent,alphaTest:this.alphaTest,depthWrite:this.depthWrite,depthTest:this.depthTest,defines:this.defines,fog:this.fog}),this.geometry=new F.BufferGeometry,this.mesh=new F.Points(this.geometry,this.material),null===this.maxParticleCount&&console.warn("SPE.Group: No maxParticleCount specified. Adding emitters after rendering will probably cause errors.")},Z.Group.constructor=Z.Group,Z.Group.prototype._updateDefines=function(){for(var t,e=this.emitters,r=e.length-1,a=this.defines;r>=0;--r)t=e[r],a.SHOULD_CALCULATE_SPRITE||(a.SHOULD_ROTATE_TEXTURE=a.SHOULD_ROTATE_TEXTURE||!!Math.max(Math.max.apply(null,t.angle.value),Math.max.apply(null,t.angle.spread))),a.SHOULD_ROTATE_PARTICLES=a.SHOULD_ROTATE_PARTICLES||!!Math.max(t.rotation.angle,t.rotation.angleSpread),a.SHOULD_WIGGLE_PARTICLES=a.SHOULD_WIGGLE_PARTICLES||!!Math.max(t.wiggle.value,t.wiggle.spread);this.material.needsUpdate=!0},Z.Group.prototype._applyAttributesToGeometry=function(){var t,e,r=this.attributes,a=this.geometry,A=a.attributes;for(var s in r)r.hasOwnProperty(s)&&(t=r[s],(e=A[s])?e.array=t.typedArray.array:a.setAttribute(s,t.bufferAttribute),t.bufferAttribute.needsUpdate=!0);this.geometry.setDrawRange(0,this.particleCount)},Z.Group.prototype.addEmitter=function(t){if(t instanceof Z.Emitter!=!1)if(this.emitterIDs.indexOf(t.uuid)>-1)console.error("Emitter already exists in this group. Will not add again.");else{if(null===t.group){var e=this.attributes,r=this.particleCount,a=r+t.particleCount;for(var A in this.particleCount=a,null!==this.maxParticleCount&&this.particleCount>this.maxParticleCount&&console.warn("SPE.Group: maxParticleCount exceeded. Requesting",this.particleCount,"particles, can support only",this.maxParticleCount),t._calculatePPSValue(t.maxAge._value+t.maxAge._spread),t._setBufferUpdateRanges(this.attributeKeys),t._setAttributeOffset(r),t.group=this,t.attributes=this.attributes,e)e.hasOwnProperty(A)&&e[A]._createBufferAttribute(null!==this.maxParticleCount?this.maxParticleCount:this.particleCount);for(var s=r;s<a;++s)t._assignPositionValue(s),t._assignForceValue(s,"velocity"),t._assignForceValue(s,"acceleration"),t._assignAbsLifetimeValue(s,"opacity"),t._assignAbsLifetimeValue(s,"size"),t._assignAngleValue(s),t._assignRotationValue(s),t._assignParamsValue(s),t._assignColorValue(s);return this._applyAttributesToGeometry(),this.emitters.push(t),this.emitterIDs.push(t.uuid),this._updateDefines(t),this.material.needsUpdate=!0,this.geometry.needsUpdate=!0,this._attributesNeedRefresh=!0,this}console.error("Emitter already belongs to another group. Will not add to requested group.")}else console.error("`emitter` argument must be instance of SPE.Emitter. Was provided with:",t)},Z.Group.prototype.removeEmitter=function(t){var e=this.emitterIDs.indexOf(t.uuid);if(t instanceof Z.Emitter!=!1)if(-1!==e){for(var r=t.attributeOffset,a=r+t.particleCount,A=this.attributes.params.typedArray,s=r;s<a;++s)A.array[4*s]=0,A.array[4*s+1]=0;for(var i in this.emitters.splice(e,1),this.emitterIDs.splice(e,1),this.attributes)this.attributes.hasOwnProperty(i)&&this.attributes[i].splice(r,a);this.particleCount-=t.particleCount,t._onRemove(),this._attributesNeedRefresh=!0}else console.error("Emitter does not exist in this group. Will not remove.");else console.error("`emitter` argument must be instance of SPE.Emitter. Was provided with:",t)},Z.Group.prototype.getFromPool=function(){var t=this._pool,e=this._createNewWhenPoolEmpty;if(t.length)return t.pop();if(e){var r=new Z.Emitter(this._poolCreationSettings);return this.addEmitter(r),r}return null},Z.Group.prototype.releaseIntoPool=function(t){if(t instanceof Z.Emitter!=!1)return t.reset(),this._pool.unshift(t),this;console.error("Argument is not instanceof SPE.Emitter:",t)},Z.Group.prototype.getPool=function(){return this._pool},Z.Group.prototype.addPool=function(t,e,r){var a;this._poolCreationSettings=e,this._createNewWhenPoolEmpty=!!r;for(var A=0;A<t;++A)a=Array.isArray(e)?new Z.Emitter(e[A]):new Z.Emitter(e),this.addEmitter(a),this.releaseIntoPool(a);return this},Z.Group.prototype._triggerSingleEmitter=function(t){var e=this.getFromPool(),r=this;if(null!==e)return t instanceof F.Vector3&&(e.position.value.copy(t),e.position.value=e.position.value),e.enable(),setTimeout((function(){e.disable(),r.releaseIntoPool(e)}),1e3*Math.max(e.duration,e.maxAge.value+e.maxAge.spread)),this;console.log("SPE.Group pool ran out.")},Z.Group.prototype.triggerPoolEmitter=function(t,e){if("number"==typeof t&&t>1)for(var r=0;r<t;++r)this._triggerSingleEmitter(e);else this._triggerSingleEmitter(e);return this},Z.Group.prototype._updateUniforms=function(t){this.uniforms.runTime.value+=t,this.uniforms.deltaTime.value=t},Z.Group.prototype._resetBufferRanges=function(){for(var t=this.attributeKeys,e=this.attributeCount-1,r=this.attributes;e>=0;--e)r[t[e]].resetUpdateRange()},Z.Group.prototype._updateBuffers=function(t){for(var e,r,a,A=this.attributeKeys,s=this.attributeCount-1,i=this.attributes,o=t.bufferUpdateRanges;s>=0;--s)r=o[e=A[s]],(a=i[e]).setUpdateRange(r.min,r.max),a.flagUpdate()},Z.Group.prototype.tick=function(t){var e=this.emitters,r=e.length,a=t||this.fixedTimeStep,A=this.attributeKeys,s=this.attributes;if(this._updateUniforms(a),this._resetBufferRanges(),0!==r||!1!==this._attributesNeedRefresh||!1!==this._attributesNeedDynamicReset){for(var i,o=0;o<r;++o)(i=e[o]).tick(a),this._updateBuffers(i);if(!0===this._attributesNeedDynamicReset){for(o=this.attributeCount-1;o>=0;--o)s[A[o]].resetDynamic();this._attributesNeedDynamicReset=!1}if(!0===this._attributesNeedRefresh){for(o=this.attributeCount-1;o>=0;--o)s[A[o]].forceUpdateAll();this._attributesNeedRefresh=!1,this._attributesNeedDynamicReset=!0}}},Z.Group.prototype.dispose=function(){return this.geometry.dispose(),this.material.dispose(),this},Z.Emitter=function(t){var e=Z.utils,r=e.types,a=Z.valueOverLifetimeLength;for(var A in(t=e.ensureTypedArg(t,r.OBJECT,{})).position=e.ensureTypedArg(t.position,r.OBJECT,{}),t.velocity=e.ensureTypedArg(t.velocity,r.OBJECT,{}),t.acceleration=e.ensureTypedArg(t.acceleration,r.OBJECT,{}),t.radius=e.ensureTypedArg(t.radius,r.OBJECT,{}),t.drag=e.ensureTypedArg(t.drag,r.OBJECT,{}),t.rotation=e.ensureTypedArg(t.rotation,r.OBJECT,{}),t.color=e.ensureTypedArg(t.color,r.OBJECT,{}),t.opacity=e.ensureTypedArg(t.opacity,r.OBJECT,{}),t.size=e.ensureTypedArg(t.size,r.OBJECT,{}),t.angle=e.ensureTypedArg(t.angle,r.OBJECT,{}),t.wiggle=e.ensureTypedArg(t.wiggle,r.OBJECT,{}),t.maxAge=e.ensureTypedArg(t.maxAge,r.OBJECT,{}),t.onParticleSpawn&&console.warn("onParticleSpawn has been removed. Please set properties directly to alter values at runtime."),this.uuid=F.MathUtils.generateUUID(),this.type=e.ensureTypedArg(t.type,r.NUMBER,Z.distributions.BOX),this.position={_value:e.ensureInstanceOf(t.position.value,F.Vector3,new F.Vector3),_spread:e.ensureInstanceOf(t.position.spread,F.Vector3,new F.Vector3),_spreadClamp:e.ensureInstanceOf(t.position.spreadClamp,F.Vector3,new F.Vector3),_distribution:e.ensureTypedArg(t.position.distribution,r.NUMBER,this.type),_randomise:e.ensureTypedArg(t.position.randomise,r.BOOLEAN,!1),_radius:e.ensureTypedArg(t.position.radius,r.NUMBER,10),_radiusScale:e.ensureInstanceOf(t.position.radiusScale,F.Vector3,new F.Vector3(1,1,1)),_distributionClamp:e.ensureTypedArg(t.position.distributionClamp,r.NUMBER,0)},this.velocity={_value:e.ensureInstanceOf(t.velocity.value,F.Vector3,new F.Vector3),_spread:e.ensureInstanceOf(t.velocity.spread,F.Vector3,new F.Vector3),_distribution:e.ensureTypedArg(t.velocity.distribution,r.NUMBER,this.type),_randomise:e.ensureTypedArg(t.position.randomise,r.BOOLEAN,!1)},this.acceleration={_value:e.ensureInstanceOf(t.acceleration.value,F.Vector3,new F.Vector3),_spread:e.ensureInstanceOf(t.acceleration.spread,F.Vector3,new F.Vector3),_distribution:e.ensureTypedArg(t.acceleration.distribution,r.NUMBER,this.type),_randomise:e.ensureTypedArg(t.position.randomise,r.BOOLEAN,!1)},this.drag={_value:e.ensureTypedArg(t.drag.value,r.NUMBER,0),_spread:e.ensureTypedArg(t.drag.spread,r.NUMBER,0),_randomise:e.ensureTypedArg(t.position.randomise,r.BOOLEAN,!1)},this.wiggle={_value:e.ensureTypedArg(t.wiggle.value,r.NUMBER,0),_spread:e.ensureTypedArg(t.wiggle.spread,r.NUMBER,0)},this.rotation={_axis:e.ensureInstanceOf(t.rotation.axis,F.Vector3,new F.Vector3(0,1,0)),_axisSpread:e.ensureInstanceOf(t.rotation.axisSpread,F.Vector3,new F.Vector3),_angle:e.ensureTypedArg(t.rotation.angle,r.NUMBER,0),_angleSpread:e.ensureTypedArg(t.rotation.angleSpread,r.NUMBER,0),_static:e.ensureTypedArg(t.rotation.static,r.BOOLEAN,!1),_center:e.ensureInstanceOf(t.rotation.center,F.Vector3,this.position._value.clone()),_randomise:e.ensureTypedArg(t.position.randomise,r.BOOLEAN,!1)},this.maxAge={_value:e.ensureTypedArg(t.maxAge.value,r.NUMBER,2),_spread:e.ensureTypedArg(t.maxAge.spread,r.NUMBER,0)},this.color={_value:e.ensureArrayInstanceOf(t.color.value,F.Color,new F.Color),_spread:e.ensureArrayInstanceOf(t.color.spread,F.Vector3,new F.Vector3),_randomise:e.ensureTypedArg(t.position.randomise,r.BOOLEAN,!1)},this.opacity={_value:e.ensureArrayTypedArg(t.opacity.value,r.NUMBER,1),_spread:e.ensureArrayTypedArg(t.opacity.spread,r.NUMBER,0),_randomise:e.ensureTypedArg(t.position.randomise,r.BOOLEAN,!1)},this.size={_value:e.ensureArrayTypedArg(t.size.value,r.NUMBER,1),_spread:e.ensureArrayTypedArg(t.size.spread,r.NUMBER,0),_randomise:e.ensureTypedArg(t.position.randomise,r.BOOLEAN,!1)},this.angle={_value:e.ensureArrayTypedArg(t.angle.value,r.NUMBER,0),_spread:e.ensureArrayTypedArg(t.angle.spread,r.NUMBER,0),_randomise:e.ensureTypedArg(t.position.randomise,r.BOOLEAN,!1)},this.particleCount=e.ensureTypedArg(t.particleCount,r.NUMBER,100),this.duration=e.ensureTypedArg(t.duration,r.NUMBER,null),this.isStatic=e.ensureTypedArg(t.isStatic,r.BOOLEAN,!1),this.activeMultiplier=e.ensureTypedArg(t.activeMultiplier,r.NUMBER,1),this.direction=e.ensureTypedArg(t.direction,r.NUMBER,1),this.alive=e.ensureTypedArg(t.alive,r.BOOLEAN,!0),this.particlesPerSecond=0,this.activationIndex=0,this.attributeOffset=0,this.attributeEnd=0,this.age=0,this.activeParticleCount=0,this.group=null,this.attributes=null,this.paramsArray=null,this.resetFlags={position:e.ensureTypedArg(t.position.randomise,r.BOOLEAN,!1)||e.ensureTypedArg(t.radius.randomise,r.BOOLEAN,!1),velocity:e.ensureTypedArg(t.velocity.randomise,r.BOOLEAN,!1),acceleration:e.ensureTypedArg(t.acceleration.randomise,r.BOOLEAN,!1)||e.ensureTypedArg(t.drag.randomise,r.BOOLEAN,!1),rotation:e.ensureTypedArg(t.rotation.randomise,r.BOOLEAN,!1),rotationCenter:e.ensureTypedArg(t.rotation.randomise,r.BOOLEAN,!1),size:e.ensureTypedArg(t.size.randomise,r.BOOLEAN,!1),color:e.ensureTypedArg(t.color.randomise,r.BOOLEAN,!1),opacity:e.ensureTypedArg(t.opacity.randomise,r.BOOLEAN,!1),angle:e.ensureTypedArg(t.angle.randomise,r.BOOLEAN,!1)},this.updateFlags={},this.updateCounts={},this.updateMap={maxAge:"params",position:"position",velocity:"velocity",acceleration:"acceleration",drag:"acceleration",wiggle:"params",rotation:"rotation",size:"size",color:"color",opacity:"opacity",angle:"angle"},this.updateMap)this.updateMap.hasOwnProperty(A)&&(this.updateCounts[this.updateMap[A]]=0,this.updateFlags[this.updateMap[A]]=!1,this._createGetterSetters(this[A],A));this.bufferUpdateRanges={},this.attributeKeys=null,this.attributeCount=0,e.ensureValueOverLifetimeCompliance(this.color,a,a),e.ensureValueOverLifetimeCompliance(this.opacity,a,a),e.ensureValueOverLifetimeCompliance(this.size,a,a),e.ensureValueOverLifetimeCompliance(this.angle,a,a)},Z.Emitter.constructor=Z.Emitter,Z.Emitter.prototype._createGetterSetters=function(t,e){var r=this;for(var a in t)if(t.hasOwnProperty(a)){var A=a.replace("_","");Object.defineProperty(t,A,{get:function(t){return function(){return this[t]}}(a),set:function(t){return function(a){var A=r.updateMap[e],s=this[t],i=Z.valueOverLifetimeLength;"_rotationCenter"===t?(r.updateFlags.rotationCenter=!0,r.updateCounts.rotationCenter=0):"_randomise"===t?r.resetFlags[A]=a:(r.updateFlags[A]=!0,r.updateCounts[A]=0),r.group._updateDefines(),this[t]=a,Array.isArray(s)&&Z.utils.ensureValueOverLifetimeCompliance(r[e],i,i)}}(a)})}},Z.Emitter.prototype._setBufferUpdateRanges=function(t){this.attributeKeys=t,this.attributeCount=t.length;for(var e=this.attributeCount-1;e>=0;--e)this.bufferUpdateRanges[t[e]]={min:Number.POSITIVE_INFINITY,max:Number.NEGATIVE_INFINITY}},Z.Emitter.prototype._calculatePPSValue=function(t){var e=this.particleCount;this.duration?this.particlesPerSecond=e/(t<this.duration?t:this.duration):this.particlesPerSecond=e/t},Z.Emitter.prototype._setAttributeOffset=function(t){this.attributeOffset=t,this.activationIndex=t,this.activationEnd=t+this.particleCount},Z.Emitter.prototype._assignValue=function(t,e){switch(t){case"position":this._assignPositionValue(e);break;case"velocity":case"acceleration":this._assignForceValue(e,t);break;case"size":case"opacity":this._assignAbsLifetimeValue(e,t);break;case"angle":this._assignAngleValue(e);break;case"params":this._assignParamsValue(e);break;case"rotation":this._assignRotationValue(e);break;case"color":this._assignColorValue(e)}},Z.Emitter.prototype._assignPositionValue=function(t){var e=Z.distributions,r=Z.utils,a=this.position,A=this.attributes.position,s=a._value,i=a._spread;switch(a._distribution){case e.BOX:r.randomVector3(A,t,s,i,a._spreadClamp);break;case e.SPHERE:r.randomVector3OnSphere(A,t,s,a._radius,a._spread.x,a._radiusScale,a._spreadClamp.x,a._distributionClamp||this.particleCount);break;case e.DISC:r.randomVector3OnDisc(A,t,s,a._radius,a._spread.x,a._radiusScale,a._spreadClamp.x);break;case e.LINE:r.randomVector3OnLine(A,t,s,i)}},Z.Emitter.prototype._assignForceValue=function(t,e){var r,a,A,s,i,o=Z.distributions,n=Z.utils,l=this[e],p=l._value,y=l._spread;switch(l._distribution){case o.BOX:n.randomVector3(this.attributes[e],t,p,y);break;case o.SPHERE:a=(r=this.attributes.position.typedArray.array)[i=3*t],A=r[i+1],s=r[i+2],n.randomDirectionVector3OnSphere(this.attributes[e],t,a,A,s,this.position._value,l._value.x,l._spread.x);break;case o.DISC:a=(r=this.attributes.position.typedArray.array)[i=3*t],A=r[i+1],s=r[i+2],n.randomDirectionVector3OnDisc(this.attributes[e],t,a,A,s,this.position._value,l._value.x,l._spread.x);break;case o.LINE:n.randomVector3OnLine(this.attributes[e],t,p,y)}if("acceleration"===e){var u=n.clamp(n.randomFloat(this.drag._value,this.drag._spread),0,1);this.attributes.acceleration.typedArray.array[4*t+3]=u}},Z.Emitter.prototype._assignAbsLifetimeValue=function(t,e){var r,a=this.attributes[e].typedArray,A=this[e],s=Z.utils;s.arrayValuesAreEqual(A._value)&&s.arrayValuesAreEqual(A._spread)?(r=Math.abs(s.randomFloat(A._value[0],A._spread[0])),a.setVec4Components(t,r,r,r,r)):a.setVec4Components(t,Math.abs(s.randomFloat(A._value[0],A._spread[0])),Math.abs(s.randomFloat(A._value[1],A._spread[1])),Math.abs(s.randomFloat(A._value[2],A._spread[2])),Math.abs(s.randomFloat(A._value[3],A._spread[3])))},Z.Emitter.prototype._assignAngleValue=function(t){var e,r=this.attributes.angle.typedArray,a=this.angle,A=Z.utils;A.arrayValuesAreEqual(a._value)&&A.arrayValuesAreEqual(a._spread)?(e=A.randomFloat(a._value[0],a._spread[0]),r.setVec4Components(t,e,e,e,e)):r.setVec4Components(t,A.randomFloat(a._value[0],a._spread[0]),A.randomFloat(a._value[1],a._spread[1]),A.randomFloat(a._value[2],a._spread[2]),A.randomFloat(a._value[3],a._spread[3]))},Z.Emitter.prototype._assignParamsValue=function(t){this.attributes.params.typedArray.setVec4Components(t,this.isStatic?1:0,0,Math.abs(Z.utils.randomFloat(this.maxAge._value,this.maxAge._spread)),Z.utils.randomFloat(this.wiggle._value,this.wiggle._spread))},Z.Emitter.prototype._assignRotationValue=function(t){this.attributes.rotation.typedArray.setVec3Components(t,Z.utils.getPackedRotationAxis(this.rotation._axis,this.rotation._axisSpread),Z.utils.randomFloat(this.rotation._angle,this.rotation._angleSpread),this.rotation._static?0:1),this.attributes.rotationCenter.typedArray.setVec3(t,this.rotation._center)},Z.Emitter.prototype._assignColorValue=function(t){Z.utils.randomColorAsHex(this.attributes.color,t,this.color._value,this.color._spread)},Z.Emitter.prototype._resetParticle=function(t){for(var e,r,a=this.resetFlags,A=this.updateFlags,s=this.updateCounts,i=this.attributeKeys,o=this.attributeCount-1;o>=0;--o)r=A[e=i[o]],!0!==a[e]&&!0!==r||(this._assignValue(e,t),this._updateAttributeUpdateRange(e,t),!0===r&&s[e]===this.particleCount?(A[e]=!1,s[e]=0):1==r&&++s[e])},Z.Emitter.prototype._updateAttributeUpdateRange=function(t,e){var r=this.bufferUpdateRanges[t];r.min=Math.min(e,r.min),r.max=Math.max(e,r.max)},Z.Emitter.prototype._resetBufferRanges=function(){for(var t,e=this.bufferUpdateRanges,r=this.bufferUpdateKeys,a=this.bufferUpdateCount-1;a>=0;--a)e[t=r[a]].min=Number.POSITIVE_INFINITY,e[t].max=Number.NEGATIVE_INFINITY},Z.Emitter.prototype._onRemove=function(){this.particlesPerSecond=0,this.attributeOffset=0,this.activationIndex=0,this.activeParticleCount=0,this.group=null,this.attributes=null,this.paramsArray=null,this.age=0},Z.Emitter.prototype._decrementParticleCount=function(){--this.activeParticleCount},Z.Emitter.prototype._incrementParticleCount=function(){++this.activeParticleCount},Z.Emitter.prototype._checkParticleAges=function(t,e,r,a){for(var A,s,i,o,n=e-1;n>=t;--n)0!==(o=r[A=4*n])&&(i=r[A+1],s=r[A+2],1===this.direction?(i+=a)>=s&&(i=0,o=0,this._decrementParticleCount()):(i-=a)<=0&&(i=s,o=0,this._decrementParticleCount()),r[A]=o,r[A+1]=i,this._updateAttributeUpdateRange("params",n))},Z.Emitter.prototype._activateParticles=function(t,e,r,a){for(var A,s,i=this.direction,o=t;o<e;++o)0!=r[A=4*o]&&1!==this.particleCount||(this._incrementParticleCount(),r[A]=1,this._resetParticle(o),s=a*(o-t),r[A+1]=-1===i?r[A+2]-s:s,this._updateAttributeUpdateRange("params",o))},Z.Emitter.prototype.tick=function(t){if(!this.isStatic){null===this.paramsArray&&(this.paramsArray=this.attributes.params.typedArray.array);var e=this.attributeOffset,r=e+this.particleCount,a=this.paramsArray,A=this.particlesPerSecond*this.activeMultiplier*t,s=this.activationIndex;if(this._resetBufferRanges(),this._checkParticleAges(e,r,a,t),!1!==this.alive){if(null!==this.duration&&this.age>this.duration)return this.alive=!1,void(this.age=0);var i=1===this.particleCount?s:0|s,o=Math.min(i+A,this.activationEnd),n=o-this.activationIndex|0,l=n>0?t/n:0;this._activateParticles(i,o,a,l),this.activationIndex+=A,this.activationIndex>r&&(this.activationIndex=e),this.age+=t}else this.age=0}},Z.Emitter.prototype.reset=function(t){if(this.age=0,this.alive=!1,!0===t){for(var e,r=this.attributeOffset,a=r+this.particleCount,A=this.paramsArray,s=this.attributes.params.bufferAttribute,i=a-1;i>=r;--i)A[e=4*i]=0,A[e+1]=0;s.updateRange.offset=0,s.updateRange.count=-1,s.needsUpdate=!0}return this},Z.Emitter.prototype.enable=function(){return this.alive=!0,this},Z.Emitter.prototype.disable=function(){return this.alive=!1,this},Z.Emitter.prototype.remove=function(){return null!==this.group?this.group.removeEmitter(this):console.error("Emitter does not belong to a group, cannot remove."),this};var G="",Q={vertexShader:"\n #include <common>\n #include <logdepthbuf_pars_vertex>\n uniform float pixelRatio;\n uniform float time;\n attribute float size; \n attribute float speed; \n attribute float opacity;\n attribute vec3 noise;\n attribute vec3 color;\n varying vec3 vColor;\n varying float vOpacity;\n void main() {\n vec4 modelPosition = modelMatrix * vec4(position, 1.0);\n modelPosition.y += sin(time * speed + modelPosition.x * noise.x * 100.0) * 0.2;\n modelPosition.z += cos(time * speed + modelPosition.x * noise.y * 100.0) * 0.2;\n modelPosition.x += cos(time * speed + modelPosition.x * noise.z * 100.0) * 0.2;\n vec4 viewPosition = viewMatrix * modelPosition;\n vec4 projectionPostion = projectionMatrix * viewPosition;\n gl_Position = projectionPostion;\n gl_PointSize = size * 25. * pixelRatio;\n gl_PointSize *= (1.0 / - viewPosition.z);\n vColor = color;\n vOpacity = opacity;\n\n\t #include <logdepthbuf_vertex>\n }",fragmentShader:"\n #include <common>\n #include <logdepthbuf_pars_fragment>\n varying vec3 vColor;\n varying float vOpacity;\n void main() {\n float distanceToCenter = distance(gl_PointCoord, vec2(0.5));\n float strength = 0.05 / distanceToCenter - 0.1;\n gl_FragColor = vec4(vColor, strength * vOpacity);\n #include <tonemapping_fragment>\n #include <encodings_fragment>\n #include <logdepthbuf_fragment>\n }"};const E=t=>t&&t.constructor===Float32Array,D=t=>void 0!==(null==t?void 0:t.x)&&void 0!==(null==t?void 0:t.y)&&void 0!==(null==t?void 0:t.z),w=t=>Array.isArray(t)?t:D(t)?[t.x,t.y,t.z]:[t,t,t];function O(e,r,a){if(void 0!==r){if(E(r))return r;if(r instanceof t){const t=Array.from({length:3*e},(()=>(t=>[t.r,t.g,t.b])(r))).flat();return Float32Array.from(t)}if(D(r)||Array.isArray(r)){const t=Array.from({length:3*e},(()=>w(r))).flat();return Float32Array.from(t)}return Float32Array.from({length:e},(()=>r))}return Float32Array.from({length:e},a)}const M={uniforms:{tDiffuse:{value:null},h:{value:1/512}},vertexShader:"\n\n\t\tvarying vec2 vUv;\n\n\t\tvoid main() {\n\n\t\t\tvUv = uv;\n\t\t\tgl_Position = projectionMatrix * modelViewMatrix * vec4( position, 1.0 );\n\n\t\t}",fragmentShader:"\n\n\t\tuniform sampler2D tDiffuse;\n\t\tuniform float h;\n\n\t\tvarying vec2 vUv;\n\n\t\tvoid main() {\n\n\t\t\tvec4 sum = vec4( 0.0 );\n\n\t\t\tsum += texture2D( tDiffuse, vec2( vUv.x - 4.0 * h, vUv.y ) ) * 0.051;\n\t\t\tsum += texture2D( tDiffuse, vec2( vUv.x - 3.0 * h, vUv.y ) ) * 0.0918;\n\t\t\tsum += texture2D( tDiffuse, vec2( vUv.x - 2.0 * h, vUv.y ) ) * 0.12245;\n\t\t\tsum += texture2D( tDiffuse, vec2( vUv.x - 1.0 * h, vUv.y ) ) * 0.1531;\n\t\t\tsum += texture2D( tDiffuse, vec2( vUv.x, vUv.y ) ) * 0.1633;\n\t\t\tsum += texture2D( tDiffuse, vec2( vUv.x + 1.0 * h, vUv.y ) ) * 0.1531;\n\t\t\tsum += texture2D( tDiffuse, vec2( vUv.x + 2.0 * h, vUv.y ) ) * 0.12245;\n\t\t\tsum += texture2D( tDiffuse, vec2( vUv.x + 3.0 * h, vUv.y ) ) * 0.0918;\n\t\t\tsum += texture2D( tDiffuse, vec2( vUv.x + 4.0 * h, vUv.y ) ) * 0.051;\n\n\t\t\tgl_FragColor = sum;\n\n\t\t}"},P={uniforms:{tDiffuse:{value:null},v:{value:1/512}},vertexShader:"\n\n\t\tvarying vec2 vUv;\n\n\t\tvoid main() {\n\n\t\t\tvUv = uv;\n\t\t\tgl_Position = projectionMatrix * modelViewMatrix * vec4( position, 1.0 );\n\n\t\t}",fragmentShader:"\n\n\t\tuniform sampler2D tDiffuse;\n\t\tuniform float v;\n\n\t\tvarying vec2 vUv;\n\n\t\tvoid main() {\n\n\t\t\tvec4 sum = vec4( 0.0 );\n\n\t\t\tsum += texture2D( tDiffuse, vec2( vUv.x, vUv.y - 4.0 * v ) ) * 0.051;\n\t\t\tsum += texture2D( tDiffuse, vec2( vUv.x, vUv.y - 3.0 * v ) ) * 0.0918;\n\t\t\tsum += texture2D( tDiffuse, vec2( vUv.x, vUv.y - 2.0 * v ) ) * 0.12245;\n\t\t\tsum += texture2D( tDiffuse, vec2( vUv.x, vUv.y - 1.0 * v ) ) * 0.1531;\n\t\t\tsum += texture2D( tDiffuse, vec2( vUv.x, vUv.y ) ) * 0.1633;\n\t\t\tsum += texture2D( tDiffuse, vec2( vUv.x, vUv.y + 1.0 * v ) ) * 0.1531;\n\t\t\tsum += texture2D( tDiffuse, vec2( vUv.x, vUv.y + 2.0 * v ) ) * 0.12245;\n\t\t\tsum += texture2D( tDiffuse, vec2( vUv.x, vUv.y + 3.0 * v ) ) * 0.0918;\n\t\t\tsum += texture2D( tDiffuse, vec2( vUv.x, vUv.y + 4.0 * v ) ) * 0.051;\n\n\t\t\tgl_FragColor = sum;\n\n\t\t}"};var Y=Object.defineProperty,z=(t,e,r)=>(((t,e,r)=>{e in t?Y(t,e,{enumerable:!0,configurable:!0,writable:!0,value:r}):t[e]=r})(t,"symbol"!=typeof e?e+"":e,r),r);function _(t){return void 0!==t.w?[e,4]:void 0!==t.z?[r,3]:[a,2]}function $(t,e,r){let a=function(t,e){const r=Math.sqrt(t.lengthSq()*e.lengthSq());if(0===r)return 0;let a=t.dot(e)/r;return a=Math.max(-1,Math.min(1,a)),Math.acos(a)}(t,e);return 0===a?a:t.clone().cross(e).dot(r)<0?-a:a}const tt=180/Math.PI,et={yaw:[{name:"前",range:[-15,15]},{name:"左",range:[15,165]},{name:"右",range:[-165,-15]},{name:"后",range:[-180.1,-165]},{name:"后",range:[165,180.1]}],pitch:[{name:"前",range:[-15,15]},{name:"上",range:[15,165]},{name:"下",range:[-165,-15]},{name:"后",range:[-180.1,-165]},{name:"后",range:[165,180.1]}],roll:[{name:"上",range:[-15,15]},{name:"左",range:[15,165]},{name:"右",range:[-165,-15]},{name:"下",range:[-180.1,-165]},{name:"下",range:[165,180.1]}]};const rt={degrees:!0,map:et,front:{x:0,y:0,z:1},up:{x:0,y:1,z:0}};let at=class{constructor(t){z(this,"_options"),z(this,"_listMap"),z(this,"_front"),z(this,"_up"),t&&(this.options=t)}static get options(){return this._options??(this.options=rt)}static set options(t){this._options=Object.assign({},structuredClone(et),t)}get defaultOptions(){return this.constructor.options}get options(){return this._options??(this.options=this.defaultOptions)}set options(t){this._options=Object.assign({},structuredClone(this.defaultOptions),t),this._listMap=null,this._front=null,this._up=null}get degrees(){return this.options.degrees??(this.options.degrees=this.defaultOptions.degrees??!0)}set degrees(t){this.options.degrees=t}get map(){return this.options.map||(this.map=this.defaultOptions.map),this.options.map}set map(t){const e=structuredClone(this.defaultOptions.map),r=structuredClone(et);t=t?{yaw:t.yaw??e.yaw??r.yaw,pitch:t.pitch??e.pitch??r.pitch,roll:t.roll??e.roll??r.roll}:e,this.options.map=t,this._listMap=null}get listMap(){return this._listMap??(this._listMap=function(t){const e={};for(const[r,a]of Object.entries(t))e[r]=Array.isArray(a)?a:Object.entries(a).map((([t,e])=>({name:t,range:e})));return e}(this.map??{}))}get front(){return this._front||(this.front=this.options.front??this.defaultOptions.front??rt.front),this._front}set front(t){this._front=(new r).copy(t)}get up(){return this._up||(this.up=this.options.up??this.defaultOptions.up??rt.up),this._up}set up(t){this._up=(new r).copy(t)}computeAzimuth(t,e,a){const A=(new r).copy(t),s=(new r).copy(e??this.front),i=(new r).copy(a??this.up);let{yaw:o,pitch:n,roll:l}=function(t,e,r){const a=e.clone().negate(),A=r.clone().projectOnPlane(e),s=$(e,t.clone().projectOnPlane(A),A),i=e.clone().cross(A);return{yaw:s,pitch:$(e,t.clone().projectOnPlane(i),i),roll:$(A,t.clone().projectOnPlane(a),a)}}(A,s,i);return this.degrees&&(o*=tt,n*=tt,l*=tt),{yaw:{angle:o,name:this.findAzimuthNames("yaw",o)},pitch:{angle:n,name:this.findAzimuthNames("pitch",n)},roll:{angle:l,name:this.findAzimuthNames("roll",l)}}}findAzimuthNames(t,e){const r=[],a=this.listMap[t];if(!a)return r;for(const{name:t,range:[A,s]}of a)(e>=A&&e<s||e<=A&&e>s)&&r.push(t);return r}};z(at,"_options"),new at,new A;var At=Object.defineProperty,st=(t,e,r)=>(((t,e,r)=>{e in t?At(t,e,{enumerable:!0,configurable:!0,writable:!0,value:r}):t[e]=r})(t,"symbol"!=typeof e?e+"":e,r),r);function it(t){const e=[];for(let r=0;r<t;r++)e.push(s.randFloatSpread(2));return e}function ot(t,e,r){const a=[],A=t-1;for(let t=0;t<A;t++){const t=2*(Math.random()-.5)*(e+r);a.push(t)}const s=Math.trunc(Math.random()*t);let i=2*(Math.random()-.5)*r;return i+=Math.sign(i)*e,a.splice(s,0,i),a}function nt(t,e){const r=[],a=t-1;for(let t=0;t<a;t++)r.push(s.randFloatSpread(2));return r.push(Math.random()*e),r}function lt(t,e,r,a){const A=[],s=t-1,i=s-1;for(let t=0;t<i;t++){const t=2*(Math.random()-.5)*(e+r);A.push(t)}const o=Math.trunc(Math.random()*s);let n=2*(Math.random()-.5)*r;return n+=Math.sign(n)*e,A.splice(o,0,n),A.push(Math.random()*a),A}function pt(t){let e=[];for(let r=0;r<t;r++)e.push(s.randFloatSpread(2));const r=Math.hypot(...e),a=Math.random()/r;return e=e.map((t=>t*a)),e}function yt(t,e,r){let a=[];for(let e=0;e<t;e++)a.push(s.randFloatSpread(2));const A=Math.hypot(...a),i=(Math.random()*r+e)/A;return a=a.map((t=>t*i)),a}function ut(t,e){let r=[];const a=t-1;for(let t=0;t<a;t++)r.push(s.randFloatSpread(2));const A=Math.hypot(...r),i=Math.random()/A;return r=r.map((t=>t*i)),r.push(Math.random()*e),r}function kt(t,e,r,a){let A=[];const i=t-1;for(let t=0;t<i;t++)A.push(s.randFloatSpread(2));const o=Math.hypot(...A),n=(Math.random()*r+e)/o;return A=A.map((t=>t*n)),A.push(Math.random()*a),A}function St({ratio:t,density:e}){return e-e*t}function gt({ratio:t,value:e}){return e-e*t}var Wt=(t=>(t[t.Circle=0]="Circle",t[t.Square=1]="Square",t))(Wt||{});function ct(t,e){const{clim:a,step:A,radius:s,value:i,solid:o,hollow:n,density:l,shape:p,densityGradient:y,valueGradient:u}=t,k=t,[S,g]=_(t);let W,c;if(e){const{lineStep:t,matrix:a}=e,A=1===p?lt:kt;W=function(e,s,i){const o=A(e,s,i,t);return 2===e&&o.push(0),new r(...o).applyMatrix4(a)},c=function(e,r){return e*r**(g-2)*t}}else{const t=1===p?ot:yt;W=function(e,r,a){const A=t(e,r,a);return new S(...A)},c=function(t,e){return t*e**(g-1)}}const d=[],I=[],b=s*o,V=s-b,m=s*n;for(let t=m+A;t<s;t+=A){const e={ratio:(t-b)/V,radius:s,solid:o,distance:t,density:l,solidRadius:b,gradientRadius:V,clim:a,value:i,hollow:n,hollowRadius:m};let r=c(t<b?l:y(e),t);const p=t-A;for(;r-- >-1;){const t=W(g,p,A),r=(new S).copy(t),a=r.length();r.add(k),d.push(r);const i=u({...e,ratio:a/s,distance:a});I.push(i)}}return{particles:d,values:I}}function dt(t){const{points:e,clim:r={x:0,y:100},step:a=3,radius:A=10,value:s=100,solid:i=.7,hollow:o=0,density:n=1,shape:l=0,densityGradient:p=St,valueGradient:y=gt}=t,u={clim:r,step:a,radius:A,value:s,solid:i,hollow:o,density:n,shape:l,densityGradient:p,valueGradient:y},k=e[0];if(!k)return[];const[S,g]=_(k);return e.map((t=>{const e=new S;return Object.assign(e,{...u,...t}),ct(e)}))}class It extends i{constructor(t){super(),st(this,"isClusterGeometry",!0),st(this,"_options"),st(this,"_colorGradient"),st(this,"_values"),t&&(this.options=t)}get options(){return this._options??(this._options={})}set options(t){this._options=t,this.updateVertices()}get gradient(){return this.options.gradient}set gradient(t){this.options.gradient=t,this.colorGradient=this.createColorGradient(t)}get colorGradient(){return this._colorGradient?this._colorGradient:this._colorGradient=this.createColorGradient(this.gradient)}set colorGradient(t){this._colorGradient=t,this.updateVertexColors()}createColorGradient(t){if(!t)return null;const e=Array.isArray(t)?function(t,e,r,a="srgb"){const A=new OffscreenCanvas(e,r).getContext("2d"),s=A.createLinearGradient(0,0,256,1);for(const[e,r]of t)s.addColorStop(Number(e),r);return A.fillStyle=s,A.fillRect(0,0,e,r),A.getImageData(0,0,e,r,{colorSpace:a})}(t,256,1):t,{width:r,height:a}=e,A=function(t,e){const{data:r,width:a}=t,A=e*a,s=A+a;return r.slice(4*A,4*s)}(e,Math.trunc(a/2));return new ImageData(A,r,1)}updateVertexColors(){this.deleteAttribute("color");const{colorGradient:t,clim:e,values:r}=this;if(!t)return!1;const{width:a,data:A}=t,i=[],{x:n,y:l}=e,p=l-n,y=a-1;for(const t of r){const e=1-(s.clamp(t,n,l)-n)/p,r=4*Math.trunc(e*y),a=A.slice(r,r+4);i.push(...a)}this.setAttribute("color",new o(new Uint8ClampedArray(i),4,!0))}get clim(){return this.options.clim??(this.options.clim={x:0,y:100})}set clim(t){this.options.clim=t,this.updateVertexColors()}get clusters(){return this.options.clusters}set clusters(t){this.options.clusters=t,this.updateVertices()}updateVertices(){this.deleteAttribute("position"),this._values=null;const t=this.clusters;if(!t)return;const e=[],r=[];let a=0;for(const{particles:A,values:s}of t){const t=A.length;for(let i=0;i<t;i++,a++){A[i].toArray(e,3*a);const t=s[i];r.push(t)}}this.setAttribute("position",new o(new Float32Array(e),3)),this.values=r}get values(){return this._values??(this._values=[])}set values(t){this._values=t,this.updateVertexColors()}addCluster(t){const e=Array.isArray(t)?t:[t],r=this.clusters;if(!r)return void(this.clusters=e);r.push.apply(r,e);let a=[];const A=[];let s=0;for(const{particles:t,values:r}of e){const e=t.length;for(let i=0;i<e;i++,s++){t[i].toArray(a,3*s);const e=r[i];A.push(e)}}const i=this.getAttribute("position");i&&(a=[...i.array,...a]),this.setAttribute("position",new o(new Float32Array(a),3)),i?this.addValueColors(A):this.values=A}addValueColors(t){const{colorGradient:e,clim:r,values:a}=this;if(!e)return!1;const{width:A,data:i}=e;let n=[];const{x:l,y:p}=r,y=p-l,u=A-1;for(const e of t){const t=1-(s.clamp(e,l,p)-l)/y,r=4*Math.trunc(t*u),A=i.slice(r,r+4);n.push(...A),a.push(e)}const k=this.getAttribute("color");k&&(n=[...k.array,...n]),this.setAttribute("color",new o(new Uint8ClampedArray(n),4,!0))}}function bt({startRadius:t,addedRadius:e,ratio:r}){return e*r+t}function Vt({startDensity:t,addedDensity:e,ratio:r}){return e*r+t}function mt({startValue:t,addedValue:e,ratio:r}){return e*r+t}function Jt(t){const{points:e,clim:a={x:0,y:100},step:A=3,radius:s=10,value:i=100,solid:o=.7,hollow:n=0,density:l=1,shape:u=Wt.Circle,densityGradient:k=St,valueGradient:S=gt,radiusGradient:g=bt,lineDensityGradient:W=Vt,lineValueGradient:c=mt}=t,d=t.lineStep??A,I={clim:a,step:A,radius:s,value:i,solid:o,hollow:n,density:l,shape:u,densityGradient:k,valueGradient:S,radiusGradient:g,lineDensityGradient:W},{total:b,lengths:V}=function(t){const e=t.length;let r=t[0];const[a,A]=_(r),s=[0];let i=0;for(let A=1;A<e;A++){const e=(new a).copy(t[A]).distanceTo(r);s.push(e),i+=e}return{lengths:s,total:i}}(e),m=e.length,J=e[0],q=e[m-1],U=J.radius??s,R=J.density??l,N=J.value??i,T=q.radius??s,h=q.density??l,v=q.value??i,C={length:b,startRadius:U,endRadius:T,addedRadius:T-U,defaultRadius:s,startDensity:R,endDensity:h,addedDensity:h-R,defaultDensity:l,startValue:N,endValue:v,addedValue:v-N,defaultValue:i},L=[];for(let t=0;t<m;t++){const r=e[t];let{radius:a,value:A,density:s}=r;const i={...C,ratio:V[t]/b,index:t-1};a=a??g(i),s=s??W(i),A=A??c(i),L.push({...I,...r,radius:a,density:s,value:A})}const[B,x]=_(J),j=[],H=m-1;for(let t=0;t<H;t++){const e=L[t],{radius:a,density:A,value:o}=e,n=new B;n.lineStep=d;const u=L[t+1],{radius:k,density:S,value:I}=u,b=new B;Object.assign(b,u);const m=b.clone().sub(n).normalize(),J=V[t+1],q=Math.trunc(J/d),U=k-a,R=S-A,N=I-o,T=new p;3===x?T.setFromUnitVectors(new r(0,0,1),m):T.setFromUnitVectors(new r(0,1,0),new r(m.x,m.y,0));const h=(new y).makeRotationFromQuaternion(T);Object.assign(n,{...e,lineDir:m,matrix:h}),j.push(n);const v={length:J,startRadius:a,endRadius:k,addedRadius:U,defaultRadius:s,startDensity:A,endDensity:S,addedDensity:R,defaultDensity:l,startValue:o,endValue:I,addedValue:N,defaultValue:i,index:t,ratio:0};let C=0;for(let t=1;t<q;t++){C=t*d;const r=m.clone().multiplyScalar(C).add(n),a=C/J;v.ratio=a;const A=g(v),s=W(v),i=c(v),o={...e,lineDir:m,matrix:h,radius:A,density:s,value:i,lineStep:d};delete o.x,delete o.y,delete o.z,delete o.w,Object.assign(r,o),j.push(r)}j[j.length-1].lineStep=J-C}return j.map((t=>{const{lineStep:e,matrix:r}=t;return ct(t,{lineStep:e,matrix:r})}))}function qt(t,e){const{x:r,y:a}=e;let A=0;for(const{value:e,clim:{x:r,y:a}}of t)A+=(e-r)/(a-r);return A*(a-r)+r}function Ut(t,e){const{clim:r,step:a,radius:A,value:s,solid:i,hollow:o,density:n,shape:l,densityGradient:p,valueGradient:y,valuesAccumulate:u}=t,[k,S]=_(t),g=(new k).copy(t),W=l===Wt.Square?ot:yt,c=[],d=[],I=A*i,b=A-I,V=A*o,m=e.map((t=>({dist:g.distanceTo(t),point:t})));for(let e=V+a;e<A;e+=a){const l={ratio:(e-I)/b,radius:A,solid:i,hollow:o,hollowRadius:V,distance:e,density:n,solidRadius:I,gradientRadius:b,clim:r,value:s},J=e<I?n:p(l);let q=J*e**(S-1);const U=e-a,R=m.filter((({dist:t,point:r})=>{const a=r.radius;return t-e<=a}));t:for(;q-- >-1;){const e=new k(...W(S,U,a)),s=e.length();e.add(g);const i=[],o={...l,ratio:s/A,distance:s},n=y(o);i.push({...t,...o,value:n,density:J});for(const{point:t}of R){const r=e.distanceTo(t),{solid:a,hollow:A,radius:s}=t;if(r<=s){const e=s*a,o=s-e,n=s*A;if(r<n)continue t;const l={...t,ratio:r/s,distance:r,solidRadius:e,gradientRadius:o,hollowRadius:n},p=y(l);i.push({...l,value:p})}}c.push(e);const p=u(i,r,J);d.push(p)}}return{particles:c,values:d}}function Rt(t){const{points:e,clim:r={x:0,y:100},step:a=3,radius:A=10,value:s=100,solid:i=.7,hollow:o=0,density:n=1,shape:l=Wt.Circle,densityGradient:p=St,valueGradient:y=gt,valuesAccumulate:u=qt}=t,k={clim:r,step:a,radius:A,value:s,solid:i,hollow:o,density:n,shape:l,densityGradient:p,valueGradient:y,valuesAccumulate:u},S=e.map((t=>({...k,...t}))),g=function(t){const e=t.length,r=[];if(0===e)return r;const[a,A]=_(t[0]);for(let A=0;A<e;A++){const s=t[A],i=(new a).copy(s),o=s.radius,n=r[A]??(r[A]=[]);for(let a=A+1;a<e;a++){const e=t[a];i.distanceToSquared(e)<=(e.radius+o)**2&&(n.push(a),(r[a]=[]).push(A))}}return r}(S);return S.map(((t,e)=>{const r=g[e].map((t=>S[t]));return Ut({...k,...t},r)}))}var Nt=(t=>(t[t.Point=0]="Point",t[t.Line=1]="Line",t[t.Heat=2]="Heat",t))(Nt||{});const Tt={cluster:{base:["radius","solid","hollow","density","shape","densityGradient","step","clusterType","points"],line:["radiusGradient","lineDensityGradient","lineStep"],heat:[]},gradient:{base:["value","valueGradient","clim","gradient"],line:["lineValueGradient"],heat:["valuesAccumulate"]}};class ht extends It{constructor(t){super(),st(this,"isParticleClusterGeometry",!0),t&&(this.options=t)}get options(){return this._options}set options(t){this._options=t,this.updateClusters()}get clusterType(){return this.options.clusterType}set clusterType(t){this.options.clusterType!==t&&(this.options.clusterType=t,this.updateClusters())}setOptions(t){const e=this.options;let r=!1;const a=Object.entries(t).some((([t,a])=>a!==e[t]&&(!!(Tt.cluster.base.includes(t)||1===this.clusterType&&Tt.cluster.line.includes(t)||2===this.clusterType&&Tt.cluster.heat.includes(t))||(Tt.gradient.base.includes(t)&&(r=!0),1===this.clusterType&&Tt.gradient.line.includes(t)&&(r=!0),void(2===this.clusterType&&Tt.gradient.heat.includes(t)&&(r=!0))))));Object.assign(this.options,t),a?this.updateClusters():r&&this.updateVertexColors()}updateClusters(){this.clusters=this.createClusters(this.options)}createClusters(t){let e;switch(t.clusterType){case 2:e=Rt(t);break;case 1:e=Jt(t);break;default:e=dt(t)}return e}addPoint(t,e){const r=Array.isArray(t)?t:[t],a={...this.options,...e,points:r},A=this.createClusters(a);this.addCluster(A)}}class vt extends n{constructor(t){super(new ht,new l({vertexColors:!0,transparent:!0,...t})),st(this,"isParticleCluster",!0),t&&(this.options=t)}get options(){return this.geometry.options}set options(t){const e=null==t?void 0:t.points;if(e){const r=this.convertPoints(e);t={...t,points:r}}this.geometry.options=t}setOptions(t){const e=t.points;if(e){const r=this.convertPoints(e);t={...t,points:r}}this.geometry.setOptions(t)}addPoint(t,e){const r=Array.isArray(t)?t:[t],a=this.convertPoints(r);this.geometry.addPoint(a,e)}convertPoints(t){const e=this.matrixWorld.clone().invert();return t.map((t=>{const a=new r;return Object.assign(a,t),a.applyMatrix4(e),a}))}}class Ct{constructor(t){const{textureUrl:e,width:r,height:a,position:A,isScaleAnimate:s,isOpacityAnimate:i}=t;void 0!==e[1]&&(this.outMaterial=this.createMaterial(e[1]),this.outPlaneGeometry=this.createPlane(r,a),this.outMesh=new u(this.outPlaneGeometry,this.outMaterial),this.outMesh.renderOrder=Number.MAX_SAFE_INTEGER-2,this.outMesh.position.set(A.x,A.y,A.z),this.outMesh.rotation.set(-1.5707022192751596,33819658717412135e-21,.34500000055302255)),this.inMaterial=this.createMaterial(e[0]),this.inPlaneGeometry=this.createPlane(r,a),this.inMesh=new u(this.inPlaneGeometry,this.inMaterial),this.inMesh.renderOrder=Number.MAX_SAFE_INTEGER-1,this.inMesh.position.set(A.x,A.y,A.z),this.inMesh.rotation.set(-1.5707022192751596,33819658717412135e-21,.34500000055302255),this.isScaleAnimate=s,this.isOpacityAnimate=i,this.AngleUnit=.1,this.MaxScale=3,this.ScaleUnit=.02,this.OpacityUnit=1/((this.MaxScale-0)/this.ScaleUnit)}createPlane(t=10,e=10){return new k(t,e)}createMaterial(t){const e=new S,r=(new g).load(t);return e.map=r,e.side=W,e.transparent=!0,e}update(){if(void 0!==this.outMesh){const t=this.outMesh.material.map;null==t||t.center.set(.5,.5),t.rotation+=this.AngleUnit}const t=this.inMesh.material.map;if(null==t||t.center.set(.5,.5),t.rotation-=this.AngleUnit,this.isScaleAnimate){this.inMesh.scale.x>this.MaxScale&&(this.inMesh.scale.x=0,this.inMesh.scale.y=0,this.inMesh.material.opacity=1,void 0!==this.outMesh&&(this.outMesh.scale.y=0,this.outMesh.scale.x=0,this.outMesh.material.opacity=1)),void 0!==this.outMesh&&(this.outMesh.scale.y+=this.ScaleUnit,this.outMesh.scale.x+=this.ScaleUnit),this.inMesh.scale.x+=this.ScaleUnit,this.inMesh.scale.y+=this.ScaleUnit}this.isOpacityAnimate&&(void 0!==this.outMesh&&(this.outMesh.material.opacity-=this.OpacityUnit),this.inMesh.material.opacity-=this.OpacityUnit)}}class Lt{constructor(t){const{topRadius:e,bottomRadius:r,height:a,position:A,texturePath:s,color:i}=t;this.geometry=this.createGeometry(e,r,a),this.material=this.creatematerial(s,i),this.position=A,this.mesh=new u(this.geometry,this.material),this.mesh.renderOrder=Number.MAX_SAFE_INTEGER-1,this.mesh.position.set(A.x,A.y+a/2,A.z),this.maxScale=15,this.minScale=1,this.opacityUnit=1/this.maxScale}createGeometry(t,e,r){return new c(t,e,r,32,16,!0)}creatematerial(t,e){const r=new S,a=(new g).load(t);return r.map=a,r.side=W,r.opacity=1,r.transparent=!0,r}update(){let t=this.mesh.scale.x;t+=.1,t>=this.maxScale&&(t=1);const e=1-this.opacityUnit*t;this.mesh.scale.set(t,this.mesh.scale.y,t),this.mesh.material.opacity=e}}var Bt={vertexShader:"\n attribute float size;\n uniform float showDistance;\n varying float dcolor;\n void main() {\n\n vec4 mvPosition = modelViewMatrix * vec4( position, 1.0 );\n // vec4 viewPosition = viewMatrix * mvPosition;\n \n //gl_PointSize = 5.0;\n float fDistance =sqrt( position.x * position.x + position.z * position.z );\n if(fDistance < showDistance)\n return;\n\n // dcolor = fDistance/355.0/3.0;\n gl_Position = projectionMatrix * mvPosition;\n gl_PointSize = size * ( 300.0 / - mvPosition.z );\n // gl_PointSize *= (1.0 / - viewPosition.z);\n }\n ",fragmentShader:"\n #include <common>\n uniform vec3 color;\n uniform float opacity;\n // varying float dcolor;\n void main() {\n\n //if ( length( gl_PointCoord - vec2( 0.5, 0.5 ) ) > 0.475 ) discard;\n // int buffer = int(dcolor);\n \n //gl_FragColor = vec4( dcolor,sin(dcolor),0, 1.0 );\n gl_FragColor = vec4( color, opacity );\n\n #include <tonemapping_fragment>\n #include <encodings_fragment>\n }\n "},xt={vertexShader:"\n uniform vec2 lowHeigh;\n varying float ratioHeigh;\n void main() {\n \n vec4 mvPosition = modelViewMatrix * vec4( position, 1.0 );\n float maxHeigh = lowHeigh.y - lowHeigh.x;\t\n float curHeigh = lowHeigh.y - position.y;\t\n ratioHeigh = curHeigh/maxHeigh;\n gl_Position = projectionMatrix * mvPosition;\n \n }\n ",fragmentShader:"\n #include <common>\n uniform vec3 color;\n varying float ratioHeigh;\n void main() {\n \n // gl_FragColor = vec4( color, 1.0-ratioHeigh*ratioHeigh*ratioHeigh-0.5 );\n gl_FragColor = vec4( color, max( 1.0-ratioHeigh*ratioHeigh*ratioHeigh-0.5, 0.01 ) );\n\n #include <tonemapping_fragment>\n #include <encodings_fragment>\n }\n "};const jt=new y(1,0,0,0,0,0,1,0,0,-1,0,0,0,0,0,1);var Ht="";const Kt=new g;function Ft(t){const{polygon:e,waterNormals:r=Ht,height:A,speed:s=1}=t,i=j(t,["polygon","waterNormals","height","speed"]),o=function(t,e){const r=t.map((t=>new a(t.x,-t.z))),A=new d(r),s=new I(A);return jt.elements[13]=null!=e?e:t[0].y,s.applyMatrix4(jt),s}(e,A),n=Kt.load(r,(function(t){t.wrapS=t.wrapT=b})),l=new x(o,Object.assign(Object.assign({},i),{waterNormals:n}));return l.speed=s,l}class ft{constructor(t){this.ssp=t,this.weatherPresetImgs={rain:"",snow:""},this._weatherId=""}createFlame(a){const{magnitude:A=1.3,gain:s=.5}=a,i=50,o=new u(new V(1,1,1),(a=>{const{imgUrl:o=K}=a,n=(new g).load(o);n.magFilter=n.minFilter=h,n.wrapS=n.wrapT=v;const l=new T({defines:{ITERATIONS:20,OCTIVES:3,WIDTH:128,BOUNDS:512},uniforms:C.merge([L.phong.uniforms,{fireTex:{value:n},time:{value:0},seed:{value:19.19*Math.random()},invModelMatrix:{value:new y},scale:{value:new r(i,i,i)},noiseScale:{value:new e(1,2,1,.3)},magnitude:{value:A},gain:{value:s},lacunarity:{value:2},diffuse:{value:new t(16576)},specular:{value:new t(1118481)},shininess:{value:Math.max(50,1e-4)},opacity:{value:.8}}]),vertexShader:H.vertexShader,fragmentShader:H.fragmentShader,transparent:!0,depthWrite:!1,depthTest:!0,lights:!0});return l.uniforms.fireTex.value=n,l})(a));o.scale.set(i,i,i);const n=t=>{const e=o.material,a=e.uniforms.invModelMatrix.value;o.updateMatrixWorld(),a.copy(o.matrixWorld).invert(),void 0!==t&&(e.uniforms.time.value=t/1e3),e.uniforms.invModelMatrix.value=a,e.uniforms.scale.value=o.getWorldScale(new r),e.uniforms.magnitude.value=A||1.3,e.uniforms.gain.value=s||.5,e.version++,this.ssp.render()};this.ssp.viewport.postUpdate.set(a.id,n);const l=this.ssp.createPluginObject(a,o),p=()=>this.ssp.viewport.postUpdate.set(a.id,n);p();return l.addEventListener("added",p),l.addEventListener("removed",(()=>this.ssp.viewport.postUpdate.delete(a.id))),l}removeFlame(t){return console.warn("请使用 ssp.removeObjectById 替代"),this.ssp.removeObjectById(t)}createSmoke(e){const{imgUrl:a=G,count:A=1e3,maxAge:s=4,size:i=200,acceleration:o=10,velocity:n={x:100,y:100,z:100},color:l=[3355443,1118481]}=e,p=new m,y=(new g).load(a),u=new Z.Group({texture:{value:y},blending:J}),k=new Z.Emitter({particleCount:A,maxAge:{value:s},position:{value:new r(0,0,0),spread:new r(0,0,0)},size:{value:i,spread:[1,1,8]},acceleration:{value:new r(0,o,0)},rotation:{angle:this.ssp.utils.deg2Euler(45),randomise:!0},velocity:{value:new r(0,100,0),spread:new r(n.x,n.y,n.z)},opacity:{value:[.5,.2,0]},color:{value:l.map((e=>new t(e)))}});u.addEmitter(k);const S=()=>{u.tick(p.getDelta()),this.ssp.render()},W=this.ssp.createPluginObject(e,u.mesh),c=()=>this.ssp.viewport.postUpdate.set(e.id,S);c();return W.addEventListener("added",c),W.addEventListener("removed",(()=>this.ssp.viewport.postUpdate.delete(e.id))),W}removeSmoke(t){return console.warn("请使用 removeObjectById 替代"),this.ssp.removeObjectById(t)}createSparkles(t){const{count:e=100,scalar:r=8,speed:a=1,opacity:A=1,noise:s=1,color:i="#fff",size:o=2}=t,{ssp:n}=this,{THREE:l}=n,{Points:p,ShaderMaterial:y,BufferGeometry:u,BufferAttribute:k}=l,S=Float32Array.from(Array.from({length:e},(()=>w(r).map(l.MathUtils.randFloatSpread))).flat()),g=O(e,o,Math.random),W=O(e,A),c=O(e,a),d=O(3*e,s),I=O(void 0===i?3*e:e,E(i)?i:new l.Color(i),(()=>1)),b=new u;b.setAttribute("position",new k(S,3)),b.setAttribute("size",new k(g,1)),b.setAttribute("opacity",new k(W,1)),b.setAttribute("speed",new k(c,1)),b.setAttribute("color",new k(I,3)),b.setAttribute("noise",new k(d,3));const V=new y({uniforms:{time:{value:0},pixelRatio:{value:self.devicePixelRatio}},vertexShader:Q.vertexShader,fragmentShader:Q.fragmentShader,depthWrite:!1,transparent:!0,blending:q}),m=new p(b,V),J=()=>{V.uniforms.time.value=n.viewport.clock.elapsedTime,this.ssp.render()},U=this.ssp.createPluginObject(t,m),R=()=>this.ssp.viewport.postUpdate.set(t.id,J);R();return U.addEventListener("added",R),U.addEventListener("removed",(()=>this.ssp.viewport.postUpdate.delete(t.id))),U}createContactShadows(t){var{scale:e=10,frames:r=1/0,opacity:a=1,width:A=1,height:s=1,blur:i=1,darkness:o=1,far:n=10,resolution:l=512}=t,p=j(t,["scale","frames","opacity","width","height","blur","darkness","far","resolution"]);const{viewport:{renderer:y,scene:u},THREE:k}=this.ssp;A*=Array.isArray(e)?e[0]:e||1,s*=Array.isArray(e)?e[1]:e||1;const S=new k.Group,g=new k.OrthographicCamera(-A/2,A/2,s/2,-s/2,0,n);g.rotation.x=Math.PI/2,S.add(g);const W=new k.WebGLRenderTarget(l,l),c=new k.WebGLRenderTarget(l,l);c.texture.generateMipmaps=W.texture.generateMipmaps=!1;const d=new k.PlaneGeometry(A,s).rotateX(Math.PI/2),I=new k.MeshBasicMaterial({map:W.texture,opacity:a,transparent:!0,depthWrite:!1}),b=new k.Mesh(d,I);b.renderOrder=1,b.scale.y=-1,S.add(b);const V=new k.Mesh(d);V.visible=!1,S.add(V);const m=new k.MeshDepthMaterial;m.userData.darkness={value:o},m.onBeforeCompile=function(t){t.uniforms.darkness=m.userData.darkness,t.fragmentShader=`\n uniform float darkness;\n ${t.fragmentShader.replace("gl_FragColor = vec4( vec3( 1.0 - fragCoordZ ), opacity );","gl_FragColor = vec4( vec3( 0.0 ), ( 1.0 - fragCoordZ ) * darkness );")}\n `},m.depthTest=!1,m.depthWrite=!1;const J=new k.ShaderMaterial(M);J.depthTest=!1;const q=new k.ShaderMaterial(P);function U(t){V.visible=!0,V.material=J,J.uniforms.tDiffuse.value=W.texture,J.uniforms.h.value=1*t/256,y.setRenderTarget(c),y.render(V,g),V.material=q,q.uniforms.tDiffuse.value=c.texture,q.uniforms.v.value=1*t/256,y.setRenderTarget(W),y.render(V,g),V.visible=!1}q.depthTest=!1;let R=0;const N=()=>{if(R>r)return;R++;const t=u.background;u.background=null,u.overrideMaterial=m;const e=y.getClearAlpha();y.setClearAlpha(0),y.setRenderTarget(W),y.render(u,g),u.overrideMaterial=null,U(i),U(.4*i),y.setRenderTarget(null),y.setClearAlpha(e),u.background=t},T=this.ssp.createPluginObject(p,S),h=()=>this.ssp.signals.beforeRender.add(N);h();return T.addEventListener("added",h),T.addEventListener("removed",(()=>this.ssp.signals.beforeRender.remove(N))),T}openWeather(t={}){const{imgUrl:e=this.weatherPresetImgs.rain,count:r=500,range:a=100,size:A=1,opacity:p=.9,color:y=16777215,velocityX:u=[-.02,.02],velocityY:k=[.4,.8]}=t;this._weatherId&&this.closeWeather();const{viewport:{renderer:S,container:W},utils:c}=this.ssp,d=new Float32Array(3*r),I=Array.from({length:r}).fill({x:0,y:0}),b=new i;for(let t=0;t<r;t++)d[3*t]=s.randFloatSpread(a),d[3*t+1]=s.randFloatSpread(a),d[3*t+2]=s.randFloatSpread(a),I[t].x=s.randFloat(...u),I[t].y=s.randFloat(...k);const V=new o(d,3);V.setUsage(U),b.setAttribute("position",V);const m=(new g).load(e);m.colorSpace=S.outputColorSpace;const J=new l({color:y,size:A,opacity:p,map:m,transparent:!0}),q=new n(b,J),T=new R,h=new N(45,W.offsetWidth/W.offsetHeight,.1,1e3);h.position.set(0,0,a/2),T.add(q);this._weatherId=`weather_${c.randomString()}`,this.ssp.viewport.postRender.set(this._weatherId,(()=>{I.forEach(((t,e)=>{d[3*e]-=t.x,d[3*e+1]-=t.y,(d[3*e]<=-a/2||d[3*e]>=a/2)&&(I[e].x*=-1),d[3*e+1]<=-a/2&&(d[3*e+1]=a/2)})),V.needsUpdate=!0,S.render(T,h),this.ssp.render()})),this.ssp.render()}closeWeather(){this._weatherId&&(this.ssp.viewport.postRender.delete(this._weatherId),this._weatherId="",this.ssp.render())}createParticleCluster(t){const e=new vt(t);return this.ssp.addObject(e),e}createCircleWave(t){const e=this.ssp.createPluginObject(t),r=new Ct(t);e.add(r.inMesh),r.outMesh&&e.add(r.outMesh);const a=()=>{this.ssp.viewport.postUpdate.set(t.id,(()=>{r.update(),this.ssp.render()}))};a();return e.addEventListener("added",a),e.addEventListener("removed",(()=>this.ssp.viewport.postUpdate.delete(t.id))),e}createCylinderWave(t){const e=this.ssp.createPluginObject(t),r=new Lt(t);e.add(r.mesh),this.ssp.addObject(e);const a=()=>{this.ssp.viewport.postUpdate.set(t.id,(()=>{r.update(),this.ssp.render()}))};a();return e.addEventListener("added",a),e.addEventListener("removed",(()=>this.ssp.viewport.postUpdate.delete(t.id))),e}createPointsWave(e){let r=0;const{xAxisCount:a=100,zAxisCount:A=100,showDistance:s=0,separation:l=20,size:p=5,maxFluctua:y=.1,color:u="#485c7c",opacity:k=1}=e,S=a*A,g=new Float32Array(3*S),W=new Float32Array(S);let c=0,d=0;for(let t=0;t<a;t++)for(let e=0;e<A;e++)g[c]=t*l-a*l/2,g[c+1]=0,g[c+2]=e*l-A*l/2,W[d]=1,c+=3,d++;const I=new i;I.setAttribute("position",new o(g,3).setUsage(U)),I.setAttribute("size",new o(W,1).setUsage(U));const b=new T({transparent:!0,depthWrite:!1,uniforms:{color:{value:new t(u)},opacity:{value:k},showDistance:{value:s}},vertexShader:Bt.vertexShader,fragmentShader:Bt.fragmentShader}),V=new n(I,b);V.renderOrder=-1;const m=()=>{const t=V.geometry.attributes.position.array,e=V.geometry.attributes.size.array;let s=0,i=0;const o=Math.sqrt(a/2*(a/2)+A/2*(A/2));for(let n=0;n<a;n++)for(let l=0;l<A;l++){const u=n-a/2,k=l-A/2,S=Math.sqrt(u*u+k*k);t[s+1]=50*Math.cos(1*(S/o*50-r))*y,e[i]=p,s+=3,i++}V.geometry.attributes.position.needsUpdate=!0,V.geometry.attributes.size.needsUpdate=!0,r+=.01,this.ssp.render()},J=this.ssp.createPluginObject(e,V),q=()=>this.ssp.viewport.postUpdate.set(e.id,m);q();return J.addEventListener("added",q),J.addEventListener("removed",(()=>this.ssp.viewport.postUpdate.delete(e.id))),J}createBuilds(e){const{buildWidth:r=100,buildDepth:A=100,buildHeigh:s=200,count:i=12,gapX:o=2,gapZ:n=2,showDistance:l=1e3,randShift:p=.5,color:y="#485c7c"}=e,k=this.ssp.createPluginObject(e);for(let e=0;e<i;e++)for(let S=0;S<i;S++){const g=(e-i/2)*r*o+(Math.random()-1)*p*r*o,W=(S-i/2)*A*n+(Math.random()-1)*p*A*n;if(Math.sqrt(g*g+W*W)<l)continue;const c=Math.floor(Math.random()*s)+s,d=new V(r,c,A,1,1,1);d.translate(g,c/2,W),d.computeBoundingBox();const I=d.boundingBox,b=new T({transparent:!0,depthWrite:!1,uniforms:{color:{value:new t(y)},lowHeigh:{value:new a(I.min.y,I.max.y)}},vertexShader:xt.vertexShader,fragmentShader:xt.fragmentShader}),m=new u(d,b);k.add(m)}return k}createWater(t){const{animation:e=!0}=t,{ssp:r}=this,a=Ft(Object.assign(Object.assign({},t),{fog:!!r.viewport.scene.fog})),A=r.createPluginObject(t,a),s=()=>{var t;a.material.uniforms.time.value+=(null!==(t=a.speed)&&void 0!==t?t:0)/60,e&&r.render()},i=()=>r.viewport.postUpdate.set(t.id,s);return i(),A.addEventListener("added",i),A.addEventListener("removed",(()=>r.viewport.postUpdate.delete(t.id))),A}removeEffect(t){return console.warn("请使用 removeObjectById 替代"),this.ssp.removeObjectById(t)}}export{It as ClusterGeometry,Nt as ClusterType,vt as ParticleCluster,ht as ParticleClusterGeometry,Wt as ParticleClusterShape,Ut as createHeatParticleClusterData,Rt as createHeatParticleClusterDataArr,ct as createPointParticleClusterData,dt as createPointParticleClusterDataArr,ft as default,St as densityGradient_Default,pt as getRandomVector_Circle,yt as getRandomVector_CircleAnnular,ut as getRandomVector_CircleCylinder,kt as getRandomVector_CircleCylinderAnnular,it as getRandomVector_Square,ot as getRandomVector_SquareAnnular,nt as getRandomVector_SquareCylinder,lt as getRandomVector_SquareCylinderAnnular,gt as valueGradient_Default,qt as valuesAccumulate_Default};
1
+ import{Color as t,Vector4 as e,Vector3 as r,Vector2 as a,Matrix3 as A,MathUtils as s,BufferGeometry as i,BufferAttribute as o,Points as n,PointsMaterial as l,Quaternion as p,Matrix4 as y,Mesh as u,PlaneGeometry as k,MeshBasicMaterial as S,TextureLoader as g,DoubleSide as W,CylinderGeometry as c,Shape as d,ShapeGeometry as I,RepeatWrapping as b,BoxGeometry as V,Clock as m,NormalBlending as J,AdditiveBlending as q,DynamicDrawUsage as U,Scene as R,PerspectiveCamera as N,ShaderMaterial as T,LinearFilter as h,ClampToEdgeWrapping as v,UniformsUtils as C,ShaderLib as L}from"three";import B from"soonspacejs";import{Water as x}from"three/examples/jsm/objects/Water.js";function j(t,e){var r={};for(var a in t)Object.prototype.hasOwnProperty.call(t,a)&&e.indexOf(a)<0&&(r[a]=t[a]);if(null!=t&&"function"==typeof Object.getOwnPropertySymbols){var A=0;for(a=Object.getOwnPropertySymbols(t);A<a.length;A++)e.indexOf(a[A])<0&&Object.prototype.propertyIsEnumerable.call(t,a[A])&&(r[a[A]]=t[a[A]])}return r}"function"==typeof SuppressedError&&SuppressedError;var H={vertexShader:"\n varying vec3 vViewPosition;\n varying vec3 vWorldPos;\n varying vec3 vNormal;\n\n #include <common>\n #include <uv_pars_vertex>\n #include <displacementmap_pars_vertex>\n #include <envmap_pars_vertex>\n #include <color_pars_vertex>\n #include <morphtarget_pars_vertex>\n #include <skinning_pars_vertex>\n #include <shadowmap_pars_vertex>\n #include <logdepthbuf_pars_vertex>\n #include <clipping_planes_pars_vertex>\n \n void main() {\n\n #include <uv_vertex>\n #include <color_vertex>\n \n //# include <begin_vertex>\n vec3 transformed = vec3( position.x, position.y, position.z );\n //<begin_vertex>\n \n #include <morphtarget_vertex>\n #include <displacementmap_vertex>\n #include <project_vertex>\n #include <logdepthbuf_vertex>\n #include <clipping_planes_vertex>\n\n vViewPosition = - mvPosition.xyz;\n\n #include <worldpos_vertex>\n\n vWorldPos = (modelMatrix * vec4(position, 1.0)).xyz;\n }",fragmentShader:"\n #include <packing>\n #include <logdepthbuf_pars_fragment>\n \n uniform vec3 color;\n uniform float time;\n uniform float seed;\n uniform mat4 invModelMatrix;\n uniform vec3 scale;\n \n uniform vec4 noiseScale;\n uniform float magnitude;\n uniform float lacunarity;\n uniform float gain;\n \n uniform sampler2D fireTex;\n \n varying vec3 vWorldPos;\n \n // GLSL simplex noise function by ashima / https://github.com/ashima/webgl-noise/blob/master/src/noise3D.glsl\n // -------- simplex noise\n vec3 mod289(vec3 x) {\n return x - floor(x * (1.0 / 289.0)) * 289.0;\n }\n \n vec4 mod289(vec4 x) {\n return x - floor(x * (1.0 / 289.0)) * 289.0;\n }\n \n vec4 permute(vec4 x) {\n return mod289(((x * 34.0) + 1.0) * x);\n }\n \n vec4 taylorInvSqrt(vec4 r) {\n return 1.79284291400159 - 0.85373472095314 * r;\n }\n \n float snoise(vec3 v) {\n const vec2 C = vec2(1.0 / 6.0, 1.0 / 3.0);\n const vec4 D = vec4(0.0, 0.5, 1.0, 2.0);\n \n // First corner\n vec3 i = floor(v + dot(v, C.yyy));\n vec3 x0 = v - i + dot(i, C.xxx);\n \n // Other corners\n vec3 g = step(x0.yzx, x0.xyz);\n vec3 l = 1.0 - g;\n vec3 i1 = min(g.xyz, l.zxy);\n vec3 i2 = max(g.xyz, l.zxy);\n \n // x0 = x0 - 0.0 + 0.0 * C.xxx;\n // x1 = x0 - i1 + 1.0 * C.xxx;\n // x2 = x0 - i2 + 2.0 * C.xxx;\n // x3 = x0 - 1.0 + 3.0 * C.xxx;\n vec3 x1 = x0 - i1 + C.xxx;\n vec3 x2 = x0 - i2 + C.yyy; // 2.0*C.x = 1/3 = C.y\n vec3 x3 = x0 - D.yyy; // -1.0+3.0*C.x = -0.5 = -D.y\n \n // Permutations\n i = mod289(i); \n vec4 p = permute(permute(permute( \n i.z + vec4(0.0, i1.z, i2.z, 1.0))\n + i.y + vec4(0.0, i1.y, i2.y, 1.0))\n + i.x + vec4(0.0, i1.x, i2.x, 1.0));\n \n // Gradients: 7x7 points over a square, mapped onto an octahedron.\n // The ring size 17*17 = 289 is close to a multiple of 49 (49*6 = 294)\n float n_ = 0.142857142857; // 1.0/7.0\n vec3 ns = n_ * D.wyz - D.xzx;\n \n vec4 j = p - 49.0 * floor(p * ns.z * ns.z); // mod(p,7*7)\n \n vec4 x_ = floor(j * ns.z);\n vec4 y_ = floor(j - 7.0 * x_); // mod(j,N)\n \n vec4 x = x_ * ns.x + ns.yyyy;\n vec4 y = y_ * ns.x + ns.yyyy;\n vec4 h = 1.0 - abs(x) - abs(y);\n \n vec4 b0 = vec4(x.xy, y.xy);\n vec4 b1 = vec4(x.zw, y.zw);\n \n //vec4 s0 = vec4(lessThan(b0,0.0))*2.0 - 1.0;\n //vec4 s1 = vec4(lessThan(b1,0.0))*2.0 - 1.0;\n vec4 s0 = floor(b0) * 2.0 + 1.0;\n vec4 s1 = floor(b1) * 2.0 + 1.0;\n vec4 sh = -step(h, vec4(0.0));\n \n vec4 a0 = b0.xzyw + s0.xzyw * sh.xxyy;\n vec4 a1 = b1.xzyw + s1.xzyw * sh.zzww;\n \n vec3 p0 = vec3(a0.xy, h.x);\n vec3 p1 = vec3(a0.zw, h.y);\n vec3 p2 = vec3(a1.xy, h.z);\n vec3 p3 = vec3(a1.zw, h.w);\n \n //Normalise gradients\n vec4 norm = taylorInvSqrt(vec4(dot(p0, p0), dot(p1, p1), dot(p2, p2), dot(p3, p3)));\n p0 *= norm.x;\n p1 *= norm.y;\n p2 *= norm.z;\n p3 *= norm.w;\n \n // Mix final noise value\n vec4 m = max(0.6 - vec4(dot(x0, x0), dot(x1, x1), dot(x2, x2), dot(x3, x3)), 0.0);\n m = m * m;\n return 42.0 * dot(m * m, vec4(dot(p0, x0), dot(p1, x1), dot(p2, x2), dot(p3, x3)));\n }\n // simplex noise --------\n \n float turbulence(vec3 p) {\n float sum = 0.0;\n float freq = 1.0;\n float amp = 1.0;\n \n for(int i = 0; i < OCTIVES; i++) {\n sum += abs(snoise(p * freq)) * amp;\n freq *= lacunarity;\n amp *= gain;\n }\n \n return sum;\n }\n \n vec4 samplerFire (vec3 p, vec4 scale) {\n vec2 st = vec2(sqrt(dot(p.xz, p.xz)), p.y);\n \n if(st.x <= 0.0 || st.x >= 1.0 || st.y <= 0.0 || st.y >= 1.0) return vec4(0.0);\n \n p.y -= (seed + time) * scale.w;\n p *= scale.xyz;\n \n st.y += sqrt(st.y) * magnitude * turbulence(p);\n \n if(st.y <= 0.0 || st.y >= 1.0) return vec4(0.0);\n \n return texture2D(fireTex, st);\n }\n \n vec3 localize(vec3 p) {\n return (invModelMatrix * vec4(p, 1.0)).xyz;\n }\n \n void main() {\n #include <logdepthbuf_fragment>\n \n vec3 rayPos = vWorldPos;\n vec3 rayDir = normalize(rayPos - cameraPosition);\n float rayLen = 0.0288 * length(scale.xyz);\n \n vec4 col = vec4(0.0);\n \n for(int i = 0; i < ITERATIONS; i++) {\n rayPos += rayDir * rayLen;\n \n vec3 lp = localize(rayPos);\n \n lp.y += 0.5;\n lp.xz *= 2.0;\n col += samplerFire(lp, noiseScale);\n }\n \n col.a = col.r;\n gl_FragColor.a = 1.0;\n gl_FragColor = col;\n }"},K="";const{THREE:F}=B;var f,X,Z={distributions:{BOX:1,SPHERE:2,DISC:3,LINE:4},valueOverLifetimeLength:4};Z.TypedArrayHelper=function(t,e,r,a){this.componentSize=r||1,this.size=e||1,this.TypedArrayConstructor=t||Float32Array,this.array=new t(e*this.componentSize),this.indexOffset=a||0},Z.TypedArrayHelper.constructor=Z.TypedArrayHelper,Z.TypedArrayHelper.prototype.setSize=function(t,e){var r=this.array.length;return e||(t*=this.componentSize),t<r?this.shrink(t):t>r?this.grow(t):void console.info("TypedArray is already of size:",t+".","Will not resize.")},Z.TypedArrayHelper.prototype.shrink=function(t){return this.array=this.array.subarray(0,t),this.size=t,this},Z.TypedArrayHelper.prototype.grow=function(t){var e=this.array,r=new this.TypedArrayConstructor(t);return r.set(e),this.array=r,this.size=t,this},Z.TypedArrayHelper.prototype.splice=function(t,e){t*=this.componentSize,e*=this.componentSize;for(var r=[],a=this.array,A=a.length,s=0;s<A;++s)(s<t||s>=e)&&r.push(a[s]);return this.setFromArray(0,r),this},Z.TypedArrayHelper.prototype.setFromArray=function(t,e){var r=t+e.length;return r>this.array.length?this.grow(r):r<this.array.length&&this.shrink(r),this.array.set(e,this.indexOffset+t),this},Z.TypedArrayHelper.prototype.setVec2=function(t,e){return this.setVec2Components(t,e.x,e.y)},Z.TypedArrayHelper.prototype.setVec2Components=function(t,e,r){var a=this.array,A=this.indexOffset+t*this.componentSize;return a[A]=e,a[A+1]=r,this},Z.TypedArrayHelper.prototype.setVec3=function(t,e){return this.setVec3Components(t,e.x,e.y,e.z)},Z.TypedArrayHelper.prototype.setVec3Components=function(t,e,r,a){var A=this.array,s=this.indexOffset+t*this.componentSize;return A[s]=e,A[s+1]=r,A[s+2]=a,this},Z.TypedArrayHelper.prototype.setVec4=function(t,e){return this.setVec4Components(t,e.x,e.y,e.z,e.w)},Z.TypedArrayHelper.prototype.setVec4Components=function(t,e,r,a,A){var s=this.array,i=this.indexOffset+t*this.componentSize;return s[i]=e,s[i+1]=r,s[i+2]=a,s[i+3]=A,this},Z.TypedArrayHelper.prototype.setMat3=function(t,e){return this.setFromArray(this.indexOffset+t*this.componentSize,e.elements)},Z.TypedArrayHelper.prototype.setMat4=function(t,e){return this.setFromArray(this.indexOffset+t*this.componentSize,e.elements)},Z.TypedArrayHelper.prototype.setColor=function(t,e){return this.setVec3Components(t,e.r,e.g,e.b)},Z.TypedArrayHelper.prototype.setNumber=function(t,e){return this.array[this.indexOffset+t*this.componentSize]=e,this},Z.TypedArrayHelper.prototype.getValueAtIndex=function(t){return this.array[this.indexOffset+t]},Z.TypedArrayHelper.prototype.getComponentValueAtIndex=function(t){return this.array.subarray(this.indexOffset+t*this.componentSize)},Z.ShaderAttribute=function(t,e,r){var a=Z.ShaderAttribute.typeSizeMap;this.type="string"==typeof t&&a.hasOwnProperty(t)?t:"f",this.componentSize=a[this.type],this.arrayType=r||Float32Array,this.typedArray=null,this.bufferAttribute=null,this.dynamicBuffer=!!e,this.updateMin=0,this.updateMax=0},Z.ShaderAttribute.constructor=Z.ShaderAttribute,Z.ShaderAttribute.typeSizeMap={f:1,v2:2,v3:3,v4:4,c:3,m3:9,m4:16},Z.ShaderAttribute.prototype.setUpdateRange=function(t,e){this.updateMin=Math.min(t*this.componentSize,this.updateMin*this.componentSize),this.updateMax=Math.max(e*this.componentSize,this.updateMax*this.componentSize)},Z.ShaderAttribute.prototype.flagUpdate=function(){var t=this.bufferAttribute,e=t.updateRange;e.offset=this.updateMin,e.count=Math.min(this.updateMax-this.updateMin+this.componentSize,this.typedArray.array.length),t.needsUpdate=!0},Z.ShaderAttribute.prototype.resetUpdateRange=function(){this.updateMin=0,this.updateMax=0},Z.ShaderAttribute.prototype.resetDynamic=function(){this.bufferAttribute.usage=this.dynamicBuffer?F.DynamicDrawUsage:F.StaticDrawUsage},Z.ShaderAttribute.prototype.splice=function(t,e){this.typedArray.splice(t,e),this.forceUpdateAll()},Z.ShaderAttribute.prototype.forceUpdateAll=function(){this.bufferAttribute.array=this.typedArray.array,this.bufferAttribute.updateRange.offset=0,this.bufferAttribute.updateRange.count=-1,this.bufferAttribute.usage=F.StaticDrawUsage,this.bufferAttribute.needsUpdate=!0},Z.ShaderAttribute.prototype._ensureTypedArray=function(t){null!==this.typedArray&&this.typedArray.size===t*this.componentSize||(null!==this.typedArray&&this.typedArray.size!==t?this.typedArray.setSize(t):null===this.typedArray&&(this.typedArray=new Z.TypedArrayHelper(this.arrayType,t,this.componentSize)))},Z.ShaderAttribute.prototype._createBufferAttribute=function(t){if(this._ensureTypedArray(t),null!==this.bufferAttribute)return this.bufferAttribute.array=this.typedArray.array,parseFloat(F.REVISION)>=81&&(this.bufferAttribute.count=this.bufferAttribute.array.length/this.bufferAttribute.itemSize),void(this.bufferAttribute.needsUpdate=!0);this.bufferAttribute=new F.BufferAttribute(this.typedArray.array,this.componentSize),this.bufferAttribute.usage=this.dynamicBuffer?F.DynamicDrawUsage:F.StaticDrawUsage},Z.ShaderAttribute.prototype.getLength=function(){return null===this.typedArray?0:this.typedArray.array.length},Z.shaderChunks={defines:["#define PACKED_COLOR_SIZE 256.0","#define PACKED_COLOR_DIVISOR 255.0"].join("\n"),uniforms:["uniform float deltaTime;","uniform float runTime;","uniform sampler2D tex;","uniform vec4 textureAnimation;","uniform float scale;"].join("\n"),attributes:["attribute vec4 acceleration;","attribute vec3 velocity;","attribute vec4 rotation;","attribute vec3 rotationCenter;","attribute vec4 params;","attribute vec4 size;","attribute vec4 angle;","attribute vec4 color;","attribute vec4 opacity;"].join("\n"),varyings:["varying vec4 vColor;","#ifdef SHOULD_ROTATE_TEXTURE"," varying float vAngle;","#endif","#ifdef SHOULD_CALCULATE_SPRITE"," varying vec4 vSpriteSheet;","#endif"].join("\n"),branchAvoidanceFunctions:["float when_gt(float x, float y) {"," return max(sign(x - y), 0.0);","}","float when_lt(float x, float y) {"," return min( max(1.0 - sign(x - y), 0.0), 1.0 );","}","float when_eq( float x, float y ) {"," return 1.0 - abs( sign( x - y ) );","}","float when_ge(float x, float y) {"," return 1.0 - when_lt(x, y);","}","float when_le(float x, float y) {"," return 1.0 - when_gt(x, y);","}","float and(float a, float b) {"," return a * b;","}","float or(float a, float b) {"," return min(a + b, 1.0);","}"].join("\n"),unpackColor:["vec3 unpackColor( in float hex ) {"," vec3 c = vec3( 0.0 );"," float r = mod( (hex / PACKED_COLOR_SIZE / PACKED_COLOR_SIZE), PACKED_COLOR_SIZE );"," float g = mod( (hex / PACKED_COLOR_SIZE), PACKED_COLOR_SIZE );"," float b = mod( hex, PACKED_COLOR_SIZE );"," c.r = r / PACKED_COLOR_DIVISOR;"," c.g = g / PACKED_COLOR_DIVISOR;"," c.b = b / PACKED_COLOR_DIVISOR;"," return c;","}"].join("\n"),unpackRotationAxis:["vec3 unpackRotationAxis( in float hex ) {"," vec3 c = vec3( 0.0 );"," float r = mod( (hex / PACKED_COLOR_SIZE / PACKED_COLOR_SIZE), PACKED_COLOR_SIZE );"," float g = mod( (hex / PACKED_COLOR_SIZE), PACKED_COLOR_SIZE );"," float b = mod( hex, PACKED_COLOR_SIZE );"," c.r = r / PACKED_COLOR_DIVISOR;"," c.g = g / PACKED_COLOR_DIVISOR;"," c.b = b / PACKED_COLOR_DIVISOR;"," c *= vec3( 2.0 );"," c -= vec3( 1.0 );"," return c;","}"].join("\n"),floatOverLifetime:["float getFloatOverLifetime( in float positionInTime, in vec4 attr ) {"," highp float value = 0.0;"," float deltaAge = positionInTime * float( VALUE_OVER_LIFETIME_LENGTH - 1 );"," float fIndex = 0.0;"," float shouldApplyValue = 0.0;"," value += attr[ 0 ] * when_eq( deltaAge, 0.0 );",""," for( int i = 0; i < VALUE_OVER_LIFETIME_LENGTH - 1; ++i ) {"," fIndex = float( i );"," shouldApplyValue = and( when_gt( deltaAge, fIndex ), when_le( deltaAge, fIndex + 1.0 ) );"," value += shouldApplyValue * mix( attr[ i ], attr[ i + 1 ], deltaAge - fIndex );"," }",""," return value;","}"].join("\n"),colorOverLifetime:["vec3 getColorOverLifetime( in float positionInTime, in vec3 color1, in vec3 color2, in vec3 color3, in vec3 color4 ) {"," vec3 value = vec3( 0.0 );"," value.x = getFloatOverLifetime( positionInTime, vec4( color1.x, color2.x, color3.x, color4.x ) );"," value.y = getFloatOverLifetime( positionInTime, vec4( color1.y, color2.y, color3.y, color4.y ) );"," value.z = getFloatOverLifetime( positionInTime, vec4( color1.z, color2.z, color3.z, color4.z ) );"," return value;","}"].join("\n"),paramFetchingFunctions:["float getAlive() {"," return params.x;","}","float getAge() {"," return params.y;","}","float getMaxAge() {"," return params.z;","}","float getWiggle() {"," return params.w;","}"].join("\n"),forceFetchingFunctions:["vec4 getPosition( in float age ) {"," return modelViewMatrix * vec4( position, 1.0 );","}","vec3 getVelocity( in float age ) {"," return velocity * age;","}","vec3 getAcceleration( in float age ) {"," return acceleration.xyz * age;","}"].join("\n"),rotationFunctions:["#ifdef SHOULD_ROTATE_PARTICLES"," mat4 getRotationMatrix( in vec3 axis, in float angle) {"," axis = normalize(axis);"," float s = sin(angle);"," float c = cos(angle);"," float oc = 1.0 - c;",""," return mat4(oc * axis.x * axis.x + c, oc * axis.x * axis.y - axis.z * s, oc * axis.z * axis.x + axis.y * s, 0.0,"," oc * axis.x * axis.y + axis.z * s, oc * axis.y * axis.y + c, oc * axis.y * axis.z - axis.x * s, 0.0,"," oc * axis.z * axis.x - axis.y * s, oc * axis.y * axis.z + axis.x * s, oc * axis.z * axis.z + c, 0.0,"," 0.0, 0.0, 0.0, 1.0);"," }",""," vec3 getRotation( in vec3 pos, in float positionInTime ) {"," if( rotation.y == 0.0 ) {"," return pos;"," }",""," vec3 axis = unpackRotationAxis( rotation.x );"," vec3 center = rotationCenter;"," vec3 translated;"," mat4 rotationMatrix;"," float angle = 0.0;"," angle += when_eq( rotation.z, 0.0 ) * rotation.y;"," angle += when_gt( rotation.z, 0.0 ) * mix( 0.0, rotation.y, positionInTime );"," translated = rotationCenter - pos;"," rotationMatrix = getRotationMatrix( axis, angle );"," return center - vec3( rotationMatrix * vec4( translated, 0.0 ) );"," }","#endif"].join("\n"),rotateTexture:[" vec2 vUv = vec2( gl_PointCoord.x, 1.0 - gl_PointCoord.y );",""," #ifdef SHOULD_ROTATE_TEXTURE"," float x = gl_PointCoord.x - 0.5;"," float y = 1.0 - gl_PointCoord.y - 0.5;"," float c = cos( -vAngle );"," float s = sin( -vAngle );"," vUv = vec2( c * x + s * y + 0.5, c * y - s * x + 0.5 );"," #endif",""," #ifdef SHOULD_CALCULATE_SPRITE"," float framesX = vSpriteSheet.x;"," float framesY = vSpriteSheet.y;"," float columnNorm = vSpriteSheet.z;"," float rowNorm = vSpriteSheet.w;"," vUv.x = gl_PointCoord.x * framesX + columnNorm;"," vUv.y = 1.0 - (gl_PointCoord.y * framesY + rowNorm);"," #endif",""," vec4 rotatedTexture = texture2D( tex, vUv );"].join("\n")},Z.shaders={vertex:[Z.shaderChunks.defines,Z.shaderChunks.uniforms,Z.shaderChunks.attributes,Z.shaderChunks.varyings,F.ShaderChunk.common,F.ShaderChunk.logdepthbuf_pars_vertex,F.ShaderChunk.fog_pars_vertex,Z.shaderChunks.branchAvoidanceFunctions,Z.shaderChunks.unpackColor,Z.shaderChunks.unpackRotationAxis,Z.shaderChunks.floatOverLifetime,Z.shaderChunks.colorOverLifetime,Z.shaderChunks.paramFetchingFunctions,Z.shaderChunks.forceFetchingFunctions,Z.shaderChunks.rotationFunctions,"void main() {"," highp float age = getAge();"," highp float alive = getAlive();"," highp float maxAge = getMaxAge();"," highp float positionInTime = (age / maxAge);"," highp float isAlive = when_gt( alive, 0.0 );"," #ifdef SHOULD_WIGGLE_PARTICLES"," float wiggleAmount = positionInTime * getWiggle();"," float wiggleSin = isAlive * sin( wiggleAmount );"," float wiggleCos = isAlive * cos( wiggleAmount );"," #endif"," vec3 vel = getVelocity( age );"," vec3 accel = getAcceleration( age );"," vec3 force = vec3( 0.0 );"," vec3 pos = vec3( position );"," float drag = 1.0 - (positionInTime * 0.5) * acceleration.w;"," force += vel;"," force *= drag;"," force += accel * age;"," pos += force;"," #ifdef SHOULD_WIGGLE_PARTICLES"," pos.x += wiggleSin;"," pos.y += wiggleCos;"," pos.z += wiggleSin;"," #endif"," #ifdef SHOULD_ROTATE_PARTICLES"," pos = getRotation( pos, positionInTime );"," #endif"," vec4 mvPosition = modelViewMatrix * vec4( pos, 1.0 );"," highp float pointSize = getFloatOverLifetime( positionInTime, size ) * isAlive;"," #ifdef HAS_PERSPECTIVE"," float perspective = scale / length( mvPosition.xyz );"," #else"," float perspective = 1.0;"," #endif"," float pointSizePerspective = pointSize * perspective;"," #ifdef COLORIZE"," vec3 c = isAlive * getColorOverLifetime("," positionInTime,"," unpackColor( color.x ),"," unpackColor( color.y ),"," unpackColor( color.z ),"," unpackColor( color.w )"," );"," #else"," vec3 c = vec3(1.0);"," #endif"," float o = isAlive * getFloatOverLifetime( positionInTime, opacity );"," vColor = vec4( c, o );"," #ifdef SHOULD_ROTATE_TEXTURE"," vAngle = isAlive * getFloatOverLifetime( positionInTime, angle );"," #endif"," #ifdef SHOULD_CALCULATE_SPRITE"," float framesX = textureAnimation.x;"," float framesY = textureAnimation.y;"," float loopCount = textureAnimation.w;"," float totalFrames = textureAnimation.z;"," float frameNumber = mod( (positionInTime * loopCount) * totalFrames, totalFrames );"," float column = floor(mod( frameNumber, framesX ));"," float row = floor( (frameNumber - column) / framesX );"," float columnNorm = column / framesX;"," float rowNorm = row / framesY;"," vSpriteSheet.x = 1.0 / framesX;"," vSpriteSheet.y = 1.0 / framesY;"," vSpriteSheet.z = columnNorm;"," vSpriteSheet.w = rowNorm;"," #endif"," gl_PointSize = pointSizePerspective;"," gl_Position = projectionMatrix * mvPosition;",F.ShaderChunk.logdepthbuf_vertex,F.ShaderChunk.fog_vertex,"}"].join("\n"),fragment:[Z.shaderChunks.uniforms,F.ShaderChunk.common,F.ShaderChunk.fog_pars_fragment,F.ShaderChunk.logdepthbuf_pars_fragment,Z.shaderChunks.varyings,Z.shaderChunks.branchAvoidanceFunctions,"void main() {"," vec3 outgoingLight = vColor.xyz;"," "," #ifdef ALPHATEST"," if ( vColor.w < float(ALPHATEST) ) discard;"," #endif",Z.shaderChunks.rotateTexture,F.ShaderChunk.logdepthbuf_fragment," outgoingLight = vColor.xyz * rotatedTexture.xyz;"," gl_FragColor = vec4( outgoingLight.xyz, rotatedTexture.w * vColor.w );",F.ShaderChunk.fog_fragment,"}"].join("\n")},Z.utils={types:{BOOLEAN:"boolean",STRING:"string",NUMBER:"number",OBJECT:"object"},ensureTypedArg:function(t,e,r){return typeof t===e?t:r},ensureArrayTypedArg:function(t,e,r){if(Array.isArray(t)){for(var a=t.length-1;a>=0;--a)if(typeof t[a]!==e)return r;return t}return this.ensureTypedArg(t,e,r)},ensureInstanceOf:function(t,e,r){return void 0!==e&&t instanceof e?t:r},ensureArrayInstanceOf:function(t,e,r){if(Array.isArray(t)){for(var a=t.length-1;a>=0;--a)if(void 0!==e&&t[a]instanceof e==!1)return r;return t}return this.ensureInstanceOf(t,e,r)},ensureValueOverLifetimeCompliance:function(t,e,r){e=e||3,r=r||3,!1===Array.isArray(t._value)&&(t._value=[t._value]),!1===Array.isArray(t._spread)&&(t._spread=[t._spread]);var a=this.clamp(t._value.length,e,r),A=this.clamp(t._spread.length,e,r),s=Math.max(a,A);t._value.length!==s&&(t._value=this.interpolateArray(t._value,s)),t._spread.length!==s&&(t._spread=this.interpolateArray(t._spread,s))},interpolateArray:function(t,e){for(var r=t.length,a=["function"==typeof t[0].clone?t[0].clone():t[0]],A=(r-1)/(e-1),s=1;s<e-1;++s){var i=s*A,o=Math.floor(i),n=Math.ceil(i),l=i-o;a[s]=this.lerpTypeAgnostic(t[o],t[n],l)}return a.push("function"==typeof t[r-1].clone?t[r-1].clone():t[r-1]),a},clamp:function(t,e,r){return Math.max(e,Math.min(t,r))},zeroToEpsilon:function(t,e){var r=1e-5,a=t;return a=e?Math.random()*r*10:r,t<0&&t>-1e-5&&(a=-a),a},lerpTypeAgnostic:function(t,e,r){var a,A=this.types;return typeof t===A.NUMBER&&typeof e===A.NUMBER?t+(e-t)*r:t instanceof F.Vector2&&e instanceof F.Vector2?((a=t.clone()).x=this.lerp(t.x,e.x,r),a.y=this.lerp(t.y,e.y,r),a):t instanceof F.Vector3&&e instanceof F.Vector3?((a=t.clone()).x=this.lerp(t.x,e.x,r),a.y=this.lerp(t.y,e.y,r),a.z=this.lerp(t.z,e.z,r),a):t instanceof F.Vector4&&e instanceof F.Vector4?((a=t.clone()).x=this.lerp(t.x,e.x,r),a.y=this.lerp(t.y,e.y,r),a.z=this.lerp(t.z,e.z,r),a.w=this.lerp(t.w,e.w,r),a):t instanceof F.Color&&e instanceof F.Color?((a=t.clone()).r=this.lerp(t.r,e.r,r),a.g=this.lerp(t.g,e.g,r),a.b=this.lerp(t.b,e.b,r),a):void console.warn("Invalid argument types, or argument types do not match:",t,e)},lerp:function(t,e,r){return t+(e-t)*r},roundToNearestMultiple:function(t,e){var r;return 0===e||0===(r=Math.abs(t)%e)?t:t<0?-(Math.abs(t)-r):t+e-r},arrayValuesAreEqual:function(t){for(var e=0;e<t.length-1;++e)if(t[e]!==t[e+1])return!1;return!0},randomFloat:function(t,e){return t+e*(Math.random()-.5)},randomVector3:function(t,e,r,a,A){var s=r.x+(Math.random()*a.x-.5*a.x),i=r.y+(Math.random()*a.y-.5*a.y),o=r.z+(Math.random()*a.z-.5*a.z);A&&(s=.5*-A.x+this.roundToNearestMultiple(s,A.x),i=.5*-A.y+this.roundToNearestMultiple(i,A.y),o=.5*-A.z+this.roundToNearestMultiple(o,A.z)),t.typedArray.setVec3Components(e,s,i,o)},randomColor:function(t,e,r,a){var A=r.r+Math.random()*a.x,s=r.g+Math.random()*a.y,i=r.b+Math.random()*a.z;A=this.clamp(A,0,1),s=this.clamp(s,0,1),i=this.clamp(i,0,1),t.typedArray.setVec3Components(e,A,s,i)},randomColorAsHex:(X=new F.Color,function(t,e,r,a){for(var A=r.length,s=[],i=0;i<A;++i){var o=a[i];X.copy(r[i]),X.r+=Math.random()*o.x-.5*o.x,X.g+=Math.random()*o.y-.5*o.y,X.b+=Math.random()*o.z-.5*o.z,X.r=this.clamp(X.r,0,1),X.g=this.clamp(X.g,0,1),X.b=this.clamp(X.b,0,1),s.push(X.getHex())}t.typedArray.setVec4Components(e,s[0],s[1],s[2],s[3])}),randomVector3OnLine:function(t,e,r,a){var A=r.clone();A.lerp(a,Math.random()),t.typedArray.setVec3Components(e,A.x,A.y,A.z)},randomVector3OnSphere:function(t,e,r,a,A,s,i,o){var n=2*Math.random()-1,l=6.2832*Math.random(),p=Math.sqrt(1-n*n),y=this.randomFloat(a,A),u=0,k=0,S=0;i&&(y=Math.round(y/i)*i),u=p*Math.cos(l)*y,k=p*Math.sin(l)*y,S=n*y,u*=s.x,k*=s.y,S*=s.z,u+=r.x,k+=r.y,S+=r.z,t.typedArray.setVec3Components(e,u,k,S)},seededRandom:function(t){var e=1e4*Math.sin(t);return e-(0|e)},randomVector3OnDisc:function(t,e,r,a,A,s,i){var o=6.2832*Math.random(),n=Math.abs(this.randomFloat(a,A)),l=0,p=0,y=0;i&&(n=Math.round(n/i)*i),l=Math.cos(o)*n,p=Math.sin(o)*n,l*=s.x,p*=s.y,l+=r.x,p+=r.y,y+=r.z,t.typedArray.setVec3Components(e,l,p,y)},randomDirectionVector3OnSphere:(f=new F.Vector3,function(t,e,r,a,A,s,i,o){f.copy(s),f.x-=r,f.y-=a,f.z-=A,f.normalize().multiplyScalar(-this.randomFloat(i,o)),t.typedArray.setVec3Components(e,f.x,f.y,f.z)}),randomDirectionVector3OnDisc:function(){var t=new F.Vector3;return function(e,r,a,A,s,i,o,n){t.copy(i),t.x-=a,t.y-=A,t.z-=s,t.normalize().multiplyScalar(-this.randomFloat(o,n)),e.typedArray.setVec3Components(r,t.x,t.y,0)}}(),getPackedRotationAxis:function(){var t=new F.Vector3,e=new F.Vector3,r=new F.Color,a=new F.Vector3(1,1,1);return function(A,s){return t.copy(A).normalize(),e.copy(s).normalize(),t.x+=.5*-s.x+Math.random()*s.x,t.y+=.5*-s.y+Math.random()*s.y,t.z+=.5*-s.z+Math.random()*s.z,t.normalize().add(a).multiplyScalar(.5),r.setRGB(t.x,t.y,t.z),r.getHex()}}()},Z.Group=function(t){var e=Z.utils,r=e.types;(t=e.ensureTypedArg(t,r.OBJECT,{})).texture=e.ensureTypedArg(t.texture,r.OBJECT,{}),this.uuid=F.MathUtils.generateUUID(),this.fixedTimeStep=e.ensureTypedArg(t.fixedTimeStep,r.NUMBER,.016),this.texture=e.ensureInstanceOf(t.texture.value,F.Texture,null),this.textureFrames=e.ensureInstanceOf(t.texture.frames,F.Vector2,new F.Vector2(1,1)),this.textureFrameCount=e.ensureTypedArg(t.texture.frameCount,r.NUMBER,this.textureFrames.x*this.textureFrames.y),this.textureLoop=e.ensureTypedArg(t.texture.loop,r.NUMBER,1),this.textureFrames.max(new F.Vector2(1,1)),this.hasPerspective=e.ensureTypedArg(t.hasPerspective,r.BOOLEAN,!0),this.colorize=e.ensureTypedArg(t.colorize,r.BOOLEAN,!0),this.maxParticleCount=e.ensureTypedArg(t.maxParticleCount,r.NUMBER,null),this.blending=e.ensureTypedArg(t.blending,r.NUMBER,F.AdditiveBlending),this.transparent=e.ensureTypedArg(t.transparent,r.BOOLEAN,!0),this.alphaTest=parseFloat(e.ensureTypedArg(t.alphaTest,r.NUMBER,0)),this.depthWrite=e.ensureTypedArg(t.depthWrite,r.BOOLEAN,!1),this.depthTest=e.ensureTypedArg(t.depthTest,r.BOOLEAN,!0),this.fog=e.ensureTypedArg(t.fog,r.BOOLEAN,!0),this.scale=e.ensureTypedArg(t.scale,r.NUMBER,300),this.emitters=[],this.emitterIDs=[],this._pool=[],this._poolCreationSettings=null,this._createNewWhenPoolEmpty=0,this._attributesNeedRefresh=!1,this._attributesNeedDynamicReset=!1,this.particleCount=0,this.uniforms={tex:{type:"t",value:this.texture},textureAnimation:{type:"v4",value:new F.Vector4(this.textureFrames.x,this.textureFrames.y,this.textureFrameCount,Math.max(Math.abs(this.textureLoop),1))},fogColor:{type:"c",value:this.fog?new F.Color:null},fogNear:{type:"f",value:10},fogFar:{type:"f",value:200},fogDensity:{type:"f",value:.5},deltaTime:{type:"f",value:0},runTime:{type:"f",value:0},scale:{type:"f",value:this.scale}},this.defines={HAS_PERSPECTIVE:this.hasPerspective,COLORIZE:this.colorize,VALUE_OVER_LIFETIME_LENGTH:Z.valueOverLifetimeLength,SHOULD_ROTATE_TEXTURE:!1,SHOULD_ROTATE_PARTICLES:!1,SHOULD_WIGGLE_PARTICLES:!1,SHOULD_CALCULATE_SPRITE:this.textureFrames.x>1||this.textureFrames.y>1},this.attributes={position:new Z.ShaderAttribute("v3",!0),acceleration:new Z.ShaderAttribute("v4",!0),velocity:new Z.ShaderAttribute("v3",!0),rotation:new Z.ShaderAttribute("v4",!0),rotationCenter:new Z.ShaderAttribute("v3",!0),params:new Z.ShaderAttribute("v4",!0),size:new Z.ShaderAttribute("v4",!0),angle:new Z.ShaderAttribute("v4",!0),color:new Z.ShaderAttribute("v4",!0),opacity:new Z.ShaderAttribute("v4",!0)},this.attributeKeys=Object.keys(this.attributes),this.attributeCount=this.attributeKeys.length,this.material=new F.ShaderMaterial({uniforms:this.uniforms,vertexShader:Z.shaders.vertex,fragmentShader:Z.shaders.fragment,blending:this.blending,transparent:this.transparent,alphaTest:this.alphaTest,depthWrite:this.depthWrite,depthTest:this.depthTest,defines:this.defines,fog:this.fog}),this.geometry=new F.BufferGeometry,this.mesh=new F.Points(this.geometry,this.material),null===this.maxParticleCount&&console.warn("SPE.Group: No maxParticleCount specified. Adding emitters after rendering will probably cause errors.")},Z.Group.constructor=Z.Group,Z.Group.prototype._updateDefines=function(){for(var t,e=this.emitters,r=e.length-1,a=this.defines;r>=0;--r)t=e[r],a.SHOULD_CALCULATE_SPRITE||(a.SHOULD_ROTATE_TEXTURE=a.SHOULD_ROTATE_TEXTURE||!!Math.max(Math.max.apply(null,t.angle.value),Math.max.apply(null,t.angle.spread))),a.SHOULD_ROTATE_PARTICLES=a.SHOULD_ROTATE_PARTICLES||!!Math.max(t.rotation.angle,t.rotation.angleSpread),a.SHOULD_WIGGLE_PARTICLES=a.SHOULD_WIGGLE_PARTICLES||!!Math.max(t.wiggle.value,t.wiggle.spread);this.material.needsUpdate=!0},Z.Group.prototype._applyAttributesToGeometry=function(){var t,e,r=this.attributes,a=this.geometry,A=a.attributes;for(var s in r)r.hasOwnProperty(s)&&(t=r[s],(e=A[s])?e.array=t.typedArray.array:a.setAttribute(s,t.bufferAttribute),t.bufferAttribute.needsUpdate=!0);this.geometry.setDrawRange(0,this.particleCount)},Z.Group.prototype.addEmitter=function(t){if(t instanceof Z.Emitter!=!1)if(this.emitterIDs.indexOf(t.uuid)>-1)console.error("Emitter already exists in this group. Will not add again.");else{if(null===t.group){var e=this.attributes,r=this.particleCount,a=r+t.particleCount;for(var A in this.particleCount=a,null!==this.maxParticleCount&&this.particleCount>this.maxParticleCount&&console.warn("SPE.Group: maxParticleCount exceeded. Requesting",this.particleCount,"particles, can support only",this.maxParticleCount),t._calculatePPSValue(t.maxAge._value+t.maxAge._spread),t._setBufferUpdateRanges(this.attributeKeys),t._setAttributeOffset(r),t.group=this,t.attributes=this.attributes,e)e.hasOwnProperty(A)&&e[A]._createBufferAttribute(null!==this.maxParticleCount?this.maxParticleCount:this.particleCount);for(var s=r;s<a;++s)t._assignPositionValue(s),t._assignForceValue(s,"velocity"),t._assignForceValue(s,"acceleration"),t._assignAbsLifetimeValue(s,"opacity"),t._assignAbsLifetimeValue(s,"size"),t._assignAngleValue(s),t._assignRotationValue(s),t._assignParamsValue(s),t._assignColorValue(s);return this._applyAttributesToGeometry(),this.emitters.push(t),this.emitterIDs.push(t.uuid),this._updateDefines(t),this.material.needsUpdate=!0,this.geometry.needsUpdate=!0,this._attributesNeedRefresh=!0,this}console.error("Emitter already belongs to another group. Will not add to requested group.")}else console.error("`emitter` argument must be instance of SPE.Emitter. Was provided with:",t)},Z.Group.prototype.removeEmitter=function(t){var e=this.emitterIDs.indexOf(t.uuid);if(t instanceof Z.Emitter!=!1)if(-1!==e){for(var r=t.attributeOffset,a=r+t.particleCount,A=this.attributes.params.typedArray,s=r;s<a;++s)A.array[4*s]=0,A.array[4*s+1]=0;for(var i in this.emitters.splice(e,1),this.emitterIDs.splice(e,1),this.attributes)this.attributes.hasOwnProperty(i)&&this.attributes[i].splice(r,a);this.particleCount-=t.particleCount,t._onRemove(),this._attributesNeedRefresh=!0}else console.error("Emitter does not exist in this group. Will not remove.");else console.error("`emitter` argument must be instance of SPE.Emitter. Was provided with:",t)},Z.Group.prototype.getFromPool=function(){var t=this._pool,e=this._createNewWhenPoolEmpty;if(t.length)return t.pop();if(e){var r=new Z.Emitter(this._poolCreationSettings);return this.addEmitter(r),r}return null},Z.Group.prototype.releaseIntoPool=function(t){if(t instanceof Z.Emitter!=!1)return t.reset(),this._pool.unshift(t),this;console.error("Argument is not instanceof SPE.Emitter:",t)},Z.Group.prototype.getPool=function(){return this._pool},Z.Group.prototype.addPool=function(t,e,r){var a;this._poolCreationSettings=e,this._createNewWhenPoolEmpty=!!r;for(var A=0;A<t;++A)a=Array.isArray(e)?new Z.Emitter(e[A]):new Z.Emitter(e),this.addEmitter(a),this.releaseIntoPool(a);return this},Z.Group.prototype._triggerSingleEmitter=function(t){var e=this.getFromPool(),r=this;if(null!==e)return t instanceof F.Vector3&&(e.position.value.copy(t),e.position.value=e.position.value),e.enable(),setTimeout((function(){e.disable(),r.releaseIntoPool(e)}),1e3*Math.max(e.duration,e.maxAge.value+e.maxAge.spread)),this;console.log("SPE.Group pool ran out.")},Z.Group.prototype.triggerPoolEmitter=function(t,e){if("number"==typeof t&&t>1)for(var r=0;r<t;++r)this._triggerSingleEmitter(e);else this._triggerSingleEmitter(e);return this},Z.Group.prototype._updateUniforms=function(t){this.uniforms.runTime.value+=t,this.uniforms.deltaTime.value=t},Z.Group.prototype._resetBufferRanges=function(){for(var t=this.attributeKeys,e=this.attributeCount-1,r=this.attributes;e>=0;--e)r[t[e]].resetUpdateRange()},Z.Group.prototype._updateBuffers=function(t){for(var e,r,a,A=this.attributeKeys,s=this.attributeCount-1,i=this.attributes,o=t.bufferUpdateRanges;s>=0;--s)r=o[e=A[s]],(a=i[e]).setUpdateRange(r.min,r.max),a.flagUpdate()},Z.Group.prototype.tick=function(t){var e=this.emitters,r=e.length,a=t||this.fixedTimeStep,A=this.attributeKeys,s=this.attributes;if(this._updateUniforms(a),this._resetBufferRanges(),0!==r||!1!==this._attributesNeedRefresh||!1!==this._attributesNeedDynamicReset){for(var i,o=0;o<r;++o)(i=e[o]).tick(a),this._updateBuffers(i);if(!0===this._attributesNeedDynamicReset){for(o=this.attributeCount-1;o>=0;--o)s[A[o]].resetDynamic();this._attributesNeedDynamicReset=!1}if(!0===this._attributesNeedRefresh){for(o=this.attributeCount-1;o>=0;--o)s[A[o]].forceUpdateAll();this._attributesNeedRefresh=!1,this._attributesNeedDynamicReset=!0}}},Z.Group.prototype.dispose=function(){return this.geometry.dispose(),this.material.dispose(),this},Z.Emitter=function(t){var e=Z.utils,r=e.types,a=Z.valueOverLifetimeLength;for(var A in(t=e.ensureTypedArg(t,r.OBJECT,{})).position=e.ensureTypedArg(t.position,r.OBJECT,{}),t.velocity=e.ensureTypedArg(t.velocity,r.OBJECT,{}),t.acceleration=e.ensureTypedArg(t.acceleration,r.OBJECT,{}),t.radius=e.ensureTypedArg(t.radius,r.OBJECT,{}),t.drag=e.ensureTypedArg(t.drag,r.OBJECT,{}),t.rotation=e.ensureTypedArg(t.rotation,r.OBJECT,{}),t.color=e.ensureTypedArg(t.color,r.OBJECT,{}),t.opacity=e.ensureTypedArg(t.opacity,r.OBJECT,{}),t.size=e.ensureTypedArg(t.size,r.OBJECT,{}),t.angle=e.ensureTypedArg(t.angle,r.OBJECT,{}),t.wiggle=e.ensureTypedArg(t.wiggle,r.OBJECT,{}),t.maxAge=e.ensureTypedArg(t.maxAge,r.OBJECT,{}),t.onParticleSpawn&&console.warn("onParticleSpawn has been removed. Please set properties directly to alter values at runtime."),this.uuid=F.MathUtils.generateUUID(),this.type=e.ensureTypedArg(t.type,r.NUMBER,Z.distributions.BOX),this.position={_value:e.ensureInstanceOf(t.position.value,F.Vector3,new F.Vector3),_spread:e.ensureInstanceOf(t.position.spread,F.Vector3,new F.Vector3),_spreadClamp:e.ensureInstanceOf(t.position.spreadClamp,F.Vector3,new F.Vector3),_distribution:e.ensureTypedArg(t.position.distribution,r.NUMBER,this.type),_randomise:e.ensureTypedArg(t.position.randomise,r.BOOLEAN,!1),_radius:e.ensureTypedArg(t.position.radius,r.NUMBER,10),_radiusScale:e.ensureInstanceOf(t.position.radiusScale,F.Vector3,new F.Vector3(1,1,1)),_distributionClamp:e.ensureTypedArg(t.position.distributionClamp,r.NUMBER,0)},this.velocity={_value:e.ensureInstanceOf(t.velocity.value,F.Vector3,new F.Vector3),_spread:e.ensureInstanceOf(t.velocity.spread,F.Vector3,new F.Vector3),_distribution:e.ensureTypedArg(t.velocity.distribution,r.NUMBER,this.type),_randomise:e.ensureTypedArg(t.position.randomise,r.BOOLEAN,!1)},this.acceleration={_value:e.ensureInstanceOf(t.acceleration.value,F.Vector3,new F.Vector3),_spread:e.ensureInstanceOf(t.acceleration.spread,F.Vector3,new F.Vector3),_distribution:e.ensureTypedArg(t.acceleration.distribution,r.NUMBER,this.type),_randomise:e.ensureTypedArg(t.position.randomise,r.BOOLEAN,!1)},this.drag={_value:e.ensureTypedArg(t.drag.value,r.NUMBER,0),_spread:e.ensureTypedArg(t.drag.spread,r.NUMBER,0),_randomise:e.ensureTypedArg(t.position.randomise,r.BOOLEAN,!1)},this.wiggle={_value:e.ensureTypedArg(t.wiggle.value,r.NUMBER,0),_spread:e.ensureTypedArg(t.wiggle.spread,r.NUMBER,0)},this.rotation={_axis:e.ensureInstanceOf(t.rotation.axis,F.Vector3,new F.Vector3(0,1,0)),_axisSpread:e.ensureInstanceOf(t.rotation.axisSpread,F.Vector3,new F.Vector3),_angle:e.ensureTypedArg(t.rotation.angle,r.NUMBER,0),_angleSpread:e.ensureTypedArg(t.rotation.angleSpread,r.NUMBER,0),_static:e.ensureTypedArg(t.rotation.static,r.BOOLEAN,!1),_center:e.ensureInstanceOf(t.rotation.center,F.Vector3,this.position._value.clone()),_randomise:e.ensureTypedArg(t.position.randomise,r.BOOLEAN,!1)},this.maxAge={_value:e.ensureTypedArg(t.maxAge.value,r.NUMBER,2),_spread:e.ensureTypedArg(t.maxAge.spread,r.NUMBER,0)},this.color={_value:e.ensureArrayInstanceOf(t.color.value,F.Color,new F.Color),_spread:e.ensureArrayInstanceOf(t.color.spread,F.Vector3,new F.Vector3),_randomise:e.ensureTypedArg(t.position.randomise,r.BOOLEAN,!1)},this.opacity={_value:e.ensureArrayTypedArg(t.opacity.value,r.NUMBER,1),_spread:e.ensureArrayTypedArg(t.opacity.spread,r.NUMBER,0),_randomise:e.ensureTypedArg(t.position.randomise,r.BOOLEAN,!1)},this.size={_value:e.ensureArrayTypedArg(t.size.value,r.NUMBER,1),_spread:e.ensureArrayTypedArg(t.size.spread,r.NUMBER,0),_randomise:e.ensureTypedArg(t.position.randomise,r.BOOLEAN,!1)},this.angle={_value:e.ensureArrayTypedArg(t.angle.value,r.NUMBER,0),_spread:e.ensureArrayTypedArg(t.angle.spread,r.NUMBER,0),_randomise:e.ensureTypedArg(t.position.randomise,r.BOOLEAN,!1)},this.particleCount=e.ensureTypedArg(t.particleCount,r.NUMBER,100),this.duration=e.ensureTypedArg(t.duration,r.NUMBER,null),this.isStatic=e.ensureTypedArg(t.isStatic,r.BOOLEAN,!1),this.activeMultiplier=e.ensureTypedArg(t.activeMultiplier,r.NUMBER,1),this.direction=e.ensureTypedArg(t.direction,r.NUMBER,1),this.alive=e.ensureTypedArg(t.alive,r.BOOLEAN,!0),this.particlesPerSecond=0,this.activationIndex=0,this.attributeOffset=0,this.attributeEnd=0,this.age=0,this.activeParticleCount=0,this.group=null,this.attributes=null,this.paramsArray=null,this.resetFlags={position:e.ensureTypedArg(t.position.randomise,r.BOOLEAN,!1)||e.ensureTypedArg(t.radius.randomise,r.BOOLEAN,!1),velocity:e.ensureTypedArg(t.velocity.randomise,r.BOOLEAN,!1),acceleration:e.ensureTypedArg(t.acceleration.randomise,r.BOOLEAN,!1)||e.ensureTypedArg(t.drag.randomise,r.BOOLEAN,!1),rotation:e.ensureTypedArg(t.rotation.randomise,r.BOOLEAN,!1),rotationCenter:e.ensureTypedArg(t.rotation.randomise,r.BOOLEAN,!1),size:e.ensureTypedArg(t.size.randomise,r.BOOLEAN,!1),color:e.ensureTypedArg(t.color.randomise,r.BOOLEAN,!1),opacity:e.ensureTypedArg(t.opacity.randomise,r.BOOLEAN,!1),angle:e.ensureTypedArg(t.angle.randomise,r.BOOLEAN,!1)},this.updateFlags={},this.updateCounts={},this.updateMap={maxAge:"params",position:"position",velocity:"velocity",acceleration:"acceleration",drag:"acceleration",wiggle:"params",rotation:"rotation",size:"size",color:"color",opacity:"opacity",angle:"angle"},this.updateMap)this.updateMap.hasOwnProperty(A)&&(this.updateCounts[this.updateMap[A]]=0,this.updateFlags[this.updateMap[A]]=!1,this._createGetterSetters(this[A],A));this.bufferUpdateRanges={},this.attributeKeys=null,this.attributeCount=0,e.ensureValueOverLifetimeCompliance(this.color,a,a),e.ensureValueOverLifetimeCompliance(this.opacity,a,a),e.ensureValueOverLifetimeCompliance(this.size,a,a),e.ensureValueOverLifetimeCompliance(this.angle,a,a)},Z.Emitter.constructor=Z.Emitter,Z.Emitter.prototype._createGetterSetters=function(t,e){var r=this;for(var a in t)if(t.hasOwnProperty(a)){var A=a.replace("_","");Object.defineProperty(t,A,{get:function(t){return function(){return this[t]}}(a),set:function(t){return function(a){var A=r.updateMap[e],s=this[t],i=Z.valueOverLifetimeLength;"_rotationCenter"===t?(r.updateFlags.rotationCenter=!0,r.updateCounts.rotationCenter=0):"_randomise"===t?r.resetFlags[A]=a:(r.updateFlags[A]=!0,r.updateCounts[A]=0),r.group._updateDefines(),this[t]=a,Array.isArray(s)&&Z.utils.ensureValueOverLifetimeCompliance(r[e],i,i)}}(a)})}},Z.Emitter.prototype._setBufferUpdateRanges=function(t){this.attributeKeys=t,this.attributeCount=t.length;for(var e=this.attributeCount-1;e>=0;--e)this.bufferUpdateRanges[t[e]]={min:Number.POSITIVE_INFINITY,max:Number.NEGATIVE_INFINITY}},Z.Emitter.prototype._calculatePPSValue=function(t){var e=this.particleCount;this.duration?this.particlesPerSecond=e/(t<this.duration?t:this.duration):this.particlesPerSecond=e/t},Z.Emitter.prototype._setAttributeOffset=function(t){this.attributeOffset=t,this.activationIndex=t,this.activationEnd=t+this.particleCount},Z.Emitter.prototype._assignValue=function(t,e){switch(t){case"position":this._assignPositionValue(e);break;case"velocity":case"acceleration":this._assignForceValue(e,t);break;case"size":case"opacity":this._assignAbsLifetimeValue(e,t);break;case"angle":this._assignAngleValue(e);break;case"params":this._assignParamsValue(e);break;case"rotation":this._assignRotationValue(e);break;case"color":this._assignColorValue(e)}},Z.Emitter.prototype._assignPositionValue=function(t){var e=Z.distributions,r=Z.utils,a=this.position,A=this.attributes.position,s=a._value,i=a._spread;switch(a._distribution){case e.BOX:r.randomVector3(A,t,s,i,a._spreadClamp);break;case e.SPHERE:r.randomVector3OnSphere(A,t,s,a._radius,a._spread.x,a._radiusScale,a._spreadClamp.x,a._distributionClamp||this.particleCount);break;case e.DISC:r.randomVector3OnDisc(A,t,s,a._radius,a._spread.x,a._radiusScale,a._spreadClamp.x);break;case e.LINE:r.randomVector3OnLine(A,t,s,i)}},Z.Emitter.prototype._assignForceValue=function(t,e){var r,a,A,s,i,o=Z.distributions,n=Z.utils,l=this[e],p=l._value,y=l._spread;switch(l._distribution){case o.BOX:n.randomVector3(this.attributes[e],t,p,y);break;case o.SPHERE:a=(r=this.attributes.position.typedArray.array)[i=3*t],A=r[i+1],s=r[i+2],n.randomDirectionVector3OnSphere(this.attributes[e],t,a,A,s,this.position._value,l._value.x,l._spread.x);break;case o.DISC:a=(r=this.attributes.position.typedArray.array)[i=3*t],A=r[i+1],s=r[i+2],n.randomDirectionVector3OnDisc(this.attributes[e],t,a,A,s,this.position._value,l._value.x,l._spread.x);break;case o.LINE:n.randomVector3OnLine(this.attributes[e],t,p,y)}if("acceleration"===e){var u=n.clamp(n.randomFloat(this.drag._value,this.drag._spread),0,1);this.attributes.acceleration.typedArray.array[4*t+3]=u}},Z.Emitter.prototype._assignAbsLifetimeValue=function(t,e){var r,a=this.attributes[e].typedArray,A=this[e],s=Z.utils;s.arrayValuesAreEqual(A._value)&&s.arrayValuesAreEqual(A._spread)?(r=Math.abs(s.randomFloat(A._value[0],A._spread[0])),a.setVec4Components(t,r,r,r,r)):a.setVec4Components(t,Math.abs(s.randomFloat(A._value[0],A._spread[0])),Math.abs(s.randomFloat(A._value[1],A._spread[1])),Math.abs(s.randomFloat(A._value[2],A._spread[2])),Math.abs(s.randomFloat(A._value[3],A._spread[3])))},Z.Emitter.prototype._assignAngleValue=function(t){var e,r=this.attributes.angle.typedArray,a=this.angle,A=Z.utils;A.arrayValuesAreEqual(a._value)&&A.arrayValuesAreEqual(a._spread)?(e=A.randomFloat(a._value[0],a._spread[0]),r.setVec4Components(t,e,e,e,e)):r.setVec4Components(t,A.randomFloat(a._value[0],a._spread[0]),A.randomFloat(a._value[1],a._spread[1]),A.randomFloat(a._value[2],a._spread[2]),A.randomFloat(a._value[3],a._spread[3]))},Z.Emitter.prototype._assignParamsValue=function(t){this.attributes.params.typedArray.setVec4Components(t,this.isStatic?1:0,0,Math.abs(Z.utils.randomFloat(this.maxAge._value,this.maxAge._spread)),Z.utils.randomFloat(this.wiggle._value,this.wiggle._spread))},Z.Emitter.prototype._assignRotationValue=function(t){this.attributes.rotation.typedArray.setVec3Components(t,Z.utils.getPackedRotationAxis(this.rotation._axis,this.rotation._axisSpread),Z.utils.randomFloat(this.rotation._angle,this.rotation._angleSpread),this.rotation._static?0:1),this.attributes.rotationCenter.typedArray.setVec3(t,this.rotation._center)},Z.Emitter.prototype._assignColorValue=function(t){Z.utils.randomColorAsHex(this.attributes.color,t,this.color._value,this.color._spread)},Z.Emitter.prototype._resetParticle=function(t){for(var e,r,a=this.resetFlags,A=this.updateFlags,s=this.updateCounts,i=this.attributeKeys,o=this.attributeCount-1;o>=0;--o)r=A[e=i[o]],!0!==a[e]&&!0!==r||(this._assignValue(e,t),this._updateAttributeUpdateRange(e,t),!0===r&&s[e]===this.particleCount?(A[e]=!1,s[e]=0):1==r&&++s[e])},Z.Emitter.prototype._updateAttributeUpdateRange=function(t,e){var r=this.bufferUpdateRanges[t];r.min=Math.min(e,r.min),r.max=Math.max(e,r.max)},Z.Emitter.prototype._resetBufferRanges=function(){for(var t,e=this.bufferUpdateRanges,r=this.bufferUpdateKeys,a=this.bufferUpdateCount-1;a>=0;--a)e[t=r[a]].min=Number.POSITIVE_INFINITY,e[t].max=Number.NEGATIVE_INFINITY},Z.Emitter.prototype._onRemove=function(){this.particlesPerSecond=0,this.attributeOffset=0,this.activationIndex=0,this.activeParticleCount=0,this.group=null,this.attributes=null,this.paramsArray=null,this.age=0},Z.Emitter.prototype._decrementParticleCount=function(){--this.activeParticleCount},Z.Emitter.prototype._incrementParticleCount=function(){++this.activeParticleCount},Z.Emitter.prototype._checkParticleAges=function(t,e,r,a){for(var A,s,i,o,n=e-1;n>=t;--n)0!==(o=r[A=4*n])&&(i=r[A+1],s=r[A+2],1===this.direction?(i+=a)>=s&&(i=0,o=0,this._decrementParticleCount()):(i-=a)<=0&&(i=s,o=0,this._decrementParticleCount()),r[A]=o,r[A+1]=i,this._updateAttributeUpdateRange("params",n))},Z.Emitter.prototype._activateParticles=function(t,e,r,a){for(var A,s,i=this.direction,o=t;o<e;++o)0!=r[A=4*o]&&1!==this.particleCount||(this._incrementParticleCount(),r[A]=1,this._resetParticle(o),s=a*(o-t),r[A+1]=-1===i?r[A+2]-s:s,this._updateAttributeUpdateRange("params",o))},Z.Emitter.prototype.tick=function(t){if(!this.isStatic){null===this.paramsArray&&(this.paramsArray=this.attributes.params.typedArray.array);var e=this.attributeOffset,r=e+this.particleCount,a=this.paramsArray,A=this.particlesPerSecond*this.activeMultiplier*t,s=this.activationIndex;if(this._resetBufferRanges(),this._checkParticleAges(e,r,a,t),!1!==this.alive){if(null!==this.duration&&this.age>this.duration)return this.alive=!1,void(this.age=0);var i=1===this.particleCount?s:0|s,o=Math.min(i+A,this.activationEnd),n=o-this.activationIndex|0,l=n>0?t/n:0;this._activateParticles(i,o,a,l),this.activationIndex+=A,this.activationIndex>r&&(this.activationIndex=e),this.age+=t}else this.age=0}},Z.Emitter.prototype.reset=function(t){if(this.age=0,this.alive=!1,!0===t){for(var e,r=this.attributeOffset,a=r+this.particleCount,A=this.paramsArray,s=this.attributes.params.bufferAttribute,i=a-1;i>=r;--i)A[e=4*i]=0,A[e+1]=0;s.updateRange.offset=0,s.updateRange.count=-1,s.needsUpdate=!0}return this},Z.Emitter.prototype.enable=function(){return this.alive=!0,this},Z.Emitter.prototype.disable=function(){return this.alive=!1,this},Z.Emitter.prototype.remove=function(){return null!==this.group?this.group.removeEmitter(this):console.error("Emitter does not belong to a group, cannot remove."),this};var G="",Q={vertexShader:"\n #include <common>\n #include <logdepthbuf_pars_vertex>\n uniform float pixelRatio;\n uniform float time;\n attribute float size; \n attribute float speed; \n attribute float opacity;\n attribute vec3 noise;\n attribute vec3 color;\n varying vec3 vColor;\n varying float vOpacity;\n void main() {\n vec4 modelPosition = modelMatrix * vec4(position, 1.0);\n modelPosition.y += sin(time * speed + modelPosition.x * noise.x * 100.0) * 0.2;\n modelPosition.z += cos(time * speed + modelPosition.x * noise.y * 100.0) * 0.2;\n modelPosition.x += cos(time * speed + modelPosition.x * noise.z * 100.0) * 0.2;\n vec4 viewPosition = viewMatrix * modelPosition;\n vec4 projectionPostion = projectionMatrix * viewPosition;\n gl_Position = projectionPostion;\n gl_PointSize = size * 25. * pixelRatio;\n gl_PointSize *= (1.0 / - viewPosition.z);\n vColor = color;\n vOpacity = opacity;\n\n\t #include <logdepthbuf_vertex>\n }",fragmentShader:"\n #include <common>\n #include <logdepthbuf_pars_fragment>\n varying vec3 vColor;\n varying float vOpacity;\n void main() {\n float distanceToCenter = distance(gl_PointCoord, vec2(0.5));\n float strength = 0.05 / distanceToCenter - 0.1;\n gl_FragColor = vec4(vColor, strength * vOpacity);\n #include <tonemapping_fragment>\n #include <colorspace_fragment>\n #include <logdepthbuf_fragment>\n }"};const E=t=>t&&t.constructor===Float32Array,D=t=>void 0!==(null==t?void 0:t.x)&&void 0!==(null==t?void 0:t.y)&&void 0!==(null==t?void 0:t.z),w=t=>Array.isArray(t)?t:D(t)?[t.x,t.y,t.z]:[t,t,t];function O(e,r,a){if(void 0!==r){if(E(r))return r;if(r instanceof t){const t=Array.from({length:3*e},(()=>(t=>[t.r,t.g,t.b])(r))).flat();return Float32Array.from(t)}if(D(r)||Array.isArray(r)){const t=Array.from({length:3*e},(()=>w(r))).flat();return Float32Array.from(t)}return Float32Array.from({length:e},(()=>r))}return Float32Array.from({length:e},a)}const M={uniforms:{tDiffuse:{value:null},h:{value:1/512}},vertexShader:"\n\n\t\tvarying vec2 vUv;\n\n\t\tvoid main() {\n\n\t\t\tvUv = uv;\n\t\t\tgl_Position = projectionMatrix * modelViewMatrix * vec4( position, 1.0 );\n\n\t\t}",fragmentShader:"\n\n\t\tuniform sampler2D tDiffuse;\n\t\tuniform float h;\n\n\t\tvarying vec2 vUv;\n\n\t\tvoid main() {\n\n\t\t\tvec4 sum = vec4( 0.0 );\n\n\t\t\tsum += texture2D( tDiffuse, vec2( vUv.x - 4.0 * h, vUv.y ) ) * 0.051;\n\t\t\tsum += texture2D( tDiffuse, vec2( vUv.x - 3.0 * h, vUv.y ) ) * 0.0918;\n\t\t\tsum += texture2D( tDiffuse, vec2( vUv.x - 2.0 * h, vUv.y ) ) * 0.12245;\n\t\t\tsum += texture2D( tDiffuse, vec2( vUv.x - 1.0 * h, vUv.y ) ) * 0.1531;\n\t\t\tsum += texture2D( tDiffuse, vec2( vUv.x, vUv.y ) ) * 0.1633;\n\t\t\tsum += texture2D( tDiffuse, vec2( vUv.x + 1.0 * h, vUv.y ) ) * 0.1531;\n\t\t\tsum += texture2D( tDiffuse, vec2( vUv.x + 2.0 * h, vUv.y ) ) * 0.12245;\n\t\t\tsum += texture2D( tDiffuse, vec2( vUv.x + 3.0 * h, vUv.y ) ) * 0.0918;\n\t\t\tsum += texture2D( tDiffuse, vec2( vUv.x + 4.0 * h, vUv.y ) ) * 0.051;\n\n\t\t\tgl_FragColor = sum;\n\n\t\t}"},P={uniforms:{tDiffuse:{value:null},v:{value:1/512}},vertexShader:"\n\n\t\tvarying vec2 vUv;\n\n\t\tvoid main() {\n\n\t\t\tvUv = uv;\n\t\t\tgl_Position = projectionMatrix * modelViewMatrix * vec4( position, 1.0 );\n\n\t\t}",fragmentShader:"\n\n\t\tuniform sampler2D tDiffuse;\n\t\tuniform float v;\n\n\t\tvarying vec2 vUv;\n\n\t\tvoid main() {\n\n\t\t\tvec4 sum = vec4( 0.0 );\n\n\t\t\tsum += texture2D( tDiffuse, vec2( vUv.x, vUv.y - 4.0 * v ) ) * 0.051;\n\t\t\tsum += texture2D( tDiffuse, vec2( vUv.x, vUv.y - 3.0 * v ) ) * 0.0918;\n\t\t\tsum += texture2D( tDiffuse, vec2( vUv.x, vUv.y - 2.0 * v ) ) * 0.12245;\n\t\t\tsum += texture2D( tDiffuse, vec2( vUv.x, vUv.y - 1.0 * v ) ) * 0.1531;\n\t\t\tsum += texture2D( tDiffuse, vec2( vUv.x, vUv.y ) ) * 0.1633;\n\t\t\tsum += texture2D( tDiffuse, vec2( vUv.x, vUv.y + 1.0 * v ) ) * 0.1531;\n\t\t\tsum += texture2D( tDiffuse, vec2( vUv.x, vUv.y + 2.0 * v ) ) * 0.12245;\n\t\t\tsum += texture2D( tDiffuse, vec2( vUv.x, vUv.y + 3.0 * v ) ) * 0.0918;\n\t\t\tsum += texture2D( tDiffuse, vec2( vUv.x, vUv.y + 4.0 * v ) ) * 0.051;\n\n\t\t\tgl_FragColor = sum;\n\n\t\t}"};var Y=Object.defineProperty,z=(t,e,r)=>(((t,e,r)=>{e in t?Y(t,e,{enumerable:!0,configurable:!0,writable:!0,value:r}):t[e]=r})(t,"symbol"!=typeof e?e+"":e,r),r);function _(t){return void 0!==t.w?[e,4]:void 0!==t.z?[r,3]:[a,2]}function $(t,e,r){let a=function(t,e){const r=Math.sqrt(t.lengthSq()*e.lengthSq());if(0===r)return 0;let a=t.dot(e)/r;return a=Math.max(-1,Math.min(1,a)),Math.acos(a)}(t,e);return 0===a?a:t.clone().cross(e).dot(r)<0?-a:a}const tt=180/Math.PI,et={yaw:[{name:"前",range:[-15,15]},{name:"左",range:[15,165]},{name:"右",range:[-165,-15]},{name:"后",range:[-180.1,-165]},{name:"后",range:[165,180.1]}],pitch:[{name:"前",range:[-15,15]},{name:"上",range:[15,165]},{name:"下",range:[-165,-15]},{name:"后",range:[-180.1,-165]},{name:"后",range:[165,180.1]}],roll:[{name:"上",range:[-15,15]},{name:"左",range:[15,165]},{name:"右",range:[-165,-15]},{name:"下",range:[-180.1,-165]},{name:"下",range:[165,180.1]}]};const rt={degrees:!0,map:et,front:{x:0,y:0,z:1},up:{x:0,y:1,z:0}};let at=class{constructor(t){z(this,"_options"),z(this,"_listMap"),z(this,"_front"),z(this,"_up"),t&&(this.options=t)}static get options(){return this._options??(this.options=rt)}static set options(t){this._options=Object.assign({},structuredClone(et),t)}get defaultOptions(){return this.constructor.options}get options(){return this._options??(this.options=this.defaultOptions)}set options(t){this._options=Object.assign({},structuredClone(this.defaultOptions),t),this._listMap=null,this._front=null,this._up=null}get degrees(){return this.options.degrees??(this.options.degrees=this.defaultOptions.degrees??!0)}set degrees(t){this.options.degrees=t}get map(){return this.options.map||(this.map=this.defaultOptions.map),this.options.map}set map(t){const e=structuredClone(this.defaultOptions.map),r=structuredClone(et);t=t?{yaw:t.yaw??e.yaw??r.yaw,pitch:t.pitch??e.pitch??r.pitch,roll:t.roll??e.roll??r.roll}:e,this.options.map=t,this._listMap=null}get listMap(){return this._listMap??(this._listMap=function(t){const e={};for(const[r,a]of Object.entries(t))e[r]=Array.isArray(a)?a:Object.entries(a).map((([t,e])=>({name:t,range:e})));return e}(this.map??{}))}get front(){return this._front||(this.front=this.options.front??this.defaultOptions.front??rt.front),this._front}set front(t){this._front=(new r).copy(t)}get up(){return this._up||(this.up=this.options.up??this.defaultOptions.up??rt.up),this._up}set up(t){this._up=(new r).copy(t)}computeAzimuth(t,e,a){const A=(new r).copy(t),s=(new r).copy(e??this.front),i=(new r).copy(a??this.up);let{yaw:o,pitch:n,roll:l}=function(t,e,r){const a=e.clone().negate(),A=r.clone().projectOnPlane(e),s=$(e,t.clone().projectOnPlane(A),A),i=e.clone().cross(A);return{yaw:s,pitch:$(e,t.clone().projectOnPlane(i),i),roll:$(A,t.clone().projectOnPlane(a),a)}}(A,s,i);return this.degrees&&(o*=tt,n*=tt,l*=tt),{yaw:{angle:o,name:this.findAzimuthNames("yaw",o)},pitch:{angle:n,name:this.findAzimuthNames("pitch",n)},roll:{angle:l,name:this.findAzimuthNames("roll",l)}}}findAzimuthNames(t,e){const r=[],a=this.listMap[t];if(!a)return r;for(const{name:t,range:[A,s]}of a)(e>=A&&e<s||e<=A&&e>s)&&r.push(t);return r}};z(at,"_options"),new at,new A;var At=Object.defineProperty,st=(t,e,r)=>(((t,e,r)=>{e in t?At(t,e,{enumerable:!0,configurable:!0,writable:!0,value:r}):t[e]=r})(t,"symbol"!=typeof e?e+"":e,r),r);function it(t){const e=[];for(let r=0;r<t;r++)e.push(s.randFloatSpread(2));return e}function ot(t,e,r){const a=[],A=t-1;for(let t=0;t<A;t++){const t=2*(Math.random()-.5)*(e+r);a.push(t)}const s=Math.trunc(Math.random()*t);let i=2*(Math.random()-.5)*r;return i+=Math.sign(i)*e,a.splice(s,0,i),a}function nt(t,e){const r=[],a=t-1;for(let t=0;t<a;t++)r.push(s.randFloatSpread(2));return r.push(Math.random()*e),r}function lt(t,e,r,a){const A=[],s=t-1,i=s-1;for(let t=0;t<i;t++){const t=2*(Math.random()-.5)*(e+r);A.push(t)}const o=Math.trunc(Math.random()*s);let n=2*(Math.random()-.5)*r;return n+=Math.sign(n)*e,A.splice(o,0,n),A.push(Math.random()*a),A}function pt(t){let e=[];for(let r=0;r<t;r++)e.push(s.randFloatSpread(2));const r=Math.hypot(...e),a=Math.random()/r;return e=e.map((t=>t*a)),e}function yt(t,e,r){let a=[];for(let e=0;e<t;e++)a.push(s.randFloatSpread(2));const A=Math.hypot(...a),i=(Math.random()*r+e)/A;return a=a.map((t=>t*i)),a}function ut(t,e){let r=[];const a=t-1;for(let t=0;t<a;t++)r.push(s.randFloatSpread(2));const A=Math.hypot(...r),i=Math.random()/A;return r=r.map((t=>t*i)),r.push(Math.random()*e),r}function kt(t,e,r,a){let A=[];const i=t-1;for(let t=0;t<i;t++)A.push(s.randFloatSpread(2));const o=Math.hypot(...A),n=(Math.random()*r+e)/o;return A=A.map((t=>t*n)),A.push(Math.random()*a),A}function St({ratio:t,density:e}){return e-e*t}function gt({ratio:t,value:e}){return e-e*t}var Wt=(t=>(t[t.Circle=0]="Circle",t[t.Square=1]="Square",t))(Wt||{});function ct(t,e){const{clim:a,step:A,radius:s,value:i,solid:o,hollow:n,density:l,shape:p,densityGradient:y,valueGradient:u}=t,k=t,[S,g]=_(t);let W,c;if(e){const{lineStep:t,matrix:a}=e,A=1===p?lt:kt;W=function(e,s,i){const o=A(e,s,i,t);return 2===e&&o.push(0),new r(...o).applyMatrix4(a)},c=function(e,r){return e*r**(g-2)*t}}else{const t=1===p?ot:yt;W=function(e,r,a){const A=t(e,r,a);return new S(...A)},c=function(t,e){return t*e**(g-1)}}const d=[],I=[],b=s*o,V=s-b,m=s*n;for(let t=m+A;t<s;t+=A){const e={ratio:(t-b)/V,radius:s,solid:o,distance:t,density:l,solidRadius:b,gradientRadius:V,clim:a,value:i,hollow:n,hollowRadius:m};let r=c(t<b?l:y(e),t);const p=t-A;for(;r-- >-1;){const t=W(g,p,A),r=(new S).copy(t),a=r.length();r.add(k),d.push(r);const i=u({...e,ratio:a/s,distance:a});I.push(i)}}return{particles:d,values:I}}function dt(t){const{points:e,clim:r={x:0,y:100},step:a=3,radius:A=10,value:s=100,solid:i=.7,hollow:o=0,density:n=1,shape:l=0,densityGradient:p=St,valueGradient:y=gt}=t,u={clim:r,step:a,radius:A,value:s,solid:i,hollow:o,density:n,shape:l,densityGradient:p,valueGradient:y},k=e[0];if(!k)return[];const[S,g]=_(k);return e.map((t=>{const e=new S;return Object.assign(e,{...u,...t}),ct(e)}))}class It extends i{constructor(t){super(),st(this,"isClusterGeometry",!0),st(this,"_options"),st(this,"_colorGradient"),st(this,"_values"),t&&(this.options=t)}get options(){return this._options??(this._options={})}set options(t){this._options=t,this.updateVertices()}get gradient(){return this.options.gradient}set gradient(t){this.options.gradient=t,this.colorGradient=this.createColorGradient(t)}get colorGradient(){return this._colorGradient?this._colorGradient:this._colorGradient=this.createColorGradient(this.gradient)}set colorGradient(t){this._colorGradient=t,this.updateVertexColors()}createColorGradient(t){if(!t)return null;const e=Array.isArray(t)?function(t,e,r,a="srgb"){const A=new OffscreenCanvas(e,r).getContext("2d"),s=A.createLinearGradient(0,0,256,1);for(const[e,r]of t)s.addColorStop(Number(e),r);return A.fillStyle=s,A.fillRect(0,0,e,r),A.getImageData(0,0,e,r,{colorSpace:a})}(t,256,1):t,{width:r,height:a}=e,A=function(t,e){const{data:r,width:a}=t,A=e*a,s=A+a;return r.slice(4*A,4*s)}(e,Math.trunc(a/2));return new ImageData(A,r,1)}updateVertexColors(){this.deleteAttribute("color");const{colorGradient:t,clim:e,values:r}=this;if(!t)return!1;const{width:a,data:A}=t,i=[],{x:n,y:l}=e,p=l-n,y=a-1;for(const t of r){const e=1-(s.clamp(t,n,l)-n)/p,r=4*Math.trunc(e*y),a=A.slice(r,r+4);i.push(...a)}this.setAttribute("color",new o(new Uint8ClampedArray(i),4,!0))}get clim(){return this.options.clim??(this.options.clim={x:0,y:100})}set clim(t){this.options.clim=t,this.updateVertexColors()}get clusters(){return this.options.clusters}set clusters(t){this.options.clusters=t,this.updateVertices()}updateVertices(){this.deleteAttribute("position"),this._values=null;const t=this.clusters;if(!t)return;const e=[],r=[];let a=0;for(const{particles:A,values:s}of t){const t=A.length;for(let i=0;i<t;i++,a++){A[i].toArray(e,3*a);const t=s[i];r.push(t)}}this.setAttribute("position",new o(new Float32Array(e),3)),this.values=r}get values(){return this._values??(this._values=[])}set values(t){this._values=t,this.updateVertexColors()}addCluster(t){const e=Array.isArray(t)?t:[t],r=this.clusters;if(!r)return void(this.clusters=e);r.push.apply(r,e);let a=[];const A=[];let s=0;for(const{particles:t,values:r}of e){const e=t.length;for(let i=0;i<e;i++,s++){t[i].toArray(a,3*s);const e=r[i];A.push(e)}}const i=this.getAttribute("position");i&&(a=[...i.array,...a]),this.setAttribute("position",new o(new Float32Array(a),3)),i?this.addValueColors(A):this.values=A}addValueColors(t){const{colorGradient:e,clim:r,values:a}=this;if(!e)return!1;const{width:A,data:i}=e;let n=[];const{x:l,y:p}=r,y=p-l,u=A-1;for(const e of t){const t=1-(s.clamp(e,l,p)-l)/y,r=4*Math.trunc(t*u),A=i.slice(r,r+4);n.push(...A),a.push(e)}const k=this.getAttribute("color");k&&(n=[...k.array,...n]),this.setAttribute("color",new o(new Uint8ClampedArray(n),4,!0))}}function bt({startRadius:t,addedRadius:e,ratio:r}){return e*r+t}function Vt({startDensity:t,addedDensity:e,ratio:r}){return e*r+t}function mt({startValue:t,addedValue:e,ratio:r}){return e*r+t}function Jt(t){const{points:e,clim:a={x:0,y:100},step:A=3,radius:s=10,value:i=100,solid:o=.7,hollow:n=0,density:l=1,shape:u=Wt.Circle,densityGradient:k=St,valueGradient:S=gt,radiusGradient:g=bt,lineDensityGradient:W=Vt,lineValueGradient:c=mt}=t,d=t.lineStep??A,I={clim:a,step:A,radius:s,value:i,solid:o,hollow:n,density:l,shape:u,densityGradient:k,valueGradient:S,radiusGradient:g,lineDensityGradient:W},{total:b,lengths:V}=function(t){const e=t.length;let r=t[0];const[a,A]=_(r),s=[0];let i=0;for(let A=1;A<e;A++){const e=(new a).copy(t[A]).distanceTo(r);s.push(e),i+=e}return{lengths:s,total:i}}(e),m=e.length,J=e[0],q=e[m-1],U=J.radius??s,R=J.density??l,N=J.value??i,T=q.radius??s,h=q.density??l,v=q.value??i,C={length:b,startRadius:U,endRadius:T,addedRadius:T-U,defaultRadius:s,startDensity:R,endDensity:h,addedDensity:h-R,defaultDensity:l,startValue:N,endValue:v,addedValue:v-N,defaultValue:i},L=[];for(let t=0;t<m;t++){const r=e[t];let{radius:a,value:A,density:s}=r;const i={...C,ratio:V[t]/b,index:t-1};a=a??g(i),s=s??W(i),A=A??c(i),L.push({...I,...r,radius:a,density:s,value:A})}const[B,x]=_(J),j=[],H=m-1;for(let t=0;t<H;t++){const e=L[t],{radius:a,density:A,value:o}=e,n=new B;n.lineStep=d;const u=L[t+1],{radius:k,density:S,value:I}=u,b=new B;Object.assign(b,u);const m=b.clone().sub(n).normalize(),J=V[t+1],q=Math.trunc(J/d),U=k-a,R=S-A,N=I-o,T=new p;3===x?T.setFromUnitVectors(new r(0,0,1),m):T.setFromUnitVectors(new r(0,1,0),new r(m.x,m.y,0));const h=(new y).makeRotationFromQuaternion(T);Object.assign(n,{...e,lineDir:m,matrix:h}),j.push(n);const v={length:J,startRadius:a,endRadius:k,addedRadius:U,defaultRadius:s,startDensity:A,endDensity:S,addedDensity:R,defaultDensity:l,startValue:o,endValue:I,addedValue:N,defaultValue:i,index:t,ratio:0};let C=0;for(let t=1;t<q;t++){C=t*d;const r=m.clone().multiplyScalar(C).add(n),a=C/J;v.ratio=a;const A=g(v),s=W(v),i=c(v),o={...e,lineDir:m,matrix:h,radius:A,density:s,value:i,lineStep:d};delete o.x,delete o.y,delete o.z,delete o.w,Object.assign(r,o),j.push(r)}j[j.length-1].lineStep=J-C}return j.map((t=>{const{lineStep:e,matrix:r}=t;return ct(t,{lineStep:e,matrix:r})}))}function qt(t,e){const{x:r,y:a}=e;let A=0;for(const{value:e,clim:{x:r,y:a}}of t)A+=(e-r)/(a-r);return A*(a-r)+r}function Ut(t,e){const{clim:r,step:a,radius:A,value:s,solid:i,hollow:o,density:n,shape:l,densityGradient:p,valueGradient:y,valuesAccumulate:u}=t,[k,S]=_(t),g=(new k).copy(t),W=l===Wt.Square?ot:yt,c=[],d=[],I=A*i,b=A-I,V=A*o,m=e.map((t=>({dist:g.distanceTo(t),point:t})));for(let e=V+a;e<A;e+=a){const l={ratio:(e-I)/b,radius:A,solid:i,hollow:o,hollowRadius:V,distance:e,density:n,solidRadius:I,gradientRadius:b,clim:r,value:s},J=e<I?n:p(l);let q=J*e**(S-1);const U=e-a,R=m.filter((({dist:t,point:r})=>{const a=r.radius;return t-e<=a}));t:for(;q-- >-1;){const e=new k(...W(S,U,a)),s=e.length();e.add(g);const i=[],o={...l,ratio:s/A,distance:s},n=y(o);i.push({...t,...o,value:n,density:J});for(const{point:t}of R){const r=e.distanceTo(t),{solid:a,hollow:A,radius:s}=t;if(r<=s){const e=s*a,o=s-e,n=s*A;if(r<n)continue t;const l={...t,ratio:r/s,distance:r,solidRadius:e,gradientRadius:o,hollowRadius:n},p=y(l);i.push({...l,value:p})}}c.push(e);const p=u(i,r,J);d.push(p)}}return{particles:c,values:d}}function Rt(t){const{points:e,clim:r={x:0,y:100},step:a=3,radius:A=10,value:s=100,solid:i=.7,hollow:o=0,density:n=1,shape:l=Wt.Circle,densityGradient:p=St,valueGradient:y=gt,valuesAccumulate:u=qt}=t,k={clim:r,step:a,radius:A,value:s,solid:i,hollow:o,density:n,shape:l,densityGradient:p,valueGradient:y,valuesAccumulate:u},S=e.map((t=>({...k,...t}))),g=function(t){const e=t.length,r=[];if(0===e)return r;const[a,A]=_(t[0]);for(let A=0;A<e;A++){const s=t[A],i=(new a).copy(s),o=s.radius,n=r[A]??(r[A]=[]);for(let a=A+1;a<e;a++){const e=t[a];i.distanceToSquared(e)<=(e.radius+o)**2&&(n.push(a),(r[a]=[]).push(A))}}return r}(S);return S.map(((t,e)=>{const r=g[e].map((t=>S[t]));return Ut({...k,...t},r)}))}var Nt=(t=>(t[t.Point=0]="Point",t[t.Line=1]="Line",t[t.Heat=2]="Heat",t))(Nt||{});const Tt={cluster:{base:["radius","solid","hollow","density","shape","densityGradient","step","clusterType","points"],line:["radiusGradient","lineDensityGradient","lineStep"],heat:[]},gradient:{base:["value","valueGradient","clim","gradient"],line:["lineValueGradient"],heat:["valuesAccumulate"]}};class ht extends It{constructor(t){super(),st(this,"isParticleClusterGeometry",!0),t&&(this.options=t)}get options(){return this._options}set options(t){this._options=t,this.updateClusters()}get clusterType(){return this.options.clusterType}set clusterType(t){this.options.clusterType!==t&&(this.options.clusterType=t,this.updateClusters())}setOptions(t){const e=this.options;let r=!1;const a=Object.entries(t).some((([t,a])=>a!==e[t]&&(!!(Tt.cluster.base.includes(t)||1===this.clusterType&&Tt.cluster.line.includes(t)||2===this.clusterType&&Tt.cluster.heat.includes(t))||(Tt.gradient.base.includes(t)&&(r=!0),1===this.clusterType&&Tt.gradient.line.includes(t)&&(r=!0),void(2===this.clusterType&&Tt.gradient.heat.includes(t)&&(r=!0))))));Object.assign(this.options,t),a?this.updateClusters():r&&this.updateVertexColors()}updateClusters(){this.clusters=this.createClusters(this.options)}createClusters(t){let e;switch(t.clusterType){case 2:e=Rt(t);break;case 1:e=Jt(t);break;default:e=dt(t)}return e}addPoint(t,e){const r=Array.isArray(t)?t:[t],a={...this.options,...e,points:r},A=this.createClusters(a);this.addCluster(A)}}class vt extends n{constructor(t){super(new ht,new l({vertexColors:!0,transparent:!0,...t})),st(this,"isParticleCluster",!0),t&&(this.options=t)}get options(){return this.geometry.options}set options(t){const e=null==t?void 0:t.points;if(e){const r=this.convertPoints(e);t={...t,points:r}}this.geometry.options=t}setOptions(t){const e=t.points;if(e){const r=this.convertPoints(e);t={...t,points:r}}this.geometry.setOptions(t)}addPoint(t,e){const r=Array.isArray(t)?t:[t],a=this.convertPoints(r);this.geometry.addPoint(a,e)}convertPoints(t){const e=this.matrixWorld.clone().invert();return t.map((t=>{const a=new r;return Object.assign(a,t),a.applyMatrix4(e),a}))}}class Ct{constructor(t){const{textureUrl:e,width:r,height:a,position:A,isScaleAnimate:s,isOpacityAnimate:i}=t;void 0!==e[1]&&(this.outMaterial=this.createMaterial(e[1]),this.outPlaneGeometry=this.createPlane(r,a),this.outMesh=new u(this.outPlaneGeometry,this.outMaterial),this.outMesh.renderOrder=Number.MAX_SAFE_INTEGER-2,this.outMesh.position.set(A.x,A.y,A.z),this.outMesh.rotation.set(-1.5707022192751596,33819658717412135e-21,.34500000055302255)),this.inMaterial=this.createMaterial(e[0]),this.inPlaneGeometry=this.createPlane(r,a),this.inMesh=new u(this.inPlaneGeometry,this.inMaterial),this.inMesh.renderOrder=Number.MAX_SAFE_INTEGER-1,this.inMesh.position.set(A.x,A.y,A.z),this.inMesh.rotation.set(-1.5707022192751596,33819658717412135e-21,.34500000055302255),this.isScaleAnimate=s,this.isOpacityAnimate=i,this.AngleUnit=.1,this.MaxScale=3,this.ScaleUnit=.02,this.OpacityUnit=1/((this.MaxScale-0)/this.ScaleUnit)}createPlane(t=10,e=10){return new k(t,e)}createMaterial(t){const e=new S,r=(new g).load(t);return e.map=r,e.side=W,e.transparent=!0,e}update(){if(void 0!==this.outMesh){const t=this.outMesh.material.map;null==t||t.center.set(.5,.5),t.rotation+=this.AngleUnit}const t=this.inMesh.material.map;if(null==t||t.center.set(.5,.5),t.rotation-=this.AngleUnit,this.isScaleAnimate){this.inMesh.scale.x>this.MaxScale&&(this.inMesh.scale.x=0,this.inMesh.scale.y=0,this.inMesh.material.opacity=1,void 0!==this.outMesh&&(this.outMesh.scale.y=0,this.outMesh.scale.x=0,this.outMesh.material.opacity=1)),void 0!==this.outMesh&&(this.outMesh.scale.y+=this.ScaleUnit,this.outMesh.scale.x+=this.ScaleUnit),this.inMesh.scale.x+=this.ScaleUnit,this.inMesh.scale.y+=this.ScaleUnit}this.isOpacityAnimate&&(void 0!==this.outMesh&&(this.outMesh.material.opacity-=this.OpacityUnit),this.inMesh.material.opacity-=this.OpacityUnit)}}class Lt{constructor(t){const{topRadius:e,bottomRadius:r,height:a,position:A,texturePath:s,color:i}=t;this.geometry=this.createGeometry(e,r,a),this.material=this.creatematerial(s,i),this.position=A,this.mesh=new u(this.geometry,this.material),this.mesh.renderOrder=Number.MAX_SAFE_INTEGER-1,this.mesh.position.set(A.x,A.y+a/2,A.z),this.maxScale=15,this.minScale=1,this.opacityUnit=1/this.maxScale}createGeometry(t,e,r){return new c(t,e,r,32,16,!0)}creatematerial(t,e){const r=new S,a=(new g).load(t);return r.map=a,r.side=W,r.opacity=1,r.transparent=!0,r}update(){let t=this.mesh.scale.x;t+=.1,t>=this.maxScale&&(t=1);const e=1-this.opacityUnit*t;this.mesh.scale.set(t,this.mesh.scale.y,t),this.mesh.material.opacity=e}}var Bt={vertexShader:"\n attribute float size;\n uniform float showDistance;\n varying float dcolor;\n void main() {\n\n vec4 mvPosition = modelViewMatrix * vec4( position, 1.0 );\n // vec4 viewPosition = viewMatrix * mvPosition;\n \n //gl_PointSize = 5.0;\n float fDistance =sqrt( position.x * position.x + position.z * position.z );\n if(fDistance < showDistance)\n return;\n\n // dcolor = fDistance/355.0/3.0;\n gl_Position = projectionMatrix * mvPosition;\n gl_PointSize = size * ( 300.0 / - mvPosition.z );\n // gl_PointSize *= (1.0 / - viewPosition.z);\n }\n ",fragmentShader:"\n #include <common>\n uniform vec3 color;\n uniform float opacity;\n // varying float dcolor;\n void main() {\n\n //if ( length( gl_PointCoord - vec2( 0.5, 0.5 ) ) > 0.475 ) discard;\n // int buffer = int(dcolor);\n \n //gl_FragColor = vec4( dcolor,sin(dcolor),0, 1.0 );\n gl_FragColor = vec4( color, opacity );\n\n #include <tonemapping_fragment>\n #include <colorspace_fragment>\n }\n "},xt={vertexShader:"\n uniform vec2 lowHeight;\n varying float ratioHeigh;\n void main() {\n \n vec4 mvPosition = modelViewMatrix * vec4( position, 1.0 );\n float maxHeigh = lowHeight.y - lowHeight.x;\t\n float curHeigh = lowHeight.y - position.y;\t\n ratioHeigh = curHeigh/maxHeigh;\n gl_Position = projectionMatrix * mvPosition;\n \n }\n ",fragmentShader:"\n #include <common>\n uniform vec3 color;\n varying float ratioHeigh;\n void main() {\n \n gl_FragColor = vec4( color, max( 1.0 - 0.5 - ratioHeigh * ratioHeigh * ratioHeigh, 0.01 ) );\n\n #include <tonemapping_fragment>\n #include <colorspace_fragment>\n }\n "};const jt=new y(1,0,0,0,0,0,1,0,0,-1,0,0,0,0,0,1);var Ht="";const Kt=new g;function Ft(t){const{polygon:e,waterNormals:r=Ht,height:A,speed:s=1}=t,i=j(t,["polygon","waterNormals","height","speed"]),o=function(t,e){const r=t.map((t=>new a(t.x,-t.z))),A=new d(r),s=new I(A);return jt.elements[13]=null!=e?e:t[0].y,s.applyMatrix4(jt),s}(e,A),n=Kt.load(r,(function(t){t.wrapS=t.wrapT=b})),l=new x(o,Object.assign(Object.assign({},i),{waterNormals:n}));return l.speed=s,l}class ft{constructor(t){this.ssp=t,this.weatherPresetImgs={rain:"",snow:""},this._weatherId=""}createFlame(a){const{magnitude:A=1.3,gain:s=.5}=a,i=50,o=new u(new V(1,1,1),(a=>{const{imgUrl:o=K}=a,n=(new g).load(o);n.magFilter=n.minFilter=h,n.wrapS=n.wrapT=v;const l=new T({defines:{ITERATIONS:20,OCTIVES:3,WIDTH:128,BOUNDS:512},uniforms:C.merge([L.phong.uniforms,{fireTex:{value:n},time:{value:0},seed:{value:19.19*Math.random()},invModelMatrix:{value:new y},scale:{value:new r(i,i,i)},noiseScale:{value:new e(1,2,1,.3)},magnitude:{value:A},gain:{value:s},lacunarity:{value:2},diffuse:{value:new t(16576)},specular:{value:new t(1118481)},shininess:{value:Math.max(50,1e-4)},opacity:{value:.8}}]),vertexShader:H.vertexShader,fragmentShader:H.fragmentShader,transparent:!0,depthWrite:!1,depthTest:!0,lights:!0});return l.uniforms.fireTex.value=n,l})(a));o.scale.set(i,i,i);const n=t=>{const e=o.material,a=e.uniforms.invModelMatrix.value;o.updateMatrixWorld(),a.copy(o.matrixWorld).invert(),void 0!==t&&(e.uniforms.time.value=t/1e3),e.uniforms.invModelMatrix.value=a,e.uniforms.scale.value=o.getWorldScale(new r),e.uniforms.magnitude.value=A||1.3,e.uniforms.gain.value=s||.5,e.version++,this.ssp.render()};this.ssp.viewport.postUpdate.set(a.id,n);const l=this.ssp.createPluginObject(a,o),p=()=>this.ssp.viewport.postUpdate.set(a.id,n);p();return l.addEventListener("added",p),l.addEventListener("removed",(()=>this.ssp.viewport.postUpdate.delete(a.id))),l}removeFlame(t){return console.warn("请使用 ssp.removeObjectById 替代"),this.ssp.removeObjectById(t)}createSmoke(e){const{imgUrl:a=G,count:A=1e3,maxAge:s=4,size:i=200,acceleration:o=10,velocity:n={x:100,y:100,z:100},color:l=[3355443,1118481]}=e,p=new m,y=(new g).load(a),u=new Z.Group({texture:{value:y},blending:J}),k=new Z.Emitter({particleCount:A,maxAge:{value:s},position:{value:new r(0,0,0),spread:new r(0,0,0)},size:{value:i,spread:[1,1,8]},acceleration:{value:new r(0,o,0)},rotation:{angle:this.ssp.utils.deg2Euler(45),randomise:!0},velocity:{value:new r(0,100,0),spread:new r(n.x,n.y,n.z)},opacity:{value:[.5,.2,0]},color:{value:l.map((e=>new t(e)))}});u.addEmitter(k);const S=()=>{u.tick(p.getDelta()),this.ssp.render()},W=this.ssp.createPluginObject(e,u.mesh),c=()=>this.ssp.viewport.postUpdate.set(e.id,S);c();return W.addEventListener("added",c),W.addEventListener("removed",(()=>this.ssp.viewport.postUpdate.delete(e.id))),W}removeSmoke(t){return console.warn("请使用 removeObjectById 替代"),this.ssp.removeObjectById(t)}createSparkles(t){const{count:e=100,scalar:r=8,speed:a=1,opacity:A=1,noise:s=1,color:i="#fff",size:o=2}=t,{ssp:n}=this,{THREE:l}=n,{Points:p,ShaderMaterial:y,BufferGeometry:u,BufferAttribute:k}=l,S=Float32Array.from(Array.from({length:e},(()=>w(r).map(l.MathUtils.randFloatSpread))).flat()),g=O(e,o,Math.random),W=O(e,A),c=O(e,a),d=O(3*e,s),I=O(void 0===i?3*e:e,E(i)?i:new l.Color(i),(()=>1)),b=new u;b.setAttribute("position",new k(S,3)),b.setAttribute("size",new k(g,1)),b.setAttribute("opacity",new k(W,1)),b.setAttribute("speed",new k(c,1)),b.setAttribute("color",new k(I,3)),b.setAttribute("noise",new k(d,3));const V=new y({uniforms:{time:{value:0},pixelRatio:{value:self.devicePixelRatio}},vertexShader:Q.vertexShader,fragmentShader:Q.fragmentShader,depthWrite:!1,transparent:!0,blending:q}),m=new p(b,V),J=()=>{V.uniforms.time.value=n.viewport.clock.elapsedTime,this.ssp.render()},U=this.ssp.createPluginObject(t,m),R=()=>this.ssp.viewport.postUpdate.set(t.id,J);R();return U.addEventListener("added",R),U.addEventListener("removed",(()=>this.ssp.viewport.postUpdate.delete(t.id))),U}createContactShadows(t){var{scale:e=10,frames:r=1/0,opacity:a=1,width:A=1,height:s=1,blur:i=1,darkness:o=1,far:n=10,resolution:l=512}=t,p=j(t,["scale","frames","opacity","width","height","blur","darkness","far","resolution"]);const{viewport:{renderer:y,scene:u},THREE:k}=this.ssp;A*=Array.isArray(e)?e[0]:e||1,s*=Array.isArray(e)?e[1]:e||1;const S=new k.Group,g=new k.OrthographicCamera(-A/2,A/2,s/2,-s/2,0,n);g.rotation.x=Math.PI/2,S.add(g);const W=new k.WebGLRenderTarget(l,l),c=new k.WebGLRenderTarget(l,l);c.texture.generateMipmaps=W.texture.generateMipmaps=!1;const d=new k.PlaneGeometry(A,s).rotateX(Math.PI/2),I=new k.MeshBasicMaterial({map:W.texture,opacity:a,transparent:!0,depthWrite:!1}),b=new k.Mesh(d,I);b.renderOrder=1,b.scale.y=-1,S.add(b);const V=new k.Mesh(d);V.visible=!1,S.add(V);const m=new k.MeshDepthMaterial;m.userData.darkness={value:o},m.onBeforeCompile=function(t){t.uniforms.darkness=m.userData.darkness,t.fragmentShader=`\n uniform float darkness;\n ${t.fragmentShader.replace("gl_FragColor = vec4( vec3( 1.0 - fragCoordZ ), opacity );","gl_FragColor = vec4( vec3( 0.0 ), ( 1.0 - fragCoordZ ) * darkness );")}\n `},m.depthTest=!1,m.depthWrite=!1;const J=new k.ShaderMaterial(M);J.depthTest=!1;const q=new k.ShaderMaterial(P);function U(t){V.visible=!0,V.material=J,J.uniforms.tDiffuse.value=W.texture,J.uniforms.h.value=1*t/256,y.setRenderTarget(c),y.render(V,g),V.material=q,q.uniforms.tDiffuse.value=c.texture,q.uniforms.v.value=1*t/256,y.setRenderTarget(W),y.render(V,g),V.visible=!1}q.depthTest=!1;let R=0;const N=()=>{if(R>r)return;R++;const t=u.background;u.background=null,u.overrideMaterial=m;const e=y.getClearAlpha();y.setClearAlpha(0),y.setRenderTarget(W),y.render(u,g),u.overrideMaterial=null,U(i),U(.4*i),y.setRenderTarget(null),y.setClearAlpha(e),u.background=t},T=this.ssp.createPluginObject(p,S),h=()=>this.ssp.signals.beforeRender.add(N);h();return T.addEventListener("added",h),T.addEventListener("removed",(()=>this.ssp.signals.beforeRender.remove(N))),T}openWeather(t={}){const{imgUrl:e=this.weatherPresetImgs.rain,count:r=500,range:a=100,size:A=1,opacity:p=.9,color:y=16777215,velocityX:u=[-.02,.02],velocityY:k=[.4,.8]}=t;this._weatherId&&this.closeWeather();const{viewport:{renderer:S,container:W},utils:c}=this.ssp,d=new Float32Array(3*r),I=Array.from({length:r}).fill({x:0,y:0}),b=new i;for(let t=0;t<r;t++)d[3*t]=s.randFloatSpread(a),d[3*t+1]=s.randFloatSpread(a),d[3*t+2]=s.randFloatSpread(a),I[t].x=s.randFloat(...u),I[t].y=s.randFloat(...k);const V=new o(d,3);V.setUsage(U),b.setAttribute("position",V);const m=(new g).load(e);m.colorSpace=S.outputColorSpace;const J=new l({color:y,size:A,opacity:p,map:m,transparent:!0}),q=new n(b,J),T=new R,h=new N(45,W.offsetWidth/W.offsetHeight,.1,1e3);h.position.set(0,0,a/2),T.add(q);this._weatherId=`weather_${c.randomString()}`,this.ssp.viewport.postRender.set(this._weatherId,(()=>{I.forEach(((t,e)=>{d[3*e]-=t.x,d[3*e+1]-=t.y,(d[3*e]<=-a/2||d[3*e]>=a/2)&&(I[e].x*=-1),d[3*e+1]<=-a/2&&(d[3*e+1]=a/2)})),V.needsUpdate=!0,S.render(T,h),this.ssp.render()})),this.ssp.render()}closeWeather(){this._weatherId&&(this.ssp.viewport.postRender.delete(this._weatherId),this._weatherId="",this.ssp.render())}createParticleCluster(t){const e=new vt(t);return this.ssp.addObject(e),e}createCircleWave(t){const e=this.ssp.createPluginObject(t),r=new Ct(t);e.add(r.inMesh),r.outMesh&&e.add(r.outMesh);const a=()=>{this.ssp.viewport.postUpdate.set(t.id,(()=>{r.update(),this.ssp.render()}))};a();return e.addEventListener("added",a),e.addEventListener("removed",(()=>this.ssp.viewport.postUpdate.delete(t.id))),e}createCylinderWave(t){const e=this.ssp.createPluginObject(t),r=new Lt(t);e.add(r.mesh),this.ssp.addObject(e);const a=()=>{this.ssp.viewport.postUpdate.set(t.id,(()=>{r.update(),this.ssp.render()}))};a();return e.addEventListener("added",a),e.addEventListener("removed",(()=>this.ssp.viewport.postUpdate.delete(t.id))),e}createPointsWave(e){let r=0;const{xAxisCount:a=100,zAxisCount:A=100,showDistance:s=0,separation:l=20,size:p=5,maxFluctua:y=.1,color:u="#485c7c",opacity:k=1}=e,S=a*A,g=new Float32Array(3*S),W=new Float32Array(S);let c=0,d=0;for(let t=0;t<a;t++)for(let e=0;e<A;e++)g[c]=t*l-a*l/2,g[c+1]=0,g[c+2]=e*l-A*l/2,W[d]=1,c+=3,d++;const I=new i;I.setAttribute("position",new o(g,3).setUsage(U)),I.setAttribute("size",new o(W,1).setUsage(U));const b=new T({transparent:!0,depthWrite:!1,uniforms:{color:{value:new t(u)},opacity:{value:k},showDistance:{value:s}},vertexShader:Bt.vertexShader,fragmentShader:Bt.fragmentShader}),V=new n(I,b);V.renderOrder=-1;const m=()=>{const t=V.geometry.attributes.position.array,e=V.geometry.attributes.size.array;let s=0,i=0;const o=Math.sqrt(a/2*(a/2)+A/2*(A/2));for(let n=0;n<a;n++)for(let l=0;l<A;l++){const u=n-a/2,k=l-A/2,S=Math.sqrt(u*u+k*k);t[s+1]=50*Math.cos(1*(S/o*50-r))*y,e[i]=p,s+=3,i++}V.geometry.attributes.position.needsUpdate=!0,V.geometry.attributes.size.needsUpdate=!0,r+=.01,this.ssp.render()},J=this.ssp.createPluginObject(e,V),q=()=>this.ssp.viewport.postUpdate.set(e.id,m);q();return J.addEventListener("added",q),J.addEventListener("removed",(()=>this.ssp.viewport.postUpdate.delete(e.id))),J}createBuilds(e){const{buildWidth:r=100,buildDepth:A=100,buildHeigh:s=200,count:i=12,gapX:o=2,gapZ:n=2,showDistance:l=1e3,randShift:p=.5,color:y="#485c7c"}=e,k=this.ssp.createPluginObject(e);for(let e=0;e<i;e++)for(let S=0;S<i;S++){const g=(e-i/2)*r*o+(Math.random()-1)*p*r*o,W=(S-i/2)*A*n+(Math.random()-1)*p*A*n;if(Math.sqrt(g*g+W*W)<l)continue;const c=Math.floor(Math.random()*s)+s,d=new V(r,c,A,1,1,1);d.translate(g,c/2,W),d.computeBoundingBox();const I=d.boundingBox,b=new T({transparent:!0,depthWrite:!1,uniforms:{color:{value:new t(y)},lowHeight:{value:new a(I.min.y,I.max.y)}},vertexShader:xt.vertexShader,fragmentShader:xt.fragmentShader}),m=new u(d,b);k.add(m)}return k}createWater(t){const{animation:e=!0}=t,{ssp:r}=this,a=Ft(Object.assign(Object.assign({},t),{fog:!!r.viewport.scene.fog})),A=r.createPluginObject(t,a),s=()=>{var t;a.material.uniforms.time.value+=(null!==(t=a.speed)&&void 0!==t?t:0)/60,e&&r.render()},i=()=>r.viewport.postUpdate.set(t.id,s);return i(),A.addEventListener("added",i),A.addEventListener("removed",(()=>r.viewport.postUpdate.delete(t.id))),A}removeEffect(t){return console.warn("请使用 removeObjectById 替代"),this.ssp.removeObjectById(t)}}export{It as ClusterGeometry,Nt as ClusterType,vt as ParticleCluster,ht as ParticleClusterGeometry,Wt as ParticleClusterShape,Ut as createHeatParticleClusterData,Rt as createHeatParticleClusterDataArr,ct as createPointParticleClusterData,dt as createPointParticleClusterDataArr,ft as default,St as densityGradient_Default,pt as getRandomVector_Circle,yt as getRandomVector_CircleAnnular,ut as getRandomVector_CircleCylinder,kt as getRandomVector_CircleCylinderAnnular,it as getRandomVector_Square,ot as getRandomVector_SquareAnnular,nt as getRandomVector_SquareCylinder,lt as getRandomVector_SquareCylinderAnnular,gt as valueGradient_Default,qt as valuesAccumulate_Default};