Android 自定义开关按钮样式


用到shape形状和selector选择器


效果图:
在这里插入图片描述
在这里插入图片描述

1,定义一个drawable/shape_thumb_off.xml文件,定义开关关闭时,thumb滑块显示的效果。

<?xml version="1.0" encoding="utf-8"?>
<shape
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:shape="rectangle">
    <corners
        android:radius="50dp"
        />
    <size
android:height="20dp"
        android:width="20dp"
        />
    <!--填充色-->
    <solid
        android:color="@color/white"/>


</shape>

2,定义一个drawable/shape_thumb_on.xml文件,定义开关打开时,thumb滑块显示的效果。

<?xml version="1.0" encoding="utf-8"?>
<shape
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:shape="rectangle">
    <corners
        android:radius="50dp"
        />
    <size
android:height="30dp"
        android:width="30dp"
        />
    <!--填充色-->
    <solid
        android:color="@color/white"/>
    <!--描边-->
    <stroke
        android:width="1dp"
        android:color="@color/red"/>
</shape>

3,定义开关关闭状态下track轨迹的样式 drawable/shape_track_off.xml

<?xml version="1.0" encoding="utf-8"?>
<shape
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:shape="rectangle">
    <!--填充色-->
    <solid
        android:color="@color/gray"/>
<size
    android:width="50dp"
    android:height="30dp"
    />
<!--圆角-->
<corners
android:radius="30dp"
    />
</shape>

4,定义开关为打开状态下track轨迹的样式 drawable/shape_track_on.xml

<?xml version="1.0" encoding="utf-8"?>
<shape
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:shape="rectangle">
    <!--填充色-->
    <solid
        android:color="@color/red"/>
    <size
        android:width="50dp"
        android:height="30dp"
        />
<!--圆角-->
<corners
android:radius="30dp"
    />
</shape>

5,定义thumb滑块在打开关闭状态下的不同,,用selector选择器

<?xml version="1.0" encoding="utf-8"?>
<!--selector选择器 就是在不同的状态下设置不同的显示效果-->
<selector
    xmlns:android="http://schemas.android.com/apk/res/android"
    >
    <!--z状态是什么,-->
    <!-- 特使状态写在上面 正常状态写在最后-->


    <!-- android:state_checked="true",,当打开时候用@drawable/shape_thumb_on形状-->
    <item android:drawable="@drawable/shape_thumb_on" android:state_checked="true" />

    <item android:drawable="@drawable/shape_thumb" />


</selector>

6,定义track轨迹在打开关闭状态下的不同,,用selector选择器

<?xml version="1.0" encoding="utf-8"?>
<!--selector选择器 就是在不同的状态下设置不同的显示效果-->
<selector
    xmlns:android="http://schemas.android.com/apk/res/android"
    >
    <!--z状态是什么,-->
    <!-- 特使状态写在上面 正常状态写在最后-->


    <!-- -->
    <item android:drawable="@drawable/shape_track_on" android:state_checked="true" />

    <item android:drawable="@drawable/shape_track" />


</selector>

7,最后在布局文件中的定义。

  <Switch
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="开关按钮"
        android:showText="true"
        android:thumb="@drawable/selector_thumb"
        android:track="@drawable/selector_track"
        />

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值