本文来自肥宝传说之路,引用必须注明出处!
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下面,两个都是垂直居中。