【轉載】 Pyqt QStackedWidget堆棧窗體

轉載地址: http://blog.csdn.net/a649518776/article/details/6636578app

 

下面用代碼實現上面窗口的設計函數

 

 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_()

 

效果:佈局

 

解析:ui

1.這裏的程序是,選中左邊列表框內的內容,顯示相應的窗體。spa

2.因此,第一步是初始化列表框QListWidget。.net

3.第二步新建堆棧窗體:設計

stack = QStackedWidget(self)

而後將三個相應的label放入其中:code

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

4.設置主窗體佈局時,用到了佈局管理器。這裏用到的是水平排列窗體QHBoxLayout:blog

mainLayout = QHBoxLayout(self)

這個佈局管理器用法爲: utf-8

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)'))
相關文章
相關標籤/搜索