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

相關文章
相關標籤/搜索