前言
水波紋效果大致上可以分為兩類,一類是有界水波紋,而另一類是無界水波紋,較為廣泛使用的是有界水波紋。
系統自帶的水波紋實現
系統自帶的方法非常方便,只需要給相應的空間設置背景,背景內容則為系統自帶的 selectableItemBackground ,這樣的話,水波紋就會在TextView所在的區域內進行繪制。
<TextViewandroid:background="?android:attr/selectableItemBackground"... />
先上效果圖
ripple的使用(需要V21以上)
<ripple xmlns:android="http://schemas.android.com/apk/res/android" android:color="@color/dark_blue"> <item android:drawable="@color/blue"/></ripple>
其中item的顏色是控件正常狀態的背景色,ripple中的顏色是點擊時出現的顏色(會以半透明的形式展示出來)。ripple顏色的變化效果要比selector的效果更加柔和,以漸變的形式出現。
<ripple xmlns:android="http://schemas.android.com/apk/res/android" android:color="@color/dark_blue"> <item android:id="@android:id/mask" android:drawable="@drawable/ic_launcher_foreground"/></ripple>
mask的作用:只能在規定范圍內顯示水波動畫,范圍邊界由mask遮罩對象指定(可以換一些比原有背景小的圖片資源,可以看出效果)。
將ripple文件設置為控件的背景色就可以了。對于沒有設置點擊事件的控件,是沒有變化效果的。需要為控件設置 android:clickable="true"
<TextView xmlns:android="http://schemas.android.com/apk/res/android" android:id="@+id/main_item_tv" android:layout_width="match_parent" android:layout_height="50dp" android:clickable="true" android:background="@drawable/item_blue_selector" android:gravity="center" android:textSize="17sp" />
對于低版本來說,我還是選擇selector作為適配方案。截止到現在,21及以上版本已經覆蓋了90%的設備。
foreground設置
現在的點擊水波紋效果只有在抬起手指的時候才能看到,不符合一些項目的需求。
其實在控件除了設置background,還可以設置foreground。
android:foreground="?attr/selectableItemBackgroundBorderless"
在控件上加上這一句就可以看到你們想要的效果了。selectableItemBackgroundBorderless是系統提供的可以一個半透明灰色水波效果,在按住控件時,即可展示。(如果不需要提前變藍的效果,設置純藍色背景即可。)
我有一壺酒,足以慰風塵。盡傾江海里,贈飲天下人。
總結
以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對VEVB武林網的支持。
新聞熱點
疑難解答