Android学习——控件ListView的使用

一、ListView的简单用法

首先新建一个ListViewTest项目,并让Android Studio自动创建好活动。然后修改activity_main.xml中的代码,如下:

 1 <?xml version="1.0" encoding="utf-8"?>
 2 <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
 3     android:layout_width="match_parent"
 4     android:layout_height="match_parent">
 5
 6    <ListView
 7        android:id="@+id/list_view"
 8        android:layout_width="match_parent"
 9        android:layout_height="match_parent">
10    </ListView>
11 </LinearLayout>

接下来修改MainActivity中的代码:

 1 public class MainActivity extends AppCompatActivity {
 2
 3     private String[] data={"Apple","Banana","Orange","Watermelon","Pear","Grape","Pineapple","Strawberry","Cherry","Mango","Apple","Banana","Orange","Watermelon","Pear","Grape","Pineapple","Strawberry","Cherry","Mango"};
 4     @Override
 5     protected void onCreate(Bundle savedInstanceState) {
 6         super.onCreate(savedInstanceState);
 7         setContentView(R.layout.activity_main);
 8
 9         ArrayAdapter<String> adapter=new ArrayAdapter<String>(MainActivity.this,android.R.layout.simple_list_item_1,data);
10         ListView listview=(ListView)findViewById(R.id.list_view);
11         listview.setAdapter(adapter);
12     }
13 }

数组中的数据无法直接传递给ListView,需要借助适配器来实现。

ArrayAdapter的构造函数中依次传入当前上下文,ListView子项布局的id,以及要适配的数据;

调用ListView的setAdapter()方法,将构建好的适配器对象传递进去,这样ListView和数据之间的关联就建立完成。

运行程序,可以通过滚动的方式来查看屏幕外的数据。

二、定制ListView的界面

首先准备一组图片,分别对应上面提供的每一种水果(注意图片大小尽量一致),放在drawable目录下,注意命名不能出现大写字母(比如Apple不合法);

在com.example.administrator.listviewtest下新建.java文件,定义一个实体类Fruit,作为ListView适配器的适配类型。

 1 public class Fruit{
 2     private String name;
 3     private int imageId;
 4     public Fruit(String name,int imageId){
 5         this.name=name;
 6         this.imageId=imageId;
 7     }
 8     public String getName(){
 9         return name;
10     }
11     public int getImageId(){
12         return imageId;
13     }
14 }

然后为ListView的子项指定一个自定义布局,在layout目录下新建fruit_item.xml。

 1 <?xml version="1.0" encoding="utf-8"?>
 2 <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
 3     android:layout_width="match_parent"
 4     android:layout_height="wrap_content">
 5
 6     <ImageView
 7         android:id="@+id/fruit_image"
 8         android:layout_width="wrap_content"
 9         android:layout_height="wrap_content" />
10
11     <TextView
12         android:id="@+id/fruit_name"
13         android:layout_width="wrap_content"
14         android:layout_height="wrap_content"
15         android:layout_gravity="center_vertical"
16         android:layout_marginLeft="10dp"
17         />
18 </LinearLayout>

接下来创建一个自定义的适配器,同样在com.example.administrator.listviewtest下新建.java文件,重写了父类的一组构造函数,用于将上下文、ListView子项布局的id和数据都传递进来,命名为FruitAdapter,代码如下:

 1 public class FruitAdapter extends ArrayAdapter<Fruit> {
 2     private int resourceId;
 3     public FruitAdapter(Context context, int textViewResourceId, List<Fruit> objects){
 4         super(context,textViewResourceId,objects);
 5         resourceId=textViewResourceId;
 6     }
 7     @Override
 8     public View getView(int position,View convertView,ViewGroup parent){
 9         Fruit fruit=getItem(position);           //获取当前项的实例
10         View view= LayoutInflater.from(getContext()).inflate(resourceId,parent,false);
11         ImageView fruitImage=(ImageView)view.findViewById(R.id.fruit_image);
12         TextView fruitName=(TextView) view.findViewById(R.id.fruit_name);
13         fruitImage.setImageResource(fruit.getImageId());
14         fruitName.setText(fruit.getName());
15         return view;
16     }
17 }

下面修改MainActivity中的代码:

 1 package com.example.administrator.listviewtest;
 2
 3 import android.support.v7.app.AppCompatActivity;
 4 import android.os.Bundle;
 5 import android.widget.ArrayAdapter;
 6 import android.widget.ListView;
 7
 8 import java.util.ArrayList;
 9 import java.util.List;
10
11 public class MainActivity extends AppCompatActivity {
12     private List<Fruit> fruitList=new ArrayList<>();
13
14 //  private String[] data={"Apple","Banana","Orange","Watermelon","Pear","Grape","Pineapple","Strawberry","Cherry","Mango","Apple","Banana","Orange","Watermelon","Pear","Grape","Pineapple","Strawberry","Cherry","Mango"};
15     @Override
16     protected void onCreate(Bundle savedInstanceState) {
17         super.onCreate(savedInstanceState);
18         setContentView(R.layout.activity_main);
19         initFruits();                 //初始化水果数据
20         FruitAdapter adapter=new FruitAdapter(MainActivity.this,R.layout.fruit_item,fruitList);
21
22 //      ArrayAdapter<String> adapter = new ArrayAdapter<String>(MainActivity.this, android.R.layout.simple_list_item_1, data);
23         ListView listview = (ListView) findViewById(R.id.list_view);
24         listview.setAdapter(adapter);
25     }
26
27     private void initFruits(){
28         for(int i=0;i<2;i++){
29             Fruit apple=new Fruit("Apple",R.drawable.apple);
30             fruitList.add(apple);
31             Fruit orange=new Fruit("Orange",R.drawable.orange);
32             fruitList.add(orange);
33             Fruit banana=new Fruit("Banana",R.drawable.banana);
34             fruitList.add(banana);
35             Fruit waterlenmo=new Fruit("Waterlemon",R.drawable.waterlemon);
36             fruitList.add(waterlenmo);
37             Fruit pear=new Fruit("Pear",R.drawable.pear);
38             fruitList.add(pear);
39             Fruit grape=new Fruit("Grape",R.drawable.grape);
40             fruitList.add(grape);
41             Fruit pineapple=new Fruit("Pineapple",R.drawable.pineapple);
42             fruitList.add(pineapple);
43             Fruit strawberry=new Fruit("Strawberry",R.drawable.straw);
44             fruitList.add(strawberry);
45             Fruit cherry=new Fruit("Cherry",R.drawable.cherry);
46             fruitList.add(cherry);
47             Fruit mango=new Fruit("mango",R.drawable.mango);
48             fruitList.add(mango);
49         }
50     }
51 }

