閱讀435 返回首頁    go 阿裏雲 go 技術社區[雲棲]


Android-----使用Button特效selector+shape

如果對係統的ui效果不滿意,可以用shape進行自定義


當然除了使用drawable這樣的圖片外今天談下自定義圖形shape的方法,對於button控件android上支持以下幾種屬性shape、gradient、stroke、corners等。

我們就以目前係統的button的selector為例說下:

<shape>
            <gradient
                android:startcolor="#ff8c00"
                android:endcolor="#ffffff"
                android:angle="270" />
            <stroke
                android:width="2dp"
                android:color="#dcdcdc" />
            <corners
                android:radius="2dp" />
            <padding
                android:left="10dp"
                android:top="10dp"
                android:right="10dp"
                android:bottom="10dp" />
        </shape>

 

對於上麵,這條shape的定義,分別為漸變,在gradient中startcolor屬性為開始的顏色,endcolor為漸變結束的顏色,下麵的angle是角度。接下來是stroke可以理解為邊緣,corners為拐角這裏radius屬性為半徑,最後是相對位置屬性padding。

對於一個button完整的定義可以為:

<?xml version="1.0" encoding="utf-8"?>
<selector
    xmlns:andro>
    <item android:state_pressed="true" >
        <shape>
            <gradient
                android:startcolor="#ff8c00"
                android:endcolor="#ffffff"
                android:angle="270" />
            <stroke
                android:width="2dp"
                android:color="#dcdcdc" />
            <corners
                android:radius="2dp" />
            <padding
                android:left="10dp"
                android:top="10dp"
                android:right="10dp"
                android:bottom="10dp" />
        </shape>
    </item>

    <item android:state_focused="true" >
        <shape>
            <gradient
                android:startcolor="#ffc2b7"
                android:endcolor="#ffc2b7"
                android:angle="270" />
            <stroke
                android:width="2dp"
                android:color="#dcdcdc" />
            <corners
                android:radius="2dp" />
            <padding
                android:left="10dp"
                android:top="10dp"
                android:right="10dp"
                android:bottom="10dp" />
        </shape>
    </item>

    <item>        
        <shape>
            <gradient
                android:startcolor="#ff9d77"
                android:endcolor="#ff9d77"
                android:angle="270" />
            <stroke
                android:width="2dp"
                android:color="#fad3cf" />
            <corners
                android:radius="2dp" />
            <padding
                android:left="10dp"
                android:top="10dp"
                android:right="10dp"
                android:bottom="10dp" />
        </shape>
    </item>
</selector>

 

注意!提示大家,以上幾個item的區別主要是體現在state_pressed按下或state_focused獲得焦點時,當當來判斷顯示什麼類型,而沒有state_xxx屬性的item可以看作是常規狀態下。

 

<?xml version="1.0" encoding="utf-8"?>

<selector xmlns:andro >

<item

android:color="hex_color"

android:state_pressed=["true" | "false"]

android:state_focused=["true" | "false"]

android:state_selected=["true" | "false"]

android:state_active=["true" | "false"]

android:state_checkable=["true" | "false"]

android:state_checked=["true" | "false"]

android:state_enabled=["true" | "false"]

android:state_window_focused=["true" | "false"] />

</selector>

 

elements:

<selector>

必須。必須是根元素。包含一個或多個<item>元素。

attributes:

xmlns:android

string,必須。定義xml的命名空間,必須是

“https://schemas.android.com/apk/res/android”.

<item>

定義特定狀態的color,通過它的特性指定。必須是<selector>的子元素。

attributes:

android:color

16進製顏色。必須。這個顏色由rgb值指定,可帶alpha。

這個值必須以“#”開頭,後麵跟隨alpha-red-green-blue信息:

l #rgb

l #argb

l #rrggbb

l #aarrggbb

android:state_pressed

boolean。“true”表示按下狀態使用(例如按鈕按下);“false”表示非按下狀態使用。

android:state_focused

boolean。“true”表示聚焦狀態使用(例如使用滾動球/d-pad聚焦button);“false”表示非聚焦狀態使用。

android:state_selected

boolean。“true”表示選中狀態使用(例如tab打開);“false”表示非選中狀態使用。

android:state_checkable

boolean。“true”表示可勾選狀態時使用;“false”表示非可勾選狀態使用。(隻對能切換可勾選—非可勾選的構件有用。)

android:state_checked

boolean。“true”表示勾選狀態使用;“false”表示非勾選狀態使用。

android:state_enabled

boolean。“true”表示可用狀態使用(能接收觸摸/點擊事件);“false”表示不可用狀態使用。

android:window_focused

boolean。“true”表示應用程序窗口有焦點時使用(應用程序在前台);“false”表示無焦點時使用(例如notification欄拉下或對話框顯示)。

注意:記住一點,statelist中第一個匹配當前狀態的item會被使用。因此,如果第一個item沒有任何狀態特性的話,那麼它將每次都被使用,這也是為什麼默認的值必須總是在最後(如下麵的例子所示)。

 

examples:

xml文件保存在res/color/button_text.xml

<?xml version="1.0" encoding="utf-8"?>

<selector xmlns:andro>

<item android:state_pressed="true"

android:color="#ffff0000"/> <!-- pressed -->

<item android:state_focused="true"

android:color="#ff0000ff"/> <!-- focused -->

<item android:color="#ff000000"/> <!-- default -->

</selector>

 

這個layout xml會應用colorstatelist到一個view上:

<button

android:layout_width="fill_parent"

android:layout_height="wrap_content"

android:text="@string/button_text"

android:textcolor="@color/button_text" />

最後更新:2017-04-02 17:28:39

  上一篇:go 避免出現bitmap內存限製OUT OF MEMORY的一種方法
  下一篇:go android-gallery遊覽圖片點擊圖片放大