Android--GridView以表格的形式显示多张图片

GridView用于在界面上按行、列分布的方式来显示多个组件。

//0.编辑Android Layout XML文件

GridView控件布局

 <GridView
        android:id="@+id/gridView" 
        android:layout_height="wrap_content"
        android:layout_width="wrap_content"
        android:numColumns="3"
        android:horizontalSpacing="10dp"
        android:verticalSpacing="10dp"
        ></GridView>

新建XML文件布局GridView中单个项

 <ImageView 
        android:id="@+id/image"
        android:src="@drawable/ic_launcher"
        android:layout_height="60dp"
        android:layout_width="60dp"     
        />
    <TextView 
       
        android:id="@+id/text"
        android:layout_marginTop="5dp"
        android:layout_height="wrap_content"
        android:layout_width="wrap_content"
        android:textColor="#ffffff"
        android:text="文字"
        />


private GridView gridView;

private List<Map<String,Object>>dataList;

protected void onCreate(Bundle savedInstanceState){

...

dataList=new ArrayList<Map<String,Object>>();

gridView=(GridView)findViewByID(R.id.gridView);  

//1.准备数据源

protected 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;
	}

//2.新建适配器(SimpleAdapter

adapter=new SimpleAdapter(this,getData(),R.layout.单项的布局XML文件名,new String[]{"image","text"},new int[]{R.id.image,R.id.text});

//3.GridView加载适配器

gridView.setAdapter(adapter);

//4.GridView配置事件监听器(OnItemClickListener)

(1) implements OnItemClickListener

(2) 重写 onItemClick方法

public void onItemClick(AdapterView<?> parent, View view, int position,
			long id) {
		// TODO Auto-generated method stub
		Toast.makeText(this, "我是"+iconName[position], Toast.LENGTH_SHORT).show();
	}
(3)gridView.setOnItemClickListener(this);


备注:使GridView适配器可以加载Bitmap图片

gvAdapter.setViewBinder(new ViewBinder() {			
			@Override
			public boolean setViewValue(View view, Object data,
					String textRepresentation) {
				if(view instanceof ImageView && data instanceof Bitmap){     
	                  ImageView iv = (ImageView) view;     
	                  iv.setImageBitmap((Bitmap) data);     
	                  return true;     
	                }
				else 
					return false;
			}
		});


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值