pyQt5实现页面切换操作

pyqt5实现多个页面切换

1.实验目的

最近探索了下各种页面跳转方式,现在介绍一种最直接的方式,就是qtdesigner中自带的分页组件,每个页面独立,比较适合多页面需求的朋友。因为毕竟核心在于目标检测网络的后端算法,所以前端web页面不需要特别精致,现在介绍一种比较实用的方式来进行页面切换。

2.ui界面

图1 第一个页面

图2 第二个页面

3.python脚本

python 复制代码
# -*- coding: utf-8 -*-
import sys

# Form implementation generated from reading ui file 'MainMenu.ui'
#
# Created by: PyQt5 UI code generator 5.15.9
#
# 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
from PyQt5.QtWidgets import QMessageBox


class Ui_Form(object):
    def setupUi(self, Form):
        Form.setObjectName("Form")
        Form.resize(916, 650)
        self.label = QtWidgets.QLabel(Form)
        self.label.setGeometry(QtCore.QRect(0, 10, 741, 641))
        self.label.setText("")
        self.label.setPixmap(QtGui.QPixmap(":/img1/img1.jpg"))
        self.label.setObjectName("label")
        self.label_2 = QtWidgets.QLabel(Form)
        self.label_2.setGeometry(QtCore.QRect(120, 60, 671, 51))
        self.label_2.setStyleSheet("font:18pt \"Times New Roman\";")
        self.label_2.setObjectName("label_2")
        self.tabWidget = QtWidgets.QTabWidget(Form)
        self.tabWidget.setGeometry(QtCore.QRect(0, 100, 731, 531))
        self.tabWidget.setObjectName("tabWidget")
        self.tab = QtWidgets.QWidget()
        self.tab.setObjectName("tab")
        self.pushButton = QtWidgets.QPushButton(self.tab)
        self.pushButton.setGeometry(QtCore.QRect(220, 210, 75, 23))
        self.pushButton.setObjectName("pushButton")
        self.tabWidget.addTab(self.tab, "")
        self.tab_2 = QtWidgets.QWidget()
        self.tab_2.setObjectName("tab_2")
        self.pushButton_2 = QtWidgets.QPushButton(self.tab_2)
        self.pushButton_2.setGeometry(QtCore.QRect(250, 180, 75, 23))
        self.pushButton_2.setObjectName("pushButton_2")
        self.tabWidget.addTab(self.tab_2, "")

        self.retranslateUi(Form)
        self.tabWidget.setCurrentIndex(0)
        QtCore.QMetaObject.connectSlotsByName(Form)

    def retranslateUi(self, Form):
        _translate = QtCore.QCoreApplication.translate
        Form.setWindowTitle(_translate("Form", "Form"))
        self.label_2.setText(_translate("Form", "欢迎来到长江大学电子信息与电气工程学院"))
        self.pushButton.setText(_translate("Form", "button1"))
        self.tabWidget.setTabText(self.tabWidget.indexOf(self.tab), _translate("Form", "图片检测界面"))
        self.pushButton_2.setText(_translate("Form", "button2"))
        self.tabWidget.setTabText(self.tabWidget.indexOf(self.tab_2), _translate("Form", "视频检测界面"))

    def fun1(self):
        box = QMessageBox()
        box.setText("欢迎来到第一个页面")
        box.show()
        box.exec_()

    def fun2(self):
        box = QMessageBox()
        box.setText("欢迎来到第二个页面")
        box.show()
        box.exec_()


import img1_rc
import logo_rc

if __name__ == '__main__':
    app = QtWidgets.QApplication(sys.argv)
    Form = QtWidgets.QWidget()
    ui = Ui_Form()
    ui.setupUi(Form)
    ui.pushButton.clicked.connect(ui.fun1)
    ui.pushButton_2.clicked.connect(ui.fun2)
    Form.show()

    sys.exit(app.exec_())

4.实验结果展示

图3 实验结果展示

4.总结

页面切换/跳转,同等条件下,实际上页面切换似乎会更加便捷,因为他直接划分了作用域,不必考虑页面切换之间的变量变化。

相关推荐
一方热衷.8 小时前
YOLO26-Seg ONNXruntime C++/python推理
开发语言·c++·python
靓仔建10 小时前
Vue3导入组件出错does not provide an export named ‘user_setting‘ (at index.vue:180:10)
开发语言·前端·typescript
赶路人儿11 小时前
UTC时间和时间戳介绍
java·开发语言
6+h11 小时前
【java】基本数据类型与包装类:拆箱装箱机制
java·开发语言·python
未来之窗软件服务12 小时前
幽冥大陆(一百12)js打造json硬件管道——东方仙盟筑基期
开发语言·javascript·算法·json·仙盟创梦ide·东方仙盟·东方仙盟算法
人道领域12 小时前
苍穹外卖:菜品分页查询与删除功能(保姆级详解)
java·开发语言·数据库·后端·spring
EverestVIP12 小时前
c++前置声明的方式与说明
开发语言·c++
天远云服13 小时前
天远企业司法认证API对接实战:PHP构建B2B供应链合规防火墙
大数据·开发语言·后端·node.js·php
空空kkk13 小时前
Java基础——代理
java·开发语言
赵谨言13 小时前
基于YOLOv5的植物目标检测研究
大数据·开发语言·经验分享·python