一.主要理解一下几个方法和属性:
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()来获得属性值。
相关推荐
qt update函数的理解: update()用来更新绘图事件,重新绘制图片。下面有个demo可以运行一下,一目了突然。
代码用了抽象的概念,将三种图形抽象成了一个myShape,在代码中的体现就是定义了一个基类myShape类,其他所有的图像类都继承自这个基类,然后在每个子类中都添加了drawShape()方法,这样在界面的paintEvent...
实现了一些角度随机旋转、噪点绘制的方法,通过使用随机数随机选中范围中的值和颜色,并对值进行随机的角度旋转,再加上一些起干扰效果的噪点,把绘制路径记录下来,在paintEvent事件里面绘制行形成的图形。...
实现mouseMoveEvent鼠标移动事件当我们的鼠标发生移动的时候记录两个坐标值,一个为移动起始坐标,一个为移动后的坐标,然后调用update重新绘画我们的页面,在paintEvent绘画事件中我们使用QPainter绘画直线,因为...
Qt实现图像的读取、鼠标位置缩放图像、移动图像
基于Qt5.5.1 + msvc2013 环境,使用paintEvent事件对QWidget进行重绘,形成自定义进度条控件。具备进度修改、颜色修改和大小修改等功能,适合初学者观看。
本统计图是一个填充了渐变颜色的曲线统计图,X轴显示了从今天往前倒推一周的日期,Y轴则显示的是时间的统计,目前只做了统计到“分”的计算,可以用于统计一周的运动时间、学习时间等...开发环境用的Qt5.5.1+MSVC2013。
本资源为Qt绘图基础,世界坐标系转换为逻辑坐标系。世界坐标系原点在视图左上角,本例子通过世界坐标转换,将坐标原点定位在视图中央,Y轴向上,X轴向右,并绘制坐标轴,基于逻辑坐标系下的绘图,可将转换关系函数...
Qt的事件过滤器 Qt事件模型一个真正强大的特色是一个QObject 的实例能够管理另一个QObject 实例的事件。 让我们试着设想已经有了一个CustomerInfoDialog的小部件。CustomerInfoDialog 包含一系列QLineEdit. 现在...
首先定义类来自定义图形,这里通过paintEvent事件来实现(主要就是绘画一个图形) void QEventView::paintEvent(QPaintEvent *event) { resize(115+m_iLen,36); QPainter painter(this); painter.setRenderHint...
用Qt鼠标事件实现基本几何图形的绘制,支持直线、矩形、圆形、椭圆。后期可以在此基础上进行扩展。使用QGraphics完成。 本示例使用QGraphics体系来实现,因为要移动对象,所以生成的图形必须是一个单独的对象,鼠标...
最近在封装一些类的时候,打算做一个窗口框架,能实现拖动、无边框、透明基本样式等功能 ...第二步: 重写paintEvent事件并使用QPainter画透明层。 void paintEvent(QPaintEvent *) { QPainter painter(this);
最简单的方式实现了无边框窗口的阴影,不需要重写paintEvent即可实现,PushButton的阴影也在代码中实现了!
主要通过重写paintEvent、mousePressEvent、mouseMoveEvent,根据鼠标点击和移动绘制线段,并可以计算所有绘制的线段的长度。
自己编写的QT自定义圆形进度条,内有中文注释,比较清晰,兼容QT4以及QT5版本,支持Windows以及Linux,交叉编译可放在嵌入式Linux下运行,才用QTpaintEvent画图,使用者可根据源码进行改进,从而来编写属于自己的...
用过滤器的方式,实现在Frame和Widget子部件上画图,很有启发性!
气泡是在paintEvent事件中,采用QPainter来绘制的。 2、更新信息 开发者:沙振宇(沙师弟专栏) 创建时间:2018-07-23 最后一次更新时间:2019-12-27 此项目CSDN博客:Qt5气泡式聊天框——QListWidget+QPainter实现 ...
qt5.11.2 mingw编译,通过paintEvent事件进行环形渐变绘制,用QTimer定时器使其运动
做了一个电池的进度条,加了警示色和正常色的判断,还加了一些动画效果,分享一下,适合初学者,开发环境是Qt5.14.2+MSVC2017。