Cocos Creator3.8 项目实战(九)2D UI DrawCall优化详解(下)

2023-10-10 07:28

本文主要是介绍Cocos Creator3.8 项目实战(九)2D UI DrawCall优化详解(下),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!


上一篇文章中,我们详细介绍了: 什么是Draw call ? Draw Call 中造成性能问题的原因是什么?以及在 Cocos Creator 项目中如何减少DrawCall ?感兴趣的朋友可以前往阅读:Cocos Creator3.8 项目实战(八)2D UI DrawCall优化详解(上)。


今天主要介绍一下,DrawCall 优化案例,以及实践过程中对DrawCall优化的经验总结,希望帮助到有需要的朋友,进一步加深对DrawCall 优化的理解。


一、DrawCall优化案例


假如这里需要做一个弹窗, 由 10 张碎图和 1 个文本所组成:

  1. 不做任何优化且未开启动态合图的情况下,渲染这个弹窗需要 11 个 DrawCall
  2. 将所有碎图打成一个图集,文本节点夹在精灵节点之间的情况下,需要 3 个 DrawCall。在顶部最外层或者底部最外层的情况下,需要 2 个 DrawCall。
  3. 文本使用 BMFont,将所有碎图和 BMFont 打成一个图集的话只需要 1 个 DrawCall,如果碎图不和 BMFont 打成一个图集的情况,则参考第 2 项。
  4. 碎图不打包图集,开启动态合图,在理想情况下,文本使用 BMFont 最少只需要 1 个 DrawCall,不使用 BMFont 的情况同样参考第 2 项。

二、关于DrawCall优化的建议


1、静态合图方式选择建议

对于自动资源合图和手动资源合图的方式选择上, 可根据实际 Draw Call需要优化的程度来进行合理选择。

  • 如果为了简单方便,可优先使用自动图集资源的方式。
  • 如果对Draw Call性能优化要求较高,可选择手动图集资源的方式。

但是无论选择哪种方式,请别忘了,遵循 尽量将处于同一界面(UI)下的相邻且渲染状态相同的碎图的原则。


2、动态合图使用建议

  • 尽量防止不同图集的UI元素互相的打乱

  • 尽量防止Label的打断

  • 组织UI组件尽可能的是下面的方式

    Label1 Label2 Label3 Label4 Label5

    Sprite1 Sprite2 Sprite3 Sprite4 Sprite5

    组织UI图集资源尽可能的是下面的方式:

    A1 A2 A3 A4 A5

    B1 B2 B3 B4 B5

    不同的图集在一起

    不要这样组织UI组件图集资源:
    A1B1 A2 B2 A3 B3 …


3、关于自动图集的几点建议

  • 合理控制图集最大尺寸,避免单个图像加载时间过长

  • 尺寸太大的图像没有必要打进图集(如背景图)

  • 善用九宫格(Sliced)可以节省很多空间

  • 间距保持默认的 2 并保持勾选扩边选项,避免图像裁剪错误和出现黑边的情况

  • 勾选不包含未被引用资源选项,自动排除没有用到的图像以节省空间(该选项预览时无效)

  • 开发时预览图集,根据结果进行调整,以达到最好的优化效果

  • 不建议任何图像资源的尺寸超过 2048 * 2048,否则在小游戏和原生平台可能会出现问题

    而且图像尺寸越大,加载的时间也越长,而且是非线性的那种增长,例如加载一张图像比加载两张图像所消耗的时间还长,得不偿失。


这篇关于Cocos Creator3.8 项目实战(九)2D UI DrawCall优化详解(下)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Nginx实现高并发的项目实践

《Nginx实现高并发的项目实践》本文主要介绍了Nginx实现高并发的项目实践,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录使用最新稳定版本的Nginx合理配置工作进程(workers)配置工作进程连接数(worker_co

Flutter监听当前页面可见与隐藏状态的代码详解

《Flutter监听当前页面可见与隐藏状态的代码详解》文章介绍了如何在Flutter中使用路由观察者来监听应用进入前台或后台状态以及页面的显示和隐藏,并通过代码示例讲解的非常详细,需要的朋友可以参考下... flutter 可以监听 app 进入前台还是后台状态,也可以监听当http://www.cppcn

C++ Primer 标准库vector示例详解

《C++Primer标准库vector示例详解》该文章主要介绍了C++标准库中的vector类型,包括其定义、初始化、成员函数以及常见操作,文章详细解释了如何使用vector来存储和操作对象集合,... 目录3.3标准库Vector定义和初始化vector对象通列表初始化vector对象创建指定数量的元素值

MyBatis与其使用方法示例详解

《MyBatis与其使用方法示例详解》MyBatis是一个支持自定义SQL的持久层框架,通过XML文件实现SQL配置和数据映射,简化了JDBC代码的编写,本文给大家介绍MyBatis与其使用方法讲解,... 目录ORM缺优分析MyBATisMyBatis的工作流程MyBatis的基本使用环境准备MyBati

Java嵌套for循环优化方案分享

《Java嵌套for循环优化方案分享》介绍了Java中嵌套for循环的优化方法,包括减少循环次数、合并循环、使用更高效的数据结构、并行处理、预处理和缓存、算法优化、尽量减少对象创建以及本地变量优化,通... 目录Java 嵌套 for 循环优化方案1. 减少循环次数2. 合并循环3. 使用更高效的数据结构4

Spring AI与DeepSeek实战一之快速打造智能对话应用

《SpringAI与DeepSeek实战一之快速打造智能对话应用》本文详细介绍了如何通过SpringAI框架集成DeepSeek大模型,实现普通对话和流式对话功能,步骤包括申请API-KEY、项目搭... 目录一、概述二、申请DeepSeek的API-KEY三、项目搭建3.1. 开发环境要求3.2. mav

Nginx中location实现多条件匹配的方法详解

《Nginx中location实现多条件匹配的方法详解》在Nginx中,location指令用于匹配请求的URI,虽然location本身是基于单一匹配规则的,但可以通过多种方式实现多个条件的匹配逻辑... 目录1. 概述2. 实现多条件匹配的方式2.1 使用多个 location 块2.2 使用正则表达式

spring @EventListener 事件与监听的示例详解

《spring@EventListener事件与监听的示例详解》本文介绍了自定义Spring事件和监听器的方法,包括如何发布事件、监听事件以及如何处理异步事件,通过示例代码和日志,展示了事件的顺序... 目录1、自定义Application Event2、自定义监听3、测试4、源代码5、其他5.1 顺序执行

Java之并行流(Parallel Stream)使用详解

《Java之并行流(ParallelStream)使用详解》Java并行流(ParallelStream)通过多线程并行处理集合数据,利用Fork/Join框架加速计算,适用于大规模数据集和计算密集... 目录Java并行流(Parallel Stream)1. 核心概念与原理2. 创建并行流的方式3. 适

web网络安全之跨站脚本攻击(XSS)详解

《web网络安全之跨站脚本攻击(XSS)详解》:本文主要介绍web网络安全之跨站脚本攻击(XSS)的相关资料,跨站脚本攻击XSS是一种常见的Web安全漏洞,攻击者通过注入恶意脚本诱使用户执行,可能... 目录前言XSS 的类型1. 存储型 XSS(Stored XSS)示例:危害:2. 反射型 XSS(Re