2015-09-29 30 views
5

MainActivity zawiera FragmentTabHost, a do FragmentTabHost dodaje się pięć Fragmentów. Oto kod startowychjava.lang.IllegalStateException: Nie można wykonać tej akcji po parametrze onSaveInstanceState, FragmentTabHost

protected void onCreate(Bundle savedInstanceState) { 
     mFragmentManager = getSupportFragmentManager(); 
     mTabHost = (FragmentTabHost) findViewById(android.R.id.tabhost); 
     mTabHost.setup(this, mFragmentManager, android.R.id.tabcontent); 
     // Home 
     mTabHost.addTab(
       mTabHost.newTabSpec(TAB_TAG_HOME).setIndicator(
         newTabItem(R.drawable.mi_selector_tab_home, 
           R.string.mi_tab_item_milian)), 
       TabFateFragment.class, null); 

     // Serach 
     mTabHost.addTab(
       mTabHost.newTabSpec(TAB_TAG_SEARCH).setIndicator(
         newTabItem(R.drawable.mi_selector_tab_search, 
           R.string.mi_navi_title_search)), 
       TabSearchFragment.class, null); 

     // Msg 
     mTabHost.addTab(
       mTabHost.newTabSpec(TAB_TAG_MSG).setIndicator(
         newTabItem(R.drawable.mi_selector_tab_msg, 
           R.string.mi_navi_title_msg)), 
       TabMsgFragment.class, null); 

     // Nearby 
     mTabHost.addTab(
       mTabHost.newTabSpec(TAB_TAG_NEARBY).setIndicator(
         newTabItem(R.drawable.mi_selector_tab_nearby, 
           R.string.mi_navi_title_nearby)), 
       TabNearbyFragment.class, null); 

     // Me 
     mTabHost.addTab(
       mTabHost.newTabSpec(TAB_TAG_ME).setIndicator(
         newTabItem(R.drawable.mi_selector_tab_me, 
           R.string.mi_navi_title_me)), 
       TabMeFragment.class, null); 
     ...... 
} 

i czytałem ten article, nie znajduję FragmentTransaction # commit() w moim kodu.

i próbowałem niestawienie super.onSaveInstanceState (Bundle outState) w moim Activity.onSaveInstanceState (outState)

@Override 
    protected void onSaveInstanceState(Bundle outState) { 
     // super.onSaveInstanceState(outState); 
    } 

Oto dziennik krach

java.lang.IllegalStateException: Can not perform this action after onSaveInstanceState 
    at android.support.v4.app.FragmentManagerImpl.checkStateLoss(Unknown Source) 
    at android.support.v4.app.FragmentManagerImpl.enqueueAction(Unknown Source) 
    at android.support.v4.app.BackStackRecord.commitInternal(Unknown Source) 
    at android.support.v4.app.BackStackRecord.commit(Unknown Source) 
    at android.support.v4.app.FragmentTabHost.onAttachedToWindow(Unknown Source) 
    at android.view.View.dispatchAttachedToWindow(View.java:12134) 
    at android.view.ViewGroup.dispatchAttachedToWindow(ViewGroup.java:2453) 
    at android.view.ViewGroup.dispatchAttachedToWindow(ViewGroup.java:2460) 
    at android.view.ViewGroup.dispatchAttachedToWindow(ViewGroup.java:2460) 
    at android.view.ViewGroup.dispatchAttachedToWindow(ViewGroup.java:2460) 
    at android.view.ViewGroup.dispatchAttachedToWindow(ViewGroup.java:2460) 
    at android.view.ViewRootImpl.performTraversals(ViewRootImpl.java:1207) 
    at android.view.ViewRootImpl.doTraversal(ViewRootImpl.java:1004) 
    at android.view.ViewRootImpl$TraversalRunnable.run(ViewRootImpl.java:5483) 
    at android.view.Choreographer$CallbackRecord.run(Choreographer.java:778) 
    at android.view.Choreographer.doCallbacks(Choreographer.java:591) 
    at android.view.Choreographer.doFrame(Choreographer.java:561) 
    at android.view.Choreographer$FrameDisplayEventReceiver.run(Choreographer.java:764) 
    at android.os.Handler.handleCallback(Handler.java:730) 
    at android.os.Handler.dispatchMessage(Handler.java:92) 
    at android.os.Looper.loop(Looper.java:137) 
    at android.app.ActivityThread.main(ActivityThread.java:5109) 
    at java.lang.reflect.Method.invokeNative(Native Method) 
    at java.lang.reflect.Method.invoke(Method.java:525) 
    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:737) 
    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:553) 
    at dalvik.system.NativeStart.main(Native Method) 
+0

Czy powyższy kod jest wykonywany z poziomu działania onCreate() twojej działalności? Czy wywołujesz setup()? – logcat

+0

zapomniałem wkleić go w moim kodzie, mTabHost.setup (this, mFragmentManager, android.R.id.tabcontent); – Scorpiuszjj

+0

Mam ten sam problem. Czy masz jakieś rozwiązanie? – MobileAppDeveloper

Odpowiedz

3

The onSaveInstanceState m etykieta jest wywoływana zanim działanie zostanie wkrótce zniszczone, aby zapisać dane aktywności. Powoduje dodanie do niego fragmentu po zapisaniu danych. Rozwiązaniem jest zastąpienie metody commit() commitAllowingStateLoss(), a efekt Jest taki sam.

+0

, ale w moim kodzie nie ma fragmentu commitment commit() FragmentTransaction #. – Scorpiuszjj

+0

Możesz zrezygnować z używania FragmentTabHost, zamiast innej metody, podobnie jak moja nowa odpowiedź. – John

+0

Po prostu próbuję to rozgryźć, a nie po prostu wypróbować inną implementację. – Scorpiuszjj

-1

Korzystanie Framelayout:

<FrameLayout 

      android:id="@+id/tab_content" 

      android:layout_width="match_parent" 

      android:layout_height="match_parent" 

      android:layout_gravity="bottom" 

      android:orientation="vertical" /> 

i dodać metodę:

private synchronized void replaceFragment() { 



     FragmentTransaction fragmentTransaction = getSupportFragmentManager().beginTransaction(); 

     // Workaround for Issue 42601: 

     // https://code.google.com/p/android/issues/detail?id=42601 

     fragmentTransaction.detach(tabFragments[previousTabIdx]).replace(R.id.tab_content, tabFragments[curTabIdx]) 

       .attach(tabFragments[curTabIdx]).commitAllowingStateLoss(); 

     previousTabIdx = curTabIdx; 

    } 

następnie można użyć commitAllowingStateLoss metoda().