Android 保存Fragment 切換狀態(tài)實(shí)例代碼
前言
一般頻繁切換Fragment會(huì)導(dǎo)致頻繁的釋放和創(chuàng)建,如果Fragment比較臃腫體驗(yàn)就非常不好了,這里分享一個(gè)方法。
正文
一、應(yīng)用場(chǎng)景
1、不使用ViewPager
2、不能用replace來切換Fragment,會(huì)導(dǎo)致Fragment釋放(調(diào)用onDestroyView)
二、實(shí)現(xiàn)
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個(gè)RadioButton,點(diǎn)擊切換不同的Fragment。
2、Activity
為RadioButton設(shè)置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新建一個(gè),setPrimaryItem設(shè)置隱藏和顯示,最后finishUpdate提交事務(wù), 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的顯示隱藏,經(jīng)常會(huì)出現(xiàn)Fragment重疊現(xiàn)象,非常頭疼,換了這個(gè)之后目前沒有發(fā)現(xiàn)重疊現(xiàn)象。
結(jié)束:以上就是對(duì)Android Fragment 實(shí)例說明,希望能幫助有需要的同學(xué)。
- Android中Fragment相互切換間不被回收的實(shí)現(xiàn)方法
- Android-實(shí)現(xiàn)切換Fragment頁功能的實(shí)現(xiàn)代碼
- 一個(gè)Activity中多個(gè)Fragment的切換
- Android UI實(shí)現(xiàn)底部切換標(biāo)簽fragment
- Android App中使用ViewPager+Fragment實(shí)現(xiàn)滑動(dòng)切換效果
- Android中使用TabHost 與 Fragment 制作頁面切換效果
- Android使用Fragment打造萬能頁面切換框架
- Android Fragment中使用SurfaceView切換時(shí)閃一下黑屏的解決辦法
- Android基礎(chǔ)之使用Fragment控制切換多個(gè)頁面
- anndroid使用ViewPager實(shí)現(xiàn)三個(gè)fragment切換
相關(guān)文章
Android自定義View葉子旋轉(zhuǎn)完整版(六)
這篇文章主要為大家詳細(xì)介紹了Android自定義View葉子旋轉(zhuǎn)完整版,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-03-03
Android開發(fā)中類加載器DexClassLoader的簡(jiǎn)單使用講解
這篇文章主要介紹了Android開發(fā)中類加載器DexClassLoader的簡(jiǎn)單使用講解,DexClassLoader可以看作是一個(gè)特殊的Java中的ClassLoader,需要的朋友可以參考下2016-04-04
Flutter 包管理器和資源管理使用學(xué)習(xí)
這篇文章主要為大家介紹了Flutter 包管理器和資源管理使用學(xué)習(xí),有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-12-12
直接可用的Android studio學(xué)生信息管理系統(tǒng)
這篇文章主要為大家詳細(xì)介紹了直接可用的Android studio學(xué)生信息管理系統(tǒng),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-01-01
Android自定義ScrollView實(shí)現(xiàn)放大回彈效果實(shí)例代碼
本篇文章主要介紹了Android自定義ScrollView實(shí)現(xiàn)放大回彈效果實(shí)例代碼,具有一定的參考價(jià)值,有興趣的可以了解一下。2017-03-03

