本文需要添加/修改3个文件:main.xml、meunitem.xml、Java源代码。

main.xml源代码如下,本身是个GirdView,用于装载Item:

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

介绍一下里面的某些属性:

android:numColumns="auto_fit" ,GridView的列数设置为自动

android:columnWidth="90dp",每列的宽度,也就是Item的宽度
android:stretchMode="columnWidth",缩放与列宽大小同步
android:verticalSpacing="10dp",两行之间的边距,如:行一(NO.0~NO.2)与行二(NO.3~NO.5)间距为10dp
android:horizontalSpacing="10dp",两列之间的边距。


接下来介绍 meunitem.xml,这个XML跟前面ListView的ImageItem.xml很类似:

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
>
<ImageView android:layout_width="wrap_content"
android:id="@+id/ItemImage"
android:layout_height="wrap_content"
android:layout_centerHorizontal="true"/>
<TextView android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_below="@+id/ItemImage"
android:id="@+id/ItemText"
android:layout_centerHorizontal="true"
/>
</RelativeLayout>

最后是JAVA的源代码

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

GridView gridview = (GridView) findViewById(R.id.GridView);
ArrayList<HashMap<String, Object>> meumList = new ArrayList<HashMap<String, Object>>();

for(int i = 1;i < 10;i++) {
HashMap<String, Object> map = new HashMap<String, Object>();
map.put("ItemImage", R.drawable.icon);
map.put("ItemText", "NO."+i);
meumList.add(map);
}

SimpleAdapter saMenuItem = new SimpleAdapter(this,
meumList, //数据源
R.layout.menuitem, //xml实现
new String[]{"ItemImage","ItemText"}, //对应map的Key
new int[]{R.id.ItemImage,R.id.ItemText}); //对应R的Id

//添加Item到网格中
gridview.setAdapter(saMenuItem);
gridview.setOnItemClickListener(new OnItemClickListener() {
public void onItemClick(AdapterView<?> arg0, View arg1, int arg2,long arg3) {
System.out.println("click index:"+arg2);
}
}
);
}

附上

效果图:
源代码下载: GirdViewDemo

更多相关文章

  1. Android(安卓)Ant更新项目
  2. Android的源代码结构
  3. 在Ubuntu上下载、编译和安装Android最新内核源代码(Linux Kernel)
  4. Android(安卓)studio开发找不到HttpClient问题
  5. Android之HorizontalScrollView(一)
  6. Android中Intent对应的category列表大全 .
  7. Android名称、版本和API level的对应关系
  8. Android版本和API Level对应关系
  9. android socket通信

随机推荐

  1. 【Android文档】Android界面绘制流程----
  2. android中搭建phonegap开发环境
  3. xmlns:android作用以及自定义布局属性
  4. Android核心技术与实例详解(第2版)
  5. Android源码树添加新的APP(含第三方so、ja
  6. android自带的drawable图标ico名称对应表
  7. android Mainifest权限设置清单
  8. Android dp方式的屏幕适配工具使用(Andro
  9. android 安装和卸载程序
  10. android排版布局学习