Reputation: 63599
The PyQt app has a QThread
running SenderWorker
, which continuously emits a signal temperatures
every second. A second QThread
running ReceiverWorker
is to receive this emitted signal and print it to screen.
Problem: However ReceiverWorker
is not responding to the emitted signal. Maybe connecting them together using the following line of code does not work?
self.receiverWorker.connectSlots(self.senderWorker)
Here's the entire code:
import sys
from PyQt4.QtGui import *
from PyQt4.QtCore import *
import time
class Screen(QMainWindow):
def __init__(self):
super(Screen, self).__init__()
self.initUI()
def initUI(self):
self.lightsBtn = QPushButton('Turn On')
self.lightsBtn.setCheckable(True)
self.lightsBtn.setStyleSheet("QPushButton:checked {color: white; background-color: green;}")
self.lightsBtn.clicked.connect(self.startLightsThread)
self.setCentralWidget(self.lightsBtn)
def startLightsThread(self):
print 'start lightsThread'
self.senderThread = QThread()
self.senderWorker = SenderWorker()
self.senderWorker.moveToThread(self.senderThread)
self.senderThread.started.connect(self.senderWorker.work)
self.senderThread.start()
self.receiverThread = QThread()
self.receiverWorker = ReceiverWorker()
self.receiverWorker.connectSlots(self.senderWorker)
self.receiverWorker.moveToThread(self.receiverThread)
self.receiverThread.start()
class SenderWorker(QObject):
temperatures = pyqtSignal(object)
def __init__(self):
QObject.__init__(self)
self._mutex = QMutex()
self._running = True
@pyqtSlot()
def work(self):
while self._running:
print 'Sender working'
self.temperatures.emit('123')
time.sleep(1)
class ReceiverWorker(QObject):
def __init__(self):
QObject.__init__(self)
self._mutex = QMutex()
self._running = True
def connectSlots(self, sender):
self.connect(sender, SIGNAL('temperatures'), self.work(temperatures))
def work(self, temperatures):
print 'Receiver working: ', temperatures
app = QApplication(sys.argv)
window = Screen()
window.show()
sys.exit(app.exec_())
import sys
from PyQt4.QtGui import *
from PyQt4.QtCore import *
import time
class Screen(QMainWindow):
def __init__(self):
super(Screen, self).__init__()
self.initUI()
def initUI(self):
self.lightsBtn = QPushButton('Turn On')
self.lightsBtn.setCheckable(True)
self.lightsBtn.setStyleSheet("QPushButton:checked {color: white; background-color: green;}")
self.lightsBtn.clicked.connect(self.startLightsThread)
self.setCentralWidget(self.lightsBtn)
def startLightsThread(self):
print 'start lightsThread'
self.senderThread = QThread()
self.senderWorker = SenderWorker()
self.senderWorker.moveToThread(self.senderThread)
self.senderThread.started.connect(self.senderWorker.work)
self.senderThread.start()
self.receiverThread = QThread()
self.receiverWorker = ReceiverWorker()
self.receiverWorker.connectSlots(self.senderWorker)
self.receiverWorker.moveToThread(self.receiverThread)
self.receiverThread.start()
class SenderWorker(QObject):
temperatures = pyqtSignal(object)
def __init__(self):
QObject.__init__(self)
self._mutex = QMutex()
self._running = True
@pyqtSlot()
def work(self):
while self._running:
print 'Sender working'
self.temperatures.emit('123')
time.sleep(1)
class ReceiverWorker(QObject):
def __init__(self):
QObject.__init__(self)
self._mutex = QMutex()
self._running = True
def connectSlots(self, sender):
sender.temperatures.connect(self.work)
def work(self, temperatures):
print 'Receiver working: ', temperatures
app = QApplication(sys.argv)
window = Screen()
window.show()
sys.exit(app.exec_())
Upvotes: 2
Views: 376
Reputation: 243897
The problem is in the connection, if you want to use the old style you must put the following syntax:
def connectSlots(self, sender):
self.connect(sender, SIGNAL('temperatures(PyQt_PyObject)'), self.work)
In the new style is much simpler( {sender}.{signal}.connect({slot})
):
def connectSlots(self, sender):
sender.temperatures.connect(self.work)
Upvotes: 1