首页 > 解决方案 > 如何从 PyQt 的主窗口打开和关闭新窗口?

问题描述

我在谷歌搜索通常很多帖子都在谈论如何打开一个新窗口而不是说明如何关闭窗口。我在这个网站上找到了几篇文章,但其中大部分都使用了我的软件中没有考虑到的对话框窗口。

我制作了一个包含旋转框和按钮的 UI 来演示我的问题。我可以在旋转框中输入等于或小于 5 的数字。当我单击按钮时,会显示一些新窗口,显示的窗口数量取决于旋转框中的数字。如果我更改为旋转框中的数字然后单击按钮,原始窗口将关闭并显示新窗口。

Fox 示例,首先我在微调框中输入“2”,然后单击按钮。然后会出现2个新窗口。如果我将旋转框中的数字更改为 3,然后单击按钮,原来的 2 个窗口将关闭,并显示 3 个新窗口。

这是我的主要程序代码:

from PyQt5.QtWidgets import QApplication, QMainWindow
from uitest_review import Ui_MainWindow  # import the UI module

# set up a class for main window
class window(QMainWindow):
    def __init__(self, parent=None):
        super(window, self).__init__(parent)

        self.ui = Ui_MainWindow()
        self.ui.setupUi(self)
        self.ui.Open.clicked.connect(self.openwindow)

    def openwindow(self):
        windownum = self.ui.windownum.value()
        print("open window num:", windownum)
        opennewwindow = newwindow(self)
        opennewwindow.show()

class newwindow(QMainWindow):
    def setupUi(self, MainWindow):
    MainWindow.setObjectName("MainWindow")

if __name__ == "__main__":
    app = QApplication([])
    gui = window()
    gui.show()
    app.exec_()

这是我的用户界面代码:

from PyQt5 import QtCore, QtGui, QtWidgets

class Ui_MainWindow(object):
    def setupUi(self, MainWindow):
        MainWindow.setObjectName("MainWindow")
        MainWindow.resize(816, 577)
        self.centralwidget = QtWidgets.QWidget(MainWindow)
        self.centralwidget.setObjectName("centralwidget")
        self.gridLayout = QtWidgets.QGridLayout(self.centralwidget)
        self.gridLayout.setObjectName("gridLayout")
        self.scrollArea = QtWidgets.QScrollArea(self.centralwidget)
        self.scrollArea.setWidgetResizable(True)
        self.scrollArea.setObjectName("scrollArea")
        self.scrollAreaWidgetContents = QtWidgets.QWidget()
        self.scrollAreaWidgetContents.setGeometry(QtCore.QRect(0, 0, 796, 537))
        self.scrollAreaWidgetContents.setObjectName(\
        "scrollAreaWidgetContents")
        self.verticalLayout = QtWidgets.QVBoxLayout(self.scrollAreaWidgetContents)
        self.verticalLayout.setContentsMargins(0, 0, 0, 0)
        self.verticalLayout.setObjectName("verticalLayout")
        spacerItem = QtWidgets.QSpacerItem(20, 10, QtWidgets.QSizePolicy.Minimum, QtWidgets.QSizePolicy.Minimum)
        self.verticalLayout.addItem(spacerItem)
        self.windownum = QtWidgets.QSpinBox(self.scrollAreaWidgetContents)
        self.windownum.setMaximum(5)
        self.windownum.setObjectName("windownum")
        self.verticalLayout.addWidget(self.windownum)
        self.groupBox = QtWidgets.QGroupBox(self.scrollAreaWidgetContents)
        self.groupBox.setTitle("")
        self.groupBox.setObjectName("groupBox")
        self.horizontalLayout = QtWidgets.QHBoxLayout(self.groupBox)
        self.horizontalLayout.setObjectName("horizontalLayout")
        spacerItem1 = QtWidgets.QSpacerItem(40, 20, QtWidgets.QSizePolicy.Preferred, QtWidgets.QSizePolicy.Minimum)
        self.horizontalLayout.addItem(spacerItem1)
        self.Open = QtWidgets.QPushButton(self.groupBox)
        font = QtGui.QFont()
        font.setPointSize(14)
        font.setBold(True)
        font.setWeight(75)
        self.Open.setFont(font)
        self.Open.setObjectName("Open")
        self.horizontalLayout.addWidget(self.Open)
        spacerItem2 = QtWidgets.QSpacerItem(40, 20, QtWidgets.QSizePolicy.Preferred, QtWidgets.QSizePolicy.Minimum)
        self.horizontalLayout.addItem(spacerItem2)
        self.verticalLayout.addWidget(self.groupBox)
        self.scrollArea.setWidget(self.scrollAreaWidgetContents)
        self.gridLayout.addWidget(self.scrollArea, 0, 0, 1, 1)
        MainWindow.setCentralWidget(self.centralwidget)
        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.Open.setText(_translate("MainWindow", "Open"))


if __name__ == "__main__":
    import sys
    app = QtWidgets.QApplication(sys.argv)
    MainWindow = QtWidgets.QMainWindow()
    ui = Ui_MainWindow()
    ui.setupUi(MainWindow)
    MainWindow.show()
    sys.exit(app.exec_())

我在主程序中创建了一个新类(newwindow),我可以调用这个类来显示一个新窗口。但我无法弄清楚如何检测打开了多少个窗口以及如何关闭它们。有人可以帮助我吗?太感谢了。

标签: pyqt5new-window

解决方案


我自己想通了。

class window(QMainWindow):
    def __init__(self, parent=None):
        super(window, self).__init__(parent)
        self.ui = Ui_MainWindow()
        self.ui.setupUi(self)
        self.ui.Open.clicked.connect(self.openwindow)
        self.openedwin = []

    def openwindow(self):
        windownum = self.ui.windownum.value()
        if windownum != 0:
            if self.openedwin != []:
                for window in self.openedwin:
                    window.close()
            for repeat in range(windownum):
                opennewwindow = newwindow(self)
                # print("opennewwindow:", opennewwindow)
                self.openedwin.append(opennewwindow)
                opennewwindow.show()
        # print("self.openedwin:", self.openedwin)


class newwindow(QMainWindow):
    def setupUi(self, MainWindow):
        MainWindow.setObjectName("MainWindow")

if __name__ == "__main__":
    app = QApplication([])
    gui = window()
    gui.show()
    app.exec_()

我添加了一个列表 self.openedwin = [] 来保存所有窗口对象。我可以使用“window object”.close() 命令在打开新窗口之前关闭窗口。


推荐阅读