FragmentPagerAdapter是PagerAdapter中的其中一种实现。它将每一个页面表示为一个 Fragment,并且每一个Fragment都将会保存到fragment manager当中。而且,当用户没可能再次回到页面的时候,fragment manager才会将这个Fragment销毁。
这种pager十分适用于有一些静态fragment,例如一组tabs,的时候使用。每个页面对应的Fragment当用户可以访问的时候会一直存在内存中,但是,当这个页面不可见的时候,view hierarchy将会被销毁。这样子会导致应用程序占有太多资源。当页面数量比较大的时候,建议使用 FragmentStatePagerAdapter。
当使用FragmentPagerAdapter的时候,ViewPager一定要使用正确的ID set。
FragmentPagerAdapter的子类只要实现 getItem(int) 和 getCount()方法。
mFragmentsList = new ArrayList<Fragment>(); mQuickCallFragment = new QuickCallFragment(); mCallLogFragment = new CallLogFragment(); mContactsFragment = new ContactsFragment(); mSettingsFragment = new SettingsFragment(); mFragmentsList.add(mQuickCallFragment); mFragmentsList.add(mCallLogFragment); mFragmentsList.add(mContactsFragment); mFragmentsList.add(mSettingsFragment);
mViewPager.setAdapter(new HomeFragmentPagerAdapter(getSupportFragmentManager(), mFragmentsList)); mViewPager.setOnPageChangeListener(new HomeOnPageChangeListener());
public class HomeFragmentPagerAdapter extends FragmentPagerAdapter { private static final String TAG = "[ZHUANG]HomeFragmentPagerAdapter"; private ArrayList<Fragment> mFragmenstList; public HomeFragmentPagerAdapter(FragmentManager fm) { super(fm); } public HomeFragmentPagerAdapter(FragmentManager fm, ArrayList<Fragment> fragments) { super(fm); this.mFragmenstList = fragments; } @Override public int getCount() { return mFragmenstList.size(); } @Override public Fragment getItem(int arg0) { return mFragmenstList.get(arg0); } @Override public int getItemPosition(Object object) { return super.getItemPosition(object); } @Override public void destroyItem(ViewGroup container, int position, Object object) { super.destroyItem(container, position, object); if(LogLevel.DEV){ DevLog.d(TAG, "destroyItem position = " + position); } } }