sandai-react
Version:
React components and utilities for the Sandai 3D AI Characters.
68 lines • 2.62 kB
TypeScript
import { TFVectorPose, IPoseSolveOptions, TPose } from "../Types";
/** Class representing pose solver. */
export declare class PoseSolver {
/** expose arm rotation calculator as a static method */
static calcArms: (lm: import("../Types").Results) => {
UpperArm: {
r: import("../utils/vector").default;
l: import("../utils/vector").default;
};
LowerArm: {
r: import("../utils/vector").default;
l: import("../utils/vector").default;
};
Hand: {
r: import("../utils/vector").default;
l: import("../utils/vector").default;
};
Unscaled: {
UpperArm: {
r: import("../utils/vector").default;
l: import("../utils/vector").default;
};
LowerArm: {
r: import("../utils/vector").default;
l: import("../utils/vector").default;
};
Hand: {
r: import("../utils/vector").default;
l: import("../utils/vector").default;
};
};
};
/** expose hips position and rotation calculator as a static method */
static calcHips: (lm3d: TFVectorPose, lm2d: Omit<TFVectorPose, "z">) => {
Hips: import("../Types").IHips;
Spine: import("../Types").XYZ;
};
/** expose leg rotation calculator as a static method */
static calcLegs: (lm: import("../Types").Results) => {
UpperLeg: {
r: import("../utils/euler").default;
l: import("../utils/euler").default;
};
LowerLeg: {
r: import("../utils/euler").default;
l: import("../utils/euler").default;
};
Unscaled: {
UpperLeg: {
r: import("../utils/vector").default;
l: import("../utils/vector").default;
};
LowerLeg: {
r: import("../utils/vector").default;
l: import("../utils/vector").default;
};
};
};
/**
* Combines arm, hips, and leg calcs into one method
* @param {Array} lm3d : array of 3D pose vectors from tfjs or mediapipe
* @param {Array} lm2d : array of 2D pose vectors from tfjs or mediapipe
* @param {String} runtime: set as either "tfjs" or "mediapipe"
* @param {IPoseSolveOptions} options: options object
*/
static solve(lm3d: TFVectorPose, lm2d: Omit<TFVectorPose, "z">, { runtime, video, imageSize, enableLegs, }?: Partial<IPoseSolveOptions>): TPose | undefined;
}
//# sourceMappingURL=index.d.ts.map