亲宝软件园·资讯

展开

Qt update刷新之源码分析(二)

IT文艺男 人气:0
大家好,我是IT文艺男,来自一线大厂的一线程序员 上次视频给大家从源码层面剖析了Qt update刷新机制的异步事件投递过程,这次视频主要从源码层面剖析Qt刷新事件(QEvent::UpdateRequest)的处理过程 我们追踪QEvent::UpdateRequest事件处理,进入消息通知流程,即`QApplication::notify(QObject *receiver, QEvent *e)`函数(没有对QEvent::UpdateRequest事件进行处理),进一步由`QApplicationPrivate::notify_helper(QObject *receiver, QEvent * e)`函数处理;如下图所示:: ![notify_helper函数](https://img2020.cnblogs.com/blog/371367/202102/371367-20210227233153667-1226813032.png) **函数主体内容如下::** **1、application的事件过滤器处理,即全局的事件过滤处理** **2、receiver的事件过滤器处理,即当前窗口的事件过滤处理** **3、调用receiver的event函数处理,即当前窗口的事件处理** receiver的event函数不做处理,如下图所示:: ![event函数](https://img2020.cnblogs.com/blog/371367/202102/371367-20210227233353076-1807293953.png) 其调用父类的event函数,即`bool QWidget::event(QEvent *event)`函数,该函数中针对事件类型进行处理(switch case),如下图所示:: ![QWidget::event函数](https://img2020.cnblogs.com/blog/371367/202102/371367-20210227233502598-1638320403.png) 对于QEvent::UpdateRequest事件,则调用syncBackingStore函数,如下图所示:: ![syncBackingStore函数](https://img2020.cnblogs.com/blog/371367/202102/371367-20210227233532730-205573496.png) **函数主体内容如下::** **1、获取tlw的QWidgetBackingStore** **2、调用sync函数** ![sync函数](https://img2020.cnblogs.com/blog/371367/202102/371367-20210227233616560-985212329.png) ![doSync函数](https://img2020.cnblogs.com/blog/371367/202102/371367-20210227233650086-1311113204.png) `QWidgetBackingStore::doSync`函数中调用`tlw->d_func()->drawWidget(store->paintDevice(), dirtyCopy, QPoint(), flags, 0, this)`;函数进行绘制,函数的第一个参数是获取绘制设备,各个平台返回自己的绘制设备,例如对于Windows平台 ![paintDevice函数](https://img2020.cnblogs.com/blog/371367/202102/371367-20210227233715612-803577935.png) *qwindowsbackingstore.cpp文件位于qtbase\src\plugins\platforms\windows目录;* 今天就讲解到这里,总结下整体思路即是从事件处理到绘制的过程分析,很清晰; 下次视频进行源码剖析Qt update刷新机制的绘制过程;谢谢

加载全部内容

相关教程
猜你喜欢
用户评论