android - 在 TabLayout 中自定义选中的选项卡
问题描述
这就是我需要的
这是我取得的成果(忽略大小和背景颜色)
我的代码:
<android.support.design.widget.TabLayout
android:id="@+id/tabs"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginTop="24dp"
app:tabMode="fixed"
app:tabBackground="@drawable/tab_selector"
app:tabIndicatorHeight="0dp"
app:tabTextAppearance="?android:textAppearanceMedium"
app:tabSelectedTextColor="#6e00b5"/>
tab_selector.xml
<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
<item android:drawable="@drawable/selected_dot"
android:state_selected="true"/>
</selector>
selected_dot.xml
<?xml version="1.0" encoding="utf-8"?>
<layer-list xmlns:android="http://schemas.android.com/apk/res/android">
<item>
<shape
android:innerRadius="0dp"
android:shape="ring"
android:thickness="4dp"
android:useLevel="false">
<solid android:color="#6e00b5"/>
</shape>
</item>
我面临的唯一问题是将点放在文本下方。
解决方案
简单的解决方案
使用app:tabIndicator
代替app:tabBackground
<TabLayout
app:tabIndicator="@drawable/tab_dot"
app:tabIndicatorHeight="8dp">
请注意,至少使用两倍app:tabIndicatorHeight
的制表符 ( 4dp
) 以使其完全可见。
推荐阅读
- javascript - 无法运行反应脚本
- c# - ASP.NET Core 3.0 表单 ModelState 总是无效
- c - 如何使用 MPI 的 C 文件中的索引修改字符串?
- mysql - 从一个员工表中返回大于经理工资的员工工资
- gnuplot - gnuplot 数据有什么问题?
- java - For循环自动递增变量
- django - 带有 Hamachi 的 IIS
- javascript - Jquery,将值从 id 传递到另一个 js 函数
- python - 为什么 file.py 不在控制台上打印任何内容?
- spring-boot - 带有 Spring Boot 应用程序的 Jetty 9.4.21 出现 TypeCast 错误