android ViewFlipper实现图片轮播

package xiuchang.administrator.myapplication;

import android.support.v7.app.ActionBarActivity;
import android.os.Bundle;
import android.view.MotionEvent;
import android.widget.ImageView;
import android.widget.ViewFlipper;


public class MainActivity extends ActionBarActivity {

private ViewFlipper flipper ;
private float startX ;
private int [] resId ={R.drawable. pic1 ,R.drawable. pic2 ,R.drawable. pic3 ,R.drawable. pic4 };
@Override
protected void onCreate(Bundle savedInstanceState) {
super .onCreate(savedInstanceState);
setContentView(R.layout. activity_main );
flipper =(ViewFlipper)findViewById(R.id. flipper );
for ( int i= 0 ;i< resId . length ;i++){
flipper .addView(getImageView( resId [i]));

}
flipper .setInAnimation( this ,R.anim. left_in );
flipper .setOutAnimation( this ,R.anim. left_out );
flipper .setFlipInterval( 3000 );
flipper .startFlipping();

}

@Override
public boolean onTouchEvent(MotionEvent event) {
switch (event.getAction()){
case MotionEvent. ACTION_DOWN :{
break ;
}
case MotionEvent. ACTION_MOVE :{
startX =event.getX();
break ;
}
case MotionEvent. ACTION_UP :{
if (event.getX()- startX > 100 ){
flipper .setInAnimation( this ,R.anim. left_in );
flipper .setInAnimation( this ,R.anim. left_out );
flipper .showPrevious(); //显示前一页
}
if ( startX -event.getX()> 100 ){
flipper .setInAnimation( this ,R.anim. right_in );
flipper .setInAnimation( this ,R.anim. right_out );
flipper .showNext(); //显示前一页

}
break ;
}
}
return super .onTouchEvent(event);
}

private ImageView getImageView( int resId){
ImageView image= new ImageView( this );
image.setImageResource(resId);
return image;
}


}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值