2014-01-20 67 views
0

我遇到了一個問題,我無法用我的應用的導航抽屜來解決問題。導航抽屜中的一個鏈接是打開一個FragmentActivity(其中包含一個ViewPager)。其他鏈接是碎片。現在我將它設置爲啓動該活動的意圖,但我得到關於我的碎片之一的一個錯誤,MapsPage。與嵌套碎片有關。我會發佈下面的logcat。這是現在我的NavigationDrawer onClick設置:無法從導航抽屜中的Fragment/FragmentActivity打開FragmentActivity

@Override 
public void onItemClick(AdapterView<?> adapterView, View view, int i, long l) { 

      Fragment newFragment = new MapsPage(); 
      FragmentManager fm = getSupportFragmentManager(); 
      switch(i) { 
      case 0: 
       newFragment = new FragOne(); 
       fm.popBackStack(); 
       break; 
      case 1: 
       newFragment = new FragTwo(); 
       fm.popBackStack(); 
       break; 
      case 2: 
       newFragment = new FragThree(); 
       fm.popBackStack(); 
       break; 
      case 3: 
       Intent in = new Intent(getApplicationContext(), FragmentPagerActivity.class); 
       startActivity(in); 
       fm.popBackStack(); 
       break; 
      } 
      fm.beginTransaction().add(R.id.main, newFragment).addToBackStack("fragback").commit(); 
      drawerLayout.closeDrawer(rl); 
} 

我的問題是與「情況3:」。 MapsPage是我的應用程序的核心,它在XML中有一個映射片段,當調用它時會導致異常。這裏是例外:

01-20 18:42:09.302: E/AndroidRuntime(15950): FATAL EXCEPTION: main 
01-20 18:42:09.302: E/AndroidRuntime(15950): Process: com.android.package.name, PID: 15950 
01-20 18:42:09.302: E/AndroidRuntime(15950): android.view.InflateException: Binary XML file line #7: Error inflating class fragment 
01-20 18:42:09.302: E/AndroidRuntime(15950): at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:713) 
01-20 18:42:09.302: E/AndroidRuntime(15950): at android.view.LayoutInflater.rInflate(LayoutInflater.java:755) 
01-20 18:42:09.302: E/AndroidRuntime(15950): at android.view.LayoutInflater.inflate(LayoutInflater.java:492) 
01-20 18:42:09.302: E/AndroidRuntime(15950): at android.view.LayoutInflater.inflate(LayoutInflater.java:397) 
01-20 18:42:09.302: E/AndroidRuntime(15950): at com.mdev.bluestorm.drinki.MapsPage.onCreateView(MapsPage.java:103) 
01-20 18:42:09.302: E/AndroidRuntime(15950): at android.support.v4.app.Fragment.performCreateView(Fragment.java:1500) 
01-20 18:42:09.302: E/AndroidRuntime(15950): at android.support.v4.app.FragmentManagerImpl.moveToState(FragmentManager.java:927) 
01-20 18:42:09.302: E/AndroidRuntime(15950): at android.support.v4.app.FragmentManagerImpl.moveToState(FragmentManager.java:1104) 
01-20 18:42:09.302: E/AndroidRuntime(15950): at android.support.v4.app.BackStackRecord.run(BackStackRecord.java:682) 
01-20 18:42:09.302: E/AndroidRuntime(15950): at android.support.v4.app.FragmentManagerImpl.execPendingActions(FragmentManager.java:1467) 
01-20 18:42:09.302: E/AndroidRuntime(15950): at android.support.v4.app.FragmentManagerImpl$1.run(FragmentManager.java:440) 
01-20 18:42:09.302: E/AndroidRuntime(15950): at android.os.Handler.handleCallback(Handler.java:733) 
01-20 18:42:09.302: E/AndroidRuntime(15950): at android.os.Handler.dispatchMessage(Handler.java:95) 
01-20 18:42:09.302: E/AndroidRuntime(15950): at android.os.Looper.loop(Looper.java:136) 
01-20 18:42:09.302: E/AndroidRuntime(15950): at android.app.ActivityThread.main(ActivityThread.java:5017) 
01-20 18:42:09.302: E/AndroidRuntime(15950): at java.lang.reflect.Method.invokeNative(Native Method) 
01-20 18:42:09.302: E/AndroidRuntime(15950): at java.lang.reflect.Method.invoke(Method.java:515) 
01-20 18:42:09.302: E/AndroidRuntime(15950): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:779) 
01-20 18:42:09.302: E/AndroidRuntime(15950): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:595) 
01-20 18:42:09.302: E/AndroidRuntime(15950): at dalvik.system.NativeStart.main(Native Method) 
01-20 18:42:09.302: E/AndroidRuntime(15950): Caused by: java.lang.IllegalArgumentException: Binary XML file line #7: Duplicate id 0x7f060060, tag null, or parent id 0x0 with another fragment for com.google.android.gms.maps.SupportMapFragment 
01-20 18:42:09.302: E/AndroidRuntime(15950): at android.support.v4.app.FragmentActivity.onCreateView(FragmentActivity.java:296) 
01-20 18:42:09.302: E/AndroidRuntime(15950): at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:685) 

這是關鍵錯誤:

01-20 18:42:09.302:E/AndroidRuntime(15950):java.lang.IllegalArgumentException異常:致二進制XML文件行#7:重複id 0x7f060060,標記null或父母id 0x0與com.google.android.gms.maps.SupportMapFragment的另一個片段

有什麼我可以做的,以防止這種情況?我需要能夠從導航抽屜中打開FragmentActivity,而不必關閉這個力量,因爲它與Google maps Fragment衝突。我需要將MapsPage作爲後臺的一部分,實際上是唯一一個,因爲您可以看到我正在爲其他頁面彈出後臺堆棧。

我真的很感謝這方面的一些幫助,我迷失在接下來要做的事上。提前致謝。

編輯:

<?xml version="1.0" encoding="utf-8"?> 
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" 
xmlns:map="http://schemas.android.com/apk/res-auto" 
android:layout_width="match_parent" 
android:layout_height="match_parent"> 

<fragment 
    android:id="@+id/map" 
    android:layout_width="match_parent" 
    android:layout_height="match_parent" 
    class="com.google.android.gms.maps.SupportMapFragment"/> 
</RelativeLayout> 
+0

後請發表所引用的XML文件。 – PearsonArtPhoto

+0

使用添加到底部的MapsPage片段的XML編輯我的問題。 –

回答

1

要調用

fm.beginTransaction().add(R.id.main,newFragment).addToBackStack("fragback").commit(); 

你叫startActivity()

+0

你是在談論我試圖打開的MapsPage或FragmentActivity?我有地圖部分的方式運作良好,這就是爲什麼我有點擔心要改變它。 –

+0

啊我明白了。我通過評論fm.beginTransaction和Intent的工作來測試它。所以我只需要爲其他片段調用fm.beginTransaction。 –

+0

謝謝。我得到了它的工作。 +1並標記爲答案。 –