浅谈Android样式开发之layer-list


引言

  在开发某些有层叠效果App时,我们第一个想到的就是让UI进行切图。下面我们来这样的一个例子。如图所示:

  上图Tab的背景效果,和带阴影的圆角矩形,是怎么实现的呢?大部分的人会让美工切图,用点九图做背景。但是,如果只提供一张图,会怎么样呢?比如,中间的Tab背景红色底线的像素高度为4px,那么,在mdpi设备上显示会符合预期,在hdpi设备上显示时会细了一点点,在xhdpi设备上显示时会再细一点,在xxhdpi上显示时又细了,在xxxhdpi上显示时则更细了。因为在xxxhdpi上,1dp=4px,所以,4px的图,在xxxhdpi设备上显示时,就只剩下1dp了。所以,为了适配好各种分辨率,必须提供相应的多套图片。如果去查看android的res源码资源,也会发现,像这种Tab的背景点九图,也根据不同分辨率尺寸提供了不同尺寸的点九图片。

  但是,在这个demo里,都没有用到任何实际的图片资源,都是用shape、selector,以及本篇要讲解的layer-list完成的。

layer-list叠加效果

  使用layer-list可以将多个drawable按照顺序层叠在一起显示,像上图中的Tab,是由一个红色的层加一个白色的层叠在一起显示的结果,阴影的圆角矩形则是由一个灰色的圆角矩形叠加上一个白色的圆角矩形。

  下面我们先来看一下Tab背景的代码: 

 1 <?xml version="1.0" encoding="utf-8"?>
 2 <selector xmlns:android="http://schemas.android.com/apk/res/android">
 3 
 4     <!-- 选中时候的样式 -->
 5     <item android:state_checked="true">
 6         <layer-list>
 7             <!-- 红色背景 -->
 8             <item>
 9                 <color android:color="#E4007F" />
10             </item>
11             <!-- 白色背景 -->
12             <item android:bottom="4dp" android:drawable="@android:color/white" />
13         </layer-list>
14     </item>
15 
16     <!--未选中时候的样式-->
17     <item>
18         <layer-list>
19             <!-- 红色背景 -->
20             <item>
21                 <color android:color="#E4007F" />
22             </item>
23             <!-- 白色背景 -->
24             <item android:bottom="1dp" android:drawable="@android:color/white" />
25         </layer-list>
26     </item>
27 
28 </selector>

  我们看到我们在样式文件定义了两个item,第一个是选中时item就是bottom向上4dp。第二个item就是正常情况下的样式。

  下面我们再来看一下圆角带阴影的按钮样式

 1 <?xml version="1.0" encoding="utf-8"?>
 2 <layer-list  xmlns:android="http://schemas.android.com/apk/res/android">
 3 
 4     <!--绘制矩形的灰色阴影-->
 5     <item
 6         android:left="2dp"
 7         android:top="4dp">
 8         <shape>
 9             <solid android:color="#929397"/>
10             <corners android:radius="10dp"/>
11         </shape>
12     </item>
13 
14     <!--绘制矩形的白色主体-->
15     <item
16         android:right="2dp"
17         android:bottom="4dp">
18         <shape>
19             <solid android:color="#ffffff"/>
20             <corners android:radius="10dp" />
21         </shape>
22     </item>
23 
24 </layer-list >

  从上面的示例代码可以看到,layer-list可以作为根节点,也可以作为selector中item的子节点。layer-list可以添加多个item子节点,每个item子节点对应一个drawable资源,按照item从上到下的顺序叠加在一起,再通过设置每个item的偏移量就可以看到阴影等效果了。layer-list的item可以通过下面四个属性设置偏移量:

  • android:top 顶部的偏移量
  • android:bottom 底部的偏移量
  • android:left 左边的偏移量
  • android:right 右边的偏移量

  这四个偏移量和控件的margin设置差不多,都是外间距的效果。如何不设置偏移量,前面的图层就完全挡住了后面的图层,从而也看不到后面的图层效果了。比如上面的例子,Tab背景中的白色背景设置了android:bottom之后才能看到一点红色背景。

