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

美乐迪电玩大厅加载机制与 RoomList 配置结构分析

本篇为《美乐迪电玩全套系统搭建》系列的第三篇,聚焦大厅与子游戏的动态加载机制,深入解析 roomlist.json 的数据结构、解析流程、入口配置方式与自定义接入扩展技巧。通过本篇内容,开发者可实现自由控制子游戏接入与分发策略。


一、RoomList 的定位与作用

在美乐迪电玩项目中,大厅与子游戏采用模块解耦加载机制。核心逻辑由 roomlist.json 文件驱动,该文件定义了所有子游戏的资源路径、名称标识、加载逻辑、热更新地址等。

路径:

assets/resources/config/roomlist.json

二、RoomList.json 数据结构详解

以实际配置为例:

[{"id": 1001,"name": "水果玛丽","prefab": "ui/games/shuiguomali/prefab","bundle": "shuiguomali","icon": "icon_fruit","type": "slots","hot": true,"entry": true,"version": "1.0.3"},{"id": 1002,"name": "跳高高","prefab": "ui/games/tiaogaogao/prefab","bundle": "tiaogaogao","type": "arcade","hot": false,"entry": false,"version": "1.0.1"}
]

字段解释:

字段名含义说明
id游戏唯一编号,用于逻辑判断
name展示用游戏名称
prefab子游戏 UI 入口 Prefab 路径
bundle对应热更新资源包名称(即子游戏目录名)
icon显示在大厅的图标路径
type游戏类别标签(slots、arcade等)
hot是否在大厅显示“火爆”标识
entry是否显示在大厅首页
version当前子游戏版本号,用于热更新对比

三、大厅挂载流程源码解析

关键入口:HallGameLoader.ts

loadRoomList() {cc.resources.load("config/roomlist", cc.JsonAsset, (err, data) => {const list = data.json;list.forEach(item => {this.createGameEntry(item);});});
}createGameEntry(item) {cc.resources.load(item.icon, cc.SpriteFrame, (err, icon) => {const node = cc.instantiate(this.gameEntryPrefab);node.getComponent(GameEntry).init(item, icon);this.content.addChild(node);});
}

说明:

  • roomlist.json 加载所有子游戏条目

  • 动态实例化按钮节点,根据 JSON 参数设定点击行为


四、子游戏打包与热更新配置

  1. 使用 Cocos Creator 将每个子游戏打成独立的 bundle

  2. 在主工程设置:

项目设置 -> Asset Bundle -> 创建新Bundle -> 命名与子游戏路径一致
  1. 将 bundle 打包并上传至远程服务器:

/shuiguomali/├── index.js├── config.json├── assets/
  1. 大厅热更管理器会自动检测对应 bundle/version 进行更新处理


五、扩展:新增一个子游戏

假设你要新增一个叫“雷电战机”的小游戏:

1. 构建资源包

  • 将其项目以 bundle 形式构建,生成 leidianzhanji 目录

2. 上传远程服务器

  • 上传路径为:https://your.cdn.com/leidianzhanji/

3. 修改 roomlist.json

{"id": 1010,"name": "雷电战机","prefab": "ui/games/leidianzhanji/prefab","bundle": "leidianzhanji","icon": "icon_jet","type": "shoot","hot": true,"entry": true,"version": "1.0.0"
}

4. 更新大厅资源路径配置(可选)

若大厅已接入动态 CDN 拉取机制,请确保 CDN 路径在 remote_config.json 中也添加 leidianzhanji 节点。


六、调试技巧与注意事项

  • 所有 icon 路径必须存在,否则实例化失败会报错

  • 若 bundle 构建后无法热更新,请确认版本号变动

  • 子游戏 Prefab 与 icon 推荐统一命名规则,便于维护

  • 子游戏资源中不要引用主工程资源,避免依赖错乱


小结

通过 roomlist.json + 动态 bundle 架构,美乐迪电玩的大厅实现了模块化加载、按需接入、热更新分发等多种场景的适配,为多子游戏平台构建提供了高扩展性的基础设施。下一篇我们将进入服务器层,逐步剖析游戏状态同步与发卡查分模块的完整实现。

http://www.xdnf.cn/news/75313.html

相关文章:

  • JavaScript之深浅拷贝
  • 安宝特方案 | 医疗AR眼镜,重新定义远程会诊体验
  • 【安装部署】Linux下最简单的 pytorch3d 安装
  • 安宝特案例 | AR如何大幅提升IC封装厂检测效率?
  • C#进阶学习(十)更加安全的委托——事件以及匿名函数与Lambda表达式和闭包的介绍
  • 【架构】ANSI/IEEE 1471-2000标准深度解析:软件密集型系统架构描述推荐实践
  • 【MATLAB第117期】#源码分享 | 基于MATLAB的SSM状态空间模型多元时间序列预测方法(多输入单输出)
  • 4.21—4.22学习总结 JavaWeb:HTML-CSS
  • Laravel 对接阿里云 OSS 说明文档
  • ecovadis评级范围,如何拿到ecovadis评级高分
  • K8S探针的应用
  • 【教程】安装 iterm2 打造漂亮且高性能的 mac 终端
  • k8s-1.28.10 安装metrics-server
  • 模拟实现strncat、qsort、atoi
  • AR/VR衍射光波导性能提升遇阻?OAS光学软件有方法
  • 如何将当前文件夹及其子文件夹下的所有word提取到一个excel里
  • 新能源汽车充电桩:多元化运营模式助力低碳出行
  • CoinNexus Chain 推出泰利风暴,开启 Web3.0 智能金融元宇宙科技新时代
  • 数字空间与VR有什么关系?什么是数字空间?
  • 全能 Sui 技术栈,构建 Web3 的未来
  • Go语言之sync包 WaitGroup的使用和底层实现
  • NVIDIA 自动驾驶技术见解
  • 基于监督学习的图像分类系统优化
  • Oracle--PL/SQL编程
  • 蓝桥杯常考的找规律题
  • Unity Paint In 3D 入门
  • (51单片机)LCD显示温度(DS18B20教程)(LCD1602教程)(延时函数教程)(单总线教程)
  • PDF处理控件Aspose.PDF指南:使用 Python 将 EPUB 转换为 PDF
  • Kubernetes相关的名词解释kubelet 组件(17)
  • uniapp 上传二进制流图片