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
- Android学习笔记(七*侧滑切换图片)
- NSIS 背景动态切换显示图片 (学习七)
- android学习笔记(七)
- Android学习笔记(七)
- Android学习笔记(七)
- Android应用开发学习笔记之图片切换器
- Android 学习笔记(七)
- android学习笔记——ImageSwitcher控件(图片切换器)
- Android 图片切换,ImageSwitcher 学习
- Android 学习笔记(二七):Menu
- android学习笔记(七)AsyncTask
- Android学习笔记(七)ContentProvider
- Android 学习笔记(二七):Menu
- Android 学习笔记(二七):Menu
- Android 学习笔记(七):WebView
- Android开发秘籍学习笔记(七)
- Android学习笔记(七)Fragment
- Android入门学习笔记整理(七)
- 260. Single Number III
- iPhone OS主要提供以下几种播放音频的方法
- 链式前向星
- 观察者模式(行为型)
- android:属性
- Android学习笔记(七*侧滑切换图片)
- Android JNI(实现自己的JNI_OnLoad函数)
- HDU 5531 Rebuild(三分)
- Android 四大组件和五大布局
- 转载-TCP协议实现原理
- 关于OkHttp框架的使用方法
- 单片机==lcd_电池充电(20)
- S-Trees(二叉树)
- C语言学习日记02