Shape在Android当中主要用来定义各种的形状属性的,在UI开发当中用的比较多。下面就来介绍一下各种属性的具体含义。
它的创建和引用方法跟状态选择器(selector)是一样的,需要先创建一个xml文件再引用。
文件位置:res/drawable/filename.xml
引用方法:
在代码中: R.drawable.filename
在XML文件: @[package:]drawable/filename
一个官方示例:
<?xml version="1.0" encoding="utf-8"?> <shape xmlns:android="http://schemas.android.com/apk/res/android" android:shape=["rectangle" | "oval" | "line" | "ring"] > <corners android:radius="integer" android:topLeftRadius="integer" android:topRightRadius="integer" android:bottomLeftRadius="integer" android:bottomRightRadius="integer" /> <gradient android:angle="integer" android:centerX="float" android:centerY="float" android:centerColor="integer" android:endColor="color" android:gradientRadius="integer" android:startColor="color" android:type=["linear" | "radial" | "sweep"] android:useLevel=["true" | "false"] /> <padding android:left="integer" android:top="integer" android:right="integer" android:bottom="integer" /> <size android:width="integer" android:height="integer" /> <solid android:color="color" /> <stroke android:width="integer" android:color="color" android:dashWidth="integer" android:dashGap="integer" /> </shape>
开头属性的含义
–android:shape 设置形状,分别有四个属性
–rectangle 矩形
–oval 圆形
–line 线型
–ring 环形
标签属性的含义
–corners 圆角
android:radius=”10dp” 四个角的半径
android:topLeftRadius=”10dp” 左上角半径
android:topRightRadius=”10dp” 右上角半径
android:bottomLeftRadius=”10dp” 左下角半径
android:bottomRightRadius=”10dp” 右下角半径
–gradient 渐变效果
android:angle=”integer” 渐变角度,必须为45的整数倍
android:centerX=”float” 渐变中心X的相当位置,范围为0~1
android:centerY=”float” 渐变中心Y的相当位置,范围为0~1
android:centerColor=”integer” 渐变中间的颜色
android:endColor=”color” 渐变结束的颜色
android:gradientRadius=”integer” 在设置径向渐变的时候需要此半径
android:startColor=”color” 开始渐变的颜色
android:type=[“linear” | “radial” | “sweep”] 渐变模式(linear线性、radial径向渐变、sweep扇形渐变)
android:useLevel=[“true” | “false”] 使用LevelListDrawable时就要设置为true。设为false时才有渐变效果
–padding 间隔(设置上下左右四个方向的间隔)
android:left=”integer”
android:top=”integer”
android:right=”integer”
android:bottom=”integer”
<!– 设置各个方向的间隔 –>
–size 形状的大小
android:width=”integer”
android:height=”integer”
–solid 充填纯色
android:color=”color”
–stroke 描边效果
android:width=”integer” 边宽
android:color=”color” 边色
android:dashWidth=”integer” 虚线短横线宽度
android:dashGap=”integer” 虚线短横线间隔