TabLayout 修改背景色,字体颜色,指示线的颜色和宽度

image.png

总的代码如下:改style放到values的style中,就重新设置了tablayout的属性了!!!

<!-- 修改tablayout的背景色,提示线的颜色,字体颜色等-->
    <style name="Base.Widget.Design.TabLayout" parent="android:Widget">
        <item name="tabBackground">@android:color/white</item>
        <item name="tabIndicatorColor">#3D87FB</item>
        <item name="tabIndicatorHeight">2dp</item>
        <item name="tabTextAppearance">@style/TextAppearance.Design.Tab</item>
        <item name="tabSelectedTextColor">#3D87FB</item>
    </style>

    <style name="TextAppearance.Design.Tab" parent="TextAppearance.AppCompat.Button">
        <item name="android:textSize">15sp</item>
        <item name="android:textColor">#666666</item>
        <item name="textAllCaps">true</item>
    </style>

1: 修改背景色

 <item name="tabBackground">@android:color/white</item>

2: 字体颜色

image.png

3: 指示线

A: 颜色和高度

 <item name="tabIndicatorColor">#3D87FB</item>
 <item name="tabIndicatorHeight">2dp</item>

B: 指示线的宽度

其中的20,20代表了,左边间距,右边间距

mTabLayout.post(new Runnable() {
            @Override
            public void run() {
                setIndicator(mTabLayout,20,20);
            }
        });
public void setIndicator(TabLayout tabs, int leftDip, int rightDip) {
        Class<?> tabLayout = tabs.getClass();
        Field tabStrip = null;
        try {
            tabStrip = tabLayout.getDeclaredField("mTabStrip");
        } catch (NoSuchFieldException e) {
            e.printStackTrace();
        }

        tabStrip.setAccessible(true);
        LinearLayout llTab = null;
        try {
            llTab = (LinearLayout) tabStrip.get(tabs);
        } catch (IllegalAccessException e) {
            e.printStackTrace();
        }

        int left = (int) TypedValue.applyDimension(TypedValue.COMPLEX_UNIT_DIP,
                leftDip, Resources.getSystem().getDisplayMetrics());
        int right = (int) TypedValue.applyDimension(TypedValue.COMPLEX_UNIT_DIP,
                rightDip, Resources.getSystem().getDisplayMetrics());

        for (int i = 0; i < llTab.getChildCount(); i++) {
            View child = llTab.getChildAt(i);
            child.setPadding(0, 0, 0, 0);
            LinearLayout.LayoutParams params = new LinearLayout.LayoutParams(0, LinearLayout.LayoutParams.MATCH_PARENT, 1);
            params.leftMargin = left;
            params.rightMargin = right;
            child.setLayoutParams(params);
            child.invalidate();
        }
    }
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 175,823评论 25 709
  • 这篇主要要介绍Tablayout使用,因为在实际开发中TabLayout和ViewPager一起使用,所以下面主要...
    mm_cuckoo阅读 17,248评论 2 55
  • 序 上图是简书Android端的主页Tab,在其他的App中Tab也是很常见的,它的实现方式也有很多:TabHos...
    积木Blocks阅读 165,871评论 109 326
  • 大概半年前,看到一个朋友在朋友圈发的两条状态,一个是:今年一定要找到男朋友。另一条:这个年纪待在家里,被更年期的父...
    芒果爱吃西米露阅读 1,293评论 0 0
  • 上一章 大高个坐在餐桌的凳子上,在微亮的橘黄色灯光下他脸上的油光映衬出黝黑的皮肤,头发结成了一块块的结,看不出他的...
    酥小栗阅读 1,891评论 0 0