ExpandableListView实现列表收缩与展开

实现效果图:    (1)在xml文件里加入<ExpandableListView android:childDivider="#E8E8E8" android:groupIndicator="@null" android:divider="#E8E8E8" android:dividerHeight="1dp" android:id="@+id/el...
摘要由CSDN通过智能技术生成

实现效果图:

    

(1)在xml文件里加入

<ExpandableListView
    android:childDivider="#E8E8E8"
    android:groupIndicator="@null"
    android:divider="#E8E8E8"
    android:dividerHeight="1dp"
    android:id="@+id/elv"
    android:layout_width="match_parent"
    android:layout_height="match_parent"/>
(2)在activity_main里加
expandableListView = (ExpandableListView) findViewById(R.id.elv);
/* 1.1 创建一个adapter实例*/
MyExpandableListViewAdapter adapter = new MyExpandableListViewAdapter(getActivity());
/* 1. 设置适配器*/
expandableListView.setAdapter(adapter);
(3)新建MyExpandableListViewAdapter适配器
import android.content.Context;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.BaseExpandableListAdapter;
import android.widget.ImageView;
import android.widget.TextView;
/**
 * Created by lenovo on 2018/5/11.
 */
public class MyExpandableListViewAdapter extends BaseExpandableListAdapter {
    private Context context;
    /* 布局填充器*/
    private LayoutInflater inflater;
    private String[] group = new String[]{
 "最新代金券", "最新投票", "最新回答"};
    /* 构造,因为布局填充器填充布局需要使用到Context,通过构造来传递 */
    public MyExpandableListViewAdapter (Context context){
        this.context = context;
        inflater = LayoutInflater.from(context);
    }
    /*组数*/
    @Override
    public int getGroupCount() {
        return group.length;
    }
    /* 指定组的子Item数*/
    @Override
    public int getChildrenCount(int groupPosition) {
        if (groupPosition==0){
            return 0;
        }else if(groupPosition==1){
            return 1;
        }else {
            return 2;
        }
    }
    /*组数据*/
    @Override
    public Object getGroup(int groupPosition) {
        return group[groupPosition];
    }
    /*返回子选项的数据*/
    @Override
    public Object getChild(int groupPosition, int childPosition) {
        return 0;

    }
    /*组ID*/
    @Override
    public long getGroupId(int groupPosition) {
        return groupPosition;
    }
    /*子ID*/
    @Override
    public long getChildId(int groupPosition, int childPosition) {
        return childPosition;
    }
    /*ID是否唯一*/
    @Override
    public boolean hasStableIds() {
        return true;
    }
    /* 组选项的视图处理 */
    @Override
    public View getGroupView(int groupPosition, boolean isExpanded, View convertView, ViewGroup parent) {
        /* 填充布局*/
        View view = inflater
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
使用ExpandableListView可以实现QQ好友分组列表。首先需要创建一个ExpandableListView控件,并为其设置适配器。适配器需要继承BaseExpandableListAdapter,并实现以下方法: 1. getGroupCount():获取分组的数量。 2. getChildrenCount():获取某个分组下子项的数量。 3. getGroup():获取某个分组的数据。 4. getChild():获取某个分组下某个子项的数据。 5. getGroupId():获取某个分组的ID。 6. getChildId():获取某个分组下某个子项的ID。 7. hasStableIds():判断分组和子项的ID是否稳定。 8. getGroupView():获取分组的视图。 9. getChildView():获取子项的视图。 10. isChildSelectable():判断子项是否可选中。 在实现适配器的过程中,需要根据数据源的结构来设置分组和子项的数据。例如,可以使用一个List<List<String>>来存储分组和子项的数据,其中外层List表示分组,内层List表示子项。在getGroup()和getChild()方法中,需要根据groupPosition和childPosition来获取对应的数据。 最后,需要为ExpandableListView设置分组的展开和收起事件。可以通过设置OnGroupClickListener和OnChildClickListener来实现。在OnGroupClickListener中,需要根据groupPosition来判断当前分组是否已经展开,如果已经展开则返回false,否则返回true。在OnChildClickListener中,可以根据childPosition来获取对应的数据,并进行相应的操作。 通过以上步骤,就可以实现一个简单的QQ好友分组列表

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值