news 2026/5/23 7:35:42

【 Godot 4 学习笔记】命名规范

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
【 Godot 4 学习笔记】命名规范

命名规范

类型命名规范示例
文件与文件夹snake_case(蛇形)player_controller.gd,assets/
类名 / 脚本名PascalCase(大驼峰)PlayerController,YAMLParser
场景节点名PascalCase(大驼峰)HitBox,Camera3D,Player
函数 / 方法snake_case(蛇形)func load_level():
变量 / 信号snake_case(蛇形)var player_health,signal door_opened
常量 / 枚举成员CONSTANT_CASE(全大写)const MAX_SPEED = 200

文件夹结构。

这套结构采用了“按功能模块分类”的逻辑,非常适合中大型项目的长期维护:

res:// (项目根目录) ├── addons/ # 第三方插件(从资产商店下载的插件放这里) ├── assets/ # 纯美术与音频资源(不参与逻辑,只负责存放素材) │ ├── audio/ │ │ ├── music/ # 背景音乐 │ │ └── sfx/ # 音效 │ ├── fonts/ # 字体文件 (.ttf, .otf) │ ├── images/ # 通用图片(如Logo、背景图) │ ├── sprites/ # 精灵图/贴图 │ ├── textures/ # 3D纹理或程序化材质贴图 │ └── models/ # 3D模型文件 (.glb, .obj) ├── scenes/ # 所有的场景文件 (.tscn) │ ├── actors/ # 游戏中的动态实体 │ │ ├── player/ # 玩家相关(如 player.tscn, player.gd) │ │ ├── enemies/ # 敌人相关 │ │ └── npcs/ # NPC相关 │ ├── levels/ # 关卡与地图场景 │ │ ├── world_map.tscn │ │ └── level_01.tscn │ ├── ui/ # UI界面场景 │ │ ├── main_menu.tscn │ │ ├── game_hud.tscn │ │ └── pause_panel.tscn │ └── systems/ # 全局系统场景(如 autoload 的单例场景) ├── scripts/ # 独立的 GDScript 脚本文件 (.gd) │ ├── globals/ # 全局单例脚本(非场景类,如 global_data.gd) │ ├── components/ # 可复用的组件化脚本(如 health_component.gd) │ ├── utils/ # 纯工具类、算法类脚本 │ └── resources/ # 自定义 Resource 资源的配套脚本 ├── resources/ # 游戏数据资源 (.tres, .res) │ ├── items/ # 物品数据(如 sword.tres, potion.tres) │ ├── characters/ # 角色属性配置数据 │ └── levels/ # 关卡专属的配置数据 └── docs/ # 项目开发文档(Godot导出时会自动忽略此文件夹) ├── design.md # 核心设计草案 └── todo.md # 开发待办清单

结构设计核心思路

  1. assets/scenes/彻底分离
    assets/文件夹只负责存放最原始的素材(图片、声音、模型),而scenes/负责将这些素材组装成带有逻辑的游戏对象。这样做的好处是,当你的项目变大时,找一张图和找一个游戏场景不会混在一起。

  2. scripts/独立存放
    虽然 Godot 允许把.gd脚本和.tscn场景放在同一个文件夹里,但对于稍微复杂一点的项目,将纯代码脚本抽离到scripts/目录下,会让你的版本控制(Git)提交记录更加清晰,也方便复用代码。

  3. 充分利用resources/管理数据
    Godot 强大的自定义资源(Custom Resources)系统非常适合做数值策划。将物品的属性、敌人的血量等数据剥离出来放在resources/里,以后你想调整数值平衡时,完全不需要去碰复杂的代码逻辑。

  4. 善用docs/文件夹
    在根目录建一个docs/用来放你的设计草稿、待办事项或者 AI 对话生成的需求文档。Godot 在打包导出游戏时,默认只会打包引擎识别的资源文件,这些.md.txt文档不会被塞进最终的游戏包里,所以你可以放心地把项目笔记存在这里。

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

JAVA审计日志表被外层事务回滚问题分析与修复

文章目录审计日志被外层事务回滚问题分析与修复一、问题现象二、定位过程与误区三、根本原因3.1 事务边界与 Async 的关系3.2 失败分支为何丢日志3.3 为什么 catch 看不到异常四、修复方案4.1 修复后的事务时序4.2 为什么不去修 Async五、原理小结:Spring 事务传播行…

作者头像 李华
网站建设 2026/5/23 7:31:47

Compose 事件分发:Initial、Main、Final

在传统 View 体系中,我们接触最多的就是 dispatchTouchEvent (父节点 → 子节点)└── onInterceptTouchEventonTouchEvent (子节点 → 父节点) 而在 Compose 中,事件分发…

作者头像 李华
网站建设 2026/5/23 7:31:09

区块链+AI+边缘计算:构建可信、高效的糖尿病风险预测系统

1. 项目概述与核心价值作为一名在医疗健康与人工智能交叉领域摸爬滚打了十多年的从业者,我见证过太多“概念很酷,落地很难”的项目。今天想和大家深入聊聊一个将区块链与人工智能结合,用于糖尿病预测的实战项目。这不仅仅是又一个“AI医疗”的…

作者头像 李华
网站建设 2026/5/23 7:25:56

深度剖析LiteOS-M内核队列:数据结构、算法与嵌入式IPC实践

1. 项目概述与核心价值最近在深度研究LiteOS-M内核源码,特别是其进程间通信(IPC)机制中的队列模块。队列作为一种基础且高效的异步通信方式,在资源受限的嵌入式系统中扮演着至关重要的角色。它不像消息队列那样承载复杂的业务数据…

作者头像 李华
网站建设 2026/5/23 7:24:41

XUnity Auto Translator:打破语言壁垒的Unity游戏翻译解决方案

XUnity Auto Translator:打破语言壁垒的Unity游戏翻译解决方案 【免费下载链接】XUnity.AutoTranslator 项目地址: https://gitcode.com/gh_mirrors/xu/XUnity.AutoTranslator 你是否曾经因为语言障碍而错过精彩的Unity游戏?面对日文、韩文或其他…

作者头像 李华
网站建设 2026/5/23 7:24:08

DownKyi终极教程:轻松下载B站8K超高清视频的完整指南

DownKyi终极教程:轻松下载B站8K超高清视频的完整指南 【免费下载链接】downkyi 哔哩下载姬downkyi,哔哩哔哩网站视频下载工具,支持批量下载,支持8K、HDR、杜比视界,提供工具箱(音视频提取、去水印等&#x…

作者头像 李华