oops-framework框架 之 资源管理(四)

2023-12-03 17:04

本文主要是介绍oops-framework框架 之 资源管理(四),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

引擎: CocosCreator 3.8.0

环境: Mac

Gitee: oops-game-kit

注: 作者dgflashoops-framework框架QQ群: 628575875


简介


在CocosCreator中,资源可以分为两大类:

  1. 静态引用资源
  2. 动态引用资源,包含动态加载和远程下载

放置在 assets 目录下的所有资源,均继承于Asset,而这些资源的动态加载主要是通过 Bundle

Bundle 存在多个,主要有两类:

  • 内置Bundle, 主要是resources、start-scene、main等
  • 自定义Bundle, 由开发者设定文件夹自定义的,用于对资源进行更好的管理和使用

Bundle 的使用主要通过CocosCreator引擎封装的AssetManager进行资源的远程下载、加载和释放等。

更多关于CocosCreator资源管理的详情可参考博客:

CocosCreator 之 resources动态加载

CocosCreator 之 Bundle的使用

CocosCreator 之 AssetManager资源管理和释放

了解这些,对了解dgflash作者分享的oops-framework框架下的资源管理是有帮助的。


ResLoader

oops-framework 中的资源管理主要被 ResLoader管理,用于管理各种不同类型资源的加载和释放。

Oops.ts中的定义如下:

// ../oops-plugin-framework/assets/core/Oop.ts
export class oops {/** 资源管理 */static res = new ResLoader();
}

使用的简单方式是:

let url = `game/textures/image/spriteFrame`;
oops.res.load(url, SpriteFrame, (err, spriteframe) => {if (err) {return console.error("load spriteframe failed:" + err.message);}this._blockSprite.spriteFrame = spriteframe;
});

这种方式同resources.load的方式很是相像。在框架中使用ResLoader对于资源的管理特点是:

  • 加载默认 resources 文件夹中资源
  • 加载默认 bundle 远程资源
  • 主动传递 bundle 名时,优先加载传递 bundle 名资源包中的资源

主要接口有:

参数或接口说明
defaultBundleName全局默认加载的资源包名,默认resources
load()加载单一任意类型资源
loadAsync()异步加载单一任意类型资源
loadDir()加载文件夹中资源
loadRemote()加载远程资源
loadBundle()加载资源包
get()根据路径,资源类型获取资源
dump()打印缓存中所有资源信息
release()通过相对路径释放资源
releaseDir()通过文件夹路径释放所有文件夹中资源

在项目启动InitRes.ts中加载必备资源或可选资源时,就能够看到资源管理的使用。

