From 230174306c44486bc4f3da0a92c16b081fa67345 Mon Sep 17 00:00:00 2001 From: "Raoul v. R" Date: Fri, 18 Aug 2017 14:50:34 +0200 Subject: [PATCH] Version 2.3.0. --- build/postprocessing.js | 2 +- build/postprocessing.min.js | 2 +- package.json | 2 +- public/demo/index.js | 12 ++++++------ public/demo/index.min.js | 2 +- 5 files changed, 10 insertions(+), 10 deletions(-) diff --git a/build/postprocessing.js b/build/postprocessing.js index efa890c1e..5e232ef4d 100644 --- a/build/postprocessing.js +++ b/build/postprocessing.js @@ -1,5 +1,5 @@ /** - * postprocessing v2.2.0 build Aug 01 2017 + * postprocessing v2.3.0 build Aug 18 2017 * https://github.com/vanruesc/postprocessing * Copyright 2017 Raoul van RĂ¼schen, Zlib */ diff --git a/build/postprocessing.min.js b/build/postprocessing.min.js index 34d029aac..98d107bb2 100644 --- a/build/postprocessing.min.js +++ b/build/postprocessing.min.js @@ -1,5 +1,5 @@ /** - * postprocessing v2.2.0 build Aug 01 2017 + * postprocessing v2.3.0 build Aug 18 2017 * https://github.com/vanruesc/postprocessing * Copyright 2017 Raoul van RĂ¼schen, Zlib */ diff --git a/package.json b/package.json index f884b213d..8d55edfc7 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "postprocessing", - "version": "2.2.0", + "version": "2.3.0", "description": "A post processing library that provides the means to implement 2D filter effects for three.js.", "homepage": "https://github.com/vanruesc/postprocessing", "main": "build/postprocessing.js", diff --git a/public/demo/index.js b/public/demo/index.js index 0ea93a7d1..5ee93d50f 100644 --- a/public/demo/index.js +++ b/public/demo/index.js @@ -3102,7 +3102,7 @@ material = new three.MeshPhongMaterial({ color: 0xffffff * Math.random(), - shading: three.FlatShading + flatShading: true }); mesh = new three.Mesh(geometry, material); @@ -3678,7 +3678,7 @@ material = new three.MeshPhongMaterial({ color: 0xffffff * Math.random(), - shading: three.FlatShading + flatShading: true }); mesh = new three.Mesh(geometry, material); @@ -3956,7 +3956,7 @@ material = new three.MeshPhongMaterial({ color: 0xffffff * Math.random(), - shading: three.FlatShading + flatShading: true }); mesh = new three.Mesh(geometry, material); @@ -4131,7 +4131,7 @@ material = new three.MeshPhongMaterial({ color: 0xffffff * Math.random(), - shading: three.FlatShading + flatShading: true }); mesh = new three.Mesh(geometry, material); @@ -4395,7 +4395,7 @@ material = new three.MeshPhongMaterial({ color: 0xffffff * Math.random(), - shading: three.FlatShading + flatShading: true }); mesh = new three.Mesh(geometry, material); @@ -4560,7 +4560,7 @@ material = new three.MeshPhongMaterial({ color: 0xffffff * Math.random(), - shading: three.FlatShading + flatShading: true }); mesh = new three.Mesh(geometry, material); diff --git a/public/demo/index.min.js b/public/demo/index.min.js index eae80e529..fe6ad1d18 100644 --- a/public/demo/index.min.js +++ b/public/demo/index.min.js @@ -1 +1 @@ -!function(e,t,n){"use strict";function r(e,t){return e+Math.floor(Math.random()*(t-e+1))}function i(e,t){return e+Math.random()*(t-e)}function a(e,t,n){return Math.max(t,Math.min(n,e))}function o(e){return Math.pow(2,Math.max(0,Math.ceil(Math.log2(e))))}t=t&&t.hasOwnProperty("default")?t.default:t,n=n&&n.hasOwnProperty("default")?n.default:n;var s="uniform sampler2D tPreviousLum;\r\nuniform sampler2D tCurrentLum;\r\nuniform float minLuminance;\r\nuniform float delta;\r\nuniform float tau;\r\n\r\nvarying vec2 vUv;\r\n\r\nvoid main() {\r\n\r\n\tfloat previousLum = texture2D(tPreviousLum, vUv, MIP_LEVEL_1X1).r;\r\n\tfloat currentLum = texture2D(tCurrentLum, vUv, MIP_LEVEL_1X1).r;\r\n\r\n\tpreviousLum = max(minLuminance, previousLum);\r\n\tcurrentLum = max(minLuminance, currentLum);\r\n\r\n\t// Adapt the luminance using Pattanaik's technique.\r\n\tfloat adaptedLum = previousLum + (currentLum - previousLum) * (1.0 - exp(-delta * tau));\r\n\r\n\tgl_FragColor.r = adaptedLum;\r\n\r\n}\r\n",l="varying vec2 vUv;\r\n\r\nvoid main() {\r\n\r\n\tvUv = uv;\r\n\tgl_Position = projectionMatrix * modelViewMatrix * vec4(position, 1.0);\r\n\r\n}\r\n",u=function(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")},c=function(){function e(e,t){for(var n=0;n0&&void 0!==arguments[0]?arguments[0]:null,r=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};u(this,n),void 0===r.focus&&(r.focus=1),void 0===r.aperture&&(r.aperture=.025),void 0===r.maxBlur&&(r.maxBlur=1);var i=v(this,(n.__proto__||Object.getPrototypeOf(n)).call(this,{type:"BokehMaterial",uniforms:{cameraNear:new e.Uniform(.1),cameraFar:new e.Uniform(2e3),aspect:new e.Uniform(1),tDiffuse:new e.Uniform(null),tDepth:new e.Uniform(null),focus:new e.Uniform(r.focus),aperture:new e.Uniform(r.aperture),maxBlur:new e.Uniform(r.maxBlur)},fragmentShader:m,vertexShader:p,depthWrite:!1,depthTest:!1}));return null!==t&&i.adoptCameraSettings(t),i}return f(n,t),c(n,[{key:"adoptCameraSettings",value:function(e){this.uniforms.cameraNear.value=e.near,this.uniforms.cameraFar.value=e.far,this.uniforms.aspect.value=e.aspect}}]),n}(e.ShaderMaterial),x="uniform sampler2D tDiffuse;\r\nuniform sampler2D tDepth;\r\n\r\nuniform vec2 texelSize;\r\nuniform vec2 halfTexelSize;\r\n\r\nuniform float cameraNear;\r\nuniform float cameraFar;\r\n\r\nuniform float focalLength;\r\nuniform float focalStop;\r\n\r\nuniform float maxBlur;\r\nuniform vec3 luminanceCoefficients;\r\nuniform float luminanceThreshold;\r\nuniform float luminanceGain;\r\nuniform float bias;\r\nuniform float fringe;\r\nuniform float ditherStrength;\r\n\r\n#ifdef SHADER_FOCUS\r\n\r\n\tuniform vec2 focusCoords;\r\n\r\n#else\r\n\r\n\tuniform float focalDepth;\r\n\r\n#endif\r\n\r\nvarying vec2 vUv;\r\n\r\n#ifndef USE_LOGDEPTHBUF\r\n\r\n\t#include \r\n\r\n\tfloat readDepth(sampler2D depthSampler, vec2 coord) {\r\n\r\n\t\tfloat fragCoordZ = texture2D(depthSampler, coord).x;\r\n\t\tfloat viewZ = perspectiveDepthToViewZ(fragCoordZ, cameraNear, cameraFar);\r\n\r\n\t\treturn viewZToOrthographicDepth(viewZ, cameraNear, cameraFar);\r\n\r\n\t}\r\n\r\n#endif\r\n\r\n#ifdef PENTAGON\r\n\r\n\tfloat penta(vec2 coords) {\r\n\r\n\t\tconst vec4 HS0 = vec4( 1.0, 0.0, 0.0, 1.0);\r\n\t\tconst vec4 HS1 = vec4( 0.309016994, 0.951056516, 0.0, 1.0);\r\n\t\tconst vec4 HS2 = vec4(-0.809016994, 0.587785252, 0.0, 1.0);\r\n\t\tconst vec4 HS3 = vec4(-0.809016994, -0.587785252, 0.0, 1.0);\r\n\t\tconst vec4 HS4 = vec4( 0.309016994, -0.951056516, 0.0, 1.0);\r\n\t\tconst vec4 HS5 = vec4( 0.0, 0.0, 1.0, 1.0);\r\n\r\n\t\tconst vec4 ONE = vec4(1.0);\r\n\r\n\t\tconst float P_FEATHER = 0.4;\r\n\t\tconst float N_FEATHER = -P_FEATHER;\r\n\r\n\t\tfloat inOrOut = -4.0;\r\n\r\n\t\tvec4 P = vec4(coords, vec2(RINGS_FLOAT - 1.3));\r\n\r\n\t\tvec4 dist = vec4(\r\n\t\t\tdot(P, HS0),\r\n\t\t\tdot(P, HS1),\r\n\t\t\tdot(P, HS2),\r\n\t\t\tdot(P, HS3)\r\n\t\t);\r\n\r\n\t\tdist = smoothstep(N_FEATHER, P_FEATHER, dist);\r\n\r\n\t\tinOrOut += dot(dist, ONE);\r\n\r\n\t\tdist.x = dot(P, HS4);\r\n\t\tdist.y = HS5.w - abs(P.z);\r\n\r\n\t\tdist = smoothstep(N_FEATHER, P_FEATHER, dist);\r\n\t\tinOrOut += dist.x;\r\n\r\n\t\treturn clamp(inOrOut, 0.0, 1.0);\r\n\r\n\t}\r\n\r\n#endif\r\n\r\n#ifdef SHOW_FOCUS\r\n\r\n\tvec3 debugFocus(vec3 c, float blur, float depth) {\r\n\r\n\t\tfloat edge = 0.002 * depth;\r\n\t\tfloat m = clamp(smoothstep(0.0, edge, blur), 0.0, 1.0);\r\n\t\tfloat e = clamp(smoothstep(1.0 - edge, 1.0, blur), 0.0, 1.0);\r\n\r\n\t\tc = mix(c, vec3(1.0, 0.5, 0.0), (1.0 - m) * 0.6);\r\n\t\tc = mix(c, vec3(0.0, 0.5, 1.0), ((1.0 - e) - (1.0 - m)) * 0.2);\r\n\r\n\t\treturn c;\r\n\r\n\t}\r\n\r\n#endif\r\n\r\n#ifdef VIGNETTE\r\n\r\n\tfloat vignette() {\r\n\r\n\t\tconst vec2 CENTER = vec2(0.5);\r\n\r\n\t\tconst float VIGNETTE_OUT = 1.3;\r\n\t\tconst float VIGNETTE_IN = 0.0;\r\n\t\tconst float VIGNETTE_FADE = 22.0; \r\n\r\n\t\tfloat d = distance(vUv, CENTER);\r\n\t\td = smoothstep(VIGNETTE_OUT + (focalStop / VIGNETTE_FADE), VIGNETTE_IN + (focalStop / VIGNETTE_FADE), d);\r\n\r\n\t\treturn clamp(d, 0.0, 1.0);\r\n\r\n\t}\r\n\r\n#endif\r\n\r\nvec2 rand(vec2 coord) {\r\n\r\n\tvec2 noise;\r\n\r\n\t#ifdef NOISE\r\n\r\n\t\tconst float a = 12.9898;\r\n\t\tconst float b = 78.233;\r\n\t\tconst float c = 43758.5453;\r\n\r\n\t\tnoise.x = clamp(fract(sin(mod(dot(coord, vec2(a, b)), 3.14)) * c), 0.0, 1.0) * 2.0 - 1.0;\r\n\t\tnoise.y = clamp(fract(sin(mod(dot(coord, vec2(a, b) * 2.0), 3.14)) * c), 0.0, 1.0) * 2.0 - 1.0;\r\n\r\n\t#else\r\n\r\n\t\tnoise.x = ((fract(1.0 - coord.s * halfTexelSize.x) * 0.25) + (fract(coord.t * halfTexelSize.y) * 0.75)) * 2.0 - 1.0;\r\n\t\tnoise.y = ((fract(1.0 - coord.s * halfTexelSize.x) * 0.75) + (fract(coord.t * halfTexelSize.y) * 0.25)) * 2.0 - 1.0;\r\n\r\n\t#endif\r\n\r\n\treturn noise;\r\n\r\n}\r\n\r\nvec3 processTexel(vec2 coords, float blur) {\r\n\r\n\tvec3 c;\r\n\tc.r = texture2D(tDiffuse, coords + vec2(0.0, 1.0) * texelSize * fringe * blur).r;\r\n\tc.g = texture2D(tDiffuse, coords + vec2(-0.866, -0.5) * texelSize * fringe * blur).g;\r\n\tc.b = texture2D(tDiffuse, coords + vec2(0.866, -0.5) * texelSize * fringe * blur).b;\r\n\r\n\t// Calculate the luminance of the constructed colour.\r\n\tfloat luminance = dot(c, luminanceCoefficients);\r\n\tfloat threshold = max((luminance - luminanceThreshold) * luminanceGain, 0.0);\r\n\r\n\treturn c + mix(vec3(0.0), c, threshold * blur);\r\n\r\n}\r\n\r\nfloat linearize(float depth) {\r\n\r\n\treturn -cameraFar * cameraNear / (depth * (cameraFar - cameraNear) - cameraFar);\r\n\r\n}\r\n\r\nfloat gather(float i, float j, float ringSamples, inout vec3 color, float w, float h, float blur) {\r\n\r\n\tconst float TWO_PI = 6.28318531;\r\n\r\n\tfloat step = TWO_PI / ringSamples;\r\n\tfloat pw = cos(j * step) * i;\r\n\tfloat ph = sin(j * step) * i;\r\n\r\n\t#ifdef PENTAGON\r\n\r\n\t\tfloat p = penta(vec2(pw, ph));\r\n\r\n\t#else\r\n\r\n\t\tfloat p = 1.0;\r\n\r\n\t#endif\r\n\r\n\tcolor += processTexel(vUv + vec2(pw * w, ph * h), blur) * mix(1.0, i / RINGS_FLOAT, bias) * p;\r\n\r\n\treturn mix(1.0, i / RINGS_FLOAT, bias) * p;\r\n\r\n}\r\n\r\nvoid main() {\r\n\r\n\t#ifdef USE_LOGDEPTHBUF\r\n\r\n\t\tfloat depth = linearize(texture2D(tDepth, vUv).x);\r\n\r\n\t#else\r\n\r\n\t\tfloat depth = linearize(readDepth(tDepth, vUv));\r\n\r\n\t#endif\r\n\r\n\t#ifdef SHADER_FOCUS\r\n\r\n\t\t#ifdef USE_LOGDEPTHBUF\r\n\r\n\t\t\tfloat fDepth = linearize(texture2D(tDepth, focusCoords).x);\r\n\r\n\t\t#else\r\n\r\n\t\t\tfloat fDepth = linearize(readDepth(tDepth, focusCoords));\r\n\r\n\t\t#endif\r\n\r\n\t#else\r\n\r\n\t\tfloat fDepth = focalDepth;\r\n\r\n\t#endif\r\n\r\n\t#ifdef MANUAL_DOF\r\n\r\n\t\tconst float nDoFStart = 1.0; \r\n\t\tconst float nDoFDist = 2.0;\r\n\t\tconst float fDoFStart = 1.0;\r\n\t\tconst float fDoFDist = 3.0;\r\n\r\n\t\tfloat focalPlane = depth - fDepth;\r\n\t\tfloat farDoF = (focalPlane - fDoFStart) / fDoFDist;\r\n\t\tfloat nearDoF = (-focalPlane - nDoFStart) / nDoFDist;\r\n\r\n\t\tfloat blur = (focalPlane > 0.0) ? farDoF : nearDoF;\r\n\r\n\t#else\r\n\r\n\t\tconst float CIRCLE_OF_CONFUSION = 0.03; // 35mm film = 0.03mm CoC.\r\n\r\n\t\tfloat focalPlaneMM = fDepth * 1000.0;\r\n\t\tfloat depthMM = depth * 1000.0;\r\n\r\n\t\tfloat focalPlane = (depthMM * focalLength) / (depthMM - focalLength);\r\n\t\tfloat farDoF = (focalPlaneMM * focalLength) / (focalPlaneMM - focalLength);\r\n\t\tfloat nearDoF = (focalPlaneMM - focalLength) / (focalPlaneMM * focalStop * CIRCLE_OF_CONFUSION);\r\n\r\n\t\tfloat blur = abs(focalPlane - farDoF) * nearDoF;\r\n\r\n\t#endif\r\n\r\n\tblur = clamp(blur, 0.0, 1.0);\r\n\r\n\t// Dithering.\r\n\tvec2 noise = rand(vUv) * ditherStrength * blur;\r\n\r\n\tfloat blurFactorX = texelSize.x * blur * maxBlur + noise.x;\r\n\tfloat blurFactorY = texelSize.y * blur * maxBlur + noise.y;\r\n\r\n\tconst int MAX_RING_SAMPLES = RINGS_INT * SAMPLES_INT;\r\n\r\n\t// Calculation of final color.\r\n\tvec4 color;\r\n\r\n\tif(blur < 0.05) {\r\n\r\n\t\tcolor = texture2D(tDiffuse, vUv);\r\n\r\n\t} else {\r\n\r\n\t\tcolor = texture2D(tDiffuse, vUv);\r\n\r\n\t\tfloat s = 1.0;\r\n\t\tint ringSamples;\r\n\r\n\t\tfor(int i = 1; i <= RINGS_INT; ++i) {\r\n\r\n\t\t\tringSamples = i * SAMPLES_INT;\r\n\r\n\t\t\t// Constant loop.\r\n\t\t\tfor(int j = 0; j < MAX_RING_SAMPLES; ++j) {\r\n\r\n\t\t\t\t// Break earlier.\r\n\t\t\t\tif(j >= ringSamples) { break; }\r\n\r\n\t\t\t\ts += gather(float(i), float(j), float(ringSamples), color.rgb, blurFactorX, blurFactorY, blur);\r\n\r\n\t\t\t}\r\n\r\n\t\t}\r\n\r\n\t\tcolor.rgb /= s; // Divide by sample count.\r\n\r\n\t}\r\n\r\n\t#ifdef SHOW_FOCUS\r\n\r\n\t\tcolor.rgb = debugFocus(color.rgb, blur, depth);\r\n\r\n\t#endif\r\n\r\n\t#ifdef VIGNETTE\r\n\r\n\t\tcolor.rgb *= vignette();\r\n\r\n\t#endif\r\n\r\n\tgl_FragColor = color;\r\n\r\n}\r\n",y="varying vec2 vUv;\r\n\r\nvoid main() {\r\n\r\n\tvUv = uv;\r\n\tgl_Position = projectionMatrix * modelViewMatrix * vec4(position, 1.0);\r\n\r\n}\r\n",M=function(t){function n(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:null,r=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};u(this,n),void 0===r.rings&&(r.rings=3),void 0===r.samples&&(r.samples=2),void 0===r.showFocus&&(r.showFocus=!1),void 0===r.showFocus&&(r.showFocus=!1),void 0===r.manualDoF&&(r.manualDoF=!1),void 0===r.vignette&&(r.vignette=!1),void 0===r.pentagon&&(r.pentagon=!1),void 0===r.shaderFocus&&(r.shaderFocus=!0),void 0===r.noise&&(r.noise=!0);var i=v(this,(n.__proto__||Object.getPrototypeOf(n)).call(this,{type:"Bokeh2Material",defines:{RINGS_INT:r.rings.toFixed(0),RINGS_FLOAT:r.rings.toFixed(1),SAMPLES_INT:r.samples.toFixed(0),SAMPLES_FLOAT:r.samples.toFixed(1)},uniforms:{tDiffuse:new e.Uniform(null),tDepth:new e.Uniform(null),texelSize:new e.Uniform(new e.Vector2),halfTexelSize:new e.Uniform(new e.Vector2),cameraNear:new e.Uniform(.1),cameraFar:new e.Uniform(2e3),focalLength:new e.Uniform(24),focalStop:new e.Uniform(.9),maxBlur:new e.Uniform(1),luminanceThreshold:new e.Uniform(.5),luminanceGain:new e.Uniform(2),luminanceCoefficients:new e.Uniform(new e.Vector3(.2126,.7152,.0722)),bias:new e.Uniform(.5),fringe:new e.Uniform(.7),ditherStrength:new e.Uniform(1e-4),focusCoords:new e.Uniform(new e.Vector2(.5,.5)),focalDepth:new e.Uniform(1)},fragmentShader:x,vertexShader:y,depthWrite:!1,depthTest:!1}));return r.showFocus&&(i.defines.SHOW_FOCUS="1"),r.manualDoF&&(i.defines.MANUAL_DOF="1"),r.vignette&&(i.defines.VIGNETTE="1"),r.pentagon&&(i.defines.PENTAGON="1"),r.shaderFocus&&(i.defines.SHADER_FOCUS="1"),r.noise&&(i.defines.NOISE="1"),void 0!==r.texelSize&&i.setTexelSize(r.texelSize.x,r.texelSize.y),null!==t&&i.adoptCameraSettings(t),i}return f(n,t),c(n,[{key:"setTexelSize",value:function(e,t){this.uniforms.texelSize.value.set(e,t),this.uniforms.halfTexelSize.value.set(e,t).multiplyScalar(.5)}},{key:"adoptCameraSettings",value:function(e){this.uniforms.cameraNear.value=e.near,this.uniforms.cameraFar.value=e.far,this.uniforms.focalLength.value=e.getFocalLength()}}]),n}(e.ShaderMaterial),w="uniform sampler2D texture1;\r\nuniform sampler2D texture2;\r\n\r\nuniform float opacity1;\r\nuniform float opacity2;\r\n\r\nvarying vec2 vUv;\r\n\r\nvoid main() {\r\n\r\n\tvec4 texel1 = opacity1 * texture2D(texture1, vUv);\r\n\tvec4 texel2 = opacity2 * texture2D(texture2, vUv);\r\n\r\n\t#ifdef SCREEN_MODE\r\n\r\n\t\tvec3 invTexel1 = vec3(1.0) - texel1.rgb;\r\n\t\tvec3 invTexel2 = vec3(1.0) - texel2.rgb;\r\n\r\n\t\tvec4 color = vec4(\r\n\t\t\tvec3(1.0) - invTexel1 * invTexel2,\r\n\t\t\ttexel1.a + texel2.a\r\n\t\t);\r\n\r\n\t#else\r\n\r\n\t\tvec4 color = texel1 + texel2;\r\n\r\n\t#endif\r\n\r\n\tgl_FragColor = color;\r\n\r\n}\r\n",b="varying vec2 vUv;\r\n\r\nvoid main() {\r\n\r\n\tvUv = uv;\r\n\tgl_Position = projectionMatrix * modelViewMatrix * vec4(position, 1.0);\r\n\r\n}\r\n",S=function(t){function n(){var t=arguments.length>0&&void 0!==arguments[0]&&arguments[0];u(this,n);var r=v(this,(n.__proto__||Object.getPrototypeOf(n)).call(this,{type:"CombineMaterial",uniforms:{texture1:new e.Uniform(null),texture2:new e.Uniform(null),opacity1:new e.Uniform(1),opacity2:new e.Uniform(1)},fragmentShader:w,vertexShader:b,depthWrite:!1,depthTest:!1}));return t&&(r.defines.SCREEN_MODE="1"),r}return f(n,t),n}(e.ShaderMaterial),D="uniform sampler2D tDiffuse;\r\n\r\nvarying vec2 vUv0;\r\nvarying vec2 vUv1;\r\nvarying vec2 vUv2;\r\nvarying vec2 vUv3;\r\n\r\nvoid main() {\r\n\r\n\t// Sample top left texel.\r\n\tvec4 sum = texture2D(tDiffuse, vUv0);\r\n\r\n\t// Sample top right texel.\r\n\tsum += texture2D(tDiffuse, vUv1);\r\n\r\n\t// Sample bottom right texel.\r\n\tsum += texture2D(tDiffuse, vUv2);\r\n\r\n\t// Sample bottom left texel.\r\n\tsum += texture2D(tDiffuse, vUv3);\r\n\r\n\t// Compute the average.\r\n\tgl_FragColor = sum * 0.25;\r\n\r\n}\r\n",P="uniform vec2 texelSize;\r\nuniform vec2 halfTexelSize;\r\nuniform float kernel;\r\n\r\nvarying vec2 vUv0;\r\nvarying vec2 vUv1;\r\nvarying vec2 vUv2;\r\nvarying vec2 vUv3;\r\n\r\nvoid main() {\r\n\r\n\tvec2 dUv = (texelSize * vec2(kernel)) + halfTexelSize;\r\n\r\n\tvUv0 = vec2(uv.x - dUv.x, uv.y + dUv.y);\r\n\tvUv1 = vec2(uv.x + dUv.x, uv.y + dUv.y);\r\n\tvUv2 = vec2(uv.x + dUv.x, uv.y - dUv.y);\r\n\tvUv3 = vec2(uv.x - dUv.x, uv.y - dUv.y);\r\n\r\n\tgl_Position = projectionMatrix * modelViewMatrix * vec4(position, 1.0);\r\n\r\n}\r\n",T=function(t){function n(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:new e.Vector2;u(this,n);var r=v(this,(n.__proto__||Object.getPrototypeOf(n)).call(this,{type:"ConvolutionMaterial",uniforms:{tDiffuse:new e.Uniform(null),texelSize:new e.Uniform(new e.Vector2),halfTexelSize:new e.Uniform(new e.Vector2),kernel:new e.Uniform(0)},fragmentShader:D,vertexShader:P,depthWrite:!1,depthTest:!1}));return r.setTexelSize(t.x,t.y),r.kernelSize=C.LARGE,r}return f(n,t),c(n,[{key:"getKernel",value:function(){return A[this.kernelSize]}},{key:"setTexelSize",value:function(e,t){this.uniforms.texelSize.value.set(e,t),this.uniforms.halfTexelSize.value.set(e,t).multiplyScalar(.5)}}]),n}(e.ShaderMaterial),A=[new Float32Array([0,0]),new Float32Array([0,1,1]),new Float32Array([0,1,1,2]),new Float32Array([0,1,2,2,3]),new Float32Array([0,1,2,3,4,4,5]),new Float32Array([0,1,2,3,4,5,7,8,9,10])],C={VERY_SMALL:0,SMALL:1,MEDIUM:2,LARGE:3,VERY_LARGE:4,HUGE:5},O="uniform sampler2D tDiffuse;\r\nuniform float opacity;\r\n\r\nvarying vec2 vUv;\r\n\r\nvoid main() {\r\n\r\n\tvec4 texel = texture2D(tDiffuse, vUv);\r\n\tgl_FragColor = opacity * texel;\r\n\r\n}\r\n",L="varying vec2 vUv;\r\n\r\nvoid main() {\r\n\r\n\tvUv = uv;\r\n\tgl_Position = projectionMatrix * modelViewMatrix * vec4(position, 1.0);\r\n\r\n}\r\n",E=function(t){function n(){return u(this,n),v(this,(n.__proto__||Object.getPrototypeOf(n)).call(this,{type:"CopyMaterial",uniforms:{tDiffuse:new e.Uniform(null),opacity:new e.Uniform(1)},fragmentShader:O,vertexShader:L,depthWrite:!1,depthTest:!1}))}return f(n,t),n}(e.ShaderMaterial),k="uniform sampler2D tDepth;\r\n\r\nvarying vec2 vUv;\r\n\r\n#ifndef USE_LOGDEPTHBUF\r\n\r\n\t#include \r\n\r\n\tuniform float cameraNear;\r\n\tuniform float cameraFar;\r\n\r\n\tfloat readDepth(sampler2D depthSampler, vec2 coord) {\r\n\r\n\t\tfloat fragCoordZ = texture2D(depthSampler, coord).x;\r\n\t\tfloat viewZ = perspectiveDepthToViewZ(fragCoordZ, cameraNear, cameraFar);\r\n\r\n\t\treturn viewZToOrthographicDepth(viewZ, cameraNear, cameraFar);\r\n\r\n\t}\r\n\r\n#endif\r\n\r\nvoid main() {\r\n\r\n\t#ifdef USE_LOGDEPTHBUF\r\n\r\n\t\tfloat depth = texture2D(tDepth, vUv).x;\r\n\r\n\t#else\r\n\r\n\t\tfloat depth = readDepth(tDepth, vUv);\r\n\r\n\t#endif\r\n\r\n\tgl_FragColor = vec4(depth, depth, depth, 1.0);\r\n\r\n}\r\n",U="varying vec2 vUv;\r\n\r\nvoid main() {\r\n\r\n\tvUv = uv;\r\n\tgl_Position = projectionMatrix * modelViewMatrix * vec4(position, 1.0);\r\n\r\n}\r\n",z=function(t){function n(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:null;u(this,n);var r=v(this,(n.__proto__||Object.getPrototypeOf(n)).call(this,{type:"DepthMaterial",uniforms:{cameraNear:new e.Uniform(.1),cameraFar:new e.Uniform(2e3),tDepth:new e.Uniform(null)},fragmentShader:k,vertexShader:U,depthWrite:!1,depthTest:!1}));return null!==t&&r.adoptCameraSettings(t),r}return f(n,t),c(n,[{key:"adoptCameraSettings",value:function(e){this.uniforms.cameraNear.value=e.near,this.uniforms.cameraFar.value=e.far}}]),n}(e.ShaderMaterial),F="uniform sampler2D tDiffuse;\r\n\r\nuniform float angle;\r\nuniform float scale;\r\nuniform float intensity;\r\n\r\nvarying vec2 vUv;\r\nvarying vec2 vUvPattern;\r\n\r\nfloat pattern() {\r\n\r\n\tfloat s = sin(angle);\r\n\tfloat c = cos(angle);\r\n\r\n\tvec2 point = vec2(c * vUvPattern.x - s * vUvPattern.y, s * vUvPattern.x + c * vUvPattern.y) * scale;\r\n\r\n\treturn (sin(point.x) * sin(point.y)) * 4.0;\r\n\r\n}\r\n\r\nvoid main() {\r\n\r\n\tvec4 texel = texture2D(tDiffuse, vUv);\r\n\tvec3 color = texel.rgb;\r\n\r\n\t#ifdef AVERAGE\r\n\r\n\t\tcolor = vec3((color.r + color.g + color.b) / 3.0);\r\n\r\n\t#endif\r\n\r\n\tcolor = vec3(color * 10.0 - 5.0 + pattern());\r\n\tcolor = texel.rgb + (color - texel.rgb) * intensity;\r\n\r\n\tgl_FragColor = vec4(color, texel.a);\r\n\r\n}\r\n",N="uniform vec4 offsetRepeat;\r\n\r\nvarying vec2 vUv;\r\nvarying vec2 vUvPattern;\r\n\r\nvoid main() {\r\n\r\n\tvUv = uv;\r\n\tvUvPattern = uv * offsetRepeat.zw + offsetRepeat.xy;\r\n\tgl_Position = projectionMatrix * modelViewMatrix * vec4(position, 1.0);\r\n\r\n}\r\n",j=function(t){function n(){var t=arguments.length>0&&void 0!==arguments[0]&&arguments[0];u(this,n);var r=v(this,(n.__proto__||Object.getPrototypeOf(n)).call(this,{type:"DotScreenMaterial",uniforms:{tDiffuse:new e.Uniform(null),angle:new e.Uniform(1.57),scale:new e.Uniform(1),intensity:new e.Uniform(1),offsetRepeat:new e.Uniform(new e.Vector4(.5,.5,1,1))},fragmentShader:F,vertexShader:N,depthWrite:!1,depthTest:!1}));return t&&(r.defines.AVERAGE="1"),r}return f(n,t),n}(e.ShaderMaterial),B="uniform sampler2D tDiffuse;\r\nuniform float time;\r\n\r\nvarying vec2 vUv;\r\n\r\n#ifdef NOISE\r\n\r\n\tuniform float noiseIntensity;\r\n\r\n#endif\r\n\r\n#ifdef SCANLINES\r\n\r\n\tuniform float scanlineIntensity;\r\n\tuniform float scanlineCount;\r\n\r\n#endif\r\n\r\n#ifdef GREYSCALE\r\n\r\n\tuniform vec3 luminanceCoefficients;\r\n\tuniform float greyscaleIntensity;\r\n\r\n#elif defined(SEPIA)\r\n\r\n\tuniform float sepiaIntensity;\r\n\r\n#endif\r\n\r\n#ifdef VIGNETTE\r\n\r\n\tuniform float vignetteOffset;\r\n\tuniform float vignetteDarkness;\r\n\r\n#endif\r\n\r\nvoid main() {\r\n\r\n\tvec4 texel = texture2D(tDiffuse, vUv);\r\n\tvec3 color = texel.rgb;\r\n\r\n\t#ifdef SCREEN_MODE\r\n\r\n\t\tvec3 invColor;\r\n\r\n\t#endif\r\n\r\n\t#ifdef NOISE\r\n\r\n\t\tfloat x = vUv.x * vUv.y * time * 1000.0;\r\n\t\tx = mod(x, 13.0) * mod(x, 123.0);\r\n\t\tx = mod(x, 0.01);\r\n\r\n\t\tvec3 noise = texel.rgb * clamp(0.1 + x * 100.0, 0.0, 1.0) * noiseIntensity;\r\n\r\n\t\t#ifdef SCREEN_MODE\r\n\r\n\t\t\tinvColor = vec3(1.0) - color;\r\n\t\t\tvec3 invNoise = vec3(1.0) - noise;\r\n\r\n\t\t\tcolor = vec3(1.0) - invColor * invNoise;\r\n\r\n\t\t#else\r\n\r\n\t\t\tcolor += noise;\r\n\r\n\t\t#endif\r\n\r\n\t#endif\r\n\r\n\t#ifdef SCANLINES\r\n\r\n\t\tvec2 sl = vec2(sin(vUv.y * scanlineCount), cos(vUv.y * scanlineCount));\r\n\t\tvec3 scanlines = texel.rgb * vec3(sl.x, sl.y, sl.x) * scanlineIntensity;\r\n\r\n\t\t#ifdef SCREEN_MODE\r\n\r\n\t\t\tinvColor = vec3(1.0) - color;\r\n\t\t\tvec3 invScanlines = vec3(1.0) - scanlines;\r\n\r\n\t\t\tcolor = vec3(1.0) - invColor * invScanlines;\r\n\r\n\t\t#else\r\n\r\n\t\t\tcolor += scanlines;\r\n\r\n\t\t#endif\r\n\r\n\t#endif\r\n\r\n\t#ifdef GREYSCALE\r\n\r\n\t\tcolor = mix(color, vec3(dot(color, luminanceCoefficients)), greyscaleIntensity);\r\n\r\n\t#elif defined(SEPIA)\r\n\r\n\t\tvec3 c = color.rgb;\r\n\r\n\t\tcolor.r = dot(c, vec3(1.0 - 0.607 * sepiaIntensity, 0.769 * sepiaIntensity, 0.189 * sepiaIntensity));\r\n\t\tcolor.g = dot(c, vec3(0.349 * sepiaIntensity, 1.0 - 0.314 * sepiaIntensity, 0.168 * sepiaIntensity));\r\n\t\tcolor.b = dot(c, vec3(0.272 * sepiaIntensity, 0.534 * sepiaIntensity, 1.0 - 0.869 * sepiaIntensity));\r\n\r\n\t#endif\r\n\r\n\t#ifdef VIGNETTE\r\n\r\n\t\tconst vec2 center = vec2(0.5);\r\n\r\n\t\t#ifdef ESKIL\r\n\r\n\t\t\tvec2 uv = (vUv - center) * vec2(vignetteOffset);\r\n\t\t\tcolor = mix(color.rgb, vec3(1.0 - vignetteDarkness), dot(uv, uv));\r\n\r\n\t\t#else\r\n\r\n\t\t\tfloat dist = distance(vUv, center);\r\n\t\t\tcolor *= smoothstep(0.8, vignetteOffset * 0.799, dist * (vignetteDarkness + vignetteOffset));\r\n\r\n\t\t#endif\t\t\r\n\r\n\t#endif\r\n\r\n\tgl_FragColor = vec4(clamp(color, 0.0, 1.0), texel.a);\r\n\r\n}\r\n",R="varying vec2 vUv;\r\n\r\nvoid main() {\r\n\r\n\tvUv = uv;\r\n\tgl_Position = projectionMatrix * modelViewMatrix * vec4(position, 1.0);\r\n\r\n}\r\n",I=function(t){function n(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};u(this,n),void 0===t.screenMode&&(t.screenMode=!0),void 0===t.noise&&(t.noise=!0),void 0===t.scanlines&&(t.scanlines=!0),void 0===t.greyscale&&(t.greyscale=!1),void 0===t.sepia&&(t.sepia=!1),void 0===t.vignette&&(t.vignette=!1),void 0===t.eskil&&(t.eskil=!1),void 0===t.noiseIntensity&&(t.noiseIntensity=.5),void 0===t.scanlineIntensity&&(t.scanlineIntensity=.05),void 0===t.greyscaleIntensity&&(t.greyscaleIntensity=1),void 0===t.sepiaIntensity&&(t.sepiaIntensity=1),void 0===t.vignetteOffset&&(t.vignetteOffset=1),void 0===t.vignetteDarkness&&(t.vignetteDarkness=1);var r=v(this,(n.__proto__||Object.getPrototypeOf(n)).call(this,{type:"FilmMaterial",uniforms:{tDiffuse:new e.Uniform(null),time:new e.Uniform(0),noiseIntensity:new e.Uniform(t.noiseIntensity),scanlineIntensity:new e.Uniform(t.scanlineIntensity),scanlineCount:new e.Uniform(0),luminanceCoefficients:new e.Uniform(new e.Vector3(.2126,.7152,.0722)),greyscaleIntensity:new e.Uniform(t.greyscaleIntensity),sepiaIntensity:new e.Uniform(t.sepiaIntensity),vignetteOffset:new e.Uniform(t.vignetteOffset),vignetteDarkness:new e.Uniform(t.vignetteDarkness)},fragmentShader:B,vertexShader:R,depthWrite:!1,depthTest:!1}));return t.greyscale&&(r.defines.GREYSCALE="1"),t.sepia&&(r.defines.SEPIA="1"),t.vignette&&(r.defines.VIGNETTE="1"),t.eskil&&(r.defines.ESKIL="1"),t.screenMode&&(r.defines.SCREEN_MODE="1"),t.noise&&(r.defines.NOISE="1"),t.scanlines&&(r.defines.SCANLINES="1"),r}return f(n,t),n}(e.ShaderMaterial),G="uniform sampler2D tDiffuse;\r\nuniform sampler2D tPerturb;\r\n\r\nuniform bool active;\r\n\r\nuniform float amount;\r\nuniform float angle;\r\nuniform float seed;\r\nuniform float seedX;\r\nuniform float seedY;\r\nuniform float distortionX;\r\nuniform float distortionY;\r\nuniform float colS;\r\n\r\nvarying vec2 vUv;\r\n\r\nfloat rand(vec2 tc) {\r\n\r\n\tconst float a = 12.9898;\r\n\tconst float b = 78.233;\r\n\tconst float c = 43758.5453;\r\n\r\n\tfloat dt = dot(tc, vec2(a, b));\r\n\tfloat sn = mod(dt, 3.14);\r\n\r\n\treturn fract(sin(sn) * c);\r\n\r\n}\r\n\r\nvoid main() {\r\n\r\n\tvec2 coord = vUv;\r\n\r\n\tfloat xs, ys;\r\n\tvec4 normal;\r\n\r\n\tvec2 offset;\r\n\tvec4 cr, cga, cb;\r\n\tvec4 snow, color;\r\n\r\n\tfloat sx, sy;\r\n\r\n\tif(active) {\r\n\r\n\t\txs = floor(gl_FragCoord.x / 0.5);\r\n\t\tys = floor(gl_FragCoord.y / 0.5);\r\n\r\n\t\tnormal = texture2D(tPerturb, coord * seed * seed);\r\n\r\n\t\tif(coord.y < distortionX + colS && coord.y > distortionX - colS * seed) {\r\n\r\n\t\t\tsx = clamp(ceil(seedX), 0.0, 1.0);\r\n\t\t\tcoord.y = sx * (1.0 - (coord.y + distortionY)) + (1.0 - sx) * distortionY;\r\n\r\n\t\t}\r\n\r\n\t\tif(coord.x < distortionY + colS && coord.x > distortionY - colS * seed) {\r\n\r\n\t\t\tsy = clamp(ceil(seedY), 0.0, 1.0);\r\n\t\t\tcoord.x = sy * distortionX + (1.0 - sy) * (1.0 - (coord.x + distortionX));\r\n\r\n\t\t}\r\n\r\n\t\tcoord.x += normal.x * seedX * (seed / 5.0);\r\n\t\tcoord.y += normal.y * seedY * (seed / 5.0);\r\n\r\n\t\toffset = amount * vec2(cos(angle), sin(angle));\r\n\r\n\t\tcr = texture2D(tDiffuse, coord + offset);\r\n\t\tcga = texture2D(tDiffuse, coord);\r\n\t\tcb = texture2D(tDiffuse, coord - offset);\r\n\r\n\t\tcolor = vec4(cr.r, cga.g, cb.b, cga.a);\r\n\t\tsnow = 200.0 * amount * vec4(rand(vec2(xs * seed, ys * seed * 50.0)) * 0.2);\r\n\t\tcolor += snow;\r\n\r\n\t} else {\r\n\r\n\t\tcolor = texture2D(tDiffuse, vUv);\r\n\r\n\t}\r\n\r\n\tgl_FragColor = color;\r\n\r\n}\r\n",W="varying vec2 vUv;\r\n\r\nvoid main() {\r\n\r\n\tvUv = uv;\r\n\tgl_Position = projectionMatrix * modelViewMatrix * vec4(position, 1.0);\r\n\r\n}\r\n",H=function(t){function n(){return u(this,n),v(this,(n.__proto__||Object.getPrototypeOf(n)).call(this,{type:"GlitchMaterial",uniforms:{tDiffuse:new e.Uniform(null),tPerturb:new e.Uniform(null),active:new e.Uniform(1),amount:new e.Uniform(.8),angle:new e.Uniform(.02),seed:new e.Uniform(.02),seedX:new e.Uniform(.02),seedY:new e.Uniform(.02),distortionX:new e.Uniform(.5),distortionY:new e.Uniform(.6),colS:new e.Uniform(.05)},fragmentShader:G,vertexShader:W,depthWrite:!1,depthTest:!1}))}return f(n,t),n}(e.ShaderMaterial),X="uniform sampler2D tDiffuse;\r\nuniform vec3 lightPosition;\r\n\r\nuniform float exposure;\r\nuniform float decay;\r\nuniform float density;\r\nuniform float weight;\r\nuniform float clampMax;\r\n\r\nvarying vec2 vUv;\r\n\r\nvoid main() {\r\n\r\n\tvec2 texCoord = vUv;\r\n\r\n\t// Calculate vector from pixel to light source in screen space.\r\n\tvec2 deltaTexCoord = texCoord - lightPosition.st;\r\n\tdeltaTexCoord *= 1.0 / NUM_SAMPLES_FLOAT * density;\r\n\r\n\t// A decreasing illumination factor.\r\n\tfloat illuminationDecay = 1.0;\r\n\r\n\tvec4 sample;\r\n\tvec4 color = vec4(0.0);\r\n\r\n\t// Estimate the probability of occlusion at each pixel by summing samples along a ray to the light source.\r\n\tfor(int i = 0; i < NUM_SAMPLES_INT; ++i) {\r\n\r\n\t\ttexCoord -= deltaTexCoord;\r\n\t\tsample = texture2D(tDiffuse, texCoord);\r\n\r\n\t\t// Apply sample attenuation scale/decay factors.\r\n\t\tsample *= illuminationDecay * weight;\r\n\r\n\t\tcolor += sample;\r\n\r\n\t\t// Update exponential decay factor.\r\n\t\tilluminationDecay *= decay;\r\n\r\n\t}\r\n\r\n\tgl_FragColor = clamp(color * exposure, 0.0, clampMax);\r\n\r\n}\r\n",V="varying vec2 vUv;\r\n\r\nvoid main() {\r\n\r\n\tvUv = uv;\r\n\tgl_Position = projectionMatrix * modelViewMatrix * vec4(position, 1.0);\r\n\r\n}\r\n",Y=function(t){function n(){return u(this,n),v(this,(n.__proto__||Object.getPrototypeOf(n)).call(this,{type:"GodRaysMaterial",defines:{NUM_SAMPLES_FLOAT:"60.0",NUM_SAMPLES_INT:"60"},uniforms:{tDiffuse:new e.Uniform(null),lightPosition:new e.Uniform(null),exposure:new e.Uniform(.6),decay:new e.Uniform(.93),density:new e.Uniform(.96),weight:new e.Uniform(.4),clampMax:new e.Uniform(1)},fragmentShader:X,vertexShader:V,depthWrite:!1,depthTest:!1}))}return f(n,t),n}(e.ShaderMaterial),q="uniform sampler2D tDiffuse;\r\nuniform float distinction;\r\nuniform vec2 range;\r\nuniform vec3 luminanceCoefficients;\r\n\r\nvarying vec2 vUv;\r\n\r\nvoid main() {\r\n\r\n\tvec4 texel = texture2D(tDiffuse, vUv);\r\n\tfloat v = dot(texel.rgb, luminanceCoefficients);\r\n\r\n\t#ifdef RANGE\r\n\r\n\t\tfloat low = step(range.x, v);\r\n\t\tfloat high = step(v, range.y);\r\n\r\n\t\t// Apply the mask.\r\n\t\tv *= low * high;\r\n\r\n\t#endif\r\n\r\n\tv = pow(abs(v), distinction);\r\n\r\n\t#ifdef COLOR\r\n\r\n\t\tgl_FragColor = vec4(texel.rgb * v, texel.a);\r\n\r\n\t#else\r\n\r\n\t\tgl_FragColor = vec4(v, v, v, texel.a);\r\n\r\n\t#endif\r\n\r\n}\r\n",K="varying vec2 vUv;\r\n\r\nvoid main() {\r\n\r\n\tvUv = uv;\r\n\tgl_Position = projectionMatrix * modelViewMatrix * vec4(position, 1.0);\r\n\r\n}\r\n",Z=function(t){function n(){var t=arguments.length>0&&void 0!==arguments[0]&&arguments[0],r=arguments.length>1&&void 0!==arguments[1]?arguments[1]:null;u(this,n);var i=v(this,(n.__proto__||Object.getPrototypeOf(n)).call(this,{type:"LuminosityMaterial",uniforms:{tDiffuse:new e.Uniform(null),distinction:new e.Uniform(1),range:new e.Uniform(null!==r?r:new e.Vector2),luminanceCoefficients:new e.Uniform(new e.Vector3(.2126,.7152,.0722))},fragmentShader:q,vertexShader:K}));return t&&(i.defines.COLOR="1"),null!==r&&(i.defines.RANGE="1"),i}return f(n,t),n}(e.ShaderMaterial),J="uniform sampler2D tDiffuse;\r\nuniform float granularity;\r\nuniform float dx;\r\nuniform float dy;\r\n\r\nvarying vec2 vUv;\r\n\r\nvoid main() {\r\n\r\n\tvec4 texel;\r\n\r\n\tif(granularity > 0.0) {\r\n\r\n\t\tvec2 coord = vec2(\r\n\t\t\tdx * (floor(vUv.x / dx) + 0.5),\r\n\t\t\tdy * (floor(vUv.y / dy) + 0.5)\r\n\t\t);\r\n\r\n\t\ttexel = texture2D(tDiffuse, coord);\r\n\r\n\t} else {\r\n\r\n\t\ttexel = texture2D(tDiffuse, vUv);\r\n\r\n\t}\r\n\r\n\tgl_FragColor = texel;\r\n\r\n}\r\n",Q="varying vec2 vUv;\r\n\r\nvoid main() {\r\n\r\n\tvUv = uv;\r\n\tgl_Position = projectionMatrix * modelViewMatrix * vec4(position, 1.0);\r\n\r\n}\r\n",_=function(t){function n(){return u(this,n),v(this,(n.__proto__||Object.getPrototypeOf(n)).call(this,{type:"PixelationMaterial",uniforms:{tDiffuse:new e.Uniform(null),granularity:new e.Uniform(1),resolution:new e.Uniform(new e.Vector2(1,1)),dx:new e.Uniform(1),dy:new e.Uniform(1)},fragmentShader:J,vertexShader:Q,depthWrite:!1,depthTest:!1}))}return f(n,t),c(n,[{key:"setResolution",value:function(e,t){this.uniforms.resolution.value.set(e,t),this.granularity=this.granularity}},{key:"granularity",get:function(){return this.uniforms.granularity.value},set:function(e){var t=this.uniforms,n=t.resolution.value;t.granularity.value=e,t.dx.value=e/n.x,t.dy.value=e/n.y}}]),n}(e.ShaderMaterial),$="#include \r\n\r\nuniform sampler2D tDiffuse;\r\nuniform vec2 center;\r\nuniform float aspect;\r\nuniform float waveSize;\r\nuniform float radius;\r\nuniform float maxRadius;\r\nuniform float amplitude;\r\n\r\nvarying vec2 vUv;\r\nvarying float vSize;\r\n\r\nvoid main() {\r\n\r\n\tvec2 aspectCorrection = vec2(aspect, 1.0);\r\n\r\n\tvec2 difference = vUv * aspectCorrection - center * aspectCorrection;\r\n\tfloat distance = sqrt(dot(difference, difference)) * vSize;\r\n\r\n\tvec2 displacement = vec2(0.0);\r\n\r\n\tif(distance > radius) {\r\n\r\n\t\tif(distance < radius + waveSize) {\r\n\r\n\t\t\tfloat angle = (distance - radius) * PI2 / waveSize;\r\n\t\t\tfloat cosSin = (1.0 - cos(angle)) * 0.5;\r\n\r\n\t\t\tfloat extent = maxRadius + waveSize;\r\n\t\t\tfloat decay = max(extent - distance * distance, 0.0) / extent;\r\n\r\n\t\t\tdisplacement = ((cosSin * amplitude * difference) / distance) * decay;\r\n\r\n\t\t}\r\n\r\n\t}\r\n\r\n\tgl_FragColor = texture2D(tDiffuse, vUv - displacement);\r\n\r\n}\r\n",ee="uniform float size;\r\nuniform float scale;\r\nuniform float cameraDistance;\r\n\r\nvarying vec2 vUv;\r\nvarying float vSize;\r\n\r\nvoid main() {\r\n\r\n\tvUv = uv;\r\n\tvSize = (0.1 * cameraDistance) / size;\r\n\tgl_Position = projectionMatrix * modelViewMatrix * vec4(position, 1.0);\r\n\r\n}\r\n",te=function(t){function n(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};return u(this,n),void 0===t.maxRadius&&(t.maxRadius=1),void 0===t.waveSize&&(t.waveSize=.2),void 0===t.amplitude&&(t.amplitude=.05),v(this,(n.__proto__||Object.getPrototypeOf(n)).call(this,{type:"ShockWaveMaterial",uniforms:{tDiffuse:new e.Uniform(null),center:new e.Uniform(new e.Vector2(.5,.5)),aspect:new e.Uniform(1),cameraDistance:new e.Uniform(1),size:new e.Uniform(1),radius:new e.Uniform(-t.waveSize),maxRadius:new e.Uniform(t.maxRadius),waveSize:new e.Uniform(t.waveSize),amplitude:new e.Uniform(t.amplitude)},fragmentShader:$,vertexShader:ee,depthWrite:!1,depthTest:!1}))}return f(n,t),n}(e.ShaderMaterial),ne="uniform sampler2D tDiffuse;\r\nuniform sampler2D tWeights;\r\n\r\nuniform vec2 texelSize;\r\n\r\nvarying vec2 vUv;\r\nvarying vec4 vOffset;\r\n\r\nvoid main() {\r\n\r\n\t// Fetch the blending weights for current pixel.\r\n\tvec4 a;\r\n\ta.xz = texture2D(tWeights, vUv).xz;\r\n\ta.y = texture2D(tWeights, vOffset.zw).g;\r\n\ta.w = texture2D(tWeights, vOffset.xy).a;\r\n\r\n\tvec4 color;\r\n\r\n\t// Check if there is any blending weight with a value greater than 0.0.\r\n\tif(dot(a, vec4(1.0)) < 1e-5) {\r\n\r\n\t\tcolor = texture2D(tDiffuse, vUv, 0.0);\r\n\r\n\t} else {\r\n\r\n\t\t/* Up to four lines can be crossing a pixel (one through each edge). We favor\r\n\t\t * blending by choosing the line with the maximum weight for each direction.\r\n\t\t */\r\n\r\n\t\tvec2 offset;\r\n\t\toffset.x = a.a > a.b ? a.a : -a.b; // Left vs. right.\r\n\t\toffset.y = a.g > a.r ? -a.g : a.r; // Top vs. bottom (changed signs).\r\n\r\n\t\t// Then we go in the direction that has the maximum weight (horizontal vs. vertical).\r\n\t\tif(abs(offset.x) > abs(offset.y)) {\r\n\r\n\t\t\toffset.y = 0.0;\r\n\r\n\t\t} else {\r\n\r\n\t\t\toffset.x = 0.0;\r\n\r\n\t\t}\r\n\r\n\t\t// Fetch the opposite color and lerp by hand.\r\n\t\tcolor = texture2D(tDiffuse, vUv, 0.0);\r\n\t\tvec2 coord = vUv + sign(offset) * texelSize;\r\n\t\tvec4 oppositeColor = texture2D(tDiffuse, coord, 0.0);\r\n\t\tfloat s = abs(offset.x) > abs(offset.y) ? abs(offset.x) : abs(offset.y);\r\n\r\n\t\t// Gamma correction.\r\n\t\tcolor.rgb = pow(abs(color.rgb), vec3(2.2));\r\n\t\toppositeColor.rgb = pow(abs(oppositeColor.rgb), vec3(2.2));\r\n\t\tcolor = mix(color, oppositeColor, s);\r\n\t\tcolor.rgb = pow(abs(color.rgb), vec3(1.0 / 2.2));\r\n\r\n\t}\r\n\r\n\tgl_FragColor = color;\r\n\r\n}\r\n",re="uniform vec2 texelSize;\r\n\r\nvarying vec2 vUv;\r\nvarying vec4 vOffset;\r\n\r\nvoid main() {\r\n\r\n\tvUv = uv;\r\n\r\n\tvOffset = uv.xyxy + texelSize.xyxy * vec4(1.0, 0.0, 0.0, -1.0); // Changed sign in W component.\r\n\r\n\tgl_Position = projectionMatrix * modelViewMatrix * vec4(position, 1.0);\r\n\r\n}\r\n",ie=function(t){function n(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:new e.Vector2;return u(this,n),v(this,(n.__proto__||Object.getPrototypeOf(n)).call(this,{type:"SMAABlendMaterial",uniforms:{tDiffuse:new e.Uniform(null),tWeights:new e.Uniform(null),texelSize:new e.Uniform(t)},fragmentShader:ne,vertexShader:re,depthWrite:!1,depthTest:!1}))}return f(n,t),n}(e.ShaderMaterial),ae="uniform sampler2D tDiffuse;\r\n\r\nvarying vec2 vUv;\r\nvarying vec4 vOffset[3];\r\n\r\nvoid main() {\r\n\r\n\tconst vec2 THRESHOLD = vec2(EDGE_THRESHOLD);\r\n\r\n\t// Calculate color deltas.\r\n\tvec4 delta;\r\n\tvec3 c = texture2D(tDiffuse, vUv).rgb;\r\n\r\n\tvec3 cLeft = texture2D(tDiffuse, vOffset[0].xy).rgb;\r\n\tvec3 t = abs(c - cLeft);\r\n\tdelta.x = max(max(t.r, t.g), t.b);\r\n\r\n\tvec3 cTop = texture2D(tDiffuse, vOffset[0].zw).rgb;\r\n\tt = abs(c - cTop);\r\n\tdelta.y = max(max(t.r, t.g), t.b);\r\n\r\n\t// We do the usual threshold.\r\n\tvec2 edges = step(THRESHOLD, delta.xy);\r\n\r\n\t// Then discard if there is no edge.\r\n\tif(dot(edges, vec2(1.0)) == 0.0) {\r\n\r\n\t\tdiscard;\r\n\r\n\t}\r\n\r\n\t// Calculate right and bottom deltas.\r\n\tvec3 cRight = texture2D(tDiffuse, vOffset[1].xy).rgb;\r\n\tt = abs(c - cRight);\r\n\tdelta.z = max(max(t.r, t.g), t.b);\r\n\r\n\tvec3 cBottom = texture2D(tDiffuse, vOffset[1].zw).rgb;\r\n\tt = abs(c - cBottom);\r\n\tdelta.w = max(max(t.r, t.g), t.b);\r\n\r\n\t// Calculate the maximum delta in the direct neighborhood.\r\n\tfloat maxDelta = max(max(max(delta.x, delta.y), delta.z), delta.w);\r\n\r\n\t// Calculate left-left and top-top deltas.\r\n\tvec3 cLeftLeft = texture2D(tDiffuse, vOffset[2].xy).rgb;\r\n\tt = abs(c - cLeftLeft);\r\n\tdelta.z = max(max(t.r, t.g), t.b);\r\n\r\n\tvec3 cTopTop = texture2D(tDiffuse, vOffset[2].zw).rgb;\r\n\tt = abs(c - cTopTop);\r\n\tdelta.w = max(max(t.r, t.g), t.b);\r\n\r\n\t// Calculate the final maximum delta.\r\n\tmaxDelta = max(max(maxDelta, delta.z), delta.w);\r\n\r\n\t// Local contrast adaptation in action.\r\n\tedges.xy *= step(0.5 * maxDelta, delta.xy);\r\n\r\n\tgl_FragColor = vec4(edges, 0.0, 0.0);\r\n\r\n}\r\n",oe="uniform vec2 texelSize;\r\n\r\nvarying vec2 vUv;\r\nvarying vec4 vOffset[3];\r\n\r\nvoid main() {\r\n\r\n\tvUv = uv;\r\n\r\n\tvOffset[0] = uv.xyxy + texelSize.xyxy * vec4(-1.0, 0.0, 0.0, 1.0); // Changed sign in W component.\r\n\tvOffset[1] = uv.xyxy + texelSize.xyxy * vec4(1.0, 0.0, 0.0, -1.0); // Changed sign in W component.\r\n\tvOffset[2] = uv.xyxy + texelSize.xyxy * vec4(-2.0, 0.0, 0.0, 2.0); // Changed sign in W component.\r\n\r\n\tgl_Position = projectionMatrix * modelViewMatrix * vec4(position, 1.0);\r\n\r\n}\r\n",se=function(t){function n(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:new e.Vector2;return u(this,n),v(this,(n.__proto__||Object.getPrototypeOf(n)).call(this,{type:"SMAAColorEdgesMaterial",defines:{EDGE_THRESHOLD:"0.1"},uniforms:{tDiffuse:new e.Uniform(null),texelSize:new e.Uniform(t)},fragmentShader:ae,vertexShader:oe,depthWrite:!1,depthTest:!1}))}return f(n,t),n}(e.ShaderMaterial),le="",ue="",ce="#define sampleLevelZeroOffset(t, coord, offset) texture2D(t, coord + float(offset) * texelSize, 0.0)\r\n\r\nuniform sampler2D tDiffuse;\r\nuniform sampler2D tArea;\r\nuniform sampler2D tSearch;\r\n\r\nuniform vec2 texelSize;\r\n\r\nvarying vec2 vUv;\r\nvarying vec4 vOffset[3];\r\nvarying vec2 vPixCoord;\r\n\r\nvec2 round(vec2 x) {\r\n\r\n\treturn sign(x) * floor(abs(x) + 0.5);\r\n\r\n}\r\n\r\nfloat searchLength(vec2 e, float bias, float scale) {\r\n\r\n\t// Not required if tSearch accesses are set to point.\r\n\t// const vec2 SEARCH_TEX_PIXEL_SIZE = 1.0 / vec2(66.0, 33.0);\r\n\t// e = vec2(bias, 0.0) + 0.5 * SEARCH_TEX_PIXEL_SIZE + e * vec2(scale, 1.0) * vec2(64.0, 32.0) * SEARCH_TEX_PIXEL_SIZE;\r\n\r\n\te.r = bias + e.r * scale;\r\n\r\n\treturn 255.0 * texture2D(tSearch, e, 0.0).r;\r\n\r\n}\r\n\r\nfloat searchXLeft(vec2 texCoord, float end) {\r\n\r\n\t/* @PSEUDO_GATHER4\r\n\t * This texCoord has been offset by (-0.25, -0.125) in the vertex shader to\r\n\t * sample between edge, thus fetching four edges in a row.\r\n\t * Sampling with different offsets in each direction allows to disambiguate\r\n\t * which edges are active from the four fetched ones.\r\n\t */\r\n\r\n\tvec2 e = vec2(0.0, 1.0);\r\n\r\n\tfor(int i = 0; i < SMAA_MAX_SEARCH_STEPS_INT; ++i) {\r\n\r\n\t\te = texture2D(tDiffuse, texCoord, 0.0).rg;\r\n\t\ttexCoord -= vec2(2.0, 0.0) * texelSize;\r\n\r\n\t\tif(!(texCoord.x > end && e.g > 0.8281 && e.r == 0.0)) { break; }\r\n\r\n\t}\r\n\r\n\t// Correct the previously applied offset (-0.25, -0.125).\r\n\ttexCoord.x += 0.25 * texelSize.x;\r\n\r\n\t// The searches are biased by 1, so adjust the coords accordingly.\r\n\ttexCoord.x += texelSize.x;\r\n\r\n\t// Disambiguate the length added by the last step.\r\n\ttexCoord.x += 2.0 * texelSize.x; // Undo last step.\r\n\ttexCoord.x -= texelSize.x * searchLength(e, 0.0, 0.5);\r\n\r\n\treturn texCoord.x;\r\n\r\n}\r\n\r\nfloat searchXRight(vec2 texCoord, float end) {\r\n\r\n\tvec2 e = vec2(0.0, 1.0);\r\n\r\n\tfor(int i = 0; i < SMAA_MAX_SEARCH_STEPS_INT; ++i) {\r\n\r\n\t\te = texture2D(tDiffuse, texCoord, 0.0).rg;\r\n\t\ttexCoord += vec2(2.0, 0.0) * texelSize;\r\n\r\n\t\tif(!(texCoord.x < end && e.g > 0.8281 && e.r == 0.0)) { break; }\r\n\r\n\t}\r\n\r\n\ttexCoord.x -= 0.25 * texelSize.x;\r\n\ttexCoord.x -= texelSize.x;\r\n\ttexCoord.x -= 2.0 * texelSize.x;\r\n\ttexCoord.x += texelSize.x * searchLength(e, 0.5, 0.5);\r\n\r\n\treturn texCoord.x;\r\n\r\n}\r\n\r\nfloat searchYUp(vec2 texCoord, float end) {\r\n\r\n\tvec2 e = vec2(1.0, 0.0);\r\n\r\n\tfor(int i = 0; i < SMAA_MAX_SEARCH_STEPS_INT; ++i) {\r\n\r\n\t\te = texture2D(tDiffuse, texCoord, 0.0).rg;\r\n\t\ttexCoord += vec2(0.0, 2.0) * texelSize; // Changed sign.\r\n\r\n\t\tif(!(texCoord.y > end && e.r > 0.8281 && e.g == 0.0)) { break; }\r\n\r\n\t}\r\n\r\n\ttexCoord.y -= 0.25 * texelSize.y; // Changed sign.\r\n\ttexCoord.y -= texelSize.y; // Changed sign.\r\n\ttexCoord.y -= 2.0 * texelSize.y; // Changed sign.\r\n\ttexCoord.y += texelSize.y * searchLength(e.gr, 0.0, 0.5); // Changed sign.\r\n\r\n\treturn texCoord.y;\r\n\r\n}\r\n\r\nfloat searchYDown(vec2 texCoord, float end) {\r\n\r\n\tvec2 e = vec2(1.0, 0.0);\r\n\r\n\tfor(int i = 0; i < SMAA_MAX_SEARCH_STEPS_INT; ++i ) {\r\n\r\n\t\te = texture2D(tDiffuse, texCoord, 0.0).rg;\r\n\t\ttexCoord -= vec2(0.0, 2.0) * texelSize; // Changed sign.\r\n\r\n\t\tif(!(texCoord.y < end && e.r > 0.8281 && e.g == 0.0)) { break; }\r\n\r\n\t}\r\n\r\n\ttexCoord.y += 0.25 * texelSize.y; // Changed sign.\r\n\ttexCoord.y += texelSize.y; // Changed sign.\r\n\ttexCoord.y += 2.0 * texelSize.y; // Changed sign.\r\n\ttexCoord.y -= texelSize.y * searchLength(e.gr, 0.5, 0.5); // Changed sign.\r\n\r\n\treturn texCoord.y;\r\n\r\n}\r\n\r\nvec2 area(vec2 dist, float e1, float e2, float offset) {\r\n\r\n\t// Rounding prevents precision errors of bilinear filtering.\r\n\tvec2 texCoord = SMAA_AREATEX_MAX_DISTANCE * round(4.0 * vec2(e1, e2)) + dist;\r\n\r\n\t// Scale and bias for texel space translation.\r\n\ttexCoord = SMAA_AREATEX_PIXEL_SIZE * texCoord + (0.5 * SMAA_AREATEX_PIXEL_SIZE);\r\n\r\n\t// Move to proper place, according to the subpixel offset.\r\n\ttexCoord.y += SMAA_AREATEX_SUBTEX_SIZE * offset;\r\n\r\n\treturn texture2D(tArea, texCoord, 0.0).rg;\r\n\r\n}\r\n\r\nvoid main() {\r\n\r\n\tvec4 weights = vec4(0.0);\r\n\tvec4 subsampleIndices = vec4(0.0);\r\n\tvec2 e = texture2D(tDiffuse, vUv).rg;\r\n\r\n\tif(e.g > 0.0) {\r\n\r\n\t\t// Edge at north.\r\n\t\tvec2 d;\r\n\r\n\t\t// Find the distance to the left.\r\n\t\tvec2 coords;\r\n\t\tcoords.x = searchXLeft(vOffset[0].xy, vOffset[2].x);\r\n\t\tcoords.y = vOffset[1].y; // vOffset[1].y = vUv.y - 0.25 * texelSize.y (@CROSSING_OFFSET)\r\n\t\td.x = coords.x;\r\n\r\n\t\t/* Now fetch the left crossing edges, two at a time using bilinear filtering.\r\n\t\tSampling at -0.25 (see @CROSSING_OFFSET) enables to discern what value each edge has. */\r\n\r\n\t\tfloat e1 = texture2D(tDiffuse, coords, 0.0).r;\r\n\r\n\t\t// Find the distance to the right.\r\n\t\tcoords.x = searchXRight(vOffset[0].zw, vOffset[2].y);\r\n\t\td.y = coords.x;\r\n\r\n\t\t// Translate distances to pixel units for better interleave arithmetic and memory accesses.\r\n\t\td = d / texelSize.x - vPixCoord.x;\r\n\r\n\t\t// The area below needs a sqrt, as the areas texture is compressed quadratically.\r\n\t\tvec2 sqrtD = sqrt(abs(d));\r\n\r\n\t\t// Fetch the right crossing edges.\r\n\t\tcoords.y -= texelSize.y; // WebGL port note: Added.\r\n\t\tfloat e2 = sampleLevelZeroOffset(tDiffuse, coords, ivec2(1, 0)).r;\r\n\r\n\t\t// Pattern recognised, now get the actual area.\r\n\t\tweights.rg = area(sqrtD, e1, e2, subsampleIndices.y);\r\n\r\n\t}\r\n\r\n\tif(e.r > 0.0) {\r\n\r\n\t\t// Edge at west.\r\n\t\tvec2 d;\r\n\r\n\t\t// Find the distance to the top.\r\n\t\tvec2 coords;\r\n\r\n\t\tcoords.y = searchYUp(vOffset[1].xy, vOffset[2].z);\r\n\t\tcoords.x = vOffset[0].x; // vOffset[1].x = vUv.x - 0.25 * texelSize.x;\r\n\t\td.x = coords.y;\r\n\r\n\t\t// Fetch the top crossing edges.\r\n\t\tfloat e1 = texture2D(tDiffuse, coords, 0.0).g;\r\n\r\n\t\t// Find the distance to the bottom.\r\n\t\tcoords.y = searchYDown(vOffset[1].zw, vOffset[2].w);\r\n\t\td.y = coords.y;\r\n\r\n\t\t// Distances in pixel units.\r\n\t\td = d / texelSize.y - vPixCoord.y;\r\n\r\n\t\t// The area below needs a sqrt, as the areas texture is compressed quadratically.\r\n\t\tvec2 sqrtD = sqrt(abs(d));\r\n\r\n\t\t// Fetch the bottom crossing edges.\r\n\t\tcoords.y -= texelSize.y; // WebGL port note: Added.\r\n\t\tfloat e2 = sampleLevelZeroOffset(tDiffuse, coords, ivec2(0, 1)).g;\r\n\r\n\t\t// Get the area for this direction.\r\n\t\tweights.ba = area(sqrtD, e1, e2, subsampleIndices.x);\r\n\r\n\t}\r\n\r\n\tgl_FragColor = weights;\r\n\r\n}\r\n",de="uniform vec2 texelSize;\r\n\r\nvarying vec2 vUv;\r\nvarying vec4 vOffset[3];\r\nvarying vec2 vPixCoord;\r\n\r\nvoid main() {\r\n\r\n\tvUv = uv;\r\n\r\n\tvPixCoord = uv / texelSize;\r\n\r\n\t// Offsets for the searches (see @PSEUDO_GATHER4).\r\n\tvOffset[0] = uv.xyxy + texelSize.xyxy * vec4(-0.25, 0.125, 1.25, 0.125); // Changed sign in Y and W components.\r\n\tvOffset[1] = uv.xyxy + texelSize.xyxy * vec4(-0.125, 0.25, -0.125, -1.25); //Changed sign in Y and W components.\r\n\r\n\t// This indicates the ends of the loops.\r\n\tvOffset[2] = vec4(vOffset[0].xz, vOffset[1].yw) + vec4(-2.0, 2.0, -2.0, 2.0) * texelSize.xxyy * SMAA_MAX_SEARCH_STEPS_FLOAT;\r\n\r\n\tgl_Position = projectionMatrix * modelViewMatrix * vec4(position, 1.0);\r\n\r\n}\r\n",fe=function(t){function n(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:new e.Vector2;u(this,n);var r=v(this,(n.__proto__||Object.getPrototypeOf(n)).call(this,{type:"SMAAWeightsMaterial",defines:{SMAA_MAX_SEARCH_STEPS_INT:"8",SMAA_MAX_SEARCH_STEPS_FLOAT:"8.0",SMAA_AREATEX_MAX_DISTANCE:"16.0",SMAA_AREATEX_PIXEL_SIZE:"(1.0 / vec2(160.0, 560.0))",SMAA_AREATEX_SUBTEX_SIZE:"(1.0 / 7.0)"},uniforms:{tDiffuse:new e.Uniform(null),tArea:new e.Uniform(null),tSearch:new e.Uniform(null),texelSize:new e.Uniform(t)},fragmentShader:ce,vertexShader:de,depthWrite:!1,depthTest:!1}));return r.areaImage=le,r.searchImage=ue,r}return f(n,t),n}(e.ShaderMaterial),ve="uniform sampler2D tDiffuse;\r\nuniform float middleGrey;\r\nuniform float maxLuminance;\r\nuniform vec3 luminanceCoefficients;\r\n\r\n#ifdef ADAPTED_LUMINANCE\r\n\r\n\tuniform sampler2D luminanceMap;\r\n\r\n#else\r\n\r\n\tuniform float averageLuminance;\r\n\r\n#endif\r\n\r\nvarying vec2 vUv;\r\n\r\nvec3 toneMap(vec3 c) {\r\n\r\n\t#ifdef ADAPTED_LUMINANCE\r\n\r\n\t\t// Get the calculated average luminance by sampling the center.\r\n\t\tfloat lumAvg = texture2D(luminanceMap, vec2(0.5)).r;\r\n\r\n\t#else\r\n\r\n\t\tfloat lumAvg = averageLuminance;\r\n\r\n\t#endif\r\n\r\n\t// Calculate the luminance of the current pixel.\r\n\tfloat lumPixel = dot(c, luminanceCoefficients);\r\n\r\n\t// Apply the modified operator (Reinhard Eq. 4).\r\n\tfloat lumScaled = (lumPixel * middleGrey) / lumAvg;\r\n\r\n\tfloat lumCompressed = (lumScaled * (1.0 + (lumScaled / (maxLuminance * maxLuminance)))) / (1.0 + lumScaled);\r\n\r\n\treturn lumCompressed * c;\r\n\r\n}\r\n\r\nvoid main() {\r\n\r\n\tvec4 texel = texture2D(tDiffuse, vUv);\r\n\tgl_FragColor = vec4(toneMap(texel.rgb), texel.a);\r\n\r\n}\r\n",he="varying vec2 vUv;\r\n\r\nvoid main() {\r\n\r\n\tvUv = uv;\r\n\tgl_Position = projectionMatrix * modelViewMatrix * vec4(position, 1.0);\r\n\r\n}\r\n",me=function(t){function n(){return u(this,n),v(this,(n.__proto__||Object.getPrototypeOf(n)).call(this,{type:"ToneMappingMaterial",uniforms:{tDiffuse:new e.Uniform(null),luminanceMap:new e.Uniform(null),averageLuminance:new e.Uniform(1),luminanceCoefficients:new e.Uniform(new e.Vector3(.2126,.7152,.0722)),maxLuminance:new e.Uniform(16),middleGrey:new e.Uniform(.6)},fragmentShader:ve,vertexShader:he,depthWrite:!1,depthTest:!1}))}return f(n,t),n}(e.ShaderMaterial),pe=function(){function t(){var n=arguments.length>0&&void 0!==arguments[0]?arguments[0]:new e.Scene,r=arguments.length>1&&void 0!==arguments[1]?arguments[1]:new e.OrthographicCamera(-1,1,1,-1,0,1),i=arguments.length>2&&void 0!==arguments[2]?arguments[2]:new e.Mesh(new e.PlaneBufferGeometry(2,2),null);u(this,t),this.name="Pass",this.scene=n,this.camera=r,this.quad=i,null!==this.quad&&(this.quad.frustumCulled=!1,null!==this.scene&&this.scene.add(this.quad)),this.needsSwap=!1,this.enabled=!0,this.renderToScreen=!1}return c(t,[{key:"render",value:function(e,t,n,r,i){throw new Error("Render method not implemented!")}},{key:"setSize",value:function(e,t){}},{key:"initialise",value:function(e,t){}},{key:"dispose",value:function(){var e=Object.keys(this),t=void 0,n=!0,r=!1,i=void 0;try{for(var a,o=e[Symbol.iterator]();!(n=(a=o.next()).done);n=!0)null!==this[t=a.value]&&"function"==typeof this[t].dispose&&(this[t].dispose(),this[t]=null)}catch(e){r=!0,i=e}finally{try{!n&&o.return&&o.return()}finally{if(r)throw i}}}}]),t}(),ge=function(t){function n(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};u(this,n);var r=v(this,(n.__proto__||Object.getPrototypeOf(n)).call(this));return r.name="BlurPass",r.needsSwap=!0,r.renderTargetX=new e.WebGLRenderTarget(1,1,{minFilter:e.LinearFilter,magFilter:e.LinearFilter,stencilBuffer:!1,depthBuffer:!1}),r.renderTargetX.texture.name="Blur.TargetX",r.renderTargetX.texture.generateMipmaps=!1,r.renderTargetY=r.renderTargetX.clone(),r.renderTargetY.texture.name="Blur.TargetY",r.resolutionScale=void 0!==t.resolutionScale?t.resolutionScale:.5,r.convolutionMaterial=new T,r.kernelSize=t.kernelSize,r.quad.material=r.convolutionMaterial,r}return f(n,pe),c(n,[{key:"render",value:function(e,t,n){var r=this.scene,i=this.camera,a=this.renderTargetX,o=this.renderTargetY,s=this.convolutionMaterial,l=s.uniforms,u=s.getKernel(),c=t,d=void 0,f=void 0,v=void 0;for(f=0,v=u.length-1;f0&&void 0!==arguments[0]?arguments[0]:C.LARGE;this.convolutionMaterial.kernelSize=e}}]),n}(),xe=function(t){function n(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};u(this,n);var r=v(this,(n.__proto__||Object.getPrototypeOf(n)).call(this));return r.name="BloomPass",r.needsSwap=!0,r.blurPass=new ge(t),r.renderTarget=new e.WebGLRenderTarget(1,1,{minFilter:e.LinearFilter,magFilter:e.LinearFilter,stencilBuffer:!1,depthBuffer:!1}),r.renderTarget.texture.name="Bloom.Target",r.renderTarget.texture.generateMipmaps=!1,r.combineMaterial=new S(void 0===t.screenMode||t.screenMode),r.intensity=t.intensity,r.luminosityMaterial=new Z(!0),r.distinction=t.distinction,r}return f(n,pe),c(n,[{key:"render",value:function(e,t,n){var r=this.quad,i=this.scene,a=this.camera,o=this.blurPass,s=this.luminosityMaterial,l=this.combineMaterial,u=this.renderTarget;r.material=s,s.uniforms.tDiffuse.value=t.texture,e.render(i,a,u),o.render(e,u,u),r.material=l,l.uniforms.texture1.value=t.texture,l.uniforms.texture2.value=u.texture,e.render(i,a,this.renderToScreen?null:n)}},{key:"initialise",value:function(t,n){this.blurPass.initialise(t,n),n||(this.renderTarget.texture.format=e.RGBFormat)}},{key:"setSize",value:function(e,t){this.blurPass.setSize(e,t),e=this.blurPass.width,t=this.blurPass.height,this.renderTarget.setSize(e,t)}},{key:"resolutionScale",get:function(){return this.blurPass.resolutionScale},set:function(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:.5;this.blurPass.resolutionScale=e}},{key:"kernelSize",get:function(){return this.blurPass.kernelSize},set:function(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:C.LARGE;this.blurPass.kernelSize=e}},{key:"intensity",get:function(){return this.combineMaterial.uniforms.opacity2.value},set:function(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:1;this.combineMaterial.uniforms.opacity2.value=e}},{key:"distinction",get:function(){return this.luminosityMaterial.uniforms.distinction.value},set:function(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:1;this.luminosityMaterial.uniforms.distinction.value=e}}]),n}(),ye=function(e){function t(e){var n=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};u(this,t);var r=v(this,(t.__proto__||Object.getPrototypeOf(t)).call(this));return r.name="BokehPass",r.needsSwap=!0,r.bokehMaterial=new g(e,n),r.quad.material=r.bokehMaterial,r}return f(t,pe),c(t,[{key:"render",value:function(e,t,n){this.bokehMaterial.uniforms.tDiffuse.value=t.texture,this.bokehMaterial.uniforms.tDepth.value=t.depthTexture,e.render(this.scene,this.camera,this.renderToScreen?null:n)}},{key:"setSize",value:function(e,t){this.bokehMaterial.uniforms.aspect.value=e/t}}]),t}(),Me=function(e){function t(e){var n=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};u(this,t);var r=v(this,(t.__proto__||Object.getPrototypeOf(t)).call(this));return r.name="Bokeh2Pass",r.needsSwap=!0,r.bokehMaterial=new M(e,n),r.quad.material=r.bokehMaterial,r}return f(t,pe),c(t,[{key:"render",value:function(e,t,n){this.bokehMaterial.uniforms.tDiffuse.value=t.texture,this.bokehMaterial.uniforms.tDepth.value=t.depthTexture,e.render(this.scene,this.camera,this.renderToScreen?null:n)}},{key:"setSize",value:function(e,t){this.bokehMaterial.setTexelSize(1/e,1/t)}}]),t}(),we=function(e){function t(){u(this,t);var e=v(this,(t.__proto__||Object.getPrototypeOf(t)).call(this,null,null,null));return e.name="ClearMaskPass",e}return f(t,pe),c(t,[{key:"render",value:function(e){e.state.buffers.stencil.setTest(!1)}}]),t}(),be=new e.Color,Se=function(e){function t(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};u(this,t);var n=v(this,(t.__proto__||Object.getPrototypeOf(t)).call(this,null,null,null));return n.name="ClearPass",n.clearColor=void 0!==e.clearColor?e.clearColor:null,n.clearAlpha=void 0!==e.clearAlpha?e.clearAlpha:0,n}return f(t,pe),c(t,[{key:"render",value:function(e,t){var n=this.clearColor,r=void 0;null!==n&&(be.copy(e.getClearColor()),r=e.getClearAlpha(),e.setClearColor(n,this.clearAlpha)),e.setRenderTarget(this.renderToScreen?null:t),e.clear(),null!==n&&e.setClearColor(be,r)}}]),t}(),De=function(e){function t(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};u(this,t);var n=v(this,(t.__proto__||Object.getPrototypeOf(t)).call(this));return n.name="DotScreenPass",n.needsSwap=!0,n.material=new j(e.average),void 0!==e.angle&&(n.material.uniforms.angle.value=e.angle),void 0!==e.scale&&(n.material.uniforms.scale.value=e.scale),void 0!==e.intensity&&(n.material.uniforms.intensity.value=e.intensity),n.quad.material=n.material,n}return f(t,pe),c(t,[{key:"render",value:function(e,t,n){this.material.uniforms.tDiffuse.value=t.texture,e.render(this.scene,this.camera,this.renderToScreen?null:n)}},{key:"setSize",value:function(e,t){e=Math.max(1,e),t=Math.max(1,t),this.material.uniforms.offsetRepeat.value.z=e,this.material.uniforms.offsetRepeat.value.w=t}}]),t}(),Pe=function(e){function t(e){u(this,t);var n=v(this,(t.__proto__||Object.getPrototypeOf(t)).call(this));return n.name="DepthPass",n.needsSwap=!0,n.depthMaterial=new z(e),n.quad.material=n.depthMaterial,n}return f(t,pe),c(t,[{key:"render",value:function(e,t,n){this.depthMaterial.uniforms.tDepth.value=t.depthTexture,e.render(this.scene,this.camera,this.renderToScreen?null:n)}}]),t}(),Te=function(e){function t(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};u(this,t);var n=v(this,(t.__proto__||Object.getPrototypeOf(t)).call(this));return n.name="FilmPass",n.needsSwap=!0,n.material=new I(e),n.quad.material=n.material,n.scanlineDensity=void 0===e.scanlineDensity?1.25:e.scanlineDensity,n}return f(t,pe),c(t,[{key:"render",value:function(e,t,n,r){this.material.uniforms.tDiffuse.value=t.texture,this.material.uniforms.time.value+=r,e.render(this.scene,this.camera,this.renderToScreen?null:n)}},{key:"setSize",value:function(e,t){this.material.uniforms.scanlineCount.value=Math.round(t*this.scanlineDensity)}}]),t}(),Ae=function(t){function n(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};u(this,n);var t=v(this,(n.__proto__||Object.getPrototypeOf(n)).call(this));return t.name="GlitchPass",t.needsSwap=!0,t.material=new H,t.quad.material=t.material,t.texture=null,t.perturbMap=void 0!==e.perturbMap?e.perturbMap:t.generatePerturbMap(e.dtSize),t.perturbMap.name="Glitch.Perturbation",t.perturbMap.generateMipmaps=!1,t.mode=Ce.SPORADIC,t.counter=0,t.breakPoint=r(120,240),t}return f(n,pe),c(n,[{key:"generatePerturbMap",value:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:64,n=t*t,r=new Float32Array(3*n),i=this.perturbMap,a=void 0,o=void 0;for(a=0;a2&&void 0!==arguments[2]?arguments[2]:{};u(this,t);var i=v(this,(t.__proto__||Object.getPrototypeOf(t)).call(this,e,n,null));return i.name="RenderPass",i.clearPass=new Se(r),i.overrideMaterial=void 0!==r.overrideMaterial?r.overrideMaterial:null,i.clearDepth=void 0!==r.clearDepth&&r.clearDepth,i.clear=void 0===r.clear||r.clear,i}return f(t,pe),c(t,[{key:"render",value:function(e,t){var n=this.scene,r=this.renderToScreen?null:t;this.clear?this.clearPass.render(e,r):this.clearDepth&&(e.setRenderTarget(r),e.clearDepth()),n.overrideMaterial=this.overrideMaterial,e.render(n,this.camera,r),n.overrideMaterial=null}}]),t}(),Le=function(t){function n(t,r,i){var a=arguments.length>3&&void 0!==arguments[3]?arguments[3]:{};u(this,n);var o=v(this,(n.__proto__||Object.getPrototypeOf(n)).call(this));return o.name="GodRaysPass",o.needsSwap=!0,o.lightScene=new e.Scene,o.mainScene=t,o.mainCamera=r,o.renderPassLight=new Oe(o.lightScene,o.mainCamera),o.renderPassMask=new Oe(o.mainScene,o.mainCamera,{overrideMaterial:new e.MeshBasicMaterial({color:0}),clearColor:new e.Color(0)}),o.renderPassMask.clear=!1,o.blurPass=new ge(a),o.renderTargetX=new e.WebGLRenderTarget(1,1,{minFilter:e.LinearFilter,magFilter:e.LinearFilter,stencilBuffer:!1,depthBuffer:!1}),o.renderTargetX.texture.name="GodRays.TargetX",o.renderTargetX.texture.generateMipmaps=!1,o.renderTargetY=o.renderTargetX.clone(),o.renderTargetY.texture.name="GodRays.TargetY",o.renderTargetMask=new e.WebGLRenderTarget(1,1,{minFilter:e.LinearFilter,magFilter:e.LinearFilter}),o.renderTargetMask.texture.name="GodRays.Mask",o.renderTargetMask.texture.generateMipmaps=!1,o.lightSource=i,o.screenPosition=new e.Vector3,o.godRaysMaterial=new Y,o.godRaysMaterial.uniforms.lightPosition.value=o.screenPosition,void 0!==a.exposure&&(o.godRaysMaterial.uniforms.exposure.value=a.exposure),void 0!==a.density&&(o.godRaysMaterial.uniforms.density.value=a.density),void 0!==a.decay&&(o.godRaysMaterial.uniforms.decay.value=a.decay),void 0!==a.weight&&(o.godRaysMaterial.uniforms.weight.value=a.weight),void 0!==a.clampMax&&(o.godRaysMaterial.uniforms.clampMax.value=a.clampMax),o.samples=a.samples,o.combineMaterial=new S(void 0===a.screenMode||a.screenMode),o.intensity=a.intensity,o}return f(n,pe),c(n,[{key:"render",value:function(e,t,n){var r=this.quad,i=this.scene,o=this.camera,s=this.mainScene,l=this.lightSource,u=this.screenPosition,c=this.godRaysMaterial,d=this.combineMaterial,f=this.renderTargetMask,v=this.renderTargetX,h=this.renderTargetY,m=void 0,p=void 0;u.copy(l.position).project(this.mainCamera),u.x=a(.5*(u.x+1),0,1),u.y=a(.5*(u.y+1),0,1),p=l.parent,m=s.background,s.background=null,this.lightScene.add(l),this.renderPassLight.render(e,f),this.renderPassMask.render(e,f),null!==p&&p.add(l),s.background=m,this.blurPass.render(e,f,v),r.material=c,c.uniforms.tDiffuse.value=v.texture,e.render(i,o,h),r.material=d,d.uniforms.texture1.value=t.texture,d.uniforms.texture2.value=h.texture,e.render(i,o,this.renderToScreen?null:n)}},{key:"initialise",value:function(t,n){this.renderPassLight.initialise(t,n),this.renderPassMask.initialise(t,n),this.blurPass.initialise(t,n),n||(this.renderTargetMask.texture.format=e.RGBFormat,this.renderTargetX.texture.format=e.RGBFormat,this.renderTargetY.texture.format=e.RGBFormat)}},{key:"setSize",value:function(e,t){this.renderPassLight.setSize(e,t),this.renderPassMask.setSize(e,t),this.blurPass.setSize(e,t),e=this.blurPass.width,t=this.blurPass.height,this.renderTargetMask.setSize(e,t),this.renderTargetX.setSize(e,t),this.renderTargetY.setSize(e,t)}},{key:"resolutionScale",get:function(){return this.blurPass.resolutionScale},set:function(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:.5;this.blurPass.resolutionScale=e}},{key:"kernelSize",get:function(){return this.blurPass.kernelSize},set:function(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:C.LARGE;this.blurPass.kernelSize=e}},{key:"intensity",get:function(){return this.combineMaterial.uniforms.opacity2.value},set:function(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:1;this.combineMaterial.uniforms.opacity2.value=e}},{key:"samples",get:function(){return Number.parseInt(this.godRaysMaterial.defines.NUM_SAMPLES_INT)},set:function(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:60;e=Math.floor(e),this.godRaysMaterial.defines.NUM_SAMPLES_FLOAT=e.toFixed(1),this.godRaysMaterial.defines.NUM_SAMPLES_INT=e.toFixed(0),this.godRaysMaterial.needsUpdate=!0}}]),n}(),Ee=function(e){function t(e,n){u(this,t);var r=v(this,(t.__proto__||Object.getPrototypeOf(t)).call(this,e,n,null));return r.name="MaskPass",r.inverse=!1,r.clearStencil=!0,r}return f(t,pe),c(t,[{key:"render",value:function(e,t,n){var r=e.context,i=e.state,a=this.scene,o=this.camera,s=this.inverse?0:1,l=1-s;i.buffers.color.setMask(!1),i.buffers.depth.setMask(!1),i.buffers.color.setLocked(!0),i.buffers.depth.setLocked(!0),i.buffers.stencil.setTest(!0),i.buffers.stencil.setOp(r.REPLACE,r.REPLACE,r.REPLACE),i.buffers.stencil.setFunc(r.ALWAYS,s,4294967295),i.buffers.stencil.setClear(l),this.clearStencil&&(e.setRenderTarget(t),e.clearStencil(),e.setRenderTarget(n),e.clearStencil()),e.render(a,o,t),e.render(a,o,n),i.buffers.color.setLocked(!1),i.buffers.depth.setLocked(!1),i.buffers.stencil.setFunc(r.EQUAL,1,4294967295),i.buffers.stencil.setOp(r.KEEP,r.KEEP,r.KEEP)}}]),t}(),ke=function(e){function t(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:30;u(this,t);var n=v(this,(t.__proto__||Object.getPrototypeOf(t)).call(this));return n.name="PixelationPass",n.needsSwap=!0,n.pixelationMaterial=new _,n.granularity=e,n.quad.material=n.pixelationMaterial,n}return f(t,pe),c(t,[{key:"render",value:function(e,t,n){this.pixelationMaterial.uniforms.tDiffuse.value=t.texture,e.render(this.scene,this.camera,this.renderToScreen?null:n)}},{key:"setSize",value:function(e,t){this.pixelationMaterial.setResolution(e,t)}},{key:"granularity",get:function(){return this.pixelationMaterial.granularity},set:function(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:30;(e=Math.floor(e))%2>0&&(e+=1),this.pixelationMaterial.granularity=e}}]),t}(),Ue=function(t){function n(t){var r=!(arguments.length>1&&void 0!==arguments[1])||arguments[1];u(this,n);var i=v(this,(n.__proto__||Object.getPrototypeOf(n)).call(this));return i.name="SavePass",i.material=new E,i.quad.material=i.material,i.renderTarget=void 0!==t?t:new e.WebGLRenderTarget(1,1,{minFilter:e.LinearFilter,magFilter:e.LinearFilter,stencilBuffer:!1,depthBuffer:!1}),i.renderTarget.texture.name="Save.Target",i.renderTarget.texture.generateMipmaps=!1,i.resize=r,i}return f(n,pe),c(n,[{key:"render",value:function(e,t){this.material.uniforms.tDiffuse.value=t.texture,e.render(this.scene,this.camera,this.renderTarget)}},{key:"initialise",value:function(t,n){n||(this.renderTarget.texture.format=e.RGBFormat)}},{key:"setSize",value:function(e,t){this.resize&&(e=Math.max(1,e),t=Math.max(1,t),this.renderTarget.setSize(e,t))}}]),n}(),ze=function(e){function t(e){var n=arguments.length>1&&void 0!==arguments[1]?arguments[1]:"tDiffuse";u(this,t);var r=v(this,(t.__proto__||Object.getPrototypeOf(t)).call(this));return r.name="ShaderPass",r.needsSwap=!0,r.material=e,r.quad.material=r.material,r.textureID=n,r}return f(t,pe),c(t,[{key:"render",value:function(e,t,n){void 0!==this.material.uniforms[this.textureID]&&(this.material.uniforms[this.textureID].value=t.texture),e.render(this.scene,this.camera,this.renderToScreen?null:n)}}]),t}(),Fe=.5*Math.PI,Ne=new e.Vector3,je=new e.Vector3,Be=function(t){function n(t){var r=arguments.length>1&&void 0!==arguments[1]?arguments[1]:new e.Vector3,i=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{};u(this,n);var a=v(this,(n.__proto__||Object.getPrototypeOf(n)).call(this));return a.name="ShockWavePass",a.needsSwap=!0,a.mainCamera=t,a.epicenter=r,a.screenPosition=new e.Vector3,a.speed=void 0!==i.speed?i.speed:2,a.time=0,a.active=!1,a.shockWaveMaterial=new te(i),a.shockWaveMaterial.uniforms.center.value=a.screenPosition,a.copyMaterial=new E,a}return f(n,pe),c(n,[{key:"explode",value:function(){this.time=0,this.active=!0}},{key:"render",value:function(e,t,n,r){var i=this.epicenter,a=this.mainCamera,o=this.screenPosition,s=this.shockWaveMaterial,l=s.uniforms,u=l.center,c=l.radius,d=l.maxRadius,f=l.waveSize;this.copyMaterial.uniforms.tDiffuse.value=t.texture,this.quad.material=this.copyMaterial,this.active&&(a.getWorldDirection(Ne),je.copy(a.position).sub(i),Ne.angleTo(je)>Fe&&(l.cameraDistance.value=a.position.distanceTo(i),o.copy(i).project(a),u.value.x=.5*(o.x+1),u.value.y=.5*(o.y+1),l.tDiffuse.value=t.texture,this.quad.material=s),this.time+=r*this.speed,c.value=this.time-f.value,c.value>=2*(d.value+f.value)&&(this.active=!1)),e.render(this.scene,this.camera,this.renderToScreen?null:n)}},{key:"setSize",value:function(e,t){this.shockWaveMaterial.uniforms.aspect.value=e/t}}]),n}(),Re=function(t){function n(t){u(this,n);var r=v(this,(n.__proto__||Object.getPrototypeOf(n)).call(this));r.name="SMAAPass",r.needsSwap=!0,r.renderTargetColorEdges=new e.WebGLRenderTarget(1,1,{minFilter:e.LinearFilter,format:e.RGBFormat,stencilBuffer:!1,depthBuffer:!1}),r.renderTargetColorEdges.texture.name="SMAA.ColorEdges",r.renderTargetColorEdges.texture.generateMipmaps=!1,r.renderTargetWeights=r.renderTargetColorEdges.clone(),r.renderTargetWeights.texture.name="SMAA.Weights",r.renderTargetWeights.texture.format=e.RGBAFormat,r.colorEdgesMaterial=new se,r.weightsMaterial=new fe;var i=new t;i.src=r.weightsMaterial.areaImage;var a=new e.Texture;a.image=i,a.name="SMAA.Area",a.minFilter=e.LinearFilter,a.format=e.RGBFormat,a.generateMipmaps=!1,a.needsUpdate=!0,a.flipY=!1;var o=new t;o.src=r.weightsMaterial.searchImage;var s=new e.Texture;return s.image=o,s.name="SMAA.Search",s.magFilter=e.NearestFilter,s.minFilter=e.NearestFilter,s.generateMipmaps=!1,s.needsUpdate=!0,s.flipY=!1,r.weightsMaterial.uniforms.tDiffuse.value=r.renderTargetColorEdges.texture,r.weightsMaterial.uniforms.tArea.value=a,r.weightsMaterial.uniforms.tSearch.value=s,r.blendMaterial=new ie,r.blendMaterial.uniforms.tWeights.value=r.renderTargetWeights.texture,r.quad.material=r.blendMaterial,r}return f(n,pe),c(n,[{key:"render",value:function(e,t,n){this.quad.material=this.colorEdgesMaterial,this.colorEdgesMaterial.uniforms.tDiffuse.value=t.texture,e.render(this.scene,this.camera,this.renderTargetColorEdges,!0),this.quad.material=this.weightsMaterial,e.render(this.scene,this.camera,this.renderTargetWeights,!1),this.quad.material=this.blendMaterial,this.blendMaterial.uniforms.tDiffuse.value=t.texture,e.render(this.scene,this.camera,this.renderToScreen?null:n)}},{key:"setSize",value:function(e,t){this.renderTargetColorEdges.setSize(e,t),this.renderTargetWeights.setSize(e,t),this.colorEdgesMaterial.uniforms.texelSize.value.copy(this.weightsMaterial.uniforms.texelSize.value.copy(this.blendMaterial.uniforms.texelSize.value.set(1/e,1/t)))}}]),n}(),Ie=function(t){function n(t){var r=arguments.length>1&&void 0!==arguments[1]?arguments[1]:1;u(this,n);var i=v(this,(n.__proto__||Object.getPrototypeOf(n)).call(this));return i.name="TexturePass",i.copyMaterial=new E,i.copyMaterial.blending=e.AdditiveBlending,i.copyMaterial.transparent=!0,i.texture=t,i.opacity=r,i.quad.material=i.copyMaterial,i}return f(n,pe),c(n,[{key:"render",value:function(e,t){e.render(this.scene,this.camera,this.renderToScreen?null:t)}},{key:"texture",get:function(){return this.copyMaterial.uniforms.tDiffuse.value},set:function(e){this.copyMaterial.uniforms.tDiffuse.value=e}},{key:"opacity",get:function(){return this.copyMaterial.uniforms.opacity.value},set:function(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:1;this.copyMaterial.uniforms.opacity.value=e}}]),n}(),Ge=function(t){function n(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};u(this,n);var r=v(this,(n.__proto__||Object.getPrototypeOf(n)).call(this));return r.name="ToneMappingPass",r.needsSwap=!0,r.renderTargetLuminosity=new e.WebGLRenderTarget(1,1,{minFilter:e.LinearMipMapLinearFilter,magFilter:e.LinearFilter,format:e.RGBFormat,stencilBuffer:!1,depthBuffer:!1}),r.renderTargetLuminosity.texture.name="ToneMapping.Luminosity",r.renderTargetAdapted=r.renderTargetLuminosity.clone(),r.renderTargetAdapted.texture.name="ToneMapping.AdaptedLuminosity",r.renderTargetAdapted.texture.generateMipmaps=!1,r.renderTargetAdapted.texture.minFilter=e.LinearFilter,r.renderTargetPrevious=r.renderTargetAdapted.clone(),r.renderTargetPrevious.texture.name="ToneMapping.PreviousLuminosity",r.copyMaterial=new E,r.luminosityMaterial=new Z,r.luminosityMaterial.uniforms.distinction.value=void 0!==t.distinction?t.distinction:1,r.adaptiveLuminosityMaterial=new h,r.resolution=t.resolution,r.toneMappingMaterial=new me,r.adaptive=t.adaptive,r}return f(n,pe),c(n,[{key:"render",value:function(e,t,n,r){var i=this.quad,a=this.scene,o=this.camera,s=this.adaptiveLuminosityMaterial,l=this.luminosityMaterial,u=this.toneMappingMaterial,c=this.copyMaterial,d=this.renderTargetPrevious,f=this.renderTargetLuminosity,v=this.renderTargetAdapted;this.adaptive&&(i.material=l,l.uniforms.tDiffuse.value=t.texture,e.render(a,o,f),i.material=s,s.uniforms.delta.value=r,s.uniforms.tPreviousLum.value=d.texture,s.uniforms.tCurrentLum.value=f.texture,e.render(a,o,v),i.material=c,c.uniforms.tDiffuse.value=v.texture,e.render(a,o,d)),i.material=u,u.uniforms.tDiffuse.value=t.texture,e.render(this.scene,this.camera,this.renderToScreen?null:n)}},{key:"initialise",value:function(t){this.quad.material=new e.MeshBasicMaterial({color:8388607}),t.render(this.scene,this.camera,this.renderTargetPrevious),this.quad.material.dispose()}},{key:"resolution",get:function(){return this.renderTargetLuminosity.width},set:function(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:256;e=o(e),this.renderTargetLuminosity.setSize(e,e),this.renderTargetPrevious.setSize(e,e),this.renderTargetAdapted.setSize(e,e),this.adaptiveLuminosityMaterial.defines.MIP_LEVEL_1X1=(Math.round(Math.log(e))/Math.log(2)).toFixed(1),this.adaptiveLuminosityMaterial.needsUpdate=!0}},{key:"adaptive",get:function(){return void 0!==this.toneMappingMaterial.defines.ADAPTED_LUMINANCE},set:function(){!(arguments.length>0&&void 0!==arguments[0])||arguments[0]?(this.toneMappingMaterial.defines.ADAPTED_LUMINANCE="1",this.toneMappingMaterial.uniforms.luminanceMap.value=this.renderTargetAdapted.texture):(delete this.toneMappingMaterial.defines.ADAPTED_LUMINANCE,this.toneMappingMaterial.uniforms.luminanceMap.value=null),this.toneMappingMaterial.needsUpdate=!0}}]),n}(),We=function(){function t(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:null,n=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};u(this,t),this.renderer=e,this.readBuffer=null,this.writeBuffer=null,null!==this.renderer&&(this.renderer.autoClear=!1,this.readBuffer=this.createBuffer(void 0===n.depthBuffer||n.depthBuffer,void 0!==n.stencilBuffer&&n.stencilBuffer,void 0!==n.depthTexture&&n.depthTexture),this.writeBuffer=this.readBuffer.clone()),this.copyPass=new ze(new E),this.passes=[]}return c(t,[{key:"replaceRenderer",value:function(e){var t=this.renderer,n=void 0,r=void 0,i=void 0;return null!==t&&t!==e&&(this.renderer=e,this.renderer.autoClear=!1,n=t.domElement.parentNode,r=t.getSize(),i=e.getSize(),null!==n&&(n.removeChild(t.domElement),n.appendChild(e.domElement)),r.width===i.width&&r.height===i.height||this.setSize()),t}},{key:"createBuffer",value:function(t,n,r){var i=this.renderer.getSize(),a=this.renderer.getPixelRatio(),o=this.renderer.context.getContextAttributes().alpha,s=new e.WebGLRenderTarget(i.width*a,i.height*a,{minFilter:e.LinearFilter,magFilter:e.LinearFilter,format:o?e.RGBAFormat:e.RGBFormat,depthBuffer:t,stencilBuffer:n,depthTexture:r?new e.DepthTexture:null});return r&&n&&(s.depthTexture.format=e.DepthStencilFormat,s.depthTexture.type=e.UnsignedInt248Type),s.texture.name="EffectComposer.Buffer",s.texture.generateMipmaps=!1,s}},{key:"addPass",value:function(e,t){var n=this.renderer,r=n.getSize(),i=n.getPixelRatio();e.setSize(r.width*i,r.height*i),e.initialise(n,n.context.getContextAttributes().alpha),void 0!==t?this.passes.splice(t,0,e):this.passes.push(e)}},{key:"removePass",value:function(e){this.passes.splice(this.passes.indexOf(e),1)}},{key:"render",value:function(e){var t=this.passes,n=this.renderer,r=this.copyPass,i=this.readBuffer,a=this.writeBuffer,o=!1,s=void 0,l=void 0,u=void 0,c=void 0,d=void 0;for(c=0,d=t.length;c0;)t.pop().dispose();void 0!==e?(this.readBuffer=e,this.writeBuffer=this.readBuffer.clone()):this.copyPass.dispose()}},{key:"depthTexture",get:function(){return this.readBuffer.depthTexture},set:function(e){this.readBuffer.depthTexture=e,this.writeBuffer.depthTexture=e}}]),t}(),He=function(){function t(n){u(this,t),this.composer=n,this.loadingManager=new e.LoadingManager,this.assets=null,this.scene=new e.Scene,this.scene.fog=new e.FogExp2(855309,.0025),this.camera=new e.PerspectiveCamera(50,window.innerWidth/window.innerHeight,.1,2e3),this.controls=null}return c(t,[{key:"load",value:function(e){e()}},{key:"initialise",value:function(){}},{key:"update",value:function(e){}},{key:"configure",value:function(e){}},{key:"reset",value:function(){var t=this.scene.fog;return this.scene=new e.Scene,this.scene.fog=t,null!==this.controls&&(this.controls.dispose(),this.controls=null),this}}]),t}(),Xe=2*Math.PI,Ve=function(t){function n(e){u(this,n);var t=v(this,(n.__proto__||Object.getPrototypeOf(n)).call(this,e));return t.bloomPass=null,t.object=null,t}return f(n,He),c(n,[{key:"load",value:function(t){var n=this,r=new Map,i=this.loadingManager,a=new e.CubeTextureLoader(i),o="textures/skies/space2/",s=[o+"px.jpg",o+"nx.jpg",o+"py.jpg",o+"ny.jpg",o+"pz.jpg",o+"nz.jpg"];null===this.assets?(i.onProgress=function(e,i,a){i===a&&(n.assets=r,t())},a.load(s,function(e){r.set("sky",e)})):t()}},{key:"initialise",value:function(){var t=this.scene,n=this.camera,r=this.assets,i=this.composer;this.controls=new e.OrbitControls(n,i.renderer.domElement),n.position.set(-10,6,15),n.lookAt(this.controls.target),t.background=r.get("sky");var a=new e.AmbientLight(6710886),o=new e.DirectionalLight(16759722);o.position.set(-1,1,1),o.target.position.copy(t.position),t.add(o),t.add(a);var s=new e.Object3D,l=new e.SphereBufferGeometry(1,4,4),u=void 0,c=void 0,d=void 0;for(c=0;c<100;++c)u=new e.MeshPhongMaterial({color:16777215*Math.random(),shading:e.FlatShading}),(d=new e.Mesh(l,u)).position.set(Math.random()-.5,Math.random()-.5,Math.random()-.5).normalize(),d.position.multiplyScalar(4*Math.random()),d.rotation.set(2*Math.random(),2*Math.random(),2*Math.random()),d.scale.multiplyScalar(.5*Math.random()),s.add(d);this.object=s,t.add(s),d=new e.Mesh(new e.BoxBufferGeometry(.25,8.25,.25),new e.MeshLambertMaterial({color:723723}));var f=void 0,v=void 0,h=void 0;f=(s=new e.Object3D).clone();var m=d.clone();m.position.set(-4,0,4),f.add(m),(m=d.clone()).position.set(4,0,4),f.add(m),(m=d.clone()).position.set(-4,0,-4),f.add(m),(m=d.clone()).position.set(4,0,-4),f.add(m),(v=f.clone()).rotation.set(Math.PI/2,0,0),(h=f.clone()).rotation.set(0,0,Math.PI/2),s.add(f),s.add(v),s.add(h),t.add(s),i.addPass(new Oe(t,n));var p=new xe({resolutionScale:.5,intensity:2,distinction:4});p.renderToScreen=!0,this.bloomPass=p,i.addPass(p)}},{key:"update",value:function(e){var t=this.object;null!==t&&(t.rotation.x+=.001,t.rotation.y+=.005,t.rotation.x>=Xe&&(t.rotation.x-=Xe),t.rotation.y>=Xe&&(t.rotation.y-=Xe))}},{key:"configure",value:function(e){var t=this.composer,n=this.bloomPass,r={resolution:n.resolutionScale,"kernel size":n.kernelSize,intensity:n.intensity,distinction:n.distinction,blend:!0,"blend mode":"screen"};e.add(r,"resolution").min(0).max(1).step(.01).onChange(function(){n.resolutionScale=r.resolution,t.setSize()}),e.add(r,"kernel size").min(C.VERY_SMALL).max(C.HUGE).step(1).onChange(function(){n.kernelSize=r["kernel size"]}),e.add(r,"intensity").min(0).max(3).step(.01).onChange(function(){n.intensity=r.intensity});var i=e.addFolder("Luminance");i.add(r,"distinction").min(1).max(10).step(.1).onChange(function(){n.distinction=r.distinction}),i.open(),e.add(r,"blend").onChange(function(){n.combineMaterial.uniforms.opacity1.value=r.blend?1:0}),e.add(r,"blend mode",["add","screen"]).onChange(function(){"add"===r["blend mode"]?delete n.combineMaterial.defines.SCREEN_MODE:n.combineMaterial.defines.SCREEN_MODE="1",n.combineMaterial.needsUpdate=!0})}}]),n}(),Ye=function(t){function n(e){u(this,n);var t=v(this,(n.__proto__||Object.getPrototypeOf(n)).call(this,e));return t.bokehPass=null,t}return f(n,He),c(n,[{key:"load",value:function(t){var n=this,r=new Map,i=this.loadingManager,a=new e.CubeTextureLoader(i),o="textures/skies/space3/",s=[o+"px.jpg",o+"nx.jpg",o+"py.jpg",o+"ny.jpg",o+"pz.jpg",o+"nz.jpg"];null===this.assets?(i.onProgress=function(e,i,a){i===a&&(n.assets=r,t())},a.load(s,function(e){r.set("sky",e)})):t()}},{key:"initialise",value:function(){var t=this.scene,n=this.camera,r=this.assets,i=this.composer;this.controls=new e.OrbitControls(n,i.renderer.domElement),this.controls.enablePan=!1,this.controls.minDistance=2.5,this.controls.maxDistance=40,n.near=.01,n.far=50,n.position.set(3,1,3),n.lookAt(this.controls.target),t.background=r.get("sky");var a=new e.AmbientLight(6710886),o=new e.DirectionalLight(16759722);o.position.set(-1,1,1),o.target.position.copy(t.position),t.add(o),t.add(a);var s=new e.SphereBufferGeometry(1,64,64),l=new e.MeshBasicMaterial({color:16776960,envMap:r.get("sky")}),u=new e.Mesh(s,l);t.add(u),i.addPass(new Oe(t,n));var c=new ye(n,{focus:.36,aperture:.007,maxBlur:.025});c.renderToScreen=!0,this.bokehPass=c,i.addPass(c)}},{key:"configure",value:function(e){var t=this.bokehPass,n={focus:t.bokehMaterial.uniforms.focus.value,aperture:t.bokehMaterial.uniforms.aperture.value,blur:t.bokehMaterial.uniforms.maxBlur.value};e.add(n,"focus").min(0).max(1).step(.001).onChange(function(){t.bokehMaterial.uniforms.focus.value=n.focus}),e.add(n,"aperture").min(0).max(.05).step(1e-4).onChange(function(){t.bokehMaterial.uniforms.aperture.value=n.aperture}),e.add(n,"blur").min(0).max(.1).step(.001).onChange(function(){t.bokehMaterial.uniforms.maxBlur.value=n.blur})}}]),n}(),qe=function(t){function n(e){u(this,n);var t=v(this,(n.__proto__||Object.getPrototypeOf(n)).call(this,e));return t.bokehPass=null,t}return f(n,He),c(n,[{key:"load",value:function(t){var n=this,r=new Map,i=this.loadingManager,a=new e.CubeTextureLoader(i),o="textures/skies/space3/",s=[o+"px.jpg",o+"nx.jpg",o+"py.jpg",o+"ny.jpg",o+"pz.jpg",o+"nz.jpg"];null===this.assets?(i.onProgress=function(e,i,a){i===a&&(n.assets=r,t())},a.load(s,function(e){r.set("sky",e)})):t()}},{key:"initialise",value:function(){var t=this.scene,n=this.camera,r=this.assets,i=this.composer;this.controls=new e.OrbitControls(n,i.renderer.domElement),this.controls.enablePan=!1,this.controls.minDistance=2.5,this.controls.maxDistance=40,n.near=.01,n.far=50,n.position.set(3,1,3),n.lookAt(this.controls.target),t.background=r.get("sky");var a=new e.AmbientLight(6710886),o=new e.DirectionalLight(16759722);o.position.set(-1,1,1),o.target.position.copy(t.position),t.add(o),t.add(a);var s=new e.SphereBufferGeometry(1,64,64),l=new e.MeshBasicMaterial({color:16776960,envMap:r.get("sky")}),u=new e.Mesh(s,l);t.add(u),i.addPass(new Oe(t,n));var c=new Me(n,{rings:3,samples:2,showFocus:!1,manualDoF:!1,vignette:!1,pentagon:!1,shaderFocus:!0,noise:!0});c.bokehMaterial.uniforms.focalStop.value=64,c.renderToScreen=!0,this.bokehPass=c,i.addPass(c)}},{key:"configure",value:function(e){var t=this.bokehPass,n={rings:Number.parseInt(t.bokehMaterial.defines.RINGS_INT),samples:Number.parseInt(t.bokehMaterial.defines.SAMPLES_INT),"focal stop":t.bokehMaterial.uniforms.focalStop.value,"focal length":t.bokehMaterial.uniforms.focalLength.value,"shader focus":void 0!==t.bokehMaterial.defines.SHADER_FOCUS,"focal depth":t.bokehMaterial.uniforms.focalDepth.value,"focus coord X":t.bokehMaterial.uniforms.focusCoords.value.x,"focus coord Y":t.bokehMaterial.uniforms.focusCoords.value.y,"max blur":t.bokehMaterial.uniforms.maxBlur.value,"lum threshold":t.bokehMaterial.uniforms.luminanceThreshold.value,"lum gain":t.bokehMaterial.uniforms.luminanceGain.value,bias:t.bokehMaterial.uniforms.bias.value,fringe:t.bokehMaterial.uniforms.fringe.value,dithering:t.bokehMaterial.uniforms.ditherStrength.value,vignette:void 0!==t.bokehMaterial.defines.VIGNETTE,pentagon:void 0!==t.bokehMaterial.defines.PENTAGON,"manual DoF":void 0!==t.bokehMaterial.defines.MANUAL_DOF,"show focus":void 0!==t.bokehMaterial.defines.SHOW_FOCUS,noise:void 0!==t.bokehMaterial.defines.NOISE},r=e.addFolder("Focus");r.add(n,"show focus").onChange(function(){n["show focus"]?t.bokehMaterial.defines.SHOW_FOCUS="1":delete t.bokehMaterial.defines.SHOW_FOCUS,t.bokehMaterial.needsUpdate=!0}),r.add(n,"shader focus").onChange(function(){n["shader focus"]?t.bokehMaterial.defines.SHADER_FOCUS="1":delete t.bokehMaterial.defines.SHADER_FOCUS,t.bokehMaterial.needsUpdate=!0}),r.add(n,"manual DoF").onChange(function(){n["manual DoF"]?t.bokehMaterial.defines.MANUAL_DOF="1":delete t.bokehMaterial.defines.MANUAL_DOF,t.bokehMaterial.needsUpdate=!0}),r.add(n,"focal stop").min(0).max(100).step(.1).onChange(function(){t.bokehMaterial.uniforms.focalStop.value=n["focal stop"]}),r.add(n,"focal depth").min(.1).max(35).step(.1).onChange(function(){t.bokehMaterial.uniforms.focalDepth.value=n["focal depth"]}),r.add(n,"focus coord X").min(0).max(1).step(.01).onChange(function(){t.bokehMaterial.uniforms.focusCoords.value.x=n["focus coord X"]}),r.add(n,"focus coord Y").min(0).max(1).step(.01).onChange(function(){t.bokehMaterial.uniforms.focusCoords.value.y=n["focus coord Y"]}),r.open(),(r=e.addFolder("Sampling")).add(n,"rings").min(1).max(6).step(1).onChange(function(){t.bokehMaterial.defines.RINGS_INT=n.rings.toFixed(0),t.bokehMaterial.defines.RINGS_FLOAT=n.rings.toFixed(1),t.bokehMaterial.needsUpdate=!0}),r.add(n,"samples").min(1).max(6).step(1).onChange(function(){t.bokehMaterial.defines.SAMPLES_INT=n.samples.toFixed(0),t.bokehMaterial.defines.SAMPLES_FLOAT=n.samples.toFixed(1),t.bokehMaterial.needsUpdate=!0}),(r=e.addFolder("Blur")).add(n,"max blur").min(0).max(1).step(.001).onChange(function(){t.bokehMaterial.uniforms.maxBlur.value=n["max blur"]}),r.add(n,"bias").min(0).max(3).step(.01).onChange(function(){t.bokehMaterial.uniforms.bias.value=n.bias}),r.add(n,"fringe").min(0).max(2).step(.05).onChange(function(){t.bokehMaterial.uniforms.fringe.value=n.fringe}),r.add(n,"noise").onChange(function(){n.noise?t.bokehMaterial.defines.NOISE="1":delete t.bokehMaterial.defines.NOISE,t.bokehMaterial.needsUpdate=!0}),r.add(n,"dithering").min(0).max(.01).step(1e-4).onChange(function(){t.bokehMaterial.uniforms.ditherStrength.value=n.dithering}),r.add(n,"pentagon").onChange(function(){n.pentagon?t.bokehMaterial.defines.PENTAGON="1":delete t.bokehMaterial.defines.PENTAGON,t.bokehMaterial.needsUpdate=!0}),r.open(),(r=e.addFolder("Luminosity")).add(n,"lum threshold").min(0).max(1).step(.01).onChange(function(){t.bokehMaterial.uniforms.luminanceThreshold.value=n["lum threshold"]}),r.add(n,"lum gain").min(0).max(4).step(.01).onChange(function(){t.bokehMaterial.uniforms.luminanceGain.value=n["lum gain"]}),e.add(n,"vignette").onChange(function(){n.vignette?t.bokehMaterial.defines.VIGNETTE="1":delete t.bokehMaterial.defines.VIGNETTE,t.bokehMaterial.needsUpdate=!0})}}]),n}(),Ke=2*Math.PI,Ze=function(t){function n(e){u(this,n);var t=v(this,(n.__proto__||Object.getPrototypeOf(n)).call(this,e));return t.renderPass=null,t.savePass=null,t.blurPass=null,t.combinePass=null,t.object=null,t}return f(n,He),c(n,[{key:"load",value:function(t){var n=this,r=new Map,i=this.loadingManager,a=new e.CubeTextureLoader(i),o="textures/skies/sunset/",s=[o+"px.png",o+"nx.png",o+"py.png",o+"ny.png",o+"pz.png",o+"nz.png"];null===this.assets?(i.onProgress=function(e,i,a){i===a&&(n.assets=r,t())},a.load(s,function(e){r.set("sky",e)})):t()}},{key:"initialise",value:function(){var t=this.scene,n=this.camera,r=this.assets,i=this.composer;this.controls=new e.OrbitControls(n,i.renderer.domElement),n.position.set(-15,0,-15),n.lookAt(this.controls.target),t.background=r.get("sky");var a=new e.AmbientLight(6710886),o=new e.DirectionalLight(16759722);o.position.set(1440,200,2e3),o.target.position.copy(t.position),t.add(o),t.add(a);var s=new e.Object3D,l=new e.SphereBufferGeometry(1,4,4),u=void 0,c=void 0,d=void 0;for(c=0;c<100;++c)u=new e.MeshPhongMaterial({color:16777215*Math.random(),shading:e.FlatShading}),(d=new e.Mesh(l,u)).position.set(Math.random()-.5,Math.random()-.5,Math.random()-.5).normalize(),d.position.multiplyScalar(10*Math.random()),d.rotation.set(2*Math.random(),2*Math.random(),2*Math.random()),d.scale.multiplyScalar(Math.random()),s.add(d);this.object=s,t.add(s);var f=new Oe(t,n);this.renderPass=f,i.addPass(f),f=new Ue,this.savePass=f,i.addPass(f),f=new ge,this.blurPass=f,i.addPass(f),(f=new ze(new S,"texture1")).material.uniforms.texture2.value=this.savePass.renderTarget.texture,f.material.uniforms.opacity1.value=1,f.material.uniforms.opacity2.value=0,f.renderToScreen=!0,this.combinePass=f,i.addPass(f)}},{key:"update",value:function(e){var t=this.object;null!==t&&(t.rotation.x+=.001,t.rotation.y+=.005,t.rotation.x>=Ke&&(t.rotation.x-=Ke),t.rotation.y>=Ke&&(t.rotation.y-=Ke))}},{key:"configure",value:function(e){var t=this.composer,n=this.renderPass,r=this.blurPass,i=this.combinePass,a={enabled:r.enabled,resolution:r.resolutionScale,"kernel size":r.kernelSize,strength:i.material.uniforms.opacity1.value};e.add(a,"resolution").min(0).max(1).step(.01).onChange(function(){r.resolutionScale=a.resolution,t.setSize()}),e.add(a,"kernel size").min(C.VERY_SMALL).max(C.HUGE).step(1).onChange(function(){r.kernelSize=a["kernel size"]}),e.add(a,"strength").min(0).max(1).step(.01).onChange(function(){i.material.uniforms.opacity1.value=a.strength,i.material.uniforms.opacity2.value=1-a.strength}),e.add(a,"enabled").onChange(function(){n.renderToScreen=!a.enabled,r.enabled=a.enabled,i.enabled=a.enabled})}}]),n}(),Je=2*Math.PI,Qe=function(t){function n(e){u(this,n);var t=v(this,(n.__proto__||Object.getPrototypeOf(n)).call(this,e));return t.object=null,t.texturePass=null,t.depthPass=null,t}return f(n,He),c(n,[{key:"initialise",value:function(){var t=this.scene,n=this.camera,r=this.composer;this.controls=new e.OrbitControls(n,r.renderer.domElement),this.controls.enablePan=!1,this.controls.maxDistance=40,n.near=.01,n.far=50,n.position.set(2,1,2),n.lookAt(this.controls.target);var i=new e.Mesh(new e.BoxBufferGeometry(1,1,1),new e.MeshBasicMaterial);this.object=i,t.add(i),r.addPass(new Oe(t,n));var a=new Ie(r.depthTexture);a.enabled=!1,this.texturePass=a,r.addPass(a),(a=new Pe(n)).renderToScreen=!0,this.depthPass=a,r.addPass(a)}},{key:"update",value:function(e){var t=this.object;null!==t&&(t.rotation.x+=.001,t.rotation.y+=.005,t.rotation.x>=Je&&(t.rotation.x-=Je),t.rotation.y>=Je&&(t.rotation.y-=Je))}},{key:"configure",value:function(e){var t=this.texturePass,n=this.depthPass,r={raw:!1};e.add(r,"raw").onChange(function(){t.enabled=r.raw,n.enabled=!r.raw,t.renderToScreen=r.raw,n.renderToScreen=!r.raw})}}]),n}(),_e=2*Math.PI,$e=function(t){function n(e){u(this,n);var t=v(this,(n.__proto__||Object.getPrototypeOf(n)).call(this,e));return t.dotScreenPass=null,t.object=null,t}return f(n,He),c(n,[{key:"load",value:function(t){var n=this,r=new Map,i=this.loadingManager,a=new e.CubeTextureLoader(i),o="textures/skies/space3/",s=[o+"px.jpg",o+"nx.jpg",o+"py.jpg",o+"ny.jpg",o+"pz.jpg",o+"nz.jpg"];null===this.assets?(i.onProgress=function(e,i,a){i===a&&(n.assets=r,t())},a.load(s,function(e){r.set("sky",e)})):t()}},{key:"initialise",value:function(){var t=this.scene,n=this.camera,r=this.assets,i=this.composer;this.controls=new e.OrbitControls(n,i.renderer.domElement),n.position.set(10,1,10),n.lookAt(this.controls.target),t.background=r.get("sky");var a=new e.AmbientLight(6710886),o=new e.DirectionalLight(16759722);o.position.set(-1,1,1),o.target.position.copy(t.position),t.add(o),t.add(a);var s=new e.Object3D,l=new e.SphereBufferGeometry(1,4,4),u=void 0,c=void 0,d=void 0;for(d=0;d<100;++d)u=new e.MeshPhongMaterial({color:16777215*Math.random(),shading:e.FlatShading}),(c=new e.Mesh(l,u)).position.set(Math.random()-.5,Math.random()-.5,Math.random()-.5).normalize(),c.position.multiplyScalar(10*Math.random()),c.rotation.set(2*Math.random(),2*Math.random(),2*Math.random()),c.scale.multiplyScalar(Math.random()),s.add(c);this.object=s,t.add(s),i.addPass(new Oe(t,n));var f=new De({scale:.8,angle:.5*Math.PI,intensity:.25});f.renderToScreen=!0,this.dotScreenPass=f,i.addPass(f)}},{key:"update",value:function(e){var t=this.object;null!==t&&(t.rotation.x+=5e-4,t.rotation.y+=.001,t.rotation.x>=_e&&(t.rotation.x-=_e),t.rotation.y>=_e&&(t.rotation.y-=_e))}},{key:"configure",value:function(e){var t=this.dotScreenPass,n={average:void 0!==t.material.defines.AVERAGE,scale:t.material.uniforms.scale.value,angle:t.material.uniforms.angle.value,intensity:t.material.uniforms.intensity.value,"center X":t.material.uniforms.offsetRepeat.value.x,"center Y":t.material.uniforms.offsetRepeat.value.y};e.add(n,"average").onChange(function(){n.average?t.material.defines.AVERAGE="1":delete t.material.defines.AVERAGE,t.material.needsUpdate=!0}),e.add(n,"scale").min(0).max(1).step(.01).onChange(function(){t.material.uniforms.scale.value=n.scale}),e.add(n,"angle").min(0).max(Math.PI).step(.001).onChange(function(){t.material.uniforms.angle.value=n.angle}),e.add(n,"intensity").min(0).max(1).step(.01).onChange(function(){t.material.uniforms.intensity.value=n.intensity});var r=e.addFolder("Center");r.add(n,"center X").min(-1).max(1).step(.01).onChange(function(){t.material.uniforms.offsetRepeat.value.x=n["center X"]}),r.add(n,"center Y").min(-1).max(1).step(.01).onChange(function(){t.material.uniforms.offsetRepeat.value.y=n["center Y"]})}}]),n}(),et=2*Math.PI,tt=function(t){function n(e){u(this,n);var t=v(this,(n.__proto__||Object.getPrototypeOf(n)).call(this,e));return t.filmPass=null,t.object=null,t}return f(n,He),c(n,[{key:"load",value:function(t){var n=this,r=new Map,i=this.loadingManager,a=new e.CubeTextureLoader(i),o="textures/skies/space/",s=[o+"px.jpg",o+"nx.jpg",o+"py.jpg",o+"ny.jpg",o+"pz.jpg",o+"nz.jpg"];null===this.assets?(i.onProgress=function(e,i,a){i===a&&(n.assets=r,t())},a.load(s,function(e){r.set("sky",e)})):t()}},{key:"initialise",value:function(){var t=this.scene,n=this.camera,r=this.assets,i=this.composer;this.controls=new e.OrbitControls(n,i.renderer.domElement),n.position.set(10,1,10),n.lookAt(this.controls.target),t.background=r.get("sky");var a=new e.AmbientLight(6710886),o=new e.DirectionalLight(16759722);o.position.set(-1,1,1),o.target.position.copy(t.position),t.add(o),t.add(a);var s=new e.Object3D,l=new e.SphereBufferGeometry(1,4,4),u=void 0,c=void 0,d=void 0;for(d=0;d<100;++d)u=new e.MeshPhongMaterial({color:16777215*Math.random(),shading:e.FlatShading}),(c=new e.Mesh(l,u)).position.set(Math.random()-.5,Math.random()-.5,Math.random()-.5).normalize(),c.position.multiplyScalar(10*Math.random()),c.rotation.set(2*Math.random(),2*Math.random(),2*Math.random()),c.scale.multiplyScalar(Math.random()),s.add(c);this.object=s,t.add(s),i.addPass(new Oe(t,n));var f=new Te({grayscale:!1,sepia:!1,vignette:!1,eskil:!1,scanlines:!0,noise:!0,noiseIntensity:.5,scanlineIntensity:.5,scanlineDensity:1.5,greyscaleIntensity:1,sepiaIntensity:1,vignetteOffset:0,vignetteDarkness:.5});f.renderToScreen=!0,this.filmPass=f,i.addPass(f)}},{key:"update",value:function(e){var t=this.object;null!==t&&(t.rotation.x+=.001,t.rotation.y+=.005,t.rotation.x>=et&&(t.rotation.x-=et),t.rotation.y>=et&&(t.rotation.y-=et))}},{key:"configure",value:function(e){var t=this.composer,n=this.filmPass,r={grayscale:void 0!==n.material.defines.GREYSCALE,sepia:void 0!==n.material.defines.SEPIA,vignette:void 0!==n.material.defines.VIGNETTE,eskil:void 0!==n.material.defines.ESKIL,noise:void 0!==n.material.defines.NOISE,scanlines:void 0!==n.material.defines.SCANLINES,"noise intensity":n.material.uniforms.noiseIntensity.value,"scanlines intensity":n.material.uniforms.scanlineIntensity.value,"scanlines count":n.scanlineDensity,"blend mode":"screen","greyscale intensity":n.material.uniforms.greyscaleIntensity.value,"sepia intensity":n.material.uniforms.sepiaIntensity.value,"vignette offset":n.material.uniforms.vignetteOffset.value,"vignette darkness":n.material.uniforms.vignetteDarkness.value},i=e.addFolder("Greyscale");i.add(r,"grayscale").onChange(function(){r.grayscale?n.material.defines.GREYSCALE="1":delete n.material.defines.GREYSCALE,n.material.needsUpdate=!0}),i.add(r,"greyscale intensity").min(0).max(1).step(.01).onChange(function(){n.material.uniforms.greyscaleIntensity.value=r["greyscale intensity"]}),i.open(),(i=e.addFolder("Noise and scanlines")).add(r,"blend mode",["add","screen"]).onChange(function(){"add"===r["blend mode"]?delete n.material.defines.SCREEN_MODE:n.material.defines.SCREEN_MODE="1",n.material.needsUpdate=!0}),i.add(r,"noise").onChange(function(){r.noise?n.material.defines.NOISE="1":delete n.material.defines.NOISE,n.material.needsUpdate=!0}),i.add(r,"noise intensity").min(0).max(1).step(.01).onChange(function(){n.material.uniforms.noiseIntensity.value=r["noise intensity"]}),i.add(r,"scanlines").onChange(function(){r.scanlines?n.material.defines.SCANLINES="1":delete n.material.defines.SCANLINES,n.material.needsUpdate=!0}),i.add(r,"scanlines intensity").min(0).max(1).step(.01).onChange(function(){n.material.uniforms.scanlineIntensity.value=r["scanlines intensity"]}),i.add(r,"scanlines count").min(0).max(2).step(.01).onChange(function(){n.scanlineDensity=r["scanlines count"],t.setSize()}),i.open(),(i=e.addFolder("Sepia")).add(r,"sepia").onChange(function(){r.sepia?n.material.defines.SEPIA="1":delete n.material.defines.SEPIA,n.material.needsUpdate=!0}),i.add(r,"sepia intensity").min(0).max(1).step(.01).onChange(function(){n.material.uniforms.sepiaIntensity.value=r["sepia intensity"]}),i.open(),(i=e.addFolder("Vignette")).add(r,"vignette").onChange(function(){r.vignette?n.material.defines.VIGNETTE="1":delete n.material.defines.VIGNETTE,n.material.needsUpdate=!0}),i.add(r,"eskil").onChange(function(){r.eskil?n.material.defines.ESKIL="1":delete n.material.defines.ESKIL,n.material.needsUpdate=!0}),i.add(r,"vignette offset").min(0).max(1).step(.01).onChange(function(){n.material.uniforms.vignetteOffset.value=r["vignette offset"]}),i.add(r,"vignette darkness").min(0).max(1).step(.01).onChange(function(){n.material.uniforms.vignetteDarkness.value=r["vignette darkness"]}),i.open()}}]),n}(),nt=2*Math.PI,rt=function(t){function n(e){u(this,n);var t=v(this,(n.__proto__||Object.getPrototypeOf(n)).call(this,e));return t.glitchPass=null,t.object=null,t}return f(n,He),c(n,[{key:"load",value:function(t){var n=this,r=new Map,i=this.loadingManager,a=new e.TextureLoader(i),o=new e.CubeTextureLoader(i),s="textures/skies/space4/",l=[s+"px.jpg",s+"nx.jpg",s+"py.jpg",s+"ny.jpg",s+"pz.jpg",s+"nz.jpg"];null===this.assets?(i.onProgress=function(e,i,a){i===a&&(n.assets=r,t())},o.load(l,function(e){r.set("sky",e)}),a.load("textures/perturb.jpg",function(t){t.magFilter=t.minFilter=e.NearestFilter,r.set("perturb-map",t)})):t()}},{key:"initialise",value:function(){var t=this.scene,n=this.camera,r=this.assets,i=this.composer;this.controls=new e.OrbitControls(n,i.renderer.domElement),n.position.set(6,1,6),n.lookAt(this.controls.target),t.background=r.get("sky");var a=new e.AmbientLight(6710886),o=new e.DirectionalLight(16759722);o.position.set(-1,1,1),o.target.position.copy(t.position),t.add(o),t.add(a);var s=new e.Object3D,l=new e.SphereBufferGeometry(1,4,4),u=void 0,c=void 0,d=void 0;for(d=0;d<100;++d)u=new e.MeshPhongMaterial({color:16777215*Math.random(),shading:e.FlatShading}),(c=new e.Mesh(l,u)).position.set(Math.random()-.5,Math.random()-.5,Math.random()-.5).normalize(),c.position.multiplyScalar(10*Math.random()),c.rotation.set(2*Math.random(),2*Math.random(),2*Math.random()),c.scale.multiplyScalar(Math.random()),s.add(c);this.object=s,t.add(s),i.addPass(new Oe(t,n));var f=new Ae({perturbMap:r.get("perturb-map")});f.renderToScreen=!0,this.glitchPass=f,i.addPass(f)}},{key:"update",value:function(e){var t=this.object;null!==t&&(t.rotation.x+=.005,t.rotation.y+=.01,t.rotation.x>=nt&&(t.rotation.x-=nt),t.rotation.y>=nt&&(t.rotation.y-=nt))}},{key:"configure",value:function(e){var t=this.glitchPass,n=t.perturbMap,r={mode:t.mode,"custom noise":!0};e.add(r,"mode").min(Ce.SPORADIC).max(Ce.CONSTANT_WILD).step(1).onChange(function(){t.mode=r.mode}),e.add(r,"custom noise").onChange(function(){r["custom noise"]?t.perturbMap=n:(t.perturbMap=null,t.generatePerturbMap(64))})}}]),n}(),it=2*Math.PI,at=function(t){function n(e){u(this,n);var t=v(this,(n.__proto__||Object.getPrototypeOf(n)).call(this,e));return t.object=null,t.maskObject=null,t.maskPass=null,t.pixelationPass=null,t}return f(n,He),c(n,[{key:"load",value:function(t){var n=this,r=new Map,i=this.loadingManager,a=new e.CubeTextureLoader(i),o="textures/skies/space/",s=[o+"px.jpg",o+"nx.jpg",o+"py.jpg",o+"ny.jpg",o+"pz.jpg",o+"nz.jpg"];null===this.assets?(i.onProgress=function(e,i,a){i===a&&(n.assets=r,t())},a.load(s,function(e){r.set("sky",e)})):t()}},{key:"initialise",value:function(){var t=this.scene,n=this.camera,r=this.assets,i=this.composer;this.controls=new e.OrbitControls(n,i.renderer.domElement),n.position.set(10,1,10),n.lookAt(this.controls.target),t.background=r.get("sky");var a=new e.AmbientLight(6710886),o=new e.DirectionalLight(16759722);o.position.set(-1,1,1),o.target.position.copy(t.position),t.add(o),t.add(a);var s=new e.Object3D,l=new e.SphereBufferGeometry(1,4,4),u=void 0,c=void 0,d=void 0;for(d=0;d<100;++d)u=new e.MeshPhongMaterial({color:16777215*Math.random(),shading:e.FlatShading}),(c=new e.Mesh(l,u)).position.set(Math.random()-.5,Math.random()-.5,Math.random()-.5).normalize(),c.position.multiplyScalar(10*Math.random()),c.rotation.set(2*Math.random(),2*Math.random(),2*Math.random()),c.scale.multiplyScalar(Math.random()),s.add(c);this.object=s,t.add(s);var f=new e.Scene;c=new e.Mesh(new e.BoxBufferGeometry(4,4,4)),this.maskObject=c,f.add(c);var v=new Oe(t,n);i.addPass(v),v=new Ee(f,n),this.maskPass=v,i.addPass(v),v=new ke(5),this.pixelationPass=v,i.addPass(v),i.addPass(new we),(v=new ze(new E)).renderToScreen=!0,i.addPass(v)}},{key:"update",value:function(e){var t=this.object,n=this.maskObject,r=void 0;null!==t&&null!==n&&(t.rotation.x+=.001,t.rotation.y+=.005,t.rotation.x>=it&&(t.rotation.x-=it),t.rotation.y>=it&&(t.rotation.y-=it),r=.001*performance.now(),n.position.x=4*Math.cos(r/1.5),n.position.y=4*Math.sin(r),n.rotation.x=r,n.rotation.y=.5*r)}},{key:"configure",value:function(e){var t=this.maskPass,n={"use mask":t.enabled};e.add(this.pixelationPass,"granularity").min(0).max(50).step(.1),e.add(n,"use mask").onChange(function(){t.enabled=n["use mask"]})}}]),n}(),ot=function(t){function n(e){u(this,n);var t=v(this,(n.__proto__||Object.getPrototypeOf(n)).call(this,e));return t.godRaysPass=null,t.sun=null,t.directionalLight=null,t}return f(n,He),c(n,[{key:"load",value:function(t){var n=this,r=new Map,i=this.loadingManager,a=new e.CubeTextureLoader(i),o=new e.TextureLoader(i),s=new e.ObjectLoader(i),l="textures/skies/starry/",u=[l+"px.png",l+"nx.png",l+"py.png",l+"ny.png",l+"pz.png",l+"nz.png"];null===this.assets?(i.onProgress=function(e,i,a){i===a&&(n.assets=r,t())},a.load(u,function(e){r.set("sky",e)}),s.load("models/waggon.json",function(e){e.rotation.x=.25*Math.PI,e.rotation.y=.75*Math.PI,r.set("waggon",e)}),o.load("textures/wood.jpg",function(t){t.wrapS=t.wrapT=e.RepeatWrapping,r.set("wood-diffuse",t)}),o.load("textures/woodnormals.jpg",function(t){t.wrapS=t.wrapT=e.RepeatWrapping,r.set("wood-normals",t)}),o.load("textures/sun.png",function(e){r.set("sun-diffuse",e)})):t()}},{key:"initialise",value:function(){var t=this.scene,n=this.camera,r=this.assets,i=this.composer;this.controls=new e.OrbitControls(n,i.renderer.domElement),this.controls.target.set(0,.5,0),n.position.set(-5,-1,-4),n.lookAt(this.controls.target),t.background=r.get("sky");var a=new e.AmbientLight(986895),o=new e.DirectionalLight(16759722);o.position.set(-1,1,1),o.target.position.copy(t.position),this.directionalLight=o,t.add(o),t.add(a);var s=r.get("waggon"),l=new e.MeshPhongMaterial({color:16777215,map:r.get("wood-diffuse"),normalMap:r.get("wood-normals"),fog:!0});s.traverse(function(e){e.material=l}),t.add(s);var u=new e.PointsMaterial({map:r.get("sun-diffuse"),size:100,sizeAttenuation:!0,color:16768426,alphaTest:0,transparent:!0,fog:!1}),c=new e.BufferGeometry;c.addAttribute("position",new e.BufferAttribute(new Float32Array(3),3));var d=new e.Points(c,u);d.frustumCulled=!1,d.position.set(75,25,100),this.sun=d,t.add(d),i.addPass(new Oe(t,n));var f=new Le(t,n,d,{resolutionScale:.6,kernelSize:C.SMALL,intensity:1,density:.96,decay:.93,weight:.4,exposure:.6,samples:60,clampMax:1});f.renderToScreen=!0,this.godRaysPass=f,i.addPass(f)}},{key:"configure",value:function(e){var t=this.directionalLight,n=this.composer,r=this.godRaysPass,i=this.sun,a={resolution:r.resolutionScale,blurriness:r.kernelSize,intensity:r.intensity,density:r.godRaysMaterial.uniforms.density.value,decay:r.godRaysMaterial.uniforms.decay.value,weight:r.godRaysMaterial.uniforms.weight.value,exposure:r.godRaysMaterial.uniforms.exposure.value,clampMax:r.godRaysMaterial.uniforms.clampMax.value,samples:r.samples,color:i.material.color.getHex(),"blend mode":"screen"};e.add(a,"resolution").min(0).max(1).step(.01).onChange(function(){r.resolutionScale=a.resolution,n.setSize()}),e.add(a,"blurriness").min(C.VERY_SMALL).max(C.HUGE).step(1).onChange(function(){r.kernelSize=a.blurriness}),e.add(a,"intensity").min(0).max(1).step(.01).onChange(function(){r.intensity=a.intensity}),e.add(a,"density").min(0).max(1).step(.01).onChange(function(){r.godRaysMaterial.uniforms.density.value=a.density}),e.add(a,"decay").min(0).max(1).step(.01).onChange(function(){r.godRaysMaterial.uniforms.decay.value=a.decay}),e.add(a,"weight").min(0).max(1).step(.01).onChange(function(){r.godRaysMaterial.uniforms.weight.value=a.weight}),e.add(a,"exposure").min(0).max(1).step(.01).onChange(function(){r.godRaysMaterial.uniforms.exposure.value=a.exposure}),e.add(a,"clampMax").min(0).max(1).step(.01).onChange(function(){r.godRaysMaterial.uniforms.clampMax.value=a.clampMax}),e.add(a,"samples").min(15).max(200).step(1).onChange(function(){r.samples=a.samples}),e.addColor(a,"color").onChange(function(){i.material.color.setHex(a.color),t.color.setHex(a.color)}),e.add(a,"blend mode",["add","screen"]).onChange(function(){"add"===a["blend mode"]?delete r.combineMaterial.defines.SCREEN_MODE:r.combineMaterial.defines.SCREEN_MODE="1",r.combineMaterial.needsUpdate=!0})}}]),n}(),st=2*Math.PI,lt=function(t){function n(e){u(this,n);var t=v(this,(n.__proto__||Object.getPrototypeOf(n)).call(this,e));return t.object=null,t}return f(n,He),c(n,[{key:"load",value:function(t){var n=this,r=new Map,i=this.loadingManager,a=new e.TextureLoader(i),o=new e.CubeTextureLoader(i),s="textures/skies/sunset/",l=[s+"px.png",s+"nx.png",s+"py.png",s+"ny.png",s+"pz.png",s+"nz.png"];null===this.assets?(i.onProgress=function(e,i,a){i===a&&(n.assets=r,t())},o.load(l,function(e){r.set("sky",e)}),a.load("textures/crate.jpg",function(t){t.wrapS=t.wrapT=e.RepeatWrapping,r.set("crate-color",t)})):t()}},{key:"initialise",value:function(){var t=this.scene,n=this.camera,r=this.assets,i=this.composer;this.controls=new e.OrbitControls(n,i.renderer.domElement),n.position.set(-3,0,-3),n.lookAt(this.controls.target),t.background=r.get("sky");var a=new e.AmbientLight(6710886),o=new e.DirectionalLight(16759722);o.position.set(1440,200,2e3),o.target.position.copy(t.position),t.add(o),t.add(a);var s=new e.Mesh(new e.BoxBufferGeometry(1,1,1),new e.MeshPhongMaterial({color:16777215,map:r.get("crate-color")}));this.object=s,t.add(s);var l=new Oe(t,n);l.renderToScreen=!0,i.addPass(l)}},{key:"update",value:function(e){var t=this.object;null!==t&&(t.rotation.x+=5e-4,t.rotation.y+=.001,t.rotation.x>=st&&(t.rotation.x-=st),t.rotation.y>=st&&(t.rotation.y-=st))}}]),n}(),ut=function(t){function n(e){u(this,n);var t=v(this,(n.__proto__||Object.getPrototypeOf(n)).call(this,e));return t.shockWavePass=null,t}return f(n,He),c(n,[{key:"load",value:function(t){var n=this,r=new Map,i=this.loadingManager,a=new e.CubeTextureLoader(i),o="textures/skies/space3/",s=[o+"px.jpg",o+"nx.jpg",o+"py.jpg",o+"ny.jpg",o+"pz.jpg",o+"nz.jpg"];null===this.assets?(i.onProgress=function(e,i,a){i===a&&(n.assets=r,t())},a.load(s,function(e){r.set("sky",e)})):t()}},{key:"initialise",value:function(){var t=this.scene,n=this.camera,r=this.assets,i=this.composer;this.controls=new e.OrbitControls(n,i.renderer.domElement),n.position.set(5,1,5),n.lookAt(this.controls.target),t.background=r.get("sky");var a=new e.AmbientLight(6710886),o=new e.DirectionalLight(16759722);o.position.set(-1,1,1),o.target.position.copy(t.position),t.add(o),t.add(a);var s=new e.SphereBufferGeometry(1,64,64),l=new e.MeshBasicMaterial({color:16776960,envMap:r.get("sky")}),u=new e.Mesh(s,l);t.add(u),i.addPass(new Oe(t,n));var c=new Be(n,u.position,{speed:2,maxRadius:.5,waveSize:.2,amplitude:.05});c.renderToScreen=!0,this.shockWavePass=c,i.addPass(c)}},{key:"configure",value:function(e){var t=this.shockWavePass,n={speed:t.speed,size:t.shockWaveMaterial.uniforms.size.value,extent:t.shockWaveMaterial.uniforms.maxRadius.value,waveSize:t.shockWaveMaterial.uniforms.waveSize.value,amplitude:t.shockWaveMaterial.uniforms.amplitude.value,explode:function(){t.explode()}};e.add(n,"speed").min(0).max(10).step(.001).onChange(function(){t.speed=n.speed}),e.add(n,"size").min(.01).max(2).step(.001).onChange(function(){t.shockWaveMaterial.uniforms.size.value=n.size}),e.add(n,"extent").min(0).max(10).step(.001).onChange(function(){t.shockWaveMaterial.uniforms.maxRadius.value=n.extent}),e.add(n,"waveSize").min(0).max(2).step(.001).onChange(function(){t.shockWaveMaterial.uniforms.waveSize.value=n.waveSize}),e.add(n,"amplitude").min(0).max(.25).step(.001).onChange(function(){t.shockWaveMaterial.uniforms.amplitude.value=n.amplitude}),e.add(n,"explode")}}]),n}(),ct=2*Math.PI,dt=function(t){function n(e){u(this,n);var t=v(this,(n.__proto__||Object.getPrototypeOf(n)).call(this,e));return t.renderer=null,t.renderer2=null,t.controls2=null,t.renderPass=null,t.smaaPass=null,t.objectA=null,t.objectB=null,t.objectC=null,t}return f(n,He),c(n,[{key:"load",value:function(t){var n=this,r=new Map,i=this.loadingManager,a=new e.TextureLoader(i),o=new e.CubeTextureLoader(i),s="textures/skies/sunset/",l=[s+"px.png",s+"nx.png",s+"py.png",s+"ny.png",s+"pz.png",s+"nz.png"];null===this.assets?(i.onProgress=function(e,i,a){i===a&&(n.assets=r,t())},o.load(l,function(e){r.set("sky",e)}),a.load("textures/crate.jpg",function(t){t.wrapS=t.wrapT=e.RepeatWrapping,r.set("crate-color",t)})):t()}},{key:"initialise",value:function(){var t=this.scene,n=this.camera,r=this.assets,i=this.composer;this.renderer2=function(){var t=new e.WebGLRenderer({logarithmicDepthBuffer:!0,antialias:!1});return t.setSize(window.innerWidth,window.innerHeight),t.setClearColor(0),t.setPixelRatio(window.devicePixelRatio),t}(),this.renderer=i.replaceRenderer(this.renderer2),this.controls=new e.OrbitControls(n,this.renderer.domElement),this.controls2=new e.OrbitControls(n,this.renderer2.domElement),n.position.set(-3,0,-3),n.lookAt(this.controls.target),t.background=r.get("sky");var a=new e.AmbientLight(6710886),o=new e.DirectionalLight(16759722);o.position.set(1440,200,2e3),o.target.position.copy(t.position),t.add(o),t.add(a);var s=new e.Mesh(new e.BoxBufferGeometry(1,1,1),new e.MeshBasicMaterial({color:0,wireframe:!0}));s.position.set(1.25,0,-1.25),this.objectA=s,t.add(s),(s=new e.Mesh(new e.BoxBufferGeometry(1,1,1),new e.MeshPhongMaterial({map:r.get("crate-color")}))).position.set(-1.25,0,1.25),this.objectB=s,t.add(s),s=new e.Mesh(new e.BoxBufferGeometry(.25,8.25,.25),new e.MeshPhongMaterial({color:855309}));var l=new e.Object3D,u=void 0,c=void 0,d=void 0;u=l.clone();var f=s.clone();f.position.set(-4,0,4),u.add(f),(f=s.clone()).position.set(4,0,4),u.add(f),(f=s.clone()).position.set(-4,0,-4),u.add(f),(f=s.clone()).position.set(4,0,-4),u.add(f),(c=u.clone()).rotation.set(Math.PI/2,0,0),(d=u.clone()).rotation.set(0,0,Math.PI/2),l.add(u),l.add(c),l.add(d),l.scale.set(.1,.1,.1),this.objectC=l,t.add(l);var v=new Oe(t,n);this.renderPass=v,i.addPass(v),(v=new Re(Image)).renderToScreen=!0,this.smaaPass=v,i.addPass(v)}},{key:"update",value:function(e){var t=this.objectA,n=this.objectB,r=this.objectC;null!==t&&(t.rotation.x+=5e-4,t.rotation.y+=.001,n.rotation.copy(t.rotation),r.rotation.copy(t.rotation),t.rotation.x>=ct&&(t.rotation.x-=ct),t.rotation.y>=ct&&(t.rotation.y-=ct))}},{key:"configure",value:function(e){var t=this.composer,n=this.renderPass,r=this.smaaPass,i=this.renderer,a=this.renderer2,o=this.controls,s=this.controls2,l={"browser AA":!1,SMAA:r.enabled,"SMAA threshold":Number.parseFloat(r.colorEdgesMaterial.defines.EDGE_THRESHOLD)};e.add(l,"browser AA").onChange(function(){var e=t.renderer.getSize();l["browser AA"]?(i.setSize(e.width,e.height),t.replaceRenderer(i),o.enabled=!0,s.enabled=!1):(a.setSize(e.width,e.height),t.replaceRenderer(a),o.enabled=!1,s.enabled=!0)}),e.add(l,"SMAA").onChange(function(){n.renderToScreen=!l.SMAA,r.enabled=l.SMAA}),e.add(l,"SMAA threshold").min(0).max(1).step(.01).onChange(function(){r.colorEdgesMaterial.defines.EDGE_THRESHOLD=l["SMAA threshold"].toFixed(2),r.colorEdgesMaterial.needsUpdate=!0})}},{key:"reset",value:function(){d(n.prototype.__proto__||Object.getPrototypeOf(n.prototype),"reset",this).call(this),this.renderer.dispose(),this.renderer=null,this.controls2.dispose(),this.controls2=null}}]),n}(),ft=2*Math.PI,vt=function(t){function n(e){u(this,n);var t=v(this,(n.__proto__||Object.getPrototypeOf(n)).call(this,e));return t.toneMappingPass=null,t.object=null,t}return f(n,He),c(n,[{key:"load",value:function(t){var n=this,r=new Map,i=this.loadingManager,a=new e.TextureLoader(i),o=new e.CubeTextureLoader(i),s="textures/skies/sunset/",l=[s+"px.png",s+"nx.png",s+"py.png",s+"ny.png",s+"pz.png",s+"nz.png"];null===this.assets?(i.onProgress=function(e,i,a){i===a&&(n.assets=r,t())},o.load(l,function(e){r.set("sky",e)}),a.load("textures/crate.jpg",function(t){t.wrapS=t.wrapT=e.RepeatWrapping,r.set("crate-color",t)})):t()}},{key:"initialise",value:function(){var t=this.scene,n=this.camera,r=this.assets,i=this.composer;this.controls=new e.OrbitControls(n,i.renderer.domElement),n.position.set(-3,0,-3),n.lookAt(this.controls.target),t.background=r.get("sky");var a=new e.AmbientLight(6710886),o=new e.DirectionalLight(16759722);o.position.set(1440,200,2e3),o.target.position.copy(t.position),t.add(o),t.add(a);var s=new e.Mesh(new e.BoxBufferGeometry(1,1,1),new e.MeshPhongMaterial({map:r.get("crate-color")}));this.object=s,t.add(s),i.addPass(new Oe(t,n));var l=new Ge({adaptive:!0,resolution:256,distinction:1});l.renderToScreen=!0,this.toneMappingPass=l,i.addPass(l)}},{key:"update",value:function(e){var t=this.object;null!==t&&(t.rotation.x+=5e-4,t.rotation.y+=.001,t.rotation.x>=ft&&(t.rotation.x-=ft),t.rotation.y>=ft&&(t.rotation.y-=ft))}},{key:"configure",value:function(e){var t=this.toneMappingPass,n={resolution:Math.round(Math.log(t.resolution)/Math.log(2)),adaptive:t.adaptive,distinction:t.luminosityMaterial.uniforms.distinction.value,"adaption rate":t.adaptiveLuminosityMaterial.uniforms.tau.value,"average lum":t.toneMappingMaterial.uniforms.averageLuminance.value,"min lum":t.adaptiveLuminosityMaterial.uniforms.minLuminance.value,"max lum":t.toneMappingMaterial.uniforms.maxLuminance.value,"middle grey":t.toneMappingMaterial.uniforms.middleGrey.value};e.add(n,"resolution").min(6).max(11).step(1).onChange(function(){t.resolution=Math.pow(2,n.resolution)}),e.add(n,"adaptive").onChange(function(){t.adaptive=n.adaptive});var r=e.addFolder("Luminance");r.add(n,"distinction").min(1).max(10).step(.1).onChange(function(){t.luminosityMaterial.uniforms.distinction.value=n.distinction}),r.add(n,"adaption rate").min(0).max(2).step(.01).onChange(function(){t.adaptiveLuminosityMaterial.uniforms.tau.value=n["adaption rate"]}),r.add(n,"average lum").min(.01).max(1).step(.01).onChange(function(){t.toneMappingMaterial.uniforms.averageLuminance.value=n["average lum"]}),r.add(n,"min lum").min(0).max(1).step(.01).onChange(function(){t.adaptiveLuminosityMaterial.uniforms.minLuminance.value=n["min lum"]}),r.add(n,"max lum").min(0).max(32).step(1).onChange(function(){t.toneMappingMaterial.uniforms.maxLuminance.value=n["max lum"]}),r.add(n,"middle grey").min(0).max(1).step(.01).onChange(function(){t.toneMappingMaterial.uniforms.middleGrey.value=n["middle grey"]}),r.open()}}]),n}(),ht=function(){function r(){u(this,r),this.clock=new e.Clock,this.composer=function(){var t=new e.WebGLRenderer({logarithmicDepthBuffer:!0,antialias:!0});return t.setSize(window.innerWidth,window.innerHeight),t.setClearColor(0),t.setPixelRatio(window.devicePixelRatio),new We(t,{stencilBuffer:!0,depthTexture:!0})}(),this.stats=function(){var e=new n;return e.showPanel(0),e.dom.id="stats",e}(),this.demos=function(e){var t=new Map;return t.set("render",new lt(e)),t.set("bloom",new Ve(e)),t.set("blur",new Ze(e)),t.set("bokeh",new Ye(e)),t.set("bokeh2",new qe(e)),t.set("depth",new Qe(e)),t.set("dot-screen",new $e(e)),t.set("film",new tt(e)),t.set("glitch",new rt(e)),t.set("god-rays",new ot(e)),t.set("pixelation",new at(e)),t.set("shock-wave",new ut(e)),t.set("smaa",new dt(e)),t.set("tone-mapping",new vt(e)),t}(this.composer),this.effect=function(e){var t=window.location.hash.slice(1);return 0!==t.length&&e.has(t)||(t=e.keys().next().value),t}(this.demos)}return c(r,[{key:"initialise",value:function(e,n,r){function i(){f.initialise(),f.camera.aspect=window.innerWidth/window.innerHeight,f.camera.updateProjectionMatrix(),(v=new t.GUI({autoPlace:!1})).add(o,"effect",Array.from(d.keys())).onChange(a),f.configure(v),n.appendChild(v.domElement),r.style.display="none",l.domElement.style.visibility="visible"}function a(){var e=l.getSize();r.style.display="block",l.domElement.style.visibility="hidden",null!==v&&(v.destroy(),n.removeChild(v.domElement)),null!==f&&(f.reset(),l.setSize(e.width,e.height),s.replaceRenderer(l)),s.reset(),(f=d.get(o.effect)).load(i)}var o=this,s=this.composer,l=s.renderer,u=this.clock,c=this.stats,d=this.demos,f=null,v=null;e.appendChild(l.domElement),n.appendChild(c.dom),a(),document.addEventListener("keydown",function(e){e.altKey&&(e.preventDefault(),n.style.visibility="hidden"===n.style.visibility?"visible":"hidden")}),window.addEventListener("resize",function(){function e(e){var n=e.target.innerWidth,r=e.target.innerHeight;s.setSize(n,r),f.camera.aspect=n/r,f.camera.updateProjectionMatrix(),t=0}var t=0;return function(n){0===t&&(t=setTimeout(e,66,n))}}()),function e(t){var n=u.getDelta();requestAnimationFrame(e),c.begin(),f.update(n),s.render(n),c.end()}()}}]),r}();window.addEventListener("load",function e(t){var n=document.getElementById("viewport"),r=n.children[0],i=document.getElementById("aside"),a=new ht;window.removeEventListener("load",e),i.style.visibility="visible",a.initialise(n,i,r)})}(THREE,dat,Stats); \ No newline at end of file +!function(e,t,n){"use strict";function r(e,t){return e+Math.floor(Math.random()*(t-e+1))}function i(e,t){return e+Math.random()*(t-e)}function a(e,t,n){return Math.max(t,Math.min(n,e))}function o(e){return Math.pow(2,Math.max(0,Math.ceil(Math.log2(e))))}t=t&&t.hasOwnProperty("default")?t.default:t,n=n&&n.hasOwnProperty("default")?n.default:n;var s="uniform sampler2D tPreviousLum;\r\nuniform sampler2D tCurrentLum;\r\nuniform float minLuminance;\r\nuniform float delta;\r\nuniform float tau;\r\n\r\nvarying vec2 vUv;\r\n\r\nvoid main() {\r\n\r\n\tfloat previousLum = texture2D(tPreviousLum, vUv, MIP_LEVEL_1X1).r;\r\n\tfloat currentLum = texture2D(tCurrentLum, vUv, MIP_LEVEL_1X1).r;\r\n\r\n\tpreviousLum = max(minLuminance, previousLum);\r\n\tcurrentLum = max(minLuminance, currentLum);\r\n\r\n\t// Adapt the luminance using Pattanaik's technique.\r\n\tfloat adaptedLum = previousLum + (currentLum - previousLum) * (1.0 - exp(-delta * tau));\r\n\r\n\tgl_FragColor.r = adaptedLum;\r\n\r\n}\r\n",l="varying vec2 vUv;\r\n\r\nvoid main() {\r\n\r\n\tvUv = uv;\r\n\tgl_Position = projectionMatrix * modelViewMatrix * vec4(position, 1.0);\r\n\r\n}\r\n",u=function(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")},c=function(){function e(e,t){for(var n=0;n0&&void 0!==arguments[0]?arguments[0]:null,r=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};u(this,n),void 0===r.focus&&(r.focus=1),void 0===r.aperture&&(r.aperture=.025),void 0===r.maxBlur&&(r.maxBlur=1);var i=v(this,(n.__proto__||Object.getPrototypeOf(n)).call(this,{type:"BokehMaterial",uniforms:{cameraNear:new e.Uniform(.1),cameraFar:new e.Uniform(2e3),aspect:new e.Uniform(1),tDiffuse:new e.Uniform(null),tDepth:new e.Uniform(null),focus:new e.Uniform(r.focus),aperture:new e.Uniform(r.aperture),maxBlur:new e.Uniform(r.maxBlur)},fragmentShader:m,vertexShader:p,depthWrite:!1,depthTest:!1}));return null!==t&&i.adoptCameraSettings(t),i}return f(n,t),c(n,[{key:"adoptCameraSettings",value:function(e){this.uniforms.cameraNear.value=e.near,this.uniforms.cameraFar.value=e.far,this.uniforms.aspect.value=e.aspect}}]),n}(e.ShaderMaterial),x="uniform sampler2D tDiffuse;\r\nuniform sampler2D tDepth;\r\n\r\nuniform vec2 texelSize;\r\nuniform vec2 halfTexelSize;\r\n\r\nuniform float cameraNear;\r\nuniform float cameraFar;\r\n\r\nuniform float focalLength;\r\nuniform float focalStop;\r\n\r\nuniform float maxBlur;\r\nuniform vec3 luminanceCoefficients;\r\nuniform float luminanceThreshold;\r\nuniform float luminanceGain;\r\nuniform float bias;\r\nuniform float fringe;\r\nuniform float ditherStrength;\r\n\r\n#ifdef SHADER_FOCUS\r\n\r\n\tuniform vec2 focusCoords;\r\n\r\n#else\r\n\r\n\tuniform float focalDepth;\r\n\r\n#endif\r\n\r\nvarying vec2 vUv;\r\n\r\n#ifndef USE_LOGDEPTHBUF\r\n\r\n\t#include \r\n\r\n\tfloat readDepth(sampler2D depthSampler, vec2 coord) {\r\n\r\n\t\tfloat fragCoordZ = texture2D(depthSampler, coord).x;\r\n\t\tfloat viewZ = perspectiveDepthToViewZ(fragCoordZ, cameraNear, cameraFar);\r\n\r\n\t\treturn viewZToOrthographicDepth(viewZ, cameraNear, cameraFar);\r\n\r\n\t}\r\n\r\n#endif\r\n\r\n#ifdef PENTAGON\r\n\r\n\tfloat penta(vec2 coords) {\r\n\r\n\t\tconst vec4 HS0 = vec4( 1.0, 0.0, 0.0, 1.0);\r\n\t\tconst vec4 HS1 = vec4( 0.309016994, 0.951056516, 0.0, 1.0);\r\n\t\tconst vec4 HS2 = vec4(-0.809016994, 0.587785252, 0.0, 1.0);\r\n\t\tconst vec4 HS3 = vec4(-0.809016994, -0.587785252, 0.0, 1.0);\r\n\t\tconst vec4 HS4 = vec4( 0.309016994, -0.951056516, 0.0, 1.0);\r\n\t\tconst vec4 HS5 = vec4( 0.0, 0.0, 1.0, 1.0);\r\n\r\n\t\tconst vec4 ONE = vec4(1.0);\r\n\r\n\t\tconst float P_FEATHER = 0.4;\r\n\t\tconst float N_FEATHER = -P_FEATHER;\r\n\r\n\t\tfloat inOrOut = -4.0;\r\n\r\n\t\tvec4 P = vec4(coords, vec2(RINGS_FLOAT - 1.3));\r\n\r\n\t\tvec4 dist = vec4(\r\n\t\t\tdot(P, HS0),\r\n\t\t\tdot(P, HS1),\r\n\t\t\tdot(P, HS2),\r\n\t\t\tdot(P, HS3)\r\n\t\t);\r\n\r\n\t\tdist = smoothstep(N_FEATHER, P_FEATHER, dist);\r\n\r\n\t\tinOrOut += dot(dist, ONE);\r\n\r\n\t\tdist.x = dot(P, HS4);\r\n\t\tdist.y = HS5.w - abs(P.z);\r\n\r\n\t\tdist = smoothstep(N_FEATHER, P_FEATHER, dist);\r\n\t\tinOrOut += dist.x;\r\n\r\n\t\treturn clamp(inOrOut, 0.0, 1.0);\r\n\r\n\t}\r\n\r\n#endif\r\n\r\n#ifdef SHOW_FOCUS\r\n\r\n\tvec3 debugFocus(vec3 c, float blur, float depth) {\r\n\r\n\t\tfloat edge = 0.002 * depth;\r\n\t\tfloat m = clamp(smoothstep(0.0, edge, blur), 0.0, 1.0);\r\n\t\tfloat e = clamp(smoothstep(1.0 - edge, 1.0, blur), 0.0, 1.0);\r\n\r\n\t\tc = mix(c, vec3(1.0, 0.5, 0.0), (1.0 - m) * 0.6);\r\n\t\tc = mix(c, vec3(0.0, 0.5, 1.0), ((1.0 - e) - (1.0 - m)) * 0.2);\r\n\r\n\t\treturn c;\r\n\r\n\t}\r\n\r\n#endif\r\n\r\n#ifdef VIGNETTE\r\n\r\n\tfloat vignette() {\r\n\r\n\t\tconst vec2 CENTER = vec2(0.5);\r\n\r\n\t\tconst float VIGNETTE_OUT = 1.3;\r\n\t\tconst float VIGNETTE_IN = 0.0;\r\n\t\tconst float VIGNETTE_FADE = 22.0; \r\n\r\n\t\tfloat d = distance(vUv, CENTER);\r\n\t\td = smoothstep(VIGNETTE_OUT + (focalStop / VIGNETTE_FADE), VIGNETTE_IN + (focalStop / VIGNETTE_FADE), d);\r\n\r\n\t\treturn clamp(d, 0.0, 1.0);\r\n\r\n\t}\r\n\r\n#endif\r\n\r\nvec2 rand(vec2 coord) {\r\n\r\n\tvec2 noise;\r\n\r\n\t#ifdef NOISE\r\n\r\n\t\tconst float a = 12.9898;\r\n\t\tconst float b = 78.233;\r\n\t\tconst float c = 43758.5453;\r\n\r\n\t\tnoise.x = clamp(fract(sin(mod(dot(coord, vec2(a, b)), 3.14)) * c), 0.0, 1.0) * 2.0 - 1.0;\r\n\t\tnoise.y = clamp(fract(sin(mod(dot(coord, vec2(a, b) * 2.0), 3.14)) * c), 0.0, 1.0) * 2.0 - 1.0;\r\n\r\n\t#else\r\n\r\n\t\tnoise.x = ((fract(1.0 - coord.s * halfTexelSize.x) * 0.25) + (fract(coord.t * halfTexelSize.y) * 0.75)) * 2.0 - 1.0;\r\n\t\tnoise.y = ((fract(1.0 - coord.s * halfTexelSize.x) * 0.75) + (fract(coord.t * halfTexelSize.y) * 0.25)) * 2.0 - 1.0;\r\n\r\n\t#endif\r\n\r\n\treturn noise;\r\n\r\n}\r\n\r\nvec3 processTexel(vec2 coords, float blur) {\r\n\r\n\tvec3 c;\r\n\tc.r = texture2D(tDiffuse, coords + vec2(0.0, 1.0) * texelSize * fringe * blur).r;\r\n\tc.g = texture2D(tDiffuse, coords + vec2(-0.866, -0.5) * texelSize * fringe * blur).g;\r\n\tc.b = texture2D(tDiffuse, coords + vec2(0.866, -0.5) * texelSize * fringe * blur).b;\r\n\r\n\t// Calculate the luminance of the constructed colour.\r\n\tfloat luminance = dot(c, luminanceCoefficients);\r\n\tfloat threshold = max((luminance - luminanceThreshold) * luminanceGain, 0.0);\r\n\r\n\treturn c + mix(vec3(0.0), c, threshold * blur);\r\n\r\n}\r\n\r\nfloat linearize(float depth) {\r\n\r\n\treturn -cameraFar * cameraNear / (depth * (cameraFar - cameraNear) - cameraFar);\r\n\r\n}\r\n\r\nfloat gather(float i, float j, float ringSamples, inout vec3 color, float w, float h, float blur) {\r\n\r\n\tconst float TWO_PI = 6.28318531;\r\n\r\n\tfloat step = TWO_PI / ringSamples;\r\n\tfloat pw = cos(j * step) * i;\r\n\tfloat ph = sin(j * step) * i;\r\n\r\n\t#ifdef PENTAGON\r\n\r\n\t\tfloat p = penta(vec2(pw, ph));\r\n\r\n\t#else\r\n\r\n\t\tfloat p = 1.0;\r\n\r\n\t#endif\r\n\r\n\tcolor += processTexel(vUv + vec2(pw * w, ph * h), blur) * mix(1.0, i / RINGS_FLOAT, bias) * p;\r\n\r\n\treturn mix(1.0, i / RINGS_FLOAT, bias) * p;\r\n\r\n}\r\n\r\nvoid main() {\r\n\r\n\t#ifdef USE_LOGDEPTHBUF\r\n\r\n\t\tfloat depth = linearize(texture2D(tDepth, vUv).x);\r\n\r\n\t#else\r\n\r\n\t\tfloat depth = linearize(readDepth(tDepth, vUv));\r\n\r\n\t#endif\r\n\r\n\t#ifdef SHADER_FOCUS\r\n\r\n\t\t#ifdef USE_LOGDEPTHBUF\r\n\r\n\t\t\tfloat fDepth = linearize(texture2D(tDepth, focusCoords).x);\r\n\r\n\t\t#else\r\n\r\n\t\t\tfloat fDepth = linearize(readDepth(tDepth, focusCoords));\r\n\r\n\t\t#endif\r\n\r\n\t#else\r\n\r\n\t\tfloat fDepth = focalDepth;\r\n\r\n\t#endif\r\n\r\n\t#ifdef MANUAL_DOF\r\n\r\n\t\tconst float nDoFStart = 1.0; \r\n\t\tconst float nDoFDist = 2.0;\r\n\t\tconst float fDoFStart = 1.0;\r\n\t\tconst float fDoFDist = 3.0;\r\n\r\n\t\tfloat focalPlane = depth - fDepth;\r\n\t\tfloat farDoF = (focalPlane - fDoFStart) / fDoFDist;\r\n\t\tfloat nearDoF = (-focalPlane - nDoFStart) / nDoFDist;\r\n\r\n\t\tfloat blur = (focalPlane > 0.0) ? farDoF : nearDoF;\r\n\r\n\t#else\r\n\r\n\t\tconst float CIRCLE_OF_CONFUSION = 0.03; // 35mm film = 0.03mm CoC.\r\n\r\n\t\tfloat focalPlaneMM = fDepth * 1000.0;\r\n\t\tfloat depthMM = depth * 1000.0;\r\n\r\n\t\tfloat focalPlane = (depthMM * focalLength) / (depthMM - focalLength);\r\n\t\tfloat farDoF = (focalPlaneMM * focalLength) / (focalPlaneMM - focalLength);\r\n\t\tfloat nearDoF = (focalPlaneMM - focalLength) / (focalPlaneMM * focalStop * CIRCLE_OF_CONFUSION);\r\n\r\n\t\tfloat blur = abs(focalPlane - farDoF) * nearDoF;\r\n\r\n\t#endif\r\n\r\n\tblur = clamp(blur, 0.0, 1.0);\r\n\r\n\t// Dithering.\r\n\tvec2 noise = rand(vUv) * ditherStrength * blur;\r\n\r\n\tfloat blurFactorX = texelSize.x * blur * maxBlur + noise.x;\r\n\tfloat blurFactorY = texelSize.y * blur * maxBlur + noise.y;\r\n\r\n\tconst int MAX_RING_SAMPLES = RINGS_INT * SAMPLES_INT;\r\n\r\n\t// Calculation of final color.\r\n\tvec4 color;\r\n\r\n\tif(blur < 0.05) {\r\n\r\n\t\tcolor = texture2D(tDiffuse, vUv);\r\n\r\n\t} else {\r\n\r\n\t\tcolor = texture2D(tDiffuse, vUv);\r\n\r\n\t\tfloat s = 1.0;\r\n\t\tint ringSamples;\r\n\r\n\t\tfor(int i = 1; i <= RINGS_INT; ++i) {\r\n\r\n\t\t\tringSamples = i * SAMPLES_INT;\r\n\r\n\t\t\t// Constant loop.\r\n\t\t\tfor(int j = 0; j < MAX_RING_SAMPLES; ++j) {\r\n\r\n\t\t\t\t// Break earlier.\r\n\t\t\t\tif(j >= ringSamples) { break; }\r\n\r\n\t\t\t\ts += gather(float(i), float(j), float(ringSamples), color.rgb, blurFactorX, blurFactorY, blur);\r\n\r\n\t\t\t}\r\n\r\n\t\t}\r\n\r\n\t\tcolor.rgb /= s; // Divide by sample count.\r\n\r\n\t}\r\n\r\n\t#ifdef SHOW_FOCUS\r\n\r\n\t\tcolor.rgb = debugFocus(color.rgb, blur, depth);\r\n\r\n\t#endif\r\n\r\n\t#ifdef VIGNETTE\r\n\r\n\t\tcolor.rgb *= vignette();\r\n\r\n\t#endif\r\n\r\n\tgl_FragColor = color;\r\n\r\n}\r\n",y="varying vec2 vUv;\r\n\r\nvoid main() {\r\n\r\n\tvUv = uv;\r\n\tgl_Position = projectionMatrix * modelViewMatrix * vec4(position, 1.0);\r\n\r\n}\r\n",M=function(t){function n(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:null,r=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};u(this,n),void 0===r.rings&&(r.rings=3),void 0===r.samples&&(r.samples=2),void 0===r.showFocus&&(r.showFocus=!1),void 0===r.showFocus&&(r.showFocus=!1),void 0===r.manualDoF&&(r.manualDoF=!1),void 0===r.vignette&&(r.vignette=!1),void 0===r.pentagon&&(r.pentagon=!1),void 0===r.shaderFocus&&(r.shaderFocus=!0),void 0===r.noise&&(r.noise=!0);var i=v(this,(n.__proto__||Object.getPrototypeOf(n)).call(this,{type:"Bokeh2Material",defines:{RINGS_INT:r.rings.toFixed(0),RINGS_FLOAT:r.rings.toFixed(1),SAMPLES_INT:r.samples.toFixed(0),SAMPLES_FLOAT:r.samples.toFixed(1)},uniforms:{tDiffuse:new e.Uniform(null),tDepth:new e.Uniform(null),texelSize:new e.Uniform(new e.Vector2),halfTexelSize:new e.Uniform(new e.Vector2),cameraNear:new e.Uniform(.1),cameraFar:new e.Uniform(2e3),focalLength:new e.Uniform(24),focalStop:new e.Uniform(.9),maxBlur:new e.Uniform(1),luminanceThreshold:new e.Uniform(.5),luminanceGain:new e.Uniform(2),luminanceCoefficients:new e.Uniform(new e.Vector3(.2126,.7152,.0722)),bias:new e.Uniform(.5),fringe:new e.Uniform(.7),ditherStrength:new e.Uniform(1e-4),focusCoords:new e.Uniform(new e.Vector2(.5,.5)),focalDepth:new e.Uniform(1)},fragmentShader:x,vertexShader:y,depthWrite:!1,depthTest:!1}));return r.showFocus&&(i.defines.SHOW_FOCUS="1"),r.manualDoF&&(i.defines.MANUAL_DOF="1"),r.vignette&&(i.defines.VIGNETTE="1"),r.pentagon&&(i.defines.PENTAGON="1"),r.shaderFocus&&(i.defines.SHADER_FOCUS="1"),r.noise&&(i.defines.NOISE="1"),void 0!==r.texelSize&&i.setTexelSize(r.texelSize.x,r.texelSize.y),null!==t&&i.adoptCameraSettings(t),i}return f(n,t),c(n,[{key:"setTexelSize",value:function(e,t){this.uniforms.texelSize.value.set(e,t),this.uniforms.halfTexelSize.value.set(e,t).multiplyScalar(.5)}},{key:"adoptCameraSettings",value:function(e){this.uniforms.cameraNear.value=e.near,this.uniforms.cameraFar.value=e.far,this.uniforms.focalLength.value=e.getFocalLength()}}]),n}(e.ShaderMaterial),w="uniform sampler2D texture1;\r\nuniform sampler2D texture2;\r\n\r\nuniform float opacity1;\r\nuniform float opacity2;\r\n\r\nvarying vec2 vUv;\r\n\r\nvoid main() {\r\n\r\n\tvec4 texel1 = opacity1 * texture2D(texture1, vUv);\r\n\tvec4 texel2 = opacity2 * texture2D(texture2, vUv);\r\n\r\n\t#ifdef SCREEN_MODE\r\n\r\n\t\tvec3 invTexel1 = vec3(1.0) - texel1.rgb;\r\n\t\tvec3 invTexel2 = vec3(1.0) - texel2.rgb;\r\n\r\n\t\tvec4 color = vec4(\r\n\t\t\tvec3(1.0) - invTexel1 * invTexel2,\r\n\t\t\ttexel1.a + texel2.a\r\n\t\t);\r\n\r\n\t#else\r\n\r\n\t\tvec4 color = texel1 + texel2;\r\n\r\n\t#endif\r\n\r\n\tgl_FragColor = color;\r\n\r\n}\r\n",b="varying vec2 vUv;\r\n\r\nvoid main() {\r\n\r\n\tvUv = uv;\r\n\tgl_Position = projectionMatrix * modelViewMatrix * vec4(position, 1.0);\r\n\r\n}\r\n",S=function(t){function n(){var t=arguments.length>0&&void 0!==arguments[0]&&arguments[0];u(this,n);var r=v(this,(n.__proto__||Object.getPrototypeOf(n)).call(this,{type:"CombineMaterial",uniforms:{texture1:new e.Uniform(null),texture2:new e.Uniform(null),opacity1:new e.Uniform(1),opacity2:new e.Uniform(1)},fragmentShader:w,vertexShader:b,depthWrite:!1,depthTest:!1}));return t&&(r.defines.SCREEN_MODE="1"),r}return f(n,t),n}(e.ShaderMaterial),D="uniform sampler2D tDiffuse;\r\n\r\nvarying vec2 vUv0;\r\nvarying vec2 vUv1;\r\nvarying vec2 vUv2;\r\nvarying vec2 vUv3;\r\n\r\nvoid main() {\r\n\r\n\t// Sample top left texel.\r\n\tvec4 sum = texture2D(tDiffuse, vUv0);\r\n\r\n\t// Sample top right texel.\r\n\tsum += texture2D(tDiffuse, vUv1);\r\n\r\n\t// Sample bottom right texel.\r\n\tsum += texture2D(tDiffuse, vUv2);\r\n\r\n\t// Sample bottom left texel.\r\n\tsum += texture2D(tDiffuse, vUv3);\r\n\r\n\t// Compute the average.\r\n\tgl_FragColor = sum * 0.25;\r\n\r\n}\r\n",P="uniform vec2 texelSize;\r\nuniform vec2 halfTexelSize;\r\nuniform float kernel;\r\n\r\nvarying vec2 vUv0;\r\nvarying vec2 vUv1;\r\nvarying vec2 vUv2;\r\nvarying vec2 vUv3;\r\n\r\nvoid main() {\r\n\r\n\tvec2 dUv = (texelSize * vec2(kernel)) + halfTexelSize;\r\n\r\n\tvUv0 = vec2(uv.x - dUv.x, uv.y + dUv.y);\r\n\tvUv1 = vec2(uv.x + dUv.x, uv.y + dUv.y);\r\n\tvUv2 = vec2(uv.x + dUv.x, uv.y - dUv.y);\r\n\tvUv3 = vec2(uv.x - dUv.x, uv.y - dUv.y);\r\n\r\n\tgl_Position = projectionMatrix * modelViewMatrix * vec4(position, 1.0);\r\n\r\n}\r\n",T=function(t){function n(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:new e.Vector2;u(this,n);var r=v(this,(n.__proto__||Object.getPrototypeOf(n)).call(this,{type:"ConvolutionMaterial",uniforms:{tDiffuse:new e.Uniform(null),texelSize:new e.Uniform(new e.Vector2),halfTexelSize:new e.Uniform(new e.Vector2),kernel:new e.Uniform(0)},fragmentShader:D,vertexShader:P,depthWrite:!1,depthTest:!1}));return r.setTexelSize(t.x,t.y),r.kernelSize=C.LARGE,r}return f(n,t),c(n,[{key:"getKernel",value:function(){return A[this.kernelSize]}},{key:"setTexelSize",value:function(e,t){this.uniforms.texelSize.value.set(e,t),this.uniforms.halfTexelSize.value.set(e,t).multiplyScalar(.5)}}]),n}(e.ShaderMaterial),A=[new Float32Array([0,0]),new Float32Array([0,1,1]),new Float32Array([0,1,1,2]),new Float32Array([0,1,2,2,3]),new Float32Array([0,1,2,3,4,4,5]),new Float32Array([0,1,2,3,4,5,7,8,9,10])],C={VERY_SMALL:0,SMALL:1,MEDIUM:2,LARGE:3,VERY_LARGE:4,HUGE:5},O="uniform sampler2D tDiffuse;\r\nuniform float opacity;\r\n\r\nvarying vec2 vUv;\r\n\r\nvoid main() {\r\n\r\n\tvec4 texel = texture2D(tDiffuse, vUv);\r\n\tgl_FragColor = opacity * texel;\r\n\r\n}\r\n",L="varying vec2 vUv;\r\n\r\nvoid main() {\r\n\r\n\tvUv = uv;\r\n\tgl_Position = projectionMatrix * modelViewMatrix * vec4(position, 1.0);\r\n\r\n}\r\n",E=function(t){function n(){return u(this,n),v(this,(n.__proto__||Object.getPrototypeOf(n)).call(this,{type:"CopyMaterial",uniforms:{tDiffuse:new e.Uniform(null),opacity:new e.Uniform(1)},fragmentShader:O,vertexShader:L,depthWrite:!1,depthTest:!1}))}return f(n,t),n}(e.ShaderMaterial),k="uniform sampler2D tDepth;\r\n\r\nvarying vec2 vUv;\r\n\r\n#ifndef USE_LOGDEPTHBUF\r\n\r\n\t#include \r\n\r\n\tuniform float cameraNear;\r\n\tuniform float cameraFar;\r\n\r\n\tfloat readDepth(sampler2D depthSampler, vec2 coord) {\r\n\r\n\t\tfloat fragCoordZ = texture2D(depthSampler, coord).x;\r\n\t\tfloat viewZ = perspectiveDepthToViewZ(fragCoordZ, cameraNear, cameraFar);\r\n\r\n\t\treturn viewZToOrthographicDepth(viewZ, cameraNear, cameraFar);\r\n\r\n\t}\r\n\r\n#endif\r\n\r\nvoid main() {\r\n\r\n\t#ifdef USE_LOGDEPTHBUF\r\n\r\n\t\tfloat depth = texture2D(tDepth, vUv).x;\r\n\r\n\t#else\r\n\r\n\t\tfloat depth = readDepth(tDepth, vUv);\r\n\r\n\t#endif\r\n\r\n\tgl_FragColor = vec4(depth, depth, depth, 1.0);\r\n\r\n}\r\n",U="varying vec2 vUv;\r\n\r\nvoid main() {\r\n\r\n\tvUv = uv;\r\n\tgl_Position = projectionMatrix * modelViewMatrix * vec4(position, 1.0);\r\n\r\n}\r\n",z=function(t){function n(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:null;u(this,n);var r=v(this,(n.__proto__||Object.getPrototypeOf(n)).call(this,{type:"DepthMaterial",uniforms:{cameraNear:new e.Uniform(.1),cameraFar:new e.Uniform(2e3),tDepth:new e.Uniform(null)},fragmentShader:k,vertexShader:U,depthWrite:!1,depthTest:!1}));return null!==t&&r.adoptCameraSettings(t),r}return f(n,t),c(n,[{key:"adoptCameraSettings",value:function(e){this.uniforms.cameraNear.value=e.near,this.uniforms.cameraFar.value=e.far}}]),n}(e.ShaderMaterial),F="uniform sampler2D tDiffuse;\r\n\r\nuniform float angle;\r\nuniform float scale;\r\nuniform float intensity;\r\n\r\nvarying vec2 vUv;\r\nvarying vec2 vUvPattern;\r\n\r\nfloat pattern() {\r\n\r\n\tfloat s = sin(angle);\r\n\tfloat c = cos(angle);\r\n\r\n\tvec2 point = vec2(c * vUvPattern.x - s * vUvPattern.y, s * vUvPattern.x + c * vUvPattern.y) * scale;\r\n\r\n\treturn (sin(point.x) * sin(point.y)) * 4.0;\r\n\r\n}\r\n\r\nvoid main() {\r\n\r\n\tvec4 texel = texture2D(tDiffuse, vUv);\r\n\tvec3 color = texel.rgb;\r\n\r\n\t#ifdef AVERAGE\r\n\r\n\t\tcolor = vec3((color.r + color.g + color.b) / 3.0);\r\n\r\n\t#endif\r\n\r\n\tcolor = vec3(color * 10.0 - 5.0 + pattern());\r\n\tcolor = texel.rgb + (color - texel.rgb) * intensity;\r\n\r\n\tgl_FragColor = vec4(color, texel.a);\r\n\r\n}\r\n",N="uniform vec4 offsetRepeat;\r\n\r\nvarying vec2 vUv;\r\nvarying vec2 vUvPattern;\r\n\r\nvoid main() {\r\n\r\n\tvUv = uv;\r\n\tvUvPattern = uv * offsetRepeat.zw + offsetRepeat.xy;\r\n\tgl_Position = projectionMatrix * modelViewMatrix * vec4(position, 1.0);\r\n\r\n}\r\n",j=function(t){function n(){var t=arguments.length>0&&void 0!==arguments[0]&&arguments[0];u(this,n);var r=v(this,(n.__proto__||Object.getPrototypeOf(n)).call(this,{type:"DotScreenMaterial",uniforms:{tDiffuse:new e.Uniform(null),angle:new e.Uniform(1.57),scale:new e.Uniform(1),intensity:new e.Uniform(1),offsetRepeat:new e.Uniform(new e.Vector4(.5,.5,1,1))},fragmentShader:F,vertexShader:N,depthWrite:!1,depthTest:!1}));return t&&(r.defines.AVERAGE="1"),r}return f(n,t),n}(e.ShaderMaterial),B="uniform sampler2D tDiffuse;\r\nuniform float time;\r\n\r\nvarying vec2 vUv;\r\n\r\n#ifdef NOISE\r\n\r\n\tuniform float noiseIntensity;\r\n\r\n#endif\r\n\r\n#ifdef SCANLINES\r\n\r\n\tuniform float scanlineIntensity;\r\n\tuniform float scanlineCount;\r\n\r\n#endif\r\n\r\n#ifdef GREYSCALE\r\n\r\n\tuniform vec3 luminanceCoefficients;\r\n\tuniform float greyscaleIntensity;\r\n\r\n#elif defined(SEPIA)\r\n\r\n\tuniform float sepiaIntensity;\r\n\r\n#endif\r\n\r\n#ifdef VIGNETTE\r\n\r\n\tuniform float vignetteOffset;\r\n\tuniform float vignetteDarkness;\r\n\r\n#endif\r\n\r\nvoid main() {\r\n\r\n\tvec4 texel = texture2D(tDiffuse, vUv);\r\n\tvec3 color = texel.rgb;\r\n\r\n\t#ifdef SCREEN_MODE\r\n\r\n\t\tvec3 invColor;\r\n\r\n\t#endif\r\n\r\n\t#ifdef NOISE\r\n\r\n\t\tfloat x = vUv.x * vUv.y * time * 1000.0;\r\n\t\tx = mod(x, 13.0) * mod(x, 123.0);\r\n\t\tx = mod(x, 0.01);\r\n\r\n\t\tvec3 noise = texel.rgb * clamp(0.1 + x * 100.0, 0.0, 1.0) * noiseIntensity;\r\n\r\n\t\t#ifdef SCREEN_MODE\r\n\r\n\t\t\tinvColor = vec3(1.0) - color;\r\n\t\t\tvec3 invNoise = vec3(1.0) - noise;\r\n\r\n\t\t\tcolor = vec3(1.0) - invColor * invNoise;\r\n\r\n\t\t#else\r\n\r\n\t\t\tcolor += noise;\r\n\r\n\t\t#endif\r\n\r\n\t#endif\r\n\r\n\t#ifdef SCANLINES\r\n\r\n\t\tvec2 sl = vec2(sin(vUv.y * scanlineCount), cos(vUv.y * scanlineCount));\r\n\t\tvec3 scanlines = texel.rgb * vec3(sl.x, sl.y, sl.x) * scanlineIntensity;\r\n\r\n\t\t#ifdef SCREEN_MODE\r\n\r\n\t\t\tinvColor = vec3(1.0) - color;\r\n\t\t\tvec3 invScanlines = vec3(1.0) - scanlines;\r\n\r\n\t\t\tcolor = vec3(1.0) - invColor * invScanlines;\r\n\r\n\t\t#else\r\n\r\n\t\t\tcolor += scanlines;\r\n\r\n\t\t#endif\r\n\r\n\t#endif\r\n\r\n\t#ifdef GREYSCALE\r\n\r\n\t\tcolor = mix(color, vec3(dot(color, luminanceCoefficients)), greyscaleIntensity);\r\n\r\n\t#elif defined(SEPIA)\r\n\r\n\t\tvec3 c = color.rgb;\r\n\r\n\t\tcolor.r = dot(c, vec3(1.0 - 0.607 * sepiaIntensity, 0.769 * sepiaIntensity, 0.189 * sepiaIntensity));\r\n\t\tcolor.g = dot(c, vec3(0.349 * sepiaIntensity, 1.0 - 0.314 * sepiaIntensity, 0.168 * sepiaIntensity));\r\n\t\tcolor.b = dot(c, vec3(0.272 * sepiaIntensity, 0.534 * sepiaIntensity, 1.0 - 0.869 * sepiaIntensity));\r\n\r\n\t#endif\r\n\r\n\t#ifdef VIGNETTE\r\n\r\n\t\tconst vec2 center = vec2(0.5);\r\n\r\n\t\t#ifdef ESKIL\r\n\r\n\t\t\tvec2 uv = (vUv - center) * vec2(vignetteOffset);\r\n\t\t\tcolor = mix(color.rgb, vec3(1.0 - vignetteDarkness), dot(uv, uv));\r\n\r\n\t\t#else\r\n\r\n\t\t\tfloat dist = distance(vUv, center);\r\n\t\t\tcolor *= smoothstep(0.8, vignetteOffset * 0.799, dist * (vignetteDarkness + vignetteOffset));\r\n\r\n\t\t#endif\t\t\r\n\r\n\t#endif\r\n\r\n\tgl_FragColor = vec4(clamp(color, 0.0, 1.0), texel.a);\r\n\r\n}\r\n",R="varying vec2 vUv;\r\n\r\nvoid main() {\r\n\r\n\tvUv = uv;\r\n\tgl_Position = projectionMatrix * modelViewMatrix * vec4(position, 1.0);\r\n\r\n}\r\n",I=function(t){function n(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};u(this,n),void 0===t.screenMode&&(t.screenMode=!0),void 0===t.noise&&(t.noise=!0),void 0===t.scanlines&&(t.scanlines=!0),void 0===t.greyscale&&(t.greyscale=!1),void 0===t.sepia&&(t.sepia=!1),void 0===t.vignette&&(t.vignette=!1),void 0===t.eskil&&(t.eskil=!1),void 0===t.noiseIntensity&&(t.noiseIntensity=.5),void 0===t.scanlineIntensity&&(t.scanlineIntensity=.05),void 0===t.greyscaleIntensity&&(t.greyscaleIntensity=1),void 0===t.sepiaIntensity&&(t.sepiaIntensity=1),void 0===t.vignetteOffset&&(t.vignetteOffset=1),void 0===t.vignetteDarkness&&(t.vignetteDarkness=1);var r=v(this,(n.__proto__||Object.getPrototypeOf(n)).call(this,{type:"FilmMaterial",uniforms:{tDiffuse:new e.Uniform(null),time:new e.Uniform(0),noiseIntensity:new e.Uniform(t.noiseIntensity),scanlineIntensity:new e.Uniform(t.scanlineIntensity),scanlineCount:new e.Uniform(0),luminanceCoefficients:new e.Uniform(new e.Vector3(.2126,.7152,.0722)),greyscaleIntensity:new e.Uniform(t.greyscaleIntensity),sepiaIntensity:new e.Uniform(t.sepiaIntensity),vignetteOffset:new e.Uniform(t.vignetteOffset),vignetteDarkness:new e.Uniform(t.vignetteDarkness)},fragmentShader:B,vertexShader:R,depthWrite:!1,depthTest:!1}));return t.greyscale&&(r.defines.GREYSCALE="1"),t.sepia&&(r.defines.SEPIA="1"),t.vignette&&(r.defines.VIGNETTE="1"),t.eskil&&(r.defines.ESKIL="1"),t.screenMode&&(r.defines.SCREEN_MODE="1"),t.noise&&(r.defines.NOISE="1"),t.scanlines&&(r.defines.SCANLINES="1"),r}return f(n,t),n}(e.ShaderMaterial),G="uniform sampler2D tDiffuse;\r\nuniform sampler2D tPerturb;\r\n\r\nuniform bool active;\r\n\r\nuniform float amount;\r\nuniform float angle;\r\nuniform float seed;\r\nuniform float seedX;\r\nuniform float seedY;\r\nuniform float distortionX;\r\nuniform float distortionY;\r\nuniform float colS;\r\n\r\nvarying vec2 vUv;\r\n\r\nfloat rand(vec2 tc) {\r\n\r\n\tconst float a = 12.9898;\r\n\tconst float b = 78.233;\r\n\tconst float c = 43758.5453;\r\n\r\n\tfloat dt = dot(tc, vec2(a, b));\r\n\tfloat sn = mod(dt, 3.14);\r\n\r\n\treturn fract(sin(sn) * c);\r\n\r\n}\r\n\r\nvoid main() {\r\n\r\n\tvec2 coord = vUv;\r\n\r\n\tfloat xs, ys;\r\n\tvec4 normal;\r\n\r\n\tvec2 offset;\r\n\tvec4 cr, cga, cb;\r\n\tvec4 snow, color;\r\n\r\n\tfloat sx, sy;\r\n\r\n\tif(active) {\r\n\r\n\t\txs = floor(gl_FragCoord.x / 0.5);\r\n\t\tys = floor(gl_FragCoord.y / 0.5);\r\n\r\n\t\tnormal = texture2D(tPerturb, coord * seed * seed);\r\n\r\n\t\tif(coord.y < distortionX + colS && coord.y > distortionX - colS * seed) {\r\n\r\n\t\t\tsx = clamp(ceil(seedX), 0.0, 1.0);\r\n\t\t\tcoord.y = sx * (1.0 - (coord.y + distortionY)) + (1.0 - sx) * distortionY;\r\n\r\n\t\t}\r\n\r\n\t\tif(coord.x < distortionY + colS && coord.x > distortionY - colS * seed) {\r\n\r\n\t\t\tsy = clamp(ceil(seedY), 0.0, 1.0);\r\n\t\t\tcoord.x = sy * distortionX + (1.0 - sy) * (1.0 - (coord.x + distortionX));\r\n\r\n\t\t}\r\n\r\n\t\tcoord.x += normal.x * seedX * (seed / 5.0);\r\n\t\tcoord.y += normal.y * seedY * (seed / 5.0);\r\n\r\n\t\toffset = amount * vec2(cos(angle), sin(angle));\r\n\r\n\t\tcr = texture2D(tDiffuse, coord + offset);\r\n\t\tcga = texture2D(tDiffuse, coord);\r\n\t\tcb = texture2D(tDiffuse, coord - offset);\r\n\r\n\t\tcolor = vec4(cr.r, cga.g, cb.b, cga.a);\r\n\t\tsnow = 200.0 * amount * vec4(rand(vec2(xs * seed, ys * seed * 50.0)) * 0.2);\r\n\t\tcolor += snow;\r\n\r\n\t} else {\r\n\r\n\t\tcolor = texture2D(tDiffuse, vUv);\r\n\r\n\t}\r\n\r\n\tgl_FragColor = color;\r\n\r\n}\r\n",W="varying vec2 vUv;\r\n\r\nvoid main() {\r\n\r\n\tvUv = uv;\r\n\tgl_Position = projectionMatrix * modelViewMatrix * vec4(position, 1.0);\r\n\r\n}\r\n",H=function(t){function n(){return u(this,n),v(this,(n.__proto__||Object.getPrototypeOf(n)).call(this,{type:"GlitchMaterial",uniforms:{tDiffuse:new e.Uniform(null),tPerturb:new e.Uniform(null),active:new e.Uniform(1),amount:new e.Uniform(.8),angle:new e.Uniform(.02),seed:new e.Uniform(.02),seedX:new e.Uniform(.02),seedY:new e.Uniform(.02),distortionX:new e.Uniform(.5),distortionY:new e.Uniform(.6),colS:new e.Uniform(.05)},fragmentShader:G,vertexShader:W,depthWrite:!1,depthTest:!1}))}return f(n,t),n}(e.ShaderMaterial),X="uniform sampler2D tDiffuse;\r\nuniform vec3 lightPosition;\r\n\r\nuniform float exposure;\r\nuniform float decay;\r\nuniform float density;\r\nuniform float weight;\r\nuniform float clampMax;\r\n\r\nvarying vec2 vUv;\r\n\r\nvoid main() {\r\n\r\n\tvec2 texCoord = vUv;\r\n\r\n\t// Calculate vector from pixel to light source in screen space.\r\n\tvec2 deltaTexCoord = texCoord - lightPosition.st;\r\n\tdeltaTexCoord *= 1.0 / NUM_SAMPLES_FLOAT * density;\r\n\r\n\t// A decreasing illumination factor.\r\n\tfloat illuminationDecay = 1.0;\r\n\r\n\tvec4 sample;\r\n\tvec4 color = vec4(0.0);\r\n\r\n\t// Estimate the probability of occlusion at each pixel by summing samples along a ray to the light source.\r\n\tfor(int i = 0; i < NUM_SAMPLES_INT; ++i) {\r\n\r\n\t\ttexCoord -= deltaTexCoord;\r\n\t\tsample = texture2D(tDiffuse, texCoord);\r\n\r\n\t\t// Apply sample attenuation scale/decay factors.\r\n\t\tsample *= illuminationDecay * weight;\r\n\r\n\t\tcolor += sample;\r\n\r\n\t\t// Update exponential decay factor.\r\n\t\tilluminationDecay *= decay;\r\n\r\n\t}\r\n\r\n\tgl_FragColor = clamp(color * exposure, 0.0, clampMax);\r\n\r\n}\r\n",V="varying vec2 vUv;\r\n\r\nvoid main() {\r\n\r\n\tvUv = uv;\r\n\tgl_Position = projectionMatrix * modelViewMatrix * vec4(position, 1.0);\r\n\r\n}\r\n",Y=function(t){function n(){return u(this,n),v(this,(n.__proto__||Object.getPrototypeOf(n)).call(this,{type:"GodRaysMaterial",defines:{NUM_SAMPLES_FLOAT:"60.0",NUM_SAMPLES_INT:"60"},uniforms:{tDiffuse:new e.Uniform(null),lightPosition:new e.Uniform(null),exposure:new e.Uniform(.6),decay:new e.Uniform(.93),density:new e.Uniform(.96),weight:new e.Uniform(.4),clampMax:new e.Uniform(1)},fragmentShader:X,vertexShader:V,depthWrite:!1,depthTest:!1}))}return f(n,t),n}(e.ShaderMaterial),q="uniform sampler2D tDiffuse;\r\nuniform float distinction;\r\nuniform vec2 range;\r\nuniform vec3 luminanceCoefficients;\r\n\r\nvarying vec2 vUv;\r\n\r\nvoid main() {\r\n\r\n\tvec4 texel = texture2D(tDiffuse, vUv);\r\n\tfloat v = dot(texel.rgb, luminanceCoefficients);\r\n\r\n\t#ifdef RANGE\r\n\r\n\t\tfloat low = step(range.x, v);\r\n\t\tfloat high = step(v, range.y);\r\n\r\n\t\t// Apply the mask.\r\n\t\tv *= low * high;\r\n\r\n\t#endif\r\n\r\n\tv = pow(abs(v), distinction);\r\n\r\n\t#ifdef COLOR\r\n\r\n\t\tgl_FragColor = vec4(texel.rgb * v, texel.a);\r\n\r\n\t#else\r\n\r\n\t\tgl_FragColor = vec4(v, v, v, texel.a);\r\n\r\n\t#endif\r\n\r\n}\r\n",K="varying vec2 vUv;\r\n\r\nvoid main() {\r\n\r\n\tvUv = uv;\r\n\tgl_Position = projectionMatrix * modelViewMatrix * vec4(position, 1.0);\r\n\r\n}\r\n",Z=function(t){function n(){var t=arguments.length>0&&void 0!==arguments[0]&&arguments[0],r=arguments.length>1&&void 0!==arguments[1]?arguments[1]:null;u(this,n);var i=v(this,(n.__proto__||Object.getPrototypeOf(n)).call(this,{type:"LuminosityMaterial",uniforms:{tDiffuse:new e.Uniform(null),distinction:new e.Uniform(1),range:new e.Uniform(null!==r?r:new e.Vector2),luminanceCoefficients:new e.Uniform(new e.Vector3(.2126,.7152,.0722))},fragmentShader:q,vertexShader:K}));return t&&(i.defines.COLOR="1"),null!==r&&(i.defines.RANGE="1"),i}return f(n,t),n}(e.ShaderMaterial),J="uniform sampler2D tDiffuse;\r\nuniform float granularity;\r\nuniform float dx;\r\nuniform float dy;\r\n\r\nvarying vec2 vUv;\r\n\r\nvoid main() {\r\n\r\n\tvec4 texel;\r\n\r\n\tif(granularity > 0.0) {\r\n\r\n\t\tvec2 coord = vec2(\r\n\t\t\tdx * (floor(vUv.x / dx) + 0.5),\r\n\t\t\tdy * (floor(vUv.y / dy) + 0.5)\r\n\t\t);\r\n\r\n\t\ttexel = texture2D(tDiffuse, coord);\r\n\r\n\t} else {\r\n\r\n\t\ttexel = texture2D(tDiffuse, vUv);\r\n\r\n\t}\r\n\r\n\tgl_FragColor = texel;\r\n\r\n}\r\n",Q="varying vec2 vUv;\r\n\r\nvoid main() {\r\n\r\n\tvUv = uv;\r\n\tgl_Position = projectionMatrix * modelViewMatrix * vec4(position, 1.0);\r\n\r\n}\r\n",_=function(t){function n(){return u(this,n),v(this,(n.__proto__||Object.getPrototypeOf(n)).call(this,{type:"PixelationMaterial",uniforms:{tDiffuse:new e.Uniform(null),granularity:new e.Uniform(1),resolution:new e.Uniform(new e.Vector2(1,1)),dx:new e.Uniform(1),dy:new e.Uniform(1)},fragmentShader:J,vertexShader:Q,depthWrite:!1,depthTest:!1}))}return f(n,t),c(n,[{key:"setResolution",value:function(e,t){this.uniforms.resolution.value.set(e,t),this.granularity=this.granularity}},{key:"granularity",get:function(){return this.uniforms.granularity.value},set:function(e){var t=this.uniforms,n=t.resolution.value;t.granularity.value=e,t.dx.value=e/n.x,t.dy.value=e/n.y}}]),n}(e.ShaderMaterial),$="#include \r\n\r\nuniform sampler2D tDiffuse;\r\nuniform vec2 center;\r\nuniform float aspect;\r\nuniform float waveSize;\r\nuniform float radius;\r\nuniform float maxRadius;\r\nuniform float amplitude;\r\n\r\nvarying vec2 vUv;\r\nvarying float vSize;\r\n\r\nvoid main() {\r\n\r\n\tvec2 aspectCorrection = vec2(aspect, 1.0);\r\n\r\n\tvec2 difference = vUv * aspectCorrection - center * aspectCorrection;\r\n\tfloat distance = sqrt(dot(difference, difference)) * vSize;\r\n\r\n\tvec2 displacement = vec2(0.0);\r\n\r\n\tif(distance > radius) {\r\n\r\n\t\tif(distance < radius + waveSize) {\r\n\r\n\t\t\tfloat angle = (distance - radius) * PI2 / waveSize;\r\n\t\t\tfloat cosSin = (1.0 - cos(angle)) * 0.5;\r\n\r\n\t\t\tfloat extent = maxRadius + waveSize;\r\n\t\t\tfloat decay = max(extent - distance * distance, 0.0) / extent;\r\n\r\n\t\t\tdisplacement = ((cosSin * amplitude * difference) / distance) * decay;\r\n\r\n\t\t}\r\n\r\n\t}\r\n\r\n\tgl_FragColor = texture2D(tDiffuse, vUv - displacement);\r\n\r\n}\r\n",ee="uniform float size;\r\nuniform float scale;\r\nuniform float cameraDistance;\r\n\r\nvarying vec2 vUv;\r\nvarying float vSize;\r\n\r\nvoid main() {\r\n\r\n\tvUv = uv;\r\n\tvSize = (0.1 * cameraDistance) / size;\r\n\tgl_Position = projectionMatrix * modelViewMatrix * vec4(position, 1.0);\r\n\r\n}\r\n",te=function(t){function n(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};return u(this,n),void 0===t.maxRadius&&(t.maxRadius=1),void 0===t.waveSize&&(t.waveSize=.2),void 0===t.amplitude&&(t.amplitude=.05),v(this,(n.__proto__||Object.getPrototypeOf(n)).call(this,{type:"ShockWaveMaterial",uniforms:{tDiffuse:new e.Uniform(null),center:new e.Uniform(new e.Vector2(.5,.5)),aspect:new e.Uniform(1),cameraDistance:new e.Uniform(1),size:new e.Uniform(1),radius:new e.Uniform(-t.waveSize),maxRadius:new e.Uniform(t.maxRadius),waveSize:new e.Uniform(t.waveSize),amplitude:new e.Uniform(t.amplitude)},fragmentShader:$,vertexShader:ee,depthWrite:!1,depthTest:!1}))}return f(n,t),n}(e.ShaderMaterial),ne="uniform sampler2D tDiffuse;\r\nuniform sampler2D tWeights;\r\n\r\nuniform vec2 texelSize;\r\n\r\nvarying vec2 vUv;\r\nvarying vec4 vOffset;\r\n\r\nvoid main() {\r\n\r\n\t// Fetch the blending weights for current pixel.\r\n\tvec4 a;\r\n\ta.xz = texture2D(tWeights, vUv).xz;\r\n\ta.y = texture2D(tWeights, vOffset.zw).g;\r\n\ta.w = texture2D(tWeights, vOffset.xy).a;\r\n\r\n\tvec4 color;\r\n\r\n\t// Check if there is any blending weight with a value greater than 0.0.\r\n\tif(dot(a, vec4(1.0)) < 1e-5) {\r\n\r\n\t\tcolor = texture2D(tDiffuse, vUv, 0.0);\r\n\r\n\t} else {\r\n\r\n\t\t/* Up to four lines can be crossing a pixel (one through each edge). We favor\r\n\t\t * blending by choosing the line with the maximum weight for each direction.\r\n\t\t */\r\n\r\n\t\tvec2 offset;\r\n\t\toffset.x = a.a > a.b ? a.a : -a.b; // Left vs. right.\r\n\t\toffset.y = a.g > a.r ? -a.g : a.r; // Top vs. bottom (changed signs).\r\n\r\n\t\t// Then we go in the direction that has the maximum weight (horizontal vs. vertical).\r\n\t\tif(abs(offset.x) > abs(offset.y)) {\r\n\r\n\t\t\toffset.y = 0.0;\r\n\r\n\t\t} else {\r\n\r\n\t\t\toffset.x = 0.0;\r\n\r\n\t\t}\r\n\r\n\t\t// Fetch the opposite color and lerp by hand.\r\n\t\tcolor = texture2D(tDiffuse, vUv, 0.0);\r\n\t\tvec2 coord = vUv + sign(offset) * texelSize;\r\n\t\tvec4 oppositeColor = texture2D(tDiffuse, coord, 0.0);\r\n\t\tfloat s = abs(offset.x) > abs(offset.y) ? abs(offset.x) : abs(offset.y);\r\n\r\n\t\t// Gamma correction.\r\n\t\tcolor.rgb = pow(abs(color.rgb), vec3(2.2));\r\n\t\toppositeColor.rgb = pow(abs(oppositeColor.rgb), vec3(2.2));\r\n\t\tcolor = mix(color, oppositeColor, s);\r\n\t\tcolor.rgb = pow(abs(color.rgb), vec3(1.0 / 2.2));\r\n\r\n\t}\r\n\r\n\tgl_FragColor = color;\r\n\r\n}\r\n",re="uniform vec2 texelSize;\r\n\r\nvarying vec2 vUv;\r\nvarying vec4 vOffset;\r\n\r\nvoid main() {\r\n\r\n\tvUv = uv;\r\n\r\n\tvOffset = uv.xyxy + texelSize.xyxy * vec4(1.0, 0.0, 0.0, -1.0); // Changed sign in W component.\r\n\r\n\tgl_Position = projectionMatrix * modelViewMatrix * vec4(position, 1.0);\r\n\r\n}\r\n",ie=function(t){function n(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:new e.Vector2;return u(this,n),v(this,(n.__proto__||Object.getPrototypeOf(n)).call(this,{type:"SMAABlendMaterial",uniforms:{tDiffuse:new e.Uniform(null),tWeights:new e.Uniform(null),texelSize:new e.Uniform(t)},fragmentShader:ne,vertexShader:re,depthWrite:!1,depthTest:!1}))}return f(n,t),n}(e.ShaderMaterial),ae="uniform sampler2D tDiffuse;\r\n\r\nvarying vec2 vUv;\r\nvarying vec4 vOffset[3];\r\n\r\nvoid main() {\r\n\r\n\tconst vec2 THRESHOLD = vec2(EDGE_THRESHOLD);\r\n\r\n\t// Calculate color deltas.\r\n\tvec4 delta;\r\n\tvec3 c = texture2D(tDiffuse, vUv).rgb;\r\n\r\n\tvec3 cLeft = texture2D(tDiffuse, vOffset[0].xy).rgb;\r\n\tvec3 t = abs(c - cLeft);\r\n\tdelta.x = max(max(t.r, t.g), t.b);\r\n\r\n\tvec3 cTop = texture2D(tDiffuse, vOffset[0].zw).rgb;\r\n\tt = abs(c - cTop);\r\n\tdelta.y = max(max(t.r, t.g), t.b);\r\n\r\n\t// We do the usual threshold.\r\n\tvec2 edges = step(THRESHOLD, delta.xy);\r\n\r\n\t// Then discard if there is no edge.\r\n\tif(dot(edges, vec2(1.0)) == 0.0) {\r\n\r\n\t\tdiscard;\r\n\r\n\t}\r\n\r\n\t// Calculate right and bottom deltas.\r\n\tvec3 cRight = texture2D(tDiffuse, vOffset[1].xy).rgb;\r\n\tt = abs(c - cRight);\r\n\tdelta.z = max(max(t.r, t.g), t.b);\r\n\r\n\tvec3 cBottom = texture2D(tDiffuse, vOffset[1].zw).rgb;\r\n\tt = abs(c - cBottom);\r\n\tdelta.w = max(max(t.r, t.g), t.b);\r\n\r\n\t// Calculate the maximum delta in the direct neighborhood.\r\n\tfloat maxDelta = max(max(max(delta.x, delta.y), delta.z), delta.w);\r\n\r\n\t// Calculate left-left and top-top deltas.\r\n\tvec3 cLeftLeft = texture2D(tDiffuse, vOffset[2].xy).rgb;\r\n\tt = abs(c - cLeftLeft);\r\n\tdelta.z = max(max(t.r, t.g), t.b);\r\n\r\n\tvec3 cTopTop = texture2D(tDiffuse, vOffset[2].zw).rgb;\r\n\tt = abs(c - cTopTop);\r\n\tdelta.w = max(max(t.r, t.g), t.b);\r\n\r\n\t// Calculate the final maximum delta.\r\n\tmaxDelta = max(max(maxDelta, delta.z), delta.w);\r\n\r\n\t// Local contrast adaptation in action.\r\n\tedges.xy *= step(0.5 * maxDelta, delta.xy);\r\n\r\n\tgl_FragColor = vec4(edges, 0.0, 0.0);\r\n\r\n}\r\n",oe="uniform vec2 texelSize;\r\n\r\nvarying vec2 vUv;\r\nvarying vec4 vOffset[3];\r\n\r\nvoid main() {\r\n\r\n\tvUv = uv;\r\n\r\n\tvOffset[0] = uv.xyxy + texelSize.xyxy * vec4(-1.0, 0.0, 0.0, 1.0); // Changed sign in W component.\r\n\tvOffset[1] = uv.xyxy + texelSize.xyxy * vec4(1.0, 0.0, 0.0, -1.0); // Changed sign in W component.\r\n\tvOffset[2] = uv.xyxy + texelSize.xyxy * vec4(-2.0, 0.0, 0.0, 2.0); // Changed sign in W component.\r\n\r\n\tgl_Position = projectionMatrix * modelViewMatrix * vec4(position, 1.0);\r\n\r\n}\r\n",se=function(t){function n(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:new e.Vector2;return u(this,n),v(this,(n.__proto__||Object.getPrototypeOf(n)).call(this,{type:"SMAAColorEdgesMaterial",defines:{EDGE_THRESHOLD:"0.1"},uniforms:{tDiffuse:new e.Uniform(null),texelSize:new e.Uniform(t)},fragmentShader:ae,vertexShader:oe,depthWrite:!1,depthTest:!1}))}return f(n,t),n}(e.ShaderMaterial),le="",ue="",ce="#define sampleLevelZeroOffset(t, coord, offset) texture2D(t, coord + float(offset) * texelSize, 0.0)\r\n\r\nuniform sampler2D tDiffuse;\r\nuniform sampler2D tArea;\r\nuniform sampler2D tSearch;\r\n\r\nuniform vec2 texelSize;\r\n\r\nvarying vec2 vUv;\r\nvarying vec4 vOffset[3];\r\nvarying vec2 vPixCoord;\r\n\r\nvec2 round(vec2 x) {\r\n\r\n\treturn sign(x) * floor(abs(x) + 0.5);\r\n\r\n}\r\n\r\nfloat searchLength(vec2 e, float bias, float scale) {\r\n\r\n\t// Not required if tSearch accesses are set to point.\r\n\t// const vec2 SEARCH_TEX_PIXEL_SIZE = 1.0 / vec2(66.0, 33.0);\r\n\t// e = vec2(bias, 0.0) + 0.5 * SEARCH_TEX_PIXEL_SIZE + e * vec2(scale, 1.0) * vec2(64.0, 32.0) * SEARCH_TEX_PIXEL_SIZE;\r\n\r\n\te.r = bias + e.r * scale;\r\n\r\n\treturn 255.0 * texture2D(tSearch, e, 0.0).r;\r\n\r\n}\r\n\r\nfloat searchXLeft(vec2 texCoord, float end) {\r\n\r\n\t/* @PSEUDO_GATHER4\r\n\t * This texCoord has been offset by (-0.25, -0.125) in the vertex shader to\r\n\t * sample between edge, thus fetching four edges in a row.\r\n\t * Sampling with different offsets in each direction allows to disambiguate\r\n\t * which edges are active from the four fetched ones.\r\n\t */\r\n\r\n\tvec2 e = vec2(0.0, 1.0);\r\n\r\n\tfor(int i = 0; i < SMAA_MAX_SEARCH_STEPS_INT; ++i) {\r\n\r\n\t\te = texture2D(tDiffuse, texCoord, 0.0).rg;\r\n\t\ttexCoord -= vec2(2.0, 0.0) * texelSize;\r\n\r\n\t\tif(!(texCoord.x > end && e.g > 0.8281 && e.r == 0.0)) { break; }\r\n\r\n\t}\r\n\r\n\t// Correct the previously applied offset (-0.25, -0.125).\r\n\ttexCoord.x += 0.25 * texelSize.x;\r\n\r\n\t// The searches are biased by 1, so adjust the coords accordingly.\r\n\ttexCoord.x += texelSize.x;\r\n\r\n\t// Disambiguate the length added by the last step.\r\n\ttexCoord.x += 2.0 * texelSize.x; // Undo last step.\r\n\ttexCoord.x -= texelSize.x * searchLength(e, 0.0, 0.5);\r\n\r\n\treturn texCoord.x;\r\n\r\n}\r\n\r\nfloat searchXRight(vec2 texCoord, float end) {\r\n\r\n\tvec2 e = vec2(0.0, 1.0);\r\n\r\n\tfor(int i = 0; i < SMAA_MAX_SEARCH_STEPS_INT; ++i) {\r\n\r\n\t\te = texture2D(tDiffuse, texCoord, 0.0).rg;\r\n\t\ttexCoord += vec2(2.0, 0.0) * texelSize;\r\n\r\n\t\tif(!(texCoord.x < end && e.g > 0.8281 && e.r == 0.0)) { break; }\r\n\r\n\t}\r\n\r\n\ttexCoord.x -= 0.25 * texelSize.x;\r\n\ttexCoord.x -= texelSize.x;\r\n\ttexCoord.x -= 2.0 * texelSize.x;\r\n\ttexCoord.x += texelSize.x * searchLength(e, 0.5, 0.5);\r\n\r\n\treturn texCoord.x;\r\n\r\n}\r\n\r\nfloat searchYUp(vec2 texCoord, float end) {\r\n\r\n\tvec2 e = vec2(1.0, 0.0);\r\n\r\n\tfor(int i = 0; i < SMAA_MAX_SEARCH_STEPS_INT; ++i) {\r\n\r\n\t\te = texture2D(tDiffuse, texCoord, 0.0).rg;\r\n\t\ttexCoord += vec2(0.0, 2.0) * texelSize; // Changed sign.\r\n\r\n\t\tif(!(texCoord.y > end && e.r > 0.8281 && e.g == 0.0)) { break; }\r\n\r\n\t}\r\n\r\n\ttexCoord.y -= 0.25 * texelSize.y; // Changed sign.\r\n\ttexCoord.y -= texelSize.y; // Changed sign.\r\n\ttexCoord.y -= 2.0 * texelSize.y; // Changed sign.\r\n\ttexCoord.y += texelSize.y * searchLength(e.gr, 0.0, 0.5); // Changed sign.\r\n\r\n\treturn texCoord.y;\r\n\r\n}\r\n\r\nfloat searchYDown(vec2 texCoord, float end) {\r\n\r\n\tvec2 e = vec2(1.0, 0.0);\r\n\r\n\tfor(int i = 0; i < SMAA_MAX_SEARCH_STEPS_INT; ++i ) {\r\n\r\n\t\te = texture2D(tDiffuse, texCoord, 0.0).rg;\r\n\t\ttexCoord -= vec2(0.0, 2.0) * texelSize; // Changed sign.\r\n\r\n\t\tif(!(texCoord.y < end && e.r > 0.8281 && e.g == 0.0)) { break; }\r\n\r\n\t}\r\n\r\n\ttexCoord.y += 0.25 * texelSize.y; // Changed sign.\r\n\ttexCoord.y += texelSize.y; // Changed sign.\r\n\ttexCoord.y += 2.0 * texelSize.y; // Changed sign.\r\n\ttexCoord.y -= texelSize.y * searchLength(e.gr, 0.5, 0.5); // Changed sign.\r\n\r\n\treturn texCoord.y;\r\n\r\n}\r\n\r\nvec2 area(vec2 dist, float e1, float e2, float offset) {\r\n\r\n\t// Rounding prevents precision errors of bilinear filtering.\r\n\tvec2 texCoord = SMAA_AREATEX_MAX_DISTANCE * round(4.0 * vec2(e1, e2)) + dist;\r\n\r\n\t// Scale and bias for texel space translation.\r\n\ttexCoord = SMAA_AREATEX_PIXEL_SIZE * texCoord + (0.5 * SMAA_AREATEX_PIXEL_SIZE);\r\n\r\n\t// Move to proper place, according to the subpixel offset.\r\n\ttexCoord.y += SMAA_AREATEX_SUBTEX_SIZE * offset;\r\n\r\n\treturn texture2D(tArea, texCoord, 0.0).rg;\r\n\r\n}\r\n\r\nvoid main() {\r\n\r\n\tvec4 weights = vec4(0.0);\r\n\tvec4 subsampleIndices = vec4(0.0);\r\n\tvec2 e = texture2D(tDiffuse, vUv).rg;\r\n\r\n\tif(e.g > 0.0) {\r\n\r\n\t\t// Edge at north.\r\n\t\tvec2 d;\r\n\r\n\t\t// Find the distance to the left.\r\n\t\tvec2 coords;\r\n\t\tcoords.x = searchXLeft(vOffset[0].xy, vOffset[2].x);\r\n\t\tcoords.y = vOffset[1].y; // vOffset[1].y = vUv.y - 0.25 * texelSize.y (@CROSSING_OFFSET)\r\n\t\td.x = coords.x;\r\n\r\n\t\t/* Now fetch the left crossing edges, two at a time using bilinear filtering.\r\n\t\tSampling at -0.25 (see @CROSSING_OFFSET) enables to discern what value each edge has. */\r\n\r\n\t\tfloat e1 = texture2D(tDiffuse, coords, 0.0).r;\r\n\r\n\t\t// Find the distance to the right.\r\n\t\tcoords.x = searchXRight(vOffset[0].zw, vOffset[2].y);\r\n\t\td.y = coords.x;\r\n\r\n\t\t// Translate distances to pixel units for better interleave arithmetic and memory accesses.\r\n\t\td = d / texelSize.x - vPixCoord.x;\r\n\r\n\t\t// The area below needs a sqrt, as the areas texture is compressed quadratically.\r\n\t\tvec2 sqrtD = sqrt(abs(d));\r\n\r\n\t\t// Fetch the right crossing edges.\r\n\t\tcoords.y -= texelSize.y; // WebGL port note: Added.\r\n\t\tfloat e2 = sampleLevelZeroOffset(tDiffuse, coords, ivec2(1, 0)).r;\r\n\r\n\t\t// Pattern recognised, now get the actual area.\r\n\t\tweights.rg = area(sqrtD, e1, e2, subsampleIndices.y);\r\n\r\n\t}\r\n\r\n\tif(e.r > 0.0) {\r\n\r\n\t\t// Edge at west.\r\n\t\tvec2 d;\r\n\r\n\t\t// Find the distance to the top.\r\n\t\tvec2 coords;\r\n\r\n\t\tcoords.y = searchYUp(vOffset[1].xy, vOffset[2].z);\r\n\t\tcoords.x = vOffset[0].x; // vOffset[1].x = vUv.x - 0.25 * texelSize.x;\r\n\t\td.x = coords.y;\r\n\r\n\t\t// Fetch the top crossing edges.\r\n\t\tfloat e1 = texture2D(tDiffuse, coords, 0.0).g;\r\n\r\n\t\t// Find the distance to the bottom.\r\n\t\tcoords.y = searchYDown(vOffset[1].zw, vOffset[2].w);\r\n\t\td.y = coords.y;\r\n\r\n\t\t// Distances in pixel units.\r\n\t\td = d / texelSize.y - vPixCoord.y;\r\n\r\n\t\t// The area below needs a sqrt, as the areas texture is compressed quadratically.\r\n\t\tvec2 sqrtD = sqrt(abs(d));\r\n\r\n\t\t// Fetch the bottom crossing edges.\r\n\t\tcoords.y -= texelSize.y; // WebGL port note: Added.\r\n\t\tfloat e2 = sampleLevelZeroOffset(tDiffuse, coords, ivec2(0, 1)).g;\r\n\r\n\t\t// Get the area for this direction.\r\n\t\tweights.ba = area(sqrtD, e1, e2, subsampleIndices.x);\r\n\r\n\t}\r\n\r\n\tgl_FragColor = weights;\r\n\r\n}\r\n",de="uniform vec2 texelSize;\r\n\r\nvarying vec2 vUv;\r\nvarying vec4 vOffset[3];\r\nvarying vec2 vPixCoord;\r\n\r\nvoid main() {\r\n\r\n\tvUv = uv;\r\n\r\n\tvPixCoord = uv / texelSize;\r\n\r\n\t// Offsets for the searches (see @PSEUDO_GATHER4).\r\n\tvOffset[0] = uv.xyxy + texelSize.xyxy * vec4(-0.25, 0.125, 1.25, 0.125); // Changed sign in Y and W components.\r\n\tvOffset[1] = uv.xyxy + texelSize.xyxy * vec4(-0.125, 0.25, -0.125, -1.25); //Changed sign in Y and W components.\r\n\r\n\t// This indicates the ends of the loops.\r\n\tvOffset[2] = vec4(vOffset[0].xz, vOffset[1].yw) + vec4(-2.0, 2.0, -2.0, 2.0) * texelSize.xxyy * SMAA_MAX_SEARCH_STEPS_FLOAT;\r\n\r\n\tgl_Position = projectionMatrix * modelViewMatrix * vec4(position, 1.0);\r\n\r\n}\r\n",fe=function(t){function n(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:new e.Vector2;u(this,n);var r=v(this,(n.__proto__||Object.getPrototypeOf(n)).call(this,{type:"SMAAWeightsMaterial",defines:{SMAA_MAX_SEARCH_STEPS_INT:"8",SMAA_MAX_SEARCH_STEPS_FLOAT:"8.0",SMAA_AREATEX_MAX_DISTANCE:"16.0",SMAA_AREATEX_PIXEL_SIZE:"(1.0 / vec2(160.0, 560.0))",SMAA_AREATEX_SUBTEX_SIZE:"(1.0 / 7.0)"},uniforms:{tDiffuse:new e.Uniform(null),tArea:new e.Uniform(null),tSearch:new e.Uniform(null),texelSize:new e.Uniform(t)},fragmentShader:ce,vertexShader:de,depthWrite:!1,depthTest:!1}));return r.areaImage=le,r.searchImage=ue,r}return f(n,t),n}(e.ShaderMaterial),ve="uniform sampler2D tDiffuse;\r\nuniform float middleGrey;\r\nuniform float maxLuminance;\r\nuniform vec3 luminanceCoefficients;\r\n\r\n#ifdef ADAPTED_LUMINANCE\r\n\r\n\tuniform sampler2D luminanceMap;\r\n\r\n#else\r\n\r\n\tuniform float averageLuminance;\r\n\r\n#endif\r\n\r\nvarying vec2 vUv;\r\n\r\nvec3 toneMap(vec3 c) {\r\n\r\n\t#ifdef ADAPTED_LUMINANCE\r\n\r\n\t\t// Get the calculated average luminance by sampling the center.\r\n\t\tfloat lumAvg = texture2D(luminanceMap, vec2(0.5)).r;\r\n\r\n\t#else\r\n\r\n\t\tfloat lumAvg = averageLuminance;\r\n\r\n\t#endif\r\n\r\n\t// Calculate the luminance of the current pixel.\r\n\tfloat lumPixel = dot(c, luminanceCoefficients);\r\n\r\n\t// Apply the modified operator (Reinhard Eq. 4).\r\n\tfloat lumScaled = (lumPixel * middleGrey) / lumAvg;\r\n\r\n\tfloat lumCompressed = (lumScaled * (1.0 + (lumScaled / (maxLuminance * maxLuminance)))) / (1.0 + lumScaled);\r\n\r\n\treturn lumCompressed * c;\r\n\r\n}\r\n\r\nvoid main() {\r\n\r\n\tvec4 texel = texture2D(tDiffuse, vUv);\r\n\tgl_FragColor = vec4(toneMap(texel.rgb), texel.a);\r\n\r\n}\r\n",he="varying vec2 vUv;\r\n\r\nvoid main() {\r\n\r\n\tvUv = uv;\r\n\tgl_Position = projectionMatrix * modelViewMatrix * vec4(position, 1.0);\r\n\r\n}\r\n",me=function(t){function n(){return u(this,n),v(this,(n.__proto__||Object.getPrototypeOf(n)).call(this,{type:"ToneMappingMaterial",uniforms:{tDiffuse:new e.Uniform(null),luminanceMap:new e.Uniform(null),averageLuminance:new e.Uniform(1),luminanceCoefficients:new e.Uniform(new e.Vector3(.2126,.7152,.0722)),maxLuminance:new e.Uniform(16),middleGrey:new e.Uniform(.6)},fragmentShader:ve,vertexShader:he,depthWrite:!1,depthTest:!1}))}return f(n,t),n}(e.ShaderMaterial),pe=function(){function t(){var n=arguments.length>0&&void 0!==arguments[0]?arguments[0]:new e.Scene,r=arguments.length>1&&void 0!==arguments[1]?arguments[1]:new e.OrthographicCamera(-1,1,1,-1,0,1),i=arguments.length>2&&void 0!==arguments[2]?arguments[2]:new e.Mesh(new e.PlaneBufferGeometry(2,2),null);u(this,t),this.name="Pass",this.scene=n,this.camera=r,this.quad=i,null!==this.quad&&(this.quad.frustumCulled=!1,null!==this.scene&&this.scene.add(this.quad)),this.needsSwap=!1,this.enabled=!0,this.renderToScreen=!1}return c(t,[{key:"render",value:function(e,t,n,r,i){throw new Error("Render method not implemented!")}},{key:"setSize",value:function(e,t){}},{key:"initialise",value:function(e,t){}},{key:"dispose",value:function(){var e=Object.keys(this),t=void 0,n=!0,r=!1,i=void 0;try{for(var a,o=e[Symbol.iterator]();!(n=(a=o.next()).done);n=!0)null!==this[t=a.value]&&"function"==typeof this[t].dispose&&(this[t].dispose(),this[t]=null)}catch(e){r=!0,i=e}finally{try{!n&&o.return&&o.return()}finally{if(r)throw i}}}}]),t}(),ge=function(t){function n(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};u(this,n);var r=v(this,(n.__proto__||Object.getPrototypeOf(n)).call(this));return r.name="BlurPass",r.needsSwap=!0,r.renderTargetX=new e.WebGLRenderTarget(1,1,{minFilter:e.LinearFilter,magFilter:e.LinearFilter,stencilBuffer:!1,depthBuffer:!1}),r.renderTargetX.texture.name="Blur.TargetX",r.renderTargetX.texture.generateMipmaps=!1,r.renderTargetY=r.renderTargetX.clone(),r.renderTargetY.texture.name="Blur.TargetY",r.resolutionScale=void 0!==t.resolutionScale?t.resolutionScale:.5,r.convolutionMaterial=new T,r.kernelSize=t.kernelSize,r.quad.material=r.convolutionMaterial,r}return f(n,pe),c(n,[{key:"render",value:function(e,t,n){var r=this.scene,i=this.camera,a=this.renderTargetX,o=this.renderTargetY,s=this.convolutionMaterial,l=s.uniforms,u=s.getKernel(),c=t,d=void 0,f=void 0,v=void 0;for(f=0,v=u.length-1;f0&&void 0!==arguments[0]?arguments[0]:C.LARGE;this.convolutionMaterial.kernelSize=e}}]),n}(),xe=function(t){function n(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};u(this,n);var r=v(this,(n.__proto__||Object.getPrototypeOf(n)).call(this));return r.name="BloomPass",r.needsSwap=!0,r.blurPass=new ge(t),r.renderTarget=new e.WebGLRenderTarget(1,1,{minFilter:e.LinearFilter,magFilter:e.LinearFilter,stencilBuffer:!1,depthBuffer:!1}),r.renderTarget.texture.name="Bloom.Target",r.renderTarget.texture.generateMipmaps=!1,r.combineMaterial=new S(void 0===t.screenMode||t.screenMode),r.intensity=t.intensity,r.luminosityMaterial=new Z(!0),r.distinction=t.distinction,r}return f(n,pe),c(n,[{key:"render",value:function(e,t,n){var r=this.quad,i=this.scene,a=this.camera,o=this.blurPass,s=this.luminosityMaterial,l=this.combineMaterial,u=this.renderTarget;r.material=s,s.uniforms.tDiffuse.value=t.texture,e.render(i,a,u),o.render(e,u,u),r.material=l,l.uniforms.texture1.value=t.texture,l.uniforms.texture2.value=u.texture,e.render(i,a,this.renderToScreen?null:n)}},{key:"initialise",value:function(t,n){this.blurPass.initialise(t,n),n||(this.renderTarget.texture.format=e.RGBFormat)}},{key:"setSize",value:function(e,t){this.blurPass.setSize(e,t),e=this.blurPass.width,t=this.blurPass.height,this.renderTarget.setSize(e,t)}},{key:"resolutionScale",get:function(){return this.blurPass.resolutionScale},set:function(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:.5;this.blurPass.resolutionScale=e}},{key:"kernelSize",get:function(){return this.blurPass.kernelSize},set:function(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:C.LARGE;this.blurPass.kernelSize=e}},{key:"intensity",get:function(){return this.combineMaterial.uniforms.opacity2.value},set:function(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:1;this.combineMaterial.uniforms.opacity2.value=e}},{key:"distinction",get:function(){return this.luminosityMaterial.uniforms.distinction.value},set:function(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:1;this.luminosityMaterial.uniforms.distinction.value=e}}]),n}(),ye=function(e){function t(e){var n=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};u(this,t);var r=v(this,(t.__proto__||Object.getPrototypeOf(t)).call(this));return r.name="BokehPass",r.needsSwap=!0,r.bokehMaterial=new g(e,n),r.quad.material=r.bokehMaterial,r}return f(t,pe),c(t,[{key:"render",value:function(e,t,n){this.bokehMaterial.uniforms.tDiffuse.value=t.texture,this.bokehMaterial.uniforms.tDepth.value=t.depthTexture,e.render(this.scene,this.camera,this.renderToScreen?null:n)}},{key:"setSize",value:function(e,t){this.bokehMaterial.uniforms.aspect.value=e/t}}]),t}(),Me=function(e){function t(e){var n=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};u(this,t);var r=v(this,(t.__proto__||Object.getPrototypeOf(t)).call(this));return r.name="Bokeh2Pass",r.needsSwap=!0,r.bokehMaterial=new M(e,n),r.quad.material=r.bokehMaterial,r}return f(t,pe),c(t,[{key:"render",value:function(e,t,n){this.bokehMaterial.uniforms.tDiffuse.value=t.texture,this.bokehMaterial.uniforms.tDepth.value=t.depthTexture,e.render(this.scene,this.camera,this.renderToScreen?null:n)}},{key:"setSize",value:function(e,t){this.bokehMaterial.setTexelSize(1/e,1/t)}}]),t}(),we=function(e){function t(){u(this,t);var e=v(this,(t.__proto__||Object.getPrototypeOf(t)).call(this,null,null,null));return e.name="ClearMaskPass",e}return f(t,pe),c(t,[{key:"render",value:function(e){e.state.buffers.stencil.setTest(!1)}}]),t}(),be=new e.Color,Se=function(e){function t(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};u(this,t);var n=v(this,(t.__proto__||Object.getPrototypeOf(t)).call(this,null,null,null));return n.name="ClearPass",n.clearColor=void 0!==e.clearColor?e.clearColor:null,n.clearAlpha=void 0!==e.clearAlpha?e.clearAlpha:0,n}return f(t,pe),c(t,[{key:"render",value:function(e,t){var n=this.clearColor,r=void 0;null!==n&&(be.copy(e.getClearColor()),r=e.getClearAlpha(),e.setClearColor(n,this.clearAlpha)),e.setRenderTarget(this.renderToScreen?null:t),e.clear(),null!==n&&e.setClearColor(be,r)}}]),t}(),De=function(e){function t(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};u(this,t);var n=v(this,(t.__proto__||Object.getPrototypeOf(t)).call(this));return n.name="DotScreenPass",n.needsSwap=!0,n.material=new j(e.average),void 0!==e.angle&&(n.material.uniforms.angle.value=e.angle),void 0!==e.scale&&(n.material.uniforms.scale.value=e.scale),void 0!==e.intensity&&(n.material.uniforms.intensity.value=e.intensity),n.quad.material=n.material,n}return f(t,pe),c(t,[{key:"render",value:function(e,t,n){this.material.uniforms.tDiffuse.value=t.texture,e.render(this.scene,this.camera,this.renderToScreen?null:n)}},{key:"setSize",value:function(e,t){e=Math.max(1,e),t=Math.max(1,t),this.material.uniforms.offsetRepeat.value.z=e,this.material.uniforms.offsetRepeat.value.w=t}}]),t}(),Pe=function(e){function t(e){u(this,t);var n=v(this,(t.__proto__||Object.getPrototypeOf(t)).call(this));return n.name="DepthPass",n.needsSwap=!0,n.depthMaterial=new z(e),n.quad.material=n.depthMaterial,n}return f(t,pe),c(t,[{key:"render",value:function(e,t,n){this.depthMaterial.uniforms.tDepth.value=t.depthTexture,e.render(this.scene,this.camera,this.renderToScreen?null:n)}}]),t}(),Te=function(e){function t(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};u(this,t);var n=v(this,(t.__proto__||Object.getPrototypeOf(t)).call(this));return n.name="FilmPass",n.needsSwap=!0,n.material=new I(e),n.quad.material=n.material,n.scanlineDensity=void 0===e.scanlineDensity?1.25:e.scanlineDensity,n}return f(t,pe),c(t,[{key:"render",value:function(e,t,n,r){this.material.uniforms.tDiffuse.value=t.texture,this.material.uniforms.time.value+=r,e.render(this.scene,this.camera,this.renderToScreen?null:n)}},{key:"setSize",value:function(e,t){this.material.uniforms.scanlineCount.value=Math.round(t*this.scanlineDensity)}}]),t}(),Ae=function(t){function n(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};u(this,n);var t=v(this,(n.__proto__||Object.getPrototypeOf(n)).call(this));return t.name="GlitchPass",t.needsSwap=!0,t.material=new H,t.quad.material=t.material,t.texture=null,t.perturbMap=void 0!==e.perturbMap?e.perturbMap:t.generatePerturbMap(e.dtSize),t.perturbMap.name="Glitch.Perturbation",t.perturbMap.generateMipmaps=!1,t.mode=Ce.SPORADIC,t.counter=0,t.breakPoint=r(120,240),t}return f(n,pe),c(n,[{key:"generatePerturbMap",value:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:64,n=t*t,r=new Float32Array(3*n),i=this.perturbMap,a=void 0,o=void 0;for(a=0;a2&&void 0!==arguments[2]?arguments[2]:{};u(this,t);var i=v(this,(t.__proto__||Object.getPrototypeOf(t)).call(this,e,n,null));return i.name="RenderPass",i.clearPass=new Se(r),i.overrideMaterial=void 0!==r.overrideMaterial?r.overrideMaterial:null,i.clearDepth=void 0!==r.clearDepth&&r.clearDepth,i.clear=void 0===r.clear||r.clear,i}return f(t,pe),c(t,[{key:"render",value:function(e,t){var n=this.scene,r=this.renderToScreen?null:t;this.clear?this.clearPass.render(e,r):this.clearDepth&&(e.setRenderTarget(r),e.clearDepth()),n.overrideMaterial=this.overrideMaterial,e.render(n,this.camera,r),n.overrideMaterial=null}}]),t}(),Le=function(t){function n(t,r,i){var a=arguments.length>3&&void 0!==arguments[3]?arguments[3]:{};u(this,n);var o=v(this,(n.__proto__||Object.getPrototypeOf(n)).call(this));return o.name="GodRaysPass",o.needsSwap=!0,o.lightScene=new e.Scene,o.mainScene=t,o.mainCamera=r,o.renderPassLight=new Oe(o.lightScene,o.mainCamera),o.renderPassMask=new Oe(o.mainScene,o.mainCamera,{overrideMaterial:new e.MeshBasicMaterial({color:0}),clearColor:new e.Color(0)}),o.renderPassMask.clear=!1,o.blurPass=new ge(a),o.renderTargetX=new e.WebGLRenderTarget(1,1,{minFilter:e.LinearFilter,magFilter:e.LinearFilter,stencilBuffer:!1,depthBuffer:!1}),o.renderTargetX.texture.name="GodRays.TargetX",o.renderTargetX.texture.generateMipmaps=!1,o.renderTargetY=o.renderTargetX.clone(),o.renderTargetY.texture.name="GodRays.TargetY",o.renderTargetMask=new e.WebGLRenderTarget(1,1,{minFilter:e.LinearFilter,magFilter:e.LinearFilter}),o.renderTargetMask.texture.name="GodRays.Mask",o.renderTargetMask.texture.generateMipmaps=!1,o.lightSource=i,o.screenPosition=new e.Vector3,o.godRaysMaterial=new Y,o.godRaysMaterial.uniforms.lightPosition.value=o.screenPosition,void 0!==a.exposure&&(o.godRaysMaterial.uniforms.exposure.value=a.exposure),void 0!==a.density&&(o.godRaysMaterial.uniforms.density.value=a.density),void 0!==a.decay&&(o.godRaysMaterial.uniforms.decay.value=a.decay),void 0!==a.weight&&(o.godRaysMaterial.uniforms.weight.value=a.weight),void 0!==a.clampMax&&(o.godRaysMaterial.uniforms.clampMax.value=a.clampMax),o.samples=a.samples,o.combineMaterial=new S(void 0===a.screenMode||a.screenMode),o.intensity=a.intensity,o}return f(n,pe),c(n,[{key:"render",value:function(e,t,n){var r=this.quad,i=this.scene,o=this.camera,s=this.mainScene,l=this.lightSource,u=this.screenPosition,c=this.godRaysMaterial,d=this.combineMaterial,f=this.renderTargetMask,v=this.renderTargetX,h=this.renderTargetY,m=void 0,p=void 0;u.copy(l.position).project(this.mainCamera),u.x=a(.5*(u.x+1),0,1),u.y=a(.5*(u.y+1),0,1),p=l.parent,m=s.background,s.background=null,this.lightScene.add(l),this.renderPassLight.render(e,f),this.renderPassMask.render(e,f),null!==p&&p.add(l),s.background=m,this.blurPass.render(e,f,v),r.material=c,c.uniforms.tDiffuse.value=v.texture,e.render(i,o,h),r.material=d,d.uniforms.texture1.value=t.texture,d.uniforms.texture2.value=h.texture,e.render(i,o,this.renderToScreen?null:n)}},{key:"initialise",value:function(t,n){this.renderPassLight.initialise(t,n),this.renderPassMask.initialise(t,n),this.blurPass.initialise(t,n),n||(this.renderTargetMask.texture.format=e.RGBFormat,this.renderTargetX.texture.format=e.RGBFormat,this.renderTargetY.texture.format=e.RGBFormat)}},{key:"setSize",value:function(e,t){this.renderPassLight.setSize(e,t),this.renderPassMask.setSize(e,t),this.blurPass.setSize(e,t),e=this.blurPass.width,t=this.blurPass.height,this.renderTargetMask.setSize(e,t),this.renderTargetX.setSize(e,t),this.renderTargetY.setSize(e,t)}},{key:"resolutionScale",get:function(){return this.blurPass.resolutionScale},set:function(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:.5;this.blurPass.resolutionScale=e}},{key:"kernelSize",get:function(){return this.blurPass.kernelSize},set:function(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:C.LARGE;this.blurPass.kernelSize=e}},{key:"intensity",get:function(){return this.combineMaterial.uniforms.opacity2.value},set:function(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:1;this.combineMaterial.uniforms.opacity2.value=e}},{key:"samples",get:function(){return Number.parseInt(this.godRaysMaterial.defines.NUM_SAMPLES_INT)},set:function(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:60;e=Math.floor(e),this.godRaysMaterial.defines.NUM_SAMPLES_FLOAT=e.toFixed(1),this.godRaysMaterial.defines.NUM_SAMPLES_INT=e.toFixed(0),this.godRaysMaterial.needsUpdate=!0}}]),n}(),Ee=function(e){function t(e,n){u(this,t);var r=v(this,(t.__proto__||Object.getPrototypeOf(t)).call(this,e,n,null));return r.name="MaskPass",r.inverse=!1,r.clearStencil=!0,r}return f(t,pe),c(t,[{key:"render",value:function(e,t,n){var r=e.context,i=e.state,a=this.scene,o=this.camera,s=this.inverse?0:1,l=1-s;i.buffers.color.setMask(!1),i.buffers.depth.setMask(!1),i.buffers.color.setLocked(!0),i.buffers.depth.setLocked(!0),i.buffers.stencil.setTest(!0),i.buffers.stencil.setOp(r.REPLACE,r.REPLACE,r.REPLACE),i.buffers.stencil.setFunc(r.ALWAYS,s,4294967295),i.buffers.stencil.setClear(l),this.clearStencil&&(e.setRenderTarget(t),e.clearStencil(),e.setRenderTarget(n),e.clearStencil()),e.render(a,o,t),e.render(a,o,n),i.buffers.color.setLocked(!1),i.buffers.depth.setLocked(!1),i.buffers.stencil.setFunc(r.EQUAL,1,4294967295),i.buffers.stencil.setOp(r.KEEP,r.KEEP,r.KEEP)}}]),t}(),ke=function(e){function t(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:30;u(this,t);var n=v(this,(t.__proto__||Object.getPrototypeOf(t)).call(this));return n.name="PixelationPass",n.needsSwap=!0,n.pixelationMaterial=new _,n.granularity=e,n.quad.material=n.pixelationMaterial,n}return f(t,pe),c(t,[{key:"render",value:function(e,t,n){this.pixelationMaterial.uniforms.tDiffuse.value=t.texture,e.render(this.scene,this.camera,this.renderToScreen?null:n)}},{key:"setSize",value:function(e,t){this.pixelationMaterial.setResolution(e,t)}},{key:"granularity",get:function(){return this.pixelationMaterial.granularity},set:function(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:30;(e=Math.floor(e))%2>0&&(e+=1),this.pixelationMaterial.granularity=e}}]),t}(),Ue=function(t){function n(t){var r=!(arguments.length>1&&void 0!==arguments[1])||arguments[1];u(this,n);var i=v(this,(n.__proto__||Object.getPrototypeOf(n)).call(this));return i.name="SavePass",i.material=new E,i.quad.material=i.material,i.renderTarget=void 0!==t?t:new e.WebGLRenderTarget(1,1,{minFilter:e.LinearFilter,magFilter:e.LinearFilter,stencilBuffer:!1,depthBuffer:!1}),i.renderTarget.texture.name="Save.Target",i.renderTarget.texture.generateMipmaps=!1,i.resize=r,i}return f(n,pe),c(n,[{key:"render",value:function(e,t){this.material.uniforms.tDiffuse.value=t.texture,e.render(this.scene,this.camera,this.renderTarget)}},{key:"initialise",value:function(t,n){n||(this.renderTarget.texture.format=e.RGBFormat)}},{key:"setSize",value:function(e,t){this.resize&&(e=Math.max(1,e),t=Math.max(1,t),this.renderTarget.setSize(e,t))}}]),n}(),ze=function(e){function t(e){var n=arguments.length>1&&void 0!==arguments[1]?arguments[1]:"tDiffuse";u(this,t);var r=v(this,(t.__proto__||Object.getPrototypeOf(t)).call(this));return r.name="ShaderPass",r.needsSwap=!0,r.material=e,r.quad.material=r.material,r.textureID=n,r}return f(t,pe),c(t,[{key:"render",value:function(e,t,n){void 0!==this.material.uniforms[this.textureID]&&(this.material.uniforms[this.textureID].value=t.texture),e.render(this.scene,this.camera,this.renderToScreen?null:n)}}]),t}(),Fe=.5*Math.PI,Ne=new e.Vector3,je=new e.Vector3,Be=function(t){function n(t){var r=arguments.length>1&&void 0!==arguments[1]?arguments[1]:new e.Vector3,i=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{};u(this,n);var a=v(this,(n.__proto__||Object.getPrototypeOf(n)).call(this));return a.name="ShockWavePass",a.needsSwap=!0,a.mainCamera=t,a.epicenter=r,a.screenPosition=new e.Vector3,a.speed=void 0!==i.speed?i.speed:2,a.time=0,a.active=!1,a.shockWaveMaterial=new te(i),a.shockWaveMaterial.uniforms.center.value=a.screenPosition,a.copyMaterial=new E,a}return f(n,pe),c(n,[{key:"explode",value:function(){this.time=0,this.active=!0}},{key:"render",value:function(e,t,n,r){var i=this.epicenter,a=this.mainCamera,o=this.screenPosition,s=this.shockWaveMaterial,l=s.uniforms,u=l.center,c=l.radius,d=l.maxRadius,f=l.waveSize;this.copyMaterial.uniforms.tDiffuse.value=t.texture,this.quad.material=this.copyMaterial,this.active&&(a.getWorldDirection(Ne),je.copy(a.position).sub(i),Ne.angleTo(je)>Fe&&(l.cameraDistance.value=a.position.distanceTo(i),o.copy(i).project(a),u.value.x=.5*(o.x+1),u.value.y=.5*(o.y+1),l.tDiffuse.value=t.texture,this.quad.material=s),this.time+=r*this.speed,c.value=this.time-f.value,c.value>=2*(d.value+f.value)&&(this.active=!1)),e.render(this.scene,this.camera,this.renderToScreen?null:n)}},{key:"setSize",value:function(e,t){this.shockWaveMaterial.uniforms.aspect.value=e/t}}]),n}(),Re=function(t){function n(t){u(this,n);var r=v(this,(n.__proto__||Object.getPrototypeOf(n)).call(this));r.name="SMAAPass",r.needsSwap=!0,r.renderTargetColorEdges=new e.WebGLRenderTarget(1,1,{minFilter:e.LinearFilter,format:e.RGBFormat,stencilBuffer:!1,depthBuffer:!1}),r.renderTargetColorEdges.texture.name="SMAA.ColorEdges",r.renderTargetColorEdges.texture.generateMipmaps=!1,r.renderTargetWeights=r.renderTargetColorEdges.clone(),r.renderTargetWeights.texture.name="SMAA.Weights",r.renderTargetWeights.texture.format=e.RGBAFormat,r.colorEdgesMaterial=new se,r.weightsMaterial=new fe;var i=new t;i.src=r.weightsMaterial.areaImage;var a=new e.Texture;a.image=i,a.name="SMAA.Area",a.minFilter=e.LinearFilter,a.format=e.RGBFormat,a.generateMipmaps=!1,a.needsUpdate=!0,a.flipY=!1;var o=new t;o.src=r.weightsMaterial.searchImage;var s=new e.Texture;return s.image=o,s.name="SMAA.Search",s.magFilter=e.NearestFilter,s.minFilter=e.NearestFilter,s.generateMipmaps=!1,s.needsUpdate=!0,s.flipY=!1,r.weightsMaterial.uniforms.tDiffuse.value=r.renderTargetColorEdges.texture,r.weightsMaterial.uniforms.tArea.value=a,r.weightsMaterial.uniforms.tSearch.value=s,r.blendMaterial=new ie,r.blendMaterial.uniforms.tWeights.value=r.renderTargetWeights.texture,r.quad.material=r.blendMaterial,r}return f(n,pe),c(n,[{key:"render",value:function(e,t,n){this.quad.material=this.colorEdgesMaterial,this.colorEdgesMaterial.uniforms.tDiffuse.value=t.texture,e.render(this.scene,this.camera,this.renderTargetColorEdges,!0),this.quad.material=this.weightsMaterial,e.render(this.scene,this.camera,this.renderTargetWeights,!1),this.quad.material=this.blendMaterial,this.blendMaterial.uniforms.tDiffuse.value=t.texture,e.render(this.scene,this.camera,this.renderToScreen?null:n)}},{key:"setSize",value:function(e,t){this.renderTargetColorEdges.setSize(e,t),this.renderTargetWeights.setSize(e,t),this.colorEdgesMaterial.uniforms.texelSize.value.copy(this.weightsMaterial.uniforms.texelSize.value.copy(this.blendMaterial.uniforms.texelSize.value.set(1/e,1/t)))}}]),n}(),Ie=function(t){function n(t){var r=arguments.length>1&&void 0!==arguments[1]?arguments[1]:1;u(this,n);var i=v(this,(n.__proto__||Object.getPrototypeOf(n)).call(this));return i.name="TexturePass",i.copyMaterial=new E,i.copyMaterial.blending=e.AdditiveBlending,i.copyMaterial.transparent=!0,i.texture=t,i.opacity=r,i.quad.material=i.copyMaterial,i}return f(n,pe),c(n,[{key:"render",value:function(e,t){e.render(this.scene,this.camera,this.renderToScreen?null:t)}},{key:"texture",get:function(){return this.copyMaterial.uniforms.tDiffuse.value},set:function(e){this.copyMaterial.uniforms.tDiffuse.value=e}},{key:"opacity",get:function(){return this.copyMaterial.uniforms.opacity.value},set:function(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:1;this.copyMaterial.uniforms.opacity.value=e}}]),n}(),Ge=function(t){function n(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};u(this,n);var r=v(this,(n.__proto__||Object.getPrototypeOf(n)).call(this));return r.name="ToneMappingPass",r.needsSwap=!0,r.renderTargetLuminosity=new e.WebGLRenderTarget(1,1,{minFilter:e.LinearMipMapLinearFilter,magFilter:e.LinearFilter,format:e.RGBFormat,stencilBuffer:!1,depthBuffer:!1}),r.renderTargetLuminosity.texture.name="ToneMapping.Luminosity",r.renderTargetAdapted=r.renderTargetLuminosity.clone(),r.renderTargetAdapted.texture.name="ToneMapping.AdaptedLuminosity",r.renderTargetAdapted.texture.generateMipmaps=!1,r.renderTargetAdapted.texture.minFilter=e.LinearFilter,r.renderTargetPrevious=r.renderTargetAdapted.clone(),r.renderTargetPrevious.texture.name="ToneMapping.PreviousLuminosity",r.copyMaterial=new E,r.luminosityMaterial=new Z,r.luminosityMaterial.uniforms.distinction.value=void 0!==t.distinction?t.distinction:1,r.adaptiveLuminosityMaterial=new h,r.resolution=t.resolution,r.toneMappingMaterial=new me,r.adaptive=t.adaptive,r}return f(n,pe),c(n,[{key:"render",value:function(e,t,n,r){var i=this.quad,a=this.scene,o=this.camera,s=this.adaptiveLuminosityMaterial,l=this.luminosityMaterial,u=this.toneMappingMaterial,c=this.copyMaterial,d=this.renderTargetPrevious,f=this.renderTargetLuminosity,v=this.renderTargetAdapted;this.adaptive&&(i.material=l,l.uniforms.tDiffuse.value=t.texture,e.render(a,o,f),i.material=s,s.uniforms.delta.value=r,s.uniforms.tPreviousLum.value=d.texture,s.uniforms.tCurrentLum.value=f.texture,e.render(a,o,v),i.material=c,c.uniforms.tDiffuse.value=v.texture,e.render(a,o,d)),i.material=u,u.uniforms.tDiffuse.value=t.texture,e.render(this.scene,this.camera,this.renderToScreen?null:n)}},{key:"initialise",value:function(t){this.quad.material=new e.MeshBasicMaterial({color:8388607}),t.render(this.scene,this.camera,this.renderTargetPrevious),this.quad.material.dispose()}},{key:"resolution",get:function(){return this.renderTargetLuminosity.width},set:function(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:256;e=o(e),this.renderTargetLuminosity.setSize(e,e),this.renderTargetPrevious.setSize(e,e),this.renderTargetAdapted.setSize(e,e),this.adaptiveLuminosityMaterial.defines.MIP_LEVEL_1X1=(Math.round(Math.log(e))/Math.log(2)).toFixed(1),this.adaptiveLuminosityMaterial.needsUpdate=!0}},{key:"adaptive",get:function(){return void 0!==this.toneMappingMaterial.defines.ADAPTED_LUMINANCE},set:function(){!(arguments.length>0&&void 0!==arguments[0])||arguments[0]?(this.toneMappingMaterial.defines.ADAPTED_LUMINANCE="1",this.toneMappingMaterial.uniforms.luminanceMap.value=this.renderTargetAdapted.texture):(delete this.toneMappingMaterial.defines.ADAPTED_LUMINANCE,this.toneMappingMaterial.uniforms.luminanceMap.value=null),this.toneMappingMaterial.needsUpdate=!0}}]),n}(),We=function(){function t(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:null,n=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};u(this,t),this.renderer=e,this.readBuffer=null,this.writeBuffer=null,null!==this.renderer&&(this.renderer.autoClear=!1,this.readBuffer=this.createBuffer(void 0===n.depthBuffer||n.depthBuffer,void 0!==n.stencilBuffer&&n.stencilBuffer,void 0!==n.depthTexture&&n.depthTexture),this.writeBuffer=this.readBuffer.clone()),this.copyPass=new ze(new E),this.passes=[]}return c(t,[{key:"replaceRenderer",value:function(e){var t=this.renderer,n=void 0,r=void 0,i=void 0;return null!==t&&t!==e&&(this.renderer=e,this.renderer.autoClear=!1,n=t.domElement.parentNode,r=t.getSize(),i=e.getSize(),null!==n&&(n.removeChild(t.domElement),n.appendChild(e.domElement)),r.width===i.width&&r.height===i.height||this.setSize()),t}},{key:"createBuffer",value:function(t,n,r){var i=this.renderer.getSize(),a=this.renderer.getPixelRatio(),o=this.renderer.context.getContextAttributes().alpha,s=new e.WebGLRenderTarget(i.width*a,i.height*a,{minFilter:e.LinearFilter,magFilter:e.LinearFilter,format:o?e.RGBAFormat:e.RGBFormat,depthBuffer:t,stencilBuffer:n,depthTexture:r?new e.DepthTexture:null});return r&&n&&(s.depthTexture.format=e.DepthStencilFormat,s.depthTexture.type=e.UnsignedInt248Type),s.texture.name="EffectComposer.Buffer",s.texture.generateMipmaps=!1,s}},{key:"addPass",value:function(e,t){var n=this.renderer,r=n.getSize(),i=n.getPixelRatio();e.setSize(r.width*i,r.height*i),e.initialise(n,n.context.getContextAttributes().alpha),void 0!==t?this.passes.splice(t,0,e):this.passes.push(e)}},{key:"removePass",value:function(e){this.passes.splice(this.passes.indexOf(e),1)}},{key:"render",value:function(e){var t=this.passes,n=this.renderer,r=this.copyPass,i=this.readBuffer,a=this.writeBuffer,o=!1,s=void 0,l=void 0,u=void 0,c=void 0,d=void 0;for(c=0,d=t.length;c0;)t.pop().dispose();void 0!==e?(this.readBuffer=e,this.writeBuffer=this.readBuffer.clone()):this.copyPass.dispose()}},{key:"depthTexture",get:function(){return this.readBuffer.depthTexture},set:function(e){this.readBuffer.depthTexture=e,this.writeBuffer.depthTexture=e}}]),t}(),He=function(){function t(n){u(this,t),this.composer=n,this.loadingManager=new e.LoadingManager,this.assets=null,this.scene=new e.Scene,this.scene.fog=new e.FogExp2(855309,.0025),this.camera=new e.PerspectiveCamera(50,window.innerWidth/window.innerHeight,.1,2e3),this.controls=null}return c(t,[{key:"load",value:function(e){e()}},{key:"initialise",value:function(){}},{key:"update",value:function(e){}},{key:"configure",value:function(e){}},{key:"reset",value:function(){var t=this.scene.fog;return this.scene=new e.Scene,this.scene.fog=t,null!==this.controls&&(this.controls.dispose(),this.controls=null),this}}]),t}(),Xe=2*Math.PI,Ve=function(t){function n(e){u(this,n);var t=v(this,(n.__proto__||Object.getPrototypeOf(n)).call(this,e));return t.bloomPass=null,t.object=null,t}return f(n,He),c(n,[{key:"load",value:function(t){var n=this,r=new Map,i=this.loadingManager,a=new e.CubeTextureLoader(i),o="textures/skies/space2/",s=[o+"px.jpg",o+"nx.jpg",o+"py.jpg",o+"ny.jpg",o+"pz.jpg",o+"nz.jpg"];null===this.assets?(i.onProgress=function(e,i,a){i===a&&(n.assets=r,t())},a.load(s,function(e){r.set("sky",e)})):t()}},{key:"initialise",value:function(){var t=this.scene,n=this.camera,r=this.assets,i=this.composer;this.controls=new e.OrbitControls(n,i.renderer.domElement),n.position.set(-10,6,15),n.lookAt(this.controls.target),t.background=r.get("sky");var a=new e.AmbientLight(6710886),o=new e.DirectionalLight(16759722);o.position.set(-1,1,1),o.target.position.copy(t.position),t.add(o),t.add(a);var s=new e.Object3D,l=new e.SphereBufferGeometry(1,4,4),u=void 0,c=void 0,d=void 0;for(c=0;c<100;++c)u=new e.MeshPhongMaterial({color:16777215*Math.random(),flatShading:!0}),(d=new e.Mesh(l,u)).position.set(Math.random()-.5,Math.random()-.5,Math.random()-.5).normalize(),d.position.multiplyScalar(4*Math.random()),d.rotation.set(2*Math.random(),2*Math.random(),2*Math.random()),d.scale.multiplyScalar(.5*Math.random()),s.add(d);this.object=s,t.add(s),d=new e.Mesh(new e.BoxBufferGeometry(.25,8.25,.25),new e.MeshLambertMaterial({color:723723}));var f=void 0,v=void 0,h=void 0;f=(s=new e.Object3D).clone();var m=d.clone();m.position.set(-4,0,4),f.add(m),(m=d.clone()).position.set(4,0,4),f.add(m),(m=d.clone()).position.set(-4,0,-4),f.add(m),(m=d.clone()).position.set(4,0,-4),f.add(m),(v=f.clone()).rotation.set(Math.PI/2,0,0),(h=f.clone()).rotation.set(0,0,Math.PI/2),s.add(f),s.add(v),s.add(h),t.add(s),i.addPass(new Oe(t,n));var p=new xe({resolutionScale:.5,intensity:2,distinction:4});p.renderToScreen=!0,this.bloomPass=p,i.addPass(p)}},{key:"update",value:function(e){var t=this.object;null!==t&&(t.rotation.x+=.001,t.rotation.y+=.005,t.rotation.x>=Xe&&(t.rotation.x-=Xe),t.rotation.y>=Xe&&(t.rotation.y-=Xe))}},{key:"configure",value:function(e){var t=this.composer,n=this.bloomPass,r={resolution:n.resolutionScale,"kernel size":n.kernelSize,intensity:n.intensity,distinction:n.distinction,blend:!0,"blend mode":"screen"};e.add(r,"resolution").min(0).max(1).step(.01).onChange(function(){n.resolutionScale=r.resolution,t.setSize()}),e.add(r,"kernel size").min(C.VERY_SMALL).max(C.HUGE).step(1).onChange(function(){n.kernelSize=r["kernel size"]}),e.add(r,"intensity").min(0).max(3).step(.01).onChange(function(){n.intensity=r.intensity});var i=e.addFolder("Luminance");i.add(r,"distinction").min(1).max(10).step(.1).onChange(function(){n.distinction=r.distinction}),i.open(),e.add(r,"blend").onChange(function(){n.combineMaterial.uniforms.opacity1.value=r.blend?1:0}),e.add(r,"blend mode",["add","screen"]).onChange(function(){"add"===r["blend mode"]?delete n.combineMaterial.defines.SCREEN_MODE:n.combineMaterial.defines.SCREEN_MODE="1",n.combineMaterial.needsUpdate=!0})}}]),n}(),Ye=function(t){function n(e){u(this,n);var t=v(this,(n.__proto__||Object.getPrototypeOf(n)).call(this,e));return t.bokehPass=null,t}return f(n,He),c(n,[{key:"load",value:function(t){var n=this,r=new Map,i=this.loadingManager,a=new e.CubeTextureLoader(i),o="textures/skies/space3/",s=[o+"px.jpg",o+"nx.jpg",o+"py.jpg",o+"ny.jpg",o+"pz.jpg",o+"nz.jpg"];null===this.assets?(i.onProgress=function(e,i,a){i===a&&(n.assets=r,t())},a.load(s,function(e){r.set("sky",e)})):t()}},{key:"initialise",value:function(){var t=this.scene,n=this.camera,r=this.assets,i=this.composer;this.controls=new e.OrbitControls(n,i.renderer.domElement),this.controls.enablePan=!1,this.controls.minDistance=2.5,this.controls.maxDistance=40,n.near=.01,n.far=50,n.position.set(3,1,3),n.lookAt(this.controls.target),t.background=r.get("sky");var a=new e.AmbientLight(6710886),o=new e.DirectionalLight(16759722);o.position.set(-1,1,1),o.target.position.copy(t.position),t.add(o),t.add(a);var s=new e.SphereBufferGeometry(1,64,64),l=new e.MeshBasicMaterial({color:16776960,envMap:r.get("sky")}),u=new e.Mesh(s,l);t.add(u),i.addPass(new Oe(t,n));var c=new ye(n,{focus:.36,aperture:.007,maxBlur:.025});c.renderToScreen=!0,this.bokehPass=c,i.addPass(c)}},{key:"configure",value:function(e){var t=this.bokehPass,n={focus:t.bokehMaterial.uniforms.focus.value,aperture:t.bokehMaterial.uniforms.aperture.value,blur:t.bokehMaterial.uniforms.maxBlur.value};e.add(n,"focus").min(0).max(1).step(.001).onChange(function(){t.bokehMaterial.uniforms.focus.value=n.focus}),e.add(n,"aperture").min(0).max(.05).step(1e-4).onChange(function(){t.bokehMaterial.uniforms.aperture.value=n.aperture}),e.add(n,"blur").min(0).max(.1).step(.001).onChange(function(){t.bokehMaterial.uniforms.maxBlur.value=n.blur})}}]),n}(),qe=function(t){function n(e){u(this,n);var t=v(this,(n.__proto__||Object.getPrototypeOf(n)).call(this,e));return t.bokehPass=null,t}return f(n,He),c(n,[{key:"load",value:function(t){var n=this,r=new Map,i=this.loadingManager,a=new e.CubeTextureLoader(i),o="textures/skies/space3/",s=[o+"px.jpg",o+"nx.jpg",o+"py.jpg",o+"ny.jpg",o+"pz.jpg",o+"nz.jpg"];null===this.assets?(i.onProgress=function(e,i,a){i===a&&(n.assets=r,t())},a.load(s,function(e){r.set("sky",e)})):t()}},{key:"initialise",value:function(){var t=this.scene,n=this.camera,r=this.assets,i=this.composer;this.controls=new e.OrbitControls(n,i.renderer.domElement),this.controls.enablePan=!1,this.controls.minDistance=2.5,this.controls.maxDistance=40,n.near=.01,n.far=50,n.position.set(3,1,3),n.lookAt(this.controls.target),t.background=r.get("sky");var a=new e.AmbientLight(6710886),o=new e.DirectionalLight(16759722);o.position.set(-1,1,1),o.target.position.copy(t.position),t.add(o),t.add(a);var s=new e.SphereBufferGeometry(1,64,64),l=new e.MeshBasicMaterial({color:16776960,envMap:r.get("sky")}),u=new e.Mesh(s,l);t.add(u),i.addPass(new Oe(t,n));var c=new Me(n,{rings:3,samples:2,showFocus:!1,manualDoF:!1,vignette:!1,pentagon:!1,shaderFocus:!0,noise:!0});c.bokehMaterial.uniforms.focalStop.value=64,c.renderToScreen=!0,this.bokehPass=c,i.addPass(c)}},{key:"configure",value:function(e){var t=this.bokehPass,n={rings:Number.parseInt(t.bokehMaterial.defines.RINGS_INT),samples:Number.parseInt(t.bokehMaterial.defines.SAMPLES_INT),"focal stop":t.bokehMaterial.uniforms.focalStop.value,"focal length":t.bokehMaterial.uniforms.focalLength.value,"shader focus":void 0!==t.bokehMaterial.defines.SHADER_FOCUS,"focal depth":t.bokehMaterial.uniforms.focalDepth.value,"focus coord X":t.bokehMaterial.uniforms.focusCoords.value.x,"focus coord Y":t.bokehMaterial.uniforms.focusCoords.value.y,"max blur":t.bokehMaterial.uniforms.maxBlur.value,"lum threshold":t.bokehMaterial.uniforms.luminanceThreshold.value,"lum gain":t.bokehMaterial.uniforms.luminanceGain.value,bias:t.bokehMaterial.uniforms.bias.value,fringe:t.bokehMaterial.uniforms.fringe.value,dithering:t.bokehMaterial.uniforms.ditherStrength.value,vignette:void 0!==t.bokehMaterial.defines.VIGNETTE,pentagon:void 0!==t.bokehMaterial.defines.PENTAGON,"manual DoF":void 0!==t.bokehMaterial.defines.MANUAL_DOF,"show focus":void 0!==t.bokehMaterial.defines.SHOW_FOCUS,noise:void 0!==t.bokehMaterial.defines.NOISE},r=e.addFolder("Focus");r.add(n,"show focus").onChange(function(){n["show focus"]?t.bokehMaterial.defines.SHOW_FOCUS="1":delete t.bokehMaterial.defines.SHOW_FOCUS,t.bokehMaterial.needsUpdate=!0}),r.add(n,"shader focus").onChange(function(){n["shader focus"]?t.bokehMaterial.defines.SHADER_FOCUS="1":delete t.bokehMaterial.defines.SHADER_FOCUS,t.bokehMaterial.needsUpdate=!0}),r.add(n,"manual DoF").onChange(function(){n["manual DoF"]?t.bokehMaterial.defines.MANUAL_DOF="1":delete t.bokehMaterial.defines.MANUAL_DOF,t.bokehMaterial.needsUpdate=!0}),r.add(n,"focal stop").min(0).max(100).step(.1).onChange(function(){t.bokehMaterial.uniforms.focalStop.value=n["focal stop"]}),r.add(n,"focal depth").min(.1).max(35).step(.1).onChange(function(){t.bokehMaterial.uniforms.focalDepth.value=n["focal depth"]}),r.add(n,"focus coord X").min(0).max(1).step(.01).onChange(function(){t.bokehMaterial.uniforms.focusCoords.value.x=n["focus coord X"]}),r.add(n,"focus coord Y").min(0).max(1).step(.01).onChange(function(){t.bokehMaterial.uniforms.focusCoords.value.y=n["focus coord Y"]}),r.open(),(r=e.addFolder("Sampling")).add(n,"rings").min(1).max(6).step(1).onChange(function(){t.bokehMaterial.defines.RINGS_INT=n.rings.toFixed(0),t.bokehMaterial.defines.RINGS_FLOAT=n.rings.toFixed(1),t.bokehMaterial.needsUpdate=!0}),r.add(n,"samples").min(1).max(6).step(1).onChange(function(){t.bokehMaterial.defines.SAMPLES_INT=n.samples.toFixed(0),t.bokehMaterial.defines.SAMPLES_FLOAT=n.samples.toFixed(1),t.bokehMaterial.needsUpdate=!0}),(r=e.addFolder("Blur")).add(n,"max blur").min(0).max(1).step(.001).onChange(function(){t.bokehMaterial.uniforms.maxBlur.value=n["max blur"]}),r.add(n,"bias").min(0).max(3).step(.01).onChange(function(){t.bokehMaterial.uniforms.bias.value=n.bias}),r.add(n,"fringe").min(0).max(2).step(.05).onChange(function(){t.bokehMaterial.uniforms.fringe.value=n.fringe}),r.add(n,"noise").onChange(function(){n.noise?t.bokehMaterial.defines.NOISE="1":delete t.bokehMaterial.defines.NOISE,t.bokehMaterial.needsUpdate=!0}),r.add(n,"dithering").min(0).max(.01).step(1e-4).onChange(function(){t.bokehMaterial.uniforms.ditherStrength.value=n.dithering}),r.add(n,"pentagon").onChange(function(){n.pentagon?t.bokehMaterial.defines.PENTAGON="1":delete t.bokehMaterial.defines.PENTAGON,t.bokehMaterial.needsUpdate=!0}),r.open(),(r=e.addFolder("Luminosity")).add(n,"lum threshold").min(0).max(1).step(.01).onChange(function(){t.bokehMaterial.uniforms.luminanceThreshold.value=n["lum threshold"]}),r.add(n,"lum gain").min(0).max(4).step(.01).onChange(function(){t.bokehMaterial.uniforms.luminanceGain.value=n["lum gain"]}),e.add(n,"vignette").onChange(function(){n.vignette?t.bokehMaterial.defines.VIGNETTE="1":delete t.bokehMaterial.defines.VIGNETTE,t.bokehMaterial.needsUpdate=!0})}}]),n}(),Ke=2*Math.PI,Ze=function(t){function n(e){u(this,n);var t=v(this,(n.__proto__||Object.getPrototypeOf(n)).call(this,e));return t.renderPass=null,t.savePass=null,t.blurPass=null,t.combinePass=null,t.object=null,t}return f(n,He),c(n,[{key:"load",value:function(t){var n=this,r=new Map,i=this.loadingManager,a=new e.CubeTextureLoader(i),o="textures/skies/sunset/",s=[o+"px.png",o+"nx.png",o+"py.png",o+"ny.png",o+"pz.png",o+"nz.png"];null===this.assets?(i.onProgress=function(e,i,a){i===a&&(n.assets=r,t())},a.load(s,function(e){r.set("sky",e)})):t()}},{key:"initialise",value:function(){var t=this.scene,n=this.camera,r=this.assets,i=this.composer;this.controls=new e.OrbitControls(n,i.renderer.domElement),n.position.set(-15,0,-15),n.lookAt(this.controls.target),t.background=r.get("sky");var a=new e.AmbientLight(6710886),o=new e.DirectionalLight(16759722);o.position.set(1440,200,2e3),o.target.position.copy(t.position),t.add(o),t.add(a);var s=new e.Object3D,l=new e.SphereBufferGeometry(1,4,4),u=void 0,c=void 0,d=void 0;for(c=0;c<100;++c)u=new e.MeshPhongMaterial({color:16777215*Math.random(),flatShading:!0}),(d=new e.Mesh(l,u)).position.set(Math.random()-.5,Math.random()-.5,Math.random()-.5).normalize(),d.position.multiplyScalar(10*Math.random()),d.rotation.set(2*Math.random(),2*Math.random(),2*Math.random()),d.scale.multiplyScalar(Math.random()),s.add(d);this.object=s,t.add(s);var f=new Oe(t,n);this.renderPass=f,i.addPass(f),f=new Ue,this.savePass=f,i.addPass(f),f=new ge,this.blurPass=f,i.addPass(f),(f=new ze(new S,"texture1")).material.uniforms.texture2.value=this.savePass.renderTarget.texture,f.material.uniforms.opacity1.value=1,f.material.uniforms.opacity2.value=0,f.renderToScreen=!0,this.combinePass=f,i.addPass(f)}},{key:"update",value:function(e){var t=this.object;null!==t&&(t.rotation.x+=.001,t.rotation.y+=.005,t.rotation.x>=Ke&&(t.rotation.x-=Ke),t.rotation.y>=Ke&&(t.rotation.y-=Ke))}},{key:"configure",value:function(e){var t=this.composer,n=this.renderPass,r=this.blurPass,i=this.combinePass,a={enabled:r.enabled,resolution:r.resolutionScale,"kernel size":r.kernelSize,strength:i.material.uniforms.opacity1.value};e.add(a,"resolution").min(0).max(1).step(.01).onChange(function(){r.resolutionScale=a.resolution,t.setSize()}),e.add(a,"kernel size").min(C.VERY_SMALL).max(C.HUGE).step(1).onChange(function(){r.kernelSize=a["kernel size"]}),e.add(a,"strength").min(0).max(1).step(.01).onChange(function(){i.material.uniforms.opacity1.value=a.strength,i.material.uniforms.opacity2.value=1-a.strength}),e.add(a,"enabled").onChange(function(){n.renderToScreen=!a.enabled,r.enabled=a.enabled,i.enabled=a.enabled})}}]),n}(),Je=2*Math.PI,Qe=function(t){function n(e){u(this,n);var t=v(this,(n.__proto__||Object.getPrototypeOf(n)).call(this,e));return t.object=null,t.texturePass=null,t.depthPass=null,t}return f(n,He),c(n,[{key:"initialise",value:function(){var t=this.scene,n=this.camera,r=this.composer;this.controls=new e.OrbitControls(n,r.renderer.domElement),this.controls.enablePan=!1,this.controls.maxDistance=40,n.near=.01,n.far=50,n.position.set(2,1,2),n.lookAt(this.controls.target);var i=new e.Mesh(new e.BoxBufferGeometry(1,1,1),new e.MeshBasicMaterial);this.object=i,t.add(i),r.addPass(new Oe(t,n));var a=new Ie(r.depthTexture);a.enabled=!1,this.texturePass=a,r.addPass(a),(a=new Pe(n)).renderToScreen=!0,this.depthPass=a,r.addPass(a)}},{key:"update",value:function(e){var t=this.object;null!==t&&(t.rotation.x+=.001,t.rotation.y+=.005,t.rotation.x>=Je&&(t.rotation.x-=Je),t.rotation.y>=Je&&(t.rotation.y-=Je))}},{key:"configure",value:function(e){var t=this.texturePass,n=this.depthPass,r={raw:!1};e.add(r,"raw").onChange(function(){t.enabled=r.raw,n.enabled=!r.raw,t.renderToScreen=r.raw,n.renderToScreen=!r.raw})}}]),n}(),_e=2*Math.PI,$e=function(t){function n(e){u(this,n);var t=v(this,(n.__proto__||Object.getPrototypeOf(n)).call(this,e));return t.dotScreenPass=null,t.object=null,t}return f(n,He),c(n,[{key:"load",value:function(t){var n=this,r=new Map,i=this.loadingManager,a=new e.CubeTextureLoader(i),o="textures/skies/space3/",s=[o+"px.jpg",o+"nx.jpg",o+"py.jpg",o+"ny.jpg",o+"pz.jpg",o+"nz.jpg"];null===this.assets?(i.onProgress=function(e,i,a){i===a&&(n.assets=r,t())},a.load(s,function(e){r.set("sky",e)})):t()}},{key:"initialise",value:function(){var t=this.scene,n=this.camera,r=this.assets,i=this.composer;this.controls=new e.OrbitControls(n,i.renderer.domElement),n.position.set(10,1,10),n.lookAt(this.controls.target),t.background=r.get("sky");var a=new e.AmbientLight(6710886),o=new e.DirectionalLight(16759722);o.position.set(-1,1,1),o.target.position.copy(t.position),t.add(o),t.add(a);var s=new e.Object3D,l=new e.SphereBufferGeometry(1,4,4),u=void 0,c=void 0,d=void 0;for(d=0;d<100;++d)u=new e.MeshPhongMaterial({color:16777215*Math.random(),flatShading:!0}),(c=new e.Mesh(l,u)).position.set(Math.random()-.5,Math.random()-.5,Math.random()-.5).normalize(),c.position.multiplyScalar(10*Math.random()),c.rotation.set(2*Math.random(),2*Math.random(),2*Math.random()),c.scale.multiplyScalar(Math.random()),s.add(c);this.object=s,t.add(s),i.addPass(new Oe(t,n));var f=new De({scale:.8,angle:.5*Math.PI,intensity:.25});f.renderToScreen=!0,this.dotScreenPass=f,i.addPass(f)}},{key:"update",value:function(e){var t=this.object;null!==t&&(t.rotation.x+=5e-4,t.rotation.y+=.001,t.rotation.x>=_e&&(t.rotation.x-=_e),t.rotation.y>=_e&&(t.rotation.y-=_e))}},{key:"configure",value:function(e){var t=this.dotScreenPass,n={average:void 0!==t.material.defines.AVERAGE,scale:t.material.uniforms.scale.value,angle:t.material.uniforms.angle.value,intensity:t.material.uniforms.intensity.value,"center X":t.material.uniforms.offsetRepeat.value.x,"center Y":t.material.uniforms.offsetRepeat.value.y};e.add(n,"average").onChange(function(){n.average?t.material.defines.AVERAGE="1":delete t.material.defines.AVERAGE,t.material.needsUpdate=!0}),e.add(n,"scale").min(0).max(1).step(.01).onChange(function(){t.material.uniforms.scale.value=n.scale}),e.add(n,"angle").min(0).max(Math.PI).step(.001).onChange(function(){t.material.uniforms.angle.value=n.angle}),e.add(n,"intensity").min(0).max(1).step(.01).onChange(function(){t.material.uniforms.intensity.value=n.intensity});var r=e.addFolder("Center");r.add(n,"center X").min(-1).max(1).step(.01).onChange(function(){t.material.uniforms.offsetRepeat.value.x=n["center X"]}),r.add(n,"center Y").min(-1).max(1).step(.01).onChange(function(){t.material.uniforms.offsetRepeat.value.y=n["center Y"]})}}]),n}(),et=2*Math.PI,tt=function(t){function n(e){u(this,n);var t=v(this,(n.__proto__||Object.getPrototypeOf(n)).call(this,e));return t.filmPass=null,t.object=null,t}return f(n,He),c(n,[{key:"load",value:function(t){var n=this,r=new Map,i=this.loadingManager,a=new e.CubeTextureLoader(i),o="textures/skies/space/",s=[o+"px.jpg",o+"nx.jpg",o+"py.jpg",o+"ny.jpg",o+"pz.jpg",o+"nz.jpg"];null===this.assets?(i.onProgress=function(e,i,a){i===a&&(n.assets=r,t())},a.load(s,function(e){r.set("sky",e)})):t()}},{key:"initialise",value:function(){var t=this.scene,n=this.camera,r=this.assets,i=this.composer;this.controls=new e.OrbitControls(n,i.renderer.domElement),n.position.set(10,1,10),n.lookAt(this.controls.target),t.background=r.get("sky");var a=new e.AmbientLight(6710886),o=new e.DirectionalLight(16759722);o.position.set(-1,1,1),o.target.position.copy(t.position),t.add(o),t.add(a);var s=new e.Object3D,l=new e.SphereBufferGeometry(1,4,4),u=void 0,c=void 0,d=void 0;for(d=0;d<100;++d)u=new e.MeshPhongMaterial({color:16777215*Math.random(),flatShading:!0}),(c=new e.Mesh(l,u)).position.set(Math.random()-.5,Math.random()-.5,Math.random()-.5).normalize(),c.position.multiplyScalar(10*Math.random()),c.rotation.set(2*Math.random(),2*Math.random(),2*Math.random()),c.scale.multiplyScalar(Math.random()),s.add(c);this.object=s,t.add(s),i.addPass(new Oe(t,n));var f=new Te({grayscale:!1,sepia:!1,vignette:!1,eskil:!1,scanlines:!0,noise:!0,noiseIntensity:.5,scanlineIntensity:.5,scanlineDensity:1.5,greyscaleIntensity:1,sepiaIntensity:1,vignetteOffset:0,vignetteDarkness:.5});f.renderToScreen=!0,this.filmPass=f,i.addPass(f)}},{key:"update",value:function(e){var t=this.object;null!==t&&(t.rotation.x+=.001,t.rotation.y+=.005,t.rotation.x>=et&&(t.rotation.x-=et),t.rotation.y>=et&&(t.rotation.y-=et))}},{key:"configure",value:function(e){var t=this.composer,n=this.filmPass,r={grayscale:void 0!==n.material.defines.GREYSCALE,sepia:void 0!==n.material.defines.SEPIA,vignette:void 0!==n.material.defines.VIGNETTE,eskil:void 0!==n.material.defines.ESKIL,noise:void 0!==n.material.defines.NOISE,scanlines:void 0!==n.material.defines.SCANLINES,"noise intensity":n.material.uniforms.noiseIntensity.value,"scanlines intensity":n.material.uniforms.scanlineIntensity.value,"scanlines count":n.scanlineDensity,"blend mode":"screen","greyscale intensity":n.material.uniforms.greyscaleIntensity.value,"sepia intensity":n.material.uniforms.sepiaIntensity.value,"vignette offset":n.material.uniforms.vignetteOffset.value,"vignette darkness":n.material.uniforms.vignetteDarkness.value},i=e.addFolder("Greyscale");i.add(r,"grayscale").onChange(function(){r.grayscale?n.material.defines.GREYSCALE="1":delete n.material.defines.GREYSCALE,n.material.needsUpdate=!0}),i.add(r,"greyscale intensity").min(0).max(1).step(.01).onChange(function(){n.material.uniforms.greyscaleIntensity.value=r["greyscale intensity"]}),i.open(),(i=e.addFolder("Noise and scanlines")).add(r,"blend mode",["add","screen"]).onChange(function(){"add"===r["blend mode"]?delete n.material.defines.SCREEN_MODE:n.material.defines.SCREEN_MODE="1",n.material.needsUpdate=!0}),i.add(r,"noise").onChange(function(){r.noise?n.material.defines.NOISE="1":delete n.material.defines.NOISE,n.material.needsUpdate=!0}),i.add(r,"noise intensity").min(0).max(1).step(.01).onChange(function(){n.material.uniforms.noiseIntensity.value=r["noise intensity"]}),i.add(r,"scanlines").onChange(function(){r.scanlines?n.material.defines.SCANLINES="1":delete n.material.defines.SCANLINES,n.material.needsUpdate=!0}),i.add(r,"scanlines intensity").min(0).max(1).step(.01).onChange(function(){n.material.uniforms.scanlineIntensity.value=r["scanlines intensity"]}),i.add(r,"scanlines count").min(0).max(2).step(.01).onChange(function(){n.scanlineDensity=r["scanlines count"],t.setSize()}),i.open(),(i=e.addFolder("Sepia")).add(r,"sepia").onChange(function(){r.sepia?n.material.defines.SEPIA="1":delete n.material.defines.SEPIA,n.material.needsUpdate=!0}),i.add(r,"sepia intensity").min(0).max(1).step(.01).onChange(function(){n.material.uniforms.sepiaIntensity.value=r["sepia intensity"]}),i.open(),(i=e.addFolder("Vignette")).add(r,"vignette").onChange(function(){r.vignette?n.material.defines.VIGNETTE="1":delete n.material.defines.VIGNETTE,n.material.needsUpdate=!0}),i.add(r,"eskil").onChange(function(){r.eskil?n.material.defines.ESKIL="1":delete n.material.defines.ESKIL,n.material.needsUpdate=!0}),i.add(r,"vignette offset").min(0).max(1).step(.01).onChange(function(){n.material.uniforms.vignetteOffset.value=r["vignette offset"]}),i.add(r,"vignette darkness").min(0).max(1).step(.01).onChange(function(){n.material.uniforms.vignetteDarkness.value=r["vignette darkness"]}),i.open()}}]),n}(),nt=2*Math.PI,rt=function(t){function n(e){u(this,n);var t=v(this,(n.__proto__||Object.getPrototypeOf(n)).call(this,e));return t.glitchPass=null,t.object=null,t}return f(n,He),c(n,[{key:"load",value:function(t){var n=this,r=new Map,i=this.loadingManager,a=new e.TextureLoader(i),o=new e.CubeTextureLoader(i),s="textures/skies/space4/",l=[s+"px.jpg",s+"nx.jpg",s+"py.jpg",s+"ny.jpg",s+"pz.jpg",s+"nz.jpg"];null===this.assets?(i.onProgress=function(e,i,a){i===a&&(n.assets=r,t())},o.load(l,function(e){r.set("sky",e)}),a.load("textures/perturb.jpg",function(t){t.magFilter=t.minFilter=e.NearestFilter,r.set("perturb-map",t)})):t()}},{key:"initialise",value:function(){var t=this.scene,n=this.camera,r=this.assets,i=this.composer;this.controls=new e.OrbitControls(n,i.renderer.domElement),n.position.set(6,1,6),n.lookAt(this.controls.target),t.background=r.get("sky");var a=new e.AmbientLight(6710886),o=new e.DirectionalLight(16759722);o.position.set(-1,1,1),o.target.position.copy(t.position),t.add(o),t.add(a);var s=new e.Object3D,l=new e.SphereBufferGeometry(1,4,4),u=void 0,c=void 0,d=void 0;for(d=0;d<100;++d)u=new e.MeshPhongMaterial({color:16777215*Math.random(),flatShading:!0}),(c=new e.Mesh(l,u)).position.set(Math.random()-.5,Math.random()-.5,Math.random()-.5).normalize(),c.position.multiplyScalar(10*Math.random()),c.rotation.set(2*Math.random(),2*Math.random(),2*Math.random()),c.scale.multiplyScalar(Math.random()),s.add(c);this.object=s,t.add(s),i.addPass(new Oe(t,n));var f=new Ae({perturbMap:r.get("perturb-map")});f.renderToScreen=!0,this.glitchPass=f,i.addPass(f)}},{key:"update",value:function(e){var t=this.object;null!==t&&(t.rotation.x+=.005,t.rotation.y+=.01,t.rotation.x>=nt&&(t.rotation.x-=nt),t.rotation.y>=nt&&(t.rotation.y-=nt))}},{key:"configure",value:function(e){var t=this.glitchPass,n=t.perturbMap,r={mode:t.mode,"custom noise":!0};e.add(r,"mode").min(Ce.SPORADIC).max(Ce.CONSTANT_WILD).step(1).onChange(function(){t.mode=r.mode}),e.add(r,"custom noise").onChange(function(){r["custom noise"]?t.perturbMap=n:(t.perturbMap=null,t.generatePerturbMap(64))})}}]),n}(),it=2*Math.PI,at=function(t){function n(e){u(this,n);var t=v(this,(n.__proto__||Object.getPrototypeOf(n)).call(this,e));return t.object=null,t.maskObject=null,t.maskPass=null,t.pixelationPass=null,t}return f(n,He),c(n,[{key:"load",value:function(t){var n=this,r=new Map,i=this.loadingManager,a=new e.CubeTextureLoader(i),o="textures/skies/space/",s=[o+"px.jpg",o+"nx.jpg",o+"py.jpg",o+"ny.jpg",o+"pz.jpg",o+"nz.jpg"];null===this.assets?(i.onProgress=function(e,i,a){i===a&&(n.assets=r,t())},a.load(s,function(e){r.set("sky",e)})):t()}},{key:"initialise",value:function(){var t=this.scene,n=this.camera,r=this.assets,i=this.composer;this.controls=new e.OrbitControls(n,i.renderer.domElement),n.position.set(10,1,10),n.lookAt(this.controls.target),t.background=r.get("sky");var a=new e.AmbientLight(6710886),o=new e.DirectionalLight(16759722);o.position.set(-1,1,1),o.target.position.copy(t.position),t.add(o),t.add(a);var s=new e.Object3D,l=new e.SphereBufferGeometry(1,4,4),u=void 0,c=void 0,d=void 0;for(d=0;d<100;++d)u=new e.MeshPhongMaterial({color:16777215*Math.random(),flatShading:!0}),(c=new e.Mesh(l,u)).position.set(Math.random()-.5,Math.random()-.5,Math.random()-.5).normalize(),c.position.multiplyScalar(10*Math.random()),c.rotation.set(2*Math.random(),2*Math.random(),2*Math.random()),c.scale.multiplyScalar(Math.random()),s.add(c);this.object=s,t.add(s);var f=new e.Scene;c=new e.Mesh(new e.BoxBufferGeometry(4,4,4)),this.maskObject=c,f.add(c);var v=new Oe(t,n);i.addPass(v),v=new Ee(f,n),this.maskPass=v,i.addPass(v),v=new ke(5),this.pixelationPass=v,i.addPass(v),i.addPass(new we),(v=new ze(new E)).renderToScreen=!0,i.addPass(v)}},{key:"update",value:function(e){var t=this.object,n=this.maskObject,r=void 0;null!==t&&null!==n&&(t.rotation.x+=.001,t.rotation.y+=.005,t.rotation.x>=it&&(t.rotation.x-=it),t.rotation.y>=it&&(t.rotation.y-=it),r=.001*performance.now(),n.position.x=4*Math.cos(r/1.5),n.position.y=4*Math.sin(r),n.rotation.x=r,n.rotation.y=.5*r)}},{key:"configure",value:function(e){var t=this.maskPass,n={"use mask":t.enabled};e.add(this.pixelationPass,"granularity").min(0).max(50).step(.1),e.add(n,"use mask").onChange(function(){t.enabled=n["use mask"]})}}]),n}(),ot=function(t){function n(e){u(this,n);var t=v(this,(n.__proto__||Object.getPrototypeOf(n)).call(this,e));return t.godRaysPass=null,t.sun=null,t.directionalLight=null,t}return f(n,He),c(n,[{key:"load",value:function(t){var n=this,r=new Map,i=this.loadingManager,a=new e.CubeTextureLoader(i),o=new e.TextureLoader(i),s=new e.ObjectLoader(i),l="textures/skies/starry/",u=[l+"px.png",l+"nx.png",l+"py.png",l+"ny.png",l+"pz.png",l+"nz.png"];null===this.assets?(i.onProgress=function(e,i,a){i===a&&(n.assets=r,t())},a.load(u,function(e){r.set("sky",e)}),s.load("models/waggon.json",function(e){e.rotation.x=.25*Math.PI,e.rotation.y=.75*Math.PI,r.set("waggon",e)}),o.load("textures/wood.jpg",function(t){t.wrapS=t.wrapT=e.RepeatWrapping,r.set("wood-diffuse",t)}),o.load("textures/woodnormals.jpg",function(t){t.wrapS=t.wrapT=e.RepeatWrapping,r.set("wood-normals",t)}),o.load("textures/sun.png",function(e){r.set("sun-diffuse",e)})):t()}},{key:"initialise",value:function(){var t=this.scene,n=this.camera,r=this.assets,i=this.composer;this.controls=new e.OrbitControls(n,i.renderer.domElement),this.controls.target.set(0,.5,0),n.position.set(-5,-1,-4),n.lookAt(this.controls.target),t.background=r.get("sky");var a=new e.AmbientLight(986895),o=new e.DirectionalLight(16759722);o.position.set(-1,1,1),o.target.position.copy(t.position),this.directionalLight=o,t.add(o),t.add(a);var s=r.get("waggon"),l=new e.MeshPhongMaterial({color:16777215,map:r.get("wood-diffuse"),normalMap:r.get("wood-normals"),fog:!0});s.traverse(function(e){e.material=l}),t.add(s);var u=new e.PointsMaterial({map:r.get("sun-diffuse"),size:100,sizeAttenuation:!0,color:16768426,alphaTest:0,transparent:!0,fog:!1}),c=new e.BufferGeometry;c.addAttribute("position",new e.BufferAttribute(new Float32Array(3),3));var d=new e.Points(c,u);d.frustumCulled=!1,d.position.set(75,25,100),this.sun=d,t.add(d),i.addPass(new Oe(t,n));var f=new Le(t,n,d,{resolutionScale:.6,kernelSize:C.SMALL,intensity:1,density:.96,decay:.93,weight:.4,exposure:.6,samples:60,clampMax:1});f.renderToScreen=!0,this.godRaysPass=f,i.addPass(f)}},{key:"configure",value:function(e){var t=this.directionalLight,n=this.composer,r=this.godRaysPass,i=this.sun,a={resolution:r.resolutionScale,blurriness:r.kernelSize,intensity:r.intensity,density:r.godRaysMaterial.uniforms.density.value,decay:r.godRaysMaterial.uniforms.decay.value,weight:r.godRaysMaterial.uniforms.weight.value,exposure:r.godRaysMaterial.uniforms.exposure.value,clampMax:r.godRaysMaterial.uniforms.clampMax.value,samples:r.samples,color:i.material.color.getHex(),"blend mode":"screen"};e.add(a,"resolution").min(0).max(1).step(.01).onChange(function(){r.resolutionScale=a.resolution,n.setSize()}),e.add(a,"blurriness").min(C.VERY_SMALL).max(C.HUGE).step(1).onChange(function(){r.kernelSize=a.blurriness}),e.add(a,"intensity").min(0).max(1).step(.01).onChange(function(){r.intensity=a.intensity}),e.add(a,"density").min(0).max(1).step(.01).onChange(function(){r.godRaysMaterial.uniforms.density.value=a.density}),e.add(a,"decay").min(0).max(1).step(.01).onChange(function(){r.godRaysMaterial.uniforms.decay.value=a.decay}),e.add(a,"weight").min(0).max(1).step(.01).onChange(function(){r.godRaysMaterial.uniforms.weight.value=a.weight}),e.add(a,"exposure").min(0).max(1).step(.01).onChange(function(){r.godRaysMaterial.uniforms.exposure.value=a.exposure}),e.add(a,"clampMax").min(0).max(1).step(.01).onChange(function(){r.godRaysMaterial.uniforms.clampMax.value=a.clampMax}),e.add(a,"samples").min(15).max(200).step(1).onChange(function(){r.samples=a.samples}),e.addColor(a,"color").onChange(function(){i.material.color.setHex(a.color),t.color.setHex(a.color)}),e.add(a,"blend mode",["add","screen"]).onChange(function(){"add"===a["blend mode"]?delete r.combineMaterial.defines.SCREEN_MODE:r.combineMaterial.defines.SCREEN_MODE="1",r.combineMaterial.needsUpdate=!0})}}]),n}(),st=2*Math.PI,lt=function(t){function n(e){u(this,n);var t=v(this,(n.__proto__||Object.getPrototypeOf(n)).call(this,e));return t.object=null,t}return f(n,He),c(n,[{key:"load",value:function(t){var n=this,r=new Map,i=this.loadingManager,a=new e.TextureLoader(i),o=new e.CubeTextureLoader(i),s="textures/skies/sunset/",l=[s+"px.png",s+"nx.png",s+"py.png",s+"ny.png",s+"pz.png",s+"nz.png"];null===this.assets?(i.onProgress=function(e,i,a){i===a&&(n.assets=r,t())},o.load(l,function(e){r.set("sky",e)}),a.load("textures/crate.jpg",function(t){t.wrapS=t.wrapT=e.RepeatWrapping,r.set("crate-color",t)})):t()}},{key:"initialise",value:function(){var t=this.scene,n=this.camera,r=this.assets,i=this.composer;this.controls=new e.OrbitControls(n,i.renderer.domElement),n.position.set(-3,0,-3),n.lookAt(this.controls.target),t.background=r.get("sky");var a=new e.AmbientLight(6710886),o=new e.DirectionalLight(16759722);o.position.set(1440,200,2e3),o.target.position.copy(t.position),t.add(o),t.add(a);var s=new e.Mesh(new e.BoxBufferGeometry(1,1,1),new e.MeshPhongMaterial({color:16777215,map:r.get("crate-color")}));this.object=s,t.add(s);var l=new Oe(t,n);l.renderToScreen=!0,i.addPass(l)}},{key:"update",value:function(e){var t=this.object;null!==t&&(t.rotation.x+=5e-4,t.rotation.y+=.001,t.rotation.x>=st&&(t.rotation.x-=st),t.rotation.y>=st&&(t.rotation.y-=st))}}]),n}(),ut=function(t){function n(e){u(this,n);var t=v(this,(n.__proto__||Object.getPrototypeOf(n)).call(this,e));return t.shockWavePass=null,t}return f(n,He),c(n,[{key:"load",value:function(t){var n=this,r=new Map,i=this.loadingManager,a=new e.CubeTextureLoader(i),o="textures/skies/space3/",s=[o+"px.jpg",o+"nx.jpg",o+"py.jpg",o+"ny.jpg",o+"pz.jpg",o+"nz.jpg"];null===this.assets?(i.onProgress=function(e,i,a){i===a&&(n.assets=r,t())},a.load(s,function(e){r.set("sky",e)})):t()}},{key:"initialise",value:function(){var t=this.scene,n=this.camera,r=this.assets,i=this.composer;this.controls=new e.OrbitControls(n,i.renderer.domElement),n.position.set(5,1,5),n.lookAt(this.controls.target),t.background=r.get("sky");var a=new e.AmbientLight(6710886),o=new e.DirectionalLight(16759722);o.position.set(-1,1,1),o.target.position.copy(t.position),t.add(o),t.add(a);var s=new e.SphereBufferGeometry(1,64,64),l=new e.MeshBasicMaterial({color:16776960,envMap:r.get("sky")}),u=new e.Mesh(s,l);t.add(u),i.addPass(new Oe(t,n));var c=new Be(n,u.position,{speed:2,maxRadius:.5,waveSize:.2,amplitude:.05});c.renderToScreen=!0,this.shockWavePass=c,i.addPass(c)}},{key:"configure",value:function(e){var t=this.shockWavePass,n={speed:t.speed,size:t.shockWaveMaterial.uniforms.size.value,extent:t.shockWaveMaterial.uniforms.maxRadius.value,waveSize:t.shockWaveMaterial.uniforms.waveSize.value,amplitude:t.shockWaveMaterial.uniforms.amplitude.value,explode:function(){t.explode()}};e.add(n,"speed").min(0).max(10).step(.001).onChange(function(){t.speed=n.speed}),e.add(n,"size").min(.01).max(2).step(.001).onChange(function(){t.shockWaveMaterial.uniforms.size.value=n.size}),e.add(n,"extent").min(0).max(10).step(.001).onChange(function(){t.shockWaveMaterial.uniforms.maxRadius.value=n.extent}),e.add(n,"waveSize").min(0).max(2).step(.001).onChange(function(){t.shockWaveMaterial.uniforms.waveSize.value=n.waveSize}),e.add(n,"amplitude").min(0).max(.25).step(.001).onChange(function(){t.shockWaveMaterial.uniforms.amplitude.value=n.amplitude}),e.add(n,"explode")}}]),n}(),ct=2*Math.PI,dt=function(t){function n(e){u(this,n);var t=v(this,(n.__proto__||Object.getPrototypeOf(n)).call(this,e));return t.renderer=null,t.renderer2=null,t.controls2=null,t.renderPass=null,t.smaaPass=null,t.objectA=null,t.objectB=null,t.objectC=null,t}return f(n,He),c(n,[{key:"load",value:function(t){var n=this,r=new Map,i=this.loadingManager,a=new e.TextureLoader(i),o=new e.CubeTextureLoader(i),s="textures/skies/sunset/",l=[s+"px.png",s+"nx.png",s+"py.png",s+"ny.png",s+"pz.png",s+"nz.png"];null===this.assets?(i.onProgress=function(e,i,a){i===a&&(n.assets=r,t())},o.load(l,function(e){r.set("sky",e)}),a.load("textures/crate.jpg",function(t){t.wrapS=t.wrapT=e.RepeatWrapping,r.set("crate-color",t)})):t()}},{key:"initialise",value:function(){var t=this.scene,n=this.camera,r=this.assets,i=this.composer;this.renderer2=function(){var t=new e.WebGLRenderer({logarithmicDepthBuffer:!0,antialias:!1});return t.setSize(window.innerWidth,window.innerHeight),t.setClearColor(0),t.setPixelRatio(window.devicePixelRatio),t}(),this.renderer=i.replaceRenderer(this.renderer2),this.controls=new e.OrbitControls(n,this.renderer.domElement),this.controls2=new e.OrbitControls(n,this.renderer2.domElement),n.position.set(-3,0,-3),n.lookAt(this.controls.target),t.background=r.get("sky");var a=new e.AmbientLight(6710886),o=new e.DirectionalLight(16759722);o.position.set(1440,200,2e3),o.target.position.copy(t.position),t.add(o),t.add(a);var s=new e.Mesh(new e.BoxBufferGeometry(1,1,1),new e.MeshBasicMaterial({color:0,wireframe:!0}));s.position.set(1.25,0,-1.25),this.objectA=s,t.add(s),(s=new e.Mesh(new e.BoxBufferGeometry(1,1,1),new e.MeshPhongMaterial({map:r.get("crate-color")}))).position.set(-1.25,0,1.25),this.objectB=s,t.add(s),s=new e.Mesh(new e.BoxBufferGeometry(.25,8.25,.25),new e.MeshPhongMaterial({color:855309}));var l=new e.Object3D,u=void 0,c=void 0,d=void 0;u=l.clone();var f=s.clone();f.position.set(-4,0,4),u.add(f),(f=s.clone()).position.set(4,0,4),u.add(f),(f=s.clone()).position.set(-4,0,-4),u.add(f),(f=s.clone()).position.set(4,0,-4),u.add(f),(c=u.clone()).rotation.set(Math.PI/2,0,0),(d=u.clone()).rotation.set(0,0,Math.PI/2),l.add(u),l.add(c),l.add(d),l.scale.set(.1,.1,.1),this.objectC=l,t.add(l);var v=new Oe(t,n);this.renderPass=v,i.addPass(v),(v=new Re(Image)).renderToScreen=!0,this.smaaPass=v,i.addPass(v)}},{key:"update",value:function(e){var t=this.objectA,n=this.objectB,r=this.objectC;null!==t&&(t.rotation.x+=5e-4,t.rotation.y+=.001,n.rotation.copy(t.rotation),r.rotation.copy(t.rotation),t.rotation.x>=ct&&(t.rotation.x-=ct),t.rotation.y>=ct&&(t.rotation.y-=ct))}},{key:"configure",value:function(e){var t=this.composer,n=this.renderPass,r=this.smaaPass,i=this.renderer,a=this.renderer2,o=this.controls,s=this.controls2,l={"browser AA":!1,SMAA:r.enabled,"SMAA threshold":Number.parseFloat(r.colorEdgesMaterial.defines.EDGE_THRESHOLD)};e.add(l,"browser AA").onChange(function(){var e=t.renderer.getSize();l["browser AA"]?(i.setSize(e.width,e.height),t.replaceRenderer(i),o.enabled=!0,s.enabled=!1):(a.setSize(e.width,e.height),t.replaceRenderer(a),o.enabled=!1,s.enabled=!0)}),e.add(l,"SMAA").onChange(function(){n.renderToScreen=!l.SMAA,r.enabled=l.SMAA}),e.add(l,"SMAA threshold").min(0).max(1).step(.01).onChange(function(){r.colorEdgesMaterial.defines.EDGE_THRESHOLD=l["SMAA threshold"].toFixed(2),r.colorEdgesMaterial.needsUpdate=!0})}},{key:"reset",value:function(){d(n.prototype.__proto__||Object.getPrototypeOf(n.prototype),"reset",this).call(this),this.renderer.dispose(),this.renderer=null,this.controls2.dispose(),this.controls2=null}}]),n}(),ft=2*Math.PI,vt=function(t){function n(e){u(this,n);var t=v(this,(n.__proto__||Object.getPrototypeOf(n)).call(this,e));return t.toneMappingPass=null,t.object=null,t}return f(n,He),c(n,[{key:"load",value:function(t){var n=this,r=new Map,i=this.loadingManager,a=new e.TextureLoader(i),o=new e.CubeTextureLoader(i),s="textures/skies/sunset/",l=[s+"px.png",s+"nx.png",s+"py.png",s+"ny.png",s+"pz.png",s+"nz.png"];null===this.assets?(i.onProgress=function(e,i,a){i===a&&(n.assets=r,t())},o.load(l,function(e){r.set("sky",e)}),a.load("textures/crate.jpg",function(t){t.wrapS=t.wrapT=e.RepeatWrapping,r.set("crate-color",t)})):t()}},{key:"initialise",value:function(){var t=this.scene,n=this.camera,r=this.assets,i=this.composer;this.controls=new e.OrbitControls(n,i.renderer.domElement),n.position.set(-3,0,-3),n.lookAt(this.controls.target),t.background=r.get("sky");var a=new e.AmbientLight(6710886),o=new e.DirectionalLight(16759722);o.position.set(1440,200,2e3),o.target.position.copy(t.position),t.add(o),t.add(a);var s=new e.Mesh(new e.BoxBufferGeometry(1,1,1),new e.MeshPhongMaterial({map:r.get("crate-color")}));this.object=s,t.add(s),i.addPass(new Oe(t,n));var l=new Ge({adaptive:!0,resolution:256,distinction:1});l.renderToScreen=!0,this.toneMappingPass=l,i.addPass(l)}},{key:"update",value:function(e){var t=this.object;null!==t&&(t.rotation.x+=5e-4,t.rotation.y+=.001,t.rotation.x>=ft&&(t.rotation.x-=ft),t.rotation.y>=ft&&(t.rotation.y-=ft))}},{key:"configure",value:function(e){var t=this.toneMappingPass,n={resolution:Math.round(Math.log(t.resolution)/Math.log(2)),adaptive:t.adaptive,distinction:t.luminosityMaterial.uniforms.distinction.value,"adaption rate":t.adaptiveLuminosityMaterial.uniforms.tau.value,"average lum":t.toneMappingMaterial.uniforms.averageLuminance.value,"min lum":t.adaptiveLuminosityMaterial.uniforms.minLuminance.value,"max lum":t.toneMappingMaterial.uniforms.maxLuminance.value,"middle grey":t.toneMappingMaterial.uniforms.middleGrey.value};e.add(n,"resolution").min(6).max(11).step(1).onChange(function(){t.resolution=Math.pow(2,n.resolution)}),e.add(n,"adaptive").onChange(function(){t.adaptive=n.adaptive});var r=e.addFolder("Luminance");r.add(n,"distinction").min(1).max(10).step(.1).onChange(function(){t.luminosityMaterial.uniforms.distinction.value=n.distinction}),r.add(n,"adaption rate").min(0).max(2).step(.01).onChange(function(){t.adaptiveLuminosityMaterial.uniforms.tau.value=n["adaption rate"]}),r.add(n,"average lum").min(.01).max(1).step(.01).onChange(function(){t.toneMappingMaterial.uniforms.averageLuminance.value=n["average lum"]}),r.add(n,"min lum").min(0).max(1).step(.01).onChange(function(){t.adaptiveLuminosityMaterial.uniforms.minLuminance.value=n["min lum"]}),r.add(n,"max lum").min(0).max(32).step(1).onChange(function(){t.toneMappingMaterial.uniforms.maxLuminance.value=n["max lum"]}),r.add(n,"middle grey").min(0).max(1).step(.01).onChange(function(){t.toneMappingMaterial.uniforms.middleGrey.value=n["middle grey"]}),r.open()}}]),n}(),ht=function(){function r(){u(this,r),this.clock=new e.Clock,this.composer=function(){var t=new e.WebGLRenderer({logarithmicDepthBuffer:!0,antialias:!0});return t.setSize(window.innerWidth,window.innerHeight),t.setClearColor(0),t.setPixelRatio(window.devicePixelRatio),new We(t,{stencilBuffer:!0,depthTexture:!0})}(),this.stats=function(){var e=new n;return e.showPanel(0),e.dom.id="stats",e}(),this.demos=function(e){var t=new Map;return t.set("render",new lt(e)),t.set("bloom",new Ve(e)),t.set("blur",new Ze(e)),t.set("bokeh",new Ye(e)),t.set("bokeh2",new qe(e)),t.set("depth",new Qe(e)),t.set("dot-screen",new $e(e)),t.set("film",new tt(e)),t.set("glitch",new rt(e)),t.set("god-rays",new ot(e)),t.set("pixelation",new at(e)),t.set("shock-wave",new ut(e)),t.set("smaa",new dt(e)),t.set("tone-mapping",new vt(e)),t}(this.composer),this.effect=function(e){var t=window.location.hash.slice(1);return 0!==t.length&&e.has(t)||(t=e.keys().next().value),t}(this.demos)}return c(r,[{key:"initialise",value:function(e,n,r){function i(){f.initialise(),f.camera.aspect=window.innerWidth/window.innerHeight,f.camera.updateProjectionMatrix(),(v=new t.GUI({autoPlace:!1})).add(o,"effect",Array.from(d.keys())).onChange(a),f.configure(v),n.appendChild(v.domElement),r.style.display="none",l.domElement.style.visibility="visible"}function a(){var e=l.getSize();r.style.display="block",l.domElement.style.visibility="hidden",null!==v&&(v.destroy(),n.removeChild(v.domElement)),null!==f&&(f.reset(),l.setSize(e.width,e.height),s.replaceRenderer(l)),s.reset(),(f=d.get(o.effect)).load(i)}var o=this,s=this.composer,l=s.renderer,u=this.clock,c=this.stats,d=this.demos,f=null,v=null;e.appendChild(l.domElement),n.appendChild(c.dom),a(),document.addEventListener("keydown",function(e){e.altKey&&(e.preventDefault(),n.style.visibility="hidden"===n.style.visibility?"visible":"hidden")}),window.addEventListener("resize",function(){function e(e){var n=e.target.innerWidth,r=e.target.innerHeight;s.setSize(n,r),f.camera.aspect=n/r,f.camera.updateProjectionMatrix(),t=0}var t=0;return function(n){0===t&&(t=setTimeout(e,66,n))}}()),function e(t){var n=u.getDelta();requestAnimationFrame(e),c.begin(),f.update(n),s.render(n),c.end()}()}}]),r}();window.addEventListener("load",function e(t){var n=document.getElementById("viewport"),r=n.children[0],i=document.getElementById("aside"),a=new ht;window.removeEventListener("load",e),i.style.visibility="visible",a.initialise(n,i,r)})}(THREE,dat,Stats); \ No newline at end of file