unity5打包机制下,一种资源打ab和资源管理的方案。
1.打ab:
  1.设置平台
  2.清楚所有资源的assetbundlename:
    string[] abNameArr = AssetDatabase.GetAllAssetBundleNames();
    AssetDatabase.RemoveAssetBundleName(abNameArr[i],true);
  3.创建ab目录
  4.根据配置把需要打包的资源找出来,对每一个setAbName
  5.调用BuildPipeline.BuildAssetBundles(ab文件夹路径,BuildAssetBundleOptions.DeterministicAssetBundle,EditorUserBuildSettins.activeBuildTarget);
  6.完成,但这里要对第4点做一些说明,因为依赖资源:
    我们可以选择一种简单粗暴的方式处理依赖资源:搞几个公共依赖assetbundle,把一些公共资源打到这几个公共ab中,具体就是:
    在第4步,我们设置一个资源的abName后,对其依赖进行:
      string[] deps = AssetDatabase.GetDependencies(sourcePath);
      if (deps[i] 需要打入公共依赖1)
      AssetImporter aIt = AssetImporter.GetAtPath(deps[i]);
      aIt.assetBundleName = 公共依赖1.assetBundle.
      if (deps[i] 需要打入公共依赖2)
      ...
    其他的依赖就不必继续分离了,即打到各个资源的ab里,虽然会增加ab的大小,但依赖资源管理会方便很多。
2.资源管理:
  先加载各个公共依赖到内存,并且一直引用这不unload,其他正式资源加载时自己加载对应的ab即可,无需加载依赖了。
具体代码如下:(启动游戏先加载公共依赖,一样的加载方式)

//原始资源引用

UnityEngine.Object m_ResGameObj = null;

//3个异步加载句柄:

//资源包加载句柄,引用www加载ab时结果

WWW m_LoadHandle = null;

//资源包加载请求,引用loadfromfileasync和loadfrommemoryasync的结果

AssetBundleCreateRequest m_Request = null;

//资源加载请求,引用loadassetasync结果

AssetBundleRequest m_AssetRequest = null;

//资源包,引用各种加载出来的资源包

AssetBundle m_AssetBundle = null;

//资源相对路径且没有后缀,作为基础路径,方便后续的各种拼接

public string V_AssetPath = null;//是否采用异步

public bool V_UseAsync = true;

//加载优先级

public int V_Priority = 0;

     /// <summary>

/// 加载图片只能用www方式

/// </summary>

/// <param name="path">绝对路径</param>

/// <returns></returns>

IEnumerator LoadBundleImpImage(string path)

{

m_LoadHandle = new WWW(PathHelper.GetInstance().F_AddFilePro(path));

yield return m_LoadHandle;

if (m_LoadHandle != null && string.IsNullOrEmpty(m_LoadHandle.error) && m_LoadHandle.assetBundle != null)

{

m_AssetBundle = m_LoadHandle.assetBundle;

string[] assets = m_AssetBundle.GetAllAssetNames();

m_ResGameObj = m_AssetBundle.LoadAsset(assets[0]);

}

else if (m_LoadHandle != null && string.IsNullOrEmpty(m_LoadHandle.error) && m_LoadHandle.texture != null)

{

m_ResGameObj = m_LoadHandle.texture;

}

if (m_LoadHandle != null) m_LoadHandle.Dispose();

m_LoadHandle = null;

}

/// <summary>

/// 加载资源imp

/// </summary>

/// <returns></returns>

IEnumerator LoadResImp()

{

ResourceRequest request = Resources.LoadAsync(V_AssetPath);

yield return request;

if (request != null && request.asset != null)

{

m_ResGameObj = request.asset;

}

m_AssetBundle = null;

}

     /// <summary>

/// 加载bundle

/// </summary>

/// <param name="path">绝对路径</param>

/// <returns></returns>

IEnumerator LoadBundleImp(string path)

