Recyclerview如何添加头布局和尾布局、item点击事件

这篇文章主要介绍了Recyclerview如何添加头布局和尾布局、item点击事件,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。

创新互联公司于2013年开始,公司以成都网站建设、成都做网站、系统开发、网络推广、文化传媒、企业宣传、平面广告设计等为主要业务,适用行业近百种。服务企业客户1000多家,涉及国内多个省份客户。拥有多年网站建设开发经验。为企业提供专业的网站建设、创意设计、宣传推广等服务。 通过专业的设计、独特的风格,为不同客户提供各种风格的特色服务。

思路:

主要重写Recyclerview.Adapter中的一些方法

1.public int getItemCount()  item熟练  +2(头布局和尾布局)

2.public int getItemViewType(int position)   判断position 设置itemType

3.创建不同的ViewHolder,分别用来加载头布局,正常布局,尾布局

4.public RecyclerView.ViewHolder onCreateViewHolder(ViewGroup parent, int viewType)  根据viewType的不同返回不同的viewholder

5.public void onBindViewHolder(RecyclerView.ViewHolder holder, int position)  根据holder的不同绑定不同的数据 

案例:

主布局中只有一个Recyclerview,里面的item除了基本的两种类型,还有头布局和尾布局,点击基本类型跳转到另外一个Activity,显示图片

Recyclerview如何添加头布局和尾布局、item点击事件

下面主要贴出Adapter和MainActivity中的代码,其他的布局文件,类比较简单就不贴出了

1.Adapter

public class MyAdapter extends RecyclerView.Adapter implements View.OnClickListener {
 private Context context;
 private List datas;

 private static final int ITEM_ONE=1;
 private static final int ITEM_TWO=2;
 private static final int ITEM_HEAD=3;
 private static final int ITEM_FOOT=4;

 private int headViewCount=1;
 private int footViewCount=1;

 private OnItemClickListener onItemClickListener;


 public MyAdapter(Context context, List datas) {
  this.context = context;
  this.datas = datas;
 }


 @Override
 public RecyclerView.ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
  if(viewType==ITEM_HEAD){
   View view= LayoutInflater.from(context).inflate(R.layout.item_head,parent,false);
   return new HeaderViewHolder(view);
  }else if(viewType==ITEM_FOOT){
   View view=LayoutInflater.from(context).inflate(R.layout.item_foot,parent,false);
   return new FootViewHolder(view);
  }

  else if(viewType==ITEM_ONE){
   View view= LayoutInflater.from(context).inflate(R.layout.item_recyclerview,parent,false);
   return new ViewHolder(view);
  }else if(viewType==ITEM_TWO){
   View view=LayoutInflater.from(context).inflate(R.layout.item_recyclerview2,parent,false);
   return new ViewHolder(view);
  }

  return null;

 }

 @Override
 public void onBindViewHolder(RecyclerView.ViewHolder holder, final int position) {
  if(holder instanceof HeaderViewHolder){

  }else if(holder instanceof FootViewHolder){

  }

  else if(holder instanceof ViewHolder){
   //注意除去头布局
   holder.itemView.setTag(position-1);
   holder.itemView.setOnClickListener(this);
   ((ViewHolder)holder).img.setBackgroundResource(datas.get(position-1).getImgId());
   ((ViewHolder)holder).tv1.setText(datas.get(position-1).getName());
   ((ViewHolder)holder).tv2.setText(datas.get(position-1).getDetail());
  }
 }


 @Override
 public int getItemCount() {
  if(datas==null){
   return headViewCount+footViewCount;
  }
  return datas.size()+headViewCount+footViewCount;
 }

 @Override
 public int getItemViewType(int position) {
  if(isHeadView(position)){
   return ITEM_HEAD;
  }
  if(isFootView(position)){
   return ITEM_FOOT;
  }

  if(position%2==0){
   return ITEM_ONE;
  }else{
   return ITEM_TWO;
  }
 }

 public boolean isHeadView(int position){

  return headViewCount!=0&&position=(datas.size()+headViewCount);
 }

 @Override
 public void onClick(View view) {
  if(onItemClickListener!=null){
   onItemClickListener.onItemClick(view, (Integer) view.getTag());
  }
 }


 class ViewHolder extends RecyclerView.ViewHolder{
   TextView tv1,tv2;
   ImageView img;

  public ViewHolder(View itemView) {
   super(itemView);
   tv1=itemView.findViewById(R.id.tv1);
   tv2=itemView.findViewById(R.id.tv2);
   img=itemView.findViewById(R.id.img);
  }
 }
 class HeaderViewHolder extends RecyclerView.ViewHolder{

  public HeaderViewHolder(View itemView) {
   super(itemView);
  }
 }
 class FootViewHolder extends RecyclerView.ViewHolder{

  public FootViewHolder(View itemView) {
   super(itemView);
  }
 }

 public void setOnItemClickListener(OnItemClickListener onItemClickListener){
  this.onItemClickListener=onItemClickListener;
 }

 interface OnItemClickListener{
  void onItemClick(View view,int position);
 }
} 

2.MainActivity

public class MainActivity extends AppCompatActivity implements MyAdapter.OnItemClickListener {
 private RecyclerView recyclerView;

 private List datas;
 private MyAdapter adapter;
 
 private int[] imgs={R.drawable.p1,R.drawable.p2,R.drawable.p3,R.drawable.p4,R.drawable.p5,R.drawable.pic1,
   R.drawable.pic2,R.drawable.pic3,R.drawable.pic4,R.drawable.pic5,R.drawable.pic6};

 @Override
 protected void onCreate(Bundle savedInstanceState) {
  super.onCreate(savedInstanceState);
  setContentView(R.layout.activity_main);
  recyclerView= (RecyclerView) findViewById(R.id.recyclerview);
  initData();
  initRecyclerView();
 }

 private void initRecyclerView() {
  recyclerView.setLayoutManager(new LinearLayoutManager(this));
  adapter=new MyAdapter(this,datas);
  adapter.setOnItemClickListener(this);
  recyclerView.setAdapter(adapter);

 }

 private void initData() {
  datas=new ArrayList<>();
  for(int i=0;i

感谢你能够认真阅读完这篇文章,希望小编分享的“Recyclerview如何添加头布局和尾布局、item点击事件”这篇文章对大家有帮助,同时也希望大家多多支持创新互联,关注创新互联行业资讯频道,更多相关知识等着你来学习!


分享标题:Recyclerview如何添加头布局和尾布局、item点击事件
标题网址:http://csdahua.cn/article/ighejs.html
扫二维码与项目经理沟通

我们在微信上24小时期待你的声音

解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流