安卓学习之路_20140421_ListView、ArrayAdapter、SimpleAdapter

1、ListView

ListView是安卓中用来显示列表的,常见的电话薄、设置中的选项应该都是用ListView来创建的,ListView是从View继承过来的子类;

ListView的显示通常需要三个重要属性:

(1)、Adapter:中文翻译为适配器,用来把数据映射到ListView的中介。

(2)、列表的数据:通常我们都是以集合的方式进行传递,可以用List和Map来进行传递。

(3)、每一个列表的样式,通常我们可以自定义一个xml文件来进行布局。

2、ArrayAdapter

中文翻译为数组适配器,用来向ListView传递一个数组,并把数组的每一项都在界面上显示成一行,这种情况下传的数据比较单一,就是一个字符串,我们可以对每个ListView添加监听事件。

代码示例:(示例代码中直接是用new了一个ListView对象,实际开发中不推介这种方法,点击事件没有写明,具体点击的要实现的效果可以添加)

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.ArrayAdapter;
import android.widget.ListView;

public class MainActivity extends Activity {

	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		// 实例化ListView
		ListView lv = new ListView(this);

		lv.setAdapter(
		// 三个参数:
		// 1、要显示在哪个页面
		// 2、每一条的样式
		// 3、要显示的内容
		new ArrayAdapter<String>(this, android.R.layout.simple_expandable_list_item_1, getData()));
		
		lv.setOnItemClickListener(new OnItemClickListener() {

			@Override
			public void onItemClick(AdapterView<?> arg0, View arg1, int arg2,long arg3) {
			}
		});
		setContentView(lv);
	}

	public List<String> getData() {
		List<String> data = new ArrayList<String>();
		data.add("测试数据1");
		data.add("测试数据2");
		data.add("测试数据3");
		data.add("测试数据4");
		data.add("测试数据5");
		return data;
	}
}
显示效果:


3、SimpleAdapter

SimpleAdapter的就是一个可以自己扩张的Adapter,我们可以再里面放置图片、文字......等任意内容,需要注意的是,当我们用SimpleAdapter的时候,就不是继承的Activity了,而是ListActivity,ListActivity和Activity没有多大的差别,只是对显示列表做了优化,具体的用法也都基本类似,以下的代码就是一个简单的SimpleAdapter,我在里面添加了一张图片,一个标题,一个内容

示例代码:

import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

import android.app.ListActivity;
import android.os.Bundle;
import android.widget.SimpleAdapter;

public class Demo2_Activity extends ListActivity {
	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		/**
		 * 实例化SimpleAdapter
		 * 三个参数:
		 * 1、要显示的页面
		 * 2、显示的数据
		 * 3、每一个列表的布局文件
		 * 4、存放的数据
		 * 5、数据的id
		 */
		SimpleAdapter simpleAdapter = new SimpleAdapter(this, getData(), R.layout.main, new String[]{"title", "info", "img"}, new int[]{R.id.text_1, R.id.text_2, R.id.img} );
		setListAdapter(simpleAdapter);
	}
	
	public List<Map<String, Object>> getData(){
		
		List<Map<String, Object>> list = new ArrayList<Map<String, Object>>();
		
		Map<String, Object> map = new HashMap<String, Object>();
		map.put("title", "B1");
		map.put("info", "android 1");
		map.put("img", R.drawable.ic_launcher);
		list.add(map);
		
		map = new HashMap<String, Object>();
		map.put("title", "B2");
		map.put("info", "android 2");
		map.put("img", R.drawable.ic_launcher);
		list.add(map);
		
		map = new HashMap<String, Object>();
		map.put("title", "B3");
		map.put("info", "android 3");
		map.put("img", R.drawable.ic_launcher);
		list.add(map);
		return list;
	}
}

xml布局文件:

<LinearLayout 
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    android:orientation="horizontal" >

    <ImageView
        android:id="@+id/img"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:background="@drawable/ic_launcher" />

    <LinearLayout
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:orientation="vertical" >

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

        <TextView
            android:id="@+id/text_2"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="bbbbb"
            android:textSize="20px" />
    </LinearLayout>

</LinearLayout>


运行效果:



4、BaseAdapter

中文翻译为基础适配器,这是一个我们可以自定义的适配器,他能实现我们想要的任何效果,都可以由我们自己定义,我们可以再里面添加各种view控件,和SimpleAdapter有点类似,但不同的地方是BaseAdapter完全由我们自己定义:

