ViewFlipper结合手势OnGestureListener制作的滑动切换效果


文章分类:移动开发
先要了解ViewFlipper,详细见: 
http://gundumw100.iteye.com/admin/blogs/896840 

OnGestureListener和OnDoubleTapListener接口定义: 
Java代码   收藏代码
  1. public interface OnGestureListener {  
  2.                 // Touch down时触发, e为down时的MotionEvent  
  3.                 boolean onDown(MotionEvent e);  
  4.                 // 在Touch down之后一定时间(115ms)触发,e为down时的MotionEvent  
  5.                 void onShowPress(MotionEvent e);  
  6.                 // Touch up时触发,e为up时的MotionEvent  
  7.                 boolean onSingleTapUp(MotionEvent e);  
  8.                 // 滑动时触发,e1为down时的MotionEvent,e2为move时的MotionEvent  
  9.                 boolean onScroll(MotionEvent e1, MotionEvent e2, float distanceX, float distanceY);  
  10.                 // 在Touch down之后一定时间(500ms)触发,e为down时的MotionEvent  
  11.                 void onLongPress(MotionEvent e);  
  12.                 // 滑动一段距离,up时触发,e1为down时的MotionEvent,e2为up时的MotionEvent  
  13.                 boolean onFling(MotionEvent e1, MotionEvent e2, float velocityX, float velocityY);  
  14. }  
  15.    
  16. public interface OnDoubleTapListener {  
  17.                 // 完成一次单击,并确定没有二击事件后触发(300ms),e为down时的MotionEvent  
  18.                 boolean onSingleTapConfirmed(MotionEvent e);  
  19.                 // 第二次单击down时触发,e为第一次down时的MotionEvent  
  20.                 boolean onDoubleTap(MotionEvent e);  
  21.                 // 第二次单击down,move和up时都触发,e为不同时机下的MotionEvent  
  22.                 boolean onDoubleTapEvent(MotionEvent e);  
  23. }  


