AssetBundle资源打包与加载
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资源打包与加载的更多相关文章
- Unity3D AssetBundle的打包与加载
在Unity项目开发过程中,当要做热更新时常常使用一个叫做AssetBundle的东西,这里做一点个人的学习记录 步骤1: 设置打包标签:具体步骤----进入Unity,选择某一资源然后看右下角,在那 ...
- u3d外部资源 打包与加载的问题
被坑了一下午,调bug,u3d外部加载资源一会可以,一会不行,始终找不到问题,最后快下班的时候,重新试了一下,原来是资源打包之前的文件名,和之后的加载资源名必须一样 [MenuItem("C ...
- Unity5 AssetBundle 打包以及加载
using UnityEngine; using System.Collections; using System.Collections.Generic; using UnityEditor; us ...
- KEngine:Unity3D资源的打包、加载、调试监控
资源模块做什么? 资源模块——ResourceModule,是KEngine中最核心的模块,其他模块基本或多或少的对它有依赖,它主要的功能是:资源打包.路径定义.资源管理.资源调试. 资源模块对Uni ...
- [Unity] unity5.3 assetbundle打包及加载
Unity5.3更新了assetbundle的打包和加载api,下面简单介绍使用方法及示例代码. 在Unity中选中一个prefab查看Inspector窗口,有两个位置可以进行assetbundle ...
- 【Cocos2d-Js基础教学(5)资源打包工具的使用及资源的异步加载处理】
TexturePacker是纹理资源打包工具,支持Cocos2dx的游戏资源打包. 如果用过的同学可以直接看下面的资源的异步加载处理 首先为什么用TexturePacker? 1,节省图片资源实际大小 ...
- Unity3d Web3d资源的动态加载
Unity3d Web3d资源的动态加载 @灰太龙 参考了宣雨松的博客,原文出处http://www.xuanyusong.com/archives/2405,如果涉及到侵权,请通知我! Unity3 ...
- UNITY_资源路径与加载外部文件
UNITY_资源路径与加载外部文件 https://www.tuicool.com/articles/qMNnmm6https://blog.csdn.net/appppppen/article/de ...
- Unity5.4新版AssetBundle资源打包
(1)新版本 唯一打包API Buildpipeline.BuildAssetBundle (2)在资源的Inpector界面最下方可设置该资源的assetbundleName, 每个assetbun ...
随机推荐
- P5357 【模板】AC自动机(二次加强版)
思路 这题可以同时作为AC自动机和SAM的模板啊喂 AC自动机 对T建出AC自动机,把S在上面匹配,然后记录每个点被经过的次数,最后统计一次即可(暴力跳fail的复杂度是不对的) SAM 对S建出SA ...
- flask学习导航主页
我就学习了网易课堂的知了Flaskk. 十分感谢. └—01-Flask视图和URL ├—课时001.[Flask预热]课程介绍 ├—课时002.[Flask预热]Flask课程准备工作 ├—课时00 ...
- 有关 C# WebAPI知识
1.[懒得安分博客总结的很全面] 2.关于基础类型作入参数的问题 参照此博客[ASP.NET WebAPI String 传值问题] 3.代码说明 using System; usi ...
- react-native-pg-utils(对react-native全局进行配置,对内置对象原型链增加方法,增加常用全局方法.)
react-native-pg-utils 对react-native全局进行配置,对内置对象原型链增加方法,增加常用全局方法. 每次新建react-native项目之后都会发现有一些很常用的方法在这 ...
- java+http文件夹上传
在web项目中上传文件夹现在已经成为了一个主流的需求.在OA,或者企业ERP系统中都有类似的需求.上传文件夹并且保留层级结构能够对用户行成很好的引导,用户使用起来也更方便.能够提供更高级的应用支撑. ...
- 路由器配置——OSPF协议(2)
一.实验目的:使用OSPF协议达到全网互通的效果 二.拓扑图 三.具体步骤配置 (1)R1路由器配置 Router>enableRouter#configure terminalEnter co ...
- 数据结构实验之链表九:双向链表(SDUT 2054)
#include <bits/stdc++.h> using namespace std; typedef struct node { int data; struct node *nex ...
- PHP开发框架CI——学习小记
之前做后端开发的时候,因为都是很小的功能或项目,所以基本都是手写原生php.不过这样的开发效率在面对稍大一些的项目的时候是比较低的.因此花时间学习一下php相关框架CI的使用. MVC架构 在学习CI ...
- HTML5调用本地摄像头画面,拍照,上传服务器
实现功能和适用业务 采集本地摄像头获取摄像头画面,拍照保存,上传服务器: 前端上传图片处理,展示,缩小,裁剪,上传服务器 实现步骤 调取本地摄像头(getUserMedia)/上传图片,将图片/视频显 ...
- C/C++程序基础-如何理解C++是面向对象化的,而C是面向过程化的
1:答:C是面向过程化的,但是C++不是完全面向对象化的.在C++中也完全可以写出与C一样过程化的程序,所以只能说C++拥有面向对象的特性.Tava是真正面向对象化的.