@tresjs/post-processing 2.0.0 → 2.2.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.
- package/dist/core/pmndrs/BarrelBlurPmndrs.vue.d.ts +26 -0
- package/dist/core/pmndrs/BrightnessContrastPmndrs.vue.d.ts +20 -0
- package/dist/core/pmndrs/ChromaticAberrationPmndrs.vue.d.ts +27 -0
- package/dist/core/pmndrs/ColorAveragePmndrs.vue.d.ts +16 -0
- package/dist/core/pmndrs/ColorDepthPmndrs.vue.d.ts +20 -0
- package/dist/core/pmndrs/DepthPickingPassPmndrs.vue.d.ts +18 -0
- package/dist/core/pmndrs/DotScreenPmndrs.vue.d.ts +22 -0
- package/dist/core/pmndrs/FishEyePmndrs.vue.d.ts +30 -0
- package/dist/core/pmndrs/GodRaysPmndrs.vue.d.ts +65 -0
- package/dist/core/pmndrs/GridPmndrs.vue.d.ts +20 -0
- package/dist/core/pmndrs/HueSaturationPmndrs.vue.d.ts +22 -0
- package/dist/core/pmndrs/KuwaharaPmndrs.vue.d.ts +27 -0
- package/dist/core/pmndrs/LensDistortionPmndrs.vue.d.ts +25 -0
- package/dist/core/pmndrs/LinocutPmndrs.vue.d.ts +15 -0
- package/dist/core/pmndrs/NoisePmndrs.vue.d.ts +0 -1
- package/dist/core/pmndrs/ScanlinePmndrs.vue.d.ts +24 -0
- package/dist/core/pmndrs/SepiaPmndrs.vue.d.ts +16 -0
- package/dist/core/pmndrs/ShockWavePmndrs.vue.d.ts +29 -0
- package/dist/core/pmndrs/TiltShiftPmndrs.vue.d.ts +49 -0
- package/dist/core/pmndrs/ToneMappingPmndrs.vue.d.ts +36 -0
- package/dist/core/pmndrs/VignettePmndrs.vue.d.ts +4 -9
- package/dist/core/pmndrs/custom/barrel-blur/index.d.ts +36 -0
- package/dist/core/pmndrs/custom/fish-eye/index.d.ts +44 -0
- package/dist/core/pmndrs/custom/kuwahara/index.d.ts +31 -0
- package/dist/core/pmndrs/custom/linocut/index.d.ts +27 -0
- package/dist/core/pmndrs/index.d.ts +20 -1
- package/dist/tres-post-processing.js +1514 -541
- package/dist/tres-post-processing.umd.cjs +236 -14
- package/package.json +20 -19
|
@@ -1,11 +1,229 @@
|
|
|
1
1
|
/**
|
|
2
2
|
* name: @tresjs/post-processing
|
|
3
|
-
* version: v2.
|
|
3
|
+
* version: v2.2.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(
|
|
8
|
+
(function(u,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):(u=typeof globalThis<"u"?globalThis:u||self,r(u["tres-post-processing"]={},u.Vue,u.Postprocessing,u.TresjsCore,u.Three,u.VueUseCore))})(this,function(u,r,c,g,n,U){"use strict";const z=/([^[.\]])+/g,Z=(i,t)=>{if(!t)return;const e=Array.isArray(t)?t:t.match(z);return e==null?void 0:e.reduce((o,a)=>o&&o[a],i)},W=(i,t,e)=>{const o=Array.isArray(t)?t:t.match(z);o&&o.reduce((a,s,l)=>(a[s]===void 0&&(a[s]={}),l===o.length-1&&(a[s]=e),a[s]),i)},O=(i,t)=>{const e={...i};return t.forEach(o=>delete e[o]),e},D=(i,t,e,o,a={})=>r.watch(i,s=>{var l;if(t.value)if(s===void 0){const d=o();W(t.value,e,Z(d,e)),(l=d.dispose)==null||l.call(d)}else W(t.value,e,i())},a),v=(i,t,e)=>i.map(([o,a])=>D(o,t,a,e)),C=(i,t,e)=>Object.keys(i).map(o=>D(()=>i[o],t,o,e));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"),o=window.WebGL2RenderingContext&&e.getContext("webgl2");return o.drawingBufferColorSpace=t,o.drawingBufferColorSpace===t}catch{return!1}}static getWebGL2ErrorMessage(){return this.getErrorMessage(2)}static getErrorMessage(t){const e={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 s=document.createElement("div");return s.id="webglmessage",s.style.fontFamily="monospace",s.style.fontSize="13px",s.style.fontWeight="normal",s.style.textAlign="center",s.style.background="#fff",s.style.color="#000",s.style.padding="1.5em",s.style.width="400px",s.style.margin="5em auto 0",o[t]?a=a.replace("$0","graphics card"):a=a.replace("$0","browser"),a=a.replace("$1",e[t]),s.innerHTML=a,s}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 B=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:n.HalfFloatType}},emits:["render"],setup(i,{expose:t,emit:e}){const o=i,a=e,{scene:s,camera:l,renderer:d,sizes:f,render:w}=g.useTresContext(),h=r.shallowRef(null);let x=null,p=null;r.provide(B,h),t({composer:h});const A=()=>{h.value&&(p=new c.NormalPass(s.value,l.value),p.enabled=!1,h.value.addPass(p),o.resolutionScale!==void 0&&G.isWebGL2Available()&&(x=new c.DepthDownsamplingPass({normalBuffer:p.texture,resolutionScale:o.resolutionScale}),x.enabled=!1,h.value.addPass(x)))},F=r.computed(()=>{const b=new c.EffectComposer,E={depthBuffer:o.depthBuffer!==void 0?o.depthBuffer:b.inputBuffer.depthBuffer,stencilBuffer:o.stencilBuffer!==void 0?o.stencilBuffer:b.inputBuffer.stencilBuffer,multisampling:G.isWebGL2Available()?o.multisampling!==void 0?o.multisampling:b.multisampling:0,frameBufferType:o.frameBufferType!==void 0?o.frameBufferType:n.HalfFloatType};return b.dispose(),E}),J=()=>{var b;!d.value&&!s.value&&!l.value||((b=h.value)==null||b.dispose(),h.value=new c.EffectComposer(d.value,F.value),h.value.addPass(new c.RenderPass(s.value,l.value)),o.disableNormalPass||A())};r.watch([d,s,l,()=>o.disableNormalPass],()=>{!f.width.value||!f.height.value||J()}),r.watch(()=>[f.width.value,f.height.value],([b,E])=>{!b&&!E||(h.value?h.value.setSize(b,E):J())},{immediate:!0});const{render:Ye}=g.useLoop();return Ye(()=>{if(o.enabled&&d.value&&h.value&&f.width.value&&f.height.value&&w.frames.value>0){const b=d.value.autoClear;d.value.autoClear=o.autoClear,o.stencilBuffer&&!o.autoClear&&d.value.clearStencil(),h.value.render(),a("render",h.value),d.value.autoClear=b}w.frames.value=w.mode.value==="always"?1:Math.max(0,w.frames.value-1)}),r.onUnmounted(()=>{var b;(b=h.value)==null||b.dispose()}),(b,E)=>r.renderSlot(b.$slots,"default")}}),m=(i,t)=>{const e=r.inject(B),o=r.shallowRef(null),a=r.shallowRef(null),{scene:s,camera:l,invalidate:d}=g.useTresContext();t&&r.watch(t,()=>d()),r.watchEffect(()=>{!l.value||!(a!=null&&a.value)||(a.value.mainCamera=l.value)});const f=r.watchEffect(()=>{!l.value||!(e!=null&&e.value)||!s.value||(r.nextTick(()=>f()),!a.value&&(a.value=i(),o.value=new c.EffectPass(l.value,a.value),e.value.addPass(o.value)))});return r.onUnmounted(()=>{var w,h,x;o.value&&((w=e==null?void 0:e.value)==null||w.removePass(o.value)),(h=a.value)==null||h.dispose(),(x=o.value)==null||x.dispose()}),{pass:o,effect:a}},$=r.defineComponent({__name:"BloomPmndrs",props:{blendFunction:{},intensity:{},kernelSize:{},luminanceThreshold:{},luminanceSmoothing:{},mipmapBlur:{type:Boolean,default:void 0}},setup(i,{expose:t}){const e=i,{pass:o,effect:a}=m(()=>new c.BloomEffect(e),e);return t({pass:o,effect:a}),v([[()=>e.intensity,"intensity"],[()=>e.kernelSize,"kernelSize"],[()=>e.luminanceSmoothing,"luminanceMaterial.smoothing"],[()=>e.luminanceThreshold,"luminanceMaterial.threshold"]],a,()=>new c.BloomEffect),()=>{}}}),ee=r.defineComponent({__name:"DepthOfFieldPmndrs",props:{blendFunction:{},worldFocusDistance:{},worldFocusRange:{},focusDistance:{},focusRange:{},bokehScale:{},resolutionScale:{},resolutionX:{},resolutionY:{}},setup(i,{expose:t}){const e=i,{camera:o}=g.useTresContext(),{pass:a,effect:s}=m(()=>new c.DepthOfFieldEffect(o.value,e),e);return t({pass:a,effect:s}),v([[()=>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"]],s,()=>new c.DepthOfFieldEffect),()=>{}}}),te=r.defineComponent({__name:"GlitchPmndrs",props:{blendFunction:{},delay:{},duration:{},strength:{},mode:{},active:{type:Boolean},ratio:{},columns:{},chromaticAberrationOffset:{},perturbationMap:{},dtSize:{}},setup(i,{expose:t}){const e=i,{pass:o,effect:a}=m(()=>new c.GlitchEffect(e),e);t({pass:o,effect:a});const{onBeforeRender:s}=g.useLoop();return s(({invalidate:l})=>l()),r.watchEffect(()=>{const l=()=>{if(e.mode!==void 0)return e.active===!1?c.GlitchMode.DISABLED:e.mode;const d=new c.GlitchEffect,f=d.mode;return d.dispose(),f};a.value&&(a.value.mode=l())}),C(O(e,["active","mode","blendFunction"]),a,()=>new c.GlitchEffect),()=>{}}}),oe=r.defineComponent({__name:"NoisePmndrs",props:{premultiply:{type:Boolean,default:void 0},blendFunction:{}},setup(i,{expose:t}){const e=i,{pass:o,effect:a}=m(()=>new c.NoiseEffect(e),e);t({pass:o,effect:a});const{onBeforeRender:s}=g.useLoop();return s(({invalidate:l})=>l()),C(O(e,["blendFunction"]),a,()=>new c.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:t}){const e=i,o=h=>h!==void 0?g.normalizeColor(h).getHex():void 0,{camera:a,scene:s}=g.useTresContext(),l={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:o(e.hiddenEdgeColor),visibleEdgeColor:o(e.visibleEdgeColor)},{pass:d,effect:f}=m(()=>new c.OutlineEffect(s.value,a.value,l),e);t({pass:d,effect:f}),r.watch([()=>e.outlinedObjects,f],()=>{var h;(h=f.value)==null||h.selection.set(e.outlinedObjects||[])},{immediate:!0});const w=r.computed(()=>({hiddenEdgeColor:e.hiddenEdgeColor?g.normalizeColor(e.hiddenEdgeColor):void 0,visibleEdgeColor:e.visibleEdgeColor?g.normalizeColor(e.visibleEdgeColor):void 0}));return v([[()=>e.blur,"blur"],[()=>e.xRay,"xRay"],[()=>e.pulseSpeed,"pulseSpeed"],[()=>e.kernelSize,"kernelSize"],[()=>e.edgeStrength,"edgeStrength"],[()=>e.patternScale,"patternScale"],[()=>e.multisampling,"multisampling"],[()=>w.value.hiddenEdgeColor,"hiddenEdgeColor"],[()=>w.value.visibleEdgeColor,"visibleEdgeColor"]],f,()=>new c.OutlineEffect),()=>{}}}),se=r.defineComponent({__name:"PixelationPmndrs",props:{granularity:{}},setup(i,{expose:t}){const e=i,{pass:o,effect:a}=m(()=>new c.PixelationEffect(e.granularity),e);return t({pass:o,effect:a}),C(e,a,()=>new c.PixelationEffect),()=>{}}}),ne=r.defineComponent({__name:"VignettePmndrs",props:{technique:{},blendFunction:{},offset:{},darkness:{}},setup(i,{expose:t}){const e=i,{pass:o,effect:a}=m(()=>new c.VignetteEffect(e),e);return t({pass:o,effect:a}),C(O(e,["blendFunction"]),a,()=>new c.VignetteEffect),()=>{}}});class H extends c.Effect{constructor({blendFunction:t=c.BlendFunction.NORMAL,amount:e=.15,offset:o=new n.Vector2(.5,.5)}={}){super("BarrelBlurEffect",`
|
|
9
|
+
uniform float amount;
|
|
10
|
+
uniform vec2 offset;
|
|
11
|
+
|
|
12
|
+
#define NUM_ITER 16
|
|
13
|
+
#define RECIP_NUM_ITER 0.0625
|
|
14
|
+
#define GAMMA 1.0
|
|
15
|
+
|
|
16
|
+
vec3 spectrum_offset(float t) {
|
|
17
|
+
float lo = step(t, 0.5);
|
|
18
|
+
float hi = 1.0 - lo;
|
|
19
|
+
float w = 1.0 - abs(2.0 * t - 1.0);
|
|
20
|
+
return pow(vec3(lo, 1.0, hi) * vec3(1.0 - w, w, 1.0 - w), vec3(1.0 / GAMMA));
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
vec2 barrelDistortion(vec2 p, float amt) {
|
|
24
|
+
p = p - offset;
|
|
25
|
+
float theta = atan(p.y, p.x);
|
|
26
|
+
float radius = pow(length(p), 1.0 + 3.0 * amt);
|
|
27
|
+
return vec2(cos(theta), sin(theta)) * radius + offset;
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
void mainUv(inout vec2 uv) {
|
|
31
|
+
uv = barrelDistortion(uv, amount * 0.5);
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
void mainImage(const in vec4 inputColor, const in vec2 uv, out vec4 outputColor) {
|
|
35
|
+
vec3 sumcol = vec3(0.0);
|
|
36
|
+
vec3 sumw = vec3(0.0);
|
|
37
|
+
|
|
38
|
+
for (int i = 0; i < NUM_ITER; ++i) {
|
|
39
|
+
float t = float(i) * RECIP_NUM_ITER;
|
|
40
|
+
vec3 w = spectrum_offset(t);
|
|
41
|
+
vec2 distortedUV = barrelDistortion(uv, amount * t);
|
|
42
|
+
sumcol += w * texture(inputBuffer, distortedUV).rgb;
|
|
43
|
+
sumw += w;
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
vec3 outcol = pow(sumcol / sumw, vec3(1.0 / GAMMA));
|
|
47
|
+
|
|
48
|
+
outcol = clamp(outcol, 0.0, 1.0); // Ensures normalized color values
|
|
49
|
+
|
|
50
|
+
outputColor = vec4(outcol, inputColor.a); // Preserves original alpha
|
|
51
|
+
}
|
|
52
|
+
`,{blendFunction:t,uniforms:new Map([["amount",new n.Uniform(e)],["offset",new n.Uniform(o)]])})}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 ie=r.defineComponent({__name:"BarrelBlurPmndrs",props:{blendFunction:{},amount:{},offset:{}},setup(i,{expose:t}){const e=i,{pass:o,effect:a}=m(()=>new H({...e,offset:Array.isArray(e.offset)?new n.Vector2(...e.offset):e.offset}),e);return t({pass:o,effect:a}),v([[()=>e.blendFunction,"blendMode.blendFunction"],[()=>e.amount,"amount"],[()=>e.offset,"offset"]],a,()=>new H),()=>{}}}),re=r.defineComponent({__name:"ToneMappingPmndrs",props:{mode:{},blendFunction:{},resolution:{},averageLuminance:{},middleGrey:{},minLuminance:{},whitePoint:{}},setup(i,{expose:t}){const e=i,{pass:o,effect:a}=m(()=>new c.ToneMappingEffect(e),e);return t({pass:o,effect:a}),v([[()=>e.mode,"mode"],[()=>e.blendFunction,"blendMode.blendFunction"],[()=>e.resolution,"resolution"],[()=>e.averageLuminance,"averageLuminance"],[()=>e.middleGrey,"middleGrey"],[()=>e.minLuminance,"adaptiveLuminanceMaterial.minLuminance"],[()=>e.whitePoint,"whitePoint"]],a,()=>new c.ToneMappingEffect),()=>{}}}),le=r.defineComponent({__name:"ChromaticAberrationPmndrs",props:{blendFunction:{},offset:{},radialModulation:{type:Boolean,default:void 0},modulationOffset:{}},setup(i,{expose:t}){const e=i,o=new c.ChromaticAberrationEffect,{pass:a,effect:s}=m(()=>new c.ChromaticAberrationEffect({...e,radialModulation:e.radialModulation??o.radialModulation,modulationOffset:e.modulationOffset??o.modulationOffset}),e);return o.dispose(),t({pass:a,effect:s}),v([[()=>e.blendFunction,"blendMode.blendFunction"],[()=>e.offset,"offset"],[()=>e.radialModulation,"radialModulation"],[()=>e.modulationOffset,"modulationOffset"]],s,()=>new c.ChromaticAberrationEffect),()=>{}}}),ce=r.defineComponent({__name:"HueSaturationPmndrs",props:{saturation:{},hue:{},blendFunction:{}},setup(i,{expose:t}){const e=i,{pass:o,effect:a}=m(()=>new c.HueSaturationEffect(e),e);return t({pass:o,effect:a}),v([[()=>e.blendFunction,"blendMode.blendFunction"],[()=>e.hue,"hue"],[()=>e.saturation,"saturation"]],a,()=>new c.HueSaturationEffect),()=>{}}}),de=r.defineComponent({__name:"ScanlinePmndrs",props:{blendFunction:{},density:{},scrollSpeed:{},opacity:{}},setup(i,{expose:t}){const e=i,{pass:o,effect:a}=m(()=>new c.ScanlineEffect(e),e);return t({pass:o,effect:a}),v([[()=>e.blendFunction,"blendMode.blendFunction"],[()=>e.density,"density"],[()=>e.scrollSpeed,"scrollSpeed"]],a,()=>new c.ScanlineEffect),r.watch([()=>e.opacity],()=>{var s,l;if(e.opacity!==void 0)(s=a.value)==null||s.blendMode.setOpacity(e.opacity);else{const d=new c.ScanlineEffect;(l=a.value)==null||l.blendMode.setOpacity(d.blendMode.getOpacity()),d.dispose()}},{immediate:!0}),()=>{}}}),ue=`
|
|
53
|
+
uniform float radius;
|
|
54
|
+
uniform int sectorCount;
|
|
55
|
+
|
|
56
|
+
const int MAX_SECTOR_COUNT = 8;
|
|
57
|
+
|
|
58
|
+
float polynomialWeight(float x, float y, float eta, float lambda) {
|
|
59
|
+
float polyValue = (x + eta) - lambda * (y * y);
|
|
60
|
+
return max(0.0, polyValue * polyValue);
|
|
61
|
+
}
|
|
62
|
+
|
|
63
|
+
void getSectorVarianceAndAverageColor(mat2 anisotropyMat, float angle, float radius, out vec3 avgColor, out float variance) {
|
|
64
|
+
vec3 weightedColorSum = vec3(0.0);
|
|
65
|
+
vec3 weightedSquaredColorSum = vec3(0.0);
|
|
66
|
+
float totalWeight = 0.0;
|
|
67
|
+
|
|
68
|
+
float eta = 0.1;
|
|
69
|
+
float lambda = 0.5;
|
|
70
|
+
float angleStep = 0.196349; // Precompute angle step
|
|
71
|
+
float halfAngleRange = 0.392699; // Precompute half angle range
|
|
72
|
+
|
|
73
|
+
float cosAngle = cos(angle);
|
|
74
|
+
float sinAngle = sin(angle);
|
|
75
|
+
|
|
76
|
+
for (float r = 1.0; r <= radius; r += 1.0) {
|
|
77
|
+
float rCosAngle = r * cosAngle;
|
|
78
|
+
float rSinAngle = r * sinAngle;
|
|
79
|
+
for (float a = -halfAngleRange; a <= halfAngleRange; a += angleStep) {
|
|
80
|
+
float cosA = cos(a);
|
|
81
|
+
float sinA = sin(a);
|
|
82
|
+
vec2 sampleOffset = vec2(rCosAngle * cosA - rSinAngle * sinA, rCosAngle * sinA + rSinAngle * cosA) / resolution;
|
|
83
|
+
sampleOffset *= anisotropyMat;
|
|
84
|
+
|
|
85
|
+
vec3 color = texture2D(inputBuffer, vUv + sampleOffset).rgb;
|
|
86
|
+
float weight = polynomialWeight(sampleOffset.x, sampleOffset.y, eta, lambda);
|
|
87
|
+
|
|
88
|
+
weightedColorSum += color * weight;
|
|
89
|
+
weightedSquaredColorSum += color * color * weight;
|
|
90
|
+
totalWeight += weight;
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
|
|
94
|
+
// Calculate average color and variance
|
|
95
|
+
avgColor = weightedColorSum / totalWeight;
|
|
96
|
+
vec3 varianceRes = (weightedSquaredColorSum / totalWeight) - (avgColor * avgColor);
|
|
97
|
+
variance = dot(varianceRes, vec3(0.299, 0.587, 0.114)); // Convert to luminance
|
|
98
|
+
}
|
|
99
|
+
|
|
100
|
+
vec4 getDominantOrientation(vec4 structureTensor) {
|
|
101
|
+
float Jxx = structureTensor.r;
|
|
102
|
+
float Jyy = structureTensor.g;
|
|
103
|
+
float Jxy = structureTensor.b;
|
|
104
|
+
|
|
105
|
+
float trace = Jxx + Jyy;
|
|
106
|
+
float det = Jxx * Jyy - Jxy * Jxy;
|
|
107
|
+
float lambda1 = 0.5 * (trace + sqrt(trace * trace - 4.0 * det));
|
|
108
|
+
float lambda2 = 0.5 * (trace - sqrt(trace * trace - 4.0 * det));
|
|
109
|
+
|
|
110
|
+
float dominantOrientation = atan(2.0 * Jxy, Jxx - Jyy) / 2.0;
|
|
111
|
+
return vec4(dominantOrientation, lambda1, lambda2, 0.0);
|
|
112
|
+
}
|
|
113
|
+
|
|
114
|
+
void mainImage(const in vec4 inputColor, const in vec2 uv, out vec4 outputColor) {
|
|
115
|
+
vec4 structureTensor = texture2D(inputBuffer, uv);
|
|
116
|
+
|
|
117
|
+
vec3 sectorAvgColors[MAX_SECTOR_COUNT];
|
|
118
|
+
float sectorVariances[MAX_SECTOR_COUNT];
|
|
119
|
+
|
|
120
|
+
vec4 orientationAndAnisotropy = getDominantOrientation(structureTensor);
|
|
121
|
+
vec2 orientation = orientationAndAnisotropy.xy;
|
|
122
|
+
|
|
123
|
+
float anisotropy = (orientationAndAnisotropy.z - orientationAndAnisotropy.w) / (orientationAndAnisotropy.z + orientationAndAnisotropy.w + 1e-7);
|
|
124
|
+
|
|
125
|
+
float alpha = 25.0;
|
|
126
|
+
float scaleX = alpha / (anisotropy + alpha);
|
|
127
|
+
float scaleY = (anisotropy + alpha) / alpha;
|
|
128
|
+
|
|
129
|
+
mat2 anisotropyMat = mat2(orientation.x, -orientation.y, orientation.y, orientation.x) * mat2(scaleX, 0.0, 0.0, scaleY);
|
|
130
|
+
|
|
131
|
+
for (int i = 0; i < sectorCount; i++) {
|
|
132
|
+
float angle = float(i) * 6.28318 / float(sectorCount); // 2π / sectorCount
|
|
133
|
+
getSectorVarianceAndAverageColor(anisotropyMat, angle, float(radius), sectorAvgColors[i], sectorVariances[i]);
|
|
134
|
+
}
|
|
135
|
+
|
|
136
|
+
float minVariance = sectorVariances[0];
|
|
137
|
+
vec3 finalColor = sectorAvgColors[0];
|
|
138
|
+
|
|
139
|
+
for (int i = 1; i < sectorCount; i++) {
|
|
140
|
+
if (sectorVariances[i] < minVariance) {
|
|
141
|
+
minVariance = sectorVariances[i];
|
|
142
|
+
finalColor = sectorAvgColors[i];
|
|
143
|
+
}
|
|
144
|
+
}
|
|
145
|
+
|
|
146
|
+
outputColor = vec4(finalColor, inputColor.a);
|
|
147
|
+
}
|
|
148
|
+
`;class V extends c.Effect{constructor({blendFunction:t=c.BlendFunction.NORMAL,radius:e=1,sectorCount:o=4}={}){super("KuwaharaEffect",ue,{blendFunction:t,uniforms:new Map([["radius",new n.Uniform(e)],["sectorCount",new n.Uniform(o)]])})}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 fe=r.defineComponent({__name:"KuwaharaPmndrs",props:{blendFunction:{},radius:{},sectorCount:{}},setup(i,{expose:t}){const e=i,{pass:o,effect:a}=m(()=>new V(e),e);return t({pass:o,effect:a}),v([[()=>e.blendFunction,"blendMode.blendFunction"],[()=>e.radius,"radius"],[()=>e.sectorCount,"sectorCount"]],a,()=>new V),()=>{}}}),he=r.defineComponent({__name:"ColorAveragePmndrs",props:{blendFunction:{},opacity:{}},setup(i,{expose:t}){const e=i,{pass:o,effect:a}=m(()=>new c.ColorAverageEffect(e.blendFunction),e);return t({pass:o,effect:a}),D(()=>e.blendFunction,a,"blendMode.blendFunction",()=>new c.ColorAverageEffect),r.watch([a,()=>e.opacity],()=>{var s,l;if(a.value)if(e.opacity!==void 0)(s=a.value)==null||s.blendMode.setOpacity(e.opacity);else{const d=new c.ColorAverageEffect;(l=a.value)==null||l.blendMode.setOpacity(d.blendMode.getOpacity()),d.dispose()}}),()=>{}}}),me=r.defineComponent({__name:"LensDistortionPmndrs",props:{distortion:{},principalPoint:{},focalLength:{},skew:{}},setup(i,{expose:t}){const e=i,{pass:o,effect:a}=m(()=>new c.LensDistortionEffect({...e,distortion:e.distortion?Array.isArray(e.distortion)?new n.Vector2(...e.distortion):e.distortion:new n.Vector2,principalPoint:e.principalPoint?Array.isArray(e.principalPoint)?new n.Vector2(...e.principalPoint):e.principalPoint:new n.Vector2,focalLength:e.focalLength?Array.isArray(e.focalLength)?new n.Vector2(...e.focalLength):e.focalLength:new n.Vector2}),e);return t({pass:o,effect:a}),C(e,a,()=>new c.LensDistortionEffect),()=>{}}}),pe=r.defineComponent({__name:"ShockWavePmndrs",props:{position:{},amplitude:{},speed:{},maxRadius:{},waveSize:{}},setup(i,{expose:t}){const e=i,{camera:o}=g.useTresContext(),{pass:a,effect:s}=m(()=>new c.ShockWaveEffect(o.value,Array.isArray(e.position)?new n.Vector3(...e.position):e.position,e),e);return t({pass:a,effect:s}),r.watch(()=>e.position,l=>{s.value&&(Array.isArray(l)?s.value.position.set(...l):l instanceof n.Vector3&&s.value.position.copy(l))},{immediate:!0}),v([[()=>e.amplitude,"amplitude"],[()=>e.waveSize,"waveSize"],[()=>e.maxRadius,"maxRadius"],[()=>e.speed,"speed"]],s,()=>new c.ShockWaveEffect),()=>{}}}),ge=r.defineComponent({__name:"TiltShiftPmndrs",props:{blendFunction:{},offset:{},rotation:{},focusArea:{},feather:{},kernelSize:{},resolutionScale:{},resolutionX:{},resolutionY:{}},setup(i,{expose:t}){const e=i,{pass:o,effect:a}=m(()=>new c.TiltShiftEffect(e),e);return t({pass:o,effect:a}),v([[()=>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"]],a,()=>new c.TiltShiftEffect),()=>{}}}),ve=r.defineComponent({__name:"DotScreenPmndrs",props:{angle:{},scale:{},blendFunction:{}},setup(i,{expose:t}){const e=i,{pass:o,effect:a}=m(()=>new c.DotScreenEffect(e),e);return t({pass:o,effect:a}),v([[()=>e.blendFunction,"blendMode.blendFunction"],[()=>e.angle,"angle"],[()=>e.scale,"scale"]],a,()=>new c.DotScreenEffect),()=>{}}}),xe=r.defineComponent({__name:"SepiaPmndrs",props:{blendFunction:{},intensity:{}},setup(i,{expose:t}){const e=i,{pass:o,effect:a}=m(()=>new c.SepiaEffect(e),e);return t({pass:o,effect:a}),v([[()=>e.blendFunction,"blendMode.blendFunction"],[()=>e.intensity,"intensity"]],a,()=>new c.SepiaEffect),()=>{}}});class X extends c.Effect{constructor({blendFunction:t=c.BlendFunction.NORMAL,scale:e=.85,noiseScale:o=0,center:a=[.5,.5],rotation:s=0}={}){const l=Array.isArray(a)?new n.Vector2().fromArray(a):a;super("LinocutEffect",`
|
|
149
|
+
uniform float scale;
|
|
150
|
+
uniform float noiseScale;
|
|
151
|
+
uniform vec2 center;
|
|
152
|
+
uniform float rotation;
|
|
153
|
+
|
|
154
|
+
float luma(vec3 color) {
|
|
155
|
+
return dot(color, vec3(0.299, 0.587, 0.114));
|
|
156
|
+
}
|
|
157
|
+
|
|
158
|
+
float luma(vec4 color) {
|
|
159
|
+
return dot(color.rgb, vec3(0.299, 0.587, 0.114));
|
|
160
|
+
}
|
|
161
|
+
|
|
162
|
+
// Simple pseudo-random noise function
|
|
163
|
+
float noise(vec2 p) {
|
|
164
|
+
return fract(sin(dot(p, vec2(12.9898, 78.233))) * 43758.5453123);
|
|
165
|
+
}
|
|
166
|
+
|
|
167
|
+
void mainImage(const in vec4 inputColor, const in vec2 uv, out vec4 outputColor) {
|
|
168
|
+
// Calculate the center based on center
|
|
169
|
+
vec2 fragCoord = uv * resolution.xy;
|
|
170
|
+
|
|
171
|
+
// Apply rotation to the coordinates
|
|
172
|
+
vec2 d = fragCoord - center * resolution.xy;
|
|
173
|
+
mat2 rotMat = mat2(cos(rotation), -sin(rotation), sin(rotation), cos(rotation));
|
|
174
|
+
vec2 rotatedD = d * rotMat;
|
|
175
|
+
|
|
176
|
+
// Calculate radial distance and angle
|
|
177
|
+
float r = length(rotatedD) / (1000.0 / max(scale, 0.01)); // Normalization to avoid artifacts
|
|
178
|
+
float a = atan(rotatedD.y, rotatedD.x) + scale * (0.5 - r) / 0.5;
|
|
179
|
+
|
|
180
|
+
// Calculate transformed coordinates
|
|
181
|
+
vec2 uvt = center * resolution.xy + r * vec2(cos(a), sin(a));
|
|
182
|
+
|
|
183
|
+
// Normalize UV coordinates
|
|
184
|
+
vec2 uv2 = fragCoord / resolution.xy;
|
|
185
|
+
|
|
186
|
+
// Generate sinusoidal line patterns
|
|
187
|
+
float c = (0.75 + 0.25 * sin(uvt.x * 1000.0 * max(scale, 0.01))); // Prevent excessive distortions
|
|
188
|
+
|
|
189
|
+
// Load the texture and convert to grayscale
|
|
190
|
+
vec4 color = texture(inputBuffer, uv2);
|
|
191
|
+
color.rgb = color.rgb * color.rgb; // Convert from sRGB to linear
|
|
192
|
+
float l = luma(color);
|
|
193
|
+
|
|
194
|
+
// Add noise based on noiseScale
|
|
195
|
+
float n = noise(uv2 * 10.0); // Generate noise
|
|
196
|
+
l += noiseScale * (n - 0.5); // Apply noise as a perturbation
|
|
197
|
+
|
|
198
|
+
// Apply smoothing to achieve the linocut effect
|
|
199
|
+
float f = smoothstep(0.5 * c, c, l);
|
|
200
|
+
f = smoothstep(0.0, 0.5, f);
|
|
201
|
+
|
|
202
|
+
// Convert the final value back to sRGB
|
|
203
|
+
f = sqrt(f);
|
|
204
|
+
|
|
205
|
+
// Output the final color in black and white
|
|
206
|
+
outputColor = vec4(vec3(f), 1.0);
|
|
207
|
+
}
|
|
208
|
+
`,{blendFunction:t,uniforms:new Map([["scale",new n.Uniform(e)],["noiseScale",new n.Uniform(o)],["center",new n.Uniform(l)],["rotation",new n.Uniform(s)]])})}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 n.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 be=r.defineComponent({__name:"LinocutPmndrs",props:{blendFunction:{},scale:{},noiseScale:{},center:{},rotation:{}},setup(i,{expose:t}){const e=i,{pass:o,effect:a}=m(()=>new X({...e,center:e.center instanceof n.Vector2?[e.center.x,e.center.y]:e.center}),e);return t({pass:o,effect:a}),v([[()=>e.blendFunction,"blendMode.blendFunction"],[()=>e.scale,"scale"],[()=>e.noiseScale,"noiseScale"],[()=>e.center,"center"],[()=>e.rotation,"rotation"]],a,()=>new X),()=>{}}}),we=r.defineComponent({__name:"DepthPickingPassPmndrs",props:{depthPacking:{},mode:{}},setup(i,{expose:t}){const e=i,o=r.inject(B),a=new c.DepthPickingPass(e),s=r.watchEffect(()=>{o!=null&&o.value&&(r.nextTick(()=>s()),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())}),t({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:t}){const e=i,{camera:o}=g.useTresContext(),{pass:a,effect:s}=m(()=>new c.GodRaysEffect(o.value,r.toRaw(e.lightSource),e),e);return t({pass:a,effect:s}),v([[()=>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,"kernelSize"],[()=>e.blur,"blur"]],s,()=>new c.GodRaysEffect),r.watch([()=>e.opacity],()=>{var l,d;if(e.opacity!==void 0)(l=s.value)==null||l.blendMode.setOpacity(e.opacity);else{const f=new c.GodRaysEffect(o.value,r.toRaw(e.lightSource));(d=s.value)==null||d.blendMode.setOpacity(f.blendMode.getOpacity()),f.dispose()}},{immediate:!0}),()=>{}}}),Ae=r.defineComponent({__name:"ColorDepthPmndrs",props:{blendFunction:{},bits:{},opacity:{}},setup(i,{expose:t}){const e=i,{pass:o,effect:a}=m(()=>new c.ColorDepthEffect(e),e);return t({pass:o,effect:a}),D(()=>e.blendFunction,a,"blendMode.blendFunction",()=>new c.ColorDepthEffect),r.watch([a,()=>e.bits],()=>{var s,l;if(a.value)if(e.bits!==void 0)(s=a.value)==null||s.setBitDepth(e.bits);else{const d=new c.ColorDepthEffect;(l=a.value)==null||l.setBitDepth(d.getBitDepth()),d.dispose()}}),r.watch([a,()=>e.opacity],()=>{var s,l;if(a.value)if(e.opacity!==void 0)(s=a.value)==null||s.blendMode.setOpacity(e.opacity);else{const d=new c.ColorDepthEffect;(l=a.value)==null||l.blendMode.setOpacity(d.blendMode.getOpacity()),d.dispose()}}),()=>{}}}),ye=r.defineComponent({__name:"GridPmndrs",props:{blendFunction:{},scale:{},lineWidth:{}},setup(i,{expose:t}){const e=i,{pass:o,effect:a}=m(()=>new c.GridEffect(e),e);return t({pass:o,effect:a}),v([[()=>e.blendFunction,"blendMode.blendFunction"],[()=>e.scale,"scale"],[()=>e.lineWidth,"lineWidth"]],a,()=>new c.GridEffect),()=>{}}});class I extends c.Effect{constructor({blendFunction:t=c.BlendFunction.NORMAL,lensS:e=new n.Vector2(1,1),lensF:o=new n.Vector2(0,1),scale:a=1}={}){super("FishEyeEffect",`
|
|
209
|
+
uniform vec2 lensS;
|
|
210
|
+
uniform vec2 lensF;
|
|
211
|
+
uniform float scale;
|
|
212
|
+
|
|
213
|
+
void mainUv(inout vec2 uv) {
|
|
214
|
+
vec2 newUv = uv * 2.0 - 1.0;
|
|
215
|
+
newUv.x = newUv.x + ((pow(newUv.y, 2.0) / scale) * newUv.x / scale) * -lensF.x;
|
|
216
|
+
newUv.y = newUv.y + ((pow(newUv.x, 2.0) / scale) * newUv.y / scale) * -lensF.y;
|
|
217
|
+
newUv = newUv * lensS;
|
|
218
|
+
newUv = newUv / scale * 0.5 + 0.5;
|
|
219
|
+
|
|
220
|
+
uv = newUv;
|
|
221
|
+
}
|
|
222
|
+
|
|
223
|
+
void mainImage(const in vec4 inputColor, const in vec2 uv, out vec4 outputColor) {
|
|
224
|
+
outputColor = vec4(inputColor.rgb, inputColor.a); // Preserves original alpha
|
|
225
|
+
}
|
|
226
|
+
`,{blendFunction:t,uniforms:new Map([["lensS",new n.Uniform(e)],["lensF",new n.Uniform(o)],["scale",new n.Uniform(a)]])})}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 Te=r.defineComponent({__name:"FishEyePmndrs",props:{blendFunction:{},lensS:{},lensF:{},scale:{}},setup(i,{expose:t}){const e=i,o=r.computed(()=>Array.isArray(e.lensS)?new n.Vector2(...e.lensS):e.lensS),a=r.computed(()=>Array.isArray(e.lensF)?new n.Vector2(...e.lensF):e.lensF),{pass:s,effect:l}=m(()=>new I({...e,lensS:o.value,lensF:a.value}),e);return t({pass:s,effect:l}),v([[()=>e.blendFunction,"blendMode.blendFunction"],[()=>o.value,"lensS"],[()=>a.value,"lensF"],[()=>e.scale,"scale"]],l,()=>new I),()=>{}}}),Me=r.defineComponent({__name:"BrightnessContrastPmndrs",props:{blendFunction:{},brightness:{},contrast:{}},setup(i,{expose:t}){const e=i,{pass:o,effect:a}=m(()=>new c.BrightnessContrastEffect(e),e);return t({pass:o,effect:a}),v([[()=>e.blendFunction,"blendMode.blendFunction"],[()=>e.brightness,"brightness"],[()=>e.contrast,"contrast"]],a,()=>new c.BrightnessContrastEffect),()=>{}}}),j={name:"CopyShader",uniforms:{tDiffuse:{value:null},opacity:{value:1}},vertexShader:`
|
|
9
227
|
|
|
10
228
|
varying vec2 vUv;
|
|
11
229
|
|
|
@@ -28,7 +246,7 @@
|
|
|
28
246
|
gl_FragColor = opacity * texel;
|
|
29
247
|
|
|
30
248
|
|
|
31
|
-
}`};class
|
|
249
|
+
}`};class S{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 n.OrthographicCamera(-1,1,1,-1,0,1);class Ee extends n.BufferGeometry{constructor(){super(),this.setAttribute("position",new n.Float32BufferAttribute([-1,3,0,-1,-1,0,3,-1,0],3)),this.setAttribute("uv",new n.Float32BufferAttribute([0,2,0,0,2,0],2))}}const De=new Ee;class y{constructor(t){this._mesh=new n.Mesh(De,t)}dispose(){this._mesh.geometry.dispose()}render(t){t.render(this._mesh,Ce)}get material(){return this._mesh.material}set material(t){this._mesh.material=t}}class Pe extends S{constructor(t,e){super(),this.textureID=e!==void 0?e:"tDiffuse",t instanceof n.ShaderMaterial?(this.uniforms=t.uniforms,this.material=t):t&&(this.uniforms=n.UniformsUtils.clone(t.uniforms),this.material=new n.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 y(this.material)}render(t,e,o){this.uniforms[this.textureID]&&(this.uniforms[this.textureID].value=o.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 Y extends S{constructor(t,e){super(),this.scene=t,this.camera=e,this.clear=!0,this.needsSwap=!1,this.inverse=!1}render(t,e,o){const a=t.getContext(),s=t.state;s.buffers.color.setMask(!1),s.buffers.depth.setMask(!1),s.buffers.color.setLocked(!0),s.buffers.depth.setLocked(!0);let l,d;this.inverse?(l=0,d=1):(l=1,d=0),s.buffers.stencil.setTest(!0),s.buffers.stencil.setOp(a.REPLACE,a.REPLACE,a.REPLACE),s.buffers.stencil.setFunc(a.ALWAYS,l,4294967295),s.buffers.stencil.setClear(d),s.buffers.stencil.setLocked(!0),t.setRenderTarget(o),this.clear&&t.clear(),t.render(this.scene,this.camera),t.setRenderTarget(e),this.clear&&t.clear(),t.render(this.scene,this.camera),s.buffers.color.setLocked(!1),s.buffers.depth.setLocked(!1),s.buffers.color.setMask(!0),s.buffers.depth.setMask(!0),s.buffers.stencil.setLocked(!1),s.buffers.stencil.setFunc(a.EQUAL,1,4294967295),s.buffers.stencil.setOp(a.KEEP,a.KEEP,a.KEEP),s.buffers.stencil.setLocked(!0)}}class Le extends S{constructor(){super(),this.needsSwap=!1}render(t){t.state.buffers.stencil.setLocked(!1),t.state.buffers.stencil.setTest(!1)}}class Re{constructor(t,e){if(this.renderer=t,this._pixelRatio=t.getPixelRatio(),e===void 0){const o=t.getSize(new n.Vector2);this._width=o.width,this._height=o.height,e=new n.WebGLRenderTarget(this._width*this._pixelRatio,this._height*this._pixelRatio,{type:n.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 Pe(j),this.copyPass.material.blending=n.NoBlending,this.clock=new n.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 o=!1;for(let a=0,s=this.passes.length;a<s;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,t,o),l.needsSwap){if(o){const d=this.renderer.getContext(),f=this.renderer.state.buffers.stencil;f.setFunc(d.NOTEQUAL,1,4294967295),this.copyPass.render(this.renderer,this.writeBuffer,this.readBuffer,t),f.setFunc(d.EQUAL,1,4294967295)}this.swapBuffers()}Y!==void 0&&(l instanceof Y?o=!0:l instanceof Le&&(o=!1))}}this.renderer.setRenderTarget(e)}reset(t){if(t===void 0){const e=this.renderer.getSize(new n.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 o=this._width*this._pixelRatio,a=this._height*this._pixelRatio;this.renderTarget1.setSize(o,a),this.renderTarget2.setSize(o,a);for(let s=0;s<this.passes.length;s++)this.passes[s].setSize(o,a)}setPixelRatio(t){this._pixelRatio=t,this.setSize(this._width,this._height)}dispose(){this.renderTarget1.dispose(),this.renderTarget2.dispose(),this.copyPass.dispose()}}class Fe extends S{constructor(t,e,o=null,a=null,s=null){super(),this.scene=t,this.camera=e,this.overrideMaterial=o,this.clearColor=a,this.clearAlpha=s,this.clear=!0,this.clearDepth=!1,this.needsSwap=!1,this._oldClearColor=new n.Color}render(t,e,o){const a=t.autoClear;t.autoClear=!1;let s,l;this.overrideMaterial!==null&&(l=this.scene.overrideMaterial,this.scene.overrideMaterial=this.overrideMaterial),this.clearColor!==null&&(t.getClearColor(this._oldClearColor),t.setClearColor(this.clearColor,t.getClearAlpha())),this.clearAlpha!==null&&(s=t.getClearAlpha(),t.setClearAlpha(this.clearAlpha)),this.clearDepth==!0&&t.clearDepth(),t.setRenderTarget(this.renderToScreen?null:o),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(s),this.overrideMaterial!==null&&(this.scene.overrideMaterial=l),t.autoClear=a}}const k=Symbol("effectComposerThree"),Oe=r.defineComponent({__name:"EffectComposer",props:{enabled:{type:Boolean,default:!0},withoutRenderPass:{type:Boolean}},setup(i,{expose:t}){const e=i,o=r.shallowRef(null);r.provide(k,o),t({composer:o});const{renderer:a,sizes:s,scene:l,camera:d,render:f}=g.useTresContext(),w=()=>{var p;(p=o.value)==null||p.dispose(),o.value=new Re(a.value)};r.watchEffect(w),r.watchEffect(()=>{var F;const{width:p,height:A}=s;A.value&&p.value&&((F=o.value)==null||F.setSize(p.value,A.value))});const{pixelRatio:h}=U.useDevicePixelRatio();r.watchEffect(()=>{var p;(p=o.value)==null||p.setPixelRatio(h.value)}),e.withoutRenderPass||r.watchEffect(()=>{d.value&&l.value&&o.value&&o.value.addPass(new Fe(l.value,d.value))});const{render:x}=g.useLoop();return x(()=>{f.frames.value>0&&o.value&&e.enabled&&o.value.render(),f.frames.value=f.mode.value==="always"?1:Math.max(0,f.frames.value-1)}),r.onUnmounted(()=>{var p;(p=o.value)==null||p.dispose()}),(p,A)=>r.renderSlot(p.$slots,"default")}}),T=(i,t)=>{const e=r.inject(k),o=r.shallowRef(i()),{sizes:a,invalidate:s}=g.useTresContext();t&&r.watch(t,()=>s());const l=r.watchEffect(()=>{!(e!=null&&e.value)||!a.height.value||!a.width.value||(e.value.addPass(o.value),r.nextTick(()=>l()))});return r.onUnmounted(()=>{var d;(d=e==null?void 0:e.value)==null||d.removePass(o.value),o.value.dispose()}),{pass:o}},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:`
|
|
32
250
|
|
|
33
251
|
varying vec2 vUv;
|
|
34
252
|
void main() {
|
|
@@ -95,7 +313,7 @@
|
|
|
95
313
|
else {
|
|
96
314
|
gl_FragColor=texture2D (tDiffuse, vUv);
|
|
97
315
|
}
|
|
98
|
-
}`};class
|
|
316
|
+
}`};class q extends S{constructor(t=64){super();const e=Be;this.uniforms=n.UniformsUtils.clone(e.uniforms),this.heightMap=this.generateHeightmap(t),this.uniforms.tDisp.value=this.heightMap,this.material=new n.ShaderMaterial({uniforms:this.uniforms,vertexShader:e.vertexShader,fragmentShader:e.fragmentShader}),this.fsQuad=new y(this.material),this.goWild=!1,this.curF=0,this.generateTrigger()}render(t,e,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=n.MathUtils.randFloat(-Math.PI,Math.PI),this.uniforms.seed_x.value=n.MathUtils.randFloat(-1,1),this.uniforms.seed_y.value=n.MathUtils.randFloat(-1,1),this.uniforms.distortion_x.value=n.MathUtils.randFloat(0,1),this.uniforms.distortion_y.value=n.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=n.MathUtils.randFloat(-Math.PI,Math.PI),this.uniforms.distortion_x.value=n.MathUtils.randFloat(0,1),this.uniforms.distortion_y.value=n.MathUtils.randFloat(0,1),this.uniforms.seed_x.value=n.MathUtils.randFloat(-.3,.3),this.uniforms.seed_y.value=n.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=n.MathUtils.randInt(120,240)}generateHeightmap(t){const e=new Float32Array(t*t),o=t*t;for(let s=0;s<o;s++){const l=n.MathUtils.randFloat(0,1);e[s]=l}const a=new n.DataTexture(e,t,t,n.RedFormat,n.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:t}){const e=i,{pass:o}=T(()=>new q(e.dtSize),e);t({pass:o});const{onBeforeRender:a}=g.useLoop();return a(({invalidate:s})=>s()),v([[()=>e.goWild,"goWild"]],o,()=>new q),()=>{}}}),P={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:`
|
|
99
317
|
|
|
100
318
|
varying vec2 vUV;
|
|
101
319
|
|
|
@@ -373,7 +591,7 @@
|
|
|
373
591
|
|
|
374
592
|
}
|
|
375
593
|
|
|
376
|
-
}`};class
|
|
594
|
+
}`};class Ue extends S{constructor(t,e,o){super(),this.uniforms=n.UniformsUtils.clone(P.uniforms),this.material=new n.ShaderMaterial({uniforms:this.uniforms,fragmentShader:P.fragmentShader,vertexShader:P.vertexShader}),this.uniforms.width.value=t,this.uniforms.height.value=e;for(const a in o)o.hasOwnProperty(a)&&this.uniforms.hasOwnProperty(a)&&(this.uniforms[a].value=o[a]);this.fsQuad=new y(this.material)}render(t,e,o){this.material.uniforms.tDiffuse.value=o.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 ze=r.defineComponent({__name:"Halftone",props:{shape:{},radius:{},rotateR:{},rotateG:{},rotateB:{},scatter:{},blending:{},greyscale:{type:Boolean},blendingMode:{}},setup(i,{expose:t}){const e=i,{sizes:o}=g.useTresContext(),a=r.computed(()=>Object.fromEntries(Object.entries(e).filter(([l,d])=>d!==void 0))),{pass:s}=T(()=>new Ue(o.width.value,o.height.value,a.value),e);return t({pass:s}),r.watchEffect(()=>{s.value.setSize(o.width.value,o.height.value)}),r.watchEffect(()=>{Object.entries(e).forEach(([l,d])=>{l in s.value.uniforms&&(s.value.uniforms[l].value=d??P.uniforms[l].value)})}),()=>{}}});class Q extends S{constructor(t,e,o,a={}){super(),this.pixelSize=t,this.resolution=new n.Vector2,this.renderResolution=new n.Vector2,this.pixelatedMaterial=this.createPixelatedMaterial(),this.normalMaterial=new n.MeshNormalMaterial,this.fsQuad=new y(this.pixelatedMaterial),this.scene=e,this.camera=o,this.normalEdgeStrength=a.normalEdgeStrength||.3,this.depthEdgeStrength=a.depthEdgeStrength||.4,this.beautyRenderTarget=new n.WebGLRenderTarget,this.beautyRenderTarget.texture.minFilter=n.NearestFilter,this.beautyRenderTarget.texture.magFilter=n.NearestFilter,this.beautyRenderTarget.texture.type=n.HalfFloatType,this.beautyRenderTarget.depthTexture=new n.DepthTexture,this.normalRenderTarget=new n.WebGLRenderTarget,this.normalRenderTarget.texture.minFilter=n.NearestFilter,this.normalRenderTarget.texture.magFilter=n.NearestFilter,this.normalRenderTarget.texture.type=n.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: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(t){this.pixelSize=t,this.setSize(this.resolution.x,this.resolution.y)}render(t,e){const o=this.fsQuad.material.uniforms;o.normalEdgeStrength.value=this.normalEdgeStrength,o.depthEdgeStrength.value=this.depthEdgeStrength,t.setRenderTarget(this.beautyRenderTarget),t.render(this.scene,this.camera);const a=this.scene.overrideMaterial;t.setRenderTarget(this.normalRenderTarget),this.scene.overrideMaterial=this.normalMaterial,t.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?t.setRenderTarget(null):(t.setRenderTarget(e),this.clear&&t.clear()),this.fsQuad.render(t)}createPixelatedMaterial(){return new n.ShaderMaterial({uniforms:{tDiffuse:{value:null},tDepth:{value:null},tNormal:{value:null},resolution:{value:new n.Vector4(this.renderResolution.x,this.renderResolution.y,1/this.renderResolution.x,1/this.renderResolution.y)},normalEdgeStrength:{value:0},depthEdgeStrength:{value:0}},vertexShader:`
|
|
377
595
|
varying vec2 vUv;
|
|
378
596
|
|
|
379
597
|
void main() {
|
|
@@ -471,7 +689,7 @@
|
|
|
471
689
|
gl_FragColor = texel * Strength;
|
|
472
690
|
|
|
473
691
|
}
|
|
474
|
-
`})}}const
|
|
692
|
+
`})}}const We=r.defineComponent({__name:"Pixelation",props:{pixelSize:{},depthEdgeStrength:{},normalEdgeStrength:{}},setup(i,{expose:t}){const e=i,{scene:o,camera:a}=g.useTresContext(),{pass:s}=T(()=>new Q(e.pixelSize,o.value,a.value),e);return t({pass:s}),r.watchEffect(()=>{s.value.setPixelSize(e.pixelSize)}),v([[()=>e.depthEdgeStrength,"depthEdgeStrength"],[()=>e.normalEdgeStrength,"normalEdgeStrength"]],s,()=>new Q(1,o.value,a.value)),()=>{}}}),Ge={name:"OutputShader",uniforms:{tDiffuse:{value:null},toneMappingExposure:{value:1}},vertexShader:`
|
|
475
693
|
precision highp float;
|
|
476
694
|
|
|
477
695
|
uniform mat4 modelViewMatrix;
|
|
@@ -488,7 +706,7 @@
|
|
|
488
706
|
gl_Position = projectionMatrix * modelViewMatrix * vec4( position, 1.0 );
|
|
489
707
|
|
|
490
708
|
}`,fragmentShader:`
|
|
491
|
-
|
|
709
|
+
|
|
492
710
|
precision highp float;
|
|
493
711
|
|
|
494
712
|
uniform sampler2D tDiffuse;
|
|
@@ -528,6 +746,10 @@
|
|
|
528
746
|
|
|
529
747
|
gl_FragColor.rgb = NeutralToneMapping( gl_FragColor.rgb );
|
|
530
748
|
|
|
749
|
+
#elif defined( CUSTOM_TONE_MAPPING )
|
|
750
|
+
|
|
751
|
+
gl_FragColor.rgb = CustomToneMapping( gl_FragColor.rgb );
|
|
752
|
+
|
|
531
753
|
#endif
|
|
532
754
|
|
|
533
755
|
// color space
|
|
@@ -538,7 +760,7 @@
|
|
|
538
760
|
|
|
539
761
|
#endif
|
|
540
762
|
|
|
541
|
-
}`};class
|
|
763
|
+
}`};class He extends S{constructor(){super();const t=Ge;this.uniforms=n.UniformsUtils.clone(t.uniforms),this.material=new n.RawShaderMaterial({name:t.name,uniforms:this.uniforms,vertexShader:t.vertexShader,fragmentShader:t.fragmentShader}),this.fsQuad=new y(this.material),this._outputColorSpace=null,this._toneMapping=null}render(t,e,o){this.uniforms.tDiffuse.value=o.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={},n.ColorManagement.getTransfer(this._outputColorSpace)===n.SRGBTransfer&&(this.material.defines.SRGB_TRANSFER=""),this._toneMapping===n.LinearToneMapping?this.material.defines.LINEAR_TONE_MAPPING="":this._toneMapping===n.ReinhardToneMapping?this.material.defines.REINHARD_TONE_MAPPING="":this._toneMapping===n.CineonToneMapping?this.material.defines.CINEON_TONE_MAPPING="":this._toneMapping===n.ACESFilmicToneMapping?this.material.defines.ACES_FILMIC_TONE_MAPPING="":this._toneMapping===n.AgXToneMapping?this.material.defines.AGX_TONE_MAPPING="":this._toneMapping===n.NeutralToneMapping?this.material.defines.NEUTRAL_TONE_MAPPING="":this._toneMapping===n.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 Ve=r.defineComponent({__name:"Output",setup(i,{expose:t}){const{pass:e}=T(()=>new He);return t({pass:e}),()=>{}}}),L={name:"SMAAEdgesShader",defines:{SMAA_THRESHOLD:"0.1"},uniforms:{tDiffuse:{value:null},resolution:{value:new n.Vector2(1/1024,1/512)}},vertexShader:`
|
|
542
764
|
|
|
543
765
|
uniform vec2 resolution;
|
|
544
766
|
|
|
@@ -622,7 +844,7 @@
|
|
|
622
844
|
|
|
623
845
|
gl_FragColor = SMAAColorEdgeDetectionPS( vUv, vOffset, tDiffuse );
|
|
624
846
|
|
|
625
|
-
}`},
|
|
847
|
+
}`},R={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 n.Vector2(1/1024,1/512)}},vertexShader:`
|
|
626
848
|
|
|
627
849
|
uniform vec2 resolution;
|
|
628
850
|
|
|
@@ -850,7 +1072,7 @@
|
|
|
850
1072
|
|
|
851
1073
|
gl_FragColor = SMAABlendingWeightCalculationPS( vUv, vPixcoord, vOffset, tDiffuse, tArea, tSearch, ivec4( 0.0 ) );
|
|
852
1074
|
|
|
853
|
-
}`},N={name:"SMAABlendShader",uniforms:{tDiffuse:{value:null},tColor:{value:null},resolution:{value:new
|
|
1075
|
+
}`},N={name:"SMAABlendShader",uniforms:{tDiffuse:{value:null},tColor:{value:null},resolution:{value:new n.Vector2(1/1024,1/512)}},vertexShader:`
|
|
854
1076
|
|
|
855
1077
|
uniform vec2 resolution;
|
|
856
1078
|
|
|
@@ -924,7 +1146,7 @@
|
|
|
924
1146
|
|
|
925
1147
|
gl_FragColor = SMAANeighborhoodBlendingPS( vUv, vOffset, tColor, tDiffuse );
|
|
926
1148
|
|
|
927
|
-
}`};class xe extends b{constructor(e,t){super(),this.edgesRT=new o.WebGLRenderTarget(e,t,{depthBuffer:!1,type:o.HalfFloatType}),this.edgesRT.texture.name="SMAAPass.edges",this.weightsRT=new o.WebGLRenderTarget(e,t,{depthBuffer:!1,type:o.HalfFloatType}),this.weightsRT.texture.name="SMAAPass.weights";const a=this,s=new Image;s.src=this.getAreaTexture(),s.onload=function(){a.areaTexture.needsUpdate=!0},this.areaTexture=new o.Texture,this.areaTexture.name="SMAAPass.area",this.areaTexture.image=s,this.areaTexture.minFilter=o.LinearFilter,this.areaTexture.generateMipmaps=!1,this.areaTexture.flipY=!1;const i=new Image;i.src=this.getSearchTexture(),i.onload=function(){a.searchTexture.needsUpdate=!0},this.searchTexture=new o.Texture,this.searchTexture.name="SMAAPass.search",this.searchTexture.image=i,this.searchTexture.magFilter=o.NearestFilter,this.searchTexture.minFilter=o.NearestFilter,this.searchTexture.generateMipmaps=!1,this.searchTexture.flipY=!1,this.uniformsEdges=o.UniformsUtils.clone(L.uniforms),this.uniformsEdges.resolution.value.set(1/e,1/t),this.materialEdges=new o.ShaderMaterial({defines:Object.assign({},L.defines),uniforms:this.uniformsEdges,vertexShader:L.vertexShader,fragmentShader:L.fragmentShader}),this.uniformsWeights=o.UniformsUtils.clone(P.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 o.ShaderMaterial({defines:Object.assign({},P.defines),uniforms:this.uniformsWeights,vertexShader:P.vertexShader,fragmentShader:P.fragmentShader}),this.uniformsBlend=o.UniformsUtils.clone(N.uniforms),this.uniformsBlend.resolution.value.set(1/e,1/t),this.uniformsBlend.tDiffuse.value=this.weightsRT.texture,this.materialBlend=new o.ShaderMaterial({uniforms:this.uniformsBlend,vertexShader:N.vertexShader,fragmentShader:N.fragmentShader}),this.fsQuad=new w(null)}render(e,t,a){this.uniformsEdges.tDiffuse.value=a.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=a.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 be=n.defineComponent({__name:"SMAA",props:{width:{},height:{}},setup(l,{expose:e}){const t=l,{sizes:a}=p.useTresContext(),{pixelRatio:s}=O.useDevicePixelRatio(),i=n.computed(()=>t.width??a.width.value*s.value),r=n.computed(()=>t.height??a.height.value*s.value),{pass:d}=A(()=>new xe(i.value,r.value),t);return e({pass:d}),n.watchEffect(()=>{d.value.setSize(i.value,r.value)}),()=>{}}}),Y={name:"LuminosityHighPassShader",shaderID:"luminosityHighPass",uniforms:{tDiffuse:{value:null},luminosityThreshold:{value:1},smoothWidth:{value:1},defaultColor:{value:new o.Color(0)},defaultOpacity:{value:0}},vertexShader:`
|
|
1149
|
+
}`};class Xe extends S{constructor(t,e){super(),this.edgesRT=new n.WebGLRenderTarget(t,e,{depthBuffer:!1,type:n.HalfFloatType}),this.edgesRT.texture.name="SMAAPass.edges",this.weightsRT=new n.WebGLRenderTarget(t,e,{depthBuffer:!1,type:n.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 n.Texture,this.areaTexture.name="SMAAPass.area",this.areaTexture.image=a,this.areaTexture.minFilter=n.LinearFilter,this.areaTexture.generateMipmaps=!1,this.areaTexture.flipY=!1;const s=new Image;s.src=this.getSearchTexture(),s.onload=function(){o.searchTexture.needsUpdate=!0},this.searchTexture=new n.Texture,this.searchTexture.name="SMAAPass.search",this.searchTexture.image=s,this.searchTexture.magFilter=n.NearestFilter,this.searchTexture.minFilter=n.NearestFilter,this.searchTexture.generateMipmaps=!1,this.searchTexture.flipY=!1,this.uniformsEdges=n.UniformsUtils.clone(L.uniforms),this.uniformsEdges.resolution.value.set(1/t,1/e),this.materialEdges=new n.ShaderMaterial({defines:Object.assign({},L.defines),uniforms:this.uniformsEdges,vertexShader:L.vertexShader,fragmentShader:L.fragmentShader}),this.uniformsWeights=n.UniformsUtils.clone(R.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 n.ShaderMaterial({defines:Object.assign({},R.defines),uniforms:this.uniformsWeights,vertexShader:R.vertexShader,fragmentShader:R.fragmentShader}),this.uniformsBlend=n.UniformsUtils.clone(N.uniforms),this.uniformsBlend.resolution.value.set(1/t,1/e),this.uniformsBlend.tDiffuse.value=this.weightsRT.texture,this.materialBlend=new n.ShaderMaterial({uniforms:this.uniformsBlend,vertexShader:N.vertexShader,fragmentShader:N.fragmentShader}),this.fsQuad=new y(null)}render(t,e,o){this.uniformsEdges.tDiffuse.value=o.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=o.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 Ie=r.defineComponent({__name:"SMAA",props:{width:{},height:{}},setup(i,{expose:t}){const e=i,{sizes:o}=g.useTresContext(),{pixelRatio:a}=U.useDevicePixelRatio(),s=r.computed(()=>e.width??o.width.value*a.value),l=r.computed(()=>e.height??o.height.value*a.value),{pass:d}=T(()=>new Xe(s.value,l.value),e);return t({pass:d}),r.watchEffect(()=>{d.value.setSize(s.value,l.value)}),()=>{}}}),K={name:"LuminosityHighPassShader",shaderID:"luminosityHighPass",uniforms:{tDiffuse:{value:null},luminosityThreshold:{value:1},smoothWidth:{value:1},defaultColor:{value:new n.Color(0)},defaultOpacity:{value:0}},vertexShader:`
|
|
928
1150
|
|
|
929
1151
|
varying vec2 vUv;
|
|
930
1152
|
|
|
@@ -956,7 +1178,7 @@
|
|
|
956
1178
|
|
|
957
1179
|
gl_FragColor = mix( outputColor, texel, alpha );
|
|
958
1180
|
|
|
959
|
-
}`};class M extends
|
|
1181
|
+
}`};class M extends S{constructor(t,e,o,a){super(),this.strength=e!==void 0?e:1,this.radius=o,this.threshold=a,this.resolution=t!==void 0?new n.Vector2(t.x,t.y):new n.Vector2(256,256),this.clearColor=new n.Color(0,0,0),this.renderTargetsHorizontal=[],this.renderTargetsVertical=[],this.nMips=5;let s=Math.round(this.resolution.x/2),l=Math.round(this.resolution.y/2);this.renderTargetBright=new n.WebGLRenderTarget(s,l,{type:n.HalfFloatType}),this.renderTargetBright.texture.name="UnrealBloomPass.bright",this.renderTargetBright.texture.generateMipmaps=!1;for(let x=0;x<this.nMips;x++){const p=new n.WebGLRenderTarget(s,l,{type:n.HalfFloatType});p.texture.name="UnrealBloomPass.h"+x,p.texture.generateMipmaps=!1,this.renderTargetsHorizontal.push(p);const A=new n.WebGLRenderTarget(s,l,{type:n.HalfFloatType});A.texture.name="UnrealBloomPass.v"+x,A.texture.generateMipmaps=!1,this.renderTargetsVertical.push(A),s=Math.round(s/2),l=Math.round(l/2)}const d=K;this.highPassUniforms=n.UniformsUtils.clone(d.uniforms),this.highPassUniforms.luminosityThreshold.value=a,this.highPassUniforms.smoothWidth.value=.01,this.materialHighPassFilter=new n.ShaderMaterial({uniforms:this.highPassUniforms,vertexShader:d.vertexShader,fragmentShader:d.fragmentShader}),this.separableBlurMaterials=[];const f=[3,5,7,9,11];s=Math.round(this.resolution.x/2),l=Math.round(this.resolution.y/2);for(let x=0;x<this.nMips;x++)this.separableBlurMaterials.push(this.getSeparableBlurMaterial(f[x])),this.separableBlurMaterials[x].uniforms.invSize.value=new n.Vector2(1/s,1/l),s=Math.round(s/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=e,this.compositeMaterial.uniforms.bloomRadius.value=.1;const w=[1,.8,.6,.4,.2];this.compositeMaterial.uniforms.bloomFactors.value=w,this.bloomTintColors=[new n.Vector3(1,1,1),new n.Vector3(1,1,1),new n.Vector3(1,1,1),new n.Vector3(1,1,1),new n.Vector3(1,1,1)],this.compositeMaterial.uniforms.bloomTintColors.value=this.bloomTintColors;const h=j;this.copyUniforms=n.UniformsUtils.clone(h.uniforms),this.blendMaterial=new n.ShaderMaterial({uniforms:this.copyUniforms,vertexShader:h.vertexShader,fragmentShader:h.fragmentShader,blending:n.AdditiveBlending,depthTest:!1,depthWrite:!1,transparent:!0}),this.enabled=!0,this.needsSwap=!1,this._oldClearColor=new n.Color,this.oldClearAlpha=1,this.basic=new n.MeshBasicMaterial,this.fsQuad=new y(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 o=Math.round(t/2),a=Math.round(e/2);this.renderTargetBright.setSize(o,a);for(let s=0;s<this.nMips;s++)this.renderTargetsHorizontal[s].setSize(o,a),this.renderTargetsVertical[s].setSize(o,a),this.separableBlurMaterials[s].uniforms.invSize.value=new n.Vector2(1/o,1/a),o=Math.round(o/2),a=Math.round(a/2)}render(t,e,o,a,s){t.getClearColor(this._oldClearColor),this.oldClearAlpha=t.getClearAlpha();const l=t.autoClear;t.autoClear=!1,t.setClearColor(this.clearColor,0),s&&t.state.buffers.stencil.setTest(!1),this.renderToScreen&&(this.fsQuad.material=this.basic,this.basic.map=o.texture,t.setRenderTarget(null),t.clear(),this.fsQuad.render(t)),this.highPassUniforms.tDiffuse.value=o.texture,this.highPassUniforms.luminosityThreshold.value=this.threshold,this.fsQuad.material=this.materialHighPassFilter,t.setRenderTarget(this.renderTargetBright),t.clear(),this.fsQuad.render(t);let d=this.renderTargetBright;for(let f=0;f<this.nMips;f++)this.fsQuad.material=this.separableBlurMaterials[f],this.separableBlurMaterials[f].uniforms.colorTexture.value=d.texture,this.separableBlurMaterials[f].uniforms.direction.value=M.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=M.BlurDirectionY,t.setRenderTarget(this.renderTargetsVertical[f]),t.clear(),this.fsQuad.render(t),d=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,s&&t.state.buffers.stencil.setTest(!0),this.renderToScreen?(t.setRenderTarget(null),this.fsQuad.render(t)):(t.setRenderTarget(o),this.fsQuad.render(t)),t.setClearColor(this._oldClearColor,this.oldClearAlpha),t.autoClear=l}getSeparableBlurMaterial(t){const e=[];for(let o=0;o<t;o++)e.push(.39894*Math.exp(-.5*o*o/(t*t))/t);return new n.ShaderMaterial({defines:{KERNEL_RADIUS:t},uniforms:{colorTexture:{value:null},invSize:{value:new n.Vector2(.5,.5)},direction:{value:new n.Vector2(.5,.5)},gaussianCoefficients:{value:e}},vertexShader:`varying vec2 vUv;
|
|
960
1182
|
void main() {
|
|
961
1183
|
vUv = uv;
|
|
962
1184
|
gl_Position = projectionMatrix * modelViewMatrix * vec4( position, 1.0 );
|
|
@@ -980,7 +1202,7 @@
|
|
|
980
1202
|
weightSum += 2.0 * w;
|
|
981
1203
|
}
|
|
982
1204
|
gl_FragColor = vec4(diffuseSum/weightSum, 1.0);
|
|
983
|
-
}`})}getCompositeMaterial(
|
|
1205
|
+
}`})}getCompositeMaterial(t){return new n.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;
|
|
984
1206
|
void main() {
|
|
985
1207
|
vUv = uv;
|
|
986
1208
|
gl_Position = projectionMatrix * modelViewMatrix * vec4( position, 1.0 );
|
|
@@ -1006,4 +1228,4 @@
|
|
|
1006
1228
|
lerpBloomFactor(bloomFactors[2]) * vec4(bloomTintColors[2], 1.0) * texture2D(blurTexture3, vUv) +
|
|
1007
1229
|
lerpBloomFactor(bloomFactors[3]) * vec4(bloomTintColors[3], 1.0) * texture2D(blurTexture4, vUv) +
|
|
1008
1230
|
lerpBloomFactor(bloomFactors[4]) * vec4(bloomTintColors[4], 1.0) * texture2D(blurTexture5, vUv) );
|
|
1009
|
-
}`})}}M.BlurDirectionX=new
|
|
1231
|
+
}`})}}M.BlurDirectionX=new n.Vector2(1,0),M.BlurDirectionY=new n.Vector2(0,1);const je=r.defineComponent({__name:"UnrealBloom",props:{radius:{default:0},strength:{default:1},threshold:{default:0}},setup(i,{expose:t}){const e=i,{sizes:o}=g.useTresContext(),{pass:a}=T(()=>new M(new n.Vector2(o.width.value,o.height.value),e.radius,e.strength,e.threshold),e);return t({pass:a}),r.watchEffect(()=>{var s;a.value.radius=e.radius??((s=a.value.getCompositeMaterial().uniforms.bloomRadius)==null?void 0:s.value)??.1}),r.watchEffect(()=>{var s;a.value.strength=e.strength??((s=a.value.getCompositeMaterial().uniforms.bloomStrength)==null?void 0:s.value)??1}),r.watchEffect(()=>{var s;a.value.threshold=e.threshold??((s=K.uniforms.luminosityThreshold)==null?void 0:s.value)??1}),()=>{}}});u.BarrelBlurPmndrs=ie,u.BloomPmndrs=$,u.BrightnessContrastPmndrs=Me,u.ChromaticAberrationPmndrs=le,u.ColorAveragePmndrs=he,u.ColorDepthPmndrs=Ae,u.DepthOfFieldPmndrs=ee,u.DepthPickingPassPmndrs=we,u.DotScreenPmndrs=ve,u.EffectComposer=Oe,u.EffectComposerPmndrs=_,u.FishEyePmndrs=Te,u.Glitch=Ne,u.GlitchPmndrs=te,u.GodRaysPmndrs=Se,u.GridPmndrs=ye,u.Halftone=ze,u.HueSaturationPmndrs=ce,u.KuwaharaPmndrs=fe,u.LensDistortionPmndrs=me,u.LinocutPmndrs=be,u.NoisePmndrs=oe,u.OutlinePmndrs=ae,u.Output=Ve,u.Pixelation=We,u.PixelationPmndrs=se,u.SMAA=Ie,u.ScanlinePmndrs=de,u.SepiaPmndrs=xe,u.ShockWavePmndrs=pe,u.TiltShiftPmndrs=ge,u.ToneMappingPmndrs=re,u.UnrealBloom=je,u.VignettePmndrs=ne,u.useEffect=T,u.useEffectPmndrs=m,Object.defineProperty(u,Symbol.toStringTag,{value:"Module"})});
|