自定义Adapter并通过布局泵LayoutInflater抓取layout模板编辑每一个item

来源:互联网 发布:网络运营商无服务 编辑:程序博客网 时间:2024/06/07 03:34

写在前面的话:

         看到标题这么长可能大家有点抓狂了,是的,我在刚刚学这一篇的时候有一些不理解,什么是布局泵?编辑每一个模板然后什么是自定义Adapter?下面我们开始学习这一篇的内容

 

 

首选上一张图,实现效果:


逻辑解析:

         首先上面这个图是最终的实现效果了,有点像我们的通讯录联系人的排版方式,说一下layout的布局吧。很简单,其实就是一个ListView组件。但是这个ListView组件用的Adapter有一点不同。我们自己定义了一个adapter并且通过getview方法对每一个条目进行了编辑和排版。然后最后将我们自定义的Adapter放入到了我们的ListView中以实现展示了这种效果下面我给出这个实现的重要代码片段,然后加以分析


代码分析:

 

第一步:理解全局变量

[java] view plaincopy
  1. /**** 
  2.      * 其中listtag是分类的分割标签,每个组的head 
  3.      */  
  4.     private List<String> list = null;         //存放联系人数据的list  
  5.     private List<String> listtag = null;      //存放字母的数据的list  
  6.     private GroupListAdapter adapter = null;    //自定义的Adapter对象  
  7.     private ListView listView = null;           //主layout中用到的listview  

第二步:MainActivity的onCreate方法处理

[java] view plaincopy
  1. @Override  
  2.     protected void onCreate(Bundle savedInstanceState) {  
  3.         super.onCreate(savedInstanceState);  
  4.         setContentView(R.layout.activity_main);  
  5.   
  6.         setData();                              //初始化联系人和首字母的数据  
  7.         adapter = new GroupListAdapter(this, list, listtag);    //[重要],将每一个item重写排版和编辑得到信息view之后放到adapter里面  
  8.         //将我们自定义的adapter放到listview里面  
  9.         listView = (ListView) findViewById(R.id.listView1);  
  10.         listView.setAdapter(adapter);  
  11.     }  

说明:注释中写的很清楚,我们总共就做了这几个逻辑处理,看到这里还不够清楚,带着我们的疑问往下看一步步的就清楚了。


第三步:初始化list数据(比较简单)

[java] view plaincopy
  1. //插入要显示的数据。listtag是联系人上面的分组ABCD。list为联系人数据  
  2.     public void setData() {  
  3.         list = new ArrayList<String>();  
  4.         listtag = new ArrayList<String>();  
  5.   
  6.         list.add("A");  
  7.         listtag.add("A");  
  8.         for (int i = 0; i < 4; i++) {  
  9.             list.add("阿波次的" + i);  
  10.         }  
  11.         list.add("B");  
  12.         listtag.add("B");  
  13.         for (int i = 0; i < 4; i++) {  
  14.             list.add("波士顿" + i);  
  15.         }  
  16.         list.add("C");  
  17.         listtag.add("C");  
  18.         for (int i = 0; i < 4; i++) {  
  19.             list.add("车辙" + i);  
  20.         }  
  21.     }  

第四步:自定义Adapter(重要)

[java] view plaincopy
  1. //自定义listAdapter,利用布局泵的方式定义每一个listview条目  
  2.     private static class GroupListAdapter extends ArrayAdapter<String> {  
  3.         private List<String> listTag = null;  
  4.           
  5.         public GroupListAdapter(Context context, List<String> objects,  
  6.                 List<String> tags) {  
  7.             super(context, 0, objects);  
  8.             this.listTag = tags;  
  9.         }  
  10.           
  11.         //禁用标签项的选择事件  
  12.         @Override  
  13.         public boolean isEnabled(int position) {  
  14.             if (listTag.contains(getItem(position))) {  
  15.                 return false;  
  16.             }  
  17.             return super.isEnabled(position);  
  18.         }  
  19.   
  20.           
  21.         //本方法是迭代的,迭代对象为构造方法第二个对象,依次取出每一个list条目,(重写就会执行)  
  22.         @Override  
  23.         public View getView(int position, View convertView, ViewGroup parent) {  
  24.             View view = convertView;  
  25.             if (listTag.contains(getItem(position))) {  
  26.                 view = LayoutInflater.from(getContext()).inflate(  
  27.                         R.layout.group_list_item_tag, null);  
  28.             } else {  
  29.                 view = LayoutInflater.from(getContext()).inflate(  
  30.                         R.layout.group_list_item, null);  
  31.             }  
  32.             TextView textView = (TextView) view  
  33.                     .findViewById(R.id.group_list_item_text);  
  34.             textView.setText(getItem(position));  
  35.             return view;  
  36.         }  
  37.     }  

