看了无数资料,总结一下自定义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. [Golang] 消费Kafka的日志提交到ElasticSearch

    0x0 需求 消费Kafka的日志并写入ElasticSearch供查询 0x1 依赖库 golang版Kafka客户端 https://github.com/Shopify/sarama golan ...

  2. delphi uniDac

    Delphi 2010安装及使用UniDAC 4.0 UniDAC是一个功能强大的非可视化跨数据库的数据访问组件,可用于Delphi,Delphi for .NET,C++Builder,and La ...

  3. k8s-job使用

    一.job特性 运行完成后退出,但是不会被删除,便于用户查看日志信息,了解任务完成的情况 删除job时产生的pod也会被一起删除 job中可以运行多个pod(任务执行多次),且可以并行运行缩短任务完成 ...

  4. Sublime Text3 搭建前端开发环境

    第一步:百度搜索sublime text3 ,直接点击红色箭头下方的下载地址,下载完成安装后会提示是否更新,直接点击更新就好了! 第二步:下载插件管理器,点击菜单栏Tools->Package ...

  5. 深入分析——HashSet是否真的无序?(JDK8)

    HashSet 是否无序 (一) 问题起因: <Core Java Volume I-Fundamentals>中对HashSet的描述是这样的: HashSet:一种没有重复元素的无序集 ...

  6. linux查看端口常用命令

    netstat命令参数: -t : 指明显示TCP端口 -u : 指明显示UDP端口 -l : 仅显示监听套接字(所谓套接字就是使应用程序能够读写与收发通讯协议(protocol)与资料的程序) -p ...

  7. 如何获取文件夹下所有文件名称(windows)

    1. win+R -> cmd 打开dos命令窗口 2. 打开需获取文件名的位置 3. 获取名称 命令格式:dir /b >> 文件目标盘符:\文件夹位置(可省略)\目标名称.目标后 ...

  8. 修改 Delphi 10.3.3 IDE 字体和字体大小

    Delphi 10.2.2 之前,可以通过 IDE视觉设置的系统注册表项 修改字体和字体大小,因为 Delphi 10.2.2 IDE增加了主题,主题包含了字体信息, 此方法失效了.对于高分辨率屏幕, ...

  9. golang函数式编程

  10. HSF 开发

    HSF 简介 HSF(High Speed Service Framework),高速服务框架,是阿里-主要采用的服务框架,其目的是 作为桥梁联通不同的业务系统,解耦系统之间的实现依赖. 1: RPC ...