溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Android shape文件屬性詳解

發布時間:2020-07-08 11:23:35 來源:網絡 閱讀:1594 作者:飛翔的貓咪 欄目:移動開發

Android開發中難免用到自定義的資源文件,其中很重要的便是Shape文件,Shape文件可以用來定義任意形狀,常常用來做背景色等。

Shape文件實際上也是.xml,其根元素是shape。下面將詳細介紹Shape文件中各種元素和屬性的含義。


根元素<shape>指定基本形狀

shape屬性指定基本形狀,允許的值有:rectangle(矩形),oval(橢圓),line(線條), ring(環)。默認的值是矩形,下面的代碼定義了一個矩形:

<?xml version="1.0" encoding="utf-8"?>
<shape android:shape="rectangle"
    xmlns:android="http://schemas.android.com/apk/res/android" >
</shape>

visible屬性設置形狀是否初始可見。

僅當形狀定義為ring時,下列屬性才可用:

  • innerRadius指定內環(即中空的洞)的半徑,接收Dimension類型。

  • innerRadiusRatio為浮點型,以環的寬度比率來表示內環的半徑,例如,如果android:innerRadiusRatio,表示內環半徑等于環的寬度除以5,這個值是可以被覆蓋的,默認為9.

  •         thickness指定環的厚度,類型為Dimension。

  •         thickne***atio也為浮點型,以環的寬度比率來表示環的厚度,例如,如果該值為"2",那么環的厚度就等于環的寬度除以2。這個值是可以被android:thickness覆蓋的,默認值是3.

  • 關于useLevel請參加下節<gradient>。


<gradient>設置漸變填充

    startcolor、centercolor、endcolor設置漸變的起止色,即允許設置兩次漸變。

    angle設置漸變的角度,僅當漸變類型為線性漸變時有效。默認0值為水平向右,其他角度以逆時針旋轉為準,例如設置為90則是自下而上,設置為270自上而下,以此類推。注意:必須是45的倍數。

    type設置漸變類型,默認是linear(線性漸變),如果設置為radial(放射/徑向漸變),則必須同時設置gradientRadius屬性,該屬性指定漸變半徑,注意:這個半徑并不是Dimension,不接受dp等單位,只能設置數字。此外還可以設置一個比較有意思的方式:sweep(掃描漸變)。三種漸變方式的效果見下圖。

Android shape文件屬性詳解Android shape文件屬性詳解Android shape文件屬性詳解

  centerX、centerY兩個屬性用于設置漸變的中心點位置,僅當漸變類型為放射漸變時有效,類型為分數或小數,不接受Dimension。默認值是0.5,有效值是0.0~1.0,超出該范圍后會看不出漸變效果。

  useLevel屬性通常不使用。該屬性用于指定是否將該shape當成一個LevelListDrawable來使用,默認值為false。

下面的代碼定義了一個線性的上下漸變:

<gradient android:startColor="#67CC24" android:endColor="#3E9010" android:angle="270" />


<solid>設置純色填充

這個元素本身沒什么好說的,既然是純色填充,只有color一個屬性。

注意:如果同一份文件同時指定漸變和純色填充,則順序在后面的會覆蓋掉前面的設置!


<size>指定尺寸

使用width、height分別設置寬高,類型為Dimension。

注意:Shape文件即使指定了size,默認情況下在使用時也會縮放到其容器的大小。如果在ImageView中使用,可以使用android:scaleType進行縮放的限制。


<stroke>描邊

當定義的形狀為line(線條)時,該屬性為必選項,設置線條的樣式。當形狀為其他形狀時,該元素起描邊的作用。

width指定邊框的寬度(Dimension),color指定邊框顏色,只接受color類型。

我們還可以設置虛線邊框:使用dashGap設置虛線之間的間隔,dashWidth設置每根虛線'-'的長度(為什么Google不把這個叫做Length?我也不知道)。僅當這兩個屬性都設置時虛線效果才生效。

下面的代碼定義了一個藍色虛線邊框:

    <stroke android:color="#0000FF" android:width="5dp" 
        android:dashGap="3dp" android:dashWidth="10dp"/>


<corners>設置圓角

僅當形狀為矩形時該元素才生效。topLeftRadius、topRightRadius、bottomLeftRadius、bottomRightRadius四個屬性分別設置四個角,radius則統一設置(四個角相同)。下面的代碼設置了四個相同的圓角:

    <corners android:radius="10dp"/>


<padding>設置邊距

該元素的含義請參照android:layout_paddingLeft等屬性。共有四個方向left、right、top、bottom可以設置,但沒有提供統一設置的屬性。


以上介紹了Shape文件的所有可用元素和屬性,但要真正用好shape,還要多寫多用才行。如有描述錯誤或不妥的地方,歡迎各位批評指正。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

亚洲午夜精品一区二区_中文无码日韩欧免_久久香蕉精品视频_欧美主播一区二区三区美女