• android列表收缩与展开仿QQ好友列表(非常详细,附源码)


         好友QQ列表,可以展开,可以收起,在android中,以往用的比较多的是listview,虽然可以实现列表的展示,但在某些情况下,我们还是希望用到可以分组并实现收缩的列表,那就要用到android的ExpandableListView,今天研究了一下这个的用法,也参考了很多资料动手写了一个小demo,实现了基本的功能,下面直接上效果图以及源代码!

         ExpandableListView是一个垂直滚动显示两级列表项的视图,与ListView不同的是,它可以有两层:每一层都能够被独立的展开并显示其子项。

    本文效果:

    效果一源码下载

    效果二源码下载

    A60[4]

    A61[6]A63[5]

    目录:

    一、实现原理

    二、布局与代码

    三、自定义图标

    四、图标放置右边

    一、实现原理

    1,首先必须在布局文件中定义一个ExpandableListView

    2,其次创建一级条目对应的布局文件group

    3,创建二级条目对应的布局文件child

    4,加载ExpandableListView组件的Activity必须继承自ExpandableListActivity

    二、布局与代码

    1、首先在主布局中activity_main.xml

    <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
        android:layout_width="fill_parent"
        android:layout_height="fill_parent"
        android:orientation="vertical" >
    
        <ExpandableListView
            android:id="@id/android:list"
            android:layout_width="fill_parent"
            android:layout_height="fill_parent" />
    
    </LinearLayout>

    2、其次在drawable文件夹定义布局一级列表groups.xml

    <LinearLayout
        xmlns:android="http://schemas.android.com/apk/res/android"
        android:orientation="vertical"
        android:layout_width="fill_parent"
        android:layout_height="fill_parent"
    >
        <TextView
            android:id="@+id/textGroup"
            android:layout_width="fill_parent"
            android:layout_height="fill_parent"
            android:paddingLeft="40px"
            android:paddingTop="6px"
            android:paddingBottom="6px"
            android:textSize="25sp"
            android:text="No data"
        />
    
    </LinearLayout>

    3、接着在drawable文件夹定义布局二级列表childs.xml

    <LinearLayout
        xmlns:android="http://schemas.android.com/apk/res/android"
      android:orientation="vertical"
        android:layout_width="fill_parent"
        android:layout_height="fill_parent"
    >
        <TextView 
            android:id="@+id/textChild"
       android:layout_width="fill_parent"
            android:layout_height="fill_parent"
            android:paddingLeft="60px"
            android:paddingTop="10px"
            android:paddingBottom="10px"
            android:textSize="20sp"
       android:text="No Data"
    />
    
    </LinearLayout>

    4、然后就是初始化和使用了

    package com.example.expandablelistview;
    
    import java.util.ArrayList;
    import java.util.HashMap;
    import java.util.List;
    import java.util.Map;
    import android.os.Bundle;
    import android.app.ExpandableListActivity;
    import android.util.DisplayMetrics;
    import android.view.View;
    import android.widget.ExpandableListView;
    import android.widget.SimpleExpandableListAdapter;
    import android.widget.Toast;
    
    public class MainActivity extends ExpandableListActivity {
    	/**
    	 * 创建一级条目容器
    	 */
    	List<Map<String, String>> gruops = new ArrayList<Map<String, String>>();
    	/**
    	 * 存放内容, 以便显示在列表中
    	 */
    	List<List<Map<String, String>>> childs = new ArrayList<List<Map<String, String>>>();
    
    	@Override
    	public void onCreate(Bundle savedInstanceState) {
    		super.onCreate(savedInstanceState);
    		setContentView(R.layout.activity_main);
    		setListData();
    	}
    
    	/**
    	 * 设置列表内容
    	 */
    	public void setListData() {
    		// 创建二个一级条目标题
    		Map<String, String> title_1 = new HashMap<String, String>();
    		Map<String, String> title_2 = new HashMap<String, String>();
    		Map<String, String> title_3 = new HashMap<String, String>();
    		title_1.put("group", "林炳文");
    		title_2.put("group", "文炳林");
    		gruops.add(title_1);
    		gruops.add(title_2);
    
    		// 创建二级条目内容
    		// 内容一
    		Map<String, String> title_1_content_1 = new HashMap<String, String>();
    		Map<String, String> title_1_content_2 = new HashMap<String, String>();
    		Map<String, String> title_1_content_3 = new HashMap<String, String>();
    		title_1_content_1.put("child", "工人");
    		title_1_content_2.put("child", "学生");
    		title_1_content_3.put("child", "农民");
    
    		List<Map<String, String>> childs_1 = new ArrayList<Map<String, String>>();
    		childs_1.add(title_1_content_1);
    		childs_1.add(title_1_content_2);
    		childs_1.add(title_1_content_3);
    
    		// 内容二
    		Map<String, String> title_2_content_1 = new HashMap<String, String>();
    		Map<String, String> title_2_content_2 = new HashMap<String, String>();
    		Map<String, String> title_2_content_3 = new HashMap<String, String>();
    		title_2_content_1.put("child", "猩猩");
    		title_2_content_2.put("child", "老虎");
    		title_2_content_3.put("child", "狮子");
    		List<Map<String, String>> childs_2 = new ArrayList<Map<String, String>>();
    		childs_2.add(title_2_content_1);
    		childs_2.add(title_2_content_2);
    		childs_2.add(title_2_content_3);
    
    		childs.add(childs_1);
    		childs.add(childs_2);
    
    		/**
    		 * 创建ExpandableList的Adapter容器 参数: 1.上下文 2.一级集合 3.一级样式文件 4. 一级条目键值
    		 * 5.一级显示控件名 6. 二级集合 7. 二级样式 8.二级条目键值 9.二级显示控件名
    		 * 
    		 */
    		SimpleExpandableListAdapter sela = new SimpleExpandableListAdapter(
    				this, gruops, R.drawable.groups, new String[] { "group" },
    				new int[] { R.id.textGroup }, childs, R.drawable.childs,
    				new String[] { "child" }, new int[] { R.id.textChild });
    		// 加入列表
    		setListAdapter(sela);
    	}
    
    	/**
    	 * 列表内容按下
    	 */
    	@Override
    	public boolean onChildClick(ExpandableListView parent, View v,
    			int groupPosition, int childPosition, long id) {
    		Toast.makeText(
    				MainActivity.this,
    				"您选择了"
    						+ gruops.get(groupPosition).toString()
    						+ "子编号"
    						+ childs.get(groupPosition).get(childPosition)
    								.toString(), Toast.LENGTH_SHORT).show();
    		return super.onChildClick(parent, v, groupPosition, childPosition, id);
    	}
    
    	/**
    	 * 二级标题按下
    	 */
    	@Override
    	public boolean setSelectedChild(int groupPosition, int childPosition,
    			boolean shouldExpandGroup) {
    		return super.setSelectedChild(groupPosition, childPosition,
    				shouldExpandGroup);
    	}
    
    	/**
    	 * 一级标题按下
    	 */
    	@Override
    	public void setSelectedGroup(int groupPosition) {
    		super.setSelectedGroup(groupPosition);
    	}
    }

    5、效果

    这是我手机上的效果,点击工人。学生等二级列表时,我手机上会有提示框出现的,但是不知为什么录制下来就是没有。A60三、自定义列表图标

    上面的图标是系统自己生成的,下面我们要改成自己的

    1、更改自定义图标

    在drawable文件夹下新建expandablelistview_change.xml

    <?xml version = "1.0"   encoding = "utf-8"?>
    <selector   xmlns:android = "http://schemas.android.com/apk/res/android" >      
         <item android:state_expanded = "true"   android:drawable = "@drawable/w2"/>      
         <item android:drawable = "@drawable/w1"/>      
    </selector > 

    2、修改上面布局Activity.main.xml

    <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
        android:layout_width="fill_parent"
        android:layout_height="fill_parent"
        android:orientation="vertical" >
    
        <ExpandableListView
            android:id="@id/android:list"
            android:layout_width="fill_parent"
            android:layout_height="fill_parent"
            android:background="#f5f5f5"
            android:cacheColorHint="#f5f5f5"
            android:groupIndicator="@drawable/expandablelistview_change" />
    
    </LinearLayout>

    其实就是加了一句android:groupIndicator="@drawable/expandablelistview_change"

    下面我们再来看看效果:

    A61[6]四、图标放置右边

    在上面MainActivity.java的函数setListData()加中:

    		// 得到屏幕的大小
    		DisplayMetrics dm = new DisplayMetrics();
    		getWindowManager().getDefaultDisplay().getMetrics(dm);
    		//图标设置在右边
    		getExpandableListView().setIndicatorBounds(dm.widthPixels-60, dm.widthPixels); // 设置指示图标的位置

    效果:

    A63[5]

  • 相关阅读:
    如何抓住用户痛点做产品?
    分析需求场景对产品设计的意义
    【用户分析-用户场景】这TM才是产品思维!
    WebUploader实现浏览器端大文件分块上传
    npm 安装包报错 rollbackFailedOptional
    PAT 甲级 1074 Reversing Linked List (25 分)(链表部分逆置,结合使用双端队列和栈,其实使用vector更简单呐)...
    PAT 甲级 1071 Speech Patterns (25 分)(map)
    P3370 【模板】字符串哈希
    PageRank算法原理与Python实现
    PAT-2019年冬季考试-甲级 7-4 Cartesian Tree (30分)(最小堆的中序遍历求层序遍历,递归建树bfs层序)...
  • 原文地址:https://www.cnblogs.com/yncxzdy/p/4298975.html
Copyright © 2020-2023  润新知