在Fragment里面使用ExpandableListView实现仿qq好友列表

来源:互联网 发布:阅微草堂笔记 知乎 编辑:程序博客网 时间:2024/05/27 19:27

概要

         本来以为这个很简单,却迟迟没有发出来....因违反发现后来出了一点小问题,我们的界面切换标题栏是改变的,这样就不能把标题栏放到activity里,我们用的是fragment啊,鉴于有些朋友只需要知道怎么在fragment里面使用ExpandableListView,这里就不废话了,先上效果图,如果觉得是您要的在向下看,节省您的时间~

效果展示



知识点

1、了解什么是ExpandableListView

相信LinstView大家已经不陌生了,ExpandableListView就是升级版的Listview,只是每个ListView里面还有一个ListView而已,我们通常把可以展开的ListView称为Group,不可展开的称Child

2、了解LayoutInflater

有时候我们需要在一个界面里引用另一个界面,这时就需要实例化一个layoutInflater,在Activity里有三种方法,在Fragment里在这写方法之前加一个getActivity即可
建议大家看一下这篇博文,讲的是其在Activity中的应用,至于怎么在Fragment里面使用,请看下文

http://blog.csdn.net/zuolongsnail/article/details/6370035

DEMO

关于fragment具体的内部使用我们之前还没有说过,很多Activity里面有的方法他都没有,这就需要我们熟练地掌握它,一般可以用view和getactivity解决

下面先说一下代码结构: 一个Group的布局、一个Child的布局、一个fragment的布局、一个fragment里面的实现

首先我们在fragment的布局文件里设置ExpandableListView

<?xml version="1.0" encoding="utf-8"?><LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"    android:orientation="vertical"    android:layout_width="fill_parent"    android:layout_height="fill_parent"    android:background="#efefef">    <include layout="@layout/title_linkman"></include>    <ImageButton        android:layout_width="fill_parent"        android:layout_height="45dp"        android:background="@drawable/find_button"/>   <LinearLayout       android:layout_width="fill_parent"       android:layout_height="wrap_content"       android:orientation="horizontal"       android:background="#ffffff"       >       <LinearLayout           android:layout_width="90dp"           android:layout_height="wrap_content"           android:orientation="vertical">           <ImageView               android:layout_width="wrap_content"               android:layout_height="wrap_content"               android:src="@drawable/lv3"               android:layout_gravity="center"               android:paddingTop="8dp"/>           <TextView               android:layout_width="wrap_content"               android:layout_height="wrap_content"               android:text="新朋友"               android:textSize="18dp"               android:paddingTop="3dp"               android:layout_gravity="center"               android:textColor="#000000"/>       </LinearLayout>       <LinearLayout           android:layout_width="90dp"           android:layout_height="wrap_content"           android:orientation="vertical">           <ImageView               android:layout_width="wrap_content"               android:layout_height="wrap_content"               android:src="@drawable/lv4"               android:layout_gravity="center"               android:paddingTop="8dp"/>           <TextView               android:layout_width="wrap_content"               android:layout_height="wrap_content"               android:text="特别关心"               android:textSize="18dp"               android:paddingTop="3dp"               android:layout_gravity="center"               android:textColor="#000000"/>       </LinearLayout>       <LinearLayout           android:layout_width="90dp"           android:layout_height="wrap_content"           android:orientation="vertical">           <ImageView               android:layout_width="wrap_content"               android:layout_height="wrap_content"               android:src="@drawable/lv5"               android:layout_gravity="center"               android:paddingTop="8dp"/>           <TextView               android:layout_width="wrap_content"               android:layout_height="wrap_content"               android:text="群组"               android:textSize="18dp"               android:paddingTop="3dp"               android:layout_gravity="center"               android:textColor="#000000"/>       </LinearLayout>       <LinearLayout           android:layout_width="90dp"           android:layout_height="wrap_content"           android:orientation="vertical">           <ImageView               android:layout_width="wrap_content"               android:layout_height="wrap_content"               android:src="@drawable/lv6"               android:layout_gravity="center"               android:paddingTop="8dp"/>           <TextView               android:layout_width="wrap_content"               android:layout_height="wrap_content"               android:text="生活服务"               android:textSize="18dp"               android:paddingTop="3dp"               android:layout_gravity="center"               android:textColor="#000000"/>       </LinearLayout>       </LinearLayout>    <TextView        android:layout_width="wrap_content"        android:layout_height="wrap_content"        android:text="我的手机"        android:layout_marginTop="2dp"/>    <ExpandableListView        android:layout_width="fill_parent"        android:layout_height="wrap_content"        android:background="#ffffff"        android:id="@+id/my_phone">    </ExpandableListView></LinearLayout>
上面太罗嗦,总结一下精华就是这个

