Android控件开发之GridView

 

类概述

一个在平面上可显示多个条目的可滚动的视图组件,该组件中的条目通过一个ListAdapter和该组件进行关联。

GridView是一项显示二维的viewgroup,可滚动的网格。一般用来显示多张图片。

以下模拟九宫图的实现,当鼠标点击图片时会进行相应的跳转链接。

 

效果图

 

GridView 属性设置

<!-- 

android:numColumns="auto_fit" ,         GridView的列数设置为自动 
android:columnWidth="90dp",              每列的宽度,也就是Item的宽度
android:stretchMode="columnWidth",      缩放与列宽大小同步
android:verticalSpacing="10dp",          两行之间的边距,如:行一(NO.0~NO.2)与行二(NO.3~NO.5)间距为10dp
android:horizontalSpacing="10dp",        两列之间的边距

-->


本程序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="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"
/>


 

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="90dp"   //注:如果使用的图片高度高于Gridview设置的android:columnWidth="90dp" 请更改这里的值
    android:layout_width="wrap_content"
    android:layout_centerHorizontal="true"
    android:id="@+id/itemImage" />

<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"/>
</RelativeLayout>

 

主程序Java源码

package com.sx.GridView;

import java.util.ArrayList;
import java.util.HashMap;

import android.app.Activity;
import android.content.Intent;
import android.os.Bundle;
import android.view.View;
import android.widget.AdapterView;
import android.widget.AdapterView.OnItemClickListener;
import android.widget.GridView;
import android.widget.SimpleAdapter;

public class GridViewActivity extends Activity 
{
    private String texts[]  = null;
    private int    images[] = null;

    public void onCreate(Bundle savedInstanceState) 
    {
        super.onCreate(savedInstanceState);	
        setContentView(R.layout.main);

        images=new int[]
        {
		R.drawable.img1, 
		R.drawable.img2,
		R.drawable.img3,
		R.drawable.img4, 
		R.drawable.img5,
		R.drawable.img6, 
		R.drawable.img7,
		R.drawable.img8
        };

        texts = new String[]
        { 
		"宫式布局1", 
		"宫式布局2",
		"宫式布局3",
		"宫式布局4", 
		"宫式布局5", 
		"宫式布局6",
		"宫式布局7", 
		"宫式布局8"
         };

	GridView gridview = (GridView) findViewById(R.id.gridview);
		
	ArrayList<HashMap<String, Object>> lstImageItem = new ArrayList<HashMap<String, Object>>();
		
	for (int i = 0; i < 8; i++)
	{		
	    HashMap<String, Object> map = new HashMap<String, Object>();
	    map.put("itemImage", images[i]);		
	    map.put("itemText",  texts[i]);
			
	    lstImageItem.add(map);
	}

        SimpleAdapter saImageItems = new SimpleAdapter(this, 
						lstImageItem,// 数据源
						R.layout.item,// 显示布局
						new String[] { "itemImage", "itemText" }, 
						new int[] { R.id.itemImage, R.id.itemText }); 
        
         gridview.setAdapter(saImageItems);

         gridview.setOnItemClickListener(new ItemClickListener());
    }

    class ItemClickListener implements OnItemClickListener
    {
	parent   发生点击动作的AdapterView
	view     在AdapterView中被点击的视图(它是由adapter提供的一个视图)。
	position 视图在adapter中的位置。
	rowid    被点击元素的行id。

	public void onItemClick(AdapterView<?> parent, View view, int position, long rowid) 
	{     
		//根据图片进行相应的跳转
		switch (images[position]) 
		{
		case R.drawable.img1: 
			break;
		}
	}
      }


 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值