Android开发——修改TabLayout的指示线宽度

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/chengxu_kuangrexintu/article/details/81870516

前言

在实际的Android开发当中,我们会遇到需要修改TabLayout的下滑线宽度。我有在网上中方法,我看到最多的博客是利用Java代码的反射进行修改。不知道为什么我copy网上的反射方法,老是报空指针错误。最后我使用google大法,我在stackoverflow网上找到了解决方案:

Android Tab layout: Wrap tab indicator width with respect to tab title

解决代码

根据上面提到的链接,我修改了一下写出下面的方法

/**
 * 修改TabLayout的指示线宽度
 */
public void modifyTabIndicatorWidth(TabLayout tabLayout, int externalMargin, int internalMargin) {
    View tabStrip = tabLayout.getChildAt(0);
    if (tabStrip instanceof ViewGroup) {
        ViewGroup tabStripGroup = (ViewGroup) tabStrip;
        int childCount = ((ViewGroup) tabStrip).getChildCount();
        for (int i = 0; i < childCount; i++) {
            View tabView = tabStripGroup.getChildAt(i);
            //设置最小宽度为0,防止指示线没有padding没有为0
            tabView.setMinimumWidth(0);
            // 将padding设置为0,将指示符封装为标题
            tabView.setPadding(0, tabView.getPaddingTop(), 0, tabView.getPaddingBottom());
            // 在制表符之间设置自定义边距
            if (tabView.getLayoutParams() instanceof ViewGroup.MarginLayoutParams) {
                ViewGroup.MarginLayoutParams layoutParams = (ViewGroup.MarginLayoutParams) tabView.getLayoutParams();
                if (i == 0) {
                    // 左边
                    settingMargin(layoutParams, externalMargin, internalMargin);
                } else if (i == childCount - 1) {
                    //右边
                    settingMargin(layoutParams, internalMargin, externalMargin);
                } else {
                    // 内部
                    settingMargin(layoutParams, internalMargin, internalMargin);
                }
            }
        }
        tabLayout.requestLayout();
    }
}

private void settingMargin(ViewGroup.MarginLayoutParams layoutParams, int start, int end) {
    if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.JELLY_BEAN_MR1) {
        layoutParams.setMarginStart(start);
        layoutParams.setMarginEnd(end);
    } else {
        layoutParams.leftMargin = start;
        layoutParams.rightMargin = end;
    }
}                

总结

该方法就只能把TabLayout的下滑线向内缩进,是在TabView的左右padding值设置为0的情况下。没有跟网上的提到反射方法一样进行一个动态的缩放。小伙伴们根据需求情况来看,是否要使用我的方法。

猜你喜欢

转载自blog.csdn.net/chengxu_kuangrexintu/article/details/81870516