IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 移动开发 -> Android drawable-使用shape实现选项卡布局 -> 正文阅读

[移动开发]Android drawable-使用shape实现选项卡布局

需要实现下面的这种选项卡的功能。

在这里插入图片描述

刚开始准备使用第三方的tab来实现,但项目中该功能不需要滑动,只要点击来进行切换。

就想着通过shape来实现对应的样式。

思路一

1.父布局设置边框stroke、solid、corners,padding。

2.子布局根据android:state_selected展示选中的布局样式,并把corners的大小设置成和父布局一致。

3.在color目录中编写布局,根据android:state_selected设置选中和默认的字体颜色。

4.在Java代码中根据点击事件设置view.setSelect(true).

其中第二步设置子布局的corners非常重要。因为shape设置为rectangle默认没有圆角,这样子布局就会覆盖父布局的圆角,显式为矩形。

代码如下:

父布局的shape如下:

注意:这里的paddingstroke设置成一致,才能正常展示出父布局的stroke。要不然会被子布局覆盖。

<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
    android:dither="true">
    <stroke
        android:color="#10B3B7"
        android:width="@dimen/dp_1"
        />
    <corners android:radius="@dimen/dp_8" />
    <solid android:color="#10B3B7"/>
<padding android:top="@dimen/dp_1" android:left="@dimen/dp_1" android:right="@dimen/dp_1" android:bottom="@dimen/dp_1"/>
</shape>

左边的子布局shape如下:

注意:其中左上角和左下角的圆角和父布局保持一致。

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
    <item android:state_selected="true" >
        <shape android:shape="rectangle">
            <solid android:color="#10B3B7"/>
            <corners android:topLeftRadius="@dimen/dp_8" android:bottomLeftRadius="@dimen/dp_8" />
        </shape>
    </item>
    <item>
        <shape android:shape="rectangle" android:dither="true">
            <solid android:color="@color/white"/>
            <corners android:topLeftRadius="@dimen/dp_8" android:bottomLeftRadius="@dimen/dp_8" />
        </shape>
    </item>
</selector>

右边的子布局shape如下:

注意:其中右上角和右下角的圆角和父布局保持一致。

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
    <item android:state_selected="true">
        <shape android:shape="rectangle" android:dither="true">
            <solid android:color="#10B3B7"/>
            <corners android:topRightRadius="@dimen/dp_8" android:bottomRightRadius="@dimen/dp_8" />
        </shape>
    </item>
    <item>
        <shape android:shape="rectangle" android:dither="true">
            <solid android:color="@color/white"/>
            <corners android:topRightRadius="@dimen/dp_8" android:bottomRightRadius="@dimen/dp_8" />
        </shape>
    </item>
   
</selector>

展示界面布局如下:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:gravity="center_horizontal"
    >
<LinearLayout
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_margin="@dimen/dp_8"
    android:background="@drawable/bg_father_shape"
    android:orientation="horizontal">
    <TextView
        android:id="@+id/tv_left"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="@string/core_measure_view"
        android:textSize="@dimen/sp_18"
        android:gravity="center"
        android:layout_weight="1"
        android:textColor="@color/core_measure_text_selector"
        android:background="@drawable/bg_left_selector"
        android:padding="@dimen/dp_10"
        />
    <TextView
        android:id="@+id/tv_right"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="@string/all_measure_view"
        android:textSize="@dimen/sp_18"
        android:gravity="center"
        android:layout_weight="1"
        android:textColor="@color/core_measure_text_selector"
        android:background="@drawable/bg_right_selector"
        android:padding="@dimen/dp_10"
        />
</LinearLayout>
</LinearLayout>

运行到手机效果如下:

在这里插入图片描述

猛一看似乎和设计图没有什么区别,左右点击切换也没有问题。

但仔细查看,特别是未选中选项卡的圆角,父布局和子布局有些重叠,致使看起来有些模糊。出现这种情况的原因是设置了父布局的paddingstroke.由于是圆角,所以设置的padding和实际的间隔会有偏差,这样才造成重叠的情况。

如果父布局没有设置stroke或者对布局要求没有那么严格,使用上面的方式完全是可行的。

但是。。。

对于追求完美的我们,还是想办法实现和设计图一致的效果。

既然是由于父布局设置paddingstroke造成的,那就不适用父布局,直接在每个子布局中设置stroke是否可行呢。

思路二

1.单独编写各种情况的子布局样式。设置一致的stroke.

2.处理相邻子布局相交的线,设置成不展示该线,或者只展示其中一个子布局的相交线。

3.子布局根据android:state_selected展示选中的布局样式。

4.在color目录中编写布局,根据android:state_selected设置选中和默认的字体颜色。

5.在Java代码中根据点击事件设置view.setSelect(true).

关于第二条, 多个有相同边框的 view 拼接在一块,会有重复的边框,造成中间边框变粗,从而影响效果。 处理方式是使用标签layer-list来隐藏矩形的某个边。 比如右边 view 的左边框设置为 - 1dp(绝对值和边框一致),则右边 view 的左边框不再显示。或者给左边 view 的右边框设置为 - 1dp(绝对值和边框一致) 亦可。

左边选中的样式代码如下:

<?xml version="1.0" encoding="utf-8"?>
<layer-list xmlns:android="http://schemas.android.com/apk/res/android">
    <item
        android:right="-1dp">
        <shape>
            <!-- 背景颜色 -->
            <solid android:color="#10B3B7" />
            <!-- 边框颜色 -->
            <stroke
                android:width="@dimen/dp_1"
                android:color="@color/actionbar_bg" />
            <corners
                android:topLeftRadius="@dimen/dp_8"
                android:bottomLeftRadius="@dimen/dp_8" />
        </shape>
    </item>
</layer-list>

左边未选中的样式代码如下:

<?xml version="1.0" encoding="utf-8"?>
<layer-list xmlns:android="http://schemas.android.com/apk/res/android">
    <item
        android:right="-1dp">
        <shape>
            <!-- 背景颜色 -->
            <solid android:color="@color/white" />
            <!-- 边框颜色 -->
            <stroke
                android:width="@dimen/dp_1"
                android:color="#10B3B7" />
            <corners
                android:topLeftRadius="@dimen/dp_8"
                android:bottomLeftRadius="@dimen/dp_8" />
        </shape>
    </item>
</layer-list>

左边布局的样式代码如下:

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
    <item android:state_selected="true" android:drawable="@drawable/bg_left_have_selector"/>
    <item  android:drawable="@drawable/bg_left_no_selector"/>
</selector>

右边布局的样式代码和左边的大致一致。这里就不展示啦。

最后运行到手机的效果如下:

在这里插入图片描述

和实际的设计图还是很接近的。完美~

总结

1.如果父布局不设置stroke,使用思路一就可以很好的实现。

2.父布局设置了stroke,使用思路二。

  移动开发 最新文章
Vue3装载axios和element-ui
android adb cmd
【xcode】Xcode常用快捷键与技巧
Android开发中的线程池使用
Java 和 Android 的 Base64
Android 测试文字编码格式
微信小程序支付
安卓权限记录
知乎之自动养号
【Android Jetpack】DataStore
上一篇文章      下一篇文章      查看所有文章
加:2021-07-07 00:02:59  更:2021-07-07 00:03:02 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/28 11:44:17-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码