运行程序后,效果图如下(图片大小后来才意识到,懒得换了……):

时间: 2024-08-02 19:20:34

Android学习——控件ListView的使用的相关文章

【Android】11.0 UI开发(三)——列表控件ListView的简单实现2

1.0 由于书上内容,已经和实际编程的兼容性已经不太友好,重写了项目,用于进一步学习列表控件ListView. 2.0 新建项目ListViewTest,其中文件目录如下: 3.0 ActivityCollector.java package com.example.listviewtest; import android.app.Activity; import java.util.ArrayList; import java.util.List; public class ActivityC

[Android Pro] android控件ListView顶部或者底部也显示分割线

reference to  :  http://blog.csdn.net/lovexieyuan520/article/details/50846569 在默认的Android控件ListView在顶部是不显示分割线的,但是我们可以使用一些技巧来显示.我们先来看下默认情况下ListView显示的效果: 可以看到顶部是没有分割线的,但是有时候我们的美工硬是在上面画了一条分割线,没办法,我们也得加上,我们在ListView顶部加上一个Header就可以实现,代码如下 listView.addHea

安卓Android控件ListView获取item中EditText值

可以明确,现在没有直接方法可以获得ListView中每一行EditText的值. 解决方案:重写BaseAdapter,然后自行获取ListView中每行输入的EditText值. 大概算法:重写BaseAdapter.getView函数,用一个数组存储EditText中的值,根据position即数组下标,在getView中动态更新EditText和动态获取EditText中的值.因为ListView中的item是复用的,如果不动态清空或动态获取EditText中值,就会出现数据紊乱,或者没数

Android基本控件之ListView(一)

我们在使用手机的时候,通常看到,像通讯录,QQ列表样式的东西,这里来解释一下,其实那些都是一个ListView 今天,我们就来详细的讲解一下ListView这个控件 ListView中每条显示的数据都称为一个item.每个item都有自己的布局. 在这里,我们就先来实现一个简单的功能,用来解释ListView这个控件 我们就来做一个最简单的只显示文本和图片的这样的一个ListView. 我先来和大家一起分析一下我们应该准备些什么: 首先,我们需要一个主界面布局文件,并在布局文件中定义一个List

Android基本控件之ListView(二)&lt;ListView优化&gt;

之前我们说到ListView的基本用法.但是,有很多的时候会额外的占用一些内存,从而消耗了性能.既然有消耗性能的可能,那么我们就对其做出相应的优化 我们首先来说说优化的步骤: 第一步.将宽和高设置为填充父窗体,有助于填充item时,避免重复渲染ListView,而导致重复多次调用ListView 第二步.判断getView()方法中的convertView是否为空,如果为空就创建View,不为空就重复使用View 第三步.创建类ViewHolder来解决每次重复查找convertView中的组件

Android必备:Android UI控件的了解与学习

看这里:Android必备:Android UI控件的了解与学习 由于工作需要,最近一段时间,需要进行Android App开发的学习,之前简单的进行过Android的了解,对于基本的Android环境的搭建等已经有过整理,一个Android App是由一个或多个Activity组成,每一个Activity都是一个UI容器,也就是一个屏幕界面,一个界面的组成则是由一组Android UI控件组成,本篇,我们就来简单的对Android UI控件进行初步的了解和学习. Android UI控件根据其

Android控件ListView获取item中EditText值

可以明确,现在没有直接方法可以获得ListView中每一行EditText的值. 解决方案:重写BaseAdapter,然后自行获取ListView中每行输入的EditText值. 大概算法:重写BaseAdapter.getView函数,用一个数组存储EditText中的值,根据position即数组下标,在getView中动态更新EditText和动态获取EditText中的值.因为ListView中的item是复用的,如果不动态清空或动态获取EditText中值,就会出现数据紊乱,或者没数

Android基础控件使用汇总

平时写代码总会遇到一些问题,准备写一个比较基础的控件使用汇总系列!本系列持续不定期更新,希望能够帮到需要的朋友!get! Android基础控件使用细节--TextView Android基础控件使用细节--Button Android基础控件使用细节--EditText Android基础控件使用细节--ImageView Android基础控件使用细节--WebView Android基础控件使用细节--ListView Android基础控件使用细节--Menu Android基础控件使用

Android常用控件:进度条

各种进度条属于 ProgressBar的子类 Sytle: 水平风格:Horizontal小风格:Small大风格:Large反向风格:Inverse小反向风格:Small.Inverse大反向风格:Large.Inverse 设置style:   style="?android:attr/progressBarStyle..." 主要属性:最大值:max当前进度:progress次要进度值:SecondaryProgress --效果类似于看电影那些缓冲 判断进度条是转圈还是水平的方