在实现多个图片的切换功能时,使用到了手势事件功能,但同时需要给图片增加一个单击事件去执行其它功能。增加单击事件后,图片会截取到touchdown并不再往下传递,导致手势事件失效,这里给出了其解决办法,稍后会整理出多图切换内容 先看解决办法,在这之前,需要了解 OnGestureListener 中 onDown、onFling、onLongPress、onScroll、onShowPress、onSingleTapUp的执行顺序以及其执行原由。这里做了简单总结
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到了这里,就已经很明了的清楚了,在onDown以后且onFling以前执行的函数有onShowPress、onSingleTapUp,我已经做过了测试不过非常快的点击还是稍微慢的点击都会触发 onSingleTapUp ,因此只需要在这个函数上做一下功夫就可以了
@Override public boolean onSingleTapUp(MotionEvent e) { // TODO Auto-generated method stub Log.d("Tag", "singletagup"); this.viewfliper.setClickable(true); Intent intent = new Intent(context, PhotoScaleActivity.class); startActivity(intent); this.viewfliper.setClickable(false); return false; }好了,这样就已经实现了想要的功能了~ 新记录~