RFrameword Unity的资源加载框架

GitHub链接

1,将RealFram/FramePlug/RFramework 拖到自己游戏的初始场景
2,ab包配置方式:(主要分为两种配置方式)
打开RealFram/Edtior/Resource/ABConfig(分别为AllPrefabPath与AllFileDirAB) AllPrefabPath为prefab文件夹路径,可以设置多个,最终编辑器会去根据文件夹查找里面所有的Prefab去计算依赖打包(注意不要出现同名Prefab,因为每个prefab会单独根据prefab名字打包ab包) AllFileDirAB为单个文件夹ab包设置,设置的时候需要设置ab包名与ab包对应文件夹路径(如:data Asset/RealFram/Data/Binary) 设置好之后打包就会根据设置自动筛选及自动设定ab包,进行打包,默认打包在Assets同目录根据不同平台所生成的文件夹下面(不会生成在Asset目录里面,打包apk等时,工具会根据平台自动拷贝ab包到StreamingAssets目录,如果热更或者初始包问题可自行更改代码 BuildApp 与 BundleEditor)。

3,资源加载代码使用:
1)同步资源加载:
ResourceManager.Instance.LoadResource(path)
泛型方法,path为资源的Unity工程相对路径,如: Assets/Data/image.png;。此方法加载不需要实例化的资源,如图片,asset,音频等资源文件。

示例:
TextAsset text = ResourceManager.Instance.LoadResource(MAINLUAPATH);
2)异步资源加载:
ResourceManager.Instance.AsyncLoadResource(string path, OnAsyncObjFinish dealfinish, LoadResPriority priority, object param1 = null, object param2 = null, object param3 = null, uint crc = 0, bool bsprite = false)
异步资源加载函数,此方法加载不需要实例化的资源,如图片,asset,音频等资源文件。 path为资源的Unity工程相对路径,如: Assets/Data/image.png; dealfinish 为加载回调;priority为加载优先级;param1,param2,param3 为参数,可以向回调传递参数。 crc为资源路径计算出来的crc,如果计算了crc那么就会强制根据crc查找,不然会根据路径进行查找资源。bsprite为是否是图片,因为异步资源加载图片有特殊转换。

