寫了那么多Android布局,你知道elevation屬性嗎

引言:新建那么多xml,寫了那么多布局文件错沽,少年簿晓,你寫過elevation屬性嗎?

一甥捺、elevation

我們知道抢蚀,在RelativeLayout里面,或者更加純凈的FrameLayout里面镰禾,后寫的View會覆蓋之前寫的View上面皿曲。

比如:

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
              android:orientation="vertical"
              android:layout_width="match_parent"
              android:layout_height="match_parent"
    >
    <RelativeLayout
        android:layout_width="match_parent"
        android:layout_height="300dp"
        android:background="#ff0000"
        >
        <View
            android:id="@+id/vGeeen"
            android:layout_width="200dp"
            android:layout_height="200dp"
            android:background="#00ff00"/>

        <TextView
            android:id="@+id/vBlue"
            android:layout_width="100dp"
            android:layout_height="100dp"
            android:background="#0000ff"/>
    </RelativeLayout>
</RelativeLayout>

效果


image.png

嗯,這很正常吴侦,vBlue現(xiàn)在vGeeen之上屋休,一切很正常。
這時候备韧,主角elevation登場劫樟。

我們稍加改動,給vBlue加上一行代碼:android:elevation="1dp"
即現(xiàn)在代碼變成:

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
              android:orientation="vertical"
              android:layout_width="match_parent"
              android:layout_height="match_parent"
    >
    <RelativeLayout
        android:layout_width="match_parent"
        android:layout_height="300dp"
        android:background="#ff0000"
        >
        <View
            android:id="@+id/vGeeen"
            android:layout_width="200dp"
            android:layout_height="200dp"
            android:elevation="1dp"
            android:background="#00ff00"/>

        <TextView
            android:id="@+id/vBlue"
            android:layout_width="100dp"
            android:layout_height="100dp"
            android:background="#0000ff"/>
    </RelativeLayout>
</RelativeLayout>

在看看現(xiàn)在的效果:

image.png

我的mBlue哪去啦织堂,說好的最后出場的都是主角呢叠艳,mBlue居然不見啦!

我們知道易阳,在css里面附较,我們經(jīng)常會計算權(quán)重,在剛剛的實踐里面潦俺,加了mGreen加了android:elevation="1dp"拒课,相當(dāng)于在這些View里面他的權(quán)重提高了,升官啦事示!

在android的世界里面早像,elevation起到了權(quán)重的作用,而且肖爵,每一個View的默認(rèn)權(quán)重都是0dp卢鹦,但在Google說他是一個陰影的作用,但是實際上由于MD設(shè)計的高度Z造成的劝堪,后面我會說到

如果我們把上面的mGreen的把elevation設(shè)置為android:elevation="0dp"法挨,那么一切照舊,最后出場的mBlue依然會覆蓋著mGreen幅聘。

原來凡纳,這個elevation是2014 年,Google 推出了Material Design新的 Android 支持庫 v7之后才有的產(chǎn)物(但是過了這么久我都沒用過elevation屬性帝蒿,慚愧)

那為什么elevation可以起到類似權(quán)重的作用呢荐糜?
因為,在MD設(shè)計里面,視圖可以投射陰影暴氏, elevation 值決定了陰影的大小和順序延塑。要設(shè)定 elevation 值

我們來新建一個布局,給TextView設(shè)置android:elevation="30dp"答渔,看看會產(chǎn)生什么效果

image.png

設(shè)置

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
                android:orientation="vertical"
                android:layout_width="match_parent"
                android:layout_height="match_parent"
    >
    <TextView
        android:layout_width="100dp"
        android:layout_height="100dp"
        android:background="#000000"
        android:layout_centerInParent="true"
        android:elevation="30dp"
        />

</RelativeLayout>

通過上圖已經(jīng)很說明了情況关带。

二、Material Design 之高度視圖高度 Z

在Material Design主題當(dāng)中給UI元素引入了高度的概念沼撕,視圖的高度由屬性Z來表示宋雏,決定了陰影的視覺效果,Z越大务豺,陰影就越大且越柔和磨总。但是Z值并不會影響視圖的大小。

