首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Pyside6中的信号

Pyside6中的信号
EN

Stack Overflow用户
提问于 2021-04-23 14:25:18
回答 1查看 6.2K关注 0票数 5

我搞不懂为什么信号不起作用。在PyQt5中,这段代码起作用(区别在于它不是信号,而是pyqtSignal)。

当您单击按钮时,TextEdit应该显示“连接到设备”的消息,如果用pyqt替换pyside,代码将正常工作。

代码语言:javascript
复制
import sys
from PySide6.QtCore import *
from PySide6.QtWidgets import *


class Ui_MainWindow(object):
    def setupUi(self, MainWindow):
        if not MainWindow.objectName():
            MainWindow.setObjectName(u"MainWindow")
        MainWindow.resize(188, 267)
        self.centralwidget = QWidget(MainWindow)
        self.centralwidget.setObjectName(u"centralwidget")
        self.pushButton = QPushButton(self.centralwidget)
        self.pushButton.setObjectName(u"pushButton")
        self.pushButton.setGeometry(QRect(50, 140, 75, 24))
        self.textEdit = QTextEdit(self.centralwidget)
        self.textEdit.setObjectName(u"textEdit")
        self.textEdit.setGeometry(QRect(30, 40, 104, 71))
        MainWindow.setCentralWidget(self.centralwidget)
        self.retranslateUi(MainWindow)
        QMetaObject.connectSlotsByName(MainWindow)
    def retranslateUi(self, MainWindow):
        MainWindow.setWindowTitle(QCoreApplication.translate("MainWindow", u"MainWindow", None))
        self.pushButton.setText(QCoreApplication.translate("MainWindow", u"PushButton", None))

class MainWindow(QMainWindow):
    def __init__(self):
        QMainWindow.__init__(self, parent=None)
        self.dragPos = None
        self.ui = Ui_MainWindow()
        self.ui.setupUi(self)
        self.show()

def update_text(value, textEdit):
    textEdit.setText(textEdit.toPlainText() + value)
    textEdit.verticalScrollBar().setValue(textEdit.verticalScrollBar().maximum())
class account(QThread):
    textUpdate = Signal(str, QTextEdit)

    def __init__(self):
        super().__init__(parent=None)
        self.textUpdate.connect(update_text)

    def run(self):
        print("thread is work")
        self.textUpdate.emit("Connect to device\n", ui.textEdit)
        
if __name__ == "__main__":
    app = QApplication()
    acc_instance = account()
    main = MainWindow()
    ui = main.ui
    ui.pushButton.clicked.connect(acc_instance.start)
    sys.exit(app.exec_())

我知道覆盖run方法是不正确的。

P.S.S .增加了一个小例子

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2021-04-23 19:26:36

您的代码有几个问题:

  1. "ui“的范围是有限的,它不是一个全局变量,因此您不能在run方法中使用它。

  1. 只注册了一些数据类型(只能在C++中完成),这样就可以通过信号发送它们,而QTextEdit则不是这样。解决办法是查找注册为QTextEdit或对象的QObject的父类。

但是在这种情况下,我不认为需要发送QTextEdit,而只需要发送数据,然后修改GUI来设置它,因为这是它的任务。

代码语言:javascript
复制
class MainWindow(QMainWindow):
    def __init__(self, parent=None):
        QMainWindow.__init__(self, parent)
        self.ui = Ui_MainWindow()
        self.ui.setupUi(self)

    @Slot(str)
    def update_text(self, value):
        self.ui.textEdit.setText(self.ui.textEdit.toPlainText() + value)
        self.ui.textEdit.verticalScrollBar().setValue(
            self.ui.textEdit.verticalScrollBar().maximum()
        )


class Account(QThread):
    textUpdate = Signal(str)

    def run(self):
        print("thread is work")
        self.textUpdate.emit("Connect to device\n")


if __name__ == "__main__":
    app = QApplication()

    main = MainWindow()
    acc_instance = Account()

    acc_instance.textUpdate.connect(main.update_text)
    main.ui.pushButton.clicked.connect(acc_instance.start)

    main.show()

    sys.exit(app.exec_())

注意:在pyqt6中,您的初始代码也不能工作。

如果要向多个QTextEdit发送文本,最好创建一个键,将每种类型的文本关联到QTextEdit组:

代码语言:javascript
复制
from collections import defaultdict
from functools import cached_property


class MainWindow(QMainWindow):
    def __init__(self):
        QMainWindow.__init__(self, parent=None)
        self.dragPos = None
        self.ui = Ui_MainWindow()
        self.ui.setupUi(self)
        self.show()

        self.register("device_viewer", self.ui.textEdit)
        # self.register("another_key", another_textedit)

    def register(self, key, textedit):
        if not isinstance(textedit, QTextEdit):
            raise TypeError(f"{textedit} must be a QTextEdit")
        self.registry_viewers[key].append(textedit)

    @cached_property
    def registry_viewers(self):
        return defaultdict(list)

    @Slot(str, str)
    def update_text(self, key, value):
        for textedit in self.registry_viewers[key]:
            textedit.setText(textedit.toPlainText() + value)
            textedit.verticalScrollBar().setValue(
                textedit.verticalScrollBar().maximum()
            )


class Account(QThread):
    textUpdate = Signal(str, str)

    def run(self):
        print("thread is work")
        self.textUpdate.emit("device_viewer", "Connect to device\n")
        # self.textUpdate.emit("another_key", "message")


if __name__ == "__main__":
    app = QApplication()

    main = MainWindow()
    acc_instance = Account()

    acc_instance.textUpdate.connect(main.update_text)
    main.ui.pushButton.clicked.connect(acc_instance.start)

    sys.exit(app.exec_())
票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/67231753

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档