`

Android 中自定义控件和属性(attr.xml,declare-styleable,TypedArray)的方法和使用 一

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

进入主题。大致以下步骤:

一、 在res/values 文件下定义一个attrs.xml 文件.代码如下:
    <?xml version="1.0" encoding="utf-8"?> 
    <resources> 
        <declare-styleable name="MyView"> 
            <attr name="textColor" format="color" /> 
            <attr name="textSize" format="dimension" /> 
        </declare-styleable> 
    </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() 方法,为了保持以后使用该属性一致性!
public MyView(Context context,AttributeSet attrs) 
    { 
        super(context,attrs); 
        mPaint = new Paint(); 
         
        TypedArray a = context.obtainStyledAttributes(attrs, 
                R.styleable.MyView); 
         
        int textColor = a.getColor(R.styleable.MyView_textColor, 
                0XFFFFFFFF); 
        float textSize = a.getDimension(R.styleable.MyView_textSize, 36); 
         
        mPaint.setTextSize(textSize); 
        mPaint.setColor(textColor); 
         
        a.recycle(); 
    }
MyView.java  MyView控件全部代码如下:

    package com.android.tutor; 
    import android.content.Context; 
    import android.content.res.TypedArray; 
    import android.graphics.Canvas; 
    import android.graphics.Color; 
    import android.graphics.Paint; 
    import android.graphics.Rect; 
    import android.graphics.Paint.Style; 
    import android.util.AttributeSet; 
    import android.view.View; 
    public class MyView extends View { 
        private Paint mPaint; 
        private Context mContext; 
        private static final String mString = "Welcome to Mr Wei's blog"; 
         
        public MyView(Context context) { 
            super(context); 
            mPaint = new Paint(); 
        } 
        public MyView(Context context,AttributeSet attrs) 
        { 
            super(context,attrs); 
            mPaint = new Paint(); 
             
            TypedArray a = context.obtainStyledAttributes(attrs, 
                    R.styleable.MyView); 
             
            int textColor = a.getColor(R.styleable.MyView_textColor, 
                    0XFFFFFFFF); 
            float textSize = a.getDimension(R.styleable.MyView_textSize, 36); 
             
            mPaint.setTextSize(textSize); 
            mPaint.setColor(textColor); 
             
            a.recycle(); 
        } 
        @Override 
        protected void onDraw(Canvas canvas) { 
            // TODO Auto-generated method stub 
            super.onDraw(canvas); 
            //设置填充 
            mPaint.setStyle(Style.FILL); 
             
            //画一个矩形,前俩个是矩形左上角坐标,后面俩个是右下角坐标 
            canvas.drawRect(new Rect(10, 10, 100, 100), mPaint); 
             
            mPaint.setColor(Color.BLUE); 
            //绘制文字 
            canvas.drawText(mString, 10, 110, mPaint); 
        } 
    } 
三、将我们自定义的MyView 加入布局main.xml 文件中,并且使用自定义属性,自定义属性必须加上:
" xmlns:test ="http://schemas.android.com/apk/res/com.android.tutor"  ,test是自定义属性的前缀,com.android.tutor 是我们包名.

main.xml 全部代码如下:


    <?xml  
    version="1.0" encoding="utf-8"?> 
    <LinearLayout  
    xmlns:android="http://schemas.android.com/apk/res/android" 
                   
    xmlns:test="http://schemas.android.com/apk/res/com.android.tutor" 
        android:orientation="vertical" 
        android:layout_width="fill_parent" 
        android:layout_height="fill_parent" 
        > 
    <TextView   
        android:layout_width="fill_parent"  
        android:layout_height="wrap_content"  
        android:text="@string/hello" 
        /> 
    <com.android.tutor.MyView 
        android:layout_width="fill_parent"  
        android:layout_height="fill_parent"  
        test:textSize="20px" 
        test:textColor="#fff" 
    /> 
    </LinearLayout> 
运行之。
分享到:
评论

相关推荐

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

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

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

    接下来,我们要在自定义组件中使用这些属性。这通常在`onCreateView()`或`onInitializeTextView()`方法中完成,通过`TypedArray`来获取属性值。以下是一个`MyTextView`类的示例: ```java public class MyTextView ...

    android 自定义view-styleable 的使用

    而`styleable`是Android SDK提供的一种机制,使得自定义View能够接受XML属性,从而实现与系统控件类似的可配置性。下面我们将详细讨论如何在Android中使用自定义`styleable`以及其重要性。 首先,理解`styleable`的...

    android自定义控件及其属性设置

    在Android开发中,自定义控件是提升应用独特性和用户体验的重要手段。自定义控件允许开发者根据需求扩展标准Android组件,实现独特的交互效果和视觉样式。本教程将深入探讨如何在Android中创建自定义控件及其属性...

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

    最后,关于AndroidTest这个压缩包子文件,它可能包含了一个Android测试项目,用于验证上述自定义控件和属性的功能。在Android Studio中,我们可以编写单元测试、UI测试等来确保自定义控件的正确性和性能。测试代码...

    自定义控件入门级demo.zip

    6. 注册到Android系统:在res/values/attrs.xml文件中定义自定义属性,在res/layout布局文件中使用标签引入自定义控件。 二、自定义控件实例分析 在这个入门级demo中,我们可能看到以下关键代码: 1. 自定义控件...

    自定义控件属性与组合控件

    首先,自定义控件属性主要涉及`attr.xml`文件的创建和使用。在项目的`res/values`目录下,我们需要创建一个或多个`attr.xml`文件,用于定义自定义的属性。例如: ```xml &lt;declare-styleable name="MyCustomView"&gt;...

    Android自定义控件使用attrs属性Demo

    4. **使用自定义控件**:现在,我们可以在XML布局中使用自定义控件,并设置自定义属性。例如: ```xml &lt;com.example.myapp.CustomButton android:layout_width="wrap_content" android:layout_height="wrap_...

    Android自定义Attr属性

    通过自定义Attr,开发者可以创建自己的XML属性,使自定义控件更具有灵活性和扩展性。以下将详细介绍Android自定义Attr属性的使用过程及其背后的原理。 首先,自定义Attr涉及到的主要步骤包括:定义属性、在资源文件...

    XML解析自定义控件

    5. **编写布局XML**:在布局文件中使用自定义控件,并设置其属性: ```xml &lt;com.example.myapp.CustomButton android:layout_width="wrap_content" android:layout_height="wrap_content" app:custom_color="@...

    Android自定义控件

    为了在XML布局文件中使用自定义控件并设置其属性,我们需要在控件类中定义XML属性。这通常通过创建一个资源文件(如 attrs.xml)并在其中声明属性。例如,我们可以定义如“标题文本”、“字体大小”、“颜色”等属性...

    android自定义控件文档

    - **作用**:`declare-styleable`用于声明自定义控件支持的属性,便于在XML布局文件中使用这些属性。 - **实现步骤**: - 在`res/values`目录下创建一个XML文件,通常命名为`attrs.xml`。 - 在此文件中使用`...

    自定义控件属性的demo

    6. **在XML中使用自定义控件**:最后,在布局文件中,我们可以像使用其他Android内置控件一样使用`TestWidget`,并设置自定义属性: ```xml &lt;com.example.myapp.TestWidget android:layout_width="wrap_content" ...

    android自定义控件+自定义属性的使用

    4. 在布局XML文件中使用自定义控件,通过全限定类名引用。 例如,我们有一个自定义控件名为MyCustomView,它可能包含以下代码: ```java public class MyCustomView extends View { public MyCustomView(Context ...

    android自定义属性控件

    通过继承`android.view.View`或者`android.widget.TextView`等基类,我们可以在`attr.xml`文件中定义自定义属性,然后在`TypedArray`中解析这些属性,使得它们在运行时能够被读取和使用。 ```xml &lt;!-- attr.xml --&gt;...

    Android简单实现自定义控件

    接下来,我们可以在布局XML文件中使用这个自定义控件,就像使用其他标准控件一样。别忘了在`&lt;merge&gt;`或`&lt;layout&gt;`标签内引入自定义控件的命名空间,并在`&lt;TestCustomWidget&gt;`标签中指定自定义属性: ```xml ...

    自定义控件与属性

    总结,自定义控件和属性是Android开发中不可或缺的一部分。通过自定义控件,我们可以实现独特的界面设计和交互效果;通过自定义属性,我们可以更加灵活地配置和控制控件的外观和行为。在实际项目中,熟练掌握这些...

    自定义控件(自定义属性)

    本篇将深入探讨如何创建一个带有自定义属性的控件,并通过实例演示如何在布局文件中使用这些属性。 首先,创建自定义控件需要继承已有的View或ViewGroup类。在这个例子中,我们可以假设我们创建了一个名为...

    Android自定义控件 AddAndSubView【第二版】EditText输入框两边加减按钮Button Demo

    最后,为了在XML布局中使用自定义控件,我们需要在res/layout文件夹下创建一个新的XML布局文件,并引入我们的自定义控件。例如: ```xml &lt;!-- activity_main.xml --&gt; &lt;com.example.myapp.AddAndSubView xmlns:...

    Android中自定义标签的举例说明.pdf

    在类的构造函数中,我们通过`obtainStyledAttributes()`方法获取到`attrs.xml`中定义的属性,并通过`TypedArray`对象读取它们的值。注意,对于`testSize`,我们需要使用`getDimensionPixelSize()`来获取尺寸值,因为...

Global site tag (gtag.js) - Google Analytics