RecyclerView无需多说,是用于替代ListView的新控件。它的适配器在于灵活。
现在有一个需求:需要RecyclerView的item支持点击事件,并且下拉到最后时,显示ProgressBar表明正在加载,并加载更多数据。
1.点击事件的实现
先定义一个接口
public interface RecyclerViewClickListener {
void onItemClick(View view,int position);
}
适配器构造函数,增加Click对象的传递
private RecyclerViewClickListener mClickListener; public PostListAdapter(RequestQueue rQueue, RecyclerViewClickListener clickListener) { this.mClickListener = clickListener;
}
创建Item的Holder对象时,传递Click对象到Holder的构造函数中(以下仅保留关键代码)
@Override
public RecyclerView.ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
NormalAnswerHolder holder = new NormalAnswerHolder(
LayoutInflater.from(parent.getContext()).inflate(R.layout.item_home, parent, false), mClickListener);
return holder; }
}
Holder类中处理Click事件
class NormalAnswerHolder extends RecyclerView.ViewHolder implements View.OnClickListener {
private RecyclerViewClickListener mClickListener;
private TextView textViewName;
private TextView textViewCount;
private TextView textViewExcerpt; public NormalAnswerHolder(View view, RecyclerViewClickListener clickListener) {
super(view);
this.mClickListener = clickListener;
textViewName = (TextView) view.findViewById(R.id.tv_name);
textViewCount = (TextView) view.findViewById(R.id.tv_count);
textViewExcerpt = (TextView)view.findViewById(R.id.tv_excerpt); itemView.setOnClickListener(this);
} /**
* Click event.
*
* @param v
*/
@Override
public void onClick(View v) {
if (mClickListener != null) {
mClickListener.onItemClick(v, getPosition());
}
}
}
注意:Holder类的构造函数中获得Click对象后,最基本的需要对itemView设置点击事件。如果需要对item中的subview设置单独的点击事件,就对相应的view设置点击事件即可。
Click事件的调用:
mAdapter = new PostListAdapter(mQueue, new RecyclerViewClickListener() {
@Override
public void onItemClick(View view, int position) {
Intent intent = new Intent(getActivity(), ArticleDetailActivity.class);
Post post = mAdapter.getPost(position);
if (post == null) return;
intent.putExtra(Define.KEY_DATE, post.getDate());
intent.putExtra(Define.KEY_NAME, post.getName());
startActivity(intent);
}
});
注意:如果需要针对不同subview的点击事件处理,在onItemClick中就需要自行依据view类型或者其他tag类标识进行区别自行处理。
2.底部Progressbar加载显示。类似于ListView的适配器,普通情况显示正常item,判断加载的item是否为当前最后一个,如果是当前最后一个,就显示为自定义的Footview,并通知进行数据加载,数据加载完成后刷新。
首先需要定义两种item的Holder,正常的和底部的,然后在适配器中进行判断。
private final int TYPE_ITEM = 0;
private final int TYPE_FOOTER = 1;
定义两个值用于区别不同的holder。
@Override
public int getItemViewType(int position) {
if (position + 1 == getItemCount()) {
return TYPE_FOOTER;
} else { return TYPE_ITEM;
}
}
重载getItemViewType,通过当前位置判断是否要加载FootView。
@Override
public RecyclerView.ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
if (viewType == TYPE_FOOTER) {
FooterViewHolder holder = new FooterViewHolder(
LayoutInflater.from(parent.getContext()).inflate(R.layout.footerview, parent, false));
return holder;
}else{
NormalAnswerWithDateHolder holder = new NormalAnswerWithDateHolder(
LayoutInflater.from(parent.getContext()).inflate(R.layout.item_homewithdate, parent, false), mClickListener);
return holder;
}
}
依据当前不同的类型,加载不同的ViewHolder
触发加载更多,目前只想到利用RecyclerView的setOnScrollListener事件来判断当前滚动的item位置。
mRecyclerView.setOnScrollListener(new RecyclerView.OnScrollListener() {
@Override
public void onScrollStateChanged(RecyclerView recyclerView, int newState) {
super.onScrollStateChanged(recyclerView, newState);
if (newState == RecyclerView.SCROLL_STATE_IDLE
&& mLinearLayoutManager.findLastVisibleItemPosition() + 1
== mAdapter.getItemCount()) {
requestOldData();
}
}
});
完。