@react-three/fiber 9.2.0 → 9.3.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/CHANGELOG.md +1168 -1160
- package/dist/declarations/src/core/events.d.ts +92 -92
- package/dist/declarations/src/core/hooks.d.ts +53 -53
- package/dist/declarations/src/core/index.d.ts +13 -13
- package/dist/declarations/src/core/loop.d.ts +31 -31
- package/dist/declarations/src/core/reconciler.d.ts +50 -50
- package/dist/declarations/src/core/renderer.d.ts +89 -89
- package/dist/declarations/src/core/store.d.ts +130 -130
- package/dist/declarations/src/core/utils.d.ts +191 -191
- package/dist/declarations/src/index.d.ts +6 -6
- package/dist/declarations/src/native/Canvas.d.ts +13 -13
- package/dist/declarations/src/native/events.d.ts +4 -4
- package/dist/declarations/src/native.d.ts +6 -6
- package/dist/declarations/src/three-types.d.ts +68 -68
- package/dist/declarations/src/web/Canvas.d.ts +23 -23
- package/dist/declarations/src/web/events.d.ts +4 -4
- package/dist/{events-e63d28a3.cjs.dev.js → events-d0449b76.cjs.dev.js} +91 -91
- package/dist/{events-59fae97e.cjs.prod.js → events-d0a20a9c.cjs.prod.js} +91 -91
- package/dist/{events-cf57b220.esm.js → events-e3cb66e2.esm.js} +90 -90
- package/dist/react-three-fiber.cjs.dev.js +5 -5
- package/dist/react-three-fiber.cjs.prod.js +5 -5
- package/dist/react-three-fiber.esm.js +6 -6
- package/native/dist/react-three-fiber-native.cjs.dev.js +8 -6
- package/native/dist/react-three-fiber-native.cjs.prod.js +8 -6
- package/native/dist/react-three-fiber-native.esm.js +9 -7
- package/native/package.json +5 -5
- package/package.json +2 -2
- package/readme.md +253 -253
|
@@ -1,92 +1,92 @@
|
|
|
1
|
-
import * as THREE from 'three';
|
|
2
|
-
import { type Properties } from "./utils.js";
|
|
3
|
-
import type { RootState, RootStore } from "./store.js";
|
|
4
|
-
export interface Intersection extends THREE.Intersection {
|
|
5
|
-
/** The event source (the object which registered the handler) */
|
|
6
|
-
eventObject: THREE.Object3D;
|
|
7
|
-
}
|
|
8
|
-
export interface IntersectionEvent<TSourceEvent> extends Intersection {
|
|
9
|
-
/** The event source (the object which registered the handler) */
|
|
10
|
-
eventObject: THREE.Object3D;
|
|
11
|
-
/** An array of intersections */
|
|
12
|
-
intersections: Intersection[];
|
|
13
|
-
/** vec3.set(pointer.x, pointer.y, 0).unproject(camera) */
|
|
14
|
-
unprojectedPoint: THREE.Vector3;
|
|
15
|
-
/** Normalized event coordinates */
|
|
16
|
-
pointer: THREE.Vector2;
|
|
17
|
-
/** Delta between first click and this event */
|
|
18
|
-
delta: number;
|
|
19
|
-
/** The ray that pierced it */
|
|
20
|
-
ray: THREE.Ray;
|
|
21
|
-
/** The camera that was used by the raycaster */
|
|
22
|
-
camera: Camera;
|
|
23
|
-
/** stopPropagation will stop underlying handlers from firing */
|
|
24
|
-
stopPropagation: () => void;
|
|
25
|
-
/** The original host event */
|
|
26
|
-
nativeEvent: TSourceEvent;
|
|
27
|
-
/** If the event was stopped by calling stopPropagation */
|
|
28
|
-
stopped: boolean;
|
|
29
|
-
}
|
|
30
|
-
export type Camera = THREE.OrthographicCamera | THREE.PerspectiveCamera;
|
|
31
|
-
export type ThreeEvent<TEvent> = IntersectionEvent<TEvent> & Properties<TEvent>;
|
|
32
|
-
export type DomEvent = PointerEvent | MouseEvent | WheelEvent;
|
|
33
|
-
export interface Events {
|
|
34
|
-
onClick: EventListener;
|
|
35
|
-
onContextMenu: EventListener;
|
|
36
|
-
onDoubleClick: EventListener;
|
|
37
|
-
onWheel: EventListener;
|
|
38
|
-
onPointerDown: EventListener;
|
|
39
|
-
onPointerUp: EventListener;
|
|
40
|
-
onPointerLeave: EventListener;
|
|
41
|
-
onPointerMove: EventListener;
|
|
42
|
-
onPointerCancel: EventListener;
|
|
43
|
-
onLostPointerCapture: EventListener;
|
|
44
|
-
}
|
|
45
|
-
export interface EventHandlers {
|
|
46
|
-
onClick?: (event: ThreeEvent<MouseEvent>) => void;
|
|
47
|
-
onContextMenu?: (event: ThreeEvent<MouseEvent>) => void;
|
|
48
|
-
onDoubleClick?: (event: ThreeEvent<MouseEvent>) => void;
|
|
49
|
-
onPointerUp?: (event: ThreeEvent<PointerEvent>) => void;
|
|
50
|
-
onPointerDown?: (event: ThreeEvent<PointerEvent>) => void;
|
|
51
|
-
onPointerOver?: (event: ThreeEvent<PointerEvent>) => void;
|
|
52
|
-
onPointerOut?: (event: ThreeEvent<PointerEvent>) => void;
|
|
53
|
-
onPointerEnter?: (event: ThreeEvent<PointerEvent>) => void;
|
|
54
|
-
onPointerLeave?: (event: ThreeEvent<PointerEvent>) => void;
|
|
55
|
-
onPointerMove?: (event: ThreeEvent<PointerEvent>) => void;
|
|
56
|
-
onPointerMissed?: (event: MouseEvent) => void;
|
|
57
|
-
onPointerCancel?: (event: ThreeEvent<PointerEvent>) => void;
|
|
58
|
-
onWheel?: (event: ThreeEvent<WheelEvent>) => void;
|
|
59
|
-
onLostPointerCapture?: (event: ThreeEvent<PointerEvent>) => void;
|
|
60
|
-
}
|
|
61
|
-
export type FilterFunction = (items: THREE.Intersection[], state: RootState) => THREE.Intersection[];
|
|
62
|
-
export type ComputeFunction = (event: DomEvent, root: RootState, previous?: RootState) => void;
|
|
63
|
-
export interface EventManager<TTarget> {
|
|
64
|
-
/** Determines if the event layer is active */
|
|
65
|
-
enabled: boolean;
|
|
66
|
-
/** Event layer priority, higher prioritized layers come first and may stop(-propagate) lower layer */
|
|
67
|
-
priority: number;
|
|
68
|
-
/** The compute function needs to set up the raycaster and an xy- pointer */
|
|
69
|
-
compute?: ComputeFunction;
|
|
70
|
-
/** The filter can re-order or re-structure the intersections */
|
|
71
|
-
filter?: FilterFunction;
|
|
72
|
-
/** The target node the event layer is tied to */
|
|
73
|
-
connected?: TTarget;
|
|
74
|
-
/** All the pointer event handlers through which the host forwards native events */
|
|
75
|
-
handlers?: Events;
|
|
76
|
-
/** Allows re-connecting to another target */
|
|
77
|
-
connect?: (target: TTarget) => void;
|
|
78
|
-
/** Removes all existing events handlers from the target */
|
|
79
|
-
disconnect?: () => void;
|
|
80
|
-
/** Triggers a onPointerMove with the last known event. This can be useful to enable raycasting without
|
|
81
|
-
* explicit user interaction, for instance when the camera moves a hoverable object underneath the cursor.
|
|
82
|
-
*/
|
|
83
|
-
update?: () => void;
|
|
84
|
-
}
|
|
85
|
-
export interface PointerCaptureTarget {
|
|
86
|
-
intersection: Intersection;
|
|
87
|
-
target: Element;
|
|
88
|
-
}
|
|
89
|
-
export declare function removeInteractivity(store: RootStore, object: THREE.Object3D): void;
|
|
90
|
-
export declare function createEvents(store: RootStore): {
|
|
91
|
-
handlePointer: (name: string) => (event: DomEvent) => void;
|
|
92
|
-
};
|
|
1
|
+
import * as THREE from 'three';
|
|
2
|
+
import { type Properties } from "./utils.js";
|
|
3
|
+
import type { RootState, RootStore } from "./store.js";
|
|
4
|
+
export interface Intersection extends THREE.Intersection {
|
|
5
|
+
/** The event source (the object which registered the handler) */
|
|
6
|
+
eventObject: THREE.Object3D;
|
|
7
|
+
}
|
|
8
|
+
export interface IntersectionEvent<TSourceEvent> extends Intersection {
|
|
9
|
+
/** The event source (the object which registered the handler) */
|
|
10
|
+
eventObject: THREE.Object3D;
|
|
11
|
+
/** An array of intersections */
|
|
12
|
+
intersections: Intersection[];
|
|
13
|
+
/** vec3.set(pointer.x, pointer.y, 0).unproject(camera) */
|
|
14
|
+
unprojectedPoint: THREE.Vector3;
|
|
15
|
+
/** Normalized event coordinates */
|
|
16
|
+
pointer: THREE.Vector2;
|
|
17
|
+
/** Delta between first click and this event */
|
|
18
|
+
delta: number;
|
|
19
|
+
/** The ray that pierced it */
|
|
20
|
+
ray: THREE.Ray;
|
|
21
|
+
/** The camera that was used by the raycaster */
|
|
22
|
+
camera: Camera;
|
|
23
|
+
/** stopPropagation will stop underlying handlers from firing */
|
|
24
|
+
stopPropagation: () => void;
|
|
25
|
+
/** The original host event */
|
|
26
|
+
nativeEvent: TSourceEvent;
|
|
27
|
+
/** If the event was stopped by calling stopPropagation */
|
|
28
|
+
stopped: boolean;
|
|
29
|
+
}
|
|
30
|
+
export type Camera = THREE.OrthographicCamera | THREE.PerspectiveCamera;
|
|
31
|
+
export type ThreeEvent<TEvent> = IntersectionEvent<TEvent> & Properties<TEvent>;
|
|
32
|
+
export type DomEvent = PointerEvent | MouseEvent | WheelEvent;
|
|
33
|
+
export interface Events {
|
|
34
|
+
onClick: EventListener;
|
|
35
|
+
onContextMenu: EventListener;
|
|
36
|
+
onDoubleClick: EventListener;
|
|
37
|
+
onWheel: EventListener;
|
|
38
|
+
onPointerDown: EventListener;
|
|
39
|
+
onPointerUp: EventListener;
|
|
40
|
+
onPointerLeave: EventListener;
|
|
41
|
+
onPointerMove: EventListener;
|
|
42
|
+
onPointerCancel: EventListener;
|
|
43
|
+
onLostPointerCapture: EventListener;
|
|
44
|
+
}
|
|
45
|
+
export interface EventHandlers {
|
|
46
|
+
onClick?: (event: ThreeEvent<MouseEvent>) => void;
|
|
47
|
+
onContextMenu?: (event: ThreeEvent<MouseEvent>) => void;
|
|
48
|
+
onDoubleClick?: (event: ThreeEvent<MouseEvent>) => void;
|
|
49
|
+
onPointerUp?: (event: ThreeEvent<PointerEvent>) => void;
|
|
50
|
+
onPointerDown?: (event: ThreeEvent<PointerEvent>) => void;
|
|
51
|
+
onPointerOver?: (event: ThreeEvent<PointerEvent>) => void;
|
|
52
|
+
onPointerOut?: (event: ThreeEvent<PointerEvent>) => void;
|
|
53
|
+
onPointerEnter?: (event: ThreeEvent<PointerEvent>) => void;
|
|
54
|
+
onPointerLeave?: (event: ThreeEvent<PointerEvent>) => void;
|
|
55
|
+
onPointerMove?: (event: ThreeEvent<PointerEvent>) => void;
|
|
56
|
+
onPointerMissed?: (event: MouseEvent) => void;
|
|
57
|
+
onPointerCancel?: (event: ThreeEvent<PointerEvent>) => void;
|
|
58
|
+
onWheel?: (event: ThreeEvent<WheelEvent>) => void;
|
|
59
|
+
onLostPointerCapture?: (event: ThreeEvent<PointerEvent>) => void;
|
|
60
|
+
}
|
|
61
|
+
export type FilterFunction = (items: THREE.Intersection[], state: RootState) => THREE.Intersection[];
|
|
62
|
+
export type ComputeFunction = (event: DomEvent, root: RootState, previous?: RootState) => void;
|
|
63
|
+
export interface EventManager<TTarget> {
|
|
64
|
+
/** Determines if the event layer is active */
|
|
65
|
+
enabled: boolean;
|
|
66
|
+
/** Event layer priority, higher prioritized layers come first and may stop(-propagate) lower layer */
|
|
67
|
+
priority: number;
|
|
68
|
+
/** The compute function needs to set up the raycaster and an xy- pointer */
|
|
69
|
+
compute?: ComputeFunction;
|
|
70
|
+
/** The filter can re-order or re-structure the intersections */
|
|
71
|
+
filter?: FilterFunction;
|
|
72
|
+
/** The target node the event layer is tied to */
|
|
73
|
+
connected?: TTarget;
|
|
74
|
+
/** All the pointer event handlers through which the host forwards native events */
|
|
75
|
+
handlers?: Events;
|
|
76
|
+
/** Allows re-connecting to another target */
|
|
77
|
+
connect?: (target: TTarget) => void;
|
|
78
|
+
/** Removes all existing events handlers from the target */
|
|
79
|
+
disconnect?: () => void;
|
|
80
|
+
/** Triggers a onPointerMove with the last known event. This can be useful to enable raycasting without
|
|
81
|
+
* explicit user interaction, for instance when the camera moves a hoverable object underneath the cursor.
|
|
82
|
+
*/
|
|
83
|
+
update?: () => void;
|
|
84
|
+
}
|
|
85
|
+
export interface PointerCaptureTarget {
|
|
86
|
+
intersection: Intersection;
|
|
87
|
+
target: Element;
|
|
88
|
+
}
|
|
89
|
+
export declare function removeInteractivity(store: RootStore, object: THREE.Object3D): void;
|
|
90
|
+
export declare function createEvents(store: RootStore): {
|
|
91
|
+
handlePointer: (name: string) => (event: DomEvent) => void;
|
|
92
|
+
};
|
|
@@ -1,53 +1,53 @@
|
|
|
1
|
-
import * as THREE from 'three';
|
|
2
|
-
import * as React from 'react';
|
|
3
|
-
import { RootState, RenderCallback, RootStore } from "./store.js";
|
|
4
|
-
import { ObjectMap } from "./utils.js";
|
|
5
|
-
import type { Instance, ConstructorRepresentation } from "./reconciler.js";
|
|
6
|
-
/**
|
|
7
|
-
* Exposes an object's {@link Instance}.
|
|
8
|
-
* @see https://docs.pmnd.rs/react-three-fiber/api/additional-exports#useInstanceHandle
|
|
9
|
-
*
|
|
10
|
-
* **Note**: this is an escape hatch to react-internal fields. Expect this to change significantly between versions.
|
|
11
|
-
*/
|
|
12
|
-
export declare function useInstanceHandle<T>(ref: React.RefObject<T>): React.RefObject<Instance<T>>;
|
|
13
|
-
/**
|
|
14
|
-
* Returns the R3F Canvas' Zustand store. Useful for [transient updates](https://github.com/pmndrs/zustand#transient-updates-for-often-occurring-state-changes).
|
|
15
|
-
* @see https://docs.pmnd.rs/react-three-fiber/api/hooks#usestore
|
|
16
|
-
*/
|
|
17
|
-
export declare function useStore(): RootStore;
|
|
18
|
-
/**
|
|
19
|
-
* Accesses R3F's internal state, containing renderer, canvas, scene, etc.
|
|
20
|
-
* @see https://docs.pmnd.rs/react-three-fiber/api/hooks#usethree
|
|
21
|
-
*/
|
|
22
|
-
export declare function useThree<T = RootState>(selector?: (state: RootState) => T, equalityFn?: <T>(state: T, newState: T) => boolean): T;
|
|
23
|
-
/**
|
|
24
|
-
* Executes a callback before render in a shared frame loop.
|
|
25
|
-
* Can order effects with render priority or manually render with a positive priority.
|
|
26
|
-
* @see https://docs.pmnd.rs/react-three-fiber/api/hooks#useframe
|
|
27
|
-
*/
|
|
28
|
-
export declare function useFrame(callback: RenderCallback, renderPriority?: number): null;
|
|
29
|
-
/**
|
|
30
|
-
* Returns a node graph of an object with named nodes & materials.
|
|
31
|
-
* @see https://docs.pmnd.rs/react-three-fiber/api/hooks#usegraph
|
|
32
|
-
*/
|
|
33
|
-
export declare function useGraph(object: THREE.Object3D): ObjectMap;
|
|
34
|
-
type InputLike = string | string[] | string[][] | Readonly<string | string[] | string[][]>;
|
|
35
|
-
type LoaderLike = THREE.Loader<any, InputLike>;
|
|
36
|
-
type GLTFLike = {
|
|
37
|
-
scene: THREE.Object3D;
|
|
38
|
-
};
|
|
39
|
-
type LoaderInstance<T extends LoaderLike | ConstructorRepresentation<LoaderLike>> = T extends ConstructorRepresentation<LoaderLike> ? InstanceType<T> : T;
|
|
40
|
-
export type LoaderResult<T extends LoaderLike | ConstructorRepresentation<LoaderLike>> = Awaited<ReturnType<LoaderInstance<T>['loadAsync']>> extends infer R ? R extends GLTFLike ? R & ObjectMap : R : never;
|
|
41
|
-
export type Extensions<T extends LoaderLike | ConstructorRepresentation<LoaderLike>> = (loader: LoaderInstance<T>) => void;
|
|
42
|
-
/**
|
|
43
|
-
* Synchronously loads and caches assets with a three loader.
|
|
44
|
-
*
|
|
45
|
-
* Note: this hook's caller must be wrapped with `React.Suspense`
|
|
46
|
-
* @see https://docs.pmnd.rs/react-three-fiber/api/hooks#useloader
|
|
47
|
-
*/
|
|
48
|
-
export declare function useLoader<I extends InputLike, L extends LoaderLike | ConstructorRepresentation<LoaderLike>>(loader: L, input: I, extensions?: Extensions<L>, onProgress?: (event: ProgressEvent<EventTarget>) => void): I extends any[] ? LoaderResult<L>[] : LoaderResult<L>;
|
|
49
|
-
export declare namespace useLoader {
|
|
50
|
-
var preload: <I extends InputLike, L extends LoaderLike | ConstructorRepresentation<LoaderLike>>(loader: L, input: I, extensions?: Extensions<L> | undefined) => void;
|
|
51
|
-
var clear: <I extends InputLike, L extends LoaderLike | ConstructorRepresentation<LoaderLike>>(loader: L, input: I) => void;
|
|
52
|
-
}
|
|
53
|
-
export {};
|
|
1
|
+
import * as THREE from 'three';
|
|
2
|
+
import * as React from 'react';
|
|
3
|
+
import { RootState, RenderCallback, RootStore } from "./store.js";
|
|
4
|
+
import { ObjectMap } from "./utils.js";
|
|
5
|
+
import type { Instance, ConstructorRepresentation } from "./reconciler.js";
|
|
6
|
+
/**
|
|
7
|
+
* Exposes an object's {@link Instance}.
|
|
8
|
+
* @see https://docs.pmnd.rs/react-three-fiber/api/additional-exports#useInstanceHandle
|
|
9
|
+
*
|
|
10
|
+
* **Note**: this is an escape hatch to react-internal fields. Expect this to change significantly between versions.
|
|
11
|
+
*/
|
|
12
|
+
export declare function useInstanceHandle<T>(ref: React.RefObject<T>): React.RefObject<Instance<T>>;
|
|
13
|
+
/**
|
|
14
|
+
* Returns the R3F Canvas' Zustand store. Useful for [transient updates](https://github.com/pmndrs/zustand#transient-updates-for-often-occurring-state-changes).
|
|
15
|
+
* @see https://docs.pmnd.rs/react-three-fiber/api/hooks#usestore
|
|
16
|
+
*/
|
|
17
|
+
export declare function useStore(): RootStore;
|
|
18
|
+
/**
|
|
19
|
+
* Accesses R3F's internal state, containing renderer, canvas, scene, etc.
|
|
20
|
+
* @see https://docs.pmnd.rs/react-three-fiber/api/hooks#usethree
|
|
21
|
+
*/
|
|
22
|
+
export declare function useThree<T = RootState>(selector?: (state: RootState) => T, equalityFn?: <T>(state: T, newState: T) => boolean): T;
|
|
23
|
+
/**
|
|
24
|
+
* Executes a callback before render in a shared frame loop.
|
|
25
|
+
* Can order effects with render priority or manually render with a positive priority.
|
|
26
|
+
* @see https://docs.pmnd.rs/react-three-fiber/api/hooks#useframe
|
|
27
|
+
*/
|
|
28
|
+
export declare function useFrame(callback: RenderCallback, renderPriority?: number): null;
|
|
29
|
+
/**
|
|
30
|
+
* Returns a node graph of an object with named nodes & materials.
|
|
31
|
+
* @see https://docs.pmnd.rs/react-three-fiber/api/hooks#usegraph
|
|
32
|
+
*/
|
|
33
|
+
export declare function useGraph(object: THREE.Object3D): ObjectMap;
|
|
34
|
+
type InputLike = string | string[] | string[][] | Readonly<string | string[] | string[][]>;
|
|
35
|
+
type LoaderLike = THREE.Loader<any, InputLike>;
|
|
36
|
+
type GLTFLike = {
|
|
37
|
+
scene: THREE.Object3D;
|
|
38
|
+
};
|
|
39
|
+
type LoaderInstance<T extends LoaderLike | ConstructorRepresentation<LoaderLike>> = T extends ConstructorRepresentation<LoaderLike> ? InstanceType<T> : T;
|
|
40
|
+
export type LoaderResult<T extends LoaderLike | ConstructorRepresentation<LoaderLike>> = Awaited<ReturnType<LoaderInstance<T>['loadAsync']>> extends infer R ? R extends GLTFLike ? R & ObjectMap : R : never;
|
|
41
|
+
export type Extensions<T extends LoaderLike | ConstructorRepresentation<LoaderLike>> = (loader: LoaderInstance<T>) => void;
|
|
42
|
+
/**
|
|
43
|
+
* Synchronously loads and caches assets with a three loader.
|
|
44
|
+
*
|
|
45
|
+
* Note: this hook's caller must be wrapped with `React.Suspense`
|
|
46
|
+
* @see https://docs.pmnd.rs/react-three-fiber/api/hooks#useloader
|
|
47
|
+
*/
|
|
48
|
+
export declare function useLoader<I extends InputLike, L extends LoaderLike | ConstructorRepresentation<LoaderLike>>(loader: L, input: I, extensions?: Extensions<L>, onProgress?: (event: ProgressEvent<EventTarget>) => void): I extends any[] ? LoaderResult<L>[] : LoaderResult<L>;
|
|
49
|
+
export declare namespace useLoader {
|
|
50
|
+
var preload: <I extends InputLike, L extends LoaderLike | ConstructorRepresentation<LoaderLike>>(loader: L, input: I, extensions?: Extensions<L> | undefined) => void;
|
|
51
|
+
var clear: <I extends InputLike, L extends LoaderLike | ConstructorRepresentation<LoaderLike>>(loader: L, input: I) => void;
|
|
52
|
+
}
|
|
53
|
+
export {};
|
|
@@ -1,13 +1,13 @@
|
|
|
1
|
-
export type { Intersection, ThreeEvent, DomEvent, Events, EventHandlers, FilterFunction, ComputeFunction, EventManager, } from "./events.js";
|
|
2
|
-
export { createEvents } from "./events.js";
|
|
3
|
-
export * from "./hooks.js";
|
|
4
|
-
export type { GlobalRenderCallback, GlobalEffectType } from "./loop.js";
|
|
5
|
-
export { flushGlobalEffects, addEffect, addAfterEffect, addTail, invalidate, advance } from "./loop.js";
|
|
6
|
-
export type { AttachFnType, AttachType, ConstructorRepresentation, Catalogue, Args, InstanceProps, Instance, } from "./reconciler.js";
|
|
7
|
-
export { extend, reconciler } from "./reconciler.js";
|
|
8
|
-
export type { ReconcilerRoot, GLProps, CameraProps, RenderProps, InjectState } from "./renderer.js";
|
|
9
|
-
export { _roots, createRoot, unmountComponentAtNode, createPortal, flushSync } from "./renderer.js";
|
|
10
|
-
export type { Subscription, Dpr, Size, Viewport, RenderCallback, Frameloop, Performance, Renderer, XRManager, RootState, RootStore, } from "./store.js";
|
|
11
|
-
export { context } from "./store.js";
|
|
12
|
-
export type { ObjectMap, Camera, Disposable, Act } from "./utils.js";
|
|
13
|
-
export { applyProps, getRootState, dispose, act, buildGraph } from "./utils.js";
|
|
1
|
+
export type { Intersection, ThreeEvent, DomEvent, Events, EventHandlers, FilterFunction, ComputeFunction, EventManager, } from "./events.js";
|
|
2
|
+
export { createEvents } from "./events.js";
|
|
3
|
+
export * from "./hooks.js";
|
|
4
|
+
export type { GlobalRenderCallback, GlobalEffectType } from "./loop.js";
|
|
5
|
+
export { flushGlobalEffects, addEffect, addAfterEffect, addTail, invalidate, advance } from "./loop.js";
|
|
6
|
+
export type { AttachFnType, AttachType, ConstructorRepresentation, Catalogue, Args, InstanceProps, Instance, } from "./reconciler.js";
|
|
7
|
+
export { extend, reconciler } from "./reconciler.js";
|
|
8
|
+
export type { ReconcilerRoot, GLProps, CameraProps, RenderProps, InjectState } from "./renderer.js";
|
|
9
|
+
export { _roots, createRoot, unmountComponentAtNode, createPortal, flushSync } from "./renderer.js";
|
|
10
|
+
export type { Subscription, Dpr, Size, Viewport, RenderCallback, Frameloop, Performance, Renderer, XRManager, RootState, RootStore, } from "./store.js";
|
|
11
|
+
export { context } from "./store.js";
|
|
12
|
+
export type { ObjectMap, Camera, Disposable, Act } from "./utils.js";
|
|
13
|
+
export { applyProps, getRootState, dispose, act, buildGraph } from "./utils.js";
|
|
@@ -1,31 +1,31 @@
|
|
|
1
|
-
/// <reference types="webxr" />
|
|
2
|
-
import type { RootState } from "./store.js";
|
|
3
|
-
export type GlobalRenderCallback = (timestamp: number) => void;
|
|
4
|
-
/**
|
|
5
|
-
* Adds a global render callback which is called each frame.
|
|
6
|
-
* @see https://docs.pmnd.rs/react-three-fiber/api/additional-exports#addEffect
|
|
7
|
-
*/
|
|
8
|
-
export declare const addEffect: (callback: GlobalRenderCallback) => () => void;
|
|
9
|
-
/**
|
|
10
|
-
* Adds a global after-render callback which is called each frame.
|
|
11
|
-
* @see https://docs.pmnd.rs/react-three-fiber/api/additional-exports#addAfterEffect
|
|
12
|
-
*/
|
|
13
|
-
export declare const addAfterEffect: (callback: GlobalRenderCallback) => () => void;
|
|
14
|
-
/**
|
|
15
|
-
* Adds a global callback which is called when rendering stops.
|
|
16
|
-
* @see https://docs.pmnd.rs/react-three-fiber/api/additional-exports#addTail
|
|
17
|
-
*/
|
|
18
|
-
export declare const addTail: (callback: GlobalRenderCallback) => () => void;
|
|
19
|
-
export type GlobalEffectType = 'before' | 'after' | 'tail';
|
|
20
|
-
export declare function flushGlobalEffects(type: GlobalEffectType, timestamp: number): void;
|
|
21
|
-
export declare function loop(timestamp: number): void;
|
|
22
|
-
/**
|
|
23
|
-
* Invalidates the view, requesting a frame to be rendered. Will globally invalidate unless passed a root's state.
|
|
24
|
-
* @see https://docs.pmnd.rs/react-three-fiber/api/additional-exports#invalidate
|
|
25
|
-
*/
|
|
26
|
-
export declare function invalidate(state?: RootState, frames?: number): void;
|
|
27
|
-
/**
|
|
28
|
-
* Advances the frameloop and runs render effects, useful for when manually rendering via `frameloop="never"`.
|
|
29
|
-
* @see https://docs.pmnd.rs/react-three-fiber/api/additional-exports#advance
|
|
30
|
-
*/
|
|
31
|
-
export declare function advance(timestamp: number, runGlobalEffects?: boolean, state?: RootState, frame?: XRFrame): void;
|
|
1
|
+
/// <reference types="webxr" />
|
|
2
|
+
import type { RootState } from "./store.js";
|
|
3
|
+
export type GlobalRenderCallback = (timestamp: number) => void;
|
|
4
|
+
/**
|
|
5
|
+
* Adds a global render callback which is called each frame.
|
|
6
|
+
* @see https://docs.pmnd.rs/react-three-fiber/api/additional-exports#addEffect
|
|
7
|
+
*/
|
|
8
|
+
export declare const addEffect: (callback: GlobalRenderCallback) => () => void;
|
|
9
|
+
/**
|
|
10
|
+
* Adds a global after-render callback which is called each frame.
|
|
11
|
+
* @see https://docs.pmnd.rs/react-three-fiber/api/additional-exports#addAfterEffect
|
|
12
|
+
*/
|
|
13
|
+
export declare const addAfterEffect: (callback: GlobalRenderCallback) => () => void;
|
|
14
|
+
/**
|
|
15
|
+
* Adds a global callback which is called when rendering stops.
|
|
16
|
+
* @see https://docs.pmnd.rs/react-three-fiber/api/additional-exports#addTail
|
|
17
|
+
*/
|
|
18
|
+
export declare const addTail: (callback: GlobalRenderCallback) => () => void;
|
|
19
|
+
export type GlobalEffectType = 'before' | 'after' | 'tail';
|
|
20
|
+
export declare function flushGlobalEffects(type: GlobalEffectType, timestamp: number): void;
|
|
21
|
+
export declare function loop(timestamp: number): void;
|
|
22
|
+
/**
|
|
23
|
+
* Invalidates the view, requesting a frame to be rendered. Will globally invalidate unless passed a root's state.
|
|
24
|
+
* @see https://docs.pmnd.rs/react-three-fiber/api/additional-exports#invalidate
|
|
25
|
+
*/
|
|
26
|
+
export declare function invalidate(state?: RootState, frames?: number): void;
|
|
27
|
+
/**
|
|
28
|
+
* Advances the frameloop and runs render effects, useful for when manually rendering via `frameloop="never"`.
|
|
29
|
+
* @see https://docs.pmnd.rs/react-three-fiber/api/additional-exports#advance
|
|
30
|
+
*/
|
|
31
|
+
export declare function advance(timestamp: number, runGlobalEffects?: boolean, state?: RootState, frame?: XRFrame): void;
|
|
@@ -1,50 +1,50 @@
|
|
|
1
|
-
import * as THREE from 'three';
|
|
2
|
-
import * as React from 'react';
|
|
3
|
-
import Reconciler from 'react-reconciler';
|
|
4
|
-
import { IsAllOptional } from "./utils.js";
|
|
5
|
-
import type { RootStore } from "./store.js";
|
|
6
|
-
import { type EventHandlers } from "./events.js";
|
|
7
|
-
import type { ThreeElement } from "../three-types.js";
|
|
8
|
-
export interface Root {
|
|
9
|
-
fiber: Reconciler.FiberRoot;
|
|
10
|
-
store: RootStore;
|
|
11
|
-
}
|
|
12
|
-
export type AttachFnType<O = any> = (parent: any, self: O) => () => void;
|
|
13
|
-
export type AttachType<O = any> = string | AttachFnType<O>;
|
|
14
|
-
export type ConstructorRepresentation<T = any> = new (...args: any[]) => T;
|
|
15
|
-
export interface Catalogue {
|
|
16
|
-
[name: string]: ConstructorRepresentation;
|
|
17
|
-
}
|
|
18
|
-
export type Args<T> = T extends ConstructorRepresentation ? T extends typeof THREE.Color ? [r: number, g: number, b: number] | [color: THREE.ColorRepresentation] : ConstructorParameters<T> : any[];
|
|
19
|
-
type ArgsProp<P> = P extends ConstructorRepresentation ? IsAllOptional<ConstructorParameters<P>> extends true ? {
|
|
20
|
-
args?: Args<P>;
|
|
21
|
-
} : {
|
|
22
|
-
args: Args<P>;
|
|
23
|
-
} : {
|
|
24
|
-
args: unknown[];
|
|
25
|
-
};
|
|
26
|
-
export type InstanceProps<T = any, P = any> = ArgsProp<P> & {
|
|
27
|
-
object?: T;
|
|
28
|
-
dispose?: null;
|
|
29
|
-
attach?: AttachType<T>;
|
|
30
|
-
onUpdate?: (self: T) => void;
|
|
31
|
-
};
|
|
32
|
-
export interface Instance<O = any> {
|
|
33
|
-
root: RootStore;
|
|
34
|
-
type: string;
|
|
35
|
-
parent: Instance | null;
|
|
36
|
-
children: Instance[];
|
|
37
|
-
props: InstanceProps<O> & Record<string, unknown>;
|
|
38
|
-
object: O & {
|
|
39
|
-
__r3f?: Instance<O>;
|
|
40
|
-
};
|
|
41
|
-
eventCount: number;
|
|
42
|
-
handlers: Partial<EventHandlers>;
|
|
43
|
-
attach?: AttachType<O>;
|
|
44
|
-
previousAttach?: any;
|
|
45
|
-
isHidden: boolean;
|
|
46
|
-
}
|
|
47
|
-
export declare function extend<T extends ConstructorRepresentation>(objects: T): React.ExoticComponent<ThreeElement<T>>;
|
|
48
|
-
export declare function extend<T extends Catalogue>(objects: T): void;
|
|
49
|
-
export declare const reconciler: Reconciler.Reconciler<RootStore, Instance<any>, void, Instance<any>, any>;
|
|
50
|
-
export {};
|
|
1
|
+
import * as THREE from 'three';
|
|
2
|
+
import * as React from 'react';
|
|
3
|
+
import Reconciler from 'react-reconciler';
|
|
4
|
+
import { IsAllOptional } from "./utils.js";
|
|
5
|
+
import type { RootStore } from "./store.js";
|
|
6
|
+
import { type EventHandlers } from "./events.js";
|
|
7
|
+
import type { ThreeElement } from "../three-types.js";
|
|
8
|
+
export interface Root {
|
|
9
|
+
fiber: Reconciler.FiberRoot;
|
|
10
|
+
store: RootStore;
|
|
11
|
+
}
|
|
12
|
+
export type AttachFnType<O = any> = (parent: any, self: O) => () => void;
|
|
13
|
+
export type AttachType<O = any> = string | AttachFnType<O>;
|
|
14
|
+
export type ConstructorRepresentation<T = any> = new (...args: any[]) => T;
|
|
15
|
+
export interface Catalogue {
|
|
16
|
+
[name: string]: ConstructorRepresentation;
|
|
17
|
+
}
|
|
18
|
+
export type Args<T> = T extends ConstructorRepresentation ? T extends typeof THREE.Color ? [r: number, g: number, b: number] | [color: THREE.ColorRepresentation] : ConstructorParameters<T> : any[];
|
|
19
|
+
type ArgsProp<P> = P extends ConstructorRepresentation ? IsAllOptional<ConstructorParameters<P>> extends true ? {
|
|
20
|
+
args?: Args<P>;
|
|
21
|
+
} : {
|
|
22
|
+
args: Args<P>;
|
|
23
|
+
} : {
|
|
24
|
+
args: unknown[];
|
|
25
|
+
};
|
|
26
|
+
export type InstanceProps<T = any, P = any> = ArgsProp<P> & {
|
|
27
|
+
object?: T;
|
|
28
|
+
dispose?: null;
|
|
29
|
+
attach?: AttachType<T>;
|
|
30
|
+
onUpdate?: (self: T) => void;
|
|
31
|
+
};
|
|
32
|
+
export interface Instance<O = any> {
|
|
33
|
+
root: RootStore;
|
|
34
|
+
type: string;
|
|
35
|
+
parent: Instance | null;
|
|
36
|
+
children: Instance[];
|
|
37
|
+
props: InstanceProps<O> & Record<string, unknown>;
|
|
38
|
+
object: O & {
|
|
39
|
+
__r3f?: Instance<O>;
|
|
40
|
+
};
|
|
41
|
+
eventCount: number;
|
|
42
|
+
handlers: Partial<EventHandlers>;
|
|
43
|
+
attach?: AttachType<O>;
|
|
44
|
+
previousAttach?: any;
|
|
45
|
+
isHidden: boolean;
|
|
46
|
+
}
|
|
47
|
+
export declare function extend<T extends ConstructorRepresentation>(objects: T): React.ExoticComponent<ThreeElement<T>>;
|
|
48
|
+
export declare function extend<T extends Catalogue>(objects: T): void;
|
|
49
|
+
export declare const reconciler: Reconciler.Reconciler<RootStore, Instance<any>, void, Instance<any>, never, any>;
|
|
50
|
+
export {};
|