@galacean/engine-core 1.1.0-beta.27 → 1.1.0-beta.29
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/dist/main.js +46 -20
- package/dist/main.js.map +1 -1
- package/dist/miniprogram.js +46 -20
- package/dist/module.js +46 -20
- package/dist/module.js.map +1 -1
- package/package.json +3 -3
- package/types/animation/AnimatorLayerMask.d.ts +45 -0
- package/types/animation/LayerPathMask.d.ts +16 -0
- package/types/animation/animationCurve/AnimationStringCurve.d.ts +7 -0
- package/types/xr/XRManager.d.ts +5 -0
- package/types/xr/XRPose.d.ts +15 -0
- package/types/xr/feature/XRFeature.d.ts +16 -0
- package/types/xr/feature/XRFeatureManager.d.ts +65 -0
- package/types/xr/feature/XRFeatureType.d.ts +13 -0
- package/types/xr/feature/camera/XRCameraManager.d.ts +26 -0
- package/types/xr/feature/hitTest/TrackableType.d.ts +10 -0
- package/types/xr/feature/hitTest/XRHitResult.d.ts +19 -0
- package/types/xr/feature/hitTest/XRHitTest.d.ts +39 -0
- package/types/xr/feature/hitTest/XRHitTestManager.d.ts +38 -0
- package/types/xr/feature/hitTest/XRHitTestType.d.ts +16 -0
- package/types/xr/feature/movementTracking/XRMovementTracking.d.ts +18 -0
- package/types/xr/feature/movementTracking/XRMovementTrackingManager.d.ts +10 -0
- package/types/xr/feature/movementTracking/XRMovementTrackingMode.d.ts +5 -0
- package/types/xr/feature/trackable/XRRequestTracking.d.ts +1 -0
- package/types/xr/feature/trackable/XRRequestTrackingState.d.ts +11 -0
- package/types/xr/feature/trackable/XRTrackableFeature.d.ts +38 -0
- package/types/xr/feature/trackable/XRTrackableManager.d.ts +41 -0
- package/types/xr/feature/trackable/XRTracked.d.ts +1 -0
- package/types/xr/feature/trackable/anchor/XRAnchor.d.ts +6 -0
- package/types/xr/feature/trackable/anchor/XRAnchorTracking.d.ts +37 -0
- package/types/xr/feature/trackable/anchor/XRAnchorTrackingManager.d.ts +20 -0
- package/types/xr/feature/trackable/anchor/XRRequestAnchor.d.ts +15 -0
- package/types/xr/feature/trackable/image/XRImageTracking.d.ts +24 -0
- package/types/xr/feature/trackable/image/XRImageTrackingManager.d.ts +31 -0
- package/types/xr/feature/trackable/image/XRReferenceImage.d.ts +11 -0
- package/types/xr/feature/trackable/image/XRRequestImage.d.ts +13 -0
- package/types/xr/feature/trackable/image/XRTrackedImage.d.ts +8 -0
- package/types/xr/feature/trackable/plane/XRPlaneMode.d.ts +13 -0
- package/types/xr/feature/trackable/plane/XRPlaneTracking.d.ts +23 -0
- package/types/xr/feature/trackable/plane/XRPlaneTrackingManager.d.ts +11 -0
- package/types/xr/feature/trackable/plane/XRRequestPlane.d.ts +12 -0
- package/types/xr/feature/trackable/plane/XRTrackedPlane.d.ts +20 -0
- package/types/xr/index.d.ts +25 -0
- package/types/xr/input/XRCamera.d.ts +15 -0
- package/types/xr/input/XRController.d.ts +38 -0
- package/types/xr/input/XRControllerPoseMode.d.ts +9 -0
- package/types/xr/input/XRInput.d.ts +8 -0
- package/types/xr/input/XRInputButton.d.ts +19 -0
- package/types/xr/input/XRInputEvent.d.ts +24 -0
- package/types/xr/input/XRInputEventType.d.ts +11 -0
- package/types/xr/input/XRInputManager.d.ts +31 -0
- package/types/xr/input/XRInputType.d.ts +23 -0
- package/types/xr/input/XRTargetRayMode.d.ts +12 -0
- package/types/xr/input/XRTrackedInputDevice.d.ts +21 -0
- package/types/xr/input/XRTrackedUpdateFlag.d.ts +11 -0
- package/types/xr/input/XRTrackingState.d.ts +11 -0
- package/types/xr/session/XRSessionManager.d.ts +45 -0
- package/types/xr/session/XRSessionMode.d.ts +8 -0
- package/types/xr/session/XRSessionState.d.ts +13 -0
- package/types/RenderPipeline/MeshRenderData.d.ts +0 -17
- package/types/RenderPipeline/MeshRenderElement.d.ts +0 -19
- package/types/RenderPipeline/SpriteElement.d.ts +0 -15
- package/types/RenderPipeline/SpriteMaskElement.d.ts +0 -12
- package/types/RenderPipeline/TextRenderElement.d.ts +0 -8
- package/types/asset/IRefObject.d.ts +0 -2
- package/types/asset/RefObject.d.ts +0 -27
- package/types/base/Event.d.ts +0 -24
- package/types/base/Util.d.ts +0 -14
- package/types/physics/PhysicsManager.d.ts +0 -78
- /package/types/{2d/data/RenderData2D.d.ts → enums/CameraType.d.ts} +0 -0
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@galacean/engine-core",
|
|
3
|
-
"version": "1.1.0-beta.
|
|
3
|
+
"version": "1.1.0-beta.29",
|
|
4
4
|
"publishConfig": {
|
|
5
5
|
"access": "public",
|
|
6
6
|
"registry": "https://registry.npmjs.org"
|
|
@@ -15,10 +15,10 @@
|
|
|
15
15
|
"types/**/*"
|
|
16
16
|
],
|
|
17
17
|
"dependencies": {
|
|
18
|
-
"@galacean/engine-math": "1.1.0-beta.
|
|
18
|
+
"@galacean/engine-math": "1.1.0-beta.29"
|
|
19
19
|
},
|
|
20
20
|
"devDependencies": {
|
|
21
|
-
"@galacean/engine-design": "1.1.0-beta.
|
|
21
|
+
"@galacean/engine-design": "1.1.0-beta.29"
|
|
22
22
|
},
|
|
23
23
|
"scripts": {
|
|
24
24
|
"b:types": "tsc"
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
import { Entity } from "../Entity";
|
|
2
|
+
import { LayerPathMask } from "./LayerPathMask";
|
|
3
|
+
/**
|
|
4
|
+
* AnimatorLayerMask is used to mask out certain entities from being animated by an AnimatorLayer.
|
|
5
|
+
*/
|
|
6
|
+
export declare class AnimatorLayerMask {
|
|
7
|
+
/**
|
|
8
|
+
* Creates an AnimatorLayerMask instance by specifying an entity.
|
|
9
|
+
* This will automatically add path masks for the entity and all its children.
|
|
10
|
+
* @param entity - The root entity to create path masks for
|
|
11
|
+
*/
|
|
12
|
+
static createByEntity(entity: Entity): AnimatorLayerMask;
|
|
13
|
+
private static _addPathMaskWithChildren;
|
|
14
|
+
private _pathMasks;
|
|
15
|
+
private _pathMaskMap;
|
|
16
|
+
/**
|
|
17
|
+
* The list of path masks.
|
|
18
|
+
*/
|
|
19
|
+
get pathMasks(): Readonly<LayerPathMask[]>;
|
|
20
|
+
/**
|
|
21
|
+
* Adds a path mask to the AnimatorLayerMask, the root path is "".
|
|
22
|
+
* @param path - The path to add a mask for
|
|
23
|
+
* @returns The created or existing LayerPathMask
|
|
24
|
+
*/
|
|
25
|
+
addPathMask(path: string): LayerPathMask;
|
|
26
|
+
/**
|
|
27
|
+
* Removes a path mask from the AnimatorLayerMask.
|
|
28
|
+
* @param path - The path of the mask to remove
|
|
29
|
+
*/
|
|
30
|
+
removePathMask(path: any): void;
|
|
31
|
+
/**
|
|
32
|
+
* Get a path mask based on the given path.
|
|
33
|
+
* @param path - The path of the mask to get
|
|
34
|
+
* @returns The LayerPathMask for the given path
|
|
35
|
+
*/
|
|
36
|
+
getPathMask(path: string): LayerPathMask;
|
|
37
|
+
/**
|
|
38
|
+
* Sets the active state of a path mask.
|
|
39
|
+
* If recursive is true, it also sets the active state of all child path masks.
|
|
40
|
+
* @param path - The path of the mask to modify
|
|
41
|
+
* @param active - The active state to set
|
|
42
|
+
* @param withChildren - Whether to apply the active state recursively to child paths
|
|
43
|
+
*/
|
|
44
|
+
setPathMaskActive(path: string, active: boolean, withChildren?: boolean): void;
|
|
45
|
+
}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* LayerPathMask represents a mask for a specific entity in an animation layer.
|
|
3
|
+
* It is used to control the animation whether to be applied to the entity or not.
|
|
4
|
+
*/
|
|
5
|
+
export declare class LayerPathMask {
|
|
6
|
+
/**
|
|
7
|
+
* It identifies a particular entity in the hierarchy.
|
|
8
|
+
* Example: "arm/left/hand" could be a path to the left hand of a character.
|
|
9
|
+
*/
|
|
10
|
+
path: string;
|
|
11
|
+
/**
|
|
12
|
+
* The active property is indicating whether the animation at this path is active or not.
|
|
13
|
+
* When true, the animation for this path is applied; when false, the animation for this path is ignored.
|
|
14
|
+
*/
|
|
15
|
+
active: boolean;
|
|
16
|
+
}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { IXRPose } from "@galacean/engine-design";
|
|
2
|
+
import { Matrix, Quaternion, Vector3 } from "@galacean/engine-math";
|
|
3
|
+
/**
|
|
4
|
+
* Data for describing pose in the XR space.
|
|
5
|
+
*/
|
|
6
|
+
export declare class XRPose implements IXRPose {
|
|
7
|
+
/** The position of the pose in XR space. */
|
|
8
|
+
position: Vector3;
|
|
9
|
+
/** The rotation of the pose in XR space. */
|
|
10
|
+
rotation: Quaternion;
|
|
11
|
+
/** The matrix of the pose in XR space. */
|
|
12
|
+
matrix: Matrix;
|
|
13
|
+
/** The inverse matrix of the pose in XR space. */
|
|
14
|
+
inverseMatrix: Matrix;
|
|
15
|
+
}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { IXRPlatformFeature } from "@galacean/engine-design";
|
|
2
|
+
import { XRManager } from "../XRManager";
|
|
3
|
+
import { XRFeatureType } from "./XRFeatureType";
|
|
4
|
+
/**
|
|
5
|
+
* The base class of XR feature manager.
|
|
6
|
+
*/
|
|
7
|
+
export declare abstract class XRFeature<T extends IXRPlatformFeature = IXRPlatformFeature> {
|
|
8
|
+
protected _xrManager: XRManager;
|
|
9
|
+
protected _type: XRFeatureType;
|
|
10
|
+
protected _enabled: boolean;
|
|
11
|
+
/**
|
|
12
|
+
* Returns whether the feature is enabled.
|
|
13
|
+
*/
|
|
14
|
+
get enabled(): boolean;
|
|
15
|
+
set enabled(value: boolean);
|
|
16
|
+
}
|
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
import { IXRFeatureDescriptor, IXRFeatureManager, IXRFeature, IXRSession, IXRFrame } from "@galacean/engine-design";
|
|
2
|
+
import { Engine } from "../../Engine";
|
|
3
|
+
/**
|
|
4
|
+
* The base class of XR feature manager.
|
|
5
|
+
*/
|
|
6
|
+
export declare abstract class XRFeatureManager<TDescriptor extends IXRFeatureDescriptor = IXRFeatureDescriptor, TFeature extends IXRFeature = IXRFeature> implements IXRFeatureManager {
|
|
7
|
+
protected _engine: Engine;
|
|
8
|
+
_platformFeature: TFeature;
|
|
9
|
+
protected _descriptor: TDescriptor;
|
|
10
|
+
protected _enabled: boolean;
|
|
11
|
+
/**
|
|
12
|
+
* Return the descriptor of the feature.
|
|
13
|
+
*/
|
|
14
|
+
get descriptor(): TDescriptor;
|
|
15
|
+
set descriptor(value: TDescriptor);
|
|
16
|
+
/**
|
|
17
|
+
* Returns whether the feature is enabled.
|
|
18
|
+
*/
|
|
19
|
+
get enabled(): boolean;
|
|
20
|
+
set enabled(value: boolean);
|
|
21
|
+
/**
|
|
22
|
+
* Returns whether the feature is supported.
|
|
23
|
+
* @param descriptor - The descriptor of the feature
|
|
24
|
+
* @returns The promise of the feature
|
|
25
|
+
*/
|
|
26
|
+
isSupported(descriptor?: IXRFeatureDescriptor): Promise<void>;
|
|
27
|
+
/**
|
|
28
|
+
* Initialize the feature.
|
|
29
|
+
* @returns The promise of the feature
|
|
30
|
+
*/
|
|
31
|
+
initialize(): Promise<void>;
|
|
32
|
+
/**
|
|
33
|
+
* Called when be enabled.
|
|
34
|
+
*/
|
|
35
|
+
onEnable(): void;
|
|
36
|
+
/**
|
|
37
|
+
* Called when be disabled.
|
|
38
|
+
*/
|
|
39
|
+
onDisable(): void;
|
|
40
|
+
/**
|
|
41
|
+
* Called when xr frame is updated.
|
|
42
|
+
*/
|
|
43
|
+
onUpdate(session: IXRSession, frame: IXRFrame): void;
|
|
44
|
+
/**
|
|
45
|
+
* Called when the session is initialized.
|
|
46
|
+
*/
|
|
47
|
+
onSessionInit(): void;
|
|
48
|
+
/**
|
|
49
|
+
* Called when session starts.
|
|
50
|
+
*/
|
|
51
|
+
onSessionStart(): void;
|
|
52
|
+
/**
|
|
53
|
+
* Called when the session is stopped.
|
|
54
|
+
*/
|
|
55
|
+
onSessionStop(): void;
|
|
56
|
+
/**
|
|
57
|
+
* Called when the session is destroyed.
|
|
58
|
+
*/
|
|
59
|
+
onSessionDestroy(): void;
|
|
60
|
+
/**
|
|
61
|
+
* Called when the xr module is destroyed.
|
|
62
|
+
*/
|
|
63
|
+
onDestroy(): void;
|
|
64
|
+
constructor(_engine: Engine);
|
|
65
|
+
}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { Camera } from "../../../Camera";
|
|
2
|
+
import { XRTrackedInputDevice } from "../../input/XRTrackedInputDevice";
|
|
3
|
+
/**
|
|
4
|
+
* The manager of XR camera.
|
|
5
|
+
*/
|
|
6
|
+
export declare class XRCameraManager {
|
|
7
|
+
private _xrManager;
|
|
8
|
+
/**
|
|
9
|
+
* The fixed foveation of the camera.
|
|
10
|
+
*/
|
|
11
|
+
get fixedFoveation(): number;
|
|
12
|
+
set fixedFoveation(value: number);
|
|
13
|
+
/**
|
|
14
|
+
* Attach the camera to the specified input type(Camera, LeftCamera or RightCamera).
|
|
15
|
+
* The camera entity need to be moved to the XROrigin entity.
|
|
16
|
+
* @param type - The input type
|
|
17
|
+
* @param camera - The camera to be attached
|
|
18
|
+
*/
|
|
19
|
+
attachCamera(type: XRTrackedInputDevice.Camera | XRTrackedInputDevice.LeftCamera | XRTrackedInputDevice.RightCamera, camera: Camera): void;
|
|
20
|
+
/**
|
|
21
|
+
* Detach the camera from the specified input type.
|
|
22
|
+
* @param type - The input type
|
|
23
|
+
* @returns The camera that was detached
|
|
24
|
+
*/
|
|
25
|
+
detachCamera(type: XRTrackedInputDevice.Camera | XRTrackedInputDevice.LeftCamera | XRTrackedInputDevice.RightCamera): Camera;
|
|
26
|
+
}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { IXRTracked } from "@galacean/engine-design";
|
|
2
|
+
import { Vector3 } from "@galacean/engine-math";
|
|
3
|
+
import { TrackableType } from "./TrackableType";
|
|
4
|
+
/**
|
|
5
|
+
* XR hit result.
|
|
6
|
+
* It is the detection result returned by using XR HitTest feature.
|
|
7
|
+
*/
|
|
8
|
+
export declare class XRHitResult {
|
|
9
|
+
/** The position of the hit point. */
|
|
10
|
+
point: Vector3;
|
|
11
|
+
/** The normal of the hit point. */
|
|
12
|
+
normal: Vector3;
|
|
13
|
+
/** The distance from the origin of the ray to the hit point. */
|
|
14
|
+
distance: number;
|
|
15
|
+
/** The hit tracked object, such as IXRTrackedPlane. */
|
|
16
|
+
trackedObject: IXRTracked;
|
|
17
|
+
/** The type of tracked object detected, such as TrackableType.Plane */
|
|
18
|
+
trackableType: TrackableType;
|
|
19
|
+
}
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
import { Ray } from "@galacean/engine-math";
|
|
2
|
+
import { XRManager } from "../../XRManager";
|
|
3
|
+
import { XRFeature } from "../XRFeature";
|
|
4
|
+
import { TrackableType } from "./TrackableType";
|
|
5
|
+
import { XRHitResult } from "./XRHitResult";
|
|
6
|
+
/**
|
|
7
|
+
* The manager of XR hit test.
|
|
8
|
+
*/
|
|
9
|
+
export declare class XRHitTest extends XRFeature {
|
|
10
|
+
private _tempRay;
|
|
11
|
+
private _tempVec2;
|
|
12
|
+
private _tempVec30;
|
|
13
|
+
private _tempVec31;
|
|
14
|
+
private _tempVec32;
|
|
15
|
+
private _tempVec33;
|
|
16
|
+
private _tempVec34;
|
|
17
|
+
private _tempVec35;
|
|
18
|
+
/**
|
|
19
|
+
* @param xrManager - The xr manager
|
|
20
|
+
*/
|
|
21
|
+
constructor(xrManager: XRManager);
|
|
22
|
+
/**
|
|
23
|
+
* Hit test.
|
|
24
|
+
* @param ray - The ray to test
|
|
25
|
+
* @param type - The type of hit test
|
|
26
|
+
* @returns The hit result
|
|
27
|
+
*/
|
|
28
|
+
hitTest(ray: Ray, type: TrackableType): XRHitResult[];
|
|
29
|
+
/**
|
|
30
|
+
* Screen hit test.
|
|
31
|
+
* @param x - The x coordinate of the screen point (normalized)
|
|
32
|
+
* @param y - The y coordinate of the screen point (normalized)
|
|
33
|
+
* @param type - The type of hit test
|
|
34
|
+
* @returns The hit result
|
|
35
|
+
*/
|
|
36
|
+
screenHitTest(x: number, y: number, type: TrackableType): XRHitResult[];
|
|
37
|
+
private _hitTestPlane;
|
|
38
|
+
private _checkPointerWithinPlane;
|
|
39
|
+
}
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import { IXRFeatureDescriptor, IXRHitResult } from "@galacean/engine-design";
|
|
2
|
+
import { XRHitTestType } from "./XRHitTestType";
|
|
3
|
+
import { Ray } from "@galacean/engine-math";
|
|
4
|
+
import { XRFeatureManager } from "../XRFeatureManager";
|
|
5
|
+
export declare class XRHitTestManager extends XRFeatureManager {
|
|
6
|
+
private _tempRay;
|
|
7
|
+
private _tempVec2;
|
|
8
|
+
private _tempVec30;
|
|
9
|
+
private _tempVec31;
|
|
10
|
+
private _tempVec32;
|
|
11
|
+
private _tempVec33;
|
|
12
|
+
private _tempVec34;
|
|
13
|
+
private _tempVec35;
|
|
14
|
+
/**
|
|
15
|
+
* Returns whether the feature is supported.
|
|
16
|
+
* @param descriptor - The descriptor of the feature
|
|
17
|
+
* @returns The promise of the feature
|
|
18
|
+
*/
|
|
19
|
+
isSupported(descriptor?: IXRFeatureDescriptor): Promise<void>;
|
|
20
|
+
/**
|
|
21
|
+
* Hit test.
|
|
22
|
+
* @param ray - The ray to test
|
|
23
|
+
* @param type - The type of hit test
|
|
24
|
+
* @returns The hit result
|
|
25
|
+
*/
|
|
26
|
+
hitTest(ray: Ray, type: XRHitTestType): IXRHitResult[];
|
|
27
|
+
/**
|
|
28
|
+
* Screen hit test.
|
|
29
|
+
* @param x - The x coordinate of the screen point (normalized)
|
|
30
|
+
* @param y - The y coordinate of the screen point (normalized)
|
|
31
|
+
* @param type - The type of hit test
|
|
32
|
+
* @returns The hit result
|
|
33
|
+
*/
|
|
34
|
+
screenHitTest(x: number, y: number, type: XRHitTestType): IXRHitResult[];
|
|
35
|
+
private _hitTest;
|
|
36
|
+
private _hitTestPlane;
|
|
37
|
+
private _checkPointerWithinPlane;
|
|
38
|
+
}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Enum for the types of hit test that can be performed.
|
|
3
|
+
* Note: currently only supports plane.
|
|
4
|
+
*/
|
|
5
|
+
export declare enum XRHitTestType {
|
|
6
|
+
/** None */
|
|
7
|
+
None = 0,
|
|
8
|
+
/** Tracked plane. */
|
|
9
|
+
Plane = 1,
|
|
10
|
+
/** Tracked mesh. */
|
|
11
|
+
Mesh = 2,
|
|
12
|
+
/** Tracked anchor. */
|
|
13
|
+
Anchor = 4,
|
|
14
|
+
/** All tracked objects. */
|
|
15
|
+
All = 7
|
|
16
|
+
}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { XRManager } from "../../XRManager";
|
|
2
|
+
import { XRFeature } from "../XRFeature";
|
|
3
|
+
import { XRMovementTrackingMode } from "./XRMovementTrackingMode";
|
|
4
|
+
/**
|
|
5
|
+
* The manager of XR movement tracking.
|
|
6
|
+
*/
|
|
7
|
+
export declare class XRMovementTracking extends XRFeature {
|
|
8
|
+
private _trackingMode;
|
|
9
|
+
/**
|
|
10
|
+
* Get the tracking mode.
|
|
11
|
+
*/
|
|
12
|
+
get trackingMode(): XRMovementTrackingMode;
|
|
13
|
+
/**
|
|
14
|
+
* @param xrManager - The xr manager
|
|
15
|
+
* @param trackingMode - The tracking mode
|
|
16
|
+
*/
|
|
17
|
+
constructor(xrManager: XRManager, trackingMode?: XRMovementTrackingMode);
|
|
18
|
+
}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { IXRMovementTracking, IXRMovementTrackingDescriptor } from "@galacean/engine-design";
|
|
2
|
+
import { XRMovementTrackingMode } from "./XRMovementTrackingMode";
|
|
3
|
+
import { XRFeatureManager } from "../XRFeatureManager";
|
|
4
|
+
export declare class XRMovementTrackingManager extends XRFeatureManager<IXRMovementTrackingDescriptor, IXRMovementTracking> {
|
|
5
|
+
/**
|
|
6
|
+
* Get the tracking mode.
|
|
7
|
+
*/
|
|
8
|
+
get trackingMode(): XRMovementTrackingMode;
|
|
9
|
+
set trackingMode(value: XRMovementTrackingMode);
|
|
10
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import { IXRTrackablePlatformFeature } from "@galacean/engine-design";
|
|
2
|
+
import { XRTrackingState } from "../../input/XRTrackingState";
|
|
3
|
+
import { XRFeature } from "../XRFeature";
|
|
4
|
+
import { XRRequestTracking } from "./XRRequestTracking";
|
|
5
|
+
import { XRTracked } from "./XRTracked";
|
|
6
|
+
/**
|
|
7
|
+
* The base class of XR trackable manager.
|
|
8
|
+
*/
|
|
9
|
+
export declare abstract class XRTrackableFeature<T extends XRTracked, K extends XRRequestTracking<T>> extends XRFeature<IXRTrackablePlatformFeature<T, K>> {
|
|
10
|
+
protected _requestTrackings: K[];
|
|
11
|
+
protected _tracked: T[];
|
|
12
|
+
protected _added: T[];
|
|
13
|
+
protected _updated: T[];
|
|
14
|
+
protected _removed: T[];
|
|
15
|
+
protected _statusSnapshot: Record<number, XRTrackingState>;
|
|
16
|
+
private _listeners;
|
|
17
|
+
/**
|
|
18
|
+
* Returns the tracked objects.
|
|
19
|
+
*/
|
|
20
|
+
get tracked(): readonly T[];
|
|
21
|
+
/**
|
|
22
|
+
* Add a listening function for tracked object changes.
|
|
23
|
+
* @param listener - The listening function
|
|
24
|
+
*/
|
|
25
|
+
addChangedListener(listener: (added: readonly T[], updated: readonly T[], removed: readonly T[]) => void): void;
|
|
26
|
+
/**
|
|
27
|
+
* Remove a listening function of tracked object changes.
|
|
28
|
+
* @param listener - The listening function
|
|
29
|
+
*/
|
|
30
|
+
removeChangedListener(listener: (added: readonly T[], updated: readonly T[], removed: readonly T[]) => void): void;
|
|
31
|
+
_onUpdate(): void;
|
|
32
|
+
_onSessionStop(): void;
|
|
33
|
+
_onSessionExit(): void;
|
|
34
|
+
_onDestroy(): void;
|
|
35
|
+
protected _addRequestTracking(requestTracking: K): void;
|
|
36
|
+
protected _removeRequestTracking(requestTracking: K): void;
|
|
37
|
+
protected _removeAllRequestTrackings(): void;
|
|
38
|
+
}
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
import { IXRFeatureDescriptor, IXRFrame, IXRRequestTracking, IXRSession, IXRTrackableFeature, IXRTracked } from "@galacean/engine-design";
|
|
2
|
+
import { XRTrackedUpdateFlag } from "../../input/XRTrackedUpdateFlag";
|
|
3
|
+
import { XRFeatureManager } from "../XRFeatureManager";
|
|
4
|
+
import { XRTrackingState } from "../../input/XRTrackingState";
|
|
5
|
+
/**
|
|
6
|
+
* The base class of XR trackable manager.
|
|
7
|
+
*/
|
|
8
|
+
export declare abstract class XRTrackableManager<TDescriptor extends IXRFeatureDescriptor, TXRTracked extends IXRTracked, TXRRequestTracking extends IXRRequestTracking<TXRTracked>, TTrackableFeature extends IXRTrackableFeature<TXRTracked, TXRRequestTracking>> extends XRFeatureManager<TDescriptor, TTrackableFeature> {
|
|
9
|
+
protected _requestTrackings: TXRRequestTracking[];
|
|
10
|
+
protected _trackedObjects: TXRTracked[];
|
|
11
|
+
protected _added: TXRTracked[];
|
|
12
|
+
protected _updated: TXRTracked[];
|
|
13
|
+
protected _removed: TXRTracked[];
|
|
14
|
+
protected _statusSnapshot: Record<number, XRTrackingState>;
|
|
15
|
+
private _trackedUpdateFlag;
|
|
16
|
+
/**
|
|
17
|
+
* Return Request tracking requirements.
|
|
18
|
+
*/
|
|
19
|
+
get requestTrackings(): readonly TXRRequestTracking[];
|
|
20
|
+
/**
|
|
21
|
+
* Returns the tracked objects.
|
|
22
|
+
*/
|
|
23
|
+
get trackedObjects(): readonly TXRTracked[];
|
|
24
|
+
addRequestTracking(requestTracking: TXRRequestTracking): void;
|
|
25
|
+
removeRequestTracking(remove: TXRRequestTracking): void;
|
|
26
|
+
removeAllRequestTrackings(): void;
|
|
27
|
+
/**
|
|
28
|
+
* Add a listening function to track changes.
|
|
29
|
+
* @param listener - The listening function
|
|
30
|
+
*/
|
|
31
|
+
addListener(listener: (type: XRTrackedUpdateFlag, param: readonly TXRTracked[]) => any): void;
|
|
32
|
+
/**
|
|
33
|
+
* Remove a listening function to track changes.
|
|
34
|
+
* @param listener - The listening function
|
|
35
|
+
*/
|
|
36
|
+
removeListener(listener: (type: XRTrackedUpdateFlag, param: readonly TXRTracked[]) => any): void;
|
|
37
|
+
onUpdate(session: IXRSession, frame: IXRFrame): void;
|
|
38
|
+
onSessionStop(): void;
|
|
39
|
+
onSessionDestroy(): void;
|
|
40
|
+
onDestroy(): void;
|
|
41
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
import { Quaternion, Vector3 } from "@galacean/engine-math";
|
|
2
|
+
import { XRManager } from "../../../XRManager";
|
|
3
|
+
import { XRTrackableFeature } from "../XRTrackableFeature";
|
|
4
|
+
import { XRAnchor } from "./XRAnchor";
|
|
5
|
+
import { XRRequestAnchor } from "./XRRequestAnchor";
|
|
6
|
+
/**
|
|
7
|
+
* The manager of XR anchor tracking.
|
|
8
|
+
*/
|
|
9
|
+
export declare class XRAnchorTracking extends XRTrackableFeature<XRAnchor, XRRequestAnchor> {
|
|
10
|
+
private _anchors;
|
|
11
|
+
/**
|
|
12
|
+
* The anchors to tracking.
|
|
13
|
+
*/
|
|
14
|
+
get trackingAnchors(): readonly XRAnchor[];
|
|
15
|
+
/**
|
|
16
|
+
* The tracked anchors.
|
|
17
|
+
*/
|
|
18
|
+
get trackedAnchors(): readonly XRAnchor[];
|
|
19
|
+
/**
|
|
20
|
+
* @param xrManager - The xr manager
|
|
21
|
+
*/
|
|
22
|
+
constructor(xrManager: XRManager);
|
|
23
|
+
/**
|
|
24
|
+
* Add a anchor in XR space.
|
|
25
|
+
* @param anchor - The anchor to be added
|
|
26
|
+
*/
|
|
27
|
+
addAnchor(position: Vector3, rotation: Quaternion): XRAnchor;
|
|
28
|
+
/**
|
|
29
|
+
* Remove a anchor in XR space.
|
|
30
|
+
* @param anchor - The anchor to be removed
|
|
31
|
+
*/
|
|
32
|
+
removeAnchor(anchor: XRAnchor): void;
|
|
33
|
+
/**
|
|
34
|
+
* Remove all tracking anchors.
|
|
35
|
+
*/
|
|
36
|
+
clearAnchors(): void;
|
|
37
|
+
}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { IXRPose, IXRTracked, IXRAnchorTracking, IXRRequestAnchorTracking, IXRAnchorTrackingDescriptor } from "@galacean/engine-design";
|
|
2
|
+
import { XRTrackableManager } from "../XRTrackableManager";
|
|
3
|
+
export declare class XRAnchorTrackingManager extends XRTrackableManager<IXRAnchorTrackingDescriptor, IXRTracked, IXRRequestAnchorTracking, IXRAnchorTracking> {
|
|
4
|
+
/**
|
|
5
|
+
* Add a tracking anchor.
|
|
6
|
+
* @param pose - The pose of anchor to be added
|
|
7
|
+
*/
|
|
8
|
+
addAnchor(pose: IXRPose): IXRRequestAnchorTracking;
|
|
9
|
+
/**
|
|
10
|
+
* Remove a tracking anchor.
|
|
11
|
+
* @param anchor - The anchor to be removed
|
|
12
|
+
*/
|
|
13
|
+
removeAnchor(anchor: IXRRequestAnchorTracking): void;
|
|
14
|
+
/**
|
|
15
|
+
* Remove all tracking anchors.
|
|
16
|
+
*/
|
|
17
|
+
removeAllAnchors(): void;
|
|
18
|
+
initialize(): Promise<void>;
|
|
19
|
+
private _createRequestTracking;
|
|
20
|
+
}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { Quaternion, Vector3 } from "@galacean/engine-math";
|
|
2
|
+
import { XRRequestTracking } from "../XRRequestTracking";
|
|
3
|
+
import { XRAnchor } from "./XRAnchor";
|
|
4
|
+
/**
|
|
5
|
+
* The request anchor in XR space.
|
|
6
|
+
*/
|
|
7
|
+
export declare class XRRequestAnchor extends XRRequestTracking<XRAnchor> {
|
|
8
|
+
position: Vector3;
|
|
9
|
+
rotation: Quaternion;
|
|
10
|
+
/**
|
|
11
|
+
* @param position - Requests the position of the anchor to be added
|
|
12
|
+
* @param rotation - Requests the rotation of the anchor to be added
|
|
13
|
+
*/
|
|
14
|
+
constructor(position: Vector3, rotation: Quaternion);
|
|
15
|
+
}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { XRManager } from "../../../XRManager";
|
|
2
|
+
import { XRTrackableFeature } from "../XRTrackableFeature";
|
|
3
|
+
import { XRReferenceImage } from "./XRReferenceImage";
|
|
4
|
+
import { XRRequestImage } from "./XRRequestImage";
|
|
5
|
+
import { XRTrackedImage } from "./XRTrackedImage";
|
|
6
|
+
/**
|
|
7
|
+
* The manager of XR image tracking.
|
|
8
|
+
*/
|
|
9
|
+
export declare class XRImageTracking extends XRTrackableFeature<XRTrackedImage, XRRequestImage> {
|
|
10
|
+
private _images;
|
|
11
|
+
/**
|
|
12
|
+
* The image to tracking.
|
|
13
|
+
*/
|
|
14
|
+
get images(): readonly XRReferenceImage[];
|
|
15
|
+
/**
|
|
16
|
+
* The tracked images.
|
|
17
|
+
*/
|
|
18
|
+
get trackedImages(): readonly XRTrackedImage[];
|
|
19
|
+
/**
|
|
20
|
+
* @param xrManager - The xr manager
|
|
21
|
+
* @param images - The images to be tracked
|
|
22
|
+
*/
|
|
23
|
+
constructor(xrManager: XRManager, images: XRReferenceImage[]);
|
|
24
|
+
}
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import { IXRImageTracking, IXRRequestImageTracking, IXRTrackedImage, IXRImageTrackingDescriptor } from "@galacean/engine-design";
|
|
2
|
+
import { XRTrackableManager } from "../XRTrackableManager";
|
|
3
|
+
import { XRReferenceImage } from "./XRReferenceImage";
|
|
4
|
+
export declare class XRImageTrackingManager extends XRTrackableManager<IXRImageTrackingDescriptor, IXRTrackedImage, IXRRequestImageTracking, IXRImageTracking> {
|
|
5
|
+
/**
|
|
6
|
+
* Add a tracking image
|
|
7
|
+
* @param image - xr reference image
|
|
8
|
+
*/
|
|
9
|
+
addImage(image: XRReferenceImage): void;
|
|
10
|
+
/**
|
|
11
|
+
* Add tracking images
|
|
12
|
+
* @param images - xr reference images
|
|
13
|
+
*/
|
|
14
|
+
addImage(images: XRReferenceImage[]): void;
|
|
15
|
+
/**
|
|
16
|
+
* Remove a tracking image
|
|
17
|
+
* @param image - xr reference image
|
|
18
|
+
*/
|
|
19
|
+
removeImage(image: XRReferenceImage): void;
|
|
20
|
+
/**
|
|
21
|
+
* Remove tracking images
|
|
22
|
+
* @param images - xr reference images
|
|
23
|
+
*/
|
|
24
|
+
removeImage(images: XRReferenceImage[]): void;
|
|
25
|
+
/**
|
|
26
|
+
* Remove all tracking images
|
|
27
|
+
*/
|
|
28
|
+
removeAllImages(): void;
|
|
29
|
+
initialize(): Promise<void>;
|
|
30
|
+
private _createRequestTracking;
|
|
31
|
+
}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { IXRReferenceImage } from "@galacean/engine-design";
|
|
2
|
+
/**
|
|
3
|
+
* A reference image is an image to look for in the physical environment.
|
|
4
|
+
*/
|
|
5
|
+
export declare class XRReferenceImage implements IXRReferenceImage {
|
|
6
|
+
name: string;
|
|
7
|
+
src: string | HTMLImageElement | SVGImageElement | HTMLVideoElement | HTMLCanvasElement | Blob | ImageData | ImageBitmap | OffscreenCanvas;
|
|
8
|
+
physicalWidth: number;
|
|
9
|
+
physicalHeight: number;
|
|
10
|
+
constructor(name: string, src: string | HTMLImageElement | SVGImageElement | HTMLVideoElement | HTMLCanvasElement | Blob | ImageData | ImageBitmap | OffscreenCanvas, physicalWidth?: number, physicalHeight?: number);
|
|
11
|
+
}
|