1. <?xml version="1.0" encoding="utf-8"?>
  2. <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
  3. android:layout_width="fill_parent"
  4. android:layout_height="fill_parent">
  5. <GridView xmlns:android="http://schemas.android.com/apk/res/android"
  6. android:id="@+id/MyGridView"
  7. android:layout_alignParentTop="true"
  8. android:layout_width="fill_parent"
  9. android:layout_height="wrap_content"
  10. android:layout_marginTop="50dp"
  11. android:columnWidth="90dp"
  12. android:stretchMode="columnWidth"
  13. android:numColumns="auto_fit"
  14. android:horizontalSpacing="10dp"
  15. android:verticalSpacing="10dp"
  16. android:gravity="center">
  17. </GridView>
  18. <TextView android:id="@+id/MyTextView"
  19. android:layout_alignParentBottom="true"
  20. android:layout_width="fill_parent"
  21. android:layout_height="wrap_content"
  22. android:textStyle="bold"
  23. android:text="基于GridView的菜单"
  24. android:textColor="@android:color/white"
  25. android:gravity="center" />
  26. </RelativeLayout>
  27. res/layout/item.xml
    1. <?xml version="1.0" encoding="utf-8"?>
    2. <LinearLayout
    3. xmlns:android="http://schemas.android.com/apk/res/android"
    4. android:orientation="vertical"
    5. android:layout_width="fill_parent"
    6. android:layout_height="wrap_content">
    7. <ImageView
    8. android:id="@+id/ItemImageView"
    9. android:layout_width="fill_parent"
    10. android:layout_height="wrap_content"
    11. android:layout_gravity="center"/>
    12. <TextView
    13. android:id="@+id/ItemTextView"
    14. android:layout_width="fill_parent"
    15. android:layout_height="wrap_content"
    16. android:gravity="center"/>
    17. </LinearLayout>

    GridViewTestActivity.java

    1. package com.zeph.android.gridview;
    2. import java.util.ArrayList;
    3. import java.util.HashMap;
    4. import java.util.List;
    5. import android.app.Activity;
    6. import android.os.Bundle;
    7. import android.view.View;
    8. import android.widget.AdapterView;
    9. import android.widget.AdapterView.OnItemClickListener;
    10. import android.widget.GridView;
    11. import android.widget.SimpleAdapter;
    12. import android.widget.Toast;
    13. public class GridViewTestActivity extends Activity {
    14. private GridView mGridView;
    15. private int[] imageRes = { R.drawable.png1, R.drawable.png2,
    16. R.drawable.png3, R.drawable.png4, R.drawable.png5, R.drawable.png6,
    17. R.drawable.png7, R.drawable.png8, R.drawable.png9 };
    18. private String[] itemName = { "PNG1", "PNG2", "PNG3", "PNG4", "PNG5",
    19. "PNG6", "PNG7", "PNG8", "PNG9" };
    20. @Override
    21. public void onCreate(Bundle savedInstanceState) {
    22. super.onCreate(savedInstanceState);
    23. setContentView(R.layout.main);
    24. mGridView = (GridView) findViewById(R.id.MyGridView);
    25. List<HashMap<String, Object>> data = new ArrayList<HashMap<String, Object>>();
    26. int length = imageRes.length;
    27. for (int i = 0; i < length; i++) {
    28. HashMap<String, Object> map = new HashMap<String, Object>();
    29. map.put("ItemImageView", imageRes[i]);
    30. map.put("ItemTextView", itemName[i]);
    31. data.add(map);
    32. }
    33. SimpleAdapter mSimpleAdapter = new SimpleAdapter(
    34. GridViewTestActivity.this, data, R.layout.item, new String[] {
    35. "ItemImageView", "ItemTextView" }, new int[] {
    36. R.id.ItemImageView, R.id.ItemTextView });
    37. mGridView.setAdapter(mSimpleAdapter);
    38. mGridView.setOnItemClickListener(new GridViewItemOnClick());
    39. }
    40. public class GridViewItemOnClick implements OnItemClickListener {
    41. @Override
    42. public void onItemClick(AdapterView<?> parent, View view, int position,
    43. long id) {
    44. Toast.makeText(getApplicationContext(), position + "",
    45. Toast.LENGTH_SHORT).show();
    46. }
    47. }
    48. }  
            1. 摘自http://blog.csdn.net/benweizhu/article/details/6737062

