Android 滑块开关 自定义Switch

自定义Switch开关:

复制代码
    <Switch
        android:id="@+id/switch_a"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:checked="true"
        android:thumb="@drawable/ccb_switch_thumb"
        android:track="@drawable/ccb_switch_track"
        />
XML 复制代码
<!-- ccb_switch_thumb -->
<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
    <item android:state_enabled="true">
        <selector>
            <item android:state_checked="true">
                <layer-list>
                    <item android:gravity="center_vertical" android:width="20dp" android:height="20dp"  android:drawable="@drawable/switch_on_normal_ov_on"/>
                </layer-list>
            </item>
            <item android:state_checked="false">
                <layer-list>
                    <item android:gravity="center_vertical" android:width="20dp" android:height="20dp" android:drawable="@drawable/switch_on_normal_ov_off" />
                </layer-list>
            </item>
        </selector>
    </item>
</selector>
XML 复制代码
<!-- ccb_switch_track -->
<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
    <item android:drawable="@drawable/switch_on_normal_bg_on" android:state_checked="true" />
    <item android:drawable="@drawable/switch_on_normal_bg_off" android:state_checked="false" />
</selector>
XML 复制代码
<!--    switch_on_normal_ov_on-->
<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
    android:shape="oval">
    <size
        android:width="22dp"
        android:height="22dp" />
    <stroke android:width="5dp" android:color="#00000000"/>
    <solid android:color="#ffffff"/>
</shape>
XML 复制代码
<!--    switch_on_normal_ov_off-->
<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
    android:shape="oval">
    <size
        android:width="22dp"
        android:height="22dp" />
    <stroke android:width="5dp" android:color="#00000000"/>
    <solid android:color="#cc8C93A2"/>
</shape>
XML 复制代码
<!--    switch_on_normal_bg_on -->
<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
    android:shape="rectangle">
    <solid android:color="#2166ff" />
    <corners android:radius="22dp"/>
    <size
        android:width="45dp"
        android:height="22dp" />
</shape>
XML 复制代码
<!--    switch_on_normal_bg_off -->
<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
    android:shape="rectangle">
    <solid android:color="#50787880" />
    <corners android:radius="22dp"/>
    <size
        android:width="45dp"
        android:height="22dp" />
</shape>
java 复制代码
        cSwitch.setOnCheckedChangeListener(new CompoundButton.OnCheckedChangeListener() {
            @Override
            public void onCheckedChanged(CompoundButton buttonView, boolean isChecked) {
                Log.i(TAG, "onCheckedChanged 改变状态为: "+isChecked);

            }
        });
        btnSwitch.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                cSwitch.setChecked(!isChecked);
            }
        });

笔记、仅供参考

相关推荐
sxczst33 分钟前
Launcher3 如何实现长按后可拖动?
android
诺诺Okami1 小时前
Android Framework-WMS-Window移除
android
小趴菜82274 小时前
Android TabLayout使用记录
android
梦终剧4 小时前
【Android之路】 Kotlin 的 data class、enum class、sealed interface
android·开发语言·kotlin
折翅鵬13 小时前
Android 程序员如何系统学习 MQTT
android·学习
搬砖的小码农_Sky13 小时前
如何将安卓应用迁移到鸿蒙?
android·华为·harmonyos
搬砖的小码农_Sky13 小时前
鸿蒙应用开发和安卓应用开发的区别
android·华为·harmonyos
2501_9160074713 小时前
iOS 混淆与团队协作,研发、安全、运维、测试如何在加固流程中高效配合(iOS 混淆、ipa 加固、协作治理)
android·ios·小程序·https·uni-app·iphone·webview
飞猿_SIR15 小时前
基于海思Hi3798MV200Android7.0聊聊HDMI色深模式和电视HDR
android·嵌入式硬件·音视频
come1123416 小时前
ptyhon 基础语法学习(对比php)
android·学习