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);
}
}
}