<ExpandableListView        android:layout_width="fill_parent"        android:layout_height="wrap_content"        android:background="#ffffff"        android:id="@+id/my_phone">    </ExpandableListView>

对,就是这样,代码都看得懂就不罗嗦了

下面是Group和Child的

Group是一个LinearLayout,里面只要有一个文本就行了,不过大家可以随意设计~

<?xml version="1.0" encoding="utf-8"?><LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"    android:layout_width="match_parent"    android:layout_height="45dp"    android:background="@color/me_blank_grey"    android:orientation="vertical">    <TextView        android:id="@+id/notice_item_date"        android:layout_width="wrap_content"        android:layout_height="wrap_content"        android:layout_gravity="center"        android:textColor="#000000"        android:gravity="center"        android:paddingTop="15dp"        android:paddingBottom="15dp"        android:layout_centerInParent="true"        android:text="2015-05-04"        android:textSize="20dp"        android:singleLine="true"        /></LinearLayout>

下面是Child布局

<?xml version="1.0" encoding="utf-8"?>    <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"        android:orientation="horizontal"        android:layout_width="fill_parent"        android:layout_height="fill_parent"       >    <ImageView        android:id="@+id/iv"        android:layout_width="50dp"        android:layout_height="50dp"        android:layout_gravity="center_vertical"/>     <TextView         android:layout_width="wrap_content"         android:layout_height="wrap_content"         android:id="@+id/group"         android:textSize="25sp"         android:paddingLeft="35px"         android:paddingTop="10px"         android:paddingRight="5px"         android:paddingBottom="10px"         android:text="No Data"         android:textColor="#000000"         android:layout_gravity="center_vertical"/>     </LinearLayout>

重头戏来了~ Fragment布局,我们边看那边说

package com.example.administrator.icephonefhhxml.Fragment;import android.app.Fragment;import android.content.Context;import android.os.Bundle;import android.view.LayoutInflater;import android.view.View;import android.view.ViewGroup;import android.widget.BaseExpandableListAdapter;import android.widget.ExpandableListView;import android.widget.ImageView;import android.widget.TextView;import com.example.administrator.icephonefhhxml.R;import java.util.ArrayList;import java.util.List;

包的引入~

public class FragmentBottomSecond extends Fragment {    private ExpandableListView expandableListView;    private List<String> Group;    private List<List<String>> Child;    private List<String> ChildFirst;    private List<String> ChildSecond;    private List<String> ChildThird;<pre name="code" class="java">    private List<List<Integer>> ChildPicture;

以上都是什么鬼呢??首先:Group,我们说过,你懂的,就是可展开的那个ListView的文字内容(我的设备、手机通讯录、我的好友),我们用一个储存String的ArrayList来声明,然后是那个不可展开的,我们用储存ArrayList<String>的ArrayList来声明,然后分别是三个ArrayLIst,分别储存每个Group下的Child的文本内容,最后是用来存储我们要用到的图片的地址的,正常来说我们要用三个,但为了方便,我们就把三个都当作这一个用了

