RecyclerView是一个高度可定制性的View
本文将使用RecyclerView实现带header的grid
为了用RecyclerView创建一个带header的grid:
1,定义一个具有两种view类型的adapter,一个为header,一个为普通item。
2,nflate一个header,把它传递给adapter。
3,重写GridLayoutManager中的setSpanSizeLookup,在header所处的位置返回和span count (列数)相等的 span size。
import java.util.ArrayList;
import java.util.List;
import com.example.test.R;
import com.widget.view.HeaderAdapter.ViewHolder;
import android.support.v7.widget.RecyclerView;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.TextView;
/**
* 为了用RecyclerView创建一个带header的grid:
1,定义一个具有两种view类型的adapter,一个为header一个为普通item。
2,inflate一个header,把它传递给adapter。
3,重写GridLayoutManager中的setSpanSizeLookup,在header所处的位置返回和span count(列数)相等的 span size。
* @author Administrator
*
*/
public class HeaderAdapter extends RecyclerView.Adapter<ViewHolder> {
private static final int ITEM_VIEW_TYPE_HEADER = 0;
private static final int ITEM_VIEW_TYPE_ITEM = 1;
private final View header;
private final List<String> labels;
public HeaderAdapter(View header, int count) {
if (header == null) {
throw new IllegalArgumentException("header may not be null");
}
this.header = header;
this.labels = new ArrayList<String>(count);
for (int i = 0; i < count; ++i) {
labels.add(String.valueOf(i));
}
}
public boolean isHeader(int position) {
return position == 0;
}
@Override
public ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
if (viewType == ITEM_VIEW_TYPE_HEADER) {
return new ViewHolder(header);
}
View view = LayoutInflater.from(parent.getContext()).inflate(R.layout.list_item, parent, false);
return new ViewHolder(view);
}
@Override
public void onBindViewHolder(final ViewHolder holder, final int position) {
if (isHeader(position)) {
return;
}
final String label = labels.get(position - 1); // Subtract 1 for header
holder.textView.setText(label);
}
@Override
public int getItemViewType(int position) {
return isHeader(position) ? ITEM_VIEW_TYPE_HEADER : ITEM_VIEW_TYPE_ITEM;
}
@Override
public int getItemCount() {
return labels.size() + 1;
}
class ViewHolder extends RecyclerView.ViewHolder implements View.OnClickListener{
public TextView textView;
public ViewHolder(View itemView) {
super(itemView);
if (onItemClickLitener != null){
itemView.setOnClickListener(this);
}
textView = (TextView) itemView.findViewById(R.id.item_0);
}
@Override
public void onClick(View v) {
// TODO Auto-generated method stub
onItemClickLitener.onItemClick(v, getLayoutPosition());//getPosition()被废弃了
}
}
private static OnItemClickLitener onItemClickLitener;
public void setOnItemClickLitener(OnItemClickLitener onItemClickLitener) {
this.onItemClickLitener = onItemClickLitener;
}
public interface OnItemClickLitener {
void onItemClick(View view, int position);
}
}
recyclerView = (RecyclerView) findViewById(R.id.recyclerView);
View header = LayoutInflater.from(this).inflate(R.layout.header_view, recyclerView, false);
final HeaderAdapter adapter = new HeaderAdapter(header, 30);
adapter.setOnItemClickLitener(new HeaderAdapter.OnItemClickLitener() {
@Override
public void onItemClick(View view, int position) {
// TODO Auto-generated method stub
if(adapter.isHeader(position)){
Toast.makeText(context, "header clicked", Toast.LENGTH_SHORT).show();
}else{
Toast.makeText(context, "header item "+(position-1), Toast.LENGTH_SHORT).show();
}
}
});
final GridLayoutManager manager = new GridLayoutManager(this, 3);
manager.setSpanSizeLookup(new GridLayoutManager.SpanSizeLookup() {
@Override
public int getSpanSize(int position) {
return adapter.isHeader(position) ? manager.getSpanCount() : 1;
}
});
recyclerView.setLayoutManager(manager);
recyclerView.setAdapter(adapter);
具体描述看原帖,我只是稍稍改了一下
http://www.open-open.com/lib/view/open1437662138631.html
如果你觉得使用RecyclerView添加Header比较烦,那没办法,就使用这个
HeaderGridView类吧
RecyclerView 必知必会
http://mp.weixin.qq.com/s/CzrKotyupXbYY6EY2HP_dA
分享到:
相关推荐
RxMagicEleme LinearEleme Grid目标Linkage-RecyclerView 的目标是:一行代码即可接入二级联动列表。除了一键接入而省去 99% 不必要的、复杂的、重复的工作外,你还可以从这个开源项目获得的内容包括:整洁的代码...
本篇主要介绍如何在RecyclerView中正确添加头部(Header)和尾部(Footer)视图,并解决在网格(Grid)或瀑布流(瀑布布局通常基于StaggeredGridLayoutManager)中Header和Footer不占满一行的问题。 首先,我们需要...
**Android-SuperSLiM详解:打造可配置的RecyclerView布局管理器** 在Android应用开发中,RecyclerView是一个不可或缺的组件,它允许开发者高效地展示大量数据并实现流畅的滚动效果。而SuperSLiM是一个强大的开源库...
`grid-with-header-list-adapter`库就是为了实现这样的功能而设计的。它允许开发者使用普通的ListView来展示带有标题的网格视图,并且还支持设置背景图像,为用户带来更丰富的视觉体验。 这个库的核心是`...
对于复杂的需求,还可以考虑使用Header/Footer支持的库,如`androidx.recyclerview.widget.RecyclerView`配合`GridLayoutManager`和`SectionedRecyclerViewAdapter`。 总结,自定义GridView表头的关键在于创建一个...
在TwoWay-View中,它不仅支持标准的线性布局,还添加了Grid布局,甚至可以自定义布局管理器,以满足各种复杂的布局需求。 其次,TwoWay-View提供了多种特性,如内置的DraggableAdapter,使得用户可以轻松实现拖放...
此外,还可以通过设置Header和Footer,为GridView添加额外的行。 6. GridView性能优化 - 使用ViewHolder模式:减少 findViewById 的调用,提高列表滑动流畅度。 - 数据加载策略:根据屏幕可见范围动态加载数据,...
2. **顶部栏(Header Bar)**:Facebook的顶部栏通常包含应用的logo、用户头像、通知图标等元素。在Android中,可以使用`Toolbar`组件替代传统的`ActionBar`,因为它提供了更多的自定义选项。可以设置背景图片、添加...
5、带侧滑删除的RecyclerView 支持横向、竖向的ListView、Grid、StaggeredGrid四种全部形式的侧滑,主要是对itemview的自定义,不涉及RecyclerView的太多修改。解决了与Viewpager嵌套的冲突。 6、Design支持库的简单...