Android實現(xiàn)手指觸控圖片縮放功能
這次記錄的是實現(xiàn)Android圖片兩手觸控縮放的功能。
編譯環(huán)境:eclipse
Android版本4.0
創(chuàng)建工程過程略
實現(xiàn)圖片在頁面兩手觸控縮放
原理圖---圖片縮放

兩手拉開圖片變大,兩手合攏圖片縮小,根據(jù)兩手的移動距離來判斷圖片放大和縮小的倍數(shù),兩手的移動距離計算方法如下:

兩手不管是正著還是斜著拉伸,用勾股定理都能計算出兩點的距離。
除此之外,還要確定兩個手位置的中心點,圖片以這個中心點為參照進行放大和縮?。?/p>

計算兩點之間的中心點的方法是,點1距原點位置X1(或者Y1)加上點2距原點位置X2(或者Y2),和除以2即可:
X0=(X1+X2)/2; Y0=(Y1+Y2)/2;
實現(xiàn)圖片在頁面內的觸控縮放(還有拖拉功能,是以前寫的)
main.xml:
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:orientation="vertical"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
tools:context="com.example.dragscale.MainActivity" >
<!--scaleType="matrix"采用矩陣來實現(xiàn)圖片的拖拉和放大-->
<ImageView
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:src="@drawable/keep"
android:scaleType="matrix"
android:id="@+id/image"/>
</LinearLayout>
MainActivity.java:
package com.example.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;
public class MainActivity extends Activity {
private ImageView imageView;
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
imageView=(ImageView)this.findViewById(R.id.image);
//添加觸摸監(jiān)聽對象(控件被觸摸就會觸發(fā)TouchListener類)
imageView.setOnTouchListener(new TouchListener());
}
private final class TouchListener implements OnTouchListener{
private PointF startPoint= new PointF();//PointF(浮點對)
private Matrix matrix=new Matrix();//矩陣對象
private Matrix currentMatrix=new Matrix();//存放照片當前的矩陣
private int mode=0;//確定是放大還是縮小
private static final int DRAG=1;//拖拉模式
private static final int ZOOM=2;//縮放模式
private float startDis;//開始距離
private PointF midPoint;//中心點
//參數(shù)1:用戶觸摸的控件;參數(shù)2:用戶觸摸所產(chǎn)生的事件
public boolean onTouch(View v, MotionEvent event) {
//判斷事件的類型
//得到低八位才能獲取動作,所以要屏蔽高八位(通過與運算&255)
//ACTION_MASK就是一個常量,代表255
switch (event.getAction()&MotionEvent.ACTION_MASK) {
case MotionEvent.ACTION_DOWN://手指下壓
mode=DRAG;
currentMatrix.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;//得到在y軸的移動距離
matrix.set(currentMatrix);//在沒有進行移動之前的位置基礎上進行移動
//實現(xiàn)位置的移動
matrix.postTranslate(dx, dy);
}else if(mode==ZOOM){//縮放模式
float endDis=distance(event);//結束距離
if(endDis>10f){//防止不規(guī)則手指觸碰
//結束距離除以開始距離得到縮放倍數(shù)
float scale=endDis/startDis;
//通過矩陣實現(xiàn)縮放
//參數(shù):1.2.指定在xy軸的放大倍數(shù);3,4以哪個參考點進行縮放
//開始的參考點以兩個觸摸點的中心為準
matrix.set(currentMatrix);//在沒有進行縮放之前的基礎上進行縮放
matrix.postScale(scale,scale,midPoint.x,midPoint.y);
}
}
break;
case MotionEvent.ACTION_UP://手指離開屏幕
case MotionEvent.ACTION_POINTER_UP://當屏幕上已經(jīng)有手指離開屏幕,屏幕上還有一個手指,就會觸發(fā)這個事件
mode=0;
break;
case MotionEvent.ACTION_POINTER_DOWN://當屏幕上已經(jīng)有觸點(手指),再有一個手指按下屏幕,就會觸發(fā)這個事件
mode=ZOOM;
startDis=distance(event);
if(startDis>10f){//防止不規(guī)則手指觸碰
midPoint=mid(event);
currentMatrix.set(imageView.getImageMatrix());//記錄ImageView當前的縮放倍數(shù)
}
break;
default:
break;
}
//將imageView的矩陣位置改變
imageView.setImageMatrix(matrix);
return true;
}
}
//計算兩點之間的距離(勾股定理)
public 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);
}
//計算兩個點的中心點
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);
}
}
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
Android中ACTION_CANCEL的觸發(fā)機制與滑出子view的情況
這篇文章主要介紹了Android中ACTION_CANCEL的觸發(fā)機制與滑出子view的情況,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-09-09
Android程序開發(fā)之ListView 與PopupWindow實現(xiàn)從左向右滑動刪除功能
這篇文章主要介紹了Android程序開發(fā)之ListView 與PopupWindow實現(xiàn)滑動刪除功能的相關資料,非常不錯,具有參考借鑒價值,需要的朋友可以參考下2016-07-07
Android裁剪圖片為圓形圖片的實現(xiàn)原理與代碼
這個方法是根據(jù)傳入的圖片的高度(height)和寬度(width)決定的,如果是 width <= height時,則會裁剪高度,裁剪的區(qū)域是寬度不變高度從頂部到寬度width的長度2013-01-01
調用startService會拋出IllegalStateException異常解決
這篇文章主要為大家介紹了調用startService會拋出IllegalStateException異常解決,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-07-07

