改变TabLayout的线的宽度

先看第一种方法如果这种方法好,下面的方法就不用看了,下面是Git网址
https://github.com/H07000223/FlycoTabLayout/blob/master/README_CN.md

        由于最近项目需要,需要设置tabLayout下方下划线的长度.笔者上网找了半天,也没有找到方法.后来了解到在源码中对tabLayout的下划线进行了设置.并没有方法可以直接设置.

然后,笔者看到了某位大神的代码,利用反射修改下划线的宽度.先上代码:

  1. public void setIndicator (TabLayout tabs,int leftDip,int rightDip){  
  2.        Class<?> tabLayout = tabs.getClass();  
  3.        Field tabStrip = null;  
  4.        try {  
  5.            tabStrip = tabLayout.getDeclaredField(“mTabStrip”);  
  6.        } catch (NoSuchFieldException e) {  
  7.            e.printStackTrace();  
  8.        }  
  9.   
  10.        tabStrip.setAccessible(true);  
  11.        LinearLayout llTab = null;  
  12.        try {  
  13.            llTab = (LinearLayout) tabStrip.get(tabs);  
  14.        } catch (IllegalAccessException e) {  
  15.            e.printStackTrace();  
  16.        }  
  17.   
  18.        int left = (int) TypedValue.applyDimension(TypedValue.COMPLEX_UNIT_DIP, leftDip, Resources.getSystem().getDisplayMetrics());  
  19.        int right = (int) TypedValue.applyDimension(TypedValue.COMPLEX_UNIT_DIP, rightDip, Resources.getSystem().getDisplayMetrics());  
  20.   
  21.        for (int i = 0; i < llTab.getChildCount(); i++) {  
  22.            View child = llTab.getChildAt(i);  
  23.            child.setPadding(0, 0, 0, 0);  
  24.            LinearLayout.LayoutParams params = new LinearLayout.LayoutParams(0, LinearLayout.LayoutParams.MATCH_PARENT, 1);  
  25.            params.leftMargin = left;  
  26.            params.rightMargin = right;  
  27.            child.setLayoutParams(params);  
  28.            child.invalidate();  
  29.        }  
 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();
        }

由于水平太臭,就不多解释了…

 至于使用方式的话,直接调用方法即可.必须要在Tablayout渲染出来后调用,我们可以选择view.post()方法来实现:

  1. tab.post(new Runnable() {  
  2.            @Override  
  3.            public void run() {  
  4.                setIndicator(tab,60,60);  
  5.            }  
  6.        });  
 tab.post(new Runnable() {
            @Override
            public void run() {
                setIndicator(tab,60,60);
            }
        });

最后放上效果图:



评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值