5

我是 android kotlin 的 Paging 3 库中的新手。我想要无限数据。所以我发现 Paging 3 库对我来说很有帮助。我使用PagingSource创建了一个列表。我没有使用房间。我嵌套了recyclerView。我将PagingDataAdapterdiff util一起用于我的 Recyclerview。我使用了codelab推荐的分页库教程我成功了,没有任何问题。我面临更新项目的困难。我使用分页源创建列表,在列表内部我有一些来自服务器的数据。我完全没有任何问题。但是在 reyclerview 中如何更新适配器或通知数据已经改变。我已经有机制来获取更新的列表。我搜索了如何在某个地方更新适配器,但每个地方都提到使用来自DataSource的invalidate()DataSource第 2 页中使用对吗?现在,根据Migrate to Paging 3中的文档,这在 Paging 3 内。我使用 Flow 来检索数据。此代码在viewmodel类中。

fun createRepo(data: List<String>, repository: RepositoryData): Flow<PagingData<UnlimitData>> {
    return repository.getStreamData(data).cachedIn(viewModelScope)
}

我正在传递来自服务器的列表。getStreamData函数返回具有 int 和 string 数据的项目。我的数据类

data class UnlimitData(val id: Int, val name: String)

createRepo在我的活动类中调用以在 adpater 中发送数据。

lifecycleScope.launch {
        viewModel.createRepo(serverData,repository).collectLatest { data ->
            adapter.submitData(data)
        }
}

这是我的适配器代码:-

class unlimitedAdapter() :
    PagingDataAdapter<UnlimitData, RecyclerView.ViewHolder>(COMPARATOR) {

override fun onBindViewHolder(holder: RecyclerView.ViewHolder, position: Int) {
    val item = getItem(position)
    if (item != null) {
        (holder as UnlimitedViewHolder).bind(item)
    }
}

override fun onCreateViewHolder(parent: ViewGroup, viewType: Int): RecyclerView.ViewHolder {
    return UnlimitedViewHolder.create(parent)
}

companion object {
    private val COMPARATOR = object : DiffUtil.ItemCallback<UnlimitData>() {
        override fun areItemsTheSame(oldItem: UnlimitData, newItem: UnlimitData): Boolean =
            oldItem.id == newItem.id

        override fun areContentsTheSame(oldItem: UnlimitData, newItem: UnlimitData): Boolean = oldItem == newItem
    }
}

}

我使用 RetroFit 添加了在列表中插入/更新数据的逻辑。我的列表已成功更新,但我无法刷新 reyclerview。

提前致谢。

4

1 回答 1

3

为了分页获取新项目,您需要调用PagingSource.invalidate()以通知Pager它需要获取新PagingSource页面并重新加载页面。您需要跟踪PagingSource工厂生产的所有 s,并在您从网络更新支持数据集时使它们失效。

编辑:像这样的东西,但这是一个非常粗糙的原型

abstract class InvalidatingPagingSourceFactory<K,V> : () -> PagingSource<K,V> {
    private val list = mutableListOf()

    abstract fun create()

    override final fun invoke() {
        create().also { list.add(it) }
    }

    fun invalidate() {
        while (list.isNotEmpty()) { list.removeFirst().invalidate() }
    }
}
于 2020-11-07T09:35:30.937 回答