Pyqt5將多個(gè)類組合在一個(gè)界面顯示的完整示例
背景:
當(dāng)你做復(fù)雜程序的時(shí)候,一個(gè)python文件不可能寫完所有UI,所以我們需要分塊組合,在不同的類寫多個(gè)UI文件及其相應(yīng)的邏輯,然后再組合在一個(gè)UI界面中。
示例如下:
1、待組合的原始主界面,主要使用控件是QTabWidget ,將不同類中的布局顯示到相應(yīng)tab中
# -*- coding: utf-8 -*- import sys from PyQt5 import QtCore, QtGui, QtWidgets from PyQt5.QtWidgets import QApplication class Ui_MainWindow(QtWidgets.QWidget): def __init__(self): super(Ui_MainWindow,self).__init__() self.setupUi() def setupUi(self): self.allLayoutV = QtWidgets.QVBoxLayout() self.allLayoutV.setContentsMargins(0, 0, 0, 0) self.allLayoutV.setObjectName("allLayoutV") self.tabWidget = QtWidgets.QTabWidget() self.tabWidget.setObjectName("tabWidget") self.tab = QtWidgets.QWidget() self.tab.setObjectName("tab") self.tabWidget.addTab(self.tab, "") self.tab_2 = QtWidgets.QWidget() self.tab_2.setObjectName("tab_2") self.tabWidget.addTab(self.tab_2, "") self.tab_3 = QtWidgets.QWidget() self.tab_3.setObjectName("tab_3") self.tabWidget.addTab(self.tab_3, "") self.allLayoutV.addWidget(self.tabWidget) self.retranslateUi() self.tabWidget.setCurrentIndex(0) self.setLayout(self.allLayoutV) self.show() def retranslateUi(self): _translate = QtCore.QCoreApplication.translate self.tabWidget.setTabText(self.tabWidget.indexOf(self.tab), _translate("MainWindow", "Tab 1")) self.tabWidget.setTabText(self.tabWidget.indexOf(self.tab_2), _translate("MainWindow", "Tab 2")) self.tabWidget.setTabText(self.tabWidget.indexOf(self.tab_3), _translate("MainWindow", "Tab 3")) if __name__ == '__main__': app = QApplication(sys.argv) ex = Ui_MainWindow() app.exit(app.exec_())
分界面1
class Test(QtWidgets.QWidget): def __init__(self, parent=None): super(Test, self).__init__(parent) # for testing lay = QtWidgets.QVBoxLayout(self) lay.addWidget(QtWidgets.QPushButton("Test"))
分界面2
class Train_Haar(QtWidgets.QWidget): def __init__(self, parent=None): super(Train_Haar, self).__init__(parent) # for testing lay = QtWidgets.QVBoxLayout(self) lay.addWidget(QtWidgets.QPushButton("Train_Haar"))
分界面3
class Train_HOG(QtWidgets.QWidget): def __init__(self, parent=None): super(Train_HOG, self).__init__(parent) # for testing lay = QtWidgets.QVBoxLayout(self) lay.addWidget(QtWidgets.QPushButton("Train_HOG"))
組合類最終代碼
# -*- coding: utf-8 -*- import sys from PyQt5 import QtCore, QtGui, QtWidgets from PyQt5.QtWidgets import QApplication # 界面1 class Test(QtWidgets.QWidget): def __init__(self, parent=None): super(Test, self).__init__(parent) # for testing lay = QtWidgets.QVBoxLayout(self) lay.addWidget(QtWidgets.QPushButton("Test")) # 界面2 class Train_Haar(QtWidgets.QWidget): def __init__(self, parent=None): super(Train_Haar, self).__init__(parent) # for testing lay = QtWidgets.QVBoxLayout(self) lay.addWidget(QtWidgets.QPushButton("Train_Haar")) # 界面3 class Train_HOG(QtWidgets.QWidget): def __init__(self, parent=None): super(Train_HOG, self).__init__(parent) # for testing lay = QtWidgets.QVBoxLayout(self) lay.addWidget(QtWidgets.QPushButton("Train_HOG")) class Ui_MainWindow(QtWidgets.QWidget): def __init__(self): super(Ui_MainWindow,self).__init__() self.setupUi() def setupUi(self): self.allLayoutV = QtWidgets.QVBoxLayout() self.allLayoutV.setContentsMargins(0, 0, 0, 0) self.allLayoutV.setObjectName("allLayoutV") self.tabWidget = QtWidgets.QTabWidget() self.tabWidget.setObjectName("tabWidget") # tab1 示例一 self.tab = QtWidgets.QWidget() self.tab.setObjectName("tab") # 創(chuàng)建Test類對(duì)象 test = Test() # 創(chuàng)建一個(gè)臨時(shí)布局,用于存放從Test中獲取的布局及其邏輯 lay = QtWidgets.QGridLayout() # 獲取Test類中的布局及其邏輯 ''' 注意這里一定要用addWeidget方法,如果直接賦值布局的話self.tab.setLayout(test.layout()) 只能得到Test中的布局 但在Test中寫的控件邏輯是不會(huì)被調(diào)用的,因?yàn)橹苯淤x值你只獲取的是布局 ''' lay.addWidget(test) # 將臨時(shí)布局設(shè)定到tab上 self.tab.setLayout(lay) self.tabWidget.addTab(self.tab, "") # tab2 示例二 self.tab_2 = QtWidgets.QWidget() self.tab_2.setObjectName("tab_2") train_Haar = Train_Haar() lay = QtWidgets.QGridLayout() lay.addWidget(train_Haar) self.tab_2.setLayout(lay) self.tabWidget.addTab(self.tab_2, "") # tab3 示例三 self.tab_3 = QtWidgets.QWidget() self.tab_3.setObjectName("tab_3") train_Hog = Train_HOG() lay = QtWidgets.QGridLayout() lay.addWidget(train_Hog) self.tab_3.setLayout(lay) self.tabWidget.addTab(self.tab_3, "") self.allLayoutV.addWidget(self.tabWidget) self.retranslateUi() self.tabWidget.setCurrentIndex(0) self.setLayout(self.allLayoutV) self.show() def retranslateUi(self): _translate = QtCore.QCoreApplication.translate self.tabWidget.setTabText(self.tabWidget.indexOf(self.tab), _translate("MainWindow", "Tab 1")) self.tabWidget.setTabText(self.tabWidget.indexOf(self.tab_2), _translate("MainWindow", "Tab 2")) self.tabWidget.setTabText(self.tabWidget.indexOf(self.tab_3), _translate("MainWindow", "Tab 3")) if __name__ == '__main__': app = QApplication(sys.argv) ex = Ui_MainWindow() app.exit(app.exec_())
最終效果:
總結(jié):
這里我用QTabWidget,其實(shí)可以使用任何布局,關(guān)鍵代碼在于addWidget,所以你可以用QGridLayout等其他布局容器都行。
# tab1 self.tab = QtWidgets.QWidget() self.tab.setObjectName("tab") # 創(chuàng)建Test類對(duì)象 test = Test() # 創(chuàng)建一個(gè)臨時(shí)布局,用于存放從Test中獲取的布局及其邏輯 lay = QtWidgets.QGridLayout() # 獲取Test類中的布局及其邏輯 ''' 注意這里一定要用addWeidget方法,如果直接賦值布局的話self.tab.setLayout(test.layout()) 只能得到Test中的布局 但在Test中寫的控件邏輯是不會(huì)被調(diào)用的,因?yàn)橹苯淤x值你只獲取的是布局 ''' lay.addWidget(test) # 將臨時(shí)布局設(shè)定到tab上 self.tab.setLayout(lay)
參考:python - Compose a PyQt5 UI from multiple classes - Stack Overflow
到此這篇關(guān)于Pyqt5將多個(gè)類組合在一個(gè)界面顯示的文章就介紹到這了,更多相關(guān)Pyqt5多個(gè)類組合在界面顯示內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
python買賣股票的最佳時(shí)機(jī)(基于貪心/蠻力算法)
這篇文章主要介紹了python買賣股票的最佳時(shí)機(jī)(基于貪心/蠻力算法),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-07-07python使用Plotly創(chuàng)建交互式數(shù)據(jù)可視化的操作步驟
Python 的 Plotly 庫(kù)是創(chuàng)建這種交互式可視化的強(qiáng)大工具,它提供了豐富的圖表類型和易于使用的接口,本文將探討如何使用 Plotly 創(chuàng)建交互式數(shù)據(jù)可視化,包括代碼實(shí)例和深入的解釋,需要的朋友可以參考下2024-08-08詳解如何基于Pyecharts繪制常見的直角坐標(biāo)系圖表
pyecharts是基于前端可視化框架echarts的Python可視化庫(kù),下面這篇文章主要給大家介紹了關(guān)于如何基于Pyecharts繪制常見的直角坐標(biāo)系圖表的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-04-04python實(shí)現(xiàn)文件+參數(shù)發(fā)送request的實(shí)例代碼
這篇文章主要介紹了python實(shí)現(xiàn)文件+參數(shù)發(fā)送request的實(shí)例代碼,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-01-01Python?OpenCV基于HSV的顏色分割實(shí)現(xiàn)示例
這篇文章主要為大家介紹了Python?OpenCV基于HSV的顏色分割實(shí)現(xiàn)示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-06-06python3 requests庫(kù)實(shí)現(xiàn)多圖片爬取教程
今天小編就為大家分享一篇python3 requests庫(kù)實(shí)現(xiàn)多圖片爬取教程,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2019-12-12