Я работаю в приложении Python, используя PySide на Raspberry Pi, с ОС Raspbian Jessie.
Я новичок в Python и совсем не эксперт. Так что, наверное, это вопрос начинающего.
В моем приложении у меня есть:
В некоторых местах кода нижележащего потока мне нужно испустить сигнал, который должен быть уловлен основным потоком. В предыдущей версии я делал так:
#Slot for clicked button
def Slot_Start_Calculation (self):
self.MyLongThread = QThread()
MyLongWorker = MyWorker(self, Qty)
MyLongWorker.moveToThread(self.MyLongThread)
self.MyLongThread.started.connect(MyLongWorker.Run_LongWorker)
MyLongWorker.WorkerFinished.connect(self.MyLongThread.quit)
MyLongWorker.WorkerFinished.connect(self.MyLongWorker.deleteLater)
MyLongThread.finished.connect(self.MyLongThread.deleteLater)
MyLongThread.start()
def Slot_Worker_Sent_A_Signal (self, Result):
print ("Worker sent this result: " + str(Result))
.
.
.
class MyWorker(QObject):
WorkerFinished = Signal()
CustomSignal = Signal(int)
def __init__(self, parent, Quantity)
super().__init__(parent)
self_parent = parent
self.Quantity = Quantity
print("Myworker's constructor")
def __del__(self):
print("Myworker's destructor")
def Run_LongWorker (self):
self.CustomSignal.connect(self.parent.Slot_Worker_Sent_A_Signal)
.
.
.
self.CustomSignal.emit(MyPartialResult)
.
.
.
self.WorkerFinished.emit()
Этот код запущен в тестовой среде несколько недель назад, пока я заканчиваю некоторые детали графического интерфейса, и я не заметил ничего плохого. Вчера, ища в сети, я случайно заметил, что QObject :: moveToThread не может перемещать объекты с родителем.
https: [// forum.qt.io/topic/40653/qobject-movetothread-cannot-move-objects-with-a-parent sizes[1]
поэтому я боюсь, что в моем коде могут быть проблемы, которые я еще не обнаружил.
Я изменил эту часть кода, и теперь она:
#New slot for clicked button.
def Slot_Start_Calculation (self):
MyLongThread = QThread()
MyLongWorker = MyWorker(Qty)
MyLongWorker.moveToThread(MyLongThread)
MyLongThread.started.connect(MyLongWorker.Run_LongWorker)
MyLongWorker.WorkerFinished.connect(MyLongThread.quit)
MyLongWorker.WorkerFinished.connect(MyLongWorker.deleteLater)
MyLongThread.finished.connect(MyLongThread.deleteLater)
MyLongThread.start()
def Slot_Worker_Sent_A_Signal (self, Result):
print ("Worker sent this result: " + str(Result))
.
.
.
class MyWorker(QObject):
WorkerFinished = Signal()
CustomSignal = Signal(int)
def __init__(self, Quantity)
super().__init__()
self.Quantity = Quantity
print("Myworker's constructor")
def __del__(self):
print("Myworker's destructor")
def Run_LongWorker (self):
self.CustomSignal.connect( ??? .Slot_Worker_Sends_A_Signal)
.
.
.
self.CustomSignal.emit(MyPartialResult)
.
.
.
self.WorkerFinished.emit()
Итак, теперь я действительно не знаю, как подключить этот сигнал к слоту, который находится в основном потоке, потому что, если я не ошибаюсь, нет отношения родитель / потомок, так как я изменил сходство потока.
Может ли кто-нибудь сказать мне, есть ли способ сделать это, и направить меня к документации по этой проблеме?
Спасибо заранее.






Наконец, думаю, я нашел ответ. В конструкторе класса Worker мне пришлось изменить ссылку на родительский объект и вызов init суперкласса.
class MyWorker(QObject):
WorkerFinished = Signal()
CustomSignal = Signal(int)
def __init__(self, parent = None, Quantity)
super().__init__()
self.Quantity = Quantity
print("Myworker's constructor")
def __del__(self):
print("Myworker's destructor")
def Run_LongWorker (self):
.
.
.
self.CustomSignal.emit(MyPartialResult)
.
.
.
self.WorkerFinished.emit()
И теперь все работает как положено.
Если кто-то обнаружит проблему с этим кодом, пожалуйста, сообщите мне.
Спасибо!