ShapeDrawable使用记录

来源:互联网 发布:js arguments用法 编辑:程序博客网 时间:2024/06/07 05:18

      • Shape的属性
      • 子标签
        • 1corners
        • 2solid
        • 3stroke
        • 4size
        • 5padding
        • 6gradient
        • 注意事项

在开发中使用shape的时候总是记不清有哪些子标签或者属性,每次都是使用的时候去网上查一查,但是有时候查到的资料讲解不是很清楚,所以打算自己写一篇,在后面用到的时候便于查阅。

Shape的属性

ShapeDrawable可以通过设置shape属性来定义形状,shape属性有四个值代表了四中形状。rectangle、oval、line、ring分别代表矩形、椭圆形、线性以及环形,其中ShapeDrawable的默认形状为矩形。

其中当shape为ring(环形)时特有的属性如下:

//尺寸,内环的半径android:innerRadius  //浮点型,以环的宽度比率来表示内环的半径         android:innerRadiusRatio//尺寸,环的厚度     android:thickness//浮点型,以环的宽度比率来表示环的厚度            android:thicknessRatio // boolean值,如果当做是LevelListDrawable使用时值为true,否则为false     android:useLevel     

子标签

1、corners

corners用于定义圆角,当shape为rectangle时有效果。

<corners //上下左右四个角的圆角半径 android:radius="dimension"   //左上角的圆角半径      android:topLeftRadius="dimension"  //右上角的圆角半径 android:topRightRadius="dimension"    //左下角的圆角半径  android:bottomLeftRadius="dimension"    //右下角的圆角半径  android:bottomRightRadius="dimension" />   

2、solid

solid用于定义内部填充色。

//color为某个颜色<solid  android:color="color" />  

3、stroke

stroke用于定义描边,能够定义边的宽度、边的形状(实线或者虚线)以及颜色。

<stroke        //描边的宽度  android:width="dimension"   //描边的颜色 android:color="color"    //虚线的宽度,值为0时是实线     android:dashWidth="dimension"      //虚线的间隔  android:dashGap="dimension" />     

其中默认定义为实线,当dashWidth值不为0时表示定义虚线。

4、size

size用于定义尺寸大小。

<size   android:width="dimension"   android:height="dimension" /> 

注意:这里可以定义尺寸大小,但是控件本身就可以设置尺寸大小,所以这个值会以控件设定值和size中设定的值的较大者为准。

5、padding

padding用于设置内边距,与平时xml中使用的padding一样的效果。

<padding    android:left="dimension"   android:top="dimension"   android:right="dimension"   android:bottom="dimension" /> 

6、gradient

gradient用于定义渐变色,可以是两色渐变(忽略中间颜色)和三色渐变以及渐变的样式。

<gradient //共有3中渐变类型,线性渐变(默认)/放射渐变/扫描式渐变  android:type=["linear" | "radial" | "sweep"]    //渐变角度,必须为45的倍数,0为从左到右,90为从上到下android:angle="integer"     //渐变中心X的相对位置,范围为0~1  android:centerX="float"  //渐变中心Y的相对位置,范围为0~1     android:centerY="float"    //渐变开始点的颜色  android:startColor="color"    //渐变中间点的颜色android:centerColor="color"   //渐变结束点的颜色  android:endColor="color" //渐变的半径,只有当渐变类型为radial时才能使用     android:gradientRadius="float"   //使用LevelListDrawable时就要设置为true。设为false时才有渐变效果  android:useLevel=["true" | "false"] />  

其中centerColor属性是可选的,如果不使用centerColor属性就是两色渐变。

注意事项

1、在构造放射性渐变时,要加上android:gradientRadius属性(渐变半径),即必须指定渐变半径的大小才会起作用。

2、angle属性只对线性渐变有效,其它两种渐变方式都没有效果。

3、centerX、centerY两个属性用于设置渐变的中心点位置,仅当渐变类型为放射渐变时有效,类型为分数或小数。

原创粉丝点击