- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我的 diffcallback areContentsTheSame(oldItem: ItemModel, newItem: ItemModel)
总是接收相同的内容。我用状态来检查,但每次状态都是一样的。尽管状态实际上正在发生变化。我打算显示每个项目的进度。所以我定期通过状态发送当前进度。使用 diffcallback,它应该检查项目的状态是否不同,然后只更新该项目。但是它接收到的 newItem 和 oldItem 似乎是一样的。
我有一个自定义模型 ItemModel
data class ItemModel(val id: String, var title: String) {
var clickListener: ClickListener? = null
var status: Status? = null
interface ClickListener{
fun onItemClick(view: View, item: ItemModel)
fun onClick(view: View, item: ItemModel)
}
companion object {
val STATUS_CHANGED = 1
val diffCallback = object : DiffUtil.ItemCallback<ItemModel>() {
override fun areItemsTheSame(oldItem: ItemModel, newItem: ItemModel): Boolean {
// Log.i("DiffUtil", "SameItem? old status: ${oldItem.status}, new Status: ${newItem.status}")
return oldItem.id == newItem.id
}
override fun areContentsTheSame(oldItem: ItemModel, newItem: ItemModel): Boolean {
// Log.i("DiffUtil", "Checking status: new: ${newItem.status}, old ${oldItem.status}")
return oldItem.status == newItem.status
}
override fun getChangePayload(oldItem: ItemModel, newItem: ItemModel): Any? {
Log.i("DiffUtil", "Payload change: ${newItem.status?.state}")
if (oldItem.status != newItem.status) {
return STATUS_CHANGED
}
return null
}
}
}
}
和状态数据类
data class Status(val max: Int, val progress: Int, val state: State = State.NONE)
这是我的 ViewModel 类;我使用 Observable.intervalRange
生成不同的数字并更改单个列表项的状态。但是似乎 diffcallback 没有正常工作。
class FunViewModel : ViewModel() {
private val itemModels: MutableLiveData<List<ItemModel>> = MutableLiveData()
fun items(): LiveData<List<ItemModel>> {
return itemModels
}
private val compositeDisposable = CompositeDisposable()
fun initialize(itemList: List<ItemModel>) {
itemModels.value = itemList
}
private fun updateItem(item: ItemModel, status: Status) {
val currentItems = mutableListOf<ItemModel>()
if (itemModels.value == null) return
currentItems.addAll(itemModels.value!!)
Log.i("UpdateItem", "Current item: ${item.id}")
if (currentItems.isNotEmpty()) {
for ((index, el) in currentItems.withIndex()) {
// Log.i("UpdateItem", "searching: ${el.id}")
if (el.id == item.id) {
val currentItem = currentItems.removeAt(index)
Log.i("UpdateItem", "old status: ${currentItem.status}")
currentItem.status = status
currentItems.add(index, currentItem)
break
}
}
itemModels.value = currentItems
Log.i("UpdateItem", "new status: ${items().value?.get(0)?.status}")
}
}
fun startProgress(item: ItemModel) {
val disposable = getProgress(item.id).map { progress ->
val status = Status(progress.second.toInt(), progress.third.toInt(), State.IN_PROGRESS)
status
}.subscribeOn(Schedulers.single())
.observeOn(AndroidSchedulers.mainThread())
.subscribe({ status ->
updateItem(item, status)
// Log.i("FunViewModel:", "Status: progress: ${status.progress}, State: ${status.state}")
},
{ throwable: Throwable? -> Log.e("FunViewModel", "Unable to process progress!", throwable) },
{
val status = Status(20, 20, State.COMPLETED)
updateItem(item, status)
Log.i("FunViewModel:", "Status: progress: ${status.progress}, State: ${status.state}")
})
compositeDisposable.add(disposable)
}
private fun getProgress(id: String): Observable<Triple<String, Long, Long>> {
return Observable.intervalRange(0, 20, 300, 500, TimeUnit.MILLISECONDS)
.map { num -> Triple<String, Long, Long>(id, 20, num) }
}
override fun onCleared() {
super.onCleared()
if (!compositeDisposable.isDisposed) compositeDisposable.dispose()
}
}
最佳答案
好吧,我发现问题是我复制原始内容的方式不是实际复制内容,而是引用。所以我通过将项目内容复制到新的 itemModel 实例中来解决问题。完成后,diff util 就能够正确区分。
代替这个,
private fun updateItem(item: ItemModel, status: Status) {
......................................................
for ((index, el) in currentItems.withIndex()) {
if (el.id == item.id) {
val currentItem = currentItems.removeAt(index)
currentItem.status = status
currentItems.add(index, currentItem)
break
}
}
itemModels.value = currentItems
......................................
}
我这样做了,
private fun updateItem(item: ItemModel, status: Status) {
...............
if (el.id == item.id) {
currentItems.removeAt(index)
val currentItem = ItemModel(item.id, "${item.title}, ${status.progress}")
currentItem.status = status
currentItems.add(index, currentItem)
break
}
...........
}
关于android - Recyclerview ListAdapter DiffUtil 未按预期工作,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54217587/
我们正在尝试对包含来自 sqlite 数据库的数据的 ArrayList 进行排序。 我可以通过添加到查询“ORDER BY”+ Col_IDBG+“DESC 来对列表进行排序 除了 Recycler
我通常在需要时将 diffutil 与 Recyclerview 一起使用。现在我有这样的情况,我从后端得到的项目是这样的: data class CarouselItem(var url: Stri
我正在尝试使用DiffUtil来更新RecyclerView。我有一个类 DataProvider ,它是一个单例类,它保存包含对象的列表。 每次我需要更新RecyclerView时,我都会修改Dat
我有一个 RecyclerView,其中的元素通过 WebSocket 更新。此更新可能会影响列表中不同位置的多个元素。我想用 DiffUtil更新 RecycleView 的元素。套接字更新本身不包
DiffUtils.dispatchUpdatesTo(adapter) 没有更新我在 recyclerView 中的数组大小 我的 result 的大小大于当前的 itemList,但只显示当前的大
我为 recyclerView 制作了一个适配器,并使用 DiffUtil 以更漂亮的方式显示列表的更新。我使用 google codelabs 作为引用。但该列表并未从以下代码更新。请帮忙 clas
我正在使用 diff util 来提高我的 recyclerview 的性能,而不是调用 notifyDataSetChanged()。 recyclerview 有一个带有一些芯片的标题,可以通过
我有一个具有 DiffUtil 功能的 RecyclerView 适配器。 我想在 DiffUtil 完成其魔法时使用 DataObserver 通知 fragment 。但是,看起来 DiffUti
我的回收站 View 中有无限滚动,因此,它会在有新数据时更新。我正在使用 DiffUtil 更新 recyclerview 中的数据。 DiffUtil 确实会更新数据,但是只要有更新数据,recy
一段时间以来,我一直被困在一个相当简单的问题上。出于某种原因,我无法在 StackOverflow 上找到这方面的答案,所以我想我应该直接寻求帮助。 问题很简单,我有一个按日期排序的交易对象列表。我正
我正在使用下面的代码来测试 DiffUtil实现。根据文档- DiffUtil is a utility class that can calculate the difference between
更新:其中一个问题解决了:现在updateList解决了,问题是我把mAdapter定义为RecyclerView .Adapter 而不是 MyAdapter。但是现在即使我正在获取数据,列表中也没
目前我尝试在我的项目中使用DiffUtil来通知RecyclerView的项目。 与此同时,我编写了一个可以添加页眉和页脚的自定义适配器。我使用了这个适配器并添加了一个加载更多的页脚,这样我的列表在向
我对 Android 还很陌生,目前正在开发我的第一个基于 RecyclerView 的严肃应用程序。当我插入或更新现有行时,我注意到我的应用程序中有一些有问题的行为:即使我在添加或 notifyIt
我使用 ListAdapter 的绑定(bind)和 DiffUtil.ItemCallback 的定义。删除项目(至少 2 个)时出现 IndexOutOfBoundsException。列表的更新
每次我调用无效数据时,我的 DIFF_UTIL 都不会被使用。日志未显示,整个列表已更新为新数据,导致屏幕移动位置等。不确定这里的问题是什么。 我有PagedListAdapter与 LiveData
我无法将 Kotlin Flows 和异步 DiffUtil 放在一起。 我的 RecyclerView.Adapter 中有这个函数,它在计算线程上计算 DiffUtil 并将更新发送到主线程上的
我是 Android 的新手,我正在尝试使用新架构组件实现条码阅读器场景。 每次读取条码时,如果条码不在列表中,我想更新 ViewModel 中的列表,添加新元素,否则增加数量。 以下解决方案有效,但
我遇到了一个有趣的情况,我的适配器有 2 种 View 类型 - HEADER 和 ITEM。 header View 始终位于位置 0。更新数据时,我使用 DiffUtil 获取数据的差异。为了分派
我的 diffcallback areContentsTheSame(oldItem: ItemModel, newItem: ItemModel) 总是接收相同的内容。我用状态来检查,但每次状态都是
我是一名优秀的程序员,十分优秀!