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

来源:互联网 发布:搜索电影免费网络观看 编辑:程序博客网 时间:2024/05/09 13:59

侧滑切换图片

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"    ><ImageSwitcherandroid: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;//移动最大速度  @Overridepublic 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() {@Overridepublic 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;}  }




0 0