Android入门(13)——GridView使用汇总

原创 2015年07月06日 20:11:08

1. GridView用于在界面上按行、列分布的方式来显示多个组件,与ListView的区别是,它可以显示类似表格的样式,而后者是一行一行的。

 


 

2. 课程目标:关于适配器SimpleAdapter。

 


 

3. 具体实现,这里先设置适配器,将数据源的内容加载到GridView中:

 

第一步:新建一个名叫item的布局文件来设置GridView中每一项的布局:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical"
    android:gravity="center" 
    android:background="#000000">
    
    <ImageView 
        android:src="@drawable/ic_launcher"
        android:layout_width="60dp"
        android:layout_height="60dp"
        android:id="@+id/image"
        />
    <TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:id="@+id/text"
        android:layout_marginTop="5dp"
        android:textColor="#ffffff"
        android:text="文字"
        />


</LinearLayout>
第二步:设置MainActivity文件:

package com.example.grideview;

import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

import android.os.Bundle;
import android.app.Activity;
import android.view.Menu;
import android.widget.GridView;
import android.widget.SimpleAdapter;

public class MainActivity extends Activity {

	private GridView gridView;
	private List<Map<String,Object>>dataList;
	private int[] icon={R.drawable.ic_launcher,R.drawable.ic_launcher,R.drawable.ic_launcher,// 这里暂且就用相同的图片了。
			R.drawable.ic_launcher,R.drawable.ic_launcher,R.drawable.ic_launcher,
			R.drawable.ic_launcher,R.drawable.ic_launcher,R.drawable.ic_launcher,
			R.drawable.ic_launcher,R.drawable.ic_launcher,R.drawable.ic_launcher};
	private String[] iconname = {"通讯录","日历","照相机","时钟","游戏","短信","铃声",
			"设置","语音","天气","浏览器","视频"};
	private SimpleAdapter adapter;
	
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);
        
        gridView = (GridView) findViewById(R.id.gridView);
        /*
         * 1.准备数据源
         * 2.新建适配器(SimpleAdapter)
         * 3.GridView加载适配器
         * 4.GridView配置事件监听器(OnItemClickListener)
         * */ 
        dataList = new ArrayList<Map<String,Object>>();
        // getData(); 和下面这个函数中的重复了
        adapter = new SimpleAdapter(
        		this, 				// 上下文
        		getData(), 			// 数据源
        		R.layout.item, 			// 单个项布局文件
        		new String[]{"image","text"}, 	// from:给布局文件中的控件设置的Map中的键名
        		new int[]{R.id.image,R.id.text}	// to:对应的是布局文件中的控件的id
        		);
        gridView.setAdapter(adapter);
    }

	private List<Map<String,Object>> getData() {
		// 
		for(int i=0; i<icon.length; i++){
			Map<String, Object> map = new HashMap<String,Object>();
			map.put("image",icon[i]);
			map.put("text", iconname[i]);
			dataList.add(map);
		}
		
		return dataList;
	}

}
那么目前位置的效果是这样的:

哈哈,是不是很逗很可爱!原因是GridView属性还没有配置好。


4. 设置属性:

首先,去掉软件头部导航条:去AndroidManifest中给application修改theme属性:

android:theme="@android:style/Theme.Black.NoTitleBar" 
然后,是GridView的属性:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical" >
    
<!-- 
android:numColumns=""   每一行显示的列数,auto_fit自动适应,制定列数的时候列间距就会失效。
        android:horizontalSpacing="" 两列之间的间距
        android:verticalSpacing=""  两行之间的间距
 -->
    <GridView 
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:id="@+id/gridView"
        
        android:numColumns="3"
        android:horizontalSpacing="10dp"
        android:verticalSpacing="10dp"
        android:layout_marginTop="10dp"
        />
    
</LinearLayout>

那现在的效果是这样的:



5. 设置监听事件:

用接口的方式实现:

package com.example.grideview;

import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

import android.os.Bundle;
import android.app.Activity;
import android.view.Menu;
import android.view.View;
import android.widget.AdapterView;
import android.widget.AdapterView.OnItemClickListener;
import android.widget.GridView;
import android.widget.SimpleAdapter;
import android.widget.Toast;

