【PyQt学习篇 · ⑦】:QWidget - 父子关系扩充和层级控制

父子关系扩充

常用API

  1. childAt(x, y) 函数可以根据传入的坐标参数获取该QWidget中位于该坐标位置的子QWidget,如果该位置没有子QWidget则返回None。

  2. parentWidget() 函数可以获取当前QWidget的父QWidget,如果没有父QWidget则返回None。通过这个函数可以遍历组成QWidget树的所有QWidget。

  3. childrenRect() 函数可以获取该QWidget中所有子QWidget的组合边界矩形(bounding rectangle),该矩形包括所有子QWidget的位置和大小。可以利用这个函数来计算一个QWidget内所有子QWidget的相对位置和大小,方便进行布局和重绘。

以下为API的使用示例:

from PyQt5.QtWidgets import *
import sys

app = QApplication(sys.argv)

window = QWidget()
window.resize(500, 500)

# 创建三个标签

label = QLabel(window)
label.setText('标签1')
label.move(50, 50)

label2 = QLabel(window)
label2.setText('标签1')
label2.move(100, 100)

label3 = QLabel(window)
label3.setText('标签1')
label3.move(150, 150)

window.show()

print(window.childAt(55, 55))   # 获取55,55的位置的子QWidget
print(label2.parentWidget())    # 获取父Qwidget
print(window.childrenRect())    # 获取该QWidget中所有子QWidget的组合边界矩形


sys.exit(app.exec_())

运行结果:

在这里插入图片描述
在这里插入图片描述

案例

案例:创建窗口,包含若干个Label控件。

要求:

  • 点击哪个标签,就让哪个标签背景变红
  • 使用父控件处理,不要自定义QLabel子类

该案例的代码:

from PyQt5.QtWidgets import *
from PyQt5.QtCore import Qt
import sys

class Window(QWidget):
    def mousePressEvent(self, QMouseEvent):
        # 获取鼠标点击的位置,判断是否为QLabel标签
        if QMouseEvent.button() == Qt.LeftButton:
        	# QMouseEvent.x()和QMouseEvent.y()表示获取鼠标在局部控件中的位置
            sub_widget = self.childAt(QMouseEvent.x(), QMouseEvent.y())
            if (sub_widget is not None) and (sub_widget.inherits("QLabel")):
                sub_widget.setStyleSheet('background-color: red;')

if __name__ == '__main__':
    app = QApplication(sys.argv)

    window = Window()
    # 创建三个标签
    for i in range(3):
        label = QLabel(window)
        label.setText(f'标签{i+1}')
        label.move(50*i, 50*i)

    window.resize(300, 300)
    window.show()

    sys.exit(app.exec_())

运行结果:
当点击标签1和标签3时,背景颜色变红。

在这里插入图片描述

层级控制

在PyQt中,QWidget的层级控制允许对不同的QWidget进行层级关系的调整,从而决定它们在屏幕上的显示顺序。以下是一些用于层级控制的常用API:

  1. lower() 函数可以将一个QWidget置于其兄弟QWidget的底部,即降低其显示级别。

  2. raise_() 函数可以将一个QWidget置于其兄弟QWidget的顶部,即提高其显示级别。

  3. a.stakUnder(b) 函数可以将QWidget a置于QWidget b的下方。

示例:
创建两个窗口,观察两个窗口的出现顺序

from PyQt5.QtWidgets import *
import sys

app = QApplication(sys.argv)

w1 = QWidget()
w1.resize(500, 500)
w1.setWindowTitle('w1')

w2 = QWidget()
w2.resize(300, 300)
w2.setWindowTitle('w2')

w1.show()
w2.show()

sys.exit(app.exec_())

运行结果:

在这里插入图片描述
通过运行结果我们看出:哪个控件后展示,它的级别就越高。在此例中w2窗口的级别比w1高。

  • 使用以上API将w2降低到底层
w1.show()
w2.show()

w2.lower()  # 将w2降低到底层
# 或
#w1.raise_()
# 或
#w2.stackUnder(w1)

运行结果:
w2降低到底层,被覆盖

在这里插入图片描述

案例

案例:创建一个窗口,在窗口中创建两个部分重叠的标签,实现鼠标点击哪个标签,哪个标签就变为顶层。

案例的代码:

from PyQt5.QtWidgets import *
from PyQt5.QtCore import Qt
import sys


class Window(QWidget):
    def mousePressEvent(self, QMouseEvent):
        if QMouseEvent.button() == Qt.LeftButton:
            sub_widget = self.childAt(QMouseEvent.x(), QMouseEvent.y())
            if (sub_widget is not None) and (sub_widget.inherits("QLabel")):
                sub_widget.raise_()     # 将鼠标点击的标签设置为顶层

if __name__ == '__main__':
    app = QApplication(sys.argv)

    window = Window()
    window.resize(500, 500)

    label1 = QLabel(window)
    label1.resize(200, 200)
    label1.setText('标签1')
    label1.setStyleSheet('background-color: red;')

    label2 = QLabel(window)
    label2.resize(200, 200)
    label2.setText('标签2')
    label2.setStyleSheet('background-color: green;')
    label2.move(100, 100)

    window.show()
    sys.exit(app.exec_())

运行结果:

在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

街 三 仔

你的鼓励是我创作的最大动力~

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值