项目场景:
想要在QListWidget中添加自定义控件,自定义控件包含3个QLabel,由QGridLayout管理布局
问题描述
setItemWidget之后发现显示空白,但是如果不调用setItemWidget,对item setText的话,可以正常显示,图1是设了自定义控件,图2是直接setText
原因分析:
打印了itemWidget内各个Label的位置,发现不对劲,尺寸过大
解决方案:
最开始尝试修改行高,但是QListWidget和QListWidgetItem没有所谓的setRowHeight之类的方法
单独显示自定义控件,发现正常布局,正常显示后,确定是setItemWidget这边没有设置导致的
又尝试了对自定义控件的布局修改:
grid_layout.setSpacing(0)
grid_layout.setContentsMargins(0, 0, 0, 0)
结果如下图:显示了一部分,可以确定需要设置行高
然后就是设置行高的部分了, QListWidget没有提供直接的设置方法,搜了一下,发现要用delegate,有点麻烦,去查了文档,找到QListWidgetItem 有可以修改的方式:
item.setData(Qt.ItemDataRole.SizeHintRole, QSize(100, 160))
到此为止,已经可以正常显示3个label了
2024/08补充:
可以通过设置item的SizeHintRole为控件sizeHint()返回值而无需慢慢调整大小
item.setData(Qt.ItemDataRole.SizeHintRole, widget.sizeHint())
另外提一下,setData这个方法其实还可以设置很多属性,比如DecorationRole,可以直接在Item文件前面嵌入1个图标,而不用setItemWidget然后再放图标控件,也不用delegate画图标