接下来假设一个场景来分析,假设我们要给一个 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;
这是跟点击事件相关的,后面我会单独出一篇来进行根系与学习。
http://cherylgood.cn
欢迎来到这里!
我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。
注册 关于