资源第二篇:bundle 的config.json 文件内容的解析

2024-08-26 16:36

本文主要是介绍资源第二篇:bundle 的config.json 文件内容的解析,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

简介

本篇文章主要是对bundle包的核心文件config.json 的分析。config.json记录着整个bundle包的具体信息,并通过config.json 去解析整个bundle包。

bundle 目录下的文件结构

在这里插入图片描述

  1. import 存放所有的json。场景、预制体、texture2D配置等json
  2. native 存放所有的实际资源,名字是使用资源的uuid
  3. config.json 是bundle的配置信息,包含了使用到的所有资源信息等
  4. index.js 是bundle中的所有脚本合并后生成的js脚本

勾选调试模式的 config.json 内容

{"paths": {}, //如果资源本身在bundle目录下,这里会有资源的路径,如果是主包,未使用到的资源不会打入包中//场景使用到的素有资源的uuid,包括场景的uuid"uuids": ["25mPg1UuhFQLAWwyCGbyp/", // test2.fire 场景的uuid"d5gcIrQmhPd7ttYFvz1IeF", // test2.fire 场景依赖的资源,自己包中的texture的uuid"ecpdLyjvZBwrvm+cedCcQy", //其他bundle中的资源"f7lRyGrkdLioafj1l6glWx" // test2.fire 场景依赖的资源,自己包中的texture中的spriteFrame的uuid],"scenes": {"db://assets/main/test2.fire": "25mPg1UuhFQLAWwyCGbyp/" //场景的路径,场景的uuid},"redirect": ["ecpdLyjvZBwrvm+cedCcQy", 0], //重定向,如果使用了其他bundle的资源,资源的uuid会出现在这里"deps": ["internal"], //依赖的bundle/** packs  是对相同合并包的一个解析比如:**/"packs": {"09731f1b4": ["25mPg1UuhFQLAWwyCGbyp/", "f7lRyGrkdLioafj1l6glWx"] //场景依赖的资源uuid,后面的uuid是使用的spriteFrame的uuid},"name": "main", //bundle的名字"importBase": "import", //import 目录资源的路径"nativeBase": "native", //native 目录资源的路径"debug": true,"isZip": false,"encrypted": false, // 是否加密"versions": {// 依赖的资源,本包中import文件夹下的资源,第一个是场景的uuid(固定位置),第二个元素是版本号,后面的是资源的uuid与版本号"import": ["09731f1b4", "75d10", "d5gcIrQmhPd7ttYFvz1IeF", "7be92"],// 依赖的资源,本包中native文件夹下的资源,第一个是资源的压缩uuid,紧接这是版本号"native": ["d5gcIrQmhPd7ttYFvz1IeF", "2790f"]}
}

release模式的 config.json 内容

