Android新手入門2016(10)--GridView
GridView跟ListView一樣是多控制項布局。實現九宮圖是最方便的。
還是先看看圖,沒圖說個雞雞是不是
如,是一種應用方式,在每個格子裡面,放入應用表徵圖,和顯示應用的名字在下方。
下面先看看布局檔案:
activity_hello_world.xml
現在說說一些新的屬性:
這裡dp相關知識可以看看Android長度相關
android:numColumns="auto_fit" 設定為自動適應螢幕寬度,只能擺放3個
android:verticalSpacing="10dp" 兩行之間的間距是10像素
android:horizontalSpacing="10dp" 兩列之間的間距為10像素
android:columnWidth="90dp" 每一列的寬度
android:stretchMode="columnWidth" 縮放與列寬的大小同步
android:gravity="center" 空間顯示的位置是中間
我們再來看看代碼:
HelloWorldActivity.java
package com.fable.helloworld; import android.app.Activity; import android.os.Bundle; import android.widget.GridView;import android.widget.SimpleAdapter; import java.util.*;public class HelloWorldActivity extends Activity { @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_hello_world); //設定主布局檔案 GridView gridview = (GridView) findViewById(R.id.gridview); //創造資料來源 ArrayList> images = new ArrayList>(); for(int i=1;i<10;i++) { HashMap map = new HashMap(); map.put("ItemImage", R.drawable.ic_launcher);//添加映像資源的ID,標識符,值 map.put("ItemText", "應用"+String.valueOf(i));//按序號做ItemText,標識符,值 images.add(map); } //把資料傳入適配器,轉換成布局需要的資料 SimpleAdapter simpleAdapter = new SimpleAdapter(this, //上下文為當前Activity images,//資料來源 R.layout.my_list_item,//每一項的布局的XML實現 new String[] {"ItemImage","ItemText"},//動態數組與ImageItem對應的子項 new int[] {R.id.ItemImage,R.id.ItemText}); //ImageItem的XML檔案裡面的一個ImageView,兩個TextView ID //添加並且顯示 gridview.setAdapter(simpleAdapter); } }可以這裡使用了SimpleAdapter,用法跟ListView一樣。對於ListView中SimpleAdapter的用法,可以看這裡。
其實過程是很簡單,就是把來源資料,轉換成適配器的資料,然後把適配器設定到gridView就行了。
跟ListView一樣,每一項的布局內也是要一個布局檔案的。
my_list_item.xml
這裡ItemText設定在ItemImage下面,兩個都是垂直置中。