2013-10-29 2 views
0

을 V2. fragment_middle에서 fragment_left로만 스 와이프하면 모든 것이 작동합니다.안드로이드 : 구글지도와 함께 보내 주시면 InflateException는 <em>다시</em>이 fragment_middle하는 fragment_right 와이프 때이 문제가

은 내가 ViewPagerAdapter와 FragmentActivity 및 ViewPager를 사용하고 있습니다. 나는 지금 세 조각을 가지고있다.

: 이것은 내 ViewPagerAdapter입니다

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; 
    } 

} 

:

<?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 클래스입니다 :

fragment_left fragment_middle fragment_right

fragment_left는 Google지도 folloing로 볼 수있을 것이다 01 23,275,344,198,

당신이보다시피, 아주 기본입니다. 그리고 마지막으로 스택 추적!

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 

답변

1

에 의해 발생 : com.google.android.gms.maps의 또 다른 조각과 중복 아이디 0x7f060008, 태그 널 (null), 또는 부모 ID를 0x0으로 : java.lang.IllegalArgumentException가 : 바이너리 XML 파일 라인 # 18.

SupportMapFragment

가 문제입니다.

이 잘못 중첩 된 조각을 만드는 것을 의미합니다. official documentation을 읽으십시오. xml은 사용할 수 없으므로 코드에는 SupportMapFragment을 작성하십시오.