QT源码解析笔记

  

1. QT如何绘制控件的
  QT的绘制控件在QStyleSheetStyle::DrawControl里面,这里会调用默认的QSS来绘制效果

2. 在设置一次QSS以后,将会触发polish事件,里面将会一次设置大小,pallte和property等属性,在QWidget::event里面的polish事件的处理可以看出来 (在QWidget::Event里面会调用QStyleSheetStyle::polish)

3. 如何设置hover这些伪状态的变化:
  1. polish事件处理的时候通过设pattle来设置
  2. 在StyleSheet里面计算renderrule的时候

4. QT 是在哪里解析QSS的:
  在styleChange里面会触发解析QSS的代码,具体在:
  QVector<QCss::StyleRule> QStyleSheetStyle::styleRules

  styleSheetCaches里面会保存所有的qss的解析代码,在qstylesheetstyle.cpp里面的静态变量
  并且站styleRules的代码里面,会遍历所有的父亲拿到父亲的qss,然后查看是否有设置到自己的qss

  polish是根据解析后的stylesheet将对应的数值复制到对应的widget属性里面

5.d->inheritStyle()将会在调用setParent的时候调用,或者在QWidget::setStyleSheet里面有传播的选项,会将style往下传递(这里是针对style的,而StyleRule则是针对属性的)

  QWidgetPrivate::propagatePaletteChange
  这个函数会将palette往下传递

6. qt绘制控件是在qwidget.cpp里面的drawWidget里面的,将会递归绘制所有的控件,此函数是通过QEvent::UpdateRequest来调用的

7. QWidgetPrivate::paintSiblingsRecursive 在这里将会发送绘制事件给子控件,然后子控件的paintEvent负责绘制

QTextStream
QTextStream里面 fillReadBuffer有一个codec

QGraphics Framework
SceneRect 返回的是当前所有元素的boundRect,比如我加入一个text,位置在0, 0, 74, 22, 则sceneRect会返回0, 0 , 74, 22
加入我们又加入一个text2, 位置在100, 100,则SceneRect则会是0, 0, 174, 122 (text宽度为74, 22)

如何判断MousePress一个Item
cachedItemsUnderMouse: 利用item的boundRect计算出与鼠标位置组成的矩阵是否有intersect,然后利用shape()调用的函数与鼠标的矩形进行intersect,如果有话则代表有点击到

当Select一个Item以后,如何取消Select:
当Press以后,将会取消所有的item的select,然后再进行判断是否select

select以后,事件传递机制有什么变化

按钮设置为mask以后,如何只判断点击到mask里面
利用QRegion


QT的信号传输机制

同一个线程,同步传输

不同的线程,异步传输

 

posted @ 2019-06-12 21:03  linyilong  阅读(703)  评论(0编辑  收藏  举报