按钮不会改变颜色onClick

时间:2013-09-19 07:30:27

标签: android button colors

我想我已经得到了所需要的东西。我想在state_pressed上更改按钮的颜色。我有以下资源:

具有以下内容的值中的color.xml:

<?xml version="1.0" encoding="utf-8"?>
<resources>
    <color name="blue">#045FB4</color>
    <color name="clicked">#A9E2F3</color>
</resources>

drawable文件夹中的button_dashboard,内容如下:

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

    <item android:drawable="@color/blue" />
    <item android:drawable="@color/clicked" android:state_pressed="true"/>

</selector>

最后我的布局中的这个按钮:

<Button
        android:id="@+id/button2"
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:layout_weight="1.0"
        android:background="@drawable/button_dashboard"
        android:text="Button" />

我做错了吗?我还没有编写任何onClick代码,因为此时不需要(只是试验)。

6 个答案:

答案 0 :(得分:3)

尝试:

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

        <item android:drawable="@color/clicked" android:state_pressed="true"/>
        <item android:drawable="@color/blue" />


    </selector>

答案 1 :(得分:1)

将drawable文件夹中button_dashboard的内容更改为此

<?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/clicked" />

        </shape>
    </item>
    <item>
        <shape>
            <solid
                android:color="@color/blue" />
        </shape>
    </item>
</selector>

最后在你的布局中使用了这个按钮:

<Button
        android:id="@+id/button2"
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:layout_weight="1.0"
        android:background="@drawable/button_dashboard"
        android:text="Button" />

希望这会有所帮助..

答案 2 :(得分:0)

使用这个 可拉伸/ selector.xml

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android" >
     <item android:state_focused="true" android:drawable="@color/Red"/>
     <item android:state_pressed="true" android:drawable="@color/Red" />
     <item android:drawable="@color/White" /> 
</selector>

并在oncreate方法中设置为按钮的背景

btn.setBackgroundResource(R.drawable.selector);

答案 3 :(得分:0)

将以下行添加到按钮布局中:

android:clickable="true"

因此,布局中的按钮现在应为:

<Button
        android:id="@+id/button2"
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:layout_weight="1.0"
        android:clickable="true"
        android:background="@drawable/button_dashboard"
        android:text="Button" />

答案 4 :(得分:0)

在button_dashboard中再添加一行

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

    <item android:drawable="@color/clicked" android:state_pressed="true"/>
    <item android:drawable="@color/clicked" android:state_selected="true"/>
    <item android:drawable="@color/blue" />

</selector>

在此之后,请将一行代码添加到按钮单击侦听器

button2.setSelected(true);

希望这会对你有所帮助。

答案 5 :(得分:0)

怎么样?

<?xml version="1.0" encoding="utf-8" ?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">    
    <item android:state_pressed="true">        
        <color android:color="@color/clicked" />    
    </item>    
    <item android:state_pressed="false">        
        <color android:color="@color/blue" />    
    </item>
 </selector>