在RecyclerView.Adapter中,平时我们刷新的方法是:
notifyDataSetChanged()
其实 ,RecyclerView.Adapter中为我们提供了很多自带酷炫的增加删除动画,包括局部刷新的方法。
·notifyItemInserted(int position): 列表position位置添加一条数据时可以调用,伴有动画效果
·notifyItemRemoved(int position) :列表position位置移除一条数据时调用,伴有动画效果
·notifyItemMoved(int fromPosition, int toPosition) 列表fromPosition位置的数据移到toPosition位置时调用,伴有动画效果
·notifyItemRangeChanged(int positionStart, int itemCount) 列表从positionStart位置到itemCount数量的列表项进行数据刷新
·notifyItemRangeInserted(int positionStart, int itemCount) 列表从positionStart位置到itemCount数量的列表项批量添加数据时调用,伴有动画效果
·notifyItemRangeRemoved(int positionStart, int itemCount) 列表从positionStart位置到itemCount数量的列表项批量删除数据时调用,伴有动画效果
需要注意的地方,在使用这些方法的时候,google官方文档中提到他们的position会自动增加,但是在实际操作过程中,并没有增加,导致数据错位的问题,所以,当我们需要使用这些特效方法的时候,必须要重新刷新一遍数据,纠正position。
//两个item之间互换位置
fun changeItem(fromPosition: Int, endPosition: Int) {
Collections.swap(mList, fromPosition, endPosition)
notifyItemMoved(fromPosition, endPosition)
// 加入如下代码保证position的位置正确性
notifyItemRangeChanged(0, mList.size)
}
这里的notifyItemRangeChanged(0, mList.size)是最懒的方法,把所有的ui都刷新了一遍,你也可以通过notifyItemRangeChanged(int positionStart, int itemCount) 这个方法,刷新局部,来优化性能。
还有一个问题就是当你操作的是第一个item的时候,比如插入完成的时候,第一个不会自动出现在recycleView的顶部,这个时候你需要自己手动将recycleView滑动到顶部。
override fun scrollToTop() {
recycleView.scrollToPosition(0)
}
这样就不会影响用户体验了