如何在没有持久索引损坏/重复的情况下使用beginMoveRows进行排序

How to sort with beginMoveRows without persistent index corruption / duplication?

本文关键字:情况下 beginMoveRows 排序 损坏 索引      更新时间:2023-10-16

我试图使用beginMoveRows/endMoveRows来保持持久索引,但有时扩展的状态标志/持久索引会重复,而它们不应该重复。

有相当多的代码,所以我会仔细检查我认为我已经告诉机器做的事情:

有一种方法,sortChildrenOf(item),它可以发挥所有的魔力。

  • 从项目中查找子项并调用sortChildrenOf,每个子项作为参数
  • 保存旧订单
  • quickSort子项
  • 发现新旧秩序的差异
  • 对于每个差异:
  • 正在移动行
  • 应用更改
  • endMoveRows

当有两个级别时,一切都很完美,但当我输入一个"长"数据树时,持久索引就会损坏。

树中的数据是从网络更新的,但实际的更新是在gui线程中完成的。

我应该按照什么确切的顺序做事吗?我可能忘记继承导致这种情况的某个方法了吗?

我已经实施了这些方法:-数据-旗帜-getItem-索引-父-setData

编辑:忘了提一下,我在主sortChildrenOf调用前后得到了emit-layoutAboutToBeChanged和emit-layout Changed。

我让它工作了,但没有使用beginMoveRows和endMoveRows。我使用了旧的发出layoutAboutToChange的系统来获取持久索引的列表,并对其进行操作,然后用changePersistentIndexList将其设置回,最后发出改变了的布局。

由于这是修复的,我相信beginMoveRows、endMoveRows和具有树类型数据的持久索引存在一些错误。

询问您是否需要一个更好的代码示例。