Android 的各種 Drawable 詳解

lightwing發表於2021-09-09

概述

android內建瞭如下幾種Drawable型別:ColorDrawable、GradientDrawable、BitmapDrawable、 NinePatchDrawable、InsetDrawable、ClipDrawable、ScaleDrawable、 RotateDrawable、AnimationDrawable、LayerDrawable、LevelListDrawable、 StateListDrawable、TransitionDrawable、ShapeDrawable。

Android把可繪製的物件抽象為Drawable,不同的圖形影像資源就代表著不同的drawable型別。Android FrameWork提供了一些具體的Drawable實現,通常在程式碼中都不會直接接觸Drawable的實現類。

 orientation, int[] colors)

BitmapDrawable

BitmapDrawable就不多介紹什麼了,最常用的從drawable中載入的圖片都是BitmapDrawable

NinePatchDrawable

NinePatchDrawable是點九圖片,NinePatchDrawable繪畫的是一個可以伸縮的點陣圖影像。Android會自動調整大小來容納顯示的內容,通常用來做可以被拉伸的背景。

InsetDrawable

InsetDrawable 表示一個drawable嵌入到另外一個drawable內部,並且在內部留一些間距,這一點很像drawable的padding屬性,區別在於 padding表示drawable的內容與drawable本身的邊距,insetDrawable表示兩個drawable和容器之間的邊距。當控制元件需要的背景比實際的邊框小的時候比較適合使用InsetDrawable。

ClipDrawable

ClipDrawable是透過設定一個Drawable的當前顯示比例來裁剪出另一張Drawable,你可以透過調節這個比例來控制裁剪的寬高,以及裁剪內容佔整個容器的權重,透過ClipDrawable的setLevel()方法調節顯示比例可以實現類似Progress進度條的效果。ClipDrawable的level值範圍在[0,10000],level的值越大裁剪的內容越少,如果level為10000時則完全顯示。

  
 

clip元素中只有android:drawable、android:clipOrientation和android:gravity三個屬性,其中android:drawable為需要裁剪的原始圖片,android:clipOrientation為裁剪的方向,可以按照垂直(vertical)或者水平(horizontal)方向進行裁剪,android:gravity為指定從哪裡開始裁剪,這個可以透過或操作設定多個屬性。

AnimationDrawable

AnimationDrawable通常是將幾張圖串起來做一個簡單動畫,

    
      
      

      
      
      
      

ScaleDrawable

ScaleDrawable,RotateDrawable分別用來對圖片進行拉伸和旋轉。

LayerDrawable

一個LayerDrawable是一個可以管理一組drawable物件的drawable。在LayerDrawable的drawable資源按照列表的順序繪製,列表的最後一個drawable繪製在最上層。

元素:必須的。 並且要作為根節點。 包含一個或者多個元素
屬性:xmlns:android 必須的。 定義xml檔案的名稱空間,必須是 “”。
定義一個drawable放置在layer drawable中,具體的位置有它的。必須是的子元素(這個不太理解)。可接受做為子元素

屬性:
android:drawable  Drawable資源。必須的。引用的drawable資源
android:id  資源ID。一個為這個item定義的唯一的資源ID。 使用:”@+id/name”.這樣的方式。可以檢索或修改這個drawable透過下面的方式:View.findViewById() orActivity.findViewById().
android:top   Integer。與top的距離,單位畫素
android:right  Integer。與right的距離,單位畫素
android:bottom  Integer。與bottom的距離,單位畫素
android:left  Integer。與left的距離,單位畫素

在預設的情況下,所有的drawable item都會縮放到合適的大小來適應檢視。因此,在一個layer-list中定義不同的位置可能會增加檢視的尺寸和被自動縮放。為了避免被縮放,可以再節點裡加上元素來指定一個drawable,並且定義一些不會被拉伸的gravity屬性,例如center。

舉個例子,下面在item裡面定義一個drawable,圖片就會自動縮放以適應檢視的大小。

為了避免縮放,可以使用的子元素來指定drawable資源


 
 

StateListDrawable

StateListDrawable通常用作selector,設定不同的背景或者顏色。ShapeDrawable定義了多種圖形,也是比較常用的。

LevelListDrawable

LevelListDrawable對應於,跟selector一樣,它也表示一個drawable集合。使用方法如下。

        
        

        

注意這裡要用src,background是不起作用的。

需要變換圖片時,呼叫這個方法iView.setImageLevel(1);

TransitionDrawable

一個TransitionDrawable是一個特殊的Drawable物件,可以實現兩個drawable資源之間淡入淡出的效果。

節點下的每個代表一個drawable資源。只能有兩個。先前轉換呼叫startTransition()。向後,呼叫 reverseTransition()

  • 檔案位於:

  • res/drawable/filename.xml
    檔名作為資源ID

  • 編譯資源型別:

  • 指向 TransitionDrawable的指標

  • 資源引用:

  • In Java: R.drawable.filename
    In XML: @[package:]drawable/filename

  • 語法:

    
      

例子:XML檔案儲存為:res/drawable/transition.xml

    
      
      

在layout檔案中使用:

ImageButton button = (ImageButton) findViewById(R.id.button);  
TransitionDrawable drawable = (TransitionDrawable) button.getDrawable();  
drawable.startTransition(500);


來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/3407/viewspace-2803549/,如需轉載,請註明出處,否則將追究法律責任。

相關文章