Android ListView示例

在Android中,可以使用ListView在垂直的可滚动列表中排列组件。

在本教程中,我们将向您展示2个ListView示例:

  1. ListView显示组件的正常方法。
  2. 自定义数组适配器可自定义ListView显示的项目。

PS此项目在Eclipse 3.7中开发,并通过Android 2.3.3进行了测试。

1.普通ListView示例

在此示例中,我们向您展示了如何通过ListView显示水果名称的列表,它应该简单易懂。

1.1 Android布局文件

文件:res / layout / list_fruit.xml

<?xml version="1.0" encoding="utf-8"?>
<TextView xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    android:padding="10dp"
    android:textSize="20sp" >
</TextView>

1.2列表视图

package com.mkyong.android;

import android.app.ListActivity;
import android.os.Bundle;
import android.view.View;
import android.widget.AdapterView;
import android.widget.ArrayAdapter;
import android.widget.ListView;
import android.widget.TextView;
import android.widget.Toast;
import android.widget.AdapterView.OnItemClickListener;

public class ListFruitActivity extends ListActivity {

	static final String[] FRUITS = new String[] { "Apple", "Avocado", "Banana",
			"Blueberry", "Coconut", "Durian", "Guava", "Kiwifruit",
			"Jackfruit", "Mango", "Olive", "Pear", "Sugar-apple" };

	@Override
	public void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);

		// no more this
		// setContentView(R.layout.list_fruit);

		setListAdapter(new ArrayAdapter<String>(this, R.layout.list_fruit,FRUITS));

		ListView listView = getListView();
		listView.setTextFilterEnabled(true);

		listView.setOnItemClickListener(new OnItemClickListener() {
			public void onItemClick(AdapterView<?> parent, View view,
					int position, long id) {
			    // When clicked, show a toast with the TextView text
			    Toast.makeText(getApplicationContext(),
				((TextView) view).getText(), Toast.LENGTH_SHORT).show();
			}
		});

	}

}

1.3演示

android listview example

2.自定义ArrayAdapter示例

在此示例中,我们向您展示如何在ListView创建4个项目,并使用自定义“ ArrayAdapter ”基于列表中的“项目名称”显示不同的图像。

2.1图片
获取4张图像进行演示。

images in android project

2.2 Android布局文件
文件:res / layout / list_mobile.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:padding="5dp" >

    <ImageView
        android:id="@+id/logo"
        android:layout_width="50px"
        android:layout_height="50px"
        android:layout_marginLeft="5px"
        android:layout_marginRight="20px"
        android:layout_marginTop="5px"
        android:src="@drawable/windowsmobile_logo" >
    </ImageView>

    <TextView
        android:id="@+id/label"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="@+id/label"
        android:textSize="30px" >
    </TextView>

</LinearLayout>

2.3自定义ArrayAdapter
创建一个扩展ArrayAdapter的类并自定义getView()方法中的项目显示。

package com.mkyong.android.adaptor;

import com.mkyong.android.R;

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 MobileArrayAdapter extends ArrayAdapter<String> {
	private final Context context;
	private final String[] values;

	public MobileArrayAdapter(Context context, String[] values) {
		super(context, R.layout.list_mobile, values);
		this.context = context;
		this.values = values;
	}

	@Override
	public View getView(int position, View convertView, ViewGroup parent) {
		LayoutInflater inflater = (LayoutInflater) context
			.getSystemService(Context.LAYOUT_INFLATER_SERVICE);

		View rowView = inflater.inflate(R.layout.list_mobile, parent, false);
		TextView textView = (TextView) rowView.findViewById(R.id.label);
		ImageView imageView = (ImageView) rowView.findViewById(R.id.logo);
		textView.setText(values[position]);

		// Change icon based on name
		String s = values[position];

		System.out.println(s);

		if (s.equals("WindowsMobile")) {
			imageView.setImageResource(R.drawable.windowsmobile_logo);
		} else if (s.equals("iOS")) {
			imageView.setImageResource(R.drawable.ios_logo);
		} else if (s.equals("Blackberry")) {
			imageView.setImageResource(R.drawable.blackberry_logo);
		} else {
			imageView.setImageResource(R.drawable.android_logo);
		}

		return rowView;
	}
}

