它是一个多层次图片集合,我们可以使用它来进行图片的叠加实现我们想要的效果。
存放位置:res/drawable/
使用方式:
在Java文件中:R.drawable.filename
在xml布局文件中:@[package:]drawable/filename
语法:
<?xml version="1.0" encoding="utf-8"?>
<layer-list
xmlns:android="http://schemas.android.com/apk/res/android" >
<item
android:drawable="@[package:]drawable/drawable_resource"
android:id="@[+][package:]id/resource_name"
android:top="dimension"
android:right="dimension"
android:bottom="dimension"
android:left="dimension" />
</layer-list>
可以看到,它的每层都是使用一个item来表示,我们可以使用多个item来进行多层的叠加。
android:drawable 对应的就是图片资源
android:id 图片的id,可以iew.findViewById() 或者 Activity.findViewById()来得到这个图片.
android:top 距离顶部位置
android:right 距离右边位置
android:bottom 距离底部位置
android:left 距离左边位置
例如:
<item android:drawable="@drawable/image" />
使用这种方式,所有的图片资源会进行拉伸来匹配父容器,为了避免自动的拉伸我们可以使用下面这种方式:
<item>
<bitmap android:src="@drawable/image"
android:gravity="center" />
</item>
例如:
<?xml version="1.0" encoding="utf-8"?>
<layer-list xmlns:android="http://schemas.android.com/apk/res/android">
<item>
<bitmap android:src="@drawable/android_red"
android:gravity="center" />
</item>
<item android:top="10dp" android:left="10dp">
<bitmap android:src="@drawable/android_green"
android:gravity="center" />
</item>
<item android:top="20dp" android:left="20dp">
<bitmap android:src="@drawable/android_blue"
android:gravity="center" />
</item>
</layer-list>
在布局文件中我们可以进行使用:
<ImageView
android:layout_height="wrap_content"
android:layout_width="wrap_content"
android:src="@drawable/layers" />
效果如下:
另外我们需要说的是,上面的layer-list xml文件最终会被解析为LayerDrawable对象,也就是它其实就是LayerDrawable对象,所以我们也可以使用代码来进行处理。
例如:
mImageView=(ImageView) findViewById(R.id.imageView);
Drawable [] drawables=new Drawable[2];
drawables[0]=getResources().getDrawable(R.drawable.e);
drawables[1]=getResources().getDrawable(R.drawable.ic_launcher);
LayerDrawable layerDrawable=new LayerDrawable(drawables);
mImageView.setImageDrawable(layerDrawable);