LayerDrawable层叠样式layer-list

简介:

原文:http://gundumw100.iteye.com/blog/896923

layer-list可以将多个图片按照顺序层叠起来。 
语法:在drawalbe/drawable-layer.xml中 

Java代码   收藏代码
  1. <layer-list xmlns:android="http://schemas.android.com/apk/res/android">  
  2.     <item android:drawable="@android:color/white" />  
  3.     <item android:drawable="@drawable/logo_overlay" />  
  4. </layer-list>  

使用方式像其他图片一样: 
如在样式中引用: 
Java代码   收藏代码
  1. <resources>  
  2.     <style name="LookupTheme" parent="@android:style/Theme.Light.NoTitleBar">  
  3.         <item name="android:windowBackground">@drawable/drawable-layer</item>  
  4.     </style>  
  5. </resources>  

在java代码中引用: 
((ImageView) findViewById(R.id.imageview)).setImageDrawable(getResources().getDrawable(R.drawable.drawable-layer) 

在代码中实现: 
Java代码   收藏代码
  1. Resources resources = getResources();   
  2. Drawable[] layers = new Drawable[2];   
  3. layers[0] = r.getDrawable(R.drawable.white);   
  4. layers[1] = r.getDrawable(R.drawable.logo_overlay);   
  5. LayerDrawable layerDrawable = new LayerDrawable(layers)  
  6. ((ImageView) findViewById(R.id.imageview)).setImageDrawable(layerDrawable);   


再举一个例子: 
要用2张图片叠加起来,看上去形成一张图片 

 

首先创建一个drawalbe/login_head.xml的文件,内容如下: 
Xml代码   收藏代码
  1. <?xml version="1.0" encoding="UTF-8"?>  
  2. <layer-list  
  3.   xmlns:android="http://schemas.android.com/apk/res/android">  
  4.     <item android:id="@+id/user_faceback_drawable" android:drawable="@drawable/faceback" />  
  5.     <item android:id="@+id/user_face_drawable" android:drawable="@drawable/h001" android:left="10.0dip" android:top="18.0dip" android:right="25.0dip" android:bottom="35.0dip" />  
  6. </layer-list>  

然后就可以使用这个组合的图片了,比如在ImageView中显示: 
<ImageView android:id="@+id/faceImg"  android:background="@drawable/login_head"  
android:layout_width="wrap_content" android:layout_height="wrap_content" /> 

使用java代码: 
如何使多个Drawable叠加(合成图片)? 
大家可能知道Bitmap的叠加处理在Android平台中可以通过Canvas一层一层的画就行了,而Drawable中如何处理呢? 除了使用BitmapDrawable的getBitmap方法将Drawable转换为Bitmap外,今天Android123给大家说下好用简单的LayerDrawable类,LayerDrawable顾名思义就是层图形对象。下面直接用一个简单的代码表示: 

Java代码   收藏代码
  1. Bitmap bm = BitmapFactory.decodeResource(getResources(),R.drawable.cwj);    
  2.     Drawable[] array = new Drawable[3];    
  3.      array[0] = new PaintDrawable(Color.BLACK); //黑色    
  4.      array[1] = new PaintDrawable(Color.WHITE); //白色       
  5.      array[2] = new BitmapDrawable(bm); //位图资源            
  6.     LayerDrawable ld = new LayerDrawable(array); //参数为上面的Drawable数组    
  7.     ld.setLayerInset(11111);  //第一个参数1代表数组的第二个元素,为白色    
  8.     ld.setLayerInset(22222); //第一个参数2代表数组的第三个元素,为位图资源    
  9.     mImageView.setImageDrawable(ld);   


上面的方法中LayerDrawable是关键,Android开发网提示setLayerInset方法原型为public void setLayerInset (int index, int l, int t, int r, int b) 其中第一个参数为层的索引号,后面的四个参数分别为left、top、right和bottom。对于简单的图片合成我们可以将第一和第二层的PaintDrawable换成BitmapDrawable即可实现简单的图片合成。

相关文章
|
7月前
|
前端开发 JavaScript 开发者
CSS隐藏元素的N种方法,你知道哪一种最适合你?
欢迎来到前端入门之旅!这个专栏是为那些对Web开发感兴趣、刚刚开始学习前端的读者们打造的。无论你是初学者还是有一些基础的开发者,我们都会在这里为你提供一个系统而又亲切的学习平台。我们以问答形式更新,为大家呈现精选的前端知识点和最佳实践。通过深入浅出的解释概念,并提供实际案例和练习,让你逐步建立起一个扎实的基础。无论是HTML、CSS、JavaScript还是最新的前端框架和工具,我们都将为你提供丰富的内容和实用技巧,帮助你更好地理解并运用前端开发中的各种技术。
|
前端开发 索引
Layui 内置方法 - layer.style(重新定义层的样式)
Layui 内置方法 - layer.style(重新定义层的样式)
203 0
|
3月前
|
移动开发 前端开发 JavaScript
Twaver-HTML5基础学习(7)Layer图层元素
本文介绍了Twaver HTML5中的图层元素(Layer),包括图层的属性和使用方法。文章详细解释了如何创建图层、设置图层属性(如可见性、可编辑性、可移动性和可旋转性),并通过示例代码展示了如何在React组件中使用图层。
48 1
Twaver-HTML5基础学习(7)Layer图层元素
|
前端开发
那些你不知道的 CSS 自定义形状网格布局 3(1)
那些你不知道的 CSS 自定义形状网格布局
87 0
那些你不知道的 CSS 自定义形状网格布局 3(1)
|
前端开发 容器
那些你不知道的 CSS 自定义形状网格布局2
那些你不知道的 CSS 自定义形状网格布局
82 0
|
7月前
|
前端开发
CSS z-index:元素堆叠
CSS z-index:元素堆叠
52 2
|
前端开发
CSS:去除input和button边框以及选中时边框默认样式
CSS:去除input和button边框以及选中时边框默认样式
|
前端开发
|
前端开发
那些你不知道的 CSS 自定义形状网格布局 3(2)
那些你不知道的 CSS 自定义形状网格布局
78 0
|
前端开发 容器
那些你不知道的 CSS 自定义形状网格布局1
那些你不知道的 CSS 自定义形状网格布局
80 0