简体   繁体   中英

onResume called before onMapReady

I have a fragment(fragment_search) in which I want add another fragment(map_fragment) programmatically, but I'm running into an issue, where tab_content.onResume() is called BEFORE OnMapReadyCallback.onMapReady().

Here's the code:

fragment_search.xml :

<LinearLayout...>
    <FrameLayout
            android:id="@+id/search_map_fragment_container"
            android:layout_width="match_parent"
            android:layout_height="match_parent">

        </FrameLayout>
</LinearLayout>

some_layout.xml:

<?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:layout_width="match_parent"
    android:layout_height="match_parent">

    <com.google.android.gms.maps.MapView android:id="@+id/mapview"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:clickable="true"
    android:enabled="true"
    android:apiKey="api key" />

</LinearLayout>

SearchFragment.class (nothing else in this class really):

@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container,
                         Bundle savedInstanceState) {
    View view = inflater.inflate(R.layout.fragment_search, container, false);
    FragmentManager fragmentManager = getFragmentManager();
    final FragmentTransaction fragmentTransaction = fragmentManager.beginTransaction();

    final SomeFragment fragment = new SomeFragment();

    OnMapReadyCallback onMapReadyCallback = new OnMapReadyCallback() {
        @Override
        public void onMapReady(GoogleMap googleMap) {
            fragment.setMap(googleMap);

            fragmentTransaction.add(R.id.search_map_fragment_container, fragment);
            fragmentTransaction.commit();
        }
    };
    fragment.getMapAsync(onMapReadyCallback);
    return view;
}

SomeFragment.class :

public class SomeFragment extends SupportMapFragment {
    MapView mapView;
    GoogleMap map;
    private MapView mMapView;
    private GoogleMap mGoogleMap;

    @Override
    public View onCreateView(LayoutInflater inflater, ViewGroup container,
                             Bundle savedInstanceState) {
        View v = inflater.inflate(R.layout.some_layout, container, false);

        mMapView = (MapView) v.findViewById(R.id.mapview);
        mMapView.onCreate(savedInstanceState);

        return v;
    }

    public void setMap(GoogleMap map){
        this.mGoogleMap=map;
    }
...}

Stack trace :

java.lang.NullPointerException: Attempt to invoke interface method 'void maps.ei.bz.o()'  on a null object reference
                                                                  at maps.ei.n.b(Unknown Source)
                                                                  at com.google.android.gms.maps.internal.i$a.onTransact(:com.google.android.gms.alldynamite:115)
                                                                  at android.os.Binder.transact(Binder.java:387)
                                                                  at com.google.android.gms.maps.internal.IMapFragmentDelegate$zza$zza.onResume(Unknown Source)
                                                                  at com.google.android.gms.maps.SupportMapFragment$zza.onResume(Unknown Source)
                                                                  at com.google.android.gms.dynamic.zza$7.zzb(Unknown Source)
                                                                  at com.google.android.gms.dynamic.zza.zza(Unknown Source)
                                                                  at com.google.android.gms.dynamic.zza.onResume(Unknown Source)
                                                                  at com.google.android.gms.maps.SupportMapFragment.onResume(Unknown Source)
                                                                  at com.beermeet.ui.search.SearchFragment.onResume(SearchFragment.java:5

7)

I think the SearchFragment.onCreateView is wrong, but i don't know what is the correct way of doing it. Any hints as to what i'm doing wrong? Thanks!

When you launch SearchFragment , it will apparently call its onResume() method as a part of the fragment lifecycle. Your logs say there is a NullPointerException in onResume() . You should check for that.

And regarding your question,

fragment.getMapAsync(onMapReadyCallback);

onResume() will be invoked before you get onMapReadyCallback because getMapAsync() is async call and will run in a different thread which will not block UI thread and hence onResume() will get invoked before you get onMapReadyCallback

The technical post webpages of this site follow the CC BY-SA 4.0 protocol. If you need to reprint, please indicate the site URL or the original address.Any question please contact:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM