Android開發(fā)手冊Button實現selector選擇器
selector是按鈕最常用的功能,對美化控件的作用很大。
上節(jié)我們說了selector和shape聯合使用,但偏向shape的介紹,今天主要說selector。
??實踐過程
我們先按照上一節(jié)的shape方式創(chuàng)建兩個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】右鍵創(chuàng)建個Drawable Resource File ,彈出框寫文件名創(chuàng)建文件,設置默認【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>
我們運行下看看
但是
我們回憶下,剛才是不是創(chuàng)建了三個文件,按鈕少的情況下還好,自定義的按鈕一多,這么多文件非常不容易管理,所以我們要用另外一種寫法,將所有內容放到一個文件中。
我們在剛才的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 布爾值,控件是否處于活動狀態(tài)
- state_single和state_first和state_middle很少使用,知道就行
以上就是Android開發(fā)手冊Button實現selector選擇器的詳細內容,更多關于Android開發(fā)Button selector選擇器的資料請關注腳本之家其它相關文章!
相關文章
Android開發(fā)實現帶有反彈效果仿IOS反彈scrollview教程詳解
本文給大家分享android開發(fā)實現帶有反彈效果,模仿ios反彈scrollview詳細教程,本文介紹的非常詳細,具有參考借鑒價值,感興趣的朋友一起看看吧2016-09-09Android實戰(zhàn)教程第四篇之簡單實現短信發(fā)送器
這篇文章主要為大家詳細介紹了Android實戰(zhàn)教程第四篇之簡單實現短信發(fā)送器,具有一定的參考價值,感興趣的小伙伴們可以參考一下2016-11-11Android Studio 視頻播放失敗 start called in state1 異常怎么解決
很多朋友問小編在使用MediaPlayer播放音頻時報出 E/MediaPlayerNative: start called in state 1, mPlayer(0x0)問題,該如何處理呢,今天小編給大家?guī)砹薃ndroid Studio 視頻播放失敗 start called in state1 異常問題,需要的朋友可以參考下2020-03-03Android Shader應用開發(fā)之霓虹閃爍文字效果
這篇文章主要為大家詳細介紹了Android Shader應用開發(fā)之霓虹閃爍文字效果,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-07-07解決Error:All flavors must now belong to a named flavor dimens
這篇文章主要介紹了解決Error:All flavors must now belong to a named flavor dimension. Learn more at https://d.android.com,需要的朋友可以參考下2017-11-11Android TextView和ImageView簡單說明
Android TextView和ImageView簡單說明,需要的朋友可以參考一下2013-03-03