在ui文件中添加动态属性
如下图所示:在属性编辑器中点击”+”按钮, 添加的属性有很多类型,一般选择string或者ByteArray, 最好选择ByteArray,如果选择string还会涉及到需要翻译的问题.
data:image/s3,"s3://crabby-images/a1aa6/a1aa6f4c8506a75a1e324835d97742936e3b0971" alt=""
然后设置你的动态属性名称:
data:image/s3,"s3://crabby-images/7bd61/7bd618109083382ac496f1e8a29083c8a3ceb216" alt=""
在你的代码中访问ui中设置的动态属性
如何遍历ui对象中的所有按钮对象
如何在循环中给btn连接信号槽
1 2 3 4 5 6 7 8 9 10
| def initUI(self): self.ui = uic.loadUi(os.path.join( os.path.dirname(__file__), "res/ctrlpanel.ui"), self) self.setFixedSize(self.ctrlpanelWidth, self.ctrlpanelHeight) for attr in dir(self.ui): obj = getattr(self.ui, attr) if isinstance(obj, QtWidgets.QPushButton) or isinstance(obj, QtWidgets.QToolButton): obj.clicked.connect(functools.partial(self.on_clicked, obj))
|
代码中访问ui设置的动态属性
一般思维定势使用’.’来访问对象的属性,但是ui中的动态属性无法通过’.’访问,
而是使用property()
函数来访问动态属性.如btn.property("btn_cmd")
如果你想在按钮上添加图片,并且让文字显示在图标下面,那么请使用QToolButton,
不要使用QPushButton, QPushButton添加图标后,其文字是默认显示在图标右边,而不是下面.
1 2 3 4
| button = QToolButton() button.setToolButtonStyle(QtCore.Qt.ToolButtonTextUnderIcon) button.setIcon(myIcon) button.setText("Sample text")
|