angular-three 2.13.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 +123 -106
- package/fesm2022/angular-three.mjs.map +1 -1
- package/lib/canvas.d.ts +7 -7
- package/lib/html.d.ts +2 -2
- 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/package.json +4 -10
- package/plugin/src/generators/init/schema.json +8 -8
- package/testing/lib/utils/web-gl-rendering-context.d.ts +1 -1
- 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 -275
- package/esm2022/lib/routed-scene.mjs +0 -33
- package/esm2022/lib/store.mjs +0 -176
- 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/esm2022/lib/roots.mjs
DELETED
|
@@ -1,275 +0,0 @@
|
|
|
1
|
-
import { assertInjector } from 'ngxtension/assert-injector';
|
|
2
|
-
import { ACESFilmicToneMapping, BasicShadowMap, ColorManagement, NoToneMapping, PCFShadowMap, PCFSoftShadowMap, Raycaster, Scene, VSMShadowMap, Vector3, } from 'three';
|
|
3
|
-
import { prepare } from './instance';
|
|
4
|
-
import { injectLoop, roots } from './loop';
|
|
5
|
-
import { injectStore } from './store';
|
|
6
|
-
import { applyProps } from './utils/apply-props';
|
|
7
|
-
import { is } from './utils/is';
|
|
8
|
-
import { makeCameraInstance, makeDpr, makeRendererInstance } from './utils/make';
|
|
9
|
-
import { checkNeedsUpdate } from './utils/update';
|
|
10
|
-
const shallowLoose = { objects: 'shallow', strict: false };
|
|
11
|
-
export function injectCanvasRootInitializer(injector) {
|
|
12
|
-
return assertInjector(injectCanvasRootInitializer, injector, () => {
|
|
13
|
-
const injectedStore = injectStore();
|
|
14
|
-
const loop = injectLoop();
|
|
15
|
-
return (canvas) => {
|
|
16
|
-
const exist = roots.has(canvas);
|
|
17
|
-
let store = roots.get(canvas);
|
|
18
|
-
if (store) {
|
|
19
|
-
console.warn('[NGT] Same canvas root is being created twice');
|
|
20
|
-
}
|
|
21
|
-
store ||= injectedStore;
|
|
22
|
-
if (!store) {
|
|
23
|
-
throw new Error('[NGT] No store initialized');
|
|
24
|
-
}
|
|
25
|
-
if (!exist) {
|
|
26
|
-
roots.set(canvas, store);
|
|
27
|
-
}
|
|
28
|
-
let isConfigured = false;
|
|
29
|
-
let lastCamera;
|
|
30
|
-
return {
|
|
31
|
-
isConfigured,
|
|
32
|
-
destroy: (timeout = 500) => {
|
|
33
|
-
const root = roots.get(canvas);
|
|
34
|
-
if (root) {
|
|
35
|
-
root.update((state) => ({ internal: { ...state.internal, active: false } }));
|
|
36
|
-
setTimeout(() => {
|
|
37
|
-
try {
|
|
38
|
-
const state = root.get();
|
|
39
|
-
state.events.disconnect?.();
|
|
40
|
-
state.gl?.renderLists?.dispose?.();
|
|
41
|
-
state.gl?.forceContextLoss?.();
|
|
42
|
-
if (state.gl?.xr)
|
|
43
|
-
state.xr.disconnect();
|
|
44
|
-
dispose(state);
|
|
45
|
-
roots.delete(canvas);
|
|
46
|
-
}
|
|
47
|
-
catch (e) {
|
|
48
|
-
console.error('[NGT] Unexpected error while destroying Canvas Root', e);
|
|
49
|
-
}
|
|
50
|
-
}, timeout);
|
|
51
|
-
}
|
|
52
|
-
},
|
|
53
|
-
configure: (inputs) => {
|
|
54
|
-
const { shadows = false, linear = false, flat = false, legacy = false, orthographic = false, frameloop = 'always', dpr = [1, 2], gl: glOptions, size: sizeOptions, camera: cameraOptions, raycaster: raycasterOptions, scene: sceneOptions, events, lookAt, performance, } = inputs;
|
|
55
|
-
const state = store.snapshot;
|
|
56
|
-
const stateToUpdate = {};
|
|
57
|
-
// setup renderer
|
|
58
|
-
let gl = state.gl;
|
|
59
|
-
if (!state.gl)
|
|
60
|
-
stateToUpdate.gl = gl = makeRendererInstance(glOptions, canvas);
|
|
61
|
-
// setup raycaster
|
|
62
|
-
let raycaster = state.raycaster;
|
|
63
|
-
if (!raycaster)
|
|
64
|
-
stateToUpdate.raycaster = raycaster = new Raycaster();
|
|
65
|
-
// set raycaster options
|
|
66
|
-
const { params, ...options } = raycasterOptions || {};
|
|
67
|
-
if (!is.equ(options, raycaster, shallowLoose))
|
|
68
|
-
applyProps(raycaster, options);
|
|
69
|
-
if (!is.equ(params, raycaster.params, shallowLoose)) {
|
|
70
|
-
applyProps(raycaster, { params: { ...raycaster.params, ...(params || {}) } });
|
|
71
|
-
}
|
|
72
|
-
// Create default camera, don't overwrite any user-set state
|
|
73
|
-
if (!state.camera || (state.camera === lastCamera && !is.equ(lastCamera, cameraOptions, shallowLoose))) {
|
|
74
|
-
lastCamera = cameraOptions;
|
|
75
|
-
const isCamera = is.camera(cameraOptions);
|
|
76
|
-
let camera = isCamera ? cameraOptions : makeCameraInstance(orthographic, state.size);
|
|
77
|
-
if (!isCamera) {
|
|
78
|
-
camera.position.z = 5;
|
|
79
|
-
if (cameraOptions) {
|
|
80
|
-
applyProps(camera, cameraOptions);
|
|
81
|
-
if ('aspect' in cameraOptions ||
|
|
82
|
-
'left' in cameraOptions ||
|
|
83
|
-
'right' in cameraOptions ||
|
|
84
|
-
'top' in cameraOptions ||
|
|
85
|
-
'bottom' in cameraOptions) {
|
|
86
|
-
Object.assign(camera, { manual: true });
|
|
87
|
-
camera?.updateProjectionMatrix();
|
|
88
|
-
}
|
|
89
|
-
}
|
|
90
|
-
// always look at center or passed-in lookAt by default
|
|
91
|
-
if (!state.camera && !cameraOptions?.rotation && !cameraOptions?.quaternion) {
|
|
92
|
-
if (Array.isArray(lookAt))
|
|
93
|
-
camera.lookAt(lookAt[0], lookAt[1], lookAt[2]);
|
|
94
|
-
else if (lookAt instanceof Vector3)
|
|
95
|
-
camera.lookAt(lookAt);
|
|
96
|
-
else
|
|
97
|
-
camera.lookAt(0, 0, 0);
|
|
98
|
-
}
|
|
99
|
-
// update projection matrix after applyprops
|
|
100
|
-
camera.updateProjectionMatrix?.();
|
|
101
|
-
}
|
|
102
|
-
if (!is.instance(camera))
|
|
103
|
-
camera = prepare(camera, { store });
|
|
104
|
-
stateToUpdate.camera = camera;
|
|
105
|
-
// Configure raycaster
|
|
106
|
-
// https://github.com/pmndrs/react-xr/issues/300
|
|
107
|
-
raycaster.camera = camera;
|
|
108
|
-
}
|
|
109
|
-
// Set up scene (one time only!)
|
|
110
|
-
if (!state.scene) {
|
|
111
|
-
let scene;
|
|
112
|
-
if (sceneOptions instanceof Scene) {
|
|
113
|
-
scene = sceneOptions;
|
|
114
|
-
}
|
|
115
|
-
else {
|
|
116
|
-
scene = new Scene();
|
|
117
|
-
if (sceneOptions)
|
|
118
|
-
applyProps(scene, sceneOptions);
|
|
119
|
-
}
|
|
120
|
-
applyProps(scene, {
|
|
121
|
-
setAttribute: (name, value) => {
|
|
122
|
-
if (canvas instanceof HTMLCanvasElement) {
|
|
123
|
-
if (canvas.parentElement) {
|
|
124
|
-
canvas.parentElement.setAttribute(name, value);
|
|
125
|
-
}
|
|
126
|
-
else {
|
|
127
|
-
canvas.setAttribute(name, value);
|
|
128
|
-
}
|
|
129
|
-
}
|
|
130
|
-
},
|
|
131
|
-
});
|
|
132
|
-
stateToUpdate.scene = prepare(scene, { store });
|
|
133
|
-
}
|
|
134
|
-
// Set up XR (one time only!)
|
|
135
|
-
if (!state.xr) {
|
|
136
|
-
// Handle frame behavior in WebXR
|
|
137
|
-
const handleXRFrame = (timestamp, frame) => {
|
|
138
|
-
const state = store.snapshot;
|
|
139
|
-
if (state.frameloop === 'never')
|
|
140
|
-
return;
|
|
141
|
-
loop.advance(timestamp, true, store, frame);
|
|
142
|
-
};
|
|
143
|
-
// Toggle render switching on session
|
|
144
|
-
const handleSessionChange = () => {
|
|
145
|
-
const state = store.snapshot;
|
|
146
|
-
state.gl.xr.enabled = state.gl.xr.isPresenting;
|
|
147
|
-
state.gl.xr.setAnimationLoop(state.gl.xr.isPresenting ? handleXRFrame : null);
|
|
148
|
-
if (!state.gl.xr.isPresenting)
|
|
149
|
-
loop.invalidate(store);
|
|
150
|
-
};
|
|
151
|
-
// WebXR session manager
|
|
152
|
-
const xr = {
|
|
153
|
-
connect: () => {
|
|
154
|
-
gl.xr.addEventListener('sessionstart', handleSessionChange);
|
|
155
|
-
gl.xr.addEventListener('sessionend', handleSessionChange);
|
|
156
|
-
},
|
|
157
|
-
disconnect: () => {
|
|
158
|
-
gl.xr.removeEventListener('sessionstart', handleSessionChange);
|
|
159
|
-
gl.xr.removeEventListener('sessionend', handleSessionChange);
|
|
160
|
-
},
|
|
161
|
-
};
|
|
162
|
-
// Subscribe to WebXR session events
|
|
163
|
-
if (gl.xr && typeof gl.xr.addEventListener === 'function')
|
|
164
|
-
xr.connect();
|
|
165
|
-
stateToUpdate.xr = xr;
|
|
166
|
-
}
|
|
167
|
-
// Set shadowmap
|
|
168
|
-
if (gl.shadowMap) {
|
|
169
|
-
const oldEnabled = gl.shadowMap.enabled;
|
|
170
|
-
const oldType = gl.shadowMap.type;
|
|
171
|
-
gl.shadowMap.enabled = !!shadows;
|
|
172
|
-
if (typeof shadows === 'boolean') {
|
|
173
|
-
gl.shadowMap.type = PCFSoftShadowMap;
|
|
174
|
-
}
|
|
175
|
-
else if (typeof shadows === 'string') {
|
|
176
|
-
const types = {
|
|
177
|
-
basic: BasicShadowMap,
|
|
178
|
-
percentage: PCFShadowMap,
|
|
179
|
-
soft: PCFSoftShadowMap,
|
|
180
|
-
variance: VSMShadowMap,
|
|
181
|
-
};
|
|
182
|
-
gl.shadowMap.type = types[shadows] ?? PCFSoftShadowMap;
|
|
183
|
-
}
|
|
184
|
-
else if (is.obj(shadows)) {
|
|
185
|
-
Object.assign(gl.shadowMap, shadows);
|
|
186
|
-
}
|
|
187
|
-
if (oldEnabled !== gl.shadowMap.enabled || oldType !== gl.shadowMap.type)
|
|
188
|
-
checkNeedsUpdate(gl.shadowMap);
|
|
189
|
-
}
|
|
190
|
-
// Safely set color management if available.
|
|
191
|
-
// Avoid accessing ColorManagement to play nice with older versions
|
|
192
|
-
if (ColorManagement) {
|
|
193
|
-
const colorManagement = ColorManagement;
|
|
194
|
-
if ('enabled' in colorManagement)
|
|
195
|
-
colorManagement['enabled'] = !legacy;
|
|
196
|
-
else if ('legacyMode' in colorManagement)
|
|
197
|
-
colorManagement['legacyMode'] = legacy;
|
|
198
|
-
}
|
|
199
|
-
if (!isConfigured) {
|
|
200
|
-
// set color space and tonemapping preferences once
|
|
201
|
-
const LinearEncoding = 3000;
|
|
202
|
-
const sRGBEncoding = 3001;
|
|
203
|
-
applyProps(gl, {
|
|
204
|
-
outputEncoding: linear ? LinearEncoding : sRGBEncoding,
|
|
205
|
-
toneMapping: flat ? NoToneMapping : ACESFilmicToneMapping,
|
|
206
|
-
});
|
|
207
|
-
}
|
|
208
|
-
// Update color management state
|
|
209
|
-
if (state.legacy !== legacy)
|
|
210
|
-
stateToUpdate.legacy = legacy;
|
|
211
|
-
if (state.linear !== linear)
|
|
212
|
-
stateToUpdate.linear = linear;
|
|
213
|
-
if (state.flat !== flat)
|
|
214
|
-
stateToUpdate.flat = flat;
|
|
215
|
-
// Set gl props
|
|
216
|
-
if (gl.setClearAlpha) {
|
|
217
|
-
gl.setClearAlpha(0);
|
|
218
|
-
}
|
|
219
|
-
gl.setPixelRatio(makeDpr(state.viewport.dpr ?? dpr));
|
|
220
|
-
gl.setSize(sizeOptions?.width ?? state.size.width, sizeOptions?.height ?? state.size.height);
|
|
221
|
-
if (is.obj(glOptions) &&
|
|
222
|
-
!(typeof glOptions === 'function') &&
|
|
223
|
-
!is.renderer(glOptions) &&
|
|
224
|
-
!is.equ(glOptions, gl, shallowLoose)) {
|
|
225
|
-
applyProps(gl, glOptions);
|
|
226
|
-
}
|
|
227
|
-
// Store events internally
|
|
228
|
-
if (events && !state.events.handlers)
|
|
229
|
-
stateToUpdate.events = events(store);
|
|
230
|
-
// Check performance
|
|
231
|
-
if (performance && !is.equ(performance, state.performance, shallowLoose)) {
|
|
232
|
-
stateToUpdate.performance = { ...state.performance, ...performance };
|
|
233
|
-
}
|
|
234
|
-
if (Object.keys(stateToUpdate).length) {
|
|
235
|
-
store.update(stateToUpdate);
|
|
236
|
-
}
|
|
237
|
-
// Check size, allow it to take on container bounds initially
|
|
238
|
-
const size = computeInitialSize(canvas, sizeOptions);
|
|
239
|
-
if (!is.equ(size, state.size, shallowLoose)) {
|
|
240
|
-
state.setSize(size.width, size.height, size.top, size.left);
|
|
241
|
-
}
|
|
242
|
-
// Check pixelratio
|
|
243
|
-
if (dpr && state.viewport.dpr !== makeDpr(dpr))
|
|
244
|
-
state.setDpr(dpr);
|
|
245
|
-
// Check frameloop
|
|
246
|
-
if (state.frameloop !== frameloop)
|
|
247
|
-
state.setFrameloop(frameloop);
|
|
248
|
-
isConfigured = true;
|
|
249
|
-
},
|
|
250
|
-
};
|
|
251
|
-
};
|
|
252
|
-
});
|
|
253
|
-
}
|
|
254
|
-
function computeInitialSize(canvas, defaultSize) {
|
|
255
|
-
if (defaultSize) {
|
|
256
|
-
return defaultSize;
|
|
257
|
-
}
|
|
258
|
-
if (typeof HTMLCanvasElement !== 'undefined' && canvas instanceof HTMLCanvasElement && canvas.parentElement) {
|
|
259
|
-
return canvas.parentElement.getBoundingClientRect();
|
|
260
|
-
}
|
|
261
|
-
if (typeof OffscreenCanvas !== 'undefined' && canvas instanceof OffscreenCanvas) {
|
|
262
|
-
return { width: canvas.width, height: canvas.height, top: 0, left: 0 };
|
|
263
|
-
}
|
|
264
|
-
return { width: 0, height: 0, top: 0, left: 0 };
|
|
265
|
-
}
|
|
266
|
-
// Disposes an object and all its properties
|
|
267
|
-
export function dispose(obj) {
|
|
268
|
-
if (obj.dispose && obj.type !== 'Scene')
|
|
269
|
-
obj.dispose();
|
|
270
|
-
for (const p in obj) {
|
|
271
|
-
p.dispose?.();
|
|
272
|
-
delete obj[p];
|
|
273
|
-
}
|
|
274
|
-
}
|
|
275
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"roots.js","sourceRoot":"","sources":["../../../../../libs/core/src/lib/roots.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injector } from '@angular/core';\nimport { assertInjector } from 'ngxtension/assert-injector';\nimport {\n\tACESFilmicToneMapping,\n\tBasicShadowMap,\n\tColorManagement,\n\tNoToneMapping,\n\tPCFShadowMap,\n\tPCFSoftShadowMap,\n\tRaycaster,\n\tScene,\n\tVSMShadowMap,\n\tVector3,\n} from 'three';\nimport { prepare } from './instance';\nimport { injectLoop, roots } from './loop';\nimport { injectStore } from './store';\nimport { NgtAnyRecord, NgtCanvasElement, NgtCanvasOptions, NgtEquConfig, NgtSize, NgtState } from './types';\nimport { applyProps } from './utils/apply-props';\nimport { is } from './utils/is';\nimport { makeCameraInstance, makeDpr, makeRendererInstance } from './utils/make';\nimport { NgtSignalStore } from './utils/signal-store';\nimport { checkNeedsUpdate } from './utils/update';\n\nconst shallowLoose = { objects: 'shallow', strict: false } as NgtEquConfig;\n\nexport function injectCanvasRootInitializer(injector?: Injector) {\n\treturn assertInjector(injectCanvasRootInitializer, injector, () => {\n\t\tconst injectedStore = injectStore();\n\t\tconst loop = injectLoop();\n\n\t\treturn (canvas: NgtCanvasElement) => {\n\t\t\tconst exist = roots.has(canvas);\n\t\t\tlet store = roots.get(canvas) as NgtSignalStore<NgtState>;\n\n\t\t\tif (store) {\n\t\t\t\tconsole.warn('[NGT] Same canvas root is being created twice');\n\t\t\t}\n\n\t\t\tstore ||= injectedStore;\n\n\t\t\tif (!store) {\n\t\t\t\tthrow new Error('[NGT] No store initialized');\n\t\t\t}\n\n\t\t\tif (!exist) {\n\t\t\t\troots.set(canvas, store);\n\t\t\t}\n\n\t\t\tlet isConfigured = false;\n\t\t\tlet lastCamera: NgtCanvasOptions['camera'];\n\n\t\t\treturn {\n\t\t\t\tisConfigured,\n\t\t\t\tdestroy: (timeout = 500) => {\n\t\t\t\t\tconst root = roots.get(canvas);\n\t\t\t\t\tif (root) {\n\t\t\t\t\t\troot.update((state) => ({ internal: { ...state.internal, active: false } }));\n\t\t\t\t\t\tsetTimeout(() => {\n\t\t\t\t\t\t\ttry {\n\t\t\t\t\t\t\t\tconst state = root.get();\n\t\t\t\t\t\t\t\tstate.events.disconnect?.();\n\t\t\t\t\t\t\t\tstate.gl?.renderLists?.dispose?.();\n\t\t\t\t\t\t\t\tstate.gl?.forceContextLoss?.();\n\t\t\t\t\t\t\t\tif (state.gl?.xr) state.xr.disconnect();\n\t\t\t\t\t\t\t\tdispose(state);\n\t\t\t\t\t\t\t\troots.delete(canvas);\n\t\t\t\t\t\t\t} catch (e) {\n\t\t\t\t\t\t\t\tconsole.error('[NGT] Unexpected error while destroying Canvas Root', e);\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}, timeout);\n\t\t\t\t\t}\n\t\t\t\t},\n\t\t\t\tconfigure: (inputs: NgtCanvasOptions) => {\n\t\t\t\t\tconst {\n\t\t\t\t\t\tshadows = false,\n\t\t\t\t\t\tlinear = false,\n\t\t\t\t\t\tflat = false,\n\t\t\t\t\t\tlegacy = false,\n\t\t\t\t\t\torthographic = false,\n\t\t\t\t\t\tframeloop = 'always',\n\t\t\t\t\t\tdpr = [1, 2],\n\t\t\t\t\t\tgl: glOptions,\n\t\t\t\t\t\tsize: sizeOptions,\n\t\t\t\t\t\tcamera: cameraOptions,\n\t\t\t\t\t\traycaster: raycasterOptions,\n\t\t\t\t\t\tscene: sceneOptions,\n\t\t\t\t\t\tevents,\n\t\t\t\t\t\tlookAt,\n\t\t\t\t\t\tperformance,\n\t\t\t\t\t} = inputs;\n\n\t\t\t\t\tconst state = store.snapshot;\n\t\t\t\t\tconst stateToUpdate: Partial<NgtState> = {};\n\n\t\t\t\t\t// setup renderer\n\t\t\t\t\tlet gl = state.gl;\n\t\t\t\t\tif (!state.gl) stateToUpdate.gl = gl = makeRendererInstance(glOptions, canvas);\n\n\t\t\t\t\t// setup raycaster\n\t\t\t\t\tlet raycaster = state.raycaster;\n\t\t\t\t\tif (!raycaster) stateToUpdate.raycaster = raycaster = new Raycaster();\n\n\t\t\t\t\t// set raycaster options\n\t\t\t\t\tconst { params, ...options } = raycasterOptions || {};\n\t\t\t\t\tif (!is.equ(options, raycaster, shallowLoose)) applyProps(raycaster, options);\n\t\t\t\t\tif (!is.equ(params, raycaster.params, shallowLoose)) {\n\t\t\t\t\t\tapplyProps(raycaster, { params: { ...raycaster.params, ...(params || {}) } });\n\t\t\t\t\t}\n\n\t\t\t\t\t// Create default camera, don't overwrite any user-set state\n\t\t\t\t\tif (!state.camera || (state.camera === lastCamera && !is.equ(lastCamera, cameraOptions, shallowLoose))) {\n\t\t\t\t\t\tlastCamera = cameraOptions;\n\t\t\t\t\t\tconst isCamera = is.camera(cameraOptions);\n\t\t\t\t\t\tlet camera = isCamera ? cameraOptions : makeCameraInstance(orthographic, state.size);\n\n\t\t\t\t\t\tif (!isCamera) {\n\t\t\t\t\t\t\tcamera.position.z = 5;\n\t\t\t\t\t\t\tif (cameraOptions) {\n\t\t\t\t\t\t\t\tapplyProps(camera, cameraOptions);\n\t\t\t\t\t\t\t\tif (\n\t\t\t\t\t\t\t\t\t'aspect' in cameraOptions ||\n\t\t\t\t\t\t\t\t\t'left' in cameraOptions ||\n\t\t\t\t\t\t\t\t\t'right' in cameraOptions ||\n\t\t\t\t\t\t\t\t\t'top' in cameraOptions ||\n\t\t\t\t\t\t\t\t\t'bottom' in cameraOptions\n\t\t\t\t\t\t\t\t) {\n\t\t\t\t\t\t\t\t\tObject.assign(camera, { manual: true });\n\t\t\t\t\t\t\t\t\tcamera?.updateProjectionMatrix();\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t// always look at center or passed-in lookAt by default\n\t\t\t\t\t\t\tif (!state.camera && !cameraOptions?.rotation && !cameraOptions?.quaternion) {\n\t\t\t\t\t\t\t\tif (Array.isArray(lookAt)) camera.lookAt(lookAt[0], lookAt[1], lookAt[2]);\n\t\t\t\t\t\t\t\telse if (lookAt instanceof Vector3) camera.lookAt(lookAt);\n\t\t\t\t\t\t\t\telse camera.lookAt(0, 0, 0);\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t// update projection matrix after applyprops\n\t\t\t\t\t\t\tcamera.updateProjectionMatrix?.();\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tif (!is.instance(camera)) camera = prepare(camera, { store });\n\n\t\t\t\t\t\tstateToUpdate.camera = camera;\n\n\t\t\t\t\t\t// Configure raycaster\n\t\t\t\t\t\t// https://github.com/pmndrs/react-xr/issues/300\n\t\t\t\t\t\traycaster.camera = camera;\n\t\t\t\t\t}\n\n\t\t\t\t\t// Set up scene (one time only!)\n\t\t\t\t\tif (!state.scene) {\n\t\t\t\t\t\tlet scene: Scene;\n\n\t\t\t\t\t\tif (sceneOptions instanceof Scene) {\n\t\t\t\t\t\t\tscene = sceneOptions;\n\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\tscene = new Scene();\n\t\t\t\t\t\t\tif (sceneOptions) applyProps(scene, sceneOptions);\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tapplyProps(scene, {\n\t\t\t\t\t\t\tsetAttribute: (name: string, value: string) => {\n\t\t\t\t\t\t\t\tif (canvas instanceof HTMLCanvasElement) {\n\t\t\t\t\t\t\t\t\tif (canvas.parentElement) {\n\t\t\t\t\t\t\t\t\t\tcanvas.parentElement.setAttribute(name, value);\n\t\t\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\t\t\tcanvas.setAttribute(name, value);\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t});\n\n\t\t\t\t\t\tstateToUpdate.scene = prepare(scene, { store });\n\t\t\t\t\t}\n\n\t\t\t\t\t// Set up XR (one time only!)\n\t\t\t\t\tif (!state.xr) {\n\t\t\t\t\t\t// Handle frame behavior in WebXR\n\t\t\t\t\t\tconst handleXRFrame: XRFrameRequestCallback = (timestamp: number, frame?: XRFrame) => {\n\t\t\t\t\t\t\tconst state = store.snapshot;\n\t\t\t\t\t\t\tif (state.frameloop === 'never') return;\n\t\t\t\t\t\t\tloop.advance(timestamp, true, store, frame);\n\t\t\t\t\t\t};\n\n\t\t\t\t\t\t// Toggle render switching on session\n\t\t\t\t\t\tconst handleSessionChange = () => {\n\t\t\t\t\t\t\tconst state = store.snapshot;\n\t\t\t\t\t\t\tstate.gl.xr.enabled = state.gl.xr.isPresenting;\n\t\t\t\t\t\t\tstate.gl.xr.setAnimationLoop(state.gl.xr.isPresenting ? handleXRFrame : null);\n\t\t\t\t\t\t\tif (!state.gl.xr.isPresenting) loop.invalidate(store);\n\t\t\t\t\t\t};\n\n\t\t\t\t\t\t// WebXR session manager\n\t\t\t\t\t\tconst xr = {\n\t\t\t\t\t\t\tconnect: () => {\n\t\t\t\t\t\t\t\tgl.xr.addEventListener('sessionstart', handleSessionChange);\n\t\t\t\t\t\t\t\tgl.xr.addEventListener('sessionend', handleSessionChange);\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\tdisconnect: () => {\n\t\t\t\t\t\t\t\tgl.xr.removeEventListener('sessionstart', handleSessionChange);\n\t\t\t\t\t\t\t\tgl.xr.removeEventListener('sessionend', handleSessionChange);\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t};\n\n\t\t\t\t\t\t// Subscribe to WebXR session events\n\t\t\t\t\t\tif (gl.xr && typeof gl.xr.addEventListener === 'function') xr.connect();\n\t\t\t\t\t\tstateToUpdate.xr = xr;\n\t\t\t\t\t}\n\n\t\t\t\t\t// Set shadowmap\n\t\t\t\t\tif (gl.shadowMap) {\n\t\t\t\t\t\tconst oldEnabled = gl.shadowMap.enabled;\n\t\t\t\t\t\tconst oldType = gl.shadowMap.type;\n\t\t\t\t\t\tgl.shadowMap.enabled = !!shadows;\n\n\t\t\t\t\t\tif (typeof shadows === 'boolean') {\n\t\t\t\t\t\t\tgl.shadowMap.type = PCFSoftShadowMap;\n\t\t\t\t\t\t} else if (typeof shadows === 'string') {\n\t\t\t\t\t\t\tconst types = {\n\t\t\t\t\t\t\t\tbasic: BasicShadowMap,\n\t\t\t\t\t\t\t\tpercentage: PCFShadowMap,\n\t\t\t\t\t\t\t\tsoft: PCFSoftShadowMap,\n\t\t\t\t\t\t\t\tvariance: VSMShadowMap,\n\t\t\t\t\t\t\t};\n\t\t\t\t\t\t\tgl.shadowMap.type = types[shadows] ?? PCFSoftShadowMap;\n\t\t\t\t\t\t} else if (is.obj(shadows)) {\n\t\t\t\t\t\t\tObject.assign(gl.shadowMap, shadows);\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tif (oldEnabled !== gl.shadowMap.enabled || oldType !== gl.shadowMap.type) checkNeedsUpdate(gl.shadowMap);\n\t\t\t\t\t}\n\n\t\t\t\t\t// Safely set color management if available.\n\t\t\t\t\t// Avoid accessing ColorManagement to play nice with older versions\n\t\t\t\t\tif (ColorManagement) {\n\t\t\t\t\t\tconst colorManagement = ColorManagement as NgtAnyRecord;\n\t\t\t\t\t\tif ('enabled' in colorManagement) colorManagement['enabled'] = !legacy;\n\t\t\t\t\t\telse if ('legacyMode' in colorManagement) colorManagement['legacyMode'] = legacy;\n\t\t\t\t\t}\n\n\t\t\t\t\tif (!isConfigured) {\n\t\t\t\t\t\t// set color space and tonemapping preferences once\n\t\t\t\t\t\tconst LinearEncoding = 3000;\n\t\t\t\t\t\tconst sRGBEncoding = 3001;\n\t\t\t\t\t\tapplyProps(gl, {\n\t\t\t\t\t\t\toutputEncoding: linear ? LinearEncoding : sRGBEncoding,\n\t\t\t\t\t\t\ttoneMapping: flat ? NoToneMapping : ACESFilmicToneMapping,\n\t\t\t\t\t\t});\n\t\t\t\t\t}\n\n\t\t\t\t\t// Update color management state\n\t\t\t\t\tif (state.legacy !== legacy) stateToUpdate.legacy = legacy;\n\t\t\t\t\tif (state.linear !== linear) stateToUpdate.linear = linear;\n\t\t\t\t\tif (state.flat !== flat) stateToUpdate.flat = flat;\n\n\t\t\t\t\t// Set gl props\n\t\t\t\t\tif (gl.setClearAlpha) {\n\t\t\t\t\t\tgl.setClearAlpha(0);\n\t\t\t\t\t}\n\t\t\t\t\tgl.setPixelRatio(makeDpr(state.viewport.dpr ?? dpr));\n\t\t\t\t\tgl.setSize(sizeOptions?.width ?? state.size.width, sizeOptions?.height ?? state.size.height);\n\n\t\t\t\t\tif (\n\t\t\t\t\t\tis.obj(glOptions) &&\n\t\t\t\t\t\t!(typeof glOptions === 'function') &&\n\t\t\t\t\t\t!is.renderer(glOptions) &&\n\t\t\t\t\t\t!is.equ(glOptions, gl, shallowLoose)\n\t\t\t\t\t) {\n\t\t\t\t\t\tapplyProps(gl, glOptions);\n\t\t\t\t\t}\n\n\t\t\t\t\t// Store events internally\n\t\t\t\t\tif (events && !state.events.handlers) stateToUpdate.events = events(store);\n\n\t\t\t\t\t// Check performance\n\t\t\t\t\tif (performance && !is.equ(performance, state.performance, shallowLoose)) {\n\t\t\t\t\t\tstateToUpdate.performance = { ...state.performance, ...performance };\n\t\t\t\t\t}\n\n\t\t\t\t\tif (Object.keys(stateToUpdate).length) {\n\t\t\t\t\t\tstore.update(stateToUpdate);\n\t\t\t\t\t}\n\n\t\t\t\t\t// Check size, allow it to take on container bounds initially\n\t\t\t\t\tconst size = computeInitialSize(canvas, sizeOptions);\n\t\t\t\t\tif (!is.equ(size, state.size, shallowLoose)) {\n\t\t\t\t\t\tstate.setSize(size.width, size.height, size.top, size.left);\n\t\t\t\t\t}\n\n\t\t\t\t\t// Check pixelratio\n\t\t\t\t\tif (dpr && state.viewport.dpr !== makeDpr(dpr)) state.setDpr(dpr);\n\t\t\t\t\t// Check frameloop\n\t\t\t\t\tif (state.frameloop !== frameloop) state.setFrameloop(frameloop);\n\n\t\t\t\t\tisConfigured = true;\n\t\t\t\t},\n\t\t\t};\n\t\t};\n\t});\n}\n\nexport type NgtCanvasConfigurator = ReturnType<ReturnType<typeof injectCanvasRootInitializer>>;\n\nfunction computeInitialSize(canvas: NgtCanvasElement, defaultSize?: NgtSize): NgtSize {\n\tif (defaultSize) {\n\t\treturn defaultSize;\n\t}\n\n\tif (typeof HTMLCanvasElement !== 'undefined' && canvas instanceof HTMLCanvasElement && canvas.parentElement) {\n\t\treturn canvas.parentElement.getBoundingClientRect();\n\t}\n\n\tif (typeof OffscreenCanvas !== 'undefined' && canvas instanceof OffscreenCanvas) {\n\t\treturn { width: canvas.width, height: canvas.height, top: 0, left: 0 };\n\t}\n\n\treturn { width: 0, height: 0, top: 0, left: 0 };\n}\n\n// Disposes an object and all its properties\nexport function dispose<TObj extends { dispose?: () => void; type?: string; [key: string]: any }>(obj: TObj) {\n\tif (obj.dispose && obj.type !== 'Scene') obj.dispose();\n\tfor (const p in obj) {\n\t\t(p as any).dispose?.();\n\t\tdelete obj[p];\n\t}\n}\n"]}
|
|
@@ -1,33 +0,0 @@
|
|
|
1
|
-
var _a;
|
|
2
|
-
import { ChangeDetectorRef, Component } from '@angular/core';
|
|
3
|
-
import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
|
|
4
|
-
import { ActivationEnd, Router, RouterOutlet } from '@angular/router';
|
|
5
|
-
import { filter } from 'rxjs';
|
|
6
|
-
import { ROUTED_SCENE } from './renderer/constants';
|
|
7
|
-
import * as i0 from "@angular/core";
|
|
8
|
-
import * as i1 from "@angular/router";
|
|
9
|
-
export class NgtRoutedScene {
|
|
10
|
-
static { _a = ROUTED_SCENE; }
|
|
11
|
-
static { this[_a] = true; }
|
|
12
|
-
constructor(router, cdr) {
|
|
13
|
-
router.events
|
|
14
|
-
.pipe(filter((event) => event instanceof ActivationEnd), takeUntilDestroyed())
|
|
15
|
-
.subscribe(cdr.detectChanges.bind(cdr));
|
|
16
|
-
}
|
|
17
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: NgtRoutedScene, deps: [{ token: i1.Router }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
18
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.11", type: NgtRoutedScene, isStandalone: true, selector: "ngt-routed-scene", ngImport: i0, template: `
|
|
19
|
-
<router-outlet />
|
|
20
|
-
`, isInline: true, dependencies: [{ kind: "directive", type: RouterOutlet, selector: "router-outlet", inputs: ["name"], outputs: ["activate", "deactivate", "attach", "detach"], exportAs: ["outlet"] }] }); }
|
|
21
|
-
}
|
|
22
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: NgtRoutedScene, decorators: [{
|
|
23
|
-
type: Component,
|
|
24
|
-
args: [{
|
|
25
|
-
standalone: true,
|
|
26
|
-
selector: 'ngt-routed-scene',
|
|
27
|
-
template: `
|
|
28
|
-
<router-outlet />
|
|
29
|
-
`,
|
|
30
|
-
imports: [RouterOutlet],
|
|
31
|
-
}]
|
|
32
|
-
}], ctorParameters: () => [{ type: i1.Router }, { type: i0.ChangeDetectorRef }] });
|
|
33
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicm91dGVkLXNjZW5lLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vbGlicy9jb3JlL3NyYy9saWIvcm91dGVkLXNjZW5lLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsU0FBUyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQzdELE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLDRCQUE0QixDQUFDO0FBQ2hFLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQ3RFLE9BQU8sRUFBRSxNQUFNLEVBQUUsTUFBTSxNQUFNLENBQUM7QUFDOUIsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLHNCQUFzQixDQUFDOzs7QUFVcEQsTUFBTSxPQUFPLGNBQWM7a0JBQ2xCLFlBQVk7YUFBYixRQUFjLEdBQUcsSUFBSSxBQUFQLENBQVE7SUFFN0IsWUFBWSxNQUFjLEVBQUUsR0FBc0I7UUFDakQsTUFBTSxDQUFDLE1BQU07YUFDWCxJQUFJLENBQ0osTUFBTSxDQUFDLENBQUMsS0FBSyxFQUFFLEVBQUUsQ0FBQyxLQUFLLFlBQVksYUFBYSxDQUFDLEVBQ2pELGtCQUFrQixFQUFFLENBQ3BCO2FBQ0EsU0FBUyxDQUFDLEdBQUcsQ0FBQyxhQUFhLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUM7SUFDMUMsQ0FBQzsrR0FWVyxjQUFjO21HQUFkLGNBQWMsNEVBTGhCOztFQUVULDREQUNTLFlBQVk7OzRGQUVWLGNBQWM7a0JBUjFCLFNBQVM7bUJBQUM7b0JBQ1YsVUFBVSxFQUFFLElBQUk7b0JBQ2hCLFFBQVEsRUFBRSxrQkFBa0I7b0JBQzVCLFFBQVEsRUFBRTs7RUFFVDtvQkFDRCxPQUFPLEVBQUUsQ0FBQyxZQUFZLENBQUM7aUJBQ3ZCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0b3JSZWYsIENvbXBvbmVudCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgdGFrZVVudGlsRGVzdHJveWVkIH0gZnJvbSAnQGFuZ3VsYXIvY29yZS9yeGpzLWludGVyb3AnO1xuaW1wb3J0IHsgQWN0aXZhdGlvbkVuZCwgUm91dGVyLCBSb3V0ZXJPdXRsZXQgfSBmcm9tICdAYW5ndWxhci9yb3V0ZXInO1xuaW1wb3J0IHsgZmlsdGVyIH0gZnJvbSAncnhqcyc7XG5pbXBvcnQgeyBST1VURURfU0NFTkUgfSBmcm9tICcuL3JlbmRlcmVyL2NvbnN0YW50cyc7XG5cbkBDb21wb25lbnQoe1xuXHRzdGFuZGFsb25lOiB0cnVlLFxuXHRzZWxlY3RvcjogJ25ndC1yb3V0ZWQtc2NlbmUnLFxuXHR0ZW1wbGF0ZTogYFxuXHRcdDxyb3V0ZXItb3V0bGV0IC8+XG5cdGAsXG5cdGltcG9ydHM6IFtSb3V0ZXJPdXRsZXRdLFxufSlcbmV4cG9ydCBjbGFzcyBOZ3RSb3V0ZWRTY2VuZSB7XG5cdHN0YXRpYyBbUk9VVEVEX1NDRU5FXSA9IHRydWU7XG5cblx0Y29uc3RydWN0b3Iocm91dGVyOiBSb3V0ZXIsIGNkcjogQ2hhbmdlRGV0ZWN0b3JSZWYpIHtcblx0XHRyb3V0ZXIuZXZlbnRzXG5cdFx0XHQucGlwZShcblx0XHRcdFx0ZmlsdGVyKChldmVudCkgPT4gZXZlbnQgaW5zdGFuY2VvZiBBY3RpdmF0aW9uRW5kKSxcblx0XHRcdFx0dGFrZVVudGlsRGVzdHJveWVkKCksXG5cdFx0XHQpXG5cdFx0XHQuc3Vic2NyaWJlKGNkci5kZXRlY3RDaGFuZ2VzLmJpbmQoY2RyKSk7XG5cdH1cbn1cbiJdfQ==
|
package/esm2022/lib/store.mjs
DELETED
|
@@ -1,176 +0,0 @@
|
|
|
1
|
-
import { ElementRef, InjectionToken, effect, inject } from '@angular/core';
|
|
2
|
-
import { Subject } from 'rxjs';
|
|
3
|
-
import { Clock, Vector2, Vector3 } from 'three';
|
|
4
|
-
import { injectLoop } from './loop';
|
|
5
|
-
import { is } from './utils/is';
|
|
6
|
-
import { makeDpr } from './utils/make';
|
|
7
|
-
import { signalStore } from './utils/signal-store';
|
|
8
|
-
import { updateCamera } from './utils/update';
|
|
9
|
-
function storeFactory(previousStore) {
|
|
10
|
-
const loop = injectLoop();
|
|
11
|
-
// NOTE: using Subject because we do not care about late-subscribers
|
|
12
|
-
const pointerMissed$ = new Subject();
|
|
13
|
-
const store = signalStore(({ get, update }) => {
|
|
14
|
-
const { invalidate, advance } = loop;
|
|
15
|
-
const position = new Vector3();
|
|
16
|
-
const defaultTarget = new Vector3();
|
|
17
|
-
const tempTarget = new Vector3();
|
|
18
|
-
function getCurrentViewport(camera = get('camera'), target = defaultTarget, size = get('size')) {
|
|
19
|
-
const { width, height, top, left } = size;
|
|
20
|
-
const aspect = width / height;
|
|
21
|
-
if (target instanceof Vector3)
|
|
22
|
-
tempTarget.copy(target);
|
|
23
|
-
else
|
|
24
|
-
tempTarget.set(...target);
|
|
25
|
-
const distance = camera.getWorldPosition(position).distanceTo(tempTarget);
|
|
26
|
-
if (is.orthographicCamera(camera)) {
|
|
27
|
-
return { width: width / camera.zoom, height: height / camera.zoom, top, left, factor: 1, distance, aspect };
|
|
28
|
-
}
|
|
29
|
-
const fov = (camera.fov * Math.PI) / 180; // convert vertical fov to radians
|
|
30
|
-
const h = 2 * Math.tan(fov / 2) * distance; // visible height
|
|
31
|
-
const w = h * (width / height);
|
|
32
|
-
return { width: w, height: h, top, left, factor: width / w, distance, aspect };
|
|
33
|
-
}
|
|
34
|
-
let performanceTimeout = undefined;
|
|
35
|
-
const setPerformanceCurrent = (current) => update((state) => ({ performance: { ...state.performance, current } }));
|
|
36
|
-
const pointer = new Vector2();
|
|
37
|
-
return {
|
|
38
|
-
pointerMissed$: pointerMissed$.asObservable(),
|
|
39
|
-
events: { priority: 1, enabled: true, connected: false },
|
|
40
|
-
invalidate: (frames = 1) => invalidate(store, frames),
|
|
41
|
-
advance: (timestamp, runGlobalEffects) => advance(timestamp, runGlobalEffects, store),
|
|
42
|
-
legacy: false,
|
|
43
|
-
linear: false,
|
|
44
|
-
flat: false,
|
|
45
|
-
controls: null,
|
|
46
|
-
clock: new Clock(),
|
|
47
|
-
pointer,
|
|
48
|
-
frameloop: 'always',
|
|
49
|
-
performance: {
|
|
50
|
-
current: 1,
|
|
51
|
-
min: 0.5,
|
|
52
|
-
max: 1,
|
|
53
|
-
debounce: 200,
|
|
54
|
-
regress: () => {
|
|
55
|
-
const state = get();
|
|
56
|
-
// Clear timeout
|
|
57
|
-
if (performanceTimeout)
|
|
58
|
-
clearTimeout(performanceTimeout);
|
|
59
|
-
// Set lower bound performance
|
|
60
|
-
if (state.performance.current !== state.performance.min)
|
|
61
|
-
setPerformanceCurrent(state.performance.min);
|
|
62
|
-
// Go back to upper bound performance after a while unless something regresses meanwhile
|
|
63
|
-
performanceTimeout = setTimeout(() => {
|
|
64
|
-
setPerformanceCurrent(get('performance', 'max'));
|
|
65
|
-
// safeDetectChanges(cdr);
|
|
66
|
-
}, state.performance.debounce);
|
|
67
|
-
},
|
|
68
|
-
},
|
|
69
|
-
size: { width: 0, height: 0, top: 0, left: 0, updateStyle: false },
|
|
70
|
-
viewport: {
|
|
71
|
-
initialDpr: 0,
|
|
72
|
-
dpr: 0,
|
|
73
|
-
width: 0,
|
|
74
|
-
height: 0,
|
|
75
|
-
top: 0,
|
|
76
|
-
left: 0,
|
|
77
|
-
aspect: 0,
|
|
78
|
-
distance: 0,
|
|
79
|
-
factor: 0,
|
|
80
|
-
getCurrentViewport,
|
|
81
|
-
},
|
|
82
|
-
setEvents: (events) => update((state) => ({ ...state, events: { ...state.events, ...events } })),
|
|
83
|
-
setSize: (width, height, top, left) => {
|
|
84
|
-
const camera = get('camera');
|
|
85
|
-
const size = { width, height, top: top || 0, left: left || 0 };
|
|
86
|
-
update((state) => ({
|
|
87
|
-
size,
|
|
88
|
-
viewport: { ...state.viewport, ...getCurrentViewport(camera, defaultTarget, size) },
|
|
89
|
-
}));
|
|
90
|
-
},
|
|
91
|
-
setDpr: (dpr) => update((state) => {
|
|
92
|
-
const resolved = makeDpr(dpr, window);
|
|
93
|
-
return { viewport: { ...state.viewport, dpr: resolved, initialDpr: state.viewport.initialDpr || resolved } };
|
|
94
|
-
}),
|
|
95
|
-
setFrameloop: (frameloop = 'always') => {
|
|
96
|
-
const clock = get('clock');
|
|
97
|
-
// if frameloop === "never" clock.elapsedTime is updated using advance(timestamp)
|
|
98
|
-
clock.stop();
|
|
99
|
-
clock.elapsedTime = 0;
|
|
100
|
-
if (frameloop !== 'never') {
|
|
101
|
-
clock.start();
|
|
102
|
-
clock.elapsedTime = 0;
|
|
103
|
-
}
|
|
104
|
-
update(() => ({ frameloop }));
|
|
105
|
-
},
|
|
106
|
-
previousRoot: previousStore,
|
|
107
|
-
internal: {
|
|
108
|
-
active: false,
|
|
109
|
-
priority: 0,
|
|
110
|
-
frames: 0,
|
|
111
|
-
lastEvent: new ElementRef(null),
|
|
112
|
-
interaction: [],
|
|
113
|
-
hovered: new Map(),
|
|
114
|
-
subscribers: [],
|
|
115
|
-
initialClick: [0, 0],
|
|
116
|
-
initialHits: [],
|
|
117
|
-
capturedMap: new Map(),
|
|
118
|
-
subscribe: (callback, priority = 0, _store = store) => {
|
|
119
|
-
const internal = get('internal');
|
|
120
|
-
// If this subscription was given a priority, it takes rendering into its own hands
|
|
121
|
-
// For that reason we switch off automatic rendering and increase the manual flag
|
|
122
|
-
// As long as this flag is positive there can be no internal rendering at all
|
|
123
|
-
// because there could be multiple render subscriptions
|
|
124
|
-
internal.priority = internal.priority + (priority > 0 ? 1 : 0);
|
|
125
|
-
internal.subscribers.push({ callback, priority, store: _store });
|
|
126
|
-
// Register subscriber and sort layers from lowest to highest, meaning,
|
|
127
|
-
// highest priority renders last (on top of the other frames)
|
|
128
|
-
internal.subscribers = internal.subscribers.sort((a, b) => (a.priority || 0) - (b.priority || 0));
|
|
129
|
-
return () => {
|
|
130
|
-
const internal = get('internal');
|
|
131
|
-
if (internal?.subscribers) {
|
|
132
|
-
// Decrease manual flag if this subscription had a priority
|
|
133
|
-
internal.priority = internal.priority - (priority > 0 ? 1 : 0);
|
|
134
|
-
// Remove subscriber from list
|
|
135
|
-
internal.subscribers = internal.subscribers.filter((s) => s.callback !== callback);
|
|
136
|
-
}
|
|
137
|
-
};
|
|
138
|
-
},
|
|
139
|
-
},
|
|
140
|
-
};
|
|
141
|
-
});
|
|
142
|
-
Object.defineProperty(store, 'pointerMissed$', { get: () => pointerMissed$ });
|
|
143
|
-
let { size: oldSize, viewport: { dpr: oldDpr }, camera: oldCamera, } = store.snapshot;
|
|
144
|
-
effect(() => {
|
|
145
|
-
const { camera: newCamera, size: newSize, viewport: { dpr: newDpr }, gl, } = store.state();
|
|
146
|
-
// Resize camera and renderer on changes to size and pixel-ratio
|
|
147
|
-
if (newSize !== oldSize || newDpr !== oldDpr) {
|
|
148
|
-
oldSize = newSize;
|
|
149
|
-
oldDpr = newDpr;
|
|
150
|
-
// Update camera & renderer
|
|
151
|
-
updateCamera(newCamera, newSize);
|
|
152
|
-
gl.setPixelRatio(newDpr);
|
|
153
|
-
const updateStyle = typeof HTMLCanvasElement !== 'undefined' && gl.domElement instanceof HTMLCanvasElement;
|
|
154
|
-
gl.setSize(newSize.width, newSize.height, updateStyle);
|
|
155
|
-
}
|
|
156
|
-
// Update viewport once the camera changes
|
|
157
|
-
if (newCamera !== oldCamera) {
|
|
158
|
-
oldCamera = newCamera;
|
|
159
|
-
updateCamera(newCamera, newSize);
|
|
160
|
-
// Update viewport
|
|
161
|
-
store.update((state) => ({ viewport: { ...state.viewport, ...state.viewport.getCurrentViewport(newCamera) } }));
|
|
162
|
-
}
|
|
163
|
-
});
|
|
164
|
-
return store;
|
|
165
|
-
}
|
|
166
|
-
export const NGT_STORE = new InjectionToken('NgtStore Token');
|
|
167
|
-
export function provideStore(store) {
|
|
168
|
-
if (store) {
|
|
169
|
-
return { provide: NGT_STORE, useFactory: store };
|
|
170
|
-
}
|
|
171
|
-
return { provide: NGT_STORE, useFactory: storeFactory };
|
|
172
|
-
}
|
|
173
|
-
export function injectStore(options) {
|
|
174
|
-
return inject(NGT_STORE, options);
|
|
175
|
-
}
|
|
176
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"store.js","sourceRoot":"","sources":["../../../../../libs/core/src/lib/store.ts"],"names":[],"mappings":"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","sourcesContent":["import { ElementRef, InjectOptions, InjectionToken, effect, inject } from '@angular/core';\nimport { Subject } from 'rxjs';\nimport { Clock, Vector2, Vector3 } from 'three';\nimport { injectLoop } from './loop';\nimport { NgtBeforeRenderRecord, NgtCamera, NgtDpr, NgtEventManager, NgtSize, NgtState, NgtViewport } from './types';\nimport { is } from './utils/is';\nimport { makeDpr } from './utils/make';\nimport { NgtSignalStore, signalStore } from './utils/signal-store';\nimport { updateCamera } from './utils/update';\n\nfunction storeFactory(previousStore: NgtSignalStore<NgtState> | null) {\n\tconst loop = injectLoop();\n\n\t// NOTE: using Subject because we do not care about late-subscribers\n\tconst pointerMissed$ = new Subject<MouseEvent>();\n\n\tconst store: NgtSignalStore<NgtState> = signalStore<NgtState>(({ get, update }) => {\n\t\tconst { invalidate, advance } = loop;\n\n\t\tconst position = new Vector3();\n\t\tconst defaultTarget = new Vector3();\n\t\tconst tempTarget = new Vector3();\n\n\t\tfunction getCurrentViewport(\n\t\t\tcamera: NgtCamera = get('camera'),\n\t\t\ttarget: Vector3 | Parameters<Vector3['set']> = defaultTarget,\n\t\t\tsize: NgtSize = get('size'),\n\t\t): Omit<NgtViewport, 'dpr' | 'initialDpr'> {\n\t\t\tconst { width, height, top, left } = size;\n\t\t\tconst aspect = width / height;\n\n\t\t\tif (target instanceof Vector3) tempTarget.copy(target);\n\t\t\telse tempTarget.set(...target);\n\n\t\t\tconst distance = camera.getWorldPosition(position).distanceTo(tempTarget);\n\n\t\t\tif (is.orthographicCamera(camera)) {\n\t\t\t\treturn { width: width / camera.zoom, height: height / camera.zoom, top, left, factor: 1, distance, aspect };\n\t\t\t}\n\n\t\t\tconst fov = (camera.fov * Math.PI) / 180; // convert vertical fov to radians\n\t\t\tconst h = 2 * Math.tan(fov / 2) * distance; // visible height\n\t\t\tconst w = h * (width / height);\n\t\t\treturn { width: w, height: h, top, left, factor: width / w, distance, aspect };\n\t\t}\n\n\t\tlet performanceTimeout: ReturnType<typeof setTimeout> | undefined = undefined;\n\t\tconst setPerformanceCurrent = (current: number) =>\n\t\t\tupdate((state) => ({ performance: { ...state.performance, current } }));\n\n\t\tconst pointer = new Vector2();\n\n\t\treturn {\n\t\t\tpointerMissed$: pointerMissed$.asObservable(),\n\t\t\tevents: { priority: 1, enabled: true, connected: false },\n\n\t\t\tinvalidate: (frames = 1) => invalidate(store, frames),\n\t\t\tadvance: (timestamp: number, runGlobalEffects?: boolean) => advance(timestamp, runGlobalEffects, store),\n\n\t\t\tlegacy: false,\n\t\t\tlinear: false,\n\t\t\tflat: false,\n\n\t\t\tcontrols: null,\n\t\t\tclock: new Clock(),\n\t\t\tpointer,\n\n\t\t\tframeloop: 'always',\n\n\t\t\tperformance: {\n\t\t\t\tcurrent: 1,\n\t\t\t\tmin: 0.5,\n\t\t\t\tmax: 1,\n\t\t\t\tdebounce: 200,\n\t\t\t\tregress: () => {\n\t\t\t\t\tconst state = get();\n\t\t\t\t\t// Clear timeout\n\t\t\t\t\tif (performanceTimeout) clearTimeout(performanceTimeout);\n\t\t\t\t\t// Set lower bound performance\n\t\t\t\t\tif (state.performance.current !== state.performance.min) setPerformanceCurrent(state.performance.min);\n\t\t\t\t\t// Go back to upper bound performance after a while unless something regresses meanwhile\n\t\t\t\t\tperformanceTimeout = setTimeout(() => {\n\t\t\t\t\t\tsetPerformanceCurrent(get('performance', 'max'));\n\t\t\t\t\t\t// safeDetectChanges(cdr);\n\t\t\t\t\t}, state.performance.debounce);\n\t\t\t\t},\n\t\t\t},\n\n\t\t\tsize: { width: 0, height: 0, top: 0, left: 0, updateStyle: false },\n\t\t\tviewport: {\n\t\t\t\tinitialDpr: 0,\n\t\t\t\tdpr: 0,\n\t\t\t\twidth: 0,\n\t\t\t\theight: 0,\n\t\t\t\ttop: 0,\n\t\t\t\tleft: 0,\n\t\t\t\taspect: 0,\n\t\t\t\tdistance: 0,\n\t\t\t\tfactor: 0,\n\t\t\t\tgetCurrentViewport,\n\t\t\t},\n\n\t\t\tsetEvents: (events: Partial<NgtEventManager<any>>) =>\n\t\t\t\tupdate((state) => ({ ...state, events: { ...state.events, ...events } })),\n\t\t\tsetSize: (width: number, height: number, top?: number, left?: number) => {\n\t\t\t\tconst camera = get('camera');\n\t\t\t\tconst size = { width, height, top: top || 0, left: left || 0 };\n\t\t\t\tupdate((state) => ({\n\t\t\t\t\tsize,\n\t\t\t\t\tviewport: { ...state.viewport, ...getCurrentViewport(camera, defaultTarget, size) },\n\t\t\t\t}));\n\t\t\t},\n\t\t\tsetDpr: (dpr: NgtDpr) =>\n\t\t\t\tupdate((state) => {\n\t\t\t\t\tconst resolved = makeDpr(dpr, window);\n\t\t\t\t\treturn { viewport: { ...state.viewport, dpr: resolved, initialDpr: state.viewport.initialDpr || resolved } };\n\t\t\t\t}),\n\t\t\tsetFrameloop: (frameloop: 'always' | 'demand' | 'never' = 'always') => {\n\t\t\t\tconst clock = get('clock');\n\n\t\t\t\t// if frameloop === \"never\" clock.elapsedTime is updated using advance(timestamp)\n\t\t\t\tclock.stop();\n\t\t\t\tclock.elapsedTime = 0;\n\n\t\t\t\tif (frameloop !== 'never') {\n\t\t\t\t\tclock.start();\n\t\t\t\t\tclock.elapsedTime = 0;\n\t\t\t\t}\n\n\t\t\t\tupdate(() => ({ frameloop }));\n\t\t\t},\n\n\t\t\tpreviousRoot: previousStore,\n\t\t\tinternal: {\n\t\t\t\tactive: false,\n\t\t\t\tpriority: 0,\n\t\t\t\tframes: 0,\n\t\t\t\tlastEvent: new ElementRef(null),\n\t\t\t\tinteraction: [],\n\t\t\t\thovered: new Map(),\n\t\t\t\tsubscribers: [],\n\t\t\t\tinitialClick: [0, 0],\n\t\t\t\tinitialHits: [],\n\t\t\t\tcapturedMap: new Map(),\n\t\t\t\tsubscribe: (\n\t\t\t\t\tcallback: NgtBeforeRenderRecord['callback'],\n\t\t\t\t\tpriority = 0,\n\t\t\t\t\t_store: NgtSignalStore<NgtState> = store,\n\t\t\t\t) => {\n\t\t\t\t\tconst internal = get('internal');\n\t\t\t\t\t// If this subscription was given a priority, it takes rendering into its own hands\n\t\t\t\t\t// For that reason we switch off automatic rendering and increase the manual flag\n\t\t\t\t\t// As long as this flag is positive there can be no internal rendering at all\n\t\t\t\t\t// because there could be multiple render subscriptions\n\t\t\t\t\tinternal.priority = internal.priority + (priority > 0 ? 1 : 0);\n\t\t\t\t\tinternal.subscribers.push({ callback, priority, store: _store });\n\t\t\t\t\t// Register subscriber and sort layers from lowest to highest, meaning,\n\t\t\t\t\t// highest priority renders last (on top of the other frames)\n\t\t\t\t\tinternal.subscribers = internal.subscribers.sort((a, b) => (a.priority || 0) - (b.priority || 0));\n\n\t\t\t\t\treturn () => {\n\t\t\t\t\t\tconst internal = get('internal');\n\t\t\t\t\t\tif (internal?.subscribers) {\n\t\t\t\t\t\t\t// Decrease manual flag if this subscription had a priority\n\t\t\t\t\t\t\tinternal.priority = internal.priority - (priority > 0 ? 1 : 0);\n\t\t\t\t\t\t\t// Remove subscriber from list\n\t\t\t\t\t\t\tinternal.subscribers = internal.subscribers.filter((s) => s.callback !== callback);\n\t\t\t\t\t\t}\n\t\t\t\t\t};\n\t\t\t\t},\n\t\t\t},\n\t\t};\n\t});\n\n\tObject.defineProperty(store, 'pointerMissed$', { get: () => pointerMissed$ });\n\n\tlet {\n\t\tsize: oldSize,\n\t\tviewport: { dpr: oldDpr },\n\t\tcamera: oldCamera,\n\t} = store.snapshot;\n\n\teffect(() => {\n\t\tconst {\n\t\t\tcamera: newCamera,\n\t\t\tsize: newSize,\n\t\t\tviewport: { dpr: newDpr },\n\t\t\tgl,\n\t\t} = store.state();\n\n\t\t// Resize camera and renderer on changes to size and pixel-ratio\n\t\tif (newSize !== oldSize || newDpr !== oldDpr) {\n\t\t\toldSize = newSize;\n\t\t\toldDpr = newDpr;\n\t\t\t// Update camera & renderer\n\t\t\tupdateCamera(newCamera, newSize);\n\t\t\tgl.setPixelRatio(newDpr);\n\n\t\t\tconst updateStyle = typeof HTMLCanvasElement !== 'undefined' && gl.domElement instanceof HTMLCanvasElement;\n\t\t\tgl.setSize(newSize.width, newSize.height, updateStyle);\n\t\t}\n\n\t\t// Update viewport once the camera changes\n\t\tif (newCamera !== oldCamera) {\n\t\t\toldCamera = newCamera;\n\t\t\tupdateCamera(newCamera, newSize);\n\t\t\t// Update viewport\n\t\t\tstore.update((state) => ({ viewport: { ...state.viewport, ...state.viewport.getCurrentViewport(newCamera) } }));\n\t\t}\n\t});\n\n\treturn store;\n}\n\nexport const NGT_STORE = new InjectionToken<NgtSignalStore<NgtState>>('NgtStore Token');\n\nexport function provideStore(store?: () => NgtSignalStore<NgtState>) {\n\tif (store) {\n\t\treturn { provide: NGT_STORE, useFactory: store };\n\t}\n\treturn { provide: NGT_STORE, useFactory: storeFactory };\n}\n\nexport function injectStore(options: InjectOptions & { optional?: false }): NgtSignalStore<NgtState>;\nexport function injectStore(options: InjectOptions): NgtSignalStore<NgtState> | null;\nexport function injectStore(): NgtSignalStore<NgtState>;\nexport function injectStore(options?: InjectOptions) {\n\treturn inject(NGT_STORE, options as InjectOptions);\n}\n"]}
|