ListView
一、作用
当手机屏幕空间有限而不能一次将内容显示完时,需要借助ListView允许用户通过手指上下滑动的方式将屏幕外的数据滚动到屏幕内,同时屏幕上原有的数据滚动出屏幕。例如查看QQ消息等。
二、用法
2.1新建项目
新建一个ListView
项目,修改activity_main.xml
中的代码:1
2
3
4
5
6
7
8
9
10<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent">
<ListView
android:id="@+id/list_view"
android:layout_width="match_parent"
android:layout_height="match_parent"/>
</LinearLayout>
activity_main.xml
布局中加入ListView
控件,并指定控件的id
为list_view,width
和height
与父布局相同,即布满手机屏幕
2.2新建实体类
定义一个水果实体类Fruit
,作为ListView适配器的的适配类型1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17public class Fruit {
private String name;
private int imageId;
public Fruit(String name,int imageId){
this.name=name;
this.imageId=imageId;
}
public String getName(){
return name;
}
public int getImageId(){
return imageId;
}
}
该类中定义了水果类的名称的图片id
2.3指定item布局
为ListView的子项指定一个自定义的布局,在layout目录下新建fruit_item.xml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="vertical" android:layout_width="match_parent"
android:layout_height="wrap_content">
<ImageView
android:id="@+id/fruit_image"
android:layout_width="wrap_content"
android:layout_height="wrap_content" />
<TextView
android:id="@+id/fruit_name"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center_vertical"
android:layout_marginLeft="10dp"/>
</LinearLayout>
这个布局定义了一个ImageView
用于显示水果图片,一个TextView
用于显示水果名称,并让TextView
垂直居中显示
2.4自定适配器
接下来创建一个自定义的适配器FruitAdapter
(继承自ArrayAdapter),泛型指定为Fruit
类1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18public class FruitAdapter extends ArrayAdapter<Fruit> {
private int resourceId;
public FruitAdapter(Context context, int textViewResourceId, List<Fruit> objects){
super(context,textViewResourceId,objects);
resourceId=textViewResourceId;
}
public View getView(int position, View convertView, ViewGroup parent){
Fruit fruit=getItem(position);//获得当前项的Fruit实例
View view= LayoutInflater.from(getContext()).inflate(resourceId,parent,false);
ImageView fruitImage=(ImageView) view.findViewById(R.id.fruit_image);
TextView fruitname=(TextView) view.findViewById(R.id.fruit_name);
fruitImage.setImageResource(fruit.getImageId());
fruitname.setText(fruit.getName());
return view;
}
}
FruitAdapter
重写父类的一组构造函数,用于将上下文
,ListView子项布局id
,和水果数据
传递进来,另外重写getview()
方法,这个方法在每个子项被滚到屏幕内时会被调用。通过getItem()
得到当前项Fruit实例,然后使用LayoutInflater
为子项加载我们传入的布局。
2.5修改MainActivity
最后修改MainActivity1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50package com.example.listviewtest;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.widget.ArrayAdapter;
import android.widget.ListView;
import java.util.ArrayList;
import java.util.List;
public class MainActivity extends AppCompatActivity {
private List<Fruit> fruitList=new ArrayList<>();
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
initFruits();
FruitAdapter adapter=new FruitAdapter(MainActivity.this,R.layout.fruit_item,fruitList);
ListView listView=(ListView)findViewById(R.id.list_view);
listView.setAdapter(adapter );
}
private void initFruits(){
for (int i=0;i<2;i++){
Fruit apple=new Fruit("Apple",R.drawable.apple_pic);
fruitList.add(apple);
Fruit banana=new Fruit("Banana",R.drawable.banana_pic);
fruitList.add(banana);
Fruit orange=new Fruit("Orange",R.drawable.orange_pic);
fruitList.add(orange);
Fruit watermelon=new Fruit("Watermelon",R.drawable.watermelon_pic);
fruitList.add(watermelon);
Fruit pear=new Fruit("Pear",R.drawable.pear_pic);
fruitList.add(pear);
Fruit grape=new Fruit("Grape",R.drawable.grape_pic);
fruitList.add(grape);
Fruit pineapple=new Fruit("Pineapple",R.drawable.pineapple_pic);
fruitList.add(pineapple);
Fruit strawberry=new Fruit("Strawberry",R.drawable.strawberry_pic);
fruitList.add(strawberry);
Fruit cherry=new Fruit("Cherry",R.drawable.cherry_pic);
fruitList.add(cherry);
Fruit mango=new Fruit("Mango",R.drawable.mango_pic);
fruitList.add(mango);
}
}
}
这里的initFruits()
方法用来初始化水果数据,然后在onCreate()方法中创建FruitAdapter
对象,并将FruitAdapter作为适配器传递给ListView