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

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 (121) hide show
  1. package/README.md +56 -4
  2. package/esm2022/index.mjs +4 -3
  3. package/esm2022/lib/effect-composer.mjs +188 -0
  4. package/esm2022/lib/effect.mjs +50 -0
  5. package/esm2022/lib/effects/ascii.mjs +120 -0
  6. package/esm2022/lib/effects/bloom.mjs +39 -0
  7. package/esm2022/lib/effects/brightness-contrast.mjs +38 -0
  8. package/esm2022/lib/effects/chromatic-abberation.mjs +38 -0
  9. package/esm2022/lib/effects/color-average.mjs +33 -0
  10. package/esm2022/lib/effects/color-depth.mjs +38 -0
  11. package/esm2022/lib/effects/depth-of-field.mjs +56 -0
  12. package/esm2022/lib/effects/depth.mjs +38 -0
  13. package/esm2022/lib/effects/dot-screen.mjs +38 -0
  14. package/esm2022/lib/effects/fxaa.mjs +38 -0
  15. package/esm2022/lib/effects/glitch.mjs +63 -0
  16. package/esm2022/lib/effects/god-rays.mjs +41 -0
  17. package/esm2022/lib/effects/grid.mjs +42 -0
  18. package/esm2022/lib/effects/hue-saturation.mjs +38 -0
  19. package/esm2022/lib/effects/index.mjs +28 -0
  20. package/esm2022/lib/effects/lens-flare.mjs +195 -0
  21. package/esm2022/lib/effects/lut.mjs +50 -0
  22. package/esm2022/lib/effects/noise.mjs +39 -0
  23. package/esm2022/lib/effects/outline.mjs +143 -0
  24. package/esm2022/lib/effects/pixelation.mjs +30 -0
  25. package/esm2022/lib/effects/scanline.mjs +43 -0
  26. package/esm2022/lib/effects/sepia.mjs +38 -0
  27. package/esm2022/lib/effects/shock-wave.mjs +38 -0
  28. package/esm2022/lib/effects/smaa.mjs +38 -0
  29. package/esm2022/lib/effects/tilt-shift-2.mjs +121 -0
  30. package/esm2022/lib/effects/tilt-shift.mjs +39 -0
  31. package/esm2022/lib/effects/vignette.mjs +38 -0
  32. package/esm2022/lib/effects/water.mjs +64 -0
  33. package/fesm2022/angular-three-postprocessing.mjs +1557 -266
  34. package/fesm2022/angular-three-postprocessing.mjs.map +1 -1
  35. package/index.d.ts +3 -2
  36. package/lib/effect-composer.d.ts +48 -0
  37. package/lib/effect.d.ts +56 -0
  38. package/lib/effects/ascii.d.ts +23 -0
  39. package/lib/effects/bloom.d.ts +10 -0
  40. package/lib/effects/brightness-contrast.d.ts +15 -0
  41. package/lib/effects/chromatic-abberation.d.ts +16 -0
  42. package/lib/effects/color-average.d.ts +11 -0
  43. package/lib/effects/color-depth.d.ts +14 -0
  44. package/lib/effects/depth-of-field.d.ts +22 -0
  45. package/lib/effects/depth.d.ts +14 -0
  46. package/lib/effects/dot-screen.d.ts +15 -0
  47. package/lib/effects/fxaa.d.ts +13 -0
  48. package/lib/effects/glitch.d.ts +29 -0
  49. package/lib/effects/god-rays.d.ts +30 -0
  50. package/lib/effects/grid.d.ts +18 -0
  51. package/lib/effects/hue-saturation.d.ts +15 -0
  52. package/lib/effects/index.d.ts +27 -0
  53. package/lib/effects/lens-flare.d.ts +96 -0
  54. package/lib/effects/lut.d.ts +19 -0
  55. package/lib/effects/noise.d.ts +14 -0
  56. package/lib/effects/outline.d.ts +74 -0
  57. package/lib/effects/pixelation.d.ts +16 -0
  58. package/lib/effects/scanline.d.ts +17 -0
  59. package/lib/effects/sepia.d.ts +14 -0
  60. package/lib/effects/shock-wave.d.ts +11 -0
  61. package/lib/effects/smaa.d.ts +15 -0
  62. package/lib/effects/tilt-shift-2.d.ts +35 -0
  63. package/lib/effects/tilt-shift.d.ts +22 -0
  64. package/lib/effects/vignette.d.ts +17 -0
  65. package/lib/effects/water.d.ts +20 -0
  66. package/package.json +13 -19
  67. package/effect-composer.d.ts +0 -53
  68. package/effect.d.ts +0 -24
  69. package/effects/README.md +0 -3
  70. package/effects/bloom/bloom.d.ts +0 -8
  71. package/effects/brightness-contrast/brightness-contrast.d.ts +0 -7
  72. package/effects/color-depth/color-depth.d.ts +0 -7
  73. package/effects/depth/depth.d.ts +0 -7
  74. package/effects/dot-screen/dot-screen.d.ts +0 -7
  75. package/effects/hue-saturation/hue-saturation.d.ts +0 -7
  76. package/effects/index.d.ts +0 -16
  77. package/effects/lut/lut.d.ts +0 -19
  78. package/effects/noise/noise.d.ts +0 -8
  79. package/effects/scanline/scanline.d.ts +0 -8
  80. package/effects/sepia/sepia.d.ts +0 -7
  81. package/effects/shock-wave/shock-wave.d.ts +0 -7
  82. package/effects/smaa/smaa.d.ts +0 -7
  83. package/effects/ssao/ssao.d.ts +0 -38
  84. package/effects/tilt-shift/tilt-shift.d.ts +0 -8
  85. package/effects/tone-mapping/tone-mapping.d.ts +0 -7
  86. package/effects/vignette/vignette.d.ts +0 -7
  87. package/esm2022/effect-composer.mjs +0 -242
  88. package/esm2022/effect.mjs +0 -79
  89. package/esm2022/effects/angular-three-postprocessing-effects.mjs +0 -5
  90. package/esm2022/effects/bloom/bloom.mjs +0 -34
  91. package/esm2022/effects/brightness-contrast/brightness-contrast.mjs +0 -30
  92. package/esm2022/effects/color-depth/color-depth.mjs +0 -30
  93. package/esm2022/effects/depth/depth.mjs +0 -30
  94. package/esm2022/effects/dot-screen/dot-screen.mjs +0 -30
  95. package/esm2022/effects/hue-saturation/hue-saturation.mjs +0 -30
  96. package/esm2022/effects/index.mjs +0 -17
  97. package/esm2022/effects/lut/lut.mjs +0 -77
  98. package/esm2022/effects/noise/noise.mjs +0 -34
  99. package/esm2022/effects/scanline/scanline.mjs +0 -34
  100. package/esm2022/effects/sepia/sepia.mjs +0 -30
  101. package/esm2022/effects/shock-wave/shock-wave.mjs +0 -30
  102. package/esm2022/effects/smaa/smaa.mjs +0 -30
  103. package/esm2022/effects/ssao/ssao.mjs +0 -189
  104. package/esm2022/effects/tilt-shift/tilt-shift.mjs +0 -34
  105. package/esm2022/effects/tone-mapping/tone-mapping.mjs +0 -30
  106. package/esm2022/effects/vignette/vignette.mjs +0 -30
  107. package/fesm2022/angular-three-postprocessing-effects.mjs +0 -619
  108. package/fesm2022/angular-three-postprocessing-effects.mjs.map +0 -1
  109. package/plugin/README.md +0 -11
  110. package/plugin/generators.json +0 -19
  111. package/plugin/package.json +0 -9
  112. package/plugin/src/generators/init/compat.d.ts +0 -2
  113. package/plugin/src/generators/init/compat.js +0 -6
  114. package/plugin/src/generators/init/compat.js.map +0 -1
  115. package/plugin/src/generators/init/init.d.ts +0 -4
  116. package/plugin/src/generators/init/init.js +0 -22
  117. package/plugin/src/generators/init/init.js.map +0 -1
  118. package/plugin/src/generators/init/schema.json +0 -6
  119. package/plugin/src/index.d.ts +0 -1
  120. package/plugin/src/index.js +0 -6
  121. package/plugin/src/index.js.map +0 -1
package/README.md CHANGED
@@ -1,7 +1,59 @@
1
- # postprocessing
1
+ # `angular-three-postprocessing`
2
2
 
