ExpandableListView实现简单二级列表

本文实例为大家分享了ExpandableListView实现简单二级列表的具体代码,供大家参考,具体内容如下

xml创建一个 ExpandableListView

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
 xmlns:tools="http://schemas.android.com/tools"
 android:layout_width="match_parent"
 android:layout_height="match_parent"
 tools:context="${relativePackage}.${activityClass}" >
 <ExpandableListView
 android:layout_width="match_parent"
 android:layout_height="match_parent"
 android:id="@+id/expandableListView">
 </ExpandableListView>

</RelativeLayout>

ExpandableListView的一级列表布局

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
 android:layout_width="match_parent"
 android:layout_height="80dp"
 android:orientation="vertical" >
 <TextView
 android:id="@+id/one_name"
 android:layout_width="wrap_content"
 android:layout_height="40dp"
 android:layout_centerInParent="true"
 android:textSize="20sp"
 android:text="我是一级列表"/>

</RelativeLayout>

ExpandableListView的二级列表布局

<?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="60dp"
 android:orientation="horizontal" >

 <ImageView
 android:id="@+id/img"
 android:layout_width="60dp"
 android:layout_height="60dp"
 android:src="@drawable/ic_launcher"/>
 <TextView
 android:layout_width="wrap_content"
 android:layout_height="wrap_content"
 android:id="@+id/tow_name"
 android:layout_marginTop="20dp"
 android:layout_marginLeft="20dp"
 android:text="嘻嘻哈哈"/>
</LinearLayout>

Java代码

package com.example.expandablelistview;

import java.util.ArrayList;
import java.util.List;

import android.R.string;
import android.app.Activity;
import android.os.Bundle;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.view.ViewGroup;
import android.widget.BaseExpandableListAdapter;
import android.widget.ExpandableListView;
import android.widget.TextView;

public class MainActivity extends Activity {
 private MainActivity.Madapder madapder;
 private ExpandableListView expandableListView;
 private List<String> allList;
 private List<List<Person>> list;
 @Override
 protected void onCreate(Bundle savedInstanceState) {
 super.onCreate(savedInstanceState);
 setContentView(R.layout.activity_main);
 //获取控件
 expandableListView=(ExpandableListView) findViewById(R.id.expandableListView);
 //初始化数据
 initData();
 //自定义适配器
 madapder=new Madapder();
 expandableListView.setAdapter(madapder);
 }
 public void initData() {
 allList=new ArrayList<String>();
 allList.add("列表①");
 allList.add("列表②");
 allList.add("列表③");
 list=new ArrayList<List<Person>>();
 List<Person> list1=new ArrayList<Person>();
 list1.add(new Person(" 虞姬"));
 list1.add(new Person(" 甄姬"));
 list1.add(new Person(" 阿狸"));
 list1.add(new Person(" 狐狸"));
 List<Person> list2=new ArrayList<Person>();
 list2.add(new Person(" 李白"));
 list2.add(new Person(" 項羽"));
 list2.add(new Person(" 荊軻"));
 list2.add(new Person(" 曹操"));
 List<Person> list3=new ArrayList<Person>();
 list3.add(new Person(" 公孙离"));
 list3.add(new Person(" 孙尚香"));
 list3.add(new Person(" 狄仁杰"));
 list3.add(new Person(" 蔡文姬"));
 list.add(list1);
 list.add(list2);
 list.add(list3);
 }
 class Madapder extends BaseExpandableListAdapter{

 @Override
 public int getGroupCount() {
 // TODO Auto-generated method stub
 return allList.size();
 }

 @Override
 public int getChildrenCount(int groupPosition) {
 // TODO Auto-generated method stub
 return list.get(groupPosition).size();
 }

 @Override
 public Object getGroup(int groupPosition) {
 // TODO Auto-generated method stub
 return allList.get(groupPosition);
 }

 @Override
 public Object getChild(int groupPosition, int childPosition) {
 // TODO Auto-generated method stub
 return list.get(groupPosition).get(childPosition);
 }

 @Override
 public long getGroupId(int groupPosition) {
 // TODO Auto-generated method stub
 return groupPosition;
 }

 @Override
 public long getChildId(int groupPosition, int childPosition) {
 // TODO Auto-generated method stub
 return childPosition;
 }

 @Override
 public boolean hasStableIds() {
 // TODO Auto-generated method stub
 return true;
 }

 @Override
 public View getGroupView(int groupPosition, boolean isExpanded,
 View convertView, ViewGroup parent) {
 GroupView groupView;
 if(convertView==null){
 groupView=new GroupView();
 //获取一级列表的布局
 convertView=View.inflate(MainActivity.this,R.layout.item_1, null);
 //复用控件
 groupView.name=(TextView) convertView.findViewById(R.id.one_name);
 //绑定
 convertView.setTag(groupView);
 }else {
 groupView = (GroupView) convertView.getTag();
 }
 //给控件设置值
 groupView.name.setText(allList.get(groupPosition));
 return convertView;
 }
 @Override
 public View getChildView(int groupPosition, int childPosition,
 boolean isLastChild, View convertView, ViewGroup parent) {
 ViewHolder Holder;
 if(convertView==null){
 Holder=new ViewHolder();
 //获取二级列表的布局
 convertView=View.inflate(MainActivity.this,R.layout.item_2, null);
 //复用控件
 Holder.text_name=(TextView) convertView.findViewById(R.id.tow_name);
 //绑定
 convertView.setTag(Holder);
 }else {
 Holder = (ViewHolder) convertView.getTag();
 }
 //给控件设置值
 Holder.text_name.setText(list.get(groupPosition).get(childPosition).getName());
 return convertView;
 }

