在写完基础的布局之后,下一课我们会学习一下如何使用Android中一个非常重要,但是对于新手略有困难的ListView,甚至很久以前都有人说过,会不会写ListView是Android能否入门的第一步。

  好了,说了这么多,写这个教程也是希望大家能加深一下印象,提前预习,以免听沙龙的时候一头雾水。

  如上图所示的界面就是一个ListView,如名字所说,ListView就是一个列表控件,通过名为Adapter的内容填充器,对其进行填充。

  这是ListView的原理图,其中的Cursor大家不用管,Cursor涉及到了数据库的操作,主要看的一条线是从ArrayList-----》 Adapter -------》 ListView。

  从这个步骤我们可以看出,使用ListView的过程,就是从数据(Arraylist),到接收器(Apapter)再放进ListView中的。

  其中的ArrayList可以认为是可以放任意东西的一种链表使用ArrayList<对象>的方式进行存储。

 1.首先我们需要一个Item的样式,就是列表里的每一项长得是什么样的。

  

  这就是我们需要的一个样式,其中出现了一个图标,一段文本,一个可点击的框(CheckBox)。

  

 <?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">
<ImageView
android:id="@+id/list_img"
android:layout_margin="8dp"
android:src="@mipmap/ic_launcher"
android:layout_width="32dp"
android:layout_height="32dp" />
<TextView
android:id="@+id/list_text"
android:singleLine="true"
android:text="哈哈哈哈哈哈哈哈"
android:layout_centerVertical="true"
android:layout_toRightOf="@+id/list_img"
android:layout_width="wrap_content"
android:layout_height="wrap_content" />
<CheckBox
android:layout_centerVertical="true"
android:layout_alignParentRight="true"
android:layout_gravity="right"
android:layout_width="wrap_content"
android:layout_height="wrap_content" />
</RelativeLayout>

  当然作为我们默认的一个布局样式,里面最好什么都不填充。

  2.现在我们有了一个布局了,我们需要建立一个与之相对的数据对象存入三个内容。

 public class ListInfo {
private int list_img;
private String list_text;
private boolean list_click; public ListInfo(int list_img, String list_text, boolean list_click) {
this.list_img = list_img;
this.list_text = list_text;
this.list_click = list_click;
} public int getList_img() {
return list_img;
} public String getList_text() {
return list_text;
} public boolean isList_click() {
return list_click;
}
}

  这个类中包含刚才视图中的三个信息,一个资源id,一个文本,一个是否点击的boolean值。

 3.最重要的接收器来了,新建一个类,继承BaseAdapter:

  继承之后会默认复写四个方法。

  

     @Override
public int getCount() {
return 0;
} @Override
public Object getItem(int i) {
return null;
} @Override
public long getItemId(int i) {
return 0;
} @Override
public View getView(int i, View view, ViewGroup viewGroup) {
return null;
}

  从名字中就能看出这些方法是用来干什么的了,getCount获得总数目,getItem返回每项的一个对象,getItemId直接返回i就好,getView获取每项的视图。

  除了这些,我们还需要两个东西,一个Context上下文用于需找View,一个ArrayList就是我们用于填充的数据了,这两个东西都要通过构造函数来实现。

  

     private ArrayList<ListInfo> userList;
private Context context;

  ArrayList里面存放的对象就是我们刚才创建的那个ListInfo。

  构造函数:

    public ListAdapter(Context context, ArrayList<ListInfo> userList) {
this.context = context;
this.userList = userList;
}

  有了这些东西我们就能修改之前的三个方法了:

    @Override
public int getCount() {
return userList.size();
} @Override
public Object getItem(int i) {
return userList.get(i);
} @Override
public long getItemId(int i) {
return i;
}

  分别用数据的size,get的Item,还有i返回。

4.下面最重要的就是关于getview的写法:

   我们都知道布局与数据建立连接是通过先找到布局,再填充数据的方式进行的,但是ListView有很多子项,每次都要找一个个布局再填充是一个非常消耗系统机能的方式,

所以我们使用ViewHolder的方式进行缓存布局,防止多次轮询的消耗。

  所谓的ViewHolder就是通过一个内部类来缓存布局:

  

    private class ViewHolder{
private ImageView imageView;
private TextView textView;
private CheckBox checkBox;
}

  这个类里包含我们一个布局所需的全部控件,一个ImageView,一个TextView,一个CheckBox,这个类作为ListAdapter的一个内部类。

  然后这是getview:

     @Override
public View getView(int i, View view, ViewGroup viewGroup) {
// 首先新建viewHolder实例,由于getView这个函数会在每个Item生成的时候都运行一次,
// 所以我们用了这种写法
ViewHolder viewHolder = null;
// view还是null时,此时为第一次创建
if(view == null){
// 新建实例
viewHolder = new ViewHolder();
// 为View添加布局,此处View是Item的View
view = LayoutInflater.from(context).inflate(R.layout.list_item,null);
// 为ViewHolder填充
viewHolder.imageView = (ImageView)view.findViewById(R.id.list_img);
viewHolder.textView = (TextView)view.findViewById(R.id.list_text);
viewHolder.checkBox = (CheckBox)view.findViewById(R.id.list_check);
// 给View设定额外的标签,可存储一个数据,我们把ViewHolder存进去
view.setTag(viewHolder);
}else {
// 此处已经是>=2 创建Item了
// 把view从tag中拿出来
viewHolder = (ViewHolder)view.getTag();
}
// 从ArrayList找到当前项的数据
ListInfo listInfo = userList.get(i);
// 逐个填充
viewHolder.imageView.setImageResource(listInfo.getList_img());
viewHolder.textView.setText(listInfo.getList_text());
viewHolder.checkBox.setChecked(listInfo.isList_click());
return view;
}

  注释写的已经很详细了。

