2014-01-20 63 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并标记为答案。 –