如何在pyqt5中显示隐藏窗口?

Posted

技术标签:

【中文标题】如何在pyqt5中显示隐藏窗口?【英文标题】:how to show a hidden window in pyqt5? 【发布时间】:2021-12-16 15:42:04 【问题描述】:

我有两个代码:

untitled.py
vprs.py

当我切换到新窗口(vprs.py)时,第一个窗口被隐藏(untitled.py)。 在窗口 vprs.py 我有一个“返回”按钮,当我点击这个按钮时如何让第一个窗口出现(untitled.py)。

代码如下:

无标题.py:

import sys
from PyQt5 import QtCore, QtGui, QtWidgets
from ohelp import Ui_oHelp
from vprs import ui_vprs_ElectroMagnetic, Moshnost_electro

class Ui_MainWindow(object):
    def openohelp(self):
        self.window = QtWidgets.QMainWindow()
        self.ui = Ui_oHelp()
        self.ui.setupUui(self.window)
        self.window.show()

    def setupUi(self, MainWindow):
        ***
# ---------------------------------------------------------------------------
        self.pushButton_8.clicked.connect(self.openohelp)
        self.pushButton_3.clicked.connect(quit)
        self.pushButton_4.clicked.connect(self.vprsElectro)
        self.pushButton.clicked.connect(self.mossh) # Transition function to vprs

    def mossh(self):
        self.windo = QtWidgets.QMainWindow()
        self.ui = Moshnost_electro()
        self.ui.moshui(self.windo)
        self.windo.show()
        MainWindow.hide()

    def vprsElectro(self):
        self.window1 = QtWidgets.QMainWindow()
        self.ui = ui_vprs_ElectroMagnetic()
        self.ui.vprsui(self.window1)
        self.window1.show()

    def retranslateUi(self, MainWindow):
        ***
if __name__ == "__main__":
    app = QtWidgets.QApplication(sys.argv)
    MainWindow = QtWidgets.QMainWindow()
    ui = Ui_MainWindow()
    ui.setupUi(MainWindow)
    MainWindow.show()
    sys.exit(app.exec_())

vprs.py:

from PyQt5 import QtCore, QtGui, QtWidgets
from electrom_test import Ui_Electrom
from mosh_rabotaem import Ui_Window

class Moshnost_electro(object):
    def moshui(self, MainWindow):
        MainWindow.setObjectName("MainWindow")
        MainWindow.resize(338, 600)
        self.centralwidget = QtWidgets.QWidget(MainWindow)
        self.centralwidget.setObjectName("centralwidget")
        self.pushButton = QtWidgets.QPushButton(self.centralwidget)
        self.pushButton.setGeometry(QtCore.QRect(10, 0, 321, 241))
        font = QtGui.QFont()
        font.setPointSize(14)
        self.pushButton.setFont(font)
        self.pushButton.setObjectName("pushButton")
        self.pushButton_2 = QtWidgets.QPushButton(self.centralwidget)
        self.pushButton_2.setGeometry(QtCore.QRect(10, 250, 321, 241))
        font = QtGui.QFont()
        font.setPointSize(14)
        self.pushButton_2.setFont(font)
        self.pushButton_2.setObjectName("pushButton_2")
        self.pushButton_3 = QtWidgets.QPushButton(self.centralwidget)
        self.pushButton_3.setGeometry(QtCore.QRect(10, 502, 321, 51))
        font = QtGui.QFont()
        font.setPointSize(14)
        self.pushButton_3.setFont(font)
        self.pushButton_3.setObjectName("pushButton_3")
        MainWindow.setCentralWidget(self.centralwidget)
        self.menubar = QtWidgets.QMenuBar(MainWindow)
        self.menubar.setGeometry(QtCore.QRect(0, 0, 338, 21))
        self.menubar.setObjectName("menubar")
        MainWindow.setMenuBar(self.menubar)
        self.statusbar = QtWidgets.QStatusBar(MainWindow)
        self.statusbar.setObjectName("statusbar")
        MainWindow.setStatusBar(self.statusbar)

        self.retrans(MainWindow)
        QtCore.QMetaObject.connectSlotsByName(MainWindow)
        # -------------------------------------------------------------------------------------------
        self.pushButton_3.clicked.connect(self.fixx) # button 'back'

    def fixx(self): #function button back
        pass
    
    def retrans(self, MainWindow):
        _translate = QtCore.QCoreApplication.translate
        MainWindow.setWindowTitle(_translate("MainWindow", "MainWindow"))
        self.pushButton.setText(_translate("MainWindow", "Варианты задач"))
        self.pushButton_2.setText(_translate("MainWindow", "Формулы"))
        self.pushButton_3.setText(_translate("MainWindow", "Назад в меню"))

