angular-three-postprocessing 2.0.0-beta.7 → 2.0.0-beta.8

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 (90) hide show
  1. package/esm2022/index.mjs +4 -3
  2. package/esm2022/lib/effect-composer.mjs +248 -0
  3. package/esm2022/lib/effect.mjs +78 -0
  4. package/esm2022/lib/effects/bloom/bloom.mjs +33 -0
  5. package/esm2022/lib/effects/brightness-contrast/brightness-contrast.mjs +29 -0
  6. package/esm2022/lib/effects/color-depth/color-depth.mjs +29 -0
  7. package/esm2022/lib/effects/depth/depth.mjs +29 -0
  8. package/esm2022/lib/effects/dot-screen/dot-screen.mjs +29 -0
  9. package/esm2022/lib/effects/hue-saturation/hue-saturation.mjs +29 -0
  10. package/esm2022/lib/effects/index.mjs +18 -0
  11. package/esm2022/lib/effects/lut/lut.mjs +70 -0
  12. package/esm2022/lib/effects/noise/noise.mjs +33 -0
  13. package/esm2022/lib/effects/pixelation/pixelation.mjs +33 -0
  14. package/esm2022/lib/effects/scanline/scanline.mjs +33 -0
  15. package/esm2022/lib/effects/sepia/sepia.mjs +29 -0
  16. package/esm2022/lib/effects/shock-wave/shock-wave.mjs +29 -0
  17. package/esm2022/lib/effects/smaa/smaa.mjs +29 -0
  18. package/esm2022/lib/effects/ssao/ssao.mjs +213 -0
  19. package/esm2022/lib/effects/tilt-shift/tilt-shift.mjs +33 -0
  20. package/esm2022/lib/effects/tone-mapping/tone-mapping.mjs +29 -0
  21. package/esm2022/lib/effects/vignette/vignette.mjs +29 -0
  22. package/fesm2022/angular-three-postprocessing.mjs +868 -206
  23. package/fesm2022/angular-three-postprocessing.mjs.map +1 -1
  24. package/index.d.ts +3 -2
  25. package/lib/effect-composer.d.ts +100 -0
  26. package/lib/effect.d.ts +27 -0
  27. package/{effects → lib/effects}/bloom/bloom.d.ts +7 -2
  28. package/{effects → lib/effects}/brightness-contrast/brightness-contrast.d.ts +9 -1
  29. package/{effects → lib/effects}/color-depth/color-depth.d.ts +8 -1
  30. package/{effects → lib/effects}/depth/depth.d.ts +8 -1
  31. package/{effects → lib/effects}/dot-screen/dot-screen.d.ts +9 -1
  32. package/{effects → lib/effects}/hue-saturation/hue-saturation.d.ts +9 -1
  33. package/{effects → lib/effects}/index.d.ts +1 -0
  34. package/lib/effects/lut/lut.d.ts +29 -0
  35. package/{effects → lib/effects}/noise/noise.d.ts +8 -1
  36. package/lib/effects/pixelation/pixelation.d.ts +20 -0
  37. package/{effects → lib/effects}/scanline/scanline.d.ts +8 -1
  38. package/{effects → lib/effects}/sepia/sepia.d.ts +8 -1
  39. package/lib/effects/shock-wave/shock-wave.d.ts +17 -0
  40. package/lib/effects/smaa/smaa.d.ts +16 -0
  41. package/lib/effects/ssao/ssao.d.ts +42 -0
  42. package/lib/effects/tilt-shift/tilt-shift.d.ts +23 -0
  43. package/lib/effects/tone-mapping/tone-mapping.d.ts +22 -0
  44. package/lib/effects/vignette/vignette.d.ts +17 -0
  45. package/package.json +3 -14
  46. package/effect-composer.d.ts +0 -53
  47. package/effect.d.ts +0 -24
  48. package/effects/README.md +0 -3
  49. package/effects/lut/lut.d.ts +0 -19
  50. package/effects/shock-wave/shock-wave.d.ts +0 -7
  51. package/effects/smaa/smaa.d.ts +0 -7
  52. package/effects/ssao/ssao.d.ts +0 -38
  53. package/effects/tilt-shift/tilt-shift.d.ts +0 -8
  54. package/effects/tone-mapping/tone-mapping.d.ts +0 -7
  55. package/effects/vignette/vignette.d.ts +0 -7
  56. package/esm2022/effect-composer.mjs +0 -242
  57. package/esm2022/effect.mjs +0 -79
  58. package/esm2022/effects/angular-three-postprocessing-effects.mjs +0 -5
  59. package/esm2022/effects/bloom/bloom.mjs +0 -34
  60. package/esm2022/effects/brightness-contrast/brightness-contrast.mjs +0 -30
  61. package/esm2022/effects/color-depth/color-depth.mjs +0 -30
  62. package/esm2022/effects/depth/depth.mjs +0 -30
  63. package/esm2022/effects/dot-screen/dot-screen.mjs +0 -30
  64. package/esm2022/effects/hue-saturation/hue-saturation.mjs +0 -30
  65. package/esm2022/effects/index.mjs +0 -17
  66. package/esm2022/effects/lut/lut.mjs +0 -77
  67. package/esm2022/effects/noise/noise.mjs +0 -34
  68. package/esm2022/effects/scanline/scanline.mjs +0 -34
  69. package/esm2022/effects/sepia/sepia.mjs +0 -30
  70. package/esm2022/effects/shock-wave/shock-wave.mjs +0 -30
  71. package/esm2022/effects/smaa/smaa.mjs +0 -30
  72. package/esm2022/effects/ssao/ssao.mjs +0 -187
  73. package/esm2022/effects/tilt-shift/tilt-shift.mjs +0 -34
  74. package/esm2022/effects/tone-mapping/tone-mapping.mjs +0 -30
  75. package/esm2022/effects/vignette/vignette.mjs +0 -30
  76. package/fesm2022/angular-three-postprocessing-effects.mjs +0 -617
  77. package/fesm2022/angular-three-postprocessing-effects.mjs.map +0 -1
  78. package/plugin/README.md +0 -11
  79. package/plugin/generators.json +0 -19
  80. package/plugin/package.json +0 -9
  81. package/plugin/src/generators/init/compat.d.ts +0 -2
  82. package/plugin/src/generators/init/compat.js +0 -6
  83. package/plugin/src/generators/init/compat.js.map +0 -1
  84. package/plugin/src/generators/init/init.d.ts +0 -4
  85. package/plugin/src/generators/init/init.js +0 -22
  86. package/plugin/src/generators/init/init.js.map +0 -1
  87. package/plugin/src/generators/init/schema.json +0 -6
  88. package/plugin/src/index.d.ts +0 -1
  89. package/plugin/src/index.js +0 -6
  90. package/plugin/src/index.js.map +0 -1
