《QT从基础到进阶·二十二》QGraphicsView显示大量图形项item导致界面卡顿的解决办法

有时候因业务需要,paint函数在界面上绘制了成百上千个图形项Items,导致操作界面的时候有明显的卡顿感,下文会提供一种比较好的解决办法,先来了解下QGraphicsItem的缓存方式。

cpp 复制代码
(1)setCacheMode(QGraphicsItem::NoCache);  //默认方式,无缓存,实时进入paint刷新重绘

(2)setCacheMode(QGraphicsItem::CacheBackground); //只缓存背景(背景色或背景图片),前景仍然需要重新计算。

(3)setCacheMode(QGraphicsItem::DeviceCoordinateCache); //将整个项缓存在设备坐标系中,并且只有在位置、大小或外观发生变化时才需要重新计算。这是最常用和最有效的缓存模式(项目较少使用旋转、缩放、剪切)

(4)setCacheMode(QGraphicsItem::ItemCoordinateCache );  //项目较多使用旋转,缩放,剪切等功能,但图形呈现质量较差。

在Item调用方式3或者直接在item构造中设置方式3能有效避免界面卡顿问题,如果图形项涉及大量的旋转,缩放,剪切,则方式3效果会和方式1差不多,基本没啥效果,界面依旧卡顿,这时就应该用方式4。

请注意,在某些情况下使用缓存可能会导致问题。例如,如果您的项的位置或大小经常更改,则需要清除该项的缓存以确保正确性。可以通过调用invalidate()函数来清除该项的缓存:

cpp 复制代码
item->setPos(0, 0); //修改位置
item->invalidate(); //清除缓存

总结:

如果你的 QGraphicsItem::paint 操作过于复杂,并且大部分是静态的,那么尝试启用缓存.如果您没有对项目或 ItemCoordinateCache 应用转换(如旋转),请使用 DeviceCoordinateCache.避免经常调用 QGraphicsItem::update() ,否则它会比没有缓存更慢。如果您需要更改项目中的某些内容,两个选项是:在子项中绘制它,或使用 QGraphicsView::drawForeground()前景层。

📢博客主页: 主页

📢欢迎点赞 👍 收藏 ⭐留言 📝 如有错误敬请指正!

📢本文由 梦回阑珊 原创,首发于 CSDN,转载注明出处🙉

📢代码改变世界,你来改变代码!✨

相关推荐
白露与泡影11 小时前
Java面试题库及答案解析(2026版)
java·开发语言·面试
wsoz11 小时前
Leetcode普通数组-day5、6
c++·算法·leetcode·数组
favour_you___11 小时前
2026_4_8算法练习题
数据结构·c++·算法
疯狂成瘾者11 小时前
Chroma向量数据库
开发语言·数据库·c#
我是唐青枫11 小时前
C#.NET Monitor 与 Mutex 深入解析:进程内同步、跨进程互斥与使用边界
开发语言·c#·.net
bbq粉刷匠11 小时前
Java--剖析synchronized
java·开发语言
ou.cs11 小时前
c# 信号量和锁的区别
开发语言·c#
Gofarlic_OMS11 小时前
装备制造企业Fluent许可证成本分点典型案例
java·大数据·开发语言·人工智能·自动化·制造
Freak嵌入式11 小时前
MicroPython LVGL基础知识和概念:显示与多屏管理
开发语言·python·github·php·gui·lvgl·micropython
SccTsAxR11 小时前
算法基石:手撕离散化、递归与分治
c++·经验分享·笔记·算法