Android新手入门2016(10)--GridView

本文来自肥宝传说之路,引用必须注明出处!

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下面,两个都是垂直居中。








  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值