1、QGridLayout QGridLayout包含多个grid,它并没有要求其中的每个grid的size相同,通常情况下,每个grid的size是不同的。 对于成员函数addWidget(widget, fromRow, fromColumn, rowSpan, columnSpan, alignment):rowSpan表示新添加进来的widget在垂直方向上跨越或者占据多少个grid。 columnSpan表示新添加进来的widget在水平方向上跨越或者占据多少个grid。 2、line edit的input mask 对一个line edit设置了input mask属性后,也就限定了输入字符。一般情况下,需要填写的字符位置是空白的,但是,你可以让该空白以某个字符占位,你只需在指定input mask的字符末尾添加“*?”即可,把‘?’换为你想用来占位的一个字符。 3、利用designer设计ui 总体上来说,先创建各个控件,然后设置layout相对来说好些。另外,grid layout对设置布局前的窗口布局依赖比较大,即如果设置grid layout前的布局不同,则生效后的差别可能较大。 4、QLabel的buddy属性 在qt中,只有QLabel实现了buddy机制。 只有你为QLabel设置了buddy后,文本中的字符‘&’才能以下划线显示(这点与其他widget不同),并创建了对应的快捷键(当然,需要+Alt),然后可以利用快捷键迅速的把光标定位到该QLabel的buddy中,例如: QLabel *what = new QLabel("Find &What:"); 该实例对应快捷键Alt+w。 5、QMouseEvent中的坐标 QMouseEvent中保存了两个坐标,一个是全局坐标,当然另外一个是局部坐标。 全局坐标(globalPos())即是桌面屏幕坐标(screen coordinates),这个跟windows下的调用getCursorPos函数得到的结果一致。 局部坐标(pos())即是相对当前active widget的坐标,左上角坐标为(0, 0)。 补充一个公式: this->mapFromGlobal(this->cursor().pos()) = event.pos() 6、鼠标跟踪 在qt中,鼠标跟踪对应函数mouseMoveEvent。但是,默认情况下他并不能如期象你想象的那样响应鼠标的移动。此时,你只需在合适的位置调用一下函数setMouseTracking(true)即可。 默认情况下,mouseMoveEvent响应你按下鼠标的某个键(拖动,但不局限于左键拖动)的鼠标移动。 7、鼠标左键拖动和左键点击的判断 鼠标左键点击很容易判断,一般就是在重写mousePressEvent函数,示例如下: void XXXWidget::mousePressEvent(QMouseEvent *event) { if(event->button() == Qt:eftButton) { // todo ... } } 左键拖动的判断一般放在mouseMoveEvent函数中,但是你不能向上例一样来判断,因为该函数的event参数总是返回Qt::NoButton。你可以这样做: void XXXWidget::mouseMoveEvent(QMouseEvent *event) { if(event->buttons() & Qt:eftButton) { // todo ... } } 8、窗口有一个子窗口,子窗口随着父窗口最小化而最小化的实现: child = new QWidget(parent); child->setWindowFlags(Qt::Window); 但是,如果父子窗口都显示的话,此时销毁父窗口,子窗口依然显示;然后关闭子窗口,才算完全关闭了整个窗口。理想的做法是这样的: child = new QWidget(parent); child->setWindowFlags(Qt::Window | Qt::SubWindow); |
qt开发总结
最新推荐文章于 2022-09-26 07:47:27 发布