Android 图片全屏滑动效果

简介:

修改一下代码,还可以有幻灯片效果。

package com.h3c.my;

import android.app.Activity;
import android.os.Bundle;
import android.os.Handler;
import android.view.GestureDetector;
import android.view.MotionEvent;
import android.view.View;
import android.view.View.OnTouchListener;
import android.view.Window;
import android.view.animation.AnimationUtils;
import android.widget.Gallery.LayoutParams;
import android.widget.ImageSwitcher;
import android.widget.ImageView;
import android.widget.Toast;
import android.widget.ViewSwitcher;

public class MyGalleryActivity extends Activity implements
		ViewSwitcher.ViewFactory {
	private ImageSwitcher mSwitcher;

	private int mPosition = 0;
	private GestureDetector mGestureDetector;

	private Handler _handle;
	private Runnable _runable;

	private static final float HORIZONTAL_SCROLL_DISTANCE = 10f;

	@Override
	public void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		requestWindowFeature(Window.FEATURE_NO_TITLE);
		setContentView(R.layout.main);

		mSwitcher = (ImageSwitcher) findViewById(R.id.imageSwitch);
		mSwitcher.setFactory(this);

		setupOnTouchListeners(findViewById(R.id.rootview));
		mSwitcher.setImageResource(mImageIds[mPosition]);

		_handle = new Handler();
		_runable = new Runnable() {
			@Override
			public void run() {

				if (mPosition == (mImageIds.length - 1)) {
					Toast.makeText(MyGalleryActivity.this, "最后一张", 0).show();
				} else {
					mSwitcher.setInAnimation(AnimationUtils.loadAnimation(
							MyGalleryActivity.this, R.anim.slide_in_right));
					mSwitcher.setOutAnimation(AnimationUtils.loadAnimation(
							MyGalleryActivity.this, R.anim.slide_out_left));
					mSwitcher.setImageResource(mImageIds[++mPosition]);

					_handle.postDelayed(_runable, 3000);
				}
			}
		};
	}

	private void setupOnTouchListeners(View rootView) {
		mGestureDetector = new GestureDetector(this, new MyGestureListener());

		OnTouchListener rootListener = new OnTouchListener() {
			public boolean onTouch(View v, MotionEvent event) {
				mGestureDetector.onTouchEvent(event);

				// We do not use the return value of
				// mGestureDetector.onTouchEvent because we will not receive
				// the "up" event if we return false for the "down" event.
				return true;
			}
		};

		rootView.setOnTouchListener(rootListener);
	}

	public void onPause() {
		super.onPause();
		_handle.removeCallbacks(_runable);
	}

	private class MyGestureListener extends
			GestureDetector.SimpleOnGestureListener {

		@Override
		public boolean onFling(MotionEvent e1, MotionEvent e2, float velocityX,
				float velocityY) {
			if (Math.abs(velocityY) <= Math.abs(velocityX)
					&& Math.abs(velocityX) > HORIZONTAL_SCROLL_DISTANCE) {
				//
				System.out.println(velocityX);
				if (velocityX > 0) {
					if (mPosition > 0) {
						_handle.removeCallbacks(_runable);
						//
						mSwitcher.setInAnimation(AnimationUtils.loadAnimation(
								MyGalleryActivity.this, R.anim.slide_in_left));
						mSwitcher
								.setOutAnimation(AnimationUtils.loadAnimation(
										MyGalleryActivity.this,
										R.anim.slide_out_right));
						mSwitcher.setImageResource(mImageIds[--mPosition]);

					}
				} else {
					if (mPosition < (mImageIds.length - 1)) {
						_handle.removeCallbacks(_runable);

						mSwitcher.setInAnimation(AnimationUtils.loadAnimation(
								MyGalleryActivity.this, R.anim.slide_in_right));
						mSwitcher.setOutAnimation(AnimationUtils.loadAnimation(
								MyGalleryActivity.this, R.anim.slide_out_left));
						mSwitcher.setImageResource(mImageIds[++mPosition]);

					} else if (mPosition == (mImageIds.length - 1)) {
						_handle.removeCallbacks(_runable);
						Toast.makeText(MyGalleryActivity.this, "注册", 0).show();
						return true;
					}
				}
			}

			return true;
		}

	}

	private Integer[] mImageIds = { R.drawable.a, R.drawable.b, R.drawable.c,
			R.drawable.d, R.drawable.e, R.drawable.f };

	@Override
	public View makeView() {
		ImageView i = new ImageView(this);
		i.setBackgroundColor(0xFF000000);
		i.setScaleType(ImageView.ScaleType.FIT_XY);
		i.setLayoutParams(new ImageSwitcher.LayoutParams(
				LayoutParams.FILL_PARENT, LayoutParams.FILL_PARENT));
		return i;
	}
}


相关文章
|
5月前
|
XML Android开发 数据格式
Android利用selector(选择器)实现图片动态点击效果
本文介绍了Android中ImageView的`src`与`background`属性的区别及应用,重点讲解如何通过设置背景选择器实现图片点击动态效果。`src`用于显示原图大小,不拉伸;`background`可随组件尺寸拉伸。通过创建`selector_setting.xml`,结合`setting_press.xml`和`setting_normal.xml`定义按下和正常状态的背景样式,提升用户体验。示例代码展示了具体实现步骤,包括XML配置和形状定义。
231 3
Android利用selector(选择器)实现图片动态点击效果
|
5月前
|
Java Android开发
Android图片的手动放大缩小
本文介绍了通过缩放因子实现图片放大缩小的功能,效果如动图所示。关键步骤包括:1) 在布局文件中设置 `android:scaleType=&quot;matrix&quot;`;2) 实例化控件并用 `ScaleGestureDetector` 处理缩放手势;3) 使用 `Matrix` 对图片进行缩放处理。为避免内存崩溃,可在全局配置添加 `android:largeHeap=&quot;true&quot;`。代码中定义了 `beforeScale` 和 `nowScale` 变量控制缩放范围,确保流畅体验。
165 8
|
5月前
|
缓存 编解码 Android开发
Android内存优化之图片优化
本文主要探讨Android开发中的图片优化问题,包括图片优化的重要性、OOM错误的成因及解决方法、Android支持的图片格式及其特点。同时介绍了图片储存优化的三种方式:尺寸优化、质量压缩和内存重用,并详细讲解了相关的实现方法与属性。此外,还分析了图片加载优化策略,如异步加载、缓存机制、懒加载等,并结合多级缓存流程提升性能。最后对比了几大主流图片加载框架(Universal ImageLoader、Picasso、Glide、Fresco)的特点与适用场景,重点推荐Fresco在处理大图、动图时的优异表现。这些内容为开发者提供了全面的图片优化解决方案。
181 1
|
Android开发 开发者
Android中弹框如何设计成全屏的
本文介绍在Android中实现全屏对话框的方法,包括使用`Dialog`和`DialogFragment`两种方式。通过设置对话框无标题、调整布局参数及使用透明背景实现全屏效果。适用于希望提升应用交互体验的开发者。
303 0
|
存储 缓存 编解码
Android经典面试题之图片Bitmap怎么做优化
本文介绍了图片相关的内存优化方法,包括分辨率适配、图片压缩与缓存。文中详细讲解了如何根据不同分辨率放置图片资源,避免图片拉伸变形;并通过示例代码展示了使用`BitmapFactory.Options`进行图片压缩的具体步骤。此外,还介绍了Glide等第三方库如何利用LRU算法实现高效图片缓存。
171 20
Android经典面试题之图片Bitmap怎么做优化
|
数据处理 开发工具 数据安全/隐私保护
Android平台RTMP推送|轻量级RTSP服务|GB28181接入之文字、png图片水印的精进之路
本文探讨了Android平台上推流模块中添加文字与PNG水印的技术演进。自2015年起,为了满足应急指挥及安防领域的需求,逐步发展出三代水印技术:第一代为静态文字与图像水印;第二代实现了动态更新水印内容的能力,例如实时位置与时间信息;至第三代,则优化了数据传输效率,直接使用Bitmap对象传递水印数据至JNI层,减少了内存拷贝次数。这些迭代不仅提升了用户体验和技术效率,也体现了开发者追求极致与不断创新的精神。
157 7
|
自然语言处理 定位技术 API
Android经典实战之如何获取图片的经纬度以及如何根据经纬度获取对应的地点名称
本文介绍如何在Android中从图片提取地理位置信息并转换为地址。首先利用`ExifInterface`获取图片内的经纬度,然后通过`Geocoder`将经纬度转为地址。注意操作需在子线程进行且考虑多语言支持。
901 4
|
XML 前端开发 Android开发
Android经典实战之Kotlin中实现圆角图片和圆形图片
本文介绍两种实现圆角图像视图的方法。第一种是通过自定义Kotlin `AppCompatImageView`,重写`onDraw`方法使用`Canvas`和`Path`进行圆角剪裁。第二种利用Android Material库中的`ShapeableImageView`,简单配置即可实现圆角效果。两种方法均易于实现且提供动态调整圆角半径的功能。
262 0
|
JSON 编解码 Apache
Android中使用HttpURLConnection实现GET POST JSON数据与下载图片
Android中使用HttpURLConnection实现GET POST JSON数据与下载图片
165 1
|
前端开发 Java API
Android系统中读写和显示图片
Android系统中读写和显示图片
111 0

热门文章

最新文章