PyQt5创建并显示子窗口

子窗口继承自QWidget

class Child(QWidget):
    def __init__(self, parent=None):
        super(Child, self).__init__(parent)
    #子窗口实现内容
    ...

主窗口中创建并显示子窗口:

方式1:

    def showChild(self):
        child = Child()
        child.show()

这种方式其实child并不是parent的子窗口,因为parent和child没有任何关联,当showChild执行完毕后,依据python的内存回收机制,child会被立即回收,体现在界面上就是子窗口一闪而过

方式2:

    def showChild(self):
        self.child = Child()
        self.child.show()

这种方式child仍然不是parent的子窗口,直观体现就是设置self.child.setWindowModality(Qt.WindowModal)并不能阻塞parent事件,只不过parent通过成员变量持有了Child,Child不会被回收,所以child是能够正常显示的。而当再次调用showChild的时候,会重新实例化一个新的Child,原来的会被回收。

方式3:

    def showChild(self):
        child = Child(self)
        child.show()

这种方式child才真正是parent的子窗口,child设置Qt.WindowModal可以阻塞parent事件,而且在任务栏上是没有child的图标的(子窗口在任务栏上是没有图标的,真正的独立主窗口才有)。

这时child.parent()指向parent,parent.children()也包含child。因为这些都是pyqt内部实现的,并不会因为child.close()而取消,所以需要重写child的close函数,

    def close(self) -> bool:
        self.setParent(None)
        self.deleteLater()
        return super(Child, self).close()

来断开child和parent的连接,否则每次打开child都会实例化一个新的对象,旧的child又无法回收,造成内存泄露。

你可能感兴趣的:(PyQt5学习总结,qt5,python)