ListView有直接添加头布局的方法,而RecyclerView没有,但是并没有关系,RecyclerView的拓展性是很强的。我们可以通过多种方法来添加头布局,下面来说两种。
第一种是直接根据位置判断,在Adapter中重写getItemViewType(int position)方法,根据位置来返回类型,在onCreateViewHolder()方法中通过viewType来判断需要加载哪种布局。详情点此查看RecyclerView加载多种布局。
第二种方法也是我们今天重点介绍的,是根据昨天的XRecyclerView直接进行拓展,而且不用像第一种方法那样特意的进行位置的判断。现在我们来逐步的分析,首先定义一个ArrayList,用于保存多个headerView。
// 拓展的一个列表,添加头部
private ArrayList<View> mHeaderViews = new ArrayList<>();
对外声明一个方法,来添加头部布局
public void addHeaderView(View view) {
mHeaderViews.add(view);
}
修改一下WrapAdapter的构造方法
public WrapAdapter(ArrayList<View> headerViews, ArrayList<View> footViews, RecyclerView.Adapter adapter) {
this.adapter = adapter;
this.mHeaderViews = headerViews;
this.mFootViews = footViews;
}
加一个头部位置的判断
@Override
public void onAttachedToRecyclerView(RecyclerView recyclerView) {
super.onAttachedToRecyclerView(recyclerView);
RecyclerView.LayoutManager manager = recyclerView.getLayoutManager();
if (manager instanceof GridLayoutManager) {
final GridLayoutManager gridManager = ((GridLayoutManager) manager);
gridManager.setSpanSizeLookup(new GridLayoutManager.SpanSizeLookup() {
@Override
public int getSpanSize(int position) {
return (isHeader(position) || isFooter(position))
? gridManager.getSpanCount() : 1;
}
});
}
}
@Override
public void onViewAttachedToWindow(RecyclerView.ViewHolder holder) {
super.onViewAttachedToWindow(holder);
ViewGroup.LayoutParams lp = holder.itemView.getLayoutParams();
if (lp != null
&& lp instanceof StaggeredGridLayoutManager.LayoutParams
&& (isHeader(holder.getLayoutPosition()) || isFooter(holder.getLayoutPosition()))) {
StaggeredGridLayoutManager.LayoutParams p = (StaggeredGridLayoutManager.LayoutParams) lp;
p.setFullSpan(true);
}
}
public boolean isHeader(int position) {
return position >= 0 && position < mHeaderViews.size();
}
在onCreateViewHolder()方法中,通过不同的类型返回不同的布局,在onBindViewHolder()方法中,判断当为头布局的时候不做任何操作,即不需要将头部的布局位置绑定到adapter中。
其实逻辑很简单,结合上一篇RecyclerView的上拉加载,下拉刷新当我们进行简单拓展之后,就会集成RecyclerView的刷新,和添加头布局的功能了。
完整代码https://github.com/hjldev/PullRecyclerView