Android中Button自定义点击效果

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

    <item android:drawable="@drawable/pressed" android:state_enabled="true" android:state_focused="true"/>
    <item android:drawable="@drawable/pressed" android:state_enabled="true" android:state_pressed="true"/>
    <item android:drawable="@drawable/normal"/> <!-- 默认时的背景图片,必须在最后呀,否则无效-->

</selector>
<Button
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:background="@drawable/selector"
    android:text="自定义Btn点击效果" />

android:state_enabled   设置是否响应事件,指所有事件

另外,需要注意selector中 `item` 的顺序:一旦前面的一个 `item` 已经满足匹配的状态,后面的 `item` 就不会去执行了。


android:state_pressed

Boolean. "true" if this item should be used when the object is pressed (such as when a button is touched/clicked); "false" if this item should be used in the default, non-pressed state.

如果是true,当被点击时显示该图片,如果是false没被按下时显示默认。

android:state_focused

Boolean. "true" if this item should be used when the object is focused (such as when a button is highlighted using the trackball/d-pad); "false" if this item should be used in the default, non-focused state.

true,获得焦点时显示;false,没获得焦点显示默认。

android:state_selected

Boolean. "true" if this item should be used when the object is selected (such as when a tab is opened); "false" if this item should be used when the object is not selected.

true,当被选择时显示该图片;false,当未被选择时显示该图片。

android:state_checkable
Boolean. "true" if this item should be used when the object is checkable; "false" if this item should be used when the object is not checkable. (Only useful if the object can transition between a checkable and non-checkable widget.)
true,当CheckBox能使用时显示该图片;false,当CheckBox不能使用时显示该图片。

android:state_checked

Boolean. "true" if this item should be used when the object is checked; "false" if it should be used when the object is un-checked.

true,当CheckBox选中时显示该图片;false,当CheckBox为选中时显示该图片。

android:state_enabled

Boolean. "true" if this item should be used when the object is enabled (capable of receiving touch/click events); "false" if it should be used when the object is disabled.

true,当该组件能使用时显示该图片;false,当该组件不能使用时显示该图片。

android:state_window_focused

Boolean. "true" if this item should be used when the application window has focus (the application is in the foreground), "false" if this item should be used when the application window does not have focus (for example, if the notification shade is pulled down or a dialog appears).

true,当此activity获得焦点在最前面时显示该图片;false,当没在最前面时显示该图片。

<!-- 以下是配置button中的文字效果 -->
<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
    <item android:state_selected="true" android:color="#FFF" />
    <item android:state_focused="true" android:color="#FFF" />
    <item android:state_pressed="true" android:color="#FFF" />
    <item android:color="#000" />
</selector>


你可以通过定义drawable文件来自定义Android Button点击背景。以下是一个简单的示例: 首先,创建一个名为 `button_bg.xml` 的 drawable 文件,它将作为按钮的背景。在该文件添加以下内容: ```xml <selector xmlns:android="http://schemas.android.com/apk/res/android"> <item android:drawable="@drawable/button_pressed" android:state_pressed="true"/> <item android:drawable="@drawable/button_normal"/> </selector> ``` 在此示例,使用了 `selector` 标签来定义按钮的状态,并在不同状态下使用不同的 drawable。具体来说,当按钮被按下时,将使用名为 `button_pressed` 的 drawable;否则,将使用名为 `button_normal` 的 drawable。 接下来,创建 `button_pressed.xml` 和 `button_normal.xml` 两个 drawable 文件,分别用于按钮按下和未按下状态的背景。这些文件可以根据你的需求进行定制。 例如,可以创建一个简单的 `button_pressed.xml` 文件,如下所示: ```xml <shape xmlns:android="http://schemas.android.com/apk/res/android" android:shape="rectangle"> <solid android:color="#FF4081"/> </shape> ``` 此文件,使用 `shape` 标签来定义一个矩形形状,并使用 `solid` 标签来填充矩形颜色。在此示例,填充颜色为粉红色。 最后,在你的布局文件,将按钮的背景设置为 `button_bg.xml`: ```xml <Button android:id="@+id/myButton" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="Click Me!" android:background="@drawable/button_bg"/> ``` 在此示例,使用 `android:background` 属性将按钮的背景设置为 `button_bg.xml`。现在,当按钮被按下时,它会使用 `button_pressed.xml` 定义的粉红色背景。否则,它将使用 `button_normal.xml` 定义的默认背景。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值