@tresjs/post-processing 2.3.1 → 2.4.0

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.
@@ -1,11 +1,11 @@
1
1
  /**
2
2
  * name: @tresjs/post-processing
3
- * version: v2.3.1
3
+ * version: v2.4.0
4
4
  * (c) 2025
5
5
  * description: Post-processing library for TresJS
6
6
  * author: Alvaro Saburido <hola@alvarosaburido.dev> (https://github.com/alvarosabu/)
7
7
  */
8
- (function(d,r){typeof exports=="object"&&typeof module<"u"?r(exports,require("vue"),require("postprocessing"),require("@tresjs/core"),require("three"),require("@vueuse/core")):typeof define=="function"&&define.amd?define(["exports","vue","postprocessing","@tresjs/core","three","@vueuse/core"],r):(d=typeof globalThis<"u"?globalThis:d||self,r(d["tres-post-processing"]={},d.Vue,d.Postprocessing,d.TresjsCore,d.Three,d.VueUseCore))})(this,function(d,r,u,x,s,N){"use strict";class z{static isWebGL2Available(){try{const e=document.createElement("canvas");return!!(window.WebGL2RenderingContext&&e.getContext("webgl2"))}catch{return!1}}static isColorSpaceAvailable(e){try{const t=document.createElement("canvas"),o=window.WebGL2RenderingContext&&t.getContext("webgl2");return o.drawingBufferColorSpace=e,o.drawingBufferColorSpace===e}catch{return!1}}static getWebGL2ErrorMessage(){return this.getErrorMessage(2)}static getErrorMessage(e){const t={1:"WebGL",2:"WebGL 2"},o={1:window.WebGLRenderingContext,2:window.WebGL2RenderingContext};let a='Your $0 does not seem to support <a href="http://khronos.org/webgl/wiki/Getting_a_WebGL_Implementation" style="color:#000">$1</a>';const n=document.createElement("div");return n.id="webglmessage",n.style.fontFamily="monospace",n.style.fontSize="13px",n.style.fontWeight="normal",n.style.textAlign="center",n.style.background="#fff",n.style.color="#000",n.style.padding="1.5em",n.style.width="400px",n.style.margin="5em auto 0",o[e]?a=a.replace("$0","graphics card"):a=a.replace("$0","browser"),a=a.replace("$1",t[e]),n.innerHTML=a,n}static isWebGLAvailable(){console.warn("isWebGLAvailable() has been deprecated and will be removed in r178. Use isWebGL2Available() instead.");try{const e=document.createElement("canvas");return!!(window.WebGLRenderingContext&&(e.getContext("webgl")||e.getContext("experimental-webgl")))}catch{return!1}}static getWebGLErrorMessage(){return console.warn("getWebGLErrorMessage() has been deprecated and will be removed in r178. Use getWebGL2ErrorMessage() instead."),this.getErrorMessage(1)}}const R=Symbol("effectComposerPmndrs"),J=r.defineComponent({__name:"EffectComposerPmndrs",props:{enabled:{type:Boolean,default:!0},depthBuffer:{type:Boolean,default:void 0},disableNormalPass:{type:Boolean,default:!1},stencilBuffer:{type:Boolean,default:void 0},resolutionScale:{},autoClear:{type:Boolean,default:!0},multisampling:{default:0},frameBufferType:{default:s.HalfFloatType}},emits:["render"],setup(i,{expose:e,emit:t}){const o=i,a=t,{scene:n,camera:l,renderer:c,sizes:f,render:m}=x.useTresContext(),g=r.shallowRef(null);let b=null,h=null;r.provide(R,g),e({composer:g});const S=()=>{g.value&&(h=new u.NormalPass(n.value,l.value),h.enabled=!1,g.value.addPass(h),o.resolutionScale!==void 0&&z.isWebGL2Available()&&(b=new u.DepthDownsamplingPass({normalBuffer:h.texture,resolutionScale:o.resolutionScale}),b.enabled=!1,g.value.addPass(b)))},y=r.computed(()=>{const w=new u.EffectComposer,P={depthBuffer:o.depthBuffer!==void 0?o.depthBuffer:w.inputBuffer.depthBuffer,stencilBuffer:o.stencilBuffer!==void 0?o.stencilBuffer:w.inputBuffer.stencilBuffer,multisampling:z.isWebGL2Available()?o.multisampling!==void 0?o.multisampling:w.multisampling:0,frameBufferType:o.frameBufferType!==void 0?o.frameBufferType:s.HalfFloatType};return w.dispose(),P}),K=()=>{var w;!c.value&&!n.value&&!l.value||((w=g.value)==null||w.dispose(),g.value=new u.EffectComposer(c.value,y.value),g.value.addPass(new u.RenderPass(n.value,l.value)),o.disableNormalPass||S())};r.watch([c,n,l,()=>o.disableNormalPass],()=>{!f.width.value||!f.height.value||K()}),r.watch(()=>[f.width.value,f.height.value],([w,P])=>{!w&&!P||(g.value?g.value.setSize(w,P):K())},{immediate:!0});const{render:Ye}=x.useLoop();return Ye(()=>{if(o.enabled&&c.value&&g.value&&f.width.value&&f.height.value&&m.frames.value>0){const w=c.value.autoClear;c.value.autoClear=o.autoClear,o.stencilBuffer&&!o.autoClear&&c.value.clearStencil(),g.value.render(),a("render",g.value),c.value.autoClear=w}m.frames.value=m.mode.value==="always"?1:Math.max(0,m.frames.value-1)}),r.onUnmounted(()=>{var w;(w=g.value)==null||w.dispose()}),(w,P)=>r.renderSlot(w.$slots,"default")}}),p=(i,e,t)=>{const o=r.inject(R),a=r.shallowRef(null),n=r.shallowRef(null),{scene:l,camera:c,invalidate:f}=x.useTresContext();r.watch(e,()=>f());const m=()=>{var h,S,y;a.value&&((h=o==null?void 0:o.value)==null||h.removePass(a.value)),(S=n.value)==null||S.dispose(),(y=a.value)==null||y.dispose()},g=h=>{!c.value||!(o!=null&&o.value)||!l.value||(n.value=i(),a.value=new u.EffectPass(c.value,n.value),o.value.addPass(a.value,h))};t&&r.watch(()=>t.map(h=>e[h]),()=>{var S;if(!(o!=null&&o.value))return;const h=(S=o.value)==null?void 0:S.passes.findIndex(y=>y===a.value);~h&&(m(),g(h))}),r.watchEffect(()=>{!c.value||!(n!=null&&n.value)||(n.value.mainCamera=c.value)});const b=r.watchEffect(()=>{!c.value||!(o!=null&&o.value)||!l.value||(r.nextTick(()=>b()),!n.value&&g())});return r.onUnmounted(()=>{m()}),{pass:a,effect:n}},U=/([^[.\]])+/g,Z=(i,e)=>{if(!e)return;const t=Array.isArray(e)?e:e.match(U);return t==null?void 0:t.reduce((o,a)=>o&&o[a],i)},W=(i,e,t)=>{const o=Array.isArray(e)?e:e.match(U);o&&o.reduce((a,n,l)=>(a[n]===void 0&&(a[n]={}),l===o.length-1&&(a[n]=t),a[n]),i)},_=(i,e)=>{const t={...i};return e.forEach(o=>delete t[o]),t},E=(i,e,t,o,a={})=>r.watch(i,n=>{var l;if(e.value)if(n===void 0){const c=o();W(e.value,t,Z(c,t)),(l=c.dispose)==null||l.call(c)}else W(e.value,t,i())},a),v=(i,e,t)=>i.map(([o,a])=>E(o,e,a,t)),O=(i,e,t)=>Object.keys(i).map(o=>E(()=>i[o],e,o,t)),$=r.defineComponent({__name:"BloomPmndrs",props:{blendFunction:{},intensity:{},kernelSize:{},luminanceThreshold:{},luminanceSmoothing:{},mipmapBlur:{type:Boolean,default:void 0}},setup(i,{expose:e}){const t=i,{pass:o,effect:a}=p(()=>new u.BloomEffect(t),t,["mipmapBlur"]);return e({pass:o,effect:a}),v([[()=>t.blendFunction,"blendMode.blendFunction"],[()=>t.intensity,"intensity"],[()=>t.kernelSize,"kernelSize"],[()=>t.luminanceSmoothing,"luminanceMaterial.smoothing"],[()=>t.luminanceThreshold,"luminanceMaterial.threshold"]],a,()=>new u.BloomEffect),()=>{}}}),ee=r.defineComponent({__name:"DepthOfFieldPmndrs",props:{blendFunction:{},worldFocusDistance:{},worldFocusRange:{},focusDistance:{},focusRange:{},bokehScale:{},resolutionScale:{},resolutionX:{},resolutionY:{}},setup(i,{expose:e}){const t=i,{camera:o}=x.useTresContext(),{pass:a,effect:n}=p(()=>new u.DepthOfFieldEffect(o.value,t),t);return e({pass:a,effect:n}),v([[()=>t.blendFunction,"blendMode.blendFunction"],[()=>t.worldFocusDistance,"circleOfConfusionMaterial.worldFocusDistance"],[()=>t.focusDistance,"circleOfConfusionMaterial.focusDistance"],[()=>t.worldFocusRange,"circleOfConfusionMaterial.worldFocusRange"],[()=>t.focusRange,"circleOfConfusionMaterial.focusRange"],[()=>t.bokehScale,"bokehScale"],[()=>t.resolutionScale,"blurPass.resolution.scale"],[()=>t.resolutionX,"resolution.width"],[()=>t.resolutionY,"resolution.height"]],n,()=>new u.DepthOfFieldEffect),()=>{}}}),te=r.defineComponent({__name:"GlitchPmndrs",props:{blendFunction:{},delay:{},duration:{},strength:{},mode:{},active:{type:Boolean},ratio:{},columns:{},chromaticAberrationOffset:{},perturbationMap:{},dtSize:{}},setup(i,{expose:e}){const t=i,{pass:o,effect:a}=p(()=>new u.GlitchEffect(t),t,["dtSize"]);e({pass:o,effect:a});const{onBeforeRender:n}=x.useLoop();return n(({invalidate:l})=>l()),r.watchEffect(()=>{const l=()=>{if(t.mode!==void 0)return t.active===!1?u.GlitchMode.DISABLED:t.mode;const c=new u.GlitchEffect,f=c.mode;return c.dispose(),f};a.value&&(a.value.mode=l())}),E(()=>t.blendFunction,a,"blendMode.blendFunction",()=>new u.GlitchEffect),O(_(t,["active","blendFunction"]),a,()=>new u.GlitchEffect),()=>{}}}),oe=r.defineComponent({__name:"NoisePmndrs",props:{premultiply:{type:Boolean,default:void 0},blendFunction:{}},setup(i,{expose:e}){const t=i,{pass:o,effect:a}=p(()=>new u.NoiseEffect(t),t);e({pass:o,effect:a});const{onBeforeRender:n}=x.useLoop();return n(({invalidate:l})=>l()),v([[()=>t.blendFunction,"blendMode.blendFunction"],[()=>t.premultiply,"premultiply"]],a,()=>new u.NoiseEffect),()=>{}}}),ae=r.defineComponent({__name:"OutlinePmndrs",props:{outlinedObjects:{},blur:{type:Boolean,default:void 0},xRay:{type:Boolean,default:void 0},kernelSize:{},pulseSpeed:{},resolutionX:{},resolutionY:{},edgeStrength:{},patternScale:{},multisampling:{},blendFunction:{},patternTexture:{},resolutionScale:{},hiddenEdgeColor:{},visibleEdgeColor:{}},setup(i,{expose:e}){const t=i,o=m=>m!==void 0?x.normalizeColor(m).getHex():void 0,{camera:a,scene:n}=x.useTresContext(),{pass:l,effect:c}=p(()=>new u.OutlineEffect(n.value,a.value,{blur:t.blur,xRay:t.xRay,kernelSize:t.kernelSize,pulseSpeed:t.pulseSpeed,resolutionX:t.resolutionX,resolutionY:t.resolutionY,patternScale:t.patternScale,edgeStrength:t.edgeStrength,blendFunction:t.blendFunction,multisampling:t.multisampling,patternTexture:t.patternTexture,resolutionScale:t.resolutionScale,hiddenEdgeColor:o(t.hiddenEdgeColor),visibleEdgeColor:o(t.visibleEdgeColor)}),t);e({pass:l,effect:c}),r.watch([()=>t.outlinedObjects,c],()=>{var m;(m=c.value)==null||m.selection.set(t.outlinedObjects||[])},{immediate:!0});const f=r.computed(()=>({hiddenEdgeColor:t.hiddenEdgeColor?x.normalizeColor(t.hiddenEdgeColor):void 0,visibleEdgeColor:t.visibleEdgeColor?x.normalizeColor(t.visibleEdgeColor):void 0}));return v([[()=>t.blendFunction,"blendMode.blendFunction"],[()=>t.blur,"blur"],[()=>t.xRay,"xRay"],[()=>t.pulseSpeed,"pulseSpeed"],[()=>t.kernelSize,"kernelSize"],[()=>t.edgeStrength,"edgeStrength"],[()=>t.patternScale,"patternScale"],[()=>t.multisampling,"multisampling"],[()=>t.resolutionX,"resolution.width"],[()=>t.resolutionY,"resolution.height"],[()=>t.patternTexture,"patternTexture"],[()=>t.resolutionScale,"resolution.scale"],[()=>f.value.hiddenEdgeColor,"hiddenEdgeColor"],[()=>f.value.visibleEdgeColor,"visibleEdgeColor"]],c,()=>new u.OutlineEffect),()=>{}}}),ne=r.defineComponent({__name:"PixelationPmndrs",props:{granularity:{}},setup(i,{expose:e}){const t=i,{pass:o,effect:a}=p(()=>new u.PixelationEffect(t.granularity),t);return e({pass:o,effect:a}),O(t,a,()=>new u.PixelationEffect),()=>{}}}),se=r.defineComponent({__name:"VignettePmndrs",props:{technique:{},blendFunction:{},offset:{},darkness:{}},setup(i,{expose:e}){const t=i,{pass:o,effect:a}=p(()=>new u.VignetteEffect(t),t);return e({pass:o,effect:a}),v([[()=>t.blendFunction,"blendMode.blendFunction"],[()=>t.offset,"offset"],[()=>t.darkness,"darkness"],[()=>t.technique,"technique"]],a,()=>new u.VignetteEffect),()=>{}}});class G extends u.Effect{constructor({blendFunction:e=u.BlendFunction.NORMAL,amount:t=.15,offset:o=new s.Vector2(.5,.5)}={}){super("BarrelBlurEffect",`
8
+ (function(d,r){typeof exports=="object"&&typeof module<"u"?r(exports,require("vue"),require("postprocessing"),require("@tresjs/core"),require("three"),require("@vueuse/core")):typeof define=="function"&&define.amd?define(["exports","vue","postprocessing","@tresjs/core","three","@vueuse/core"],r):(d=typeof globalThis<"u"?globalThis:d||self,r(d["tres-post-processing"]={},d.Vue,d.Postprocessing,d.TresjsCore,d.Three,d.VueUseCore))})(this,function(d,r,u,b,i,W){"use strict";class G{static isWebGL2Available(){try{const t=document.createElement("canvas");return!!(window.WebGL2RenderingContext&&t.getContext("webgl2"))}catch{return!1}}static isColorSpaceAvailable(t){try{const e=document.createElement("canvas"),a=window.WebGL2RenderingContext&&e.getContext("webgl2");return a.drawingBufferColorSpace=t,a.drawingBufferColorSpace===t}catch{return!1}}static getWebGL2ErrorMessage(){return this.getErrorMessage(2)}static getErrorMessage(t){const e={1:"WebGL",2:"WebGL 2"},a={1:window.WebGLRenderingContext,2:window.WebGL2RenderingContext};let o='Your $0 does not seem to support <a href="http://khronos.org/webgl/wiki/Getting_a_WebGL_Implementation" style="color:#000">$1</a>';const n=document.createElement("div");return n.id="webglmessage",n.style.fontFamily="monospace",n.style.fontSize="13px",n.style.fontWeight="normal",n.style.textAlign="center",n.style.background="#fff",n.style.color="#000",n.style.padding="1.5em",n.style.width="400px",n.style.margin="5em auto 0",a[t]?o=o.replace("$0","graphics card"):o=o.replace("$0","browser"),o=o.replace("$1",e[t]),n.innerHTML=o,n}static isWebGLAvailable(){console.warn("isWebGLAvailable() has been deprecated and will be removed in r178. Use isWebGL2Available() instead.");try{const t=document.createElement("canvas");return!!(window.WebGLRenderingContext&&(t.getContext("webgl")||t.getContext("experimental-webgl")))}catch{return!1}}static getWebGLErrorMessage(){return console.warn("getWebGLErrorMessage() has been deprecated and will be removed in r178. Use getWebGL2ErrorMessage() instead."),this.getErrorMessage(1)}}const F=Symbol("effectComposerPmndrs"),_=r.defineComponent({__name:"EffectComposerPmndrs",props:{enabled:{type:Boolean,default:!0},depthBuffer:{type:Boolean,default:void 0},disableNormalPass:{type:Boolean,default:!1},stencilBuffer:{type:Boolean,default:void 0},resolutionScale:{},autoClear:{type:Boolean,default:!0},multisampling:{default:0},frameBufferType:{default:i.HalfFloatType}},emits:["render"],setup(l,{expose:t,emit:e}){const a=l,o=e,{scene:n,camera:s,renderer:c,sizes:f,render:m}=b.useTresContext(),g=r.shallowRef(null);let S=null,h=null;r.provide(F,g),t({composer:g});const A=()=>{g.value&&(h=new u.NormalPass(n.value,s.value),h.enabled=!1,g.value.addPass(h),a.resolutionScale!==void 0&&G.isWebGL2Available()&&(S=new u.DepthDownsamplingPass({normalBuffer:h.texture,resolutionScale:a.resolutionScale}),S.enabled=!1,g.value.addPass(S)))},v=r.computed(()=>{const w=new u.EffectComposer,L={depthBuffer:a.depthBuffer!==void 0?a.depthBuffer:w.inputBuffer.depthBuffer,stencilBuffer:a.stencilBuffer!==void 0?a.stencilBuffer:w.inputBuffer.stencilBuffer,multisampling:G.isWebGL2Available()?a.multisampling!==void 0?a.multisampling:w.multisampling:0,frameBufferType:a.frameBufferType!==void 0?a.frameBufferType:i.HalfFloatType};return w.dispose(),L}),y=()=>{var w;!c.value&&!n.value&&!s.value||((w=g.value)==null||w.dispose(),g.value=new u.EffectComposer(c.value,v.value),g.value.addPass(new u.RenderPass(n.value,s.value)),a.disableNormalPass||A())};r.watch([c,n,s,()=>a.disableNormalPass],()=>{!f.width.value||!f.height.value||y()}),r.watch(()=>[f.width.value,f.height.value],([w,L])=>{!w&&!L||(g.value?g.value.setSize(w,L):y())},{immediate:!0});const{render:T}=b.useLoop();return T(()=>{if(a.enabled&&c.value&&g.value&&f.width.value&&f.height.value&&m.frames.value>0){const w=c.value.autoClear;c.value.autoClear=a.autoClear,a.stencilBuffer&&!a.autoClear&&c.value.clearStencil(),g.value.render(),o("render",g.value),c.value.autoClear=w}m.frames.value=m.mode.value==="always"?1:Math.max(0,m.frames.value-1)}),r.onUnmounted(()=>{var w;(w=g.value)==null||w.dispose()}),(w,L)=>r.renderSlot(w.$slots,"default")}}),p=(l,t,e)=>{const a=r.inject(F),o=r.shallowRef(null),n=r.shallowRef(null),{scene:s,camera:c,invalidate:f}=b.useTresContext();r.watch(t,()=>f());const m=()=>{var h,A,v;o.value&&((h=a==null?void 0:a.value)==null||h.removePass(o.value)),(A=n.value)==null||A.dispose(),(v=o.value)==null||v.dispose()},g=h=>{!c.value||!(a!=null&&a.value)||!s.value||(n.value=l(),o.value=new u.EffectPass(c.value,n.value),a.value.addPass(o.value,h))};e&&r.watch(()=>e.map(h=>t[h]),()=>{var A;if(!(a!=null&&a.value))return;const h=(A=a.value)==null?void 0:A.passes.findIndex(v=>v===o.value);~h&&(m(),g(h))}),r.watchEffect(()=>{!c.value||!(n!=null&&n.value)||(n.value.mainCamera=c.value)});const S=r.watchEffect(()=>{!c.value||!(a!=null&&a.value)||!s.value||(r.nextTick(()=>S()),!n.value&&g())});return r.onUnmounted(()=>{m()}),{pass:o,effect:n}},H=/([^[.\]])+/g,$=(l,t)=>{if(!t)return;const e=Array.isArray(t)?t:t.match(H);return e==null?void 0:e.reduce((a,o)=>a&&a[o],l)},V=(l,t,e)=>{const a=Array.isArray(t)?t:t.match(H);a&&a.reduce((o,n,s)=>(o[n]===void 0&&(o[n]={}),s===a.length-1&&(o[n]=e),o[n]),l)},ee=(l,t)=>{const e={...l};return t.forEach(a=>delete e[a]),e},D=(l,t,e,a,o={})=>r.watch(l,n=>{var s;if(t.value)if(n===void 0){const c=a();V(t.value,e,$(c,e)),(s=c.dispose)==null||s.call(c)}else V(t.value,e,l())},o),x=(l,t,e)=>l.map(([a,o])=>D(a,t,o,e)),N=(l,t,e)=>Object.keys(l).map(a=>D(()=>l[a],t,a,e)),te=r.defineComponent({__name:"BloomPmndrs",props:{blendFunction:{},intensity:{},kernelSize:{},luminanceThreshold:{},luminanceSmoothing:{},mipmapBlur:{type:Boolean,default:void 0}},setup(l,{expose:t}){const e=l,{pass:a,effect:o}=p(()=>new u.BloomEffect(e),e,["mipmapBlur"]);return t({pass:a,effect:o}),x([[()=>e.blendFunction,"blendMode.blendFunction"],[()=>e.intensity,"intensity"],[()=>e.kernelSize,"kernelSize"],[()=>e.luminanceSmoothing,"luminanceMaterial.smoothing"],[()=>e.luminanceThreshold,"luminanceMaterial.threshold"]],o,()=>new u.BloomEffect),()=>{}}}),ae=r.defineComponent({__name:"DepthOfFieldPmndrs",props:{blendFunction:{},worldFocusDistance:{},worldFocusRange:{},focusDistance:{},focusRange:{},bokehScale:{},resolutionScale:{},resolutionX:{},resolutionY:{}},setup(l,{expose:t}){const e=l,{camera:a}=b.useTresContext(),{pass:o,effect:n}=p(()=>new u.DepthOfFieldEffect(a.value,e),e);return t({pass:o,effect:n}),x([[()=>e.blendFunction,"blendMode.blendFunction"],[()=>e.worldFocusDistance,"circleOfConfusionMaterial.worldFocusDistance"],[()=>e.focusDistance,"circleOfConfusionMaterial.focusDistance"],[()=>e.worldFocusRange,"circleOfConfusionMaterial.worldFocusRange"],[()=>e.focusRange,"circleOfConfusionMaterial.focusRange"],[()=>e.bokehScale,"bokehScale"],[()=>e.resolutionScale,"blurPass.resolution.scale"],[()=>e.resolutionX,"resolution.width"],[()=>e.resolutionY,"resolution.height"]],n,()=>new u.DepthOfFieldEffect),()=>{}}}),oe=r.defineComponent({__name:"GlitchPmndrs",props:{blendFunction:{},delay:{},duration:{},strength:{},mode:{},active:{type:Boolean},ratio:{},columns:{},chromaticAberrationOffset:{},perturbationMap:{},dtSize:{}},setup(l,{expose:t}){const e=l,{pass:a,effect:o}=p(()=>new u.GlitchEffect(e),e,["dtSize"]);t({pass:a,effect:o});const{onBeforeRender:n}=b.useLoop();return n(({invalidate:s})=>s()),r.watchEffect(()=>{const s=()=>{if(e.mode!==void 0)return e.active===!1?u.GlitchMode.DISABLED:e.mode;const c=new u.GlitchEffect,f=c.mode;return c.dispose(),f};o.value&&(o.value.mode=s())}),D(()=>e.blendFunction,o,"blendMode.blendFunction",()=>new u.GlitchEffect),N(ee(e,["active","blendFunction"]),o,()=>new u.GlitchEffect),()=>{}}}),ne=r.defineComponent({__name:"NoisePmndrs",props:{premultiply:{type:Boolean,default:void 0},blendFunction:{}},setup(l,{expose:t}){const e=l,{pass:a,effect:o}=p(()=>new u.NoiseEffect(e),e);t({pass:a,effect:o});const{onBeforeRender:n}=b.useLoop();return n(({invalidate:s})=>s()),x([[()=>e.blendFunction,"blendMode.blendFunction"],[()=>e.premultiply,"premultiply"]],o,()=>new u.NoiseEffect),()=>{}}}),ie=r.defineComponent({__name:"OutlinePmndrs",props:{outlinedObjects:{},blur:{type:Boolean,default:void 0},xRay:{type:Boolean,default:void 0},kernelSize:{},pulseSpeed:{},resolutionX:{},resolutionY:{},edgeStrength:{},patternScale:{},multisampling:{},blendFunction:{},patternTexture:{},resolutionScale:{},hiddenEdgeColor:{},visibleEdgeColor:{}},setup(l,{expose:t}){const e=l,a=m=>m!==void 0?b.normalizeColor(m).getHex():void 0,{camera:o,scene:n}=b.useTresContext(),{pass:s,effect:c}=p(()=>new u.OutlineEffect(n.value,o.value,{blur:e.blur,xRay:e.xRay,kernelSize:e.kernelSize,pulseSpeed:e.pulseSpeed,resolutionX:e.resolutionX,resolutionY:e.resolutionY,patternScale:e.patternScale,edgeStrength:e.edgeStrength,blendFunction:e.blendFunction,multisampling:e.multisampling,patternTexture:e.patternTexture,resolutionScale:e.resolutionScale,hiddenEdgeColor:a(e.hiddenEdgeColor),visibleEdgeColor:a(e.visibleEdgeColor)}),e);t({pass:s,effect:c}),r.watch([()=>e.outlinedObjects,c],()=>{var m;(m=c.value)==null||m.selection.set(e.outlinedObjects||[])},{immediate:!0});const f=r.computed(()=>({hiddenEdgeColor:e.hiddenEdgeColor?b.normalizeColor(e.hiddenEdgeColor):void 0,visibleEdgeColor:e.visibleEdgeColor?b.normalizeColor(e.visibleEdgeColor):void 0}));return x([[()=>e.blendFunction,"blendMode.blendFunction"],[()=>e.blur,"blur"],[()=>e.xRay,"xRay"],[()=>e.pulseSpeed,"pulseSpeed"],[()=>e.kernelSize,"kernelSize"],[()=>e.edgeStrength,"edgeStrength"],[()=>e.patternScale,"patternScale"],[()=>e.multisampling,"multisampling"],[()=>e.resolutionX,"resolution.width"],[()=>e.resolutionY,"resolution.height"],[()=>e.patternTexture,"patternTexture"],[()=>e.resolutionScale,"resolution.scale"],[()=>f.value.hiddenEdgeColor,"hiddenEdgeColor"],[()=>f.value.visibleEdgeColor,"visibleEdgeColor"]],c,()=>new u.OutlineEffect),()=>{}}}),se=r.defineComponent({__name:"PixelationPmndrs",props:{granularity:{}},setup(l,{expose:t}){const e=l,{pass:a,effect:o}=p(()=>new u.PixelationEffect(e.granularity),e);return t({pass:a,effect:o}),N(e,o,()=>new u.PixelationEffect),()=>{}}}),re=r.defineComponent({__name:"VignettePmndrs",props:{technique:{},blendFunction:{},offset:{},darkness:{}},setup(l,{expose:t}){const e=l,{pass:a,effect:o}=p(()=>new u.VignetteEffect(e),e);return t({pass:a,effect:o}),x([[()=>e.blendFunction,"blendMode.blendFunction"],[()=>e.offset,"offset"],[()=>e.darkness,"darkness"],[()=>e.technique,"technique"]],o,()=>new u.VignetteEffect),()=>{}}});class I extends u.Effect{constructor({blendFunction:t=u.BlendFunction.NORMAL,amount:e=.15,offset:a=new i.Vector2(.5,.5)}={}){super("BarrelBlurEffect",`
9
9
  uniform float amount;
10
10
  uniform vec2 offset;
11
11
 
@@ -49,7 +49,7 @@
49
49
 
50
50
  outputColor = vec4(outcol, inputColor.a); // Preserves original alpha
51
51
  }
52
- `,{blendFunction:e,uniforms:new Map([["amount",new s.Uniform(t)],["offset",new s.Uniform(o)]])})}get amount(){var e;return(e=this.uniforms.get("amount"))==null?void 0:e.value}set amount(e){this.uniforms.get("amount").value=e}get offset(){var e;return(e=this.uniforms.get("offset"))==null?void 0:e.value}set offset(e){this.uniforms.get("offset").value=e}}const ie=r.defineComponent({__name:"BarrelBlurPmndrs",props:{blendFunction:{},amount:{},offset:{}},setup(i,{expose:e}){const t=i,{pass:o,effect:a}=p(()=>new G({...t,offset:Array.isArray(t.offset)?new s.Vector2(...t.offset):t.offset}),t);return e({pass:o,effect:a}),v([[()=>t.blendFunction,"blendMode.blendFunction"],[()=>t.amount,"amount"],[()=>t.offset,"offset"]],a,()=>new G),()=>{}}}),re=r.defineComponent({__name:"ToneMappingPmndrs",props:{mode:{},blendFunction:{},resolution:{},averageLuminance:{},middleGrey:{},minLuminance:{},whitePoint:{}},setup(i,{expose:e}){const t=i,{pass:o,effect:a}=p(()=>new u.ToneMappingEffect(t),t);return e({pass:o,effect:a}),v([[()=>t.mode,"mode"],[()=>t.blendFunction,"blendMode.blendFunction"],[()=>t.resolution,"resolution"],[()=>t.averageLuminance,"averageLuminance"],[()=>t.middleGrey,"middleGrey"],[()=>t.minLuminance,"adaptiveLuminanceMaterial.minLuminance"],[()=>t.whitePoint,"whitePoint"]],a,()=>new u.ToneMappingEffect),()=>{}}}),le=r.defineComponent({__name:"ChromaticAberrationPmndrs",props:{blendFunction:{},offset:{},radialModulation:{type:Boolean,default:void 0},modulationOffset:{}},setup(i,{expose:e}){const t=i,o=new u.ChromaticAberrationEffect,{pass:a,effect:n}=p(()=>new u.ChromaticAberrationEffect({...t,radialModulation:t.radialModulation??o.radialModulation,modulationOffset:t.modulationOffset??o.modulationOffset}),t);return o.dispose(),e({pass:a,effect:n}),v([[()=>t.blendFunction,"blendMode.blendFunction"],[()=>t.offset,"offset"],[()=>t.radialModulation,"radialModulation"],[()=>t.modulationOffset,"modulationOffset"]],n,()=>new u.ChromaticAberrationEffect),()=>{}}}),ce=r.defineComponent({__name:"HueSaturationPmndrs",props:{saturation:{},hue:{},blendFunction:{}},setup(i,{expose:e}){const t=i,{pass:o,effect:a}=p(()=>new u.HueSaturationEffect(t),t);return e({pass:o,effect:a}),v([[()=>t.blendFunction,"blendMode.blendFunction"],[()=>t.hue,"hue"],[()=>t.saturation,"saturation"]],a,()=>new u.HueSaturationEffect),()=>{}}}),ue=r.defineComponent({__name:"ScanlinePmndrs",props:{blendFunction:{},density:{},scrollSpeed:{},opacity:{}},setup(i,{expose:e}){const t=i,{pass:o,effect:a}=p(()=>new u.ScanlineEffect(t),t);return e({pass:o,effect:a}),v([[()=>t.blendFunction,"blendMode.blendFunction"],[()=>t.density,"density"],[()=>t.scrollSpeed,"scrollSpeed"]],a,()=>new u.ScanlineEffect),r.watch([()=>t.opacity],()=>{var n,l;if(t.opacity!==void 0)(n=a.value)==null||n.blendMode.setOpacity(t.opacity);else{const c=new u.ScanlineEffect;(l=a.value)==null||l.blendMode.setOpacity(c.blendMode.getOpacity()),c.dispose()}},{immediate:!0}),()=>{}}}),de=`
52
+ `,{blendFunction:t,uniforms:new Map([["amount",new i.Uniform(e)],["offset",new i.Uniform(a)]])})}get amount(){var t;return(t=this.uniforms.get("amount"))==null?void 0:t.value}set amount(t){this.uniforms.get("amount").value=t}get offset(){var t;return(t=this.uniforms.get("offset"))==null?void 0:t.value}set offset(t){this.uniforms.get("offset").value=t}}const le=r.defineComponent({__name:"BarrelBlurPmndrs",props:{blendFunction:{},amount:{},offset:{}},setup(l,{expose:t}){const e=l,{pass:a,effect:o}=p(()=>new I({...e,offset:Array.isArray(e.offset)?new i.Vector2(...e.offset):e.offset}),e);return t({pass:a,effect:o}),x([[()=>e.blendFunction,"blendMode.blendFunction"],[()=>e.amount,"amount"],[()=>e.offset,"offset"]],o,()=>new I),()=>{}}}),ce=r.defineComponent({__name:"ToneMappingPmndrs",props:{mode:{},blendFunction:{},resolution:{},averageLuminance:{},middleGrey:{},minLuminance:{},whitePoint:{}},setup(l,{expose:t}){const e=l,{pass:a,effect:o}=p(()=>new u.ToneMappingEffect(e),e);return t({pass:a,effect:o}),x([[()=>e.mode,"mode"],[()=>e.blendFunction,"blendMode.blendFunction"],[()=>e.resolution,"resolution"],[()=>e.averageLuminance,"averageLuminance"],[()=>e.middleGrey,"middleGrey"],[()=>e.minLuminance,"adaptiveLuminanceMaterial.minLuminance"],[()=>e.whitePoint,"whitePoint"]],o,()=>new u.ToneMappingEffect),()=>{}}}),ue=r.defineComponent({__name:"ChromaticAberrationPmndrs",props:{blendFunction:{},offset:{},radialModulation:{type:Boolean,default:void 0},modulationOffset:{}},setup(l,{expose:t}){const e=l,a=new u.ChromaticAberrationEffect,{pass:o,effect:n}=p(()=>new u.ChromaticAberrationEffect({...e,radialModulation:e.radialModulation??a.radialModulation,modulationOffset:e.modulationOffset??a.modulationOffset}),e);return a.dispose(),t({pass:o,effect:n}),x([[()=>e.blendFunction,"blendMode.blendFunction"],[()=>e.offset,"offset"],[()=>e.radialModulation,"radialModulation"],[()=>e.modulationOffset,"modulationOffset"]],n,()=>new u.ChromaticAberrationEffect),()=>{}}}),de=r.defineComponent({__name:"HueSaturationPmndrs",props:{saturation:{},hue:{},blendFunction:{}},setup(l,{expose:t}){const e=l,{pass:a,effect:o}=p(()=>new u.HueSaturationEffect(e),e);return t({pass:a,effect:o}),x([[()=>e.blendFunction,"blendMode.blendFunction"],[()=>e.hue,"hue"],[()=>e.saturation,"saturation"]],o,()=>new u.HueSaturationEffect),()=>{}}}),fe=r.defineComponent({__name:"ScanlinePmndrs",props:{blendFunction:{},density:{},scrollSpeed:{},opacity:{}},setup(l,{expose:t}){const e=l,{pass:a,effect:o}=p(()=>new u.ScanlineEffect(e),e);return t({pass:a,effect:o}),x([[()=>e.blendFunction,"blendMode.blendFunction"],[()=>e.density,"density"],[()=>e.scrollSpeed,"scrollSpeed"]],o,()=>new u.ScanlineEffect),r.watch([()=>e.opacity],()=>{var n,s;if(e.opacity!==void 0)(n=o.value)==null||n.blendMode.setOpacity(e.opacity);else{const c=new u.ScanlineEffect;(s=o.value)==null||s.blendMode.setOpacity(c.blendMode.getOpacity()),c.dispose()}},{immediate:!0}),()=>{}}}),he=`
53
53
  uniform float radius;
54
54
  uniform int sectorCount;
55
55
 
@@ -145,7 +145,7 @@ void mainImage(const in vec4 inputColor, const in vec2 uv, out vec4 outputColor)
145
145
 
146
146
  outputColor = vec4(finalColor, inputColor.a);
147
147
  }
148
- `;class H extends u.Effect{constructor({blendFunction:e=u.BlendFunction.NORMAL,radius:t=1,sectorCount:o=4}={}){super("KuwaharaEffect",de,{blendFunction:e,uniforms:new Map([["radius",new s.Uniform(t)],["sectorCount",new s.Uniform(o)]])})}get radius(){var e;return(e=this.uniforms.get("radius"))==null?void 0:e.value}set radius(e){this.uniforms.get("radius").value=e}get sectorCount(){var e;return(e=this.uniforms.get("sectorCount"))==null?void 0:e.value}set sectorCount(e){this.uniforms.get("sectorCount").value=e}}const fe=r.defineComponent({__name:"KuwaharaPmndrs",props:{blendFunction:{},radius:{},sectorCount:{}},setup(i,{expose:e}){const t=i,{pass:o,effect:a}=p(()=>new H(t),t);return e({pass:o,effect:a}),v([[()=>t.blendFunction,"blendMode.blendFunction"],[()=>t.radius,"radius"],[()=>t.sectorCount,"sectorCount"]],a,()=>new H),()=>{}}}),he=r.defineComponent({__name:"ColorAveragePmndrs",props:{blendFunction:{},opacity:{}},setup(i,{expose:e}){const t=i,{pass:o,effect:a}=p(()=>new u.ColorAverageEffect(t.blendFunction),t);return e({pass:o,effect:a}),E(()=>t.blendFunction,a,"blendMode.blendFunction",()=>new u.ColorAverageEffect),r.watch([a,()=>t.opacity],()=>{var n,l;if(a.value)if(t.opacity!==void 0)(n=a.value)==null||n.blendMode.setOpacity(t.opacity);else{const c=new u.ColorAverageEffect;(l=a.value)==null||l.blendMode.setOpacity(c.blendMode.getOpacity()),c.dispose()}}),()=>{}}}),me=r.defineComponent({__name:"LensDistortionPmndrs",props:{distortion:{},principalPoint:{},focalLength:{},skew:{}},setup(i,{expose:e}){const t=i,{pass:o,effect:a}=p(()=>new u.LensDistortionEffect({...t,distortion:t.distortion?Array.isArray(t.distortion)?new s.Vector2(...t.distortion):t.distortion:new s.Vector2,principalPoint:t.principalPoint?Array.isArray(t.principalPoint)?new s.Vector2(...t.principalPoint):t.principalPoint:new s.Vector2,focalLength:t.focalLength?Array.isArray(t.focalLength)?new s.Vector2(...t.focalLength):t.focalLength:new s.Vector2}),t);return e({pass:o,effect:a}),O(t,a,()=>new u.LensDistortionEffect),()=>{}}}),pe=r.defineComponent({__name:"ShockWavePmndrs",props:{position:{},amplitude:{},speed:{},maxRadius:{},waveSize:{}},setup(i,{expose:e}){const t=i,{camera:o}=x.useTresContext(),{pass:a,effect:n}=p(()=>new u.ShockWaveEffect(o.value,Array.isArray(t.position)?new s.Vector3(...t.position):t.position,t),t);return e({pass:a,effect:n}),r.watch(()=>t.position,l=>{n.value&&(Array.isArray(l)?n.value.position.set(...l):l instanceof s.Vector3&&n.value.position.copy(l))},{immediate:!0}),v([[()=>t.amplitude,"amplitude"],[()=>t.waveSize,"waveSize"],[()=>t.maxRadius,"maxRadius"],[()=>t.speed,"speed"]],n,()=>new u.ShockWaveEffect),()=>{}}}),ge=r.defineComponent({__name:"TiltShiftPmndrs",props:{blendFunction:{},offset:{},rotation:{},focusArea:{},feather:{},kernelSize:{},resolutionScale:{},resolutionX:{},resolutionY:{}},setup(i,{expose:e}){const t=i,{pass:o,effect:a}=p(()=>new u.TiltShiftEffect(t),t);return e({pass:o,effect:a}),v([[()=>t.blendFunction,"blendMode.blendFunction"],[()=>t.offset,"offset"],[()=>t.rotation,"rotation"],[()=>t.focusArea,"focusArea"],[()=>t.feather,"feather"],[()=>t.kernelSize,"kernelSize"],[()=>t.resolutionScale,"resolution.scale"],[()=>t.resolutionX,"resolution.width"],[()=>t.resolutionY,"resolution.height"]],a,()=>new u.TiltShiftEffect),()=>{}}}),ve=r.defineComponent({__name:"DotScreenPmndrs",props:{angle:{},scale:{},blendFunction:{}},setup(i,{expose:e}){const t=i,{pass:o,effect:a}=p(()=>new u.DotScreenEffect(t),t);return e({pass:o,effect:a}),v([[()=>t.blendFunction,"blendMode.blendFunction"],[()=>t.angle,"angle"],[()=>t.scale,"scale"]],a,()=>new u.DotScreenEffect),()=>{}}}),xe=r.defineComponent({__name:"SepiaPmndrs",props:{blendFunction:{},intensity:{}},setup(i,{expose:e}){const t=i,{pass:o,effect:a}=p(()=>new u.SepiaEffect(t),t);return e({pass:o,effect:a}),v([[()=>t.blendFunction,"blendMode.blendFunction"],[()=>t.intensity,"intensity"]],a,()=>new u.SepiaEffect),()=>{}}});class V extends u.Effect{constructor({blendFunction:e=u.BlendFunction.NORMAL,scale:t=.85,noiseScale:o=0,center:a=[.5,.5],rotation:n=0}={}){const l=Array.isArray(a)?new s.Vector2().fromArray(a):a;super("LinocutEffect",`
148
+ `;class X extends u.Effect{constructor({blendFunction:t=u.BlendFunction.NORMAL,radius:e=1,sectorCount:a=4}={}){super("KuwaharaEffect",he,{blendFunction:t,uniforms:new Map([["radius",new i.Uniform(e)],["sectorCount",new i.Uniform(a)]])})}get radius(){var t;return(t=this.uniforms.get("radius"))==null?void 0:t.value}set radius(t){this.uniforms.get("radius").value=t}get sectorCount(){var t;return(t=this.uniforms.get("sectorCount"))==null?void 0:t.value}set sectorCount(t){this.uniforms.get("sectorCount").value=t}}const me=r.defineComponent({__name:"KuwaharaPmndrs",props:{blendFunction:{},radius:{},sectorCount:{}},setup(l,{expose:t}){const e=l,{pass:a,effect:o}=p(()=>new X(e),e);return t({pass:a,effect:o}),x([[()=>e.blendFunction,"blendMode.blendFunction"],[()=>e.radius,"radius"],[()=>e.sectorCount,"sectorCount"]],o,()=>new X),()=>{}}}),pe=r.defineComponent({__name:"ColorAveragePmndrs",props:{blendFunction:{},opacity:{}},setup(l,{expose:t}){const e=l,{pass:a,effect:o}=p(()=>new u.ColorAverageEffect(e.blendFunction),e);return t({pass:a,effect:o}),D(()=>e.blendFunction,o,"blendMode.blendFunction",()=>new u.ColorAverageEffect),r.watch([o,()=>e.opacity],()=>{var n,s;if(o.value)if(e.opacity!==void 0)(n=o.value)==null||n.blendMode.setOpacity(e.opacity);else{const c=new u.ColorAverageEffect;(s=o.value)==null||s.blendMode.setOpacity(c.blendMode.getOpacity()),c.dispose()}}),()=>{}}}),ge=r.defineComponent({__name:"LensDistortionPmndrs",props:{distortion:{},principalPoint:{},focalLength:{},skew:{}},setup(l,{expose:t}){const e=l,{pass:a,effect:o}=p(()=>new u.LensDistortionEffect({...e,distortion:e.distortion?Array.isArray(e.distortion)?new i.Vector2(...e.distortion):e.distortion:new i.Vector2,principalPoint:e.principalPoint?Array.isArray(e.principalPoint)?new i.Vector2(...e.principalPoint):e.principalPoint:new i.Vector2,focalLength:e.focalLength?Array.isArray(e.focalLength)?new i.Vector2(...e.focalLength):e.focalLength:new i.Vector2}),e);return t({pass:a,effect:o}),N(e,o,()=>new u.LensDistortionEffect),()=>{}}}),ve=r.defineComponent({__name:"ShockWavePmndrs",props:{position:{},amplitude:{},speed:{},maxRadius:{},waveSize:{}},setup(l,{expose:t}){const e=l,{camera:a}=b.useTresContext(),{pass:o,effect:n}=p(()=>new u.ShockWaveEffect(a.value,Array.isArray(e.position)?new i.Vector3(...e.position):e.position,e),e);return t({pass:o,effect:n}),r.watch(()=>e.position,s=>{n.value&&(Array.isArray(s)?n.value.position.set(...s):s instanceof i.Vector3&&n.value.position.copy(s))},{immediate:!0}),x([[()=>e.amplitude,"amplitude"],[()=>e.waveSize,"waveSize"],[()=>e.maxRadius,"maxRadius"],[()=>e.speed,"speed"]],n,()=>new u.ShockWaveEffect),()=>{}}}),xe=r.defineComponent({__name:"TiltShiftPmndrs",props:{blendFunction:{},offset:{},rotation:{},focusArea:{},feather:{},kernelSize:{},resolutionScale:{},resolutionX:{},resolutionY:{}},setup(l,{expose:t}){const e=l,{pass:a,effect:o}=p(()=>new u.TiltShiftEffect(e),e);return t({pass:a,effect:o}),x([[()=>e.blendFunction,"blendMode.blendFunction"],[()=>e.offset,"offset"],[()=>e.rotation,"rotation"],[()=>e.focusArea,"focusArea"],[()=>e.feather,"feather"],[()=>e.kernelSize,"kernelSize"],[()=>e.resolutionScale,"resolution.scale"],[()=>e.resolutionX,"resolution.width"],[()=>e.resolutionY,"resolution.height"]],o,()=>new u.TiltShiftEffect),()=>{}}}),be=r.defineComponent({__name:"DotScreenPmndrs",props:{angle:{},scale:{},blendFunction:{}},setup(l,{expose:t}){const e=l,{pass:a,effect:o}=p(()=>new u.DotScreenEffect(e),e);return t({pass:a,effect:o}),x([[()=>e.blendFunction,"blendMode.blendFunction"],[()=>e.angle,"angle"],[()=>e.scale,"scale"]],o,()=>new u.DotScreenEffect),()=>{}}}),we=r.defineComponent({__name:"SepiaPmndrs",props:{blendFunction:{},intensity:{}},setup(l,{expose:t}){const e=l,{pass:a,effect:o}=p(()=>new u.SepiaEffect(e),e);return t({pass:a,effect:o}),x([[()=>e.blendFunction,"blendMode.blendFunction"],[()=>e.intensity,"intensity"]],o,()=>new u.SepiaEffect),()=>{}}});class j extends u.Effect{constructor({blendFunction:t=u.BlendFunction.NORMAL,scale:e=.85,noiseScale:a=0,center:o=[.5,.5],rotation:n=0}={}){const s=Array.isArray(o)?new i.Vector2().fromArray(o):o;super("LinocutEffect",`
149
149
  uniform float scale;
150
150
  uniform float noiseScale;
151
151
  uniform vec2 center;
@@ -205,7 +205,7 @@ void mainImage(const in vec4 inputColor, const in vec2 uv, out vec4 outputColor)
205
205
  // Output the final color in black and white
206
206
  outputColor = vec4(vec3(f), 1.0);
207
207
  }
208
- `,{blendFunction:e,uniforms:new Map([["scale",new s.Uniform(t)],["noiseScale",new s.Uniform(o)],["center",new s.Uniform(l)],["rotation",new s.Uniform(n)]])})}get scale(){var e;return(e=this.uniforms.get("scale"))==null?void 0:e.value}set scale(e){this.uniforms.get("scale").value=e}get noiseScale(){var e;return(e=this.uniforms.get("noiseScale"))==null?void 0:e.value}set noiseScale(e){this.uniforms.get("noiseScale").value=e}get center(){var e;return(e=this.uniforms.get("center"))==null?void 0:e.value}set center(e){this.uniforms.get("center").value=Array.isArray(e)?new s.Vector2().fromArray(e):e}get rotation(){var e;return(e=this.uniforms.get("rotation"))==null?void 0:e.value}set rotation(e){this.uniforms.get("rotation").value=e}}const be=r.defineComponent({__name:"LinocutPmndrs",props:{blendFunction:{},scale:{},noiseScale:{},center:{},rotation:{}},setup(i,{expose:e}){const t=i,{pass:o,effect:a}=p(()=>new V({...t,center:t.center instanceof s.Vector2?[t.center.x,t.center.y]:t.center}),t);return e({pass:o,effect:a}),v([[()=>t.blendFunction,"blendMode.blendFunction"],[()=>t.scale,"scale"],[()=>t.noiseScale,"noiseScale"],[()=>t.center,"center"],[()=>t.rotation,"rotation"]],a,()=>new V),()=>{}}}),we=r.defineComponent({__name:"DepthPickingPassPmndrs",props:{depthPacking:{},mode:{}},setup(i,{expose:e}){const t=i,o=r.inject(R),a=new u.DepthPickingPass(t),n=r.watchEffect(()=>{o!=null&&o.value&&(r.nextTick(()=>n()),o.value.addPass(a))});return r.onUnmounted(()=>{var l;!(o!=null&&o.value)||!a||((l=o==null?void 0:o.value)==null||l.removePass(a),a.dispose())}),e({pass:a}),()=>{}}}),Se=r.defineComponent({__name:"GodRaysPmndrs",props:{blendFunction:{},lightSource:{},opacity:{},density:{},decay:{},kernelSize:{},resolutionScale:{},blur:{type:Boolean},resolutionX:{},resolutionY:{},weight:{},exposure:{},samples:{},clampMax:{}},setup(i,{expose:e}){const t=i,{camera:o}=x.useTresContext(),a=r.computed(()=>t.lightSource??new s.Mesh(new s.SphereGeometry(1e-5),new s.MeshBasicMaterial({visible:!1}))),{pass:n,effect:l}=p(()=>new u.GodRaysEffect(o.value,a.value,t),t);return e({pass:n,effect:l}),v([[()=>t.blendFunction,"blendMode.blendFunction"],[()=>t.density,"godRaysMaterial.density"],[()=>t.decay,"godRaysMaterial.decay"],[()=>t.weight,"godRaysMaterial.weight"],[()=>t.exposure,"godRaysMaterial.exposure"],[()=>t.samples,"godRaysMaterial.samples"],[()=>t.clampMax,"godRaysMaterial.maxIntensity"],[()=>t.resolutionScale,"resolution.scale"],[()=>t.resolutionX,"resolution.width"],[()=>t.resolutionY,"resolution.height"],[()=>t.kernelSize,"blurPass.kernelSize"],[()=>t.blur,"blurPass.enabled"]],l,()=>new u.GodRaysEffect),r.watch([()=>t.lightSource,l],()=>{l.value&&(l.value.lightSource=r.toRaw(a.value))},{immediate:!0}),r.watch([()=>t.opacity],()=>{var c,f;if(t.opacity!==void 0)(c=l.value)==null||c.blendMode.setOpacity(t.opacity);else{const m=new u.GodRaysEffect(o.value,r.toRaw(a.value));(f=l.value)==null||f.blendMode.setOpacity(m.blendMode.getOpacity()),m.dispose()}},{immediate:!0}),()=>{}}}),Ae=r.defineComponent({__name:"ColorDepthPmndrs",props:{blendFunction:{},bits:{},opacity:{}},setup(i,{expose:e}){const t=i,{pass:o,effect:a}=p(()=>new u.ColorDepthEffect(t),t);return e({pass:o,effect:a}),E(()=>t.blendFunction,a,"blendMode.blendFunction",()=>new u.ColorDepthEffect),r.watch([a,()=>t.bits],()=>{var n,l;if(a.value)if(t.bits!==void 0)(n=a.value)==null||n.setBitDepth(t.bits);else{const c=new u.ColorDepthEffect;(l=a.value)==null||l.setBitDepth(c.getBitDepth()),c.dispose()}}),r.watch([a,()=>t.opacity],()=>{var n,l;if(a.value)if(t.opacity!==void 0)(n=a.value)==null||n.blendMode.setOpacity(t.opacity);else{const c=new u.ColorDepthEffect;(l=a.value)==null||l.blendMode.setOpacity(c.blendMode.getOpacity()),c.dispose()}}),()=>{}}}),ye=r.defineComponent({__name:"GridPmndrs",props:{blendFunction:{},scale:{},lineWidth:{}},setup(i,{expose:e}){const t=i,{pass:o,effect:a}=p(()=>new u.GridEffect(t),t);return e({pass:o,effect:a}),v([[()=>t.blendFunction,"blendMode.blendFunction"],[()=>t.scale,"scale"],[()=>t.lineWidth,"lineWidth"]],a,()=>new u.GridEffect),()=>{}}});class X extends u.Effect{constructor({blendFunction:e=u.BlendFunction.NORMAL,lensS:t=new s.Vector2(1,1),lensF:o=new s.Vector2(0,1),scale:a=1}={}){super("FishEyeEffect",`
208
+ `,{blendFunction:t,uniforms:new Map([["scale",new i.Uniform(e)],["noiseScale",new i.Uniform(a)],["center",new i.Uniform(s)],["rotation",new i.Uniform(n)]])})}get scale(){var t;return(t=this.uniforms.get("scale"))==null?void 0:t.value}set scale(t){this.uniforms.get("scale").value=t}get noiseScale(){var t;return(t=this.uniforms.get("noiseScale"))==null?void 0:t.value}set noiseScale(t){this.uniforms.get("noiseScale").value=t}get center(){var t;return(t=this.uniforms.get("center"))==null?void 0:t.value}set center(t){this.uniforms.get("center").value=Array.isArray(t)?new i.Vector2().fromArray(t):t}get rotation(){var t;return(t=this.uniforms.get("rotation"))==null?void 0:t.value}set rotation(t){this.uniforms.get("rotation").value=t}}const Se=r.defineComponent({__name:"LinocutPmndrs",props:{blendFunction:{},scale:{},noiseScale:{},center:{},rotation:{}},setup(l,{expose:t}){const e=l,{pass:a,effect:o}=p(()=>new j({...e,center:e.center instanceof i.Vector2?[e.center.x,e.center.y]:e.center}),e);return t({pass:a,effect:o}),x([[()=>e.blendFunction,"blendMode.blendFunction"],[()=>e.scale,"scale"],[()=>e.noiseScale,"noiseScale"],[()=>e.center,"center"],[()=>e.rotation,"rotation"]],o,()=>new j),()=>{}}}),Ae=r.defineComponent({__name:"DepthPickingPassPmndrs",props:{depthPacking:{},mode:{}},setup(l,{expose:t}){const e=l,a=r.inject(F),o=new u.DepthPickingPass(e),n=r.watchEffect(()=>{a!=null&&a.value&&(r.nextTick(()=>n()),a.value.addPass(o))});return r.onUnmounted(()=>{var s;!(a!=null&&a.value)||!o||((s=a==null?void 0:a.value)==null||s.removePass(o),o.dispose())}),t({pass:o}),()=>{}}}),ye=r.defineComponent({__name:"GodRaysPmndrs",props:{blendFunction:{},lightSource:{},opacity:{},density:{},decay:{},kernelSize:{},resolutionScale:{},blur:{type:Boolean},resolutionX:{},resolutionY:{},weight:{},exposure:{},samples:{},clampMax:{}},setup(l,{expose:t}){const e=l,{camera:a}=b.useTresContext(),o=r.computed(()=>e.lightSource??new i.Mesh(new i.SphereGeometry(1e-5),new i.MeshBasicMaterial({visible:!1}))),{pass:n,effect:s}=p(()=>new u.GodRaysEffect(a.value,o.value,e),e);return t({pass:n,effect:s}),x([[()=>e.blendFunction,"blendMode.blendFunction"],[()=>e.density,"godRaysMaterial.density"],[()=>e.decay,"godRaysMaterial.decay"],[()=>e.weight,"godRaysMaterial.weight"],[()=>e.exposure,"godRaysMaterial.exposure"],[()=>e.samples,"godRaysMaterial.samples"],[()=>e.clampMax,"godRaysMaterial.maxIntensity"],[()=>e.resolutionScale,"resolution.scale"],[()=>e.resolutionX,"resolution.width"],[()=>e.resolutionY,"resolution.height"],[()=>e.kernelSize,"blurPass.kernelSize"],[()=>e.blur,"blurPass.enabled"]],s,()=>new u.GodRaysEffect),r.watch([()=>e.lightSource,s],()=>{s.value&&(s.value.lightSource=r.toRaw(o.value))},{immediate:!0}),r.watch([()=>e.opacity],()=>{var c,f;if(e.opacity!==void 0)(c=s.value)==null||c.blendMode.setOpacity(e.opacity);else{const m=new u.GodRaysEffect(a.value,r.toRaw(o.value));(f=s.value)==null||f.blendMode.setOpacity(m.blendMode.getOpacity()),m.dispose()}},{immediate:!0}),()=>{}}}),Me=r.defineComponent({__name:"ColorDepthPmndrs",props:{blendFunction:{},bits:{},opacity:{}},setup(l,{expose:t}){const e=l,{pass:a,effect:o}=p(()=>new u.ColorDepthEffect(e),e);return t({pass:a,effect:o}),D(()=>e.blendFunction,o,"blendMode.blendFunction",()=>new u.ColorDepthEffect),r.watch([o,()=>e.bits],()=>{var n,s;if(o.value)if(e.bits!==void 0)(n=o.value)==null||n.setBitDepth(e.bits);else{const c=new u.ColorDepthEffect;(s=o.value)==null||s.setBitDepth(c.getBitDepth()),c.dispose()}}),r.watch([o,()=>e.opacity],()=>{var n,s;if(o.value)if(e.opacity!==void 0)(n=o.value)==null||n.blendMode.setOpacity(e.opacity);else{const c=new u.ColorDepthEffect;(s=o.value)==null||s.blendMode.setOpacity(c.blendMode.getOpacity()),c.dispose()}}),()=>{}}}),Te=r.defineComponent({__name:"GridPmndrs",props:{blendFunction:{},scale:{},lineWidth:{}},setup(l,{expose:t}){const e=l,{pass:a,effect:o}=p(()=>new u.GridEffect(e),e);return t({pass:a,effect:o}),x([[()=>e.blendFunction,"blendMode.blendFunction"],[()=>e.scale,"scale"],[()=>e.lineWidth,"lineWidth"]],o,()=>new u.GridEffect),()=>{}}});class Y extends u.Effect{constructor({blendFunction:t=u.BlendFunction.NORMAL,lensS:e=new i.Vector2(1,1),lensF:a=new i.Vector2(0,1),scale:o=1}={}){super("FishEyeEffect",`
209
209
  uniform vec2 lensS;
210
210
  uniform vec2 lensF;
211
211
  uniform float scale;
@@ -223,7 +223,7 @@ void mainImage(const in vec4 inputColor, const in vec2 uv, out vec4 outputColor)
223
223
  void mainImage(const in vec4 inputColor, const in vec2 uv, out vec4 outputColor) {
224
224
  outputColor = vec4(inputColor.rgb, inputColor.a); // Preserves original alpha
225
225
  }
226
- `,{blendFunction:e,uniforms:new Map([["lensS",new s.Uniform(t)],["lensF",new s.Uniform(o)],["scale",new s.Uniform(a)]])})}get lensS(){var e;return(e=this.uniforms.get("lensS"))==null?void 0:e.value}set lensS(e){this.uniforms.get("lensS").value=e}get lensF(){var e;return(e=this.uniforms.get("lensF"))==null?void 0:e.value}set lensF(e){this.uniforms.get("lensF").value=e}get scale(){var e;return(e=this.uniforms.get("scale"))==null?void 0:e.value}set scale(e){this.uniforms.get("scale").value=e}}const Me=r.defineComponent({__name:"FishEyePmndrs",props:{blendFunction:{},lensS:{},lensF:{},scale:{}},setup(i,{expose:e}){const t=i,o=r.computed(()=>Array.isArray(t.lensS)?new s.Vector2(...t.lensS):t.lensS),a=r.computed(()=>Array.isArray(t.lensF)?new s.Vector2(...t.lensF):t.lensF),{pass:n,effect:l}=p(()=>new X({...t,lensS:o.value,lensF:a.value}),t);return e({pass:n,effect:l}),v([[()=>t.blendFunction,"blendMode.blendFunction"],[()=>o.value,"lensS"],[()=>a.value,"lensF"],[()=>t.scale,"scale"]],l,()=>new X),()=>{}}}),Te=r.defineComponent({__name:"BrightnessContrastPmndrs",props:{blendFunction:{},brightness:{},contrast:{}},setup(i,{expose:e}){const t=i,{pass:o,effect:a}=p(()=>new u.BrightnessContrastEffect(t),t);return e({pass:o,effect:a}),v([[()=>t.blendFunction,"blendMode.blendFunction"],[()=>t.brightness,"brightness"],[()=>t.contrast,"contrast"]],a,()=>new u.BrightnessContrastEffect),()=>{}}}),I={name:"CopyShader",uniforms:{tDiffuse:{value:null},opacity:{value:1}},vertexShader:`
226
+ `,{blendFunction:t,uniforms:new Map([["lensS",new i.Uniform(e)],["lensF",new i.Uniform(a)],["scale",new i.Uniform(o)]])})}get lensS(){var t;return(t=this.uniforms.get("lensS"))==null?void 0:t.value}set lensS(t){this.uniforms.get("lensS").value=t}get lensF(){var t;return(t=this.uniforms.get("lensF"))==null?void 0:t.value}set lensF(t){this.uniforms.get("lensF").value=t}get scale(){var t;return(t=this.uniforms.get("scale"))==null?void 0:t.value}set scale(t){this.uniforms.get("scale").value=t}}const Ce=r.defineComponent({__name:"FishEyePmndrs",props:{blendFunction:{},lensS:{},lensF:{},scale:{}},setup(l,{expose:t}){const e=l,a=r.computed(()=>Array.isArray(e.lensS)?new i.Vector2(...e.lensS):e.lensS),o=r.computed(()=>Array.isArray(e.lensF)?new i.Vector2(...e.lensF):e.lensF),{pass:n,effect:s}=p(()=>new Y({...e,lensS:a.value,lensF:o.value}),e);return t({pass:n,effect:s}),x([[()=>e.blendFunction,"blendMode.blendFunction"],[()=>a.value,"lensS"],[()=>o.value,"lensF"],[()=>e.scale,"scale"]],s,()=>new Y),()=>{}}}),Ee=r.defineComponent({__name:"BrightnessContrastPmndrs",props:{blendFunction:{},brightness:{},contrast:{}},setup(l,{expose:t}){const e=l,{pass:a,effect:o}=p(()=>new u.BrightnessContrastEffect(e),e);return t({pass:a,effect:o}),x([[()=>e.blendFunction,"blendMode.blendFunction"],[()=>e.brightness,"brightness"],[()=>e.contrast,"contrast"]],o,()=>new u.BrightnessContrastEffect),()=>{}}}),z={OFF:0,EDGES:1,WEIGHTS:2},Pe=r.defineComponent({__name:"SMAAPmndrs",props:{blendFunction:{},opacity:{},preset:{},edgeDetectionMode:{},predicationMode:{},debug:{}},setup(l,{expose:t}){const e=l,{pass:a,effect:o}=p(()=>new u.SMAAEffect(e),e),{camera:n}=b.useTresContext(),s=r.inject(F);t({pass:a,effect:o});const c=new u.SMAAEffect;x([[()=>Number(e.blendFunction),"blendMode.blendFunction"],[()=>Number(e.predicationMode),"edgeDetectionMaterial.predicationMode"],[()=>Number(e.edgeDetectionMode),"edgeDetectionMaterial.edgeDetectionMode"]],o,()=>new u.SMAAEffect),r.watch([o,()=>e.opacity],()=>{o.value&&(e.opacity!==void 0?o.value.blendMode.setOpacity(e.opacity):o.value.blendMode.setOpacity(c.blendMode.getOpacity()))},{immediate:!0}),r.watch([o,()=>e.preset],()=>{o.value&&o.value.applyPreset(Number(e.preset))});let f=null,m=null;const g=v=>{if(!o.value)return null;const y=v==="edges"?o.value.edgesTexture:o.value.weightsTexture,T=new u.EffectPass(n.value,o.value,new u.TextureEffect({texture:y}));return T.renderToScreen=!1,T.enabled=!1,T.fullscreenMaterial.encodeOutput=!1,T},S=v=>{v==="edges"&&!f?f=g("edges"):v==="weights"&&!m&&(m=g("weights"))},h=(v,y)=>{!v||!(s!=null&&s.value)||v.enabled!==y&&(v.enabled=y,v.renderToScreen=y,y&&!(s!=null&&s.value.passes.includes(v))?s==null||s.value.addPass(v):!y&&(s!=null&&s.value.passes.includes(v))&&(s==null||s.value.removePass(v),v.dispose()))},A=v=>{if(!a.value)return;const y=v===z.OFF,T=v===z.EDGES,w=v===z.WEIGHTS;a.value.enabled=y,a.value.renderToScreen=y,T&&S("edges"),w&&S("weights"),h(f,T),h(m,w),T||(f=null),w||(m=null)};return r.watch(()=>e.debug,()=>{!a.value||e.debug===void 0||A(e.debug)},{immediate:!0}),()=>{}}}),De=r.defineComponent({__name:"FXAAPmndrs",props:{blendFunction:{},opacity:{},samples:{},minEdgeThreshold:{},maxEdgeThreshold:{},subpixelQuality:{}},setup(l,{expose:t}){const e=l,{pass:a,effect:o}=p(()=>new u.FXAAEffect(e),e);return t({pass:a,effect:o}),x([[()=>e.blendFunction,"blendMode.blendFunction"],[()=>e.samples,"samples"],[()=>e.minEdgeThreshold,"minEdgeThreshold"],[()=>e.maxEdgeThreshold,"maxEdgeThreshold"],[()=>e.subpixelQuality,"subpixelQuality"]],o,()=>new u.FXAAEffect),r.watch([o,()=>e.opacity],()=>{var n,s;if(o.value)if(e.opacity!==void 0)(n=o.value)==null||n.blendMode.setOpacity(e.opacity);else{const c=new u.FXAAEffect;(s=o.value)==null||s.blendMode.setOpacity(c.blendMode.getOpacity()),c.dispose()}},{immediate:!0}),()=>{}}}),Le=r.defineComponent({__name:"TexturePmndrs",props:{blendFunction:{},texture:{},opacity:{}},setup(l,{expose:t}){const e=l,{pass:a,effect:o}=p(()=>new u.TextureEffect(e),e);return t({pass:a,effect:o}),x([[()=>e.blendFunction,"blendMode.blendFunction"]],o,()=>new u.TextureEffect),r.watch([()=>e.opacity],()=>{var n,s;if(e.opacity!==void 0)(n=o.value)==null||n.blendMode.setOpacity(e.opacity);else{const c=new u.TextureEffect;(s=o.value)==null||s.blendMode.setOpacity(c.blendMode.getOpacity()),c.dispose()}},{immediate:!0}),()=>{}}}),Fe=r.defineComponent({__name:"ASCIIPmndrs",props:{blendFunction:{},opacity:{},cellSize:{},inverted:{type:Boolean},color:{},useSceneColor:{type:Boolean},asciiTexture:{}},setup(l,{expose:t}){const e=l,a=new u.ASCIIEffect,{asciiTexture:o,...n}=e,{pass:s,effect:c}=p(()=>new u.ASCIIEffect(n),e);return t({pass:s,effect:c}),r.onUnmounted(()=>{a.dispose()}),x([[()=>e.blendFunction,"blendMode.blendFunction"],[()=>e.cellSize,"cellSize"],[()=>e.inverted,"inverted"]],c,()=>new u.ASCIIEffect),r.watch([c,()=>e.useSceneColor],()=>{c.value&&(e.useSceneColor?c.value.color=null:c.value.color=e.color??a.color)},{immediate:!0}),r.watch([c,()=>e.opacity],()=>{c.value&&c.value.blendMode.setOpacity(e.opacity??a.blendMode.getOpacity())},{immediate:!0}),r.watch([c,()=>e.color],()=>{c.value&&(e.useSceneColor||(c.value.color=e.color??null))},{immediate:!0}),r.watch([c,()=>e.asciiTexture],()=>{if(!c.value)return;const f=e.asciiTexture?new u.ASCIITexture(e.asciiTexture):a.asciiTexture;c.value.asciiTexture=f},{immediate:!0}),r.watch([c,()=>e.blendFunction],()=>{c.value&&(c.value.blendMode.blendFunction=e.blendFunction?Number(e.blendFunction):Number(a.blendMode.blendFunction))},{immediate:!0}),()=>{}}}),k={name:"CopyShader",uniforms:{tDiffuse:{value:null},opacity:{value:1}},vertexShader:`
227
227
 
228
228
  varying vec2 vUv;
229
229
 
@@ -246,7 +246,7 @@ void mainImage(const in vec4 inputColor, const in vec2 uv, out vec4 outputColor)
246
246
  gl_FragColor = opacity * texel;
247
247
 
248
248
 
249
- }`};class A{constructor(){this.isPass=!0,this.enabled=!0,this.needsSwap=!0,this.clear=!1,this.renderToScreen=!1}setSize(){}render(){console.error("THREE.Pass: .render() must be implemented in derived pass.")}dispose(){}}const Ce=new s.OrthographicCamera(-1,1,1,-1,0,1);class Ee extends s.BufferGeometry{constructor(){super(),this.setAttribute("position",new s.Float32BufferAttribute([-1,3,0,-1,-1,0,3,-1,0],3)),this.setAttribute("uv",new s.Float32BufferAttribute([0,2,0,0,2,0],2))}}const Pe=new Ee;class M{constructor(e){this._mesh=new s.Mesh(Pe,e)}dispose(){this._mesh.geometry.dispose()}render(e){e.render(this._mesh,Ce)}get material(){return this._mesh.material}set material(e){this._mesh.material=e}}class De extends A{constructor(e,t){super(),this.textureID=t!==void 0?t:"tDiffuse",e instanceof s.ShaderMaterial?(this.uniforms=e.uniforms,this.material=e):e&&(this.uniforms=s.UniformsUtils.clone(e.uniforms),this.material=new s.ShaderMaterial({name:e.name!==void 0?e.name:"unspecified",defines:Object.assign({},e.defines),uniforms:this.uniforms,vertexShader:e.vertexShader,fragmentShader:e.fragmentShader})),this.fsQuad=new M(this.material)}render(e,t,o){this.uniforms[this.textureID]&&(this.uniforms[this.textureID].value=o.texture),this.fsQuad.material=this.material,this.renderToScreen?(e.setRenderTarget(null),this.fsQuad.render(e)):(e.setRenderTarget(t),this.clear&&e.clear(e.autoClearColor,e.autoClearDepth,e.autoClearStencil),this.fsQuad.render(e))}dispose(){this.material.dispose(),this.fsQuad.dispose()}}class j extends A{constructor(e,t){super(),this.scene=e,this.camera=t,this.clear=!0,this.needsSwap=!1,this.inverse=!1}render(e,t,o){const a=e.getContext(),n=e.state;n.buffers.color.setMask(!1),n.buffers.depth.setMask(!1),n.buffers.color.setLocked(!0),n.buffers.depth.setLocked(!0);let l,c;this.inverse?(l=0,c=1):(l=1,c=0),n.buffers.stencil.setTest(!0),n.buffers.stencil.setOp(a.REPLACE,a.REPLACE,a.REPLACE),n.buffers.stencil.setFunc(a.ALWAYS,l,4294967295),n.buffers.stencil.setClear(c),n.buffers.stencil.setLocked(!0),e.setRenderTarget(o),this.clear&&e.clear(),e.render(this.scene,this.camera),e.setRenderTarget(t),this.clear&&e.clear(),e.render(this.scene,this.camera),n.buffers.color.setLocked(!1),n.buffers.depth.setLocked(!1),n.buffers.color.setMask(!0),n.buffers.depth.setMask(!0),n.buffers.stencil.setLocked(!1),n.buffers.stencil.setFunc(a.EQUAL,1,4294967295),n.buffers.stencil.setOp(a.KEEP,a.KEEP,a.KEEP),n.buffers.stencil.setLocked(!0)}}class Le extends A{constructor(){super(),this.needsSwap=!1}render(e){e.state.buffers.stencil.setLocked(!1),e.state.buffers.stencil.setTest(!1)}}class Fe{constructor(e,t){if(this.renderer=e,this._pixelRatio=e.getPixelRatio(),t===void 0){const o=e.getSize(new s.Vector2);this._width=o.width,this._height=o.height,t=new s.WebGLRenderTarget(this._width*this._pixelRatio,this._height*this._pixelRatio,{type:s.HalfFloatType}),t.texture.name="EffectComposer.rt1"}else this._width=t.width,this._height=t.height;this.renderTarget1=t,this.renderTarget2=t.clone(),this.renderTarget2.texture.name="EffectComposer.rt2",this.writeBuffer=this.renderTarget1,this.readBuffer=this.renderTarget2,this.renderToScreen=!0,this.passes=[],this.copyPass=new De(I),this.copyPass.material.blending=s.NoBlending,this.clock=new s.Clock}swapBuffers(){const e=this.readBuffer;this.readBuffer=this.writeBuffer,this.writeBuffer=e}addPass(e){this.passes.push(e),e.setSize(this._width*this._pixelRatio,this._height*this._pixelRatio)}insertPass(e,t){this.passes.splice(t,0,e),e.setSize(this._width*this._pixelRatio,this._height*this._pixelRatio)}removePass(e){const t=this.passes.indexOf(e);t!==-1&&this.passes.splice(t,1)}isLastEnabledPass(e){for(let t=e+1;t<this.passes.length;t++)if(this.passes[t].enabled)return!1;return!0}render(e){e===void 0&&(e=this.clock.getDelta());const t=this.renderer.getRenderTarget();let o=!1;for(let a=0,n=this.passes.length;a<n;a++){const l=this.passes[a];if(l.enabled!==!1){if(l.renderToScreen=this.renderToScreen&&this.isLastEnabledPass(a),l.render(this.renderer,this.writeBuffer,this.readBuffer,e,o),l.needsSwap){if(o){const c=this.renderer.getContext(),f=this.renderer.state.buffers.stencil;f.setFunc(c.NOTEQUAL,1,4294967295),this.copyPass.render(this.renderer,this.writeBuffer,this.readBuffer,e),f.setFunc(c.EQUAL,1,4294967295)}this.swapBuffers()}j!==void 0&&(l instanceof j?o=!0:l instanceof Le&&(o=!1))}}this.renderer.setRenderTarget(t)}reset(e){if(e===void 0){const t=this.renderer.getSize(new s.Vector2);this._pixelRatio=this.renderer.getPixelRatio(),this._width=t.width,this._height=t.height,e=this.renderTarget1.clone(),e.setSize(this._width*this._pixelRatio,this._height*this._pixelRatio)}this.renderTarget1.dispose(),this.renderTarget2.dispose(),this.renderTarget1=e,this.renderTarget2=e.clone(),this.writeBuffer=this.renderTarget1,this.readBuffer=this.renderTarget2}setSize(e,t){this._width=e,this._height=t;const o=this._width*this._pixelRatio,a=this._height*this._pixelRatio;this.renderTarget1.setSize(o,a),this.renderTarget2.setSize(o,a);for(let n=0;n<this.passes.length;n++)this.passes[n].setSize(o,a)}setPixelRatio(e){this._pixelRatio=e,this.setSize(this._width,this._height)}dispose(){this.renderTarget1.dispose(),this.renderTarget2.dispose(),this.copyPass.dispose()}}class Re extends A{constructor(e,t,o=null,a=null,n=null){super(),this.scene=e,this.camera=t,this.overrideMaterial=o,this.clearColor=a,this.clearAlpha=n,this.clear=!0,this.clearDepth=!1,this.needsSwap=!1,this._oldClearColor=new s.Color}render(e,t,o){const a=e.autoClear;e.autoClear=!1;let n,l;this.overrideMaterial!==null&&(l=this.scene.overrideMaterial,this.scene.overrideMaterial=this.overrideMaterial),this.clearColor!==null&&(e.getClearColor(this._oldClearColor),e.setClearColor(this.clearColor,e.getClearAlpha())),this.clearAlpha!==null&&(n=e.getClearAlpha(),e.setClearAlpha(this.clearAlpha)),this.clearDepth==!0&&e.clearDepth(),e.setRenderTarget(this.renderToScreen?null:o),this.clear===!0&&e.clear(e.autoClearColor,e.autoClearDepth,e.autoClearStencil),e.render(this.scene,this.camera),this.clearColor!==null&&e.setClearColor(this._oldClearColor),this.clearAlpha!==null&&e.setClearAlpha(n),this.overrideMaterial!==null&&(this.scene.overrideMaterial=l),e.autoClear=a}}const Y=Symbol("effectComposerThree"),Oe=r.defineComponent({__name:"EffectComposer",props:{enabled:{type:Boolean,default:!0},withoutRenderPass:{type:Boolean}},setup(i,{expose:e}){const t=i,o=r.shallowRef(null);r.provide(Y,o),e({composer:o});const{renderer:a,sizes:n,scene:l,camera:c,render:f}=x.useTresContext(),m=()=>{var h;(h=o.value)==null||h.dispose(),o.value=new Fe(a.value)};r.watchEffect(m),r.watchEffect(()=>{var y;const{width:h,height:S}=n;S.value&&h.value&&((y=o.value)==null||y.setSize(h.value,S.value))});const{pixelRatio:g}=N.useDevicePixelRatio();r.watchEffect(()=>{var h;(h=o.value)==null||h.setPixelRatio(g.value)}),t.withoutRenderPass||r.watchEffect(()=>{c.value&&l.value&&o.value&&o.value.addPass(new Re(l.value,c.value))});const{render:b}=x.useLoop();return b(()=>{f.frames.value>0&&o.value&&t.enabled&&o.value.render(),f.frames.value=f.mode.value==="always"?1:Math.max(0,f.frames.value-1)}),r.onUnmounted(()=>{var h;(h=o.value)==null||h.dispose()}),(h,S)=>r.renderSlot(h.$slots,"default")}}),T=(i,e,t)=>{if(!e&&t)throw new Error("passDependencies is required when dependencyFieldsTriggeringRecreation is provided");const o=r.inject(Y),a=r.shallowRef(i()),{sizes:n,invalidate:l}=x.useTresContext();e&&r.watch(e,()=>l());const c=()=>{var m;(m=o==null?void 0:o.value)==null||m.removePass(a.value),a.value.dispose()},f=r.watchEffect(()=>{!(o!=null&&o.value)||!n.height.value||!n.width.value||(o.value.addPass(a.value),r.nextTick(()=>f()))});return t&&r.watch(()=>t.map(m=>e==null?void 0:e[m]),()=>{if(!(o!=null&&o.value))return;const m=o.value.passes.findIndex(g=>g===a.value);~m&&(c(),a.value=i(),o.value.insertPass(a.value,m))}),r.onUnmounted(()=>{c()}),{pass:a}},Be={uniforms:{tDiffuse:{value:null},tDisp:{value:null},byp:{value:0},amount:{value:.08},angle:{value:.02},seed:{value:.02},seed_x:{value:.02},seed_y:{value:.02},distortion_x:{value:.5},distortion_y:{value:.6},col_s:{value:.05}},vertexShader:`
249
+ }`};class M{constructor(){this.isPass=!0,this.enabled=!0,this.needsSwap=!0,this.clear=!1,this.renderToScreen=!1}setSize(){}render(){console.error("THREE.Pass: .render() must be implemented in derived pass.")}dispose(){}}const Oe=new i.OrthographicCamera(-1,1,1,-1,0,1);class Re extends i.BufferGeometry{constructor(){super(),this.setAttribute("position",new i.Float32BufferAttribute([-1,3,0,-1,-1,0,3,-1,0],3)),this.setAttribute("uv",new i.Float32BufferAttribute([0,2,0,0,2,0],2))}}const Be=new Re;class C{constructor(t){this._mesh=new i.Mesh(Be,t)}dispose(){this._mesh.geometry.dispose()}render(t){t.render(this._mesh,Oe)}get material(){return this._mesh.material}set material(t){this._mesh.material=t}}class Ne extends M{constructor(t,e){super(),this.textureID=e!==void 0?e:"tDiffuse",t instanceof i.ShaderMaterial?(this.uniforms=t.uniforms,this.material=t):t&&(this.uniforms=i.UniformsUtils.clone(t.uniforms),this.material=new i.ShaderMaterial({name:t.name!==void 0?t.name:"unspecified",defines:Object.assign({},t.defines),uniforms:this.uniforms,vertexShader:t.vertexShader,fragmentShader:t.fragmentShader})),this.fsQuad=new C(this.material)}render(t,e,a){this.uniforms[this.textureID]&&(this.uniforms[this.textureID].value=a.texture),this.fsQuad.material=this.material,this.renderToScreen?(t.setRenderTarget(null),this.fsQuad.render(t)):(t.setRenderTarget(e),this.clear&&t.clear(t.autoClearColor,t.autoClearDepth,t.autoClearStencil),this.fsQuad.render(t))}dispose(){this.material.dispose(),this.fsQuad.dispose()}}class q extends M{constructor(t,e){super(),this.scene=t,this.camera=e,this.clear=!0,this.needsSwap=!1,this.inverse=!1}render(t,e,a){const o=t.getContext(),n=t.state;n.buffers.color.setMask(!1),n.buffers.depth.setMask(!1),n.buffers.color.setLocked(!0),n.buffers.depth.setLocked(!0);let s,c;this.inverse?(s=0,c=1):(s=1,c=0),n.buffers.stencil.setTest(!0),n.buffers.stencil.setOp(o.REPLACE,o.REPLACE,o.REPLACE),n.buffers.stencil.setFunc(o.ALWAYS,s,4294967295),n.buffers.stencil.setClear(c),n.buffers.stencil.setLocked(!0),t.setRenderTarget(a),this.clear&&t.clear(),t.render(this.scene,this.camera),t.setRenderTarget(e),this.clear&&t.clear(),t.render(this.scene,this.camera),n.buffers.color.setLocked(!1),n.buffers.depth.setLocked(!1),n.buffers.color.setMask(!0),n.buffers.depth.setMask(!0),n.buffers.stencil.setLocked(!1),n.buffers.stencil.setFunc(o.EQUAL,1,4294967295),n.buffers.stencil.setOp(o.KEEP,o.KEEP,o.KEEP),n.buffers.stencil.setLocked(!0)}}class ze extends M{constructor(){super(),this.needsSwap=!1}render(t){t.state.buffers.stencil.setLocked(!1),t.state.buffers.stencil.setTest(!1)}}class Ue{constructor(t,e){if(this.renderer=t,this._pixelRatio=t.getPixelRatio(),e===void 0){const a=t.getSize(new i.Vector2);this._width=a.width,this._height=a.height,e=new i.WebGLRenderTarget(this._width*this._pixelRatio,this._height*this._pixelRatio,{type:i.HalfFloatType}),e.texture.name="EffectComposer.rt1"}else this._width=e.width,this._height=e.height;this.renderTarget1=e,this.renderTarget2=e.clone(),this.renderTarget2.texture.name="EffectComposer.rt2",this.writeBuffer=this.renderTarget1,this.readBuffer=this.renderTarget2,this.renderToScreen=!0,this.passes=[],this.copyPass=new Ne(k),this.copyPass.material.blending=i.NoBlending,this.clock=new i.Clock}swapBuffers(){const t=this.readBuffer;this.readBuffer=this.writeBuffer,this.writeBuffer=t}addPass(t){this.passes.push(t),t.setSize(this._width*this._pixelRatio,this._height*this._pixelRatio)}insertPass(t,e){this.passes.splice(e,0,t),t.setSize(this._width*this._pixelRatio,this._height*this._pixelRatio)}removePass(t){const e=this.passes.indexOf(t);e!==-1&&this.passes.splice(e,1)}isLastEnabledPass(t){for(let e=t+1;e<this.passes.length;e++)if(this.passes[e].enabled)return!1;return!0}render(t){t===void 0&&(t=this.clock.getDelta());const e=this.renderer.getRenderTarget();let a=!1;for(let o=0,n=this.passes.length;o<n;o++){const s=this.passes[o];if(s.enabled!==!1){if(s.renderToScreen=this.renderToScreen&&this.isLastEnabledPass(o),s.render(this.renderer,this.writeBuffer,this.readBuffer,t,a),s.needsSwap){if(a){const c=this.renderer.getContext(),f=this.renderer.state.buffers.stencil;f.setFunc(c.NOTEQUAL,1,4294967295),this.copyPass.render(this.renderer,this.writeBuffer,this.readBuffer,t),f.setFunc(c.EQUAL,1,4294967295)}this.swapBuffers()}q!==void 0&&(s instanceof q?a=!0:s instanceof ze&&(a=!1))}}this.renderer.setRenderTarget(e)}reset(t){if(t===void 0){const e=this.renderer.getSize(new i.Vector2);this._pixelRatio=this.renderer.getPixelRatio(),this._width=e.width,this._height=e.height,t=this.renderTarget1.clone(),t.setSize(this._width*this._pixelRatio,this._height*this._pixelRatio)}this.renderTarget1.dispose(),this.renderTarget2.dispose(),this.renderTarget1=t,this.renderTarget2=t.clone(),this.writeBuffer=this.renderTarget1,this.readBuffer=this.renderTarget2}setSize(t,e){this._width=t,this._height=e;const a=this._width*this._pixelRatio,o=this._height*this._pixelRatio;this.renderTarget1.setSize(a,o),this.renderTarget2.setSize(a,o);for(let n=0;n<this.passes.length;n++)this.passes[n].setSize(a,o)}setPixelRatio(t){this._pixelRatio=t,this.setSize(this._width,this._height)}dispose(){this.renderTarget1.dispose(),this.renderTarget2.dispose(),this.copyPass.dispose()}}class We extends M{constructor(t,e,a=null,o=null,n=null){super(),this.scene=t,this.camera=e,this.overrideMaterial=a,this.clearColor=o,this.clearAlpha=n,this.clear=!0,this.clearDepth=!1,this.needsSwap=!1,this._oldClearColor=new i.Color}render(t,e,a){const o=t.autoClear;t.autoClear=!1;let n,s;this.overrideMaterial!==null&&(s=this.scene.overrideMaterial,this.scene.overrideMaterial=this.overrideMaterial),this.clearColor!==null&&(t.getClearColor(this._oldClearColor),t.setClearColor(this.clearColor,t.getClearAlpha())),this.clearAlpha!==null&&(n=t.getClearAlpha(),t.setClearAlpha(this.clearAlpha)),this.clearDepth==!0&&t.clearDepth(),t.setRenderTarget(this.renderToScreen?null:a),this.clear===!0&&t.clear(t.autoClearColor,t.autoClearDepth,t.autoClearStencil),t.render(this.scene,this.camera),this.clearColor!==null&&t.setClearColor(this._oldClearColor),this.clearAlpha!==null&&t.setClearAlpha(n),this.overrideMaterial!==null&&(this.scene.overrideMaterial=s),t.autoClear=o}}const Q=Symbol("effectComposerThree"),Ge=r.defineComponent({__name:"EffectComposer",props:{enabled:{type:Boolean,default:!0},withoutRenderPass:{type:Boolean}},setup(l,{expose:t}){const e=l,a=r.shallowRef(null);r.provide(Q,a),t({composer:a});const{renderer:o,sizes:n,scene:s,camera:c,render:f}=b.useTresContext(),m=()=>{var h;(h=a.value)==null||h.dispose(),a.value=new Ue(o.value)};r.watchEffect(m),r.watchEffect(()=>{var v;const{width:h,height:A}=n;A.value&&h.value&&((v=a.value)==null||v.setSize(h.value,A.value))});const{pixelRatio:g}=W.useDevicePixelRatio();r.watchEffect(()=>{var h;(h=a.value)==null||h.setPixelRatio(g.value)}),e.withoutRenderPass||r.watchEffect(()=>{c.value&&s.value&&a.value&&a.value.addPass(new We(s.value,c.value))});const{render:S}=b.useLoop();return S(()=>{f.frames.value>0&&a.value&&e.enabled&&a.value.render(),f.frames.value=f.mode.value==="always"?1:Math.max(0,f.frames.value-1)}),r.onUnmounted(()=>{var h;(h=a.value)==null||h.dispose()}),(h,A)=>r.renderSlot(h.$slots,"default")}}),E=(l,t,e)=>{if(!t&&e)throw new Error("passDependencies is required when dependencyFieldsTriggeringRecreation is provided");const a=r.inject(Q),o=r.shallowRef(l()),{sizes:n,invalidate:s}=b.useTresContext();t&&r.watch(t,()=>s());const c=()=>{var m;(m=a==null?void 0:a.value)==null||m.removePass(o.value),o.value.dispose()},f=r.watchEffect(()=>{!(a!=null&&a.value)||!n.height.value||!n.width.value||(a.value.addPass(o.value),r.nextTick(()=>f()))});return e&&r.watch(()=>e.map(m=>t==null?void 0:t[m]),()=>{if(!(a!=null&&a.value))return;const m=a.value.passes.findIndex(g=>g===o.value);~m&&(c(),o.value=l(),a.value.insertPass(o.value,m))}),r.onUnmounted(()=>{c()}),{pass:o}},He={uniforms:{tDiffuse:{value:null},tDisp:{value:null},byp:{value:0},amount:{value:.08},angle:{value:.02},seed:{value:.02},seed_x:{value:.02},seed_y:{value:.02},distortion_x:{value:.5},distortion_y:{value:.6},col_s:{value:.05}},vertexShader:`
250
250
 
