更多分享请看:
接下来假设一个场景来分析,假设我们要给一个TextView控件设置一段文字进行显示,一般我们会使用该方法。
holder.setText(R.id.xxx,"hello world");
public BaseViewHolder setText(int viewId, CharSequence value) {
TextView view = getView(viewId);
view.setText(value);
return this;
}
可以看到,源码里第一步会调用getView(viewId)方法,我们来看下该方法的代码
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的时候传进来的
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;
这是跟点击事件相关的,后面我会单独出一篇来进行根系与学习。
网友评论