Android开发权威指南(第二版)
上QQ阅读APP看书,第一时间看更新

14.3 GridView(网格控件)

源代码目录:src/ch14/Gridview

从名字很容易看出,GridView控件用于显示一个网格。实际上,GridView与前面讲的ListView、Spinner等控件的使用方法类似,只是GridView在显示方式上有所不同。GridView控件采用了二维表的方式来显示列表项(也可称为单元格),每一个单元格是一个View对象,在单元格上可以放置任何Android SDK支持的控件。

既然GridView采用了二维表的方式显示单元格,就需要设置二维表的行和列。设置GridView的列可以使用<GridView>标签的columnWidth属性,也可以使用GridView.setColumnWidth方法设置列数。GridView中的单元格会根据列数自动折行显示,因此,并不需要设置GridView的行数,但需要使用android:numColumns属性设置网格的列数,否则GridView只会显示一列。

在本例中使用了SimpleAdapter对象封装GridView中每个单元格的数据(图像的资源ID),在GridView的下方显示一个ImageView控件,当选中或单击某个单元格后,该单元格中的图像将被放大显示在这个ImageView控件中。下面是本例中的完整实现代码,在这些代码中创建了SimpleAdapter对象,并使用GridView.setAdapter方法指定这个SimpleAdapter对象。

源代码文件:src/ch14/Gridview/src/mobile/android/gridview/Main.java

public class Main extends Activity implements OnItemSelectedListener,

    OnItemClickListener

{  

  private ImageView imageView;

  // 定义数据源

  private int[] resIds = new int[]

  { R.drawable.item1, R.drawable.item2, R.drawable.item3, R.drawable.item4,

      R.drawable.item5, R.drawable.item6, R.drawable.item7,

      R.drawable.item8, R.drawable.item9, R.drawable.item10,

      R.drawable.item11, R.drawable.item12, R.drawable.item13,

      R.drawable.item14, R.drawable.item15, R.drawable.item16 };

  @Override

  public void onItemSelected(AdapterView<?> parent, View view, int position,

      long id)

  {

    // 选中网格中图像时在ImageView控件中放大显示图像

    imageView.setImageResource(resIds[position]);

  }

  @Override

  public void onNothingSelected(AdapterView<?> parent)

  {

  }

  @Override

  public void onItemClick(AdapterView<?> parent, View view, int position,

      long id)

  {

    // 单击网格中图像时在ImageView控件中放大显示图像

    imageView.setImageResource(resIds[position]);

  }

  @Override

  public void onCreate(Bundle savedInstanceState)

  {

    super.onCreate(savedInstanceState);

    setContentView(R.layout.main);

    GridView gridView = (GridView) findViewById(R.id.gridview);

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

    // 单元格使用的布局只有一个ImageView控件,ID名为imageview,for循环将每一个

    // 单元格显示的图像资源ID加到cells对象中,用Map对象保存ID名(imageview)和图像资源ID

    for (int i = 0; i < resIds.length; i++)

    {

      Map<String, Object> cell = new HashMap<String, Object>();

      cell.put("imageview", resIds[i]);

      cells.add(cell);

    }

    // 创建SimpleAdapter对象

    SimpleAdapter simpleAdapter = new SimpleAdapter(this, cells,

        R.layout.cell, new String[]

        { "imageview" }, new int[]

        { R.id.imageview });

    gridView.setAdapter(simpleAdapter);

    imageView = (ImageView) findViewById(R.id.imageview);

    gridView.setOnItemSelectedListener(this);

    gridView.setOnItemClickListener(this);

    imageView.setImageResource(resIds[0]);

  }

}

定义GridView控件的gridview.xml布局文件的代码如下:

源代码文件:src/ch14/Gridview/res/layout/main.xml

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

<LinearLayout xmlns:android="http://schemas.android.com/ apk/res/android"

  android:orientation="vertical" android:layout_width= "fill_parent"

  android:layout_height="fill_parent" android:gravity= "center_horizontal">

  <GridView android:id="@+id/gridview" android:layout_ width="fill_parent"

    android:layout_height="wrap_content" android:numColumns="4"

    android:padding="20dp" android:horizontalSpacing="6dp"

    android:verticalSpacing="6dp" />

  <ImageView android:id="@+id/imageview" android:layout_ width="fill_parent"

    android:layout_height="150dp" />

</LinearLayout>

运行本例后,选中或单击屏幕上方单元格中的图像,将在屏幕下方的ImageView控件中放大显示单元格中的图像,效果如图14-15所示。

 

▲图14-15 GridView 控件