Android中的Selector的用法詳解及實例
Android中的Selector的用法
<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android" >
<item android:state_pressed="true" android:drawable="@drawable/bg_selected">
</item>
<item android:drawable="@drawable/bg_unselect">
</item>
</selector>
在工作的時候,由于系統(tǒng)給出的控件不夠美觀,因此開發(fā)時領導常常要我更改下界面,用美工給的圖片取代系統(tǒng)圖片。開始時,我只是給按鈕等設置一下背景圖片,這樣做雖然美觀了,但界面看起來卻比較死板,比如用戶點擊了按鈕后,按鈕沒一點反應。于是我就再給控件添加上onTouch監(jiān)聽事件,按下后改變背景顏色,松手后再恢復原來顏色。但后來發(fā)現(xiàn)了selector這個利器,真是喜出望外,不用再添加onTouch監(jiān)聽事件了,用起來也方便靈活。不得不說,多和其他開發(fā)人員交流技術經驗等還是很有必要的,特別是像我這樣獨自負責一個app開發(fā)的。
Android的selector要在 drawable 下配置。
其中,selector可以設置的屬性有:
android:state_pressed 如果是true,當被點擊時顯示該圖片,如果是false沒被按下時顯示默認。
android:state_focused 如果是true,獲得焦點時顯示;如果是false沒獲得焦點顯示默認。
android:state_selected 如果是true,當被選擇時顯示該圖片;是false未被選擇時顯示該圖片。
android:state_checkable 如果值為true,當CheckBox能使用時顯示該圖片;false,當CheckBox不能使用時顯示該圖片。
android:state_checked 如果值為true,當CheckBox選中時顯示該圖片;false,當CheckBox為選中時顯示該圖片。
android:state_enabled 如果值為true,當該組件能使用時顯示該圖片;false,當該組件不能使用時顯示該圖片。
android:state_window_focused 如果值為true,當此activity獲得焦點在最前面時顯示該圖片;false,當沒在最前面時顯示該圖片
這些屬性值也可以疊加使用,比如:
android:state_window_focused=”true” android:state_pressed=”true”
表明是非觸摸模式下獲得焦點并單擊時的背景圖片。
一般來說,Button控件只需要用 android:state_pressed就可以。比如,一個Button控件的背景設置為:
<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android" >
<item android:state_pressed="true" android:drawable="@drawable/bg_selected">
</item>
<item android:drawable="@drawable/bg_unselect">
</item>
</selector>
這表明該Button控件按下時,背景圖片是bg_selected,其它情況下(沒有被點擊或者點擊后松開等)背景圖片為bg_unselect。
selector除了可以設置組件的背景顏色外,也可以設置文字的顏色。比如某個Button控件被按下后,Button上的文字顏色也發(fā)生改變。例如:
<?xml version="1.0" encoding="utf-8"?> <selector xmlns:android="http://schemas.android.com/apk/res/android" > <item android:state_pressed="true" android:color="#ffffff"></item> <item android:color="#000000"></item> </selector>
即該Button控件的顏色為黑色,但按鈕按下后,顏色會變成白色。松開后,顏色恢復為黑色。
以上可以在代碼中這樣設置:
<Button android:layout_width="match_parent" android:layout_height="wrap_content" android:background="@drawable/btn_slector" android:text="abc" android:textColor="@drawable/text_selector" />
除了selector外,還有一個Shape,可以用來定制控件的圖形效果,兩者可以一起使用。
感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!
相關文章
如何通過Android Stduio來編寫一個完整的天氣預報APP
這篇文章主要介紹了通過Android Stduio來編寫一個天氣預報APP,具體的實現(xiàn)是通過調用天氣預報接口來獲得天氣數(shù)據,再將查詢的天氣信息存儲在SQLiteDatabase中,界面則用LIstView和GridView來搭建2021-08-08
Android開發(fā)中PopupWindow用法實例分析
這篇文章主要介紹了Android開發(fā)中PopupWindow用法,結合實例形式分析了PopupWindow彈出窗口效果的使用技巧,需要的朋友可以參考下2016-02-02
flutter PositionedTransition實現(xiàn)縮放動畫
這篇文章主要為大家詳細介紹了flutter PositionedTransition實現(xiàn)縮放動畫,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2019-07-07
Android App開發(fā)中ViewPager組件的入門使用教程
這篇文章主要介紹了Android App開發(fā)中ViewPager組件的入門使用教程,ViewPager主要用來實現(xiàn)通過滑動來切換頁面的效果,需要的朋友可以參考下2016-03-03
Android實現(xiàn)微信朋友圈評論EditText效果
這篇文章主要為大家詳細介紹了Android實現(xiàn)微信朋友圈評論EditText效果,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-11-11

