绘图

android的绘图应该继承View组件,并重写onDraw(Canvas canvas)方法即可。

重写onDraw(Canvas canvas)方法时涉及一个绘图API:Canvas,Canvas代表了“依附”于指定View的画布,其提供了如下图所示的方法——用于绘制各种图像:

注意:在Canvas提供的绘制方法中还用到了一个API:Path,Path代表任意多条直线连接而成的任意图形,当Canvas根据Path绘制时,可以绘制出任意的形状。

实例如下:

  1. 布局文件==》
  2. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
  3. xmlns:tools="http://schemas.android.com/tools"
  4. android:layout_width="match_parent"
  5. android:layout_height="match_parent"
  6. android:orientation="vertical"
  7. tools:context=".MainActivity" >
  8.  
  9. <com.example.mycanvas.MyView
  10. android:id="@+id/myView1"
  11. android:layout_width="wrap_content"
  12. android:layout_height="wrap_content" />
  13.  
  14. </LinearLayout>
  15.  
  16. 代码实现==》
  17. package com.example.mycanvas;
  18.  
  19. import android.content.Context;
  20. import android.graphics.Canvas;
  21. import android.graphics.Color;
  22. import android.graphics.LinearGradient;
  23. import android.graphics.Paint;
  24. import android.graphics.Path;
  25. import android.graphics.RectF;
  26. import android.graphics.Shader;
  27. import android.util.AttributeSet;
  28. import android.view.View;
  29.  
  30. public class MyView extends View
  31. {
  32. public MyView(Context context, AttributeSet set)
  33. {
  34. super(context, set);
  35. }
  36.  
  37. @Override
  38. protected void onDraw(Canvas canvas)
  39. {
  40. super.onDraw(canvas);
  41. // 把整张布绘制成白色
  42. canvas.drawColor(Color.WHITE);
  43. Paint p = new Paint();
  44. // 去除锯齿
  45. p.setAntiAlias(true);
  46. p.setColor(Color.BLUE);
  47. p.setStyle(Paint.Style.STROKE);
  48. p.setStrokeWidth(3);
  49. // 绘制圆形
  50. canvas.drawCircle(40, 40, 30, p);
  51. // 绘制正方形
  52. canvas.drawRect(10, 80, 70, 140, p);
  53. // 绘制矩形
  54. canvas.drawRect(10, 150, 70, 190, p);
  55. RectF rect = new RectF(10, 200, 70, 230);
  56. // 绘制圆角矩形
  57. canvas.drawRoundRect(rect, 15, 15, p);
  58. RectF rect1 = new RectF(10, 240, 70, 270);
  59. // 绘制椭圆
  60. canvas.drawOval(rect1, p);
  61.  
  62. paintTriangle(canvas, p);
  63. paintFivePointStar(canvas, p);
  64. paintGraph(canvas, p);
  65. paintGraph2(canvas, p);
  66. paintGraph3(canvas, p);
  67. }
  68.  
  69. /* 设置字符大小后绘制 */
  70. private void paintGraph3(Canvas canvas, Paint paint)
  71. {
  72. paint.setTextSize(26);
  73. paint.setShader(null);
  74. // 绘制字符串
  75. canvas.drawText("圆形", 260, 50, paint);
  76. // canvas.drawText("方形", 260, 120, paint);
  77. // canvas.drawText("长方形", 240, 170, paint);
  78. // canvas.drawText("圆角矩形", 230, 220, paint);
  79. // canvas.drawText("圆形", 240, 260, paint);
  80. // canvas.drawText("三角形", 240, 325, paint);
  81. // canvas.drawText("五角形", 240, 390, paint);
  82. }
  83.  
  84. private void paintGraph2(Canvas canvas, Paint paint)
  85. {
  86. // 设置渐变器后绘制
  87. Shader shader = new LinearGradient(0, 0, 40, 60, new int[] { Color.RED, Color.GREEN,
  88. Color.BLUE, Color.YELLOW }, null, Shader.TileMode.REPEAT);
  89. paint.setShader(shader);
  90. // 设置阴影
  91. paint.setShadowLayer(45, 10, 10, Color.GRAY);
  92. // 绘制圆形
  93. canvas.drawCircle(200, 40, 30, paint);
  94. // 绘制正方形
  95. canvas.drawRect(170, 80, 230, 140, paint);
  96. // 绘制矩形
  97. canvas.drawRect(170, 150, 230, 190, paint);
  98. // 绘制圆角矩形
  99. RectF r = new RectF(170, 200, 230, 230);
  100. canvas.drawRect(r, paint);
  101.  
  102. // 绘制椭圆
  103. RectF rel2 = new RectF(170, 240, 230, 270);
  104. canvas.drawOval(rel2, paint);
  105.  
  106. // 绘制三角形
  107. Path path = new Path();
  108. path.moveTo(170, 340);
  109. path.lineTo(230, 340);
  110. path.lineTo(200, 290);
  111. path.close();
  112. // 根据Path进行绘制,绘制三角形
  113. canvas.drawPath(path, paint);
  114.  
  115. // 定义一个Path对象,封闭成一个三角形
  116. Path p1 = new Path();
  117. p1.moveTo(186, 360);
  118. p1.lineTo(214, 360);
  119. p1.lineTo(230, 392);
  120. p1.lineTo(200, 420);
  121. p1.lineTo(170, 392);
  122. p1.close();
  123. // 根据Path进行绘制,绘制三角形
  124. canvas.drawPath(p1, paint);
  125. }
  126.  
  127. private void paintGraph(Canvas canvas, Paint p)
  128. {
  129. // 设置填充风格后绘制
  130. p.setStyle(Paint.Style.FILL);
  131. p.setColor(Color.RED);
  132. canvas.drawCircle(120, 40, 30, p);
  133. // 绘制正方形
  134. canvas.drawRect(90, 80, 150, 140, p);
  135. // 绘制矩形
  136. canvas.drawRect(90, 150, 150, 190, p);
  137. RectF re2 = new RectF(90, 200, 150, 230);
  138. // 绘制圆角矩形
  139. canvas.drawRoundRect(re2, 15, 15, p);
  140.  
  141. RectF rel2 = new RectF(90, 240, 150, 270);
  142. // 绘制椭圆
  143. canvas.drawOval(rel2, p);
  144.  
  145. // 绘制三角形
  146. Path path = new Path();
  147. path.moveTo(90, 340);
  148. path.lineTo(150, 340);
  149. path.lineTo(120, 290);
  150. path.close();
  151. // 根据Path进行绘制,绘制三角形
  152. canvas.drawPath(path, p);
  153.  
  154. // 定义一个Path对象,封闭成一个三角形
  155. Path p1 = new Path();
  156. p1.moveTo(106, 360);
  157. p1.lineTo(134, 360);
  158. p1.lineTo(150, 390);
  159. p1.lineTo(120, 420);
  160. p1.lineTo(90, 392);
  161. p1.close();
  162. // 根据Path进行绘制,绘制三角形
  163. canvas.drawPath(p1, p);
  164. }
  165.  
  166. private void paintFivePointStar(Canvas canvas, Paint p)
  167. {
  168. // 定义一个Path对象,封闭成一个五角星
  169. Path p2 = new Path();
  170. p2.moveTo(26, 360);
  171. p2.lineTo(54, 360);
  172. p2.lineTo(70, 392);
  173. p2.lineTo(40, 420);
  174. p2.lineTo(10, 392);
  175. p2.close();
  176. // 根据Path进行绘制,绘制五角形
  177. canvas.drawPath(p2, p);
  178. }
  179.  
  180. private void paintTriangle(Canvas canvas, Paint p)
  181. {
  182. // 定义一个Path对象,封闭成一个三角形
  183. Path p1 = new Path();
  184. p1.moveTo(10, 340);
  185. p1.lineTo(70, 340);
  186. p1.lineTo(40, 290);
  187. p1.close();
  188. // 根据Path进行绘制,绘制三角形
  189. canvas.drawPath(p1, p);
  190. }
  191.  
  192. }

