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

时间:2018-01-03 02:00:39

标签: python pyqt pyqt4 pyqt5

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

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

代码不起作用。谁能帮助我纠正它,因此我可以基本了解Slot + Signal。

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_())

非常感谢!

1 个答案:

答案 0 :(得分:3)

您的代码有以下错误:

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

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

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

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)