Addressables一些内容

Getting started | Addressables | 1.18.19 (unity3d.com)

1,加载资源
  • 使用AssetReference的方式
    1,在脚本中声明AssetReference变量
    2,在Inspector中赋值
    :AssetReference不会自动加载或卸载引用的资产,需要手动调用相关API(LoadAssetAsyncReleaseAsset
  • 使用地址的方式(Addressables.LoadAssetAsync<T>(address)
    :加载后同样需要手动卸载相关资产
  • 使用标签的方式(Addressables.LoadAssetAsync<T>()
    :测试失败
2,资源组打包方式
  • 将组内资源打包成一个包
  • 每项单独打包
  • 按照标签打包
3,一些概念

Asset address:标识可寻址资产的字符串ID。可以作为键来加载资产。
AssetReferences:可用来与可寻址资产进行绑定。在代码中创建该类型的实例后,可在Inspector窗口中为其赋值(可寻址资产类型)。
Label:标签。可以添加到多个资产上,可以作为键来加载/卸载资产。
Asset location:用来描述如何加载资产及其依赖项的运行时对象,可以作为键来加载对象。
Key:用来表示一个或多个可寻址资源的对象,包含addresslabelAssetReferences实例、location对象。
Asset loading and unloading:在运行时用来加载、卸载资产的API。
Dependencies:资产依赖项。
Dependency and resource management:可寻址系统使用引用计数来跟踪正在使用的资产和Assetbundles,包括是否要加载/卸载依赖项。
Group:可寻址资产的分组。可设置组内资产的打包方式和加载方式。
Content catalogs:用来描述资产和包含资产的资源的映射关系。
Content builds:使用可寻址资产时,在构建项目前,要先构建内容。
Multiple platform support:运行平台。
Addressables tools:可寻址系统提供的工具。可用来组织、构建、优化内容。

  • Asset address(资产地址)
    1,可寻址系统的一个特性是在运行时可以通过地址加载资产,不管资产是放在本地还是远端。系统的资源管理器通过查找catalogs中的地址找到资产存放的位置(资产可以内置、放在本地缓存中、放在远端)。
    2,资产的地址和其物理位置无直接关系,两者通过Content catalogs进行映射。
    3,一个资产对应一个地址,而一个地址可以对应多个资产。相同地址的资产可以通过标签进行区分。
  • AssetReference
    1,AssetReference还包含其他类型,如 AssetReferenceGameObject(AssetReference<GameObject>)...
  • Loading and releasing assets
    1,加载资源时只需要加载主资产(依赖项会自动加载)。
    2,加载的可寻址资产需要手动卸载(否则会占用内存)。
    3,可寻址系统会对已加载的资产的引用进行追踪,当引用不为0时,不会卸载。
    4,加载和卸载的方法是对应的,加载使用LoadAssetAsync时,卸载应使用Release,加载使用InstantiateAsync时,卸载应使用ReleaseInstance
  • Dependency and resource management
    1,加载资产时,系统自动加载其依赖项。卸载时同样会自动卸载其依赖项(除非依赖项被其他加载的资产引用)。
  • Addressables groups and labels
    1,所有可寻址资产隶属于某个组,不为其指定时使用默认组。
    2,组规定了组内资产的打包方式。
  • Group schemas
  • Content catalogs
    1,Content catalogs用来表明资产的地址和物理位置的映射关系。
    2,一个Unity项目有一个Content catalogs
    3,可以加载其他Unity项目创建的Content catalogs来加载这些项目生成的可寻址资产(即可以创建Unity工程专门用来生成可寻址资产后放到其他项目里用)。
    4,生成Content catalogs时会同时生成hash文件,在加载远端的可寻址资产时,哈希值用来校验资产是否更新需要下载。
    5,Profile中配置了Content catalogs中与资产地址对应的加载路径。
  • Content builds
    1,内容生成与项目生成相互独立。
    2,生成内容时,会生成Content catalogs文件、hash文件、包含了资产的Assetbundle包。
    3,生成的内容与平台绑定,为不同平台生成的内容不能相互使用。
  • Play mode scripts
    定义了在编辑器模式下可寻址系统加载、卸载资产的方式。
    Use the Asset database:直接使用项目内的可寻址资产
    Simulate groups:模拟加载
    Use existing build:使用生成的内容
  • Support for multiple platforms
4,Assetbundle的压缩格式

Unity - Manual: AssetBundle compression (unity3d.com)

  • 两种压缩格式(LZMA、LZ4)
    1,默认情况下,生成assetbundle包时使用LZMA格式,缓存时使用LZ4格式。
    2,与LZ4格式相比,使用LZMA格式生成的包更小,但如果要使用包中的某个资源需要将整个包解压。LZ4为基于块的压缩,使用某个资源时只需要解压包含资源的块。
    3,LZMA格式不适用于WebGL平台。
  • Assetbundle包的两种缓存
    1,内存缓存
    内存缓存使用无压缩格式存在于RAM中,可快速访问,缺点是会占用大量内存。
    2,硬盘缓存
  • 加载Assetbundle
    1,使用UnityWebRequest加载Assetbundle时,在API中传入版本号参数Unity会将下载的资源缓存到硬盘上,否则会存入内存中。
    2,在API中,将Caching.compressionEnabled参数设为true,Unity在将资源存入硬盘时使用LZ4压缩格式,设为false则不压缩。(不传入默认为true)
    3,AssetBundle.LoadFromFileAssetBundle.LoadFromFileAsync始终对 LZMA AssetBundle 使用内存缓存,所以最好使用 UWR API。如果无法使用 UWR API,您可以使用 AssetBundle.RecompressAssetBundleAsync将 LZMA AssetBundle 重写到磁盘中。
5,资产组的更新策略

资产组的组更新策略包含两种:Cannot Change Post ReleaseCan Change Post Release

  • Cannot Change Post Release:不经常更新的组(本地组)应该设置为本项策略。
  • Can Change Post Release:经常更新的组设置为此项。

    1,不管选哪个策略资产组都是可以更新的,区别在于处理和访问资产的方式。
    2,不是完整生成时,不要改资产组的更新策略。
    3,设置为Cannot Change Post Release的资产组,当组中的某个资产需要更新时,Check for Content Updates工具会将该资源移入新的组进行打包用于更新,(新组的加载方式为远程加载,更新策略为Can Change Post Release),换句话说,设置为Cannot Change Post Release的资产组中的某个资产需要更新时,系统只会下载需要更新的内容,而不会下载整包。相对的,设置为Can Change Post Release的资产组中的某项资产需要更新时,系统需要下载整包。
    结论:需要从本地加载的资产组和需要从远端加载但比较大的资产组应设置为Cannot Change Post Release,需要从远端加载较小且需要频繁更新的组设置为Can Change Post Release
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,099评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,828评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,540评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,848评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,971评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,132评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,193评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,934评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,376评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,687评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,846评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,537评论 4 335
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,175评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,887评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,134评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,674评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,741评论 2 351

推荐阅读更多精彩内容