void OnAsyncObjFinish(string path, Object obj, object param1 = null, object param2 = null, object param3 = null)
回调函数写法,都是由上面异步加载传递下来的 ```示例: ResourceManager.Instance.AsyncLoadResource(path, OnLoadSpriteFinish, LoadResPriority.RES_MIDDLE, image, setNativeSize);

回调函数:
void OnLoadSpriteFinish(string path, Object obj, object param1 = null, object param2 = null, object param3 = null)
{
if (obj != null)
{
Sprite sp = obj as Sprite;
Image image = param1 as Image;
if (m_AllSpriteDic.ContainsKey(image))
{
ResourceManager.Instance.ReleaseResource(image.sprite);
}
m_AllSpriteDic[image] = sp;
bool setNativeSize = (bool)param2;
if (image.sprite != null)
image.sprite = null;

    image.sprite = sp;
    if (setNativeSize)
    {
        image.SetNativeSize();
    }
}

}

3)释放资源:
ResourceManager.Instance.ReleaseResource(Object obj, bool destoryObj = false)  
同步资源加载的释放方法,obj参数为加载资源的引用;destoryObj为是否完全释放改资源。

ResourceManager.Instance.ReleaseResource(string path, bool destoryObj = false) 
同步资源加载的释放方法,path参数为加载资源的路径;destoryObj为是否完全释放改资源。

示例:
ResourceManager.Instance.ReleaseResource(m_Image.sprite, true);
4)预加载资源:
ResourceManager.Instance.PreloadResource(string path) 
预加载资源,主要传入路径即可进行预加载。

示例:
ResourceManager.Instance.PreloadResource(MAINLUAPATH);
5)同步实例化gameobject
ObjectManager.Instance.InstantiateObject(string resPath, bool setSceneObject = false, ResourceType resType = ResourceType.NONE, bool bClear = true)  
同步gameobject加载,resPath为prefab路径;setSceneObject为是否放到Scene节点下面;resType资源类型;bClear为是否跳场景清除。

示例:
GameObject obj =  ObjectManager.Instance.InstantiateObject(ConstantString.DuihuanItem);
6)异步实例化gameobject
ObjectManager.Instance.InstantiateObjectAsync(string resPath, OnAsyncObjFinish dealFinish, LoadResPriority priority,
      ResourceType resType = ResourceType.NONE, bool setSceneObject = false,object param1 = null, 
      object param2 = null, object param3 = null, bool bClear = true, bool bCancle = true)
异步gameobject加载,resPath为prefab路径;dealFinish为加载回调;priority为加载优先级;resType为加载类型;setSceneObject为是否放到Scene节点下面;resType资源类型;param1,param2,param3 为参数,可以向回调传递参数;bClear为是否跳场景清除;bCancle为是否可以取消加载。

void OnAsyncObjFinish(string path, Object obj, object param1 = null, object param2 = null, object param3 = null)
回调函数写法,都是由上面异步加载传递下来的

示例:
ObjectManager.Instance.InstantiateObjectAsync(m_CurrentSetting.SceneFX, OnMapEffectLoadFinish, LoadResPriority.RES_HIGHT);

回调函数:
private void OnMapEffectLoadFinish(string path, UnityEngine.Object obj, object param1 = null, object param2 = null, object param3 = null)
{
    m_CurrentFXPrefab = obj as GameObject;
}
7)卸载gameobject
ObjectManager.Instance.ReleaseObject(GameObject obj, int iMaxCacheCount = -1, bool bDestroyCacheResource = false, bool bRecycleParent = true)
参数obj为实例化的gameobject引用;iMaxCacheCount为缓存最大个数,-1代表无限;bDestroyCacheResource为是否清除缓存;bRecycleParent为是否放回回收节点,如果不放回自动Setactive为false,一般用于UI的prefab释放,减少setparent操作。

示例:
ObjectManager.Instance.ReleaseObject(gameObject);
7)预加载gameobject
ObjectManager.Instance.PreloadGameObject(string resPath, int count = 1, bool clear = false)
预加载gamobject,resPath为Prefab路径;count为预加载个数;clear为跳场景是否清除。

示例:
ObjectManager.Instance.PreloadGameObject(ConstantString.CardPath, 40);
8)跳场景时对缓存的清除
ObjectManager.Instance.ClearCache();
ResourceManager.Instance.ClearCache();
调用这两个函数,在资源加载的时候有参数来确定某些资源或者Prefab跳场景是否清除,如果不清除,将常驻内存,方便快速加载。

9)关于离线数据的使用
目前离线数据有UI离线数据及特效离线数据,主要用于实例化的gameobject从对象池取出时还原原本结构(当然,如果很复杂的结果还原难以做到,需要使用者自己根据情况还原,基本的还原类型都有,也可以去拓展UIOfflineData与EffectOfflineData或者继承OfflineData去写新的离线数据还原) 操作方法,选中Prefab右键生成对应的离线数据,此功能还可以拓展缓冲gameobject的任何组件,避免代码中经常出现getcompontent的操作。但是会占部分内存。

10)数据资源加载转换
此框架包含了数据资源加载及转换, 类<-> xml<->二进制<->excel,都可以互转,可以去查看DataEditor脚本。编辑器工具也有右键转换xml,二进制等功能。xml与excel的转换基于reg文件,在Assets同级目录的Data目录中,有BuffData的xml-excel配置例子。在工程目录中RealFram/DemoData中有BuffData类的例子,可供参看。

11)Unity2017之后新图集加载方式
在ResourceManager中加入一个新的方法,用来加载新图集,主要是将图片路径进行拆分计算出图集路径以及图片名称,然后加载图集后使用图片名称加载图片

  /// <summary>
  /// 新图集加载方法
  /// </summary>
  /// <param name="path"></param>
  /// <returns></returns>
  public Sprite LoadSpriteBySpriteAtlas(string path)
  {
      string spriteName = path.Remove(0, path.LastIndexOf('/') + 1);
      spriteName = spriteName.Remove(spriteName.LastIndexOf('.'));
      string filePath = path.Remove(path.LastIndexOf('/'));
      string spriteAtlasName = filePath.Remove(0, filePath.LastIndexOf('/') + 1);
      string spriteAtlasPath = string.Format("{0}/{1}.spriteatlas", filePath, spriteAtlasName);
      SpriteAtlas spriteAtlas = LoadResource<SpriteAtlas>(spriteAtlasPath);
      if (spriteAtlas == null)
      {
          Debug.LogError("不存在该图集:" + spriteAtlasPath);
          return null;
      }
      else 
      {
          return spriteAtlas.GetSprite(spriteName);
      }
  }
Unity商业游戏底层资源加载框架的相关源码可以通过Unity官方提供的AssetBundle类来实现。AssetBundle类是Unity中用于打包和加载资源的类,它可以将游戏中的各种资源(例如场景、模型、纹理、音频等)打包为一个个独立的AssetBundle文件,然后在运行时动态加载这些文件。 以下是实现资源加载的简单示例代码: ```csharp using UnityEngine; public class ResourceManager : MonoBehaviour { // 资源加载路径 public string bundleURL; // 资源名称 public string assetName; // 加载完成后的资源对象 private GameObject loadedAsset; void Start() { // 启动异步加载资源的协程 StartCoroutine(LoadAssetBundle()); } // 异步加载资源的协程 IEnumerator LoadAssetBundle() { // 使用UnityWebRequest从指定URL加载AssetBundle文件 using (var request = UnityEngine.Networking.UnityWebRequestAssetBundle.GetAssetBundle(bundleURL)) { yield return request.SendWebRequest(); // 加载AssetBundle文件 var bundle = DownloadHandlerAssetBundle.GetContent(request); // 从AssetBundle中异步加载资源 var assetRequest = bundle.LoadAssetAsync<GameObject>(assetName); yield return assetRequest; // 获取加载完成的资源对象 loadedAsset = assetRequest.asset as GameObject; } // 使用加载完成的资源对象进行后续操作 if (loadedAsset != null) { Instantiate(loadedAsset, transform.position, Quaternion.identity); } } } ``` 以上代码在Start方法中启动了一个协程,通过UnityWebRequest异步地从指定URL加载AssetBundle文件,然后使用AssetBundle.LoadAssetAsync异步地加载指定名称的资源,最后获取加载完成的资源对象进行后续操作。 注意:上述代码仅为示例,具体的资源加载逻辑和流程可能因项目需求而异,需要根据实际情况进行相应的修改和扩展。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值