feat: 添加跨平台运行时、资产系统和UI适配功能 (#256)

* 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检测到的代码问题
This commit is contained in:
YHH
2025-12-03 22:15:22 +08:00
committed by GitHub
parent caf7622aa0
commit 63f006ab62
496 changed files with 77601 additions and 4067 deletions

View File

@@ -0,0 +1,43 @@
{
"id": "blueprint",
"name": "@esengine/blueprint",
"displayName": "Blueprint",
"description": "Visual scripting system | 可视化脚本系统",
"version": "1.0.0",
"category": "AI",
"icon": "Workflow",
"tags": [
"visual",
"scripting",
"blueprint",
"nodes"
],
"isCore": false,
"defaultEnabled": false,
"isEngineModule": true,
"canContainContent": true,
"platforms": [
"web",
"desktop"
],
"dependencies": [
"core"
],
"exports": {
"components": [
"BlueprintComponent"
],
"systems": [
"BlueprintSystem"
],
"other": [
"Blueprint",
"BlueprintNode",
"BlueprintGraph"
]
},
"editorPackage": "@esengine/blueprint-editor",
"requiresWasm": false,
"outputPath": "dist/index.js",
"pluginExport": "BlueprintPlugin"
}

View File

@@ -31,6 +31,7 @@
"license": "MIT",
"devDependencies": {
"@esengine/ecs-framework": "workspace:*",
"@esengine/engine-core": "workspace:*",
"@esengine/build-config": "workspace:*",
"@types/node": "^20.19.17",
"rimraf": "^5.0.0",

View File

@@ -0,0 +1,60 @@
/**
* Blueprint Plugin for ES Engine.
* ES引擎的蓝图插件。
*
* Provides visual scripting runtime support.
* 提供可视化脚本运行时支持。
*/
import type { IPlugin, ModuleManifest, IRuntimeModule } from '@esengine/engine-core';
/**
* Blueprint Runtime Module.
* 蓝图运行时模块。
*
* Note: Blueprint uses a custom system (IBlueprintSystem) instead of EntitySystem,
* so createSystems is not implemented here. Blueprint systems should be created
* manually using createBlueprintSystem(scene).
*/
class BlueprintRuntimeModule implements IRuntimeModule {
async onInitialize(): Promise<void> {
// Blueprint system initialization
// Blueprint uses IBlueprintSystem which is different from EntitySystem
}
onDestroy(): void {
// Cleanup
}
}
/**
* Plugin manifest for Blueprint.
* 蓝图的插件清单。
*/
const manifest: ModuleManifest = {
id: 'blueprint',
name: '@esengine/blueprint',
displayName: 'Blueprint',
version: '1.0.0',
description: '可视化脚本系统',
category: 'AI',
icon: 'Workflow',
isCore: false,
defaultEnabled: false,
isEngineModule: true,
dependencies: ['core'],
exports: {
components: ['BlueprintComponent'],
systems: ['BlueprintSystem']
},
requiresWasm: false
};
/**
* Blueprint Plugin.
* 蓝图插件。
*/
export const BlueprintPlugin: IPlugin = {
manifest,
runtimeModule: new BlueprintRuntimeModule()
};

View File

@@ -29,3 +29,6 @@ export {
triggerCustomBlueprintEvent
} from './runtime/BlueprintSystem';
export { createEmptyBlueprint, validateBlueprintAsset } from './types/blueprint';
// Plugin
export { BlueprintPlugin } from './BlueprintPlugin';