如何让ViewPager+Fragment来回切换时数据不重复加载

设计思路

本人在设计一款App时,使用了ViewPager+Fragment的模式,一开始设计时为了避免重复加载数据,就使用了ViewPager的setoffscreenPageLimit(int Limit)的方式,直接加载所有的页面,后来数据较多时发现这样会占用大量的空间,用户可能不会去翻看其它数据,那么那些数据加载出来有必要吗?但是如果不一次性加载怎么滑动回来那不是又要重新加载?经过思考,我立马想出了第一个方案,动态管理ViewPager的缓存个数。

  1. @Override  
  2.         public void onPageSelected(int position) {  
  3.             Fragment fragment = fragments[position];  
  4.                 //判断是否滑动到了第二个界面,假如是那么加载4个界面,前后各两个,随着postion递增  
  5.                 if(position>=2){  
  6.                     viewpager.setOffscreenPageLimit(position);  
  7.                 }  
  8.             }  
  9.         }  
但是这样的操作有很大的BUG,当postion=2时,ViewPager会首先移除原先0位置的Fragment,再从新添加,并且也没有解决缓存过多问题。于是,在经过失败后我想出了第二个方案,可不可以自己写一个FragmentViewPager对Fragment进行管理呢,让FragmentViewPager不执行移除原先的Fragment。

MyFragmentViewPager

  1. public class MyFragmentPagerAdapter extends PagerAdapter {  
  2.     private Fragment[] fragments;  
  3.     private FragmentManager manager;  
  4.   
  5.     public MyFragmentPagerAdapter(FragmentManager fm, Fragment[] fragments) {  
  6.         super();  
  7.         manager=fm;  
  8.         this.fragments = fragments;  
  9.     }  
  10.   
  11.   
  12.     @Override  
  13.     public int getCount() {  
  14.         return fragments.length;  
  15.     }  
  16.   
  17.     @Override  
  18.     public Object instantiateItem(ViewGroup container, int position) {  
  19.         Fragment fragment = fragments[position];  
  20.         //判断当前的fragment是否已经被添加进入Fragmentanager管理器中  
  21.         if (!fragment.isAdded()) {  
  22.             FragmentTransaction transaction = manager.beginTransaction();  
  23.             transaction.add(fragment, fragment.getClass().getSimpleName());  
  24.             //不保存系统参数,自己控制加载的参数  
  25.             transaction.commitAllowingStateLoss();  
  26.             //手动调用,立刻加载Fragment片段  
  27.             manager.executePendingTransactions();  
  28.         }  
  29.         if (fragment.getView().getParent() == null) {  
  30.             //添加布局  
  31.             container.addView(fragment.getView());  
  32.         }  
  33.         return fragment.getView();  
  34.     }  
  35.   
  36.   
  37.     @Override  
  38.     public void destroyItem(ViewGroup container, int position, Object object) {  
  39.         //移除布局  
  40.         container.removeView(fragments[position].getView());  
  41.     }  
  42.   
  43.     @Override  
  44.     public boolean isViewFromObject(View view, Object object) {  
  45.         return view == object;  
  46.     }  
  47. }  


效果如下:


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值