angular-three-postprocessing 2.0.0-beta.4 → 2.0.0-beta.41
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/index.mjs +4 -3
- package/esm2022/lib/effect-composer.mjs +249 -0
- package/esm2022/lib/effect.mjs +78 -0
- package/esm2022/lib/effects/bloom/bloom.mjs +33 -0
- package/esm2022/lib/effects/brightness-contrast/brightness-contrast.mjs +29 -0
- package/esm2022/lib/effects/color-depth/color-depth.mjs +29 -0
- package/esm2022/lib/effects/depth/depth.mjs +29 -0
- package/esm2022/lib/effects/dot-screen/dot-screen.mjs +29 -0
- package/esm2022/lib/effects/hue-saturation/hue-saturation.mjs +29 -0
- package/esm2022/lib/effects/index.mjs +18 -0
- package/esm2022/lib/effects/lut/lut.mjs +74 -0
- package/esm2022/lib/effects/noise/noise.mjs +33 -0
- package/esm2022/lib/effects/pixelation/pixelation.mjs +37 -0
- package/esm2022/lib/effects/scanline/scanline.mjs +33 -0
- package/esm2022/lib/effects/sepia/sepia.mjs +29 -0
- package/esm2022/lib/effects/shock-wave/shock-wave.mjs +29 -0
- package/esm2022/lib/effects/smaa/smaa.mjs +29 -0
- package/esm2022/lib/effects/ssao/ssao.mjs +217 -0
- package/esm2022/lib/effects/tilt-shift/tilt-shift.mjs +33 -0
- package/esm2022/lib/effects/tone-mapping/tone-mapping.mjs +29 -0
- package/esm2022/lib/effects/vignette/vignette.mjs +29 -0
- package/fesm2022/angular-three-postprocessing.mjs +881 -206
- package/fesm2022/angular-three-postprocessing.mjs.map +1 -1
- package/index.d.ts +3 -2
- package/lib/effect-composer.d.ts +105 -0
- package/lib/effect.d.ts +27 -0
- package/{effects → lib/effects}/bloom/bloom.d.ts +7 -2
- package/{effects → lib/effects}/brightness-contrast/brightness-contrast.d.ts +9 -1
- package/{effects → lib/effects}/color-depth/color-depth.d.ts +8 -1
- package/{effects → lib/effects}/depth/depth.d.ts +8 -1
- package/{effects → lib/effects}/dot-screen/dot-screen.d.ts +9 -1
- package/{effects → lib/effects}/hue-saturation/hue-saturation.d.ts +9 -1
- package/{effects → lib/effects}/index.d.ts +1 -0
- package/lib/effects/lut/lut.d.ts +29 -0
- package/{effects → lib/effects}/noise/noise.d.ts +8 -1
- package/lib/effects/pixelation/pixelation.d.ts +20 -0
- package/{effects → lib/effects}/scanline/scanline.d.ts +8 -1
- package/{effects → lib/effects}/sepia/sepia.d.ts +8 -1
- package/lib/effects/shock-wave/shock-wave.d.ts +17 -0
- package/lib/effects/smaa/smaa.d.ts +16 -0
- package/lib/effects/ssao/ssao.d.ts +42 -0
- package/lib/effects/tilt-shift/tilt-shift.d.ts +23 -0
- package/lib/effects/tone-mapping/tone-mapping.d.ts +22 -0
- package/lib/effects/vignette/vignette.d.ts +17 -0
- package/package.json +4 -14
- package/effect-composer.d.ts +0 -53
- package/effect.d.ts +0 -24
- package/effects/README.md +0 -3
- package/effects/lut/lut.d.ts +0 -19
- package/effects/shock-wave/shock-wave.d.ts +0 -7
- package/effects/smaa/smaa.d.ts +0 -7
- package/effects/ssao/ssao.d.ts +0 -38
- package/effects/tilt-shift/tilt-shift.d.ts +0 -8
- package/effects/tone-mapping/tone-mapping.d.ts +0 -7
- package/effects/vignette/vignette.d.ts +0 -7
- package/esm2022/effect-composer.mjs +0 -242
- package/esm2022/effect.mjs +0 -79
- package/esm2022/effects/angular-three-postprocessing-effects.mjs +0 -5
- package/esm2022/effects/bloom/bloom.mjs +0 -34
- package/esm2022/effects/brightness-contrast/brightness-contrast.mjs +0 -30
- package/esm2022/effects/color-depth/color-depth.mjs +0 -30
- package/esm2022/effects/depth/depth.mjs +0 -30
- package/esm2022/effects/dot-screen/dot-screen.mjs +0 -30
- package/esm2022/effects/hue-saturation/hue-saturation.mjs +0 -30
- package/esm2022/effects/index.mjs +0 -17
- package/esm2022/effects/lut/lut.mjs +0 -77
- package/esm2022/effects/noise/noise.mjs +0 -34
- package/esm2022/effects/scanline/scanline.mjs +0 -34
- package/esm2022/effects/sepia/sepia.mjs +0 -30
- package/esm2022/effects/shock-wave/shock-wave.mjs +0 -30
- package/esm2022/effects/smaa/smaa.mjs +0 -30
- package/esm2022/effects/ssao/ssao.mjs +0 -187
- package/esm2022/effects/tilt-shift/tilt-shift.mjs +0 -34
- package/esm2022/effects/tone-mapping/tone-mapping.mjs +0 -30
- package/esm2022/effects/vignette/vignette.mjs +0 -30
- package/fesm2022/angular-three-postprocessing-effects.mjs +0 -617
- package/fesm2022/angular-three-postprocessing-effects.mjs.map +0 -1
- package/plugin/README.md +0 -11
- package/plugin/generators.json +0 -19
- package/plugin/package.json +0 -9
- package/plugin/src/generators/init/compat.d.ts +0 -2
- package/plugin/src/generators/init/compat.js +0 -6
- package/plugin/src/generators/init/compat.js.map +0 -1
- package/plugin/src/generators/init/init.d.ts +0 -4
- package/plugin/src/generators/init/init.js +0 -22
- package/plugin/src/generators/init/init.js.map +0 -1
- package/plugin/src/generators/init/schema.json +0 -6
- package/plugin/src/index.d.ts +0 -1
- package/plugin/src/index.js +0 -6
- package/plugin/src/index.js.map +0 -1
|
@@ -0,0 +1,74 @@
|
|
|
1
|
+
import { CUSTOM_ELEMENTS_SCHEMA, Component, Input, computed, effect } from '@angular/core';
|
|
2
|
+
import { NgtArgs, injectNgtRef, injectNgtStore, signalStore } from 'angular-three';
|
|
3
|
+
import { BlendFunction, LUT3DEffect } from 'postprocessing';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
export class NgtpLUT {
|
|
6
|
+
set _lut(lut) {
|
|
7
|
+
this.inputs.set({ lut });
|
|
8
|
+
}
|
|
9
|
+
set _blendFunction(blendFunction) {
|
|
10
|
+
this.inputs.set({ blendFunction });
|
|
11
|
+
}
|
|
12
|
+
set _tetrahedralInterpolation(tetrahedralInterpolation) {
|
|
13
|
+
this.inputs.set({ tetrahedralInterpolation });
|
|
14
|
+
}
|
|
15
|
+
constructor() {
|
|
16
|
+
this.inputs = signalStore({});
|
|
17
|
+
this.effectRef = injectNgtRef();
|
|
18
|
+
this.lut = this.inputs.select('lut');
|
|
19
|
+
this.tetrahedralInterpolation = this.inputs.select('tetrahedralInterpolation');
|
|
20
|
+
this.blendFunction = this.inputs.select('blendFunction');
|
|
21
|
+
this.store = injectNgtStore();
|
|
22
|
+
this.invalidate = this.store.select('invalidate');
|
|
23
|
+
this.effect = computed(() => new LUT3DEffect(this.lut(), {
|
|
24
|
+
blendFunction: this.blendFunction(),
|
|
25
|
+
tetrahedralInterpolation: this.tetrahedralInterpolation(),
|
|
26
|
+
}));
|
|
27
|
+
this.setState();
|
|
28
|
+
}
|
|
29
|
+
setState() {
|
|
30
|
+
effect(() => {
|
|
31
|
+
const [effect, invalidate, lut, tetrahedralInterpolation] = [
|
|
32
|
+
this.effect(),
|
|
33
|
+
this.invalidate(),
|
|
34
|
+
this.lut(),
|
|
35
|
+
this.tetrahedralInterpolation(),
|
|
36
|
+
];
|
|
37
|
+
if (!effect)
|
|
38
|
+
return;
|
|
39
|
+
if (tetrahedralInterpolation)
|
|
40
|
+
effect.tetrahedralInterpolation = tetrahedralInterpolation;
|
|
41
|
+
if (lut)
|
|
42
|
+
effect.lut = lut;
|
|
43
|
+
invalidate();
|
|
44
|
+
});
|
|
45
|
+
}
|
|
46
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: NgtpLUT, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
47
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.3", type: NgtpLUT, isStandalone: true, selector: "ngtp-lut", inputs: { effectRef: "effectRef", _lut: ["lut", "_lut"], _blendFunction: ["blendFunction", "_blendFunction"], _tetrahedralInterpolation: ["tetrahedralInterpolation", "_tetrahedralInterpolation"] }, ngImport: i0, template: `
|
|
48
|
+
<ngt-primitive *args="[effect()]" [ref]="effectRef" />
|
|
49
|
+
`, isInline: true, dependencies: [{ kind: "directive", type: NgtArgs, selector: "ng-template[args]", inputs: ["args"] }] }); }
|
|
50
|
+
}
|
|
51
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: NgtpLUT, decorators: [{
|
|
52
|
+
type: Component,
|
|
53
|
+
args: [{
|
|
54
|
+
selector: 'ngtp-lut',
|
|
55
|
+
standalone: true,
|
|
56
|
+
template: `
|
|
57
|
+
<ngt-primitive *args="[effect()]" [ref]="effectRef" />
|
|
58
|
+
`,
|
|
59
|
+
imports: [NgtArgs],
|
|
60
|
+
schemas: [CUSTOM_ELEMENTS_SCHEMA],
|
|
61
|
+
}]
|
|
62
|
+
}], ctorParameters: function () { return []; }, propDecorators: { effectRef: [{
|
|
63
|
+
type: Input
|
|
64
|
+
}], _lut: [{
|
|
65
|
+
type: Input,
|
|
66
|
+
args: [{ required: true, alias: 'lut' }]
|
|
67
|
+
}], _blendFunction: [{
|
|
68
|
+
type: Input,
|
|
69
|
+
args: [{ alias: 'blendFunction' }]
|
|
70
|
+
}], _tetrahedralInterpolation: [{
|
|
71
|
+
type: Input,
|
|
72
|
+
args: [{ alias: 'tetrahedralInterpolation' }]
|
|
73
|
+
}] } });
|
|
74
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibHV0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9wb3N0cHJvY2Vzc2luZy9zcmMvbGliL2VmZmVjdHMvbHV0L2x1dC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxRQUFRLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQzNGLE9BQU8sRUFBRSxPQUFPLEVBQUUsWUFBWSxFQUFFLGNBQWMsRUFBRSxXQUFXLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDbkYsT0FBTyxFQUFFLGFBQWEsRUFBRSxXQUFXLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQzs7QUF1QjVELE1BQU0sT0FBTyxPQUFPO0lBS25CLElBQTZDLElBQUksQ0FBQyxHQUFrQjtRQUNuRSxJQUFJLENBQUMsTUFBTSxDQUFDLEdBQUcsQ0FBQyxFQUFFLEdBQUcsRUFBRSxDQUFDLENBQUM7SUFDMUIsQ0FBQztJQUVELElBQXVDLGNBQWMsQ0FBQyxhQUE0QjtRQUNqRixJQUFJLENBQUMsTUFBTSxDQUFDLEdBQUcsQ0FBQyxFQUFFLGFBQWEsRUFBRSxDQUFDLENBQUM7SUFDcEMsQ0FBQztJQUVELElBQWtELHlCQUF5QixDQUFDLHdCQUFpQztRQUM1RyxJQUFJLENBQUMsTUFBTSxDQUFDLEdBQUcsQ0FBQyxFQUFFLHdCQUF3QixFQUFFLENBQUMsQ0FBQztJQUMvQyxDQUFDO0lBaUJEO1FBL0JRLFdBQU0sR0FBRyxXQUFXLENBQWUsRUFBRSxDQUFDLENBQUM7UUFFdEMsY0FBUyxHQUFHLFlBQVksRUFBZSxDQUFDO1FBY3pDLFFBQUcsR0FBRyxJQUFJLENBQUMsTUFBTSxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUNoQyw2QkFBd0IsR0FBRyxJQUFJLENBQUMsTUFBTSxDQUFDLE1BQU0sQ0FBQywwQkFBMEIsQ0FBQyxDQUFDO1FBQzFFLGtCQUFhLEdBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQyxNQUFNLENBQUMsZUFBZSxDQUFDLENBQUM7UUFFcEQsVUFBSyxHQUFHLGNBQWMsRUFBRSxDQUFDO1FBQ3pCLGVBQVUsR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLE1BQU0sQ0FBQyxZQUFZLENBQUMsQ0FBQztRQUVyRCxXQUFNLEdBQUcsUUFBUSxDQUNoQixHQUFHLEVBQUUsQ0FDSixJQUFJLFdBQVcsQ0FBQyxJQUFJLENBQUMsR0FBRyxFQUFFLEVBQUU7WUFDM0IsYUFBYSxFQUFFLElBQUksQ0FBQyxhQUFhLEVBQUU7WUFDbkMsd0JBQXdCLEVBQUUsSUFBSSxDQUFDLHdCQUF3QixFQUFFO1NBQ3pELENBQUMsQ0FDSCxDQUFDO1FBR0QsSUFBSSxDQUFDLFFBQVEsRUFBRSxDQUFDO0lBQ2pCLENBQUM7SUFFTyxRQUFRO1FBQ2YsTUFBTSxDQUFDLEdBQUcsRUFBRTtZQUNYLE1BQU0sQ0FBQyxNQUFNLEVBQUUsVUFBVSxFQUFFLEdBQUcsRUFBRSx3QkFBd0IsQ0FBQyxHQUFHO2dCQUMzRCxJQUFJLENBQUMsTUFBTSxFQUFFO2dCQUNiLElBQUksQ0FBQyxVQUFVLEVBQUU7Z0JBQ2pCLElBQUksQ0FBQyxHQUFHLEVBQUU7Z0JBQ1YsSUFBSSxDQUFDLHdCQUF3QixFQUFFO2FBQy9CLENBQUM7WUFDRixJQUFJLENBQUMsTUFBTTtnQkFBRSxPQUFPO1lBQ3BCLElBQUksd0JBQXdCO2dCQUFFLE1BQU0sQ0FBQyx3QkFBd0IsR0FBRyx3QkFBd0IsQ0FBQztZQUN6RixJQUFJLEdBQUc7Z0JBQUUsTUFBTSxDQUFDLEdBQUcsR0FBRyxHQUFHLENBQUM7WUFDMUIsVUFBVSxFQUFFLENBQUM7UUFDZCxDQUFDLENBQUMsQ0FBQztJQUNKLENBQUM7OEdBakRXLE9BQU87a0dBQVAsT0FBTywwUUFOVDs7RUFFVCw0REFDUyxPQUFPOzsyRkFHTCxPQUFPO2tCQVRuQixTQUFTO21CQUFDO29CQUNWLFFBQVEsRUFBRSxVQUFVO29CQUNwQixVQUFVLEVBQUUsSUFBSTtvQkFDaEIsUUFBUSxFQUFFOztFQUVUO29CQUNELE9BQU8sRUFBRSxDQUFDLE9BQU8sQ0FBQztvQkFDbEIsT0FBTyxFQUFFLENBQUMsc0JBQXNCLENBQUM7aUJBQ2pDOzBFQUlTLFNBQVM7c0JBQWpCLEtBQUs7Z0JBRXVDLElBQUk7c0JBQWhELEtBQUs7dUJBQUMsRUFBRSxRQUFRLEVBQUUsSUFBSSxFQUFFLEtBQUssRUFBRSxLQUFLLEVBQUU7Z0JBSUEsY0FBYztzQkFBcEQsS0FBSzt1QkFBQyxFQUFFLEtBQUssRUFBRSxlQUFlLEVBQUU7Z0JBSWlCLHlCQUF5QjtzQkFBMUUsS0FBSzt1QkFBQyxFQUFFLEtBQUssRUFBRSwwQkFBMEIsRUFBRSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENVU1RPTV9FTEVNRU5UU19TQ0hFTUEsIENvbXBvbmVudCwgSW5wdXQsIGNvbXB1dGVkLCBlZmZlY3QgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IE5ndEFyZ3MsIGluamVjdE5ndFJlZiwgaW5qZWN0Tmd0U3RvcmUsIHNpZ25hbFN0b3JlIH0gZnJvbSAnYW5ndWxhci10aHJlZSc7XG5pbXBvcnQgeyBCbGVuZEZ1bmN0aW9uLCBMVVQzREVmZmVjdCB9IGZyb20gJ3Bvc3Rwcm9jZXNzaW5nJztcblxuZXhwb3J0IHR5cGUgTmd0cExVVFN0YXRlID0ge1xuXHRsdXQ6IFRIUkVFLlRleHR1cmU7XG5cdGJsZW5kRnVuY3Rpb24/OiBCbGVuZEZ1bmN0aW9uO1xuXHR0ZXRyYWhlZHJhbEludGVycG9sYXRpb24/OiBib29sZWFuO1xufTtcblxuZGVjbGFyZSBnbG9iYWwge1xuXHRpbnRlcmZhY2UgSFRNTEVsZW1lbnRUYWdOYW1lTWFwIHtcblx0XHQnbmd0cC1sdXQnOiBOZ3RwTFVUU3RhdGU7XG5cdH1cbn1cblxuQENvbXBvbmVudCh7XG5cdHNlbGVjdG9yOiAnbmd0cC1sdXQnLFxuXHRzdGFuZGFsb25lOiB0cnVlLFxuXHR0ZW1wbGF0ZTogYFxuXHRcdDxuZ3QtcHJpbWl0aXZlICphcmdzPVwiW2VmZmVjdCgpXVwiIFtyZWZdPVwiZWZmZWN0UmVmXCIgLz5cblx0YCxcblx0aW1wb3J0czogW05ndEFyZ3NdLFxuXHRzY2hlbWFzOiBbQ1VTVE9NX0VMRU1FTlRTX1NDSEVNQV0sXG59KVxuZXhwb3J0IGNsYXNzIE5ndHBMVVQge1xuXHRwcml2YXRlIGlucHV0cyA9IHNpZ25hbFN0b3JlPE5ndHBMVVRTdGF0ZT4oe30pO1xuXG5cdEBJbnB1dCgpIGVmZmVjdFJlZiA9IGluamVjdE5ndFJlZjxMVVQzREVmZmVjdD4oKTtcblxuXHRASW5wdXQoeyByZXF1aXJlZDogdHJ1ZSwgYWxpYXM6ICdsdXQnIH0pIHNldCBfbHV0KGx1dDogVEhSRUUuVGV4dHVyZSkge1xuXHRcdHRoaXMuaW5wdXRzLnNldCh7IGx1dCB9KTtcblx0fVxuXG5cdEBJbnB1dCh7IGFsaWFzOiAnYmxlbmRGdW5jdGlvbicgfSkgc2V0IF9ibGVuZEZ1bmN0aW9uKGJsZW5kRnVuY3Rpb246IEJsZW5kRnVuY3Rpb24pIHtcblx0XHR0aGlzLmlucHV0cy5zZXQoeyBibGVuZEZ1bmN0aW9uIH0pO1xuXHR9XG5cblx0QElucHV0KHsgYWxpYXM6ICd0ZXRyYWhlZHJhbEludGVycG9sYXRpb24nIH0pIHNldCBfdGV0cmFoZWRyYWxJbnRlcnBvbGF0aW9uKHRldHJhaGVkcmFsSW50ZXJwb2xhdGlvbjogYm9vbGVhbikge1xuXHRcdHRoaXMuaW5wdXRzLnNldCh7IHRldHJhaGVkcmFsSW50ZXJwb2xhdGlvbiB9KTtcblx0fVxuXG5cdHByaXZhdGUgbHV0ID0gdGhpcy5pbnB1dHMuc2VsZWN0KCdsdXQnKTtcblx0cHJpdmF0ZSB0ZXRyYWhlZHJhbEludGVycG9sYXRpb24gPSB0aGlzLmlucHV0cy5zZWxlY3QoJ3RldHJhaGVkcmFsSW50ZXJwb2xhdGlvbicpO1xuXHRwcml2YXRlIGJsZW5kRnVuY3Rpb24gPSB0aGlzLmlucHV0cy5zZWxlY3QoJ2JsZW5kRnVuY3Rpb24nKTtcblxuXHRwcml2YXRlIHN0b3JlID0gaW5qZWN0Tmd0U3RvcmUoKTtcblx0cHJpdmF0ZSBpbnZhbGlkYXRlID0gdGhpcy5zdG9yZS5zZWxlY3QoJ2ludmFsaWRhdGUnKTtcblxuXHRlZmZlY3QgPSBjb21wdXRlZChcblx0XHQoKSA9PlxuXHRcdFx0bmV3IExVVDNERWZmZWN0KHRoaXMubHV0KCksIHtcblx0XHRcdFx0YmxlbmRGdW5jdGlvbjogdGhpcy5ibGVuZEZ1bmN0aW9uKCksXG5cdFx0XHRcdHRldHJhaGVkcmFsSW50ZXJwb2xhdGlvbjogdGhpcy50ZXRyYWhlZHJhbEludGVycG9sYXRpb24oKSxcblx0XHRcdH0pLFxuXHQpO1xuXG5cdGNvbnN0cnVjdG9yKCkge1xuXHRcdHRoaXMuc2V0U3RhdGUoKTtcblx0fVxuXG5cdHByaXZhdGUgc2V0U3RhdGUoKSB7XG5cdFx0ZWZmZWN0KCgpID0+IHtcblx0XHRcdGNvbnN0IFtlZmZlY3QsIGludmFsaWRhdGUsIGx1dCwgdGV0cmFoZWRyYWxJbnRlcnBvbGF0aW9uXSA9IFtcblx0XHRcdFx0dGhpcy5lZmZlY3QoKSxcblx0XHRcdFx0dGhpcy5pbnZhbGlkYXRlKCksXG5cdFx0XHRcdHRoaXMubHV0KCksXG5cdFx0XHRcdHRoaXMudGV0cmFoZWRyYWxJbnRlcnBvbGF0aW9uKCksXG5cdFx0XHRdO1xuXHRcdFx0aWYgKCFlZmZlY3QpIHJldHVybjtcblx0XHRcdGlmICh0ZXRyYWhlZHJhbEludGVycG9sYXRpb24pIGVmZmVjdC50ZXRyYWhlZHJhbEludGVycG9sYXRpb24gPSB0ZXRyYWhlZHJhbEludGVycG9sYXRpb247XG5cdFx0XHRpZiAobHV0KSBlZmZlY3QubHV0ID0gbHV0O1xuXHRcdFx0aW52YWxpZGF0ZSgpO1xuXHRcdH0pO1xuXHR9XG59XG4iXX0=
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
import { CUSTOM_ELEMENTS_SCHEMA, Component } from '@angular/core';
|
|
2
|
+
import { NgtArgs, extend } from 'angular-three';
|
|
3
|
+
import { BlendFunction, NoiseEffect } from 'postprocessing';
|
|
4
|
+
import { NgtpEffect } from '../../effect';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
extend({ NoiseEffect });
|
|
7
|
+
export class NgtpNoise extends NgtpEffect {
|
|
8
|
+
constructor() {
|
|
9
|
+
super(...arguments);
|
|
10
|
+
this.defaultBlendFunction = BlendFunction.COLOR_DODGE;
|
|
11
|
+
}
|
|
12
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: NgtpNoise, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
|
|
13
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.3", type: NgtpNoise, isStandalone: true, selector: "ngtp-noise", usesInheritance: true, ngImport: i0, template: `
|
|
14
|
+
<ngt-noise-effect ngtCompound *args="args()" [camera]="camera()" [ref]="effectRef">
|
|
15
|
+
<ng-content />
|
|
16
|
+
</ngt-noise-effect>
|
|
17
|
+
`, isInline: true, dependencies: [{ kind: "directive", type: NgtArgs, selector: "ng-template[args]", inputs: ["args"] }] }); }
|
|
18
|
+
}
|
|
19
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: NgtpNoise, decorators: [{
|
|
20
|
+
type: Component,
|
|
21
|
+
args: [{
|
|
22
|
+
selector: 'ngtp-noise',
|
|
23
|
+
standalone: true,
|
|
24
|
+
template: `
|
|
25
|
+
<ngt-noise-effect ngtCompound *args="args()" [camera]="camera()" [ref]="effectRef">
|
|
26
|
+
<ng-content />
|
|
27
|
+
</ngt-noise-effect>
|
|
28
|
+
`,
|
|
29
|
+
imports: [NgtArgs],
|
|
30
|
+
schemas: [CUSTOM_ELEMENTS_SCHEMA],
|
|
31
|
+
}]
|
|
32
|
+
}] });
|
|
33
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibm9pc2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL3Bvc3Rwcm9jZXNzaW5nL3NyYy9saWIvZWZmZWN0cy9ub2lzZS9ub2lzZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsU0FBUyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ2xFLE9BQU8sRUFBRSxPQUFPLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ2hELE9BQU8sRUFBRSxhQUFhLEVBQUUsV0FBVyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDNUQsT0FBTyxFQUFFLFVBQVUsRUFBd0IsTUFBTSxjQUFjLENBQUM7O0FBRWhFLE1BQU0sQ0FBQyxFQUFFLFdBQVcsRUFBRSxDQUFDLENBQUM7QUFtQnhCLE1BQU0sT0FBTyxTQUFVLFNBQVEsVUFBdUI7SUFYdEQ7O1FBWVUseUJBQW9CLEdBQUcsYUFBYSxDQUFDLFdBQVcsQ0FBQztLQUMxRDs4R0FGWSxTQUFTO2tHQUFULFNBQVMsNkZBUlg7Ozs7RUFJVCw0REFDUyxPQUFPOzsyRkFHTCxTQUFTO2tCQVhyQixTQUFTO21CQUFDO29CQUNWLFFBQVEsRUFBRSxZQUFZO29CQUN0QixVQUFVLEVBQUUsSUFBSTtvQkFDaEIsUUFBUSxFQUFFOzs7O0VBSVQ7b0JBQ0QsT0FBTyxFQUFFLENBQUMsT0FBTyxDQUFDO29CQUNsQixPQUFPLEVBQUUsQ0FBQyxzQkFBc0IsQ0FBQztpQkFDakMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDVVNUT01fRUxFTUVOVFNfU0NIRU1BLCBDb21wb25lbnQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IE5ndEFyZ3MsIGV4dGVuZCB9IGZyb20gJ2FuZ3VsYXItdGhyZWUnO1xuaW1wb3J0IHsgQmxlbmRGdW5jdGlvbiwgTm9pc2VFZmZlY3QgfSBmcm9tICdwb3N0cHJvY2Vzc2luZyc7XG5pbXBvcnQgeyBOZ3RwRWZmZWN0LCB0eXBlIE5ndHBFZmZlY3RTdGF0ZSB9IGZyb20gJy4uLy4uL2VmZmVjdCc7XG5cbmV4dGVuZCh7IE5vaXNlRWZmZWN0IH0pO1xuXG5kZWNsYXJlIGdsb2JhbCB7XG5cdGludGVyZmFjZSBIVE1MRWxlbWVudFRhZ05hbWVNYXAge1xuXHRcdCduZ3RwLW5vaXNlJzogeyBwcmVtdWx0aXBseT86IGJvb2xlYW4gfSAmIE5ndHBFZmZlY3RTdGF0ZTtcblx0fVxufVxuXG5AQ29tcG9uZW50KHtcblx0c2VsZWN0b3I6ICduZ3RwLW5vaXNlJyxcblx0c3RhbmRhbG9uZTogdHJ1ZSxcblx0dGVtcGxhdGU6IGBcblx0XHQ8bmd0LW5vaXNlLWVmZmVjdCBuZ3RDb21wb3VuZCAqYXJncz1cImFyZ3MoKVwiIFtjYW1lcmFdPVwiY2FtZXJhKClcIiBbcmVmXT1cImVmZmVjdFJlZlwiPlxuXHRcdFx0PG5nLWNvbnRlbnQgLz5cblx0XHQ8L25ndC1ub2lzZS1lZmZlY3Q+XG5cdGAsXG5cdGltcG9ydHM6IFtOZ3RBcmdzXSxcblx0c2NoZW1hczogW0NVU1RPTV9FTEVNRU5UU19TQ0hFTUFdLFxufSlcbmV4cG9ydCBjbGFzcyBOZ3RwTm9pc2UgZXh0ZW5kcyBOZ3RwRWZmZWN0PE5vaXNlRWZmZWN0PiB7XG5cdG92ZXJyaWRlIGRlZmF1bHRCbGVuZEZ1bmN0aW9uID0gQmxlbmRGdW5jdGlvbi5DT0xPUl9ET0RHRTtcbn1cbiJdfQ==
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
import { CUSTOM_ELEMENTS_SCHEMA, Component, Input, computed } from '@angular/core';
|
|
2
|
+
import { NgtArgs, injectNgtRef, signalStore } from 'angular-three';
|
|
3
|
+
import { PixelationEffect } from 'postprocessing';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
export class NgtpPixelation {
|
|
6
|
+
constructor() {
|
|
7
|
+
this.inputs = signalStore({ granularity: 30 });
|
|
8
|
+
this.effectRef = injectNgtRef();
|
|
9
|
+
this.granularity = this.inputs.select('granularity');
|
|
10
|
+
this.effect = computed(() => new PixelationEffect(this.granularity()));
|
|
11
|
+
}
|
|
12
|
+
set _granularity(granularity) {
|
|
13
|
+
this.inputs.set({ granularity });
|
|
14
|
+
}
|
|
15
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: NgtpPixelation, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
16
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.3", type: NgtpPixelation, isStandalone: true, selector: "ngtp-pixelation", inputs: { effectRef: "effectRef", _granularity: ["granularity", "_granularity"] }, ngImport: i0, template: `
|
|
17
|
+
<ngt-primitive *args="[effect()]" [ref]="effectRef" />
|
|
18
|
+
`, isInline: true, dependencies: [{ kind: "directive", type: NgtArgs, selector: "ng-template[args]", inputs: ["args"] }] }); }
|
|
19
|
+
}
|
|
20
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: NgtpPixelation, decorators: [{
|
|
21
|
+
type: Component,
|
|
22
|
+
args: [{
|
|
23
|
+
selector: 'ngtp-pixelation',
|
|
24
|
+
standalone: true,
|
|
25
|
+
template: `
|
|
26
|
+
<ngt-primitive *args="[effect()]" [ref]="effectRef" />
|
|
27
|
+
`,
|
|
28
|
+
imports: [NgtArgs],
|
|
29
|
+
schemas: [CUSTOM_ELEMENTS_SCHEMA],
|
|
30
|
+
}]
|
|
31
|
+
}], propDecorators: { effectRef: [{
|
|
32
|
+
type: Input
|
|
33
|
+
}], _granularity: [{
|
|
34
|
+
type: Input,
|
|
35
|
+
args: [{ alias: 'granularity' }]
|
|
36
|
+
}] } });
|
|
37
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGl4ZWxhdGlvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvcG9zdHByb2Nlc3Npbmcvc3JjL2xpYi9lZmZlY3RzL3BpeGVsYXRpb24vcGl4ZWxhdGlvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDbkYsT0FBTyxFQUFFLE9BQU8sRUFBRSxZQUFZLEVBQUUsV0FBVyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ25FLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLGdCQUFnQixDQUFDOztBQXNCbEQsTUFBTSxPQUFPLGNBQWM7SUFUM0I7UUFVUyxXQUFNLEdBQUcsV0FBVyxDQUFzQixFQUFFLFdBQVcsRUFBRSxFQUFFLEVBQUUsQ0FBQyxDQUFDO1FBRTlELGNBQVMsR0FBRyxZQUFZLEVBQW9CLENBQUM7UUFNOUMsZ0JBQVcsR0FBRyxJQUFJLENBQUMsTUFBTSxDQUFDLE1BQU0sQ0FBQyxhQUFhLENBQUMsQ0FBQztRQUV4RCxXQUFNLEdBQUcsUUFBUSxDQUFDLEdBQUcsRUFBRSxDQUFDLElBQUksZ0JBQWdCLENBQUMsSUFBSSxDQUFDLFdBQVcsRUFBRSxDQUFDLENBQUMsQ0FBQztLQUNsRTtJQVBBLElBQXFDLFlBQVksQ0FBQyxXQUFtQjtRQUNwRSxJQUFJLENBQUMsTUFBTSxDQUFDLEdBQUcsQ0FBQyxFQUFFLFdBQVcsRUFBRSxDQUFDLENBQUM7SUFDbEMsQ0FBQzs4R0FQVyxjQUFjO2tHQUFkLGNBQWMsOEpBTmhCOztFQUVULDREQUNTLE9BQU87OzJGQUdMLGNBQWM7a0JBVDFCLFNBQVM7bUJBQUM7b0JBQ1YsUUFBUSxFQUFFLGlCQUFpQjtvQkFDM0IsVUFBVSxFQUFFLElBQUk7b0JBQ2hCLFFBQVEsRUFBRTs7RUFFVDtvQkFDRCxPQUFPLEVBQUUsQ0FBQyxPQUFPLENBQUM7b0JBQ2xCLE9BQU8sRUFBRSxDQUFDLHNCQUFzQixDQUFDO2lCQUNqQzs4QkFJUyxTQUFTO3NCQUFqQixLQUFLO2dCQUUrQixZQUFZO3NCQUFoRCxLQUFLO3VCQUFDLEVBQUUsS0FBSyxFQUFFLGFBQWEsRUFBRSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENVU1RPTV9FTEVNRU5UU19TQ0hFTUEsIENvbXBvbmVudCwgSW5wdXQsIGNvbXB1dGVkIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBOZ3RBcmdzLCBpbmplY3ROZ3RSZWYsIHNpZ25hbFN0b3JlIH0gZnJvbSAnYW5ndWxhci10aHJlZSc7XG5pbXBvcnQgeyBQaXhlbGF0aW9uRWZmZWN0IH0gZnJvbSAncG9zdHByb2Nlc3NpbmcnO1xuaW1wb3J0IHR5cGUgeyBOZ3RwRWZmZWN0U3RhdGUgfSBmcm9tICcuLi8uLi9lZmZlY3QnO1xuXG5leHBvcnQgdHlwZSBOZ3RwUGl4ZWxhdGlvblN0YXRlID0ge1xuXHRncmFudWxhcml0eTogbnVtYmVyO1xufTtcblxuZGVjbGFyZSBnbG9iYWwge1xuXHRpbnRlcmZhY2UgSFRNTEVsZW1lbnRUYWdOYW1lTWFwIHtcblx0XHQnbmd0cC1waXhlbGF0aW9uJzogTmd0cFBpeGVsYXRpb25TdGF0ZSAmIE5ndHBFZmZlY3RTdGF0ZTtcblx0fVxufVxuXG5AQ29tcG9uZW50KHtcblx0c2VsZWN0b3I6ICduZ3RwLXBpeGVsYXRpb24nLFxuXHRzdGFuZGFsb25lOiB0cnVlLFxuXHR0ZW1wbGF0ZTogYFxuXHRcdDxuZ3QtcHJpbWl0aXZlICphcmdzPVwiW2VmZmVjdCgpXVwiIFtyZWZdPVwiZWZmZWN0UmVmXCIgLz5cblx0YCxcblx0aW1wb3J0czogW05ndEFyZ3NdLFxuXHRzY2hlbWFzOiBbQ1VTVE9NX0VMRU1FTlRTX1NDSEVNQV0sXG59KVxuZXhwb3J0IGNsYXNzIE5ndHBQaXhlbGF0aW9uIHtcblx0cHJpdmF0ZSBpbnB1dHMgPSBzaWduYWxTdG9yZTxOZ3RwUGl4ZWxhdGlvblN0YXRlPih7IGdyYW51bGFyaXR5OiAzMCB9KTtcblxuXHRASW5wdXQoKSBlZmZlY3RSZWYgPSBpbmplY3ROZ3RSZWY8UGl4ZWxhdGlvbkVmZmVjdD4oKTtcblxuXHRASW5wdXQoeyBhbGlhczogJ2dyYW51bGFyaXR5JyB9KSBzZXQgX2dyYW51bGFyaXR5KGdyYW51bGFyaXR5OiBudW1iZXIpIHtcblx0XHR0aGlzLmlucHV0cy5zZXQoeyBncmFudWxhcml0eSB9KTtcblx0fVxuXG5cdHByaXZhdGUgZ3JhbnVsYXJpdHkgPSB0aGlzLmlucHV0cy5zZWxlY3QoJ2dyYW51bGFyaXR5Jyk7XG5cblx0ZWZmZWN0ID0gY29tcHV0ZWQoKCkgPT4gbmV3IFBpeGVsYXRpb25FZmZlY3QodGhpcy5ncmFudWxhcml0eSgpKSk7XG59XG4iXX0=
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
import { CUSTOM_ELEMENTS_SCHEMA, Component } from '@angular/core';
|
|
2
|
+
import { NgtArgs, extend } from 'angular-three';
|
|
3
|
+
import { BlendFunction, ScanlineEffect } from 'postprocessing';
|
|
4
|
+
import { NgtpEffect } from '../../effect';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
extend({ ScanlineEffect });
|
|
7
|
+
export class NgtpScanline extends NgtpEffect {
|
|
8
|
+
constructor() {
|
|
9
|
+
super(...arguments);
|
|
10
|
+
this.defaultBlendFunction = BlendFunction.OVERLAY;
|
|
11
|
+
}
|
|
12
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: NgtpScanline, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
|
|
13
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.3", type: NgtpScanline, isStandalone: true, selector: "ngtp-scanline", usesInheritance: true, ngImport: i0, template: `
|
|
14
|
+
<ngt-scanline-effect ngtCompound *args="args()" [camera]="camera()" [ref]="effectRef">
|
|
15
|
+
<ng-content />
|
|
16
|
+
</ngt-scanline-effect>
|
|
17
|
+
`, isInline: true, dependencies: [{ kind: "directive", type: NgtArgs, selector: "ng-template[args]", inputs: ["args"] }] }); }
|
|
18
|
+
}
|
|
19
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: NgtpScanline, decorators: [{
|
|
20
|
+
type: Component,
|
|
21
|
+
args: [{
|
|
22
|
+
selector: 'ngtp-scanline',
|
|
23
|
+
standalone: true,
|
|
24
|
+
template: `
|
|
25
|
+
<ngt-scanline-effect ngtCompound *args="args()" [camera]="camera()" [ref]="effectRef">
|
|
26
|
+
<ng-content />
|
|
27
|
+
</ngt-scanline-effect>
|
|
28
|
+
`,
|
|
29
|
+
imports: [NgtArgs],
|
|
30
|
+
schemas: [CUSTOM_ELEMENTS_SCHEMA],
|
|
31
|
+
}]
|
|
32
|
+
}] });
|
|
33
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2NhbmxpbmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL3Bvc3Rwcm9jZXNzaW5nL3NyYy9saWIvZWZmZWN0cy9zY2FubGluZS9zY2FubGluZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsU0FBUyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ2xFLE9BQU8sRUFBRSxPQUFPLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ2hELE9BQU8sRUFBRSxhQUFhLEVBQUUsY0FBYyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDL0QsT0FBTyxFQUFFLFVBQVUsRUFBd0IsTUFBTSxjQUFjLENBQUM7O0FBRWhFLE1BQU0sQ0FBQyxFQUFFLGNBQWMsRUFBRSxDQUFDLENBQUM7QUFtQjNCLE1BQU0sT0FBTyxZQUFhLFNBQVEsVUFBMEI7SUFYNUQ7O1FBWVUseUJBQW9CLEdBQUcsYUFBYSxDQUFDLE9BQU8sQ0FBQztLQUN0RDs4R0FGWSxZQUFZO2tHQUFaLFlBQVksZ0dBUmQ7Ozs7RUFJVCw0REFDUyxPQUFPOzsyRkFHTCxZQUFZO2tCQVh4QixTQUFTO21CQUFDO29CQUNWLFFBQVEsRUFBRSxlQUFlO29CQUN6QixVQUFVLEVBQUUsSUFBSTtvQkFDaEIsUUFBUSxFQUFFOzs7O0VBSVQ7b0JBQ0QsT0FBTyxFQUFFLENBQUMsT0FBTyxDQUFDO29CQUNsQixPQUFPLEVBQUUsQ0FBQyxzQkFBc0IsQ0FBQztpQkFDakMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDVVNUT01fRUxFTUVOVFNfU0NIRU1BLCBDb21wb25lbnQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IE5ndEFyZ3MsIGV4dGVuZCB9IGZyb20gJ2FuZ3VsYXItdGhyZWUnO1xuaW1wb3J0IHsgQmxlbmRGdW5jdGlvbiwgU2NhbmxpbmVFZmZlY3QgfSBmcm9tICdwb3N0cHJvY2Vzc2luZyc7XG5pbXBvcnQgeyBOZ3RwRWZmZWN0LCB0eXBlIE5ndHBFZmZlY3RTdGF0ZSB9IGZyb20gJy4uLy4uL2VmZmVjdCc7XG5cbmV4dGVuZCh7IFNjYW5saW5lRWZmZWN0IH0pO1xuXG5kZWNsYXJlIGdsb2JhbCB7XG5cdGludGVyZmFjZSBIVE1MRWxlbWVudFRhZ05hbWVNYXAge1xuXHRcdCduZ3RwLXNjYW5saW5lJzogeyBkZW5zaXR5PzogbnVtYmVyIH0gJiBOZ3RwRWZmZWN0U3RhdGU7XG5cdH1cbn1cblxuQENvbXBvbmVudCh7XG5cdHNlbGVjdG9yOiAnbmd0cC1zY2FubGluZScsXG5cdHN0YW5kYWxvbmU6IHRydWUsXG5cdHRlbXBsYXRlOiBgXG5cdFx0PG5ndC1zY2FubGluZS1lZmZlY3Qgbmd0Q29tcG91bmQgKmFyZ3M9XCJhcmdzKClcIiBbY2FtZXJhXT1cImNhbWVyYSgpXCIgW3JlZl09XCJlZmZlY3RSZWZcIj5cblx0XHRcdDxuZy1jb250ZW50IC8+XG5cdFx0PC9uZ3Qtc2NhbmxpbmUtZWZmZWN0PlxuXHRgLFxuXHRpbXBvcnRzOiBbTmd0QXJnc10sXG5cdHNjaGVtYXM6IFtDVVNUT01fRUxFTUVOVFNfU0NIRU1BXSxcbn0pXG5leHBvcnQgY2xhc3MgTmd0cFNjYW5saW5lIGV4dGVuZHMgTmd0cEVmZmVjdDxTY2FubGluZUVmZmVjdD4ge1xuXHRvdmVycmlkZSBkZWZhdWx0QmxlbmRGdW5jdGlvbiA9IEJsZW5kRnVuY3Rpb24uT1ZFUkxBWTtcbn1cbiJdfQ==
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import { CUSTOM_ELEMENTS_SCHEMA, Component } from '@angular/core';
|
|
2
|
+
import { NgtArgs, extend } from 'angular-three';
|
|
3
|
+
import { SepiaEffect } from 'postprocessing';
|
|
4
|
+
import { NgtpEffect } from '../../effect';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
extend({ SepiaEffect });
|
|
7
|
+
export class NgtpSepia extends NgtpEffect {
|
|
8
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: NgtpSepia, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
|
|
9
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.3", type: NgtpSepia, isStandalone: true, selector: "ngtp-sepia", usesInheritance: true, ngImport: i0, template: `
|
|
10
|
+
<ngt-sepia-effect ngtCompound *args="args()" [camera]="camera()" [ref]="effectRef">
|
|
11
|
+
<ng-content />
|
|
12
|
+
</ngt-sepia-effect>
|
|
13
|
+
`, isInline: true, dependencies: [{ kind: "directive", type: NgtArgs, selector: "ng-template[args]", inputs: ["args"] }] }); }
|
|
14
|
+
}
|
|
15
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: NgtpSepia, decorators: [{
|
|
16
|
+
type: Component,
|
|
17
|
+
args: [{
|
|
18
|
+
selector: 'ngtp-sepia',
|
|
19
|
+
standalone: true,
|
|
20
|
+
template: `
|
|
21
|
+
<ngt-sepia-effect ngtCompound *args="args()" [camera]="camera()" [ref]="effectRef">
|
|
22
|
+
<ng-content />
|
|
23
|
+
</ngt-sepia-effect>
|
|
24
|
+
`,
|
|
25
|
+
imports: [NgtArgs],
|
|
26
|
+
schemas: [CUSTOM_ELEMENTS_SCHEMA],
|
|
27
|
+
}]
|
|
28
|
+
}] });
|
|
29
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VwaWEuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL3Bvc3Rwcm9jZXNzaW5nL3NyYy9saWIvZWZmZWN0cy9zZXBpYS9zZXBpYS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsU0FBUyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ2xFLE9BQU8sRUFBRSxPQUFPLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ2hELE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUM3QyxPQUFPLEVBQUUsVUFBVSxFQUF3QixNQUFNLGNBQWMsQ0FBQzs7QUFFaEUsTUFBTSxDQUFDLEVBQUUsV0FBVyxFQUFFLENBQUMsQ0FBQztBQW1CeEIsTUFBTSxPQUFPLFNBQVUsU0FBUSxVQUF1Qjs4R0FBekMsU0FBUztrR0FBVCxTQUFTLDZGQVJYOzs7O0VBSVQsNERBQ1MsT0FBTzs7MkZBR0wsU0FBUztrQkFYckIsU0FBUzttQkFBQztvQkFDVixRQUFRLEVBQUUsWUFBWTtvQkFDdEIsVUFBVSxFQUFFLElBQUk7b0JBQ2hCLFFBQVEsRUFBRTs7OztFQUlUO29CQUNELE9BQU8sRUFBRSxDQUFDLE9BQU8sQ0FBQztvQkFDbEIsT0FBTyxFQUFFLENBQUMsc0JBQXNCLENBQUM7aUJBQ2pDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ1VTVE9NX0VMRU1FTlRTX1NDSEVNQSwgQ29tcG9uZW50IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBOZ3RBcmdzLCBleHRlbmQgfSBmcm9tICdhbmd1bGFyLXRocmVlJztcbmltcG9ydCB7IFNlcGlhRWZmZWN0IH0gZnJvbSAncG9zdHByb2Nlc3NpbmcnO1xuaW1wb3J0IHsgTmd0cEVmZmVjdCwgdHlwZSBOZ3RwRWZmZWN0U3RhdGUgfSBmcm9tICcuLi8uLi9lZmZlY3QnO1xuXG5leHRlbmQoeyBTZXBpYUVmZmVjdCB9KTtcblxuZGVjbGFyZSBnbG9iYWwge1xuXHRpbnRlcmZhY2UgSFRNTEVsZW1lbnRUYWdOYW1lTWFwIHtcblx0XHQnbmd0cC1zZXBpYSc6IHsgaW50ZW5zaXR5PzogbnVtYmVyIH0gJiBOZ3RwRWZmZWN0U3RhdGU7XG5cdH1cbn1cblxuQENvbXBvbmVudCh7XG5cdHNlbGVjdG9yOiAnbmd0cC1zZXBpYScsXG5cdHN0YW5kYWxvbmU6IHRydWUsXG5cdHRlbXBsYXRlOiBgXG5cdFx0PG5ndC1zZXBpYS1lZmZlY3Qgbmd0Q29tcG91bmQgKmFyZ3M9XCJhcmdzKClcIiBbY2FtZXJhXT1cImNhbWVyYSgpXCIgW3JlZl09XCJlZmZlY3RSZWZcIj5cblx0XHRcdDxuZy1jb250ZW50IC8+XG5cdFx0PC9uZ3Qtc2VwaWEtZWZmZWN0PlxuXHRgLFxuXHRpbXBvcnRzOiBbTmd0QXJnc10sXG5cdHNjaGVtYXM6IFtDVVNUT01fRUxFTUVOVFNfU0NIRU1BXSxcbn0pXG5leHBvcnQgY2xhc3MgTmd0cFNlcGlhIGV4dGVuZHMgTmd0cEVmZmVjdDxTZXBpYUVmZmVjdD4ge31cbiJdfQ==
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import { CUSTOM_ELEMENTS_SCHEMA, Component } from '@angular/core';
|
|
2
|
+
import { NgtArgs, extend } from 'angular-three';
|
|
3
|
+
import { ShockWaveEffect } from 'postprocessing';
|
|
4
|
+
import { NgtpEffect } from '../../effect';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
extend({ ShockWaveEffect });
|
|
7
|
+
export class NgtpShockWave extends NgtpEffect {
|
|
8
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: NgtpShockWave, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
|
|
9
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.3", type: NgtpShockWave, isStandalone: true, selector: "ngtp-shock-wave", usesInheritance: true, ngImport: i0, template: `
|
|
10
|
+
<ngt-shock-wave-effect ngtCompound *args="args()" [camera]="camera()" [ref]="effectRef">
|
|
11
|
+
<ng-content />
|
|
12
|
+
</ngt-shock-wave-effect>
|
|
13
|
+
`, isInline: true, dependencies: [{ kind: "directive", type: NgtArgs, selector: "ng-template[args]", inputs: ["args"] }] }); }
|
|
14
|
+
}
|
|
15
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: NgtpShockWave, decorators: [{
|
|
16
|
+
type: Component,
|
|
17
|
+
args: [{
|
|
18
|
+
selector: 'ngtp-shock-wave',
|
|
19
|
+
standalone: true,
|
|
20
|
+
template: `
|
|
21
|
+
<ngt-shock-wave-effect ngtCompound *args="args()" [camera]="camera()" [ref]="effectRef">
|
|
22
|
+
<ng-content />
|
|
23
|
+
</ngt-shock-wave-effect>
|
|
24
|
+
`,
|
|
25
|
+
imports: [NgtArgs],
|
|
26
|
+
schemas: [CUSTOM_ELEMENTS_SCHEMA],
|
|
27
|
+
}]
|
|
28
|
+
}] });
|
|
29
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2hvY2std2F2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvcG9zdHByb2Nlc3Npbmcvc3JjL2xpYi9lZmZlY3RzL3Nob2NrLXdhdmUvc2hvY2std2F2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsU0FBUyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ2xFLE9BQU8sRUFBRSxPQUFPLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ2hELE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUNqRCxPQUFPLEVBQUUsVUFBVSxFQUF3QixNQUFNLGNBQWMsQ0FBQzs7QUFFaEUsTUFBTSxDQUFDLEVBQUUsZUFBZSxFQUFFLENBQUMsQ0FBQztBQXdCNUIsTUFBTSxPQUFPLGFBQWMsU0FBUSxVQUEyQjs4R0FBakQsYUFBYTtrR0FBYixhQUFhLGtHQVJmOzs7O0VBSVQsNERBQ1MsT0FBTzs7MkZBR0wsYUFBYTtrQkFYekIsU0FBUzttQkFBQztvQkFDVixRQUFRLEVBQUUsaUJBQWlCO29CQUMzQixVQUFVLEVBQUUsSUFBSTtvQkFDaEIsUUFBUSxFQUFFOzs7O0VBSVQ7b0JBQ0QsT0FBTyxFQUFFLENBQUMsT0FBTyxDQUFDO29CQUNsQixPQUFPLEVBQUUsQ0FBQyxzQkFBc0IsQ0FBQztpQkFDakMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDVVNUT01fRUxFTUVOVFNfU0NIRU1BLCBDb21wb25lbnQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IE5ndEFyZ3MsIGV4dGVuZCB9IGZyb20gJ2FuZ3VsYXItdGhyZWUnO1xuaW1wb3J0IHsgU2hvY2tXYXZlRWZmZWN0IH0gZnJvbSAncG9zdHByb2Nlc3NpbmcnO1xuaW1wb3J0IHsgTmd0cEVmZmVjdCwgdHlwZSBOZ3RwRWZmZWN0U3RhdGUgfSBmcm9tICcuLi8uLi9lZmZlY3QnO1xuXG5leHRlbmQoeyBTaG9ja1dhdmVFZmZlY3QgfSk7XG5cbmRlY2xhcmUgZ2xvYmFsIHtcblx0aW50ZXJmYWNlIEhUTUxFbGVtZW50VGFnTmFtZU1hcCB7XG5cdFx0J25ndHAtc2hvY2std2F2ZSc6IHtcblx0XHRcdHNwZWVkPzogbnVtYmVyO1xuXHRcdFx0bWF4UmFkaXVzPzogbnVtYmVyO1xuXHRcdFx0d2F2ZVNpemU/OiBudW1iZXI7XG5cdFx0XHRhbXBsaXR1ZGU/OiBudW1iZXI7XG5cdFx0fSAmIE5ndHBFZmZlY3RTdGF0ZTtcblx0fVxufVxuXG5AQ29tcG9uZW50KHtcblx0c2VsZWN0b3I6ICduZ3RwLXNob2NrLXdhdmUnLFxuXHRzdGFuZGFsb25lOiB0cnVlLFxuXHR0ZW1wbGF0ZTogYFxuXHRcdDxuZ3Qtc2hvY2std2F2ZS1lZmZlY3Qgbmd0Q29tcG91bmQgKmFyZ3M9XCJhcmdzKClcIiBbY2FtZXJhXT1cImNhbWVyYSgpXCIgW3JlZl09XCJlZmZlY3RSZWZcIj5cblx0XHRcdDxuZy1jb250ZW50IC8+XG5cdFx0PC9uZ3Qtc2hvY2std2F2ZS1lZmZlY3Q+XG5cdGAsXG5cdGltcG9ydHM6IFtOZ3RBcmdzXSxcblx0c2NoZW1hczogW0NVU1RPTV9FTEVNRU5UU19TQ0hFTUFdLFxufSlcbmV4cG9ydCBjbGFzcyBOZ3RwU2hvY2tXYXZlIGV4dGVuZHMgTmd0cEVmZmVjdDxTaG9ja1dhdmVFZmZlY3Q+IHt9XG4iXX0=
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import { CUSTOM_ELEMENTS_SCHEMA, Component } from '@angular/core';
|
|
2
|
+
import { NgtArgs, extend } from 'angular-three';
|
|
3
|
+
import { EdgeDetectionMode, PredicationMode, SMAAEffect, SMAAPreset } from 'postprocessing';
|
|
4
|
+
import { NgtpEffect } from '../../effect';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
extend({ SMAAEffect });
|
|
7
|
+
export class NgtpSMAA extends NgtpEffect {
|
|
8
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: NgtpSMAA, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
|
|
9
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.3", type: NgtpSMAA, isStandalone: true, selector: "ngtp-SMAA", usesInheritance: true, ngImport: i0, template: `
|
|
10
|
+
<ngt-SMAA-effect ngtCompound *args="args()" [camera]="camera()" [ref]="effectRef">
|
|
11
|
+
<ng-content />
|
|
12
|
+
</ngt-SMAA-effect>
|
|
13
|
+
`, isInline: true, dependencies: [{ kind: "directive", type: NgtArgs, selector: "ng-template[args]", inputs: ["args"] }] }); }
|
|
14
|
+
}
|
|
15
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: NgtpSMAA, decorators: [{
|
|
16
|
+
type: Component,
|
|
17
|
+
args: [{
|
|
18
|
+
selector: 'ngtp-SMAA',
|
|
19
|
+
standalone: true,
|
|
20
|
+
template: `
|
|
21
|
+
<ngt-SMAA-effect ngtCompound *args="args()" [camera]="camera()" [ref]="effectRef">
|
|
22
|
+
<ng-content />
|
|
23
|
+
</ngt-SMAA-effect>
|
|
24
|
+
`,
|
|
25
|
+
imports: [NgtArgs],
|
|
26
|
+
schemas: [CUSTOM_ELEMENTS_SCHEMA],
|
|
27
|
+
}]
|
|
28
|
+
}] });
|
|
29
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic21hYS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvcG9zdHByb2Nlc3Npbmcvc3JjL2xpYi9lZmZlY3RzL3NtYWEvc21hYS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsU0FBUyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ2xFLE9BQU8sRUFBRSxPQUFPLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ2hELE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxlQUFlLEVBQUUsVUFBVSxFQUFFLFVBQVUsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQzVGLE9BQU8sRUFBRSxVQUFVLEVBQXdCLE1BQU0sY0FBYyxDQUFDOztBQUVoRSxNQUFNLENBQUMsRUFBRSxVQUFVLEVBQUUsQ0FBQyxDQUFDO0FBdUJ2QixNQUFNLE9BQU8sUUFBUyxTQUFRLFVBQXNCOzhHQUF2QyxRQUFRO2tHQUFSLFFBQVEsNEZBUlY7Ozs7RUFJVCw0REFDUyxPQUFPOzsyRkFHTCxRQUFRO2tCQVhwQixTQUFTO21CQUFDO29CQUNWLFFBQVEsRUFBRSxXQUFXO29CQUNyQixVQUFVLEVBQUUsSUFBSTtvQkFDaEIsUUFBUSxFQUFFOzs7O0VBSVQ7b0JBQ0QsT0FBTyxFQUFFLENBQUMsT0FBTyxDQUFDO29CQUNsQixPQUFPLEVBQUUsQ0FBQyxzQkFBc0IsQ0FBQztpQkFDakMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDVVNUT01fRUxFTUVOVFNfU0NIRU1BLCBDb21wb25lbnQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IE5ndEFyZ3MsIGV4dGVuZCB9IGZyb20gJ2FuZ3VsYXItdGhyZWUnO1xuaW1wb3J0IHsgRWRnZURldGVjdGlvbk1vZGUsIFByZWRpY2F0aW9uTW9kZSwgU01BQUVmZmVjdCwgU01BQVByZXNldCB9IGZyb20gJ3Bvc3Rwcm9jZXNzaW5nJztcbmltcG9ydCB7IE5ndHBFZmZlY3QsIHR5cGUgTmd0cEVmZmVjdFN0YXRlIH0gZnJvbSAnLi4vLi4vZWZmZWN0JztcblxuZXh0ZW5kKHsgU01BQUVmZmVjdCB9KTtcblxuZGVjbGFyZSBnbG9iYWwge1xuXHRpbnRlcmZhY2UgSFRNTEVsZW1lbnRUYWdOYW1lTWFwIHtcblx0XHQnbmd0cC1TTUFBJzoge1xuXHRcdFx0cHJlc2V0PzogU01BQVByZXNldDtcblx0XHRcdGVkZ2VEZXRlY3Rpb25Nb2RlPzogRWRnZURldGVjdGlvbk1vZGU7XG5cdFx0XHRwcmVkaWNhdGlvbk1vZGU/OiBQcmVkaWNhdGlvbk1vZGU7XG5cdFx0fSAmIE5ndHBFZmZlY3RTdGF0ZTtcblx0fVxufVxuXG5AQ29tcG9uZW50KHtcblx0c2VsZWN0b3I6ICduZ3RwLVNNQUEnLFxuXHRzdGFuZGFsb25lOiB0cnVlLFxuXHR0ZW1wbGF0ZTogYFxuXHRcdDxuZ3QtU01BQS1lZmZlY3Qgbmd0Q29tcG91bmQgKmFyZ3M9XCJhcmdzKClcIiBbY2FtZXJhXT1cImNhbWVyYSgpXCIgW3JlZl09XCJlZmZlY3RSZWZcIj5cblx0XHRcdDxuZy1jb250ZW50IC8+XG5cdFx0PC9uZ3QtU01BQS1lZmZlY3Q+XG5cdGAsXG5cdGltcG9ydHM6IFtOZ3RBcmdzXSxcblx0c2NoZW1hczogW0NVU1RPTV9FTEVNRU5UU19TQ0hFTUFdLFxufSlcbmV4cG9ydCBjbGFzcyBOZ3RwU01BQSBleHRlbmRzIE5ndHBFZmZlY3Q8U01BQUVmZmVjdD4ge31cbiJdfQ==
|
|
@@ -0,0 +1,217 @@
|
|
|
1
|
+
import { CUSTOM_ELEMENTS_SCHEMA, Component, Input, computed } from '@angular/core';
|
|
2
|
+
import { NgtArgs, injectNgtRef, signalStore } from 'angular-three';
|
|
3
|
+
import { BlendFunction, SSAOEffect } from 'postprocessing';
|
|
4
|
+
import { injectNgtpEffectComposerApi } from '../../effect-composer';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
export class NgtpSSAO {
|
|
7
|
+
constructor() {
|
|
8
|
+
this.inputs = signalStore({
|
|
9
|
+
blendFunction: BlendFunction.MULTIPLY,
|
|
10
|
+
samples: 30,
|
|
11
|
+
rings: 4,
|
|
12
|
+
distanceThreshold: 1.0,
|
|
13
|
+
distanceFalloff: 0.0,
|
|
14
|
+
rangeThreshold: 0.5,
|
|
15
|
+
rangeFalloff: 0.1,
|
|
16
|
+
luminanceInfluence: 0.9,
|
|
17
|
+
radius: 20,
|
|
18
|
+
bias: 0.5,
|
|
19
|
+
intensity: 1.0,
|
|
20
|
+
depthAwareUpsampling: true,
|
|
21
|
+
});
|
|
22
|
+
this.effectRef = injectNgtRef();
|
|
23
|
+
this.effectComposerApi = injectNgtpEffectComposerApi();
|
|
24
|
+
this.effect = computed(() => {
|
|
25
|
+
const [state, { camera, normalPass, downSamplingPass, resolutionScale }] = [
|
|
26
|
+
this.inputs.state(),
|
|
27
|
+
this.effectComposerApi(),
|
|
28
|
+
];
|
|
29
|
+
if (normalPass === null && downSamplingPass === null) {
|
|
30
|
+
console.error('Please enable the NormalPass in the NgtpEffectComposer in order to use NgtpSSAO.');
|
|
31
|
+
return null;
|
|
32
|
+
}
|
|
33
|
+
return new SSAOEffect(camera, normalPass && !downSamplingPass ? normalPass.texture : null, {
|
|
34
|
+
...state,
|
|
35
|
+
// @ts-expect-error
|
|
36
|
+
normalDepthBuffer: state.normalDepthBuffer || (downSamplingPass ? downSamplingPass.texture : null),
|
|
37
|
+
resolutionScale: state.resolutionScale || (resolutionScale ?? 1),
|
|
38
|
+
depthAwareUpsampling: state.depthAwareUpsampling ?? true,
|
|
39
|
+
});
|
|
40
|
+
});
|
|
41
|
+
}
|
|
42
|
+
set _blendFunction(blendFunction) {
|
|
43
|
+
this.inputs.set({ blendFunction });
|
|
44
|
+
}
|
|
45
|
+
set _distanceScaling(distanceScaling) {
|
|
46
|
+
this.inputs.set({ distanceScaling });
|
|
47
|
+
}
|
|
48
|
+
set _depthAwareUpsampling(depthAwareUpsampling) {
|
|
49
|
+
this.inputs.set({ depthAwareUpsampling });
|
|
50
|
+
}
|
|
51
|
+
set _normalDepthBuffer(normalDepthBuffer) {
|
|
52
|
+
this.inputs.set({ normalDepthBuffer });
|
|
53
|
+
}
|
|
54
|
+
set _samples(samples) {
|
|
55
|
+
this.inputs.set({ samples });
|
|
56
|
+
}
|
|
57
|
+
set _rings(rings) {
|
|
58
|
+
this.inputs.set({ rings });
|
|
59
|
+
}
|
|
60
|
+
set _worldDistanceThreshold(worldDistanceThreshold) {
|
|
61
|
+
this.inputs.set({ worldDistanceThreshold });
|
|
62
|
+
}
|
|
63
|
+
set _worldDistanceFalloff(worldDistanceFalloff) {
|
|
64
|
+
this.inputs.set({ worldDistanceFalloff });
|
|
65
|
+
}
|
|
66
|
+
set _worldProximityThreshold(worldProximityThreshold) {
|
|
67
|
+
this.inputs.set({ worldProximityThreshold });
|
|
68
|
+
}
|
|
69
|
+
set _worldProximityFalloff(worldProximityFalloff) {
|
|
70
|
+
this.inputs.set({ worldProximityFalloff });
|
|
71
|
+
}
|
|
72
|
+
set _distanceThreshold(distanceThreshold) {
|
|
73
|
+
this.inputs.set({ distanceThreshold });
|
|
74
|
+
}
|
|
75
|
+
set _distanceFalloff(distanceFalloff) {
|
|
76
|
+
this.inputs.set({ distanceFalloff });
|
|
77
|
+
}
|
|
78
|
+
set _rangeThreshold(rangeThreshold) {
|
|
79
|
+
this.inputs.set({ rangeThreshold });
|
|
80
|
+
}
|
|
81
|
+
set _rangeFalloff(rangeFalloff) {
|
|
82
|
+
this.inputs.set({ rangeFalloff });
|
|
83
|
+
}
|
|
84
|
+
set _minRadiusScale(minRadiusScale) {
|
|
85
|
+
this.inputs.set({ minRadiusScale });
|
|
86
|
+
}
|
|
87
|
+
set _luminanceInfluence(luminanceInfluence) {
|
|
88
|
+
this.inputs.set({ luminanceInfluence });
|
|
89
|
+
}
|
|
90
|
+
set _radius(radius) {
|
|
91
|
+
this.inputs.set({ radius });
|
|
92
|
+
}
|
|
93
|
+
set _intensity(intensity) {
|
|
94
|
+
this.inputs.set({ intensity });
|
|
95
|
+
}
|
|
96
|
+
set _bias(bias) {
|
|
97
|
+
this.inputs.set({ bias });
|
|
98
|
+
}
|
|
99
|
+
set _fade(fade) {
|
|
100
|
+
this.inputs.set({ fade });
|
|
101
|
+
}
|
|
102
|
+
set _color(color) {
|
|
103
|
+
this.inputs.set({ color });
|
|
104
|
+
}
|
|
105
|
+
set _resolutionScale(resolutionScale) {
|
|
106
|
+
this.inputs.set({ resolutionScale });
|
|
107
|
+
}
|
|
108
|
+
set _resolutionX(resolutionX) {
|
|
109
|
+
this.inputs.set({ resolutionX });
|
|
110
|
+
}
|
|
111
|
+
set _resolutionY(resolutionY) {
|
|
112
|
+
this.inputs.set({ resolutionY });
|
|
113
|
+
}
|
|
114
|
+
set _width(width) {
|
|
115
|
+
this.inputs.set({ width });
|
|
116
|
+
}
|
|
117
|
+
set _height(height) {
|
|
118
|
+
this.inputs.set({ height });
|
|
119
|
+
}
|
|
120
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: NgtpSSAO, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
121
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.3", type: NgtpSSAO, isStandalone: true, selector: "ngtp-SSAO", inputs: { effectRef: "effectRef", _blendFunction: ["blendFunction", "_blendFunction"], _distanceScaling: ["distanceScaling", "_distanceScaling"], _depthAwareUpsampling: ["depthAwareUpsampling", "_depthAwareUpsampling"], _normalDepthBuffer: ["normalDepthBuffer", "_normalDepthBuffer"], _samples: ["samples", "_samples"], _rings: ["rings", "_rings"], _worldDistanceThreshold: ["worldDistanceThreshold", "_worldDistanceThreshold"], _worldDistanceFalloff: ["worldDistanceFalloff", "_worldDistanceFalloff"], _worldProximityThreshold: ["worldProximityThreshold", "_worldProximityThreshold"], _worldProximityFalloff: ["worldProximityFalloff", "_worldProximityFalloff"], _distanceThreshold: ["distanceThreshold", "_distanceThreshold"], _distanceFalloff: ["distanceFalloff", "_distanceFalloff"], _rangeThreshold: ["rangeThreshold", "_rangeThreshold"], _rangeFalloff: ["rangeFalloff", "_rangeFalloff"], _minRadiusScale: ["minRadiusScale", "_minRadiusScale"], _luminanceInfluence: ["luminanceInfluence", "_luminanceInfluence"], _radius: ["radius", "_radius"], _intensity: ["intensity", "_intensity"], _bias: ["bias", "_bias"], _fade: ["fade", "_fade"], _color: ["color", "_color"], _resolutionScale: ["resolutionScale", "_resolutionScale"], _resolutionX: ["resolutionX", "_resolutionX"], _resolutionY: ["resolutionY", "_resolutionY"], _width: ["width", "_width"], _height: ["height", "_height"] }, ngImport: i0, template: `
|
|
122
|
+
<ngt-primitive *args="[effect()]" [ref]="effectRef" />
|
|
123
|
+
`, isInline: true, dependencies: [{ kind: "directive", type: NgtArgs, selector: "ng-template[args]", inputs: ["args"] }] }); }
|
|
124
|
+
}
|
|
125
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: NgtpSSAO, decorators: [{
|
|
126
|
+
type: Component,
|
|
127
|
+
args: [{
|
|
128
|
+
selector: 'ngtp-SSAO',
|
|
129
|
+
standalone: true,
|
|
130
|
+
template: `
|
|
131
|
+
<ngt-primitive *args="[effect()]" [ref]="effectRef" />
|
|
132
|
+
`,
|
|
133
|
+
imports: [NgtArgs],
|
|
134
|
+
schemas: [CUSTOM_ELEMENTS_SCHEMA],
|
|
135
|
+
}]
|
|
136
|
+
}], propDecorators: { effectRef: [{
|
|
137
|
+
type: Input
|
|
138
|
+
}], _blendFunction: [{
|
|
139
|
+
type: Input,
|
|
140
|
+
args: [{ alias: 'blendFunction' }]
|
|
141
|
+
}], _distanceScaling: [{
|
|
142
|
+
type: Input,
|
|
143
|
+
args: [{ alias: 'distanceScaling' }]
|
|
144
|
+
}], _depthAwareUpsampling: [{
|
|
145
|
+
type: Input,
|
|
146
|
+
args: [{ alias: 'depthAwareUpsampling' }]
|
|
147
|
+
}], _normalDepthBuffer: [{
|
|
148
|
+
type: Input,
|
|
149
|
+
args: [{ alias: 'normalDepthBuffer' }]
|
|
150
|
+
}], _samples: [{
|
|
151
|
+
type: Input,
|
|
152
|
+
args: [{ alias: 'samples' }]
|
|
153
|
+
}], _rings: [{
|
|
154
|
+
type: Input,
|
|
155
|
+
args: [{ alias: 'rings' }]
|
|
156
|
+
}], _worldDistanceThreshold: [{
|
|
157
|
+
type: Input,
|
|
158
|
+
args: [{ alias: 'worldDistanceThreshold' }]
|
|
159
|
+
}], _worldDistanceFalloff: [{
|
|
160
|
+
type: Input,
|
|
161
|
+
args: [{ alias: 'worldDistanceFalloff' }]
|
|
162
|
+
}], _worldProximityThreshold: [{
|
|
163
|
+
type: Input,
|
|
164
|
+
args: [{ alias: 'worldProximityThreshold' }]
|
|
165
|
+
}], _worldProximityFalloff: [{
|
|
166
|
+
type: Input,
|
|
167
|
+
args: [{ alias: 'worldProximityFalloff' }]
|
|
168
|
+
}], _distanceThreshold: [{
|
|
169
|
+
type: Input,
|
|
170
|
+
args: [{ alias: 'distanceThreshold' }]
|
|
171
|
+
}], _distanceFalloff: [{
|
|
172
|
+
type: Input,
|
|
173
|
+
args: [{ alias: 'distanceFalloff' }]
|
|
174
|
+
}], _rangeThreshold: [{
|
|
175
|
+
type: Input,
|
|
176
|
+
args: [{ alias: 'rangeThreshold' }]
|
|
177
|
+
}], _rangeFalloff: [{
|
|
178
|
+
type: Input,
|
|
179
|
+
args: [{ alias: 'rangeFalloff' }]
|
|
180
|
+
}], _minRadiusScale: [{
|
|
181
|
+
type: Input,
|
|
182
|
+
args: [{ alias: 'minRadiusScale' }]
|
|
183
|
+
}], _luminanceInfluence: [{
|
|
184
|
+
type: Input,
|
|
185
|
+
args: [{ alias: 'luminanceInfluence' }]
|
|
186
|
+
}], _radius: [{
|
|
187
|
+
type: Input,
|
|
188
|
+
args: [{ alias: 'radius' }]
|
|
189
|
+
}], _intensity: [{
|
|
190
|
+
type: Input,
|
|
191
|
+
args: [{ alias: 'intensity' }]
|
|
192
|
+
}], _bias: [{
|
|
193
|
+
type: Input,
|
|
194
|
+
args: [{ alias: 'bias' }]
|
|
195
|
+
}], _fade: [{
|
|
196
|
+
type: Input,
|
|
197
|
+
args: [{ alias: 'fade' }]
|
|
198
|
+
}], _color: [{
|
|
199
|
+
type: Input,
|
|
200
|
+
args: [{ alias: 'color' }]
|
|
201
|
+
}], _resolutionScale: [{
|
|
202
|
+
type: Input,
|
|
203
|
+
args: [{ alias: 'resolutionScale' }]
|
|
204
|
+
}], _resolutionX: [{
|
|
205
|
+
type: Input,
|
|
206
|
+
args: [{ alias: 'resolutionX' }]
|
|
207
|
+
}], _resolutionY: [{
|
|
208
|
+
type: Input,
|
|
209
|
+
args: [{ alias: 'resolutionY' }]
|
|
210
|
+
}], _width: [{
|
|
211
|
+
type: Input,
|
|
212
|
+
args: [{ alias: 'width' }]
|
|
213
|
+
}], _height: [{
|
|
214
|
+
type: Input,
|
|
215
|
+
args: [{ alias: 'height' }]
|
|
216
|
+
}] } });
|
|
217
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ssao.js","sourceRoot":"","sources":["../../../../../../../libs/postprocessing/src/lib/effects/ssao/ssao.ts"],"names":[],"mappings":"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","sourcesContent":["import { CUSTOM_ELEMENTS_SCHEMA, Component, Input, computed } from '@angular/core';\nimport { NgtArgs, injectNgtRef, signalStore } from 'angular-three';\nimport { BlendFunction, SSAOEffect } from 'postprocessing';\nimport { injectNgtpEffectComposerApi } from '../../effect-composer';\n\n// first two args are camera and texture\nexport type NgtpSSAOState = NonNullable<ConstructorParameters<typeof SSAOEffect>[2]>;\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'ngtp-SSAO': NgtpSSAOState;\n\t}\n}\n\n@Component({\n\tselector: 'ngtp-SSAO',\n\tstandalone: true,\n\ttemplate: `\n\t\t<ngt-primitive *args=\"[effect()]\" [ref]=\"effectRef\" />\n\t`,\n\timports: [NgtArgs],\n\tschemas: [CUSTOM_ELEMENTS_SCHEMA],\n})\nexport class NgtpSSAO {\n\tprivate inputs = signalStore<NgtpSSAOState>({\n\t\tblendFunction: BlendFunction.MULTIPLY,\n\t\tsamples: 30,\n\t\trings: 4,\n\t\tdistanceThreshold: 1.0,\n\t\tdistanceFalloff: 0.0,\n\t\trangeThreshold: 0.5,\n\t\trangeFalloff: 0.1,\n\t\tluminanceInfluence: 0.9,\n\t\tradius: 20,\n\t\tbias: 0.5,\n\t\tintensity: 1.0,\n\t\tdepthAwareUpsampling: true,\n\t});\n\n\t@Input() effectRef = injectNgtRef<SSAOEffect>();\n\n\t@Input({ alias: 'blendFunction' }) set _blendFunction(blendFunction: BlendFunction) {\n\t\tthis.inputs.set({ blendFunction });\n\t}\n\n\t@Input({ alias: 'distanceScaling' }) set _distanceScaling(distanceScaling: boolean) {\n\t\tthis.inputs.set({ distanceScaling });\n\t}\n\n\t@Input({ alias: 'depthAwareUpsampling' }) set _depthAwareUpsampling(depthAwareUpsampling: boolean) {\n\t\tthis.inputs.set({ depthAwareUpsampling });\n\t}\n\n\t@Input({ alias: 'normalDepthBuffer' }) set _normalDepthBuffer(normalDepthBuffer: THREE.Texture) {\n\t\tthis.inputs.set({ normalDepthBuffer });\n\t}\n\n\t@Input({ alias: 'samples' }) set _samples(samples: number) {\n\t\tthis.inputs.set({ samples });\n\t}\n\n\t@Input({ alias: 'rings' }) set _rings(rings: number) {\n\t\tthis.inputs.set({ rings });\n\t}\n\n\t@Input({ alias: 'worldDistanceThreshold' }) set _worldDistanceThreshold(worldDistanceThreshold: number) {\n\t\tthis.inputs.set({ worldDistanceThreshold });\n\t}\n\n\t@Input({ alias: 'worldDistanceFalloff' }) set _worldDistanceFalloff(worldDistanceFalloff: number) {\n\t\tthis.inputs.set({ worldDistanceFalloff });\n\t}\n\n\t@Input({ alias: 'worldProximityThreshold' }) set _worldProximityThreshold(worldProximityThreshold: number) {\n\t\tthis.inputs.set({ worldProximityThreshold });\n\t}\n\n\t@Input({ alias: 'worldProximityFalloff' }) set _worldProximityFalloff(worldProximityFalloff: number) {\n\t\tthis.inputs.set({ worldProximityFalloff });\n\t}\n\n\t@Input({ alias: 'distanceThreshold' }) set _distanceThreshold(distanceThreshold: number) {\n\t\tthis.inputs.set({ distanceThreshold });\n\t}\n\n\t@Input({ alias: 'distanceFalloff' }) set _distanceFalloff(distanceFalloff: number) {\n\t\tthis.inputs.set({ distanceFalloff });\n\t}\n\n\t@Input({ alias: 'rangeThreshold' }) set _rangeThreshold(rangeThreshold: number) {\n\t\tthis.inputs.set({ rangeThreshold });\n\t}\n\n\t@Input({ alias: 'rangeFalloff' }) set _rangeFalloff(rangeFalloff: number) {\n\t\tthis.inputs.set({ rangeFalloff });\n\t}\n\n\t@Input({ alias: 'minRadiusScale' }) set _minRadiusScale(minRadiusScale: number) {\n\t\tthis.inputs.set({ minRadiusScale });\n\t}\n\n\t@Input({ alias: 'luminanceInfluence' }) set _luminanceInfluence(luminanceInfluence: number) {\n\t\tthis.inputs.set({ luminanceInfluence });\n\t}\n\n\t@Input({ alias: 'radius' }) set _radius(radius: number) {\n\t\tthis.inputs.set({ radius });\n\t}\n\n\t@Input({ alias: 'intensity' }) set _intensity(intensity: number) {\n\t\tthis.inputs.set({ intensity });\n\t}\n\n\t@Input({ alias: 'bias' }) set _bias(bias: number) {\n\t\tthis.inputs.set({ bias });\n\t}\n\n\t@Input({ alias: 'fade' }) set _fade(fade: number) {\n\t\tthis.inputs.set({ fade });\n\t}\n\n\t@Input({ alias: 'color' }) set _color(color: THREE.Color) {\n\t\tthis.inputs.set({ color });\n\t}\n\n\t@Input({ alias: 'resolutionScale' }) set _resolutionScale(resolutionScale: number) {\n\t\tthis.inputs.set({ resolutionScale });\n\t}\n\n\t@Input({ alias: 'resolutionX' }) set _resolutionX(resolutionX: number) {\n\t\tthis.inputs.set({ resolutionX });\n\t}\n\n\t@Input({ alias: 'resolutionY' }) set _resolutionY(resolutionY: number) {\n\t\tthis.inputs.set({ resolutionY });\n\t}\n\n\t@Input({ alias: 'width' }) set _width(width: number) {\n\t\tthis.inputs.set({ width });\n\t}\n\n\t@Input({ alias: 'height' }) set _height(height: number) {\n\t\tthis.inputs.set({ height });\n\t}\n\n\tprivate effectComposerApi = injectNgtpEffectComposerApi();\n\n\teffect = computed(() => {\n\t\tconst [state, { camera, normalPass, downSamplingPass, resolutionScale }] = [\n\t\t\tthis.inputs.state(),\n\t\t\tthis.effectComposerApi(),\n\t\t];\n\n\t\tif (normalPass === null && downSamplingPass === null) {\n\t\t\tconsole.error('Please enable the NormalPass in the NgtpEffectComposer in order to use NgtpSSAO.');\n\t\t\treturn null;\n\t\t}\n\n\t\treturn new SSAOEffect(camera, normalPass && !downSamplingPass ? (normalPass as any).texture : null, {\n\t\t\t...state,\n\t\t\t// @ts-expect-error\n\t\t\tnormalDepthBuffer: state.normalDepthBuffer || (downSamplingPass ? downSamplingPass.texture : null),\n\t\t\tresolutionScale: state.resolutionScale || (resolutionScale ?? 1),\n\t\t\tdepthAwareUpsampling: state.depthAwareUpsampling ?? true,\n\t\t});\n\t});\n}\n"]}
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
import { CUSTOM_ELEMENTS_SCHEMA, Component } from '@angular/core';
|
|
2
|
+
import { NgtArgs, extend } from 'angular-three';
|
|
3
|
+
import { BlendFunction, KernelSize, TiltShiftEffect } from 'postprocessing';
|
|
4
|
+
import { NgtpEffect } from '../../effect';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
extend({ TiltShiftEffect });
|
|
7
|
+
export class NgtpTiltShift extends NgtpEffect {
|
|
8
|
+
constructor() {
|
|
9
|
+
super(...arguments);
|
|
10
|
+
this.defaultBlendFunction = BlendFunction.ADD;
|
|
11
|
+
}
|
|
12
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: NgtpTiltShift, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
|
|
13
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.3", type: NgtpTiltShift, isStandalone: true, selector: "ngtp-tilt-shift", usesInheritance: true, ngImport: i0, template: `
|
|
14
|
+
<ngt-tilt-shift-effect ngtCompound *args="args()" [camera]="camera()" [ref]="effectRef">
|
|
15
|
+
<ng-content />
|
|
16
|
+
</ngt-tilt-shift-effect>
|
|
17
|
+
`, isInline: true, dependencies: [{ kind: "directive", type: NgtArgs, selector: "ng-template[args]", inputs: ["args"] }] }); }
|
|
18
|
+
}
|
|
19
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: NgtpTiltShift, decorators: [{
|
|
20
|
+
type: Component,
|
|
21
|
+
args: [{
|
|
22
|
+
selector: 'ngtp-tilt-shift',
|
|
23
|
+
standalone: true,
|
|
24
|
+
template: `
|
|
25
|
+
<ngt-tilt-shift-effect ngtCompound *args="args()" [camera]="camera()" [ref]="effectRef">
|
|
26
|
+
<ng-content />
|
|
27
|
+
</ngt-tilt-shift-effect>
|
|
28
|
+
`,
|
|
29
|
+
imports: [NgtArgs],
|
|
30
|
+
schemas: [CUSTOM_ELEMENTS_SCHEMA],
|
|
31
|
+
}]
|
|
32
|
+
}] });
|
|
33
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGlsdC1zaGlmdC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvcG9zdHByb2Nlc3Npbmcvc3JjL2xpYi9lZmZlY3RzL3RpbHQtc2hpZnQvdGlsdC1zaGlmdC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsU0FBUyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ2xFLE9BQU8sRUFBRSxPQUFPLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ2hELE9BQU8sRUFBRSxhQUFhLEVBQUUsVUFBVSxFQUFFLGVBQWUsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQzVFLE9BQU8sRUFBRSxVQUFVLEVBQXdCLE1BQU0sY0FBYyxDQUFDOztBQUVoRSxNQUFNLENBQUMsRUFBRSxlQUFlLEVBQUUsQ0FBQyxDQUFDO0FBNkI1QixNQUFNLE9BQU8sYUFBYyxTQUFRLFVBQTJCO0lBWDlEOztRQVlVLHlCQUFvQixHQUFHLGFBQWEsQ0FBQyxHQUFHLENBQUM7S0FDbEQ7OEdBRlksYUFBYTtrR0FBYixhQUFhLGtHQVJmOzs7O0VBSVQsNERBQ1MsT0FBTzs7MkZBR0wsYUFBYTtrQkFYekIsU0FBUzttQkFBQztvQkFDVixRQUFRLEVBQUUsaUJBQWlCO29CQUMzQixVQUFVLEVBQUUsSUFBSTtvQkFDaEIsUUFBUSxFQUFFOzs7O0VBSVQ7b0JBQ0QsT0FBTyxFQUFFLENBQUMsT0FBTyxDQUFDO29CQUNsQixPQUFPLEVBQUUsQ0FBQyxzQkFBc0IsQ0FBQztpQkFDakMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDVVNUT01fRUxFTUVOVFNfU0NIRU1BLCBDb21wb25lbnQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IE5ndEFyZ3MsIGV4dGVuZCB9IGZyb20gJ2FuZ3VsYXItdGhyZWUnO1xuaW1wb3J0IHsgQmxlbmRGdW5jdGlvbiwgS2VybmVsU2l6ZSwgVGlsdFNoaWZ0RWZmZWN0IH0gZnJvbSAncG9zdHByb2Nlc3NpbmcnO1xuaW1wb3J0IHsgTmd0cEVmZmVjdCwgdHlwZSBOZ3RwRWZmZWN0U3RhdGUgfSBmcm9tICcuLi8uLi9lZmZlY3QnO1xuXG5leHRlbmQoeyBUaWx0U2hpZnRFZmZlY3QgfSk7XG5cbmRlY2xhcmUgZ2xvYmFsIHtcblx0aW50ZXJmYWNlIEhUTUxFbGVtZW50VGFnTmFtZU1hcCB7XG5cdFx0J25ndHAtdGlsdC1zaGlmdCc6IHtcblx0XHRcdG9mZnNldD86IG51bWJlcjtcblx0XHRcdHJvdGF0aW9uPzogbnVtYmVyO1xuXHRcdFx0Zm9jdXNBcmVhPzogbnVtYmVyO1xuXHRcdFx0ZmVhdGhlcj86IG51bWJlcjtcblx0XHRcdGJpYXM/OiBudW1iZXI7XG5cdFx0XHRrZXJuZWxTaXplPzogS2VybmVsU2l6ZTtcblx0XHRcdHJlc29sdXRpb25TY2FsZT86IG51bWJlcjtcblx0XHRcdHJlc29sdXRpb25YPzogbnVtYmVyO1xuXHRcdFx0cmVzb2x1dGlvblk/OiBudW1iZXI7XG5cdFx0fSAmIE5ndHBFZmZlY3RTdGF0ZTtcblx0fVxufVxuXG5AQ29tcG9uZW50KHtcblx0c2VsZWN0b3I6ICduZ3RwLXRpbHQtc2hpZnQnLFxuXHRzdGFuZGFsb25lOiB0cnVlLFxuXHR0ZW1wbGF0ZTogYFxuXHRcdDxuZ3QtdGlsdC1zaGlmdC1lZmZlY3Qgbmd0Q29tcG91bmQgKmFyZ3M9XCJhcmdzKClcIiBbY2FtZXJhXT1cImNhbWVyYSgpXCIgW3JlZl09XCJlZmZlY3RSZWZcIj5cblx0XHRcdDxuZy1jb250ZW50IC8+XG5cdFx0PC9uZ3QtdGlsdC1zaGlmdC1lZmZlY3Q+XG5cdGAsXG5cdGltcG9ydHM6IFtOZ3RBcmdzXSxcblx0c2NoZW1hczogW0NVU1RPTV9FTEVNRU5UU19TQ0hFTUFdLFxufSlcbmV4cG9ydCBjbGFzcyBOZ3RwVGlsdFNoaWZ0IGV4dGVuZHMgTmd0cEVmZmVjdDxUaWx0U2hpZnRFZmZlY3Q+IHtcblx0b3ZlcnJpZGUgZGVmYXVsdEJsZW5kRnVuY3Rpb24gPSBCbGVuZEZ1bmN0aW9uLkFERDtcbn1cbiJdfQ==
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import { CUSTOM_ELEMENTS_SCHEMA, Component } from '@angular/core';
|
|
2
|
+
import { NgtArgs, extend } from 'angular-three';
|
|
3
|
+
import { ToneMappingEffect, ToneMappingMode } from 'postprocessing';
|
|
4
|
+
import { NgtpEffect } from '../../effect';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
extend({ ToneMappingEffect });
|
|
7
|
+
export class NgtpToneMapping extends NgtpEffect {
|
|
8
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: NgtpToneMapping, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
|
|
9
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.3", type: NgtpToneMapping, isStandalone: true, selector: "ngtp-tone-mapping", usesInheritance: true, ngImport: i0, template: `
|
|
10
|
+
<ngt-tone-mapping-effect ngtCompound *args="args()" [camera]="camera()" [ref]="effectRef">
|
|
11
|
+
<ng-content />
|
|
12
|
+
</ngt-tone-mapping-effect>
|
|
13
|
+
`, isInline: true, dependencies: [{ kind: "directive", type: NgtArgs, selector: "ng-template[args]", inputs: ["args"] }] }); }
|
|
14
|
+
}
|
|
15
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: NgtpToneMapping, decorators: [{
|
|
16
|
+
type: Component,
|
|
17
|
+
args: [{
|
|
18
|
+
selector: 'ngtp-tone-mapping',
|
|
19
|
+
standalone: true,
|
|
20
|
+
template: `
|
|
21
|
+
<ngt-tone-mapping-effect ngtCompound *args="args()" [camera]="camera()" [ref]="effectRef">
|
|
22
|
+
<ng-content />
|
|
23
|
+
</ngt-tone-mapping-effect>
|
|
24
|
+
`,
|
|
25
|
+
imports: [NgtArgs],
|
|
26
|
+
schemas: [CUSTOM_ELEMENTS_SCHEMA],
|
|
27
|
+
}]
|
|
28
|
+
}] });
|
|
29
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG9uZS1tYXBwaW5nLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9wb3N0cHJvY2Vzc2luZy9zcmMvbGliL2VmZmVjdHMvdG9uZS1tYXBwaW5nL3RvbmUtbWFwcGluZy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsU0FBUyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ2xFLE9BQU8sRUFBRSxPQUFPLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ2hELE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxlQUFlLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUNwRSxPQUFPLEVBQUUsVUFBVSxFQUF3QixNQUFNLGNBQWMsQ0FBQzs7QUFFaEUsTUFBTSxDQUFDLEVBQUUsaUJBQWlCLEVBQUUsQ0FBQyxDQUFDO0FBNkI5QixNQUFNLE9BQU8sZUFBZ0IsU0FBUSxVQUE2Qjs4R0FBckQsZUFBZTtrR0FBZixlQUFlLG9HQVJqQjs7OztFQUlULDREQUNTLE9BQU87OzJGQUdMLGVBQWU7a0JBWDNCLFNBQVM7bUJBQUM7b0JBQ1YsUUFBUSxFQUFFLG1CQUFtQjtvQkFDN0IsVUFBVSxFQUFFLElBQUk7b0JBQ2hCLFFBQVEsRUFBRTs7OztFQUlUO29CQUNELE9BQU8sRUFBRSxDQUFDLE9BQU8sQ0FBQztvQkFDbEIsT0FBTyxFQUFFLENBQUMsc0JBQXNCLENBQUM7aUJBQ2pDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ1VTVE9NX0VMRU1FTlRTX1NDSEVNQSwgQ29tcG9uZW50IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBOZ3RBcmdzLCBleHRlbmQgfSBmcm9tICdhbmd1bGFyLXRocmVlJztcbmltcG9ydCB7IFRvbmVNYXBwaW5nRWZmZWN0LCBUb25lTWFwcGluZ01vZGUgfSBmcm9tICdwb3N0cHJvY2Vzc2luZyc7XG5pbXBvcnQgeyBOZ3RwRWZmZWN0LCB0eXBlIE5ndHBFZmZlY3RTdGF0ZSB9IGZyb20gJy4uLy4uL2VmZmVjdCc7XG5cbmV4dGVuZCh7IFRvbmVNYXBwaW5nRWZmZWN0IH0pO1xuXG5kZWNsYXJlIGdsb2JhbCB7XG5cdGludGVyZmFjZSBIVE1MRWxlbWVudFRhZ05hbWVNYXAge1xuXHRcdCduZ3RwLXRvbmUtbWFwcGluZyc6IHtcblx0XHRcdGFkYXB0aXZlPzogYm9vbGVhbjtcblx0XHRcdG1vZGU/OiBUb25lTWFwcGluZ01vZGU7XG5cdFx0XHRyZXNvbHV0aW9uPzogbnVtYmVyO1xuXHRcdFx0bWF4THVtaW5hbmNlPzogbnVtYmVyO1xuXHRcdFx0d2hpdGVQb2ludD86IG51bWJlcjtcblx0XHRcdG1pZGRsZUdyZXk/OiBudW1iZXI7XG5cdFx0XHRtaW5MdW1pbmFuY2U/OiBudW1iZXI7XG5cdFx0XHRhdmVyYWdlTHVtaW5hbmNlPzogbnVtYmVyO1xuXHRcdFx0YWRhcHRhdGlvblJhdGU/OiBudW1iZXI7XG5cdFx0fSAmIE5ndHBFZmZlY3RTdGF0ZTtcblx0fVxufVxuXG5AQ29tcG9uZW50KHtcblx0c2VsZWN0b3I6ICduZ3RwLXRvbmUtbWFwcGluZycsXG5cdHN0YW5kYWxvbmU6IHRydWUsXG5cdHRlbXBsYXRlOiBgXG5cdFx0PG5ndC10b25lLW1hcHBpbmctZWZmZWN0IG5ndENvbXBvdW5kICphcmdzPVwiYXJncygpXCIgW2NhbWVyYV09XCJjYW1lcmEoKVwiIFtyZWZdPVwiZWZmZWN0UmVmXCI+XG5cdFx0XHQ8bmctY29udGVudCAvPlxuXHRcdDwvbmd0LXRvbmUtbWFwcGluZy1lZmZlY3Q+XG5cdGAsXG5cdGltcG9ydHM6IFtOZ3RBcmdzXSxcblx0c2NoZW1hczogW0NVU1RPTV9FTEVNRU5UU19TQ0hFTUFdLFxufSlcbmV4cG9ydCBjbGFzcyBOZ3RwVG9uZU1hcHBpbmcgZXh0ZW5kcyBOZ3RwRWZmZWN0PFRvbmVNYXBwaW5nRWZmZWN0PiB7fVxuIl19
|