首頁 > Java > java教程 > 主體

Androidselector背景選擇器的使用詳解

高洛峰
發布: 2017-01-20 15:44:05
原創
1323 人瀏覽過

在開發應用程式中,很多情況下要設計listview或button控制項的背景,以下總結android的selector的用法:
1.在drawable中配置Android的selector。
將以下的XML檔案儲存成你自己命名的.xml檔案(例如item_bg.xml),並將該檔案放置在drawable檔案中,在系統使用時根據ListView中的清單項目的狀態來使用對應的背景圖片。

<?xml version="1.0" encoding="utf-8" ?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
    <!-- 默认时的背景图片-->
    <item android:drawable="@drawable/pic1" />
    <!-- 没有焦点时的背景图片-->
    <item android:state_window_focused="false" android:drawable="@drawable/pic1" />
    <!-- 非触摸模式下获得焦点并单击时的背景图片-->
    <item android:state_focused="true"  android:state_pressed="true"
       android:drawable="@drawable/pic2" />
    <!-- 触摸模式下单击时的背景图片-->
    <item android:state_focused="false" android:state_pressed="true"
       android:drawable="@drawable/pic3" />
    <!--选中时的图片背景-->
    <item android:state_selected="true" android:drawable="@drawable/pic4" />
    <!--获得焦点时的图片背景-->
    <item android:state_focused="true" android:drawable="@drawable/pic5" />
</selector>
登入後複製

2.使用上面的設定檔:
第一個方法是在listview設定檔中配置,程式碼如下:android:listSelector="@drawable/item_bg"
第二種方法是在listview的item中加入屬性,程式碼如下:android:background=“@dr​​awable/item_bg"
第三種方法是在java程式碼中設置,程式碼如下:Drawable drawable =getResources().getDrawable(R.drawable.item_bg); 
 ListView.setSelector( drawable);
上面的設定方法顯示效果有時候為黑,所以需要在設定檔上加上以下程式碼:android:cacheColorHint="@android:color/transparent" 使其背景是透明的。
同樣,Button也有一些背景效果,如下為屬性解釋:
android:state_selected是設定選取時的效果
android:state_focused是設定獲得焦點的效果
android:state_pressed是設定點選的效果
android:state_enabled是設定是否回應事件
下面是一個selector用來設定button中的文字狀態,程式碼如下:

<?xmlversion="1.0" encoding="utf-8"?>
<selectorxmlns:android="http://schemas.android.com/apk/res/android">
    <itemandroid:state_selected="true" android:color="#FFF" />
    <itemandroid:state_focused="true" android:color="#FFF" />
    <itemandroid:state_pressed="true" android:color="#FFF" />
    <itemandroid:color="#000" />
</selector>
登入後複製

更多Androidselector背景選擇器的使用詳解相關文章請關注PHP中文網!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板