我尝试自己解决问题,但没有任何效果。 (如果您需要更多代码行,我会添加它)。提前谢谢你。

【问题讨论】:

【参考方案1】:

您可以将新窗口的按钮clicked 信号与前一个的show 连接起来。

基本上,以下可能就足够了:

    def mossh(self):
        self.windo = QtWidgets.QMainWindow()
        self.ui = Moshnost_electro()
        self.ui.moshui(self.windo)
        self.windo.show()
        MainWindow.hide()
        self.ui.pushButton_3.clicked.connect(MainWindow.show)

但是。虽然这可行,但我强烈反对这样做,这是因为您的代码存在严重问题,迟早会产生其他问题。

首先,pyuic 生成的文件不应该被编辑。这些文件旨在专门用作imports,并且始终保持不变(在官方指南中阅读更多关于这个非常重要方面的信息using Designer)。

另一个重要的问题是你不断地覆盖self.ui,这是错误的,因为有两个原因:首先,每个窗口都应该有自己对ui的引用,然后每次你做self.ui = ...你失去任何可能的、直接的方式来访问 当前 ui。

因此,第一步是重建所有 ui 文件(每个UI 都有自己的文件),包括引用主窗口的文件。然后,该主窗口将在 __init__ 中创建所有其他窗口,并在适当的时候显示它们(而不是连续创建它们)。

在以下示例中,我假设您已将主窗口 ui 生成为 ui_mainWindow.py

from PyQt5 import QtWidgets
from ui_mainWindow import Ui_MainWindow
from ohelp import Ui_oHelp
from vprs import Moshnost_electro


class MainWindow(QtWidgets.QMainWindow, Ui_MainWindow):
    def __init__(self):
        super().__init__()
        self.setupUi(self)

        self.helpWindow = HelpWindow()
        self.mosshWindow = MosshWindow()

        self.pushButton_8.clicked.connect(self.openohelp)
        self.pushButton.clicked.connect(self.mossh)

        self.mosshWindow.pushButton_3.clicked.connect(self.show)

    def openhelp(self):
        self.helpWindow.show()

    def mossh(self):
        self.hide()
        self.mosshWindow.show()


class HelpWindow(QtWidgets.QMainWindow, Ui_oHelp):
    def __init__(self):
        super().__init__()
        self.setupUi(self)


class MosshWindow(QtWidgets.QMainWindow, Moshnost_electro):
    def __init__(self):
        super().__init__()
        self.setupUi(self)
        self.pushButton_3.clicked.connect(self.hide)


if __name__ == "__main__":
    import sys
    app = QtWidgets.QApplication(sys.argv)
    mainWindow = MainWindow()
    mainWindow.show()
    sys.exit(app.exec_())

补充说明:

只有类和常量应该有大写的名称(如上所示,我使用了mainWindow = MainWindow()); 您也不应该引用可能具有多个实例的对象实例的全局变量(就像您对 MainWindow.hide() 所做的那样; 始终不鼓励使用固定/硬编码的几何图形,并且应该始终首选layout managers(即使来自Designer); 而不是QMainWindow,你应该考虑一个QDialog用于外部窗口并使用exec(),这也是因为现在如果用户关闭另一个窗口,它不会自动重新打开主窗口(程序将出口);注意如果要切换到dialog,不能复用同一个ui文件,需要在Designer中新建一个;

【讨论】:

以上是关于如何在pyqt5中显示隐藏窗口?的主要内容,如果未能解决你的问题,请参考以下文章

PyQt5如何暂时隐藏主窗口? [关闭]

delphi2007如何让程序不在任务栏中隐藏和显示?

PYQT5 qlineedit 隐藏后不显示

PyQt5 QDialog隐藏问号按钮

如何在HTML中的一个页面中实现窗口的隐藏和显示?

如何在 iPhone 中隐藏窗口屏幕并在一段时间后显示屏幕?