ListFragment 使用ListView and 自定义Adapter

在开发过程中经常使用Tabs + ListFragment 作为表现形式。

ListFragment 中加入ListView显示方式很容易。


[java] view plain copy 在CODE上查看代码片 派生到我的代码片
  1. packageproject.animalsound;
  2. importandroid.app.ListFragment;
  3. importandroid.os.Bundle;
  4. importandroid.view.LayoutInflater;
  5. importandroid.view.View;
  6. importandroid.view.ViewGroup;
  7. importandroid.widget.ListView;
  8. publicclassTabFirstextendsListFragment{
  9. privateAnimalListAdapteradapter=null;
  10. @Override
  11. publicvoidonCreate(BundlesavedInstanceState){
  12. super.onCreate(savedInstanceState);
  13. adapter=newAnimalListAdapter(getActivity());
  14. setListAdapter(adapter);
  15. }
  16. @Override
  17. publicViewonCreateView(LayoutInflaterinflater,ViewGroupcontainer,
  18. BundlesavedInstanceState){
  19. Viewv=inflater.inflate(R.layout.tab_first,container,false);
  20. returnv;
  21. }
  22. @Override
  23. publicvoidonListItemClick(ListViewl,Viewv,intposition,longid){
  24. System.out.println("ClickOnListItem!!!");
  25. super.onListItemClick(l,v,position,id);
  26. }
  27. }
只要在onCreateView中增加
[java] view plain copy 在CODE上查看代码片 派生到我的代码片
  1. Viewv=inflater.inflate(R.layout.tab_first,container,false);
就可以完成。

对应的R.layout.tab_first为:

[html] view plain copy 在CODE上查看代码片 派生到我的代码片
  1. <?xmlversion="1.0"encoding="utf-8"?>
  2. <RelativeLayoutxmlns:android="http://schemas.android.com/apk/res/android"
  3. android:layout_width="match_parent"
  4. android:layout_height="match_parent"
  5. android:orientation="vertical">
  6. <ListView
  7. android:id="@+id/android:list"
  8. android:layout_width="fill_parent"
  9. android:layout_height="wrap_content"
  10. />
  11. </RelativeLayout>

在这里我们对于ListView上的每个Item的布局使用下面布局

user.xml

[java] view plain copy 在CODE上查看代码片 派生到我的代码片
  1. <?xmlversion="1.0"encoding="utf-8"?>
  2. <RelativeLayoutxmlns:android="http://schemas.android.com/apk/res/android"
  3. android:layout_width="fill_parent"
  4. android:layout_height="fill_parent"
  5. android:orientation="horizontal">
  6. <ImageView
  7. android:id="@+id/animal"
  8. android:layout_width="wrap_content"
  9. android:layout_height="80dp"
  10. android:layout_alignParentLeft="true"
  11. android:layout_centerVertical="true"
  12. android:layout_margin="1dp"/>
  13. <LinearLayout
  14. android:layout_height="fill_parent"
  15. android:layout_width="wrap_content"
  16. android:layout_marginLeft="20dp"
  17. android:layout_toRightOf="@id/animal"
  18. android:layout_centerVertical="true"
  19. android:orientation="vertical">
  20. <TextView
  21. android:id="@+id/cn_word"
  22. android:layout_width="wrap_content"
  23. android:layout_height="wrap_content"
  24. android:layout_gravity="center"
  25. android:textColor="#191970"
  26. android:textSize="30sp"/>
  27. <TextView
  28. android:id="@+id/en_word"
  29. android:layout_width="wrap_content"
  30. android:layout_height="wrap_content"
  31. android:layout_gravity="center"
  32. android:textColor="#800080"
  33. android:textSize="30sp"/>
  34. </LinearLayout>
  35. <ImageView
  36. android:id="@+id/speaker"
  37. android:layout_width="wrap_content"
  38. android:layout_height="wrap_content"
  39. android:layout_alignParentRight="true"
  40. android:layout_margin="15dp"
  41. android:layout_centerVertical="true"
  42. android:src="@drawable/speaker"
  43. />
  44. </RelativeLayout>

但是在实现的时候常会遇到一个问题,如果相对其中的一个ImageView增加OnClickListener的时候会出现问题。

我们无法在下句获得的View对象中使用findViewById(R.id.speaker)去获得对应的ID对象。

[java] view plain copy 在CODE上查看代码片 派生到我的代码片
  1. Viewv=inflater.inflate(R.layout.tab_first,container,false);
原因是这句只是获得了R.layout.tab_first对应的View对象。

所以需要从user.xml获得对象信息。


这里可以使用Adapter轻松完成注册Listener的过程。我们继承BaseAdapter,然后在getView中实现整个初始化的过程。

[java] view plain copy 在CODE上查看代码片 派生到我的代码片
  1. packageproject.animalsound;
  2. importandroid.content.Context;
  3. importandroid.view.LayoutInflater;
  4. importandroid.view.View;
  5. importandroid.view.View.OnClickListener;
  6. importandroid.view.ViewGroup;
  7. importandroid.widget.BaseAdapter;
  8. importandroid.widget.ImageView;
  9. importandroid.widget.TextView;
  10. classViewHolder{
  11. publicImageViewanimal;
  12. publicTextViewcn_word;
  13. publicTextViewen_word;
  14. publicImageViewspeaker;
  15. }
  16. publicclassAnimalListAdapterextendsBaseAdapter{
  17. privateLayoutInflatermInflater=null;
  18. publicAnimalListAdapter(Contextcontext){
  19. super();
  20. mInflater=(LayoutInflater)context
  21. .getSystemService(Context.LAYOUT_INFLATER_SERVICE);
  22. }
  23. @Override
  24. publicintgetCount(){
  25. //TODOAuto-generatedmethodstub
  26. return50;
  27. }
  28. @Override
  29. publicObjectgetItem(intposition){
  30. //TODOAuto-generatedmethodstub
  31. returnnull;
  32. }
  33. @Override
  34. publiclonggetItemId(intposition){
  35. //TODOAuto-generatedmethodstub
  36. returnposition;
  37. }
  38. @Override
  39. publicViewgetView(intposition,ViewconvertView,ViewGroupparent){
  40. ViewHolderholder=null;
  41. if(convertView==null){
  42. holder=newViewHolder();
  43. convertView=mInflater.inflate(R.layout.user,null);
  44. holder.animal=(ImageView)convertView.findViewById(R.id.animal);
  45. holder.cn_word=(TextView)convertView.findViewById(R.id.cn_word);
  46. holder.en_word=(TextView)convertView.findViewById(R.id.en_word);
  47. holder.speaker=(ImageView)convertView.findViewById(R.id.speaker);
  48. convertView.setTag(holder);
  49. }else{
  50. holder=(ViewHolder)convertView.getTag();
  51. }
  52. holder.animal.setImageResource(R.drawable.ic_launcher);
  53. holder.cn_word.setText("xxxxx");
  54. holder.en_word.setText("ssssss");
  55. holder.speaker.setImageResource(R.drawable.speaker);
  56. holder.speaker.setOnClickListener(newOnClickListener(){
  57. @Override
  58. publicvoidonClick(Viewv){
  59. System.out.println("ClickonthespeakerimageonListItem");
  60. }
  61. });
  62. returnconvertView;
  63. }
  64. }


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值