我们在做Android项目的时候,有时候会用到一些简单的图片效果,但是这时身边又没有美工在的时候,就显得很尴尬了。其实一些简单的图片效果,我们根本就不需要美工去切图,我们自己运用Android 的shape 编写一个XML就OK了。
shape的各种属性如下:
<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android" >
<!-- 圆角 -->
<corners
android:radius="9dp"
android:topLeftRadius="2dp"
android:topRightRadius="2dp"
android:bottomLeftRadius="2dp"
android:bottomRightRadius="2dp"/><!-- 设置圆角半径 -->
<!-- 渐变 -->
<gradient
android:startColor="@android:color/white"
android:centerColor="@android:color/black"
android:endColor="@android:color/black"
android:useLevel="true"
android:angle="45"
android:type="radial"
android:centerX="0"
android:centerY="0"
android:gradientRadius="90"/>
<!-- 间隔 -->
<padding
android:left="2dp"
android:top="2dp"
android:right="2dp"
android:bottom="2dp"/><!-- 各方向的间隔 -->
<!-- 大小 -->
<size
android:width="50dp"
android:height="50dp"/><!-- 宽度和高度 -->
<!-- 填充 -->
<solid
android:color="@android:color/white"/><!-- 填充的颜色 -->
<!-- 描边 -->
<stroke
android:width="2dp"
android:color="@android:color/black"
android:dashWidth="1dp" <!-- 表示设置边框为虚线,每一小段虚线的长度-->
android:dashGap="2dp"/> <!--每段虚线的间隔距离-->
</shape>
需要注意的是:
1、android:radius=”9dp”圆角属性是总的属性,若设置了其他的圆角属性后,在此方位的radius属性就无效了。
2、设置了填充色之后,渐变属性就不起作用了。