说明:

OK,第四步可以说是我们整个功能的核心部分了,注意我们是继承了一个ArrayAdapter,然后重写了两个方法。首先注意这两个方法的作用,注释上给了很清楚,如果大家看不懂可以删除掉方法然后跑一跑程序加深一下理解。就明白这两个方法是做什么的了。注意:重写的方法一旦重写就肯定会执行,

 

单独说一下getview方法吧。你可以想象一下放个方法在我们定义的list对象的for循环迭代里面然后就存在了下面的关系

Position = I;

View = listview中应用的每一个viewitem

既然这样我想大家应该很容易看明白了。在迭代的同时利用当前的position对应的item和listTag对象去做对比。如果存在在这个其中就说明是标题行,那么就用布局泵拿到标题行对应的layout里面的view然后编辑该view为对应的方式。不存在就是普通的联系人行。这么说您懂了吗?

 

在经过了上面的这个处理之后我们再将每一个行view放到adapter中去。然后形成了我们最终的效果

 

 

 

Layout文件:

主layout:

1、activity_main.xml文件

[html] view plaincopy
  1. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"  
  2.     xmlns:tools="http://schemas.android.com/tools"  
  3.     android:layout_width="fill_parent"  
  4.     android:layout_height="fill_parent"  
  5.     android:orientation="vertical"  
  6.     tools:context=".MainActivity" >  
  7.     <ListView  
  8.         android:id="@+id/listView1"  
  9.         android:layout_width="match_parent"  
  10.         android:layout_height="wrap_content"   
  11.         android:cacheColorHint="#00000000"  
  12.         >  
  13.     </ListView>  
  14. </LinearLayout>  

模板layout文件:

1、 group_list_item_tag.xml文件 [联系人layout模板]

[html] view plaincopy
  1. <?xml version="1.0" encoding="utf-8"?>  
  2. <!-- 联系人layout模板 -->  
  3. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"  
  4.     android:layout_width="fill_parent"  
  5.     android:layout_height="wrap_content"  
  6.     android:background="#555555"  
  7.     android:paddingLeft="10dip">  
  8.     <TextView  
  9.        android:id="@+id/group_list_item_text"  
  10.        android:layout_width="wrap_content"  
  11.        android:layout_height="20dip"  
  12.        android:textColor="#ffffff"  
  13.        android:gravity="center_vertical"/>  
  14. </LinearLayout>  

2、 group_list_item.xml 文件标题行layout模板

[html] view plaincopy
  1. <?xml version="1.0" encoding="utf-8"?>  
  2. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"  
  3.     android:orientation="horizontal"  
  4.     android:layout_width="fill_parent"  
  5.     android:layout_height="wrap_content"  
  6.     android:padding="5dip">  
  7.     <!-- 图片和文字 -->  
  8.     <!-- 随便放了一张图片,稍微美化一下 -->  
  9.     <ImageView  
  10.        android:src="@drawable/ic_launcher"  
  11.        android:layout_width="wrap_content"  
  12.        android:layout_height="wrap_content"/>  
  13.     <TextView  
  14.        android:id="@+id/group_list_item_text"  
  15.        android:layout_width="wrap_content"  
  16.        android:layout_height="fill_parent"  
  17.        android:paddingLeft="5dip"  
  18.        android:gravity="center_vertical"/>  
  19. </LinearLayout>  

最后的说明:

    后面的2个模板只是对应listview的每一个item的。希望大家理解。

 

 

源码下载地址:

http://pan.baidu.com/share/link?shareid=458100&uk=1997312776

0 0
原创粉丝点击