RecyclerView notifyItemRangeRemoved 没有动画
RecyclerView notifyItemRangeRemoved no animation
我将 recyclerView 与 notifyItemRangeInserted 和 notifyItemRangeRemoved 一起使用。
我屏幕中的 RecyclerView 使用了 width="match_parent" and height="wrap_content"
我需要在我的 recylerView 中显示或隐藏 ALL 元素。我使用了这段代码,效果很好。元素更改后隐藏和显示 visibility
标志。
但是由于某种原因存在用于插入的动画并且没有用于删除的动画。为什么?
class MyAdapter : RecyclerView.Adapter<ViewHolder>() {
var objects: List<MyData> = emptyList()
set(value) {
field = value
notifyDataSetChanged()
}
var visibility: Boolean = true
set(value) {
field = value
when (field) {
true -> notifyItemRangeInserted(0, cards.size)
false -> notifyItemRangeRemoved(0, cards.size)
}
}
override fun getItemCount(): Int = if (visibility) objects.size else 0
上网查了一下,发现RecyclerView在height = wrap_content时动画有问题。
在某些版本的回收库中google
这是固定的,但是从人们的回答中我发现这个问题与 androidx 库相关
我将 recyclerView 与 notifyItemRangeInserted 和 notifyItemRangeRemoved 一起使用。
我屏幕中的 RecyclerView 使用了 width="match_parent" and height="wrap_content"
我需要在我的 recylerView 中显示或隐藏 ALL 元素。我使用了这段代码,效果很好。元素更改后隐藏和显示 visibility
标志。
但是由于某种原因存在用于插入的动画并且没有用于删除的动画。为什么?
class MyAdapter : RecyclerView.Adapter<ViewHolder>() {
var objects: List<MyData> = emptyList()
set(value) {
field = value
notifyDataSetChanged()
}
var visibility: Boolean = true
set(value) {
field = value
when (field) {
true -> notifyItemRangeInserted(0, cards.size)
false -> notifyItemRangeRemoved(0, cards.size)
}
}
override fun getItemCount(): Int = if (visibility) objects.size else 0
上网查了一下,发现RecyclerView在height = wrap_content时动画有问题。
在某些版本的回收库中google 这是固定的,但是从人们的回答中我发现这个问题与 androidx 库相关