注:将自定义组件拖放到布局文件,即可看到效果,如下图所示:

android学习笔记42——图形图像处理2——绘图的更多相关文章

  1. android学习笔记43——图形图像处理3——Path

    Path类 Path类可以预先在View上将N个点连成一条“路径”,然后调用Canavas的drawPath(path,paint)即可沿着路径绘制图形. android还为路径绘制提供了PathEf ...

  2. android学习笔记41——图形图像处理1

    图像图像处理 ImageView:用于显示普通静态图片: AnimationDrawable:用于开发逐帧动画: Animation:用于对普通图片使用补间动画: Bitmap.BitmapFacto ...

  3. Android学习笔记进阶18 之画图并保存图片到本地

    1.首先创建一个Bitmap图片,并指定大小:   2.在该图片上创建一个新的画布Canvas,然后在画布上绘制,并保存即可:   3.需要保存的目录File,注意如果写的目录如“/sdcard/so ...

  4. Android学习笔记进阶18之画图并保存图片到本地

    1.首先创建一个Bitmap图片,并指定大小:   2.在该图片上创建一个新的画布Canvas,然后在画布上绘制,并保存即可:   3.需要保存的目录File,注意如果写的目录如“/sdcard/so ...

  5. Android 学习笔记之Volley(七)实现Json数据加载和解析...

    学习内容: 1.使用Volley实现异步加载Json数据...   Volley的第二大请求就是通过发送请求异步实现Json数据信息的加载,加载Json数据有两种方式,一种是通过获取Json对象,然后 ...

  6. Android学习笔记进阶之在图片上涂鸦(能清屏)

    Android学习笔记进阶之在图片上涂鸦(能清屏) 2013-11-19 10:52 117人阅读 评论(0) 收藏 举报 HandWritingActivity.java package xiaos ...

  7. android学习笔记36——使用原始XML文件

    XML文件 android中使用XML文件,需要开发者手动创建res/xml文件夹. 实例如下: book.xml==> <?xml version="1.0" enc ...

  8. Android学习笔记之JSON数据解析

    转载:Android学习笔记44:JSON数据解析 JSON(JavaScript Object Notation)是一种轻量级的数据交换格式,采用完全独立于语言的文本格式,为Web应用开发提供了一种 ...

  9. udacity android 学习笔记: lesson 4 part b

    udacity android 学习笔记: lesson 4 part b 作者:干货店打杂的 /titer1 /Archimedes 出处:https://code.csdn.net/titer1 ...

