angular-three-soba 1.2.0 → 1.3.0
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/cameras/README.md +3 -0
- package/cameras/index.d.ts +3 -0
- package/cameras/lib/camera/camera-content.d.ts +13 -0
- package/cameras/lib/camera/camera.d.ts +19 -0
- package/cameras/lib/orthographic-camera/orthographic-camera.d.ts +17 -0
- package/cameras/lib/perspective-camera/perspective-camera.d.ts +9 -0
- package/esm2020/cameras/angular-three-soba-cameras.mjs +5 -0
- package/esm2020/cameras/index.mjs +4 -0
- package/esm2020/cameras/lib/camera/camera-content.mjs +20 -0
- package/esm2020/cameras/lib/camera/camera.mjs +74 -0
- package/esm2020/cameras/lib/orthographic-camera/orthographic-camera.mjs +92 -0
- package/esm2020/cameras/lib/perspective-camera/perspective-camera.mjs +46 -0
- package/esm2020/misc/index.mjs +2 -1
- package/esm2020/misc/lib/fbo/fbo.mjs +38 -0
- package/esm2020/staging/lib/accumulative-shadows/accumulative-shadows.mjs +14 -12
- package/esm2020/staging/lib/accumulative-shadows/randomized-lights.mjs +6 -3
- package/fesm2015/angular-three-soba-cameras.mjs +224 -0
- package/fesm2015/angular-three-soba-cameras.mjs.map +1 -0
- package/fesm2015/angular-three-soba-misc.mjs +34 -2
- package/fesm2015/angular-three-soba-misc.mjs.map +1 -1
- package/fesm2015/angular-three-soba-staging.mjs +17 -12
- package/fesm2015/angular-three-soba-staging.mjs.map +1 -1
- package/fesm2020/angular-three-soba-cameras.mjs +224 -0
- package/fesm2020/angular-three-soba-cameras.mjs.map +1 -0
- package/fesm2020/angular-three-soba-misc.mjs +38 -2
- package/fesm2020/angular-three-soba-misc.mjs.map +1 -1
- package/fesm2020/angular-three-soba-staging.mjs +17 -12
- package/fesm2020/angular-three-soba-staging.mjs.map +1 -1
- package/misc/index.d.ts +1 -0
- package/misc/lib/fbo/fbo.d.ts +13 -0
- package/package.json +9 -1
- package/plugin/package.json +1 -1
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { TemplateRef } from '@angular/core';
|
|
2
|
+
import * as THREE from 'three';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
export declare class NgtsCameraContent {
|
|
5
|
+
readonly template: TemplateRef<any>;
|
|
6
|
+
ngtsCameraContent: boolean | '';
|
|
7
|
+
static ngTemplateContextGuard(_: NgtsCameraContent, ctx: unknown): ctx is {
|
|
8
|
+
target: THREE.WebGLRenderTarget;
|
|
9
|
+
group?: THREE.Group;
|
|
10
|
+
};
|
|
11
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<NgtsCameraContent, never>;
|
|
12
|
+
static ɵdir: i0.ɵɵDirectiveDeclaration<NgtsCameraContent, "ng-template[ngtsCameraContent]", never, { "ngtsCameraContent": "ngtsCameraContent"; }, {}, never, never, true, never>;
|
|
13
|
+
}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { OnInit } from '@angular/core';
|
|
2
|
+
import { NgtCamera, NgtRxStore, NgtStore } from 'angular-three';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
export declare abstract class NgtsCamera<TCamera extends NgtCamera> extends NgtRxStore implements OnInit {
|
|
5
|
+
set makeDefault(makeDefault: boolean);
|
|
6
|
+
set manual(manual: boolean);
|
|
7
|
+
set frames(frames: number);
|
|
8
|
+
set resolution(resolution: number);
|
|
9
|
+
set envMap(envMap: THREE.Texture);
|
|
10
|
+
cameraRef: import("angular-three").NgtInjectedRef<TCamera>;
|
|
11
|
+
protected readonly store: NgtStore;
|
|
12
|
+
readonly fboRef: import("angular-three").NgtInjectedRef<import("three").WebGLRenderTarget>;
|
|
13
|
+
initialize(): void;
|
|
14
|
+
ngOnInit(): void;
|
|
15
|
+
private setDefaultCamera;
|
|
16
|
+
private updateProjectionMatrix;
|
|
17
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<NgtsCamera<any>, never>;
|
|
18
|
+
static ɵdir: i0.ɵɵDirectiveDeclaration<NgtsCamera<any>, never, never, { "makeDefault": "makeDefault"; "manual": "manual"; "frames": "frames"; "resolution": "resolution"; "envMap": "envMap"; "cameraRef": "cameraRef"; }, {}, never, never, false, never>;
|
|
19
|
+
}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { NgtsCamera } from '../camera/camera';
|
|
2
|
+
import { NgtsCameraContent } from '../camera/camera-content';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
export declare class NgtsOrthographicCamera extends NgtsCamera<THREE.OrthographicCamera> {
|
|
5
|
+
cameraContent?: NgtsCameraContent;
|
|
6
|
+
set left(left: number);
|
|
7
|
+
set right(right: number);
|
|
8
|
+
set top(top: number);
|
|
9
|
+
set bottom(bottom: number);
|
|
10
|
+
initialize(): void;
|
|
11
|
+
readonly left$: import("rxjs").Observable<any>;
|
|
12
|
+
readonly right$: import("rxjs").Observable<any>;
|
|
13
|
+
readonly top$: import("rxjs").Observable<any>;
|
|
14
|
+
readonly bottom$: import("rxjs").Observable<any>;
|
|
15
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<NgtsOrthographicCamera, never>;
|
|
16
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<NgtsOrthographicCamera, "ngts-orthographic-camera", never, { "left": "left"; "right": "right"; "top": "top"; "bottom": "bottom"; }, {}, ["cameraContent"], never, true, never>;
|
|
17
|
+
}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { PerspectiveCamera } from 'three';
|
|
2
|
+
import { NgtsCamera } from '../camera/camera';
|
|
3
|
+
import { NgtsCameraContent } from '../camera/camera-content';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
export declare class NgtsPerspectiveCamera extends NgtsCamera<PerspectiveCamera> {
|
|
6
|
+
cameraContent?: NgtsCameraContent;
|
|
7
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<NgtsPerspectiveCamera, never>;
|
|
8
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<NgtsPerspectiveCamera, "ngts-perspective-camera", never, {}, {}, ["cameraContent"], never, true, never>;
|
|
9
|
+
}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Generated bundle index. Do not edit.
|
|
3
|
+
*/
|
|
4
|
+
export * from './index';
|
|
5
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYW5ndWxhci10aHJlZS1zb2JhLWNhbWVyYXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWJzL2FuZ3VsYXItdGhyZWUtc29iYS9jYW1lcmFzL3NyYy9hbmd1bGFyLXRocmVlLXNvYmEtY2FtZXJhcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsU0FBUyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBHZW5lcmF0ZWQgYnVuZGxlIGluZGV4LiBEbyBub3QgZWRpdC5cbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL2luZGV4JztcbiJdfQ==
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
export * from './lib/camera/camera-content';
|
|
2
|
+
export * from './lib/orthographic-camera/orthographic-camera';
|
|
3
|
+
export * from './lib/perspective-camera/perspective-camera';
|
|
4
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWJzL2FuZ3VsYXItdGhyZWUtc29iYS9jYW1lcmFzL3NyYy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLDZCQUE2QixDQUFDO0FBQzVDLGNBQWMsK0NBQStDLENBQUM7QUFDOUQsY0FBYyw2Q0FBNkMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vbGliL2NhbWVyYS9jYW1lcmEtY29udGVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9vcnRob2dyYXBoaWMtY2FtZXJhL29ydGhvZ3JhcGhpYy1jYW1lcmEnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvcGVyc3BlY3RpdmUtY2FtZXJhL3BlcnNwZWN0aXZlLWNhbWVyYSc7XG4iXX0=
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { Directive, inject, Input, TemplateRef } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export class NgtsCameraContent {
|
|
4
|
+
constructor() {
|
|
5
|
+
this.template = inject(TemplateRef);
|
|
6
|
+
this.ngtsCameraContent = '';
|
|
7
|
+
}
|
|
8
|
+
static ngTemplateContextGuard(_, ctx) {
|
|
9
|
+
return true;
|
|
10
|
+
}
|
|
11
|
+
}
|
|
12
|
+
NgtsCameraContent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.3", ngImport: i0, type: NgtsCameraContent, deps: [], target: i0.ɵɵFactoryTarget.Directive });
|
|
13
|
+
NgtsCameraContent.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.1.3", type: NgtsCameraContent, isStandalone: true, selector: "ng-template[ngtsCameraContent]", inputs: { ngtsCameraContent: "ngtsCameraContent" }, ngImport: i0 });
|
|
14
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.3", ngImport: i0, type: NgtsCameraContent, decorators: [{
|
|
15
|
+
type: Directive,
|
|
16
|
+
args: [{ selector: 'ng-template[ngtsCameraContent]', standalone: true }]
|
|
17
|
+
}], propDecorators: { ngtsCameraContent: [{
|
|
18
|
+
type: Input
|
|
19
|
+
}] } });
|
|
20
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FtZXJhLWNvbnRlbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2FuZ3VsYXItdGhyZWUtc29iYS9jYW1lcmFzL3NyYy9saWIvY2FtZXJhL2NhbWVyYS1jb250ZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxFQUFFLEtBQUssRUFBRSxXQUFXLEVBQUUsTUFBTSxlQUFlLENBQUM7O0FBSXRFLE1BQU0sT0FBTyxpQkFBaUI7SUFEOUI7UUFFYSxhQUFRLEdBQUcsTUFBTSxDQUFDLFdBQVcsQ0FBQyxDQUFDO1FBQy9CLHNCQUFpQixHQUFpQixFQUFFLENBQUM7S0FRakQ7SUFORyxNQUFNLENBQUMsc0JBQXNCLENBQ3pCLENBQW9CLEVBQ3BCLEdBQVk7UUFFWixPQUFPLElBQUksQ0FBQztJQUNoQixDQUFDOzs4R0FUUSxpQkFBaUI7a0dBQWpCLGlCQUFpQjsyRkFBakIsaUJBQWlCO2tCQUQ3QixTQUFTO21CQUFDLEVBQUUsUUFBUSxFQUFFLGdDQUFnQyxFQUFFLFVBQVUsRUFBRSxJQUFJLEVBQUU7OEJBRzlELGlCQUFpQjtzQkFBekIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERpcmVjdGl2ZSwgaW5qZWN0LCBJbnB1dCwgVGVtcGxhdGVSZWYgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCAqIGFzIFRIUkVFIGZyb20gJ3RocmVlJztcblxuQERpcmVjdGl2ZSh7IHNlbGVjdG9yOiAnbmctdGVtcGxhdGVbbmd0c0NhbWVyYUNvbnRlbnRdJywgc3RhbmRhbG9uZTogdHJ1ZSB9KVxuZXhwb3J0IGNsYXNzIE5ndHNDYW1lcmFDb250ZW50IHtcbiAgICByZWFkb25seSB0ZW1wbGF0ZSA9IGluamVjdChUZW1wbGF0ZVJlZik7XG4gICAgQElucHV0KCkgbmd0c0NhbWVyYUNvbnRlbnQ6IGJvb2xlYW4gfCAnJyA9ICcnO1xuXG4gICAgc3RhdGljIG5nVGVtcGxhdGVDb250ZXh0R3VhcmQoXG4gICAgICAgIF86IE5ndHNDYW1lcmFDb250ZW50LFxuICAgICAgICBjdHg6IHVua25vd25cbiAgICApOiBjdHggaXMgeyB0YXJnZXQ6IFRIUkVFLldlYkdMUmVuZGVyVGFyZ2V0OyBncm91cD86IFRIUkVFLkdyb3VwIH0ge1xuICAgICAgICByZXR1cm4gdHJ1ZTtcbiAgICB9XG59XG4iXX0=
|
|
@@ -0,0 +1,74 @@
|
|
|
1
|
+
import { Directive, inject, Input } from '@angular/core';
|
|
2
|
+
import { injectNgtRef, NgtRxStore, NgtStore } from 'angular-three';
|
|
3
|
+
import { injectNgtsFBO } from 'angular-three-soba/misc';
|
|
4
|
+
import { combineLatest, map } from 'rxjs';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
export class NgtsCamera extends NgtRxStore {
|
|
7
|
+
constructor() {
|
|
8
|
+
super(...arguments);
|
|
9
|
+
this.cameraRef = injectNgtRef();
|
|
10
|
+
this.store = inject(NgtStore);
|
|
11
|
+
this.fboRef = injectNgtsFBO(() => this.select('resolution').pipe(map((resolution) => ({ width: resolution }))));
|
|
12
|
+
}
|
|
13
|
+
set makeDefault(makeDefault) {
|
|
14
|
+
this.set({ makeDefault });
|
|
15
|
+
}
|
|
16
|
+
set manual(manual) {
|
|
17
|
+
this.set({ manual });
|
|
18
|
+
}
|
|
19
|
+
set frames(frames) {
|
|
20
|
+
this.set({ frames });
|
|
21
|
+
}
|
|
22
|
+
set resolution(resolution) {
|
|
23
|
+
this.set({ resolution });
|
|
24
|
+
}
|
|
25
|
+
set envMap(envMap) {
|
|
26
|
+
this.set({ envMap });
|
|
27
|
+
}
|
|
28
|
+
initialize() {
|
|
29
|
+
super.initialize();
|
|
30
|
+
this.set({ resolution: 256, frames: Infinity, makeDefault: false, manual: false });
|
|
31
|
+
}
|
|
32
|
+
ngOnInit() {
|
|
33
|
+
this.hold(this.cameraRef.$, (camera) => {
|
|
34
|
+
camera.updateProjectionMatrix();
|
|
35
|
+
this.setDefaultCamera();
|
|
36
|
+
this.updateProjectionMatrix();
|
|
37
|
+
});
|
|
38
|
+
}
|
|
39
|
+
setDefaultCamera() {
|
|
40
|
+
this.effect(combineLatest([this.cameraRef.$, this.select('makeDefault')]), ([camera, makeDefault]) => {
|
|
41
|
+
if (makeDefault) {
|
|
42
|
+
const { camera: oldCamera } = this.store.get();
|
|
43
|
+
this.store.set({ camera });
|
|
44
|
+
return () => {
|
|
45
|
+
this.store.set({ camera: oldCamera });
|
|
46
|
+
};
|
|
47
|
+
}
|
|
48
|
+
});
|
|
49
|
+
}
|
|
50
|
+
updateProjectionMatrix() {
|
|
51
|
+
this.effect(combineLatest([this.cameraRef.$, this.select('manual')]), ([camera, manual]) => {
|
|
52
|
+
if (!manual && camera)
|
|
53
|
+
camera.updateProjectionMatrix();
|
|
54
|
+
});
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
NgtsCamera.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.3", ngImport: i0, type: NgtsCamera, deps: null, target: i0.ɵɵFactoryTarget.Directive });
|
|
58
|
+
NgtsCamera.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.1.3", type: NgtsCamera, inputs: { makeDefault: "makeDefault", manual: "manual", frames: "frames", resolution: "resolution", envMap: "envMap", cameraRef: "cameraRef" }, usesInheritance: true, ngImport: i0 });
|
|
59
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.3", ngImport: i0, type: NgtsCamera, decorators: [{
|
|
60
|
+
type: Directive
|
|
61
|
+
}], propDecorators: { makeDefault: [{
|
|
62
|
+
type: Input
|
|
63
|
+
}], manual: [{
|
|
64
|
+
type: Input
|
|
65
|
+
}], frames: [{
|
|
66
|
+
type: Input
|
|
67
|
+
}], resolution: [{
|
|
68
|
+
type: Input
|
|
69
|
+
}], envMap: [{
|
|
70
|
+
type: Input
|
|
71
|
+
}], cameraRef: [{
|
|
72
|
+
type: Input
|
|
73
|
+
}] } });
|
|
74
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FtZXJhLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9hbmd1bGFyLXRocmVlLXNvYmEvY2FtZXJhcy9zcmMvbGliL2NhbWVyYS9jYW1lcmEudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLEVBQUUsS0FBSyxFQUFVLE1BQU0sZUFBZSxDQUFDO0FBQ2pFLE9BQU8sRUFBRSxZQUFZLEVBQWEsVUFBVSxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUM5RSxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFDeEQsT0FBTyxFQUFFLGFBQWEsRUFBRSxHQUFHLEVBQUUsTUFBTSxNQUFNLENBQUM7O0FBRzFDLE1BQU0sT0FBZ0IsVUFBc0MsU0FBUSxVQUFVO0lBRDlFOztRQXNCYSxjQUFTLEdBQUcsWUFBWSxFQUFXLENBQUM7UUFFMUIsVUFBSyxHQUFHLE1BQU0sQ0FBQyxRQUFRLENBQUMsQ0FBQztRQUNuQyxXQUFNLEdBQUcsYUFBYSxDQUFDLEdBQUcsRUFBRSxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsWUFBWSxDQUFDLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDLFVBQVUsRUFBRSxFQUFFLENBQUMsQ0FBQyxFQUFFLEtBQUssRUFBRSxVQUFVLEVBQUUsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO0tBZ0N2SDtJQXZERyxJQUFhLFdBQVcsQ0FBQyxXQUFvQjtRQUN6QyxJQUFJLENBQUMsR0FBRyxDQUFDLEVBQUUsV0FBVyxFQUFFLENBQUMsQ0FBQztJQUM5QixDQUFDO0lBRUQsSUFBYSxNQUFNLENBQUMsTUFBZTtRQUMvQixJQUFJLENBQUMsR0FBRyxDQUFDLEVBQUUsTUFBTSxFQUFFLENBQUMsQ0FBQztJQUN6QixDQUFDO0lBRUQsSUFBYSxNQUFNLENBQUMsTUFBYztRQUM5QixJQUFJLENBQUMsR0FBRyxDQUFDLEVBQUUsTUFBTSxFQUFFLENBQUMsQ0FBQztJQUN6QixDQUFDO0lBRUQsSUFBYSxVQUFVLENBQUMsVUFBa0I7UUFDdEMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxFQUFFLFVBQVUsRUFBRSxDQUFDLENBQUM7SUFDN0IsQ0FBQztJQUVELElBQWEsTUFBTSxDQUFDLE1BQXFCO1FBQ3JDLElBQUksQ0FBQyxHQUFHLENBQUMsRUFBRSxNQUFNLEVBQUUsQ0FBQyxDQUFDO0lBQ3pCLENBQUM7SUFPUSxVQUFVO1FBQ2YsS0FBSyxDQUFDLFVBQVUsRUFBRSxDQUFDO1FBQ25CLElBQUksQ0FBQyxHQUFHLENBQUMsRUFBRSxVQUFVLEVBQUUsR0FBRyxFQUFFLE1BQU0sRUFBRSxRQUFRLEVBQUUsV0FBVyxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUUsS0FBSyxFQUFFLENBQUMsQ0FBQztJQUN2RixDQUFDO0lBRUQsUUFBUTtRQUNKLElBQUksQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxNQUFNLEVBQUUsRUFBRTtZQUNuQyxNQUFNLENBQUMsc0JBQXNCLEVBQUUsQ0FBQztZQUNoQyxJQUFJLENBQUMsZ0JBQWdCLEVBQUUsQ0FBQztZQUN4QixJQUFJLENBQUMsc0JBQXNCLEVBQUUsQ0FBQztRQUNsQyxDQUFDLENBQUMsQ0FBQztJQUNQLENBQUM7SUFFTyxnQkFBZ0I7UUFDcEIsSUFBSSxDQUFDLE1BQU0sQ0FBQyxhQUFhLENBQUMsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLENBQUMsRUFBRSxJQUFJLENBQUMsTUFBTSxDQUFDLGFBQWEsQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsTUFBTSxFQUFFLFdBQVcsQ0FBQyxFQUFFLEVBQUU7WUFDakcsSUFBSSxXQUFXLEVBQUU7Z0JBQ2IsTUFBTSxFQUFFLE1BQU0sRUFBRSxTQUFTLEVBQUUsR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLEdBQUcsRUFBRSxDQUFDO2dCQUMvQyxJQUFJLENBQUMsS0FBSyxDQUFDLEdBQUcsQ0FBQyxFQUFFLE1BQU0sRUFBRSxDQUFDLENBQUM7Z0JBQzNCLE9BQU8sR0FBRyxFQUFFO29CQUNSLElBQUksQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLEVBQUUsTUFBTSxFQUFFLFNBQVMsRUFBRSxDQUFDLENBQUM7Z0JBQzFDLENBQUMsQ0FBQzthQUNMO1FBQ0wsQ0FBQyxDQUFDLENBQUM7SUFDUCxDQUFDO0lBRU8sc0JBQXNCO1FBQzFCLElBQUksQ0FBQyxNQUFNLENBQUMsYUFBYSxDQUFDLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFDLEVBQUUsSUFBSSxDQUFDLE1BQU0sQ0FBQyxRQUFRLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLE1BQU0sRUFBRSxNQUFNLENBQUMsRUFBRSxFQUFFO1lBQ3ZGLElBQUksQ0FBQyxNQUFNLElBQUksTUFBTTtnQkFBRSxNQUFNLENBQUMsc0JBQXNCLEVBQUUsQ0FBQztRQUMzRCxDQUFDLENBQUMsQ0FBQztJQUNQLENBQUM7O3VHQXZEaUIsVUFBVTsyRkFBVixVQUFVOzJGQUFWLFVBQVU7a0JBRC9CLFNBQVM7OEJBRU8sV0FBVztzQkFBdkIsS0FBSztnQkFJTyxNQUFNO3NCQUFsQixLQUFLO2dCQUlPLE1BQU07c0JBQWxCLEtBQUs7Z0JBSU8sVUFBVTtzQkFBdEIsS0FBSztnQkFJTyxNQUFNO3NCQUFsQixLQUFLO2dCQUlHLFNBQVM7c0JBQWpCLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3RpdmUsIGluamVjdCwgSW5wdXQsIE9uSW5pdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgaW5qZWN0Tmd0UmVmLCBOZ3RDYW1lcmEsIE5ndFJ4U3RvcmUsIE5ndFN0b3JlIH0gZnJvbSAnYW5ndWxhci10aHJlZSc7XG5pbXBvcnQgeyBpbmplY3ROZ3RzRkJPIH0gZnJvbSAnYW5ndWxhci10aHJlZS1zb2JhL21pc2MnO1xuaW1wb3J0IHsgY29tYmluZUxhdGVzdCwgbWFwIH0gZnJvbSAncnhqcyc7XG5cbkBEaXJlY3RpdmUoKVxuZXhwb3J0IGFic3RyYWN0IGNsYXNzIE5ndHNDYW1lcmE8VENhbWVyYSBleHRlbmRzIE5ndENhbWVyYT4gZXh0ZW5kcyBOZ3RSeFN0b3JlIGltcGxlbWVudHMgT25Jbml0IHtcbiAgICBASW5wdXQoKSBzZXQgbWFrZURlZmF1bHQobWFrZURlZmF1bHQ6IGJvb2xlYW4pIHtcbiAgICAgICAgdGhpcy5zZXQoeyBtYWtlRGVmYXVsdCB9KTtcbiAgICB9XG5cbiAgICBASW5wdXQoKSBzZXQgbWFudWFsKG1hbnVhbDogYm9vbGVhbikge1xuICAgICAgICB0aGlzLnNldCh7IG1hbnVhbCB9KTtcbiAgICB9XG5cbiAgICBASW5wdXQoKSBzZXQgZnJhbWVzKGZyYW1lczogbnVtYmVyKSB7XG4gICAgICAgIHRoaXMuc2V0KHsgZnJhbWVzIH0pO1xuICAgIH1cblxuICAgIEBJbnB1dCgpIHNldCByZXNvbHV0aW9uKHJlc29sdXRpb246IG51bWJlcikge1xuICAgICAgICB0aGlzLnNldCh7IHJlc29sdXRpb24gfSk7XG4gICAgfVxuXG4gICAgQElucHV0KCkgc2V0IGVudk1hcChlbnZNYXA6IFRIUkVFLlRleHR1cmUpIHtcbiAgICAgICAgdGhpcy5zZXQoeyBlbnZNYXAgfSk7XG4gICAgfVxuXG4gICAgQElucHV0KCkgY2FtZXJhUmVmID0gaW5qZWN0Tmd0UmVmPFRDYW1lcmE+KCk7XG5cbiAgICBwcm90ZWN0ZWQgcmVhZG9ubHkgc3RvcmUgPSBpbmplY3QoTmd0U3RvcmUpO1xuICAgIHJlYWRvbmx5IGZib1JlZiA9IGluamVjdE5ndHNGQk8oKCkgPT4gdGhpcy5zZWxlY3QoJ3Jlc29sdXRpb24nKS5waXBlKG1hcCgocmVzb2x1dGlvbikgPT4gKHsgd2lkdGg6IHJlc29sdXRpb24gfSkpKSk7XG5cbiAgICBvdmVycmlkZSBpbml0aWFsaXplKCkge1xuICAgICAgICBzdXBlci5pbml0aWFsaXplKCk7XG4gICAgICAgIHRoaXMuc2V0KHsgcmVzb2x1dGlvbjogMjU2LCBmcmFtZXM6IEluZmluaXR5LCBtYWtlRGVmYXVsdDogZmFsc2UsIG1hbnVhbDogZmFsc2UgfSk7XG4gICAgfVxuXG4gICAgbmdPbkluaXQoKSB7XG4gICAgICAgIHRoaXMuaG9sZCh0aGlzLmNhbWVyYVJlZi4kLCAoY2FtZXJhKSA9PiB7XG4gICAgICAgICAgICBjYW1lcmEudXBkYXRlUHJvamVjdGlvbk1hdHJpeCgpO1xuICAgICAgICAgICAgdGhpcy5zZXREZWZhdWx0Q2FtZXJhKCk7XG4gICAgICAgICAgICB0aGlzLnVwZGF0ZVByb2plY3Rpb25NYXRyaXgoKTtcbiAgICAgICAgfSk7XG4gICAgfVxuXG4gICAgcHJpdmF0ZSBzZXREZWZhdWx0Q2FtZXJhKCkge1xuICAgICAgICB0aGlzLmVmZmVjdChjb21iaW5lTGF0ZXN0KFt0aGlzLmNhbWVyYVJlZi4kLCB0aGlzLnNlbGVjdCgnbWFrZURlZmF1bHQnKV0pLCAoW2NhbWVyYSwgbWFrZURlZmF1bHRdKSA9PiB7XG4gICAgICAgICAgICBpZiAobWFrZURlZmF1bHQpIHtcbiAgICAgICAgICAgICAgICBjb25zdCB7IGNhbWVyYTogb2xkQ2FtZXJhIH0gPSB0aGlzLnN0b3JlLmdldCgpO1xuICAgICAgICAgICAgICAgIHRoaXMuc3RvcmUuc2V0KHsgY2FtZXJhIH0pO1xuICAgICAgICAgICAgICAgIHJldHVybiAoKSA9PiB7XG4gICAgICAgICAgICAgICAgICAgIHRoaXMuc3RvcmUuc2V0KHsgY2FtZXJhOiBvbGRDYW1lcmEgfSk7XG4gICAgICAgICAgICAgICAgfTtcbiAgICAgICAgICAgIH1cbiAgICAgICAgfSk7XG4gICAgfVxuXG4gICAgcHJpdmF0ZSB1cGRhdGVQcm9qZWN0aW9uTWF0cml4KCkge1xuICAgICAgICB0aGlzLmVmZmVjdChjb21iaW5lTGF0ZXN0KFt0aGlzLmNhbWVyYVJlZi4kLCB0aGlzLnNlbGVjdCgnbWFudWFsJyldKSwgKFtjYW1lcmEsIG1hbnVhbF0pID0+IHtcbiAgICAgICAgICAgIGlmICghbWFudWFsICYmIGNhbWVyYSkgY2FtZXJhLnVwZGF0ZVByb2plY3Rpb25NYXRyaXgoKTtcbiAgICAgICAgfSk7XG4gICAgfVxufVxuIl19
|
|
@@ -0,0 +1,92 @@
|
|
|
1
|
+
import { NgIf, NgTemplateOutlet } from '@angular/common';
|
|
2
|
+
import { Component, ContentChild, CUSTOM_ELEMENTS_SCHEMA, Input } from '@angular/core';
|
|
3
|
+
import { extend, NgtPush } from 'angular-three';
|
|
4
|
+
import { combineLatest, map } from 'rxjs';
|
|
5
|
+
import { Group, OrthographicCamera } from 'three';
|
|
6
|
+
import { NgtsCamera } from '../camera/camera';
|
|
7
|
+
import { NgtsCameraContent } from '../camera/camera-content';
|
|
8
|
+
import * as i0 from "@angular/core";
|
|
9
|
+
extend({ OrthographicCamera, Group });
|
|
10
|
+
export class NgtsOrthographicCamera extends NgtsCamera {
|
|
11
|
+
constructor() {
|
|
12
|
+
super(...arguments);
|
|
13
|
+
this.left$ = combineLatest([this.select('left'), this.store.select('size')]).pipe(map(([left, size]) => left ?? size.width / -2));
|
|
14
|
+
this.right$ = combineLatest([this.select('right'), this.store.select('size')]).pipe(map(([right, size]) => right ?? size.width / 2));
|
|
15
|
+
this.top$ = combineLatest([this.select('top'), this.store.select('size')]).pipe(map(([top, size]) => top ?? size.height / 2));
|
|
16
|
+
this.bottom$ = combineLatest([this.select('bottom'), this.store.select('size')]).pipe(map(([bottom, size]) => bottom ?? size.height / -2));
|
|
17
|
+
}
|
|
18
|
+
set left(left) {
|
|
19
|
+
this.set({ left });
|
|
20
|
+
}
|
|
21
|
+
set right(right) {
|
|
22
|
+
this.set({ right });
|
|
23
|
+
}
|
|
24
|
+
set top(top) {
|
|
25
|
+
this.set({ top });
|
|
26
|
+
}
|
|
27
|
+
set bottom(bottom) {
|
|
28
|
+
this.set({ bottom });
|
|
29
|
+
}
|
|
30
|
+
initialize() {
|
|
31
|
+
super.initialize();
|
|
32
|
+
this.set({ left: 0, right: 0, top: 0, bottom: 0 });
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
NgtsOrthographicCamera.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.3", ngImport: i0, type: NgtsOrthographicCamera, deps: null, target: i0.ɵɵFactoryTarget.Component });
|
|
36
|
+
NgtsOrthographicCamera.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.1.3", type: NgtsOrthographicCamera, isStandalone: true, selector: "ngts-orthographic-camera", inputs: { left: "left", right: "right", top: "top", bottom: "bottom" }, queries: [{ propertyName: "cameraContent", first: true, predicate: NgtsCameraContent, descendants: true }], usesInheritance: true, ngImport: i0, template: `
|
|
37
|
+
<ngt-orthographic-camera
|
|
38
|
+
ngtCompound
|
|
39
|
+
[ref]="cameraRef"
|
|
40
|
+
[left]="left$ | ngtPush"
|
|
41
|
+
[right]="right$ | ngtPush"
|
|
42
|
+
[top]="top$ | ngtPush"
|
|
43
|
+
[bottom]="bottom$ | ngtPush"
|
|
44
|
+
>
|
|
45
|
+
<ng-container
|
|
46
|
+
*ngIf="cameraContent && !cameraContent.ngtsCameraContent"
|
|
47
|
+
[ngTemplateOutlet]="cameraContent.template"
|
|
48
|
+
/>
|
|
49
|
+
</ngt-orthographic-camera>
|
|
50
|
+
<ngt-group #group *ngIf="cameraContent && cameraContent.ngtsCameraContent">
|
|
51
|
+
<ng-container *ngTemplateOutlet="cameraContent.template; context: { fbo: fboRef.nativeElement, group }" />
|
|
52
|
+
</ngt-group>
|
|
53
|
+
`, isInline: true, dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "pipe", type: NgtPush, name: "ngtPush" }] });
|
|
54
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.3", ngImport: i0, type: NgtsOrthographicCamera, decorators: [{
|
|
55
|
+
type: Component,
|
|
56
|
+
args: [{
|
|
57
|
+
selector: 'ngts-orthographic-camera',
|
|
58
|
+
standalone: true,
|
|
59
|
+
template: `
|
|
60
|
+
<ngt-orthographic-camera
|
|
61
|
+
ngtCompound
|
|
62
|
+
[ref]="cameraRef"
|
|
63
|
+
[left]="left$ | ngtPush"
|
|
64
|
+
[right]="right$ | ngtPush"
|
|
65
|
+
[top]="top$ | ngtPush"
|
|
66
|
+
[bottom]="bottom$ | ngtPush"
|
|
67
|
+
>
|
|
68
|
+
<ng-container
|
|
69
|
+
*ngIf="cameraContent && !cameraContent.ngtsCameraContent"
|
|
70
|
+
[ngTemplateOutlet]="cameraContent.template"
|
|
71
|
+
/>
|
|
72
|
+
</ngt-orthographic-camera>
|
|
73
|
+
<ngt-group #group *ngIf="cameraContent && cameraContent.ngtsCameraContent">
|
|
74
|
+
<ng-container *ngTemplateOutlet="cameraContent.template; context: { fbo: fboRef.nativeElement, group }" />
|
|
75
|
+
</ngt-group>
|
|
76
|
+
`,
|
|
77
|
+
imports: [NgIf, NgTemplateOutlet, NgtPush],
|
|
78
|
+
schemas: [CUSTOM_ELEMENTS_SCHEMA],
|
|
79
|
+
}]
|
|
80
|
+
}], propDecorators: { cameraContent: [{
|
|
81
|
+
type: ContentChild,
|
|
82
|
+
args: [NgtsCameraContent]
|
|
83
|
+
}], left: [{
|
|
84
|
+
type: Input
|
|
85
|
+
}], right: [{
|
|
86
|
+
type: Input
|
|
87
|
+
}], top: [{
|
|
88
|
+
type: Input
|
|
89
|
+
}], bottom: [{
|
|
90
|
+
type: Input
|
|
91
|
+
}] } });
|
|
92
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoib3J0aG9ncmFwaGljLWNhbWVyYS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvYW5ndWxhci10aHJlZS1zb2JhL2NhbWVyYXMvc3JjL2xpYi9vcnRob2dyYXBoaWMtY2FtZXJhL29ydGhvZ3JhcGhpYy1jYW1lcmEudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLElBQUksRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQ3pELE9BQU8sRUFBRSxTQUFTLEVBQUUsWUFBWSxFQUFFLHNCQUFzQixFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN2RixPQUFPLEVBQUUsTUFBTSxFQUFFLE9BQU8sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNoRCxPQUFPLEVBQUUsYUFBYSxFQUFFLEdBQUcsRUFBRSxNQUFNLE1BQU0sQ0FBQztBQUMxQyxPQUFPLEVBQUUsS0FBSyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sT0FBTyxDQUFDO0FBQ2xELE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQztBQUM5QyxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQzs7QUFFN0QsTUFBTSxDQUFDLEVBQUUsa0JBQWtCLEVBQUUsS0FBSyxFQUFFLENBQUMsQ0FBQztBQTBCdEMsTUFBTSxPQUFPLHNCQUF1QixTQUFRLFVBQW9DO0lBeEJoRjs7UUFnRGEsVUFBSyxHQUFHLGFBQWEsQ0FBQyxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsTUFBTSxDQUFDLEVBQUUsSUFBSSxDQUFDLEtBQUssQ0FBQyxNQUFNLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FDakYsR0FBRyxDQUFDLENBQUMsQ0FBQyxJQUFJLEVBQUUsSUFBSSxDQUFDLEVBQUUsRUFBRSxDQUFDLElBQUksSUFBSSxJQUFJLENBQUMsS0FBSyxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQ2pELENBQUM7UUFFTyxXQUFNLEdBQUcsYUFBYSxDQUFDLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxPQUFPLENBQUMsRUFBRSxJQUFJLENBQUMsS0FBSyxDQUFDLE1BQU0sQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUNuRixHQUFHLENBQUMsQ0FBQyxDQUFDLEtBQUssRUFBRSxJQUFJLENBQUMsRUFBRSxFQUFFLENBQUMsS0FBSyxJQUFJLElBQUksQ0FBQyxLQUFLLEdBQUcsQ0FBQyxDQUFDLENBQ2xELENBQUM7UUFFTyxTQUFJLEdBQUcsYUFBYSxDQUFDLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsRUFBRSxJQUFJLENBQUMsS0FBSyxDQUFDLE1BQU0sQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUMvRSxHQUFHLENBQUMsQ0FBQyxDQUFDLEdBQUcsRUFBRSxJQUFJLENBQUMsRUFBRSxFQUFFLENBQUMsR0FBRyxJQUFJLElBQUksQ0FBQyxNQUFNLEdBQUcsQ0FBQyxDQUFDLENBQy9DLENBQUM7UUFFTyxZQUFPLEdBQUcsYUFBYSxDQUFDLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxRQUFRLENBQUMsRUFBRSxJQUFJLENBQUMsS0FBSyxDQUFDLE1BQU0sQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUNyRixHQUFHLENBQUMsQ0FBQyxDQUFDLE1BQU0sRUFBRSxJQUFJLENBQUMsRUFBRSxFQUFFLENBQUMsTUFBTSxJQUFJLElBQUksQ0FBQyxNQUFNLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FDdEQsQ0FBQztLQUNMO0lBcENHLElBQWEsSUFBSSxDQUFDLElBQVk7UUFDMUIsSUFBSSxDQUFDLEdBQUcsQ0FBQyxFQUFFLElBQUksRUFBRSxDQUFDLENBQUM7SUFDdkIsQ0FBQztJQUVELElBQWEsS0FBSyxDQUFDLEtBQWE7UUFDNUIsSUFBSSxDQUFDLEdBQUcsQ0FBQyxFQUFFLEtBQUssRUFBRSxDQUFDLENBQUM7SUFDeEIsQ0FBQztJQUVELElBQWEsR0FBRyxDQUFDLEdBQVc7UUFDeEIsSUFBSSxDQUFDLEdBQUcsQ0FBQyxFQUFFLEdBQUcsRUFBRSxDQUFDLENBQUM7SUFDdEIsQ0FBQztJQUVELElBQWEsTUFBTSxDQUFDLE1BQWM7UUFDOUIsSUFBSSxDQUFDLEdBQUcsQ0FBQyxFQUFFLE1BQU0sRUFBRSxDQUFDLENBQUM7SUFDekIsQ0FBQztJQUVRLFVBQVU7UUFDZixLQUFLLENBQUMsVUFBVSxFQUFFLENBQUM7UUFDbkIsSUFBSSxDQUFDLEdBQUcsQ0FBQyxFQUFFLElBQUksRUFBRSxDQUFDLEVBQUUsS0FBSyxFQUFFLENBQUMsRUFBRSxHQUFHLEVBQUUsQ0FBQyxFQUFFLE1BQU0sRUFBRSxDQUFDLEVBQUUsQ0FBQyxDQUFDO0lBQ3ZELENBQUM7O21IQXRCUSxzQkFBc0I7dUdBQXRCLHNCQUFzQix1TUFDakIsaUJBQWlCLHVFQXRCckI7Ozs7Ozs7Ozs7Ozs7Ozs7O0tBaUJULDREQUNTLElBQUksNkZBQUUsZ0JBQWdCLCtJQUFFLE9BQU87MkZBR2hDLHNCQUFzQjtrQkF4QmxDLFNBQVM7bUJBQUM7b0JBQ1AsUUFBUSxFQUFFLDBCQUEwQjtvQkFDcEMsVUFBVSxFQUFFLElBQUk7b0JBQ2hCLFFBQVEsRUFBRTs7Ozs7Ozs7Ozs7Ozs7Ozs7S0FpQlQ7b0JBQ0QsT0FBTyxFQUFFLENBQUMsSUFBSSxFQUFFLGdCQUFnQixFQUFFLE9BQU8sQ0FBQztvQkFDMUMsT0FBTyxFQUFFLENBQUMsc0JBQXNCLENBQUM7aUJBQ3BDOzhCQUVvQyxhQUFhO3NCQUE3QyxZQUFZO3VCQUFDLGlCQUFpQjtnQkFFbEIsSUFBSTtzQkFBaEIsS0FBSztnQkFJTyxLQUFLO3NCQUFqQixLQUFLO2dCQUlPLEdBQUc7c0JBQWYsS0FBSztnQkFJTyxNQUFNO3NCQUFsQixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdJZiwgTmdUZW1wbGF0ZU91dGxldCB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBDb21wb25lbnQsIENvbnRlbnRDaGlsZCwgQ1VTVE9NX0VMRU1FTlRTX1NDSEVNQSwgSW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IGV4dGVuZCwgTmd0UHVzaCB9IGZyb20gJ2FuZ3VsYXItdGhyZWUnO1xuaW1wb3J0IHsgY29tYmluZUxhdGVzdCwgbWFwIH0gZnJvbSAncnhqcyc7XG5pbXBvcnQgeyBHcm91cCwgT3J0aG9ncmFwaGljQ2FtZXJhIH0gZnJvbSAndGhyZWUnO1xuaW1wb3J0IHsgTmd0c0NhbWVyYSB9IGZyb20gJy4uL2NhbWVyYS9jYW1lcmEnO1xuaW1wb3J0IHsgTmd0c0NhbWVyYUNvbnRlbnQgfSBmcm9tICcuLi9jYW1lcmEvY2FtZXJhLWNvbnRlbnQnO1xuXG5leHRlbmQoeyBPcnRob2dyYXBoaWNDYW1lcmEsIEdyb3VwIH0pO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ25ndHMtb3J0aG9ncmFwaGljLWNhbWVyYScsXG4gICAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgICB0ZW1wbGF0ZTogYFxuICAgICAgICA8bmd0LW9ydGhvZ3JhcGhpYy1jYW1lcmFcbiAgICAgICAgICAgIG5ndENvbXBvdW5kXG4gICAgICAgICAgICBbcmVmXT1cImNhbWVyYVJlZlwiXG4gICAgICAgICAgICBbbGVmdF09XCJsZWZ0JCB8IG5ndFB1c2hcIlxuICAgICAgICAgICAgW3JpZ2h0XT1cInJpZ2h0JCB8IG5ndFB1c2hcIlxuICAgICAgICAgICAgW3RvcF09XCJ0b3AkIHwgbmd0UHVzaFwiXG4gICAgICAgICAgICBbYm90dG9tXT1cImJvdHRvbSQgfCBuZ3RQdXNoXCJcbiAgICAgICAgPlxuICAgICAgICAgICAgPG5nLWNvbnRhaW5lclxuICAgICAgICAgICAgICAgICpuZ0lmPVwiY2FtZXJhQ29udGVudCAmJiAhY2FtZXJhQ29udGVudC5uZ3RzQ2FtZXJhQ29udGVudFwiXG4gICAgICAgICAgICAgICAgW25nVGVtcGxhdGVPdXRsZXRdPVwiY2FtZXJhQ29udGVudC50ZW1wbGF0ZVwiXG4gICAgICAgICAgICAvPlxuICAgICAgICA8L25ndC1vcnRob2dyYXBoaWMtY2FtZXJhPlxuICAgICAgICA8bmd0LWdyb3VwICNncm91cCAqbmdJZj1cImNhbWVyYUNvbnRlbnQgJiYgY2FtZXJhQ29udGVudC5uZ3RzQ2FtZXJhQ29udGVudFwiPlxuICAgICAgICAgICAgPG5nLWNvbnRhaW5lciAqbmdUZW1wbGF0ZU91dGxldD1cImNhbWVyYUNvbnRlbnQudGVtcGxhdGU7IGNvbnRleHQ6IHsgZmJvOiBmYm9SZWYubmF0aXZlRWxlbWVudCwgZ3JvdXAgfVwiIC8+XG4gICAgICAgIDwvbmd0LWdyb3VwPlxuICAgIGAsXG4gICAgaW1wb3J0czogW05nSWYsIE5nVGVtcGxhdGVPdXRsZXQsIE5ndFB1c2hdLFxuICAgIHNjaGVtYXM6IFtDVVNUT01fRUxFTUVOVFNfU0NIRU1BXSxcbn0pXG5leHBvcnQgY2xhc3MgTmd0c09ydGhvZ3JhcGhpY0NhbWVyYSBleHRlbmRzIE5ndHNDYW1lcmE8VEhSRUUuT3J0aG9ncmFwaGljQ2FtZXJhPiB7XG4gICAgQENvbnRlbnRDaGlsZChOZ3RzQ2FtZXJhQ29udGVudCkgY2FtZXJhQ29udGVudD86IE5ndHNDYW1lcmFDb250ZW50O1xuXG4gICAgQElucHV0KCkgc2V0IGxlZnQobGVmdDogbnVtYmVyKSB7XG4gICAgICAgIHRoaXMuc2V0KHsgbGVmdCB9KTtcbiAgICB9XG5cbiAgICBASW5wdXQoKSBzZXQgcmlnaHQocmlnaHQ6IG51bWJlcikge1xuICAgICAgICB0aGlzLnNldCh7IHJpZ2h0IH0pO1xuICAgIH1cblxuICAgIEBJbnB1dCgpIHNldCB0b3AodG9wOiBudW1iZXIpIHtcbiAgICAgICAgdGhpcy5zZXQoeyB0b3AgfSk7XG4gICAgfVxuXG4gICAgQElucHV0KCkgc2V0IGJvdHRvbShib3R0b206IG51bWJlcikge1xuICAgICAgICB0aGlzLnNldCh7IGJvdHRvbSB9KTtcbiAgICB9XG5cbiAgICBvdmVycmlkZSBpbml0aWFsaXplKCk6IHZvaWQge1xuICAgICAgICBzdXBlci5pbml0aWFsaXplKCk7XG4gICAgICAgIHRoaXMuc2V0KHsgbGVmdDogMCwgcmlnaHQ6IDAsIHRvcDogMCwgYm90dG9tOiAwIH0pO1xuICAgIH1cblxuICAgIHJlYWRvbmx5IGxlZnQkID0gY29tYmluZUxhdGVzdChbdGhpcy5zZWxlY3QoJ2xlZnQnKSwgdGhpcy5zdG9yZS5zZWxlY3QoJ3NpemUnKV0pLnBpcGUoXG4gICAgICAgIG1hcCgoW2xlZnQsIHNpemVdKSA9PiBsZWZ0ID8/IHNpemUud2lkdGggLyAtMilcbiAgICApO1xuXG4gICAgcmVhZG9ubHkgcmlnaHQkID0gY29tYmluZUxhdGVzdChbdGhpcy5zZWxlY3QoJ3JpZ2h0JyksIHRoaXMuc3RvcmUuc2VsZWN0KCdzaXplJyldKS5waXBlKFxuICAgICAgICBtYXAoKFtyaWdodCwgc2l6ZV0pID0+IHJpZ2h0ID8/IHNpemUud2lkdGggLyAyKVxuICAgICk7XG5cbiAgICByZWFkb25seSB0b3AkID0gY29tYmluZUxhdGVzdChbdGhpcy5zZWxlY3QoJ3RvcCcpLCB0aGlzLnN0b3JlLnNlbGVjdCgnc2l6ZScpXSkucGlwZShcbiAgICAgICAgbWFwKChbdG9wLCBzaXplXSkgPT4gdG9wID8/IHNpemUuaGVpZ2h0IC8gMilcbiAgICApO1xuXG4gICAgcmVhZG9ubHkgYm90dG9tJCA9IGNvbWJpbmVMYXRlc3QoW3RoaXMuc2VsZWN0KCdib3R0b20nKSwgdGhpcy5zdG9yZS5zZWxlY3QoJ3NpemUnKV0pLnBpcGUoXG4gICAgICAgIG1hcCgoW2JvdHRvbSwgc2l6ZV0pID0+IGJvdHRvbSA/PyBzaXplLmhlaWdodCAvIC0yKVxuICAgICk7XG59XG4iXX0=
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
import { NgIf, NgTemplateOutlet } from '@angular/common';
|
|
2
|
+
import { Component, ContentChild, CUSTOM_ELEMENTS_SCHEMA } from '@angular/core';
|
|
3
|
+
import { extend } from 'angular-three';
|
|
4
|
+
import { Group, PerspectiveCamera } from 'three';
|
|
5
|
+
import { NgtsCamera } from '../camera/camera';
|
|
6
|
+
import { NgtsCameraContent } from '../camera/camera-content';
|
|
7
|
+
import * as i0 from "@angular/core";
|
|
8
|
+
extend({ PerspectiveCamera, Group });
|
|
9
|
+
export class NgtsPerspectiveCamera extends NgtsCamera {
|
|
10
|
+
}
|
|
11
|
+
NgtsPerspectiveCamera.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.3", ngImport: i0, type: NgtsPerspectiveCamera, deps: null, target: i0.ɵɵFactoryTarget.Component });
|
|
12
|
+
NgtsPerspectiveCamera.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.1.3", type: NgtsPerspectiveCamera, isStandalone: true, selector: "ngts-perspective-camera", queries: [{ propertyName: "cameraContent", first: true, predicate: NgtsCameraContent, descendants: true }], usesInheritance: true, ngImport: i0, template: `
|
|
13
|
+
<ngt-perspective-camera [ref]="cameraRef" ngtCompound>
|
|
14
|
+
<ng-container
|
|
15
|
+
*ngIf="cameraContent && !cameraContent.ngtsCameraContent"
|
|
16
|
+
[ngTemplateOutlet]="cameraContent.template"
|
|
17
|
+
/>
|
|
18
|
+
</ngt-perspective-camera>
|
|
19
|
+
<ngt-group #group *ngIf="cameraContent && cameraContent.ngtsCameraContent">
|
|
20
|
+
<ng-container *ngTemplateOutlet="cameraContent.template; context: { fbo: fboRef.nativeElement, group }" />
|
|
21
|
+
</ngt-group>
|
|
22
|
+
`, isInline: true, dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }] });
|
|
23
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.3", ngImport: i0, type: NgtsPerspectiveCamera, decorators: [{
|
|
24
|
+
type: Component,
|
|
25
|
+
args: [{
|
|
26
|
+
selector: 'ngts-perspective-camera',
|
|
27
|
+
standalone: true,
|
|
28
|
+
template: `
|
|
29
|
+
<ngt-perspective-camera [ref]="cameraRef" ngtCompound>
|
|
30
|
+
<ng-container
|
|
31
|
+
*ngIf="cameraContent && !cameraContent.ngtsCameraContent"
|
|
32
|
+
[ngTemplateOutlet]="cameraContent.template"
|
|
33
|
+
/>
|
|
34
|
+
</ngt-perspective-camera>
|
|
35
|
+
<ngt-group #group *ngIf="cameraContent && cameraContent.ngtsCameraContent">
|
|
36
|
+
<ng-container *ngTemplateOutlet="cameraContent.template; context: { fbo: fboRef.nativeElement, group }" />
|
|
37
|
+
</ngt-group>
|
|
38
|
+
`,
|
|
39
|
+
imports: [NgIf, NgTemplateOutlet],
|
|
40
|
+
schemas: [CUSTOM_ELEMENTS_SCHEMA],
|
|
41
|
+
}]
|
|
42
|
+
}], propDecorators: { cameraContent: [{
|
|
43
|
+
type: ContentChild,
|
|
44
|
+
args: [NgtsCameraContent]
|
|
45
|
+
}] } });
|
|
46
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGVyc3BlY3RpdmUtY2FtZXJhLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9hbmd1bGFyLXRocmVlLXNvYmEvY2FtZXJhcy9zcmMvbGliL3BlcnNwZWN0aXZlLWNhbWVyYS9wZXJzcGVjdGl2ZS1jYW1lcmEudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLElBQUksRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQ3pELE9BQU8sRUFBRSxTQUFTLEVBQUUsWUFBWSxFQUFFLHNCQUFzQixFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ2hGLE9BQU8sRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDdkMsT0FBTyxFQUFFLEtBQUssRUFBRSxpQkFBaUIsRUFBRSxNQUFNLE9BQU8sQ0FBQztBQUNqRCxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sa0JBQWtCLENBQUM7QUFDOUMsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sMEJBQTBCLENBQUM7O0FBRTdELE1BQU0sQ0FBQyxFQUFFLGlCQUFpQixFQUFFLEtBQUssRUFBRSxDQUFDLENBQUM7QUFtQnJDLE1BQU0sT0FBTyxxQkFBc0IsU0FBUSxVQUE2Qjs7a0hBQTNELHFCQUFxQjtzR0FBckIscUJBQXFCLDhIQUNoQixpQkFBaUIsdUVBZnJCOzs7Ozs7Ozs7O0tBVVQsNERBQ1MsSUFBSSw2RkFBRSxnQkFBZ0I7MkZBR3ZCLHFCQUFxQjtrQkFqQmpDLFNBQVM7bUJBQUM7b0JBQ1AsUUFBUSxFQUFFLHlCQUF5QjtvQkFDbkMsVUFBVSxFQUFFLElBQUk7b0JBQ2hCLFFBQVEsRUFBRTs7Ozs7Ozs7OztLQVVUO29CQUNELE9BQU8sRUFBRSxDQUFDLElBQUksRUFBRSxnQkFBZ0IsQ0FBQztvQkFDakMsT0FBTyxFQUFFLENBQUMsc0JBQXNCLENBQUM7aUJBQ3BDOzhCQUVvQyxhQUFhO3NCQUE3QyxZQUFZO3VCQUFDLGlCQUFpQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nSWYsIE5nVGVtcGxhdGVPdXRsZXQgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgQ29tcG9uZW50LCBDb250ZW50Q2hpbGQsIENVU1RPTV9FTEVNRU5UU19TQ0hFTUEgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IGV4dGVuZCB9IGZyb20gJ2FuZ3VsYXItdGhyZWUnO1xuaW1wb3J0IHsgR3JvdXAsIFBlcnNwZWN0aXZlQ2FtZXJhIH0gZnJvbSAndGhyZWUnO1xuaW1wb3J0IHsgTmd0c0NhbWVyYSB9IGZyb20gJy4uL2NhbWVyYS9jYW1lcmEnO1xuaW1wb3J0IHsgTmd0c0NhbWVyYUNvbnRlbnQgfSBmcm9tICcuLi9jYW1lcmEvY2FtZXJhLWNvbnRlbnQnO1xuXG5leHRlbmQoeyBQZXJzcGVjdGl2ZUNhbWVyYSwgR3JvdXAgfSk7XG5cbkBDb21wb25lbnQoe1xuICAgIHNlbGVjdG9yOiAnbmd0cy1wZXJzcGVjdGl2ZS1jYW1lcmEnLFxuICAgIHN0YW5kYWxvbmU6IHRydWUsXG4gICAgdGVtcGxhdGU6IGBcbiAgICAgICAgPG5ndC1wZXJzcGVjdGl2ZS1jYW1lcmEgW3JlZl09XCJjYW1lcmFSZWZcIiBuZ3RDb21wb3VuZD5cbiAgICAgICAgICAgIDxuZy1jb250YWluZXJcbiAgICAgICAgICAgICAgICAqbmdJZj1cImNhbWVyYUNvbnRlbnQgJiYgIWNhbWVyYUNvbnRlbnQubmd0c0NhbWVyYUNvbnRlbnRcIlxuICAgICAgICAgICAgICAgIFtuZ1RlbXBsYXRlT3V0bGV0XT1cImNhbWVyYUNvbnRlbnQudGVtcGxhdGVcIlxuICAgICAgICAgICAgLz5cbiAgICAgICAgPC9uZ3QtcGVyc3BlY3RpdmUtY2FtZXJhPlxuICAgICAgICA8bmd0LWdyb3VwICNncm91cCAqbmdJZj1cImNhbWVyYUNvbnRlbnQgJiYgY2FtZXJhQ29udGVudC5uZ3RzQ2FtZXJhQ29udGVudFwiPlxuICAgICAgICAgICAgPG5nLWNvbnRhaW5lciAqbmdUZW1wbGF0ZU91dGxldD1cImNhbWVyYUNvbnRlbnQudGVtcGxhdGU7IGNvbnRleHQ6IHsgZmJvOiBmYm9SZWYubmF0aXZlRWxlbWVudCwgZ3JvdXAgfVwiIC8+XG4gICAgICAgIDwvbmd0LWdyb3VwPlxuICAgIGAsXG4gICAgaW1wb3J0czogW05nSWYsIE5nVGVtcGxhdGVPdXRsZXRdLFxuICAgIHNjaGVtYXM6IFtDVVNUT01fRUxFTUVOVFNfU0NIRU1BXSxcbn0pXG5leHBvcnQgY2xhc3MgTmd0c1BlcnNwZWN0aXZlQ2FtZXJhIGV4dGVuZHMgTmd0c0NhbWVyYTxQZXJzcGVjdGl2ZUNhbWVyYT4ge1xuICAgIEBDb250ZW50Q2hpbGQoTmd0c0NhbWVyYUNvbnRlbnQpIGNhbWVyYUNvbnRlbnQ/OiBOZ3RzQ2FtZXJhQ29udGVudDtcbn1cbiJdfQ==
|
package/esm2020/misc/index.mjs
CHANGED
|
@@ -1,2 +1,3 @@
|
|
|
1
1
|
export * from './lib/bake-shadows/bake-shadows';
|
|
2
|
-
|
|
2
|
+
export * from './lib/fbo/fbo';
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWJzL2FuZ3VsYXItdGhyZWUtc29iYS9taXNjL3NyYy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLGlDQUFpQyxDQUFDO0FBQ2hELGNBQWMsZUFBZSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9saWIvYmFrZS1zaGFkb3dzL2Jha2Utc2hhZG93cyc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9mYm8vZmJvJztcbiJdfQ==
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import { inject } from '@angular/core';
|
|
2
|
+
import { injectNgtDestroy, injectNgtRef, NgtStore, safeDetectChanges } from 'angular-three';
|
|
3
|
+
import { isObservable, of, takeUntil } from 'rxjs';
|
|
4
|
+
import * as THREE from 'three';
|
|
5
|
+
export function injectNgtsFBO(paramsFactory) {
|
|
6
|
+
const store = inject(NgtStore);
|
|
7
|
+
const targetRef = injectNgtRef();
|
|
8
|
+
const { destroy$, cdr } = injectNgtDestroy(() => {
|
|
9
|
+
targetRef.nativeElement?.dispose();
|
|
10
|
+
});
|
|
11
|
+
const params = paramsFactory({});
|
|
12
|
+
const params$ = isObservable(params) ? params : of(params);
|
|
13
|
+
params$.pipe(takeUntil(destroy$)).subscribe(({ width, height, settings }) => {
|
|
14
|
+
const { gl, size, viewport } = store.get();
|
|
15
|
+
const _width = typeof width === 'number' ? width : size.width * viewport.dpr;
|
|
16
|
+
const _height = typeof height === 'number' ? height : size.height * viewport.dpr;
|
|
17
|
+
const _settings = (typeof width === 'number' ? settings : width) || {};
|
|
18
|
+
const { samples, ...targetSettings } = _settings;
|
|
19
|
+
if (!targetRef.nativeElement) {
|
|
20
|
+
const target = new THREE.WebGLRenderTarget(_width, _height, {
|
|
21
|
+
minFilter: THREE.LinearFilter,
|
|
22
|
+
magFilter: THREE.LinearFilter,
|
|
23
|
+
encoding: gl.outputEncoding,
|
|
24
|
+
type: THREE.HalfFloatType,
|
|
25
|
+
...targetSettings,
|
|
26
|
+
});
|
|
27
|
+
if (samples)
|
|
28
|
+
target.samples = samples;
|
|
29
|
+
targetRef.nativeElement = target;
|
|
30
|
+
}
|
|
31
|
+
targetRef.nativeElement.setSize(_width, _height);
|
|
32
|
+
if (samples)
|
|
33
|
+
targetRef.nativeElement.samples = samples;
|
|
34
|
+
safeDetectChanges(cdr);
|
|
35
|
+
});
|
|
36
|
+
return targetRef;
|
|
37
|
+
}
|
|
38
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmJvLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9hbmd1bGFyLXRocmVlLXNvYmEvbWlzYy9zcmMvbGliL2Ziby9mYm8udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN2QyxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsWUFBWSxFQUFFLFFBQVEsRUFBRSxpQkFBaUIsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUM1RixPQUFPLEVBQUUsWUFBWSxFQUFjLEVBQUUsRUFBRSxTQUFTLEVBQUUsTUFBTSxNQUFNLENBQUM7QUFDL0QsT0FBTyxLQUFLLEtBQUssTUFBTSxPQUFPLENBQUM7QUFhL0IsTUFBTSxVQUFVLGFBQWEsQ0FDekIsYUFBNEc7SUFFNUcsTUFBTSxLQUFLLEdBQUcsTUFBTSxDQUFDLFFBQVEsQ0FBQyxDQUFDO0lBQy9CLE1BQU0sU0FBUyxHQUFHLFlBQVksRUFBMkIsQ0FBQztJQUMxRCxNQUFNLEVBQUUsUUFBUSxFQUFFLEdBQUcsRUFBRSxHQUFHLGdCQUFnQixDQUFDLEdBQUcsRUFBRTtRQUM1QyxTQUFTLENBQUMsYUFBYSxFQUFFLE9BQU8sRUFBRSxDQUFDO0lBQ3ZDLENBQUMsQ0FBQyxDQUFDO0lBQ0gsTUFBTSxNQUFNLEdBQUcsYUFBYSxDQUFDLEVBQUUsQ0FBQyxDQUFDO0lBQ2pDLE1BQU0sT0FBTyxHQUFHLFlBQVksQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsTUFBTSxDQUFDLENBQUM7SUFFM0QsT0FBTyxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsUUFBUSxDQUFDLENBQUMsQ0FBQyxTQUFTLENBQUMsQ0FBQyxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUUsUUFBUSxFQUFFLEVBQUUsRUFBRTtRQUN4RSxNQUFNLEVBQUUsRUFBRSxFQUFFLElBQUksRUFBRSxRQUFRLEVBQUUsR0FBRyxLQUFLLENBQUMsR0FBRyxFQUFFLENBQUM7UUFDM0MsTUFBTSxNQUFNLEdBQUcsT0FBTyxLQUFLLEtBQUssUUFBUSxDQUFDLENBQUMsQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxLQUFLLEdBQUcsUUFBUSxDQUFDLEdBQUcsQ0FBQztRQUM3RSxNQUFNLE9BQU8sR0FBRyxPQUFPLE1BQU0sS0FBSyxRQUFRLENBQUMsQ0FBQyxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLE1BQU0sR0FBRyxRQUFRLENBQUMsR0FBRyxDQUFDO1FBQ2pGLE1BQU0sU0FBUyxHQUFHLENBQUMsT0FBTyxLQUFLLEtBQUssUUFBUSxDQUFDLENBQUMsQ0FBQyxRQUFRLENBQUMsQ0FBQyxDQUFFLEtBQXFCLENBQUMsSUFBSSxFQUFFLENBQUM7UUFFeEYsTUFBTSxFQUFFLE9BQU8sRUFBRSxHQUFHLGNBQWMsRUFBRSxHQUFHLFNBQVMsQ0FBQztRQUVqRCxJQUFJLENBQUMsU0FBUyxDQUFDLGFBQWEsRUFBRTtZQUMxQixNQUFNLE1BQU0sR0FBRyxJQUFJLEtBQUssQ0FBQyxpQkFBaUIsQ0FBQyxNQUFNLEVBQUUsT0FBTyxFQUFFO2dCQUN4RCxTQUFTLEVBQUUsS0FBSyxDQUFDLFlBQVk7Z0JBQzdCLFNBQVMsRUFBRSxLQUFLLENBQUMsWUFBWTtnQkFDN0IsUUFBUSxFQUFFLEVBQUUsQ0FBQyxjQUFjO2dCQUMzQixJQUFJLEVBQUUsS0FBSyxDQUFDLGFBQWE7Z0JBQ3pCLEdBQUcsY0FBYzthQUNwQixDQUFDLENBQUM7WUFDSCxJQUFJLE9BQU87Z0JBQUUsTUFBTSxDQUFDLE9BQU8sR0FBRyxPQUFPLENBQUM7WUFDdEMsU0FBUyxDQUFDLGFBQWEsR0FBRyxNQUFNLENBQUM7U0FDcEM7UUFFRCxTQUFTLENBQUMsYUFBYSxDQUFDLE9BQU8sQ0FBQyxNQUFNLEVBQUUsT0FBTyxDQUFDLENBQUM7UUFDakQsSUFBSSxPQUFPO1lBQUUsU0FBUyxDQUFDLGFBQWEsQ0FBQyxPQUFPLEdBQUcsT0FBTyxDQUFDO1FBQ3ZELGlCQUFpQixDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBQzNCLENBQUMsQ0FBQyxDQUFDO0lBRUgsT0FBTyxTQUFTLENBQUM7QUFDckIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGluamVjdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgaW5qZWN0Tmd0RGVzdHJveSwgaW5qZWN0Tmd0UmVmLCBOZ3RTdG9yZSwgc2FmZURldGVjdENoYW5nZXMgfSBmcm9tICdhbmd1bGFyLXRocmVlJztcbmltcG9ydCB7IGlzT2JzZXJ2YWJsZSwgT2JzZXJ2YWJsZSwgb2YsIHRha2VVbnRpbCB9IGZyb20gJ3J4anMnO1xuaW1wb3J0ICogYXMgVEhSRUUgZnJvbSAndGhyZWUnO1xuXG5pbnRlcmZhY2UgRkJPU2V0dGluZ3M8VCBleHRlbmRzIGJvb2xlYW4gPSBmYWxzZT4gZXh0ZW5kcyBUSFJFRS5XZWJHTFJlbmRlclRhcmdldE9wdGlvbnMge1xuICAgIG11bHRpc2FtcGxlPzogVDtcbiAgICBzYW1wbGVzPzogbnVtYmVyO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIE5ndHNGQk9QYXJhbXM8VCBleHRlbmRzIGJvb2xlYW4gPSBmYWxzZT4ge1xuICAgIHdpZHRoPzogbnVtYmVyIHwgRkJPU2V0dGluZ3M8VD47XG4gICAgaGVpZ2h0PzogbnVtYmVyO1xuICAgIHNldHRpbmdzPzogRkJPU2V0dGluZ3M8VD47XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBpbmplY3ROZ3RzRkJPPFQgZXh0ZW5kcyBib29sZWFuID0gZmFsc2U+KFxuICAgIHBhcmFtc0ZhY3Rvcnk6IChkZWZhdWx0UGFyYW1zOiBQYXJ0aWFsPE5ndHNGQk9QYXJhbXM8VD4+KSA9PiBOZ3RzRkJPUGFyYW1zPFQ+IHwgT2JzZXJ2YWJsZTxOZ3RzRkJPUGFyYW1zPFQ+PlxuKSB7XG4gICAgY29uc3Qgc3RvcmUgPSBpbmplY3QoTmd0U3RvcmUpO1xuICAgIGNvbnN0IHRhcmdldFJlZiA9IGluamVjdE5ndFJlZjxUSFJFRS5XZWJHTFJlbmRlclRhcmdldD4oKTtcbiAgICBjb25zdCB7IGRlc3Ryb3kkLCBjZHIgfSA9IGluamVjdE5ndERlc3Ryb3koKCkgPT4ge1xuICAgICAgICB0YXJnZXRSZWYubmF0aXZlRWxlbWVudD8uZGlzcG9zZSgpO1xuICAgIH0pO1xuICAgIGNvbnN0IHBhcmFtcyA9IHBhcmFtc0ZhY3Rvcnkoe30pO1xuICAgIGNvbnN0IHBhcmFtcyQgPSBpc09ic2VydmFibGUocGFyYW1zKSA/IHBhcmFtcyA6IG9mKHBhcmFtcyk7XG5cbiAgICBwYXJhbXMkLnBpcGUodGFrZVVudGlsKGRlc3Ryb3kkKSkuc3Vic2NyaWJlKCh7IHdpZHRoLCBoZWlnaHQsIHNldHRpbmdzIH0pID0+IHtcbiAgICAgICAgY29uc3QgeyBnbCwgc2l6ZSwgdmlld3BvcnQgfSA9IHN0b3JlLmdldCgpO1xuICAgICAgICBjb25zdCBfd2lkdGggPSB0eXBlb2Ygd2lkdGggPT09ICdudW1iZXInID8gd2lkdGggOiBzaXplLndpZHRoICogdmlld3BvcnQuZHByO1xuICAgICAgICBjb25zdCBfaGVpZ2h0ID0gdHlwZW9mIGhlaWdodCA9PT0gJ251bWJlcicgPyBoZWlnaHQgOiBzaXplLmhlaWdodCAqIHZpZXdwb3J0LmRwcjtcbiAgICAgICAgY29uc3QgX3NldHRpbmdzID0gKHR5cGVvZiB3aWR0aCA9PT0gJ251bWJlcicgPyBzZXR0aW5ncyA6ICh3aWR0aCBhcyBGQk9TZXR0aW5ncykpIHx8IHt9O1xuXG4gICAgICAgIGNvbnN0IHsgc2FtcGxlcywgLi4udGFyZ2V0U2V0dGluZ3MgfSA9IF9zZXR0aW5ncztcblxuICAgICAgICBpZiAoIXRhcmdldFJlZi5uYXRpdmVFbGVtZW50KSB7XG4gICAgICAgICAgICBjb25zdCB0YXJnZXQgPSBuZXcgVEhSRUUuV2ViR0xSZW5kZXJUYXJnZXQoX3dpZHRoLCBfaGVpZ2h0LCB7XG4gICAgICAgICAgICAgICAgbWluRmlsdGVyOiBUSFJFRS5MaW5lYXJGaWx0ZXIsXG4gICAgICAgICAgICAgICAgbWFnRmlsdGVyOiBUSFJFRS5MaW5lYXJGaWx0ZXIsXG4gICAgICAgICAgICAgICAgZW5jb2Rpbmc6IGdsLm91dHB1dEVuY29kaW5nLFxuICAgICAgICAgICAgICAgIHR5cGU6IFRIUkVFLkhhbGZGbG9hdFR5cGUsXG4gICAgICAgICAgICAgICAgLi4udGFyZ2V0U2V0dGluZ3MsXG4gICAgICAgICAgICB9KTtcbiAgICAgICAgICAgIGlmIChzYW1wbGVzKSB0YXJnZXQuc2FtcGxlcyA9IHNhbXBsZXM7XG4gICAgICAgICAgICB0YXJnZXRSZWYubmF0aXZlRWxlbWVudCA9IHRhcmdldDtcbiAgICAgICAgfVxuXG4gICAgICAgIHRhcmdldFJlZi5uYXRpdmVFbGVtZW50LnNldFNpemUoX3dpZHRoLCBfaGVpZ2h0KTtcbiAgICAgICAgaWYgKHNhbXBsZXMpIHRhcmdldFJlZi5uYXRpdmVFbGVtZW50LnNhbXBsZXMgPSBzYW1wbGVzO1xuICAgICAgICBzYWZlRGV0ZWN0Q2hhbmdlcyhjZHIpO1xuICAgIH0pO1xuXG4gICAgcmV0dXJuIHRhcmdldFJlZjtcbn1cbiJdfQ==
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { Component, CUSTOM_ELEMENTS_SCHEMA, Directive, inject, InjectionToken, Input } from '@angular/core';
|
|
2
|
-
import { extend, getLocalState,
|
|
2
|
+
import { extend, getLocalState, injectNgtRef, NgtRxStore, NgtStore } from 'angular-three';
|
|
3
3
|
import { shaderMaterial } from 'angular-three-soba/shaders';
|
|
4
|
-
import { combineLatest } from 'rxjs';
|
|
4
|
+
import { combineLatest, Subject } from 'rxjs';
|
|
5
5
|
import * as THREE from 'three';
|
|
6
6
|
import { Group, Mesh, PlaneGeometry } from 'three';
|
|
7
7
|
import { ProgressiveLightMap } from './progressive-light-map';
|
|
@@ -17,7 +17,7 @@ const SoftShadowMaterial = shaderMaterial({
|
|
|
17
17
|
`
|
|
18
18
|
varying vec2 vUv;
|
|
19
19
|
void main() {
|
|
20
|
-
gl_Position = projectionMatrix * viewMatrix *
|
|
20
|
+
gl_Position = projectionMatrix * viewMatrix * modelMatrix * vec4(position, 1.);
|
|
21
21
|
vUv = uv;
|
|
22
22
|
}
|
|
23
23
|
`,
|
|
@@ -30,7 +30,7 @@ uniform float blend;
|
|
|
30
30
|
uniform float opacity;
|
|
31
31
|
uniform float alphaTest;
|
|
32
32
|
void main() {
|
|
33
|
-
vec4
|
|
33
|
+
vec4 sampledDiffuseColor = texture2D(map, vUv);
|
|
34
34
|
gl_FragColor = vec4(color * sampledDiffuseColor.r * blend, max(0.0, (1.0 - (sampledDiffuseColor.r + sampledDiffuseColor.g + sampledDiffuseColor.b) / alphaTest)) * opacity);
|
|
35
35
|
#include <tonemapping_fragment>
|
|
36
36
|
#include <encodings_fragment>
|
|
@@ -90,6 +90,7 @@ function accumulativeShadowsApiFactory(accumulativeShadows) {
|
|
|
90
90
|
: accumulativeShadows.get('frames')),
|
|
91
91
|
},
|
|
92
92
|
});
|
|
93
|
+
const subject = new Subject();
|
|
93
94
|
accumulativeShadows.hold(accumulativeShadows.meshRef.$, (mesh) => {
|
|
94
95
|
accumulativeShadows.pLM.configure(mesh);
|
|
95
96
|
accumulativeShadows.hold(combineLatest([accumulativeShadows.select(), getLocalState(store.get('scene')).objects]), () => {
|
|
@@ -99,13 +100,14 @@ function accumulativeShadowsApiFactory(accumulativeShadows) {
|
|
|
99
100
|
if (!api.temporal && api.frames !== Infinity)
|
|
100
101
|
api.update(api.blend);
|
|
101
102
|
});
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
}
|
|
103
|
+
accumulativeShadows.effect(subject, () => store.get('internal').subscribe(() => {
|
|
104
|
+
const limit = accumulativeShadows.get('limit');
|
|
105
|
+
if ((api.temporal || api.frames === Infinity) && api.count < api.frames && api.count < limit) {
|
|
106
|
+
api.update();
|
|
107
|
+
api.count++;
|
|
108
|
+
}
|
|
109
|
+
}));
|
|
110
|
+
subject.next();
|
|
109
111
|
});
|
|
110
112
|
return api;
|
|
111
113
|
}
|
|
@@ -273,4 +275,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.3", ngImpor
|
|
|
273
275
|
}], toneMapped: [{
|
|
274
276
|
type: Input
|
|
275
277
|
}] } });
|
|
276
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"accumulative-shadows.js","sourceRoot":"","sources":["../../../../../../../libs/angular-three-soba/staging/src/lib/accumulative-shadows/accumulative-shadows.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, CUSTOM_ELEMENTS_SCHEMA, Directive, inject, InjectionToken, Input } from '@angular/core';\nimport { extend, getLocalState, injectBeforeRender, injectNgtRef, NgtRxStore, NgtStore } from 'angular-three';\nimport { shaderMaterial } from 'angular-three-soba/shaders';\nimport { combineLatest } from 'rxjs';\nimport * as THREE from 'three';\nimport { Group, Mesh, PlaneGeometry } from 'three';\nimport { ProgressiveLightMap } from './progressive-light-map';\n\nconst SoftShadowMaterial = shaderMaterial(\n    {\n        color: new THREE.Color(),\n        blend: 2.0,\n        alphaTest: 0.75,\n        opacity: 0,\n        map: null,\n    },\n    // language=GLSL\n    `\nvarying vec2 vUv;\nvoid main() {\n  gl_Position = projectionMatrix * viewMatrix * modeLMatrix * vec4(position, 1.);\n  vUv = uv;\n}\n  `,\n    // language=GLSL\n    `\nvarying vec2 vUv;\nuniform sampler2D map;\nuniform vec3 color;\nuniform float blend;\nuniform float opacity;\nuniform float alphaTest;\nvoid main() {\n  vec4 sampleDiffuseColor = texture2D(map, vUv):\n  gl_FragColor = vec4(color * sampledDiffuseColor.r * blend, max(0.0, (1.0 - (sampledDiffuseColor.r + sampledDiffuseColor.g + sampledDiffuseColor.b) / alphaTest)) * opacity);\n  #include <tonemapping_fragment>\n  #include <encodings_fragment>\n}\n  `\n);\n\ntype SoftShadowMaterialInputs = {\n    map: THREE.Texture;\n    color?: THREE.ColorRepresentation;\n    alphaTest?: number;\n    blend?: number;\n};\n\nextend({ SoftShadowMaterial, Group, Mesh, PlaneGeometry });\n\nexport type NgtsAccumulativeShadowsLightApi = { update: () => void };\n\nexport type NgtsAccumulativeShadowsApi = {\n    lights: Map<string, NgtsAccumulativeShadowsLightApi>;\n    temporal: boolean;\n    frames: number;\n    blend: number;\n    count: number;\n    getMesh: () => THREE.Mesh<THREE.PlaneGeometry, SoftShadowMaterialInputs & THREE.ShaderMaterial>;\n    reset: () => void;\n    update: (frames?: number) => void;\n};\n\nexport const NGTS_ACCUMULATIVE_SHADOWS_API = new InjectionToken<NgtsAccumulativeShadowsApi>(\n    'NgtsAccumulativeShadows API'\n);\n\nfunction accumulativeShadowsApiFactory(accumulativeShadows: NgtsAccumulativeShadows) {\n    const store = inject(NgtStore);\n\n    const api = {\n        lights: new Map(),\n        count: 0,\n        getMesh: () =>\n            accumulativeShadows.meshRef.nativeElement as THREE.Mesh<\n                THREE.PlaneGeometry,\n                SoftShadowMaterialInputs & THREE.ShaderMaterial\n            >,\n        reset: () => {\n            accumulativeShadows.pLM.clear();\n            const material = api.getMesh().material;\n            material.opacity = 0;\n            material.alphaTest = 0;\n            api.count = 0;\n        },\n        update: (frames = 1) => {\n            // adapt the opacity blend ratio to the number of frames\n            const material = api.getMesh().material;\n            if (!api.temporal) {\n                material.opacity = accumulativeShadows.get('opacity');\n                material.alphaTest = accumulativeShadows.get('alphaTest');\n            } else {\n                material.opacity = Math.min(\n                    accumulativeShadows.get('opacity'),\n                    material.opacity + accumulativeShadows.get('opacity') / api.blend\n                );\n                material.alphaTest = Math.min(\n                    accumulativeShadows.get('alphaTest'),\n                    material.alphaTest + accumulativeShadows.get('alphaTest') / api.blend\n                );\n            }\n\n            // switch accumulative lights on\n            accumulativeShadows.accumulativeShadowsRef.nativeElement.visible = true;\n            // collect scene lights and meshes\n            accumulativeShadows.pLM.prepare();\n\n            // update the lightmap and the accumulative lights\n            for (let i = 0; i < frames; i++) {\n                api.lights.forEach((light) => light.update());\n                accumulativeShadows.pLM.update(store.get('camera'), api.blend);\n            }\n\n            // switch lights off\n            accumulativeShadows.accumulativeShadowsRef.nativeElement.visible = false;\n            // restore lights and meshes\n            accumulativeShadows.pLM.finish();\n        },\n    } as NgtsAccumulativeShadowsApi;\n\n    Object.defineProperties(api, {\n        temporal: {\n            get: () => !!accumulativeShadows.get('temporal'),\n        },\n        frames: {\n            get: () => Math.max(2, accumulativeShadows.get('frames')),\n        },\n        blend: {\n            get: () =>\n                Math.max(\n                    2,\n                    accumulativeShadows.get('frames') === Infinity\n                        ? accumulativeShadows.get('blend')\n                        : accumulativeShadows.get('frames')\n                ),\n        },\n    });\n\n    accumulativeShadows.hold(accumulativeShadows.meshRef.$, (mesh) => {\n        accumulativeShadows.pLM.configure(mesh);\n\n        accumulativeShadows.hold(\n            combineLatest([accumulativeShadows.select(), getLocalState(store.get('scene')).objects]),\n            () => {\n                // reset internals, buffers, ...\n                api.reset();\n                // update lightmap\n                if (!api.temporal && api.frames !== Infinity) api.update(api.blend);\n            }\n        );\n    });\n\n    injectBeforeRender(() => {\n        const limit = accumulativeShadows.get('limit');\n        if (api.getMesh() && (api.temporal || api.frames === Infinity) && api.count < api.frames && api.count < limit) {\n            api.update();\n            api.count++;\n        }\n    });\n\n    return api;\n}\n\n@Directive({ selector: 'ngts-accumulative-shadows-consumer', standalone: true })\nexport class AccumulativeShadowsConsumer {\n    constructor() {\n        inject(NGTS_ACCUMULATIVE_SHADOWS_API);\n    }\n}\n\n@Component({\n    selector: 'ngts-accumulative-shadows',\n    standalone: true,\n    template: `\n        <ngt-group ngtCompound>\n            <ngt-group [ref]=\"accumulativeShadowsRef\" [traverse]=\"nullTraverse\">\n                <ng-content />\n                <ngts-accumulative-shadows-consumer />\n            </ngt-group>\n            <ngt-mesh [receiveShadow]=\"true\" [ref]=\"meshRef\" [scale]=\"get('scale')\" [rotation]=\"[-Math.PI / 2, 0, 0]\">\n                <ngt-plane-geometry />\n                <ngt-soft-shadow-material\n                    [transparent]=\"true\"\n                    [depthWrite]=\"false\"\n                    [color]=\"get('color')\"\n                    [toneMapped]=\"get('toneMapped')\"\n                    [blend]=\"get('colorBlend')\"\n                    [map]=\"pLM.progressiveLightMap2.texture\"\n                />\n            </ngt-mesh>\n        </ngt-group>\n    `,\n    imports: [AccumulativeShadowsConsumer],\n    providers: [\n        {\n            provide: NGTS_ACCUMULATIVE_SHADOWS_API,\n            useFactory: accumulativeShadowsApiFactory,\n            deps: [NgtsAccumulativeShadows],\n        },\n    ],\n    schemas: [CUSTOM_ELEMENTS_SCHEMA],\n})\nexport class NgtsAccumulativeShadows extends NgtRxStore {\n    readonly nullTraverse = () => null;\n    readonly Math = Math;\n\n    private readonly store = inject(NgtStore);\n\n    readonly pLM = new ProgressiveLightMap(this.store.get('gl'), this.store.get('scene'), this.get('resolution'));\n\n    readonly accumulativeShadowsRef = injectNgtRef<THREE.Group>();\n    readonly meshRef = injectNgtRef<THREE.Mesh>();\n\n    /** How many frames it can render, more yields cleaner results but takes more time, 40 */\n    @Input() set frames(frames: number) {\n        this.set({ frames });\n    }\n\n    /** If frames === Infinity blend controls the refresh ratio, 100 */\n    @Input() set blend(blend: number) {\n        this.set({ blend });\n    }\n\n    /** Can limit the amount of frames rendered if frames === Infinity, usually to get some performance back once a movable scene has settled, Infinity */\n    @Input() set limit(limit: number) {\n        this.set({ limit });\n    }\n\n    /** Scale of the plane,  */\n    @Input() set scale(scale: number) {\n        this.set({ scale });\n    }\n\n    /** Temporal accumulates shadows over time which is more performant but has a visual regression over instant results, false  */\n    @Input() set temporal(temporal: boolean) {\n        this.set({ temporal });\n    }\n\n    /** Opacity of the plane, 1 */\n    @Input() set opacity(opacity: number) {\n        this.set({ opacity });\n    }\n\n    /** Discards alpha pixels, 0.65 */\n    @Input() set alphaTest(alphaTest: number) {\n        this.set({ alphaTest });\n    }\n\n    /** Shadow color, black */\n    @Input() set color(color: string) {\n        this.set({ color });\n    }\n\n    /** Colorblend, how much colors turn to black, 0 is black, 2 */\n    @Input() set colorBlend(colorBlend: number) {\n        this.set({ colorBlend });\n    }\n\n    /** Buffer resolution, 1024 */\n    @Input() set resolution(resolution: number) {\n        this.set({ resolution });\n    }\n\n    /** Texture tonemapping */\n    @Input() set toneMapped(toneMapped: boolean) {\n        this.set({ toneMapped });\n    }\n\n    override initialize(): void {\n        super.initialize();\n        this.set({\n            frames: 40,\n            limit: Infinity,\n            blend: 20,\n            scale: 10,\n            opacity: 1,\n            alphaTest: 0.75,\n            color: 'black',\n            colorBlend: 2,\n            resolution: 1024,\n            toneMapped: true,\n        });\n    }\n}\n"]}
|
|
278
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"accumulative-shadows.js","sourceRoot":"","sources":["../../../../../../../libs/angular-three-soba/staging/src/lib/accumulative-shadows/accumulative-shadows.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, CUSTOM_ELEMENTS_SCHEMA, Directive, inject, InjectionToken, Input } from '@angular/core';\nimport { extend, getLocalState, injectNgtRef, NgtRxStore, NgtStore } from 'angular-three';\nimport { shaderMaterial } from 'angular-three-soba/shaders';\nimport { combineLatest, Subject } from 'rxjs';\nimport * as THREE from 'three';\nimport { Group, Mesh, PlaneGeometry } from 'three';\nimport { ProgressiveLightMap } from './progressive-light-map';\n\nconst SoftShadowMaterial = shaderMaterial(\n    {\n        color: new THREE.Color(),\n        blend: 2.0,\n        alphaTest: 0.75,\n        opacity: 0,\n        map: null,\n    },\n    // language=GLSL\n    `\nvarying vec2 vUv;\nvoid main() {\n  gl_Position = projectionMatrix * viewMatrix * modelMatrix * vec4(position, 1.);\n  vUv = uv;\n}\n  `,\n    // language=GLSL\n    `\nvarying vec2 vUv;\nuniform sampler2D map;\nuniform vec3 color;\nuniform float blend;\nuniform float opacity;\nuniform float alphaTest;\nvoid main() {\n  vec4 sampledDiffuseColor = texture2D(map, vUv);\n  gl_FragColor = vec4(color * sampledDiffuseColor.r * blend, max(0.0, (1.0 - (sampledDiffuseColor.r + sampledDiffuseColor.g + sampledDiffuseColor.b) / alphaTest)) * opacity);\n  #include <tonemapping_fragment>\n  #include <encodings_fragment>\n}\n  `\n);\n\ntype SoftShadowMaterialInputs = {\n    map: THREE.Texture;\n    color?: THREE.ColorRepresentation;\n    alphaTest?: number;\n    blend?: number;\n};\n\nextend({ SoftShadowMaterial, Group, Mesh, PlaneGeometry });\n\nexport type NgtsAccumulativeShadowsLightApi = { update: () => void };\n\nexport type NgtsAccumulativeShadowsApi = {\n    lights: Map<string, NgtsAccumulativeShadowsLightApi>;\n    temporal: boolean;\n    frames: number;\n    blend: number;\n    count: number;\n    getMesh: () => THREE.Mesh<THREE.PlaneGeometry, SoftShadowMaterialInputs & THREE.ShaderMaterial>;\n    reset: () => void;\n    update: (frames?: number) => void;\n};\n\nexport const NGTS_ACCUMULATIVE_SHADOWS_API = new InjectionToken<NgtsAccumulativeShadowsApi>(\n    'NgtsAccumulativeShadows API'\n);\n\nfunction accumulativeShadowsApiFactory(accumulativeShadows: NgtsAccumulativeShadows) {\n    const store = inject(NgtStore);\n\n    const api = {\n        lights: new Map(),\n        count: 0,\n        getMesh: () =>\n            accumulativeShadows.meshRef.nativeElement as THREE.Mesh<\n                THREE.PlaneGeometry,\n                SoftShadowMaterialInputs & THREE.ShaderMaterial\n            >,\n        reset: () => {\n            accumulativeShadows.pLM.clear();\n            const material = api.getMesh().material;\n            material.opacity = 0;\n            material.alphaTest = 0;\n            api.count = 0;\n        },\n        update: (frames = 1) => {\n            // adapt the opacity blend ratio to the number of frames\n            const material = api.getMesh().material;\n            if (!api.temporal) {\n                material.opacity = accumulativeShadows.get('opacity');\n                material.alphaTest = accumulativeShadows.get('alphaTest');\n            } else {\n                material.opacity = Math.min(\n                    accumulativeShadows.get('opacity'),\n                    material.opacity + accumulativeShadows.get('opacity') / api.blend\n                );\n                material.alphaTest = Math.min(\n                    accumulativeShadows.get('alphaTest'),\n                    material.alphaTest + accumulativeShadows.get('alphaTest') / api.blend\n                );\n            }\n\n            // switch accumulative lights on\n            accumulativeShadows.accumulativeShadowsRef.nativeElement.visible = true;\n            // collect scene lights and meshes\n            accumulativeShadows.pLM.prepare();\n\n            // update the lightmap and the accumulative lights\n            for (let i = 0; i < frames; i++) {\n                api.lights.forEach((light) => light.update());\n                accumulativeShadows.pLM.update(store.get('camera'), api.blend);\n            }\n\n            // switch lights off\n            accumulativeShadows.accumulativeShadowsRef.nativeElement.visible = false;\n            // restore lights and meshes\n            accumulativeShadows.pLM.finish();\n        },\n    } as NgtsAccumulativeShadowsApi;\n\n    Object.defineProperties(api, {\n        temporal: {\n            get: () => !!accumulativeShadows.get('temporal'),\n        },\n        frames: {\n            get: () => Math.max(2, accumulativeShadows.get('frames')),\n        },\n        blend: {\n            get: () =>\n                Math.max(\n                    2,\n                    accumulativeShadows.get('frames') === Infinity\n                        ? accumulativeShadows.get('blend')\n                        : accumulativeShadows.get('frames')\n                ),\n        },\n    });\n\n    const subject = new Subject<void>();\n\n    accumulativeShadows.hold(accumulativeShadows.meshRef.$, (mesh) => {\n        accumulativeShadows.pLM.configure(mesh);\n\n        accumulativeShadows.hold(\n            combineLatest([accumulativeShadows.select(), getLocalState(store.get('scene')).objects]),\n            () => {\n                // reset internals, buffers, ...\n                api.reset();\n                // update lightmap\n                if (!api.temporal && api.frames !== Infinity) api.update(api.blend);\n            }\n        );\n\n        accumulativeShadows.effect(subject, () =>\n            store.get('internal').subscribe(() => {\n                const limit = accumulativeShadows.get('limit');\n                if ((api.temporal || api.frames === Infinity) && api.count < api.frames && api.count < limit) {\n                    api.update();\n                    api.count++;\n                }\n            })\n        );\n        subject.next();\n    });\n\n    return api;\n}\n\n@Directive({ selector: 'ngts-accumulative-shadows-consumer', standalone: true })\nexport class AccumulativeShadowsConsumer {\n    constructor() {\n        inject(NGTS_ACCUMULATIVE_SHADOWS_API);\n    }\n}\n\n@Component({\n    selector: 'ngts-accumulative-shadows',\n    standalone: true,\n    template: `\n        <ngt-group ngtCompound>\n            <ngt-group [ref]=\"accumulativeShadowsRef\" [traverse]=\"nullTraverse\">\n                <ng-content />\n                <ngts-accumulative-shadows-consumer />\n            </ngt-group>\n            <ngt-mesh [receiveShadow]=\"true\" [ref]=\"meshRef\" [scale]=\"get('scale')\" [rotation]=\"[-Math.PI / 2, 0, 0]\">\n                <ngt-plane-geometry />\n                <ngt-soft-shadow-material\n                    [transparent]=\"true\"\n                    [depthWrite]=\"false\"\n                    [color]=\"get('color')\"\n                    [toneMapped]=\"get('toneMapped')\"\n                    [blend]=\"get('colorBlend')\"\n                    [map]=\"pLM.progressiveLightMap2.texture\"\n                />\n            </ngt-mesh>\n        </ngt-group>\n    `,\n    imports: [AccumulativeShadowsConsumer],\n    providers: [\n        {\n            provide: NGTS_ACCUMULATIVE_SHADOWS_API,\n            useFactory: accumulativeShadowsApiFactory,\n            deps: [NgtsAccumulativeShadows],\n        },\n    ],\n    schemas: [CUSTOM_ELEMENTS_SCHEMA],\n})\nexport class NgtsAccumulativeShadows extends NgtRxStore {\n    readonly nullTraverse = () => null;\n    readonly Math = Math;\n\n    private readonly store = inject(NgtStore);\n\n    readonly pLM = new ProgressiveLightMap(this.store.get('gl'), this.store.get('scene'), this.get('resolution'));\n\n    readonly accumulativeShadowsRef = injectNgtRef<THREE.Group>();\n    readonly meshRef = injectNgtRef<THREE.Mesh>();\n\n    /** How many frames it can render, more yields cleaner results but takes more time, 40 */\n    @Input() set frames(frames: number) {\n        this.set({ frames });\n    }\n\n    /** If frames === Infinity blend controls the refresh ratio, 100 */\n    @Input() set blend(blend: number) {\n        this.set({ blend });\n    }\n\n    /** Can limit the amount of frames rendered if frames === Infinity, usually to get some performance back once a movable scene has settled, Infinity */\n    @Input() set limit(limit: number) {\n        this.set({ limit });\n    }\n\n    /** Scale of the plane,  */\n    @Input() set scale(scale: number) {\n        this.set({ scale });\n    }\n\n    /** Temporal accumulates shadows over time which is more performant but has a visual regression over instant results, false  */\n    @Input() set temporal(temporal: boolean) {\n        this.set({ temporal });\n    }\n\n    /** Opacity of the plane, 1 */\n    @Input() set opacity(opacity: number) {\n        this.set({ opacity });\n    }\n\n    /** Discards alpha pixels, 0.65 */\n    @Input() set alphaTest(alphaTest: number) {\n        this.set({ alphaTest });\n    }\n\n    /** Shadow color, black */\n    @Input() set color(color: string) {\n        this.set({ color });\n    }\n\n    /** Colorblend, how much colors turn to black, 0 is black, 2 */\n    @Input() set colorBlend(colorBlend: number) {\n        this.set({ colorBlend });\n    }\n\n    /** Buffer resolution, 1024 */\n    @Input() set resolution(resolution: number) {\n        this.set({ resolution });\n    }\n\n    /** Texture tonemapping */\n    @Input() set toneMapped(toneMapped: boolean) {\n        this.set({ toneMapped });\n    }\n\n    override initialize(): void {\n        super.initialize();\n        this.set({\n            frames: 40,\n            limit: Infinity,\n            blend: 20,\n            scale: 10,\n            opacity: 1,\n            alphaTest: 0.75,\n            color: 'black',\n            colorBlend: 2,\n            resolution: 1024,\n            toneMapped: true,\n        });\n    }\n}\n"]}
|