unity AssetBundle 使用方法1

2024-06-09 14:48

本文主要是介绍unity AssetBundle 使用方法1,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

AssetBundle是Unity引擎提供的—种用于存储资源的文件格式 ,它 可以存储任意一种Unity引擎能够识别的资源 ,例如模型 、纹理 、音频 、动画片段甚至整个场景等 。AssetBundle也可以包含开发者自定义的二进制文件,只需将二进制文件的扩展名改成.bytes,unity引擎即可将其识别为TextAsset,进 而可以被打包到AssetBundle文件中。

AseetBundle 资源打包

如何离线创建AB
BuildPipeline.BuildAssetBundle(UnityEngine.Object mainAsset, UnityEngine.Object[] assets, string pathName, BuildAssetBundleOptions assetBundleOptions, BuildTarget targetPlatform) 

•  将Project文件夹中的任意个Assets打包成一个AB
•  一般适用于对单个大规模场景的细分
参数:mainAsset 主资源,assets 打包对象,pathName 文件保存路径, assetBundleOptions 打包类型,targetPlatform 目标平台

  BuildPipeline.BuildStreamedSceneAssetBundle(string[] levels, string locationPath, BuildTarget target) 

• 该方法与BuildPipeline.BuildAssetBundle的作用相似,但是多了一个额外的参数可以为每个物体指定一个自定义的标识符
•  将一个或多个场景中的资源及其所有依赖打包成一个AB
•  一般适用于对单个或多个场景进行集中打包
参数:打包场景名称数组 levels,locationPath 保存路径,target 目标平台

打包选项 BuildAssetBundleOptions

CompleteAssets
•  使每个Asset本身完备化

CollectDependencies
•  包入每个Asset依赖的所有资源

DeterministicAssetBundle
•  使每个Object具有唯一的、不变的Hash ID,便于后续查找
•  可用于增量式发布Asset Bundle

UncompressedAssetBundle
•  不进行数据压缩

依赖关系处理

假设模型A需要使用材质materia1和材质materia2,模型B需使用材质materia1和materia3,materia1需要使用贴图texture1,materia2需要使用贴图texture2,materia3需要使用贴图texture3,模型C需要使用模型A。
我们在进行打包的时候需要将被依赖的对象优先进行打包,因此打包顺序为先为贴图texture1、texture2、texture3进行打包,然后对材质materia1、materia2、materia3进行打包,在对模型A、模型B进行打包,最后对模型C进行打包。
打包建立依赖需要使用的方法:
•  BuildPipeline.PushAssetDependencies()
•  BuildPipeline.PopAssetDependencies()
以上两个方法必须成对使用,一个push对应一个pop
打包过程简化为
PushAssetDependencies。。
打包texture1、texture2、texture3
PushAssetDependencies。。
打包materia1、materia2、materia3
PushAssetDependencies。。
打包模型A、模型B
PushAssetDependencies。。
打包模型C
PopAssetDependencies。。
PopAssetDependencies。。
PopAssetDependencies。。
PopAssetDependencies。。

