博客
关于我
android自定义tab下划线变大,官方TabLayout下划线跟随字体长度变化(SDK 28以上)...
阅读量:799 次
发布时间:2023-04-17

本文共 852 字,大约阅读时间需要 2 分钟。

Android TabLayout在SDK28引入了一个重要的新特性,即下划线可以根据字体长度自动调整。这大大简化了实现场景,无需反射或引入第三方控件。

下划线自适应特性解析

在Android系统中,TabLayout默认提供了下划线的显示功能。随着SDK版本的升级,特别是SDK28,TabLayout的下划线实现方式发生了重要变化。具体来说,开发者可以通过属性设置来控制下划线的显示方式。

关键属性配置

以下是实现自适应下划线的关键属性配置:

  • id

    android:id="@+id/tabPassengerFlow"

  • 布局属性

    android:layout_width="match_parent"
    android:layout_height="wrap_content"

  • 背景颜色

    android:background="@color/color_FFFFFF"

  • 指示器颜色

    app:tabIndicatorColor="@color/color_207DFC"

  • 指示器充满属性

    app:tabIndicatorFullWidth="false"

  • 选中字体颜色

    app:tabSelectedTextColor="@color/color_207DFC"

  • 字体颜色

    app:tabTextColor="@color/color_333333"

  • 优势展示

    相比于传统实现方式,这种自适应下划线的实现具有显著优势:

    • 简化开发流程:无需反射或引入第三方库,直接通过属性配置即可实现。
    • 灵活性增强:下划线长度自动根据字体内容调整,适配不同字体大小需求。
    • 性能优化:避免了复杂操作,提升应用性能和用户体验。

    实现示例

    以下是一个典型的TabLayout布局示例:

    总结

    Android SDK28对TabLayout的优化,使得自适应下划线实现变得更加简便。开发者只需通过属性配置即可实现灵活的下划线显示效果,不再需要依赖反射或第三方库。这一改进不仅简化了开发流程,也提升了应用的用户体验和性能表现。

    转载地址:http://uogfk.baihongyu.com/

    你可能感兴趣的文章
    MySQL8,体验不一样的安装方式!
    查看>>
    MySQL: Host '127.0.0.1' is not allowed to connect to this MySQL server
    查看>>
    Mysql: 对换(替换)两条记录的同一个字段值
    查看>>
    mysql:Can‘t connect to local MySQL server through socket ‘/var/run/mysqld/mysqld.sock‘解决方法
    查看>>
    MYSQL:基础——3N范式的表结构设计
    查看>>
    MYSQL:基础——触发器
    查看>>
    Mysql:连接报错“closing inbound before receiving peer‘s close_notify”
    查看>>
    mysqlbinlog报错unknown variable ‘default-character-set=utf8mb4‘
    查看>>
    mysqldump 参数--lock-tables浅析
    查看>>
    mysqldump 导出中文乱码
    查看>>
    mysqldump 导出数据库中每张表的前n条
    查看>>
    mysqldump: Got error: 1044: Access denied for user ‘xx’@’xx’ to database ‘xx’ when using LOCK TABLES
    查看>>
    Mysqldump参数大全(参数来源于mysql5.5.19源码)
    查看>>
    mysqldump备份时忽略某些表
    查看>>
    mysqldump实现数据备份及灾难恢复
    查看>>
    mysqldump数据库备份无法进行操作只能查询 --single-transaction
    查看>>
    mysqldump的一些用法
    查看>>
    mysqli
    查看>>
    MySQLIntegrityConstraintViolationException异常处理
    查看>>
    mysqlreport分析工具详解
    查看>>