Присвоение значений сигнала переменной - PullRequest
1 голос
/ 01 мая 2019

Я новичок в области сигналов и слотов в Python и в настоящее время проектирую графический интерфейс с Pyqt5. Пользователь требует выбрать из смеси qcombobox, где каждый элемент является qmenu. Я пытаюсь сохранить выбор пути, по которому идет пользователь, используя сигналы.

Изображение выбора GUI

Попытка:

Использование pathChanged в классе как:

pathChanged = QtCore.pyqtSignal(list)

и позже в init распечатать выбранный путь с помощью:

combo.pathChanged.connect(print)

Но это не сохранит значение моего пути к переменной, а просто отобразит его на консоли. Если я приравниваю вышеупомянутое к переменной, то я просто получаю ячейку памяти

Как сохранить выборки в списке, и список добавляется после каждого выбора пользователя?

Попытка реализовать идею из исходного кода: https://stackoverflow.com/a/52723148/6942881

И мой код:

from PyQt5 import QtCore, QtWidgets


data = {'Concept': {
            "Aircraft":{
                    "Blended Wing":[],
                    "Lifting Body":["Flat Bottom","Round Bottom","Wing"],
                    "Wing Body":["Fixed","Rotary","Swept"]},
            "Launch Vehicle":{
                    "SSTO":["Expendable","Reusable","Partially Reusable"],
                    "TSTO":["Expendable","Reusable","Partially Reusable"],
                    "MSTO":["Expendable","Reusable","Partially Reusable"]}
                    }
        }


class ComboBoxExpandable(QtWidgets.QPushButton):
    currentTextChanged = QtCore.pyqtSignal(str)
    pathChanged = QtCore.pyqtSignal(list)

    def setData(self, value):
        menu = QtWidgets.QMenu(self)
        self.setMenu(menu)
        self.append_element(value, menu)
        menu.triggered.connect(self.on_triggered)
    def printer(self,path):
        # print(path)
        return path

    @QtCore.pyqtSlot(QtWidgets.QAction)
    def on_triggered(self, action):
        self.setText(action.text())
        path = [action.text()] 
        w = action.parentWidget()
        while w.parentWidget() and isinstance(w.parentWidget(), QtWidgets.QMenu):
            path.insert(0, w.title())
            w = w.parentWidget()

        self.pathChanged.emit(path)
        self.currentTextChanged.emit(self.text())
        self.printer(path)


    @staticmethod
    def append_element(value, menu):
        if isinstance(value, list):
            for e in value:
                ComboBoxExpandable.append_element(e, menu)
        elif isinstance(value, dict):
            for k, v in value.items():
                if v==[]:
                    menu.addAction(k)
                else:
                    ComboBoxExpandable.append_element(v, menu.addMenu(k))
        else:
            menu.addAction(value)


class Widget(QtWidgets.QWidget):
    def __init__(self, parent=None):
        super(Widget, self).__init__(parent)

        combo = ComboBoxExpandable()
        combo.setData(data)
        result_label = QtWidgets.QLabel()
        combo.currentTextChanged.connect(result_label.setText)
        combo.pathChanged.connect(print)
        lay = QtWidgets.QFormLayout(self)
        lay.addRow("Select Concept: ", combo)
        lay.addRow("Concept Selected: ", result_label)

if __name__ == '__main__':
    import sys

    app = QtWidgets.QApplication(sys.argv)
    w = Widget()
    w.show()
    sys.exit(app.exec_())

1 Ответ

1 голос
/ 01 мая 2019

Решение состоит в том, чтобы создать слот, связанный с этим сигналом, в котором список, который транспортируется через сигнал, добавляется к члену класса:

class Widget(QtWidgets.QWidget):
    def __init__(self, parent=None):
        super(Widget, self).__init__(parent)

        self._paths = [] # <---container
        combo = ComboBoxExpandable()
        combo.setData(data)
        result_label = QtWidgets.QLabel()
        combo.currentTextChanged.connect(result_label.setText)
        combo.pathChanged.connect(self.on_pathChanged)
        lay = QtWidgets.QFormLayout(self)
        lay.addRow("Select Concept: ", combo)
        lay.addRow("Concept Selected: ", result_label)

    @QtCore.pyqtSlot(list)
    def on_pathChanged(self, path):
        self._paths.append(path) # append path
        print(self._paths)
...