图片缩放,拖拽等操作

之前做项目要对图片的查看,然后就自己写了一个,适合对图片的浏览,跟系统图库的效果一样哦,先贴一张美女图片,听说有美女,男人就会多看一眼,不知道是不是真的,哈哈

布局文件需要注意的一点是 scaleType一定要是 matrix,这样才能对图片进行一系列的矩阵操作,例如放大缩小,拖拽,等等

[html] view plaincopy

  1. <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"  
  2.     xmlns:tools="http://schemas.android.com/tools"  
  3.     android:layout_width="fill_parent"  
  4.     android:layout_height="fill_parent" >  
  5.   
  6.     <ImageView  
  7.         android:id="@+id/imageView1"  
  8.         android:layout_width="fill_parent"  
  9.         android:layout_height="fill_parent"  
  10.         android:scaleType="matrix" />  
  11.   
  12. </RelativeLayout>  

代码我都有注释,直接上代码咯

[java] view plaincopy

  1. package com.example.zoomanddrafting;  
  2.   
  3. import android.app.Activity;  
  4. import android.content.Context;  
  5. import android.content.Intent;  
  6. import android.graphics.Bitmap;  
  7. import android.graphics.BitmapFactory;  
  8. import android.graphics.Matrix;  
  9. import android.graphics.PointF;  
  10. import android.graphics.RectF;  
  11. import android.os.Bundle;  
  12. import android.util.DisplayMetrics;  
  13. import android.util.FloatMath;  
  14. import android.view.MotionEvent;  
  15. import android.view.View;  
  16. import android.view.View.OnTouchListener;  
  17. import android.widget.ImageView;  
  18.   
  19.   
  20.   
  21. public class PhotoViewer extends Activity implements OnTouchListener {  
  22.   
  23.     private static final String TAG = "PhotoViewer";  
  24.     public static final int RESULT_CODE_NOFOUND = 200;  
  25.       
  26.       
  27.     Matrix matrix = new Matrix();  
  28.     Matrix savedMatrix = new Matrix();  
  29.     DisplayMetrics dm;  
  30.     ImageView imgView;  
  31.     Bitmap bitmap;  
  32.   
  33.     /** 最小缩放比例*/  
  34.     float minScaleR = 1.0f;  
  35.     /** 最大缩放比例*/  
  36.     static final float MAX_SCALE = 10f;  
  37.   
  38.     /** 初始状态*/  
  39.     static final int NONE = 0;  
  40.     /** 拖动*/  
  41.     static final int DRAG = 1;  
  42.     /** 缩放*/  
  43.     static final int ZOOM = 2;  
  44.       
  45.     /** 当前模式*/  
  46.     int mode = NONE;  
  47.   
  48.     PointF prev = new PointF();  
  49.     PointF mid = new PointF();  
  50.     float dist = 1f;  
  51.   
  52.       
  53.     @Override  
  54.     public void onCreate(Bundle savedInstanceState) {  
  55.         super.onCreate(savedInstanceState);  
  56.         // 获取图片资源  
  57.         bitmap = BitmapFactory.decodeResource(getResources(), R.drawable.item);  
  58.           
  59.         setContentView(R.layout.activity_main);  
  60.         imgView = (ImageView) findViewById(R.id.imageView1);// 获取控件  
  61.         imgView.setImageBitmap(bitmap);// 填充控件  
  62.         imgView.setOnTouchListener(this);// 设置触屏监听  
  63.         dm = new DisplayMetrics();  
  64.         getWindowManager().getDefaultDisplay().getMetrics(dm);// 获取分辨率  
  65. //        minZoom();  
  66.         center();  
  67.         imgView.setImageMatrix(matrix);  
  68.           
  69.     }  
  70.   
  71.     public void SureOnClick(View v)  
  72.     {  
  73.           
  74.     }  
  75.       
  76.     /** 
  77.      * 触屏监听 
  78.      */  
  79.     public boolean onTouch(View v, MotionEvent event) {  
  80.   
  81.         switch (event.getAction() & MotionEvent.ACTION_MASK) {  
  82.         // 主点按下  
  83.         case MotionEvent.ACTION_DOWN:  
  84.             savedMatrix.set(matrix);  
  85.             prev.set(event.getX(), event.getY());  
  86.             mode = DRAG;  
  87.             break;  
  88.         // 副点按下  
  89.         case MotionEvent.ACTION_POINTER_DOWN:  
  90.             dist = spacing(event);  
  91.             // 如果连续两点距离大于10,则判定为多点模式  
  92.             if (spacing(event) > 10f) {  
  93.                 savedMatrix.set(matrix);  
  94.                 midPoint(mid, event);  
  95.                 mode = ZOOM;  
  96.             }  
  97.             break;  
  98.         case MotionEvent.ACTION_UP:  
  99.         case MotionEvent.ACTION_POINTER_UP:  
  100.             mode = NONE;  
  101.             //savedMatrix.set(matrix);  
  102.             break;  
  103.         case MotionEvent.ACTION_MOVE:  
  104.             if (mode == DRAG) {  
  105.                 matrix.set(savedMatrix);  
  106.                 matrix.postTranslate(event.getX() - prev.x, event.getY()  
  107.                         - prev.y);  
  108.             } else if (mode == ZOOM) {  
  109.                 float newDist = spacing(event);  
  110.                 if (newDist > 10f) {  
  111.                     matrix.set(savedMatrix);  
  112.                     float tScale = newDist / dist;  
  113.                     matrix.postScale(tScale, tScale, mid.x, mid.y);  
  114.                 }  
  115.             }  
  116.             break;  
  117.         }  
  118.         imgView.setImageMatrix(matrix);  
  119.         CheckView();  
  120.         return true;  
  121.     }  
  122.   
  123.     /** 
  124.      * 限制最大最小缩放比例,自动居中 
  125.      */  
  126.     private void CheckView() {  
  127.         float p[] = new float[9];  
  128.         matrix.getValues(p);  
  129.         if (mode == ZOOM) {  
  130.             if (p[0] < minScaleR) {  
  131.                 //Log.d("", "当前缩放级别:"+p[0]+",最小缩放级别:"+minScaleR);  
  132.                 matrix.setScale(minScaleR, minScaleR);  
  133.             }  
  134.             if (p[0] > MAX_SCALE) {  
  135.                 //Log.d("", "当前缩放级别:"+p[0]+",最大缩放级别:"+MAX_SCALE);  
  136.                 matrix.set(savedMatrix);  
  137.             }  
  138.         }  
  139.         center();  
  140.     }  
  141.   
  142.     /** 
  143.      * 最小缩放比例,最大为100% 
  144.      */  
  145.     private void minZoom() {  
  146.         minScaleR = Math.min(  
  147.                 (float) dm.widthPixels / (float) bitmap.getWidth(),  
  148.                 (float) dm.heightPixels / (float) bitmap.getHeight());  
  149.         if (minScaleR < 1.0) {  
  150.             matrix.postScale(minScaleR, minScaleR);  
  151.         }  
  152.     }  
  153.   
  154.     private void center() {  
  155.         center(true, true);  
  156.     }  
  157.   
  158.     /** 
  159.      * 横向、纵向居中 
  160.      */  
  161.     protected void center(boolean horizontal, boolean vertical) {  
  162.   
  163.         Matrix m = new Matrix();  
  164.         m.set(matrix);  
  165.         RectF rect = new RectF(0, 0, bitmap.getWidth(), bitmap.getHeight());  
  166.         m.mapRect(rect);  
  167.   
  168.         float height = rect.height();  
  169.         float width = rect.width();  
  170.   
  171.         float deltaX = 0, deltaY = 0;  
  172.   
  173.         if (vertical) {  
  174.             // 图片小于屏幕大小,则居中显示。大于屏幕,上方留空则往上移,下方留空则往下移  
  175.             int screenHeight = dm.heightPixels;  
  176.             if (height < screenHeight) {  
  177.                 deltaY = (screenHeight - height) / 2 - rect.top;  
  178.             } else if (rect.top > 0) {  
  179.                 deltaY = -rect.top;  
  180.             } else if (rect.bottom < screenHeight) {  
  181.                 deltaY = imgView.getHeight() - rect.bottom;  
  182.             }  
  183.         }  
  184.   
  185.         if (horizontal) {  
  186.             int screenWidth = dm.widthPixels;  
  187.             if (width < screenWidth) {  
  188.                 deltaX = (screenWidth - width) / 2 - rect.left;  
  189.             } else if (rect.left > 0) {  
  190.                 deltaX = -rect.left;  
  191.             } else if (rect.right < screenWidth) {  
  192.                 deltaX = screenWidth - rect.right;  
  193.             }  
  194.         }  
  195.         matrix.postTranslate(deltaX, deltaY);  
  196.     }  
  197.   
  198.     /** 
  199.      * 两点的距离 
  200.      */  
  201.     private float spacing(MotionEvent event) {  
  202.         float x = event.getX(0) - event.getX(1);  
  203.         float y = event.getY(0) - event.getY(1);  
  204.         return FloatMath.sqrt(x * x + y * y);  
  205.     }  
  206.   
  207.     /** 
  208.      * 两点的中点 
  209.      */  
  210.     private void midPoint(PointF point, MotionEvent event) {  
  211.         float x = event.getX(0) + event.getX(1);  
  212.         float y = event.getY(0) + event.getY(1);  
  213.         point.set(x / 2, y / 2);  
  214.     }  
  215.       
  216.     
  217. }  

