【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

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/20690.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

别输在不会表达上

形象有时比内在更重要。着装对一个人的影响&#xff0c;比很多人想象中要重要得多。无论在什么场合&#xff0c;也不管你的年龄&#xff0c;你的穿衣品味都在不断定义你是谁。也许你会说漂亮是一件很主观的事情&#xff0c;每个人都有自己的审美。但是请记住&#xff0c;你的衣…

安装pytorch深度学习模型时要知道自己的电脑显卡是否支持CUDA

安装pytorch深度学习模型时要知道自己的电脑显卡是否支持CUDA&#xff0c;如何知道自己的显卡是否支持呢&#xff1f;可以去下面的网站&#xff0c;打开后就可以见到如下图所示&#xff1a; CUDA | 支持的GPU | GeForce (nvidia.cn)

amis 事件动作 和 行为按钮 常用用法

行为按钮 action &#xff08;仅是对click事件的处理&#xff09; actionType&#xff1a;这是 action 最核心的配置&#xff0c;来指定该 action 的作用类型&#xff0c;支持&#xff1a;ajax、link、url、drawer、dialog、confirm、cancel、prev、next、copy、close。 Butt…

[数据集][目标检测]脑溢血检测数据集VOC+YOLO格式767张2类别

数据集格式&#xff1a;Pascal VOC格式YOLO格式(不包含分割路径的txt文件&#xff0c;仅仅包含jpg图片以及对应的VOC格式xml文件和yolo格式txt文件) 图片数量(jpg文件个数)&#xff1a;767 标注数量(xml文件个数)&#xff1a;767 标注数量(txt文件个数)&#xff1a;767 标注类别…

【传知代码】基于知识引导提示的因果概念提取(论文复现)

前言&#xff1a;在当今信息爆炸的时代&#xff0c;我们被海量的数据所包围&#xff0c;然而&#xff0c;这些数据中的真正价值往往隐藏在深层的因果关系之中。无论是科学研究、商业决策&#xff0c;还是日常生活中的选择&#xff0c;理解并准确把握事物之间的因果关系&#xf…

Navicat Premium 16.01 下载、安装教程

Navicat Premium 16下载与安装教程 目录 Navicat Premium 16下载与安装教程前言安装步骤同意协议选择安装目录桌面快捷方式安装正在安装安装完成 步骤下载方式 前言 数据库管理用Navicat更加方便&#xff0c;可视化效果更好&#xff0c;今天给大家带来2022 Navicat Premium 16…

【thinkphp问题栏】tp5.1重写URL,取消路径上的index.php

在Apache运行thinkphp5.1时&#xff0c;发现系统默认生成的.htaccess不生效。 首先先查看怎么修改伪静态 1、修改Apache的配置文件 在Apache的安装目录下&#xff0c;打开config/httpd.conf。 搜索rewrite.so&#xff0c;将前面的#删掉&#xff0c;表示开启URL重写功能 2、…

Java | Leetcode Java题解之第120题三角形最小路径和

题目&#xff1a; 题解&#xff1a; class Solution {public int minimumTotal(List<List<Integer>> triangle) {int n triangle.size();int[] f new int[n];f[0] triangle.get(0).get(0);for (int i 1; i < n; i) {f[i] f[i - 1] triangle.get(i).get(i…

知名专业定制线缆知名智造品牌推荐-精工电联:解决水下机器人线缆行业痛点的领航者

在科技日新月异的今天&#xff0c;精工电联作为高科技智能化产品及自动化设备专用连接线束和连接器配套服务商&#xff0c;致力于为高科技行业提供高品质、高性能的集成线缆和连接器定制服务。我们不仅是高品质定制线缆供应商&#xff0c;更是水下机器人线缆行业痛点的有效解决…

win系统游戏提示找不到d3dx9_37.dll丢失的解决方法-最简单的解决方法

d3dx9_37.dll 是一个动态链接库文件&#xff0c;属于 Microsoft DirectX 9 的一部分。DirectX 9 是一个用于多媒体应用&#xff0c;特别是游戏和视频的 API&#xff0c;它提供了一套丰富的功能&#xff0c;用于处理图形、声音和输入设备等。d3dx9_37.dll 文件包含了 Direct3D 9…

