android的ScaleGestureDetector缩放类详解

文章由多出组合,它们来自:

http://elvajxw.iteye.com/blog/1308452

http://www.cnblogs.com/lknlfy/archive/2012/03/11/2390274.html

类概述

       根据接收的 MotionEvent,  侦测由多个触点(多点触控)引发的变形手势。callback 方法
ScaleGestureDetector.OnScaleGestureListener  会在特定手势事件发生时通知用户
该类仅能和Touch事件引发的 MotionEvent 配合使用。使用该类需要为你的 View 创建
ScaleGestureDetector  实例确保在
onTouchEvent(MotionEvent)方法中调用  onTouchEvent  (MotionEvent). 
 在事件发生时,定义在 callback 中的方法会被调用。

(ScaleGestureDetector 为 Android2.2 新增的类,允许 Views 可以通过提供的MotionEvents 检测和处理包括多点触摸在内的手势变化信息。)

内部类

       interface  ScaleGestureDetector.OnScaleGestureListener
       手势发生时接收通知的监听器

class ScaleGestureDetector.SimpleOnScaleGestureListener      
       一个方便使用的类。 若仅想监听一部分尺寸伸缩事件,可继承该类。

  公共构造方法

public ScaleGestureDetector(Context context, ScaleGestureDetector.OnScaleGestureListener listener)

构造函数
       公共方法

public float getCurrentSpan ()

       返回手势过程中,组成该手势的两个触点的当前距离。
       返回值
       以像素为单位的触点距离。

  public long getEventTime ()

返回事件被捕捉时的时间。
       返回值
       以毫秒为单位的事件时间。

public float getFocusX ()

返回当前手势焦点的 X 坐标。 如果手势正在进行中,焦点位于组成手势的两个触点之间。 如果手势正在结束,焦点为仍留在屏幕上的触点的位置。若 isInProgress()返回 false,该方法的返回值未定义。
       返回值
       返回焦点的 X 坐标值,以像素为单位。

public float getFocusY ()

       返回当前手势焦点的 Y 坐标。 如果手势正在进行中,焦点位于组成手势的两个触点之间。 如果手势正在结束,焦点为仍留在屏幕上的触点的位置。若 isInProgress()返回 false,该方法的返回值未定义。
       返回值
       返回焦点的 Y 坐标值,以像素为单位。

  public float getPreviousSpan ()

返回手势过程中,组成该手势的两个触点的前一次距离。
       返回值
       两点的前一次距离,以像素为单位。

public float getScaleFactor ()

返回从前一个伸缩事件至当前伸缩事件的伸缩比率。该值定义为  (getCurrentSpan()  / getPreviousSpan())。
       返回值
       当前伸缩比率.

public long getTimeDelta ()

返回前一次接收到的伸缩事件距当前伸缩事件的时间差,以毫秒为单位。
       返回值
       从前一次伸缩事件起始的时间差,以毫秒为单位。

public boolean isInProgress ()

如果手势处于进行过程中,返回 true.
       返回值
       如果手势处于进行过程中,返回 true。否则返回 false。

简单示例:

新建工程MyScale,修改main.xml文件,在里面添加一个Button和一个SurfaceView,如下:

<?xml version="1.0" encoding="utf-8"?>
 <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
     android:layout_width="fill_parent"
     android:layout_height="fill_parent"
     android:orientation="vertical" >
 
     <Button
         android:id="@+id/button"
         android:layout_width="fill_parent"
         android:layout_height="wrap_content"
         android:text="显示图片"
         />
    
     <SurfaceView
         android:id="@+id/surfaceview"
         android:layout_width="fill_parent"
         android:layout_height="fill_parent"
         />
 
 </LinearLayout>

修改MyScaleActivity.java文件,主要是实现按钮的监听和定义一个类实现ScaleGestureDetector.OnScaleGestureListener接口:

