ViewPager適配器編寫

ViewPager的適配器的編寫

  public class FixPagerAdapter extends FragmentStatePagerAdapter {

//頂部TabLayout的文字
private String[] titles;
//保存Fragment的集合
private List<Fragment> fragments = null;

public void setFragments(List<Fragment> fragments) {
    this.fragments = fragments;

}

public void setTitles(String[] titles){
    this.titles=titles;

}

public FixPagerAdapter(FragmentManager fm) {
    super(fm);
}

@Override
public Fragment getItem(int position) {
    return fragments.get(position);
}

@Override
public int getCount() {
    return fragments.size();
}

@Override
public Object instantiateItem(ViewGroup container, int position) {
    Fragment fragment = null;
    try {
        fragment = (Fragment) super.instantiateItem(container, position);

    } catch (Exception e) {

    }

    return fragment;
}

@Override
public void destroyItem(ViewGroup container, int position, Object object) {

}

@Override
public CharSequence getPageTitle(int position) {
    return titles[position];
}

}

ViewPager繼承FragmentPagerAdapter和FragmentStatePagerAdapter兩種的區(qū)別

 兩種適配器的寫法是一樣的,顯示出來的效果基本是一樣的,
 FragmentPagerAdapter適用于當(dāng)viewpager中fragment數(shù)量少的
情況,F(xiàn)ragmentStatePagerAdapter適用于fragment數(shù)量多的情況
下使用
兩種adapter的創(chuàng)建,儲存方式不同
兩種adapter的銷毀方式不同

FragmentPagerAdapter

創(chuàng)建
@SuppressWarnings("ReferenceEquality")
@Override
public Object instantiateItem(ViewGroup container, int position) {
    if (mCurTransaction == null) {
        mCurTransaction = mFragmentManager.beginTransaction();
    }

    final long itemId = getItemId(position);

    // Do we already have this fragment?
    String name = makeFragmentName(container.getId(), itemId);
    Fragment fragment = mFragmentManager.findFragmentByTag(name);
    if (fragment != null) {
        if (DEBUG) Log.v(TAG, "Attaching item #" + itemId + ": f=" + fragment);
        mCurTransaction.attach(fragment);
    } else {
        fragment = getItem(position);
        if (DEBUG) Log.v(TAG, "Adding item #" + itemId + ": f=" + fragment);
        mCurTransaction.add(container.getId(), fragment,
                makeFragmentName(container.getId(), itemId));
    }
    if (fragment != mCurrentPrimaryItem) {
        fragment.setMenuVisibility(false);
        fragment.setUserVisibleHint(false);
    }

    return fragment;
}

銷毀
@Override
public void destroyItem(ViewGroup container, int position, Object object) {
    if (mCurTransaction == null) {
        mCurTransaction = mFragmentManager.beginTransaction();
    }
    if (DEBUG) Log.v(TAG, "Detaching item #" + getItemId(position) + ": f=" + object
            + " v=" + ((Fragment)object).getView());
    mCurTransaction.detach((Fragment)object);
}
創(chuàng)建時,以鍵值對的形式,存儲id,fragment,fragment名字
銷毀時,不是將不可見的fragment銷毀,而是
僅僅將該fragment從頁面中detach掉,fragment還是在manager
中保存,內(nèi)存沒有被釋放,所以FragmentPagerAdapter不適合
fragment數(shù)量多的情況下使用,因
為未被釋放的fragment會占用大量內(nèi)存。

FragmentStatePagerAdapter

創(chuàng)建
 @Override
public Object instantiateItem(ViewGroup container, int position) {
    // If we already have this item instantiated, there is nothing
    // to do.  This can happen when we are restoring the entire pager
    // from its saved state, where the fragment manager has already
    // taken care of restoring the fragments we previously had instantiated.
    if (mFragments.size() > position) {
        Fragment f = mFragments.get(position);
        if (f != null) {
            return f;
        }
    }

    if (mCurTransaction == null) {
        mCurTransaction = mFragmentManager.beginTransaction();
    }

    Fragment fragment = getItem(position);
    if (DEBUG) Log.v(TAG, "Adding item #" + position + ": f=" + fragment);
    if (mSavedState.size() > position) {
        Fragment.SavedState fss = mSavedState.get(position);
        if (fss != null) {
            fragment.setInitialSavedState(fss);
        }
    }
    while (mFragments.size() <= position) {
        mFragments.add(null);
    }
    fragment.setMenuVisibility(false);
    fragment.setUserVisibleHint(false);
    mFragments.set(position, fragment);
    mCurTransaction.add(container.getId(), fragment);

    return fragment;
}

銷毀
  @Override
public void destroyItem(ViewGroup container, int position, Object object) {
    Fragment fragment = (Fragment) object;

    if (mCurTransaction == null) {
        mCurTransaction = mFragmentManager.beginTransaction();
    }
    if (DEBUG) Log.v(TAG, "Removing item #" + position + ": f=" + object
            + " v=" + ((Fragment)object).getView());
    while (mSavedState.size() <= position) {
        mSavedState.add(null);
    }
    mSavedState.set(position, fragment.isAdded()
            ? mFragmentManager.saveFragmentInstanceState(fragment) : null);
    mFragments.set(position, null);

    mCurTransaction.remove(fragment);
}

創(chuàng)建時會保存fragment位置狀態(tài),fragment,
銷毀時會保存fragment位置狀態(tài),這樣就會保存當(dāng)前fragment的   
位置狀態(tài),創(chuàng)建時候,在當(dāng)前位置創(chuàng)建,節(jié)約資源
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容