自定义微调器,带圆角,描边和选择器图标

时间:2012-01-23 23:33:51

标签: android android-xml android-spinner

我希望我的Spinner有一个黑色渐变背景,左边是白色文字,右边是一个选择器图标(白色向下指向的三角形)。我认为有两种方法可以解决这个问题:

  1. 如果我将背景设置为xml可绘制资源,我可以让我的Spinner看起来很完美,但是我需要以某种方式在右边添加白色三角形,我不知道如何去吧:

    <?xml version="1.0" encoding="utf-8"?>
    <selector xmlns:android="http://schemas.android.com/apk/res/android">
    <item>
        <shape>
            <gradient
                android:startColor="#343434"
                android:endColor="#171717"
                android:angle="270" />
            <stroke
                android:width="1dp"
                android:color="#ffffff" />
            <corners
                android:radius="4dp" />
            <padding
                android:left="3dp"
                android:top="3dp"
                android:right="3dp"
                android:bottom="3dp" />
        </shape>
    </item>
    </selector>
    
  2. 我创建了一个包含三角形的9补丁图像,然后使用xml对角进行圆角处理并为图像添加笔划。我已经开始了,但无法使其发挥作用:

    <?xml version="1.0" encoding="utf-8"?>
    <selector xmlns:android="http://schemas.android.com/apk/res/android">
        <item android:drawable="@drawable/spinnerblack" >
            <stroke
                android:width="1dp"
                android:color="#ffffff" />
            <corners
                android:radius="3dp" />
            <padding
                android:left="3dp"
                android:top="3dp"
                android:right="3dp"
                android:bottom="3dp" />
        </item>
    </selector>
    
  3. 有人可以告诉我我可以为方法1做些什么,或者我在方法2中做错了什么?我不想在我的9补丁图像中添加笔划和圆角,因为我认为它看起来不那么好。此外,我更喜欢方法1到方法2.任何帮助都非常赞赏。

1 个答案:

答案 0 :(得分:12)

我在我的应用中做了类似于方法1的操作。基本上你需要将你的选择器与一个图层列表结合起来:

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
    <item>
        <layer-list>
            <item>
                <shape>
                    <gradient
                        android:startColor="#343434"
                        android:endColor="#171717"
                        android:angle="270" />
                    <stroke
                        android:width="1dp"
                        android:color="#ffffff" />
                    <corners
                        android:radius="4dp" />
                    <padding
                        android:left="3dp"
                        android:top="3dp"
                        android:right="3dp"
                        android:bottom="3dp" />
                </shape>
            </item>
            <item
                android:top="12dp"
                android:right="15dp">
                <bitmap android:src="@drawable/arrow_bitmap"
                        android:gravity="top|right" />
            </item>
        </layer-list>
    </item>
</selector>

在我的xml中,我还添加了一个第三层,其中包含一个不可见的<shape>(即它的alpha设置为0)但添加了填充。