RecyclerView的多条目加载适配器

package com.bawei.zonghe.adapter;

import android.content.Context;
import android.support.v7.widget.LinearLayoutManager;
import android.support.v7.widget.RecyclerView;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;

import com.bawei.zonghe.R;
import com.bawei.zonghe.bean.NewBean;
import com.bawei.zonghe.utils.BannerImageLoader;
import com.youth.banner.Banner;

import java.util.ArrayList;
import java.util.List;

/**
 * Created by dell-pc on 2017/10/25.
 */

public class MyNewAdapter extends RecyclerView.Adapter<RecyclerView.ViewHolder> {

    private Context context;
    private List<NewBean.StoriesBean> storiesBeanList;
    private List<NewBean.TopStoriesBean> topStoriesBeanList;

    public MyNewAdapter(Context context, List<NewBean.StoriesBean> storiesBeanList, List<NewBean.TopStoriesBean> topStoriesBeanList) {
        this.context = context;
        this.storiesBeanList = storiesBeanList;
        this.topStoriesBeanList = topStoriesBeanList;
    }

    /**
     * 设置多条目布局
     * @param position
     * @return
     */
    @Override
    public int getItemViewType(int position) {
        if(position == 0){
            return 0;
        }else if(position == 1){
            return 1;
        }
        return 1;
    }

    @Override
    public RecyclerView.ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
        if(viewType == 0){
            View view = LayoutInflater.from(context).inflate(R.layout.item_new_banner, parent, false);
            BannerViewHolder bannerViewHolder = new BannerViewHolder(view);
            return bannerViewHolder;
        }else{
            View view1 = LayoutInflater.from(context).inflate(R.layout.item_new_rv, parent, false);
            RecycleViewHolder recycleViewHolder = new RecycleViewHolder(view1);
            return recycleViewHolder;
        }
    }

    @Override
    public void onBindViewHolder(RecyclerView.ViewHolder holder, int position) {
        if(holder instanceof BannerViewHolder){
            BannerViewHolder holder1 = (BannerViewHolder) holder;
            holder1.banner.setImageLoader(new BannerImageLoader());
            List<String> bannerList = new ArrayList<>(); //定义一个存放banner图片的集合
            for(int i = 0;i<topStoriesBeanList.size();i++){
                bannerList.add(topStoriesBeanList.get(i).getImage());
            }
            holder1.banner.setImages(bannerList);
            holder1.banner.setDelayTime(3000);
            holder1.banner.start();
        }else if(holder instanceof RecycleViewHolder){
            RecycleViewHolder holder2 = (RecycleViewHolder) holder;
            holder2.rv.setLayoutManager(new LinearLayoutManager(context));
            MyRecyNewAdapter myRecyNewAdapter = new MyRecyNewAdapter(context, storiesBeanList);
            holder2.rv.setAdapter(myRecyNewAdapter);
        }
    }

    @Override
    public int getItemCount() {
        return 2;
    }

    public class RecycleViewHolder extends RecyclerView.ViewHolder{

        private final RecyclerView rv;

        public RecycleViewHolder(View itemView) {
            super(itemView);
            rv = itemView.findViewById(R.id.rv_new_item);
        }
    }

    public class BannerViewHolder extends RecyclerView.ViewHolder{

        private final Banner banner;

        public BannerViewHolder(View itemView) {
            super(itemView);
            banner = itemView.findViewById(R.id.banner);
        }
    }

}

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在使用 RecyclerView 时,你可以通过自定义适配器来控制数据的绑定和展示。以下是使用自定义适配器的基本步骤: 1. 创建适配器类:首先,你需要创建一个继承自 RecyclerView.Adapter适配器类。在适配器类中,你需要重写几个关键方法,包括 onCreateViewHolder、onBindViewHolder 和 getItemCount。 - onCreateViewHolder:用于创建 RecyclerViewViewHolder 对象。在这个方法中,你需要创建一个自定义的 ViewHolder,并将对应的布局文件进行绑定。 - onBindViewHolder:用于将数据绑定到 ViewHolder 中的视图上。你可以在这个方法中设置文本、图片等视图的内容。 - getItemCount:用于返回数据集合的大小,即要展示的列表项数量。 2. 创建 ViewHolder 类:在适配器中,你需要创建一个继承自 RecyclerView.ViewHolder 的 ViewHolder 类。ViewHolder 类主要用于缓存视图项中的子视图,以便在绑定数据时快速获取。 3. 绑定数据:在 onBindViewHolder 方法中,你可以根据位置获取对应的数据对象,并将数据绑定到 ViewHolder 中的视图上。比如,你可以设置 TextView 的文本、ImageView 的图片等。 4. 设置布局管理器和适配器:在使用 RecyclerView 的 Activity 或 Fragment 中,你需要设置布局管理器和适配器。 - 布局管理器(LayoutManager):RecyclerView 需要一个布局管理器来决定列表项的排列方式,如线性布局、网格布局等。你可以选择合适的布局管理器,并将其设置给 RecyclerView。 - 适配器Adapter):将自定义的适配器实例化,并将其设置给 RecyclerView。 下面是一个简单的示例代码,展示如何使用自定义适配器: ```java public class CustomAdapter extends RecyclerView.Adapter<CustomAdapter.ViewHolder> { private List<String> data; public CustomAdapter(List<String> data) { this.data = data; } @Override public ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) { View view = LayoutInflater.from(parent.getContext()).inflate(R.layout.item_layout, parent, false); return new ViewHolder(view); } @Override public void onBindViewHolder(ViewHolder holder, int position) { String item = data.get(position); holder.textView.setText(item); } @Override public int getItemCount() { return data.size(); } public static class ViewHolder extends RecyclerView.ViewHolder { TextView textView; public ViewHolder(View itemView) { super(itemView); textView = itemView.findViewById(R.id.item_text); } } } ``` 在使用 RecyclerView 的 Activity 或 Fragment 中,你可以这样设置布局管理器和适配器: ```java RecyclerView recyclerView = findViewById(R.id.recycler_view); RecyclerView.LayoutManager layoutManager = new LinearLayoutManager(this); recyclerView.setLayoutManager(layoutManager); CustomAdapter adapter = new CustomAdapter(data); recyclerView.setAdapter(adapter); ``` 以上是使用自定义适配器的基本步骤,你可以根据自己的需求进行相应的修改和扩展。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值