自定义ExpandableListView 实现像QQ好友列表一样的功能


直接上代码。


1. 先自定义一个View  重写ExpandableListView  

package com.coustom.myex;

import android.content.Context;
import android.util.AttributeSet;
import android.view.View;
import android.widget.AbsListView;
import android.widget.AdapterView;
import android.widget.ExpandableListAdapter;
import android.widget.ExpandableListView;
import android.widget.FrameLayout;
import android.widget.AbsListView.OnScrollListener;
import android.widget.RelativeLayout;

public class QExListView extends ExpandableListView implements OnScrollListener {
	private RelativeLayout _groupLayout;
	public int _groupIndex = -1;
	private ExpandableListAdapter _exAdapter;

	@Override
	public void setAdapter(ExpandableListAdapter adapter) {
		super.setAdapter(adapter);
	}

	/**
	 * @param context
	 */
	public QExListView(Context context) {
		super(context);
		super.setOnScrollListener(this);
	}

	/**
	 * @param context
	 * @param attrs
	 */
	public QExListView(Context context, AttributeSet attrs) {
		super(context, attrs);
		super.setOnScrollListener(this);
	}

	/**
	 * @param context
	 * @param attrs
	 * @param defStyle
	 */
	public QExListView(Context context, AttributeSet attrs, int defStyle) {
		super(context, attrs, defStyle);
		super.setOnScrollListener(this);
	}

	@Override
	public void onScroll(AbsListView view, int firstVisibleItem,
			int visibleItemCount, int totalItemCount) {

		if (_exAdapter == null)
			_exAdapter = this.getExpandableListAdapter();

		int ptp = view.pointToPosition(0, 0);
		if (ptp != AdapterView.INVALID_POSITION) {
			QExListView qExlist = (QExListView) view;
			long pos = qExlist.getExpandableListPosition(ptp);
			int groupPos = ExpandableListView.getPackedPositionGroup(pos);
			int childPos = ExpandableListView.getPackedPositionChild(pos);

			if (childPos < 0) {
				groupPos = -1;
			}
			if (groupPos < _groupIndex) {

				_groupIndex = groupPos;

				if (_groupLayout != null) {
					_groupLayout.removeAllViews();
					_groupLayout.setVisibility(GONE);// 这里设置Gone 为了不让它遮挡后面header
				}
			} else if (groupPos > _groupIndex) {
				final FrameLayout fl = (FrameLayout) getParent();
				_groupIndex = groupPos;
				if (_groupLayout != null)
					fl.removeView(_groupLayout);

				_groupLayout = (RelativeLayout) getExpandableListAdapter()
						.getGroupView(groupPos, true, null, null);
				_groupLayout.setOnClickListener(new OnClickListener() {

					@Override
					public void onClick(View v) {
						collapseGroup(_groupIndex);
					}
				});

				fl.addView(_groupLayout, fl.getChildCount(), new LayoutParams(
						LayoutParams.FILL_PARENT, 50));

			}
		}
	}

	@Override
	public void onScrollStateChanged(AbsListView view, int scrollState) {
	}

}

2. 设置Adapter 

package com.coustom.myex;

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

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;

public class ExAdapter extends BaseExpandableListAdapter {
	private ArrayList<String> group;
	private ArrayList<List<String>> child;

	public void initData() {
		group = new ArrayList<String>();
		child = new ArrayList<List<String>>();
		setData("女人健康", new String[] { "运动健康", "潮流服饰", "美容健康", "减肥瘦身", "身体健康",
				"饮食健康", "运动健康", "潮流服饰", "美容健康", "减肥瘦身", "身体健康", "饮食健康", "运动健康",
				"潮流服饰", "美容健康", "减肥瘦身", "身体健康", "饮食健康" });
		setData("女人养生", new String[] { "饮食养生", "运动养生", "健身养生", "冬季养生", "日常护理",
				"运动健康", "潮流服饰", "美容健康", "减肥瘦身", "身体健康", "饮食健康", "运动健康", "潮流服饰",
				"美容健康", "减肥瘦身", "身体健康", "饮食健康" });
		setData("其他", new String[] { "爱美我在行", "保健一点通", "吃喝有门道", "生活小窍门" });

	}

	public void setData(String group, String[] child) {
		this.group.add(group);
		List<String> listChild = new ArrayList<String>();
		for (int i = 0; i < child.length; i++) {
			listChild.add(child[i]);
		}
		this.child.add(listChild);
	}

	Context mContext;

	public ExAdapter(Context context) {
		mContext = context;
		initData();
	}

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

	@Override
	public int getChildrenCount(int groupPosition) {
		// 返回的是对应group的child大小,不能将child的所有元素返回
		return child.get(groupPosition).size();
	}

	@Override
	public Object getGroup(int groupPosition) {
		// 根据groupPosition的索引值返回group对象
		return group.get(groupPosition);
	}

