Android:LayerDrawable资源
与 StateListDrawable 类似,LayerDrawable 也可以包含一个 Drawable 数组,因此系统将会按这些 Drawable 对象的数组顺序来绘制它们,索引最大的 Drawable 对象将会被绘制在最上面,可以通过将 drawable 摆放到不同位置来达到一些特殊的叠加效果。
一、使用简介
XML文件根元素为<layer-list>,可以包含多个<item>元素,该元素是一种层次化的drawable集合,可以指定下列属性:
- android:drawable:指定作为LayerDrawable元素之一的Drawable对象。
- android:id:指定一个标识
- android:buttom|top|left|button:指定一个长度值,用于指定将该Drawable对象绘制到目标组件的指定位置。
语法格式
<?xml version="1.0" encoding="utf-8"?>
<layer-list xmlns:android="http://schemas.android.com/apk/res/android" >
    <!--指定特定状态下的颜色-->
    <item android:id="@+id/background" android:drawable="@drawable/grow" />
    <item android:id="@+id/progress" android:drawable="@drawable/ok" />
</layer-list>
<?xml version="1.0" encoding="utf-8"?>
<layer-list xmlns:android="http://schemas.android.com/apk/res/android" >
    <item>
        <bitmap android:src="@drawable/ic_launcher" android:gravity="center" />
    </item>
    <item android:top="25dp" android:left="25dp">
        <bitmap android:src="@drawable/ic_launcher" android:gravity="center" />
    </item>
    <item android:top="50dp" android:left="50dp">
        <bitmap android:src="@drawable/ic_launcher" android:gravity="center" />
    </item>
</layer-list>
二、实例
1.按钮阴影效果
<?xml version="1.0" encoding="utf-8"?>
<layer-list xmlns:android="http://schemas.android.com/apk/res/android">
    <!-- layer-list设置图层效果:每一个item是一张图层,从下往上叠放 -->
    <!-- item前景层-->
    <item
        android:left="2dp"
        android:top="2dp">
        <shape>
            <gradient
                android:angle="45"
                android:endColor="#66ffd87c"
                android:startColor="#6696CDCD"
                android:type="linear" />
            <corners android:radius="10dp" />
        </shape>
    </item>
    <!-- item预览层-->
    <!-- 这层item会覆盖在之前上一层的item之上,会产生叠加的效果。-->
    <item
        android:bottom="2dp"
        android:right="2dp">
        <shape>
            <solid android:color="@android:color/white" />
            <corners android:radius="10dp" />
        </shape>
    </item>
</layer-list>
2.输入框效果
<?xml version="1.0" encoding="utf-8"?>
<layer-list xmlns:android="http://schemas.android.com/apk/res/android">
    <!-- 前景层-->
    <item>
        <shape android:shape="rectangle">
            <solid android:color="#0ac39e" />
        </shape>
    </item>
    <!-- 第二层,当前drawable为一个纯白色,相对view底部6dp外间距。-->
    <item android:bottom="6dp">
        <shape android:shape="rectangle">
            <solid android:color="#ffffff" />
        </shape>
    </item>
    <!--第三层,当前drawable为一个纯白色,相对view下,左,右各1dp的外间距。-->
    <item
        android:bottom="1dp"
        android:left="1dp"
        android:right="1dp">
        <shape android:shape="rectangle">
            <solid android:color="#ffffff" />
        </shape>
    </item>
</layer-list>
                        