AssetBundle相关

AssetBundle相关====>AssetBundle打包:设置好AssetBundle包名后,利用BuildPipeline.BuildAssetBundles("Path");进行打包。该函数有三参和四参的,三参如下:    outputPath : 导出路径  BuildAssetBundleOptions  : 导出选项枚举,内容在后面。 其中包含:是否压缩,是否使用块压缩即LZ4压缩等 BuildTa…

大家好,又见面了,我是你们的朋友全栈君。

====>AssetBundle打包:设置好AssetBundle包名后,利用BuildPipeline.BuildAssetBundles (“Path”);进行打包。

该函数有三参和四参的,三参如下:

    outputPath : 导出路径 
 BuildAssetBundleOptions  : 导出选项枚举,内容在后面。 其中包含:是否压缩,是否使用块压缩即LZ4压缩等
 BuildTarget  : 导出平台枚举

        如果第二个参数选择None,则默认是选择LZMA算法压缩。

        LZMA:压缩出来的包更小,故加载时间长但是需要整体解压(比如包中有ABC三个资源,我只需用A,但BC也会被解压出来)

        LZ4:会对ABC资源分别进行压缩(块压缩),所以如果只使用A,那么BC不会被解压出来。速度快

====>下载AssetBundle:下载AB包api

            有四大种(从内存、本地、WWW、UnityWebRequest),其中LoadFromFile和LoadFromMemory都有其异步方法。而3,4推荐使用4。3是如果当前没有下载过,就从服务器下载,存到本地的缓存Catch中。如果下载过就直接从本地Catch中加载。

            同步加载传递参数是路径,Async的传递byte字节数组,www传递url和版本号(或者校验码等)    

            www传递参数url,版本号。

            AssetBundle相关

            法①:AssetBundle.LoadFromFile(“abPath + pathName”)及其

            法②:异步方法AssetBundle.LoadFromFileAsync  协程实现

                        static IEnumerator LoadAsyncCoroutine(string path){

                                 AssetBundleCreateRequest abcr = AssetBundle.LoadFromFileAsync(path) ;

                                 yield return abcr;

                                AssetBundle ab = abcr.assetBundle;

                         }

                法③、④:LoadFromMemoryAsync  ,LoadFromMemory(参数也是字节数组)

                                        AssetBundle相关

                法⑤:www异步加载  yield return www;www.assetBundle;即可

                            AssetBundle相关

                法⑥:UnityWebRequest方法,用来代替WWW加载。

                            AssetBundle相关

====>加载AssetBundle包中的资源

                     AssetBundle相关

               法①: Object  AssetBundle.LoadAsset(string assetName);

              法②: AssetBundleRequest AssetBundle.LoadAssetAsync(string assetName); 返回值是AssetBundleRequest类型 abr ,abr.assetBundle即可。

                其他方法:LoadAllAsset及其异步Async方法

=================================

依赖加载处理,解决冗余:依赖加载

            ①获取包含总Manifest文件的AB包(与目录名相同)

                    AssetBundle manifestAB = AssetBundle.LoadFromFile(outputPath); // 加载总ManifestAssetBundle

            ②得到Manifest文件

                    AssetBundleManifest manifest = (AssetBundleManifest)manifestAB.LoadAsset(“AssetBundleManifest”);

            ③获取当前资源所需的所有依赖项

                    string[] dependencies = manifest.GetAllDependencies(“sprite1234.ab”); // 结果 sprite1.ab

            ④遍历加载出所有依赖包

                    foreach(string name in dependencies){

                AssetBundle.LoadFromFile(“path+name”);

            }

             ⑤释放资源包

                    manifestAB.Unload(false); // 释放AssetBundle