	@Override
	public Object getChild(int groupPosition, int childPosition) {
		// 根据groupPosition,childPosition索引值,返回一个child对象
		return child.get(groupPosition).get(childPosition);
	}

	@Override
	public long getGroupId(int groupPosition) {
		// 返回groupPosition的id
		return groupPosition;
	}

	@Override
	public long getChildId(int groupPosition, int childPosition) {
		// 返回childPosition的id
		return childPosition;
	}

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

	/*
	 * 回调方法 isExpanded 第一次打开的时候,是否显二级菜单
	 */
	@Override
	public View getGroupView(int groupPosition, boolean isExpanded,
			View convertView, ViewGroup parent) {
		View view = LayoutInflater.from(mContext).inflate(
				R.layout.ex_list_parent_item, parent, false);

		// 可以在这里填充布局
		TextView textView = (TextView) view.findViewById(R.id.textView1);
		ImageView imageView = (ImageView) view.findViewById(R.id.imageView1);
		imageView.setPadding(0, 15, 0, 0);
		textView.setText(group.get(groupPosition));
		if (isExpanded) {
			imageView.setImageResource(R.drawable.arrow_down);
		} else {
			imageView.setImageResource(R.drawable.arrow_right);
		}
		textView.setTextSize(25);
//		textView.setPadding(30, 5, 0, 5);
		return view;
	}

	// 在这里是获取二级list的
	@Override
	public View getChildView(int groupPosition, int childPosition,
			boolean isLastChild, View convertView, ViewGroup parent) {
		ViewHodler viewHodler = new ViewHodler();
		// 可以在这里填充布局
		if (convertView == null) {
			convertView = LayoutInflater.from(mContext).inflate(
					R.layout.item_list_artlist, parent, false);
			viewHodler.textView = (TextView) convertView
					.findViewById(R.id.textView1);
			convertView.setTag(viewHodler);
		} else {
			viewHodler = (ViewHodler) convertView.getTag();
		}
		viewHodler.textView
				.setText(child.get(groupPosition).get(childPosition));
		return convertView;
	}

	@Override
	public boolean isChildSelectable(int groupPosition, int childPosition) {
		// 为false的时候,child不能点击
		return true;
	}

	class ViewHodler {
		TextView textView;
	}

}

3. 引用  

package com.coustom.myex;

import android.os.Bundle;
import android.app.Activity;
import android.graphics.Color;
import android.view.Menu;

public class MainActivity extends Activity {
	private QExListView listView;
	private ExAdapter adapter;

	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.activity_main);
		listView = (QExListView) findViewById(R.id.MyView);
		listView.setCacheColorHint(new Color().GRAY);
		adapter = new ExAdapter(getApplicationContext());
		// listView.setOnChildClickListener(onChildClickListener);
		listView.setAdapter(adapter);
	}

	@Override
	public boolean onCreateOptionsMenu(Menu menu) {
		// Inflate the menu; this adds items to the action bar if it is present.
		getMenuInflater().inflate(R.menu.main, menu);
		return true;
	}

}


4. 引用刚才自定义的View  activity_main.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="fill_parent"
    android:background="#dddddd"
    android:layout_height="fill_parent"
    android:orientation="vertical" >

    <FrameLayout
        android:layout_width="fill_parent"
        android:layout_height="fill_parent" >

        <com.coustom.myex.QExListView
            android:id="@+id/MyView"
            android:layout_width="fill_parent"
            android:layout_height="fill_parent"
            android:cacheColorHint="#000000"
            android:fadingEdge="none"
            android:groupIndicator="@null" >
        </com.coustom.myex.QExListView>
    </FrameLayout>

</LinearLayout>

5. 两个自定义的 item 

① ex_list_parent_item.xml

<?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="match_parent"
    android:background="#CCCCCC"
    android:orientation="vertical" >

    <TextView
        android:id="@+id/textView1"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignParentLeft="true"
        android:text="Large Text"
        android:textAppearance="?android:attr/textAppearanceLarge" />

    <ImageView
        android:id="@+id/imageView1"
        android:layout_width="25dp"
        android:layout_height="30dp"
        android:layout_alignParentRight="true"
        android:layout_alignParentTop="true"
        android:layout_marginRight="37dp"
        android:paddingTop="5dp"
        android:scaleType="center"
        android:src="@drawable/arrow_right" />

</RelativeLayout>

② item_list_artlist.xml

<?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="match_parent"
    android:gravity="center_vertical"
    android:orientation="horizontal"
    android:background="#FAe3e3"
    android:paddingLeft="20dp" >

    <ImageView
        android:id="@+id/imageView1"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:src="@drawable/expande_child_dian" />

    <TextView
        android:id="@+id/textView1"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:paddingLeft="5dp"
        android:text="Large Text"
        android:textAppearance="?android:attr/textAppearanceLarge" />

</LinearLayout>



  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值