251
251
  varying vec2 vUv;
252
252
  void main() {
@@ -313,7 +313,7 @@ void mainImage(const in vec4 inputColor, const in vec2 uv, out vec4 outputColor)
313
313
  else {
314
314
  gl_FragColor=texture2D (tDiffuse, vUv);
315
315
  }
316
- }`};class k extends A{constructor(e=64){super();const t=Be;this.uniforms=s.UniformsUtils.clone(t.uniforms),this.heightMap=this.generateHeightmap(e),this.uniforms.tDisp.value=this.heightMap,this.material=new s.ShaderMaterial({uniforms:this.uniforms,vertexShader:t.vertexShader,fragmentShader:t.fragmentShader}),this.fsQuad=new M(this.material),this.goWild=!1,this.curF=0,this.generateTrigger()}render(e,t,o){this.uniforms.tDiffuse.value=o.texture,this.uniforms.seed.value=Math.random(),this.uniforms.byp.value=0,this.curF%this.randX==0||this.goWild==!0?(this.uniforms.amount.value=Math.random()/30,this.uniforms.angle.value=s.MathUtils.randFloat(-Math.PI,Math.PI),this.uniforms.seed_x.value=s.MathUtils.randFloat(-1,1),this.uniforms.seed_y.value=s.MathUtils.randFloat(-1,1),this.uniforms.distortion_x.value=s.MathUtils.randFloat(0,1),this.uniforms.distortion_y.value=s.MathUtils.randFloat(0,1),this.curF=0,this.generateTrigger()):this.curF%this.randX<this.randX/5?(this.uniforms.amount.value=Math.random()/90,this.uniforms.angle.value=s.MathUtils.randFloat(-Math.PI,Math.PI),this.uniforms.distortion_x.value=s.MathUtils.randFloat(0,1),this.uniforms.distortion_y.value=s.MathUtils.randFloat(0,1),this.uniforms.seed_x.value=s.MathUtils.randFloat(-.3,.3),this.uniforms.seed_y.value=s.MathUtils.randFloat(-.3,.3)):this.goWild==!1&&(this.uniforms.byp.value=1),this.curF++,this.renderToScreen?(e.setRenderTarget(null),this.fsQuad.render(e)):(e.setRenderTarget(t),this.clear&&e.clear(),this.fsQuad.render(e))}generateTrigger(){this.randX=s.MathUtils.randInt(120,240)}generateHeightmap(e){const t=new Float32Array(e*e),o=e*e;for(let n=0;n<o;n++){const l=s.MathUtils.randFloat(0,1);t[n]=l}const a=new s.DataTexture(t,e,e,s.RedFormat,s.FloatType);return a.needsUpdate=!0,a}dispose(){this.material.dispose(),this.heightMap.dispose(),this.fsQuad.dispose()}}const Ne=r.defineComponent({__name:"Glitch",props:{dtSize:{},goWild:{type:Boolean}},setup(i,{expose:e}){const t=i,{pass:o}=T(()=>new k(t.dtSize),t,["dtSize"]);e({pass:o});const{onBeforeRender:a}=x.useLoop();return a(({invalidate:n})=>n()),v([[()=>t.goWild,"goWild"]],o,()=>new k),()=>{}}}),D={name:"HalftoneShader",uniforms:{tDiffuse:{value:null},shape:{value:1},radius:{value:4},rotateR:{value:Math.PI/12*1},rotateG:{value:Math.PI/12*2},rotateB:{value:Math.PI/12*3},scatter:{value:0},width:{value:1},height:{value:1},blending:{value:1},blendingMode:{value:1},greyscale:{value:!1},disable:{value:!1}},vertexShader:`
316
+ }`};class K extends M{constructor(t=64){super();const e=He;this.uniforms=i.UniformsUtils.clone(e.uniforms),this.heightMap=this.generateHeightmap(t),this.uniforms.tDisp.value=this.heightMap,this.material=new i.ShaderMaterial({uniforms:this.uniforms,vertexShader:e.vertexShader,fragmentShader:e.fragmentShader}),this.fsQuad=new C(this.material),this.goWild=!1,this.curF=0,this.generateTrigger()}render(t,e,a){this.uniforms.tDiffuse.value=a.texture,this.uniforms.seed.value=Math.random(),this.uniforms.byp.value=0,this.curF%this.randX==0||this.goWild==!0?(this.uniforms.amount.value=Math.random()/30,this.uniforms.angle.value=i.MathUtils.randFloat(-Math.PI,Math.PI),this.uniforms.seed_x.value=i.MathUtils.randFloat(-1,1),this.uniforms.seed_y.value=i.MathUtils.randFloat(-1,1),this.uniforms.distortion_x.value=i.MathUtils.randFloat(0,1),this.uniforms.distortion_y.value=i.MathUtils.randFloat(0,1),this.curF=0,this.generateTrigger()):this.curF%this.randX<this.randX/5?(this.uniforms.amount.value=Math.random()/90,this.uniforms.angle.value=i.MathUtils.randFloat(-Math.PI,Math.PI),this.uniforms.distortion_x.value=i.MathUtils.randFloat(0,1),this.uniforms.distortion_y.value=i.MathUtils.randFloat(0,1),this.uniforms.seed_x.value=i.MathUtils.randFloat(-.3,.3),this.uniforms.seed_y.value=i.MathUtils.randFloat(-.3,.3)):this.goWild==!1&&(this.uniforms.byp.value=1),this.curF++,this.renderToScreen?(t.setRenderTarget(null),this.fsQuad.render(t)):(t.setRenderTarget(e),this.clear&&t.clear(),this.fsQuad.render(t))}generateTrigger(){this.randX=i.MathUtils.randInt(120,240)}generateHeightmap(t){const e=new Float32Array(t*t),a=t*t;for(let n=0;n<a;n++){const s=i.MathUtils.randFloat(0,1);e[n]=s}const o=new i.DataTexture(e,t,t,i.RedFormat,i.FloatType);return o.needsUpdate=!0,o}dispose(){this.material.dispose(),this.heightMap.dispose(),this.fsQuad.dispose()}}const Ve=r.defineComponent({__name:"Glitch",props:{dtSize:{},goWild:{type:Boolean}},setup(l,{expose:t}){const e=l,{pass:a}=E(()=>new K(e.dtSize),e,["dtSize"]);t({pass:a});const{onBeforeRender:o}=b.useLoop();return o(({invalidate:n})=>n()),x([[()=>e.goWild,"goWild"]],a,()=>new K),()=>{}}}),O={name:"HalftoneShader",uniforms:{tDiffuse:{value:null},shape:{value:1},radius:{value:4},rotateR:{value:Math.PI/12*1},rotateG:{value:Math.PI/12*2},rotateB:{value:Math.PI/12*3},scatter:{value:0},width:{value:1},height:{value:1},blending:{value:1},blendingMode:{value:1},greyscale:{value:!1},disable:{value:!1}},vertexShader:`
317
317
 
318
318
  varying vec2 vUV;
319
319
 
@@ -591,7 +591,7 @@ void mainImage(const in vec4 inputColor, const in vec2 uv, out vec4 outputColor)
591
591
 
592
592
  }
593
593
 
594
- }`};class ze extends A{constructor(e,t,o){super(),this.uniforms=s.UniformsUtils.clone(D.uniforms),this.material=new s.ShaderMaterial({uniforms:this.uniforms,fragmentShader:D.fragmentShader,vertexShader:D.vertexShader}),this.uniforms.width.value=e,this.uniforms.height.value=t;for(const a in o)o.hasOwnProperty(a)&&this.uniforms.hasOwnProperty(a)&&(this.uniforms[a].value=o[a]);this.fsQuad=new M(this.material)}render(e,t,o){this.material.uniforms.tDiffuse.value=o.texture,this.renderToScreen?(e.setRenderTarget(null),this.fsQuad.render(e)):(e.setRenderTarget(t),this.clear&&e.clear(),this.fsQuad.render(e))}setSize(e,t){this.uniforms.width.value=e,this.uniforms.height.value=t}dispose(){this.material.dispose(),this.fsQuad.dispose()}}const Ue=r.defineComponent({__name:"Halftone",props:{shape:{},radius:{},rotateR:{},rotateG:{},rotateB:{},scatter:{},blending:{},greyscale:{type:Boolean},blendingMode:{}},setup(i,{expose:e}){const t=i,{sizes:o}=x.useTresContext(),a=r.computed(()=>Object.fromEntries(Object.entries(t).filter(([l,c])=>c!==void 0))),{pass:n}=T(()=>new ze(o.width.value,o.height.value,a.value),t);return e({pass:n}),r.watchEffect(()=>{n.value.setSize(o.width.value,o.height.value)}),r.watchEffect(()=>{Object.entries(t).forEach(([l,c])=>{l in n.value.uniforms&&(n.value.uniforms[l].value=c??D.uniforms[l].value)})}),()=>{}}});class q extends A{constructor(e,t,o,a={}){super(),this.pixelSize=e,this.resolution=new s.Vector2,this.renderResolution=new s.Vector2,this.pixelatedMaterial=this.createPixelatedMaterial(),this.normalMaterial=new s.MeshNormalMaterial,this.fsQuad=new M(this.pixelatedMaterial),this.scene=t,this.camera=o,this.normalEdgeStrength=a.normalEdgeStrength||.3,this.depthEdgeStrength=a.depthEdgeStrength||.4,this.beautyRenderTarget=new s.WebGLRenderTarget,this.beautyRenderTarget.texture.minFilter=s.NearestFilter,this.beautyRenderTarget.texture.magFilter=s.NearestFilter,this.beautyRenderTarget.texture.type=s.HalfFloatType,this.beautyRenderTarget.depthTexture=new s.DepthTexture,this.normalRenderTarget=new s.WebGLRenderTarget,this.normalRenderTarget.texture.minFilter=s.NearestFilter,this.normalRenderTarget.texture.magFilter=s.NearestFilter,this.normalRenderTarget.texture.type=s.HalfFloatType}dispose(){this.beautyRenderTarget.dispose(),this.normalRenderTarget.dispose(),this.pixelatedMaterial.dispose(),this.normalMaterial.dispose(),this.fsQuad.dispose()}setSize(e,t){this.resolution.set(e,t),this.renderResolution.set(e/this.pixelSize|0,t/this.pixelSize|0);const{x:o,y:a}=this.renderResolution;this.beautyRenderTarget.setSize(o,a),this.normalRenderTarget.setSize(o,a),this.fsQuad.material.uniforms.resolution.value.set(o,a,1/o,1/a)}setPixelSize(e){this.pixelSize=e,this.setSize(this.resolution.x,this.resolution.y)}render(e,t){const o=this.fsQuad.material.uniforms;o.normalEdgeStrength.value=this.normalEdgeStrength,o.depthEdgeStrength.value=this.depthEdgeStrength,e.setRenderTarget(this.beautyRenderTarget),e.render(this.scene,this.camera);const a=this.scene.overrideMaterial;e.setRenderTarget(this.normalRenderTarget),this.scene.overrideMaterial=this.normalMaterial,e.render(this.scene,this.camera),this.scene.overrideMaterial=a,o.tDiffuse.value=this.beautyRenderTarget.texture,o.tDepth.value=this.beautyRenderTarget.depthTexture,o.tNormal.value=this.normalRenderTarget.texture,this.renderToScreen?e.setRenderTarget(null):(e.setRenderTarget(t),this.clear&&e.clear()),this.fsQuad.render(e)}createPixelatedMaterial(){return new s.ShaderMaterial({uniforms:{tDiffuse:{value:null},tDepth:{value:null},tNormal:{value:null},resolution:{value:new s.Vector4(this.renderResolution.x,this.renderResolution.y,1/this.renderResolution.x,1/this.renderResolution.y)},normalEdgeStrength:{value:0},depthEdgeStrength:{value:0}},vertexShader:`
594
+ }`};class Ie extends M{constructor(t,e,a){super(),this.uniforms=i.UniformsUtils.clone(O.uniforms),this.material=new i.ShaderMaterial({uniforms:this.uniforms,fragmentShader:O.fragmentShader,vertexShader:O.vertexShader}),this.uniforms.width.value=t,this.uniforms.height.value=e;for(const o in a)a.hasOwnProperty(o)&&this.uniforms.hasOwnProperty(o)&&(this.uniforms[o].value=a[o]);this.fsQuad=new C(this.material)}render(t,e,a){this.material.uniforms.tDiffuse.value=a.texture,this.renderToScreen?(t.setRenderTarget(null),this.fsQuad.render(t)):(t.setRenderTarget(e),this.clear&&t.clear(),this.fsQuad.render(t))}setSize(t,e){this.uniforms.width.value=t,this.uniforms.height.value=e}dispose(){this.material.dispose(),this.fsQuad.dispose()}}const Xe=r.defineComponent({__name:"Halftone",props:{shape:{},radius:{},rotateR:{},rotateG:{},rotateB:{},scatter:{},blending:{},greyscale:{type:Boolean},blendingMode:{}},setup(l,{expose:t}){const e=l,{sizes:a}=b.useTresContext(),o=r.computed(()=>Object.fromEntries(Object.entries(e).filter(([s,c])=>c!==void 0))),{pass:n}=E(()=>new Ie(a.width.value,a.height.value,o.value),e);return t({pass:n}),r.watchEffect(()=>{n.value.setSize(a.width.value,a.height.value)}),r.watchEffect(()=>{Object.entries(e).forEach(([s,c])=>{s in n.value.uniforms&&(n.value.uniforms[s].value=c??O.uniforms[s].value)})}),()=>{}}});class J extends M{constructor(t,e,a,o={}){super(),this.pixelSize=t,this.resolution=new i.Vector2,this.renderResolution=new i.Vector2,this.pixelatedMaterial=this.createPixelatedMaterial(),this.normalMaterial=new i.MeshNormalMaterial,this.fsQuad=new C(this.pixelatedMaterial),this.scene=e,this.camera=a,this.normalEdgeStrength=o.normalEdgeStrength||.3,this.depthEdgeStrength=o.depthEdgeStrength||.4,this.beautyRenderTarget=new i.WebGLRenderTarget,this.beautyRenderTarget.texture.minFilter=i.NearestFilter,this.beautyRenderTarget.texture.magFilter=i.NearestFilter,this.beautyRenderTarget.texture.type=i.HalfFloatType,this.beautyRenderTarget.depthTexture=new i.DepthTexture,this.normalRenderTarget=new i.WebGLRenderTarget,this.normalRenderTarget.texture.minFilter=i.NearestFilter,this.normalRenderTarget.texture.magFilter=i.NearestFilter,this.normalRenderTarget.texture.type=i.HalfFloatType}dispose(){this.beautyRenderTarget.dispose(),this.normalRenderTarget.dispose(),this.pixelatedMaterial.dispose(),this.normalMaterial.dispose(),this.fsQuad.dispose()}setSize(t,e){this.resolution.set(t,e),this.renderResolution.set(t/this.pixelSize|0,e/this.pixelSize|0);const{x:a,y:o}=this.renderResolution;this.beautyRenderTarget.setSize(a,o),this.normalRenderTarget.setSize(a,o),this.fsQuad.material.uniforms.resolution.value.set(a,o,1/a,1/o)}setPixelSize(t){this.pixelSize=t,this.setSize(this.resolution.x,this.resolution.y)}render(t,e){const a=this.fsQuad.material.uniforms;a.normalEdgeStrength.value=this.normalEdgeStrength,a.depthEdgeStrength.value=this.depthEdgeStrength,t.setRenderTarget(this.beautyRenderTarget),t.render(this.scene,this.camera);const o=this.scene.overrideMaterial;t.setRenderTarget(this.normalRenderTarget),this.scene.overrideMaterial=this.normalMaterial,t.render(this.scene,this.camera),this.scene.overrideMaterial=o,a.tDiffuse.value=this.beautyRenderTarget.texture,a.tDepth.value=this.beautyRenderTarget.depthTexture,a.tNormal.value=this.normalRenderTarget.texture,this.renderToScreen?t.setRenderTarget(null):(t.setRenderTarget(e),this.clear&&t.clear()),this.fsQuad.render(t)}createPixelatedMaterial(){return new i.ShaderMaterial({uniforms:{tDiffuse:{value:null},tDepth:{value:null},tNormal:{value:null},resolution:{value:new i.Vector4(this.renderResolution.x,this.renderResolution.y,1/this.renderResolution.x,1/this.renderResolution.y)},normalEdgeStrength:{value:0},depthEdgeStrength:{value:0}},vertexShader:`
595
595
  varying vec2 vUv;