@@ -0,0 +1,42 @@
1
+ import { BlendFunction, SSAOEffect } from 'postprocessing';
2
+ import * as i0 from "@angular/core";
3
+ export type NgtpSSAOState = NonNullable<ConstructorParameters<typeof SSAOEffect>[2]>;
4
+ declare global {
5
+ interface HTMLElementTagNameMap {
6
+ 'ngtp-SSAO': NgtpSSAOState;
7
+ }
8
+ }
9
+ export declare class NgtpSSAO {
10
+ private inputs;
11
+ effectRef: import("angular-three").NgtInjectedRef<SSAOEffect>;
12
+ set _blendFunction(blendFunction: BlendFunction);
13
+ set _distanceScaling(distanceScaling: boolean);
14
+ set _depthAwareUpsampling(depthAwareUpsampling: boolean);
15
+ set _normalDepthBuffer(normalDepthBuffer: THREE.Texture);
16
+ set _samples(samples: number);
17
+ set _rings(rings: number);
18
+ set _worldDistanceThreshold(worldDistanceThreshold: number);
19
+ set _worldDistanceFalloff(worldDistanceFalloff: number);
20
+ set _worldProximityThreshold(worldProximityThreshold: number);
21
+ set _worldProximityFalloff(worldProximityFalloff: number);
22
+ set _distanceThreshold(distanceThreshold: number);
23
+ set _distanceFalloff(distanceFalloff: number);
24
+ set _rangeThreshold(rangeThreshold: number);
25
+ set _rangeFalloff(rangeFalloff: number);
26
+ set _minRadiusScale(minRadiusScale: number);
27
+ set _luminanceInfluence(luminanceInfluence: number);
28
+ set _radius(radius: number);
29
+ set _intensity(intensity: number);
30
+ set _bias(bias: number);
31
+ set _fade(fade: number);
32
+ set _color(color: THREE.Color);
33
+ set _resolutionScale(resolutionScale: number);
34
+ set _resolutionX(resolutionX: number);
35
+ set _resolutionY(resolutionY: number);
36
+ set _width(width: number);
37
+ set _height(height: number);
38
+ private effectComposerApi;
39
+ effect: import("@angular/core").Signal<SSAOEffect | null>;
40
+ static ɵfac: i0.ɵɵFactoryDeclaration<NgtpSSAO, never>;
41
+ 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>;
42
+ }
@@ -0,0 +1,23 @@
1
+ import { BlendFunction, KernelSize, TiltShiftEffect } from 'postprocessing';
2
+ import { NgtpEffect, type NgtpEffectState } from '../../effect';
3
+ import * as i0 from "@angular/core";
4
+ declare global {
5
+ interface HTMLElementTagNameMap {
6
+ 'ngtp-tilt-shift': {
7
+ offset?: number;
8
+ rotation?: number;
9
+ focusArea?: number;
10
+ feather?: number;
11
+ bias?: number;
12
+ kernelSize?: KernelSize;
13
+ resolutionScale?: number;
14
+ resolutionX?: number;
15
+ resolutionY?: number;
16
+ } & NgtpEffectState;
17
+ }
18
+ }
19
+ export declare class NgtpTiltShift extends NgtpEffect<TiltShiftEffect> {
20
+ defaultBlendFunction: BlendFunction;
21
+ static ɵfac: i0.ɵɵFactoryDeclaration<NgtpTiltShift, never>;
22
+ static ɵcmp: i0.ɵɵComponentDeclaration<NgtpTiltShift, "ngtp-tilt-shift", never, {}, {}, never, ["*"], true, never>;
23
+ }
@@ -0,0 +1,22 @@
1
+ import { ToneMappingEffect, ToneMappingMode } from 'postprocessing';
2
+ import { NgtpEffect, type NgtpEffectState } from '../../effect';
3
+ import * as i0 from "@angular/core";
4
+ declare global {
5
+ interface HTMLElementTagNameMap {
6
+ 'ngtp-tone-mapping': {
7
+ adaptive?: boolean;
8
+ mode?: ToneMappingMode;
9
+ resolution?: number;
10
+ maxLuminance?: number;
11
+ whitePoint?: number;
12
+ middleGrey?: number;
13
+ minLuminance?: number;
14
+ averageLuminance?: number;
15
+ adaptationRate?: number;
16
+ } & NgtpEffectState;
17
+ }
18
+ }
19
+ export declare class NgtpToneMapping extends NgtpEffect<ToneMappingEffect> {
20
+ static ɵfac: i0.ɵɵFactoryDeclaration<NgtpToneMapping, never>;
21
+ static ɵcmp: i0.ɵɵComponentDeclaration<NgtpToneMapping, "ngtp-tone-mapping", never, {}, {}, never, ["*"], true, never>;
22
+ }
@@ -0,0 +1,17 @@
1
+ import { VignetteEffect, VignetteTechnique } from 'postprocessing';
2
+ import { NgtpEffect, type NgtpEffectState } from '../../effect';
3
+ import * as i0 from "@angular/core";
4
+ declare global {
5
+ interface HTMLElementTagNameMap {
6
+ 'ngtp-vignette': {
7
+ technique?: VignetteTechnique;
8
+ eskil?: boolean;
9
+ offset?: number;
10
+ darkness?: number;
11
+ } & NgtpEffectState;
12
+ }
13
+ }
14
+ export declare class NgtpVignette extends NgtpEffect<VignetteEffect> {
15
+ static ɵfac: i0.ɵɵFactoryDeclaration<NgtpVignette, never>;
16
+ static ɵcmp: i0.ɵɵComponentDeclaration<NgtpVignette, "ngtp-vignette", never, {}, {}, never, ["*"], true, never>;
17
+ }
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "angular-three-postprocessing",
3
- "version": "2.0.0-beta.7",
3
+ "version": "2.0.0-beta.8",
4
4
  "publishConfig": {
5
5
  "access": "public"
6
6
  },
@@ -26,17 +26,12 @@
26
26
  "@angular/core": " ^16.0.0",
27
27
  "angular-three": "^2.0.0",
28
28
  "postprocessing": "^6.0.0",
29
- "three": "^0.148.0 || ^0.149.0 || ^0.150.0 || ^0.151.0 || ^0.152.0",
30
- "three-stdlib": "2.23.4"
29
+ "three": ">=0.148.0"
31
30
  },
32
31
  "dependencies": {
33
- "tslib": "^2.3.0",
34
- "@nx/devkit": "^16.0.0",
35
- "nx": "^16.0.0"
32
+ "tslib": "^2.3.0"
36
33
  },
37
34
  "sideEffects": false,
38
- "generators": "./plugin/generators.json",
39
- "schematics": "./plugin/generators.json",
40
35
  "module": "fesm2022/angular-three-postprocessing.mjs",
41
36
  "typings": "index.d.ts",
42
37
  "exports": {
@@ -48,12 +43,6 @@
48
43
  "esm2022": "./esm2022/angular-three-postprocessing.mjs",
49
44
  "esm": "./esm2022/angular-three-postprocessing.mjs",
50
45
  "default": "./fesm2022/angular-three-postprocessing.mjs"
51
- },
52
- "./effects": {
53
- "types": "./effects/index.d.ts",
54
- "esm2022": "./esm2022/effects/angular-three-postprocessing-effects.mjs",
55
- "esm": "./esm2022/effects/angular-three-postprocessing-effects.mjs",
56
- "default": "./fesm2022/angular-three-postprocessing-effects.mjs"
57
46
  }
