起源:ListView是Android开发中使用最广泛的一种控件,它以垂直列表的形式显示所有列表项。
创建ListView有两种方式:
☆ 直接使用ListView进行创建。
☆让Activity继承ListActivity。
一旦在程序中获得了ListView之后,接下来就需要为ListView设置它要显示的列表子项,借助Adapter来实现。
ListView常用XML属性
下面通过一个简单的例子来展示ListView的基本使用方法,效果图见文章结尾。
一、XML Code
1.activiyt_main.xml
在主xml文件内只添加一个ListView控件。
代码如下:
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="horizontal"> <ListView
android:id="@+id/list_view"
android:layout_width="match_parent"
android:layout_height="match_parent" >
</ListView> </LinearLayout>
2.item.xml
在这个xml内设置每个子列的布局样式,此处简单添加一个ImageView和TextView,分别用来显示汽车Logo和品牌。
代码如下:
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="horizontal"
android:padding="5dp"
android:background="#FFFFFF"> <ImageView
android:id="@+id/car_logo"
android:layout_width="wrap_content"
android:layout_height="wrap_content"/>
<TextView
android:id="@+id/car_name"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center"
android:layout_marginLeft="10dp"/> </LinearLayout>
二、Java Code
首先从网上下了一组汽车Logo作为素材。
接着定义一个实体类,作为ListView适配器的适配类型。
1.Car.java
Car类只有两个属性:品牌名字和LogoId,以及getName()和getLogoId两个方法。
代码如下:
package com.michael.listviewtest; public class Car { private String name; private int logoId; public Car(String name, int logoId) {
this.name = name;
this.logoId = logoId;
} public String getName() {
return name;
} public int getLogoId() {
return logoId;
} }
前文已经讲过,若想展现ListView内的子项,需要创建一个自定义的适配器。此处将自定义的适配器继承自ArrayAdapter,并将泛型指定为Car类。
2.CarAdapter.java
重点重写getView()方法,这个方法在每个子项被滚动到屏幕内时都会被调用。首先通过getItem()方法得到当前子项的Car实例。为了提高性能,对ListVie进行适当优化。在CarAdapter类增加一个内部类ViewHolder,用于对控件的实例进行缓存。当convertView为空的时候,首先使用LayoutInflater的inflater()方法为子项加载传入的布局,再创建一个ViewHolder对象,并将控件的实例都存放在ViewHolder里,然后调用ViewHolder的setTag()方法,将ViewHolder对象存储在View中。当convertView不为空时则调用View的getTag()方法,把ViewHolder重新取出。这样的话,所有的控件实例都缓存在ViewHolder里,省去了每次通过findVoewById()方法来获取控件实例的步骤,提高了ListView的运行效率。
代码如下:
package com.michael.listviewtest; import java.util.List; import android.content.Context;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.ArrayAdapter;
import android.widget.ImageView;
import android.widget.TextView; public class CarAdapter extends ArrayAdapter<Car>{ private int resourceId; public CarAdapter(Context context, int resource, List<Car> objects) {
super(context, resource, objects);
resourceId = resource;
} @Override
public View getView(int position, View convertView, ViewGroup parent) {
Car car = getItem(position);
View view;
ViewHolder viewHolder;
if(convertView == null) {
view = LayoutInflater.from(getContext()).inflate(resourceId, null);
viewHolder = new ViewHolder();
viewHolder.carLogo = (ImageView)view.findViewById(R.id.car_logo);
viewHolder.carName = (TextView)view.findViewById(R.id.car_name);
view.setTag(viewHolder);
}else {
view = convertView;
viewHolder = (ViewHolder)view.getTag();
}
viewHolder.carLogo.setImageResource(car.getLogoId());
viewHolder.carName.setText(car.getName());
return view;
} class ViewHolder {
ImageView carLogo;
TextView carName;
}
}
3.MainActivity.java
最后把视图的加载,数据的初始化以及ListView和Adapter的适配操作添加到MainActivity里。
此外为ListView的每个子项添加一个点击事件,通过setOnItemClickListener()方法,并重写onItemClick()方法,此处就通过Toast子项包含实例的名字简单实现。
代码如下:
package com.michael.listviewtest; import java.util.ArrayList;
import java.util.List; import android.app.Activity;
import android.os.Bundle;
import android.view.View;
import android.widget.AdapterView;
import android.widget.AdapterView.OnItemClickListener;
import android.widget.ListView;
import android.widget.Toast; public class MainActivity extends Activity { private List<Car> carLists = new ArrayList<Car>(); @Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
initCars();
CarAdapter adapter = new CarAdapter(MainActivity.this, R.layout.item, carLists);
ListView listView = (ListView)findViewById(R.id.list_view);
listView.setAdapter(adapter);
listView.setOnItemClickListener(new OnItemClickListener() { @Override
public void onItemClick(AdapterView<?> parent, View view, int position,
long id) {
Car car = carLists.get(position);
Toast.makeText(MainActivity.this, car.getName(), Toast.LENGTH_SHORT).show();
}
});
} public void initCars() {
Car lotus = new Car("Lotus", R.drawable.lotus);
carLists.add(lotus);
Car lamboghini = new Car("Lamboghini", R.drawable.lamboghini);
carLists.add(lamboghini);
Car bmw = new Car("BMW", R.drawable.bmw);
carLists.add(bmw);
Car fiat = new Car("Fiat", R.drawable.fiat);
carLists.add(fiat);
Car cadillac = new Car("Cadillac", R.drawable.cadillac);
carLists.add(cadillac);
Car mercedes = new Car("Mercedes", R.drawable.mercedes);
carLists.add(mercedes);
Car skoda = new Car("Skoda", R.drawable.skoda);
carLists.add(skoda);
Car volvo = new Car("Volvo", R.drawable.volvo);
carLists.add(volvo);
Car nissan = new Car("Nissan", R.drawable.nissan);
carLists.add(nissan);
Car ferrari = new Car("Ferrari", R.drawable.ferrari);
carLists.add(ferrari);
Car porsche = new Car("Porsche", R.drawable.porsche);
carLists.add(porsche);
Car rollsroyce = new Car("Rollsroyce", R.drawable.rollsroyce);
carLists.add(rollsroyce);
}
}
效果图如下: