您好,登錄后才能下訂單哦!
在Android項(xiàng)目中怎么自定義陰影效果?針對(duì)這個(gè)問題,這篇文章詳細(xì)介紹了相對(duì)應(yīng)的分析和解答,希望可以幫助更多想解決這個(gè)問題的小伙伴找到更簡(jiǎn)單易行的方法。
Android 自定義陰影效果詳解及實(shí)例
Android5.X中,Google為其增加了兩個(gè)屬性 android:elevation=” ” 與 android:translationZ=” “,對(duì)應(yīng)垂直方向上的高度變化。系統(tǒng)會(huì)自動(dòng)增加陰影效果。
在TabLayout中增加android:elevation=” 8dp” ,效果如下:
箭頭指向的就是系統(tǒng)為我們默認(rèn)提供,結(jié)果差強(qiáng)人意。那我們是不是可以自定義陰影,不使用系統(tǒng)提供的。
自定義陰影效果
陰影效果如下:
這里只使用自定義陰影,并未使用android:elevation=” 8dp”
原理
用遮蓋的方式實(shí)現(xiàn)
共分為二層,前景層和背景層
前景層:設(shè)置一個(gè)綠色的矩形區(qū)域
背景層:一個(gè)從黑到綠色的過度顏色矩形填充,這里選擇“綠色”是因?yàn)樯厦娴囊彩且粔K綠色。
在res/drawable里創(chuàng)建Xml,Xml代碼如下:
<?xml version="1.0" encoding="utf-8"?> <layer-list xmlns:android="http://schemas.android.com/apk/res/android"> <item> <shape> <gradient android:startColor="#000" <!--開始顏色--> android:endColor="@color/colorAccent" <!--結(jié)束顏色,背景色:綠色.系統(tǒng)會(huì)自動(dòng)繪制顏色--> android:angle="90" /><!--角度:從下到上--> </shape> </item> <item android:top="8dp"><!--距離頂部8dp--> <shape> <solid android:color="@color/colorAccent" /> </shape> </item> </layer-list>
提示:注釋為方便讀者閱讀,所以報(bào)錯(cuò)就把注釋刪了。
然后設(shè)置TabLayout的 android:background=”@drawable/shadow_bg”
LayerDrawable對(duì)象
相信大家對(duì)ShapeDrawable比較了解,這里講下少用的LayerDrawable,如果覺得有必要說下ShapeDrawable可以在評(píng)論反饋。
LayerDrawable可以包含一個(gè)Drawable數(shù)組,系統(tǒng)會(huì)按這些Drawable對(duì)象的數(shù)組的順序進(jìn)行繪制。
定義LayerDrawable對(duì)象Xml文件的根元素為< layer-list> < /layer-list,該元素可以包含多個(gè)< item>< /item>元素,該元素可指定如下屬性:
關(guān)于在Android項(xiàng)目中怎么自定義陰影效果問題的解答就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關(guān)注億速云行業(yè)資訊頻道了解更多相關(guān)知識(shí)。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。