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包的一个镜像,你可以在这里找到包的源代码、版本发布信息等。

相关推荐
二狗哈1 天前
Cesium快速入门15:图元Primitive创建图像物体
开发语言·javascript·3d·webgl·cesium·地图可视化
技术探讨者1 天前
Unity 框架:从核心构成到实践应用的全面解析
unity·游戏引擎
牛掰是怎么形成的1 天前
Unity Legacy动画与骨骼动画的本质区别
unity·游戏引擎
weixin_458360911 天前
Unity使用Cursor Editor
unity
萘柰奈1 天前
Unity学习--2D动画--[序列帧动画]2D序列帧动画
学习·unity·游戏引擎
EQ-雪梨蛋花汤1 天前
【Unity笔记】Unity 模型渲染优化:从 Batching 到 GI 设置的完整指南
笔记·unity·游戏引擎
花花_11 天前
一步封神:Unity环境搭建终极全宇宙级攻略(Win/Mac/云)
macos·unity·游戏引擎
Unity打怪升级1 天前
【Unity精品源码】Ultimate Character Controller:高级角色控制器完整解决方案
游戏·unity·ue5·游戏引擎·godot·游戏程序·cocos2d
qq_312982131 天前
Unity国际版下载方法 https://unity.com/releases 被重定向问题导致下载不到Unity国际版的问题解决
unity·游戏引擎
光光的奇妙冒险1 天前
Luban+Unity使用,看这一篇文章就够了
unity·游戏引擎·游戏程序·游戏策划