Android中Fragment相互切换间不被回收的实现方法

Android中Fragment相互切换间不被回收的实现方法,第1张

概述前言Android运行在各种各样的设备中,有小屏幕的手机,超大屏的平板甚至电视。针对屏幕尺寸的差距,很多情况下,都是先针对手机开发一套App,然后拷贝一份,修改布局以适应平板神马超级大屏的。难道无法做到一个App

前言

AndroID运行在各种各样的设备中,有小屏幕的手机,超大屏的平板甚至电视。针对屏幕尺寸的差距,很多情况下,都是先针对手机开发一套App,然后拷贝一份,修改布局以适应平板神马超级大屏的。难道无法做到一个App可以同时适应手机和平板么,当然了,必须有啊。Fragment的出现就是为了解决这样的问题。

如今市面上的应用基本上都是单Activity+多Fragment实现的了,而这类APP都有在相互切换时不被回收,即切换回原来的Fragment时还是原先的状态,这就是这里要实现的了。

这里使用Fragment的add()show()hIDe()实现,即显示和隐藏,这样原来的Fragment就不会被销毁了。

二话不说,贴代码,代码是最好的老师。

示例代码(注释还算详细了)

public class MainActivity extends AppCompatActivity implements VIEw.OnClickListener { private ImageVIEw ibOne; private ImageVIEw ibTwo; private ImageVIEw ibThree;  private FragmentManager mFm; private ArrayList<Fragment> mFragmentList = new ArrayList<Fragment>(); private String[] mFragmentTagList = {"OneFragment","TwoFragment","ThreeFragment"}; private Fragment mCurrentFragmen = null; // 记录当前显示的Fragment @OverrIDe protected voID onCreate(Bundle savedInstanceState) {  super.onCreate(savedInstanceState);  setContentVIEw(R.layout.activity_main);    initVIEw();  initData();   } private voID initData() {  OneFragment oneFragment = new OneFragment();  TwoFragment twoFragment = new TwoFragment();  ThreeFragment threeFragment = new ThreeFragment();  mFragmentList.add(0,oneFragment);  mFragmentList.add(1,twoFragment);  mFragmentList.add(2,threeFragment);  mCurrentFragmen = mFragmentList.get(0);  // 初始化首次进入时的Fragment  mFm = getFragmentManager();  FragmentTransaction transaction = mFm.beginTransaction();  transaction.add(R.ID.fl_show,mCurrentFragmen,mFragmentTagList[0]);  transaction.commitAllowingStateLoss(); } // findVIEwByID private voID initVIEw() {  ibOne = (ImageVIEw)findVIEwByID(R.ID.ib_one);  ibTwo = (ImageVIEw)findVIEwByID(R.ID.ib_two);  ibThree = (ImageVIEw)findVIEwByID(R.ID.ib_three);  ibOne.setonClickListener(this);  ibTwo.setonClickListener(this);  ibThree.setonClickListener(this); } @OverrIDe public voID onClick(VIEw vIEw) {  switch (vIEw.getID()){   case R.ID.ib_one:    switchFragment(mFragmentList.get(0),mFragmentTagList[0]);    break;   case R.ID.ib_two:    switchFragment(mFragmentList.get(1),mFragmentTagList[1]);    break;   case R.ID.ib_three:    switchFragment(mFragmentList.get(2),mFragmentTagList[2]);    break;  } } // 转换Fragment voID switchFragment(Fragment to,String tag){  if(mCurrentFragmen != to){   FragmentTransaction transaction = mFm.beginTransaction();   if(!to.isAdded()){    // 没有添加过:    // 隐藏当前的,添加新的,显示新的    transaction.hIDe(mCurrentFragmen).add(R.ID.fl_show,to,tag).show(to);   }else{    // 隐藏当前的,显示新的    transaction.hIDe(mCurrentFragmen).show(to);   }   mCurrentFragmen = to;   transaction.commitAllowingStateLoss();  } } // 当activity非正常销毁时被调用 @OverrIDe public voID onSaveInstanceState(Bundle outState,PersistableBundle outPersistentState) {  super.onSaveInstanceState(outState,outPersistentState);  // 重置Fragment,防止当内存不足时导致Fragment重叠  updateFragment(outState); } // 重置Fragment private voID updateFragment(Bundle outState) {  mFm = getFragmentManager();  if(outState == null){   FragmentTransaction transaction = mFm.beginTransaction();   OneFragment oneFragment = new OneFragment();   mCurrentFragmen = oneFragment;   transaction.add(R.ID.fl_show,oneFragment,mFragmentTagList[0]).commitAllowingStateLoss();  }else{   // 通过tag找到fragment并重置   OneFragment oneFragment = (OneFragment) mFm.findFragmentByTag(mFragmentTagList[0]);   TwoFragment twoFragment = (TwoFragment) mFm.findFragmentByTag(mFragmentTagList[1]);   ThreeFragment threeFragment = (ThreeFragment) mFm.findFragmentByTag(mFragmentTagList[2]);   mFm.beginTransaction().show(oneFragment).hIDe(twoFragment).hIDe(threeFragment);  } }}

我以前对于这种需求是在一个Activity中使用relativeLayout,在其中加入多个布局(类似Fragment),当点击下方Tab时设置布局的visibility的,思想是一样的,但这样实现起来很是丑陋,所以不建议使用。

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对编程小技巧的支持

总结

以上是内存溢出为你收集整理的Android中Fragment相互切换间不被回收的实现方法全部内容,希望文章能够帮你解决Android中Fragment相互切换间不被回收的实现方法所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/web/1144921.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-31
下一篇 2022-05-31

发表评论

登录后才能评论

评论列表(0条)

保存