当前位置: 首页 > news >正文

【 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文档不会被塞进最终的游戏包里,所以你可以放心地把项目笔记存在这里。

http://www.gsyq.cn/news/1353859.html

相关文章:

  • 终极NHSE存档编辑器完整解析:从架构设计到高级修改的完整指南
  • 开机自启,免开机登录及图形界面
  • 小米K30U Ubuntu内核编译:从环境搭建到boot.img打包全流程
  • 多合一烧写器设计:从接口协议到硬件实现的嵌入式开发利器
  • 瑞萨MCU的AI战略:从边缘计算到嵌入式AI部署实战
  • 量子计算即服务框架QCSHQD:混合量子-经典开发实战指南
  • 模型参数量越大越好?qwen-vl-embedding模型实践
  • catlass 算子模板库的分层抽象设计:从模板到高性能矩阵乘
  • 晋城市2026黄金回收本地口碑商家榜:黄金首饰+ 白银+ 铂金+ 彩金回收门店及联系方式推荐 - 盛世金银回收
  • 百度智能云走进文博会:四方战略合作开启AI+IP新叙事
  • JetBrains IDE试用重置插件:30天无限续杯的开发利器
  • 单对以太网(SPE):一场改写工业通信物理层的底层变革
  • rust语言学习笔记Trait(九)PartialEq、 Eq(相等比较)
  • 轻薄本秒变高配工作站,向日葵升级“高性能版”,设计、剪辑更顺手!
  • ZU+ MPSoC 8颗DDR4大内存子系统硬件设计实战与信号完整性解析
  • 极限编程XP
  • Linux文件操作实战:find、grep、tar命令组合应用与避坑指南
  • 宁德市2026黄金回收本地口碑商家榜:黄金首饰+ 白银+ 铂金+ 彩金回收门店及联系方式推荐 - 盛世金银回收
  • QQ音乐加密音频技术解析:qmcdump解密工具深度指南与专业实践
  • [特殊字符] Java GC机制详解:G1、ZGC、Shenandoah全面解析与版本演进对比
  • matplotlib的Figure画布管理
  • LaCT架构解析:混合窗口注意力与长序列建模的创新融合
  • RT-Thread全局中断操作:原理、应用与低功耗设计关键
  • 荆州市2026黄金回收本地口碑商家榜:黄金首饰+ 白银+ 铂金+ 彩金回收门店及联系方式推荐 - 盛世金银回收
  • ESP32/ESP8266固件备份全攻略:esptool与flash_download_tool实战详解
  • 2026年GEO生成引擎优化:当AI成为信息入口,品牌如何抢占新流量高地?
  • DownKyi终极教程:轻松下载B站8K超高清视频的完整指南
  • 极致优化:Agent响应延迟从十秒压缩到一秒的全过程
  • 数字芯片RTL设计核心原则与实践:从可综合性到时序收敛
  • 国产工控机选型实战:从自主可控到边缘智能的工业应用解析