Unity Addressables 系统处理 WebGL 打包本地资源的一种高效方式

为了在 WebGL 中更快捷地处理和使用本地资源文件(例如图片),一个非常便捷且高效的方式是使用 Unity Addressables 系统。Addressables 提供了对资源的高效管理,并且允许你在构建时将资源标记为 可按需加载,使得你能避免将所有资源一次性打包到构建包中,从而减小 WebGL 构建的体积。

为什么选择 Addressables?

按需加载:资源只在需要时加载,可以显著减小初次加载的时间。

简化资源管理:资源的管理和版本控制更加高效,尤其适合 WebGL 等浏览器平台。

支持远程和本地加载:可以从本地存储或者服务器加载资源。

使用 Addressables 打包 WebGL 本地资源的步骤

  1. 安装 Addressables 包

首先确保你在 Unity 中启用了 Addressables 包。如果你尚未安装 Addressables,可以通过以下步骤安装:

  1. 打开 Unity 编辑器。

  2. 点击 Window > Package Manager。

  3. 在 Package Manager 中,搜索 Addressables,并点击 Install 按钮。

  4. 设置资源为 Addressable

你需要将你想要打包和按需加载的资源标记为 Addressable,例如图片、音频、模型等。

  1. 在 Project 窗口中,右键点击你的资源文件(例如 .png 图片文件),选择 Simplify > Mark as Addressable。

  2. 在 Inspector 面板中,找到 Addressable 选项并勾选。Unity 会为这个资源分配一个 Addressable Asset 地址。

  3. 可以为每个资源分配不同的地址(例如 "Textures/MyImage"),这样你可以通过地址加载资源。

  4. 配置 Addressables 组

你可以将资源分组,以便 Unity 在构建时处理它们。Addressables 会将资源打包成不同的组。

  1. 打开 Window > Asset Management > Addressables,点击 Groups。

  2. 在 Addressables Groups 窗口中,你可以创建一个新的组,或将已有的资源拖到不同的组中。这些组将决定资源在构建时如何打包。

  3. 构建 Addressables

在 WebGL 项目中,你可以将资源打包成 Addressables,并在 WebGL 环境中按需加载这些资源。

  1. 打开 Window > Asset Management > Addressables。

  2. 点击 Build,然后选择 Build Player Content,开始构建所有的 Addressable 资源。Unity 会生成并处理所有标记为 Addressable 的资源。

  3. 加载资源

在 WebGL 构建中,你可以按需加载资源。以下是一个加载纹理的例子:

csharp

using UnityEngine;

using UnityEngine.AddressableAssets;

using UnityEngine.ResourceManagement.AsyncOperations;

public class AddressableExample : MonoBehaviour

{

void Start()

{

// 异步加载名为 "Textures/MyImage" 的纹理

Addressables.LoadAssetAsync<Texture2D>("Textures/MyImage").Completed += OnTextureLoaded;

}

// 资源加载完成后回调

void OnTextureLoaded(AsyncOperationHandle<Texture2D> handle)

{

if (handle.Status == AsyncOperationStatus.Succeeded)

{

Texture2D texture = handle.Result;

// 使用加载的纹理

Renderer renderer = GetComponent<Renderer>();

renderer.material.mainTexture = texture;

}

else

{

Debug.LogError("纹理加载失败!");

}

}

}

  1. 打包 WebGL 构建

完成上述步骤后,你可以使用 Unity 进行 WebGL 构建:

  1. 打开 File > Build Settings,选择 WebGL 平台。

  2. 点击 Build,Unity 会将项目打包成 WebGL 格式。

  3. 打包完成后,部署到 Web 服务器上进行测试。WebGL 会自动从构建包中加载和显示你的资源。

额外优化:使用远程加载

Addressables 支持 远程加载,这意味着你可以将 Addressable 资源上传到远程服务器,并通过网络按需加载。

  1. 配置远程资源:在 Addressables Groups 窗口中,右键点击组,选择 Build > Set Remote Build Path 来设置资源的远程路径。

  2. 上传资源:将资源上传到你指定的服务器或云存储服务中。

  3. 加载远程资源:使用相同的代码来加载资源,Unity 会从远程服务器加载这些资源。

例如,加载远程地址的代码示例:

csharp

Addressables.LoadAssetAsync<Texture2D>("https://myserver.com/Textures/MyImage").Completed += OnTextureLoaded;

总结

Unity Addressables 系统是处理 WebGL 打包本地资源的一种高效方式,具备以下优点:

按需加载:减少了 WebGL 的初始加载时间,避免了将所有资源打包到构建包中。

资源优化:支持将资源打包为独立的文件,可以按需加载,降低了 WebGL 构建的体积。

远程资源支持:可以将资源托管在远程服务器上,方便在 WebGL 中动态加载和更新资源。

只需标记资源为 Addressable 并构建 WebGL 项目,你就能高效地管理本地资源,并优化 WebGL 游戏的加载性能。

官方示例项目:

https://github.com/Unity-Technologies/Addressables-Sample

这个仓库提供了使用Addressables包的示例项目,可以帮助你快速上手并了解其基本用法。

社区镜像:

https://github.com/needle-mirror/com.unity.addressables

这个仓库是Unity官方Addressables包的一个镜像,你可以在这里找到包的源代码、版本发布信息等。

相关推荐
异次元的归来4 小时前
Unity DOTS中的share component
unity·游戏引擎
向宇it7 小时前
【从零开始入门unity游戏开发之——C#篇25】C#面向对象动态多态——virtual、override 和 base 关键字、抽象类和抽象方法
java·开发语言·unity·c#·游戏引擎
_oP_i9 小时前
unity webgl部署到iis报错
unity
Go_Accepted9 小时前
Unity全局雾效
unity
向宇it9 小时前
【从零开始入门unity游戏开发之——C#篇24】C#面向对象继承——万物之父(object)、装箱和拆箱、sealed 密封类
java·开发语言·unity·c#·游戏引擎
汪洪墩10 小时前
【Mars3d】设置backgroundImage、map.scene.skyBox、backgroundImage来回切换
开发语言·javascript·python·ecmascript·webgl·cesium
m0_7482343412 小时前
webGL硬核知识:图形渲染管渲染流程,各个阶段对应的API调用方式
图形渲染·webgl
每日出拳老爷子12 小时前
【图形渲染】【Unity Shader】【Nvidia CG】有用的参考资料链接
unity·游戏引擎·图形渲染
北海651613 小时前
Dots 常用操作
unity
YY-nb20 小时前
Unity Apple Vision Pro 开发教程:物体识别跟踪
unity·游戏引擎·apple vision pro