xml布局为ListView
调用ListView.addHeaderView(view)方法在ListView的上方添加其他组件,多次调用,则按顺序从上向下罗列
其view是一个独立的布局文件
如ListView.addHeaderView(View1);ListView.addHeaderView(View2);
则View1是ListView的第一项,position = 0;View2是ListView的第二项,position = 1;
具体用法 :
以添加是布局是一个Banner为例
1.首先定义View protected ListView listView; protected View headerView; protected Banner banner;
2.初始化:headerView = View.inflate(getActivity(),R.layout.view_banner,null); //view_banner是Banner的布局文件
banner = (Banner)headerView.findViewById(R.id.banner);
3.添加addHeaderView(...)的方法: listView.addHeaderView(headerView);
4.添加ListView的适配器:listView.setAdapter(adapter);
注:
问题1:如果在headerView中存在HorizontalListView(横向滚动的控件),则存在焦点冲突
解决方案:
private float moveX; private float moveY; private float DownX; private float DownY; private long moveTime;
listView.setOnTouchListener(new View.OnTouchListener() { @Override public boolean onTouch(View v, MotionEvent event) { switch (event.getAction()) { case MotionEvent.ACTION_DOWN: DownX = event.getX(); DownY = event.getY(); moveX = 0; moveY = 0; currentMS = System.currentTimeMillis(); break; case MotionEvent.ACTION_MOVE: moveX += Math.abs(event.getX() - DownX); moveY += Math.abs(event.getY() - DownY); DownX = event.getX(); DownY = event.getY(); break; case MotionEvent.ACTION_UP: moveTime = System.currentTimeMillis(); if (moveTime > 200 && (moveX > 20 || moveY > 20)) { return true; } break; } return false; } });
问题2:增加headerView后,ListView滑动不流畅
解决方法:重写ListView,设置ListView为不可滑动,在ListView外套一个ScrollView
重写的ListView如下
public class NoScrollListView extends ListView { public NoScrollListView(Context context) { super(context); } public NoScrollListView(Context context, AttributeSet attrs) { super(context, attrs); } public NoScrollListView(Context context, AttributeSet attrs, int defStyle) { super(context, attrs, defStyle); } @Override protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) { int expandSpec = MeasureSpec.makeMeasureSpec(Integer.MAX_VALUE >>2, MeasureSpec.AT_MOST); super.onMeasure(widthMeasureSpec, expandSpec); } }