图片轮播

package com.example.viewflipperdemo;


import android.app.Activity;
import android.os.Bundle;
import android.view.MotionEvent;
import android.view.View;
import android.view.View.OnTouchListener;
import android.view.animation.AlphaAnimation;
import android.widget.ImageView;
import android.widget.ViewFlipper;




public class MainActivity extends Activity {
int start;
ViewFlipper vf;
private int[] id = {R.drawable.a,R.drawable.b,R.drawable.c};
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.layout);
        vf = (ViewFlipper)findViewById(R.id.viewFlipper1);
        //以下是逐渐动画
        AlphaAnimation inaa = new AlphaAnimation(0.0f, 1.0f);//第二个参数越大图片呈现的速度就越快。
        inaa.setDuration(700);  
        vf.setInAnimation(inaa);
        for(int a:id){
        ImageView iv = new ImageView(this);
        iv.setImageResource(a);
        vf.addView(iv);
        }
        
        vf.setFlipInterval(4000);
        vf.startFlipping();
        vf.setOnTouchListener(new OnTouchListener(){
        @Override
        public boolean onTouch(View v, MotionEvent event) {
        //收拾判断
        switch (event.getAction()) {  
        //手势按下
        case MotionEvent.ACTION_DOWN:
        //获取手势按下的点
        start=(int) event.getX();
        break;
        //手势移动
        case MotionEvent.ACTION_MOVE:  
        break;
        //手离开
        case MotionEvent.ACTION_UP:  
        //按下的点 和结束的点 的插 大于100为 向右  
        if(start - event.getX()>100){  
        //下一张
        vf.showPrevious();
        }
        if(start - event.getX()<100){
        //上一张
        vf.showNext();
        }  
        break;
       
        }
        return true;
        }
        });
    }

}


以下是布局文件

<?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:id="@+id/viewFlipper1"
        android:layout_width="260dp"
        android:layout_height="200dp"
        android:layout_gravity="top|center">
    </ViewFlipper>


</LinearLayout>

整个实现非常的简洁。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值