您好,登錄后才能下訂單哦!
這篇文章給大家分享的是有關Android中Button如何實現點擊換圖案及顏色的內容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。
<?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">
這樣就可以讓我們的設置生效了:
雖然設置了按鈕的基本屬性,但是現在這個按鈕看上去跟TextView
也沒什么區別,點擊也毫無反應,接下來我們就要設置一下點擊效果。
本次要實現的效果主要是點擊以后按鈕的背景隨之更換,所以我們在res
->drawable
文件夾下新建一個Drawable Resource文件,起名為background_shift
。可以看到,該文件的根節點為圖片選擇器selector
。
然后我們加入一點圖片資源,點擊res
,右鍵new
->Vector Asset
,進入這個界面后點擊Clip Art
選擇一個喜歡的圖標,比如我選擇了WiFi:
同時我另導入了一張WiFi關閉的圖標。
導入后,就可以在background_shift
文件中使用了,在這里我通過state_pressed
設置按下時顯示WiFi,不按下時顯示WiFi關閉,代碼如下:
<?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
屬性設置為該資源即可實現背景變換。
做顏色變換與圖像變換類似,不同之處在于資源存放位置不同。在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
設置為該資源從而實現顏色變換。
除了背景顏色,還有foregroud
前景色,這個是最上層的顏色,會覆蓋整個圖層,不常用。
感謝各位的閱讀!關于“Android中Button如何實現點擊換圖案及顏色”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。