`
v5browser
  • 浏览: 1130628 次
社区版块
存档分类
最新评论

【Android UI】 Shape详解 (GradientDrawable)

 
阅读更多

在Android开发过程中,经常需要改变控件的默认样式, 那么通常会使用多个图片来解决。不过这种方式可能需要多个图片,比如一个按钮,需要点击时的式样图片,默认的式样图片。 这样就容易使apk变大。

那么除了使用drawable这样的图片外,还有其他方法吗?

本次就谈一下自定义图形shape,Android上支持以下几种属性shape、gradient、stroke、corners、padding、solid等。

先来看两个例子:

  1. <shape
  2. xmlns:android="http://schemas.android.com/apk/res/android"
  3. android:shape="rectangle">
  4. <gradientandroid:startColor="#FFFF0000"
  5. android:endColor="#80FF00FF"
  6. android:angle="270"/>
  7. <paddingandroid:left="50dp"
  8. android:top="20dp"android:right="7dp"
  9. android:bottom="7dp"/>
  10. <cornersandroid:radius="8dp"/>
  11. </shape>

效果:

  1. <?xmlversion="1.0"encoding="UTF-8"?>
  2. <shapeandroid:shape="rectangle"
  3. xmlns:android="http://schemas.android.com/apk/res/android">
  4. <solidandroid:color="#b4000000"/>
  5. <strokeandroid:width="2.0dip"
  6. android:color="#b4ffffff"
  7. android:dashWidth="3.0dip"
  8. android:dashGap="0.0dip"/>
  9. <paddingandroid:left="7.0dip"
  10. android:top="7.0dip"android:right="7.0dip"
  11. android:bottom="7.0dip"/>
  12. <cornersandroid:radius="8.0dip"/>
  13. </shape>

效果:

总结一下Shape的所有子属性,如图:

简单说明一下:

gradient-- 对应颜色渐变。 startcolor、endcolor就不多说了。android:angle 是指从哪个角度开始变。

solid -- 填充。

stroke -- 描边。

corners -- 圆角。

padding -- 定义内容离边界的距离。 与android:padding_left、android:padding_right这些是一个道理。


上面这些不是本讲重点。 本讲的重点是这些xml中属性,与Java类的对应关系, 以及如何使用Java类写出上面一样的效果!

首先来看对应关系:

父节点 shape -- ShapeDrawable

[子节点] gradient --

[子节点]padding --

[子节点]corners -- setCornerRadiussetCornerRadii

[子节点]solid --

[子节点] stroke -- setStroke

[子节点] size -- setSize

发现只有几个是可以对应的~~ 看来通过Java代码来实现上述是行不通的..

暂时研究到这, 如果有实现的朋友,希望可以留言指点,非常感谢。


附件对android.graphics.drawable.Drawable包下的类进行了一下总结。 包括类与XML属性的对应关系。 感觉很不错! 需要的各位可以学习一下。

下载地址: http://download.csdn.net/source/3251635

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics