当前位置: 首页 > 编程笔记 >

Android 保存Fragment 切换状态实例代码

裴浩歌
2023-03-14
本文向大家介绍Android 保存Fragment 切换状态实例代码,包括了Android 保存Fragment 切换状态实例代码的使用技巧和注意事项,需要的朋友参考一下

前言

 一般频繁切换Fragment会导致频繁的释放和创建,如果Fragment比较臃肿体验就非常不好了,这里分享一个方法。

 正文

 一、应用场景

  1、不使用ViewPager

  2、不能用replace来切换Fragment,会导致Fragment释放(调用onDestroyView)

 二、实现

1、xml

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
 android:layout_width="match_parent"
 android:layout_height="match_parent"
 android:orientation="vertical" >

 <FrameLayout
  android:id="@+id/container"
  android:layout_width="match_parent"
  android:layout_height="0dip"
  android:layout_weight="1.0" >
 </FrameLayout>

 <RadioGroup
  android:id="@+id/main_radio"
  android:layout_width="fill_parent"
  android:layout_height="wrap_content"
  android:layout_gravity="bottom"
  android:gravity="bottom"
  android:layout_marginBottom="-6dp"
  android:orientation="horizontal" >

  <RadioButton
   android:id="@+id/radio_button0"
   style="@style/main_tab_bottom"
   android:drawableTop="@drawable/bottom_1" />

  <RadioButton
   android:id="@+id/radio_button1"
   style="@style/main_tab_bottom"
   android:drawableTop="@drawable/bottom_2" />

  <RadioButton
   android:id="@+id/radio_button2"
   style="@style/main_tab_bottom"
   android:drawableTop="@drawable/bottom_3" />

  <RadioButton
   android:id="@+id/radio_button3"
   style="@style/main_tab_bottom"
   android:drawableTop="@drawable/bottom_4" />

  <RadioButton
   android:id="@+id/radio_button4"
   style="@style/main_tab_bottom"
   android:drawableTop="@drawable/bottom_5" />
 </RadioGroup>

</LinearLayout>

代码说明:

    非常常见的底部放5个RadioButton,点击切换不同的Fragment。

  2、Activity

   为RadioButton设置setOnCheckedChangeListener事件,其他代码:

 public void onCheckedChanged(CompoundButton buttonView, boolean isChecked) {
  if (isChecked) {
   Fragment fragment = (Fragment) mFragmentPagerAdapter.instantiateItem(mContainer, buttonView.getId());
   mFragmentPagerAdapter.setPrimaryItem(mContainer, 0, fragment);
   mFragmentPagerAdapter.finishUpdate(mContainer);
  } 
 }

 private FragmentPagerAdapter mFragmentPagerAdapter = new FragmentPagerAdapter(getSupportFragmentManager()) {

  @Override
  public Fragment getItem(int position) {
   switch (position) {
   case R.id.radio_button1:
    return new Fragment1();
   case R.id.radio_button2:
    return new Fragment2();
   case R.id.radio_button3:
    return new Fragment3();
   case R.id.radio_button4:
    return new Fragment4();
   case R.id.radio_button0:
   default:
    return new Fragment0();
   }
  }

  @Override
  public int getCount() {
   return 5;
  }
 };

代码说明:

   instantiateItem从FragmentManager中查找Fragment,找不到就getItem新建一个,setPrimaryItem设置隐藏和显示,最后finishUpdate提交事务, mContainer就是xml中的FrameLayout。

 三、FragmentPagerAdapter核心代码

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

 @Override
 public void setPrimaryItem(ViewGroup container, int position, Object object) {
  Fragment fragment = (Fragment)object;
  if (fragment != mCurrentPrimaryItem) {
   if (mCurrentPrimaryItem != null) {
    mCurrentPrimaryItem.setMenuVisibility(false);
    mCurrentPrimaryItem.setUserVisibleHint(false);
   }
   if (fragment != null) {
    fragment.setMenuVisibility(true);
    fragment.setUserVisibleHint(true);
   }
   mCurrentPrimaryItem = fragment;
  }
 }

 @Override
 public void finishUpdate(ViewGroup container) {
  if (mCurTransaction != null) {
   mCurTransaction.commitAllowingStateLoss();
   mCurTransaction = null;
   mFragmentManager.executePendingTransactions();
  
} 
 public void setMenuVisibility(boolean menuVisible) {
        super.setMenuVisibility(menuVisible);
        if (this.getView() != null)
            this.getView().setVisibility(menuVisible ? View.VISIBLE : View.GONE);
    } }

FragmentPagerAdapter是support包自带的类。

四、注意

  之前自己模拟ViewPager用attach、setMenuVisibility、setUserVisibleHint来控制Fragment的显示隐藏,经常会出现Fragment重叠现象,非常头疼,换了这个之后目前没有发现重叠现象。

 结束:以上就是对Android Fragment 实例说明,希望能帮助有需要的同学。

 类似资料:
  • 本文向大家介绍Vue中保存用户登录状态实例代码,包括了Vue中保存用户登录状态实例代码的使用技巧和注意事项,需要的朋友参考一下 首先我们假设,这里的登录组件(register.vue)是App.vue组件的子组件,是通过路由进入登录组件的。 登录组件中用户点击登录后,后台会传过来一个用户名,我的App.vue组件中需要拿到这个用户名,并将上面的“登录注册”字样变为“用户名”。 为了保证用户刷新后用

  • 我正在尝试在我的应用程序中启用黑夜模式,虽然它正在工作,但当我重新启动应用程序时,它会再次变为亮模式。基本上,我想保存黑夜模式状态,所以当重新启动应用程序时,它会在设置为暗模式后保持黑暗模式,而不是亮模式。我的相关代码如下: 我也尝试了这个活动,但它并没有保存黑暗模式的状态。

  • 本文向大家介绍Android fragment实现多个页面切换效果,包括了Android fragment实现多个页面切换效果的使用技巧和注意事项,需要的朋友参考一下 现在的APP首页大部分屏幕的下方显示一行Tab标签选项,点击不同的标签就可以切换到不同的界面。如下图: 我们之前都是用TabHost来实现,但是殊不知,TabHost并非是那么的简单,它的可扩展性非常的差,不能随意地定制Tab项显示

  • 本文向大家介绍Android Fragment动态创建详解及示例代码,包括了Android Fragment动态创建详解及示例代码的使用技巧和注意事项,需要的朋友参考一下 Android Fragment 动态创建 Fragment是activity的界面中的一部分或一种行为。可以把多个Fragment组合到一个activity中来创建一个多界面并且可以在多个activity中重用一个Fragme

  • 我搜索了很多信息,但没有一个明确的。有人能给出一个明确的解决方案和一个例子吗?

  • 所以,我有一个按钮,在黑暗和光明模式之间切换(我的网站默认是黑暗的),它可以工作,但现在我需要它保持在任何切换状态,在多个页面选择。我怀疑这和会话存储有关。也不想使用jQuery。我可以在代码中添加什么来实现这一点呢? 我有五个页面都链接到了id为“dark”的styles.css,然后在JS中我引用了第二个样式表light.css或JS中的“light”,所以我要切换样式表。所有五个页面的页脚都