69 lines
2.1 KiB
Markdown
69 lines
2.1 KiB
Markdown
|
|
# ECS Framework WASM 支持包
|
|||
|
|
|
|||
|
|
这个包包含了 @esengine/ecs-framework 的 WASM 加速模块。
|
|||
|
|
|
|||
|
|
## 包含文件
|
|||
|
|
|
|||
|
|
- `ecs_wasm_core.js` - WASM胶水代码
|
|||
|
|
- `ecs_wasm_core.d.ts` - TypeScript类型定义
|
|||
|
|
- `ecs_wasm_core_bg.wasm` - WASM二进制文件
|
|||
|
|
- `ecs_wasm_core_bg.wasm.d.ts` - WASM类型定义
|
|||
|
|
- `package.json` - 包信息
|
|||
|
|
|
|||
|
|
## 使用方法
|
|||
|
|
|
|||
|
|
### 1. Cocos Creator 3.8+
|
|||
|
|
|
|||
|
|
```typescript
|
|||
|
|
import { ecsCore } from '@esengine/ecs-framework';
|
|||
|
|
|
|||
|
|
// 1. 将WASM文件导入到项目资源中
|
|||
|
|
// 2. 导入胶水代码
|
|||
|
|
import('./ecs_wasm_core.js').then(({ default: wasmFactory }) => {
|
|||
|
|
// 3. 使用Cocos API加载WASM文件
|
|||
|
|
this.loadWasmOrAsm("wasmFiles", "ecs_wasm_core", "your-wasm-uuid").then((wasmFile) => {
|
|||
|
|
// 4. 初始化WASM支持
|
|||
|
|
ecsCore.initializeWasm(wasmFactory, wasmFile).then((success) => {
|
|||
|
|
if (success) {
|
|||
|
|
console.log("ECS WASM加速已启用");
|
|||
|
|
} else {
|
|||
|
|
console.log("回退到JavaScript实现");
|
|||
|
|
}
|
|||
|
|
});
|
|||
|
|
});
|
|||
|
|
});
|
|||
|
|
```
|
|||
|
|
|
|||
|
|
### 2. 其他环境(浏览器/Node.js)
|
|||
|
|
|
|||
|
|
```typescript
|
|||
|
|
import { ecsCore } from '@esengine/ecs-framework';
|
|||
|
|
|
|||
|
|
// 1. 导入胶水代码
|
|||
|
|
import('./ecs_wasm_core.js').then(({ default: wasmFactory }) => {
|
|||
|
|
// 2. 加载WASM文件
|
|||
|
|
fetch('./ecs_wasm_core_bg.wasm').then(response => response.arrayBuffer()).then((wasmFile) => {
|
|||
|
|
// 3. 初始化WASM支持
|
|||
|
|
ecsCore.initializeWasm(wasmFactory, wasmFile).then((success) => {
|
|||
|
|
if (success) {
|
|||
|
|
console.log("ECS WASM加速已启用");
|
|||
|
|
} else {
|
|||
|
|
console.log("回退到JavaScript实现");
|
|||
|
|
}
|
|||
|
|
});
|
|||
|
|
});
|
|||
|
|
});
|
|||
|
|
```
|
|||
|
|
|
|||
|
|
## 注意事项
|
|||
|
|
|
|||
|
|
1. 如果不使用此WASM包,框架会自动使用JavaScript实现,功能完全正常
|
|||
|
|
2. WASM主要提供查询性能优化,对于大多数应用场景JavaScript实现已足够
|
|||
|
|
3. 确保在ECS系统初始化之前调用`initializeWasm`方法
|
|||
|
|
|
|||
|
|
## 技术支持
|
|||
|
|
|
|||
|
|
如遇问题,请访问:
|
|||
|
|
- [GitHub Issues](https://github.com/esengine/ecs-framework/issues)
|
|||
|
|
- [主项目文档](https://github.com/esengine/ecs-framework#readme)
|