angular-three-soba 1.3.1 → 1.4.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.
Files changed (53) hide show
  1. package/abstractions/README.md +3 -0
  2. package/abstractions/index.d.ts +6 -0
  3. package/abstractions/lib/billboard/billboard.d.ts +14 -0
  4. package/abstractions/lib/gizmo-helper/gizmo-helper.d.ts +41 -0
  5. package/abstractions/lib/gizmo-helper/gizmo-viewcube/constants.d.ts +12 -0
  6. package/abstractions/lib/gizmo-helper/gizmo-viewcube/gizmo-viewcube-edge.d.ts +16 -0
  7. package/abstractions/lib/gizmo-helper/gizmo-viewcube/gizmo-viewcube-face.d.ts +24 -0
  8. package/abstractions/lib/gizmo-helper/gizmo-viewcube/gizmo-viewcube-inputs.d.ts +14 -0
  9. package/abstractions/lib/gizmo-helper/gizmo-viewcube/gizmo-viewcube.d.ts +15 -0
  10. package/abstractions/lib/gizmo-helper/gizmo-viewport/gizmo-viewport-axis.d.ts +28 -0
  11. package/abstractions/lib/gizmo-helper/gizmo-viewport/gizmo-viewport.d.ts +21 -0
  12. package/abstractions/lib/text/text.d.ts +21 -0
  13. package/abstractions/lib/text-3d/text-3d.d.ts +39 -0
  14. package/esm2020/abstractions/angular-three-soba-abstractions.mjs +5 -0
  15. package/esm2020/abstractions/index.mjs +7 -0
  16. package/esm2020/abstractions/lib/billboard/billboard.mjs +73 -0
  17. package/esm2020/abstractions/lib/gizmo-helper/gizmo-helper.mjs +206 -0
  18. package/esm2020/abstractions/lib/gizmo-helper/gizmo-viewcube/constants.mjs +31 -0
  19. package/esm2020/abstractions/lib/gizmo-helper/gizmo-viewcube/gizmo-viewcube-edge.mjs +91 -0
  20. package/esm2020/abstractions/lib/gizmo-helper/gizmo-viewcube/gizmo-viewcube-face.mjs +182 -0
  21. package/esm2020/abstractions/lib/gizmo-helper/gizmo-viewcube/gizmo-viewcube-inputs.mjs +45 -0
  22. package/esm2020/abstractions/lib/gizmo-helper/gizmo-viewcube/gizmo-viewcube.mjs +133 -0
  23. package/esm2020/abstractions/lib/gizmo-helper/gizmo-viewport/gizmo-viewport-axis.mjs +193 -0
  24. package/esm2020/abstractions/lib/gizmo-helper/gizmo-viewport/gizmo-viewport.mjs +266 -0
  25. package/esm2020/abstractions/lib/text/text.mjs +110 -0
  26. package/esm2020/abstractions/lib/text-3d/text-3d.mjs +144 -0
  27. package/esm2020/cameras/lib/orthographic-camera/orthographic-camera.mjs +5 -5
  28. package/esm2020/performance/lib/stats/stats.mjs +21 -7
  29. package/esm2020/staging/index.mjs +3 -1
  30. package/esm2020/staging/lib/camera-shake/camera-shake.mjs +121 -0
  31. package/esm2020/staging/lib/cloud/cloud.mjs +159 -0
  32. package/fesm2015/angular-three-soba-abstractions.mjs +1431 -0
  33. package/fesm2015/angular-three-soba-abstractions.mjs.map +1 -0
  34. package/fesm2015/angular-three-soba-cameras.mjs +4 -4
  35. package/fesm2015/angular-three-soba-cameras.mjs.map +1 -1
  36. package/fesm2015/angular-three-soba-performance.mjs +20 -6
  37. package/fesm2015/angular-three-soba-performance.mjs.map +1 -1
  38. package/fesm2015/angular-three-soba-staging.mjs +274 -4
  39. package/fesm2015/angular-three-soba-staging.mjs.map +1 -1
  40. package/fesm2020/angular-three-soba-abstractions.mjs +1428 -0
  41. package/fesm2020/angular-three-soba-abstractions.mjs.map +1 -0
  42. package/fesm2020/angular-three-soba-cameras.mjs +4 -4
  43. package/fesm2020/angular-three-soba-cameras.mjs.map +1 -1
  44. package/fesm2020/angular-three-soba-performance.mjs +20 -6
  45. package/fesm2020/angular-three-soba-performance.mjs.map +1 -1
  46. package/fesm2020/angular-three-soba-staging.mjs +274 -4
  47. package/fesm2020/angular-three-soba-staging.mjs.map +1 -1
  48. package/package.json +11 -3
  49. package/performance/lib/stats/stats.d.ts +5 -4
  50. package/plugin/package.json +1 -1
  51. package/staging/index.d.ts +2 -0
  52. package/staging/lib/camera-shake/camera-shake.d.ts +28 -0
  53. package/staging/lib/cloud/cloud.d.ts +23 -0
