【Unity知识点详解】Addressables的资源加载

2024-05-31 20:44

本文主要是介绍【Unity知识点详解】Addressables的资源加载,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

        今天来简单介绍一下Addressables,并介绍一下如何通过AssetName加载单个资源、如何通过Label加载多个资源、以及如何通过List<string>加载多个资源。由于Addressables的资源加载均为异步加载,所以今天给大家介绍如何使用StartCoroutine、如何使用Async/Await、如何使用Completed回调的三种方式加载。

        

准备工作

        首先我们需要在Unity菜单栏Window中找到Package Manager,在Package Manager中下载并安装Addressables组件。

        我们在项目中准备了一些游戏资源,并且可以在Inspector窗口下将资源选择为加载资源,对于目录而言也可以整体选择为加载资源。

        选择完加载资源之后,我们通过Window->Asset Management->Addressables->Groups路径页签打开Addressables Groups窗口,Addressables Groups中列举的则是所有选中的加载资源。

        我们可以对每个资源进行Label分类,当然不分类默认default也没关系。点击Manage Labels可以打开Labels窗口自定义自己所需要的标签。关于Label有什么用往后看。

使用StartCoroutine加载资源

using System.Collections;
using System.Collections.Generic;
using UnityEngine;
using UnityEngine.AddressableAssets;
using UnityEngine.ResourceManagement.AsyncOperations;public class LoadCoroutine : MonoBehaviour
{public void Awake(){StartCoroutine(LoadAssetAsync("LanguageConfig"));StartCoroutine(LoadMultipleAssetAsync("Config"));StartCoroutine(LoadMultipleAssetAsync(new List<string>() { "LanguageConfig", "RoleConfig", "Prefab" }));}/// <summary>单资源加载</summary>/// <param name="pAssetName"></param>public IEnumerator LoadAssetAsync(string pAssetName){AsyncOperationHandle asyncOperationHandle = Addressables.LoadAssetAsync<UnityEngine.Object>(pAssetName);yield return asyncOperationHandle;LoadAssetAsyncCompleted(asyncOperationHandle);}/// <summary>多资源加载(通过Label)</summary>/// <param name="pLabelsName"></param>public IEnumerator LoadMultipleAssetAsync(string pLabelsName){AsyncOperationHandle<IList<UnityEngine.Object>> asyncOperationHandle = Addressables.LoadAssetsAsync<UnityEngine.Object>(pLabelsName, null);yield return asyncOperationHandle;LoadAssetAsyncCompleted(asyncOperationHandle);}/// <summary>多资源加载(通过List)</summary>/// <param name="pNameList"></param>public IEnumerator LoadMultipleAssetAsync(List<string> pNameList){AsyncOperationHandle<IList<UnityEngine.Object>> asyncOperationHandle = Addressables.LoadAssetsAsync<UnityEngine.Object>(pNameList, null, Addressables.MergeMode.Union, false);yield return asyncOperationHandle;LoadMultipleAssetAsyncCompleted(asyncOperationHandle);}/// <summary>加载完成回调</summary>public void LoadAssetAsyncCompleted(AsyncOperationHandle pHandle){if (pHandle.Status == AsyncOperationStatus.Succeeded){if (pHandle.Result is List<UnityEngine.Object>){List<UnityEngine.Object> assetList = pHandle.Result as List<UnityEngine.Object>;for (int index = 0; index < assetList.Count; index++){Debug.LogError(assetList[index]);}}else{Debug.LogError(pHandle.Result);}}}/// <summary>加载完成回调</summary>public void LoadMultipleAssetAsyncCompleted(AsyncOperationHandle<IList<UnityEngine.Object>> pHandle){if (pHandle.Status == AsyncOperationStatus.Succeeded){if (pHandle.Result is List<UnityEngine.Object>){List<UnityEngine.Object> assetList = pHandle.Result as List<UnityEngine.Object>;for (int index = 0; index < assetList.Count; index++){Debug.LogError(assetList[index]);}}else{Debug.LogError(pHandle.Result);}}}
}

        我们这里先来介绍使用StartCoroutine加载资源,这里我提供了三种加载资源的方法。

