1.介绍

总结:ListView 是一个可以以垂直滚动的方式展示条目内容的一个列表,条目的内容来自于ListAdapter(适配器)。

2.操作步骤

3.ListView中convertView和ViewHolder的工作原理

Android中有个叫做Recycler(反复循环器)的构件,下图是它的工作原理:

(1)如果你有10亿个项目(item),其中只有可见的项目存在内存中,其他的在Recycler中
(2)当item1滚出屏幕,并且一个新的项目从屏幕地段上来时,ListView再请求一个type1视图。convertView此时不是空值了,它的值是item1.你只需要设定新的数据返回convertView,不必重新创建一个视图。这样直接使用convertView从而减少了很不不必要view的创建

4.典型ListView数据适配器方法分析

示例代码:

(1)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"
android:padding="6dp"
android:layout_centerVertical="true"> <TextView
android:layout_marginTop="10dp"
android:id="@+id/tv_phone_number"
android:text="拦截号码"
android:textSize="18dp"
android:textColor="#000000"
android:layout_width="wrap_content"
android:layout_height="wrap_content" /> <TextView
android:id="@+id/tv_function_type"
android:text="拦截类型"
android:textSize="18dp"
android:layout_below="@+id/tv_phone_number"
android:layout_marginTop="10dp"
android:textColor="#000000"
android:layout_width="wrap_content"
android:layout_height="wrap_content" /> <!--<ImageView-->
<!--android:layout_alignParentRight="true"-->
<!--android:background="@drawable/selector_black_call_delete1_bg"-->
<!--android:layout_width="wrap_content"-->
<!--android:layout_height="wrap_content" />--> <!--android:background="@drawable/selector_black_call_delete1_bg"-->
<ImageView
android:id="@+id/iv_black_call_delete"
android:layout_alignParentRight="true"
android:background="@drawable/selector_black_call_delete1_bg"
android:layout_width="wrap_content"
android:layout_height="wrap_content" />
</RelativeLayout>

(2)java后台代码:

/**
* listview的数据适配器
*/
private class MyAdapter extends BaseAdapter {
//getCount决定了listview一共有多少个item
@Override
public int getCount() {
return blackCallList.size();
} //获得相应数据集合中特定位置的数据项
@Override
public Object getItem(int position) {
return blackCallList.get(position);
} //返回该postion对应item的id
@Override
public long getItemId(int position) {
return position;
} //getView()返回了每个item项所显示的view
@Override
public View getView(final int position, View convertView, ViewGroup parent) {
//复用convertView,并减少了findViewById的次数
ViewHolder holder=null;
//1.convertView为空,代表当前的条目是首次构建,需要查找控件,查找到的控件在后续的条目中可以去做复用
if(convertView==null){
convertView=View.inflate(getApplicationContext(), R.layout.listview_black_list_call_item, null);
//2.创建一个ViewHolder对象,去存储所找到的控件
holder=new ViewHolder();
holder.tv_phone_number=convertView.findViewById(R.id.tv_phone_number);
holder.tv_function_type=convertView.findViewById(R.id.tv_function_type);
holder.iv_black_call_delete=convertView.findViewById(R.id.iv_black_call_delete);
//3.存储当前的ViewHolder对象
convertView.setTag(holder);
}else {
//4.复用convertView中存储的ViewHolder对象
holder= (ViewHolder) convertView.getTag();
} holder.tv_phone_number.setText(blackCallList.get(position).getPhoneNumber());
holder.tv_function_type.setText(blackCallList.get(position).getFunctionType()); //给图片imageview绑定点击事件
holder.iv_black_call_delete.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
BlackListCallDBUtil.deleteOneRecord(blackCallList.get(position).getPhoneNumber(),blackCallList.get(position).getFunctionType());
initData(); //重新显示列表数据
}
});
return convertView;
} private class ViewHolder {
public TextView tv_phone_number;
public TextView tv_function_type;
public ImageView iv_black_call_delete;
}
}

(1)getCount()方法:决定了listview一共有多少个item(条目)

(2)getItem()方法:获得相应数据集合中特定位置的数据项

常用于:listview的点击事件(例如setOnItemSelectedListener),方便地调用来获取获取当前行数据。

(3)getItemId()方法:返回该postion对应item的id

(4)getView()方法:返回了每个item项所要显示的view

5.内存溢出问题(快速拖到条目)

