TabLayout与FragmentViewPager结合使用遇到的问题

TabLayout和FragmentViewPager经常结合使用,用法比较简单,只需要用setupWithViewPager方法把两者关联起来就可以了。但在使用过程中遇到了以下几个问题。


1. tabLayout不显示名字

        for (int i = 0; i < 3; i++) {
            TabLayout.Tab tab = tabLayout.newTab();
            tab.setText(titleName[i]); // String数组里面存放的是几个tab的名字
            tabLayout.addTab(tab);
        } 
        List<Fragment> list = new ArrayList<Fragment>();
        list.add(new HomeRecommendFragment());
        list.add(new HomeRecommendFragment());
        list.add(new HomeRecommendFragment());
        viewPager.setAdapter(new MainPageFragmentAdapter(getFragmentManager(), list));
        tabLayout.setupWithViewPager(viewPager);

结果几个名字都没有显示出来

查看android官方文档TabLayout,有如下解释:

这里写图片描述

可见,在setupWithViewPager之后,tablayout会使用每个pageAdapter里的page title,而起初我并没有设置。

所以设置一下就可以了


public class MainPageFragmentAdapter extends FragmentPagerAdapter {

    List<Fragment> list;
    String[] titles;

    public MainPageFragmentAdapter(android.support.v4.app.FragmentManager fm, List<Fragment> list, String[] titles) {
        super(fm);
        this.list = list;
        this.titles = titles; // 把tab名字通过数组传进来
    }

    @Override
    public Fragment getItem(int position) {
        return list.get(position);
    }

    @Override
    public int getCount() {
        return list.size();
    }

    @Override
    public CharSequence getPageTitle(int position) {
        return titles[position]; // 在这里返回每个tab的名字
    }
}

2. 点击tab之后,ViewPager不滑动

给TabLayout定义了自己的onTabSelectedListener之后,再点击一个tab,ViewPager并没有跟着滑动

tabLayout.setOnTabSelectedListener(new TabLayout.OnTabSelectedListener() {
            @Override
            public void onTabSelected(TabLayout.Tab tab) {
                Log.i(TAG, "");
            }

            @Override
            public void onTabUnselected(TabLayout.Tab tab) {

            }

            @Override
            public void onTabReselected(TabLayout.Tab tab) {

            }
        });

这其实是因为TabLayout已经有默认的OnTabSelectedListener了,就是ViewPagerOnTabSelectedListener,查看源码,定义如下:

/**
     * A {@link TabLayout.OnTabSelectedListener} class which contains the necessary calls back
     * to the provided {@link ViewPager} so that the tab position is kept in sync.
     */
    public static class ViewPagerOnTabSelectedListener implements TabLayout.OnTabSelectedListener {
        private final ViewPager mViewPager;

        public ViewPagerOnTabSelectedListener(ViewPager viewPager) {
            mViewPager = viewPager;
        }

        @Override
        public void onTabSelected(TabLayout.Tab tab) {
            mViewPager.setCurrentItem(tab.getPosition()); // 关键代码
        }

        @Override
        public void onTabUnselected(TabLayout.Tab tab) {
            // No-op
        }

        @Override
        public void onTabReselected(TabLayout.Tab tab) {
            // No-op
        }
    }

关键的代码就是在onTabselected方法里面调用了viewPager的setCurrentItem

所以要想自定义OnTabSelectedListener,也加上
mViewPager.setCurrentItem(tab.getPosition())就可以了


        tabLayout.setOnTabSelectedListener(new TabLayout.OnTabSelectedListener() {
            @Override
            public void onTabSelected(TabLayout.Tab tab) {
                Log.i(TAG, "");
                viewPager.setCurrentItem(tab.getPosition());
            }

            @Override
            public void onTabUnselected(TabLayout.Tab tab) {

            }

            @Override
            public void onTabReselected(TabLayout.Tab tab) {

            }
        });
  • 3
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值