基本信息
源码名称:Android 二级列表效果
源码大小:0.15M
文件格式:.rar
开发语言:Java
更新时间:2016-04-26
友情提示:(无需注册或充值,赞助后即可获取资源下载链接)
嘿,亲!知识可是无价之宝呢,但咱这精心整理的资料也耗费了不少心血呀。小小地破费一下,绝对物超所值哦!如有下载和支付问题,请联系我们QQ(微信同号):813200300
本次赞助数额为: 2 元×
微信扫码支付:2 元
×
请留下您的邮箱,我们将在2小时内将文件发到您的邮箱
源码介绍
使用了expandlistview,用于展开二级列表
package com.myproject.test; import com.eyu.activity_test.R; import android.app.Activity; import android.graphics.Color; import android.os.Bundle; import android.view.View; import android.view.ViewGroup; import android.view.Window; import android.widget.BaseExpandableListAdapter; import android.widget.ExpandableListAdapter; import android.widget.ExpandableListView; import android.widget.ExpandableListView.OnChildClickListener; import android.widget.ExpandableListView.OnGroupClickListener; import android.widget.ImageView; import android.widget.RelativeLayout; import android.widget.TextView; /** * 自定义ExpandableList列表类 * * @author jgduan * */ public class ExpandableList extends Activity { // 这个数组是用来存储一级item的点击次数的,根据点击次数设置一级标签的选中、为选中状态 private int[] group_checked = new int[] { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 }; // 用来标识是否设置二級item背景色为绿色,初始值为-1既为选中状态 private int child_groupId = -1; private int child_childId = -1; protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); // 隐藏标题 requestWindowFeature(Window.FEATURE_NO_TITLE); // 指定布局 setContentView(R.layout.main); // 新建一个ExpandableListView ExpandableListView expandableListView = (ExpandableListView) findViewById(R.id.list); // 设置默认图标为不显示状态 expandableListView.setGroupIndicator(null); // 为列表绑定数据源 expandableListView.setAdapter(adapter); // 设置一级item点击的监听器 expandableListView.setOnGroupClickListener(new OnGroupClickListener() { @Override public boolean onGroupClick(ExpandableListView parent, View v, int groupPosition, long id) { group_checked[groupPosition] = group_checked[groupPosition] 1; // 刷新界面 ((BaseExpandableListAdapter) adapter).notifyDataSetChanged(); return false; } }); // 设置二级item点击的监听器 expandableListView.setOnChildClickListener(new OnChildClickListener() { @Override public boolean onChildClick(ExpandableListView parent, View v, int groupPosition, int childPosition, long id) { // 将被点击的一丶二级标签的位置记录下来 child_groupId = groupPosition; child_childId = childPosition; // 刷新界面 ((BaseExpandableListAdapter) adapter).notifyDataSetChanged(); return false; } }); } final ExpandableListAdapter adapter = new BaseExpandableListAdapter() { // 一级标签上的logo图片数据源 int[] group_logo_array = new int[] { R.drawable.map, R.drawable.message, R.drawable.music, R.drawable.children }; // 一级标签上的标题数据源 private String[] group_title_arry = new String[] { "中医常识", "中医养生", "美容养颜", "育儿百科" }; // 一级标签的描述文本数据源 private String[] group_text_array = new String[] { "经络", "安神醒脑", "减肥", "幼儿保健" }; // 子视图显示文字 private String[][] child_text_array = new String[][] { { "孕吐怎么办", "孕吐怎么办", "孕吐怎么办", "孕吐怎么办" }, { "新生儿治疗", "新生儿治疗", "新生儿治疗", "新生儿治疗" }, { "孕吐怎么办", "孕吐怎么办", "孕吐怎么办", "孕吐怎么办" }, { "新生儿治疗", "新生儿治疗", "新生儿治疗", "新生儿治疗" } }; // 一级标签上的状态图片数据源 int[] group_state_array = new int[] { R.drawable.group_down, R.drawable.group_up }; // 重写ExpandableListAdapter中的各个方法 /** * 获取一级标签总数 */ @Override public int getGroupCount() { return group_text_array.length; } /** * 获取一级标签内容 */ @Override public Object getGroup(int groupPosition) { return group_text_array[groupPosition]; } /** * 获取一级标签的ID */ @Override public long getGroupId(int groupPosition) { return groupPosition; } /** * 获取一级标签下二级标签的总数 */ @Override public int getChildrenCount(int groupPosition) { return child_text_array[groupPosition].length; } /** * 获取一级标签下二级标签的内容 */ @Override public Object getChild(int groupPosition, int childPosition) { return child_text_array[groupPosition][childPosition]; } /** * 获取二级标签的ID */ @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) { // 为视图对象指定布局 convertView = (RelativeLayout) RelativeLayout.inflate( getBaseContext(), R.layout.group, null); /** * 声明视图上要显示的控件 */ // 新建一个ImageView对象,用来显示一级标签上的logo图片 ImageView group_logo = (ImageView) convertView .findViewById(R.id.group_logo); // 新建一个TextView对象,用来显示一级标签上的标题信息 TextView group_title = (TextView) convertView .findViewById(R.id.group_title); // 新建一个TextView对象,用来显示一级标签上的大体描述的信息 TextView group_text = (TextView) convertView .findViewById(R.id.group_text); // 新建一个ImageView对象,根据用户点击来标识一级标签的选中状态 ImageView group_state = (ImageView) convertView .findViewById(R.id.group_state); /** * 设置相应控件的内容 */ // 设置要显示的图片 group_logo.setBackgroundResource(group_logo_array[groupPosition]); // 设置标题上的文本信息 group_title.setText(group_title_arry[groupPosition]); // 设置整体描述上的文本信息 group_text.setText(group_text_array[groupPosition]); if (group_checked[groupPosition] % 2 == 1) { // 设置默认的图片是选中状态 group_state.setBackgroundResource(group_state_array[1]); } else { for (int test : group_checked) { if (test == 0 || test % 2 == 0) { // 设置默认的图片是未选中状态 group_state.setBackgroundResource(group_state_array[0]); } } } // 返回一个布局对象 return convertView; } /** * 对一级标签下的二级标签进行设置 */ @Override public View getChildView(int groupPosition, int childPosition, boolean isLastChild, View convertView, ViewGroup parent) { // 为视图对象指定布局 convertView = (RelativeLayout) RelativeLayout.inflate( getBaseContext(), R.layout.child, null); /** * 声明视图上要显示的控件 */ // 新建一个TextView对象,用来显示具体内容 TextView child_text = (TextView) convertView .findViewById(R.id.child_text); /** * 设置相应控件的内容 */ // 设置要显示的文本信息 child_text.setText(child_text_array[groupPosition][childPosition]); // 判断item的位置是否相同,如相同,则表示为选中状态,更改其背景颜色,如不相同,则设置背景色为白色 if (child_groupId == groupPosition && child_childId == childPosition) { // 设置背景色为绿色 convertView.setBackgroundColor(Color.GREEN); } else { // 设置背景色为白色 convertView.setBackgroundColor(Color.WHITE); } // 返回一个布局对象 return convertView; } /** * 当选择子节点的时候,调用该方法 */ @Override public boolean isChildSelectable(int groupPosition, int childPosition) { return true; } }; }