Android開發手冊Button實現selector選擇器
selector是按鈕最常用的功能,對美化控件的作用很大。
上節我們說瞭selector和shape聯合使用,但偏向shape的介紹,今天主要說selector。
👉實踐過程
我們先按照上一節的shape方式創建兩個shape背景
btn_selector_shape1.xml
<?xml version="1.0" encoding="utf-8"?> <shape xmlns:android="http://schemas.android.com/apk/res/android" android:shape="rectangle"> <!-- 圓角 --> <corners android:radius="5dp" /> <!--填充顏色--> <solid android:color="#00ff00" /> </shape> 復制代碼
btn_selector_shape2.xml
<?xml version="1.0" encoding="utf-8"?> <shape xmlns:android="http://schemas.android.com/apk/res/android" android:shape="rectangle"> <!--圓角--> <corners android:radius="5dp" /> <!--填充顏色--> <solid android:color="#0000ff" /> </shape> 復制代碼
接著我們在【res-drawable】右鍵創建個Drawable Resource File ,彈出框寫文件名創建文件,設置默認【Root element】為selector。
btn_selector0.xml
<?xml version="1.0" encoding="utf-8"?> <selector xmlns:android="http://schemas.android.com/apk/res/android"> <item android:drawable="@drawable/btn_selector_shape1" android:state_pressed="true" /> <item android:drawable="@drawable/btn_selector_shape2" android:state_window_focused="false" /> </selector> 復制代碼
佈局中引用
<?xml version="1.0" encoding="utf-8"?> <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:app="http://schemas.android.com/apk/res-auto" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="match_parent" android:background="@color/white" tools:context=".TextActivity"> <Button android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_marginLeft="160dp" android:background="@drawable/btn_selector0" android:text="按下變色" android:textColor="@color/white" /> </RelativeLayout> 復制代碼
我們運行下看看
但是
我們回憶下,剛才是不是創建瞭三個文件,按鈕少的情況下還好,自定義的按鈕一多,這麼多文件非常不容易管理,所以我們要用另外一種寫法,將所有內容放到一個文件中。
我們在剛才的btn.selector0.xml中修改:
<?xml version="1.0" encoding="utf-8"?> <selector xmlns:android="http://schemas.android.com/apk/res/android"> <!--這是第一種方式,利用drwable引用文件--> <!--<item android:drawable="@drawable/btn_selector_shape1" android:state_pressed="true" />--> <!--<item android:drawable="@drawable/btn_selector_shape2" android:state_pressed="false" />--> <!--第二種方式如下--> <item android:state_pressed="false"> <shape android:shape="rectangle"> <!-- 圓角 --> <corners android:radius="5dp" /> <!--填充顏色為白色--> <solid android:color="#0000ff" /> </shape> </item> <!--單擊時是一個帶圓角,白色背景,綠色邊框的矩形--> <item android:state_pressed="true"> <shape android:shape="rectangle"> <!--圓角--> <corners android:radius="5dp" /> <!--填充顏色為白色--> <solid android:color="#00ff00" /> </shape> </item> </selector> 復制代碼
我們運行起來看看,哎,效果很正確啊
Selector的屬性不止這兩個哦:
- state_focused 佈爾值,是否獲得焦點
- state_window_focused 佈爾值,是否獲得窗口焦點
- state_enabled 佈爾值,控件是否可用
- state_checkable 佈爾值,控件可否被勾選
- state_checked 佈爾值,控件是否被勾選
- state_selected 佈爾值,控件是否被選擇,針對有滾輪的情況
- state_pressed 佈爾值,控件是否被按下
- state_active 佈爾值,控件是否處於活動狀態
- state_single和state_first和state_middle很少使用,知道就行
以上就是Android開發手冊Button實現selector選擇器的詳細內容,更多關於Android開發Button selector選擇器的資料請關註WalkonNet其它相關文章!
推薦閱讀:
- Android shape與selector標簽使用詳解
- Android開發手冊自定義Switch開關按鈕控件
- Android入門之SwitchButton的使用教程
- Android中Button實現點擊換圖案及顏色
- Android開發返回鍵明暗點擊效果的實例代碼