596
596
 
597
597
  void main() {
@@ -689,7 +689,7 @@ void mainImage(const in vec4 inputColor, const in vec2 uv, out vec4 outputColor)
689
689
  gl_FragColor = texel * Strength;
690
690
 
691
691
  }
692
- `})}}const We=r.defineComponent({__name:"Pixelation",props:{pixelSize:{},depthEdgeStrength:{},normalEdgeStrength:{}},setup(i,{expose:e}){const t=i,{scene:o,camera:a}=x.useTresContext(),{pass:n}=T(()=>new q(t.pixelSize,o.value,a.value),t);return e({pass:n}),r.watchEffect(()=>{n.value.setPixelSize(t.pixelSize)}),v([[()=>t.depthEdgeStrength,"depthEdgeStrength"],[()=>t.normalEdgeStrength,"normalEdgeStrength"]],n,()=>new q(1,o.value,a.value)),()=>{}}}),Ge={name:"OutputShader",uniforms:{tDiffuse:{value:null},toneMappingExposure:{value:1}},vertexShader:`
692
+ `})}}const je=r.defineComponent({__name:"Pixelation",props:{pixelSize:{},depthEdgeStrength:{},normalEdgeStrength:{}},setup(l,{expose:t}){const e=l,{scene:a,camera:o}=b.useTresContext(),{pass:n}=E(()=>new J(e.pixelSize,a.value,o.value),e);return t({pass:n}),r.watchEffect(()=>{n.value.setPixelSize(e.pixelSize)}),x([[()=>e.depthEdgeStrength,"depthEdgeStrength"],[()=>e.normalEdgeStrength,"normalEdgeStrength"]],n,()=>new J(1,a.value,o.value)),()=>{}}}),Ye={name:"OutputShader",uniforms:{tDiffuse:{value:null},toneMappingExposure:{value:1}},vertexShader:`
693
693
  precision highp float;
