Android开发(2) - 九宫格的实现

前言

在程序中经常会遇到九宫格的样式实现,如下图:

下面我们看看实现的步骤。

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

至此完成。
代码下载

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 206,482评论 6 481
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 88,377评论 2 382
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 152,762评论 0 342
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 55,273评论 1 279
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 64,289评论 5 373
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,046评论 1 285
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,351评论 3 400
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,988评论 0 259
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 43,476评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,948评论 2 324
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,064评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,712评论 4 323
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,261评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,264评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,486评论 1 262
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,511评论 2 354
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,802评论 2 345

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 171,510评论 25 707
  • 问答题47 /72 常见浏览器兼容性问题与解决方案? 参考答案 (1)浏览器兼容问题一:不同浏览器的标签默认的外补...
    _Yfling阅读 13,728评论 1 92
  • 选择qi:是表达式 标签选择器 类选择器 属性选择器 继承属性: color,font,text-align,li...
    love2013阅读 2,303评论 0 11
  • 不知何时,知识付费成了风口,恨不得楼下煎饼摊的老板都能开几趟课《小学文化如何做到月入两万》、《21 天带你养成早起...
    CodyYang阅读 222评论 0 2
  • 8月21日是学校的开放日,还以为开放日就是打开大门随便参观,可是事实证明又搞错了。开放日,我们除了知道天天所...
    百合兔子阅读 237评论 0 1