AssetBundle资源打包

 1.AssetLabels资源标签

  文件名:资源打包成AssetBundle后的文件名,类似于压缩包的名字
  后缀:自定义
  文件名和后缀名都是小写格式(大写会自动转为小写)
2. BuildPipeline.BuildAssetBundles(string outputPath, BuildAssetBundleOptions assetBundleOptions, BuildTarget targetPlatform) 打包所有设置了AssetLabel的资源
  outputPath:路径,打包出来的AssetBunlde文件存放的位置
  BuildAssetBundleOptions:选项,设置AssetBundle打包过程中压缩方式

    BuildAssetBundleOptions枚举选项:

      None使用LZMA压缩算法进行压缩,打包后资源体积最小
      UncompressedAssetBundle不压缩,打包后的AssetBundle体积最大,但是加载速度最快
      ChunkBasedCompression使用LZ4压缩算法进行压缩,打包后的AssetBundle体积和加载速度介于上面二者之间
  BuildTarget:平台,AssetBundle是平台之间不兼容的,IOS,Android是两套资源

  
在AssetLabels区域填写AssetBundle名称的时候,名称是可以分目录嵌套的:文件夹名/文件名

AssetBundle打包后的资源包,分两部分组成:

  1.资源打包出来的AssetBundle文件
  2.AssetBundle文件配套的manifest文本文件

manifest文件

manifest文件用于专门存储打包后的AssetBundle文件的基本信息,主要包含:
  CRC校验码:类似于MD5,用于计算出该资源的一个特殊信息标示
  ClassTypes列表:当前资源关联使用到了Unity中的哪些类,这些类是以编号索引的形式存在的,每个编号都对应一个类文件
  Assets:AssetsBundle里包含了哪些资源文件
  Dependencies:依赖

在打包出来的AssetBundle文件中,有一个特殊的manifest文件,和AssetBundle存放的文件夹同名,且只在根文件夹下有唯一的一个

这个manifest文件可以称作"AssetBundle目录文件",它存储了打包出来的所有AssetBundle的文件的索引信息
通过这个目录文件,可以找到所有的AssetBundle文件

AssetBundle资源加载

将项目资源打包成AssetBundle后,一般有两种操作

一.将这些AssetBundle留着项目工程中,当成普通资源使用

  1.加载AssetBundle资源到内存

    AssetBundle ab =  AssetBundle.LoadFromFile("路径");加载AssetBundle资源到内存,返回一个AssetBundle对象

        2.从AssetBundle中获取资源

    T res = ab.LoadAsset<T>("资源名");

   3.实例化

打包

[MenuItem("xx/xxx")]
public static void Build_WINDOWS64()
{
  string outputPath = Path.Combine(Application.streamingAssetsPath, "Data");
  if (!Directory.Exists(outputPath))
    Directory.CreateDirectory(outputPath);   BuildPipeline.BuildAssetBundles(outputPath, BuildAssetBundleOptions.None, BuildTarget.StandaloneWindows64);//自己选择平台
  AssetDatabase.Refresh();
}

加载

using System.Collections;
using System.Collections.Generic; public class AssetBundleManager
{
private readonly string _path = UnityEngine.Application.streamingAssetsPath + "/Data/";
private static AssetBundleManager _instance;
private bool mIsLoadingEnd = false;
public bool IsLoadingEnd { get { return mIsLoadingEnd; } }
private List<string> mLoadingNames;
private Dictionary<string, UnityEngine.Object> mAssets;
private Dictionary<string, UnityEngine.Texture2D> mTexture2Ds; public static AssetBundleManager GetInstance()
{
if (_instance == null)
{
_instance = new AssetBundleManager();
}
return _instance;
} private AssetBundleManager()
{
mLoadingNames = new List<string>(){
//todo:要加载的资源名
}; mAssets = new Dictionary<string, UnityEngine.Object>();
mTexture2Ds = new Dictionary<string, UnityEngine.Texture2D>();
} /// <summary>
/// 加载assetsbundle
   /// 记得先加载到内存StartCoroutine(AssetBundleManager.GetInstance().Loading());
/// </summary>
public IEnumerator Loading()
{
foreach (var nameAndType in mLoadingNames)
{
string filename = _path + nameAndType.ToLower();
UnityEngine.AssetBundleCreateRequest request = UnityEngine.AssetBundle.LoadFromFileAsync(filename);
yield return request;
LoadAsset(request.assetBundle);
}
mIsLoadingEnd = true;
} private UnityEngine.AssetBundle LoadAssetBundle(string fileName)
{
UnityEngine.AssetBundle AB = UnityEngine.AssetBundle.LoadFromFile(_path + fileName);
return AB;
} private void LoadAsset(UnityEngine.AssetBundle ab)
{
UnityEngine.Object[] assets = ab.LoadAllAssets();
for (int i = ; i < assets.Length; i++)
{
//一张图片的AssetsBundle包含自身Texture2D和它里面全部Sprite,有可能重名
if (!typeof(UnityEngine.Texture2D).Equals(assets[i].GetType()))
mAssets.Add(assets[i].name, assets[i]);
else
mTexture2Ds.Add(assets[i].name, assets[i] as UnityEngine.Texture2D);
}
} /// <summary>
/// 从assetbundle获取texture2d
/// </summary>
public UnityEngine.Texture2D GetTexture2D(string name)
{
UnityEngine.Texture2D obj;
mTexture2Ds.TryGetValue(name, out obj);
return obj;
} /// <summary>
/// 从assetbundle获取Object
/// </summary>
public UnityEngine.Object GetAsset(string name)
{
UnityEngine.Object obj;
mAssets.TryGetValue(name, out obj);
return obj;
}
}

