Android中Button實現(xiàn)點擊換圖案及顏色
基本框架
<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent" android:orientation="vertical"> <Button android:layout_width="200dp" android:layout_height="100dp"/> </LinearLayout>
基本屬性
在上面的xml
文件中Ctrl+左鍵點進Button
可以看到該類是繼承自TextView
類的,也就是說在TextView
部分講到的都可以用在Button
上。
文本與背景
在這里我們就簡單的設置下按鈕上的文本為"Push Me",背景顏色設置為紫色(這兩個資源都被保存在values
文件夾的三個xml
文件里),但奇怪的是文本都被強制轉換成了大寫,而設置背景也無效。
主題修改
問題出在主題文件themes.xml
上,我們需要進入該文件,將textAllCaps
設為false
,就可以取消強制大寫,即加入下面的代碼:
<item name="textAllCaps">true</item>
然后我們還需要把基礎主題文件由
<style name="Theme.MyButton" parent="Theme.MaterialComponents.DayNight.DarkActionBar">
改為
<style name="Theme.MyButton" parent="Theme.MaterialComponents.DayNight.DarkActionBar.Bridge">
這樣就可以讓我們的設置生效了:
雖然設置了按鈕的基本屬性,但是現(xiàn)在這個按鈕看上去跟TextView
也沒什么區(qū)別,點擊也毫無反應,接下來我們就要設置一下點擊效果。
點擊效果
本次要實現(xiàn)的效果主要是點擊以后按鈕的背景隨之更換,所以我們在res
->drawable
文件夾下新建一個Drawable Resource文件,起名為background_shift
??梢钥吹剑撐募母?jié)點為圖片選擇器selector
。
圖片變換
然后我們加入一點圖片資源,點擊res
,右鍵new
->Vector Asset
,進入這個界面后點擊Clip Art
選擇一個喜歡的圖標,比如我選擇了WiFi:
同時我另導入了一張WiFi關閉的圖標。
導入后,就可以在background_shift
文件中使用了,在這里我通過state_pressed
設置按下時顯示W(wǎng)iFi,不按下時顯示W(wǎng)iFi關閉,代碼如下:
<?xml version="1.0" encoding="utf-8"?> <selector xmlns:android="http://schemas.android.com/apk/res/android"> <item android:drawable="@drawable/ic_baseline_wifi_24" android:state_pressed="true"/> <item android:drawable="@drawable/ic_baseline_wifi_off_24" android:state_pressed="false"/> </selector>
寫好了background_shift.xml
,就可以在activity_main.xml
中使用了,將Button
的background
屬性設置為該資源即可實現(xiàn)背景變換。
顏色變換
做顏色變換與圖像變換類似,不同之處在于資源存放位置不同。在res
文件夾,我們新建一個color
文件夾,右擊rec
,在new
->Directory
中新建文件夾,取名color
之后在color
中也建立一個Drawable Resource文件,然后設定按下時為藍色,默認為紅色:
<?xml version="1.0" encoding="utf-8"?> <selector xmlns:android="http://schemas.android.com/apk/res/android"> <item android:color="#ff0000ff" android:state_pressed="true"/> <item android:color="#ffff0000"/> </selector>
有了這個顏色變換文件,我們就可以在activity_main.xml
中將Button
的backgroundTint
設置為該資源從而實現(xiàn)顏色變換。
除了背景顏色,還有foregroud
前景色,這個是最上層的顏色,會覆蓋整個圖層,不常用。
總結
到此這篇關于Android中Button實現(xiàn)點擊換圖案及顏色的文章就介紹到這了,更多相關Android Button點擊換圖案及顏色內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
Android launcher中模擬按home鍵的實現(xiàn)
這篇文章主要介紹了Android launcher中模擬按home鍵的實現(xiàn)的相關資料,需要的朋友可以參考下2017-05-05Android Build Variants 為項目設置變種版本的方法
下面小編就為大家分享一篇Android Build Variants 為項目設置變種版本的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-01-01android實現(xiàn)視頻的加密和解密(使用AES)
本篇文章主要介紹了android實現(xiàn)視頻的加密和解密(使用AES),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-05-05android編程實現(xiàn)添加文本內容到sqlite表中的方法
這篇文章主要介紹了android編程實現(xiàn)添加文本內容到sqlite表中的方法,結合實例較為詳細的分析了Android針對txt文本文件的讀取及SQL數(shù)據(jù)庫操作的相關技巧,需要的朋友可以參考下2015-11-11