{//paths是资源的路径信息,key是资源的uuid,value是一个数组,第一个元素是资源的路径,后面的元素是资源的类型"paths": {},//types是资源的类型信息,paths中的资源类型是通过索引来这里的查找的"types": [],//当前包使用到的所有资源的uuid,包含场景的uuid"uuids": ["25mPg1UuhFQLAWwyCGbyp/","d5gcIrQmhPd7ttYFvz1IeF","edLdjA5wFPBZ6FT1VAfExX","03jMiDhOFLDY594LJy1G1v","41F7knMkFA/L9r3Fe/KnP6","ecpdLyjvZBwrvm+cedCcQy","f7lRyGrkdLioafj1l6glWx"],//场景信息,key是场景的路径,value是uuids的索引数字 可以根据索引数字从uuids中找到uuid"scenes": { "db://assets/main/test2.fire": 0 },//重定向信息,当该包中使用了其他bundle资源时,会生成信息。每2个为一组,前一个为uuids的索引数字,后一个为deps的索引数字"redirect": [4, 0, 5, 1],//使用到其他bundle的资源时,会再次记录bundle包的名字。例如这里使用了subGame1和internal两个bundle的资源"deps": ["subGame1", "internal"],/**打包信息,例如这里有两个pack,每个元素的key都是import中文件名(uuid),value是该文件关联的资源的uuid数组。例如:第一个pack 中key是import中场景的json名,value是是该场景中使用到的所有资源的索引数字,通过该索引数字可以从uuids中找到uuid第二个pack中key是import中texture2D的json名,value是所有的texture2D都会使用该texture2D的json的索引数字,通过该索引数字可以从uuids中找到uuid**/"packs": { "064519d1c": [1, 2], "0addf2f00": [3, 0, 6] },"name": "main",//bundle的名字"importBase": "import",//import文件夹的名字"nativeBase": "native",//native文件夹的名字"debug": false,//是否是debug模式"isZip": false,//是否是zip压缩"encrypted": false,//是否是加密的/** 版本信息,import中的版本信息,native中的版本信息。打包勾选了MD5 Cache时,会生成版本信息。没勾选时,为空。没有versions字段时,表示没有勾选MD5 Cache。import中的版本信息是一个数组,每2个为一组,第一个是uuids的索引数字,第二个是版本号。这里使用的直接是import中的文件名064519dc。native中的版本信息是一个数组,每2个为一组,第一个是uuids的索引数字,第二个是版本号**/"versions": { "import": ["064519d1c", "b2b05", "0addf2f00", "dfe43"], "native": [1, "2790f", 2, "6b2af"] }
}

这两种不同config.json可以做一个很好的参考对比,第二种由于带有很多数字,较难理解,所以参考第一种会更容易让人去理解数字表示的意思。

打包规则的简单总结

压缩类型设置:压缩是对import目录下的json文件的操作。

  • 无压缩: 所有的json文件都独立存在
  • 默认:相同类型的会压缩到一起。

例如:spriteFrame的json会与场景的json合并到一起。texture2D的json相同的话合并成一个json,它的解析会在config.json的packs中关联,texture的json的uuid作为key,value是所有使用到该json的cc.Texture2D的uuid。

  • 合并所有json:把所有的json 合并成一个大json
    官方文档参考: 压缩类型设置

注意点

  1. main 是主包,资源在主包文件目录中,但未被静态引用,则该资源不会被打到包里。简单来说就是只会把静态引用到的资源打包进去。
    其他bundle,如果资源在bundle中,就会打入到bundle中。
  2. bundle的优先级问题:官方文档优先级
  3. 静态引用资源,会把spriteFrame的json合并到场景的json中,如果是未使用到的资源,它的json都是独立的一个文件,依然会打包到config.json 的uuids字段里。
  4. internal 内置bundle 是一个特殊的bundle,在项目加载时,第一个加载的bundle 是internal bundle,当启动游戏时,会在准备引擎阶段下载internal的effects目录和Material目录。最后才会通过bundle的api 反序列化场景数据和初始化场景。

这篇关于资源第二篇:bundle 的config.json 文件内容的解析的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1109098

相关文章

网页解析 lxml 库--实战

lxml库使用流程 lxml 是 Python 的第三方解析库,完全使用 Python 语言编写,它对 XPath表达式提供了良好的支 持,因此能够了高效地解析 HTML/XML 文档。本节讲解如何通过 lxml 库解析 HTML 文档。 pip install lxml lxm| 库提供了一个 etree 模块,该模块专门用来解析 HTML/XML 文档,下面来介绍一下 lxml 库

【C++】_list常用方法解析及模拟实现

相信自己的力量,只要对自己始终保持信心,尽自己最大努力去完成任何事,就算事情最终结果是失败了,努力了也不留遗憾。💓💓💓 目录   ✨说在前面 🍋知识点一:什么是list? •🌰1.list的定义 •🌰2.list的基本特性 •🌰3.常用接口介绍 🍋知识点二:list常用接口 •🌰1.默认成员函数 🔥构造函数(⭐) 🔥析构函数 •🌰2.list对象

OWASP十大安全漏洞解析

