UI之修改Button顏色保持默認(rèn)點(diǎn)擊效果

一花履、常用修改Button顏色并設(shè)置點(diǎn)擊效果方法

Android中Button的默認(rèn)顏色為灰色屎篱,并且?guī)в心J(rèn)的點(diǎn)擊效果,在5.0以上的系統(tǒng)還有漣漪的效果榜跌。通常在開發(fā)時(shí)我們都會(huì)
修改Button的顏色损搬,最常用的方式就是修改Button的背景顏色碧库,即“android:background”;只是修改簡(jiǎn)單的修改背景顏色的話Button就沒有點(diǎn)擊效果巧勤,這時(shí)我們一般會(huì)使用selector來實(shí)現(xiàn)點(diǎn)擊效果嵌灰;這樣處理不僅會(huì)增加工作量,也會(huì)丟失掉5.0以上系統(tǒng)的漣漪效果颅悉。

二沽瞭、使用Style修改Button顏色并保持默認(rèn)點(diǎn)擊效果

Android中我們也可以通過Style來設(shè)置Button的樣式

1. Style中Button樣式的設(shè)置

首先我們需要查看默認(rèn)的Button樣式是如何設(shè)置的,在.../res/styles.xml文件中我們可以看到應(yīng)用默認(rèn)的style

<style name="AppTheme" parent="Theme.AppCompat.Light.DarkActionBar">
    <!-- Customize your theme here. -->
    <item name="colorPrimary">@color/colorPrimary</item>
    <item name="colorPrimaryDark">@color/colorPrimaryDark</item>
    <item name="colorAccent">@color/colorAccent</item>
</style>

按住command鍵點(diǎn)擊“Theme.AppCompat.Light.DarkActionBar”剩瓶,或者選中按“command+B”快捷鍵繼續(xù)跟蹤查看

<style name="Theme.AppCompat.Light.DarkActionBar" parent="Base.Theme.AppCompat.Light.DarkActionBar"/>

繼續(xù)跟蹤查看“Base.Theme.AppCompat.Light.DarkActionBar”

<style name="Base.Theme.AppCompat.Light.DarkActionBar" parent="Base.Theme.AppCompat.Light">
    <item name="actionBarPopupTheme">@style/ThemeOverlay.AppCompat.Light</item>
    <item name="actionBarWidgetTheme">@null</item>
    <item name="actionBarTheme">@style/ThemeOverlay.AppCompat.Dark.ActionBar</item>

    <!-- Panel attributes -->
    <item name="listChoiceBackgroundIndicator">@drawable/abc_list_selector_holo_dark</item>

    <item name="colorPrimaryDark">@color/primary_dark_material_dark</item>
    <item name="colorPrimary">@color/primary_material_dark</item>
</style>

繼續(xù)跟蹤查看“Base.Theme.AppCompat.Light”時(shí)會(huì)提示有不同版本驹溃,通過一個(gè)個(gè)跟蹤查看可以知道城丧,最終繼承的parent style都是“Base.V7.Theme.AppCompat.Light”,在“Base.V7.Theme.AppCompat.Light”可以找到對(duì)Button樣式的定義

<style name="Base.V7.Theme.AppCompat.Light" parent="Platform.AppCompat.Light">
    ...

    <!-- Button styles -->
    <item name="buttonStyle">@style/Widget.AppCompat.Button</item>
    <item name="buttonStyleSmall">@style/Widget.AppCompat.Button.Small</item>
    <item name="android:textAppearanceButton">@style/TextAppearance.AppCompat.Widget.Button</item>

    ...
</style>

其中有設(shè)置了buttonStyle豌鹤,繼續(xù)跟蹤查看“Widget.AppCompat.Button”

<style name="Widget.AppCompat.Button" parent="Base.Widget.AppCompat.Button"/>

繼續(xù)跟蹤查看“Base.Widget.AppCompat.Button”時(shí)會(huì)提示有不同版本亡哄,如圖:


Base.Widget.AppCompat.Button.jpg

