自定义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方法。

时间: 2024-12-09 10:05:20

自定义view的自定义属性方法的相关文章

Android 高手进阶之自定义View,自定义属性(带进度的圆形进度条)

转载请注明地址:http://blog.csdn.net/xiaanming/article/details/10298163 很多的时候,系统自带的View满足不了我们功能的需求,那么我们就需要自己来自定义一个能满足我们需求的View,自定义View我们需要先继承View,添加类的构造方法,重写父类View的一些方法,例如onDraw,为了我们自定义的View在一个项目中能够重用,有时候我们需要自定义其属性,举个很简单的例子,我在项目中的多个界面使用我自定义的View,每个界面该自定义View

Android自定义View的实现方法,带你一步步深入了解View(四)

转载请注明出处:http://blog.csdn.net/guolin_blog/article/details/17357967 不 知不觉中,带你一步步深入了解View系列的文章已经写到第四篇了,回顾一下,我们一共学习了LayoutInflater的原理分析.视图的绘制流程. 视图的状态及重绘等知识,算是把View中很多重要的知识点都涉及到了.如果你还没有看过我前面的几篇文章,建议先去阅读一下,多了解一些原理方面的东 西. 之前我有承诺过,会在View这个话题上多写几篇博客,讲一讲View的

【转】Android自定义View的实现方法,带你一步步深入了解View(四)

原文网址: 转载请注明出处:http://blog.csdn.net/guolin_blog/article/details/17357967 不知不觉中,带你一步步深入了解View系列的文章已经写到第四篇了,回顾一下,我们一共学习了LayoutInflater的原理分析.视图的绘制流程.视图的状态及重绘等知识,算是把View中很多重要的知识点都涉及到了.如果你还没有看过我前面的几篇文章,建议先去阅读一下,多了解一些原理方面的东西. 之前我有承诺过,会在View这个话题上多写几篇博客,讲一讲Vi

自定义View调用onDraw方法

============问题描述============ 我现在有一个需求,要自定义View,初始化的时候调用了onDraw方法,完后我自定义一个方法,调用该方法的时候,要重新调用onDraw方法,但我用postInvalidate无效,代码如下: 启动类: public class MainActivity extends Activity {         TestOnDraw view;                  @Override         protected void 

自定义view中自定义属性的用法.

有时候我们自定义的view需要用到有自己定义的属性. 首先定义自己的属性,在res/values/attrs.xml中定义,xml文件如下: <?xml version="1.0" encoding="utf-8"?> <resources> <declare-styleable name = "myView"> <attr name = "text" format = "s

自定义View 中一些方法的调用时机

onFinishInflate()函数的调用时机: onFinishInflate() 当View中所有的子控件均被映射成xml后触发 onMeasure(int, int) 确定所有子元素的大小 onLayout(boolean, int, int, int, int) 当View分配所有的子元素的大小和位置时触发 onSizeChanged(int, int, int, int) 当view的大小发生变化时触发 onDraw(Canvas) view渲染内容的细节 onKeyDown(int

Android初级教程初谈自定义view自定义属性

有些时候,自己要在布局文件中重复书写大量的代码来定义一个布局.这是最基本的使用,当然要掌握:但是有些场景都去对应的布局里面写对应的属性,就显得很无力.会发现,系统自带的控件无法满足我们的要求,这个时候就要考虑自定义控件.自定义view的世界,也很浩瀚,个人需要学的地方还有很多很多.自定义view,会节省开发效率,很有必要学习其基本原理和方法.接下来就对自定义view,做一个初步的认识,一步步了解封装的重要性.但是,也仅仅是一个初步,因为它实在太灵活了. 有这么一种场景,看图: 除了布局之外,还有

Android应用自定义View绘制方法手册

背景 这篇迟迟难产的文章算是对2015前半年的一个交代吧,那时候有一哥们要求来一发Android Canvas相关总结,这哥们还打赏了,实在不好意思,可是这事一放就给放忘了,最近群里小伙伴催着说没更新博客,坐等更新啥的,随先有这么一篇Android应用开发超级基础的文章诞生了(因为这种文章最好写哈,就是用熟了就行).不得不说下这么久为何一直没更新博客的原因了,首先遇上了过年,我个人崇尚过节就该放下一切好好陪陪亲人,珍惜在一起的时光:其次今年开年很是蛋疼,不是不顺当就是深深的觉得被坑,所以心情也就

Android_自定义View之跳动的loading

这篇文章记录一下Android自定义UI的知识,一个小小的跳动的loading,特别感谢Nil的指点-废话不多,先来效果 SoHOT链接和star地址:SoHOT源码地址,在文章最后最后有github开源地址,别错过 如果您还没有去给SoHOT一颗star而直接看这个项目,那简直是有点损失,希望您点上面的链接,去star和下载体验一下SoHoT,捡起那个大西瓜再来捡这个小芝麻项目,你懂的!! 凑乎看吧,录制的效果不如真机上平滑-凑乎看吧. 1,自定义View的自定义属性提取 2,View中动画的