ViewFlipper实践

类似于viewpager,但是没有手势滑动,更适合做轮播图(不能点的那种)。

在布局中定义:

    <ViewFlipper
        android:id="@+id/flipper"
        android:layout_width="match_parent"
        android:layout_height="match_parent">

    </ViewFlipper>
在程序中引用:
@EActivity(R.layout.activity_main4)
public class Main4Activity extends AppCompatActivity {

    @ViewById
    ViewFlipper flipper;

    private int[] dabid = {R.drawable.ic_launcher, R.drawable.images, R.drawable.init_pic, R.drawable.biz_topic_vote_submit_default};

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
    }

    @AfterViews
    void initView() {
        for (int i = 0; i < dabid.length; i++) {
            flipper.addView(getImageView(dabid[i]));
        }
        //设置自动播放的功能
       flipper.setInAnimation(Main4Activity.this, R.anim.left_in);
        flipper.setOutAnimation(Main4Activity.this, R.anim.left_out);
        flipper.setFlipInterval(3000);
        flipper.startFlipping();
    }

    private ImageView getImageView(int imagrs) {
        ImageView image = new ImageView(this);
        image.setImageResource(imagrs);
        image.setScaleType(ImageView.ScaleType.FIT_XY);
        return image;
    }
}
在getImageView中,设置的是src的资源,这时是按照图片大小来填充当前布局,如果需要全屏显示图片,可以用setbackground。

支持手势滑动的方法:

重写onTouchEvent()方法,并关闭自动滑动的效果:

    @Override
    public boolean onTouchEvent(MotionEvent event) {
        switch (event.getAction()) {
            case MotionEvent.ACTION_DOWN:
                mystartX = event.getX();
                break;
            case MotionEvent.ACTION_UP:
                //向右划
                if (event.getX() - mystartX > 100) {
                    flipper.setInAnimation(this, R.anim.left_in);
                    flipper.setOutAnimation(this, R.anim.left_out);
                    flipper.showPrevious();
                }
                //向左划
                if (event.getX() - mystartX < 100) {
                    flipper.setInAnimation(this, R.anim.right_in);
                    flipper.setOutAnimation(this, R.anim.right_out);
                    flipper.showNext();
                }
                break;
            case MotionEvent.ACTION_MOVE:
                break;
        }
        return super.onTouchEvent(event);
    }


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值