Pyqt5 页码层与逻辑层分离

结构框架

  1. 设计两个ui界面
  2. 为两个ui生成的py文件 去分别定义两个逻辑层去分别继承前面的两个类
  3. 初始化逻辑层
  4. 设置信号与槽
  5. 定义槽

文件说明

  •         一共六个文件

        

MW1.ui                                                界面1 ui设计

MW1.py                                               界面1 ui转py文件

MW2.ui                                                界面2ui文件

MW2.py                                               界面2 ui转py文件

First_window_action.py                       逻辑层1 继承界面1的py类

MW2_Action.py                                    逻辑层2 继承界面2的py类

 

MW1.py

# -*- coding: utf-8 -*-

# Form implementation generated from reading ui file 'MW1.ui'
#
# Created by: PyQt5 UI code generator 5.15.4
#
# WARNING: Any manual changes made to this file will be lost when pyuic5 is
# run again.  Do not edit this file unless you know what you are doing.


from PyQt5 import QtCore, QtGui, QtWidgets


class Ui_MainWindow(object):
    def setupUi(self, MainWindow):
        MainWindow.setObjectName("MainWindow")
        MainWindow.resize(460, 294)
        self.centralwidget = QtWidgets.QWidget(MainWindow)
        self.centralwidget.setObjectName("centralwidget")
        self.widget = QtWidgets.QWidget(self.centralwidget)
        self.widget.setGeometry(QtCore.QRect(20, 20, 411, 221))
        self.widget.setStyleSheet("background-color: rgb(255, 255, 127);")
        self.widget.setObjectName("widget")
        self.label = QtWidgets.QLabel(self.widget)
        self.label.setGeometry(QtCore.QRect(150, 10, 101, 41))
        self.label.setObjectName("label")
        self.TurnTo1_Button = QtWidgets.QPushButton(self.widget)
        self.TurnTo1_Button.setGeometry(QtCore.QRect(70, 170, 75, 23))
        self.TurnTo1_Button.setStyleSheet("background-color: rgb(170, 170, 255);")
        self.TurnTo1_Button.setObjectName("TurnTo1_Button")
        self.TurnTo2_Button = QtWidgets.QPushButton(self.widget)
        self.TurnTo2_Button.setGeometry(QtCore.QRect(260, 170, 75, 23))
        self.TurnTo2_Button.setStyleSheet("background-color: rgb(170, 170, 255);")
        self.TurnTo2_Button.setObjectName("TurnTo2_Button")
        MainWindow.setCentralWidget(self.centralwidget)
        self.menubar = QtWidgets.QMenuBar(MainWindow)
        self.menubar.setGeometry(QtCore.QRect(0, 0, 460, 23))
        self.menubar.setObjectName("menubar")
        MainWindow.setMenuBar(self.menubar)
        self.statusbar = QtWidgets.QStatusBar(MainWindow)
        self.statusbar.setObjectName("statusbar")
        MainWindow.setStatusBar(self.statusbar)

        self.retranslateUi(MainWindow)
        QtCore.QMetaObject.connectSlotsByName(MainWindow)

    def retranslateUi(self, MainWindow):
        _translate = QtCore.QCoreApplication.translate
        MainWindow.setWindowTitle(_translate("MainWindow", "MainWindow"))
        self.label.setText(_translate("MainWindow", "这是界面1"))
        self.TurnTo1_Button.setText(_translate("MainWindow", "界面1"))
        self.TurnTo2_Button.setText(_translate("MainWindow", "界面2"))

展示界面1内容

 

MW2.py

from PyQt5 import QtCore, QtGui, QtWidgets


