Android手勢識別類 GestureDetector
為了加強鼠標響應事件,Android提供了GestureDetector手勢識別類。通過GestureDetector.OnGestureListener來獲取當前被觸發的操作手勢(Single Tap Up、Show Press、Long Press、Scroll、Down、Fling),具體包括以下幾種:
boolean onDoubleTap(MotionEvent e)
解釋:雙擊的第二下Touch down時觸發
boolean onDoubleTapEvent(MotionEvent e)
解釋:雙擊的第二下Touch down和up都會觸發,可用e.getAction()區分。
boolean onDown(MotionEvent e)
解釋:Touch down時觸發
boolean onFling(MotionEvent e1, MotionEvent e2, float velocityX, float velocityY)
解釋:Touch了滑動一點距離后,up時觸發。
void onLongPress(MotionEvent e)
解釋:Touch了不移動一直Touch down時觸發
boolean onScroll(MotionEvent e1, MotionEvent e2, float distanceX, float distanceY)
解釋:Touch了滑動時觸發。
void onShowPress(MotionEvent e)
解釋:Touch了還沒有滑動時觸發
(與onDown,onLongPress比較
onDown只要Touch down一定立刻觸發。
而Touchdown后過一會沒有滑動先觸發onShowPress再是onLongPress。
所以Touchdown后一直不滑動,onDown->onShowPress->onLongPress這個順序觸發。
boolean onSingleTapConfirmed(MotionEvent e)
boolean onSingleTapUp(MotionEvent e)
解釋:上面這兩個函數都是在touch down后又沒有滑動(onScroll),又沒有長按(onLongPress),然后Touchup時觸發。
點擊一下非常快的(不滑動)Touchup:
onDown->onSingleTapUp->onSingleTapConfirmed
點擊一下稍微慢點的(不滑動)Touchup:
onDown->onShowPress->onSingleTapUp->onSingleTapConfirmed
用一個圖片切換的例子來說明手勢識別類的使用。
java代碼:
package com.lovo;
import android.app.Activity;
import android.os.Bundle;
import android.view.GestureDetector;
import android.view.GestureDetector.OnGestureListener;
import android.view.MotionEvent;
import android.widget.ImageView;
/**
* 手勢識別類
* 圖片切換顯示,實現接口OnGestureListener
* @author Administrator
*
*/
public class MyGestrueTest extends Activity implements OnGestureListener{
/**手勢管理器*/
private GestureDetector detector;
/**圖片資源數組*/
private int [] imageId;
/**圖片視圖*/
private ImageView imageView ;
private ImageView[] imgView;
/**圖片下標計數器*/
private int count=0;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.my_gesture_test);
//創建手勢管理器
detector = new GestureDetector(this);
//得到圖片視圖
imageView=(ImageView) findViewById(R.id.image_gestrue);
//得到圖片資源的Id
imageId = new int[]{
R.drawable.whatsnew_fornew_01,
R.drawable.whatsnew_fornew_02,
R.drawable.whatsnew_fornew_03,
R.drawable.whatsnew_fornew_04,
R.drawable.whatsnew_fornew_05};
//得到圖片視圖 ImageView
imgView = new ImageView []{
(ImageView) findViewById(R.id.small_image1),
(ImageView) findViewById(R.id.small_image2),
(ImageView) findViewById(R.id.small_image3),
(ImageView) findViewById(R.id.small_image4),
(ImageView) findViewById(R.id.small_image5)};
}
@Override
public boolean onTouchEvent(MotionEvent event) {
//將touch事件交給手勢管理器來處理
return detector.onTouchEvent(event);
}
@Override
public boolean onDown(MotionEvent e) {
return false;
}
/**
* 手勢滑動觸發的事件
*/
@Override
public boolean onFling(MotionEvent e1, MotionEvent e2, float velocityX,
float velocityY) {
//從右往左移動
if(e1.getX()-e2.getX()>50){
//下標++
count++;
if(count<=4){
//切換到下一張
imageView.setImageResource(imageId[count]);
//設置該張對應的高亮小圖標
imgView[count].setImageResource(R.drawable.page_indicator_focused);
//其他小圖標均為非高亮
imgView[count-1].setImageResource(R.drawable.page_indicator_unfocused);
}else{
//滑動到最后一張,該方向不會再滑動,就停留在最后一張
count=4;
imageView.setImageResource(imageId[count]);
}
}
//從左往右移動
if(e1.getX()-e2.getX()<50){
count--;
if(count>=0){
imageView.setImageResource(imageId[count]);
imgView[count].setImageResource(R.drawable.page_indicator_focused);
imgView[count+1].setImageResource(R.drawable.page_indicator_unfocused);
}else{
count=0;
imageView.setImageResource(imageId[count]);
}
}
return false;
}
@Override
public void onLongPress(MotionEvent e) {}
@Override
public boolean onScroll(MotionEvent e1, MotionEvent e2, float distanceX,
float distanceY) {
return false;
}
@Override
public void onShowPress(MotionEvent e) {}
@Override
public boolean onSingleTapUp(MotionEvent e) {
return false;
}
}
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="#000">
<LinearLayout
android:id="@+id/my_geture_test_1"
android:layout_width="match_parent"
android:layout_height="match_parent" >
<ImageView
android:id="@+id/image_gestrue"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:src="@drawable/whatsnew_fornew_01" >
</ImageView>
</LinearLayout>
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_alignParentBottom="true"
android:gravity="center_horizontal"
android:layout_marginBottom="30dp"
>
<ImageView
android:id="@+id/small_image1"
android:padding="5dp"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:src="@drawable/page_indicator_focused"
>
</ImageView>
<ImageView
android:id="@+id/small_image2"
android:padding="5dp"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:src="@drawable/page_indicator_unfocused" >
</ImageView>
<ImageView
android:id="@+id/small_image3"
android:padding="5dp"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:src="@drawable/page_indicator_unfocused" >
</ImageView>
<ImageView
android:id="@+id/small_image4"
android:padding="5dp"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:src="@drawable/page_indicator_unfocused" >
</ImageView>
<ImageView
android:id="@+id/small_image5"
android:padding="5dp"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:src="@drawable/page_indicator_unfocused" >
</ImageView>
</LinearLayout>
</RelativeLayout>