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)
上一篇 2022年6月28日 下午9:36
下一篇 2022年6月28日 下午9:36


相关推荐

  • 宏与WINDOWS API简单使用

    宏与WINDOWSAPI简单使用#define定义宏定义宏语法:#define<宏名><字符串>如#definePI3.1415926#defineP

    2021年12月13日
    53
  • TRAE 豆包大模型备案公示

    TRAE 豆包大模型备案公示

    2026年3月12日
    2
  • C/C++:long int与long long的区别

    C/C++:long int与long long的区别longint  longint即long,给人的感觉好像是长整型,但实际上,它和int一样,只有32位。cppreference给出的定义是——int-basicintegertype.Thekeywordintmaybeomittedifanyofthemodifierslistedbelowareused.Ifnolengthmodif…

    2022年6月6日
    59
  • SDIO接口_gmac接口是什么意思

    SDIO接口_gmac接口是什么意思文章目录SDIO信号和接口SDIO命令流程SDIO寄存器卡检测卡识别卡常用命令SDIO,全称:SecureDigitalInputandOutput,即安全数字输入输出接口。SDIO卡是在SD内存卡接口的基础上发展起来的接口,SDIO接口兼容以前的SD内存卡,并且可以连接SDIO接口的设备,目前根据SDIO协议的SPEC,SDIO接口支持的设备总类有蓝牙,网卡,电视卡等。支持三种不同…

    2022年10月4日
    6
  • 回溯法——利用解空间树解决0-1背包问题

    回溯法——利用解空间树解决0-1背包问题一 简介 01 背包典型的解法是动态规划 之前的博客也有介绍 这里就不再赘述 https blog csdn net Jayphone17 article details 这里有一些回溯法相关的基础理论知识 https blog csdn net Jayphone17 article details 二 算法设计 1 定义问题解

    2026年3月18日
    2
  • 黑盒测试 场景法_黑盒测试方法定义

    黑盒测试 场景法_黑盒测试方法定义通过运用场景来对系统的功能点或业务流程的描述,从而提高测试效果。场景法一般包含基本流和备用流,从一个流程开始,通过描述经过的路径来确定的过程,经过遍历所有的基本流和备用流来完成整个场景。  为什么场景法能如此清晰的描述整个事件?因为,现在的系统基本上都是由事件来触发控制流程的。如:我们申请一个项目,需先提交审批单据,再由部门经理审批,审核通过后由总经理来最终审批,如果部门经理审核不通过

    2026年4月15日
    6

发表回复

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

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