angular-three-postprocessing 1.6.0 → 2.0.0-beta.3

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 (87) hide show
  1. package/README.md +4 -12
  2. package/effect-composer.d.ts +53 -0
  3. package/effect.d.ts +24 -0
  4. package/effects/bloom/bloom.d.ts +8 -0
  5. package/effects/{lib/brightness-contrast → brightness-contrast}/brightness-contrast.d.ts +1 -2
  6. package/effects/{lib/color-depth → color-depth}/color-depth.d.ts +1 -2
  7. package/effects/{lib/depth → depth}/depth.d.ts +1 -2
  8. package/effects/{lib/dot-screen → dot-screen}/dot-screen.d.ts +1 -2
  9. package/effects/{lib/hue-saturation → hue-saturation}/hue-saturation.d.ts +1 -2
  10. package/effects/index.d.ts +16 -14
  11. package/effects/lut/lut.d.ts +19 -0
  12. package/effects/{lib/noise → noise}/noise.d.ts +2 -3
  13. package/effects/{lib/scanline → scanline}/scanline.d.ts +2 -3
  14. package/effects/{lib/sepia → sepia}/sepia.d.ts +1 -2
  15. package/effects/shock-wave/shock-wave.d.ts +7 -0
  16. package/effects/smaa/smaa.d.ts +7 -0
  17. package/effects/ssao/ssao.d.ts +38 -0
  18. package/effects/tilt-shift/tilt-shift.d.ts +8 -0
  19. package/effects/tone-mapping/tone-mapping.d.ts +7 -0
  20. package/effects/{lib/vignette → vignette}/vignette.d.ts +1 -2
  21. package/esm2022/angular-three-postprocessing.mjs +1 -1
  22. package/esm2022/effect-composer.mjs +242 -0
  23. package/esm2022/effect.mjs +79 -0
  24. package/esm2022/effects/angular-three-postprocessing-effects.mjs +1 -1
  25. package/esm2022/effects/bloom/bloom.mjs +34 -0
  26. package/esm2022/effects/brightness-contrast/brightness-contrast.mjs +30 -0
  27. package/esm2022/effects/color-depth/color-depth.mjs +30 -0
  28. package/esm2022/effects/depth/depth.mjs +30 -0
  29. package/esm2022/effects/dot-screen/dot-screen.mjs +30 -0
  30. package/esm2022/effects/hue-saturation/hue-saturation.mjs +30 -0
  31. package/esm2022/effects/index.mjs +17 -15
  32. package/esm2022/effects/lut/lut.mjs +77 -0
  33. package/esm2022/effects/noise/noise.mjs +34 -0
  34. package/esm2022/effects/scanline/scanline.mjs +34 -0
  35. package/esm2022/effects/sepia/sepia.mjs +30 -0
  36. package/esm2022/effects/shock-wave/shock-wave.mjs +30 -0
  37. package/esm2022/effects/smaa/smaa.mjs +30 -0
  38. package/esm2022/effects/ssao/ssao.mjs +189 -0
  39. package/esm2022/effects/tilt-shift/tilt-shift.mjs +34 -0
  40. package/esm2022/effects/tone-mapping/tone-mapping.mjs +30 -0
  41. package/esm2022/effects/vignette/vignette.mjs +30 -0
  42. package/esm2022/index.mjs +3 -3
  43. package/fesm2022/angular-three-postprocessing-effects.mjs +359 -224
  44. package/fesm2022/angular-three-postprocessing-effects.mjs.map +1 -1
  45. package/fesm2022/angular-three-postprocessing.mjs +163 -162
  46. package/fesm2022/angular-three-postprocessing.mjs.map +1 -1
  47. package/index.d.ts +2 -2
  48. package/package.json +6 -14
  49. package/plugin/package.json +1 -1
  50. package/plugin/src/generators/init/compat.js.map +1 -1
  51. package/plugin/src/generators/init/init.d.ts +1 -1
  52. package/plugin/src/generators/init/init.js +14 -18
  53. package/plugin/src/generators/init/init.js.map +1 -1
  54. package/plugin/src/index.js.map +1 -1
  55. package/effects/lib/bloom/bloom.d.ts +0 -9
  56. package/effects/lib/lut/lut.d.ts +0 -13
  57. package/effects/lib/ssao/ssao.d.ts +0 -13
  58. package/effects/lib/tilt-shift/tilt-shift.d.ts +0 -9
  59. package/effects/lib/tone-mapping/tone-mapping.d.ts +0 -8
  60. package/esm2022/effects/lib/bloom/bloom.mjs +0 -44
  61. package/esm2022/effects/lib/brightness-contrast/brightness-contrast.mjs +0 -29
  62. package/esm2022/effects/lib/color-depth/color-depth.mjs +0 -29
  63. package/esm2022/effects/lib/depth/depth.mjs +0 -29
  64. package/esm2022/effects/lib/dot-screen/dot-screen.mjs +0 -29
  65. package/esm2022/effects/lib/hue-saturation/hue-saturation.mjs +0 -29
  66. package/esm2022/effects/lib/lut/lut.mjs +0 -60
  67. package/esm2022/effects/lib/noise/noise.mjs +0 -33
  68. package/esm2022/effects/lib/scanline/scanline.mjs +0 -33
  69. package/esm2022/effects/lib/sepia/sepia.mjs +0 -29
  70. package/esm2022/effects/lib/ssao/ssao.mjs +0 -102
  71. package/esm2022/effects/lib/tilt-shift/tilt-shift.mjs +0 -43
  72. package/esm2022/effects/lib/tone-mapping/tone-mapping.mjs +0 -39
  73. package/esm2022/effects/lib/vignette/vignette.mjs +0 -29
  74. package/esm2022/lib/effect-composer.mjs +0 -241
  75. package/esm2022/lib/effect.mjs +0 -80
  76. package/esm2022/selection/angular-three-postprocessing-selection.mjs +0 -5
  77. package/esm2022/selection/index.mjs +0 -3
  78. package/esm2022/selection/lib/select.mjs +0 -69
  79. package/esm2022/selection/lib/selection.mjs +0 -44
  80. package/fesm2022/angular-three-postprocessing-selection.mjs +0 -114
  81. package/fesm2022/angular-three-postprocessing-selection.mjs.map +0 -1
  82. package/lib/effect-composer.d.ts +0 -39
  83. package/lib/effect.d.ts +0 -22
  84. package/selection/README.md +0 -3
  85. package/selection/index.d.ts +0 -2
  86. package/selection/lib/select.d.ts +0 -14
  87. package/selection/lib/selection.d.ts +0 -18