@@ -0,0 +1,3 @@
1
+ # angular-three-soba/abstractions
2
+
3
+ Secondary entry point of `angular-three-soba`. It can be used by importing from `angular-three-soba/abstractions`.
@@ -0,0 +1,6 @@
1
+ export * from './lib/billboard/billboard';
2
+ export * from './lib/gizmo-helper/gizmo-helper';
3
+ export * from './lib/gizmo-helper/gizmo-viewcube/gizmo-viewcube';
4
+ export * from './lib/gizmo-helper/gizmo-viewport/gizmo-viewport';
5
+ export * from './lib/text-3d/text-3d';
6
+ export * from './lib/text/text';
@@ -0,0 +1,14 @@
1
+ import { NgtBeforeRenderEvent, NgtRxStore } from 'angular-three';
2
+ import { Group } from 'three';
3
+ import * as i0 from "@angular/core";
4
+ export declare class NgtsBillboard extends NgtRxStore {
5
+ billboardRef: import("angular-three").NgtInjectedRef<Group>;
6
+ set follow(follow: boolean);
7
+ set lockX(lockX: boolean);
8
+ set lockY(lockY: boolean);
9
+ set lockZ(lockZ: boolean);
10
+ initialize(): void;
11
+ onBeforeRender(event: NgtBeforeRenderEvent<Group>): void;
12
+ static ɵfac: i0.ɵɵFactoryDeclaration<NgtsBillboard, never>;
13
+ static ɵcmp: i0.ɵɵComponentDeclaration<NgtsBillboard, "ngts-billboard", never, { "billboardRef": "billboardRef"; "follow": "follow"; "lockX": "lockX"; "lockY": "lockY"; "lockZ": "lockZ"; }, {}, never, ["*"], true, never>;
14
+ }
@@ -0,0 +1,41 @@
1
+ import { EventEmitter, InjectionToken, OnInit, TemplateRef } from '@angular/core';
2
+ import { NgtRxStore } from 'angular-three';
3
+ import { Group, Object3D, OrthographicCamera, Quaternion, Vector3 } from 'three';
4
+ import * as i0 from "@angular/core";
5
+ export interface NgtsGizmoHelperApi {
6
+ tweenCamera: (direction: Vector3) => void;
7
+ }
8
+ export declare const NGTS_GIZMO_HELPER_API: InjectionToken<NgtsGizmoHelperApi>;
9
+ export declare class NgtsGizmoHelperContent {
10
+ static ɵfac: i0.ɵɵFactoryDeclaration<NgtsGizmoHelperContent, never>;
11
+ static ɵdir: i0.ɵɵDirectiveDeclaration<NgtsGizmoHelperContent, "ng-template[ngtsGizmoHelperContent]", never, {}, {}, never, never, true, never>;
12
+ }
13
+ export declare class NgtsGizmoHelper extends NgtRxStore implements OnInit {
14
+ private readonly store;
15
+ readonly gizmoRef: import("angular-three").NgtInjectedRef<Group>;
16
+ readonly virtualCameraRef: import("angular-three").NgtInjectedRef<OrthographicCamera>;
17
+ animating: boolean;
18
+ radius: number;
19
+ focusPoint: Vector3;
20
+ q1: Quaternion;
21
+ q2: Quaternion;
22
+ target: Vector3;
23
+ targetPosition: Vector3;
24
+ dummy: Object3D<import("three").Event>;
25
+ private defaultUp;
26
+ private turnRate;
27
+ private matrix;
28
+ set alignment(alignment: 'top-left' | 'top-right' | 'bottom-right' | 'bottom-left' | 'bottom-center' | 'center-right' | 'center-left' | 'center-center' | 'top-center');
29
+ set margin(margin: [number, number]);
30
+ set renderPriority(renderPriority: number);
31
+ set autoClear(autoClear: boolean);
32
+ updated: EventEmitter<void>;
33
+ gizmoHelperContent: TemplateRef<unknown>;
34
+ initialize(): void;
35
+ ngOnInit(): void;
36
+ onBeforeRender(delta: number): void;
37
+ private setGizmoPosition;
38
+ private updateDefaultUp;
39
+ static ɵfac: i0.ɵɵFactoryDeclaration<NgtsGizmoHelper, never>;
40
+ static ɵcmp: i0.ɵɵComponentDeclaration<NgtsGizmoHelper, "ngts-gizmo-helper", never, { "alignment": "alignment"; "margin": "margin"; "renderPriority": "renderPriority"; "autoClear": "autoClear"; }, { "updated": "updated"; }, ["gizmoHelperContent"], never, true, never>;
41
+ }
@@ -0,0 +1,12 @@
1
+ import * as THREE from 'three';
2
+ export declare const colors: {
3
+ bg: string;
4
+ hover: string;
5
+ text: string;
6
+ stroke: string;
7
+ };
8
+ export declare const defaultFaces: string[];
9
+ export declare const corners: THREE.Vector3[];
10
+ export declare const cornerDimensions: [number, number, number];
11
+ export declare const edges: THREE.Vector3[];
12
+ export declare const edgeDimensions: [number, number, number][];
@@ -0,0 +1,16 @@
1
+ import { NgtThreeEvent } from 'angular-three';
2
+ import { Vector3 } from 'three';
3
+ import { NgtsGizmoViewcubeInputs } from './gizmo-viewcube-inputs';
4
+ import * as i0 from "@angular/core";
5
+ export declare class NgtsGizmoViewcubeEdgeCube extends NgtsGizmoViewcubeInputs {
6
+ readonly gizmoHelperApi: import("../gizmo-helper").NgtsGizmoHelperApi;
7
+ hover: boolean;
8
+ set dimensions(dimensions: [number, number, number]);
9
+ set position(position: Vector3);
10
+ initialize(): void;
11
+ onPointerMove(event: NgtThreeEvent<PointerEvent>): void;
12
+ onPointerOut(event: NgtThreeEvent<PointerEvent>): void;
13
+ onClick(event: NgtThreeEvent<MouseEvent>): void;
14
+ static ɵfac: i0.ɵɵFactoryDeclaration<NgtsGizmoViewcubeEdgeCube, never>;
15
+ static ɵcmp: i0.ɵɵComponentDeclaration<NgtsGizmoViewcubeEdgeCube, "ngts-gizmo-viewcube-edge-cube[dimensions][position]", never, { "dimensions": "dimensions"; "position": "position"; }, {}, never, never, true, never>;
16
+ }
@@ -0,0 +1,24 @@
1
+ import { NgtThreeEvent } from 'angular-three';
2
+ import { NgtsGizmoViewcubeInputs } from './gizmo-viewcube-inputs';
3
+ import * as i0 from "@angular/core";
4
+ export declare class NgtsGizmoViewcubeFaceMaterial extends NgtsGizmoViewcubeInputs {
5
+ private readonly document;
6
+ set index(index: number);
7
+ set hover(hover: boolean);
8
+ set font(font: string);
9
+ set color(color: string);
10
+ initialize(): void;
11
+ static ɵfac: i0.ɵɵFactoryDeclaration<NgtsGizmoViewcubeFaceMaterial, never>;
12
+ static ɵcmp: i0.ɵɵComponentDeclaration<NgtsGizmoViewcubeFaceMaterial, "ngts-gizmo-viewcube-face-material[hover][index]", never, { "index": "index"; "hover": "hover"; "font": "font"; "color": "color"; }, {}, never, never, true, never>;
13
+ }
14
+ export declare class NgtsGizmoViewcubeFaceCube extends NgtsGizmoViewcubeInputs {
15
+ readonly gizmoHelperApi: import("../gizmo-helper").NgtsGizmoHelperApi;
16
+ set font(font: string);
17
+ set color(color: string);
18
+ hover: number;
19
+ onPointerMove(event: NgtThreeEvent<PointerEvent>): void;
20
+ onPointerOut(event: NgtThreeEvent<PointerEvent>): void;
21
+ onClick(event: NgtThreeEvent<MouseEvent>): void;
22
+ static ɵfac: i0.ɵɵFactoryDeclaration<NgtsGizmoViewcubeFaceCube, never>;
23
+ static ɵcmp: i0.ɵɵComponentDeclaration<NgtsGizmoViewcubeFaceCube, "ngts-gizmo-viewcube-face-cube", never, { "font": "font"; "color": "color"; }, {}, never, never, true, never>;
24
+ }
@@ -0,0 +1,14 @@
1
+ import { EventEmitter } from '@angular/core';
2
+ import { NgtRxStore, NgtStore, NgtThreeEvent } from 'angular-three';
3
+ import * as i0 from "@angular/core";
4
+ export declare abstract class NgtsGizmoViewcubeInputs extends NgtRxStore {
5
+ protected readonly store: NgtStore;
6
+ set opacity(opacity: number);
7
+ set hoverColor(hoverColor: string);
8
+ set textColor(textColor: string);
9
+ set strokeColor(strokeColor: string);
10
+ set faces(faces: string[]);
11
+ set clickEmitter(clickEmitter: EventEmitter<NgtThreeEvent<MouseEvent>>);
12
+ static ɵfac: i0.ɵɵFactoryDeclaration<NgtsGizmoViewcubeInputs, never>;
13
+ static ɵdir: i0.ɵɵDirectiveDeclaration<NgtsGizmoViewcubeInputs, never, never, { "opacity": "opacity"; "hoverColor": "hoverColor"; "textColor": "textColor"; "strokeColor": "strokeColor"; "faces": "faces"; "clickEmitter": "clickEmitter"; }, {}, never, never, false, never>;
14
+ }
@@ -0,0 +1,15 @@
1
+ import { EventEmitter } from '@angular/core';
2
+ import { NgtThreeEvent } from 'angular-three';
3
+ import { NgtsGizmoViewcubeInputs } from './gizmo-viewcube-inputs';
4
+ import * as i0 from "@angular/core";
5
+ export declare class NgtsGizmoViewcube extends NgtsGizmoViewcubeInputs {
6
+ readonly edges: import("three").Vector3[];
7
+ readonly edgeDimensions: [number, number, number][];
8
+ readonly corners: import("three").Vector3[];
9
+ readonly cornerDimensions: [number, number, number];
10
+ set font(font: string);
11
+ set color(color: string);
12
+ clicked: EventEmitter<NgtThreeEvent<MouseEvent>>;
13
+ static ɵfac: i0.ɵɵFactoryDeclaration<NgtsGizmoViewcube, never>;
14
+ static ɵcmp: i0.ɵɵComponentDeclaration<NgtsGizmoViewcube, "ngts-gizmo-viewcube", never, { "font": "font"; "color": "color"; }, { "clicked": "clicked"; }, never, never, true, never>;
15
+ }
@@ -0,0 +1,28 @@
1
+ import { EventEmitter } from '@angular/core';
2
+ import { NgtRxStore, NgtThreeEvent } from 'angular-three';
3
+ import * as i0 from "@angular/core";
4
+ export declare class NgtsGizmoViewportAxis extends NgtRxStore {
5
+ set color(color: string);
6
+ set rotation(rotation: [number, number, number]);
7
+ set scale(scale: [number, number, number]);
8
+ initialize(): void;
9
+ static ɵfac: i0.ɵɵFactoryDeclaration<NgtsGizmoViewportAxis, never>;
10
+ static ɵcmp: i0.ɵɵComponentDeclaration<NgtsGizmoViewportAxis, "ngts-gizmo-viewport-axis[color][rotation]", never, { "color": "color"; "rotation": "rotation"; "scale": "scale"; }, {}, never, never, true, never>;
11
+ }
12
+ export declare class NgtsGizmoViewportAxisHead extends NgtRxStore {
13
+ private readonly document;
14
+ private readonly store;
15
+ readonly gl: import("three").WebGLRenderer;
16
+ set arcStyle(arcStyle: string);
17
+ set label(label: string);
18
+ set labelColor(labelColor: string);
19
+ set axisHeadScale(axisHeadScale: number);
20
+ set disabled(disabled: boolean);
21
+ set font(font: string);
22
+ set clickEmitter(clickEmitter: EventEmitter<NgtThreeEvent<MouseEvent>>);
23
+ initialize(): void;
24
+ onPointerOver(event: NgtThreeEvent<PointerEvent>): void;
25
+ onPointerOut(event: NgtThreeEvent<PointerEvent>): void;
26
+ static ɵfac: i0.ɵɵFactoryDeclaration<NgtsGizmoViewportAxisHead, never>;
27
+ static ɵcmp: i0.ɵɵComponentDeclaration<NgtsGizmoViewportAxisHead, "ngts-gizmo-viewport-axis-head", never, { "arcStyle": "arcStyle"; "label": "label"; "labelColor": "labelColor"; "axisHeadScale": "axisHeadScale"; "disabled": "disabled"; "font": "font"; "clickEmitter": "clickEmitter"; }, {}, never, never, true, never>;
28
+ }
@@ -0,0 +1,21 @@
1
+ import { EventEmitter } from '@angular/core';
2
+ import { NgtRxStore, NgtThreeEvent } from 'angular-three';
3
+ import * as i0 from "@angular/core";
4
+ export declare class NgtsGizmoViewport extends NgtRxStore {
5
+ readonly gizmoHelperApi: import("../gizmo-helper").NgtsGizmoHelperApi;
6
+ readonly Math: Math;
7
+ set axisColors(axisColors: [string, string, string]);
8
+ set axisScale(axisScale: [number, number, number]);
9
+ set labels(labels: [string, string, string]);
10
+ set axisHeadScale(axisHeadScale: number);
11
+ set labelColor(labelColor: string);
12
+ set hideNegativeAxes(hideNegativeAxes: boolean);
13
+ set hideAxisHeads(hideAxisHeads: boolean);
14
+ set disabled(disabled: boolean);
15
+ set font(font: string);
16
+ clicked: EventEmitter<NgtThreeEvent<MouseEvent>>;
17
+ initialize(): void;
18
+ onPointerDown(event: NgtThreeEvent<PointerEvent>): void;
19
+ static ɵfac: i0.ɵɵFactoryDeclaration<NgtsGizmoViewport, never>;
20
+ static ɵcmp: i0.ɵɵComponentDeclaration<NgtsGizmoViewport, "ngts-gizmo-viewport", never, { "axisColors": "axisColors"; "axisScale": "axisScale"; "labels": "labels"; "axisHeadScale": "axisHeadScale"; "labelColor": "labelColor"; "hideNegativeAxes": "hideNegativeAxes"; "hideAxisHeads": "hideAxisHeads"; "disabled": "disabled"; "font": "font"; }, { "clicked": "clicked"; }, never, never, true, never>;
21
+ }
@@ -0,0 +1,21 @@
1
+ import { EventEmitter, OnDestroy, OnInit } from '@angular/core';
2
+ import { NgtRxStore } from 'angular-three';
3
+ import * as i0 from "@angular/core";
4
+ export declare class NgtsText extends NgtRxStore implements OnInit, OnDestroy {
5
+ textRef: import("angular-three").NgtInjectedRef<Text>;
6
+ set text(text: string);
7
+ set characters(characters: string);
8
+ set font(font: string);
9
+ set anchorX(anchorX: number | 'left' | 'center' | 'right');
10
+ set anchorY(anchorY: number | 'top' | 'top-baseline' | 'middle' | 'bottom-baseline' | 'bottom');
11
+ sync: EventEmitter<Text>;
12
+ initialize(): void;
13
+ private readonly store;
14
+ private readonly troikaText;
15
+ ngOnInit(): void;
16
+ ngOnDestroy(): void;
17
+ private preloadFont;
18
+ private syncText;
19
+ static ɵfac: i0.ɵɵFactoryDeclaration<NgtsText, never>;
20
+ static ɵcmp: i0.ɵɵComponentDeclaration<NgtsText, "ngts-text[text]", never, { "textRef": "textRef"; "text": "text"; "characters": "characters"; "font": "font"; "anchorX": "anchorX"; "anchorY": "anchorY"; }, { "sync": "sync"; }, never, ["*"], true, never>;
21
+ }
@@ -0,0 +1,39 @@
1
+ import { NgtRxStore } from 'angular-three';
2
+ import * as i0 from "@angular/core";
3
+ declare type Glyph = {
4
+ _cachedOutline: string[];
5
+ ha: number;
6
+ o: string;
7
+ };
8
+ declare type FontData = {
9
+ boundingBox: {
10
+ yMax: number;
11
+ yMin: number;
12
+ };
13
+ familyName: string;
14
+ glyphs: {
15
+ [k: string]: Glyph;
16
+ };
17
+ resolution: number;
18
+ underlineThickness: number;
19
+ };
20
+ export declare class NgtsText3D extends NgtRxStore {
21
+ set font(font: FontData | string);
22
+ set text(text: string);
23
+ set bevelEnabled(bevelEnabled: boolean);
24
+ set bevelOffset(bevelOffset: number);
25
+ set bevelSize(bevelSize: number);
26
+ set bevelThickness(bevelThickness: number);
27
+ set curveSegments(curveSegments: number);
28
+ set bevelSegments(bevelSegments: number);
29
+ set height(height: number);
30
+ set size(size: number);
31
+ set lineHeight(lineHeight: number);
32
+ set letterSpacing(letterSpacing: number);
33
+ initialize(): void;
34
+ private readonly font$;
35
+ readonly geometryArgs$: import("rxjs").Observable<any[]>;
36
+ static ɵfac: i0.ɵɵFactoryDeclaration<NgtsText3D, never>;
37
+ static ɵcmp: i0.ɵɵComponentDeclaration<NgtsText3D, "ngts-text-3d[font]", never, { "font": "font"; "text": "text"; "bevelEnabled": "bevelEnabled"; "bevelOffset": "bevelOffset"; "bevelSize": "bevelSize"; "bevelThickness": "bevelThickness"; "curveSegments": "curveSegments"; "bevelSegments": "bevelSegments"; "height": "height"; "size": "size"; "lineHeight": "lineHeight"; "letterSpacing": "letterSpacing"; }, {}, never, ["*"], true, never>;
38
+ }
39
+ export {};
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Generated bundle index. Do not edit.
3
+ */
4
+ export * from './index';
5
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYW5ndWxhci10aHJlZS1zb2JhLWFic3RyYWN0aW9ucy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL2xpYnMvYW5ndWxhci10aHJlZS1zb2JhL2Fic3RyYWN0aW9ucy9zcmMvYW5ndWxhci10aHJlZS1zb2JhLWFic3RyYWN0aW9ucy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsU0FBUyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBHZW5lcmF0ZWQgYnVuZGxlIGluZGV4LiBEbyBub3QgZWRpdC5cbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL2luZGV4JztcbiJdfQ==
@@ -0,0 +1,7 @@
1
+ export * from './lib/billboard/billboard';
2
+ export * from './lib/gizmo-helper/gizmo-helper';
3
+ export * from './lib/gizmo-helper/gizmo-viewcube/gizmo-viewcube';
4
+ export * from './lib/gizmo-helper/gizmo-viewport/gizmo-viewport';
5
+ export * from './lib/text-3d/text-3d';
6
+ export * from './lib/text/text';
7
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWJzL2FuZ3VsYXItdGhyZWUtc29iYS9hYnN0cmFjdGlvbnMvc3JjL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsMkJBQTJCLENBQUM7QUFDMUMsY0FBYyxpQ0FBaUMsQ0FBQztBQUNoRCxjQUFjLGtEQUFrRCxDQUFDO0FBQ2pFLGNBQWMsa0RBQWtELENBQUM7QUFDakUsY0FBYyx1QkFBdUIsQ0FBQztBQUN0QyxjQUFjLGlCQUFpQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9saWIvYmlsbGJvYXJkL2JpbGxib2FyZCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9naXptby1oZWxwZXIvZ2l6bW8taGVscGVyJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2dpem1vLWhlbHBlci9naXptby12aWV3Y3ViZS9naXptby12aWV3Y3ViZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9naXptby1oZWxwZXIvZ2l6bW8tdmlld3BvcnQvZ2l6bW8tdmlld3BvcnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvdGV4dC0zZC90ZXh0LTNkJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3RleHQvdGV4dCc7XG4iXX0=
@@ -0,0 +1,73 @@
1
+ import { Component, CUSTOM_ELEMENTS_SCHEMA, Input } from '@angular/core';
2
+ import { extend, injectNgtRef, NgtRxStore } from 'angular-three';
3
+ import { Group } from 'three';
4
+ import * as i0 from "@angular/core";
5
+ extend({ Group });
6
+ export class NgtsBillboard extends NgtRxStore {
7
+ constructor() {
8
+ super(...arguments);
9
+ this.billboardRef = injectNgtRef();
10
+ }
11
+ set follow(follow) {
12
+ this.set({ follow });
13
+ }
14
+ set lockX(lockX) {
15
+ this.set({ lockX });
16
+ }
17
+ set lockY(lockY) {
18
+ this.set({ lockY });
19
+ }
20
+ set lockZ(lockZ) {
21
+ this.set({ lockZ });
22
+ }
23
+ initialize() {
24
+ super.initialize();
25
+ this.set({ follow: true, lockX: false, lockY: false, lockZ: false });
26
+ }
27
+ onBeforeRender(event) {
28
+ const { follow, lockX, lockY, lockZ } = this.get();
29
+ if (!follow)
30
+ return;
31
+ // save prev rotation in case we're locking axises
32
+ const prevRotation = event.object.rotation.clone();
33
+ // always face the camera
34
+ event.object.quaternion.copy(event.state.camera.quaternion);
35
+ // readjust any axis that is locked
36
+ if (lockX)
37
+ event.object.rotation.x = prevRotation.x;
38
+ if (lockY)
39
+ event.object.rotation.y = prevRotation.y;
40
+ if (lockZ)
41
+ event.object.rotation.z = prevRotation.z;
42
+ }
43
+ }
44
+ NgtsBillboard.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.3", ngImport: i0, type: NgtsBillboard, deps: null, target: i0.ɵɵFactoryTarget.Component });
45
+ NgtsBillboard.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.1.3", type: NgtsBillboard, isStandalone: true, selector: "ngts-billboard", inputs: { billboardRef: "billboardRef", follow: "follow", lockX: "lockX", lockY: "lockY", lockZ: "lockZ" }, usesInheritance: true, ngImport: i0, template: `
46
+ <ngt-group ngtCompound [ref]="billboardRef" (beforeRender)="onBeforeRender($any($event))">
47
+ <ng-content />
48
+ </ngt-group>
49
+ `, isInline: true });
50
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.3", ngImport: i0, type: NgtsBillboard, decorators: [{
51
+ type: Component,
52
+ args: [{
53
+ selector: 'ngts-billboard',
54
+ standalone: true,
55
+ template: `
56
+ <ngt-group ngtCompound [ref]="billboardRef" (beforeRender)="onBeforeRender($any($event))">
57
+ <ng-content />
58
+ </ngt-group>
59
+ `,
60
+ schemas: [CUSTOM_ELEMENTS_SCHEMA],
61
+ }]
62
+ }], propDecorators: { billboardRef: [{
63
+ type: Input
64
+ }], follow: [{
65
+ type: Input
66
+ }], lockX: [{
67
+ type: Input
68
+ }], lockY: [{
69
+ type: Input
70
+ }], lockZ: [{
71
+ type: Input
72
+ }] } });
73
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmlsbGJvYXJkLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9hbmd1bGFyLXRocmVlLXNvYmEvYWJzdHJhY3Rpb25zL3NyYy9saWIvYmlsbGJvYXJkL2JpbGxib2FyZC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLHNCQUFzQixFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6RSxPQUFPLEVBQUUsTUFBTSxFQUFFLFlBQVksRUFBd0IsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3ZGLE9BQU8sRUFBRSxLQUFLLEVBQUUsTUFBTSxPQUFPLENBQUM7O0FBRTlCLE1BQU0sQ0FBQyxFQUFFLEtBQUssRUFBRSxDQUFDLENBQUM7QUFZbEIsTUFBTSxPQUFPLGFBQWMsU0FBUSxVQUFVO0lBVjdDOztRQVdhLGlCQUFZLEdBQUcsWUFBWSxFQUFTLENBQUM7S0FpQ2pEO0lBL0JHLElBQWEsTUFBTSxDQUFDLE1BQWU7UUFDL0IsSUFBSSxDQUFDLEdBQUcsQ0FBQyxFQUFFLE1BQU0sRUFBRSxDQUFDLENBQUM7SUFDekIsQ0FBQztJQUNELElBQWEsS0FBSyxDQUFDLEtBQWM7UUFDN0IsSUFBSSxDQUFDLEdBQUcsQ0FBQyxFQUFFLEtBQUssRUFBRSxDQUFDLENBQUM7SUFDeEIsQ0FBQztJQUNELElBQWEsS0FBSyxDQUFDLEtBQWM7UUFDN0IsSUFBSSxDQUFDLEdBQUcsQ0FBQyxFQUFFLEtBQUssRUFBRSxDQUFDLENBQUM7SUFDeEIsQ0FBQztJQUNELElBQWEsS0FBSyxDQUFDLEtBQWM7UUFDN0IsSUFBSSxDQUFDLEdBQUcsQ0FBQyxFQUFFLEtBQUssRUFBRSxDQUFDLENBQUM7SUFDeEIsQ0FBQztJQUVRLFVBQVU7UUFDZixLQUFLLENBQUMsVUFBVSxFQUFFLENBQUM7UUFDbkIsSUFBSSxDQUFDLEdBQUcsQ0FBQyxFQUFFLE1BQU0sRUFBRSxJQUFJLEVBQUUsS0FBSyxFQUFFLEtBQUssRUFBRSxLQUFLLEVBQUUsS0FBSyxFQUFFLEtBQUssRUFBRSxLQUFLLEVBQUUsQ0FBQyxDQUFDO0lBQ3pFLENBQUM7SUFFRCxjQUFjLENBQUMsS0FBa0M7UUFDN0MsTUFBTSxFQUFFLE1BQU0sRUFBRSxLQUFLLEVBQUUsS0FBSyxFQUFFLEtBQUssRUFBRSxHQUFHLElBQUksQ0FBQyxHQUFHLEVBQUUsQ0FBQztRQUNuRCxJQUFJLENBQUMsTUFBTTtZQUFFLE9BQU87UUFFcEIsa0RBQWtEO1FBQ2xELE1BQU0sWUFBWSxHQUFHLEtBQUssQ0FBQyxNQUFNLENBQUMsUUFBUSxDQUFDLEtBQUssRUFBRSxDQUFDO1FBQ25ELHlCQUF5QjtRQUN6QixLQUFLLENBQUMsTUFBTSxDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLEtBQUssQ0FBQyxNQUFNLENBQUMsVUFBVSxDQUFDLENBQUM7UUFDNUQsbUNBQW1DO1FBQ25DLElBQUksS0FBSztZQUFFLEtBQUssQ0FBQyxNQUFNLENBQUMsUUFBUSxDQUFDLENBQUMsR0FBRyxZQUFZLENBQUMsQ0FBQyxDQUFDO1FBQ3BELElBQUksS0FBSztZQUFFLEtBQUssQ0FBQyxNQUFNLENBQUMsUUFBUSxDQUFDLENBQUMsR0FBRyxZQUFZLENBQUMsQ0FBQyxDQUFDO1FBQ3BELElBQUksS0FBSztZQUFFLEtBQUssQ0FBQyxNQUFNLENBQUMsUUFBUSxDQUFDLENBQUMsR0FBRyxZQUFZLENBQUMsQ0FBQyxDQUFDO0lBQ3hELENBQUM7OzBHQWpDUSxhQUFhOzhGQUFiLGFBQWEsNk1BUFo7Ozs7S0FJVDsyRkFHUSxhQUFhO2tCQVZ6QixTQUFTO21CQUFDO29CQUNQLFFBQVEsRUFBRSxnQkFBZ0I7b0JBQzFCLFVBQVUsRUFBRSxJQUFJO29CQUNoQixRQUFRLEVBQUU7Ozs7S0FJVDtvQkFDRCxPQUFPLEVBQUUsQ0FBQyxzQkFBc0IsQ0FBQztpQkFDcEM7OEJBRVksWUFBWTtzQkFBcEIsS0FBSztnQkFFTyxNQUFNO3NCQUFsQixLQUFLO2dCQUdPLEtBQUs7c0JBQWpCLEtBQUs7Z0JBR08sS0FBSztzQkFBakIsS0FBSztnQkFHTyxLQUFLO3NCQUFqQixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBDVVNUT01fRUxFTUVOVFNfU0NIRU1BLCBJbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgZXh0ZW5kLCBpbmplY3ROZ3RSZWYsIE5ndEJlZm9yZVJlbmRlckV2ZW50LCBOZ3RSeFN0b3JlIH0gZnJvbSAnYW5ndWxhci10aHJlZSc7XG5pbXBvcnQgeyBHcm91cCB9IGZyb20gJ3RocmVlJztcblxuZXh0ZW5kKHsgR3JvdXAgfSk7XG5cbkBDb21wb25lbnQoe1xuICAgIHNlbGVjdG9yOiAnbmd0cy1iaWxsYm9hcmQnLFxuICAgIHN0YW5kYWxvbmU6IHRydWUsXG4gICAgdGVtcGxhdGU6IGBcbiAgICAgICAgPG5ndC1ncm91cCBuZ3RDb21wb3VuZCBbcmVmXT1cImJpbGxib2FyZFJlZlwiIChiZWZvcmVSZW5kZXIpPVwib25CZWZvcmVSZW5kZXIoJGFueSgkZXZlbnQpKVwiPlxuICAgICAgICAgICAgPG5nLWNvbnRlbnQgLz5cbiAgICAgICAgPC9uZ3QtZ3JvdXA+XG4gICAgYCxcbiAgICBzY2hlbWFzOiBbQ1VTVE9NX0VMRU1FTlRTX1NDSEVNQV0sXG59KVxuZXhwb3J0IGNsYXNzIE5ndHNCaWxsYm9hcmQgZXh0ZW5kcyBOZ3RSeFN0b3JlIHtcbiAgICBASW5wdXQoKSBiaWxsYm9hcmRSZWYgPSBpbmplY3ROZ3RSZWY8R3JvdXA+KCk7XG5cbiAgICBASW5wdXQoKSBzZXQgZm9sbG93KGZvbGxvdzogYm9vbGVhbikge1xuICAgICAgICB0aGlzLnNldCh7IGZvbGxvdyB9KTtcbiAgICB9XG4gICAgQElucHV0KCkgc2V0IGxvY2tYKGxvY2tYOiBib29sZWFuKSB7XG4gICAgICAgIHRoaXMuc2V0KHsgbG9ja1ggfSk7XG4gICAgfVxuICAgIEBJbnB1dCgpIHNldCBsb2NrWShsb2NrWTogYm9vbGVhbikge1xuICAgICAgICB0aGlzLnNldCh7IGxvY2tZIH0pO1xuICAgIH1cbiAgICBASW5wdXQoKSBzZXQgbG9ja1oobG9ja1o6IGJvb2xlYW4pIHtcbiAgICAgICAgdGhpcy5zZXQoeyBsb2NrWiB9KTtcbiAgICB9XG5cbiAgICBvdmVycmlkZSBpbml0aWFsaXplKCkge1xuICAgICAgICBzdXBlci5pbml0aWFsaXplKCk7XG4gICAgICAgIHRoaXMuc2V0KHsgZm9sbG93OiB0cnVlLCBsb2NrWDogZmFsc2UsIGxvY2tZOiBmYWxzZSwgbG9ja1o6IGZhbHNlIH0pO1xuICAgIH1cblxuICAgIG9uQmVmb3JlUmVuZGVyKGV2ZW50OiBOZ3RCZWZvcmVSZW5kZXJFdmVudDxHcm91cD4pIHtcbiAgICAgICAgY29uc3QgeyBmb2xsb3csIGxvY2tYLCBsb2NrWSwgbG9ja1ogfSA9IHRoaXMuZ2V0KCk7XG4gICAgICAgIGlmICghZm9sbG93KSByZXR1cm47XG5cbiAgICAgICAgLy8gc2F2ZSBwcmV2IHJvdGF0aW9uIGluIGNhc2Ugd2UncmUgbG9ja2luZyBheGlzZXNcbiAgICAgICAgY29uc3QgcHJldlJvdGF0aW9uID0gZXZlbnQub2JqZWN0LnJvdGF0aW9uLmNsb25lKCk7XG4gICAgICAgIC8vIGFsd2F5cyBmYWNlIHRoZSBjYW1lcmFcbiAgICAgICAgZXZlbnQub2JqZWN0LnF1YXRlcm5pb24uY29weShldmVudC5zdGF0ZS5jYW1lcmEucXVhdGVybmlvbik7XG4gICAgICAgIC8vIHJlYWRqdXN0IGFueSBheGlzIHRoYXQgaXMgbG9ja2VkXG4gICAgICAgIGlmIChsb2NrWCkgZXZlbnQub2JqZWN0LnJvdGF0aW9uLnggPSBwcmV2Um90YXRpb24ueDtcbiAgICAgICAgaWYgKGxvY2tZKSBldmVudC5vYmplY3Qucm90YXRpb24ueSA9IHByZXZSb3RhdGlvbi55O1xuICAgICAgICBpZiAobG9ja1opIGV2ZW50Lm9iamVjdC5yb3RhdGlvbi56ID0gcHJldlJvdGF0aW9uLno7XG4gICAgfVxufVxuIl19
@@ -0,0 +1,206 @@
1
+ import { NgTemplateOutlet } from '@angular/common';
2
+ import { Component, ContentChild, CUSTOM_ELEMENTS_SCHEMA, Directive, EventEmitter, inject, InjectionToken, Input, Output, TemplateRef, } from '@angular/core';
3
+ import { selectSlice } from '@rx-angular/state';
4
+ import { extend, injectNgtRef, NgtPortal, NgtPortalContent, NgtRxStore, NgtStore } from 'angular-three';
5
+ import { NgtsOrthographicCamera } from 'angular-three-soba/cameras';
6
+ import { combineLatest, map } from 'rxjs';
7
+ import { Group, Matrix4, Object3D, Quaternion, Vector3 } from 'three';
8
+ import * as i0 from "@angular/core";
9
+ const isOrbitControls = (controls) => {
10
+ return 'minPolarAngle' in controls;
11
+ };
12
+ export const NGTS_GIZMO_HELPER_API = new InjectionToken('NgtsGizmoHelper API');
13
+ function gizmoHelperApiFactory(gizmo) {
14
+ const store = inject(NgtStore);
15
+ return {
16
+ tweenCamera: (direction) => {
17
+ const { controls, camera, invalidate } = store.get();
18
+ const defaultControls = controls;
19
+ gizmo.animating = true;
20
+ if (defaultControls)
21
+ gizmo.focusPoint = defaultControls.target;
22
+ gizmo.radius = camera.position.distanceTo(gizmo.target);
23
+ // rotate from current camera orientation
24
+ gizmo.q1.copy(camera.quaternion);
25
+ // to new current camera orientation
26
+ gizmo.targetPosition.copy(direction).multiplyScalar(gizmo.radius).add(gizmo.target);
27
+ gizmo.dummy.lookAt(gizmo.targetPosition);
28
+ gizmo.q2.copy(gizmo.dummy.quaternion);
29
+ invalidate();
30
+ },
31
+ };
32
+ }
33
+ extend({ Group });
34
+ export class NgtsGizmoHelperContent {
35
+ }
36
+ NgtsGizmoHelperContent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.3", ngImport: i0, type: NgtsGizmoHelperContent, deps: [], target: i0.ɵɵFactoryTarget.Directive });
37
+ NgtsGizmoHelperContent.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.1.3", type: NgtsGizmoHelperContent, isStandalone: true, selector: "ng-template[ngtsGizmoHelperContent]", ngImport: i0 });
38
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.3", ngImport: i0, type: NgtsGizmoHelperContent, decorators: [{
39
+ type: Directive,
40
+ args: [{
41
+ selector: 'ng-template[ngtsGizmoHelperContent]',
42
+ standalone: true,
43
+ }]
44
+ }] });
45
+ export class NgtsGizmoHelper extends NgtRxStore {
46
+ constructor() {
47
+ super(...arguments);
48
+ this.store = inject(NgtStore);
49
+ this.gizmoRef = injectNgtRef();
50
+ this.virtualCameraRef = injectNgtRef();
51
+ this.animating = false;
52
+ this.radius = 0;
53
+ this.focusPoint = new Vector3(0, 0, 0);
54
+ this.q1 = new Quaternion();
55
+ this.q2 = new Quaternion();
56
+ this.target = new Vector3();
57
+ this.targetPosition = new Vector3();
58
+ this.dummy = new Object3D();
59
+ this.defaultUp = new Vector3(0, 0, 0);
60
+ this.turnRate = 2 * Math.PI; // turn rate in angles per sec
61
+ this.matrix = new Matrix4();
62
+ this.updated = new EventEmitter();
63
+ }
64
+ set alignment(alignment) {
65
+ this.set({ alignment });
66
+ }
67
+ set margin(margin) {
68
+ this.set({ margin });
69
+ }
70
+ set renderPriority(renderPriority) {
71
+ this.set({ renderPriority });
72
+ }
73
+ set autoClear(autoClear) {
74
+ this.set({ autoClear });
75
+ }
76
+ initialize() {
77
+ super.initialize();
78
+ this.set({ alignment: 'bottom-right', margin: [80, 80], renderPriority: 1 });
79
+ }
80
+ ngOnInit() {
81
+ this.updateDefaultUp();
82
+ this.setGizmoPosition();
83
+ }
84
+ onBeforeRender(delta) {
85
+ if (this.virtualCameraRef.nativeElement && this.gizmoRef.nativeElement) {
86
+ const { controls, camera: mainCamera, invalidate } = this.store.get();
87
+ const defaultControls = controls;
88
+ // Animate step
89
+ if (this.animating) {
90
+ if (this.q1.angleTo(this.q2) < 0.01) {
91
+ this.animating = false;
92
+ // Orbit controls uses UP vector as the orbit axes,
93
+ // so we need to reset it after the animation is done
94
+ // moving it around for the controls to work correctly
95
+ if (isOrbitControls(defaultControls)) {
96
+ mainCamera.up.copy(this.defaultUp);
97
+ }
98
+ }
99
+ else {
100
+ const step = delta * this.turnRate;
101
+ // animate position by doing a slerp and then scaling the position on the unit sphere
102
+ this.q1.rotateTowards(this.q2, step);
103
+ // animate orientation
104
+ mainCamera.position
105
+ .set(0, 0, 1)
106
+ .applyQuaternion(this.q1)
107
+ .multiplyScalar(this.radius)
108
+ .add(this.focusPoint);
109
+ mainCamera.up.set(0, 1, 0).applyQuaternion(this.q1).normalize();
110
+ mainCamera.quaternion.copy(this.q1);
111
+ if (this.updated.observed)
112
+ this.updated.emit();
113
+ else if (defaultControls) {
114
+ defaultControls.update();
115
+ }
116
+ invalidate();
117
+ }
118
+ }
119
+ // Sync Gizmo with main camera orientation
120
+ this.matrix.copy(mainCamera.matrix).invert();
121
+ this.gizmoRef.nativeElement.quaternion.setFromRotationMatrix(this.matrix);
122
+ }
123
+ }
124
+ setGizmoPosition() {
125
+ this.connect('gizmoPosition', combineLatest([this.store.select('size'), this.select(selectSlice(['alignment', 'margin']))]).pipe(map(([size, { alignment, margin }]) => {
126
+ const [marginX, marginY] = margin;
127
+ const x = alignment.endsWith('-center')
128
+ ? 0
129
+ : alignment.endsWith('-left')
130
+ ? -size.width / 2 + marginX
131
+ : size.width / 2 - marginX;
132
+ const y = alignment.startsWith('center-')
133
+ ? 0
134
+ : alignment.startsWith('top-')
135
+ ? size.height / 2 - marginY
136
+ : -size.height / 2 + marginY;
137
+ return [x, y, 0];
138
+ })));
139
+ }
140
+ updateDefaultUp() {
141
+ this.hold(this.store.select('camera'), (camera) => {
142
+ this.defaultUp.copy(camera.up);
143
+ });
144
+ }
145
+ }
146
+ NgtsGizmoHelper.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.3", ngImport: i0, type: NgtsGizmoHelper, deps: null, target: i0.ɵɵFactoryTarget.Component });
147
+ NgtsGizmoHelper.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.1.3", type: NgtsGizmoHelper, isStandalone: true, selector: "ngts-gizmo-helper", inputs: { alignment: "alignment", margin: "margin", renderPriority: "renderPriority", autoClear: "autoClear" }, outputs: { updated: "updated" }, providers: [{ provide: NGTS_GIZMO_HELPER_API, useFactory: gizmoHelperApiFactory, deps: [NgtsGizmoHelper] }], queries: [{ propertyName: "gizmoHelperContent", first: true, predicate: NgtsGizmoHelperContent, descendants: true, read: TemplateRef, static: true }], usesInheritance: true, ngImport: i0, template: `
148
+ <ngt-portal [renderPriority]="get('renderPriority')">
149
+ <ng-template ngtPortalContent>
150
+ <ngts-orthographic-camera
151
+ [cameraRef]="virtualCameraRef"
152
+ [makeDefault]="true"
153
+ [position]="[0, 0, 200]"
154
+ />
155
+ <ngt-group
156
+ [ref]="gizmoRef"
157
+ [position]="get('gizmoPosition')"
158
+ (beforeRender)="onBeforeRender($any($event).state.delta)"
159
+ >
160
+ <ng-container *ngTemplateOutlet="gizmoHelperContent" />
161
+ </ngt-group>
162
+ </ng-template>
163
+ </ngt-portal>
164
+ `, isInline: true, dependencies: [{ kind: "component", type: NgtPortal, selector: "ngt-portal", inputs: ["container", "state", "autoRender", "autoRenderPriority"], outputs: ["beforeRender"] }, { kind: "directive", type: NgtPortalContent, selector: "ng-template[ngtPortalContent]" }, { kind: "component", type: NgtsOrthographicCamera, selector: "ngts-orthographic-camera", inputs: ["left", "right", "top", "bottom"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }] });
165
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.3", ngImport: i0, type: NgtsGizmoHelper, decorators: [{
166
+ type: Component,
167
+ args: [{
168
+ selector: 'ngts-gizmo-helper',
169
+ standalone: true,
170
+ template: `
171
+ <ngt-portal [renderPriority]="get('renderPriority')">
172
+ <ng-template ngtPortalContent>
173
+ <ngts-orthographic-camera
174
+ [cameraRef]="virtualCameraRef"
175
+ [makeDefault]="true"
176
+ [position]="[0, 0, 200]"
177
+ />
178
+ <ngt-group
179
+ [ref]="gizmoRef"
180
+ [position]="get('gizmoPosition')"
181
+ (beforeRender)="onBeforeRender($any($event).state.delta)"
182
+ >
183
+ <ng-container *ngTemplateOutlet="gizmoHelperContent" />
184
+ </ngt-group>
185
+ </ng-template>
186
+ </ngt-portal>
187
+ `,
188
+ imports: [NgtPortal, NgtPortalContent, NgtsOrthographicCamera, NgTemplateOutlet],
189
+ providers: [{ provide: NGTS_GIZMO_HELPER_API, useFactory: gizmoHelperApiFactory, deps: [NgtsGizmoHelper] }],
190
+ schemas: [CUSTOM_ELEMENTS_SCHEMA],
191
+ }]
192
+ }], propDecorators: { alignment: [{
193
+ type: Input
194
+ }], margin: [{
195
+ type: Input
196
+ }], renderPriority: [{
197
+ type: Input
198
+ }], autoClear: [{
199
+ type: Input
200
+ }], updated: [{
201
+ type: Output
202
+ }], gizmoHelperContent: [{
203
+ type: ContentChild,
204
+ args: [NgtsGizmoHelperContent, { static: true, read: TemplateRef }]
205
+ }] } });
206
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gizmo-helper.js","sourceRoot":"","sources":["../../../../../../../libs/angular-three-soba/abstractions/src/lib/gizmo-helper/gizmo-helper.ts"],"names":[],"mappings":"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","sourcesContent":["import { NgTemplateOutlet } from '@angular/common';\nimport {\n    Component,\n    ContentChild,\n    CUSTOM_ELEMENTS_SCHEMA,\n    Directive,\n    EventEmitter,\n    inject,\n    InjectionToken,\n    Input,\n    OnInit,\n    Output,\n    TemplateRef,\n} from '@angular/core';\nimport { selectSlice } from '@rx-angular/state';\nimport { extend, injectNgtRef, NgtPortal, NgtPortalContent, NgtRxStore, NgtStore } from 'angular-three';\nimport { NgtsOrthographicCamera } from 'angular-three-soba/cameras';\nimport { combineLatest, map } from 'rxjs';\nimport { Group, Matrix4, Object3D, OrthographicCamera, Quaternion, Vector3 } from 'three';\nimport { OrbitControls } from 'three-stdlib';\n\ntype ControlsProto = { update(): void; target: THREE.Vector3 };\n\nconst isOrbitControls = (controls: ControlsProto): controls is OrbitControls => {\n    return 'minPolarAngle' in (controls as OrbitControls);\n};\n\nexport interface NgtsGizmoHelperApi {\n    tweenCamera: (direction: Vector3) => void;\n}\n\nexport const NGTS_GIZMO_HELPER_API = new InjectionToken<NgtsGizmoHelperApi>('NgtsGizmoHelper API');\n\nfunction gizmoHelperApiFactory(gizmo: NgtsGizmoHelper) {\n    const store = inject(NgtStore);\n\n    return {\n        tweenCamera: (direction: Vector3) => {\n            const { controls, camera, invalidate } = store.get();\n            const defaultControls = controls as unknown as ControlsProto;\n\n            gizmo.animating = true;\n            if (defaultControls) gizmo.focusPoint = defaultControls.target;\n            gizmo.radius = camera.position.distanceTo(gizmo.target);\n            // rotate from current camera orientation\n            gizmo.q1.copy(camera.quaternion);\n            // to new current camera orientation\n            gizmo.targetPosition.copy(direction).multiplyScalar(gizmo.radius).add(gizmo.target);\n            gizmo.dummy.lookAt(gizmo.targetPosition);\n            gizmo.q2.copy(gizmo.dummy.quaternion);\n            invalidate();\n        },\n    };\n}\n\nextend({ Group });\n\n@Directive({\n    selector: 'ng-template[ngtsGizmoHelperContent]',\n    standalone: true,\n})\nexport class NgtsGizmoHelperContent {}\n\n@Component({\n    selector: 'ngts-gizmo-helper',\n    standalone: true,\n    template: `\n        <ngt-portal [renderPriority]=\"get('renderPriority')\">\n            <ng-template ngtPortalContent>\n                <ngts-orthographic-camera\n                    [cameraRef]=\"virtualCameraRef\"\n                    [makeDefault]=\"true\"\n                    [position]=\"[0, 0, 200]\"\n                />\n                <ngt-group\n                    [ref]=\"gizmoRef\"\n                    [position]=\"get('gizmoPosition')\"\n                    (beforeRender)=\"onBeforeRender($any($event).state.delta)\"\n                >\n                    <ng-container *ngTemplateOutlet=\"gizmoHelperContent\" />\n                </ngt-group>\n            </ng-template>\n        </ngt-portal>\n    `,\n    imports: [NgtPortal, NgtPortalContent, NgtsOrthographicCamera, NgTemplateOutlet],\n    providers: [{ provide: NGTS_GIZMO_HELPER_API, useFactory: gizmoHelperApiFactory, deps: [NgtsGizmoHelper] }],\n    schemas: [CUSTOM_ELEMENTS_SCHEMA],\n})\nexport class NgtsGizmoHelper extends NgtRxStore implements OnInit {\n    private readonly store = inject(NgtStore);\n\n    readonly gizmoRef = injectNgtRef<Group>();\n    readonly virtualCameraRef = injectNgtRef<OrthographicCamera>();\n\n    animating = false;\n    radius = 0;\n    focusPoint = new Vector3(0, 0, 0);\n    q1 = new Quaternion();\n    q2 = new Quaternion();\n\n    target = new Vector3();\n    targetPosition = new Vector3();\n    dummy = new Object3D();\n\n    private defaultUp = new Vector3(0, 0, 0);\n    private turnRate = 2 * Math.PI; // turn rate in angles per sec\n    private matrix = new Matrix4();\n\n    @Input() set alignment(\n        alignment:\n            | 'top-left'\n            | 'top-right'\n            | 'bottom-right'\n            | 'bottom-left'\n            | 'bottom-center'\n            | 'center-right'\n            | 'center-left'\n            | 'center-center'\n            | 'top-center'\n    ) {\n        this.set({ alignment });\n    }\n\n    @Input() set margin(margin: [number, number]) {\n        this.set({ margin });\n    }\n\n    @Input() set renderPriority(renderPriority: number) {\n        this.set({ renderPriority });\n    }\n\n    @Input() set autoClear(autoClear: boolean) {\n        this.set({ autoClear });\n    }\n\n    @Output() updated = new EventEmitter<void>();\n\n    @ContentChild(NgtsGizmoHelperContent, { static: true, read: TemplateRef })\n    gizmoHelperContent!: TemplateRef<unknown>;\n\n    override initialize(): void {\n        super.initialize();\n        this.set({ alignment: 'bottom-right', margin: [80, 80], renderPriority: 1 });\n    }\n\n    ngOnInit() {\n        this.updateDefaultUp();\n        this.setGizmoPosition();\n    }\n\n    onBeforeRender(delta: number) {\n        if (this.virtualCameraRef.nativeElement && this.gizmoRef.nativeElement) {\n            const { controls, camera: mainCamera, invalidate } = this.store.get();\n            const defaultControls = controls as unknown as ControlsProto;\n            // Animate step\n            if (this.animating) {\n                if (this.q1.angleTo(this.q2) < 0.01) {\n                    this.animating = false;\n                    // Orbit controls uses UP vector as the orbit axes,\n                    // so we need to reset it after the animation is done\n                    // moving it around for the controls to work correctly\n                    if (isOrbitControls(defaultControls)) {\n                        mainCamera.up.copy(this.defaultUp);\n                    }\n                } else {\n                    const step = delta * this.turnRate;\n                    // animate position by doing a slerp and then scaling the position on the unit sphere\n                    this.q1.rotateTowards(this.q2, step);\n                    // animate orientation\n                    mainCamera.position\n                        .set(0, 0, 1)\n                        .applyQuaternion(this.q1)\n                        .multiplyScalar(this.radius)\n                        .add(this.focusPoint);\n                    mainCamera.up.set(0, 1, 0).applyQuaternion(this.q1).normalize();\n                    mainCamera.quaternion.copy(this.q1);\n                    if (this.updated.observed) this.updated.emit();\n                    else if (defaultControls) {\n                        defaultControls.update();\n                    }\n                    invalidate();\n                }\n            }\n\n            // Sync Gizmo with main camera orientation\n            this.matrix.copy(mainCamera.matrix).invert();\n            this.gizmoRef.nativeElement.quaternion.setFromRotationMatrix(this.matrix);\n        }\n    }\n\n    private setGizmoPosition() {\n        this.connect(\n            'gizmoPosition',\n            combineLatest([this.store.select('size'), this.select(selectSlice(['alignment', 'margin']))]).pipe(\n                map(([size, { alignment, margin }]) => {\n                    const [marginX, marginY] = margin;\n                    const x = alignment.endsWith('-center')\n                        ? 0\n                        : alignment.endsWith('-left')\n                        ? -size.width / 2 + marginX\n                        : size.width / 2 - marginX;\n                    const y = alignment.startsWith('center-')\n                        ? 0\n                        : alignment.startsWith('top-')\n                        ? size.height / 2 - marginY\n                        : -size.height / 2 + marginY;\n                    return [x, y, 0];\n                })\n            )\n        );\n    }\n\n    private updateDefaultUp() {\n        this.hold(this.store.select('camera'), (camera) => {\n            this.defaultUp.copy(camera.up);\n        });\n    }\n}\n"]}