Skip to content

Using Resource System

DOM edited this page Jun 1, 2014 · 36 revisions

Egret资源加载管理系统(RES)

1. RES模块是什么?

Egret提供了一套默认的资源加载管理模块,在"RES"这个命名空间下。RES是一个可选的模块,与Egret核心库完全独立。开发者可以自行选择是否采用它,或使用自定义的第三方资源加载管理库。

2. RES配置文件格式

这里我们以Egret模板项目的resource.json为例:

{

"resources": [ {"name":"bgImage","type":"img","url":"assets/bg.jpg"}, {"name":"egretIcon","type":"img","url":"assets/egret_icon.png"}, {"name":"description","type":"json","url":"config/description.json"} ],

"groups": [ {"name":"preload","keys":"bgImage,egretIcon"} ] }

resources下是每一项资源的配置信息,name表示这个资源的唯一短名标识符,type表示资源类型,url是资源文件的路径。

groups下是预加载资源组的配置,每项是一个资源组。name表示资源组的组名,keys表示这个资源组包含哪些资源,里面的逗号分隔的每一个字符串,都与resources下的资源name对应。同一个资源可以存在于多个资源组里。

3. 如何初始化?

调用RES.loadConfig()加载之前的resource.json配置文件即可完成初始化。loadConfig()第一个参数是resource.json文件的完整路径,第二个参数是resource.json里每个资源项url的前缀。例如配置里的bgImage资源项填的url是assets/bg.jpg,在这里实际加载时将会采用resources/assets/bg.jpg来加载:


RES.addEventListener(RES.ResourceEvent.CONFIG_COMPLETE,this.onConfigComp,this); RES.loadConfig("resources/resource.json","resources/");

若需要在初始化完成后再做一些处理,监听ResourceEvent.CONFIG_COMPLETE事件即可。

注意:RES.loadConfig()通常应写在整个游戏最开始初始化的地方,并且只执行一次。

4. 如何预加载资源组?

在配置文件加载完成后,我们可以调用RES.loadConfig()开始预加载配置中的一组资源。第一个参数"preload"对应配置文件中的资源组名。预加载可以在游戏启动时,也可以是某个面板被打开前,调用时机由具体项的目逻辑确定:

RES.addEventListener(RES.ResourceEvent.GROUP_COMPLETE,this.onResourceLoadComplete,this);

RES.addEventListener(RES.ResourceEvent.GROUP_PROGRESS,this.onResourceProgress,this); RES.loadGroup("preload");

这里需要注意下组加载事件回调函数里的写法,需要使用event.groupName判断下这个事件是属于哪个资源组,因为可能有多个资源组同时在加载:

private onResourceProgress(event:RES.ResourceEvent):void {
if(event.groupName=="preload"){
    this.loadingView.setProgress(event.itemsLoaded,event.itemsTotal);
}

}

若同时启动多个资源组一起加载,比如在加载"preload"前,我们希望先加载一个更小的"loading"资源组,以提供显示"preload"组加载进度的素材,可以使用RES.loadGroup()的第二个参数,为"loading"组传入一个优先级更大的数字,来迫使loading组在preload前加载完成:


RES.loadGroup("loading",1); RES.loadGroup("preload",0);

若资源组无法预先配置在文件中,需要运行时才能动态确定的,我们可以通过调用RES.createGroup(name:string,keys:Array)方法,动态创建一个资源组,再加载它。

5. 如何获取资源?(三种获取方式以及如何直接获取文件中的子资源)

RES一共含有三种资源获取方式:

  • RES.getRes(name:string):any
    同步获取资源 这种方式只能获取已经缓存过的资源,例如之前调用过loadGroup()被预加载的资源。
  • RES.getResAsync(name:string,compFunc:Function,thisObject:any):void
    异步获取资源,这种方式可以获取配置中含有的所有资源项。如果缓存中存在,直接调用回调函数返回,若不存在,就启动网络加载文件并解析后回调。
  • RES.getResByUrl(url:string,compFunc:Function,thisObject:any,type:string=""):void
    通过url获取不在配置中的资源,通常不建议使用这个接口,只有那些不合适填写在配置中,比如获取网络上其他服务器的资源时,才采用这种方式。

6. RES内置了哪些文件类型的解析器?

目前RES内置支持的文件类型有:

  • RES.ResourceItem.TYPE_BIN(bin):解析为原始的二进制文件
  • RES.ResourceItem.TYPE_IMAGE(image):解析为egret.Texture对象
  • RES.ResourceItem.TYPE_TEXT(text):解析为string变量
  • RES.ResourceItem.TYPE_JSON(json):解析为json对象
  • RES.ResourceItem.TYPE_SHEET(sheet):解析为egret.SpriteSheet对象
  • RES.ResourceItem.TYPE_FONT(font):解析为egret.BitmapTextSpriteSheet对象
  • RES.ResourceItem.TYPE_SOUND():解析为egret.Sound对象

7. RES模块解决什么问题?

8. 如何与GUI系统无缝桥接?

9. 图片类型如何配置九宫格参数?