背景: 对于单击“x”按钮而不是关闭整个应用程序时隐藏自身(或将其最小化,或只是关闭“主窗口”)的应用程序,这是很常见的。在 mac 中,关闭窗口是“command+w”,而关闭应用程序是“command+q”。它们是不同的。
问题:closeEvent
是不够的。在 PyQT5 中,我们可以在任何 QWindow/QDialog/QWidget 中挂钩 closeEvent 并拒绝该事件。我们可以通过 self.hide()
隐藏窗口。
def closeEvent(self, event):
event.reject()
self.hide()
但是,如果我们这样做,窗口将变得不可阻挡,因为其他关闭方式(Command+Q 或右键单击图标然后退出或通过菜单栏退出)都被阻止了。 (这很有趣,因为无论如何都无法关闭该应用。)
可能的解决方案:
这篇文章可能类似于How to write event for window close(X) button in pyqt4 python,但与“如何使用Qt禁用窗口的关闭按钮”的所谓“重复”完全不同
[1]。这不是一个大问题,但相关。窗口隐藏后,我们需要“单击任务栏/停靠栏中的图标”事件来显示它。是否有一些对象绑定到事件?
答案 0 :(得分:1)
尝试将 WA_QuitOnClose
设置为 False。以下对我有用:
import sys
from PyQt5.QtWidgets import *
from PyQt5.QtCore import *
from PyQt5.QtGui import *
if __name__ == '__main__':
app = QApplication(sys.argv)
window = QMainWindow()
window.setCentralWidget(QWidget())
window.setAttribute(Qt.WA_QuitOnClose, False)
QShortcut(QKeySequence.Close, window, window.close)
window.show()
sys.exit(app.exec_())
答案 1 :(得分:0)
检查应用程序是否关闭的一种方法(通过右键单击 Dock 中的图标或 cmd+Q)是捕获应用程序的事件。
我认为事件链是: 应用程序关闭 (19) -> 窗口关闭 (19) -> AboutToQuit
因此,如果窗口关闭被阻止,则 AboutToQuit 中没有任何帮助。我们只需要捕捉上游事件,应用程序关闭。
class MyApplication(QApplication):
def event(self, e):
if e.type() == 19: # Close event
sys.exit() # Or we can do other things to "force close"
class MyWindow(QMainWindow):
def closeEvent(self, e):
e.ignore()
if __name__ == '__main__':
app = MyApplication(sys.argv)
window = MyWindow()
window.show()
sys.exit(app.exec_())