“Base.Widget.AppCompat.Button”不同版本有不同的實(shí)現(xiàn)

  • V21之前
<style name="Base.Widget.AppCompat.Button" parent="android:Widget">
    <item name="android:background">@drawable/abc_btn_default_mtrl_shape</item>
    <item name="android:textAppearance">?android:attr/textAppearanceButton</item>
    <item name="android:minHeight">48dip</item>
    <item name="android:minWidth">88dip</item>
    <item name="android:focusable">true</item>
    <item name="android:clickable">true</item>
    <item name="android:gravity">center_vertical|center_horizontal</item>
</style>
  • V21及V21之后
<style name="Base.Widget.AppCompat.Button" parent="android:Widget.Material.Button"/>
...
<style name="Widget.Material.Button">
    <item name="background">@drawable/btn_default_material</item>
    <item name="textAppearance">?attr/textAppearanceButton</item>
    <item name="minHeight">48dip</item>
    <item name="minWidth">88dip</item>
    <item name="stateListAnimator">@anim/button_state_list_anim_material</item>
    <item name="focusable">true</item>
    <item name="clickable">true</item>
    <item name="gravity">center_vertical|center_horizontal</item>
</style>

可以看到針對(duì)不同版本分別設(shè)置了Button的樣式。

2. btttonStyle中顏色的設(shè)置

通過分析Style傍药,可以知道可以通過buttonStyle來指定Button的樣式

<style name="AppTheme" parent="Theme.AppCompat.Light.DarkActionBar">
    <!-- Customize your theme here. -->
    <item name="colorPrimary">@color/colorPrimary</item>
    <item name="colorPrimaryDark">@color/colorPrimaryDark</item>
    <item name="colorAccent">@color/colorAccent</item>
    <!-- 設(shè)置button的Style -->
    <item name="buttonStyle">@style/Xxx</item>
</style>

在V7支持包中磺平,提供了5個(gè)預(yù)置的Button的Style,如下:

<style name="Widget.AppCompat.Button" parent="Base.Widget.AppCompat.Button"/>
<style name="Widget.AppCompat.Button.Colored" parent="Base.Widget.AppCompat.Button.Colored"/>
<style name="Widget.AppCompat.Button.Borderless" parent="Base.Widget.AppCompat.Button.Borderless"/>
<style name="Widget.AppCompat.Button.Borderless.Colored" parent="Base.Widget.AppCompat.Button.Borderless.Colored"/>
<style name="Widget.AppCompat.Button.Small" parent="Base.Widget.AppCompat.Button.Small"/>
Style 背景顏色屬性 文字顏色屬性 效果
.Button(默認(rèn)) colorButtonNormal textColor
(默認(rèn)黑色)
Widget.AppCompat.Button.jpg
.Button.Colored colorAccent textColor
(默認(rèn)白色)
Widget.AppCompat.Button.Colored.jpg
.Button.Borderless 透明 textColor
(默認(rèn)黑色)
Widget.AppCompat.Button.Borderless.jpg
.Button.Borderless.Colored 透明 textColor
(默認(rèn)colorAccent)
Widget.AppCompat.Button.Borderless.Colored.jpg
.Button.Small colorButtonNormal textColor
(默認(rèn)黑色)
Widget.AppCompat.Button.Small.jpg

3. 通過buttonStyle修改Button顏色

3.1 全局Button設(shè)置

直接在應(yīng)用主題中設(shè)置buttonStyle拐辽,然后通過相應(yīng)的屬性修改Button的背景色或文字顏色
如下:

<style name="AppTheme" parent="Theme.AppCompat.Light.DarkActionBar">
    <!-- Customize your theme here. -->
    <item name="colorPrimary">@color/colorPrimary</item>
    <item name="colorPrimaryDark">@color/colorPrimaryDark</item>
    <item name="colorAccent">@color/colorAccent</item>
    <item name="buttonStyle">@style/Widget.AppCompat.Button</item>
    <item name="colorButtonNormal">@color/colorBlue</item>
