1. 程式人生 > >Android新手入門2016(10)--GridView

Android新手入門2016(10)--GridView

分享 XML tar 技術分享 gravity watermark 垂直 代碼 out

本文來自肥寶傳說之路。引用必須註明出處!

GridView跟ListView一樣是多控件布局。實現九宮圖是最方便的。

還是先看看圖,沒圖說個雞雞是不是

技術分享

如上圖。是一種應用方式。在每一個格子裏面。放入應用圖標,和顯示應用的名字在下方。

以下先看看布局文件:

activity_hello_world.xml

<?

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:verticalSpacing="10dp" android:horizontalSpacing="10dp" android:columnWidth="90dp" android:stretchMode="columnWidth" android:gravity="center" />

如今說說一些新的屬性:

這裏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<HashMap<String, Object>> images = 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.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的使用方法,能夠看這裏。

事實上過程是非常easy,就是把源數據,轉換成適配器的數據,然後把適配器設置到gridView即可了。

跟ListView一樣,每一項的布局內也是要一個布局文件的。

my_list_item.xml

<?xml version="1.0" encoding="utf-8"?>  
<RelativeLayout   
         xmlns:android="http://schemas.android.com/apk/res/android"   
         android:layout_height="wrap_content"   
         android:paddingBottom="4dip" android:layout_width="fill_parent">  
         <ImageView   
               android:layout_height="wrap_content"   
               android:id="@+id/ItemImage"   
               android:layout_width="wrap_content"   
               android:layout_centerHorizontal="true">   
         </ImageView>  
         <TextView   
               android:layout_width="wrap_content"   
               android:layout_below="@+id/ItemImage"   
               android:layout_height="wrap_content"   
               android:text="TextView01"   
               android:layout_centerHorizontal="true"   
               android:id="@+id/ItemText">  
         </TextView>  
</RelativeLayout>  
這裏ItemText設置在ItemImage以下,兩個都是垂直居中。





技術分享



Android新手入門2016(10)--GridView