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

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

[java] view
plain
copy

  1. package project.animalsound;
  2. import android.app.ListFragment;
  3. import android.os.Bundle;
  4. import android.view.LayoutInflater;
  5. import android.view.View;
  6. import android.view.ViewGroup;
  7. import android.widget.ListView;
  8. public class TabFirst extends ListFragment {
  9. private AnimalListAdapter adapter = null;
  10. @Override
  11. public void onCreate(Bundle savedInstanceState) {
  12. super.onCreate(savedInstanceState);
  13. adapter = new AnimalListAdapter (getActivity());
  14. setListAdapter(adapter);
  15. }
  16. @Override
  17. public View onCreateView(LayoutInflater inflater, ViewGroup container,
  18. Bundle savedInstanceState) {
  19. View v = inflater.inflate(R.layout.tab_first, container, false);
  20. return v;
  21. }
  22. @Override
  23. public void onListItemClick(ListView l, View v, int position, long id) {
  24. System.out.println("Click On List Item!!!");
  25. super.onListItemClick(l, v, position, id);
  26. }
  27. }

只要在onCreateView中增加

[java] view
plain
copy

  1. View v = inflater.inflate(R.layout.tab_first, container, false);

就可以完成。

对应的R.layout.tab_first为:

[html] view
plain
copy

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <RelativeLayout xmlns: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

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <RelativeLayout xmlns: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

  1. View v = inflater.inflate(R.layout.tab_first, container, false);

原因是这句只是获得了R.layout.tab_first对应的View对象。

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

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

