android:shape的使用

  1. <shape>  
  2.     <!-- 实心 -->  
  3.     <solid android:color="#ff9d77"/>  
  4.     <!-- 渐变 -->  
  5.     <gradient  
  6.         android:startColor="#ff8c00"  
  7.         android:endColor="#FFFFFF"  
  8.         android:angle="270" />  
  9.     <!-- 描边 -->  
  10.     <stroke  
  11.         android:width="2dp"  
  12.         android:color="#dcdcdc" />  
  13.     <!-- 圆角 -->  
  14.     <corners  
  15.         android:radius="2dp" />  
  16.     <padding  
  17.         android:left="10dp"  
  18.         android:top="10dp"  
  19.         android:right="10dp"  
  20.         android:bottom="10dp" />  
  21. </shape>  
  22. solid:实心,就是填充的意思
    android:color指定填充的颜色

    gradient:渐变
    android:startColor和android:endColor分别为起始和结束颜色,ndroid:angle是渐变角度,必须为45的整数倍。
    另外渐变默认的模式为android:type="linear",即线性渐变,可以指定渐变为径向渐变,android:type="radial",径向渐变需要指定半径android:gradientRadius="50"。

    stroke:描边
    android:width="2dp" 描边的宽度,android:color 描边的颜色。
    我们还可以把描边弄成虚线的形式,设置方式为:
    android:dashWidth="5dp"

    android:dashGap="3dp"
    其中android:dashWidth表示'-'这样一个横线的宽度,android:dashGap表示之间隔开的距离。

    corners:圆角
    android:radius为角的弧度,值越大角越圆。
    我们还可以把四个角设定成不同的角度,方法为:

    复制到剪贴板    XML/HTML代码
    1. <corners  
    2.   
    3.         android:topRightRadius="20dp"    右上角  
    4.         android:bottomLeftRadius="20dp"    右下角  
    5.         android:topLeftRadius="1dp"    左上角  
    6.         android:bottomRightRadius="0dp"    左下角  
    7. />  



    这里有个地方需要注意,bottomLeftRadius是右下角,而不是左下角,这个有点郁闷,不过不影响使用,记得别搞错了就行。

      但是我用1.6的手机设置0dip是无效的,而用2.3.5的平板是有效果的,所以我把左下角角度设成0.01了,肉眼就看不出来与0dip的差别。

    padding:间隔
    这个就不用多说了,XML布局文件中经常用到。


    大体的就是这样,以下是一个使用的具体示例:用在Selector中作为Button的背景,分别定义了按钮的一般状态、获得焦点状态和按下时的状态,具体代码如下:

     

    复制到剪贴板  XML/HTML代码
    1. main.xml:  
    2. <Button  
    3.     android:layout_width="wrap_content"  
    4.     android:layout_height="wrap_content"  
    5.     android:text="TestShapeButton"  
    6.     android:background="@drawable/button_selector"  
    7.     />  
    8. >  

  23.     <!-- 圆角 -->
        <corners android:radius="100dp" />
        <!-- 设置圆角半径 -->




        <!-- 描边 -->
        <stroke
            android:width="1dp"
            android:color="#999999" />


        <!-- 填充的颜色 -->
        <solid android:color="#FFFFFF" >
        </solid>


        <!-- 间隔 -->
        <padding
            android:bottom="2dp"
            android:left="2dp"
            android:right="2dp"
            android:top="2dp" />
        <!-- 各方向的间隔 -->
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

贾修行

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值