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. (原创)C++11改进我们的程序之简化我们的程序(四)

    这次要讲的是:c++11统一初始化.统一begin()/end()和for-loop循环如何简化我们的程序 初始化列表 c++11之前有各种各样的初始化语法,有时候初始化的时候还挺麻烦,比较典型的如v ...

  2. 每日英语:5 Things to Know About Missing Malaysia Airlines Flight and Air Safety

    Malaysia Airlines Flight MH370, with 239 people aboard, lost contact early Saturday with the airline ...

  3. android Socket 编程

    Socket 通信 1.UDP实现  (DatagramSocket) [客户端] //首先创建一个DatagramSocket对象 DatagramSocket socket = new Datag ...

  4. Docker 入门(Mac环境)- part 5 stacks

    part-5 stacks 简介 stack就是栈,栈的结构是什么样的呢?一层一层是紧挨着的,然后互相依赖,不能说中间少了一个.这样说就很明白了,栈实际上在docker中就相当于多个互相依赖的组件,共 ...

  5. django中使用POST方法 获取POST数据

    在django中获取post数据,首先要规定post发送的数据类型是什么. 1.获取POST中表单键值数据 如果要在django的POST方法中获取表单数据,则在客户端使用JavaScript发送PO ...

  6. 域控制器修改IP操作步骤

    域控制器更改IP 在DC运维时,可能会碰上需要调整域控制器IP的情况,下面的操作就是在Windows Server 2008环境下域控制器更改IP的完整操作步骤. 1. 使用管理员帐号登录域控制器,依 ...

  7. mysql 添加外键时 error 150 问题总汇

    当你试图在mysql中创建一个外键的时候,这个出错会经常发生,这是非常令人沮丧的.像这种不能创建一个.frm 文件的报错好像暗示着操作系统的文件的权限错误或者其它原因,但实际上,这些都不是的,事实上, ...

  8. S3C2440的七种模式之——未定义模式(去掉bl print1 bug解决)

    现在做第一个实验,模拟未定义模式. 未定义模式,是cpu遇到自己不能识别的指令时候做出的异常处理. arm指令的机器码一定是按照某种规范要求的,不然你随意写一条指令,cpu不是都可以执行吗?在cpu没 ...

  9. eclipse中git插件使用

    1,首先看下文件的几个工作区:Unstaged Changes(本地工作空间),Staged Changes(Add to Index操作之后代码存放的地方),Local Repository(本地仓 ...

  10. xorm的sql builder

    最近在使用xorm,并使用了sql builder来构建sql查询没想到升级后原来可以使用的代码居然报错了. 0x00 代码 sql, args, _ := builder.Select(" ...