Search code examples
pythonpyqtqtguiqmainwindow

PyQt: How to hide QMainWindow


Clicking Dialog_01's button hides its window and opens Dialog_02. Clicking Dialog_02's button should close its windows and unhide Dialog_01. How to achieve it?

import sys, os
from PyQt4 import QtCore, QtGui    

class Dialog_02(QtGui.QMainWindow):
    def __init__(self):
        super(Dialog_02, self).__init__()

        myQWidget = QtGui.QWidget()
        myBoxLayout = QtGui.QVBoxLayout()       

        Button_02 = QtGui.QPushButton("Close THIS and Unhide Dialog 01")
        Button_02.clicked.connect(self.closeAndReturn)
        myBoxLayout.addWidget(Button_02)

        myQWidget.setLayout(myBoxLayout)
        self.setCentralWidget(myQWidget)
        self.setWindowTitle('Dialog 02')

    def closeAndReturn(self):
        self.close()

class Dialog_01(QtGui.QMainWindow):
    def __init__(self):
        super(Dialog_01, self).__init__()

        myQWidget = QtGui.QWidget()
        myBoxLayout = QtGui.QVBoxLayout()       

        Button_01 = QtGui.QPushButton("Hide THIS and Open Dialog 02")
        Button_01.clicked.connect(self.callAnotherQMainWindow)
        myBoxLayout.addWidget(Button_01)        

        myQWidget.setLayout(myBoxLayout)
        self.setCentralWidget(myQWidget)
        self.setWindowTitle('Dialog 01')

    def callAnotherQMainWindow(self):
        self.hide()
        self.dialog_02 = Dialog_02()
        self.dialog_02.show()
        self.dialog_02.raise_()

if __name__ == '__main__':
    app = QtGui.QApplication(sys.argv)
    dialog_1 = Dialog_01()
    dialog_1.show()
    sys.exit(app.exec_())

Solution

  • Make the first window a parent of the second window:

    class Dialog_02(QtGui.QMainWindow):
        def __init__(self, parent):
            super(Dialog_02, self).__init__(parent)
            # ensure this window gets garbage-collected when closed
            self.setAttribute(QtCore.Qt.WA_DeleteOnClose)
        ...    
    
        def closeAndReturn(self):
            self.close()
            self.parent().show()
    
    class Dialog_01(QtGui.QMainWindow):
        ...
    
        def callAnotherQMainWindow(self):
            self.hide()
            self.dialog_02 = Dialog_02(self)
            self.dialog_02.show()
    

    If you want the same dialog to be shown each time, do something like:

        def callAnotherQMainWindow(self):
            self.hide()
            if not hassattr(self, 'dialog_02'):
                self.dialog_02 = Dialog_02(self)
            self.dialog_02.show()
    

    and hide() the child window, rather than closing it.