使用选项卡将ViewFragment替换为ViewPager中的Fragment

Luc*_*aka 4 tabs android fragment android-viewpager android-listfragment

我尝试在我的应用中设置以下导航:

实际情况:ViewPager + Tabs在列表之间滑动:

  • ListFragment A.
  • ListFragment B.

所需条件:ViewPager +标签:

  • ListFragment一个onListItemSelected用DetailFragment A替换ListFragment A.
  • ListFragment B onListItemSelected用DetailFragment B替换ListFragment B.

目标是在选项卡导航中显示详细信息片段.我不能用detailFragment替换fragmentList(fragmentList没有自定义布局,因此没有ID,我不知道怎么做).此外,启动新活动会隐藏选项卡栏.

有人可以帮帮我吗?

min*_*deh 14

我会创建一个包装片段,知道要显示什么 - 列表或详细信息.这将完全脱离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) {
              // 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);
            }
        }
    }
}
Run Code Online (Sandbox Code Playgroud)

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>
Run Code Online (Sandbox Code Playgroud)

其他方式.这应该有效,但你必须尝试一下(布局id本身,而不是有一个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"/>
Run Code Online (Sandbox Code Playgroud)