1. 程式人生 > >Android技術——列表呈現,AdapterView及其子類(下)

Android技術——列表呈現,AdapterView及其子類(下)

八:用Adapter向GridView提供資料

1、GridView用於在介面上安行列分佈的方式顯示子項。

2、GridView與ListView有共同父類:ABSListView,因此它們高度相似,它們都是用於呈現列表項。它們的唯一區別是:ListView只顯示一列,GridView可顯示多列。可以說                ListView是一種特殊的GridView。

3、與ListView相似,GridView也是通過Adapter來提供資料的。可以使用ArrayAdapter、SimpleAdapter、BaseAdapter來向GridView提供資料,方法與ListView是一致的。

4、GridView有如下常用的XML屬性


注意:numColumns屬性用於設定表格的列。如果numColumns屬性設定為1,那GridView就變成了ListView,所以numColumns屬性一般設定為大於1。

注意:stretchMode屬性支援如下屬性值,

            NO_STRETCH:不拉伸

            STRETCH_SPACING:僅拉伸元素之間的距離

            STRETCH_SPACING_UNIFORM:表格元素本身,元素之間的間距一起拉伸

            STRETCH_COLUMN_WIDTH:僅拉伸表格元素本身

5、用BaseAdapter向GridView提供資料的例子

/GridViewTest/res/layout/activity_main.xml檔案:

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="fill_parent"
    android:layout_height="wrap_content"
    android:orientation="vertical" >
    <GridView
        android:id="@+id/liv_songs"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:numColumns="2" >
    </GridView>
</LinearLayout>

/GridViewTest/res/layout/lin_item_song.xml檔案:

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="wrap_content" >
    <ImageView
        android:id="@+id/img_head"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignParentLeft="true"
        android:layout_centerVertical="true"
        android:layout_margin="1dp"
        android:background="@drawable/ic_launcher" />
    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_centerVertical="true"
        android:layout_toLeftOf="@+id/btn_play"
        android:layout_toRightOf="@+id/img_head"
        android:orientation="horizontal" >
        <TextView
            android:id="@+id/txt_song_name"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_weight="3"
            android:gravity="center"
            android:text="test"
            android:textSize="8dp" />
    </LinearLayout>
    <!-- 如果沒有focusable、clickable、focusableInTouchMode三個屬性設定為false,點選事件會被子View優先捕捉到,導致ListView.setOnItemClickListener失效 -->
    <Button
        android:id="@+id/btn_play"
        android:layout_width="45dp"
        android:layout_height="30dp"
        android:layout_alignParentRight="true"
        android:layout_centerVertical="true"
        android:clickable="false"
        android:focusable="false"
        android:focusableInTouchMode="false"
        android:text="播放"
        android:textSize="7dp" />
</RelativeLayout>

/GridViewTest/src/com/example/gridviewtest/MainActivity.java檔案:

package com.example.gridviewtest;
import android.app.Activity;
import android.content.Context;
import android.os.Bundle;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.view.View.OnClickListener;
import android.widget.AdapterView;
import android.widget.BaseAdapter;
import android.widget.Button;
import android.widget.GridView;
import android.widget.ImageView;
import android.widget.TextView;
import android.widget.Toast;
import android.widget.AdapterView.OnItemClickListener;
public class MainActivity extends Activity
{
    @Override
    protected void onCreate(Bundle savedInstanceState)
    {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        GridView list = (GridView) findViewById(R.id.liv_songs);
        final String[] songs = new String[20];
        songs[0] = "假如讓你吻下去";
        songs[1] = "你太善良";
        songs[2] = "深深深";
        songs[3] = "忘情號";
        songs[4] = "如果這是情";
        songs[5] = "假如讓你吻下去";
        songs[6] = "你太善良";
        songs[7] = "深深深";
        songs[8] = "忘情號";
        songs[9] = "如果這是情";
        songs[10] = "假如讓你吻下去";
        songs[11] = "你太善良";
        songs[12] = "深深深";
        songs[13] = "忘情號";
        songs[14] = "如果這是情";
        songs[15] = "假如讓你吻下去";
        songs[16] = "你太善良";
        songs[17] = "深深深";
        songs[18] = "忘情號";
        songs[19] = "如果這是情";
        int[] imgs = new int[] { R.drawable.linyilian, R.drawable.zhangzhilin,
                R.drawable.likeqin, R.drawable.dudewei, R.drawable.liming,
                R.drawable.linyilian, R.drawable.zhangzhilin,
                R.drawable.likeqin, R.drawable.dudewei, R.drawable.liming,
                R.drawable.linyilian, R.drawable.zhangzhilin,
                R.drawable.likeqin, R.drawable.dudewei, R.drawable.liming,
                R.drawable.linyilian, R.drawable.zhangzhilin,
                R.drawable.likeqin, R.drawable.dudewei, R.drawable.liming };
        BaseAdapter adapter = new songsBaseAdapter(this, songs, imgs);
        list.setAdapter(adapter);
        list.setOnItemClickListener(new OnItemClickListener()
        {
            @Override
            public void onItemClick(AdapterView<?> arg0, View arg1, int arg2,
                    long arg3)
            {
                Toast t = Toast.makeText(MainActivity.this, songs[arg2]
                        + " 正在播放...", 10000);
                t.show();
            }
        });
    }
}
class songsBaseAdapter extends BaseAdapter
{
    private Context  context;
    private String[] songs_info;
    private int[]    songs_img;
    public songsBaseAdapter(Context t, String[] s_info, int[] s_img)
    {
        context = t;
        songs_info = s_info;
        songs_img = s_img;
    }
    @Override
    public int getCount()
    {
        // TODO Auto-generated method stub
        return 20;
    }
    @Override
    public Object getItem(int arg0)
    {
        // TODO Auto-generated method stub
        return null;
    }
    @Override
    public long getItemId(int arg0)
    {
        // 傳入的arg0是列表項的下標(第幾個列表項),可用這個值作為列表項的ID
        return arg0;
    }
    @Override
    public View getView(int item_count, View arg1, ViewGroup arg2)
    {
        // 這個方法將提供列表項的佈局及細節,第一個引數是列表項下標(第幾個列表項),第二個引數是該列表項的View,第三個引數是整個ListView
        final int _item_count = item_count;
        LayoutInflater inflater = (LayoutInflater) context
                .getSystemService(Context.LAYOUT_INFLATER_SERVICE);
        arg1 = inflater.inflate(R.layout.lin_item_song, null);
        ((TextView) arg1.findViewById(R.id.txt_song_name))
                .setText(songs_info[item_count]);
        ((ImageView) arg1.findViewById(R.id.img_head))
                .setBackgroundResource(songs_img[item_count]);
        ((Button) arg1.findViewById(R.id.btn_play))
                .setOnClickListener(new OnClickListener()
                {
                    @Override
                    public void onClick(View arg0)
                    {
                        Toast t = Toast.makeText(context, "“"
                                + songs_info[_item_count] + "”正在播放", 10000);
                        t.show();
                    }
                });
        return arg1;
    }
}

效果如下: