Gallery控件初体验——简单的相册
?
初学android,学着做了一个小例子,例子非常简单,就是用Gallery实现一个简单的相册,由于我是初学者,所以我遇到的问题可能也是初学者也会遇到的问题,在完成这个小例子过程中遇到了很多意想不到的问题,最后借助网络都解决了,现在把我做的这个小例子拿出分享给各位初学者!我做了尽可能详细的注释,我想一定会对初学者有所帮助!由于初学android,例子也是超级简单,路过的各位大侠请勿见笑!
Gallery:即图片浏览控件
layout部分:
?
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
?? ?android:orientation="vertical"
?? ?android:layout_width="fill_parent"
?? ?android:layout_height="fill_parent" >
?
?? <Gallery android:id="@+id/gallery"
?? ? ? ? ? ?android:layout_width="fill_parent"
?? ? ? ? ? ?android:layout_height="wrap_content"
?? ? ? ? ? ?>
?? </Gallery>
?? <ImageView android:id="@+id/img_show"
?? ? ? ? ? ? ?android:layout_width="wrap_content"
?? ? ? ? ? ? ?android:layout_height="wrap_content">
??</ImageView> ? ??
</LinearLayout>
?
代码部分:
主类部分代码:
GalleryActivity类
?
package com.google.android.test;
?
?
import android.app.Activity;
import android.os.Bundle;
import android.view.View;
import android.widget.AdapterView;
import android.widget.Gallery;
import android.widget.ImageView;
import android.widget.Toast;
?
public class GalleryActivity extends Activity {
/*定义要使用的对象*/
private Gallery gallery;
private ImageView imageView;
private ImageAdapter imageadapter;
@Override
public void onCreate(Bundle savedInstanceState){
super.onCreate(savedInstanceState);
setContentView(R.layout.gallery);
/* 通过findViewById 取得 资源对象*/
gallery=(Gallery)this.findViewById(R.id.gallery);
imageView=(ImageView)findViewById(R.id.img_show);
/*给Gallery设置适配器 把GalleryActivity类传入参数*/
imageadapter=new ImageAdapter(this);
gallery.setAdapter(imageadapter);
/*设置Gallery的点击事件监听器*/
gallery.setOnItemClickListener(new Gallery.OnItemClickListener(){?
@Override ?
public void onItemClick(AdapterView<?> parent, View v, int position, long id) {?
// TODO Auto-generated method stub
/*设置大图片*/
imageView.setBackgroundResource(imageadapter.mImageIds[position]);
/*显示该图片是几号*/
Toast.makeText(GalleryActivity.this,"你选择了"+(position)+"号图片",Toast.LENGTH_SHORT).show();
}
});
}
?
}
?
ImageAdapter 类
?
package com.google.android.test;
?
import android.content.Context;
import android.util.Log;
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{
/*变量声明*/
?? private Context mContext;//上下文
?? /* 构建一Integer array 并取得预加载Drawable 的图片id */
?? public Integer[] mImageIds={
R.drawable.img1, ?
R.drawable.img2,
R.drawable.img3,
R.drawable.img4,
R.drawable.img5
?? };
?? /*自定义的构造方法*/
?? public ImageAdapter(Context c){
// TODO Auto-generated constructor stub
? this.mContext=c;
?? }
?? @Override
?? /* 重写的方法getCount,返回图片数目 */
?? public int getCount(){
// TODO Auto-generated constructor stub
? return mImageIds.length;//获取图片的个数?
?? }
?? @Override
?? /* 重写的方法getItemId,返回图像的数组id */
?? public Object getItem(int position){
// TODO Auto-generated constructor stub
? return position;//获取图片在库中的位置
?? }
?? @Override
?? public long getItemId(int position){
// TODO Auto-generated constructor stub
? return position;//获取图片在库中的位置 ?
?? }
?? @Override
?? /* 重写的方法getView,返回一View 对象 */
?? public View getView(int position,View convertView,ViewGroup parent){
// TODO Auto-generated constructor stub
? Log.i("Tag", position+"");
? /* 产生ImageView 对象 */
? ImageView imageView=new ImageView(mContext);
? /* 设置图片给imageView 对象 */
? imageView.setImageResource(mImageIds[position]);
? /* 重新设置Layout 的宽高 */
? imageView.setLayoutParams(new Gallery.LayoutParams(128,128));
? /* 重新设置图片的宽高 */
? imageView.setScaleType(ImageView.ScaleType.FIT_CENTER);
? /* 返回imageView 对象 */
? return imageView;
?? }
}
?
?