android中实现在ImageView上随意画线涂鸦的方法

 更新时间:2018年10月10日 09:58:05   作者:浩GE  
今天小编就为大家分享一篇android中实现在ImageView上随意画线涂鸦的方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧

我实现的思路:

1.继承ImageView类

2.重写onTouchEvent方法,在ACTION_MOVE(即移动时),记录下所经过的点坐标,在ACTION_UP时(即手指离开时,这时一条线已经画完),将所画的线(点的集合)保存在一个集合中

3.重写onDraw方法,利用canvas和所记录下的线和点画出线来

可能我讲的十分笼统,下面来看看实际的代码吧

//代表ImageView上的一点
public class ViewPoint
{
  float x;
  float y;
}

//表示一条线
public class Line
{
  ArrayList<ViewPoint> points = new ArrayList<ViewPoint>(); 
}

如上所示,ViewPoint表示一点,而Line表示一条线

然后在扩展的ImageView类上声明如下:

public class HandWritingImageView extends ImageView
{
  private Paint paint;

  //当前正在画的线
  private Line current = new Line();
 //所有画过的线
  private ArrayList<Line> lines = new ArrayList<Line>(); 
}

随后重写onTouchEvent方法

@Override
 public boolean onTouchEvent(MotionEvent event)
 { 
 //获取坐标
 clickX = event.getX();
 clickY = event.getY();
 
 if (event.getAction() == MotionEvent.ACTION_DOWN)
 {
  invalidate();
  
  return true;
 }
 else if (event.getAction() == MotionEvent.ACTION_MOVE) 
 {
  ViewPoint point = new ViewPoint();
  point.x = clickX;
  point.y = clickY;
  //在移动时添加所经过的点
  current.points.add(point);

  invalidate();
  return true;
 }
 else if (event.getAction() == MotionEvent.ACTION_UP) 
 { 
  //添加画过的线
  lines.add(current);
  current = new Line();
   
  invalidate();
 }
 
 return super.onTouchEvent(event);
 }

可以看到当我们手指移动时,获取保存所经过的点并调用invalidate方法进行屏幕刷新(可以使onDraw方法被调用,稍后可以看到),当我们手指离开时添加之前的所画的线到集合中,并调用invalidate方法

接下来看看所重写的onDraw方法,它利用所保存的线的信息进行画线

@Override 
 protected void onDraw(Canvas canvas) 
 { 
 super.onDraw(canvas);
 //画出之前所有的线
 for (int i = 0; i < lineData.lines.size(); i++)
 {
  drawLine(canvas, lines.get(i));
 }
  
 //画出当前的线
 drawLine(canvas, current);
 
 } 
 
 private void drawLine(Canvas canvas, Line line)
 {
 for (int i = 0; i < line.points.size() - 1; i++)
 {
  float x = line.points.get(i).x;
  float y = line.points.get(i).y;
  
  float nextX = line.points.get(i + 1).x;
  float nextY = line.points.get(i + 1).y;
  
  canvas.drawLine(x, y, nextX, nextY, paint);
 }
 }

这样就可以在ImageView上随意涂鸦了,并且还可以通过删除lines中的最后条line来实现撤销功能。

以上这篇android中实现在ImageView上随意画线涂鸦的方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • Android编程实现带有单选按钮和复选按钮的dialog功能示例

    Android编程实现带有单选按钮和复选按钮的dialog功能示例

    这篇文章主要介绍了Android编程实现带有单选按钮和复选按钮的dialog功能,结合具体实例形式分析了Android实现带有单选按钮的dialog对话框及带有复选按钮的dialog对话框相关操作技巧,需要的朋友可以参考下
    2017-09-09
  • Android View的事件分发机制深入分析讲解

    Android View的事件分发机制深入分析讲解

    事件分发从手指触摸屏幕开始,即产生了触摸信息,被底层系统捕获后会传递给Android的输入系统服务IMS,通过Binder把消息发送到activity,activity会通过phoneWindow、DecorView最终发送给ViewGroup。这里就直接分析ViewGroup的事件分发
    2023-01-01
  • Android 8.0实现发送通知

    Android 8.0实现发送通知

    这篇文章主要为大家详细介绍了Android 8.0实现发送通知,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-07-07
  • 基于android示例程序(bitmapfun) 高效加载图片让人无语地方

    基于android示例程序(bitmapfun) 高效加载图片让人无语地方

    尝试了使用git上的一个开源项目afinal(bitmapfun的封装版)来加载图片,但是在测试的时候发现了一个问题,新的图片加载器(bitmapfun)比之前用的ImageDownloader要慢很多,特别是在网络状况不好的时候,那简直是太让人无语了
    2013-04-04
  • Android搭建本地Tomcat服务器及相关配置

    Android搭建本地Tomcat服务器及相关配置

    这篇文章主要介绍了Android搭建本地Tomcat服务器及相关配置,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-07-07
  • Android ViewPager加载图片效果

    Android ViewPager加载图片效果

    这篇文章主要为大家详细介绍了Android ViewPager加载图片效果的相关资料,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-01-01
  • Android的搜索框架实例详解

    Android的搜索框架实例详解

    这篇文章主要介绍了Android的搜索框架实例详解的相关资料,非常不错,具有参考借鉴价值,感兴趣的朋友一起看看吧
    2016-10-10
  • Android中应用前后台切换监听的实现详解

    Android中应用前后台切换监听的实现详解

    这篇文章主要给大家介绍了关于Android中应用前后台切换监听实现的相关资料,文中通过示例代码介绍的非常详细,对大家具有一定的参考学习价值,需要的朋友们下面跟着小编来一起学习学习吧。
    2017-07-07
  • Android自定义view制作抽奖转盘

    Android自定义view制作抽奖转盘

    这篇文章主要为大家详细介绍了Android自定义view制作抽奖转盘,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-12-12
  • Android studio实现简单的计算器

    Android studio实现简单的计算器

    这篇文章主要为大家详细介绍了Android studio实现简单的计算器,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-03-03

最新评论