1. 这不是“Hello World”,而是你真正踏入游戏开发的第一道门坎
很多人第一次打开 Godot,点开新建项目,看到那个简洁得近乎简陋的界面时,第一反应是:“就这?比 Unity 空白得多,连个默认场景都不给?”——我当年也是。但三个月后,当我用同一个 Godot 项目同时导出 Windows、macOS、Linux、WebGL 和 Android 版本,且所有平台行为完全一致、资源加载零兼容性问题时,我才真正理解:Godot 的“空”,不是匮乏,而是克制;它的“轻”,不是简陋,而是去除了所有非必要抽象层后的精准表达。
Godot 引擎游戏开发项目(一) ,这个标题看似平淡,但它背后承载的是一个完整、可复现、可演进的最小可行游戏闭环:从零创建项目、构建可交互角色、实现基础物理响应、接入输入系统、完成场景切换逻辑,最后打包发布到桌面平台。它不讲“Godot 多好”,只做“这件事怎么一步步做出来”;不堆砌 API 文档,只聚焦“你此刻在编辑器里该点哪里、写哪几行、为什么不能少、为什么不能多”。
这篇文章适合三类人:一是刚学完 Python 或 JavaScript,想把代码变成“能跑起来的东西”的编程新手;二是从 Unity/Unreal 转来、被节点树和信号机制搞懵的中阶开发者;三是独立游戏人——你不需要美术外包、不需要服务器运维,只要一台笔记本、一个想法、和足够清晰的执行路径。全文所有操作均基于 Godot 4.3 stable (2024年8月最新稳定版),所有代码可直接复制粘贴运行,所有截图逻辑均可在无插件、无扩展、仅官方引擎的前提下复现。接下来,我们不谈哲学,不画蓝图,直接进入第一个真实可运行的场景:一个会走路、会跳跃、会碰撞、会死亡、会重生的角色控制器。
2. 从空白项目到可行走角色:节点结构即设计语言
2.1 为什么必须从 Node2D 开始,而不是 Sprite3D 或 Control?
Godot 的核心范式是“节点即对象,场景即组合”。很多初学者一上来就拖一个 Sprite 节点进场景,然后疯狂调参数,结果发现角色不动、不响应键盘、甚至根本没出现在视图里——问题往往不出在代码,而出在 父节点缺失 。
Sprite 是一个“纯渲染节点”,它只负责把一张图画出来,不自带坐标系锚点、不处理输入、不参与物理计算。它就像一张贴在墙上的海报:你不能让它自己走动,也不能指望它“感觉”到你按了空格键。要让 Sprite 动起来,它必须挂在一个具备运动能力的“容器”下。这个容器,在 2D 游戏中最常用的就是 CharacterBody2D (Godot 4 中替代旧版 KinematicBody2D 的新物理体类型)。
提示:不要跳过这一步直接建 Sprite3D 或 Control。前者属于三维空间体系,引入 Z 轴和摄像机视角后,坐标转换、光照、图层管理复杂度指数级上升;后者是 UI 专用节点,没有物理属性,无法与 TileMap 或 CollisionShape2D 产生真实碰撞。选错根节点,等于从起点就跑偏了整条开发链路。
所以,标准起手式是:
- 新建场景 → 选择 CharacterBody2D (不是 Sprite,不是 Node2D,就是 CharacterBody2D);
- 重命名为
Player; - 在
Player下添加子节点: Sprite2D (负责显示)、 CollisionShape2D (负责检测碰撞)、 AnimationPlayer (后续用于播放动画); - 为
CollisionShape2D挂载一个RectangleShape2D(矩形碰撞盒),尺寸设为Vector2(32, 64)—— 这是 2D 平台跳跃游戏最经典的人形比例(宽32像素,高64像素,符合 1:2 黄金比例,利于后续动画帧对齐)。
这个结构不是约定俗成,而是有明确工程依据: CharacterBody2D 提供 move_and_slide() 方法,它内部已集成滑动摩擦、斜坡攀爬、天花板反弹等平台游戏刚需物理逻辑; Sprite2D 的 position 属性自动继承父节点位移,无需手动同步坐标; CollisionShape2D 与 CharacterBody2D 绑定后,引擎会在每帧自动调用 get_slide_collision_count() 等接口,为你省去手写 AABB 检测的全部数学运算。
2.2 输入系统不是“监听按键”,而是“映射动作”
Godot 的输入处理分三层:底层硬件事件(KeyInput)、中间层动作映射(Action)、上层逻辑响应( input_event 或 _process )。绝大多数新手卡在第二层——他们写 if Input.is_key_pressed(KEY_SPACE) ,结果跳跃延迟半秒、连跳失效、移动端无法适配。
正确做法是: 先定义动作,再绑定设备,最后在角色脚本中响应动作 。
操作路径:
- 编辑 → 项目设置 → 输入映射(Input Map)标签页;
- 点击
+添加新动作,命名为ui_accept(通用确认键,兼容手柄A键/空格/鼠标左键); - 再添加
move_right、move_left、jump三个动作; - 分别为每个动作绑定键位:
move_right绑定D和Right,move_left绑定A和Left,jump绑定W、Space、Up; - 关键一步:勾选
Deadzone为0.5(防止手柄摇杆微动误触发),并为jump动作启用Allow Mouse(确保网页端点击也能触发)。
这样做的好处是:你后续在脚本里只需写 Input.is_action_just_pressed("jump") ,引擎会自动判断当前设备是键盘、手柄还是触屏,并返回统一布尔值。当你要移植到手机端时,只需在输入映射里新增 touch_jump 动作,绑定到屏幕某区域,而角色脚本一行代码都不用改。 </


984

被折叠的 条评论
为什么被折叠?



