TabLayout定义下标宽度

本文探讨了如何避免通过反射来改变TabLayout下标的宽度,指出这种方法可能导致Tab的点击范围缩小和显示问题。作者发现TabLayout的下标是通过绘制长方体实现的,并提出只需调整长方体的坐标即可解决问题。文章提供了修改后的代码,并已上传至GitHub,呼吁其他开发者尊重原创,保留源链接。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

原文链接:https://blog.youkuaiyun.com/qq_15736263/article/details/80972691

网上很多博客TabLayout定义下标宽度都是通过反射修改Tab的宽度实现的,实际效果就是Tab的点击范围变小,且这种方法下标最短宽度只能设置成最宽的Tab的宽度,体验效果很不好。

查看源码后发现 其实就是在draw方法中画了一条长方体,包括动画也是这样实现的。

public void draw(Canvas canvas) {
    super.draw(canvas);
    if (this.mIndicatorLeft >= 0 && this.mIndicatorRight > this.mIndicatorLeft) {
        canvas.drawRect((float)this.mIndicatorLeft, (float)(this.getHeight() - this.mSelectedIndicatorHeight), (float)this.mIndicatorRight, (float)this.getHeight(), this.mSelectedIndicatorPaint);
    }
}

那我们明白了,只需要修改这个长方体的左右坐标即可。

修改完成后代码如下

public void draw(Canvas canvas) {
    super.draw(canvas);
    if (this.mIndicatorLeft >= 0 && this.mIndicatorRight > this.mIndicatorLeft) {
        if (this.mSelectedIndicatorWidth <= 0) {
            canvas.drawRect((float)this.mIndicatorLeft, (float)(this.getHeight() - this.mSelectedIndicatorHeight), (float)this.mIndicatorRight, (float)this.getHeight(), this.mSelectedIndicatorPaint);
        } else {
            int left = (this.mIndicatorRight - this.mIndicatorLeft) / 2 - this.mSelectedIndicatorWidth / 2 + this.mIndicatorLeft;
            canvas.drawRect((float)left, (float)(this.getHeight() - this.mSelectedIndicatorHeight), (float)(left + this.mSelectedIndicatorWidth), (float)this.getHeight(), this.mSelectedIndicatorPaint);
        }
    }

}


其实很简单,就是不知道Google为啥不愿意去实现,只能我们自己加代码实现了

为了方便伸手党,代码已经上传到了github

地址:https://github.com/MoonlitDropOfBlood/TabLayout


盗链的各位爸爸,麻烦留个源链接吧,拜托了

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值