Android學習筆記之GridView

<1>簡介

一個在平面上可顯示多個條目的可滾動的視圖組件,該組件中的條目通過一個ListAdapter和該組件進行關聯。

比如實現九宮格圖,用GridView是首選,也是最簡單的。

<2>XML屬性

屬性:

android:columnWidth  

設置列的寬度。關聯的方法爲:setColumnWidth(int)

android:gravity   

設置此組件中的內容在組件中的位置

必須是一個或多個(用“|”分隔開)以下的常量。

topbottomleftrightcenter_verticalfill_verticalcenter_horizontalfill_horizontalcenterfill

關聯方法:setGravity (int gravity)

android:horizontalSpacing  

兩列之間的間距。關聯方法:setHorizontalSpacing(int)

android:numColumns  

列數。關聯方法:setNumColumns(int)

可以是auto_fit常量,表示儘可能多的顯示列來填補的可用空間。

android:stretchMode

縮放模式。關聯方法:setStretchMode(int)

 

Constant Value Description
none 0
spacingWidth 1 在每列之間的空間進行縮放
columnWidth 2 每列進行平均的縮放
spacingWidthUniform 3 每一列之間的間隔是均勻地縮放.

android:verticalSpacing   

兩行之間的間距。關聯方法:setVerticalSpacing(int)

<3>常用公共方法

public     ListAdapter  getAdapter()

獲得與此組件相關的適配器

返回值: ListAdapter適配器實例

 

public    int      getNumColumns()

獲得GridView的列數

public   int      getStretchMode()

獲得GridView的縮放模式

public   void  setAdapter(ListAdapter adapter)

設置與此組件相關的適配器

public         void      setColumnWidth(int columnWidth)

設置GridView的列寬.

public        void      setGravity(int gravity)

設置控件內容的位置,默認值爲:Gravity.LEFT

public       void      setHorizontalSpacing(int horizontalSpacing)

設置列間距.

public         void      setNumColumns(int numColumns)

設置grid的列數

public       void      setSelection(int position)

設置選中的條目.

public         void      setStretchMode(int stretchMode)

設置grid中的條目以什麼縮放模式去填充空間。

stretchMode 可選值:NO_STRETCHSTRETCH_SPACINGSTRETCH_SPACING_UNIFORM,或STRETCH_COLUMN_WIDTH

<4>範例

main.xml

[java] view plaincopy
  1. <?xml version="1.0" encoding="utf-8"?>  
  2. <GridView xmlns:android="http://schemas.android.com/apk/res/android"  
  3.     android:id="@+id/gridview"  
  4.     android:layout_width="fill_parent"  
  5.     android:layout_height="fill_parent"  
  6.     android:verticalSpacing="5dip"  
  7.     android:horizontalSpacing="5dip"  
  8.     android:columnWidth="80dip"  
  9.     android:numColumns="auto_fit"  
  10.     android:stretchMode="columnWidth"  
  11.     android:gravity="center"  
  12.     />  


 

[java] view plaincopy
  1. package xiaosi.gridview;  
  2.   
  3. import android.app.Activity;  
  4. import android.content.Context;  
  5. import android.os.Bundle;  
  6. import android.view.View;  
  7. import android.view.ViewGroup;  
  8. import android.widget.AdapterView;  
  9. import android.widget.AdapterView.OnItemClickListener;  
  10. import android.widget.BaseAdapter;  
  11. import android.widget.GridView;  
  12. import android.widget.ImageView;  
  13. import android.widget.Toast;  
  14.   
  15. public class GridViewActivity extends Activity {  
  16.     /** Called when the activity is first created. */  
  17.     private GridView gridview = null;  
  18.     @Override  
  19.     public void onCreate(Bundle savedInstanceState) {  
  20.         super.onCreate(savedInstanceState);  
  21.         setContentView(R.layout.main);  
  22.           
  23.         gridview = (GridView)findViewById(R.id.gridview);  
  24.         gridview.setAdapter(new ImageAdapter(GridViewActivity.this));      
  25.         gridview.setOnItemClickListener(new OnItemClickListener() {  
  26.   
  27.             public void onItemClick(AdapterView<?> arg0, View arg1, int arg2,  
  28.                     long arg3) {  
  29.                   
  30.                 Toast.makeText(GridViewActivity.this"" + arg2, Toast.LENGTH_SHORT).show();          
  31.             }  
  32.               
  33.         });  
  34.     }  
  35.       
  36.     public class ImageAdapter extends BaseAdapter {  
  37.   
  38.         private Context context;  
  39.         private int[] ImageBox ={  
  40.                 R.drawable.sample_1,R.drawable.sample_0,  
  41.                 R.drawable.sample_3,R.drawable.sample_4,  
  42.                 R.drawable.sample_5,R.drawable.sample_2,  
  43.                 R.drawable.sample_3,R.drawable.sample_2,  
  44.                 R.drawable.sample_4,R.drawable.sample_5,  
  45.                 R.drawable.sample_4,R.drawable.sample_2,  
  46.                 R.drawable.sample_3,R.drawable.sample_3,  
  47.                 R.drawable.sample_4,R.drawable.sample_5,  
  48.                 R.drawable.sample_5,R.drawable.sample_7};  
  49.         public ImageAdapter(Context context){  
  50.             this.context = context;  
  51.         }  
  52.         public int getCount() {  
  53.             return ImageBox.length;  
  54.         }  
  55.   
  56.         public Object getItem(int arg0) {  
  57.             // TODO Auto-generated method stub  
  58.             return null;  
  59.         }  
  60.   
  61.         public long getItemId(int position) {  
  62.             // TODO Auto-generated method stub  
  63.             return 0;  
  64.         }  
  65.   
  66.         public View getView(int position, View convertView, ViewGroup parent) {  
  67.             ImageView imageView;          
  68.             if (convertView == null) {    
  69.                 // if it's not recycled, initialize some attributes              
  70.                 imageView = new ImageView(context);              
  71.                 imageView.setLayoutParams(new GridView.LayoutParams(120120));              
  72.                 imageView.setScaleType(ImageView.ScaleType.CENTER_CROP);              
  73.                 imageView.setPadding(8888);          
  74.             }  
  75.             else   
  76.             {             
  77.                 imageView = (ImageView) convertView;         
  78.             }   
  79.               
  80.             imageView.setImageResource(ImageBox[position]);          
  81.             return imageView;  
  82.         }  
  83.           
  84.     }  
  85. }  


發佈了29 篇原創文章 · 獲贊 11 · 訪問量 8萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章