android 多列顯示 之 GridView(含源碼)


 源碼下載:
http://www.eoeandroid.com/thread-182395-1-1.html

 

----------------------------------------------------------------------

ViewPager多頁面滑動切換以及動畫效果(版主加個精唄~)
http://www.eoeandroid.com/thread-157771-1-1.html

使用ViewPager實現左右滑動翻頁
http://www.eoeandroid.com/thread-158261-1-1.html

ANDROID左右滑屏仿QQ新功能引導界面(兩種方式)
http://www.eoeandroid.com/thread-117817-1-1.html

 

大家可能遇到過這樣的情況,一個應用要開發手機版和 Pad 版,在手機中一個ListView就可以搞定,並且是一列顯示的,但運行在Pad上時,發現界面太長,需要在Pad上進行多列顯示,這時候就希望實現多列的效果,這里我簡單實現了個Demo,供大家參考(我也是遇到這樣的情況才有這樣的需求,大家共勉),對於高手來說這些都是小意思,請高台貴手,勿拍!(最下方附有源碼)

1.效果類似Hiapk的安卓市場,如下:

2.界面布局
  main.xml

<?xml version="1.0" encoding="utf-8"?>
 
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
 
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    android:orientation="vertical" >
 
    <GridView 
 
        android:id="@+id/list_gridView"
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:columnWidth="100dp" 
        android:numColumns="5"/>
 
</LinearLayout>

Tips:上面的 android:numColumns="5" 表示顯示的列數

  item_main.xml 在這里布局需要顯示的元素
 
<?xml version="1.0" encoding="utf-8"?>
 
<TableLayout xmlns:android="http://schemas.android.com/apk/res/android"
 
    android:layout_width="fill_parent"
    android:layout_height="wrap_content"
    android:padding="10dp"
    android:scrollbars="vertical" >
 
    <TableRow >
 
        <TextView
 
            android:id="@+id/key"
            android:ellipsize="end"
            android:gravity="left"/>
 
    </TableRow>
 
    <TableRow android:paddingTop="5dp" >
  
        <TextView

            android:id="@+id/title_1"
            android:ellipsize="end"
            android:gravity="left" />
 
    </TableRow>
 
    <TableRow android:paddingTop="5dp" >
 
        <TextView
 
           android:id="@+id/title_2"
            android:ellipsize="end"
            android:gravity="left"/>
 
        <ImageView
 
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_alignParentRight="true"
            android:src="@drawable/item_more" />
 
    </TableRow>
  
   <TableRow android:paddingTop="5dp" >
  
        <TextView

            android:id="@+id/title_3"
            android:ellipsize="end“
            android:gravity="left"/>

    </TableRow>
 
    <TableRow android:paddingTop="5dp" >
  
        <TextView

             android:id="@+id/title_4"
            android:ellipsize="end"
             android:gravity="left" />

    </TableRow>
 
</TableLayout>

3.Activity處理

  其實與使用ListView和GirdView沒什么區別
package org.hanely.towne.activity;
 

import java.util.ArrayList;
 
import java.util.HashMap;
 
import java.util.List;
 
import android.app.Activity;
 
import android.os.Bundle;
 
import android.widget.GridView;

import android.widget.SimpleAdapter;
 
public class GirdviewActivity extends Activity {
 
        private GridView gridListView;
        private List<HashMap<String,String>> data;
        private String test ="多列顯示Test";

    @Override
 
    public void onCreate(Bundle savedInstanceState) {
 
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);
 
        findVidwByIds();
 
        fillData();
 
        SimpleAdapter sa = new SimpleAdapter(this, data, R.layout.item_main, new String[]{"key","title_1","title_2","title_3","title_4"}, new int[]{R.id.key,R.id.title_1,R.id.title_2,R.id.title_3,R.id.title_4});
  
        gridListView.setAdapter(sa);

    }
 
    public void findVidwByIds(){
 
            gridListView = (GridView) findViewById(R.id.list_gridView);
 
    }
 
    public void fillData(){
 
            data = new ArrayList<HashMap<String,String>>();
 
            for(int i=0; i<10; i++){
 
                    HashMap<String,String> map = new HashMap<String,String>();
  
                    map.put("key", test+i);
 
                    map.put("title_1", test+i);
                    map.put("title_2", test+i);
                    map.put("title_3", test+i);
                    map.put("title_4", test+i); 
 
                   data.add(map);

            }
    }
}

 

 

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM