我正在使用绑定(bind)到 observablecollection 的 MvxListView 来显示聊天消息。我找到了一种方法, ListView 总是使用以下 2 个属性向下滚动到底部:

android:stackFromBottom="true"
android:transcriptMode="alwaysScroll"

当我通过命令(当我自己发送消息时)向 observablecollection 添加消息时,这很有效,但是当我通过 viewmodel 接收消息(通过信号器)然后以完全相同的方式将消息添加到 observablecollection 时, ListView 已更新,但不会向下滚动。当我手动向下滚动消息时,它只是不会自动向下滚动。我认为这可能与通过信号器到达的消息有关,因为它是一个异步回调。

我尝试手动强制 ListView 在 MvxAdapter 中向下滚动,如下所示:
   public override void NotifyDataSetChanged()
    {
        base.NotifyDataSetChanged();
        ((FragmentActivity)_context).RunOnUiThread(() =>
        {
            _list.SetSelection(this.Count-1);
        });
    }

然后在消息到达时显式调用它,但这也没有任何作用。

帮助?

最佳答案

刚刚从 Slodge 看到这个答案:

Advice on where and when to use ObservableCollection in MvvmCross

UI 更新必须同步完成。仔细想想,这确实是有道理的。我的答案是使用:

MvxMainThreadDispatcher.Instance.RequestMainThreadAction(() => {
    // fill your collection in the viewmodel and do a propertychanged
});

10-07 22:47