OWASP(开放式Web应用程序安全项目)发布的“十大安全漏洞”列表是Web应用程序安全领域的权威指南,它总结了Web应用程序中最常见、最危险的安全隐患。以下是对OWASP十大安全漏洞的详细解析: 1. 注入漏洞(Injection) 描述:攻击者通过在应用程序的输入数据中插入恶意代码,从而控制应用程序的行为。常见的注入类型包括SQL注入、OS命令注入、LDAP注入等。 影响:可能导致数据泄

从状态管理到性能优化:全面解析 Android Compose

文章目录 引言一、Android Compose基本概念1.1 什么是Android Compose?1.2 Compose的优势1.3 如何在项目中使用Compose 二、Compose中的状态管理2.1 状态管理的重要性2.2 Compose中的状态和数据流2.3 使用State和MutableState处理状态2.4 通过ViewModel进行状态管理 三、Compose中的列表和滚动

Spring 源码解读:自定义实现Bean定义的注册与解析

引言 在Spring框架中,Bean的注册与解析是整个依赖注入流程的核心步骤。通过Bean定义,Spring容器知道如何创建、配置和管理每个Bean实例。本篇文章将通过实现一个简化版的Bean定义注册与解析机制,帮助你理解Spring框架背后的设计逻辑。我们还将对比Spring中的BeanDefinition和BeanDefinitionRegistry,以全面掌握Bean注册和解析的核心原理。

两个月冲刺软考——访问位与修改位的题型(淘汰哪一页);内聚的类型;关于码制的知识点;地址映射的相关内容

1.访问位与修改位的题型(淘汰哪一页) 访问位:为1时表示在内存期间被访问过,为0时表示未被访问;修改位:为1时表示该页面自从被装入内存后被修改过,为0时表示未修改过。 置换页面时,最先置换访问位和修改位为00的,其次是01(没被访问但被修改过)的,之后是10(被访问了但没被修改过),最后是11。 2.内聚的类型 功能内聚:完成一个单一功能,各个部分协同工作,缺一不可。 顺序内聚:

CSP 2023 提高级第一轮 CSP-S 2023初试题 完善程序第二题解析 未完

一、题目阅读 (最大值之和)给定整数序列 a0,⋯,an−1,求该序列所有非空连续子序列的最大值之和。上述参数满足 1≤n≤105 和 1≤ai≤108。 一个序列的非空连续子序列可以用两个下标 ll 和 rr(其中0≤l≤r<n0≤l≤r<n)表示,对应的序列为 al,al+1,⋯,ar​。两个非空连续子序列不同,当且仅当下标不同。 例如,当原序列为 [1,2,1,2] 时,要计算子序列 [

多线程解析报表

假如有这样一个需求,当我们需要解析一个Excel里多个sheet的数据时,可以考虑使用多线程,每个线程解析一个sheet里的数据,等到所有的sheet都解析完之后,程序需要提示解析完成。 Way1 join import java.time.LocalTime;public class Main {public static void main(String[] args) thro

ZooKeeper 中的 Curator 框架解析

Apache ZooKeeper 是一个为分布式应用提供一致性服务的软件。它提供了诸如配置管理、分布式同步、组服务等功能。在使用 ZooKeeper 时,Curator 是一个非常流行的客户端库,它简化了 ZooKeeper 的使用,提供了高级的抽象和丰富的工具。本文将详细介绍 Curator 框架,包括它的设计哲学、核心组件以及如何使用 Curator 来简化 ZooKeeper 的操作。 1

STL经典案例(四)——实验室预约综合管理系统(项目涉及知识点很全面,内容有点多,耐心看完会有收获的!)

项目干货满满,内容有点过多,看起来可能会有点卡。系统提示读完超过俩小时,建议分多篇发布,我觉得分篇就不完整了,失去了这个项目的灵魂 一、需求分析 高校实验室预约管理系统包括三种不同身份:管理员、实验室教师、学生 管理员:给学生和实验室教师创建账号并分发 实验室教师:审核学生的预约申请 学生:申请使用实验室 高校实验室包括:超景深实验室(可容纳10人)、大数据实验室(可容纳20人)、物联网实验