public IEnumerator LoadAssetAsync(string pAssetName) 是通过资源名称加载资源,这个方法只能加载单个资源,这里的参数pAssetName指代的则是Addressables Groups窗口中的Addressable Name。这里的Addressable Name是可以自行修改的,资源选取的时候默认是全路径名称,就像上面截图中MainPanel一样显示的是全路径。我们在开发中可以根据自己的需求进行修改。

public IEnumerator LoadMultipleAssetAsync(string pLabelsName)是通过Label名称加载资源的,一次可以加载一个或多个资源。这个方法会将所有标记为pLabelsName的资源加载进来,并且返回一个IList<TObject>类型的结果。

public IEnumerator LoadMultipleAssetAsync(List<string> pNameList)是通过一个名称列表加载资源的,一次可以加载一个或多个资源。这里的pNameList参数既可以包含单个pAssetName,也可以包含pLabelsName,或者同时包含pAssetName和pLabelsName。加载完成后同样会返回一个IList<TObject>类型的结果,这里需要说明的是一个资源只会被加载一次,例如pNameList中包含了资源名MainPanel,又包含了Label名Prefab,同时MainPanel又被标记为了Prefab,此时加载返回的资源结果中只会有一个MainPanel。

        以上三种方法均是调用了Addressables类中提供的资源加载接口,Addressables中则是包含了所有的资源加载接口,感兴趣的小伙伴可以自己研究。

        Addressables的加载接口返回的均为一个AsyncOperationHandle对象,由于AsyncOperationHandle对象继承自IEnumerator,所以我们可以将加载方法写成一个协程函数通过StartCoroutine来进行调用。加载完成后我们可以通过AsyncOperationHandle.Result获取加载的资源,Result为object类型在实际使用时需要根据实际类型进行转换后使用。

using System.Collections;
using System.Collections.Generic;
using UnityEngine;
using UnityEngine.AddressableAssets;
using UnityEngine.ResourceManagement.AsyncOperations;public class LoadAsyncAwait : MonoBehaviour
{public void Awake(){LoadAssetAsync("LanguageConfig");LoadMultipleAssetAsync("Config");LoadMultipleAssetAsync(new List<string>() { "LanguageConfig", "MainPanel", "SettingPanel" });}/// <summary>单资源加载</summary>/// <param name="pAssetName"></param>public async void LoadAssetAsync(string pAssetName){AsyncOperationHandle asyncOperationHandle = Addressables.LoadAssetAsync<UnityEngine.Object>(pAssetName);await asyncOperationHandle.Task;LoadAssetAsyncCompleted(asyncOperationHandle);}/// <summary>多资源加载(通过Label)</summary>/// <param name="pLabelsName"></param>public async void LoadMultipleAssetAsync(string pLabelsName){AsyncOperationHandle asyncOperationHandle = Addressables.LoadAssetsAsync<UnityEngine.Object>(pLabelsName, null);await asyncOperationHandle.Task;LoadAssetAsyncCompleted(asyncOperationHandle);}/// <summary>多资源加载(通过List)</summary>/// <param name="pNameList"></param>public async void LoadMultipleAssetAsync(List<string> pNameList){AsyncOperationHandle<IList<UnityEngine.Object>> asyncOperationHandle = Addressables.LoadAssetsAsync<UnityEngine.Object>(pNameList, null, Addressables.MergeMode.Union, false);await asyncOperationHandle.Task;LoadMultipleAssetAsyncCompleted(asyncOperationHandle);}/// <summary>加载完成回调</summary>public void LoadAssetAsyncCompleted(AsyncOperationHandle pHandle){if (pHandle.Status == AsyncOperationStatus.Succeeded){if (pHandle.Result is List<UnityEngine.Object>){List<UnityEngine.Object> assetList = pHandle.Result as List<UnityEngine.Object>;for (int index = 0; index < assetList.Count; index++){Debug.LogError(assetList[index]);}}else{Debug.LogError(pHandle.Result);}}}/// <summary>加载完成回调</summary>public void LoadMultipleAssetAsyncCompleted(AsyncOperationHandle<IList<UnityEngine.Object>> pHandle){if (pHandle.Status == AsyncOperationStatus.Succeeded){if (pHandle.Result is List<UnityEngine.Object>){List<UnityEngine.Object> assetList = pHandle.Result as List<UnityEngine.Object>;for (int index = 0; index < assetList.Count; index++){Debug.LogError(assetList[index]);}}else{Debug.LogError(pHandle.Result);}}}
}

