Android百日程序:GridView实现相册效果

本章使用GridView控件来做一个相册效果。

图片效果如下:

响应点击事件,点击的时候提示是当前第几章图片,从左到右,从上到下。

点击了第一张图片,显示了1.

步骤:

一 新建项目,然后把图片资源拷贝到res/drawable/文件夹中,如果没有drawable这个文件夹也不要紧,可以直接新建这个文件夹,然后在Eclipse项目中刷新,就会在项目中显示出来了

二 然后在Layout的界面xml文件activity_main.xml(当然也可以随意自己喜欢命名),输入如下代码:

<?xml version="1.0" encoding="utf-8"?>
<GridView xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@+id/gridview"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:columnWidth="90dp"
    android:numColumns="auto_fit"
    android:verticalSpacing="10dp"
    android:horizontalSpacing="10dp"
    android:stretchMode="columnWidth"
    android:gravity="center"
/>

没什么特别的,就是设置好行宽,然后自动排好行数numColumns="auto_fit",这个好像是Android自动排列的。

三 activity_main.xml对应的java文件MainActivity.java输入逻辑代码,主要是修改onCreate这个函数就可以了,其他就默认可以了,不用管:

	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.activity_main);

		GridView gridview = (GridView) findViewById(R.id.gridview);
		gridview.setAdapter(new ImageAdapter(this));

		gridview.setOnItemClickListener(new OnItemClickListener() {
			public void onItemClick(AdapterView<?> parent, View v,
					int position, long id) {
				Toast.makeText(MainActivity.this, "" + (position+1),
						Toast.LENGTH_SHORT).show();
			}
		});
	}

主要是设置好监听GridView对象的ItemClickListener就可以了。Toast可以理解为一个轻量的提示对话框,就是上图中显示1的一个小对话框,显示大概1秒多就自动消失。

小技巧:

不知道对象属于那些头文件?例如OnItemClickListener是属于什么文件库啊?

这个有时候是个头疼的问题,尤其是使用VC写C++的时候,需要自己动手去查,头疼的是,查到了这个函数,或者类之后,居然没提示需要include什么头文件,不过到了Java,似乎那都不是事了,一个快捷键搞定了:ctrl+shift+o;那么就会全自动包括所有需要的库了。

四 之后创建一个Java类,放在MainActivity.java一个目录下,然后添加代码:

package su.gridview.hellogridview;

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

public class ImageAdapter extends BaseAdapter {
	private Context mContext;

	public ImageAdapter(Context c) {
		mContext = c;
	}

	public int getCount() {
		return mThumbIds.length;
	}

	public Object getItem(int position) {
		return null;
	}

	public long getItemId(int position) {
		return 0;
	}

	// create a new ImageView for each item referenced by the Adapter
	public View getView(int position, View convertView, ViewGroup parent) {
		ImageView imageView;
		if (convertView == null) { // if it's not recycled, initialize some
									// attributes
			imageView = new ImageView(mContext);
			imageView.setLayoutParams(new GridView.LayoutParams(85, 85));
			imageView.setScaleType(ImageView.ScaleType.CENTER_CROP);
			imageView.setPadding(8, 8, 8, 8);
		} else {
			imageView = (ImageView) convertView;
		}

		imageView.setImageResource(mThumbIds[position]);
		return imageView;
	}

	// references to our images
	private Integer[] mThumbIds = { R.drawable.x0, R.drawable.x1,
			R.drawable.x2, R.drawable.x3, R.drawable.x4, R.drawable.x5,
			R.drawable.x10, R.drawable.x9, R.drawable.x8, R.drawable.x7,
			R.drawable.x6, R.drawable.x5, R.drawable.x11, R.drawable.x20,
			R.drawable.x13, R.drawable.x14, R.drawable.x15, R.drawable.x16,
			R.drawable.x17, R.drawable.x18, R.drawable.x19, R.drawable.x20 };
}

本例没用的函数都是因为必须需要复写BaseAdapter类的。

主要使用了getCount和getView这两个函数。按照他的样式实现就可以了,具体的低层工作就是由Adapter类自动调用的,调用getCount,Adapter就知道有多少资源对象需要显示了,调用getView就可以把图片资源显示出来,其中传入convertView是为了加速,复用之前用过的View。

这个是我的理解,更加详细的原理还有待有空参考一下源代码吧。

参考资料:http://developer.android.com/guide/topics/ui/layout/gridview.html

第二章完成,感觉Android写程序实在是太方便了,难怪Android大行其道啊,对比一个DirectX这些API的用法,简直就是傻瓜式的。尤其令我想起之前使用Direct2D,微软真的傻了,都什么年头了,居然还出Direct2D这么难用的API。呵呵,别说我黑微软;最近听说VC居然要支持Android了,感觉微软是低下了高贵的头了,支持了竞争对手的东西;同时也想赶上Android的步伐,不是牺牲色相啊。战略需要,是应该低下头的。

时间: 2024-11-02 12:51:46

Android百日程序:GridView实现相册效果的相关文章

Android百日程序:使用Intent回传结果

本章使用Intent,回传需要的结果: 流程: 启动主页->按下按键启动第二个activity->输入用户名,按下OK按键->回传用户名回主页->主页读取用户名并显示出来. 1 启动主页图: 2 启动第二个activity 3 输入用户名: 4 回传到主页,读取并显示: 新建项目,然后输入对应的代码就OK了. 1 主页界面代码(activity_main.xml): <LinearLayout xmlns:android="http://schemas.androi

Android百日程序:进度条对话框实现

显示由Activity管理的dialog. 这种dialog有多种多样,其中比较常见的是loading的时候,显示的一个loading进度条. Android显示这样的进度条还是非常方便的,因为有现成的模块可以调用. 首先看看本程序的效果吧: 1 主界面: 2 点击这个按钮之后,显示: 进度条到了100的时候就会自动关闭,当然这里是模拟下载,真实的下载算法还需要继续完善,不过也是很简单的算法了,不算是难点. 点击Cancel或者OK按钮也可以调用函数,进行有需要的操作,这里直接显示一个Toast

Android百日程序: Fragment动态管理和生命期

之前写过Fragment使用的程序,Fragment可以静态,也可以动态载入内存中的,这一章进一步看看如何动态地更换Fragment和看看Fragment生命期都有什么函数. 本章利用响应菜单点击事件,轮流载入不同的Fragment,显示不同的界面,效果如下: 开始的是没有载入Fragmen为空白: 点击菜单的NEXT FRAGMENT VIEW,就进入下一个界面,载入两个: 继续点击显示Fragment 1: 继续点击,显示Fragment2: 然后就是循环了: 如此循环显示不同画面. 一 首

Android百日程序 开篇章:Intent打开网页

学习一下人家100日写100个网页的做法,我也用100日写100个完整的Android程序. 这些程序的最基本要求: 1 完整性-每个程序都必须是独立可运行的 2 不重复性-所用的重点知识点都不一样 开篇章: --本章参考书本:Hello Android 编写一个简单的页面,如下,图1: 在文本框输入网址,图2: 点击按钮GO,然后就可以打开这个网站了, 图3: 步骤: 一  首先,新建一个项目,具体参数设置可以参照我的项目设置,如下: 主要看 1 src下的Browser.java:主要的ja

Android百日程序: Activity的生命期

到了Android 4 的activity的生命期内的函数有7个,变得十分复杂,完善.故此要掌握好Activity的各个函数,知道应该在那个函数写什么逻辑代码. 本篇博客写个小程序测试一下activity的声明周期如何运作. 首先总结一下: 1 onCreate():activyt第一次创建的时候调用,还可能在改activity在onStop或者onPauce状态下被系统自动释放,那么当用户需要继续回到改activity的时候,也会调用这个onCreate()函数 2 onStart():当改a

Android百日程序:嵌入Fragment

Fragment相当于一个小型activity,因为Fragment可以实现activity中所有的功能,不同的是Fragment可以嵌入activity,一个activity可以有多个Fragment,而且可以运行时根据需要切换Fragment,达到可以适应不同屏幕大小等目的需要. 本章来看看如何在activity中嵌入Fragment的方法,有静态和动态方法的. 静态方法就是使用xml直接嵌入,动态就是在Java代码中嵌入. 方法: 1 按照默认设置新建项目 2 新建一个类命名为Fragme

Android百日程序:Intent传递数据

上一遍是回传数据,当热Activity之间是可以利用Intent很方便地传递很多数据的. 本章就两个Activity之间传递String和Int数据. 1 主要界面: 2 点击按钮之后,就进入第二个activity 这个时候会利用Toast机制显示第一个activity传递什么String和Int给第二个activity. 3 然后点击"return to main activity",回到第一个activity 同样会显示回传的信息 这样可以在activity之间来回传递需要的信息.

Android百日程序:高效载入大图片

问题:如果图片很大,全部载入内存,而显示屏又不大,那么再大的图片也不会提高视觉效果的,而且会消耗无谓的内存. 解决办法就是根据实际需要多大的图片,然后动态计算应该载入多大的图片:但是因为不太可能图片大小和实际需要的大小一致,故此需要载入图片大小为一个2的某次方的值,而大于实际需要的大小. 如图,载入一个微缩图大小为100*100 新建一个项目, 参考Google上的方法:http://developer.android.com/training/displaying-bitmaps/load-b

进阶三之Android UI介面之(滑动效果之Gallery + GridView)

人一生下就会哭,笑是后来才学会的.所以忧伤是一种低级的本能,而快乐是一种更高级的能力. 本讲内容:滑动效果之Gallery + GridView Android系统自带一个GridView和Gallery两个控件,GridView网格显示,Gallery单个浏览,两者结合起来可以真正实现Gallery浏览图片效果. 示例效果图         下面是res/layout/activity_main.xml 布局文件: <?xml version="1.0" encoding=&q