import { B2Vec2, B2Mat22, B2Vec3, B2Mat33, B2Rot } from '../../Common/b2Math'; import { B2Body } from '../b2Body'; import { B2Joint, B2JointDef, B2LimitState } from './b2Joint'; import { B2SolverData } from '../b2TimeStep'; export declare class B2RevoluteJointDef extends B2JointDef { localAnchorA: B2Vec2; localAnchorB: B2Vec2; referenceAngle: number; enableLimit: boolean; lowerAngle: number; upperAngle: number; enableMotor: boolean; motorSpeed: number; maxMotorTorque: number; constructor(); Initialize(bA: B2Body, bB: B2Body, anchor: B2Vec2): void; } export declare class B2RevoluteJoint extends B2Joint { m_localAnchorA: B2Vec2; m_localAnchorB: B2Vec2; m_impulse: B2Vec3; m_motorImpulse: number; m_enableMotor: boolean; m_maxMotorTorque: number; m_motorSpeed: number; m_enableLimit: boolean; m_referenceAngle: number; m_lowerAngle: number; m_upperAngle: number; m_indexA: number; m_indexB: number; m_rA: B2Vec2; m_rB: B2Vec2; m_localCenterA: B2Vec2; m_localCenterB: B2Vec2; m_invMassA: number; m_invMassB: number; m_invIA: number; m_invIB: number; m_mass: B2Mat33; m_motorMass: number; m_limitState: B2LimitState; m_qA: B2Rot; m_qB: B2Rot; m_lalcA: B2Vec2; m_lalcB: B2Vec2; m_K: B2Mat22; constructor(def: B2RevoluteJointDef); private static InitVelocityConstraints_s_P; InitVelocityConstraints(data: B2SolverData): void; private static SolveVelocityConstraints_s_P; private static SolveVelocityConstraints_s_Cdot_v2; private static SolveVelocityConstraints_s_Cdot1; private static SolveVelocityConstraints_s_impulse_v3; private static SolveVelocityConstraints_s_reduced_v2; private static SolveVelocityConstraints_s_impulse_v2; SolveVelocityConstraints(data: B2SolverData): void; private static SolvePositionConstraints_s_C_v2; private static SolvePositionConstraints_s_impulse; SolvePositionConstraints(data: B2SolverData): boolean; GetAnchorA(out: B2Vec2): B2Vec2; GetAnchorB(out: B2Vec2): B2Vec2; GetReactionForce(inv_dt: number, out: B2Vec2): B2Vec2; GetReactionTorque(inv_dt: number): number; GetLocalAnchorA(): B2Vec2; GetLocalAnchorB(): B2Vec2; GetReferenceAngle(): number; GetJointAngle(): number; GetJointSpeed(): number; IsMotorEnabled(): boolean; EnableMotor(flag: boolean): void; GetMotorTorque(inv_dt: number): number; GetMotorSpeed(): number; SetMaxMotorTorque(torque: number): void; GetMaxMotorTorque(): number; IsLimitEnabled(): boolean; EnableLimit(flag: boolean): void; GetLowerLimit(): number; GetUpperLimit(): number; SetLimits(lower: number, upper: number): void; SetMotorSpeed(speed: number): void; Dump(log: (format: string, ...args: any[]) => void): void; }