如何在不同的类中使用 Slot+Signal?

Rt *_*Rtt 3 python pyqt pyqt4 pyqt5

我必须说这是一个非常初学者的问题。我已经阅读并尝试了很多,但仍然不明白如何Slot+Signal工作。

在我下面的代码中,当单击按钮时,我想将三个变量从 MyApp 类传输到 Worker 类中。

该代码不起作用。

from PyQt5.QtWidgets import *
from PyQt5.QtGui import *
from PyQt5.QtCore import *
import sys


class Worker(QObject):
    def __init__(self, parent=None):
        super(Worker, self).__init__(parent)

    @pyqtSlot(str, str, int)
    def onJob(self, strA, strB, int1):
        print(strA, strB, int1)
        for i in range(40):
            print(i)


class MyApp(QWidget):
    def __init__(self, parent= None):
        super(MyApp, self).__init__(parent)
        self.initUI()

    def initUI(self):
        self.btn = QPushButton("start", self)
        self.btn.clicked.connect(self.start)
        self.show()

    def start(self):
        otherClass = Worker()
        self.signal = pyqtSignal(str, str, int)
        self.signal.emit("foo", "baz", 10)
        self.signal.connect(otherClass.onJob)

if __name__ == '__main__':
    app = QApplication(sys.argv)
    window = MyApp()
    window.show()
    sys.exit(app.exec_())
Run Code Online (Sandbox Code Playgroud)

eyl*_*esc 6

您的代码有以下错误:

  • 信号不得在类的任何方法中声明,它必须与方法处于同一级别。

  • 如果我在将信号连接到任何插槽之前发送信号,那么没有人会听到信息,因此数据将丢失,也就是说,数据的传输几乎是瞬时的。

在以下代码中,我实施了必要的修改以使其工作:

class MyApp(QWidget):
    signal = pyqtSignal(str, str, int)
    def __init__(self, parent= None):
        super(MyApp, self).__init__(parent)
        self.initUI()

    def initUI(self):
        self.btn = QPushButton("start", self)
        self.btn.clicked.connect(self.start)
        self.show()

    def start(self):
        otherClass = Worker()
        self.signal.connect(otherClass.onJob)
        self.signal.emit("foo", "baz", 10)
Run Code Online (Sandbox Code Playgroud)