侧滑切换图片
1.主界面布局:
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="horizontal"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:id="@+id/llayout"
android:gravity="center"
>
<ImageSwitcher
android:id="@+id/imageSwitcher1"
android:layout_gravity="center"
android:layout_width="wrap_content"
android:layout_height="wrap_content"/>
</LinearLayout>
2.主活动代码:
</pre><pre name="code" class="html">
package hqu.edu.cn;
import android.os.Bundle;
import android.app.Activity;
import android.view.GestureDetector;
import android.view.Menu;
import android.view.MotionEvent;
import android.app.Activity;
import android.os.Bundle;
import android.view.View;
import android.view.GestureDetector.OnGestureListener;
import android.view.View.OnClickListener;
import android.view.View.OnTouchListener;
import android.view.ViewGroup.LayoutParams;
import android.view.animation.AnimationUtils;
import android.widget.Button;
import android.widget.ImageSwitcher;
import android.widget.ImageView;
import android.widget.ViewSwitcher.ViewFactory;
public class ImageSwitcherActivity extends Activity implements OnTouchListener,OnGestureListener {
private int[] imageId = new int[] { R.drawable.img01, R.drawable.img02,
R.drawable.img03, R.drawable.img04, R.drawable.img05,
R.drawable.img06, R.drawable.img07, R.drawable.img08,
R.drawable.img09 }; // 声明并初始化一个保存要显示图像ID的数组
private int index = 0; // 当前显示图像的索引
private ImageSwitcher imageSwitcher; // 声明一个图像切换器对象
private static final int FLING_MIN_DISTANCE = 120;//移动最小距离
private static final int FLING_MIN_VELOCITY = 200;//移动最大速度
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_image_switcher);
imageSwitcher = (ImageSwitcher) findViewById(R.id.imageSwitcher1); // 获取图像切换器
// 设置动画效果
imageSwitcher.setInAnimation(AnimationUtils.loadAnimation(this,
android.R.anim.fade_in)); // 设置淡入动画
imageSwitcher.setOutAnimation(AnimationUtils.loadAnimation(this,
android.R.anim.fade_out)); // 设置淡出动画
imageSwitcher.setFactory(new ViewFactory() {
@Override
public View makeView() {
ImageView imageView = new ImageView(ImageSwitcherActivity.this); // 实例化一个ImageView类的对象
imageView.setScaleType(ImageView.ScaleType.FIT_CENTER); // 设置保持纵横比居中缩放图像
imageView.setLayoutParams(new ImageSwitcher.LayoutParams(
LayoutParams.WRAP_CONTENT, LayoutParams.WRAP_CONTENT));
return imageView; // 返回imageView对象
}
});
imageSwitcher.setImageResource(imageId[index]);// 显示默认的图片
//设置Touch监听
imageSwitcher.setOnTouchListener(this);
//允许长按
imageSwitcher.setLongClickable(true);
}
//构建手势探测器
GestureDetector mygesture = new GestureDetector(this);
@Override
public boolean onTouch(View v, MotionEvent event) {
return mygesture.onTouchEvent(event);
}
//显示下一张图片
public void showNextImage(){
++index;
if(index>= imageId.length ){
//Toast.makeText(MainActivity.this, "已到最后一张图片", Toast.LENGTH_SHORT).show();
index=0;
}
imageSwitcher.setImageResource(imageId[index]);
//System.out.println("positoon="+position);
}
//显示上一张图片
public void showLastImage(){
--index;
if(index<0){
//Toast.makeText(MainActivity.this, "已到第一张图片", Toast.LENGTH_SHORT).show();
index=imageId.length-1;
}
imageSwitcher.setImageResource(imageId[index]);
}
/*用户按下触摸屏、快速移动后松开,由1个MotionEvent ACTION_DOWN,
* 多个ACTION_MOVE, 1个ACTION_UP触发*/
//主要方法
@Override
public boolean onFling(MotionEvent e1, MotionEvent e2, float velocityX,
float velocityY) {
// e1:第1个ACTION_DOWN MotionEvent
// e2:最后一个ACTION_MOVE MotionEvent
// velocityX:X轴上的移动速度(像素/秒)
// velocityY:Y轴上的移动速度(像素/秒)
// X轴的坐标位移大于FLING_MIN_DISTANCE,且移动速度大于FLING_MIN_VELOCITY个像素/秒
//向有翻图片
if (e1.getX() - e2.getX() > FLING_MIN_DISTANCE
&& Math.abs(velocityX) > FLING_MIN_VELOCITY) {
showNextImage();
}
//向左翻图片
if (e2.getX() - e1.getX() > FLING_MIN_DISTANCE
&& Math.abs(velocityX) > FLING_MIN_VELOCITY) {
showLastImage();
}
return false;
}
//下面方法没用,但是这里必须实现
/* 用户长按触摸屏,由多个MotionEvent ACTION_DOWN触发*/
@Override
public void onLongPress(MotionEvent e) {}
/* 用户按下触摸屏,并拖动,由1个MotionEvent ACTION_DOWN, 多个ACTION_MOVE触发*/
@Override
public boolean onScroll(MotionEvent e1, MotionEvent e2, float distanceX,float distanceY) {return false;}
/* 用户轻触触摸屏,尚未松开或拖动,由一个1个MotionEvent ACTION_DOWN触发
注意和onDown()的区别,强调的是没有松开或者拖动的状态 */
@Override
public void onShowPress(MotionEvent e) {}
/*用户(轻触触摸屏后)松开,由一个1个MotionEvent ACTION_UP触发*/
@Override
public boolean onSingleTapUp(MotionEvent e) {return false;}
@Override
public boolean onDown(MotionEvent e) {return false;}
}