我想在 QTableView 中设置一个可编辑的列,到目前为止,我尝试继承 QTableView 并重新实现Qt::ItemFlags flags(const QModelIndex & index) const
,继承 QSqlQueryModel 并重新实现Qt::ItemFlags flags(const QModelIndex & index) const
,最后,继承 QAbstractItemView ,但这会导致编译错误。
对QTableView进行子类化:
#include "exqtableview.h"
ExQTableView::ExQTableView(QWidget *parent) :
QTableView(parent)
{
}
Qt::ItemFlags ExQTableView::flags(const QModelIndex & index) const
{
if (!index.isValid())
return Qt::ItemIsEnabled;
if (index.column() == 2)
return index.parent().flags() & ~Qt::ItemIsEditable;
}
子类化QSqlQueryModel
#include "exsqlquerymodel.h"
ExSqlQueryModel::ExSqlQueryModel(QObject *parent) :
QSqlQueryModel(parent)
{
}
Qt::ItemFlags ExSqlQueryModel::flags( const QModelIndex &index) const
{
Qt::ItemFlags flags = QSqlQueryModel::flags(index);
if (index.column() == 2 )
flags &= ~Qt::ItemIsEditable;
return flags;
}
子类化QAbstractItemView
#include "exitemdelegate.h"
#include <QTableWidgetItem>
ExItemDelegate::ExItemDelegate(QObject *parent) :
QItemDelegate(parent)
{
}
QWidget *ExItemDelegate::createEditor(QWidget *parent,
const QStyleOptionViewItem & ,
const QModelIndex & index ) const
{
QTableWidgetItem *item = new QTableWidgetItem;
return item;
}
void ExItemDelegate::setEditorData(QWidget *editor,
const QModelIndex &index) const
{
float value = index.model()->data(index, Qt::EditRole).toFloat();
QTableWidgetItem *cell = static_cast<QTableWidgetItem*>(editor);
cell->setData(0, value);
}
void ExItemDelegate::setModelData(QWidget *editor, QAbstractItemModel *model,
const QModelIndex &index) const
{
QTableWidgetItem *cell = static_cast<QTableWidgetItem*>(editor);
float value = cell->data(Qt::DisplayRole);
model->setData(index, value, Qt::EditRole);
}
void ExItemDelegate::updateEditorGeometry(QWidget *editor,
const QStyleOptionViewItem &option, const QModelIndex &) const
{
editor->setGeometry(option.rect);
}
为什么所有这些方法都无法实现我的目标?
答案 0 :(得分:3)
要使一列可编辑,您应该添加可编辑标志,而不是将其删除:
flags |= Qt::ItemIsEditable;
flags()
函数属于模型类,而不属于视图,并且您还有一个完整的Qt example,其中显示了如何使QSqlQueryModel
可编辑