 @Override
 public boolean isChildSelectable(int groupPosition, int childPosition) {
 // TODO Auto-generated method stub
 return true;
 }
 }
 class ViewHolder{
 TextView text_name;
 }
 class GroupView{
 TextView name;
 }
}

Java_封装类

package com.example.expandablelistview;

public class Person {
 String name;
 public Person() {
 // TODO Auto-generated constructor stub
 }
 public Person(String name) {
 super();
 this.name = name;
 }
 public String getName() {
 return name;
 }
 public void setName(String name) {
 this.name = name;
 }
 @Override
 public String toString() {
 return "Person [name=" + name + "]";
 }

}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • 完美实现ExpandableListView二级分栏效果

    本文实例为大家分享了ExpandableListView二级分栏效果的具体代码,供大家参考,具体内容如下 对ExpandableListView控件进行封装(未自定义)直接上代码: 通用ViewHolder类,仅在setImageResource中添加代码 package com.svp.haoyan.expandablelistview.tool; import android.content.Context; import android.graphics.Bitmap; import an

  • ExpandableListView实现二级列表购物车

    android中常常要用到ListView,有时也要用到ExpandableListView,如在手机设置中,对于分类有很好的效果,会用ListView的人一定会用ExpandableListView,因为ExpandableListView extends ListView的,下面来看个简单的例子 运行效果图: 导入依赖 compile 'com.google.code.gson:gson:2.8.2' compile 'com.squareup.okhttp3:okhttp:3.9.0' 记

  • ExpandableListView实现简单二级列表

    本文实例为大家分享了ExpandableListView实现简单二级列表的具体代码,供大家参考,具体内容如下 xml创建一个 ExpandableListView <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:layout_width="m

  • Android实现二级列表购物车功能

    本文实例为大家分享了Android实现二级列表购物车功能的具体代码,供大家参考,具体内容如下 MainActivity: package com.baway.twoshopcar; import android.os.Bundle; import android.support.v7.app.AppCompatActivity; import android.view.View; import android.widget.CheckBox; import android.widget.Expa

  • Android基于BaseExpandableListAdapter实现的二级列表仿通话记录功能详解

    本文实例讲述了Android基于BaseExpandableListAdapter实现的二级列表仿通话记录功能.分享给大家供大家参考,具体如下: android SDK中带有这样类似的例子,但是那个还是静态数据,没有实际应用价值,参考意义不大. 网上找了很多,还是那样的情况,几乎是同一篇文章,大家转来转去.况且,那篇例子也是静态的数据. 还是自己试试,自己写一个吧.程序读取手机系统的通话记录,按联系人分组,显示到列表. 开发工具:eclipse 运行环境:htc G9 android2.3.3

  • IOS实现展开二级列表效果

    先来看看效果图 用法(类似UITableView) 初始化XDMultTableView #import "XDMultTableView.h" ... @property(nonatomic, readwrite, strong)XDMultTableView *tableView; _tableView = [[XDMultTableView alloc] initWithFrame:CGRectMake(0, 64, self.view.frame.size.width, sel

  • Python简单删除列表中相同元素的方法示例

    本文实例讲述了Python简单删除列表中相同元素的方法.分享给大家供大家参考,具体如下: 去除列表中重复的元素,非常简单,直接上代码: a = [11, 21, 3, 4, 3, 2, 5] b = list(set(a)) print(a) print(b) 运行结果: E:\Program\Python>d.py [11, 21, 3, 4, 3, 2, 5] [2, 3, 4, 5, 11, 21] 看到了吗,结果中确实没有了重复的元素.但是,同时,结果中的元素被按从小到大进行了排序! P

  • jQuery简单实现列表隐藏和显示效果示例

    本文实例讲述了jQuery简单实现列表隐藏和显示效果.分享给大家供大家参考,具体如下: <!doctype html> <html lang="en"> <head> <meta charset="UTF-8"> <title>隐藏和显示</title> <style> *{ padding: 0; margin: 0;} li{ list-style-type: none;} bo

  • jquery实现的简单二级菜单效果代码

    本文实例讲述了jquery实现的简单二级菜单效果代码.分享给大家供大家参考.具体如下: 这是一款基于jquery实现的二级菜单,研究了这么多天,才学会用jquery写一个菜单,也算是对自己的鼓励吧,自我感觉这个菜单很不错,欢迎朋友们指点江山. 运行效果截图如下: 在线演示地址如下: http://demo.jb51.net/js/2015/jquery-simple-2l-menu-style-demo-codes/ 具体代码如下: <!DOCTYPE html PUBLIC "-//W3

  • jQuery实现简单的列表式导航菜单效果代码

    本文实例讲述了jQuery实现简单的列表式导航菜单效果代码.分享给大家供大家参考.具体如下: 这里使用jQuery实现简单的列表式导航菜单,是根据网上的一个教程,边看边写的,经过了修正,拷贝代码即可使用.主要实现包括三个部分,一是CSS.二是引入jQuery.三是编写JS代码进行jQuery控件. 运行效果截图如下: 在线演示地址如下: http://demo.jb51.net/js/2015/jquery-simple-list-style-nav-menu-codes/ 具体代码如下: <h

  • Smarty最简单实现列表奇偶变色的方法

    本文实例讲述了Smarty最简单实现列表奇偶变色的方法.分享给大家供大家参考.具体如下: 最近在换模板的过程中遇到过一个问题:列表页隔行换色,本来想用程序实现的,但在网上发现smarty模板中有一个很方便的方法,特分享一下: {section name=cat loop=$list} <tr bgcolor="{cycle values="#FFFFFF,#CCCCCC"}"> <td>{$list[cat].id}</td> &

随机推荐