ViewPager和TabLayout的使用

在开发中ViewPager+TabLayout的使用场景仍是蛮多的。如今这个项目就频繁使用到这个组合,特意总结了下。java

首先,先上布局文件

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    android:orientation="vertical" android:layout_width="match_parent"
    android:layout_height="match_parent">

    <android.support.design.widget.TabLayout
        android:id="@+id/fragment_notice_tabLayout"
        android:layout_width="match_parent"
        android:layout_height="@dimen/dip44"
        app:tabIndicatorColor="@color/red"
        app:tabSelectedTextColor="@color/red"
        >
    </android.support.design.widget.TabLayout>
    <android.support.v4.view.ViewPager
        android:id="@+id/fragment_notice_viewPager"
        android:layout_width="match_parent"
        android:layout_height="match_parent">
    </android.support.v4.view.ViewPager>
</LinearLayout>
复制代码

代码

public class NoticeFragment extends BaseFragment {

    @BindView(R.id.fragment_notice_tabLayout)
    TabLayout tabLayout;
    @BindView(R.id.fragment_notice_viewPager)
    ViewPager viewPager;

    private List<String> titleList  ;
    private List<Fragment> viewList  ;
    
    @Nullable
    @Override
    public View onCreateView(LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {
        return inflater.inflate(R.layout.fragment_notice, null, false);
    }

    @Override
    public void onViewCreated(View view, @Nullable Bundle savedInstanceState) {
        super.onViewCreated(view, savedInstanceState);
        setupViewPager();
    }
    @Override
    public void onCreate(@Nullable Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        titleList = new ArrayList<>();
        viewList = new ArrayList<>();
        titleList.add("通知");
        titleList.add("私信");
        titleList.add("最近来访");
        viewList.add(new NotificationFragment());
        viewList.add(new MessageFragment());
        viewList.add(new LastVisitorsFragment());
    }
    public void setupViewPager() {
        MyPagerAdapter adapter = new MyPagerAdapter(getChildFragmentManager());
        //给viewPager设置adapter
        viewPager.setAdapter(adapter);
        //tabLayout与viewPager绑定
        tabLayout.setupWithViewPager(viewPager);
        viewPager.setCurrentItem(0);
        viewPager.setOffscreenPageLimit(1);
    }
    //ViewPager适配器
    class MyPagerAdapter extends FragmentPagerAdapter {
        public MyPagerAdapter(FragmentManager fm) {
            super(fm);
        }
        @Override
        public int getCount() {
            return viewList.size();//页卡数
        }

        @Override
        public Fragment getItem(int position) {
            return viewList.get(position);
        }
        @Override
        public CharSequence getPageTitle(int position) {
            return titleList.get(position);//页卡标题
        }
    }
    
}
复制代码

上面这个代码一看就懂了吧,其实蛮简单的。主要是想讲下思路和其中一些细节。思路对了很容易触类旁通

  • 明确本身的需求,须要几个tab。例如例子上须要三个tab(通知,私信,最近来访)。有几个tab就有几个fragment与之对应。
  • 把tab的标题和fragment添加到List中
  • 须要写一个Adapter,继承FragmentPagerAdapter
  • 给ViewPager设置适配器而且将tabLayout和ViewPager绑定

思路就上面四点,明确得一匹。理清思路,和上面代码一并看,就懂了。android

好了,如今讲下细节,这也算是个坑吧。

细心的确定看到个人类是继承Fragment,而不是Activity(这个BaseFragment是咱们本身封装过的)app

public class NoticeFragment extends BaseFragmentide

我在new MyPagerAdapter的时候里面的参数是getChildFragmentManager()布局

MyPagerAdapter adapter = new MyPagerAdapter(getChildFragmentManager());spa

若是你是在Activity中使用Fragment的话,用的是getFragmentManager()这个方法。若是你是在Fragment里面用Fragment的话那就得用getChildFragmentManager()。在Fragment中使用Fragment的状况下,若是用getFragmentManager()获取到的是父Fragment的FragmentManager对象。code

相关文章
相关标签/搜索