子窗口继承自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又无法回收,造成内存泄露。