这是一种经典布局方式,同时使用频率很是高。首先说fragmentpagerviewadapter,一样的还有fragmentstateviewpageradapter,前者适用于少许fragment,会缓存三个fragment,复用率高,在界面少的时候建议使用。
实现思路为 1将fragment用getsupportfragemnt加入到adapter中,2将adapter加入到view pager中,最后将tablayout与viewpager关联,一个简单的例子代码以下,在oncreate方法中:缓存
mAdapter=new MinePagerAdapter(this,getSupportFragmentManager(),viewpagerAcMain); viewpagerAcMain.setAdapter(mAdapter); tabLayout.setupWithViewPager(viewpagerAcMain); mAdapter.setFragment(fragments); for (int i = 0; i <tabLayout.getTabCount(); i++) { TabLayout.Tab tab=tabLayout.getTabAt(i); assert tab != null; tab.setCustomView(mAdapter.getCustomView(i,tabLayout)); } viewpagerAcMain.setCurrentItem(0);
若是要设置tablayout点击标题栏变色请设置tablayout的监听statechange方法。
关于setfragment方法,解释一下,使用setfragment是adapter中写的方法,是为了获取fragment时销毁重建新的fragment,达到强制刷新数据的结果,可是有损于界面渲染速度。adapter代码以下。同时在adapter中写tablayout的view获取方法,getcumstomview,填充tablayout的界面。若是你没有数据刷新的需求,能够直接在adapter的getItem继承方法中使用switch切换fragment简单实现。ide
public class MinePagerAdapter extends FragmentPagerAdapter { Context mContext; List<Fragment> fragments=new ArrayList<>(); FragmentManager fm; ViewPager viewPager; public MinePagerAdapter(@NonNull FragmentManager fm, int behavior) { super(fm, behavior); } public MinePagerAdapter(Context context, FragmentManager fm, ViewPager viewPager) { super(fm); this.mContext=context; this.fm=fm; this.viewPager=viewPager; } @Override public int getItemPosition(@NonNull Object object) { return POSITION_NONE; } @NonNull @Override public Fragment getItem(int position) { return fragments.get(position); } @Override public int getCount() { return fragments.size(); } public void setFragment(List<Fragment> fragments) { if (this.fragments != null) { FragmentTransaction ft=fm.beginTransaction(); for (Fragment fragment : fragments) { this.fragments.remove(fragment); } ft.commit(); ft=null; fm.executePendingTransactions(); } this.fragments=fragments; notifyDataSetChanged(); } public View getCustomView(int position, TabLayout tabLayout) { Context context=mContext; View view=null; view= LayoutInflater.from(context).inflate(R.layout.item_tab_act_main,tabLayout,false); ImageView image=view.findViewById(R.id.im_tab); switch(position){ case 0: image.setBackgroundResource(R.drawable.ic_start); break; case 1: image.setBackgroundResource(R.drawable.ic_start); break; case 2: image.setBackgroundResource(R.drawable.ic_start); break; } return view; } }
若是在其余fragment中想设置跳转其余fragment的方式,在activity中实现方法布局
public void setPageCurrent(int position) { viewpagerAcMain.setCurrentItem(position); }