我也将工程上传了,不要积分哦,欢迎下载代码下载

时间: 2024-12-30 23:41:09

图片缩放,拖拽等操作的相关文章

jQuery自定义图片缩放拖拽插件imageQ实现方法(附demo源码下载)_jquery

本文实例讲述了jQuery自定义图片缩放拖拽插件imageQ实现方法.分享给大家供大家参考,具体如下: 综合网上一些代码 自己写的一个图片缩放拖拽的小插件 /** * * <a href="http://lib.csdn.net/base/22" class='replace_word' title="jQuery知识库" target='_blank' style='color:#df3434; font-weight:bold;'>jQuery<

插件 放大 拖拽 旋转-求一个图片放大拖拽,旋转功能的插件!

问题描述 求一个图片放大拖拽,旋转功能的插件! 可以实现: 1,图片放大 2,可以将放大的图片拖拽 3,点击按钮左旋转和右旋转可以实现旋转操作 解决方案 bootstrap里面应该有相应的插件.

Flex4图片在指定区域内自由拖拽移动,缩放图片大小例子

如果图片过大,一般我们展示的时候要允许用户通过鼠标滚轮进行缩放,同时点击可以拖拽移动(类似百度地图那样的操作).下面通过一个样例进行演示:    效果图如下:     <?xml version="1.0" encoding="utf-8">      代码如下所示?xml>   <?xml version="1.0" encoding="utf-8"?> <s:Application xm

JS实现放大、缩小及拖拽图片的方法【可兼容IE、火狐】_javascript技巧

本文实例讲述了JS实现放大.缩小及拖拽图片的方法.分享给大家供大家参考,具体如下: var divId; var v_left; var v_top; window.onload=function(){ divId = document.getElementById("block1"); var height1 = images1.height;//图片的高度 var width1 = images1.width;//图片的宽度 v_left=(document.body.client

Android实现让图片在屏幕上任意移动的方法(拖拽功能)_Android

本文实例讲述了Android实现让图片在屏幕上任意移动的方法.分享给大家供大家参考,具体如下: public class DragExampleActivity extends Activity { Bitmap mBitmap; /** Called when the activity is first created. */ @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInst

