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>
復制代碼

我們運行下看看

image.png

image.png

但是

我們回憶下,剛才是不是創建瞭三個文件,按鈕少的情況下還好,自定義的按鈕一多,這麼多文件非常不容易管理,所以我們要用另外一種寫法,將所有內容放到一個文件中。

我們在剛才的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_singlestate_firststate_middle很少使用,知道就行

 

以上就是Android開發手冊Button實現selector選擇器的詳細內容,更多關於Android開發Button selector選擇器的資料請關註WalkonNet其它相關文章!

推薦閱讀: