【Unity3D技术文档翻译】第1.3篇 创建 AssetBundles

上一章:【Unity3D技术文档翻译】第1.2篇 为打包 AssetBundles 准备资产
本章原文所在章节:【Unity Manual】→【Working in Unity】→【Advanced Development】→【AssetBundles】→【Building AssetBundles】
创建 AssetBundles
在【AssetBundles 工作流】一节中,我们使用了一个有3个参数的方法:BuildPipeline.BuildAssetBundles。这一节我们更深入一点,来了解这个方法的真正作用。

Assets/AssetBundles:这是一个目录,创建好的 AssetBundles 将输出到该目录下。你可以将该目录更改为任何你想要的目录,只要确保在创建 AssetBundles 前该目录真实存在。
BuildAssetBundleOptions
BuildAssetBundleOptions 有几个不同的选项可供选择,每个选项都有各自的效果。可以通过 BuildAssetBundleOptions 的 API 来浏览这些选项(截止2017.2版本共有12个属性选项)。
当项目需求改变或者增加时,你可以自由地改变或组合使用
BuildAssetBundleOptions 的不同选项。这里介绍3个涉及 AssetBundle 压缩方式的选项:
- BuildAssetBundleOptions.None
这个选项使用 LZMA 算法压缩文件,把序列化数据文件压缩为一个 LZMA 流。如果使用了该算法,在使用 AssetBundle 内的资源前,需要将 AssetBundle 完全解压。这就导致了即便使用了尽可能小的文件,仍然需要长一些的加载时间。再次提醒:当使用
BuildAssetBundleOptions.None 选项时,想要使用任何 AssetBundle 中的资源,整个 AssetBundle 必须处于未压缩状态。
一旦 AssetBundle 被解压,它将再次被 LZ4 压缩算法压缩,并存储在磁盘中。与 LZMA 算法不同的是,使用 LZ4 算法压缩的 AssetBundle,不需要等待整个 AssetBundle 被解压,就可以使用其中的任何资源。这种算法最好的使用场景是:一个 AssetBundle 包含了很多资源,当我们获取并使用其中的某个资源后,其他资源也将被陆续加载。比如:打包一个角色或者一个场景的所有资源。
LZMA 压缩算法只被推荐用于从远程服务器下载的小文件,作为初始化之用。一旦文件被下载下来,它们就会被缓存为 LZ4 算法压缩的 AssetBundle。
(三思题外话:LZ4 压缩算法是 Unity 5.3 版本新增的压缩格式。LZMA 算法的压缩比更大,相应的解压时间更长;LZ4 算法的压缩比稍小,但是解压时间大幅缩短。因此除了上段推荐的“从远程服务器下载小文件用于初始化”,其他场景建议使用 LZ4 算法压缩 AssetBundle。使用 LZ4 算法压缩的选项在下面有介绍。)
- BuildAssetBundleOptions.UncompressedAssetBundle
使用这个选项创建的 AssetBundle,其中的资源将完全不压缩。这会导致下载大文件时耗时较长,但是相应的,一旦下载完成,加载资源会很快。
- BuildAssetBundleOptions. ChunkBasedCompression
这个选项使用 LZ4 算法压缩资源,和 LZMA 压缩算法相比,压缩后的 AssetBundle 更大,但是在使用其中资源的时候不需要整个 AssetBundle 被解压。LZ4 使用一种基于数据块的算法, AssetBundle 在被加载时,会被当成一片片“数据块”依次加载。因此当一片“数据块”被解压后,其中包含的资源就可被使用,就算 AssetBundle 中的其他“数据块”还没有被解压。
ChunkBasedCompression选项拥有与完全不压缩的 AssetBundle 相近的加载时间,同时降低了存储在磁盘上的大小。(这里可以看作是官方钦定了)
BuildTarget
BuildTarget.Standalone:这个参数是用来告诉“构建流水线”(build pipeline)我们想要在哪个平台使用这些 AssetBundles。你可以在 BuildTarget 的 API 引用中查看详细的选项列表。当然,如果你不愿意硬编码 BuildTarget ,你可以使用 EditorUserBuildSettings.activeBuildTarget ,它会根据你当前设置的编译平台,来自动找到对应的平台创建 AssetBundle。
一旦你正确建立了脚本,你就可以创建你的 AssetBundles 了。如果你按照上面的例子写脚本,点击 Assets > Build AssetBundles 就可以开始创建 AssetBundles。
现在你已经成功创建了你的 AssetBundles,你可能注意到你的 AssetBundles 目录下比你预期的要多了其他的文件。准确的说,一共有 2*(n+1) 个多出来的其他文件。让我们来花点时间,更准确地复习一下 BuildPipeline.BuildAssetBundles 字段。
对于编辑器中的每个 AssetBundle,你将会注意到一个以该 AssetBundle 名称命名、以“.manifest”为后缀的文件。
另外还有一个额外的 bundle,并且 manifest 的名字没有和任何一个你创建的 AssetBundle 同名。它实际上是以所在的目录命名(即 AssetBundles 被创建到的目录)。这就是 Manifest Bundle。我们将讨论更多关于 Manifest Bundle 以及如何使用的内容。
AssetBundle 文件
这是指没有 “.manifest” 后缀名的文件,我们将在运行时加载它,并获取利用其中的资源。
AssetBundle 文件是一个包含了多种多样文件的归档(压缩)文件。归档的结构会有轻微的变化,这取决于它是一个普通的 AssetBundle 还是一个场景的
AssetBundle。下面是一个普通 AssetBundle 的结构图:

场景的 AssetBundle 和普通 AssetBundle 的结构有轻微不同,是因为场景数据流的加载和它所包含的内容都有所优化。下面是一个场景 AssetBundle 的结构图:(然而官方手册并没有给图片...)
Manifest 文件
对于每个生成的 AssetBundle,包括额外的 Manifest Bundle,都会有个相关联的 manifest 文件同时生成。manifest 文件可以被任何文本编辑器打开,里面包含了 AssetBundle 相关的一些信息,比如循环冗余检查(CRC:cyclic redundancy check)以及其他依赖数据。普通 AssetBundle 的 manifest 文件内容看起来像是下面的样子:
ManifestFileVersion: 0
CRC: 2422268106
Hashes:
AssetFileHash:
serializedVersion: 2
Hash: 8b6db55a2344f068cf8a9be0a662ba15
TypeTreeHash:
serializedVersion: 2
Hash: 37ad974993dbaa77485dd2a0c38f347a
HashAppended: 0
ClassTypes:
- Class: 91
Script: {instanceID: 0}
Assets:
Asset_0: Assets/Mecanim/StateMachine.controller
Dependencies: {}
Which shows the contained assets, dependencies, and other information.
The Manifest Bundle that was generated will have a manifest, but it’ll look more like this:
ManifestFileVersion: 0
AssetBundleManifest:
AssetBundleInfos:
Info_0:
Name: scene1assetbundle
Dependencies: {}
上面的内容显示了 AssetBundles 的联系性以及它们的依赖。目前,只需要知道它包含了 AssetBundleManifest 对象,该对象对在运行时加载哪个依赖的 AssetBundle 有显著帮助。想要学习了解更多关于如何使用 AssetBundle 和 manifest 对象的内容,可查看【本地使用 AssetBundles】一节。
如果本文对你有帮助的话,点个赞或者评论一下吧!
【Unity3D技术文档翻译】第1.3篇 创建 AssetBundles的更多相关文章
- 【Unity3D技术文档翻译】第1.8篇 AssetBundles 问题及解决方法
上一章:[Unity3D技术文档翻译]第1.7篇 AssetBundles 补丁更新 本章原文所在章节:[Unity Manual]→[Working in Unity]→[Advanced Deve ...
- 【Unity3D技术文档翻译】第1.9篇 使用 Unity AssetBundle Browser tool (AssetBundle系列完结)
上一章:[Unity3D技术文档翻译]第1.8篇 AssetBundles 问题及解决方法 本章原文所在章节:[Unity Manual]→[Working in Unity]→[Advanced D ...
- 【Unity3D技术文档翻译】第1.6篇 使用 AssetBundle Manager
上一章:[Unity3D技术文档翻译]第1.5篇 使用 AssetBundles 本章原文所在章节:[Unity Manual]→[Working in Unity]→[Advanced Develo ...
- 【Unity3D技术文档翻译】第1.4篇 AssetBundle 依赖关系
上一章:[Unity3D技术文档翻译]第1.3篇 创建 AssetBundles 本章原文所在章节:[Unity Manual]→[Working in Unity]→[Advanced Develo ...
- 【Unity3D技术文档翻译】第1.5篇 本地使用 AssetBundles
上一章:[Unity3D技术文档翻译]第1.4篇 AssetBundle 依赖关系 本章原文所在章节:[Unity Manual]→[Working in Unity]→[Advanced Devel ...
- 【Unity3D技术文档翻译】第1.7篇 AssetBundles 补丁更新
上一章:[Unity3D技术文档翻译]第1.6篇 使用 AssetBundle Manager 本章原文所在章节:[Unity Manual]→[Working in Unity]→[Advanced ...
- 【Unity3D技术文档翻译】第1.2篇 为打包 AssetBundles 准备资产
本章原文所在章节:[Unity Manual]→[Working in Unity]→[Advanced Development]→[AssetBundles]→[Preparing Assets f ...
- 【Unity3D技术文档翻译】第1.1篇 AssetBundle 工作流
译者前言:本章是关于从创建到加载,再到使用 AssetBundle 的整个流程的概述.阅读本章将对 AssetBundle 的工作流程有个简单而全面的了解. 本章原文所在章节:[Unity Manua ...
- 【Unity3D技术文档翻译】第1.0篇 AssetBundles
前言 "Unity圣典"是目前对官方文档翻译比较详细的,然而文档的最新更新日期是2013年,已经远远落后最新版本,参考意义有限.官方文档.脚本手册是学习Unity3D最直接有效的途 ...
随机推荐
- Powerdesigner+Execel
1.将Powerdesigner中的表(PDM)导入到execel中 Ctrl+Shift+X/tool->Execute commands ->Edit/Run script 粘贴如下v ...
- python_如何定义装饰器类?
案例: 实现一个能将函数调用信息记录到日志的装饰器 需求: 把每次函数的调用时间,执行时间,调用次数写入日志 可以对被装饰函数分组,调用信息记录到不同日志 动态修改参数,比如日志格式 动态打开关闭日志 ...
- junit4X系列--Builder、Request与JUnitCore
原文出处:http://www.blogjava.net/DLevin/archive/2012/05/12/377957.html.感谢作者的无私分享. 初次用文字的方式记录读源码的过程,不知道怎么 ...
- JAVA中pdf转图片的方法
JAVA中实现pdf转图片可以通过第三方提供的架包,这里介绍几种常用的,可以根据自身需求选择使用. 一.icepdf.有收费版和开源版,几种方法里最推荐的.转换的效果比较好,能识别我手头文件中的中文, ...
- java时间格式转化(毫秒 to 00:00)
把秒数转换为%d:%02d:%02d 格式 private String stringForTime(int timeSec) { int totalSeconds = timeSec; int se ...
- css 块状元素与行内元素(内联元素)的理解
块状元素: 它一般是其他元素的容器元素,可以容纳块状元素和行内元素,它默认是不会和其他元素同一行的,即相当于两个块状元素写一起是垂直布局的.最常用的是div和p 行内元素: 行内元素又称内联元素,它只 ...
- PHP date函数详解
在页面的最前页加上date_default_timezone_set(PRC); /*把时间调到北京时间,php5默认为格林威治标准时间*/date ()a: "am"或是 ...
- 【转】wget
wget 下载整个网站,或者特定目录 需要下载某个目录下面的所有文件.命令如下 wget -c -r -np -k -L -p www.xxx.org/pub/path/ 在下载时.有用到外部域名的图 ...
- CentOS7搭建时间服务器-chrony(不坑)
标签(linux): chrony 笔者Q:972581034 交流群:605799367.有任何疑问可与笔者或加群交流 之前centos6我们一直用的ntp时间服务器,虽然到CentOS7上也可以装 ...
- openstack开发基础