如何优雅的实现recycleview加入顶部headerview,实现一起滑动效果

如题所述

 (1)在adapter中定义两个标志量,分别代表header布局和普通布局:
  //header布局标志
  private static final int TYPE_HEADER=0;
  //普通布局标志
  public static final int TYPE_NORMAL=1;
  (2)然后通过get构造器让我们可以通过adapter直接调用构造器直接设置headerview:
  //headerview的布局
  private View mHeaderView;

  public View getmHeaderView() {
  return mHeaderView;
  }
  public void setmHeaderView(View mHeaderView) {
  this.mHeaderView = mHeaderView;
  notifyItemInserted(0);
  }

  (3)接下来重写getviewtype方法,判断是否有headerview,根据是否有headerview返回不同的标志位;
  @Override
  public int getItemViewType(int position) {
  if(mHeaderView==null) return TYPE_NORMAL;
  if(position==0)return TYPE_HEADER;//将header插入到顶部
  return TYPE_NORMAL;
  }
  (4)在onCreateViewHolder根据不同的类型返回不同的viewholder:
  @Override
  public BaseViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
  if(mHeaderView!=null&&viewType==TYPE_HEADER) return new BaseViewHolder(mHeaderView,mHeaderView,null);
  View mView = null;
  mView = mInflater.inflate(itemViewID, null, false);
  return new BaseViewHolder(mView, mHeaderView,monItemClickListener);
  }
  (5)最后在onBindViewHolder方法中根据不同的类型返回不同的布局,
  @Override
  public void onBindViewHolder(BaseViewHolder holder, int position) {
  if(getItemViewType(position)==TYPE_HEADER) return;
  bindData(holder, position);
  }
  (6)最后在baseviewholder中判断itemview是否为headerview,然后让adapter加载不同的viewholder
  public BaseViewHolder(View itemView,View mHeaderView, BaseAdapter.onItemClickListener onItemClickListener) {
  super(itemView);
  this.mHeaderView=mHeaderView;
  if(itemView==mHeaderView) return;
  mViews = new SparseArray<>();
  this.monItemClickListener = onItemClickListener;
  itemView.setOnClickListener(this);
  }
温馨提示:内容为网友见解,仅供参考
无其他回答
相似回答