本文讲实现一个自定义列表的Android程序,程序将实现一个使用自定义的适配器(Adapter)绑定
数据,通过contextView.setTag绑定数据有按钮的ListView。
系统显示列表(ListView)时,首先会实例化一个适配器,本文将实例化一个自定义的适配器。实现
自定义适配器,必须手动映射数据,这时就需要重写getView()方法,系统在绘制列表的每一行的时候
将调用此方法。
ListView在开始绘制的时候,系统自动调用getCount()函数,根据函数返回值得到ListView的长度,
然后根据这个长度,调用getView()逐一画出每一行。
具体使用方法可以参考下面代码,只需记住Android自定义ListView三步骤:
第一步:准备主布局文件、组件布局文件等
第二步:获取并整理数据
第三部:绑定数据,这里我们是通过自己编写Adapter类来完成的
1.首先新建一个list.XML
Java代码
<?xmlversion="1.0"encoding="utf-8"?>
<LinearLayoutxmlns:android="/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical">
<LinearLayoutandroid:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="horizontal"android:background="#f1e4f1">
<ImageView
android:id="@+id/image"
android:layout_width="wrap_content"
android:layout_height="wrap_content"/>
<TextView
android:id="@+id/title"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:textColor="#666872"/>
<Button
android:id="@+id/view"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="详细"/>
</LinearLayout>
<TextView
android:id="@+id/info"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:textColor="#666872"/>
</LinearLayout>
2、新建一个适配器类MyAdspter.java
Java代码
publicclassMyAdspterextendsBaseAdapter{
privateList<Map<String,Object>>data;
privateLayoutInflaterlayoutInflater;
privateContextcontext;
publicMyAdspter(Contextcontext,List<Map<String,Object>>data){
this.context=context;
this.data=data;
this.layoutInflater=LayoutInflater.from(context);
}
/**
*组件集合,对应list.xml中的控件
*@authorAdministrator
*/
publicfinalclassZujian{
publicImageViewimage;
publicTextViewtitle;
publicButtonview;
publicTextViewinfo;
}
@Override
publicintgetCount(){
returndata.size();
}
/**
*获得某一位置的数据
*/
@Override
publicObjectgetItem(intposition){
returndata.get(position);
}
/**
*获得唯一标识
*/
@Override
publiclonggetItemId(intposition){
returnposition;
}
@Override
publicViewgetView(intposition,ViewconvertView,ViewGroupparent){
Zujianzujian=null;
if(convertView==null){
zujian=newZujian();
//获得组件,实例化组件
convertView=layoutInflater.inflate(R.layout.list,null);
zujian.image=(ImageView)convertView.findViewById(R.id.image);
zujian.title=(TextView)convertView.findViewById(R.id.title);
zujian.view=(Button)convertView.findViewById(R.id.view);
zujian.info=(TextView)convertView.findViewById(R.id.info);
convertView.setTag(zujian);
}else{
zujian=(Zujian)convertView.getTag();
}
//绑定数据
zujian.image.setBackgroundResource((Integer)data.get(position).get("image"));
zujian.title.setText((String)data.get(position).get("title"));
zujian.info.setText((String)data.get(position).get("info"));
returnconvertView;
}
}
关于上面LayoutInflater的使用:在实际开发种LayoutInflater这个类还是非常有用的。它的作用类似
于 findViewById(),不同点是LayoutInflater是用来找layout下xml布局文件,并且会实例化!。
getView()的三个参数:position表示将显示的是第几行,covertView是从布局文件中inflate来的布
局。我们用LayoutInflater的方法将定义好的list.xml文件提取成View实例用来显示。然后将xml文件
中的各个组件实例化,这样便可以将数据对应到各个组件上了。但是按钮为了响应点击事件,需要为
它添加点击监听器,这样就能捕获点击事件。
3、activity_main.xml中添加ListView控件
Java代码
<RelativeLayoutxmlns:android="/apk/res/android"
xmlns:tools="/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:paddingBottom="@dimen/activity_vertical_margin"
android:paddingLeft="@dimen/activity_horizontal_margin"
android:paddingRight="@dimen/activity_horizontal_margin"
android:paddingTop="@dimen/activity_vertical_margin"
tools:context=".MainActivity">
<ListView
android:id="@+id/list"
android:layout_width="fill_parent"
android:layout_height="fill_parent"></ListView>
</RelativeLayout>
4、在activity中调用ListView
Java代码
publicclassMainActivityextendsActivity{
privateListViewlistView=null;
@Override
protectedvoidonCreate(BundlesavedInstanceState){
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
listView=(ListView)findViewById(R.id.list);
List<Map<String,Object>>list=getData();
listView.setAdapter(newMyAdspter(this,list));
}
@Override
publicbooleanonCreateOptionsMenu(Menumenu){
getMenuInflater().inflate(R.menu.main,menu);
returntrue;
}
publicList<Map<String,Object>>getData(){
List<Map<String,Object>>list=newArrayList<Map<String,Object>>();
for(inti=0;i<10;i++){
Map<String,Object>map=newHashMap<String,Object>();
map.put("image",R.drawable.ic_launcher);
map.put("title","这是一个标题"+i);
map.put("info","这是一个详细信息"+i);
list.add(map);
}
returnlist;
}
}