利用getView(int i, View view, ViewGroup viewGroup) 方法的第二个参数,回收已经隐藏的组件

6.listView 显示数据的原理

mvc模式:

<1>javaweb中

m:mode 数据 ;v:view 视图 jsp ;c:controller servlet

<2>Android

m:mode 数据(javabean)

v:view 视图 组件

c:adapter (适配器)

注意:无论是哪种Adapter,其作用都是把数据展示到listview中

7.xml布局

<1>activity_main.xml布局

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context=".MainActivity"> <ListView
android:id="@+id/lv_message"
android:layout_width="match_parent"
android:layout_height="match_parent"> </ListView> </LinearLayout>

注意:ListView的高度必须设置为  android:layout_height="match_parent"

<2>item_show.xml布局

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:layout_width="match_parent"
android:layout_height="wrap_content"> <ImageView
android:id="@+id/imageView"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:src="@mipmap/ic_launcher" /> <TextView
android:id="@+id/tv_title"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_toRightOf="@+id/imageView"
android:ellipsize="end"
android:singleLine="true"
android:text="掘金115-105雷霆,默里27+5+9,约基奇23+16,威少27+9+9,乔治25+9"
android:textColor="#000000"
android:textSize="20dp" /> <TextView
android:id="@+id/tv_content"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_below="@+id/tv_title"
android:layout_toRightOf="@+id/imageView"
android:ellipsize="end"
android:maxLines="2"
android:textColor="#6D6E72"
android:text="虎扑3月30日讯,雷霆坐镇主场迎来了掘金的挑战。首节比赛,约基奇展现了自己在内线的统治力,4投4中单节砍下10分7篮板2助攻。于此同时,还让对位的雷霆中锋亚当斯在首节数据挂零。凭借约基奇的出色表现,掘金在首节就取得了33-29的领先。次节比赛,掘金攻势依然凶猛,开场一波7-0的小高潮立刻将分差拉大到了两位数。但首节表现低迷的亚当斯终于迎来了复苏,5投全中砍下10分,帮助雷霆奋起直追,最终雷霆成功将分差再次缩小到了4分,两队的比分定格在了56-52。"
android:textSize="15dp" />
</RelativeLayout>

注意:采用相对布局,若图片不能加载,设置图片来源为 android:src="@mipmap/ic_launcher"

8.java后台

package com.example.lucky.test53listview;

import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.view.ViewGroup;
import android.widget.BaseAdapter;
import android.widget.ListView;
import android.widget.TextView; public class MainActivity extends AppCompatActivity {
ListView lv_message; @Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
lv_message=findViewById(R.id.lv_message);
lv_message.setAdapter(new MyListAdapter());
} //ListView的数据适配器
public class MyListAdapter extends BaseAdapter{ //设置一共需要显示的数据条数
@Override
public int getCount() {
return 60;
} //返回position位置对应的对象
@Override
public Object getItem(int i) {
return null;
} //返回position位置对应的id
@Override
public long getItemId(int i) {
return 0;
} //获取一个view,用来显示ListView的数据,会作为ListView的一个条目出现
//参数2为历史缓存对象(页面一次会显示的textView对象都是新创建的,当用户滑动列表时,后面显示textview 是复用前面的view)
@Override
public View getView(int i, View view, ViewGroup viewGroup) {
View viewShow;
if(view==null){
//创建新的view对象,可以通过打气筒(View.inflate())把一个布局资源转换成一个view对象
viewShow=View.inflate(getApplicationContext(),R.layout.item_show,null);
System.out.println("创建新的view对象"+i);
}else {
System.out.println("复用历史缓存对象"+i);
viewShow= view;
}
return viewShow;
}
}
}

9.效果图

