Подтвердить что ты не робот

PyQt4 Свернуть в лоток

Есть ли способ свести к минимуму до лотка в PyQt4? Я уже работал с классом QSystemTrayIcon, но теперь я хотел бы свернуть или "скрыть" окно приложения и показать только значок в трее.

Кто-нибудь это сделал? Любое направление будет оценено.

Использование Python 2.5.4 и PyQt4 на Window XP Pro

4b9b3361

Ответ 1

Это довольно просто, как только вы помните, что нет возможности фактически свести к системный лоток.

Вместо этого вы подделываете это, делая это:

  • Поймать событие минимизации в вашем окне
  • В обработчике событий минимизации создайте и покажите QSystemTrayIcon
  • Также в обработчике событий минимизации вызовите hide() или setVisible (false) в окне
  • Поймайте щелчок/двойной щелчок/пункт меню на значке в панели задач
  • В обработчике событий значка в системном трее вызовите show() или setVisible (true) в вашем окне и, возможно, скройте значок своего лотка.

Ответ 2

Код помогает, поэтому здесь что-то я написал для приложения, за исключением closeEvent вместо события минимизации.

Примечания:

"closeEvent (event)" - это переопределенное событие Qt, поэтому оно должно быть помещено в класс, который реализует окно, которое вы хотите скрыть.

"okayToClose()" - это функция, которую вы можете рассмотреть при реализации (или логический флаг, который вы хотите сохранить), поскольку иногда вы действительно хотите выйти из приложения, а не сводить к минимуму до systray.

Также есть пример того, как показать() ваше окно снова.

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()

Ответ 3

Просто добавьте к примеру Криса:

Важно, чтобы вы использовали нотацию Qt при объявлении сигнала, т.е.

правильно:

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

а не PyQt one

неверно и не будет работать:

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

Обратите внимание на :: в сигнальной строке. Мне потребовалось около трех часов, чтобы понять.

Ответ 4

Здесь рабочий код... Спасибо Matze для Crucial, СИГНАЛ взял у меня больше времени на любопытство, но делал другие вещи. поэтому ta для #! момент: -)

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

Ответ 5

Это было отредактировано ответом 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()

Ответ 6

Это код, и он помогает мне верить, покажите мне код

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()

Ответ 7

Это правильный способ обработки двойного щелчка на значке в трее для 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