{

m_Request = AssetBundle.LoadFromFileAsync(path);

yield return m_Request;

if (m_Request != null && m_Request.assetBundle != null)

{

m_AssetBundle = m_Request.assetBundle;

string[] assets = m_AssetBundle.GetAllAssetNames();

m_AssetRequest = m_AssetBundle.LoadAssetAsync(assets[0]);

yield return m_AssetRequest;

m_ResGameObj = m_AssetRequest.asset;

F_SendFinishEvent();

m_Request = null;

m_AssetRequest = null;

}

}

     //加载入口

     public void StartLoadAsset()

{

string absolutePath = GetPersistentAssetPath();

if (V_UseAsync)

{

string abPath = string.Empty;

if (PathHelper.GetInstance().F_CheckFileExists(absolutePath))

{

abPath = absolutePath;

}

if (abPath.EndsWith(PathHelper.ABFile))

{

AssetManager.GetInstance().StartCoroutine(LoadBundleImp(abPath));

}

else if (abPath.EndsWith(".jpg") || abPath.EndsWith(".png"))

{

AssetManager.GetInstance().StartCoroutine(LoadBundleImpImage(abPath));

}

else//加载安装包里的文件,或者编辑器下加载资源使用

{

AssetManager.GetInstance().StartCoroutine(LoadResImp());

}

}

else

{

//同步加载

try

{

if (m_ResGameObj == null)

{

m_AssetBundle = null;

if (AssetManager.GetInstance().F_IsLoadByAb() &&

absolutePath.EndsWith(PathHelper.ABFile))

{

m_AssetBundle = AssetBundle.LoadFromFile(absolutePath);

}

if (m_AssetBundle != null)

{

string[] assets = m_AssetBundle.GetAllAssetNames();

m_ResGameObj = m_AssetBundle.LoadAsset(assets[0]);

}

else

{

m_ResGameObj = Resources.Load(V_AssetPath);

}

}

}

catch

{

}

}

}

