我使用QTableView
来显示只读数据。该模型基于QList
包含另一个QList
的自定义类型。像这样:
typedef struct
{
int range;
QString description;
} Field;
typedef struct
{
QString name;
QList<Field> fields;
} Item;
QList<Item> items;
在我的QAbstractTableModel
实现中,我有一个选择当前item
的插槽:
void setCurrentItem(int idx)
{
// checks for errors (omissis)
currentItemIdx = idx;
// ask to redraw the table
emit dataChanged(this->index(0, 0), this->index(rowCount(), columnCount()));
}
所有模型的逻辑都依赖于该项目,例如:
int MyModel::rowCount(const QModelIndex&) const {
return items.at(m_currentItemIdx).fields.count();
}
QVariant MyModel::data(const QModelIndex &index, int role) const {
if (!index.isValid()) return QVariant();
if (index.row() >= items.at(m_currentItemIdx).fields.count()) return QVariant();
Field f = items.at(m_currentItemIdx).fields.at(index.row);
switch (role) {
case Qt::DisplayRole:
switch (index.column()){
case 0:
return f.range;
break;
case 1:
return f.description;
break;
default:
return QVariant();
}
break;
}
return QVariant();
}
问题是当我使用setCurrentItem()
更改当前项时,代码使用新数据,但QTableView
不更改其行,然后不请求新内容。
我认为emit dataChanged()
是真的,但似乎没有。
我应该怎么做才能通知我改变了模型大小的观点?
我正在尝试避免插入/删除行机制,因为我不想更改QList
中的实际数据,我只想获取一组不同的信息。
答案 0 :(得分:4)
更改模型数据之前,请先调用QAbstractItemModel::beginResetModel()
和QAbstractItemModel::endResetModel()
。
像这样:
void setCurrentItem(int idx)
{
beginResetModel();
currentItemIdx = idx;
endResetModel();
}