【问题标题】:Android: InflateException when swiping with Google Maps v2Android:使用 Google Maps v2 滑动时出现 InflateException
【发布时间】:2013-10-29 17:02:18
【问题描述】:

我在滑动到 fragment_right 然后 返回 到 fragment_middle 时遇到问题。如果我只从 fragment_middle 向 fragment_left 滑动,反之亦然,一切正常。

我将 FragmentActivity 和 ViewPager 与 ViewPagerAdapter 一起使用。 到目前为止,我有三个 Fragment。

fragment_left 片段中间 fragment_right

fragment_left 的 Google 地图视图如下:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:id="@+id/fragment_left"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical"
    android:background="@color/color_lime" >

    <RelativeLayout
        android:id="@+id/map_map"
        android:name="com.google.android.gms.maps.MapFragment"
        android:layout_width="match_parent"
        android:layout_height="0dp"
        android:layout_weight="3"
        android:background="@color/color_red" >

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

    <RelativeLayout
        android:id="@+id/map_chat"
        android:layout_width="match_parent"
        android:layout_height="0dp"
        android:layout_weight="1"
        android:background="@color/color_white" >

        <TextView
            android:id="@+id/map_tv_stupid_info"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:padding="16dp"
            android:text="fragment left"
            android:textSize="18sp" />
    </RelativeLayout>

</LinearLayout>

这是我的 FragmentLeft 类:

package com.example.worldfriends;
import android.content.Context;
import android.os.Bundle;
import android.support.v4.app.Fragment;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;

public class FragmentLeft extends Fragment {

    public static Fragment newInstance(Context context) {
        FragmentLeft fragment = new FragmentLeft();

        return fragment;
    }

    @Override
    public View onCreateView(LayoutInflater inflater, ViewGroup container,Bundle savedInstanceState) {
        ViewGroup view = (ViewGroup) inflater.inflate(R.layout.fragment_left, null);
        return view;
    }

}

这是我的 ViewPagerAdapter:

package com.example.worldfriends;

import android.content.Context;
import android.support.v4.app.Fragment;
import android.support.v4.app.FragmentManager;
import android.support.v4.app.FragmentPagerAdapter;

public class ViewPagerAdapter extends FragmentPagerAdapter {

    private Context context;
    private static int totalPage=3;
    private int currentItem=1;

    public ViewPagerAdapter(Context context, FragmentManager fm) {
        super(fm);
        this.context=context;
    }

    @Override
    public Fragment getItem(int position) {
        Fragment fragment = new Fragment();
        switch(position){
        case 0:
            fragment=FragmentLeft.newInstance(context);
            break;
        case 1:
            fragment=FragmentMiddle.newInstance(context);
            break;
        case 2:
            fragment=FragmentRight.newInstance(context);
            break;
        }
        return fragment;
    }

    @Override
    public int getCount() {
        return totalPage;
    }

    public int getCurrentItem() {
        return currentItem;
    }

}

如您所见,这是非常基本的。最后但并非最不重要的一点是堆栈跟踪!

