Android实现对imageview的拖动以及缩放
2012-02-02 12:11
597 查看
package org.wch.gesture; import android.graphics.Matrix; import android.graphics.PointF; import android.util.FloatMath; import android.util.Log; import android.view.MotionEvent; import android.view.View; import android.view.View.OnTouchListener; import android.widget.ImageView; import android.widget.ImageView.ScaleType; public class MulitPointTouchListener implements OnTouchListener { Matrix matrix = new Matrix(); Matrix savedMatrix = new Matrix(); public ImageView image; static final int NONE = 0; static final int DRAG = 1; static final int ZOOM = 2; int mode = NONE; PointF start = new PointF(); PointF mid = new PointF(); float oldDist = 1f; public MulitPointTouchListener(ImageView image) { super(); this.image = image; } @Override public boolean onTouch(View v, MotionEvent event) { this.image.setScaleType(ScaleType.MATRIX); ImageView view = (ImageView) v; // dumpEvent(event); switch (event.getAction() & MotionEvent.ACTION_MASK) { case MotionEvent.ACTION_DOWN: Log.w("FLAG", "ACTION_DOWN"); matrix.set(view.getImageMatrix()); savedMatrix.set(matrix); start.set(event.getX(), event.getY()); mode = DRAG; break; case MotionEvent.ACTION_POINTER_DOWN: Log.w("FLAG", "ACTION_POINTER_DOWN"); oldDist = spacing(event); if (oldDist > 10f) { savedMatrix.set(matrix); midPoint(mid, event); mode = ZOOM; } break; case MotionEvent.ACTION_UP: Log.w("FLAG", "ACTION_UP"); case MotionEvent.ACTION_POINTER_UP: Log.w("FLAG", "ACTION_POINTER_UP"); mode = NONE; break; case MotionEvent.ACTION_MOVE: Log.w("FLAG", "ACTION_MOVE"); if (mode == DRAG) { matrix.set(savedMatrix); matrix.postTranslate(event.getX() - start.x, event.getY() - start.y); } else if (mode == ZOOM) { float newDist = spacing(event); if (newDist > 10f) { matrix.set(savedMatrix); float scale = newDist / oldDist; matrix.postScale(scale, scale, mid.x, mid.y); } } break; } view.setImageMatrix(matrix); return true; } private float spacing(MotionEvent event) { float x = event.getX(0) - event.getX(1); float y = event.getY(0) - event.getY(1); return FloatMath.sqrt(x * x + y * y); } private void midPoint(PointF point, MotionEvent event) { float x = event.getX(0) + event.getX(1); float y = event.getY(0) + event.getY(1); point.set(x / 2, y / 2); } }
相关文章推荐
- Android实现对imageview的拖动以及缩放
- Android实现对imageview的拖动以及缩放
- Android通过自定义ImageView控件实现图片的缩放和拖动的实现代码
- Android开发之ImageView通过matrix实现两点缩放和图片拖动
- Android实现ImageView图片缩放和拖动
- 【Android】自定义ImageView实现图片的平移、缩放、旋转(手势操作)
- Android深入浅出系列之实例应用—简单的手指拖动图片,图片滑来滑去显示应用Gallery和BaseAdapter以及ImageView的使用
- android 自定义ImageView实现图片手势滑动、多点触摸缩放
- Android学习备忘020——android自定义ImageView实现缩放,回弹效果
- Android ImageView手势缩放完整的实现
- Android开发之-- SubsamplingScaleImageView加载长图并实现手势放大缩放
- 自定义ImageView实现拖动、旋转、缩放功能
- 自定义ImageView实现图片的拖动、缩放和边界回弹
- Android中用Matrix实现ImageView里的图片平移和缩放动画
- (干货) Android实现ImageVIew多点触控及双击缩放
- Android:自定义ImageView实现缩放,回弹效果
- Android自定义View来实现解析lrc歌词并同步滚动、上下拖动、缩放歌词的功能[转]
- Android深入浅出系列之实例应用—简单的手指拖动图片,图片滑来滑去显示应用Gallery和BaseAdapter以及ImageView的使用
- android学习记录(二)-----imageView实现图片的旋转和缩放
- android 自定义ImageView实现图片缩放边界回弹和缩小回弹