使用cc.SpriteAtlas 中批量资源管理的方式思考(如管理一副扑克牌)

本文主要是介绍使用cc.SpriteAtlas 中批量资源管理的方式思考(如管理一副扑克牌),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

背景: 比如一副扑克,有54张,按照普通的做法,则是制作一个Prefab预制体,然后里面有个CardArr存储所有的54张牌纹理数组,然后初始化一张牌取一张纹理。 这样所有的54张都要拖进去,感觉怪怪的。

1)异步加载(不推荐):

 //设置显示的图片setCardShow(name) {var self = thiscc.log("setCardShow->" + name)cc.loader.loadRes("pic1/" + name, cc.SpriteFrame, function (err, spriteFrame) {cc.log("cc.loader.loadRes->" + name)self.sprite.spriteFrame = spriteFrame;});},

2)Atlas管理(推荐)

game.js

cc.Class({extends: cc.Component,properties: {node_player_card: cc.Node,cardPrefab: cc.Prefab},// LIFE-CYCLE CALLBACKS:onLoad() {if (!cc.vv) {cc.vv = {};}},start() {for (var i = 1; i < 10; i++) {var comp = cc.instantiate(this.cardPrefab).getComponent("card");var spriteFrame = cc.vv.card_mgr.getSprite("B_bamboo_" + i);comp.setCard(spriteFrame);this.node_player_card.addChild(comp.node);}}
});

card_mgr.js

cc.Class({extends: cc.Component,properties: {cardAtlas: cc.SpriteAtlas,},getSprite: function(frameName){return this.cardAtlas.getSpriteFrame(frameName);},// LIFE-CYCLE CALLBACKS:onLoad () {cc.vv.card_mgr = this;},onDestroy: function () {delete cc.vv.card_mgr;}
});

这样编辑器中,只需要绑定下altas纹理集到SpriteAtlas整个数据上即可,如下:

这样cardAtlas只需要存储一个纹理集合即可

card.js

cc.Class({extends: cc.Component,properties: {},// LIFE-CYCLE CALLBACKS:// onLoad () {},start () {},setCard: function (spriteFrame) {this.node.getComponent(cc.Sprite).spriteFrame = spriteFrame;}
});

这样很容易就把整个纹理集合管理起来了,不需要异步加载,效果如下:

总结:

毫无疑问,重点推荐Atlas方式打包围纹理集进行管理

这篇关于使用cc.SpriteAtlas 中批量资源管理的方式思考(如管理一副扑克牌)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

使用Docker构建Python Flask程序的详细教程

《使用Docker构建PythonFlask程序的详细教程》在当今的软件开发领域,容器化技术正变得越来越流行,而Docker无疑是其中的佼佼者,本文我们就来聊聊如何使用Docker构建一个简单的Py... 目录引言一、准备工作二、创建 Flask 应用程序三、创建 dockerfile四、构建 Docker

Python使用vllm处理多模态数据的预处理技巧

《Python使用vllm处理多模态数据的预处理技巧》本文深入探讨了在Python环境下使用vLLM处理多模态数据的预处理技巧,我们将从基础概念出发,详细讲解文本、图像、音频等多模态数据的预处理方法,... 目录1. 背景介绍1.1 目的和范围1.2 预期读者1.3 文档结构概述1.4 术语表1.4.1 核

C#读写文本文件的多种方式详解

《C#读写文本文件的多种方式详解》这篇文章主要为大家详细介绍了C#中各种常用的文件读写方式,包括文本文件,二进制文件、CSV文件、JSON文件等,有需要的小伙伴可以参考一下... 目录一、文本文件读写1. 使用 File 类的静态方法2. 使用 StreamReader 和 StreamWriter二、二进

Python使用pip工具实现包自动更新的多种方法

《Python使用pip工具实现包自动更新的多种方法》本文深入探讨了使用Python的pip工具实现包自动更新的各种方法和技术,我们将从基础概念开始,逐步介绍手动更新方法、自动化脚本编写、结合CI/C... 目录1. 背景介绍1.1 目的和范围1.2 预期读者1.3 文档结构概述1.4 术语表1.4.1 核

Conda与Python venv虚拟环境的区别与使用方法详解

《Conda与Pythonvenv虚拟环境的区别与使用方法详解》随着Python社区的成长,虚拟环境的概念和技术也在不断发展,:本文主要介绍Conda与Pythonvenv虚拟环境的区别与使用... 目录前言一、Conda 与 python venv 的核心区别1. Conda 的特点2. Python v

Spring Boot中WebSocket常用使用方法详解

《SpringBoot中WebSocket常用使用方法详解》本文从WebSocket的基础概念出发,详细介绍了SpringBoot集成WebSocket的步骤,并重点讲解了常用的使用方法,包括简单消... 目录一、WebSocket基础概念1.1 什么是WebSocket1.2 WebSocket与HTTP

C#中Guid类使用小结

《C#中Guid类使用小结》本文主要介绍了C#中Guid类用于生成和操作128位的唯一标识符,用于数据库主键及分布式系统,支持通过NewGuid、Parse等方法生成,感兴趣的可以了解一下... 目录前言一、什么是 Guid二、生成 Guid1. 使用 Guid.NewGuid() 方法2. 从字符串创建

Knife4j+Axios+Redis前后端分离架构下的 API 管理与会话方案(最新推荐)

《Knife4j+Axios+Redis前后端分离架构下的API管理与会话方案(最新推荐)》本文主要介绍了Swagger与Knife4j的配置要点、前后端对接方法以及分布式Session实现原理,... 目录一、Swagger 与 Knife4j 的深度理解及配置要点Knife4j 配置关键要点1.Spri

Python使用python-can实现合并BLF文件

《Python使用python-can实现合并BLF文件》python-can库是Python生态中专注于CAN总线通信与数据处理的强大工具,本文将使用python-can为BLF文件合并提供高效灵活... 目录一、python-can 库:CAN 数据处理的利器二、BLF 文件合并核心代码解析1. 基础合

Python使用OpenCV实现获取视频时长的小工具

《Python使用OpenCV实现获取视频时长的小工具》在处理视频数据时,获取视频的时长是一项常见且基础的需求,本文将详细介绍如何使用Python和OpenCV获取视频时长,并对每一行代码进行深入解析... 目录一、代码实现二、代码解析1. 导入 OpenCV 库2. 定义获取视频时长的函数3. 打开视频文