694
694
 
695
695
  uniform mat4 modelViewMatrix;
@@ -760,7 +760,7 @@ void mainImage(const in vec4 inputColor, const in vec2 uv, out vec4 outputColor)
760
760
 
761
761
  #endif
762
762
 
763
- }`};class He extends A{constructor(){super();const e=Ge;this.uniforms=s.UniformsUtils.clone(e.uniforms),this.material=new s.RawShaderMaterial({name:e.name,uniforms:this.uniforms,vertexShader:e.vertexShader,fragmentShader:e.fragmentShader}),this.fsQuad=new M(this.material),this._outputColorSpace=null,this._toneMapping=null}render(e,t,o){this.uniforms.tDiffuse.value=o.texture,this.uniforms.toneMappingExposure.value=e.toneMappingExposure,(this._outputColorSpace!==e.outputColorSpace||this._toneMapping!==e.toneMapping)&&(this._outputColorSpace=e.outputColorSpace,this._toneMapping=e.toneMapping,this.material.defines={},s.ColorManagement.getTransfer(this._outputColorSpace)===s.SRGBTransfer&&(this.material.defines.SRGB_TRANSFER=""),this._toneMapping===s.LinearToneMapping?this.material.defines.LINEAR_TONE_MAPPING="":this._toneMapping===s.ReinhardToneMapping?this.material.defines.REINHARD_TONE_MAPPING="":this._toneMapping===s.CineonToneMapping?this.material.defines.CINEON_TONE_MAPPING="":this._toneMapping===s.ACESFilmicToneMapping?this.material.defines.ACES_FILMIC_TONE_MAPPING="":this._toneMapping===s.AgXToneMapping?this.material.defines.AGX_TONE_MAPPING="":this._toneMapping===s.NeutralToneMapping?this.material.defines.NEUTRAL_TONE_MAPPING="":this._toneMapping===s.CustomToneMapping&&(this.material.defines.CUSTOM_TONE_MAPPING=""),this.material.needsUpdate=!0),this.renderToScreen===!0?(e.setRenderTarget(null),this.fsQuad.render(e)):(e.setRenderTarget(t),this.clear&&e.clear(e.autoClearColor,e.autoClearDepth,e.autoClearStencil),this.fsQuad.render(e))}dispose(){this.material.dispose(),this.fsQuad.dispose()}}const Ve=r.defineComponent({__name:"Output",setup(i,{expose:e}){const{pass:t}=T(()=>new He);return e({pass:t}),()=>{}}}),L={name:"SMAAEdgesShader",defines:{SMAA_THRESHOLD:"0.1"},uniforms:{tDiffuse:{value:null},resolution:{value:new s.Vector2(1/1024,1/512)}},vertexShader:`
763
+ }`};class ke extends M{constructor(){super();const t=Ye;this.uniforms=i.UniformsUtils.clone(t.uniforms),this.material=new i.RawShaderMaterial({name:t.name,uniforms:this.uniforms,vertexShader:t.vertexShader,fragmentShader:t.fragmentShader}),this.fsQuad=new C(this.material),this._outputColorSpace=null,this._toneMapping=null}render(t,e,a){this.uniforms.tDiffuse.value=a.texture,this.uniforms.toneMappingExposure.value=t.toneMappingExposure,(this._outputColorSpace!==t.outputColorSpace||this._toneMapping!==t.toneMapping)&&(this._outputColorSpace=t.outputColorSpace,this._toneMapping=t.toneMapping,this.material.defines={},i.ColorManagement.getTransfer(this._outputColorSpace)===i.SRGBTransfer&&(this.material.defines.SRGB_TRANSFER=""),this._toneMapping===i.LinearToneMapping?this.material.defines.LINEAR_TONE_MAPPING="":this._toneMapping===i.ReinhardToneMapping?this.material.defines.REINHARD_TONE_MAPPING="":this._toneMapping===i.CineonToneMapping?this.material.defines.CINEON_TONE_MAPPING="":this._toneMapping===i.ACESFilmicToneMapping?this.material.defines.ACES_FILMIC_TONE_MAPPING="":this._toneMapping===i.AgXToneMapping?this.material.defines.AGX_TONE_MAPPING="":this._toneMapping===i.NeutralToneMapping?this.material.defines.NEUTRAL_TONE_MAPPING="":this._toneMapping===i.CustomToneMapping&&(this.material.defines.CUSTOM_TONE_MAPPING=""),this.material.needsUpdate=!0),this.renderToScreen===!0?(t.setRenderTarget(null),this.fsQuad.render(t)):(t.setRenderTarget(e),this.clear&&t.clear(t.autoClearColor,t.autoClearDepth,t.autoClearStencil),this.fsQuad.render(t))}dispose(){this.material.dispose(),this.fsQuad.dispose()}}const qe=r.defineComponent({__name:"Output",setup(l,{expose:t}){const{pass:e}=E(()=>new ke);return t({pass:e}),()=>{}}}),R={name:"SMAAEdgesShader",defines:{SMAA_THRESHOLD:"0.1"},uniforms:{tDiffuse:{value:null},resolution:{value:new i.Vector2(1/1024,1/512)}},vertexShader:`
764
764
 
