【转载】 Pyqt QStackedWidget堆栈窗体

本文介绍如何使用 PyQt4 实现一个简单的选项卡界面。通过左侧的列表选择不同的选项,右侧会显示对应的标签页内容。文章详细展示了创建 QStackedWidget 的步骤,并解释了如何设置布局和信号槽来实现选项卡切换的功能。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

转载地址: http://blog.youkuaiyun.com/a649518776/article/details/6636578

 

下面用代码实现上面窗口的设计

 

 1 # -*- coding: utf-8 -*-
 2 from PyQt4.QtGui import *
 3 from PyQt4.QtCore import *
 4 import sys
 5 
 6 QTextCodec.setCodecForTr(QTextCodec.codecForName("utf8"))
 7 class Stacked(QDialog):
 8     def __init__(self, parent=None):
 9         super(Stacked, self).__init__(parent)
10         self.setWindowTitle(self.tr("StackedWidget"))
11 
12         leftlist = QListWidget(self)
13         leftlist.insertItem(0, 'window1')
14         leftlist.insertItem(1, 'window2')
15         leftlist.insertItem(2, 'window3')
16 
17         label1 = QLabel('windowTest1\n11111111 ')
18         label2 = QLabel('windowTest2\n22222222 ')
19         label3 = QLabel('windowTest3\n33333333 ')
20 
21         stack = QStackedWidget(self)
22         stack.addWidget(label1)
23         stack.addWidget(label2)
24         stack.addWidget(label3)
25 
26         mainLayout = QHBoxLayout(self)
27         mainLayout.setMargin(5)  # 对话框边距设为5 Margin 边距  5px
28         mainLayout.setSpacing(5)  # 内部控件间距为5 Spacing间距  5px
29         mainLayout.addWidget(leftlist)
30         mainLayout.addWidget(stack, 0, Qt.AlignHCenter)
31         mainLayout.setStretchFactor(leftlist, 1)
32         mainLayout.setStretchFactor(stack, 3)  # 设定了list与stack比例为1:3。
33         self.connect(leftlist, SIGNAL('currentRowChanged(int)'), stack, SLOT('setCurrentIndex(int)'))
34 
35 
36 if __name__ == '__main__':
37     app = QApplication(sys.argv)
38     main = Stacked()
39     main.show()
40     app.exec_()

 

效果:

 

解析:

1.这里的程序是,选中左边列表框内的内容,显示相应的窗体。

2.所以,第一步是初始化列表框QListWidget。

3.第二步新建堆栈窗体:

stack = QStackedWidget(self)

然后将三个相应的label放入其中:

        stack.addWidget(label1)
        stack.addWidget(label2)
        stack.addWidget(label3)

4.设置主窗体布局时,用到了布局管理器。这里用到的是水平排列窗体QHBoxLayout:

mainLayout = QHBoxLayout(self)

这个布局管理器用法为: 

mainLayout.setMargin(5)  # 对话框边距设为5 Margin 边距  5px
mainLayout.setSpacing(5)  # 内部控件间距为5 Spacing间距  5px

setStetchFactor函数

mainLayout.setStretchFactor(leftlist, 1)
mainLayout.setStretchFactor(stack, 3)  # 设定了list与stack比例为1:3。

5.设定消息相应的信号与槽:

self.connect(leftlist, SIGNAL('currentRowChanged(int)'), stack, SLOT('setCurrentIndex(int)'))

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值