setAdapter() в фрагменте onActivityCreated вызывает IllegalStateException: представление содержимого еще не создано при нажатии кнопки «Назад»

Когда мое приложение работает в одностолбцовом режиме, при нажатии на элемент в ListFragment A используется обратный вызов основного действия для программного запуска Fragment B для отображения дополнительной информации. Я запускаю фрагмент B следующим образом:

// Create the new fragment and set an argument pointing to the entry's ID in the database
FragmentEntryDetails newFragment = new FragmentEntryDetails();
Bundle args = new Bundle();
args.putInt("entryID", entryID);
newFragment.setArguments(args);

// Specify where in the view we want to place the fragment, then add it to the backstack so the user can
// return to the previous fragment
FragmentTransaction transaction = getFragmentManager().beginTransaction();
transaction.replace(R.id.fragment_container, newFragment);
transaction.addToBackStack(null);
// Commit the transaction
transaction.commit();

Когда я нажимаю кнопку "Назад", чтобы вернуться к списку результатов поиска в ListFragment A, приложение аварийно завершает работу со следующим исключением IllegalStateException:

03-06 09:21:53.273: E/AndroidRuntime(32760): FATAL EXCEPTION: main
03-06 09:21:53.273: E/AndroidRuntime(32760): java.lang.IllegalStateException: Content view not yet created
03-06 09:21:53.273: E/AndroidRuntime(32760):    at android.app.ListFragment.ensureList(ListFragment.java:386)
03-06 09:21:53.273: E/AndroidRuntime(32760):    at android.app.ListFragment.getListView(ListFragment.java:280)
03-06 09:21:53.273: E/AndroidRuntime(32760):    at com.test.dictApp.FragmentSearch.onActivityCreated(FragmentSearch.java:98)
03-06 09:21:53.273: E/AndroidRuntime(32760):    at android.app.Fragment.performActivityCreated(Fragment.java:1703)
03-06 09:21:53.273: E/AndroidRuntime(32760):    at android.app.FragmentManagerImpl.moveToState(FragmentManager.java:903)
03-06 09:21:53.273: E/AndroidRuntime(32760):    at android.app.FragmentManagerImpl.moveToState(FragmentManager.java:1057)
03-06 09:21:53.273: E/AndroidRuntime(32760):    at android.app.BackStackRecord.popFromBackStack(BackStackRecord.java:764)
03-06 09:21:53.273: E/AndroidRuntime(32760):    at android.app.FragmentManagerImpl.popBackStackState(FragmentManager.java:1484)
03-06 09:21:53.273: E/AndroidRuntime(32760):    at android.app.FragmentManagerImpl.popBackStackImmediate(FragmentManager.java:490)
03-06 09:21:53.273: E/AndroidRuntime(32760):    at android.app.Activity.onBackPressed(Activity.java:2167)
03-06 09:21:53.273: E/AndroidRuntime(32760):    at android.app.Activity.onKeyUp(Activity.java:2145)
03-06 09:21:53.273: E/AndroidRuntime(32760):    at android.view.KeyEvent.dispatch(KeyEvent.java:2633)
03-06 09:21:53.273: E/AndroidRuntime(32760):    at android.app.Activity.dispatchKeyEvent(Activity.java:2375)
03-06 09:21:53.273: E/AndroidRuntime(32760):    at com.android.internal.policy.impl.PhoneWindow$DecorView.dispatchKeyEvent(PhoneWindow.java:1847)
03-06 09:21:53.273: E/AndroidRuntime(32760):    at android.view.ViewRootImpl.deliverKeyEventPostIme(ViewRootImpl.java:3701)
03-06 09:21:53.273: E/AndroidRuntime(32760):    at android.view.ViewRootImpl.handleImeFinishedEvent(ViewRootImpl.java:3651)
03-06 09:21:53.273: E/AndroidRuntime(32760):    at android.view.ViewRootImpl$ViewRootHandler.handleMessage(ViewRootImpl.java:2818)
03-06 09:21:53.273: E/AndroidRuntime(32760):    at android.os.Handler.dispatchMessage(Handler.java:99)
03-06 09:21:53.273: E/AndroidRuntime(32760):    at android.os.Looper.loop(Looper.java:137)
03-06 09:21:53.273: E/AndroidRuntime(32760):    at android.app.ActivityThread.main(ActivityThread.java:5041)
03-06 09:21:53.273: E/AndroidRuntime(32760):    at java.lang.reflect.Method.invokeNative(Native Method)
03-06 09:21:53.273: E/AndroidRuntime(32760):    at java.lang.reflect.Method.invoke(Method.java:511)
03-06 09:21:53.273: E/AndroidRuntime(32760):    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:793)
03-06 09:21:53.273: E/AndroidRuntime(32760):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:560)
03-06 09:21:53.273: E/AndroidRuntime(32760):    at dalvik.system.NativeStart.main(Native Method)

Ошибка указывает на setAdapter() в функции onActivityCreated() ListFragment A:

@Override
public void onActivityCreated(Bundle savedInstanceState)
{
    // Tell the main activity that this fragment has menu elements to declare
    super.onActivityCreated(savedInstanceState);
    setHasOptionsMenu(true);

    adapter = new FragmentSearchCursorAdapter(getActivity(), null, 0);
    // Assign our CursorAdapter
    getListView().setAdapter(adapter);

    Bundle args = getSQLArgs("dictionary");
    // Load up the cursor that will handle the SQL grunt work
    getLoaderManager().initLoader(SEARCH_LOADER_ID, args, this);
}

Почему getListView().setAdapter() вызывает проблему? В соответствии с жизненным циклом фрагмента listView должен быть доступен для манипуляций. Должен ли я устанавливать адаптер только в том случае, если он еще не установлен?

Редактировать: я разобрался, см. мой ответ ниже.


person IAmKale    schedule 06.03.2013    source источник


Ответы (1)


Я только недавно заработал достаточно кредитов, чтобы ответить на свои вопросы, поэтому я решил превратить свои комментарии в реальный ответ.

Решение состояло в том, чтобы переместить назначение моего FragmentSearchCursorAdapter в метод onCreateView() ListFragment A, а затем использовать setListAdapter() вместо getListView().setAdapter(), как показано ниже:

@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState)
{
    // Specify the fragment layout file for this fragment class
    View view = inflater.inflate(R.layout.fragment_search, container, false);
    // Assign our CursorAdapter
    adapter = new FragmentSearchCursorAdapter(getActivity(), null, 0);
    setListAdapter(adapter);

    return view;
}
person IAmKale    schedule 25.07.2013