5.在Activity中使用:

 布局中添加:

  

     <ListView
android:id="@+id/listview"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
/>

  Activity中添加:

  

         ListView listView = (ListView)findViewById(R.id.listview);

         ArrayList<ListInfo> arrayList = new ArrayList<>();

         for(int i = 0;i < 10;i++){
arrayList.add(new ListInfo(R.mipmap.ic_launcher,"蛤蛤蛤蛤",true));
arrayList.add(new ListInfo(R.mipmap.ic_launcher,"蛤蛤",false));
} ListAdapter adapter = new ListAdapter(this,arrayList); listView.setAdapter(adapter);

  注意到新建了ArrayList然后随意new了20个子项。

  然后填充进Adapter里,然后再给ListView添加Adapter就可以了。

  

  这就是最后完成的界面了!大家试试吧!

  源码下载

ListView的基础应用的更多相关文章

  1. ListView的基础入门

    1.先在XML中定义一个ListView视图 2.获得ListView,在Mainactivity中声明 3.创建一个类继承适配器BaseAdapter,实现四个方法 public class MyL ...

  2. Android学习之ListView使用基础

    1.ListView的简单用法 1.1 布局 <LinearLayout xmlns:android="http://schemas.android.com/apk/res/andro ...

  3. Xamarin.Android 入门之:Listview和adapter

    一.引言 不管开发什么软件,列表的使用是必不可少的,而本章我们将学习如何使用Xamarin去实现它,以及如何使用自定义适配器.关于xamarin中listview的基础和适配器可以查看官网https: ...

  4. 【转】整理一下Android中的ListView

    原文网址:http://sunbofu.blog.51cto.com/6431507/1280441 Android中的listview目测是一个使用频率很高的组件,所以今天来总结一下listview ...

  5. android学习--视图列表(ListView和ListActivity)

    说明: 视图列表(ListView和ListActivity)与AutoComplete.Spinner类似,它们都须要一个供显示的列表项,能够须要借助于内容Adapter提供显示列表项 创建List ...

  6. JavaFX它ListView使用

    ListView它是通过同一控制非.在JavaFX在.ListView此外,它拥有非常丰富的功能.下列.让我们来看看如何使用ListView. ListView位于javafx.scene.contr ...

  7. Android开发之漫漫长途 XIV——ListView

    该文章是一个系列文章,是本人在Android开发的漫漫长途上的一点感想和记录,我会尽量按照先易后难的顺序进行编写该系列.该系列引用了<Android开发艺术探索>以及<深入理解And ...

  8. Android开发技巧——自定义单选或多选的ListView

    这篇其实应该是属于写自定义单选或多选的ListView的基础教程,无奈目前许多人对此的实现大多都绕了远路,反而使得这正规的写法倒显得有些技巧性了. 本文原创,转载请注明在CSDN上的出处: http: ...

  9. Android 使用ListView显示信息列表

    课程目标1.理解ListView的基础使用2.学会熟练运用两种适配器(ArrayAdapter.SimpleAdapter)3.学会熟练运用两种监听器(OnScrollListener.OnItemC ...

随机推荐

  1. 初探百度F.I.S — 由工具到解决方案

    1. 前言 阅兵放假三天,我哪儿也没去,宅着看了一些东东:git命令行.svn命令以及下面的主角——百度FIS.对看过的git.svn的命令也做了一些总结,请参见:<git命令学习笔记>和 ...

  2. 使用 jQuery & CSS3 实现优雅的手风琴效果

    手风琴效果常用于切换显示一组内容,这种方式既可以节省网页空间又可以有动画效果.今天,我们将创造一个优雅的手风琴内容效果.这个想法是有悬停时滑出一些垂直手风琴标签.我们将添加一些 CSS3 属性来提升外 ...

  3. 最简单的tab切换

    JS: $(".con").eq(0).show();    $(".btn span").click(function(){        var num = ...

  4. 程序新能优化-SQL优化

  5. 为Autodesk Viewer添加自定义工具条

    如果你参加过我们近期的活动,你就会频繁的听到我们现在正在做的Autodesk Viewer大模型浏览器,这是一个不需要下载任何插件,基于WebGL技术的浏览器,可以支持几十种数据格式.同时viewer ...

  6. 为Windows Azure Web站点添加MIME类型解决文件下载失败的问题

    这几天在倒腾Autodesk 360 Viewer,前面的文章也介绍过了,这将是一个全新的在线模型浏览工具.我做了个实验,把A360Viewer放在一个web 站点,然后发布到Windows Azur ...

  7. 如何编写Vault插件扩展Vault Explorer的功能

    今天练习了一下Vault Explorer的扩展程序,基本上是Vault SDK中的HelloWord示例程序.如果你刚刚开始接触Vault的二次开发,希望对你有帮助. 开始之前,你需要安装Vault ...

  8. 如何获取应用宝APP ID

    二百二维码支持绑定应用宝ID后,android 扫码下载后,微信直接下载APP,不打开应用宝页面,非常方便APP进行推广 那如何获取应用宝APP ID呢, 请参考下面的教程    一, 打开http: ...

  9. linux 修改home 目录

         第一种方法:vi /etc/passwd 找到要修改的用户那几行,修改掉即可.此法很暴力,建议慎用. /etc/passwd文件格式 登录名:加密口令:数字用户ID:数字组ID:注释字段:起 ...

  10. Android--ListView下拉刷新

    整理了下以前写的小项目,ListView的下拉刷新,虽然小但还是想纪念下..适合新手看,大神略过... 效果图:     代码:  实体类 package com.example.listviewre ...