首页 > 技术文章 > android中与Adapter相关的控件----GridView

huolan 2016-01-14 10:15 原文

GridView(网格视图)讲解

一、GridView(网格视图)这个是控件也是比较多,和listView的很多地方都是一样的,但是GridView可以显示多列,而listView只能显示一列,个人觉得这是最大的区别。常用属性:

android:columnWidth:设置列的宽度

android:gravity:组件的对齐方式

android:horizontalSpacing:水平方向的每个单元格的间距

android:verticalSpacing:垂直方向每个单元格的间距

android:numColumns:设置列数,默认是1.

android:stretchMode设置拉伸的模式,可选值有:none不拉伸,spacingWidth拉伸元素间的间隔空隙 columnWidth:仅仅拉伸表格元素自身 spacingWidthUniform既拉伸元素间距又拉伸他们之间的间隔空隙

二、使用实例

<?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">
    <GridView
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:numColumns="2"
        android:id="@+id/gv">
    </GridView>
</LinearLayout>
<?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="horizontal">
        <ImageView
            android:id="@+id/image1"
            android:layout_width="100dp"
            android:layout_height="100dp"
            android:src="@mipmap/ic_launcher"/>
        <TextView
            android:id="@+id/text1"
            android:layout_width="match_parent"
            android:layout_height="100dp"
            android:gravity="center"
            android:text="哈哈"
            android:textSize="30sp"/>
</LinearLayout>

Java文件

package com.example.test3;

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

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

public class MainActivity extends Activity{
    private GridView gridView;
    private List<Map<String,Object>> list;
    private SimpleAdapter adapter;
    @Override
    protected void onCreate(Bundle savedInstanceState){
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        gridView = (GridView) findViewById(R.id.gv);
        list = new ArrayList<>();
        for(int i = 0;i < 10;i++){
            Map<String,Object> map = new HashMap<>();
            map.put("image",R.mipmap.ic_launcher);
            map.put("content","哈哈" + i);
            list.add(map);
        }
        adapter = new SimpleAdapter(MainActivity.this,list,R.layout.item
                    ,new String[]{"image","content"}
                    ,new int[]{R.id.image1,R.id.text1});
        gridView.setAdapter(adapter);
    }
}

效果图

 

推荐阅读