Android之图形图像之使用Path类总结

举报
chenyu 发表于 2021/07/27 00:54:38 2021/07/27
【摘要】 Path类可以预先在View上将N个点连成一条"路径",然后调用Canvas的drawPath(path,paint)即可沿着路径绘制图形 Android还为路径绘制提供了PathEffect来定义绘制效果,PathEffect包含如下子类 ComposePathEffect CornerPathEffect DashPathEffect Discret...

Path类可以预先在View上将N个点连成一条"路径",然后调用Canvas的drawPath(path,paint)即可沿着路径绘制图形

Android还为路径绘制提供了PathEffect来定义绘制效果,PathEffect包含如下子类

ComposePathEffect

CornerPathEffect

DashPathEffect

DiscretePathEffect

PathDashPathEffect

SumPathEffect

下面的示例将会逐一使用上面的绘制效果


  
  1. package WangLi.Graphics.PathTest;
  2. import android.app.Activity;
  3. import android.content.Context;
  4. import android.graphics.Canvas;
  5. import android.graphics.Color;
  6. import android.graphics.ComposePathEffect;
  7. import android.graphics.CornerPathEffect;
  8. import android.graphics.DashPathEffect;
  9. import android.graphics.DiscretePathEffect;
  10. import android.graphics.Paint;
  11. import android.graphics.Path;
  12. import android.graphics.PathDashPathEffect;
  13. import android.graphics.PathEffect;
  14. import android.graphics.SumPathEffect;
  15. import android.os.Bundle;
  16. import android.view.View;
  17. public class PathTest extends Activity {
  18. /** Called when the activity is first created. */
  19. @Override
  20. public void onCreate(Bundle savedInstanceState) {
  21. super.onCreate(savedInstanceState);
  22. setContentView(new MyView(this));
  23. }
  24. class MyView extends View
  25. {
  26. float phase;
  27. PathEffect[] effects = new PathEffect[7];
  28. int[] colors;
  29. private Paint paint;
  30. Path path;
  31. public MyView(Context context) {
  32. super(context);
  33. paint = new Paint();
  34. paint.setStyle(Paint.Style.STROKE);
  35. paint.setStrokeWidth(4);
  36. //创建,并初始化Path
  37. path = new Path();
  38. path.moveTo(0, 0);
  39. for(int i = 1; i<= 15; i++)
  40. {
  41. //生成15个点,随机生成它们的坐标,并将它们连成一条Path
  42. path.lineTo(i*20, (float)Math.random()*60);
  43. }
  44. //初始化七个颜色
  45. colors = new int[] {
  46. Color.BLACK,Color.BLUE,Color.CYAN,
  47. Color.GREEN,Color.MAGENTA,Color.RED,Color.YELLOW
  48. };
  49. }
  50. protected void onDraw(Canvas canvas)
  51. {
  52. //将背景填充成白色
  53. canvas.drawColor(Color.WHITE);
  54. //-------下面开始初始化7中路径的效果
  55. //使用路径效果
  56. effects[0] = null;
  57. //使用CornerPathEffect路径效果
  58. effects[1] = new CornerPathEffect(10);
  59. //初始化DiscretePathEffect
  60. effects[2] = new DiscretePathEffect(3.0f,5.0f);
  61. //初始化DashPathEffect
  62. effects[3] = new DashPathEffect(new float[]{20,10,5,10},phase);
  63. //初始化PathDashPathEffect
  64. Path p = new Path();
  65. p.addRect(0, 0, 8, 8, Path.Direction.CCW);
  66. effects[4] = new PathDashPathEffect(p,12,phase,PathDashPathEffect.Style.ROTATE);
  67. //初始化PathDashPathEffect
  68. effects[5] = new ComposePathEffect(effects[2],effects[4]);
  69. effects[6] = new SumPathEffect(effects[4],effects[3]);
  70. //将画布移到8,8处开始绘制
  71. canvas.translate(8, 8);
  72. //依次使用7中不同路径效果,7种不同的颜色来绘制路径
  73. for(int i = 0; i < effects.length; i++)
  74. {
  75. paint.setPathEffect(effects[i]);
  76. paint.setColor(colors[i]);
  77. canvas.drawPath(path, paint);
  78. canvas.translate(0, 60);
  79. }
  80. //改变phase值,形成动画效果
  81. phase += 1;
  82. invalidate();
  83. }
  84. }
  85. }
效果如下



文章来源: chenyu.blog.csdn.net,作者:chen.yu,版权归原作者所有,如需转载,请联系作者。

原文链接:chenyu.blog.csdn.net/article/details/50484174

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。