背景:
当你做复杂程序的时候,一个python文件不可能写完所有UI,所以我们需要分块组合,在不同的类写多个UI文件及其相应的逻辑,然后再组合在一个UI界面中。
示例如下:
1、待组合的原始主界面,主要使用控件是QTabWidget ,将不同类中的布局显示到相应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\") # 创建Test类对象 test = Test() # 创建一个临时布局,用于存放从Test中获取的布局及其逻辑 lay = QtWidgets.QGridLayout() # 获取Test类中的布局及其逻辑 \'\'\' 注意这里一定要用addWeidget方法,如果直接赋值布局的话self.tab.setLayout(test.layout()) 只能得到Test中的布局 但在Test中写的控件逻辑是不会被调用的,因为直接赋值你只获取的是布局 \'\'\' lay.addWidget(test) # 将临时布局设定到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_())
最终效果:
总结:
这里我用QTabWidget,其实可以使用任何布局,关键代码在于addWidget,所以你可以用QGridLayout等其他布局容器都行。
# tab1 self.tab = QtWidgets.QWidget() self.tab.setObjectName(\"tab\") # 创建Test类对象 test = Test() # 创建一个临时布局,用于存放从Test中获取的布局及其逻辑 lay = QtWidgets.QGridLayout() # 获取Test类中的布局及其逻辑 \'\'\' 注意这里一定要用addWeidget方法,如果直接赋值布局的话self.tab.setLayout(test.layout()) 只能得到Test中的布局 但在Test中写的控件逻辑是不会被调用的,因为直接赋值你只获取的是布局 \'\'\' lay.addWidget(test) # 将临时布局设定到tab上 self.tab.setLayout(lay)
参考:python – Compose a PyQt5 UI from multiple classes – Stack Overflow
© 版权声明
THE END
暂无评论内容