2013-03-02 217 views
1

我有一個應用程序,它內部我必須顯示一個片段(從v4 suppport庫)與地圖和裏面的位置。我使用的Play服務庫,和我創建幷包含一個支持地圖片段Android IllegalStateException與谷歌地圖api v2

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

我在我的應用程序的多個片段使用和FrameLayout中,我做出片段交易XML。

我已經定義的位置片段是這樣的:當我點擊了第一次激活位置片段按鈕

import android.os.Bundle; 
import android.support.v4.app.Fragment; 
import android.view.LayoutInflater; 
import android.view.View; 
import android.view.ViewGroup; 
import android.widget.RelativeLayout; 
import com.google.android.gms.maps.CameraUpdateFactory; 
import com.google.android.gms.maps.GoogleMap; 
import com.google.android.gms.maps.SupportMapFragment; 
import com.google.android.gms.maps.model.BitmapDescriptorFactory; 
import com.google.android.gms.maps.model.LatLng; 
import com.google.android.gms.maps.model.Marker; 
import com.google.android.gms.maps.model.MarkerOptions; 


public class LocationFragment extends Fragment{ 
    static final LatLng HAMBURG = new LatLng(53.558, 9.927); 
    static final LatLng KIEL = new LatLng(53.551, 9.993); 
    RelativeLayout rl; 
    private GoogleMap map=null; 
    @Override 
    public View onCreateView (LayoutInflater inflater, ViewGroup container, Bundle savedInstanceBundle) 
    { 
     if (map==null){ 
      rl = (RelativeLayout) inflater.inflate(R.layout.maps, container,false); 
      map = ((SupportMapFragment) getActivity().getSupportFragmentManager().findFragmentById(R.id.map)).getMap(); 
      Marker hamburg = map.addMarker(new MarkerOptions().position(HAMBURG) 
        .title("Hamburg")); 
      Marker kiel = map.addMarker(new MarkerOptions() 
        .position(KIEL) 
        .title("Pilates") 
        .snippet("Pilates teaching") 
        .icon(BitmapDescriptorFactory 
          .fromResource(R.drawable.ic_launcher))); 
      map.moveCamera(CameraUpdateFactory.newLatLngZoom(HAMBURG, 15)); 
      map.animateCamera(CameraUpdateFactory.zoomTo(10), 2000, null); 
     } 
     return rl; 
    } 

} 

一切工作正常。問題出現時,我點擊另一個片段,然後在這一個再次,我得到以下錯誤:

E/AndroidRuntime(30571): FATAL EXCEPTION: main 
E/AndroidRuntime(30571): java.lang.IllegalStateException: The specified child already has a parent. You must call removeView() on the child's parent first. 
E/AndroidRuntime(30571): at android.view.ViewGroup.addViewInner(ViewGroup.java:3620) 
E/AndroidRuntime(30571): at android.view.ViewGroup.addView(ViewGroup.java:3491) 
E/AndroidRuntime(30571): at android.view.ViewGroup.addView(ViewGroup.java:3436) 
E/AndroidRuntime(30571): at android.view.ViewGroup.addView(ViewGroup.java:3412) 
E/AndroidRuntime(30571): at android.support.v4.app.NoSaveStateFrameLayout.wrap(NoSaveStateFrameLayout.java:40) 
E/AndroidRuntime(30571): at android.support.v4.app.FragmentManagerImpl.moveToState(FragmentManager.java:915) 
E/AndroidRuntime(30571): at android.support.v4.app.FragmentManagerImpl.moveToState(FragmentManager.java:1088) 
E/AndroidRuntime(30571): at android.support.v4.app.BackStackRecord.run(BackStackRecord.java:682) 
E/AndroidRuntime(30571): at android.support.v4.app.FragmentManagerImpl.execPendingActions(FragmentManager.java:1444) 
E/AndroidRuntime(30571): at android.support.v4.app.FragmentManagerImpl$1.run(FragmentManager.java:429) 
E/AndroidRuntime(30571): at android.os.Handler.handleCallback(Handler.java:615) 
E/AndroidRuntime(30571): at android.os.Handler.dispatchMessage(Handler.java:92) 
E/AndroidRuntime(30571): at android.os.Looper.loop(Looper.java:137) 
E/AndroidRuntime(30571): at android.app.ActivityThread.main(ActivityThread.java:4921) 
E/AndroidRuntime(30571): at java.lang.reflect.Method.invokeNative(Native Method) 
E/AndroidRuntime(30571): at java.lang.reflect.Method.invoke(Method.java:511) 
E/AndroidRuntime(30571): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1027) 
E/AndroidRuntime(30571): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:794) 
E/AndroidRuntime(30571): at dalvik.system.NativeStart.main(Native Method) 
E/android.os.Debug(2143): [email protected] > dumpstate -k -t -z -d -o /data/log/dumpstate_app_error 

你能幫我嗎?

回答

0

試試這個:

rl = (RelativeLayout) inflater.inflate(R.layout.maps, null); 
+0

感謝您的回答,但它不工作。我得到相同的錯誤 – 2013-03-02 22:15:39

+0

你知道什麼確切的線是錯誤的來源嗎? – agamov 2013-03-02 22:19:51

+0

是的,你指出的線 – 2013-03-02 22:26:49