第39章、网格视图GridView(从零开始学Android)

这篇教程介绍了如何在Android中设计并实现GridView。首先在activity_main.xml布局文件中添加GridView,接着创建grid.xml来定义每个单元格的内容。然后,在MainActivity.java中编写相关代码进行数据绑定和事件处理。最后,展示了运行后的效果。
网格视图对于需要有类似“九宫格”布局时非常有用。

 

一、设计界面

  1、打开“res/layout/activity_main.xml”文件。

  从工具栏向activity拖出1个GridView网格视图。

  

  2、打开activity_main.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="match_parent"   
    android:layout_height="match_parent"  
    android:numColumns="auto_fit"  
    android:verticalSpacing="10dp"  
    android:horizontalSpacing="10dp"  
    android:columnWidth="90dp"  
    android:stretchMode="columnWidth"  
    android:gravity="center"  
/> 

 

  3、添加grid.xml文件。

  

  4、打开activity_main.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>  


 

二、打开“src/com.genwoxue.gridview/MainActivity.java”文件。

  然后输入以下代码:

package com.genwoxue.gridview;

import android.app.Activity;
import android.os.Bundle;
import android.view.View;
import android.widget.GridView;
import android.widget.SimpleAdapter;
import java.util.ArrayList;
import java.util.HashMap;
import android.widget.AdapterView;
import android.widget.AdapterView.OnItemClickListener;

public class MainActivity extends Activity {

	@Override
	public void onCreate(Bundle savedInstanceState) {  
	     super.onCreate(savedInstanceState);  
	     setContentView(R.layout.activity_main);  
	     GridView gridview = (GridView) findViewById(R.id.gridview);  
	        
	     //生成动态数组,并且转入数据   
	     ArrayList<HashMap<String, Object>> lstImageItem = new ArrayList<HashMap<String, Object>>();  
	     for(int i=0;i<10;i++){  
	        HashMap<String, Object> map = new HashMap<String, Object>();  
	        map.put("ItemImage", R.drawable.ic_launcher);//添加图像资源的ID   
	        map.put("ItemText", "NO."+String.valueOf(i));//按序号做ItemText   
	        lstImageItem.add(map);  
	      }  
	      //生成适配器的ImageItem <====> 动态数组的元素,两者一一对应   
	      SimpleAdapter saImageItems = new SimpleAdapter(this, 
	                                                lstImageItem,//数据来源    
	                                                R.layout.grid,//grid的XML实现   
	                                                  
	                                                //动态数组与ImageItem对应的子项           
	                                                new String[] {"ItemImage","ItemText"},   
	                                                  
	                                                //ImageItem的XML文件里面的一个ImageView,两个TextView ID   
	                                                new int[] {R.id.ItemImage,R.id.ItemText});  
	      //添加并且显示   
	      gridview.setAdapter(saImageItems);  
	      //添加消息处理   
	      gridview.setOnItemClickListener(new ItemClickListener());  
	  }  
	    
	  //当AdapterView被单击(触摸屏或者键盘),则返回的Item单击事件   
	  class  ItemClickListener implements OnItemClickListener{  
		  public void onItemClick(AdapterView<?> arg0,View arg1,int arg2,long arg3){  
			    HashMap<String, Object> item=(HashMap<String, Object>) arg0.getItemAtPosition(arg2);  
			    //显示所选Item的ItemText   
			    setTitle((String)item.get("ItemText"));  
		  }  	      
	  }  

}


三、运行结果

  

      (本篇来源于网络)

评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

蒋会全

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值