ViewFlipper

一个多页面管理控件,可以实现子界面的自动切换
为ViewPager加入View

  1. 静态导入
    在layout布局文件中直接导入
<ViewFlipper>
  ImageView1

   ImageView2
   .....
</ViewFlipper>

2.动态导入:addView()

main.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical" >
    <ViewFlipper 
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:id="@+id/flipper"></ViewFlipper>

</LinearLayout>

MainActivity.java

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.main);
        flipper=(ViewFlipper) findViewById(R.id.flipper);
        //动态导入的方式为ViewFlipper加入子View
        for(int i=0;i<resId.length;i++){
            flipper.addView(getImageView(resId[i]));
        }
    }
    //自定义函数,使得返回值为ImageView的形式
    private ImageView getImageView(int resId){
        ImageView Image=new ImageView(this);
        Image.setBackgroundResource(resId);//使得图片铺满整个屏幕
        //Image.setImageResource(resId);
        return Image;
    }

利用ViewFlipper实现图片轮播

//为ViewFlipper添加进入的动画效果
        //flipper.setInAnimation(this, resourceID);
        //为ViewFlipper添加退出的动画效果
        //flipper.setOutAnimation(this, resourceID);

        //为ViewFlipper设定视图切换的时间间隔
//      flipper.setFlipInterval(3000);
//      flipper.startFlipping();//让动画动起来,还有stopFlipping()方法
  • 手势滑动的监听处理
    @Override
    public boolean onTouchEvent(MotionEvent event) {
        //获得触发事件的动作
        switch (event.getAction()) {
        //手指落下
        case MotionEvent.ACTION_DOWN:{  
            startX=event.getX();//获得横向坐标x轴的值作为起始点的坐标
            break;
        }
        //手指滑动,需判断是向左滑动还是向右滑动
        case MotionEvent.ACTION_MOVE:{
            //向右滑动看前一页
            if(event.getX()-startX>100){
                //动画效果:从左边淡入淡出
                //flipper.setInAnimation(this, resourceID);

                //动画效果:从右边淡入淡出
                //flipper.setOutAnimation(this, resourceID);

                //显示前一页
                flipper.showPrevious();
            }
            //向左滑动看前一页
            if(startX-event.getX()>100){
                //动画效果:从左边淡入淡出
                //flipper.setInAnimation(this, resourceID);

                //动画效果:从左边淡入淡出
                //flipper.setOutAnimation(this, resourceID);

                //显示后一页
                flipper.showNext();

            }
            break;
        }
        //手指离开
        case MotionEvent.ACTION_UP:{            
            break;
        }


        }
        return super.onTouchEvent(event);
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值