Android應用之定義陰影和裁剪視圖技巧

來源:互聯網
上載者:User

標籤:des   android   http   io   ar   使用   sp   strong   檔案   

今天要寫的陰影和視圖裁剪,無法向下相容,請注意。

Material Design 為使用者介面元素引入了深度這個元素。深度協助使用者理解各個元素之間的重要關聯和協助使用者關注他們手上的任務。

視圖的高度(elevation),通過Z屬性工作表現,通過他的陰影確定:z值更高的視圖投影出更大的陰影。視圖只在Z=0的平面上投影處陰影;他們不會投影陰影在其他放在下面的視圖上面和高於z=0的平面。

有更高Z值的視圖擋住Z值較低的視圖。無論如何,Z值不會影響到View的大小。

高度也是有用的,當在執行一些動作的時候建立動畫讓組件升起。

為視圖分配高度

一個View的Z值有兩個組成部分,elevation(高度)和translation(平移).elevation是一個靜態部分,translation 用於動畫:

Z = elevation + translationZ

 

不同高度的視圖的陰影

在布局檔案中設定evelation 使用android:elevation,在代碼中使用View.setElevation()方法。

設定一個視圖的平移,使用View.setTranslationZ()方法。

新的方法ViewPropertyAnimator.z()和ViewPropertyAnimator.translationZ()可以讓你更容易的變動視圖的高度。更多的資訊,看e良師益友的Android應用開發視頻教程

你也可以使用StateListAnimator方式定義這些檔案在xml檔案中。特別適用於,狀態改變時執行的動畫,比如使用者點擊按鈕。更多資訊,請看動畫檢視狀態改變,下次在動畫一節講。

Z值在測量上使用和X,Y值一樣的單位。

自訂視圖陰影和輪廓

視圖的背景邊界決定了陰影的預設圖案。輪廓(Outlines)代表了繪圖物件的外形狀,並確定了對觸摸反饋區的波紋。

看這個視圖,定義一個背景Drawable:

 

背景是一個圓角矩形

 

當這個背景drawable作為視圖的輪廓,視圖投射出圓角陰影。提供一個自訂的輪廓,可以覆蓋預設視圖陰影的形狀。

在自己的代碼中自訂一個輪廓:

1.繼承ViewOutlineProvider類

2.重寫getOutline()方法

3.在視圖中設定輪廓,使用View.setOutlineProvider()方法

你可以建立橢圓和圓角矩形輪廓使用OutLine類中的方法。視圖預設的outline provider會根據視圖的背景來產生輪廓。可以設定視圖的outline provider為null,來阻止投射陰影。

裁剪視圖

裁剪視圖功能,可以讓你更容易的改變視圖的形狀。你可以裁剪視圖為了和其他的設計項目保持一致,或者改變成形狀響應使用者的輸入。你可以裁剪一個視圖的輪廓使用View.setClipToOutLine()方法,或者android:clipToOutline屬性。只有矩形,圓角矩形,圓圈的輪廓支援被裁剪,可以使用Outline.canClip()方法檢測是否支援被裁剪。

裁剪視圖到一個drawable的形狀,設定drawable作為視圖的背景(讓視圖顯示在其上),並且調用View.setClipToOutline()方法。

裁剪視圖是一個耗費的操作,裁剪視圖時不要使用形狀動畫。達到這種效果,請使用Reveal Effect 動畫(下節講)。

總結

上面可以看到,設定陰影很簡單:

設定eleavation值。

添加背景或者設定一個outline.

更多關於Android應用開發的知識、技巧請關注e良師益友網

Android應用之定義陰影和裁剪視圖技巧

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.