GridView九宫格菜单实现方式的更多相关文章

  1. Android控件GridView之仿支付宝钱包首页带有分割线的GridView九宫格的完美实现

    Android控件GridView之仿支付宝钱包首页带有分割线的GridView九宫格的完美实现 2015-03-10 22:38 28419人阅读 评论(17) 收藏 举报  分类: Android ...

  2. angular2 递归导航菜单实现方式

    看了网上很多源码,基本都是采用循环三级的方式.如果是无限级的菜单,就无法实现了. 菜单格式: [ { "title": "Item-1", "icon ...

  3. Bootstrap系列 -- 27. 下拉菜单对齐方式

    Bootstrap框架中下拉菜单默认是左对齐,如果你想让下拉菜单相对于父容器右对齐时,可以在“dropdown-menu”上添加一个“pull-right”或者“dropdown-menu-right ...

  4. GridView右键菜单

    一.添加右键菜单 1.在VS工具箱中的“菜单和工具栏”找到ContextMenuStrip控件,双击添加. 2.点击ContextMenuStrip右上方的小三角形,打开编辑项,可以添加菜单项.至于菜 ...

  5. 使用像AdminLTE的前端框架,树形导航菜单实现方式都有哪些?

    之前用easyui等富前端框架开发的时候都是使用封装好的县城的插件,现在使用最新的类似AdminLTE似的前段框架实现树形菜单都用什么方式? 后台拼接html然后前端用JS append方法添加还是直 ...

  6. django实现动态菜单的方式

    1.model from django.contrib.auth.models import User #django自带 class UserProfile(models.Model): " ...

  7. C#开发微信门户及应用(11)--微信菜单的多种表现方式介绍

    在前面一系列文章中,我们可以看到微信自定义菜单的重要性,可以说微信公众号账号中,菜单是用户的第一印象,我们要规划好这些菜单的内容,布局等信息.根据微信菜单的定义,我们可以看到,一般菜单主要分为两种,一 ...

  8. [.Net] C#开发微信门户及应用之微信菜单的多种表现方式介绍

    URL:http://www.it165.net/pro/html/201405/13997.html 在前面一系列文章中,我们可以看到微信自定义菜单的重要性,可以说微信公众号账号中,菜单是用户的第一 ...

  9. Android4.0 -- UI控件之 Menu 菜单的的使用(二)

    上一讲我们讲解了android中在代码或者xml文件中定义菜单,这一讲我们继续来讲解一下定义菜单的其他方式:创建上下文的菜单.查看API文档 Menus :Creating Contextual Me ...

随机推荐

  1. TMsgThread, TCommThread -- 在delphi线程中实现消息循环

    http://delphi.cjcsoft.net//viewthread.php?tid=635 在delphi线程中实现消息循环 在delphi线程中实现消息循环 Delphi的TThread类使 ...

  2. 书写CSS需要注意的地方

    1.注意对图片设置宽高和转化为块2.文字超出的设置3.空白部分用空div来设置4.做之前考虑重用,重用部分命名不要和内容相关 尽量公共(comWidth area small big img list ...

  3. Educational Codeforces Round 4 A. The Text Splitting 水题

    A. The Text Splitting 题目连接: http://www.codeforces.com/contest/612/problem/A Description You are give ...

  4. bzoj 1026 [SCOI2009]windy数 数位dp

    1026: [SCOI2009]windy数 Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://www.lydsy.com/JudgeOnline ...

  5. This implementation is not part of the Windows Platform FIPS validated cryptographic algorithms. 此实现不是 Windows 平台 FIPS 验证的加密算法的一部分 解决方案

    但web启用了md5加密后 有可能出现这样的错误 This implementation is not part of the Windows Platform FIPS validated cryp ...

  6. iOS 2D绘图详解(Quartz 2D)之阴影和渐变(Shadow,Gradient)

    前言:这个系列写道这里已经是第五篇了,本文会介绍下阴影和渐变的基础知识,以及一些基本的Demo Code展示,应该还会有两篇,介绍下Bitmap绘制以及Pattern等知识. Shadow shado ...

  7. iOS开发——测试篇&breakpoints、lldb 和 chisel 的详解

    breakpoints.lldb 和 chisel 的详解 Breakpoints BreakPoint分类 breakpoint也是有分类的,我这里的文章内大致按使用的方式分为了 Normal Br ...

  8. ext3文件系统基础

    http://blog.csdn.net/haiross/article/category/1488205/2   block size: 是文件系统最小的单位,Ext2/Ext3/Ext4 的区块大 ...

  9. sqlserver 行转列 语文,数学,物理,化学

    数据库查询行转列 1.原数据库值 stdname stdsubject result 张三 语文 张三 数学 张三 物理 李四 语文 李四 数学 李四 物理 李四 化学 李四 化学 2.要得到如下表 ...

  10. 看完《Don't make me think》的总结

    寒假在公司实习,然后公司人数比较少,作为一个前端实习生,分工下,就去负责了项目的业务逻辑的梳理以及页面的设计,为了让页面设计的好看,交互性好,便于用户使用,我就快速看了这本薄薄的却很有用的书.书的整体 ...