在好例子网,分享、交流、成长!
您当前所在位置:首页Java 开发实例Android平台开发 → Android 二级列表效果

Android 二级列表效果

Android平台开发

下载此实例
  • 开发语言:Java
  • 实例大小:0.15M
  • 下载次数:30
  • 浏览次数:362
  • 发布时间:2016-04-26
  • 实例类别:Android平台开发
  • 发 布 人:yu0784
  • 文件格式:.rar
  • 所需积分:2
 相关标签: Android expandlistview

实例介绍

【实例简介】

使用了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;
		}

	};

}

实例下载地址

Android 二级列表效果

不能下载?内容有错? 点击这里报错 + 投诉 + 提问

好例子网口号:伸出你的我的手 — 分享

网友评论

发表评论

(您的评论需要经过审核才能显示)

查看所有0条评论>>

小贴士

感谢您为本站写下的评论,您的评论对其它用户来说具有重要的参考价值,所以请认真填写。

  • 类似“顶”、“沙发”之类没有营养的文字,对勤劳贡献的楼主来说是令人沮丧的反馈信息。
  • 相信您也不想看到一排文字/表情墙,所以请不要反馈意义不大的重复字符,也请尽量不要纯表情的回复。
  • 提问之前请再仔细看一遍楼主的说明,或许是您遗漏了。
  • 请勿到处挖坑绊人、招贴广告。既占空间让人厌烦,又没人会搭理,于人于己都无利。

关于好例子网

本站旨在为广大IT学习爱好者提供一个非营利性互相学习交流分享平台。本站所有资源都可以被免费获取学习研究。本站资源来自网友分享,对搜索内容的合法性不具有预见性、识别性、控制性,仅供学习研究,请务必在下载后24小时内给予删除,不得用于其他任何用途,否则后果自负。基于互联网的特殊性,平台无法对用户传输的作品、信息、内容的权属或合法性、安全性、合规性、真实性、科学性、完整权、有效性等进行实质审查;无论平台是否已进行审查,用户均应自行承担因其传输的作品、信息、内容而可能或已经产生的侵权或权属纠纷等法律责任。本站所有资源不代表本站的观点或立场,基于网友分享,根据中国法律《信息网络传播权保护条例》第二十二与二十三条之规定,若资源存在侵权或相关问题请联系本站客服人员,点此联系我们。关于更多版权及免责申明参见 版权及免责申明

;
报警