Android 手势识别 (左右滑动)实现 页面 切换

要实现 页面左右滑动的效果  就一定要由手势识别器, 就是这个对象 GestureDetector用法其实很简单,这里 写一下 方便以后用到的时候好找
步骤就是 这样子 123.1.
 初始化手势识别器   
注册 手势识别的 touch 事件就是这么简单。
仅仅两步 就能实现识别手势页面切换。
因为 页面切换 在每个 activity  中都有  所以 我们 把手势识别器 初始化   注册  放在baseactivity里面 能够最有效地 利用我们的代码。



[java]  view plain copy print ?
  1. package com.example.gesturedemo;  
  2. import android.app.Activity;  
  3. import android.os.Bundle;  
  4. import android.view.GestureDetector;  
  5. import android.view.View;  
  6. import android.view.MotionEvent;  
  7.   
  8. public abstract class BaseActivity extends Activity {  
  9.   
  10. private GestureDetector mGestureDetector;  
  11.   
  12. @Override  
  13. protected void onCreate(Bundle savedInstanceState) {  
  14.     // TODO Auto-generated method stub  
  15.     super.onCreate(savedInstanceState);  
  16.     //1 初始化  手势识别器  
  17.     mGestureDetector = new GestureDetector(this,new GestureDetector.SimpleOnGestureListener(){  
  18.         @Override  
  19.         public boolean onFling(MotionEvent e1, MotionEvent e2, float velocityX,  
  20.                 float velocityY) { // e1: 第一次按下的位置   e2   当手离开屏幕 时的位置  velocityX  沿x 轴的速度  velocityY: 沿Y轴方向的速度  
  21.             //判断竖直方向移动的大小  
  22.             if(Math.abs(e1.getRawY() - e2.getRawY())>100){  
  23.                 //Toast.makeText(getApplicationContext(), "动作不合法", 0).show();  
  24.                 return true;  
  25.             }  
  26.             if(Math.abs(velocityX)<150){  
  27.                 //Toast.makeText(getApplicationContext(), "移动的太慢", 0).show();  
  28.                 return true;  
  29.             }  
  30.               
  31.             if((e1.getRawX() - e2.getRawX()) >200){ // 表示 向右滑动表示下一页  
  32.                 //显示下一页  
  33.                 next(null);  
  34.                 return true;  
  35.             }  
  36.               
  37.             if((e2.getRawX() - e1.getRawX()) >200){  //向左滑动 表示 上一页  
  38.                 //显示上一页  
  39.                 pre(null);  
  40.                 return true;//消费掉当前事件  不让当前事件继续向下传递  
  41.             }  
  42.             return super.onFling(e1, e2, velocityX, velocityY);  
  43.         }  
  44.     });  
  45.       
  46. }  
  47. /** 
  48.  * 下一个页面 
  49.  * @param view 
  50.  */  
  51. public abstract void next(View view);  
  52. /** 
  53.  * 上一个页面 
  54.  * @param view 
  55.  */  
  56. public abstract void pre(View view);  
  57.   
  58. //重写activity的触摸事件  
  59. @Override  
  60. public boolean onTouchEvent(MotionEvent event) {  
  61.     //2.让手势识别器生效  
  62.     mGestureDetector.onTouchEvent(event);  
  63.     return super.onTouchEvent(event);  
  64. }  
  65.   
  66. }  



然后 让 每个具体的界面 去继承 这个baseactivity     然后实现相应的 next 或者 pre  方法 即可。 为了 显示效果 ,我们定义  几个动画 效果,左进右出,或者右进左出的。  具体 看 小demo 。



真的很容易(点我下载)

你可能感兴趣的:(Android)