2018-04-18 TabLayout 标签页文字显示问题以及

2018-04-18  本文已影响24人  贝贝ovo

详情
当添加了tab或者是在布局文件中定义了TabItem,且调用了setupWithViewPager方法,ViewPager的Adapter又没有复写getPagerTitle方法(这个方法在PagerAdapter中默认返回null)tab页文字无法显示

正确使用 两种方法
1.不用 setupWithViewPager方法,添加以下代码

tbTitle.addOnTabSelectedListener(new TabLayout.ViewPagerOnTabSelectedListener(vpContent));
vpContent.addOnPageChangeListener(new TabLayout.TabLayoutOnPageChangeListener(tbTitle));

这两行代码来源于TabLayout的setupWithViewPager方法,目的就是为了实现ViewPager和TabLayout的联动,但不用removeAllTabs,看过这部分源码的朋友应该都知道,setupWithViewPager方法中先清除tab,然后根据ViewPager的getPagerTitle返回的字符串创建文字Tab并且添加到TabLayout中用于与ViewPager联动

2.用setupWithViewPager方法,复写ViewPager的Adapter的getPagerTitle方法 (kotlin代码额)

override fun getPageTitle(position: Int): CharSequence {
       if (mTitleList.size==0) {
           return ""
       }else {
           return mTitleList[position]
       }
   }

Indicator下划线宽度问题参考这两篇文章
https://blog.csdn.net/u013134391/article/details/70833903
https://blog.csdn.net/h_gao/article/details/79784325

上一篇下一篇

猜你喜欢

热点阅读