原文地址::https://blog.csdn.net/wangqing_12345/article/details/51520208?locationNum=5&fps=1
相关文章
1、QT之paintEvent事件----https://blog.csdn.net/Code_Thinking/article/details/38820301
2、QT关键问题解决之paintevent理解----https://blog.csdn.net/u012151242/article/details/78947024
3、QT 绘制 局部刷新的N中方法----https://blog.csdn.net/yjzl1911/article/details/46987647
4、第五章 Qt双缓冲(double buffering)----https://blog.csdn.net/HelloZEX/article/details/78319263
5、QT 界面绘制刷新机制----https://blog.csdn.net/calmreason/article/details/98753548
6、Qt重绘之update,repaint详解----https://blog.csdn.net/lindyl/article/details/10913199
7、Qt QRegion裁剪区域实现部分区域刷新 避免闪烁区域太大----https://blog.csdn.net/u013255206/article/details/70312818
8、QT5双缓冲绘图简单代码----https://blog.csdn.net/xiaodong60606/article/details/47125513
9、QT中双缓冲加速绘制-----https://blog.csdn.net/wb175208/article/details/82464342
10、QT 双缓冲绘图----https://blog.csdn.net/qq_41768362/article/details/95042416
一.主要理解一下几个方法和属性:
1.QWidget * QScrollView::viewport () const
2.void QWidget::paintEvent ( QPaintEvent * ) [虚 保护]
3.void QWidget::repaint ( int x, int y, int w, int h, bool erase = TRUE ) [槽]
4.void QWidget::update () [槽]
5.void QWidget::erase ( int x, int y, int w, int h )
6.bool updatesEnabled
二.现分别详细介绍:
1.QWidget * QScrollView::viewport () const
返回滚动视图中的视口窗口部件,这个窗口部件包含内容窗口部件或者要画的区域。
2.void QWidget::paintEvent ( QPaintEvent * ) [虚 保护]
只要窗口部件需要被重绘就被调用。每个要显示输出的窗口部件必须实现它。这个事件处理器可以在子类中被重新实现来接收绘制事件。 它可以是repaint()或update()的结果。 很多窗口部件在当它们被请求时,它们很简单地重新绘制整个界面,但是一些窗口部件通过仅仅绘制被请求的区域QPaintEvent::region()进 行优化,例如,QListView和QCanvas就是这样做的。
Qt也可通过把多个绘制事件合并为一个来加快绘制速度。当update()被调用几次或者窗口系统发送几次绘制事件,Qt把它们合并为 一个比较大区域(请参考QRegion::unite())的一个事件中。repaint()不允许这样优化,所以只要可能我们尽量使用update ()。
当绘制事件发生,更新区域通常被擦除。这里有一些例外,通过QPaintEvent::erased()可以得知这个窗口部件是否被擦除。
3.void QWidget::repaint ( int x, int y, int w, int h, bool erase = TRUE ) [槽]
通过立即调用paintEvent()来直接重新绘制窗口部件,如果erase为真,Qt在paintEvent()调用之前擦除区域 (x,y,w,h)。 如果w是负数,它被width()-x替换,并且如果h是负数,它被height()-y替换。 如果你需要立即重新绘制,建议使用repaint(),比如在动画期间。在绝大多数情况下,update()更好,因为它允许Qt来优化速度并且防止闪 烁。 警告:如果你在一个函数中调用repaint(),而它自己又被paintEvent()调用,你也许会看到无线循环。update()函数从来不会产生 循环。
4.void QWidget::update () [槽]
更新窗口部件,当Qt回到主事件中时,它规划了所要处理的绘制事件。这样允许Qt进行优化从而得到比调用repaint()更快的速度和更 少的闪烁。 几次调用update()的结果通常仅仅是一次paintEvent()调用。 Qt通常在paintEvent()调用之前擦除这个窗口部件的区域,仅仅只有在WRepaintNoErase窗口部件标记被设置的时候才不会。
5.void QWidget::erase ( int x, int y, int w, int h )
在窗口部件中擦除指定区域(x, y, w, h),并不产生绘制事件。
如果w为负数,它被width()-x替换。如果h为负数,它被height()-y替换。
子窗口部件不被影响。
6.bool updatesEnabled
这个属性保存的是更新是否生效。
如果更新失效,调用update()和repaint()是没有效果的。如果更新失效,来自窗口系统的绘制事件会被正常处理。 setUpdatesEnabled()通常被用于在一小段事件内使更新失效,例如为了避免在大的变化期间发生屏幕闪烁。
实例:
setUpdatesEnabled( FALSE );
bigVisualChanges();
setUpdatesEnabled( TRUE );
repaint();
通过setUpdatesEnabled()设置属性值并且通过isUpdatesEnabled()来获得属性值。
————————————————
版权声明:本文为CSDN博主「此去经年.COM」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/wangqing_12345/article/details/51520208
本文深入探讨了QT中绘画与刷新机制的关键概念,包括paintEvent、repaint与update方法的区别和应用,以及双缓冲绘图的优化技巧。通过具体实例,帮助读者理解如何在QT应用程序中实现高效、流畅的界面绘制。

1437

被折叠的 条评论
为什么被折叠?



