目录
背景
创建窗体
基于窗体创建自己的子类
运行程序
结果
分析
修改入口代码
修改自定义类基类
总结
1) 选择 main window
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
该问题,如果不创建子类,而是将槽函数直接放入到窗体子类中也不会发生问题。
各种窗口对应不同的类,每个类应用自己的application进行管理,混搭后易出现莫名其妙的问题。