Qt qlistwidget自绘,隔行换色

2023-12-21 07:13:27

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

文章来源:https://blog.csdn.net/xcksj666/article/details/135105184
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。