package com.nan.scale;
 
 import android.app.Activity;
 import android.graphics.Bitmap;
 import android.graphics.BitmapFactory;
 import android.graphics.Canvas;
 import android.graphics.Color;
 import android.graphics.Matrix;
 import android.graphics.Rect;
 import android.os.Bundle;
 import android.view.MotionEvent;
 import android.view.ScaleGestureDetector;
 import android.view.SurfaceHolder;
 import android.view.SurfaceView;
 import android.view.View;
 import android.widget.Button;
 
 
 
 public class MyScaleActivity extends Activity
 {
     private Button mButton = null;
     private SurfaceView mSurfaceView = null;
     private SurfaceHolder mSurfaceHolder = null;
     private ScaleGestureDetector mScaleGestureDetector = null;
     private Bitmap mBitmap = null;   
    
     /** Called when the activity is first created. */
     @Override
     public void onCreate(Bundle savedInstanceState)
     {
         super.onCreate(savedInstanceState);
         setContentView(R.layout.main);
        
         mSurfaceView = (SurfaceView)this.findViewById(R.id.surfaceview);
         mSurfaceHolder = mSurfaceView.getHolder(); 
         mScaleGestureDetector = new ScaleGestureDetector(this,new ScaleGestureListener());
         mButton = (Button)this.findViewById(R.id.button);
         //按钮监听
         mButton.setOnClickListener(new View.OnClickListener()
         {
            
             @Override
             public void onClick(View v)
             {
                 // TODO Auto-generated method stub
                 mBitmap = BitmapFactory.decodeResource(getResources(), R.drawable.mmm);
                 //锁定整个SurfaceView
                 Canvas mCanvas = mSurfaceHolder.lockCanvas();
                 //画图
                 mCanvas.drawBitmap(mBitmap, 0f, 0f, null);
                 //绘制完成,提交修改
                 mSurfaceHolder.unlockCanvasAndPost(mCanvas);
                 //重新锁一次
                 mSurfaceHolder.lockCanvas(new Rect(0, 0, 0, 0));
                 mSurfaceHolder.unlockCanvasAndPost(mCanvas);
             }
         });
        
     }
    
     @Override
     public boolean onTouchEvent(MotionEvent event)
     {           
         //返回给ScaleGestureDetector来处理
         return mScaleGestureDetector.onTouchEvent(event);
     }
    
    
     public class ScaleGestureListener implements ScaleGestureDetector.OnScaleGestureListener
     {
 
         @Override
         public boolean onScale(ScaleGestureDetector detector)
         {
             // TODO Auto-generated method stub
            
             Matrix mMatrix = new Matrix();       
             //缩放比例
             float scale = detector.getScaleFactor()/3;
             mMatrix.setScale(scale, scale);
            
             //锁定整个SurfaceView
             Canvas mCanvas = mSurfaceHolder.lockCanvas();
             //清屏
             mCanvas.drawColor(Color.BLACK);
             //画缩放后的图
             mCanvas.drawBitmap(mBitmap, mMatrix, null);
             //绘制完成,提交修改
             mSurfaceHolder.unlockCanvasAndPost(mCanvas);
             //重新锁一次
             mSurfaceHolder.lockCanvas(new Rect(0, 0, 0, 0));
             mSurfaceHolder.unlockCanvasAndPost(mCanvas);
            
             return false;
         }
 
         @Override
         public boolean onScaleBegin(ScaleGestureDetector detector)
         {
             // TODO Auto-generated method stub   
             //一定要返回true才会进入onScale()这个函数
             return true;
         }
 
         @Override
         public void onScaleEnd(ScaleGestureDetector detector)
         {
             // TODO Auto-generated method stub
            
         }
        
     }
     
 }

时间: 2024-08-01 22:45:35

android的ScaleGestureDetector缩放类详解的相关文章

Android开发之Html类详解

在进行Android开发中经常回忽略Html类.这个类其实很简单,就是将HTML标签文本解析成普通的样式文本.下面就让我么看一下这个类的具体介绍. 类结构: java.lang.Object    ? android.text.Html 类概述: 这个类用于处理的HTML字符串并将其转换成可显示的样式文本.但并不是所有的HTML标记的支持. 公有方法: 说其简单是应为它就有四个方法: Public Methods static String escapeHtml(CharSequence tex

Android开发之MediaRecorder类详解

MediaRecorder类详解 手机一般都有麦克风和摄像头,而Android系统就可以利用这些硬件来录制音视频了. 为了增加对录制音视频的支持,Android系统提供了一个MediaRecorder的类.该类的使用也非常简单,下面让我们来了解一下这个类: 一.类结构: java.lang.Object    ? android.media.MediaRecorder 二.类概述: 用于录制音频和视频的一个类. 三.状态图: 说明: 与MediaPlayer类非常相似MediaRecorder也

android自定义控件系列----Scroller类详解

说在前面的话: 为什么要来说Scroller这个类呢?这个类到底是拿来干什么的呢?如果你看了ListView这类控件那么你肯定会发现里面有一个Sroller类,其实它的作用就是辅助记录和计算我们滑动的距离和速度这些.从而让我们在自定义控件的时候可以方便的做一些滑动和回弹的动画,为什么呢?因为Sroller类都给你计算好了嘛. 类分析 public class Scroller { private int mMode; private int mStartX; private int mStart

Android基础入门教程——8.3.1 三个绘图工具类详解

Android基础入门教程--8.3.1 三个绘图工具类详解 标签(空格分隔): Android基础入门教程 本节引言: 上两小节我们学习了Drawable以及Bitmap,都是加载好图片的,而本节我们要学习的绘图相关的 一些API,他们分别是Canvas(画布),Paint(画笔),Path(路径)!本节非常重要,同时也是我们 自定义View的基础哦~好的,话不多说开始本节内容~ 官方API文档:Canvas:Paint:Path: 1.相关方法详解 1)Paint(画笔): 就是画笔,用于设

Android技术18:Android中Adapter类详解

1.Adapter设计模式 Android中adapter接口有很多种实现,例如,ArrayAdapter,BaseAdapter,CursorAdapter,SimpleAdapter,SimpleCursorAdapter等,他们分别对应不同的数据源.例如,ArrayAdater对应List和数组数据源,而CursorAdapter对应Cursor对象(一般从数据库中获取的记录集).这些Adapter都需要getView方法返回当前列表项显示的View对象.当Model发生改变时,会调用Ba

Android中滑屏实现----手把手教你如何实现触摸滑屏以及Scroller类详解

Android中滑屏实现----手把手教你如何实现触摸滑屏以及Scroller类详解

Android中内容观察者的使用---- ContentObserver类详解

  转载请注明出处:http://blog.csdn.net/qinjuning 前言: 工作中,需要开启一个线程大量的查询某个数据库值发送了变化,导致的开销很大,后来在老大的指点下,利用了 ContentObserver完美的解决了该问题,感到很兴奋,做完之后自己也对ContentObserver做下总结. ContentObserver——内容观察者,目的是观察(捕捉)特定Uri引起的数据库的变化,继而做一些相应的处理,它类似于 数据库技术中的触发器(Trigger),当ContentObs

Android高效率编码-第三方SDK详解系列(三)——JPush推送牵扯出来的江湖恩怨,XMPP实现推送,自定义客户端推送

Android高效率编码-第三方SDK详解系列(三)--JPush推送牵扯出来的江湖恩怨,XMPP实现推送,自定义客户端推送 很久没有更新第三方SDK这个系列了,所以更新一下这几天工作中使用到的推送,写这个系列真的很要命,你要去把他们的API文档大致的翻阅一遍,而且各种功能都实现一遍,解决各种bug各种坑,不得不说,极光推送真坑,大家使用还是要慎重,我们看一下极光推送的官网 https://www.jpush.cn/common/ 推送比较使用,很多软件有需要,所以在这个点拿出来多讲讲,我们本节

Android触摸屏事件派发机制详解与源码分析二(ViewGroup篇)

1 背景 还记得前一篇<Android触摸屏事件派发机制详解与源码分析一(View篇)>中关于透过源码继续进阶实例验证模块中存在的点击Button却触发了LinearLayout的事件疑惑吗?当时说了,在那一篇咱们只讨论View的触摸事件派发机制,这个疑惑留在了这一篇解释,也就是ViewGroup的事件派发机制. PS:阅读本篇前建议先查看前一篇<Android触摸屏事件派发机制详解与源码分析一(View篇)>,这一篇承接上一篇. 关于View与ViewGroup的区别在前一篇的A