在Qt中,你可以使用自定义绘制来改变QListWidget中项的外观。通过继承QStyledItemDelegate类并重写其paint()方法来实现自定义绘制,简单的示例,演示如何自绘QListWidget中的项:
```cpp
#include <QApplication>
#include <QListWidget>
#include <QStyledItemDelegate>
#include <QPainter>
class CustomItemDelegate : public QStyledItemDelegate
{
public:
? ? void paint(QPainter *painter, const QStyleOptionViewItem &option, const QModelIndex &index) override
? ? {
? ? ? ? // 调用基类的绘制方法以保留默认的绘制行为 ? ? ? ?QStyledItemDelegate::paint(painter, option, index);
? ? ? ? // 自定义绘制代码
? ? ? ? if (index.row() % 2 == 0) {
? ? ? ? ? ? // 绘制偶数行的项为红色背景 ? ? ? ? ? ?painter->fillRect(option.rect, Qt::red);
? ? ? ? } else {
? ? ? ? ? ? // 绘制奇数行的项为绿色背景
? ? ? ? ? ? painter->fillRect(option.rect, Qt::green);
? ? ? ? }
? ? }
};
int main(int argc, char *argv[])
{
? ? QApplication app(argc, argv);
? ? QListWidget listWidget;
? ? listWidget.setViewMode(QListWidget::IconMode);
? ? listWidget.setIconSize(QSize(100, 100));
? ? listWidget.addItem("Item 1");
? ? listWidget.addItem("Item 2");
? ? listWidget.addItem("Item 3");
? ? CustomItemDelegate itemDelegate;
? ? listWidget.setItemDelegate(&itemDelegate);
? ? listWidget.show();
? ? return app.exec();
}
```
在这个示例中,我们创建了一个自定义的QStyledItemDelegate子类CustomItemDelegate,并重写了其paint()方法。在paint()方法中,我们首先调用基类的绘制方法以保留默认的绘制行为,然后根据项的索引来判断是否为偶数行,从而设置不同的背景颜色。
最后,我们将自定义的ItemDelegate设置给QListWidget,这样就可以实现自定义绘制