QT开发中文网

QListView里面的元素是qwidget给出完整代码

当QListView的元素是QWidget时,您可以使用自定义委托来实现。以下是一个完整的示例代码:

#include <QApplication>
#include <QListView>
#include <QWidget>
#include <QVBoxLayout>

class CustomWidget : public QWidget {
public:
    explicit CustomWidget(const QString& text, QWidget* parent = nullptr) : QWidget(parent) {
        QVBoxLayout* layout = new QVBoxLayout(this);
        QLabel* label = new QLabel(text, this);
        layout->addWidget(label);
    }
};

class WidgetDelegate : public QStyledItemDelegate {
public:
    void paint(QPainter* painter, const QStyleOptionViewItem& option, const QModelIndex& index) const override {
        QStyleOptionViewItem opt = option;
        initStyleOption(&opt, index);

        // 绘制背景和边框
        painter->save();
        painter->setRenderHint(QPainter::Antialiasing);
        painter->fillRect(opt.rect, opt.state & QStyle::State_Selected ? QColor("#E8F2FE") : QColor(Qt::white));
        painter->drawRoundedRect(opt.rect.adjusted(1, 1, -1, -1), 5, 5);
        painter->restore();

        // 绘制文本
        QRect textRect = opt.rect.adjusted(10, 0, -10, 0);
        painter->save();
        painter->setPen(opt.palette.color(QPalette::Text));
        painter->drawText(textRect, Qt::AlignLeft | Qt::AlignVCenter,
                          opt.fontMetrics.elidedText(index.data().toString(), Qt::ElideRight, textRect.width()));
        painter->restore();
    }

    QSize sizeHint(const QStyleOptionViewItem& option, const QModelIndex& index) const override {
         return QSize(100, 30); // 自定义元素的大小
    }

    QWidget* createEditor(QWidget* parent, const QStyleOptionViewItem& option, const QModelIndex& index) const override {
        Q_UNUSED(option);
        CustomWidget* editor = new CustomWidget(index.data().toString(), parent);
        return editor;
    }

    void setEditorData(QWidget* editor, const QModelIndex& index) const override {
        if (CustomWidget* customWidget = qobject_cast<CustomWidget*>(editor)) {
            customWidget->setText(index.data().toString());
        }
    }

    void setModelData(QWidget* editor, QAbstractItemModel* model, const QModelIndex& index) const override {
        if (CustomWidget* customWidget = qobject_cast<CustomWidget*>(editor)) {
            model->setData(index, customWidget->text());
        }
    }
};

int main(int argc, char** argv) {
    QApplication app(argc, argv);

    QStringList data;
    data << "Item 1" << "Item 2" << "Item 3";

    QListView listView;
    
    // 使用自定义委托
    WidgetDelegate delegate;
    
    listView.setItemDelegate(&delegate);
    
	// 创建一个模型并设置数据
	QStandardItemModel model;
	for (const QString& item : data) {
		QStandardItem* itemObj = new QStandardItem(item);
		model.appendRow(itemObj);
	}

	listView.setModel(&model);

	listView.show();

	return app.exec();
}

在上述代码中,我们创建了一个QListView,并使用自定义委托(WidgetDelegate)来实现将QWidget作为元素进行显示和编辑。我们自定义了QWidget部件(CustomWidget),并通过重写paint()函数来绘制背景和边框以及文本。在createEditor()函数中创建了CustomWidget的实例,并在setEditorData()和setModelData()函数中进行数据的设置和获取。

这样,您就可以在QListView中显示并编辑包含QWidget部件的元素了。

希望对您有所帮助!如有其他问题,请随时提问。


内容由零声教学AI助手提供,问题来源于学员提问

本站部分文章来源于网络,版权归原作者所有,如有侵权请联系站长删除。
转载请注明出处:http://qt.0voice.com/?id=11342

分享:
扫描分享到社交APP
上一篇
下一篇
发表列表
游客 游客
此处应有掌声~
评论列表

还没有评论,快来说点什么吧~

联系我们

在线咨询: 点击这里给我发消息

微信号:3007537140

上班时间: 10:30-22:30

关注我们
x

注册

已经有帐号?