上一篇文章已经介绍过了RecyclerView的基本使用方法,原文如下:android RecyclerView布局真的只是那么简单!此篇文章算是对RecyclerView更深使用的介绍。
FootView和HeadView在ListView中的本身就有相对应的函数,但是在新潮的RecyclerView中却没有了,FootView在分页加载(上拉加载更多)中起着很重要的作用,因此也必须要学习一下了。(HeadView的添加与FootView的添加相比大致一样,在此就只讲FootView的添加了)
int getItemViewType(int position):此函数是RecyclerView中自带的函数,参数为每个item的position,返回一个int类型表示类型。
此函数的作用是区分普通的item与FootView的Item,让FootView这个Item能一直处在adapter中的最下端。
在例子中定义了两种类型如下:
//两个final int类型表示ViewType的两种类型
private final int NORMAL_TYPE = 0;
private final int FOOT_TYPE = 1111;
该函数如下:
@Override
public int getItemViewType(int position) {
if (position == max_count - 1) {
return FOOT_TYPE;
}
return NORMAL_TYPE;
}
1、定义getItemViewType(int position)并且定义自己所需要的ViewType的类型。
2、在定义ViewHolder(),**onCreateViewHolder()和onBindViewHolder()**中都考虑两种情况,一种是普通的item,另一种是FootView。
另外默认的ViewHolder()函数中只会有View itemView一个参数,此处因为需要,所以要添加int viewType的参数,代码中如下:
//初始化viewHolder,此处绑定后在onBindViewHolder中可以直接使用
public ViewHolder(View itemView, int viewType) {
super(itemView);
if (viewType == NORMAL_TYPE) {
tvViewHolder = (TextView) itemView.findViewById(R.id.tv_view_holder);
llViewHolder = (LinearLayout) itemView;
} else if (viewType == FOOT_TYPE) {
tvFootView = (TextView) itemView;
}
}
此处再说一下三个函数的大致作用:
将item布局中的控件与ViewHolder中所定义的属性绑定,更便于在**onBindViewHolder()**中使用。
此函数用来创建每一个item,最后返回的不是view,而是返回的一个ViewHolder。
此函数中一般用来将数据绑定到item中的控件中。
结合以上分析看代码,读者应该比较容易理解了,下面附上关键adapter代码和源码地址:
public class RecyclerAdapter extends RecyclerView.Adapter {
private List mData;//数据
private int max_count = 10;//最大显示数
private Boolean isFootView = false;//是否添加了FootView
private String footViewText = "";//FootView的内容
//两个final int类型表示ViewType的两种类型
private final int NORMAL_TYPE = 0;
private final int FOOT_TYPE = 1111;
public RecyclerAdapter(List data) {
mData = data;
}
public class ViewHolder extends RecyclerView.ViewHolder {
public TextView tvViewHolder;
public LinearLayout llViewHolder;
public TextView tvFootView;//footView的TextView属于独自的一个layout
//初始化viewHolder,此处绑定后在onBindViewHolder中可以直接使用
public ViewHolder(View itemView, int viewType) {
super(itemView);
if (viewType == NORMAL_TYPE) {
tvViewHolder = (TextView) itemView.findViewById(R.id.tv_view_holder);
llViewHolder = (LinearLayout) itemView;
} else if (viewType == FOOT_TYPE) {
tvFootView = (TextView) itemView;
}
}
}
@Override
public ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
View normal_views = LayoutInflater.from(parent.getContext()).inflate(
R.layout.rc_item, parent, false);
View foot_view = LayoutInflater.from(parent.getContext()).inflate(
R.layout.foot_view, parent, false);
if (viewType == FOOT_TYPE)
return new ViewHolder(foot_view, FOOT_TYPE);
return new ViewHolder(normal_views, NORMAL_TYPE);
}
@Override
public int getItemViewType(int position) {
if (position == max_count - 1) {
return FOOT_TYPE;
}
return NORMAL_TYPE;
}
@Override
public void onBindViewHolder(ViewHolder holder, int position) {
//建立起ViewHolder中试图与数据的关联
Log.d("xjj", getItemViewType(position) + "");
//如果footview存在,并且当前位置ViewType是FOOT_TYPE
if (isFootView && (getItemViewType(position) == FOOT_TYPE)) {
holder.tvFootView.setText(footViewText);
} else {
holder.tvViewHolder.setText(mData.get(position) + position);
}
}
@Override
public int getItemCount() {
if (mData.size() < max_count) {
return mData.size();
}
return max_count;
}
//创建一个方法来设置footView中的文字
public void setFootViewText(String footViewText) {
isFootView = true;
this.footViewText = footViewText;
}
}
下一篇文章中,笔者在此基础上做了一下一点改动,很容易就实现了分页加载的功能,文章地址如下:
http://blog.csdn.net/double2hao/article/details/52788708
源码地址:http://download.csdn.net/detail/double2hao/9650717