【PyQt5】designer 页面点击按钮跳转页面

首先要知道,使用 Qt designer 和 代码进行 Qt 开发实现页面跳转是不一样的,这里我们使用的是 designer 开发,在这里简单记录一下。

PyQt5 实现两个页面跳转

目前场景:

  • 用 Qt designer 设计好了两个页面:a_ui.pyb_ui.py
  • a_ui.py 中有个按钮的 id 为 goButton

我们实现两个页面之间的跳转:

from a_ui import Ui_MainWindow as A_Ui # a界面的库
from b_ui import Ui_MainWindow as B_Ui # b界面的库

from PyQt5 import QtCore, QtWidgets
import sys

class AUi(QtWidgets.QMainWindow, A_Ui):
    def __init__(self):
        super(AUi, self).__init__()
        self.setupUi(self)

class BUi(QtWidgets.QMainWindow, B_Ui):
    def __init__(self):
        super(BUi, self).__init__()
        self.setupUi(self)

if __name__ == '__main__':
    app = QtWidgets.QApplication(sys.argv)
    a = AUi()
    a.show()
    b = BUi()
    # button是你定义的按钮
    a.goButton.clicked.connect(
    	lambda:{a.close(), b.show()}
   	)
    sys.exit(app.exec_())

PyQt5 实现多个页面跳转

PyQt5 实现多个页面跳转,我们可以借助一个 Controller 控制器来实现,大体思路如下:

# 利用一个控制器来控制页面的跳转
class Controller:
    def __init__(self):
        pass
    def show_A(self):
    	# 创建 A 窗口对象并显示
    	# 关闭其余窗口对象
    def show_B(self):
    	# 创建 B 窗口对象并显示
    	# 关闭其余窗口对象
    def show_C(self):
    	# 创建 C 窗口对象并显示
    	# 关闭其余窗口对象

来看一个使用情景:

  • 用 Qt designer 设计好了三个页面:hello.pylogin.pyoperate.py
  • hello.py 中有一个 Id 为 loginBuuton 的按钮,用于跳转到 login.py 窗口
  • hello.py 中还有一个 Id 为 operateButton 的按钮,用于跳转到 operate.py 窗口

实现效果

注:由于我们的 界面逻辑 是分离的,所以界面只需满足上面的使用情境中的要求即可。

运行程序启动一个 hello.py 的欢迎界面:
在这里插入图片描述
点击 票务管理,实际上是点击了 loginButton 按钮,跳转到了 login.py 登录界面:
在这里插入图片描述
如果欢迎界面中点击的是 票务查询,实际上是点击了 operateButton,会跳转到 operate.py 界面:
在这里插入图片描述

代码编写

首先导入需要的模块:系统模块利用designer设计的页面

import sys
from PyQt5 import QtCore, QtWidgets, QtCore

# 导入 Qt designer 设计的页面
from hello import Ui_MainWindow as Hello_Ui 
from login import Ui_MainWindow as Login_Ui
from operate import Ui_MainWindow as Operate_Ui

然后写页面对应的窗口类,我们这里简单的实现 一个页面往其他页面的跳转
实现跳转的逻辑主要都在 HelloWindow 类中,其他窗口类仅仅做了初始化:

# 主窗口
class HelloWindow(QtWidgets.QMainWindow, Hello_Ui):
    switch_window1 = QtCore.pyqtSignal() # 跳转信号
    switch_window2 = QtCore.pyqtSignal() # 跳转信号
    def __init__(self):
        super(HelloWindow, self).__init__()
        self.setupUi(self)
        self.queryButton.clicked.connect(self.goOperate)
        self.manageButton.clicked.connect(self.goLogin)
    def goLogin(self):
        self.switch_window1.emit()
    def goOperate(self):
        self.switch_window2.emit()

# 登录窗口
class LoginWindow(QtWidgets.QMainWindow, Login_Ui):
    def __init__(self):
        super(LoginWindow, self).__init__()
        self.setupUi(self)

# 操作窗口
class OperateWindow(QtWidgets.QMainWindow, Operate_Ui):
    def __init__(self):
        super(OperateWindow, self).__init__()
        self.setupUi(self)

控制器用来控制页面的跳转:

# 利用一个控制器来控制页面的跳转
class Controller:
    def __init__(self):
        pass
    # 跳转到 hello 窗口
    def show_hello(self):
        self.hello = HelloWindow()
        self.hello.switch_window1.connect(self.show_login)
        self.hello.switch_window2.connect(self.show_operate)
        self.hello.show()
    # 跳转到 login 窗口, 注意关闭原页面
    def show_login(self):
        self.login = LoginWindow()
        self.hello.close()
        self.login.show()
    # 跳转到 operate 窗口, 注意关闭原页面
    def show_operate(self):
        self.operate = OperateWindow()
        self.hello.close()
        self.operate.show()

启动整个项目:

def main():
    app = QtWidgets.QApplication(sys.argv)
    controller = Controller() # 控制器实例
    controller.show_hello() # 默认展示的是 hello 页面
    sys.exit(app.exec_())

if __name__ == '__main__':
    main()
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章