GridView跟ListView一样是多控件布局。实现九宫图是最方便的。

还是先看看图,没图说个鸡鸡是不是


如上图,是一种应用方式,在每个格子里面,放入应用图标,和显示应用的名字在下方。

下面先看看布局文件:

activity_hello_world.xml

<?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:verticalSpacing="10dp"      android:horizontalSpacing="10dp"      android:columnWidth="90dp"      android:stretchMode="columnWidth"      android:gravity="center"  />  
现在说说一些新的属性:

这里dp相关知识可以看看Android长度相关

android:numColumns="auto_fit" 设置为自动适应屏幕宽度,上图只能摆放3个
android:verticalSpacing="10dp" 两行之间的间距是10像素
android:horizontalSpacing="10dp" 两列之间的间距为10像素
android:columnWidth="90dp" 每一列的宽度
android:stretchMode="columnWidth" 缩放与列宽的大小同步
android:gravity="center" 空间显示的位置是中间

我们再来看看代码:

HelloWorldActivity.java

package com.fable.helloworld; import android.app.Activity;  import android.os.Bundle;   import android.widget.GridView;import android.widget.SimpleAdapter; import java.util.*;public class HelloWorldActivity extends Activity {      @Override      public void onCreate(Bundle savedInstanceState) {       super.onCreate(savedInstanceState);        setContentView(R.layout.activity_hello_world);  //设置主布局文件        GridView gridview = (GridView) findViewById(R.id.gridview);                  //创造数据来源        ArrayList<HashMap<String, Object>> images = 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.ic_launcher);//添加图像资源的ID,标识符,值        map.put("ItemText", "应用"+String.valueOf(i));//按序号做ItemText,标识符,值          images.add(map);          }          //把数据传入适配器,转换成布局需要的数据        SimpleAdapter simpleAdapter = new SimpleAdapter(this, //上下文为当前Activity        images,//数据来源           R.layout.my_list_item,//每一项的布局的XML实现            new String[] {"ItemImage","ItemText"},//动态数组与ImageItem对应的子项         new int[] {R.id.ItemImage,R.id.ItemText});  //ImageItem的XML文件里面的一个ImageView,两个TextView ID          //添加并且显示          gridview.setAdapter(simpleAdapter);       }     }
可以这里使用了SimpleAdapter,用法跟ListView一样。对于ListView中SimpleAdapter的用法,可以看 这里。

其实过程是很简单,就是把源数据,转换成适配器的数据,然后把适配器设置到gridView就行了。

跟ListView一样,每一项的布局内也是要一个布局文件的。

my_list_item.xml

<?xml version="1.0" encoding="utf-8"?>  <RelativeLayout            xmlns:android="http://schemas.android.com/apk/res/android"            android:layout_height="wrap_content"            android:paddingBottom="4dip" android:layout_width="fill_parent">           <ImageView                  android:layout_height="wrap_content"                  android:id="@+id/ItemImage"                  android:layout_width="wrap_content"                  android:layout_centerHorizontal="true">            </ImageView>           <TextView                  android:layout_width="wrap_content"                  android:layout_below="@+id/ItemImage"                  android:layout_height="wrap_content"                  android:text="TextView01"                  android:layout_centerHorizontal="true"                  android:id="@+id/ItemText">           </TextView>  </RelativeLayout>  
这里ItemText设置在ItemImage下面,两个都是垂直居中。








更多相关文章

  1. mybatisplus的坑 insert标签insert into select无参数问题的解决
  2. python起点网月票榜字体反爬案例
  3. NPM 和webpack 的基础使用
  4. 【阿里云镜像】使用阿里巴巴DNS镜像源——DNS配置教程
  5. 读取android手机流量信息
  6. android 使用html5作布局文件: webview跟javascript交互
  7. 《Android开发从零开始》——25.数据存储(4)
  8. Android(安卓)多媒体扫描过程(Android(安卓)Media Scanner Proces
  9. Android系统配置数据库注释(settings.db)

随机推荐

  1. Windows下mysql5.7.18安装配置教程
  2. mysql中格式化数字详解
  3. Mysql事务操作失败如何解决
  4. mysql报错:Deadlock found when trying to
  5. 阿里云Linux CentOS 7.2下自建MySQL的roo
  6. Mybatis特殊字符处理的详解
  7. MySql索引详细介绍及正确使用方法
  8. windows server2014 安装 Mysql Applying
  9. MySQL 5.7解压版安装、卸载及乱码问题的
  10. MySql带OR关键字的多条件查询语句