随机推荐

  1. Java-->发牌流程修改版

    --> 这一次要封装得狠一点... package com.xm.ddz; // 每一张牌的属性 public class Card { private String flowerColor; ...

  2. Android模仿QQ空间图片上传——原理

    MainActivity.class package com.example.imagedemotext; import java.io.ByteArrayOutputStream; import j ...

  3. Android多分辨率适配经验总结

      Android多分辨率适配是一件很有意义但是比较麻烦的事情,网上有很多关于多分辨率适配的文章,多数文章讲解的都是整个APP的图片比较规则,可以将图片做成9图来完成多分辨率适配,但是对于一些游戏类应 ...

  4. UVa 572 油田(DFS求连通块)

    https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_problem& ...

  5. JavaWeb学习记录(二十三)——文件上传与下载

    一.导入jar包

  6. 第n小的质数

    总时间限制:  1000ms 内存限制:  65536kB 描述 输入一个正整数n,求第n小的质数. 输入 一个不超过10000的正整数n. 输出 第n小的质数. 样例输入 10 样例输出 29 代碼 ...

  7. 家族_NOI导刊2010普及(10)

    题目描述 在一个与世隔绝的岛屿上,有一个有趣的现象:同一个家族的人家总是相邻的(这里的相邻是指东南西北四个方向),不同的家族之间总会有河流或是山丘隔绝,但同一个家族的人不一定有相同姓氏.现在给你岛上的 ...

  8. POJ 1469 COURSES(二部图匹配)

                                                                     COURSES Time Limit: 1000MS   Memory ...

  9. Python 基础语法(四)

    Python 基础语法(四) --------------------------------------------接 Python 基础语法(三)------------------------- ...

  10. /usr/include/gnu/stubs.h:7:27: error: gnu/stubs-32.h:No such file or directory的解决办法

    在编译32位HDecode时出现如题所示的错误,原因时没有安装32位glibc库导致的: ubuntu: sudo apt-get install libc6-dev-i386 CentOS:yum ...