TabLayout與ViewPager連用

1:基本設(shè)置

val tabTitles =arrayOf("最近七天收益","下屬會(huì)員充值","歷史收益")? //TabLayout的三個(gè)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)? //設(shè)置adapter

content.setAdapter(adapter)? ?//設(shè)置adapter,content為ViewPager的id

tab.setupWithViewPager(content)? //設(shè)置Tab Layout與ViewPager聯(lián)動(dòng)

tab.setTabMode(TabLayout.MODE_FIXED)? //設(shè)置模式

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:設(shè)置TabLayout默認(rèn)選中

content.setCurrentItem(type)? ?//content為ViewPager的id,type為需要選中的item

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

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容