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;
}
});
}
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>
整个实现非常的简洁。