viral-viewer-2 6.2.1 → 6.2.4
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +0 -0
- package/dist/index.js +2 -21
- package/dist/index.js.LICENSE.txt +19 -0
- package/dist/threejs-addon/n8ao/post-processing.d.ts +109 -109
- package/package.json +6 -4
- package/dist/components/animation/viral-animation.js +0 -59
- package/dist/components/animation/viral-animation.js.map +0 -1
- package/dist/components/bvh/viral-bvh.js +0 -19
- package/dist/components/bvh/viral-bvh.js.map +0 -1
- package/dist/components/camera/viral-camera.js +0 -201
- package/dist/components/camera/viral-camera.js.map +0 -1
- package/dist/components/centralized-event-handler/viral-centralized-event-handler.d.ts +0 -7
- package/dist/components/centralized-event-handler/viral-centralized-event-handler.js +0 -47
- package/dist/components/centralized-event-handler/viral-centralized-event-handler.js.map +0 -1
- package/dist/components/compress/viral-compress.processor.js +0 -13
- package/dist/components/compress/viral-compress.processor.js.map +0 -1
- package/dist/components/context-menu/viral-context-menu.d.ts +0 -17
- package/dist/components/context-menu/viral-context-menu.js +0 -74
- package/dist/components/context-menu/viral-context-menu.js.map +0 -1
- package/dist/components/custom-objects/index.js +0 -6
- package/dist/components/custom-objects/index.js.map +0 -1
- package/dist/components/custom-objects/viral-instanced-mesh.js +0 -200
- package/dist/components/custom-objects/viral-instanced-mesh.js.map +0 -1
- package/dist/components/data-manager/viral-data-manager.js +0 -35
- package/dist/components/data-manager/viral-data-manager.js.map +0 -1
- package/dist/components/event-handler/base/event-dispatcher.js +0 -35
- package/dist/components/event-handler/base/event-dispatcher.js.map +0 -1
- package/dist/components/event-handler/keyboard/viral-keyboard.js +0 -76
- package/dist/components/event-handler/keyboard/viral-keyboard.js.map +0 -1
- package/dist/components/event-handler/mouse/viral-mouse.js +0 -234
- package/dist/components/event-handler/mouse/viral-mouse.js.map +0 -1
- package/dist/components/event-handler/viral-centralized-event-handler.js +0 -158
- package/dist/components/event-handler/viral-centralized-event-handler.js.map +0 -1
- package/dist/components/event-handler/viral-lifecycle-event-handler.js +0 -55
- package/dist/components/event-handler/viral-lifecycle-event-handler.js.map +0 -1
- package/dist/components/keyboard/viral-keyboard.d.ts +0 -17
- package/dist/components/keyboard/viral-keyboard.js +0 -76
- package/dist/components/keyboard/viral-keyboard.js.map +0 -1
- package/dist/components/loader/viral-point-cloud.loader.js +0 -33
- package/dist/components/loader/viral-point-cloud.loader.js.map +0 -1
- package/dist/components/loader/viral-revit.loader.js +0 -119
- package/dist/components/loader/viral-revit.loader.js.map +0 -1
- package/dist/components/loader/viral-three.loader.js +0 -20
- package/dist/components/loader/viral-three.loader.js.map +0 -1
- package/dist/components/loader/viral.loader.js +0 -16
- package/dist/components/loader/viral.loader.js.map +0 -1
- package/dist/components/material/viral-material-manager.js +0 -60
- package/dist/components/material/viral-material-manager.js.map +0 -1
- package/dist/components/mouse/viral-mouse.d.ts +0 -31
- package/dist/components/mouse/viral-mouse.js +0 -234
- package/dist/components/mouse/viral-mouse.js.map +0 -1
- package/dist/components/navigation-cube/components/cube-camera.d.ts +0 -15
- package/dist/components/navigation-cube/components/cube-camera.js +0 -74
- package/dist/components/navigation-cube/components/cube-camera.js.map +0 -1
- package/dist/components/navigation-cube/components/cube-renderer.d.ts +0 -9
- package/dist/components/navigation-cube/components/cube-renderer.js +0 -31
- package/dist/components/navigation-cube/components/cube-renderer.js.map +0 -1
- package/dist/components/navigation-cube/components/cube-scene.d.ts +0 -13
- package/dist/components/navigation-cube/components/cube-scene.js +0 -546
- package/dist/components/navigation-cube/components/cube-scene.js.map +0 -1
- package/dist/components/navigation-cube/components/cube.mouse.d.ts +0 -9
- package/dist/components/navigation-cube/components/cube.mouse.js +0 -109
- package/dist/components/navigation-cube/components/cube.mouse.js.map +0 -1
- package/dist/components/navigation-cube/viral-navigation-cube.d.ts +0 -16
- package/dist/components/navigation-cube/viral-navigation-cube.js +0 -50
- package/dist/components/navigation-cube/viral-navigation-cube.js.map +0 -1
- package/dist/components/post-processing/ambient-occlusion-effect.d.ts +0 -11
- package/dist/components/post-processing/ambient-occlusion-effect.js +0 -32
- package/dist/components/post-processing/ambient-occlusion-effect.js.map +0 -1
- package/dist/components/post-processing/bloom-effect.d.ts +0 -11
- package/dist/components/post-processing/bloom-effect.js +0 -29
- package/dist/components/post-processing/bloom-effect.js.map +0 -1
- package/dist/components/post-processing/outline-effect.d.ts +0 -13
- package/dist/components/post-processing/outline-effect.js +0 -33
- package/dist/components/post-processing/outline-effect.js.map +0 -1
- package/dist/components/post-processing/post-processing-renderer.js +0 -46
- package/dist/components/post-processing/post-processing-renderer.js.map +0 -1
- package/dist/components/post-processing/viral-post-processing.d.ts +0 -11
- package/dist/components/post-processing/viral-post-processing.js +0 -29
- package/dist/components/post-processing/viral-post-processing.js.map +0 -1
- package/dist/components/renderer/viral-renderer.js +0 -51
- package/dist/components/renderer/viral-renderer.js.map +0 -1
- package/dist/components/scene/viral-scene.js +0 -129
- package/dist/components/scene/viral-scene.js.map +0 -1
- package/dist/components/spinner/viral-spinner.d.ts +0 -10
- package/dist/components/spinner/viral-spinner.js +0 -207
- package/dist/components/spinner/viral-spinner.js.map +0 -1
- package/dist/components/stats/viral-stats.js +0 -17
- package/dist/components/stats/viral-stats.js.map +0 -1
- package/dist/components/tools/tools/viral-tool-ambient-occlusion.d.ts +0 -7
- package/dist/components/tools/tools/viral-tool-ambient-occlusion.js +0 -16
- package/dist/components/tools/tools/viral-tool-ambient-occlusion.js.map +0 -1
- package/dist/components/tools/tools/viral-tool-dark-mode.d.ts +0 -7
- package/dist/components/tools/tools/viral-tool-dark-mode.js +0 -21
- package/dist/components/tools/tools/viral-tool-dark-mode.js.map +0 -1
- package/dist/components/tools/tools/viral-tool-elevation.d.ts +0 -11
- package/dist/components/tools/tools/viral-tool-elevation.js +0 -30
- package/dist/components/tools/tools/viral-tool-elevation.js.map +0 -1
- package/dist/components/tools/tools/viral-tool-measure.d.ts +0 -33
- package/dist/components/tools/tools/viral-tool-measure.js +0 -243
- package/dist/components/tools/tools/viral-tool-measure.js.map +0 -1
- package/dist/components/tools/tools/viral-tool-sunlight.d.ts +0 -7
- package/dist/components/tools/tools/viral-tool-sunlight.js +0 -46
- package/dist/components/tools/tools/viral-tool-sunlight.js.map +0 -1
- package/dist/components/tools/viral-tools.d.ts +0 -32
- package/dist/components/tools/viral-tools.js +0 -213
- package/dist/components/tools/viral-tools.js.map +0 -1
- package/dist/components/visibility-manager/viral-visibility-manager.js +0 -168
- package/dist/components/visibility-manager/viral-visibility-manager.js.map +0 -1
- package/dist/components/worker/base/worker-pool.js +0 -68
- package/dist/components/worker/base/worker-pool.js.map +0 -1
- package/dist/components/worker/base/worker-thread.js +0 -35
- package/dist/components/worker/base/worker-thread.js.map +0 -1
- package/dist/components/worker/fetch-data.worker.js +0 -31
- package/dist/components/worker/fetch-data.worker.js.map +0 -1
- package/dist/components/worker/viral-viewer-2.worker.js +0 -127
- package/dist/components/worker/viral-viewer-2.worker.js.map +0 -1
- package/dist/components/worker/viral-viewer-3.worker.js +0 -82
- package/dist/components/worker/viral-viewer-3.worker.js.map +0 -1
- package/dist/components/worker/viral-viewer-4.worker.js +0 -97
- package/dist/components/worker/viral-viewer-4.worker.js.map +0 -1
- package/dist/components/worker/viral-viewer.worker.js +0 -107
- package/dist/components/worker/viral-viewer.worker.js.map +0 -1
- package/dist/components/worker-script/fetch-data-worker.script.js +0 -56
- package/dist/components/worker-script/fetch-data-worker.script.js.map +0 -1
- package/dist/components/worker-script/load-model-worker-2.script.js +0 -2704
- package/dist/components/worker-script/load-model-worker-2.script.js.map +0 -1
- package/dist/components/worker-script/load-model-worker-3.script.js +0 -34170
- package/dist/components/worker-script/load-model-worker-3.script.js.map +0 -1
- package/dist/components/worker-script/load-model-worker.script.js +0 -148
- package/dist/components/worker-script/load-model-worker.script.js.map +0 -1
- package/dist/components/worker-script/threejs.types.js +0 -34162
- package/dist/components/worker-script/threejs.types.js.map +0 -1
- package/dist/const/colors.js +0 -38
- package/dist/const/colors.js.map +0 -1
- package/dist/const/fonts.js +0 -17
- package/dist/const/fonts.js.map +0 -1
- package/dist/gui/context-menu/viral-context-menu.js +0 -74
- package/dist/gui/context-menu/viral-context-menu.js.map +0 -1
- package/dist/gui/draggable-modal/viral-draggable-modal.js +0 -91
- package/dist/gui/draggable-modal/viral-draggable-modal.js.map +0 -1
- package/dist/gui/fonts/fonts.js +0 -20
- package/dist/gui/fonts/fonts.js.map +0 -1
- package/dist/gui/navigation-cube/components/cube-camera.js +0 -74
- package/dist/gui/navigation-cube/components/cube-camera.js.map +0 -1
- package/dist/gui/navigation-cube/components/cube-renderer.js +0 -31
- package/dist/gui/navigation-cube/components/cube-renderer.js.map +0 -1
- package/dist/gui/navigation-cube/components/cube-scene.js +0 -546
- package/dist/gui/navigation-cube/components/cube-scene.js.map +0 -1
- package/dist/gui/navigation-cube/components/cube.mouse.js +0 -109
- package/dist/gui/navigation-cube/components/cube.mouse.js.map +0 -1
- package/dist/gui/navigation-cube/viral-navigation-cube.js +0 -50
- package/dist/gui/navigation-cube/viral-navigation-cube.js.map +0 -1
- package/dist/gui/spinner/viral-spinner.js +0 -102
- package/dist/gui/spinner/viral-spinner.js.map +0 -1
- package/dist/gui/tools/tools/viral-tool-ambient-occlusion.js +0 -16
- package/dist/gui/tools/tools/viral-tool-ambient-occlusion.js.map +0 -1
- package/dist/gui/tools/tools/viral-tool-dark-mode.js +0 -21
- package/dist/gui/tools/tools/viral-tool-dark-mode.js.map +0 -1
- package/dist/gui/tools/tools/viral-tool-elevation.js +0 -30
- package/dist/gui/tools/tools/viral-tool-elevation.js.map +0 -1
- package/dist/gui/tools/tools/viral-tool-measure.js +0 -243
- package/dist/gui/tools/tools/viral-tool-measure.js.map +0 -1
- package/dist/gui/tools/tools/viral-tool-sunlight.js +0 -46
- package/dist/gui/tools/tools/viral-tool-sunlight.js.map +0 -1
- package/dist/gui/tools/viral-tools.js +0 -213
- package/dist/gui/tools/viral-tools.js.map +0 -1
- package/dist/index.js.map +0 -1
- package/dist/models/dictionary.model.d.ts +0 -0
- package/dist/models/dictionary.model.js +0 -1
- package/dist/models/dictionary.model.js.map +0 -1
- package/dist/services/local-storage.service.js +0 -57
- package/dist/services/local-storage.service.js.map +0 -1
- package/dist/threejs-addon/buffer-geometry-utils.d.ts +0 -64
- package/dist/threejs-addon/buffer-geometry-utils.js +0 -807
- package/dist/threejs-addon/buffer-geometry-utils.js.map +0 -1
- package/dist/threejs-addon/gltf-loader.d.ts +0 -17
- package/dist/threejs-addon/gltf-loader.js +0 -2796
- package/dist/threejs-addon/gltf-loader.js.map +0 -1
- package/dist/threejs-addon/n8ao/n8ao.js +0 -1952
- package/dist/threejs-addon/n8ao/n8ao.js.map +0 -1
- package/dist/threejs-addon/n8ao/post-processing.js +0 -15145
- package/dist/threejs-addon/n8ao/post-processing.js.map +0 -1
- package/dist/threejs-addon/post-processing/effect-composer.d.ts +0 -27
- package/dist/threejs-addon/post-processing/effect-composer.js +0 -134
- package/dist/threejs-addon/post-processing/effect-composer.js.map +0 -1
- package/dist/threejs-addon/post-processing/mask-pass.d.ts +0 -11
- package/dist/threejs-addon/post-processing/mask-pass.js +0 -69
- package/dist/threejs-addon/post-processing/mask-pass.js.map +0 -1
- package/dist/threejs-addon/post-processing/outline-pass.d.ts +0 -58
- package/dist/threejs-addon/post-processing/outline-pass.js +0 -484
- package/dist/threejs-addon/post-processing/outline-pass.js.map +0 -1
- package/dist/threejs-addon/post-processing/output-pass.d.ts +0 -11
- package/dist/threejs-addon/post-processing/output-pass.js +0 -61
- package/dist/threejs-addon/post-processing/output-pass.js.map +0 -1
- package/dist/threejs-addon/post-processing/pass.d.ts +0 -20
- package/dist/threejs-addon/post-processing/pass.js +0 -48
- package/dist/threejs-addon/post-processing/pass.js.map +0 -1
- package/dist/threejs-addon/post-processing/render-pass.d.ts +0 -13
- package/dist/threejs-addon/post-processing/render-pass.js +0 -50
- package/dist/threejs-addon/post-processing/render-pass.js.map +0 -1
- package/dist/threejs-addon/post-processing/sao-pass.d.ts +0 -62
- package/dist/threejs-addon/post-processing/sao-pass.js +0 -296
- package/dist/threejs-addon/post-processing/sao-pass.js.map +0 -1
- package/dist/threejs-addon/post-processing/shader-pass.d.ts +0 -11
- package/dist/threejs-addon/post-processing/shader-pass.js +0 -48
- package/dist/threejs-addon/post-processing/shader-pass.js.map +0 -1
- package/dist/threejs-addon/post-processing/ssaa-render-pass.d.ts +0 -30
- package/dist/threejs-addon/post-processing/ssaa-render-pass.js +0 -202
- package/dist/threejs-addon/post-processing/ssaa-render-pass.js.map +0 -1
- package/dist/threejs-addon/post-processing/unreal-bloom-pass.d.ts +0 -48
- package/dist/threejs-addon/post-processing/unreal-bloom-pass.js +0 -290
- package/dist/threejs-addon/post-processing/unreal-bloom-pass.js.map +0 -1
- package/dist/threejs-addon/shaders/color-correction-shader.d.ts +0 -22
- package/dist/threejs-addon/shaders/color-correction-shader.js +0 -43
- package/dist/threejs-addon/shaders/color-correction-shader.js.map +0 -1
- package/dist/threejs-addon/shaders/copy-shader.d.ts +0 -13
- package/dist/threejs-addon/shaders/copy-shader.js +0 -39
- package/dist/threejs-addon/shaders/copy-shader.js.map +0 -1
- package/dist/threejs-addon/shaders/depth-limited-blur-shader.d.ts +0 -48
- package/dist/threejs-addon/shaders/depth-limited-blur-shader.js +0 -142
- package/dist/threejs-addon/shaders/depth-limited-blur-shader.js.map +0 -1
- package/dist/threejs-addon/shaders/fxaa-shader.d.ts +0 -14
- package/dist/threejs-addon/shaders/fxaa-shader.js +0 -279
- package/dist/threejs-addon/shaders/fxaa-shader.js.map +0 -1
- package/dist/threejs-addon/shaders/luminosity-high-pass-shader.d.ts +0 -27
- package/dist/threejs-addon/shaders/luminosity-high-pass-shader.js +0 -56
- package/dist/threejs-addon/shaders/luminosity-high-pass-shader.js.map +0 -1
- package/dist/threejs-addon/shaders/output-shader.d.ts +0 -13
- package/dist/threejs-addon/shaders/output-shader.js +0 -72
- package/dist/threejs-addon/shaders/output-shader.js.map +0 -1
- package/dist/threejs-addon/shaders/sao-shader.d.ts +0 -71
- package/dist/threejs-addon/shaders/sao-shader.js +0 -180
- package/dist/threejs-addon/shaders/sao-shader.js.map +0 -1
- package/dist/threejs-addon/shaders/unpack-depth-rgba-shader.d.ts +0 -13
- package/dist/threejs-addon/shaders/unpack-depth-rgba-shader.js +0 -41
- package/dist/threejs-addon/shaders/unpack-depth-rgba-shader.js.map +0 -1
- package/dist/threejs-addon/simplify-modifier.d.ts +0 -4
- package/dist/threejs-addon/simplify-modifier.js +0 -325
- package/dist/threejs-addon/simplify-modifier.js.map +0 -1
- package/dist/threejs-addon/stats.js +0 -102
- package/dist/threejs-addon/stats.js.map +0 -1
- package/dist/threejs-addon/transform-control.d.ts +0 -74
- package/dist/threejs-addon/transform-control.js +0 -1033
- package/dist/threejs-addon/transform-control.js.map +0 -1
- package/dist/types.js +0 -145
- package/dist/types.js.map +0 -1
- package/dist/utils/html.js +0 -12
- package/dist/utils/html.js.map +0 -1
- package/dist/utils/index.js +0 -10
- package/dist/utils/index.js.map +0 -1
- package/dist/utils/log.js +0 -14
- package/dist/utils/log.js.map +0 -1
- package/dist/utils/threejs.js +0 -44
- package/dist/utils/threejs.js.map +0 -1
- package/dist/viral-viewer-api.js +0 -73
- package/dist/viral-viewer-api.js.map +0 -1
|
@@ -1,39 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
/**
|
|
3
|
-
* Full-screen textured quad shader
|
|
4
|
-
*/
|
|
5
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
-
exports.CopyShader = void 0;
|
|
7
|
-
const CopyShader = {
|
|
8
|
-
uniforms: {
|
|
9
|
-
'tDiffuse': { value: null },
|
|
10
|
-
'opacity': { value: 1.0 }
|
|
11
|
-
},
|
|
12
|
-
vertexShader: /* glsl */ `
|
|
13
|
-
|
|
14
|
-
varying vec2 vUv;
|
|
15
|
-
|
|
16
|
-
void main() {
|
|
17
|
-
|
|
18
|
-
vUv = uv;
|
|
19
|
-
gl_Position = projectionMatrix * modelViewMatrix * vec4( position, 1.0 );
|
|
20
|
-
|
|
21
|
-
}`,
|
|
22
|
-
fragmentShader: /* glsl */ `
|
|
23
|
-
|
|
24
|
-
uniform float opacity;
|
|
25
|
-
|
|
26
|
-
uniform sampler2D tDiffuse;
|
|
27
|
-
|
|
28
|
-
varying vec2 vUv;
|
|
29
|
-
|
|
30
|
-
void main() {
|
|
31
|
-
|
|
32
|
-
gl_FragColor = texture2D( tDiffuse, vUv );
|
|
33
|
-
gl_FragColor.a *= opacity;
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
}`
|
|
37
|
-
};
|
|
38
|
-
exports.CopyShader = CopyShader;
|
|
39
|
-
//# sourceMappingURL=copy-shader.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"copy-shader.js","sourceRoot":"","sources":["../../../src/threejs-addon/shaders/copy-shader.js"],"names":[],"mappings":";AAAA;;GAEG;;;AAEH,MAAM,UAAU,GAAG;IAEf,QAAQ,EAAE;QAEN,UAAU,EAAE,EAAE,KAAK,EAAE,IAAI,EAAE;QAC3B,SAAS,EAAE,EAAE,KAAK,EAAE,GAAG,EAAE;KAE5B;IAED,YAAY,EAAE,UAAU,CAAC;;;;;;;;;IASzB;IAEA,cAAc,EAAE,UAAU,CAAC;;;;;;;;;;;;;;IAc3B;CAEH,CAAC;AAEO,gCAAU"}
|
|
@@ -1,48 +0,0 @@
|
|
|
1
|
-
export namespace DepthLimitedBlurShader {
|
|
2
|
-
namespace defines {
|
|
3
|
-
const KERNEL_RADIUS: number;
|
|
4
|
-
const DEPTH_PACKING: number;
|
|
5
|
-
const PERSPECTIVE_CAMERA: number;
|
|
6
|
-
}
|
|
7
|
-
namespace uniforms {
|
|
8
|
-
namespace tDiffuse {
|
|
9
|
-
const value: null;
|
|
10
|
-
}
|
|
11
|
-
namespace size {
|
|
12
|
-
const value_1: Vector2;
|
|
13
|
-
export { value_1 as value };
|
|
14
|
-
}
|
|
15
|
-
namespace sampleUvOffsets {
|
|
16
|
-
const value_2: Vector2[];
|
|
17
|
-
export { value_2 as value };
|
|
18
|
-
}
|
|
19
|
-
namespace sampleWeights {
|
|
20
|
-
const value_3: number[];
|
|
21
|
-
export { value_3 as value };
|
|
22
|
-
}
|
|
23
|
-
namespace tDepth {
|
|
24
|
-
const value_4: null;
|
|
25
|
-
export { value_4 as value };
|
|
26
|
-
}
|
|
27
|
-
namespace cameraNear {
|
|
28
|
-
const value_5: number;
|
|
29
|
-
export { value_5 as value };
|
|
30
|
-
}
|
|
31
|
-
namespace cameraFar {
|
|
32
|
-
const value_6: number;
|
|
33
|
-
export { value_6 as value };
|
|
34
|
-
}
|
|
35
|
-
namespace depthCutoff {
|
|
36
|
-
const value_7: number;
|
|
37
|
-
export { value_7 as value };
|
|
38
|
-
}
|
|
39
|
-
}
|
|
40
|
-
const vertexShader: string;
|
|
41
|
-
const fragmentShader: string;
|
|
42
|
-
}
|
|
43
|
-
export namespace BlurShaderUtils {
|
|
44
|
-
function createSampleWeights(kernelRadius: any, stdDev: any): number[];
|
|
45
|
-
function createSampleOffsets(kernelRadius: any, uvIncrement: any): any[];
|
|
46
|
-
function configure(material: any, kernelRadius: any, stdDev: any, uvIncrement: any): void;
|
|
47
|
-
}
|
|
48
|
-
import { Vector2 } from 'three';
|
|
@@ -1,142 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.BlurShaderUtils = exports.DepthLimitedBlurShader = void 0;
|
|
4
|
-
const three_1 = require("three");
|
|
5
|
-
/**
|
|
6
|
-
* TODO
|
|
7
|
-
*/
|
|
8
|
-
const DepthLimitedBlurShader = {
|
|
9
|
-
defines: {
|
|
10
|
-
'KERNEL_RADIUS': 4,
|
|
11
|
-
'DEPTH_PACKING': 1,
|
|
12
|
-
'PERSPECTIVE_CAMERA': 1
|
|
13
|
-
},
|
|
14
|
-
uniforms: {
|
|
15
|
-
'tDiffuse': { value: null },
|
|
16
|
-
'size': { value: new three_1.Vector2(512, 512) },
|
|
17
|
-
'sampleUvOffsets': { value: [new three_1.Vector2(0, 0)] },
|
|
18
|
-
'sampleWeights': { value: [1.0] },
|
|
19
|
-
'tDepth': { value: null },
|
|
20
|
-
'cameraNear': { value: 10 },
|
|
21
|
-
'cameraFar': { value: 1000 },
|
|
22
|
-
'depthCutoff': { value: 10 },
|
|
23
|
-
},
|
|
24
|
-
vertexShader: /* glsl */ `
|
|
25
|
-
|
|
26
|
-
#include <common>
|
|
27
|
-
|
|
28
|
-
uniform vec2 size;
|
|
29
|
-
|
|
30
|
-
varying vec2 vUv;
|
|
31
|
-
varying vec2 vInvSize;
|
|
32
|
-
|
|
33
|
-
void main() {
|
|
34
|
-
vUv = uv;
|
|
35
|
-
vInvSize = 1.0 / size;
|
|
36
|
-
|
|
37
|
-
gl_Position = projectionMatrix * modelViewMatrix * vec4( position, 1.0 );
|
|
38
|
-
}`,
|
|
39
|
-
fragmentShader: /* glsl */ `
|
|
40
|
-
|
|
41
|
-
#include <common>
|
|
42
|
-
#include <packing>
|
|
43
|
-
|
|
44
|
-
uniform sampler2D tDiffuse;
|
|
45
|
-
uniform sampler2D tDepth;
|
|
46
|
-
|
|
47
|
-
uniform float cameraNear;
|
|
48
|
-
uniform float cameraFar;
|
|
49
|
-
uniform float depthCutoff;
|
|
50
|
-
|
|
51
|
-
uniform vec2 sampleUvOffsets[ KERNEL_RADIUS + 1 ];
|
|
52
|
-
uniform float sampleWeights[ KERNEL_RADIUS + 1 ];
|
|
53
|
-
|
|
54
|
-
varying vec2 vUv;
|
|
55
|
-
varying vec2 vInvSize;
|
|
56
|
-
|
|
57
|
-
float getDepth( const in vec2 screenPosition ) {
|
|
58
|
-
#if DEPTH_PACKING == 1
|
|
59
|
-
return unpackRGBAToDepth( texture2D( tDepth, screenPosition ) );
|
|
60
|
-
#else
|
|
61
|
-
return texture2D( tDepth, screenPosition ).x;
|
|
62
|
-
#endif
|
|
63
|
-
}
|
|
64
|
-
|
|
65
|
-
float getViewZ( const in float depth ) {
|
|
66
|
-
#if PERSPECTIVE_CAMERA == 1
|
|
67
|
-
return perspectiveDepthToViewZ( depth, cameraNear, cameraFar );
|
|
68
|
-
#else
|
|
69
|
-
return orthographicDepthToViewZ( depth, cameraNear, cameraFar );
|
|
70
|
-
#endif
|
|
71
|
-
}
|
|
72
|
-
|
|
73
|
-
void main() {
|
|
74
|
-
float depth = getDepth( vUv );
|
|
75
|
-
if( depth >= ( 1.0 - EPSILON ) ) {
|
|
76
|
-
discard;
|
|
77
|
-
}
|
|
78
|
-
|
|
79
|
-
float centerViewZ = -getViewZ( depth );
|
|
80
|
-
bool rBreak = false, lBreak = false;
|
|
81
|
-
|
|
82
|
-
float weightSum = sampleWeights[0];
|
|
83
|
-
vec4 diffuseSum = texture2D( tDiffuse, vUv ) * weightSum;
|
|
84
|
-
|
|
85
|
-
for( int i = 1; i <= KERNEL_RADIUS; i ++ ) {
|
|
86
|
-
|
|
87
|
-
float sampleWeight = sampleWeights[i];
|
|
88
|
-
vec2 sampleUvOffset = sampleUvOffsets[i] * vInvSize;
|
|
89
|
-
|
|
90
|
-
vec2 sampleUv = vUv + sampleUvOffset;
|
|
91
|
-
float viewZ = -getViewZ( getDepth( sampleUv ) );
|
|
92
|
-
|
|
93
|
-
if( abs( viewZ - centerViewZ ) > depthCutoff ) rBreak = true;
|
|
94
|
-
|
|
95
|
-
if( ! rBreak ) {
|
|
96
|
-
diffuseSum += texture2D( tDiffuse, sampleUv ) * sampleWeight;
|
|
97
|
-
weightSum += sampleWeight;
|
|
98
|
-
}
|
|
99
|
-
|
|
100
|
-
sampleUv = vUv - sampleUvOffset;
|
|
101
|
-
viewZ = -getViewZ( getDepth( sampleUv ) );
|
|
102
|
-
|
|
103
|
-
if( abs( viewZ - centerViewZ ) > depthCutoff ) lBreak = true;
|
|
104
|
-
|
|
105
|
-
if( ! lBreak ) {
|
|
106
|
-
diffuseSum += texture2D( tDiffuse, sampleUv ) * sampleWeight;
|
|
107
|
-
weightSum += sampleWeight;
|
|
108
|
-
}
|
|
109
|
-
|
|
110
|
-
}
|
|
111
|
-
|
|
112
|
-
gl_FragColor = diffuseSum / weightSum;
|
|
113
|
-
}`
|
|
114
|
-
};
|
|
115
|
-
exports.DepthLimitedBlurShader = DepthLimitedBlurShader;
|
|
116
|
-
const BlurShaderUtils = {
|
|
117
|
-
createSampleWeights: function (kernelRadius, stdDev) {
|
|
118
|
-
const weights = [];
|
|
119
|
-
for (let i = 0; i <= kernelRadius; i++) {
|
|
120
|
-
weights.push(gaussian(i, stdDev));
|
|
121
|
-
}
|
|
122
|
-
return weights;
|
|
123
|
-
},
|
|
124
|
-
createSampleOffsets: function (kernelRadius, uvIncrement) {
|
|
125
|
-
const offsets = [];
|
|
126
|
-
for (let i = 0; i <= kernelRadius; i++) {
|
|
127
|
-
offsets.push(uvIncrement.clone().multiplyScalar(i));
|
|
128
|
-
}
|
|
129
|
-
return offsets;
|
|
130
|
-
},
|
|
131
|
-
configure: function (material, kernelRadius, stdDev, uvIncrement) {
|
|
132
|
-
material.defines['KERNEL_RADIUS'] = kernelRadius;
|
|
133
|
-
material.uniforms['sampleUvOffsets'].value = BlurShaderUtils.createSampleOffsets(kernelRadius, uvIncrement);
|
|
134
|
-
material.uniforms['sampleWeights'].value = BlurShaderUtils.createSampleWeights(kernelRadius, stdDev);
|
|
135
|
-
material.needsUpdate = true;
|
|
136
|
-
}
|
|
137
|
-
};
|
|
138
|
-
exports.BlurShaderUtils = BlurShaderUtils;
|
|
139
|
-
function gaussian(x, stdDev) {
|
|
140
|
-
return Math.exp(-(x * x) / (2.0 * (stdDev * stdDev))) / (Math.sqrt(2.0 * Math.PI) * stdDev);
|
|
141
|
-
}
|
|
142
|
-
//# sourceMappingURL=depth-limited-blur-shader.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"depth-limited-blur-shader.js","sourceRoot":"","sources":["../../../src/threejs-addon/shaders/depth-limited-blur-shader.js"],"names":[],"mappings":";;;AAAA,iCAEe;AAEf;;GAEG;AAEH,MAAM,sBAAsB,GAAG;IAC3B,OAAO,EAAE;QACL,eAAe,EAAE,CAAC;QAClB,eAAe,EAAE,CAAC;QAClB,oBAAoB,EAAE,CAAC;KAC1B;IACD,QAAQ,EAAE;QACN,UAAU,EAAE,EAAE,KAAK,EAAE,IAAI,EAAE;QAC3B,MAAM,EAAE,EAAE,KAAK,EAAE,IAAI,eAAO,CAAC,GAAG,EAAE,GAAG,CAAC,EAAE;QACxC,iBAAiB,EAAE,EAAE,KAAK,EAAE,CAAC,IAAI,eAAO,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE;QACjD,eAAe,EAAE,EAAE,KAAK,EAAE,CAAC,GAAG,CAAC,EAAE;QACjC,QAAQ,EAAE,EAAE,KAAK,EAAE,IAAI,EAAE;QACzB,YAAY,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE;QAC3B,WAAW,EAAE,EAAE,KAAK,EAAE,IAAI,EAAE;QAC5B,aAAa,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE;KAC/B;IACD,YAAY,EAAE,UAAU,CAAC;;;;;;;;;;;;;;IAczB;IAEA,cAAc,EAAE,UAAU,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;IA0E3B;CAEH,CAAC;AAiDO,wDAAsB;AA/C/B,MAAM,eAAe,GAAG;IAEpB,mBAAmB,EAAE,UAAS,YAAY,EAAE,MAAM;QAE9C,MAAM,OAAO,GAAG,EAAE,CAAC;QAEnB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,IAAI,YAAY,EAAE,CAAC,EAAE,EAAE;YAEpC,OAAO,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC;SAErC;QAED,OAAO,OAAO,CAAC;IAEnB,CAAC;IAED,mBAAmB,EAAE,UAAS,YAAY,EAAE,WAAW;QAEnD,MAAM,OAAO,GAAG,EAAE,CAAC;QAEnB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,IAAI,YAAY,EAAE,CAAC,EAAE,EAAE;YAEpC,OAAO,CAAC,IAAI,CAAC,WAAW,CAAC,KAAK,EAAE,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC,CAAC;SAEvD;QAED,OAAO,OAAO,CAAC;IAEnB,CAAC;IAED,SAAS,EAAE,UAAS,QAAQ,EAAE,YAAY,EAAE,MAAM,EAAE,WAAW;QAE3D,QAAQ,CAAC,OAAO,CAAC,eAAe,CAAC,GAAG,YAAY,CAAC;QACjD,QAAQ,CAAC,QAAQ,CAAC,iBAAiB,CAAC,CAAC,KAAK,GAAG,eAAe,CAAC,mBAAmB,CAAC,YAAY,EAAE,WAAW,CAAC,CAAC;QAC5G,QAAQ,CAAC,QAAQ,CAAC,eAAe,CAAC,CAAC,KAAK,GAAG,eAAe,CAAC,mBAAmB,CAAC,YAAY,EAAE,MAAM,CAAC,CAAC;QACrG,QAAQ,CAAC,WAAW,GAAG,IAAI,CAAC;IAEhC,CAAC;CAEJ,CAAC;AAQ+B,0CAAe;AANhD,SAAS,QAAQ,CAAC,CAAC,EAAE,MAAM;IAEvB,OAAO,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,GAAG,GAAG,CAAC,MAAM,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,GAAG,IAAI,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,CAAC;AAEhG,CAAC"}
|
|
@@ -1,14 +0,0 @@
|
|
|
1
|
-
export namespace FXAAShader {
|
|
2
|
-
namespace uniforms {
|
|
3
|
-
namespace tDiffuse {
|
|
4
|
-
const value: null;
|
|
5
|
-
}
|
|
6
|
-
namespace resolution {
|
|
7
|
-
const value_1: Vector2;
|
|
8
|
-
export { value_1 as value };
|
|
9
|
-
}
|
|
10
|
-
}
|
|
11
|
-
const vertexShader: string;
|
|
12
|
-
const fragmentShader: string;
|
|
13
|
-
}
|
|
14
|
-
import { Vector2 } from 'three';
|
|
@@ -1,279 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.FXAAShader = void 0;
|
|
4
|
-
const three_1 = require("three");
|
|
5
|
-
/**
|
|
6
|
-
* NVIDIA FXAA by Timothy Lottes
|
|
7
|
-
* https://developer.download.nvidia.com/assets/gamedev/files/sdk/11/FXAA_WhitePaper.pdf
|
|
8
|
-
* - WebGL port by @supereggbert
|
|
9
|
-
* http://www.glge.org/demos/fxaa/
|
|
10
|
-
* Further improved by Daniel Sturk
|
|
11
|
-
*/
|
|
12
|
-
const FXAAShader = {
|
|
13
|
-
uniforms: {
|
|
14
|
-
'tDiffuse': { value: null },
|
|
15
|
-
'resolution': { value: new three_1.Vector2(1 / 1024, 1 / 512) }
|
|
16
|
-
},
|
|
17
|
-
vertexShader: /* glsl */ `
|
|
18
|
-
|
|
19
|
-
varying vec2 vUv;
|
|
20
|
-
|
|
21
|
-
void main() {
|
|
22
|
-
|
|
23
|
-
vUv = uv;
|
|
24
|
-
gl_Position = projectionMatrix * modelViewMatrix * vec4( position, 1.0 );
|
|
25
|
-
|
|
26
|
-
}`,
|
|
27
|
-
fragmentShader: `
|
|
28
|
-
precision highp float;
|
|
29
|
-
|
|
30
|
-
uniform sampler2D tDiffuse;
|
|
31
|
-
|
|
32
|
-
uniform vec2 resolution;
|
|
33
|
-
|
|
34
|
-
varying vec2 vUv;
|
|
35
|
-
|
|
36
|
-
// FXAA 3.11 implementation by NVIDIA, ported to WebGL by Agost Biro (biro@archilogic.com)
|
|
37
|
-
|
|
38
|
-
//----------------------------------------------------------------------------------
|
|
39
|
-
// File: es3-kepler\FXAA\assets\shaders/FXAA_DefaultES.frag
|
|
40
|
-
// SDK Version: v3.00
|
|
41
|
-
// Email: gameworks@nvidia.com
|
|
42
|
-
// Site: http://developer.nvidia.com/
|
|
43
|
-
//
|
|
44
|
-
// Copyright (c) 2014-2015, NVIDIA CORPORATION. All rights reserved.
|
|
45
|
-
//
|
|
46
|
-
// Redistribution and use in source and binary forms, with or without
|
|
47
|
-
// modification, are permitted provided that the following conditions
|
|
48
|
-
// are met:
|
|
49
|
-
// * Redistributions of source code must retain the above copyright
|
|
50
|
-
// notice, this list of conditions and the following disclaimer.
|
|
51
|
-
// * Redistributions in binary form must reproduce the above copyright
|
|
52
|
-
// notice, this list of conditions and the following disclaimer in the
|
|
53
|
-
// documentation and/or other materials provided with the distribution.
|
|
54
|
-
// * Neither the name of NVIDIA CORPORATION nor the names of its
|
|
55
|
-
// contributors may be used to endorse or promote products derived
|
|
56
|
-
// from this software without specific prior written permission.
|
|
57
|
-
//
|
|
58
|
-
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS ''AS IS'' AND ANY
|
|
59
|
-
// EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
60
|
-
// IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
|
|
61
|
-
// PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
|
|
62
|
-
// CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
|
|
63
|
-
// EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
|
|
64
|
-
// PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
|
|
65
|
-
// PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
|
|
66
|
-
// OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
67
|
-
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
|
68
|
-
// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
69
|
-
//
|
|
70
|
-
//----------------------------------------------------------------------------------
|
|
71
|
-
|
|
72
|
-
#ifndef FXAA_DISCARD
|
|
73
|
-
//
|
|
74
|
-
// Only valid for PC OpenGL currently.
|
|
75
|
-
// Probably will not work when FXAA_GREEN_AS_LUMA = 1.
|
|
76
|
-
//
|
|
77
|
-
// 1 = Use discard on pixels which don't need AA.
|
|
78
|
-
// For APIs which enable concurrent TEX+ROP from same surface.
|
|
79
|
-
// 0 = Return unchanged color on pixels which don't need AA.
|
|
80
|
-
//
|
|
81
|
-
#define FXAA_DISCARD 0
|
|
82
|
-
#endif
|
|
83
|
-
|
|
84
|
-
/*--------------------------------------------------------------------------*/
|
|
85
|
-
#define FxaaTexTop(t, p) texture2D(t, p, -100.0)
|
|
86
|
-
#define FxaaTexOff(t, p, o, r) texture2D(t, p + (o * r), -100.0)
|
|
87
|
-
/*--------------------------------------------------------------------------*/
|
|
88
|
-
|
|
89
|
-
#define NUM_SAMPLES 5
|
|
90
|
-
|
|
91
|
-
// assumes colors have premultipliedAlpha, so that the calculated color contrast is scaled by alpha
|
|
92
|
-
float contrast( vec4 a, vec4 b ) {
|
|
93
|
-
vec4 diff = abs( a - b );
|
|
94
|
-
return max( max( max( diff.r, diff.g ), diff.b ), diff.a );
|
|
95
|
-
}
|
|
96
|
-
|
|
97
|
-
/*============================================================================
|
|
98
|
-
|
|
99
|
-
FXAA3 QUALITY - PC
|
|
100
|
-
|
|
101
|
-
============================================================================*/
|
|
102
|
-
|
|
103
|
-
/*--------------------------------------------------------------------------*/
|
|
104
|
-
vec4 FxaaPixelShader(
|
|
105
|
-
vec2 posM,
|
|
106
|
-
sampler2D tex,
|
|
107
|
-
vec2 fxaaQualityRcpFrame,
|
|
108
|
-
float fxaaQualityEdgeThreshold,
|
|
109
|
-
float fxaaQualityinvEdgeThreshold
|
|
110
|
-
) {
|
|
111
|
-
vec4 rgbaM = FxaaTexTop(tex, posM);
|
|
112
|
-
vec4 rgbaS = FxaaTexOff(tex, posM, vec2( 0.0, 1.0), fxaaQualityRcpFrame.xy);
|
|
113
|
-
vec4 rgbaE = FxaaTexOff(tex, posM, vec2( 1.0, 0.0), fxaaQualityRcpFrame.xy);
|
|
114
|
-
vec4 rgbaN = FxaaTexOff(tex, posM, vec2( 0.0,-1.0), fxaaQualityRcpFrame.xy);
|
|
115
|
-
vec4 rgbaW = FxaaTexOff(tex, posM, vec2(-1.0, 0.0), fxaaQualityRcpFrame.xy);
|
|
116
|
-
// . S .
|
|
117
|
-
// W M E
|
|
118
|
-
// . N .
|
|
119
|
-
|
|
120
|
-
bool earlyExit = max( max( max(
|
|
121
|
-
contrast( rgbaM, rgbaN ),
|
|
122
|
-
contrast( rgbaM, rgbaS ) ),
|
|
123
|
-
contrast( rgbaM, rgbaE ) ),
|
|
124
|
-
contrast( rgbaM, rgbaW ) )
|
|
125
|
-
< fxaaQualityEdgeThreshold;
|
|
126
|
-
// . 0 .
|
|
127
|
-
// 0 0 0
|
|
128
|
-
// . 0 .
|
|
129
|
-
|
|
130
|
-
#if (FXAA_DISCARD == 1)
|
|
131
|
-
if(earlyExit) FxaaDiscard;
|
|
132
|
-
#else
|
|
133
|
-
if(earlyExit) return rgbaM;
|
|
134
|
-
#endif
|
|
135
|
-
|
|
136
|
-
float contrastN = contrast( rgbaM, rgbaN );
|
|
137
|
-
float contrastS = contrast( rgbaM, rgbaS );
|
|
138
|
-
float contrastE = contrast( rgbaM, rgbaE );
|
|
139
|
-
float contrastW = contrast( rgbaM, rgbaW );
|
|
140
|
-
|
|
141
|
-
float relativeVContrast = ( contrastN + contrastS ) - ( contrastE + contrastW );
|
|
142
|
-
relativeVContrast *= fxaaQualityinvEdgeThreshold;
|
|
143
|
-
|
|
144
|
-
bool horzSpan = relativeVContrast > 0.;
|
|
145
|
-
// . 1 .
|
|
146
|
-
// 0 0 0
|
|
147
|
-
// . 1 .
|
|
148
|
-
|
|
149
|
-
// 45 deg edge detection and corners of objects, aka V/H contrast is too similar
|
|
150
|
-
if( abs( relativeVContrast ) < .3 ) {
|
|
151
|
-
// locate the edge
|
|
152
|
-
vec2 dirToEdge;
|
|
153
|
-
dirToEdge.x = contrastE > contrastW ? 1. : -1.;
|
|
154
|
-
dirToEdge.y = contrastS > contrastN ? 1. : -1.;
|
|
155
|
-
// . 2 . . 1 .
|
|
156
|
-
// 1 0 2 ~= 0 0 1
|
|
157
|
-
// . 1 . . 0 .
|
|
158
|
-
|
|
159
|
-
// tap 2 pixels and see which ones are "outside" the edge, to
|
|
160
|
-
// determine if the edge is vertical or horizontal
|
|
161
|
-
|
|
162
|
-
vec4 rgbaAlongH = FxaaTexOff(tex, posM, vec2( dirToEdge.x, -dirToEdge.y ), fxaaQualityRcpFrame.xy);
|
|
163
|
-
float matchAlongH = contrast( rgbaM, rgbaAlongH );
|
|
164
|
-
// . 1 .
|
|
165
|
-
// 0 0 1
|
|
166
|
-
// . 0 H
|
|
167
|
-
|
|
168
|
-
vec4 rgbaAlongV = FxaaTexOff(tex, posM, vec2( -dirToEdge.x, dirToEdge.y ), fxaaQualityRcpFrame.xy);
|
|
169
|
-
float matchAlongV = contrast( rgbaM, rgbaAlongV );
|
|
170
|
-
// V 1 .
|
|
171
|
-
// 0 0 1
|
|
172
|
-
// . 0 .
|
|
173
|
-
|
|
174
|
-
relativeVContrast = matchAlongV - matchAlongH;
|
|
175
|
-
relativeVContrast *= fxaaQualityinvEdgeThreshold;
|
|
176
|
-
|
|
177
|
-
if( abs( relativeVContrast ) < .3 ) { // 45 deg edge
|
|
178
|
-
// 1 1 .
|
|
179
|
-
// 0 0 1
|
|
180
|
-
// . 0 1
|
|
181
|
-
|
|
182
|
-
// do a simple blur
|
|
183
|
-
return mix(
|
|
184
|
-
rgbaM,
|
|
185
|
-
(rgbaN + rgbaS + rgbaE + rgbaW) * .25,
|
|
186
|
-
.4
|
|
187
|
-
);
|
|
188
|
-
}
|
|
189
|
-
|
|
190
|
-
horzSpan = relativeVContrast > 0.;
|
|
191
|
-
}
|
|
192
|
-
|
|
193
|
-
if(!horzSpan) rgbaN = rgbaW;
|
|
194
|
-
if(!horzSpan) rgbaS = rgbaE;
|
|
195
|
-
// . 0 . 1
|
|
196
|
-
// 1 0 1 -> 0
|
|
197
|
-
// . 0 . 1
|
|
198
|
-
|
|
199
|
-
bool pairN = contrast( rgbaM, rgbaN ) > contrast( rgbaM, rgbaS );
|
|
200
|
-
if(!pairN) rgbaN = rgbaS;
|
|
201
|
-
|
|
202
|
-
vec2 offNP;
|
|
203
|
-
offNP.x = (!horzSpan) ? 0.0 : fxaaQualityRcpFrame.x;
|
|
204
|
-
offNP.y = ( horzSpan) ? 0.0 : fxaaQualityRcpFrame.y;
|
|
205
|
-
|
|
206
|
-
bool doneN = false;
|
|
207
|
-
bool doneP = false;
|
|
208
|
-
|
|
209
|
-
float nDist = 0.;
|
|
210
|
-
float pDist = 0.;
|
|
211
|
-
|
|
212
|
-
vec2 posN = posM;
|
|
213
|
-
vec2 posP = posM;
|
|
214
|
-
|
|
215
|
-
int iterationsUsed = 0;
|
|
216
|
-
int iterationsUsedN = 0;
|
|
217
|
-
int iterationsUsedP = 0;
|
|
218
|
-
for( int i = 0; i < NUM_SAMPLES; i++ ) {
|
|
219
|
-
iterationsUsed = i;
|
|
220
|
-
|
|
221
|
-
float increment = float(i + 1);
|
|
222
|
-
|
|
223
|
-
if(!doneN) {
|
|
224
|
-
nDist += increment;
|
|
225
|
-
posN = posM + offNP * nDist;
|
|
226
|
-
vec4 rgbaEndN = FxaaTexTop(tex, posN.xy);
|
|
227
|
-
doneN = contrast( rgbaEndN, rgbaM ) > contrast( rgbaEndN, rgbaN );
|
|
228
|
-
iterationsUsedN = i;
|
|
229
|
-
}
|
|
230
|
-
|
|
231
|
-
if(!doneP) {
|
|
232
|
-
pDist += increment;
|
|
233
|
-
posP = posM - offNP * pDist;
|
|
234
|
-
vec4 rgbaEndP = FxaaTexTop(tex, posP.xy);
|
|
235
|
-
doneP = contrast( rgbaEndP, rgbaM ) > contrast( rgbaEndP, rgbaN );
|
|
236
|
-
iterationsUsedP = i;
|
|
237
|
-
}
|
|
238
|
-
|
|
239
|
-
if(doneN || doneP) break;
|
|
240
|
-
}
|
|
241
|
-
|
|
242
|
-
|
|
243
|
-
if ( !doneP && !doneN ) return rgbaM; // failed to find end of edge
|
|
244
|
-
|
|
245
|
-
float dist = min(
|
|
246
|
-
doneN ? float( iterationsUsedN ) / float( NUM_SAMPLES - 1 ) : 1.,
|
|
247
|
-
doneP ? float( iterationsUsedP ) / float( NUM_SAMPLES - 1 ) : 1.
|
|
248
|
-
);
|
|
249
|
-
|
|
250
|
-
// hacky way of reduces blurriness of mostly diagonal edges
|
|
251
|
-
// but reduces AA quality
|
|
252
|
-
dist = pow(dist, .5);
|
|
253
|
-
|
|
254
|
-
dist = 1. - dist;
|
|
255
|
-
|
|
256
|
-
return mix(
|
|
257
|
-
rgbaM,
|
|
258
|
-
rgbaN,
|
|
259
|
-
dist * .5
|
|
260
|
-
);
|
|
261
|
-
}
|
|
262
|
-
|
|
263
|
-
void main() {
|
|
264
|
-
const float edgeDetectionQuality = .2;
|
|
265
|
-
const float invEdgeDetectionQuality = 1. / edgeDetectionQuality;
|
|
266
|
-
|
|
267
|
-
gl_FragColor = FxaaPixelShader(
|
|
268
|
-
vUv,
|
|
269
|
-
tDiffuse,
|
|
270
|
-
resolution,
|
|
271
|
-
edgeDetectionQuality, // [0,1] contrast needed, otherwise early discard
|
|
272
|
-
invEdgeDetectionQuality
|
|
273
|
-
);
|
|
274
|
-
|
|
275
|
-
}
|
|
276
|
-
`
|
|
277
|
-
};
|
|
278
|
-
exports.FXAAShader = FXAAShader;
|
|
279
|
-
//# sourceMappingURL=fxaa-shader.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"fxaa-shader.js","sourceRoot":"","sources":["../../../src/threejs-addon/shaders/fxaa-shader.js"],"names":[],"mappings":";;;AAAA,iCAEe;AAEf;;;;;;GAMG;AAEH,MAAM,UAAU,GAAG;IAEf,QAAQ,EAAE;QAEN,UAAU,EAAE,EAAE,KAAK,EAAE,IAAI,EAAE;QAC3B,YAAY,EAAE,EAAE,KAAK,EAAE,IAAI,eAAO,CAAC,CAAC,GAAG,IAAI,EAAE,CAAC,GAAG,GAAG,CAAC,EAAE;KAE1D;IAED,YAAY,EAAE,UAAU,CAAC;;;;;;;;;IASzB;IAEA,cAAc,EAAE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAyPlB;CAED,CAAC;AAEO,gCAAU"}
|
|
@@ -1,27 +0,0 @@
|
|
|
1
|
-
export namespace LuminosityHighPassShader {
|
|
2
|
-
const shaderID: string;
|
|
3
|
-
namespace uniforms {
|
|
4
|
-
namespace tDiffuse {
|
|
5
|
-
const value: null;
|
|
6
|
-
}
|
|
7
|
-
namespace luminosityThreshold {
|
|
8
|
-
const value_1: number;
|
|
9
|
-
export { value_1 as value };
|
|
10
|
-
}
|
|
11
|
-
namespace smoothWidth {
|
|
12
|
-
const value_2: number;
|
|
13
|
-
export { value_2 as value };
|
|
14
|
-
}
|
|
15
|
-
namespace defaultColor {
|
|
16
|
-
const value_3: Color;
|
|
17
|
-
export { value_3 as value };
|
|
18
|
-
}
|
|
19
|
-
namespace defaultOpacity {
|
|
20
|
-
const value_4: number;
|
|
21
|
-
export { value_4 as value };
|
|
22
|
-
}
|
|
23
|
-
}
|
|
24
|
-
const vertexShader: string;
|
|
25
|
-
const fragmentShader: string;
|
|
26
|
-
}
|
|
27
|
-
import { Color } from 'three';
|
|
@@ -1,56 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.LuminosityHighPassShader = void 0;
|
|
4
|
-
const three_1 = require("three");
|
|
5
|
-
/**
|
|
6
|
-
* Luminosity
|
|
7
|
-
* http://en.wikipedia.org/wiki/Luminosity
|
|
8
|
-
*/
|
|
9
|
-
const LuminosityHighPassShader = {
|
|
10
|
-
shaderID: 'luminosityHighPass',
|
|
11
|
-
uniforms: {
|
|
12
|
-
'tDiffuse': { value: null },
|
|
13
|
-
'luminosityThreshold': { value: 1.0 },
|
|
14
|
-
'smoothWidth': { value: 1.0 },
|
|
15
|
-
'defaultColor': { value: new three_1.Color(0x000000) },
|
|
16
|
-
'defaultOpacity': { value: 0.0 }
|
|
17
|
-
},
|
|
18
|
-
vertexShader: /* glsl */ `
|
|
19
|
-
|
|
20
|
-
varying vec2 vUv;
|
|
21
|
-
|
|
22
|
-
void main() {
|
|
23
|
-
|
|
24
|
-
vUv = uv;
|
|
25
|
-
|
|
26
|
-
gl_Position = projectionMatrix * modelViewMatrix * vec4( position, 1.0 );
|
|
27
|
-
|
|
28
|
-
}`,
|
|
29
|
-
fragmentShader: /* glsl */ `
|
|
30
|
-
|
|
31
|
-
uniform sampler2D tDiffuse;
|
|
32
|
-
uniform vec3 defaultColor;
|
|
33
|
-
uniform float defaultOpacity;
|
|
34
|
-
uniform float luminosityThreshold;
|
|
35
|
-
uniform float smoothWidth;
|
|
36
|
-
|
|
37
|
-
varying vec2 vUv;
|
|
38
|
-
|
|
39
|
-
void main() {
|
|
40
|
-
|
|
41
|
-
vec4 texel = texture2D( tDiffuse, vUv );
|
|
42
|
-
|
|
43
|
-
vec3 luma = vec3( 0.299, 0.587, 0.114 );
|
|
44
|
-
|
|
45
|
-
float v = dot( texel.xyz, luma );
|
|
46
|
-
|
|
47
|
-
vec4 outputColor = vec4( defaultColor.rgb, defaultOpacity );
|
|
48
|
-
|
|
49
|
-
float alpha = smoothstep( luminosityThreshold, luminosityThreshold + smoothWidth, v );
|
|
50
|
-
|
|
51
|
-
gl_FragColor = mix( outputColor, texel, alpha );
|
|
52
|
-
|
|
53
|
-
}`
|
|
54
|
-
};
|
|
55
|
-
exports.LuminosityHighPassShader = LuminosityHighPassShader;
|
|
56
|
-
//# sourceMappingURL=luminosity-high-pass-shader.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"luminosity-high-pass-shader.js","sourceRoot":"","sources":["../../../src/threejs-addon/shaders/luminosity-high-pass-shader.js"],"names":[],"mappings":";;;AAAA,iCAEe;AAEf;;;GAGG;AAEH,MAAM,wBAAwB,GAAG;IAE7B,QAAQ,EAAE,oBAAoB;IAE9B,QAAQ,EAAE;QAEN,UAAU,EAAE,EAAE,KAAK,EAAE,IAAI,EAAE;QAC3B,qBAAqB,EAAE,EAAE,KAAK,EAAE,GAAG,EAAE;QACrC,aAAa,EAAE,EAAE,KAAK,EAAE,GAAG,EAAE;QAC7B,cAAc,EAAE,EAAE,KAAK,EAAE,IAAI,aAAK,CAAC,QAAQ,CAAC,EAAE;QAC9C,gBAAgB,EAAE,EAAE,KAAK,EAAE,GAAG,EAAE;KAEnC;IAED,YAAY,EAAE,UAAU,CAAC;;;;;;;;;;IAUzB;IAEA,cAAc,EAAE,UAAU,CAAC;;;;;;;;;;;;;;;;;;;;;;;;IAwB3B;CAEH,CAAC;AAEO,4DAAwB"}
|
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
export namespace OutputShader {
|
|
2
|
-
namespace uniforms {
|
|
3
|
-
namespace tDiffuse {
|
|
4
|
-
const value: null;
|
|
5
|
-
}
|
|
6
|
-
namespace toneMappingExposure {
|
|
7
|
-
const value_1: number;
|
|
8
|
-
export { value_1 as value };
|
|
9
|
-
}
|
|
10
|
-
}
|
|
11
|
-
const vertexShader: string;
|
|
12
|
-
const fragmentShader: string;
|
|
13
|
-
}
|