安卓自定义: swipe toggle button with image

标签 android android-layout togglebutton

我正在尝试在 Android 中构建一个自定义滑动切换按钮,我希望像下面的图像一样看起来像单选按钮但功能是切换按钮。谁来帮帮我。我该怎么办?

图片 1

enter image description here

最佳答案

尝试使用SlidingToggleSwithView

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    xmlns:switch="http://schemas.android.com/apk/res-auto"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical"
    android:paddingBottom="@dimen/activity_vertical_margin"
    android:paddingLeft="@dimen/activity_horizontal_margin"
    android:paddingRight="@dimen/activity_horizontal_margin"
    android:paddingTop="@dimen/activity_vertical_margin"
    tools:context="de.nitri.slidingtoggleswitchdemo.MainActivity$PlaceholderFragment" >

    <de.nitri.slidingtoggleswitch.SlidingToggleSwitchView
        android:id="@+id/sliding_toggle_switch"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:textColor="#ff000000"
        switch:leftButtonText="@string/left_button_text"
        switch:rightButtonText="@string/right_button_text" />

    <TextView
        android:id="@+id/textView1"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:gravity="center"
        android:textAppearance="?android:attr/textAppearanceLarge" />

</LinearLayout>

主 Activity .java

public class MainActivity extends FragmentActivity implements OnToggleListener {
    //...

    @Override
    public void onToggle(int result) {
        if (result == SlidingToggleSwitchView.LEFT_SELECTED)
            //...
        else
            //...
    }

}

red_button_background.xml

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android" >
    <item android:state_pressed="true">
    <shape>
        <gradient
            android:startColor="#ffcc1a03"
            android:endColor="#fffd280c"
            android:angle="270" />
        <corners
            android:radius="3dp" />
        <padding
            android:left="10dp"
            android:top="10dp"
            android:right="10dp"
            android:bottom="10dp" />
    </shape>
</item>

<item android:state_focused="true" >
    <shape>
        <gradient
            android:endColor="#ffcc1a03"
            android:startColor="#fffd280c"
            android:angle="270" />
        <corners
            android:radius="3dp" />
        <padding
            android:left="10dp"
            android:top="10dp"
            android:right="10dp"
            android:bottom="10dp" />
    </shape>
</item>

<item android:state_enabled="false" >
    <shape>
        <gradient
            android:endColor="#fa515151"
            android:startColor="#fa989898"
            android:angle="270" />
        <corners
            android:radius="3dp" />
        <padding
            android:left="10dp"
            android:top="10dp"
            android:right="10dp"
            android:bottom="10dp" />
    </shape>
</item>

<item>        
    <shape>
        <gradient
            android:endColor="#ffcc1a03"
            android:startColor="#fffd280c"
            android:angle="270" />
        <corners
            android:radius="3dp" />
        <padding
            android:left="10dp"
            android:top="10dp"
            android:right="10dp"
            android:bottom="10dp" />
    </shape>
</item>

</selector>

toggle_frame_blue.xml

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

    <stroke
        android:width="2dp"
        android:color="@android:color/darker_gray" />

    <gradient
        android:angle="90"
        android:endColor="#FF3A9CE3"
        android:startColor="#FF6CBCF4" />

    <corners android:radius="10px" />

    <padding
        android:bottom="0dp"
        android:left="0dp"
        android:right="0dp"
        android:top="0dp" />

</shape>

输出

enter image description here enter image description here

关于安卓自定义: swipe toggle button with image,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36980801/

相关文章:

java - C2DM - 消息从服务器成功发送,但未显示在设备上

java - 如何更改 BottomNavigationView 中特定项目的 iconTint

android - 可变宽度 TextView 旁边的固定宽度 TextView

android - 如何将 ImageView 置于 CardView 之上?请查看详情

Android 切换按钮/分段按钮

javascript - 单击按钮启用和禁用

android - 无法从设备模拟器-5554 获取查看服务器版本和无法从设备模拟器-5554 获取查看服务器协议(protocol)版本

android - RelativeLayout 不执行 "match_parent"和 alignBottom

android - "Must supply height attribute"错误

wpf - 使用图像内容为 ToggleButton 设置快捷键