使用Async/Await加载资源

        接下来介绍的是使用Async/Await方式加载资源,同样示例中展示了通过AssetName加载资源、通过Label加载资源、以及通过List<string>加载资源,同样是调用Addressables类的加载接口加载资源。不同的是Async/Await方式使用的是AsyncOperationHandle中提供的Task异步类,在函数写法上略有不同。相比StartCoroutine而言Async/Await的调用方式与普通函数无异。在加载完成之后,同样从AsyncOperationHandle.Result获取加载的资源资源对象。   

using System;
using System.Collections.Generic;
using UnityEngine;
using UnityEngine.AddressableAssets;
using UnityEngine.ResourceManagement.AsyncOperations;public class LoadCompleted : MonoBehaviour
{public void Awake(){LoadAssetAsync("LanguageConfig", LoadAssetAsyncCompleted);LoadMultipleAssetAsync("Config", LoadMultipleAssetAsyncCompleted);LoadMultipleAssetAsync(new List<string>() { "LanguageConfig", "MainPanel", "SettingPanel" }, LoadMultipleAssetAsyncCompleted);}/// <summary>单资源加载</summary>/// <param name="pAssetName"></param>/// <param name="LoadComplete"></param>public void LoadAssetAsync(string pAssetName, Action<AsyncOperationHandle> LoadComplete){AsyncOperationHandle asyncOperationHandle = Addressables.LoadAssetAsync<UnityEngine.Object>(pAssetName);asyncOperationHandle.Completed += LoadComplete;}/// <summary>多资源加载(通过Label)</summary>/// <param name="pLabelsName"></param>/// <param name="LoadComplete"></param>public void LoadMultipleAssetAsync(string pLabelsName, Action<AsyncOperationHandle<IList<UnityEngine.Object>>> LoadComplete){AsyncOperationHandle<IList<UnityEngine.Object>> asyncOperationHandle = Addressables.LoadAssetsAsync<UnityEngine.Object>(pLabelsName, null);asyncOperationHandle.Completed += LoadComplete;}/// <summary>多资源加载(通过List)</summary>/// <param name="pNameList"></param>/// <param name="LoadComplete"></param>public void LoadMultipleAssetAsync(List<string> pNameList, Action<AsyncOperationHandle<IList<UnityEngine.Object>>> LoadComplete){AsyncOperationHandle<IList<UnityEngine.Object>> asyncOperationHandle = Addressables.LoadAssetsAsync<UnityEngine.Object>(pNameList, null, Addressables.MergeMode.Union, false);asyncOperationHandle.Completed += LoadComplete;}/// <summary>加载完成回调</summary>public void LoadAssetAsyncCompleted(AsyncOperationHandle pHandle){if (pHandle.Status == AsyncOperationStatus.Succeeded){if (pHandle.Result is List<UnityEngine.Object>){List<UnityEngine.Object> assetList = pHandle.Result as List<UnityEngine.Object>;for (int index = 0; index < assetList.Count; index++){Debug.LogError(assetList[index]);}}else{Debug.LogError(pHandle.Result);}}}/// <summary>加载完成回调</summary>public void LoadMultipleAssetAsyncCompleted(AsyncOperationHandle<IList<UnityEngine.Object>> pHandle){if (pHandle.Status == AsyncOperationStatus.Succeeded){if (pHandle.Result is List<UnityEngine.Object>){List<UnityEngine.Object> assetList = pHandle.Result as List<UnityEngine.Object>;for (int index = 0; index < assetList.Count; index++){Debug.LogError(assetList[index]);}}else{Debug.LogError(pHandle.Result);}}}
}

使用Completed回调加载资源

        最后一种方式是使用Completed回调来加载资源。与前两种方式最大的不同就是在调用方法时需要传入回调函数,当资源加载完成时则会调用回调函数。回调函数则会返回一个AsyncOperationHandle类型的参数,使用方法与前两种方式相同。

官方文档链接

Loading Addressable assets:https://docs.unity3d.com/Packages/com.unity.addressables@1.18/manual/LoadingAddressableAssets.html

Addressables类:https://docs.unity3d.com/Packages/com.unity.addressables@1.18/api/UnityEngine.AddressableAssets.Addressables.html

这篇关于【Unity知识点详解】Addressables的资源加载的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1019000

相关文章

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

基本知识点

