自定义view的自定义属性方法

  一般自定义view以达到某些效果,复写onDraw()方法就行了。当我们需要动态地响应用户的操作且能像Android自带View那样直接操作属性就很方便了,为了达到这个目的,我们就可以使用自定义view属性的方法来对我们的自定义view进行动态响应了。

   为了实现自定义的view的自定义属性,应该完成这四步:

  • 为你的view在资源标签下定义自设的属性
  • 在你的XML layout中指定属性值
  • 在运行时获取属性值
  • 把获取到的属性值应用在你的view上

step1

   在资源标签下定义自设的属性,放置于res/values/attrs.xml文件中。下面是一个attrs.xml文件的示例:

1 <resources>
2    <declare-styleable name="PieChart">
3        <attr name="showText" format="boolean" />
4        <attr name="labelPosition" format="enum">
5            <enum name="left" value="0"/>
6            <enum name="right" value="1"/>
7        </attr>
8    </declare-styleable>
9 </resources>

  上面的代码声明了2个自设的属性,showTextlabelPosition,它们都归属于PieChart的项目下的styleable实例。styleable实例的名字,通常与自定义的view名字一致。当然你也可以不一致。

step2:

  一旦你定义了自设的属性,你就可以在layout XML文件中使用它们。唯一不同的是你自设的属性是归属于自己项目的命名空间。不是属于http://schemas.android.com/apk/res/android的命名空间,它们归属于http://schemas.android.com/apk/res/[your package name]。例如,下面演示了如何为PieChart使用上面定义的属性:

1 <?xml version="1.0" encoding="utf-8"?>
2 <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
3    xmlns:custom="http://schemas.android.com/apk/res/com.example.customviews">
4  <com.example.customviews.charting.PieChart
5      custom:showText="true"
6      custom:labelPosition="left" />
7 </LinearLayout>

  为了避免输入长串的namespace名字,示例上面参考android别名的方法,使用了custom作为别名,你也可以选择其他的名称所为你的namespace,这只是一个变量名。请注意,如果你的view是一个内部类,你必须指定这个view的外部类。同样的,如果PieChart有一个内部类叫做PieView。为了使用这个类中自设的属性,你应该使用com.example.customviews.charting.PieChart$PieView.

step3:

  在运行时获取属性值,当view从XML layout被创建的时候,在xml标签下的属性值都是从resource下读取出来并传递到view的构造方法中作为一个AttributeSet参数。我们通过obtainStyledAttributes()来获取属性值。这个方法会传递一个TypedArray对象。view通过TypedArray对象解析出属性值。

 1 public PieChart(Context context, AttributeSet attrs) {
 2    super(context, attrs);
 3    TypedArray a = context.getTheme().obtainStyledAttributes(
 4         attrs,
 5         R.styleable.PieChart,
 6         0, 0);
 7 
 8    try {
 9        mShowText = a.getBoolean(R.styleable.PieChart_showText, false);
10        mTextPos = a.getInteger(R.styleable.PieChart_labelPosition, 0);
11    } finally {
12        a.recycle();
13    }
14 }

  ps:注意TypedArray对象是一个公共资源,必须被在使用后进行回收。

step4:

  从构造方法中获取到自定义属性,我们就可以应用自定义属性了。为了动态地实现一些view效果,我们可以放出getter 与setter方法来达到目的:

1 public boolean isShowText() {
2    return mShowText;
3 }
4 
5 public void setShowText(boolean showText) {
6    mShowText = showText;
7    invalidate();
8    requestLayout();
9 }

  请注意,在setShowText方法里面有调用invalidate()) and requestLayout()). 当view的某些内容发生变化的时候,需要调用invalidate来通知系统对这个view进行重新绘制,当某些元素变化会引起组件大小变化时,需要调用requestLayout方法。

 

posted @ 2015-04-24 15:04  Simba.Chen  阅读(622)  评论(0编辑  收藏  举报