在开发中使用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两个属性用于设置渐变的中心点位置,仅当渐变类型为放射渐变时有效,类型为分数或小数。