Android 5.0 Button 按鈕水紋效果的適配問題

從5.0開始,一些控件的點(diǎn)擊時(shí)候默認(rèn)是有水紋效果的如下圖

這里寫圖片描述

以Button舉例可以按照如下使用:
注意是android:theme

<Button  
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:text="Button"
    android:theme="@style/MyButton"/>

自定義樣式:

<style name="MyButton" parent="Theme.AppCompat.Light">  
    <item name="colorControlHighlight">@color/indigo</item>
    <item name="colorButtonNormal">@color/pink</item>
</style>  

但是這樣在5.0以下的系統(tǒng),這樣就沒有效果,按鈕會變成默認(rèn)的灰色狀態(tài),點(diǎn)擊按鈕也不會有顏色的狀態(tài)區(qū)別
為了兼容5.0以下的設(shè)備,我們可以利用seletor(勘誤:button用theme在5.0以下也是有按壓變色的,雖然沒有水波紋,下面的方法仍然適用其他控件的適配)

 <Button
                android:id="@+id/confirm"
                style="@style/GreenButton"
                android:text="@string/confirm" />
  <style name="GreenButton">
        <item name="android:layout_width">match_parent</item>
        <item name="android:layout_height">@dimen/button_height_tall</item>
        <item name="android:background">@drawable/selector_green_button</item>
        <item name="android:textColor">@color/white</item>
        <item name="android:textSize">@dimen/font_large</item>
    </style>

我們可以在drawable和drawable-v21下新建同一份文件selector_green_button.xml

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">

    <item android:drawable="@color/deep_green" android:state_pressed="true" />

    <item android:drawable="@color/green" />
</selector>
<!--v21下 -->
<?xml version="1.0" encoding="utf-8"?>
<ripple xmlns:android="http://schemas.android.com/apk/res/android"
    android:color="@color/deep_green">//這里是擴(kuò)散水波紋的色值
    <item android:drawable="@color/green" />

</ripple>

有個(gè)問題需要注意,如果的想要你的波紋沒有按壓的時(shí)候?yàn)橥该鳡顟B(tài),下面的寫法是無效的.會導(dǎo)致按壓沒有效果

<!--v21下 -->
<?xml version="1.0" encoding="utf-8"?>
<ripple xmlns:android="http://schemas.android.com/apk/res/android"
    android:color="@color/deep_green">//這里是擴(kuò)散水波紋的色值
    <item android:drawable="@android:color/transparent" />//這里你用透明色和透明的圖片都是沒有效果的
</ripple>

正取的做法如下:

<!--v21下 -->
<?xml version="1.0" encoding="utf-8"?>
<ripple xmlns:android="http://schemas.android.com/apk/res/android"
    android:color="@color/deep_green">//這里是擴(kuò)散水波紋的色值
     <item android:id="@android:id/mask" android:drawable="@color/white" />里面的色值可以任選一個(gè)
</ripple>

android:id="@android:id/mask"會讓系統(tǒng)并不會真的繪制,并告知波紋的繪制邊界

如果寫成下面,波紋的繪制范圍會超出控件的邊界

<!--v21下 -->
<?xml version="1.0" encoding="utf-8"?>
<ripple xmlns:android="http://schemas.android.com/apk/res/android"
    android:color="@color/deep_green">//這里是擴(kuò)散水波紋的色值
</ripple>

如上,這樣設(shè)置后5.0以下的設(shè)備具有按鈕按下變色的效果,5.0以上就具有水波紋效果.其他控件同理

后續(xù):
Material Design Button 的 disable 效果

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末蕾额,一起剝皮案震驚了整個(gè)濱河市棠笑,隨后出現(xiàn)的幾起案子齐饮,更是在濱河造成了極大的恐慌妒茬,老刑警劉巖赴叹,帶你破解...
    沈念sama閱讀 210,978評論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件弓千,死亡現(xiàn)場離奇詭異齿诞,居然都是意外死亡酸休,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 89,954評論 2 384
  • 文/潘曉璐 我一進(jìn)店門祷杈,熙熙樓的掌柜王于貴愁眉苦臉地迎上來斑司,“玉大人,你說我怎么就攤上這事但汞《咐澹” “怎么了?”我有些...
    開封第一講書人閱讀 156,623評論 0 345
  • 文/不壞的土叔 我叫張陵特占,是天一觀的道長糙置。 經(jīng)常有香客問我,道長是目,這世上最難降的妖魔是什么谤饭? 我笑而不...
    開封第一講書人閱讀 56,324評論 1 282
  • 正文 為了忘掉前任,我火速辦了婚禮懊纳,結(jié)果婚禮上揉抵,老公的妹妹穿的比我還像新娘。我一直安慰自己嗤疯,他們只是感情好冤今,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,390評論 5 384
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著茂缚,像睡著了一般戏罢。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上脚囊,一...
    開封第一講書人閱讀 49,741評論 1 289
  • 那天龟糕,我揣著相機(jī)與錄音,去河邊找鬼悔耘。 笑死讲岁,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播缓艳,決...
    沈念sama閱讀 38,892評論 3 405
  • 文/蒼蘭香墨 我猛地睜開眼校摩,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了阶淘?” 一聲冷哼從身側(cè)響起秧耗,我...
    開封第一講書人閱讀 37,655評論 0 266
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎舶治,沒想到半個(gè)月后分井,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,104評論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡霉猛,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,451評論 2 325
  • 正文 我和宋清朗相戀三年尺锚,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片惜浅。...
    茶點(diǎn)故事閱讀 38,569評論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡瘫辩,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出坛悉,到底是詐尸還是另有隱情伐厌,我是刑警寧澤,帶...
    沈念sama閱讀 34,254評論 4 328
  • 正文 年R本政府宣布裸影,位于F島的核電站挣轨,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏轩猩。R本人自食惡果不足惜卷扮,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,834評論 3 312
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望均践。 院中可真熱鬧晤锹,春花似錦、人聲如沸彤委。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,725評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽焦影。三九已至车遂,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間偷办,已是汗流浹背艰额。 一陣腳步聲響...
    開封第一講書人閱讀 31,950評論 1 264
  • 我被黑心中介騙來泰國打工澄港, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留椒涯,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 46,260評論 2 360
  • 正文 我出身青樓回梧,卻偏偏與公主長得像废岂,于是被迫代替她去往敵國和親祖搓。 傳聞我的和親對象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,446評論 2 348

推薦閱讀更多精彩內(nèi)容