[java] view
plain
copy

  1. package project.animalsound;
  2. import android.content.Context;
  3. import android.view.LayoutInflater;
  4. import android.view.View;
  5. import android.view.View.OnClickListener;
  6. import android.view.ViewGroup;
  7. import android.widget.BaseAdapter;
  8. import android.widget.ImageView;
  9. import android.widget.TextView;
  10. class ViewHolder {
  11. public ImageView animal;
  12. public TextView cn_word;
  13. public TextView en_word;
  14. public ImageView speaker;
  15. }
  16. public class AnimalListAdapter extends BaseAdapter {
  17. private LayoutInflater mInflater = null;
  18. public AnimalListAdapter(Context context){
  19. super();
  20. mInflater = (LayoutInflater) context
  21. .getSystemService(Context.LAYOUT_INFLATER_SERVICE);
  22. }
  23. @Override
  24. public int getCount() {
  25. // TODO Auto-generated method stub
  26. return 50;
  27. }
  28. @Override
  29. public Object getItem(int position) {
  30. // TODO Auto-generated method stub
  31. return null;
  32. }
  33. @Override
  34. public long getItemId(int position) {
  35. // TODO Auto-generated method stub
  36. return position;
  37. }
  38. @Override
  39. public View getView(int position, View convertView, ViewGroup parent) {
  40. ViewHolder holder = null;
  41. if (convertView == null) {
  42. holder = new ViewHolder();
  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(new OnClickListener(){
  57. @Override
  58. public void onClick(View v) {
  59. System.out.println("Click on the speaker image on ListItem ");
  60. }
  61. });
  62. return convertView;
  63. }
  64. }

ListFragment 使用ListView and 自定义Adapter的更多相关文章

  1. fragment、ListFragment使用ListView及自定义Listview等初始化操作

    fragment.ListFragment使用ListView及自定义Listview等初始化操作 1.先说一下 从官方api中说fragment碎片中使用Listview有专门的 ListView碎 ...

  2. android代码优化----ListView中自定义adapter的封装(ListView的模板写法)

    [声明] 欢迎转载,但请保留文章原始出处→_→ 生命壹号:http://www.cnblogs.com/smyhvae/ 文章来源:http://www.cnblogs.com/smyhvae/p/4 ...

  3. ANDROID_MARS学习笔记_S04_008_用Listview、自定义adapter显示返回的微博数据

    一.简介 运行结果 二.代码1.xml(1)activity_main.xml <?xml version="1.0" encoding="utf-8"? ...

  4. Android ListView 自定义 Adapter

    自定义Adapter类 public class ListViewAdapter extends BaseAdapter { private static final String TAG = Mai ...

  5. android 自定义adapter和线程结合 + ListView中按钮滑动后状态丢失解决办法

    adapter+线程 1.很多时候自定义adapter的数据都是来源于服务器的,所以在获取服务器的时候就需要异步获取,这里就需要开线程了(线程池)去获取服务器的数据了.但这样有的时候adapter的中 ...

  6. 【转】Android自定义Adapter的ListView的思路及代码

    原文网址:http://www.jb51.net/article/37236.htm Android自定义Adapter的ListView的思路及代码,需要的朋友可以参考一下   在开发中,我们经常使 ...

  7. 关于自定义Adapter实现ListView的使用

    以下为使用BaseAdapter作扩展,自定义Adapter来使用ListView控件: 需要注意以下的几点: 1.自定义Adapter时,需要特别注意Adapter类中getView()方法覆盖,注 ...

  8. [Android] Android RecycleView和ListView 自定义Adapter封装类

    在网上查看了很多对应 Android RecycleView和ListView 自定义Adapter封装类 的文章,主要存在几个问题: 一).网上代码一大抄,复制来复制去,大部分都运行不起来,或者 格 ...

  9. 自定义Adapter为什么会重复多轮调用getView?——原来是ListView.onMeasure在作祟

    相信很多人在使用自定义Adapter的时候都遇到这样的问题: 假设Adapter数据源中只有30个Item,理论上每显示一个新的Item的时候就会调用一次getView,均显示一次的话是要调用getV ...

随机推荐

  1. Python3 pip换源

    pip安装源 介绍 """ 1.采用国内源,加速下载模块的速度 2.常用pip源: -- 豆瓣:https://pypi.douban.com/simple -- 阿里: ...

  2. delphi7 如何描述窗体上的全部控件

    在delphi开发中,经常需要用到窗体中控件的name名来进行对象方法或属性的调用,所以如何对delphi窗体进行简洁,清楚,完整的描述就很重要.最好能不看界面也能进行界面编码,具体如下表所示: xx ...

  3. 【转】VS2017缺少文件

    在VS工程中,添加c/c++工程中外部头文件及库的基本步骤: 1.添加工程的头文件目录:工程---属性---配置属性---c/c++---常规---附加包含目录:加上头文件存放目录. 2.添加文件引用 ...

  4. 消息队列rabbitmq的五种工作模式(go语言版本)

    前言:如果你对rabbitmq基本概念都不懂,可以移步此篇博文查阅消息队列RabbitMQ 一.单发单收 二.工作队列Work Queue 三.发布/订阅 Publish/Subscribe 四.路由 ...

  5. dp-最长公共子序列(LCS)

    字符序列 与 字符字串的区别 序列是可以不连续的字符串 , 字串必须要是连续的 . 问题描述 : 给定两串字符串 abcde 和 acdf , 找出 2 串中相同的字符序列,观察知 相同的字符序列为 ...

  6. Miller-Rabin​素数测试算法

    \(Miller-Rabin\)​素数测试 用途 判断整数\(n\)是否是质数,在\(n\)较小的情况下,可以使用试除法,时间复杂度为\(O(\sqrt n)\).但当\(n\)的值较大的时候,朴素的 ...

  7. Djaingo 日志配置

    1.setting.py文件 # 项目级别的日志配置 BASE_LOG_DIR = os.path.join(BASE_DIR, "log") LOGGING = { 'versi ...

  8. Treap基本用法总结

    Treap=Tree+Heap  起名的人非常有才 Treap是啥? 一棵二叉搜索树可能退化成链,那样各种操作的效率都比较低 于是可爱的Treap在每个节点原先值v的基础上加了一个随机数rnd,树的形 ...

  9. elasticsearch(lucene)索引数据过程

    倒排索引存储-分段存储(lucene的功能)在lucene中:lucene index包含了若干个segment在elasticsearch中:index包含了若干主从shard,shard包干了若干 ...

  10. 「 神器 」在线PDF文件管理工具和图片编辑神器

    每天进步一丢丢,连接梦与想 在线PDF文件管理工具 完全免费的PDF文件在线管理工具,其功能包括:合并PDF文件.拆分PDF文件.压缩PDF文件.Office文件转换为PDF文件.PDF文件转换为JP ...