2011-03-15 2 views
0

Когда следующий код запускается, приложение лотка может всплывать вокруг объекта AboutWindow QLabel в середине экрана. Но при закрытии этого экрана все приложение отключается без ошибок (значок в трее исчезает, и в журнале консоли нет никакой ошибки).PyQt4 Tray Icon Проблема при отображении QLabel

import sys 
from PyQt4 import QtGui, QtCore 


class AboutWindow(QtGui.QLabel): 

def __init__(self, parent=None): 
    QtGui.QLabel.__init__(self, parent=parent) 
    self.setText(""" 
    Huge text goes here 
    """) 


class SystemTrayIcon(QtGui.QSystemTrayIcon): 
    def __init__(self, icon, parent=None): 
     QtGui.QSystemTrayIcon.__init__(self, icon, parent) 
     menu = QtGui.QMenu(parent) 
     self.createMenuActions(menu) 
     self.setContextMenu(menu) 
     # I've tried using the same parent as QSystemTrayIcon, 
     # but the label is not shown. 
     # self.aboutWindow = AboutWindow(parent=parent) 
     self.aboutWindow = AboutWindow(parent=None) 


    def createMenuActions(self, menu): 
     exitAction = QtGui.QAction("Exit", menu) 
     configureAppAction = QtGui.QAction("Configure Application", menu) 
     aboutAction = QtGui.QAction("About", menu) 

     self.connect(configureAppAction, QtCore.SIGNAL('triggered()'), self._configureApp) 
     self.connect(aboutAction, QtCore.SIGNAL('triggered()'), self._showAbout) 
     self.connect(exitAction, QtCore.SIGNAL('triggered()'), self._exitApp) 

     self.addActionsToMenu(menu, configureAppAction, aboutAction, exitAction) 

    def addActionsToMenu(self, menu, *args): 
     for action in args: 
      menu.addAction(action) 

    def _configureApp(self): pass 

    def _showAbout(self): 
     self.aboutWindow.show() 

    def _exitApp(self): 
     sys.exit(0) 

def main(): 
    app = QtGui.QApplication(sys.argv) 
    widget = QtGui.QWidget() 
    # I'm passing a widget parent to QSystemTrayIcon as pointed out in: 
    # http://stackoverflow.com/questions/893984/pyqt-show-menu-in-a-system-tray-application 
    trayIcon = SystemTrayIcon(QtGui.QIcon("icon.xpm"), widget) 
    trayIcon.show() 
    sys.exit(app.exec_()) 

if __name__ == '__main__': 
    main() 

Как указано в коде, я попытался установить тот же родительский для трей и объекта AboutWindow, но это не сработало (метка не показана). Я также пытался подклассифицировать QMainWindow, но тот же эффект произошел.

Я хотел бы понять, если это поведение по умолчанию при открытии нового окна из QSystemTrayIcon, когда ни одно окно и значок не имеют одного и того же родителя, и если есть обходной путь для этого вопроса.

Спасибо.

ответ

0

Хорошо, я думаю, я не был слишком ясен в этой проблеме, но я нашел простое решение.

Qt имеет метод, который фиксирует событие закрытия, отправленное в виджет (http://doc.qt.nokia.com/4.6/qwidget.html#closeEvent). Вы можете в своем подклассе QWidget переписать этот метод, чтобы предотвратить закрытие виджета (который во всех моих тестах закрыл бы все приложение) и только скрыть его. Приведенный ниже код показывает, что я изменил в своем коде, чтобы заставить его работать:

... 

class AboutWindow(QtGui.QLabel): 

    def __init__(self, parent=None): 
     QtGui.QLabel.__init__(self, parent=parent) 
     self.setText(""" 
     Huge text goes here 
     """) 

    # Prevent the widget from closing the whole application, only hides it 
    def closeEvent(self, event): 
     event.ignore() 
     self.hide() 

... 
0

Эта проблема возникает потому, что при закрытии «только» окна, Qt ошибочно думает, что вы хотите, чтобы выйти из приложения. Ваш ответ (Kaos12) - уродливое исправление imho, иногда вы действительно хотите закрыть материал (это не то же самое, что скрывать его). Правильный способ сделать это, чтобы отключить это поведение, добавив строку:

app.setQuitOnLastWindowClosed(False) 

после строки 50 в этом коде (после того, как «создание» приложение). В этой инструкции Qt не будет закрывать приложение, даже если все окна будут закрыты.