========释放资源

           AssetBundle.Unload(false):卸载当前不被使用的资源,可能会造成内存没法被卸载。比如:

            一个包AB中有一个m材质被Person1使用着,那么调用完该方法后,AB包被卸载了,但是Person1上的m没被卸载,但是和AB包间的引用关系断开了。这时,即使我重新加载出了AB包,它也和Person1之间没引用关系了,这时如果m不被Person1使用了,那么m就没有办法被卸载了。这时只能通过Resources.UnloadUnusedAsset()卸载了

        AssetBundle.Unload(true):卸载AB包以及所有资源。使用:要确保当前没有物体在使用里边的资源了,一般在关卡、场景切换时

        AssetBundle相关


                    

        释放资源

        注意:如果不释放www,则AssetBundle.Unload(false)的时候,是不能释放掉ab包的,因为内存会保存有一份ab的引用。

        & www对象:www加载完毕后调用www.dispose()或www = null

        & AssetBundle对象:    

            对于使用完毕的AB,调用AssetBundle.Unload(false)或true释放

            false:卸载AB对象时,保留内存中已加载的资源 ture:卸载AB对象时,同时卸载内存中已加载的资源(不建议)

        & 对于资源使用完毕的,调用Resources.UnloadAsset()

        & 不再使用的GameObject直接Destroy即可

        —-

        * Prefab:DestroyImmediate卸载

        * 非Prefab:Resources.UnloadAsset()、Resources.UnloadUnuesedAsset()、AssetBundle.Unload(true)

============================================================================================

AssetBundle分组策略:

                    AssetBundle相关

AssetBundle相关

        解释:1、不经常更新的和经常更新分离:如果不分离比如A、B都是100M,本来只有A需要更新,这时因为它们是同一个包,那么用户需要下载更新200M。

=========================AssetBundle查看工具(内含可查看包大小、名字、引用资源、包含资源等+打包功能等):AssetBundle Browser tool

        AssetBundle相关

AssetBundle相关

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/148676.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 百度之星资格赛,hdu 4825 XOR SUM

    百度之星资格赛,hdu 4825 XOR SUM

    2021年11月23日
    45
  • java ee简介_Java EE 简介

    java ee简介_Java EE 简介JavaEE简介JavaEE基本架构JavaEE的诞生是为了解决传统C/S架构的弊端:客户端臃肿庞大,扩展性差等弊端。JavaEE将传统的两层结构细分为了四层。这四层分别是:Client层,Web层,Business层,EIS层JavaEE客户端JavaEE客户端层可分为以下几种:Web客户端,通常是浏览器呈现的网页,这种客户端成为轻量级客户端,因为他们不与…

    2022年7月7日
    15
  • 配置NFS固定端口[通俗易懂]

    配置NFS固定端口[通俗易懂]NFS启动时会随机启动多个端口并向RPC注册,为了设置安全组以及iptables规则,需要设置NFS固定端口。NFS服务需要开启mountd,nfs,nlockmgr,portmapper,rquotad这5个服务,其中nfs、portmapper的端口是固定的,另外三个服务的端口是随机分配的,所以需要给mountd,nlockmgr,rquotad设置固定的端口。其中,给mountd、rq…

    2022年6月27日
    153
  • charles打断点有什么用_charles打断点后 如何执行

    charles打断点有什么用_charles打断点后 如何执行前言Charles是收费软件,可以免费试用30天。试用期过后,未付费的用户仍然可以继续使用,但是每次使用时间不能超过30分钟,并且启动时将会有10秒种的延时。此时,我们只需网上找一个注册码即可解

    2022年7月30日
    3
  • 直插式电阻电容封装与尺寸图…[通俗易懂]

    原文地址:直插式电阻电容封装与尺寸图解作者:北极光直插式无源器件体积普遍要比贴片式要大一些,而且直插式器件在制作PCB时需要打孔,焊接工艺跟贴片式也有差别,较为麻烦,相对而言,直插式电阻电容多是面向大功率电路应用。一、直插式电阻封装及尺寸直插式电阻封装为AXIAL-xx形式(比如AXIAL-0.3、AXIAL-0.4),后面的xx代表焊盘中心间距为xx英寸,这一点在网上很多文章都没说清楚

    2022年4月12日
    465
  • poj3617Best Cow Line

    poj3617Best Cow Line

    2021年12月7日
    37

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号