765
765
  uniform vec2 resolution;
766
766
 
@@ -844,7 +844,7 @@ void mainImage(const in vec4 inputColor, const in vec2 uv, out vec4 outputColor)
844
844
 
845
845
  gl_FragColor = SMAAColorEdgeDetectionPS( vUv, vOffset, tDiffuse );
846
846
 
847
- }`},F={name:"SMAAWeightsShader",defines:{SMAA_MAX_SEARCH_STEPS:"8",SMAA_AREATEX_MAX_DISTANCE:"16",SMAA_AREATEX_PIXEL_SIZE:"( 1.0 / vec2( 160.0, 560.0 ) )",SMAA_AREATEX_SUBTEX_SIZE:"( 1.0 / 7.0 )"},uniforms:{tDiffuse:{value:null},tArea:{value:null},tSearch:{value:null},resolution:{value:new s.Vector2(1/1024,1/512)}},vertexShader:`
847
+ }`},B={name:"SMAAWeightsShader",defines:{SMAA_MAX_SEARCH_STEPS:"8",SMAA_AREATEX_MAX_DISTANCE:"16",SMAA_AREATEX_PIXEL_SIZE:"( 1.0 / vec2( 160.0, 560.0 ) )",SMAA_AREATEX_SUBTEX_SIZE:"( 1.0 / 7.0 )"},uniforms:{tDiffuse:{value:null},tArea:{value:null},tSearch:{value:null},resolution:{value:new i.Vector2(1/1024,1/512)}},vertexShader:`
848
848
 
