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

相关文章

网页解析 lxml 库--实战

lxml库使用流程 lxml 是 Python 的第三方解析库,完全使用 Python 语言编写,它对 XPath表达式提供了良好的支 持,因此能够了高效地解析 HTML/XML 文档。本节讲解如何通过 lxml 库解析 HTML 文档。 pip install lxml lxm| 库提供了一个 etree 模块,该模块专门用来解析 HTML/XML 文档,下面来介绍一下 lxml 库

Vue3 的 shallowRef 和 shallowReactive:优化性能

大家对 Vue3 的 ref 和 reactive 都很熟悉,那么对 shallowRef 和 shallowReactive 是否了解呢? 在编程和数据结构中,“shallow”(浅层)通常指对数据结构的最外层进行操作,而不递归地处理其内部或嵌套的数据。这种处理方式关注的是数据结构的第一层属性或元素,而忽略更深层次的嵌套内容。 1. 浅层与深层的对比 1.1 浅层(Shallow) 定义

HarmonyOS学习(七)——UI(五)常用布局总结

自适应布局 1.1、线性布局(LinearLayout) 通过线性容器Row和Column实现线性布局。Column容器内的子组件按照垂直方向排列,Row组件中的子组件按照水平方向排列。 属性说明space通过space参数设置主轴上子组件的间距,达到各子组件在排列上的等间距效果alignItems设置子组件在交叉轴上的对齐方式,且在各类尺寸屏幕上表现一致,其中交叉轴为垂直时,取值为Vert

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

这15个Vue指令,让你的项目开发爽到爆

1. V-Hotkey 仓库地址: github.com/Dafrok/v-ho… Demo: 戳这里 https://dafrok.github.io/v-hotkey 安装: npm install --save v-hotkey 这个指令可以给组件绑定一个或多个快捷键。你想要通过按下 Escape 键后隐藏某个组件,按住 Control 和回车键再显示它吗?小菜一碟: <template

HDFS—存储优化(纠删码)

纠删码原理 HDFS 默认情况下,一个文件有3个副本,这样提高了数据的可靠性,但也带来了2倍的冗余开销。 Hadoop3.x 引入了纠删码,采用计算的方式,可以节省约50%左右的存储空间。 此种方式节约了空间,但是会增加 cpu 的计算。 纠删码策略是给具体一个路径设置。所有往此路径下存储的文件,都会执行此策略。 默认只开启对 RS-6-3-1024k

如何用Docker运行Django项目

本章教程,介绍如何用Docker创建一个Django,并运行能够访问。 一、拉取镜像 这里我们使用python3.11版本的docker镜像 docker pull python:3.11 二、运行容器 这里我们将容器内部的8080端口,映射到宿主机的80端口上。 docker run -itd --name python311 -p

性能分析之MySQL索引实战案例

文章目录 一、前言二、准备三、MySQL索引优化四、MySQL 索引知识回顾五、总结 一、前言 在上一讲性能工具之 JProfiler 简单登录案例分析实战中已经发现SQL没有建立索引问题,本文将一起从代码层去分析为什么没有建立索引? 开源ERP项目地址:https://gitee.com/jishenghua/JSH_ERP 二、准备 打开IDEA找到登录请求资源路径位置

使用opencv优化图片(画面变清晰)

文章目录 需求影响照片清晰度的因素 实现降噪测试代码 锐化空间锐化Unsharp Masking频率域锐化对比测试 对比度增强常用算法对比测试 需求 对图像进行优化,使其看起来更清晰,同时保持尺寸不变,通常涉及到图像处理技术如锐化、降噪、对比度增强等 影响照片清晰度的因素 影响照片清晰度的因素有很多,主要可以从以下几个方面来分析 1. 拍摄设备 相机传感器:相机传

OpenHarmony鸿蒙开发( Beta5.0)无感配网详解

1、简介 无感配网是指在设备联网过程中无需输入热点相关账号信息,即可快速实现设备配网,是一种兼顾高效性、可靠性和安全性的配网方式。 2、配网原理 2.1 通信原理 手机和智能设备之间的信息传递,利用特有的NAN协议实现。利用手机和智能设备之间的WiFi 感知订阅、发布能力,实现了数字管家应用和设备之间的发现。在完成设备间的认证和响应后,即可发送相关配网数据。同时还支持与常规Sof