//原始资源引用        UnityEngine.Object m_ResGameObj = null;        //3个异步加载句柄:        //资源包加载句柄,引用www加载ab时结果        WWW m_LoadHandle = null;        //资源包加载请求,引用loadfromfileasync和loadfrommemoryasync的结果        AssetBundleCreateRequest m_Request = null;        //资源加载请求,引用loadassetasync结果        AssetBundleRequest m_AssetRequest = null;        //资源包,引用各种加载出来的资源包        AssetBundle m_AssetBundle = null;        //资源相对路径且没有后缀,作为基础路径,方便后续的各种拼接        public string V_AssetPath = null;//是否采用异步        public bool V_UseAsync = true;        //加载优先级        public int V_Priority = 0;     /// <summary>        /// 加载图片只能用www方式        /// </summary>        /// <param name="path">绝对路径</param>        /// <returns></returns>        IEnumerator LoadBundleImpImage(string path)        {            m_LoadHandle = new WWW(PathHelper.GetInstance().F_AddFilePro(path));            yield return m_LoadHandle;            if (m_LoadHandle != null && string.IsNullOrEmpty(m_LoadHandle.error) && m_LoadHandle.assetBundle != null)            {                m_AssetBundle = m_LoadHandle.assetBundle;                string[] assets = m_AssetBundle.GetAllAssetNames();                m_ResGameObj = m_AssetBundle.LoadAsset(assets[0]);            }            else if (m_LoadHandle != null && string.IsNullOrEmpty(m_LoadHandle.error) && m_LoadHandle.texture != null)            {                m_ResGameObj = m_LoadHandle.texture;            }            if (m_LoadHandle != null) m_LoadHandle.Dispose();            m_LoadHandle = null;        }
        /// <summary>        /// 加载资源imp        /// </summary>        /// <returns></returns>        IEnumerator LoadResImp()        {            ResourceRequest request = Resources.LoadAsync(V_AssetPath);            yield return request;            if (request != null && request.asset != null)            {                m_ResGameObj = request.asset;            }            m_AssetBundle = null;        }
     /// <summary>        /// 加载bundle        /// </summary>        /// <param name="path">绝对路径</param>        /// <returns></returns>        IEnumerator LoadBundleImp(string path)        {            m_Request = AssetBundle.LoadFromFileAsync(path);            yield return m_Request;            if (m_Request != null && m_Request.assetBundle != null)            {                m_AssetBundle = m_Request.assetBundle;                string[] assets = m_AssetBundle.GetAllAssetNames();                m_AssetRequest = m_AssetBundle.LoadAssetAsync(assets[0]);                yield return m_AssetRequest;                m_ResGameObj = m_AssetRequest.asset;                F_SendFinishEvent();                m_Request = null;                m_AssetRequest = null;            }        }
     //加载入口     public void StartLoadAsset()        {            string absolutePath = GetPersistentAssetPath();            if (V_UseAsync)            {                string abPath = string.Empty;                if (PathHelper.GetInstance().F_CheckFileExists(absolutePath))                {                    abPath = absolutePath;                }                if (abPath.EndsWith(PathHelper.ABFile))                {                    AssetManager.GetInstance().StartCoroutine(LoadBundleImp(abPath));                }                else if (abPath.EndsWith(".jpg") || abPath.EndsWith(".png"))                {                    AssetManager.GetInstance().StartCoroutine(LoadBundleImpImage(abPath));                }                else//加载安装包里的文件,或者编辑器下加载资源使用                {                    AssetManager.GetInstance().StartCoroutine(LoadResImp());                }            }            else            {                //同步加载                try                {                    if (m_ResGameObj == null)                    {                        m_AssetBundle = null;                        if (AssetManager.GetInstance().F_IsLoadByAb() &&                            absolutePath.EndsWith(PathHelper.ABFile))                        {                            m_AssetBundle = AssetBundle.LoadFromFile(absolutePath);                        }                        if (m_AssetBundle != null)                        {                            string[] assets = m_AssetBundle.GetAllAssetNames();                            m_ResGameObj = m_AssetBundle.LoadAsset(assets[0]);                        }                        else                        {                            m_ResGameObj = Resources.Load(V_AssetPath);                        }                    }                }                catch                {
                }            }        }

unity-------------------打包BuildAssetBundles的使用的更多相关文章

  1. 实力封装:Unity打包AssetBundle(大结局)

    →→前情提要:让用户选择要打包的文件←← 大结局:更多选择 Unity打包AssetBundle从入门到放弃系列终于要迎来大结局了[小哥哥表示实在写不动了o(╥﹏╥)o]... 经过上一次的教程,其实 ...

  2. UNITY 打包安卓APK

    1,安装JDK.这个直接下就行了. 2,安装android sdk相关.这个比较蛋疼,官网是被墙的.有些网站的包还是需要访问墙外下载的.关键是找对那个能用的包(对我来说就是不FQ). http://p ...

  3. unity 打包资源及网络请求资源包

    第一步 导包 在Assets新建一个Editor目录 新建一个Test类 using UnityEngine; using System.Collections; using UnityEditor; ...

  4. unity 打包apk安装失败

    Unity 打包Apk安装失败,错误提示:安卓未完成. 解决方案:检查BundleID是否一致

  5. SDK,JDk,Unity打包安卓apk

    SDK:软件开发工具包(缩写:SDK.外语全称:Software Development Kit)一般都是一些软件工程师为特定的软件包.软件框架.硬件平台.操作系统等建立应用软件时的开发工具的集合. ...

  6. unity打包iOS上线归纳

    1.去https://developer.apple.com登陆账号去生成打包用的签名文件,生成一个测试用的和一个上线发布用的签名文件 注意:签名文件绑定id必须和应用绑定包命一致,iOSapp唯一性 ...

  7. 实力封装:Unity打包AssetBundle(一)

    说明:这是一系列循序渐进的教程,今天先介绍最简单的AssetBundle打包方式. 这是一个由在Unity中需要加载模型而引发出来的一系列坑,为了填坑花了不少时间,如果有需要在Unity中自定义菜单, ...

  8. 实力封装:Unity打包AssetBundle(二)

    →前情提要:Unity最基本的AssetBundle打包方式. 第二种打包方式 Unity提供的BuildAssetBundles API还有一个重载形式,看下面↓↓ public static As ...

  9. Unity打包/读取AssetBundle资源全教程

    Unity 资源AssetBundle打包 本文提供全流程,中文翻译. Chinar 坚持将简单的生活方式,带给世人!(拥有更好的阅读体验 -- 高分辨率用户请根据需求调整网页缩放比例) Chinar ...

  10. Unity打包同一文件Hash不一样

    问题起因 游戏开发基本都会涉及到资源版本管理及更新,本文记录我在打包过程中遇到的一小问题: 开过中常用于标记资源版本的方法有计算文件Hash.VCS的版本等. 在Unity中对同一个资源文件进行多次打 ...