10-29 17:52:09.951: W/dalvikvm(26552): threadid=1: thread exiting with uncaught exception (group=0x41985700)
10-29 17:52:09.975: E/AndroidRuntime(26552): FATAL EXCEPTION: main
10-29 17:52:09.975: E/AndroidRuntime(26552): android.view.InflateException: Binary XML file line #18: Error inflating class fragment
10-29 17:52:09.975: E/AndroidRuntime(26552):    at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:713)
10-29 17:52:09.975: E/AndroidRuntime(26552):    at android.view.LayoutInflater.rInflate(LayoutInflater.java:755)
10-29 17:52:09.975: E/AndroidRuntime(26552):    at android.view.LayoutInflater.rInflate(LayoutInflater.java:758)
10-29 17:52:09.975: E/AndroidRuntime(26552):    at android.view.LayoutInflater.inflate(LayoutInflater.java:492)
10-29 17:52:09.975: E/AndroidRuntime(26552):    at android.view.LayoutInflater.inflate(LayoutInflater.java:397)
10-29 17:52:09.975: E/AndroidRuntime(26552):    at android.view.LayoutInflater.inflate(LayoutInflater.java:353)
10-29 17:52:09.975: E/AndroidRuntime(26552):    at com.example.worldfriends.FragmentLeft.onCreateView(FragmentLeft.java:20)
10-29 17:52:09.975: E/AndroidRuntime(26552):    at android.support.v4.app.Fragment.performCreateView(Fragment.java:1478)
10-29 17:52:09.975: E/AndroidRuntime(26552):    at android.support.v4.app.FragmentManagerImpl.moveToState(FragmentManager.java:927)
10-29 17:52:09.975: E/AndroidRuntime(26552):    at android.support.v4.app.FragmentManagerImpl.attachFragment(FragmentManager.java:1280)
10-29 17:52:09.975: E/AndroidRuntime(26552):    at android.support.v4.app.BackStackRecord.run(BackStackRecord.java:672)
10-29 17:52:09.975: E/AndroidRuntime(26552):    at android.support.v4.app.FragmentManagerImpl.execPendingActions(FragmentManager.java:1460)
10-29 17:52:09.975: E/AndroidRuntime(26552):    at android.support.v4.app.FragmentManagerImpl.executePendingTransactions(FragmentManager.java:472)
10-29 17:52:09.975: E/AndroidRuntime(26552):    at android.support.v4.app.FragmentPagerAdapter.finishUpdate(FragmentPagerAdapter.java:141)
10-29 17:52:09.975: E/AndroidRuntime(26552):    at android.support.v4.view.ViewPager.populate(ViewPager.java:1068)
10-29 17:52:09.975: E/AndroidRuntime(26552):    at android.support.v4.view.ViewPager.populate(ViewPager.java:914)
10-29 17:52:09.975: E/AndroidRuntime(26552):    at android.support.v4.view.ViewPager$3.run(ViewPager.java:244)
10-29 17:52:09.975: E/AndroidRuntime(26552):    at android.view.Choreographer$CallbackRecord.run(Choreographer.java:749)
10-29 17:52:09.975: E/AndroidRuntime(26552):    at android.view.Choreographer.doCallbacks(Choreographer.java:562)
10-29 17:52:09.975: E/AndroidRuntime(26552):    at android.view.Choreographer.doFrame(Choreographer.java:531)
10-29 17:52:09.975: E/AndroidRuntime(26552):    at android.view.Choreographer$FrameDisplayEventReceiver.run(Choreographer.java:735)
10-29 17:52:09.975: E/AndroidRuntime(26552):    at android.os.Handler.handleCallback(Handler.java:730)
10-29 17:52:09.975: E/AndroidRuntime(26552):    at android.os.Handler.dispatchMessage(Handler.java:92)
10-29 17:52:09.975: E/AndroidRuntime(26552):    at android.os.Looper.loop(Looper.java:137)
10-29 17:52:09.975: E/AndroidRuntime(26552):    at android.app.ActivityThread.main(ActivityThread.java:5103)
10-29 17:52:09.975: E/AndroidRuntime(26552):    at java.lang.reflect.Method.invokeNative(Native Method)
10-29 17:52:09.975: E/AndroidRuntime(26552):    at java.lang.reflect.Method.invoke(Method.java:525)
10-29 17:52:09.975: E/AndroidRuntime(26552):    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:737)
10-29 17:52:09.975: E/AndroidRuntime(26552):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:553)
10-29 17:52:09.975: E/AndroidRuntime(26552):    at dalvik.system.NativeStart.main(Native Method)
10-29 17:52:09.975: E/AndroidRuntime(26552): Caused by: java.lang.IllegalArgumentException: Binary XML file line #18: Duplicate id 0x7f060008, tag null, or parent id 0x0 with another fragment for com.google.android.gms.maps.SupportMapFragment
10-29 17:52:09.975: E/AndroidRuntime(26552):    at android.support.v4.app.FragmentActivity.onCreateView(FragmentActivity.java:290)
10-29 17:52:09.975: E/AndroidRuntime(26552):    at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:685)
10-29 17:52:09.975: E/AndroidRuntime(26552):    ... 29 more
10-29 17:52:11.569: I/Process(26552): Sending signal. PID: 26552 SIG: 9

【问题讨论】:

    标签: android swipe google-maps-api-2 inflate-exception


    【解决方案1】:

    原因:java.lang.IllegalArgumentException:二进制 XML 文件第 18 行:重复 id 0x7f060008、标签 null 或父 id 0x0 与 com.google.android.gms.maps.SupportMapFragment 的另一个片段

    是你的问题。

    这意味着您错误地创建了嵌套片段。读取official documentation:不允许使用xml,在代码中创建SupportMapFragment

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2013-03-24
      • 1970-01-01
      • 1970-01-01
      • 2014-02-16
      相关资源
      最近更新 更多