修改Qt模型/视图中的数据表示

时间:2016-02-28 08:00:26

标签: qt cell qtableview qsqltablemodel

我正在使用Qt 5.4.2并且我在尝试找出如何在从模型填充视图时更改数据“表示”时遇到了麻烦。我有一个QSqlTableModel来保存数据库数据和一个显示数据库内容的QTableView。

现在,数据库中的某些数据格式与我希望在View中显示的格式不同。例如,我想以不同的方式显示日期格式,但我不知道在何处/如何实现这样的逻辑。我不希望模型以任何方式受到影响,只有视图中显示的数据。

1 个答案:

答案 0 :(得分:0)

您应该为特定列实现自定义委托并手动设置它。只需实现一个派生自QStyledItemDelegate的类,如:

#include <QItemDelegate>
#include <QDateTimeEdit>

class DateTimeEditDelegate: public QStyledItemDelegate
{
 Q_OBJECT
public:
    DateTimeEditDelegate(QObject *parent = 0);

    void *paint( QPainter *painter,
                            const QStyleOptionViewItem &option,
                            const QModelIndex &index ) const;

    QWidget *createEditor( QWidget *parent,
                            const QStyleOptionViewItem &option,
                            const QModelIndex &index ) const;

    void setEditorData( QWidget *editor,
                            const QModelIndex &index ) const;

    void setModelData( QWidget *editor,
                            QAbstractItemModel *model,
                            const QModelIndex &index ) const;

    void updateEditorGeometry( QWidget *editor,
                            const QStyleOptionViewItem &option,
                            const QModelIndex &index ) const;

    mutable QDateTimeEdit *dataTimeEdit;

private slots:

    void setData(QDateTime val);

};



DateTimeEditDelegate::DateTimeEditDelegate(QObject *parent ):QStyledItemDelegate(parent)
{

}

void*DateTimeEditDelegate::paint(QPainter *painter, const QStyleOptionViewItem &option, const QModelIndex &index) const
{
    QDateTime dateTime = index.model()->data( index, Qt::DisplayRole ).toDateTime();
    painter->drawText(option.rect().topLeft(), dateTime.toString());
    return;
}

QWidget *DateTimeEditDelegate::createEditor(QWidget *parent, const QStyleOptionViewItem &option, const QModelIndex &index) const
{
    dataTimeEdit = new QDateTimeEdit( parent );
    QObject::connect(dataTimeEdit,SIGNAL(dateTimeChanged(QDateTime)),this,SLOT(setData(QDateTime)));
    return dataTimeEdit;
}

void DateTimeEditDelegate::setEditorData(QWidget *editor, const QModelIndex &index) const
{
    QVariant dateTime = index.model()->data( index, Qt::DisplayRole );

    (static_cast<QDateTimeEdit*>( editor ))->setDateTime(dateTime.toDateTime());
}

void DateTimeEditDelegate::setModelData(QWidget *editor, QAbstractItemModel *model, const QModelIndex &index) const
{
    model->setData( index, static_cast<QDateTimeEdit*>( editor )->dateTime() );
}


void DateTimeEditDelegate::updateEditorGeometry(QWidget *editor, const QStyleOptionViewItem &option, const QModelIndex &index) const
{
    editor->setGeometry( option.rect );
}

void DateTimeEditDelegate::setData(QDateTime val)
{
    emit commitData(dataTimeEdit);
}

最后将委托的实例设置为一列:

ui->tableView->setItemDelegateForColumn(0, new DateTimeEditDelegate(ui->tableView));

它只是代表的一个示例,它在自定义数据编辑中实现自定义数据表示。你应该根据自己的需要实现自己。