jquery插件jquery.nicescroll实现图片无滚动条左右拖拽的方法_jquery

本文实例讲述了jquery插件jquery.nicescroll实现图片无滚动条左右拖拽的方法.分享给大家供大家参考.具体如下: 这里介绍jQuery图片左右拖拽特效,无滚动条,将多张图片组合在一起形成的效果,插件使用的是jquery.nicescroll.js,拖动过程中不会出现滚动条,这样更美观了一些,若需要此效果,可参见下边框中的代码. 运行效果截图如下: 具体代码如下: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitiona

JavaScript实现文字与图片拖拽效果的方法_javascript技巧

本文实例讲述了JavaScript实现文字与图片拖拽效果的方法.分享给大家供大家参考.具体实现方法如下: 复制代码 代码如下: <html> <head> <title>JavaScript实现文字与图片的拖拽效果</title> <style type="text/css"> *{padding:0;margin:0;} .tips{position:absolute;background:#eee;} </style

js实现使用鼠标拖拽切换图片的方法_javascript技巧

本文实例讲述了js实现使用鼠标拖拽切换图片的方法.分享给大家供大家参考.具体实现方法如下: <script type="text/javascript" src="js/jquery.min.js"></script> <style type="text/css"> *{margin:0;padding:0;} .m-slider{width:600px;margin:0 auto 10px !importan

Android中实现HorizontalScrollView内子控件横向拖拽

前言 网上ListView上下拖动的例子有,效果也很好,但是项目要横着拖的,只要硬着头皮自己写(主要是没找到合适的),参考文章1修改而来,分享一下. 截图 代码 java public class HoDragActivity extends Activity { private LinearLayout main; private GestureDetector mGestureDetector; @Override public void onCreate(Bundle savedInsta