`
stephen830
  • 浏览: 2978104 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

ListView的使用和特性研究(一)

 
阅读更多

ListView的使用和特性研究(一)

 

转载自 : http://www.android777.com/index.php/tutorial/listview-1.html

 

ListView应该是android里最常用的显示数据的控件了。它用来将集合数据一个个抽取出来按照从头到尾往下显示的控件里,这些是在手机中经常看到的一些布局。

 

我们可以看从简单的到难的布局,一步步学习如何使用ListView来构建UI和了解ListView的原理和实现机制。

 

我们看看最简单的ListView效果:

 


 

带有图标的ListView效果图:


其他稍微复杂的ListView的布局。



 

下面我们从简单到难的步骤分析演示如何使用android中的ListView。

 

1.简单的ListView布局(单行显示信息)


首先我们先创建存放ListView的Activity所需要的布局xml文件。

 

list_view1.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout
  xmlns:android="http://schemas.android.com/apk/res/android"
  android:id="@+id/linerlayout1"
  android:orientation="vertical"
  android:layout_height="fill_parent"
  android:layout_width="fill_parent"
  >
     <ListView
        android:id="@+id/list1"
        android:layout_width="fill_parent"
        android:layout_height="fill_parent"
     />
</LinearLayout>
 

上面代码我们创建了一个布局配置文件,里面只放了一个ListView控件,将其ID设置为:list1。

 

接下来是java代码,大概步骤是:先找出ListView,然后往ListView里填充东西。

 

	final String[] data = {"第一章","第二章","第三章","第四章","第五章"};
	
    /** Called when the activity is first created. */
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.list_view1);
        
        ListView lv = (ListView) findViewById(R.id.list1);
        ArrayAdapter<String> adapter = new ArrayAdapter<String>(
        		this,android.R.layout.simple_list_item_1,data);
        lv.setAdapter(adapter);
    }
 


 以上是运行这个运行这个ListView,并往里面填充东西的代码。在android中,由于数据来源多种多样,如:从资源文件读取、从数据库中读取、从 网络上其他地方读取而最终这些数据都将被展示在ListView中,所以这边android就用了adapter设计模式,对应每种数据来源使用对应的 adapter来连接数据和视图。



 以上的代码很简单,运行效果如下:


上面代码有一定的局限性,就是比如你要创建稍微复杂点的布局,如名片卡,显示名字,电话信息,地址等。像这种稍微复杂的布局就无法用上面的来做,因为在上面的例子中,ArrayAdapter里装的数据都是String型,单行仅能显示一条数据。

 

 

2.进阶的ArrayAdapter,自定义布局来显示ArrayAdapter里面装的对象。

 

这边我们沿用上面的xml布局,因为要往ArrayAdapter里面装对象,所以这边我们先定义一个对象,最后要做的就是将对象的信息显示在ListView中。

 

package com.zhouzijing.android;

public class Person {
	 
    public String name;
    public int age;
    public String email;
    public String address;
 
    public Person(String name, int age, String email, String address) {
        super();
        this.name = name;
        this.age = age;
        this.email = email;
        this.address = address;
    }
 
    @Override
    public String toString() {
        return "Person [name=" + name + ", age=" + age + ", email=" + email
                + ", address=" + address + "]";
    }
 
}

 

 

接下来将这个对象装进ArrayAdapter显示出来。

 

    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.list_view1);
        
      //创建数据源.
        Person[] data = new Person[]{
            new Person("蔡志坤",25,"ffczk86@gmail.com","厦门市"),
            new Person("李杰华",25,"aa@bb.com","漳州市"),
            new Person("张亮",25,"cc@gmail.com","厦门市"),
            new Person("陈旭",25,"ccadd@gmail.com","厦门市"),
            new Person("刘玄德",25,"ffczk86@gmail.com","福州市")
        };
        
        ListView lv = (ListView) findViewById(R.id.list1);
        ArrayAdapter<Person> adapter = new ArrayAdapter<Person>(
        		this,android.R.layout.simple_list_item_1,data);
        lv.setAdapter(adapter);
    }

 

效果图是:


依据上面的结果,可以得出结论,ArrayAdapter默认是调用它里面装的对象的toString方法来展示数据。但是上面的信息显得太凌乱,所以这 边要介绍另外一个ArrayAdapter的使用方法,就是扩展ArrayAdapter ,通过继承它来实现自定义视图的展现。所以刚开始要做的是先创建 一个xml布局文件,确定ListView里每行数据显示的样式。

 

list_view1_item.xml

 

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout
  xmlns:android="http://schemas.android.com/apk/res/android"
  android:id="@+id/linerlayout1"
  android:orientation="vertical"
  android:layout_height="fill_parent"
  android:layout_width="fill_parent"
  >
     <TextView
        android:id="@+id/person_name"
        android:textSize="23sp"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
     />
     <TextView
        android:id="@+id/person_age"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
  	/>
  	<TextView
        android:id="@+id/person_email"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
  	/>
  	<TextView
        android:id="@+id/person_address"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
  	/>
</LinearLayout>
 

接下来通过继承ArrayAdapter,然后重写getView方法,用来将自定义布局的View注入到ListView中,然后将每条数据装进对应的View中。

 

PersonAdapter.java

package com.zhouzijing.android;

import android.content.Context;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.ArrayAdapter;
import android.widget.TextView;

public class PersonAdapter extends ArrayAdapter<Person>{

	LayoutInflater mLayoutInflater;
    int resourceId;
    Context mContext;
    
	public PersonAdapter(Context context, int resourceId, Person[] objects) {
		super(context, resourceId, objects);
		
		//获取LayoutInflater 服务,用来从预定义的xml布局创建view对象.
        this.resourceId = resourceId;
        mLayoutInflater = LayoutInflater.from(context);
	}

	@Override
	public View getView(int position, View convertView, ViewGroup parent) {
		if(convertView == null){
            //创建新的view视图.
            convertView = mLayoutInflater.inflate(resourceId, null);
        }
        //获取当前要显示的数据
        Person person = getItem(position);

        TextView name = (TextView) convertView.findViewById(R.id.person_name);
        TextView age = (TextView) convertView.findViewById(R.id.person_age);
        TextView email = (TextView) convertView.findViewById(R.id.person_email);
        TextView address = (TextView) convertView.findViewById(R.id.person_address);

        name.setText(person.name);
        age.setText(String.valueOf(person.age));
        email.setText(person.email);
        address.setText(person.address);

        return convertView;
	}
	
	

	

}
 

 

调用自定义的PersonAdapter

    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.list_view1);
        
      //创建数据源.
        Person[] data = new Person[]{
            new Person("蔡志坤",25,"ffczk86@gmail.com","厦门市"),
            new Person("李杰华",25,"aa@bb.com","漳州市"),
            new Person("张亮",25,"cc@gmail.com","厦门市"),
            new Person("陈旭",25,"ccadd@gmail.com","厦门市"),
            new Person("刘玄德",25,"ffczk86@gmail.com","福州市")
        };
        
        ListView lv = (ListView) findViewById(R.id.list1);
        PersonAdapter adapter = new PersonAdapter(
        		this,R.layout.list_view1_item,data);
        lv.setAdapter(adapter);
    }
 

最终的效果图是:


 

以上继承ArrayAdapter类,重写getView方法,里面的实现还不是最高效率,这边涉及到ListView的懒加载机制和实现的原理,以后详论。

 


3.通过上面两个例子我们可以简单的了解创建ListView的一般步骤,总的说来可以总结为下面几个步骤。

  • 创建ListView里item的布局xml文件,第一个例子引用了android.R.layout.simple_list_item_1 ,所以省略掉创建的步骤,缺点是只能显示一条信息。
  • 创建数据源,数据源可能是手动添加或查询数据库获取。
  • 通过继承ArrayAdapter,重写getView方法来进行数据绑定。

 

 

 

 

 

 

  • 大小: 12.7 KB
  • 大小: 41.5 KB
  • 大小: 66.9 KB
  • 大小: 48.3 KB
  • 大小: 12.7 KB
  • 大小: 14 KB
  • 大小: 39.3 KB
  • 大小: 25.6 KB
分享到:
评论
3 楼 Jasper_Success 2012-02-09  
请教一下带有图标的那个是怎么弄得?谢谢
2 楼 copier8 2011-11-09  
好文章!
1 楼 dwpcny 2011-09-05  
引用
[i][/i]
[img][/img][url][/url][flash=200,200][/flash]

相关推荐

    老外写的ListView

    ListView的特性包括但不限于:滚动流畅性、Item点击事件、Header和Footer的添加、自定义适配器和视图复用等。 【ObjectListViewFull】 根据压缩包子文件的文件名称,"ObjectListViewFull"可能是一个完整的、包含...

    Android-滑动listview标题置顶listview吸顶效果

    通过研究这些内容,开发者可以更深入地了解和掌握滑动ListView标题置顶、吸顶效果以及透明状态栏的具体实现方法。这不仅可以提升个人技能,还能为实际项目开发提供宝贵的参考。 总之,滑动ListView时标题置顶、...

    一个透明Listview和透明Panel

    标题中的“一个透明Listview和透明Panel”是指在编程中创建具有透明效果的ListView和Panel控件。...通过研究和使用这些源码,开发者可以学习到如何在 Delphi 平台上创建具有高级图形特性的用户界面。

    ListView滑轮选择的控件

    总之,ListView滑轮选择控件是Android开发中的一个创新设计,它结合了WheelView的直观滚动体验和ListView的灵活性,为用户提供了一种高效且易于使用的交互方式。通过自定义ListView及其适配器,以及对滚动事件的精确...

    VB6 ListView处理海量数据

    在提供的"Virtual_ListView_Demo"文件中,应该包含了如何使用虚拟模式处理海量数据的VB6示例代码,你可以通过学习和研究这个示例来掌握这一技术。通过合理利用ListView的虚拟模式,即使处理百万条数据,也能保证应用...

    强大的listview效果集合项目

    在性能优化方面,ListView的一个重要特性是视图复用,通过`convertView`参数在`getView()`方法中实现。这样可以在滚动时重用已创建但不再可视的视图,降低内存消耗和提高性能。同时,合理地使用ViewHolder模式也能...

    一个支持listview的widget

    本资源包含了一个专门支持ListView显示的Widget,以及与之相关的ADW源码和Launcher Plus源码。这将帮助开发者深入了解如何在Widget中集成ListView,提升用户体验,并且可以借鉴源码来优化自己的应用设计。 首先,...

    ListView的两种实现方法

    在Android开发中,ListView是一种非常常见的视图组件,它用于展示大量的数据列表,通常与Adapter配合使用,可以实现数据的动态加载和滚动效果。本文将详细介绍两种实现ListView的方法:一种是继承自`...

    C# 强大的自定义ListView ObjectListViewFull-2.4.1

    通过研究和使用ObjectListViewDemo,开发者可以快速掌握这个库的用法,并将其应用到自己的项目中,提升应用的用户体验和功能多样性。无论你是初学者还是经验丰富的开发者,ObjectListView都值得你去探索和学习。

    一个实现抽屉滑动删除效果的listView 源码

    当用户在ListView的某一项上滑动时,我们需要计算滑动的方向和距离,以判断是否触发删除操作。这涉及到Android的MotionEvent类和它的ACTION_DOWN、ACTION_MOVE、ACTION_UP等常量,以及getRawX()和getRawY()方法来...

    横向ListView的完整实现(包含基于横向listview做的一个小相册demo).zip

    在这个案例中,开发者可能使用了`RecyclerView`,因为它更高效、更灵活,并且提供了诸如动画和视图复用等高级特性。 1. **使用RecyclerView** - RecyclerView是Android Lollipop引入的一个组件,它比ListView更...

    Android商城项目listview展示,真实项目抽取出来的,可以慢慢研究

    这个项目提取自一个真实的Android应用,它展示了如何利用ListView组件来实现商品列表的展示,同时结合下拉刷新和上拉加载功能,以及在顶部添加广告轮播的功能。以下是对这些关键技术点的详细说明: 1. **ListView**...

    C# listview大合集,里面绝对有一款是你想要的效果

    总之,这个C# ListView合集涵盖了ListView的多种应用场景和高级特性,帮助你提升程序的用户体验和功能完整性。无论你是希望创建一个简单的数据列表,还是需要一个功能丰富的界面,都能在这些示例中找到灵感和实现...

    使用ListView控件实现漂亮的自定义表格效果实例源码

    总之,本实例源码提供了一个使用ListView实现自定义表格效果的范例,涉及到了Android开发中的数据绑定、视图复用、事件监听等多个关键知识点,对于学习和提高Android UI设计能力大有裨益。通过深入研究和实践,...

    listview上拉下拉

    在Android开发中,ListView是常用的一种控件,用于展示大量数据列表。"listview上拉下拉"这个主题主要涉及到ListView的滚动...通过研究和实践这些资源,开发者可以掌握这一常见的Android开发技巧,提升应用的用户体验。

    Android自制带刷新的ListView

    然而,原生的ListView并不直接支持下拉刷新和上拉加载更多的功能,这在现代移动应用中是必不可少的特性。"Android自制带刷新的ListView"这个主题正是针对这一需求,提供了一种实现方式来增强ListView的功能。 首先...

    listview嵌套无限轮播+分类demo

    ListView的另一个特性是它可以嵌套其他视图,例如在这个案例中,开发者可能创建了一个ListView,其中的每个item都是一个轮播视图,这样就可以实现分类下的图片或内容无限轮播。这种嵌套布局在电商应用、新闻阅读应用...

    ListView水平滑动分页

    另外,注意在API 17及以上版本,可以使用RecyclerView替代ListView,它提供了更强大的滑动和动画支持。 7. **使用第三方库**:为了简化开发,可以考虑使用一些第三方库,如`androidx.recyclerview.widget....

    安卓listview相关相关-垂直滚动的viewpager改造listview过来的.zip

    你需要确保Adapter的这一特性得到正确实现,以避免内存浪费和性能问题。 6. **适配器的生命周期管理**:因为ViewPager会缓存页面,所以需要正确处理Adapter的添加、删除和更新操作,确保数据和视图的一致性。 7. *...

    listview圆角示例源码

    2. **适配器(Adapter)的使用**:接着,我们需要创建一个自定义的Adapter,用于填充ListView的数据。在getView()方法中,将上述自定义布局设置给列表项的视图,并根据数据填充内容。 ```java public class ...

Global site tag (gtag.js) - Google Analytics