1、c++的输入加上ios::sync_with_stdio(false);  等价于 c的输入,读取速度会加快(但是在字符串的题里面和容易出现问题) 2、lower_bound()和upper_bound() iterator lower_bound( const key_type &key ): 返回一个迭代器,指向键值>= key的第一个元素。 iterator upper_bou

OpenHarmony鸿蒙开发( Beta5.0)无感配网详解

1、简介 无感配网是指在设备联网过程中无需输入热点相关账号信息,即可快速实现设备配网,是一种兼顾高效性、可靠性和安全性的配网方式。 2、配网原理 2.1 通信原理 手机和智能设备之间的信息传递,利用特有的NAN协议实现。利用手机和智能设备之间的WiFi 感知订阅、发布能力,实现了数字管家应用和设备之间的发现。在完成设备间的认证和响应后,即可发送相关配网数据。同时还支持与常规Sof

6.1.数据结构-c/c++堆详解下篇(堆排序,TopK问题)

上篇:6.1.数据结构-c/c++模拟实现堆上篇(向下,上调整算法,建堆,增删数据)-CSDN博客 本章重点 1.使用堆来完成堆排序 2.使用堆解决TopK问题 目录 一.堆排序 1.1 思路 1.2 代码 1.3 简单测试 二.TopK问题 2.1 思路(求最小): 2.2 C语言代码(手写堆) 2.3 C++代码(使用优先级队列 priority_queue)

K8S(Kubernetes)开源的容器编排平台安装步骤详解

K8S(Kubernetes)是一个开源的容器编排平台,用于自动化部署、扩展和管理容器化应用程序。以下是K8S容器编排平台的安装步骤、使用方式及特点的概述: 安装步骤: 安装Docker:K8S需要基于Docker来运行容器化应用程序。首先要在所有节点上安装Docker引擎。 安装Kubernetes Master:在集群中选择一台主机作为Master节点,安装K8S的控制平面组件,如AP

Flutter 进阶:绘制加载动画

绘制加载动画:由小圆组成的大圆 1. 定义 LoadingScreen 类2. 实现 _LoadingScreenState 类3. 定义 LoadingPainter 类4. 总结 实现加载动画 我们需要定义两个类:LoadingScreen 和 LoadingPainter。LoadingScreen 负责控制动画的状态,而 LoadingPainter 则负责绘制动画。

嵌入式Openharmony系统构建与启动详解

大家好,今天主要给大家分享一下,如何构建Openharmony子系统以及系统的启动过程分解。 第一:OpenHarmony系统构建      首先熟悉一下,构建系统是一种自动化处理工具的集合,通过将源代码文件进行一系列处理,最终生成和用户可以使用的目标文件。这里的目标文件包括静态链接库文件、动态链接库文件、可执行文件、脚本文件、配置文件等。      我们在编写hellowor

LabVIEW FIFO详解

在LabVIEW的FPGA开发中,FIFO(先入先出队列)是常用的数据传输机制。通过配置FIFO的属性,工程师可以在FPGA和主机之间,或不同FPGA VIs之间进行高效的数据传输。根据具体需求,FIFO有多种类型与实现方式,包括目标范围内FIFO(Target-Scoped)、DMA FIFO以及点对点流(Peer-to-Peer)。 FIFO类型 **目标范围FIFO(Target-Sc

019、JOptionPane类的常用静态方法详解

目录 JOptionPane类的常用静态方法详解 1. showInputDialog()方法 1.1基本用法 1.2带有默认值的输入框 1.3带有选项的输入对话框 1.4自定义图标的输入对话框 2. showConfirmDialog()方法 2.1基本用法 2.2自定义按钮和图标 2.3带有自定义组件的确认对话框 3. showMessageDialog()方法 3.1

两个月冲刺软考——访问位与修改位的题型(淘汰哪一页);内聚的类型;关于码制的知识点;地址映射的相关内容

1.访问位与修改位的题型(淘汰哪一页) 访问位:为1时表示在内存期间被访问过,为0时表示未被访问;修改位:为1时表示该页面自从被装入内存后被修改过,为0时表示未修改过。 置换页面时,最先置换访问位和修改位为00的,其次是01(没被访问但被修改过)的,之后是10(被访问了但没被修改过),最后是11。 2.内聚的类型 功能内聚:完成一个单一功能,各个部分协同工作,缺一不可。 顺序内聚: