tag requires a 'drawable' attribute or child tag defining a drawab

异常日志:

Caused by: org.xmlpull.v1.XmlPullParserException: Binary XML file line #3: <item> tag requires a 'drawable' attribute or child tag defining a drawable


产生原因:

      我的一个button按钮的background属性中设置成"@color/button_text_selector",按照异常来说,这个background这个属性的值必须是drawable类型的,不能是color类型。


drawable&color:

本来我是想给button设置一个selector,让按钮背景正常状态下是一个颜色值,点击状态下背景又是另外一个值,但是没想到报了这样一个错误,既然background只能设置为drawable,那我就写一个drawable的selector给button设置不同状态下的颜色值,如下所示:
<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
    <!-- 点击状态下的效果 -->
    <item android:state_pressed="true">
        <shape>
            <!-- 设置背景填充色为黑色 -->
            <solid android:color="@color/black"/>
            <!-- 设置边框宽度为1dp,边框颜色为白色 -->
            <stroke android:width="1dp" android:color="@color/white" />
            <!-- 设置按钮圆角半径为5dp -->
            <corners android:radius="5dp" />
            <!-- 设置按钮中间文字距上下左右都为10dp的间距 -->
            <padding android:bottom="10dp" android:left="10dp" android:right="10dp" android:top="10dp" />
        </shape>
    </item>
    <!-- 正常状态下(非点击)的效果 -->
    <item android:state_pressed="false">
        <shape>
            <!-- 设置背景填充色为白色 -->
            <solid android:color="@color/white"/>
            <!-- 设置边框宽度为1dp,边框颜色为黑色 -->
            <stroke android:width="1dp" android:color="@color/black" />
            <!-- 设置按钮圆角半径为5dp -->
            <corners android:radius="5dp" />
            <!-- 设置按钮中间文字距上下左右都为10dp的间距 -->
            <padding android:bottom="10dp" android:left="10dp" android:right="10dp" android:top="10dp" />
        </shape>
    </item>

</selector>

这样即可对不同状态下的button设置颜色值了,还可以设置其他圆角之类的效果;当然这个只能设置按钮背景的效果,但是文字是没有点击效果的,如果使用我上面缩写的selector,那么就会在按下按钮的时候出现这个效果:
<item> tag requires a 'drawable' attribute or child tag defining a drawab_第1张图片
在按钮被点击的时候背景色和字体颜色混成一体,所以我们最好同时给字体颜色设置一个selector,如下:
<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
    <!-- button点击状态下的字体颜色 -->
    <item android:state_pressed="true" android:color="@color/white"></item>
    <!-- button正常状态下的字体颜色 -->
    <item android:state_pressed="false" android:color="@color/black"></item>
</selector>

最后在界面layout中设置button属性:
<Button
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="@string/button"
        android:background="@drawable/button_selector"
        android:textColor="@color/button_text_selector"/>

这样我们的button效果就会如图:
<item> tag requires a 'drawable' attribute or child tag defining a drawab_第2张图片
button正常状态下为白底黑字黑边,点击状态下为黑底白字白边。

demo下载:

http://download.csdn.net/detail/zhufuing/6974387

你可能感兴趣的:( tag requires a 'drawable' attribute or child tag defining a drawab)