FairyGUI学习

DrawCall优化

知识点一 DrawCall是什么?

DC就是CPU通知GPU进行一次渲染的命令

如果DC次数较多会导致游戏卡顿

我们可以通过打图集,将小图合并成大图,将本应n次的DC变成1次DC来提高性能

知识点二 FairyGUI 和 UGUI以及NGUI的 DrawCall优化异同

相同点:

3种UI都是通过打图集来优化DC

不同点:

UGUI和NGUI的UI元素层级会影响DC的数量,我们拼UI时,要注意不同图集的UI元素的层级关系

FairyGUI中不用太过在意UI元素的层级,它会帮助我们进行深度调整

FairyGUI采用了Unity的动态批处理技术,提供了深度调整技术进行DC优化

动态批处理:cpu每帧把可以进行动态批处理的网格进行合并,再把合并后的数据传给gpu,使用同一个材质对其渲染,达到降低DC的目的

知识点三 FairyGUI中优化DrawCall的关键步骤
cs 复制代码
  TeachPanel panel = UIManager.Instance.ShowPanel<TeachPanel>("Teach");

1.打开Unity中的动态批处理 File------>Build Setting------>PlayerSetting------>Other Setting------>Dynamic Batching

2.将组件的fairyBatching属性设置为true

cs 复制代码
    panel.fairyBatching = true;

**注意:**某个组件设置了fairyBatching,那么无需在子组件和孙子组件再启用fairyBatching

一般只在顶层组件打开这个功能(面板组件)

永远不要在GRoot 上开启fairyBatching

知识点四 手动触发深度调整

对于打开了fairyBatching 的组件

当自己调用SetPositionAPI 改变子元件或者孙子元件的位置、大小,旋转或缩放

并不会自动触发深度调整

例如:一个图片原来显示在一个窗口里的顶层,你将它从原来的位置移到另外一个位置,这个图片就有可能被窗口里的其他元素遮挡,这时开发者需要手动触发深度调整GObject 中的InvalidateBatchingState 方法

cs 复制代码
 panel.InvalidateBatchingState();

注意:这个API并不需要由开启了fairyBatching 的组件调用

可以是任何一个内含的元件

相关推荐
阿蒙Amon15 小时前
TypeScript学习-第10章:模块与命名空间
学习·ubuntu·typescript
AI绘画哇哒哒15 小时前
【干货收藏】深度解析AI Agent框架:设计原理+主流选型+项目实操,一站式学习指南
人工智能·学习·ai·程序员·大模型·产品经理·转行
ujainu15 小时前
Flutter + OpenHarmony 游戏开发进阶:用户输入响应——GestureDetector 实现点击发射
flutter·游戏·openharmony
hudawei99615 小时前
TweenAnimationBuilder和AnimatedBuilder两种动画的比较
flutter·ui·动画·tweenanimation·animatedbuilder
ujainu15 小时前
Flutter + OpenHarmony 实现无限跑酷游戏开发实战—— 对象池化、性能优化与流畅控制
flutter·游戏·性能优化·openharmony·endless runner
戌中横15 小时前
JavaScript——预解析
前端·javascript·学习
●VON16 小时前
React Native for OpenHarmony:2048 小游戏的开发与跨平台适配实践
javascript·学习·react native·react.js·von
依米阳光0816 小时前
Playwright MCP AI实现自动化UI测试
ui·自动化·playwright·mcp
ZH154558913116 小时前
Flutter for OpenHarmony Python学习助手实战:自动化脚本开发的实现
python·学习·flutter
xcLeigh16 小时前
Python入门:Python3 requests模块全面学习教程
开发语言·python·学习·模块·python3·requests