参考示例
对选择的一个文件夹内的对象进行打包
static void floderPack(){string fileName = "resource1";//打包文件名if (Selection.activeObject != null){//如果选择内容不为空,则打包文件名为该文件名fileName = Selection.activeObject.name;}//设置打包文件保存文件夹的位置string targetDir = Application.streamingAssetsPath + "/MyResource";if (!Directory.Exists(targetDir)){targetDir = "";}//打开文件打包路径选择面板,选择文件打包路径string savePath = EditorUtility.SaveFilePanel("打包文件", targetDir, fileName, ExtensionType.unity3D);//设置打包方式为保存依赖的所有文件BuildAssetBundleOptions ABBuilder = BuildAssetBundleOptions.CollectDependencies | BuildAssetBundleOptions.CompleteAssets | BuildAssetBundleOptions.DeterministicAssetBundle;Object[] objs = Selection.GetFiltered(typeof(Object), SelectionMode.DeepAssets);foreach (var item in objs){string objPath = AssetDatabase.GetAssetPath(item);Debug.Log("objpath=" + objPath);if (item is Texture2D){AssetDatabase.ImportAsset(objPath);}}bool isBuildOK = BuildPipeline.BuildAssetBundle(Selection.activeGameObject, objs, savePath, ABBuilder, BuildTarget.StandaloneWindows);if (isBuildOK){Debug.Log("build ok");}else{Debug.Log("build error");}}
对一个文件夹内的被选中的单独文件进行打包
[MenuItem("ABpackage/SingleFileAB")]static void SinglePack(){string fileName = "resource1";//打包文件名if (Selection.activeObject != null){//如果选择内容不为空,则打包文件名为该文件名fileName = Selection.activeObject.name;}//设置打包文件保存文件夹的位置string targetDir = Application.streamingAssetsPath + "/MyResource";if (!Directory.Exists(targetDir)){targetDir = "";}//打开文件打包路径选择面板,选择文件打包路径string savePath = EditorUtility.SaveFilePanel("打包文件", targetDir, fileName, ExtensionType.unity3D);//设置打包方式为保存依赖的所有文件BuildAssetBundleOptions ABBuilder = BuildAssetBundleOptions.CollectDependencies | BuildAssetBundleOptions.CompleteAssets | BuildAssetBundleOptions.DeterministicAssetBundle;Object obj = Selection.activeObject;string objPath = AssetDatabase.GetAssetPath(obj);Debug.Log("objpath=" + objPath);Object[] objs = { obj };bool isBuildOK = BuildPipeline.BuildAssetBundle(Selection.activeGameObject, objs, savePath, ABBuilder, BuildTarget.StandaloneWindows);if (isBuildOK){Debug.Log("build ok");}else{Debug.Log("build error");}}
对一个文件夹内的场景文件进行打包
[MenuItem("ABpackage/ScenesAB _Android")]public static void ABScenes(){string assetPath = EditorUtility.SaveFilePanel("save scene", "", "myScene", "scene.assetbundle");//string currentScene = EditorApplication.currentScene;Object[] objs = Selection.GetFiltered(typeof(Object), SelectionMode.DeepAssets);List<string> list = new List<string>();foreach (var item in objs){string path = AssetDatabase.GetAssetPath(item);int mFindIndex = path.LastIndexOf(".");string mExtName = path.Substring(mFindIndex + 1);//获取文件后缀名Debug.Log("mExtName:" + mExtName);if (mExtName == "unity")//保存场景文件{list.Add(path);}}Debug.Log("list.Count=" + list.Count);BuildPipeline.BuildStreamedSceneAssetBundle(list.ToArray(), assetPath, BuildTarget.Android);}
通过依赖关系进行打包
[MenuItem("ABpackage/depend")]public static void test1(){//依赖关系:objB和objC依赖于objAObject objA = AssetDatabase.LoadAssetAtPath("Assets/Texture/village_04.png", typeof(Object));Object objB = AssetDatabase.LoadAssetAtPath("Assets/Model/Cube2.prefab", typeof(Object));Object objC = AssetDatabase.LoadAssetAtPath("Assets/Model/Sphere.prefab", typeof(Object));BuildAssetBundleOptions option = BuildAssetBundleOptions.CollectDependencies | BuildAssetBundleOptions.CompleteAssets | BuildAssetBundleOptions.DeterministicAssetBundle;//PushAssetDependencies需要和PopAssetDependencies成对出现//被依赖对象需要先进行打包Object[] obj1 = { objA };Object[] obj2 = { objB };Object[] obj3 = { objC };BuildPipeline.PushAssetDependencies();BuildPipeline.BuildAssetBundle(null, obj1, @"D:\U3Dworkplace\Login_client\AB\texture.assetbundle", option, BuildTarget.Android);BuildPipeline.PushAssetDependencies();BuildPipeline.BuildAssetBundle(null, obj2, @"D:\U3Dworkplace\Login_client\AB\objB.assetbundle", option, BuildTarget.Android);BuildPipeline.BuildAssetBundle(null, obj3, @"D:\U3Dworkplace\Login_client\AB\objC.assetbundle", option, BuildTarget.Android);BuildPipeline.PopAssetDependencies();BuildPipeline.PopAssetDependencies();}

这篇关于unity AssetBundle 使用方法1的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

C++使用栈实现括号匹配的代码详解

《C++使用栈实现括号匹配的代码详解》在编程中,括号匹配是一个常见问题,尤其是在处理数学表达式、编译器解析等任务时,栈是一种非常适合处理此类问题的数据结构,能够精确地管理括号的匹配问题,本文将通过C+... 目录引言问题描述代码讲解代码解析栈的状态表示测试总结引言在编程中,括号匹配是一个常见问题,尤其是在

Nginx设置连接超时并进行测试的方法步骤

《Nginx设置连接超时并进行测试的方法步骤》在高并发场景下,如果客户端与服务器的连接长时间未响应,会占用大量的系统资源,影响其他正常请求的处理效率,为了解决这个问题,可以通过设置Nginx的连接... 目录设置连接超时目的操作步骤测试连接超时测试方法:总结:设置连接超时目的设置客户端与服务器之间的连接

Java中String字符串使用避坑指南

《Java中String字符串使用避坑指南》Java中的String字符串是我们日常编程中用得最多的类之一,看似简单的String使用,却隐藏着不少“坑”,如果不注意,可能会导致性能问题、意外的错误容... 目录8个避坑点如下:1. 字符串的不可变性:每次修改都创建新对象2. 使用 == 比较字符串,陷阱满

Java判断多个时间段是否重合的方法小结

《Java判断多个时间段是否重合的方法小结》这篇文章主要为大家详细介绍了Java中判断多个时间段是否重合的方法,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录判断多个时间段是否有间隔判断时间段集合是否与某时间段重合判断多个时间段是否有间隔实体类内容public class D

Python使用国内镜像加速pip安装的方法讲解

《Python使用国内镜像加速pip安装的方法讲解》在Python开发中,pip是一个非常重要的工具,用于安装和管理Python的第三方库,然而,在国内使用pip安装依赖时,往往会因为网络问题而导致速... 目录一、pip 工具简介1. 什么是 pip?2. 什么是 -i 参数?二、国内镜像源的选择三、如何

使用C++实现链表元素的反转

《使用C++实现链表元素的反转》反转链表是链表操作中一个经典的问题,也是面试中常见的考题,本文将从思路到实现一步步地讲解如何实现链表的反转,帮助初学者理解这一操作,我们将使用C++代码演示具体实现,同... 目录问题定义思路分析代码实现带头节点的链表代码讲解其他实现方式时间和空间复杂度分析总结问题定义给定

IDEA编译报错“java: 常量字符串过长”的原因及解决方法

《IDEA编译报错“java:常量字符串过长”的原因及解决方法》今天在开发过程中,由于尝试将一个文件的Base64字符串设置为常量,结果导致IDEA编译的时候出现了如下报错java:常量字符串过长,... 目录一、问题描述二、问题原因2.1 理论角度2.2 源码角度三、解决方案解决方案①:StringBui

Linux使用nload监控网络流量的方法

《Linux使用nload监控网络流量的方法》Linux中的nload命令是一个用于实时监控网络流量的工具,它提供了传入和传出流量的可视化表示,帮助用户一目了然地了解网络活动,本文给大家介绍了Linu... 目录简介安装示例用法基础用法指定网络接口限制显示特定流量类型指定刷新率设置流量速率的显示单位监控多个

Java覆盖第三方jar包中的某一个类的实现方法

《Java覆盖第三方jar包中的某一个类的实现方法》在我们日常的开发中,经常需要使用第三方的jar包,有时候我们会发现第三方的jar包中的某一个类有问题,或者我们需要定制化修改其中的逻辑,那么应该如何... 目录一、需求描述二、示例描述三、操作步骤四、验证结果五、实现原理一、需求描述需求描述如下:需要在

JavaScript中的reduce方法执行过程、使用场景及进阶用法

《JavaScript中的reduce方法执行过程、使用场景及进阶用法》:本文主要介绍JavaScript中的reduce方法执行过程、使用场景及进阶用法的相关资料,reduce是JavaScri... 目录1. 什么是reduce2. reduce语法2.1 语法2.2 参数说明3. reduce执行过程