看了无数资料,总结一下自定义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. Scheduling In Go

    https://www.ardanlabs.com/blog/2018/08/scheduling-in-go-part1.html https://blog.altoros.com/golang-i ...

  2. npm 加速之 yarn cnpm pnpm

    npm 加速之 yarn cnpm pnpm 有没有感觉到使用 npm 的时候很慢? 安装速度 几Kb/s 不说, 还装着装着出错了, 奇奇怪怪的问题.这种情况大多数还是因为网络的原因, 很多时候虽然 ...

  3. (原)理解码率控制模式(x264,x265,vpx)

    理解码率控制模式(x264,x265,vpx) 原文链接:https://slhck.info/video/2017/03/01/rate-control.html 翻译:lihaiping1603@ ...

  4. (原)关于使用imagemagick将gif叠加到图片或者画布上的方法,以及疑难杂症

    今天因为项目过程中,有一个小需求,需要将一个指定的gif按照指定大小,叠加到画布的指定位置上,本来对于熟悉这块的人,简直就是小菜一碟哈,但本人因为对imagemagick的不熟悉,导致在这个需求上摸索 ...

  5. Ubuntu16.04安装Consul

    1.下载安装包 https://www.consul.io/downloads.html wget https://releases.hashicorp.com/consul/1.5.3/consul ...

  6. 使用swig在python中调用C++

    1.安装swig 下载链接: http://www.swig.org/survey.html tar -xvf swig-.tar.gz ./configure --prefix=/usr/local ...

  7. 量化编程技术—pdb进行调试

    # -*- coding: utf-8 -*- # @Date: 2017-08-26 # @Original: import pdb def gen_buy_change_list(): buy_c ...

  8. vue播放mu38视频兼容谷歌ie等浏览器

    <template> <div id="id_test_video" style="width:100%; height:auto;"> ...

  9. massif 图例

    19.63^ ### | # | # :: | # : ::: | :::::::::# : : :: | : # : : : :: | : # : : : : ::: | : # : : : : : ...

  10. LinkedHashSet有没有重复的元素

      1.LinkedHashSet 的概述和使用 llinkedHashSet 的特点: 是唯一能保证怎么存就怎么输出的 set 集合,并且去重复 1 LinkedHashSet<String& ...