# TabLayoutX **Repository Path**: cjf_90/TabLayoutX ## Basic Information - **Project Name**: TabLayoutX - **Description**: 适配AndroidX的TabLayoutX - **Primary Language**: Unknown - **License**: MulanPSL-2.0 - **Default Branch**: master - **Homepage**: None - **GVP Project**: No ## Statistics - **Stars**: 0 - **Forks**: 0 - **Created**: 2024-03-13 - **Last Updated**: 2024-03-13 ## Categories & Tags **Categories**: Uncategorized **Tags**: None ## README XTabLayout——可修改选中项字体大小和指示器长度的TabLayout XTabLayout是基于design包中的TabLayout进行了功能的扩展,在保留原有功能的基础上,增加了修改选中项字体大小、修改指示器长度以及限制屏幕显示范围内显示的Tab个数。 集成步骤: 1.添加XTabLayout依赖库 在app目录下的build.gradle的dependencies中添加如下引用: api 'com.gitee.cjf_90:XTabLayout:0.0.1' 2.在布局文件中设置XTabLayout属性 TabLayout有的属性,在XTabLayout中都会有,属性名称都是前面加个x,后面的t变成大写。 其中增加了xTabIndicatorWidth用于设置指示器长度,xTabTextSize用于设置未选中项的字体大小,xTabSelectedTextSize用于设置选中项的字体大小。 此外1.0.1版本中添加如下属性可以设置屏幕范围内显示的Tab个数 app:xTabDisplayNum="3" 或者在代码中添加 tabLayout.setxTabDisplayNum(3);//需要写在setupWithViewPager前 tabLayout.setupWithViewPager(viewPager); 这里我们限制为3个,则每个tab的宽度为屏幕的1/3. 需要注意显示的个数会受Adapter的ItemCount影响,例如ItemCount为3,但是我们设app:xTabDisplayNum=“4”,那么显示出来的Tab的宽度其实是屏幕的1/3,并非1/4。 3.初始化 XTabLayout的使用方式和TabLayout是一样的,代码如下: //将TabLayout和ViewPager关联起来。 XTabLayout tabLayout = (XTabLayout) findViewById(R.id.xTablayout); tabLayout.setupWithViewPager(viewPager); 增加设置Tab背景色的功能。 app:xTabBackgroundColor="#fff" app:xTabSelectedBackgroundColor="#ff0" 增加设置指示器长度随Tab文本内容长度变化的功能。 使用方式:不设置xTabIndicatorWidth属性即可 增加设置标题字母大小写转换功能,默认小写不自动转大写 使用方式:在xml文件中添加app:xTabTextAllCaps="false"或者在代码中调用xTabLayout.setAllCaps(false); 增加设置分割线功能 使用方式: 1.xml: app:xTabDividerWidth="2dp" app:xTabDividerHeight="15dp" app:xTabDividerColor="#000" app:xTabDividerGravity="center" 不设置xTabDividerHeight属性或者赋值为0时则分割线高度占满 2.java: tabLayout.setDividerSize(5,20); tabLayout.setDividerColor(Color.BLACK); tabLayout.setDividerGravity(DividerDrawable.CENTER); setDividerSize方法中第二个参数为高度,如果设置为0时则分割线高度占满 优化设置指示器长度功能 使用方式: a.明确指定指示器为某个长度则设置xTabIndicatorWidth b.指定指示器长度跟随文本变化则设置xTabDividerWidthWidthText c.如果需要指示器长度占满,则两个属性都不设置,默认占满。 增加设置字体粗体功能 使用方式: app:xTabTextSelectedBold="true" app:xTabTextBold="true"