* feat(platform-common): 添加WASM加载器和环境检测API * feat(rapier2d): 新增Rapier2D WASM绑定包 * feat(physics-rapier2d): 添加跨平台WASM加载器 * feat(asset-system): 添加运行时资产目录和bundle格式 * feat(asset-system-editor): 新增编辑器资产管理包 * feat(editor-core): 添加构建系统和模块管理 * feat(editor-app): 重构浏览器预览使用import maps * feat(platform-web): 添加BrowserRuntime和资产读取 * feat(engine): 添加材质系统和着色器管理 * feat(material): 新增材质系统和着色器编辑器 * feat(tilemap): 增强tilemap编辑器和动画系统 * feat(modules): 添加module.json配置 * feat(core): 添加module.json和类型定义更新 * chore: 更新依赖和构建配置 * refactor(plugins): 更新插件模板使用ModuleManifest * chore: 添加第三方依赖库 * chore: 移除BehaviourTree-ai和ecs-astar子模块 * docs: 更新README和文档主题样式 * fix: 修复Rust文档测试和添加rapier2d WASM绑定 * fix(tilemap-editor): 修复画布高DPI屏幕分辨率适配问题 * feat(ui): 添加UI屏幕适配系统(CanvasScaler/SafeArea) * fix(ecs-engine-bindgen): 添加缺失的ecs-framework-math依赖 * fix: 添加缺失的包依赖修复CI构建 * fix: 修复CodeQL检测到的代码问题 * fix: 修复构建错误和缺失依赖 * fix: 修复类型检查错误 * fix(material-system): 修复tsconfig配置支持TypeScript项目引用 * fix(editor-core): 修复Rollup构建配置添加tauri external * fix: 修复CodeQL检测到的代码问题 * fix: 修复CodeQL检测到的代码问题
163 lines
4.6 KiB
TypeScript
163 lines
4.6 KiB
TypeScript
import {RawImpulseJointSet} from "../raw";
|
|
import {Coarena} from "../coarena";
|
|
import {RigidBodySet} from "./rigid_body_set";
|
|
import {
|
|
RevoluteImpulseJoint,
|
|
FixedImpulseJoint,
|
|
ImpulseJoint,
|
|
ImpulseJointHandle,
|
|
JointData,
|
|
JointType,
|
|
PrismaticImpulseJoint,
|
|
} from "./impulse_joint";
|
|
import {IslandManager} from "./island_manager";
|
|
import {RigidBodyHandle} from "./rigid_body";
|
|
import {Collider, ColliderHandle} from "../geometry";
|
|
|
|
/**
|
|
* A set of joints.
|
|
*
|
|
* To avoid leaking WASM resources, this MUST be freed manually with `jointSet.free()`
|
|
* once you are done using it (and all the joints it created).
|
|
*/
|
|
export class ImpulseJointSet {
|
|
raw: RawImpulseJointSet;
|
|
private map: Coarena<ImpulseJoint>;
|
|
|
|
/**
|
|
* Release the WASM memory occupied by this joint set.
|
|
*/
|
|
public free() {
|
|
if (!!this.raw) {
|
|
this.raw.free();
|
|
}
|
|
this.raw = undefined;
|
|
|
|
if (!!this.map) {
|
|
this.map.clear();
|
|
}
|
|
this.map = undefined;
|
|
}
|
|
|
|
constructor(raw?: RawImpulseJointSet) {
|
|
this.raw = raw || new RawImpulseJointSet();
|
|
this.map = new Coarena<ImpulseJoint>();
|
|
// Initialize the map with the existing elements, if any.
|
|
if (raw) {
|
|
raw.forEachJointHandle((handle: ImpulseJointHandle) => {
|
|
this.map.set(handle, ImpulseJoint.newTyped(raw, null, handle));
|
|
});
|
|
}
|
|
}
|
|
|
|
/** @internal */
|
|
public finalizeDeserialization(bodies: RigidBodySet) {
|
|
this.map.forEach((joint) => joint.finalizeDeserialization(bodies));
|
|
}
|
|
|
|
/**
|
|
* Creates a new joint and return its integer handle.
|
|
*
|
|
* @param bodies - The set of rigid-bodies containing the bodies the joint is attached to.
|
|
* @param desc - The joint's parameters.
|
|
* @param parent1 - The handle of the first rigid-body this joint is attached to.
|
|
* @param parent2 - The handle of the second rigid-body this joint is attached to.
|
|
* @param wakeUp - Should the attached rigid-bodies be awakened?
|
|
*/
|
|
public createJoint(
|
|
bodies: RigidBodySet,
|
|
desc: JointData,
|
|
parent1: RigidBodyHandle,
|
|
parent2: RigidBodyHandle,
|
|
wakeUp: boolean,
|
|
): ImpulseJoint {
|
|
const rawParams = desc.intoRaw();
|
|
const handle = this.raw.createJoint(
|
|
rawParams,
|
|
parent1,
|
|
parent2,
|
|
wakeUp,
|
|
);
|
|
rawParams.free();
|
|
let joint = ImpulseJoint.newTyped(this.raw, bodies, handle);
|
|
this.map.set(handle, joint);
|
|
return joint;
|
|
}
|
|
|
|
/**
|
|
* Remove a joint from this set.
|
|
*
|
|
* @param handle - The integer handle of the joint.
|
|
* @param wakeUp - If `true`, the rigid-bodies attached by the removed joint will be woken-up automatically.
|
|
*/
|
|
public remove(handle: ImpulseJointHandle, wakeUp: boolean) {
|
|
this.raw.remove(handle, wakeUp);
|
|
this.unmap(handle);
|
|
}
|
|
|
|
/**
|
|
* Calls the given closure with the integer handle of each impulse joint attached to this rigid-body.
|
|
*
|
|
* @param f - The closure called with the integer handle of each impulse joint attached to the rigid-body.
|
|
*/
|
|
public forEachJointHandleAttachedToRigidBody(
|
|
handle: RigidBodyHandle,
|
|
f: (handle: ImpulseJointHandle) => void,
|
|
) {
|
|
this.raw.forEachJointAttachedToRigidBody(handle, f);
|
|
}
|
|
|
|
/**
|
|
* Internal function, do not call directly.
|
|
* @param handle
|
|
*/
|
|
public unmap(handle: ImpulseJointHandle) {
|
|
this.map.delete(handle);
|
|
}
|
|
|
|
/**
|
|
* The number of joints on this set.
|
|
*/
|
|
public len(): number {
|
|
return this.map.len();
|
|
}
|
|
|
|
/**
|
|
* Does this set contain a joint with the given handle?
|
|
*
|
|
* @param handle - The joint handle to check.
|
|
*/
|
|
public contains(handle: ImpulseJointHandle): boolean {
|
|
return this.get(handle) != null;
|
|
}
|
|
|
|
/**
|
|
* Gets the joint with the given handle.
|
|
*
|
|
* Returns `null` if no joint with the specified handle exists.
|
|
*
|
|
* @param handle - The integer handle of the joint to retrieve.
|
|
*/
|
|
public get(handle: ImpulseJointHandle): ImpulseJoint | null {
|
|
return this.map.get(handle);
|
|
}
|
|
|
|
/**
|
|
* Applies the given closure to each joint contained by this set.
|
|
*
|
|
* @param f - The closure to apply.
|
|
*/
|
|
public forEach(f: (joint: ImpulseJoint) => void) {
|
|
this.map.forEach(f);
|
|
}
|
|
|
|
/**
|
|
* Gets all joints in the list.
|
|
*
|
|
* @returns joint list.
|
|
*/
|
|
public getAll(): ImpulseJoint[] {
|
|
return this.map.getAll();
|
|
}
|
|
}
|