[pyqt] 使用自定义QListWidgetItem

一、背景

略。

二、思路

新建自定义类customQListWidgetItem,该类继承自QListWidgetItem。

新建窗口w(QWidget类)。

新建列表listWidget(QListWidget类)。

新建两个customQListWidgetItem实例,并将这连个实例加入到listWidget中。

三、代码

import sys
from PyQt5.Qt import *;
from PyQt5.QtCore import *;
from PyQt5.QtWidgets import *;

# 自定义的item 继承自QListWidgetItem
class customQListWidgetItem(QListWidgetItem):
    def __init__(self, name, img):
        super().__init__()
        # 自定义item中的widget 用来显示自定义的内容
        self.widget = QWidget()
        # 用来显示name
        self.nameLabel = QLabel()
        self.nameLabel.setText(name)
        # 用来显示avator(图像)
        self.avatorLabel = QLabel()
        # 设置图像源 和 图像大小
        self.avatorLabel.setPixmap(QPixmap(img).scaled(50, 50))
        # 设置布局用来对nameLabel和avatorLabel进行布局
        self.hbox = QHBoxLayout()
        self.hbox.addWidget(self.avatorLabel)
        self.hbox.addWidget(self.nameLabel)
        self.hbox.addStretch(1)
        # 设置widget的布局
        self.widget.setLayout(self.hbox)
        # 设置自定义的QListWidgetItem的sizeHint,不然无法显示
        self.setSizeHint(self.widget.sizeHint())
 
if __name__ == "__main__":
    app = QApplication(sys.argv)

    # 主窗口
    w = QWidget()
    w.setWindowTitle("QListWindow")
    # 新建QListWidget
    listWidget = QListWidget(w)
    listWidget.resize(300, 300)

    # 新建两个自定义的QListWidgetItem(customQListWidgetItem)
    item1 = customQListWidgetItem("鲤鱼王", "liyuwang.jpg")
    item2 = customQListWidgetItem("可达鸭", "kedaya.jpg")

    # 在listWidget中加入两个自定义的item
    listWidget.addItem(item1)
    listWidget.setItemWidget(item1, item1.widget)
    listWidget.addItem(item2)
    listWidget.setItemWidget(item2, item2.widget)

    # 绑定点击槽函数 点击显示对应item中的name
    listWidget.itemClicked.connect(lambda item: print(item.nameLabel.text()))

    w.show()
    sys.exit(app.exec_())

四、最终效果

可以看到我自定义的item只包含两部分,图像和文字。点击选项会显示对应的名字。

五、注意的问题

1、QListWidget.itemClicked.connect()绑定槽函数时会传递一个QListWidgetItem参数。

2、在自定义的item(customQListWidgetItem类)中需要.setSizeHint()为self.widget.sizeHint()不然会无法显示。

3、使用QLabel.setPixmap(QPixmap(img).scaled(width, height))来设置QLabel中显示的图片源和图片大小

posted on 2019-12-28 22:32  刘好念  阅读(66)  评论(0编辑  收藏  举报  来源