849
849
  uniform vec2 resolution;
850
850
 
@@ -1072,7 +1072,7 @@ void mainImage(const in vec4 inputColor, const in vec2 uv, out vec4 outputColor)
1072
1072
 
1073
1073
  gl_FragColor = SMAABlendingWeightCalculationPS( vUv, vPixcoord, vOffset, tDiffuse, tArea, tSearch, ivec4( 0.0 ) );
1074
1074
 
1075
- }`},B={name:"SMAABlendShader",uniforms:{tDiffuse:{value:null},tColor:{value:null},resolution:{value:new s.Vector2(1/1024,1/512)}},vertexShader:`
1075
+ }`},U={name:"SMAABlendShader",uniforms:{tDiffuse:{value:null},tColor:{value:null},resolution:{value:new i.Vector2(1/1024,1/512)}},vertexShader:`
1076
1076
 
1077
1077
  uniform vec2 resolution;
1078
1078
 
@@ -1146,7 +1146,7 @@ void mainImage(const in vec4 inputColor, const in vec2 uv, out vec4 outputColor)
1146
1146
 
1147
1147
  gl_FragColor = SMAANeighborhoodBlendingPS( vUv, vOffset, tColor, tDiffuse );
1148
1148
 
1149
- }`};class Xe extends A{constructor(e,t){super(),this.edgesRT=new s.WebGLRenderTarget(e,t,{depthBuffer:!1,type:s.HalfFloatType}),this.edgesRT.texture.name="SMAAPass.edges",this.weightsRT=new s.WebGLRenderTarget(e,t,{depthBuffer:!1,type:s.HalfFloatType}),this.weightsRT.texture.name="SMAAPass.weights";const o=this,a=new Image;a.src=this.getAreaTexture(),a.onload=function(){o.areaTexture.needsUpdate=!0},this.areaTexture=new s.Texture,this.areaTexture.name="SMAAPass.area",this.areaTexture.image=a,this.areaTexture.minFilter=s.LinearFilter,this.areaTexture.generateMipmaps=!1,this.areaTexture.flipY=!1;const n=new Image;n.src=this.getSearchTexture(),n.onload=function(){o.searchTexture.needsUpdate=!0},this.searchTexture=new s.Texture,this.searchTexture.name="SMAAPass.search",this.searchTexture.image=n,this.searchTexture.magFilter=s.NearestFilter,this.searchTexture.minFilter=s.NearestFilter,this.searchTexture.generateMipmaps=!1,this.searchTexture.flipY=!1,this.uniformsEdges=s.UniformsUtils.clone(L.uniforms),this.uniformsEdges.resolution.value.set(1/e,1/t),this.materialEdges=new s.ShaderMaterial({defines:Object.assign({},L.defines),uniforms:this.uniformsEdges,vertexShader:L.vertexShader,fragmentShader:L.fragmentShader}),this.uniformsWeights=s.UniformsUtils.clone(F.uniforms),this.uniformsWeights.resolution.value.set(1/e,1/t),this.uniformsWeights.tDiffuse.value=this.edgesRT.texture,this.uniformsWeights.tArea.value=this.areaTexture,this.uniformsWeights.tSearch.value=this.searchTexture,this.materialWeights=new s.ShaderMaterial({defines:Object.assign({},F.defines),uniforms:this.uniformsWeights,vertexShader:F.vertexShader,fragmentShader:F.fragmentShader}),this.uniformsBlend=s.UniformsUtils.clone(B.uniforms),this.uniformsBlend.resolution.value.set(1/e,1/t),this.uniformsBlend.tDiffuse.value=this.weightsRT.texture,this.materialBlend=new s.ShaderMaterial({uniforms:this.uniformsBlend,vertexShader:B.vertexShader,fragmentShader:B.fragmentShader}),this.fsQuad=new M(null)}render(e,t,o){this.uniformsEdges.tDiffuse.value=o.texture,this.fsQuad.material=this.materialEdges,e.setRenderTarget(this.edgesRT),this.clear&&e.clear(),this.fsQuad.render(e),this.fsQuad.material=this.materialWeights,e.setRenderTarget(this.weightsRT),this.clear&&e.clear(),this.fsQuad.render(e),this.uniformsBlend.tColor.value=o.texture,this.fsQuad.material=this.materialBlend,this.renderToScreen?(e.setRenderTarget(null),this.fsQuad.render(e)):(e.setRenderTarget(t),this.clear&&e.clear(),this.fsQuad.render(e))}setSize(e,t){this.edgesRT.setSize(e,t),this.weightsRT.setSize(e,t),this.materialEdges.uniforms.resolution.value.set(1/e,1/t),this.materialWeights.uniforms.resolution.value.set(1/e,1/t),this.materialBlend.uniforms.resolution.value.set(1/e,1/t)}getAreaTexture(){return""}getSearchTexture(){return""}dispose(){this.edgesRT.dispose(),this.weightsRT.dispose(),this.areaTexture.dispose(),this.searchTexture.dispose(),this.materialEdges.dispose(),this.materialWeights.dispose(),this.materialBlend.dispose(),this.fsQuad.dispose()}}const Ie=r.defineComponent({__name:"SMAA",props:{width:{},height:{}},setup(i,{expose:e}){const t=i,{sizes:o}=x.useTresContext(),{pixelRatio:a}=N.useDevicePixelRatio(),n=r.computed(()=>t.width??o.width.value*a.value),l=r.computed(()=>t.height??o.height.value*a.value),{pass:c}=T(()=>new Xe(n.value,l.value),t);return e({pass:c}),r.watchEffect(()=>{c.value.setSize(n.value,l.value)}),()=>{}}}),Q={name:"LuminosityHighPassShader",shaderID:"luminosityHighPass",uniforms:{tDiffuse:{value:null},luminosityThreshold:{value:1},smoothWidth:{value:1},defaultColor:{value:new s.Color(0)},defaultOpacity:{value:0}},vertexShader:`
1149
+ }`};class Qe extends M{constructor(t,e){super(),this.edgesRT=new i.WebGLRenderTarget(t,e,{depthBuffer:!1,type:i.HalfFloatType}),this.edgesRT.texture.name="SMAAPass.edges",this.weightsRT=new i.WebGLRenderTarget(t,e,{depthBuffer:!1,type:i.HalfFloatType}),this.weightsRT.texture.name="SMAAPass.weights";const a=this,o=new Image;o.src=this.getAreaTexture(),o.onload=function(){a.areaTexture.needsUpdate=!0},this.areaTexture=new i.Texture,this.areaTexture.name="SMAAPass.area",this.areaTexture.image=o,this.areaTexture.minFilter=i.LinearFilter,this.areaTexture.generateMipmaps=!1,this.areaTexture.flipY=!1;const n=new Image;n.src=this.getSearchTexture(),n.onload=function(){a.searchTexture.needsUpdate=!0},this.searchTexture=new i.Texture,this.searchTexture.name="SMAAPass.search",this.searchTexture.image=n,this.searchTexture.magFilter=i.NearestFilter,this.searchTexture.minFilter=i.NearestFilter,this.searchTexture.generateMipmaps=!1,this.searchTexture.flipY=!1,this.uniformsEdges=i.UniformsUtils.clone(R.uniforms),this.uniformsEdges.resolution.value.set(1/t,1/e),this.materialEdges=new i.ShaderMaterial({defines:Object.assign({},R.defines),uniforms:this.uniformsEdges,vertexShader:R.vertexShader,fragmentShader:R.fragmentShader}),this.uniformsWeights=i.UniformsUtils.clone(B.uniforms),this.uniformsWeights.resolution.value.set(1/t,1/e),this.uniformsWeights.tDiffuse.value=this.edgesRT.texture,this.uniformsWeights.tArea.value=this.areaTexture,this.uniformsWeights.tSearch.value=this.searchTexture,this.materialWeights=new i.ShaderMaterial({defines:Object.assign({},B.defines),uniforms:this.uniformsWeights,vertexShader:B.vertexShader,fragmentShader:B.fragmentShader}),this.uniformsBlend=i.UniformsUtils.clone(U.uniforms),this.uniformsBlend.resolution.value.set(1/t,1/e),this.uniformsBlend.tDiffuse.value=this.weightsRT.texture,this.materialBlend=new i.ShaderMaterial({uniforms:this.uniformsBlend,vertexShader:U.vertexShader,fragmentShader:U.fragmentShader}),this.fsQuad=new C(null)}render(t,e,a){this.uniformsEdges.tDiffuse.value=a.texture,this.fsQuad.material=this.materialEdges,t.setRenderTarget(this.edgesRT),this.clear&&t.clear(),this.fsQuad.render(t),this.fsQuad.material=this.materialWeights,t.setRenderTarget(this.weightsRT),this.clear&&t.clear(),this.fsQuad.render(t),this.uniformsBlend.tColor.value=a.texture,this.fsQuad.material=this.materialBlend,this.renderToScreen?(t.setRenderTarget(null),this.fsQuad.render(t)):(t.setRenderTarget(e),this.clear&&t.clear(),this.fsQuad.render(t))}setSize(t,e){this.edgesRT.setSize(t,e),this.weightsRT.setSize(t,e),this.materialEdges.uniforms.resolution.value.set(1/t,1/e),this.materialWeights.uniforms.resolution.value.set(1/t,1/e),this.materialBlend.uniforms.resolution.value.set(1/t,1/e)}getAreaTexture(){return""}getSearchTexture(){return""}dispose(){this.edgesRT.dispose(),this.weightsRT.dispose(),this.areaTexture.dispose(),this.searchTexture.dispose(),this.materialEdges.dispose(),this.materialWeights.dispose(),this.materialBlend.dispose(),this.fsQuad.dispose()}}const Ke=r.defineComponent({__name:"SMAA",props:{width:{},height:{}},setup(l,{expose:t}){const e=l,{sizes:a}=b.useTresContext(),{pixelRatio:o}=W.useDevicePixelRatio(),n=r.computed(()=>e.width??a.width.value*o.value),s=r.computed(()=>e.height??a.height.value*o.value),{pass:c}=E(()=>new Qe(n.value,s.value),e);return t({pass:c}),r.watchEffect(()=>{c.value.setSize(n.value,s.value)}),()=>{}}}),Z={name:"LuminosityHighPassShader",shaderID:"luminosityHighPass",uniforms:{tDiffuse:{value:null},luminosityThreshold:{value:1},smoothWidth:{value:1},defaultColor:{value:new i.Color(0)},defaultOpacity:{value:0}},vertexShader:`
1150
1150
 
1151
1151
  varying vec2 vUv;
1152
1152
 
@@ -1178,7 +1178,7 @@ void mainImage(const in vec4 inputColor, const in vec2 uv, out vec4 outputColor)
1178
1178
 
1179
1179
  gl_FragColor = mix( outputColor, texel, alpha );
1180
1180
 
