转自: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间的位置重叠的更多相关文章

  1. vue中兄弟组件间通讯

    vue2.0中兄弟组件间的通讯是通过eventBus(事件发布订阅)实现的. eventBus.js import Vue from 'vue' const eventBus = new Vue() ...

  2. Vue2.5开发去哪儿网App 城市列表开发之 兄弟组件间联动及列表性能优化

    一,  兄弟组件间联动 1.  点击城市字母,左侧对应显示 给遍历的 字母 添加一个点击事件: Alphabet.vue @click="handleLetterClick" ha ...

  3. Vue2不使用Vuex如何实现兄弟组件间的通信

    在一些正规的大型项目的企业级开发过程中我们一般会引入Vuex来对Vue所有组件进行状态管理,可以轻松实现各组件间的通信.但是有时候做做自己的小项目,没有必要使用Vuex时,如何简单的实现组件间的通信? ...

  4. Vue-组件传值:子传父和兄弟组件间常见的传值方式

    前言 上篇介绍了我对vue组件化的理解和父组件对子组件传值的方式,这篇介绍下常见的子传父和兄弟组件间的传值方式 目录 子组件向父组件传值 任意组件间的传值方式 正文 子组件向父组件传值 关键知识点:$ ...

  5. vue中兄弟组件间 的传值 bus(可以理解为公共交通)

    点击大儿子(头部组件的年月日,下面的都要变化) 就相当于点击了年月日之后,下面的组件重新调接口,参数变化       1.首先随便哪儿写个bus.js 内容如下: import Vue from 'v ...

  6. C语言使用memcpy函数实现两个数间任意位置的复制操作

    c和c++使用的内存拷贝函数,memcpy函数的功能是从源src所指的内存地址的起始位置开始拷贝n个字节到目标dest所指的内存地址的起始位置中. 用法:void *memcpy(void *dest ...

  7. Vue 使用eventBus 实现兄弟组件间的通信

    实现方式:  主要是在相互通信的兄弟组件之中,都引入一个新的vue实例,然后通过分别调用这个实例的事件触发事件广播 和监听来实现通信和参数传递. 需求: a页面tree的增删改后,数据还是之前的老数据 ...

  8. Exchanger兄弟线程间数据信息交换

    一.简述 Exchanger可以在两个线程之间交换数据,只能是2个线程,他不支持更多的线程之间互换数据.当线程A调用Exchange对象的exchange()方法后,他会陷入阻塞状态,直到线程B也调用 ...

  9. Vue中兄弟组件间传值-(Bus/总线/发布订阅模式/观察者)

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

随机推荐

  1. Python监控日志程序

    一个简易的日志监控的脚本,功能如下:1.windows环境2.当匹配日志关键字时会发出声音,匹配的关键字不同,播放的声音不同3.能做到实时响应 注意:是在win环境下哦 直接上代码吧 1 2 3 4 ...

  2. mysql 加入�列,改动列,删除列。

    MySQL 加入�列,改动列,删除列 ALTER TABLE:加入�,改动,删除表的列,约束等表的定义. 查看列:desc 表名; 改动表名:alter table t_book rename to ...

  3. Project Euler problem 62

    题目的大意很简单 做法的话. 我们就枚举1~10000的数的立方, 然后把这个立方中的有序重新排列,生成一个字符串s, 然后对于那些符合题目要求的肯定是生成同一个字符串的. 然后就可以用map来搞了 ...

  4. Core Foundation框架介绍

    Core Foundation框架介绍 **参考网址: ARC下OC对象和CF对象之间的桥接 Core Foundation框架介绍 Core Foundation框架 Core Foundation ...

  5. [转] Java中的容器

    在书写程序的时候,我们常常需要对大量的对象引用进行管理.为了实现有效的归类管理,我们常常将同类的引用放置在同一数据容器中. 由于数据容器中存放了我们随时可能需要使用到的对象引用,所以一般的数据容器要都 ...

  6. YYCache 源码分析(一)

    iOS 开发中总会用到各种缓存,YYCache或许是你最好的选择.性能上有优势,用法也很简单.作者ibireme曾经对比过同类轮子:http://blog.ibireme.com/2015/10/26 ...

  7. 微信,QQ这类IM app怎么做——谈谈Websocket

    前言 关于我和WebSocket的缘:我从大二在计算机网络课上听老师讲过之后,第一次使用就到了毕业之后的第一份工作.直到最近换了工作,到了一家是含有IM社交聊天功能的app的时候,我觉得我现在可以谈谈 ...

  8. TCP/IP协议原理与应用笔记09:数据通信---封装

    2016-08-091. 数据通信----封装: 2. 协议数据单元: PDU:对等层数据通信的单元. 比如Source端的应用层 和 Destination端的应用层是对等层(L7),这个时候L7 ...

  9. python 全栈开发之路 day1

    python 全栈开发之路 day1   本节内容 计算机发展介绍 计算机硬件组成 计算机基本原理 计算机 计算机(computer)俗称电脑,是一种用于高速计算的电子计算机器,可以进行数值计算,又可 ...

  10. python 之路,Day27 - 主机管理+堡垒机系统开发

    python 之路,Day27 - 主机管理+堡垒机系统开发   本节内容 需求讨论 构架设计 表结构设计 程序开发 1.需求讨论 实现对用户的权限管理,能访问哪些机器,在被访问的机器上有哪些权限 实 ...