欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  移动技术

Android编程简单实现九宫格示例

程序员文章站 2023-11-07 15:39:16
本文实例讲述了android编程简单实现九宫格。分享给大家供大家参考,具体如下: 实现的步骤 1. 一个整体的容器部分。就是上图中包括整个图片项个各个部分,这里我们...

本文实例讲述了android编程简单实现九宫格。分享给大家供大家参考,具体如下:

Android编程简单实现九宫格示例

实现的步骤

1. 一个整体的容器部分。就是上图中包括整个图片项个各个部分,这里我们使用gridview(表格布局)来实现

2.整个界面里需要注意的是 “重复的部分”,就是 各个图片项和,图片下方显示的文字了。那么我们需要描述这个部分。在描述时,要说明图片位于上方,文字位于下方。

3.迭代,或者说重复的将各项 插入(放入)到容器内。
需要添加/修改3个文件:main.xml、meunitem.xml、activity

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>

在这里需要关注的属性是columnwidth,这里指定了列的宽度,一个列对象,对应一个 “可重复的子项”,这个子项就是我们 的图片项和图片下方文字显示的部分。如果不指定这个宽度的话,默认是每行(展示的行,界面)仅仅只显示一个 “可重复的子项”,而当指定了宽度时,本文指定为90dp,如果每行实际行尺寸大于90,他就会继续将下一个的“可重复的子项”,放置在本行。于是就呈现一种 一行显示多个子项的情况。numcolumns属性,指定一个自动填充的值,指示了自动填充行。

2。指定“可重复的子项”,就是需要迭代显示的部分

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);
  }
});
}

更多关于android相关内容感兴趣的读者可查看本站专题:《android开发入门与进阶教程》、《android调试技巧与常见问题解决方法汇总》、《android基本组件用法总结》、《android视图view技巧总结》、《android布局layout技巧总结》及《android控件用法总结

希望本文所述对大家android程序设计有所帮助。