Android学习笔记(七*侧滑切换图片)

侧滑切换图片

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;}  
	
	
	
	
	
	
	
}




评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值