angular-three 2.5.1 → 2.6.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/esm2022/lib/canvas.mjs +3 -3
- package/esm2022/lib/directives/args.mjs +3 -3
- package/esm2022/lib/directives/selection.mjs +6 -6
- package/esm2022/lib/html.mjs +9 -8
- package/esm2022/lib/instance.mjs +2 -2
- package/esm2022/lib/pipes/hexify.mjs +3 -3
- package/esm2022/lib/portal.mjs +9 -9
- package/esm2022/lib/renderer/constants.mjs +2 -1
- package/esm2022/lib/renderer/index.mjs +17 -28
- package/esm2022/lib/routed-scene.mjs +3 -3
- package/esm2022/lib/three-types.mjs +1 -1
- package/esm2022/lib/types.mjs +1 -1
- package/esm2022/lib/utils/object-events.mjs +24 -4
- package/esm2022/nativescript/lib/canvas.mjs +3 -3
- package/esm2022/testing/lib/test-canvas.mjs +3 -3
- package/fesm2022/angular-three-nativescript.mjs +3 -3
- package/fesm2022/angular-three-testing.mjs +3 -3
- package/fesm2022/angular-three.mjs +75 -64
- package/fesm2022/angular-three.mjs.map +1 -1
- package/lib/canvas.d.ts +42 -42
- package/lib/renderer/constants.d.ts +1 -0
- package/lib/three-types.d.ts +5 -1
- package/lib/types.d.ts +3 -3
- package/lib/utils/object-events.d.ts +6 -0
- package/metadata.json +1 -1
- package/nativescript/lib/canvas.d.ts +12 -12
- package/package.json +1 -1
- package/web-types.json +1 -1
package/esm2022/lib/types.mjs
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../../../libs/core/src/lib/types.ts"],"names":[],"mappings":"","sourcesContent":["import { ElementRef, Signal } from '@angular/core';\nimport { Observable } from 'rxjs';\nimport {\n\tCamera,\n\tClock,\n\tEventDispatcher,\n\tIntersection,\n\tObject3D,\n\tOrthographicCamera,\n\tPerspectiveCamera,\n\tRay,\n\tRaycaster,\n\tScene,\n\tVector2,\n\tVector3,\n\tWebGLRenderer,\n\tWebGLRendererParameters,\n\tWebGLShadowMap,\n} from 'three';\nimport { NgtObject3DNode } from './three-types';\nimport { NgtSignalStore } from './utils/signal-store';\n\nexport type NgtProperties<T> = Pick<T, { [K in keyof T]: T[K] extends (_: any) => any ? never : K }[keyof T]>;\nexport type NgtAnyRecord = Record<string, any>;\n\nexport type NgtEquConfig = {\n\t/** Compare arrays by reference equality a === b (default), or by shallow equality */\n\tarrays?: 'reference' | 'shallow';\n\t/** Compare objects by reference equality a === b (default), or by shallow equality */\n\tobjects?: 'reference' | 'shallow';\n\t/** If true the keys in both a and b must match 1:1 (default), if false a's keys must intersect b's */\n\tstrict?: boolean;\n};\n\nexport type NgtGLOptions =\n\t| NgtRendererLike\n\t| ((canvas: NgtCanvasElement) => NgtRendererLike)\n\t| Partial<NgtProperties<WebGLRenderer> | WebGLRendererParameters>\n\t| undefined;\n\nexport interface NgtCanvasOptions {\n\t/** A threejs renderer instance or props that go into the default renderer */\n\tgl?: NgtGLOptions;\n\t/** Dimensions to fit the renderer to. Will measure canvas dimensions if omitted */\n\tsize?: NgtSize;\n\t/**\n\t * Enables shadows (by default PCFsoft). Can accept `gl.shadowMap` options for fine-tuning,\n\t * but also strings: 'basic' | 'percentage' | 'soft' | 'variance'.\n\t * @see https://threejs.org/docs/#api/en/renderers/WebGLRenderer.shadowMap\n\t */\n\tshadows?: boolean | 'basic' | 'percentage' | 'soft' | 'variance' | Partial<WebGLShadowMap>;\n\t/**\n\t * Disables three r139 color management.\n\t * @see https://threejs.org/docs/#manual/en/introduction/Color-management\n\t */\n\tlegacy?: boolean;\n\t/** Switch off automatic sRGB color space and gamma correction */\n\tlinear?: boolean;\n\t/** Use `THREE.NoToneMapping` instead of `THREE.ACESFilmicToneMapping` */\n\tflat?: boolean;\n\t/** Creates an orthographic camera */\n\torthographic?: boolean;\n\t/**\n\t * R3F's render mode. Set to `demand` to only render on state change or `never` to take control.\n\t * @see https://docs.pmnd.rs/react-three-fiber/advanced/scaling-performance#on-demand-rendering\n\t */\n\tframeloop?: 'always' | 'demand' | 'never';\n\t/**\n\t * R3F performance options for adaptive performance.\n\t * @see https://docs.pmnd.rs/react-three-fiber/advanced/scaling-performance#movement-regression\n\t */\n\tperformance?: Partial<Omit<NgtPerformance, 'regress'>>;\n\t/** Target pixel ratio. Can clamp between a range: `[min, max]` */\n\tdpr?: NgtDpr;\n\t/** Props that go into the default raycaster */\n\traycaster?: Partial<Raycaster>;\n\t/** A `Scene` instance or props that go into the default scene */\n\tscene?: Scene | Partial<Scene>;\n\t/** A `Camera` instance or props that go into the default camera */\n\tcamera?: (\n\t\t| NgtCamera\n\t\t| Partial<\n\t\t\t\tNgtObject3DNode<Camera, typeof Camera> &\n\t\t\t\t\tNgtObject3DNode<PerspectiveCamera, typeof PerspectiveCamera> &\n\t\t\t\t\tNgtObject3DNode<OrthographicCamera, typeof OrthographicCamera>\n\t\t  >\n\t) & {\n\t\t/** Flags the camera as manual, putting projection into your own hands */\n\t\tmanual?: boolean;\n\t};\n\t/** An R3F event manager to manage elements' pointer events */\n\tevents?: (store: NgtSignalStore<NgtState>) => NgtEventManager<HTMLElement>;\n\t/** The target where events are being subscribed to, default: the div that wraps canvas */\n\teventSource?: HTMLElement | ElementRef<HTMLElement>;\n\t/** The event prefix that is cast into canvas pointer x/y events, default: \"offset\" */\n\teventPrefix?: 'offset' | 'client' | 'page' | 'layer' | 'screen';\n\t/** Default coordinate for the camera to look at */\n\tlookAt?: Vector3 | Parameters<Vector3['set']>;\n}\n\nexport interface NgtIntersection extends Intersection {\n\t/** The event source (the object which registered the handler) */\n\teventObject: Object3D;\n}\n\nexport interface NgtIntersectionEvent<TSourceEvent> extends NgtIntersection {\n\t/** The event source (the object which registered the handler) */\n\teventObject: Object3D;\n\t/** An array of intersections */\n\tintersections: NgtIntersection[];\n\t/** vec3.set(pointer.x, pointer.y, 0).unproject(camera) */\n\tunprojectedPoint: Vector3;\n\t/** Normalized event coordinates */\n\tpointer: Vector2;\n\t/** Delta between first click and this event */\n\tdelta: number;\n\t/** The ray that pierced it */\n\tray: Ray;\n\t/** The camera that was used by the raycaster */\n\tcamera: NgtCamera;\n\t/** stopPropagation will stop underlying handlers from firing */\n\tstopPropagation: () => void;\n\t/** The original host event */\n\tnativeEvent: TSourceEvent;\n\t/** If the event was stopped by calling stopPropagation */\n\tstopped: boolean;\n}\n\nexport type NgtCamera = OrthographicCamera | PerspectiveCamera;\nexport type NgtThreeEvent<TEvent> = NgtIntersectionEvent<TEvent> & NgtProperties<TEvent>;\nexport type NgtDomEvent = PointerEvent | MouseEvent | WheelEvent;\n\nexport type NgtEventHandlers = {\n\tclick?: (event: NgtThreeEvent<MouseEvent>) => void;\n\tcontextmenu?: (event: NgtThreeEvent<MouseEvent>) => void;\n\tdblclick?: (event: NgtThreeEvent<MouseEvent>) => void;\n\tpointerup?: (event: NgtThreeEvent<PointerEvent>) => void;\n\tpointerdown?: (event: NgtThreeEvent<PointerEvent>) => void;\n\tpointerover?: (event: NgtThreeEvent<PointerEvent>) => void;\n\tpointerout?: (event: NgtThreeEvent<PointerEvent>) => void;\n\tpointerenter?: (event: NgtThreeEvent<PointerEvent>) => void;\n\tpointerleave?: (event: NgtThreeEvent<PointerEvent>) => void;\n\tpointermove?: (event: NgtThreeEvent<PointerEvent>) => void;\n\tpointermissed?: (event: MouseEvent) => void;\n\tpointercancel?: (event: NgtThreeEvent<PointerEvent>) => void;\n\twheel?: (event: NgtThreeEvent<WheelEvent>) => void;\n};\n\nexport type NgtEvents = {\n\t[TEvent in keyof NgtEventHandlers]-?: EventListener;\n};\n\nexport type NgtFilterFunction = (items: Intersection[], store: NgtSignalStore<NgtState>) => Intersection[];\nexport type NgtComputeFunction = (\n\tevent: NgtDomEvent,\n\troot: NgtSignalStore<NgtState>,\n\tprevious: NgtSignalStore<NgtState> | null,\n) => void;\n\nexport type NgtEventManager<TTarget> = {\n\t/** Determines if the event layer is active */\n\tenabled: boolean;\n\t/** Event layer priority, higher prioritized layers come first and may stop(-propagate) lower layer  */\n\tpriority: number;\n\t/** The compute function needs to set up the raycaster and an xy- pointer  */\n\tcompute?: NgtComputeFunction;\n\t/** The filter can re-order or re-structure the intersections  */\n\tfilter?: NgtFilterFunction;\n\t/** The target node the event layer is tied to */\n\tconnected?: TTarget;\n\t/** All the pointer event handlers through which the host forwards native events */\n\thandlers?: NgtEvents;\n\t/** Allows re-connecting to another target */\n\tconnect?: (target: TTarget) => void;\n\t/** Removes all existing events handlers from the target */\n\tdisconnect?: () => void;\n\t/** Triggers a onPointerMove with the last known event. This can be useful to enable raycasting without\n\t *  explicit user interaction, for instance when the camera moves a hoverable object underneath the cursor.\n\t */\n\tupdate?: () => void;\n};\n\nexport interface NgtPointerCaptureTarget {\n\tintersection: NgtIntersection;\n\ttarget: Element;\n}\n\nexport type NgtAttachFunction<TChild = any, TParent = any> = (\n\tparent: TParent,\n\tchild: TChild,\n\tstore: NgtSignalStore<NgtState>,\n) => void | (() => void);\n\nexport type NgtAttachable<TChild = any, TParent = any> = NgtAttachFunction<TChild, TParent> | string | string[];\n\nexport interface NgtAfterAttach<\n\tTChild extends NgtInstanceNode = NgtInstanceNode,\n\tTParent extends NgtInstanceNode = NgtInstanceNode,\n> {\n\tparent: TParent;\n\tnode: TChild;\n}\n\nexport interface NgtLocalInstanceState {\n\tobjects: NgtInstanceNode[];\n\tnonObjects: NgtInstanceNode[];\n\tparent: NgtInstanceNode | null;\n\tgeometryStamp: number;\n}\n\nexport interface NgtLocalState {\n\t/** the store of the canvas that the instance is being rendered to */\n\tstore: NgtSignalStore<NgtState>;\n\t// objects related to this instance\n\tinstanceStore: NgtSignalStore<NgtLocalInstanceState>;\n\t// shortcut to signals\n\tparent: Signal<NgtLocalInstanceState['parent']>;\n\tobjects: Signal<NgtLocalInstanceState['objects']>;\n\tnonObjects: Signal<NgtLocalInstanceState['nonObjects']>;\n\n\t// shortcut to add/remove object to list\n\tadd: (instance: NgtInstanceNode, type: 'objects' | 'nonObjects') => void;\n\tremove: (instance: NgtInstanceNode, type: 'objects' | 'nonObjects') => void;\n\tsetParent: (parent: NgtInstanceNode | null) => void;\n\tupdateGeometryStamp: () => void;\n\n\t// if this THREE instance is a ngt-primitive\n\tprimitive?: boolean;\n\t// if this THREE object has any events bound to it\n\teventCount: number;\n\t// list of handlers to handle the events\n\thandlers: Partial<NgtEventHandlers>;\n\t// attach information so that we can detach as well as reset\n\tattach?: string[] | NgtAttachFunction;\n\t// previously attach information so we can reset as well as clean up\n\tpreviousAttach?: unknown | (() => void);\n\t// is raw value\n\tisRaw?: boolean;\n\t// priority for before render\n\tpriority?: number;\n\tonUpdate?: (node: NgtInstanceNode) => void;\n\tonAttach?: (afterAttach: NgtAfterAttach) => void;\n}\n\nexport type NgtInstanceNode<TNode = any> = { __ngt__: NgtLocalState } & NgtAnyRecord & TNode;\n\nexport type NgtCanvasElement = HTMLCanvasElement | OffscreenCanvas;\nexport type NgtGlobalRenderCallback = (timeStamp: number) => void;\n\nexport type NgtRendererLike = { render: (scene: Scene, camera: Camera) => any };\nexport type NgtCameraManual = NgtCamera & { manual?: boolean };\nexport type NgtDpr = number | [min: number, max: number];\nexport type NgtSize = { width: number; height: number; top: number; left: number };\n\nexport type NgtViewport = NgtSize & {\n\t/** The initial pixel ratio */\n\tinitialDpr: number;\n\t/** Current pixel ratio */\n\tdpr: number;\n\t/** size.width / viewport.width */\n\tfactor: number;\n\t/** Camera distance */\n\tdistance: number;\n\t/** Camera aspect ratio: width / height */\n\taspect: number;\n};\n\nexport type NgtPerformance = {\n\t/** Current performance normal, between min and max */\n\tcurrent: number;\n\t/** How low the performance can go, between 0 and max */\n\tmin: number;\n\t/** How high the performance can go, between min and max */\n\tmax: number;\n\t/** Time until current returns to max in ms */\n\tdebounce: number;\n\t/** Sets current to min, puts the system in regression */\n\tregress: () => void;\n};\n\nexport type NgtRenderState = NgtState & { delta: number; frame?: XRFrame };\n\nexport type NgtBeforeRenderEvent<TObject extends NgtInstanceNode = NgtInstanceNode> = {\n\tstate: NgtRenderState;\n\tobject: TObject;\n};\n\nexport type NgtBeforeRenderRecord = {\n\tcallback: (state: NgtRenderState) => void;\n\tstore: NgtSignalStore<NgtState>;\n\tpriority?: number;\n};\n\nexport type NgtInternalState = {\n\tactive: boolean;\n\tpriority: number;\n\tframes: number;\n\tlastEvent: ElementRef<NgtDomEvent | null>;\n\tinteraction: Object3D[];\n\thovered: Map<string, NgtThreeEvent<NgtDomEvent>>;\n\tcapturedMap: Map<number, Map<Object3D, NgtPointerCaptureTarget>>;\n\tinitialClick: [x: number, y: number];\n\tinitialHits: Object3D[];\n\tsubscribers: NgtBeforeRenderRecord[];\n\tsubscribe: (\n\t\tcallback: NgtBeforeRenderRecord['callback'],\n\t\tpriority?: number,\n\t\tstore?: NgtSignalStore<NgtState>,\n\t) => () => void;\n};\n\nexport type NgtState = {\n\t/** The instance of the renderer */\n\tgl: WebGLRenderer;\n\t/** Default camera */\n\tcamera: NgtCameraManual;\n\t/** Default scene */\n\tscene: Scene;\n\t/** Default raycaster */\n\traycaster: Raycaster;\n\t/** Default clock */\n\tclock: Clock;\n\t/** Event layer interface, contains the event handler and the node they're connected to */\n\tevents: NgtEventManager<any>;\n\t/** XR interface */\n\txr: { connect: () => void; disconnect: () => void };\n\t/** Currently used controls */\n\tcontrols: EventDispatcher | null;\n\t/** Normalized event coordinates */\n\tpointer: Vector2;\n\t/* Whether to enable r139's ColorManagement */\n\tlegacy: boolean;\n\t/** Shortcut to gl.outputColorSpace = LinearSRGBColorSpace */\n\tlinear: boolean;\n\t/** Shortcut to gl.toneMapping = NoTonemapping */\n\tflat: boolean;\n\t/** Render loop flags */\n\tframeloop: 'always' | 'demand' | 'never';\n\t/** Adaptive performance interface */\n\tperformance: NgtPerformance;\n\t/** Reactive pixel-size of the canvas */\n\tsize: NgtSize;\n\t/** Reactive size of the viewport in threejs units */\n\tviewport: NgtViewport & {\n\t\tgetCurrentViewport: (\n\t\t\tcamera?: NgtCamera,\n\t\t\ttarget?: Vector3 | Parameters<Vector3['set']>,\n\t\t\tsize?: NgtSize,\n\t\t) => Omit<NgtViewport, 'dpr' | 'initialDpr'>;\n\t};\n\t/** Flags the canvas for render, but doesn't render in itself */\n\tinvalidate: (frames?: number) => void;\n\t/** Advance (render) one step */\n\tadvance: (timestamp: number, runGlobalEffects?: boolean) => void;\n\t/** Shortcut to setting the event layer */\n\tsetEvents: (events: Partial<NgtEventManager<any>>) => void;\n\t/**\n\t * Shortcut to manual sizing\n\t */\n\tsetSize: (width: number, height: number, top?: number, left?: number) => void;\n\t/** Shortcut to manual setting the pixel ratio */\n\tsetDpr: (dpr: NgtDpr) => void;\n\t/** Shortcut to frameloop flags */\n\tsetFrameloop: (frameloop?: 'always' | 'demand' | 'never') => void;\n\t/** When the canvas was clicked but nothing was hit */\n\t/** PointerMissed Observable */\n\tpointerMissed$: Observable<MouseEvent>;\n\t/** If this state model is layered (via createPortal) then this contains the previous layer */\n\tpreviousRoot: NgtSignalStore<NgtState> | null;\n\t/** Internals */\n\tinternal: NgtInternalState;\n};\n"]}
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../../../libs/core/src/lib/types.ts"],"names":[],"mappings":"","sourcesContent":["import { ElementRef, Signal } from '@angular/core';\nimport { Observable } from 'rxjs';\nimport {\n\tCamera,\n\tClock,\n\tEventDispatcher,\n\tIntersection,\n\tObject3D,\n\tOrthographicCamera,\n\tPerspectiveCamera,\n\tRay,\n\tRaycaster,\n\tScene,\n\tVector2,\n\tVector3,\n\tWebGLRenderer,\n\tWebGLRendererParameters,\n\tWebGLShadowMap,\n} from 'three';\nimport { NgtObject3DNode } from './three-types';\nimport { NgtSignalStore } from './utils/signal-store';\n\nexport type NgtProperties<T> = { [K in keyof T as T[K] extends (...args: Array<any>) => any ? never : K]: T[K] };\nexport type NgtAnyRecord = Record<string, any>;\n\nexport type NgtEquConfig = {\n\t/** Compare arrays by reference equality a === b (default), or by shallow equality */\n\tarrays?: 'reference' | 'shallow';\n\t/** Compare objects by reference equality a === b (default), or by shallow equality */\n\tobjects?: 'reference' | 'shallow';\n\t/** If true the keys in both a and b must match 1:1 (default), if false a's keys must intersect b's */\n\tstrict?: boolean;\n};\n\nexport type NgtGLOptions =\n\t| NgtRendererLike\n\t| ((canvas: NgtCanvasElement) => NgtRendererLike)\n\t| Partial<NgtProperties<WebGLRenderer> | WebGLRendererParameters>\n\t| undefined;\n\nexport interface NgtCanvasOptions {\n\t/** A threejs renderer instance or props that go into the default renderer */\n\tgl?: NgtGLOptions;\n\t/** Dimensions to fit the renderer to. Will measure canvas dimensions if omitted */\n\tsize?: NgtSize;\n\t/**\n\t * Enables shadows (by default PCFsoft). Can accept `gl.shadowMap` options for fine-tuning,\n\t * but also strings: 'basic' | 'percentage' | 'soft' | 'variance'.\n\t * @see https://threejs.org/docs/#api/en/renderers/WebGLRenderer.shadowMap\n\t */\n\tshadows?: boolean | 'basic' | 'percentage' | 'soft' | 'variance' | Partial<WebGLShadowMap>;\n\t/**\n\t * Disables three r139 color management.\n\t * @see https://threejs.org/docs/#manual/en/introduction/Color-management\n\t */\n\tlegacy?: boolean;\n\t/** Switch off automatic sRGB color space and gamma correction */\n\tlinear?: boolean;\n\t/** Use `THREE.NoToneMapping` instead of `THREE.ACESFilmicToneMapping` */\n\tflat?: boolean;\n\t/** Creates an orthographic camera */\n\torthographic?: boolean;\n\t/**\n\t * R3F's render mode. Set to `demand` to only render on state change or `never` to take control.\n\t * @see https://docs.pmnd.rs/react-three-fiber/advanced/scaling-performance#on-demand-rendering\n\t */\n\tframeloop?: 'always' | 'demand' | 'never';\n\t/**\n\t * R3F performance options for adaptive performance.\n\t * @see https://docs.pmnd.rs/react-three-fiber/advanced/scaling-performance#movement-regression\n\t */\n\tperformance?: Partial<Omit<NgtPerformance, 'regress'>>;\n\t/** Target pixel ratio. Can clamp between a range: `[min, max]` */\n\tdpr?: NgtDpr;\n\t/** Props that go into the default raycaster */\n\traycaster?: Partial<Raycaster>;\n\t/** A `Scene` instance or props that go into the default scene */\n\tscene?: Scene | Partial<Scene>;\n\t/** A `Camera` instance or props that go into the default camera */\n\tcamera?: (\n\t\t| NgtCamera\n\t\t| Partial<\n\t\t\t\tNgtObject3DNode<Camera, typeof Camera> &\n\t\t\t\t\tNgtObject3DNode<PerspectiveCamera, typeof PerspectiveCamera> &\n\t\t\t\t\tNgtObject3DNode<OrthographicCamera, typeof OrthographicCamera>\n\t\t  >\n\t) & {\n\t\t/** Flags the camera as manual, putting projection into your own hands */\n\t\tmanual?: boolean;\n\t};\n\t/** An R3F event manager to manage elements' pointer events */\n\tevents?: (store: NgtSignalStore<NgtState>) => NgtEventManager<HTMLElement>;\n\t/** The target where events are being subscribed to, default: the div that wraps canvas */\n\teventSource?: HTMLElement | ElementRef<HTMLElement>;\n\t/** The event prefix that is cast into canvas pointer x/y events, default: \"offset\" */\n\teventPrefix?: 'offset' | 'client' | 'page' | 'layer' | 'screen';\n\t/** Default coordinate for the camera to look at */\n\tlookAt?: Vector3 | Parameters<Vector3['set']>;\n}\n\nexport interface NgtIntersection extends Intersection {\n\t/** The event source (the object which registered the handler) */\n\teventObject: Object3D;\n}\n\nexport interface NgtIntersectionEvent<TSourceEvent> extends NgtIntersection {\n\t/** The event source (the object which registered the handler) */\n\teventObject: Object3D;\n\t/** An array of intersections */\n\tintersections: NgtIntersection[];\n\t/** vec3.set(pointer.x, pointer.y, 0).unproject(camera) */\n\tunprojectedPoint: Vector3;\n\t/** Normalized event coordinates */\n\tpointer: Vector2;\n\t/** Delta between first click and this event */\n\tdelta: number;\n\t/** The ray that pierced it */\n\tray: Ray;\n\t/** The camera that was used by the raycaster */\n\tcamera: NgtCamera;\n\t/** stopPropagation will stop underlying handlers from firing */\n\tstopPropagation: () => void;\n\t/** The original host event */\n\tnativeEvent: TSourceEvent;\n\t/** If the event was stopped by calling stopPropagation */\n\tstopped: boolean;\n}\n\nexport type NgtCamera = OrthographicCamera | PerspectiveCamera;\nexport type NgtThreeEvent<TEvent> = NgtIntersectionEvent<TEvent> & NgtProperties<TEvent>;\nexport type NgtDomEvent = PointerEvent | MouseEvent | WheelEvent;\n\nexport type NgtEventHandlers = {\n\tclick?: (event: NgtThreeEvent<MouseEvent>) => void;\n\tcontextmenu?: (event: NgtThreeEvent<MouseEvent>) => void;\n\tdblclick?: (event: NgtThreeEvent<MouseEvent>) => void;\n\tpointerup?: (event: NgtThreeEvent<PointerEvent>) => void;\n\tpointerdown?: (event: NgtThreeEvent<PointerEvent>) => void;\n\tpointerover?: (event: NgtThreeEvent<PointerEvent>) => void;\n\tpointerout?: (event: NgtThreeEvent<PointerEvent>) => void;\n\tpointerenter?: (event: NgtThreeEvent<PointerEvent>) => void;\n\tpointerleave?: (event: NgtThreeEvent<PointerEvent>) => void;\n\tpointermove?: (event: NgtThreeEvent<PointerEvent>) => void;\n\tpointermissed?: (event: MouseEvent) => void;\n\tpointercancel?: (event: NgtThreeEvent<PointerEvent>) => void;\n\twheel?: (event: NgtThreeEvent<WheelEvent>) => void;\n};\n\nexport type NgtEvents = {\n\t[TEvent in keyof NgtEventHandlers]-?: EventListener;\n};\n\nexport type NgtFilterFunction = (items: Intersection[], store: NgtSignalStore<NgtState>) => Intersection[];\nexport type NgtComputeFunction = (\n\tevent: NgtDomEvent,\n\troot: NgtSignalStore<NgtState>,\n\tprevious: NgtSignalStore<NgtState> | null,\n) => void;\n\nexport type NgtEventManager<TTarget> = {\n\t/** Determines if the event layer is active */\n\tenabled: boolean;\n\t/** Event layer priority, higher prioritized layers come first and may stop(-propagate) lower layer  */\n\tpriority: number;\n\t/** The compute function needs to set up the raycaster and an xy- pointer  */\n\tcompute?: NgtComputeFunction;\n\t/** The filter can re-order or re-structure the intersections  */\n\tfilter?: NgtFilterFunction;\n\t/** The target node the event layer is tied to */\n\tconnected?: TTarget;\n\t/** All the pointer event handlers through which the host forwards native events */\n\thandlers?: NgtEvents;\n\t/** Allows re-connecting to another target */\n\tconnect?: (target: TTarget) => void;\n\t/** Removes all existing events handlers from the target */\n\tdisconnect?: () => void;\n\t/** Triggers a onPointerMove with the last known event. This can be useful to enable raycasting without\n\t *  explicit user interaction, for instance when the camera moves a hoverable object underneath the cursor.\n\t */\n\tupdate?: () => void;\n};\n\nexport interface NgtPointerCaptureTarget {\n\tintersection: NgtIntersection;\n\ttarget: Element;\n}\n\nexport type NgtAttachFunction<TChild = any, TParent = any> = (\n\tparent: TParent,\n\tchild: TChild,\n\tstore: NgtSignalStore<NgtState>,\n) => void | (() => void);\n\nexport type NgtAttachable<TChild = any, TParent = any> = NgtAttachFunction<TChild, TParent> | string | string[];\n\nexport interface NgtAfterAttach<\n\tTChild extends NgtInstanceNode = NgtInstanceNode,\n\tTParent extends NgtInstanceNode = NgtInstanceNode,\n> {\n\tparent: TParent;\n\tnode: TChild;\n}\n\nexport interface NgtLocalInstanceState {\n\tobjects: NgtInstanceNode[];\n\tnonObjects: NgtInstanceNode[];\n\tparent: NgtInstanceNode | null;\n\tgeometryStamp: number;\n}\n\nexport interface NgtLocalState {\n\t/** the store of the canvas that the instance is being rendered to */\n\tstore: NgtSignalStore<NgtState>;\n\t// objects related to this instance\n\tinstanceStore: NgtSignalStore<NgtLocalInstanceState>;\n\t// shortcut to signals\n\tparent: Signal<NgtLocalInstanceState['parent']>;\n\tobjects: Signal<NgtLocalInstanceState['objects']>;\n\tnonObjects: Signal<NgtLocalInstanceState['nonObjects']>;\n\n\t// shortcut to add/remove object to list\n\tadd: (instance: NgtInstanceNode, type: 'objects' | 'nonObjects') => void;\n\tremove: (instance: NgtInstanceNode, type: 'objects' | 'nonObjects') => void;\n\tsetParent: (parent: NgtInstanceNode | null) => void;\n\tupdateGeometryStamp: () => void;\n\n\t// if this THREE instance is a ngt-primitive\n\tprimitive?: boolean;\n\t// if this THREE object has any events bound to it\n\teventCount: number;\n\t// list of handlers to handle the events\n\thandlers: Partial<NgtEventHandlers>;\n\t// attach information so that we can detach as well as reset\n\tattach?: string[] | NgtAttachFunction;\n\t// previously attach information so we can reset as well as clean up\n\tpreviousAttach?: unknown | (() => void);\n\t// is raw value\n\tisRaw?: boolean;\n\t// priority for before render\n\tpriority?: number;\n\tonUpdate?: (node: NgtInstanceNode) => void;\n\tonAttach?: (afterAttach: NgtAfterAttach) => void;\n}\n\nexport type NgtInstanceNode<TNode = any> = { __ngt__: NgtLocalState } & NgtAnyRecord & TNode;\n\nexport type NgtCanvasElement = HTMLCanvasElement | OffscreenCanvas;\nexport type NgtGlobalRenderCallback = (timeStamp: number) => void;\n\nexport type NgtRendererLike = { render: (scene: Scene, camera: Camera) => any };\nexport type NgtCameraManual = NgtCamera & { manual?: boolean };\nexport type NgtDpr = number | [min: number, max: number];\nexport type NgtSize = { width: number; height: number; top: number; left: number };\n\nexport type NgtViewport = NgtSize & {\n\t/** The initial pixel ratio */\n\tinitialDpr: number;\n\t/** Current pixel ratio */\n\tdpr: number;\n\t/** size.width / viewport.width */\n\tfactor: number;\n\t/** Camera distance */\n\tdistance: number;\n\t/** Camera aspect ratio: width / height */\n\taspect: number;\n};\n\nexport type NgtPerformance = {\n\t/** Current performance normal, between min and max */\n\tcurrent: number;\n\t/** How low the performance can go, between 0 and max */\n\tmin: number;\n\t/** How high the performance can go, between min and max */\n\tmax: number;\n\t/** Time until current returns to max in ms */\n\tdebounce: number;\n\t/** Sets current to min, puts the system in regression */\n\tregress: () => void;\n};\n\nexport type NgtRenderState = NgtState & { delta: number; frame?: XRFrame };\n\nexport type NgtBeforeRenderEvent<TObject extends NgtInstanceNode = NgtInstanceNode> = {\n\tstate: NgtRenderState;\n\tobject: TObject;\n};\n\nexport type NgtBeforeRenderRecord = {\n\tcallback: (state: NgtRenderState) => void;\n\tstore: NgtSignalStore<NgtState>;\n\tpriority?: number;\n};\n\nexport type NgtInternalState = {\n\tactive: boolean;\n\tpriority: number;\n\tframes: number;\n\tlastEvent: ElementRef<NgtDomEvent | null>;\n\tinteraction: Object3D[];\n\thovered: Map<string, NgtThreeEvent<NgtDomEvent>>;\n\tcapturedMap: Map<number, Map<Object3D, NgtPointerCaptureTarget>>;\n\tinitialClick: [x: number, y: number];\n\tinitialHits: Object3D[];\n\tsubscribers: NgtBeforeRenderRecord[];\n\tsubscribe: (\n\t\tcallback: NgtBeforeRenderRecord['callback'],\n\t\tpriority?: number,\n\t\tstore?: NgtSignalStore<NgtState>,\n\t) => () => void;\n};\n\nexport type NgtState = {\n\t/** The instance of the renderer */\n\tgl: WebGLRenderer;\n\t/** Default camera */\n\tcamera: NgtCameraManual;\n\t/** Default scene */\n\tscene: Scene;\n\t/** Default raycaster */\n\traycaster: Raycaster;\n\t/** Default clock */\n\tclock: Clock;\n\t/** Event layer interface, contains the event handler and the node they're connected to */\n\tevents: NgtEventManager<any>;\n\t/** XR interface */\n\txr: { connect: () => void; disconnect: () => void };\n\t/** Currently used controls */\n\tcontrols: EventDispatcher | null;\n\t/** Normalized event coordinates */\n\tpointer: Vector2;\n\t/* Whether to enable r139's ColorManagement */\n\tlegacy: boolean;\n\t/** Shortcut to gl.outputColorSpace = LinearSRGBColorSpace */\n\tlinear: boolean;\n\t/** Shortcut to gl.toneMapping = NoTonemapping */\n\tflat: boolean;\n\t/** Render loop flags */\n\tframeloop: 'always' | 'demand' | 'never';\n\t/** Adaptive performance interface */\n\tperformance: NgtPerformance;\n\t/** Reactive pixel-size of the canvas */\n\tsize: NgtSize;\n\t/** Reactive size of the viewport in threejs units */\n\tviewport: NgtViewport & {\n\t\tgetCurrentViewport: (\n\t\t\tcamera?: NgtCamera,\n\t\t\ttarget?: Vector3 | Parameters<Vector3['set']>,\n\t\t\tsize?: NgtSize,\n\t\t) => Omit<NgtViewport, 'dpr' | 'initialDpr'>;\n\t};\n\t/** Flags the canvas for render, but doesn't render in itself */\n\tinvalidate: (frames?: number) => void;\n\t/** Advance (render) one step */\n\tadvance: (timestamp: number, runGlobalEffects?: boolean) => void;\n\t/** Shortcut to setting the event layer */\n\tsetEvents: (events: Partial<NgtEventManager<any>>) => void;\n\t/**\n\t * Shortcut to manual sizing\n\t */\n\tsetSize: (width: number, height: number, top?: number, left?: number) => void;\n\t/** Shortcut to manual setting the pixel ratio */\n\tsetDpr: (dpr: NgtDpr) => void;\n\t/** Shortcut to frameloop flags */\n\tsetFrameloop: (frameloop?: 'always' | 'demand' | 'never') => void;\n\t/** When the canvas was clicked but nothing was hit */\n\t/** PointerMissed Observable */\n\tpointerMissed$: Observable<MouseEvent>;\n\t/** If this state model is layered (via createPortal) then this contains the previous layer */\n\tpreviousRoot: NgtSignalStore<NgtState> | null;\n\t/** Internals */\n\tinternal: NgtInternalState;\n};\n"]}
|
|
@@ -38,13 +38,33 @@ export class NgtObjectEvents {
|
|
|
38
38
|
emitEvent(eventName) {
|
|
39
39
|
return this[eventName].emit.bind(this[eventName]);
|
|
40
40
|
}
|
|
41
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.
|
|
42
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "18.2.
|
|
41
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: NgtObjectEvents, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
42
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "18.2.9", type: NgtObjectEvents, isStandalone: true, selector: "[ngtObjectEvents]", inputs: { ngtObjectEvents: { classPropertyName: "ngtObjectEvents", publicName: "ngtObjectEvents", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { 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" }, ngImport: i0 }); }
|
|
43
43
|
}
|
|
44
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.
|
|
44
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: NgtObjectEvents, decorators: [{
|
|
45
45
|
type: Directive,
|
|
46
46
|
args: [{ standalone: true, selector: '[ngtObjectEvents]' }]
|
|
47
47
|
}], ctorParameters: () => [] });
|
|
48
|
+
export const NgtObjectEventsInputs = ['ngtObjectEvents'];
|
|
49
|
+
export const NgtObjectEventsOutputs = [
|
|
50
|
+
'click',
|
|
51
|
+
'dblclick',
|
|
52
|
+
'contextmenu',
|
|
53
|
+
'pointerup',
|
|
54
|
+
'pointerdown',
|
|
55
|
+
'pointerover',
|
|
56
|
+
'pointerout',
|
|
57
|
+
'pointerenter',
|
|
58
|
+
'pointerleave',
|
|
59
|
+
'pointermove',
|
|
60
|
+
'pointermissed',
|
|
61
|
+
'pointercancel',
|
|
62
|
+
'wheel',
|
|
63
|
+
];
|
|
64
|
+
/**
|
|
65
|
+
* @deprecated Use NgtObjectEventsInputs and NgtObjectEventsOutputs instead along with NgtObjectEvents
|
|
66
|
+
* @since 2.6.0 Will be removed in 3.0.0
|
|
67
|
+
*/
|
|
48
68
|
export const NgtObjectEventsHostDirective = {
|
|
49
69
|
directive: NgtObjectEvents,
|
|
50
70
|
inputs: ['ngtObjectEvents'],
|
|
@@ -85,4 +105,4 @@ export function injectObjectEvents(target, events, { injector } = {}) {
|
|
|
85
105
|
return cleanUps;
|
|
86
106
|
});
|
|
87
107
|
}
|
|
88
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
108
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"object-events.js","sourceRoot":"","sources":["../../../../../../libs/core/src/lib/utils/object-events.ts"],"names":[],"mappings":"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","sourcesContent":["import { DestroyRef, Directive, effect, ElementRef, inject, Injector, model, output, Renderer2 } from '@angular/core';\nimport { assertInjector } from 'ngxtension/assert-injector';\nimport { Object3D } from 'three';\nimport { NgtEventHandlers, NgtThreeEvent } from '../types';\nimport { resolveRef } from './resolve-ref';\n\n@Directive({ standalone: true, selector: '[ngtObjectEvents]' })\nexport class NgtObjectEvents {\n\tclick = output<NgtThreeEvent<MouseEvent>>();\n\tdblclick = output<NgtThreeEvent<MouseEvent>>();\n\tcontextmenu = output<NgtThreeEvent<MouseEvent>>();\n\tpointerup = output<NgtThreeEvent<PointerEvent>>();\n\tpointerdown = output<NgtThreeEvent<PointerEvent>>();\n\tpointerover = output<NgtThreeEvent<PointerEvent>>();\n\tpointerout = output<NgtThreeEvent<PointerEvent>>();\n\tpointerenter = output<NgtThreeEvent<PointerEvent>>();\n\tpointerleave = output<NgtThreeEvent<PointerEvent>>();\n\tpointermove = output<NgtThreeEvent<PointerEvent>>();\n\tpointermissed = output<NgtThreeEvent<MouseEvent>>();\n\tpointercancel = output<NgtThreeEvent<PointerEvent>>();\n\twheel = output<NgtThreeEvent<WheelEvent>>();\n\n\t// NOTE: we use model here to allow for the hostDirective host to set this value\n\tngtObjectEvents = model<ElementRef<Object3D> | Object3D | null | undefined>();\n\n\tconstructor() {\n\t\tinjectObjectEvents(this.ngtObjectEvents, {\n\t\t\tclick: this.emitEvent('click'),\n\t\t\tdblclick: this.emitEvent('dblclick'),\n\t\t\tcontextmenu: this.emitEvent('contextmenu'),\n\t\t\tpointerup: this.emitEvent('pointerup'),\n\t\t\tpointerdown: this.emitEvent('pointerdown'),\n\t\t\tpointerover: this.emitEvent('pointerover'),\n\t\t\tpointerout: this.emitEvent('pointerout'),\n\t\t\tpointerenter: this.emitEvent('pointerenter'),\n\t\t\tpointerleave: this.emitEvent('pointerleave'),\n\t\t\tpointermove: this.emitEvent('pointermove'),\n\t\t\tpointermissed: this.emitEvent('pointermissed'),\n\t\t\tpointercancel: this.emitEvent('pointercancel'),\n\t\t\twheel: this.emitEvent('wheel'),\n\t\t});\n\t}\n\n\tprivate emitEvent<TEvent extends keyof NgtEventHandlers>(eventName: TEvent) {\n\t\treturn this[eventName].emit.bind(this[eventName]) as NgtEventHandlers[TEvent];\n\t}\n}\n\nexport const NgtObjectEventsInputs = ['ngtObjectEvents'] as const;\nexport const NgtObjectEventsOutputs = [\n\t'click',\n\t'dblclick',\n\t'contextmenu',\n\t'pointerup',\n\t'pointerdown',\n\t'pointerover',\n\t'pointerout',\n\t'pointerenter',\n\t'pointerleave',\n\t'pointermove',\n\t'pointermissed',\n\t'pointercancel',\n\t'wheel',\n] as const;\n\n/**\n * @deprecated Use NgtObjectEventsInputs and NgtObjectEventsOutputs instead along with NgtObjectEvents\n * @since 2.6.0 Will be removed in 3.0.0\n */\nexport const NgtObjectEventsHostDirective = {\n\tdirective: NgtObjectEvents,\n\tinputs: ['ngtObjectEvents'],\n\toutputs: [\n\t\t'click',\n\t\t'dblclick',\n\t\t'contextmenu',\n\t\t'pointerup',\n\t\t'pointerdown',\n\t\t'pointerover',\n\t\t'pointerout',\n\t\t'pointerenter',\n\t\t'pointerleave',\n\t\t'pointermove',\n\t\t'pointermissed',\n\t\t'pointercancel',\n\t\t'wheel',\n\t],\n};\n\nexport function injectObjectEvents(\n\ttarget: () => ElementRef<Object3D> | Object3D | null | undefined,\n\tevents: NgtEventHandlers,\n\t{ injector }: { injector?: Injector } = {},\n) {\n\treturn assertInjector(injectObjectEvents, injector, () => {\n\t\tconst renderer = inject(Renderer2);\n\n\t\tconst cleanUps: Array<() => void> = [];\n\n\t\teffect((onCleanup) => {\n\t\t\tconst targetRef = resolveRef(target());\n\n\t\t\tif (!targetRef) return;\n\n\t\t\tObject.entries(events).forEach(([eventName, eventHandler]) => {\n\t\t\t\tcleanUps.push(renderer.listen(targetRef, eventName, eventHandler));\n\t\t\t});\n\n\t\t\tonCleanup(() => {\n\t\t\t\tcleanUps.forEach((cleanUp) => cleanUp());\n\t\t\t});\n\t\t});\n\n\t\tinject(DestroyRef).onDestroy(() => {\n\t\t\tcleanUps.forEach((cleanUp) => cleanUp());\n\t\t});\n\n\t\treturn cleanUps;\n\t});\n}\n"]}
|
|
@@ -102,14 +102,14 @@ export class NgtCanvasNative {
|
|
|
102
102
|
});
|
|
103
103
|
this.glRef.changeDetectorRef.detectChanges();
|
|
104
104
|
}
|
|
105
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.
|
|
106
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.2.0", version: "18.2.
|
|
105
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: NgtCanvasNative, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
106
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.2.0", version: "18.2.9", type: NgtCanvasNative, isStandalone: true, selector: "NgtCanvas", 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 }, lookAt: { classPropertyName: "lookAt", publicName: "lookAt", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { created: "created" }, providers: [{ provide: DOCUMENT, useValue: document }, provideStore()], viewQueries: [{ propertyName: "canvasViewContainerRef", first: true, predicate: ["canvas"], descendants: true, read: ViewContainerRef, isSignal: true }], ngImport: i0, template: `
|
|
107
107
|
<GridLayout>
|
|
108
108
|
<Canvas #canvas style="width: 100%; height: auto" (ready)="onReady($event)"></Canvas>
|
|
109
109
|
</GridLayout>
|
|
110
110
|
`, isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
111
111
|
}
|
|
112
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.
|
|
112
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: NgtCanvasNative, decorators: [{
|
|
113
113
|
type: Component,
|
|
114
114
|
args: [{
|
|
115
115
|
selector: 'NgtCanvas',
|
|
@@ -30,10 +30,10 @@ export class NgtTestCanvas {
|
|
|
30
30
|
this.environmentInjector?.destroy();
|
|
31
31
|
this.ref?.destroy();
|
|
32
32
|
}
|
|
33
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.
|
|
34
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.2.
|
|
33
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: NgtTestCanvas, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
34
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.2.9", type: NgtTestCanvas, isStandalone: true, selector: "ngt-test-canvas", inputs: { sceneGraph: { classPropertyName: "sceneGraph", publicName: "sceneGraph", isSignal: true, isRequired: true, transformFunction: null } }, ngImport: i0, template: '', isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
35
35
|
}
|
|
36
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.
|
|
36
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: NgtTestCanvas, decorators: [{
|
|
37
37
|
type: Component,
|
|
38
38
|
args: [{
|
|
39
39
|
selector: 'ngt-test-canvas',
|
|
@@ -103,14 +103,14 @@ class NgtCanvasNative {
|
|
|
103
103
|
});
|
|
104
104
|
this.glRef.changeDetectorRef.detectChanges();
|
|
105
105
|
}
|
|
106
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.
|
|
107
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.2.0", version: "18.2.
|
|
106
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: NgtCanvasNative, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
107
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.2.0", version: "18.2.9", type: NgtCanvasNative, isStandalone: true, selector: "NgtCanvas", 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 }, lookAt: { classPropertyName: "lookAt", publicName: "lookAt", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { created: "created" }, providers: [{ provide: DOCUMENT, useValue: document }, provideStore()], viewQueries: [{ propertyName: "canvasViewContainerRef", first: true, predicate: ["canvas"], descendants: true, read: ViewContainerRef, isSignal: true }], ngImport: i0, template: `
|
|
108
108
|
<GridLayout>
|
|
109
109
|
<Canvas #canvas style="width: 100%; height: auto" (ready)="onReady($event)"></Canvas>
|
|
110
110
|
</GridLayout>
|
|
111
111
|
`, isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
112
112
|
}
|
|
113
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.
|
|
113
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: NgtCanvasNative, decorators: [{
|
|
114
114
|
type: Component,
|
|
115
115
|
args: [{
|
|
116
116
|
selector: 'NgtCanvas',
|
|
@@ -32,10 +32,10 @@ class NgtTestCanvas {
|
|
|
32
32
|
this.environmentInjector?.destroy();
|
|
33
33
|
this.ref?.destroy();
|
|
34
34
|
}
|
|
35
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.
|
|
36
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.2.
|
|
35
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: NgtTestCanvas, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
36
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.2.9", type: NgtTestCanvas, isStandalone: true, selector: "ngt-test-canvas", inputs: { sceneGraph: { classPropertyName: "sceneGraph", publicName: "sceneGraph", isSignal: true, isRequired: true, transformFunction: null } }, ngImport: i0, template: '', isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
37
37
|
}
|
|
38
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.
|
|
38
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: NgtTestCanvas, decorators: [{
|
|
39
39
|
type: Component,
|
|
40
40
|
args: [{
|
|
41
41
|
selector: 'ngt-test-canvas',
|