@spatialwalk/avatarkit 1.0.0-beta.10 → 1.0.0-beta.101
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 +771 -4
- package/README.md +676 -365
- package/dist/StreamingAudioPlayer-BULgPjpe.js +643 -0
- package/dist/avatar_core_wasm-CQbUl6zN.js +2696 -0
- package/dist/avatar_core_wasm-bd762669.wasm +0 -0
- package/dist/core/Avatar.d.ts +5 -7
- package/dist/core/AvatarController.d.ts +99 -60
- package/dist/core/AvatarManager.d.ts +32 -12
- package/dist/core/AvatarSDK.d.ts +58 -0
- package/dist/core/AvatarView.d.ts +136 -128
- package/dist/index-C0A1HA8M.js +18427 -0
- package/dist/index.d.ts +2 -4
- package/dist/index.js +17 -17
- package/dist/next.d.ts +2 -0
- package/dist/performance/FrameRateMonitor.d.ts +85 -0
- package/dist/types/character-settings.d.ts +7 -1
- package/dist/types/character.d.ts +42 -16
- package/dist/types/index.d.ts +165 -45
- package/dist/vite.d.ts +19 -0
- package/next.d.ts +3 -0
- package/next.js +187 -0
- package/package.json +38 -8
- package/vite.d.ts +20 -0
- package/vite.js +126 -0
- package/dist/StreamingAudioPlayer-Bq2-bQiT.js +0 -319
- package/dist/StreamingAudioPlayer-Bq2-bQiT.js.map +0 -1
- package/dist/animation/AnimationWebSocketClient.d.ts +0 -50
- package/dist/animation/AnimationWebSocketClient.d.ts.map +0 -1
- package/dist/animation/utils/eventEmitter.d.ts +0 -13
- package/dist/animation/utils/eventEmitter.d.ts.map +0 -1
- package/dist/animation/utils/flameConverter.d.ts +0 -26
- package/dist/animation/utils/flameConverter.d.ts.map +0 -1
- package/dist/audio/AnimationPlayer.d.ts +0 -57
- package/dist/audio/AnimationPlayer.d.ts.map +0 -1
- package/dist/audio/StreamingAudioPlayer.d.ts +0 -123
- package/dist/audio/StreamingAudioPlayer.d.ts.map +0 -1
- package/dist/avatar_core_wasm-D4eEi7Eh.js +0 -1666
- package/dist/avatar_core_wasm-D4eEi7Eh.js.map +0 -1
- package/dist/avatar_core_wasm.wasm +0 -0
- package/dist/config/app-config.d.ts +0 -44
- package/dist/config/app-config.d.ts.map +0 -1
- package/dist/config/constants.d.ts +0 -29
- package/dist/config/constants.d.ts.map +0 -1
- package/dist/config/sdk-config-loader.d.ts +0 -12
- package/dist/config/sdk-config-loader.d.ts.map +0 -1
- package/dist/core/Avatar.d.ts.map +0 -1
- package/dist/core/AvatarController.d.ts.map +0 -1
- package/dist/core/AvatarDownloader.d.ts +0 -95
- package/dist/core/AvatarDownloader.d.ts.map +0 -1
- package/dist/core/AvatarKit.d.ts +0 -48
- package/dist/core/AvatarKit.d.ts.map +0 -1
- package/dist/core/AvatarManager.d.ts.map +0 -1
- package/dist/core/AvatarView.d.ts.map +0 -1
- package/dist/core/NetworkLayer.d.ts +0 -59
- package/dist/core/NetworkLayer.d.ts.map +0 -1
- package/dist/generated/driveningress/v1/driveningress.d.ts +0 -80
- package/dist/generated/driveningress/v1/driveningress.d.ts.map +0 -1
- package/dist/generated/driveningress/v2/driveningress.d.ts +0 -81
- package/dist/generated/driveningress/v2/driveningress.d.ts.map +0 -1
- package/dist/generated/google/protobuf/struct.d.ts +0 -108
- package/dist/generated/google/protobuf/struct.d.ts.map +0 -1
- package/dist/generated/google/protobuf/timestamp.d.ts +0 -129
- package/dist/generated/google/protobuf/timestamp.d.ts.map +0 -1
- package/dist/index-bQnEVIkT.js +0 -5999
- package/dist/index-bQnEVIkT.js.map +0 -1
- package/dist/index.d.ts.map +0 -1
- package/dist/index.js.map +0 -1
- package/dist/renderer/RenderSystem.d.ts +0 -79
- package/dist/renderer/RenderSystem.d.ts.map +0 -1
- package/dist/renderer/covariance.d.ts +0 -13
- package/dist/renderer/covariance.d.ts.map +0 -1
- package/dist/renderer/renderer.d.ts +0 -8
- package/dist/renderer/renderer.d.ts.map +0 -1
- package/dist/renderer/sortSplats.d.ts +0 -12
- package/dist/renderer/sortSplats.d.ts.map +0 -1
- package/dist/renderer/webgl/reorderData.d.ts +0 -14
- package/dist/renderer/webgl/reorderData.d.ts.map +0 -1
- package/dist/renderer/webgl/webglRenderer.d.ts +0 -66
- package/dist/renderer/webgl/webglRenderer.d.ts.map +0 -1
- package/dist/renderer/webgpu/webgpuRenderer.d.ts +0 -54
- package/dist/renderer/webgpu/webgpuRenderer.d.ts.map +0 -1
- package/dist/types/character-settings.d.ts.map +0 -1
- package/dist/types/character.d.ts.map +0 -1
- package/dist/types/index.d.ts.map +0 -1
- package/dist/utils/animation-interpolation.d.ts +0 -17
- package/dist/utils/animation-interpolation.d.ts.map +0 -1
- package/dist/utils/cls-tracker.d.ts +0 -17
- package/dist/utils/cls-tracker.d.ts.map +0 -1
- package/dist/utils/error-utils.d.ts +0 -27
- package/dist/utils/error-utils.d.ts.map +0 -1
- package/dist/utils/logger.d.ts +0 -35
- package/dist/utils/logger.d.ts.map +0 -1
- package/dist/utils/reqId.d.ts +0 -20
- package/dist/utils/reqId.d.ts.map +0 -1
- package/dist/wasm/avatarCoreAdapter.d.ts +0 -188
- package/dist/wasm/avatarCoreAdapter.d.ts.map +0 -1
- package/dist/wasm/avatarCoreMemory.d.ts +0 -141
- package/dist/wasm/avatarCoreMemory.d.ts.map +0 -1
package/dist/index.d.ts
CHANGED
|
@@ -1,11 +1,9 @@
|
|
|
1
1
|
/**
|
|
2
|
-
*
|
|
2
|
+
* AvatarKit SDK - Unified Public API
|
|
3
3
|
*/
|
|
4
4
|
export { Avatar } from './core/Avatar';
|
|
5
5
|
export { AvatarController } from './core/AvatarController';
|
|
6
|
-
export {
|
|
6
|
+
export { AvatarSDK } from './core/AvatarSDK';
|
|
7
7
|
export { AvatarManager } from './core/AvatarManager';
|
|
8
8
|
export { AvatarView } from './core/AvatarView';
|
|
9
9
|
export * from './types';
|
|
10
|
-
export type { CharacterInfo, FlameInfo } from './wasm/avatarCoreAdapter';
|
|
11
|
-
//# sourceMappingURL=index.d.ts.map
|
package/dist/index.js
CHANGED
|
@@ -1,19 +1,19 @@
|
|
|
1
|
-
import { b
|
|
1
|
+
import { b, c, m, f, d, j, g, C, i, D, E, k, h, L, R, n } from "./index-C0A1HA8M.js";
|
|
2
2
|
export {
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
3
|
+
b as Avatar,
|
|
4
|
+
c as AvatarController,
|
|
5
|
+
m as AvatarError,
|
|
6
|
+
f as AvatarManager,
|
|
7
|
+
d as AvatarSDK,
|
|
8
|
+
j as AvatarState,
|
|
9
|
+
g as AvatarView,
|
|
10
|
+
C as ConnectionState,
|
|
11
|
+
i as ConversationState,
|
|
12
|
+
D as DrivingServiceMode,
|
|
13
|
+
E as Environment,
|
|
14
|
+
k as ErrorCode,
|
|
15
|
+
h as LoadProgress,
|
|
16
|
+
L as LogLevel,
|
|
17
|
+
R as ResourceType,
|
|
18
|
+
n as extractResourceUrls
|
|
18
19
|
};
|
|
19
|
-
//# sourceMappingURL=index.js.map
|
package/dist/next.d.ts
ADDED
|
@@ -0,0 +1,85 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Per-frame render timing — Web platform.
|
|
3
|
+
* Aligned with Android FrameRenderInfo / iOS FrameRenderInfo.
|
|
4
|
+
*/
|
|
5
|
+
export interface FrameRenderInfo {
|
|
6
|
+
/** Frame start timestamp (performance.now ms). */
|
|
7
|
+
startTimeMs: number;
|
|
8
|
+
/** Frame end timestamp (performance.now ms). */
|
|
9
|
+
endTimeMs: number;
|
|
10
|
+
/** Sort stage time (ms). */
|
|
11
|
+
sortTimeMs: number;
|
|
12
|
+
/** GPU render time (ms). */
|
|
13
|
+
renderTimeMs: number;
|
|
14
|
+
/** Reorder time (ms, WebGL path only; 0 for WebGPU). */
|
|
15
|
+
reorderTimeMs: number;
|
|
16
|
+
/** CPU render-submit time (ms, loadSplats + render call). */
|
|
17
|
+
renderSubmitTimeMs: number;
|
|
18
|
+
/** Production frame serial (incremented on actual render). */
|
|
19
|
+
frameSerial: number;
|
|
20
|
+
/** Presentation frame serial (incremented on display submit). */
|
|
21
|
+
presentFrameSerial: number;
|
|
22
|
+
/** Idle time: gap between previous frame end and this frame start (ms). */
|
|
23
|
+
idleTimeMs: number;
|
|
24
|
+
}
|
|
25
|
+
/**
|
|
26
|
+
* Frame rate monitoring info — unified public API across platforms.
|
|
27
|
+
* Contains pre-computed high-level performance metrics.
|
|
28
|
+
*/
|
|
29
|
+
export interface FrameRateInfo {
|
|
30
|
+
/** Production FPS (actual frames rendered per second). */
|
|
31
|
+
fps: number;
|
|
32
|
+
/** Presentation FPS (display refresh rate including reused frames). */
|
|
33
|
+
presentationFps: number;
|
|
34
|
+
/** 95th percentile frame interval (ms). */
|
|
35
|
+
frameIntervalP95Ms: number;
|
|
36
|
+
/** 99th percentile frame interval (ms). */
|
|
37
|
+
frameIntervalP99Ms: number;
|
|
38
|
+
/** Percentage of frames with interval > 50ms (jank ratio). */
|
|
39
|
+
jankRatioPercent: number;
|
|
40
|
+
/** Average total frame time (ms). */
|
|
41
|
+
averageFrameTimeMs: number;
|
|
42
|
+
/** Estimated CPU busy ratio (%). Browser approximation based on frame active time vs interval. */
|
|
43
|
+
cpuUsagePercent: number;
|
|
44
|
+
/** Per-frame details within the sliding window (aligned with Android/iOS). */
|
|
45
|
+
frames: FrameRenderInfo[];
|
|
46
|
+
}
|
|
47
|
+
export interface PlaybackStats {
|
|
48
|
+
avgFps: number;
|
|
49
|
+
frameCount: number;
|
|
50
|
+
durationMs: number;
|
|
51
|
+
/** Percentage of frame intervals > 50ms */
|
|
52
|
+
jankRatio: number;
|
|
53
|
+
/** Coefficient of variation of frame intervals (stddev / mean) */
|
|
54
|
+
fpsCv: number;
|
|
55
|
+
}
|
|
56
|
+
/**
|
|
57
|
+
* Frame rate monitor with 2-second sliding window.
|
|
58
|
+
* Aligned with Android/iOS FrameRateMonitor.
|
|
59
|
+
*
|
|
60
|
+
* @example
|
|
61
|
+
* ```ts
|
|
62
|
+
* controller.frameRateMonitorEnabled = true
|
|
63
|
+
* controller.onFrameRateInfo = (info) => {
|
|
64
|
+
* console.log('FPS:', info.fps, 'Jank:', info.jankRatioPercent)
|
|
65
|
+
* }
|
|
66
|
+
* ```
|
|
67
|
+
*/
|
|
68
|
+
export declare class FrameRateMonitor {
|
|
69
|
+
enabled: boolean;
|
|
70
|
+
onFrameRateInfo: ((info: FrameRateInfo) => void) | null;
|
|
71
|
+
private lwFrameCount;
|
|
72
|
+
private lwStartTimeMs;
|
|
73
|
+
private lwLastEndTimeMs;
|
|
74
|
+
private lwJankCount;
|
|
75
|
+
private lwSumInterval;
|
|
76
|
+
private lwSumIntervalSq;
|
|
77
|
+
/** Reset the lightweight counter. Call at playback start. */
|
|
78
|
+
resetPlaybackStats(): void;
|
|
79
|
+
/** Get lightweight playback stats. Call at playback end. */
|
|
80
|
+
getPlaybackStats(): PlaybackStats;
|
|
81
|
+
private frames;
|
|
82
|
+
private computeFrameRateInfo;
|
|
83
|
+
private percentileInterval;
|
|
84
|
+
private jankRatio;
|
|
85
|
+
}
|
|
@@ -16,8 +16,14 @@ export interface CameraSettings {
|
|
|
16
16
|
translationY: number;
|
|
17
17
|
translationZ: number;
|
|
18
18
|
}
|
|
19
|
+
export interface TransformSettings {
|
|
20
|
+
x: number;
|
|
21
|
+
y: number;
|
|
22
|
+
scale: number;
|
|
23
|
+
}
|
|
19
24
|
export interface CharacterSettings {
|
|
20
25
|
eyelid: EyelidSettings;
|
|
26
|
+
eyefocus?: EyelidSettings;
|
|
21
27
|
camera: CameraSettings;
|
|
28
|
+
transform?: TransformSettings;
|
|
22
29
|
}
|
|
23
|
-
//# sourceMappingURL=character-settings.d.ts.map
|
|
@@ -1,7 +1,45 @@
|
|
|
1
|
-
import { CharacterAsset } from '../generated/driveningress/v2/driveningress';
|
|
2
1
|
import { CameraSettings, CharacterSettings } from './character-settings';
|
|
2
|
+
export interface Resource {
|
|
3
|
+
type: string;
|
|
4
|
+
local: string;
|
|
5
|
+
remote: string;
|
|
6
|
+
}
|
|
7
|
+
export interface ResourceHolder {
|
|
8
|
+
resource?: Resource;
|
|
9
|
+
/** Compressed model resource (~30% of original size, with minor quality degradation). */
|
|
10
|
+
xrResource?: Resource;
|
|
11
|
+
}
|
|
12
|
+
export interface Models {
|
|
13
|
+
shape?: ResourceHolder;
|
|
14
|
+
gsStandard?: ResourceHolder;
|
|
15
|
+
gsHigh?: ResourceHolder;
|
|
16
|
+
gsUltra?: ResourceHolder;
|
|
17
|
+
}
|
|
18
|
+
export interface Animations {
|
|
19
|
+
frameIdle?: ResourceHolder;
|
|
20
|
+
frameMono?: ResourceHolder;
|
|
21
|
+
audioMono?: ResourceHolder;
|
|
22
|
+
}
|
|
23
|
+
export interface CustomAnimation {
|
|
24
|
+
key: string;
|
|
25
|
+
pbUrl: string;
|
|
26
|
+
wavUrl: string;
|
|
27
|
+
remark: string;
|
|
28
|
+
}
|
|
29
|
+
export interface CharacterAsset {
|
|
30
|
+
characterId: string;
|
|
31
|
+
version: string;
|
|
32
|
+
camera?: ResourceHolder;
|
|
33
|
+
models?: Models;
|
|
34
|
+
animations?: Animations;
|
|
35
|
+
background?: ResourceHolder;
|
|
36
|
+
characterSettings?: {
|
|
37
|
+
[key: string]: any;
|
|
38
|
+
};
|
|
39
|
+
customAnimations: CustomAnimation[];
|
|
40
|
+
}
|
|
3
41
|
/**
|
|
4
|
-
*
|
|
42
|
+
* Character metadata
|
|
5
43
|
*/
|
|
6
44
|
export type CharacterMeta = CharacterAsset & {
|
|
7
45
|
characterSettings?: CharacterSettings;
|
|
@@ -13,27 +51,15 @@ export type PreloadCameraSettings = PreloadResources<{
|
|
|
13
51
|
camera: CameraSettings;
|
|
14
52
|
}>;
|
|
15
53
|
/**
|
|
16
|
-
*
|
|
54
|
+
* Resource type enumeration
|
|
17
55
|
*/
|
|
18
56
|
export declare enum ResourceType {
|
|
19
57
|
CAMERA = "camera",
|
|
20
58
|
ANIMATION_IDLE = "frameIdle",
|
|
21
|
-
ANIMATION_MONO = "frameMono",
|
|
22
|
-
AUDIO_MONO = "audioMono",
|
|
23
59
|
MODEL_SHAPE = "shape",
|
|
24
60
|
MODEL_GS = "gsStandard"
|
|
25
61
|
}
|
|
26
62
|
/**
|
|
27
|
-
*
|
|
63
|
+
* Extract all resource URLs
|
|
28
64
|
*/
|
|
29
65
|
export declare function extractResourceUrls(meta: CharacterMeta): Record<ResourceType, string | null>;
|
|
30
|
-
/**
|
|
31
|
-
* 检查角色是否有完整的独白资源
|
|
32
|
-
*/
|
|
33
|
-
export declare function hasMonologue(meta: CharacterMeta): boolean;
|
|
34
|
-
/**
|
|
35
|
-
* 从 RealtimeCharacter 的 modelInfo JSON 中解析是否有独白
|
|
36
|
-
* modelInfo 是一个 JSON 字符串,包含角色的模型信息
|
|
37
|
-
*/
|
|
38
|
-
export declare function hasMonologueFromModelInfo(modelInfo: string): boolean;
|
|
39
|
-
//# sourceMappingURL=character.d.ts.map
|
package/dist/types/index.d.ts
CHANGED
|
@@ -1,20 +1,42 @@
|
|
|
1
1
|
/**
|
|
2
|
-
*
|
|
2
|
+
* Unified public types & interfaces
|
|
3
3
|
*/
|
|
4
4
|
export declare enum Environment {
|
|
5
5
|
cn = "cn",
|
|
6
|
-
|
|
7
|
-
|
|
6
|
+
intl = "intl"
|
|
7
|
+
}
|
|
8
|
+
export declare enum DrivingServiceMode {
|
|
9
|
+
/** Driven by SDK directly */
|
|
10
|
+
sdk = "sdk",
|
|
11
|
+
/** Driven by host application */
|
|
12
|
+
host = "host"
|
|
13
|
+
}
|
|
14
|
+
export declare enum LogLevel {
|
|
15
|
+
/** Disable all logs */
|
|
16
|
+
off = "off",
|
|
17
|
+
/** Error logs only */
|
|
18
|
+
error = "error",
|
|
19
|
+
/** Warning and error logs */
|
|
20
|
+
warning = "warning",
|
|
21
|
+
/** All logs (info, warning, error), default value */
|
|
22
|
+
all = "all"
|
|
23
|
+
}
|
|
24
|
+
export interface AudioFormat {
|
|
25
|
+
/** Channel count, fixed to 1 (mono) */
|
|
26
|
+
readonly channelCount: 1;
|
|
27
|
+
/** Sample rate, supported: 8000, 16000, 22050, 24000, 32000, 44100, 48000, default: 16000 */
|
|
28
|
+
readonly sampleRate: number;
|
|
8
29
|
}
|
|
9
30
|
export interface Configuration {
|
|
10
31
|
readonly environment: Environment;
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
32
|
+
/** Driving service mode, default is sdk */
|
|
33
|
+
readonly drivingServiceMode?: DrivingServiceMode;
|
|
34
|
+
/** Log level, default is off */
|
|
35
|
+
readonly logLevel?: LogLevel;
|
|
36
|
+
/** Audio format configuration, default is { channelCount: 1, sampleRate: 16000 } */
|
|
37
|
+
readonly audioFormat?: AudioFormat;
|
|
38
|
+
/** Custom character data API base URL (optional, if provided will be used preferentially, otherwise use environment-configured sdkApiBaseUrl) */
|
|
39
|
+
readonly characterApiBaseUrl?: string;
|
|
18
40
|
}
|
|
19
41
|
export declare enum LoadProgress {
|
|
20
42
|
downloading = "downloading",
|
|
@@ -32,22 +54,61 @@ export declare enum ConnectionState {
|
|
|
32
54
|
connected = "connected",
|
|
33
55
|
failed = "failed"
|
|
34
56
|
}
|
|
35
|
-
export declare enum
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
57
|
+
export declare enum ConversationState {
|
|
58
|
+
/** Idle state (breathing animation) */
|
|
59
|
+
idle = "idle",
|
|
60
|
+
/** Playing state */
|
|
61
|
+
playing = "playing",
|
|
62
|
+
/** Paused state */
|
|
63
|
+
paused = "paused"
|
|
64
|
+
}
|
|
65
|
+
export declare enum ErrorCode {
|
|
66
|
+
/** AppID not recognized (reserved, future appID validation logic) */
|
|
67
|
+
appIDUnrecognized = "appIDUnrecognized",
|
|
68
|
+
/** Session Token invalid (WebSocket close code 4010) */
|
|
69
|
+
sessionTokenInvalid = "sessionTokenInvalid",
|
|
70
|
+
/** Session Token expired (WebSocket close code 4010) */
|
|
71
|
+
sessionTokenExpired = "sessionTokenExpired",
|
|
72
|
+
/** Insufficient balance (WebSocket close code 4001) */
|
|
73
|
+
insufficientBalance = "insufficientBalance",
|
|
74
|
+
/** Concurrent connection limit exceeded (WebSocket close code 4003) */
|
|
75
|
+
concurrentLimitExceeded = "concurrentLimitExceeded",
|
|
76
|
+
/** AvatarID not recognized */
|
|
77
|
+
avatarIDUnrecognized = "avatarIDUnrecognized",
|
|
78
|
+
/** Failed to fetch avatar metadata */
|
|
79
|
+
failedToFetchAvatarMetadata = "failedToFetchAvatarMetadata",
|
|
80
|
+
/** Failed to download avatar assets */
|
|
81
|
+
failedToDownloadAvatarAssets = "failedToDownloadAvatarAssets",
|
|
82
|
+
/** WebSocket connection error (handshake failure, network error) */
|
|
83
|
+
websocketError = "websocketError",
|
|
84
|
+
/** WebSocket connection closed abnormally (close code 1006) */
|
|
85
|
+
websocketClosedAbnormally = "websocketClosedAbnormally",
|
|
86
|
+
/** WebSocket closed with unexpected close code */
|
|
87
|
+
websocketClosedUnexpected = "websocketClosedUnexpected",
|
|
88
|
+
/** Session timeout (WebSocket close code 4002) */
|
|
89
|
+
sessionTimeout = "sessionTimeout",
|
|
90
|
+
/** Connection already in progress */
|
|
91
|
+
connectionInProgress = "connectionInProgress",
|
|
92
|
+
/** Network layer not available (SDK mode required) */
|
|
93
|
+
networkLayerNotAvailable = "networkLayerNotAvailable",
|
|
94
|
+
/** Failed to start playback */
|
|
95
|
+
playbackStartFailed = "playbackStartFailed",
|
|
96
|
+
/** Playback initialization failed */
|
|
97
|
+
playbackInitFailed = "playbackInitFailed",
|
|
98
|
+
/** Audio-only playback initialization failed */
|
|
99
|
+
audioOnlyInitFailed = "audioOnlyInitFailed",
|
|
100
|
+
/** No audio data to play */
|
|
101
|
+
noAudio = "noAudio",
|
|
102
|
+
/** Audio context not initialized */
|
|
103
|
+
audioContextNotInitialized = "audioContextNotInitialized",
|
|
104
|
+
/** Animation player not initialized */
|
|
105
|
+
animationPlayerNotInitialized = "animationPlayerNotInitialized",
|
|
106
|
+
/** Server-side error */
|
|
107
|
+
serverError = "serverError"
|
|
108
|
+
}
|
|
109
|
+
export declare class AvatarError extends Error {
|
|
110
|
+
code: ErrorCode;
|
|
111
|
+
constructor(message: string, code: ErrorCode);
|
|
51
112
|
}
|
|
52
113
|
export interface CameraConfig {
|
|
53
114
|
position: [number, number, number];
|
|
@@ -58,29 +119,88 @@ export interface CameraConfig {
|
|
|
58
119
|
up?: [number, number, number];
|
|
59
120
|
aspect?: number;
|
|
60
121
|
}
|
|
61
|
-
export interface RenderPerformanceStats {
|
|
62
|
-
renderTime: number;
|
|
63
|
-
sortTime: number;
|
|
64
|
-
backend: 'webgpu' | 'webgl' | null;
|
|
65
|
-
pointCount?: number;
|
|
66
|
-
}
|
|
67
122
|
/**
|
|
68
|
-
*
|
|
123
|
+
* Animation keyframe data
|
|
124
|
+
* Used to represent avatar pose and expression parameters
|
|
69
125
|
*/
|
|
70
|
-
export
|
|
71
|
-
/**
|
|
72
|
-
|
|
73
|
-
/**
|
|
74
|
-
|
|
126
|
+
export interface KeyframeData {
|
|
127
|
+
/** Translation [x, y, z] */
|
|
128
|
+
translation: number[];
|
|
129
|
+
/** Rotation [x, y, z] (Euler angles, in radians) */
|
|
130
|
+
rotation: number[];
|
|
131
|
+
/** Neck pose [x, y, z] (in radians) */
|
|
132
|
+
neckPose: number[];
|
|
133
|
+
/** Jaw pose [x, y, z] (in radians) */
|
|
134
|
+
jawPose: number[];
|
|
135
|
+
/** Eye pose [x, y, z, x, y, z] (3 parameters for each eye) */
|
|
136
|
+
eyePose: number[];
|
|
137
|
+
/** Eyelid [x, y] */
|
|
138
|
+
eyeLid: number[];
|
|
139
|
+
/** Expression parameters array */
|
|
140
|
+
expression: number[];
|
|
75
141
|
}
|
|
76
142
|
/**
|
|
77
|
-
*
|
|
143
|
+
* Post-processing parameter configuration
|
|
144
|
+
* Used to overlay in real-time on animation parameters returned by the server
|
|
78
145
|
*/
|
|
79
|
-
export interface
|
|
80
|
-
/**
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
146
|
+
export interface PostProcessingConfig {
|
|
147
|
+
/** Rotation (Euler angles, in radians) */
|
|
148
|
+
rotation?: {
|
|
149
|
+
x?: number;
|
|
150
|
+
y?: number;
|
|
151
|
+
z?: number;
|
|
152
|
+
};
|
|
153
|
+
/** Translation (position offset) */
|
|
154
|
+
translation?: {
|
|
155
|
+
x?: number;
|
|
156
|
+
y?: number;
|
|
157
|
+
z?: number;
|
|
158
|
+
};
|
|
159
|
+
/** Neck pose offset (in radians) */
|
|
160
|
+
neckPose?: {
|
|
161
|
+
x?: number;
|
|
162
|
+
y?: number;
|
|
163
|
+
z?: number;
|
|
164
|
+
weightX?: number;
|
|
165
|
+
weightY?: number;
|
|
166
|
+
weightZ?: number;
|
|
167
|
+
};
|
|
168
|
+
/** Jaw pose offset (in radians) */
|
|
169
|
+
jawPose?: {
|
|
170
|
+
x?: number;
|
|
171
|
+
y?: number;
|
|
172
|
+
z?: number;
|
|
173
|
+
weight?: number;
|
|
174
|
+
};
|
|
175
|
+
/** Eye pose offset (in radians) */
|
|
176
|
+
eyePose?: {
|
|
177
|
+
x?: number;
|
|
178
|
+
y?: number;
|
|
179
|
+
z?: number;
|
|
180
|
+
weightX?: number;
|
|
181
|
+
weightY?: number;
|
|
182
|
+
weightZ?: number;
|
|
183
|
+
};
|
|
184
|
+
/** Eye blink value (-1.0 to 1.0, larger value means more closed) */
|
|
185
|
+
eyeBlink?: number;
|
|
186
|
+
/** Expression weight (0.0-2.0, 0=no expression, 1=normal, >1=enhanced) */
|
|
187
|
+
expressionWeight?: number;
|
|
188
|
+
/** Eye tracking complete configuration (real-time control of eye_focus, must provide complete configuration) */
|
|
189
|
+
eyefocus?: {
|
|
190
|
+
enabled: boolean;
|
|
191
|
+
auto_eyelid_adjustment?: boolean;
|
|
192
|
+
eyelid_threshold?: number;
|
|
193
|
+
targets?: number[];
|
|
194
|
+
};
|
|
195
|
+
}
|
|
196
|
+
export interface FlameInfo {
|
|
197
|
+
vertexCount: number;
|
|
198
|
+
faceCount: number;
|
|
199
|
+
jointCount: number;
|
|
200
|
+
}
|
|
201
|
+
export interface CharacterInfo {
|
|
202
|
+
pointCount: number;
|
|
203
|
+
hasAnimation: boolean;
|
|
84
204
|
}
|
|
85
205
|
export * from './character';
|
|
86
|
-
|
|
206
|
+
export type { FrameRateInfo, FrameRenderInfo } from '../performance/FrameRateMonitor';
|
package/dist/vite.d.ts
ADDED
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { Plugin } from 'vite';
|
|
2
|
+
/**
|
|
3
|
+
* Vite plugin for @spatialwalk/avatarkit
|
|
4
|
+
* Automatically handles WASM file configuration for development and production builds
|
|
5
|
+
*
|
|
6
|
+
* @example
|
|
7
|
+
* ```ts
|
|
8
|
+
* import { defineConfig } from 'vite'
|
|
9
|
+
* import { avatarkitVitePlugin } from '@spatialwalk/avatarkit/vite'
|
|
10
|
+
*
|
|
11
|
+
* export default defineConfig({
|
|
12
|
+
* plugins: [
|
|
13
|
+
* avatarkitVitePlugin()
|
|
14
|
+
* ]
|
|
15
|
+
* })
|
|
16
|
+
* ```
|
|
17
|
+
*/
|
|
18
|
+
export declare function avatarkitVitePlugin(): Plugin;
|
|
19
|
+
export default avatarkitVitePlugin;
|
package/next.d.ts
ADDED