故事背景是这样的:项目做的是个类似抖音的短视频播放功能,点击进去视频详情,全屏播放,然后上下滑动切换视频,用的是RecyclerView结合阿里云player做的视频流播放,因为这个后台是个分页接口,所以在上滑到快没数据的时候需要加载更多。之前用的是:
this.list.clear(); //清空数据源
this.list.addAll(list); //更新数据源
adapter.notifyDataSetChanged();//刷新列表
然后就有个小问题,每页请求10条,如果首页当前总共10个视频,从首页直接点击第10个,即当前是正在播放第10个视频,然后直接就请求下一页视频数据了,使用上面的代码会导致当前正在播放的视频重新开始播放,体验不太好,而且众所周知notifyDataSetChanged()全部刷新,效率是最低的。就想着使用RecyclerView的局部刷新来替换解决,即
notifyItemRangeChanged(this.list.size()-list.size(),this.list.size()); //只刷新加载多出来的部分数据列表
然后运行发现没效果,多的数据上滑没有出现!懵逼ing。。。 (tip:之前一般都是用RecyclerView做列表,第一次做这种复杂的视频流~)
//最后换成了这种写法,顺利刷新数据,同时不中断当前正在播放的视频进度:
this.list.addAll(list);//更新数据源 notifyItemRangeInserted(this.list.size()-list.size(),this.list.size());//更新列表个数 notifyItemRangeChanged(this.list.size()-list.size(),this.list.size());//更新列表数据
顾名思义,先插入列表个数,再进行局部刷新操作,记录一下,具体什么原因还没来得及看源码,先这样解决了,over。