I am trying to get a map from SupportMapFragment but it returns null. From what I read, this may be due to the fact that the fragment is not yet fully displayed, and therefore the map does not exist ?! I tried to fix it with executePendingTransactions (), but have not yet succeeded.
Any ideas how to fix this?
Here is the code
private GoogleMap map; private SupportMapFragment mapFragment; @Override public void onCreate( Bundle savedInstanceState ) { //... super.onCreate( savedInstanceState ); setContentView( R.layout.screen_mission2 ); GoogleMapOptions mapOptions = new GoogleMapOptions(); mapOptions.mapType(GoogleMap.MAP_TYPE_NORMAL) .compassEnabled(true) .rotateGesturesEnabled(false) .tiltGesturesEnabled(false); android.support.v4.app.FragmentManager myFragmentManager = getSupportFragmentManager(); android.support.v4.app.FragmentManager.enableDebugLogging(true); mapFragment = SupportMapFragment.newInstance(mapOptions); FragmentTransaction fragmentTransaction = myFragmentManager.beginTransaction(); fragmentTransaction.add(R.id.mapFragment, mapFragment); fragmentTransaction.commit(); myFragmentManager.executePendingTransactions(); if(mapFragment == null) Base.log("mapFragment==null"); if(map==null){ map = mapFragment.getMap(); Base.log("map should have been initialized"); if(map==null) Base.log("map still null"); } }
And the layout file:
<fragment android:id="@+id/mapFragment" android:name="com.google.android.gms.maps.SupportMapFragment" android:layout_width="match_parent" android:layout_height="match_parent" />
It returns the next log
V/FragmentManager(24224): add: SupportMapFragment{4078c4b8 id=0x7f06003d} V/FragmentManager(24224): Allocated fragment index SupportMapFragment{4078c4b8
source share