11. viewFlipper.setInAnimation(slideLeftIn);
12. viewFlipper.setOutAnimation(slideLeftOut);
13. viewFlipper.showNext();
14. } else if (e2.getX() - e1.getX() > SWIPE_MIN_DISTANCE &&
Math.abs(velocityX) > SWIPE_THRESHOLD_VELOCITY) {
15. viewFlipper.setInAnimation(slideRightIn);
16. viewFlipper.setOutAnimation(slideRightOut);
17. viewFlipper.showPrevious();
18. }
这里的viewFlipper是含有多个view的一个container, 可以很方便的调用prev/next view, 加上animation动画, 可以达到一些不错的效果:
1. viewFlipper = (ViewFlipper)findViewById(R.id.flipper);
2. slideLeftIn = AnimationUtils.loadAnimation
(this, R.anim.slide_left_in);
3. slideLeftOut = AnimationUtils.loadAnimation
(this, R.anim.slide_left_out);
4. slideRightIn = AnimationUtils.loadAnimation
(this, R.anim.slide_right_in);
5. slideRightOut = AnimationUtils.loadAnimation
(this, R.anim.slide_right_out);
自定义的animation可以查看具体的XML, 比如从左边进来的一个动画:
1. < set xmlns:android="http://schemas.
android.com/apk/res/android">
2. < translate android:fromXDelta="100%p"
android:toXDelta="0" android:duration="800"/>
3. < /set>
当然最后不要忘记在你的Activity中override onTouch方法来获取手势action:
1. @Override
2. public boolean onTouchEvent(MotionEvent event) {
3. if (gestureDetector.onTouchEvent(event))
4. return true;
5. else
6. return false;
7. }
Android滑动手势的相关识别方法就为大家介绍到这里。