[转载]Android通过手势(多点)缩放和拖拽图片

转载 2012年03月26日 01:20:17

原文地址:Android通过手势(多点)缩放和拖拽图片    作者:望夜

在MotionEvent中有两个事件值得注意一下,分别是ACTION_DOWN和ACTION_POINTER_DOWN。

       ACTION_DOWN:这个很好理解,当屏幕检测到有手指按下之后就触发到这个事件。
       ACTION_POINTER_DOWN:这个是实现多点的关键,当屏幕检测到有多个手指同时按下之后,就触发了这个事件。
通过getAction()可以获得当前屏幕的事件类型:ACTION_DOWN, ACTION_MOVE, ACTION_UP, orACTION_CANCEL。但是如果像获得如上的ACTION_POINTER_DOWN,则得和ACTION_MASK相与才能得到ACTION_POINTER_DOWN事件。

       所以我们运用一个switch-case结构就可以实现对图片进行拖拽或缩放,而缩放的只要思想是在移动的过程中计算两个点之间的距离,然后再进行缩放。

      上代码:
  1.       @Override
  2.        publicboolean onTouch(View v, MotionEvent event) {
  3.              ImageViewview = (ImageView) v;
  4.             dumpEvent(event);
  5.              // Handletouch events here...
  6.              switch(event.getAction() & MotionEvent.ACTION_MASK){
  7.              caseMotionEvent.ACTION_DOWN:
  8.                  matrix.set(view.getImageMatrix());
  9.                  savedMatrix.set(matrix);
  10.                  start.set(event.getX(), event.getY());
  11.                   //Log.d(TAG,"mode=DRAG");
  12.                   mode =DRAG;
  13.                   //Log.d(TAG,"mode=NONE");
  14.                  break;
  15.              caseMotionEvent.ACTION_POINTER_DOWN:
  16.                   oldDist =spacing(event);
  17.                   //Log.d(TAG,"oldDist=" + oldDist);
  18.                   if (oldDist> 10f) {
  19.                        savedMatrix.set(matrix);
  20.                        midPoint(mid,event);
  21.                        mode =ZOOM;
  22.                        //Log.d(TAG,"mode=ZOOM");
  23.                   }//ACTION_DOWN, ACTION_MOVE, ACTION_UP, or ACTION_CANCEL.
  24.                  break;
  25.              caseMotionEvent.ACTION_UP:
  26.              caseMotionEvent.ACTION_POINTER_UP:
  27.                   mode =NONE;
  28.                  break;
  29.              caseMotionEvent.ACTION_MOVE:
  30.                   if (mode ==DRAG) {
  31.                        //...
  32.                        matrix.set(savedMatrix);
  33.                        matrix.postTranslate(event.getX()- start.x, event.getY()
  34.                                   -start.y);
  35.                   } else if(mode == ZOOM) {
  36.                        float newDist= spacing(event);
  37.                        //Log.d(TAG,"newDist=" + newDist);
  38.                        if (newDist> 10f) {
  39.                             matrix.set(savedMatrix);
  40.                              float scale= newDist / oldDist;
  41.                             matrix.postScale(scale, scale, mid.x, mid.y);
  42.                        }
  43.                   }
  44.                  break;
  45.             }

  46.             view.setImageMatrix(matrix);
  47.              returntrue; // indicate event was handled
  48.        }

  49.        private voiddumpEvent(MotionEvent event) {
  50.              Stringnames[] = { "DOWN", "UP", "MOVE", "CANCEL", "OUTSIDE",
  51.                        "POINTER_DOWN","POINTER_UP", "7?", "8?", "9?" };
  52.             StringBuilder sb = new StringBuilder();
  53.              int action= event.getAction();
  54.              intactionCode = action &MotionEvent.ACTION_MASK;
  55.             sb.append("event ACTION_").append(names[actionCode]);
  56.              if(actionCode == MotionEvent.ACTION_POINTER_DOWN
  57.                        || actionCode== MotionEvent.ACTION_POINTER_UP) {
  58.                  sb.append("(pid ").append(
  59.                              action>>MotionEvent.ACTION_POINTER_ID_SHIFT);
  60.                  sb.append(")");
  61.             }
  62.             sb.append("[");
  63.              for (int i= 0; i < event.getPointerCount(); i++) {
  64.                  sb.append("#").append(i);
  65.                  sb.append("(pid").append(event.getPointerId(i));
  66.                  sb.append(")=").append((int)event.getX(i));
  67.                  sb.append(",").append((int)event.getY(i));
  68.                   if (i + 1< event.getPointerCount())
  69.                        sb.append(";");
  70.             }
  71.             sb.append("]");
  72.             //Log.d(TAG, sb.toString());
  73.        }
复制代码
求两点间距离:
  1. private float spacing(MotionEvent event) {
  2.              float x =event.getX(0) - event.getX(1);
  3.              float y =event.getY(0) - event.getY(1);
  4.              returnFloatMath.sqrt(x * x + y * y);
  5.        }
复制代码

求两点间中点:
  1.        private voidmidPoint(PointF point, MotionEvent event) {
  2.              float x =event.getX(0) + event.getX(1);

相关文章推荐

Android通过手势(多点)缩放和拖拽图片

在MotionEvent中有两个事件值得注意一下,分别是ACTION_DOWN和ACTION_POINTER_DOWN。 ACTION_DOWN:这个很好理解,当屏幕检测到有手指按下之后就触发到这个...

Android通过手势(多点)缩放和拖拽图片

在MotionEvent中有两个事件值得注意一下,分别是ACTION_DOWN和ACTION_POINTER_DOWN。 ACTION_DOWN:这个很好理解,当屏幕检测到有手指按下之后就触发到这个...

android项目 之 记事本(14) ----- 手势缩放与拖拽图片

本文是自己学习所做笔记,欢迎转载,但请注明出处:http://blog.csdn.net/jesson20121020 想必大家都用过系统的图库,浏览图片时,可以通过手势放大或缩小图片,旋转图片,拖拽...

android手势缩放和拖拽图片

  • 2015年04月22日 17:16
  • 4.41MB
  • 下载

android 自定义ImageView实现图片手势滑动、多点触摸缩放

这两天研究了一下多点触控缩放,也参考了网上几个例子,但觉得不够完美。 先推荐大家看一篇很详细的介绍:http://blog.csdn.net/jj120522/article/details/846...

Android多点触控缩放拖拽实例

在Android上查看图片或者浏览网页时,我们往往有把图片或者网页放大或者缩小的的需求,这样就能够获得更多的细节信息 或者获得更多的全貌信息,多点触摸与绽放功能正是满足这种应用场景的技术。...
  • cqtddt
  • cqtddt
  • 2014年12月28日 16:49
  • 1066

图片随手势缩放平移,多点触控

  • 2017年08月30日 16:46
  • 519KB
  • 下载

Android官方开发文档Training系列课程中文版:手势处理之拖拽或缩放

原文地址:http://android.xsoftlab.net/training/gestures/scale.html 这节课主要学习如何使用触摸手势来拖动或者放大屏幕上的对象,以及使用onTo...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:[转载]Android通过手势(多点)缩放和拖拽图片
举报原因:
原因补充:

(最多只允许输入30个字)