Android-UI控件-GridView

GridView(网格视图)是按照行列的方式来显示内容的,一般用于显示图片,比如实现九宫格图

主要用于设置Adapter

GridView常用的XML属性:
android:columnWidth 设置列的宽度。

android:gravity 设置对齐方式

android:horizontalSpacing 两列之间的间距。

android:numColumns 设置列数。

android:stretchMode 缩放模式。

android:verticalSpacing 两行之间的间距。

例子一:
MainActivity.java
package com.android.gridview2.activity;

import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import android.app.Activity;
import android.os.Bundle;
import android.widget.GridView;
import android.widget.SimpleAdapter;

public class MainActivity extends Activity {

   private GridView gv; 
   @Override
   protected void onCreate(Bundle savedInstanceState) { 
      // TODO Auto-generated method stub 
      super.onCreate(savedInstanceState); 
      setContentView(R.layout.gridview); 

      //准备要添加的数据条目 
      List<Map<String, Object>> items = new ArrayList<Map<String,Object>>(); 
      for (int i = 0; i < 9; i++) { 
        Map<String, Object> item = new HashMap<String, Object>(); 
        item.put("imageItem", R.drawable.icon);//添加图像资源的ID   
        item.put("textItem", "icon" + i);//按序号添加ItemText   
        items.add(item); 
      } 

      //实例化一个适配器 
      SimpleAdapter adapter = new SimpleAdapter(this,  
                                                  items,  
                                                  R.layout.grid_item,  
                                                  new String[]{"imageItem", "textItem"},  
                                                  new int[]{R.id.image_item, R.id.text_item}); 

      //获得GridView实例 
      gv = (GridView)findViewById(R.id.mygridview); 
      //为GridView设置适配器 
      gv.setAdapter(adapter); 

   } 

}

gridview.xml

<?xml version="1.0" encoding="utf-8"?>

<LinearLayout xmlns:android=“http://schemas.android.com/apk/res/android
android:layout_width=“wrap_content”
android:layout_height=“wrap_content”


grid_item.xml

<?xml version="1.0" encoding="utf-8"?>

<RelativeLayout xmlns:android=“http://schemas.android.com/apk/res/android
android:id="@+id/RelativeLayout1"
android:layout_width=“wrap_content”
android:layout_height=“fill_parent”
android:paddingBottom=“6dip”



例子二:
MainActivity.java
package com.android.gridview3;

import java.util.ArrayList;
import java.util.List;
import android.app.Activity;
import android.content.Context;
import android.os.Bundle;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.AdapterView;
import android.widget.BaseAdapter;
import android.widget.GridView;
import android.widget.ImageView;
import android.widget.TextView;
import android.widget.Toast;
import android.widget.AdapterView.OnItemClickListener;

public class MainActivity extends Activity
{
private GridView gridView;
//图片的文字标题
private String[] titles = new String[]
{ “pic1”, “pic2”, “pic3”, “pic4”, “pic5”, “pic6”, “pic7”, “pic8”, “pic9”};
//图片ID数组
private int[] images = new int[]{
R.drawable.pic1, R.drawable.pic2, R.drawable.pic3,
R.drawable.pic4, R.drawable.pic5, R.drawable.pic6,
R.drawable.pic7, R.drawable.pic8,R.drawable.pic9
};

@Override
public void onCreate(Bundle savedInstanceState){ 
    super.onCreate(savedInstanceState); 
    setContentView(R.layout.main); 
    gridView = (GridView) findViewById(R.id.gridview); 
    PictureAdapter adapter = new PictureAdapter(titles, images, this); 
    gridView.setAdapter(adapter); 

    gridView.setOnItemClickListener(new OnItemClickListener() 
        { 
            public void onItemClick(AdapterView<?> parent, View v, int position, long id) 
            { 
                Toast.makeText(MainActivity.this, "pic" + (position+1), Toast.LENGTH_SHORT).show(); 
            } 
        }); 
} 

}
//自定义适配器
class PictureAdapter extends BaseAdapter{
private LayoutInflater inflater;
private List pictures;

public PictureAdapter(String[] titles, int[] images, Context context) 
{ 
    super(); 
    pictures = new ArrayList<Picture>(); 
    inflater = LayoutInflater.from(context); 
    for (int i = 0; i < images.length; i++) 
    { 
        Picture picture = new Picture(titles[i], images[i]); 
        pictures.add(picture); 
    } 
} 

@Override
public int getCount() 
{ 
    if (null != pictures) 
    { 
        return pictures.size(); 
    } else
    { 
        return 0; 
    } 
} 

@Override
public Object getItem(int position) 
{ 
    return pictures.get(position); 
} 

@Override
public long getItemId(int position) 
{ 
    return position; 
} 

@Override
public View getView(int position, View convertView, ViewGroup parent) 
{ 
    ViewHolder viewHolder; 
    if (convertView == null) 
    { 
        convertView = inflater.inflate(R.layout.picture_item, null); 
        viewHolder = new ViewHolder(); 
        viewHolder.title = (TextView) convertView.findViewById(R.id.title); 
        viewHolder.image = (ImageView) convertView.findViewById(R.id.image); 
        convertView.setTag(viewHolder); 
    } else
    { 
        viewHolder = (ViewHolder) convertView.getTag(); 
    } 
    viewHolder.title.setText(pictures.get(position).getTitle()); 
    viewHolder.image.setImageResource(pictures.get(position).getImageId()); 
    return convertView; 
} 

}

class ViewHolder
{
public TextView title;
public ImageView image;
}

class Picture
{
private String title;
private int imageId;

public Picture() 
{ 
    super(); 
} 

public Picture(String title, int imageId) 
{ 
    super(); 
    this.title = title; 
    this.imageId = imageId; 
} 

public String getTitle() 
{ 
    return title; 
} 

public void setTitle(String title) 
{ 
    this.title = title; 
} 

public int getImageId() 
{ 
    return imageId; 
} 

public void setImageId(int imageId) 
{ 
    this.imageId = imageId; 
} 

}
main.xml

<?xml version="1.0" encoding="utf-8"?>


picture_item.xml

<?xml version="1.0" encoding="utf-8"?>




评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值