欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

Unity之AssetBundle打包

程序员文章站 2022-04-03 15:38:18
...

AssetBundle

Resources:表示U3D自动将资源打成一个AssetBundle包,所有放在Resources下的文件夹都会打成一个AssetBundle包,资源非常大,Resources文件夹在真机上最大只有2G的内存(专业版会增大内存)

AssetBundle包:其实可以看成一个压缩包(有固定格式的),默认情况下使用LZMA压缩方式压缩的资源文件;和压缩ZIP一样的,只不过里面的格式变了

   Unity3D引擎为我们提供了三种压缩策略来处理AssetBundle的压缩,即:

    1、LZMA格式:

        在默认情况下,打包生成的AssetBundle都会被压缩。在U3D中,AssetBundle的标准压缩格式便是LZMA(LZMA是一种序列化流文件),因此在默认情况下,打出的AssetBundle包处于LZMA格式的压缩状态,在使用AssetBundle前需要先解压缩。使用LZMA格式压缩的AssetBundle的包体积最小(高压缩比),但是会相应的增加解压缩的时间

    2、LZ4格式:

        Unity5.3之后的版本增加了LZ4格式压缩,由于LZ4的压缩比一般,因此经过压缩后的AssetBundle包体的体积较大(该算法基于chunk)。

    3、不压缩

Resources和AssetBundle的区别:

  1、Resources:有2G的限制,不支持动态更新(拿Android为例)

    a、上线后,Resources里面的资源都在APK里面,只能读不能写

    b、StreamingAssets和dataPath都是在Apk中,Apk为一个压缩包,里面的东西只能读不能写,因此这个限制就决定了Resources不能支持热更新

  2、PersistPath(支持热更):

    a、只能手动打包

    b、打包方式:

      1、4.0以前,打包的依赖关系都必须手动

      2、5.0以后,这种依赖关系全部自动

创建AssetBundle:AssetBundle可以将任何资源打包成assetbundle(如果是unity不能识别的文件,可以通过改变后缀进行打包)

  1、在任何一个游戏物体的右下角有AssetBundle,第一个为包名,第二个为后缀(不能识别的物体不能修改,修改后缀变成能识别的物体)

更新流程:

  1、代码的更新:热更新

  2、资源的更新:AssetBundle更新

    a、创建assetbundle

    b、将assetbundle打成一个zip文件,放进streamingAssetPath里面

    c、把需要更新的AssetBundle先上传到Server,如果Server有更新(与服务器版本进行比对),把server的assetbundle包下载下来(zip文件),然后解压到persistentPath里

    d:加载:判断PersistentPath里是否有这个资源,如果没有就读取StreamingAssetPath里面的,如果有,就直接读取PersistentPath里的

        1、LoadAsset:从资源包中加载指定的资源

        2、LoadAllAsset:加载当前资源包中所以的资源

        3、LoadAssetAsync:从资源包中异步加载资源

  3、资源卸载:资源卸载部分使用的是Unload方法

     Unload:

        a、该方法会卸载运行时内存中包含在bundle中的所有资源。

        b、当传入的参数为true,则不仅仅内存中的AssetBundle对象包含的资源会被销毁;根据这些资源实例化而来的游戏内的对象也会销毁

        c、当传入的参数为false,则仅仅销毁内存中的AssetBundle对象包含的资源

    

using System.Collections.Generic;
using UnityEngine;
using UnityEditor;//编辑器命名空间的引用

public class TestDemo {

    //MenuItem:附加属性
    //自定义工具:提高团队的开发效率
    [MenuItem("Itools/TestBuild")]
	public static void BuilderAssetBundle()
    {
        string outputPath = Application.streamingAssetsPath + "/Test";
        //BuildPipeline.BuildAssetBundles():只需要提供一个输出AssetBundle的地址即可,
        //引擎会自动根据资源的assetBundleName属性批量打包,自动建立Bundle以及资源之间的依赖关系
        BuildPipeline.BuildAssetBundles(outputPath, 0, EditorUserBuildSettings.activeBuildTarget);
    }
}
  
  BuildPipeline.BuildAssetBundles():
    1、第一个参数:AssetBundle输出到哪一个文件夹
    2、第二个参数:枚举类型,可以选择多个参数,多个参数之间可以用“|“隔开
      a、CompleteAssets:保证资源的完备性,默认开启
      b、CollectDependencies:用于搜集资源的依赖项,默认开启
        和完整性有点相像,会把游戏物体所依赖的资源一起进行打包,防止有些被依赖的资源没有被打进去
      c、DeterministicAssetBundle:用于为资源维护固定ID,默认开启
        所以的资源都有固定的标记的,在资源的mate文件中的guid:64位组成的字符串,电脑里是随机生成并且唯一,每一个文件的唯一标识
      d、ForceRebuildAssetBundle:用于强制重打所有AssetBundle文件,5.3以后新增
        资源更新了,重新打包,将以前的资源包丢弃
      e、IgnoreTypeTreeChanges:用于判断AssetBundle更新时,是否忽略TypeTree的变化,新增
        打包时是否忽略父子关系
      f、AppendHashToAssetBundleName:用于将Hash值添加在AssetBundle文件名之后,开启这个选项可以直接通过文件名来判断哪些Bundle的内容进行了更新
        (4.X下普遍需要通过比较二进制等方法来判断,但在某些情况下即使内容不变重新打包,Bundle的二进制也会变化),新增
        在包名后缀名后面添加一个Hash表
      g:ChunkBasedCompression:用于使用LZ4格式进行压缩,5.3新增

  

 
        BuildPipeline.BuildAssetBundles(outputPath, BuildAssetBundleOptions.AppendHashToAssetBundleName|BuildAssetBundleOptions.ChunkBasedCompression, EditorUserBuildSettings.activeBuildTarget);

  AssetBundle的适用平台与跨平台性

    AssetBundle适用于多种平台,包括网页应用、移动应用、桌面应用等,可以动态更新,但不同平台所使用的AssetBundle并不相同,在创建离线AssetBundle的时候需要通过参数来指定目标平台,相关关系如表所示:

    Unity之AssetBundle打包

     IOS:在Mac版本的Standlone打包

    Windows:打Android、PC、WebPlayer