2.4 ListView
ListView ,但是使用上面的自定义适配器来显示列表。

package com.mkyong.android;

import com.mkyong.android.adaptor.MobileArrayAdapter;
import android.app.ListActivity;
import android.os.Bundle;
import android.widget.ListView;
import android.widget.Toast;
import android.view.View;

public class ListMobileActivity extends ListActivity {

	static final String[] MOBILE_OS = 
               new String[] { "Android", "iOS", "WindowsMobile", "Blackberry"};

	@Override
	public void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);

		setListAdapter(new MobileArrayAdapter(this, MOBILE_OS));

	}

	@Override
	protected void onListItemClick(ListView l, View v, int position, long id) {

		//get selected items
		String selectedValue = (String) getListAdapter().getItem(position);
		Toast.makeText(this, selectedValue, Toast.LENGTH_SHORT).show();

	}

}

2.5演示

android custom array adapter example

下载源代码

下载两个示例– Android-ListView-Example.zip (21 KB)

参考文献

  1. Android ListView示例
  2. Android ListView JavaDoc

翻译自: https://mkyong.com/android/android-listview-example/

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
ListViewAndroid中常用的控件之一,可以用于展示一组数据,并支持滚动。下面是一个带有图像和文本的Android ListView示例的用法: 1. 首先,创建一个布局文件,比如list_item.xml,用于定义ListView中每个项的布局。这个布局可以包含一个ImageView和一个TextView,用于显示图像和文本。示例代码如下: ```xml <?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:orientation="horizontal" android:layout_width="match_parent" android:layout_height="wrap_content" android:padding="10dp"> <ImageView android:id="@+id/image" android:layout_width="50dp" android:layout_height="50dp" android:src="@drawable/ic_launcher"/> <TextView android:id="@+id/text" android:layout_width="wrap_content" android:layout_height="wrap_content" android:textSize="20sp" android:text="Item"/> </LinearLayout> ``` 2. 创建一个适配器类,用于将数据绑定到ListView中的每个项。这个适配器需要实现ListAdapter接口,并重写其中的几个方法。示例代码如下: ```java public class MyListAdapter implements ListAdapter { private List<Item> items; private Context context; public MyListAdapter(Context context, List<Item> items) { this.items = items; this.context = context; } @Override public View getView(int position, View convertView, ViewGroup parent) { View view = convertView; if (view == null) { view = LayoutInflater.from(context).inflate(R.layout.list_item, parent, false); } Item item = items.get(position); ImageView image = view.findViewById(R.id.image); image.setImageResource(item.getImage()); TextView text = view.findViewById(R.id.text); text.setText(item.getText()); return view; } // 其他方法省略 } ``` 在这个适配器中,我们将数据源items和上下文context传递进来,然后在getView方法中将数据绑定到ListView中的每个项。 3. 最后,在Activity中使用ListView和适配器来展示数据。示例代码如下: ```java public class MainActivity extends AppCompatActivity { private ListView listView; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); List<Item> items = new ArrayList<>(); items.add(new Item(R.drawable.ic_launcher, "Item 1")); items.add(new Item(R.drawable.ic_launcher, "Item 2")); items.add(new Item(R.drawable.ic_launcher, "Item 3")); MyListAdapter adapter = new MyListAdapter(this, items); listView = findViewById(R.id.list_view); listView.setAdapter(adapter); } } ``` 在这个Activity中,我们将数据源items传递给适配器,并将适配器设置给ListView。这样,ListView就会自动展示我们的数据了。 完整的示例代码可以参考这个项目:https://github.com/lynn01247/android-listview-example。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值