PyQt4 Свернуть в лоток
Есть ли способ свести к минимуму до лотка в PyQt4? Я уже работал с классом QSystemTrayIcon, но теперь я хотел бы свернуть или "скрыть" окно приложения и показать только значок в трее.
Кто-нибудь это сделал? Любое направление будет оценено.
Использование Python 2.5.4 и PyQt4 на Window XP Pro
Ответы
Ответ 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