class Ui_MainWindow(object):
    def setupUi(self, MainWindow):
        MainWindow.setObjectName("MainWindow")
        MainWindow.resize(800, 303)
        self.centralwidget = QtWidgets.QWidget(MainWindow)
        self.centralwidget.setObjectName("centralwidget")
        self.frame = QtWidgets.QFrame(self.centralwidget)
        self.frame.setGeometry(QtCore.QRect(20, 10, 761, 251))
        self.frame.setStyleSheet("background-color: rgb(170, 255, 255);")
        self.frame.setFrameShape(QtWidgets.QFrame.StyledPanel)
        self.frame.setFrameShadow(QtWidgets.QFrame.Raised)
        self.frame.setObjectName("frame")
        self.label = QtWidgets.QLabel(self.frame)
        self.label.setGeometry(QtCore.QRect(330, 0, 101, 41))
        self.label.setObjectName("label")
        self.TurnTo1_Button2 = QtWidgets.QPushButton(self.frame)
        self.TurnTo1_Button2.setGeometry(QtCore.QRect(200, 190, 75, 23))
        self.TurnTo1_Button2.setStyleSheet("background-color: rgb(170, 170, 255);")
        self.TurnTo1_Button2.setObjectName("TurnTo1_Button2")
        self.TurnTo2_Button2 = QtWidgets.QPushButton(self.frame)
        self.TurnTo2_Button2.setGeometry(QtCore.QRect(390, 190, 75, 23))
        self.TurnTo2_Button2.setStyleSheet("background-color: rgb(170, 170, 255);")
        self.TurnTo2_Button2.setObjectName("TurnTo2_Button2")
        MainWindow.setCentralWidget(self.centralwidget)
        self.menubar = QtWidgets.QMenuBar(MainWindow)
        self.menubar.setGeometry(QtCore.QRect(0, 0, 800, 23))
        self.menubar.setObjectName("menubar")
        MainWindow.setMenuBar(self.menubar)
        self.statusbar = QtWidgets.QStatusBar(MainWindow)
        self.statusbar.setObjectName("statusbar")
        MainWindow.setStatusBar(self.statusbar)

        self.retranslateUi(MainWindow)
        QtCore.QMetaObject.connectSlotsByName(MainWindow)

    def retranslateUi(self, MainWindow):
        _translate = QtCore.QCoreApplication.translate
        MainWindow.setWindowTitle(_translate("MainWindow", "MainWindow"))
        self.label.setText(_translate("MainWindow", "这是界面2"))
        self.TurnTo1_Button2.setText(_translate("MainWindow", "界面1"))
        self.TurnTo2_Button2.setText(_translate("MainWindow", "界面2"))

First_window_action.py  

import sys
import MW1
import MW2_Action
from PyQt5.QtWidgets import QApplication, QMainWindow, QWidget, QFileDialog, QMessageBox
from PyQt5 import QtWidgets


# 注意这里定义的第一个界面的后端代码类需要继承两个类
class FirstWindowActions(MW1.Ui_MainWindow, QMainWindow):
    def __init__(self):
        super(MW1.Ui_MainWindow, self).__init__()
        # 创建界面
        self.setupUi(self)
        # 绑定槽函数`
        self.TurnTo2_Button.clicked.connect(self.open_btn_clicked)
        self.TurnTo2_Button.clicked.connect(self.close)


    # 核心代码
    # 定义一个按钮的槽函数
    def open_btn_clicked(self):
        """点击相应按钮,跳转到第二个界面"""
        # 实例化第二个界面的后端类,并对第二个界面进行显示
        # 通过派生新类去访问类
        self.another_window = MW2_Action.AnotherWindowActions()
        self.another_window.show()


# 主程序入口
if __name__ == '__main__':
    # 这里是界面的入口,在这里需要定义QApplication对象,之后界面跳转时不用再重新定义,只需要调用show()函数即可
    app = QApplication(sys.argv)

    # 实例化
    demo_window = FirstWindowActions()

    # 显示
    demo_window.show()

    sys.exit(app.exec_())

MW2_Action.py

import sys
import MW1
import MW2_Action
from PyQt5.QtWidgets import QApplication, QMainWindow, QWidget, QFileDialog, QMessageBox
from PyQt5 import QtWidgets


# 注意这里定义的第一个界面的后端代码类需要继承两个类
class FirstWindowActions(MW1.Ui_MainWindow, QMainWindow):
    def __init__(self):
        super(MW1.Ui_MainWindow, self).__init__()
        # 创建界面
        self.setupUi(self)
        # 绑定槽函数`
        self.TurnTo2_Button.clicked.connect(self.open_btn_clicked)
        self.TurnTo2_Button.clicked.connect(self.close)


    # 核心代码
    # 定义一个按钮的槽函数
    def open_btn_clicked(self):
        """点击相应按钮,跳转到第二个界面"""
        # 实例化第二个界面的后端类,并对第二个界面进行显示
        # 通过派生新类去访问类
        self.another_window = MW2_Action.AnotherWindowActions()
        self.another_window.show()


