我通过使用选择器定义的可绘制对象自定义了切换按钮。我使用这个可绘制对象作为切换按钮的背景。
<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/