• Android适配器Adapter学习


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

          下面看一下AdapterView的结构图:

          

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

         

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

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

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

       

    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怎么适配:

       

    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了。先看一下布局文件:

     

    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>    

       
    下面是核心代码:

     

     

    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很方便的。

  • 相关阅读:
    dreamvc框架(一)ioc容器的集成
    1040. Longest Symmetric String (25)
    虚指针存在证明及虚函数表
    Kibana中doc与search策略的区别
    AngularJS API之bootstrap启动
    AngularJS 技术总结
    Elasticsearch Javascript API增删改查
    AngularJS 中的Promise --- $q服务详解
    Ruby编程实践
    Ruby测试小代码[计算50以内的素数]
  • 原文地址:https://www.cnblogs.com/fx2008/p/3140296.html
Copyright © 2020-2023  润新知