RecyclerView局部刷新的应用场景简单分析

RecyclerView 局部刷新的应用场景巩固

今天在做通讯录屏蔽时,由于通讯录列表里有两种不同的效果展示:

1. 已经屏蔽的 item ,显示一个按钮“解除屏蔽”
2. 未屏蔽的 item ,显示两个按钮“恢复屏蔽”和“邀请”

分析到这里后,果断在 adapter 里创建了两种 type 来分别处理两种不一样的显示效果,事实证明这也确实能满足这个需求。
然而当我把测试数据添加到2000条时,越往列表底部,当处理点击按钮切换 item 的 type 时, ui 刷新的就越慢。
分析了一下,大致知道了是怎么回事:

RecyclerView 的局部刷新 notifyItemRangeChanged(int positionStart, int itemCount) ,它是当 adapter 绑定的数据源发生变化后,
把变化的数据刷新到 原typeview 上去。
也就是说,我之前的写法,使用局部刷新去改变typeview,这种用法是不对的。

NotifyItemRangeChanged官方解释

google官方解释,大概意思是

“这是一个 item 改变事件,而不是结构改变事件。它表明,在给定的位置范围内的数据的任何反射都是失效的并且应该更新。这些在给定范围的 item 具有相同的标识(即它们的数据都已经失效并需要更新)。”

recyclerview的局部刷新是有区分的,有数据的刷新和 item 结构的刷新,局部的 item 插入、删除、移动刷新方法都是结构的刷新。而notifyItemChanged、notifyItemRangeChanged方法属于数据的刷新。

解决方法:
把之前的两种typeview合并成一种(两种布局其实前边的布局都是一样的,后边的按钮不一样,这种还是很好处理的,直接写道一块然后根据标识字段显示隐藏)

再次测试无论在列表底部还是顶部,刷新ui都嗖嗖的

注意一点:notifyItemRangeChanged 更新的是数据源,并不是专门用来更新 viewtype 的。所以在划分 viewtype 的时候,一定要思路清晰,考虑清楚
RecyclerView局部刷新闪烁是指在使用RecyclerView进行局部刷新时,界面出现明显的闪烁现象。这种现象通常是由于RecyclerView的Item刷新过程中引起的,下面是一些可能导致RecyclerView局部刷新闪烁的原因和解决方法。 1. 数据源变化频繁:当RecyclerView的数据源频繁发生变化时,局部刷新可能会导致闪烁。解决办法可以是尽量减少数据源的变化,例如使用DiffUtil工具类来优化数据比较,只更新真正变化的Item。 2. ViewHolder的重用问题:如果RecyclerView的Item中使用了动画效果,而在进行局部刷新时未正确处理ViewHolder的重用问题,可能会导致动画重复播放,从而产生闪烁。解决办法是在局部刷新的时候,清除或暂停动画效果,并正确处理ViewHolder的重用逻辑。 3. 刷新时的绘制问题:默认情况下,RecyclerView进行Item的局部刷新时,会重新绘制整个Item View,这可能会导致闪烁。解决办法是通过重写Item View的onDraw()方法,在局部刷新时只绘制变化的部分,而不是整个Item View。 4. 使用过多的动画效果:如果RecyclerView中的Item View使用了过多的动画效果,例如淡入淡出、旋转等,这些动画效果在局部刷新时会导致闪烁。解决办法是优化动画效果的使用,尽量减少动画效果的数量和复杂度。 总之,解决RecyclerView局部刷新闪烁问题的方法包括优化数据源的变化、正确处理ViewHolder的重用逻辑、优化绘制和动画效果的使用等。通过这些措施,可以有效减少RecyclerView局部刷新闪烁的现象,提升用户体验。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值