news 2026/6/22 9:36:42

Godot Engine采用分层架构设计

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Godot Engine采用分层架构设计

Godot Engine采用分层架构设计,官方文档提供了从核心组件到底层驱动的整体架构示意图,清晰展示各模块的层级关系与核心职责。

一、核心四层架构

Godot的引擎主体从底层到上层分为四个核心层级,各层职责明确且依赖关系清晰:

  1. Core(核心层)
    作为引擎最基础的底层支撑,包含主程序循环、数学运算库、对象系统、变体类型等通用基础模块,对应源码目录为/core/,为上层所有模块提供统一的基础能力支撑。
  2. Servers(服务器层)
    以单例对象的形式实现引擎的核心子系统,涵盖渲染、音频、物理等核心功能,在引擎启动时初始化,对应源码目录为/servers/,通过RID机制统一管理资源生命周期。
  3. Scene(场景层)
    是引擎最高层级的应用构建层,提供了Godot标志性的节点-场景树系统,所有游戏对象、UI元素都以节点形式组织在场景树中,对应源码目录为/scene/,包含2D/3D节点、GUI控件等完整组件库。
  4. Drivers/Platform Interface(驱动与平台抽象层)
    对底层平台细节做了完全封装,包含图形API驱动、音频后端、操作系统适配接口等,实现引擎跨平台运行能力,对应源码目录为/drivers//platform/

二、核心扩展模块

除了四层基础架构外,引擎还包含多个关键扩展模块:

  • Editor模块‌:Godot编辑器本身完全基于引擎自身的UI系统开发,提供动画编辑、音频总线配置、资源库对接等可视化开发工具,通过REST API与AssetLib资源服务器交互。
  • Modules模块‌:作为引擎的扩展插槽,可灵活接入物理、网络、脚本语言绑定等自定义功能,支持GDExtension、C#等多语言扩展能力。

三、核心概念对应关系

Godot的核心设计和主流商业游戏引擎有明确的概念对应,便于开发者快速理解其框架逻辑:

表格

Godot Engine对应Unreal Engine概念核心作用
NodeActor基础游戏对象单元
SignalBroadcast低耦合事件通信机制
SceneLevel Map可复用的游戏场景文件
Scene TreePersistent Level Map运行时的全局对象树

