PyQt5: как запустить окно из контекстного меню значка на панели задач?

У меня есть два отдельных файла, один из которых создает значок в системном трее и контекстное меню, а другой - окно для ввода данных пользователем.

traywindow.py содержит это:

import sys
import os
from PyQt5 import QtCore, QtWidgets
from PyQt5.QtWidgets import QMainWindow, QWidget, QLabel, QLineEdit
from PyQt5.QtWidgets import QPushButton
from PyQt5.QtCore import QSize    

class MainWindow(QMainWindow):
    def __init__(self):
        QMainWindow.__init__(self)

        self.setMinimumSize(QSize(320, 172))    
        self.setWindowTitle("Set Account") 

        # Setup username field
        self.username_label = QLabel(self)
        self.username_label.setText('Username')
        self.username_field = QLineEdit(self)
        self.username_label.move(45, 20)
        self.username_field.move(115, 23)
        self.username_field.resize(150, 25)

        # Setup OK button
        pybutton = QPushButton('OK', self)
        pybutton.clicked.connect(self.buttonClicked)
        pybutton.resize(100,32)
        pybutton.move(110, 128)        

    def buttonClicked(self):
        print('Username: ' + self.username_field.text())

def displayWindow():
    app = QtWidgets.QApplication(sys.argv)
    preferences_window = MainWindow()
    preferences_window.show()
    sys.exit(app.exec_())

if __name__ == "__main__":
    displayWindow()

Который производит:

введите описание изображения здесь

trayapp.py содержит это:

import os
import sys
import traywindow
from PyQt5 import QtWidgets, QtCore, QtGui

class SystemTrayIcon(QtWidgets.QSystemTrayIcon):

    def __init__(self, icon, parent=None):
        QtWidgets.QSystemTrayIcon.__init__(self, icon, parent)

        menu = QtWidgets.QMenu(parent)
        prefs_action = menu.addAction('Preferences...')
        self.setContextMenu(menu)
        prefs_action.triggered.connect(self.setPrefs)

    def setPrefs(self):
        traywindow.displayWindow()

def main(image):
    app = QtWidgets.QApplication(sys.argv)
    w = QtWidgets.QWidget()
    trayIcon = SystemTrayIcon(QtGui.QIcon(image), w)
    trayIcon.show()
    sys.exit(app.exec_())

if __name__ == '__main__':
    icon = 'icon.png'
    main(icon)

Который производит:

Окно

Я хочу запустить окно из моего контекстного меню, поэтому, когда я нажимаю на Preferences... это откроет Set Account окно, и когда я заполняю поле и нажимаю на OK, запишите это в переменные / передайте их в качестве аргументов в trayapp.py файл. В настоящее время моя попытка в приведенном выше коде дает мне это, когда я нажимаю на Preferences...:

Traceback (most recent call last):
  File "/Users/Username/Downloads/trayapp.py", line 17, in setPrefs
    traywindow.displayWindow()
  File "/Users/Username/Downloads/traywindow.py", line 36, in displayWindow
    sys.exit(app.exec_())
SystemExit: -1
[Finished in 3.0s with exit code -6]

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

1 ответ

Решение

Вы можете иметь только одно QApplication, и в displayWindow вы создаете второе QApplication, вместо этого создайте MainWindow и не вызывайте displayWindow.

def setPrefs(self):
    self.window = traywindow.MainWindow()
    self.window.show()
Другие вопросы по тегам