1181
- }`};class C extends A{constructor(e,t,o,a){super(),this.strength=t!==void 0?t:1,this.radius=o,this.threshold=a,this.resolution=e!==void 0?new s.Vector2(e.x,e.y):new s.Vector2(256,256),this.clearColor=new s.Color(0,0,0),this.renderTargetsHorizontal=[],this.renderTargetsVertical=[],this.nMips=5;let n=Math.round(this.resolution.x/2),l=Math.round(this.resolution.y/2);this.renderTargetBright=new s.WebGLRenderTarget(n,l,{type:s.HalfFloatType}),this.renderTargetBright.texture.name="UnrealBloomPass.bright",this.renderTargetBright.texture.generateMipmaps=!1;for(let b=0;b<this.nMips;b++){const h=new s.WebGLRenderTarget(n,l,{type:s.HalfFloatType});h.texture.name="UnrealBloomPass.h"+b,h.texture.generateMipmaps=!1,this.renderTargetsHorizontal.push(h);const S=new s.WebGLRenderTarget(n,l,{type:s.HalfFloatType});S.texture.name="UnrealBloomPass.v"+b,S.texture.generateMipmaps=!1,this.renderTargetsVertical.push(S),n=Math.round(n/2),l=Math.round(l/2)}const c=Q;this.highPassUniforms=s.UniformsUtils.clone(c.uniforms),this.highPassUniforms.luminosityThreshold.value=a,this.highPassUniforms.smoothWidth.value=.01,this.materialHighPassFilter=new s.ShaderMaterial({uniforms:this.highPassUniforms,vertexShader:c.vertexShader,fragmentShader:c.fragmentShader}),this.separableBlurMaterials=[];const f=[3,5,7,9,11];n=Math.round(this.resolution.x/2),l=Math.round(this.resolution.y/2);for(let b=0;b<this.nMips;b++)this.separableBlurMaterials.push(this.getSeparableBlurMaterial(f[b])),this.separableBlurMaterials[b].uniforms.invSize.value=new s.Vector2(1/n,1/l),n=Math.round(n/2),l=Math.round(l/2);this.compositeMaterial=this.getCompositeMaterial(this.nMips),this.compositeMaterial.uniforms.blurTexture1.value=this.renderTargetsVertical[0].texture,this.compositeMaterial.uniforms.blurTexture2.value=this.renderTargetsVertical[1].texture,this.compositeMaterial.uniforms.blurTexture3.value=this.renderTargetsVertical[2].texture,this.compositeMaterial.uniforms.blurTexture4.value=this.renderTargetsVertical[3].texture,this.compositeMaterial.uniforms.blurTexture5.value=this.renderTargetsVertical[4].texture,this.compositeMaterial.uniforms.bloomStrength.value=t,this.compositeMaterial.uniforms.bloomRadius.value=.1;const m=[1,.8,.6,.4,.2];this.compositeMaterial.uniforms.bloomFactors.value=m,this.bloomTintColors=[new s.Vector3(1,1,1),new s.Vector3(1,1,1),new s.Vector3(1,1,1),new s.Vector3(1,1,1),new s.Vector3(1,1,1)],this.compositeMaterial.uniforms.bloomTintColors.value=this.bloomTintColors;const g=I;this.copyUniforms=s.UniformsUtils.clone(g.uniforms),this.blendMaterial=new s.ShaderMaterial({uniforms:this.copyUniforms,vertexShader:g.vertexShader,fragmentShader:g.fragmentShader,blending:s.AdditiveBlending,depthTest:!1,depthWrite:!1,transparent:!0}),this.enabled=!0,this.needsSwap=!1,this._oldClearColor=new s.Color,this.oldClearAlpha=1,this.basic=new s.MeshBasicMaterial,this.fsQuad=new M(null)}dispose(){for(let e=0;e<this.renderTargetsHorizontal.length;e++)this.renderTargetsHorizontal[e].dispose();for(let e=0;e<this.renderTargetsVertical.length;e++)this.renderTargetsVertical[e].dispose();this.renderTargetBright.dispose();for(let e=0;e<this.separableBlurMaterials.length;e++)this.separableBlurMaterials[e].dispose();this.compositeMaterial.dispose(),this.blendMaterial.dispose(),this.basic.dispose(),this.fsQuad.dispose()}setSize(e,t){let o=Math.round(e/2),a=Math.round(t/2);this.renderTargetBright.setSize(o,a);for(let n=0;n<this.nMips;n++)this.renderTargetsHorizontal[n].setSize(o,a),this.renderTargetsVertical[n].setSize(o,a),this.separableBlurMaterials[n].uniforms.invSize.value=new s.Vector2(1/o,1/a),o=Math.round(o/2),a=Math.round(a/2)}render(e,t,o,a,n){e.getClearColor(this._oldClearColor),this.oldClearAlpha=e.getClearAlpha();const l=e.autoClear;e.autoClear=!1,e.setClearColor(this.clearColor,0),n&&e.state.buffers.stencil.setTest(!1),this.renderToScreen&&(this.fsQuad.material=this.basic,this.basic.map=o.texture,e.setRenderTarget(null),e.clear(),this.fsQuad.render(e)),this.highPassUniforms.tDiffuse.value=o.texture,this.highPassUniforms.luminosityThreshold.value=this.threshold,this.fsQuad.material=this.materialHighPassFilter,e.setRenderTarget(this.renderTargetBright),e.clear(),this.fsQuad.render(e);let c=this.renderTargetBright;for(let f=0;f<this.nMips;f++)this.fsQuad.material=this.separableBlurMaterials[f],this.separableBlurMaterials[f].uniforms.colorTexture.value=c.texture,this.separableBlurMaterials[f].uniforms.direction.value=C.BlurDirectionX,e.setRenderTarget(this.renderTargetsHorizontal[f]),e.clear(),this.fsQuad.render(e),this.separableBlurMaterials[f].uniforms.colorTexture.value=this.renderTargetsHorizontal[f].texture,this.separableBlurMaterials[f].uniforms.direction.value=C.BlurDirectionY,e.setRenderTarget(this.renderTargetsVertical[f]),e.clear(),this.fsQuad.render(e),c=this.renderTargetsVertical[f];this.fsQuad.material=this.compositeMaterial,this.compositeMaterial.uniforms.bloomStrength.value=this.strength,this.compositeMaterial.uniforms.bloomRadius.value=this.radius,this.compositeMaterial.uniforms.bloomTintColors.value=this.bloomTintColors,e.setRenderTarget(this.renderTargetsHorizontal[0]),e.clear(),this.fsQuad.render(e),this.fsQuad.material=this.blendMaterial,this.copyUniforms.tDiffuse.value=this.renderTargetsHorizontal[0].texture,n&&e.state.buffers.stencil.setTest(!0),this.renderToScreen?(e.setRenderTarget(null),this.fsQuad.render(e)):(e.setRenderTarget(o),this.fsQuad.render(e)),e.setClearColor(this._oldClearColor,this.oldClearAlpha),e.autoClear=l}getSeparableBlurMaterial(e){const t=[];for(let o=0;o<e;o++)t.push(.39894*Math.exp(-.5*o*o/(e*e))/e);return new s.ShaderMaterial({defines:{KERNEL_RADIUS:e},uniforms:{colorTexture:{value:null},invSize:{value:new s.Vector2(.5,.5)},direction:{value:new s.Vector2(.5,.5)},gaussianCoefficients:{value:t}},vertexShader:`varying vec2 vUv;
1181
+ }`};class P extends M{constructor(t,e,a,o){super(),this.strength=e!==void 0?e:1,this.radius=a,this.threshold=o,this.resolution=t!==void 0?new i.Vector2(t.x,t.y):new i.Vector2(256,256),this.clearColor=new i.Color(0,0,0),this.renderTargetsHorizontal=[],this.renderTargetsVertical=[],this.nMips=5;let n=Math.round(this.resolution.x/2),s=Math.round(this.resolution.y/2);this.renderTargetBright=new i.WebGLRenderTarget(n,s,{type:i.HalfFloatType}),this.renderTargetBright.texture.name="UnrealBloomPass.bright",this.renderTargetBright.texture.generateMipmaps=!1;for(let S=0;S<this.nMips;S++){const h=new i.WebGLRenderTarget(n,s,{type:i.HalfFloatType});h.texture.name="UnrealBloomPass.h"+S,h.texture.generateMipmaps=!1,this.renderTargetsHorizontal.push(h);const A=new i.WebGLRenderTarget(n,s,{type:i.HalfFloatType});A.texture.name="UnrealBloomPass.v"+S,A.texture.generateMipmaps=!1,this.renderTargetsVertical.push(A),n=Math.round(n/2),s=Math.round(s/2)}const c=Z;this.highPassUniforms=i.UniformsUtils.clone(c.uniforms),this.highPassUniforms.luminosityThreshold.value=o,this.highPassUniforms.smoothWidth.value=.01,this.materialHighPassFilter=new i.ShaderMaterial({uniforms:this.highPassUniforms,vertexShader:c.vertexShader,fragmentShader:c.fragmentShader}),this.separableBlurMaterials=[];const f=[3,5,7,9,11];n=Math.round(this.resolution.x/2),s=Math.round(this.resolution.y/2);for(let S=0;S<this.nMips;S++)this.separableBlurMaterials.push(this.getSeparableBlurMaterial(f[S])),this.separableBlurMaterials[S].uniforms.invSize.value=new i.Vector2(1/n,1/s),n=Math.round(n/2),s=Math.round(s/2);this.compositeMaterial=this.getCompositeMaterial(this.nMips),this.compositeMaterial.uniforms.blurTexture1.value=this.renderTargetsVertical[0].texture,this.compositeMaterial.uniforms.blurTexture2.value=this.renderTargetsVertical[1].texture,this.compositeMaterial.uniforms.blurTexture3.value=this.renderTargetsVertical[2].texture,this.compositeMaterial.uniforms.blurTexture4.value=this.renderTargetsVertical[3].texture,this.compositeMaterial.uniforms.blurTexture5.value=this.renderTargetsVertical[4].texture,this.compositeMaterial.uniforms.bloomStrength.value=e,this.compositeMaterial.uniforms.bloomRadius.value=.1;const m=[1,.8,.6,.4,.2];this.compositeMaterial.uniforms.bloomFactors.value=m,this.bloomTintColors=[new i.Vector3(1,1,1),new i.Vector3(1,1,1),new i.Vector3(1,1,1),new i.Vector3(1,1,1),new i.Vector3(1,1,1)],this.compositeMaterial.uniforms.bloomTintColors.value=this.bloomTintColors;const g=k;this.copyUniforms=i.UniformsUtils.clone(g.uniforms),this.blendMaterial=new i.ShaderMaterial({uniforms:this.copyUniforms,vertexShader:g.vertexShader,fragmentShader:g.fragmentShader,blending:i.AdditiveBlending,depthTest:!1,depthWrite:!1,transparent:!0}),this.enabled=!0,this.needsSwap=!1,this._oldClearColor=new i.Color,this.oldClearAlpha=1,this.basic=new i.MeshBasicMaterial,this.fsQuad=new C(null)}dispose(){for(let t=0;t<this.renderTargetsHorizontal.length;t++)this.renderTargetsHorizontal[t].dispose();for(let t=0;t<this.renderTargetsVertical.length;t++)this.renderTargetsVertical[t].dispose();this.renderTargetBright.dispose();for(let t=0;t<this.separableBlurMaterials.length;t++)this.separableBlurMaterials[t].dispose();this.compositeMaterial.dispose(),this.blendMaterial.dispose(),this.basic.dispose(),this.fsQuad.dispose()}setSize(t,e){let a=Math.round(t/2),o=Math.round(e/2);this.renderTargetBright.setSize(a,o);for(let n=0;n<this.nMips;n++)this.renderTargetsHorizontal[n].setSize(a,o),this.renderTargetsVertical[n].setSize(a,o),this.separableBlurMaterials[n].uniforms.invSize.value=new i.Vector2(1/a,1/o),a=Math.round(a/2),o=Math.round(o/2)}render(t,e,a,o,n){t.getClearColor(this._oldClearColor),this.oldClearAlpha=t.getClearAlpha();const s=t.autoClear;t.autoClear=!1,t.setClearColor(this.clearColor,0),n&&t.state.buffers.stencil.setTest(!1),this.renderToScreen&&(this.fsQuad.material=this.basic,this.basic.map=a.texture,t.setRenderTarget(null),t.clear(),this.fsQuad.render(t)),this.highPassUniforms.tDiffuse.value=a.texture,this.highPassUniforms.luminosityThreshold.value=this.threshold,this.fsQuad.material=this.materialHighPassFilter,t.setRenderTarget(this.renderTargetBright),t.clear(),this.fsQuad.render(t);let c=this.renderTargetBright;for(let f=0;f<this.nMips;f++)this.fsQuad.material=this.separableBlurMaterials[f],this.separableBlurMaterials[f].uniforms.colorTexture.value=c.texture,this.separableBlurMaterials[f].uniforms.direction.value=P.BlurDirectionX,t.setRenderTarget(this.renderTargetsHorizontal[f]),t.clear(),this.fsQuad.render(t),this.separableBlurMaterials[f].uniforms.colorTexture.value=this.renderTargetsHorizontal[f].texture,this.separableBlurMaterials[f].uniforms.direction.value=P.BlurDirectionY,t.setRenderTarget(this.renderTargetsVertical[f]),t.clear(),this.fsQuad.render(t),c=this.renderTargetsVertical[f];this.fsQuad.material=this.compositeMaterial,this.compositeMaterial.uniforms.bloomStrength.value=this.strength,this.compositeMaterial.uniforms.bloomRadius.value=this.radius,this.compositeMaterial.uniforms.bloomTintColors.value=this.bloomTintColors,t.setRenderTarget(this.renderTargetsHorizontal[0]),t.clear(),this.fsQuad.render(t),this.fsQuad.material=this.blendMaterial,this.copyUniforms.tDiffuse.value=this.renderTargetsHorizontal[0].texture,n&&t.state.buffers.stencil.setTest(!0),this.renderToScreen?(t.setRenderTarget(null),this.fsQuad.render(t)):(t.setRenderTarget(a),this.fsQuad.render(t)),t.setClearColor(this._oldClearColor,this.oldClearAlpha),t.autoClear=s}getSeparableBlurMaterial(t){const e=[];for(let a=0;a<t;a++)e.push(.39894*Math.exp(-.5*a*a/(t*t))/t);return new i.ShaderMaterial({defines:{KERNEL_RADIUS:t},uniforms:{colorTexture:{value:null},invSize:{value:new i.Vector2(.5,.5)},direction:{value:new i.Vector2(.5,.5)},gaussianCoefficients:{value:e}},vertexShader:`varying vec2 vUv;
1182
1182
  void main() {
1183
1183
  vUv = uv;
1184
1184
  gl_Position = projectionMatrix * modelViewMatrix * vec4( position, 1.0 );
@@ -1202,7 +1202,7 @@ void mainImage(const in vec4 inputColor, const in vec2 uv, out vec4 outputColor)
1202
1202
  weightSum += 2.0 * w;
1203
1203
  }
1204
1204
  gl_FragColor = vec4(diffuseSum/weightSum, 1.0);
1205
- }`})}getCompositeMaterial(e){return new s.ShaderMaterial({defines:{NUM_MIPS:e},uniforms:{blurTexture1:{value:null},blurTexture2:{value:null},blurTexture3:{value:null},blurTexture4:{value:null},blurTexture5:{value:null},bloomStrength:{value:1},bloomFactors:{value:null},bloomTintColors:{value:null},bloomRadius:{value:0}},vertexShader:`varying vec2 vUv;
1205
+ }`})}getCompositeMaterial(t){return new i.ShaderMaterial({defines:{NUM_MIPS:t},uniforms:{blurTexture1:{value:null},blurTexture2:{value:null},blurTexture3:{value:null},blurTexture4:{value:null},blurTexture5:{value:null},bloomStrength:{value:1},bloomFactors:{value:null},bloomTintColors:{value:null},bloomRadius:{value:0}},vertexShader:`varying vec2 vUv;
1206
1206
  void main() {
1207
1207
  vUv = uv;
1208
1208
  gl_Position = projectionMatrix * modelViewMatrix * vec4( position, 1.0 );
@@ -1228,4 +1228,4 @@ void mainImage(const in vec4 inputColor, const in vec2 uv, out vec4 outputColor)
1228
1228
  lerpBloomFactor(bloomFactors[2]) * vec4(bloomTintColors[2], 1.0) * texture2D(blurTexture3, vUv) +
1229
1229
  lerpBloomFactor(bloomFactors[3]) * vec4(bloomTintColors[3], 1.0) * texture2D(blurTexture4, vUv) +
1230
1230
  lerpBloomFactor(bloomFactors[4]) * vec4(bloomTintColors[4], 1.0) * texture2D(blurTexture5, vUv) );
1231
- }`})}}C.BlurDirectionX=new s.Vector2(1,0),C.BlurDirectionY=new s.Vector2(0,1);const je=r.defineComponent({__name:"UnrealBloom",props:{radius:{default:0},strength:{default:1},threshold:{default:0}},setup(i,{expose:e}){const t=i,{sizes:o}=x.useTresContext(),{pass:a}=T(()=>new C(new s.Vector2(o.width.value,o.height.value),t.radius,t.strength,t.threshold),t);return e({pass:a}),r.watchEffect(()=>{var n;a.value.radius=t.radius??((n=a.value.getCompositeMaterial().uniforms.bloomRadius)==null?void 0:n.value)??.1}),r.watchEffect(()=>{var n;a.value.strength=t.strength??((n=a.value.getCompositeMaterial().uniforms.bloomStrength)==null?void 0:n.value)??1}),r.watchEffect(()=>{var n;a.value.threshold=t.threshold??((n=Q.uniforms.luminosityThreshold)==null?void 0:n.value)??1}),()=>{}}});d.BarrelBlurPmndrs=ie,d.BloomPmndrs=$,d.BrightnessContrastPmndrs=Te,d.ChromaticAberrationPmndrs=le,d.ColorAveragePmndrs=he,d.ColorDepthPmndrs=Ae,d.DepthOfFieldPmndrs=ee,d.DepthPickingPassPmndrs=we,d.DotScreenPmndrs=ve,d.EffectComposer=Oe,d.EffectComposerPmndrs=J,d.FishEyePmndrs=Me,d.Glitch=Ne,d.GlitchPmndrs=te,d.GodRaysPmndrs=Se,d.GridPmndrs=ye,d.Halftone=Ue,d.HueSaturationPmndrs=ce,d.KuwaharaPmndrs=fe,d.LensDistortionPmndrs=me,d.LinocutPmndrs=be,d.NoisePmndrs=oe,d.OutlinePmndrs=ae,d.Output=Ve,d.Pixelation=We,d.PixelationPmndrs=ne,d.SMAA=Ie,d.ScanlinePmndrs=ue,d.SepiaPmndrs=xe,d.ShockWavePmndrs=pe,d.TiltShiftPmndrs=ge,d.ToneMappingPmndrs=re,d.UnrealBloom=je,d.VignettePmndrs=se,d.useEffect=T,d.useEffectPmndrs=p,Object.defineProperty(d,Symbol.toStringTag,{value:"Module"})});
1231
+ }`})}}P.BlurDirectionX=new i.Vector2(1,0),P.BlurDirectionY=new i.Vector2(0,1);const Je=r.defineComponent({__name:"UnrealBloom",props:{radius:{default:0},strength:{default:1},threshold:{default:0}},setup(l,{expose:t}){const e=l,{sizes:a}=b.useTresContext(),{pass:o}=E(()=>new P(new i.Vector2(a.width.value,a.height.value),e.radius,e.strength,e.threshold),e);return t({pass:o}),r.watchEffect(()=>{var n;o.value.radius=e.radius??((n=o.value.getCompositeMaterial().uniforms.bloomRadius)==null?void 0:n.value)??.1}),r.watchEffect(()=>{var n;o.value.strength=e.strength??((n=o.value.getCompositeMaterial().uniforms.bloomStrength)==null?void 0:n.value)??1}),r.watchEffect(()=>{var n;o.value.threshold=e.threshold??((n=Z.uniforms.luminosityThreshold)==null?void 0:n.value)??1}),()=>{}}});d.ASCIIPmndrs=Fe,d.BarrelBlurPmndrs=le,d.BloomPmndrs=te,d.BrightnessContrastPmndrs=Ee,d.ChromaticAberrationPmndrs=ue,d.ColorAveragePmndrs=pe,d.ColorDepthPmndrs=Me,d.DepthOfFieldPmndrs=ae,d.DepthPickingPassPmndrs=Ae,d.DotScreenPmndrs=be,d.EffectComposer=Ge,d.EffectComposerPmndrs=_,d.FXAAPmndrs=De,d.FishEyePmndrs=Ce,d.Glitch=Ve,d.GlitchPmndrs=oe,d.GodRaysPmndrs=ye,d.GridPmndrs=Te,d.Halftone=Xe,d.HueSaturationPmndrs=de,d.KuwaharaPmndrs=me,d.LensDistortionPmndrs=ge,d.LinocutPmndrs=Se,d.NoisePmndrs=ne,d.OutlinePmndrs=ie,d.Output=qe,d.Pixelation=je,d.PixelationPmndrs=se,d.SMAA=Ke,d.SMAAPmndrs=Pe,d.ScanlinePmndrs=fe,d.SepiaPmndrs=we,d.ShockWavePmndrs=ve,d.TexturePmndrs=Le,d.TiltShiftPmndrs=xe,d.ToneMappingPmndrs=ce,d.UnrealBloom=Je,d.VignettePmndrs=re,d.useEffect=E,d.useEffectPmndrs=p,Object.defineProperty(d,Symbol.toStringTag,{value:"Module"})});