┌─────────────────────────────────────────────────────────────────────────────┐
│ Scene Layer (场景层) │
│ ┌──────────────┐ ┌──────────────┐ ┌──────────────┐ ┌──────────────────────┐ │
│ │ 2D 节点 │ │ 3D 节点 │ │ GUI 控件 │ │ 动画系统 │ │
│ │ Node2D │ │ Node3D │ │ Control │ │ AnimationPlayer │ │
│ │ Sprite2D │ │ MeshInstance│ │ Button │ │ AnimationTree │ │
│ │ TileMap │ │ Camera3D │ │ Label │ │ Skeleton3D │ │
│ └──────────────┘ └──────────────┘ └──────────────┘ └──────────────────────┘ │
│ ┌──────────────────────────────────────────────────────────────────────────┐ │
│ │ SceneTree (场景树) - 运行时全局对象管理器 │ │
│ │ Node (节点基类) - 生命周期 / 信号 / 通知 / 组 │ │
│ │ Resource (资源系统) - ResourceLoader / ResourceSaver │ │
│ └──────────────────────────────────────────────────────────────────────────┘ │
│ 源码目录: /scene/* │
├─────────────────────────────────────────────────────────────────────────────┤
│ Server Layer (服务器层) │
│ ┌──────────────┐ ┌──────────────┐ ┌──────────────┐ ┌──────────────────────┐ │
│ │ RenderingServer│ │PhysicsServer │ │ AudioServer │ │ NavigationServer │ │
│ │ 渲染服务 │ │ 物理服务 │ │ 音频服务 │ │ 导航服务 │ │
│ │ · 网格管理 │ │ · 2D 物理 │ │ · 混音 │ │ · 导航网格 │ │
│ │ · 材质系统 │ │ · 3D 物理 │ │ · 音频总线 │ │ · 寻路算法 │ │
│ │ · 光照/阴影 │ │ · 碰撞检测 │ │ · 效果器 │ │ · 回避系统 │ │
│ │ · 后处理 │ │ · 关节约束 │ │ · 流播放 │ │ │ │
│ └──────────────┘ └──────────────┘ └──────────────┘ └──────────────────────┘ │
│ ┌──────────────────────────────────────────────────────────────────────────┐ │
│ │ 所有 Server 均为单例对象,引擎启动时初始化 │ │
│ │ 通过 RID (Resource ID) 机制统一管理资源生命周期 │ │
│ └──────────────────────────────────────────────────────────────────────────┘ │
│ 源码目录: /servers/* │
├─────────────────────────────────────────────────────────────────────────────┤
│ Core Layer (核心层) │
│ ┌──────────────┐ ┌──────────────┐ ┌──────────────┐ ┌──────────────────────┐ │
│ │ 对象系统 │ │ 数据类型 │ │ 内存管理 │ │ 数学库 │ │
│ │ Object │ │ Variant │ │ Memory │ │ Math │ │
│ │ RefCounted │ │ String │ │ Allocator │ │ Vector2/3/4 │ │
│ │ ClassDB │ │ Dictionary │ │ Pool │ │ Transform3D │ │
│ │ Signal │ │ Array │ │ │ │ AABB │ │
│ └──────────────┘ └──────────────┘ └──────────────┘ └──────────────────────┘ │
│ ┌──────────────┐ ┌──────────────┐ ┌──────────────┐ ┌──────────────────────┐ │
│ │ 容器类型 │ │ 输入系统 │ │ IO 抽象 │ │ 线程与同步 │ │
│ │ Vector │ │ InputEvent │ │ FileAccess │ │ Thread │ │
│ │ HashMap │ │ InputMap │ │ DirAccess │ │ Mutex │ │
│ │ List │ │ Shortcut │ │ JSON/XML │ │ Semaphore │ │
│ │ Set │ │ │ │ │ │ WorkerThreadPool │ │
│ └──────────────┘ └──────────────┘ └──────────────┘ └──────────────────────┘ │
│ 源码目录: /core/* │
├─────────────────────────────────────────────────────────────────────────────┤
│ Drivers / Platform Layer (驱动与平台抽象层) │
│ ┌──────────────┐ ┌──────────────┐ ┌──────────────┐ ┌──────────────────────┐ │
│ │ 图形驱动 │ │ 音频驱动 │ │ 平台适配 │ │ 窗口系统 │ │
│ │ Vulkan │ │ WASAPI │ │ Windows │ │ DisplayServer │ │
│ │ D3D12 │ │ PulseAudio │ │ Linux │ │ X11/Wayland │ │
│ │ Metal(MVK) │ │ CoreAudio │ │ macOS │ │ Win32 │ │
│ │ OpenGL ES │ │ ALSA │ │ Android │ │ Cocoa │ │
│ │ WebGL │ │ AAudio │ │ iOS │ │ │ │
│ └──────────────┘ └──────────────┘ └──────────────┘ └──────────────────────┘ │
│ 源码目录: /drivers/* , /platform/* │
└─────────────────────────────────────────────────────────────────────────────┘

核心概念对应关系

| Godot Engine | 对应 Unreal Engine 概念 | 核心作用 |
| --- | --- | --- |
| ‌Node‌ | Actor | 基础游戏对象单元,所有场景对象的基类 |
| ‌Signal‌ | Broadcast / Delegate | 低耦合事件通信机制,节点间松耦合交互 |
| ‌Scene‌ | Level / Map | 可复用的游戏场景文件(.tscn) |
| ‌SceneTree‌ | Persistent Level / World | 运行时的全局对象树,管理所有节点生命周期 |
| ‌Resource‌ | UObject / DataAsset | 可序列化的数据资源(.tres / .res) |
| ‌Server‌ | Subsystem | 引擎核心子系统单例,提供渲染/物理/音频等服务 |
| ‌Variant‌ | 动态类型容器 | C++ 与脚本之间的桥梁类型,支持序列化 |
| ‌ClassDB‌ | Reflection System | 运行时类型注册与反射系统 |

数据流与调用关系

用户代码 (GDScript / C# / GDExtension)


┌───────────────────┐
│ SceneTree │ ← 场景树遍历、信号分发、生命周期管理
│ Node 体系 │
└────────┬──────────┘
│ 调用 Server API

┌───────────────────┐
│ RenderingServer │ ← 高层渲染命令(创建网格、设置材质、提交绘制)
│ PhysicsServer │ ← 物理模拟(碰撞检测、刚体运动、关节约束)
│ AudioServer │ ← 音频播放(混音、效果器、空间化音频)
│ NavigationServer │ ← 寻路与导航网格查询
└────────┬──────────┘
│ 通过 RID 操作资源

┌───────────────────┐
│ Core 层 │ ← 内存管理、数学运算、容器操作、线程调度
└────────┬──────────┘
│ 平台抽象接口

┌───────────────────┐
│ Drivers / Platform│ ← Vulkan/D3D12/Metal 渲染、WASAPI/CoreAudio 音频
│ 具体驱动实现 │ Windows/Linux/macOS/Android/iOS 平台适配
└───────────────────┘

渲染子系统内部架构

┌─────────────────────────────────────────────────────────┐
│ RenderingServer │
│ (高层渲染 API,场景无关) │
└──────────────────────┬──────────────────────────────────┘

┌─────────────┼─────────────┐
▼ ▼ ▼
┌─────────────┐ ┌─────────────┐ ┌─────────────┐
│ Renderer │ │ Renderer │ │ Renderer │
│ Scene │ │ Canvas │ │ Storage │
│ (3D 场景) │ │ (2D 画布) │ │ (资源存储) │
└──────┬──────┘ └──────┬──────┘ └──────┬──────┘
│ │ │
└───────────────┼───────────────┘

┌─────────────────────────────────────────────────────────┐
│ RenderingDevice │
│ (底层 GPU API,跨后端统一抽象) │
└──────────────────────┬──────────────────────────────────┘

┌─────────────┼─────────────┐
▼ ▼ ▼
┌─────────────┐ ┌─────────────┐ ┌─────────────┐
│ Vulkan │ │ D3D12 │ │ Metal │
│ Backend │ │ Backend │ │ (MoltenVK) │
└─────────────┘ └─────────────┘ └─────────────┘

主循环执行流程

main() 入口 (platform/<os>/godot_<os>.cpp)


Main::setup() ← 初始化引擎、加载项目配置


Main::start() ← 创建 SceneTree、加载主场景


OS::run() ← 进入主循环

├─→ DisplayServer::process_events() ← 处理窗口事件、输入事件

└─→ Main::iteration() ← 每帧迭代

├─→ 物理更新 (固定频率)
│ └─→ PhysicsServer::step()

├─→ 逻辑更新 (可变频率)
│ └─→ SceneTree::process()

└─→ 渲染更新
└─→ RenderingServer::draw()

这个架构图涵盖了 Godot Engine 从底层平台驱动到上层场景系统的完整分层结构,以及各层之间的调用关系和数据流向。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/22 9:33:50

hp-FCM与非负矩拟合:攻克复杂几何热粘塑性分析难题

1. 从“硬骨头”到“可啃的骨头”&#xff1a;复杂几何热粘塑性分析的工程挑战在工程仿真领域&#xff0c;我们常常会遇到一些让人头疼的“硬骨头”问题。比如&#xff0c;当你需要分析一个带有复杂内部空腔的航空发动机涡轮叶片在高温、高转速下的应力与变形&#xff0c;或者评…

作者头像 李华
网站建设 2026/6/22 9:09:43

如何3步完成B站视频转文字:Bili2Text高效工具指南

如何3步完成B站视频转文字&#xff1a;Bili2Text高效工具指南 【免费下载链接】bili2text Bilibili视频转文字&#xff0c;一步到位&#xff0c;输入链接即可使用 项目地址: https://gitcode.com/gh_mirrors/bi/bili2text 还在为整理B站视频内容而烦恼吗&#xff1f;Bil…

作者头像 李华
网站建设 2026/6/22 9:06:33

第22章:多模型路由——为不同任务选择不同模型

1. 项目背景 业务场景 某公司的AI平台已经服务了三个部门:客服部用qwen2.5:7b做问答(日均5000次),研发部用qwen2.5:7b做代码审查(日均200次),运维部用qwen2.5:7b做日志分析(日均100次)。一切看似正常,但CTO看完成本报告后皱起了眉头。 客服部的小王抱怨:"为…

作者头像 李华
网站建设 2026/6/22 9:03:53

基于MC56F8006 DSC与RS-485的高亮度LED网络驱动方案详解

1. 项目概述&#xff1a;一个模块化高亮度LED网络的诞生 在嵌入式开发领域&#xff0c;尤其是涉及大功率LED驱动和分布式控制的场景&#xff0c;我们常常面临几个核心挑战&#xff1a;如何精确控制每一颗LED的亮度和颜色&#xff1f;如何将数十甚至上百个这样的节点稳定地连接成…

作者头像 李华
网站建设 2026/6/22 9:01:33

韩语大语言模型词元剪枝实战:优化推理效率与显存占用

1. 项目缘起&#xff1a;当韩语LLM遇上“臃肿”的词表最近在折腾一个韩语大语言模型&#xff08;LLM&#xff09;的本地部署项目&#xff0c;目标很明确&#xff1a;在有限的消费级GPU上&#xff08;比如我的RTX 4090 24GB&#xff09;&#xff0c;跑起一个能流畅对话、理解复杂…

作者头像 李华