0
点赞
收藏
分享

微信扫一扫

pyqt 信号槽函数传递失败


目录

​​背景​​

​​创建窗体​​

​​基于窗体创建自己的子类​​

​​运行程序​​

​​结果​​

​​分析​​

​​修改入口代码​​

​​修改自定义类基类​​

​​总结​​

背景

创建窗体

1) 选择 main window

pyqt 信号槽函数传递失败_子类

 2) 绘制控件,并为控件添加 事件及槽函数,示例

self.dev_class.currentRowChanged['int'].connect(self.test)
QtCore.QMetaObject.connectSlotsByName(MainWindow)

3)绘制其余控件后,将此文件转换成py文件,即mainwindow.py

基于窗体创建自己的子类

以进行功能定制和扩展,示例代码如下,将原先窗体绘制时的 事件槽函数改成我们自定义的。

class CfgWindow(QMainWindow, Ui_MainWindow):
def __init__(self, *args, **kwargs):
super(CfgWindow, self).__init__(*args, **kwargs)
self.setupUi(self)

self.dev_class.currentRowChanged['int'].connect(self.change_cfg_class)
self.show()
def change_cfg_class(self,index): (//自定义的槽函数)
print("index: %d" % index)
self.stackedWidget.setCurrentIndex(index)

运行程序

添加入口函数,创建窗体并运行。

if __name__ == '__main__':
app = QtWidgets.QApplication(sys.argv)
MainWindow = QtWidgets.QMainWindow()
ui = CfgWindow()

ui.setupUi(MainWindow)
MainWindow.show()
sys.exit(app.exec_())

结果

当我们运行时,通过改变list widget的选项来触发  currentRowChanged 事件,然而并没有调入我们的槽函数 change_cfg_class

分析

修改入口代码

我们将入口代码改为

if __name__ == '__main__':
# app = QtWidgets.QApplication(sys.argv)
app = QApplication(sys.argv)
# MainWindow = QtWidgets.QMainWindow()
ui = CfgWindow()

# ui.setupUi(MainWindow)
# MainWindow.show()
sys.exit(app.exec_())

即不采用Qtwidgets 对窗体进行管理,则可以正常响应事件进入槽函数。

修改自定义类基类

将自定义类的窗体基类由QMainWindow 修改为QtWidgets,运行时报错如下。

class CfgWindow(QtWidgets, Ui_MainWindow):

TypeError: metaclass conflict: the metaclass of a derived class must be a (non-strict) subclass of the metaclasses of all its bases

此时如果需要解决此报错,则需要修改Ui_MainWindow的基类,最终导致我们修改界面创建时的选择,修改为widgets

pyqt 信号槽函数传递失败_控件_02

总结

该问题,如果不创建子类,而是将槽函数直接放入到窗体子类中也不会发生问题。

 各种窗口对应不同的类,每个类应用自己的application进行管理,混搭后易出现莫名其妙的问题。

举报

相关推荐

0 条评论