@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.
Files changed (230) hide show
  1. package/CHANGELOG.md +20 -0
  2. package/dist/needle-engine.js +34306 -26230
  3. package/dist/needle-engine.umd.cjs +743 -298
  4. package/lib/engine/api.d.ts +4 -0
  5. package/lib/engine/api.js +10 -0
  6. package/lib/engine/api.js.map +1 -1
  7. package/lib/engine/codegen/register_types.js +23 -7
  8. package/lib/engine/codegen/register_types.js.map +1 -1
  9. package/lib/engine/debug/debug_overlay.js +7 -1
  10. package/lib/engine/debug/debug_overlay.js.map +1 -1
  11. package/lib/engine/engine_addressables.js +2 -2
  12. package/lib/engine/engine_addressables.js.map +1 -1
  13. package/lib/engine/engine_assetdatabase.d.ts +17 -51
  14. package/lib/engine/engine_assetdatabase.js +252 -126
  15. package/lib/engine/engine_assetdatabase.js.map +1 -1
  16. package/lib/engine/engine_components.js +13 -1
  17. package/lib/engine/engine_components.js.map +1 -1
  18. package/lib/engine/engine_components_internal.d.ts +8 -0
  19. package/lib/engine/engine_components_internal.js +29 -0
  20. package/lib/engine/engine_components_internal.js.map +1 -0
  21. package/lib/engine/engine_constants.d.ts +1 -0
  22. package/lib/engine/engine_constants.js +1 -0
  23. package/lib/engine/engine_constants.js.map +1 -1
  24. package/lib/engine/engine_context_registry.d.ts +2 -0
  25. package/lib/engine/engine_context_registry.js +6 -0
  26. package/lib/engine/engine_context_registry.js.map +1 -1
  27. package/lib/engine/engine_editor-sync.d.ts +9 -0
  28. package/lib/engine/engine_editor-sync.js +8 -0
  29. package/lib/engine/engine_editor-sync.js.map +1 -0
  30. package/lib/engine/engine_element_loading.js +1 -1
  31. package/lib/engine/engine_element_loading.js.map +1 -1
  32. package/lib/engine/engine_gameobject.js +15 -20
  33. package/lib/engine/engine_gameobject.js.map +1 -1
  34. package/lib/engine/engine_gltf_builtin_components.d.ts +2 -3
  35. package/lib/engine/engine_gltf_builtin_components.js +23 -6
  36. package/lib/engine/engine_gltf_builtin_components.js.map +1 -1
  37. package/lib/engine/engine_networking_auto.d.ts +1 -0
  38. package/lib/engine/engine_networking_auto.js +42 -9
  39. package/lib/engine/engine_networking_auto.js.map +1 -1
  40. package/lib/engine/engine_patcher.d.ts +8 -0
  41. package/lib/engine/engine_patcher.js +98 -0
  42. package/lib/engine/engine_patcher.js.map +1 -0
  43. package/lib/engine/engine_physics.d.ts +5 -1
  44. package/lib/engine/engine_physics.js +11 -1
  45. package/lib/engine/engine_physics.js.map +1 -1
  46. package/lib/engine/engine_scenetools.js +0 -1
  47. package/lib/engine/engine_scenetools.js.map +1 -1
  48. package/lib/engine/engine_serialization_core.js +4 -0
  49. package/lib/engine/engine_serialization_core.js.map +1 -1
  50. package/lib/engine/engine_setup.d.ts +1 -1
  51. package/lib/engine/engine_setup.js +9 -5
  52. package/lib/engine/engine_setup.js.map +1 -1
  53. package/lib/engine/engine_texture.d.ts +6 -1
  54. package/lib/engine/engine_texture.js +39 -1
  55. package/lib/engine/engine_texture.js.map +1 -1
  56. package/lib/engine/engine_types.d.ts +4 -0
  57. package/lib/engine/engine_types.js.map +1 -1
  58. package/lib/engine/engine_utils.js +3 -2
  59. package/lib/engine/engine_utils.js.map +1 -1
  60. package/lib/engine/extensions/NEEDLE_progressive.d.ts +0 -1
  61. package/lib/engine/extensions/NEEDLE_progressive.js +24 -26
  62. package/lib/engine/extensions/NEEDLE_progressive.js.map +1 -1
  63. package/lib/engine/extensions/extensions.d.ts +4 -1
  64. package/lib/engine/extensions/extensions.js +16 -0
  65. package/lib/engine/extensions/extensions.js.map +1 -1
  66. package/lib/engine/extensions/usage_tracker.d.ts +12 -0
  67. package/lib/engine/extensions/usage_tracker.js +59 -0
  68. package/lib/engine/extensions/usage_tracker.js.map +1 -0
  69. package/lib/engine-components/AnimatorController.js +4 -0
  70. package/lib/engine-components/AnimatorController.js.map +1 -1
  71. package/lib/engine-components/AudioSource.js +2 -1
  72. package/lib/engine-components/AudioSource.js.map +1 -1
  73. package/lib/engine-components/Camera.d.ts +6 -0
  74. package/lib/engine-components/Camera.js +70 -31
  75. package/lib/engine-components/Camera.js.map +1 -1
  76. package/lib/engine-components/Component.d.ts +52 -0
  77. package/lib/engine-components/Component.js +55 -14
  78. package/lib/engine-components/Component.js.map +1 -1
  79. package/lib/engine-components/Networking.js +19 -0
  80. package/lib/engine-components/Networking.js.map +1 -1
  81. package/lib/engine-components/OrbitControls.d.ts +2 -0
  82. package/lib/engine-components/OrbitControls.js +9 -0
  83. package/lib/engine-components/OrbitControls.js.map +1 -1
  84. package/lib/engine-components/ParticleSystem.js +11 -1
  85. package/lib/engine-components/ParticleSystem.js.map +1 -1
  86. package/lib/engine-components/ReflectionProbe.js +18 -6
  87. package/lib/engine-components/ReflectionProbe.js.map +1 -1
  88. package/lib/engine-components/Renderer.d.ts +1 -1
  89. package/lib/engine-components/Renderer.js +24 -6
  90. package/lib/engine-components/Renderer.js.map +1 -1
  91. package/lib/engine-components/Skybox.js +2 -0
  92. package/lib/engine-components/Skybox.js.map +1 -1
  93. package/lib/engine-components/SmoothFollow.js +1 -2
  94. package/lib/engine-components/SmoothFollow.js.map +1 -1
  95. package/lib/engine-components/WebARCameraBackground.d.ts +19 -0
  96. package/lib/engine-components/WebARCameraBackground.js +185 -0
  97. package/lib/engine-components/WebARCameraBackground.js.map +1 -0
  98. package/lib/engine-components/WebXR.d.ts +4 -0
  99. package/lib/engine-components/WebXR.js +11 -8
  100. package/lib/engine-components/WebXR.js.map +1 -1
  101. package/lib/engine-components/WebXRAvatar.js +1 -0
  102. package/lib/engine-components/WebXRAvatar.js.map +1 -1
  103. package/lib/engine-components/codegen/components.d.ts +14 -6
  104. package/lib/engine-components/codegen/components.js +14 -6
  105. package/lib/engine-components/codegen/components.js.map +1 -1
  106. package/lib/engine-components/js-extensions/Object3D.js +4 -1
  107. package/lib/engine-components/js-extensions/Object3D.js.map +1 -1
  108. package/lib/engine-components/postprocessing/Effects/Antialiasing.d.ts +13 -0
  109. package/lib/engine-components/postprocessing/Effects/Antialiasing.js +46 -0
  110. package/lib/engine-components/postprocessing/Effects/Antialiasing.js.map +1 -0
  111. package/lib/engine-components/postprocessing/Effects/Bloom.d.ts +12 -0
  112. package/lib/engine-components/postprocessing/Effects/Bloom.js +76 -0
  113. package/lib/engine-components/postprocessing/Effects/Bloom.js.map +1 -0
  114. package/lib/engine-components/postprocessing/Effects/ChromaticAberration.d.ts +8 -0
  115. package/lib/engine-components/postprocessing/Effects/ChromaticAberration.js +39 -0
  116. package/lib/engine-components/postprocessing/Effects/ChromaticAberration.js.map +1 -0
  117. package/lib/engine-components/postprocessing/Effects/ColorAdjustments.d.ts +12 -0
  118. package/lib/engine-components/postprocessing/Effects/ColorAdjustments.js +96 -0
  119. package/lib/engine-components/postprocessing/Effects/ColorAdjustments.js.map +1 -0
  120. package/lib/engine-components/postprocessing/Effects/DepthOfField.d.ts +21 -0
  121. package/lib/engine-components/postprocessing/Effects/DepthOfField.js +87 -0
  122. package/lib/engine-components/postprocessing/Effects/DepthOfField.js.map +1 -0
  123. package/lib/engine-components/postprocessing/Effects/Pixelation.d.ts +7 -0
  124. package/lib/engine-components/postprocessing/Effects/Pixelation.js +30 -0
  125. package/lib/engine-components/postprocessing/Effects/Pixelation.js.map +1 -0
  126. package/lib/engine-components/postprocessing/Effects/ScreenspaceAmbientOcclusion.d.ts +11 -0
  127. package/lib/engine-components/postprocessing/Effects/ScreenspaceAmbientOcclusion.js +70 -0
  128. package/lib/engine-components/postprocessing/Effects/ScreenspaceAmbientOcclusion.js.map +1 -0
  129. package/lib/engine-components/postprocessing/Effects/Tonemapping.d.ts +16 -0
  130. package/lib/engine-components/postprocessing/Effects/Tonemapping.js +52 -0
  131. package/lib/engine-components/postprocessing/Effects/Tonemapping.js.map +1 -0
  132. package/lib/engine-components/postprocessing/Effects/Vignette.d.ts +11 -0
  133. package/lib/engine-components/postprocessing/Effects/Vignette.js +57 -0
  134. package/lib/engine-components/postprocessing/Effects/Vignette.js.map +1 -0
  135. package/lib/engine-components/postprocessing/PostProcessingEffect.d.ts +29 -0
  136. package/lib/engine-components/postprocessing/PostProcessingEffect.js +89 -0
  137. package/lib/engine-components/postprocessing/PostProcessingEffect.js.map +1 -0
  138. package/lib/engine-components/postprocessing/PostProcessingHandler.d.ts +13 -0
  139. package/lib/engine-components/postprocessing/PostProcessingHandler.js +119 -0
  140. package/lib/engine-components/postprocessing/PostProcessingHandler.js.map +1 -0
  141. package/lib/engine-components/postprocessing/Volume.d.ts +23 -0
  142. package/lib/engine-components/postprocessing/Volume.js +176 -0
  143. package/lib/engine-components/postprocessing/Volume.js.map +1 -0
  144. package/lib/engine-components/postprocessing/VolumeParameter.d.ts +21 -0
  145. package/lib/engine-components/postprocessing/VolumeParameter.js +75 -0
  146. package/lib/engine-components/postprocessing/VolumeParameter.js.map +1 -0
  147. package/lib/engine-components/postprocessing/VolumeProfile.d.ts +7 -0
  148. package/lib/engine-components/postprocessing/VolumeProfile.js +42 -0
  149. package/lib/engine-components/postprocessing/VolumeProfile.js.map +1 -0
  150. package/lib/engine-components/timeline/TimelineTracks.js +14 -15
  151. package/lib/engine-components/timeline/TimelineTracks.js.map +1 -1
  152. package/lib/engine-components/ui/Text.js +28 -170
  153. package/lib/engine-components/ui/Text.js.map +1 -1
  154. package/lib/engine-components-experimental/networking/PlayerSync.d.ts +18 -0
  155. package/lib/engine-components-experimental/networking/PlayerSync.js +61 -7
  156. package/lib/engine-components-experimental/networking/PlayerSync.js.map +1 -1
  157. package/lib/include/three/ARButton.d.ts +1 -1
  158. package/lib/include/three/ARButton.js +11 -19
  159. package/lib/include/three/ARButton.js.map +1 -1
  160. package/lib/include/three/VRButton.js +1 -4
  161. package/lib/include/three/VRButton.js.map +1 -1
  162. package/package.json +3 -2
  163. package/plugins/vite/drop-client.js +77 -0
  164. package/plugins/vite/drop.js +81 -0
  165. package/plugins/vite/editor-connection.js +121 -0
  166. package/plugins/vite/index.js +9 -4
  167. package/src/engine/api.ts +30 -1
  168. package/src/engine/codegen/register_types.js +25 -9
  169. package/src/engine/debug/debug_overlay.ts +7 -1
  170. package/src/engine/engine_addressables.ts +2 -2
  171. package/src/engine/engine_assetdatabase.ts +291 -184
  172. package/src/engine/engine_components.ts +20 -1
  173. package/src/engine/engine_components_internal.ts +30 -0
  174. package/src/engine/engine_constants.ts +4 -1
  175. package/src/engine/engine_context_registry.ts +7 -0
  176. package/src/engine/engine_editor-sync.ts +21 -0
  177. package/src/engine/engine_element_loading.ts +1 -1
  178. package/src/engine/engine_gameobject.ts +16 -21
  179. package/src/engine/engine_gltf_builtin_components.ts +30 -15
  180. package/src/engine/engine_networking_auto.ts +48 -11
  181. package/src/engine/engine_patcher.ts +113 -0
  182. package/src/engine/engine_physics.ts +15 -2
  183. package/src/engine/engine_scenetools.ts +0 -1
  184. package/src/engine/engine_serialization_core.ts +6 -0
  185. package/src/engine/engine_setup.ts +11 -5
  186. package/src/engine/engine_texture.ts +54 -5
  187. package/src/engine/engine_types.ts +6 -1
  188. package/src/engine/engine_utils.ts +6 -5
  189. package/src/engine/extensions/NEEDLE_progressive.ts +32 -32
  190. package/src/engine/extensions/extensions.ts +22 -1
  191. package/src/engine/extensions/usage_tracker.ts +91 -0
  192. package/src/engine-components/AnimatorController.ts +2 -0
  193. package/src/engine-components/AudioSource.ts +1 -1
  194. package/src/engine-components/Camera.ts +77 -37
  195. package/src/engine-components/Component.ts +74 -30
  196. package/src/engine-components/Networking.ts +9 -1
  197. package/src/engine-components/OrbitControls.ts +11 -2
  198. package/src/engine-components/ParticleSystem.ts +9 -1
  199. package/src/engine-components/ReflectionProbe.ts +17 -7
  200. package/src/engine-components/Renderer.ts +22 -5
  201. package/src/engine-components/Skybox.ts +2 -0
  202. package/src/engine-components/SmoothFollow.ts +4 -4
  203. package/src/engine-components/WebARCameraBackground.ts +215 -0
  204. package/src/engine-components/WebXR.ts +12 -8
  205. package/src/engine-components/WebXRAvatar.ts +1 -0
  206. package/src/engine-components/codegen/components.ts +14 -6
  207. package/src/engine-components/js-extensions/Object3D.ts +6 -1
  208. package/src/engine-components/postprocessing/Effects/Antialiasing.ts +52 -0
  209. package/src/engine-components/postprocessing/Effects/Bloom.ts +75 -0
  210. package/src/engine-components/postprocessing/Effects/ChromaticAberration.ts +36 -0
  211. package/src/engine-components/postprocessing/Effects/ColorAdjustments.ts +114 -0
  212. package/src/engine-components/postprocessing/Effects/DepthOfField.ts +90 -0
  213. package/src/engine-components/postprocessing/Effects/Pixelation.ts +28 -0
  214. package/src/engine-components/postprocessing/Effects/ScreenspaceAmbientOcclusion.ts +71 -0
  215. package/src/engine-components/postprocessing/Effects/Tonemapping.ts +55 -0
  216. package/src/engine-components/postprocessing/Effects/Vignette.ts +55 -0
  217. package/src/engine-components/postprocessing/PostProcessingEffect.ts +112 -0
  218. package/src/engine-components/postprocessing/PostProcessingHandler.ts +148 -0
  219. package/src/engine-components/postprocessing/Volume.ts +194 -0
  220. package/src/engine-components/postprocessing/VolumeParameter.ts +85 -0
  221. package/src/engine-components/postprocessing/VolumeProfile.ts +40 -0
  222. package/src/engine-components/timeline/TimelineTracks.ts +16 -17
  223. package/src/engine-components/ui/Text.ts +37 -174
  224. package/src/engine-components-experimental/networking/PlayerSync.ts +68 -7
  225. package/src/include/three/ARButton.js +13 -24
  226. package/src/include/three/VRButton.js +1 -7
  227. package/lib/engine-components/Volume.d.ts +0 -34
  228. package/lib/engine-components/Volume.js +0 -140
  229. package/lib/engine-components/Volume.js.map +0 -1
  230. 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
+ }