`
libo19881179
  • 浏览: 266529 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

【so easy~】完全仿QQ好友列表,自定义ExpandableListView!

阅读更多

最近,需要做一个可展开的listview,不禁想起了ExpandableListView。但是,在写了一个简单的例子后,发现了问题:

 

ExpandableListView是又多个childList组成的。

当展开的childList过长,又需要打开其他的list时,用户只能先滚动到最上面关掉这个childList,才可能打开其他的childlist!

 

这样的用户体验很差。iPhone做的就很不错,QQ的好友列表顶端 也有类似的导航,显示当前gruop的标签,并且点击就可以关闭当前组,十分方便!

http://androiddada.iteye.com/

 

好了,今天就模仿做了这个,直接上图:


 

 

下面是页面的布局(其他无用的布局我已经去掉了):

 

 

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

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

        <com.customWidget.QExListView
            android:choiceMode="singleChoice"
            android:id="@+id/home_expandableListView"
            android:layout_width="fill_parent"
            android:layout_height="fill_parent"
            android:layout_below="@id/head_line"
            android:cacheColorHint="#00000000"
            android:childDivider="@drawable/list_divider_line"
            android:divider="@drawable/list_divider_line"
            android:dividerHeight="1dip"
            android:fadingEdge="none"
            android:groupIndicator="@null" />
    </FrameLayout>

</LinearLayout>

 这里要说明的是:他的父控件一定要为FrameLayout。因为需要添加在ExpandableListView上层的小导航条!

 

下面是自定义组件QExListView 代码:

 

 

public class QExListView extends ExpandableListView implements OnScrollListener {



	@Override
	public void setAdapter(ExpandableListAdapter adapter) {
		// TODO Auto-generated method stub
		super.setAdapter(adapter);
	}


	private LinearLayout _groupLayout;
	public int _groupIndex = -1;

	/**
	 * @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 = (LinearLayout) getExpandableListAdapter()
						.getGroupView(groupPos, true, null, null);
				_groupLayout.setOnClickListener(new OnClickListener() {

					@Override
					public void onClick(View v) {
						collapseGroup(_groupIndex);
						Home_Act._viewHandler.post(new Runnable() {
							@Override
							public void run() {
								// TODO Auto-generated method stub
								fl.removeView(_groupLayout);
								fl.addView(_groupLayout, new LayoutParams(
										LayoutParams.FILL_PARENT, 50));
							}
						});
					}
				});
				
				
				fl.addView(_groupLayout,fl.getChildCount(), new LayoutParams(
						LayoutParams.FILL_PARENT, 50));

			}
		}
	}

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

}

 


所用的adapter与ExpandableListView一样,这里就不赘述了。

 

大家可以试试,如果发现有bug 可以留言!

 

http://androiddada.iteye.com/

  • 大小: 887.7 KB
11
1
分享到:
评论
41 楼 androidios2014 2015-11-12  
运行有滚没有把分组选项置顶,楼主帮忙给个源码学习719662854@qq.com,谢谢了!
40 楼 l657757077 2014-10-15  
楼主给个源码学习学习。邮箱:657757077@qq.com
39 楼 hao_yh 2014-08-22  
楼主,修改后的代码能发我一份吗?感谢。感觉现在是只要界面创建就会创建第一组的浮动效果。还有怎么事实的更新浮动窗里控件的状态,比如我要放一个checkbox,通过点击改变点击组下面child的状态,现在不会实时的更新,求楼主给思路
38 楼 yaweidai 2013-11-05  
楼主能给个源码吗?260672727@qq.com
学习学习!
37 楼 亚当爱上java 2013-09-23  
f u c k!!
36 楼 ransimon 2013-05-07  
楼主,能发一份给我吗?急需学习学习,谢谢啦!!!! simonran8023@qq.com
35 楼 zb122812210 2013-04-20  
当非常快速滚动的时候,会失灵,不知道有没有办法解决
34 楼 gintama 2013-04-17  
怎么样让list只展开一个,其余的自动闭合,不是点击之后才关闭当前组
33 楼 sdylag 2013-03-24  
学习用,求源码,谢谢——请发邮箱:744303693@qq.com 谢谢。
32 楼 Merrygrass 2012-10-25  
楼主能分享下源码吗?    caymanor@gmail.com
31 楼 对一无二 2012-08-22  
楼主给下源码吧!支持楼主,谢谢!793461835@qq.com
30 楼 liuyong240 2012-08-10  
liuyong240@126.com

谢谢LZ
29 楼 liuyong240 2012-08-10  
可以发份源码吗?
28 楼 对一无二 2012-08-07  
楼主给下源码吧!等着急用,谢谢!793461835@qq.com
27 楼 对一无二 2012-08-07  
楼主给下源码吧(压缩包)!等着急用,谢谢!
26 楼 xiangdream 2012-07-15  
楼主啊,不要只上代码片段啊
25 楼 d19890415 2012-06-29  
给下源码吧,多谢 285275534@qq.com
24 楼 范明正 2012-06-13  
朋友们给个源码吧479187668@163.com
23 楼 symily406 2012-05-30  
请问楼主,这个 Home_Act是在什么地方定义的
22 楼 wujinglun 2012-05-02  
楼主能不能给下源码呀?wujinglun@qq.com

相关推荐

Global site tag (gtag.js) - Google Analytics