【问题标题】:Android switch - change background of switch at on / offAndroid switch - 在开/关时更改开关的背景
【发布时间】:2015-03-11 07:52:51
【问题描述】:

有人知道如何在我的应用程序中实现这样的开关吗?

或者我如何在打开/关闭时更改标准开关的背景颜色?

【问题讨论】:

  • 通过设置切换开关时的背景。您甚至可以添加动画以使其看起来不错!很高兴能帮助到你......
  • 你想要滑动切换还是改变背景的代码?
  • 您可以在函数onCheckedChanged中更改它。这是给你的link。你可以在android中使用selector来改变背景。这是link给你的。
  • 我认为 dev.bmax 的回答应该被接受一个

标签: android xml


【解决方案1】:

下面是示例 XML,供您开始:

<Switch
    android:layout_width="75dp"
    android:layout_height="25dp"
    android:id="@+id/switch1"
    android:layout_centerVertical="true"
    android:layout_centerHorizontal="true"
    android:track="@drawable/switch_track_selector"
    android:switchMinWidth="75dp"
    android:thumb="@drawable/switch_thumb_selector" />

switch_track_selector.xml

<selector xmlns:android="http://schemas.android.com/apk/res/android">
    <item
        android:drawable="@drawable/switch_track_on"
        android:state_checked="true"/>

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

</selector>

switch_track_on.xml

<shape
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:shape="rectangle" >

    <corners
        android:radius="15dp" />
    <size
        android:width="75dp"
        android:height="25dp" />
    <solid
        android:color="#3E98F3" />
    <stroke
        android:width="1dp"
        android:color="#000000" />
</shape>

switch_track_off.xml

<shape
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:shape="rectangle" >

    <corners
        android:radius="15dp" />
    <size
        android:width="75dp"
        android:height="25dp" />
    <solid
        android:color="#FFFFFF" />
    <stroke
        android:width="1dp"
        android:color="#000000" />
</shape>

switch_thumb_selector.xml

<selector xmlns:android="http://schemas.android.com/apk/res/android">
    <item 
        android:drawable="@drawable/switch_thumb"
        android:state_checked="true"/>

    <item 
        android:drawable="@drawable/switch_thumb"
        android:state_checked="false"/>

</selector>

switch_thumb.xml

<shape
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:shape="oval">

    <size
        android:width="25dp"
        android:height="25dp" />

    <solid
        android:color="#CCCCCC" />

    <stroke
        android:width="1dp"
        android:color="#000000" />

</shape>

【讨论】:

  • 拯救了我的一天。只是一个建议:切换按钮在没有边框 (0dp) 的情况下看起来好多了,所以在示例中的宽度可能是 0dp 而不是 1。
  • 这是一个完美的答案,无需任何额外的努力就能节省您的时间和时间
  • 不知道为什么没有选择这个作为答案。
  • 太棒了,很少见到比这更好的答案。但是对于较旧的 API 版本看起来不太好,所以我只为较新的版本添加了 values-21
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2020-11-12
  • 1970-01-01
相关资源
最近更新 更多