`
byandby
  • 浏览: 1696462 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

android 图片拖动效果(Gallery)

阅读更多
  这还算是一个稍微有点炫的效果吧。IPhone曾经凭借这个效果吸引了无数的苹果粉丝,在Android平台上也可以实现这一效果。要实现这一效果,需要一个容器来存放Gallery显示的图片,这里使用一个继承自BaseAdapter 类的派生类来装这些图片。运行效果如下





示例代码
package xiaohang.zhimeng;

import android.app.Activity;
import android.os.Bundle;
import android.view.View;
import android.widget.AdapterView;
import android.widget.Gallery;
import android.widget.Toast;
import android.widget.AdapterView.OnItemClickListener;

public class Activity01 extends Activity {
	/** 
	Gallery类概述(Gallery)此单词翻译过来为画廊,美术馆

	一种view,以水平列表的方式显示在屏幕中央 看一眼图片就知道咋回事了
	此类继承了  AbsSpinner
	 */

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

		//获得Gallery对象
		Gallery g = (Gallery) findViewById(R.id.Gallery01);

		//添加ImageAdapter给Gallery对象 注意哦Gallery类并没有setAdapter这个方法 这个方法是从AbsSpinner类继承的
		g.setAdapter(new ImageAdapter(this));

		//设置Gallery的背景图片
		g.setBackgroundResource(R.drawable.bg0);

		//设置Gallery的事件监听
		g.setOnItemClickListener(new GalleryItemListener());

	}

	class GalleryItemListener implements OnItemClickListener {
		public void onItemClick(AdapterView<?> parent, View view, int position,
				long id) {
			Toast.makeText(Activity01.this, "你选择了" + (position + 1) + " 号图片",
					Toast.LENGTH_SHORT).show();

		}
	}
}


ImageAdapter类继承自BaseAdapter类 继承BaseAdapter类就会实现一些方法 这些方法可以用来 设置图片源、获取图片个数、设置显示的方式等等。
package xiaohang.zhimeng;

import android.content.Context;
import android.view.View;
import android.view.ViewGroup;
import android.widget.BaseAdapter;
import android.widget.Gallery;
import android.widget.ImageView;

public class ImageAdapter extends BaseAdapter {

	// 定义Context
	private Context mContext;
	// 定义整型数组 即图片源
	private Integer[] mImageIds = { R.drawable.img1, R.drawable.img2,
			R.drawable.img3, R.drawable.img4, R.drawable.img5, R.drawable.img6,
			R.drawable.img7, R.drawable.img8, };

	// 声明ImageAdapter
	public ImageAdapter(Context c) {
		mContext = c;
	}

	// 获取图片的个数
	public int getCount() {
		return mImageIds.length;
	}

	// 获取图片在库中的位置
	public Object getItem(int position) {
		return position;
	}

	// 获取图片ID
	public long getItemId(int position) {
		return position;
	}

	public View getView(int position, View convertView, ViewGroup parent) {
		ImageView imageview = new ImageView(mContext);

		// 给ImageView设置资源
		imageview.setImageResource(mImageIds[position]);
		// 设置布局 图片120*120
		imageview.setLayoutParams(new Gallery.LayoutParams(120, 120));
		// 设置显示比例类型
		imageview.setScaleType(ImageView.ScaleType.FIT_CENTER);
		return imageview;
	}

}

最后布局文件
<?xml version="1.0" encoding="utf-8"?>
<Gallery xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/Gallery01"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    android:spacing="2px"
    >
    <!-- android:spacing="2px"用来设置图片之间的间距 -->
</Gallery>
平台android  2.0  API Level 5

源码附件


  • 大小: 58.1 KB
分享到:
评论
4 楼 silencetq 2011-09-14  
在拖动时候上面图片会感觉有一层黑色的膜,变得比较暗淡,怎么才能正常显示这些图片呢?
3 楼 贫僧不吃肉 2011-03-03  
// 获取图片ID 
    public long getItemId(int position) { 
        return position; 
    } 


怎么感觉有点奇怪?把传入参数又给返回?

2 楼 help_android 2011-02-12  
 
1 楼 help_android 2011-02-12  

相关推荐

    android 图片拖动效果(Gallery控件)

    `Gallery`控件是Android早期版本中实现图片拖动效果的一个好工具。虽然现在已经被`ViewPager`等更现代的组件取代,但理解`Gallery`的工作原理可以帮助开发者更好地理解和使用更高级的组件。在实际开发中,根据项目...

    Android学习记录使用Gallery实现炫丽的拖动效果

    在Android开发中,实现炫丽的拖动效果是提升用户体验的重要一环,特别是使用`Gallery`组件可以创建出类似轮播图或者选择器的效果。这篇博客"Android学习记录使用Gallery实现炫丽的拖动效果"深入探讨了如何利用`...

    android Gallery 拖动式 图片浏览

    在这个“android Gallery 拖动式 图片浏览”项目中,我们主要探讨了如何在Android应用中实现一个可以拖动浏览图片的`Gallery`。 `Gallery`是Android SDK中的一个视图组件,位于`android.widget`包下。它的核心特性...

    android图片拖动效果

    ### Android 图片拖动效果详解 #### 一、概述 在移动应用开发中,提供直观易用的用户界面是提升用户体验的重要因素之一。本篇文章主要介绍如何在Android应用中实现类似iPhone上的图片拖动效果。这种效果允许用户...

    Android图片拖动、点击放大效果

    本项目"Android图片拖动、点击放大效果"提供了一个具体的解决方案,利用Gallery组件和ScaleAnimation类来达到目标。 首先,Gallery组件是Android SDK中的一个特殊视图,它允许用户水平滚动一系列的视图,类似于iOS...

    android gallery实现图片拖动

    总的来说,实现“android gallery实现图片拖动”的功能需要以下几个步骤: 1. 在XML布局中添加`Gallery`和`ImageSwitcher`。 2. 创建自定义适配器,填充`Gallery`的数据。 3. 设置`OnItemClickListener`,监听`...

    自己重写Android下的拥有拖拽功能的Gallery

    1、自己重写了Android下的Gallery(比Android中现有的Gallery更有实用性)。 2、支持数据绑定,且支持绑定数据的动态更新。 3、拖拽效果的用户体验很好。 4、支持item选择效果,前提是item实现了View类的...

    Android UI控件之Gallery实现拖动式图片浏览效果

    在Android中是通过Gallery来实现拖动效果的。 通过Gallery可以实现各种各样的效果,此篇文章只是简要谈谈他的用法,至于后续的一些效果 有机会的时候做一个整理。  首先看看其简单实现吧!本次实例是通过选取图片...

    android 拖动图片集

    在Android开发中,实现图片拖动效果是一种常见的需求,尤其在设计新闻应用或者相册功能时,用户往往期望能够自由浏览并手势操作图片。"android 拖动图片集"这个话题,主要涉及到的是Android中的`Gallery`组件,它...

    android gallery画廊 如iPhone拖动相片特效

    "android gallery画廊 如iPhone拖动相片特效"是一个专为此目的设计的功能,它借鉴了iOS系统的照片滚动效果,实现了在Android平台上平滑且具有动态感的图片浏览体验。 首先,我们要了解Android中的`Gallery`组件。在...

    Android-图片浏览器支持缩放下拉缩小退出

    "Android-图片浏览器支持缩放下拉缩小退出"这个项目旨在实现一个与微信图片浏览效果类似的图片查看器,具备手势缩放、下拉缩小以及平滑退出的功能。接下来,我们将深入探讨实现这些功能的关键知识点。 首先,我们要...

    android4.0 Gallery相册 源代码

    9. **动画效果**:Gallery还使用` OverscrollDrawable`来处理边缘拖动时的视觉效果,如弹性回弹和拉伸效果。 通过分析和学习`Gallery`的源代码,开发者可以了解到Android UI组件的实现原理,以及如何处理触摸事件、...

    安卓Gallery照片墙画廊图库相关-Android实现左右滑动查看图片效果.rar

    在给定的资源中,“安卓Gallery照片墙画廊图库相关-Android实现左右滑动查看图片效果.rar”提供了一个实现此类功能的示例。 Gallery组件在早期版本的Android API中被广泛用于实现图片浏览,但在API 16之后被替换为...

    安卓Gallery照片墙画廊图库相关-相册加载和图片拖拽本例子加载相册相片效果和添加拍照功能.rar

    【标题】"安卓Gallery照片墙画廊图库相关-相册加载和图片拖拽本例子加载相册相片效果和添加拍照功能.rar" 涉及到的是Android平台上的一个应用示例,主要展示了如何创建一个类似Gallery的照片墙画廊图库,并且实现了...

    android 3D gallery 显示图片

    "android 3D gallery 显示图片"这个主题主要涵盖了如何在Android应用中实现一个可以360度无限滚动展示图片的组件,这种效果通常会给用户带来更丰富的视觉体验。以下将详细介绍实现这一功能的关键知识点。 1. **...

    Gallery可拖动和放大图片

    总的来说,“Gallery可拖动和放大图片”是一个结合了`Gallery`滑动和图片手势操作的实例,它展示了如何在Android应用中实现高效且交互丰富的图片浏览功能。通过深入学习和理解这个示例,开发者可以为自己的应用添加...

    Android图片剪切并存入数据库

    在Android开发中,图片处理是一项常见的任务,尤其是涉及到用户交互时,例如允许用户从相册选取图片或直接通过相机拍摄,然后对图片进行裁剪并存储。本项目"Android图片剪切并存入数据库"正是关注这个场景,下面将...

    GalleryDemo_画廊效果Android源码.zip

    "GalleryDemo"是一个专门用于实现画廊效果的Android源码项目,它为我们提供了一个优雅、流畅的图片浏览解决方案。本文将深入探讨GalleryDemo的核心原理,帮助开发者理解和运用这一组件。 一、Gallery组件介绍 ...

Global site tag (gtag.js) - Google Analytics