Andriod ListView组件的使用的更多相关文章

  1. ListView组件应用源码

    首先在xml文件中定义ListView组件 <ListView android:id="@+id/show_view_list" android:layout_width=& ...

  2. 为ListView组件加上快速滑块以及修改快速滑块图像

    本文转载自:http://blog.csdn.net/ouyang_peng/article/details/46919723 作者:欧阳鹏  欢迎转载,与人分享是进步的源泉! 转载请保留原文地址:h ...

  3. Android开发 ---基本UI组件6 :只定义一个listView组件,然后通过BaseAdapter适配器根据数据的多少自行添加多个ListView显示数据

    效果图: 1.activity_main.xml 描述: 定义了一个按钮 <?xml version="1.0" encoding="utf-8"?> ...

  4. 【React Native开发】React Native控件之ListView组件解说以及最齐全实例(19)

    ),React Native技术交流4群(458982758).请不要反复加群!欢迎各位大牛,React Native技术爱好者加入交流!同一时候博客左側欢迎微信扫描关注订阅号,移动技术干货,精彩文章 ...

  5. React Native常用组件之ListView组件

    学习iOS开发的同学应该都知道UITableView,几乎每个APP中都有它的存在,而且衍生出各种形态:那么同样,ListView就是在React Native中的tableView,而且更加简单和灵 ...

  6. 我的Android进阶之旅------>如何为ListView组件加上快速滑块以及修改快速滑块图像

    使用布局文件需要将android:fastScrollEnabled="true" ,如下代码所示: <ListView android:id="@+id/list ...

  7. UI组件之AdapterView及其子类(五)ListView组件和ListActivity

    ListView组件是一个显示组件,继承AdapterView基类,前面已经介绍了分别使用ArrayAdapter,SimpleAdapter,扩展BaseAdapter来为LisView提供列表项h ...

  8. ListView组件中 onEndReached 方法在滚动到距离列表最底部一半时执行

    初次使用ListView,在写列表滚动到最底部自动加载使用到方法onEndReached, 发现: ListView组件中 onEndReached 方法在滚动到距离列表最底部一半时执行, 于是翻看文 ...

  9. React-Native Listview组件用法详解

    ListView作为React Native的核心组件,用于高效地显示一个可以垂直滚动的变化的数据列表.其中最重要的属性之一是DataSource,列表依赖的数据源,用于实例化一个ListView对象 ...

随机推荐

  1. no newline at the end of file

    [no newline at the end of file] 修复这个警告,在文件结尾回车一下就行了. 这么规定的初衷是,为了每一行都要以换行结束.  因为行尾的/表示连接下一行,如果一个文件最后一 ...

  2. ajax请求参数中含有特殊字符"#"的问题 (另附上js编码解码的几种方法)

    使用ajax向后台提交的时候 由于参数中含有#  默认会被截断 只保留#之前的字符  json格式的字符串则不会被请求到后台的action 可以使用encodeURIComponent在前台进行编码, ...

  3. Java中long和Long的区别

    Java的数据类型分两种: 1.基本类型:long,int,byte,float,double,char,short,boolean 2. 对象类型(类): Long,Integer,Byte,Flo ...

  4. Opennebula自定义VM 实现方法-Contextualizing Virtual Machines 2.2

    from:http://archives.opennebula.org/documentation:archives:rel2.2:cong There are two contextualizati ...

  5. 如何安全退出已调用多个Activity的应用

    对于单一Activity的应用来说,退出很简单,直接finish()即可.当然,也可以用killProcess()和System.exit()这样的方法. 但是,对于多Activity的应用来说,在打 ...

  6. Luogu 3698 [CQOI2017]小Q的棋盘

    BZOJ 4813 虽然数据范围很迷人,但是想树形$dp$没有前途. 先发现一个事情,就是我们可以先选择一条链,最后要走到这一条链上不回来,走到链上的点每一个只需要一步,而如果要走这条链之外的点,一个 ...

  7. CentOS7下源码包方式安装Erlang

    1.官网上下载源码包:OTP 19.1 Source File 2.把源码放在source目录中 , 解压 :tar -zxvf otp_src_19.1.tar.gz [或者 直接下载 rpm包 e ...

  8. 编写高质量代码改善C#程序的157个建议——建议46:显式释放资源需继承接口IDisposable

    建议46:显式释放资源需继承接口IDisposable C#中的每一个类型都代表一种资源,资源分为两类: 托管资源:由CLR管理分配和释放的资源,即从CLR里new出来的对象. 非托管资源:不受CLR ...

  9. 【转】SSH指南

    OpenSSH OpenSSH 是 SSH (Secure SHell) 协议的免费开源实现.它用安全.加密的网络连接工具代替了 telnet.ftp. rlogin.rsh 和 rcp 工具.Ope ...

  10. MongoDB整理笔记のGridFS

    GridFS 是一种将大型文件存储在MongoDB 数据库中的文件规范.所有官方支持的驱动均实现了GridFS 规范. GridFS是MongoDB中的一个内置功能,可以用于存放大量小文件. 官网学习 ...