Я використовував гібридний підхід для фрагментів, що містять подання списку. Це здається виконавчим, оскільки я не замінюю поточний фрагмент, а додаю новий фрагмент і приховую поточний. У мене є такий спосіб у діяльності, де розміщуються мої фрагменти:
public void addFragment(Fragment currentFragment, Fragment targetFragment, String tag) {
FragmentManager fragmentManager = getSupportFragmentManager();
FragmentTransaction transaction = fragmentManager.beginTransaction();
transaction.setCustomAnimations(0,0,0,0);
transaction.hide(currentFragment);
// use a fragment tag, so that later on we can find the currently displayed fragment
transaction.add(R.id.frame_layout, targetFragment, tag)
.addToBackStack(tag)
.commit();
}
Я використовую цей метод у своєму фрагменті (містить перегляд списку) щоразу, коли елемент списку натискається / натискається (і тому мені потрібно запустити / відобразити фрагмент деталей):
FragmentManager fragmentManager = getActivity().getSupportFragmentManager();
SearchFragment currentFragment = (SearchFragment) fragmentManager.findFragmentByTag(getFragmentTags()[0]);
DetailsFragment detailsFragment = DetailsFragment.newInstance("some object containing some details");
((MainActivity) getActivity()).addFragment(currentFragment, detailsFragment, "Details");
getFragmentTags()
повертає масив рядків, який я використовую як теги для різних фрагментів, коли я додаю новий фрагмент (див. transaction.add
метод у addFragment
вищевказаному методі).
У фрагменті, що містить перегляд списку, я роблю це в його методі onPause ():
@Override
public void onPause() {
// keep the list view's state in memory ("save" it)
// before adding a new fragment or replacing current fragment with a new one
ListView lv = (ListView) getActivity().findViewById(R.id.listView);
mListViewState = lv.onSaveInstanceState();
super.onPause();
}
Потім у onCreateView фрагмента (фактично в методі, який викликається в onCreateView), я відновлюю стан:
// Restore previous state (including selected item index and scroll position)
if(mListViewState != null) {
Log.d(TAG, "Restoring the listview's state.");
lv.onRestoreInstanceState(mListViewState);
}