二.将这些AssetBundle上传服务器,客户端第一次运行时从服务器下载AssetBundle缓存到本地再使用(实现客户端的安装包与资源分离,降低客户端安装包的体积)

 1.服务器端下载主文件

    从服务器端下载AssetBundle需要web路径地址,每一个地址对应一个AssetBundle文件.我们不可能在代码中写几十上百个文件的web地址,所以我们需要先下载"目录AssetBundle文件",然后通过它来间接获取其他AssetBundle文件的下载路径地址.

需要引入命名空间using UnityEngine.Networking;

using System.Collections;
using System.IO;
using UnityEngine;
using UnityEngine.Networking; public class TestAssetBundle : MonoBehaviour
{
private string mainAssetBundleURL = @"http://www.xxx.com.xxx/AssetBundleFile";
private string allAssetBundleURL = @"http://www.xxx.com.xxx/"; void Start()
{
StartCoroutine(DownloadMainAssetBundle());
} /// <summary>
/// 下载目录AssetBundle文件
/// </summary>
IEnumerator DownloadMainAssetBundle()
{
//创建一个获取AssetBundle文件的web请求
UnityWebRequest request = UnityWebRequestAssetBundle.GetAssetBundle(mainAssetBundleURL); //发送web请求
yield return request.SendWebRequest(); //从请求中获取内容,返回AssetBundle类型的数据
AssetBundle ab = DownloadHandlerAssetBundle.GetContent(request); //从"目录AssetBundle"中获取manifest数据
AssetBundleManifest manifest = ab.LoadAsset<AssetBundleManifest>("AssetBundleManifest"); //获取manifest文件中所有的AssetBundle的名称信息
string[] names = manifest.GetAllAssetBundles(); foreach (var name in names)
{
StartCoroutine(DownloadAssetBundleAndSave(allAssetBundleURL + name));
}
} /// <summary>
/// 下载AssetBundle并保存到本地
/// </summary>
IEnumerator DownloadAssetBundleAndSave(string url)
{
UnityWebRequest request = UnityWebRequest.Get(url);
yield return request.SendWebRequest();
// 截取路径地址中的文件名(需要引入System.IO)
string fileName = Path.GetFileName(url);
SaveAssetBundle(fileName, request.downloadHandler.data);
} /// <summary>
/// 存储AssetBundle为本地文件
/// </summary>
private void SaveAssetBundle(string fileName, byte[] bytes)
{
//创建一个文件信息对象(System.IO)
FileInfo fileInfo = new FileInfo(Application.streamingAssetsPath + "//" + fileName); //创建一个文件流对象
FileStream fs = fileInfo.Create(); //通过文件流对象,往文件内写入信息
fs.Write(bytes, , bytes.Length); //文件写入存储到硬盘
fs.Flush(); //关闭文件流对象
fs.Close(); //销毁文件对象
fs.Dispose();
}
}

