@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.
- package/dist/core/pmndrs/ASCIIPmndrs.vue.d.ts +40 -0
- package/dist/core/pmndrs/FXAAPmndrs.vue.d.ts +32 -0
- package/dist/core/pmndrs/SMAAPmndrs.vue.d.ts +42 -0
- package/dist/core/pmndrs/TexturePmndrs.vue.d.ts +21 -0
- package/dist/core/pmndrs/index.d.ts +5 -1
- package/dist/tres-post-processing.js +1049 -850
- package/dist/tres-post-processing.umd.cjs +17 -17
- package/package.json +2 -2
|
@@ -1,28 +1,28 @@
|
|
|
1
1
|
/**
|
|
2
2
|
* name: @tresjs/post-processing
|
|
3
|
-
* version: v2.
|
|
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
|
-
import { defineComponent as u, shallowRef as
|
|
9
|
-
import { EffectComposer as
|
|
10
|
-
import { useTresContext as y, useLoop as
|
|
11
|
-
import { HalfFloatType as
|
|
12
|
-
import { useDevicePixelRatio as
|
|
13
|
-
class
|
|
8
|
+
import { defineComponent as u, shallowRef as H, provide as He, computed as O, watch as g, onUnmounted as W, renderSlot as Ie, inject as J, watchEffect as w, nextTick as ce, toRaw as fe } from "vue";
|
|
9
|
+
import { EffectComposer as he, RenderPass as Je, NormalPass as Ze, DepthDownsamplingPass as _e, EffectPass as Xe, BloomEffect as pe, DepthOfFieldEffect as me, GlitchEffect as j, GlitchMode as $e, NoiseEffect as ve, OutlineEffect as ge, PixelationEffect as xe, VignetteEffect as be, Effect as Z, BlendFunction as _, ToneMappingEffect as Se, ChromaticAberrationEffect as ee, HueSaturationEffect as we, ScanlineEffect as te, ColorAverageEffect as oe, LensDistortionEffect as Ae, ShockWaveEffect as ye, TiltShiftEffect as Me, DotScreenEffect as Te, SepiaEffect as Ce, DepthPickingPass as et, GodRaysEffect as se, ColorDepthEffect as V, GridEffect as Ee, BrightnessContrastEffect as Pe, SMAAEffect as ae, TextureEffect as q, FXAAEffect as re, ASCIIEffect as ne, ASCIITexture as tt } from "postprocessing";
|
|
10
|
+
import { useTresContext as y, useLoop as I, normalizeColor as ie } from "@tresjs/core";
|
|
11
|
+
import { HalfFloatType as P, Uniform as C, Vector2 as f, Vector3 as B, Mesh as je, SphereGeometry as ot, MeshBasicMaterial as Ve, OrthographicCamera as st, BufferGeometry as at, Float32BufferAttribute as De, ShaderMaterial as T, UniformsUtils as L, WebGLRenderTarget as F, NoBlending as rt, Clock as nt, Color as K, MathUtils as M, DataTexture as it, RedFormat as lt, FloatType as ut, MeshNormalMaterial as ct, NearestFilter as N, DepthTexture as dt, Vector4 as ft, RawShaderMaterial as ht, ColorManagement as pt, SRGBTransfer as mt, LinearToneMapping as vt, ReinhardToneMapping as gt, CineonToneMapping as xt, ACESFilmicToneMapping as bt, AgXToneMapping as St, NeutralToneMapping as wt, CustomToneMapping as At, Texture as Le, LinearFilter as yt, AdditiveBlending as Mt } from "three";
|
|
12
|
+
import { useDevicePixelRatio as Ye } from "@vueuse/core";
|
|
13
|
+
class Fe {
|
|
14
14
|
static isWebGL2Available() {
|
|
15
15
|
try {
|
|
16
|
-
const
|
|
17
|
-
return !!(window.WebGL2RenderingContext &&
|
|
16
|
+
const t = document.createElement("canvas");
|
|
17
|
+
return !!(window.WebGL2RenderingContext && t.getContext("webgl2"));
|
|
18
18
|
} catch {
|
|
19
19
|
return !1;
|
|
20
20
|
}
|
|
21
21
|
}
|
|
22
|
-
static isColorSpaceAvailable(
|
|
22
|
+
static isColorSpaceAvailable(t) {
|
|
23
23
|
try {
|
|
24
|
-
const
|
|
25
|
-
return o.drawingBufferColorSpace =
|
|
24
|
+
const e = document.createElement("canvas"), o = window.WebGL2RenderingContext && e.getContext("webgl2");
|
|
25
|
+
return o.drawingBufferColorSpace = t, o.drawingBufferColorSpace === t;
|
|
26
26
|
} catch {
|
|
27
27
|
return !1;
|
|
28
28
|
}
|
|
@@ -30,8 +30,8 @@ class Te {
|
|
|
30
30
|
static getWebGL2ErrorMessage() {
|
|
31
31
|
return this.getErrorMessage(2);
|
|
32
32
|
}
|
|
33
|
-
static getErrorMessage(
|
|
34
|
-
const
|
|
33
|
+
static getErrorMessage(t) {
|
|
34
|
+
const e = {
|
|
35
35
|
1: "WebGL",
|
|
36
36
|
2: "WebGL 2"
|
|
37
37
|
}, o = {
|
|
@@ -40,14 +40,14 @@ class Te {
|
|
|
40
40
|
};
|
|
41
41
|
let s = 'Your $0 does not seem to support <a href="http://khronos.org/webgl/wiki/Getting_a_WebGL_Implementation" style="color:#000">$1</a>';
|
|
42
42
|
const a = document.createElement("div");
|
|
43
|
-
return a.id = "webglmessage", a.style.fontFamily = "monospace", a.style.fontSize = "13px", a.style.fontWeight = "normal", a.style.textAlign = "center", a.style.background = "#fff", a.style.color = "#000", a.style.padding = "1.5em", a.style.width = "400px", a.style.margin = "5em auto 0", o[
|
|
43
|
+
return a.id = "webglmessage", a.style.fontFamily = "monospace", a.style.fontSize = "13px", a.style.fontWeight = "normal", a.style.textAlign = "center", a.style.background = "#fff", a.style.color = "#000", a.style.padding = "1.5em", a.style.width = "400px", a.style.margin = "5em auto 0", o[t] ? s = s.replace("$0", "graphics card") : s = s.replace("$0", "browser"), s = s.replace("$1", e[t]), a.innerHTML = s, a;
|
|
44
44
|
}
|
|
45
45
|
// @deprecated, r168
|
|
46
46
|
static isWebGLAvailable() {
|
|
47
47
|
console.warn("isWebGLAvailable() has been deprecated and will be removed in r178. Use isWebGL2Available() instead.");
|
|
48
48
|
try {
|
|
49
|
-
const
|
|
50
|
-
return !!(window.WebGLRenderingContext && (
|
|
49
|
+
const t = document.createElement("canvas");
|
|
50
|
+
return !!(window.WebGLRenderingContext && (t.getContext("webgl") || t.getContext("experimental-webgl")));
|
|
51
51
|
} catch {
|
|
52
52
|
return !1;
|
|
53
53
|
}
|
|
@@ -56,7 +56,7 @@ class Te {
|
|
|
56
56
|
return console.warn("getWebGLErrorMessage() has been deprecated and will be removed in r178. Use getWebGL2ErrorMessage() instead."), this.getErrorMessage(1);
|
|
57
57
|
}
|
|
58
58
|
}
|
|
59
|
-
const
|
|
59
|
+
const $ = Symbol("effectComposerPmndrs"), Yt = /* @__PURE__ */ u({
|
|
60
60
|
__name: "EffectComposerPmndrs",
|
|
61
61
|
props: {
|
|
62
62
|
enabled: { type: Boolean, default: !0 },
|
|
@@ -66,109 +66,109 @@ const se = Symbol("effectComposerPmndrs"), Gt = /* @__PURE__ */ u({
|
|
|
66
66
|
resolutionScale: {},
|
|
67
67
|
autoClear: { type: Boolean, default: !0 },
|
|
68
68
|
multisampling: { default: 0 },
|
|
69
|
-
frameBufferType: { default:
|
|
69
|
+
frameBufferType: { default: P }
|
|
70
70
|
},
|
|
71
71
|
emits: ["render"],
|
|
72
|
-
setup(
|
|
73
|
-
const o =
|
|
74
|
-
let
|
|
75
|
-
|
|
76
|
-
const
|
|
77
|
-
|
|
72
|
+
setup(n, { expose: t, emit: e }) {
|
|
73
|
+
const o = n, s = e, { scene: a, camera: r, renderer: i, sizes: l, render: d } = y(), p = H(null);
|
|
74
|
+
let b = null, c = null;
|
|
75
|
+
He($, p), t({ composer: p });
|
|
76
|
+
const S = () => {
|
|
77
|
+
p.value && (c = new Ze(a.value, r.value), c.enabled = !1, p.value.addPass(c), o.resolutionScale !== void 0 && Fe.isWebGL2Available() && (b = new _e({
|
|
78
78
|
normalBuffer: c.texture,
|
|
79
79
|
resolutionScale: o.resolutionScale
|
|
80
|
-
}),
|
|
81
|
-
},
|
|
82
|
-
const
|
|
83
|
-
depthBuffer: o.depthBuffer !== void 0 ? o.depthBuffer :
|
|
84
|
-
stencilBuffer: o.stencilBuffer !== void 0 ? o.stencilBuffer :
|
|
85
|
-
multisampling:
|
|
86
|
-
frameBufferType: o.frameBufferType !== void 0 ? o.frameBufferType :
|
|
80
|
+
}), b.enabled = !1, p.value.addPass(b)));
|
|
81
|
+
}, m = O(() => {
|
|
82
|
+
const x = new he(), G = {
|
|
83
|
+
depthBuffer: o.depthBuffer !== void 0 ? o.depthBuffer : x.inputBuffer.depthBuffer,
|
|
84
|
+
stencilBuffer: o.stencilBuffer !== void 0 ? o.stencilBuffer : x.inputBuffer.stencilBuffer,
|
|
85
|
+
multisampling: Fe.isWebGL2Available() ? o.multisampling !== void 0 ? o.multisampling : x.multisampling : 0,
|
|
86
|
+
frameBufferType: o.frameBufferType !== void 0 ? o.frameBufferType : P
|
|
87
87
|
};
|
|
88
|
-
return
|
|
89
|
-
}),
|
|
90
|
-
var
|
|
91
|
-
!
|
|
88
|
+
return x.dispose(), G;
|
|
89
|
+
}), A = () => {
|
|
90
|
+
var x;
|
|
91
|
+
!i.value && !a.value && !r.value || ((x = p.value) == null || x.dispose(), p.value = new he(i.value, m.value), p.value.addPass(new Je(a.value, r.value)), o.disableNormalPass || S());
|
|
92
92
|
};
|
|
93
|
-
|
|
94
|
-
!l.width.value || !l.height.value ||
|
|
95
|
-
}),
|
|
96
|
-
!
|
|
93
|
+
g([i, a, r, () => o.disableNormalPass], () => {
|
|
94
|
+
!l.width.value || !l.height.value || A();
|
|
95
|
+
}), g(() => [l.width.value, l.height.value], ([x, G]) => {
|
|
96
|
+
!x && !G || (p.value ? p.value.setSize(x, G) : A());
|
|
97
97
|
}, {
|
|
98
98
|
immediate: !0
|
|
99
99
|
});
|
|
100
|
-
const { render:
|
|
101
|
-
return
|
|
102
|
-
if (o.enabled &&
|
|
103
|
-
const
|
|
104
|
-
|
|
100
|
+
const { render: E } = I();
|
|
101
|
+
return E(() => {
|
|
102
|
+
if (o.enabled && i.value && p.value && l.width.value && l.height.value && d.frames.value > 0) {
|
|
103
|
+
const x = i.value.autoClear;
|
|
104
|
+
i.value.autoClear = o.autoClear, o.stencilBuffer && !o.autoClear && i.value.clearStencil(), p.value.render(), s("render", p.value), i.value.autoClear = x;
|
|
105
105
|
}
|
|
106
|
-
|
|
107
|
-
}),
|
|
108
|
-
var
|
|
109
|
-
(
|
|
110
|
-
}), (
|
|
111
|
-
}
|
|
112
|
-
}),
|
|
113
|
-
const o =
|
|
114
|
-
|
|
115
|
-
const
|
|
116
|
-
var c,
|
|
117
|
-
s.value && ((c = o == null ? void 0 : o.value) == null || c.removePass(s.value)), (
|
|
118
|
-
},
|
|
119
|
-
!
|
|
106
|
+
d.frames.value = d.mode.value === "always" ? 1 : Math.max(0, d.frames.value - 1);
|
|
107
|
+
}), W(() => {
|
|
108
|
+
var x;
|
|
109
|
+
(x = p.value) == null || x.dispose();
|
|
110
|
+
}), (x, G) => Ie(x.$slots, "default");
|
|
111
|
+
}
|
|
112
|
+
}), h = (n, t, e) => {
|
|
113
|
+
const o = J($), s = H(null), a = H(null), { scene: r, camera: i, invalidate: l } = y();
|
|
114
|
+
g(t, () => l());
|
|
115
|
+
const d = () => {
|
|
116
|
+
var c, S, m;
|
|
117
|
+
s.value && ((c = o == null ? void 0 : o.value) == null || c.removePass(s.value)), (S = a.value) == null || S.dispose(), (m = s.value) == null || m.dispose();
|
|
118
|
+
}, p = (c) => {
|
|
119
|
+
!i.value || !(o != null && o.value) || !r.value || (a.value = n(), s.value = new Xe(i.value, a.value), o.value.addPass(s.value, c));
|
|
120
120
|
};
|
|
121
|
-
|
|
122
|
-
() =>
|
|
121
|
+
e && g(
|
|
122
|
+
() => e.map((c) => t[c]),
|
|
123
123
|
() => {
|
|
124
|
-
var
|
|
124
|
+
var S;
|
|
125
125
|
if (!(o != null && o.value))
|
|
126
126
|
return;
|
|
127
|
-
const c = (
|
|
128
|
-
~c && (
|
|
127
|
+
const c = (S = o.value) == null ? void 0 : S.passes.findIndex((m) => m === s.value);
|
|
128
|
+
~c && (d(), p(c));
|
|
129
129
|
}
|
|
130
|
-
),
|
|
131
|
-
!
|
|
130
|
+
), w(() => {
|
|
131
|
+
!i.value || !(a != null && a.value) || (a.value.mainCamera = i.value);
|
|
132
132
|
});
|
|
133
|
-
const
|
|
134
|
-
!
|
|
133
|
+
const b = w(() => {
|
|
134
|
+
!i.value || !(o != null && o.value) || !r.value || (ce(() => b()), !a.value && p());
|
|
135
135
|
});
|
|
136
|
-
return
|
|
137
|
-
|
|
136
|
+
return W(() => {
|
|
137
|
+
d();
|
|
138
138
|
}), {
|
|
139
139
|
pass: s,
|
|
140
140
|
effect: a
|
|
141
141
|
};
|
|
142
|
-
},
|
|
143
|
-
if (!
|
|
142
|
+
}, ke = /([^[.\]])+/g, Tt = (n, t) => {
|
|
143
|
+
if (!t)
|
|
144
144
|
return;
|
|
145
|
-
const
|
|
146
|
-
return
|
|
147
|
-
},
|
|
148
|
-
const o = Array.isArray(
|
|
149
|
-
o && o.reduce((s, a,
|
|
150
|
-
},
|
|
151
|
-
const
|
|
152
|
-
return
|
|
153
|
-
},
|
|
154
|
-
var
|
|
155
|
-
if (
|
|
145
|
+
const e = Array.isArray(t) ? t : t.match(ke);
|
|
146
|
+
return e == null ? void 0 : e.reduce((o, s) => o && o[s], n);
|
|
147
|
+
}, Oe = (n, t, e) => {
|
|
148
|
+
const o = Array.isArray(t) ? t : t.match(ke);
|
|
149
|
+
o && o.reduce((s, a, r) => (s[a] === void 0 && (s[a] = {}), r === o.length - 1 && (s[a] = e), s[a]), n);
|
|
150
|
+
}, Ct = (n, t) => {
|
|
151
|
+
const e = { ...n };
|
|
152
|
+
return t.forEach((o) => delete e[o]), e;
|
|
153
|
+
}, X = (n, t, e, o, s = {}) => g(n, (a) => {
|
|
154
|
+
var r;
|
|
155
|
+
if (t.value)
|
|
156
156
|
if (a === void 0) {
|
|
157
|
-
const
|
|
158
|
-
|
|
157
|
+
const i = o();
|
|
158
|
+
Oe(t.value, e, Tt(i, e)), (r = i.dispose) == null || r.call(i);
|
|
159
159
|
} else
|
|
160
|
-
|
|
161
|
-
}, s),
|
|
160
|
+
Oe(t.value, e, n());
|
|
161
|
+
}, s), v = (n, t, e) => n.map(([o, s]) => X(
|
|
162
162
|
o,
|
|
163
|
-
|
|
163
|
+
t,
|
|
164
164
|
s,
|
|
165
|
-
|
|
166
|
-
)),
|
|
167
|
-
() =>
|
|
168
|
-
|
|
165
|
+
e
|
|
166
|
+
)), de = (n, t, e) => Object.keys(n).map((o) => X(
|
|
167
|
+
() => n[o],
|
|
168
|
+
t,
|
|
169
169
|
o,
|
|
170
|
-
|
|
171
|
-
)),
|
|
170
|
+
e
|
|
171
|
+
)), kt = /* @__PURE__ */ u({
|
|
172
172
|
__name: "BloomPmndrs",
|
|
173
173
|
props: {
|
|
174
174
|
blendFunction: {},
|
|
@@ -178,22 +178,22 @@ const se = Symbol("effectComposerPmndrs"), Gt = /* @__PURE__ */ u({
|
|
|
178
178
|
luminanceSmoothing: {},
|
|
179
179
|
mipmapBlur: { type: Boolean, default: void 0 }
|
|
180
180
|
},
|
|
181
|
-
setup(
|
|
182
|
-
const
|
|
183
|
-
return
|
|
181
|
+
setup(n, { expose: t }) {
|
|
182
|
+
const e = n, { pass: o, effect: s } = h(() => new pe(e), e, ["mipmapBlur"]);
|
|
183
|
+
return t({ pass: o, effect: s }), v(
|
|
184
184
|
[
|
|
185
|
-
[() =>
|
|
186
|
-
[() =>
|
|
187
|
-
[() =>
|
|
188
|
-
[() =>
|
|
189
|
-
[() =>
|
|
185
|
+
[() => e.blendFunction, "blendMode.blendFunction"],
|
|
186
|
+
[() => e.intensity, "intensity"],
|
|
187
|
+
[() => e.kernelSize, "kernelSize"],
|
|
188
|
+
[() => e.luminanceSmoothing, "luminanceMaterial.smoothing"],
|
|
189
|
+
[() => e.luminanceThreshold, "luminanceMaterial.threshold"]
|
|
190
190
|
],
|
|
191
191
|
s,
|
|
192
|
-
() => new
|
|
192
|
+
() => new pe()
|
|
193
193
|
), () => {
|
|
194
194
|
};
|
|
195
195
|
}
|
|
196
|
-
}),
|
|
196
|
+
}), qt = /* @__PURE__ */ u({
|
|
197
197
|
__name: "DepthOfFieldPmndrs",
|
|
198
198
|
props: {
|
|
199
199
|
blendFunction: {},
|
|
@@ -206,26 +206,26 @@ const se = Symbol("effectComposerPmndrs"), Gt = /* @__PURE__ */ u({
|
|
|
206
206
|
resolutionX: {},
|
|
207
207
|
resolutionY: {}
|
|
208
208
|
},
|
|
209
|
-
setup(
|
|
210
|
-
const
|
|
211
|
-
return
|
|
209
|
+
setup(n, { expose: t }) {
|
|
210
|
+
const e = n, { camera: o } = y(), { pass: s, effect: a } = h(() => new me(o.value, e), e);
|
|
211
|
+
return t({ pass: s, effect: a }), v(
|
|
212
212
|
[
|
|
213
|
-
[() =>
|
|
214
|
-
[() =>
|
|
215
|
-
[() =>
|
|
216
|
-
[() =>
|
|
217
|
-
[() =>
|
|
218
|
-
[() =>
|
|
219
|
-
[() =>
|
|
220
|
-
[() =>
|
|
221
|
-
[() =>
|
|
213
|
+
[() => e.blendFunction, "blendMode.blendFunction"],
|
|
214
|
+
[() => e.worldFocusDistance, "circleOfConfusionMaterial.worldFocusDistance"],
|
|
215
|
+
[() => e.focusDistance, "circleOfConfusionMaterial.focusDistance"],
|
|
216
|
+
[() => e.worldFocusRange, "circleOfConfusionMaterial.worldFocusRange"],
|
|
217
|
+
[() => e.focusRange, "circleOfConfusionMaterial.focusRange"],
|
|
218
|
+
[() => e.bokehScale, "bokehScale"],
|
|
219
|
+
[() => e.resolutionScale, "blurPass.resolution.scale"],
|
|
220
|
+
[() => e.resolutionX, "resolution.width"],
|
|
221
|
+
[() => e.resolutionY, "resolution.height"]
|
|
222
222
|
],
|
|
223
223
|
a,
|
|
224
|
-
() => new
|
|
224
|
+
() => new me()
|
|
225
225
|
), () => {
|
|
226
226
|
};
|
|
227
227
|
}
|
|
228
|
-
}),
|
|
228
|
+
}), Qt = /* @__PURE__ */ u({
|
|
229
229
|
__name: "GlitchPmndrs",
|
|
230
230
|
props: {
|
|
231
231
|
blendFunction: {},
|
|
@@ -240,51 +240,51 @@ const se = Symbol("effectComposerPmndrs"), Gt = /* @__PURE__ */ u({
|
|
|
240
240
|
perturbationMap: {},
|
|
241
241
|
dtSize: {}
|
|
242
242
|
},
|
|
243
|
-
setup(
|
|
244
|
-
const
|
|
245
|
-
|
|
246
|
-
const { onBeforeRender: a } =
|
|
247
|
-
return a(({ invalidate:
|
|
248
|
-
const
|
|
249
|
-
if (
|
|
250
|
-
return
|
|
251
|
-
const
|
|
252
|
-
return
|
|
243
|
+
setup(n, { expose: t }) {
|
|
244
|
+
const e = n, { pass: o, effect: s } = h(() => new j(e), e, ["dtSize"]);
|
|
245
|
+
t({ pass: o, effect: s });
|
|
246
|
+
const { onBeforeRender: a } = I();
|
|
247
|
+
return a(({ invalidate: r }) => r()), w(() => {
|
|
248
|
+
const r = () => {
|
|
249
|
+
if (e.mode !== void 0)
|
|
250
|
+
return e.active === !1 ? $e.DISABLED : e.mode;
|
|
251
|
+
const i = new j(), l = i.mode;
|
|
252
|
+
return i.dispose(), l;
|
|
253
253
|
};
|
|
254
|
-
s.value && (s.value.mode =
|
|
255
|
-
}),
|
|
256
|
-
() =>
|
|
254
|
+
s.value && (s.value.mode = r());
|
|
255
|
+
}), X(
|
|
256
|
+
() => e.blendFunction,
|
|
257
257
|
s,
|
|
258
258
|
"blendMode.blendFunction",
|
|
259
|
-
() => new
|
|
260
|
-
),
|
|
261
|
-
|
|
259
|
+
() => new j()
|
|
260
|
+
), de(
|
|
261
|
+
Ct(e, ["active", "blendFunction"]),
|
|
262
262
|
s,
|
|
263
|
-
() => new
|
|
263
|
+
() => new j()
|
|
264
264
|
), () => {
|
|
265
265
|
};
|
|
266
266
|
}
|
|
267
|
-
}),
|
|
267
|
+
}), Kt = /* @__PURE__ */ u({
|
|
268
268
|
__name: "NoisePmndrs",
|
|
269
269
|
props: {
|
|
270
270
|
premultiply: { type: Boolean, default: void 0 },
|
|
271
271
|
blendFunction: {}
|
|
272
272
|
},
|
|
273
|
-
setup(
|
|
274
|
-
const
|
|
275
|
-
|
|
276
|
-
const { onBeforeRender: a } =
|
|
277
|
-
return a(({ invalidate:
|
|
273
|
+
setup(n, { expose: t }) {
|
|
274
|
+
const e = n, { pass: o, effect: s } = h(() => new ve(e), e);
|
|
275
|
+
t({ pass: o, effect: s });
|
|
276
|
+
const { onBeforeRender: a } = I();
|
|
277
|
+
return a(({ invalidate: r }) => r()), v(
|
|
278
278
|
[
|
|
279
|
-
[() =>
|
|
280
|
-
[() =>
|
|
279
|
+
[() => e.blendFunction, "blendMode.blendFunction"],
|
|
280
|
+
[() => e.premultiply, "premultiply"]
|
|
281
281
|
],
|
|
282
282
|
s,
|
|
283
|
-
() => new
|
|
283
|
+
() => new ve()
|
|
284
284
|
), () => {
|
|
285
285
|
};
|
|
286
286
|
}
|
|
287
|
-
}),
|
|
287
|
+
}), Jt = /* @__PURE__ */ u({
|
|
288
288
|
__name: "OutlinePmndrs",
|
|
289
289
|
props: {
|
|
290
290
|
outlinedObjects: {},
|
|
@@ -303,83 +303,83 @@ const se = Symbol("effectComposerPmndrs"), Gt = /* @__PURE__ */ u({
|
|
|
303
303
|
hiddenEdgeColor: {},
|
|
304
304
|
visibleEdgeColor: {}
|
|
305
305
|
},
|
|
306
|
-
setup(
|
|
307
|
-
const
|
|
308
|
-
() => new
|
|
306
|
+
setup(n, { expose: t }) {
|
|
307
|
+
const e = n, o = (d) => d !== void 0 ? ie(d).getHex() : void 0, { camera: s, scene: a } = y(), { pass: r, effect: i } = h(
|
|
308
|
+
() => new ge(
|
|
309
309
|
a.value,
|
|
310
310
|
s.value,
|
|
311
311
|
{
|
|
312
|
-
blur:
|
|
313
|
-
xRay:
|
|
314
|
-
kernelSize:
|
|
315
|
-
pulseSpeed:
|
|
316
|
-
resolutionX:
|
|
317
|
-
resolutionY:
|
|
318
|
-
patternScale:
|
|
319
|
-
edgeStrength:
|
|
320
|
-
blendFunction:
|
|
321
|
-
multisampling:
|
|
322
|
-
patternTexture:
|
|
323
|
-
resolutionScale:
|
|
324
|
-
hiddenEdgeColor: o(
|
|
325
|
-
visibleEdgeColor: o(
|
|
312
|
+
blur: e.blur,
|
|
313
|
+
xRay: e.xRay,
|
|
314
|
+
kernelSize: e.kernelSize,
|
|
315
|
+
pulseSpeed: e.pulseSpeed,
|
|
316
|
+
resolutionX: e.resolutionX,
|
|
317
|
+
resolutionY: e.resolutionY,
|
|
318
|
+
patternScale: e.patternScale,
|
|
319
|
+
edgeStrength: e.edgeStrength,
|
|
320
|
+
blendFunction: e.blendFunction,
|
|
321
|
+
multisampling: e.multisampling,
|
|
322
|
+
patternTexture: e.patternTexture,
|
|
323
|
+
resolutionScale: e.resolutionScale,
|
|
324
|
+
hiddenEdgeColor: o(e.hiddenEdgeColor),
|
|
325
|
+
visibleEdgeColor: o(e.visibleEdgeColor)
|
|
326
326
|
// width and height are explicitly omitted, because they are deprecated in postprocessing's OutlineEffect
|
|
327
327
|
}
|
|
328
328
|
),
|
|
329
|
-
|
|
329
|
+
e
|
|
330
330
|
);
|
|
331
|
-
|
|
332
|
-
[() =>
|
|
331
|
+
t({ pass: r, effect: i }), g(
|
|
332
|
+
[() => e.outlinedObjects, i],
|
|
333
333
|
// watchEffect is intentionally not used here as it would result in an endless loop
|
|
334
334
|
() => {
|
|
335
|
-
var
|
|
336
|
-
(
|
|
335
|
+
var d;
|
|
336
|
+
(d = i.value) == null || d.selection.set(e.outlinedObjects || []);
|
|
337
337
|
},
|
|
338
338
|
{
|
|
339
339
|
immediate: !0
|
|
340
340
|
}
|
|
341
341
|
);
|
|
342
|
-
const l =
|
|
343
|
-
hiddenEdgeColor:
|
|
344
|
-
visibleEdgeColor:
|
|
342
|
+
const l = O(() => ({
|
|
343
|
+
hiddenEdgeColor: e.hiddenEdgeColor ? ie(e.hiddenEdgeColor) : void 0,
|
|
344
|
+
visibleEdgeColor: e.visibleEdgeColor ? ie(e.visibleEdgeColor) : void 0
|
|
345
345
|
}));
|
|
346
|
-
return
|
|
346
|
+
return v(
|
|
347
347
|
[
|
|
348
|
-
[() =>
|
|
349
|
-
[() =>
|
|
350
|
-
[() =>
|
|
351
|
-
[() =>
|
|
352
|
-
[() =>
|
|
353
|
-
[() =>
|
|
354
|
-
[() =>
|
|
355
|
-
[() =>
|
|
356
|
-
[() =>
|
|
357
|
-
[() =>
|
|
358
|
-
[() =>
|
|
359
|
-
[() =>
|
|
348
|
+
[() => e.blendFunction, "blendMode.blendFunction"],
|
|
349
|
+
[() => e.blur, "blur"],
|
|
350
|
+
[() => e.xRay, "xRay"],
|
|
351
|
+
[() => e.pulseSpeed, "pulseSpeed"],
|
|
352
|
+
[() => e.kernelSize, "kernelSize"],
|
|
353
|
+
[() => e.edgeStrength, "edgeStrength"],
|
|
354
|
+
[() => e.patternScale, "patternScale"],
|
|
355
|
+
[() => e.multisampling, "multisampling"],
|
|
356
|
+
[() => e.resolutionX, "resolution.width"],
|
|
357
|
+
[() => e.resolutionY, "resolution.height"],
|
|
358
|
+
[() => e.patternTexture, "patternTexture"],
|
|
359
|
+
[() => e.resolutionScale, "resolution.scale"],
|
|
360
360
|
[() => l.value.hiddenEdgeColor, "hiddenEdgeColor"],
|
|
361
361
|
[() => l.value.visibleEdgeColor, "visibleEdgeColor"]
|
|
362
362
|
],
|
|
363
|
-
|
|
364
|
-
() => new
|
|
363
|
+
i,
|
|
364
|
+
() => new ge()
|
|
365
365
|
), () => {
|
|
366
366
|
};
|
|
367
367
|
}
|
|
368
|
-
}),
|
|
368
|
+
}), Zt = /* @__PURE__ */ u({
|
|
369
369
|
__name: "PixelationPmndrs",
|
|
370
370
|
props: {
|
|
371
371
|
granularity: {}
|
|
372
372
|
},
|
|
373
|
-
setup(
|
|
374
|
-
const
|
|
375
|
-
return
|
|
376
|
-
|
|
373
|
+
setup(n, { expose: t }) {
|
|
374
|
+
const e = n, { pass: o, effect: s } = h(() => new xe(e.granularity), e);
|
|
375
|
+
return t({ pass: o, effect: s }), de(
|
|
376
|
+
e,
|
|
377
377
|
s,
|
|
378
|
-
() => new
|
|
378
|
+
() => new xe()
|
|
379
379
|
), () => {
|
|
380
380
|
};
|
|
381
381
|
}
|
|
382
|
-
}),
|
|
382
|
+
}), _t = /* @__PURE__ */ u({
|
|
383
383
|
__name: "VignettePmndrs",
|
|
384
384
|
props: {
|
|
385
385
|
technique: {},
|
|
@@ -387,22 +387,22 @@ const se = Symbol("effectComposerPmndrs"), Gt = /* @__PURE__ */ u({
|
|
|
387
387
|
offset: {},
|
|
388
388
|
darkness: {}
|
|
389
389
|
},
|
|
390
|
-
setup(
|
|
391
|
-
const
|
|
392
|
-
return
|
|
390
|
+
setup(n, { expose: t }) {
|
|
391
|
+
const e = n, { pass: o, effect: s } = h(() => new be(e), e);
|
|
392
|
+
return t({ pass: o, effect: s }), v(
|
|
393
393
|
[
|
|
394
|
-
[() =>
|
|
395
|
-
[() =>
|
|
396
|
-
[() =>
|
|
397
|
-
[() =>
|
|
394
|
+
[() => e.blendFunction, "blendMode.blendFunction"],
|
|
395
|
+
[() => e.offset, "offset"],
|
|
396
|
+
[() => e.darkness, "darkness"],
|
|
397
|
+
[() => e.technique, "technique"]
|
|
398
398
|
],
|
|
399
399
|
s,
|
|
400
|
-
() => new
|
|
400
|
+
() => new be()
|
|
401
401
|
), () => {
|
|
402
402
|
};
|
|
403
403
|
}
|
|
404
404
|
});
|
|
405
|
-
class
|
|
405
|
+
class Be extends Z {
|
|
406
406
|
/**
|
|
407
407
|
* Creates a new BarrelBlurEffect instance.
|
|
408
408
|
*
|
|
@@ -412,7 +412,7 @@ class Ee extends q {
|
|
|
412
412
|
* @param {Vector2} [options.offset] - Offset of the barrel distortion center (0 to 1 for both x and y). This allows you to change the position of the distortion effect.
|
|
413
413
|
*
|
|
414
414
|
*/
|
|
415
|
-
constructor({ blendFunction:
|
|
415
|
+
constructor({ blendFunction: t = _.NORMAL, amount: e = 0.15, offset: o = new f(0.5, 0.5) } = {}) {
|
|
416
416
|
super("BarrelBlurEffect", `
|
|
417
417
|
uniform float amount;
|
|
418
418
|
uniform vec2 offset;
|
|
@@ -458,11 +458,11 @@ class Ee extends q {
|
|
|
458
458
|
outputColor = vec4(outcol, inputColor.a); // Preserves original alpha
|
|
459
459
|
}
|
|
460
460
|
`, {
|
|
461
|
-
blendFunction:
|
|
461
|
+
blendFunction: t,
|
|
462
462
|
uniforms: /* @__PURE__ */ new Map([
|
|
463
|
-
["amount", new
|
|
463
|
+
["amount", new C(e)],
|
|
464
464
|
// Uniform controlling the intensity of distortion
|
|
465
|
-
["offset", new
|
|
465
|
+
["offset", new C(o)]
|
|
466
466
|
// Uniform controlling the offset of distortion
|
|
467
467
|
])
|
|
468
468
|
});
|
|
@@ -473,11 +473,11 @@ class Ee extends q {
|
|
|
473
473
|
* @type {number}
|
|
474
474
|
*/
|
|
475
475
|
get amount() {
|
|
476
|
-
var
|
|
477
|
-
return (
|
|
476
|
+
var t;
|
|
477
|
+
return (t = this.uniforms.get("amount")) == null ? void 0 : t.value;
|
|
478
478
|
}
|
|
479
|
-
set amount(
|
|
480
|
-
this.uniforms.get("amount").value =
|
|
479
|
+
set amount(t) {
|
|
480
|
+
this.uniforms.get("amount").value = t;
|
|
481
481
|
}
|
|
482
482
|
/**
|
|
483
483
|
* The offset.
|
|
@@ -485,40 +485,40 @@ class Ee extends q {
|
|
|
485
485
|
* @type {Vector2}
|
|
486
486
|
*/
|
|
487
487
|
get offset() {
|
|
488
|
-
var
|
|
489
|
-
return (
|
|
488
|
+
var t;
|
|
489
|
+
return (t = this.uniforms.get("offset")) == null ? void 0 : t.value;
|
|
490
490
|
}
|
|
491
|
-
set offset(
|
|
492
|
-
this.uniforms.get("offset").value =
|
|
491
|
+
set offset(t) {
|
|
492
|
+
this.uniforms.get("offset").value = t;
|
|
493
493
|
}
|
|
494
494
|
}
|
|
495
|
-
const
|
|
495
|
+
const $t = /* @__PURE__ */ u({
|
|
496
496
|
__name: "BarrelBlurPmndrs",
|
|
497
497
|
props: {
|
|
498
498
|
blendFunction: {},
|
|
499
499
|
amount: {},
|
|
500
500
|
offset: {}
|
|
501
501
|
},
|
|
502
|
-
setup(
|
|
503
|
-
const
|
|
504
|
-
() => new
|
|
505
|
-
...
|
|
506
|
-
offset: Array.isArray(
|
|
502
|
+
setup(n, { expose: t }) {
|
|
503
|
+
const e = n, { pass: o, effect: s } = h(
|
|
504
|
+
() => new Be({
|
|
505
|
+
...e,
|
|
506
|
+
offset: Array.isArray(e.offset) ? new f(...e.offset) : e.offset
|
|
507
507
|
}),
|
|
508
|
-
|
|
508
|
+
e
|
|
509
509
|
);
|
|
510
|
-
return
|
|
510
|
+
return t({ pass: o, effect: s }), v(
|
|
511
511
|
[
|
|
512
|
-
[() =>
|
|
513
|
-
[() =>
|
|
514
|
-
[() =>
|
|
512
|
+
[() => e.blendFunction, "blendMode.blendFunction"],
|
|
513
|
+
[() => e.amount, "amount"],
|
|
514
|
+
[() => e.offset, "offset"]
|
|
515
515
|
],
|
|
516
516
|
s,
|
|
517
|
-
() => new
|
|
517
|
+
() => new Be()
|
|
518
518
|
), () => {
|
|
519
519
|
};
|
|
520
520
|
}
|
|
521
|
-
}),
|
|
521
|
+
}), eo = /* @__PURE__ */ u({
|
|
522
522
|
__name: "ToneMappingPmndrs",
|
|
523
523
|
props: {
|
|
524
524
|
mode: {},
|
|
@@ -529,24 +529,24 @@ const qt = /* @__PURE__ */ u({
|
|
|
529
529
|
minLuminance: {},
|
|
530
530
|
whitePoint: {}
|
|
531
531
|
},
|
|
532
|
-
setup(
|
|
533
|
-
const
|
|
534
|
-
return
|
|
532
|
+
setup(n, { expose: t }) {
|
|
533
|
+
const e = n, { pass: o, effect: s } = h(() => new Se(e), e);
|
|
534
|
+
return t({ pass: o, effect: s }), v(
|
|
535
535
|
[
|
|
536
|
-
[() =>
|
|
537
|
-
[() =>
|
|
538
|
-
[() =>
|
|
539
|
-
[() =>
|
|
540
|
-
[() =>
|
|
541
|
-
[() =>
|
|
542
|
-
[() =>
|
|
536
|
+
[() => e.mode, "mode"],
|
|
537
|
+
[() => e.blendFunction, "blendMode.blendFunction"],
|
|
538
|
+
[() => e.resolution, "resolution"],
|
|
539
|
+
[() => e.averageLuminance, "averageLuminance"],
|
|
540
|
+
[() => e.middleGrey, "middleGrey"],
|
|
541
|
+
[() => e.minLuminance, "adaptiveLuminanceMaterial.minLuminance"],
|
|
542
|
+
[() => e.whitePoint, "whitePoint"]
|
|
543
543
|
],
|
|
544
544
|
s,
|
|
545
|
-
() => new
|
|
545
|
+
() => new Se()
|
|
546
546
|
), () => {
|
|
547
547
|
};
|
|
548
548
|
}
|
|
549
|
-
}),
|
|
549
|
+
}), to = /* @__PURE__ */ u({
|
|
550
550
|
__name: "ChromaticAberrationPmndrs",
|
|
551
551
|
props: {
|
|
552
552
|
blendFunction: {},
|
|
@@ -554,47 +554,47 @@ const qt = /* @__PURE__ */ u({
|
|
|
554
554
|
radialModulation: { type: Boolean, default: void 0 },
|
|
555
555
|
modulationOffset: {}
|
|
556
556
|
},
|
|
557
|
-
setup(
|
|
558
|
-
const
|
|
559
|
-
...
|
|
557
|
+
setup(n, { expose: t }) {
|
|
558
|
+
const e = n, o = new ee(), { pass: s, effect: a } = h(() => new ee({
|
|
559
|
+
...e,
|
|
560
560
|
// Unfortunately, these defaults must be set this way as the type in postprocessing is not correct.
|
|
561
561
|
// The arguments are optional in the actual constructor, but not in the type.
|
|
562
|
-
radialModulation:
|
|
563
|
-
modulationOffset:
|
|
564
|
-
}),
|
|
565
|
-
return o.dispose(),
|
|
562
|
+
radialModulation: e.radialModulation ?? o.radialModulation,
|
|
563
|
+
modulationOffset: e.modulationOffset ?? o.modulationOffset
|
|
564
|
+
}), e);
|
|
565
|
+
return o.dispose(), t({ pass: s, effect: a }), v(
|
|
566
566
|
[
|
|
567
|
-
[() =>
|
|
568
|
-
[() =>
|
|
569
|
-
[() =>
|
|
570
|
-
[() =>
|
|
567
|
+
[() => e.blendFunction, "blendMode.blendFunction"],
|
|
568
|
+
[() => e.offset, "offset"],
|
|
569
|
+
[() => e.radialModulation, "radialModulation"],
|
|
570
|
+
[() => e.modulationOffset, "modulationOffset"]
|
|
571
571
|
],
|
|
572
572
|
a,
|
|
573
|
-
() => new
|
|
573
|
+
() => new ee()
|
|
574
574
|
), () => {
|
|
575
575
|
};
|
|
576
576
|
}
|
|
577
|
-
}),
|
|
577
|
+
}), oo = /* @__PURE__ */ u({
|
|
578
578
|
__name: "HueSaturationPmndrs",
|
|
579
579
|
props: {
|
|
580
580
|
saturation: {},
|
|
581
581
|
hue: {},
|
|
582
582
|
blendFunction: {}
|
|
583
583
|
},
|
|
584
|
-
setup(
|
|
585
|
-
const
|
|
586
|
-
return
|
|
584
|
+
setup(n, { expose: t }) {
|
|
585
|
+
const e = n, { pass: o, effect: s } = h(() => new we(e), e);
|
|
586
|
+
return t({ pass: o, effect: s }), v(
|
|
587
587
|
[
|
|
588
|
-
[() =>
|
|
589
|
-
[() =>
|
|
590
|
-
[() =>
|
|
588
|
+
[() => e.blendFunction, "blendMode.blendFunction"],
|
|
589
|
+
[() => e.hue, "hue"],
|
|
590
|
+
[() => e.saturation, "saturation"]
|
|
591
591
|
],
|
|
592
592
|
s,
|
|
593
|
-
() => new
|
|
593
|
+
() => new we()
|
|
594
594
|
), () => {
|
|
595
595
|
};
|
|
596
596
|
}
|
|
597
|
-
}),
|
|
597
|
+
}), so = /* @__PURE__ */ u({
|
|
598
598
|
__name: "ScanlinePmndrs",
|
|
599
599
|
props: {
|
|
600
600
|
blendFunction: {},
|
|
@@ -602,25 +602,25 @@ const qt = /* @__PURE__ */ u({
|
|
|
602
602
|
scrollSpeed: {},
|
|
603
603
|
opacity: {}
|
|
604
604
|
},
|
|
605
|
-
setup(
|
|
606
|
-
const
|
|
607
|
-
return
|
|
605
|
+
setup(n, { expose: t }) {
|
|
606
|
+
const e = n, { pass: o, effect: s } = h(() => new te(e), e);
|
|
607
|
+
return t({ pass: o, effect: s }), v(
|
|
608
608
|
[
|
|
609
|
-
[() =>
|
|
610
|
-
[() =>
|
|
611
|
-
[() =>
|
|
609
|
+
[() => e.blendFunction, "blendMode.blendFunction"],
|
|
610
|
+
[() => e.density, "density"],
|
|
611
|
+
[() => e.scrollSpeed, "scrollSpeed"]
|
|
612
612
|
],
|
|
613
613
|
s,
|
|
614
|
-
() => new
|
|
615
|
-
),
|
|
616
|
-
[() =>
|
|
614
|
+
() => new te()
|
|
615
|
+
), g(
|
|
616
|
+
[() => e.opacity],
|
|
617
617
|
() => {
|
|
618
|
-
var a,
|
|
619
|
-
if (
|
|
620
|
-
(a = s.value) == null || a.blendMode.setOpacity(
|
|
618
|
+
var a, r;
|
|
619
|
+
if (e.opacity !== void 0)
|
|
620
|
+
(a = s.value) == null || a.blendMode.setOpacity(e.opacity);
|
|
621
621
|
else {
|
|
622
|
-
const
|
|
623
|
-
(
|
|
622
|
+
const i = new te();
|
|
623
|
+
(r = s.value) == null || r.blendMode.setOpacity(i.blendMode.getOpacity()), i.dispose();
|
|
624
624
|
}
|
|
625
625
|
},
|
|
626
626
|
{
|
|
@@ -629,7 +629,7 @@ const qt = /* @__PURE__ */ u({
|
|
|
629
629
|
), () => {
|
|
630
630
|
};
|
|
631
631
|
}
|
|
632
|
-
}),
|
|
632
|
+
}), Et = `
|
|
633
633
|
uniform float radius;
|
|
634
634
|
uniform int sectorCount;
|
|
635
635
|
|
|
@@ -726,7 +726,7 @@ void mainImage(const in vec4 inputColor, const in vec2 uv, out vec4 outputColor)
|
|
|
726
726
|
outputColor = vec4(finalColor, inputColor.a);
|
|
727
727
|
}
|
|
728
728
|
`;
|
|
729
|
-
class
|
|
729
|
+
class Re extends Z {
|
|
730
730
|
/**
|
|
731
731
|
* Creates a new KuwaharaEffect instance.
|
|
732
732
|
*
|
|
@@ -736,12 +736,12 @@ class Pe extends q {
|
|
|
736
736
|
* @param {number} [options.sectorCount] - Number of sectors.
|
|
737
737
|
*
|
|
738
738
|
*/
|
|
739
|
-
constructor({ blendFunction:
|
|
740
|
-
super("KuwaharaEffect",
|
|
741
|
-
blendFunction:
|
|
739
|
+
constructor({ blendFunction: t = _.NORMAL, radius: e = 1, sectorCount: o = 4 } = {}) {
|
|
740
|
+
super("KuwaharaEffect", Et, {
|
|
741
|
+
blendFunction: t,
|
|
742
742
|
uniforms: /* @__PURE__ */ new Map([
|
|
743
|
-
["radius", new
|
|
744
|
-
["sectorCount", new
|
|
743
|
+
["radius", new C(e)],
|
|
744
|
+
["sectorCount", new C(o)]
|
|
745
745
|
])
|
|
746
746
|
});
|
|
747
747
|
}
|
|
@@ -751,11 +751,11 @@ class Pe extends q {
|
|
|
751
751
|
* @type {number}
|
|
752
752
|
*/
|
|
753
753
|
get radius() {
|
|
754
|
-
var
|
|
755
|
-
return (
|
|
754
|
+
var t;
|
|
755
|
+
return (t = this.uniforms.get("radius")) == null ? void 0 : t.value;
|
|
756
756
|
}
|
|
757
|
-
set radius(
|
|
758
|
-
this.uniforms.get("radius").value =
|
|
757
|
+
set radius(t) {
|
|
758
|
+
this.uniforms.get("radius").value = t;
|
|
759
759
|
}
|
|
760
760
|
/**
|
|
761
761
|
* The sector count.
|
|
@@ -763,65 +763,65 @@ class Pe extends q {
|
|
|
763
763
|
* @type {number}
|
|
764
764
|
*/
|
|
765
765
|
get sectorCount() {
|
|
766
|
-
var
|
|
767
|
-
return (
|
|
766
|
+
var t;
|
|
767
|
+
return (t = this.uniforms.get("sectorCount")) == null ? void 0 : t.value;
|
|
768
768
|
}
|
|
769
|
-
set sectorCount(
|
|
770
|
-
this.uniforms.get("sectorCount").value =
|
|
769
|
+
set sectorCount(t) {
|
|
770
|
+
this.uniforms.get("sectorCount").value = t;
|
|
771
771
|
}
|
|
772
772
|
}
|
|
773
|
-
const
|
|
773
|
+
const ao = /* @__PURE__ */ u({
|
|
774
774
|
__name: "KuwaharaPmndrs",
|
|
775
775
|
props: {
|
|
776
776
|
blendFunction: {},
|
|
777
777
|
radius: {},
|
|
778
778
|
sectorCount: {}
|
|
779
779
|
},
|
|
780
|
-
setup(
|
|
781
|
-
const
|
|
782
|
-
() => new
|
|
783
|
-
|
|
780
|
+
setup(n, { expose: t }) {
|
|
781
|
+
const e = n, { pass: o, effect: s } = h(
|
|
782
|
+
() => new Re(e),
|
|
783
|
+
e
|
|
784
784
|
);
|
|
785
|
-
return
|
|
785
|
+
return t({ pass: o, effect: s }), v(
|
|
786
786
|
[
|
|
787
|
-
[() =>
|
|
788
|
-
[() =>
|
|
789
|
-
[() =>
|
|
787
|
+
[() => e.blendFunction, "blendMode.blendFunction"],
|
|
788
|
+
[() => e.radius, "radius"],
|
|
789
|
+
[() => e.sectorCount, "sectorCount"]
|
|
790
790
|
],
|
|
791
791
|
s,
|
|
792
|
-
() => new
|
|
792
|
+
() => new Re()
|
|
793
793
|
), () => {
|
|
794
794
|
};
|
|
795
795
|
}
|
|
796
|
-
}),
|
|
796
|
+
}), ro = /* @__PURE__ */ u({
|
|
797
797
|
__name: "ColorAveragePmndrs",
|
|
798
798
|
props: {
|
|
799
799
|
blendFunction: {},
|
|
800
800
|
opacity: {}
|
|
801
801
|
},
|
|
802
|
-
setup(
|
|
803
|
-
const
|
|
804
|
-
return
|
|
805
|
-
() =>
|
|
802
|
+
setup(n, { expose: t }) {
|
|
803
|
+
const e = n, { pass: o, effect: s } = h(() => new oe(e.blendFunction), e);
|
|
804
|
+
return t({ pass: o, effect: s }), X(
|
|
805
|
+
() => e.blendFunction,
|
|
806
806
|
s,
|
|
807
807
|
"blendMode.blendFunction",
|
|
808
|
-
() => new
|
|
809
|
-
),
|
|
810
|
-
[s, () =>
|
|
808
|
+
() => new oe()
|
|
809
|
+
), g(
|
|
810
|
+
[s, () => e.opacity],
|
|
811
811
|
() => {
|
|
812
|
-
var a,
|
|
812
|
+
var a, r;
|
|
813
813
|
if (s.value)
|
|
814
|
-
if (
|
|
815
|
-
(a = s.value) == null || a.blendMode.setOpacity(
|
|
814
|
+
if (e.opacity !== void 0)
|
|
815
|
+
(a = s.value) == null || a.blendMode.setOpacity(e.opacity);
|
|
816
816
|
else {
|
|
817
|
-
const
|
|
818
|
-
(
|
|
817
|
+
const i = new oe();
|
|
818
|
+
(r = s.value) == null || r.blendMode.setOpacity(i.blendMode.getOpacity()), i.dispose();
|
|
819
819
|
}
|
|
820
820
|
}
|
|
821
821
|
), () => {
|
|
822
822
|
};
|
|
823
823
|
}
|
|
824
|
-
}),
|
|
824
|
+
}), no = /* @__PURE__ */ u({
|
|
825
825
|
__name: "LensDistortionPmndrs",
|
|
826
826
|
props: {
|
|
827
827
|
distortion: {},
|
|
@@ -829,24 +829,24 @@ const _t = /* @__PURE__ */ u({
|
|
|
829
829
|
focalLength: {},
|
|
830
830
|
skew: {}
|
|
831
831
|
},
|
|
832
|
-
setup(
|
|
833
|
-
const
|
|
834
|
-
() => new
|
|
835
|
-
...
|
|
836
|
-
distortion:
|
|
837
|
-
principalPoint:
|
|
838
|
-
focalLength:
|
|
832
|
+
setup(n, { expose: t }) {
|
|
833
|
+
const e = n, { pass: o, effect: s } = h(
|
|
834
|
+
() => new Ae({
|
|
835
|
+
...e,
|
|
836
|
+
distortion: e.distortion ? Array.isArray(e.distortion) ? new f(...e.distortion) : e.distortion : new f(),
|
|
837
|
+
principalPoint: e.principalPoint ? Array.isArray(e.principalPoint) ? new f(...e.principalPoint) : e.principalPoint : new f(),
|
|
838
|
+
focalLength: e.focalLength ? Array.isArray(e.focalLength) ? new f(...e.focalLength) : e.focalLength : new f()
|
|
839
839
|
}),
|
|
840
|
-
|
|
840
|
+
e
|
|
841
841
|
);
|
|
842
|
-
return
|
|
843
|
-
|
|
842
|
+
return t({ pass: o, effect: s }), de(
|
|
843
|
+
e,
|
|
844
844
|
s,
|
|
845
|
-
() => new
|
|
845
|
+
() => new Ae()
|
|
846
846
|
), () => {
|
|
847
847
|
};
|
|
848
848
|
}
|
|
849
|
-
}),
|
|
849
|
+
}), io = /* @__PURE__ */ u({
|
|
850
850
|
__name: "ShockWavePmndrs",
|
|
851
851
|
props: {
|
|
852
852
|
position: {},
|
|
@@ -855,30 +855,30 @@ const _t = /* @__PURE__ */ u({
|
|
|
855
855
|
maxRadius: {},
|
|
856
856
|
waveSize: {}
|
|
857
857
|
},
|
|
858
|
-
setup(
|
|
859
|
-
const
|
|
860
|
-
() => new
|
|
861
|
-
|
|
858
|
+
setup(n, { expose: t }) {
|
|
859
|
+
const e = n, { camera: o } = y(), { pass: s, effect: a } = h(
|
|
860
|
+
() => new ye(o.value, Array.isArray(e.position) ? new B(...e.position) : e.position, e),
|
|
861
|
+
e
|
|
862
862
|
);
|
|
863
|
-
return
|
|
864
|
-
() =>
|
|
865
|
-
(
|
|
866
|
-
a.value && (Array.isArray(
|
|
863
|
+
return t({ pass: s, effect: a }), g(
|
|
864
|
+
() => e.position,
|
|
865
|
+
(r) => {
|
|
866
|
+
a.value && (Array.isArray(r) ? a.value.position.set(...r) : r instanceof B && a.value.position.copy(r));
|
|
867
867
|
},
|
|
868
868
|
{ immediate: !0 }
|
|
869
|
-
),
|
|
869
|
+
), v(
|
|
870
870
|
[
|
|
871
|
-
[() =>
|
|
872
|
-
[() =>
|
|
873
|
-
[() =>
|
|
874
|
-
[() =>
|
|
871
|
+
[() => e.amplitude, "amplitude"],
|
|
872
|
+
[() => e.waveSize, "waveSize"],
|
|
873
|
+
[() => e.maxRadius, "maxRadius"],
|
|
874
|
+
[() => e.speed, "speed"]
|
|
875
875
|
],
|
|
876
876
|
a,
|
|
877
|
-
() => new
|
|
877
|
+
() => new ye()
|
|
878
878
|
), () => {
|
|
879
879
|
};
|
|
880
880
|
}
|
|
881
|
-
}),
|
|
881
|
+
}), lo = /* @__PURE__ */ u({
|
|
882
882
|
__name: "TiltShiftPmndrs",
|
|
883
883
|
props: {
|
|
884
884
|
blendFunction: {},
|
|
@@ -891,73 +891,73 @@ const _t = /* @__PURE__ */ u({
|
|
|
891
891
|
resolutionX: {},
|
|
892
892
|
resolutionY: {}
|
|
893
893
|
},
|
|
894
|
-
setup(
|
|
895
|
-
const
|
|
896
|
-
return
|
|
894
|
+
setup(n, { expose: t }) {
|
|
895
|
+
const e = n, { pass: o, effect: s } = h(() => new Me(e), e);
|
|
896
|
+
return t({ pass: o, effect: s }), v(
|
|
897
897
|
[
|
|
898
|
-
[() =>
|
|
899
|
-
[() =>
|
|
900
|
-
[() =>
|
|
901
|
-
[() =>
|
|
902
|
-
[() =>
|
|
903
|
-
[() =>
|
|
904
|
-
[() =>
|
|
905
|
-
[() =>
|
|
906
|
-
[() =>
|
|
898
|
+
[() => e.blendFunction, "blendMode.blendFunction"],
|
|
899
|
+
[() => e.offset, "offset"],
|
|
900
|
+
[() => e.rotation, "rotation"],
|
|
901
|
+
[() => e.focusArea, "focusArea"],
|
|
902
|
+
[() => e.feather, "feather"],
|
|
903
|
+
[() => e.kernelSize, "kernelSize"],
|
|
904
|
+
[() => e.resolutionScale, "resolution.scale"],
|
|
905
|
+
[() => e.resolutionX, "resolution.width"],
|
|
906
|
+
[() => e.resolutionY, "resolution.height"]
|
|
907
907
|
],
|
|
908
908
|
s,
|
|
909
|
-
() => new
|
|
909
|
+
() => new Me()
|
|
910
910
|
), () => {
|
|
911
911
|
};
|
|
912
912
|
}
|
|
913
|
-
}),
|
|
913
|
+
}), uo = /* @__PURE__ */ u({
|
|
914
914
|
__name: "DotScreenPmndrs",
|
|
915
915
|
props: {
|
|
916
916
|
angle: {},
|
|
917
917
|
scale: {},
|
|
918
918
|
blendFunction: {}
|
|
919
919
|
},
|
|
920
|
-
setup(
|
|
921
|
-
const
|
|
922
|
-
return
|
|
920
|
+
setup(n, { expose: t }) {
|
|
921
|
+
const e = n, { pass: o, effect: s } = h(() => new Te(e), e);
|
|
922
|
+
return t({ pass: o, effect: s }), v(
|
|
923
923
|
[
|
|
924
|
-
[() =>
|
|
925
|
-
[() =>
|
|
926
|
-
[() =>
|
|
924
|
+
[() => e.blendFunction, "blendMode.blendFunction"],
|
|
925
|
+
[() => e.angle, "angle"],
|
|
926
|
+
[() => e.scale, "scale"]
|
|
927
927
|
],
|
|
928
928
|
s,
|
|
929
|
-
() => new
|
|
929
|
+
() => new Te()
|
|
930
930
|
), () => {
|
|
931
931
|
};
|
|
932
932
|
}
|
|
933
|
-
}),
|
|
933
|
+
}), co = /* @__PURE__ */ u({
|
|
934
934
|
__name: "SepiaPmndrs",
|
|
935
935
|
props: {
|
|
936
936
|
blendFunction: {},
|
|
937
937
|
intensity: {}
|
|
938
938
|
},
|
|
939
|
-
setup(
|
|
940
|
-
const
|
|
941
|
-
return
|
|
939
|
+
setup(n, { expose: t }) {
|
|
940
|
+
const e = n, { pass: o, effect: s } = h(() => new Ce(e), e);
|
|
941
|
+
return t({ pass: o, effect: s }), v(
|
|
942
942
|
[
|
|
943
|
-
[() =>
|
|
944
|
-
[() =>
|
|
943
|
+
[() => e.blendFunction, "blendMode.blendFunction"],
|
|
944
|
+
[() => e.intensity, "intensity"]
|
|
945
945
|
],
|
|
946
946
|
s,
|
|
947
|
-
() => new
|
|
947
|
+
() => new Ce()
|
|
948
948
|
), () => {
|
|
949
949
|
};
|
|
950
950
|
}
|
|
951
951
|
});
|
|
952
|
-
class
|
|
952
|
+
class Ne extends Z {
|
|
953
953
|
/**
|
|
954
954
|
* Creates a new LinocutEffect instance.
|
|
955
955
|
*
|
|
956
956
|
* @param {LinocutPmndrsProps} [options] - Configuration options for the effect.
|
|
957
957
|
*
|
|
958
958
|
*/
|
|
959
|
-
constructor({ blendFunction:
|
|
960
|
-
const
|
|
959
|
+
constructor({ blendFunction: t = _.NORMAL, scale: e = 0.85, noiseScale: o = 0, center: s = [0.5, 0.5], rotation: a = 0 } = {}) {
|
|
960
|
+
const r = Array.isArray(s) ? new f().fromArray(s) : s;
|
|
961
961
|
super("LinocutEffect", `
|
|
962
962
|
uniform float scale;
|
|
963
963
|
uniform float noiseScale;
|
|
@@ -1019,45 +1019,45 @@ class De extends q {
|
|
|
1019
1019
|
outputColor = vec4(vec3(f), 1.0);
|
|
1020
1020
|
}
|
|
1021
1021
|
`, {
|
|
1022
|
-
blendFunction:
|
|
1022
|
+
blendFunction: t,
|
|
1023
1023
|
uniforms: /* @__PURE__ */ new Map([
|
|
1024
|
-
["scale", new
|
|
1025
|
-
["noiseScale", new
|
|
1026
|
-
["center", new
|
|
1027
|
-
["rotation", new
|
|
1024
|
+
["scale", new C(e)],
|
|
1025
|
+
["noiseScale", new C(o)],
|
|
1026
|
+
["center", new C(r)],
|
|
1027
|
+
["rotation", new C(a)]
|
|
1028
1028
|
])
|
|
1029
1029
|
});
|
|
1030
1030
|
}
|
|
1031
1031
|
get scale() {
|
|
1032
|
-
var
|
|
1033
|
-
return (
|
|
1032
|
+
var t;
|
|
1033
|
+
return (t = this.uniforms.get("scale")) == null ? void 0 : t.value;
|
|
1034
1034
|
}
|
|
1035
|
-
set scale(
|
|
1036
|
-
this.uniforms.get("scale").value =
|
|
1035
|
+
set scale(t) {
|
|
1036
|
+
this.uniforms.get("scale").value = t;
|
|
1037
1037
|
}
|
|
1038
1038
|
get noiseScale() {
|
|
1039
|
-
var
|
|
1040
|
-
return (
|
|
1039
|
+
var t;
|
|
1040
|
+
return (t = this.uniforms.get("noiseScale")) == null ? void 0 : t.value;
|
|
1041
1041
|
}
|
|
1042
|
-
set noiseScale(
|
|
1043
|
-
this.uniforms.get("noiseScale").value =
|
|
1042
|
+
set noiseScale(t) {
|
|
1043
|
+
this.uniforms.get("noiseScale").value = t;
|
|
1044
1044
|
}
|
|
1045
1045
|
get center() {
|
|
1046
|
-
var
|
|
1047
|
-
return (
|
|
1046
|
+
var t;
|
|
1047
|
+
return (t = this.uniforms.get("center")) == null ? void 0 : t.value;
|
|
1048
1048
|
}
|
|
1049
|
-
set center(
|
|
1050
|
-
this.uniforms.get("center").value = Array.isArray(
|
|
1049
|
+
set center(t) {
|
|
1050
|
+
this.uniforms.get("center").value = Array.isArray(t) ? new f().fromArray(t) : t;
|
|
1051
1051
|
}
|
|
1052
1052
|
get rotation() {
|
|
1053
|
-
var
|
|
1054
|
-
return (
|
|
1053
|
+
var t;
|
|
1054
|
+
return (t = this.uniforms.get("rotation")) == null ? void 0 : t.value;
|
|
1055
1055
|
}
|
|
1056
|
-
set rotation(
|
|
1057
|
-
this.uniforms.get("rotation").value =
|
|
1056
|
+
set rotation(t) {
|
|
1057
|
+
this.uniforms.get("rotation").value = t;
|
|
1058
1058
|
}
|
|
1059
1059
|
}
|
|
1060
|
-
const
|
|
1060
|
+
const fo = /* @__PURE__ */ u({
|
|
1061
1061
|
__name: "LinocutPmndrs",
|
|
1062
1062
|
props: {
|
|
1063
1063
|
blendFunction: {},
|
|
@@ -1066,44 +1066,44 @@ const ro = /* @__PURE__ */ u({
|
|
|
1066
1066
|
center: {},
|
|
1067
1067
|
rotation: {}
|
|
1068
1068
|
},
|
|
1069
|
-
setup(
|
|
1070
|
-
const
|
|
1071
|
-
() => new
|
|
1072
|
-
...
|
|
1073
|
-
center:
|
|
1069
|
+
setup(n, { expose: t }) {
|
|
1070
|
+
const e = n, { pass: o, effect: s } = h(
|
|
1071
|
+
() => new Ne({
|
|
1072
|
+
...e,
|
|
1073
|
+
center: e.center instanceof f ? [e.center.x, e.center.y] : e.center
|
|
1074
1074
|
}),
|
|
1075
|
-
|
|
1075
|
+
e
|
|
1076
1076
|
);
|
|
1077
|
-
return
|
|
1077
|
+
return t({ pass: o, effect: s }), v(
|
|
1078
1078
|
[
|
|
1079
|
-
[() =>
|
|
1080
|
-
[() =>
|
|
1081
|
-
[() =>
|
|
1082
|
-
[() =>
|
|
1083
|
-
[() =>
|
|
1079
|
+
[() => e.blendFunction, "blendMode.blendFunction"],
|
|
1080
|
+
[() => e.scale, "scale"],
|
|
1081
|
+
[() => e.noiseScale, "noiseScale"],
|
|
1082
|
+
[() => e.center, "center"],
|
|
1083
|
+
[() => e.rotation, "rotation"]
|
|
1084
1084
|
],
|
|
1085
1085
|
s,
|
|
1086
|
-
() => new
|
|
1086
|
+
() => new Ne()
|
|
1087
1087
|
), () => {
|
|
1088
1088
|
};
|
|
1089
1089
|
}
|
|
1090
|
-
}),
|
|
1090
|
+
}), ho = /* @__PURE__ */ u({
|
|
1091
1091
|
__name: "DepthPickingPassPmndrs",
|
|
1092
1092
|
props: {
|
|
1093
1093
|
depthPacking: {},
|
|
1094
1094
|
mode: {}
|
|
1095
1095
|
},
|
|
1096
|
-
setup(
|
|
1097
|
-
const
|
|
1098
|
-
o != null && o.value && (
|
|
1096
|
+
setup(n, { expose: t }) {
|
|
1097
|
+
const e = n, o = J($), s = new et(e), a = w(() => {
|
|
1098
|
+
o != null && o.value && (ce(() => a()), o.value.addPass(s));
|
|
1099
1099
|
});
|
|
1100
|
-
return
|
|
1101
|
-
var
|
|
1102
|
-
!(o != null && o.value) || !s || ((
|
|
1103
|
-
}),
|
|
1100
|
+
return W(() => {
|
|
1101
|
+
var r;
|
|
1102
|
+
!(o != null && o.value) || !s || ((r = o == null ? void 0 : o.value) == null || r.removePass(s), s.dispose());
|
|
1103
|
+
}), t({ pass: s }), () => {
|
|
1104
1104
|
};
|
|
1105
1105
|
}
|
|
1106
|
-
}),
|
|
1106
|
+
}), po = /* @__PURE__ */ u({
|
|
1107
1107
|
__name: "GodRaysPmndrs",
|
|
1108
1108
|
props: {
|
|
1109
1109
|
blendFunction: {},
|
|
@@ -1121,51 +1121,51 @@ const ro = /* @__PURE__ */ u({
|
|
|
1121
1121
|
samples: {},
|
|
1122
1122
|
clampMax: {}
|
|
1123
1123
|
},
|
|
1124
|
-
setup(
|
|
1125
|
-
const
|
|
1126
|
-
() =>
|
|
1127
|
-
new
|
|
1128
|
-
new
|
|
1124
|
+
setup(n, { expose: t }) {
|
|
1125
|
+
const e = n, { camera: o } = y(), s = O(
|
|
1126
|
+
() => e.lightSource ?? new je(
|
|
1127
|
+
new ot(1e-5),
|
|
1128
|
+
new Ve({ visible: !1 })
|
|
1129
1129
|
)
|
|
1130
|
-
), { pass: a, effect:
|
|
1131
|
-
() => new
|
|
1132
|
-
|
|
1130
|
+
), { pass: a, effect: r } = h(
|
|
1131
|
+
() => new se(o.value, s.value, e),
|
|
1132
|
+
e
|
|
1133
1133
|
);
|
|
1134
|
-
return
|
|
1134
|
+
return t({ pass: a, effect: r }), v(
|
|
1135
1135
|
[
|
|
1136
|
-
[() =>
|
|
1137
|
-
[() =>
|
|
1138
|
-
[() =>
|
|
1139
|
-
[() =>
|
|
1140
|
-
[() =>
|
|
1141
|
-
[() =>
|
|
1142
|
-
[() =>
|
|
1143
|
-
[() =>
|
|
1144
|
-
[() =>
|
|
1145
|
-
[() =>
|
|
1146
|
-
[() =>
|
|
1147
|
-
[() =>
|
|
1136
|
+
[() => e.blendFunction, "blendMode.blendFunction"],
|
|
1137
|
+
[() => e.density, "godRaysMaterial.density"],
|
|
1138
|
+
[() => e.decay, "godRaysMaterial.decay"],
|
|
1139
|
+
[() => e.weight, "godRaysMaterial.weight"],
|
|
1140
|
+
[() => e.exposure, "godRaysMaterial.exposure"],
|
|
1141
|
+
[() => e.samples, "godRaysMaterial.samples"],
|
|
1142
|
+
[() => e.clampMax, "godRaysMaterial.maxIntensity"],
|
|
1143
|
+
[() => e.resolutionScale, "resolution.scale"],
|
|
1144
|
+
[() => e.resolutionX, "resolution.width"],
|
|
1145
|
+
[() => e.resolutionY, "resolution.height"],
|
|
1146
|
+
[() => e.kernelSize, "blurPass.kernelSize"],
|
|
1147
|
+
[() => e.blur, "blurPass.enabled"]
|
|
1148
1148
|
],
|
|
1149
|
-
|
|
1150
|
-
() => new
|
|
1151
|
-
),
|
|
1152
|
-
[() =>
|
|
1149
|
+
r,
|
|
1150
|
+
() => new se()
|
|
1151
|
+
), g(
|
|
1152
|
+
[() => e.lightSource, r],
|
|
1153
1153
|
() => {
|
|
1154
|
-
|
|
1154
|
+
r.value && (r.value.lightSource = fe(s.value));
|
|
1155
1155
|
},
|
|
1156
1156
|
{ immediate: !0 }
|
|
1157
|
-
),
|
|
1158
|
-
[() =>
|
|
1157
|
+
), g(
|
|
1158
|
+
[() => e.opacity],
|
|
1159
1159
|
() => {
|
|
1160
|
-
var
|
|
1161
|
-
if (
|
|
1162
|
-
(
|
|
1160
|
+
var i, l;
|
|
1161
|
+
if (e.opacity !== void 0)
|
|
1162
|
+
(i = r.value) == null || i.blendMode.setOpacity(e.opacity);
|
|
1163
1163
|
else {
|
|
1164
|
-
const
|
|
1164
|
+
const d = new se(
|
|
1165
1165
|
o.value,
|
|
1166
|
-
|
|
1166
|
+
fe(s.value)
|
|
1167
1167
|
);
|
|
1168
|
-
(l =
|
|
1168
|
+
(l = r.value) == null || l.blendMode.setOpacity(d.blendMode.getOpacity()), d.dispose();
|
|
1169
1169
|
}
|
|
1170
1170
|
},
|
|
1171
1171
|
{
|
|
@@ -1174,69 +1174,69 @@ const ro = /* @__PURE__ */ u({
|
|
|
1174
1174
|
), () => {
|
|
1175
1175
|
};
|
|
1176
1176
|
}
|
|
1177
|
-
}),
|
|
1177
|
+
}), mo = /* @__PURE__ */ u({
|
|
1178
1178
|
__name: "ColorDepthPmndrs",
|
|
1179
1179
|
props: {
|
|
1180
1180
|
blendFunction: {},
|
|
1181
1181
|
bits: {},
|
|
1182
1182
|
opacity: {}
|
|
1183
1183
|
},
|
|
1184
|
-
setup(
|
|
1185
|
-
const
|
|
1186
|
-
return
|
|
1187
|
-
() =>
|
|
1184
|
+
setup(n, { expose: t }) {
|
|
1185
|
+
const e = n, { pass: o, effect: s } = h(() => new V(e), e);
|
|
1186
|
+
return t({ pass: o, effect: s }), X(
|
|
1187
|
+
() => e.blendFunction,
|
|
1188
1188
|
s,
|
|
1189
1189
|
"blendMode.blendFunction",
|
|
1190
|
-
() => new
|
|
1191
|
-
),
|
|
1192
|
-
[s, () =>
|
|
1190
|
+
() => new V()
|
|
1191
|
+
), g(
|
|
1192
|
+
[s, () => e.bits],
|
|
1193
1193
|
() => {
|
|
1194
|
-
var a,
|
|
1194
|
+
var a, r;
|
|
1195
1195
|
if (s.value)
|
|
1196
|
-
if (
|
|
1197
|
-
(a = s.value) == null || a.setBitDepth(
|
|
1196
|
+
if (e.bits !== void 0)
|
|
1197
|
+
(a = s.value) == null || a.setBitDepth(e.bits);
|
|
1198
1198
|
else {
|
|
1199
|
-
const
|
|
1200
|
-
(
|
|
1199
|
+
const i = new V();
|
|
1200
|
+
(r = s.value) == null || r.setBitDepth(i.getBitDepth()), i.dispose();
|
|
1201
1201
|
}
|
|
1202
1202
|
}
|
|
1203
|
-
),
|
|
1204
|
-
[s, () =>
|
|
1203
|
+
), g(
|
|
1204
|
+
[s, () => e.opacity],
|
|
1205
1205
|
() => {
|
|
1206
|
-
var a,
|
|
1206
|
+
var a, r;
|
|
1207
1207
|
if (s.value)
|
|
1208
|
-
if (
|
|
1209
|
-
(a = s.value) == null || a.blendMode.setOpacity(
|
|
1208
|
+
if (e.opacity !== void 0)
|
|
1209
|
+
(a = s.value) == null || a.blendMode.setOpacity(e.opacity);
|
|
1210
1210
|
else {
|
|
1211
|
-
const
|
|
1212
|
-
(
|
|
1211
|
+
const i = new V();
|
|
1212
|
+
(r = s.value) == null || r.blendMode.setOpacity(i.blendMode.getOpacity()), i.dispose();
|
|
1213
1213
|
}
|
|
1214
1214
|
}
|
|
1215
1215
|
), () => {
|
|
1216
1216
|
};
|
|
1217
1217
|
}
|
|
1218
|
-
}),
|
|
1218
|
+
}), vo = /* @__PURE__ */ u({
|
|
1219
1219
|
__name: "GridPmndrs",
|
|
1220
1220
|
props: {
|
|
1221
1221
|
blendFunction: {},
|
|
1222
1222
|
scale: {},
|
|
1223
1223
|
lineWidth: {}
|
|
1224
1224
|
},
|
|
1225
|
-
setup(
|
|
1226
|
-
const
|
|
1227
|
-
return
|
|
1225
|
+
setup(n, { expose: t }) {
|
|
1226
|
+
const e = n, { pass: o, effect: s } = h(() => new Ee(e), e);
|
|
1227
|
+
return t({ pass: o, effect: s }), v(
|
|
1228
1228
|
[
|
|
1229
|
-
[() =>
|
|
1230
|
-
[() =>
|
|
1231
|
-
[() =>
|
|
1229
|
+
[() => e.blendFunction, "blendMode.blendFunction"],
|
|
1230
|
+
[() => e.scale, "scale"],
|
|
1231
|
+
[() => e.lineWidth, "lineWidth"]
|
|
1232
1232
|
],
|
|
1233
1233
|
s,
|
|
1234
|
-
() => new
|
|
1234
|
+
() => new Ee()
|
|
1235
1235
|
), () => {
|
|
1236
1236
|
};
|
|
1237
1237
|
}
|
|
1238
1238
|
});
|
|
1239
|
-
class
|
|
1239
|
+
class ze extends Z {
|
|
1240
1240
|
/**
|
|
1241
1241
|
* Creates a new FishEyeEffect instance.
|
|
1242
1242
|
*
|
|
@@ -1247,7 +1247,7 @@ class Le extends q {
|
|
|
1247
1247
|
* @param {number} [options.scale] - Scale.
|
|
1248
1248
|
*
|
|
1249
1249
|
*/
|
|
1250
|
-
constructor({ blendFunction:
|
|
1250
|
+
constructor({ blendFunction: t = _.NORMAL, lensS: e = new f(1, 1), lensF: o = new f(0, 1), scale: s = 1 } = {}) {
|
|
1251
1251
|
super("FishEyeEffect", `
|
|
1252
1252
|
uniform vec2 lensS;
|
|
1253
1253
|
uniform vec2 lensF;
|
|
@@ -1267,11 +1267,11 @@ class Le extends q {
|
|
|
1267
1267
|
outputColor = vec4(inputColor.rgb, inputColor.a); // Preserves original alpha
|
|
1268
1268
|
}
|
|
1269
1269
|
`, {
|
|
1270
|
-
blendFunction:
|
|
1270
|
+
blendFunction: t,
|
|
1271
1271
|
uniforms: /* @__PURE__ */ new Map([
|
|
1272
|
-
["lensS", new
|
|
1273
|
-
["lensF", new
|
|
1274
|
-
["scale", new
|
|
1272
|
+
["lensS", new C(e)],
|
|
1273
|
+
["lensF", new C(o)],
|
|
1274
|
+
["scale", new C(s)]
|
|
1275
1275
|
])
|
|
1276
1276
|
});
|
|
1277
1277
|
}
|
|
@@ -1281,11 +1281,11 @@ class Le extends q {
|
|
|
1281
1281
|
* @type {Vector2}
|
|
1282
1282
|
*/
|
|
1283
1283
|
get lensS() {
|
|
1284
|
-
var
|
|
1285
|
-
return (
|
|
1284
|
+
var t;
|
|
1285
|
+
return (t = this.uniforms.get("lensS")) == null ? void 0 : t.value;
|
|
1286
1286
|
}
|
|
1287
|
-
set lensS(
|
|
1288
|
-
this.uniforms.get("lensS").value =
|
|
1287
|
+
set lensS(t) {
|
|
1288
|
+
this.uniforms.get("lensS").value = t;
|
|
1289
1289
|
}
|
|
1290
1290
|
/**
|
|
1291
1291
|
* The lensF.
|
|
@@ -1293,11 +1293,11 @@ class Le extends q {
|
|
|
1293
1293
|
* @type {Vector2}
|
|
1294
1294
|
*/
|
|
1295
1295
|
get lensF() {
|
|
1296
|
-
var
|
|
1297
|
-
return (
|
|
1296
|
+
var t;
|
|
1297
|
+
return (t = this.uniforms.get("lensF")) == null ? void 0 : t.value;
|
|
1298
1298
|
}
|
|
1299
|
-
set lensF(
|
|
1300
|
-
this.uniforms.get("lensF").value =
|
|
1299
|
+
set lensF(t) {
|
|
1300
|
+
this.uniforms.get("lensF").value = t;
|
|
1301
1301
|
}
|
|
1302
1302
|
/**
|
|
1303
1303
|
* The scale.
|
|
@@ -1305,14 +1305,14 @@ class Le extends q {
|
|
|
1305
1305
|
* @type {number}
|
|
1306
1306
|
*/
|
|
1307
1307
|
get scale() {
|
|
1308
|
-
var
|
|
1309
|
-
return (
|
|
1308
|
+
var t;
|
|
1309
|
+
return (t = this.uniforms.get("scale")) == null ? void 0 : t.value;
|
|
1310
1310
|
}
|
|
1311
|
-
set scale(
|
|
1312
|
-
this.uniforms.get("scale").value =
|
|
1311
|
+
set scale(t) {
|
|
1312
|
+
this.uniforms.get("scale").value = t;
|
|
1313
1313
|
}
|
|
1314
1314
|
}
|
|
1315
|
-
const
|
|
1315
|
+
const go = /* @__PURE__ */ u({
|
|
1316
1316
|
__name: "FishEyePmndrs",
|
|
1317
1317
|
props: {
|
|
1318
1318
|
blendFunction: {},
|
|
@@ -1320,52 +1320,247 @@ const co = /* @__PURE__ */ u({
|
|
|
1320
1320
|
lensF: {},
|
|
1321
1321
|
scale: {}
|
|
1322
1322
|
},
|
|
1323
|
-
setup(
|
|
1324
|
-
const
|
|
1325
|
-
() => Array.isArray(
|
|
1326
|
-
), s =
|
|
1327
|
-
() => Array.isArray(
|
|
1328
|
-
), { pass: a, effect:
|
|
1329
|
-
() => new
|
|
1330
|
-
...
|
|
1323
|
+
setup(n, { expose: t }) {
|
|
1324
|
+
const e = n, o = O(
|
|
1325
|
+
() => Array.isArray(e.lensS) ? new f(...e.lensS) : e.lensS
|
|
1326
|
+
), s = O(
|
|
1327
|
+
() => Array.isArray(e.lensF) ? new f(...e.lensF) : e.lensF
|
|
1328
|
+
), { pass: a, effect: r } = h(
|
|
1329
|
+
() => new ze({
|
|
1330
|
+
...e,
|
|
1331
1331
|
lensS: o.value,
|
|
1332
1332
|
lensF: s.value
|
|
1333
1333
|
}),
|
|
1334
|
-
|
|
1334
|
+
e
|
|
1335
1335
|
);
|
|
1336
|
-
return
|
|
1336
|
+
return t({ pass: a, effect: r }), v(
|
|
1337
1337
|
[
|
|
1338
|
-
[() =>
|
|
1338
|
+
[() => e.blendFunction, "blendMode.blendFunction"],
|
|
1339
1339
|
[() => o.value, "lensS"],
|
|
1340
1340
|
[() => s.value, "lensF"],
|
|
1341
|
-
[() =>
|
|
1341
|
+
[() => e.scale, "scale"]
|
|
1342
1342
|
],
|
|
1343
|
-
|
|
1344
|
-
() => new
|
|
1343
|
+
r,
|
|
1344
|
+
() => new ze()
|
|
1345
1345
|
), () => {
|
|
1346
1346
|
};
|
|
1347
1347
|
}
|
|
1348
|
-
}),
|
|
1348
|
+
}), xo = /* @__PURE__ */ u({
|
|
1349
1349
|
__name: "BrightnessContrastPmndrs",
|
|
1350
1350
|
props: {
|
|
1351
1351
|
blendFunction: {},
|
|
1352
1352
|
brightness: {},
|
|
1353
1353
|
contrast: {}
|
|
1354
1354
|
},
|
|
1355
|
-
setup(
|
|
1356
|
-
const
|
|
1357
|
-
return
|
|
1355
|
+
setup(n, { expose: t }) {
|
|
1356
|
+
const e = n, { pass: o, effect: s } = h(() => new Pe(e), e);
|
|
1357
|
+
return t({ pass: o, effect: s }), v(
|
|
1358
1358
|
[
|
|
1359
|
-
[() =>
|
|
1360
|
-
[() =>
|
|
1361
|
-
[() =>
|
|
1359
|
+
[() => e.blendFunction, "blendMode.blendFunction"],
|
|
1360
|
+
[() => e.brightness, "brightness"],
|
|
1361
|
+
[() => e.contrast, "contrast"]
|
|
1362
1362
|
],
|
|
1363
1363
|
s,
|
|
1364
|
-
() => new
|
|
1364
|
+
() => new Pe()
|
|
1365
1365
|
), () => {
|
|
1366
1366
|
};
|
|
1367
1367
|
}
|
|
1368
|
-
}),
|
|
1368
|
+
}), le = {
|
|
1369
|
+
OFF: 0,
|
|
1370
|
+
EDGES: 1,
|
|
1371
|
+
WEIGHTS: 2
|
|
1372
|
+
}, bo = /* @__PURE__ */ u({
|
|
1373
|
+
__name: "SMAAPmndrs",
|
|
1374
|
+
props: {
|
|
1375
|
+
blendFunction: {},
|
|
1376
|
+
opacity: {},
|
|
1377
|
+
preset: {},
|
|
1378
|
+
edgeDetectionMode: {},
|
|
1379
|
+
predicationMode: {},
|
|
1380
|
+
debug: {}
|
|
1381
|
+
},
|
|
1382
|
+
setup(n, { expose: t }) {
|
|
1383
|
+
const e = n, { pass: o, effect: s } = h(() => new ae(e), e), { camera: a } = y(), r = J($);
|
|
1384
|
+
t({ pass: o, effect: s });
|
|
1385
|
+
const i = new ae();
|
|
1386
|
+
v(
|
|
1387
|
+
[
|
|
1388
|
+
[() => Number(e.blendFunction), "blendMode.blendFunction"],
|
|
1389
|
+
[() => Number(e.predicationMode), "edgeDetectionMaterial.predicationMode"],
|
|
1390
|
+
[() => Number(e.edgeDetectionMode), "edgeDetectionMaterial.edgeDetectionMode"]
|
|
1391
|
+
],
|
|
1392
|
+
s,
|
|
1393
|
+
() => new ae()
|
|
1394
|
+
), g(
|
|
1395
|
+
[s, () => e.opacity],
|
|
1396
|
+
() => {
|
|
1397
|
+
s.value && (e.opacity !== void 0 ? s.value.blendMode.setOpacity(e.opacity) : s.value.blendMode.setOpacity(i.blendMode.getOpacity()));
|
|
1398
|
+
},
|
|
1399
|
+
{ immediate: !0 }
|
|
1400
|
+
), g(
|
|
1401
|
+
[s, () => e.preset],
|
|
1402
|
+
() => {
|
|
1403
|
+
s.value && s.value.applyPreset(Number(e.preset));
|
|
1404
|
+
}
|
|
1405
|
+
);
|
|
1406
|
+
let l = null, d = null;
|
|
1407
|
+
const p = (m) => {
|
|
1408
|
+
if (!s.value)
|
|
1409
|
+
return null;
|
|
1410
|
+
const A = m === "edges" ? s.value.edgesTexture : s.value.weightsTexture, E = new Xe(a.value, s.value, new q({ texture: A }));
|
|
1411
|
+
return E.renderToScreen = !1, E.enabled = !1, E.fullscreenMaterial.encodeOutput = !1, E;
|
|
1412
|
+
}, b = (m) => {
|
|
1413
|
+
m === "edges" && !l ? l = p("edges") : m === "weights" && !d && (d = p("weights"));
|
|
1414
|
+
}, c = (m, A) => {
|
|
1415
|
+
!m || !(r != null && r.value) || m.enabled !== A && (m.enabled = A, m.renderToScreen = A, A && !(r != null && r.value.passes.includes(m)) ? r == null || r.value.addPass(m) : !A && (r != null && r.value.passes.includes(m)) && (r == null || r.value.removePass(m), m.dispose()));
|
|
1416
|
+
}, S = (m) => {
|
|
1417
|
+
if (!o.value)
|
|
1418
|
+
return;
|
|
1419
|
+
const A = m === le.OFF, E = m === le.EDGES, x = m === le.WEIGHTS;
|
|
1420
|
+
o.value.enabled = A, o.value.renderToScreen = A, E && b("edges"), x && b("weights"), c(l, E), c(d, x), E || (l = null), x || (d = null);
|
|
1421
|
+
};
|
|
1422
|
+
return g(
|
|
1423
|
+
() => e.debug,
|
|
1424
|
+
() => {
|
|
1425
|
+
!o.value || e.debug === void 0 || S(e.debug);
|
|
1426
|
+
},
|
|
1427
|
+
{ immediate: !0 }
|
|
1428
|
+
), () => {
|
|
1429
|
+
};
|
|
1430
|
+
}
|
|
1431
|
+
}), So = /* @__PURE__ */ u({
|
|
1432
|
+
__name: "FXAAPmndrs",
|
|
1433
|
+
props: {
|
|
1434
|
+
blendFunction: {},
|
|
1435
|
+
opacity: {},
|
|
1436
|
+
samples: {},
|
|
1437
|
+
minEdgeThreshold: {},
|
|
1438
|
+
maxEdgeThreshold: {},
|
|
1439
|
+
subpixelQuality: {}
|
|
1440
|
+
},
|
|
1441
|
+
setup(n, { expose: t }) {
|
|
1442
|
+
const e = n, { pass: o, effect: s } = h(() => new re(e), e);
|
|
1443
|
+
return t({ pass: o, effect: s }), v(
|
|
1444
|
+
[
|
|
1445
|
+
[() => e.blendFunction, "blendMode.blendFunction"],
|
|
1446
|
+
[() => e.samples, "samples"],
|
|
1447
|
+
[() => e.minEdgeThreshold, "minEdgeThreshold"],
|
|
1448
|
+
[() => e.maxEdgeThreshold, "maxEdgeThreshold"],
|
|
1449
|
+
[() => e.subpixelQuality, "subpixelQuality"]
|
|
1450
|
+
],
|
|
1451
|
+
s,
|
|
1452
|
+
() => new re()
|
|
1453
|
+
), g(
|
|
1454
|
+
[s, () => e.opacity],
|
|
1455
|
+
() => {
|
|
1456
|
+
var a, r;
|
|
1457
|
+
if (s.value)
|
|
1458
|
+
if (e.opacity !== void 0)
|
|
1459
|
+
(a = s.value) == null || a.blendMode.setOpacity(e.opacity);
|
|
1460
|
+
else {
|
|
1461
|
+
const i = new re();
|
|
1462
|
+
(r = s.value) == null || r.blendMode.setOpacity(i.blendMode.getOpacity()), i.dispose();
|
|
1463
|
+
}
|
|
1464
|
+
},
|
|
1465
|
+
{ immediate: !0 }
|
|
1466
|
+
), () => {
|
|
1467
|
+
};
|
|
1468
|
+
}
|
|
1469
|
+
}), wo = /* @__PURE__ */ u({
|
|
1470
|
+
__name: "TexturePmndrs",
|
|
1471
|
+
props: {
|
|
1472
|
+
blendFunction: {},
|
|
1473
|
+
texture: {},
|
|
1474
|
+
opacity: {}
|
|
1475
|
+
},
|
|
1476
|
+
setup(n, { expose: t }) {
|
|
1477
|
+
const e = n, { pass: o, effect: s } = h(() => new q(e), e);
|
|
1478
|
+
return t({
|
|
1479
|
+
pass: o,
|
|
1480
|
+
effect: s
|
|
1481
|
+
}), v(
|
|
1482
|
+
[
|
|
1483
|
+
[() => e.blendFunction, "blendMode.blendFunction"]
|
|
1484
|
+
],
|
|
1485
|
+
s,
|
|
1486
|
+
() => new q()
|
|
1487
|
+
), g(
|
|
1488
|
+
[() => e.opacity],
|
|
1489
|
+
() => {
|
|
1490
|
+
var a, r;
|
|
1491
|
+
if (e.opacity !== void 0)
|
|
1492
|
+
(a = s.value) == null || a.blendMode.setOpacity(e.opacity);
|
|
1493
|
+
else {
|
|
1494
|
+
const i = new q();
|
|
1495
|
+
(r = s.value) == null || r.blendMode.setOpacity(i.blendMode.getOpacity()), i.dispose();
|
|
1496
|
+
}
|
|
1497
|
+
},
|
|
1498
|
+
{
|
|
1499
|
+
immediate: !0
|
|
1500
|
+
}
|
|
1501
|
+
), () => {
|
|
1502
|
+
};
|
|
1503
|
+
}
|
|
1504
|
+
}), Ao = /* @__PURE__ */ u({
|
|
1505
|
+
__name: "ASCIIPmndrs",
|
|
1506
|
+
props: {
|
|
1507
|
+
blendFunction: {},
|
|
1508
|
+
opacity: {},
|
|
1509
|
+
cellSize: {},
|
|
1510
|
+
inverted: { type: Boolean },
|
|
1511
|
+
color: {},
|
|
1512
|
+
useSceneColor: { type: Boolean },
|
|
1513
|
+
asciiTexture: {}
|
|
1514
|
+
},
|
|
1515
|
+
setup(n, { expose: t }) {
|
|
1516
|
+
const e = n, o = new ne(), { asciiTexture: s, ...a } = e, { pass: r, effect: i } = h(() => new ne(a), e);
|
|
1517
|
+
return t({ pass: r, effect: i }), W(() => {
|
|
1518
|
+
o.dispose();
|
|
1519
|
+
}), v(
|
|
1520
|
+
[
|
|
1521
|
+
[() => e.blendFunction, "blendMode.blendFunction"],
|
|
1522
|
+
[() => e.cellSize, "cellSize"],
|
|
1523
|
+
[() => e.inverted, "inverted"]
|
|
1524
|
+
],
|
|
1525
|
+
i,
|
|
1526
|
+
() => new ne()
|
|
1527
|
+
), g(
|
|
1528
|
+
[i, () => e.useSceneColor],
|
|
1529
|
+
() => {
|
|
1530
|
+
i.value && (e.useSceneColor ? i.value.color = null : i.value.color = e.color ?? o.color);
|
|
1531
|
+
},
|
|
1532
|
+
{ immediate: !0 }
|
|
1533
|
+
), g(
|
|
1534
|
+
[i, () => e.opacity],
|
|
1535
|
+
() => {
|
|
1536
|
+
i.value && i.value.blendMode.setOpacity(e.opacity ?? o.blendMode.getOpacity());
|
|
1537
|
+
},
|
|
1538
|
+
{ immediate: !0 }
|
|
1539
|
+
), g(
|
|
1540
|
+
[i, () => e.color],
|
|
1541
|
+
() => {
|
|
1542
|
+
i.value && (e.useSceneColor || (i.value.color = e.color ?? null));
|
|
1543
|
+
},
|
|
1544
|
+
{ immediate: !0 }
|
|
1545
|
+
), g(
|
|
1546
|
+
[i, () => e.asciiTexture],
|
|
1547
|
+
() => {
|
|
1548
|
+
if (!i.value)
|
|
1549
|
+
return;
|
|
1550
|
+
const l = e.asciiTexture ? new tt(e.asciiTexture) : o.asciiTexture;
|
|
1551
|
+
i.value.asciiTexture = l;
|
|
1552
|
+
},
|
|
1553
|
+
{ immediate: !0 }
|
|
1554
|
+
), g(
|
|
1555
|
+
[i, () => e.blendFunction],
|
|
1556
|
+
() => {
|
|
1557
|
+
i.value && (i.value.blendMode.blendFunction = e.blendFunction ? Number(e.blendFunction) : Number(o.blendMode.blendFunction));
|
|
1558
|
+
},
|
|
1559
|
+
{ immediate: !0 }
|
|
1560
|
+
), () => {
|
|
1561
|
+
};
|
|
1562
|
+
}
|
|
1563
|
+
}), qe = {
|
|
1369
1564
|
name: "CopyShader",
|
|
1370
1565
|
uniforms: {
|
|
1371
1566
|
tDiffuse: { value: null },
|
|
@@ -1403,7 +1598,7 @@ const co = /* @__PURE__ */ u({
|
|
|
1403
1598
|
}`
|
|
1404
1599
|
)
|
|
1405
1600
|
};
|
|
1406
|
-
class
|
|
1601
|
+
class D {
|
|
1407
1602
|
constructor() {
|
|
1408
1603
|
this.isPass = !0, this.enabled = !0, this.needsSwap = !0, this.clear = !1, this.renderToScreen = !1;
|
|
1409
1604
|
}
|
|
@@ -1415,202 +1610,202 @@ class C {
|
|
|
1415
1610
|
dispose() {
|
|
1416
1611
|
}
|
|
1417
1612
|
}
|
|
1418
|
-
const
|
|
1419
|
-
class
|
|
1613
|
+
const Pt = new st(-1, 1, 1, -1, 0, 1);
|
|
1614
|
+
class Dt extends at {
|
|
1420
1615
|
constructor() {
|
|
1421
|
-
super(), this.setAttribute("position", new
|
|
1616
|
+
super(), this.setAttribute("position", new De([-1, 3, 0, -1, -1, 0, 3, -1, 0], 3)), this.setAttribute("uv", new De([0, 2, 0, 0, 2, 0], 2));
|
|
1422
1617
|
}
|
|
1423
1618
|
}
|
|
1424
|
-
const
|
|
1619
|
+
const Lt = new Dt();
|
|
1425
1620
|
class R {
|
|
1426
|
-
constructor(
|
|
1427
|
-
this._mesh = new
|
|
1621
|
+
constructor(t) {
|
|
1622
|
+
this._mesh = new je(Lt, t);
|
|
1428
1623
|
}
|
|
1429
1624
|
dispose() {
|
|
1430
1625
|
this._mesh.geometry.dispose();
|
|
1431
1626
|
}
|
|
1432
|
-
render(
|
|
1433
|
-
|
|
1627
|
+
render(t) {
|
|
1628
|
+
t.render(this._mesh, Pt);
|
|
1434
1629
|
}
|
|
1435
1630
|
get material() {
|
|
1436
1631
|
return this._mesh.material;
|
|
1437
1632
|
}
|
|
1438
|
-
set material(
|
|
1439
|
-
this._mesh.material =
|
|
1633
|
+
set material(t) {
|
|
1634
|
+
this._mesh.material = t;
|
|
1440
1635
|
}
|
|
1441
1636
|
}
|
|
1442
|
-
class
|
|
1443
|
-
constructor(
|
|
1444
|
-
super(), this.textureID =
|
|
1445
|
-
name:
|
|
1446
|
-
defines: Object.assign({},
|
|
1637
|
+
class Ft extends D {
|
|
1638
|
+
constructor(t, e) {
|
|
1639
|
+
super(), this.textureID = e !== void 0 ? e : "tDiffuse", t instanceof T ? (this.uniforms = t.uniforms, this.material = t) : t && (this.uniforms = L.clone(t.uniforms), this.material = new T({
|
|
1640
|
+
name: t.name !== void 0 ? t.name : "unspecified",
|
|
1641
|
+
defines: Object.assign({}, t.defines),
|
|
1447
1642
|
uniforms: this.uniforms,
|
|
1448
|
-
vertexShader:
|
|
1449
|
-
fragmentShader:
|
|
1643
|
+
vertexShader: t.vertexShader,
|
|
1644
|
+
fragmentShader: t.fragmentShader
|
|
1450
1645
|
})), this.fsQuad = new R(this.material);
|
|
1451
1646
|
}
|
|
1452
|
-
render(
|
|
1453
|
-
this.uniforms[this.textureID] && (this.uniforms[this.textureID].value = o.texture), this.fsQuad.material = this.material, this.renderToScreen ? (
|
|
1647
|
+
render(t, e, o) {
|
|
1648
|
+
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));
|
|
1454
1649
|
}
|
|
1455
1650
|
dispose() {
|
|
1456
1651
|
this.material.dispose(), this.fsQuad.dispose();
|
|
1457
1652
|
}
|
|
1458
1653
|
}
|
|
1459
|
-
class
|
|
1460
|
-
constructor(
|
|
1461
|
-
super(), this.scene =
|
|
1654
|
+
class We extends D {
|
|
1655
|
+
constructor(t, e) {
|
|
1656
|
+
super(), this.scene = t, this.camera = e, this.clear = !0, this.needsSwap = !1, this.inverse = !1;
|
|
1462
1657
|
}
|
|
1463
|
-
render(
|
|
1464
|
-
const s =
|
|
1658
|
+
render(t, e, o) {
|
|
1659
|
+
const s = t.getContext(), a = t.state;
|
|
1465
1660
|
a.buffers.color.setMask(!1), a.buffers.depth.setMask(!1), a.buffers.color.setLocked(!0), a.buffers.depth.setLocked(!0);
|
|
1466
|
-
let
|
|
1467
|
-
this.inverse ? (
|
|
1661
|
+
let r, i;
|
|
1662
|
+
this.inverse ? (r = 0, i = 1) : (r = 1, i = 0), a.buffers.stencil.setTest(!0), a.buffers.stencil.setOp(s.REPLACE, s.REPLACE, s.REPLACE), a.buffers.stencil.setFunc(s.ALWAYS, r, 4294967295), a.buffers.stencil.setClear(i), a.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), a.buffers.color.setLocked(!1), a.buffers.depth.setLocked(!1), a.buffers.color.setMask(!0), a.buffers.depth.setMask(!0), a.buffers.stencil.setLocked(!1), a.buffers.stencil.setFunc(s.EQUAL, 1, 4294967295), a.buffers.stencil.setOp(s.KEEP, s.KEEP, s.KEEP), a.buffers.stencil.setLocked(!0);
|
|
1468
1663
|
}
|
|
1469
1664
|
}
|
|
1470
|
-
class
|
|
1665
|
+
class Ot extends D {
|
|
1471
1666
|
constructor() {
|
|
1472
1667
|
super(), this.needsSwap = !1;
|
|
1473
1668
|
}
|
|
1474
|
-
render(
|
|
1475
|
-
|
|
1669
|
+
render(t) {
|
|
1670
|
+
t.state.buffers.stencil.setLocked(!1), t.state.buffers.stencil.setTest(!1);
|
|
1476
1671
|
}
|
|
1477
1672
|
}
|
|
1478
|
-
class
|
|
1479
|
-
constructor(
|
|
1480
|
-
if (this.renderer =
|
|
1481
|
-
const o =
|
|
1482
|
-
this._width = o.width, this._height = o.height,
|
|
1673
|
+
class Bt {
|
|
1674
|
+
constructor(t, e) {
|
|
1675
|
+
if (this.renderer = t, this._pixelRatio = t.getPixelRatio(), e === void 0) {
|
|
1676
|
+
const o = t.getSize(new f());
|
|
1677
|
+
this._width = o.width, this._height = o.height, e = new F(this._width * this._pixelRatio, this._height * this._pixelRatio, { type: P }), e.texture.name = "EffectComposer.rt1";
|
|
1483
1678
|
} else
|
|
1484
|
-
this._width =
|
|
1485
|
-
this.renderTarget1 =
|
|
1679
|
+
this._width = e.width, this._height = e.height;
|
|
1680
|
+
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 Ft(qe), this.copyPass.material.blending = rt, this.clock = new nt();
|
|
1486
1681
|
}
|
|
1487
1682
|
swapBuffers() {
|
|
1488
|
-
const
|
|
1489
|
-
this.readBuffer = this.writeBuffer, this.writeBuffer =
|
|
1683
|
+
const t = this.readBuffer;
|
|
1684
|
+
this.readBuffer = this.writeBuffer, this.writeBuffer = t;
|
|
1490
1685
|
}
|
|
1491
|
-
addPass(
|
|
1492
|
-
this.passes.push(
|
|
1686
|
+
addPass(t) {
|
|
1687
|
+
this.passes.push(t), t.setSize(this._width * this._pixelRatio, this._height * this._pixelRatio);
|
|
1493
1688
|
}
|
|
1494
|
-
insertPass(
|
|
1495
|
-
this.passes.splice(
|
|
1689
|
+
insertPass(t, e) {
|
|
1690
|
+
this.passes.splice(e, 0, t), t.setSize(this._width * this._pixelRatio, this._height * this._pixelRatio);
|
|
1496
1691
|
}
|
|
1497
|
-
removePass(
|
|
1498
|
-
const
|
|
1499
|
-
|
|
1692
|
+
removePass(t) {
|
|
1693
|
+
const e = this.passes.indexOf(t);
|
|
1694
|
+
e !== -1 && this.passes.splice(e, 1);
|
|
1500
1695
|
}
|
|
1501
|
-
isLastEnabledPass(
|
|
1502
|
-
for (let
|
|
1503
|
-
if (this.passes[
|
|
1696
|
+
isLastEnabledPass(t) {
|
|
1697
|
+
for (let e = t + 1; e < this.passes.length; e++)
|
|
1698
|
+
if (this.passes[e].enabled)
|
|
1504
1699
|
return !1;
|
|
1505
1700
|
return !0;
|
|
1506
1701
|
}
|
|
1507
|
-
render(
|
|
1508
|
-
|
|
1509
|
-
const
|
|
1702
|
+
render(t) {
|
|
1703
|
+
t === void 0 && (t = this.clock.getDelta());
|
|
1704
|
+
const e = this.renderer.getRenderTarget();
|
|
1510
1705
|
let o = !1;
|
|
1511
1706
|
for (let s = 0, a = this.passes.length; s < a; s++) {
|
|
1512
|
-
const
|
|
1513
|
-
if (
|
|
1514
|
-
if (
|
|
1707
|
+
const r = this.passes[s];
|
|
1708
|
+
if (r.enabled !== !1) {
|
|
1709
|
+
if (r.renderToScreen = this.renderToScreen && this.isLastEnabledPass(s), r.render(this.renderer, this.writeBuffer, this.readBuffer, t, o), r.needsSwap) {
|
|
1515
1710
|
if (o) {
|
|
1516
|
-
const
|
|
1517
|
-
l.setFunc(
|
|
1711
|
+
const i = this.renderer.getContext(), l = this.renderer.state.buffers.stencil;
|
|
1712
|
+
l.setFunc(i.NOTEQUAL, 1, 4294967295), this.copyPass.render(this.renderer, this.writeBuffer, this.readBuffer, t), l.setFunc(i.EQUAL, 1, 4294967295);
|
|
1518
1713
|
}
|
|
1519
1714
|
this.swapBuffers();
|
|
1520
1715
|
}
|
|
1521
|
-
|
|
1716
|
+
We !== void 0 && (r instanceof We ? o = !0 : r instanceof Ot && (o = !1));
|
|
1522
1717
|
}
|
|
1523
1718
|
}
|
|
1524
|
-
this.renderer.setRenderTarget(
|
|
1719
|
+
this.renderer.setRenderTarget(e);
|
|
1525
1720
|
}
|
|
1526
|
-
reset(
|
|
1527
|
-
if (
|
|
1528
|
-
const
|
|
1529
|
-
this._pixelRatio = this.renderer.getPixelRatio(), this._width =
|
|
1721
|
+
reset(t) {
|
|
1722
|
+
if (t === void 0) {
|
|
1723
|
+
const e = this.renderer.getSize(new f());
|
|
1724
|
+
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);
|
|
1530
1725
|
}
|
|
1531
|
-
this.renderTarget1.dispose(), this.renderTarget2.dispose(), this.renderTarget1 =
|
|
1726
|
+
this.renderTarget1.dispose(), this.renderTarget2.dispose(), this.renderTarget1 = t, this.renderTarget2 = t.clone(), this.writeBuffer = this.renderTarget1, this.readBuffer = this.renderTarget2;
|
|
1532
1727
|
}
|
|
1533
|
-
setSize(
|
|
1534
|
-
this._width =
|
|
1728
|
+
setSize(t, e) {
|
|
1729
|
+
this._width = t, this._height = e;
|
|
1535
1730
|
const o = this._width * this._pixelRatio, s = this._height * this._pixelRatio;
|
|
1536
1731
|
this.renderTarget1.setSize(o, s), this.renderTarget2.setSize(o, s);
|
|
1537
1732
|
for (let a = 0; a < this.passes.length; a++)
|
|
1538
1733
|
this.passes[a].setSize(o, s);
|
|
1539
1734
|
}
|
|
1540
|
-
setPixelRatio(
|
|
1541
|
-
this._pixelRatio =
|
|
1735
|
+
setPixelRatio(t) {
|
|
1736
|
+
this._pixelRatio = t, this.setSize(this._width, this._height);
|
|
1542
1737
|
}
|
|
1543
1738
|
dispose() {
|
|
1544
1739
|
this.renderTarget1.dispose(), this.renderTarget2.dispose(), this.copyPass.dispose();
|
|
1545
1740
|
}
|
|
1546
1741
|
}
|
|
1547
|
-
class
|
|
1548
|
-
constructor(
|
|
1549
|
-
super(), this.scene =
|
|
1742
|
+
class Rt extends D {
|
|
1743
|
+
constructor(t, e, o = null, s = null, a = null) {
|
|
1744
|
+
super(), this.scene = t, this.camera = e, this.overrideMaterial = o, this.clearColor = s, this.clearAlpha = a, this.clear = !0, this.clearDepth = !1, this.needsSwap = !1, this._oldClearColor = new K();
|
|
1550
1745
|
}
|
|
1551
|
-
render(
|
|
1552
|
-
const s =
|
|
1553
|
-
|
|
1554
|
-
let a,
|
|
1555
|
-
this.overrideMaterial !== null && (
|
|
1746
|
+
render(t, e, o) {
|
|
1747
|
+
const s = t.autoClear;
|
|
1748
|
+
t.autoClear = !1;
|
|
1749
|
+
let a, r;
|
|
1750
|
+
this.overrideMaterial !== null && (r = this.scene.overrideMaterial, this.scene.overrideMaterial = this.overrideMaterial), this.clearColor !== null && (t.getClearColor(this._oldClearColor), t.setClearColor(this.clearColor, t.getClearAlpha())), this.clearAlpha !== null && (a = 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(a), this.overrideMaterial !== null && (this.scene.overrideMaterial = r), t.autoClear = s;
|
|
1556
1751
|
}
|
|
1557
1752
|
}
|
|
1558
|
-
const
|
|
1753
|
+
const Qe = Symbol("effectComposerThree"), yo = /* @__PURE__ */ u({
|
|
1559
1754
|
__name: "EffectComposer",
|
|
1560
1755
|
props: {
|
|
1561
1756
|
enabled: { type: Boolean, default: !0 },
|
|
1562
1757
|
withoutRenderPass: { type: Boolean }
|
|
1563
1758
|
},
|
|
1564
|
-
setup(
|
|
1565
|
-
const
|
|
1566
|
-
|
|
1567
|
-
const { renderer: s, sizes: a, scene:
|
|
1568
|
-
|
|
1759
|
+
setup(n, { expose: t }) {
|
|
1760
|
+
const e = n, o = H(null);
|
|
1761
|
+
He(Qe, o), t({ composer: o });
|
|
1762
|
+
const { renderer: s, sizes: a, scene: r, camera: i, render: l } = y();
|
|
1763
|
+
w(() => {
|
|
1569
1764
|
var c;
|
|
1570
|
-
(c = o.value) == null || c.dispose(), o.value = new
|
|
1571
|
-
}),
|
|
1572
|
-
var
|
|
1573
|
-
const { width: c, height:
|
|
1574
|
-
|
|
1765
|
+
(c = o.value) == null || c.dispose(), o.value = new Bt(s.value);
|
|
1766
|
+
}), w(() => {
|
|
1767
|
+
var m;
|
|
1768
|
+
const { width: c, height: S } = a;
|
|
1769
|
+
S.value && c.value && ((m = o.value) == null || m.setSize(c.value, S.value));
|
|
1575
1770
|
});
|
|
1576
|
-
const { pixelRatio:
|
|
1577
|
-
|
|
1771
|
+
const { pixelRatio: p } = Ye();
|
|
1772
|
+
w(() => {
|
|
1578
1773
|
var c;
|
|
1579
|
-
(c = o.value) == null || c.setPixelRatio(
|
|
1580
|
-
}),
|
|
1581
|
-
|
|
1774
|
+
(c = o.value) == null || c.setPixelRatio(p.value);
|
|
1775
|
+
}), e.withoutRenderPass || w(() => {
|
|
1776
|
+
i.value && r.value && o.value && o.value.addPass(new Rt(r.value, i.value));
|
|
1582
1777
|
});
|
|
1583
|
-
const { render:
|
|
1584
|
-
return
|
|
1585
|
-
l.frames.value > 0 && o.value &&
|
|
1586
|
-
}),
|
|
1778
|
+
const { render: b } = I();
|
|
1779
|
+
return b(() => {
|
|
1780
|
+
l.frames.value > 0 && o.value && e.enabled && o.value.render(), l.frames.value = l.mode.value === "always" ? 1 : Math.max(0, l.frames.value - 1);
|
|
1781
|
+
}), W(() => {
|
|
1587
1782
|
var c;
|
|
1588
1783
|
(c = o.value) == null || c.dispose();
|
|
1589
|
-
}), (c,
|
|
1784
|
+
}), (c, S) => Ie(c.$slots, "default");
|
|
1590
1785
|
}
|
|
1591
|
-
}),
|
|
1592
|
-
if (!
|
|
1786
|
+
}), U = (n, t, e) => {
|
|
1787
|
+
if (!t && e)
|
|
1593
1788
|
throw new Error("passDependencies is required when dependencyFieldsTriggeringRecreation is provided");
|
|
1594
|
-
const o =
|
|
1595
|
-
|
|
1596
|
-
const
|
|
1597
|
-
var
|
|
1598
|
-
(
|
|
1599
|
-
}, l =
|
|
1600
|
-
!(o != null && o.value) || !a.height.value || !a.width.value || (o.value.addPass(s.value),
|
|
1789
|
+
const o = J(Qe), s = H(n()), { sizes: a, invalidate: r } = y();
|
|
1790
|
+
t && g(t, () => r());
|
|
1791
|
+
const i = () => {
|
|
1792
|
+
var d;
|
|
1793
|
+
(d = o == null ? void 0 : o.value) == null || d.removePass(s.value), s.value.dispose();
|
|
1794
|
+
}, l = w(() => {
|
|
1795
|
+
!(o != null && o.value) || !a.height.value || !a.width.value || (o.value.addPass(s.value), ce(() => l()));
|
|
1601
1796
|
});
|
|
1602
|
-
return
|
|
1603
|
-
() =>
|
|
1797
|
+
return e && g(
|
|
1798
|
+
() => e.map((d) => t == null ? void 0 : t[d]),
|
|
1604
1799
|
() => {
|
|
1605
1800
|
if (!(o != null && o.value))
|
|
1606
1801
|
return;
|
|
1607
|
-
const
|
|
1608
|
-
~
|
|
1802
|
+
const d = o.value.passes.findIndex((p) => p === s.value);
|
|
1803
|
+
~d && (i(), s.value = n(), o.value.insertPass(s.value, d));
|
|
1609
1804
|
}
|
|
1610
|
-
),
|
|
1611
|
-
|
|
1805
|
+
), W(() => {
|
|
1806
|
+
i();
|
|
1612
1807
|
}), { pass: s };
|
|
1613
|
-
},
|
|
1808
|
+
}, Nt = {
|
|
1614
1809
|
uniforms: {
|
|
1615
1810
|
tDiffuse: { value: null },
|
|
1616
1811
|
//diffuse texture
|
|
@@ -1705,53 +1900,53 @@ const Xe = Symbol("effectComposerThree"), ho = /* @__PURE__ */ u({
|
|
|
1705
1900
|
}`
|
|
1706
1901
|
)
|
|
1707
1902
|
};
|
|
1708
|
-
class
|
|
1709
|
-
constructor(
|
|
1903
|
+
class Ue extends D {
|
|
1904
|
+
constructor(t = 64) {
|
|
1710
1905
|
super();
|
|
1711
|
-
const
|
|
1712
|
-
this.uniforms =
|
|
1906
|
+
const e = Nt;
|
|
1907
|
+
this.uniforms = L.clone(e.uniforms), this.heightMap = this.generateHeightmap(t), this.uniforms.tDisp.value = this.heightMap, this.material = new T({
|
|
1713
1908
|
uniforms: this.uniforms,
|
|
1714
|
-
vertexShader:
|
|
1715
|
-
fragmentShader:
|
|
1909
|
+
vertexShader: e.vertexShader,
|
|
1910
|
+
fragmentShader: e.fragmentShader
|
|
1716
1911
|
}), this.fsQuad = new R(this.material), this.goWild = !1, this.curF = 0, this.generateTrigger();
|
|
1717
1912
|
}
|
|
1718
|
-
render(
|
|
1719
|
-
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 =
|
|
1913
|
+
render(t, e, o) {
|
|
1914
|
+
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 = M.randFloat(-Math.PI, Math.PI), this.uniforms.seed_x.value = M.randFloat(-1, 1), this.uniforms.seed_y.value = M.randFloat(-1, 1), this.uniforms.distortion_x.value = M.randFloat(0, 1), this.uniforms.distortion_y.value = M.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 = M.randFloat(-Math.PI, Math.PI), this.uniforms.distortion_x.value = M.randFloat(0, 1), this.uniforms.distortion_y.value = M.randFloat(0, 1), this.uniforms.seed_x.value = M.randFloat(-0.3, 0.3), this.uniforms.seed_y.value = M.randFloat(-0.3, 0.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));
|
|
1720
1915
|
}
|
|
1721
1916
|
generateTrigger() {
|
|
1722
|
-
this.randX =
|
|
1917
|
+
this.randX = M.randInt(120, 240);
|
|
1723
1918
|
}
|
|
1724
|
-
generateHeightmap(
|
|
1725
|
-
const
|
|
1919
|
+
generateHeightmap(t) {
|
|
1920
|
+
const e = new Float32Array(t * t), o = t * t;
|
|
1726
1921
|
for (let a = 0; a < o; a++) {
|
|
1727
|
-
const
|
|
1728
|
-
|
|
1922
|
+
const r = M.randFloat(0, 1);
|
|
1923
|
+
e[a] = r;
|
|
1729
1924
|
}
|
|
1730
|
-
const s = new
|
|
1925
|
+
const s = new it(e, t, t, lt, ut);
|
|
1731
1926
|
return s.needsUpdate = !0, s;
|
|
1732
1927
|
}
|
|
1733
1928
|
dispose() {
|
|
1734
1929
|
this.material.dispose(), this.heightMap.dispose(), this.fsQuad.dispose();
|
|
1735
1930
|
}
|
|
1736
1931
|
}
|
|
1737
|
-
const
|
|
1932
|
+
const Mo = /* @__PURE__ */ u({
|
|
1738
1933
|
__name: "Glitch",
|
|
1739
1934
|
props: {
|
|
1740
1935
|
dtSize: {},
|
|
1741
1936
|
goWild: { type: Boolean }
|
|
1742
1937
|
},
|
|
1743
|
-
setup(
|
|
1744
|
-
const
|
|
1745
|
-
|
|
1746
|
-
const { onBeforeRender: s } =
|
|
1747
|
-
return s(({ invalidate: a }) => a()),
|
|
1748
|
-
[[() =>
|
|
1938
|
+
setup(n, { expose: t }) {
|
|
1939
|
+
const e = n, { pass: o } = U(() => new Ue(e.dtSize), e, ["dtSize"]);
|
|
1940
|
+
t({ pass: o });
|
|
1941
|
+
const { onBeforeRender: s } = I();
|
|
1942
|
+
return s(({ invalidate: a }) => a()), v(
|
|
1943
|
+
[[() => e.goWild, "goWild"]],
|
|
1749
1944
|
o,
|
|
1750
|
-
() => new
|
|
1945
|
+
() => new Ue()
|
|
1751
1946
|
), () => {
|
|
1752
1947
|
};
|
|
1753
1948
|
}
|
|
1754
|
-
}),
|
|
1949
|
+
}), Q = {
|
|
1755
1950
|
name: "HalftoneShader",
|
|
1756
1951
|
uniforms: {
|
|
1757
1952
|
tDiffuse: { value: null },
|
|
@@ -2055,28 +2250,28 @@ const po = /* @__PURE__ */ u({
|
|
|
2055
2250
|
}`
|
|
2056
2251
|
)
|
|
2057
2252
|
};
|
|
2058
|
-
class
|
|
2059
|
-
constructor(
|
|
2060
|
-
super(), this.uniforms =
|
|
2253
|
+
class zt extends D {
|
|
2254
|
+
constructor(t, e, o) {
|
|
2255
|
+
super(), this.uniforms = L.clone(Q.uniforms), this.material = new T({
|
|
2061
2256
|
uniforms: this.uniforms,
|
|
2062
|
-
fragmentShader:
|
|
2063
|
-
vertexShader:
|
|
2064
|
-
}), this.uniforms.width.value =
|
|
2257
|
+
fragmentShader: Q.fragmentShader,
|
|
2258
|
+
vertexShader: Q.vertexShader
|
|
2259
|
+
}), this.uniforms.width.value = t, this.uniforms.height.value = e;
|
|
2065
2260
|
for (const s in o)
|
|
2066
2261
|
o.hasOwnProperty(s) && this.uniforms.hasOwnProperty(s) && (this.uniforms[s].value = o[s]);
|
|
2067
2262
|
this.fsQuad = new R(this.material);
|
|
2068
2263
|
}
|
|
2069
|
-
render(
|
|
2070
|
-
this.material.uniforms.tDiffuse.value = o.texture, this.renderToScreen ? (
|
|
2264
|
+
render(t, e, o) {
|
|
2265
|
+
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));
|
|
2071
2266
|
}
|
|
2072
|
-
setSize(
|
|
2073
|
-
this.uniforms.width.value =
|
|
2267
|
+
setSize(t, e) {
|
|
2268
|
+
this.uniforms.width.value = t, this.uniforms.height.value = e;
|
|
2074
2269
|
}
|
|
2075
2270
|
dispose() {
|
|
2076
2271
|
this.material.dispose(), this.fsQuad.dispose();
|
|
2077
2272
|
}
|
|
2078
2273
|
}
|
|
2079
|
-
const
|
|
2274
|
+
const To = /* @__PURE__ */ u({
|
|
2080
2275
|
__name: "Halftone",
|
|
2081
2276
|
props: {
|
|
2082
2277
|
shape: {},
|
|
@@ -2089,55 +2284,55 @@ const mo = /* @__PURE__ */ u({
|
|
|
2089
2284
|
greyscale: { type: Boolean },
|
|
2090
2285
|
blendingMode: {}
|
|
2091
2286
|
},
|
|
2092
|
-
setup(
|
|
2093
|
-
const
|
|
2287
|
+
setup(n, { expose: t }) {
|
|
2288
|
+
const e = n, { sizes: o } = y(), s = O(
|
|
2094
2289
|
() => Object.fromEntries(
|
|
2095
|
-
Object.entries(
|
|
2290
|
+
Object.entries(e).filter(([r, i]) => i !== void 0)
|
|
2096
2291
|
)
|
|
2097
|
-
), { pass: a } =
|
|
2292
|
+
), { pass: a } = U(() => new zt(
|
|
2098
2293
|
o.width.value,
|
|
2099
2294
|
o.height.value,
|
|
2100
2295
|
s.value
|
|
2101
|
-
),
|
|
2102
|
-
return
|
|
2296
|
+
), e);
|
|
2297
|
+
return t({ pass: a }), w(() => {
|
|
2103
2298
|
a.value.setSize(o.width.value, o.height.value);
|
|
2104
|
-
}),
|
|
2105
|
-
Object.entries(
|
|
2106
|
-
|
|
2299
|
+
}), w(() => {
|
|
2300
|
+
Object.entries(e).forEach(([r, i]) => {
|
|
2301
|
+
r in a.value.uniforms && (a.value.uniforms[r].value = i ?? Q.uniforms[r].value);
|
|
2107
2302
|
});
|
|
2108
2303
|
}), () => {
|
|
2109
2304
|
};
|
|
2110
2305
|
}
|
|
2111
2306
|
});
|
|
2112
|
-
class
|
|
2113
|
-
constructor(
|
|
2114
|
-
super(), this.pixelSize =
|
|
2307
|
+
class Ge extends D {
|
|
2308
|
+
constructor(t, e, o, s = {}) {
|
|
2309
|
+
super(), this.pixelSize = t, this.resolution = new f(), this.renderResolution = new f(), this.pixelatedMaterial = this.createPixelatedMaterial(), this.normalMaterial = new ct(), this.fsQuad = new R(this.pixelatedMaterial), this.scene = e, this.camera = o, this.normalEdgeStrength = s.normalEdgeStrength || 0.3, this.depthEdgeStrength = s.depthEdgeStrength || 0.4, this.beautyRenderTarget = new F(), this.beautyRenderTarget.texture.minFilter = N, this.beautyRenderTarget.texture.magFilter = N, this.beautyRenderTarget.texture.type = P, this.beautyRenderTarget.depthTexture = new dt(), this.normalRenderTarget = new F(), this.normalRenderTarget.texture.minFilter = N, this.normalRenderTarget.texture.magFilter = N, this.normalRenderTarget.texture.type = P;
|
|
2115
2310
|
}
|
|
2116
2311
|
dispose() {
|
|
2117
2312
|
this.beautyRenderTarget.dispose(), this.normalRenderTarget.dispose(), this.pixelatedMaterial.dispose(), this.normalMaterial.dispose(), this.fsQuad.dispose();
|
|
2118
2313
|
}
|
|
2119
|
-
setSize(
|
|
2120
|
-
this.resolution.set(
|
|
2314
|
+
setSize(t, e) {
|
|
2315
|
+
this.resolution.set(t, e), this.renderResolution.set(t / this.pixelSize | 0, e / this.pixelSize | 0);
|
|
2121
2316
|
const { x: o, y: s } = this.renderResolution;
|
|
2122
2317
|
this.beautyRenderTarget.setSize(o, s), this.normalRenderTarget.setSize(o, s), this.fsQuad.material.uniforms.resolution.value.set(o, s, 1 / o, 1 / s);
|
|
2123
2318
|
}
|
|
2124
|
-
setPixelSize(
|
|
2125
|
-
this.pixelSize =
|
|
2319
|
+
setPixelSize(t) {
|
|
2320
|
+
this.pixelSize = t, this.setSize(this.resolution.x, this.resolution.y);
|
|
2126
2321
|
}
|
|
2127
|
-
render(
|
|
2322
|
+
render(t, e) {
|
|
2128
2323
|
const o = this.fsQuad.material.uniforms;
|
|
2129
|
-
o.normalEdgeStrength.value = this.normalEdgeStrength, o.depthEdgeStrength.value = this.depthEdgeStrength,
|
|
2324
|
+
o.normalEdgeStrength.value = this.normalEdgeStrength, o.depthEdgeStrength.value = this.depthEdgeStrength, t.setRenderTarget(this.beautyRenderTarget), t.render(this.scene, this.camera);
|
|
2130
2325
|
const s = this.scene.overrideMaterial;
|
|
2131
|
-
|
|
2326
|
+
t.setRenderTarget(this.normalRenderTarget), this.scene.overrideMaterial = this.normalMaterial, t.render(this.scene, this.camera), this.scene.overrideMaterial = s, 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);
|
|
2132
2327
|
}
|
|
2133
2328
|
createPixelatedMaterial() {
|
|
2134
|
-
return new
|
|
2329
|
+
return new T({
|
|
2135
2330
|
uniforms: {
|
|
2136
2331
|
tDiffuse: { value: null },
|
|
2137
2332
|
tDepth: { value: null },
|
|
2138
2333
|
tNormal: { value: null },
|
|
2139
2334
|
resolution: {
|
|
2140
|
-
value: new
|
|
2335
|
+
value: new ft(
|
|
2141
2336
|
this.renderResolution.x,
|
|
2142
2337
|
this.renderResolution.y,
|
|
2143
2338
|
1 / this.renderResolution.x,
|
|
@@ -2256,28 +2451,28 @@ class Fe extends C {
|
|
|
2256
2451
|
});
|
|
2257
2452
|
}
|
|
2258
2453
|
}
|
|
2259
|
-
const
|
|
2454
|
+
const Co = /* @__PURE__ */ u({
|
|
2260
2455
|
__name: "Pixelation",
|
|
2261
2456
|
props: {
|
|
2262
2457
|
pixelSize: {},
|
|
2263
2458
|
depthEdgeStrength: {},
|
|
2264
2459
|
normalEdgeStrength: {}
|
|
2265
2460
|
},
|
|
2266
|
-
setup(
|
|
2267
|
-
const
|
|
2268
|
-
return
|
|
2269
|
-
a.value.setPixelSize(
|
|
2270
|
-
}),
|
|
2461
|
+
setup(n, { expose: t }) {
|
|
2462
|
+
const e = n, { scene: o, camera: s } = y(), { pass: a } = U(() => new Ge(e.pixelSize, o.value, s.value), e);
|
|
2463
|
+
return t({ pass: a }), w(() => {
|
|
2464
|
+
a.value.setPixelSize(e.pixelSize);
|
|
2465
|
+
}), v(
|
|
2271
2466
|
[
|
|
2272
|
-
[() =>
|
|
2273
|
-
[() =>
|
|
2467
|
+
[() => e.depthEdgeStrength, "depthEdgeStrength"],
|
|
2468
|
+
[() => e.normalEdgeStrength, "normalEdgeStrength"]
|
|
2274
2469
|
],
|
|
2275
2470
|
a,
|
|
2276
|
-
() => new
|
|
2471
|
+
() => new Ge(1, o.value, s.value)
|
|
2277
2472
|
), () => {
|
|
2278
2473
|
};
|
|
2279
2474
|
}
|
|
2280
|
-
}),
|
|
2475
|
+
}), Wt = {
|
|
2281
2476
|
name: "OutputShader",
|
|
2282
2477
|
uniforms: {
|
|
2283
2478
|
tDiffuse: { value: null },
|
|
@@ -2363,39 +2558,39 @@ const vo = /* @__PURE__ */ u({
|
|
|
2363
2558
|
}`
|
|
2364
2559
|
)
|
|
2365
2560
|
};
|
|
2366
|
-
class
|
|
2561
|
+
class Ut extends D {
|
|
2367
2562
|
constructor() {
|
|
2368
2563
|
super();
|
|
2369
|
-
const
|
|
2370
|
-
this.uniforms =
|
|
2371
|
-
name:
|
|
2564
|
+
const t = Wt;
|
|
2565
|
+
this.uniforms = L.clone(t.uniforms), this.material = new ht({
|
|
2566
|
+
name: t.name,
|
|
2372
2567
|
uniforms: this.uniforms,
|
|
2373
|
-
vertexShader:
|
|
2374
|
-
fragmentShader:
|
|
2568
|
+
vertexShader: t.vertexShader,
|
|
2569
|
+
fragmentShader: t.fragmentShader
|
|
2375
2570
|
}), this.fsQuad = new R(this.material), this._outputColorSpace = null, this._toneMapping = null;
|
|
2376
2571
|
}
|
|
2377
|
-
render(
|
|
2378
|
-
this.uniforms.tDiffuse.value = o.texture, this.uniforms.toneMappingExposure.value =
|
|
2572
|
+
render(t, e, o) {
|
|
2573
|
+
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 = {}, pt.getTransfer(this._outputColorSpace) === mt && (this.material.defines.SRGB_TRANSFER = ""), this._toneMapping === vt ? this.material.defines.LINEAR_TONE_MAPPING = "" : this._toneMapping === gt ? this.material.defines.REINHARD_TONE_MAPPING = "" : this._toneMapping === xt ? this.material.defines.CINEON_TONE_MAPPING = "" : this._toneMapping === bt ? this.material.defines.ACES_FILMIC_TONE_MAPPING = "" : this._toneMapping === St ? this.material.defines.AGX_TONE_MAPPING = "" : this._toneMapping === wt ? this.material.defines.NEUTRAL_TONE_MAPPING = "" : this._toneMapping === At && (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));
|
|
2379
2574
|
}
|
|
2380
2575
|
dispose() {
|
|
2381
2576
|
this.material.dispose(), this.fsQuad.dispose();
|
|
2382
2577
|
}
|
|
2383
2578
|
}
|
|
2384
|
-
const
|
|
2579
|
+
const Eo = /* @__PURE__ */ u({
|
|
2385
2580
|
__name: "Output",
|
|
2386
|
-
setup(
|
|
2387
|
-
const { pass:
|
|
2388
|
-
return
|
|
2581
|
+
setup(n, { expose: t }) {
|
|
2582
|
+
const { pass: e } = U(() => new Ut());
|
|
2583
|
+
return t({ pass: e }), () => {
|
|
2389
2584
|
};
|
|
2390
2585
|
}
|
|
2391
|
-
}),
|
|
2586
|
+
}), Y = {
|
|
2392
2587
|
name: "SMAAEdgesShader",
|
|
2393
2588
|
defines: {
|
|
2394
2589
|
SMAA_THRESHOLD: "0.1"
|
|
2395
2590
|
},
|
|
2396
2591
|
uniforms: {
|
|
2397
2592
|
tDiffuse: { value: null },
|
|
2398
|
-
resolution: { value: new
|
|
2593
|
+
resolution: { value: new f(1 / 1024, 1 / 512) }
|
|
2399
2594
|
},
|
|
2400
2595
|
vertexShader: (
|
|
2401
2596
|
/* glsl */
|
|
@@ -2489,7 +2684,7 @@ const go = /* @__PURE__ */ u({
|
|
|
2489
2684
|
|
|
2490
2685
|
}`
|
|
2491
2686
|
)
|
|
2492
|
-
},
|
|
2687
|
+
}, k = {
|
|
2493
2688
|
name: "SMAAWeightsShader",
|
|
2494
2689
|
defines: {
|
|
2495
2690
|
SMAA_MAX_SEARCH_STEPS: "8",
|
|
@@ -2501,7 +2696,7 @@ const go = /* @__PURE__ */ u({
|
|
|
2501
2696
|
tDiffuse: { value: null },
|
|
2502
2697
|
tArea: { value: null },
|
|
2503
2698
|
tSearch: { value: null },
|
|
2504
|
-
resolution: { value: new
|
|
2699
|
+
resolution: { value: new f(1 / 1024, 1 / 512) }
|
|
2505
2700
|
},
|
|
2506
2701
|
vertexShader: (
|
|
2507
2702
|
/* glsl */
|
|
@@ -2739,12 +2934,12 @@ const go = /* @__PURE__ */ u({
|
|
|
2739
2934
|
|
|
2740
2935
|
}`
|
|
2741
2936
|
)
|
|
2742
|
-
},
|
|
2937
|
+
}, ue = {
|
|
2743
2938
|
name: "SMAABlendShader",
|
|
2744
2939
|
uniforms: {
|
|
2745
2940
|
tDiffuse: { value: null },
|
|
2746
2941
|
tColor: { value: null },
|
|
2747
|
-
resolution: { value: new
|
|
2942
|
+
resolution: { value: new f(1 / 1024, 1 / 512) }
|
|
2748
2943
|
},
|
|
2749
2944
|
vertexShader: (
|
|
2750
2945
|
/* glsl */
|
|
@@ -2829,43 +3024,43 @@ const go = /* @__PURE__ */ u({
|
|
|
2829
3024
|
}`
|
|
2830
3025
|
)
|
|
2831
3026
|
};
|
|
2832
|
-
class
|
|
2833
|
-
constructor(
|
|
2834
|
-
super(), this.edgesRT = new
|
|
3027
|
+
class Gt extends D {
|
|
3028
|
+
constructor(t, e) {
|
|
3029
|
+
super(), this.edgesRT = new F(t, e, {
|
|
2835
3030
|
depthBuffer: !1,
|
|
2836
|
-
type:
|
|
2837
|
-
}), this.edgesRT.texture.name = "SMAAPass.edges", this.weightsRT = new
|
|
3031
|
+
type: P
|
|
3032
|
+
}), this.edgesRT.texture.name = "SMAAPass.edges", this.weightsRT = new F(t, e, {
|
|
2838
3033
|
depthBuffer: !1,
|
|
2839
|
-
type:
|
|
3034
|
+
type: P
|
|
2840
3035
|
}), this.weightsRT.texture.name = "SMAAPass.weights";
|
|
2841
3036
|
const o = this, s = new Image();
|
|
2842
3037
|
s.src = this.getAreaTexture(), s.onload = function() {
|
|
2843
3038
|
o.areaTexture.needsUpdate = !0;
|
|
2844
|
-
}, this.areaTexture = new
|
|
3039
|
+
}, this.areaTexture = new Le(), this.areaTexture.name = "SMAAPass.area", this.areaTexture.image = s, this.areaTexture.minFilter = yt, this.areaTexture.generateMipmaps = !1, this.areaTexture.flipY = !1;
|
|
2845
3040
|
const a = new Image();
|
|
2846
3041
|
a.src = this.getSearchTexture(), a.onload = function() {
|
|
2847
3042
|
o.searchTexture.needsUpdate = !0;
|
|
2848
|
-
}, this.searchTexture = new
|
|
2849
|
-
defines: Object.assign({},
|
|
3043
|
+
}, this.searchTexture = new Le(), this.searchTexture.name = "SMAAPass.search", this.searchTexture.image = a, this.searchTexture.magFilter = N, this.searchTexture.minFilter = N, this.searchTexture.generateMipmaps = !1, this.searchTexture.flipY = !1, this.uniformsEdges = L.clone(Y.uniforms), this.uniformsEdges.resolution.value.set(1 / t, 1 / e), this.materialEdges = new T({
|
|
3044
|
+
defines: Object.assign({}, Y.defines),
|
|
2850
3045
|
uniforms: this.uniformsEdges,
|
|
2851
|
-
vertexShader:
|
|
2852
|
-
fragmentShader:
|
|
2853
|
-
}), this.uniformsWeights =
|
|
2854
|
-
defines: Object.assign({},
|
|
3046
|
+
vertexShader: Y.vertexShader,
|
|
3047
|
+
fragmentShader: Y.fragmentShader
|
|
3048
|
+
}), this.uniformsWeights = L.clone(k.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 T({
|
|
3049
|
+
defines: Object.assign({}, k.defines),
|
|
2855
3050
|
uniforms: this.uniformsWeights,
|
|
2856
|
-
vertexShader:
|
|
2857
|
-
fragmentShader:
|
|
2858
|
-
}), this.uniformsBlend =
|
|
3051
|
+
vertexShader: k.vertexShader,
|
|
3052
|
+
fragmentShader: k.fragmentShader
|
|
3053
|
+
}), this.uniformsBlend = L.clone(ue.uniforms), this.uniformsBlend.resolution.value.set(1 / t, 1 / e), this.uniformsBlend.tDiffuse.value = this.weightsRT.texture, this.materialBlend = new T({
|
|
2859
3054
|
uniforms: this.uniformsBlend,
|
|
2860
|
-
vertexShader:
|
|
2861
|
-
fragmentShader:
|
|
3055
|
+
vertexShader: ue.vertexShader,
|
|
3056
|
+
fragmentShader: ue.fragmentShader
|
|
2862
3057
|
}), this.fsQuad = new R(null);
|
|
2863
3058
|
}
|
|
2864
|
-
render(
|
|
2865
|
-
this.uniformsEdges.tDiffuse.value = o.texture, this.fsQuad.material = this.materialEdges,
|
|
3059
|
+
render(t, e, o) {
|
|
3060
|
+
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));
|
|
2866
3061
|
}
|
|
2867
|
-
setSize(
|
|
2868
|
-
this.edgesRT.setSize(
|
|
3062
|
+
setSize(t, e) {
|
|
3063
|
+
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);
|
|
2869
3064
|
}
|
|
2870
3065
|
getAreaTexture() {
|
|
2871
3066
|
return "";
|
|
@@ -2877,27 +3072,27 @@ class Ft extends C {
|
|
|
2877
3072
|
this.edgesRT.dispose(), this.weightsRT.dispose(), this.areaTexture.dispose(), this.searchTexture.dispose(), this.materialEdges.dispose(), this.materialWeights.dispose(), this.materialBlend.dispose(), this.fsQuad.dispose();
|
|
2878
3073
|
}
|
|
2879
3074
|
}
|
|
2880
|
-
const
|
|
3075
|
+
const Po = /* @__PURE__ */ u({
|
|
2881
3076
|
__name: "SMAA",
|
|
2882
3077
|
props: {
|
|
2883
3078
|
width: {},
|
|
2884
3079
|
height: {}
|
|
2885
3080
|
},
|
|
2886
|
-
setup(
|
|
2887
|
-
const
|
|
2888
|
-
return
|
|
2889
|
-
|
|
3081
|
+
setup(n, { expose: t }) {
|
|
3082
|
+
const e = n, { sizes: o } = y(), { pixelRatio: s } = Ye(), a = O(() => e.width ?? o.width.value * s.value), r = O(() => e.height ?? o.height.value * s.value), { pass: i } = U(() => new Gt(a.value, r.value), e);
|
|
3083
|
+
return t({ pass: i }), w(() => {
|
|
3084
|
+
i.value.setSize(a.value, r.value);
|
|
2890
3085
|
}), () => {
|
|
2891
3086
|
};
|
|
2892
3087
|
}
|
|
2893
|
-
}),
|
|
3088
|
+
}), Ke = {
|
|
2894
3089
|
name: "LuminosityHighPassShader",
|
|
2895
3090
|
shaderID: "luminosityHighPass",
|
|
2896
3091
|
uniforms: {
|
|
2897
3092
|
tDiffuse: { value: null },
|
|
2898
3093
|
luminosityThreshold: { value: 1 },
|
|
2899
3094
|
smoothWidth: { value: 1 },
|
|
2900
|
-
defaultColor: { value: new
|
|
3095
|
+
defaultColor: { value: new K(0) },
|
|
2901
3096
|
defaultOpacity: { value: 0 }
|
|
2902
3097
|
},
|
|
2903
3098
|
vertexShader: (
|
|
@@ -2941,80 +3136,80 @@ const xo = /* @__PURE__ */ u({
|
|
|
2941
3136
|
}`
|
|
2942
3137
|
)
|
|
2943
3138
|
};
|
|
2944
|
-
class
|
|
2945
|
-
constructor(
|
|
2946
|
-
super(), this.strength =
|
|
2947
|
-
let a = Math.round(this.resolution.x / 2),
|
|
2948
|
-
this.renderTargetBright = new
|
|
2949
|
-
for (let
|
|
2950
|
-
const c = new
|
|
2951
|
-
c.texture.name = "UnrealBloomPass.h" +
|
|
2952
|
-
const
|
|
2953
|
-
|
|
3139
|
+
class z extends D {
|
|
3140
|
+
constructor(t, e, o, s) {
|
|
3141
|
+
super(), this.strength = e !== void 0 ? e : 1, this.radius = o, this.threshold = s, this.resolution = t !== void 0 ? new f(t.x, t.y) : new f(256, 256), this.clearColor = new K(0, 0, 0), this.renderTargetsHorizontal = [], this.renderTargetsVertical = [], this.nMips = 5;
|
|
3142
|
+
let a = Math.round(this.resolution.x / 2), r = Math.round(this.resolution.y / 2);
|
|
3143
|
+
this.renderTargetBright = new F(a, r, { type: P }), this.renderTargetBright.texture.name = "UnrealBloomPass.bright", this.renderTargetBright.texture.generateMipmaps = !1;
|
|
3144
|
+
for (let b = 0; b < this.nMips; b++) {
|
|
3145
|
+
const c = new F(a, r, { type: P });
|
|
3146
|
+
c.texture.name = "UnrealBloomPass.h" + b, c.texture.generateMipmaps = !1, this.renderTargetsHorizontal.push(c);
|
|
3147
|
+
const S = new F(a, r, { type: P });
|
|
3148
|
+
S.texture.name = "UnrealBloomPass.v" + b, S.texture.generateMipmaps = !1, this.renderTargetsVertical.push(S), a = Math.round(a / 2), r = Math.round(r / 2);
|
|
2954
3149
|
}
|
|
2955
|
-
const
|
|
2956
|
-
this.highPassUniforms =
|
|
3150
|
+
const i = Ke;
|
|
3151
|
+
this.highPassUniforms = L.clone(i.uniforms), this.highPassUniforms.luminosityThreshold.value = s, this.highPassUniforms.smoothWidth.value = 0.01, this.materialHighPassFilter = new T({
|
|
2957
3152
|
uniforms: this.highPassUniforms,
|
|
2958
|
-
vertexShader:
|
|
2959
|
-
fragmentShader:
|
|
3153
|
+
vertexShader: i.vertexShader,
|
|
3154
|
+
fragmentShader: i.fragmentShader
|
|
2960
3155
|
}), this.separableBlurMaterials = [];
|
|
2961
3156
|
const l = [3, 5, 7, 9, 11];
|
|
2962
|
-
a = Math.round(this.resolution.x / 2),
|
|
2963
|
-
for (let
|
|
2964
|
-
this.separableBlurMaterials.push(this.getSeparableBlurMaterial(l[
|
|
2965
|
-
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 =
|
|
2966
|
-
const
|
|
2967
|
-
this.compositeMaterial.uniforms.bloomFactors.value =
|
|
2968
|
-
const
|
|
2969
|
-
this.copyUniforms =
|
|
3157
|
+
a = Math.round(this.resolution.x / 2), r = Math.round(this.resolution.y / 2);
|
|
3158
|
+
for (let b = 0; b < this.nMips; b++)
|
|
3159
|
+
this.separableBlurMaterials.push(this.getSeparableBlurMaterial(l[b])), this.separableBlurMaterials[b].uniforms.invSize.value = new f(1 / a, 1 / r), a = Math.round(a / 2), r = Math.round(r / 2);
|
|
3160
|
+
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 = 0.1;
|
|
3161
|
+
const d = [1, 0.8, 0.6, 0.4, 0.2];
|
|
3162
|
+
this.compositeMaterial.uniforms.bloomFactors.value = d, this.bloomTintColors = [new B(1, 1, 1), new B(1, 1, 1), new B(1, 1, 1), new B(1, 1, 1), new B(1, 1, 1)], this.compositeMaterial.uniforms.bloomTintColors.value = this.bloomTintColors;
|
|
3163
|
+
const p = qe;
|
|
3164
|
+
this.copyUniforms = L.clone(p.uniforms), this.blendMaterial = new T({
|
|
2970
3165
|
uniforms: this.copyUniforms,
|
|
2971
|
-
vertexShader:
|
|
2972
|
-
fragmentShader:
|
|
2973
|
-
blending:
|
|
3166
|
+
vertexShader: p.vertexShader,
|
|
3167
|
+
fragmentShader: p.fragmentShader,
|
|
3168
|
+
blending: Mt,
|
|
2974
3169
|
depthTest: !1,
|
|
2975
3170
|
depthWrite: !1,
|
|
2976
3171
|
transparent: !0
|
|
2977
|
-
}), this.enabled = !0, this.needsSwap = !1, this._oldClearColor = new
|
|
3172
|
+
}), this.enabled = !0, this.needsSwap = !1, this._oldClearColor = new K(), this.oldClearAlpha = 1, this.basic = new Ve(), this.fsQuad = new R(null);
|
|
2978
3173
|
}
|
|
2979
3174
|
dispose() {
|
|
2980
|
-
for (let
|
|
2981
|
-
this.renderTargetsHorizontal[
|
|
2982
|
-
for (let
|
|
2983
|
-
this.renderTargetsVertical[
|
|
3175
|
+
for (let t = 0; t < this.renderTargetsHorizontal.length; t++)
|
|
3176
|
+
this.renderTargetsHorizontal[t].dispose();
|
|
3177
|
+
for (let t = 0; t < this.renderTargetsVertical.length; t++)
|
|
3178
|
+
this.renderTargetsVertical[t].dispose();
|
|
2984
3179
|
this.renderTargetBright.dispose();
|
|
2985
|
-
for (let
|
|
2986
|
-
this.separableBlurMaterials[
|
|
3180
|
+
for (let t = 0; t < this.separableBlurMaterials.length; t++)
|
|
3181
|
+
this.separableBlurMaterials[t].dispose();
|
|
2987
3182
|
this.compositeMaterial.dispose(), this.blendMaterial.dispose(), this.basic.dispose(), this.fsQuad.dispose();
|
|
2988
3183
|
}
|
|
2989
|
-
setSize(
|
|
2990
|
-
let o = Math.round(
|
|
3184
|
+
setSize(t, e) {
|
|
3185
|
+
let o = Math.round(t / 2), s = Math.round(e / 2);
|
|
2991
3186
|
this.renderTargetBright.setSize(o, s);
|
|
2992
3187
|
for (let a = 0; a < this.nMips; a++)
|
|
2993
|
-
this.renderTargetsHorizontal[a].setSize(o, s), this.renderTargetsVertical[a].setSize(o, s), this.separableBlurMaterials[a].uniforms.invSize.value = new
|
|
3188
|
+
this.renderTargetsHorizontal[a].setSize(o, s), this.renderTargetsVertical[a].setSize(o, s), this.separableBlurMaterials[a].uniforms.invSize.value = new f(1 / o, 1 / s), o = Math.round(o / 2), s = Math.round(s / 2);
|
|
2994
3189
|
}
|
|
2995
|
-
render(
|
|
2996
|
-
|
|
2997
|
-
const
|
|
2998
|
-
|
|
2999
|
-
let
|
|
3190
|
+
render(t, e, o, s, a) {
|
|
3191
|
+
t.getClearColor(this._oldClearColor), this.oldClearAlpha = t.getClearAlpha();
|
|
3192
|
+
const r = t.autoClear;
|
|
3193
|
+
t.autoClear = !1, t.setClearColor(this.clearColor, 0), a && 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);
|
|
3194
|
+
let i = this.renderTargetBright;
|
|
3000
3195
|
for (let l = 0; l < this.nMips; l++)
|
|
3001
|
-
this.fsQuad.material = this.separableBlurMaterials[l], this.separableBlurMaterials[l].uniforms.colorTexture.value =
|
|
3002
|
-
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,
|
|
3003
|
-
}
|
|
3004
|
-
getSeparableBlurMaterial(
|
|
3005
|
-
const
|
|
3006
|
-
for (let o = 0; o <
|
|
3007
|
-
|
|
3008
|
-
return new
|
|
3196
|
+
this.fsQuad.material = this.separableBlurMaterials[l], this.separableBlurMaterials[l].uniforms.colorTexture.value = i.texture, this.separableBlurMaterials[l].uniforms.direction.value = z.BlurDirectionX, t.setRenderTarget(this.renderTargetsHorizontal[l]), t.clear(), this.fsQuad.render(t), this.separableBlurMaterials[l].uniforms.colorTexture.value = this.renderTargetsHorizontal[l].texture, this.separableBlurMaterials[l].uniforms.direction.value = z.BlurDirectionY, t.setRenderTarget(this.renderTargetsVertical[l]), t.clear(), this.fsQuad.render(t), i = this.renderTargetsVertical[l];
|
|
3197
|
+
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, a && 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 = r;
|
|
3198
|
+
}
|
|
3199
|
+
getSeparableBlurMaterial(t) {
|
|
3200
|
+
const e = [];
|
|
3201
|
+
for (let o = 0; o < t; o++)
|
|
3202
|
+
e.push(0.39894 * Math.exp(-0.5 * o * o / (t * t)) / t);
|
|
3203
|
+
return new T({
|
|
3009
3204
|
defines: {
|
|
3010
|
-
KERNEL_RADIUS:
|
|
3205
|
+
KERNEL_RADIUS: t
|
|
3011
3206
|
},
|
|
3012
3207
|
uniforms: {
|
|
3013
3208
|
colorTexture: { value: null },
|
|
3014
|
-
invSize: { value: new
|
|
3209
|
+
invSize: { value: new f(0.5, 0.5) },
|
|
3015
3210
|
// inverse texture size
|
|
3016
|
-
direction: { value: new
|
|
3017
|
-
gaussianCoefficients: { value:
|
|
3211
|
+
direction: { value: new f(0.5, 0.5) },
|
|
3212
|
+
gaussianCoefficients: { value: e }
|
|
3018
3213
|
// precomputed Gaussian coefficients
|
|
3019
3214
|
},
|
|
3020
3215
|
vertexShader: `varying vec2 vUv;
|
|
@@ -3045,10 +3240,10 @@ class B extends C {
|
|
|
3045
3240
|
}`
|
|
3046
3241
|
});
|
|
3047
3242
|
}
|
|
3048
|
-
getCompositeMaterial(
|
|
3049
|
-
return new
|
|
3243
|
+
getCompositeMaterial(t) {
|
|
3244
|
+
return new T({
|
|
3050
3245
|
defines: {
|
|
3051
|
-
NUM_MIPS:
|
|
3246
|
+
NUM_MIPS: t
|
|
3052
3247
|
},
|
|
3053
3248
|
uniforms: {
|
|
3054
3249
|
blurTexture1: { value: null },
|
|
@@ -3092,70 +3287,74 @@ class B extends C {
|
|
|
3092
3287
|
});
|
|
3093
3288
|
}
|
|
3094
3289
|
}
|
|
3095
|
-
|
|
3096
|
-
|
|
3097
|
-
const
|
|
3290
|
+
z.BlurDirectionX = new f(1, 0);
|
|
3291
|
+
z.BlurDirectionY = new f(0, 1);
|
|
3292
|
+
const Do = /* @__PURE__ */ u({
|
|
3098
3293
|
__name: "UnrealBloom",
|
|
3099
3294
|
props: {
|
|
3100
3295
|
radius: { default: 0 },
|
|
3101
3296
|
strength: { default: 1 },
|
|
3102
3297
|
threshold: { default: 0 }
|
|
3103
3298
|
},
|
|
3104
|
-
setup(
|
|
3105
|
-
const
|
|
3106
|
-
new
|
|
3107
|
-
|
|
3108
|
-
|
|
3109
|
-
|
|
3110
|
-
),
|
|
3111
|
-
return
|
|
3299
|
+
setup(n, { expose: t }) {
|
|
3300
|
+
const e = n, { sizes: o } = y(), { pass: s } = U(() => new z(
|
|
3301
|
+
new f(o.width.value, o.height.value),
|
|
3302
|
+
e.radius,
|
|
3303
|
+
e.strength,
|
|
3304
|
+
e.threshold
|
|
3305
|
+
), e);
|
|
3306
|
+
return t({ pass: s }), w(() => {
|
|
3112
3307
|
var a;
|
|
3113
|
-
s.value.radius =
|
|
3114
|
-
}),
|
|
3308
|
+
s.value.radius = e.radius ?? ((a = s.value.getCompositeMaterial().uniforms.bloomRadius) == null ? void 0 : a.value) ?? 0.1;
|
|
3309
|
+
}), w(() => {
|
|
3115
3310
|
var a;
|
|
3116
|
-
s.value.strength =
|
|
3117
|
-
}),
|
|
3311
|
+
s.value.strength = e.strength ?? ((a = s.value.getCompositeMaterial().uniforms.bloomStrength) == null ? void 0 : a.value) ?? 1;
|
|
3312
|
+
}), w(() => {
|
|
3118
3313
|
var a;
|
|
3119
|
-
s.value.threshold =
|
|
3314
|
+
s.value.threshold = e.threshold ?? ((a = Ke.uniforms.luminosityThreshold) == null ? void 0 : a.value) ?? 1;
|
|
3120
3315
|
}), () => {
|
|
3121
3316
|
};
|
|
3122
3317
|
}
|
|
3123
3318
|
});
|
|
3124
3319
|
export {
|
|
3125
|
-
|
|
3126
|
-
|
|
3127
|
-
|
|
3128
|
-
|
|
3129
|
-
|
|
3130
|
-
|
|
3131
|
-
|
|
3132
|
-
|
|
3133
|
-
|
|
3134
|
-
|
|
3135
|
-
|
|
3136
|
-
|
|
3137
|
-
|
|
3138
|
-
|
|
3139
|
-
|
|
3140
|
-
|
|
3141
|
-
|
|
3142
|
-
|
|
3143
|
-
|
|
3144
|
-
|
|
3145
|
-
|
|
3146
|
-
|
|
3147
|
-
|
|
3148
|
-
|
|
3149
|
-
|
|
3150
|
-
|
|
3151
|
-
|
|
3152
|
-
Zt as
|
|
3153
|
-
|
|
3154
|
-
|
|
3155
|
-
|
|
3156
|
-
|
|
3157
|
-
|
|
3158
|
-
|
|
3159
|
-
|
|
3160
|
-
|
|
3320
|
+
Ao as ASCIIPmndrs,
|
|
3321
|
+
$t as BarrelBlurPmndrs,
|
|
3322
|
+
kt as BloomPmndrs,
|
|
3323
|
+
xo as BrightnessContrastPmndrs,
|
|
3324
|
+
to as ChromaticAberrationPmndrs,
|
|
3325
|
+
ro as ColorAveragePmndrs,
|
|
3326
|
+
mo as ColorDepthPmndrs,
|
|
3327
|
+
qt as DepthOfFieldPmndrs,
|
|
3328
|
+
ho as DepthPickingPassPmndrs,
|
|
3329
|
+
uo as DotScreenPmndrs,
|
|
3330
|
+
yo as EffectComposer,
|
|
3331
|
+
Yt as EffectComposerPmndrs,
|
|
3332
|
+
So as FXAAPmndrs,
|
|
3333
|
+
go as FishEyePmndrs,
|
|
3334
|
+
Mo as Glitch,
|
|
3335
|
+
Qt as GlitchPmndrs,
|
|
3336
|
+
po as GodRaysPmndrs,
|
|
3337
|
+
vo as GridPmndrs,
|
|
3338
|
+
To as Halftone,
|
|
3339
|
+
oo as HueSaturationPmndrs,
|
|
3340
|
+
ao as KuwaharaPmndrs,
|
|
3341
|
+
no as LensDistortionPmndrs,
|
|
3342
|
+
fo as LinocutPmndrs,
|
|
3343
|
+
Kt as NoisePmndrs,
|
|
3344
|
+
Jt as OutlinePmndrs,
|
|
3345
|
+
Eo as Output,
|
|
3346
|
+
Co as Pixelation,
|
|
3347
|
+
Zt as PixelationPmndrs,
|
|
3348
|
+
Po as SMAA,
|
|
3349
|
+
bo as SMAAPmndrs,
|
|
3350
|
+
so as ScanlinePmndrs,
|
|
3351
|
+
co as SepiaPmndrs,
|
|
3352
|
+
io as ShockWavePmndrs,
|
|
3353
|
+
wo as TexturePmndrs,
|
|
3354
|
+
lo as TiltShiftPmndrs,
|
|
3355
|
+
eo as ToneMappingPmndrs,
|
|
3356
|
+
Do as UnrealBloom,
|
|
3357
|
+
_t as VignettePmndrs,
|
|
3358
|
+
U as useEffect,
|
|
3359
|
+
h as useEffectPmndrs
|
|
3161
3360
|
};
|