Pyside uiLoader 捕获关闭事件信号



如何正确捕获来自 PySide QtUiTools.QUiLoader(( 设置的关闭事件?

我可以让实例化类连接到小部件和其他所有内容,但我不确定如何在此设置中拦截信号。

理想情况下,我希望所有关闭的调用都通过我的closeEvent(显然(,以便我可以确保关闭窗口是安全的。但是由于我的self.closeEvent((绑定到我的View(QtWidgets.QMainWindow(而不是self._qt.closeEvent((,我不知道如何进入self._qt.closeEvent((方法来在这种情况下覆盖它。

或者有没有更好的方法来设置它来捕获这些窗口事件?

# Compatible enough with Pyside 2
from PySide import QtGui as QtWidgets
from PySide import QtUiTools
from PySide import QtCore
class View(QtWidgets.QMainWindow):
def __init__(self, parent=None):
super(View, self).__init__(parent=parent)
self.setup()
def closeEvent(self, event):
# Do things
event.accept()
def setup(self):
loader = QtUiTools.QUiLoader()
fy = QtCore.QFile('example.ui')
fy.open(QtCore.QFile.ReadOnly)
self._qt = loader.load(fy, self)
fy.close()
self._qt.pCanceled.clicked(self._qt.close)

不适用:

PySide/PyQt 检测用户是否尝试关闭窗口

关闭,但 PySide 不使用 PyQt 的 uic,并且似乎以不同的方式运行(并且不起作用(:

PyQt:点击 X 不会触发关闭事件

closeEvent

不是信号,而是发送QCloseEvent事件时调用的方法。信号和事件是不同的东西。谈到这个问题,在Qt中有两种侦听事件的方法,第一种是覆盖fooEvent()方法,第二种是使用事件过滤器,如下所示:

from PySide import QtGui as QtWidgets
from PySide import QtUiTools
from PySide import QtCore
class View(QtWidgets.QMainWindow):
def __init__(self, parent=None):
super(View, self).__init__(parent=parent)
self._qt = None
self.setup()
def closeEvent(self, event):
self.do_things()
super(View, self).closeEvent(event)
def do_things(self):
print("do_things")
def setup(self):
loader = QtUiTools.QUiLoader()
fy = QtCore.QFile('example.ui')
fy.open(QtCore.QFile.ReadOnly)
self._qt = loader.load(fy, self)
fy.close()
self._qt.pCanceled.clicked.connect(self._qt.close)
self._qt.installEventFilter(self)
def eventFilter(self, watched, event):
if watched is self._qt and event.type() == QtCore.QEvent.Close:
self.do_things()
return super(View, self).eventFilter(watched, event)

if __name__ == '__main__':
import sys
app = QtWidgets.QApplication(sys.argv)
w = View()
w.show()
sys.exit(app.exec_())

更新:

通常,在eventFilter中,返回 True 即可忽略事件,但在QCloseEvent的情况下,您必须忽略该事件并返回 True,如下所示:

def eventFilter(self, watched, event):
if watched is self._qt and event.type() == QtCore.QEvent.Close:
self.do_things()
event.ignore()
return True
return super(View, self).eventFilter(watched, event)

最新更新