android - 在 Android 上自定义切换按钮

标签 android togglebutton

我通过使用选择器定义的可绘制对象自定义了切换按钮。我使用这个可绘制对象作为切换按钮的背景。

<ToggleButton
    android:id="@+id/mailbox:toggle_button"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_gravity="bottom"
    android:layout_weight="1"
    android:background="@drawable/toggle_background"
    android:gravity="center_horizontal|center_vertical" />

toggle_background 定义在这里:

    <?xml version="1.0" encoding="utf-8"?>
    <selector xmlns:android="http://schemas.android.com/apk/res/android">
        <item
            android:drawable="@drawable/img1"
            android:state_checked="true" />
        <item
            android:drawable="@drawable/img2"
            android:state_checked="false" />    
    </selector>

问题是图像总是被拉伸(stretch)。有没有办法为未拉伸(stretch)的两种状态定义图像?

我需要的是一个会被拉伸(stretch)的背景,并且在按钮的中心有一个不能被拉伸(stretch)的图标。

这可能吗?

最佳答案

这是我的最终解决方案。

在布局中:

<ToggleButton
    android:id="@+id/mailbox:toggle"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_weight="1"     
    android:background="@drawable/toggle_drawable_layers"/>

在 toggle_drawable_layers.xml 中

<?xml version="1.0" encoding="utf-8"?>
<layer-list xmlns:android="http://schemas.android.com/apk/res/android" >
    <item android:drawable="@drawable/toggle_drawable_bkg"></item>
    <item android:left="10dp" android:drawable="@drawable/toggle_drawable_left"
          android:gravity="center_vertical|center_horizontal" />
</layer-list>

在 toggle_drawable_left.xml 中

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
    <item android:state_checked="true">
        <bitmap android:src="@drawable/bitmap_checked"
          android:gravity="center_vertical|center_horizontal" />
    </item>
    <item android:state_checked="false">
        <bitmap android:src="@drawable/bitmap_unchecked"
          android:gravity="center_vertical|center_horizontal" />
    </item>        
</selector>

关于android - 在 Android 上自定义切换按钮,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12726289/

相关文章:

css - 将切换按钮分成多行

html - 将切换框的值添加到总计

javascript - 如何用 JavaScript 画一个简单的尺子?

java - get JSONException : Value of type java. 解析 JSON 响应时 lang.String 无法转换为 JSONObject

c# - 我可以更改弹出窗口的对齐方式,使其出现在按钮的左侧而不是右侧吗?

flutter - 如何在 flutter 中自定义切换按钮

android - 离线创建cordova 5.x android gradle build

android - 使用 JNI 时 eclipse 对 C 文件的意外行为,为什么会这样?

java - 如何检查 Cloud Storage for Firebase 上上传文件的文件类型?

android - 左右 Android 抽屉导航相互重叠