gpt4 book ai didi

java - 无法从抽屉导航中的 Fragment/FragmentActivity 打开 FragmentActivity

转载 作者:行者123 更新时间:2023-12-01 13:36:20 25 4
gpt4 key购买 nike

我遇到了一个无法用应用程序的抽屉导航解决的问题。抽屉导航中的链接之一是打开 FragmentActivity(其中包含 ViewPager)。其他链接是 fragment 。现在我已将其设置为启动该 Activity 的 Intent ,但我收到有关我的 fragment 之一 MapsPage 的错误。与嵌套 fragment 有关。我将在下面发布 logcat。这就是我的 NavigationDrawer onClick 的设置:

@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 中有一个 map fragment ,这会导致调用此 fragment 时出现异常。这是异常(exception)情况:

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 的另一个 fragment

我可以采取什么措施来防止这种情况发生吗?我需要能够从抽屉导航打开 FragmentActivity 而无需强制关闭,因为它与 Google map 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>

最佳答案

您正在调用

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

在调用startActivity()之后

关于java - 无法从抽屉导航中的 Fragment/FragmentActivity 打开 FragmentActivity,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21241963/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com