选择器中的Android按钮形状不起作用

时间:2016-02-12 18:17:03

标签: android button shape cornerradius

我有一个button和一个selector,必须更改color的{​​{1}},paddingcorner radius。我在更改button时没有任何问题,但我永远看不到colorpadding的任何更改。

corner radius

button_color.xml

<?xml version="1.0" encoding="utf-8"?> <selector xmlns:android="http://schemas.android.com/apk/res/android"> <item android:drawable="@color/button_disabled" android:state_enabled="false"> <shape android:shape="rectangle" android:padding="8dp"> <corners android:radius="4dp" /> </shape> </item> <item android:drawable="@color/button_pressed" android:state_pressed="true"> <shape android:shape="rectangle" android:padding="8dp"> <corners android:radius="4dp" /> </shape> </item> <item android:drawable="@color/button_focused" android:state_focused="true"> <shape android:shape="rectangle" android:padding="8dp"> <corners android:radius="4dp" /> </shape> </item> <item android:drawable="@color/colorAccent"> <shape android:shape="rectangle" android:padding="8dp"> <corners android:radius="4dp" /> </shape> </item> </selector> 的代码:

button

我知道一些笨拙的方法来获取 <LinearLayout> .... <Button android:layout_width="match_parent" android:layout_height="wrap_content" android:text="@string/add_to_fav" android:id="@+id/add" android:background="@drawable/button_color" android:textColor="@drawable/button_text_color" /> </LinearLayout> - 将它放入布局中,但1)它将是&#34;无用的父母&#34 ;; 2)我不会得到padding

那么我做错了什么,所以我没有corner radius

谢谢!

2 个答案:

答案 0 :(得分:2)

填充,颜色和角落应位于shape

所以试试这个:

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">

    <item android:state_enabled="false">
        <shape>
            <padding android:left="5dp" android:top="2dp"
                     android:right="5dp" android:bottom="2dp" />
            <corners android:radius="4dp" />
            <solid android:color="@color/colorPrimary"/>
        </shape>
    </item>
    <item android:state_pressed="true">
        <shape>
            <padding android:left="5dp" android:top="2dp"
                     android:right="5dp" android:bottom="2dp" />
            <corners android:radius="4dp" />
            <solid android:color="@color/colorAccent"/>
        </shape>
    </item>
    <item android:state_focused="true">
        <shape>
            <padding android:left="5dp" android:top="2dp"
                     android:right="5dp" android:bottom="2dp" />
            <corners android:radius="4dp" />
            <solid android:color="@color/colorPrimary"/>
        </shape>
    </item>
    <item>
        <shape>
            <padding android:left="5dp" android:top="2dp"
                     android:right="5dp" android:bottom="2dp" />
            <solid android:color="@color/colorPrimaryDark"/>
            <corners android:radius="4dp" />
        </shape>
    </item>

</selector>

这样他们都可以工作。

答案 1 :(得分:1)

android:radius值可能太小而无法显示效果。另一方面,padding的语法必须改变如下:

<item android:drawable="@color/button_focused" android:state_focused="true">
    <shape
        android:shape="rectangle">
        <corners android:radius="20dip" />
        <padding
            android:left="8dip"
            android:top="8dip"
            android:right="8dip"
            android:bottom="8dip" />

    </shape>
</item>

请注意:如documentation for Shape Drawable中所述,

  

填充以应用于包含的View元素(这会填充View内容的位置,而不是形状)。