目录

BaseRecyclerViewAdapterHelper开源项目之BaseViewHolder源码学习

目录

http://catbro.cn/attachment/20170308/ba293c54559c4ab2a17700dead88243e.png

接下来假设一个场景来分析,假设我们要给一个TextView控件设置一段文字进行显示,一般我们会使用该方法。

holder.setText(R.id.xxx,“hello world”);

1
2
3
4
5
 public BaseViewHolder setText(int viewId, CharSequence value) {
        TextView view = getView(viewId);
        view.setText(value);
        return this;
    }

可以看到,源码里第一步会调用getView(viewId)方法,我们来看下该方法的代码

1
2
3
4
5
6
7
8
 public  T getView(int viewId) {
        View view = views.get(viewId);
        if (view == null) {
            view = convertView.findViewById(viewId);
            views.put(viewId, view);
        }
        return (T) view;
    }

代码中,他会先到views中根据view 的id进行查找,看是否前面已经实时化该view,如果实例化来,就直接拿来用就好。

如果view==null

我们会通过converView去调用我们再熟悉不过的findViewById进行创建,然后把创建的view实例缓存到views中方便下次使用,

上面我们说到converView,他代码的是我们viewholder的ItemView,也就是每个item的总布局。他其实是在我们初始化BaseViewHolder的时候传进来的

1
2
3
4
5
6
7
8
9
  public BaseViewHolder(View view) {
        super(view);
        this.views = new SparseArray();
        this.childClickViewIds = new LinkedHashSet<>();
        this.itemChildLongClickViewIds = new LinkedHashSet<>();
        this.nestViews = new HashSet<>();
        this.convertView = view;

    }

而BseVIewHolder的创建又是从我们的BaseQuickAdapter里面执行的,我们下一篇会分析BaseQuickAdapter的代码。

剩下的事情就相当简单了,如果从views缓存队列中找到了我们需要的view,直接调用setText设置文字,没找到就先创建,然后压入缓存,然后再调用。其余的api调用方法执行的逻辑基本一样。

BaseViewHolder里还有三个比较重要的成员

private final HashSet nestViews;

private final LinkedHashSet childClickViewIds;

private final LinkedHashSet itemChildLongClickViewIds; 这是跟点击事件相关的,后面我会单独出一篇来进行根系与学习。 http://catbro.cn