@needle-tools/engine 2.66.1-pre → 2.67.0-pre
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/CHANGELOG.md +20 -0
- package/dist/needle-engine.js +34306 -26230
- package/dist/needle-engine.umd.cjs +743 -298
- package/lib/engine/api.d.ts +4 -0
- package/lib/engine/api.js +10 -0
- package/lib/engine/api.js.map +1 -1
- package/lib/engine/codegen/register_types.js +23 -7
- package/lib/engine/codegen/register_types.js.map +1 -1
- package/lib/engine/debug/debug_overlay.js +7 -1
- package/lib/engine/debug/debug_overlay.js.map +1 -1
- package/lib/engine/engine_addressables.js +2 -2
- package/lib/engine/engine_addressables.js.map +1 -1
- package/lib/engine/engine_assetdatabase.d.ts +17 -51
- package/lib/engine/engine_assetdatabase.js +252 -126
- package/lib/engine/engine_assetdatabase.js.map +1 -1
- package/lib/engine/engine_components.js +13 -1
- package/lib/engine/engine_components.js.map +1 -1
- package/lib/engine/engine_components_internal.d.ts +8 -0
- package/lib/engine/engine_components_internal.js +29 -0
- package/lib/engine/engine_components_internal.js.map +1 -0
- package/lib/engine/engine_constants.d.ts +1 -0
- package/lib/engine/engine_constants.js +1 -0
- package/lib/engine/engine_constants.js.map +1 -1
- package/lib/engine/engine_context_registry.d.ts +2 -0
- package/lib/engine/engine_context_registry.js +6 -0
- package/lib/engine/engine_context_registry.js.map +1 -1
- package/lib/engine/engine_editor-sync.d.ts +9 -0
- package/lib/engine/engine_editor-sync.js +8 -0
- package/lib/engine/engine_editor-sync.js.map +1 -0
- package/lib/engine/engine_element_loading.js +1 -1
- package/lib/engine/engine_element_loading.js.map +1 -1
- package/lib/engine/engine_gameobject.js +15 -20
- package/lib/engine/engine_gameobject.js.map +1 -1
- package/lib/engine/engine_gltf_builtin_components.d.ts +2 -3
- package/lib/engine/engine_gltf_builtin_components.js +23 -6
- package/lib/engine/engine_gltf_builtin_components.js.map +1 -1
- package/lib/engine/engine_networking_auto.d.ts +1 -0
- package/lib/engine/engine_networking_auto.js +42 -9
- package/lib/engine/engine_networking_auto.js.map +1 -1
- package/lib/engine/engine_patcher.d.ts +8 -0
- package/lib/engine/engine_patcher.js +98 -0
- package/lib/engine/engine_patcher.js.map +1 -0
- package/lib/engine/engine_physics.d.ts +5 -1
- package/lib/engine/engine_physics.js +11 -1
- package/lib/engine/engine_physics.js.map +1 -1
- package/lib/engine/engine_scenetools.js +0 -1
- package/lib/engine/engine_scenetools.js.map +1 -1
- package/lib/engine/engine_serialization_core.js +4 -0
- package/lib/engine/engine_serialization_core.js.map +1 -1
- package/lib/engine/engine_setup.d.ts +1 -1
- package/lib/engine/engine_setup.js +9 -5
- package/lib/engine/engine_setup.js.map +1 -1
- package/lib/engine/engine_texture.d.ts +6 -1
- package/lib/engine/engine_texture.js +39 -1
- package/lib/engine/engine_texture.js.map +1 -1
- package/lib/engine/engine_types.d.ts +4 -0
- package/lib/engine/engine_types.js.map +1 -1
- package/lib/engine/engine_utils.js +3 -2
- package/lib/engine/engine_utils.js.map +1 -1
- package/lib/engine/extensions/NEEDLE_progressive.d.ts +0 -1
- package/lib/engine/extensions/NEEDLE_progressive.js +24 -26
- package/lib/engine/extensions/NEEDLE_progressive.js.map +1 -1
- package/lib/engine/extensions/extensions.d.ts +4 -1
- package/lib/engine/extensions/extensions.js +16 -0
- package/lib/engine/extensions/extensions.js.map +1 -1
- package/lib/engine/extensions/usage_tracker.d.ts +12 -0
- package/lib/engine/extensions/usage_tracker.js +59 -0
- package/lib/engine/extensions/usage_tracker.js.map +1 -0
- package/lib/engine-components/AnimatorController.js +4 -0
- package/lib/engine-components/AnimatorController.js.map +1 -1
- package/lib/engine-components/AudioSource.js +2 -1
- package/lib/engine-components/AudioSource.js.map +1 -1
- package/lib/engine-components/Camera.d.ts +6 -0
- package/lib/engine-components/Camera.js +70 -31
- package/lib/engine-components/Camera.js.map +1 -1
- package/lib/engine-components/Component.d.ts +52 -0
- package/lib/engine-components/Component.js +55 -14
- package/lib/engine-components/Component.js.map +1 -1
- package/lib/engine-components/Networking.js +19 -0
- package/lib/engine-components/Networking.js.map +1 -1
- package/lib/engine-components/OrbitControls.d.ts +2 -0
- package/lib/engine-components/OrbitControls.js +9 -0
- package/lib/engine-components/OrbitControls.js.map +1 -1
- package/lib/engine-components/ParticleSystem.js +11 -1
- package/lib/engine-components/ParticleSystem.js.map +1 -1
- package/lib/engine-components/ReflectionProbe.js +18 -6
- package/lib/engine-components/ReflectionProbe.js.map +1 -1
- package/lib/engine-components/Renderer.d.ts +1 -1
- package/lib/engine-components/Renderer.js +24 -6
- package/lib/engine-components/Renderer.js.map +1 -1
- package/lib/engine-components/Skybox.js +2 -0
- package/lib/engine-components/Skybox.js.map +1 -1
- package/lib/engine-components/SmoothFollow.js +1 -2
- package/lib/engine-components/SmoothFollow.js.map +1 -1
- package/lib/engine-components/WebARCameraBackground.d.ts +19 -0
- package/lib/engine-components/WebARCameraBackground.js +185 -0
- package/lib/engine-components/WebARCameraBackground.js.map +1 -0
- package/lib/engine-components/WebXR.d.ts +4 -0
- package/lib/engine-components/WebXR.js +11 -8
- package/lib/engine-components/WebXR.js.map +1 -1
- package/lib/engine-components/WebXRAvatar.js +1 -0
- package/lib/engine-components/WebXRAvatar.js.map +1 -1
- package/lib/engine-components/codegen/components.d.ts +14 -6
- package/lib/engine-components/codegen/components.js +14 -6
- package/lib/engine-components/codegen/components.js.map +1 -1
- package/lib/engine-components/js-extensions/Object3D.js +4 -1
- package/lib/engine-components/js-extensions/Object3D.js.map +1 -1
- package/lib/engine-components/postprocessing/Effects/Antialiasing.d.ts +13 -0
- package/lib/engine-components/postprocessing/Effects/Antialiasing.js +46 -0
- package/lib/engine-components/postprocessing/Effects/Antialiasing.js.map +1 -0
- package/lib/engine-components/postprocessing/Effects/Bloom.d.ts +12 -0
- package/lib/engine-components/postprocessing/Effects/Bloom.js +76 -0
- package/lib/engine-components/postprocessing/Effects/Bloom.js.map +1 -0
- package/lib/engine-components/postprocessing/Effects/ChromaticAberration.d.ts +8 -0
- package/lib/engine-components/postprocessing/Effects/ChromaticAberration.js +39 -0
- package/lib/engine-components/postprocessing/Effects/ChromaticAberration.js.map +1 -0
- package/lib/engine-components/postprocessing/Effects/ColorAdjustments.d.ts +12 -0
- package/lib/engine-components/postprocessing/Effects/ColorAdjustments.js +96 -0
- package/lib/engine-components/postprocessing/Effects/ColorAdjustments.js.map +1 -0
- package/lib/engine-components/postprocessing/Effects/DepthOfField.d.ts +21 -0
- package/lib/engine-components/postprocessing/Effects/DepthOfField.js +87 -0
- package/lib/engine-components/postprocessing/Effects/DepthOfField.js.map +1 -0
- package/lib/engine-components/postprocessing/Effects/Pixelation.d.ts +7 -0
- package/lib/engine-components/postprocessing/Effects/Pixelation.js +30 -0
- package/lib/engine-components/postprocessing/Effects/Pixelation.js.map +1 -0
- package/lib/engine-components/postprocessing/Effects/ScreenspaceAmbientOcclusion.d.ts +11 -0
- package/lib/engine-components/postprocessing/Effects/ScreenspaceAmbientOcclusion.js +70 -0
- package/lib/engine-components/postprocessing/Effects/ScreenspaceAmbientOcclusion.js.map +1 -0
- package/lib/engine-components/postprocessing/Effects/Tonemapping.d.ts +16 -0
- package/lib/engine-components/postprocessing/Effects/Tonemapping.js +52 -0
- package/lib/engine-components/postprocessing/Effects/Tonemapping.js.map +1 -0
- package/lib/engine-components/postprocessing/Effects/Vignette.d.ts +11 -0
- package/lib/engine-components/postprocessing/Effects/Vignette.js +57 -0
- package/lib/engine-components/postprocessing/Effects/Vignette.js.map +1 -0
- package/lib/engine-components/postprocessing/PostProcessingEffect.d.ts +29 -0
- package/lib/engine-components/postprocessing/PostProcessingEffect.js +89 -0
- package/lib/engine-components/postprocessing/PostProcessingEffect.js.map +1 -0
- package/lib/engine-components/postprocessing/PostProcessingHandler.d.ts +13 -0
- package/lib/engine-components/postprocessing/PostProcessingHandler.js +119 -0
- package/lib/engine-components/postprocessing/PostProcessingHandler.js.map +1 -0
- package/lib/engine-components/postprocessing/Volume.d.ts +23 -0
- package/lib/engine-components/postprocessing/Volume.js +176 -0
- package/lib/engine-components/postprocessing/Volume.js.map +1 -0
- package/lib/engine-components/postprocessing/VolumeParameter.d.ts +21 -0
- package/lib/engine-components/postprocessing/VolumeParameter.js +75 -0
- package/lib/engine-components/postprocessing/VolumeParameter.js.map +1 -0
- package/lib/engine-components/postprocessing/VolumeProfile.d.ts +7 -0
- package/lib/engine-components/postprocessing/VolumeProfile.js +42 -0
- package/lib/engine-components/postprocessing/VolumeProfile.js.map +1 -0
- package/lib/engine-components/timeline/TimelineTracks.js +14 -15
- package/lib/engine-components/timeline/TimelineTracks.js.map +1 -1
- package/lib/engine-components/ui/Text.js +28 -170
- package/lib/engine-components/ui/Text.js.map +1 -1
- package/lib/engine-components-experimental/networking/PlayerSync.d.ts +18 -0
- package/lib/engine-components-experimental/networking/PlayerSync.js +61 -7
- package/lib/engine-components-experimental/networking/PlayerSync.js.map +1 -1
- package/lib/include/three/ARButton.d.ts +1 -1
- package/lib/include/three/ARButton.js +11 -19
- package/lib/include/three/ARButton.js.map +1 -1
- package/lib/include/three/VRButton.js +1 -4
- package/lib/include/three/VRButton.js.map +1 -1
- package/package.json +3 -2
- package/plugins/vite/drop-client.js +77 -0
- package/plugins/vite/drop.js +81 -0
- package/plugins/vite/editor-connection.js +121 -0
- package/plugins/vite/index.js +9 -4
- package/src/engine/api.ts +30 -1
- package/src/engine/codegen/register_types.js +25 -9
- package/src/engine/debug/debug_overlay.ts +7 -1
- package/src/engine/engine_addressables.ts +2 -2
- package/src/engine/engine_assetdatabase.ts +291 -184
- package/src/engine/engine_components.ts +20 -1
- package/src/engine/engine_components_internal.ts +30 -0
- package/src/engine/engine_constants.ts +4 -1
- package/src/engine/engine_context_registry.ts +7 -0
- package/src/engine/engine_editor-sync.ts +21 -0
- package/src/engine/engine_element_loading.ts +1 -1
- package/src/engine/engine_gameobject.ts +16 -21
- package/src/engine/engine_gltf_builtin_components.ts +30 -15
- package/src/engine/engine_networking_auto.ts +48 -11
- package/src/engine/engine_patcher.ts +113 -0
- package/src/engine/engine_physics.ts +15 -2
- package/src/engine/engine_scenetools.ts +0 -1
- package/src/engine/engine_serialization_core.ts +6 -0
- package/src/engine/engine_setup.ts +11 -5
- package/src/engine/engine_texture.ts +54 -5
- package/src/engine/engine_types.ts +6 -1
- package/src/engine/engine_utils.ts +6 -5
- package/src/engine/extensions/NEEDLE_progressive.ts +32 -32
- package/src/engine/extensions/extensions.ts +22 -1
- package/src/engine/extensions/usage_tracker.ts +91 -0
- package/src/engine-components/AnimatorController.ts +2 -0
- package/src/engine-components/AudioSource.ts +1 -1
- package/src/engine-components/Camera.ts +77 -37
- package/src/engine-components/Component.ts +74 -30
- package/src/engine-components/Networking.ts +9 -1
- package/src/engine-components/OrbitControls.ts +11 -2
- package/src/engine-components/ParticleSystem.ts +9 -1
- package/src/engine-components/ReflectionProbe.ts +17 -7
- package/src/engine-components/Renderer.ts +22 -5
- package/src/engine-components/Skybox.ts +2 -0
- package/src/engine-components/SmoothFollow.ts +4 -4
- package/src/engine-components/WebARCameraBackground.ts +215 -0
- package/src/engine-components/WebXR.ts +12 -8
- package/src/engine-components/WebXRAvatar.ts +1 -0
- package/src/engine-components/codegen/components.ts +14 -6
- package/src/engine-components/js-extensions/Object3D.ts +6 -1
- package/src/engine-components/postprocessing/Effects/Antialiasing.ts +52 -0
- package/src/engine-components/postprocessing/Effects/Bloom.ts +75 -0
- package/src/engine-components/postprocessing/Effects/ChromaticAberration.ts +36 -0
- package/src/engine-components/postprocessing/Effects/ColorAdjustments.ts +114 -0
- package/src/engine-components/postprocessing/Effects/DepthOfField.ts +90 -0
- package/src/engine-components/postprocessing/Effects/Pixelation.ts +28 -0
- package/src/engine-components/postprocessing/Effects/ScreenspaceAmbientOcclusion.ts +71 -0
- package/src/engine-components/postprocessing/Effects/Tonemapping.ts +55 -0
- package/src/engine-components/postprocessing/Effects/Vignette.ts +55 -0
- package/src/engine-components/postprocessing/PostProcessingEffect.ts +112 -0
- package/src/engine-components/postprocessing/PostProcessingHandler.ts +148 -0
- package/src/engine-components/postprocessing/Volume.ts +194 -0
- package/src/engine-components/postprocessing/VolumeParameter.ts +85 -0
- package/src/engine-components/postprocessing/VolumeProfile.ts +40 -0
- package/src/engine-components/timeline/TimelineTracks.ts +16 -17
- package/src/engine-components/ui/Text.ts +37 -174
- package/src/engine-components-experimental/networking/PlayerSync.ts +68 -7
- package/src/include/three/ARButton.js +13 -24
- package/src/include/three/VRButton.js +1 -7
- package/lib/engine-components/Volume.d.ts +0 -34
- package/lib/engine-components/Volume.js +0 -140
- package/lib/engine-components/Volume.js.map +0 -1
- package/src/engine-components/Volume.ts +0 -141
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { DepthOfFieldEffect } from "postprocessing";
|
|
2
|
+
import { PostProcessingEffect } from "../PostProcessingEffect";
|
|
3
|
+
import { VolumeParameter } from "../VolumeParameter";
|
|
4
|
+
export declare enum DepthOfFieldMode {
|
|
5
|
+
Off = 0,
|
|
6
|
+
Gaussian = 1,
|
|
7
|
+
Bokeh = 2
|
|
8
|
+
}
|
|
9
|
+
export declare class DepthOfField extends PostProcessingEffect {
|
|
10
|
+
get typeName(): string;
|
|
11
|
+
mode: DepthOfFieldMode;
|
|
12
|
+
focusDistance: VolumeParameter;
|
|
13
|
+
focalLength: VolumeParameter;
|
|
14
|
+
aperture: VolumeParameter;
|
|
15
|
+
gaussianMaxRadius: VolumeParameter;
|
|
16
|
+
init(): void;
|
|
17
|
+
onCreateEffect(): DepthOfFieldEffect[] | undefined;
|
|
18
|
+
unapply(): void;
|
|
19
|
+
calculateFocusDistance(target: any): number;
|
|
20
|
+
viewZToOrthographicDepth(viewZ: any, near: any, far: any): number;
|
|
21
|
+
}
|
|
@@ -0,0 +1,87 @@
|
|
|
1
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
2
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
3
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
4
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
5
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
6
|
+
};
|
|
7
|
+
import { DepthOfFieldEffect } from "postprocessing";
|
|
8
|
+
import { getWorldPosition } from "../../../engine/engine_three_utils";
|
|
9
|
+
import { serializable } from "../../../engine/engine_serialization";
|
|
10
|
+
import { Mathf } from "../../../engine/engine_math";
|
|
11
|
+
import { PostProcessingEffect } from "../PostProcessingEffect";
|
|
12
|
+
import { VolumeParameter } from "../VolumeParameter";
|
|
13
|
+
import { registerCustomEffectType } from "../VolumeProfile";
|
|
14
|
+
export var DepthOfFieldMode;
|
|
15
|
+
(function (DepthOfFieldMode) {
|
|
16
|
+
DepthOfFieldMode[DepthOfFieldMode["Off"] = 0] = "Off";
|
|
17
|
+
DepthOfFieldMode[DepthOfFieldMode["Gaussian"] = 1] = "Gaussian";
|
|
18
|
+
DepthOfFieldMode[DepthOfFieldMode["Bokeh"] = 2] = "Bokeh";
|
|
19
|
+
})(DepthOfFieldMode || (DepthOfFieldMode = {}));
|
|
20
|
+
export class DepthOfField extends PostProcessingEffect {
|
|
21
|
+
get typeName() {
|
|
22
|
+
return "DepthOfField";
|
|
23
|
+
}
|
|
24
|
+
mode;
|
|
25
|
+
focusDistance;
|
|
26
|
+
focalLength;
|
|
27
|
+
aperture;
|
|
28
|
+
gaussianMaxRadius;
|
|
29
|
+
init() {
|
|
30
|
+
this.focalLength.valueProcessor = v => {
|
|
31
|
+
const t = v / 300;
|
|
32
|
+
const max = 2; // this.context.mainCameraComponent?.farClipPlane ?? 10;
|
|
33
|
+
return Mathf.lerp(max, .01, t);
|
|
34
|
+
};
|
|
35
|
+
const maxBokehScale = 20;
|
|
36
|
+
this.aperture.valueProcessor = v => {
|
|
37
|
+
const t = 1 - v / 32;
|
|
38
|
+
return Mathf.lerp(1, maxBokehScale, t);
|
|
39
|
+
};
|
|
40
|
+
}
|
|
41
|
+
onCreateEffect() {
|
|
42
|
+
if (this.mode === DepthOfFieldMode.Off)
|
|
43
|
+
return undefined;
|
|
44
|
+
// console.log(this.focusDistance.overrideState, this.focusDistance.value);
|
|
45
|
+
// const depth = new DepthEffect({
|
|
46
|
+
// inverted: true,
|
|
47
|
+
// // blendFunction: BlendFunction.SET,
|
|
48
|
+
// });
|
|
49
|
+
const dof = new DepthOfFieldEffect(this.context.mainCamera, {
|
|
50
|
+
worldFocusRange: .2,
|
|
51
|
+
focalLength: 1,
|
|
52
|
+
bokehScale: 20,
|
|
53
|
+
});
|
|
54
|
+
this.focusDistance.onValueChanged = v => dof.circleOfConfusionMaterial.worldFocusDistance = v;
|
|
55
|
+
this.focalLength.onValueChanged = v => dof.circleOfConfusionMaterial.worldFocusRange = v;
|
|
56
|
+
this.aperture.onValueChanged = v => dof.bokehScale = v;
|
|
57
|
+
return [dof];
|
|
58
|
+
}
|
|
59
|
+
unapply() {
|
|
60
|
+
}
|
|
61
|
+
calculateFocusDistance(target) {
|
|
62
|
+
const camera = this.context.mainCamera;
|
|
63
|
+
const distance = getWorldPosition(camera).distanceTo(target);
|
|
64
|
+
// console.log(distance, camera.near, camera.far);
|
|
65
|
+
return this.viewZToOrthographicDepth(-distance, camera.near, camera.far);
|
|
66
|
+
}
|
|
67
|
+
viewZToOrthographicDepth(viewZ, near, far) {
|
|
68
|
+
return (viewZ + near) / (near - far);
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
__decorate([
|
|
72
|
+
serializable()
|
|
73
|
+
], DepthOfField.prototype, "mode", void 0);
|
|
74
|
+
__decorate([
|
|
75
|
+
serializable(VolumeParameter)
|
|
76
|
+
], DepthOfField.prototype, "focusDistance", void 0);
|
|
77
|
+
__decorate([
|
|
78
|
+
serializable(VolumeParameter)
|
|
79
|
+
], DepthOfField.prototype, "focalLength", void 0);
|
|
80
|
+
__decorate([
|
|
81
|
+
serializable(VolumeParameter)
|
|
82
|
+
], DepthOfField.prototype, "aperture", void 0);
|
|
83
|
+
__decorate([
|
|
84
|
+
serializable(VolumeParameter)
|
|
85
|
+
], DepthOfField.prototype, "gaussianMaxRadius", void 0);
|
|
86
|
+
registerCustomEffectType("DepthOfField", DepthOfField);
|
|
87
|
+
//# sourceMappingURL=DepthOfField.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"DepthOfField.js","sourceRoot":"","sources":["../../../../../src/engine-components/postprocessing/Effects/DepthOfField.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { EffectProviderResult, PostProcessingEffect } from "../PostProcessingEffect";
|
|
2
|
+
import { VolumeParameter } from "../VolumeParameter";
|
|
3
|
+
export declare class PixelationEffect extends PostProcessingEffect {
|
|
4
|
+
get typeName(): string;
|
|
5
|
+
granularity: VolumeParameter;
|
|
6
|
+
onCreateEffect(): EffectProviderResult;
|
|
7
|
+
}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
2
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
3
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
4
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
5
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
6
|
+
};
|
|
7
|
+
import { registerCustomEffectType } from "../VolumeProfile";
|
|
8
|
+
import { PostProcessingEffect } from "../PostProcessingEffect";
|
|
9
|
+
import { PixelationEffect as PixelationEffectPP } from "postprocessing";
|
|
10
|
+
import { VolumeParameter } from "../VolumeParameter";
|
|
11
|
+
import { serializable } from "../../../engine/engine_serialization";
|
|
12
|
+
export class PixelationEffect extends PostProcessingEffect {
|
|
13
|
+
get typeName() {
|
|
14
|
+
return "PixelationEffect";
|
|
15
|
+
}
|
|
16
|
+
granularity;
|
|
17
|
+
onCreateEffect() {
|
|
18
|
+
const effect = new PixelationEffectPP();
|
|
19
|
+
this.granularity.onValueChanged = v => {
|
|
20
|
+
console.log(v);
|
|
21
|
+
effect.granularity = v;
|
|
22
|
+
};
|
|
23
|
+
return effect;
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
__decorate([
|
|
27
|
+
serializable(VolumeParameter)
|
|
28
|
+
], PixelationEffect.prototype, "granularity", void 0);
|
|
29
|
+
registerCustomEffectType("PixelationEffect", PixelationEffect);
|
|
30
|
+
//# sourceMappingURL=Pixelation.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Pixelation.js","sourceRoot":"","sources":["../../../../../src/engine-components/postprocessing/Effects/Pixelation.ts"],"names":[],"mappings":";;;;;;AAAA,OAAO,EAAE,wBAAwB,EAAE,MAAM,kBAAkB,CAAC;AAC5D,OAAO,EAAwB,oBAAoB,EAAE,MAAM,yBAAyB,CAAC;AACrF,OAAO,EAAE,gBAAgB,IAAI,kBAAkB,EAAE,MAAM,gBAAgB,CAAC;AACxE,OAAO,EAAE,eAAe,EAAE,MAAM,oBAAoB,CAAC;AACrD,OAAO,EAAE,YAAY,EAAE,MAAM,sCAAsC,CAAC;AAEpE,MAAM,OAAO,gBAAiB,SAAQ,oBAAoB;IACtD,IAAI,QAAQ;QACR,OAAO,kBAAkB,CAAC;IAC9B,CAAC;IAGD,WAAW,CAAmB;IAE9B,cAAc;QAEV,MAAM,MAAM,GAAG,IAAI,kBAAkB,EAAE,CAAC;QAExC,IAAI,CAAC,WAAW,CAAC,cAAc,GAAG,CAAC,CAAC,EAAE;YAClC,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;YACf,MAAM,CAAC,WAAW,GAAG,CAAC,CAAC;QAC3B,CAAC,CAAA;QAED,OAAO,MAAM,CAAC;IAClB,CAAC;CAEJ;AAdG;IADC,YAAY,CAAC,eAAe,CAAC;qDACA;AAelC,wBAAwB,CAAC,kBAAkB,EAAE,gBAAgB,CAAC,CAAC"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { EffectProviderResult, PostProcessingEffect } from "../PostProcessingEffect";
|
|
2
|
+
import { VolumeParameter } from "../VolumeParameter";
|
|
3
|
+
export declare class ScreenSpaceAmbientOcclusion extends PostProcessingEffect {
|
|
4
|
+
get typeName(): string;
|
|
5
|
+
intensity: VolumeParameter;
|
|
6
|
+
falloff: VolumeParameter;
|
|
7
|
+
samples: VolumeParameter;
|
|
8
|
+
onBeforeRender(): void;
|
|
9
|
+
private _ssao?;
|
|
10
|
+
onCreateEffect(): EffectProviderResult;
|
|
11
|
+
}
|
|
@@ -0,0 +1,70 @@
|
|
|
1
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
2
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
3
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
4
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
5
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
6
|
+
};
|
|
7
|
+
import { DepthDownsamplingPass, NormalPass, SSAOEffect } from "postprocessing";
|
|
8
|
+
import { PerspectiveCamera } from "three";
|
|
9
|
+
import { serializable } from "../../../engine/engine_serialization";
|
|
10
|
+
import { PostProcessingEffect } from "../PostProcessingEffect";
|
|
11
|
+
import { VolumeParameter } from "../VolumeParameter";
|
|
12
|
+
import { registerCustomEffectType } from "../VolumeProfile";
|
|
13
|
+
export class ScreenSpaceAmbientOcclusion extends PostProcessingEffect {
|
|
14
|
+
get typeName() {
|
|
15
|
+
return "ScreenSpaceAmbientOcclusion";
|
|
16
|
+
}
|
|
17
|
+
intensity;
|
|
18
|
+
falloff;
|
|
19
|
+
samples;
|
|
20
|
+
onBeforeRender() {
|
|
21
|
+
if (this._ssao && this.context.mainCamera instanceof PerspectiveCamera) {
|
|
22
|
+
const fadeDistance = this.context.mainCamera.far - this.context.mainCamera.near;
|
|
23
|
+
this._ssao.ssaoMaterial.worldDistanceFalloff = fadeDistance * .01;
|
|
24
|
+
this._ssao.ssaoMaterial.worldDistanceThreshold = this.context.mainCamera.far;
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
_ssao;
|
|
28
|
+
onCreateEffect() {
|
|
29
|
+
const cam = this.context.mainCamera;
|
|
30
|
+
const normalPass = new NormalPass(this.context.scene, cam);
|
|
31
|
+
const depthDownsamplingPass = new DepthDownsamplingPass({
|
|
32
|
+
normalBuffer: normalPass.texture,
|
|
33
|
+
resolutionScale: 0.5
|
|
34
|
+
});
|
|
35
|
+
const ssao = this._ssao = new SSAOEffect(cam, normalPass.texture, {
|
|
36
|
+
normalDepthBuffer: depthDownsamplingPass.texture,
|
|
37
|
+
worldDistanceThreshold: 1,
|
|
38
|
+
worldDistanceFalloff: 1,
|
|
39
|
+
worldProximityThreshold: .1,
|
|
40
|
+
worldProximityFalloff: 2,
|
|
41
|
+
intensity: 1,
|
|
42
|
+
// blendFunction: BlendFunction.MULTIPLY,
|
|
43
|
+
});
|
|
44
|
+
this.intensity.onValueChanged = newValue => {
|
|
45
|
+
ssao.intensity = newValue;
|
|
46
|
+
};
|
|
47
|
+
this.falloff.onValueChanged = newValue => {
|
|
48
|
+
ssao.ssaoMaterial.radius = newValue * .1;
|
|
49
|
+
};
|
|
50
|
+
this.samples.onValueChanged = newValue => {
|
|
51
|
+
ssao.samples = newValue;
|
|
52
|
+
};
|
|
53
|
+
const arr = new Array();
|
|
54
|
+
arr.push(normalPass);
|
|
55
|
+
arr.push(depthDownsamplingPass);
|
|
56
|
+
arr.push(ssao);
|
|
57
|
+
return arr;
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
__decorate([
|
|
61
|
+
serializable(VolumeParameter)
|
|
62
|
+
], ScreenSpaceAmbientOcclusion.prototype, "intensity", void 0);
|
|
63
|
+
__decorate([
|
|
64
|
+
serializable(VolumeParameter)
|
|
65
|
+
], ScreenSpaceAmbientOcclusion.prototype, "falloff", void 0);
|
|
66
|
+
__decorate([
|
|
67
|
+
serializable(VolumeParameter)
|
|
68
|
+
], ScreenSpaceAmbientOcclusion.prototype, "samples", void 0);
|
|
69
|
+
registerCustomEffectType("ScreenSpaceAmbientOcclusion", ScreenSpaceAmbientOcclusion);
|
|
70
|
+
//# sourceMappingURL=ScreenspaceAmbientOcclusion.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ScreenspaceAmbientOcclusion.js","sourceRoot":"","sources":["../../../../../src/engine-components/postprocessing/Effects/ScreenspaceAmbientOcclusion.ts"],"names":[],"mappings":";;;;;;AAAA,OAAO,EAAiB,qBAAqB,EAAU,UAAU,EAAE,UAAU,EAAE,MAAM,gBAAgB,CAAC;AACtG,OAAO,EAAc,iBAAiB,EAAE,MAAM,OAAO,CAAC;AACtD,OAAO,EAAE,YAAY,EAAE,MAAM,sCAAsC,CAAC;AACpE,OAAO,EAAwB,oBAAoB,EAAE,MAAM,yBAAyB,CAAC;AACrF,OAAO,EAAE,eAAe,EAAE,MAAM,oBAAoB,CAAC;AACrD,OAAO,EAAE,wBAAwB,EAAE,MAAM,kBAAkB,CAAC;AAG5D,MAAM,OAAO,2BAA4B,SAAQ,oBAAoB;IAEjE,IAAI,QAAQ;QACR,OAAO,6BAA6B,CAAC;IACzC,CAAC;IAGD,SAAS,CAAmB;IAG5B,OAAO,CAAmB;IAG1B,OAAO,CAAmB;IAE1B,cAAc;QACV,IAAI,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,OAAO,CAAC,UAAU,YAAY,iBAAiB,EAAE;YACpE,MAAM,YAAY,GAAG,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,GAAG,GAAG,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,IAAI,CAAC;YAChF,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,oBAAoB,GAAG,YAAY,GAAG,GAAG,CAAC;YAClE,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,sBAAsB,GAAG,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,GAAG,CAAC;SAChF;IACL,CAAC;IAEO,KAAK,CAAc;IAE3B,cAAc;QAEV,MAAM,GAAG,GAAG,IAAI,CAAC,OAAO,CAAC,UAAgC,CAAC;QAC1D,MAAM,UAAU,GAAG,IAAI,UAAU,CAAC,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,GAAG,CAAC,CAAC;QAC3D,MAAM,qBAAqB,GAAG,IAAI,qBAAqB,CAAC;YACpD,YAAY,EAAE,UAAU,CAAC,OAAO;YAChC,eAAe,EAAE,GAAG;SACvB,CAAC,CAAC;QAEH,MAAM,IAAI,GAAG,IAAI,CAAC,KAAK,GAAG,IAAI,UAAU,CAAC,GAAI,EAAE,UAAU,CAAC,OAAO,EAAE;YAC/D,iBAAiB,EAAE,qBAAqB,CAAC,OAAO;YAChD,sBAAsB,EAAE,CAAC;YACzB,oBAAoB,EAAE,CAAC;YACvB,uBAAuB,EAAE,EAAE;YAC3B,qBAAqB,EAAE,CAAC;YACxB,SAAS,EAAE,CAAC;YACZ,yCAAyC;SAC5C,CAAC,CAAC;QAEH,IAAI,CAAC,SAAS,CAAC,cAAc,GAAG,QAAQ,CAAC,EAAE;YACvC,IAAI,CAAC,SAAS,GAAG,QAAQ,CAAC;QAC9B,CAAC,CAAA;QACD,IAAI,CAAC,OAAO,CAAC,cAAc,GAAG,QAAQ,CAAC,EAAE;YACrC,IAAI,CAAC,YAAY,CAAC,MAAM,GAAG,QAAQ,GAAG,EAAE,CAAC;QAC7C,CAAC,CAAA;QACD,IAAI,CAAC,OAAO,CAAC,cAAc,GAAG,QAAQ,CAAC,EAAE;YACrC,IAAI,CAAC,OAAO,GAAG,QAAQ,CAAC;QAC5B,CAAC,CAAA;QAED,MAAM,GAAG,GAAG,IAAI,KAAK,EAAE,CAAC;QACxB,GAAG,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QACrB,GAAG,CAAC,IAAI,CAAC,qBAAqB,CAAC,CAAC;QAChC,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACf,OAAO,GAAG,CAAC;IACf,CAAC;CAEJ;AAtDG;IADC,YAAY,CAAC,eAAe,CAAC;8DACF;AAG5B;IADC,YAAY,CAAC,eAAe,CAAC;4DACJ;AAG1B;IADC,YAAY,CAAC,eAAe,CAAC;4DACJ;AAiD9B,wBAAwB,CAAC,6BAA6B,EAAE,2BAA2B,CAAC,CAAC"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { PostProcessingEffect } from "../PostProcessingEffect";
|
|
2
|
+
import { VolumeParameter } from "../VolumeParameter";
|
|
3
|
+
export declare enum TonemappingMode {
|
|
4
|
+
None = 0,
|
|
5
|
+
Neutral = 1,
|
|
6
|
+
ACES = 2
|
|
7
|
+
}
|
|
8
|
+
export declare class ToneMapping extends PostProcessingEffect {
|
|
9
|
+
get typeName(): string;
|
|
10
|
+
mode: VolumeParameter;
|
|
11
|
+
get isToneMapping(): boolean;
|
|
12
|
+
init(): void;
|
|
13
|
+
apply(): void;
|
|
14
|
+
unapply(): void;
|
|
15
|
+
private _apply;
|
|
16
|
+
}
|
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
2
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
3
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
4
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
5
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
6
|
+
};
|
|
7
|
+
import { ACESFilmicToneMapping, LinearToneMapping, NoToneMapping, ReinhardToneMapping } from "three";
|
|
8
|
+
import { serializable } from "../../../engine/engine_serialization";
|
|
9
|
+
import { PostProcessingEffect } from "../PostProcessingEffect";
|
|
10
|
+
import { VolumeParameter } from "../VolumeParameter";
|
|
11
|
+
import { registerCustomEffectType } from "../VolumeProfile";
|
|
12
|
+
export var TonemappingMode;
|
|
13
|
+
(function (TonemappingMode) {
|
|
14
|
+
TonemappingMode[TonemappingMode["None"] = 0] = "None";
|
|
15
|
+
TonemappingMode[TonemappingMode["Neutral"] = 1] = "Neutral";
|
|
16
|
+
TonemappingMode[TonemappingMode["ACES"] = 2] = "ACES";
|
|
17
|
+
})(TonemappingMode || (TonemappingMode = {}));
|
|
18
|
+
export class ToneMapping extends PostProcessingEffect {
|
|
19
|
+
get typeName() {
|
|
20
|
+
return "ToneMapping";
|
|
21
|
+
}
|
|
22
|
+
mode;
|
|
23
|
+
get isToneMapping() { return true; }
|
|
24
|
+
init() {
|
|
25
|
+
this.mode.defaultValue = NoToneMapping;
|
|
26
|
+
}
|
|
27
|
+
apply() {
|
|
28
|
+
this.mode.onValueChanged = this._apply.bind(this);
|
|
29
|
+
this._apply(this.mode.value);
|
|
30
|
+
}
|
|
31
|
+
unapply() {
|
|
32
|
+
this.context.renderer.toneMapping = NoToneMapping;
|
|
33
|
+
}
|
|
34
|
+
_apply(v) {
|
|
35
|
+
switch (v) {
|
|
36
|
+
case TonemappingMode.None:
|
|
37
|
+
this.context.renderer.toneMapping = LinearToneMapping;
|
|
38
|
+
break;
|
|
39
|
+
case TonemappingMode.Neutral:
|
|
40
|
+
this.context.renderer.toneMapping = ReinhardToneMapping;
|
|
41
|
+
break;
|
|
42
|
+
case TonemappingMode.ACES:
|
|
43
|
+
this.context.renderer.toneMapping = ACESFilmicToneMapping;
|
|
44
|
+
break;
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
__decorate([
|
|
49
|
+
serializable(VolumeParameter)
|
|
50
|
+
], ToneMapping.prototype, "mode", void 0);
|
|
51
|
+
registerCustomEffectType("Tonemapping", ToneMapping);
|
|
52
|
+
//# sourceMappingURL=Tonemapping.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Tonemapping.js","sourceRoot":"","sources":["../../../../../src/engine-components/postprocessing/Effects/Tonemapping.ts"],"names":[],"mappings":";;;;;;AAAA,OAAO,EAAE,qBAAqB,EAAE,iBAAiB,EAAE,aAAa,EAAE,mBAAmB,EAAE,MAAM,OAAO,CAAC;AACrG,OAAO,EAAE,YAAY,EAAE,MAAM,sCAAsC,CAAC;AACpE,OAAO,EAAwB,oBAAoB,EAAE,MAAM,yBAAyB,CAAC;AACrF,OAAO,EAAE,eAAe,EAAE,MAAM,oBAAoB,CAAC;AACrD,OAAO,EAAE,wBAAwB,EAAE,MAAM,kBAAkB,CAAC;AAG5D,MAAM,CAAN,IAAY,eAIX;AAJD,WAAY,eAAe;IACvB,qDAAQ,CAAA;IACR,2DAAW,CAAA;IACX,qDAAQ,CAAA;AACZ,CAAC,EAJW,eAAe,KAAf,eAAe,QAI1B;AAED,MAAM,OAAO,WAAY,SAAQ,oBAAoB;IAGjD,IAAI,QAAQ;QACR,OAAO,aAAa,CAAC;IACzB,CAAC;IAGD,IAAI,CAAmB;IAEvB,IAAI,aAAa,KAAK,OAAO,IAAI,CAAC,CAAC,CAAC;IAEpC,IAAI;QACA,IAAI,CAAC,IAAI,CAAC,YAAY,GAAG,aAAa,CAAC;IAC3C,CAAC;IAED,KAAK;QACD,IAAI,CAAC,IAAK,CAAC,cAAc,GAAG,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACnD,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,IAAK,CAAC,KAAK,CAAC,CAAA;IACjC,CAAC;IAED,OAAO;QACH,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,WAAW,GAAG,aAAa,CAAC;IACtD,CAAC;IAEO,MAAM,CAAC,CAAC;QACZ,QAAQ,CAAC,EAAE;YACP,KAAK,eAAe,CAAC,IAAI;gBACrB,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,WAAW,GAAG,iBAAiB,CAAC;gBACtD,MAAM;YACV,KAAK,eAAe,CAAC,OAAO;gBACxB,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,WAAW,GAAG,mBAAmB,CAAC;gBACxD,MAAM;YACV,KAAK,eAAe,CAAC,IAAI;gBACrB,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,WAAW,GAAG,qBAAqB,CAAC;gBAC1D,MAAM;SACb;IACL,CAAC;CAEJ;AA/BG;IADC,YAAY,CAAC,eAAe,CAAC;yCACP;AAiC3B,wBAAwB,CAAC,aAAa,EAAE,WAAW,CAAC,CAAC"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { VolumeParameter } from "../VolumeParameter";
|
|
2
|
+
import { EffectProviderResult, PostProcessingEffect } from "../PostProcessingEffect";
|
|
3
|
+
export declare class Vignette extends PostProcessingEffect {
|
|
4
|
+
get typeName(): string;
|
|
5
|
+
color: VolumeParameter;
|
|
6
|
+
intensity: VolumeParameter;
|
|
7
|
+
center: VolumeParameter;
|
|
8
|
+
init(): void;
|
|
9
|
+
onCreateEffect(): EffectProviderResult;
|
|
10
|
+
private updateDarkness;
|
|
11
|
+
}
|
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
2
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
3
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
4
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
5
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
6
|
+
};
|
|
7
|
+
import { serializable } from "../../../engine/engine_serialization";
|
|
8
|
+
import { VolumeParameter } from "../VolumeParameter";
|
|
9
|
+
import { PostProcessingEffect } from "../PostProcessingEffect";
|
|
10
|
+
import { registerCustomEffectType } from "../VolumeProfile";
|
|
11
|
+
import { VignetteEffect } from "postprocessing";
|
|
12
|
+
export class Vignette extends PostProcessingEffect {
|
|
13
|
+
get typeName() {
|
|
14
|
+
return "Vignette";
|
|
15
|
+
}
|
|
16
|
+
color;
|
|
17
|
+
intensity;
|
|
18
|
+
center;
|
|
19
|
+
init() {
|
|
20
|
+
this.color.defaultValue = { r: 0, g: 0, b: 0, a: 1 };
|
|
21
|
+
this.intensity.defaultValue = 0;
|
|
22
|
+
this.center.defaultValue = { x: 0.5, y: 0.5 };
|
|
23
|
+
}
|
|
24
|
+
onCreateEffect() {
|
|
25
|
+
// https://github.com/pmndrs/postprocessing/blob/f8ed90635ee6710744cc0f38811fc00ce873a450/src/effects/VignetteEffect.js
|
|
26
|
+
const vignette = new VignetteEffect();
|
|
27
|
+
this.intensity.onValueChanged = v => {
|
|
28
|
+
vignette.offset = v;
|
|
29
|
+
this.updateDarkness(vignette);
|
|
30
|
+
};
|
|
31
|
+
this.color.onValueChanged = _ => {
|
|
32
|
+
this.updateDarkness(vignette);
|
|
33
|
+
};
|
|
34
|
+
// this.center.onValueChanged = v => {
|
|
35
|
+
// console.log(v);
|
|
36
|
+
// vignette.offset = v.x;
|
|
37
|
+
// };
|
|
38
|
+
return vignette;
|
|
39
|
+
}
|
|
40
|
+
updateDarkness(effect) {
|
|
41
|
+
// const col = this.color.value;
|
|
42
|
+
// const colval = 1 - (col.r + col.g + col.b + col.a) / 4;
|
|
43
|
+
const val = this.intensity.value;
|
|
44
|
+
effect.darkness = val;
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
__decorate([
|
|
48
|
+
serializable(VolumeParameter)
|
|
49
|
+
], Vignette.prototype, "color", void 0);
|
|
50
|
+
__decorate([
|
|
51
|
+
serializable(VolumeParameter)
|
|
52
|
+
], Vignette.prototype, "intensity", void 0);
|
|
53
|
+
__decorate([
|
|
54
|
+
serializable(VolumeParameter)
|
|
55
|
+
], Vignette.prototype, "center", void 0);
|
|
56
|
+
registerCustomEffectType("Vignette", Vignette);
|
|
57
|
+
//# sourceMappingURL=Vignette.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Vignette.js","sourceRoot":"","sources":["../../../../../src/engine-components/postprocessing/Effects/Vignette.ts"],"names":[],"mappings":";;;;;;AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,sCAAsC,CAAC;AACpE,OAAO,EAAE,eAAe,EAAE,MAAM,oBAAoB,CAAC;AACrD,OAAO,EAAwB,oBAAoB,EAAE,MAAM,yBAAyB,CAAC;AACrF,OAAO,EAAE,wBAAwB,EAAE,MAAM,kBAAkB,CAAC;AAC5D,OAAO,EAAE,cAAc,EAAE,MAAM,gBAAgB,CAAC;AAGhD,MAAM,OAAO,QAAS,SAAQ,oBAAoB;IAC9C,IAAI,QAAQ;QACR,OAAO,UAAU,CAAC;IACtB,CAAC;IAGD,KAAK,CAAmB;IAGxB,SAAS,CAAmB;IAG5B,MAAM,CAAmB;IAEzB,IAAI;QACA,IAAI,CAAC,KAAK,CAAC,YAAY,GAAG,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC;QACrD,IAAI,CAAC,SAAS,CAAC,YAAY,GAAG,CAAC,CAAC;QAChC,IAAI,CAAC,MAAM,CAAC,YAAY,GAAG,EAAE,CAAC,EAAE,GAAG,EAAE,CAAC,EAAE,GAAG,EAAE,CAAC;IAClD,CAAC;IAED,cAAc;QACV,uHAAuH;QACvH,MAAM,QAAQ,GAAG,IAAI,cAAc,EAAE,CAAC;QAEtC,IAAI,CAAC,SAAS,CAAC,cAAc,GAAG,CAAC,CAAC,EAAE;YAChC,QAAQ,CAAC,MAAM,GAAG,CAAC,CAAC;YACpB,IAAI,CAAC,cAAc,CAAC,QAAQ,CAAC,CAAC;QAClC,CAAC,CAAA;QACD,IAAI,CAAC,KAAK,CAAC,cAAc,GAAG,CAAC,CAAC,EAAE;YAC5B,IAAI,CAAC,cAAc,CAAC,QAAQ,CAAC,CAAC;QAClC,CAAC,CAAC;QACF,sCAAsC;QACtC,sBAAsB;QACtB,6BAA6B;QAC7B,KAAK;QAEL,OAAO,QAAQ,CAAC;IACpB,CAAC;IAEO,cAAc,CAAC,MAAsB;QACzC,gCAAgC;QAChC,0DAA0D;QAC1D,MAAM,GAAG,GAAG,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC;QACjC,MAAM,CAAC,QAAQ,GAAG,GAAG,CAAC;IAC1B,CAAC;CAEJ;AAxCG;IADC,YAAY,CAAC,eAAe,CAAC;uCACN;AAGxB;IADC,YAAY,CAAC,eAAe,CAAC;2CACF;AAG5B;IADC,YAAY,CAAC,eAAe,CAAC;wCACL;AAmC7B,wBAAwB,CAAC,UAAU,EAAE,QAAQ,CAAC,CAAC"}
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import { Effect, Pass } from "postprocessing";
|
|
2
|
+
import { Component } from "../Component";
|
|
3
|
+
import { ISerializable, SerializationContext } from "../../engine/engine_serialization_core";
|
|
4
|
+
import { EditorModification, IEditorModification } from "../../engine/engine_editor-sync";
|
|
5
|
+
export declare type EffectProviderResult = Effect | Pass | Array<Effect | Pass>;
|
|
6
|
+
export interface IEffectProvider {
|
|
7
|
+
apply(): void | undefined | EffectProviderResult;
|
|
8
|
+
unapply(): void;
|
|
9
|
+
}
|
|
10
|
+
export declare abstract class PostProcessingEffect extends Component implements IEffectProvider, ISerializable, IEditorModification {
|
|
11
|
+
abstract get typeName(): string;
|
|
12
|
+
onEnable(): void;
|
|
13
|
+
onDisable(): void;
|
|
14
|
+
active: boolean;
|
|
15
|
+
/** override to initialize bindings on parameters */
|
|
16
|
+
init(): void;
|
|
17
|
+
/** previously created effect (if any) */
|
|
18
|
+
private _result;
|
|
19
|
+
/** Apply post settings. Make sure to call super.apply() if you also create an effect */
|
|
20
|
+
apply(): void | undefined | EffectProviderResult;
|
|
21
|
+
/** Reset previously set values (e.g. when adjusting settings on the renderer like Tonemapping) */
|
|
22
|
+
unapply(): void;
|
|
23
|
+
/** implement to create a effect once to be cached in the base class. Make sure super.apply() is called if you also override apply */
|
|
24
|
+
onCreateEffect?(): EffectProviderResult | undefined;
|
|
25
|
+
dispose(): void;
|
|
26
|
+
private initParameters;
|
|
27
|
+
onAfterDeserialize(data: any, _context: SerializationContext): void;
|
|
28
|
+
onEditorModification(modification: EditorModification): void | boolean | undefined;
|
|
29
|
+
}
|
|
@@ -0,0 +1,89 @@
|
|
|
1
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
2
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
3
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
4
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
5
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
6
|
+
};
|
|
7
|
+
import { serializable } from "../../engine/engine_serialization";
|
|
8
|
+
import { VolumeParameter } from "./VolumeParameter";
|
|
9
|
+
import { Component } from "../Component";
|
|
10
|
+
export class PostProcessingEffect extends Component {
|
|
11
|
+
onEnable() {
|
|
12
|
+
// Dont override the serialized value by enabling (we could also just disable this component / map enabled to active)
|
|
13
|
+
if (this.__internalDidAwakeAndStart)
|
|
14
|
+
this.active = true;
|
|
15
|
+
}
|
|
16
|
+
onDisable() {
|
|
17
|
+
this.active = false;
|
|
18
|
+
}
|
|
19
|
+
active = true;
|
|
20
|
+
/** override to initialize bindings on parameters */
|
|
21
|
+
init() {
|
|
22
|
+
}
|
|
23
|
+
/** previously created effect (if any) */
|
|
24
|
+
_result;
|
|
25
|
+
/** Apply post settings. Make sure to call super.apply() if you also create an effect */
|
|
26
|
+
apply() {
|
|
27
|
+
if (!this._result) {
|
|
28
|
+
this._result = this.onCreateEffect?.call(this);
|
|
29
|
+
if (this._result) {
|
|
30
|
+
this.initParameters();
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
return this._result;
|
|
34
|
+
}
|
|
35
|
+
/** Reset previously set values (e.g. when adjusting settings on the renderer like Tonemapping) */
|
|
36
|
+
unapply() { }
|
|
37
|
+
dispose() {
|
|
38
|
+
if (this._result) {
|
|
39
|
+
if (Array.isArray(this._result)) {
|
|
40
|
+
this._result.forEach(r => r.dispose());
|
|
41
|
+
}
|
|
42
|
+
else {
|
|
43
|
+
this._result.dispose();
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
this._result = undefined;
|
|
47
|
+
}
|
|
48
|
+
initParameters() {
|
|
49
|
+
// Automatically call init on all VolumeParameter properties
|
|
50
|
+
// This will enforce the valueProcessor and onValueChanged to be called
|
|
51
|
+
const keys = Object.keys(this);
|
|
52
|
+
for (const key of keys) {
|
|
53
|
+
const value = this[key];
|
|
54
|
+
if (value instanceof VolumeParameter) {
|
|
55
|
+
value.__init();
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
onAfterDeserialize(data, _context) {
|
|
60
|
+
// When using additional effects and parameters exported from the editor are not in the volume parameter format
|
|
61
|
+
if (typeof data === "object") {
|
|
62
|
+
const types = this["$serializedTypes"];
|
|
63
|
+
if (types) {
|
|
64
|
+
for (const fieldName in Object.keys(types)) {
|
|
65
|
+
const type = types[fieldName];
|
|
66
|
+
if (type === VolumeParameter) {
|
|
67
|
+
const value = data[fieldName];
|
|
68
|
+
if (value !== undefined) {
|
|
69
|
+
this[fieldName].value = value;
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
onEditorModification(modification) {
|
|
77
|
+
// Handle a property modification if the property is a VolumeParameter and the modification is just a plain value
|
|
78
|
+
const key = modification.propertyName;
|
|
79
|
+
if (this[key] instanceof VolumeParameter) {
|
|
80
|
+
const value = modification.value;
|
|
81
|
+
this[key].value = value;
|
|
82
|
+
return true;
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
}
|
|
86
|
+
__decorate([
|
|
87
|
+
serializable()
|
|
88
|
+
], PostProcessingEffect.prototype, "active", void 0);
|
|
89
|
+
//# sourceMappingURL=PostProcessingEffect.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"PostProcessingEffect.js","sourceRoot":"","sources":["../../../../src/engine-components/postprocessing/PostProcessingEffect.ts"],"names":[],"mappings":";;;;;;AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,mCAAmC,CAAC;AAEjE,OAAO,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAC;AACpD,OAAO,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AAWzC,MAAM,OAAgB,oBAAqB,SAAQ,SAAS;IAIxD,QAAQ;QACJ,qHAAqH;QACrH,IAAI,IAAI,CAAC,0BAA0B;YAC/B,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC;IAC3B,CAAC;IAED,SAAS;QACL,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;IACxB,CAAC;IAGD,MAAM,GAAY,IAAI,CAAC;IAEvB,oDAAoD;IACpD,IAAI;IAEJ,CAAC;IAED,yCAAyC;IACjC,OAAO,CAA0C;IAGzD,wFAAwF;IACxF,KAAK;QACD,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE;YACf,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,cAAc,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC;YAC/C,IAAI,IAAI,CAAC,OAAO,EAAE;gBACd,IAAI,CAAC,cAAc,EAAE,CAAC;aACzB;SACJ;QACD,OAAO,IAAI,CAAC,OAAO,CAAC;IACxB,CAAC;IAED,kGAAkG;IAClG,OAAO,KAAW,CAAC;IAKnB,OAAO;QACH,IAAI,IAAI,CAAC,OAAO,EAAE;YACd,IAAI,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE;gBAC7B,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,OAAO,EAAE,CAAC,CAAC;aAC1C;iBAAM;gBACH,IAAI,CAAC,OAAO,CAAC,OAAO,EAAE,CAAC;aAC1B;SACJ;QACD,IAAI,CAAC,OAAO,GAAG,SAAS,CAAC;IAC7B,CAAC;IAEO,cAAc;QAClB,4DAA4D;QAC5D,uEAAuE;QACvE,MAAM,IAAI,GAAG,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAC/B,KAAK,MAAM,GAAG,IAAI,IAAI,EAAE;YACpB,MAAM,KAAK,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC;YACxB,IAAI,KAAK,YAAY,eAAe,EAAE;gBAClC,KAAK,CAAC,MAAM,EAAE,CAAC;aAClB;SACJ;IACL,CAAC;IAED,kBAAkB,CAAC,IAAS,EAAE,QAA8B;QACxD,+GAA+G;QAC/G,IAAI,OAAO,IAAI,KAAK,QAAQ,EAAE;YAC1B,MAAM,KAAK,GAAG,IAAI,CAAC,kBAAkB,CAAC,CAAC;YACvC,IAAI,KAAK,EAAE;gBACP,KAAK,MAAM,SAAS,IAAI,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE;oBACxC,MAAM,IAAI,GAAG,KAAK,CAAC,SAAS,CAAC,CAAC;oBAC9B,IAAI,IAAI,KAAK,eAAe,EAAE;wBAC1B,MAAM,KAAK,GAAG,IAAI,CAAC,SAAS,CAAC,CAAC;wBAC9B,IAAI,KAAK,KAAK,SAAS,EAAE;4BACrB,IAAI,CAAC,SAAS,CAAC,CAAC,KAAK,GAAG,KAAK,CAAC;yBACjC;qBACJ;iBACJ;aACJ;SACJ;IACL,CAAC;IAGD,oBAAoB,CAAC,YAAgC;QACjD,iHAAiH;QACjH,MAAM,GAAG,GAAG,YAAY,CAAC,YAAY,CAAC;QACtC,IAAI,IAAI,CAAC,GAAG,CAAC,YAAY,eAAe,EAAE;YACtC,MAAM,KAAK,GAAG,YAAY,CAAC,KAAK,CAAC;YACjC,IAAI,CAAC,GAAG,CAAC,CAAC,KAAK,GAAG,KAAK,CAAC;YACxB,OAAO,IAAI,CAAC;SACf;IACL,CAAC;CACJ;AA/EG;IADC,YAAY,EAAE;oDACQ"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { Context } from "../../engine/engine_setup";
|
|
2
|
+
import { PostProcessingEffect } from "./PostProcessingEffect";
|
|
3
|
+
export declare class PostProcessingHandler {
|
|
4
|
+
private _composer;
|
|
5
|
+
private _lastVolumeComponents?;
|
|
6
|
+
private _effects;
|
|
7
|
+
apply(context: Context, components: PostProcessingEffect[]): void;
|
|
8
|
+
unapply(context: Context): void;
|
|
9
|
+
dispose(context: Context): void;
|
|
10
|
+
private onApply;
|
|
11
|
+
/** Build composer passes */
|
|
12
|
+
private applyEffects;
|
|
13
|
+
}
|