`
flycomos.lee
  • 浏览: 280456 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

Android 中自定义属性(attr.xml,TypedArray)的使用!

 
阅读更多

xml 文件里定义控件的属性,我们已经习惯了android:attrs="" ,那么我们能不能定义自己的属性能,比如:test:attrs="" 呢?答案是肯定的.

 

好了我就不卖关子了,直接进入主题。大致以下步骤:

 

一、res/values 文件下定义一个attrs.xml 文件.代码如下:

 

 

  1. 一、在res/values文件下定义一个attrs.xml文件.代码如下:  
  2. <?xml version="1.0"  encoding= "utf-8" ?>  
  3. <resources>  
  4.     <declare-styleable name="MyView" >  
  5.         <attr name="textColor"  format= "color"  />  
  6.         <attr name="textSize"  format= "dimension"  />  
  7.     </declare-styleable>  
  8. </resources>  

 

 

二、 我们在MyView.java 代码修改如下,其中下面的构造方法是重点,我们获取定义的属性我们R.sytleable.MyView_textColor, 获取方法中后面通常设定默认值(float textSize = a.getDimension(R.styleable.MyView_textSize, 36 ); ) 防止我们在xml 文件中没有定义.从而使用默认值!

获取,MyView 就是定义在<declare-styleable name="MyView "></declare-styleable> 里的 名字,获取里面属性用 名字_ 属性 连接起来就可以.TypedArray 通常最后调用 .recycle() 方法,为了保持以后使用该属性一致性!

 

  1. public  MyView(Context context,AttributeSet attrs)  
  2.     {  
  3.         super (context,attrs);  
  4.         mPaint = new  Paint();  
  5.           
  6.         TypedArray a = context.obtainStyledAttributes(attrs,  
  7.                 R.styleable.MyView);  
  8.           
  9.         int  textColor = a.getColor(R.styleable.MyView_textColor,  
  10.                 0XFFFFFFFF );  
  11.         float  textSize = a.getDimension(R.styleable.MyView_textSize,  36 );  
  12.           
  13.         mPaint.setTextSize(textSize);  
  14.         mPaint.setColor(textColor);  
  15.           
  16.         a.recycle();  
  17.     }  

 

MyView.java 全部代码如下:

 

  1. package  com.android.tutor;  
  2. import  android.content.Context;  
  3. import  android.content.res.TypedArray;  
  4. import  android.graphics.Canvas;  
  5. import  android.graphics.Color;  
  6. import  android.graphics.Paint;  
  7. import  android.graphics.Rect;  
  8. import  android.graphics.Paint.Style;  
  9. import  android.util.AttributeSet;  
  10. import  android.view.View;  
  11. public   class  MyView  extends  View {  
  12.     private  Paint mPaint;  
  13.     private  Context mContext;  
  14.     private   static   final  String mString =  "Welcome to Mr Wei's blog" ;  
  15.       
  16.     public  MyView(Context context) {  
  17.         super (context);  
  18.         mPaint = new  Paint();  
  19.     }  
  20.     public  MyView(Context context,AttributeSet attrs)  
  21.     {  
  22.         super (context,attrs);  
  23.         mPaint = new  Paint();  
  24.           
  25.         TypedArray a = context.obtainStyledAttributes(attrs,  
  26.                 R.styleable.MyView);  
  27.           
  28.         int  textColor = a.getColor(R.styleable.MyView_textColor,  
  29.                 0XFFFFFFFF );  
  30.         float  textSize = a.getDimension(R.styleable.MyView_textSize,  36 );  
  31.           
  32.         mPaint.setTextSize(textSize);  
  33.         mPaint.setColor(textColor);  
  34.           
  35.         a.recycle();  
  36.     }  
  37.     @Override   
  38.     protected   void  onDraw(Canvas canvas) {  
  39.         // TODO Auto-generated method stub   
  40.         super .onDraw(canvas);  
  41.         //设置填充   
  42.         mPaint.setStyle(Style.FILL);  
  43.           
  44.         //画一个矩形,前俩个是矩形左上角坐标,后面俩个是右下角坐标   
  45.         canvas.drawRect(new  Rect( 10 10 100 100 ), mPaint);  
  46.           
  47.         mPaint.setColor(Color.BLUE);  
  48.         //绘制文字   
  49.         canvas.drawText(mString, 10 110 , mPaint);  
  50.     }  
  51. }  

 

三、将我们自定义的MyView 加入布局main.xml 文件中,平且使用自定义属性,自定义属性必须加上:

      xmlns:test ="http://schemas.android.com/apk/res/com.android.tutor "蓝色 是自定义属性的前缀,红色 是我们包名.

main.xml 全部代码如下:

 

  1. <?xml   
  2. version="1.0"  encoding= "utf-8" ?>  
  3. <LinearLayout   
  4. xmlns:android="http://schemas.android.com/apk/res/android"   
  5.                 
  6. xmlns:test="http://schemas.android.com/apk/res/com.android.tutor"   
  7.     android:orientation="vertical"   
  8.     android:layout_width="fill_parent"   
  9.     android:layout_height="fill_parent"   
  10.     >  
  11. <TextView    
  12.     android:layout_width="fill_parent"    
  13.     android:layout_height="wrap_content"    
  14.     android:text="@string/hello"   
  15.     />  
  16. <com.android.tutor.MyView  
  17.     android:layout_width="fill_parent"    
  18.     android:layout_height="fill_parent"    
  19.     test:textSize="20px"   
  20.     test:textColor="#fff"   
  21. />  
  22. </LinearLayout>  

 

四、运行之效果如下图:

 

分享到:
评论

相关推荐

    Android 中自定义属性(attr.xml,TypedArray)的使用

    在Android开发中,自定义属性(attr.xml, TypedArray)是一种强大的工具,它允许开发者扩展Android组件的功能,创建个性化的UI元素,同时提高代码的可重用性和可配置性。以下将详细介绍如何在Android中使用自定义...

    Android中自定义属性attrs.xml、TypedArray的使用

    总结一下,`attrs.xml`文件和`TypedArray`在Android自定义组件中起着至关重要的作用。它们允许开发者定义和获取自定义属性,使组件更具可配置性和可复用性。通过熟练掌握这两者,开发者可以更高效地创建出满足需求的...

    Aj_03的Android 中自定义属性(attr.xml,TypedArray)的使用(源码)

    测试:Android 中自定义属性(attr.xml,TypedArray)的使用 注意:MyView(Context context,AttributeSet attrs)构造函数的实现, 和注意main.xml的LinearLayout 里加的声明 要了解:test:textSize="20px" test:...

    Android自定义Attr属性

    以下将详细介绍Android自定义Attr属性的使用过程及其背后的原理。 首先,自定义Attr涉及到的主要步骤包括:定义属性、在资源文件中声明属性、解析属性值以及在代码中使用属性。让我们逐一探讨这些步骤: 1. **定义...

    Android如何使用XML自定义属性

    #### 二、在布局中使用自定义属性 1. **在布局文件中引用自定义属性** 在布局文件中,你可以通过指定属性名称的方式给自定义属性赋值: ```xml &lt;com.example.myapp.CustomView android:id="@+id/custom_view...

    android自定义属性(三种方法dome)

    定义和获取属性后,我们可以在XML布局文件中使用这些自定义属性。比如: ```xml &lt;com.example.CustomButton.CustomButton android:layout_width="wrap_content" android:layout_height="wrap_content" app:...

    Android自定义属性

    在Android开发中,自定义属性是一种非常常见的技术,它允许开发者扩展系统提供的组件特性,创建具有独特功能和外观的自定义视图或者组件。通过自定义属性,开发者可以更好地控制UI设计,提升应用的用户体验。以下是...

    Android 自定义属性及其引用

    本文将深入探讨Android自定义属性的创建、使用以及它们在实际项目中的应用。 首先,我们来了解自定义属性的定义。在Android中,自定义属性通常在资源XML文件的`&lt;declare-styleable&gt;`元素中定义。例如,假设我们要为...

    Android自定义菜单属性DEMO

    这包括在attr.xml文件中定义属性,解析这些属性并在自定义View类中使用它们,以及在布局文件中设置这些属性。这个DEMO对于提升Android开发者对自定义组件的理解和实践能力非常有帮助。通过学习和实践,开发者可以更...

    AttrTest android自定义属性

    3. 在布局文件中使用自定义属性。 4. 在`AndroidManifest.xml`中声明支持的命名空间,以便在布局编辑器中预览。 通过学习和实践这个简单的实例,你可以掌握Android自定义属性的基本用法,从而更好地定制你的应用...

    androidの自定义viw属性使用

    本文将深入探讨如何在Android中自定义View并使用属性(attrs.xml)来扩展其功能。 首先,自定义View的基本步骤包括创建一个新的View类,继承自Android的View或ViewGroup类,然后重写其构造函数、onDraw()方法等。但...

    android 重写控件添加自定义属性

    现在,我们可以在布局XML文件中使用这个自定义控件,并设置自定义属性: ```xml &lt;com.example.CustomButton android:layout_width="wrap_content" android:layout_height="wrap_content" app:customTextSize="24...

    android自定义控件LineDemo.rar

    总结,LineDemo是一个基础的Android自定义控件实例,它教会了我们如何创建一个简单但实用的自定义控件,包括定义属性、解析属性、重写`onDraw()`以及在布局中使用自定义控件。这只是一个起点,开发者可以通过这个...

    使用自定义属性源代码

    现在,我们可以在XML布局中使用这个自定义属性: ```xml &lt;com.example.RainAnimation android:layout_width="match_parent" android:layout_height="match_parent" app:rainColor="@color/colorPrimary" /&gt; ``` ...

    Android高手进阶教程与Android基础教程

    Android高手进阶教程之----Android 中自定义属性(attr.xml,TypedArray)的使用! .doc Android高手进阶教程之----Android中万能的BaseAdapter(Spinner,ListView,GridView)的使用!.doc Android高手进阶教程之----通过...

    android 自定义属性实现 ImageView 透明度渐变效果

    在Android项目中,自定义属性通常放在res/values/attrs.xml文件中。如果该文件不存在,需要手动创建。在这个文件中,我们将定义一个名为`alphaAnimationDuration`的属性,用于控制透明度渐变的持续时间。示例如下: ...

    android 自定义控件 自定义属性详细介绍

    在Android应用开发中,自定义控件和属性是提高代码复用性和灵活性的关键。当系统内置的控件和属性无法满足特定需求时,开发者可以通过自定义来实现更个性化的功能。本文将深入探讨如何在Android中创建自定义控件并...

    Android 自定义View 之 自定义属性 demo 修改版

    本篇文章将深入探讨如何在Android中进行自定义View,并以"自定义属性demo修改版"为例,讲解如何添加和使用自定义属性。 首先,自定义属性是在Android资源文件中定义的,通常在res/values/attrs.xml中。在这个示例中...

    自定义属性

    在Android开发中,自定义属性可以定义在自定义View类的`attr.xml`文件中,然后在`style.xml`或布局文件中引用。这允许开发者创建具有独特外观和行为的自定义控件。例如,你可以创建一个带有特殊边框、颜色或动画效果...

    android自定义属性控件

    以上内容涵盖了Android自定义属性控件的基本实现,包括自定义属性、自定义控件的绘制与交互,以及简单的Tab控件封装。通过这些技术,开发者可以构建出功能强大且具有个性化风格的Android应用。在实际项目中,还需要...

Global site tag (gtag.js) - Google Analytics