3
- This library was generated with [Nx](https://nx.dev).
3
+ This is the main entry point for post-processing effects in Angular Three. It provides a way to apply various visual effects to your 3D scene after it has been rendered. This library relies on `maath`, `three-stdlib`, and `postprocessing` as dependencies.
4
4
 
5
- ## Running unit tests
5
+ ## Installation
6
6
 
7
- Run `nx test postprocessing` to execute the unit tests.
7
+ ```bash
8
+ npm install angular-three-postprocessing three-stdlib maath postprocessing
9
+ # yarn add angular-three-postprocessing three-stdlib maath postprocessing
10
+ # pnpm add angular-three-postprocessing three-stdlib maath postprocessing
11
+ ```
12
+
13
+ ## NgtpEffectComposer
14
+
15
+ This is a wrapper component that manages and applies post-processing effects to your scene. It takes content children of effects and applies them in the order they are provided.
16
+
17
+ ### Object Inputs (NgtpEffectComposerOptions)
18
+
19
+ | Property | Description | Default Value |
20
+ | ------------------ | ------------------------------------------------------------------------------------------------- | ------------- |
21
+ | `enabled` | Whether the effect composer is enabled. | true |
22
+ | `depthBuffer` | Whether to use a depth buffer. | undefined |
23
+ | `enableNormalPass` | Whether to enable the normal pass. This is only used for SSGI currently. | undefined |
24
+ | `stencilBuffer` | Whether to use a stencil buffer. | undefined |
25
+ | `autoClear` | Whether to automatically clear the output buffer before rendering. | true |
26
+ | `resolutionScale` | A scaling factor for the resolution of the effect composer. | undefined |
27
+ | `multisampling` | The number of samples to use for multisample anti-aliasing (MSAA). Set to 0 to disable MSAA. | 8 |
28
+ | `frameBufferType` | The data type to use for the frame buffer. | HalfFloatType |
29
+ | `renderPriority` | The render priority of the effect composer. | 1 |
30
+ | `camera` | The camera to use for rendering. If not provided, the default camera from the store will be used. | undefined |
31
+ | `scene` | The scene to render. If not provided, the default scene from the store will be used. | undefined |
32
+
33
+ ````html
34
+ <ngtp-effect-composer [options]="{ multisampling: 0, frameBufferType: FloatType, enableNormalPass: true }">
35
+ <ngtp-bloom />
36
+ </ngtp-effect-composer>
37
+ ```
38
+ ````
39
+
40
+ ### NgtpEffectComposerApi
41
+
42
+ This is an interface that provides access to the underlying `NgtpEffectComposer` instance, as well as the `camera` and `scene` being used. It also includes references to the `NormalPass` and `DepthDownsamplingPass` if they are enabled
43
+
44
+ ```ts
45
+ export interface NgtpEffectComposerApi {
46
+ composer: EffectComposer;
47
+ camera: Camera;
48
+ scene: Scene;
49
+ normalPass: NormalPass | null;
50
+ downSamplingPass: DepthDownsamplingPass | null;
51
+ resolutionScale?: number;
52
+ }
53
+ ```
54
+
55
+ To retrieve the `NgtpEffectComposerApi` for components within `<ngtp-effect-composer />`, you can use the `injectEffectComposerApi` function.
56
+
57
+ ## Effects
58
+
59
+ TBD
package/esm2022/index.mjs CHANGED
@@ -1,3 +1,4 @@
1
- export * from './effect';
2
- export * from './effect-composer';
3
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9saWJzL3Bvc3Rwcm9jZXNzaW5nL3NyYy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLFVBQVUsQ0FBQztBQUN6QixjQUFjLG1CQUFtQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9lZmZlY3QnO1xuZXhwb3J0ICogZnJvbSAnLi9lZmZlY3QtY29tcG9zZXInO1xuIl19
1
+ export * from './lib/effect';
2
+ export * from './lib/effect-composer';
3
+ export * from './lib/effects';
4
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9saWJzL3Bvc3Rwcm9jZXNzaW5nL3NyYy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLGNBQWMsQ0FBQztBQUM3QixjQUFjLHVCQUF1QixDQUFDO0FBQ3RDLGNBQWMsZUFBZSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9saWIvZWZmZWN0JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2VmZmVjdC1jb21wb3Nlcic7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9lZmZlY3RzJztcbiJdfQ==
@@ -0,0 +1,188 @@
1
+ import { CUSTOM_ELEMENTS_SCHEMA, ChangeDetectionStrategy, Component, Injector, afterNextRender, computed, inject, input, viewChild, } from '@angular/core';
2
+ import { extend, getLocalState, injectBeforeRender, injectStore, pick } from 'angular-three';
3
+ import { injectAutoEffect } from 'ngxtension/auto-effect';
4
+ import { mergeInputs } from 'ngxtension/inject-inputs';
5
+ import { DepthDownsamplingPass, Effect, EffectAttribute, EffectComposer, EffectPass, NormalPass, Pass, RenderPass, } from 'postprocessing';
6
+ import { Group, HalfFloatType, NoToneMapping } from 'three';
7
+ import { isWebGL2Available } from 'three-stdlib';
8
+ import * as i0 from "@angular/core";
9
+ const defaultOptions = {
10
+ enabled: true,
11
+ renderPriority: 1,
12
+ autoClear: true,
13
+ multisampling: 8,
14
+ frameBufferType: HalfFloatType,
15
+ };
16
+ function isConvolution(effect) {
17
+ return (effect.getAttributes() & EffectAttribute.CONVOLUTION) === EffectAttribute.CONVOLUTION;
18
+ }
19
+ export class NgtpEffectComposer {
20
+ constructor() {
21
+ this.options = input(defaultOptions, { transform: mergeInputs(defaultOptions) });
22
+ this.injector = inject(Injector);
23
+ this.autoEffect = injectAutoEffect();
24
+ this.store = injectStore();
25
+ this.size = this.store.select('size');
26
+ this.gl = this.store.select('gl');
27
+ this.defaultScene = this.store.select('scene');
28
+ this.defaultCamera = this.store.select('camera');
29
+ this.depthBuffer = pick(this.options, 'depthBuffer');
30
+ this.stencilBuffer = pick(this.options, 'stencilBuffer');
31
+ this.multisampling = pick(this.options, 'multisampling');
32
+ this.frameBufferType = pick(this.options, 'frameBufferType');
33
+ this.scene = computed(() => this.options().scene ?? this.defaultScene());
34
+ this.camera = computed(() => this.options().camera ?? this.defaultCamera());
35
+ this.enableNormalPass = pick(this.options, 'enableNormalPass');
36
+ this.resolutionScale = pick(this.options, 'resolutionScale');
37
+ this.groupRef = viewChild.required('group');
38
+ this.composerData = computed(() => {
39
+ const webGL2Available = isWebGL2Available();
40
+ const [gl, scene, camera, depthBuffer, stencilBuffer, multisampling, frameBufferType, enableNormalPass, resolutionScale,] = [
41
+ this.gl(),
42
+ this.scene(),
43
+ this.camera(),
44
+ this.depthBuffer(),
45
+ this.stencilBuffer(),
46
+ this.multisampling(),
47
+ this.frameBufferType(),
48
+ this.enableNormalPass(),
49
+ this.resolutionScale(),
50
+ ];
51
+ // initialize composer
52
+ const composer = new EffectComposer(gl, {
53
+ depthBuffer,
54
+ stencilBuffer,
55
+ multisampling: multisampling > 0 && webGL2Available ? multisampling : 0,
56
+ frameBufferType,
57
+ });
58
+ // add render pass
59
+ composer.addPass(new RenderPass(scene, camera));
60
+ // create normal pass
61
+ let downSamplingPass = null;
62
+ let normalPass = null;
63
+ if (enableNormalPass) {
64
+ normalPass = new NormalPass(scene, camera);
65
+ normalPass.enabled = false;
66
+ composer.addPass(normalPass);
67
+ if (resolutionScale !== undefined && webGL2Available) {
68
+ downSamplingPass = new DepthDownsamplingPass({ normalBuffer: normalPass.texture, resolutionScale });
69
+ downSamplingPass.enabled = false;
70
+ composer.addPass(downSamplingPass);
71
+ }
72
+ }
73
+ return { composer, normalPass, downSamplingPass };
74
+ });
75
+ extend({ Group });
76
+ afterNextRender(() => {
77
+ this.disableToneMapping();
78
+ this.setComposerSize();
79
+ this.updatePasses();
80
+ injectBeforeRender(({ delta }) => {
81
+ const [{ composer }, { enabled, autoClear, stencilBuffer }, gl] = [
82
+ this.composerData(),
83
+ this.options(),
84
+ this.gl(),
85
+ ];
86
+ if (enabled) {
87
+ const currentAutoClear = gl.autoClear;
88
+ gl.autoClear = autoClear;
89
+ if (stencilBuffer && !autoClear)
90
+ gl.clearStencil();
91
+ composer.render(delta);
92
+ gl.autoClear = currentAutoClear;
93
+ }
94
+ }, { injector: this.injector, priority: this.options().enabled ? this.options().renderPriority : 0 });
95
+ });
96
+ }
97
+ // NOTE: Disable tone mapping because threejs disallows tonemapping on render targets
98
+ disableToneMapping() {
99
+ this.autoEffect(() => {
100
+ const gl = this.gl();
101
+ const currentTonemapping = gl.toneMapping;
102
+ gl.toneMapping = NoToneMapping;
103
+ return () => {
104
+ gl.toneMapping = currentTonemapping;
105
+ };
106
+ });
107
+ }
108
+ setComposerSize() {
109
+ this.autoEffect(() => {
110
+ const [{ composer }, { width, height }] = [this.composerData(), this.size()];
111
+ if (composer) {
112
+ composer.setSize(width, height);
113
+ }
114
+ });
115
+ }
116
+ updatePasses() {
117
+ this.autoEffect(() => {
118
+ const [group, { composer, normalPass, downSamplingPass }, camera] = [
119
+ this.groupRef(),
120
+ this.composerData(),
121
+ this.camera(),
122
+ ];
123
+ const passes = [];
124
+ if (group.nativeElement && composer) {
125
+ const localState = getLocalState(group.nativeElement);
126
+ if (!localState)
127
+ return;
128
+ const children = localState.nonObjects();
129
+ for (let i = 0; i < children.length; i++) {
130
+ const child = children[i];
131
+ if (child instanceof Effect) {
132
+ const effects = [child];
133
+ if (!isConvolution(child)) {
134
+ let next = null;
135
+ while ((next = children[i + 1]) instanceof Effect) {
136
+ if (isConvolution(next))
137
+ break;
138
+ effects.push(next);
139
+ i++;
140
+ }
141
+ }
142
+ const pass = new EffectPass(camera, ...effects);
143
+ passes.push(pass);
144
+ }
145
+ else if (child instanceof Pass) {
146
+ passes.push(child);
147
+ }
148
+ }
149
+ for (const pass of passes) {
150
+ composer.addPass(pass);
151
+ }
152
+ if (normalPass)
153
+ normalPass.enabled = true;
154
+ if (downSamplingPass)
155
+ downSamplingPass.enabled = true;
156
+ }
157
+ return () => {
158
+ for (const pass of passes)
159
+ composer?.removePass(pass);
160
+ if (normalPass)
161
+ normalPass.enabled = false;
162
+ if (downSamplingPass)
163
+ downSamplingPass.enabled = false;
164
+ };
165
+ });
166
+ }
167
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.3", ngImport: i0, type: NgtpEffectComposer, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
168
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.2.0", version: "18.1.3", type: NgtpEffectComposer, isStandalone: true, selector: "ngtp-effect-composer", inputs: { options: { classPropertyName: "options", publicName: "options", isSignal: true, isRequired: false, transformFunction: null } }, viewQueries: [{ propertyName: "groupRef", first: true, predicate: ["group"], descendants: true, isSignal: true }], ngImport: i0, template: `
169
+ <ngt-group #group>
170
+ <ng-content />
171
+ </ngt-group>
172
+ `, isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
173
+ }
174
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.3", ngImport: i0, type: NgtpEffectComposer, decorators: [{
175
+ type: Component,
176
+ args: [{
177
+ selector: 'ngtp-effect-composer',
178
+ standalone: true,
179
+ template: `
180
+ <ngt-group #group>
181
+ <ng-content />
182
+ </ngt-group>
183
+ `,
184
+ schemas: [CUSTOM_ELEMENTS_SCHEMA],
185
+ changeDetection: ChangeDetectionStrategy.OnPush,
186
+ }]
187
+ }], ctorParameters: () => [] });
188
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"effect-composer.js","sourceRoot":"","sources":["../../../../../libs/postprocessing/src/lib/effect-composer.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n\tCUSTOM_ELEMENTS_SCHEMA,\n\tChangeDetectionStrategy,\n\tComponent,\n\tElementRef,\n\tInjector,\n\tafterNextRender,\n\tcomputed,\n\tinject,\n\tinput,\n\tviewChild,\n} from '@angular/core';\nimport { extend, getLocalState, injectBeforeRender, injectStore, pick } from 'angular-three';\nimport { injectAutoEffect } from 'ngxtension/auto-effect';\nimport { mergeInputs } from 'ngxtension/inject-inputs';\nimport {\n\tDepthDownsamplingPass,\n\tEffect,\n\tEffectAttribute,\n\tEffectComposer,\n\tEffectPass,\n\tNormalPass,\n\tPass,\n\tRenderPass,\n} from 'postprocessing';\nimport { Camera, Group, HalfFloatType, NoToneMapping, Scene, TextureDataType } from 'three';\nimport { isWebGL2Available } from 'three-stdlib';\n\nexport interface NgtpEffectComposerOptions {\n\tenabled: boolean;\n\tdepthBuffer?: boolean;\n\t/** Only used for SSGI currently, leave it disabled for everything else unless it's needed */\n\tenableNormalPass?: boolean;\n\tstencilBuffer?: boolean;\n\tautoClear: boolean;\n\tresolutionScale?: number;\n\tmultisampling: number;\n\tframeBufferType: TextureDataType;\n\trenderPriority: number;\n\tcamera?: Camera;\n\tscene?: Scene;\n}\n\nconst defaultOptions: NgtpEffectComposerOptions = {\n\tenabled: true,\n\trenderPriority: 1,\n\tautoClear: true,\n\tmultisampling: 8,\n\tframeBufferType: HalfFloatType,\n};\n\nfunction isConvolution(effect: Effect) {\n\treturn (effect.getAttributes() & EffectAttribute.CONVOLUTION) === EffectAttribute.CONVOLUTION;\n}\n\n@Component({\n\tselector: 'ngtp-effect-composer',\n\tstandalone: true,\n\ttemplate: `\n\t\t<ngt-group #group>\n\t\t\t<ng-content />\n\t\t</ngt-group>\n\t`,\n\tschemas: [CUSTOM_ELEMENTS_SCHEMA],\n\tchangeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class NgtpEffectComposer {\n\toptions = input(defaultOptions, { transform: mergeInputs(defaultOptions) });\n\n\tprivate injector = inject(Injector);\n\tprivate autoEffect = injectAutoEffect();\n\tprivate store = injectStore();\n\tprivate size = this.store.select('size');\n\tprivate gl = this.store.select('gl');\n\tprivate defaultScene = this.store.select('scene');\n\tprivate defaultCamera = this.store.select('camera');\n\n\tdepthBuffer = pick(this.options, 'depthBuffer');\n\tstencilBuffer = pick(this.options, 'stencilBuffer');\n\tmultisampling = pick(this.options, 'multisampling');\n\tframeBufferType = pick(this.options, 'frameBufferType');\n\tscene = computed(() => this.options().scene ?? this.defaultScene());\n\tcamera = computed(() => this.options().camera ?? this.defaultCamera());\n\tenableNormalPass = pick(this.options, 'enableNormalPass');\n\tresolutionScale = pick(this.options, 'resolutionScale');\n\n\tgroupRef = viewChild.required<ElementRef<Group>>('group');\n\n\tcomposerData = computed(() => {\n\t\tconst webGL2Available = isWebGL2Available();\n\t\tconst [\n\t\t\tgl,\n\t\t\tscene,\n\t\t\tcamera,\n\t\t\tdepthBuffer,\n\t\t\tstencilBuffer,\n\t\t\tmultisampling,\n\t\t\tframeBufferType,\n\t\t\tenableNormalPass,\n\t\t\tresolutionScale,\n\t\t] = [\n\t\t\tthis.gl(),\n\t\t\tthis.scene(),\n\t\t\tthis.camera(),\n\t\t\tthis.depthBuffer(),\n\t\t\tthis.stencilBuffer(),\n\t\t\tthis.multisampling(),\n\t\t\tthis.frameBufferType(),\n\t\t\tthis.enableNormalPass(),\n\t\t\tthis.resolutionScale(),\n\t\t];\n\n\t\t// initialize composer\n\t\tconst composer = new EffectComposer(gl, {\n\t\t\tdepthBuffer,\n\t\t\tstencilBuffer,\n\t\t\tmultisampling: multisampling > 0 && webGL2Available ? multisampling : 0,\n\t\t\tframeBufferType,\n\t\t});\n\n\t\t// add render pass\n\t\tcomposer.addPass(new RenderPass(scene, camera));\n\n\t\t// create normal pass\n\t\tlet downSamplingPass = null;\n\t\tlet normalPass = null;\n\t\tif (enableNormalPass) {\n\t\t\tnormalPass = new NormalPass(scene, camera);\n\t\t\tnormalPass.enabled = false;\n\t\t\tcomposer.addPass(normalPass);\n\t\t\tif (resolutionScale !== undefined && webGL2Available) {\n\t\t\t\tdownSamplingPass = new DepthDownsamplingPass({ normalBuffer: normalPass.texture, resolutionScale });\n\t\t\t\tdownSamplingPass.enabled = false;\n\t\t\t\tcomposer.addPass(downSamplingPass);\n\t\t\t}\n\t\t}\n\n\t\treturn { composer, normalPass, downSamplingPass };\n\t});\n\n\tconstructor() {\n\t\textend({ Group });\n\n\t\tafterNextRender(() => {\n\t\t\tthis.disableToneMapping();\n\t\t\tthis.setComposerSize();\n\t\t\tthis.updatePasses();\n\n\t\t\tinjectBeforeRender(\n\t\t\t\t({ delta }) => {\n\t\t\t\t\tconst [{ composer }, { enabled, autoClear, stencilBuffer }, gl] = [\n\t\t\t\t\t\tthis.composerData(),\n\t\t\t\t\t\tthis.options(),\n\t\t\t\t\t\tthis.gl(),\n\t\t\t\t\t];\n\n\t\t\t\t\tif (enabled) {\n\t\t\t\t\t\tconst currentAutoClear = gl.autoClear;\n\t\t\t\t\t\tgl.autoClear = autoClear;\n\t\t\t\t\t\tif (stencilBuffer && !autoClear) gl.clearStencil();\n\t\t\t\t\t\tcomposer.render(delta);\n\t\t\t\t\t\tgl.autoClear = currentAutoClear;\n\t\t\t\t\t}\n\t\t\t\t},\n\t\t\t\t{ injector: this.injector, priority: this.options().enabled ? this.options().renderPriority : 0 },\n\t\t\t);\n\t\t});\n\t}\n\n\t// NOTE: Disable tone mapping because threejs disallows tonemapping on render targets\n\tprivate disableToneMapping() {\n\t\tthis.autoEffect(() => {\n\t\t\tconst gl = this.gl();\n\t\t\tconst currentTonemapping = gl.toneMapping;\n\t\t\tgl.toneMapping = NoToneMapping;\n\t\t\treturn () => {\n\t\t\t\tgl.toneMapping = currentTonemapping;\n\t\t\t};\n\t\t});\n\t}\n\n\tprivate setComposerSize() {\n\t\tthis.autoEffect(() => {\n\t\t\tconst [{ composer }, { width, height }] = [this.composerData(), this.size()];\n\t\t\tif (composer) {\n\t\t\t\tcomposer.setSize(width, height);\n\t\t\t}\n\t\t});\n\t}\n\n\tprivate updatePasses() {\n\t\tthis.autoEffect(() => {\n\t\t\tconst [group, { composer, normalPass, downSamplingPass }, camera] = [\n\t\t\t\tthis.groupRef(),\n\t\t\t\tthis.composerData(),\n\t\t\t\tthis.camera(),\n\t\t\t];\n\n\t\t\tconst passes: Pass[] = [];\n\n\t\t\tif (group.nativeElement && composer) {\n\t\t\t\tconst localState = getLocalState(group.nativeElement);\n\t\t\t\tif (!localState) return;\n\n\t\t\t\tconst children = localState.nonObjects();\n\t\t\t\tfor (let i = 0; i < children.length; i++) {\n\t\t\t\t\tconst child = children[i];\n\t\t\t\t\tif (child instanceof Effect) {\n\t\t\t\t\t\tconst effects: Effect[] = [child];\n\n\t\t\t\t\t\tif (!isConvolution(child)) {\n\t\t\t\t\t\t\tlet next: unknown = null;\n\t\t\t\t\t\t\twhile ((next = children[i + 1]) instanceof Effect) {\n\t\t\t\t\t\t\t\tif (isConvolution(next)) break;\n\t\t\t\t\t\t\t\teffects.push(next as Effect);\n\t\t\t\t\t\t\t\ti++;\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tconst pass = new EffectPass(camera, ...effects);\n\t\t\t\t\t\tpasses.push(pass);\n\t\t\t\t\t} else if (child instanceof Pass) {\n\t\t\t\t\t\tpasses.push(child);\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tfor (const pass of passes) {\n\t\t\t\t\tcomposer.addPass(pass);\n\t\t\t\t}\n\n\t\t\t\tif (normalPass) normalPass.enabled = true;\n\t\t\t\tif (downSamplingPass) downSamplingPass.enabled = true;\n\t\t\t}\n\n\t\t\treturn () => {\n\t\t\t\tfor (const pass of passes) composer?.removePass(pass);\n\t\t\t\tif (normalPass) normalPass.enabled = false;\n\t\t\t\tif (downSamplingPass) downSamplingPass.enabled = false;\n\t\t\t};\n\t\t});\n\t}\n}\n"]}
@@ -0,0 +1,50 @@
1
+ import { CUSTOM_ELEMENTS_SCHEMA, ChangeDetectionStrategy, Component, Directive, inject, input } from '@angular/core';
2
+ import { injectStore } from 'angular-three';
3
+ import { createNoopInjectionToken } from 'ngxtension/create-injection-token';
4
+ import * as i0 from "@angular/core";
5
+ export const [injectDefaultEffectOptions, provideDefaultEffectOptions] = createNoopInjectionToken('Default Effect options');
6
+ export class NgtpEffectBlendMode {
7
+ constructor() {
8
+ this.effect = inject(NgtpEffect, { optional: true });
9
+ }
10
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.3", ngImport: i0, type: NgtpEffectBlendMode, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
11
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.1.3", type: NgtpEffectBlendMode, isStandalone: true, selector: "ngtp-effect-blend-mode", ngImport: i0, template: `
12
+ @if (effect) {
13
+ <ngt-value [rawValue]="effect.blendFunction()" attach="blendMode.blendFunction" />
14
+ <ngt-value [rawValue]="effect.opacity()" attach="blendMode.opacity.value" />
15
+ }
16
+ `, isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
17
+ }
18
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.3", ngImport: i0, type: NgtpEffectBlendMode, decorators: [{
19
+ type: Component,
20
+ args: [{
21
+ selector: 'ngtp-effect-blend-mode',
22
+ standalone: true,
23
+ template: `
24
+ @if (effect) {
25
+ <ngt-value [rawValue]="effect.blendFunction()" attach="blendMode.blendFunction" />
26
+ <ngt-value [rawValue]="effect.opacity()" attach="blendMode.opacity.value" />
27
+ }
28
+ `,
29
+ schemas: [CUSTOM_ELEMENTS_SCHEMA],
30
+ changeDetection: ChangeDetectionStrategy.OnPush,
31
+ }]
32
+ }] });
33
+ export class NgtpEffect {
34
+ constructor() {
35
+ this.defaultEffectOptions = injectDefaultEffectOptions({ optional: true });
36
+ this.blendFunction = input(this.defaultEffectOptions?.blendFunction);
37
+ this.opacity = input(this.defaultEffectOptions?.opacity);
38
+ this.store = injectStore();
39
+ this.camera = this.store.select('camera');
40
+ this.invalidate = this.store.select('invalidate');
41
+ }
42
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.3", ngImport: i0, type: NgtpEffect, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
43
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "18.1.3", type: NgtpEffect, isStandalone: true, inputs: { blendFunction: { classPropertyName: "blendFunction", publicName: "blendFunction", isSignal: true, isRequired: false, transformFunction: null }, opacity: { classPropertyName: "opacity", publicName: "opacity", isSignal: true, isRequired: false, transformFunction: null } }, ngImport: i0 }); }
44
+ }
45
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.3", ngImport: i0, type: NgtpEffect, decorators: [{
46
+ type: Directive,
47
+ args: [{ standalone: true }]
48
+ }] });
49
+ export const NgtpEffectHostDirective = { directive: NgtpEffect, inputs: ['blendFunction', 'opacity'] };
50
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWZmZWN0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vbGlicy9wb3N0cHJvY2Vzc2luZy9zcmMvbGliL2VmZmVjdC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLFNBQVMsRUFBRSxNQUFNLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3JILE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDNUMsT0FBTyxFQUFFLHdCQUF3QixFQUFFLE1BQU0sbUNBQW1DLENBQUM7O0FBRzdFLE1BQU0sQ0FBQyxNQUFNLENBQUMsMEJBQTBCLEVBQUUsMkJBQTJCLENBQUMsR0FBRyx3QkFBd0IsQ0FHOUYsd0JBQXdCLENBQUMsQ0FBQztBQWM3QixNQUFNLE9BQU8sbUJBQW1CO0lBWmhDO1FBYUMsV0FBTSxHQUFHLE1BQU0sQ0FBQyxVQUFVLEVBQUUsRUFBRSxRQUFRLEVBQUUsSUFBSSxFQUFFLENBQUMsQ0FBQztLQUNoRDs4R0FGWSxtQkFBbUI7a0dBQW5CLG1CQUFtQixrRkFUckI7Ozs7O0VBS1Q7OzJGQUlXLG1CQUFtQjtrQkFaL0IsU0FBUzttQkFBQztvQkFDVixRQUFRLEVBQUUsd0JBQXdCO29CQUNsQyxVQUFVLEVBQUUsSUFBSTtvQkFDaEIsUUFBUSxFQUFFOzs7OztFQUtUO29CQUNELE9BQU8sRUFBRSxDQUFDLHNCQUFzQixDQUFDO29CQUNqQyxlQUFlLEVBQUUsdUJBQXVCLENBQUMsTUFBTTtpQkFDL0M7O0FBTUQsTUFBTSxPQUFPLFVBQVU7SUFEdkI7UUFFQyx5QkFBb0IsR0FBRywwQkFBMEIsQ0FBQyxFQUFFLFFBQVEsRUFBRSxJQUFJLEVBQUUsQ0FBQyxDQUFDO1FBRXRFLGtCQUFhLEdBQUcsS0FBSyxDQUFDLElBQUksQ0FBQyxvQkFBb0IsRUFBRSxhQUFhLENBQUMsQ0FBQztRQUNoRSxZQUFPLEdBQUcsS0FBSyxDQUFDLElBQUksQ0FBQyxvQkFBb0IsRUFBRSxPQUFPLENBQUMsQ0FBQztRQUU1QyxVQUFLLEdBQUcsV0FBVyxFQUFFLENBQUM7UUFDOUIsV0FBTSxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsTUFBTSxDQUFDLFFBQVEsQ0FBQyxDQUFDO1FBQ3JDLGVBQVUsR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLE1BQU0sQ0FBQyxZQUFZLENBQUMsQ0FBQztLQUM3Qzs4R0FUWSxVQUFVO2tHQUFWLFVBQVU7OzJGQUFWLFVBQVU7a0JBRHRCLFNBQVM7bUJBQUMsRUFBRSxVQUFVLEVBQUUsSUFBSSxFQUFFOztBQVkvQixNQUFNLENBQUMsTUFBTSx1QkFBdUIsR0FBRyxFQUFFLFNBQVMsRUFBRSxVQUFVLEVBQUUsTUFBTSxFQUFFLENBQUMsZUFBZSxFQUFFLFNBQVMsQ0FBQyxFQUFFLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDVVNUT01fRUxFTUVOVFNfU0NIRU1BLCBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBEaXJlY3RpdmUsIGluamVjdCwgaW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IGluamVjdFN0b3JlIH0gZnJvbSAnYW5ndWxhci10aHJlZSc7XG5pbXBvcnQgeyBjcmVhdGVOb29wSW5qZWN0aW9uVG9rZW4gfSBmcm9tICduZ3h0ZW5zaW9uL2NyZWF0ZS1pbmplY3Rpb24tdG9rZW4nO1xuaW1wb3J0IHsgQmxlbmRGdW5jdGlvbiB9IGZyb20gJ3Bvc3Rwcm9jZXNzaW5nJztcblxuZXhwb3J0IGNvbnN0IFtpbmplY3REZWZhdWx0RWZmZWN0T3B0aW9ucywgcHJvdmlkZURlZmF1bHRFZmZlY3RPcHRpb25zXSA9IGNyZWF0ZU5vb3BJbmplY3Rpb25Ub2tlbjx7XG5cdGJsZW5kRnVuY3Rpb24/OiBCbGVuZEZ1bmN0aW9uO1xuXHRvcGFjaXR5PzogbnVtYmVyO1xufT4oJ0RlZmF1bHQgRWZmZWN0IG9wdGlvbnMnKTtcblxuQENvbXBvbmVudCh7XG5cdHNlbGVjdG9yOiAnbmd0cC1lZmZlY3QtYmxlbmQtbW9kZScsXG5cdHN0YW5kYWxvbmU6IHRydWUsXG5cdHRlbXBsYXRlOiBgXG5cdFx0QGlmIChlZmZlY3QpIHtcblx0XHRcdDxuZ3QtdmFsdWUgW3Jhd1ZhbHVlXT1cImVmZmVjdC5ibGVuZEZ1bmN0aW9uKClcIiBhdHRhY2g9XCJibGVuZE1vZGUuYmxlbmRGdW5jdGlvblwiIC8+XG5cdFx0XHQ8bmd0LXZhbHVlIFtyYXdWYWx1ZV09XCJlZmZlY3Qub3BhY2l0eSgpXCIgYXR0YWNoPVwiYmxlbmRNb2RlLm9wYWNpdHkudmFsdWVcIiAvPlxuXHRcdH1cblx0YCxcblx0c2NoZW1hczogW0NVU1RPTV9FTEVNRU5UU19TQ0hFTUFdLFxuXHRjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbn0pXG5leHBvcnQgY2xhc3MgTmd0cEVmZmVjdEJsZW5kTW9kZSB7XG5cdGVmZmVjdCA9IGluamVjdChOZ3RwRWZmZWN0LCB7IG9wdGlvbmFsOiB0cnVlIH0pO1xufVxuXG5ARGlyZWN0aXZlKHsgc3RhbmRhbG9uZTogdHJ1ZSB9KVxuZXhwb3J0IGNsYXNzIE5ndHBFZmZlY3Qge1xuXHRkZWZhdWx0RWZmZWN0T3B0aW9ucyA9IGluamVjdERlZmF1bHRFZmZlY3RPcHRpb25zKHsgb3B0aW9uYWw6IHRydWUgfSk7XG5cblx0YmxlbmRGdW5jdGlvbiA9IGlucHV0KHRoaXMuZGVmYXVsdEVmZmVjdE9wdGlvbnM/LmJsZW5kRnVuY3Rpb24pO1xuXHRvcGFjaXR5ID0gaW5wdXQodGhpcy5kZWZhdWx0RWZmZWN0T3B0aW9ucz8ub3BhY2l0eSk7XG5cblx0cHJpdmF0ZSBzdG9yZSA9IGluamVjdFN0b3JlKCk7XG5cdGNhbWVyYSA9IHRoaXMuc3RvcmUuc2VsZWN0KCdjYW1lcmEnKTtcblx0aW52YWxpZGF0ZSA9IHRoaXMuc3RvcmUuc2VsZWN0KCdpbnZhbGlkYXRlJyk7XG59XG5cbmV4cG9ydCBjb25zdCBOZ3RwRWZmZWN0SG9zdERpcmVjdGl2ZSA9IHsgZGlyZWN0aXZlOiBOZ3RwRWZmZWN0LCBpbnB1dHM6IFsnYmxlbmRGdW5jdGlvbicsICdvcGFjaXR5J10gfTtcbiJdfQ==
@@ -0,0 +1,120 @@
1
+ import { CUSTOM_ELEMENTS_SCHEMA, ChangeDetectionStrategy, Component, computed, input } from '@angular/core';
2
+ import { NgtArgs } from 'angular-three';
3
+ import { mergeInputs } from 'ngxtension/inject-inputs';
4
+ import { Effect } from 'postprocessing';
5
+ import { CanvasTexture, Color, NearestFilter, RepeatWrapping, Texture, Uniform } from 'three';
6
+ import * as i0 from "@angular/core";
7
+ const fragment = `
8
+ uniform sampler2D uCharacters;
9
+ uniform float uCharactersCount;
10
+ uniform float uCellSize;
11
+ uniform bool uInvert;
12
+ uniform vec3 uColor;
13
+
14
+ const vec2 SIZE = vec2(16.);
15
+
16
+ vec3 greyscale(vec3 color, float strength) {
17
+ float g = dot(color, vec3(0.299, 0.587, 0.114));
18
+ return mix(color, vec3(g), strength);
19
+ }
20
+
21
+ vec3 greyscale(vec3 color) {
22
+ return greyscale(color, 1.0);
23
+ }
24
+
25
+ void mainImage(const in vec4 inputColor, const in vec2 uv, out vec4 outputColor) {
26
+ vec2 cell = resolution / uCellSize;
27
+ vec2 grid = 1.0 / cell;
28
+ vec2 pixelizedUV = grid * (0.5 + floor(uv / grid));
29
+ vec4 pixelized = texture2D(inputBuffer, pixelizedUV);
30
+ float greyscaled = greyscale(pixelized.rgb).r;
31
+
32
+ if (uInvert) {
33
+ greyscaled = 1.0 - greyscaled;
34
+ }
35
+
36
+ float characterIndex = floor((uCharactersCount - 1.0) * greyscaled);
37
+ vec2 characterPosition = vec2(mod(characterIndex, SIZE.x), floor(characterIndex / SIZE.y));
38
+ vec2 offset = vec2(characterPosition.x, -characterPosition.y) / SIZE;
39
+ vec2 charUV = mod(uv * (cell / SIZE), 1.0 / SIZE) - vec2(0., 1.0 / SIZE) + offset;
40
+ vec4 asciiCharacter = texture2D(uCharacters, charUV);
41
+
42
+ asciiCharacter.rgb = uColor * asciiCharacter.r;
43
+ asciiCharacter.a = pixelized.a;
44
+ outputColor = asciiCharacter;
45
+ }
46
+ `;
47
+ export class ASCIIEffect extends Effect {
48
+ constructor({ font = 'arial', characters = ` .:,'-^=*+?!|0#X%WM@`, fontSize = 54, cellSize = 16, color = '#ffffff', invert = false, } = {}) {
49
+ const uniforms = new Map([
50
+ ['uCharacters', new Uniform(new Texture())],
51
+ ['uCellSize', new Uniform(cellSize)],
52
+ ['uCharactersCount', new Uniform(characters.length)],
53
+ ['uColor', new Uniform(new Color(color))],
54
+ ['uInvert', new Uniform(invert)],
55
+ ]);
56
+ super('ASCIIEffect', fragment, { uniforms });
57
+ const charactersTextureUniform = this.uniforms.get('uCharacters');
58
+ if (charactersTextureUniform) {
59
+ charactersTextureUniform.value = this.createCharactersTexture(characters, font, fontSize);
60
+ }
61
+ }
62
+ /** Draws the characters on a Canvas and returns a texture */
63
+ createCharactersTexture(characters, font, fontSize) {
64
+ const canvas = document.createElement('canvas');
65
+ const SIZE = 1024;
66
+ const MAX_PER_ROW = 16;
67
+ const CELL = SIZE / MAX_PER_ROW;
68
+ canvas.width = canvas.height = SIZE;
69
+ const texture = new CanvasTexture(canvas, undefined, RepeatWrapping, RepeatWrapping, NearestFilter, NearestFilter);
70
+ const context = canvas.getContext('2d');
71
+ if (!context) {
72
+ throw new Error('Context not available');
73
+ }
74
+ context.clearRect(0, 0, SIZE, SIZE);
75
+ context.font = `${fontSize}px ${font}`;
76
+ context.textAlign = 'center';
77
+ context.textBaseline = 'middle';
78
+ context.fillStyle = '#fff';
79
+ for (let i = 0; i < characters.length; i++) {
80
+ const char = characters[i];
81
+ const x = i % MAX_PER_ROW;
82
+ const y = Math.floor(i / MAX_PER_ROW);
83
+ context.fillText(char, x * CELL + CELL / 2, y * CELL + CELL / 2);
84
+ }
85
+ texture.needsUpdate = true;
86
+ return texture;
87
+ }
88
+ }
89
+ const defaultOptions = {
90
+ font: 'arial',
91
+ characters: ` .:,'-^=*+?!|0#X%WM@`,
92
+ fontSize: 54,
93
+ cellSize: 16,
94
+ color: '#ffffff',
95
+ invert: false,
96
+ };
97
+ export class NgtpASCII {
98
+ constructor() {
99
+ this.options = input(defaultOptions, { transform: mergeInputs(defaultOptions) });
100
+ this.effect = computed(() => new ASCIIEffect(this.options()));
101
+ }
102
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.3", ngImport: i0, type: NgtpASCII, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
103
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.1.3", type: NgtpASCII, isStandalone: true, selector: "ngtp-ascii", inputs: { options: { classPropertyName: "options", publicName: "options", isSignal: true, isRequired: false, transformFunction: null } }, ngImport: i0, template: `
104
+ <ngt-primitive *args="[effect()]" />
105
+ `, isInline: true, dependencies: [{ kind: "directive", type: NgtArgs, selector: "ng-template[args]", inputs: ["args"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
106
+ }
107
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.3", ngImport: i0, type: NgtpASCII, decorators: [{
108
+ type: Component,
109
+ args: [{
110
+ selector: 'ngtp-ascii',
111
+ standalone: true,
112
+ template: `
113
+ <ngt-primitive *args="[effect()]" />
114
+ `,
115
+ imports: [NgtArgs],
116
+ schemas: [CUSTOM_ELEMENTS_SCHEMA],
117
+ changeDetection: ChangeDetectionStrategy.OnPush,
118
+ }]
119
+ }] });
120
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ascii.js","sourceRoot":"","sources":["../../../../../../libs/postprocessing/src/lib/effects/ascii.ts"],"names":[],"mappings":"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","sourcesContent":["import { CUSTOM_ELEMENTS_SCHEMA, ChangeDetectionStrategy, Component, computed, input } from '@angular/core';\nimport { NgtArgs } from 'angular-three';\nimport { mergeInputs } from 'ngxtension/inject-inputs';\nimport { Effect } from 'postprocessing';\nimport { CanvasTexture, Color, NearestFilter, RepeatWrapping, Texture, Uniform } from 'three';\n\nconst fragment = `\nuniform sampler2D uCharacters;\nuniform float uCharactersCount;\nuniform float uCellSize;\nuniform bool uInvert;\nuniform vec3 uColor;\n\nconst vec2 SIZE = vec2(16.);\n\nvec3 greyscale(vec3 color, float strength) {\n    float g = dot(color, vec3(0.299, 0.587, 0.114));\n    return mix(color, vec3(g), strength);\n}\n\nvec3 greyscale(vec3 color) {\n    return greyscale(color, 1.0);\n}\n\nvoid mainImage(const in vec4 inputColor, const in vec2 uv, out vec4 outputColor) {\n    vec2 cell = resolution / uCellSize;\n    vec2 grid = 1.0 / cell;\n    vec2 pixelizedUV = grid * (0.5 + floor(uv / grid));\n    vec4 pixelized = texture2D(inputBuffer, pixelizedUV);\n    float greyscaled = greyscale(pixelized.rgb).r;\n\n    if (uInvert) {\n        greyscaled = 1.0 - greyscaled;\n    }\n\n    float characterIndex = floor((uCharactersCount - 1.0) * greyscaled);\n    vec2 characterPosition = vec2(mod(characterIndex, SIZE.x), floor(characterIndex / SIZE.y));\n    vec2 offset = vec2(characterPosition.x, -characterPosition.y) / SIZE;\n    vec2 charUV = mod(uv * (cell / SIZE), 1.0 / SIZE) - vec2(0., 1.0 / SIZE) + offset;\n    vec4 asciiCharacter = texture2D(uCharacters, charUV);\n\n    asciiCharacter.rgb = uColor * asciiCharacter.r;\n    asciiCharacter.a = pixelized.a;\n    outputColor = asciiCharacter;\n}\n`;\n\ninterface ASCIIEffectOptions {\n\tfont?: string;\n\tcharacters?: string;\n\tfontSize?: number;\n\tcellSize?: number;\n\tcolor?: string;\n\tinvert?: boolean;\n}\n\nexport class ASCIIEffect extends Effect {\n\tconstructor({\n\t\tfont = 'arial',\n\t\tcharacters = ` .:,'-^=*+?!|0#X%WM@`,\n\t\tfontSize = 54,\n\t\tcellSize = 16,\n\t\tcolor = '#ffffff',\n\t\tinvert = false,\n\t}: ASCIIEffectOptions = {}) {\n\t\tconst uniforms = new Map<string, Uniform>([\n\t\t\t['uCharacters', new Uniform(new Texture())],\n\t\t\t['uCellSize', new Uniform(cellSize)],\n\t\t\t['uCharactersCount', new Uniform(characters.length)],\n\t\t\t['uColor', new Uniform(new Color(color))],\n\t\t\t['uInvert', new Uniform(invert)],\n\t\t]);\n\n\t\tsuper('ASCIIEffect', fragment, { uniforms });\n\n\t\tconst charactersTextureUniform = this.uniforms.get('uCharacters');\n\n\t\tif (charactersTextureUniform) {\n\t\t\tcharactersTextureUniform.value = this.createCharactersTexture(characters, font, fontSize);\n\t\t}\n\t}\n\n\t/** Draws the characters on a Canvas and returns a texture */\n\tpublic createCharactersTexture(characters: string, font: string, fontSize: number): Texture {\n\t\tconst canvas = document.createElement('canvas');\n\t\tconst SIZE = 1024;\n\t\tconst MAX_PER_ROW = 16;\n\t\tconst CELL = SIZE / MAX_PER_ROW;\n\n\t\tcanvas.width = canvas.height = SIZE;\n\t\tconst texture = new CanvasTexture(canvas, undefined, RepeatWrapping, RepeatWrapping, NearestFilter, NearestFilter);\n\t\tconst context = canvas.getContext('2d');\n\n\t\tif (!context) {\n\t\t\tthrow new Error('Context not available');\n\t\t}\n\n\t\tcontext.clearRect(0, 0, SIZE, SIZE);\n\t\tcontext.font = `${fontSize}px ${font}`;\n\t\tcontext.textAlign = 'center';\n\t\tcontext.textBaseline = 'middle';\n\t\tcontext.fillStyle = '#fff';\n\n\t\tfor (let i = 0; i < characters.length; i++) {\n\t\t\tconst char = characters[i];\n\t\t\tconst x = i % MAX_PER_ROW;\n\t\t\tconst y = Math.floor(i / MAX_PER_ROW);\n\t\t\tcontext.fillText(char, x * CELL + CELL / 2, y * CELL + CELL / 2);\n\t\t}\n\n\t\ttexture.needsUpdate = true;\n\t\treturn texture;\n\t}\n}\n\nconst defaultOptions: ASCIIEffectOptions = {\n\tfont: 'arial',\n\tcharacters: ` .:,'-^=*+?!|0#X%WM@`,\n\tfontSize: 54,\n\tcellSize: 16,\n\tcolor: '#ffffff',\n\tinvert: false,\n};\n\n@Component({\n\tselector: 'ngtp-ascii',\n\tstandalone: true,\n\ttemplate: `\n\t\t<ngt-primitive *args=\"[effect()]\" />\n\t`,\n\timports: [NgtArgs],\n\tschemas: [CUSTOM_ELEMENTS_SCHEMA],\n\tchangeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class NgtpASCII {\n\toptions = input(defaultOptions, { transform: mergeInputs(defaultOptions) });\n\teffect = computed(() => new ASCIIEffect(this.options()));\n}\n"]}
@@ -0,0 +1,39 @@
1
+ import { CUSTOM_ELEMENTS_SCHEMA, ChangeDetectionStrategy, Component, inject, input } from '@angular/core';
2
+ import { NgtArgs, extend } from 'angular-three';
3
+ import { BlendFunction, BloomEffect } from 'postprocessing';
4
+ import { NgtpEffect, NgtpEffectBlendMode, NgtpEffectHostDirective, provideDefaultEffectOptions } from '../effect';
5
+ import * as i0 from "@angular/core";
6
+ import * as i1 from "../effect";
7
+ extend({ BloomEffect });
8
+ export class NgtpBloom {
9
+ constructor() {
10
+ this.effect = inject(NgtpEffect, { host: true });
11
+ this.options = input({});
12
+ }
13
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.3", ngImport: i0, type: NgtpBloom, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
14
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.1.3", type: NgtpBloom, isStandalone: true, selector: "ngtp-bloom", inputs: { options: { classPropertyName: "options", publicName: "options", isSignal: true, isRequired: false, transformFunction: null } }, providers: [provideDefaultEffectOptions({ blendFunction: BlendFunction.ADD })], hostDirectives: [{ directive: i1.NgtpEffect, inputs: ["blendFunction", "blendFunction", "opacity", "opacity"] }], ngImport: i0, template: `
15
+ <ngt-bloom-effect *args="[options()]" [camera]="effect.camera()">
16
+ <ngtp-effect-blend-mode />
17
+ <ng-content />
18
+ </ngt-bloom-effect>
19
+ `, isInline: true, dependencies: [{ kind: "directive", type: NgtArgs, selector: "ng-template[args]", inputs: ["args"] }, { kind: "component", type: NgtpEffectBlendMode, selector: "ngtp-effect-blend-mode" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
20
+ }
21
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.3", ngImport: i0, type: NgtpBloom, decorators: [{
22
+ type: Component,
23
+ args: [{
24
+ selector: 'ngtp-bloom',
25
+ standalone: true,
26
+ template: `
27
+ <ngt-bloom-effect *args="[options()]" [camera]="effect.camera()">
28
+ <ngtp-effect-blend-mode />
29
+ <ng-content />
30
+ </ngt-bloom-effect>
31
+ `,
32
+ imports: [NgtArgs, NgtpEffectBlendMode],
33
+ schemas: [CUSTOM_ELEMENTS_SCHEMA],
34
+ changeDetection: ChangeDetectionStrategy.OnPush,
35
+ hostDirectives: [NgtpEffectHostDirective],
36
+ providers: [provideDefaultEffectOptions({ blendFunction: BlendFunction.ADD })],
37
+ }]
38
+ }] });
39
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmxvb20uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL3Bvc3Rwcm9jZXNzaW5nL3NyYy9saWIvZWZmZWN0cy9ibG9vbS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLE1BQU0sRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDMUcsT0FBTyxFQUFFLE9BQU8sRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDaEQsT0FBTyxFQUFFLGFBQWEsRUFBRSxXQUFXLEVBQXNCLE1BQU0sZ0JBQWdCLENBQUM7QUFDaEYsT0FBTyxFQUFFLFVBQVUsRUFBRSxtQkFBbUIsRUFBRSx1QkFBdUIsRUFBRSwyQkFBMkIsRUFBRSxNQUFNLFdBQVcsQ0FBQzs7O0FBRWxILE1BQU0sQ0FBQyxFQUFFLFdBQVcsRUFBRSxDQUFDLENBQUM7QUFpQnhCLE1BQU0sT0FBTyxTQUFTO0lBZnRCO1FBZ0JDLFdBQU0sR0FBRyxNQUFNLENBQUMsVUFBVSxFQUFFLEVBQUUsSUFBSSxFQUFFLElBQUksRUFBRSxDQUFDLENBQUM7UUFDNUMsWUFBTyxHQUFHLEtBQUssQ0FBQyxFQUErQyxDQUFDLENBQUM7S0FDakU7OEdBSFksU0FBUztrR0FBVCxTQUFTLG1NQUZWLENBQUMsMkJBQTJCLENBQUMsRUFBRSxhQUFhLEVBQUUsYUFBYSxDQUFDLEdBQUcsRUFBRSxDQUFDLENBQUMsNElBVnBFOzs7OztFQUtULDREQUNTLE9BQU8sZ0ZBQUUsbUJBQW1COzsyRkFNMUIsU0FBUztrQkFmckIsU0FBUzttQkFBQztvQkFDVixRQUFRLEVBQUUsWUFBWTtvQkFDdEIsVUFBVSxFQUFFLElBQUk7b0JBQ2hCLFFBQVEsRUFBRTs7Ozs7RUFLVDtvQkFDRCxPQUFPLEVBQUUsQ0FBQyxPQUFPLEVBQUUsbUJBQW1CLENBQUM7b0JBQ3ZDLE9BQU8sRUFBRSxDQUFDLHNCQUFzQixDQUFDO29CQUNqQyxlQUFlLEVBQUUsdUJBQXVCLENBQUMsTUFBTTtvQkFDL0MsY0FBYyxFQUFFLENBQUMsdUJBQXVCLENBQUM7b0JBQ3pDLFNBQVMsRUFBRSxDQUFDLDJCQUEyQixDQUFDLEVBQUUsYUFBYSxFQUFFLGFBQWEsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxDQUFDO2lCQUM5RSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENVU1RPTV9FTEVNRU5UU19TQ0hFTUEsIENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIGluamVjdCwgaW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IE5ndEFyZ3MsIGV4dGVuZCB9IGZyb20gJ2FuZ3VsYXItdGhyZWUnO1xuaW1wb3J0IHsgQmxlbmRGdW5jdGlvbiwgQmxvb21FZmZlY3QsIEJsb29tRWZmZWN0T3B0aW9ucyB9IGZyb20gJ3Bvc3Rwcm9jZXNzaW5nJztcbmltcG9ydCB7IE5ndHBFZmZlY3QsIE5ndHBFZmZlY3RCbGVuZE1vZGUsIE5ndHBFZmZlY3RIb3N0RGlyZWN0aXZlLCBwcm92aWRlRGVmYXVsdEVmZmVjdE9wdGlvbnMgfSBmcm9tICcuLi9lZmZlY3QnO1xuXG5leHRlbmQoeyBCbG9vbUVmZmVjdCB9KTtcblxuQENvbXBvbmVudCh7XG5cdHNlbGVjdG9yOiAnbmd0cC1ibG9vbScsXG5cdHN0YW5kYWxvbmU6IHRydWUsXG5cdHRlbXBsYXRlOiBgXG5cdFx0PG5ndC1ibG9vbS1lZmZlY3QgKmFyZ3M9XCJbb3B0aW9ucygpXVwiIFtjYW1lcmFdPVwiZWZmZWN0LmNhbWVyYSgpXCI+XG5cdFx0XHQ8bmd0cC1lZmZlY3QtYmxlbmQtbW9kZSAvPlxuXHRcdFx0PG5nLWNvbnRlbnQgLz5cblx0XHQ8L25ndC1ibG9vbS1lZmZlY3Q+XG5cdGAsXG5cdGltcG9ydHM6IFtOZ3RBcmdzLCBOZ3RwRWZmZWN0QmxlbmRNb2RlXSxcblx0c2NoZW1hczogW0NVU1RPTV9FTEVNRU5UU19TQ0hFTUFdLFxuXHRjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcblx0aG9zdERpcmVjdGl2ZXM6IFtOZ3RwRWZmZWN0SG9zdERpcmVjdGl2ZV0sXG5cdHByb3ZpZGVyczogW3Byb3ZpZGVEZWZhdWx0RWZmZWN0T3B0aW9ucyh7IGJsZW5kRnVuY3Rpb246IEJsZW5kRnVuY3Rpb24uQUREIH0pXSxcbn0pXG5leHBvcnQgY2xhc3MgTmd0cEJsb29tIHtcblx0ZWZmZWN0ID0gaW5qZWN0KE5ndHBFZmZlY3QsIHsgaG9zdDogdHJ1ZSB9KTtcblx0b3B0aW9ucyA9IGlucHV0KHt9IGFzIE9taXQ8Qmxvb21FZmZlY3RPcHRpb25zLCAnYmxlbmRGdW5jdGlvbic+KTtcbn1cbiJdfQ==
@@ -0,0 +1,38 @@
1
+ import { CUSTOM_ELEMENTS_SCHEMA, ChangeDetectionStrategy, Component, inject, input } from '@angular/core';
2
+ import { NgtArgs, extend } from 'angular-three';
3
+ import { BrightnessContrastEffect } from 'postprocessing';
4
+ import { NgtpEffect, NgtpEffectBlendMode, NgtpEffectHostDirective } from '../effect';
5
+ import * as i0 from "@angular/core";
6
+ import * as i1 from "../effect";
7
+ extend({ BrightnessContrastEffect });
8
+ export class NgtpBrightnessContrast {
9
+ constructor() {
10
+ this.effect = inject(NgtpEffect, { host: true });
11
+ this.options = input({});
12
+ }
13
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.3", ngImport: i0, type: NgtpBrightnessContrast, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
14
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.1.3", type: NgtpBrightnessContrast, isStandalone: true, selector: "ngtp-brightness-contrast", inputs: { options: { classPropertyName: "options", publicName: "options", isSignal: true, isRequired: false, transformFunction: null } }, hostDirectives: [{ directive: i1.NgtpEffect, inputs: ["blendFunction", "blendFunction", "opacity", "opacity"] }], ngImport: i0, template: `
15
+ <ngt-brightness-contrast-effect *args="[options()]" [camera]="effect.camera()">
16
+ <ngtp-effect-blend-mode />
17
+ <ng-content />
18
+ </ngt-brightness-contrast-effect>
19
+ `, isInline: true, dependencies: [{ kind: "directive", type: NgtArgs, selector: "ng-template[args]", inputs: ["args"] }, { kind: "component", type: NgtpEffectBlendMode, selector: "ngtp-effect-blend-mode" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
20
+ }
21
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.3", ngImport: i0, type: NgtpBrightnessContrast, decorators: [{
22
+ type: Component,
23
+ args: [{
24
+ selector: 'ngtp-brightness-contrast',
25
+ standalone: true,
26
+ template: `
27
+ <ngt-brightness-contrast-effect *args="[options()]" [camera]="effect.camera()">
28
+ <ngtp-effect-blend-mode />
29
+ <ng-content />
30
+ </ngt-brightness-contrast-effect>
31
+ `,
32
+ imports: [NgtArgs, NgtpEffectBlendMode],
33
+ schemas: [CUSTOM_ELEMENTS_SCHEMA],
34
+ changeDetection: ChangeDetectionStrategy.OnPush,
35
+ hostDirectives: [NgtpEffectHostDirective],
36
+ }]
37
+ }] });
38
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYnJpZ2h0bmVzcy1jb250cmFzdC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvcG9zdHByb2Nlc3Npbmcvc3JjL2xpYi9lZmZlY3RzL2JyaWdodG5lc3MtY29udHJhc3QudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHNCQUFzQixFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBRSxNQUFNLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQzFHLE9BQU8sRUFBRSxPQUFPLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ2hELE9BQU8sRUFBRSx3QkFBd0IsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQzFELE9BQU8sRUFBRSxVQUFVLEVBQUUsbUJBQW1CLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSxXQUFXLENBQUM7OztBQUVyRixNQUFNLENBQUMsRUFBRSx3QkFBd0IsRUFBRSxDQUFDLENBQUM7QUFrQnJDLE1BQU0sT0FBTyxzQkFBc0I7SUFkbkM7UUFlQyxXQUFNLEdBQUcsTUFBTSxDQUFDLFVBQVUsRUFBRSxFQUFFLElBQUksRUFBRSxJQUFJLEVBQUUsQ0FBQyxDQUFDO1FBQzVDLFlBQU8sR0FBRyxLQUFLLENBQUMsRUFBb0QsQ0FBQyxDQUFDO0tBQ3RFOzhHQUhZLHNCQUFzQjtrR0FBdEIsc0JBQXNCLGdWQVh4Qjs7Ozs7RUFLVCw0REFDUyxPQUFPLGdGQUFFLG1CQUFtQjs7MkZBSzFCLHNCQUFzQjtrQkFkbEMsU0FBUzttQkFBQztvQkFDVixRQUFRLEVBQUUsMEJBQTBCO29CQUNwQyxVQUFVLEVBQUUsSUFBSTtvQkFDaEIsUUFBUSxFQUFFOzs7OztFQUtUO29CQUNELE9BQU8sRUFBRSxDQUFDLE9BQU8sRUFBRSxtQkFBbUIsQ0FBQztvQkFDdkMsT0FBTyxFQUFFLENBQUMsc0JBQXNCLENBQUM7b0JBQ2pDLGVBQWUsRUFBRSx1QkFBdUIsQ0FBQyxNQUFNO29CQUMvQyxjQUFjLEVBQUUsQ0FBQyx1QkFBdUIsQ0FBQztpQkFDekMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDVVNUT01fRUxFTUVOVFNfU0NIRU1BLCBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBpbmplY3QsIGlucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBOZ3RBcmdzLCBleHRlbmQgfSBmcm9tICdhbmd1bGFyLXRocmVlJztcbmltcG9ydCB7IEJyaWdodG5lc3NDb250cmFzdEVmZmVjdCB9IGZyb20gJ3Bvc3Rwcm9jZXNzaW5nJztcbmltcG9ydCB7IE5ndHBFZmZlY3QsIE5ndHBFZmZlY3RCbGVuZE1vZGUsIE5ndHBFZmZlY3RIb3N0RGlyZWN0aXZlIH0gZnJvbSAnLi4vZWZmZWN0JztcblxuZXh0ZW5kKHsgQnJpZ2h0bmVzc0NvbnRyYXN0RWZmZWN0IH0pO1xuXG5leHBvcnQgdHlwZSBCcmlnaHRuZXNzRWZmZWN0T3B0aW9ucyA9IE5vbk51bGxhYmxlPENvbnN0cnVjdG9yUGFyYW1ldGVyczx0eXBlb2YgQnJpZ2h0bmVzc0NvbnRyYXN0RWZmZWN0PlswXT47XG5cbkBDb21wb25lbnQoe1xuXHRzZWxlY3RvcjogJ25ndHAtYnJpZ2h0bmVzcy1jb250cmFzdCcsXG5cdHN0YW5kYWxvbmU6IHRydWUsXG5cdHRlbXBsYXRlOiBgXG5cdFx0PG5ndC1icmlnaHRuZXNzLWNvbnRyYXN0LWVmZmVjdCAqYXJncz1cIltvcHRpb25zKCldXCIgW2NhbWVyYV09XCJlZmZlY3QuY2FtZXJhKClcIj5cblx0XHRcdDxuZ3RwLWVmZmVjdC1ibGVuZC1tb2RlIC8+XG5cdFx0XHQ8bmctY29udGVudCAvPlxuXHRcdDwvbmd0LWJyaWdodG5lc3MtY29udHJhc3QtZWZmZWN0PlxuXHRgLFxuXHRpbXBvcnRzOiBbTmd0QXJncywgTmd0cEVmZmVjdEJsZW5kTW9kZV0sXG5cdHNjaGVtYXM6IFtDVVNUT01fRUxFTUVOVFNfU0NIRU1BXSxcblx0Y2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG5cdGhvc3REaXJlY3RpdmVzOiBbTmd0cEVmZmVjdEhvc3REaXJlY3RpdmVdLFxufSlcbmV4cG9ydCBjbGFzcyBOZ3RwQnJpZ2h0bmVzc0NvbnRyYXN0IHtcblx0ZWZmZWN0ID0gaW5qZWN0KE5ndHBFZmZlY3QsIHsgaG9zdDogdHJ1ZSB9KTtcblx0b3B0aW9ucyA9IGlucHV0KHt9IGFzIE9taXQ8QnJpZ2h0bmVzc0VmZmVjdE9wdGlvbnMsICdibGVuZEZ1bmN0aW9uJz4pO1xufVxuIl19
@@ -0,0 +1,38 @@
1
+ import { CUSTOM_ELEMENTS_SCHEMA, ChangeDetectionStrategy, Component, inject, input } from '@angular/core';
2
+ import { NgtArgs, extend } from 'angular-three';
3
+ import { ChromaticAberrationEffect } from 'postprocessing';
4
+ import { NgtpEffect, NgtpEffectBlendMode, NgtpEffectHostDirective } from '../effect';
5
+ import * as i0 from "@angular/core";
6
+ import * as i1 from "../effect";
7
+ extend({ ChromaticAberrationEffect });
8
+ export class NgtpChromaticAberration {
9
+ constructor() {
10
+ this.effect = inject(NgtpEffect, { host: true });
11
+ this.options = input({});
12
+ }
13
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.3", ngImport: i0, type: NgtpChromaticAberration, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
14
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.1.3", type: NgtpChromaticAberration, isStandalone: true, selector: "ngtp-chromatic-aberration", inputs: { options: { classPropertyName: "options", publicName: "options", isSignal: true, isRequired: false, transformFunction: null } }, hostDirectives: [{ directive: i1.NgtpEffect, inputs: ["blendFunction", "blendFunction", "opacity", "opacity"] }], ngImport: i0, template: `
15
+ <ngt-chromatic-aberration-effect *args="[options()]" [camera]="effect.camera()">
16
+ <ngtp-effect-blend-mode />
17
+ <ng-content />
18
+ </ngt-chromatic-aberration-effect>
19
+ `, isInline: true, dependencies: [{ kind: "directive", type: NgtArgs, selector: "ng-template[args]", inputs: ["args"] }, { kind: "component", type: NgtpEffectBlendMode, selector: "ngtp-effect-blend-mode" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
20
+ }
21
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.3", ngImport: i0, type: NgtpChromaticAberration, decorators: [{
22
+ type: Component,
23
+ args: [{
24
+ selector: 'ngtp-chromatic-aberration',
25
+ template: `
26
+ <ngt-chromatic-aberration-effect *args="[options()]" [camera]="effect.camera()">
27
+ <ngtp-effect-blend-mode />
28
+ <ng-content />
29
+ </ngt-chromatic-aberration-effect>
30
+ `,
31
+ standalone: true,
32
+ schemas: [CUSTOM_ELEMENTS_SCHEMA],
33
+ changeDetection: ChangeDetectionStrategy.OnPush,
34
+ imports: [NgtArgs, NgtpEffectBlendMode],
35
+ hostDirectives: [NgtpEffectHostDirective],
36
+ }]
37
+ }] });
38
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hyb21hdGljLWFiYmVyYXRpb24uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL3Bvc3Rwcm9jZXNzaW5nL3NyYy9saWIvZWZmZWN0cy9jaHJvbWF0aWMtYWJiZXJhdGlvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLE1BQU0sRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDMUcsT0FBTyxFQUFFLE9BQU8sRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDaEQsT0FBTyxFQUFFLHlCQUF5QixFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDM0QsT0FBTyxFQUFFLFVBQVUsRUFBRSxtQkFBbUIsRUFBRSx1QkFBdUIsRUFBRSxNQUFNLFdBQVcsQ0FBQzs7O0FBRXJGLE1BQU0sQ0FBQyxFQUFFLHlCQUF5QixFQUFFLENBQUMsQ0FBQztBQW9CdEMsTUFBTSxPQUFPLHVCQUF1QjtJQWRwQztRQWVDLFdBQU0sR0FBRyxNQUFNLENBQUMsVUFBVSxFQUFFLEVBQUUsSUFBSSxFQUFFLElBQUksRUFBRSxDQUFDLENBQUM7UUFDNUMsWUFBTyxHQUFHLEtBQUssQ0FBQyxFQUE2RCxDQUFDLENBQUM7S0FDL0U7OEdBSFksdUJBQXVCO2tHQUF2Qix1QkFBdUIsaVZBWnpCOzs7OztFQUtULDREQUlTLE9BQU8sZ0ZBQUUsbUJBQW1COzsyRkFHMUIsdUJBQXVCO2tCQWRuQyxTQUFTO21CQUFDO29CQUNWLFFBQVEsRUFBRSwyQkFBMkI7b0JBQ3JDLFFBQVEsRUFBRTs7Ozs7RUFLVDtvQkFDRCxVQUFVLEVBQUUsSUFBSTtvQkFDaEIsT0FBTyxFQUFFLENBQUMsc0JBQXNCLENBQUM7b0JBQ2pDLGVBQWUsRUFBRSx1QkFBdUIsQ0FBQyxNQUFNO29CQUMvQyxPQUFPLEVBQUUsQ0FBQyxPQUFPLEVBQUUsbUJBQW1CLENBQUM7b0JBQ3ZDLGNBQWMsRUFBRSxDQUFDLHVCQUF1QixDQUFDO2lCQUN6QyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENVU1RPTV9FTEVNRU5UU19TQ0hFTUEsIENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIGluamVjdCwgaW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IE5ndEFyZ3MsIGV4dGVuZCB9IGZyb20gJ2FuZ3VsYXItdGhyZWUnO1xuaW1wb3J0IHsgQ2hyb21hdGljQWJlcnJhdGlvbkVmZmVjdCB9IGZyb20gJ3Bvc3Rwcm9jZXNzaW5nJztcbmltcG9ydCB7IE5ndHBFZmZlY3QsIE5ndHBFZmZlY3RCbGVuZE1vZGUsIE5ndHBFZmZlY3RIb3N0RGlyZWN0aXZlIH0gZnJvbSAnLi4vZWZmZWN0JztcblxuZXh0ZW5kKHsgQ2hyb21hdGljQWJlcnJhdGlvbkVmZmVjdCB9KTtcblxuZXhwb3J0IHR5cGUgQ2hyb21hdGljQWJlcnJhdGlvbkVmZmVjdE9wdGlvbnMgPSBQYXJ0aWFsPFxuXHROb25OdWxsYWJsZTxDb25zdHJ1Y3RvclBhcmFtZXRlcnM8dHlwZW9mIENocm9tYXRpY0FiZXJyYXRpb25FZmZlY3Q+WzBdPlxuPjtcblxuQENvbXBvbmVudCh7XG5cdHNlbGVjdG9yOiAnbmd0cC1jaHJvbWF0aWMtYWJlcnJhdGlvbicsXG5cdHRlbXBsYXRlOiBgXG5cdFx0PG5ndC1jaHJvbWF0aWMtYWJlcnJhdGlvbi1lZmZlY3QgKmFyZ3M9XCJbb3B0aW9ucygpXVwiIFtjYW1lcmFdPVwiZWZmZWN0LmNhbWVyYSgpXCI+XG5cdFx0XHQ8bmd0cC1lZmZlY3QtYmxlbmQtbW9kZSAvPlxuXHRcdFx0PG5nLWNvbnRlbnQgLz5cblx0XHQ8L25ndC1jaHJvbWF0aWMtYWJlcnJhdGlvbi1lZmZlY3Q+XG5cdGAsXG5cdHN0YW5kYWxvbmU6IHRydWUsXG5cdHNjaGVtYXM6IFtDVVNUT01fRUxFTUVOVFNfU0NIRU1BXSxcblx0Y2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG5cdGltcG9ydHM6IFtOZ3RBcmdzLCBOZ3RwRWZmZWN0QmxlbmRNb2RlXSxcblx0aG9zdERpcmVjdGl2ZXM6IFtOZ3RwRWZmZWN0SG9zdERpcmVjdGl2ZV0sXG59KVxuZXhwb3J0IGNsYXNzIE5ndHBDaHJvbWF0aWNBYmVycmF0aW9uIHtcblx0ZWZmZWN0ID0gaW5qZWN0KE5ndHBFZmZlY3QsIHsgaG9zdDogdHJ1ZSB9KTtcblx0b3B0aW9ucyA9IGlucHV0KHt9IGFzIE9taXQ8Q2hyb21hdGljQWJlcnJhdGlvbkVmZmVjdE9wdGlvbnMsICdibGVuZEZ1bmN0aW9uJz4pO1xufVxuIl19