SupportMapFragment показывается во второй раз

У меня есть SupportMapFragment в моем собственном фрагменте. Когда я показываю этот фрагмент во второй раз, он вылетает.

Сначала я попытался добавить SupportMapFragment в XML, но у меня была та же проблема, что описана здесь.

Поэтому я попытался добавить его программно:

@Override
    public View onCreateView(LayoutInflater inflater, ViewGroup container,
            Bundle savedInstanceState) {
        View view = inflater.inflate(R.layout.map_fragment, container, false);
        isGooglePlay=isGooglePlay();
        if(isGooglePlay){
            mMapFragment = SupportMapFragment.newInstance();
            FragmentTransaction fragmentTransaction =
                         getChildFragmentManager().beginTransaction();
            fragmentTransaction.add(R.id.map_fragment_mapRoot, mMapFragment);
            fragmentTransaction.commit(); 
            map = mMapFragment.getMap();
            if (map != null){
                map.animateCamera(CameraUpdateFactory.zoomTo(100F));
            }
        }
        return view;
    } 

Сбой в строке, где транзакция зафиксирована.

  FATAL EXCEPTION: main
  Process: com.sabatsoft.sgs14remote, PID: 23914
  java.lang.IllegalStateException: Activity has been destroyed
    at android.support.v4.app.FragmentManagerImpl.enqueueAction(FragmentManager.java:1365)
    at android.support.v4.app.BackStackRecord.commitInternal(BackStackRecord.java:595)
    at android.support.v4.app.BackStackRecord.commit(BackStackRecord.java:574)
    at com.sabatsoft.sgs14remote.fragment.FlightMapFragment.onCreateView(FlightMapFragment.java:45)
    at android.support.v4.app.Fragment.performCreateView(Fragment.java:1500)
    at android.support.v4.app.FragmentManagerImpl.moveToState(FragmentManager.java:927)
    at android.support.v4.app.FragmentManagerImpl.moveToState(FragmentManager.java:1104)
    at android.support.v4.app.BackStackRecord.run(BackStackRecord.java:682)
    at android.support.v4.app.FragmentManagerImpl.execPendingActions(FragmentManager.java:1467)
    at android.support.v4.app.FragmentManagerImpl$1.run(FragmentManager.java:440)
    at android.os.Handler.handleCallback(Handler.java:733)
    at android.os.Handler.dispatchMessage(Handler.java:95)
    at android.os.Looper.loop(Looper.java:136)
    at android.app.ActivityThread.main(ActivityThread.java:5001)
    at java.lang.reflect.Method.invoke(Native Method)
    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:785)
    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:601)

person SpeedEX505    schedule 08.08.2014    source источник


Ответы (1)


Существует аналогичная известная проблема, см. здесь.

Это ошибка во вложенных фрагментах. По сути, дочерний FragmentManager завершается с нарушенным внутренним состоянием, когда он отсоединяется от активности.

Краткосрочным обходным решением является добавление следующего кода в ваш фрагмент.

@Override
public void onDetach() {
super.onDetach();

try {
     Field childFragmentManager = Fragment.class.getDeclaredField("mChildFragmentManager");
     childFragmentManager.setAccessible(true);
     childFragmentManager.set(this, null);
     } catch (NoSuchFieldException e) {
        throw new RuntimeException(e);
     } catch (IllegalAccessException e) {
        throw new RuntimeException(e);
    }
}
person AnkitSomani    schedule 08.08.2014