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性能优化也讲的差不多了,接下来要分享什么呢?明天再看吧~~大家共同进步吧