我会创建一个包装片段(fragment),该片段了解要显示的内容 - 列表或细节。这将完全与 ViewPager
解耦 - ViewPager 只知道它持有包装片段,而这些片段将自己管理其内容。
实现方式如下:
public class WrapperFragment extends Fragment {
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
MyListFragment list = new MyListFragment();
list.setListAdapter(adapter);
list.setOnItemClickListener(new OnItemClickListener() {
@Override public void onItemClick(AdapterView<?> l, View v, int position, long id) {
Fragment details = new Fragment();
getChildFragmentManager()
.beginTransaction()
.replace(R.id.container, details)
.addToBackStack(null)
.commit();
}
});
getChildFragmentManager()
.beginTransaction()
.add(R.id.container, list)
.commit();
}
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
return inflater.inflate(R.layout.wrapper, container, false);
}
public class MyListFragment extends ListFragment {
private OnItemClickListener listener;
public void setOnItemClickListener(OnItemClickListener l) {
this.listener = l;
}
@Override
public void onListItemClick(ListView l, View v, int position, long id) {
if(listener != null) {
listener.onItemClick(l, v, position, id);
}
}
}
}
wrapper.xml
的想法是,WrapperFragment
必须提供一个包含具有id container
的视图的布局 - 因为我们正在使用该id的视图来放置子片段 - MyListFragment
或DetailsFragment
。
<?xml version="1.0" encoding="utf-8"?>
<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent">
<FrameLayout
android:id="@+id/container"
android:layout_width="match_parent"
android:layout_height="match_parent"/>
</FrameLayout>
另一种方法。这应该可以工作,但是你需要尝试一下(布局本身有id
,而不是具有container
ID的子元素):
<?xml version="1.0" encoding="utf-8"?>
<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/container"
android:layout_width="match_parent"
android:layout_height="match_parent"/>
wrapper.xml
的示例。如果您在处理此问题时遇到困难,请告诉我。 - mindehgetChildFragmentManager().popBackStack()
。注意在显示DetailsFragment
时的.addToBackStack(null)
行。它基本上是说“将此事务保存为历史操作 - 可以通过按 HW 返回按钮来返回的操作之一”。而popBackStack()
类似于模拟 HW 返回按钮点击。将backStack
管理视为类似于 HTML5 历史记录 API,可能更容易理解。 - mindehonCreateOptionsMenu()
仅在顶级片段-包装器上调用。解决方案可以从那里创建菜单-例如通过手动调用listFragment#onCreateOptionsMenu()
。这只是我想到的,你需要尝试一下。 - mindeh