AdapterView和Adapter

来源:互联网 发布:地名地址数据规范 编辑:程序博客网 时间:2024/05/16 14:03
  1. AdapterView:容器组件,其子元素内容的有adapter所决定
    ListView:以垂直滑动列表形式显示一组数据。
    GridView:以网格形式显示一组数据。
    Spinner:以下拉列表形式显示一组数据。
    Gallery:以水平滑动列表形式显示一组数据。

  2. Adapter数据和视图之间交互的中介
    ArrayAdapter:最简单的适配器,数据源为文本字符串数组。

    ArrayAdapter<String> adapter = new ArrayAdapter<String>(                      this,                      R.layout.item,//只能有一个定义了id的TextView                      data);//data既可以是数组,也可以是List集合  

SimpleAdapter:简单适配器,数据源结构比较复杂,一般为List类型对象。

List<Map<String,Object>> mData= new ArrayList<Map<String,Object>>();;  for(int i =0; i < lengh; i++) {          Map<String,Object> item = new HashMap<String,Object>();          item.put("image", R.drawable.portrait);          item.put("title", mListTitle[i]);          item.put("text", mListStr[i]);          mData.add(item);       }   SimpleAdapter adapter = new SimpleAdapter(                  this,                  mData,                  R.layout.item,                      new String[]{"image","title","text"},                  new int[]{R.id.image,R.id.title,R.id.text});

SimpleCusorAdapter:游标适配器,数据源一般为数据库中的数据。
自定义适配器:更灵活的适配器,数据源不定(由用户自行指定),需要继承BaseAdapter抽象类。

  1. 自定义adapter
    代码来源:http://blog.csdn.net/listening_music/article/details/6965755
package com.test.listviewsimpleadapter;import java.util.ArrayList;import java.util.HashMap;import java.util.List;import java.util.Map;import android.app.AlertDialog;import android.app.ListActivity;import android.content.Context;import android.content.DialogInterface;import android.os.Bundle;import android.util.Log;import android.view.LayoutInflater;import android.view.View;import android.view.ViewGroup;import android.widget.BaseAdapter;import android.widget.Button;import android.widget.ImageView;import android.widget.ListView;import android.widget.TextView;/* listView在开始绘制的时候,系统首先调用getCount()函数,根据他的返回值得到listView的长 * 度(这也是为什么在开始的第一张图特别的标出列表长度),然后根据这个长度,调用getView()逐 * 一绘制每一行。如果你的getCount()返回值是0的话,列表将不显示同样return 1,就只显示一行。 * 系统显示列表时,首先实例化一个适配器(这里将实例化自定义的适配器)。当手动完成适配时,必 * 须手动映射数据,这需要重写getView()方法。系统在绘制列表的每一行的时候将调用此方法。 * getView()有三个参数,position表示将显示的是第几行,covertView是从布局文件中inflate来的 * 布局。我们用LayoutInflater的方法将定义好的main.xml文件提取成View实例用来显示。然后 * 将xml文件中的各个组件实例化(简单的findViewById()方法)。这样便可以将数据对应到各个组件 * 上了。但是按钮为了响应点击事件,需要为它添加点击监听器,这样就能捕获点击事件。至此一个自定 * 义的listView就完成了,现在让我们回过头从新审视这个过程。系统要绘制ListView了,他首先获得 * 要绘制的这个列表的长度,然后开始绘制第一行,怎么绘制呢?调用getView()函数。在这个函数里面 * 首先获得一个View(实际上是一个ViewGroup),然后再实例并设置各个组件,显示之。好了,绘制完 * 这一行了。那 再绘制下一行,直到绘完为止。在实际的运行过程中会发现listView的每一行没有焦点 * 了,这是因为Button抢夺了listView的焦点,只要布局文件中将Button设置为没有焦点就OK了*/public class MyListView4 extends ListActivity {    private List<Map<String, Object>> mData;    @Override    public void onCreate(Bundle savedInstanceState) {        super.onCreate(savedInstanceState);        mData = getData();        MyAdapter adapter = new MyAdapter(this);        setListAdapter(adapter);    }    private 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", "G1");        map.put("info", "google 1");        map.put("img", R.drawable.i1);        list.add(map);        map = new HashMap<String, Object>();        map.put("title", "G2");        map.put("info", "google 2");        map.put("img", R.drawable.i2);        list.add(map);        map = new HashMap<String, Object>();        map.put("title", "G3");        map.put("info", "google 3");        map.put("img", R.drawable.i3);        list.add(map);        return list;    }    // ListView 中某项被选中后的逻辑    @Override    protected void onListItemClick(ListView l, View v, int position, long id) {        Log.v("MyListView4-click", (String) mData.get(position).get("title"));    }    /**     * listview中点击按键弹出对话框     */    public void showInfo() {        new AlertDialog.Builder(this).setTitle("我的listview")                .setMessage("介绍...")                .setPositiveButton("确定", new DialogInterface.OnClickListener() {                    @Override                    public void onClick(DialogInterface dialog, int which) {                    }                }).show();    }    public final class ViewHolder {        public ImageView img;        public TextView title;        public TextView info;        public Button viewBtn;    }    public class MyAdapter extends BaseAdapter {        private LayoutInflater mInflater;        public MyAdapter(Context context) {            this.mInflater = LayoutInflater.from(context);        }        @Override        public int getCount() {            // TODO Auto-generated method stub            return mData.size();        }        @Override        public Object getItem(int arg0) {            // TODO Auto-generated method stub            return null;        }        @Override        public long getItemId(int arg0) {            // TODO Auto-generated method stub            return 0;        }        @Override        public View getView(int position, View convertView, ViewGroup parent) {            // 显示优化(只要之前显示过的就可以不再再次从布局文件读取,直接从缓存中读取——ViewHolder的作用)            // 其实是setTag和getTag中Tag的作用            ViewHolder holder = null;            if (convertView == null) {// 如果是第一次显示该页面(要记得保存到viewholder中供下次直接从缓存中调用)                holder = new ViewHolder();                convertView = mInflater.inflate(R.layout.main, null);                // 以下为保存这一屏的内容,供下次回到这一屏的时候直接refresh,而不用重读布局文件                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.viewBtn = (Button) convertView                        .findViewById(R.id.view_btn);                convertView.setTag(holder);            } else {// 如果之前已经显示过该页面,则用viewholder中的缓存直接刷屏                holder = (ViewHolder) convertView.getTag();            }            holder.img.setBackgroundResource((Integer) mData.get(position).get(                    "img"));            holder.title.setText((String) mData.get(position).get("title"));            holder.info.setText((String) mData.get(position).get("info"));            holder.viewBtn.setOnClickListener(new View.OnClickListener() {                @Override                public void onClick(View v) {                    showInfo();                }            });            return convertView;        }    }}
0 0