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);
            }
        });

笔记、仅供参考

相关推荐
随遇丿而安2 小时前
第10周:Activity 基础功能与生命周期优化
android
alexhilton15 小时前
Android车载OS中的Remote Compose
android·kotlin·android jetpack
落魄Android在线炒饭1 天前
Android 自定义HAL开发篇之 HIDL篇——从入门到实战(上)
android
plainGeekDev1 天前
广播接收器 → Flow + Lifecycle
android·java·kotlin
plainGeekDev1 天前
EventBus → SharedFlow
android·java·kotlin
37手游移动客户端团队2 天前
招聘-高级安卓开发工程师
android·客户端
用户41659673693552 天前
WebView 请求异常排查操作手册
android·前端
Kapaseker2 天前
学不动了,入门 Compose Styles API
android·kotlin
墨狂之逸才3 天前
Android TV WebView 遥控器按键处理:从全透传到白名单
android
plainGeekDev3 天前
MVC 写法 → MVVM
android·java·kotlin