TabLayout与ViewPager连用

1:基本设置

val tabTitles =arrayOf("最近七天收益","下属会员充值","历史收益")  //TabLayout的三个item

val list: MutableList = ArrayList()     //放置子view的集合

val incomeFragment = IncomeFragment()  //子view1

val myMemberRechargeFragment = MyMemberRechargeFragment()  //子view2

val incomeHistoryFragment = IncomeHistoryFragment()  //子view3

list.add(incomeFragment)   //添加子view1

list.add(myMemberRechargeFragment)  //添加子view2

list.add(incomeHistoryFragment)  //添加子view3

val adapter = MyViewPageAdapter(supportFragmentManager, list, tabTitles)  //设置adapter

content.setAdapter(adapter)   //设置adapter,content为ViewPager的id

tab.setupWithViewPager(content)  //设置Tab Layout与ViewPager联动

tab.setTabMode(TabLayout.MODE_FIXED)  //设置模式

2:adapter(MyViewPageAdapter)

public class MyViewPageAdapterextends FragmentPagerAdapter {

private List list;

private String tabTitles[];

public MyViewPageAdapter(FragmentManager fm, List list,String tabTitles[]) {

super(fm);

this.list = list;

this.tabTitles = tabTitles;

}

@Override

    public Fragment getItem(int i) {

return list.get(i);

}

@Override

    public int getCount() {

return list.size();

}

@Override

    public CharSequence getPageTitle(int position) {

return tabTitles[position];

}

@Override

    public void destroyItem(ViewGroup container,int position, Object object) {

//super.destroyItem(container, position, object); 避免多出销毁Fragment

    }

}

3:设置TabLayout默认选中

content.setCurrentItem(type)   //content为ViewPager的id,type为需要选中的item

tab.getTabAt(type)!!.select()    //tab为TabLayout的id,type同上。

你可能感兴趣的:(TabLayout与ViewPager连用)