angular-three-soba 2.0.0-beta.242 → 2.0.0-beta.244
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/abstractions/lib/text.d.ts +3 -5
- package/cameras/lib/camera-content.d.ts +4 -4
- package/cameras/lib/orthographic-camera.d.ts +10 -6
- package/cameras/lib/perspective-camera.d.ts +6 -6
- package/controls/index.d.ts +1 -0
- package/controls/lib/camera-controls.d.ts +39 -0
- package/controls/lib/orbit-controls.d.ts +4 -6
- package/esm2022/abstractions/lib/text.mjs +17 -21
- package/esm2022/cameras/lib/camera-content.mjs +6 -6
- package/esm2022/cameras/lib/orthographic-camera.mjs +44 -36
- package/esm2022/cameras/lib/perspective-camera.mjs +24 -29
- package/esm2022/controls/index.mjs +2 -1
- package/esm2022/controls/lib/camera-controls.mjs +127 -0
- package/esm2022/controls/lib/orbit-controls.mjs +18 -25
- package/esm2022/loaders/lib/gltf-loader.mjs +6 -6
- package/esm2022/loaders/lib/loader.mjs +3 -3
- package/esm2022/loaders/lib/texture-loader.mjs +7 -7
- package/esm2022/materials/angular-three-soba-materials.mjs +5 -0
- package/esm2022/materials/index.mjs +2 -0
- package/esm2022/materials/lib/custom-shader-material.mjs +72 -0
- package/esm2022/misc/index.mjs +1 -2
- package/esm2022/misc/lib/bake-shadows.mjs +6 -6
- package/esm2022/misc/lib/fbo.mjs +6 -6
- package/esm2022/staging/index.mjs +3 -1
- package/esm2022/staging/lib/accumulative-shadows.mjs +11 -15
- package/esm2022/staging/lib/bb-anchor.mjs +10 -14
- package/esm2022/staging/lib/camera-shake.mjs +6 -6
- package/esm2022/staging/lib/contact-shadows.mjs +12 -14
- package/esm2022/staging/lib/environment.mjs +107 -109
- package/esm2022/staging/lib/float.mjs +12 -16
- package/esm2022/staging/lib/lightformer.mjs +107 -0
- package/esm2022/staging/lib/matcap-texture.mjs +6 -6
- package/esm2022/staging/lib/normal-texture.mjs +6 -6
- package/esm2022/staging/lib/randomized-lights.mjs +6 -6
- package/esm2022/staging/lib/render-texture.mjs +213 -0
- package/fesm2022/angular-three-soba-abstractions.mjs +16 -20
- package/fesm2022/angular-three-soba-abstractions.mjs.map +1 -1
- package/fesm2022/angular-three-soba-cameras.mjs +67 -64
- package/fesm2022/angular-three-soba-cameras.mjs.map +1 -1
- package/fesm2022/angular-three-soba-controls.mjs +142 -26
- package/fesm2022/angular-three-soba-controls.mjs.map +1 -1
- package/fesm2022/angular-three-soba-loaders.mjs +15 -15
- package/fesm2022/angular-three-soba-loaders.mjs.map +1 -1
- package/fesm2022/angular-three-soba-materials.mjs +79 -0
- package/fesm2022/angular-three-soba-materials.mjs.map +1 -0
- package/fesm2022/angular-three-soba-misc.mjs +10 -22
- package/fesm2022/angular-three-soba-misc.mjs.map +1 -1
- package/fesm2022/angular-three-soba-staging.mjs +476 -180
- package/fesm2022/angular-three-soba-staging.mjs.map +1 -1
- package/loaders/lib/gltf-loader.d.ts +4 -4
- package/loaders/lib/texture-loader.d.ts +4 -4
- package/materials/README.md +3 -0
- package/materials/index.d.ts +1 -0
- package/materials/lib/custom-shader-material.d.ts +19 -0
- package/misc/index.d.ts +0 -1
- package/package.json +110 -103
- package/staging/index.d.ts +2 -0
- package/staging/lib/accumulative-shadows.d.ts +3 -4
- package/staging/lib/bb-anchor.d.ts +3 -4
- package/staging/lib/contact-shadows.d.ts +2 -2
- package/staging/lib/environment.d.ts +24 -34
- package/staging/lib/float.d.ts +3 -4
- package/staging/lib/lightformer.d.ts +334 -0
- package/staging/lib/randomized-lights.d.ts +1 -1
- package/staging/lib/render-texture.d.ts +64 -0
- package/web-types.json +1 -1
- package/esm2022/misc/lib/content.mjs +0 -14
- package/misc/lib/content.d.ts +0 -8
|
@@ -1,4 +1,3 @@
|
|
|
1
|
-
import { TemplateRef } from '@angular/core';
|
|
2
1
|
import { NgtMesh } from 'angular-three';
|
|
3
2
|
import { ColorRepresentation } from 'three';
|
|
4
3
|
import * as i0 from "@angular/core";
|
|
@@ -37,9 +36,8 @@ export interface NgtsTextOptions extends Partial<NgtMesh> {
|
|
|
37
36
|
export declare class NgtsText {
|
|
38
37
|
text: import("@angular/core").InputSignal<string>;
|
|
39
38
|
options: import("@angular/core").InputSignalWithTransform<NgtsTextOptions, "" | Partial<NgtsTextOptions>>;
|
|
40
|
-
parameters: import("@angular/core").Signal<
|
|
39
|
+
parameters: import("@angular/core").Signal<Omit<NgtsTextOptions, "characters" | "fontSize" | "font" | "anchorX" | "anchorY" | "sdfGlyphSize">>;
|
|
41
40
|
synced: import("@angular/core").OutputEmitterRef<Text>;
|
|
42
|
-
content: import("@angular/core").Signal<TemplateRef<any> | undefined>;
|
|
43
41
|
private autoEffect;
|
|
44
42
|
private store;
|
|
45
43
|
private invalidate;
|
|
@@ -49,9 +47,9 @@ export declare class NgtsText {
|
|
|
49
47
|
anchorY: import("@angular/core").Signal<number | "top" | "top-baseline" | "middle" | "bottom-baseline" | "bottom">;
|
|
50
48
|
sdfGlyphSize: import("@angular/core").Signal<number>;
|
|
51
49
|
fontSize: import("@angular/core").Signal<number>;
|
|
52
|
-
troikaMesh: any
|
|
50
|
+
troikaMesh: import("@angular/core").Signal<any>;
|
|
53
51
|
args: import("@angular/core").Signal<any[]>;
|
|
54
52
|
constructor();
|
|
55
53
|
static ɵfac: i0.ɵɵFactoryDeclaration<NgtsText, never>;
|
|
56
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<NgtsText, "ngts-text", never, { "text": { "alias": "text"; "required": true; "isSignal": true; }; "options": { "alias": "options"; "required": false; "isSignal": true; }; }, { "synced": "synced"; }, ["
|
|
54
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<NgtsText, "ngts-text", never, { "text": { "alias": "text"; "required": true; "isSignal": true; }; "options": { "alias": "options"; "required": false; "isSignal": true; }; }, { "synced": "synced"; }, never, ["*"], true, never>;
|
|
57
55
|
}
|
|
@@ -1,10 +1,10 @@
|
|
|
1
1
|
import { Signal } from '@angular/core';
|
|
2
2
|
import { Texture } from 'three';
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
|
-
export declare class
|
|
5
|
-
static ngTemplateContextGuard(_:
|
|
4
|
+
export declare class NgtsCameraContent {
|
|
5
|
+
static ngTemplateContextGuard(_: NgtsCameraContent, ctx: unknown): ctx is {
|
|
6
6
|
$implicit: Signal<Texture>;
|
|
7
7
|
};
|
|
8
|
-
static ɵfac: i0.ɵɵFactoryDeclaration<
|
|
9
|
-
static ɵdir: i0.ɵɵDirectiveDeclaration<
|
|
8
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<NgtsCameraContent, never>;
|
|
9
|
+
static ɵdir: i0.ɵɵDirectiveDeclaration<NgtsCameraContent, "ng-template[cameraContent]", never, {}, {}, never, never, true, never>;
|
|
10
10
|
}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { TemplateRef } from '@angular/core';
|
|
1
|
+
import { ElementRef, TemplateRef } from '@angular/core';
|
|
2
2
|
import { NgtOrthographicCamera } from 'angular-three';
|
|
3
3
|
import { Group, OrthographicCamera, Texture } from 'three';
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
@@ -15,16 +15,20 @@ export interface NgtsOrthographicCameraOptions extends Partial<NgtOrthographicCa
|
|
|
15
15
|
envMap?: Texture;
|
|
16
16
|
}
|
|
17
17
|
export declare class NgtsOrthographicCamera {
|
|
18
|
-
cameraRef: import("@angular/core").InputSignal<import("angular-three").NgtInjectedRef<OrthographicCamera>>;
|
|
19
18
|
options: import("@angular/core").InputSignalWithTransform<NgtsOrthographicCameraOptions, "" | Partial<NgtsOrthographicCameraOptions>>;
|
|
20
|
-
parameters: import("@angular/core").Signal<
|
|
19
|
+
parameters: import("@angular/core").Signal<Omit<NgtsOrthographicCameraOptions, "left" | "right" | "top" | "bottom" | "makeDefault" | "manual" | "frames" | "resolution" | "envMap">>;
|
|
21
20
|
content: import("@angular/core").Signal<TemplateRef<any> | undefined>;
|
|
22
|
-
|
|
23
|
-
|
|
21
|
+
cameraContent: import("@angular/core").Signal<TemplateRef<any> | undefined>;
|
|
22
|
+
cameraRef: import("@angular/core").Signal<ElementRef<OrthographicCamera>>;
|
|
23
|
+
groupRef: import("@angular/core").Signal<ElementRef<Group<import("three").Object3DEventMap>>>;
|
|
24
24
|
private autoEffect;
|
|
25
25
|
private store;
|
|
26
26
|
private camera;
|
|
27
27
|
size: import("@angular/core").Signal<import("angular-three").NgtSize>;
|
|
28
|
+
left: import("@angular/core").Signal<number>;
|
|
29
|
+
right: import("@angular/core").Signal<number>;
|
|
30
|
+
top: import("@angular/core").Signal<number>;
|
|
31
|
+
bottom: import("@angular/core").Signal<number>;
|
|
28
32
|
private manual;
|
|
29
33
|
private makeDefault;
|
|
30
34
|
private resolution;
|
|
@@ -32,5 +36,5 @@ export declare class NgtsOrthographicCamera {
|
|
|
32
36
|
texture: import("@angular/core").Signal<Texture>;
|
|
33
37
|
constructor();
|
|
34
38
|
static ɵfac: i0.ɵɵFactoryDeclaration<NgtsOrthographicCamera, never>;
|
|
35
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<NgtsOrthographicCamera, "ngts-orthographic-camera", never, { "
|
|
39
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<NgtsOrthographicCamera, "ngts-orthographic-camera", never, { "options": { "alias": "options"; "required": false; "isSignal": true; }; }, {}, ["content", "cameraContent"], never, true, never>;
|
|
36
40
|
}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { TemplateRef } from '@angular/core';
|
|
1
|
+
import { ElementRef, TemplateRef } from '@angular/core';
|
|
2
2
|
import { NgtPerspectiveCamera } from 'angular-three';
|
|
3
3
|
import { Group, PerspectiveCamera, Texture } from 'three';
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
@@ -15,12 +15,12 @@ export interface NgtsPerspectiveCameraOptions extends Partial<NgtPerspectiveCame
|
|
|
15
15
|
envMap?: Texture;
|
|
16
16
|
}
|
|
17
17
|
export declare class NgtsPerspectiveCamera {
|
|
18
|
-
cameraRef: import("@angular/core").InputSignal<import("angular-three").NgtInjectedRef<PerspectiveCamera>>;
|
|
19
18
|
options: import("@angular/core").InputSignalWithTransform<NgtsPerspectiveCameraOptions, "" | Partial<NgtsPerspectiveCameraOptions>>;
|
|
20
|
-
parameters: import("@angular/core").Signal<
|
|
19
|
+
parameters: import("@angular/core").Signal<Omit<NgtsPerspectiveCameraOptions, "makeDefault" | "manual" | "frames" | "resolution" | "envMap">>;
|
|
21
20
|
content: import("@angular/core").Signal<TemplateRef<any> | undefined>;
|
|
22
|
-
|
|
23
|
-
|
|
21
|
+
cameraContent: import("@angular/core").Signal<TemplateRef<any> | undefined>;
|
|
22
|
+
cameraRef: import("@angular/core").Signal<ElementRef<PerspectiveCamera>>;
|
|
23
|
+
groupRef: import("@angular/core").Signal<ElementRef<Group<import("three").Object3DEventMap>>>;
|
|
24
24
|
private autoEffect;
|
|
25
25
|
private store;
|
|
26
26
|
private camera;
|
|
@@ -32,5 +32,5 @@ export declare class NgtsPerspectiveCamera {
|
|
|
32
32
|
texture: import("@angular/core").Signal<Texture>;
|
|
33
33
|
constructor();
|
|
34
34
|
static ɵfac: i0.ɵɵFactoryDeclaration<NgtsPerspectiveCamera, never>;
|
|
35
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<NgtsPerspectiveCamera, "ngts-perspective-camera", never, { "
|
|
35
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<NgtsPerspectiveCamera, "ngts-perspective-camera", never, { "options": { "alias": "options"; "required": false; "isSignal": true; }; }, {}, ["content", "cameraContent"], never, true, never>;
|
|
36
36
|
}
|
package/controls/index.d.ts
CHANGED
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
import { NgtCamera } from 'angular-three';
|
|
2
|
+
import CameraControls from 'camera-controls';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
export interface NgtsCameraControlsOptions {
|
|
5
|
+
camera?: NgtCamera;
|
|
6
|
+
domElement?: HTMLElement;
|
|
7
|
+
makeDefault: boolean;
|
|
8
|
+
events: boolean;
|
|
9
|
+
regress: boolean;
|
|
10
|
+
}
|
|
11
|
+
declare global {
|
|
12
|
+
interface HTMLElementTagNameMap {
|
|
13
|
+
/**
|
|
14
|
+
* @extends camera-controls|CameraControls
|
|
15
|
+
*/
|
|
16
|
+
'ngts-camera-controls': CameraControls & NgtsCameraControlsOptions;
|
|
17
|
+
}
|
|
18
|
+
}
|
|
19
|
+
export declare class NgtsCameraControls {
|
|
20
|
+
options: import("@angular/core").InputSignalWithTransform<Partial<CameraControls> & NgtsCameraControlsOptions, "" | Partial<Partial<CameraControls> & NgtsCameraControlsOptions>>;
|
|
21
|
+
parameters: import("@angular/core").Signal<Omit<Partial<CameraControls> & NgtsCameraControlsOptions, "camera" | "makeDefault" | "regress" | "domElement">>;
|
|
22
|
+
changed: import("@angular/core").OutputEmitterRef<any>;
|
|
23
|
+
started: import("@angular/core").OutputEmitterRef<any>;
|
|
24
|
+
ended: import("@angular/core").OutputEmitterRef<any>;
|
|
25
|
+
private store;
|
|
26
|
+
private invalidate;
|
|
27
|
+
private performanceRegress;
|
|
28
|
+
private defaultCamera;
|
|
29
|
+
private glDomElement;
|
|
30
|
+
private eventsElement;
|
|
31
|
+
private camera;
|
|
32
|
+
private regress;
|
|
33
|
+
private domElement;
|
|
34
|
+
private makeDefault;
|
|
35
|
+
controls: import("@angular/core").Signal<CameraControls>;
|
|
36
|
+
constructor();
|
|
37
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<NgtsCameraControls, never>;
|
|
38
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<NgtsCameraControls, "ngts-camera-controls", never, { "options": { "alias": "options"; "required": false; "isSignal": true; }; }, { "changed": "changed"; "started": "started"; "ended": "ended"; }, never, ["*"], true, never>;
|
|
39
|
+
}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { NgtVector3 } from 'angular-three';
|
|
2
2
|
import { Camera, Event } from 'three';
|
|
3
3
|
import { OrbitControls } from 'three-stdlib';
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
@@ -21,8 +21,7 @@ declare global {
|
|
|
21
21
|
}
|
|
22
22
|
export declare class NgtsOrbitControls {
|
|
23
23
|
options: import("@angular/core").InputSignalWithTransform<Partial<OrbitControls> & NgtsOrbitControlsOptions, "" | Partial<Partial<OrbitControls> & NgtsOrbitControlsOptions>>;
|
|
24
|
-
parameters: import("@angular/core").Signal<
|
|
25
|
-
controlsRef: import("@angular/core").InputSignal<NgtInjectedRef<OrbitControls>>;
|
|
24
|
+
parameters: import("@angular/core").Signal<Omit<Partial<OrbitControls> & NgtsOrbitControlsOptions, "camera" | "makeDefault" | "regress" | "domElement" | "enableDamping" | "keyEvents">>;
|
|
26
25
|
changed: import("@angular/core").OutputEmitterRef<Event<string, unknown>>;
|
|
27
26
|
started: import("@angular/core").OutputEmitterRef<Event<string, unknown>>;
|
|
28
27
|
ended: import("@angular/core").OutputEmitterRef<Event<string, unknown>>;
|
|
@@ -36,13 +35,12 @@ export declare class NgtsOrbitControls {
|
|
|
36
35
|
private keyEvents;
|
|
37
36
|
private domElement;
|
|
38
37
|
private makeDefault;
|
|
39
|
-
|
|
38
|
+
controls: import("@angular/core").Signal<OrbitControls>;
|
|
40
39
|
protected enableDamping: import("@angular/core").Signal<boolean>;
|
|
41
40
|
constructor();
|
|
42
|
-
private setControls;
|
|
43
41
|
private connectElement;
|
|
44
42
|
private makeControlsDefault;
|
|
45
43
|
private setEvents;
|
|
46
44
|
static ɵfac: i0.ɵɵFactoryDeclaration<NgtsOrbitControls, never>;
|
|
47
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<NgtsOrbitControls, "ngts-orbit-controls", never, { "options": { "alias": "options"; "required": false; "isSignal": true; };
|
|
45
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<NgtsOrbitControls, "ngts-orbit-controls", never, { "options": { "alias": "options"; "required": false; "isSignal": true; }; }, { "changed": "changed"; "started": "started"; "ended": "ended"; }, never, ["*"], true, never>;
|
|
48
46
|
}
|
|
@@ -1,7 +1,6 @@
|
|
|
1
1
|
import { NgTemplateOutlet } from '@angular/common';
|
|
2
|
-
import { CUSTOM_ELEMENTS_SCHEMA, ChangeDetectionStrategy, Component, DestroyRef,
|
|
3
|
-
import { NgtArgs,
|
|
4
|
-
import { NgtsContent } from 'angular-three-soba/misc';
|
|
2
|
+
import { CUSTOM_ELEMENTS_SCHEMA, ChangeDetectionStrategy, Component, DestroyRef, afterNextRender, computed, inject, input, output, } from '@angular/core';
|
|
3
|
+
import { NgtArgs, injectStore, omit, pick } from 'angular-three';
|
|
5
4
|
import { injectAutoEffect } from 'ngxtension/auto-effect';
|
|
6
5
|
import { mergeInputs } from 'ngxtension/inject-inputs';
|
|
7
6
|
// @ts-expect-error - no type def
|
|
@@ -17,11 +16,10 @@ export class NgtsText {
|
|
|
17
16
|
constructor() {
|
|
18
17
|
this.text = input.required();
|
|
19
18
|
this.options = input(defaultOptions, { transform: mergeInputs(defaultOptions) });
|
|
20
|
-
this.parameters =
|
|
19
|
+
this.parameters = omit(this.options, ['font', 'fontSize', 'sdfGlyphSize', 'anchorX', 'anchorY', 'characters']);
|
|
21
20
|
this.synced = output();
|
|
22
|
-
this.content = contentChild(NgtsContent, { read: TemplateRef });
|
|
23
21
|
this.autoEffect = injectAutoEffect();
|
|
24
|
-
this.store =
|
|
22
|
+
this.store = injectStore();
|
|
25
23
|
this.invalidate = this.store.select('invalidate');
|
|
26
24
|
this.characters = pick(this.options, 'characters');
|
|
27
25
|
this.font = pick(this.options, 'font');
|
|
@@ -29,12 +27,10 @@ export class NgtsText {
|
|
|
29
27
|
this.anchorY = pick(this.options, 'anchorY');
|
|
30
28
|
this.sdfGlyphSize = pick(this.options, 'sdfGlyphSize');
|
|
31
29
|
this.fontSize = pick(this.options, 'fontSize');
|
|
32
|
-
this.troikaMesh = new Text();
|
|
33
|
-
this.args = computed(() => [this.troikaMesh]
|
|
34
|
-
equal: (a, b) => Object.is(a[0], b[0]),
|
|
35
|
-
});
|
|
30
|
+
this.troikaMesh = computed(() => new Text(), { equal: Object.is });
|
|
31
|
+
this.args = computed(() => [this.troikaMesh()]);
|
|
36
32
|
inject(DestroyRef).onDestroy(() => {
|
|
37
|
-
this.troikaMesh.dispose();
|
|
33
|
+
this.troikaMesh().dispose();
|
|
38
34
|
});
|
|
39
35
|
// NOTE: this could be just effect but autoEffect is used for consistency
|
|
40
36
|
this.autoEffect(() => {
|
|
@@ -45,16 +41,16 @@ export class NgtsText {
|
|
|
45
41
|
});
|
|
46
42
|
afterNextRender(() => {
|
|
47
43
|
this.autoEffect(() => {
|
|
48
|
-
const [invalidate] = [this.invalidate(), this.text(), this.options()];
|
|
49
|
-
this.troikaMesh.sync(() => {
|
|
44
|
+
const [invalidate, text] = [this.invalidate(), this.text(), this.options()];
|
|
45
|
+
this.troikaMesh().sync(() => {
|
|
50
46
|
invalidate();
|
|
51
|
-
this.synced.emit(this.troikaMesh);
|
|
47
|
+
this.synced.emit(this.troikaMesh());
|
|
52
48
|
});
|
|
53
49
|
});
|
|
54
50
|
});
|
|
55
51
|
}
|
|
56
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.
|
|
57
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.
|
|
52
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.6", ngImport: i0, type: NgtsText, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
53
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.0.6", type: NgtsText, isStandalone: true, selector: "ngts-text", inputs: { text: { classPropertyName: "text", publicName: "text", isSignal: true, isRequired: true, transformFunction: null }, options: { classPropertyName: "options", publicName: "options", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { synced: "synced" }, ngImport: i0, template: `
|
|
58
54
|
<ngt-primitive
|
|
59
55
|
*args="args()"
|
|
60
56
|
[text]="text()"
|
|
@@ -65,11 +61,11 @@ export class NgtsText {
|
|
|
65
61
|
[fontSize]="fontSize()"
|
|
66
62
|
[parameters]="parameters()"
|
|
67
63
|
>
|
|
68
|
-
<ng-
|
|
64
|
+
<ng-content />
|
|
69
65
|
</ngt-primitive>
|
|
70
|
-
`, isInline: true, dependencies: [{ kind: "directive", type: NgtArgs, selector: "ng-template[args]", inputs: ["args"] }
|
|
66
|
+
`, isInline: true, dependencies: [{ kind: "directive", type: NgtArgs, selector: "ng-template[args]", inputs: ["args"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
71
67
|
}
|
|
72
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.
|
|
68
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.6", ngImport: i0, type: NgtsText, decorators: [{
|
|
73
69
|
type: Component,
|
|
74
70
|
args: [{
|
|
75
71
|
selector: 'ngts-text',
|
|
@@ -85,7 +81,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.3", ngImpor
|
|
|
85
81
|
[fontSize]="fontSize()"
|
|
86
82
|
[parameters]="parameters()"
|
|
87
83
|
>
|
|
88
|
-
<ng-
|
|
84
|
+
<ng-content />
|
|
89
85
|
</ngt-primitive>
|
|
90
86
|
`,
|
|
91
87
|
imports: [NgtArgs, NgTemplateOutlet],
|
|
@@ -93,4 +89,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.3", ngImpor
|
|
|
93
89
|
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
94
90
|
}]
|
|
95
91
|
}], ctorParameters: () => [] });
|
|
96
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
92
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"text.js","sourceRoot":"","sources":["../../../../../../libs/soba/abstractions/src/lib/text.ts"],"names":[],"mappings":"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","sourcesContent":["import { NgTemplateOutlet } from '@angular/common';\nimport {\n\tCUSTOM_ELEMENTS_SCHEMA,\n\tChangeDetectionStrategy,\n\tComponent,\n\tDestroyRef,\n\tafterNextRender,\n\tcomputed,\n\tinject,\n\tinput,\n\toutput,\n} from '@angular/core';\nimport { NgtArgs, NgtMesh, injectStore, omit, pick } from 'angular-three';\nimport { injectAutoEffect } from 'ngxtension/auto-effect';\nimport { mergeInputs } from 'ngxtension/inject-inputs';\nimport { ColorRepresentation } from 'three';\n// @ts-expect-error - no type def\nimport { Text, preloadFont } from 'troika-three-text';\n\nexport interface NgtsTextOptions extends Partial<NgtMesh> {\n\tcharacters?: string;\n\tcolor?: ColorRepresentation;\n\t/** Font size, default: 1 */\n\tfontSize: number;\n\tfontWeight?: number | string;\n\tfontStyle?: 'italic' | 'normal';\n\tmaxWidth?: number;\n\tlineHeight?: number;\n\tletterSpacing?: number;\n\ttextAlign?: 'left' | 'right' | 'center' | 'justify';\n\tfont?: string;\n\tanchorX: number | 'left' | 'center' | 'right';\n\tanchorY: number | 'top' | 'top-baseline' | 'middle' | 'bottom-baseline' | 'bottom';\n\tclipRect?: [number, number, number, number];\n\tdepthOffset?: number;\n\tdirection?: 'auto' | 'ltr' | 'rtl';\n\toverflowWrap?: 'normal' | 'break-word';\n\twhiteSpace?: 'normal' | 'overflowWrap' | 'nowrap';\n\toutlineWidth?: number | string;\n\toutlineOffsetX?: number | string;\n\toutlineOffsetY?: number | string;\n\toutlineBlur?: number | string;\n\toutlineColor?: ColorRepresentation;\n\toutlineOpacity?: number;\n\tstrokeWidth?: number | string;\n\tstrokeColor?: ColorRepresentation;\n\tstrokeOpacity?: number;\n\tfillOpacity?: number;\n\tsdfGlyphSize: number;\n\tdebugSDF?: boolean;\n}\n\nconst defaultOptions: NgtsTextOptions = {\n\tsdfGlyphSize: 64,\n\tanchorX: 'center',\n\tanchorY: 'middle',\n\tfontSize: 1,\n};\n\n@Component({\n\tselector: 'ngts-text',\n\tstandalone: true,\n\ttemplate: `\n\t\t<ngt-primitive\n\t\t\t*args=\"args()\"\n\t\t\t[text]=\"text()\"\n\t\t\t[font]=\"font()\"\n\t\t\t[anchorX]=\"anchorX()\"\n\t\t\t[anchorY]=\"anchorY()\"\n\t\t\t[sdfGlyphSize]=\"sdfGlyphSize()\"\n\t\t\t[fontSize]=\"fontSize()\"\n\t\t\t[parameters]=\"parameters()\"\n\t\t>\n\t\t\t<ng-content />\n\t\t</ngt-primitive>\n\t`,\n\timports: [NgtArgs, NgTemplateOutlet],\n\tschemas: [CUSTOM_ELEMENTS_SCHEMA],\n\tchangeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class NgtsText {\n\ttext = input.required<string>();\n\toptions = input(defaultOptions, { transform: mergeInputs(defaultOptions) });\n\tparameters = omit(this.options, ['font', 'fontSize', 'sdfGlyphSize', 'anchorX', 'anchorY', 'characters']);\n\n\tsynced = output<Text>();\n\n\tprivate autoEffect = injectAutoEffect();\n\tprivate store = injectStore();\n\tprivate invalidate = this.store.select('invalidate');\n\n\tprivate characters = pick(this.options, 'characters');\n\n\tfont = pick(this.options, 'font');\n\tanchorX = pick(this.options, 'anchorX');\n\tanchorY = pick(this.options, 'anchorY');\n\tsdfGlyphSize = pick(this.options, 'sdfGlyphSize');\n\tfontSize = pick(this.options, 'fontSize');\n\n\ttroikaMesh = computed(() => new Text(), { equal: Object.is });\n\targs = computed(() => [this.troikaMesh()]);\n\n\tconstructor() {\n\t\tinject(DestroyRef).onDestroy(() => {\n\t\t\tthis.troikaMesh().dispose();\n\t\t});\n\n\t\t// NOTE: this could be just effect but autoEffect is used for consistency\n\t\tthis.autoEffect(() => {\n\t\t\tconst [font, characters, invalidate] = [this.font(), this.characters(), this.invalidate()];\n\t\t\tif (font) {\n\t\t\t\tpreloadFont({ font, characters }, () => invalidate());\n\t\t\t}\n\t\t});\n\n\t\tafterNextRender(() => {\n\t\t\tthis.autoEffect(() => {\n\t\t\t\tconst [invalidate, text] = [this.invalidate(), this.text(), this.options()];\n\t\t\t\tthis.troikaMesh().sync(() => {\n\t\t\t\t\tinvalidate();\n\t\t\t\t\tthis.synced.emit(this.troikaMesh());\n\t\t\t\t});\n\t\t\t});\n\t\t});\n\t}\n}\n"]}
|
|
@@ -1,14 +1,14 @@
|
|
|
1
1
|
import { Directive } from '@angular/core';
|
|
2
2
|
import * as i0 from "@angular/core";
|
|
3
|
-
export class
|
|
3
|
+
export class NgtsCameraContent {
|
|
4
4
|
static ngTemplateContextGuard(_, ctx) {
|
|
5
5
|
return true;
|
|
6
6
|
}
|
|
7
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.
|
|
8
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.0.
|
|
7
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.6", ngImport: i0, type: NgtsCameraContent, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
8
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.0.6", type: NgtsCameraContent, isStandalone: true, selector: "ng-template[cameraContent]", ngImport: i0 }); }
|
|
9
9
|
}
|
|
10
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.
|
|
10
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.6", ngImport: i0, type: NgtsCameraContent, decorators: [{
|
|
11
11
|
type: Directive,
|
|
12
|
-
args: [{ standalone: true, selector: 'ng-template[
|
|
12
|
+
args: [{ standalone: true, selector: 'ng-template[cameraContent]' }]
|
|
13
13
|
}] });
|
|
14
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
14
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FtZXJhLWNvbnRlbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL3NvYmEvY2FtZXJhcy9zcmMvbGliL2NhbWVyYS1jb250ZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQVUsTUFBTSxlQUFlLENBQUM7O0FBSWxELE1BQU0sT0FBTyxpQkFBaUI7SUFDN0IsTUFBTSxDQUFDLHNCQUFzQixDQUFDLENBQW9CLEVBQUUsR0FBWTtRQUMvRCxPQUFPLElBQUksQ0FBQztJQUNiLENBQUM7OEdBSFcsaUJBQWlCO2tHQUFqQixpQkFBaUI7OzJGQUFqQixpQkFBaUI7a0JBRDdCLFNBQVM7bUJBQUMsRUFBRSxVQUFVLEVBQUUsSUFBSSxFQUFFLFFBQVEsRUFBRSw0QkFBNEIsRUFBRSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERpcmVjdGl2ZSwgU2lnbmFsIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBUZXh0dXJlIH0gZnJvbSAndGhyZWUnO1xuXG5ARGlyZWN0aXZlKHsgc3RhbmRhbG9uZTogdHJ1ZSwgc2VsZWN0b3I6ICduZy10ZW1wbGF0ZVtjYW1lcmFDb250ZW50XScgfSlcbmV4cG9ydCBjbGFzcyBOZ3RzQ2FtZXJhQ29udGVudCB7XG5cdHN0YXRpYyBuZ1RlbXBsYXRlQ29udGV4dEd1YXJkKF86IE5ndHNDYW1lcmFDb250ZW50LCBjdHg6IHVua25vd24pOiBjdHggaXMgeyAkaW1wbGljaXQ6IFNpZ25hbDxUZXh0dXJlPiB9IHtcblx0XHRyZXR1cm4gdHJ1ZTtcblx0fVxufVxuIl19
|
|
@@ -1,11 +1,11 @@
|
|
|
1
1
|
import { NgTemplateOutlet } from '@angular/common';
|
|
2
|
-
import { CUSTOM_ELEMENTS_SCHEMA, ChangeDetectionStrategy, Component, TemplateRef, afterNextRender, contentChild, input, untracked, } from '@angular/core';
|
|
3
|
-
import {
|
|
4
|
-
import {
|
|
2
|
+
import { CUSTOM_ELEMENTS_SCHEMA, ChangeDetectionStrategy, Component, TemplateRef, afterNextRender, computed, contentChild, input, untracked, viewChild, } from '@angular/core';
|
|
3
|
+
import { extend, injectBeforeRender, injectStore, omit, pick } from 'angular-three';
|
|
4
|
+
import { injectFBO } from 'angular-three-soba/misc';
|
|
5
5
|
import { injectAutoEffect } from 'ngxtension/auto-effect';
|
|
6
6
|
import { mergeInputs } from 'ngxtension/inject-inputs';
|
|
7
7
|
import { Group, OrthographicCamera } from 'three';
|
|
8
|
-
import {
|
|
8
|
+
import { NgtsCameraContent } from './camera-content';
|
|
9
9
|
import * as i0 from "@angular/core";
|
|
10
10
|
extend({ OrthographicCamera, Group });
|
|
11
11
|
const defaultOptions = {
|
|
@@ -16,16 +16,30 @@ const defaultOptions = {
|
|
|
16
16
|
};
|
|
17
17
|
export class NgtsOrthographicCamera {
|
|
18
18
|
constructor() {
|
|
19
|
-
this.cameraRef = input(injectNgtRef());
|
|
20
19
|
this.options = input(defaultOptions, { transform: mergeInputs(defaultOptions) });
|
|
21
|
-
this.parameters =
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
20
|
+
this.parameters = omit(this.options, [
|
|
21
|
+
'envMap',
|
|
22
|
+
'makeDefault',
|
|
23
|
+
'manual',
|
|
24
|
+
'frames',
|
|
25
|
+
'resolution',
|
|
26
|
+
'left',
|
|
27
|
+
'top',
|
|
28
|
+
'bottom',
|
|
29
|
+
'right',
|
|
30
|
+
]);
|
|
31
|
+
this.content = contentChild(TemplateRef);
|
|
32
|
+
this.cameraContent = contentChild(NgtsCameraContent, { read: TemplateRef });
|
|
33
|
+
this.cameraRef = viewChild.required('camera');
|
|
34
|
+
this.groupRef = viewChild.required('group');
|
|
25
35
|
this.autoEffect = injectAutoEffect();
|
|
26
|
-
this.store =
|
|
36
|
+
this.store = injectStore();
|
|
27
37
|
this.camera = this.store.select('camera');
|
|
28
38
|
this.size = this.store.select('size');
|
|
39
|
+
this.left = computed(() => this.options().left ?? this.size().width / -2);
|
|
40
|
+
this.right = computed(() => this.options().right ?? this.size().width / 2);
|
|
41
|
+
this.top = computed(() => this.options().top ?? this.size().height / 2);
|
|
42
|
+
this.bottom = computed(() => this.options().bottom ?? this.size().height / -2);
|
|
29
43
|
this.manual = pick(this.options, 'manual');
|
|
30
44
|
this.makeDefault = pick(this.options, 'makeDefault');
|
|
31
45
|
this.resolution = pick(this.options, 'resolution');
|
|
@@ -52,11 +66,11 @@ export class NgtsOrthographicCamera {
|
|
|
52
66
|
injectBeforeRender(({ gl, scene }) => {
|
|
53
67
|
const [{ frames, envMap }, group, camera, fbo] = [
|
|
54
68
|
this.options(),
|
|
55
|
-
this.groupRef.nativeElement,
|
|
69
|
+
this.groupRef().nativeElement,
|
|
56
70
|
this.cameraRef().nativeElement,
|
|
57
71
|
this.fbo(),
|
|
58
72
|
];
|
|
59
|
-
if (this.
|
|
73
|
+
if (this.cameraContent() && group && camera && fbo && (frames === Infinity || count < frames)) {
|
|
60
74
|
group.visible = false;
|
|
61
75
|
gl.setRenderTarget(fbo);
|
|
62
76
|
oldEnvMap = scene.background;
|
|
@@ -70,49 +84,43 @@ export class NgtsOrthographicCamera {
|
|
|
70
84
|
}
|
|
71
85
|
});
|
|
72
86
|
}
|
|
73
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.
|
|
74
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.2.0", version: "18.0.
|
|
87
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.6", ngImport: i0, type: NgtsOrthographicCamera, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
88
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.2.0", version: "18.0.6", type: NgtsOrthographicCamera, isStandalone: true, selector: "ngts-orthographic-camera", inputs: { options: { classPropertyName: "options", publicName: "options", isSignal: true, isRequired: false, transformFunction: null } }, queries: [{ propertyName: "content", first: true, predicate: TemplateRef, descendants: true, isSignal: true }, { propertyName: "cameraContent", first: true, predicate: NgtsCameraContent, descendants: true, read: TemplateRef, isSignal: true }], viewQueries: [{ propertyName: "cameraRef", first: true, predicate: ["camera"], descendants: true, isSignal: true }, { propertyName: "groupRef", first: true, predicate: ["group"], descendants: true, isSignal: true }], ngImport: i0, template: `
|
|
75
89
|
<ngt-orthographic-camera
|
|
76
|
-
|
|
77
|
-
[left]="
|
|
78
|
-
[right]="
|
|
79
|
-
[top]="
|
|
80
|
-
[bottom]="
|
|
90
|
+
#camera
|
|
91
|
+
[left]="left()"
|
|
92
|
+
[right]="right()"
|
|
93
|
+
[top]="top()"
|
|
94
|
+
[bottom]="bottom()"
|
|
81
95
|
[parameters]="parameters()"
|
|
82
96
|
>
|
|
83
97
|
<ng-container [ngTemplateOutlet]="content() ?? null" />
|
|
84
98
|
</ngt-orthographic-camera>
|
|
85
99
|
|
|
86
|
-
<ngt-group
|
|
87
|
-
<ng-container
|
|
88
|
-
[ngTemplateOutlet]="withTextureContent() ?? null"
|
|
89
|
-
[ngTemplateOutletContext]="{ $implicit: texture }"
|
|
90
|
-
/>
|
|
100
|
+
<ngt-group #group>
|
|
101
|
+
<ng-container [ngTemplateOutlet]="cameraContent() ?? null" [ngTemplateOutletContext]="{ $implicit: texture }" />
|
|
91
102
|
</ngt-group>
|
|
92
103
|
`, isInline: true, dependencies: [{ kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
93
104
|
}
|
|
94
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.
|
|
105
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.6", ngImport: i0, type: NgtsOrthographicCamera, decorators: [{
|
|
95
106
|
type: Component,
|
|
96
107
|
args: [{
|
|
97
108
|
selector: 'ngts-orthographic-camera',
|
|
98
109
|
standalone: true,
|
|
99
110
|
template: `
|
|
100
111
|
<ngt-orthographic-camera
|
|
101
|
-
|
|
102
|
-
[left]="
|
|
103
|
-
[right]="
|
|
104
|
-
[top]="
|
|
105
|
-
[bottom]="
|
|
112
|
+
#camera
|
|
113
|
+
[left]="left()"
|
|
114
|
+
[right]="right()"
|
|
115
|
+
[top]="top()"
|
|
116
|
+
[bottom]="bottom()"
|
|
106
117
|
[parameters]="parameters()"
|
|
107
118
|
>
|
|
108
119
|
<ng-container [ngTemplateOutlet]="content() ?? null" />
|
|
109
120
|
</ngt-orthographic-camera>
|
|
110
121
|
|
|
111
|
-
<ngt-group
|
|
112
|
-
<ng-container
|
|
113
|
-
[ngTemplateOutlet]="withTextureContent() ?? null"
|
|
114
|
-
[ngTemplateOutletContext]="{ $implicit: texture }"
|
|
115
|
-
/>
|
|
122
|
+
<ngt-group #group>
|
|
123
|
+
<ng-container [ngTemplateOutlet]="cameraContent() ?? null" [ngTemplateOutletContext]="{ $implicit: texture }" />
|
|
116
124
|
</ngt-group>
|
|
117
125
|
`,
|
|
118
126
|
imports: [NgTemplateOutlet],
|
|
@@ -120,4 +128,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.3", ngImpor
|
|
|
120
128
|
schemas: [CUSTOM_ELEMENTS_SCHEMA],
|
|
121
129
|
}]
|
|
122
130
|
}], ctorParameters: () => [] });
|
|
123
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"orthographic-camera.js","sourceRoot":"","sources":["../../../../../../libs/soba/cameras/src/lib/orthographic-camera.ts"],"names":[],"mappings":"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","sourcesContent":["import { NgTemplateOutlet } from '@angular/common';\nimport {\n\tCUSTOM_ELEMENTS_SCHEMA,\n\tChangeDetectionStrategy,\n\tComponent,\n\tTemplateRef,\n\tafterNextRender,\n\tcontentChild,\n\tinput,\n\tuntracked,\n} from '@angular/core';\nimport {\n\tNgtOrthographicCamera,\n\texclude,\n\textend,\n\tinjectBeforeRender,\n\tinjectNgtRef,\n\tinjectNgtStore,\n\tpick,\n} from 'angular-three';\nimport { NgtsContent, injectFBO } from 'angular-three-soba/misc';\nimport { injectAutoEffect } from 'ngxtension/auto-effect';\nimport { mergeInputs } from 'ngxtension/inject-inputs';\nimport { Color, Group, OrthographicCamera, Texture } from 'three';\nimport { NgtsCameraContentWithFboTexture } from './camera-content';\n\nextend({ OrthographicCamera, Group });\n\nexport interface NgtsOrthographicCameraOptions extends Partial<NgtOrthographicCamera> {\n\t/** Registers the camera as the system default, fiber will start rendering with it */\n\tmakeDefault?: boolean;\n\t/** Making it manual will stop responsiveness and you have to calculate aspect ratio yourself. */\n\tmanual?: boolean;\n\t/** Number of frames to render, Infinity */\n\tframes: number;\n\t/** Resolution of the FBO, 256 */\n\tresolution: number;\n\t/** Optional environment map for functional use */\n\tenvMap?: Texture;\n}\n\nconst defaultOptions: NgtsOrthographicCameraOptions = {\n\tframes: Infinity,\n\tresolution: 256,\n\tmakeDefault: false,\n\tmanual: false,\n};\n\n@Component({\n\tselector: 'ngts-orthographic-camera',\n\tstandalone: true,\n\ttemplate: `\n\t\t<ngt-orthographic-camera\n\t\t\t[ref]=\"cameraRef()\"\n\t\t\t[left]=\"size().width / -2\"\n\t\t\t[right]=\"size().width / 2\"\n\t\t\t[top]=\"size().height / 2\"\n\t\t\t[bottom]=\"size().height / -2\"\n\t\t\t[parameters]=\"parameters()\"\n\t\t>\n\t\t\t<ng-container [ngTemplateOutlet]=\"content() ?? null\" />\n\t\t</ngt-orthographic-camera>\n\n\t\t<ngt-group [ref]=\"groupRef\">\n\t\t\t<ng-container\n\t\t\t\t[ngTemplateOutlet]=\"withTextureContent() ?? null\"\n\t\t\t\t[ngTemplateOutletContext]=\"{ $implicit: texture }\"\n\t\t\t/>\n\t\t</ngt-group>\n\t`,\n\timports: [NgTemplateOutlet],\n\tchangeDetection: ChangeDetectionStrategy.OnPush,\n\tschemas: [CUSTOM_ELEMENTS_SCHEMA],\n})\nexport class NgtsOrthographicCamera {\n\tcameraRef = input(injectNgtRef<OrthographicCamera>());\n\toptions = input(defaultOptions, { transform: mergeInputs(defaultOptions) });\n\tparameters = exclude(this.options, ['envMap', 'makeDefault', 'manual', 'frames', 'resolution']);\n\n\tcontent = contentChild(NgtsContent, { read: TemplateRef });\n\twithTextureContent = contentChild(NgtsCameraContentWithFboTexture, { read: TemplateRef });\n\n\tgroupRef = injectNgtRef<Group>();\n\n\tprivate autoEffect = injectAutoEffect();\n\tprivate store = injectNgtStore();\n\n\tprivate camera = this.store.select('camera');\n\tsize = this.store.select('size');\n\n\tprivate manual = pick(this.options, 'manual');\n\tprivate makeDefault = pick(this.options, 'makeDefault');\n\tprivate resolution = pick(this.options, 'resolution');\n\tprivate fbo = injectFBO(() => ({ width: this.resolution() }));\n\ttexture = pick(this.fbo, 'texture');\n\n\tconstructor() {\n\t\tafterNextRender(() => {\n\t\t\tthis.autoEffect(() => {\n\t\t\t\tif (!this.manual()) {\n\t\t\t\t\tthis.cameraRef().nativeElement.updateProjectionMatrix();\n\t\t\t\t}\n\t\t\t});\n\n\t\t\tthis.autoEffect(() => {\n\t\t\t\tif (this.makeDefault()) {\n\t\t\t\t\tconst oldCam = untracked(this.camera);\n\t\t\t\t\tthis.store.update({ camera: this.cameraRef().nativeElement });\n\t\t\t\t\treturn () => this.store.update(() => ({ camera: oldCam }));\n\t\t\t\t}\n\t\t\t\treturn;\n\t\t\t});\n\n\t\t\tthis.cameraRef().nativeElement.updateProjectionMatrix();\n\t\t});\n\n\t\tlet count = 0;\n\t\tlet oldEnvMap: Color | Texture | null = null;\n\t\tinjectBeforeRender(({ gl, scene }) => {\n\t\t\tconst [{ frames, envMap }, group, camera, fbo] = [\n\t\t\t\tthis.options(),\n\t\t\t\tthis.groupRef.nativeElement,\n\t\t\t\tthis.cameraRef().nativeElement,\n\t\t\t\tthis.fbo(),\n\t\t\t];\n\t\t\tif (this.withTextureContent() && group && camera && fbo && (frames === Infinity || count < frames)) {\n\t\t\t\tgroup.visible = false;\n\t\t\t\tgl.setRenderTarget(fbo);\n\t\t\t\toldEnvMap = scene.background;\n\t\t\t\tif (envMap) scene.background = envMap;\n\t\t\t\tgl.render(scene, camera);\n\t\t\t\tscene.background = oldEnvMap;\n\t\t\t\tgl.setRenderTarget(null);\n\t\t\t\tgroup.visible = true;\n\t\t\t\tcount++;\n\t\t\t}\n\t\t});\n\t}\n}\n"]}
|
|
131
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"orthographic-camera.js","sourceRoot":"","sources":["../../../../../../libs/soba/cameras/src/lib/orthographic-camera.ts"],"names":[],"mappings":"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","sourcesContent":["import { NgTemplateOutlet } from '@angular/common';\nimport {\n\tCUSTOM_ELEMENTS_SCHEMA,\n\tChangeDetectionStrategy,\n\tComponent,\n\tElementRef,\n\tTemplateRef,\n\tafterNextRender,\n\tcomputed,\n\tcontentChild,\n\tinput,\n\tuntracked,\n\tviewChild,\n} from '@angular/core';\nimport { NgtOrthographicCamera, extend, injectBeforeRender, injectStore, omit, pick } from 'angular-three';\nimport { injectFBO } from 'angular-three-soba/misc';\nimport { injectAutoEffect } from 'ngxtension/auto-effect';\nimport { mergeInputs } from 'ngxtension/inject-inputs';\nimport { Color, Group, OrthographicCamera, Texture } from 'three';\nimport { NgtsCameraContent } from './camera-content';\n\nextend({ OrthographicCamera, Group });\n\nexport interface NgtsOrthographicCameraOptions extends Partial<NgtOrthographicCamera> {\n\t/** Registers the camera as the system default, fiber will start rendering with it */\n\tmakeDefault?: boolean;\n\t/** Making it manual will stop responsiveness and you have to calculate aspect ratio yourself. */\n\tmanual?: boolean;\n\t/** Number of frames to render, Infinity */\n\tframes: number;\n\t/** Resolution of the FBO, 256 */\n\tresolution: number;\n\t/** Optional environment map for functional use */\n\tenvMap?: Texture;\n}\n\nconst defaultOptions: NgtsOrthographicCameraOptions = {\n\tframes: Infinity,\n\tresolution: 256,\n\tmakeDefault: false,\n\tmanual: false,\n};\n\n@Component({\n\tselector: 'ngts-orthographic-camera',\n\tstandalone: true,\n\ttemplate: `\n\t\t<ngt-orthographic-camera\n\t\t\t#camera\n\t\t\t[left]=\"left()\"\n\t\t\t[right]=\"right()\"\n\t\t\t[top]=\"top()\"\n\t\t\t[bottom]=\"bottom()\"\n\t\t\t[parameters]=\"parameters()\"\n\t\t>\n\t\t\t<ng-container [ngTemplateOutlet]=\"content() ?? null\" />\n\t\t</ngt-orthographic-camera>\n\n\t\t<ngt-group #group>\n\t\t\t<ng-container [ngTemplateOutlet]=\"cameraContent() ?? null\" [ngTemplateOutletContext]=\"{ $implicit: texture }\" />\n\t\t</ngt-group>\n\t`,\n\timports: [NgTemplateOutlet],\n\tchangeDetection: ChangeDetectionStrategy.OnPush,\n\tschemas: [CUSTOM_ELEMENTS_SCHEMA],\n})\nexport class NgtsOrthographicCamera {\n\toptions = input(defaultOptions, { transform: mergeInputs(defaultOptions) });\n\tparameters = omit(this.options, [\n\t\t'envMap',\n\t\t'makeDefault',\n\t\t'manual',\n\t\t'frames',\n\t\t'resolution',\n\t\t'left',\n\t\t'top',\n\t\t'bottom',\n\t\t'right',\n\t]);\n\n\tcontent = contentChild(TemplateRef);\n\tcameraContent = contentChild(NgtsCameraContent, { read: TemplateRef });\n\n\tcameraRef = viewChild.required<ElementRef<OrthographicCamera>>('camera');\n\tgroupRef = viewChild.required<ElementRef<Group>>('group');\n\n\tprivate autoEffect = injectAutoEffect();\n\tprivate store = injectStore();\n\n\tprivate camera = this.store.select('camera');\n\tsize = this.store.select('size');\n\n\tleft = computed(() => this.options().left ?? this.size().width / -2);\n\tright = computed(() => this.options().right ?? this.size().width / 2);\n\ttop = computed(() => this.options().top ?? this.size().height / 2);\n\tbottom = computed(() => this.options().bottom ?? this.size().height / -2);\n\n\tprivate manual = pick(this.options, 'manual');\n\tprivate makeDefault = pick(this.options, 'makeDefault');\n\tprivate resolution = pick(this.options, 'resolution');\n\tprivate fbo = injectFBO(() => ({ width: this.resolution() }));\n\ttexture = pick(this.fbo, 'texture');\n\n\tconstructor() {\n\t\tafterNextRender(() => {\n\t\t\tthis.autoEffect(() => {\n\t\t\t\tif (!this.manual()) {\n\t\t\t\t\tthis.cameraRef().nativeElement.updateProjectionMatrix();\n\t\t\t\t}\n\t\t\t});\n\n\t\t\tthis.autoEffect(() => {\n\t\t\t\tif (this.makeDefault()) {\n\t\t\t\t\tconst oldCam = untracked(this.camera);\n\t\t\t\t\tthis.store.update({ camera: this.cameraRef().nativeElement });\n\t\t\t\t\treturn () => this.store.update(() => ({ camera: oldCam }));\n\t\t\t\t}\n\t\t\t\treturn;\n\t\t\t});\n\n\t\t\tthis.cameraRef().nativeElement.updateProjectionMatrix();\n\t\t});\n\n\t\tlet count = 0;\n\t\tlet oldEnvMap: Color | Texture | null = null;\n\t\tinjectBeforeRender(({ gl, scene }) => {\n\t\t\tconst [{ frames, envMap }, group, camera, fbo] = [\n\t\t\t\tthis.options(),\n\t\t\t\tthis.groupRef().nativeElement,\n\t\t\t\tthis.cameraRef().nativeElement,\n\t\t\t\tthis.fbo(),\n\t\t\t];\n\t\t\tif (this.cameraContent() && group && camera && fbo && (frames === Infinity || count < frames)) {\n\t\t\t\tgroup.visible = false;\n\t\t\t\tgl.setRenderTarget(fbo);\n\t\t\t\toldEnvMap = scene.background;\n\t\t\t\tif (envMap) scene.background = envMap;\n\t\t\t\tgl.render(scene, camera);\n\t\t\t\tscene.background = oldEnvMap;\n\t\t\t\tgl.setRenderTarget(null);\n\t\t\t\tgroup.visible = true;\n\t\t\t\tcount++;\n\t\t\t}\n\t\t});\n\t}\n}\n"]}
|