效果圖如下所示:
一、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"><Buttonandroid: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控制項實現按鈕點擊變色,希望對大家有所協助,如果大家有任何疑問請給我留言,小編會及時回複大家的。在此也非常感謝大家對雲棲社區網站的支援!