总结 

  • 根节点不同时,可设置的属性是会不同的,比如selector下,可以设置一些状态属性,而在layer-list下,可以设置偏移量;
  • 就算父节点同样是selector,放在drawable目录和放在color目录下可用的属性也会不同,比如drawable目录下可用的属性为android:drawable,在color目录下可用的属性为android:color;
  • item的子节点可以为任何类型的drawable类标签,除了上面例子中的shape、color、layer-list,也可以是selector,还有其他没讲过的bitmap、clip、scale、inset、transition、rotate、animated-rotate、lever-list等等。

完整样例

  下面我给出以上效果完整的XML代码,Tab页使用的是RadioButton。完整布局如下:

 1 <?xml version="1.0" encoding="utf-8"?>
 2 <RelativeLayout
 3     xmlns:android="http://schemas.android.com/apk/res/android"
 4     android:layout_width="match_parent"
 5     android:layout_height="match_parent"
 6     android:background="#bababc">
 7 
 8     <RadioGroup
 9         android:layout_width="match_parent"
10         android:layout_height="wrap_content"
11         android:orientation="horizontal"
12         android:id="@+id/line1">
13 
14         <RadioButton
15             android:layout_width="0dp"
16             android:layout_height="60dp"
17             android:layout_weight="1"
18             android:button="@null"
19             android:text="Tab1"
20             android:textColor="@drawable/text_style"
21             android:textSize="18dp"
22             android:gravity="center"
23             android:paddingTop="12dp"
24             android:paddingBottom="12dp"
25             android:background="@drawable/layer_list_sample_style"/>
26 
27         <RadioButton
28             android:layout_width="0dp"
29             android:layout_height="60dp"
30             android:layout_weight="1"
31             android:button="@null"
32             android:text="Tab2"
33             android:textColor="@drawable/text_style"
34             android:textSize="18dp"
35             android:gravity="center"
36             android:paddingTop="12dp"
37             android:paddingBottom="12dp"
38             android:background="@drawable/layer_list_sample_style"/>
39 
40         <RadioButton
41             android:layout_width="0dp"
42             android:layout_height="60dp"
43             android:layout_weight="1"
44             android:button="@null"
45             android:text="Tab3"
46             android:textColor="@drawable/text_style"
47             android:textSize="18dp"
48             android:gravity="center"
49             android:paddingTop="12dp"
50             android:paddingBottom="12dp"
51             android:background="@drawable/layer_list_sample_style"/>
52 
53     </RadioGroup>
54 
55 
56     <TextView
57         android:layout_width="match_parent"
58         android:layout_height="wrap_content"
59         android:layout_below="@+id/line1"
60         android:text="带阴影的圆角矩形"
61         android:textColor="#333333"
62         android:textSize="18dp"
63         android:gravity="center"
64         android:paddingTop="18dp"
65         android:paddingBottom="18dp"
66         android:layout_margin="30dp"
67         android:background="@drawable/button_style"/>
68 
69 </RelativeLayout>

 参考文档

  http://keeganlee.me/post/android/20150909

转载于:https://www.cnblogs.com/dreamGong/p/6196504.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Android 中,<layer-list> 标签用于创建一个图形层列表,可以在一个图形中使用多个图层。每个图层可以指定颜色、形状、边框等属性,可以通过设置透明度来创建半透明效果。 <layer-list> 标签通常用于创建自定义的按钮、标签等 UI 控件,也可以用于创建渐变背景、圆形头像等效果。 以下是一个使用 <layer-list> 标签创建自定义按钮的示例: ```xml <selector xmlns:android="http://schemas.android.com/apk/res/android"> <item android:state_pressed="true"> <layer-list> <item> <shape android:shape="rectangle"> <corners android:radius="8dp" /> <solid android:color="#333333" /> </shape> </item> <item android:bottom="4dp"> <shape android:shape="rectangle"> <corners android:radius="8dp" /> <solid android:color="#555555" /> </shape> </item> </layer-list> </item> <item> <shape android:shape="rectangle"> <corners android:radius="8dp" /> <solid android:color="#444444" /> </shape> </item> </selector> ``` 该示例使用 <layer-list> 标签定义了两个图层,第一个图层为按钮的底部,使用矩形形状和圆角边框,填充颜色为 #333333;第二个图层为按钮的顶部,也使用矩形形状和圆角边框,填充颜色为 #555555,并设置了 bottom 属性为 4dp,使其相对于底部图层向上偏移 4dp。当按钮被按下时,会显示底部图层和顶部图层的组合,形成按下效果。未被按下时,只显示底部图层,形成普通状态的按钮。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值