ListView性能优化系列之三
上一节讲到了ListView中的垃圾回收站,用来管理回收view,这一节将继续学习源码,看看这个垃圾回收站到底是怎么用的,convertView是如何传递到adapter的getView方法的。
- makeAndAddView:这个方法是在ListView里面,顾名思义,这个方法中有两个动词make和add,所以这个方法的作用是构造一个view并且将这个view加入到viewgroup的children list中去。
private View makeAndAddView(int position, int y, boolean flow,
int childrenLeft, boolean selected) {
View child;
if (!mDataChanged) {// 数据没有发生改变
child = mRecycler.getActiveView(position);// 从回收站的当前可见的视图列表中获取
if (child != null) {
/**
* 定位并且添加这个view到ViewGrop中的children列表,从回收站获取的视图不需要测量
* 所以最后一个参数为true
*/
setupChild(child, position, y, flow, childrenLeft, selected,true);
return child;
}
}
//获取一个view,有可能是从回收站拿到的,也可能是从新构造的一个view
child = obtainView(position, mIsScrap);
// 这个视图需要定位并且重新测量
setupChild(child, position, y, flow, childrenLeft, selected, mIsScrap[0]);
return child;
}
obtainView:当这个方法被调用时,说明Recycle bin中的view已经不可用了,那么,现在唯一的方法就是,convert一个老的view,或者构造一个新的view。
View obtainView(int position, boolean[] isScrap) {
isScrap[0] = false;
View scrapView;
scrapView = mRecycler.getScrapView(position);//从垃圾箱里面取数据
View child;
if (scrapView != null) {//当有数据的时候,直接通过老的view去convert(找不到一个合适翻译)
//调用第一节中adapter的getView方法,将scrapView传入,也就是我们的converView
child = mAdapter.getView(position, scrapView, this);
if (child != scrapView) {//返回的view和传入的scrapViwe不同
mRecycler.addScrapView(scrapView);//放入垃圾桶
if (mCacheColorHint != 0) {
child.setDrawingCacheBackgroundColor(mCacheColorHint);
}
} else {
isScrap[0] = true;
child.dispatchFinishTemporaryDetach();
}
} else {//回收站中没有拿到数据,就只能够自己去inflate一个xml布局文件,或者new一个view
child = mAdapter.getView(position, null, this);//这里传入的converView=null
if (mCacheColorHint != 0) {
child.setDrawingCacheBackgroundColor(mCacheColorHint);
}
}
return child;
}
总结:用了三篇博客,耗时一天时间(打了一下午篮球,晚上加班),关于listview性能优化也讲的差不多了,接下来要分享什么呢?明天再看吧~~大家共同进步吧