android - 使用自定义可绘制对象的自定义开关显得很大

标签 android xml toggle toggleswitch

我正在使用 3 个可绘制文件制作自定义 switch。两个图标,OnOff,由 89x89 图像表示,以及一个 171x93 的自定义 Track 可绘制资源(黑色)。当我将自定义可绘制对象设置为开关时,它会拉伸(stretch)到图像的大小。我如何缩小这些图像以使其完全适合并且不大于文本本身?


这是我的switch xml:

<Switch
        android:layout_width="220dp"
        android:layout_height="wrap_content"
        android:id="@+id/switchAnimation"
        android:thumb="@drawable/my_switch"
        android:switchMinWidth="55dp"
        android:track="@drawable/toggle_track"
        android:textOff=""
        android:textOn=""
        android:textColor="#FFF"/>


开关的drawable my_switch.xml:

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


轨道的drawable:

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

我已经在两个模拟器设备 Galaxy nexus API 21 和 Nexus 4 API 19 上对此进行了测试。另一个问题,我还注意到在 API 19 设备中单击开关时没有像API 21(而不是图标只是出现和消失),这正常吗?! nexus 4 API 19 with custom black track

![没有自定义轨道的 nenxus 4 API 19][2]

galaxy nenxus API 21 with black track


编辑
我把资源变小了很多,25x25,现在看起来大小合适,但看起来有点像素化。有什么方法可以将质量图标缩小到更小的尺寸吗?

最佳答案

简单地添加不透明度为零的描边:

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
    <item android:state_checked="true" android:state_enabled="true">
        <shape android:shape="oval" android:visible="true">
            <solid android:color="@android:color/white" />
            <size android:width="20dp" android:height="20dp" />
            <stroke android:width="7dp" android:color="#00000000" />
        </shape>
    </item>
    <item android:state_checked="false" android:state_enabled="false">
        <shape android:shape="oval" android:visible="true">
            <solid android:color="#ccc" />
            <size android:width="20dp" android:height="20dp" />
            <stroke android:width="7dp" android:color="#00000000" />
        </shape>
    </item>
</selector>

Sample Image

关于android - 使用自定义可绘制对象的自定义开关显得很大,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29628301/

相关文章:

java - 如何从 GetDataTask 返回一个字符串到 onCreate

android - 无法在模拟器中启动 AVD 权限被拒绝

android - 如何为 android 创建类似 ibook 书架的用户界面?

php number_format 给出错误信息

android - 以编程方式将服务器证书信息添加到 Trust Manager Android

xml - 集成动态 XML 内容以在 Google/Bing 中建立索引的最佳方式

java - RSS 项目顺序,重要吗?

javascript - 如何在 html 中使用纯 javascript 切换类

jquery - 使用 JQuery Toggle 设置和检索变量

javascript - 如何找出 Dashgum Bootstrap 主题中切换导航背后的功能/编程?