在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,这样就可以实现自定义绘制