很久没有进行我的Android学习之旅了,今天抽空继续。
简单一点吧,就瞧瞧那个Grid的效果,Android提供了一个GridView,不过从APIDemo中看来,它似乎与PC上的GRID差别还是挺大的,更像那个IconView的感觉。不知道Android中如何实现表格界面?虽然在移动终端上,表格一般不会有谁使用,大家似乎更倾向于使用ListView,而Android对于ListView则有更简单的实现ListActivity。
废话不说,还是自己写几句代码来实验一下。
<GridViewid="@+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();
GridViewgrd=(GridView)this.findViewById(R.id.grid);
SimpleAdapteradapter=newSimpleAdapter(this,items,R.layout.list_row,newString[]...{"name"},newint[]...{R.id.item});
grd.setAdapter(adapter);
我觉得GridView并不象表格,倒更象IconView,下面试试用图像作为GridView的内容。现在,不能用简单Adapter了,得自己弄一个ImageAdapter,就让它衍生于BaseAdapter类吧。
publicclassImageAdapterextendsBaseAdapter...{
//这是资源ID的数组
privateInteger[]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
};
publicImageAdapter(Contextc)...{
mContext=c;
}
publicintgetCount()...{
returnmThumbIds.length;
}
publicObjectgetItem(intposition)...{
returnposition;
}
publiclonggetItemId(intposition)...{
returnposition;
}
publicViewgetView(intposition,ViewconvertView,ViewGroupparent)...{
ImageViewi=newImageView(mContext);
//设置图像源于资源ID。
i.setImageResource(mThumbIds[position]);
i.setAdjustViewBounds(true);
i.setBackground(android.R.drawable.picture_frame);
returni;
}
privateContextmContext;
}
很简单,只要重载几个方法就可以了,关键是那个getView方法,它负责构建出每个单元格中的对象实例。这里我们构造的是一个ImageView实例。
然后就是同样的将这个Adapter赋给GridView即可,大家可以看看效果,注意在做这个例子前,先放几个小图片到res/drawable目录下,buildproject一下就可以得到那个R.drawable.a了(这里的a是图像文件名,如a.png)。
在getView方法中我们使用了ImageView类,这又是一个widget。除了上面用到的几个方法以外,还有以下几个方法值得注意:
与图像来源有关的方法,我们只用了资源文件的方式。
//不同的图像来源
publicvoidsetImageBitmap(Bitmapbm)
publicvoidsetImageDrawable(Drawabledrawable)
publicvoidsetImageResource(intresid)
publicvoidsetImageURI(ContentURIuri)
图像效果的操作。
//颜色过滤
publicvoidsetColorFilter(intcolor,Modemode)
//矩阵变换
publicvoidsetImageMatrix(Matrixmatrix)
//透明度
publicvoidsetAlpha(intalpha)
具体的使用可以参考API,动手试一下就差不多了。
分享到:
相关推荐
Android高级应用源码-GridView添加图片DeleteGridView0.2.zip
Android高级应用源码-gridview最新版本.zip
Android项目实战--手机卫士06--GridView的优化与修改Button的显示样式
Android高级应用源码-gridview分页效果.zip
Android格子视图,即GridView详解。
Android 学习笔记(十三):Activity-GridView
GridView系列---GridView固定表头
GridView系列---GridView分页
android 网格组件9宫格,GridView展示数据 3*3排列显示。鼠标点击其中一个网格 会触发事件,并传递参数
源码参考,欢迎下载
GridView系列---GridView合并表头
android-GridView显示图片点击放大,本人亲测,可以使用,放心下载吧!!
介绍Android中gridview和imageview的部分属性
Swipe-to-Select-GridView ,Swipe-to-Select-GridView 是一个基于 UICollectionView 的 ...
GridView.zip
Android--开发--ActivityGroup + GridView + ViewFlipper 实现选项卡
实例>--gridview使用大全 里面关于gridview的使用讲的比较详细,且附有实现代码 word格式
•Android---UI篇---GridView(网格布局) • •Android---UI篇---Gallery(画廊视图) • •Android---UI篇---Spinner(下拉列表) • •Android---UI篇---TabWidget(切换卡) • •Android---UI篇---LinearLayout...