Android绘图机制(三)——自定义View的三种实现方式以及实战项目操作


Android绘图机制(一)——自定义View的基础属性和方法

里说过,实现自定义View有三种方式,分别是

1.对现有的控件进行扩展

2.通过组件来实现新的控件

3.重写View来实现全新的控件

所以本节就来带大家把这个流程走一遍,我们用到的项目还是

Android绘图机制(二)——自定义View绘制形, 圆形, 三角形, 扇形, 椭圆, 曲线,文字和图片的坐标讲解

本节现在就是做一个真正意义上的自定义View的操作了

注意本节的项目来自于《Android群英传》中的几个小例子

一.对现有的控件进行扩展之自定义TextView

我们新建一个Class类TextView继承TextView
package com.lgl.view.view;

import android.content.Context;
import android.graphics.Canvas;
import android.graphics.Color;
import android.graphics.Paint;
import android.util.AttributeSet;

/**
 * Created by LGL on 2016/1/10.
 */
public class TextView extends android.widget.TextView {

    private Paint paint1, paint2;

    public TextView(Context context) {
        super(context);
    }

    public TextView(Context context, AttributeSet attrs) {
        super(context, attrs);
    }

    @Override
    protected void onDraw(Canvas canvas) {

        //实例化画笔
        paint1 = new Paint();
        //给画笔1设置颜色
        paint1.setColor(getResources()
                .getColor(android.R.color.holo_blue_light));
        //给画笔1设置Style
        paint1.setStyle(Paint.Style.FILL);

        //实例化画笔
        paint2 = new Paint();
        //给画笔2设置颜色
        paint2.setColor(Color.YELLOW);
        //给画笔2设置Style
        paint2.setStyle(Paint.Style.FILL);

        //绘制外层矩形
        canvas.drawRect(0, 0, getMeasuredWidth(), getMeasuredHeight(), paint1);
        //绘制内层矩形
        canvas.drawRect(10, 10, getMeasuredWidth() - 10, getMeasuredHeight() - 10, paint2);
        canvas.save();
        //父类完成的方法,即绘制完成
        super.onDraw(canvas);
    }
}

截图

二.重写View来实现全新的控件

市面上有许许多多的APP,他们之中有很多的控件都不是原生的,而是需要我们自定义View的
package com.lgl.view.view;

import android.content.Context;
import android.graphics.Canvas;
import android.graphics.Color;
import android.graphics.Paint;
import android.graphics.RectF;
import android.util.AttributeSet;
import android.view.View;
import android.view.WindowManager;

/**
 * 半弧圆
 * Created by LGL on 2016/1/10.
 */
public class RCircleView extends View {

    //弧的画笔
    private Paint rpaint;
    //圆的画笔
    private Paint cpaint;
    //文字的画笔
    private Paint tvpaint;
    //屏幕高宽
    private int width, height;
    //文字
    private String text = "绘制半弧圆";

    public RCircleView(Context context) {
        super(context);
        init();
    }

    public RCircleView(Context context, AttributeSet attrs) {
        super(context, attrs);
        init();
    }

    private void init() {
        //获取屏幕的宽高
        //Android绘图机制(一)——自定义View的基础属性和方法里面有讲
        WindowManager wm = (WindowManager) getContext()
                .getSystemService(Context.WINDOW_SERVICE);

        width = wm.getDefaultDisplay().getWidth();
        height = wm.getDefaultDisplay().getHeight();
    }

    @Override
    protected void onDraw(Canvas canvas) {
        super.onDraw(canvas);

        //实例化画笔,以及设置属性,颜色,文字大小
        rpaint = new Paint();
        rpaint.setStyle(Paint.Style.STROKE);
        cpaint = new Paint();
        tvpaint = new Paint();
        tvpaint.setColor(Color.WHITE);
        tvpaint.setTextSize(20);
        //绘制弧线的区域矩形
        RectF mArcRectF = new RectF((float) (width * 0.1), (float) (width * 0.1), (float) (width * 0.9), (float) (width * 0.9));
        //绘制圆
        canvas.drawCircle(width / 2, width / 2, (float) (width * 0.5 / 3), cpaint);
        //绘制弧线
        canvas.drawArc(mArcRectF, 270, 240, false, rpaint);
        //这样绘制的话,会出现偏差的,文字以圆形的中心开始绘制
        canvas.drawText(text, width / 2, width / 2, tvpaint);
    }
}

截图

这里,你会疑惑,为什么文字不是居中?我们来画个图

这个还是比较基础的,下一节我们就来点新的玩法

Demo下载:本系列最后一节提供

最新文章

  1. 剑指Offer面试题:19.包含Min函数的栈
  2. Mono.Posix.dll文件
  3. iOS:WebKit内核框架的应用与解析
  4. PHP 点滴疑惑
  5. C++实现建立和一二进制树的三个递归遍历
  6. PSU 离11.2.0.3.0 -> 11.2.0.3.11 如果解决冲突的整个
  7. CODEFORCES#274 DIV2
  8. oracle即时客户端安装方法
  9. Nuget安装nupkg文件
  10. web.xml解析
  11. 网站开发进阶(三十七)JSP页面跳转问题解决
  12. SLAM入门之视觉里程计(1):特征点的匹配
  13. [转]Kaldi命令词识别
  14. [转]用C#在windows上操控电脑自带蓝牙(入道指南)
  15. C#泛型的学习
  16. Linux中的sleep、usleep、nanosleep、poll和select
  17. Chrome快捷键大全
  18. HDU 2323
  19. java try catch finally return执行
  20. C++的一些知识点摘抄(创建基本类 高级类)

热门文章

  1. Java实现内部类
  2. [ExtJS5学习笔记]第十三节 Extjs5的Ext.each方法学习
  3. EBS总账模块与其他模块数据关联关系
  4. Tomcat集群如何同步会话
  5. 开源项目——小Q聊天机器人V1.0
  6. linux常用的压缩与解压缩命令
  7. Dynamics CRM2013/2015 Plugin注册工具Register New Assembly时无法看到注册按钮的解决办法
  8. Hadoop:Hadoop简介及环境配置
  9. python中MySQLdb的使用
  10. 安卓手机与ROS通信遥控Gazebo中仿真机器人小车运动(ROS_indigo)