這篇文章將為大家詳細(xì)講解有關(guān)怎么在python中使用QStackedWidget控件,文章內(nèi)容質(zhì)量較高,因此小編分享給大家做個(gè)參考,希望大家閱讀完這篇文章后對(duì)相關(guān)知識(shí)有一定的了解。
為宜秀等地區(qū)用戶提供了全套網(wǎng)頁(yè)設(shè)計(jì)制作服務(wù),及宜秀網(wǎng)站建設(shè)行業(yè)解決方案。主營(yíng)業(yè)務(wù)為成都網(wǎng)站設(shè)計(jì)、成都做網(wǎng)站、宜秀網(wǎng)站設(shè)計(jì),以傳統(tǒng)方式定制建設(shè)網(wǎng)站,并提供域名空間備案等一條龍服務(wù),秉承以專業(yè)、用心的態(tài)度為用戶提供真誠(chéng)的服務(wù)。我們深信只要達(dá)到每一位用戶的要求,就會(huì)得到認(rèn)可,從而選擇與我們長(zhǎng)期合作。這樣,我們也可以走得更遠(yuǎn)!PyQt5窗口布局控件QStackedWidget介紹QTackedWidget是一個(gè)堆棧窗口控件,可以填充一些小控件,但是同一時(shí)間只有一個(gè)小控件可以顯示,QStackedWidget使用QStackedLayout布局。QSTackedWidget控件與QTabWidget類似,可以有效的顯示窗口的控件
QStackedWidget的使用實(shí)例import sys from PyQt5.QtGui import * from PyQt5.QtCore import * from PyQt5.QtWidgets import * class StackedExample(QWidget): def __init__(self): super(StackedExample, self).__init__() #設(shè)置窗口初始位置和大小 self.setGeometry(300,50,10,10) self.setWindowTitle('StackedWidget 例子') #創(chuàng)建列表窗口,添加條目 self.leftlist=QListWidget() self.leftlist.insertItem(0,'聯(lián)系方式') self.leftlist.insertItem(1,'個(gè)人信息') self.leftlist.insertItem(2,'教育程度') #創(chuàng)建三個(gè)小控件 self.stack1=QWidget() self.stack2=QWidget() self.stack3=QWidget() self.stack1UI() self.stack2UI() self.stack3UI() #在QStackedWidget對(duì)象中填充了三個(gè)子控件 self.stack=QStackedWidget(self) self.stack.addWidget(self.stack1) self.stack.addWidget(self.stack2) self.stack.addWidget(self.stack3) #水平布局,添加部件到布局中 HBox=QHBoxLayout() HBox.addWidget(self.leftlist) HBox.addWidget(self.stack) self.setLayout(HBox) self.leftlist.currentRowChanged.connect(self.display) def stack1UI(self): layout=QFormLayout() layout.addRow('姓名',QLineEdit()) layout.addRow('地址',QLineEdit()) self.stack1.setLayout(layout) def stack2UI(self): # zhu表單布局,次水平布局 layout = QFormLayout() sex = QHBoxLayout() # 水平布局添加單選按鈕 sex.addWidget(QRadioButton('男')) sex.addWidget(QRadioButton('女')) # 表單布局添加控件 layout.addRow(QLabel('性別'), sex) layout.addRow('生日', QLineEdit()) self.stack2.setLayout(layout) def stack3UI(self): # 水平布局 layout = QHBoxLayout() # 添加控件到布局中 layout.addWidget(QLabel('科目')) layout.addWidget(QCheckBox('物理')) layout.addWidget(QCheckBox('高數(shù)')) self.stack3.setLayout(layout) def display(self,i): #設(shè)置當(dāng)前可見(jiàn)的選項(xiàng)卡的索引 self.stack.setCurrentIndex(i) if __name__ == '__main__': app=QApplication(sys.argv) demo=StackedExample() demo.show() sys.exit(app.exec_())
運(yùn)行效果如圖
在這個(gè)例子中,在QStackedWidget對(duì)象中填充了三個(gè)子控件
self.stack1=QWidget() self.stack2=QWidget() self.stack3=QWidget() #在QStackedWidget對(duì)象中填充了三個(gè)子控件 self.stack=QStackedWidget(self) self.stack.addWidget(self.stack1) self.stack.addWidget(self.stack2) self.stack.addWidget(self.stack3)
每個(gè)子控件都可以有自己的布局,包含特定的表單元素,QStackedWidget控件不能在頁(yè)面之間進(jìn)行切換,它與當(dāng)前選中的QListWidget控件中的選項(xiàng)進(jìn)行連接
#創(chuàng)建列表窗口,添加條目 self.leftlist=QListWidget() self.leftlist.insertItem(0,'聯(lián)系方式') self.leftlist.insertItem(1,'個(gè)人信息') self.leftlist.insertItem(2,'教育程度') self.leftlist.currentRowChanged.connect(self.display)
將QListWidget的currentRowChanged信號(hào)與display()槽函數(shù)相關(guān)聯(lián),從而改變堆疊控件的視圖
def display(self,i): #設(shè)置當(dāng)前可見(jiàn)的選項(xiàng)卡的索引 self.stack.setCurrentIndex(i)
實(shí)際開(kāi)發(fā)中,做界面設(shè)計(jì),當(dāng)然一般是借助Qt designer,方便而高效。
關(guān)于怎么在python中使用QStackedWidget控件就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,可以學(xué)到更多知識(shí)。如果覺(jué)得文章不錯(cuò),可以把它分享出去讓更多的人看到。