58
47
  }
59
48
  }
@@ -1,53 +0,0 @@
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 DELETED
@@ -1,24 +0,0 @@
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
- }
package/effects/README.md DELETED
@@ -1,3 +0,0 @@
1
- # angular-three-postprocessing/effects
2
-
3
- Secondary entry point of `angular-three-postprocessing`. It can be used by importing from `angular-three-postprocessing/effects`.
@@ -1,19 +0,0 @@
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
- }
@@ -1,7 +0,0 @@
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
- }
@@ -1,7 +0,0 @@
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
- }
@@ -1,38 +0,0 @@
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
- }
@@ -1,8 +0,0 @@
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
- }
@@ -1,7 +0,0 @@
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
- }
@@ -1,7 +0,0 @@
1
- import { NgtpEffect } from 'angular-three-postprocessing';
2
- import { VignetteEffect } from 'postprocessing';
3
- import * as i0 from "@angular/core";
4
- export declare class NgtpVignette extends NgtpEffect<VignetteEffect> {
5
- static ɵfac: i0.ɵɵFactoryDeclaration<NgtpVignette, never>;
6
- static ɵcmp: i0.ɵɵComponentDeclaration<NgtpVignette, "ngtp-vignette", never, {}, {}, never, ["*"], true, never>;
7
- }
@@ -1,242 +0,0 @@
1
- import { CUSTOM_ELEMENTS_SCHEMA, Component, InjectionToken, Input, computed, effect, inject, } from '@angular/core';
2
- import { NgtSignalStore, NgtStore, extend, injectBeforeRender, injectNgtRef, requestAnimationFrameInInjectionContext, } 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
- requestAnimationFrameInInjectionContext(() => {
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.3", ngImport: i0, type: NgtpEffectComposer, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
187
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.3", 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.3", 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    requestAnimationFrameInInjectionContext,\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        requestAnimationFrameInInjectionContext(() => {\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"]}