android實現九宮格 GridView 用法

main.xml源代碼如下,本身是個GirdView,用於裝載Item: 

<?xml version="1.0" encoding="utf-8"?> 
<GridView xmlns:Android="http://schemas.android.com/apk/res/android" 
  android:id="@+id/GridView" 
  android:layout_width="fill_parent" 
  android:layout_height="fill_parent" 
  android:numColumns="auto_fit" 
  android:horizontalSpacing="10dp" 
  android:verticalSpacing="10dp" 
  android:columnWidth="90dp" 
  android:stretchMode="columnWidth" 
  android:gravity="center"></GridView> 

介紹一下里面的某些屬性: 

android:numColumns="auto_fit" ,GridView的列數設置爲自動 

android:columnWidth="90dp",每列的寬度,也就是Item的寬度 
android:stretchMode="columnWidth",縮放與列寬大小同步 
android:verticalSpacing="10dp",兩行之間的邊距,如:行一(NO.0~NO.2)與行二(NO.3~NO.5)間距爲10dp 
android:horizontalSpacing="10dp",兩列之間的邊距。 


接下來介紹 meunitem.xml,這個XML跟前面ListView的ImageItem.xml很類似: 

<?xml version="1.0" encoding="utf-8"?> 
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" 
android:layout_width="fill_parent" 
android:layout_height="wrap_content" 

<ImageView  android:layout_width="wrap_content" 
    android:id="@+id/ItemImage" 
    android:layout_height="wrap_content" 
    android:layout_centerHorizontal="true"/> 
<TextView   android:layout_width="wrap_content" 
android:layout_height="wrap_content" 
android:layout_below="@+id/ItemImage" 
android:id="@+id/ItemText" 
android:layout_centerHorizontal="true" 
/> 
</RelativeLayout> 

最後是JAVA的源代碼 

@Override 
protected void onCreate(Bundle savedInstanceState) { 
super.onCreate(savedInstanceState); 
setContentView(R.layout.mainmenu); 

GridView gridview = (GridView) findViewById(R.id.GridView); 
ArrayList<HashMap<String, Object>> meumList = new ArrayList<HashMap<String, Object>>(); 

for(int i = 1;i < 10;i++) { 
HashMap<String, Object> map = new HashMap<String, Object>(); 
map.put("ItemImage", R.drawable.icon); 
map.put("ItemText", "NO."+i); 
meumList.add(map); 


SimpleAdapter saMenuItem = new SimpleAdapter(this, 
  meumList, //數據源 
  R.layout.menuitem, //xml實現 
  new String[]{"ItemImage","ItemText"}, //對應map的Key 
  new int[]{R.id.ItemImage,R.id.ItemText});  //對應R的Id 

//添加Item到網格中 
gridview.setAdapter(saMenuItem); 
gridview.setOnItemClickListener(new OnItemClickListener() { 
public void onItemClick(AdapterView<?> arg0, View arg1, int arg2,long arg3) { 
                                        System.out.println("click index:"+arg2); 


); 

  
附上 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章