# 主程序入口
if __name__ == '__main__':
    # 这里是界面的入口,在这里需要定义QApplication对象,之后界面跳转时不用再重新定义,只需要调用show()函数即可
    app = QApplication(sys.argv)

    # 实例化
    demo_window = FirstWindowActions()

    # 显示
    demo_window.show()

    sys.exit(app.exec_())

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 在 Python 中使用 PyQt5 实现多界面设计可以使用 QStackedWidget 组件。 QStackedWidget 组件是一个容器组件,可以在其中嵌入多个子界面,并通过设置当前来显示不同的子界面。 使用方法如下: 1. 创建 QStackedWidget 对象 2. 创建多个子界面(QWidget 对象) 3. 将子界面添加到 QStackedWidget 中 4. 设置当前来显示不同的子界面 下面是一个简单的例子: ```python import sys from PyQt5.QtWidgets import QApplication, QWidget, QStackedWidget, QVBoxLayout class MainWindow(QWidget): def __init__(self): super().__init__() self.initUI() def initUI(self): # 创建 QStackedWidget 对象 stacked_widget = QStackedWidget() # 创建多个子界面 page1 = QWidget() page2 = QWidget() page3 = QWidget() # 将子界面添加到 QStackedWidget 中 stacked_widget.addWidget(page1) stacked_widget.addWidget(page2) stacked_widget.addWidget(page3) # 设置当前 stacked_widget.setCurrentIndex(0) # 在窗口中添加 QStackedWidget 并显示 layout = QVBoxLayout() layout.addWidget(stacked_widget) self.setLayout(layout) self.show() if __name__ == '__main__': app = QApplication(sys.argv) window = MainWindow() sys.exit(app.exec_()) ``` 在这个例子中,我们创建了三个子界面(page1、page2、page3)并将它们添加到 QStackedWidget 中,然后设置当前为第一,就可以在窗口中显示第一 ### 回答2: 利用PythonPyQt5可以实现多界面设计,具体步骤如下: 首先,我们需要导入PyQt5库,并创建一个主窗口类。 ```python from PyQt5.QtWidgets import QApplication, QMainWindow class MainWindow(QMainWindow): def __init__(self): super().__init__() # 设置主窗口的标题和大小 self.setWindowTitle("多界面设计示例") self.setGeometry(100, 100, 300, 200) # 创建一个按钮并添加到主窗口上 button = QPushButton("打开第二界面", self) button.move(100, 100) ``` 然后,我们需要创建第二界面。在第一界面的按钮点击事件中,可以打开第二界面。 ```python from PyQt5.QtWidgets import QDialog, QLabel class SecondWindow(QDialog): def __init__(self): super().__init__() # 设置第二界面的标题和大小 self.setWindowTitle("第二界面") self.setGeometry(200, 200, 300, 200) # 创建一个标签并添加到第二界面上 label = QLabel("这是第二界面", self) label.move(100, 100) ``` 最后,我们需要在主程序中实例化主窗口类,并展示界面。 ```python if __name__ == "__main__": import sys # 创建一个应用程序对象 app = QApplication(sys.argv) # 实例化主窗口类 main_window = MainWindow() # 在点击按钮时打开第二界面 button.clicked.connect(lambda: open_second_window()) def open_second_window(): second_window = SecondWindow() second_window.exec() # 显示主窗口 main_window.show() # 进入主循环 sys.exit(app.exec()) ``` 这样,就实现了通过点击主窗口上的按钮,打开第二界面的多界面设计。在主窗口和第二界面中,我们可以根据需要添加更多的功能和控件。 ### 回答3: 利用PythonPyQt5可以实现多界面设计。PyQt5是一个Python的GUI框架,可以用于创建各种类型的界面。多界面设计通常包括主界面和子界面的切换,可以通过使用PyQt5的QStackedWidget(堆叠窗口小部件)来实现。 首先,我们需要导入PyQt5库,使用以下代码实现: ```python from PyQt5.QtCore import * from PyQt5.QtWidgets import * from PyQt5.QtGui import * ``` 然后,创建一个继承自QMainWindow的主窗口类,设置主界面的布局和样式。在主界面中添加按钮或其他控件,用于触发显示子界面的事件。 接下来,创建继承自QWidget的子窗口类,用于显示子界面的内容。在子界面中添加所需的控件和布局,根据需求进行设计。 在主窗口类中,我们可以为按钮或其他控件添加信号和槽函数,用于切换显示子界面。在槽函数中,我们可以使用QStackedWidget的setCurrentIndex方法来切换显示的界面。例如: ```python self.stacked_widget.setCurrentIndex(1) # 显示第二个子界面 ``` 添加完所有的子界面后,我们可以将它们添加到QStackedWidget中,使用addWiget方法来进行添加。例如: ```python self.stacked_widget.addWidget(ChildWindow1()) # 添加第一个子界面 self.stacked_widget.addWidget(ChildWindow2()) # 添加第二个子界面 ``` 最后,我们需要在主窗口的布局中添加QStackedWidget,并设置好布局和样式。 通过以上步骤,利用PythonPyQt5,我们可以实现多界面设计。当用户在主界面点击按钮或其他控件时,可以切换显示子界面,以实现不同功能或模块的展示和操作。同时,我们还可以通过设置子界面的布局和样式来满足设计要求。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值