具体的流程为:

(1)、关联Activity的布局文件,这个布局文件中一般情况下只有一个ListView的控件

(2)、创建一个ListView的对象,并对其实例化,通过findviewbyId来实例化,和常用的view实例化是一样的

(3)、创建一个我们需要实现BaseAdapter的类,这个类需要集成BaseAdapter,需要我们重写其中的四个方法,并在Activity中实例化其对象。

(4)、用一个方法来传递我们需要添加的数据,通过这个方法返回值来传递,

示例代码:

(1).AdapterDemo类

import java.util.List;
import java.util.Map;

import android.content.Context;
import android.view.LayoutInflater;
import android.view.View;
import android.view.View.OnClickListener;
import android.view.ViewGroup;
import android.widget.BaseAdapter;
import android.widget.Button;
import android.widget.ImageView;
import android.widget.TextView;
import android.widget.Toast;

public class AdapterDemo extends BaseAdapter {

	Context con;
	List<Map<String, Object>> list;
	//用LayoutInflater来将xml的布局文件转换成一个view
	private LayoutInflater mInflater;

	public AdapterDemo(Context con, List<Map<String, Object>> list) {
		this.con = con;
		this.list = list;
		this.mInflater = LayoutInflater.from(con);
	}

	// 得到数据的大小并返回
	@Override
	public int getCount() {
		// TODO Auto-generated method stub
		return list.size();
	}

	// 得到第几个的对象并返回
	@Override
	public Object getItem(int position) {
		// TODO Auto-generated method stub
		return position;
	}

	// 得到当前是第几个列表并返回
	@Override
	public long getItemId(int position) {
		// TODO Auto-generated method stub
		return position;
	}

	/**
	 * 得到view的对象并返回
	 * 三个参数:
	 * 1、第几个列表
	 * 2、显示的View
	 * 3、父类的View 
	 */
	@Override
	public View getView(final int position, View convertView, ViewGroup parent) {
		// TODO Auto-generated method stub
		//把xml转换成view显示
		convertView = mInflater.inflate(R.layout.listadapter, null);
		//实例化当前内部类的对象,用这个对象来传值
		ViewHolder holder = new ViewHolder();
		//实例化holder中的img,title,info,button
		holder.img = (ImageView) convertView.findViewById(R.id.img);
		holder.title = (TextView) convertView.findViewById(R.id.title);
		holder.info = (TextView) convertView.findViewById(R.id.info);
		holder.button = (Button) convertView.findViewById(R.id.bt);
		//给button添加点击事件
		holder.button.setOnClickListener(new OnClickListener() {
			@Override
			public void onClick(View v) {
				Toast.makeText(con, String.valueOf(position),
						Toast.LENGTH_SHORT).show();
			}
		});
		
		//设置img,title,info,button需要设置的值
		holder.img.setBackgroundResource((Integer) list.get(position)
				.get("img"));
		holder.title.setText((CharSequence) list.get(position).get("title"));
		holder.info.setText((CharSequence) list.get(position).get("info"));
		holder.button.setText((CharSequence) list.get(position).get("button"));
		return convertView;
	}

	class ViewHolder {
		ImageView img;
		TextView title, info;
		Button button;
	}
}

(2)、MainActivity类
package com.jiang.baseAdapter;

import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

import android.app.Activity;
import android.os.Bundle;
import android.widget.ListView;

public class MainActivity extends Activity {

	ListView lv;

	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		//关联当前Activity的布局文件
		setContentView(R.layout.activity_main);
		//实例化ListView对象
		lv = (ListView) findViewById(R.id.listview);
		//实例化一个实现BaseAdapter的对象,这个类是我们自己定义的,两个参数分别问:1、要显示的界面;2、传递的数据
		AdapterDemo ad = new AdapterDemo(this, getData());
		lv.setAdapter(ad);
	}

	public List<Map<String, Object>> getData() {

		List<Map<String, Object>> list = new ArrayList<Map<String, Object>>();

		Map<String, Object> map = new HashMap<String, Object>();
		map.put("title", "B1");
		map.put("info", "android 1");
		map.put("img", R.drawable.ic_launcher);
		map.put("button", "aaaa");
		list.add(map);

		map = new HashMap<String, Object>();
		map.put("title", "B2");
		map.put("info", "android 2");
		map.put("img", R.drawable.ic_launcher);
		map.put("button", "bbbb");
		list.add(map);

		map = new HashMap<String, Object>();
		map.put("title", "B2");
		map.put("info", "android 2");
		map.put("img", R.drawable.ic_launcher);
		map.put("button", "ccccc");
		list.add(map);
		
		return list;
	}
}
(3)、Activity的布局文件mani_activity.xml