实例: 
Java代码   收藏代码
  1. import android.app.Activity;  
  2. import android.os.Bundle;  
  3. import android.view.GestureDetector;  
  4. import android.view.MotionEvent;  
  5. import android.view.View;  
  6. import android.widget.Button;  
  7. import android.widget.ViewFlipper;  
  8.   
  9. public class FlingSlideActivity extends Activity implements GestureDetector.OnGestureListener,GestureDetector.OnDoubleTapListener{  
  10.     private ViewFlipper mViewFlipper;  
  11.     private GestureDetector mGestureDetector;  
  12.     /** Called when the activity is first created. */  
  13.     @Override  
  14.     public void onCreate(Bundle savedInstanceState) {  
  15.         super.onCreate(savedInstanceState);  
  16.         setContentView(R.layout.main);  
  17.         mViewFlipper = (ViewFlipper) findViewById(R.id.flipper);  
  18.         Button button1 = (Button) findViewById(R.id.Button1);     
  19.         button1.setOnClickListener(new View.OnClickListener() {     
  20.             public void onClick(View view) {  
  21.                 mViewFlipper.showNext();     
  22.             }     
  23.         });  
  24.         Button button2 = (Button) findViewById(R.id.Button2);     
  25.         button2.setOnClickListener(new View.OnClickListener() {     
  26.             public void onClick(View view) {  
  27.                 mViewFlipper.showNext();     
  28.             }     
  29.         });        
  30.         Button button3 = (Button) findViewById(R.id.Button3);     
  31.         button3.setOnClickListener(new View.OnClickListener() {     
  32.             public void onClick(View view) {  
  33.                 mViewFlipper.showNext();     
  34.             }  
  35.         });  
  36.         mGestureDetector = new GestureDetector(this);  
  37.     }  
  38.     //别忘了覆盖onTouchEvent方法  
  39.     @Override  
  40.     public boolean onTouchEvent(MotionEvent event) {  
  41.         return mGestureDetector.onTouchEvent(event);  
  42.     }  
  43.     //以下是OnGestureListener需要实现的方法  
  44.     public boolean onDown(MotionEvent e) {  
  45.         // TODO Auto-generated method stub  
  46.         return false;  
  47.     }  
  48.     public boolean onFling(MotionEvent e1, MotionEvent e2, float velocityX,  
  49.             float velocityY) {  
  50.         // TODO Auto-generated method stub  
  51.         if(e1.getX() > e2.getX()) {//向左滑动  
  52.             mViewFlipper.setInAnimation(getApplicationContext(), R.anim.push_left_in);     
  53.             mViewFlipper.setOutAnimation(getApplicationContext(), R.anim.push_left_out);     
  54.            mViewFlipper.showNext();     
  55.        }else if(e1.getX() < e2.getX()) {//向右滑动  
  56.            mViewFlipper.setInAnimation(getApplicationContext(), R.anim.push_right_in);     
  57.            mViewFlipper.setOutAnimation(getApplicationContext(), R.anim.push_right_out);     
  58.            mViewFlipper.showPrevious();     
  59.        }else {     
  60.            return false;     
  61.        }     
  62.        return true;  
  63.     }  
  64.   
  65.     public void onLongPress(MotionEvent e) {  
  66.         // TODO Auto-generated method stub  
  67.           
  68.     }  
  69.   
  70.     public boolean onScroll(MotionEvent e1, MotionEvent e2, float distanceX,  
  71.             float distanceY) {  
  72.         // TODO Auto-generated method stub  
  73.         return false;  
  74.     }  
  75.   
  76.     public void onShowPress(MotionEvent e) {  
  77.         // TODO Auto-generated method stub  
  78.           
  79.     }  
  80.   
  81.     public boolean onSingleTapUp(MotionEvent e) {  
  82.         // TODO Auto-generated method stub  
  83.         return false;  
  84.     }  
  85.     //以下是OnDoubleTapListener需要实现的方法  
  86.     public boolean onDoubleTap(MotionEvent e) {  
  87.         // TODO Auto-generated method stub  
  88.            mViewFlipper.startFlipping(); //双击自动切换界面  
  89.            return true;  
  90.     }  
  91.     public boolean onDoubleTapEvent(MotionEvent e) {  
  92.         // TODO Auto-generated method stub  
  93.         return false;  
  94.     }  
  95.     public boolean onSingleTapConfirmed(MotionEvent e) {  
  96.         // TODO Auto-generated method stub  
  97.         if(mViewFlipper.isFlipping()){ //单击结束自动切换  
  98.             mViewFlipper.stopFlipping();  
  99.         }  
  100.         return false;  
  101.     }  
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
ViewFlipper是Android中的一个ViewGroup,可以用于实现视图的轮播、广告轮播等效果。以下是一个简单的示例,实现ViewFlipper的左右滑动切换图片效果: 1. 在XML布局文件中加入ViewFlipper组件,并添加ImageView子组件作为要轮播的图片。 ```xml <ViewFlipper android:id="@+id/viewFlipper" android:layout_width="match_parent" android:layout_height="match_parent"> <ImageView android:layout_width="match_parent" android:layout_height="match_parent" android:src="@drawable/image1"/> <ImageView android:layout_width="match_parent" android:layout_height="match_parent" android:src="@drawable/image2"/> <ImageView android:layout_width="match_parent" android:layout_height="match_parent" android:src="@drawable/image3"/> </ViewFlipper> ``` 2. 在Java代码中获取ViewFlipper组件,并设置动画效果。 ```java ViewFlipper viewFlipper = findViewById(R.id.viewFlipper); // 设置切换动画 viewFlipper.setInAnimation(this, android.R.anim.slide_in_left); viewFlipper.setOutAnimation(this, android.R.anim.slide_out_right); // 设置轮播时间间隔 viewFlipper.setFlipInterval(3000); // 启动自动轮播 viewFlipper.setAutoStart(true); ``` 在上述代码中,我们使用了Android自带的两种动画效果:slide_in_left和slide_out_right,这两种动画效果可以实现ViewFlipper的左右滑动切换图片效果。同时,我们还设置了轮播时间间隔为3秒,并启动了自动轮播。 最后,我们需要注意的是,如果我们想要在ViewFlipper中添加更多的图片,只需要在XML布局文件中添加更多的ImageView子组件即可。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值