看了无数资料,总结一下自定义View
先明白一个自定义View的三大流程

  • onMeasure()
    测量,决定View的大小

  • onLayout()
    布局,决定View在ViewGroup中的位置

  • onDraw()
    绘制,画出这个View的内容

这三个方法都存在于View类中,我们自定义View需要针对这三个方法做出修改来达到我们需要的目标或功能
先来一个最基本的例子,我们单纯的画一个圆,我们只需修改onDraw()方法即可
MyCustomVew.java

  1. public class MyCustomView extends View { 


  2. public MyCustomView(Context context, AttributeSet attrs, int defStyleAttr) { 

  3. super(context, attrs, defStyleAttr); 

  4. // TODO Auto-generated constructor stub 




  5. public MyCustomView(Context context, AttributeSet attrs) { 

  6. super(context, attrs); 

  7. // TODO Auto-generated constructor stub 




  8. public MyCustomView(Context context) { 

  9. super(context); 

  10. // TODO Auto-generated constructor stub 




  11. @Override 

  12. protected void onDraw(Canvas canvas) { 

  13. // TODO Auto-generated method stub 

  14. super.onDraw(canvas); 

  15. // 实例化画笔并打开抗锯齿 

  16. Paint paint = new Paint(Paint.ANTI_ALIAS_FLAG); 

  17. // 设置画笔颜色 

  18. paint.setColor(Color.RED); 

  19. /** 

  20. * 画笔样式分三种:  

  21. * 1.Paint.Style.STROKE:描边  

  22. * 2.Paint.Style.FILL_AND_STROKE:描边并填充 

  23. * 3.Paint.Style.FILL:填充 既然是画圆,那么就选择样式为描边 

  24. */ 

  25. paint.setStyle(Paint.Style.STROKE); 

  26. /* 

  27. * 设置描边的粗细,单位:像素px 注意:当setStrokeWidth(0)的时候描边宽度并不为0而是只占一个像素 

  28. */ 

  29. paint.setStrokeWidth(10); 

  30. // 参数含义依次为:圆心X坐标、圆心Y坐标、圆半径、画笔 

  31. canvas.drawCircle(500, 500, 200, paint); 





在Activity的布局文件中引入这个自定义View

  1. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" 

  2. xmlns:app="http://schemas.android.com/apk/res-auto" 

  3. android:id="@+id/main_root_ll" 

  4. android:layout_width="match_parent" 

  5. android:layout_height="match_parent" 

  6. android:orientation="vertical" > 


  7. <com.example.testcustomview.MyCustomView 

  8. android:id="@+id/main_cv" 

  9. android:layout_width="match_parent" 

  10. android:layout_height="match_parent" /> 


  11. </LinearLayout> 

运行结果如下

如果我们想要让这个圆动起来呢?我们只要不断的去修改onDraw()不断的绘制就可以了
譬如我们想要画一个由小到大的实心圆,我们需要做的就是不断的改变的半径
MyCustomView

  1. public class MyCustomView extends View implements Runnable { 


  2. private int radiu;// 圆的半径 

  3. private Paint paint; 


  4. public MyCustomView(Context context, AttributeSet attrs) { 

  5. super(context, attrs); 

  6. initPaint(); 




  7. public MyCustomView(Context context) { 

  8. this(context, null); 




  9. public void initPaint() { 

  10. paint = new Paint(Paint.ANTI_ALIAS_FLAG); 

  11. // 设置画笔颜色 

  12. paint.setColor(Color.RED); 

  13. /** 

  14. * 画笔样式分三种: 1.Paint.Style.STROKE:描边 2.Paint.Style.FILL_AND_STROKE:描边并填充 

  15. * 3.Paint.Style.FILL:填充 既然是画圆,那么就选择样式为描边 

  16. */ 

  17. paint.setStyle(Paint.Style.FILL_AND_STROKE); 

  18. /* 

  19. * 设置描边的粗细,单位:像素px 注意:当setStrokeWidth(0)的时候描边宽度并不为0而是只占一个像素 

  20. */ 

  21. paint.setStrokeWidth(10); 




  22. @Override 

  23. protected void onDraw(Canvas canvas) { 

  24. // TODO Auto-generated method stub 

  25. super.onDraw(canvas); 

  26. canvas.drawCircle(500, 500, radiu, paint); 




  27. @Override 

  28. public void run() { 

  29. while (radiu <= 200) { 

  30. try { 

  31. radiu += 10; 

  32. Thread.sleep(300); 

  33. //刷新View 

  34. postInvalidate(); 

  35. } catch (InterruptedException e) { 

  36. // TODO Auto-generated catch block 

  37. e.printStackTrace(); 









可以看到我们在run方法中调用了一个postInvalidate(),这个方法还有一个对应的方法Invalidate(),这两个方法的区别在于

  • postInvalidate()
    前者是在非UI线程中使,用来刷新界面

  • Invalidate()
    在UI线程自身中使用,用来刷新界面

刚才的例子是画了一个圆,canvas还提供了其他一系列方法来供我们调用,用来画各种各样的图形
下篇文章来介绍

自定义View(一),初识自定义View的更多相关文章

  1. [asp.net mvc 奇淫巧技] 01 - 封装上下文 - 在View中获取自定义的上下文

    我们在asp.net 开发中已经封装了最强大的HttpContext,我们可以在HttpContext中可以获取到几乎任何想获取的东西,也可以在HttpContext写入需要返回客户端的信息.但是这些 ...

  2. Android 自定义View修炼-【2014年最后的分享啦】Android实现自定义刮刮卡效果View

    一.简介: 今天是2014年最后一天啦,首先在这里,我祝福大家在新的2015年都一个个的新健康,新收入,新顺利,新如意!!! 上一偏,我介绍了用Xfermode实现自定义圆角和椭圆图片view的博文& ...

  3. Android 自定义View修炼-自定义可动画展开收缩View的实现

    有时候需要点击一个view可以动画展开和收缩折叠一个View这样的效果,这样就可以直接自定义View来实现. 本例中,采用继承FrameLayout来实现自定义的ExpandView.下面将详细介绍各 ...

  4. 自定义View 一 (继承VIew重写onDraw方法)

    项目:具有圆形效果的自定义View 一.继承View并重写onDraw方法 public class CircleView extends View{ private static final int ...

  5. Android查缺补漏(View篇)--自定义 View 的基本流程

    View是Android很重要的一部分,常用的View有Button.TextView.EditView.ListView.GridView.各种layout等等,开发者通过对这些View的各种组合以 ...

  6. Android view相关与自定义View

    一.关于view的机制的问答 1.gesturedetector和ontouchevent的区别 gesturedetector指的是手势检测器,根据动态手势的运动特性,提出了速率边沿检测算法来分割手 ...

  7. 【Android - 自定义View】之自定义九宫格手势解锁控件

    首先来介绍一下这个自定义View: (1)这个自定义View的名称叫做 LockView ,继承自View类: (2)这个自定义View实现了应用中常见的九宫格手势解锁功能,可以用于保证应用安全: ( ...

  8. 【Android - 自定义View】之自定义View实现“刮刮卡”效果

    首先来介绍一下这个自定义View: (1)这个自定义View的名字叫做 GuaguakaView ,继承自View类: (2)这个View实现了很多电商项目中的“刮刮卡”的效果,即用户可以刮开覆盖层, ...

  9. 【Android - 自定义View】之自定义可滚动的流式布局

    首先来介绍一下这个自定义View: (1)这个自定义View的名称叫做 FlowLayout ,继承自ViewGroup类: (2)在这个自定义View中,用户可以放入所有继承自View类的视图,这个 ...

  10. 【Android - 自定义View】之自定义可下拉刷新或上拉加载的ListView

    首先来介绍一下这个自定义View: (1)这个自定义View的名称叫做 RefreshableListView ,继承自ListView类: (2)在这个自定义View中,用户可以设置是否支持下拉刷新 ...

随机推荐

  1. 大幅度改变celery日志外观,修改成日志可点击跳转和鲜艳五彩日志,解决脚本中已添加handler的logger和框架日志重复记录问题。

    大幅度改变celery日志外观,修改成日志可点击跳转和鲜艳五彩日志,解决脚本中已添加handler的logger和框架日志重复记录问题.打猴子补丁. 先把脚本中的所有logger的handlers全部 ...

  2. Maven 常用工具类整理

    目录 1.Apache Commons 1.1.字符串处理 1.2.集合操作 1.3.IO操作 1.4.编解码操作 2.Google Guava 2.1.多场景使用 2.2.guava-retryin ...

  3. sql 在查询到的语句基础上添加行号

    正常查询语句: SELECT TagName FROM ps_status a WHERE a.TagName LIKE "DTmk_zybf%1bxxjcqh.PV" 查询结果: ...

  4. CentOS上安装配置RabbitMQ Server

    1. 安装Erlang 由于rabbitmq是基于erlang语言开发的,所以必须先安装erlang. curl -s https://packagecloud.io/install/reposito ...

  5. maven-archetype-plugin 的正确打开方式

    1.  准备好一个编辑好的模板工程 2. 在 pom.xml 中添加 maven-archetype-plugin 插件 <plugin> <groupId>org.apach ...

  6. 通过下载git包来安装git

    Git是一个开源的分布式版本控制系统,可以有效.高速的处理从很小到非常大的项目版本管理.而国外的GitHub和国内的Coding都是项目的托管平台.但是在使用Git工具的时候,第一步要学会如何安装gi ...

  7. 1-3docker commit定制镜像

    以定制⼀个 Web 服务器为例⼦ 1.commit定制镜像 docker pull nginx:1.17   运行容器 --name:容器名字 -d:后台 -p本地端口:容器内端口 docker ru ...

  8. HTML5自定义select标签样式的方法

    HTML5自定义select标签样式的方法 -webkit-appearance: none; 这个东西可以隐藏箭头 不过手机端就直接 设置透明度为0就行了(如果这种做法比前面个要麻烦点 毕竟还要对他 ...

  9. javascript (0, obj.prop)()的用法

    我第一次看到这种奇怪的用法是在babel的源码中, 其实它的原理就是使得在prop这个方法里无法获取this, 从而无法对类中的其他变量或方法做操作. obj.prop() 这是一个方法调用, pro ...

  10. ajax中如何使用全局变量?

    在ajax中一般都是采取默认的异步请求,但是有时候参数是需要做到全局通用,这时候发起同步请求. 如下: $.ajax({ type:"post", url:"url路径& ...