Android:(8)GridView与ImageView

本文探讨了Android中GridView组件的使用,包括其与表格界面的相似性,以及如何通过自定义Adapter来展示图像内容。通过实例代码展示了如何配置GridView属性,构建SimpleAdapter和ImageAdapter,并将Adapter应用到GridView中。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

简单一点吧,就瞧瞧那个Grid的效果,Android提供了一个GridView,不过从APIDemo中看来,它似乎与PC上的GRID差别还是挺大的,更像那个IconView的感觉。不知道Android中如何实现表格界面?虽然在移动终端上,表格一般不会有谁使用,大家似乎更倾向于使用ListView,而Android对于ListView则有更简单的实现ListActivity。

废话不说,还是自己写几句代码来实验一下。

<GridView id="@+id/grid" android:layout_width="fill_parent" android:layout_height="fill_parent" android:padding="10dip" android:verticalSpacing="10" android:horizontalSpacing="10" android:numColumns="auto_fit" android:columnWidth="60" android:stretchMode="columnWidth" android:gravity="center" />

从描述文件中的这些属性来看,与表格非常类似,除了padding和spacing以外,它还多了那个gravity,这里是center表示单元格中的内容居中放,在类GridView中也提供了方法setGravity(int)来实现这个效果。

接着,我们沿用以前那个fillMaps方法来构造SimpleAdapter,以前将这个adapter赋给ListActivity,现在同样的Adapter,却是赋给了GridView,效果又会是怎样呢?

List<HashMap<String, String>> items = fillMaps(); GridView grd=(GridView)this.findViewById(R.id.grid); SimpleAdapter adapter=new SimpleAdapter(this,items,R.layout.list_row,new String[]...{"name"},new int[]...{R.id.item}); grd.setAdapter(adapter);

我觉得GridView并不象表格,倒更象IconView,下面试试用图像作为GridView的内容。现在,不能用简单Adapter了,得自己弄一个ImageAdapter,就让它衍生于BaseAdapter类吧。

public class ImageAdapter extends BaseAdapter ...{ //这是资源ID的数组 private Integer[] mThumbIds = ...{ R.drawable.a,R.drawable.b,R.drawable.c, R.drawable.d,R.drawable.e,R.drawable.f, R.drawable.g,R.drawable.h,R.drawable.i }; public ImageAdapter(Context c) ...{ mContext = c; } public int getCount() ...{ return mThumbIds.length; } public Object getItem(int position) ...{ return position; } public long getItemId(int position) ...{ return position; } public View getView(int position, View convertView, ViewGroup parent) ...{ ImageView i = new ImageView(mContext); //设置图像源于资源ID。 i.setImageResource(mThumbIds[position]); i.setAdjustViewBounds(true); i.setBackground(android.R.drawable.picture_frame); return i; } private Context mContext; }

很简单,只要重载几个方法就可以了,关键是那个getView方法,它负责构建出每个单元格中的对象实例。这里我们构造的是一个ImageView实例。

然后就是同样的将这个Adapter赋给GridView即可,大家可以看看效果,注意在做这个例子前,先放几个小图片到res/drawable目录下,buildproject一下就可以得到那个R.drawable.a了(这里的a是图像文件名,如a.png)。

在getView方法中我们使用了ImageView类,这又是一个widget。除了上面用到的几个方法以外,还有以下几个方法值得注意:

与图像来源有关的方法,我们只用了资源文件的方式。

//不同的图像来源 public void setImageBitmap(Bitmap bm) public void setImageDrawable(Drawable drawable) public void setImageResource(int resid) public void setImageURI(ContentURI uri) 图像效果的操作。 //颜色过滤 public void setColorFilter(int color, Mode mode) //矩阵变换 public void setImageMatrix(Matrix matrix) //透明度 public void setAlpha(int alpha)

具体的使用可以参考API,动手试一下就差不多了。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值