</style>
3.2 單個(gè)Button設(shè)置

在styles.xml文件中新建Style,繼承應(yīng)用Style擦酌,在其中設(shè)置buttonStyle俱诸,并通過相應(yīng)的屬性修改Button的背景色或文字顏色
然后在需要修改的Button中添加android:theme屬性,引用新建的Style即可

<style name="RedButton" parent="AppTheme">
    <item name="buttonStyle">@style/Widget.AppCompat.Button</item>
    <item name="colorButtonNormal">@color/colorRed</item>
</style>

在layout中使用

<Button
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:text="Button_1"
    android:theme="@style/RedButton" />
    <!-- 注意是android:theme屬性赊舶,不是style屬性 -->

三睁搭、修改Button圓角大小

目前只找到了全局修改Button圓角大小的方法
在dimes.xml文件中復(fù)寫abc_control_corner_material的值,可以修改應(yīng)用內(nèi)所有Button的圓角大小

<dimen name="abc_control_corner_material" tools:override="true">8dp</dimen>
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末笼平,一起剝皮案震驚了整個(gè)濱河市园骆,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌寓调,老刑警劉巖锌唾,帶你破解...
    沈念sama閱讀 211,123評(píng)論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異夺英,居然都是意外死亡晌涕,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,031評(píng)論 2 384
  • 文/潘曉璐 我一進(jìn)店門烦衣,熙熙樓的掌柜王于貴愁眉苦臉地迎上來鸵赫,“玉大人萄凤,你說我怎么就攤上這事【宀疲” “怎么了?”我有些...
    開封第一講書人閱讀 156,723評(píng)論 0 345
  • 文/不壞的土叔 我叫張陵扭仁,是天一觀的道長(zhǎng)垮衷。 經(jīng)常有香客問我,道長(zhǎng)斋枢,這世上最難降的妖魔是什么帘靡? 我笑而不...
    開封第一講書人閱讀 56,357評(píng)論 1 283
  • 正文 為了忘掉前任,我火速辦了婚禮瓤帚,結(jié)果婚禮上描姚,老公的妹妹穿的比我還像新娘涩赢。我一直安慰自己,他們只是感情好轩勘,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,412評(píng)論 5 384
  • 文/花漫 我一把揭開白布筒扒。 她就那樣靜靜地躺著,像睡著了一般绊寻。 火紅的嫁衣襯著肌膚如雪花墩。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,760評(píng)論 1 289
  • 那天澄步,我揣著相機(jī)與錄音冰蘑,去河邊找鬼。 笑死村缸,一個(gè)胖子當(dāng)著我的面吹牛祠肥,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播梯皿,決...
    沈念sama閱讀 38,904評(píng)論 3 405
  • 文/蒼蘭香墨 我猛地睜開眼仇箱,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了东羹?” 一聲冷哼從身側(cè)響起剂桥,我...
    開封第一講書人閱讀 37,672評(píng)論 0 266
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎属提,沒想到半個(gè)月后权逗,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,118評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡垒拢,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,456評(píng)論 2 325
  • 正文 我和宋清朗相戀三年旬迹,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片求类。...
    茶點(diǎn)故事閱讀 38,599評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡奔垦,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出尸疆,到底是詐尸還是另有隱情椿猎,我是刑警寧澤,帶...
    沈念sama閱讀 34,264評(píng)論 4 328
  • 正文 年R本政府宣布寿弱,位于F島的核電站犯眠,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏症革。R本人自食惡果不足惜筐咧,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,857評(píng)論 3 312
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧量蕊,春花似錦铺罢、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,731評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至势就,卻和暖如春泉瞻,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背苞冯。 一陣腳步聲響...
    開封第一講書人閱讀 31,956評(píng)論 1 264
  • 我被黑心中介騙來泰國(guó)打工袖牙, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人抱完。 一個(gè)月前我還...
    沈念sama閱讀 46,286評(píng)論 2 360
  • 正文 我出身青樓贼陶,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親巧娱。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,465評(píng)論 2 348

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