Android 实现九宫格布局
fmms
13年前
下面我们看看实现的步骤。
1. 一个整体的容器部分。就是上图中包括整个图片项个各个部分,这里我们使用gridView(表格布局)来实现
2.整个界面里需要注意的是 “重复的部分”,就是 各个图片项和,图片下方显示的文字了。那么我们需要描述这个部分。在描述时,要说明图片位于上方,文字位于下方。
3.迭代,或者说重复的将各项 插入(放入)到容器内。
我们看看具体怎么实现。
1.新建一个activity,描述放置我们的容器控件
<GridView android:id="@+id/gridView1" android:layout_width="fill_parent" android:numColumns="auto_fit" android:stretchMode="columnWidth" android:columnWidth="90dp" android:gravity="center" android:layout_height="fill_parent"> </GridView>
在这里需要关注的属性是columnWidth,这里指定了列的宽度,一个列对象,对应一个 “可重复的子项”,这个子项就是我们 的图片项和图片下方文字显示的部分。如果不指定这个宽度的话,默认是每行(展示的行,界面)仅仅只显示一个 “可重复的子项”,而当指定了宽度时,本文指定为90dp,如果每行实际行尺寸大于90,他就会继续将下一个的“可重复的子项”,放置在本行。于是就呈现一种 一行显示多个子项的情况。numColumns属性,指定一个自动填充的值,指示了自动填充行。
2。指定“可重复的子项”,就是需要迭代显示的部分
新建一个布局文件layout_gridview_item.xml
<RelativeLayout android:id="@+id/relativeLayout1" android:layout_width="fill_parent" android:layout_height="wrap_content" xmlns:android="http://schemas.android.com/apk/res/android"> <ImageView android:id="@+id/imageView_ItemImage" android:layout_width="wrap_content" android:src="@drawable/icon" android:layout_height="wrap_content" android:layout_centerHorizontal="true" > </ImageView> <TextView android:id="@+id/textView_ItemText" android:text="TextView" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_below="@+id/imageView_ItemImage" android:layout_centerHorizontal="true" > </TextView> </RelativeLayout>
这里使用了一个相对布局,在TextView 里使用属性android:layout_below="@+id/imageView_ItemImage"
指示了文本在图片的下方。
3.剩下的就是数据绑定了。上代码:
protected void onCreate(Bundle savedInstanceState) { // TODO Auto-generated method stub super.onCreate(savedInstanceState); setContentView(R.layout.layout_main); _gridView1 = (GridView)findViewById(R.id.gridView1); ArrayList<HashMap<String,Object>> lst = new ArrayList<HashMap<String,Object>>(); for(int i = 0 ;i < 10; i++) { HashMap<String,Object> map = new HashMap<String,Object>(); map.put("itemImage", R.drawable.icon); map.put("itemText", "item"+i); lst.add(map); } SimpleAdapter adpter = new SimpleAdapter(this, lst,R.layout.layout_gridview_item, new String[]{"itemImage","itemText"}, new int[]{R.id.imageView_ItemImage,R.id.textView_ItemText}); _gridView1.setAdapter(adpter); _gridView1.setOnItemClickListener(new gridView1OnClickListener()); }
先构建ArrayList作为数据源,在构建SimpleAdapter 作为数据适配器,为gridView指定适配器对象。注意在构建适配器对象的参数,如下:
SimpleAdapter adpter = new SimpleAdapter(this, lst,R.layout.layout_gridview_item, //指定 子项的布局文件的ID new String[]{"itemImage","itemText"}, //指定 数据的列 new int[]{R.id.imageView_ItemImage,R.id.textView_ItemText}); //指定数据的列对应到的 绑定的目标控件
那么如何获得选择的项呢?就是上面的gridView1OnClickListener的实现内容如下:
class gridView1OnClickListener implements OnItemClickListener { public void onItemClick(AdapterView<?> arg0, View arg1, int arg2, long arg3) { // TODO Auto-generated method stub Object obj = _gridView1.getAdapter().getItem(arg2); HashMap<String,Object> map = (HashMap<String,Object>)obj; String str = (String) map.get("itemText"); Toast.makeText(getApplicationContext(), ""+str, 0).show(); } }至此完成。
源码下载: loginproj.rar 转自:http://www.cnblogs.com/vir56k/archive/2011/06/16/2082688.html