Google Map V2 crash when used in ViewPager fragment?-Collection of common programming errors

I have a problem where I’m trying to use Google Maps v2 in my Android app.

My plan is to have a viewpager with two pages (a “detail” page and a “googlemap” page)

I’ve set the whole thing up, and it’s giving me some weird results:

When I start swiping to the “googlemap” page, in the middle of the animation (like if I hold the viewpager halfway), I can see the map load up properly.It’s just there.

All the things I’ve set up (markers, camera, animation…) run as they are supposed to.

But as soon I complete the swipe, and the googlemap page takes over the entire screen, the whole thing crashes.

Any idea what could cause it?

Here is all the relevant code:

FragmentMap.xml




    


MapFragment.java

import android.os.Bundle;
import android.support.v4.app.Fragment;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;

import com.google.android.gms.maps.GoogleMap;
import com.google.android.gms.maps.SupportMapFragment;

public class MapFragment extends Fragment {

    private GoogleMap map;
    private static View view;

    @Override
    public View onCreateView(LayoutInflater inflater, ViewGroup container,Bundle savedInstanceState) {
        if (view != null) 
        {
            ViewGroup parent = (ViewGroup) view.getParent();
            if (parent != null)
                parent.removeView(view);
        }
        view = inflater.inflate(R.layout.fragment_map, container, false);
        map = ((SupportMapFragment) getFragmentManager().findFragmentById(R.id.map)).getMap();

        getActivity().getSupportFragmentManager().popBackStack();
        return view;

    }

    public static MapFragment newInstance() {
        MapFragment f = new MapFragment();
        return f;
    }
}

DetailActivity.java

import android.content.Intent;
import android.os.Bundle;
import android.support.v4.app.Fragment;
import android.support.v4.app.FragmentActivity;
import android.support.v4.app.FragmentManager;
import android.support.v4.app.FragmentPagerAdapter;
import android.support.v4.view.ViewPager;

public class DetailActivity extends FragmentActivity {

    int extraID;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_detail_holder);

        Intent prevIntent = getIntent();
        extraID = prevIntent.getIntExtra("selected_ID", 0);

        ViewPager pager = (ViewPager) findViewById(R.id.viewpager);
        pager.setAdapter(new MyPagerAdapter(getSupportFragmentManager()));
    }

    private class MyPagerAdapter extends FragmentPagerAdapter {

        public MyPagerAdapter(FragmentManager fm) {
            super(fm);
        }
        @Override
        public Fragment getItem(int pos) {
            switch (pos) {
            case 0:
                return DetailFragment.newInstance(extraID);
            case 1:
                return MapFragment.newInstance();
            default:
                return null;
            }
        }

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

detailHolder.xml



EDIT: logcat

09-28 13:41:42.830: E/AndroidRuntime(12693): FATAL EXCEPTION: main
09-28 13:41:42.830: E/AndroidRuntime(12693): java.lang.NullPointerException
09-28 13:41:42.830: E/AndroidRuntime(12693):    at android.support.v4.app.BackStackRecord.doAddOp(BackStackRecord.java:394)
09-28 13:41:42.830: E/AndroidRuntime(12693):    at android.support.v4.app.BackStackRecord.add(BackStackRecord.java:389)
09-28 13:41:42.830: E/AndroidRuntime(12693):    at android.support.v4.app.FragmentPagerAdapter.instantiateItem(FragmentPagerAdapter.java:99)
09-28 13:41:42.830: E/AndroidRuntime(12693):    at android.support.v4.view.ViewPager.addNewItem(ViewPager.java:832)
09-28 13:41:42.830: E/AndroidRuntime(12693):    at android.support.v4.view.ViewPager.populate(ViewPager.java:1048)
09-28 13:41:42.830: E/AndroidRuntime(12693):    at android.support.v4.view.ViewPager.populate(ViewPager.java:914)
09-28 13:41:42.830: E/AndroidRuntime(12693):    at android.support.v4.view.ViewPager$3.run(ViewPager.java:244)
09-28 13:41:42.830: E/AndroidRuntime(12693):    at android.view.Choreographer$CallbackRecord.run(Choreographer.java:749)
09-28 13:41:42.830: E/AndroidRuntime(12693):    at android.view.Choreographer.doCallbacks(Choreographer.java:562)
09-28 13:41:42.830: E/AndroidRuntime(12693):    at android.view.Choreographer.doFrame(Choreographer.java:531)
09-28 13:41:42.830: E/AndroidRuntime(12693):    at android.view.Choreographer$FrameDisplayEventReceiver.run(Choreographer.java:735)
09-28 13:41:42.830: E/AndroidRuntime(12693):    at android.os.Handler.handleCallback(Handler.java:725)
09-28 13:41:42.830: E/AndroidRuntime(12693):    at android.os.Handler.dispatchMessage(Handler.java:92)
09-28 13:41:42.830: E/AndroidRuntime(12693):    at android.os.Looper.loop(Looper.java:137)
09-28 13:41:42.830: E/AndroidRuntime(12693):    at android.app.ActivityThread.main(ActivityThread.java:5230)
09-28 13:41:42.830: E/AndroidRuntime(12693):    at java.lang.reflect.Method.invokeNative(Native Method)
09-28 13:41:42.830: E/AndroidRuntime(12693):    at java.lang.reflect.Method.invoke(Method.java:525)
09-28 13:41:42.830: E/AndroidRuntime(12693):    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:799)
09-28 13:41:42.830: E/AndroidRuntime(12693):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:566)
09-28 13:41:42.830: E/AndroidRuntime(12693):    at dalvik.system.NativeStart.main(Native Method)