public class MainActivity extends Activity implements OnItemClickListener{

	private GridView gridView;
	private List<Map<String,Object>>dataList;
	private int[] icon={R.drawable.ic_launcher,R.drawable.ic_launcher,R.drawable.ic_launcher,
			R.drawable.ic_launcher,R.drawable.ic_launcher,R.drawable.ic_launcher,
			R.drawable.ic_launcher,R.drawable.ic_launcher,R.drawable.ic_launcher,
			R.drawable.ic_launcher,R.drawable.ic_launcher,R.drawable.ic_launcher};
	private String[] iconname = {"通讯录","日历","照相机","时钟","游戏","短信","铃声",
			"设置","语音","天气","浏览器","视频"};
	private SimpleAdapter adapter;
	
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);
        
        gridView = (GridView) findViewById(R.id.gridView);
        /*
         * 1.准备数据源
         * 2.新建适配器(SimpleAdapter)
         * 3.GridView加载适配器
         * 4.GridView配置事件监听器(OnItemClickListener)
         * */ 
        dataList = new ArrayList<Map<String,Object>>();
        adapter = new SimpleAdapter(
        		this, 				// 上下文
        		getData(), 			// 数据源
        		R.layout.item, 			// 单个项布局文件
        		new String[]{"image","text"}, 	// from:对应的是Map中的键名
        		new int[]{R.id.image,R.id.text}	// to:对应的是布局文件中的控件的id
        		);
        gridView.setAdapter(adapter);
        gridView.setOnItemClickListener(this);
    }

	private List<Map<String,Object>> getData() {
		// 
		for(int i=0; i<icon.length; i++){
			Map<String, Object> map = new HashMap<String,Object>();
			map.put("image",icon[i]);
			map.put("text", iconname[i]);
			dataList.add(map);
		}
		
		return dataList;
	}

	@Override
	public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
		// position从0开始的。
		Toast.makeText(this, "我是"+iconname[position], Toast.LENGTH_SHORT).show();
	}

}
效果图:

哈哈,本章结束。



可以参考一下ListView的使用方法:ListView使用汇总






版权声明:本文为博主原创文章,未经博主允许不得转载。

Android基础入门教程——2.4.9 GridView(网格视图)的基本使用

Android基础入门教程——2.4.9 GridView(网格视图)的基本使用标签(空格分隔): Android基础入门教程本节引言: 本节给大家介绍的是第二个Adapter类的控件——Grid...

阅读《Android 从入门到精通》(13)——日期选择器

日期选择器(DatePicker) java.lang.Object; android.view.View; android.view.ViewGroup; android.widget.FrameL...

Android入门基础(13) menu菜单汇总

Android入门学习(13)                                                                               -----...

android手机卫士——3、使用gridview生成程序主页面

一、主页面使用gridview,通过数据适配器,实现九宫格 指定列数:android:numColumns="3" ...
  • etmessi
  • etmessi
  • 2013年09月22日 17:01
  • 755

Android——使用GridView制作二维布局界面(行、列分布)

1.GridView的三个关键属性 android:numColumns="auto_fit"       每一行显示多少列 android:horizontalSpacing="10dp" ...
  • S415X
  • S415X
  • 2016年08月10日 12:28
  • 133

Android之旅第四站——GridView的使用…

GridView 是一种网格视图,相比较之前的ListView的列表视图,网格视图显得更加有条理,先来看看它长什么样子。。大家肯定见过很多类似的界面,淘宝,京东等很多都有。它的使用很简单,基本上和Li...

Android API 中文(15) —— GridView

  • 2010年10月19日 11:49
  • 403KB
  • 下载

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

GridView跟ListView一样是多控件布局。实现九宫图是最方便的。 还是先看看图,没图说个鸡鸡是不是 如上图,是一种应用方式,在每个格子里面,放入应用图标,和显示应用的名字在下方。 下面先...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:Android入门(13)——GridView使用汇总
举报原因:
原因补充:

(最多只允许输入30个字)