package/README.md CHANGED
@@ -1,15 +1,7 @@
1
- # Postprocessing for Angular Three using postprocessing
1
+ # postprocessing
2
2
 
3
- ## Installation
3
+ This library was generated with [Nx](https://nx.dev).
4
4
 
5
- ```shell
6
- ng add angular-three-postprocessing
7
- ```
5
+ ## Running unit tests
8
6
 
9
- ## Documentations
10
-
11
- Read more about Angular Three Postprocessing usages in [TBD: Documentations](#)
12
-
13
- ## Contributions
14
-
15
- Contributions are welcomed
7
+ Run `nx test postprocessing` to execute the unit tests.
@@ -0,0 +1,53 @@
1
+ import { InjectionToken, Signal } from '@angular/core';
2
+ import { NgtSignalStore } from 'angular-three';
3
+ import { DepthDownsamplingPass, EffectComposer, NormalPass } from 'postprocessing';
4
+ import * as THREE from 'three';
5
+ import * as i0 from "@angular/core";
6
+ export interface NgtpEffectComposerState {
7
+ enabled: boolean;
8
+ depthBuffer?: boolean;
9
+ disableNormalPass?: boolean;
10
+ stencilBuffer?: boolean;
11
+ autoClear: boolean;
12
+ resolutionScale?: number;
13
+ multisampling: number;
14
+ frameBufferType: THREE.TextureDataType;
15
+ renderPriority: number;
16
+ camera?: THREE.Camera;
17
+ scene?: THREE.Scene;
18
+ }
19
+ export interface NgtpEffectComposerApi {
20
+ composer: EffectComposer;
21
+ normalPass: NormalPass | null;
22
+ downSamplingPass: DepthDownsamplingPass | null;
23
+ camera: THREE.Camera;
24
+ scene: THREE.Scene;
25
+ resolutionScale?: number;
26
+ }
27
+ export declare const NGTP_EFFECT_COMPOSER_API: InjectionToken<Signal<NgtpEffectComposerApi>>;
28
+ export declare class NgtpEffectComposer extends NgtSignalStore<NgtpEffectComposerState> {
29
+ #private;
30
+ readonly composerRef: import("angular-three").NgtInjectedRef<THREE.Group>;
31
+ set enabled(enabled: boolean);
32
+ set depthBuffer(depthBuffer: boolean);
33
+ set disableNormalPass(disableNormalPass: boolean);
34
+ set stencilBuffer(stencilBuffer: boolean);
35
+ set autoClear(autoClear: boolean);
36
+ set resolutionScale(resolutionScale: number);
37
+ set multisampling(multisampling: number);
38
+ set frameBufferType(frameBufferType: THREE.TextureDataType);
39
+ set renderPriority(renderPriority: number);
40
+ set camera(camera: THREE.Camera);
41
+ set scene(scene: THREE.Scene);
42
+ readonly api: Signal<{
43
+ composer: EffectComposer;
44
+ normalPass: NormalPass | null;
45
+ downSamplingPass: DepthDownsamplingPass | null;
46
+ resolutionScale: number | undefined;
47
+ camera: THREE.Camera;
48
+ scene: THREE.Scene;
49
+ }>;
50
+ constructor();
51
+ static ɵfac: i0.ɵɵFactoryDeclaration<NgtpEffectComposer, never>;
52
+ static ɵcmp: i0.ɵɵComponentDeclaration<NgtpEffectComposer, "ngtp-effect-composer", never, { "enabled": { "alias": "enabled"; "required": false; }; "depthBuffer": { "alias": "depthBuffer"; "required": false; }; "disableNormalPass": { "alias": "disableNormalPass"; "required": false; }; "stencilBuffer": { "alias": "stencilBuffer"; "required": false; }; "autoClear": { "alias": "autoClear"; "required": false; }; "resolutionScale": { "alias": "resolutionScale"; "required": false; }; "multisampling": { "alias": "multisampling"; "required": false; }; "frameBufferType": { "alias": "frameBufferType"; "required": false; }; "renderPriority": { "alias": "renderPriority"; "required": false; }; "camera": { "alias": "camera"; "required": false; }; "scene": { "alias": "scene"; "required": false; }; }, {}, never, ["*"], true, never>;
53
+ }
package/effect.d.ts ADDED
@@ -0,0 +1,24 @@
1
+ import { NgtSignalStore, NgtStore } from 'angular-three';
2
+ import { BlendFunction, Effect } from 'postprocessing';
3
+ import * as i0 from "@angular/core";
4
+ export declare abstract class NgtpEffect<T extends Effect> extends NgtSignalStore<{
5
+ blendFunction?: BlendFunction;
6
+ opacity?: number;
7
+ }> {
8
+ #private;
9
+ effectRef: import("angular-three").NgtInjectedRef<T>;
10
+ set blendFunction(blendFunction: BlendFunction);
11
+ set opacity(opacity: number);
12
+ protected defaultBlendFunction: BlendFunction;
13
+ protected nativeArgs: () => never[];
14
+ readonly effectBlendFunction: import("@angular/core").Signal<BlendFunction | undefined>;
15
+ readonly effectOpacity: import("@angular/core").Signal<number | undefined>;
16
+ protected readonly store: NgtStore;
17
+ protected readonly camera: import("@angular/core").Signal<import("angular-three").NgtCameraManual>;
18
+ protected readonly args: import("@angular/core").Signal<{
19
+ [x: string]: any;
20
+ }[]>;
21
+ constructor();
22
+ static ɵfac: i0.ɵɵFactoryDeclaration<NgtpEffect<any>, never>;
23
+ static ɵdir: i0.ɵɵDirectiveDeclaration<NgtpEffect<any>, never, never, { "effectRef": { "alias": "effectRef"; "required": false; }; "blendFunction": { "alias": "blendFunction"; "required": false; }; "opacity": { "alias": "opacity"; "required": false; }; }, {}, never, never, false, never>;
24
+ }
@@ -0,0 +1,8 @@
1
+ import { NgtpEffect } from 'angular-three-postprocessing';
2
+ import { BlendFunction, BloomEffect } from 'postprocessing';
3
+ import * as i0 from "@angular/core";
4
+ export declare class NgtpBloom extends NgtpEffect<BloomEffect> {
5
+ defaultBlendFunction: BlendFunction;
6
+ static ɵfac: i0.ɵɵFactoryDeclaration<NgtpBloom, never>;
7
+ static ɵcmp: i0.ɵɵComponentDeclaration<NgtpBloom, "ngtp-bloom", never, {}, {}, never, ["*"], true, never>;
8
+ }
@@ -2,7 +2,6 @@ import { NgtpEffect } from 'angular-three-postprocessing';
2
2
  import { BrightnessContrastEffect } from 'postprocessing';
3
3
  import * as i0 from "@angular/core";
4
4
  export declare class NgtpBrightnessContrast extends NgtpEffect<BrightnessContrastEffect> {
5
- get effectConstructor(): typeof BrightnessContrastEffect;
6
5
  static ɵfac: i0.ɵɵFactoryDeclaration<NgtpBrightnessContrast, never>;
7
- static ɵcmp: i0.ɵɵComponentDeclaration<NgtpBrightnessContrast, "ngtp-brightness-contrast", never, { "brightness": { "alias": "brightness"; "required": false; }; "contrast": { "alias": "contrast"; "required": false; }; }, {}, never, never, true, never>;
6
+ static ɵcmp: i0.ɵɵComponentDeclaration<NgtpBrightnessContrast, "ngtp-brightness-contrast", never, {}, {}, never, ["*"], true, never>;
8
7
  }
@@ -2,7 +2,6 @@ import { NgtpEffect } from 'angular-three-postprocessing';
2
2
  import { ColorDepthEffect } from 'postprocessing';
3
3
  import * as i0 from "@angular/core";
4
4
  export declare class NgtpColorDepth extends NgtpEffect<ColorDepthEffect> {
5
- get effectConstructor(): typeof ColorDepthEffect;
6
5
  static ɵfac: i0.ɵɵFactoryDeclaration<NgtpColorDepth, never>;
7
- static ɵcmp: i0.ɵɵComponentDeclaration<NgtpColorDepth, "ngtp-color-depth", never, { "bits": { "alias": "bits"; "required": false; }; }, {}, never, never, true, never>;
6
+ static ɵcmp: i0.ɵɵComponentDeclaration<NgtpColorDepth, "ngtp-color-depth", never, {}, {}, never, ["*"], true, never>;
8
7
  }
@@ -2,7 +2,6 @@ import { NgtpEffect } from 'angular-three-postprocessing';
2
2
  import { DepthEffect } from 'postprocessing';
3
3
  import * as i0 from "@angular/core";
4
4
  export declare class NgtpDepth extends NgtpEffect<DepthEffect> {
5
- get effectConstructor(): typeof DepthEffect;
6
5
  static ɵfac: i0.ɵɵFactoryDeclaration<NgtpDepth, never>;
7
- static ɵcmp: i0.ɵɵComponentDeclaration<NgtpDepth, "ngtp-depth", never, { "inverted": { "alias": "inverted"; "required": false; }; }, {}, never, never, true, never>;
6
+ static ɵcmp: i0.ɵɵComponentDeclaration<NgtpDepth, "ngtp-depth", never, {}, {}, never, ["*"], true, never>;
8
7
  }
@@ -2,7 +2,6 @@ import { NgtpEffect } from 'angular-three-postprocessing';
2
2
  import { DotScreenEffect } from 'postprocessing';
3
3
  import * as i0 from "@angular/core";
4
4
  export declare class NgtpDotScreen extends NgtpEffect<DotScreenEffect> {
5
- get effectConstructor(): typeof DotScreenEffect;
6
5
  static ɵfac: i0.ɵɵFactoryDeclaration<NgtpDotScreen, never>;
7
- static ɵcmp: i0.ɵɵComponentDeclaration<NgtpDotScreen, "ngtp-dot-screen", never, { "angle": { "alias": "angle"; "required": false; }; "scale": { "alias": "scale"; "required": false; }; }, {}, never, never, true, never>;
6
+ static ɵcmp: i0.ɵɵComponentDeclaration<NgtpDotScreen, "ngtp-dot-screen", never, {}, {}, never, ["*"], true, never>;
8
7
  }
@@ -2,7 +2,6 @@ import { NgtpEffect } from 'angular-three-postprocessing';
2
2
  import { HueSaturationEffect } from 'postprocessing';
3
3
  import * as i0 from "@angular/core";
4
4
  export declare class NgtpHueSaturation extends NgtpEffect<HueSaturationEffect> {
5
- get effectConstructor(): typeof HueSaturationEffect;
6
5
  static ɵfac: i0.ɵɵFactoryDeclaration<NgtpHueSaturation, never>;
7
- static ɵcmp: i0.ɵɵComponentDeclaration<NgtpHueSaturation, "ngtp-hue-saturation", never, { "hue": { "alias": "hue"; "required": false; }; "saturation": { "alias": "saturation"; "required": false; }; }, {}, never, never, true, never>;
6
+ static ɵcmp: i0.ɵɵComponentDeclaration<NgtpHueSaturation, "ngtp-hue-saturation", never, {}, {}, never, ["*"], true, never>;
8
7
  }
@@ -1,14 +1,16 @@
1
- export * from './lib/bloom/bloom';
2
- export * from './lib/brightness-contrast/brightness-contrast';
3
- export * from './lib/color-depth/color-depth';
4
- export * from './lib/depth/depth';
5
- export * from './lib/dot-screen/dot-screen';
6
- export * from './lib/hue-saturation/hue-saturation';
7
- export * from './lib/lut/lut';
8
- export * from './lib/noise/noise';
9
- export * from './lib/scanline/scanline';
10
- export * from './lib/sepia/sepia';
11
- export * from './lib/ssao/ssao';
12
- export * from './lib/tilt-shift/tilt-shift';
13
- export * from './lib/tone-mapping/tone-mapping';
14
- export * from './lib/vignette/vignette';
1
+ export * from './bloom/bloom';
2
+ export * from './brightness-contrast/brightness-contrast';
3
+ export * from './color-depth/color-depth';
4
+ export * from './depth/depth';
5
+ export * from './dot-screen/dot-screen';
6
+ export * from './hue-saturation/hue-saturation';
7
+ export * from './lut/lut';
8
+ export * from './noise/noise';
9
+ export * from './scanline/scanline';
10
+ export * from './sepia/sepia';
11
+ export * from './shock-wave/shock-wave';
12
+ export * from './smaa/smaa';
13
+ export * from './ssao/ssao';
14
+ export * from './tilt-shift/tilt-shift';
15
+ export * from './tone-mapping/tone-mapping';
16
+ export * from './vignette/vignette';
@@ -0,0 +1,19 @@
1
+ import { NgtSignalStore } from 'angular-three';
2
+ import { BlendFunction, LUT3DEffect } from 'postprocessing';
3
+ import * as i0 from "@angular/core";
4
+ export interface NgtpLUTState {
5
+ lut: THREE.Texture;
6
+ blendFunction?: BlendFunction;
7
+ tetrahedralInterpolation?: boolean;
8
+ }
9
+ export declare class NgtpLUT extends NgtSignalStore<NgtpLUTState> {
10
+ #private;
11
+ effectRef: import("angular-three").NgtInjectedRef<LUT3DEffect>;
12
+ set lut(lut: THREE.Texture);
13
+ set blendFunction(blendFunction: BlendFunction);
14
+ set tetrahedralInterpolation(tetrahedralInterpolation: boolean);
15
+ readonly effect: import("@angular/core").Signal<LUT3DEffect>;
16
+ constructor();
17
+ static ɵfac: i0.ɵɵFactoryDeclaration<NgtpLUT, never>;
18
+ static ɵcmp: i0.ɵɵComponentDeclaration<NgtpLUT, "ngtp-lut", never, { "effectRef": { "alias": "effectRef"; "required": false; }; "lut": { "alias": "lut"; "required": true; }; "blendFunction": { "alias": "blendFunction"; "required": false; }; "tetrahedralInterpolation": { "alias": "tetrahedralInterpolation"; "required": false; }; }, {}, never, never, true, never>;
19
+ }
@@ -2,8 +2,7 @@ import { NgtpEffect } from 'angular-three-postprocessing';
2
2
  import { BlendFunction, NoiseEffect } from 'postprocessing';
3
3
  import * as i0 from "@angular/core";
4
4
  export declare class NgtpNoise extends NgtpEffect<NoiseEffect> {
5
- get effectConstructor(): typeof NoiseEffect;
6
- defaultBlendMode: BlendFunction;
5
+ defaultBlendFunction: BlendFunction;
7
6
  static ɵfac: i0.ɵɵFactoryDeclaration<NgtpNoise, never>;
8
- static ɵcmp: i0.ɵɵComponentDeclaration<NgtpNoise, "ngtp-noise", never, { "premultiply": { "alias": "premultiply"; "required": false; }; }, {}, never, never, true, never>;
7
+ static ɵcmp: i0.ɵɵComponentDeclaration<NgtpNoise, "ngtp-noise", never, {}, {}, never, ["*"], true, never>;
9
8
  }
@@ -2,8 +2,7 @@ import { NgtpEffect } from 'angular-three-postprocessing';
2
2
  import { BlendFunction, ScanlineEffect } from 'postprocessing';
3
3
  import * as i0 from "@angular/core";
4
4
  export declare class NgtpScanline extends NgtpEffect<ScanlineEffect> {
5
- get effectConstructor(): typeof ScanlineEffect;
6
- defaultBlendMode: BlendFunction;
5
+ defaultBlendFunction: BlendFunction;
7
6
  static ɵfac: i0.ɵɵFactoryDeclaration<NgtpScanline, never>;
8
- static ɵcmp: i0.ɵɵComponentDeclaration<NgtpScanline, "ngtp-scanline", never, { "density": { "alias": "density"; "required": false; }; }, {}, never, never, true, never>;
7
+ static ɵcmp: i0.ɵɵComponentDeclaration<NgtpScanline, "ngtp-scanline", never, {}, {}, never, ["*"], true, never>;
9
8
  }
@@ -2,7 +2,6 @@ import { NgtpEffect } from 'angular-three-postprocessing';
2
2
  import { SepiaEffect } from 'postprocessing';
3
3
  import * as i0 from "@angular/core";
4
4
  export declare class NgtpSepia extends NgtpEffect<SepiaEffect> {
5
- get effectConstructor(): typeof SepiaEffect;
6
5
  static ɵfac: i0.ɵɵFactoryDeclaration<NgtpSepia, never>;
7
- static ɵcmp: i0.ɵɵComponentDeclaration<NgtpSepia, "ngtp-sepia", never, { "intensity": { "alias": "intensity"; "required": false; }; }, {}, never, never, true, never>;
6
+ static ɵcmp: i0.ɵɵComponentDeclaration<NgtpSepia, "ngtp-sepia", never, {}, {}, never, ["*"], true, never>;
8
7
  }
@@ -0,0 +1,7 @@
1
+ import { NgtpEffect } from 'angular-three-postprocessing';
2
+ import { ShockWaveEffect } from 'postprocessing';
3
+ import * as i0 from "@angular/core";
4
+ export declare class NgtpShockWave extends NgtpEffect<ShockWaveEffect> {
5
+ static ɵfac: i0.ɵɵFactoryDeclaration<NgtpShockWave, never>;
6
+ static ɵcmp: i0.ɵɵComponentDeclaration<NgtpShockWave, "ngtp-noise", never, {}, {}, never, ["*"], true, never>;
7
+ }
@@ -0,0 +1,7 @@
1
+ import { NgtpEffect } from 'angular-three-postprocessing';
2
+ import { SMAAEffect } from 'postprocessing';
3
+ import * as i0 from "@angular/core";
4
+ export declare class NgtpSMAA extends NgtpEffect<SMAAEffect> {
5
+ static ɵfac: i0.ɵɵFactoryDeclaration<NgtpSMAA, never>;
6
+ static ɵcmp: i0.ɵɵComponentDeclaration<NgtpSMAA, "ngtp-SMAA", never, {}, {}, never, ["*"], true, never>;
7
+ }
@@ -0,0 +1,38 @@
1
+ import { NgtSignalStore } from 'angular-three';
2
+ import { BlendFunction, SSAOEffect } from 'postprocessing';
3
+ import * as i0 from "@angular/core";
4
+ export type NgtpSSAOState = NonNullable<ConstructorParameters<typeof SSAOEffect>[2]>;
5
+ export declare class NgtpSSAO extends NgtSignalStore<NgtpSSAOState> {
6
+ #private;
7
+ effectRef: import("angular-three").NgtInjectedRef<SSAOEffect>;
8
+ set blendFunction(blendFunction: BlendFunction);
9
+ set distanceScaling(distanceScaling: boolean);
10
+ set depthAwareUpsampling(depthAwareUpsampling: boolean);
11
+ set normalDepthBuffer(normalDepthBuffer: THREE.Texture);
12
+ set samples(samples: number);
13
+ set rings(rings: number);
14
+ set worldDistanceThreshold(worldDistanceThreshold: number);
15
+ set worldDistanceFalloff(worldDistanceFalloff: number);
16
+ set worldProximityThreshold(worldProximityThreshold: number);
17
+ set worldProximityFalloff(worldProximityFalloff: number);
18
+ set distanceThreshold(distanceThreshold: number);
19
+ set distanceFalloff(distanceFalloff: number);
20
+ set rangeThreshold(rangeThreshold: number);
21
+ set rangeFalloff(rangeFalloff: number);
22
+ set minRadiusScale(minRadiusScale: number);
23
+ set luminanceInfluence(luminanceInfluence: number);
24
+ set radius(radius: number);
25
+ set intensity(intensity: number);
26
+ set bias(bias: number);
27
+ set fade(fade: number);
28
+ set color(color: THREE.Color);
29
+ set resolutionScale(resolutionScale: number);
30
+ set resolutionX(resolutionX: number);
31
+ set resolutionY(resolutionY: number);
32
+ set width(width: number);
33
+ set height(height: number);
34
+ readonly effect: import("@angular/core").Signal<{}>;
35
+ constructor();
36
+ static ɵfac: i0.ɵɵFactoryDeclaration<NgtpSSAO, never>;
37
+ static ɵcmp: i0.ɵɵComponentDeclaration<NgtpSSAO, "ngtp-SSAO", never, { "effectRef": { "alias": "effectRef"; "required": false; }; "blendFunction": { "alias": "blendFunction"; "required": false; }; "distanceScaling": { "alias": "distanceScaling"; "required": false; }; "depthAwareUpsampling": { "alias": "depthAwareUpsampling"; "required": false; }; "normalDepthBuffer": { "alias": "normalDepthBuffer"; "required": false; }; "samples": { "alias": "samples"; "required": false; }; "rings": { "alias": "rings"; "required": false; }; "worldDistanceThreshold": { "alias": "worldDistanceThreshold"; "required": false; }; "worldDistanceFalloff": { "alias": "worldDistanceFalloff"; "required": false; }; "worldProximityThreshold": { "alias": "worldProximityThreshold"; "required": false; }; "worldProximityFalloff": { "alias": "worldProximityFalloff"; "required": false; }; "distanceThreshold": { "alias": "distanceThreshold"; "required": false; }; "distanceFalloff": { "alias": "distanceFalloff"; "required": false; }; "rangeThreshold": { "alias": "rangeThreshold"; "required": false; }; "rangeFalloff": { "alias": "rangeFalloff"; "required": false; }; "minRadiusScale": { "alias": "minRadiusScale"; "required": false; }; "luminanceInfluence": { "alias": "luminanceInfluence"; "required": false; }; "radius": { "alias": "radius"; "required": false; }; "intensity": { "alias": "intensity"; "required": false; }; "bias": { "alias": "bias"; "required": false; }; "fade": { "alias": "fade"; "required": false; }; "color": { "alias": "color"; "required": false; }; "resolutionScale": { "alias": "resolutionScale"; "required": false; }; "resolutionX": { "alias": "resolutionX"; "required": false; }; "resolutionY": { "alias": "resolutionY"; "required": false; }; "width": { "alias": "width"; "required": false; }; "height": { "alias": "height"; "required": false; }; }, {}, never, never, true, never>;
38
+ }
@@ -0,0 +1,8 @@
1
+ import { NgtpEffect } from 'angular-three-postprocessing';
2
+ import { BlendFunction, TiltShiftEffect } from 'postprocessing';
3
+ import * as i0 from "@angular/core";
4
+ export declare class NgtpTiltShift extends NgtpEffect<TiltShiftEffect> {
5
+ defaultBlendFunction: BlendFunction;
6
+ static ɵfac: i0.ɵɵFactoryDeclaration<NgtpTiltShift, never>;
7
+ static ɵcmp: i0.ɵɵComponentDeclaration<NgtpTiltShift, "ngtp-tilt-shift", never, {}, {}, never, ["*"], true, never>;
8
+ }
@@ -0,0 +1,7 @@
1
+ import { NgtpEffect } from 'angular-three-postprocessing';
2
+ import { ToneMappingEffect } from 'postprocessing';
3
+ import * as i0 from "@angular/core";
4
+ export declare class NgtpToneMapping extends NgtpEffect<ToneMappingEffect> {
5
+ static ɵfac: i0.ɵɵFactoryDeclaration<NgtpToneMapping, never>;
6
+ static ɵcmp: i0.ɵɵComponentDeclaration<NgtpToneMapping, "ngtp-tone-mapping", never, {}, {}, never, ["*"], true, never>;
7
+ }
@@ -2,7 +2,6 @@ import { NgtpEffect } from 'angular-three-postprocessing';
2
2
  import { VignetteEffect } from 'postprocessing';
3
3
  import * as i0 from "@angular/core";
4
4
  export declare class NgtpVignette extends NgtpEffect<VignetteEffect> {
5
- get effectConstructor(): typeof VignetteEffect;
6
5
  static ɵfac: i0.ɵɵFactoryDeclaration<NgtpVignette, never>;
7
- static ɵcmp: i0.ɵɵComponentDeclaration<NgtpVignette, "ngtp-vignette", never, { "technique": { "alias": "technique"; "required": false; }; "eskil": { "alias": "eskil"; "required": false; }; "offset": { "alias": "offset"; "required": false; }; "darkness": { "alias": "darkness"; "required": false; }; }, {}, never, never, true, never>;
6
+ static ɵcmp: i0.ɵɵComponentDeclaration<NgtpVignette, "ngtp-vignette", never, {}, {}, never, ["*"], true, never>;
8
7
  }
@@ -2,4 +2,4 @@
2
2
  * Generated bundle index. Do not edit.
3
3
  */
4
4
  export * from './index';
5
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYW5ndWxhci10aHJlZS1wb3N0cHJvY2Vzc2luZy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL2xpYnMvYW5ndWxhci10aHJlZS1wb3N0cHJvY2Vzc2luZy9zcmMvYW5ndWxhci10aHJlZS1wb3N0cHJvY2Vzc2luZy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsU0FBUyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBHZW5lcmF0ZWQgYnVuZGxlIGluZGV4LiBEbyBub3QgZWRpdC5cbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL2luZGV4JztcbiJdfQ==
5
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYW5ndWxhci10aHJlZS1wb3N0cHJvY2Vzc2luZy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL2xpYnMvcG9zdHByb2Nlc3Npbmcvc3JjL2FuZ3VsYXItdGhyZWUtcG9zdHByb2Nlc3NpbmcudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLFNBQVMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogR2VuZXJhdGVkIGJ1bmRsZSBpbmRleC4gRG8gbm90IGVkaXQuXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9pbmRleCc7XG4iXX0=
@@ -0,0 +1,242 @@
1
+ import { CUSTOM_ELEMENTS_SCHEMA, Component, InjectionToken, Input, computed, effect, inject, } from '@angular/core';
2
+ import { NgtSignalStore, NgtStore, extend, injectBeforeRender, injectNgtRef, requestAnimationInInjectionContext, } from 'angular-three';
3
+ import { DepthDownsamplingPass, EffectComposer, EffectPass, NormalPass, RenderPass } from 'postprocessing';
4
+ import * as THREE from 'three';
5
+ import { Group } from 'three';
6
+ import { isWebGL2Available } from 'three-stdlib';
7
+ import * as i0 from "@angular/core";
8
+ extend({ Group });
9
+ export const NGTP_EFFECT_COMPOSER_API = new InjectionToken('NgtpEffectComposer API');
10
+ class NgtpEffectComposer extends NgtSignalStore {
11
+ set enabled(enabled) {
12
+ this.set({ enabled });
13
+ }
14
+ set depthBuffer(depthBuffer) {
15
+ this.set({ depthBuffer });
16
+ }
17
+ set disableNormalPass(disableNormalPass) {
18
+ this.set({ disableNormalPass });
19
+ }
20
+ set stencilBuffer(stencilBuffer) {
21
+ this.set({ stencilBuffer });
22
+ }
23
+ set autoClear(autoClear) {
24
+ this.set({ autoClear });
25
+ }
26
+ set resolutionScale(resolutionScale) {
27
+ this.set({ resolutionScale });
28
+ }
29
+ set multisampling(multisampling) {
30
+ this.set({ multisampling });
31
+ }
32
+ set frameBufferType(frameBufferType) {
33
+ this.set({ frameBufferType });
34
+ }
35
+ set renderPriority(renderPriority) {
36
+ this.set({ renderPriority });
37
+ }
38
+ set camera(camera) {
39
+ this.set({ camera });
40
+ }
41
+ set scene(scene) {
42
+ this.set({ scene });
43
+ }
44
+ #store;
45
+ #gl;
46
+ #size;
47
+ #defaultScene;
48
+ #defaultCamera;
49
+ #scene;
50
+ #camera;
51
+ #depthBuffer;
52
+ #stencilBuffer;
53
+ #multisampling;
54
+ #frameBufferType;
55
+ #disableNormalPass;
56
+ #resolutionScale;
57
+ #activeScene;
58
+ #activeCamera;
59
+ #composerEntities;
60
+ constructor() {
61
+ super({
62
+ enabled: true,
63
+ renderPriority: 1,
64
+ autoClear: true,
65
+ multisampling: 8,
66
+ frameBufferType: THREE.HalfFloatType,
67
+ });
68
+ this.composerRef = injectNgtRef();
69
+ this.#store = inject(NgtStore);
70
+ this.#gl = this.#store.select('gl');
71
+ this.#size = this.#store.select('size');
72
+ this.#defaultScene = this.#store.select('scene');
73
+ this.#defaultCamera = this.#store.select('camera');
74
+ this.#scene = this.select('scene');
75
+ this.#camera = this.select('camera');
76
+ this.#depthBuffer = this.select('depthBuffer');
77
+ this.#stencilBuffer = this.select('stencilBuffer');
78
+ this.#multisampling = this.select('multisampling');
79
+ this.#frameBufferType = this.select('frameBufferType');
80
+ this.#disableNormalPass = this.select('disableNormalPass');
81
+ this.#resolutionScale = this.select('resolutionScale');
82
+ this.#activeScene = computed(() => this.#scene() || this.#defaultScene());
83
+ this.#activeCamera = computed(() => this.#camera() || this.#defaultCamera());
84
+ this.#composerEntities = computed(() => {
85
+ const gl = this.#gl();
86
+ const camera = this.#activeCamera();
87
+ const scene = this.#activeScene();
88
+ const depthBuffer = this.#depthBuffer();
89
+ const stencilBuffer = this.#stencilBuffer();
90
+ const multisampling = this.#multisampling();
91
+ const frameBufferType = this.#frameBufferType();
92
+ const disableNormalPass = this.#disableNormalPass();
93
+ const resolutionScale = this.#resolutionScale();
94
+ const webGL2Available = isWebGL2Available();
95
+ // Initialize composer
96
+ const effectComposer = new EffectComposer(gl, {
97
+ depthBuffer,
98
+ stencilBuffer,
99
+ multisampling: multisampling > 0 && webGL2Available ? multisampling : 0,
100
+ frameBufferType,
101
+ });
102
+ // Add render pass
103
+ effectComposer.addPass(new RenderPass(scene, camera));
104
+ // Create normal pass
105
+ let downSamplingPass = null;
106
+ let normalPass = null;
107
+ if (!disableNormalPass) {
108
+ normalPass = new NormalPass(scene, camera);
109
+ normalPass.enabled = false;
110
+ effectComposer.addPass(normalPass);
111
+ if (resolutionScale !== undefined && webGL2Available) {
112
+ downSamplingPass = new DepthDownsamplingPass({ normalBuffer: normalPass.texture, resolutionScale });
113
+ downSamplingPass.enabled = false;
114
+ effectComposer.addPass(downSamplingPass);
115
+ }
116
+ }
117
+ return { effectComposer, normalPass, downSamplingPass };
118
+ });
119
+ this.api = computed(() => {
120
+ const { effectComposer, normalPass, downSamplingPass } = this.#composerEntities();
121
+ return {
122
+ composer: effectComposer,
123
+ normalPass,
124
+ downSamplingPass,
125
+ resolutionScale: this.#resolutionScale(),
126
+ camera: this.#activeCamera(),
127
+ scene: this.#activeScene(),
128
+ };
129
+ });
130
+ requestAnimationInInjectionContext(() => {
131
+ this.#setComposerSize();
132
+ this.#updateEffectPasses();
133
+ this.#setBeforeRender();
134
+ });
135
+ }
136
+ #setComposerSize() {
137
+ const trigger = computed(() => ({ composer: this.#composerEntities().effectComposer, size: this.#size() }));
138
+ effect(() => {
139
+ const { composer, size } = trigger();
140
+ if (!composer)
141
+ return;
142
+ composer.setSize(size.width, size.height);
143
+ });
144
+ }
145
+ #updateEffectPasses() {
146
+ const trigger = computed(() => ({
147
+ composerEntities: this.#composerEntities(),
148
+ instance: this.composerRef.nativeElement,
149
+ children: this.composerRef.children('nonObjects')(),
150
+ camera: this.#activeCamera(),
151
+ }));
152
+ effect((onCleanup) => {
153
+ const { composerEntities: { effectComposer, normalPass, downSamplingPass }, instance, children, camera, } = trigger();
154
+ let effectPass;
155
+ if (instance && children.length && effectComposer) {
156
+ effectPass = new EffectPass(camera, ...children);
157
+ effectPass.renderToScreen = true;
158
+ effectComposer.addPass(effectPass);
159
+ if (normalPass)
160
+ normalPass.enabled = true;
161
+ if (downSamplingPass)
162
+ downSamplingPass.enabled = true;
163
+ }
164
+ onCleanup(() => {
165
+ if (effectPass)
166
+ effectComposer?.removePass(effectPass);
167
+ if (normalPass)
168
+ normalPass.enabled = false;
169
+ if (downSamplingPass)
170
+ downSamplingPass.enabled = false;
171
+ });
172
+ });
173
+ }
174
+ #setBeforeRender() {
175
+ injectBeforeRender(({ delta }) => {
176
+ const enabled = this.get('enabled');
177
+ const autoClear = this.get('autoClear');
178
+ const gl = this.#store.get('gl');
179
+ const { effectComposer } = this.#composerEntities();
180
+ if (enabled && effectComposer) {
181
+ gl.autoClear = autoClear;
182
+ effectComposer.render(delta);
183
+ }
184
+ }, { priority: this.get('enabled') ? this.get('renderPriority') : 0 });
185
+ }
186
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: NgtpEffectComposer, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
187
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.0", type: NgtpEffectComposer, isStandalone: true, selector: "ngtp-effect-composer", inputs: { enabled: "enabled", depthBuffer: "depthBuffer", disableNormalPass: "disableNormalPass", stencilBuffer: "stencilBuffer", autoClear: "autoClear", resolutionScale: "resolutionScale", multisampling: "multisampling", frameBufferType: "frameBufferType", renderPriority: "renderPriority", camera: "camera", scene: "scene" }, providers: [
188
+ {
189
+ provide: NGTP_EFFECT_COMPOSER_API,
190
+ useFactory: (composer) => composer.api,
191
+ deps: [NgtpEffectComposer],
192
+ },
193
+ ], usesInheritance: true, ngImport: i0, template: `
194
+ <ngt-group [ref]="composerRef">
195
+ <ng-content />
196
+ </ngt-group>
197
+ `, isInline: true }); }
198
+ }
199
+ export { NgtpEffectComposer };
200
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: NgtpEffectComposer, decorators: [{
201
+ type: Component,
202
+ args: [{
203
+ selector: 'ngtp-effect-composer',
204
+ standalone: true,
205
+ template: `
206
+ <ngt-group [ref]="composerRef">
207
+ <ng-content />
208
+ </ngt-group>
209
+ `,
210
+ providers: [
211
+ {
212
+ provide: NGTP_EFFECT_COMPOSER_API,
213
+ useFactory: (composer) => composer.api,
214
+ deps: [NgtpEffectComposer],
215
+ },
216
+ ],
217
+ schemas: [CUSTOM_ELEMENTS_SCHEMA],
218
+ }]
219
+ }], ctorParameters: function () { return []; }, propDecorators: { enabled: [{
220
+ type: Input
221
+ }], depthBuffer: [{
222
+ type: Input
223
+ }], disableNormalPass: [{
224
+ type: Input
225
+ }], stencilBuffer: [{
226
+ type: Input
227
+ }], autoClear: [{
228
+ type: Input
229
+ }], resolutionScale: [{
230
+ type: Input
231
+ }], multisampling: [{
232
+ type: Input
233
+ }], frameBufferType: [{
234
+ type: Input
235
+ }], renderPriority: [{
236
+ type: Input
237
+ }], camera: [{
238
+ type: Input
239
+ }], scene: [{
240
+ type: Input
241
+ }] } });
242
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"effect-composer.js","sourceRoot":"","sources":["../../../../libs/postprocessing/src/effect-composer.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    CUSTOM_ELEMENTS_SCHEMA,\n    Component,\n    InjectionToken,\n    Input,\n    Signal,\n    computed,\n    effect,\n    inject,\n} from '@angular/core';\nimport {\n    NgtSignalStore,\n    NgtStore,\n    extend,\n    injectBeforeRender,\n    injectNgtRef,\n    requestAnimationInInjectionContext,\n} from 'angular-three';\nimport { DepthDownsamplingPass, EffectComposer, EffectPass, NormalPass, RenderPass } from 'postprocessing';\nimport * as THREE from 'three';\nimport { Group } from 'three';\nimport { isWebGL2Available } from 'three-stdlib';\n\nextend({ Group });\n\nexport interface NgtpEffectComposerState {\n    enabled: boolean;\n    depthBuffer?: boolean;\n    disableNormalPass?: boolean;\n    stencilBuffer?: boolean;\n    autoClear: boolean;\n    resolutionScale?: number;\n    multisampling: number;\n    frameBufferType: THREE.TextureDataType;\n    renderPriority: number;\n    camera?: THREE.Camera;\n    scene?: THREE.Scene;\n}\n\nexport interface NgtpEffectComposerApi {\n    composer: EffectComposer;\n    normalPass: NormalPass | null;\n    downSamplingPass: DepthDownsamplingPass | null;\n    camera: THREE.Camera;\n    scene: THREE.Scene;\n    resolutionScale?: number;\n}\n\nexport const NGTP_EFFECT_COMPOSER_API = new InjectionToken<Signal<NgtpEffectComposerApi>>('NgtpEffectComposer API');\n\n@Component({\n    selector: 'ngtp-effect-composer',\n    standalone: true,\n    template: `\n        <ngt-group [ref]=\"composerRef\">\n            <ng-content />\n        </ngt-group>\n    `,\n    providers: [\n        {\n            provide: NGTP_EFFECT_COMPOSER_API,\n            useFactory: (composer: NgtpEffectComposer) => composer.api,\n            deps: [NgtpEffectComposer],\n        },\n    ],\n    schemas: [CUSTOM_ELEMENTS_SCHEMA],\n})\nexport class NgtpEffectComposer extends NgtSignalStore<NgtpEffectComposerState> {\n    readonly composerRef = injectNgtRef<THREE.Group>();\n\n    @Input() set enabled(enabled: boolean) {\n        this.set({ enabled });\n    }\n\n    @Input() set depthBuffer(depthBuffer: boolean) {\n        this.set({ depthBuffer });\n    }\n\n    @Input() set disableNormalPass(disableNormalPass: boolean) {\n        this.set({ disableNormalPass });\n    }\n\n    @Input() set stencilBuffer(stencilBuffer: boolean) {\n        this.set({ stencilBuffer });\n    }\n\n    @Input() set autoClear(autoClear: boolean) {\n        this.set({ autoClear });\n    }\n\n    @Input() set resolutionScale(resolutionScale: number) {\n        this.set({ resolutionScale });\n    }\n\n    @Input() set multisampling(multisampling: number) {\n        this.set({ multisampling });\n    }\n\n    @Input() set frameBufferType(frameBufferType: THREE.TextureDataType) {\n        this.set({ frameBufferType });\n    }\n\n    @Input() set renderPriority(renderPriority: number) {\n        this.set({ renderPriority });\n    }\n\n    @Input() set camera(camera: THREE.Camera) {\n        this.set({ camera });\n    }\n\n    @Input() set scene(scene: THREE.Scene) {\n        this.set({ scene });\n    }\n\n    readonly #store = inject(NgtStore);\n    readonly #gl = this.#store.select('gl');\n    readonly #size = this.#store.select('size');\n    readonly #defaultScene = this.#store.select('scene');\n    readonly #defaultCamera = this.#store.select('camera');\n\n    readonly #scene = this.select('scene');\n    readonly #camera = this.select('camera');\n\n    readonly #depthBuffer = this.select('depthBuffer');\n    readonly #stencilBuffer = this.select('stencilBuffer');\n    readonly #multisampling = this.select('multisampling');\n    readonly #frameBufferType = this.select('frameBufferType');\n    readonly #disableNormalPass = this.select('disableNormalPass');\n    readonly #resolutionScale = this.select('resolutionScale');\n\n    readonly #activeScene = computed(() => this.#scene() || this.#defaultScene());\n    readonly #activeCamera = computed(() => this.#camera() || this.#defaultCamera());\n\n    readonly #composerEntities = computed(() => {\n        const gl = this.#gl();\n        const camera = this.#activeCamera();\n        const scene = this.#activeScene();\n        const depthBuffer = this.#depthBuffer();\n        const stencilBuffer = this.#stencilBuffer();\n        const multisampling = this.#multisampling();\n        const frameBufferType = this.#frameBufferType();\n        const disableNormalPass = this.#disableNormalPass();\n        const resolutionScale = this.#resolutionScale();\n\n        const webGL2Available = isWebGL2Available();\n        // Initialize composer\n        const effectComposer = new EffectComposer(gl, {\n            depthBuffer,\n            stencilBuffer,\n            multisampling: multisampling > 0 && webGL2Available ? multisampling : 0,\n            frameBufferType,\n        });\n\n        // Add render pass\n        effectComposer.addPass(new RenderPass(scene, camera));\n\n        // Create normal pass\n        let downSamplingPass = null;\n        let normalPass = null;\n        if (!disableNormalPass) {\n            normalPass = new NormalPass(scene, camera);\n            normalPass.enabled = false;\n            effectComposer.addPass(normalPass);\n            if (resolutionScale !== undefined && webGL2Available) {\n                downSamplingPass = new DepthDownsamplingPass({ normalBuffer: normalPass.texture, resolutionScale });\n                downSamplingPass.enabled = false;\n                effectComposer.addPass(downSamplingPass);\n            }\n        }\n\n        return { effectComposer, normalPass, downSamplingPass };\n    });\n\n    readonly api = computed(() => {\n        const { effectComposer, normalPass, downSamplingPass } = this.#composerEntities();\n        return {\n            composer: effectComposer,\n            normalPass,\n            downSamplingPass,\n            resolutionScale: this.#resolutionScale(),\n            camera: this.#activeCamera(),\n            scene: this.#activeScene(),\n        };\n    });\n\n    constructor() {\n        super({\n            enabled: true,\n            renderPriority: 1,\n            autoClear: true,\n            multisampling: 8,\n            frameBufferType: THREE.HalfFloatType,\n        });\n        requestAnimationInInjectionContext(() => {\n            this.#setComposerSize();\n            this.#updateEffectPasses();\n            this.#setBeforeRender();\n        });\n    }\n\n    #setComposerSize() {\n        const trigger = computed(() => ({ composer: this.#composerEntities().effectComposer, size: this.#size() }));\n        effect(() => {\n            const { composer, size } = trigger();\n            if (!composer) return;\n            composer.setSize(size.width, size.height);\n        });\n    }\n\n    #updateEffectPasses() {\n        const trigger = computed(() => ({\n            composerEntities: this.#composerEntities(),\n            instance: this.composerRef.nativeElement,\n            children: this.composerRef.children('nonObjects')(),\n            camera: this.#activeCamera(),\n        }));\n        effect((onCleanup) => {\n            const {\n                composerEntities: { effectComposer, normalPass, downSamplingPass },\n                instance,\n                children,\n                camera,\n            } = trigger();\n\n            let effectPass: EffectPass;\n            if (instance && children.length && effectComposer) {\n                effectPass = new EffectPass(camera, ...children);\n                effectPass.renderToScreen = true;\n                effectComposer.addPass(effectPass);\n                if (normalPass) normalPass.enabled = true;\n                if (downSamplingPass) downSamplingPass.enabled = true;\n            }\n\n            onCleanup(() => {\n                if (effectPass) effectComposer?.removePass(effectPass);\n                if (normalPass) normalPass.enabled = false;\n                if (downSamplingPass) downSamplingPass.enabled = false;\n            });\n        });\n    }\n\n    #setBeforeRender() {\n        injectBeforeRender(\n            ({ delta }) => {\n                const enabled = this.get('enabled');\n                const autoClear = this.get('autoClear');\n                const gl = this.#store.get('gl');\n                const { effectComposer } = this.#composerEntities();\n                if (enabled && effectComposer) {\n                    gl.autoClear = autoClear;\n                    effectComposer.render(delta);\n                }\n            },\n            { priority: this.get('enabled') ? this.get('renderPriority') : 0 }\n        );\n    }\n}\n"]}