PyQt4最小化到托盘

时间:2009-04-16 22:16:38

标签: python pyqt4 system-tray minimize

有没有办法在PyQt4中最小化到托盘?我已经使用过QSystemTrayIcon类,但现在我想最小化或“隐藏”我的应用程序窗口,并只显示托盘图标。

有人这样做过吗?任何方向都会受到赞赏。

在Window XP Pro上使用Python 2.5.4和PyQt4

7 个答案:

答案 0 :(得分:29)

一旦你记住实际上没有办法最小化到system tray,这是非常简单的。

相反,你这样做是假的:

  1. 在窗口上捕捉最小化事件
  2. 在最小化事件处理程序中,创建并显示QSystemTrayIcon
  3. 同样在最小化事件处理程序中,在窗口上调用hide()或setVisible(false)
  4. 抓住系统任务栏图标
  5. 上的点击/双击/菜单项
  6. 在您的系统托盘图标事件处理程序中,在窗口上调用show()或setVisible(true),并可选择隐藏托盘图标。

答案 1 :(得分:12)

代码有帮助,所以这是我为应用程序编写的内容,除了closeEvent而不是最小化事件。

注意:

“closeEvent(event)”是一个重写的Qt事件,因此必须将它放在实现您要隐藏的窗口的类中。

“okayToClose()”是您可能考虑实现的函数(或者您可能想要存储的布尔标志),因为有时您实际上想要退出应用程序而不是最小化到系统托盘。

还有一个如何再次显示()窗口的例子。

def __init__(self):
  traySignal = "activated(QSystemTrayIcon::ActivationReason)"
  QtCore.QObject.connect(self.trayIcon, QtCore.SIGNAL(traySignal), self.__icon_activated)

def closeEvent(self, event):
  if self.okayToClose(): 
    #user asked for exit
    self.trayIcon.hide()
    event.accept()
  else:
    #"minimize"
    self.hide()
    self.trayIcon.show() #thanks @mojo
    event.ignore()

def __icon_activated(self, reason):
  if reason == QtGui.QSystemTrayIcon.DoubleClick:
    self.show()

答案 2 :(得分:7)

只是为了添加Chris的例子:

在声明信号时使用Qt表示法至关重要,即

<强>正确

self.connect(self.icon, SIGNAL("activated(QSystemTrayIcon::ActivationReason)"), self.iconClicked)

而不是PyQt一个

不正确,无效:

self.connect(self.icon, SIGNAL("activated(QSystemTrayIcon.ActivationReason)"), self.iconClicked)

请注意信号字符串中的::。这花了我大约三个小时来弄明白。

答案 3 :(得分:4)

这是工作代码。谢谢 Matze 至关重要,SIGNAL带给我更多的好奇心......但做其他事情。所以你要#!时刻: - )

def create_sys_tray(self):
    self.sysTray = QtGui.QSystemTrayIcon(self)
    self.sysTray.setIcon( QtGui.QIcon('../images/corp/blip_32.png') )
    self.sysTray.setVisible(True)
    self.connect(self.sysTray, QtCore.SIGNAL("activated(QSystemTrayIcon::ActivationReason)"), self.on_sys_tray_activated)

    self.sysTrayMenu = QtGui.QMenu(self)
    act = self.sysTrayMenu.addAction("FOO")

def on_sys_tray_activated(self, reason):
    print "reason-=" , reason

答案 4 :(得分:3)

这是对vzades回复的编辑,但它在很多方面被拒绝了。它与它们的代码完全相同,但也会遵循最小化事件(并且在没有语法错误/缺少图标的情况下运行)。

import sys
from PyQt4 import QtGui, QtCore


class Example(QtGui.QWidget):
    def __init__(self):
        super(Example, self).__init__()
        self.initUI()

    def initUI(self):
        style = self.style()

        # Set the window and tray icon to something
        icon = style.standardIcon(QtGui.QStyle.SP_MediaSeekForward)
        self.tray_icon = QtGui.QSystemTrayIcon()
        self.tray_icon.setIcon(QtGui.QIcon(icon))
        self.setWindowIcon(QtGui.QIcon(icon))

        # Restore the window when the tray icon is double clicked.
        self.tray_icon.activated.connect(self.restore_window)

    def event(self, event):
        if (event.type() == QtCore.QEvent.WindowStateChange and 
                self.isMinimized()):
            # The window is already minimized at this point.  AFAIK,
            # there is no hook stop a minimize event. Instead,
            # removing the Qt.Tool flag should remove the window
            # from the taskbar.
            self.setWindowFlags(self.windowFlags() & ~QtCore.Qt.Tool)
            self.tray_icon.show()
            return True
        else:
            return super(Example, self).event(event)

    def closeEvent(self, event):
        reply = QtGui.QMessageBox.question(
            self,
            'Message',"Are you sure to quit?",
            QtGui.QMessageBox.Yes | QtGui.QMessageBox.No,
            QtGui.QMessageBox.No)

        if reply == QtGui.QMessageBox.Yes:
            event.accept()
        else:
            self.tray_icon.show()
            self.hide()
            event.ignore()

    def restore_window(self, reason):
        if reason == QtGui.QSystemTrayIcon.DoubleClick:
            self.tray_icon.hide()
            # self.showNormal will restore the window even if it was
            # minimized.
            self.showNormal()

def main():
    app = QtGui.QApplication(sys.argv)
    ex = Example()
    ex.show()
    sys.exit(app.exec_())


if __name__ == '__main__':
    main()

答案 5 :(得分:1)

这是代码,它确实帮助我相信给我看代码

import sys
from PyQt4 import QtGui, QtCore
from PyQt4.QtGui import QDialog, QApplication, QPushButton, QLineEdit, QFormLayout, QSystemTrayIcon


class Example(QtGui.QWidget):

    def __init__(self):
        super(Example, self).__init__()
        self.initUI()

    def initUI(self):
        self.icon = QSystemTrayIcon()
        r = self.icon.isSystemTrayAvailable()
        print r
        self.icon.setIcon(QtGui.QIcon('/home/vzades/Desktop/web.png'))
        self.icon.show()
        # self.icon.setVisible(True)
        self.setGeometry(300, 300, 250, 150)
        self.setWindowIcon(QtGui.QIcon('/home/vzades/Desktop/web.png'))
        self.setWindowTitle('Message box')
        self.show()
        self.icon.activated.connect(self.activate)
        self.show()

    def closeEvent(self, event):

        reply = QtGui.QMessageBox.question(self, 'Message', "Are you sure to quit?", QtGui.QMessageBox.Yes |
                                           QtGui.QMessageBox.No, QtGui.QMessageBox.No)

        if reply == QtGui.QMessageBox.Yes:
            event.accept()
        else:
            self.icon.show()

            self.hide()

            event.ignore()

    def activate(self, reason):
        print reason
        if reason == 2:
            self.show()

    def __icon_activated(self, reason):
        if reason == QtGui.QSystemTrayIcon.DoubleClick:
            self.show()


def main():

    app = QtGui.QApplication(sys.argv)
    ex = Example()
    sys.exit(app.exec_())


if __name__ == '__main__':
    main()

答案 6 :(得分:1)

这是处理双击PyQt5托盘图标的正确方法。

def _create_tray(self):
    self.tray_icon = QSystemTrayIcon(self)
    self.tray_icon.activated.connect(self.__icon_activated)

def __icon_activated(self, reason):
    if reason in (QSystemTrayIcon.Trigger, QSystemTrayIcon.DoubleClick):
        pass