<RelativeLayout
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context=".MainActivity" >

    <ListView 
        android:id="@+id/listview"
        android:layout_width="fill_parent"
        android:layout_height="fill_parent">
        
    </ListView>

</RelativeLayout>
(4)、Adapter的布局文件listadapter.xml

<LinearLayout 
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    android:orientation="horizontal"
     >

    <ImageView
        android:id="@+id/img"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:background="@drawable/ic_launcher" />

    <LinearLayout
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:orientation="vertical" >

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

        <TextView
            android:id="@+id/info"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="bbbbb"
            android:textSize="20px" />
    </LinearLayout>
    
    <Button 
        android:id="@+id/bt"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"/>

</LinearLayout>

运行效果:




学习总结:

今天主要是学习的ListView的三个适配器,总体感觉来说有点晕,主要是BaseAdapter,此方法在我们的开发中是常用的,所以需要不断的练习来提高自己,才能熟练的使用。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在Android Studio中,ArrayAdapterSimpleAdapter都是常用的适配器类,用于将数据源与UI控件进行绑定。下面我来分别介绍一下这两个适配器类的使用方法。 ### ArrayAdapter ArrayAdapter是一个简单的适配器,它可以将一个数组或List中的数据与ListView等UI控件进行绑定。使用ArrayAdapter时,需要创建一个包含数据的数组或List,并将其传入ArrayAdapter的构造函数中,然后将ArrayAdapter设置到对应的UI控件中即可。 下面是一个简单的使用ArrayAdapter的示例代码: ```java String[] data = {"apple", "banana", "orange", "pear"}; ArrayAdapter<String> adapter = new ArrayAdapter<String>(this, android.R.layout.simple_list_item_1, data); ListView listView = (ListView) findViewById(R.id.list_view); listView.setAdapter(adapter); ``` 在上面的代码中,我们创建了一个包含4个字符串的数组data,然后将其传入ArrayAdapter的构造函数中,同时指定了一个简单的ListView的布局文件`android.R.layout.simple_list_item_1`,最后将ArrayAdapter设置到ListView中。 ### SimpleAdapter SimpleAdapter是一个稍微复杂一些的适配器,它可以将一个List中的Map与ListView等UI控件进行绑定。使用SimpleAdapter时,需要创建一个包含多个Map的List,并将其传入SimpleAdapter的构造函数中,然后将SimpleAdapter设置到对应的UI控件中即可。 下面是一个简单的使用SimpleAdapter的示例代码: ```java List<Map<String, Object>> data = new ArrayList<Map<String, Object>>(); Map<String, Object> map1 = new HashMap<String, Object>(); map1.put("name", "apple"); map1.put("image", R.drawable.apple); data.add(map1); Map<String, Object> map2 = new HashMap<String, Object>(); map2.put("name", "banana"); map2.put("image", R.drawable.banana); data.add(map2); Map<String, Object> map3 = new HashMap<String, Object>(); map3.put("name", "orange"); map3.put("image", R.drawable.orange); data.add(map3); Map<String, Object> map4 = new HashMap<String, Object>(); map4.put("name", "pear"); map4.put("image", R.drawable.pear); data.add(map4); SimpleAdapter adapter = new SimpleAdapter(this, data, R.layout.item_simple_adapter, new String[]{"name", "image"}, new int[]{R.id.tv_name, R.id.iv_image}); ListView listView = (ListView) findViewById(R.id.list_view); listView.setAdapter(adapter); ``` 在上面的代码中,我们创建了一个包含4个Map的List,每个Map包含两个键值对(name和image),分别对应水果的名称和图片资源的ID。然后将List传入SimpleAdapter的构造函数中,同时指定了一个ListView的布局文件`R.layout.item_simple_adapter`,以及将name和image映射到ListView的两个控件(tv_name和iv_image)上。 总的来说,ArrayAdapterSimpleAdapter都是非常实用的适配器类,用于将数据源与UI控件进行绑定。在实际开发中,我们可以根据具体的需求来选择使用哪个适配器类。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值