angular-three 2.14.0 → 3.0.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/fesm2022/angular-three-nativescript.mjs +3 -3
- package/fesm2022/angular-three-nativescript.mjs.map +1 -1
- package/fesm2022/angular-three-testing.mjs +12 -14
- package/fesm2022/angular-three-testing.mjs.map +1 -1
- package/fesm2022/angular-three.mjs +116 -100
- package/fesm2022/angular-three.mjs.map +1 -1
- package/lib/canvas.d.ts +31 -31
- package/lib/html.d.ts +3 -3
- package/lib/portal.d.ts +2 -2
- package/lib/routed-scene.d.ts +8 -2
- package/lib/utils/object-events.d.ts +0 -19
- package/nativescript/lib/canvas.d.ts +3 -3
- package/package.json +3 -9
- package/plugin/src/generators/init/schema.json +8 -8
- package/esm2022/angular-three.mjs +0 -5
- package/esm2022/index.mjs +0 -25
- package/esm2022/lib/canvas.mjs +0 -188
- package/esm2022/lib/directives/args.mjs +0 -53
- package/esm2022/lib/directives/selection.mjs +0 -69
- package/esm2022/lib/dom/events.mjs +0 -73
- package/esm2022/lib/events.mjs +0 -361
- package/esm2022/lib/html.mjs +0 -44
- package/esm2022/lib/instance.mjs +0 -83
- package/esm2022/lib/loader.mjs +0 -93
- package/esm2022/lib/loop.mjs +0 -141
- package/esm2022/lib/pipes/hexify.mjs +0 -86
- package/esm2022/lib/portal.mjs +0 -220
- package/esm2022/lib/renderer/catalogue.mjs +0 -7
- package/esm2022/lib/renderer/constants.mjs +0 -23
- package/esm2022/lib/renderer/index.mjs +0 -544
- package/esm2022/lib/renderer/state.mjs +0 -54
- package/esm2022/lib/renderer/utils.mjs +0 -223
- package/esm2022/lib/roots.mjs +0 -274
- package/esm2022/lib/routed-scene.mjs +0 -33
- package/esm2022/lib/store.mjs +0 -179
- package/esm2022/lib/three-types.mjs +0 -2
- package/esm2022/lib/types.mjs +0 -2
- package/esm2022/lib/utils/apply-props.mjs +0 -130
- package/esm2022/lib/utils/attach.mjs +0 -46
- package/esm2022/lib/utils/before-render.mjs +0 -41
- package/esm2022/lib/utils/is.mjs +0 -52
- package/esm2022/lib/utils/make.mjs +0 -52
- package/esm2022/lib/utils/object-events.mjs +0 -137
- package/esm2022/lib/utils/output-ref.mjs +0 -9
- package/esm2022/lib/utils/parameters.mjs +0 -70
- package/esm2022/lib/utils/resolve-ref.mjs +0 -8
- package/esm2022/lib/utils/signal-store.mjs +0 -90
- package/esm2022/lib/utils/update.mjs +0 -37
- package/esm2022/nativescript/angular-three-nativescript.mjs +0 -5
- package/esm2022/nativescript/index.mjs +0 -2
- package/esm2022/nativescript/lib/canvas.mjs +0 -127
- package/esm2022/testing/angular-three-testing.mjs +0 -5
- package/esm2022/testing/index.mjs +0 -3
- package/esm2022/testing/lib/test-bed.mjs +0 -130
- package/esm2022/testing/lib/test-canvas.mjs +0 -45
- package/esm2022/testing/lib/utils/mock-canvas.mjs +0 -37
- package/esm2022/testing/lib/utils/web-gl-rendering-context.mjs +0 -752
package/lib/canvas.d.ts
CHANGED
|
@@ -24,12 +24,15 @@ export declare class NgtCanvas {
|
|
|
24
24
|
dpr: import("@angular/core").InputSignal<NgtDpr>;
|
|
25
25
|
raycaster: import("@angular/core").InputSignal<Partial<Raycaster> | undefined>;
|
|
26
26
|
scene: import("@angular/core").InputSignal<Scene | Partial<Scene> | undefined>;
|
|
27
|
-
camera: import("@angular/core").InputSignal<NonNullable<((import("
|
|
27
|
+
camera: import("@angular/core").InputSignal<NonNullable<((import("angular-three").NgtCamera | Partial<{
|
|
28
|
+
parent?: import("three").Object3D<import("three").Object3DEventMap> | null | undefined;
|
|
29
|
+
add?: ((...object: import("three").Object3D[]) => import("three").Camera) | undefined;
|
|
30
|
+
remove?: ((...object: import("three").Object3D[]) => import("three").Camera) | undefined;
|
|
31
|
+
attach: string | string[] | import("angular-three").NgtAttachFunction;
|
|
28
32
|
readonly type?: string | undefined;
|
|
29
33
|
viewport?: import("three").Vector4 | undefined;
|
|
30
34
|
addEventListener: (<TEventKey extends keyof import("angular-three").NgtNodeEventMap<import("three").Camera>>(type: TEventKey, listener: (this: import("angular-three").NgtNodeElement<import("three").Camera, typeof import("three").Camera>, ev: import("angular-three").NgtNodeEventMap<import("three").Camera>[TEventKey]) => any) => void) & (<TEventKey extends keyof import("angular-three").NgtAllObject3DEventsMap>(type: TEventKey, listener: (this: any, ev: import("angular-three").NgtAllObject3DEventsMap[TEventKey]) => any) => void);
|
|
31
35
|
removeEventListener: (<TEventKey extends keyof import("angular-three").NgtNodeEventMap<import("three").Camera>>(type: TEventKey, listener: (this: import("angular-three").NgtNodeElement<import("three").Camera, typeof import("three").Camera>, ev: import("angular-three").NgtNodeEventMap<import("three").Camera>[TEventKey]) => any) => void) & (<TEventKey extends keyof import("angular-three").NgtAllObject3DEventsMap>(type: TEventKey, listener: (this: any, ev: import("angular-three").NgtAllObject3DEventsMap[TEventKey]) => any) => void);
|
|
32
|
-
attach: string | string[] | import("./types").NgtAttachFunction;
|
|
33
36
|
__ngt_args__: [];
|
|
34
37
|
readonly isCamera?: true | undefined;
|
|
35
38
|
matrixWorldInverse?: import("three").Matrix4 | undefined;
|
|
@@ -41,7 +44,6 @@ export declare class NgtCanvas {
|
|
|
41
44
|
readonly id?: number | undefined;
|
|
42
45
|
uuid?: string | undefined;
|
|
43
46
|
name?: string | undefined;
|
|
44
|
-
parent?: import("three").Object3D<import("three").Object3DEventMap> | null | undefined;
|
|
45
47
|
children?: import("three").Object3D<import("three").Object3DEventMap>[] | undefined;
|
|
46
48
|
readonly modelViewMatrix?: import("three").Matrix4 | undefined;
|
|
47
49
|
readonly normalMatrix?: import("three").Matrix3 | undefined;
|
|
@@ -83,8 +85,6 @@ export declare class NgtCanvas {
|
|
|
83
85
|
(vector: Vector3): void;
|
|
84
86
|
(x: number, y: number, z: number): void;
|
|
85
87
|
} | undefined;
|
|
86
|
-
add?: ((...object: import("three").Object3D[]) => import("three").Camera) | undefined;
|
|
87
|
-
remove?: ((...object: import("three").Object3D[]) => import("three").Camera) | undefined;
|
|
88
88
|
removeFromParent?: (() => import("three").Camera) | undefined;
|
|
89
89
|
clear?: (() => import("three").Camera) | undefined;
|
|
90
90
|
getObjectById?: ((id: number) => import("three").Object3D | undefined) | undefined;
|
|
@@ -115,20 +115,14 @@ export declare class NgtCanvas {
|
|
|
115
115
|
dispose: (() => void) | null;
|
|
116
116
|
raycast: import("three").Object3D["raycast"] | null;
|
|
117
117
|
} & {
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
offsetX: number;
|
|
123
|
-
offsetY: number;
|
|
124
|
-
width: number;
|
|
125
|
-
height: number;
|
|
126
|
-
} | null | undefined;
|
|
118
|
+
parent?: import("three").Object3D<import("three").Object3DEventMap> | null | undefined;
|
|
119
|
+
add?: ((...object: import("three").Object3D[]) => import("three").PerspectiveCamera) | undefined;
|
|
120
|
+
remove?: ((...object: import("three").Object3D[]) => import("three").PerspectiveCamera) | undefined;
|
|
121
|
+
attach: string | string[] | import("angular-three").NgtAttachFunction;
|
|
127
122
|
readonly type?: string | undefined;
|
|
128
123
|
viewport?: import("three").Vector4 | undefined;
|
|
129
124
|
addEventListener: (<TEventKey extends keyof import("angular-three").NgtNodeEventMap<import("three").PerspectiveCamera>>(type: TEventKey, listener: (this: import("angular-three").NgtNodeElement<import("three").PerspectiveCamera, typeof import("three").PerspectiveCamera>, ev: import("angular-three").NgtNodeEventMap<import("three").PerspectiveCamera>[TEventKey]) => any) => void) & (<TEventKey extends keyof import("angular-three").NgtAllObject3DEventsMap>(type: TEventKey, listener: (this: any, ev: import("angular-three").NgtAllObject3DEventsMap[TEventKey]) => any) => void);
|
|
130
125
|
removeEventListener: (<TEventKey extends keyof import("angular-three").NgtNodeEventMap<import("three").PerspectiveCamera>>(type: TEventKey, listener: (this: import("angular-three").NgtNodeElement<import("three").PerspectiveCamera, typeof import("three").PerspectiveCamera>, ev: import("angular-three").NgtNodeEventMap<import("three").PerspectiveCamera>[TEventKey]) => any) => void) & (<TEventKey extends keyof import("angular-three").NgtAllObject3DEventsMap>(type: TEventKey, listener: (this: any, ev: import("angular-three").NgtAllObject3DEventsMap[TEventKey]) => any) => void);
|
|
131
|
-
attach: string | string[] | import("./types").NgtAttachFunction;
|
|
132
126
|
__ngt_args__: [fov?: number | undefined, aspect?: number | undefined, near?: number | undefined, far?: number | undefined];
|
|
133
127
|
readonly isCamera?: true | undefined;
|
|
134
128
|
matrixWorldInverse?: import("three").Matrix4 | undefined;
|
|
@@ -140,7 +134,6 @@ export declare class NgtCanvas {
|
|
|
140
134
|
readonly id?: number | undefined;
|
|
141
135
|
uuid?: string | undefined;
|
|
142
136
|
name?: string | undefined;
|
|
143
|
-
parent?: import("three").Object3D<import("three").Object3DEventMap> | null | undefined;
|
|
144
137
|
children?: import("three").Object3D<import("three").Object3DEventMap>[] | undefined;
|
|
145
138
|
readonly modelViewMatrix?: import("three").Matrix4 | undefined;
|
|
146
139
|
readonly normalMatrix?: import("three").Matrix3 | undefined;
|
|
@@ -182,8 +175,6 @@ export declare class NgtCanvas {
|
|
|
182
175
|
(vector: Vector3): void;
|
|
183
176
|
(x: number, y: number, z: number): void;
|
|
184
177
|
} | undefined;
|
|
185
|
-
add?: ((...object: import("three").Object3D[]) => import("three").PerspectiveCamera) | undefined;
|
|
186
|
-
remove?: ((...object: import("three").Object3D[]) => import("three").PerspectiveCamera) | undefined;
|
|
187
178
|
removeFromParent?: (() => import("three").PerspectiveCamera) | undefined;
|
|
188
179
|
clear?: (() => import("three").PerspectiveCamera) | undefined;
|
|
189
180
|
getObjectById?: ((id: number) => import("three").Object3D | undefined) | undefined;
|
|
@@ -211,6 +202,15 @@ export declare class NgtCanvas {
|
|
|
211
202
|
near?: number | undefined;
|
|
212
203
|
far?: number | undefined;
|
|
213
204
|
focus?: number | undefined;
|
|
205
|
+
view?: {
|
|
206
|
+
enabled: boolean;
|
|
207
|
+
fullWidth: number;
|
|
208
|
+
fullHeight: number;
|
|
209
|
+
offsetX: number;
|
|
210
|
+
offsetY: number;
|
|
211
|
+
width: number;
|
|
212
|
+
height: number;
|
|
213
|
+
} | null | undefined;
|
|
214
214
|
filmGauge?: number | undefined;
|
|
215
215
|
filmOffset?: number | undefined;
|
|
216
216
|
getFocalLength?: (() => number) | undefined;
|
|
@@ -234,20 +234,14 @@ export declare class NgtCanvas {
|
|
|
234
234
|
dispose: (() => void) | null;
|
|
235
235
|
raycast: import("three").Object3D["raycast"] | null;
|
|
236
236
|
} & {
|
|
237
|
-
|
|
238
|
-
|
|
239
|
-
|
|
240
|
-
|
|
241
|
-
offsetX: number;
|
|
242
|
-
offsetY: number;
|
|
243
|
-
width: number;
|
|
244
|
-
height: number;
|
|
245
|
-
} | null | undefined;
|
|
237
|
+
parent?: import("three").Object3D<import("three").Object3DEventMap> | null | undefined;
|
|
238
|
+
add?: ((...object: import("three").Object3D[]) => import("three").OrthographicCamera) | undefined;
|
|
239
|
+
remove?: ((...object: import("three").Object3D[]) => import("three").OrthographicCamera) | undefined;
|
|
240
|
+
attach: string | string[] | import("angular-three").NgtAttachFunction;
|
|
246
241
|
readonly type?: string | undefined;
|
|
247
242
|
viewport?: import("three").Vector4 | undefined;
|
|
248
243
|
addEventListener: (<TEventKey extends keyof import("angular-three").NgtNodeEventMap<import("three").OrthographicCamera>>(type: TEventKey, listener: (this: import("angular-three").NgtNodeElement<import("three").OrthographicCamera, typeof import("three").OrthographicCamera>, ev: import("angular-three").NgtNodeEventMap<import("three").OrthographicCamera>[TEventKey]) => any) => void) & (<TEventKey extends keyof import("angular-three").NgtAllObject3DEventsMap>(type: TEventKey, listener: (this: any, ev: import("angular-three").NgtAllObject3DEventsMap[TEventKey]) => any) => void);
|
|
249
244
|
removeEventListener: (<TEventKey extends keyof import("angular-three").NgtNodeEventMap<import("three").OrthographicCamera>>(type: TEventKey, listener: (this: import("angular-three").NgtNodeElement<import("three").OrthographicCamera, typeof import("three").OrthographicCamera>, ev: import("angular-three").NgtNodeEventMap<import("three").OrthographicCamera>[TEventKey]) => any) => void) & (<TEventKey extends keyof import("angular-three").NgtAllObject3DEventsMap>(type: TEventKey, listener: (this: any, ev: import("angular-three").NgtAllObject3DEventsMap[TEventKey]) => any) => void);
|
|
250
|
-
attach: string | string[] | import("./types").NgtAttachFunction;
|
|
251
245
|
__ngt_args__: [left?: number | undefined, right?: number | undefined, top?: number | undefined, bottom?: number | undefined, near?: number | undefined, far?: number | undefined];
|
|
252
246
|
readonly isCamera?: true | undefined;
|
|
253
247
|
matrixWorldInverse?: import("three").Matrix4 | undefined;
|
|
@@ -259,7 +253,6 @@ export declare class NgtCanvas {
|
|
|
259
253
|
readonly id?: number | undefined;
|
|
260
254
|
uuid?: string | undefined;
|
|
261
255
|
name?: string | undefined;
|
|
262
|
-
parent?: import("three").Object3D<import("three").Object3DEventMap> | null | undefined;
|
|
263
256
|
children?: import("three").Object3D<import("three").Object3DEventMap>[] | undefined;
|
|
264
257
|
readonly modelViewMatrix?: import("three").Matrix4 | undefined;
|
|
265
258
|
readonly normalMatrix?: import("three").Matrix3 | undefined;
|
|
@@ -301,8 +294,6 @@ export declare class NgtCanvas {
|
|
|
301
294
|
(vector: Vector3): void;
|
|
302
295
|
(x: number, y: number, z: number): void;
|
|
303
296
|
} | undefined;
|
|
304
|
-
add?: ((...object: import("three").Object3D[]) => import("three").OrthographicCamera) | undefined;
|
|
305
|
-
remove?: ((...object: import("three").Object3D[]) => import("three").OrthographicCamera) | undefined;
|
|
306
297
|
removeFromParent?: (() => import("three").OrthographicCamera) | undefined;
|
|
307
298
|
clear?: (() => import("three").OrthographicCamera) | undefined;
|
|
308
299
|
getObjectById?: ((id: number) => import("three").Object3D | undefined) | undefined;
|
|
@@ -326,6 +317,15 @@ export declare class NgtCanvas {
|
|
|
326
317
|
zoom?: number | undefined;
|
|
327
318
|
near?: number | undefined;
|
|
328
319
|
far?: number | undefined;
|
|
320
|
+
view?: {
|
|
321
|
+
enabled: boolean;
|
|
322
|
+
fullWidth: number;
|
|
323
|
+
fullHeight: number;
|
|
324
|
+
offsetX: number;
|
|
325
|
+
offsetY: number;
|
|
326
|
+
width: number;
|
|
327
|
+
height: number;
|
|
328
|
+
} | null | undefined;
|
|
329
329
|
setViewOffset?: ((fullWidth: number, fullHeight: number, offsetX: number, offsetY: number, width: number, height: number) => void) | undefined;
|
|
330
330
|
clearViewOffset?: (() => void) | undefined;
|
|
331
331
|
updateProjectionMatrix?: (() => void) | undefined;
|
package/lib/html.d.ts
CHANGED
|
@@ -8,11 +8,11 @@ export declare function provideHTMLDomElement<TDeps extends Array<ProviderToken<
|
|
|
8
8
|
}>(deps: TDeps, factory: (...args: TValues) => HTMLElement): Provider;
|
|
9
9
|
export declare abstract class NgtHTML {
|
|
10
10
|
static [HTML]: boolean;
|
|
11
|
-
protected store: import("angular-three").NgtSignalStore<import("
|
|
11
|
+
protected store: import("angular-three").NgtSignalStore<import("angular-three").NgtState>;
|
|
12
12
|
protected destroyRef: DestroyRef;
|
|
13
13
|
protected host: ElementRef<HTMLElement>;
|
|
14
|
-
protected domElement: "gl" |
|
|
14
|
+
protected domElement: HTMLElement | "gl" | null;
|
|
15
15
|
constructor();
|
|
16
16
|
static ɵfac: i0.ɵɵFactoryDeclaration<NgtHTML, never>;
|
|
17
|
-
static ɵdir: i0.ɵɵDirectiveDeclaration<NgtHTML, never, never, {}, {}, never, never,
|
|
17
|
+
static ɵdir: i0.ɵɵDirectiveDeclaration<NgtHTML, never, never, {}, {}, never, never, true, never>;
|
|
18
18
|
}
|
package/lib/portal.d.ts
CHANGED
|
@@ -34,7 +34,7 @@ export type NgtPortalInjectableState = Partial<Omit<NgtState, NgtPortalPrivateKe
|
|
|
34
34
|
}>;
|
|
35
35
|
export declare class NgtPortal {
|
|
36
36
|
container: import("@angular/core").InputSignal<Object3D<import("three").Object3DEventMap>>;
|
|
37
|
-
state: import("@angular/core").InputSignal<Partial<Omit<NgtState, "
|
|
37
|
+
state: import("@angular/core").InputSignal<Partial<Omit<NgtState, "events" | "size" | "viewport" | "invalidate" | "advance" | "setEvents" | "setSize" | "setDpr" | "setFrameloop"> & {
|
|
38
38
|
events?: {
|
|
39
39
|
enabled?: boolean;
|
|
40
40
|
priority?: number;
|
|
@@ -54,7 +54,7 @@ export declare class NgtPortal {
|
|
|
54
54
|
private portalStore;
|
|
55
55
|
private parentStore;
|
|
56
56
|
protected parentScene: import("@angular/core").Signal<Scene>;
|
|
57
|
-
protected parentCamera: import("@angular/core").Signal<import("
|
|
57
|
+
protected parentCamera: import("@angular/core").Signal<import("angular-three").NgtCameraManual>;
|
|
58
58
|
private raycaster;
|
|
59
59
|
private pointer;
|
|
60
60
|
private portalRendered;
|
package/lib/routed-scene.d.ts
CHANGED
|
@@ -1,7 +1,13 @@
|
|
|
1
|
-
import { ChangeDetectorRef } from '@angular/core';
|
|
2
|
-
import { Router } from '@angular/router';
|
|
1
|
+
import { ChangeDetectorRef, EnvironmentInjector } from '@angular/core';
|
|
2
|
+
import { ActivatedRoute, Router, RouterOutlet } from '@angular/router';
|
|
3
3
|
import { ROUTED_SCENE } from './renderer/constants';
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
5
|
+
export declare class NgtRouterOutlet extends RouterOutlet {
|
|
6
|
+
private environmentInjector;
|
|
7
|
+
activateWith(activatedRoute: ActivatedRoute, environmentInjector: EnvironmentInjector): void;
|
|
8
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<NgtRouterOutlet, never>;
|
|
9
|
+
static ɵdir: i0.ɵɵDirectiveDeclaration<NgtRouterOutlet, "ngt-router-outlet", never, {}, {}, never, never, true, never>;
|
|
10
|
+
}
|
|
5
11
|
export declare class NgtRoutedScene {
|
|
6
12
|
static [ROUTED_SCENE]: boolean;
|
|
7
13
|
constructor(router: Router, cdr: ChangeDetectorRef);
|
|
@@ -22,25 +22,6 @@ export declare class NgtObjectEvents {
|
|
|
22
22
|
static ɵfac: i0.ɵɵFactoryDeclaration<NgtObjectEvents, never>;
|
|
23
23
|
static ɵdir: i0.ɵɵDirectiveDeclaration<NgtObjectEvents, "[ngtObjectEvents]", never, { "ngtObjectEvents": { "alias": "ngtObjectEvents"; "required": false; "isSignal": true; }; }, { "click": "click"; "dblclick": "dblclick"; "contextmenu": "contextmenu"; "pointerup": "pointerup"; "pointerdown": "pointerdown"; "pointerover": "pointerover"; "pointerout": "pointerout"; "pointerenter": "pointerenter"; "pointerleave": "pointerleave"; "pointermove": "pointermove"; "pointermissed": "pointermissed"; "pointercancel": "pointercancel"; "wheel": "wheel"; "ngtObjectEvents": "ngtObjectEventsChange"; }, never, never, true, never>;
|
|
24
24
|
}
|
|
25
|
-
/**
|
|
26
|
-
* @deprecated this has never worked. Use `NgtObjectEvents` and explicit value for inputs and outputs instead
|
|
27
|
-
* @since 2.12.0 Will be removed in 3.0.0
|
|
28
|
-
*/
|
|
29
|
-
export declare const NgtObjectEventsInputs: string[];
|
|
30
|
-
/**
|
|
31
|
-
* @deprecated this has never worked. Use `NgtObjectEvents` and explicit value for inputs and outputs instead
|
|
32
|
-
* @since 2.12.0 Will be removed in 3.0.0
|
|
33
|
-
*/
|
|
34
|
-
export declare const NgtObjectEventsOutputs: string[];
|
|
35
|
-
/**
|
|
36
|
-
* @deprecated Use NgtObjectEventsInputs and NgtObjectEventsOutputs instead along with NgtObjectEvents
|
|
37
|
-
* @since 2.6.0 Will be removed in 3.0.0
|
|
38
|
-
*/
|
|
39
|
-
export declare const NgtObjectEventsHostDirective: {
|
|
40
|
-
directive: typeof NgtObjectEvents;
|
|
41
|
-
inputs: string[];
|
|
42
|
-
outputs: string[];
|
|
43
|
-
};
|
|
44
25
|
export declare function injectObjectEvents(target: () => ElementRef<Object3D> | Object3D | null | undefined, events: NgtEventHandlers, { injector }?: {
|
|
45
26
|
injector?: Injector;
|
|
46
27
|
}): (() => void)[];
|
|
@@ -18,6 +18,7 @@ export declare class NgtCanvasNative {
|
|
|
18
18
|
raycaster: import("@angular/core").InputSignal<Partial<Raycaster> | undefined>;
|
|
19
19
|
scene: import("@angular/core").InputSignal<Scene | Partial<Scene> | undefined>;
|
|
20
20
|
camera: import("@angular/core").InputSignal<NonNullable<((import("angular-three").NgtCamera | Partial<{
|
|
21
|
+
name?: string | undefined;
|
|
21
22
|
readonly type?: string | undefined;
|
|
22
23
|
addEventListener: (<TEventKey extends keyof import("angular-three").NgtNodeEventMap<import("three").Camera>>(type: TEventKey, listener: (this: import("angular-three").NgtNodeElement<import("three").Camera, typeof import("three").Camera>, ev: import("angular-three").NgtNodeEventMap<import("three").Camera>[TEventKey]) => any) => void) & (<TEventKey extends keyof import("angular-three").NgtAllObject3DEventsMap>(type: TEventKey, listener: (this: any, ev: import("angular-three").NgtAllObject3DEventsMap[TEventKey]) => any) => void);
|
|
23
24
|
removeEventListener: (<TEventKey extends keyof import("angular-three").NgtNodeEventMap<import("three").Camera>>(type: TEventKey, listener: (this: import("angular-three").NgtNodeElement<import("three").Camera, typeof import("three").Camera>, ev: import("angular-three").NgtNodeEventMap<import("three").Camera>[TEventKey]) => any) => void) & (<TEventKey extends keyof import("angular-three").NgtAllObject3DEventsMap>(type: TEventKey, listener: (this: any, ev: import("angular-three").NgtAllObject3DEventsMap[TEventKey]) => any) => void);
|
|
@@ -33,7 +34,6 @@ export declare class NgtCanvasNative {
|
|
|
33
34
|
readonly isObject3D?: true | undefined;
|
|
34
35
|
readonly id?: number | undefined;
|
|
35
36
|
uuid?: string | undefined;
|
|
36
|
-
name?: string | undefined;
|
|
37
37
|
parent?: import("three").Object3D<import("three").Object3DEventMap> | null | undefined;
|
|
38
38
|
children?: import("three").Object3D<import("three").Object3DEventMap>[] | undefined;
|
|
39
39
|
readonly modelViewMatrix?: import("three").Matrix4 | undefined;
|
|
@@ -108,6 +108,7 @@ export declare class NgtCanvasNative {
|
|
|
108
108
|
dispose: (() => void) | null;
|
|
109
109
|
raycast: import("three").Object3D["raycast"] | null;
|
|
110
110
|
} & {
|
|
111
|
+
name?: string | undefined;
|
|
111
112
|
readonly type?: string | undefined;
|
|
112
113
|
addEventListener: (<TEventKey extends keyof import("angular-three").NgtNodeEventMap<import("three").PerspectiveCamera>>(type: TEventKey, listener: (this: import("angular-three").NgtNodeElement<import("three").PerspectiveCamera, typeof import("three").PerspectiveCamera>, ev: import("angular-three").NgtNodeEventMap<import("three").PerspectiveCamera>[TEventKey]) => any) => void) & (<TEventKey extends keyof import("angular-three").NgtAllObject3DEventsMap>(type: TEventKey, listener: (this: any, ev: import("angular-three").NgtAllObject3DEventsMap[TEventKey]) => any) => void);
|
|
113
114
|
removeEventListener: (<TEventKey extends keyof import("angular-three").NgtNodeEventMap<import("three").PerspectiveCamera>>(type: TEventKey, listener: (this: import("angular-three").NgtNodeElement<import("three").PerspectiveCamera, typeof import("three").PerspectiveCamera>, ev: import("angular-three").NgtNodeEventMap<import("three").PerspectiveCamera>[TEventKey]) => any) => void) & (<TEventKey extends keyof import("angular-three").NgtAllObject3DEventsMap>(type: TEventKey, listener: (this: any, ev: import("angular-three").NgtAllObject3DEventsMap[TEventKey]) => any) => void);
|
|
@@ -123,7 +124,6 @@ export declare class NgtCanvasNative {
|
|
|
123
124
|
readonly isObject3D?: true | undefined;
|
|
124
125
|
readonly id?: number | undefined;
|
|
125
126
|
uuid?: string | undefined;
|
|
126
|
-
name?: string | undefined;
|
|
127
127
|
parent?: import("three").Object3D<import("three").Object3DEventMap> | null | undefined;
|
|
128
128
|
children?: import("three").Object3D<import("three").Object3DEventMap>[] | undefined;
|
|
129
129
|
readonly modelViewMatrix?: import("three").Matrix4 | undefined;
|
|
@@ -227,6 +227,7 @@ export declare class NgtCanvasNative {
|
|
|
227
227
|
dispose: (() => void) | null;
|
|
228
228
|
raycast: import("three").Object3D["raycast"] | null;
|
|
229
229
|
} & {
|
|
230
|
+
name?: string | undefined;
|
|
230
231
|
readonly type?: string | undefined;
|
|
231
232
|
addEventListener: (<TEventKey extends keyof import("angular-three").NgtNodeEventMap<import("three").OrthographicCamera>>(type: TEventKey, listener: (this: import("angular-three").NgtNodeElement<import("three").OrthographicCamera, typeof import("three").OrthographicCamera>, ev: import("angular-three").NgtNodeEventMap<import("three").OrthographicCamera>[TEventKey]) => any) => void) & (<TEventKey extends keyof import("angular-three").NgtAllObject3DEventsMap>(type: TEventKey, listener: (this: any, ev: import("angular-three").NgtAllObject3DEventsMap[TEventKey]) => any) => void);
|
|
232
233
|
removeEventListener: (<TEventKey extends keyof import("angular-three").NgtNodeEventMap<import("three").OrthographicCamera>>(type: TEventKey, listener: (this: import("angular-three").NgtNodeElement<import("three").OrthographicCamera, typeof import("three").OrthographicCamera>, ev: import("angular-three").NgtNodeEventMap<import("three").OrthographicCamera>[TEventKey]) => any) => void) & (<TEventKey extends keyof import("angular-three").NgtAllObject3DEventsMap>(type: TEventKey, listener: (this: any, ev: import("angular-three").NgtAllObject3DEventsMap[TEventKey]) => any) => void);
|
|
@@ -242,7 +243,6 @@ export declare class NgtCanvasNative {
|
|
|
242
243
|
readonly isObject3D?: true | undefined;
|
|
243
244
|
readonly id?: number | undefined;
|
|
244
245
|
uuid?: string | undefined;
|
|
245
|
-
name?: string | undefined;
|
|
246
246
|
parent?: import("three").Object3D<import("three").Object3DEventMap> | null | undefined;
|
|
247
247
|
children?: import("three").Object3D<import("three").Object3DEventMap>[] | undefined;
|
|
248
248
|
readonly modelViewMatrix?: import("three").Matrix4 | undefined;
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "angular-three",
|
|
3
|
-
"version": "
|
|
3
|
+
"version": "3.0.0",
|
|
4
4
|
"publishConfig": {
|
|
5
5
|
"access": "public"
|
|
6
6
|
},
|
|
@@ -22,8 +22,8 @@
|
|
|
22
22
|
],
|
|
23
23
|
"license": "MIT",
|
|
24
24
|
"peerDependencies": {
|
|
25
|
-
"@angular/common": ">=
|
|
26
|
-
"@angular/core": ">=
|
|
25
|
+
"@angular/common": ">=19.0.0 <20.0.0",
|
|
26
|
+
"@angular/core": ">=19.0.0 <20.0.0",
|
|
27
27
|
"ngxtension": ">=3.0.0",
|
|
28
28
|
"three": ">=0.148.0 <0.172.0",
|
|
29
29
|
"@nativescript/angular": ">=18.0.0 <19.0.0",
|
|
@@ -83,20 +83,14 @@
|
|
|
83
83
|
},
|
|
84
84
|
".": {
|
|
85
85
|
"types": "./index.d.ts",
|
|
86
|
-
"esm2022": "./esm2022/angular-three.mjs",
|
|
87
|
-
"esm": "./esm2022/angular-three.mjs",
|
|
88
86
|
"default": "./fesm2022/angular-three.mjs"
|
|
89
87
|
},
|
|
90
88
|
"./nativescript": {
|
|
91
89
|
"types": "./nativescript/index.d.ts",
|
|
92
|
-
"esm2022": "./esm2022/nativescript/angular-three-nativescript.mjs",
|
|
93
|
-
"esm": "./esm2022/nativescript/angular-three-nativescript.mjs",
|
|
94
90
|
"default": "./fesm2022/angular-three-nativescript.mjs"
|
|
95
91
|
},
|
|
96
92
|
"./testing": {
|
|
97
93
|
"types": "./testing/index.d.ts",
|
|
98
|
-
"esm2022": "./esm2022/testing/angular-three-testing.mjs",
|
|
99
|
-
"esm": "./esm2022/testing/angular-three-testing.mjs",
|
|
100
94
|
"default": "./fesm2022/angular-three-testing.mjs"
|
|
101
95
|
}
|
|
102
96
|
},
|
|
@@ -2,12 +2,12 @@
|
|
|
2
2
|
"cli": "nx",
|
|
3
3
|
"$id": "Init",
|
|
4
4
|
"title": "Init Angular Three",
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
5
|
+
"type": "object",
|
|
6
|
+
"properties": {
|
|
7
|
+
"skipGenerateExperience": {
|
|
8
|
+
"type": "boolean",
|
|
9
|
+
"description": "Skip generating Experience component",
|
|
10
|
+
"default": false
|
|
11
|
+
}
|
|
12
|
+
}
|
|
13
13
|
}
|
|
@@ -1,5 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Generated bundle index. Do not edit.
|
|
3
|
-
*/
|
|
4
|
-
export * from './index';
|
|
5
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYW5ndWxhci10aHJlZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL2xpYnMvY29yZS9zcmMvYW5ndWxhci10aHJlZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsU0FBUyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBHZW5lcmF0ZWQgYnVuZGxlIGluZGV4LiBEbyBub3QgZWRpdC5cbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL2luZGV4JztcbiJdfQ==
|
package/esm2022/index.mjs
DELETED
|
@@ -1,25 +0,0 @@
|
|
|
1
|
-
export * from './lib/canvas';
|
|
2
|
-
export * from './lib/directives/args';
|
|
3
|
-
export * from './lib/directives/selection';
|
|
4
|
-
export * from './lib/html';
|
|
5
|
-
export * from './lib/instance';
|
|
6
|
-
export * from './lib/loader';
|
|
7
|
-
export * from './lib/loop';
|
|
8
|
-
export * from './lib/pipes/hexify';
|
|
9
|
-
export * from './lib/portal';
|
|
10
|
-
export * from './lib/renderer';
|
|
11
|
-
export * from './lib/roots';
|
|
12
|
-
export * from './lib/routed-scene';
|
|
13
|
-
export * from './lib/store';
|
|
14
|
-
export * from './lib/utils/apply-props';
|
|
15
|
-
export * from './lib/utils/attach';
|
|
16
|
-
export * from './lib/utils/before-render';
|
|
17
|
-
export * from './lib/utils/is';
|
|
18
|
-
export * from './lib/utils/make';
|
|
19
|
-
export * from './lib/utils/object-events';
|
|
20
|
-
export * from './lib/utils/output-ref';
|
|
21
|
-
export * from './lib/utils/parameters';
|
|
22
|
-
export * from './lib/utils/resolve-ref';
|
|
23
|
-
export * from './lib/utils/signal-store';
|
|
24
|
-
export * from './lib/utils/update';
|
|
25
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9saWJzL2NvcmUvc3JjL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsY0FBYyxDQUFDO0FBQzdCLGNBQWMsdUJBQXVCLENBQUM7QUFDdEMsY0FBYyw0QkFBNEIsQ0FBQztBQUMzQyxjQUFjLFlBQVksQ0FBQztBQUMzQixjQUFjLGdCQUFnQixDQUFDO0FBQy9CLGNBQWMsY0FBYyxDQUFDO0FBQzdCLGNBQWMsWUFBWSxDQUFDO0FBQzNCLGNBQWMsb0JBQW9CLENBQUM7QUFDbkMsY0FBYyxjQUFjLENBQUM7QUFDN0IsY0FBYyxnQkFBZ0IsQ0FBQztBQUMvQixjQUFjLGFBQWEsQ0FBQztBQUM1QixjQUFjLG9CQUFvQixDQUFDO0FBQ25DLGNBQWMsYUFBYSxDQUFDO0FBQzVCLGNBQWMseUJBQXlCLENBQUM7QUFDeEMsY0FBYyxvQkFBb0IsQ0FBQztBQUNuQyxjQUFjLDJCQUEyQixDQUFDO0FBQzFDLGNBQWMsZ0JBQWdCLENBQUM7QUFDL0IsY0FBYyxrQkFBa0IsQ0FBQztBQUNqQyxjQUFjLDJCQUEyQixDQUFDO0FBQzFDLGNBQWMsd0JBQXdCLENBQUM7QUFDdkMsY0FBYyx3QkFBd0IsQ0FBQztBQUN2QyxjQUFjLHlCQUF5QixDQUFDO0FBQ3hDLGNBQWMsMEJBQTBCLENBQUM7QUFDekMsY0FBYyxvQkFBb0IsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vbGliL2NhbnZhcyc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9kaXJlY3RpdmVzL2FyZ3MnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZGlyZWN0aXZlcy9zZWxlY3Rpb24nO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvaHRtbCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9pbnN0YW5jZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9sb2FkZXInO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvbG9vcCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9waXBlcy9oZXhpZnknO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvcG9ydGFsJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3JlbmRlcmVyJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3Jvb3RzJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3JvdXRlZC1zY2VuZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9zdG9yZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi91dGlscy9hcHBseS1wcm9wcyc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi91dGlscy9hdHRhY2gnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvdXRpbHMvYmVmb3JlLXJlbmRlcic7XG5leHBvcnQgKiBmcm9tICcuL2xpYi91dGlscy9pcyc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi91dGlscy9tYWtlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3V0aWxzL29iamVjdC1ldmVudHMnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvdXRpbHMvb3V0cHV0LXJlZic7XG5leHBvcnQgKiBmcm9tICcuL2xpYi91dGlscy9wYXJhbWV0ZXJzJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3V0aWxzL3Jlc29sdmUtcmVmJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3V0aWxzL3NpZ25hbC1zdG9yZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi91dGlscy91cGRhdGUnO1xuXG5leHBvcnQgdHlwZSAqIGZyb20gJy4vbGliL3RocmVlLXR5cGVzJztcbmV4cG9ydCB0eXBlICogZnJvbSAnLi9saWIvdHlwZXMnO1xuIl19
|
package/esm2022/lib/canvas.mjs
DELETED
|
@@ -1,188 +0,0 @@
|
|
|
1
|
-
import { afterNextRender, booleanAttribute, ChangeDetectionStrategy, Component, computed, createEnvironmentInjector, DestroyRef, effect, ElementRef, EnvironmentInjector, inject, Injector, input, NgZone, output, signal, untracked, viewChild, ViewContainerRef, } from '@angular/core';
|
|
2
|
-
import { outputFromObservable } from '@angular/core/rxjs-interop';
|
|
3
|
-
import { NgxResize, provideResizeOptions } from 'ngxtension/resize';
|
|
4
|
-
import { createPointerEvents } from './dom/events';
|
|
5
|
-
import { provideNgtRenderer } from './renderer';
|
|
6
|
-
import { injectCanvasRootInitializer } from './roots';
|
|
7
|
-
import { NgtRoutedScene } from './routed-scene';
|
|
8
|
-
import { injectStore, provideStore } from './store';
|
|
9
|
-
import { is } from './utils/is';
|
|
10
|
-
import * as i0 from "@angular/core";
|
|
11
|
-
export class NgtCanvas {
|
|
12
|
-
constructor() {
|
|
13
|
-
this.store = injectStore();
|
|
14
|
-
this.initRoot = injectCanvasRootInitializer();
|
|
15
|
-
this.host = inject(ElementRef);
|
|
16
|
-
this.zone = inject(NgZone);
|
|
17
|
-
this.environmentInjector = inject(EnvironmentInjector);
|
|
18
|
-
this.injector = inject(Injector);
|
|
19
|
-
this.sceneGraph = input.required({
|
|
20
|
-
transform: (value) => {
|
|
21
|
-
if (value === 'routed') {
|
|
22
|
-
console.warn(`[NGT] 'routed' sceneGraph is not working properly.`);
|
|
23
|
-
return NgtRoutedScene;
|
|
24
|
-
}
|
|
25
|
-
return value;
|
|
26
|
-
},
|
|
27
|
-
});
|
|
28
|
-
this.gl = input();
|
|
29
|
-
this.size = input();
|
|
30
|
-
this.shadows = input(false, {
|
|
31
|
-
transform: (value) => {
|
|
32
|
-
if (value === '')
|
|
33
|
-
return booleanAttribute(value);
|
|
34
|
-
return value;
|
|
35
|
-
},
|
|
36
|
-
});
|
|
37
|
-
this.legacy = input(false, { transform: booleanAttribute });
|
|
38
|
-
this.linear = input(false, { transform: booleanAttribute });
|
|
39
|
-
this.flat = input(false, { transform: booleanAttribute });
|
|
40
|
-
this.orthographic = input(false, { transform: booleanAttribute });
|
|
41
|
-
this.frameloop = input('always');
|
|
42
|
-
this.performance = input();
|
|
43
|
-
this.dpr = input([1, 2]);
|
|
44
|
-
this.raycaster = input();
|
|
45
|
-
this.scene = input();
|
|
46
|
-
this.camera = input();
|
|
47
|
-
this.events = input(createPointerEvents);
|
|
48
|
-
this.eventSource = input();
|
|
49
|
-
this.eventPrefix = input('offset');
|
|
50
|
-
this.lookAt = input();
|
|
51
|
-
this.created = output();
|
|
52
|
-
this.pointerMissed = outputFromObservable(this.store.get('pointerMissed$'));
|
|
53
|
-
this.glCanvas = viewChild.required('glCanvas');
|
|
54
|
-
this.glCanvasViewContainerRef = viewChild.required('glCanvas', { read: ViewContainerRef });
|
|
55
|
-
this.hbPointerEvents = computed(() => (this.eventSource() ? 'none' : 'auto'));
|
|
56
|
-
// NOTE: this signal is updated outside of Zone
|
|
57
|
-
this.resizeResult = signal({}, { equal: Object.is });
|
|
58
|
-
this.configurator = signal(null);
|
|
59
|
-
// NOTE: this means that everything in NgtCanvas will be in afterNextRender.
|
|
60
|
-
// this allows the content of NgtCanvas to use effect instead of afterNextRender
|
|
61
|
-
afterNextRender(() => {
|
|
62
|
-
const canvasElement = this.glCanvas().nativeElement;
|
|
63
|
-
this.zone.runOutsideAngular(() => {
|
|
64
|
-
this.configurator.set(this.initRoot(canvasElement));
|
|
65
|
-
});
|
|
66
|
-
effect(() => {
|
|
67
|
-
const resizeResult = this.resizeResult();
|
|
68
|
-
if (!resizeResult.width || resizeResult.width <= 0 || !resizeResult.height || resizeResult.height <= 0)
|
|
69
|
-
return;
|
|
70
|
-
const configurator = this.configurator();
|
|
71
|
-
if (!configurator)
|
|
72
|
-
return;
|
|
73
|
-
const canvasOptions = {
|
|
74
|
-
gl: this.gl(),
|
|
75
|
-
shadows: this.shadows(),
|
|
76
|
-
legacy: this.legacy(),
|
|
77
|
-
linear: this.linear(),
|
|
78
|
-
flat: this.flat(),
|
|
79
|
-
orthographic: this.orthographic(),
|
|
80
|
-
frameloop: this.frameloop(),
|
|
81
|
-
performance: this.performance(),
|
|
82
|
-
dpr: this.dpr(),
|
|
83
|
-
raycaster: this.raycaster(),
|
|
84
|
-
scene: this.scene(),
|
|
85
|
-
camera: this.camera(),
|
|
86
|
-
events: this.events(),
|
|
87
|
-
eventSource: this.eventSource(),
|
|
88
|
-
eventPrefix: this.eventPrefix(),
|
|
89
|
-
lookAt: this.lookAt(),
|
|
90
|
-
size: resizeResult,
|
|
91
|
-
};
|
|
92
|
-
this.zone.runOutsideAngular(() => {
|
|
93
|
-
configurator.configure(canvasOptions);
|
|
94
|
-
untracked(() => {
|
|
95
|
-
if (this.glRef) {
|
|
96
|
-
this.glRef.changeDetectorRef.detectChanges();
|
|
97
|
-
}
|
|
98
|
-
else {
|
|
99
|
-
this.noZoneRender();
|
|
100
|
-
}
|
|
101
|
-
});
|
|
102
|
-
});
|
|
103
|
-
}, { injector: this.injector });
|
|
104
|
-
});
|
|
105
|
-
inject(DestroyRef).onDestroy(() => {
|
|
106
|
-
this.glRef?.destroy();
|
|
107
|
-
this.glEnvironmentInjector?.destroy();
|
|
108
|
-
this.configurator()?.destroy();
|
|
109
|
-
});
|
|
110
|
-
}
|
|
111
|
-
noZoneRender() {
|
|
112
|
-
// NOTE: destroy previous instances if existed
|
|
113
|
-
this.glEnvironmentInjector?.destroy();
|
|
114
|
-
this.glRef?.destroy();
|
|
115
|
-
// NOTE: Flag the canvas active, rendering will now begin
|
|
116
|
-
this.store.update((state) => ({ internal: { ...state.internal, active: true } }));
|
|
117
|
-
const [state, eventSource, eventPrefix] = [
|
|
118
|
-
this.store.snapshot,
|
|
119
|
-
untracked(this.eventSource),
|
|
120
|
-
untracked(this.eventPrefix),
|
|
121
|
-
];
|
|
122
|
-
// connect to event source
|
|
123
|
-
state.events.connect?.(eventSource ? (is.ref(eventSource) ? eventSource.nativeElement : eventSource) : this.host.nativeElement);
|
|
124
|
-
// setup compute for eventPrefix
|
|
125
|
-
if (eventPrefix) {
|
|
126
|
-
state.setEvents({
|
|
127
|
-
compute: (event, store) => {
|
|
128
|
-
const { pointer, raycaster, camera, size } = store.snapshot;
|
|
129
|
-
const x = event[(eventPrefix + 'X')];
|
|
130
|
-
const y = event[(eventPrefix + 'Y')];
|
|
131
|
-
pointer.set((x / size.width) * 2 - 1, -(y / size.height) * 2 + 1);
|
|
132
|
-
raycaster.setFromCamera(pointer, camera);
|
|
133
|
-
},
|
|
134
|
-
});
|
|
135
|
-
}
|
|
136
|
-
// emit created event if observed
|
|
137
|
-
this.created.emit(this.store.snapshot);
|
|
138
|
-
if (!this.store.get('events', 'connected')) {
|
|
139
|
-
this.store.get('events').connect?.(untracked(this.glCanvas).nativeElement);
|
|
140
|
-
}
|
|
141
|
-
this.glEnvironmentInjector = createEnvironmentInjector([provideNgtRenderer(this.store)], this.environmentInjector);
|
|
142
|
-
this.glRef = untracked(this.glCanvasViewContainerRef).createComponent(untracked(this.sceneGraph), {
|
|
143
|
-
environmentInjector: this.glEnvironmentInjector,
|
|
144
|
-
injector: this.injector,
|
|
145
|
-
});
|
|
146
|
-
this.glRef.changeDetectorRef.detectChanges();
|
|
147
|
-
}
|
|
148
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: NgtCanvas, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
149
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.2.0", version: "18.2.11", type: NgtCanvas, isStandalone: true, selector: "ngt-canvas", inputs: { sceneGraph: { classPropertyName: "sceneGraph", publicName: "sceneGraph", isSignal: true, isRequired: true, transformFunction: null }, gl: { classPropertyName: "gl", publicName: "gl", isSignal: true, isRequired: false, transformFunction: null }, size: { classPropertyName: "size", publicName: "size", isSignal: true, isRequired: false, transformFunction: null }, shadows: { classPropertyName: "shadows", publicName: "shadows", isSignal: true, isRequired: false, transformFunction: null }, legacy: { classPropertyName: "legacy", publicName: "legacy", isSignal: true, isRequired: false, transformFunction: null }, linear: { classPropertyName: "linear", publicName: "linear", isSignal: true, isRequired: false, transformFunction: null }, flat: { classPropertyName: "flat", publicName: "flat", isSignal: true, isRequired: false, transformFunction: null }, orthographic: { classPropertyName: "orthographic", publicName: "orthographic", isSignal: true, isRequired: false, transformFunction: null }, frameloop: { classPropertyName: "frameloop", publicName: "frameloop", isSignal: true, isRequired: false, transformFunction: null }, performance: { classPropertyName: "performance", publicName: "performance", isSignal: true, isRequired: false, transformFunction: null }, dpr: { classPropertyName: "dpr", publicName: "dpr", isSignal: true, isRequired: false, transformFunction: null }, raycaster: { classPropertyName: "raycaster", publicName: "raycaster", isSignal: true, isRequired: false, transformFunction: null }, scene: { classPropertyName: "scene", publicName: "scene", isSignal: true, isRequired: false, transformFunction: null }, camera: { classPropertyName: "camera", publicName: "camera", isSignal: true, isRequired: false, transformFunction: null }, events: { classPropertyName: "events", publicName: "events", isSignal: true, isRequired: false, transformFunction: null }, eventSource: { classPropertyName: "eventSource", publicName: "eventSource", isSignal: true, isRequired: false, transformFunction: null }, eventPrefix: { classPropertyName: "eventPrefix", publicName: "eventPrefix", isSignal: true, isRequired: false, transformFunction: null }, lookAt: { classPropertyName: "lookAt", publicName: "lookAt", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { created: "created", pointerMissed: "pointerMissed" }, host: { properties: { "style.pointerEvents": "hbPointerEvents()" }, styleAttribute: "display: block;position: relative;width: 100%;height: 100%;overflow: hidden;" }, providers: [
|
|
150
|
-
provideResizeOptions({
|
|
151
|
-
emitInZone: false,
|
|
152
|
-
emitInitialResult: true,
|
|
153
|
-
debounce: { scroll: 50, resize: 0 },
|
|
154
|
-
}),
|
|
155
|
-
provideStore(),
|
|
156
|
-
], viewQueries: [{ propertyName: "glCanvas", first: true, predicate: ["glCanvas"], descendants: true, isSignal: true }, { propertyName: "glCanvasViewContainerRef", first: true, predicate: ["glCanvas"], descendants: true, read: ViewContainerRef, isSignal: true }], ngImport: i0, template: `
|
|
157
|
-
<div (ngxResize)="resizeResult.set($event)" style="height: 100%; width: 100%;">
|
|
158
|
-
<canvas #glCanvas style="display: block;"></canvas>
|
|
159
|
-
</div>
|
|
160
|
-
`, isInline: true, dependencies: [{ kind: "directive", type: NgxResize, selector: "[ngxResize]", inputs: ["ngxResizeOptions"], outputs: ["ngxResize"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
161
|
-
}
|
|
162
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: NgtCanvas, decorators: [{
|
|
163
|
-
type: Component,
|
|
164
|
-
args: [{
|
|
165
|
-
selector: 'ngt-canvas',
|
|
166
|
-
standalone: true,
|
|
167
|
-
template: `
|
|
168
|
-
<div (ngxResize)="resizeResult.set($event)" style="height: 100%; width: 100%;">
|
|
169
|
-
<canvas #glCanvas style="display: block;"></canvas>
|
|
170
|
-
</div>
|
|
171
|
-
`,
|
|
172
|
-
imports: [NgxResize],
|
|
173
|
-
providers: [
|
|
174
|
-
provideResizeOptions({
|
|
175
|
-
emitInZone: false,
|
|
176
|
-
emitInitialResult: true,
|
|
177
|
-
debounce: { scroll: 50, resize: 0 },
|
|
178
|
-
}),
|
|
179
|
-
provideStore(),
|
|
180
|
-
],
|
|
181
|
-
host: {
|
|
182
|
-
style: 'display: block;position: relative;width: 100%;height: 100%;overflow: hidden;',
|
|
183
|
-
'[style.pointerEvents]': 'hbPointerEvents()',
|
|
184
|
-
},
|
|
185
|
-
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
186
|
-
}]
|
|
187
|
-
}], ctorParameters: () => [] });
|
|
188
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"canvas.js","sourceRoot":"","sources":["../../../../../libs/core/src/lib/canvas.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n\tafterNextRender,\n\tbooleanAttribute,\n\tChangeDetectionStrategy,\n\tComponent,\n\tComponentRef,\n\tcomputed,\n\tcreateEnvironmentInjector,\n\tDestroyRef,\n\teffect,\n\tElementRef,\n\tEnvironmentInjector,\n\tinject,\n\tInjector,\n\tinput,\n\tNgZone,\n\toutput,\n\tsignal,\n\tType,\n\tuntracked,\n\tviewChild,\n\tViewContainerRef,\n} from '@angular/core';\nimport { outputFromObservable } from '@angular/core/rxjs-interop';\nimport { NgxResize, provideResizeOptions, ResizeOptions, ResizeResult } from 'ngxtension/resize';\nimport { Raycaster, Scene, Vector3 } from 'three';\nimport { createPointerEvents } from './dom/events';\nimport { provideNgtRenderer } from './renderer';\nimport { injectCanvasRootInitializer, NgtCanvasConfigurator } from './roots';\nimport { NgtRoutedScene } from './routed-scene';\nimport { injectStore, provideStore } from './store';\nimport { NgtCanvasOptions, NgtDomEvent, NgtDpr, NgtGLOptions, NgtPerformance, NgtSize, NgtState } from './types';\nimport { is } from './utils/is';\n\n@Component({\n\tselector: 'ngt-canvas',\n\tstandalone: true,\n\ttemplate: `\n\t\t<div (ngxResize)=\"resizeResult.set($event)\" style=\"height: 100%; width: 100%;\">\n\t\t\t<canvas #glCanvas style=\"display: block;\"></canvas>\n\t\t</div>\n\t`,\n\timports: [NgxResize],\n\tproviders: [\n\t\tprovideResizeOptions({\n\t\t\temitInZone: false,\n\t\t\temitInitialResult: true,\n\t\t\tdebounce: { scroll: 50, resize: 0 },\n\t\t} as ResizeOptions),\n\t\tprovideStore(),\n\t],\n\thost: {\n\t\tstyle: 'display: block;position: relative;width: 100%;height: 100%;overflow: hidden;',\n\t\t'[style.pointerEvents]': 'hbPointerEvents()',\n\t},\n\tchangeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class NgtCanvas {\n\tprivate store = injectStore();\n\tprivate initRoot = injectCanvasRootInitializer();\n\n\tprivate host = inject<ElementRef<HTMLElement>>(ElementRef);\n\tprivate zone = inject(NgZone);\n\tprivate environmentInjector = inject(EnvironmentInjector);\n\tprivate injector = inject(Injector);\n\n\tsceneGraph = input.required<Type<any>, Type<any> | 'routed'>({\n\t\ttransform: (value) => {\n\t\t\tif (value === 'routed') {\n\t\t\t\tconsole.warn(`[NGT] 'routed' sceneGraph is not working properly.`);\n\t\t\t\treturn NgtRoutedScene;\n\t\t\t}\n\t\t\treturn value;\n\t\t},\n\t});\n\tgl = input<NgtGLOptions>();\n\tsize = input<NgtSize>();\n\tshadows = input(false, {\n\t\ttransform: (value) => {\n\t\t\tif (value === '') return booleanAttribute(value);\n\t\t\treturn value as NonNullable<NgtCanvasOptions['shadows']>;\n\t\t},\n\t});\n\tlegacy = input(false, { transform: booleanAttribute });\n\tlinear = input(false, { transform: booleanAttribute });\n\tflat = input(false, { transform: booleanAttribute });\n\torthographic = input(false, { transform: booleanAttribute });\n\tframeloop = input<NonNullable<NgtCanvasOptions['frameloop']>>('always');\n\tperformance = input<Partial<Omit<NgtPerformance, 'regress'>>>();\n\tdpr = input<NgtDpr>([1, 2]);\n\traycaster = input<Partial<Raycaster>>();\n\tscene = input<Scene | Partial<Scene>>();\n\tcamera = input<NonNullable<NgtCanvasOptions['camera']>>();\n\tevents = input(createPointerEvents);\n\teventSource = input<HTMLElement | ElementRef<HTMLElement>>();\n\teventPrefix = input<NonNullable<NgtCanvasOptions['eventPrefix']>>('offset');\n\tlookAt = input<Vector3 | Parameters<Vector3['set']>>();\n\tcreated = output<NgtState>();\n\tpointerMissed = outputFromObservable(this.store.get('pointerMissed$'));\n\n\tprivate glCanvas = viewChild.required<ElementRef<HTMLCanvasElement>>('glCanvas');\n\tprivate glCanvasViewContainerRef = viewChild.required('glCanvas', { read: ViewContainerRef });\n\n\tprotected hbPointerEvents = computed(() => (this.eventSource() ? 'none' : 'auto'));\n\n\t// NOTE: this signal is updated outside of Zone\n\tprotected resizeResult = signal<ResizeResult>({} as ResizeResult, { equal: Object.is });\n\tprivate configurator = signal<NgtCanvasConfigurator | null>(null);\n\n\tprivate glEnvironmentInjector?: EnvironmentInjector;\n\tprivate glRef?: ComponentRef<unknown>;\n\n\tconstructor() {\n\t\t// NOTE: this means that everything in NgtCanvas will be in afterNextRender.\n\t\t// this allows the content of NgtCanvas to use effect instead of afterNextRender\n\t\tafterNextRender(() => {\n\t\t\tconst canvasElement = this.glCanvas().nativeElement;\n\t\t\tthis.zone.runOutsideAngular(() => {\n\t\t\t\tthis.configurator.set(this.initRoot(canvasElement));\n\t\t\t});\n\n\t\t\teffect(\n\t\t\t\t() => {\n\t\t\t\t\tconst resizeResult = this.resizeResult();\n\t\t\t\t\tif (!resizeResult.width || resizeResult.width <= 0 || !resizeResult.height || resizeResult.height <= 0)\n\t\t\t\t\t\treturn;\n\n\t\t\t\t\tconst configurator = this.configurator();\n\t\t\t\t\tif (!configurator) return;\n\n\t\t\t\t\tconst canvasOptions = {\n\t\t\t\t\t\tgl: this.gl(),\n\t\t\t\t\t\tshadows: this.shadows(),\n\t\t\t\t\t\tlegacy: this.legacy(),\n\t\t\t\t\t\tlinear: this.linear(),\n\t\t\t\t\t\tflat: this.flat(),\n\t\t\t\t\t\torthographic: this.orthographic(),\n\t\t\t\t\t\tframeloop: this.frameloop(),\n\t\t\t\t\t\tperformance: this.performance(),\n\t\t\t\t\t\tdpr: this.dpr(),\n\t\t\t\t\t\traycaster: this.raycaster(),\n\t\t\t\t\t\tscene: this.scene(),\n\t\t\t\t\t\tcamera: this.camera(),\n\t\t\t\t\t\tevents: this.events(),\n\t\t\t\t\t\teventSource: this.eventSource(),\n\t\t\t\t\t\teventPrefix: this.eventPrefix(),\n\t\t\t\t\t\tlookAt: this.lookAt(),\n\t\t\t\t\t\tsize: resizeResult,\n\t\t\t\t\t};\n\n\t\t\t\t\tthis.zone.runOutsideAngular(() => {\n\t\t\t\t\t\tconfigurator.configure(canvasOptions);\n\n\t\t\t\t\t\tuntracked(() => {\n\t\t\t\t\t\t\tif (this.glRef) {\n\t\t\t\t\t\t\t\tthis.glRef.changeDetectorRef.detectChanges();\n\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\tthis.noZoneRender();\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t});\n\t\t\t\t\t});\n\t\t\t\t},\n\t\t\t\t{ injector: this.injector },\n\t\t\t);\n\t\t});\n\n\t\tinject(DestroyRef).onDestroy(() => {\n\t\t\tthis.glRef?.destroy();\n\t\t\tthis.glEnvironmentInjector?.destroy();\n\t\t\tthis.configurator()?.destroy();\n\t\t});\n\t}\n\n\tprivate noZoneRender() {\n\t\t// NOTE: destroy previous instances if existed\n\t\tthis.glEnvironmentInjector?.destroy();\n\t\tthis.glRef?.destroy();\n\n\t\t// NOTE: Flag the canvas active, rendering will now begin\n\t\tthis.store.update((state) => ({ internal: { ...state.internal, active: true } }));\n\n\t\tconst [state, eventSource, eventPrefix] = [\n\t\t\tthis.store.snapshot,\n\t\t\tuntracked(this.eventSource),\n\t\t\tuntracked(this.eventPrefix),\n\t\t];\n\n\t\t// connect to event source\n\t\tstate.events.connect?.(\n\t\t\teventSource ? (is.ref(eventSource) ? eventSource.nativeElement : eventSource) : this.host.nativeElement,\n\t\t);\n\n\t\t// setup compute for eventPrefix\n\t\tif (eventPrefix) {\n\t\t\tstate.setEvents({\n\t\t\t\tcompute: (event, store) => {\n\t\t\t\t\tconst { pointer, raycaster, camera, size } = store.snapshot;\n\t\t\t\t\tconst x = event[(eventPrefix + 'X') as keyof NgtDomEvent] as number;\n\t\t\t\t\tconst y = event[(eventPrefix + 'Y') as keyof NgtDomEvent] as number;\n\t\t\t\t\tpointer.set((x / size.width) * 2 - 1, -(y / size.height) * 2 + 1);\n\t\t\t\t\traycaster.setFromCamera(pointer, camera);\n\t\t\t\t},\n\t\t\t});\n\t\t}\n\n\t\t// emit created event if observed\n\t\tthis.created.emit(this.store.snapshot);\n\n\t\tif (!this.store.get('events', 'connected')) {\n\t\t\tthis.store.get('events').connect?.(untracked(this.glCanvas).nativeElement);\n\t\t}\n\n\t\tthis.glEnvironmentInjector = createEnvironmentInjector([provideNgtRenderer(this.store)], this.environmentInjector);\n\t\tthis.glRef = untracked(this.glCanvasViewContainerRef).createComponent(untracked(this.sceneGraph), {\n\t\t\tenvironmentInjector: this.glEnvironmentInjector,\n\t\t\tinjector: this.injector,\n\t\t});\n\n\t\tthis.glRef.changeDetectorRef.detectChanges();\n\t}\n}\n"]}
|