`
1028826685
  • 浏览: 938413 次
  • 性别: Icon_minigender_1
  • 来自: 重庆
社区版块
存档分类

android实现手势缩放、移动图片

阅读更多
新建一个触摸监听器类

package com.liyong.btprinter;

import android.graphics.Matrix;
import android.graphics.PointF;
import android.util.FloatMath;
import android.view.MotionEvent;
import android.view.View;
import android.view.View.OnTouchListener;
import android.widget.ImageView;

public class MulitPointTouchListener implements OnTouchListener {

private static final String TAG = "Touch";
    // These matrices will be used to move and zoom image
    Matrix matrix = new Matrix();
    Matrix savedMatrix = new Matrix();

    // We can be in one of these 3 states
    static final int NONE = 0;
    static final int DRAG = 1;
    static final int ZOOM = 2;
    int mode = NONE;

    // Remember some things for zooming
    PointF start = new PointF();
    PointF mid = new PointF();
    float oldDist = 1f;

    @Override
    public boolean onTouch(View v, MotionEvent event) {

            ImageView view = (ImageView) v;
            // Log.e("view_width",
            // view.getImageMatrix()..toString()+"*"+v.getWidth());
            // Dump touch event to log
            dumpEvent(event);

            // Handle touch events here...
            switch (event.getAction() & MotionEvent.ACTION_MASK) {
            case MotionEvent.ACTION_DOWN:

                    matrix.set(view.getImageMatrix());
                    savedMatrix.set(matrix);
                    start.set(event.getX(), event.getY());
                    //Log.d(TAG, "mode=DRAG");
                    mode = DRAG;

                  
                    //Log.d(TAG, "mode=NONE");
                    break;
            case MotionEvent.ACTION_POINTER_DOWN:
                    oldDist = spacing(event);
                    //Log.d(TAG, "oldDist=" + oldDist);
                    if (oldDist > 10f) {
                            savedMatrix.set(matrix);
                            midPoint(mid, event);
                            mode = ZOOM;
                            //Log.d(TAG, "mode=ZOOM");
                    }
                    break;
            case MotionEvent.ACTION_UP:
            case MotionEvent.ACTION_POINTER_UP:
                    mode = NONE;
                    //Log.e("view.getWidth", view.getWidth() + "");
                    //Log.e("view.getHeight", view.getHeight() + "");

                    break;
            case MotionEvent.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);
                            //Log.d(TAG, "newDist=" + newDist);
                            if (newDist > 10f) {
                                    matrix.set(savedMatrix);
                                    float scale = newDist / oldDist;
                                    matrix.postScale(scale, scale, mid.x, mid.y);
                            }
                    }
                    break;
            }

            view.setImageMatrix(matrix);
            return true; // indicate event was handled
    }

    private void dumpEvent(MotionEvent event) {
            String names[] = { "DOWN", "UP", "MOVE", "CANCEL", "OUTSIDE",
                            "POINTER_DOWN", "POINTER_UP", "7?", "8?", "9?" };
            StringBuilder sb = new StringBuilder();
            int action = event.getAction();
            int actionCode = action & MotionEvent.ACTION_MASK;
            sb.append("event ACTION_").append(names[actionCode]);
            if (actionCode == MotionEvent.ACTION_POINTER_DOWN
                            || actionCode == MotionEvent.ACTION_POINTER_UP) {
                    sb.append("(pid ").append(
                                    action >> MotionEvent.ACTION_POINTER_ID_SHIFT);
                    sb.append(")");
            }
            sb.append("[");
            for (int i = 0; i < event.getPointerCount(); i++) {
                    sb.append("#").append(i);
                    sb.append("(pid ").append(event.getPointerId(i));
                    sb.append(")=").append((int) event.getX(i));
                    sb.append(",").append((int) event.getY(i));
                    if (i + 1 < event.getPointerCount())
                            sb.append(";");
            }
            sb.append("]");
            //Log.d(TAG, sb.toString());
    }

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


}

编写一个xml文件
<?xml version="1.0" encoding="UTF-8"?> 

    <LinearLayout
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="vertical"
    android:layout_height="fill_parent"
    android:layout_width="fill_parent"
    android:id="@+id/linearLayout1"
    android:weightSum="1"> 
       <ImageView android:layout_width="fill_parent"
       android:id="@+id/priviewimage"
       android:layout_height="fill_parent"
       android:layout_gravity="center"
       android:scaleType="matrix"
        >
      </ImageView> 
    </LinearLayout>
注意其中的: android:scaleType="matrix"
priviewimage.setImageBitmap(ActivityPreviewImage.click_bitmap);
priviewimage=(ImageView)findViewById(R.id.priviewimage);
priviewimage.setOnTouchListener(new MulitPointTouchListener());

分享到:
评论

相关推荐

    Android实现图片手势缩放、移动、双击放大缩小

    Android实现图片手势缩放、移动、双击放大缩小。

    android 图片手势缩放

    这个示例着重于实现Android图片的手势缩放功能,通过监听用户的触摸事件来调整图片的大小,提供流畅且直观的操作体验。 手势识别在Android中主要依赖于`GestureDetector`和`ScaleGestureDetector`这两个类。`...

    android手势处理图片平移、缩放和旋转

    "android手势处理图片平移、缩放和旋转"这个主题涉及到的主要知识点包括Android手势检测、ImageView的扩展以及图片操作。 首先,我们要了解Android的手势检测。Android系统提供了一套GestureDetector和...

    Android-一个Android图片缩放查看控件支持手势

    总之,这个Android图片缩放查看控件是通过自定义View、手势识别、矩阵变换、图片加载库和性能优化等技术实现的。它的核心在于提供了一种用户友好的方式来查看和交互图片,满足了Android应用中常见的图片查看需求。

    Android通过手势实现的缩放处理

    在Android开发中,手势识别是实现用户交互的关键技术之一,特别是在移动设备上,手势操作能够提供直观、便捷的用户体验。本篇文章将详细讲解如何在Android应用中通过手势识别实现缩放处理,主要聚焦于多点触摸...

    Android 图片随手势放大缩小功能

    在Android开发中,实现图片随手势放大缩小的功能是一项常见的需求,尤其在开发图像查看器或者照片浏览应用时。这个功能让用户体验更加流畅自然,能够自由地探索图片的细节。以下将详细讲解如何实现这一功能。 首先...

    html移动开发手势缩放(纯干货)(基于hammer velocity)

    本教程将详细介绍如何利用Hammer.js和Velocity.js这两个库来实现在HTML页面上的手势缩放功能,尤其适用于Android和iOS设备。 Hammer.js是一个轻量级的手势库,它提供了丰富的手势识别功能,如滑动、双击、捏合等,...

    android手势旋转,缩放,移动图片

    综上所述,实现"android手势旋转,缩放,移动图片"需要结合手势识别、图像矩阵变换以及无锯齿图片处理技术。通过自定义View,如`TouchImageView`,我们可以构建一个功能强大的图片操作组件,为用户提供流畅的交互...

    Android图片裁剪----移动、缩放图片进行裁剪

    本知识点将详细介绍如何在Android中实现图片的移动和缩放裁剪。 首先,我们需要了解Android中处理图片的基础知识。Android提供了多种库和API来处理图像,例如Bitmap类用于表示位图图像,Matrix类则用于处理图像的...

    android手势缩放和拖拽图片

    在Android开发中,实现手势缩放和拖拽图片的功能是一项常用且重要的技能,尤其是在创建自定义图片查看器或相册应用时。以下将详细介绍如何在Android应用中实现这些功能。 一、手势识别基础 Android提供了` ...

    android手势移动代码(动态图片跟随手势移动)

    本示例代码是针对"android手势移动代码(动态图片跟随手势移动)",主要用于实现动态图片跟随用户的触摸手势进行移动,这对于游戏开发或是任何需要图形对象移动的应用都极其有用。下面我们将详细讲解这一技术。 ...

    Android View 跟随手势移动和缩放

    "Android View 跟随手势移动和缩放"的主题聚焦于如何实现View在屏幕上跟随用户的触摸手势进行平移(translate)和缩放(zoom)操作。这种功能广泛应用于图片查看器、地图应用以及各种需要用户自定义布局的场景。 ...

    通过手势控制图片的缩放、移动、旋转

    2. **移动手势**:移动图片通常需要单指滑动屏幕。在iOS中,`UIPanGestureRecognizer`会跟踪手指的移动,我们可以通过改变图片的`center`属性来实现。Android的`GestureDetector`则在`onDown()`捕获触摸开始,在`...

    SurfaceView实现图片缩放,移动加标记

    本项目通过`SurfaceView`实现图片的缩放、移动以及添加标记功能,这在许多应用场景中都非常实用,比如地图应用或者图像编辑工具。同时,项目还包含了发送电子邮件并附带多个附件的功能,这在日常的移动应用中也是...

    Android 双指拖动和双指缩放图片

    在Android开发中,实现双指拖动和双指缩放图片是常见的手势识别应用场景,尤其在图片查看器或画板类应用中极为常见。本文将深入探讨如何在Android平台上实现这一功能,以及如何将绘制的线条与背景图片进行正片叠底的...

    Android实现通过手势控制图片大小缩放的方法

    在Android开发中,实现通过手势控制图片大小缩放的功能,主要涉及到手势识别和图像处理两个核心技术。以下将详细讲解这两个方面以及如何结合它们来实现上述功能。 首先,我们需要理解Android中处理手势触摸事件的...

    android多点触控缩放移动旋转等手势

    在Android平台上,多点触控手势是开发交互式应用程序的关键技术,它允许用户通过两个或更多的手指进行操作,如缩放、移动和旋转等。这些功能极大地提升了用户体验,尤其是在图像查看器、地图应用和游戏等领域。本文...

    Android实现图片左右滚动,点击对应放大且可以缩放

    Android代码,自定义HorizontalScrollView,实现图片左右滑动切换,点击对应图片,加载对应图片,且双击和手指实现缩放功能,单击一下退出,结合了几个例子,写的一个比较完整一点的Demo,希望对需要此功能的人有所...

    android 手势控制 图片缩放

    为了实现手势缩放,我们需要改变ImageView内部的Matrix对象。Matrix可以理解为一个2D变换矩阵,可以进行平移、旋转、缩放等操作。当ScaleGestureDetector检测到缩放手势时,我们可以更新Matrix的ScaleX和ScaleY值,...

    Android使用Matrix实现图片缩放,移动

    这种技术常用于图片查看器应用、地图应用等,允许用户自由缩放和移动图片以查看细节。在实现时,还需要考虑图片的边界限制,防止图片移出视图范围。 总之,通过熟练运用Android的Matrix类和多点触控事件处理,我们...

Global site tag (gtag.js) - Google Analytics