RecyclerView三种局部刷新实现

        1. RecyclerView自带的局部刷新

        缺点:要知道数据变化index

  //RecyclerView.Adapter中局部刷新主要API
  Adapter.notifyItemChanged(int)
  Adapter.notifyItemInserted(int)
  Adapter.notifyItemRangeChanged(int,int)
  Adapter.notifyItemRangeInserted(int,int)
  Adapter.notifyItemRangeRemoved(int,int)

        2. 使用DiffUtil, 只更新数据有变化的item, 25.1.0版本开始支持

        缺点:数据比较在主线程,可能ANR
DiffUtil.DiffResult result = DiffUtil.calculateDiff(new MyCallback(oldList, mTextModels), true);
myAdapter.setData(mTextModels);
result.dispatchUpdatesTo(myAdapter);

        3. AsyncListDiffer,数据比较在子线程,27.1.0版本开始支持

        在Adapter中获取数据不直接从model中获取,而改为从AsyncListDiffer中获取。实质仍然是对DiffUtil的包装。

public class MyDiffAdapter  extends RecyclerView.Adapter {
  private Context mContext;
  private AsyncListDiffer<TextModel> mTextDiffl;
  private DiffUtil.ItemCallback<TextModel> diffCallback = new MyItemCallBack();
  public MyDiffAdapter(Context mContext) {
      this.mContext = mContext;
      mTextDiffl = new AsyncListDiffer<>(this, diffCallback);
  }
  @NonNull
  @Override
  public RecyclerView.ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
      View itemView = LayoutInflater.from(mContext).inflate(R.layout.item_view, null);
      return new MyViewHolder(itemView);
  }
  @Override
  public void onBindViewHolder(RecyclerView.ViewHolder holder, int position) {
      MyAdapter.MyViewHolder myViewHolder = (MyAdapter.MyViewHolder) holder;
      TextModel textModel = getItem(position);
      myViewHolder.tv.setText(textModel.getTextTitle() + "." + textModel.getTextContent());
  }
  @Override
  public int getItemCount() {
      return mTextDiffl.getCurrentList().size();
  }
  public void submitList(List<TextModel> data) {
    mTextDiffl.submitList(data);
  }
  public TextModel getItem(int position) {
      return mTextDiffl.getCurrentList().get(position);
  }
  class MyViewHolder extends RecyclerView.ViewHolder {
      TextView tv;
      MyViewHolder(View itemView) {
          super(itemView);
          tv = (TextView) itemView.findViewById(R.id.item_tv);
    }
  }
}
public class MyItemCallBack extends DiffUtil.ItemCallback<TextModel> {
    @Override
    public boolean areItemsTheSame(@NonNull TextModel oldItem, @NonNull TextModel newItem) {
      return TextUtils.equals(oldItem.getTextTitle(), newItem.getTextTitle());
    }
    @Override
    public boolean areContentsTheSame(@NonNull TextModel oldItem, @NonNull TextModel newItem) {
      return TextUtils.equals(oldItem.getTextContent(), newItem.getTextContent());
}

  • 11
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
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局部刷新闪烁的现象,提升用户体验。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值