随机推荐

  1. Spark SQL编程指南(Python)【转】

    转自:http://www.cnblogs.com/yurunmiao/p/4685310.html 前言   Spark SQL允许我们在Spark环境中使用SQL或者Hive SQL执行关系型查询 ...

  2. VMWare ESX/ESXi 虚拟机硬盘的厚置备(Thick Provision)与精简置备(Thin Provision)的转换

    VMWare ESX/ESXi 有两种硬盘置备方式,厚制备(thick)和精简置备(Thin) 有时可能会由于性能问题或磁盘空间需要将虚拟机磁盘在两种模式间进行互转,虽然在虚拟机配置页面是没有办法修改 ...

  3. 组策略分发Adobe Reader 11教程

    1, 实验环境 域控:Windows Server 2012 R2 客户端:Windows 7 Adobe Reader 版本:11.0.00 2, 获取分发 Adobe Reader 的许可协议 按 ...

  4. C#学习笔记(10)——再谈委托,不同国家问候的例子

    说明(2017-6-14 09:08:38): 1. 首先是一个简单的委托 (1)命名空间下定义一个委托MyDel: public delegate void MyDel(string name); ...

  5. Java基础篇--字符串处理(StringBuffer)

    字符串处理 在Java中最常将字符串作为String类型对象来处理.同时String中也提供了很多操作字符串的函数(可自行查阅资料),而本篇将介绍StringBuffer如何操作字符串. String ...

  6. eclipse Maven项目Context root 为空,不能修改

    从SVN下载项目的时候,遇到过这种问题,导入下来的项目没有Context root 的名字,导致报错. 看了网上的解决办法,不行,于是研究了下,得出了解决办法,这里来记录一下. 先将Maven项目下载 ...

  7. C# if为false仍然进入方法体,==和qeual结果不一致

    场景: 代码: if( e.Key == Key.Tab) { // ... } 断点调试:结果为false,进入方法体   ??? 更改为: if(Key.Tab.Equals(e.key)) { ...

  8. C语言 · 和最大子序列

    算法提高 和最大子序列   时间限制:1.0s   内存限制:512.0MB      问题描述 对于一个给定的长度为N的整数序列A,它的“子序列”的定义是:A中非空的一段连续的元素(整数).你要完成 ...

  9. 设备接口体应用container_of的思考

    结构体应用container_of,可参考 container_of

  10. Ubuntu16.04怎么将桌面左侧的启动器移动到屏幕底部

    与其他 Linux 发行版不同,Ubuntu 多年来一直使用 Unity 做桌面环境,该环境的最突出特点就是桌面左侧有一个启动器栏(Launcher).从 16.04 版本开始,Ubuntu 提供了一 ...