視圖的Z值由兩個分量表示:

  • 1笼沥、Elevation:靜態(tài)的分量
  • 2蚪燕、Translation:用于動畫的動態(tài)的分量

Z值的計算公式為:
Z=elevation+translationZ

elevation屬性和translationZ是好朋友。

具體我們就不在這里細說了奔浅,具體了解可以查閱Material Design中的Elevation和shadows馆纳,寫的挺好的。

三汹桦、緣從何時起

那么鲁驶,這個elevation屬性我是如何發(fā)現(xiàn)的。
一切都要從CardView說起营勤。

我們經(jīng)常會在CardView里面設(shè)置類似app:cardElevation="5dp"之類的代碼灵嫌。
然后就是我發(fā)現(xiàn)處于CardView底部一個View死活不出來壹罚,app:cardElevation就是
CardView獨有的elevation葛作,當(dāng)然了,CardView也是可以設(shè)置elevation的猖凛。

小結(jié)一下:

MD設(shè)計中赂蠢,視圖有高度的概念,用Z來表示辨泳,Z受到Elevation和Translation兩個量控制虱岂,因為這個高度的概念,導(dǎo)致了elevation屬性產(chǎn)生了類似css中的權(quán)重的作用菠红。

END第岖,謝謝閱讀。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末试溯,一起剝皮案震驚了整個濱河市蔑滓,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖键袱,帶你破解...
    沈念sama閱讀 218,941評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件燎窘,死亡現(xiàn)場離奇詭異,居然都是意外死亡蹄咖,警方通過查閱死者的電腦和手機褐健,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,397評論 3 395
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來澜汤,“玉大人蚜迅,你說我怎么就攤上這事∫祝” “怎么了慢叨?”我有些...
    開封第一講書人閱讀 165,345評論 0 356
  • 文/不壞的土叔 我叫張陵,是天一觀的道長务蝠。 經(jīng)常有香客問我拍谐,道長,這世上最難降的妖魔是什么馏段? 我笑而不...
    開封第一講書人閱讀 58,851評論 1 295
  • 正文 為了忘掉前任轩拨,我火速辦了婚禮,結(jié)果婚禮上院喜,老公的妹妹穿的比我還像新娘亡蓉。我一直安慰自己,他們只是感情好喷舀,可當(dāng)我...
    茶點故事閱讀 67,868評論 6 392
  • 文/花漫 我一把揭開白布砍濒。 她就那樣靜靜地躺著,像睡著了一般硫麻。 火紅的嫁衣襯著肌膚如雪爸邢。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,688評論 1 305
  • 那天拿愧,我揣著相機與錄音杠河,去河邊找鬼。 笑死浇辜,一個胖子當(dāng)著我的面吹牛券敌,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播柳洋,決...
    沈念sama閱讀 40,414評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼待诅,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了熊镣?” 一聲冷哼從身側(cè)響起卑雁,我...
    開封第一講書人閱讀 39,319評論 0 276
  • 序言:老撾萬榮一對情侶失蹤立由,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后序厉,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體锐膜,經(jīng)...
    沈念sama閱讀 45,775評論 1 315
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,945評論 3 336
  • 正文 我和宋清朗相戀三年弛房,在試婚紗的時候發(fā)現(xiàn)自己被綠了道盏。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 40,096評論 1 350
  • 序言:一個原本活蹦亂跳的男人離奇死亡文捶,死狀恐怖荷逞,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情粹排,我是刑警寧澤种远,帶...
    沈念sama閱讀 35,789評論 5 346
  • 正文 年R本政府宣布,位于F島的核電站顽耳,受9級特大地震影響坠敷,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜射富,卻給世界環(huán)境...
    茶點故事閱讀 41,437評論 3 331
  • 文/蒙蒙 一膝迎、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧胰耗,春花似錦限次、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,993評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至赠群,卻和暖如春羊始,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背乎串。 一陣腳步聲響...
    開封第一講書人閱讀 33,107評論 1 271
  • 我被黑心中介騙來泰國打工店枣, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留速警,地道東北人叹誉。 一個月前我還...
    沈念sama閱讀 48,308評論 3 372
  • 正文 我出身青樓,卻偏偏與公主長得像闷旧,于是被迫代替她去往敵國和親长豁。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 45,037評論 2 355

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