八:用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;
}
}
效果如下: