Android自定义控件的实现步骤(二)

前天已经写了一个关于自定义控件的实现步骤的博客,这个是附上代码的详细版本

首先,我们得新建一个attrs.xml的资源文件,在上面添加我们将要自定义控件的额外属性,就是自定义控件的自定义属性,具体代码如下:

<resources>

    <declare-styleable name="TestView">
        <attr name="textColor" format="color"></attr>
        <attr name="textSize" format="dimension"></attr>
        <attr name="imgBackground" format="integer"></attr>
        <attr name="topBorder" format="boolean"></attr>
        <attr name="bottomBorder" format="boolean"></attr>
        <attr name="leftBorder" format="boolean"></attr>
        <attr name="rightBorder" format="boolean"></attr>
    </declare-styleable>

</resources>

然后我们在定义一个自己控件的类,要继承相应的控件比如说你想自定义一个TextView控件,你就得继承TextView这个类,然后在类中定义与你上面属性相对应的变量,然后通过TypedArray类获得相应的属性的值,然后也就是最主要的一点,我们得在OnDraw函数中使用,具体代码如下:

public class MyView extends TextView {

    private Paint mTextPaint;
    private Paint mBorderPaint;
    private Context mContext;
    private boolean mTopBorder;
    private boolean mBottomBorder;
    private boolean mLeftBorder;
    private boolean mRightBorder;

    public MyView(Context context, AttributeSet attrs) {
        super(context, attrs);
        // TODO Auto-generated constructor stub
        mContext = context;
        initMyView();
        // 对于我们自定义的类中,我们需要使用一个名为obtainStyledAttributes的方法来获取我们的定义。
        TypedArray params = context.obtainStyledAttributes(attrs,
                R.styleable.TestView);
        // 得到自定义控件的属性值。
        int backgroudId = params.getResourceId(
                R.styleable.TestView_imgBackground, 0);
        if (backgroudId != 0)
            setBackgroundResource(backgroudId);
        int textColor = params.getColor(R.styleable.TestView_textColor,
                0XFFFFFFFF);
        setTextColor(textColor);
        float textSize = params.getDimension(R.styleable.TestView_textSize, 40);
        setTextSize(textSize);

        mTopBorder = params.getBoolean(R.styleable.TestView_topBorder, true);
        mLeftBorder = params.getBoolean(R.styleable.TestView_leftBorder, true);
        mBottomBorder = params.getBoolean(R.styleable.TestView_bottomBorder, true);
        mRightBorder = params.getBoolean(R.styleable.TestView_rightBorder, true);

    }

    @Override
    protected void onDraw(Canvas canvas) {
        super.onDraw(canvas);
        if (mTopBorder == true)
            canvas.drawLine(0, 0, this.getWidth() - 1, 0, mBorderPaint);
        if (mRightBorder == true)
            canvas.drawLine(this.getWidth() - 1, 0, this.getWidth() - 1,
                    this.getHeight() - 1, mBorderPaint);
        if (mBottomBorder == true)
            canvas.drawLine(this.getWidth() - 1, this.getHeight() - 1, 0,
                    this.getHeight() - 1, mBorderPaint);
        if (mLeftBorder == true)
            canvas.drawLine(0, this.getHeight() - 1, 0, 0, mBorderPaint);
    }

    public void initMyView() {
        mTextPaint = new Paint();
        mTextPaint.setColor(Color.WHITE);

        mBorderPaint = new Paint();
        mBorderPaint.setColor(android.graphics.Color.BLACK);
    }

    public void setTextColor(int textColor) {
        mTextPaint.setColor(0XFFAABBCC);
    }

    public void setTextSize(float textSize) {
        mTextPaint.setTextSize(textSize);
    }

    public void setTopBorder(boolean mTopBorder) {
        this.mTopBorder = mTopBorder;
    }

    public void setBottomBorder(boolean mBottomBorder) {
        this.mBottomBorder = mBottomBorder;
    }

    public void setLeftBorder(boolean mLeftBorder) {
        this.mLeftBorder = mLeftBorder;
    }

    public void setRightBorder(boolean mRightBorder) {
        this.mRightBorder = mRightBorder;
    }

    public void setPaddings(float paddingLeft, float paddingTop) {
        setPadding((int) paddingLeft, (int) paddingTop, 0, 0);
    }
}

最后一步就是在你的Activity的布局中使用你所定义的控件,具体的使用方法就是你自定义控件的类所在的包的包名加上类名(使用的时候,在设置自定义属性的时候是没有提示的,得自己记住自己设定的属性)

 <myControl.MyView
                    android:id="@+id/TextView_Tue"
                    android:layout_width="@dimen/cell_width"
                    android:layout_height="40dp"
                    android:layout_weight="1"
                    android:background="@drawable/solid"
                    android:text="" />

注:最后的注意的是在使用自定义控件的时候,必须在前面加上自己属性的引用,如下代码(入第二行所示):

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:myView="http://schemas.android.com/apk/res/com.zsxy_schedule"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical" >

Android自定义控件的实现步骤(二)

时间: 2024-08-26 09:59:26

Android自定义控件的实现步骤(二)的相关文章

Android 自定义控件开发入门(二)

上一次我们讲了一堆实现自定义控件的理论基础,列举了View类一些可以重写的方法,我们对这些方法的重写是我们继承View类来派生自定义控件的关键 我通过一个最简单的例子给大家展示了这一个过程,无论是多么复杂的自定义控件,思路总是这样子的,但是因为我们仅仅重写了onDraw方法使得大家觉得怪怪的,作为一个控件,我们居然还要为了他的实现为其增加麻烦的监听,这就不能叫做控件了. 下面再给大家介绍一个经常重写的方法法:publicboolean onTouchEvent (MotionEvent even

Android自定义控件的实现步骤(一)

今天下午,研究了一下Android的自定义控件该怎样实现,算是有了一点眉目,现在总结下,当做加深记忆,也许对那些刚开始学Android的人会有点帮助 以下是我总结出来的步骤: 1. 首先,要创建一个attrs的xml文件,来储存要自定义控件的属性,就是创建一个xml文件,然后使用<declare-styeable>声明控件名,然后用<attr>标签实现属性的名字和对应的类型. 2. 创建相应的类,继承要自定义的控件类,然后实现相应的构造方法,定义与属性相关的变量以及对应的get和s

Android自定义控件之自定义组合控件(三)

前言: 前两篇介绍了自定义控件的基础原理Android自定义控件之基本原理(一).自定义属性Android自定义控件之自定义属性(二).今天重点介绍一下如何通过自定义组合控件来提高布局的复用,降低开发成本,以及维护成本. 使用自定义组合控件的好处? 我们在项目开发中经常会遇见很多相似或者相同的布局,比如APP的标题栏,我们从三种方式实现标题栏来对比自定义组件带来的好处,毕竟好的东西还是以提高开发效率,降低开发成本为导向的. 1.)第一种方式:直接在每个xml布局中写相同的标题栏布局代码 <?xm

Android自定义控件之自定义ViewGroup实现标签云(四)

前言: 前面几篇讲了自定义控件绘制原理Android自定义控件之基本原理(一),自定义属性Android自定义控件之自定义属性(二),自定义组合控件Android自定义控件之自定义组合控件(三),常言道:“好记性不如烂笔头,光说不练假把式!!!”,作为一名学渣就是因为没有遵循这句名言才沦落于此,所以要谨遵教诲,注重理论与实践相结合,今天通过自定义ViewGroup来实现一下项目中用到的标签云. 需求背景: 公司需要实现一个知识点的标签显示,每个标签的长度未知,如下图所示 基本绘制流程: 绘制原理

Android自定义控件View(二)

在前一篇博客中学习了Android自定义控件View的流程步骤和注意点,不了解的童鞋可以参考Android自定义控件View(一).这一节开始学习自定义控件View(二)之继承系统已有的控件.我们来自定义一个圆形ImageView. RoundImageView 随着Android UI效果越来越炫,很多系统自带的控件已经无法满足日常开发需求,比如很多应用的头像是圆形的,QQ头像就是圆形的图片.但是Android系统提供的控件当中没有一个是圆形的.那么怎么才能实现圆形头像效果呢?两种方法: 图片

android 自定义控件二之仿QQ长按删除

自定义Dialog 1.先上个效果图: 虽然效果丑了点,但主要学习修改已有的控件,例如修改Dialog控件 2.一些基本的只是进行了解 Dialog: theme是Dialog的样式,常用样式为: <style name="MyDialogStyle" parent="@android:Theme.Dialog"> <item name="android:windowFrame">@null</item> &l

android自定义控件(二)Canvas

一.重要方法 1.translate2.scale3.rotate 二.注意 1.明确顺序 canvas.rotate(45); canvas.drawRect(new Rect(50, 50, 100, 100), paint); 如果顺序调换,则没有旋转的效果 2.转换的时候,需要把转换的中心点移到shape自身的中心 int left=50,top=50, right = 100,bottom = 100; canvas.translate(right/2, bottom/2); canv

Android自定义控件系列八:详解onMeasure()(二)--利用onMeasure测量来实现图片拉伸永不变形,解决屏幕适配问题

上一篇文章详细讲解了一下onMeasure/measure方法在Android自定义控件时的原理和作用,参看博文:Android自定义控件系列七:详解onMeasure()方法中如何测量一个控件尺寸(一),今天就来真正实践一下,让这两个方法大显神威来帮我们搞定图片的屏幕适配问题. 请尊重原创劳动成果,转载请注明出处:http://blog.csdn.net/cyp331203/article/details/45038329,非允许请勿用于商业或盈利用途,违者必究. 使用ImageView会遇到

Android自定义控件系列二:如何自定义属性

上一篇Android自定义控件系列一:如何测量控件尺寸 我们讲了如何确定控件的属性,这篇接着也是讲个必要的知识-如何自定义属性.对于一个完整的或者说真正有实用价值的控件,自定义属性是必不可少的. 如何为控件定义属性 在res/values/attrs.xml(attrs.xml如果不存在,可以创建个)中使用<declare-styleable>标签定义属性,比如我想定义个显示头像的圆形的图片控件(AvatarImageView): 01.<?xml version="1.0&q