【30天精通Prometheus:一站式监控实战指南】第12天:windows_exporter从入门到实战:安装、配置详解与生产环境搭建指南,超详细

亲爱的读者们&#x1f44b;   欢迎加入【30天精通Prometheus】专栏&#xff01;&#x1f4da; 在这里&#xff0c;我们将探索Prometheus的强大功能&#xff0c;并将其应用于实际监控中。这个专栏都将为你提供宝贵的实战经验。&#x1f680;   Prometheus是云原生和DevOps的…

容器化部署gitlab、jenkins,jenkins应用示例

一、容器化部署docker和docker conpose安装 Docker&Docker-compose的安装及部署_docker 20 使用什么版本docker-compose-CSDN博客 1.docker 安装脚本 cat >01_docker.sh<<EOF #!/bin/bash yum remove docker \docker-client \docker-client-latest \docker-co…

用开源模型MusicGen制作六一儿童节专属音乐

使用的是开源模型MusicGen&#xff0c;它可以根据文字描述或者已有旋律生成高质量的音乐(32kHz)&#xff0c;其原理是通过生成Encodec token然后再解码为音频&#xff0c;模型利用EnCodec神经音频编解码器来从原始波形中学习离散音频token。EnCodec将音频信号映射到一个或多个并…

堡垒机,日志审计系统,行为管理,漏洞扫描的作用

堡垒机 日志审计 行为管理 漏洞扫描 堡垒机和防火墙的区别主要体现在以下几个方面&#xff1a; 功能不同&#xff1a;堡垒机主要用于管理和控制服务器访问权限&#xff0c;提供安全的登录通道和权限控制&#xff0c;还可以记录并监控用户对服务器的所有操作&#xff0c;为后…

两个数相加减高级实现

不使用实现两数相加 #include <stdio.h> int plus(int a, int b) {int sum0,addication0;while(b!0){sum a^b;addication (a&b)<<1;a sum;b addication;}return a; }不使用-实现两数相减 #include <stdio.h> int sub(int a, int b) {int sum0,abdc…

C++ 课堂实验 编写一个能计算银行存款的小程序。

本关任务&#xff1a;编写一个能计算银行存款的小程序。 相关知识 为了完成本关任务&#xff0c;你需要掌握&#xff1a;1.简单的循环语句&#xff0c;2.基本数据类型。 编程要求 10万元存银行&#xff0c;每年利息3.75%&#xff0c;每年计算一次利息&#xff0c;将本金加上…

基于Open3D的点云处理24-ICP匹配cuda加速

参考:docs/jupyter/t_pipelines/t_icp_registration.ipynb 完整测试用例: import open3d as o3d import open3d.core as o3cif o3d.__DEVICE_API__ == cuda:import open3d.cuda.pybind.t.pipelines.registration as treg else:

mac地址一样,ip不同,能ping通么?

一、mac地址一样&#xff0c;ip不通能ping通过么&#xff1f; 结论&#xff1a;两台设置的mac地址一样&#xff0c;不管是否通过交换机&#xff0c;两个设备之间都不会收到影响。 1、两个设备之间不通过交换机。 原因&#xff1a;这是因为在ping时&#xff0c;设备会发起arp…

携程梁建章:持续投资创新与AI,开启旅游行业未来增长

5月30至31日&#xff0c;携程集团在上海和张家界举办Envision 2024全球合作伙伴大会&#xff0c;邀请超50个国家和地区的1600余名外籍旅游业嘉宾与会&#xff0c;共同探讨中国跨境旅游市场发展机遇&#xff0c;讲好中国故事。 携程国际业务增速迅猛&#xff0c;创新与AI解锁未…

Unity 自定义房间布局系统 设计与实现一个灵活的房间放置系统 ——自定义房间区域功能

自定义房间区域功能 效果&#xff1a; 功能&#xff1a; 能够自定义房间的大小一键生成放置区域可控的放置网格点当物体放置到区域内可自动吸附物体是否可放置&#xff0c;放置时如果与其他物体交叉则不可放置&#xff08;纯算法计算&#xff09;管理房间内的物体&#xff0c…