Android学习 多读官网,故意健康---手势

风流不在谈锋胜,袖手无言味最长。这篇文章主要讲述Android学习 多读官网,故意健康---手势相关的知识,希望能为你提供帮助。
官网地址 ttp://developer.android.com/training/gestures/detector.html:


【Android学习 多读官网,故意健康---手势】一、能够直接覆盖Activity的onTouch方法


public class MainActivity extends Activity { ... // This example shows an Activity, but you would use the same approach if // you were subclassing a View. @Override public boolean onTouchEvent(MotionEvent event){             int action = MotionEventCompat.getActionMasked(event);             switch(action) {         case (MotionEvent.ACTION_DOWN) :             Log.d(DEBUG_TAG,"Action was DOWN");             return true;         case (MotionEvent.ACTION_MOVE) :             Log.d(DEBUG_TAG,"Action was MOVE");             return true;         case (MotionEvent.ACTION_UP) :             Log.d(DEBUG_TAG,"Action was UP");             return true;         case (MotionEvent.ACTION_CANCEL) :             Log.d(DEBUG_TAG,"Action was CANCEL");             return true;         case (MotionEvent.ACTION_OUTSIDE) :             Log.d(DEBUG_TAG,"Movement occurred outside bounds " +                     "of current screen element");             return true;               default :             return super.onTouchEvent(event);     }       }



二:也能够给单个的view设置监听器
View myView = findViewById(R.id.my_view); myView.setOnTouchListener(new OnTouchListener() {     public boolean onTouch(View v, MotionEvent event) {         // ... Respond to touch events               return true;     } });

三:可是 onTouch方法毕竟仅仅能检測一些简单的手势,像滑动、双击、长按等。单用onTouch方法处理就显得棘手了,谷歌提供了方便的    GestureDetector  类来更方便的处理手势。

详细的须要实例    GestureDetectorCompat  类,  该类中的构造方法须要实现 监听器。GestureDetector.OnGestureListener  去通知用户,当各种事件(滑动、双击、长按等)发生。为了使  GestureDetector  正常监听事件,同一时候须要重写Activity的 nTouch方法。把事件交给Detector。
详细见官网demo:


public class MainActivity extends Activity implements         GestureDetector.OnGestureListener,         GestureDetector.OnDoubleTapListener{         private static final String DEBUG_TAG = "Gestures";     private GestureDetectorCompat mDetector;     // Called when the activity is first created.     @Override     public void onCreate(Bundle savedInstanceState) {         super.onCreate(savedInstanceState);         setContentView(R.layout.activity_main);         // Instantiate the gesture detector with the         // application context and an implementation of         // GestureDetector.OnGestureListener         mDetector = new GestureDetectorCompat(this,this);         // Set the gesture detector as the double tap         // listener.         mDetector.setOnDoubleTapListener(this);     }    @Override     public boolean onTouchEvent(MotionEvent event){         this.mDetector.onTouchEvent(event);         // Be sure to call the superclass implementation         return super.onTouchEvent(event);     }    @Override     public boolean onDown(MotionEvent event) {         Log.d(DEBUG_TAG,"onDown: " + event.toString());         return true;     }    @Override     public boolean onFling(MotionEvent event1, MotionEvent event2,             float velocityX, float velocityY) {         Log.d(DEBUG_TAG, "onFling: " + event1.toString()+event2.toString());         return true;     }    @Override     public void onLongPress(MotionEvent event) {         Log.d(DEBUG_TAG, "onLongPress: " + event.toString());     }    @Override     public boolean onScroll(MotionEvent e1, MotionEvent e2, float distanceX,             float distanceY) {         Log.d(DEBUG_TAG, "onScroll: " + e1.toString()+e2.toString());         return true;     }    @Override     public void onShowPress(MotionEvent event) {         Log.d(DEBUG_TAG, "onShowPress: " + event.toString());     }    @Override     public boolean onSingleTapUp(MotionEvent event) {         Log.d(DEBUG_TAG, "onSingleTapUp: " + event.toString());         return true;     }    @Override     public boolean onDoubleTap(MotionEvent event) {         Log.d(DEBUG_TAG, "onDoubleTap: " + event.toString());         return true;     }    @Override     public boolean onDoubleTapEvent(MotionEvent event) {         Log.d(DEBUG_TAG, "onDoubleTapEvent: " + event.toString());         return true;     }    @Override     public boolean onSingleTapConfirmed(MotionEvent event) {         Log.d(DEBUG_TAG, "onSingleTapConfirmed: " + event.toString());         return true;     } }


补充:

onScroll:在屏幕上慢慢的滚动。


onFling:在屏幕上高速的滚动,并高速移开手指。



Whether or not you use  GestureDetector.OnGestureListener, it‘s best practice to implement an  onDown()method that returns  true. This is because all gestures begin with an  onDown()  message. If you return  false  fromonDown(), as  GestureDetector.SimpleOnGestureListener  does by default, the system assumes that you want to ignore the rest of the gesture, and the other methods of  GestureDetector.OnGestureListener  never get called. This has the potential to cause unexpected problems in your app. The only time you should return  false  fromonDown()  is if you truly want to ignore an entire gesture.



另外,官网上说最好复写onDown方法,并返回true,由于其它方法的消息都是从onDown方法開始的。并且onDown系统默认返回false,其它的方法也不会被调用。


但是我自己试了下,当onDown方法返回false,其它方法是能够被调用的。。这就奇怪了。。。哪位高手亲试过这个样例的,回复下。。


??







    推荐阅读