自定义信号在PySide中不起作用

时间:2015-07-04 03:43:20

标签: python pyside

我是PySide的新手,我试图发出信号并从另一个班级接收信号。

我在MySignal类的对象上使用了emit,并且从MyRadioButton类发出了信号。发射和连接都返回True但是我想要的是,更新方法没有被调用

这是文件和代码的基本结构。

# MySignals.py
from PySide.QtCore import QObject, Signal

class MyCheckedSignal(QObject):
    signal = Signal(str)


# MyRadioButton.py
class MyRadioButton(QWidget, QObject):
    def __init__(self, value=None, label=None):
        QWidget.__init__(self)
        self.__value = value
        self.__checked = False
        self.checkSignal = MySignals.MyCheckedSignal()

    def toggleCheck(self):
        if self.__checked == False:
                self.__checked = True
                self.checkSignal.emit(SIGNAL(self.__value))
        else:
                self.__checked = False


# MyRadioGroup.py
class MyRadioGroup(QObject):
    def __init__(self, radioes=None):
        QObject.__init__(self)
        for radio in radioes:
            # radio is of type MyRadio
            # self.connect(radio, SIGNAL("checked()"), self.update)
            radio.checkSignal.signal.connect(self.update)
            # self.connect(self.update)

    def update(self, value):
        print("Checked", value)

1 个答案:

答案 0 :(得分:1)

前言:您选择的基类似乎很奇怪:您的MyRadioButton可能应该继承自QRadioButton而您的MyRadioGroup会从QGroupBox继承,这是一个合适的小部件,因此将与应用程序的其余部分很好地集成。请查看内部描述,了解布局的具体示例。

针对您的具体问题,并且不使用现有的QRadioButton,您无需为信号创建特殊类。只需声明您的MyRadioButton如下:

class MyRadioButton(QPushButton):
    checkSignal = QtCore.Signal(str)

    def __init__(self, value=None, label=None):
        QPushButton.__init__(self)
        self.__value = value
        self.__checked = False
        self.setCheckable(True)  # This will 'hold' the button once clicked
        self.clicked.connect(self.toggleCheck)  # Signal emitted on click

    def toggleCheck(self):
        if self.__checked == False:
                self.__checked = True
                self.checkSignal.emit(self.__value)
        else:
                self.__checked = False

请注意,要激活toggleCheck方法,您必须将QAbstractButtonclicked的信号连接到该方法。然后你的RadioGroup变得简单(如果你想以某种方式显示它,继承QWidget是一个好主意):

class MyRadioGroup(QWidget):
    def __init__(self, radioes=None):
        QWidget.__init__(self)
        self.radioes = radioes  # good idea to store a reference to it
        for radio in radioes:
            radio.checkSignal.connect(self.update)

    def update(self, value):
        print("Checked", value)

我将粘贴到整个文件下方供您测试。在我的设置(Python 2.7.8,PySide 1.2.2)上,这很好。

顺便说一句:我对你的路线感到困惑 self.checkSignal.emit(SIGNAL(self.__value))。这是SIGNAL的内容是什么?也许我错过了你的问题。

完整的示例文件:

import sys
from PySide import QtGui
from PySide import QtCore

class MyRadioButton(QtGui.QPushButton):
    checkSignal = QtCore.Signal(str)

    def __init__(self, text, value=None, label=None):
        QtGui.QPushButton.__init__(self, text)
        self.__value = value
        self.__checked = False
        self.setCheckable(True)
        self.clicked.connect(self.toggleCheck)

    def toggleCheck(self):
        if self.__checked == False:
                self.__checked = True
                self.checkSignal.emit(self.__value)
        else:
                self.__checked = False


class MyRadioGroup(QtGui.QWidget):
    def __init__(self, radios=None):
        QtGui.QWidget.__init__(self)
        self.radios = radios
        for radio in self.radios:
            radio.checkSignal.connect(self.update)

    def update(self, value):
        print("Checked", value)

app = QtGui.QApplication(sys.argv)

radio1 = MyRadioButton('Hello toto', value='toto')
radio2 = MyRadioButton('Hello titi', value='titi')
group = MyRadioGroup(radios=[radio1, radio2])

vbox = QtGui.QVBoxLayout()
vbox.addWidget(radio1)
vbox.addWidget(radio2)
vbox.addStretch(1)
group.setLayout(vbox)
group.resize(250, 150)
group.setWindowTitle('Signals')
group.show()

sys.exit(app.exec_())