4

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

<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>

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

我需要的是一个可以拉伸的背景,并且在按钮的中心有一个不能拉伸的图标。

可能吗?

4

5 回答 5

13

这是我的最终解决方案。

在布局中:

<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>
于 2012-10-05T09:22:05.473 回答
5

我以这种方式完成了相同的任务,按钮:

        <ToggleButton  android:id="@+id/mlAbout"
            android:textOn="@string/about"
            android:textOff="@string/about"
            android:background="@drawable/ml_about" />

@drawable/ml_about:

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

@drawable/list_bg_top 将被拉伸的背景图像,@drawable/waiting_status_btn 是不会被小部件拉伸的图标

于 2012-10-04T11:41:48.110 回答
2

只需在选择器中使用位图而不是可绘制对象(无需使用图层):

<?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>

另外,不要忘记在 ToggleButton 声明中声明 android:textOff="" android:textOn=""

于 2013-12-11T13:23:58.967 回答
1

肯定会帮助你

于 2012-10-04T11:40:37.487 回答
0

还有另一种克服拉伸问题的方法:

只需将图像转换为九补丁图像,其中可拉伸区域就在图像的所有侧面。

然后Android只会在不可见区域拉伸图像,并保持可见图像不变。

于 2014-04-28T20:29:50.663 回答