关于兄弟QWidget间的位置重叠
转自:http://hi.baidu.com/dbzhang800/item/a7bf1f1e983c6af964eabf45?qq-pf-to=pcqq.group
缘起
csdn上一用户抱怨:她的 connectSlotsByName 不起作用,给出的证据如下:
MainWindow::MainWindow(QWidget *parent) :
QMainWindow(parent),
ui(new Ui::MainWindow)
{
QPushButton *btn=new QPushButton(this);
btn->setObjectName("TestButton");
btn->setText("test");
btn->setGeometry(50,70,100,150);
QMetaObject::connectSlotsByName(this);
ui->setupUi(this);
}
MainWindow头文件中将on_TestButton_clicked声名为槽,实现文件中如下:
public slots:
void MainWindow::on_TestButton_clicked()
{
QObject *obj=sender();
qDebug("TestButton is clicked);
}初步分析
首先我们看到,QPushButton的用法存在问题。我们知道 QMainWindow是由菜单栏、工具栏、状态栏、中心Widget、停靠Widget等构成的,QMainWindow的使用就是使用这些部件。这儿他创建了QMainWindow 的直接子对象,而不是放到中心Widget或停靠Widget中。
但是,尽管违背了QMainWindow原则,由于QMainWindow只不过是QWidget的子类,所以从QWidget角度看,还是不应该出现这个楼主的抱怨才对。但测试了一下:确实有问题,QPushButton不响应鼠标事件(去掉中心Widget后按钮正常)。
一开始脑袋发昏,考虑了一下:是不是QMainWindow为其他子对象设置的事件过滤器呢?按该思路走,未果。
然后回归正途:中心Widget和这儿手动布局的QPushButton位置重合!
什么状况
多个的同级 Widget 位置重合了,怎么办?谁先谁后?谁在上面?
到这儿其实就很简单了,调整顺序,相关的成员函数:
- QWidget::stackUnder
- QWidget::raise
- QWidget::lower
然后,对于这个问题, 解决起来就很简单了。只需在构造函数的最后,加一行:
btn->raise();
即可。(注意:本文的目的是指告诉你为什么会出现这种问题。要从根本上解决问题,请老老实实按QMainWindow的用法使用;如果像本文这样用的话,其实就没必要用QMainWindow了,因为也发挥不了QMainWindow的威力。)
完整的例子
import sys
from PySide import QtGui
app = QtGui.QApplication(sys.argv)
p = QtGui.QWidget()
p.resize(400, 300)
c1 = QtGui.QPushButton("Push", p)
c2 = QtGui.QWidget(p)
c1.setGeometry(0, 0, 200, 200)
c2.setGeometry(0, 0, 200, 200)
#c1.raise_()
#c2.lower()
p.show()
sys.exit(app.exec_())
c1(按钮) 和 c2(普通的Widget) 是同级Widget,先创建的c1会被后创建的c2覆盖,要让c1在上面,需要调整二者在父对象堆栈中的顺序。c1上升或c2下降。
http://blog.csdn.net/zzwdkxx/article/details/38979165
关于兄弟QWidget间的位置重叠的更多相关文章
- vue中兄弟组件间通讯
vue2.0中兄弟组件间的通讯是通过eventBus(事件发布订阅)实现的. eventBus.js import Vue from 'vue' const eventBus = new Vue() ...
- Vue2.5开发去哪儿网App 城市列表开发之 兄弟组件间联动及列表性能优化
一, 兄弟组件间联动 1. 点击城市字母,左侧对应显示 给遍历的 字母 添加一个点击事件: Alphabet.vue @click="handleLetterClick" ha ...
- Vue2不使用Vuex如何实现兄弟组件间的通信
在一些正规的大型项目的企业级开发过程中我们一般会引入Vuex来对Vue所有组件进行状态管理,可以轻松实现各组件间的通信.但是有时候做做自己的小项目,没有必要使用Vuex时,如何简单的实现组件间的通信? ...
- Vue-组件传值:子传父和兄弟组件间常见的传值方式
前言 上篇介绍了我对vue组件化的理解和父组件对子组件传值的方式,这篇介绍下常见的子传父和兄弟组件间的传值方式 目录 子组件向父组件传值 任意组件间的传值方式 正文 子组件向父组件传值 关键知识点:$ ...
- vue中兄弟组件间 的传值 bus(可以理解为公共交通)
点击大儿子(头部组件的年月日,下面的都要变化) 就相当于点击了年月日之后,下面的组件重新调接口,参数变化 1.首先随便哪儿写个bus.js 内容如下: import Vue from 'v ...
- C语言使用memcpy函数实现两个数间任意位置的复制操作
c和c++使用的内存拷贝函数,memcpy函数的功能是从源src所指的内存地址的起始位置开始拷贝n个字节到目标dest所指的内存地址的起始位置中. 用法:void *memcpy(void *dest ...
- Vue 使用eventBus 实现兄弟组件间的通信
实现方式: 主要是在相互通信的兄弟组件之中,都引入一个新的vue实例,然后通过分别调用这个实例的事件触发事件广播 和监听来实现通信和参数传递. 需求: a页面tree的增删改后,数据还是之前的老数据 ...
- Exchanger兄弟线程间数据信息交换
一.简述 Exchanger可以在两个线程之间交换数据,只能是2个线程,他不支持更多的线程之间互换数据.当线程A调用Exchange对象的exchange()方法后,他会陷入阻塞状态,直到线程B也调用 ...
- Vue中兄弟组件间传值-(Bus/总线/发布订阅模式/观察者)
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
随机推荐
- Android 网络框架--Retrofit
1.导入Jar包 compile 'com.google.code.gson:gson:2.8.0' compile 'com.squareup.retrofit2:retrofit:2.1.0' c ...
- uva 116 Unidirectional TSP (DP)
uva 116 Unidirectional TSP Background Problems that require minimum paths through some domain appear ...
- “too many open files" ----增大打开的文件数
http://www.cnblogs.com/ibook360/archive/2012/05/11/2495405.html [root@localhost ~]# ab -n -c http:/ ...
- [转] __thread关键字
http://blog.csdn.net/liuxuejiang158blog/article/details/14100897 __thread是GCC内置的线程局部存储设施,存取效率可以和全局变量 ...
- AC自动机学习笔记
AC自动机 ----多个模板的字符串匹配 字典树Trie加上失配边构成 插入操作:ac.insert(p[i],i);构造失配函数:ac.getFail();计算文本串T中每个模板串的匹配数:ac.f ...
- HDU 4607 Park Visit(树的直径)
题目大意:给定一棵树,让求出依次访问k个点的最小花费,每条边的权值都为1. 思路:如果能一直往下走不回来,那么这个路径肯定是最小的,这就取决于给定的k,但是怎么确定这个能一直走的长度呢,其实这个就是树 ...
- Cookie的读写
记住怎么写就可以了,不要问我为什么=_= 设置值的页面:context.Response.SetCookie(new HttpCookie("username",username) ...
- Asp.net中的页面跳转及post数据
/// <summary> /// This method prepares an Html form which holds all data /// in hidden field i ...
- CXF自动生成客户端
官网下载apache-cxf-3.1.6,bin目录下.配置环境变量,生成客户端 http://blog.csdn.net/jaune161/article/details/25499939 http ...
- type和create type
type和create type 异同点: create type 可在库中生成一个长期有效的自定义类型对象,而type作用域仅限于语句块中: 两者都可以自定义数据类型: 各种ty ...