我尝试在我的应用中设置以下导航:
实际情况:ViewPager + Tabs在列表之间滑动:
所需条件: ViewPager +标签:
目标是在选项卡导航中显示详细信息片段。我不能用detailFragment替换fragmentList(fragmentList没有自定义布局,因此没有ID,我不知道怎么做)。 此外,开始新活动会隐藏标签栏。
有人可以帮帮我吗?
答案 0 :(得分:14)
我会创建一个知道要显示什么的包装片段 - 列表或详细信息。这将与ViewPager
完全分离 - pager只会知道它包含包装器片段,而这些片段会自行管理它们的内容。
实施将遵循这些方针:
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) {
// Create details fragment based on clicked item's position
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) {
// There has to be a view with id `container` inside `wrapper.xml`
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
):
<?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"/>