zoukankan      html  css  js  c++  java
  • Android拖动和缩放图片

    Android拖动和缩放图片

    2014年5月9日 

    我们在使用应用其中常常须要浏览图片。比方在微信其中。点击图片之后能够对图片进行缩放。

    本博客介绍怎样对图片进行拖拽和缩放。这首先要了解Android中的触摸机制了,在屏幕中有手指按下、手指抬起、手指移动还有多个手指触摸的动作。

    我们要实现对图片的拖拽和缩放就是要基于这些动作来进行逻辑处理。

    图片的拖拽主要是计算手指開始的位置与当前手指的位置关系,来进行平移的,详细能够看代码。

    图片的缩放就涉及到计算两点之间的距离来得到缩放比,调用矩阵方法来达到缩放的效果。

    演示样例代码:http://download.csdn.net/detail/wwj_748/7324363




    package com.wwj.dragscale;
    
    import android.app.Activity;
    import android.graphics.Matrix;
    import android.graphics.PointF;
    import android.os.Bundle;
    import android.util.FloatMath;
    import android.view.MotionEvent;
    import android.view.View;
    import android.view.View.OnTouchListener;
    import android.widget.ImageView;
    
    /**
     * 对图片进行拖拽和缩放
     * 
     * @author wwj
     * 
     */
    public class MainActivity extends Activity {
    	private ImageView imageView;
    
    	@Override
    	protected void onCreate(Bundle savedInstanceState) {
    		super.onCreate(savedInstanceState);
    		setContentView(R.layout.activity_main);
    		imageView = (ImageView) findViewById(R.id.imageView);
    		imageView.setOnTouchListener(new TouchListener());
    	}
    
    	private class TouchListener implements OnTouchListener {
    
    		private PointF startPoint = new PointF();
    		private Matrix matrix = new Matrix();
    		private Matrix currentMaritx = new Matrix();
    
    		private int mode = 0; // 用于标记模式
    		private static final int DRAG = 1; // 拖动
    		private static final int ZOOM = 2; // 放大
    		private float startDis = 0;
    		private PointF midPoint; // 中心点
    
    		@Override
    		public boolean onTouch(View v, MotionEvent event) {
    			switch (event.getAction() & MotionEvent.ACTION_MASK) {
    			case MotionEvent.ACTION_DOWN:
    				mode = DRAG; // 拖拽
    				currentMaritx.set(imageView.getImageMatrix()); // 记录ImageView当前移动位置
    				startPoint.set(event.getX(), event.getY()); // 開始点
    				break;
    			case MotionEvent.ACTION_MOVE:// 移动事件
    				if (mode == DRAG) { // 图片拖动事件
    					float dx = event.getX() - startPoint.x; // x轴移动距离
    					float dy = event.getY() - startPoint.y;
    					matrix.set(currentMaritx); // 在当前的位置基础上移动
    					matrix.postTranslate(dx, dy);
    				} else if (mode == ZOOM) { // 图片放大事件
    					float endDis = distance(event); // 结束距离
    					if (endDis > 10f) {
    						float scale = endDis / startDis; // 放大倍数
    						matrix.set(currentMaritx);
    						matrix.postScale(scale, scale, midPoint.x, midPoint.y);
    					}
    
    				}
    				break;
    			case MotionEvent.ACTION_UP:
    				mode = 0;
    				break;
    			// 有手指离开屏幕,但屏幕还有触点(手指)
    			case MotionEvent.ACTION_POINTER_UP:
    				mode = 0;
    				break;
    			// 当屏幕上已经有触点(手指),再有一个手指压下屏幕
    			case MotionEvent.ACTION_POINTER_DOWN:
    				mode = ZOOM;
    				startDis = distance(event);
    				if (startDis > 10f) { // 避免手指上有两个
    					midPoint = mid(event);
    					currentMaritx.set(imageView.getImageMatrix()); // 记录当前的缩放倍数
    				}
    				break;
    			}
    			// 显示缩放后的图片
    			imageView.setImageMatrix(matrix);
    			return true;
    		}
    
    	}
    
    	/**
    	 * 计算两点之间的距离
    	 * 
    	 * @param event
    	 * @return
    	 */
    	public static float distance(MotionEvent event) {
    		float dx = event.getX(1) - event.getX(0);
    		float dy = event.getY(1) - event.getY(0);
    		return FloatMath.sqrt(dx * dx + dy * dy);
    	}
    
    	/**
    	 * 计算两点之间的中间点
    	 * 
    	 * @param event
    	 * @return
    	 */
    	public static PointF mid(MotionEvent event) {
    		float midX = (event.getX(1) + event.getX(0)) / 2;
    		float midY = (event.getY(1) + event.getY(0)) / 2;
    		return new PointF(midX, midY);
    	}
    
    }
    




    版权声明:本文博客原创文章,博客,未经同意,不得转载。

  • 相关阅读:
    [转] CSocket 和CAsyncSocket类介绍
    error C2275: 'SOCKET' : illegal use of this type as an expression
    tagVARIANT、VARIANT、_variant_t和COleVariant
    使用MFC WinInet进行FTP中文件的简单上传和下载功能
    【转】VS2008快速将代码中字符串改为_T(“”)风格的方法
    【转】Internet与Intranet区别
    POSIX是什么?
    Ocx控件注册不成功?可能是tlb文件导致~
    十三种基于直方图的图像全局二值化算法原理、实现、代码及效果(转)
    图像匹配之欧式距离算法(转)
  • 原文地址:https://www.cnblogs.com/lcchuguo/p/4620856.html
Copyright © 2011-2022 走看看