pyqt5使用按钮跳转界面

本文介绍了使用PyQt5实现界面跳转的两种方法:一种是纯代码方式,另一种是结合Qtdesigner的设计方式。通过实例展示了按钮点击事件触发新窗口的显示过程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

简介

进行按钮进行界面的跳转,我这里面我介绍两种,一种是没有使用Qtdesigner的代码,另一种是使用Qtdesigner的代码

代码1

import sys
from PyQt5.QtWidgets import QMainWindow, QPushButton, QApplication


class First(QMainWindow):

    def __init__(self):
        super().__init__()

        self.initUI()

    def initUI(self):
        self.btn = QPushButton("Button", self)
        self.btn.move(30, 50)
        


        self.setGeometry(300, 300, 500, 500)
        self.setWindowTitle('Event sender')
        self.show()

class Second(QMainWindow):
    def __init__(self):
        super().__init__()

        self.initUI()

    def initUI(self):
        self.setGeometry(300, 300, 290, 150)
        self.setWindowTitle('Get sender')


if __name__ == '__main__':
    app = QApplication(sys.argv)
    a = First()
    b = Second()
    a.show()
    a.btn.clicked.connect(b.show)
    sys.exit(app.exec_())

代码2

下面的代码使用了Qtdesigner的代码

from PyQt5 import QtCore, QtGui, QtWidgets
import sys
from PyQt5.QtWidgets import QApplication, QMainWindow, QWidget, QLabel,\
                                          QPushButton, QLineEdit, QMenuBar, QStatusBar
from PyQt5.QtCore import *

class FirstWindow(QWidget):

    def __init__(self, parent=None):
        # super这个用法是调用父类的构造函数
        # parent=None表示默认没有父Widget,如果指定父亲Widget,则调用之
        super(FirstWindow, self).__init__(parent)
        self.setGeometry(500, 500, 500, 500)
        self.setWindowTitle('显示')

        self.btn = QPushButton(self)
        self.btn.setText('标定')
        self.btn.move(150, 50)


#下面的一部分是Qtdesigner的代码

class Ui_MainWindow(object):
    def setupUi(self, MainWindow):
        MainWindow.setObjectName("MainWindow")
        MainWindow.resize(624, 479)
        self.centralwidget = QtWidgets.QWidget(MainWindow)
        self.centralwidget.setObjectName("centralwidget")
        self.label = QtWidgets.QLabel(self.centralwidget)
        self.label.setGeometry(QtCore.QRect(190, 130, 51, 31))
        self.label.setObjectName("label")
        self.pushButton = QtWidgets.QPushButton(self.centralwidget)
        self.pushButton.setGeometry(QtCore.QRect(330, 260, 75, 23))
        self.pushButton.setObjectName("pushButton")
        self.lineEdit = QtWidgets.QLineEdit(self.centralwidget)
        self.lineEdit.setGeometry(QtCore.QRect(280, 130, 151, 21))
        self.lineEdit.setObjectName("lineEdit")
        self.label_2 = QtWidgets.QLabel(self.centralwidget)
        self.label_2.setGeometry(QtCore.QRect(190, 180, 51, 31))
        self.label_2.setObjectName("label_2")
        self.lineEdit_2 = QtWidgets.QLineEdit(self.centralwidget)
        self.lineEdit_2.setGeometry(QtCore.QRect(280, 190, 151, 21))
        self.lineEdit_2.setObjectName("lineEdit_2")
        self.pushButton_2 = QtWidgets.QPushButton(self.centralwidget)
        self.pushButton_2.setGeometry(QtCore.QRect(200, 260, 75, 23))
        self.pushButton_2.setObjectName("pushButton_2")
        MainWindow.setCentralWidget(self.centralwidget)
        self.menubar = QtWidgets.QMenuBar(MainWindow)
        self.menubar.setGeometry(QtCore.QRect(0, 0, 624, 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", "   长"))
        self.pushButton.setText(_translate("MainWindow", "确定"))
        self.label_2.setText(_translate("MainWindow", "   宽"))
        self.pushButton_2.setText(_translate("MainWindow", "取消"))

if __name__ == "__main__":
    app = QApplication(sys.argv)
    MainWindow = QMainWindow()
    ui = Ui_MainWindow()
    ui.setupUi(MainWindow)

    ex = FirstWindow()
    ex.btn.clicked.connect(MainWindow.show)
    ex.show()

    sys.exit(app.exec_())

 

### PyQt5按钮点击事件导致的界面切换速度慢问题 当在PyQt5应用程序中遇到由于长时间操作而导致界面卡顿的情况时,主要原因是主进程中执行了耗时的任务,阻塞了GUI线程[^1]。为了提高响应速度并保持良好的用户体验,在设计应用逻辑时应考虑将耗时任务移至后台工作。 #### 使用多线程或多进程处理耗时任务 对于那些确实需要较长时间才能完成的工作流程,推荐采用Python内置模块`threading`或`multiprocessing`创建新的线程/进程来运行这些任务。这样可以让主线程继续监听用户的交互而不受影响: ```python from threading import Thread import time def long_running_task(): # 模拟一个耗时较长的任务 time.sleep(2) class WorkerThread(Thread): def __init__(self, target=None): super().__init__() self.target = target def run(self): if callable(self.target): self.target() # 创建worker实例并将long_running_task作为目标函数传递给它 worker = WorkerThread(target=long_running_task) worker.start() ``` #### 利用信号槽机制更新UI状态 即使是在另一个线程里完成了实际的数据获取或其他计算密集型作业,也不能直接修改任何属于主窗口部件的对象属性;而是应该利用PyQt自带的Signal & Slot系统通知前端做出相应改变: ```python from PyQt5.QtCore import pyqtSlot, QObject, pyqtSignal class Communicate(QObject): update_ui_signal = pyqtSignal(str) communicator = Communicate() @pyqtSlot(str) def handle_update(message): print(f"Received message from worker thread: {message}") communicator.update_ui_signal.connect(handle_update) # 在WorkerThread.run方法内部发送消息回主线程 if some_condition_met: communicator.update_ui_signal.emit('Task finished') ``` #### 预加载资源减少延迟感 提前准备好即将展示的内容也可以有效缓解瞬间性能瓶颈带来的影响。比如预先加载图片文件到内存缓存区、初始化好待渲染的小部件对象等措施都能让用户感觉程序更加流畅自然[^5]: ```python cached_widgets = {} for widget_name in ['page_1', 'page_2']: new_widget = QWidget() setup_page(new_widget) # 自定义页面配置函数 cached_widgets[widget_name] = new_widget current_shown = None def switch_to(page_key): global current_shown if page_key != current_shown and page_key in cached_widgets: layout.addWidget(cached_widgets[page_key]) current_shown = page_key ``` 通过上述几种方式相结合的方式能够显著改善基于PyQt框架构建的应用程序因频繁触发复杂业务逻辑而引起的视觉停滞现象。
评论 8
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值