    public FragmentBottomSecond() {    }    @Override    public View onCreateView(LayoutInflater inflater, ViewGroup container,                             Bundle savedInstanceState) {        View view = inflater.inflate(R.layout.contain_fragment_second, container, false);        Group = new ArrayList<String>();        Group.add("我的设备");        Group.add("手机通讯录");        Group.add("我的好友");        ChildFirst = new ArrayList<String>();        ChildFirst.add("我的电脑");        ChildFirst.add("我的手机");        ChildFirst.add("我的打印机");        ChildSecond= new ArrayList<String>();        ChildSecond.add("伊布");        ChildSecond.add("皮卡丘");        ChildSecond.add("喵喵");        ChildThird= new ArrayList<String>();        ChildThird.add("我的伊布");        ChildThird.add("我的皮卡丘");        ChildThird.add("我的喵喵");        Child = new ArrayList<List<String>>();        Child.add(ChildFirst);        Child.add(ChildSecond);        Child.add(ChildThird);        List<Integer> tmp_list = new ArrayList<Integer>();        tmp_list.add(R.drawable.user1);        tmp_list.add(R.drawable.user2);        tmp_list.add(R.drawable.user3);        ChildPicture = new ArrayList<List<Integer>>();        ChildPicture.add(tmp_list);        ChildPicture.add(tmp_list);        ChildPicture.add(tmp_list);

把东西都放到里面

        expandableListView = (ExpandableListView)view.findViewById(R.id.my_phone);

实例化expandableLIstView

        expandableListView.setAdapter(new MyExpandableListViewAdapter(getActivity()));

给他设置adapter,这里getActivity(),如果在Activity中用就是this

        expandableListView.setGroupIndicator(null);

让前面的箭头消失(设置为空)也可以设置成自定义的(括号里是图片地址(图片设为selector,之前有提及))或是默认的(把这句删掉),我这里没有合适的图片,默认的又太丑就索性设置为空

        return view;    }    class MyExpandableListViewAdapter extends BaseExpandableListAdapter {        private Context context;        public MyExpandableListViewAdapter(Context context) {            this.context = context;        }        @Override        public int getGroupCount() {            return Group.size();        }        @Override        public int getChildrenCount(int groupPosition) {            return Child.get(groupPosition).size();        }        @Override        public Object getGroup(int groupPosition) {            return Group.get(groupPosition);        }        @Override        public Object getChild(int groupPosition, int childPosition) {            return Child.get(groupPosition).get(childPosition);        }        @Override        public long getGroupId(int groupPosition) {            return groupPosition;        }        @Override        public long getChildId(int groupPosition, int childPosition) {            return childPosition;        }        @Override        public boolean hasStableIds() {            return true;        }

以上都是固定形式,没有特殊要求直接返回即可(具体含义看英文可懂就不赘述了)

        @Override        public View getGroupView(int groupPosition, boolean isExpanded,                                 View convertView, ViewGroup parent) {            GroupHolder groupHolder = null;     //我们自己设定的一个简单类,用来存储控件的相关信息            if (convertView == null) {          //这里的convertView其实是一个起缓冲作用的,工具,因为当一个item从屏幕中滚出,我们把它放到convertView里                                                 //,这样再滑回来的时候可以直接去取,不用重新创建,这里也推荐一个网址,大家可以详细了解
http://blog.csdn.net/bill_ming/article/details/8817172
                convertView = (View) getActivity().getLayoutInflater().from(context).inflate(                        R.layout.group_view, null);      //把界面放到缓冲区                groupHolder = new GroupHolder();          //实例化我们创建的这个类                groupHolder.txt = (TextView) convertView.findViewById(R.id.notice_item_date);  //实例化类里的TextView                convertView.setTag(groupHolder);                                 //给view对象一个标签,告诉计算机我们已经在缓冲区里放了一个view,下回直                                                                               //接来拿就行了            } else {                groupHolder = (GroupHolder) convertView.getTag();     //然后他就直接来拿            }            groupHolder.txt.setText(Group.get(groupPosition));//最后在相应的group里设置他相应的Text            return convertView;        }

从某种角度来说,最重要的就是设置Group和Chuild的外观,以及把外观和我们之前设置的数据对应起来,我们详细说一个另一个类似

        @Override        public View getChildView(int groupPosition, int childPosition,                                 boolean isLastChild, View convertView, ViewGroup parent) {            ItemHolder itemHolder = null;            if (convertView == null) {                convertView = (View) getActivity().getLayoutInflater().from(context).inflate(                        R.layout.text_view, null);                itemHolder = new ItemHolder();                itemHolder.txt = (TextView) convertView.findViewById(R.id.group);                itemHolder.img = (ImageView) convertView.findViewById(R.id.iv);                convertView.setTag(itemHolder);            } else {                itemHolder = (ItemHolder) convertView.getTag();            }            itemHolder.txt.setText(Child.get(groupPosition).get(                    childPosition));            itemHolder.img.setBackgroundResource(ChildPicture.get(groupPosition).get(                    childPosition));            return convertView;        }        @Override        public boolean isChildSelectable(int groupPosition, int childPosition) {            return true;        }    }    class GroupHolder {        public TextView txt;        public ImageView img;    }    class ItemHolder {        public ImageView img;        public TextView txt;    }}

感想

不了解fragmen做起来确实很累,博主是新手,有什么不对的地方还请指教,另外如果读者有什么不明白的或者细节上的问题也可以q我或留言,大家加油咯~~

每日一句:


有人说,遇到对的那个人,不是强烈的动心,而是长久的安心--你知道,“他不会走”,无论你多么落魄多么不修边幅,他也不会走。你无需装得多么优秀,多么可人,他喜欢的就是你现在这样最自然的样子。

3 1