Android实现对imageview的拖动以及缩放

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);  
	}  
} 

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值