当前位置:   article > 正文

Android-06 Android适配器adapter_andriod适配器的作用

andriod适配器的作用


一.什么是适配器,适配器有什么用?

适配器是AdapterView视图(如ListView - 列表视图控件、Gallery - 缩略图浏览器控件、GridView - 网格控件、Spinner - 下拉列表控件、AutoCompleteTextView - 自动提示文本框、ExpandableListView - 支持展开/收缩功能的列表控件等)与数据之间的桥梁,用来处理数据并将数据绑定到AdapterView上。
android提供多种适配器,开发时可以针对数据源的不同采用最方便的适配器,也可以自定义适配器完成复杂功能。

补充:

AdapterView对象有两个主要任务
    1. 在布局中显示数据
    2. 处理用户的选择


BaseAdapter一般的适配器基类可用于将数据绑定到listview、Gallery、GridView 、spinner、AutoCompleteTextView上,当然也可以绑定到ExpandableListView上
BaseExpandableListAdapter可扩展的适配器基类可用于将数据绑定到支持展开/收缩功能的列表控件ExpandableListView上,ExpandableListView继承自ListView

二.两种适配器基类的相关类图与继承关系

1>BaseAdapter适配器相关类图:图1和图2

              

                                                                            图1    BaseAdapter适配器相关类图

             

             

                 

                                                                   图2    BaseAdapter适配器相关类图(续)

2>BaseExpandableListAdapter适配器相关类图:图3

                                                                           图3  BaseExpandableListAdapter适配器相关类图

三.重要类的相关方法构造函数的具体分析

1.ArrayAdapter

补充:

1>数据源写法对比

1.用静态字符数组常量来给ArrayAdapter 赋值。 优点,直接用数组写入,数据量大建议使用。

static final String[] list="...";

ArrayAdapter<String> arrayAdapter = new ArrayAdapter<String>(this,R.layout.list_item,list);

2.在程序中给ArrayAdapter 赋值。优点:可以在程序中灵活写入。

ArrayList<String> list = new ArrayList<String>();

list.add("数据1");

list.add("数据N");

ArrayAdapter<String> arrayAdapter = new ArrayAdapter<String>(this,R.layout.list_item,list);

3.使用国际化接口 字符数组来 给ArrayAdapter 赋值。优点:提供的组件的选项可以国际化。

目录【res】→【values】→【strings.xml】添加

<string-array name="letter">
  <item>A</item>
  <item>B</item>
  <item>C</item>
  <item>D</item>
</string-array>

ArrayAdapter<CharSequence> adapter = ArrayAdapter.createFromResource(this,R.array.letter,android.R.layout.my_list_item)//只需要显示

ArrayAdapter<CharSequence> adapter = new ArrayAdapter(this,android.R.layout.my_list_item,Arrays.asList(getResources().getTextArray(R.array.letter)))//允许动态增删

2>什么情况使用ArrayAdapter,什么时候使用BaseAdapter

当数量较多,比如超过100条或频繁动态增减时使用arrayadapter可以方便控制ui,

如果仅仅为了显示则使用baseadapter更节省资源


     在开发中我们需要绑定一些数据展现到桌面上,这是就需要AdapterView。AdapterView是ViewGroup的子类,它决定了怎么展现视图通过Adapter来绑定特殊的数据类型。 AdapterView是非常有帮助的当你展现数据在你的布局中。Gallery,ListView和 Spinner是AdapterView的子类。

      下面看一下AdapterView的结构图:

      

      然后再看一下Adapter的结构图:

     

    上面已经充分展现了他们的子类和父类的基础关系。

     下面我们看一个ListViewDemo的例子:

    先来看一个简单的adapter的例子:

   

