Unity打包资源,进行后台加载
Unity打包资源,进行后台加载
需要项目优化的pa you,这边走:Unity项目优化——Web版
一、前言
因为在下载Three.js,所以趁着这个时间写一下资源打包加载吧
小黑在刚开始学习Unity的时候,一是通过教课老师上课讲的知识,二是在网上看一些教程,但里面总会提到,打成AB包。刚开始很好奇,这个AB包到底是什么东东!!!
直到我上班之后,才明白了解了,原来AB包又称为AssetBundle包,就是把一些资源放到后台去加载,但是具体流程是什么呢?这就是小黑今天要带给大家的知识咯。
二、正篇
如何打AB包,分为以下几步
一:把我们的模型拿到
在Unity的Porject中选择你所要打AB包的模型,在Inspector最下面会有模型视图小窗口,当模型还没被动手脚的时候是这样子:
动手后它变为下图所示:
二:模型部分已准备就绪了,接下来就是去打成AB包
1:在Unity中创建特殊文件夹:StreamingAssets
2:导入我们的脚本:PackagingAssetBundle.cs到Editor中
using System.Collections;
using System.Collections.Generic;
using UnityEditor;
using UnityEngine;
using System.IO;
public class PackagingAssetBundle : MonoBehaviour
{
[MenuItem("AssetBundle/Packaging")]
private static void PackageBuddle()
{
Debug.Log("Please wait while packing the asset package.....");
string packagePath = Application.dataPath+ "/StreamingAssets";
if (packagePath.Length <= 0 || !Directory.Exists(packagePath))
return;
Debug.Log("Output Path: " + packagePath);
BuildPipeline.BuildAssetBundles(packagePath,BuildAssetBundleOptions.None,BuildTarget.WebGL);
AssetDatabase.Refresh();
}
}
3:在编辑器上边点击AssetBundle\Packaging
1:
2:点击之后会出现
3:看下图,粉色框是打包时的提示,红色框是打包完成后的路径提示;
4:看StreamingAssets文件夹下:有两个文件
到现在,我们的AB包就算打出来了。可它怎么用呢,别着急,接下来就是去使用了;
三、动态加载
1:打开StreamingAssets文件夹
2:我们看到下图,把最大的这个 .unity3d文件给到公司后台,让他和你对接口,给你文档。
3:编写我们自己接收文件的的代码
using UnityEngine;
using System.Collections;
using System.Collections.Generic;
using System;
using LitJson;
using UnityEngine.Networking; //这个一定不能忘记
public class CS_Test : MonoBehaviour
{
void Start(){}
/// <summary> 用来存放模型在后台的路径 </summary>
public static List<string> LuJing = new List<string>();
/// <summary>
/// 与PHP后台做交互,取想到的模型,图片或者其他
/// </summary>
/// <param name="URL">获取访问模型路径,的一个路径</param>
/// <param name="requestDic">字典,key为:所要加载东西的标签或者什么的;value为:后台分辨的结果</param>
/// <param name="callBack">回调函数,可以为null</param>
/// <returns></returns>
public static IEnumerator OnGetInfo(string URL ,Dictionary<string, string> requestDic,Action<string> callBack)
{
//表单
WWWForm form = new WWWForm();
WWW www;
if (requestDic != null)
{
foreach (var item in requestDic)
form.AddField(item.Key, item.Value);
}
else
form.AddField("测试是否接通","1");
www = new WWW(URL, form);
yield return www;
if (www.error != null)
Debug.LogError("php请求错误,请检查出你的错误:" + www.error);
else
{
if (www.isDone && callBack != null)
callBack(www.text);
}
}
public static IEnumerator ABsCreatGameObject()
{
foreach (var item in LuJing)
{
WWW w = new WWW(item);
yield return w;
if (w.isDone)
{
GameObject[] objs = w.assetBundle.LoadAllAssets<GameObject>();
foreach (var isitem in objs)
{
GameObject go = Instantiate(isitem);
}
}
}
}
}
到这里,我们与后台交互的代码基本写完了。接下来我们需要去调用它。
4:调用我们的交互代码与后台要模型
using System.Collections;
using System.Collections.Generic;
using UnityEngine;
using LitJson;
public class CreateModel_ : MonoBehaviour {
private Dictionary<string, string> dic_CreateModel = new Dictionary<string, string>();
void Start ()
{
dic_CreateModel.Add("code或者和你们后台对接口", "给后台去对接口");
}
private bool isCreateBool = true;
void OnEnable()
{
if (isCreateBool)
{
StartCoroutine(CS_Test.OnGetInfo(ToPHPData.DownURL,dic_CreateModel, (string s) =>
{
JsonData data = JsonMapper.ToObject(s);
CS_Test.LuJing.Clear();
for (int i = 0; i < 5; i++)
CS_Test.LuJing.Add(ToPHPData.DownURL + data["data"][i]["model"].ToString());
if (CS_Test.LuJing.Count != 0)
StartCoroutine(CS_Test.ABsCreatGameObject());
}));
}
}
}
/*
* ok,当我们的该脚本每被激活一次,就会向后台要一次模型并且加载出来,可根据你需要的改写
*/
5:看结果去咯~
1:我们刚运行程序,所以我们的小无人机还没有出现,等1s不到~
2:1s不到的时间,我们的无人机出现了,并且出现在我们的层级面板
不过有一点大家要注意,就是我们的模型通过后台加载进来之后,名字后方都有 (Clone) 的字样,在使用模型的时候,肯定要查找,不能把这个忘了
于是乎,我们与后台交互拿模型,数据什么的就大功告成啦!
我们与后台交互拿模型,数据什么的就大功告成啦!
大功告成啦!
成啦!
记得点赞哟!也可以转发给需要的伙伴们
程序的道路上学习永不停止,探索随时进行。
Let’s go. Just do it. We can.
Unity打包资源,进行后台加载的更多相关文章
- 【Cocos2d-Js基础教学(5)资源打包工具的使用及资源的异步加载处理】
TexturePacker是纹理资源打包工具,支持Cocos2dx的游戏资源打包. 如果用过的同学可以直接看下面的资源的异步加载处理 首先为什么用TexturePacker? 1,节省图片资源实际大小 ...
- UNITY_资源路径与加载外部文件
UNITY_资源路径与加载外部文件 https://www.tuicool.com/articles/qMNnmm6https://blog.csdn.net/appppppen/article/de ...
- 高效使用Bitmaps(二) 后台加载Bitmap
转载:http://my.oschina.net/rengwuxian/blog/183802 为什么要在后台加载Bitmap? 有没有过这种体验:你在Android手机上打开了一个带有含图片的Lis ...
- Unity3d Web3d资源的动态加载
Unity3d Web3d资源的动态加载 @灰太龙 参考了宣雨松的博客,原文出处http://www.xuanyusong.com/archives/2405,如果涉及到侵权,请通知我! Unity3 ...
- Unity+NGUI打造网络图片异步加载和本地缓存工具(一)
我们已经开发了在移动终端中,异步网络图片被装入多,在unity其中尽管AssetBundle存在,通常第一个好游戏的资源,然后加载到现场,但也有很多地方可以使用异步网络加载图像以及其缓存机制. 我也写 ...
- Webpack 常见静态资源处理 - 模块加载器(Loaders)+ExtractTextPlugin插件
Webpack 常见静态资源处理 - 模块加载器(Loaders)+ExtractTextPlugin插件 webpack系列目录 webpack 系列 一:模块系统的演进 webpack 系列 二: ...
- 【UE4 C++ 基础知识】<11>资源的同步加载与异步加载
同步加载 同步加载会造成进程阻塞. FObjectFinder / FClassFinder 在构造函数加载 ConstructorHelpers::FObjectFinder Constructor ...
- 背水一战 Windows 10 (11) - 资源: CustomResource, ResourceDictionary, 加载外部的 ResourceDictionary 文件
[源码下载] 背水一战 Windows 10 (11) - 资源: CustomResource, ResourceDictionary, 加载外部的 ResourceDictionary 文件 作者 ...
- HTML页面处理以及资源文件的加载
Javascript 异步加载详解 这篇文章很详细的介绍了HTML的页面处理以及资源文件的加载. 本文总结一下浏览器在 javascript 的加载方式. 关键词:异步加载(async loading ...
- thinkphp 的两种建构模式 第一种一个单入口里面定义两个模块,前台和后台,函数控制模块必须function.php前台加载前台模块的汉书配置文件,后台加载后台模块的汉书配置文件,公共文件共用。第二种架构模式两个单入口文件,分别生成两个应用定义define。。。函数可以定义配置文件。。。。
thinkphp 的两种建构模式 第一种一个单入口里面定义两个模块,前台和后台,函数控制模块必须function.php前台加载前台模块的汉书配置文件,后台加载后台模块的汉书配置文件,公共文件共用. ...
随机推荐
- 安装nvm 和 yarn
安装nvm curl -o- https://raw.githubusercontent.com/nvm-sh/nvm/v0.39.1/install.sh | bash 执行上面的命令 如果出现问题 ...
- Python基础部分:4、 python语法之注释
目录 一.python语法之注释 1.什么是注释 2.如何编写注释 二.PEP8规范 一.python语法之注释 1.什么是注释 注释用来向用户提示或解释某些代码的作用和功能,它可以出现在代码中的任何 ...
- Oracle数据泵导入dmp文件,报ORA-39083、ORA-01917错误解决办法
将10.16.23.111数据库服务器中的数据库名称为cwy_init1的数据导出,随后在10.16.23.112数据库服务器创建空库cwy_init2,将导出的cwy_init1数据文件(cwy_i ...
- [leetcode] 713. Subarray Product Less Than K
题目 Given an array of integers nums and an integer k, return the number of contiguous subarrays where ...
- docker和docker-compose便捷安装
安装docker: curl -fsSL get.docker.com -o get-docker.sh&&sh get-docker.sh 或: curl -sSL https:// ...
- 在Linux配置git
生成ssh ssh-keygen -t rsa 可以不设置密码,一路回车就行,会在 ~/.ssh/下生成两个ssh key: ssh-add ~/.ssh/id_rsa.pub 这一步是使用刚才生成那 ...
- 【Spark】Day01-入门、模块组成、4种运行模式详解及配置、案例实操(spark分析过程)
一.概述 1.概念 基于内存的大数据分析计算引擎 2.特点 快速.通用.可融合性 3.Spark内置模块[腾讯8000台spark集群] Spark运行在集群管理器(Cluster Manager)上 ...
- Vue 打包报错UnhandledPromiseRejectionWarning: postcss-svgo: Error in parsing SVG
解决方案 检查下自己最新写的css 或者最新引入的样式库,把里面的base64的url替换成双引号形式的 PS:我这报错是因为引入的weui.min.css里面的loading样式的`backgrou ...
- Android-helloword
环境早已配置完毕,就是后来选择API的时候出现了一点问题,唉,追求时尚,选择最新版本的API,结果就悲剧了,跑不起来,也找不到原因.后来换成Android 4.22 17API Level就行了... ...
- 回顾Vue计算属性VS其他语法有感
回顾Vue计算属性VS其他语法有感 重新回顾官方教程中的到计算属性和侦听器,发觉获益良多,主要就是两点: 计算属性和其他语法的比较 计算属性.侦听属性.方法.模板变量的使用 计算属性和其他语法的比较 ...