自定义安卓SWITCH样式

本文介绍了如何在Android Studio中创建一个自定义的SWITCH组件。通过新建XML文件定义滑块和滑轨样式,以及在styles.xml中设置文字样式,最后在activity.xml布局文件中添加开关,完成自定义SWITCH的实现。

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

一,在AndroidStudio新建一个工程

二,在RES \可绘制文件夹新建4个XML文件

switch_thumb.xml是滑块样式

<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
    android:shape="oval">
    <size
        android:width="30dp"
        android:height="30dp">
    </size>
    <solid
        android:color="@android:color/white">
    </solid>

</shape>

switch_track.xml是滑轨样式

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">

    <item android:state_checked="true"  android:drawable="@drawable/switch_track_on"/>
    <item android:state_checked="false" android:drawable="@drawable/switch_track_off"/>

</selector>

switch_track_off.xml是OFF状态时滑轨样式

<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
    android:shape="rectangle">
    <solid
        android:color="@android:color/darker_gray">
    </solid>

    <size
        android:width="150dp"
        android:height="50dp"/>
    <corners
        android:radius="32dp">
    </corners>
</shape>

switch_track_on.xml是ON状态时滑轨样式

<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
    android:shape="rectangle">

    <solid
        android:color="@android:color/holo_green_light">
    </solid>
    <size
        android:width="150dp"
        android:height="50dp"/>
    <corners
        android:radius="32dp">
    </corners>

</shape>

 

三,在res \ values \ styles.xml文件里添加如下代码

<style name="My.TextAppearance" parent="@style/TextAppearance.AppCompat.Widget.Switch">

        <item name="android:textSize">20dp</item>

        <item name="android:textColor">#000</item>

    </style>

这段代码主要控制切换开关文字大小和颜色

四,在RES \布局\ activity.xml文件里添加开关

<Switch
        android:id="@+id/switch1"
        android:layout_width="wrap_content"
        android:layout_height="0dp"
        android:layout_alignParentStart="true"
        android:layout_alignParentTop="true"
        android:layout_gravity="center_horizontal"
        android:layout_marginStart="348dp"
        android:layout_marginTop="172dp"
        android:layout_weight="1"
        android:checked="false"
        android:switchTextAppearance="@style/My.TextAppearance"
        android:textSize="50dp"
        android:thumb="@drawable/switch_thumb"
        android:track="@drawable/switch_track"
        tools:checked="true" />

至此,简单的自定义安卓SWITCH样式已完成。

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值