[java]  view plain copy
  1. public class SimpleList extends ListActivity {  
  2.     private String[] mListString={"姓名:王魁锋","性别:男","年龄:23",  
  3.             "居住地:上海市普陀区","邮箱:wangkuifeng0118@126.com"};  
  4.     private ListView mListView=null;  
  5.     @Override  
  6.     protected void onCreate(Bundle savedInstanceState) {  
  7.         // TODO Auto-generated method stub  
  8.         super.onCreate(savedInstanceState);  
  9.         mListView=this.getListView();  
  10.         setListAdapter(new ArrayAdapter<String>(this,  
  11.             android.R.layout.simple_list_item_1,mListString));  
  12.         mListView.setOnItemClickListener(new OnItemClickListener() {  
  13.   
  14.             @Override  
  15.             public void onItemClick(AdapterView<?> parent, View view,  
  16.                     int position, long id) {  
  17.                 // TODO Auto-generated method stub  
  18.             Toast.makeText(SimpleList.this"你选择了:"+mListString[position], 1).show();  
  19.             }  
  20.         });  
  21.     }  

  这里用到了系统定义好的适配模式,当然这只能用来简单的数据适配,下面看一下效果:

    

    接下来看一个稍微复杂点的,SimpleAdapter怎么适配:

   

[java]  view plain copy
  1. public class IconList extends ListActivity {  
  2.   
  3.      private String[] mListTitle = { "姓名""性别""年龄""居住地","邮箱"};    
  4.         private String[] mListStr = { "王魁锋""男""23""上海市普陀区",    
  5.             "wangkuifeng0118@126.com"};    
  6.         ListView mListView = null;    
  7.         ArrayList<Map<String,Object>> mData= new ArrayList<Map<String,Object>>();;    
  8.         
  9.         @Override  
  10.         protected void onCreate(Bundle savedInstanceState) {  
  11.             // TODO Auto-generated method stub  
  12.              mListView = getListView();    
  13.                   
  14.             int lengh = mListTitle.length;    
  15.             for(int i =0; i < lengh; i++) {    
  16.                 Map<String,Object> item = new HashMap<String,Object>();    
  17.                 item.put("image", R.drawable.portrait);    
  18.                 item.put("title", mListTitle[i]);    
  19.                 item.put("text", mListStr[i]);    
  20.                 mData.add(item);     
  21.             }    
  22.             SimpleAdapter adapter = new SimpleAdapter(this,mData,R.layout.iconlist,    
  23.                 new String[]{"image","title","text"},new int[]{R.id.image,R.id.title,R.id.text});    
  24.                 setListAdapter(adapter);    
  25.             mListView.setOnItemClickListener(new OnItemClickListener() {    
  26.                 @Override  
  27.                 public void onItemClick(AdapterView<?> parent, View view,  
  28.                         int position, long id) {  
  29.                     // TODO Auto-generated method stub  
  30.                      Toast.makeText(IconList.this,"您选择了标题:" + mListTitle[position] + "    内容:"+mListStr[position], Toast.LENGTH_LONG).show();    
  31.                        
  32.                 }    
  33.             });    
  34.             super.onCreate(savedInstanceState);  
  35.         }  
  36. }  
    上面的数据可以是同数据库读取的也可以是从网络获取的,这里不做过多介绍,看下效果:

    

      哈哈 看起来美观了些,如果要做更复杂的布局,哪就要用BaseAdapter了。先看一下布局文件:

[html]  view plain copy
  1. <?xml version="1.0" encoding="utf-8"?>    
  2.     
  3. <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"    
  4.     android:layout_width="fill_parent" android:layout_height="wrap_content">    
  5.     <ImageView android:id="@+id/color_image"    
  6.         android:layout_width="wrap_content" android:layout_height="fill_parent"    
  7.         android:layout_alignParentTop="true" android:layout_alignParentBottom="true"    
  8.         android:adjustViewBounds="true"    
  9.         android:padding="2dip" />    
  10.     <TextView android:id="@+id/color_title"    
  11.         android:layout_width="fill_parent" android:layout_height="wrap_content"    
  12.         android:layout_toRightOf="@+id/color_image"    
  13.         android:layout_alignParentTop="true"    
  14.         android:layout_alignParentRight="true" android:singleLine="true"    
  15.         android:ellipsize="marquee"     
  16.         android:textSize="15dip"  />    
  17.     <TextView android:id="@+id/color_text"    
  18.         android:layout_width="fill_parent" android:layout_height="wrap_content"    
  19.         android:layout_toRightOf="@+id/color_image"    
  20.         android:layout_below="@+id/color_title"    
  21.         android:layout_alignParentBottom="true"    
  22.         android:layout_alignParentRight="true"     
  23.         android:singleLine="true"    
  24.         android:ellipsize="marquee"     
  25.         android:textSize="20dip" />    
  26. </RelativeLayout>    
   
下面是核心代码:

 

[java]  view plain copy
  1. public class ColorList extends ListActivity {  
  2.      private String[] mListTitle = { "姓名""性别""年龄""居住地","邮箱"};    
  3.      private String[] mListText={"王魁锋","男","23","上海市普陀区","wangkuifeng0118@126.com"};  
  4.      private ListView mListView=null;  
  5.      private MyListAdapter myAdapter=null;  
  6.     @Override  
  7.     protected void onCreate(Bundle savedInstanceState) {  
  8.         // TODO Auto-generated method stub  
  9.          mListView=this.getListView();  
  10.          myAdapter=new MyListAdapter(this);  
  11.          this.setListAdapter(myAdapter);  
  12.            
  13.          mListView.setOnItemClickListener(new OnItemClickListener() {  
  14.   
  15.             @Override  
  16.             public void onItemClick(AdapterView<?> parent, View view,  
  17.                     int position, long id) {  
  18.                 // TODO Auto-generated method stub  
  19.                 View v=parent.getChildAt(position);  
  20.                 v.setBackgroundColor(Color.RED);  
  21.                 Toast.makeText(ColorList.this"你选择了 "+mListText[position], 1).show();  
  22.             }  
  23.         });  
  24.         super.onCreate(savedInstanceState);  
  25.     }  
  26.     private class MyListAdapter extends BaseAdapter{  
  27.         private Context mContext;  
  28.         private int[] colors=new int[]{0xff626569,0xff4f5257 };  
  29.          public MyListAdapter(Context context){  
  30.              mContext=context;  
  31.          }  
  32.         @Override  
  33.         public int getCount() {  
  34.             // TODO Auto-generated method stub  
  35.             return mListText.length;  
  36.         }  
  37.   
  38.         @Override  
  39.         public Object getItem(int position) {  
  40.             // TODO Auto-generated method stub  
  41.             return position;  
  42.         }  
  43.   
  44.         @Override  
  45.         public long getItemId(int position) {  
  46.             // TODO Auto-generated method stub  
  47.             return position;  
  48.         }  
  49.   
  50.         @Override  
  51.         public View getView(int position, View convertView, ViewGroup parent) {  
  52.             ImageView image=null;  
  53.             TextView title=null;  
  54.             TextView  content=null;  
  55.             if(convertView==null){  
  56.                 convertView=LayoutInflater.from(mContext).inflate(R.layout.colorlist, null);  
  57.                 image=(ImageView) convertView.findViewById(R.id.color_image);  
  58.                 title=(TextView) convertView.findViewById(R.id.color_title);  
  59.                 content=(TextView) convertView.findViewById(R.id.color_text);  
  60.             }  
  61.             int colorPos=position%colors.length;  
  62.             convertView.setBackgroundColor(colors[colorPos]);  
  63.             title.setText(mListTitle[position]);  
  64.             content.setText(mListText[position]);  
  65.             image.setImageResource(R.drawable.portrait);  
  66.               
  67.             return convertView;  
  68.         }  
  69.           
  70.     }  
  71. }  

     BaseAdapter可以让我们做比较复杂的布局,只要在xml文件中设置好布局格式,在getView中分别取出放入相应的值就可以了。下面看一些效果:

   

    还有一些SpinnerAdapter和SimpleCursorAdapter等系统自带的适配器,都是比较简单的,可以看下API自行练习一下,这里特别说明一下,从数据库里取出的数据最好直接放入 SimpleCursorAdapter很方便的。


声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/运维做开发/article/detail/856392
推荐阅读
相关标签
  

闽ICP备14008679号