// 加载远程资源,使用loadBundle进行加载
private loadBundle(queue: AsyncQueue) {queue.push(async (next: NextFunction, params: any, args: any) => {// 设置默认加载的外部资源包名oops.res.defaultBundleName = oops.config.game.bundleName;if (oops.config.game.bundleEnable) {await oops.res.loadBundle(oops.config.game.bundleServer, oops.config.game.bundleVersion);}else {await oops.res.loadBundle(oops.config.game.bundleName);}next();});
}// 加载自定义内容 使用load进行单一资源加载
private loadCustom(queue: AsyncQueue) {queue.push(async (next: NextFunction, params: any, args: any) => {// 加载多语言对应字体oops.res.load("language/font/" + oops.language.current, next);});
}// 加载公共资源, 使用loadDir进行目录加载
private loadCommon(queue: AsyncQueue) {queue.push((next: NextFunction, params: any, args: any) => {oops.res.loadDir("common", next);});
}

示例


图片动态加载、图片远程加载、Spine动态加载的示例:

export class UIResLoadLayer extends Component {@property(Sprite) sprite: Sprite = null; @property(sp.Skeleton) spine: sp.Skeleton = null; // 图片动态加载public clickImgLoad() {let url = "game/texture/game1/spriteFrame"oops.res.load(url, (err, spriteframe) => {if (err) {console.log("资源加载失败", err);return;}this.sprite.spriteFrame = spriteframe;})}// 图片远程加载public clickRemoteLoad() {let url = "https://oops-1255342636.cos-website.ap-shanghai.myqcloud.com/img/bg.png";var opt = { ext: ".png" };var onComplete = (err: Error | null, data: ImageAsset) => {const spriteFrame = new SpriteFrame();const texture = new Texture2D();texture.image = data;spriteFrame.texture = texture;this.sprite.spriteFrame = spriteFrame;}oops.res.loadRemote<ImageAsset>(url, opt, onComplete);}// spine动态加载public clickSpineLoad() {let url = "game/spine/model1"oops.res.load(url, sp.SkeletonData, (err, sd: sp.SkeletonData) => {if (err) {return console.error(err.message);}this.spine.skeletonData = sd;this.spine.setAnimation(0, "AttackCritical_Arch", true);});}
}

注:在ResLoader.ts提供的接口中,有着相关的代码示例,这里就不复制粘贴了。

有一点需要注意,如果存在 Bundle ,在项目启动的时候会优先加载

// InitRes.ts
entityEnter(e: Initialize): void {var queue: AsyncQueue = new AsyncQueue();/** 加载远程资源配置 */this.loadBundle(queue);// ...queue.play();
}private loadBundle(queue: AsyncQueue) {queue.push(async (next: NextFunction, params: any, args: any) => {// 设置默认加载的外部资源包名oops.res.defaultBundleName = oops.config.game.bundleName;// 加载外部资源包// ...next();});
}

这里会默认将defaultBundleName修改为指定的BundleName, 如果需要动态加载 resources 目录中的资源,就需要设置下名字:

let bundleName = "resources";
let path = "common/texture/img/spriteFrame";
oops.res.load(bundleName, path, spriteFrame, (err, spriteFrame) => {});

感谢作者dgflash的分享,作者CSDN博客: dgflash CSDN

最后,祝大家学习和生活愉快!

这篇关于oops-framework框架 之 资源管理(四)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/450191

相关文章

cross-plateform 跨平台应用程序-03-如果只选择一个框架,应该选择哪一个?

跨平台系列 cross-plateform 跨平台应用程序-01-概览 cross-plateform 跨平台应用程序-02-有哪些主流技术栈? cross-plateform 跨平台应用程序-03-如果只选择一个框架,应该选择哪一个? cross-plateform 跨平台应用程序-04-React Native 介绍 cross-plateform 跨平台应用程序-05-Flutte

Spring框架5 - 容器的扩展功能 (ApplicationContext)

private static ApplicationContext applicationContext;static {applicationContext = new ClassPathXmlApplicationContext("bean.xml");} BeanFactory的功能扩展类ApplicationContext进行深度的分析。ApplicationConext与 BeanF

数据治理框架-ISO数据治理标准

引言 "数据治理"并不是一个新的概念,国内外有很多组织专注于数据治理理论和实践的研究。目前国际上,主要的数据治理框架有ISO数据治理标准、GDI数据治理框架、DAMA数据治理管理框架等。 ISO数据治理标准 改标准阐述了数据治理的标准、基本原则和数据治理模型,是一套完整的数据治理方法论。 ISO/IEC 38505标准的数据治理方法论的核心内容如下: 数据治理的目标:促进组织高效、合理地

ZooKeeper 中的 Curator 框架解析

Apache ZooKeeper 是一个为分布式应用提供一致性服务的软件。它提供了诸如配置管理、分布式同步、组服务等功能。在使用 ZooKeeper 时,Curator 是一个非常流行的客户端库,它简化了 ZooKeeper 的使用,提供了高级的抽象和丰富的工具。本文将详细介绍 Curator 框架,包括它的设计哲学、核心组件以及如何使用 Curator 来简化 ZooKeeper 的操作。 1

【Kubernetes】K8s 的安全框架和用户认证

K8s 的安全框架和用户认证 1.Kubernetes 的安全框架1.1 认证:Authentication1.2 鉴权:Authorization1.3 准入控制:Admission Control 2.Kubernetes 的用户认证2.1 Kubernetes 的用户认证方式2.2 配置 Kubernetes 集群使用密码认证 Kubernetes 作为一个分布式的虚拟

Spring Framework系统框架

序号表示的是学习顺序 IoC(控制反转)/DI(依赖注入): ioc:思想上是控制反转,spring提供了一个容器,称为IOC容器,用它来充当IOC思想中的外部。 我的理解就是spring把这些对象集中管理,放在容器中,这个容器就叫Ioc这些对象统称为Bean 用对象的时候不用new,直接外部提供(bean) 当外部的对象有关系的时候,IOC给它俩绑好(DI) DI和IO

Sentinel 高可用流量管理框架

Sentinel 是面向分布式服务架构的高可用流量防护组件,主要以流量为切入点,从限流、流量整形、熔断降级、系统负载保护、热点防护等多个维度来帮助开发者保障微服务的稳定性。 Sentinel 具有以下特性: 丰富的应用场景:Sentinel 承接了阿里巴巴近 10 年的双十一大促流量的核心场景,例如秒杀(即突发流量控制在系统容量可以承受的范围)、消息削峰填谷、集群流量控制、实时熔断下游不可用应

利用Django框架快速构建Web应用:从零到上线

随着互联网的发展,Web应用的需求日益增长,而Django作为一个高级的Python Web框架,以其强大的功能和灵活的架构,成为了众多开发者的选择。本文将指导你如何从零开始使用Django框架构建一个简单的Web应用,并将其部署到线上,让世界看到你的作品。 Django简介 Django是由Adrian Holovaty和Simon Willison于2005年开发的一个开源框架,旨在简

Yii框架relations的使用

通过在 relations() 中声明这些相关对象,我们就可以利用强大的 Relational ActiveRecord (RAR) 功能来访问资讯的相关对象,例如它的作者和评论。不需要自己写复杂的 SQL JOIN 语句。 前提条件 在组织数据库时,需要使用主键与外键约束才能使用ActiveReocrd的关系操作; 场景 申明关系 两张表之间的关系无非三种:一对多;一对一;多对多; 在

laravel框架实现redis分布式集群原理

在app/config/database.php中配置如下: 'redis' => array('cluster' => true,'default' => array('host' => '172.21.107.247','port' => 6379,),'redis1' => array('host' => '172.21.107.248','port' => 6379,),) 其中cl