2013-10-18 18 views
9

ターゲットSDK 4.3でコンパイルされ、実行されているAndroid Appに関する問題があります。アプリケーションには2つのアクティビティがあり、メインアクティビティはLauncherアクティビティとSecondActivityです。どちらもフラグメントを使用しています。古いデバイスもサポートするために、サポートlibが使用されています。java.lang.IllegalStateException:フラグメントが既に追加されている

次のシナリオでは、「IllegalStateException:Fragment already added」エラーが発生します。アプリを起動し

1)は - > MainActivityは意図
3)ホームボタンを押し
4)24時間でテストに長い時間()
5を待ってSecondActivityに
2)スイッチを示しています)再度アプリアイコン→例外を押してください。時間が短い場合、SecondActivityは期待どおりに表示されます。

フラグメント処理中に多くのIllegalStateExceptionsを読んでいますが、すべてがすべてreplace()メソッドの問題を指摘していました。 Stacktraceでは、自分のコードは決して呼び出されません。

FragementがActiviesのonCreate(に追加された)方法:

protected void onCreate(Bundle savedInstanceState) { 
    super.onCreate(savedInstanceState); 
    setContentView(..); 
    ListFragment listFragment = this.getCaptureListFragment(); 
    FragmentTransaction tx = this.getSupportFragmentManager().beginTransaction(); 
    tx.add(R.id.MainFragmentContainer, listFragment, "list_fragment_tag"); 
    tx.commit(); 
} 

private ListFragment getListFragment() { 
    ListFragment listFragment = (ListFragment) this.getSupportFragmentManager().findFragmentByTag("list_fragment_tag"); 
    if (listFragment == null) { 
     listFragment = new ListFragment(); 
    } 
    return listFragment; 
} 


java.lang.RuntimeException: Unable to start activity ComponentInfo{de.myexample.demo/de.myexample.demo.ui.SecondActivity}: java.lang.IllegalStateException: Fragment already added: ListFragment{42283f58 #0 id=0x7f060094 de.myexample.demo.ui.ListFragment} 
    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2211) 
    at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2261) 
    at android.app.ActivityThread.access$600(ActivityThread.java:141) 
    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1256) 
    at android.os.Handler.dispatchMessage(Handler.java:99) 
    at android.os.Looper.loop(Looper.java:137) 
    at android.app.ActivityThread.main(ActivityThread.java:5103) 
    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) 
Caused by: java.lang.IllegalStateException: Fragment already added: ListFragment{42283f58 #0 id=0x7f060094 de.myexample.demo.ui.ListFragment} 
    at android.support.v4.app.FragmentManagerImpl.addFragment(SourceFile:1175) 
    at android.support.v4.app.BackStackRecord.run(SourceFile:616) 
    at android.support.v4.app.FragmentManagerImpl.execPendingActions(SourceFile:1460) 
    at android.support.v4.app.FragmentActivity.onStart(SourceFile:556) 
    at android.app.Instrumentation.callActivityOnStart(Instrumentation.java:1171) 
    at android.app.Activity.performStart(Activity.java:5143) 
    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2184) 
    ... 11 more 
java.lang.IllegalStateException: Fragment already added: ListFragment{42283f58 #0 id=0x7f060094 de.myexample.demo.ui.ListFragment} 
    at android.support.v4.app.FragmentManagerImpl.addFragment(SourceFile:1175) 
    at android.support.v4.app.BackStackRecord.run(SourceFile:616) 
    at android.support.v4.app.FragmentManagerImpl.execPendingActions(SourceFile:1460) 
    at android.support.v4.app.FragmentActivity.onStart(SourceFile:556) 
    at android.app.Instrumentation.callActivityOnStart(Instrumentation.java:1171) 
    at android.app.Activity.performStart(Activity.java:5143) 
    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2184) 
    at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2261) 
    at android.app.ActivityThread.access$600(ActivityThread.java:141) 
    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1256) 
    at android.os.Handler.dispatchMessage(Handler.java:99) 
    at android.os.Looper.loop(Looper.java:137) 
    at android.app.ActivityThread.main(ActivityThread.java:5103) 
    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

を? – Raghunandan

+0

tx.replace(R.id.MainFragmentContainer、listFragment)を使用してみてください。 tx.add()メソッドを使用する代わりに.Read [this](http://developer.android.com/guide/components/fragments.html)。フラグメントの詳細については –

+0

ありがとう@Raghunandan。私は記事に欠けている行を追加しました。 – creaity

答えて

12

オーケーは、自分自身でで解決しました。

すべてのフラグメントをonPause()に入れて、いくつかのブール値に状態を格納します。そのブール値に応じて、フラグメントはonResume()に入れられます。アクティビティがバックグラウンドにどれくらいかかっていたかに関係なく、起動は安定しています。

boolean addList = false; 

@Override 
protected void onResume() { 
    FragmentTransaction tx = this.getSupportFragmentManager().beginTransaction(); 
    if (this.addList) { 
     ListFragment list = this.getListFragment(); 
     tx.add(R.id.MainFragmentContainer, list, "list_fragment_tag"); 
    } 

    tx.commit(); 
    super.onResume(); 

    this.addList = false; 

} 

@Override 
protected void onPause() { 
    this.addList = this.getListFragment().isAdded(); 
    ... 
    if (this.addList) { 
     FragmentTransaction tx = this.getSupportFragmentManager().beginTransaction(); 
     tx.remove(this.getListFragment()); 
     tx.commit(); 
    } 
    this.getSupportFragmentManager().executePendingTransactions(); 
    super.onPause(); 

} 

たぶん、同じ問題を持つ人を助けること

0

フラグメントマネージャはその状態と、終了を保存します。したがって、フラグメントを再度追加する必要はありません。

は次のように実行します。 - >開発者向けオプションこれを再現するために

protected void onCreate(Bundle savedInstanceState) { 
    super.onCreate(savedInstanceState); 
    setContentView(..); 

    if (savedInstanceState == null) { 
     ListFragment listFragment = this.getCaptureListFragment(); 
     FragmentTransaction tx = this.getSupportFragmentManager().beginTransaction(); 
     tx.add(R.id.MainFragmentContainer, listFragment, "list_fragment_tag"); 
     tx.commit(); 
    } 
} 
+0

答えをありがとう。それは助けられましたが、完全ではありませんでした。 Android 4.1の場合、それはトリックです。しかし、4.4のKitKatデバイスでは、アクティビティは空であり、フラグメントは見られません。しかし、このように、手動で取り除くよりもはるかに優れているように見えます。たぶん、ifの中の新しいデバイスで手動でフラグメントを削除することができます。もっとテストをしなければなりません。しかし、私はそれが問題になる前に少なくとも24時間待たなければならないので、彼らは非常に時間がかかります – creaity

8

、1は設定で「活動を保管しないでください」活性化できます。その後、アクティビティを一時停止してから再開します。あなたはフラグメントの追加の状態をチェックするための新しいブール型フィールドを作成する必要はありません:)

+0

それは私のために働いていません:( –

-3

24時間を待つ必要はありませんです

。断片化されたメソッドもあります。 ちょうどそれを使用します。アクティビティあちこちsetContentViewさ myFragment.isAdded()

+0

ブール値は、フラグメントの状態を格納するために追加されています(私のonPause()メソッドを参照してください) – creaity

+1

はい、私はもっと注意深く読んでいます。申し訳ありませんが、あなたは正しいです。 – serefakyuz

関連する問題