欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  移动技术

Android 自定义Button控件实现按钮点击变色

程序员文章站 2024-03-02 11:26:10
效果图如下所示: 一、shape 样式:(在drawable新建--》new--》drawable resource file 在父级标签selector添加item...

效果图如下所示:

Android 自定义Button控件实现按钮点击变色

一、shape 样式:(在drawable新建--》new--》drawable resource file 在父级标签selector添加item )

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
<item android:state_pressed="true">
<shape android:shape="rectangle">
<solid android:color="#73c4f3" />
<stroke android:width="2dp" android:color="#ffffff" />
<corners android:radius="20dp" />
<padding android:bottom="5dp" android:left="10dp" android:right="10dp" android:top="5dp" />
<gradient android:angle="270" android:endcolor="#8accf2" android:startcolor="#8accf2" android:type="sweep" />
</shape>
<shape>
<solid android:color="#3fb3f6" />
<stroke android:width="2dp" android:color="#ffffff" />
<corners android:radius="20dp" />
<padding android:bottom="5dp" android:left="10dp" android:right="10dp" android:top="5dp" />
</shape>
</item>
</selector>

二、style 样式:

<style name="rectangle">
<item name="android:layout_width">match_parent</item>
<item name="android:layout_height">wrap_content</item>
<item name="android:textsize">15sp</item>
<item name="android:textcolor">#ffffff</item>
<item name="android:background">@drawable/buttonclickstyle</item>
</style>

三、button控件调用style样式:

<?xml version="1.0" encoding="utf-8"?>
<relativelayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:paddingbottom="@dimen/activity_vertical_margin"
android:paddingleft="@dimen/activity_horizontal_margin"
android:paddingright="@dimen/activity_horizontal_margin"
android:paddingtop="@dimen/activity_vertical_margin"
tools:context="com.example.ly.blogtest.mainactivity">
<button
android:id="@+id/button"
style="@style/rectangle"
android:text="@string/btn1" />
</relativelayout>

----------------------------------按钮点击变色-----------------------------------------------------

----------------------------------item属性标记------------------------------

android:state_pressed 是否按下,如一个按钮触摸或者点击。

android:state_focused 是否取得焦点,比如用户选择了一个文本框。

android:state_hovered 光标是否悬停,通常与focused state相同,它是4.0的新特性

android:state_selected 被选中,它与focus state并不完全一样,如一个list view 被选中的时候,它里面的各个子组件可能通过方向键,被选中了。

android:state_checkable 组件是否能被check。如:radiobutton是可以被check的。

android:state_checked 被checked了,如:一个radiobutton可以被check了。

android:state_enabled 能够接受触摸或者点击事件

android:state_activated 被激活

android:state_window_focused

应用程序是否在前台,当有通知栏被拉下来或者一个对话框弹出的时候应用程序就不在前台了

注意:如果有多个item,那么程序将自动从上到下进行匹配,最先匹配的将得到应用。(不是通过最佳匹配)

如果一个item没有任何的状态说明,那么它将可以被任何一个状态匹配。

----------------------------------item属性标记------------------------------

以上所述是小编给大家介绍的android 自定义button控件实现按钮点击变色,希望对大家有所帮助