AssetBundle资源打包与加载的更多相关文章

  1. Unity3D AssetBundle的打包与加载

    在Unity项目开发过程中,当要做热更新时常常使用一个叫做AssetBundle的东西,这里做一点个人的学习记录 步骤1: 设置打包标签:具体步骤----进入Unity,选择某一资源然后看右下角,在那 ...

  2. u3d外部资源 打包与加载的问题

    被坑了一下午,调bug,u3d外部加载资源一会可以,一会不行,始终找不到问题,最后快下班的时候,重新试了一下,原来是资源打包之前的文件名,和之后的加载资源名必须一样 [MenuItem("C ...

  3. Unity5 AssetBundle 打包以及加载

    using UnityEngine; using System.Collections; using System.Collections.Generic; using UnityEditor; us ...

  4. KEngine:Unity3D资源的打包、加载、调试监控

    资源模块做什么? 资源模块——ResourceModule,是KEngine中最核心的模块,其他模块基本或多或少的对它有依赖,它主要的功能是:资源打包.路径定义.资源管理.资源调试. 资源模块对Uni ...

  5. [Unity] unity5.3 assetbundle打包及加载

    Unity5.3更新了assetbundle的打包和加载api,下面简单介绍使用方法及示例代码. 在Unity中选中一个prefab查看Inspector窗口,有两个位置可以进行assetbundle ...

  6. 【Cocos2d-Js基础教学(5)资源打包工具的使用及资源的异步加载处理】

    TexturePacker是纹理资源打包工具,支持Cocos2dx的游戏资源打包. 如果用过的同学可以直接看下面的资源的异步加载处理 首先为什么用TexturePacker? 1,节省图片资源实际大小 ...

  7. Unity3d Web3d资源的动态加载

    Unity3d Web3d资源的动态加载 @灰太龙 参考了宣雨松的博客,原文出处http://www.xuanyusong.com/archives/2405,如果涉及到侵权,请通知我! Unity3 ...

  8. UNITY_资源路径与加载外部文件

    UNITY_资源路径与加载外部文件 https://www.tuicool.com/articles/qMNnmm6https://blog.csdn.net/appppppen/article/de ...

  9. Unity5.4新版AssetBundle资源打包

    (1)新版本 唯一打包API Buildpipeline.BuildAssetBundle (2)在资源的Inpector界面最下方可设置该资源的assetbundleName, 每个assetbun ...

随机推荐

  1. NSURLSession使用说明及后台工作流程分析

    原文摘自http://www.cocoachina.com/industry/20131106/7304.html NSURLSession是iOS7中新的网络接口,它与咱们熟悉的NSURLConne ...

  2. 浏览器判断是否安装APP

    浏览器判断是否安装APP http://blog.csdn.net/henrywulibin/article/details/52087041 从浏览器中打开我们的应用 http://blog.csd ...

  3. Android和SQLite版本对应关系

    Android和SQLite版本对应关系 今天Xamarin群有人问到Android和SQLite版本如何对应,顺手查了一下,贴出来. SQLite 3.8.4.3: • 21-5.0-Lollipo ...

  4. WPF:依赖属性的数据绑定

    One of the strengths of WPF is its data binding capabilities. Although data binding is not new (in f ...

  5. unity, 非public变量需要加[SerializeField]才能序列化

    非public变量需要加[SerializeField]才能序列化 例如: MonoBehaviour中: [SerializeField] private float m_xxx; 在相应的Cust ...

  6. CFileDialog使用总结

    http://blog.csdn.net/tianhai110/article/details/2055149 CFileDialog经常用,但经常忘,现归纳整理下,方便今后查询. 例子: CFile ...

  7. [转载]用c写PHP的扩展接口(php5,c++)

    原文[http://bugs.tutorbuddy.com/php5cpp/php5cpp/] 第1节. 开始之前 开始前,我要说明:这篇文章所描述的主要是在UNIX的PHP环境上的. 另外一点我要说 ...

  8. ThreadLocal源码分析:(二)get()方法

    在ThreadLocal的get(),set()的时候都会清除线程ThreadLocalMap里所有key为null的value. 而ThreadLocal的remove()方法会先将Entry中对k ...

  9. net core体系-Standard-1概述

    前言 早上起来.NET社区沸腾了,期待已久的.NET Core 2.0终于发布!根据个人经验,微软的产品一般在2.0时会趋于成熟,所以一个新的.Net开发时代已经来临!未来属于.NET Core. . ...

  10. mui的switch开关的应用

    HTML: <!--mui的switch开关--> <div class="mui-content-padded"> <h5>switch开关m ...