单击 x 按钮时如何隐藏/最小化窗口

时间:2021-02-21 23:00:23

标签: python macos pyqt event-handling pyqt5

背景: 对于单击“x”按钮而不是关闭整个应用程序时隐藏自身(或将其最小化,或只是关闭“主窗口”)的应用程序,这是很常见的。在 mac 中,关闭窗口是“command+w”,而关闭应用程序是“command+q”。它们是不同的。

问题:closeEvent 是不够的。在 PyQT5 中,我们可以在任何 QWindow/QDialog/QWidget 中挂钩 closeEvent 并拒绝该事件。我们可以通过 self.hide() 隐藏窗口。

def closeEvent(self, event):
  event.reject()
  self.hide()

但是,如果我们这样做,窗口将变得不可阻挡,因为其他关闭方式(Command+Q 或右键单击图标然后退出或通过菜单栏退出)都被阻止了。 (这很有趣,因为无论如何都无法关闭该应用。)

可能的解决方案:

  1. 隐藏 x 按钮。这是一种权宜之计,但这个问题是因为我想要的是通过 x 按钮隐藏窗口而不是删除按钮。
  2. 找到除了 closeEvent 之外的不同事件,它可以将 X 按钮与其他按钮区分开来并阻止该事件。但不幸的是,我看不到这样的事件。如果存在该事件,也许我会遇到另一个问题[1]
  3. 继续阻塞 closeEvent 并挂钩其他绑定到“command+Q”或“通过右键单击退出”的事件。然后强制退出该偶数钩中的应用程序。在这种情况下,我的问题变成:我可以通过一些 Qt 对象连接退出或 (command+Q) 吗
  4. 也许还有其他更好的解决方案。

这篇文章可能类似于How to write event for window close(X) button in pyqt4 python,但与“如何使用Qt禁用窗口的关闭按钮”的所谓“重复”完全不同

[1]。这不是一个大问题,但相关。窗口隐藏后,我们需要“单击任务栏/停靠栏中的图标”事件来显示它。是否有一些对象绑定到事件?

2 个答案:

答案 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_())
相关问题