在开发过程中经常使用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. 使用Theia——创建插件

    上一篇:使用Theia——创建扩展包 创建Theia插件 下面我们来看看如何创建Theia插件.作为示例,我们将注册一个Hello World命令,该命令显示一个“Hello World”通知.本文将 ...

  2. tomcat服务器基本操作:实现www.baidu.com访问tomcat中项目

    0.实现用其他的域名,而不再使用localhost:8080/xxx,访问tomcat中的项目: (1). 修改访问tomcat的端口号: (2). tomcat配置虚拟主机: (3). 本地DNS解 ...

  3. 大数据框架开发基础之Sqoop(1) 入门

    Sqoop是一款开源的工具,主要用于在Hadoop(Hive)与传统的数据库(mysql.postgresql...)间进行数据的传递,可以将一个关系型数据库(例如 : MySQL ,Oracle , ...

  4. (一)Angular+spring-security-cas前后端分离(基于ticket)认证时序图

    一.静态资源认证时序图 2. ajax请求认证拦截时序图 3.退出登录时序图

  5. Hexo 中使用 emoji 和 tasks

    替换为 markdown-it 今天在迁移博客项目的时候,发现原来在 hugo 中可以使用的 Emoji 和 tasks 功能都不能正常使用了,查询了一下原因,主要是因为 hexo 默认的解析器是 h ...

  6. CTPN中anchors代码

    import numpy as np def generate_basic_anchors(sizes, base_size=16): #base_anchor([0,0,15,15]) base_a ...

  7. 正则表达式grep命令

    grep命令 作用:文本搜索工具,根据用户指定的“模式”对目标文本逐行进行匹配检查:打印匹配到的行. 模式::由正则表达式字符及文本字符所编写的过滤条件 语法:grep [OPTIONS] PATTE ...

  8. 通过例子进阶学习C++(四)计算2的64次方,不服写写看

    ​ 本文是通过例子学习C++的第四篇,通过这个例子可以快速入门c++相关的语法. 1.乍一看题目非常简单,简单思考一下,可以通过for循环实现: #include <iostream> u ...

  9. python列表(数组)

    列表(list)  就是 数组 - 列表是Python中的一个对象 - 对象(object)就是内存中专门用来存储数据的一块区域 - 之前我们学习的对象,像数值,它只能保存一个单一的数据 - 列表中可 ...

  10. .Net Core Web Api实践(四)填坑连接Redis时Timeout performing EVAL

    前言:前两篇文章.net core+Redis+IIS+nginx实现Session共享中,介绍了使用Microsoft.Extensions.Caching.Redis实现Session共享的方法, ...