我有一个内部结构类似于Simple Tree Model Example的树模型。有一个特殊的数组类型项,我要为其显示索引。我的数据方法如下:
QVariant Model::data(const QModelIndex & index, int role ) const
{
if (!index.isValid())
return QVariant();
TreeNode *item = getItem(index);
if (role == Qt::DisplayRole) {
return item->text();
}
...
return QVariant();
}
const QString TreeNode::text() const
{
if (array) {
return name() + " [" + QString::number(childNumber()) + "]";
}
return mText;
}
我有一个执行节点删除的单元测试,该测试使用Model Test。问题出在测试的最后一行
void ModelTest::rowsRemoved ( const QModelIndex & parent, int start, int end )
{
Changing c = remove.pop();
QVERIFY( c.parent == parent );
QVERIFY( c.oldSize - ( end - start + 1 ) == model->rowCount ( parent ) );
QVERIFY( c.last == model->data ( model->index ( start - 1, 0, c.parent ) ) );
QVERIFY( c.next == model->data ( model->index ( start, 0, c.parent ) ) );
}
比较删除前的值和删除后的值。就我而言,由于我还显示索引,因此它们不匹配。例如,我在模型中有Item1
和Item2
。如果Item1
被删除,则Item2
变成Item1
并且测试失败。
我的问题是我的模型实现有问题吗?我应该以不同的方式处理这种情况吗?
答案 0 :(得分:1)
不能仅以静默方式更改QAbstractItemModel中的数据。对于数据已更改的索引,应始终发出dataChanged信号。
如果您这样做:
" [" + QString::number(childNumber()) + "]"
然后,每次childNumber()更改时,您都需要发出dataChanged信号。因此,如果仅通过QAbstractItemModel :: setData可以更改索引数据,将会容易得多。