Adapter 中view 的复用的一种优化方案

在实际的的项目开发中,如果存在2个相似的adpter 进行布局的复用,比如我遇到到的 PagerAdapter 和 ListAdapter 复用同一个布局的时候,那么我在PagerAdapter 的
 @Override
    public Object instantiateItem(ViewGroup view, int position) {
        View convertView = getScrapView();
        View currentView = mInnerAdapter.getView(position, convertView, view);
        currentView.setTag(position);
        currentView.setOnClickListener(mOnClickListener);
        view.addView(currentView);
        return currentView;
    }

通过代码我们看到getScrapView(),去获取convertView 那么 getScrapView() 的实现方式为:

   private View getScrapView(){
        if (mScrapViews != null && mScrapViews.size() > 0){
            return mScrapViews.remove(0);
        }
        return null;
    }

其中 private List mScrapViews = new ArrayList<>();

我们是从缓存mScrapViews 中去获取,那么mScrapViews 中的数据是如何获取的,

 @Override
    public void destroyItem(ViewGroup container, int position, Object object) {
        recycleView(object);
        container.removeView((View) object);
    }

这里我门看一个方法 recycleView(object); 那么这份方法中的实现方式为:

private void recycleView(Object object){
        if (object != null && object instanceof View){
            mScrapViews.add((View) object);
        }
    }

这样我门完成了 view 的缓存和获取,
在这个pageAdapter 中通过:

 View currentView = mInnerAdapter.getView(position, convertView, view);
        currentView.setTag(position);

这里的mInnerAdapter 是 需要复用ListAdpter 的实例,那么这个getView 的实现方式就是我们常规的实现方式

猜你喜欢

转载自blog.csdn.net/ahubenkui/article/details/78011451
今日推荐