RecyclerView适配器多条目

package com.example.myapplication02;


import android.content.Context;
import android.support.v7.widget.RecyclerView;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.ImageView;
import android.widget.LinearLayout;
import android.widget.TextView;


import com.nostra13.universalimageloader.core.ImageLoader;


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


/**
 * Created by 浮生丶 on 2018/5/24 0024.
 */


public class RecyclerViewAdapter extends RecyclerView.Adapter {
    private Context context;
    List<Bean.DataBeanX.DataBean> datas;
    private View view;
    String s="http://365jia.cn/uploads/";
    private final int TYPRONE = 1;
    private final int TYPETWO = 2;
private    a b;
    @Override
    public int getItemViewType(int position) {
        if(position%2==0){
            return TYPRONE;
        } else if(position%2==1){
            return TYPETWO;
        } else {
            return super.getItemViewType(position);
        }
    }
    public RecyclerViewAdapter(Context context, List<Bean.DataBeanX.DataBean> datas) {
        this.context = context;
        this.datas = datas;
    }


    @Override
    public RecyclerView.ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {


        if(viewType==TYPRONE){
            View view = LayoutInflater.from(context).inflate(R.layout.item, null);
            MyViewHloder viewHolderA = new MyViewHloder(view);
            return viewHolderA;
        }else if(viewType==TYPETWO){
            View view = LayoutInflater.from(context).inflate(R.layout.item02, null);
            ViewHolderB viewHolderB = new ViewHolderB(view);
            return viewHolderB;
        }




         return null;




    }


    @Override
    public void onBindViewHolder(RecyclerView.ViewHolder holder, final int position) {
        if(holder instanceof MyViewHloder){
            MyViewHloder vh= (MyViewHloder) holder;
            vh.tv.setText(datas.get(position).getTitle());
            ImageLoader.getInstance().displayImage(s+datas.get(position).getPics().get(0),vh.iv,ImageloaderUtil.getImageOptions());
            vh.itemView.setOnClickListener(new View.OnClickListener() {
                @Override
                public void onClick(View v) {
                    if (b!=null){
                        b.d(position);
                    }
                }
            });


        }else if(holder instanceof ViewHolderB){
            ViewHolderB vh= (ViewHolderB) holder;
            ((ViewHolderB) holder).text.setText(datas.get(position).getTitle());
            vh.itemView.setOnLongClickListener(new View.OnLongClickListener() {
                @Override
                public boolean onLongClick(View v) {
                    if (b!=null){
                        b.d(position);
                    }
                    return false;
                }
            });
         }










    }


    @Override
    public int getItemCount() {
        return datas.size();
    }
    private  class  MyViewHloder extends RecyclerView.ViewHolder{


        private final ImageView iv;
        private final TextView tv;
        public MyViewHloder(View itemView) {
            super(itemView);
            iv = itemView.findViewById(R.id.iv);
            tv = itemView.findViewById(R.id.tv);
        }
    }
    class ViewHolderB extends RecyclerView.ViewHolder{


        TextView text;


        public ViewHolderB(View itemView) {
            super(itemView);
            text= (TextView) itemView.findViewById(R.id.item_text);
        }
    }
    public  interface  a{
        void d(int position);
    }
    public  void e(a c){
        b=c;
    }
    public  void  remv( int position){


        notifyItemRemoved(position);
    }
}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,让我来为你详细介绍一下如何使用Kotlin在安卓应用中编写一个带有多条目RecyclerView,并且可以根据条目的不同点击跳转到不同的Activity。 首先,我们需要在项目的Gradle文件中添加RecyclerView的依赖项: ``` implementation 'androidx.recyclerview:recyclerview:1.2.1' ``` 接下来,我们创建一个名为`MyAdapter`的Kotlin类,并继承`RecyclerView.Adapter`。在类中,我们需要定义一个内部类`ViewHolder`,该类继承自`RecyclerView.ViewHolder`。在`ViewHolder`类中,我们需要定义多个`View`的成员变量,用于显示列表项的不同信息,并且可以设置点击事件。 ``` class MyAdapter(private val data: List<MyData>) : RecyclerView.Adapter<RecyclerView.ViewHolder>() { companion object { const val TYPE_ONE = 1 const val TYPE_TWO = 2 } override fun getItemViewType(position: Int): Int { return data[position].type } override fun onCreateViewHolder(parent: ViewGroup, viewType: Int): RecyclerView.ViewHolder { return when (viewType) { TYPE_ONE -> { val view = LayoutInflater.from(parent.context).inflate(R.layout.list_item_one, parent, false) ViewHolderOne(view) } else -> { val view = LayoutInflater.from(parent.context).inflate(R.layout.list_item_two, parent, false) ViewHolderTwo(view) } } } override fun onBindViewHolder(holder: RecyclerView.ViewHolder, position: Int) { when (holder.itemViewType) { TYPE_ONE -> { val viewHolderOne = holder as ViewHolderOne viewHolderOne.textViewOne.text = data[position].textOne viewHolderOne.itemView.setOnClickListener { val intent = Intent(holder.itemView.context, ActivityOne::class.java) holder.itemView.context.startActivity(intent) } } else -> { val viewHolderTwo = holder as ViewHolderTwo viewHolderTwo.textViewTwo.text = data[position].textTwo viewHolderTwo.itemView.setOnClickListener { val intent = Intent(holder.itemView.context, ActivityTwo::class.java) holder.itemView.context.startActivity(intent) } } } } override fun getItemCount(): Int { return data.size } class ViewHolderOne(view: View) : RecyclerView.ViewHolder(view) { val textViewOne: TextView = view.findViewById(R.id.text_view_one) } class ViewHolderTwo(view: View) : RecyclerView.ViewHolder(view) { val textViewTwo: TextView = view.findViewById(R.id.text_view_two) } } ``` 在`MyAdapter`类中,我们需要实现四个方法:`getItemViewType`、`onCreateViewHolder`、`onBindViewHolder`和`getItemCount`。这些方法分别用于返回当前位置的数据类型、创建新的ViewHolder、绑定数据到ViewHolder和返回列表项的数量。 在`getItemViewType`方法中,我们需要根据当前位置的数据类型返回对应的条目类型。 在`onCreateViewHolder`方法中,我们需要创建一个新的ViewHolder,并为其绑定对应条目类型的布局文件。 在`onBindViewHolder`方法中,我们需要根据当前位置的数据类型获取对应的ViewHolder并将数据绑定到ViewHolder的对应View中,并且可以设置View的点击事件,在点击事件中跳转到对应的Activity。 在`getItemCount`方法中,我们需要返回列表项的数量。 最后,在Fragment中,我们可以使用以下代码来设置RecyclerView的布局和适配器: ``` recyclerView.layoutManager = LinearLayoutManager(activity) recyclerView.adapter = MyAdapter(data) ``` 其中,`data`是一个包含多种数据类型的List,包含了我们想要显示的列表项数据。 这样,我们就成功地使用Kotlin编写了一个带有多条目RecyclerView,并且可以根据条目的不同点击跳转到不同的Activity。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值