105.PyQt5_QStackedWidget_堆叠窗口控件

在这里插入图片描述

我 的 个 人 主 页:👉👉 失心疯的个人主页 👈👈
入 门 教 程 推 荐 :👉👉 Python零基础入门教程合集 👈👈
虚 拟 环 境 搭 建 :👉👉 Python项目虚拟环境(超详细讲解) 👈👈
PyQt5 系 列 教 程:👉👉 Python GUI(PyQt5)文章合集 👈👈
Oracle数据库教程:👉👉 Oracle数据库文章合集 👈👈
优 质 资 源 下 载 :👉👉 资源下载合集 👈👈

在这里插入图片描述

QStackedWidget 堆叠窗口控件
  • 描述
    • QTackedWidget是一个堆栈窗口控件,可以将一些控件堆叠在一起,但是同一时间只有一个控件可以显示
    • QStackedWidget是一个构建在QStackedLayout类之上的便利布局控件
    • QStackedWidget不提供用户切换页面的内在手段。这通常是通过QComboBox或QListWidget完成的
  • 继承自:QFrame
  • 功能作用
  • 构造函数
    QStackedWidget(parent)          # 创建QStackedWidget对象的同时设置父对象
    
  • 添加控件
    addWidget(QWidget) -> int              # 添加控件到QStackedWidget对象列表的最后,并返回索引号
    
    insertWidget(index, QWidget) -> int    # 在指定索引位置插入控件,并返回索引号
    
  • 获取控件&索引
    indexOf(QWidget) -> int                 # 获取指定控件的索引号
    
    widget(int) -> QWidget                  # 根据索引号获取控件
    
    currentIndex() -> int                   # 获取当前显示控件的索引
    
    currentWidget() -> QWidget              # 获取当前显示的控件
    
    
  • 当前显示
    setCurrentIndex(index)                  # 设置指定索引号控件为当前显示控件
    
    setCurrentWidget(QWidget)               # 设置指定控件为当前显示控件
    
  • 获取堆叠控件个数
    count()                                 # 获取QStackedWidget对象中堆叠控件的总个数
    
  • 移除控件
    removeWidget(QWidget)                   # 移除指定控件
    
    # removeWidget(widget(int))             # 嵌套使用,移除指定索引控件
    
  • **可用信号
    widgetRemoved(index)            # 移除控件时发射该信号,传递被移除控件的索引
    
    currentChanged(index)           # 当前显示控件发生改变时发射该信号,传递新显示控件的索引
    

  • 演示代码
  • 示例1:QStackedWidget-功能演示
    from PyQt5.Qt import *
    import sys
    
    
    class Windows(QWidget):
        def __init__(self):
            super().__init__()
            self.setWindowTitle('QStackedWidget-功能演示')
            self.resize(500, 300)
            self.widget_list()
    
        def widget_list(self):
            stw = QStackedWidget()
            self.stw = stw
            w1 = QWidget()
            w2 = QWidget()
            w3 = QWidget()
            w4 = QWidget()
    
            QLabel('主页', w1).move(100, 100)
            QLabel('简介', w2).move(100, 100)
            QLabel('联系', w3).move(100, 100)
            QLabel('地址', w4).move(100, 100)
    
            w1.setStyleSheet('background-color: red;')
            w2.setStyleSheet('background-color: yellow;')
            w3.setStyleSheet('background-color: cyan;')
            w4.setStyleSheet('background-color: green;')
    
            stw.addWidget(w1)
            stw.addWidget(w2)
            stw.addWidget(w3)
            stw.addWidget(w4)
    
            cmb = QComboBox()
            items = ['主页', '简介', '联系', '地址']
            cmb.addItems(items)
    
            hlayout = QHBoxLayout()
            hlayout.addWidget(cmb, 1)
            hlayout.addWidget(stw, 4)
            self.setLayout(hlayout)
    
            cmb.currentIndexChanged[int].connect(self.open_window)
    
            stw.currentChanged.connect(lambda index: print(f'当前显示控件发生了改变,新控件索引{index}'))
    
        def open_window(self, index):
            self.stw.setCurrentIndex(index)
    
    
    if __name__ == '__main__':
        app = QApplication(sys.argv)
        window = Windows()
    
        window.show()
        sys.exit(app.exec_())
    
    
  • 效果图
    • 在这里插入图片描述
  • 该示例中我们用的QComboBox控件做的选项栏,同样也可以用多个按钮,也可以用我们后面需要学到的ListView、ListWidget
  • 2
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
PyQt5中的堆叠显示是指将多个控件堆叠在一起,只显示其中的一个控件,其他控件被隐藏。当需要切换显示的控件时,只需要更改当前显示的控件即可。 PyQt5中实现堆叠显示可以使用QStackedWidget控件。该控件可以包含多个子控件,但只会显示其中的一个子控件。可以使用setCurrentIndex()方法来设置当前显示的子控件的索引,或者使用setCurrentWidget()方法来设置当前显示的子控件。 以下是一个简单的例子,演示如何使用QStackedWidget实现堆叠显示: ```python import sys from PyQt5.QtWidgets import QApplication, QWidget, QVBoxLayout, QStackedWidget, QPushButton class StackedExample(QWidget): def __init__(self): super().__init__() self.initUI() def initUI(self): # 创建QStackedWidget控件,并添加两个子控件 self.stack = QStackedWidget(self) self.stack.addWidget(self.createWidget('Widget 1')) self.stack.addWidget(self.createWidget('Widget 2')) # 创建两个按钮,用于切换显示的子控件 btn1 = QPushButton('Show widget 1', self) btn1.clicked.connect(lambda:self.stack.setCurrentIndex(0)) btn2 = QPushButton('Show widget 2', self) btn2.clicked.connect(lambda:self.stack.setCurrentIndex(1)) # 创建垂直布局,并将按钮和QStackedWidget添加进布局中 vbox = QVBoxLayout() vbox.addWidget(btn1) vbox.addWidget(btn2) vbox.addWidget(self.stack) self.setLayout(vbox) self.setWindowTitle('Stacked Widget Example') self.show() def createWidget(self, text): # 创建一个QWidget控件,并在上面添加一些文本 widget = QWidget(self) widget.setStyleSheet('background-color: yellow') layout = QVBoxLayout(widget) layout.addWidget(QPushButton('Button 1', widget)) layout.addWidget(QPushButton('Button 2', widget)) layout.addWidget(QPushButton('Button 3', widget)) layout.addWidget(QPushButton('Button 4', widget)) layout.addWidget(QPushButton('Button 5', widget)) layout.addWidget(QPushButton('Button 6', widget)) layout.addWidget(QPushButton('Button 7', widget)) layout.addWidget(QPushButton('Button 8', widget)) layout.addWidget(QPushButton('Button 9', widget)) layout.addWidget(QPushButton('Button 10', widget)) layout.addWidget(QPushButton('Button 11', widget)) layout.addWidget(QPushButton('Button 12', widget)) layout.addWidget(QPushButton('Button 13', widget)) layout.addWidget(QPushButton('Button 14', widget)) layout.addWidget(QPushButton('Button 15', widget)) layout.addWidget(QPushButton('Button 16', widget)) layout.addWidget(QPushButton('Button 17', widget)) layout.addWidget(QPushButton('Button 18', widget)) layout.addWidget(QPushButton('Button 19', widget)) layout.addWidget(QPushButton('Button 20', widget)) return widget if __name__ == '__main__': app = QApplication(sys.argv) ex = StackedExample() sys.exit(app.exec_()) ``` 在上面的例子中,我们创建了一个QStackedWidget控件,并添加了两个QWidget控件。然后创建了两个按钮,用于切换显示的子控件。最后,将这些控件放在垂直布局中,并将其设置为窗口的主布局。运行程序后,点击不同的按钮即可切换显示的子控件

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

失心疯_2023

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

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

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

打赏作者

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

抵扣说明:

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

余额充值